From 5d480903c47b8966a086fc6c9bb26151f695570a Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期五, 13 三月 2026 15:19:03 +0800
Subject: [PATCH] erp下发停止出库任务,wms取消wcs任务

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |  110 +++++++++++++++++++++++++++---------------------------
 1 files changed, 55 insertions(+), 55 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index 47ea86e..9aa7192 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -375,58 +375,70 @@
     @Transactional
     public R pakoutOrderPause(OpenOrderPakoutPauseParam param) {
         if (param == null || Cools.isEmpty(param.getOrderId())) {
-            throw new CoolException("orderNo is empty");
+            throw new CoolException("orderNo涓嶈兘涓虹┖");
+        }
+        if (param.getExecute() == null) {
+            throw new CoolException("reason涓嶈兘涓虹┖");
         }
 
         List<WrkMast> activeTasks = findActiveOutboundTasks(param.getOrderId());
-        Map<String, Object> result = new HashMap<>();
-        result.put("orderNo", param.getOrderId());
-        result.put("taskCount", activeTasks.size());
-        if (activeTasks.isEmpty()) {
-            result.put("confirmedCount", 0);
-            return R.ok("no active out tasks").add(result);
-        }
-
-        Date now = new Date();
-        int confirmedCount = 0;
-        for (WrkMast wrkMast : activeTasks) {
-            if (wrkMast == null || "Y".equalsIgnoreCase(wrkMast.getPdcType())) {
-                continue;
+        if (Objects.equals(param.getExecute(), 1)) {
+            // ERP纭绔嬪嵆鎵ц锛屼粎澶勭悊寰呬笅鍙戠殑鍑哄簱浠诲姟銆�
+            List<WrkMast> pendingTasks = activeTasks.stream()
+                    .filter(wrkMast -> wrkMast != null && Objects.equals(wrkMast.getWrkSts(), 11L))
+                    .collect(Collectors.toList());
+            Map<String, Object> result = new HashMap<>();
+            result.put("orderNo", param.getOrderId());
+            result.put("taskCount", pendingTasks.size());
+            if (pendingTasks.isEmpty()) {
+                result.put("confirmedCount", 0);
+                return R.ok("鏃犳湁鏁堝嚭搴撲换鍔�").add(result);
             }
-            wrkMast.setPdcType("Y");
+
+            Date now = new Date();
+            int confirmedCount = 0;
+            for (WrkMast wrkMast : pendingTasks) {
+                if (wrkMast == null || "Y".equalsIgnoreCase(wrkMast.getPdcType())) {
+                    continue;
+                }
+                wrkMast.setPdcType("Y");
 //            wrkMast.setUpdMk("ERP_CONFIRMED");
 //            wrkMast.setManuType("ERP_CONFIRM_OUT");
-            wrkMast.setModiTime(now);
-            wrkMast.setModiUser(9527L);
-            if (!wrkMastService.updateById(wrkMast)) {
-                throw new CoolException("confirm out task failed: " + wrkMast.getWrkNo());
+                wrkMast.setModiTime(now);
+                wrkMast.setModiUser(9527L);
+                if (!wrkMastService.updateById(wrkMast)) {
+                    throw new CoolException("纭鎵ц鍑哄簱浠诲姟澶辫触: " + wrkMast.getWrkNo());
+                }
+                confirmedCount++;
             }
-            confirmedCount++;
-        }
 
-        result.put("confirmedCount", confirmedCount);
-        return R.ok(confirmedCount == 0 ? "tasks already confirmed" : "erp confirm out success").add(result);
+            result.put("confirmedCount", confirmedCount);
+            return R.ok(confirmedCount == 0 ? "浠诲姟宸茬‘璁ゆ墽琛�" : "ERP纭鎵ц鍑哄簱鎴愬姛").add(result);
+        }
+        if (Objects.equals(param.getExecute(), 2)) {
+            // ERP璇锋眰鍙栨秷浠诲姟锛氱洿鎺ユ敹闆嗕换鍔″彿锛屾寜 taskList 鏍煎紡鍙戦�佺粰 WCS銆�
+            Map<String, Object> result = new HashMap<>();
+            result.put("orderNo", param.getOrderId());
+            result.put("execute", param.getExecute());
+            result.put("taskCount", activeTasks.size());
+            if (activeTasks.isEmpty()) {
+                return R.ok("鏃犳湁鏁堝嚭搴撲换鍔�").add(result);
+            }
+            List<HashMap<String,Object>> taskList = new ArrayList<>();
+            for (WrkMast wrkMast : activeTasks) {
+                HashMap<String,Object> hashMap = new HashMap<>();
+                hashMap.put("taskNo", wrkMast.getWrkNo());
+                taskList.add(hashMap);
+            }
+            wcsApiService.pauseOutTasks(taskList);
+            return R.ok("鍙栨秷浠诲姟宸插彂閫佽嚦WCS").add(result);
+        }
+        throw new CoolException("reason浠呮敮鎸�1鎴�2");
     }
 
     @Override
-    @Transactional
     public R pakoutOrderExecute(OpenOrderPakoutExecuteParam param) {
-        if (param == null || Cools.isEmpty(param.getOrderId())) {
-            throw new CoolException("orderId is empty");
-        }
-        if (param.getExecute() == null) {
-            throw new CoolException("execute is empty");
-        }
-        if (Objects.equals(param.getExecute(), 1)) {
-            return createPakoutTasks(param.getOrderId());
-        }
-        if (Objects.equals(param.getExecute(), 2)) {
-            OpenOrderPakoutPauseParam pauseParam = new OpenOrderPakoutPauseParam();
-            pauseParam.setOrderId(param.getOrderId());
-//            pauseParam.setReason("OPEN_API_CONFIRM_OUT");
-            return pakoutOrderPause(pauseParam);
-        }
-        throw new CoolException("execute only supports 1 or 2");
+        return null;
     }
 
     private List<WrkMast> findActiveOutboundTasks(String orderNo) {
@@ -444,7 +456,7 @@
         List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>()
                 .in("wrk_no", wrkNos)
                 .in("io_type", Arrays.asList(101, 103, 104, 107, 108, 110))
-                .eq("wrk_sts", 11L));
+                .in("wrk_sts", Arrays.asList(11L, 12L, 13L)));
         if (wrkMasts == null || wrkMasts.isEmpty()) {
             return Collections.emptyList();
         }
@@ -555,24 +567,12 @@
         return orderDetl.getMatnr() + "|batch=" + (orderDetl.getBatch() == null ? "" : orderDetl.getBatch()) + "|lack=" + lackQty;
     }
 
