From 50fb58286ed3b718c39a97e0987ee7561a295651 Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期五, 04 七月 2025 17:56:41 +0800 Subject: [PATCH] git ch --- server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java | 468 ++++++++++++++++++++++++++++------------------------------ 1 files changed, 227 insertions(+), 241 deletions(-) diff --git a/server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java index 9c2b9a9..7f8d9fe 100644 --- a/server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java +++ b/server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java @@ -31,12 +31,14 @@ import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.*; +import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; /** @@ -246,12 +248,14 @@ queryWrapper.selectAll(UnionChange.class); pageWrap.getModel().setIsdeleted(Constants.ZERO); queryWrapper.selectAs(UnionApply::getCode,UnionChange::getApplyCode); - queryWrapper.selectAs(Solutions::getName,UnionChange::getSolutionsName) + queryWrapper.selectAs(Solutions::getName,UnionChange::getSolutionsName) + .select(" (select c.NAME from insurance_apply i left join company c on i.COMPANY_ID = c.id where i.UNION_APPLY_ID = t.UNION_APPLY_ID limit 1 ) ",UnionApply::getCompanyName) .select("( select count(1) from apply_chagne_detail ad where t.id = ad.UNION_CHANGE_ID and ad.TYPE = 0 )",UnionChange::getAddNum) .select("( select count(1) from apply_chagne_detail ad where t.id = ad.UNION_CHANGE_ID and ad.TYPE = 1 )",UnionChange::getDelNum) .select("( select count(1) from apply_chagne_detail ad where t.id = ad.UNION_CHANGE_ID and ad.TYPE = 2 )",UnionChange::getChangeNum); queryWrapper.leftJoin(UnionApply.class,UnionApply::getId,UnionChange::getUnionApplyId); queryWrapper.leftJoin(Solutions.class,Solutions::getId,UnionApply::getSolutionId); + queryWrapper.leftJoin(Company.class,Company::getId,UnionApply::getCompanyId); LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(Constants.equalsInteger(user.getType(),Constants.TWO)){ queryWrapper.eq(UnionChange::getShopId, user.getCompanyId()); @@ -262,6 +266,9 @@ } if (pageWrap.getModel().getCreator() != null) { queryWrapper.eq(UnionChange::getCreator, pageWrap.getModel().getCreator()); + } + if (pageWrap.getModel().getSolutionsName() != null) { + queryWrapper.eq(Solutions::getName, pageWrap.getModel().getSolutionsName()); } if (pageWrap.getModel().getQueryStartTime() != null) { @@ -351,10 +358,10 @@ if(!(Constants.equalsInteger(user.getType(),Constants.ZERO) || Constants.equalsInteger(user.getType(),Constants.TWO))){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炲晢鎴峰钩鍙扮敤鎴凤紝鏃犳硶杩涜璇ユ搷浣�"); } - if(saveUnionChangeDTO.getBusinessType().equals(Constants.ZERO)||Objects.isNull(saveUnionChangeDTO.getApplyDate())){ - //2024骞�5鏈�9鏃�14:59:24 淇敼 榛樿鍏ュ綋鍓嶅ぉ - saveUnionChangeDTO.setApplyDate(DateUtil.getMontageDate(new Date(),1)); - } +// if(saveUnionChangeDTO.getBusinessType().equals(Constants.ZERO)||Objects.isNull(saveUnionChangeDTO.getApplyDate())){ +// //2024骞�5鏈�9鏃�14:59:24 淇敼 榛樿鍏ュ綋鍓嶅ぉ +// saveUnionChangeDTO.setApplyDate(DateUtil.getMontageDate(new Date(),1)); +// } if(Objects.isNull(saveUnionChangeDTO) || Objects.isNull(saveUnionChangeDTO.getApplyIds()) || Objects.isNull(saveUnionChangeDTO.getApplyDate()) @@ -374,33 +381,37 @@ } if(saveUnionChangeDTO.getBusinessType().equals(Constants.ZERO)){ // saveUnionChangeDTO.setApplyDate(unionApply.getStartTime()); - - saveUnionChangeDTO.setAddValidDate(saveUnionChangeDTO.getApplyDate()); - saveUnionChangeDTO.setDelValidDate(saveUnionChangeDTO.getApplyDate()); - //鏍规嵁鐢宠鏃ユ湡 澶勭悊鍔犲噺淇濈殑 瀹為檯鐢熸晥鏃ユ湡 - if(Objects.nonNull(solutions.getAddValidDays())){ - saveUnionChangeDTO.setAddValidDate( - DateUtil.afterDateByType(saveUnionChangeDTO.getApplyDate(),0,solutions.getAddValidDays()) - ); + if(unionApply.getStartTime().getTime()>System.currentTimeMillis()){ + saveUnionChangeDTO.setAddValidDate(unionApply.getStartTime()); + saveUnionChangeDTO.setDelValidDate(unionApply.getStartTime()); }else{ saveUnionChangeDTO.setAddValidDate(saveUnionChangeDTO.getApplyDate()); - } - if(Objects.nonNull(solutions.getDelValidDays())){ - saveUnionChangeDTO.setDelValidDate( - DateUtil.afterDateByType(saveUnionChangeDTO.getApplyDate(),0,solutions.getDelValidDays()) - ); - }else{ saveUnionChangeDTO.setDelValidDate(saveUnionChangeDTO.getApplyDate()); - } - //鍒ゆ柇鎵瑰崟鏃ユ湡 鍚堝苟鍗曠殑鎵瑰崟鐢熸晥鏈熷湪涓� 淇濆崟璧锋湡鐨勬鏃� 鍒颁繚鍗曟鏈� - //鑾峰彇寮�濮嬫棩鏈熸鏃� - if(saveUnionChangeDTO.getAddValidDate().getTime()<unionApply.getStartTime().getTime() - || saveUnionChangeDTO.getAddValidDate().getTime()> unionApply.getEndTime().getTime()){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍔犱繚鐢熸晥鏈熼敊璇�"); - } - if(saveUnionChangeDTO.getDelValidDate().getTime()<unionApply.getStartTime().getTime() - || saveUnionChangeDTO.getDelValidDate().getTime()> unionApply.getEndTime().getTime()){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍑忎繚鐢熸晥鏈熼敊璇�"); + //鏍规嵁鐢宠鏃ユ湡 澶勭悊鍔犲噺淇濈殑 瀹為檯鐢熸晥鏃ユ湡 + if(Objects.nonNull(solutions.getAddValidDays())){ + saveUnionChangeDTO.setAddValidDate( + DateUtil.afterDateByType(saveUnionChangeDTO.getApplyDate(),0,solutions.getAddValidDays()) + ); + }else{ + saveUnionChangeDTO.setAddValidDate(saveUnionChangeDTO.getApplyDate()); + } + if(Objects.nonNull(solutions.getDelValidDays())){ + saveUnionChangeDTO.setDelValidDate( + DateUtil.afterDateByType(saveUnionChangeDTO.getApplyDate(),0,solutions.getDelValidDays()) + ); + }else{ + saveUnionChangeDTO.setDelValidDate(saveUnionChangeDTO.getApplyDate()); + } + //鍒ゆ柇鎵瑰崟鏃ユ湡 鍚堝苟鍗曠殑鎵瑰崟鐢熸晥鏈熷湪涓� 淇濆崟璧锋湡鐨勬鏃� 鍒颁繚鍗曟鏈� + //鑾峰彇寮�濮嬫棩鏈熸鏃� + if(saveUnionChangeDTO.getAddValidDate().getTime()<unionApply.getStartTime().getTime() + || saveUnionChangeDTO.getAddValidDate().getTime()> unionApply.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍔犱繚鐢熸晥鏈熼敊璇�"); + } + if(saveUnionChangeDTO.getDelValidDate().getTime()<unionApply.getStartTime().getTime() + || saveUnionChangeDTO.getDelValidDate().getTime()> unionApply.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍑忎繚鐢熸晥鏈熼敊璇�"); + } } }else{ // if(saveUnionChangeDTO.getApplyDate().getTime()<DateUtil.afterDateByType(unionApply.getStartTime(),0,1).getTime() @@ -626,6 +637,7 @@ String companyName = ""; String creditCode = ""; String email = ""; + String signId = ""; if(Constants.equalsInteger(user.getType(),Constants.TWO)){ if(!unionChange.getShopId().equals(user.getCompanyId())){ throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧烽潪鎮ㄧ殑鍚堝苟鍗曪紝鎮ㄦ棤娉曡繘琛屾搷浣滐紒"); @@ -637,6 +649,7 @@ companyName = company.getName(); creditCode = company.getCode(); email = company.getEmail(); + signId = company.getSignId(); }else{ companyName = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.PLAT_COMPANY_NAME).getCode(); creditCode = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.PLAT_CREDIT_CODE).getCode(); @@ -655,17 +668,17 @@ String fileUrl = null; -// if(Constants.equalsObject(unionChange.getType(), Constants.ONE)){ -// fileUrl = ExcelExporter.build(UnionChange.class).exportUnionChangeOtherUnitExcelToPdf(unionChange,"鎹㈠巶鐢宠琛�"); -// }else{ -// fileUrl = ExcelExporter.build(UnionChange.class).exportUnionChangeExcelToPdf(unionChange,"鍔犲噺淇濈敵璇疯〃"); -// } + if(Constants.equalsObject(unionChange.getType(), Constants.ONE)){ + fileUrl = ExcelExporter.build(UnionChange.class).exportUnionChangeOtherUnitExcelToPdf(unionChange,"鎹㈠巶鐢宠琛�"); + }else{ + fileUrl = ExcelExporter.build(UnionChange.class).exportUnionChangeExcelToPdf(unionChange,"鍔犲噺淇濈敵璇疯〃"); + } String notifyUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.SIGN_DONE_NOTIFY_URL).getCode(); notifyUrl = notifyUrl.replace("${type}","0").replace("${id}",unionChange.getId().toString()); -// String applyNo = signService.applySignLocalFile(company.getName(),company.getName(),fileUrl,company.getCode(),company.getEmail(),"鍚堝苟鍗曪紙鍔犲噺淇�/鎹㈠巶锛夌敵璇风缃�",company.getSignId(),notifyUrl); + String applyNo = signService.applySignLocalFileByParam(companyName,companyName,fileUrl,creditCode,email,"鍚堝苟鍗曪紙鍔犲噺淇�/鎹㈠巶锛夌敵璇风缃�",null,notifyUrl,new Float(0.7)); //涓存椂浣跨敤 - fileUrl = "https://yybred.oss-cn-hangzhou.aliyuncs.com/apply/20241230/a0d128f2-ba6c-4ad4-b86b-b2610a513d41.pdf"; - String applyNo = signService.applySignWidthQifengSet(companyName,fileUrl,companyName,creditCode,email,"浜哄憳鍚嶅崟绛剧珷",null,notifyUrl,new Float(0.7)); +// fileUrl = "https://yybred.oss-cn-hangzhou.aliyuncs.com/apply/20241230/a0d128f2-ba6c-4ad4-b86b-b2610a513d41.pdf"; +// String applyNo = signService.applySignWidthQifengSet(companyName,fileUrl,companyName,creditCode,email,"浜哄憳鍚嶅崟绛剧珷",null,notifyUrl,new Float(0.7)); if(StringUtils.isBlank(applyNo) ){ throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鑾峰彇鍦ㄧ嚎绛剧珷鍦板潃澶辫触锛岃绋嶅悗閲嶈瘯锛�"); } @@ -684,215 +697,187 @@ } + @Autowired + private RedisTemplate redisTemplate;// Redis鎿嶄綔绫伙紝瀵硅繖涓娇鐢ㄤ笉鐔熸倝鐨勶紝鍙互鍙傝�冨墠闈㈢殑鍗氬 + private static final String KEY_PREFIX = "unionchange:upload:"; + @Override @Transactional(rollbackFor = {BusinessException.class,Exception.class}) public void uploadBXD(UnionChangeBXDDTO unionChangeBXDDTO){ - if(Objects.isNull(unionChangeBXDDTO) - || Objects.isNull(unionChangeBXDDTO.getId()) - || Objects.isNull(unionChangeBXDDTO.getApplyDate()) -// || StringUtils.isBlank(unionChangeBXDDTO.getName()) -// || StringUtils.isBlank(unionChangeBXDDTO.getFileurl()) - || StringUtils.isBlank(unionChangeBXDDTO.getCode()) - || CollectionUtils.isEmpty(unionChangeBXDDTO.getPidanFileList()) - ){ - throw new BusinessException(ResponseStatus.BAD_REQUEST); - } - LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); - UnionChange unionChange = unionChangeMapper.selectById(unionChangeBXDDTO.getId()); - if(Objects.isNull(unionChange)||!Constants.equalsInteger(unionChange.getIsdeleted(),Constants.ZERO)){ - throw new BusinessException(ResponseStatus.DATA_EMPTY); - } - if(!Constants.equalsInteger(unionChange.getType(),Constants.ONE)&& - unionChangeBXDDTO.getDelValidTime() == null ){ - throw new BusinessException(ResponseStatus.BAD_REQUEST); - } - unionChangeBXDDTO.setApplyId(unionChange.getUnionApplyId()); - unionChange.setStatus(Constants.formatIntegerNum(unionChange.getStatus())); - unionChange.setShopId(Constants.formatIntegerNum(unionChange.getShopId())); - if(Constants.equalsInteger(user.getType(),Constants.TWO) && !unionChange.getShopId().equals(user.getCompanyId())){ - throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧烽潪鎮ㄧ殑鍚堝苟鍗曪紝鎮ㄦ棤娉曡繘琛屾搷浣滐紒"); - } - if(unionChange.getStatus().equals(Constants.UnionChangeStatus.FINISH.getKey())){ - throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曚笟鍔″凡瀹岀粨锛屾偍鏃犳硶杩涜璇ユ搷浣滐紒"); - } - if(unionChange.getStatus().equals(Constants.UnionChangeStatus.CLOSE.getKey())){ - throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曚笟鍔″凡鍏抽棴"); - } - if(!unionChange.getStatus().equals(Constants.UnionChangeStatus.UPLOAD_INSURANCE_POLICY.getKey())){ - throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曠姸鎬佸凡娴佽浆"); - } - UnionApply unionApply = unionApplyMapper.selectById(unionChange.getUnionApplyId()); - if(Objects.isNull(unionApply)){ - throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鍚堝苟淇濆崟淇℃伅"); - } - Solutions solutions = solutionsMapper.selectById(unionApply.getSolutionId()); - if(Objects.isNull(solutions)){ - throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濋櫓鏂规"); - } - if(unionChange.getType().equals(Constants.ZERO)){ - //鍒ゆ柇鎵瑰崟鏃ユ湡 鍚堝苟鍗曠殑鎵瑰崟鐢熸晥鏈熷湪涓� 淇濆崟璧锋湡鐨勬鏃� 鍒颁繚鍗曟鏈� - //鑾峰彇寮�濮嬫棩鏈熸鏃� - if(unionChangeBXDDTO.getApplyDate().getTime()<unionApply.getStartTime().getTime() - || unionChangeBXDDTO.getApplyDate().getTime()> unionApply.getEndTime().getTime()){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍔犱繚鐢熸晥鏈熼敊璇�"); + try{ + if(Objects.nonNull(redisTemplate.opsForValue().get(KEY_PREFIX+unionChangeBXDDTO.getId()))){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璇峰嬁閲嶅鎻愪氦"); + }; + redisTemplate.opsForValue().set(KEY_PREFIX+unionChangeBXDDTO.getId(), unionChangeBXDDTO.getId(), 30000, TimeUnit.SECONDS); + if(Objects.isNull(unionChangeBXDDTO) + || Objects.isNull(unionChangeBXDDTO.getId()) + || Objects.isNull(unionChangeBXDDTO.getApplyDate()) + // || StringUtils.isBlank(unionChangeBXDDTO.getName()) + // || StringUtils.isBlank(unionChangeBXDDTO.getFileurl()) + || StringUtils.isBlank(unionChangeBXDDTO.getCode()) + || CollectionUtils.isEmpty(unionChangeBXDDTO.getPidanFileList()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); } - if(unionChangeBXDDTO.getDelValidTime().getTime()<unionApply.getStartTime().getTime() - || unionChangeBXDDTO.getDelValidTime().getTime()> unionApply.getEndTime().getTime()){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍑忎繚鐢熸晥鏈熼敊璇�"); + LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + UnionChange unionChange = unionChangeMapper.selectById(unionChangeBXDDTO.getId()); + if(Objects.isNull(unionChange)||!Constants.equalsInteger(unionChange.getIsdeleted(),Constants.ZERO)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); } - }else{ - if(unionChangeBXDDTO.getApplyDate().getTime()<unionChange.getApplyStartTime().getTime()){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎵瑰崟鏃ユ湡蹇呴』澶т簬鐢宠鏃ユ湡"); + if(!Constants.equalsInteger(unionChange.getType(),Constants.ONE)&& + unionChangeBXDDTO.getDelValidTime() == null ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); } - } - - List<ApplyChange> applyChangeList = applyChangeJoinMapper.selectJoinList(ApplyChange.class, - new MPJLambdaWrapper<ApplyChange>() - .selectAll(ApplyChange.class) - .selectAs(InsuranceApply::getSolutionId,ApplyChange::getSolutionsId) - .selectAs(InsuranceApply::getCode,ApplyChange::getApplyCode) - .leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyChange::getApplyId) - .eq(ApplyChange::getUnionChangeId,unionChange.getId())); - - List<Multifile> pidanFileList = unionChangeBXDDTO.getPidanFileList(); - for (Multifile pidanFile:pidanFileList) { - if(StringUtils.isBlank( pidanFile.getFileurl()) - ||StringUtils.isBlank( pidanFile .getName())) { - throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鎵瑰崟鏂囦欢鍙傛暟閿欒"); + unionChangeBXDDTO.setApplyId(unionChange.getUnionApplyId()); + unionChange.setStatus(Constants.formatIntegerNum(unionChange.getStatus())); + unionChange.setShopId(Constants.formatIntegerNum(unionChange.getShopId())); + if(Constants.equalsInteger(user.getType(),Constants.TWO) && !unionChange.getShopId().equals(user.getCompanyId())){ + throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧烽潪鎮ㄧ殑鍚堝苟鍗曪紝鎮ㄦ棤娉曡繘琛屾搷浣滐紒"); } - pidanFile.setIsdeleted(Constants.ZERO); - pidanFile.setCreator(user.getId()); - pidanFile.setObjId(unionChange.getId()); - pidanFile.setCreateDate(new Date()); - pidanFile.setObjType(Constants.MultiFile.WTB_CA_DONE_PDF.getKey()); - pidanFile.setType(Constants.TWO); - } - multifileMapper.insertBatchSomeColumn(pidanFileList); - - for (ApplyChange applyChange:applyChangeList) { - for (Multifile pidanFile:pidanFileList) { - Multifile m = new Multifile(); - m.setId(null); - m.setIsdeleted(Constants.ZERO); - m.setCreator(user.getId()); - m.setCreateDate(new Date()); - m.setObjId(applyChange.getId()); - m.setFileurl(pidanFile.getFileurl()); - m.setName(pidanFile.getName()); - m.setObjType(Constants.MultiFile.CA_PD_PDF.getKey()); - m.setType(Constants.TWO); - multifileMapper.insert(m); + if(unionChange.getStatus().equals(Constants.UnionChangeStatus.FINISH.getKey())){ + throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曚笟鍔″凡瀹岀粨锛屾偍鏃犳硶杩涜璇ユ搷浣滐紒"); } - - } - - //瀛樺偍鍚堝苟鍗曚繚闄╁崟 - /* Multifile multifile = new Multifile(); - multifile.setIsdeleted(Constants.ZERO); - multifile.setCreator(user.getId()); - multifile.setCreateDate(new Date()); - multifile.setObjId(unionChangeBXDDTO.getId()); - multifile.setCreateDate(new Date()); - multifile.setObjType(Constants.MultiFile.WTB_CA_DONE_PDF.getKey()); - multifile.setType(Constants.TWO); - multifile.setFileurl(unionChangeBXDDTO.getFileurl()); - multifile.setName(unionChangeBXDDTO.getName()); - multifileMapper.insert(multifile);*/ - -// if(CollectionUtils.isNotEmpty(unionChangeBXDDTO.getApplyChangeBXDList())){ -// //鏌ヨ鏄惁涓嶅瓨鍦ㄥ綋鍓嶅悎骞跺崟鐨勬暟鎹� -// if(applyChangeJoinMapper.selectCount(new QueryWrapper<ApplyChange>() -// .lambda().ne(ApplyChange::getUnionChangeId,unionChangeBXDDTO.getId()) -// .in(ApplyChange::getId, -// unionChangeBXDDTO.getApplyChangeBXDList().stream().map(m->m.getObjId()).collect(Collectors.toList()) -// ) -// )>Constants.ZERO){ -// throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎵瑰崟鏄庣粏璁板綍瀛樺湪闈炴湰鍚堝苟鍗曟暟鎹�"); -// }; -// for (Multifile m:unionChangeBXDDTO.getApplyChangeBXDList()) { -// if(StringUtils.isBlank(m.getName()) -// || StringUtils.isBlank(m.getFileurl()) ){ -// continue; -// } -// if(Objects.isNull(m.getObjId()) -// ||StringUtils.isBlank(m.getFileurl()) -// ||StringUtils.isBlank(m.getName()) -// ){ -// throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎵瑰崟鏂囦欢淇℃伅缂哄け"); -// } -// m.setId(null); -// m.setIsdeleted(Constants.ZERO); -// m.setCreator(user.getId()); -// m.setCreateDate(new Date()); -// m.setObjType(Constants.MultiFile.CA_PD_PDF.getKey()); -// m.setType(Constants.TWO); -// multifileMapper.insert(m); -// } -// } - if(CollectionUtils.isNotEmpty(applyChangeList)){ - for (ApplyChange applyChange:applyChangeList) { - ApplyChange oldModel = applyChange; - applyChange.setApplyStartTime(unionChangeBXDDTO.getApplyDate()); - applyChange.setDelValidTime(unionChangeBXDDTO.getDelValidTime()); -// applyChange.setValidTime(unionChangeBXDDTO.getApplyDate()); - applyChange.setEditDate(new Date()); - applyChange.setEditor(user.getId()); - applyChange.setStatus(Constants.ApplyChangeStatus.APPROVE.getKey()); - applyChange.setCode(unionChangeBXDDTO.getCode()); - applyChange.setValidCode(unionChangeBXDDTO.getCode()); - applyChange.setCheckUserId(user.getId()); - List<ApplyChagneDetail> allList = applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class, - new MPJLambdaWrapper<ApplyChagneDetail>() - .selectAll(ApplyChagneDetail.class) - .selectAs(Member::getIdcardNo,ApplyChagneDetail::getIdcardNo) - .selectAs(Solutions::getTimeUnit, ApplyChagneDetail::getSolutionTimeUnit) - .selectAs(Solutions::getPrice, ApplyChagneDetail::getSolutionPrice) - .selectAs(Worktype::getName, ApplyChagneDetail::getWorkTypeName) - .selectAs(DispatchUnit::getName, ApplyChagneDetail::getDuName) - .selectAs(Member::getName, ApplyChagneDetail::getMemberName) - .selectAs(Solutions::getName,ApplyChagneDetail::getSolutionsName) - .selectAs(InsuranceApply::getCode,ApplyChagneDetail::getApplyCode) - .selectAs(InsuranceApply::getServerCost,ApplyChagneDetail::getServerCost) - .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId) - .leftJoin(Member.class, Member::getId, ApplyChagneDetail::getMemberId) - .leftJoin(InsuranceApply.class, InsuranceApply::getId, ApplyChange::getApplyId) - .leftJoin(Solutions.class, Solutions::getId, InsuranceApply::getSolutionId) - .leftJoin(Worktype.class, Worktype::getId, ApplyChagneDetail::getWorktypeId) - .leftJoin(DispatchUnit.class, DispatchUnit::getId, ApplyChagneDetail::getDuId) - .eq(ApplyChagneDetail::getApplyChangeId,applyChange.getId())); - this.dealApplyChangeDetail(applyChange,allList,solutions); - applyChangeJoinMapper.updateById(applyChange); - //瀛樺偍鎵瑰崟瀹屾垚淇℃伅 - Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_PLATFORM_APPROVE; - String info = ""; - if(applyChange.getValidTime()!=null && applyChange.getValidTime().getTime()/1000!= applyChange.getApplyStartTime().getTime()/1000){ - info =applyLogType.getInfo(); - info = info.replace("${param1}",DateUtil.getPlusTime2(applyChange.getValidTime())); - info = info.replace("${param2}",DateUtil.getPlusTime2(applyChange.getApplyStartTime())); + if(unionChange.getStatus().equals(Constants.UnionChangeStatus.CLOSE.getKey())){ + throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曚笟鍔″凡鍏抽棴"); + } + if(!unionChange.getStatus().equals(Constants.UnionChangeStatus.UPLOAD_INSURANCE_POLICY.getKey())){ + throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝鍚堝苟鍗曠姸鎬佸凡娴佽浆"); + } + UnionApply unionApply = unionApplyMapper.selectById(unionChange.getUnionApplyId()); + if(Objects.isNull(unionApply)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鍚堝苟淇濆崟淇℃伅"); + } + Solutions solutions = solutionsMapper.selectById(unionApply.getSolutionId()); + if(Objects.isNull(solutions)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濋櫓鏂规"); + } + if(unionChange.getType().equals(Constants.ZERO)){ + //鍒ゆ柇鎵瑰崟鏃ユ湡 鍚堝苟鍗曠殑鎵瑰崟鐢熸晥鏈熷湪涓� 淇濆崟璧锋湡鐨勬鏃� 鍒颁繚鍗曟鏈� + //鑾峰彇寮�濮嬫棩鏈熸鏃� + if(unionChangeBXDDTO.getApplyDate().getTime()<unionApply.getStartTime().getTime() + || unionChangeBXDDTO.getApplyDate().getTime()> unionApply.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍔犱繚鐢熸晥鏈熼敊璇�"); } - ApplyLog log = new ApplyLog(applyChange,applyLogType.getName(), info,applyChange.getId(),applyLogType.getKey(),JSONObject.toJSONString(oldModel), JSONObject.toJSONString(applyChange)); - applyLogMapper.insert(log); + if(unionChangeBXDDTO.getDelValidTime().getTime()<unionApply.getStartTime().getTime() + || unionChangeBXDDTO.getDelValidTime().getTime()> unionApply.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍚堝苟鍗曠殑鎵瑰崟鍑忎繚鐢熸晥鏈熼敊璇�"); + } + }else{ + if(unionChangeBXDDTO.getApplyDate().getTime()<unionChange.getApplyStartTime().getTime()){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎵瑰崟鏃ユ湡蹇呴』澶т簬鐢宠鏃ユ湡"); + } + } + + List<ApplyChange> applyChangeList = applyChangeJoinMapper.selectJoinList(ApplyChange.class, + new MPJLambdaWrapper<ApplyChange>() + .selectAll(ApplyChange.class) + .selectAs(InsuranceApply::getSolutionId,ApplyChange::getSolutionsId) + .selectAs(InsuranceApply::getCode,ApplyChange::getApplyCode) + .leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyChange::getApplyId) + .eq(ApplyChange::getUnionChangeId,unionChange.getId())); + + List<Multifile> pidanFileList = unionChangeBXDDTO.getPidanFileList(); + for (Multifile pidanFile:pidanFileList) { + if(StringUtils.isBlank( pidanFile.getFileurl()) + ||StringUtils.isBlank( pidanFile .getName())) { + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鎵瑰崟鏂囦欢鍙傛暟閿欒"); + } + pidanFile.setIsdeleted(Constants.ZERO); + pidanFile.setCreator(user.getId()); + pidanFile.setObjId(unionChange.getId()); + pidanFile.setCreateDate(new Date()); + pidanFile.setObjType(Constants.MultiFile.WTB_CA_DONE_PDF.getKey()); + pidanFile.setType(Constants.TWO); + } + multifileMapper.insert(pidanFileList); + + for (ApplyChange applyChange:applyChangeList) { + for (Multifile pidanFile:pidanFileList) { + Multifile m = new Multifile(); + m.setId(null); + m.setIsdeleted(Constants.ZERO); + m.setCreator(user.getId()); + m.setCreateDate(new Date()); + m.setObjId(applyChange.getId()); + m.setFileurl(pidanFile.getFileurl()); + m.setName(pidanFile.getName()); + m.setObjType(Constants.MultiFile.CA_PD_PDF.getKey()); + m.setType(Constants.TWO); + multifileMapper.insert(m); + } } + + + if(CollectionUtils.isNotEmpty(applyChangeList)){ + for (ApplyChange applyChange:applyChangeList) { + ApplyChange oldModel = applyChange; + applyChange.setApplyStartTime(unionChangeBXDDTO.getApplyDate()); + applyChange.setDelValidTime(unionChangeBXDDTO.getDelValidTime()); + // applyChange.setValidTime(unionChangeBXDDTO.getApplyDate()); + applyChange.setEditDate(new Date()); + applyChange.setEditor(user.getId()); + applyChange.setStatus(Constants.ApplyChangeStatus.APPROVE.getKey()); + applyChange.setCode(unionChangeBXDDTO.getCode()); + applyChange.setValidCode(unionChangeBXDDTO.getCode()); + applyChange.setCheckUserId(user.getId()); + List<ApplyChagneDetail> allList = applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class, + new MPJLambdaWrapper<ApplyChagneDetail>() + .selectAll(ApplyChagneDetail.class) + .selectAs(Member::getIdcardNo,ApplyChagneDetail::getIdcardNo) + .selectAs(Solutions::getTimeUnit, ApplyChagneDetail::getSolutionTimeUnit) + .selectAs(Solutions::getPrice, ApplyChagneDetail::getSolutionPrice) + .selectAs(Worktype::getName, ApplyChagneDetail::getWorkTypeName) + .selectAs(DispatchUnit::getName, ApplyChagneDetail::getDuName) + .selectAs(Member::getName, ApplyChagneDetail::getMemberName) + .selectAs(Solutions::getName,ApplyChagneDetail::getSolutionsName) + .selectAs(InsuranceApply::getCode,ApplyChagneDetail::getApplyCode) + .selectAs(InsuranceApply::getServerCost,ApplyChagneDetail::getServerCost) + .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId) + .leftJoin(Member.class, Member::getId, ApplyChagneDetail::getMemberId) + .leftJoin(InsuranceApply.class, InsuranceApply::getId, ApplyChange::getApplyId) + .leftJoin(Solutions.class, Solutions::getId, InsuranceApply::getSolutionId) + .leftJoin(Worktype.class, Worktype::getId, ApplyChagneDetail::getWorktypeId) + .leftJoin(DispatchUnit.class, DispatchUnit::getId, ApplyChagneDetail::getDuId) + .eq(ApplyChagneDetail::getApplyChangeId,applyChange.getId())); + this.dealApplyChangeDetail(applyChange,allList,solutions); + applyChangeJoinMapper.updateById(applyChange); + //瀛樺偍鎵瑰崟瀹屾垚淇℃伅 + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_PLATFORM_APPROVE; + String info = ""; + if(applyChange.getValidTime()!=null && applyChange.getValidTime().getTime()/1000!= applyChange.getApplyStartTime().getTime()/1000){ + info =applyLogType.getInfo(); + info = info.replace("${param1}",DateUtil.getPlusTime2(applyChange.getValidTime())); + info = info.replace("${param2}",DateUtil.getPlusTime2(applyChange.getApplyStartTime())); + } + ApplyLog log = new ApplyLog(applyChange,applyLogType.getName(), info,applyChange.getId(),applyLogType.getKey(),JSONObject.toJSONString(oldModel), JSONObject.toJSONString(applyChange)); + applyLogMapper.insert(log); + + } + } + unionChangeMapper.update(null,new UpdateWrapper<UnionChange>().lambda() + .set(UnionChange::getStatus,Constants.UnionChangeStatus.FINISH.getKey()) + .set(UnionChange::getEditDate,new Date()) + .set(UnionChange::getEditor,user.getId()) + .set(UnionChange::getValidTime,unionChangeBXDDTO.getApplyDate()) + .set(UnionChange::getDelValidTime,unionChangeBXDDTO.getDelValidTime()) + .set(UnionChange::getApplyStartTime,unionChangeBXDDTO.getApplyDate()) + .set(UnionChange::getCode,unionChangeBXDDTO.getCode()) + .eq(UnionChange::getId,unionChangeBXDDTO.getId()) + ); + + + Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_HBD_UPLOAD_INSURANCE; + ApplyLog log = new ApplyLog(unionChange,applyLogType.getName(), null + ,unionChange.getId(),applyLogType.getKey(),null, JSONObject.toJSONString(unionChange)); + applyLogMapper.insert(log); + + }catch (Exception e){ + e.printStackTrace(); + }finally { + redisTemplate.delete(KEY_PREFIX + unionChangeBXDDTO.getId()); } - unionChangeMapper.update(null,new UpdateWrapper<UnionChange>().lambda() - .set(UnionChange::getStatus,Constants.UnionChangeStatus.FINISH.getKey()) - .set(UnionChange::getEditDate,new Date()) - .set(UnionChange::getEditor,user.getId()) - .set(UnionChange::getValidTime,unionChangeBXDDTO.getApplyDate()) - .set(UnionChange::getDelValidTime,unionChangeBXDDTO.getDelValidTime()) - .set(UnionChange::getApplyStartTime,unionChangeBXDDTO.getApplyDate()) - .set(UnionChange::getCode,unionChangeBXDDTO.getCode()) - .eq(UnionChange::getId,unionChangeBXDDTO.getId()) - ); - - - Constants.ApplyLogType applyLogType = Constants.ApplyLogType.CA_HBD_UPLOAD_INSURANCE; - ApplyLog log = new ApplyLog(unionChange,applyLogType.getName(), null - ,unionChange.getId(),applyLogType.getKey(),null, JSONObject.toJSONString(unionChange)); - applyLogMapper.insert(log); - } @@ -941,6 +926,7 @@ .eq(InsuranceApply::getId, applyChange.getApplyId()) ); applyChange.setFee(bigDecimalVO.getTotalFee()); + } @@ -953,7 +939,7 @@ , BigDecimalVO bigDecimalVO,List<ApplyChagneDetail> reduceList,Integer i){ //鏌ヨ浜哄憳淇℃伅鏄惁瀛樺湪鐩稿悓鐨勬柟妗堜笅鏄惁瀛樺湪 鍐茬獊鏁版嵁 InsuranceApplyServiceImpl.checkStaticMemberSolution(solutions.getBaseId(), - detail.getIdcardNo(),detail.getMemberName(),DateUtil.getMontageDate(applyChange.getApplyStartTime(),1),DateUtil.getMontageDate(detail.getEndTime(),2), + detail.getMemberId(),detail.getIdcardNo(),detail.getMemberName(),DateUtil.getMontageDate(applyChange.getApplyStartTime(),1),DateUtil.getMontageDate(detail.getEndTime(),2), applyDetailJoinMapper); //鍔犱繚 @@ -1064,17 +1050,17 @@ BigDecimal reduceFee = BigDecimal.ZERO; //濡傛灉鎵瑰崟鏃ユ湡 澶т簬 鍛樺伐淇濆崟鐨勫紑濮嬫棩鏈� - if(applyChange.getDelValidTime().getTime() > oldModel.getStartTime().getTime()){ - if(reduceDate.getTime()>oldModel.getStartTime().getTime()){ - reduceDate = DateUtil.getMontageDate(oldModel.getStartTime(), 3); - }else{ - reduceDate = DateUtil.getMontageDate(applyChange.getDelValidTime(), 3); - } + if(reduceDate.getTime() > oldModel.getStartTime().getTime()){ + reduceDate = DateUtil.getMontageDate(applyChange.getDelValidTime(), 3); + //鍑忎繚璁板綍鎿嶄綔鍚庣殑鎬昏垂鐢� + reduceFee = Constants.reduceFee( + solutions,fee,insuranceApply.getStartTime(),insuranceApply.getFinalEndTime(),oldModel.getStartTime(),reduceDate) ; + }else if(reduceDate.getTime()<oldModel.getStartTime().getTime()){ + reduceDate = DateUtil.getMontageDate(oldModel.getStartTime(), 3); //鍑忎繚璁板綍鎿嶄綔鍚庣殑鎬昏垂鐢� reduceFee = Constants.reduceFee( solutions,fee,insuranceApply.getStartTime(),insuranceApply.getFinalEndTime(),oldModel.getStartTime(),reduceDate) ; } - BigDecimal pullFee = BigDecimal.ZERO; if (oldModel.getStartTime().getTime() < System.currentTimeMillis()) { -- Gitblit v1.9.3