From fc03a64522e6c6e0f47eeb82c8900e1910a0a363 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期四, 01 二月 2024 09:11:11 +0800
Subject: [PATCH] 111

---
 server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java     |  317 ++++++++++++++++++------
 server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java                  |    4 
 server/service/src/main/java/com/doumee/service/business/impl/ApplyDetailServiceImpl.java     |    1 
 server/company/src/main/java/com/doumee/api/business/MemberInsuranceController.java           |    7 
 server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java    |   20 
 server/service/src/main/java/com/doumee/dao/business/vo/AreasTree.java                        |   90 ++++++
 server/company/src/main/java/com/doumee/api/business/SettleClaimsController.java              |    2 
 server/service/src/main/java/com/doumee/service/business/impl/MemberInsuranceServiceImpl.java |    7 
 server/service/src/main/java/com/doumee/dao/business/model/MemberInsurance.java               |   80 +++++
 server/service/src/main/java/com/doumee/core/utils/DateUtil.java                              |   53 +++
 server/platform/src/main/java/com/doumee/api/common/PublicController.java                     |    1 
 server/service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java           |    1 
 server/company/src/main/java/com/doumee/api/business/AreasController.java                     |   16 +
 server/service/src/main/java/com/doumee/core/utils/Constants.java                             |   18 +
 server/service/src/main/java/com/doumee/service/business/impl/InsuranceApplyServiceImpl.java  |   83 ++++-
 server/company/src/main/java/com/doumee/api/common/PublicController.java                      |   12 
 server/service/src/main/java/com/doumee/dao/business/dto/SCSupplementDTO.java                 |    1 
 server/service/src/main/java/com/doumee/dao/business/join/MemberInsuranceJoinMapper.java      |   18 +
 server/service/src/main/java/com/doumee/dao/business/model/Areas.java                         |    7 
 server/service/src/main/java/com/doumee/dao/business/model/ApplyDetail.java                   |    4 
 20 files changed, 611 insertions(+), 131 deletions(-)

diff --git a/server/company/src/main/java/com/doumee/api/business/AreasController.java b/server/company/src/main/java/com/doumee/api/business/AreasController.java
index 8fd44d6..0c96ba9 100644
--- a/server/company/src/main/java/com/doumee/api/business/AreasController.java
+++ b/server/company/src/main/java/com/doumee/api/business/AreasController.java
@@ -7,6 +7,7 @@
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.model.PageData;
 import com.doumee.dao.business.model.Areas;
+import com.doumee.dao.business.vo.AreasTree;
 import com.doumee.service.business.AreasService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
@@ -74,6 +75,21 @@
         return ApiResponse.success(areasService.findPage(pageWrap));
     }
 
+    @ApiOperation("鍒楄〃鏌ヨ")
+    @PostMapping("/findList")
+    public ApiResponse<List<Areas>> findList (@RequestBody Areas areas) {
+        return ApiResponse.success(areasService.findList(areas));
+    }
+
+    @ApiOperation("鍖哄煙鏍戝垪琛�")
+    @PostMapping("/findTreeList")
+    public ApiResponse<List<Areas>> findTreeList () {
+        List<Areas> areasList = areasService.findList(new Areas());
+        AreasTree treeBuild = new AreasTree(areasList);
+        areasList = treeBuild.buildTree();
+        return ApiResponse.success(areasList);
+    }
+
     @ApiOperation("瀵煎嚭Excel")
     @PostMapping("/exportExcel")
     @RequiresPermissions("business:areas:exportExcel")
diff --git a/server/company/src/main/java/com/doumee/api/business/MemberInsuranceController.java b/server/company/src/main/java/com/doumee/api/business/MemberInsuranceController.java
index 22f6137..e2679df 100644
--- a/server/company/src/main/java/com/doumee/api/business/MemberInsuranceController.java
+++ b/server/company/src/main/java/com/doumee/api/business/MemberInsuranceController.java
@@ -74,6 +74,13 @@
         return ApiResponse.success(memberInsuranceService.findPage(pageWrap));
     }
 
+    @ApiOperation("鍒楄〃鏌ヨ")
+    @PostMapping("/findList")
+    @RequiresPermissions("business:memberinsurance:query")
+    public ApiResponse<List<MemberInsurance>> findList (@RequestBody MemberInsurance memberInsurance) {
+        return ApiResponse.success(memberInsuranceService.findList(memberInsurance));
+    }
+
     @ApiOperation("瀵煎嚭Excel")
     @PostMapping("/exportExcel")
     @RequiresPermissions("business:memberinsurance:exportExcel")
diff --git a/server/company/src/main/java/com/doumee/api/business/SettleClaimsController.java b/server/company/src/main/java/com/doumee/api/business/SettleClaimsController.java
index 6e2d2fa..ad43c63 100644
--- a/server/company/src/main/java/com/doumee/api/business/SettleClaimsController.java
+++ b/server/company/src/main/java/com/doumee/api/business/SettleClaimsController.java
@@ -102,7 +102,7 @@
     @ApiOperation("鏍规嵁ID鏌ヨ")
     @GetMapping("/{id}")
     @RequiresPermissions("business:settleclaims:query")
-    public ApiResponse findById(@PathVariable Integer id) {
+    public ApiResponse<SettleClaims> findById(@PathVariable Integer id) {
         return ApiResponse.success(settleClaimsService.getSettleClaimsDetail(id));
     }
     @ApiOperation("鍒犻櫎闄勪欢")
diff --git a/server/company/src/main/java/com/doumee/api/common/PublicController.java b/server/company/src/main/java/com/doumee/api/common/PublicController.java
index 10c9278..81b84f4 100644
--- a/server/company/src/main/java/com/doumee/api/common/PublicController.java
+++ b/server/company/src/main/java/com/doumee/api/common/PublicController.java
@@ -129,6 +129,17 @@
                     String tempFileName =  nowDate + "/" + fileName;
                     String key = folder + tempFileName;// 鏂囦欢鍚�
                     ALiYunUtil obs = new ALiYunUtil(endpoint,access_id, access_key);
+                    int type = 2;
+                    if(StringUtils.endsWith(key,".mp4")){
+                        type =1;
+                    }else if(StringUtils.endsWith(key,".jpg")
+                            || StringUtils.endsWith(key,".JPG")
+                            || StringUtils.endsWith(key,".png")
+                            || StringUtils.endsWith(key,".PNG")
+                            || StringUtils.endsWith(key,".jpeg")
+                            || StringUtils.endsWith(key,".JPEG")){
+                        type =0;
+                    }
                     if (obs.uploadOnlineObject(file.getInputStream(),bucketName, key,null)) {
                         // 绉诲姩鎴愬姛,杩斿洖鏂囦欢鍚�
                         // sendSuccessMessage(response, resourcePath+key);
@@ -139,6 +150,7 @@
                         fileJSON.put("url", resourcePath + key);
                         fileJSON.put("imgaddr", tempFileName);
                         fileJSON.put("imgname", fileName);
+                        fileJSON.put("type", type);
                         fileJSON.put("originname", originname);
                         context.put("data",fileJSON);
                         context.put("message","璇锋眰鎴愬姛");
diff --git a/server/platform/src/main/java/com/doumee/api/common/PublicController.java b/server/platform/src/main/java/com/doumee/api/common/PublicController.java
index 990ab93..5aa2019 100644
--- a/server/platform/src/main/java/com/doumee/api/common/PublicController.java
+++ b/server/platform/src/main/java/com/doumee/api/common/PublicController.java
@@ -176,6 +176,7 @@
                         type =1;
                     }else if(StringUtils.endsWith(key,".jpg")
                             || StringUtils.endsWith(key,".JPG")
+                            || StringUtils.endsWith(key,".png")
                             || StringUtils.endsWith(key,".PNG")
                             || StringUtils.endsWith(key,".jpeg")
                             || StringUtils.endsWith(key,".JPEG")){
diff --git a/server/service/src/main/java/com/doumee/core/utils/Constants.java b/server/service/src/main/java/com/doumee/core/utils/Constants.java
index f2b834f..5270010 100644
--- a/server/service/src/main/java/com/doumee/core/utils/Constants.java
+++ b/server/service/src/main/java/com/doumee/core/utils/Constants.java
@@ -3,6 +3,7 @@
 import com.doumee.core.constants.ResponseStatus;
 import com.doumee.core.exception.BusinessException;
 import com.doumee.dao.business.model.Solutions;
+import com.doumee.dao.business.vo.CountCyclePriceVO;
 import io.swagger.models.auth.In;
 import org.apache.commons.collections4.CollectionUtils;
 import org.apache.commons.compress.archivers.zip.ZipArchiveEntry;
@@ -161,6 +162,23 @@
         return age;
     }
 
+
+    public static CountCyclePriceVO countPriceVO(Date startDate, Solutions solutions){
+        CountCyclePriceVO countCyclePriceVO = new CountCyclePriceVO();
+        if(solutions.getInsureCycleUnit().equals(Constants.ZERO)){
+            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(startDate,0,solutions.getInsureCycle()));
+        }else if(solutions.getInsureCycleUnit().equals(Constants.TWO)){
+            Integer monthDays = DateUtil.monthDays(startDate);
+            Date afterDate = DateUtil.afterDateByType(startDate,0,monthDays);
+            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(afterDate,0,-1));
+        }else if(solutions.getInsureCycleUnit().equals(Constants.THREE)){
+            Date afterDate = DateUtil.afterDateByType(startDate,2,solutions.getInsureCycle());
+            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(afterDate,0,-1));
+        }
+        countCyclePriceVO.setCyclePrice(Constants.countDetailFee(solutions,countCyclePriceVO.getEndDate(),startDate));
+        return countCyclePriceVO;
+    }
+
     public static Integer getSexByIdCard(String idCard){
         Pattern pattern = Pattern.compile("\\d{17}[\\d|x]"); // 瀹氫箟韬唤璇佸彿鐮佹牸寮忕殑姝e垯琛ㄨ揪寮�
         Matcher matcher = pattern.matcher(idCard);
diff --git a/server/service/src/main/java/com/doumee/core/utils/DateUtil.java b/server/service/src/main/java/com/doumee/core/utils/DateUtil.java
index e6e6b7e..ef4258d 100644
--- a/server/service/src/main/java/com/doumee/core/utils/DateUtil.java
+++ b/server/service/src/main/java/com/doumee/core/utils/DateUtil.java
@@ -3109,19 +3109,66 @@
     }
 
 
