From 22271e641e4505ba906c3770905b7e84e3ad8d85 Mon Sep 17 00:00:00 2001 From: MrShi <1878285526@qq.com> Date: 星期二, 02 四月 2024 17:05:57 +0800 Subject: [PATCH] mrshi --- server/service/src/main/java/com/doumee/core/utils/Constants.java | 552 ++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 502 insertions(+), 50 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 07c89d8..8b22c7f 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,12 +3,20 @@ 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; +import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream; import org.apache.commons.lang3.StringUtils; -import java.io.File; +import javax.servlet.ServletOutputStream; +import java.io.*; import java.math.BigDecimal; +import java.net.URL; import java.net.URLDecoder; +import java.time.LocalDate; +import java.time.temporal.ChronoUnit; import java.util.*; import java.util.Date; import java.util.regex.Matcher; @@ -35,7 +43,9 @@ public static final String RANGE_SIZE = "RANGE_SIZE"; public static final String CATE_PARAM_OPEN = "_CATE_PARAM_OPEN"; public static final String OPEN_SYNC_SWITCH = "OPEN_SYNC_SWITCH"; - + public static final String WX_MIN_PROGRAM = "WX_MIN_PROGRAM"; + public static final String WX_MIN_APPID = "WX_MIN_APPID"; + public static final String WX_MIN_SECRET = "WX_MIN_SECRET"; public static final String SYSTEM ="SYSTEM"; public static final String GOODS_IMG_DIR ="GOODS_IMG_DIR"; @@ -72,6 +82,8 @@ public static final String TAXES_FILE = "TAXES_FILE"; public static final String APPLY_FILE ="APPLY_FILE" ; public static final String SETTLE_FILE ="SETTLE_FILE" ; + public static final String DU_FILE ="DU_FILE" ; + public static final String SIGN_DONE_NOTIFY_URL = "SIGN_DONE_NOTIFY_URL"; /** * 浼佷笟鏁版嵁鏉ユ簮 0骞冲彴娉ㄥ唽 1鍚庡彴瀵煎叆 @@ -140,6 +152,61 @@ } return d.intValue(); } + + public static long getAgeByIdCard(String idCard){ + int birthYear = Integer.parseInt(idCard.substring(6, 10)); + int birthMonth = Integer.parseInt(idCard.substring(10, 12)); + int birthDay = Integer.parseInt(idCard.substring(12, 14)); + + LocalDate birthDate = LocalDate.of(birthYear, birthMonth, birthDay); + LocalDate currentDate = LocalDate.now(); + long age = ChronoUnit.YEARS.between(birthDate, currentDate); + 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 = 0; + if (matcher.matches()) { + int genderCode = Integer.parseInt(idCard.substring(16, 17)); // 浠庣17浣嶅紑濮嬫彁鍙栨�у埆缂栫爜锛堝鏁颁负鐢锋�э紝鍋舵暟涓哄コ鎬э級 + if ((genderCode % 2 == 1) ) { + sex = 0; + } else { + sex = 1; + } + } else { + sex = -1; + } + return sex; + } + /** * 鐘舵�� 0宸蹭繚瀛樸��1寰呭鏍搞��2瀹℃牳閫氳繃銆�3閫�鍥炰慨鏀广��4瀹℃牳椹冲洖銆�5寰呮湇鍔℃満鏋勭‘璁ゃ��6鏈嶅姟鏈烘瀯鎷掔粷銆�7宸插垎閰嶆湇鍔℃満鏋勩��8璇婃柇涓� * 锛堟垚鍔熶笂浼犵涓�浠芥湇鍔¤祫鏂欙級銆�9鏈嶅姟瀹屾垚銆�10宸插垎閰嶈瘎鍒嗕笓瀹躲��11宸插畬鎴愶紙涓撳涓婁紶璇勫垎锛� 12閫�鍥炰慨鏀逛腑 13 宸插畬鎴愰��鍥炰慨鏀� @@ -367,7 +434,10 @@ BD_APPLY_PDF(8, "淇濆崟鐢宠琛≒DF ", "淇濆崟鐢宠琛≒DF "), BD_SIGNED_PDF(9, "绛剧讲鍚庝繚鍗曠敵璇疯〃PDF", "绛剧讲鍚庝繚鍗曠敵璇疯〃PDF"), COM_SING_IMG(10, "浼佷笟鍗扮珷", "浼佷笟鍗扮珷"), - BD_DONE_PDF(10, "鏈�缁堟姤鍗�", "鏈�缁堟姤鍗�"), + BD_DONE_PDF(11, "鏈�缁堟姤鍗�", "鏈�缁堟姤鍗�"), + CA_PD_PDF(12, "鏈�缁堟姤鍗�", "鏈�缁堟姤鍗�"), + CA_APPLY_JIAJIAN_SIGN(13, "鍔犲噺淇濈敵璇风绔犳枃浠�", "鍔犲噺淇濈敵璇风绔犳枃浠�"), + CA_APPLY_CHANGEUNIT_SIGN(14, "鎹㈠巶鐢宠绛剧珷鏂囦欢", "鎹㈠巶鐢宠绛剧珷鏂囦欢"), ; @@ -487,7 +557,7 @@ public static void main(String[] args) { - System.out.println("hello&&devicenumber=22110002&&uuid=1e52008fb8ff\n".length()); + System.out.println("{\"companyName\":\"搴斿疂绉戞妧\",\"endtime\":\"2024-03-01 17:19:00\",\"erpId\":\"4D40185D5BC74A13821BE46EAF8B4179\",\"erpWithVisitDTOList\":[],\"faceImg\":\"20240304/1709518170325_742.jpg\",\"idcardNo\":\"342501199609300535\",\"idcardType\":0,\"name\":\"榛勬檵\",\"phone\":\"17756328697\",\"reason\":\"鎺㈤櫓\",\"receptMemberId\":\"E7E514BD7DE3F27CE0530B630A0AEAE0\",\"starttime\":\"2024-03-01 13:18:00\"}"); } /** * 鐢ㄦ埛绫诲瀷 0绯荤粺鐢ㄦ埛 1浼佷笟鐢ㄦ埛 2鏈嶅姟鏈烘瀯绠$悊鍛� 3鏈嶅姟鏈烘瀯瀛愯处鍙� 4缁煎悎鏈嶅姟鍗曚綅绠$悊鍛� 5缁煎悎鏈嶅姟鍗曚綅瀛愯处鍙� 6涓撳 7鍘垮尯鐢ㄦ埛 8甯傚眬鐢ㄦ埛 @@ -618,31 +688,99 @@ } + public enum ApplyCollectStatus { + DSP(0, "寰呭鎵�"), + DCD(1, "寰呭嚭鍗�"), + BZZ(2, "淇濋殰涓�"), + YGQ(3, "宸茶繃鏈�"), + YTH(4, "宸查��鍥�"), + THSQZ(5, "鐢宠閫�鍥�"), + YGB(6, "宸插叧闂�"), + DQYQZ(7, "寰呯缃�"), + ; + // 鎴愬憳鍙橀噺 + private String name; + private int key; + + // 鏋勯�犳柟娉� + ApplyCollectStatus(int key, String name) { + this.name = name; + this.key = key; + } + + // 鏅�氭柟娉� + public static String getName(int index) { + for (ApplyCollectStatus c : ApplyCollectStatus.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 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, "鎶曚繚瀹℃牳閫氳繃",""), + 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, "鎶曚繚瀹℃牳閫氳繃","鎻愪氦鎰忚锛�${param}",0), + UPLOAD_AGAIN(26, "鍐嶆鎶曚繚","",0), + PALTFORM_EDIT_BD(22, "淇敼淇濆崟","淇敼鍘熷洜锛�${param}",0), + + + 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, "鎻愪氦鎶曚繚","",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), + 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; } // 鏅�氭柟娉� @@ -662,6 +800,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() { @@ -686,31 +834,45 @@ public void setInfo(String info) { this.info = info; + } + + + public int getType() { + return type; + } + + public void setType(int type) { + this.type = type; } } public enum InsuranceApplyStatus { - UPLOAD(0, "鎻愪氦鎶曚繚",""), - PLATFORM_RETURN(1, "瀹℃牳涓嶉�氳繃","鎻愪氦鎰忚锛�${param}"), - WAIT_SIGNATURE(2, "宸蹭笂浼犱唬绛剧敵璇疯〃寰呬紒涓氱绔�",""), - SIGNATURE(3, "宸茬绔犲緟涓婁紶淇濋櫓鍗�",""), - FAIL_RETURN(4, "淇濆崟鍑哄叿澶辫触閫�鍥�",""), - UPLOAD_INSURANCE(5, "淇濆崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param}鍙樻洿涓�${param1}"), - COMPANY_APPLY_RETURN(6, "浼佷笟鐢宠閫�鍥�(涓嶅彲椹冲洖)","鎻愪氦鎰忚锛�${param}"), - COMPANY_APPLY_RETURN_SELECT(7, "浼佷笟鐢宠閫�鍥�(鍙┏鍥�)","鎻愪氦鎰忚锛�${param}"), - CLOSE(8, "璁㈠崟鍏抽棴",""), - PLATFORM_CHECK_PASS(9,"骞冲彴鎶曚繚瀹℃牳閫氳繃",""), + UPLOAD(0, "鎻愪氦鎶曚繚","",0), + PLATFORM_RETURN(1, "瀹℃牳涓嶉�氳繃","鎻愪氦鎰忚锛�${param}",4), + WAIT_SIGNATURE(2, "宸蹭笂浼犱唬绛剧敵璇疯〃寰呬紒涓氱绔�","",7), + SIGNATURE(3, "宸茬绔犲緟涓婁紶淇濋櫓鍗�","",1), + FAIL_RETURN(4, "淇濆崟鍑哄叿澶辫触閫�鍥�","",4), + UPLOAD_INSURANCE(5, "淇濆崟瀹屾垚","淇濋櫓鐢熸晥璧锋湡锛�${param}鍙樻洿涓�${param1}",2), + COMPANY_BACK_APPLY_UPLOAD(6, "浼佷笟鐢宠閫�鍥�(鎻愪氦鎶曚繚)","鎻愪氦鎰忚锛�${param}",5), + COMPANY_BACK_APPLY_WAIT_SIGNATURE(7, "浼佷笟鐢宠閫�鍥�(寰呯绔�)","鎻愪氦鎰忚锛�${param}",5), + COMPANY_BACK_APPLY_SIGNATURE(8, "浼佷笟鐢宠閫�鍥�(宸茬绔�)","鎻愪氦鎰忚锛�${param}",5), + CLOSE(9, "璁㈠崟鍏抽棴","",6), + PLATFORM_CHECK_PASS(10,"骞冲彴鎶曚繚瀹℃牳閫氳繃","鎻愪氦鎰忚锛�${param}",0), + COMPANY_BACK_APPLY_PASS(11, "浼佷笟鐢宠閫�鍥�(骞冲彴鎶曚繚瀹℃牳閫氳繃)","鎻愪氦鎰忚锛�${param}",5), ; // 鎴愬憳鍙橀噺 private String name; private String info; private int key; + private int collectStatus; + // 鏋勯�犳柟娉� - InsuranceApplyStatus(int key, String name,String info) { + InsuranceApplyStatus(int key, String name,String info,int collectStatus) { this.name = name; this.key = key; this.info = info; + this.collectStatus = collectStatus; } // 鏅�氭柟娉� @@ -718,6 +880,25 @@ for (InsuranceApplyStatus c : InsuranceApplyStatus.values()) { if (c.getKey() == index) { return c.name; + } + } + return null; + } + public static List<Integer> getKesByStatus(Integer collectStatus) { + List<Integer> list = new ArrayList<>(); + if(collectStatus!=null){ + for (InsuranceApplyStatus c : InsuranceApplyStatus.values()) { + if (Constants.equalsInteger(c.getCollectStatus() ,collectStatus)) { + list.add(c.getKey()); + } + } + } + return list; + } + public static Integer getCollectStatus(Integer index) { + for (InsuranceApplyStatus c : InsuranceApplyStatus.values()) { + if (Constants.equalsInteger(c.getKey() , index)) { + return c.collectStatus; } } return null; @@ -755,7 +936,191 @@ public void setInfo(String info) { this.info = info; } + + public int getCollectStatus() { + return collectStatus; + } + + public void setCollectStatus(int collectStatus) { + this.collectStatus = collectStatus; + } } + + + 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, "鐢宠椹冲洖","鐢宠椹冲洖","鐢宠椹冲洖","","",""), + SIX(6, "","","","","","") + ; + + // 鎴愬憳鍙橀噺 + 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){ //鏌ヨ淇濋櫓瀹為檯鍛ㄦ湡 @@ -766,16 +1131,26 @@ return solutions.getPrice().multiply(new BigDecimal(cycle)); } + public static BigDecimal countDetailFee(int timeUnit ,BigDecimal price,Date startDate, Date endDate){ + //鏌ヨ淇濋櫓瀹為檯鍛ㄦ湡 + Integer cycle = DateUtil.calculateBetween(endDate,startDate,timeUnit); + if(cycle==-1){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鏃ユ湡淇℃伅閿欒!"); + } + return Constants.formatBigdecimal(price).multiply(new BigDecimal(cycle)); + } + public enum ApplyChangeStatus { UPLOAD(0, "鎻愪氦鍔犲噺淇�/鎹㈠巶鐢宠"), SIGNATURE(1, "宸茬绔�"), - APPROVE(2, "宸蹭笂浼犲鎵�"), - RETURN_APPLY(3, "鍙戣捣閫�鍥炵敵璇�"), - PLATFORM_AGREE(4, "骞冲彴鍚屾剰锛堝凡閫�鍥烇級"), - CLOSE(5, "宸插叧闂�"), - PALTFORM_CHECK_PASS(6, "瀹℃牳涓嶉�氳繃"), - PALTFORM_CHECK_PASS_NO(7, "瀹℃牳閫氳繃"), + APPROVE(2, "宸蹭笂浼犲鏍�"), + RETURN_APPLY_UPLOAD(3, "鍙戣捣閫�鍥炵敵璇�(寰呭鏍�)"), + RETURN_APPLY_SIGNATURE(4, "鍙戣捣閫�鍥炵敵璇凤紙宸茬绔狅級"), + PLATFORM_AGREE(5, "骞冲彴鍚屾剰锛堝凡閫�鍥烇級"), + CLOSE(6, "宸插叧闂�"), + PALTFORM_CHECK_PASS(7, "瀹℃牳閫氳繃"), + PALTFORM_CHECK_PASS_NO(8, "瀹℃牳涓嶉�氳繃"), ; // 鎴愬憳鍙橀噺 private String name; @@ -821,8 +1196,9 @@ public enum SettleClaimsStatus { WAIT_ACCEPTANCE(0, "寰呭彈鐞�"), RETURN_ACCEPTANCE(1, "閫�鍥炲彈鐞�"), - CONFIRM_INFORMATION(2, "纭璧勬枡"), - FINISH_ACCEPTANCE(3, "瀹屾垚鍙楃悊"), + DEAL_ING(2, "鍙楃悊涓�"), + CONFIRM_INFORMATION(3, "纭璧勬枡"), + FINISH_ACCEPTANCE(4, "瀹屾垚鍙楃悊"), ; // 鎴愬憳鍙橀噺 private String name; @@ -865,15 +1241,15 @@ public enum SettleClaimsLogType { UPLOAD(0, "鎻愪氦鎶ユ","鎻愪氦鎰忚锛�${param}"), PLATFORM_RETURN(1, "骞冲彴閫�鍥�","鎻愪氦鎰忚锛�${param}"), - CONFIRM_INFORMATION(2, "骞冲彴纭璧勬枡","鎻愪氦鎰忚锛�${param}"), - PLATFORM_FINISH(3, "骞冲彴瀹屾垚鍙楃悊","鎻愪氦鎰忚锛�${param}"), + PLATFORM_CONFIRM_INFORMATION(2, "骞冲彴纭璧勬枡",""), + PLATFORM_FINISH(3, "缁撴鎻愪氦","鎻愪氦鎰忚锛�${param}"), UPDATE_DATA(4, "淇敼淇℃伅","鎻愪氦鎰忚锛�${param}"), SUPPLEMENT(5, "琛ュ厖璇存槑","鎻愪氦鎰忚锛�${param}"), - COMPANY_APPLY_RETURN(6, "骞冲彴鐞嗚禂澶勭悊","鎻愪氦鎰忚锛�${param}"), - COMPANY_APPLY_CLOSE(7, "骞冲彴澶囨敞鏍囩",""), - PLATFORM_AGREE_BACK(8, "骞冲彴娣诲姞鎶ユ鍙�",""), + PLATFORM_LP_DEAL(6, "骞冲彴鐞嗚禂澶勭悊","鎻愪氦鎰忚锛�${param}"), + PLATFORM_REMARK(7, "骞冲彴澶囨敞鏍囩","${param}"), + PLATFORM_ADDCODE(8, "骞冲彴娣诲姞鎶ユ鍙�","澶囨鍙凤細${param}"), PLATFORM_UN_AGREE_BACK(9, "浼佷笟涓嬭浇璧勬枡",""), - COMPANY_EDIT(10, "骞冲彴涓嬭浇璧勬枡",""), + PLATFORM_DOWNLOAD(10, "骞冲彴涓嬭浇璧勬枡",""), PLATFORM_CHECK_PASS(11, "骞冲彴涓婁紶璧勬枡",""), ; // 鎴愬憳鍙橀噺 @@ -935,29 +1311,38 @@ -//3=閫�鍥炵敵璇凤紱4=骞冲彴瀹℃壒閫氳繃锛�0=瀹℃壒椹冲洖;5=骞冲彴瀹℃壒椹冲洖 public enum ApplyChangeLogStatus { - UPLOAD(0, "鍙戣捣鐢宠"), - RETURN_APPLY(3, "鍙戣捣閫�鍥炵敵璇�"), - PLATFORM_AGREE(4, "骞冲彴瀹℃壒閫氳繃"), - PLATFORM_UN_AGREE(0, "瀹℃壒椹冲洖"), - CLOSE(5, "鍏抽棴"), + UPLOAD(0, "鍙戣捣鐢宠",""), + RETURN_APPLY(3, "鍙戣捣閫�鍥炵敵璇�","鎻愪氦鎰忚锛�${param}"), + PLATFORM_AGREE(4, "骞冲彴瀹℃牳閫氳繃" ,"鎻愪氦鎰忚锛�${param}"), + PLATFORM_UN_AGREE(0, "瀹℃牳椹冲洖","鎻愪氦鎰忚锛�${param}"), + CLOSE(5, "鍏抽棴",""), ; // 鎴愬憳鍙橀噺 private String name; + private String info; private int key; // 鏋勯�犳柟娉� - ApplyChangeLogStatus(int key, String name) { + ApplyChangeLogStatus(int key, String name,String info) { this.name = name; + this.info = info; this.key = key; } // 鏅�氭柟娉� public static String getName(int index) { - for (ApplyLogType c : ApplyLogType.values()) { + for (ApplyChangeLogStatus c : ApplyChangeLogStatus.values()) { if (c.getKey() == index) { return c.name; + } + } + return null; + } + public static String getInfo(int index) { + for (ApplyChangeLogStatus c : ApplyChangeLogStatus.values()) { + if (c.getKey() == index) { + return c.info; } } return null; @@ -980,7 +1365,17 @@ this.key = key; } + public String getInfo() { + return info; + } + + public void setInfo(String info) { + this.info = info; + } + } + + public enum ProjectRecord { @@ -1184,4 +1579,61 @@ this.des = des; } } + + public static File getFileByNetFile(String url,String fileName) { + //瀵规湰鍦版枃浠跺懡鍚� + File file = null; + try { + URL urlfile; + InputStream inStream = null; + OutputStream os = null; + try { + String tempDir = System.getProperty("java.io.tmpdir")+fileName; + file = new File(tempDir); + //涓嬭浇 + urlfile = new URL(url); + inStream = urlfile.openStream(); + os = new FileOutputStream(file); + int bytesRead = 0; + byte[] buffer = new byte[8192]; + while ((bytesRead = inStream.read(buffer, 0, 8192)) != -1) { + os.write(buffer, 0, bytesRead); + } + } catch (Exception e) { + e.printStackTrace(); + } finally { + try { + if (null != os) { + os.close(); + } + if (null != inStream) { + inStream.close(); + } + } catch (Exception e) { + e.printStackTrace(); + } + } + }catch (Exception e){ + + } + + return file; + } + public static void packFilesToZip(List<File> files, ServletOutputStream os) throws IOException { + try (ZipArchiveOutputStream zipOutputStream = new ZipArchiveOutputStream(os)) { + for (File file : files) { + ZipArchiveEntry entry = new ZipArchiveEntry(file.getName()); + zipOutputStream.putArchiveEntry(entry); + try (FileInputStream fileInputStream = new FileInputStream(file)) { + byte[] buffer = new byte[1024]; + int length; + while ((length = fileInputStream.read(buffer)) > 0) { + zipOutputStream.write(buffer, 0, length); + } + } + zipOutputStream.closeArchiveEntry(); + file.delete(); + } + } + } } -- Gitblit v1.9.3