From 61b40ca50044c8b20b6ea21028398e068ca103a0 Mon Sep 17 00:00:00 2001
From: jiazx0107@163.com <jiazx0107@163.com>
Date: 星期六, 12 八月 2023 16:16:14 +0800
Subject: [PATCH] 调整DEVICE的字段和缓存,增加支持根据ID直接获取设备信息,优化MODBUS-TCP协议 实现

---
 igds-inout/src/main/java/com/ld/igds/inout/manager/InoutReportManager.java |  212 +++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 159 insertions(+), 53 deletions(-)

diff --git a/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutReportManager.java b/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutReportManager.java
index 99927be..d04efe0 100644
--- a/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutReportManager.java
+++ b/igds-inout/src/main/java/com/ld/igds/inout/manager/InoutReportManager.java
@@ -4,13 +4,12 @@
 import com.ld.igds.check.dto.CheckItemData;
 import com.ld.igds.check.service.CoreCheckStandardService;
 import com.ld.igds.common.CoreCommonService;
+import com.ld.igds.common.bar.BarCodeUtils;
+import com.ld.igds.constant.FoodLevel;
 import com.ld.igds.constant.FoodVariety;
 import com.ld.igds.inout.InoutBill;
 import com.ld.igds.inout.InoutConstant;
-import com.ld.igds.inout.dto.InoutData;
-import com.ld.igds.inout.dto.InoutRecordItemData;
-import com.ld.igds.inout.dto.InoutRecordItemParam;
-import com.ld.igds.inout.dto.WeightBill;
+import com.ld.igds.inout.dto.*;
 import com.ld.igds.inout.service.InoutRecordItemService;
 import com.ld.igds.m.dto.NoticeDto;
 import com.ld.igds.m.service.HInoutNoticeService;
@@ -85,6 +84,14 @@
         if ("5322".equals(data.getCompanyId())) {
             htmlStr = InoutBill.IN_WEIGHT_5322;
         }
+        // 鐪夊北甯傚簱浣跨敤
+        if ("5005".equals(data.getCompanyId())) {
+            htmlStr = InoutBill.IN_WEIGHT_5005;
+        }
+        // 涓规1搴撲娇鐢�
+        if ("5012".equals(data.getCompanyId())) {
+            htmlStr = InoutBill.IN_WEIGHT_5012;
+        }
 
         htmlStr = htmlStr.replace("billTitle", bill.getBillTitle());
 
@@ -105,6 +112,7 @@
         htmlStr = htmlStr.replace("foodVariety", bill.getFoodVariety());
         htmlStr = htmlStr.replace("depotName", bill.getDepotName());
         htmlStr = htmlStr.replace("foodLocation", bill.getFoodLocation());
+
 
         htmlStr = htmlStr.replace("plateNum", bill.getPlateNum());
         htmlStr = htmlStr.replace("fullWeight",
@@ -136,8 +144,12 @@
         htmlStr = htmlStr.replace("remark", bill.getRemark());
         htmlStr = htmlStr.replace("moneyName", bill.getMoneyName());
 
-        htmlStr = htmlStr.replace("handleUser", bill.getHandleUser());
-
+        htmlStr = htmlStr.replaceAll("weightUser",
+                bill.getWeightUser() == null ? "" : bill.getWeightUser());
+        htmlStr = htmlStr.replaceAll("handleUser",
+                bill.getHandleUser() == null ? "" : bill.getHandleUser());
+        htmlStr = htmlStr.replaceAll("keeperName",
+                bill.getKeeperUser() == null ? "" : bill.getKeeperUser());
         return htmlStr;
     }
 
