From 9145f8a44c6ae733019e43c775cc30243032e502 Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期三, 29 四月 2026 16:16:43 +0800
Subject: [PATCH] 拍照触发修改

---
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java |  213 ++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 168 insertions(+), 45 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 9a001d8..92a24f6 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -51,6 +51,8 @@
 
     private static final Map<Integer, BigDecimal> INBOUND_WEIGHT_FACTOR_BY_SOURCE_STA;
     private static final String DATE_TIME_PATTERN = "yyyy-MM-dd HH:mm:ss";
+    private static final int DEFAULT_OUT_ORDER_BATCH_PRIORITY = 100;
+    private static final int DEFAULT_OUT_ORDER_BATCH_PRIORITY_THRESHOLD = 1;
     // ERP 鍑哄簱鍙eぇ浜庤闃堝�兼椂锛�/outOrder 鍙惤鍑哄簱璁㈠崟锛岀敱瀹氭椂鍣ㄥ悗缁敓鎴愪换鍔°��
     private static final int PENDING_OUT_ORDER_STATION_THRESHOLD = 600;
     // 寤惰繜鍑哄簱璁㈠崟浣跨敤鐙珛鍗曟嵁绫诲瀷锛屼究浜庡拰浜哄伐/椤甸潰鍒涘缓鐨勫嚭搴撳崟鍖哄垎鏉ユ簮銆�
@@ -465,7 +467,7 @@
         }
         if (Objects.equals(param.getExecute(), 2)) {
             // execute=2 鍏堝叧闂鍗曞紑鍏筹紝闃绘瀹氭椂鍣ㄧ户缁负鏈敓鎴愪换鍔$殑鏄庣粏寤� WrkMast銆�
-            // 宸茬粡鐢熸垚鐨勪换鍔℃寜鐘舵�佸垎娴侊細11 灏氭湭涓嬪彂锛岃蛋鏈湴鍙栨秷锛�12/13 宸蹭笅鍙戞垨鎵ц涓紝闇�瑕侀�氱煡 WCS 鏆傚仠銆�
+            // 宸茬粡鐢熸垚鐨勪换鍔℃寜鐘舵�佸垎娴侊細11 灏氭湭涓嬪彂锛岃蛋鏈湴鍙栨秷锛�12/13 宸蹭笅鍙戞垨鎵ц涓紝闇�瑕侀�氱煡 WCS 鍙栨秷銆�
             Map<String, Object> result = new HashMap<>();
             result.put("orderNo", param.getOrderId());
             result.put("execute", param.getExecute());
@@ -487,6 +489,7 @@
                 return R.ok("鍑哄簱璁㈠崟宸蹭腑姝�").add(result);
             }
             List<HashMap<String,Object>> taskList = new ArrayList<>();
+            List<WrkMast> wcsCancelTasks = new ArrayList<>();
             int cancelledLocalTaskCount = 0;
             for (WrkMast wrkMast : activeTasks) {
                 HashMap<String,Object> hashMap = new HashMap<>();
@@ -498,14 +501,23 @@
                     continue;
                 }
                 taskList.add(hashMap);
+                wcsCancelTasks.add(wrkMast);
             }
+            int cancelledWcsTaskCount = 0;
             if (!taskList.isEmpty()) {
-                // wrk_sts=12/13 绛夊凡杩涘叆 WCS 渚х殑浠诲姟蹇呴』鏍¢獙 WCS 杩斿洖锛屽け璐ュ垯浜嬪姟鍥炴粴锛岄伩鍏嶆湰鍦拌鎶ュ凡鏆傚仠銆�
+                // wrk_sts=12/13 绛夊凡杩涘叆 WCS 渚х殑浠诲姟蹇呴』鏍¢獙 WCS 杩斿洖锛屽け璐ュ垯浜嬪姟鍥炴粴锛岄伩鍏嶆湰鍦拌鎶ュ凡鍙栨秷銆�
                 R wcsR = wcsApiService.pauseOutTasks(taskList);
                 requireWcsPauseOk(wcsR);
+                // WCS 宸茬‘璁ゅ彇娑堝悗锛屾湰鍦颁篃瑕佸彇娑堜换鍔″苟鍥炴粴璁㈠崟鏄庣粏 work_qty銆�
+                // 鍥炴粴閫昏緫鍦� WorkService.cancelWrkMast 涓粺涓�澶勭悊锛岀‘淇� WCS 鍥炶皟 task_cancel 璧板悓涓�濂楀彛寰勩��
+                for (WrkMast wrkMast : wcsCancelTasks) {
+                    workService.cancelWrkMast(wrkMast.getWrkNo()+"", 9955L);
+                    cancelledWcsTaskCount++;
+                }
             }
             result.put("cancelledLocalTaskCount", cancelledLocalTaskCount);
             result.put("pausedWcsTaskCount", taskList.size());