+    /**
+     * 鎷兼帴鏃ユ湡鏁版嵁
+     * @param date
+     * @param optType   1:姣忔棩寮�濮� 2锛氭瘡鏃ョ粨鏉� 3:鏄ㄦ棩缁撴潫
+     * @return
+     */
+    public static Date getMontageDate(Date date ,Integer optType) {
+        String strShortDate = DateUtil.dateToString(date,"yyyy-MM-dd");
+        if(optType.equals(1)){
+            return DateUtil.StringToDate(strShortDate +" 00:00:00");
+        }else if(optType.equals(2)){
+            return DateUtil.StringToDate(strShortDate +" 23:59:59");
+        }else if(optType.equals(3)){
+            strShortDate = DateUtil.dateToString(DateUtil.getDateBetween(date,-1),"yyyy-MM-dd");
+            return DateUtil.StringToDate(strShortDate +" 23:59:59");
+        }else{
+            return null;
+        }
+    }
+
 
     public static void main(String[] args) {
 //       System.out.println(DateUtil.DateToStr(DateUtil.afterDateByType(
 //               DateUtil.stringToDate("2024-02-01","yyyy-MM-dd")
 //               ,1,1),"yyyy-MM-dd HH:mm:ss"));
 
-        System.out.println( DateUtil.daysBetweenDates(DateUtil.stringToDate("2024-02-29","yyyy-MM-dd"),
-                DateUtil.stringToDate("2024-02-01","yyyy-MM-dd"))
+//        System.out.println( DateUtil.daysBetweenDates(DateUtil.stringToDate("2024-02-29","yyyy-MM-dd"),
+//                DateUtil.stringToDate("2024-02-01","yyyy-MM-dd"))
+//        );
+//
+//        System.out.println(DateUtil.calculateBetween(DateUtil.StringToDate("2024-02-29 23:59:59"),DateUtil.StringToDate("2024-02-01 00:00:00"),0));
+
+
+        System.out.println(
+                DateUtil.DateToStr(
+
+                DateUtil.getMontageDate(DateUtil.StringToDate("2024-02-29 21:59:59"),1) ,"yyyy-MM-dd HH:mm:ss"
+                )
         );
 
-        System.out.println(DateUtil.calculateBetween(DateUtil.StringToDate("2024-02-29 23:59:59"),DateUtil.StringToDate("2024-02-01 00:00:00"),0));
 
 
+        System.out.println(
+
+                DateUtil.DateToStr(
+
+                        DateUtil.getMontageDate(DateUtil.StringToDate("2024-02-29 21:59:59"),2) ,"yyyy-MM-dd HH:mm:ss"
+                )
+
+        );
+
+        System.out.println(
+
+                DateUtil.DateToStr(
+
+                        DateUtil.getMontageDate(DateUtil.StringToDate("2024-02-29 21:59:59"),3) ,"yyyy-MM-dd HH:mm:ss"
+                )
+
+        );
+
 //        Calendar calo = Calendar.getInstance();
 //        Calendar caln = Calendar.getInstance(); // ,"yyyy-MM-dd HH:mm:ss"
 //        caln.setTime(DateUtil.StringToDate("2024-02-29 23:59:59"));
diff --git a/server/service/src/main/java/com/doumee/dao/business/dto/SCSupplementDTO.java b/server/service/src/main/java/com/doumee/dao/business/dto/SCSupplementDTO.java
index 50fab89..1e05014 100644
--- a/server/service/src/main/java/com/doumee/dao/business/dto/SCSupplementDTO.java
+++ b/server/service/src/main/java/com/doumee/dao/business/dto/SCSupplementDTO.java
@@ -20,6 +20,7 @@
 
     @ApiModelProperty(value = "鏂囦欢璺緞")
     private String fileUrl;
+
     @ApiModelProperty(value = "鏂囦欢鍚嶇О")
     private String fileName;
 
diff --git a/server/service/src/main/java/com/doumee/dao/business/join/MemberInsuranceJoinMapper.java b/server/service/src/main/java/com/doumee/dao/business/join/MemberInsuranceJoinMapper.java
new file mode 100644
index 0000000..c2b25b0
--- /dev/null
+++ b/server/service/src/main/java/com/doumee/dao/business/join/MemberInsuranceJoinMapper.java
@@ -0,0 +1,18 @@
+package com.doumee.dao.business.join;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.doumee.dao.business.model.ApplyDetail;
+import com.doumee.dao.business.model.MemberInsurance;
+import com.github.yulichang.base.mapper.MPJJoinMapper;
+
+import java.util.List;
+
+/**
+ * @author 姹熻箘韫�
+ * @date 2024/01/22 11:55
+ */
+public interface MemberInsuranceJoinMapper extends MPJJoinMapper<MemberInsurance> {
+
+    void insertBatchSomeColumn(List<MemberInsurance> addList);
+
+}
diff --git a/server/service/src/main/java/com/doumee/dao/business/model/ApplyDetail.java b/server/service/src/main/java/com/doumee/dao/business/model/ApplyDetail.java
index 0167ba5..2b55812 100644
--- a/server/service/src/main/java/com/doumee/dao/business/model/ApplyDetail.java
+++ b/server/service/src/main/java/com/doumee/dao/business/model/ApplyDetail.java
@@ -110,6 +110,10 @@
     @ExcelColumn(name="淇濋櫓鏂规",index =2)
     private String solutionName;
 
+    @ApiModelProperty(value = "鏂规涓婚敭")
+    @TableField(exist = false)
+    private Integer solutionId;
+
     @ApiModelProperty(value = "鎵瑰崟鍙�")
     @TableField(exist = false)
     private String validCode;
diff --git a/server/service/src/main/java/com/doumee/dao/business/model/Areas.java b/server/service/src/main/java/com/doumee/dao/business/model/Areas.java
index 67de20f..62f57b8 100644
--- a/server/service/src/main/java/com/doumee/dao/business/model/Areas.java
+++ b/server/service/src/main/java/com/doumee/dao/business/model/Areas.java
@@ -1,5 +1,6 @@
 package com.doumee.dao.business.model;
 
+import com.baomidou.mybatisplus.annotation.TableField;
 import com.doumee.core.annotation.excel.ExcelColumn;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
@@ -9,6 +10,7 @@
 import lombok.Data;
 import com.fasterxml.jackson.annotation.JsonFormat;
 import java.util.Date;
+import java.util.List;
 
 /**
  * 鐪佸競鍖轰俊鎭〃
@@ -71,4 +73,9 @@
     @ExcelColumn(name="鎺掑簭鐮�")
     private Integer sortnum;
 
+    @ApiModelProperty(value = "瀛愰泦鏁版嵁", example = "1")
+    @TableField(exist = false)
+    private List<Areas> childAreasList;
+
+
 }
diff --git a/server/service/src/main/java/com/doumee/dao/business/model/MemberInsurance.java b/server/service/src/main/java/com/doumee/dao/business/model/MemberInsurance.java
index 218436d..0ce8b72 100644
--- a/server/service/src/main/java/com/doumee/dao/business/model/MemberInsurance.java
+++ b/server/service/src/main/java/com/doumee/dao/business/model/MemberInsurance.java
@@ -1,6 +1,8 @@
 package com.doumee.dao.business.model;
 
 import com.doumee.core.annotation.excel.ExcelColumn;
+import com.doumee.core.model.LoginUserInfo;
+import com.doumee.core.utils.Constants;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
 import com.baomidou.mybatisplus.annotation.IdType;
@@ -20,6 +22,59 @@
 @ApiModel("鍛樺伐鎶曚繚鏄庣粏璁板綍")
 @TableName("`member_insurance`")
 public class MemberInsurance {
+
+    public MemberInsurance(){
+
+    }
+    //鎶曚繚鐢宠鏁版嵁
+    public MemberInsurance(ApplyDetail applyDetail, Integer sysUserId){
+        this.createDate = new Date();
+        this.creator = sysUserId;
+        this.isdeleted = Constants.ZERO;
+        this.applyId = applyDetail.getApplyId();
+        this.memberId = applyDetail.getMemberId();
+        this.endTime = applyDetail.getEndTime();
+        this.startTime = applyDetail.getStartTime();
+        this.idcardNo = applyDetail.getIdcardNo();
+        this.solutionId = applyDetail.getSolutionId();
+        this.duId = applyDetail.getDuId();
+        this.worktypeId = applyDetail.getWorktypeId();
+        this.fee = applyDetail.getFee();
+        this.sex = applyDetail.getSex();
+        this.bdCode = applyDetail.getApplyCode();
+        this.solutionName = applyDetail.getSolutionName();
+        this.worktypeName = applyDetail.getWorkTypeName();
+        this.duName = applyDetail.getDuName();
+//        this.relationType = Constants.ZERO;
+        this.relationId = applyDetail.getId();
+    }
+
+
+    //鍔犲噺淇濈敵璇锋暟鎹�
+    public MemberInsurance(ApplyChagneDetail applyChangeDetail, ApplyChange applyChange, Integer sysUserId,Integer applyDetailId){
+        this.createDate = new Date();
+        this.creator = sysUserId;
+        this.isdeleted = Constants.ZERO;
+        this.applyId = applyChange.getApplyId();
+        this.memberId = applyChangeDetail.getMemberId();
+        this.endTime = applyChangeDetail.getEndTime();
+        this.startTime = applyChangeDetail.getStartTime();
+        this.idcardNo = applyChangeDetail.getIdcardNo();
+        this.duId = applyChangeDetail.getDuId();
+        this.worktypeId = applyChangeDetail.getWorktypeId();
+        this.fee = applyChangeDetail.getFee();
+        this.sex = applyChangeDetail.getSex();
+        this.bdCode = applyChange.getApplyCode();
+        this.pdCode = applyChange.getCode();
+        this.solutionName = applyChange.getSolutionsName();
+        this.worktypeName = applyChangeDetail.getWorkTypeName();
+        this.duName = applyChangeDetail.getDuName();
+//        this.relationType = Constants.ONE;
+        this.relationId = applyDetailId;
+    }
+
+
+
 
     @TableId(type = IdType.AUTO)
     @ApiModelProperty(value = "涓婚敭", example = "1")
@@ -66,16 +121,21 @@
 
     @ApiModelProperty(value = "瀹為檯淇濋櫓鐢熸晥姝㈡湡")
     @ExcelColumn(name="瀹為檯淇濋櫓鐢熸晥姝㈡湡")
-    private String endTime;
+    private Date endTime;
 
     @ApiModelProperty(value = "瀹為檯淇濋櫓鐢熸晥璧锋湡")
     @ExcelColumn(name="瀹為檯淇濋櫓鐢熸晥璧锋湡")
-    private String startTime;
+    private Date startTime;
 
-    @ApiModelProperty(value = "鏈�杩戞搷浣滄椂闂�")
-    @ExcelColumn(name="鏈�杩戞搷浣滄椂闂�")
-    @JsonFormat(pattern = "yyyy-MM-dd")
-    private Date idcardNo;
+    @ApiModelProperty(value = "韬唤璇佸彿鐮�")
+    @ExcelColumn(name="韬唤璇佸彿鐮�")
+    private String idcardNo;
+
+
+    @ApiModelProperty(value = "鏂规涓婚敭", example = "1")
+    @ExcelColumn(name="鏂规涓婚敭")
+    private Integer solutionId;
+
 
     @ApiModelProperty(value = "娲鹃仯鍗曚綅缂栫爜锛堝叧鑱攄ispatch_unit)", example = "1")
     @ExcelColumn(name="娲鹃仯鍗曚綅缂栫爜锛堝叧鑱攄ispatch_unit)")
@@ -121,4 +181,12 @@
     @ExcelColumn(name="娲鹃仯鍗曚綅鍚嶇О")
     private String duName;
 
+    @ApiModelProperty(value = "鍏宠仈鏄庣粏涓婚敭", example = "1")
+    @ExcelColumn(name="鍏宠仈鏄庣粏涓婚敭")
+    private Integer relationId;
+
+//    @ApiModelProperty(value = "鍏宠仈鏄庣粏绫诲瀷锛�0=鎶曚繚鐢宠锛�1=鍔犲噺淇�/鎹㈠巶", example = "1")
+//    @ExcelColumn(name="鍏宠仈鏄庣粏绫诲瀷锛�0=鎶曚繚鐢宠锛�1=鍔犲噺淇�/鎹㈠巶")
+//    private Integer relationType;
+
 }
diff --git a/server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java b/server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java
index a32df91..33b3c79 100644
--- a/server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java
+++ b/server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java
@@ -152,7 +152,7 @@
 
     @ApiModelProperty(value = "鍑洪櫓鍦板尯(鍏宠仈areas)", example = "1")
     @ExcelColumn(name="鍑洪櫓鍦板尯(鍏宠仈areas)")
-    private Integer areaId;
+    private String areaId;
 
     @ApiModelProperty(value = "鍑洪櫓鍦板尯鍚嶇О锛堢渷甯傦級")
     @ExcelColumn(name="鍑洪櫓鍦板尯鍚嶇О锛堢渷甯傦級")
@@ -222,7 +222,7 @@
     @ApiModelProperty(value = "淇濋櫓鐢熸晥璧锋湡")
     @TableField(exist = false)
     private Date baoxianStartTime;
-    @ApiModelProperty(value = "淇濋櫓鐢熸晥璧锋湡")
+    @ApiModelProperty(value = "淇濋櫓鐢熸晥姝㈡湡")
     @TableField(exist = false)
     private Date baoxianEndTime;
 
diff --git a/server/service/src/main/java/com/doumee/dao/business/vo/AreasTree.java b/server/service/src/main/java/com/doumee/dao/business/vo/AreasTree.java
new file mode 100644
index 0000000..5c82226
--- /dev/null
+++ b/server/service/src/main/java/com/doumee/dao/business/vo/AreasTree.java
@@ -0,0 +1,90 @@
+package com.doumee.dao.business.vo;
+
+
+import com.dingtalk.api.response.OapiNewretailQueryorginfoResponse;
+import com.doumee.core.utils.Constants;
+import com.doumee.dao.business.model.Areas;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Objects;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2023/7/13 10:40
+ */
+public class AreasTree {
+
+    // 淇濆瓨鍙備笌鏋勫缓鏍戝舰鐨勬墍鏈夋暟鎹紙閫氬父鏁版嵁搴撴煡璇㈢粨鏋滐級
+    public List<Areas> nodeList = new ArrayList<>();
+
+
+    /**
+     *  鏋勯�犳柟娉�
+     *  @param nodeList 灏嗘暟鎹泦鍚堣祴鍊肩粰nodeList锛屽嵆鎵�鏈夋暟鎹綔涓烘墍鏈夎妭鐐广��
+     */
+    public AreasTree(List<Areas> nodeList){
+        this.nodeList = nodeList;
+    }
+
+
+    /**
+     *   鑾峰彇闇�鏋勫缓鐨勬墍鏈夋牴鑺傜偣锛堥《绾ц妭鐐癸級 "0"
+     *   @return 鎵�鏈夋牴鑺傜偣List闆嗗悎
+     */
+    public List<Areas> getRootNode(){
+        // 淇濆瓨鎵�鏈夋牴鑺傜偣锛堟墍鏈夋牴鑺傜偣鐨勬暟鎹級
+        List<Areas> rootNodeList = new ArrayList<>();
+        // treeNode锛氭煡璇㈠嚭鐨勬瘡涓�鏉℃暟鎹紙鑺傜偣锛�
+        for (Areas treeNode : nodeList){
+            // 鍒ゆ柇褰撳墠鑺傜偣鏄惁涓烘牴鑺傜偣锛屾澶勬敞鎰忥細鑻arentId绫诲瀷鏄疭tring锛屽垯瑕侀噰鐢╡quals()鏂规硶鍒ゆ柇銆�
+            if (treeNode.getType().equals(Constants.ZERO)) {
+                rootNodeList.add(treeNode);
+            }
+        }
+        return rootNodeList;
+    }
+
+
+    /**
+     *  鏍规嵁姣忎竴涓《绾ц妭鐐癸紙鏍硅妭鐐癸級杩涜鏋勫缓鏍戝舰缁撴瀯
+     *  @return  鏋勫缓鏁存5鏍�
+     */
+    public List<Areas> buildTree(){
+        // treeNodes锛氫繚瀛樹竴涓《绾ц妭鐐规墍鏋勫缓鍑烘潵鐨勫畬鏁存爲褰�
+        List<Areas> treeNodes = new ArrayList<Areas>();
+        // getRootNode()锛氳幏鍙栨墍鏈夌殑鏍硅妭鐐�
+        for (Areas treeRootNode : getRootNode()) {
+            // 灏嗛《绾ц妭鐐硅繘琛屾瀯寤哄瓙鏍�
+            treeRootNode = buildChildTree(treeRootNode);
+            // 瀹屾垚涓�涓《绾ц妭鐐规墍鏋勫缓鐨勬爲褰紝澧炲姞杩涙潵
+            treeNodes.add(treeRootNode);
+        }
+        return treeNodes;
+    }
+
+    /**
+     *  閫掑綊-----鏋勫缓瀛愭爲褰㈢粨鏋�
+     *  @param  pNode 鏍硅妭鐐癸紙椤剁骇鑺傜偣锛�
+     *  @return 鏁存5鏍�
+     */
+    public Areas buildChildTree(Areas pNode){
+        List<Areas> childTree = new ArrayList<Areas>();
+        // nodeList锛氭墍鏈夎妭鐐归泦鍚堬紙鎵�鏈夋暟鎹級
+        for (Areas treeNode : nodeList) {
+            // 鍒ゆ柇褰撳墠鑺傜偣鐨勭埗鑺傜偣ID鏄惁绛変簬鏍硅妭鐐圭殑ID锛屽嵆褰撳墠鑺傜偣涓哄叾涓嬬殑瀛愯妭鐐�
+            if (!Objects.isNull(treeNode.getParentId())&&treeNode.getParentId().equals(pNode.getId())) {
+                // 鍐嶉�掑綊杩涜鍒ゆ柇褰撳墠鑺傜偣鐨勬儏鍐碉紝璋冪敤鑷韩鏂规硶
+                childTree.add(buildChildTree(treeNode));
+            }
+        }
+        // for寰幆缁撴潫锛屽嵆鑺傜偣涓嬫病鏈変换浣曡妭鐐癸紝鏍戝舰鏋勫缓缁撴潫锛岃缃爲缁撴灉
+        pNode.setChildAreasList(childTree);
+        return pNode;
+    }
+
+
+
+}
diff --git a/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java
index c8e661a..489a5ee 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/ApplyChangeServiceImpl.java
@@ -37,6 +37,11 @@
 
 import java.math.BigDecimal;
 import java.util.*;
+import java.math.RoundingMode;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+import java.util.Objects;
 import java.util.stream.Collectors;
 
 /**
@@ -72,6 +77,9 @@
 
     @Autowired
     private ApplyDetailJoinMapper applyDetailJoinMapper;
+
+    @Autowired
+    private MemberInsuranceJoinMapper memberInsuranceJoinMapper;
 
     @Autowired
     private MemberMapper memberMapper;
@@ -195,6 +203,7 @@
         ApplyLog log = new ApplyLog(update,applyLogType.getName(), info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update));
         applyLogMapper.insert(log);
 
+
         return  1;
 
     }
@@ -263,9 +272,14 @@
                         .selectAll(ApplyChagneDetail.class)
                         .selectAs(Solutions::getTimeUnit,ApplyChagneDetail::getSolutionTimeUnit)
                         .selectAs(Solutions::getPrice,ApplyChagneDetail::getSolutionPrice)
+                        .selectAs(Worktype::getName,ApplyChagneDetail::getWorkTypeName)
+                        .selectAs(DispatchUnit::getName,ApplyChagneDetail::getDuName)
                   .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId)
                   .leftJoin(InsuranceApply.class, InsuranceApply::getId, ApplyChange::getApplyId)
                   .leftJoin(Solutions.class, Solutions::getId, InsuranceApply::getSolutionId)
+                  .leftJoin(Solutions.class, Solutions::getId, ApplyChange::getSolutionsId)
+                    .leftJoin(Worktype.class,Worktype::getId,ApplyChagneDetail::getWorktypeId)
+                    .leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyChagneDetail::getDuId)
                   .eq(ApplyChagneDetail::getApplyChangeId,update.getId())
                   .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) );
         if(detailList ==null || detailList.size()==0){
@@ -281,41 +295,104 @@
             if(oldModel == null  ){
                 throw  new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鐢ㄦ埛銆�"+detail.getMemberName()+"銆戝師淇濆崟淇℃伅鏈夎锛屽綋鍓嶇敵璇蜂笉鏀寔鍑忎繚澶勭悊锛�");
             }
+            Date endDate = oldModel.getEndTime();
+            //褰撳墠鏃ユ湡澶т簬鎵瑰崟鏃ユ湡 闇�瑕佸洖婊氭暟鎹疄闄呮暟鎹�
+            Boolean flag = DateUtil.getMontageDate(new Date(),2).compareTo(DateUtil.getMontageDate(update.getStartTime(),2))>0;
+            //鎹㈠巶鍚庡巻鍙茶褰曠殑璐圭敤 fee
+            Integer days = DateUtil.daysBetweenDates(DateUtil.getMontageDate(update.getStartTime(),2),DateUtil.getMontageDate(oldModel.getStartTime(),1)) + 1;
+            BigDecimal oldFee = this.getApplyPrice(update.getApplyId(),days);
+            BigDecimal fee = oldModel.getFee();
+            BigDecimal oldCurrentFee = oldModel.getCurrentFee();
             applyDetailJoinMapper.update(null, new UpdateWrapper<ApplyDetail>().lambda()
                     .set(ApplyDetail::getEditor,update.getEditor())
-                    .set(ApplyDetail::getWorktypeId,detail.getWorktypeId())
-                    .set(ApplyDetail::getDuId,detail.getDuId())
                     .set(ApplyDetail::getEditDate,update.getEditDate())
+                    .set(ApplyDetail::getEndTime,DateUtil.getMontageDate(update.getStartTime(),2))
+                    .set(ApplyDetail::getFee,oldFee)
+                    .set(flag,ApplyDetail::getCurrentFee,oldFee)
                     .eq(ApplyDetail::getId,oldModel.getApplyId())
             );
 
+            //淇敼 鍛樺伐鎶曚繚鏄庣粏璁板綍 鍘嗗彶鏁版嵁
+            memberInsuranceJoinMapper.update(null,new UpdateWrapper<MemberInsurance>().lambda()
+                    .set(MemberInsurance::getEndTime,update.getApplyStartTime())
+                            .set(MemberInsurance::getFee,oldFee)
+                    .eq(MemberInsurance::getRelationId,oldModel.getId())
+            );
+
+            ApplyDetail applyDetail = new ApplyDetail();
+            applyDetail.setApplyId(oldModel.getApplyId());
+            applyDetail.setCreateDate(new Date());
+            applyDetail.setCreator(update.getEditor());
+            applyDetail.setMemberId(oldModel.getMemberId());
+            applyDetail.setStartTime(DateUtil.getMontageDate(update.getApplyStartTime(),1));
+            applyDetail.setEndTime(endDate);
+            applyDetail.setDuId(detail.getDuId());
+            applyDetail.setWorktypeId(detail.getWorktypeId());
+            applyDetail.setIdcardNo(oldModel.getIdcardNo());
+            applyDetail.setFee(fee.subtract(oldFee));
+            if(flag){
+                applyDetail.setCurrentFee(oldCurrentFee.multiply(oldFee));
+            }else{
+                applyDetail.setCurrentFee(BigDecimal.ZERO);
+            }
+            applyDetail.setSex(oldModel.getSex());
+            applyDetail.setMemberName(oldModel.getMemberName());
+            applyDetail.setFromId(detail.getId());
+            applyDetailJoinMapper.insert(applyDetail);
+
+            MemberInsurance memberInsurance = new MemberInsurance(applyDetail,update.getId());
+            memberInsuranceJoinMapper.insert(memberInsurance);
         }
     }
     /**
      * 澶勭悊鍔犲噺淇濇槑缁嗘暟鎹�
      * @param update
      */
-    private void dealDetailsValidTime(ApplyChange update ) {
+    private void dealDetailsValidTime(ApplyChange update) {
         List<ApplyChagneDetail> detailList = applyChagneDetailJoinMapper.selectJoinList(ApplyChagneDetail.class,
                 new MPJLambdaWrapper<ApplyChagneDetail>()
                         .selectAll(ApplyChagneDetail.class)
-                        .selectAs(Solutions::getTimeUnit,ApplyChagneDetail::getSolutionTimeUnit)
-                        .selectAs(Solutions::getPrice,ApplyChagneDetail::getSolutionPrice)
-                  .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId)
-                  .leftJoin(InsuranceApply.class, InsuranceApply::getId, ApplyChange::getApplyId)
-                  .leftJoin(Solutions.class, Solutions::getId, InsuranceApply::getSolutionId)
-                  .eq(ApplyChagneDetail::getApplyChangeId,update.getId())
-                  .eq(ApplyChagneDetail::getIsdeleted,Constants.ZERO) );
-        if(detailList ==null || detailList.size()==0){
+                        .selectAs(Solutions::getTimeUnit, ApplyChagneDetail::getSolutionTimeUnit)
+                        .selectAs(Solutions::getPrice, ApplyChagneDetail::getSolutionPrice)
+                        .selectAs(Worktype::getName, ApplyChagneDetail::getWorkTypeName)
+                        .selectAs(DispatchUnit::getName, ApplyChagneDetail::getDuName)
+                        .leftJoin(ApplyChange.class, ApplyChange::getId, ApplyChagneDetail::getApplyChangeId)
+                        .leftJoin(InsuranceApply.class, InsuranceApply::getId, ApplyChange::getApplyId)
+                        .leftJoin(Solutions.class, Solutions::getId, InsuranceApply::getSolutionId)
+                        .leftJoin(Solutions.class, Solutions::getId, ApplyChange::getSolutionsId)
+                        .leftJoin(Worktype.class, Worktype::getId, ApplyChagneDetail::getWorktypeId)
+                        .leftJoin(DispatchUnit.class, DispatchUnit::getId, ApplyChagneDetail::getDuId)
+                        .eq(ApplyChagneDetail::getApplyChangeId, update.getId())
+                        .eq(ApplyChagneDetail::getIsdeleted, Constants.ZERO));
+        if (detailList == null || detailList.size() == 0) {
             return;
         }
         List<ApplyDetail> addList = new ArrayList<>();
         List<Integer> reduceMembers = new ArrayList<>();
         BigDecimal totalFee = new BigDecimal(0);
         BigDecimal currentFee = new BigDecimal(0);
+        //鎶曚繚璁板綍 鍔犱繚鏁版嵁鍔犲叆鏂版暟鎹�  鍑忎繚鏁版嵁 淇敼鑰佹暟鎹�
+        List<MemberInsurance> memberInsuranceList = new ArrayList<>();
 
-        for(ApplyChagneDetail detail : detailList){
-            if(Constants.equalsInteger(detail.getType(),Constants.ZERO)){
+
+        //鍔犱繚涓氬姟 浣跨敤鐨勫姞淇濋噾棰�
+        ApplyChangeCyclePriceDTO applyChangeCyclePriceDTO_add = new ApplyChangeCyclePriceDTO();
+        applyChangeCyclePriceDTO_add.setApplyId(update.getApplyId());
+        applyChangeCyclePriceDTO_add.setValidTime(DateUtil.getMontageDate(update.getStartTime(), 1));
+        //鍔犱繚 娣诲姞鐨勯噾棰�
+        CountCyclePriceVO countCyclePriceVO_add = this.getChangeCountCyclePriceVO(applyChangeCyclePriceDTO_add);
+
+
+        //鍑忎繚涓氬姟 浣跨敤鐨勫噺淇濋噾棰�
+        ApplyChangeCyclePriceDTO applyChangeCyclePriceDTO_reduce = new ApplyChangeCyclePriceDTO();
+        applyChangeCyclePriceDTO_reduce.setApplyId(update.getApplyId());
+        applyChangeCyclePriceDTO_reduce.setValidTime(DateUtil.getMontageDate(update.getStartTime(), 3));
+        //鍑忎繚 闇�瑕佸噺灏戠殑閲戦
+        CountCyclePriceVO countCyclePriceVO_reduce = this.getChangeCountCyclePriceVO(applyChangeCyclePriceDTO_reduce);
+
+
+        for (ApplyChagneDetail detail : detailList) {
+            if (Constants.equalsInteger(detail.getType(), Constants.ZERO)) {
                 //鍔犱繚
                 ApplyDetail add = new ApplyDetail();
                 add.setApplyId(update.getApplyId());
@@ -332,57 +409,88 @@
                 add.setEndTime(detail.getEndTime());
                 add.setFee(new BigDecimal(0));
 //                add.setFee(Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), add.getStartTime(),add.getEndTime()));
-                if(DateUtil.daysBetweenDates(add.getStartTime(),new Date() )>=0){
-                    //濡傛灉宸蹭骇鐢熻垂鐢紝璁$畻宸蹭骇鐢熻垂鐢�
-                    add.setCurrentFee(Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), add.getStartTime(),new Date()));
+                if (DateUtil.daysBetweenDates(add.getStartTime(), new Date()) >= 0) {
+                    add.setStartTime(DateUtil.getMontageDate(update.getApplyStartTime(), 1));
+                    add.setEndTime(DateUtil.getMontageDate(detail.getEndTime(), 2));
+
+                    add.setFee(countCyclePriceVO_add.getCyclePrice());
+                    if (DateUtil.daysBetweenDates(DateUtil.getMontageDate(add.getStartTime(), 2), new Date()) >= 0) {
+                        Integer days = DateUtil.daysBetweenDates(new Date(), DateUtil.getMontageDate(add.getStartTime(), 2)) + 1;
+                        //濡傛灉宸蹭骇鐢熻垂鐢紝璁$畻宸蹭骇鐢熻垂鐢�
+                        add.setCurrentFee(this.getApplyPrice(update.getApplyId(), days));
+                    }
+//                addList.add(add);
+                    applyDetailJoinMapper.insert(add);
+                    totalFee.add(add.getFee());
+                    currentFee.add(add.getCurrentFee());
+
+                    MemberInsurance memberInsurance = new MemberInsurance(detail, update, update.getEditor(), add.getId());
+                    memberInsuranceList.add(memberInsurance);
+                } else {
+                    //鍑忎繚鎿嶄綔
+                    //鏌ヨ鍛樺伐鏄湪涓诲崟涓� 鏄惁瀛樺湪鐢熸晥涓殑鏁版嵁
+                    ApplyDetail oldModel = applyDetailJoinMapper.selectOne(new QueryWrapper<ApplyDetail>().lambda()
+                            .eq(ApplyDetail::getApplyId, update.getApplyId())
+                            .eq(ApplyDetail::getMemberId, detail.getMemberId())
+                            .orderByDesc(ApplyDetail::getCreateDate)
+                            .last("limit 1"));
+                    if (oldModel == null || oldModel.getStartTime() == null || oldModel.getStartTime().getTime() > update.getApplyStartTime().getTime()) {
+                        throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(), "瀵逛笉璧凤紝鐢ㄦ埛銆�" + detail.getMemberName() + "銆戝師淇濆崟淇℃伅鏈夎锛屽綋鍓嶇敵璇蜂笉鏀寔鍑忎繚澶勭悊锛�");
+                    }
+                    //閫�淇濋渶瑕侀��鍥炵殑璐圭敤
+                    BigDecimal updateFee = countCyclePriceVO_reduce.getCyclePrice().multiply(new BigDecimal(-1));
+                    BigDecimal updateCurrentFee = oldModel.getFee().subtract(updateFee);
+
+//                BigDecimal updateCurrentFee = new BigDecimal(0);
+//                if(DateUtil.daysBetweenDates(update.getApplyStartTime(),new Date() )>0){
+//                    //濡傛灉鐢熸晥鏃堕棿 鏄粖澶╀箣鍓嶏紝閫�鍥炲凡浜х敓璐圭敤锛岃绠楀凡浜х敓璐圭敤(鎬昏垂鐢�-宸蹭骇鐢熻垂鐢�)
+//                    updateCurrentFee = updateFee.subtract(oldModel.getCurrentFee());
+//                }
+
+//                    BigDecimal updateFee = (Constants.countDetailFee(detail.getSolutionTimeUnit(), detail.getSolutionPrice(), oldModel.getStartTime(), update.getApplyStartTime()));
+//                    BigDecimal updateCurrentFee = new BigDecimal(0);
+                    if (DateUtil.daysBetweenDates(update.getApplyStartTime(), new Date()) > 0) {
+                        //濡傛灉鐢熸晥鏃堕棿 鏄粖澶╀箣鍓嶏紝閫�鍥炲凡浜х敓璐圭敤锛岃绠楀凡浜х敓璐圭敤(鎬昏垂鐢�-宸蹭骇鐢熻垂鐢�)
+                        updateCurrentFee = updateFee.subtract(Constants.formatBigdecimal(oldModel.getCurrentFee()));
+                    }
+                    applyDetailJoinMapper.update(null, new UpdateWrapper<ApplyDetail>().lambda()
+                            .setSql(" fee = ifnull(fee,0)+" + updateFee)
+                            .setSql(" current_fee = " + updateCurrentFee)
+                            .set(ApplyDetail::getEndTime, update.getApplyStartTime())
+                            .set(ApplyDetail::getEditor, update.getEditor())
+                            .set(ApplyDetail::getEditDate, update.getEditDate())
+                            .eq(ApplyDetail::getId, oldModel.getApplyId())
+                    );
+                    totalFee.add(updateFee);
+                    currentFee.add(updateCurrentFee);
+
+                    //淇敼 鍛樺伐鎶曚繚鏄庣粏璁板綍 鍘嗗彶鏁版嵁
+                    memberInsuranceJoinMapper.update(null, new UpdateWrapper<MemberInsurance>().lambda()
+                            .setSql(" fee = ifnull(fee,0)+" + updateFee)
+                            .set(MemberInsurance::getEndTime, update.getApplyStartTime())
+                            .eq(MemberInsurance::getRelationId, oldModel.getId())
+                    );
+
                 }
-                addList.add(add);
-                totalFee.add(add.getFee());
-                currentFee.add(add.getCurrentFee());
-            }else{
-                //鍑忎繚鎿嶄綔
-                //鏌ヨ鍛樺伐鏄湪涓诲崟涓� 鏄惁瀛樺湪鐢熸晥涓殑鏁版嵁
-                ApplyDetail oldModel = applyDetailJoinMapper.selectOne(new QueryWrapper<ApplyDetail>().lambda()
-                        .eq(ApplyDetail::getApplyId, update.getApplyId())
-                        .eq(ApplyDetail::getMemberId, detail.getMemberId())
-                        .orderByDesc(ApplyDetail::getCreateDate)
-                        .last("limit 1"));
-                if(oldModel == null || oldModel.getStartTime()==null || oldModel.getStartTime().getTime() > update.getApplyStartTime().getTime()){
-                    throw  new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝鐢ㄦ埛銆�"+detail.getMemberName()+"銆戝師淇濆崟淇℃伅鏈夎锛屽綋鍓嶇敵璇蜂笉鏀寔鍑忎繚澶勭悊锛�");
-                }
-                BigDecimal updateFee = (Constants.countDetailFee(detail.getSolutionTimeUnit(),detail.getSolutionPrice(), oldModel.getStartTime(),update.getApplyStartTime()));
-                BigDecimal updateCurrentFee = new BigDecimal(0);
-                if(DateUtil.daysBetweenDates(update.getApplyStartTime(),new Date() )>0){
-                    //濡傛灉鐢熸晥鏃堕棿 鏄粖澶╀箣鍓嶏紝閫�鍥炲凡浜х敓璐圭敤锛岃绠楀凡浜х敓璐圭敤(鎬昏垂鐢�-宸蹭骇鐢熻垂鐢�)
-                    updateCurrentFee = updateFee.subtract(Constants.formatBigdecimal(oldModel.getCurrentFee()));
-                }
-                applyDetailJoinMapper.update(null, new UpdateWrapper<ApplyDetail>().lambda()
-                        .setSql(" fee = ifnull(fee,0)+"+updateFee)
-                        .setSql(" current_fee = "+updateFee)
-                        .set(ApplyDetail::getEditor,update.getEditor())
-                        .set(ApplyDetail::getEditDate,update.getEditDate())
-                        .eq(ApplyDetail::getId,oldModel.getApplyId())
+            }
+
+            if (memberInsuranceList != null && memberInsuranceList.size() > 0) {
+//            applyDetailJoinMapper.insertBatchSomeColumn(addList);
+                memberInsuranceJoinMapper.insertBatchSomeColumn(memberInsuranceList);
+            }
+            if (totalFee.compareTo(new BigDecimal(0)) != 0) {
+                //濡傛灉淇濆崟閲戦鍙戠敓缂栫爜锛屾洿鏂版�讳繚鍗曢噾棰�
+                insuranceApplyMapper.update(null, new UpdateWrapper<InsuranceApply>().lambda()
+                        .setSql(" fee = ifnull(fee,0)+" + totalFee)
+                        .setSql(" current_fee = ifnull(current_fee,0)+" + currentFee)
+                        .set(InsuranceApply::getEditor, update.getEditor())
+                        .set(InsuranceApply::getEditDate, update.getEditDate())
+                        .eq(InsuranceApply::getId, update.getApplyId())
                 );
-                totalFee.add(updateFee);
-                currentFee.add(updateCurrentFee);
 
             }
-        }
-        if(addList!=null && addList.size()>0){
-            applyDetailJoinMapper.insertBatchSomeColumn(addList);
-        }
-        if(totalFee.compareTo(new BigDecimal(0)) != 0){
-            //濡傛灉淇濆崟閲戦鍙戠敓缂栫爜锛屾洿鏂版�讳繚鍗曢噾棰�
-            insuranceApplyMapper.update(null, new UpdateWrapper<InsuranceApply>().lambda()
-                    .setSql(" fee = ifnull(fee,0)+"+totalFee)
-                    .setSql(" current_fee = ifnull(current_fee,0)+"+currentFee)
-                    .set(InsuranceApply::getEditor,update.getEditor())
-                    .set(InsuranceApply::getEditDate,update.getEditDate())
-                    .eq(InsuranceApply::getId,update.getApplyId())
-            );
 
         }
-
     }
 
     /**
@@ -565,11 +673,13 @@
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "鐢宠鏃ユ湡鏈浜庝繚鍗曟棩鏈熷唴锛屾棤娉曡繘琛岃鎿嶄綔");
         }
 
-
         applyChange.setEditDate(new Date());
         applyChange.setEditor(loginUserInfo.getId());
         applyChange.setStatus(Constants.ZERO);
         BigDecimal fee = BigDecimal.ZERO;
+        //鍒犻櫎鍘嗗彶鏁版嵁
+        applyChagneDetailJoinMapper.delete(new QueryWrapper<ApplyChagneDetail>().lambda().eq(ApplyChagneDetail::getApplyChangeId,applyChange.getId()));
+
         this.dealApplyChangeData(applyChange,insuranceApply,companySolution,solutions,loginUserInfo,fee);
         applyChange.setFee(fee);
         applyChangeMapper.updateById(applyChange);
@@ -605,13 +715,20 @@
             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鏁版嵁寮傚父锛氫繚闄╂柟妗堜笅鏈煡璇㈠埌宸ョ淇℃伅");
         }
 
+        ApplyChangeCyclePriceDTO applyChangeCyclePriceDTO = new ApplyChangeCyclePriceDTO();
+        applyChangeCyclePriceDTO.setApplyId(insuranceApply.getId());
         //鍔犱繚鏁版嵁
         List<ApplyChagneDetail> addDetailList = applyChange.getAddDetailList();
         if (CollectionUtils.isNotEmpty(addDetailList)) {
             if(companySolution.getCanAdd().equals(Constants.ZERO)){
                 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "璇ヤ紒涓氬垎閰嶄繚闄╂柟妗堟棤娉曡繘琛屽姞淇�");
             }
-            this.addChangeDetail(applyChange,addDetailList,duWorktypeList,duSolutionList,insuranceApply,solutions,loginUserInfo);
+            //鍔犱繚鏄庣粏鏁版嵁 璁$畻閲戦  鏍规嵁鎵瑰崟鏃堕棿 璁$畻
+            applyChangeCyclePriceDTO.setValidTime(DateUtil.getMontageDate(insuranceApply.getStartTime(),1));
+            CountCyclePriceVO countCyclePriceVO =  this.getChangeCountCyclePriceVO(applyChangeCyclePriceDTO);
+            BigDecimal detailFee = countCyclePriceVO.getCyclePrice();
+
+            this.addChangeDetail(applyChange,addDetailList,duWorktypeList,duSolutionList,insuranceApply,solutions,loginUserInfo,detailFee);
 
             fee = addDetailList.stream().map(ApplyChagneDetail::getFee).reduce(BigDecimal.ZERO,BigDecimal::add);
         }
@@ -622,7 +739,11 @@
             if(companySolution.getCanReduce().equals(Constants.ZERO)){
                 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "璇ヤ紒涓氬垎閰嶄繚闄╂柟妗堟棤娉曡繘琛屽噺淇�");
             }
-            this.delChangeDetail(applyChange,delDetailList,insuranceApply,solutions,loginUserInfo);
+            //鍑忎繚鏄庣粏鏁版嵁 璁$畻閲戦  鏍规嵁鎵瑰崟鏃堕棿 鍓嶄竴澶� 璁$畻
+            applyChangeCyclePriceDTO.setValidTime(DateUtil.getMontageDate(insuranceApply.getStartTime(),3));
+            CountCyclePriceVO countCyclePriceVO =  this.getChangeCountCyclePriceVO(applyChangeCyclePriceDTO);
+            BigDecimal detailFee = countCyclePriceVO.getCyclePrice();
+            this.delChangeDetail(applyChange,delDetailList,insuranceApply,solutions,loginUserInfo,detailFee);
             fee = fee.add(delDetailList.stream().map(ApplyChagneDetail::getFee).reduce(BigDecimal.ZERO,BigDecimal::add));
         }
 
@@ -663,7 +784,7 @@
      * @param delDetailList
      * @param loginUserInfo
      */
-    public void delChangeDetail(ApplyChange applyChange ,List<ApplyChagneDetail> delDetailList,InsuranceApply insuranceApply,Solutions solutions,LoginUserInfo loginUserInfo){
+    public void delChangeDetail(ApplyChange applyChange ,List<ApplyChagneDetail> delDetailList,InsuranceApply insuranceApply,Solutions solutions,LoginUserInfo loginUserInfo,BigDecimal detailFee){
         for (ApplyChagneDetail applyChagneDetail : delDetailList) {
             if (Objects.isNull(applyChagneDetail.getMemberId())) {
                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍑忎繚浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戝繀濉」缂哄け");
@@ -699,17 +820,10 @@
             applyChagneDetail.setApplyChangeId(applyChange.getId());
             applyChagneDetail.setType(Constants.ONE);
 
-            System.out.println(DateUtil.dateToString(applyDetail.getEndTime(),"yyyy-MM-dd"));
-            System.out.println(DateUtil.dateToString(applyDetail.getStartTime(),"yyyy-MM-dd"));
-            System.out.println(DateUtil.dateToString(applyChange.getValidTime(),"yyyy-MM-dd"));
+            applyChagneDetail.setStartTime(DateUtil.getMontageDate(applyDetail.getStartTime(),1));
+            applyChagneDetail.setEndTime(DateUtil.getMontageDate(applyChange.getStartTime(),3));
 
-            BigDecimal sumFee = Constants.countDetailFee(solutions, applyDetail.getEndTime(),applyDetail.getStartTime());
-            BigDecimal useFee = Constants.countDetailFee(solutions, applyChange.getValidTime(),applyDetail.getStartTime());
-
-            applyChagneDetail.setFee(
-                    Constants.countDetailFee(solutions, applyDetail.getEndTime(),applyDetail.getStartTime())
-                            .subtract(Constants.countDetailFee(solutions,applyChange.getValidTime(), applyDetail.getStartTime())).multiply(new BigDecimal(-1))
-            );
+            applyChagneDetail.setFee( detailFee.multiply(new BigDecimal(-1)));
             applyChagneDetailJoinMapper.insert(applyChagneDetail);
         }
     }
@@ -724,7 +838,7 @@
      * @param duSolutionList
      * @param loginUserInfo
      */
-    public void addChangeDetail(ApplyChange applyChange ,List<ApplyChagneDetail> addDetailList,List<DuWorktype> duWorktypeList,List<DuSolution> duSolutionList,InsuranceApply insuranceApply,Solutions solutions,LoginUserInfo loginUserInfo){
+    public void addChangeDetail(ApplyChange applyChange ,List<ApplyChagneDetail> addDetailList,List<DuWorktype> duWorktypeList,List<DuSolution> duSolutionList,InsuranceApply insuranceApply,Solutions solutions,LoginUserInfo loginUserInfo,BigDecimal detailFee){
         for (ApplyChagneDetail applyChagneDetail : addDetailList) {
             if (    Objects.isNull(applyChagneDetail.getDuId())
                     || Objects.isNull(applyChagneDetail.getWorktypeId())
@@ -732,7 +846,6 @@
             ) {
                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍔犱繚浜哄憳銆�" + applyChagneDetail.getMemberName() + "銆戝繀濉」缂哄け");
             }
-
 
             Member member = new Member();
             if(Objects.isNull(applyChagneDetail.getMemberId())){
@@ -805,10 +918,10 @@
             applyChagneDetail.setCreator(loginUserInfo.getId());
             applyChagneDetail.setIsdeleted(Constants.ZERO);
             applyChagneDetail.setApplyChangeId(applyChange.getId());
+            applyChagneDetail.setStartTime(DateUtil.getMontageDate(applyChange.getStartTime(),1));
+            applyChagneDetail.setEndTime(DateUtil.getMontageDate(insuranceApply.getEndTime(),2));
             applyChagneDetail.setType(Constants.ZERO);
-            applyChagneDetail.setFee(
-                    Constants.countDetailFee(solutions,insuranceApply.getEndTime(),applyChange.getValidTime())
-            );
+            applyChagneDetail.setFee(detailFee);
             applyChagneDetailJoinMapper.insert(applyChagneDetail);
         }
     }
@@ -1328,6 +1441,11 @@
     }
 
 
+    /**
+     * 鍔犲噺淇濈敵璇锋椂 鏌ヨ鍔犲噺閲戦
+     * @param applyChangeCyclePriceDTO
+     * @return
+     */
     @Override
     public CountCyclePriceVO getChangeCountCyclePriceVO(ApplyChangeCyclePriceDTO applyChangeCyclePriceDTO){
         if(Objects.isNull(applyChangeCyclePriceDTO)
@@ -1335,7 +1453,6 @@
             || Objects.isNull(applyChangeCyclePriceDTO.getValidTime())){
             throw new BusinessException(ResponseStatus.BAD_REQUEST);
         }
-
         InsuranceApply insuranceApply = insuranceApplyMapper.selectById(applyChangeCyclePriceDTO.getApplyId());
         if(Objects.isNull(insuranceApply)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濆崟");
@@ -1344,13 +1461,47 @@
         if(Objects.isNull(solutions)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈡柟妗堜俊鎭�");
         }
-        CountCyclePriceVO countCyclePriceVO = new CountCyclePriceVO();
-        countCyclePriceVO.setCyclePrice(Constants.countDetailFee(solutions,insuranceApply.getEndTime(),applyChangeCyclePriceDTO.getValidTime()));
-        return countCyclePriceVO;
+        //鏍规嵁鎵瑰崟鏃ユ湡 鍜� 缁撴潫鏃ユ湡 璁$畻閲戦
+        //楠岃瘉鎵瑰崟鏃ユ湡鏄惁鍦ㄥ綋鍓嶆棩鏈熷悗 涓� 鍦ㄤ繚鍗曠粨鏉熸棩鏈熷墠 鐢宠鏃堕棿蹇呴』澶勪簬淇濆崟鐨勬椂闂磋寖鍥村唴
+        if (!(DateUtil.compareDate( insuranceApply.getStartTime(),applyChangeCyclePriceDTO.getValidTime()) >= Constants.ZERO
+                && DateUtil.compareDate( applyChangeCyclePriceDTO.getValidTime(),insuranceApply.getEndTime()) >= Constants.ZERO)) {
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "鐢宠鏃ユ湡鏈浜庝繚鍗曟棩鏈熷唴锛屾棤娉曡繘琛岃鎿嶄綔");
+        }
+        //鎬诲ぉ鏁�
+        Integer sumDays = DateUtil.daysBetweenDates(insuranceApply.getEndTime(),insuranceApply.getStartTime()) + 1;
+        //鍔犲噺淇� 鍒扮粨鏉熺殑澶╂暟
+        Integer optDays = DateUtil.daysBetweenDates(insuranceApply.getEndTime(),applyChangeCyclePriceDTO.getValidTime()) + 1;
 
+        CountCyclePriceVO countCyclePriceVO = Constants.countPriceVO(insuranceApply.getStartTime(),solutions);
+        //鎬婚噾棰�
+        BigDecimal sumPrice = countCyclePriceVO.getCyclePrice();
+        CountCyclePriceVO returnCountCyclePriceVO = new CountCyclePriceVO();
+        //鍔犲噺淇濋噾棰�
+        returnCountCyclePriceVO.setCyclePrice(sumPrice.divide(new BigDecimal(sumDays),2, RoundingMode.HALF_UP).multiply(new BigDecimal(optDays)));
+        return returnCountCyclePriceVO;
     }
 
-
-
+    /**
+     * 璁$畻淇濆崟涓�  X澶� 澶氬皯璐圭敤
+     * @param applyId
+     * @param optDays
+     * @return
+     */
+    public BigDecimal getApplyPrice(Integer applyId,Integer optDays){
+        InsuranceApply insuranceApply = insuranceApplyMapper.selectById(applyId);
+        if(Objects.isNull(insuranceApply)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌淇濆崟");
+        }
+        Solutions solutions = solutionsMapper.selectById(insuranceApply.getSolutionId());
+        if(Objects.isNull(solutions)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈡柟妗堜俊鎭�");
+        }
+        //鎬诲ぉ鏁�
+        Integer sumDays = DateUtil.daysBetweenDates(insuranceApply.getEndTime(),insuranceApply.getStartTime()) + 1;
+        CountCyclePriceVO countCyclePriceVO = Constants.countPriceVO(insuranceApply.getStartTime(),solutions);
+        //鎬婚噾棰�
+        BigDecimal sumPrice = countCyclePriceVO.getCyclePrice();;
+        return sumPrice.divide(new BigDecimal(sumDays),2, RoundingMode.HALF_UP).multiply(new BigDecimal(optDays));
+    }
 
 }
diff --git a/server/service/src/main/java/com/doumee/service/business/impl/ApplyDetailServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/ApplyDetailServiceImpl.java
index 4936fdf..1b5163a 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/ApplyDetailServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/ApplyDetailServiceImpl.java
@@ -250,6 +250,7 @@
         queryWrapper.selectAll(ApplyDetail.class);
         queryWrapper.selectAs(DispatchUnit::getName,ApplyDetail::getDuName);
         queryWrapper.selectAs(InsuranceApply::getCode,ApplyDetail::getApplyCode);
+        queryWrapper.selectAs(Solutions::getId,ApplyDetail::getSolutionId);
         queryWrapper.selectAs(Solutions::getName,ApplyDetail::getSolutionName);
         queryWrapper.selectAs(Worktype::getName,ApplyDetail::getWorkTypeName);
         queryWrapper.selectAs(Member::getIdcardNo,ApplyDetail::getIdcardNo);
diff --git a/server/service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
index c687a96..6e33274 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
@@ -81,6 +81,7 @@
     @Override
     public List<Areas> findList(Areas areas) {
         QueryWrapper<Areas> wrapper = new QueryWrapper<>(areas);
+        wrapper.select("id , name , code , type , parent_id");
         return areasMapper.selectList(wrapper);
     }
   
diff --git a/server/service/src/main/java/com/doumee/service/business/impl/InsuranceApplyServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/InsuranceApplyServiceImpl.java
index cf56469..9da21c5 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/InsuranceApplyServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/InsuranceApplyServiceImpl.java
@@ -15,10 +15,7 @@
 import com.doumee.dao.business.dto.CountCyclePriceDTO;
 import com.doumee.dao.business.dto.InsuranceApplyOptDTO;
 import com.doumee.dao.business.dto.InsuranceApplyQueryDTO;
-import com.doumee.dao.business.join.ApplyDetailJoinMapper;
-import com.doumee.dao.business.join.ApplyLogJoinMapper;
-import com.doumee.dao.business.join.DuSolutionJoinMapper;
-import com.doumee.dao.business.join.InsuranceApplyJoinMapper;
+import com.doumee.dao.business.join.*;
 import com.doumee.dao.business.model.*;
 import com.doumee.dao.business.vo.CountCyclePriceVO;
 import com.doumee.dao.system.model.SystemUser;
@@ -64,6 +61,8 @@
     private InsuranceApplyJoinMapper insuranceApplyJoinMapper;
     @Autowired
     private CompanyMapper companyMapper;
+    @Autowired
+    private MemberInsuranceJoinMapper memberInsuranceJoinMapper;
 
     @Autowired
     private ApplyDetailMapper applyDetailMapper;
@@ -182,6 +181,36 @@
         }
         ApplyLog log = new ApplyLog(update,applyLogType.getName(), info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update));
         applyLogMapper.insert(log);
+
+
+        //瀛樺偍鍛樺伐淇℃伅鎶曚繚璁板綍
+        //鏌ヨ鍗曟嵁鏄庣粏璁板綍
+        MPJLambdaWrapper<ApplyDetail> queryWrapper = new MPJLambdaWrapper<>();
+        queryWrapper.selectAll(ApplyDetail.class);
+        queryWrapper.selectAs(DispatchUnit::getName,ApplyDetail::getDuName);
+        queryWrapper.selectAs(InsuranceApply::getCode,ApplyDetail::getApplyCode);
+        queryWrapper.selectAs(Solutions::getId,ApplyDetail::getSolutionId);
+        queryWrapper.selectAs(Solutions::getName,ApplyDetail::getSolutionName);
+        queryWrapper.selectAs(Worktype::getName,ApplyDetail::getWorkTypeName);
+        queryWrapper.selectAs(Member::getIdcardNo,ApplyDetail::getIdcardNo);
+        queryWrapper.selectAs(Member::getName,ApplyDetail::getMemberName);
+        queryWrapper.leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyDetail::getDuId);
+        queryWrapper.leftJoin(Worktype.class,Worktype::getId,ApplyDetail::getWorktypeId);
+        queryWrapper.leftJoin(Member.class,Member::getId,ApplyDetail::getMemberId);
+        queryWrapper.leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyDetail::getApplyId);
+        queryWrapper.leftJoin(Solutions.class,Solutions::getId,InsuranceApply::getSolutionId);
+        queryWrapper.eq(ApplyDetail::getApplyId,insuranceApply.getId());
+        List<ApplyDetail> applyDetailList = applyDetailJoinMapper.selectJoinList(ApplyDetail.class,queryWrapper);
+
+        if(CollectionUtils.isNotEmpty(applyDetailList)){
+            List<MemberInsurance> memberInsuranceList = new ArrayList<>();
+            for (ApplyDetail applyDetail:applyDetailList) {
+                MemberInsurance memberInsurance = new MemberInsurance(applyDetail,user.getId());
+                memberInsuranceList.add(memberInsurance);
+            }
+            memberInsuranceJoinMapper.insertBatchSomeColumn(memberInsuranceList);
+        }
+
         return  1;
 
     }