@@ -149,7 +161,7 @@
      */
     public String outWeightBill(InoutData data) {
         // 鑾峰彇琛ㄥ崟鏁版嵁
-        WeightBill bill = this.createBillData(data, "鍑哄簱绉伴噸鍗�");
+        WeightBill bill = this.createBillData(data, "鍑哄簱鍒掔爜鍗�");
 
         //榛樿妯$増
         String htmlStr = InoutBill.OUT_WEIGHT_DEFAULT;
@@ -183,7 +195,14 @@
         if ("5322".equals(data.getCompanyId())) {
             htmlStr = InoutBill.OUT_WEIGHT_5322;
         }
-
+        // 鐪夊北甯傚簱浣跨敤
+        if ("5005".equals(data.getCompanyId())) {
+            htmlStr = InoutBill.OUT_WEIGHT_5005;
+        }
+        // 涓规1搴撲娇鐢�
+        if ("5012".equals(data.getCompanyId())) {
+            htmlStr = InoutBill.OUT_WEIGHT_5012;
+        }
         htmlStr = htmlStr.replace("billTitle", bill.getBillTitle());
 
         htmlStr = htmlStr.replace("registerTime", bill.getRegisterTime());
@@ -191,7 +210,7 @@
         htmlStr = htmlStr.replace("fullTime", bill.getFullTime());
         htmlStr = htmlStr.replace("emptyTime", bill.getEmptyTime());
         htmlStr = htmlStr.replace("serId", bill.getSerId());
-        htmlStr = htmlStr.replace("specType", bill.getSpecType());
+//        htmlStr = htmlStr.replace("specType", bill.getSpecType());
 
         htmlStr = htmlStr.replace("customerName", bill.getCustomerName());
         htmlStr = htmlStr.replace("deptName", bill.getUnitName());
@@ -213,18 +232,24 @@
                 new DecimalFormat("0").format(bill.getNetWeight()));
 
         htmlStr = htmlStr.replace("remark", bill.getRemark());
-        htmlStr = htmlStr.replace("deWet", bill.getDeWet() + "");
+//        htmlStr = htmlStr.replace("deWet", bill.getDeWet() + "");
         htmlStr = htmlStr.replace("settleWeight",
                 new DecimalFormat("0").format(bill.getSettleWeight()));
-
+        htmlStr = htmlStr.replace("deHandle", bill.getDeHandle() + "");
         htmlStr = htmlStr.replace("handleUser", bill.getHandleUser());
         htmlStr = htmlStr.replace("deSum", bill.getDeSum() + "");
-
+        htmlStr = htmlStr.replace("deOther", bill.getDeOther() + "");
         htmlStr = htmlStr.replace("price", bill.getPrice());
         htmlStr = htmlStr.replace("settleMoney", bill.getSettleMoney() + "");
         htmlStr = htmlStr.replace("wet", bill.getWet() + "");
         htmlStr = htmlStr.replace("impurity", bill.getImpurity() + "");
 
+        htmlStr = htmlStr.replaceAll("weightUser",
+                bill.getWeightUser() == null ? "" : bill.getWeightUser());
+        htmlStr = htmlStr.replaceAll("handleUser",
+                bill.getHandleUser() == null ? "" : bill.getHandleUser());
+        htmlStr = htmlStr.replaceAll("keeperName",
+                bill.getKeeperUser() == null ? "" : bill.getKeeperUser());
         return htmlStr;
     }
 
@@ -267,7 +292,6 @@
         bill.setFullTime(DateFormatUtils.format(data.getFullWeightTime(),
                 "yyyy-MM-dd HH:mm:ss"));
         bill.setSerId(data.getId());
-//        bill.setSpecType(StringUtils.isEmpty(data.getSpecType()) ? "鏁g伯" : data.getSpecType());
         if ("5016".equals(data.getCompanyId())) {
             bill.setCompleteTime(DateFormatUtils.format(data.getCompleteTime(), "yyyy-MM-dd"));
             bill.setSerId(data.getId().substring(2));
@@ -275,7 +299,6 @@
         }
 
         //瀹㈡埛淇℃伅
-        // bill.setCustomerId(data.getCustomerId() == null ? "" : data.getCustomerId());
         bill.setCustomerName(data.getCustomerName() == null ? "" : data.getCustomerName());
         bill.setUserId(data.getUserId() == null ? "" : data.getUserId());
         bill.setUserAddress(data.getUserAddress() == null ? "" : data.getUserAddress());
@@ -311,19 +334,10 @@
         bill.setRecordWeight(data.getRecordWeight());
         bill.setCheckStatus(data.getCheckStatus().equals(InoutConstant.STATUS_PASS) ? "鍚堟牸" : "涓嶅悎鏍�");
 
-//        bill.setDeWet(data.getDeWet());
-//        bill.setDeImpurity(data.getDeImpurity());
         bill.setDeHandle(data.getDeHandle());
         bill.setDeOther(data.getDeOther());
