From 6f01b51fc0770fda7787076caf0314be7a7f6656 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 27 六月 2025 10:58:21 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/ReportToThirdServiceImpl.java |  287 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 208 insertions(+), 79 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/ReportToThirdServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/ReportToThirdServiceImpl.java
index 5115f87..178a672 100644
--- a/src/main/java/com/zy/asrs/service/impl/ReportToThirdServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/ReportToThirdServiceImpl.java
@@ -3,19 +3,15 @@
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.exception.CoolException;
-import com.zy.asrs.entity.DocType;
-import com.zy.asrs.entity.Order;
-import com.zy.asrs.entity.OrderDetl;
-import com.zy.asrs.service.ApiLogService;
-import com.zy.asrs.service.OrderService;
-import com.zy.asrs.service.ReportToThirdService;
+import com.zy.asrs.entity.*;
+import com.zy.asrs.service.*;
 import com.zy.nc.SendUtil;
-import com.zy.nc.entity.NccCgCgdhdWms;
-import com.zy.nc.entity.NccSaleDbddWms;
-import com.zy.nc.entity.NccSaleXsfhmxWms;
-import com.zy.nc.entity.NccScZkmxbWms;
+import com.zy.nc.entity.*;
+import com.zy.nc.service.NccSaleXsfhmxWmsService;
+import com.zy.nc.service.NccScPcdaWmsService;
 import com.zy.nc.util.NcResultMessage;
 import com.zy.nc.vo.*;
 import lombok.extern.slf4j.Slf4j;
@@ -34,9 +30,23 @@
 
     @Autowired
     private ApiLogService apiLogService;
-
     @Autowired
     private OrderService orderService;
+    @Autowired
+    private WrkDetlService wrkDetlService;
+    @Autowired
+    private InventoryCheckOrderService inventoryCheckOrderService;
+    @Autowired
+    private InventoryCheckOrderDetlService inventoryCheckOrderDetlService;
+
+    @Autowired
+    private StoreTypeService storeTypeService;
+
+    @Autowired
+    private NccScPcdaWmsService nccScPcdaWmsService;
+
+    @Autowired
+    private NccSaleXsfhmxWmsService nccSaleXsfhmxWmsService;
 
     @Value("${NYNC.ip}")
     private String nyncIp;
@@ -49,6 +59,9 @@
 
     @Value("${NYNC.saveRefWhsTrans}")
     private String saveRefWhsTrans;
+
+    @Value("${NYNC.invcountAdd}")
+    private String invcountAdd;
 
     @Value("${NYNC.purchasein}")
     private String purchasein;
@@ -107,21 +120,23 @@
                     }
                     break;
                 case "閲囪喘鍒拌揣":
-                    process1 = processCGDH(orderDetls);
-                    List<Object> cg = new ArrayList<>();
-                    cg.add(process1);
-                    //鍙戦�佽姹�
-                    response = SendUtil.sendDataToNc(SendUtil.token, nyncIp + ":" + port, purchasein, JSONObject.toJSONString(cg));
-                    if (!Cools.isEmpty(response) && response.isSuccess()) {
-                        log.info("閲囪喘鍒拌揣response:{}", response);
-                        step = 10;
-                    } else {
-                        remark = response.getMessage() + "--" + response.getErrorStack().substring(0, 100);
-                    }
+                    //涓嶉渶瑕佷笂鎶ヤ簡
+                    step = 10;
+//                    process1 = processCGDH(orderDetls);
+//                    List<Object> cg = new ArrayList<>();
+//                    cg.add(process1);
+//                    //鍙戦�佽姹�
+//                    response = SendUtil.sendDataToNc(SendUtil.token, nyncIp + ":" + port, purchasein, JSONObject.toJSONString(cg));
+//                    if (!Cools.isEmpty(response) && response.isSuccess()) {
+//                        log.info("閲囪喘鍒拌揣response:{}", response);
+//                        step = 10;
+//                    } else {
+//                        remark = response.getMessage() + "--" + response.getErrorStack().substring(0, 100);
+//                    }
                     break;
                 case "杞簱-鍑哄簱":
                     if (step == 1) {
-                        process2 = processGENERALOUT2(orderDetls, memo);
+                        process2 = processGENERALOUT2(orderDetls, order.getOperMemb(), order.getItemId(), memo);
                         List<Object> zkck2 = new ArrayList<>();
                         zkck2.add(process2);
                         //鍙戦�佽姹�
@@ -143,7 +158,7 @@
                             log.info("杞簱-鍑哄簱1response:{}", response);
                             memo = response.getData().toString();
 
-                            process2 = processGENERALOUT2(orderDetls, memo);
+                            process2 = processGENERALOUT2(orderDetls, order.getOperMemb(), order.getItemId(), memo);
                             List<Object> zkck2 = new ArrayList<>();
                             zkck2.add(process2);
                             //鍙戦�佽姹�
@@ -191,22 +206,53 @@
 
     }
 