+            result.put("cancelledWcsTaskCount", cancelledWcsTaskCount);
             return R.ok("鍑哄簱璁㈠崟宸蹭腑姝�").add(result);
         }
         throw new CoolException("reason浠呮敮鎸�1鎴�2");
@@ -1615,7 +1627,7 @@
         wrkMast.setIoTime(now);
         wrkMast.setWrkSts(11L); // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID
         wrkMast.setIoType(ioType); // 鍏ュ嚭搴撶姸鎬�
-        wrkMast.setIoPri(13D); // 浼樺厛绾э細13
+        wrkMast.setIoPri(Double.valueOf(i)); // 浼樺厛绾�
         wrkMast.setCrnNo(locMast.getCrnNo());
         wrkMast.setSourceStaNo(staDesc.getCrnStn()); // 婧愮珯
         wrkMast.setStaNo(staDesc.getStnNo()); // 鐩爣绔�
@@ -1626,9 +1638,9 @@
         wrkMast.setExitMk("N"); // 閫�鍑�
         wrkMast.setEmptyMk("N"); // 绌烘澘
         wrkMast.setLinkMis("N");
-        wrkMast.setPdcType("N");
         wrkMast.setContainerNo(param.getContainerNo());
         wrkMast.setTeu(teu);
+        wrkMast.setPdcType(locMast.getCrnNo()>=19?"Y":"N");//鑷姩浠诲姟涓嬪彂鏍囪
         wrkMast.setPlateNo(param.getPlateNo());
         wrkMast.setTrainNo(param.getTrainNo());
         wrkMast.setFreqType(param.getFreqType());
@@ -1700,23 +1712,39 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public R outOrderBatch(Map<String, List<OutTaskParam>> linesByBatchSeq,int count) {
-        int i = 0;
+
         for (Map.Entry<String, List<OutTaskParam>> entry : linesByBatchSeq.entrySet()) {
+            int i = DEFAULT_OUT_ORDER_BATCH_PRIORITY;
+            int j = 0;
+            int priorityThreshold = getOutOrderBatchPriorityThreshold();
             for (OutTaskParam outTaskParam : entry.getValue()) {
-                if(outTaskParam.getSeq()!=0){
-                    i= outTaskParam.getSeq();
-                }else{
-                    i++;
-                }
                 int teu = Cools.isEmpty(outTaskParam.getTeu())?0:outTaskParam.getTeu();
                 R r = outOrder(outTaskParam, count, teu ,i);
                 if (!Objects.equals(r.get("code"), 200)) {
                     throw new CoolException("鍑哄簱寤哄崟澶辫触");
                 }
+                j++;
+                if (j >= priorityThreshold) {
+                    i--;
+                    j = 0;
+                }
             }
 
         }
         return R.ok();
+    }
+
+    private int getOutOrderBatchPriorityThreshold() {
+        Parameter parameter = Parameter.get();
+        if (parameter == null || Cools.isEmpty(parameter.getOutOrderBatchPriorityThreshold())) {
+            return DEFAULT_OUT_ORDER_BATCH_PRIORITY_THRESHOLD;
+        }
+        try {
+            int threshold = Integer.parseInt(parameter.getOutOrderBatchPriorityThreshold().trim());
+            return threshold <= 0 ? DEFAULT_OUT_ORDER_BATCH_PRIORITY_THRESHOLD : threshold;
+        } catch (NumberFormatException ignored) {
+            return DEFAULT_OUT_ORDER_BATCH_PRIORITY_THRESHOLD;
+        }
     }
 
     @Override
@@ -1737,38 +1765,21 @@
         Date now = new Date();
         int orderCount = 0;
         int detailCount = 0;