-//        bill.setDeSum(data.getDeSum() == null ? 0.0 :data.getDeSum());
 
         bill.setSettleWeight(data.getSettleWeight());
-//        if(data.getWet() != null && data.getWet() > 0){
-//            bill.setWet(data.getWet() +"");
-//        }
-//        if(data.getImpurity() != null && data.getImpurity() > 0){
-//            bill.setImpurity(data.getImpurity()+"");
-//        }
 
         bill.setPrice(data.getPrice() == null ? "" : data.getPrice() + "");
         if (data.getSettleMoney() <= 0) {
@@ -334,6 +348,15 @@
         bill.setSettleMoney(data.getSettleMoney() == null ? "" : data.getSettleMoney() + "");
         bill.setRemark(data.getRemarks() == null ? "" : data.getRemarks());
 
+
+        if(InoutConstant.TYPE_IN.equals(data.getType())){
+            bill.setWeightUser(data.getFullWeightUser());
+        }
+        if(InoutConstant.TYPE_OUT.equals(data.getType())){
+            bill.setWeightUser(data.getEmptyWeightUser());
+        }
+        bill.setHandleUser(data.getHandleUser());
+        bill.setKeeperUser(depot.getStoreKeeperName());
         return bill;
     }
 
@@ -348,15 +371,26 @@
         // 鑾峰彇鍖栭獙鏁版嵁
         List<CheckItemData> checkLst = data.getCheckItems();
         if (null == checkLst)
-            checkStandardService.getCheckItemById(data.getCheckId(),
-                    data.getCompanyId());
+            checkStandardService.getCheckItemById(data.getCheckId(), data.getCompanyId());
 
         if (checkLst == null || checkLst.size() < 1) {
             return "鏃犲寲楠屾暟鎹紝涓嶆墦鍗帮紒";
         }
-
+        String mark = data.getFoodVariety().substring(0, 3);
         // 璋冩暣妯$増鏁版嵁骞惰繑鍥�
-        String htmlStr = InoutBill.IN_CHECK_DEFAULT;
+        String htmlStr = "";
+        if (FoodVariety.FOOD_VARIETY_WHEAT.equals(mark)) {
+            htmlStr = InoutBill.IN_CHECK_WHEAT;
+        } else if (FoodVariety.FOOD_VARIETY_PADDY.equals(mark)) {
+            htmlStr = InoutBill.IN_CHECK_PADDY;
+        } else if (FoodVariety.FOOD_VARIETY_CORN.equals(mark)) {
+            htmlStr = InoutBill.IN_CHECK_CORN;
+        } else if (FoodVariety.FOOD_VARIETY_SOYBEAN.equals(data.getFoodVariety())) {
+            htmlStr = InoutBill.IN_CHECK_SOYBEAN;
+        } else {
+            return "妯℃澘鏆傛湭纭畾锛侊紒";
+        }
+
 
         DefaultDept dept = sysDeptService.getCacheDept(data.getCompanyId(),
                 data.getDeptId());
@@ -365,18 +399,36 @@
                 (dept == null ? "鍏ュ簱鍖栭獙鍗�" : dept.getName() + "鍏ュ簱鍖栭獙鍗�"));
 
         // 鏇挎崲鍩虹鏁版嵁
-        String time = DateFormatUtils.format(data.getRegisterTime(),
-                "yyyy-MM-dd");
-        htmlStr = htmlStr.replace("time", time);
+//        String time = DateFormatUtils.format(data.getRegisterTime(),
+//                "yyyy-MM-dd");
+        String checkTime = data.getCheckTime() == null ? "-" : DateFormatUtils.format(data.getCheckTime(), "yyyy-MM-dd HH:mm:ss");
+        String sampleTime = data.getSampleTime() == null ? "-" : DateFormatUtils.format(data.getSampleTime(), "yyyy-MM-dd HH:mm:ss");
+        String reportTime = DateFormatUtils.format(new Date(), "yyyy-MM-dd HH:mm:ss");
+//        htmlStr = htmlStr.replace("time", time);
         htmlStr = htmlStr.replace("customerName", data.getCustomerName());
