From 9075639de65743f310d63a65700ce9a3b79247fe Mon Sep 17 00:00:00 2001
From: CZT <czt18638530771@163.com>
Date: 星期二, 07 十一月 2023 10:52:34 +0800
Subject: [PATCH] 调整品种信息

---
 src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java |   99 +++++++++++++++++++++++++++++++++++--------------
 1 files changed, 71 insertions(+), 28 deletions(-)

diff --git a/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java b/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java
index fb5fbdc..be70db2 100644
--- a/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java
+++ b/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java
@@ -12,7 +12,9 @@
 import com.fzzy.api.view.repository.ApiLogRep;
 import com.fzzy.async.fzzy40.entity.Fz40InoutNoticeIn;
 import com.fzzy.async.fzzy40.entity.Fz40InoutRecord;
+import com.fzzy.async.fzzy40.entity.Fz40InoutRecordItem;
 import com.fzzy.async.fzzy40.repository.Fzzy40Sync1202Rep;
+import com.fzzy.async.fzzy40.repository.Fzzy40SyncInoutRecordItemRep;
 import com.fzzy.async.fzzy40.repository.Fzzy40SyncNoticeInRep;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang.StringUtils;
@@ -21,6 +23,7 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
+import java.text.ParseException;
 import java.text.SimpleDateFormat;
 import java.util.*;
 
@@ -38,6 +41,8 @@
 
     @Autowired
     private Fzzy40Sync1202Rep fzzySync1202Rep;
+    @Autowired
+    private Fzzy40SyncInoutRecordItemRep fzzy40SyncInoutRecordItemRep;
     @Autowired
     private Fzzy40SyncNoticeInRep fzzySyncNoticeInRep;
     @Autowired
@@ -80,12 +85,16 @@
             Api1105 api1105;
             List<Fz40InoutNoticeIn> listInoutNotice;
             List<Api1202> api1202List;
