From 99af0223ae0858c69d1b75106d5f8bb0ab14b129 Mon Sep 17 00:00:00 2001
From: zhangherong <571457620@qq.com>
Date: 星期三, 27 八月 2025 17:04:29 +0800
Subject: [PATCH] art: 移库单回调出库逻辑添加

---
 src/main/java/org/jeecg/modules/wms/service/impl/MESWebServiceSoapImpl.java |  143 +++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 136 insertions(+), 7 deletions(-)

diff --git a/src/main/java/org/jeecg/modules/wms/service/impl/MESWebServiceSoapImpl.java b/src/main/java/org/jeecg/modules/wms/service/impl/MESWebServiceSoapImpl.java
index ff68abc..31ce6f0 100644
--- a/src/main/java/org/jeecg/modules/wms/service/impl/MESWebServiceSoapImpl.java
+++ b/src/main/java/org/jeecg/modules/wms/service/impl/MESWebServiceSoapImpl.java
@@ -5,8 +5,22 @@
 import org.apache.commons.lang3.StringUtils;
 import org.jeecg.common.aspect.annotation.ApiLog;
 import org.jeecg.common.constant.ApiLogCategoryEnum;
+import org.jeecg.modules.base.entity.LineSideWarehouse;
+import org.jeecg.modules.base.service.ILineSideWarehouseService;
+import org.jeecg.modules.lsw.entity.LswMaterial;
+import org.jeecg.modules.lsw.entity.LswMaterialInbound;
+import org.jeecg.modules.lsw.entity.LswMaterialInventory;
+import org.jeecg.modules.lsw.entity.LswMaterialOutbound;
+import org.jeecg.modules.lsw.service.ILswMaterialInboundService;
+import org.jeecg.modules.lsw.service.ILswMaterialInventoryService;
+import org.jeecg.modules.lsw.service.ILswMaterialOutboundService;
+import org.jeecg.modules.lsw.service.ILswMaterialService;
 import org.jeecg.modules.mes.entity.MesMaterialTransferRequest;
+import org.jeecg.modules.mes.entity.MesTransferOrderPrint;
+import org.jeecg.modules.mes.enums.MaterialTransferRequestStatus;
+import org.jeecg.modules.mes.enums.TransferOrderStatusEnum;
 import org.jeecg.modules.mes.service.IMesMaterialTransferRequestService;
+import org.jeecg.modules.mes.service.IMesTransferOrderPrintService;
 import org.jeecg.modules.wms.dto.WSResponse;
 import org.jeecg.modules.wms.request.ReceiveWMSScanItemList;
 import org.jeecg.modules.wms.request.WMSWebServiceSendItem;
@@ -21,6 +35,7 @@
 import javax.jws.WebService;
 import javax.xml.ws.RequestWrapper;
 import javax.xml.ws.ResponseWrapper;
+import java.math.BigDecimal;
 
 
 @Slf4j
@@ -30,6 +45,18 @@
 
     @Autowired
     private IMesMaterialTransferRequestService materialTransferRequestService;
+    @Autowired
+    private ILineSideWarehouseService lineSideWarehouseService;
+    @Autowired
+    private ILswMaterialInboundService materialInboundService;
+    @Autowired
+    private IMesTransferOrderPrintService transferOrderPrintService;
+    @Autowired
+    private ILswMaterialOutboundService materialOutboundService;
+    @Autowired
+    private ILswMaterialInventoryService materialInventoryService;
+    @Autowired
+    private ILswMaterialService materialService;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -45,19 +72,121 @@
             response.setErrorDesc("浼犲叆鐨勫弬鏁颁负绌猴紒");
             return response;
         }
