From 78a173f85f8a4666d83cf8d900f04dd9f8e3e127 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 17 六月 2025 08:53:12 +0800
Subject: [PATCH] 提交一把订单

---
 server/service/src/main/java/com/doumee/core/utils/Constants.java |  224 +++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 191 insertions(+), 33 deletions(-)

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 a589686..470525b 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
@@ -4,8 +4,10 @@
 import cn.hutool.core.util.IdcardUtil;
 import com.doumee.core.constants.ResponseStatus;
 import com.doumee.core.exception.BusinessException;
+import com.doumee.dao.business.dto.ApplyPowerDTO;
 import com.doumee.dao.business.dto.CountCyclePriceDTO;
 import com.doumee.dao.business.model.*;
+import com.doumee.dao.business.vo.ApplyPowerVO;
 import com.doumee.dao.business.vo.ChangeDealTypeVO;
 import com.doumee.dao.business.vo.CountCyclePriceVO;
 import io.swagger.models.auth.In;
@@ -21,7 +23,10 @@
 import java.math.RoundingMode;
 import java.net.URL;
 import java.net.URLDecoder;
+import java.time.Instant;
 import java.time.LocalDate;
+import java.time.Period;
+import java.time.ZoneId;
 import java.time.temporal.ChronoUnit;
 import java.util.*;
 import java.util.Date;
@@ -99,6 +104,7 @@
     public static final String COMPANY_USER_APPLY ="COMPANY_USER_APPLY" ;
     public static final String INSURANCE ="INSURANCE" ;
     public static final String CONTRACT ="CONTRACT" ;
+    public static final String DISCUSS_PROBLEM_TYPE ="DISCUSS_PROBLEM_TYPE" ;
 
     public static final String SETTLE_FILE ="SETTLE_FILE" ;
     public static final String DU_FILE ="DU_FILE" ;
@@ -194,6 +200,13 @@
                 return  Constants.equalsInteger(model.getStatus(), UnionApplyStatus.FINISH.getKey())?"淇濋櫓鐢熸晥姝㈡湡":"棰勮鐢熸晥姝㈡湡";
         }
 