-        htmlStr = htmlStr.replace("serId", data.getId());
+        htmlStr = htmlStr.replace("serId", data.getId().substring(2));
+        htmlStr = htmlStr.replace("deptName", dept.getName());
         htmlStr = htmlStr.replace("foodVariety", FoodVariety.getMsg(data.getFoodVariety()));
         htmlStr = htmlStr.replace("plateNum", data.getPlateNum());
         htmlStr = htmlStr.replace("userName", data.getUserName());
-        htmlStr = htmlStr.replace("foodYear", data.getFoodYear() == null ? "/" : data.getFoodYear());
+        htmlStr = htmlStr.replace("foodYear", data.getFoodYear() == null ? "-" : data.getFoodYear());
         Depot depot = commonService.getCacheDepot(data.getCompanyId(), data.getDepotId());
-        htmlStr = htmlStr.replace("depotName", depot == null ? "/" : depot.getName());
-        htmlStr = htmlStr.replace("checkUser", data.getCheckUser() == null ? "/" : data.getCheckUser());
+        htmlStr = htmlStr.replace("storeKeeperName", depot == null ? "" : (depot.getStoreKeeperName() == null ? "" : depot.getStoreKeeperName()));
+        htmlStr = htmlStr.replace("depotName", depot == null ? "-" : depot.getName());
+        htmlStr = htmlStr.replace("checkUser", data.getCheckUser() == null ? "-" : data.getCheckUser());
+        htmlStr = htmlStr.replace("foodType", data.getFoodType() == null ? "-" : data.getFoodType());
+        htmlStr = htmlStr.replace("foodNumber", data.getSettleWeight() + "");
+        htmlStr = htmlStr.replace("checkNum", data.getDeCheck() + "");
+        htmlStr = htmlStr.replace("foodLocation", data.getFoodLocation() == null ? "-" : data.getFoodLocation());
+        htmlStr = htmlStr.replace("foodLevel", data.getFoodLevel() == null ? "-" : FoodLevel.getMsg(data.getFoodLevel()));
+        htmlStr = htmlStr.replace("hwmc", "");
+
+        htmlStr = htmlStr.replace("unit", "");
+        htmlStr = htmlStr.replace("sampleUser", data.getSampleUser() == null ? "-" : data.getSampleUser());
+        htmlStr = htmlStr.replace("checkTime", checkTime);
+        htmlStr = htmlStr.replace("sampleTime", sampleTime);
+        htmlStr = htmlStr.replace("bgcjsj", reportTime);
+        htmlStr = htmlStr.replace("remark", data.getRemarks() == null ? "鏃�" : data.getRemarks());
 
         Map<String, String> checkBillItems = getCheckBillItems();
         // 閬嶅巻鍖栭獙缁撴灉锛屽瓨鍏ap闆嗗悎涓�
@@ -384,7 +436,7 @@
         for (CheckItemData item : checkLst) {
             key = item.getStandardId() + "_ST";
             // checkBillItems.put(key, item.getStandardValue());
-            key = item.getStandardId() + "_VAL";
+//            key = item.getStandardId() + "_VAL";
             checkBillItems.put(key, item.getValue());
         }
 
