From 5ecb8706b917aa86f43e44a412e86e3e50b636c0 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期一, 09 六月 2025 09:54:04 +0800 Subject: [PATCH] 提交一把订单 --- server/platform/src/main/java/com/doumee/api/business/ApplyChangeController.java | 130 ++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 126 insertions(+), 4 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 9f1a364..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,20 +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 姹熻箘韫� @@ -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