+        int removedUndispatchedDetailCount = 0;
         List<String> orderNos = new ArrayList<>();
         for (Map.Entry<String, List<OutTaskParam>> entry : paramsByOrderNo.entrySet()) {
             String orderNo = entry.getKey();
-            // 寤惰繜寤哄崟鍏佽瑕嗙洊鈥滃皻鏈敓鎴愪换鍔°�佹湭杩涘叆鎵ц鈥濈殑鏃ц鍗曪紱
-            // 涓�鏃﹀凡鏈夋椿鍔ㄤ换鍔℃垨鍘嗗彶浠诲姟锛屽垯绂佹瑕嗙洊锛岄伩鍏嶉噸澶嶅嚭搴撳悓涓�璁㈠崟銆�
+            // 寤惰繜寤哄崟鍏佽鍚屼竴涓� orderNo 鍐嶆涓嬪彂锛�
+            // 宸蹭笅鍙�/宸插畬鎴愭槑缁嗕繚鐣欒拷婧紱鏈笅鍙戞槑缁嗗垹闄ゅ悗锛屼娇鐢ㄦ湰娆℃帴鍙e弬鏁伴噸鏂版彃鍏ャ��
             assertPendingPakoutOrderCanReplace(orderNo);
 
             OrderPakout order = orderPakoutService.selectByNo(orderNo);
-            if (order != null) {
-                orderPakoutService.remove(order.getId());
-            }
-
-            DocType docType = docTypeService.selectOrAdd(OUT_ORDER_PENDING_DOC_TYPE, Boolean.FALSE);
-            order = new OrderPakout();
-            order.setUuid(String.valueOf(snowflakeIdWorker.nextId()));
-            order.setOrderNo(orderNo);
-            order.setOrderTime(DateUtils.convert(now));
-            order.setDocType(docType.getDocId());
-            // settle=1 琛ㄧず寰呯敓鎴愪换鍔★紱鐢熸垚杩囪嚦灏戜竴涓繘浠撶紪鍙锋壒娆″悗缃负 2銆�
-            // status=1 鏄惎鍔ㄥ紑鍏筹紝pakoutOrderPause(execute=2) 浼氱疆 0 闃绘瀹氭椂鍣ㄧ户缁敓鎴愩��
-            order.setSettle(1L);
-            order.setStatus(1);
-            order.setCreateBy(9527L);
-            order.setCreateTime(now);
-            order.setUpdateBy(9527L);
-            order.setUpdateTime(now);
-            // moveStatus 淇濈暀鐜版湁鈥滃璐�/绉诲簱鈥濊涔夛紝杩欓噷涓嶅鐢ㄥ畠鍋氭殏鍋滃紑鍏炽��
-            order.setMoveStatus(0);
-            // 2 琛ㄧず鍑哄簱鏂瑰悜锛屽拰 man_order_detl_pakout 鏄庣粏淇濇寔涓�鑷淬��
-            order.setPakinPakoutStatus(2);
-            if (!orderPakoutService.insert(order)) {
-                throw new CoolException("鐢熸垚鍑哄簱璁㈠崟澶辫触锛�" + orderNo);
+            if (order == null) {
+                order = createPendingPakoutOrderHeader(orderNo, now);
+            } else {
+                assertNoNonReplaceablePendingDetailConflict(order, entry.getValue());
+                removedUndispatchedDetailCount += removeUndispatchedPendingDetails(order.getId());
+                refreshPendingPakoutOrderForResubmit(order, now);
             }
 
             for (OutTaskParam param : entry.getValue()) {
@@ -1786,6 +1797,7 @@
         Map<String, Object> result = new LinkedHashMap<>();
         result.put("orderCount", orderCount);
         result.put("detailCount", detailCount);
+        result.put("removedUndispatchedDetailCount", removedUndispatchedDetailCount);
         result.put("orderNos", orderNos);
         return R.ok("鍑哄簱璁㈠崟鐢熸垚鎴愬姛").add(result);
     }
@@ -1946,12 +1958,126 @@
         }
     }
 