+    @Override
+    public boolean reportTkrk(String matnr, String batch, String orderNo, Double anfme) {
+        Object process1 = processTKRK(matnr, batch, orderNo, anfme);
+        //鍙戦�佽姹�
+        NcResultMessage response = SendUtil.sendDataToNc(SendUtil.token, nyncIp + ":" + port, saveRefDelivery, JSONObject.toJSONString(process1));
+        log.info("閫�搴撳叆搴搑esponse:{}", response);
+        if (!Cools.isEmpty(response) && response.isSuccess()) {
+            log.info("閫�搴撳叆搴搑esponse:{}", response);
+            return true;
+        } else {
+//            remark = response.getMessage() + "--" + response.getErrorStack().substring(0, 100);
+            return false;
+        }
+    }
+
+    @Override
+    public boolean reportCheckOrder(InventoryCheckOrder checkOrder) {
+        Object process1 = processInvcount(checkOrder);
+        //鍙戦�佽姹�
+        NcResultMessage response = SendUtil.sendDataToNc(SendUtil.token, nyncIp + ":" + port, invcountAdd, JSONObject.toJSONString(process1));
+        log.info("鐩樼偣鍗時esponse:{}", response);
+        if (!Cools.isEmpty(response) && response.isSuccess()) {
+            log.info("鐩樼偣鍗時esponse:{}", response);
+            return true;
+        } else {
+//            remark = response.getMessage() + "--" + response.getErrorStack().substring(0, 100);
+            return false;
+        }
+    }
 
     private Object processXSFH(List<OrderDetl> orderDetls, Boolean flag) {
         //缁勮瀵硅薄鏁版嵁
         Map<String, Object> data = new HashMap<String, Object>();
         SaleOutHeadVO saleOutHeadVO = new SaleOutHeadVO();
         saleOutHeadVO.setPk_org("FYT");
-        saleOutHeadVO.setCwarehouseid("6101");
         SaleOutBodyVO saleOutBodyVO = null;
         List<SaleOutBodyVO> saleOutBodyVOList = new ArrayList<>();
         for (OrderDetl orderDetl : orderDetls) {
+            if (orderDetl.getQty() <= 0) {
+                continue;
+            }
             saleOutBodyVO = new SaleOutBodyVO();
             String remark = orderDetl.getRemark();
             if (!Cools.isEmpty(remark)) {
                 NccSaleXsfhmxWms nccSaleXsfhmxWms = JSONObject.parseObject(remark, NccSaleXsfhmxWms.class);
                 saleOutBodyVO.setCsourcetype("4331");
-                saleOutBodyVO.setClocationid("610101");
+                //saleOutBodyVO.setClocationid("610101");
                 saleOutBodyVO.setCsourcebillbid(nccSaleXsfhmxWms.getCdeliverybid());
                 saleOutBodyVO.setCsourcebillhid(nccSaleXsfhmxWms.getCdeliveryid());
                 saleOutHeadVO.setVdef2(nccSaleXsfhmxWms.getVdef2());
@@ -217,9 +263,11 @@
                 saleOutHeadVO.setVdef13(nccSaleXsfhmxWms.getVdef13());
                 saleOutHeadVO.setVdef14(nccSaleXsfhmxWms.getVdef14());
             }
+            saleOutHeadVO.setCwarehouseid(orderDetl.getStandby1());
+
             saleOutBodyVO.setVbatchcode(orderDetl.getBatch());
-            saleOutBodyVO.setNshouldnum(flag ? -orderDetl.getAnfme() : orderDetl.getAnfme());
-            saleOutBodyVO.setNnum(orderDetl.getQty());
+            saleOutBodyVO.setNshouldnum(flag ? -orderDetl.getQty() : orderDetl.getQty());
+            saleOutBodyVO.setNnum(flag ? -orderDetl.getQty() : orderDetl.getQty());
             saleOutBodyVOList.add(saleOutBodyVO);
         }
         data.put("SaleOutHeadVO", saleOutHeadVO);
@@ -227,12 +275,95 @@
         return data;
     }
 
