package com.doumee.api.business; import com.doumee.api.BaseController; import com.doumee.core.annotation.excel.ExcelExporter; import com.doumee.core.annotation.pr.PreventRepeat; import com.doumee.core.constants.Constants; import com.doumee.core.model.ApiResponse; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.dao.business.model.Member; import com.doumee.service.business.MemberService; import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.math.BigDecimal; import java.util.ArrayList; import java.util.List; import java.util.Objects; /** * @author 江蹄蹄 * @date 2025/07/09 12:00 */ @Api(tags = "会员信息表") @RestController @RequestMapping("/business/member") public class MemberController extends BaseController { @Autowired private MemberService memberService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("business:member:create") public ApiResponse create(@RequestBody Member member) { return ApiResponse.success(memberService.create(member)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("business:member:delete") public ApiResponse deleteById(@PathVariable Integer id) { memberService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("business:member:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(Integer.valueOf(id)); } memberService.deleteByIdInBatch(idList); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("business:member:update") public ApiResponse updateById(@RequestBody Member member) { memberService.updateById(member); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("business:member:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(memberService.findPage(pageWrap)); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("business:member:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { List memberList = memberService.findPage(pageWrap).getRecords(); if(CollectionUtils.isNotEmpty(memberList)){ for (Member m:memberList) { m.setAmountYuan(Objects.nonNull(m.getAmount())&&m.getAmount()> Constants.ZERO? new BigDecimal(m.getAmount()+"").divide(new BigDecimal("100"),2,BigDecimal.ROUND_UP):BigDecimal.ZERO); List identityInfo = new ArrayList<>(); if(Constants.equalsInteger(m.getWorkerIdentity(),Constants.TWO)){ identityInfo.add("工人"); } if(Constants.equalsInteger(m.getDriverIdentity(),Constants.TWO)){ identityInfo.add("司机"); } if(Constants.equalsInteger(m.getChefIdentity(),Constants.TWO)){ identityInfo.add("供餐"); } m.setIdentityApplyInfo(StringUtils.join(identityInfo,",")); m.setIdentityInfo("发单方" + (StringUtils.isNotBlank(m.getIdentityApplyInfo())?" | 接单方":"")); } } ExcelExporter.build(Member.class).export(memberList, "会员信息表", response); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("business:member:query") public ApiResponse findById(@PathVariable Integer id) { return ApiResponse.success(memberService.findById(id)); } }