@@ -599,6 +628,7 @@
         info = info.replace("${param}", update.getCheckInfo());
         ApplyLog log = new ApplyLog(update,applyLogType.getName(),info,update.getId(),applyLogType.getKey(),JSONObject.toJSONString(model), JSONObject.toJSONString(update));
         applyLogMapper.insert(log);
+
         return  1;
 
     }
@@ -633,14 +663,22 @@
         insuranceApply.setCompanyId(loginUserInfo.getCompanyId());
         insuranceApply.setCheckInfo(insuranceApplyStatus.getName());
         insuranceApply.setStartTime(insuranceApply.getApplyStartTime());
-        insuranceApply.setEndTime(insuranceApply.getApplyEndTime());
         insuranceApply.setCheckDate(new Date());
         insuranceApply.setCurrentFee(BigDecimal.ZERO);
         insuranceApply.setCheckUserId(loginUserInfo.getId());
         insuranceApply.setStatus(insuranceApplyStatus.getKey());
+
+        CountCyclePriceDTO countCyclePriceDTO = new CountCyclePriceDTO();
+        countCyclePriceDTO.setSolutionsId(insuranceApply.getSolutionId());
+        countCyclePriceDTO.setStartDate(insuranceApply.getStartTime());
+        CountCyclePriceVO  countCyclePriceVO = this.getCountCyclePriceVO(countCyclePriceDTO);
+        insuranceApply.setApplyEndTime(countCyclePriceVO.getEndDate());
+        insuranceApply.setEndTime(countCyclePriceVO.getEndDate());
         insuranceApplyMapper.insert(insuranceApply);
