From caf2599a9869244ded811018811c37a2aabac3fc Mon Sep 17 00:00:00 2001 From: vince <757871790@qq.com> Date: 星期三, 08 一月 2025 11:29:05 +0800 Subject: [PATCH] 优化测温协议 --- src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java | 97 ++++++++++++++++++++++++++++++++---------------- 1 files changed, 65 insertions(+), 32 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 c1eed03..1335dd4 100644 --- a/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java +++ b/src/main/java/com/fzzy/async/fzzy40/impl/Fzzy40Sync1202.java @@ -7,18 +7,24 @@ import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; +import com.fzzy.api.utils.DateUtil; import com.fzzy.api.view.repository.Api1202Rep; 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; import org.apache.commons.lang.time.DateFormatUtils; +import org.apache.commons.lang.time.DateUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; +import java.text.ParseException; +import java.text.SimpleDateFormat; import java.util.*; /** @@ -35,6 +41,8 @@ @Autowired private Fzzy40Sync1202Rep fzzySync1202Rep; + @Autowired + private Fzzy40SyncInoutRecordItemRep fzzy40SyncInoutRecordItemRep; @Autowired private Fzzy40SyncNoticeInRep fzzySyncNoticeInRep; @Autowired @@ -77,11 +85,11 @@ Api1105 api1105; List<Fz40InoutNoticeIn> listInoutNotice; List<Api1202> api1202List; - Calendar c = Calendar.getInstance(); - String ywsj = ""; - String num = ""; - Map<String, Integer> map = new HashMap<>(); + List<Fz40InoutRecordItem> listInoutRecordItem; for (Fz40InoutRecord sysData : list) { + if(sysData.getRecordStatus().equals("DEL") || sysData.getRecordStatus().equals("ERROR")){ + continue; + } if(null == sysData.getRecordWeight() || sysData.getRecordWeight() == 0){ sysData.setRecordWeight(sysData.getSettleWeight()); } @@ -97,34 +105,27 @@ apiData = new Api1202(); apiData.setRkywdh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4)); - //鍒ゆ柇涓氬姟鏃堕棿涓庡崟鎹彿鏄惁鍖归厤 - ywsj = DateFormatUtils.format(sysData.getCompleteTime(),"yyMMdd"); - if(!ywsj.equals(sysData.getId().substring(4, 10))){ - if(null == map.get(ywsj)){ - map.put(ywsj, 10201); - } - num = String.valueOf(map.get(ywsj)).substring(1); - apiData.setRkywdh(Constant.INOUT_TYPE_14 + ywsj + num); - map.put(ywsj, map.get(ywsj) + 1); - } //璐т綅浠g爜 apiData.setHwdm(api1105.getHwdm()); apiData.setYwlx(Constant.INOUT_TYPE_2); - apiData.setYwrq(sysData.getRegisterTime()); + apiData.setYwrq(DateUtils.parseDate(sysData.getId().substring(2, 10), new String[] { "yyyyMMdd" })); apiData.setCyr(sysData.getUserName()); //榛樿涓�涓殢渚垮�� - apiData.setLxdh(StringUtils.isEmpty(sysData.getUserContact()) ? "13012345678" : sysData.getUserContact()); + apiData.setLxdh(StringUtils.isEmpty(sysData.getUserContact()) ? "13012345678" : sysData.getUserContact().trim()); apiData.setSfzh(null == sysData.getUserId() ? "410183200010100000" : sysData.getUserId().trim()); //鑾峰彇鍚堝悓鍙� 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(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()); @@ -133,13 +134,12 @@ apiData.setYsgj(StringUtils.isEmpty(sysData.getTransType()) ? "1":sysData.getTransType()); //杞﹁埞鍙� - apiData.setCch(sysData.getPlateNum()); - c.setTime(sysData.getRegisterTime()); - c.add(Calendar.MINUTE,-3); - apiData.setDjsj(c.getTime()); + apiData.setCch(sysData.getPlateNum().trim()); + + apiData.setDjsj(sysData.getRegisterTime()); //绮鍝佺 - String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); + String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety().substring(0,3)); apiData.setLspzdm(mappingCode); //绮鎬ц川 @@ -149,14 +149,20 @@ 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()); @@ -165,6 +171,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()); @@ -178,12 +187,13 @@ apiData.setXckl( 0 - sysData.getDeHandle()); apiData.setJz(sysData.getRecordWeight()); - c.setTime(sysData.getCompleteTime()); - c.add(Calendar.MINUTE,3); - apiData.setCmsj(c.getTime()); + if(!sysData.getCompleteTime().after(sysData.getEmptyWeightTime())){ + sysData.setCompleteTime(DateUtils.addMinutes(sysData.getEmptyWeightTime(), 10)); + } + apiData.setCmsj(sysData.getCompleteTime()); //鎿嶄綔鏍囧織鍙婃渶鍚庢洿鏂版椂闂� - apiData.setZhgxsj(c.getTime()); + apiData.setZhgxsj(sysData.getUpdateTime()); //涓氬姟id銆佸簱鍖虹紪鐮併�佸悓姝ユ椂闂� apiData.setBizId(sysData.getId()); @@ -195,9 +205,32 @@ }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