From 7b3b79013ac10c091666ebc0b8f0916506de80df Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 10 十一月 2025 16:22:34 +0800
Subject: [PATCH] 入库上报明细库位不完全修改

---
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java |  139 ++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 127 insertions(+), 12 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java
index 1415e42..f38ec84 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java
@@ -297,16 +297,14 @@
                 List<StockItem> stockItems = stockItemService.list(new LambdaQueryWrapper<StockItem>()
                         .eq(StockItem::getFieldsIndex, orderItem.getFieldsIndex()));
                 //鑾峰彇搴撳瓨涓鍗曞簱浣�
-                if (!stockItems.isEmpty()) {
-                    Set<Long> stockIds = stockItems.stream().map(StockItem::getStockId).collect(Collectors.toSet());
-                    //鑾峰彇搴撳瓨搴撲綅淇℃伅
-                    List<Stock> stocks = stockService.list(new LambdaQueryWrapper<Stock>()
-                            .in(Stock::getId, stockIds)
-                            .eq(Stock::getType, OrderType.ORDER_IN.type)
-                            .eq(Stock::getSourceCode, order.getCode()));
-                    Set<String> locs = stocks.stream().map(Stock::getLocCode).collect(Collectors.toSet());
-                    String locCode = StringUtils.join(locs.toArray(), ",");
-                    param.setZone(locCode);
+                Set<Long> longSet = stockItems.stream().map(StockItem::getStockId).collect(Collectors.toSet());
+                //鑾峰彇搴撳瓨搴撲綅淇℃伅
+                Stock stocks = stockService.getOne(new LambdaQueryWrapper<Stock>()
+                        .in(Stock::getId, longSet)
+                        .eq(Stock::getType, OrderType.ORDER_IN.type)
+                        .eq(Stock::getSourceCode, order.getCode()));
+                if (!Objects.isNull(stocks)) {
+                    param.setZone(stocks.getLocCode());
                 }
             }
             //鑾峰彇绱㈠紩鍐呭
@@ -332,7 +330,7 @@
                 //閲囪喘閫�璐�
                 params.setOrderType("PR_Outstock").setAction("Update");
                 param.setOutQty(orderItem.getQty());
