From e856339c5eef51276d64956f2e3f64386f75ce66 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期日, 04 二月 2024 16:12:22 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 server/service/src/main/java/com/doumee/core/utils/Constants.java |  291 +++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 259 insertions(+), 32 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 f2b834f..ff6ca38 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,16 +162,42 @@
         return age;
     }
 
+
+    public static CountCyclePriceVO countPriceVO(Date startDate, Solutions solutions){
+        CountCyclePriceVO countCyclePriceVO = new CountCyclePriceVO();
+        if(solutions.getInsureCycleUnit().equals(Constants.ZERO)){
+            countCyclePriceVO.setEndDate(
+                    DateUtil.getMontageDate(
+                        DateUtil.afterDateByType(startDate,0,solutions.getInsureCycle()-1)
+                    ,2)
+            );
+        }else if(solutions.getInsureCycleUnit().equals(Constants.TWO)){
+            //鑾峰彇褰撴湀澶╂暟
+            Integer monthDays = DateUtil.monthDays(startDate);
+            //鑾峰彇澶╂暟鍚庣殑鏃ユ湡
+            Date afterDate = DateUtil.afterDateByType(startDate,0,monthDays);
+            //璧嬪�� 姣忔棩缁撴潫鏃跺垎绉�
+            countCyclePriceVO.setEndDate(DateUtil.getMontageDate(afterDate,3));
+        }else if(solutions.getInsureCycleUnit().equals(Constants.THREE)){
+            //鑾峰彇X骞村悗鏃ユ湡 澶氫簡涓�澶�
+            Date afterDate = DateUtil.afterDateByType(startDate,2,solutions.getInsureCycle());
+            //璧嬪�� 姣忔棩缁撴潫鏃跺垎绉� 鐒跺悗鍑忓皯涓�澶�
+            countCyclePriceVO.setEndDate(DateUtil.getMontageDate(afterDate,3));
+        }
+        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);
-        Integer sex = 1;
+        Integer sex = 0;
         if (matcher.matches()) {
             int genderCode = Integer.parseInt(idCard.substring(16, 17)); // 浠庣17浣嶅紑濮嬫彁鍙栨�у埆缂栫爜锛堝鏁颁负鐢锋�э紝鍋舵暟涓哄コ鎬э級
             if ((genderCode % 2 == 1) ) {
-                sex = 1;
+                sex = 0;
             } else {
-                sex = 2;
+                sex = 1;
             }
         } else {
            sex = -1;
@@ -710,43 +737,48 @@
 
 
     public  enum ApplyLogType {
-        UPLOAD(0, "鎻愪氦鎶曚繚","鎻愪氦鎰忚锛�${param}"),
-        PLATFORM_RETURN(1, "閫�鍥炴姇淇�","鎻愪氦鎰忚锛�${param}"),
-        WAIT_SIGNATURE(2, "涓婁紶鎶曚繚鍗�","鎻愪氦鎰忚锛�${param}"),
-        SIGNATURE(3, "浼佷笟绛剧珷",""),
-        FAIL_RETURN(4, "淇濆崟鍑哄叿澶辫触閫�鍥�","鎻愪氦鎰忚锛�${param}"),
-        UPLOAD_INSURANCE(5, "淇濆崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param1}鍙樻洿涓�${param2}"),
-        COMPANY_APPLY_RETURN(6, "鐢宠閫�鍥�","鎻愪氦鎰忚锛�${param}"),
-        COMPANY_APPLY_CLOSE(7, "鍏抽棴鐢宠",""),
-        PLATFORM_AGREE_BACK(8, "鍚屾剰閫�鍥炵敵璇�",""),
-        PLATFORM_UN_AGREE_BACK(9, "椹冲洖閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}"),
-        COMPANY_EDIT(10, "淇濆崟淇敼","鎻愪氦鎰忚锛�${param1}\n${param2}"),
-        PLATFORM_CHECK_PASS(11, "鎶曚繚瀹℃牳閫氳繃",""),
-        CA_PLATFORM_CHECK_PASS_NO(12, "閫�鍥炴姇淇�","鎻愪氦鎰忚锛�${param}"),
-        CA_PLATFORM_AGREE_BACK_APPLY(13, "鍚屾剰閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}"),
-        CA_PLATFORM_APPROVE(14, "鎵瑰崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param1}鍙樻洿涓�${param2}"),
-        CA_PLATFORM_CHECK_SIGNATURE(15, "浼佷笟绛剧珷",""),
-        CA_COMPANY_EDIT(16, "鎵瑰崟淇敼","鎻愪氦鎰忚锛�${param1}\n${param2}"),
-        CA_COMPANY_COMMIT(17, "鎻愪氦鎶曚繚","鎻愪氦鎰忚锛�${param}"),
-        CA_COMPANY_BACK_APPLY(18, "鐢宠閫�鍥�","鎻愪氦鎰忚锛�${param}"),
-        CA_COMPANY_CLOSE(19, "鍏抽棴璁㈠崟",""),
-        CA_PALTFORM_REFUSE_APPLY(20, "椹冲洖閫�鍥炵敵璇�",""),
-        CA_PALTFORM_EDIT_PIDAN(21, "淇敼鎵瑰崟","淇敼鍘熷洜锛�${param}"),
-        PALTFORM_EDIT_BD(22, "淇敼淇濆崟","淇敼鍘熷洜锛�${param}"),
-        CA_JIAJIAN_APPLY_SIGN(23, "鍔犲噺淇濈敵璇蜂紒涓氱绔�",""),
+        UPLOAD(0, "鎻愪氦鎶曚繚","鎻愪氦鎰忚锛�${param}",0),
+        PLATFORM_RETURN(1, "閫�鍥炴姇淇�","鎻愪氦鎰忚锛�${param}",0),
+        WAIT_SIGNATURE(2, "涓婁紶鎶曚繚鍗�","鎻愪氦鎰忚锛�${param}",0),
+        SIGNATURE(3, "浼佷笟绛剧珷","",0),
+        FAIL_RETURN(4, "淇濆崟鍑哄叿澶辫触閫�鍥�","鎻愪氦鎰忚锛�${param}",0),
+        UPLOAD_INSURANCE(5, "淇濆崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param1}鍙樻洿涓�${param2}",0),
+        COMPANY_APPLY_RETURN(6, "鐢宠閫�鍥�","鎻愪氦鎰忚锛�${param}",0),
+        COMPANY_APPLY_CLOSE(7, "鍏抽棴鐢宠","",0),
+        PLATFORM_AGREE_BACK(8, "鍚屾剰閫�鍥炵敵璇�","",0),
+        PLATFORM_UN_AGREE_BACK(9, "椹冲洖閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}",0),
+        COMPANY_EDIT(10, "淇濆崟淇敼","鎻愪氦鎰忚锛�${param1}\n${param2}",0),
+        PLATFORM_CHECK_PASS(11, "鎶曚繚瀹℃牳閫氳繃","",0),
+        UPLOAD_AGAIN(26, "鍐嶆鎶曚繚","",0),
 
-        CA_CHANGUNIT_APPLY_SIGN(24, "鎹㈡垚鐢宠浼佷笟绛剧珷",""),
+
+        CA_PLATFORM_CHECK_PASS_NO(12, "閫�鍥炴姇淇�","鎻愪氦鎰忚锛�${param}",1),
+        CA_PLATFORM_AGREE_BACK_APPLY(13, "鍚屾剰閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}",1),
+        CA_PLATFORM_APPROVE(14, "鎵瑰崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param1}鍙樻洿涓�${param2}",1),
+        CA_PLATFORM_CHECK_SIGNATURE(15, "浼佷笟绛剧珷","",1),
+        CA_COMPANY_EDIT(16, "鎵瑰崟淇敼","鎻愪氦鎰忚锛�${param1}\n${param2}",1),
+        CA_COMPANY_COMMIT(17, "鎻愪氦鎶曚繚","鎻愪氦鎰忚锛�${param}",1),
+        CA_COMPANY_BACK_APPLY(18, "鐢宠閫�鍥�","鎻愪氦鎰忚锛�${param}",1),
+        CA_COMPANY_CLOSE(19, "鍏抽棴璁㈠崟","",1),
+        CA_PALTFORM_REFUSE_APPLY(20, "椹冲洖閫�鍥炵敵璇�","",1),
+        CA_PALTFORM_EDIT_PIDAN(21, "淇敼鎵瑰崟","淇敼鍘熷洜锛�${param}",1),
+        PALTFORM_EDIT_BD(22, "淇敼淇濆崟","淇敼鍘熷洜锛�${param}",1),
+        CA_JIAJIAN_APPLY_SIGN(23, "鍔犲噺淇濈敵璇蜂紒涓氱绔�","",1),
+        CA_CHANGUNIT_APPLY_SIGN(24, "鎹㈠巶鐢宠浼佷笟绛剧珷","",1),
+        CA_UPLOAD_AGAIN(25, "鍐嶆鎶曚繚","",1),
         ;
         // 鎴愬憳鍙橀噺
         private String name;
         private String info;
         private int key;
+        private int type;
 
         // 鏋勯�犳柟娉�
-        ApplyLogType(int key, String name,String info) {
+        ApplyLogType(int key, String name,String info,int type) {
             this.name = name;
             this.info = info;
             this.key = key;
+            this.type = type;
         }
 
         // 鏅�氭柟娉�
@@ -766,6 +798,16 @@
             }
             return null;
         }
+        public static List<Integer> getTypeList(int type) {
+            List<Integer> list = new ArrayList<>();
+            for (ApplyLogType c : ApplyLogType.values()) {
+                if (c.getType() == type) {
+                    list.add(c.getKey());
+                }
+            }
+            return list;
+        }
+
 
         // get set 鏂规硶
         public String getName() {
@@ -790,6 +832,15 @@
 
         public void setInfo(String info) {
             this.info = info;
+        }
+
+
+        public int getType() {
+            return type;
+        }
+
+        public void setType(int type) {
+            this.type = type;
         }
     }
 
@@ -892,6 +943,181 @@
         }
     }
 