+    private OrderPakout createPendingPakoutOrderHeader(String orderNo, Date now) {
+        DocType docType = docTypeService.selectOrAdd(OUT_ORDER_PENDING_DOC_TYPE, Boolean.FALSE);
+        OrderPakout order = new OrderPakout();
+        order.setUuid(String.valueOf(snowflakeIdWorker.nextId()));
+        order.setOrderNo(orderNo);
+        order.setOrderTime(DateUtils.convert(now));
+        order.setDocType(docType.getDocId());
+        // settle=1 琛ㄧず寰呯敓鎴愪换鍔★紱鐢熸垚杩囪嚦灏戜竴涓繘浠撶紪鍙锋壒娆″悗缃负 2銆�
+        // status=1 鏄惎鍔ㄥ紑鍏筹紝pakoutOrderPause(execute=2) 浼氱疆 0 闃绘瀹氭椂鍣ㄧ户缁敓鎴愩��
+        order.setSettle(1L);
+        order.setStatus(1);
+        order.setCreateBy(9527L);
+        order.setCreateTime(now);
+        order.setUpdateBy(9527L);
+        order.setUpdateTime(now);
+        // moveStatus 淇濈暀鐜版湁鈥滃璐�/绉诲簱鈥濊涔夛紝杩欓噷涓嶅鐢ㄥ畠鍋氭殏鍋滃紑鍏炽��
+        order.setMoveStatus(0);
+        // 2 琛ㄧず鍑哄簱鏂瑰悜锛屽拰 man_order_detl_pakout 鏄庣粏淇濇寔涓�鑷淬��
+        order.setPakinPakoutStatus(2);
+        if (!orderPakoutService.insert(order)) {
+            throw new CoolException("鐢熸垚鍑哄簱璁㈠崟澶辫触锛�" + orderNo);
+        }
+        return order;
+    }
+
+    private void refreshPendingPakoutOrderForResubmit(OrderPakout order, Date now) {
+        if (order == null) {
+            return;
+        }
+        boolean hasDispatchedDetail = hasDispatchedPendingDetail(order.getId());
+        order.setStatus(1);
+        order.setSettle(hasDispatchedDetail ? 2L : 1L);
+        order.setUpdateBy(9527L);
+        order.setUpdateTime(now);
+        order.setPakinPakoutStatus(2);
+        if (!orderPakoutService.updateById(order)) {
+            throw new CoolException("鏇存柊鍑哄簱璁㈠崟澶辫触锛�" + order.getOrderNo());
+        }
+    }
+
+    private boolean hasDispatchedPendingDetail(Long orderId) {
+        List<OrderDetlPakout> details = orderDetlPakoutService.selectList(new EntityWrapper<OrderDetlPakout>()
+                .eq("order_id", orderId)
+                .eq("status", 1));
+        if (Cools.isEmpty(details)) {
+            return false;
+        }
+        for (OrderDetlPakout detail : details) {
+            if (!isUndispatchedPendingDetail(detail)) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    /**
+     * 鍒犻櫎鍚岃鍗曚腑灏氭湭涓嬪彂鐨勬槑缁嗐��
+     *
+     * 鍒ゆ柇鍙e緞锛�
+     * - work_qty <= 0锛氬皻鏈敓鎴愭湁鏁堜换鍔★紝鎴栦腑姝㈠悗浠诲姟宸茶鍙栨秷骞跺畬鎴愬洖婊氥��
+     * - qty <= 0锛氭病鏈変笟鍔″畬鎴愰噺锛屽垹闄ゅ悗涓嶄細涓㈠け宸插畬鎴愬嚭搴撹褰曘��
+     */
+    private int removeUndispatchedPendingDetails(Long orderId) {
+        List<OrderDetlPakout> details = orderDetlPakoutService.selectList(new EntityWrapper<OrderDetlPakout>()
+                .eq("order_id", orderId)
+                .eq("status", 1));
+        if (Cools.isEmpty(details)) {
+            return 0;
+        }
+        int removed = 0;
+        for (OrderDetlPakout detail : details) {
+            if (!isUndispatchedPendingDetail(detail)) {
+                continue;
+            }
+            if (!orderDetlPakoutService.deleteById(detail.getId())) {
+                throw new CoolException("鍒犻櫎鏈笅鍙戝嚭搴撹鍗曟槑缁嗗け璐ワ細" + detail.getOrderNo());
+            }
+            removed++;
+        }
+        return removed;
+    }
+
+    private void assertNoNonReplaceablePendingDetailConflict(OrderPakout order, List<OutTaskParam> params) {
+        if (order == null || Cools.isEmpty(params)) {
+            return;
+        }
+        Set<String> newPalletIds = params.stream()
+                .filter(Objects::nonNull)
+                .map(OutTaskParam::getPalletId)
+                .filter(palletId -> !Cools.isEmpty(palletId))
+                .collect(Collectors.toCollection(LinkedHashSet::new));
+        if (newPalletIds.isEmpty()) {
+            return;
+        }
+        List<OrderDetlPakout> details = orderDetlPakoutService.selectList(new EntityWrapper<OrderDetlPakout>()
+                .eq("order_id", order.getId())
+                .eq("status", 1));
+        if (Cools.isEmpty(details)) {
+            return;
+        }
+        for (OrderDetlPakout detail : details) {
+            if (detail == null || !newPalletIds.contains(detail.getPalletId()) || isUndispatchedPendingDetail(detail)) {
+                continue;
+            }
+            throw new CoolException("鎵樼洏銆�" + detail.getPalletId() + "銆嶅凡瀛樺湪宸蹭笅鍙戞垨宸插畬鎴愬嚭搴撴槑缁嗭紝鏃犳硶瑕嗙洊");
+        }
+    }
+
+    private boolean isUndispatchedPendingDetail(OrderDetlPakout detail) {
+        return detail != null
+                && safeDouble(detail.getWorkQty()) <= 0.0D
+                && safeDouble(detail.getQty()) <= 0.0D;
+    }
+
     /**
      * 鍒ゆ柇寤惰繜鍑哄簱璁㈠崟鏄惁杩樿兘琚綋鍓嶆帴鍙h姹傝鐩栥��
      *
-     * 鍏佽瑕嗙洊鐨勮竟鐣屽彧闄愪簬鈥滃凡寤鸿鍗曚絾灏氭湭鐢熸垚浠讳綍浠诲姟鈥濈殑鎯呭喌銆�
-     * 鍙 WrkMast 鎴� WrkMastLog 宸插瓨鍦紝灏辫鏄庤鍗曞凡缁忚繘鍏ユ墽琛岄摼璺垨鍘嗗彶閾捐矾锛�
-     * 鍐嶈鐩栦細鐮村潖浠诲姟銆佸簱瀛樺拰 ERP 鍥炰紶涔嬮棿鐨勫彲杩芥函鍏崇郴銆�
+     * 娲诲姩浠诲姟浠嶇劧瀛樺湪鏃朵笉鍏佽瑕嗙洊锛屽洜涓轰换鍔°�佸簱浣嶃�乄CS 鎸囦护杩樺湪鎵ц閾捐矾涓娿��
+     * 宸茬粡鍙栨秷骞跺綊妗e埌 WrkMastLog 鐨勪换鍔″厑璁搁噸涓嬪彂锛涘叾璁㈠崟鏄庣粏 work_qty 宸插湪鍙栨秷鏃跺洖婊氾紝
+     * 鏈鎺ュ彛浼氬垹闄ゆ湭涓嬪彂鏄庣粏骞舵彃鍏ユ柊鏄庣粏銆�
      */
     private void assertPendingPakoutOrderCanReplace(String orderNo) {
         List<WrkMast> activeTasks = findActiveOutboundTasks(orderNo);
@@ -1961,14 +2087,11 @@
         int activeWrkCount = wrkMastService.selectCount(new EntityWrapper<WrkMast>()
                 .eq("io_type", 101)
                 .eq("user_no", orderNo));
-        int historyWrkCount = wrkMastLogService.selectCount(new EntityWrapper<WrkMastLog>()
-                .eq("io_type", 101)
-                .eq("user_no", orderNo));
-        if (activeWrkCount > 0 || historyWrkCount > 0) {
-            throw new CoolException("鍑哄簱璁㈠崟宸插瓨鍦ㄤ换鍔℃。鎴栦换鍔″巻鍙叉。锛屾棤娉曡鐩栵細" + orderNo);
+        if (activeWrkCount > 0) {
+            throw new CoolException("鍑哄簱璁㈠崟宸插瓨鍦ㄤ换鍔℃。锛屾棤娉曡鐩栵細" + orderNo);
         }
         OrderPakout order = orderPakoutService.selectByNo(orderNo);
-        if (order != null && order.getSettle() != null && order.getSettle() > 1L) {
+        if (order != null && order.getSettle() != null && order.getSettle() > 2L) {
             throw new CoolException(orderNo + "姝e湪鍑哄簱锛屾棤娉曚慨鏀瑰崟鎹�");
         }
     }

--
Gitblit v1.9.1