@@ -409,44 +461,76 @@
      */
     private Map<String, String> getCheckBillItems() {
         Map<String, String> map = new HashMap<>();
-        map.put("C03_ST", "");
-        map.put("C03_VAL", "");
         map.put("C01_ST", "");
         map.put("C01_VAL", "");
         map.put("C02_ST", "");
         map.put("C02_VAL", "");
+        map.put("C03_ST", "");
+        map.put("C03_VAL", "");
+        map.put("C04_ST", "");
+        map.put("C04_VAL", "");
+        map.put("C05_ST", "");
+        map.put("C05_VAL", "");
+        map.put("C06_ST", "");
+        map.put("C06_VAL", "");
+        map.put("C07_ST", "");
+        map.put("C07_VAL", "");
+        map.put("C08_ST", "");
+        map.put("C08_VAL", "");
         map.put("C09_ST", "");
         map.put("C09_VAL", "");
+        map.put("C10_ST", "");
+        map.put("C10_VAL", "");
+        map.put("C11_ST", "");
+        map.put("C11_VAL", "");
+        map.put("C12_ST", "");
+        map.put("C12_VAL", "");
+        map.put("C13_ST", "");
+        map.put("C13_VAL", "");
+        map.put("C14_ST", "");
+        map.put("C14_VAL", "");
+        map.put("C15_ST", "");
+        map.put("C15_VAL", "");
+        map.put("C16_ST", "");
+        map.put("C16_VAL", "");
+        map.put("C17_ST", "");
+        map.put("C17_VAL", "");
+        map.put("C18_ST", "");
+        map.put("C18_VAL", "");
+        map.put("C19_ST", "");
+        map.put("C19_VAL", "");
+        map.put("C20_ST", "");
+        map.put("C20_VAL", "");
+        map.put("C21_ST", "");
+        map.put("C21_VAL", "");
         map.put("C22_ST", "");
         map.put("C22_VAL", "");
         map.put("C23_ST", "");
         map.put("C23_VAL", "");
-        map.put("C10_ST", "");
-        map.put("C10_VAL", "");
-        map.put("C04_ST", "");
-        map.put("C04_VAL", "");
         map.put("C24_ST", "");
         map.put("C24_VAL", "");
-        map.put("C08_ST", "");
-        map.put("C08_VAL", "");
-        map.put("C12_ST", "");
-        map.put("C12_VAL", "");
         map.put("C25_ST", "");
         map.put("C25_VAL", "");
-        map.put("C14_ST", "");
-        map.put("C14_VAL", "");
-        map.put("C29_ST", "");
-        map.put("C29_VAL", "");
-        map.put("C11_ST", "");
-        map.put("C11_VAL", "");
+        map.put("C26_ST", "");
+        map.put("C26_VAL", "");
         map.put("C27_ST", "");
         map.put("C27_VAL", "");
         map.put("C28_ST", "");
         map.put("C28_VAL", "");
+        map.put("C29_ST", "");
+        map.put("C29_VAL", "");
         map.put("C30_ST", "");
         map.put("C30_VAL", "");
         map.put("C31_ST", "");
         map.put("C31_VAL", "");
+        map.put("C32_ST", "");
+        map.put("C32_VAL", "");
+        map.put("C33_ST", "");
+        map.put("C33_VAL", "");
+        map.put("C34_ST", "");
+        map.put("C34_VAL", "");
+        map.put("C35_ST", "");
+        map.put("C35_VAL", "");
         return map;
     }
 
@@ -526,12 +610,12 @@
         }
 //        htmlStr = htmlStr.replace("driverName", settle.getUserName() + "");
 //        htmlStr = htmlStr.replace("otherSum", settle.getOtherSum() + "");
-        htmlStr = htmlStr.replace("paySum", settle.getPaySum() + "");
+        htmlStr = htmlStr.replace("paySum", settle.getPayMoney() + "");
 
         htmlStr = htmlStr.replace("remark", settle.getRemarks() == null ? ""
                 : settle.getRemarks());
         htmlStr = htmlStr.replace("moneyName",
-                MoneyUtil.formatToCN(new BigDecimal(settle.getPaySum())));
+                MoneyUtil.formatToCN(new BigDecimal(settle.getPayMoney())));
 
         return htmlStr;
     }
@@ -717,6 +801,26 @@
         return htmlStr;
     }
 
+    /**
+     * 鎵撳嵃鎵︽牱鍗曪紝鐩存帴杩斿洖鏉″舰鐮丅ase64鍥剧墖
+     *
+     * @param data
+     * @return
+     */
+    public String simpleBill(InoutCheckData data) {
+
+        if (null == data.getId()) return null;
+        if (null == data.getCheckId()) return null;
+
+        if (null == data.getCheckTime()) {
+            data.setCheckTime(new Date());
+        }
+
+        String imgBase64 = BarCodeUtils.getBarCodeImageBase64(data.getId(), data.getCheckId(), "绮鏍峰搧鍗曟潯鐮�", DateFormatUtils.format(data.getCheckTime(), "yyyy-MM-dd HH:mm"));
+
+        return imgBase64;
+    }
+
     public static void main(String[] args) {
         List<String> result = new ArrayList<>();
         result.add("1");
@@ -735,4 +839,6 @@
         List<String> strings3 = result.subList(6, 8);
         System.out.println(strings3);
     }
+
+
 }
\ No newline at end of file

--
Gitblit v1.9.3