From 418eb69319481f176a49ab085b971d81d55661f7 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 20 五月 2025 10:32:36 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/2.0.1' into 2.0.1
---
 server/service/src/main/java/com/doumee/service/business/impl/UnionChangeServiceImpl.java |  438 ++++++++++++++++++++++++++----------------------------
 1 files changed, 208 insertions(+), 230 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 deac02d..9dec078 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
@@ -1,6 +1,7 @@
 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.annotation.excel.ExcelExporter;
 import com.doumee.core.constants.ResponseStatus;
@@ -31,12 +32,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;
 
 /**
@@ -377,33 +380,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()
@@ -689,215 +696,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.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(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);
-
     }
 
 
@@ -946,6 +925,7 @@
                 .eq(InsuranceApply::getId, applyChange.getApplyId())
         );
         applyChange.setFee(bigDecimalVO.getTotalFee());
+
     }
 
 
@@ -958,7 +938,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);
 
         //鍔犱繚
@@ -1071,17 +1051,15 @@
         //濡傛灉鎵瑰崟鏃ユ湡 澶т簬 鍛樺伐淇濆崟鐨勫紑濮嬫棩鏈�
         if(reduceDate.getTime() > oldModel.getStartTime().getTime()){
             reduceDate = DateUtil.getMontageDate(applyChange.getDelValidTime(), 3);
-//            if(reduceDate.getTime()<oldModel.getStartTime().getTime()){
-//                reduceDate = DateUtil.getMontageDate(oldModel.getStartTime(), 3);
-//            }else{
-//                reduceDate = DateUtil.getMontageDate(applyChange.getDelValidTime(), 3);
-//            }
-        }else{
+            //鍑忎繚璁板綍鎿嶄綔鍚庣殑鎬昏垂鐢�
+            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) ;
         }
-        //鍑忎繚璁板綍鎿嶄綔鍚庣殑鎬昏垂鐢�
-        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