+            List<Fz40InoutRecordItem> listInoutRecordItem;
             for (Fz40InoutRecord sysData : list) {
-                if(null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0){
+                if (sysData.getRecordStatus().equals("DEL") || sysData.getRecordStatus().equals("ERROR")) {
+                    continue;
+                }
+                if (null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0) {
                     sysData.setRecordWeight(sysData.getSettleWeight());
                 }
                 //鍒ゆ柇鍑�閲嶆槸鍚﹀ぇ浜�0锛岀瓑浜�0琛ㄧず涓嶅悎鏍硷紝涓嶈繘琛屽悓姝ヤ笂浼�
-                if(null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0){
+                if (null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0) {
                     continue;
                 }
                 //鑾峰彇璐т綅淇℃伅
@@ -97,20 +106,10 @@
 
                 apiData.setRkywdh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4));
 
-                //鍒ゆ柇涓氬姟鏃堕棿涓庡崟鎹彿鏄惁鍖归厤锛岃嫢涓嶅尮閰嶏紝鍒欐洿鏀逛笟鍔℃椂闂翠负鍗曟嵁鍙锋墍鍦ㄧ殑鏃堕棿
-                SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd");
-                Date time = dateFormat.parse(sysData.getId().substring(2, 10));
-                int numDay = DateUtil.difDay(sysData.getCompleteTime(), time);
-                if(numDay != 0){
-                    sysData.setFullWeightTime(DateUtils.addDays(sysData.getFullWeightTime(), numDay));
-                    sysData.setEmptyWeightTime(DateUtils.addDays(sysData.getEmptyWeightTime(), numDay));
-                    sysData.setCompleteTime(DateUtils.addDays(sysData.getCompleteTime(), numDay));
-                }
-
                 //璐т綅浠g爜
                 apiData.setHwdm(api1105.getHwdm());
                 apiData.setYwlx(Constant.INOUT_TYPE_2);
-                apiData.setYwrq(sysData.getCompleteTime());
+                apiData.setYwrq(DateUtils.parseDate(sysData.getId().substring(2, 10), new String[]{"yyyyMMdd"}));
                 apiData.setCyr(sysData.getUserName());
 
                 //榛樿涓�涓殢渚垮��
@@ -120,16 +119,19 @@
 
                 //鑾峰彇鍚堝悓鍙�
                 listInoutNotice = fzzySyncNoticeInRep.listInoutNoticeInById(sysData.getNoticeId());
-                if(null != listInoutNotice && listInoutNotice.size() >0){
-                    apiData.setHth(api1105.getHwdm().substring(0,18) + listInoutNotice.get(0).getContractId());
-                }else {
-                    apiData.setHth(api1105.getHwdm().substring(0,18) + apiData.getRkywdh());
+                if (null != listInoutNotice && listInoutNotice.size() > 0) {
+                    if (StringUtils.isNotEmpty(listInoutNotice.get(0).getContractId())) {
+                        apiData.setHth(api1105.getHwdm().substring(0, 18) + listInoutNotice.get(0).getContractId());
+                    }
+                    if (StringUtils.isNotEmpty(listInoutNotice.get(0).getPlanId())) {
+                        apiData.setJhmxh(listInoutNotice.get(0).getPlanId());
+                    }
                 }
 
-                apiData.setXxdz(StringUtils.isEmpty(sysData.getUserAddress()) ? "璇︾粏鍦板潃":sysData.getUserAddress());
+                apiData.setXxdz(StringUtils.isEmpty(sysData.getUserAddress()) ? "璇︾粏鍦板潃" : sysData.getUserAddress());
 
                 //杩愯緭宸ュ叿锛岃嫢涓虹┖锛屽垯榛樿缁�1-姹借溅
-                apiData.setYsgj(StringUtils.isEmpty(sysData.getTransType()) ? "1":sysData.getTransType());
+                apiData.setYsgj(StringUtils.isEmpty(sysData.getTransType()) ? "1" : sysData.getTransType());
 
                 //杞﹁埞鍙�
                 apiData.setCch(sysData.getPlateNum().trim());
@@ -138,23 +140,32 @@
 
                 //绮鍝佺
                 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety());
+                if(StringUtils.isEmpty(mappingCode)){
+                    mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety().substring(0, 3));
+                }
                 apiData.setLspzdm(mappingCode);
 
                 //绮鎬ц川
                 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, sysData.getFoodType());
                 apiData.setLsxzdm(mappingCode);
 
-                apiData.setShnd(StringUtils.isEmpty(sysData.getFoodYear())? DateFormatUtils.format(new Date(), "yyyy") :sysData.getFoodYear());
+                apiData.setShnd(StringUtils.isEmpty(sysData.getFoodYear()) ? DateFormatUtils.format(new Date(), "yyyy") : sysData.getFoodYear());
 
                 //浜у湴浠g爜
-                String cddm = commonService.getFoodLocationIdFromCache(sysData.getFoodLocation());
-                apiData.setCddm(cddm);
+                mappingCode = commonService.getFoodLocationIdFromCache(sysData.getFoodLocation());
+                if (StringUtils.isEmpty(mappingCode)) {
+                    mappingCode = apiData.getHwdm().substring(2, 8);
+                }
+                apiData.setCddm(mappingCode);
 
                 //妫�鏂ょ被鍨嬶紝榛樿0-绉伴噸鍏ュ簱
                 apiData.setJjlx("0");
 
                 //姣涢噸淇℃伅
                 apiData.setMz(sysData.getFullWeight());
+                if (!sysData.getFullWeightTime().after(sysData.getRegisterTime())) {
+                    sysData.setFullWeightTime(DateUtils.addMinutes(sysData.getRegisterTime(), 25));
+                }
                 apiData.setMzjlsj(sysData.getFullWeightTime());
                 apiData.setMzjby(sysData.getFullWeightUser());
                 apiData.setMzjly(sysData.getFullWeightUser());
