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