From a01d637e9ff2bf26aa44c65a239413a38bd8b1fe Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期三, 04 六月 2025 09:39:13 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/2.0.1' into 2.0.1

---
 server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java |  134 ++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 128 insertions(+), 6 deletions(-)

diff --git a/server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java b/server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java
index 939d177..e0dd6fb 100644
--- a/server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java
+++ b/server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java
@@ -3,26 +3,38 @@
 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 姹熻箘韫�
- * @date 2024/01/15 11:15
+ * @date 2024/01/16 10:03
  */
-@Api(tags = "鍔犲噺淇濈敵璇蜂俊鎭〃")
+@Api(tags = "鍔犲噺淇濇崲鍘傜敵璇蜂俊鎭〃")
 @RestController
 @RequestMapping("/business/applyChange")
 public class ApplyChangeController extends BaseController {
@@ -30,12 +42,66 @@
     @Autowired
     private ApplyChangeService applyChangeService;
 
+    @Autowired
+    private InsuranceApplyService insuranceApplyService;
+
+    @Autowired
+    private UnionChangeServiceImpl unionChangeServiceImpl;
+
     @PreventRepeat
     @ApiOperation("鏂板缓")
     @PostMapping("/create")
     @RequiresPermissions("business:applychange:create")
     public ApiResponse create(@RequestBody ApplyChange applyChange) {
         return ApiResponse.success(applyChangeService.create(applyChange));
+    }
+    @PreventRepeat
+    @ApiOperation("骞冲彴閫�鍥炵敵璇�")
+    @PostMapping("/back")
+    @RequiresPermissions("business:applychange:back")
+    public ApiResponse back(@RequestBody ApplyChange applyChange) {
+        return ApiResponse.success(applyChangeService.back(applyChange));
+    }
+    @PreventRepeat
+    @ApiOperation("骞冲彴澶勭悊閫�鍥炵敵璇�")
+    @PostMapping("/dealBackApply")
+    @RequiresPermissions("business:applychange:dealBackApply")
+    public ApiResponse dealBackApply(@RequestBody ApplyChange applyChange) {
+        return ApiResponse.success(applyChangeService.dealBackApply(applyChange));
+    }
+    @PreventRepeat
+    @ApiOperation("骞冲彴涓婁紶鎵瑰崟")
+    @PostMapping("/uploadPidan")
+    @RequiresPermissions("business:applychange:uploadPidan")
+    public ApiResponse uploadPidan(@RequestBody ApplyChange applyChange) {
+        Integer applyId = applyChangeService.uploadPidan(applyChange);
+        insuranceApplyService.updateApplyCurrentFee(applyId,null);
+        return ApiResponse.success(null);
+    }
+    @PreventRepeat
+    @ApiOperation("骞冲彴淇敼鎵瑰崟")
+    @PostMapping("/editPidan")
+    @RequiresPermissions("business:applychange:uploadPidan")
+    public ApiResponse editPidan(@RequestBody ApplyChange applyChange) {
+        return ApiResponse.success(applyChangeService.editPidan(applyChange));
+    }
+    @ApiOperation("鑾峰彇鍔犲噺淇濈绔犲湴鍧�")
+    @PostMapping("/getJiajianBaoSignLink")
+    @RequiresPermissions("business:applychange:sign")
+    public ApiResponse<String> getSignLinkJiajiabao (@RequestBody ApplyChange model, HttpServletResponse response) {
+        return ApiResponse.success( applyChangeService.getSignLinkJiajiabao(model));
+    }
+    @ApiOperation("鑾峰彇缂撳瓨鐢宠绛剧珷鍦板潃")
+    @PostMapping("/getChangeUnitSignLink")
+    @RequiresPermissions("business:applychange:sign")
+    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鍒犻櫎")
@@ -71,20 +137,76 @@
     @PostMapping("/page")
     @RequiresPermissions("business:applychange:query")
     public ApiResponse<PageData<ApplyChange>> findPage (@RequestBody PageWrap<ApplyChange> pageWrap) {
-        return ApiResponse.success(applyChangeService.findPage(pageWrap));
+        return ApiResponse.success(applyChangeService.findPageForCompany(pageWrap));
     }
 
     @ApiOperation("瀵煎嚭Excel")
     @PostMapping("/exportExcel")
     @RequiresPermissions("business:applychange:exportExcel")
     public void exportExcel (@RequestBody PageWrap<ApplyChange> pageWrap, HttpServletResponse response) {
-        ExcelExporter.build(ApplyChange.class).export(applyChangeService.findPage(pageWrap).getRecords(), "鍔犲噺淇濈敵璇蜂俊鎭〃", response);
+        ExcelExporter.build(ApplyChange.class).export(applyChangeService.findPageForCompany(pageWrap).getRecords(), "鍔犲噺淇濇崲鍘傜敵璇蜂俊鎭〃", response);
     }
+
+    @ApiOperation("瀵煎嚭鍔犲噺淇濊鎯呭崟")
+    @PostMapping("/exportJiajianBaoExcel")
+    @RequiresPermissions("business:applychange:exportExcel")
+    public void exportJiajianBaoExcel (@RequestBody ApplyChange model, HttpServletResponse response) {
+        ExcelExporter.build(ApplyChange.class).exportJiajianBaoExcel(applyChangeService.exportJiajianBaoExcel(model),   response);
+    }
+    @ApiOperation("瀵煎嚭鎹㈠巶鐢宠璇︽儏鍗�")
+    @PostMapping("/exportChangeUnitExcel")
+    @RequiresPermissions("business:applychange:exportExcel")
+    public void exportChangeUnitExcel (@RequestBody ApplyChange model, HttpServletResponse response) {
+        ExcelExporter.build(ApplyChange.class).exportChangeUnitExcel(applyChangeService.exportChangeUnitExcel(model),   response);
+    }
+
 
     @ApiOperation("鏍规嵁ID鏌ヨ")
     @GetMapping("/{id}")
     @RequiresPermissions("business:applychange:query")
-    public ApiResponse findById(@PathVariable Integer id) {
-        return ApiResponse.success(applyChangeService.findById(id));
+    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);
+    }
+
 }

--
Gitblit v1.9.3