+
+
         //澶勭悊涓嬬骇鏁版嵁
-        this.dealApplyDetailData(insuranceApply,applyDetailList,loginUserInfo);
+        this.dealApplyDetailData(insuranceApply,applyDetailList,loginUserInfo,countCyclePriceVO);
         InsuranceApply updBean = new InsuranceApply();
         updBean.setId(insuranceApply.getId());
         updBean.setFee(applyDetailList.stream().map(ApplyDetail::getFee).reduce(BigDecimal.ZERO,BigDecimal::add));
@@ -692,14 +730,21 @@
         insuranceApply.setCompanyId(loginUserInfo.getCompanyId());
         insuranceApply.setCheckInfo(insuranceApplyStatus.getName());
         insuranceApply.setStartTime(insuranceApply.getApplyStartTime());
-        insuranceApply.setEndTime(insuranceApply.getApplyEndTime());
         insuranceApply.setCheckDate(new Date());
         insuranceApply.setCurrentFee(BigDecimal.ZERO);
         insuranceApply.setCheckUserId(loginUserInfo.getId());
         insuranceApply.setStatus(insuranceApplyStatus.getKey());
+
+        CountCyclePriceDTO countCyclePriceDTO = new CountCyclePriceDTO();
+        countCyclePriceDTO.setSolutionsId(insuranceApply.getSolutionId());
+        countCyclePriceDTO.setStartDate(insuranceApply.getStartTime());
+        CountCyclePriceVO  countCyclePriceVO = this.getCountCyclePriceVO(countCyclePriceDTO);
+        insuranceApply.setApplyEndTime(countCyclePriceVO.getEndDate());
+        insuranceApply.setEndTime(countCyclePriceVO.getEndDate());
+
         applyDetailMapper.delete(new QueryWrapper<ApplyDetail>().lambda().eq(ApplyDetail::getApplyId,insuranceApply.getId()));
         //澶勭悊涓嬬骇鏁版嵁