-        for(WMSWebServiceSendItem item : request.getWmsWebServiceSendItemList()) {
-            if(StringUtils.isNotBlank(item.getReservationOrder())) {
+        int errorCount = 0;
+        int successCount = 0;
+        StringBuilder errorMsg = new StringBuilder();
+        for (WMSWebServiceSendItem item : request.getWmsWebServiceSendItemList()) {
+            if (StringUtils.isNotBlank(item.getReservationOrder())) {
                 //鐗╂枡鎷夊姩鍥炶皟
                 MesMaterialTransferRequest transferRequest = materialTransferRequestService.queryByReservationCode(item.getReservationOrder());
-                if(transferRequest == null) {
-                    response.setErrorCode("N");
-                    response.setErrorDesc("鏍规嵁棰勭暀鍙锋湭鎵惧埌鐗╂枡鎷夊姩鍗曪紒");
-                    return response;
+                if (transferRequest == null) {
+                    errorCount++;
+                    errorMsg.append("鏍规嵁棰勭暀鍙穂").append(item.getReservationOrder()).append("]鏈壘鍒扮墿鏂欐媺鍔ㄥ崟锛乗n");
+                    continue;
                 }
-            }else if(StringUtils.isNotBlank(item.getAlign())){
+                LineSideWarehouse warehouse = lineSideWarehouseService.getById(transferRequest.getTargetWarehouseId());
+                if (warehouse == null || !warehouse.getWarehouseCode().equals(item.getDestSection())) {
+                    errorCount++;
+                    errorMsg.append("绾胯竟搴揫").append(item.getDestSection()).append("]鏈壘鍒帮紒\n");
+                    continue;
+                }
+                if (!transferRequest.getMaterialNumber().equals(item.getSkuCode())) {
+                    errorCount++;
+                    errorMsg.append("鐗╂枡缂栧彿[").append(item.getSkuCode()).append("]涓嶅尮閰嶏紒\n");
+                    continue;
+                }
+                if (StringUtils.isBlank(item.getTrackLot())) {
+                    errorCount++;
+                    errorMsg.append("鎵规鍙穂").append(item.getTrackLot()).append("]涓嶈兘涓虹┖锛乗n");
+                    continue;
+                }
+                transferRequest.setRequestStatus(MaterialTransferRequestStatus.CHECKED_IN.name());
+                //璁$畻瀹為檯鎷夊姩鏁伴噺
+                BigDecimal actualQuantity = transferRequest.getActualQuantity() == null ? item.getQuantity() : transferRequest.getActualQuantity().add(item.getQuantity());
+                transferRequest.setActualQuantity(actualQuantity);
+
+                //娣诲姞鍏ュ簱淇℃伅
+                LswMaterialInbound inbound = new LswMaterialInbound();
+                inbound.setWarehouseId(transferRequest.getTargetWarehouseId());
+                inbound.setReceiver("WMS");
+                inbound.setMaterialNumber(transferRequest.getMaterialNumber());
+                inbound.setMaterialName(transferRequest.getMaterialName());
+                inbound.setBatchNumber(item.getTrackLot());
+                inbound.setQuantity(item.getQuantity());
+                inbound.setFactoryId(warehouse.getFactoryId());
+                boolean b = materialInboundService.inboundMaterial(inbound);
+                if (!b) {
+                    errorCount++;
+                    errorMsg.append("棰勭暀鍙穂").append(item.getReservationOrder()).append("]鍏ュ簱澶辫触锛乗n");
+                    continue;
+                }
+                //鏇存柊鐗╂枡鎷夊姩鍗�
+                materialTransferRequestService.updateById(transferRequest);
+                successCount++;
+            } else if (StringUtils.isNotBlank(item.getAlign())) {
                 //绉诲簱鍗曞洖璋�
+                MesTransferOrderPrint transferOrder = transferOrderPrintService.queryByOrderCode(item.getAlign());
+                if (transferOrder == null) {
+                    errorCount++;
+                    errorMsg.append("绉诲簱鍗昜").append(item.getAlign()).append("]涓嶅瓨鍦紒\n");
+                    continue;
+                }
+                LswMaterialInventory inventory = materialInventoryService.getById(item.getMesStockID());
+                if (inventory == null) {
+                    errorCount++;
+                    errorMsg.append("搴撳瓨淇℃伅[").append(item.getMesStockID()).append("]涓嶅瓨鍦紒\n");
+                    continue;
+                }
+                LswMaterial material = materialService.queryByMaterialNumber(item.getSkuCode());
+                if(material == null) {
+                    errorCount++;
+                    errorMsg.append("鐗╂枡缂栧彿[").append(item.getSkuCode()).append("]涓嶅瓨鍦紒\n");
+                    continue;
+                }
+                LineSideWarehouse warehouse = lineSideWarehouseService.getById(transferOrder.getOriginalWarehouseId());
+                if (warehouse == null || !warehouse.getWarehouseCode().equals(item.getDestSection())) {
+                    errorCount++;
+                    errorMsg.append("绾胯竟搴揫").append(item.getDestSection()).append("]鏈壘鍒帮紒\n");
+                    continue;
+                }
+                //绉诲簱鍗曟洿鏀�
+                transferOrder.setOrderStatus(TransferOrderStatusEnum.COMPLETED.name());
+                //鎴愬搧鍑哄簱
+                LswMaterialOutbound outbound = new LswMaterialOutbound();
+                outbound.setBatchNumber(inventory.getBatchNumber());
+                outbound.setQuantity(item.getQuantity());
+                outbound.setMaterialNumber(material.getMaterialNumber());
+                outbound.setMaterialName(material.getMaterialName());
+                outbound.setInventoryId(inventory.getId());
+                outbound.setWarehouseId(transferOrder.getOriginalWarehouseId());
+                outbound.setFactoryId(warehouse.getFactoryId());
+                outbound.setOutboundStaff("WMS");
+                boolean b = materialOutboundService.outboundMaterial(outbound);
+                if (!b) {
+                    errorCount++;
+                    errorMsg.append("绉诲簱鍗昜").append(item.getAlign()).append("]鍑哄簱澶辫触锛乗n");
+                    continue;
+                }
+                transferOrderPrintService.updateById(transferOrder);
+                successCount++;
             }
         }
+        //澶勭悊杩斿洖缁撴灉
+        if (errorCount > 0) {
+            response.setErrorCode("N");
+            if (successCount > 0) {
+                String msg = "鎴愬姛鎵ц" + successCount + "鏉★紝澶辫触" + errorCount + "鏉★紒\n";
+                errorMsg.insert(0, msg);
+            } else {
+                String msg = "澶辫触" + errorCount + "鏉★紒\n";
+                errorMsg.insert(0, msg);
+            }
+            response.setErrorDesc(errorMsg.toString());
+        } else {
+            response.setErrorCode("Y");
+            String msg = "鎴愬姛鎵ц" + successCount + "鏉★紒\n";
+            response.setErrorDesc(msg);
+        }
         return response;
     }
 }

--
Gitblit v1.9.3