From 3e9d3cf02c66e26587e5d5e16a1a2905e565af98 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 10 十一月 2025 15:52:37 +0800
Subject: [PATCH] 入库上报明细库位不完全修改

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java       |   16 ++--
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/ReportMsgService.java          |    3 +
 rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/ReportMsgServiceImpl.java |  116 ++++++++++++++++++++++++++++++++++++++
 3 files changed, 127 insertions(+), 8 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/ReportMsgService.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/ReportMsgService.java
index 1be8ba1..95eda6d 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/ReportMsgService.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/ReportMsgService.java
@@ -4,6 +4,7 @@
 import com.vincent.rsf.server.api.controller.erp.params.ReportParams;
 import com.vincent.rsf.server.api.entity.dto.PoItemsDto;
 import com.vincent.rsf.server.manager.entity.WkOrder;
+import com.vincent.rsf.server.manager.entity.WkOrderItem;
 
 import java.util.List;
 
@@ -23,4 +24,6 @@
     R uploadCheckOrder(ReportParams params);
 
     void reportOrders(WkOrder order);
+
+    void reportOrderItem(WkOrderItem orederItem);
 }
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 eb921d9..d9a0ccb 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
@@ -384,4 +384,120 @@
         }
     }
 
+    /**
+     * @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.setNtyStatus(OrderReportStatus.ORDER_REPORT_STATUS_ALL.val);
+                asnOrderService.updateById(order);
+            }
+        } catch (Exception e) {
+            log.error("<UNK>", e);
+        }
+
+        try {
+            //浼戠湢3绉�
+            Thread.sleep(3000);
+        } catch (InterruptedException e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+
 }
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
index 4f6661a..e58f132 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java
@@ -562,16 +562,16 @@
             taskItems.forEach(taskItem -> {
                 WkOrder order = asnOrderService.getById(taskItem.getOrderId());
                 if (Objects.isNull(order)) {
-                    throw new CoolException("鏁版嫇閿欒锛屽崟鎹笉瀛樺湪锛侊紒");
+                    throw new CoolException("鏁版嵁閿欒锛屽崟鎹笉瀛樺湪锛侊紒");
                 }
                 if (order.getType().equals(OrderType.ORDER_IN.type)) {
-//                    try {
-//                        //涓婃姤宸插畬鎴愯鍗曡嚦ERP銆丮ES绛変笁鏂圭郴缁�
-//
-//                    } catch (Exception e) {
-//                        log.error(e.getMessage());
-//                    }
-                    reportMsgService.reportOrders(order);
+                    WkOrderItem wkOrderItem = asnOrderItemService.getOne(new LambdaQueryWrapper<WkOrderItem>()
+                            .eq(WkOrderItem::getOrderId, order.getId())
+                            .eq(WkOrderItem::getFieldsIndex, taskItem.getFieldsIndex()));
+                    if (Objects.isNull(wkOrderItem)) {
+                        throw new CoolException("鏁版嵁閿欒锛屽崟鎹槑缁嗕笉瀛樺湪鎴栧凡瀹屾垚锛侊紒");
+                    }
+                    reportMsgService.reportOrderItem(wkOrderItem);
                     order.setReportOnce(order.getReportOnce() + 1);
                     if (!asnOrderService.updateById(order)) {
                         log.error(order.getCode() + "锛屽崟鎹笂浼犳鏁颁慨鏀瑰け璐ワ紒锛�");

--
Gitblit v1.9.1