-        this.dealApplyDetailData(insuranceApply,applyDetailList,loginUserInfo);
+        this.dealApplyDetailData(insuranceApply,applyDetailList,loginUserInfo,countCyclePriceVO);
         insuranceApply.setFee(applyDetailList.stream().map(ApplyDetail::getFee).reduce(BigDecimal.ZERO,BigDecimal::add));
         insuranceApplyMapper.updateById(insuranceApply);
         //瀛樺偍鏃ュ織鏁版嵁
@@ -709,7 +754,7 @@
 
 
 
-    public void dealApplyDetailData(InsuranceApply insuranceApply,List<ApplyDetail> applyDetailList,LoginUserInfo loginUserInfo){
+    public void dealApplyDetailData(InsuranceApply insuranceApply,List<ApplyDetail> applyDetailList,LoginUserInfo loginUserInfo,CountCyclePriceVO  countCyclePriceVO){
         Solutions solutions = solutionsMapper.selectById(insuranceApply.getSolutionId());
         if(Objects.isNull(solutions)){
             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鏈煡璇㈠埌鏂规淇℃伅");
@@ -796,7 +841,7 @@
                 applyDetail.setMemberId(member.getId());
                 applyDetail.setIdcardNo(member.getIdcardNo());
                 applyDetail.setSex(member.getSex());
-                applyDetail.setFee(Constants.countDetailFee(solutions,insuranceApply.getApplyEndTime(),insuranceApply.getApplyStartTime()));
+                applyDetail.setFee(countCyclePriceVO.getCyclePrice());
                 //楠岃瘉娲鹃仯鍗曚綅淇℃伅鏄惁瀛樺湪
                 if(duSolutionList.stream().filter(d->d.getDispatchUnitId().equals(applyDetail.getDuId())).collect(Collectors.toList()).size()<=Constants.ZERO){
                     throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"銆�"+applyDetail.getMemberName()+"銆戝憳宸ユ淳閬e崟浣嶆湭鏌ヨ鍒帮紒");
@@ -1306,6 +1351,8 @@
 
 
 
+
+
     @Override
     public CountCyclePriceVO getCountCyclePriceVO(CountCyclePriceDTO countCyclePriceDTO){
         if(Objects.isNull(countCyclePriceDTO)
@@ -1318,21 +1365,11 @@
         if(Objects.isNull(solutions)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈡柟妗堜俊鎭�");
         }
-        CountCyclePriceVO countCyclePriceVO = new CountCyclePriceVO();
-        if(solutions.getInsureCycleUnit().equals(Constants.ZERO)){
-            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(countCyclePriceDTO.getStartDate(),0,solutions.getInsureCycle()));
-        }else if(solutions.getInsureCycleUnit().equals(Constants.TWO)){
-            Integer monthDays = DateUtil.monthDays(countCyclePriceDTO.getStartDate());
-            Date afterDate = DateUtil.afterDateByType(countCyclePriceDTO.getStartDate(),0,monthDays);
-            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(afterDate,0,-1));
-        }else if(solutions.getInsureCycleUnit().equals(Constants.THREE)){
-            Date afterDate = DateUtil.afterDateByType(countCyclePriceDTO.getStartDate(),2,solutions.getInsureCycle());
-            countCyclePriceVO.setEndDate(DateUtil.afterDateByType(afterDate,0,-1));
-        }
-        countCyclePriceVO.setCyclePrice(Constants.countDetailFee(solutions,countCyclePriceVO.getEndDate(),countCyclePriceDTO.getStartDate()));
-        return countCyclePriceVO;
+        return Constants.countPriceVO(countCyclePriceDTO.getStartDate(),solutions);
     }
 
 
 
+
+
 }
diff --git a/server/service/src/main/java/com/doumee/service/business/impl/MemberInsuranceServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/MemberInsuranceServiceImpl.java
index 5743ae7..5887e9c 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/MemberInsuranceServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/MemberInsuranceServiceImpl.java
@@ -83,6 +83,7 @@
     public List<MemberInsurance> findList(MemberInsurance memberInsurance) {
         memberInsurance.setIsdeleted(Constants.ZERO);
         QueryWrapper<MemberInsurance> wrapper = new QueryWrapper<>(memberInsurance);
+        wrapper.orderByDesc("CREATE_DATE");
         return memberInsuranceMapper.selectList(wrapper);
     }
   
@@ -129,10 +130,6 @@
         if (pageWrap.getModel().getStartTime() != null) {
             queryWrapper.lambda().eq(MemberInsurance::getStartTime, pageWrap.getModel().getStartTime());
         }
-        if (pageWrap.getModel().getIdcardNo() != null) {
-            queryWrapper.lambda().ge(MemberInsurance::getIdcardNo, Utils.Date.getStart(pageWrap.getModel().getIdcardNo()));
-            queryWrapper.lambda().le(MemberInsurance::getIdcardNo, Utils.Date.getEnd(pageWrap.getModel().getIdcardNo()));
-        }
         if (pageWrap.getModel().getDuId() != null) {
             queryWrapper.lambda().eq(MemberInsurance::getDuId, pageWrap.getModel().getDuId());
         }
@@ -176,6 +173,8 @@
         return PageData.from(memberInsuranceMapper.selectPage(page, queryWrapper));
     }
 