+    private Object processTKRK(String matnr,String batch, String orderNo, Double anfme) {
+//        EntityWrapper<NccXsckmxTkWms> wrapper = new EntityWrapper<>();
+//        wrapper.eq("VBATCHCODE", batch).eq("VSOURCEBILLCODE", orderNo);
+//        NccXsckmxTkWms nccXsckmxTkWms = nccXsckmxTkWmsService.selectOne(wrapper);
+//        if (null == nccXsckmxTkWms) {
+//            throw new CoolException("鏈壘鍒版鏉$爜");
+//        }
+
+        NccSaleXsfhmxWms nccSaleXsfhmxWms = nccSaleXsfhmxWmsService.selectOne(new EntityWrapper<NccSaleXsfhmxWms>()
+                .eq("VBILLCODE", orderNo)
+                .eq("WLBM", matnr)
+        );
+        if(null == nccSaleXsfhmxWms) {
+            throw new CoolException("鏈壘鍒伴攢鍞崟鎹�");
+        }
+
+        //缁勮瀵硅薄鏁版嵁
+        Map<String, Object> data = new HashMap<String, Object>();
+        SaleOutHeadVO saleOutHeadVO = new SaleOutHeadVO();
+        saleOutHeadVO.setPk_org("FYT");
+        SaleOutBodyVO saleOutBodyVO = null;
+        List<SaleOutBodyVO> saleOutBodyVOList = new ArrayList<>();
+
+        saleOutBodyVO = new SaleOutBodyVO();
+        saleOutBodyVO.setCsourcetype("4331");
+        saleOutBodyVO.setCsourcebillbid(nccSaleXsfhmxWms.getCdeliverybid());
+        saleOutBodyVO.setCsourcebillhid(nccSaleXsfhmxWms.getCdeliveryid());
+        saleOutHeadVO.setCwarehouseid(nccSaleXsfhmxWms.getFhckbm());
+
+        saleOutBodyVO.setVbatchcode(batch);
+        saleOutBodyVO.setNnum(anfme * -1);
+        saleOutBodyVOList.add(saleOutBodyVO);
+
+        data.put("SaleOutHeadVO", saleOutHeadVO);
+        data.put("SaleOutBodyVO", saleOutBodyVOList);
+        return data;
+    }
+
+    private Object processInvcount(InventoryCheckOrder checkOrder) {
+        List<InventoryCheckOrderDetl> inventoryCheckOrderDetls = inventoryCheckOrderDetlService.selectList(new EntityWrapper<InventoryCheckOrderDetl>()
+                .eq("order_no", checkOrder.getOrderNo()));
+        if (inventoryCheckOrderDetls.isEmpty()) {
+            throw new CoolException("鐩樼偣鏄庣粏涓嶅瓨鍦�");
+        }
+
+        //缁勮瀵硅薄鏁版嵁
+        Map<String, Object> data = new HashMap<String, Object>();
+
+        //浠撳簱id
+        String cwarehouseid = null;
+        List<InvCountBodyVO> invCountBodyVOList = new ArrayList<>();
+        for (InventoryCheckOrderDetl inventoryCheckOrderDetl : inventoryCheckOrderDetls) {
+            List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>()
+                    .eq("matnr", inventoryCheckOrderDetl.getMatnr())
+                    .eq("batch", inventoryCheckOrderDetl.getBatch())
+            );
+            if (wrkDetls.isEmpty()) {
+                throw new CoolException("宸ヤ綔妗f槑缁嗕笉瀛樺湪");
+            }
+
+            cwarehouseid = wrkDetls.get(0).getStandby1();
+
+            InvCountBodyVO invCountBodyVO = new InvCountBodyVO();
+            invCountBodyVO.setCmaterialoid(inventoryCheckOrderDetl.getMatnr());
+            invCountBodyVO.setVbatchcode(inventoryCheckOrderDetl.getBatch());
+            invCountBodyVO.setNcountastnum(inventoryCheckOrderDetl.getCheckAnfme());
+            invCountBodyVOList.add(invCountBodyVO);
+        }
+
+        InvCountHeaderVO invCountHeaderVO = new InvCountHeaderVO();
+        invCountHeaderVO.setPk_org("FYT");
+        invCountHeaderVO.setCtrantypeid("4R-01");
+        invCountHeaderVO.setCwarehouseid(cwarehouseid);
+
+        data.put("InvCountHeaderVO", invCountHeaderVO);
+        data.put("InvCountBodyVO", invCountBodyVOList);
+        data.put("paper", "2");
+        data.put("splr", "1");
+
+        ArrayList<Map<String, Object>> list = new ArrayList<>();
+        list.add(data);
+        return list;
+    }
+
     private Object processZKRK(List<OrderDetl> orderDetls) {
         //缁勮瀵硅薄鏁版嵁
         Map<String, Object> data = new HashMap<String, Object>();
         GeneralInHeadVO generalInHeadVO = new GeneralInHeadVO();
         generalInHeadVO.setPk_org("FYT");
-        generalInHeadVO.setCwarehouseid("6101");
         GeneralInBodyVO generalInBodyVO = null;
         List<GeneralInBodyVO> generalInBodyVOS = new ArrayList<>();
         for (OrderDetl orderDetl : orderDetls) {
@@ -246,7 +377,9 @@
                 generalInBodyVO.setNnum(orderDetl.getQty());
                 generalInBodyVO.setNshouldnum(orderDetl.getAnfme());
                 generalInBodyVO.setCsourcetype(nccScZkmxbWms.getZklxbm());
+
             }
+            generalInHeadVO.setCwarehouseid(orderDetl.getStandby1());
             generalInBodyVOS.add(generalInBodyVO);
         }
         data.put("GeneralInHeadVO", generalInHeadVO);
