MrShi
2025-06-27 3b41ed97d0f72cfd58de069da283f2f7ee3f09a5
server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java
@@ -3,21 +3,32 @@
import com.doumee.api.BaseController;
import com.doumee.core.annotation.excel.ExcelExporter;
import com.doumee.core.annotation.pr.PreventRepeat;
import com.doumee.core.constants.ResponseStatus;
import com.doumee.core.exception.BusinessException;
import com.doumee.core.model.ApiResponse;
import com.doumee.core.model.PageWrap;
import com.doumee.core.model.PageData;
import com.doumee.core.utils.Constants;
import com.doumee.core.utils.DateUtil;
import com.doumee.dao.business.dto.ApplyChangeCyclePriceDTO;
import com.doumee.dao.business.model.ApplyChange;
import com.doumee.dao.business.model.InsuranceApply;
import com.doumee.dao.business.vo.CountCyclePriceVO;
import com.doumee.service.business.ApplyChangeService;
import com.doumee.service.business.InsuranceApplyService;
import com.doumee.service.business.impl.UnionChangeServiceImpl;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.authz.annotation.RequiresPermissions;    
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.CollectionUtils;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Objects;
/**
 * @author 江蹄蹄
@@ -31,6 +42,12 @@
    @Autowired
    private ApplyChangeService applyChangeService;
    @Autowired
    private InsuranceApplyService insuranceApplyService;
    @Autowired
    private UnionChangeServiceImpl unionChangeServiceImpl;
    @PreventRepeat
    @ApiOperation("新建")
    @PostMapping("/create")
@@ -39,7 +56,7 @@
        return ApiResponse.success(applyChangeService.create(applyChange));
    }
    @PreventRepeat
    @ApiOperation("平台退回投保")
    @ApiOperation("平台退回申请")
    @PostMapping("/back")
    @RequiresPermissions("business:applychange:back")
    public ApiResponse back(@RequestBody ApplyChange applyChange) {
@@ -57,7 +74,9 @@
    @PostMapping("/uploadPidan")
    @RequiresPermissions("business:applychange:uploadPidan")
    public ApiResponse uploadPidan(@RequestBody ApplyChange applyChange) {
        return ApiResponse.success(applyChangeService.uploadPidan(applyChange));
        Integer applyId = applyChangeService.uploadPidan(applyChange);
        insuranceApplyService.updateApplyCurrentFee(applyId,null);
        return ApiResponse.success(null);
    }
    @PreventRepeat
    @ApiOperation("平台修改批单")
@@ -78,6 +97,13 @@
    public ApiResponse<String> getChangeUnitSignLink (@RequestBody ApplyChange model, HttpServletResponse response) {
        return ApiResponse.success( applyChangeService.getSignLinkChangeUnit(model));
    }
    @ApiOperation("列表查询")
    @PostMapping("/list")
    @RequiresPermissions("business:applychange:query")
    public ApiResponse<List<ApplyChange>> list (@RequestBody ApplyChange applyChange) {
        return ApiResponse.success(applyChangeService.findListForCompany(applyChange));
    }
    @ApiOperation("根据ID删除")
    @GetMapping("/delete/{id}")
    @RequiresPermissions("business:applychange:delete")
@@ -141,4 +167,46 @@
    public ApiResponse<ApplyChange> findById(@PathVariable Integer id) {
        return ApiResponse.success(applyChangeService.findDetail(id));
    }
    @ApiOperation("查询月度统计数据")
    @PostMapping("/monthList")
    @RequiresPermissions("business:applychange:query")
    public ApiResponse<List<ApplyChange>> findPage (@RequestBody ApplyChange pageWrap) {
        return ApiResponse.success(applyChangeService.monthTotalList(pageWrap));
    }
    @ApiOperation("加减保业务补充金额")
    @PostMapping("/getChangeCountCyclePriceVO")
    public ApiResponse<CountCyclePriceVO> getChangeCountCyclePriceVO (@RequestBody ApplyChangeCyclePriceDTO applyChangeCyclePriceDTO) {
        applyChangeCyclePriceDTO.setValidTime(DateUtil.getMontageDate(new Date(),1));
        return ApiResponse.success("操作成功",applyChangeService.getChangeCountCyclePriceVO(applyChangeCyclePriceDTO));
    }
    @ApiOperation("商户审核 - 委托保业务")
    @PostMapping("/check")
    @RequiresPermissions("business:applychange:check")
    public ApiResponse check(@RequestBody ApplyChange model) {
        return ApiResponse.success(applyChangeService.check(model,unionChangeServiceImpl));
    }
    @ApiOperation("导出保单下所有加减保详情单")
    @PostMapping("/exportApplyJiajianBaoExcel")
    @RequiresPermissions("business:applychange:exportExcel")
    public void exportApplyJiajianBaoExcel (@RequestBody InsuranceApply insuranceApply, HttpServletResponse response) {
        insuranceApply = insuranceApplyService.findDetail(insuranceApply.getId());
        if(Objects.isNull(insuranceApply)){
            throw new BusinessException(com.doumee.core.constants.ResponseStatus.DATA_EMPTY);
        }
        List<ApplyChange> applyChangeList = applyChangeService.findListByApplyId(insuranceApply.getId(), Constants.ZERO);
        List<ApplyChange> excelList = new ArrayList<>();
        if(CollectionUtils.isEmpty(applyChangeList)){
            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"无可导出的加减保记录");
        }else{
            for (ApplyChange applyChange:applyChangeList) {
                excelList.add(applyChangeService.exportJiajianBaoExcel(applyChange));
            }
        }
        ExcelExporter.build(ApplyChange.class).exportApplyJiajianBaoExcel(insuranceApply,excelList,   response);
    }
}