+
+
     @Override
     public long count(MemberInsurance memberInsurance) {
         QueryWrapper<MemberInsurance> wrapper = new QueryWrapper<>(memberInsurance);
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 9175834..99bd7d2 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
@@ -358,6 +358,8 @@
         }
         settleClaims.setCreateDate(new Date());
         settleClaims.setIsdeleted(Constants.ZERO);
+        settleClaims.setCompanyId(loginUserInfo.getCompanyId());
+        settleClaims.setStatus(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey());
         settleClaims.setCreator(loginUserInfo.getId());
         settleClaims.setCheckUserId(loginUserInfo.getId());
         settleClaimsMapper.insert(settleClaims);
@@ -368,6 +370,7 @@
                 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(),"闄勪欢鍐呭寮傚父");
                 }
@@ -551,8 +554,8 @@
         if(!oldSettleClaims.getSolutionId().equals(settleClaims.getSolutionId())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏃犳硶淇敼鏂规淇℃伅");
         }
-        if(!(oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE)
-                || oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION))){
+        if(!(oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey())
+                || oldSettleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔");
         }
         oldSettleClaims.setEditor(loginUserInfo.getId());
@@ -589,8 +592,8 @@
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炰紒涓氬憳宸ユ棤娉曡繘琛岃鎿嶄綔");
         }
         SettleClaims settleClaims  = settleClaimsMapper.selectById(scSupplementDTO.getId());