@@ -281,31 +414,7 @@
         return data;
     }
 
-    private Object processZKCK(Order order, List<OrderDetl> orderDetls) {
-        //缁勮瀵硅薄鏁版嵁
-        Map<String, Object> data = new HashMap<String, Object>();
-        WhsTransBillHeaderVO whsTransBillHeaderVO = new WhsTransBillHeaderVO();
-        whsTransBillHeaderVO.setPk_org("FYT");
-        whsTransBillHeaderVO.setCotherwhid(order.getItemId());
-        whsTransBillHeaderVO.setCtrantypeid("4K-01");
-        WhsTransBillBodyVO whsTransBillBodyVO = null;
-        List<WhsTransBillBodyVO> whsTransBillBodyVOS = new ArrayList<>();
-        for (OrderDetl orderDetl : orderDetls) {
-            whsTransBillBodyVO = new WhsTransBillBodyVO();
-            String remark = orderDetl.getRemark();
-            //if (!Cools.isEmpty(remark)) {
-            //NccSaleXsfhmxWms nccSaleXsfhmxWms = JSONObject.parseObject(remark, NccSaleXsfhmxWms.class);
-            whsTransBillBodyVO.setNnum(orderDetl.getQty());
-            whsTransBillBodyVO.setCmaterialoid(orderDetl.getMatnr());
-            whsTransBillBodyVO.setVbatchcode(orderDetl.getBatch());
-            //}
-            whsTransBillHeaderVO.setCwarehouseid(orderDetl.getStandby1());
-            whsTransBillBodyVOS.add(whsTransBillBodyVO);
-        }
-        data.put("WhsTransBillHeaderVO", whsTransBillHeaderVO);
-        data.put("WhsTransBillBodyVO", whsTransBillBodyVOS);
-        return data;
-    }
+
 
 
     private Object processCGDH(List<OrderDetl> orderDetls) {
@@ -313,7 +422,7 @@
         Map<String, Object> data = new HashMap<String, Object>();
         ic_purchasein_h ic_purchasein_h = new ic_purchasein_h();
         ic_purchasein_h.setPk_org("FYT");
-        ic_purchasein_h.setCwarehouseid("6301");
+        //ic_purchasein_h.setCwarehouseid("6301");
         ic_purchasein_h.setCfanaceorgoid("FYT");
         ic_purchasein_b ic_purchasein_b = null;
         List<ic_purchasein_b> ic_purchasein_bs = new ArrayList<>();
@@ -332,6 +441,7 @@
                 ic_purchasein_b.setCsourcetype(nccCgCgdhdWms.getDhlxbm());
                 ic_purchasein_b.setVbatchcode(orderDetl.getBatch());
             }