@@ -163,6 +174,9 @@
 
                 //鐨噸淇℃伅
                 apiData.setPz(sysData.getEmptyWeight());
+                if (!sysData.getEmptyWeightTime().after(sysData.getFullWeightTime())) {
+                    sysData.setEmptyWeightTime(DateUtils.addMinutes(sysData.getFullWeightTime(), 60));
+                }
                 apiData.setPzjlsj(sysData.getEmptyWeightTime());
                 apiData.setPzjby(sysData.getEmptyWeightUser());
                 apiData.setPzjly(sysData.getEmptyWeightUser());
@@ -170,12 +184,18 @@
                 //鎵i噸 鍖栭獙鎬绘墸閲�
                 apiData.setZjklxj(sysData.getDeCheck());
 
+                apiData.setBzwkl(0 - sysData.getDePackage());
+                apiData.setBzbjs(sysData.getBzbjs());
+
                 //鍏跺畠
-                apiData.setQtkl( 0 - sysData.getDeOther());
+                apiData.setQtkl(0 - sysData.getDeOther());
                 //鍊间粨 鐜板満鎵i噸
-                apiData.setXckl( 0 - sysData.getDeHandle());
+                apiData.setXckl(0 - sysData.getDeHandle());
 
                 apiData.setJz(sysData.getRecordWeight());
+                if (!sysData.getCompleteTime().after(sysData.getEmptyWeightTime())) {
+                    sysData.setCompleteTime(DateUtils.addMinutes(sysData.getEmptyWeightTime(), 10));
+                }
                 apiData.setCmsj(sysData.getCompleteTime());
 
                 //鎿嶄綔鏍囧織鍙婃渶鍚庢洿鏂版椂闂�
@@ -186,14 +206,37 @@
                 apiData.setKqdm(kqdm);
                 apiData.setSyncTime(new Date());
                 api1202List = api1202Rep.getDataById(apiData.getRkywdh());
-                if(null == api1202List || api1202List.isEmpty()){
+                if (null == api1202List || api1202List.isEmpty()) {
                     apiData.setCzbz(Constant.CZBZ_I);
-                }else {
+                } else {
                     apiData.setCzbz(api1202List.get(0).getCzbz());
                 }
+                //鍒ゆ柇鏄惁涓鸿埞杩�
+                if (StringUtils.isNotEmpty(sysData.getTransType()) && sysData.getTransType().equals("3")) {
+                    listInoutRecordItem = fzzy40SyncInoutRecordItemRep.findDataByRecordId(sysData.getId());
+                    if (null == listInoutRecordItem || listInoutRecordItem.isEmpty()) {
+                        api1202Rep.save(apiData);
+                        continue;
+                    }
 
-                //淇濆瓨鏁版嵁
-                api1202Rep.save(apiData);
+                    int idNum = Integer.valueOf(sysData.getId().substring(12)) * 100 + 10001;
+                    for (Fz40InoutRecordItem fz40InoutRecordItem : listInoutRecordItem) {
+                        if (fz40InoutRecordItem.getSettleWeight() <= 0) {
+                            continue;
+                        }
+                        apiData.setRkywdh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4, 10) + String.valueOf(idNum).substring(1));
+                        apiData.setMz(fz40InoutRecordItem.getFullWeight());
+                        apiData.setPz(fz40InoutRecordItem.getEmptyWeight());
+                        apiData.setJz(fz40InoutRecordItem.getSettleWeight());
+
+                        api1202Rep.save(apiData);
+                        idNum++;
+                    }
+                } else {
+                    //淇濆瓨鏁版嵁
+                    api1202Rep.save(apiData);
+                }
+
                 log.info("1202---鍚屾鏁版嵁锛歿}", apiData.toString());
             }
         } catch (Exception e) {

--
Gitblit v1.9.3