From ac3587fec379a08d94d30b0a13e67e10612b3b06 Mon Sep 17 00:00:00 2001 From: nidapeng <jp@doumee.com> Date: 星期一, 01 四月 2024 15:24:32 +0800 Subject: [PATCH] 提交一把 --- server/service/src/main/java/com/doumee/service/business/impl/UnionApplyServiceImpl.java | 188 ++++++++++++++++++++++++++++++++++++---------- 1 files changed, 147 insertions(+), 41 deletions(-) diff --git a/server/service/src/main/java/com/doumee/service/business/impl/UnionApplyServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/UnionApplyServiceImpl.java index 5327580..75d7444 100644 --- a/server/service/src/main/java/com/doumee/service/business/impl/UnionApplyServiceImpl.java +++ b/server/service/src/main/java/com/doumee/service/business/impl/UnionApplyServiceImpl.java @@ -10,18 +10,13 @@ import com.doumee.core.utils.Constants; import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; -import com.doumee.dao.business.CompanyMapper; -import com.doumee.dao.business.MultifileMapper; -import com.doumee.dao.business.SolutionsMapper; -import com.doumee.dao.business.UnionApplyMapper; -import com.doumee.dao.business.dto.SaveUnionApplyDTO; -import com.doumee.dao.business.dto.UnionApplyBXDDDetailTO; -import com.doumee.dao.business.dto.UnionApplyBXDDTO; -import com.doumee.dao.business.dto.UploadMultifileDTO; +import com.doumee.dao.business.*; +import com.doumee.dao.business.dto.*; import com.doumee.dao.business.join.ApplyDetailJoinMapper; import com.doumee.dao.business.join.InsuranceApplyJoinMapper; import com.doumee.dao.business.join.UnionApplyJoinMapper; import com.doumee.dao.business.model.*; +import com.doumee.service.business.SmsEmailService; import com.doumee.service.business.UnionApplyService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; @@ -33,9 +28,10 @@ import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import org.springframework.util.CollectionUtils; +import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import java.math.BigDecimal; import java.util.ArrayList; @@ -78,6 +74,14 @@ @Autowired private SignService signService; + + @Autowired + private SmsEmailService smsEmailService; + @Autowired + private ApplyLogMapper applyLogMapper; + + @Value("${debug_model}") + private boolean debugModel; @Override public Integer create(UnionApply unionApply) { @@ -142,13 +146,18 @@ MPJLambdaWrapper<UnionApply> queryWrapper = new MPJLambdaWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); queryWrapper.selectAll(UnionApply.class); + queryWrapper.selectAs(Solutions::getName,UnionApply::getSolutionName); + queryWrapper.select("(select count(b.id) from apply_detail b where b.isdeleted=0 and b.union_apply_id=t.id) as insureNum "); queryWrapper.leftJoin(Solutions.class,Solutions::getId,UnionApply::getSolutionId); LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); - if(user.getType().equals(Constants.TWO)){ - queryWrapper.eq(UnionApply::getCompanyId, pageWrap.getModel().getCompanyId()); + if(Constants.equalsInteger(user.getType(),Constants.TWO)){ + queryWrapper.eq(UnionApply::getCompanyId, user.getCompanyId()); } if (pageWrap.getModel().getId() != null) { queryWrapper.eq(UnionApply::getId, pageWrap.getModel().getId()); + } + if (pageWrap.getModel().getSolutionId() != null) { + queryWrapper.eq(UnionApply::getSolutionId, pageWrap.getModel().getSolutionId()); } if (pageWrap.getModel().getCreator() != null) { queryWrapper.eq(UnionApply::getCreator, pageWrap.getModel().getCreator()); @@ -214,16 +223,29 @@ } if (pageWrap.getModel().getSignApplyNo() != null) { queryWrapper.eq(UnionApply::getSignApplyNo, pageWrap.getModel().getSignApplyNo()); - } - for(PageWrap.SortData sortData: pageWrap.getSorts()) { - if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { - queryWrapper.orderByDesc(sortData.getProperty()); - } else { - queryWrapper.orderByAsc(sortData.getProperty()); + }if(pageWrap.getSorts().size() == 0){ + queryWrapper.orderByDesc(UnionApply::getCreateDate ); + }else { + for(PageWrap.SortData sortData: pageWrap.getSorts()) { + if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { + queryWrapper.orderByDesc(sortData.getProperty()); + } else { + queryWrapper.orderByAsc(sortData.getProperty()); + } } } + PageData<UnionApply> pageData = PageData.from(unionApplyJoinMapper.selectJoinPage(page,UnionApply.class, queryWrapper)); + if(pageData!=null && pageData.getRecords()!=null){ + for(UnionApply model : pageData.getRecords()){ + initStatusInfo(model); + } + } return pageData; + } + + private void initStatusInfo(UnionApply model) { + model.setStatusInfo(Constants.UnionApplyStatus.getName(Constants.formatIntegerNum(model.getStatus()))); } @Override @@ -261,6 +283,7 @@ unionApply.setServiceDays(DateUtil.daysBetweenDates(new Date(),unionApply.getStartTime())+1); } } + initStatusInfo(unionApply); return unionApply; } @@ -268,6 +291,7 @@ @Override + @Transactional(rollbackFor ={BusinessException.class,Exception.class} ) public Integer merge(SaveUnionApplyDTO saveUnionApplyDTO){ LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(!user.getType().equals(Constants.TWO)){ @@ -275,19 +299,30 @@ } if(Objects.isNull(saveUnionApplyDTO) || Objects.isNull(saveUnionApplyDTO.getApplyIds()) + || saveUnionApplyDTO.getApplyIds().size() == 0 || Objects.isNull(saveUnionApplyDTO.getStartDate()) || Objects.isNull(saveUnionApplyDTO.getEndDate()) + || saveUnionApplyDTO.getStartDate().getTime()>saveUnionApplyDTO.getEndDate().getTime() || Objects.isNull(saveUnionApplyDTO.getBaseSolutionId()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } + Solutions solutions = solutionsMapper.selectOne(new QueryWrapper<Solutions>().lambda(). + eq(Solutions::getType,Constants.ONE) + .eq(Solutions::getIsdeleted,Constants.ZERO) + .eq(Solutions::getDataType,Constants.ZERO) + .eq(Solutions::getBaseId,saveUnionApplyDTO.getBaseSolutionId())); + //鏌ヨ鏂规鏁版嵁 + if(solutions == null){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝鏂规淇℃伅鏈夎锛岃鍒锋柊椤甸潰閲嶈瘯"); + } List<InsuranceApply> insuranceApplyList = insuranceApplyJoinMapper.selectJoinList(InsuranceApply.class, new MPJLambdaWrapper<InsuranceApply>() .selectAll(InsuranceApply.class) - .selectAs(InsuranceApply::getSolutionBaseId,Solutions::getBaseId) + .selectAs(Solutions::getBaseId,InsuranceApply::getSolutionBaseId) .leftJoin(Solutions.class,Solutions::getId,InsuranceApply::getSolutionId) .eq(InsuranceApply::getIsdeleted, Constants.ZERO) - .eq(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.COMPANY_MEMBER_LIST_SIGNATURE.getKey()) + .eq(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.WTB_BUSINESS_CHECK_PASS.getKey()) .eq(Solutions::getBaseId,saveUnionApplyDTO.getBaseSolutionId()) .in(InsuranceApply::getId,saveUnionApplyDTO.getApplyIds()) .isNull(InsuranceApply::getUnionApplyId) @@ -307,22 +342,38 @@ unionApply.setStatus(Constants.UnionApplyStatus.MERGE.getKey()); unionApply.setCheckUserId(user.getId()); unionApply.setCurrentFee(BigDecimal.ZERO); + unionApply.setIsdeleted(Constants.ZERO); + unionApply.setSolutionId(solutions.getId()); Integer maxDays = DateUtil.calculateBetween(saveUnionApplyDTO.getStartDate(),saveUnionApplyDTO.getEndDate(),0); - List<ApplyDetail> applyDetailList = applyDetailJoinMapper.selectList(new QueryWrapper<ApplyDetail>().lambda().select(ApplyDetail::getPrice) - .in(ApplyDetail::getApplyId,saveUnionApplyDTO.getApplyIds())); - unionApply.setFee(applyDetailList.stream().map(i->i.getPrice().multiply(new BigDecimal(maxDays))).reduce(BigDecimal.ZERO,BigDecimal::add)); + + List<ApplyDetail> applyDetailList = applyDetailJoinMapper.selectList(new QueryWrapper<ApplyDetail>().lambda().select(ApplyDetail::getId,ApplyDetail::getPrice) + .in(ApplyDetail::getApplyId,saveUnionApplyDTO.getApplyIds()) + .eq(ApplyDetail::getIsdeleted,Constants.ZERO)); + if(applyDetailList.size()==0){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝瀛樺湪濮旀墭鎶曚繚鐢宠璁板綍淇℃伅鏈夎锛岃杩斿洖鏌ョ湅鐢宠浜哄憳鏄惁涓虹┖锛�"); + } + unionApply.setFee(applyDetailList.stream().map(i->Constants.formatBigdecimal(i.getPrice()).multiply(new BigDecimal(maxDays))).reduce(BigDecimal.ZERO,BigDecimal::add)); + unionApplyMapper.insert(unionApply); insuranceApplyJoinMapper.update(null,new UpdateWrapper<InsuranceApply>().lambda() .set(InsuranceApply::getUnionApplyId,unionApply.getId()) .set(InsuranceApply::getCheckDate,new Date()) .set(InsuranceApply::getCheckUserId,user.getId()) + .set(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.WTB_TOUBAOING.getKey()) .in(InsuranceApply::getId,saveUnionApplyDTO.getApplyIds())); applyDetailJoinMapper.update(null,new UpdateWrapper<ApplyDetail>().lambda() .set(ApplyDetail::getUnionApplyId,unionApply.getId()) .in(ApplyDetail::getApplyId,saveUnionApplyDTO.getApplyIds())); + + + + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.IA_HBD_UPLOAD; + ApplyLog log = new ApplyLog(unionApply,applyLogType.getName(), null + ,unionApply.getId(),applyLogType.getKey(),null, JSONObject.toJSONString(unionApply)); + applyLogMapper.insert(log); return unionApply.getId(); @@ -331,16 +382,19 @@ /** * 鍙栨秷淇濆崟鍚堝苟 - * @param id + * @param closeDTO */ @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) - public void cancelMerge(Integer id){ + public void cancelMerge(CloseDTO closeDTO){ LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(!user.getType().equals(Constants.TWO)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炲晢鎴风敤鎴凤紝鏃犳硶杩涜璇ユ搷浣滐紒"); } - UnionApply unionApply = unionApplyMapper.selectById(id); + if(Objects.isNull(closeDTO)||Objects.isNull(closeDTO.getId())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + UnionApply unionApply = unionApplyMapper.selectById(closeDTO.getId()); if(Objects.isNull(unionApply)||!Constants.equalsInteger(unionApply.getIsdeleted(),Constants.ZERO)){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } @@ -363,6 +417,7 @@ .set(InsuranceApply::getUnionApplyId,null) .set(InsuranceApply::getCheckDate,new Date()) .set(InsuranceApply::getCheckUserId,user.getId()) + .set(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.WTB_BUSINESS_CHECK_PASS.getKey()) .eq(InsuranceApply::getUnionApplyId,unionApply.getId())); applyDetailJoinMapper.update(null,new UpdateWrapper<ApplyDetail>().lambda() @@ -375,6 +430,16 @@ .set(UnionApply::getStatus,Constants.UnionApplyStatus.CLOSE.getKey()) .eq(UnionApply::getId,unionApply.getId()) ); + + + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.IA_HBD_CLOSE; + String info =applyLogType.getInfo(); + info = info.replace("${param}", closeDTO.getReason()); + ApplyLog log = new ApplyLog(unionApply,applyLogType.getName(), info + ,unionApply.getId(),applyLogType.getKey(),null, null); + applyLogMapper.insert(log); + + applyLogMapper.insert(log); } @@ -382,8 +447,8 @@ @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public void uploadToubaodan(UploadMultifileDTO uploadMultifileDTO){ if(uploadMultifileDTO.getBusinessId() == null - ||StringUtils.isBlank( uploadMultifileDTO.getFilePath()) - ||StringUtils.isBlank( uploadMultifileDTO.getFileName())){ + ||StringUtils.isBlank( uploadMultifileDTO.getFileurl()) + ||StringUtils.isBlank( uploadMultifileDTO.getName())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); @@ -404,6 +469,41 @@ throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曚笟鍔″凡娴佽浆锛屾偍鏃犳硶杩涜璇ユ搷浣滐紒"); } + if(CollectionUtils.isNotEmpty(uploadMultifileDTO.getMultifileList())){ + List<Multifile> multifileList = uploadMultifileDTO.getMultifileList(); + for (Multifile multifile:multifileList) { + if(Objects.isNull(multifile.getObjId()) + ||Objects.isNull(multifile.getName()) + ||Objects.isNull(multifile.getFileurl())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"浼佷笟鎶曚繚鍗曢檮浠跺弬鏁伴敊璇�"); + } + InsuranceApply insuranceApply = insuranceApplyJoinMapper.selectOne(new QueryWrapper<InsuranceApply>().lambda() + .eq(InsuranceApply::getId,multifile.getObjId()) + .eq(InsuranceApply::getUnionApplyId,uploadMultifileDTO.getBusinessId()) + ); + if(Objects.isNull(insuranceApply)){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"浼佷笟鎶曚繚鍗曟湭鏌ヨ鍒�"); + } + + multifile.setIsdeleted(Constants.ZERO); + multifile.setCreator(user.getId()); + multifile.setCreateDate(new Date()); + multifile.setCreateDate(new Date()); + multifile.setObjType(Constants.MultiFile.COMPANY_TBD_SIGNED.getKey()); + multifile.setType(Constants.TWO); + multifileMapper.insert(multifile); + + insuranceApplyJoinMapper.update(null,new UpdateWrapper<InsuranceApply>().lambda() + .set(InsuranceApply::getUnionApplyTbdStatus,Constants.ONE) + .set(InsuranceApply::getEditDate,new Date()) + .set(InsuranceApply::getEditor,user.getId()) + .eq(InsuranceApply::getId,multifile.getObjId()) + ); + + } + } + + unionApply.setCheckDate(new Date()); unionApply.setCheckUserId(user.getId()); unionApply.setStatus(Constants.UnionApplyStatus.WAIT_SIGNATURE.getKey()); @@ -419,29 +519,34 @@ multifile.setCreateDate(new Date()); multifile.setObjType(Constants.MultiFile.HBD_BD_SIGNED_PDF.getKey()); multifile.setType(Constants.TWO); - multifile.setFileurl(uploadMultifileDTO.getFilePath()); - multifile.setName(uploadMultifileDTO.getFileName()); + multifile.setFileurl(uploadMultifileDTO.getFileurl()); + multifile.setName(uploadMultifileDTO.getName()); multifileMapper.insert(multifile); - } /** * 鍚堝苟鍗� - 鎶曚繚鐢宠绛剧讲 - * @param id * @return */ @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) - public String getSignLink(Integer id) { - if(id == null ){ + public String getSignLink(SmsCheckDTO smsCheckDTO) { + if(Objects.isNull(smsCheckDTO) + || Objects.isNull(smsCheckDTO.getBusinessId()) + || StringUtils.isBlank(smsCheckDTO.getCode()) + ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + //楠岃瘉 楠岃瘉鐮� + if(!debugModel){ + smsEmailService.validateCode(smsCheckDTO.getCode()); } LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(!user.getType().equals(Constants.TWO)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炲晢鎴风敤鎴凤紝鏃犳硶杩涜璇ユ搷浣滐紒"); } - UnionApply unionApply = unionApplyJoinMapper.selectById(id); + UnionApply unionApply = unionApplyJoinMapper.selectById(smsCheckDTO.getBusinessId()); if(unionApply == null ||!Constants.equalsInteger(unionApply.getIsdeleted(),Constants.ZERO)){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } @@ -563,7 +668,7 @@ multifile.setCreator(user.getId()); multifile.setCreateDate(new Date()); multifile.setObjId(insuranceApply.getId()); - multifile.setObjType(Constants.MultiFile.COMPANY_TBD_SIGNED_PDF.getKey()); + multifile.setObjType(Constants.MultiFile.BD_DONE_PDF.getKey()); multifile.setType(Constants.TWO); multifile.setFileurl(unionApplyBXDDDetailTO.getFileUrl()); multifile.setName(unionApplyBXDDDetailTO.getFileName()); @@ -578,7 +683,8 @@ new BigDecimal(applyDetails.size()) .multiply(price) ) - .set(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey()) + .set(InsuranceApply::getStatus,Constants.InsuranceApplyStatus.WTB_DONE.getKey()) + .set(InsuranceApply::getUnionApplyTbdStatus,3) .set(InsuranceApply::getFee,price.multiply(new BigDecimal(applyDetails.size())).multiply(new BigDecimal(maxDays))) .set(InsuranceApply::getCurrentFee,currentFee.multiply(new BigDecimal(applyDetails.size()))) .set(InsuranceApply::getStartTime,unionApplyBXDDTO.getStartTime()) @@ -620,7 +726,7 @@ multifile.setCreator(user.getId()); multifile.setCreateDate(new Date()); multifile.setObjId(unionApply.getId()); - multifile.setObjType(Constants.MultiFile.HBD_BD_APPLY_PDF.getKey()); + multifile.setObjType(Constants.MultiFile.WTB_BD_DONE_PDF.getKey()); multifile.setType(Constants.TWO); multifile.setFileurl(unionApplyBXDDTO.getFileUrl()); multifile.setName(unionApplyBXDDTO.getFileName()); @@ -628,12 +734,12 @@ } - + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.IA_HBD_UPLOAD_TBD; + ApplyLog log = new ApplyLog(unionApply,applyLogType.getName(), null + ,unionApply.getId(),applyLogType.getKey(),null, JSONObject.toJSONString(unionApply)); + applyLogMapper.insert(log); } - - - } -- Gitblit v1.9.3