From 16e8c7adbee6c9ee9bac09a80d44d3bfd3fe2f0c Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期一, 19 五月 2025 09:45:38 +0800 Subject: [PATCH] Merge branch '2.0.2' into 2.0.1 --- server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java | 478 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 467 insertions(+), 11 deletions(-) diff --git a/server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java index d9e8421..d5c68c8 100644 --- a/server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java +++ b/server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java @@ -1,7 +1,6 @@ package com.doumee.service.business.impl; import com.alibaba.fastjson.JSONObject; -import com.baomidou.mybatisplus.extension.api.R; import com.doumee.biz.system.SystemDictDataBiz; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; @@ -9,14 +8,16 @@ import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Constants; +import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; -import com.doumee.dao.business.SettleClaimsLogMapper; -import com.doumee.dao.business.SettleClaimsMapper; +import com.doumee.dao.business.*; import com.doumee.dao.business.dto.SCSupplementDTO; +import com.doumee.dao.business.dto.SettleClaimsDTO; import com.doumee.dao.business.join.MultifileJoinMapper; import com.doumee.dao.business.join.SettleClaimsJoinMapper; import com.doumee.dao.business.join.SettleClaimsLogJoinMapper; import com.doumee.dao.business.model.*; +import com.doumee.dao.business.vo.RiskConfigVO; import com.doumee.dao.system.model.SystemUser; import com.doumee.service.business.SettleClaimsLogService; import com.doumee.service.business.SettleClaimsService; @@ -24,12 +25,16 @@ import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.doumee.service.system.impl.SystemDictDataServiceImpl; import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.github.yulichang.wrapper.MPJLambdaWrapper; +import io.swagger.annotations.ApiModelProperty; import org.apache.commons.compress.archivers.zip.ZipArchiveEntry; import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; +import org.checkerframework.checker.units.qual.A; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -39,6 +44,7 @@ import java.io.FileInputStream; import java.io.IOException; import java.net.URLEncoder; +import java.nio.charset.Charset; import java.util.*; import java.util.stream.Collectors; @@ -66,6 +72,21 @@ @Autowired private SettleClaimsLogJoinMapper settleClaimsLogJoinMapper; + + @Autowired + private NoticesMapper noticesMapper; + + @Autowired + private InsuranceApplyMapper insuranceApplyMapper; + + @Autowired + private SolutionsMapper solutionsMapper; + + @Autowired + private SolutionsBaseMapper solutionsBaseMapper; + + @Autowired + private ApplyDetailMapper applyDetailMapper; /** * 鍒犻櫎闄勪欢 @@ -117,6 +138,17 @@ update.setStatus(Constants.SettleClaimsStatus.RETURN_ACCEPTANCE.getKey()); settleClaimsMapper.updateById(update); + + //瀛樺偍寰呭姙淇℃伅 + Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.SETTLE_CLAIMS; + //鍒犻櫎鍏朵粬寰呭姙 + noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey()).eq(Notices::getObjId,model.getId())); + + Notices notices = new Notices(noticeObjectType,Constants.ONE,model.getId(),model.getInformantName(), + model.getCompanyId(), Constants.NoticeType.FOUR); + noticesMapper.insert(notices); + + Constants.SettleClaimsLogType applyLogType = Constants.SettleClaimsLogType.PLATFORM_RETURN; String info =applyLogType.getInfo(); info = info.replace("${param}", update.getCheckInfo()); @@ -155,6 +187,12 @@ update.setId(model.getId()); update.setStatus(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()); settleClaimsMapper.updateById(update); + + + //瀛樺偍寰呭姙淇℃伅 + Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.SETTLE_CLAIMS; + //鍒犻櫎鍏朵粬寰呭姙 + noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey()).eq(Notices::getObjId,model.getId())); Constants.SettleClaimsLogType applyLogType = Constants.SettleClaimsLogType.PLATFORM_CONFIRM_INFORMATION; String info =applyLogType.getInfo(); @@ -239,6 +277,14 @@ update.setScClaimAccount(Constants.formatBigdecimal(param.getScClaimAccount())); update.setClaimAccount(update.getYlClaimAccount().add(update.getSwClaimAccount()).add(update.getScClaimAccount()).add(update.getWgClaimAccount())); settleClaimsMapper.updateById(update); + + //瀛樺偍寰呭姙淇℃伅 + Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.SETTLE_CLAIMS; + //鍒犻櫎鍏朵粬寰呭姙 + noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey()).eq(Notices::getObjId,model.getId())); + Notices notices = new Notices(noticeObjectType,Constants.ONE,model.getId(),model.getInformantName(), + model.getCompanyId(), Constants.NoticeType.ONE); + noticesMapper.insert(notices); Constants.SettleClaimsLogType applyLogType = Constants.SettleClaimsLogType.PLATFORM_FINISH; String info =applyLogType.getInfo(); @@ -385,6 +431,17 @@ } //璁板綍鏃ュ織 this.saveSettleClaimsLog(settleClaims,Constants.SettleClaimsLogType.UPLOAD,null); + + + //瀛樺偍寰呭姙淇℃伅 + Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.SETTLE_CLAIMS; + //鍒犻櫎鍏朵粬寰呭姙 + noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey()).eq(Notices::getObjId,settleClaims.getId())); + Notices notices = new Notices(noticeObjectType,Constants.ZERO,settleClaims.getId(),settleClaims.getInformantName(), + settleClaims.getCompanyId(), Constants.NoticeType.ZERO); + noticesMapper.insert(notices); + + return settleClaims.getId(); } @@ -406,6 +463,7 @@ List<File> fileList = new ArrayList<>(); List<Multifile> multifileList = multifileJoinMapper.selectList(new QueryWrapper<Multifile>().lambda() + .eq(Multifile::getIsdeleted,Constants.ZERO) .eq(Multifile::getObjId,id) .isNotNull(Multifile::getFileurl) .in(Multifile::getObjType, Arrays.asList(new Integer[]{ @@ -415,28 +473,31 @@ Constants.MultiFile.LP_SCZL_FILE.getKey(), Constants.MultiFile.LP_JACL_FILE.getKey(), })) + .orderByAsc(Multifile::getCreateDate) ); if(multifileList== null || multifileList.size() == 0){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } String path = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode()+systemDictDataBiz.queryByCode(Constants.OSS,Constants.SETTLE_FILE).getCode(); + Integer sn = 1; for(Multifile l : multifileList){ - File f = Constants.getFileByNetFile(path + l.getFileurl(),StringUtils.defaultString(l.getName(),"鏈懡鍚�")); + File f = Constants.getFileByNetFile(path + l.getFileurl(),StringUtils.defaultString(sn + "_" +l.getName(),"鏈懡鍚�")); if(f !=null && f.isFile()){ fileList.add(f); } + sn = sn +1; } if(fileList == null || fileList.size() == 0){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } - String fileName = model.getInformantName() +"鐞嗚禂璧勬枡涓媉"+System.currentTimeMillis()+".zip" ; - String encodeFileName = URLEncoder.encode(fileName); + String fileName = model.getInformantName() +"-鐞嗚禂璧勬枡-" +System.currentTimeMillis(); + String encodeFileName =URLEncoder.encode(fileName, Charset.forName("UTF-8").toString())+".zip"; response.setHeader("Content-Disposition","attachment;filename=" + encodeFileName); response.setContentType("application/octet-stream"); response.setHeader("eva-opera-type", "download"); response.setHeader("eva-download-filename", encodeFileName); Constants.packFilesToZip(fileList,response.getOutputStream()); - } catch (IOException e) { + } catch (Exception e) { throw new BusinessException(ResponseStatus.EXPORT_EXCEL_ERROR, e); } } @@ -520,8 +581,34 @@ .eq(SettleClaimsLog::getSettleClainmsId,settleClaims.getId()) .orderByAsc(SettleClaimsLog::getCreateDate) ); - settleClaims.setSettleClaimsLogList(settleClaimsLogList); + SettleClaimsLog lastConfirm = settleClaimsLogMapper.selectOne(new QueryWrapper<SettleClaimsLog>().lambda() + .eq(SettleClaimsLog::getSettleClainmsId,settleClaims.getId()) + .eq(SettleClaimsLog::getObjType,Constants.SettleClaimsLogType.PLATFORM_CONFIRM_INFORMATION.getKey()) + .orderByDesc(SettleClaimsLog::getCreateDate) + .last(" limit 1") + ); + + Multifile multifile = multifileJoinMapper.selectOne(new QueryWrapper<Multifile>() + .lambda() + .eq(Multifile::getObjId,settleClaims.getId()) + .eq(Multifile::getIsdeleted,Constants.ZERO) + .in(Multifile::getObjType, + Constants.MultiFile.LP_SGXC_FILE.getKey(), + Constants.MultiFile.LP_YGGX_FILE.getKey(), + Constants.MultiFile.LP_MZCL_FILE.getKey(), + Constants.MultiFile.LP_ZYCL_FILE.getKey(), + Constants.MultiFile.LP_SCZL_FILE.getKey(), + Constants.MultiFile.LP_JACL_FILE.getKey()) + .orderByDesc(Multifile::getCreateDate) + .last(" limit 1") + ); + + if(!Objects.isNull(lastConfirm)&&!Objects.isNull(multifile)){ + settleClaims.setFinishDate(lastConfirm.getCreateDate().compareTo(multifile.getCreateDate())>=0?lastConfirm.getCreateDate():multifile.getCreateDate()); + }else if(!Objects.isNull(lastConfirm)&&Objects.isNull(multifile)){ + settleClaims.setFinishDate(lastConfirm.getCreateDate()); + } return settleClaims; } @@ -555,6 +642,7 @@ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏃犳硶淇敼鏂规淇℃伅"); } if(!(oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey()) + || oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.DEAL_ING.getKey()) || oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔"); } @@ -593,6 +681,7 @@ } SettleClaims settleClaims = settleClaimsMapper.selectById(scSupplementDTO.getId()); if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey()) + || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.DEAL_ING.getKey()) || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔"); } @@ -624,6 +713,7 @@ SettleClaims settleClaims = settleClaimsMapper.selectById(scSupplementDTO.getId()); if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey()) + || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.DEAL_ING.getKey()) || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔"); } @@ -637,7 +727,7 @@ multifile.setObjType(scSupplementDTO.getObjType()); multifile.setObjId(scSupplementDTO.getId()); multifile.setFileurl(scSupplementDTO.getFileUrl()); - multifile.setName(scSupplementDTO.getFileUrl().substring(scSupplementDTO.getFileUrl().lastIndexOf("/") + 1)); + multifile.setName(scSupplementDTO.getFileName()); multifile.setType(scSupplementDTO.getFileType()); multifileJoinMapper.insert(multifile); } @@ -732,6 +822,7 @@ .leftJoin(InsuranceApply.class,InsuranceApply::getId,SettleClaims::getInsuranceApplyId) .leftJoin(Solutions.class,Solutions::getId,SettleClaims::getSolutionId); queryWrapper.eq(DispatchUnit::getIsdeleted,Constants.ZERO); + queryWrapper.eq(SettleClaims::getIsdeleted,Constants.ZERO); if(Constants.equalsInteger(user.getType(),Constants.ZERO)){ //鍙兘鐪嬫潈闄愯寖鍥村唴 if(user.getCompanyIdList() == null || user.getCompanyIdList().size() == 0){ @@ -810,7 +901,15 @@ queryWrapper.eq(SettleClaims::getCode, pageWrap.getModel().getCode()); } if (pageWrap.getModel().getStatus() != null) { - queryWrapper.eq(SettleClaims::getStatus, pageWrap.getModel().getStatus()); + if(pageWrap.getModel().getStatus().equals(Constants.ZERO)){ + queryWrapper.in(SettleClaims::getStatus, Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey() + ,Constants.SettleClaimsStatus.DEAL_ING.getKey() + ,Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()); + }else{ + queryWrapper.eq(SettleClaims::getStatus, pageWrap.getModel().getStatus()); + } + + } if (pageWrap.getModel().getType() != null) { queryWrapper.eq(SettleClaims::getType, pageWrap.getModel().getType()); @@ -842,7 +941,7 @@ if (pageWrap.getModel().getInsuranceApplyId() != null) { queryWrapper.eq(SettleClaims::getInsuranceApplyId, pageWrap.getModel().getInsuranceApplyId()); } - queryWrapper.orderByAsc(SettleClaims::getCreateDate); + queryWrapper.orderByDesc(SettleClaims::getCreateDate); /*for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); @@ -859,4 +958,361 @@ QueryWrapper<SettleClaims> wrapper = new QueryWrapper<>(settleClaims); return settleClaimsMapper.selectCount(wrapper); } + + + public void saveSettleClaims(SettleClaimsDTO settleClaimsDTO){ + LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + if(!loginUserInfo.getType().equals(Constants.ONE)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炰紒涓氬憳宸ユ棤娉曡繘琛岃鎿嶄綔"); + } + if(Objects.isNull(settleClaimsDTO) + || Objects.isNull(settleClaimsDTO.getSaveType()) + || Objects.isNull(settleClaimsDTO.getMemberId()) + ||StringUtils.isBlank(settleClaimsDTO.getIdcardNo()) + || Objects.isNull(settleClaimsDTO.getInsuranceApplyId()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + if(Constants.equalsInteger(settleClaimsDTO.getSaveType(),Constants.ONE)){ + if(Objects.isNull(settleClaimsDTO.getSolutionId()) + ||Objects.isNull(settleClaimsDTO.getWorktypeId()) + ||Objects.isNull(settleClaimsDTO.getDuId()) + ||StringUtils.isBlank(settleClaimsDTO.getHappenTime()) + ||StringUtils.isBlank(settleClaimsDTO.getContent()) + ||Objects.isNull(settleClaimsDTO.getType()) + ||Objects.isNull(settleClaimsDTO.getInHospital()) + ||Objects.isNull(settleClaimsDTO.getHurtType()) + ||Objects.isNull(settleClaimsDTO.getMedicalInsurance()) + ||StringUtils.isBlank(settleClaimsDTO.getInformantName()) + ||StringUtils.isBlank(settleClaimsDTO.getInformantPhone()) + ||StringUtils.isBlank(settleClaimsDTO.getReceiveUserName()) + ||StringUtils.isBlank(settleClaimsDTO.getReceiveBank()) + ||StringUtils.isBlank(settleClaimsDTO.getReceiveAccount()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + } + SettleClaims settleClaims = new SettleClaims(); + BeanUtils.copyProperties(settleClaimsDTO,settleClaims); + if(Objects.nonNull(settleClaims.getId())){ + settleClaims.setEditDate(new Date()); + settleClaims.setEditor(loginUserInfo.getId()); + settleClaimsMapper.updateById(settleClaims); + }else{ + settleClaims.setCreateDate(new Date()); + settleClaims.setIsdeleted(Constants.ZERO); + settleClaims.setCompanyId(loginUserInfo.getCompanyId()); + settleClaims.setStatus(Constants.equalsInteger(settleClaimsDTO.getSaveType(),Constants.ONE)? + Constants.SettleClaimsStatus.RETURN_ACCEPTANCE.getKey():Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey()); + settleClaims.setCreator(loginUserInfo.getId()); + settleClaims.setCheckUserId(loginUserInfo.getId()); + settleClaimsMapper.insert(settleClaims); + } + this.saveFile(settleClaims,settleClaimsDTO,loginUserInfo); + //澶勭悊椋庨櫓淇℃伅 + + + } + + public void saveRisk(SettleClaims settleClaims, SettleClaimsDTO settleClaimsDTO, SystemDictDataServiceImpl systemDictDataService){ + //鏍规嵁淇濆崟淇℃伅 鏌ヨ鍑轰富鏂规 + InsuranceApply insuranceApply = insuranceApplyMapper.selectById(settleClaims.getInsuranceApplyId()); + if(Objects.isNull(insuranceApply)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濆崟鏁版嵁"); + } + Date happenTime = DateUtil.StringToDate(settleClaims.getHappenTime()); + if(happenTime.getTime() < insuranceApply.getStartTime().getTime() || happenTime.getTime() > insuranceApply.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"浜嬫晠鍙戠敓浜嬩欢鏈湪淇濆崟鐢熸晥鑼冨洿鍐�"); + } + Solutions solutions = solutionsMapper.selectById(insuranceApply.getSolutionId()); + if(Objects.isNull(solutions)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌瀛愭柟妗堜俊鎭�"); + } + SolutionsBase solutionsBase = solutionsBaseMapper.selectById(solutions.getParentId()); + if(Objects.isNull(solutionsBase)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌涓绘柟妗堜俊鎭�"); + } + List<Map<String,String>> riskList = new ArrayList<>(); + //鏌ヨ淇濆崟鏄庣粏鏁版嵁 + ApplyDetail applyDetail = applyDetailMapper.selectOne(new QueryWrapper<ApplyDetail>().lambda().eq(ApplyDetail::getApplyId,settleClaims.getInsuranceApplyId()).eq(ApplyDetail::getId,settleClaimsDTO.getApplyDetailId()).last("limit 1 ")); + //鏄惁寮�鍚� 鏂板憳宸ユ姤妗� 0涓嶅厑璁� 1鍏佽 + if(Constants.equalsInteger(solutionsBase.getRiskNewUserStatus(),Constants.ONE) + && Objects.nonNull(solutionsBase.getRiskNewUserUnit()) + && Objects.nonNull(solutionsBase.getRiskNewUserTime()) + ){ + if(happenTime.getTime() > applyDetail.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"浜嬫晠鍙戠敓鏃堕棿鏈湪浜哄憳淇濋殰鏃ユ湡鑼冨洿鍐�"); + } + Map<String,String> map = new HashMap<>(); + map.put("title","淇濆崟宸叉姇淇濇湭鐢熸晥"); + Date startDate = applyDetail.getStartTime(); + if(Constants.equalsInteger(solutionsBase.getRiskNewUserUnit(),Constants.ONE)){ + startDate = DateUtil.afterMinutesByDate(-solutionsBase.getRiskNewUserTime()*60,startDate); + }else if(Constants.equalsInteger(solutionsBase.getRiskNewUserUnit(),Constants.TWO)){ + startDate = DateUtil.afterDayByDate(-solutionsBase.getRiskNewUserTime(),happenTime); + }else{ + if(happenTime.getTime() < applyDetail.getStartTime().getTime() || happenTime.getTime() > applyDetail.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"浜嬫晠鍙戠敓鏃堕棿鏈湪浜哄憳淇濋殰鏃ユ湡鑼冨洿鍐�"); + } + } + if(happenTime.getTime() < startDate.getTime() ){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"浜嬫晠鍙戠敓鏃堕棿鏈湪浜哄憳淇濋殰鏃ユ湡鑼冨洿鍐�"); + }else{ + map.put("info","浜嬫晠鍙戠敓鏃堕棿鏃╀簬淇濆崟鐢熸晥鏃堕棿"+solutionsBase.getRiskNewUserUnit()+(Constants.equalsInteger(solutionsBase.getRiskNewUserUnit(),Constants.ONE)?"灏忔椂鍐�":"澶╁唴")); + riskList.add(map); + } + }else{ + if(happenTime.getTime() < applyDetail.getStartTime().getTime() || happenTime.getTime() > applyDetail.getEndTime().getTime()){ + throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"浜嬫晠鍙戠敓鏃堕棿鏈湪浜哄憳淇濋殰鏃ユ湡鑼冨洿鍐�"); + } + } + + //鏄惁寮�鍚� 寤惰繜鎶ユ鎻愰啋鏄惁寮�鍚� 0涓嶅厑璁� 1鍏佽 + if(Constants.equalsInteger(solutionsBase.getRiskDelayStatus(),Constants.ONE)){ + Map<String,String> map = new HashMap<>(); + map.put("title","寤惰繜鎶ユ鎻愰啋"); + //鏍规嵁閰嶇疆 鏌ヨ 寤惰繜鎶ユ鎻愰啋鏃堕棿鍗曚綅 0鍒嗛挓 1灏忔椂 2澶� + if(Constants.equalsInteger(solutionsBase.getRiskDelayUnit(),Constants.ZERO)){ + if(DateUtil.getBetweenMin(happenTime,new Date())>solutionsBase.getRiskDelayTime()){ + map.put("info","鎶ユ鏃堕棿瓒呰繃妗堝彂鏃堕棿"+solutionsBase.getRiskDelayUnit()+"鍒嗛挓"); + riskList.add(map); + } + }else if(Constants.equalsInteger(solutionsBase.getRiskDelayUnit(),Constants.ONE)){ + if(DateUtil.getBetweenHours(happenTime,new Date())>solutionsBase.getRiskDelayTime()){ + map.put("info","鎶ユ鏃堕棿瓒呰繃妗堝彂鏃堕棿"+solutionsBase.getRiskDelayUnit()+"灏忔椂"); + riskList.add(map); + } + }else if(Constants.equalsInteger(solutionsBase.getRiskDelayUnit(),Constants.TWO)){ + if(DateUtil.getBetweenDay(happenTime,new Date())>solutionsBase.getRiskDelayTime()){ + map.put("info","鎶ユ鏃堕棿瓒呰繃妗堝彂鏃堕棿"+solutionsBase.getRiskDelayUnit()+"澶�"); + riskList.add(map); + } + } + } + + //鏌ヨ瀛楀吀鍊奸厤缃俊鎭� + RiskConfigVO riskConfigVO = systemDictDataService.getRiskConfig(); + //澶氭鍑洪櫓鎻愰啋 + if(StringUtils.isNotBlank(riskConfigVO.getRiskTimesOpen()) && StringUtils.equals(riskConfigVO.getRiskTimesOpen(),Constants.ONE+"") + && StringUtils.isNotBlank(riskConfigVO.getRiskTimesReportTimes())){ + Integer cxcs = settleClaimsMapper.selectCount(new QueryWrapper<SettleClaims>().lambda() + .eq(SettleClaims::getMemberId,settleClaimsDTO.getMemberId()) + .ne(Objects.nonNull(settleClaims.getId()),SettleClaims::getId,settleClaims.getId()) + .apply(" HAPPEN_TIME > DATE_SUB(now(), INTERVAL 365 DAY) ") + ); + if(cxcs>Integer.valueOf(riskConfigVO.getRiskTimesReportTimes())){ + Map<String,String> map = new HashMap<>(); + map.put("title","鐤戜技澶氭鍑洪櫓"); + map.put("info","鍑洪櫓浜轰竴骞村唴宸插嚭闄�"+cxcs+"娆�"); + riskList.add(map); + settleClaims.setRiskTimesCx(Constants.ONE); + }; + } + //鐤戜技閲嶅鎶ユ + if(StringUtils.isNotBlank(riskConfigVO.getRiskRepeatReportOpen()) + && StringUtils.equals(riskConfigVO.getRiskRepeatReportOpen(),Constants.ONE+"") + && StringUtils.isNotBlank(riskConfigVO.getRiskRepeatReportTimeUnit()) + && StringUtils.isNotBlank(riskConfigVO.getRiskRepeatReportTime())){ + Integer cxcs = settleClaimsMapper.selectCount(new QueryWrapper<SettleClaims>().lambda() + .eq(SettleClaims::getMemberId,settleClaimsDTO.getMemberId()) + .ne(Objects.nonNull(settleClaims.getId()),SettleClaims::getId,settleClaims.getId()) + .apply(riskConfigVO.getRiskRepeatReportTimeUnit().equals("1")," HAPPEN_TIME > DATE_SUB(now(), INTERVAL "+riskConfigVO.getRiskRepeatReportTime()+" HOUR) ") + .apply(riskConfigVO.getRiskRepeatReportTimeUnit().equals("2")," HAPPEN_TIME > DATE_SUB(now(), INTERVAL "+riskConfigVO.getRiskRepeatReportTime()+" DAY) ") + ); + if(cxcs > Constants.TWO){ + Map<String,String> map = new HashMap<>(); + map.put("title","鐤戜技閲嶅鎶ユ"); + map.put("info","璇ュ嚭闄╀汉鍦�"+riskConfigVO.getRiskRepeatReportTime()+(riskConfigVO.getRiskRepeatReportTimeUnit().equals("1")?"灏忔椂":"澶�")+"鍐呭凡鎶ユ"+cxcs+"娆�"); + riskList.add(map); + settleClaims.setRiskRepeat(Constants.ONE); + } + } + + + //绱㈣禂娆℃暟杩囧鎻愰啋 + if(StringUtils.isNotBlank(riskConfigVO.getRiskClaimTimesOpen()) + && StringUtils.equals(riskConfigVO.getRiskClaimTimesOpen(),Constants.ONE+"") + && StringUtils.isNotBlank(riskConfigVO.getRiskClaimTimes())){ + Integer cxcs = settleClaimsMapper.selectCount(new QueryWrapper<SettleClaims>().lambda() + .eq(SettleClaims::getInsuranceApplyId,settleClaimsDTO.getInsuranceApplyId()) + .ne(Objects.nonNull(settleClaims.getId()),SettleClaims::getId,settleClaims.getId()) + .apply(" HAPPEN_TIME > DATE_SUB(now(), INTERVAL 365 DAY) ") + ); + if(cxcs > Integer.valueOf(riskConfigVO.getRiskClaimTimes())){ + Map<String,String> map = new HashMap<>(); + map.put("title","璇ヤ繚鍗曠储璧旀鏁拌繃澶�"); + map.put("info","绱绱㈣禂娆℃暟宸插埌杈�"+cxcs+"娆�"); + riskList.add(map); + settleClaims.setRiskTimesSp(Constants.ONE); + } + } + + //璁捐鏁忔劅璇嶆眹 + if(StringUtils.isNotBlank(riskConfigVO.getRiskSensitiveWordsOpen()) + && StringUtils.equals(riskConfigVO.getRiskSensitiveWordsOpen(),Constants.ONE+"") + && StringUtils.isNotBlank(riskConfigVO.getRiskSensitiveWords())){ + String [] words = riskConfigVO.getRiskSensitiveWords().split(","); + String sensitiveWord = ""; + for (String word:words) { + if(settleClaims.getContent().indexOf(word)>=Constants.ZERO){ + if(Constants.equalsInteger(sensitiveWord.length(),Constants.ZERO)){ + sensitiveWord = word; + }else{ + sensitiveWord = sensitiveWord + "銆�" + word ; + } + } + } + if(!Constants.equalsInteger(sensitiveWord.length(),Constants.ZERO)){ + Map<String,String> map = new HashMap<>(); + map.put("title","娑夊強鏁忔劅璇�"); + map.put("info","妫�娴嬪埌鏁忔劅璇嶏細"+sensitiveWord); + riskList.add(map); + settleClaims.setRiskSensitive(sensitiveWord); + } + } + + //鐤戜技鏂板憳宸ュ嚭闄� + + } + + public void saveFile(SettleClaims settleClaims,SettleClaimsDTO settleClaimsDTO,LoginUserInfo loginUserInfo){ + multifileJoinMapper.delete(new QueryWrapper<Multifile>().lambda() + .eq(Multifile::getObjId,settleClaims.getId()) + .in(Multifile::getObjType, + Constants.MultiFile.LP_SGXC_FILE.getKey(), + Constants.MultiFile.LP_YGGX_FILE.getKey(), + Constants.MultiFile.LP_MZCL_FILE.getKey(), + Constants.MultiFile.LP_ZYCL_FILE.getKey(), + Constants.MultiFile.LP_OTHER_FILE.getKey(), + Constants.MultiFile.LP_SCZL_FILE.getKey() + ) + ); + List<Multifile> reportVideo = settleClaimsDTO.getReportFileList(); + if(CollectionUtils.isNotEmpty(reportVideo)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_SGXC_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + List<Multifile> relationFileList = settleClaimsDTO.getRelationFileList(); + if(CollectionUtils.isNotEmpty(relationFileList)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_YGGX_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + List<Multifile> outpatientFileList = settleClaimsDTO.getOutpatientFileList(); + if(CollectionUtils.isNotEmpty(outpatientFileList)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_MZCL_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + List<Multifile> hospitalFileList = settleClaimsDTO.getHospitalFileList(); + if(CollectionUtils.isNotEmpty(hospitalFileList)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_ZYCL_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + List<Multifile> disabilityFileList = settleClaimsDTO.getDisabilityFileList(); + if(CollectionUtils.isNotEmpty(disabilityFileList)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_SCZL_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + List<Multifile> otherFileList = settleClaimsDTO.getOtherFileList(); + if(CollectionUtils.isNotEmpty(otherFileList)){ + for (int i = 0; i < reportVideo.size(); i++) { + Multifile multifile = reportVideo.get(i); + if(Objects.isNull(multifile.getFileurl()) + || Objects.isNull(multifile.getType()) + || StringUtils.isBlank(multifile.getName()) + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闄勪欢鍐呭寮傚父"); + } + multifile.setCreator(loginUserInfo.getId()); + multifile.setCreateDate(new Date()); + multifile.setIsdeleted(Constants.ZERO); + multifile.setObjId(settleClaims.getId()); + multifile.setObjType(Constants.MultiFile.LP_OTHER_FILE.getKey()); + multifile.setSortnum(i+1); + multifileJoinMapper.insert(multifile); + } + } + + + + + } + + + + } -- Gitblit v1.9.3