-            } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER_TERANSFER.type)) {
+            } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER_TERANSFER_IN.type)) {
                 //璋冩嫈鍏ュ簱鍗�
                 params.setOrderType("Mv_Instock").setAction("Update");
 
@@ -370,7 +368,7 @@
         params.setData(reportData);
         try {
             R reported = uploadReportOrders(params);
-            if (reported.get("code").equals("200")) {
+            if (Integer.valueOf(reported.get("code").toString()) == 200) {
                 order.setNtyStatus(OrderReportStatus.ORDER_REPORT_STATUS_ALL.val);
                 asnOrderService.updateById(order);
             }
@@ -386,4 +384,121 @@
         }
     }
 
+    /**
+     * @author Ryan
+     * @date 2025/11/10
+     * @description: 鍏ュ簱浠诲姟鏄庣粏涓婃姤
+     * @version 1.0
+     */
+    @Override
+    public void reportOrderItem(WkOrderItem orderItem) {
+        ReportParams params = new ReportParams();
+
+        WkOrder order = asnOrderService.getById(orderItem.getOrderId());
+        if (Objects.isNull(order)) {
+            throw new RuntimeException("鍗曟嵁涓嶅瓨鍦ㄦ垨宸插畬鎴愶紒锛�");
+        }
+
+        List<ReportDataParam> reportData = new ArrayList<>();
+
+        ReportDataParam param = new ReportDataParam();
+        User user = userService.getById(orderItem.getUpdateBy());
+        String nickName = null;
+        if (!Objects.isNull(user)) {
+            nickName = user.getNickname();
+        }
+        //鑾峰彇鍏ュ簱搴撲綅淇℃伅
+        if (order.getType().equals(OrderType.ORDER_IN.type)) {
+            //绛涢�夊綋鍓嶅敮涓�瀛楁鎵�鏈夊嚭鍏ュ簱淇℃伅
+            List<StockItem> stockItems = stockItemService.list(new LambdaQueryWrapper<StockItem>()
+                    .eq(StockItem::getFieldsIndex, orderItem.getFieldsIndex()));
+            //鑾峰彇搴撳瓨涓鍗曞簱浣�
+            Set<Long> longSet = stockItems.stream().map(StockItem::getStockId).collect(Collectors.toSet());
+            //鑾峰彇搴撳瓨搴撲綅淇℃伅
+            Stock stocks = stockService.getOne(new LambdaQueryWrapper<Stock>()
+                    .in(Stock::getId, longSet)
+                    .eq(Stock::getType, OrderType.ORDER_IN.type)
+                    .eq(Stock::getSourceCode, order.getCode()));
+            if (!Objects.isNull(stocks)) {
+                param.setZone(stocks.getLocCode());
+            }
+        }
+        //鑾峰彇绱㈠紩鍐呭
+        Map<String, String> fields = FieldsUtils.getFields(orderItem.getFieldsIndex());
+
+        //璁剧疆閫氱敤鍙傛暟
+        param.setWMSNO(order.getCode())
+                .setPONO(order.getPoCode())
+                .setOrderNO(order.getPoCode())
+                .setOrderDate(order.getCreateTime())
+                .setItemCode(orderItem.getMatnrCode())
+                .setEditUser(nickName)
+                .setEditDate(order.getUpdateTime())
+                .setGoodsNO(fields.get("crushNo"))
+                .setMemoDtl(order.getMemo());
+
+        if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_DONE_IN.type)) {
+            //閲囪喘鍏ュ簱鍗�
+            params.setOrderType("PO_Instock").setAction("Update");
+            //鑾峰彇鎸囧畾鏌ヨ瀛楁CrushNo 绁ㄥ彿
+            param.setInQty(orderItem.getQty());
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_PURCHASE_RETURN.type)) {
+            //閲囪喘閫�璐�
+            params.setOrderType("PR_Outstock").setAction("Update");
+            param.setOutQty(orderItem.getQty());
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER_TERANSFER_IN.type)) {
+            //璋冩嫈鍏ュ簱鍗�
+            params.setOrderType("Mv_Instock").setAction("Update");
+
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_PROD.type)) {
+            //鐢熶骇鍏ュ簱鍗�
+//                params.setOrderType("WO_Outstock").setAction("Update");
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_PURCHASE.type)) {
+            //鐢熶骇閫�鏂�
+            params.setOrderType("WR_Instock").setAction("Update");
+            param.setInQty(orderItem.getQty());
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_RETURN_ORDER.type)) {
+            //鐢熶骇棰嗘枡
+            params.setOrderType("WO_Outstock").setAction("Update");
+            param.setOutQty(orderItem.getQty());
+
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_PROD_ADDITION.type)) {
+            //鐢熶骇琛ユ枡
+            params.setOrderType("WR_Instock_BL").setAction("Update");
+            param.setOutQty(orderItem.getQty());
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_FIX_OUT.type)) {
+            params.setOrderType("WO_Outstock_WR").setAction("Update");
+            param.setOutQty(orderItem.getQty());
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER_IN.type)) {
+            //鍏跺畠鍏ュ簱鍗�/鎵嬪姩鍏ュ簱鍗�
+            params.setOrderType("In_Instock").setAction("Update");
+            param.setInQty(orderItem.getQty());
+
+        } else if (order.getWkType().equals(OrderWorkType.ORDER_WORK_TYPE_OTHER.type)) {
+            //鍏跺畠鍑哄簱鍗�/鎵嬪姩鍑哄簱鍗�
+            params.setOrderType("Io_Outstock").setAction("Update");
+            param.setOutQty(orderItem.getQty());
+        }
+        reportData.add(param);
+        params.setData(reportData);
+        try {
+            R reported = uploadReportOrders(params);
+            if (Integer.valueOf(reported.get("code").toString()) == 200) {
+                //淇敼璁㈠崟涓婃姤娆℃暟
+                order.setReportOnce(order.getReportOnce() + 1);
+                asnOrderService.updateById(order);
+            }
+        } catch (Exception e) {
+            log.error("<UNK>", e);
+        }
+
+        try {
+            //浼戠湢3绉�
+            Thread.sleep(3000);
+        } catch (InterruptedException e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+
 }

--
Gitblit v1.9.1