+
+    public  enum NoticeObjectType {
+        INSURANCE_APPLY(0, "鎶曚繚鐢宠","淇濋櫓鏂规"),
+        APPLY_CHANGE(1, "鍔犲噺淇濈敵璇�","淇濋櫓鏂规"),
+        CHANGE_FACTORY(2, "鍛樺伐鎹㈠巶鐢宠","淇濋櫓鏂规"),
+        DISPATCH_UNIT(3, "娲鹃仯鍗曚綅鐢宠","娲鹃仯鍗曚綅"),
+        TAXES(4, "寮�绁ㄧ敵璇�","寮�绁ㄩ噾棰�"),
+        SETTLE_CLAIMS(5, "鎶ユ鐞嗚禂","鎶ユ浜�")
+        ;
+        // 鎴愬憳鍙橀噺
+        private int key;
+        private String name;
+        private String info;
+
+        // 鏋勯�犳柟娉�
+        NoticeObjectType(int key, String name,String info) {
+            this.name = name;
+            this.key = key;
+            this.info = info;
+        }
+
+        // 鏅�氭柟娉�
+        public static String getName(int index) {
+            for (NoticeObjectType c : NoticeObjectType.values()) {
+                if (c.getKey() == index) {
+                    return c.name;
+                }
+            }
+            return null;
+        }
+
+
+        // get set 鏂规硶
+        public String getName() {
+            return name;
+        }
+
+        public void setName(String name) {
+            this.name = name;
+        }
+
+        public int getKey() {
+            return key;
+        }
+
+        public void setKey(int key) {
+            this.key = key;
+        }
+
+        public String getInfo() {
+            return info;
+        }
+
+        public void setInfo(String info) {
+            this.info = info;
+        }
+
+    }
+
+
+    public  enum NoticeType {
+
+        ZERO(0, "寰呭鎵�","","","寰呭鏍�","宸茬敵璇�","寰呭彈鐞�"),
+        ONE(1, "浼佷笟寰呯缃�","","","宸ョ寰呭鏍�","","瀹屾垚鍙楃悊"),
+        TWO(2, "寰呭嚭鍗�","寰呭鎵�","寰呭鎵�","","",""),
+        THREE(3, "鐢宠閫�鍥�","鐢宠閫�鍥�","鐢宠閫�鍥�","","",""),
+        FOUR(4, "宸查��鍥�","宸查��鍥�","宸查��鍥�","","",""),
+        FIVE(5, "鐢宠椹冲洖","鐢宠椹冲洖","鐢宠椹冲洖","","","")
+        ;
+
+        // 鎴愬憳鍙橀噺
+        private int status;
+        private String insuranceApplyDetail;
+        private String applyChangeDetail;
+        private String changeFactoryDetail;
+        private String dispatchUnitDetail;
+        private String taxesDetail;
+        private String settleClaimsDetail;
+
+        // 鏋勯�犳柟娉�
+        NoticeType(int status, String insuranceApplyDetail,String applyChangeDetail
+                , String changeFactoryDetail,String dispatchUnitDetail
+                , String taxesDetail,String settleClaimsDetail) {
+            this.status = status;
+            this.insuranceApplyDetail = insuranceApplyDetail;
+            this.applyChangeDetail = applyChangeDetail;
+            this.changeFactoryDetail = changeFactoryDetail;
+            this.dispatchUnitDetail = dispatchUnitDetail;
+            this.taxesDetail = taxesDetail;
+            this.settleClaimsDetail = settleClaimsDetail;
+        }
+
+        // 鏅�氭柟娉�
+        public static String getDetail(int status,int type) {
+            for (NoticeType c : NoticeType.values()) {
+                if (c.getStatus() == status) {
+                    if(type==NoticeObjectType.INSURANCE_APPLY.getKey() ){
+                        return c.getInsuranceApplyDetail();
+                    }else if(type == NoticeObjectType.APPLY_CHANGE.getKey()){
+                        return c.getApplyChangeDetail();
+                    }else if(type == NoticeObjectType.CHANGE_FACTORY.getKey()){
+                        return c.getChangeFactoryDetail();
+                    }else if(type == NoticeObjectType.DISPATCH_UNIT.getKey()){
+                        return c.getDispatchUnitDetail();
+                    }else if(type == NoticeObjectType.TAXES.getKey()){
+                        return c.getTaxesDetail();
+                    }else if(type == NoticeObjectType.SETTLE_CLAIMS.getKey()){
+                        return c.getSettleClaimsDetail();
+                    }
+                }
+            }
+            return null;
+        }
+
+        // get set 鏂规硶
+        public int getStatus() {
+            return status;
+        }
+
+        public void setStatus(int status) {
+            this.status = status;
+        }
+
+        public String getInsuranceApplyDetail() {
+            return insuranceApplyDetail;
+        }
+
+        public void setInsuranceApplyDetail(String name) {
+            this.insuranceApplyDetail = insuranceApplyDetail;
+        }
+
+        public String getApplyChangeDetail() {
+            return applyChangeDetail;
+        }
+
+        public void setApplyChangeDetail(String info) {
+            this.applyChangeDetail = applyChangeDetail;
+        }
+
+        public String getChangeFactoryDetail() {
+            return changeFactoryDetail;
+        }
+
+        public void setChangeFactoryDetail(String info) {
+            this.changeFactoryDetail = changeFactoryDetail;
+        }
+
+        public String getDispatchUnitDetail() {
+            return dispatchUnitDetail;
+        }
+
+        public void setDispatchUnitDetail(String info) {
+            this.dispatchUnitDetail = dispatchUnitDetail;
+        }
+
+        public String getTaxesDetail() {
+            return taxesDetail;
+        }
+
+        public void setTaxesDetail(String info) {
+            this.taxesDetail = taxesDetail;
+        }
+
+        public String getSettleClaimsDetail() {
+            return settleClaimsDetail;
+        }
+
+        public void setSettleClaimsDetail(String info) {
+            this.settleClaimsDetail = settleClaimsDetail;
+        }
+
+
+    }
+
+
     public static BigDecimal countDetailFee(Solutions solutions,Date startDate, Date endDate){
         //鏌ヨ淇濋櫓瀹為檯鍛ㄦ湡
         Integer cycle = DateUtil.calculateBetween(endDate,startDate,solutions.getTimeUnit());
@@ -914,7 +1140,7 @@
     public  enum ApplyChangeStatus {
         UPLOAD(0, "鎻愪氦鍔犲噺淇�/鎹㈠巶鐢宠"),
         SIGNATURE(1, "宸茬绔�"),
-        APPROVE(2, "宸蹭笂浼犲鎵�"),
+        APPROVE(2, "宸蹭笂浼犲鏍�"),
         RETURN_APPLY_UPLOAD(3, "鍙戣捣閫�鍥炵敵璇�(寰呭鏍�)"),
         RETURN_APPLY_SIGNATURE(4, "鍙戣捣閫�鍥炵敵璇凤紙宸茬绔狅級"),
         PLATFORM_AGREE(5, "骞冲彴鍚屾剰锛堝凡閫�鍥烇級"),
@@ -1084,8 +1310,8 @@
     public  enum ApplyChangeLogStatus {
         UPLOAD(0, "鍙戣捣鐢宠",""),
         RETURN_APPLY(3, "鍙戣捣閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}"),
-        PLATFORM_AGREE(4, "骞冲彴瀹℃壒閫氳繃" ,"鎻愪氦鎰忚锛�${param}"),
-        PLATFORM_UN_AGREE(0, "瀹℃壒椹冲洖","鎻愪氦鎰忚锛�${param}"),
+        PLATFORM_AGREE(4, "骞冲彴瀹℃牳閫氳繃" ,"鎻愪氦鎰忚锛�${param}"),
+        PLATFORM_UN_AGREE(0, "瀹℃牳椹冲洖","鎻愪氦鎰忚锛�${param}"),
         CLOSE(5, "鍏抽棴",""),
         ;
         // 鎴愬憳鍙橀噺
@@ -1402,6 +1628,7 @@
                     }
                 }
                 zipOutputStream.closeArchiveEntry();
+                file.delete();
             }
         }
     }

--
Gitblit v1.9.3