-        if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE)
-                || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION))){
+        if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey())
+                || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔");
         }
         settleClaims.setEditor(loginUserInfo.getId());
@@ -612,21 +615,18 @@
         LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
         if(Objects.isNull(scSupplementDTO)
                 || Objects.isNull(scSupplementDTO.getId())
-                || Objects.isNull(scSupplementDTO.getSupplement())
                 || Objects.isNull(scSupplementDTO.getObjType())
                 || Objects.isNull(scSupplementDTO.getFileUrl())
                 || Objects.isNull(scSupplementDTO.getFileType())
-                || scSupplementDTO.getObjType().equals(Constants.ZERO)
         ){
             throw new BusinessException(ResponseStatus.BAD_REQUEST);
         }
 
         SettleClaims settleClaims  = settleClaimsMapper.selectById(scSupplementDTO.getId());
-        if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE)
-                || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION))){
+        if(!(settleClaims.getStatus().equals(Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey())
+                || settleClaims.getStatus().equals(Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"褰撳墠鐘舵�佹棤娉曡繘琛岃鎿嶄綔");
         }
-
         Multifile multifile = new Multifile();
         if(loginUserInfo.getType().equals(Constants.ONE)){
             multifile.setCompanyId(loginUserInfo.getCompanyId());
@@ -634,7 +634,9 @@
         multifile.setCreator(loginUserInfo.getId());
         multifile.setCreateDate(new Date());
         multifile.setIsdeleted(Constants.ZERO);
+        multifile.setObjType(scSupplementDTO.getObjType());
         multifile.setObjId(scSupplementDTO.getId());
+        multifile.setFileurl(scSupplementDTO.getFileUrl());
         multifile.setName(scSupplementDTO.getFileUrl().substring(scSupplementDTO.getFileUrl().lastIndexOf("/") + 1));
         multifile.setType(scSupplementDTO.getFileType());
         multifileJoinMapper.insert(multifile);

--
Gitblit v1.9.3