+            ic_purchasein_h.setCwarehouseid(orderDetl.getStandby1());
             ic_purchasein_bs.add(ic_purchasein_b);
         }
         data.put("ic_purchasein_h", ic_purchasein_h);
@@ -339,40 +449,45 @@
         return data;
     }
 
-    /**
-     * @param orderDetls
-     * @return
-     */
-    private Object processGENERALOUT(List<OrderDetl> orderDetls) {
+
+    private Object processZKCK(Order order, List<OrderDetl> orderDetls) {
         //缁勮瀵硅薄鏁版嵁
         Map<String, Object> data = new HashMap<String, Object>();
-        ic_generalout_h generalout_h = new ic_generalout_h();
-        generalout_h.setPk_org("FYT");
-        generalout_h.setCwarehouseid("6101");
-        ic_generalout_b generalout_b = null;
-        List<ic_generalout_b> ic_purchasein_bs = new ArrayList<>();
+        WhsTransBillHeaderVO whsTransBillHeaderVO = new WhsTransBillHeaderVO();
+        whsTransBillHeaderVO.setPk_org("FYT");
+        whsTransBillHeaderVO.setCotherwhid(order.getItemId());
+        whsTransBillHeaderVO.setCtrantypeid("4K-01");
+        WhsTransBillBodyVO whsTransBillBodyVO = null;
+        List<WhsTransBillBodyVO> whsTransBillBodyVOS = new ArrayList<>();
         for (OrderDetl orderDetl : orderDetls) {
-            generalout_b = new ic_generalout_b();
-            String remark = orderDetl.getRemark();
-            if (!Cools.isEmpty(remark)) {
-                NccSaleXsfhmxWms nccSaleXsfhmxWms = JSONObject.parseObject(remark, NccSaleXsfhmxWms.class);
-                generalout_b.setCmaterialvid(orderDetl.getMatnr());
-                generalout_b.setNshouldassistnum(orderDetl.getQty());
-                generalout_b.setVbatchcode(orderDetl.getBatch());
+            NccScPcdaWms nccScPcdaWms = nccScPcdaWmsService.selectOne(new EntityWrapper<NccScPcdaWms>().eq("vbatchcode", orderDetl.getBatch()).eq("wlbm", orderDetl.getMatnr()));
+            if (nccScPcdaWms == null) {
+                throw new CoolException("鎵规[{}]鐗╂枡[{}]鏈壘鍒�" + orderDetl.getBatch() + orderDetl.getMatnr());
             }
-            ic_purchasein_bs.add(generalout_b);
+
+            whsTransBillBodyVO = new WhsTransBillBodyVO();
+            whsTransBillBodyVO.setCstateid(nccScPcdaWms.getPkBatchcode());
+
+            String remark = orderDetl.getRemark();
+            //if (!Cools.isEmpty(remark)) {
+            //NccSaleXsfhmxWms nccSaleXsfhmxWms = JSONObject.parseObject(remark, NccSaleXsfhmxWms.class);
+            whsTransBillBodyVO.setNnum(orderDetl.getQty());
+            whsTransBillBodyVO.setCmaterialoid(orderDetl.getMatnr());
+            whsTransBillBodyVO.setVbatchcode(orderDetl.getBatch());
+            //}
+            whsTransBillHeaderVO.setCwarehouseid(orderDetl.getStandby1());
+            whsTransBillBodyVOS.add(whsTransBillBodyVO);
         }
-        data.put("ic_generalout_h", generalout_h);
-        data.put("ic_generalout_b", ic_purchasein_bs);
+        data.put("WhsTransBillHeaderVO", whsTransBillHeaderVO);
+        data.put("WhsTransBillBodyVO", whsTransBillBodyVOS);
         return data;
     }
 
-
     /**
      * @param orderDetls
      * @return
      */
-    private Object processGENERALOUT2(List<OrderDetl> orderDetls, String memo) {
+    private Object processGENERALOUT2(List<OrderDetl> orderDetls, String renyuan, String rukucangku, String memo) {
         Object o = JSONObject.parseArray(memo).get(0);
         JSONObject jsonObject = JSONObject.parseObject(o.toString());
         String cspecialhid = JSONObject.parseObject(jsonObject.getString("ic.WhsTransBillHeaderVO")).getString("cspecialhid");
@@ -386,17 +501,31 @@
         Map<String, Object> data = new HashMap<String, Object>();
         ic_generalout_h generalout_h = new ic_generalout_h();
         generalout_h.setPk_org("FYT");
-        generalout_h.setCwarehouseid("6101");
+        //generalout_h.setCwarehouseid("6101");
         ic_generalout_b generalout_b = null;
         List<ic_generalout_b> ic_purchasein_bs = new ArrayList<>();
         for (int i = 0; i < orderDetls.size(); i++) {
+//            NccScPcdaWms nccScPcdaWms = nccScPcdaWmsService.selectOne(new EntityWrapper<NccScPcdaWms>().eq("vbatchcode", orderDetls.get(i).getBatch()).eq("wlbm", orderDetls.get(i).getMatnr()));
+//            if (nccScPcdaWms == null) {
+//                throw new CoolException("鎵规[{}]鐗╂枡[{}]鏈壘鍒�" + orderDetls.get(i).getBatch() + orderDetls.get(i).getMatnr());
+//            }
             OrderDetl orderDetl = orderDetls.get(i);
+            generalout_h.setCwarehouseid(orderDetl.getStandby1());
             generalout_b = new ic_generalout_b();
             generalout_b.setCsourcebillbid(s.get(i));
             generalout_b.setCsourcetype("4K-01");
             generalout_b.setCsourcebillhid(cspecialhid);
             generalout_b.setCmaterialvid(orderDetl.getMatnr());
-            generalout_b.setNshouldassistnum(orderDetl.getQty());
+            //generalout_b.setCstateid(nccScPcdaWms.getVcode());
+            StoreType storeType = storeTypeService.selectOne(new EntityWrapper<StoreType>().eq("store_id", orderDetl.getStandby1()));
+            generalout_b.setCdptvid(storeType.getDepartmentId());
+            generalout_b.setBillmaker(renyuan);
+            StoreType storeType2 = storeTypeService.selectOne(new EntityWrapper<StoreType>().eq("store_id", rukucangku));
+            generalout_b.setCotherwhid(rukucangku);
+            generalout_b.setCothercalbodyvid(storeType2.getDepartmentId());
+
+            //generalout_b.setNshouldassistnum(orderDetl.getQty());
+            generalout_b.setNnum(orderDetl.getQty());
             generalout_b.setVbatchcode(orderDetl.getBatch());
             ic_purchasein_bs.add(generalout_b);
         }

--
Gitblit v1.9.1