-    private boolean needNotifyWcsStop(WrkMast wrkMast) {
-        return wrkMast != null
-                && wrkMast.getWrkSts() != null
-                && wrkMast.getWrkSts() >= 12L
-                && wrkMast.getWrkSts() < 14L;
-    }
-
-    private StopOutTaskParams buildStopOutTaskParams(OpenOrderPakoutPauseParam param, List<WrkMast> wrkMasts) {
+    private StopOutTaskParams buildStopOutTaskParams(List<WrkMast> wrkMasts) {
         StopOutTaskParams stopParams = new StopOutTaskParams();
-        stopParams.setOrderNo(param.getOrderId());
-        stopParams.setReason(param.getReason());
+        // WCS鍙栨秷鎺ュ彛浠呮帴鏀� taskList.taskNo銆�
         for (WrkMast wrkMast : wrkMasts) {
             StopOutTaskParams.TaskItem item = new StopOutTaskParams.TaskItem();
             item.setTaskNo(String.valueOf(wrkMast.getWrkNo()));
-            if (wrkMast.getStaNo() != null) {
-                item.setStaNo(String.valueOf(wrkMast.getStaNo()));
-            }
-            item.setLocNo(wrkMast.getSourceLocNo());
             stopParams.getTasks().add(item);
         }
         return stopParams;

--
Gitblit v1.9.1