+    }
+
+    public static BigDecimal getBigDecimalNoNull(BigDecimal bigDecimal){
+        if(Objects.isNull(bigDecimal)){
+            return  BigDecimal.ZERO;
+        }
+        return bigDecimal;
     }
 
     /**
@@ -308,6 +321,38 @@
         }
         return Constants.countPriceVO(countCyclePriceDTO.getStartDate(),countCyclePriceDTO.getSolutions());
     }
+
+    public static int calculateAge(String idCard,Date dateDate) {
+        try{
+            Integer happenYear = Integer.valueOf(DateUtil.dateToString(dateDate,"yyyy"));
+            Integer birthYear = Integer.valueOf(idCard.substring(6,10));
+            return happenYear - birthYear;
+        }catch (Exception e){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"骞撮緞淇℃伅閿欒");
+        }
+
+
+
+
+
+//        if (idCard == null || idCard.length() != 18) {
+//            throw new IllegalArgumentException("韬唤璇佸彿鐮佸繀椤绘槸18浣�");
+//        }
+//
+//        // 鎻愬彇鍑虹敓鏃ユ湡
+//        String birthDateStr = idCard.substring(6, 14); // 渚嬪锛�19900101
+//        LocalDate birthDate = LocalDate.parse(birthDateStr);
+//        Instant instant = dateDate.toInstant();
+//        // 鑾峰彇褰撳墠鏃ユ湡
+//        LocalDate currentDate = instant.atZone(ZoneId.systemDefault()).toLocalDate(); // 杞崲涓� LocalDate
+//
+//        // 璁$畻骞撮緞
+//        Period period = Period.between(birthDate, currentDate);
+//        int age = period.getYears(); // 鐩存帴鑾峰彇骞翠唤宸嵆涓哄勾榫�
+
+//        return age;
+    }
+
 
     public static CountCyclePriceVO countPriceVO(Date startDate, Solutions solutions){
         CountCyclePriceVO countCyclePriceVO = new CountCyclePriceVO();
@@ -769,6 +814,8 @@
         LP_FILE(32, "淇濋櫓鍏徃涓婁紶鐞嗚禂鏉愭枡涓�瑙堣〃", "淇濋櫓鍏徃涓婁紶鐞嗚禂鏉愭枡涓�瑙堣〃"),
         LP_OTHER_FILE(33, "鐞嗚禂鍏朵粬鏉愭枡", "鐞嗚禂鍏朵粬鏉愭枡"),
         LP_PAY_FILE(34, "鎵撴鍑瘉", "鎵撴鍑瘉"),
+        LP_DZBD_FILE(35, "鐢靛瓙淇濆崟", "鐢靛瓙淇濆崟"),
+        LP_SUPPLEMENT_FILE(36, "琛ュ厖鏉愭枡", "琛ュ厖鏉愭枡"),
 
         ;
         // 鎴愬憳鍙橀噺
@@ -1622,10 +1669,11 @@
         CHANGE_FACTORY(2, "鍛樺伐鎹㈠巶鐢宠","淇濋櫓鏂规"),
         DISPATCH_UNIT(3, "娲鹃仯鍗曚綅鐢宠","娲鹃仯鍗曚綅"),
         TAXES(4, "寮�绁ㄧ敵璇�","寮�绁ㄩ噾棰�"),
-        SETTLE_CLAIMS(5, "鎶ユ鐞嗚禂","鎶ユ浜�"),
+        SETTLE_CLAIMS(5, "鐞嗚禂鎻愰啋","鎶ユ淇℃伅"),
         CONTRACT(6, "鍚堝悓绛剧讲","鍚堝悓绛剧讲"),
         SOLUTIONS(7, "鏂规绛剧讲","鏂规绛剧讲"),
         COMPANY_USER_APPLY(8, "闆嗗洟鐢宠","闆嗗洟鐢宠"),
+        SETTLE_CLAIMS_APPLY_ADMIN(9, "鎶ユ鐞嗚禂","寰呯珛妗�"),
         ;
         // 鎴愬憳鍙橀噺
         private int key;
@@ -1680,19 +1728,36 @@
 
     public  enum NoticeType {
 
-        ZERO(0, "寰呭鏍�","","","寰呭鏍�","寰呭鐞�","澶勭悊涓�","寰呯缃�","寰呯缃�"),
-        ONE(1, "浼佷笟寰呯缃�","","","宸ョ寰呭鏍�","","宸茬粨妗�","",""),
-        TWO(2, "寰呭嚭鍗�","寰呭鏍�","寰呭鏍�","","","","",""),
-        THREE(3, "鐢宠閫�鍥�","鐢宠閫�鍥�","鐢宠閫�鍥�","","","","",""),
-        FOUR(4, "宸查��鍥�","宸查��鍥�","宸查��鍥�","","","宸叉挙閿�","",""),
-        FIVE(5, "鐢宠椹冲洖","鐢宠椹冲洖","鐢宠椹冲洖","","","","",""),
+        ZERO(0, "寰呭鏍�","","","寰呭鏍�","寰呭鐞�","椋庨櫓妗堜欢寰呭鏍�","寰呯缃�","寰呯缃�"),
+        //鐞嗚禂閫氱煡浼佷笟锛堥潪寰呭姙锛�
+        ONE(1, "浼佷笟寰呯缃�","","","宸ョ寰呭鏍�","","椋庨櫓妗堜欢绔嬫閫�鍥�","",""),
+        TWO(2, "寰呭嚭鍗�","寰呭鏍�","寰呭鏍�","","","宸茬珛妗堝緟鍙楃悊","",""),
+        THREE(3, "鐢宠閫�鍥�","鐢宠閫�鍥�","鐢宠閫�鍥�","","","宸插彈鐞嗭紝闇�瑕佽ˉ鍏呮潗鏂�","",""),
+        //鐞嗚禂閫氱煡浼佷笟锛堥潪寰呭姙锛�
+        FOUR(4, "宸查��鍥�","宸查��鍥�","宸查��鍥�","","","宸叉嫆缁濆彈鐞�","",""),
+        FIVE(5, "鐢宠椹冲洖","鐢宠椹冲洖","鐢宠椹冲洖","","","鍟嗚寰呴瀵煎鎵�","",""),
         //缁繚閫氱煡
-        SIX(6, "","","","","","","",""),
-        //鍟嗘埛绔� 濮旀墭淇� - 鎶曚繚寰呭鏍� 鍔犲噺淇� 鎹㈠巶 寰呭鏍�
-        SEVEN(7, "寰呭鏍�","寰呭鏍�","寰呭鏍�","","","","",""),
+        SIX(6, "","","","","","鍟嗚瀹℃壒鎷掔粷","",""),
+        //鍟嗘埛绔� 濮旀墭淇� - 鎶曚繚寰呭鏍� 鍔犲噺淇� 鎹㈠巶 寰呭鏍�, 鐞嗚禂閫氱煡浼佷笟锛堥潪寰呭姙锛�
+        SEVEN(7, "寰呭鏍�","寰呭鏍�","寰呭鏍�","","","鍟嗚瀹℃壒鎷掔粷閫氱煡","",""),
         //寰呭瀹�
-        EIGHT(8, "寰呭鏍�","","","","","","",""),
-        NINE(9, "","","","","","","",""),
+        EIGHT(8, "寰呭鏍�","","","","","寰呯悊绠�","",""),
+        NINE(9, "","","","","","寰呮牳璧�","",""),
+        TEN(10, "","","","","","寰呮牳璧旂‘璁�","",""),
+        ELEVEN(11, "","","","","","璧斾粯閲戦宸插彉鏇�","",""),
+        TWELVE(12, "","","","","","寰呯粨妗�","",""),
+        //鐞嗚禂閫氱煡骞冲彴锛堥潪浠e姙锛�
+        THIRTEEN(13, "","","","","","宸茬粨妗堬紝璧斾粯娆鹃」灏嗗湪1-3涓伐浣滄棩鍐呭埌璐�","",""),
+        //鐞嗚禂閫氱煡骞冲彴锛堥潪浠e姙锛�
+        FOURTEEN(14, "","","","","","宸叉挙妗�","",""),
+        //鐞嗚禂閫氱煡浼佷笟锛堥潪寰呭姙锛�
+        FIFTEEN(15, "","","","","","宸插彈鐞嗗緟鐞嗙畻","",""),
+        //鐞嗚禂閫氱煡浼佷笟(闈炲緟鍔烇級
+        SIXTEEN(16, "","","","","","鍙楃悊瀹℃壒涓�","",""),
+        //鐞嗚禂閫氱煡浼佷笟(闈炲緟鍔烇級
+        SEVENTEEN(17, "","","","","","宸茬悊绠楀緟鏍歌禂","",""),
+        //鐞嗚禂閫氱煡浼佷笟(闈炲緟鍔烇級
+        EIGHTEEN(18, "","","","","","寰呯粨妗堬紝璧斾粯閲戦宸插彉鏇�","",""),
         ;
 
         // 鎴愬憳鍙橀噺
@@ -1938,19 +2003,19 @@
         // 8鍟嗚瀹℃壒鎷掔粷 9宸插彈鐞� 10寰呮牳璧�  11宸叉牳璧� 12宸茬‘璁ら噾棰� 13宸茬粨妗� 14宸叉挙妗�
         WAIT_ACCEPTANCE(0, "鏆傚瓨涓�",0),
         RETURN_ACCEPTANCE(1, "宸叉姤妗�",1),
-        DEAL_ING(2, "寰呯珛妗� 锛堝純鐢級",0),
-        CONFIRM_INFORMATION(3, "宸茬珛妗�",1),
-        FINISH_ACCEPTANCE(4, "绔嬫閫�鍥�",1),
-        WAIT_DEAL(5, "寰呭彈鐞�",2),
-        REJECT_DEAL(6, "鎷掔粷鍙楃悊",2),
-        WAIT_DISCUSS_AUDIT(7, "寰呭晢璁鎵�",2),
+        DEAL_ING(2, "寰呯珛妗�",0),//寮冪敤
+        CONFIRM_INFORMATION(3, "宸茬珛妗�",2),
+        FINISH_ACCEPTANCE(4, "绔嬫閫�鍥�",2),
+        WAIT_DEAL(5, "寰呭彈鐞�",3),//寮冪敤
+        REJECT_DEAL(6, "鎷掔粷鍙楃悊",3),
+        WAIT_DISCUSS_AUDIT(7, "寰呭晢璁鎵�",3),
         WAIT_DISCUSS_REJECT(8, "鍟嗚瀹℃壒鎷掔粷",3),
         ACCEPTANCE(9, "宸插彈鐞�",3),//寰呯悊绠�
         WAIT_AUDIT_COMPENSATION(10, "寰呮牳璧�",4),
         COMPENSATION(11, "宸叉牳璧�",5),
-        CONFIRM_FEE(12, "宸茬‘璁ら噾棰�",5),
+        CONFIRM_FEE(12, "寰呯粨妗�",5),
         CLOSE_CASE(13, "宸茬粨妗�",6),
-        RETURN(14, "宸叉挙妗�",6),
+        RETURN(14, "宸叉挙妗�",7),
         ;
         // 鎴愬憳鍙橀噺
         private String name;//涓氬姟鎻忚堪
@@ -2002,12 +2067,12 @@
         UPLOAD(0, "鎻愪氦鎶ユ","鎻愪氦鎰忚锛�${param}"),
         PLATFORM_RETURN(1, "骞冲彴閫�鍥�","鎻愪氦鎰忚锛�${param}"),
         PLATFORM_CONFIRM_INFORMATION(2, "骞冲彴纭璧勬枡",""),
-        PLATFORM_FINISH(3, "缁撴","鎻愪氦鎰忚锛�${param}"),
+        PLATFORM_FINISH(3, "宸茬粨妗�","鎻愪氦鎰忚锛�${param}"),
         UPDATE_DATA(4, "淇敼淇℃伅","鎻愪氦鎰忚锛�${param}"),
         SUPPLEMENT(5, "琛ュ厖璇存槑","鎻愪氦鎰忚锛�${param}"),
         PLATFORM_LP_DEAL(6, "骞冲彴鐞嗚禂澶勭悊","宸插湪骞冲彴瀹屾垚鐞嗚禂"),
-        PLATFORM_REMARK(7, "骞冲彴澶囨敞鏍囩","${param}"),
-        PLATFORM_ADDCODE(8, "骞冲彴娣诲姞鎶ユ鍙�","澶囨鍙凤細${param}"),
+        PLATFORM_REMARK(7, "澶囨敞鏍囩","${param}"),
+        PLATFORM_ADDCODE(8, "骞冲彴淇敼鎶ユ鍙�","澶囨鍙凤細${param}"),
         PLATFORM_UN_AGREE_BACK(9, "浼佷笟涓嬭浇璧勬枡",""),
         PLATFORM_DOWNLOAD(10, "骞冲彴涓嬭浇璧勬枡",""),
         PLATFORM_CHECK_PASS(11, "骞冲彴涓婁紶璧勬枡",""),
@@ -2024,6 +2089,8 @@
         PLATFORM_UPD_FEE(22, "鏍歌禂-淇敼閲戦",""),
         CONFIRM_FEE(22, "鏍歌禂-瀹㈡埛纭閲戦","宸茬‘璁ら噾棰�"),
         UPD_CASE_TYPE(23, "鍙楃悊-纭妗堜欢绫诲瀷","宸茬‘璁ゆ浠剁被鍨�"),
+        UPD_HURT_TYPE(24, "淇敼浼ゆ畫绫诲瀷淇℃伅","鏄惁浼ゆ畫淇敼涓衡�渰param}鈥�"),
+        UPD_RECEIVE_INFO(25, "鏀舵淇℃伅鍙樻洿","淇敼鏀舵淇℃伅"),
         ;
         // 鎴愬憳鍙橀噺
         private String name;
@@ -2039,7 +2106,7 @@
 
         // 鏅�氭柟娉�
         public static String getName(int index) {
-            for (ApplyLogType c : ApplyLogType.values()) {
+            for (SettleClaimsLogType c : SettleClaimsLogType.values()) {
                 if (c.getKey() == index) {
                     return c.name;
                 }
@@ -2047,7 +2114,7 @@
             return null;
         }
         public static String getInfo(int index) {
-            for (ApplyLogType c : ApplyLogType.values()) {
+            for (SettleClaimsLogType c : SettleClaimsLogType.values()) {
                 if (c.getKey() == index) {
                     return c.info;
                 }
@@ -2083,23 +2150,25 @@
 
 
     public  enum SettleClaimsLogParentStatus {
-        BA(1, "鎶ユ","宸叉姤妗�"),
-        LA(2, "绔嬫","宸茬珛妗�"),
-        SL(3, "鍙楃悊","宸插彈鐞�"),
-        LS(4, "鐞嗙畻","宸茬悊绠�"),
-        HP(5, "鏍歌禂","宸叉牳璧�"),
-        JA(6, "缁撴","宸茬粨妗�"),
+        BA(1, "鎶ユ","宸叉姤妗�","宸叉姤妗�"),
+        LA(2, "绔嬫","宸茬珛妗�","寰呯珛妗�"),
+        SL(3, "鍙楃悊","宸插彈鐞�","寰呭彈鐞�"),
+        LS(4, "鐞嗙畻","宸茬悊绠�","寰呯悊绠�"),
+        HP(5, "鏍歌禂","宸叉牳璧�","寰呮牳璧�"),
+        JA(6, "缁撴","宸茬粨妗�","寰呯粨妗�"),
         ;
         // 鎴愬憳鍙橀噺
         private String name;
         private String info;
+        private String waitInfo;
         private int key;
 
         // 鏋勯�犳柟娉�
-        SettleClaimsLogParentStatus(int key, String name,String info) {
+        SettleClaimsLogParentStatus(int key, String name,String info,String waitInfo) {
             this.name = name;
             this.info = info;
             this.key = key;
+            this.waitInfo = waitInfo;
         }
 
         // 鏅�氭柟娉�
@@ -2111,7 +2180,6 @@
             }
             return null;
         }
-
 
         // 鏅�氭柟娉�
         public static SettleClaimsLogParentStatus getAll(int index) {
@@ -2156,6 +2224,16 @@
         public void setInfo(String info) {
             this.info = info;
         }
+
+
+        public String getWaitInfo() {
+            return waitInfo;
+        }
+
+        public void setWaitInfo(String waitInfo) {
+            this.waitInfo = waitInfo;
+        }
+
     }
 
 
@@ -2796,5 +2874,85 @@
 
     }
 
+    public static void  initApplyStatus(InsuranceApply apply){
+        apply.setStatusCollect(Constants.InsuranceApplyStatus.getCollectStatus(apply.getStatus()));
+        if(Constants.equalsInteger(apply.getStatus(),Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey())
+                || Constants.equalsInteger(apply.getStatus(),Constants.InsuranceApplyStatus.WTB_DONE.getKey())){
+            //濡傛灉宸插畬鎴�
+            if(apply.getEndTime()==null || System.currentTimeMillis()>apply.getEndTime().getTime()){
+                apply.setStatusCollect(Constants.THREE);//宸茶繃鏈�
+            }
+        }
+        Constants.setServiceDays(apply);
+        apply.setStatusInfo(Constants.ApplyCollectStatus.getName(apply.getStatusCollect()));
+        if(Constants.equalsInteger(apply.getStatus(),Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey())
+                || Constants.equalsInteger(apply.getStatus(),Constants.InsuranceApplyStatus.WTB_DONE.getKey()) ){
+            if(apply.getStartTime().getTime()>System.currentTimeMillis()){
+                apply.setStatusInfo("寰呯敓鏁�");
+            }else if(apply.getEndTime().getTime()<System.currentTimeMillis()){
+                apply.setStatusInfo("宸茶繃鏈�");
+            }else{
+                apply.setStatusInfo("淇濋殰涓�");
+            }
+        }
+    }
+
+    public static void setServiceDays(InsuranceApply insuranceApply) {
+        //璁剧疆鍦ㄤ繚鏃堕暱锛堝ぉ鏁帮級
+        insuranceApply.setServiceDays(Constants.ZERO);
+        if(insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.UPLOAD_INSURANCE.getKey())
+                || insuranceApply.getStatus().equals(Constants.InsuranceApplyStatus.WTB_DONE.getKey())){
+            //濡傛灉褰撳墠鏃堕棿澶т簬缁撴潫鏃ユ湡 鍒欎娇鐢ㄧ粨鏉熸棩鏈熷姣斿紑濮嬫棩鏈�
+            if(DateUtil.compareDate(new Date(),insuranceApply.getEndTime())>=Constants.ZERO){
+                insuranceApply.setServiceDays(
+                        DateUtil.daysBetweenDates(insuranceApply.getEndTime(),insuranceApply.getStartTime())+1
+                );
+            }else if(DateUtil.compareDate(insuranceApply.getStartTime(),new Date())>=Constants.ZERO){
+                //鏈紑濮�
+                insuranceApply.setServiceDays(Constants.ZERO);
+            }else{
+                insuranceApply.setServiceDays(DateUtil.daysBetweenDates(new Date(),insuranceApply.getStartTime())+1);
+            }
+        }
+    }
+
+    public static ApplyPowerVO getApplyPowerStatic(ApplyPowerDTO applyPowerDTO, InsuranceApply insuranceApply, Solutions solutions){
+        if(Objects.isNull(applyPowerDTO)
+                || Objects.isNull(applyPowerDTO.getApplyId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鍙傛暟閿欒");
+        }
+        if(Objects.isNull(applyPowerDTO.getBeginDate())){
+            applyPowerDTO.setBeginDate(new Date());
+        }
+        ApplyPowerVO applyPowerVO = new ApplyPowerVO();
+        //鑾峰彇鏂规 缁撴潫鏃堕棿
+        Date endTime = insuranceApply.getEndTime();
+        //鏌ヨ褰撳墠鍘诲姞淇濈殑寮�濮嬫棩鏈�  yyyy-MM-dd HH:mm:ss 2024-10-29 00:00:00
+        Date addStartDate = DateUtil.getMontageDate(
+                DateUtil.afterDateByType(applyPowerDTO.getBeginDate(),Constants.ZERO,solutions.getAddValidDays()),
+                1
+        );
+        applyPowerVO.setAddStartDate(addStartDate);
+        //鍔犱繚鐢熸晥鏃ユ湡澶т簬 淇濆崟缁撴潫鏃ユ湡 鍒欎笉鍙互杩涜鍔犱繚
+        if(addStartDate.getTime()>=endTime.getTime()){
+            applyPowerVO.setAddTrue(Constants.ONE);
+        }else{
+            applyPowerVO.setAddTrue(Constants.ZERO);
+        }
+        //鏌ヨ褰撳墠鍘诲噺淇濈殑寮�濮嬫棩鏈�  yyyy-MM-dd HH:mm:ss 2024-10-29 00:00:00
+        Date delStartDate = DateUtil.getMontageDate(
+                DateUtil.afterDateByType(applyPowerDTO.getBeginDate(),Constants.ZERO,solutions.getAddValidDays()),
+                1
+        );
+        applyPowerVO.setDelStartDate(delStartDate);
+        //鍔犱繚鐢熸晥鏃ユ湡澶т簬 淇濆崟缁撴潫鏃ユ湡 鍒欎笉鍙互杩涜鍑忎繚
+        if(delStartDate.getTime()>=endTime.getTime()){
+            applyPowerVO.setDelTrue(Constants.ONE);
+        }else{
+            applyPowerVO.setDelTrue(Constants.ZERO);
+        }
+        return applyPowerVO;
+    }
+
 
 }

--
Gitblit v1.9.3