From 505fc31385d5a40a1240c4677f2493513d95085e Mon Sep 17 00:00:00 2001
From: skyouc <creaycat@gmail.com>
Date: 星期四, 27 十一月 2025 11:11:26 +0800
Subject: [PATCH] 相同票号入收货区判断

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java |   60 ++++++++++++++++++++++++++++++++----------------------------
 1 files changed, 32 insertions(+), 28 deletions(-)

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 dc089a5..cd50f8a 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
@@ -24,6 +24,7 @@
 import com.vincent.rsf.server.manager.enums.*;
 import com.vincent.rsf.server.manager.entity.*;
 import com.vincent.rsf.server.manager.service.*;
+import com.vincent.rsf.server.manager.service.impl.LocItemWorkingServiceImpl;
 import com.vincent.rsf.server.manager.service.impl.LocServiceImpl;
 import com.vincent.rsf.server.manager.service.impl.WaveOrderRelaServiceImpl;
 import com.vincent.rsf.server.system.constant.GlobalConfigCode;
@@ -99,6 +100,9 @@
     private ReportMsgService reportMsgService;
     @Autowired
     private WaveOrderRelaService waveOrderRelaService;
+    @Autowired
+    private LocItemWorkingService locItemWorkingService;
+
 
     /**
      * @param
@@ -578,19 +582,7 @@
                 throw new CoolException("浠诲姟鍘嗗彶妗d繚瀛樺け璐ワ紒锛�");
             }
             List<TaskItem> taskItems = taskItemService.list(new LambdaQueryWrapper<TaskItem>().eq(TaskItem::getTaskId, task.getId()));
-            //鍏ュ簱鍗曟嵁鏄庣粏涓婃姤
-//            if (order.getType().equals(OrderType.ORDER_OUT.type)) {
-//                try {
-//                    //涓婃姤宸插畬鎴愯鍗曡嚦ERP銆丮ES绛変笁鏂圭郴缁�
-//                    reportMsgService.reportOrders(order);
-//                    order.setReportOnce(order.getReportOnce() + 1);
-//                    if (!asnOrderService.updateById(order)) {
-//                        log.error(order.getCode() + "锛屽崟鎹笂浼犳鏁颁慨鏀瑰け璐ワ紒锛�");
-//                    }
-//                } catch (Exception e) {
-//                    log.error(e.getMessage());
-//                }
-//            }
+
             if (task.getTaskType().equals(TaskType.TASK_TYPE_IN.type)) {
                 for (TaskItem taskItem : taskItems) {
                     if (Objects.isNull(taskItem.getOrderId())) {
@@ -610,8 +602,8 @@
                     /**鍏ュ簱鍗曟槑缁嗕笂鎶�*/
                     reportMsgService.reportOrderItem(wkOrderItem);
                 }
-            } else if (task.getTaskType() >= TaskType.TASK_TYPE_OUT.type && task.getTaskType() <= TaskType.TASK_TYPE_EMPITY_OUT.type) {
-
+            } else if ((task.getTaskType() >= TaskType.TASK_TYPE_OUT.type && task.getTaskType() <= TaskType.TASK_TYPE_EMPITY_OUT.type)
+                    || task.getTaskType().equals(TaskType.TASK_TYPE_PICK_IN.type)) {
                 /**鍒ゆ柇鍗曟嵁鏄惁瀹屾垚**/
                 Set<Long> longSet = taskItems.stream().map(TaskItem::getSourceId).collect(Collectors.toSet());
                 List<WaveOrderRela> waveOrderRelas = waveOrderRelaService.list(new LambdaQueryWrapper<WaveOrderRela>()
@@ -625,23 +617,30 @@
                     throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
                 }
 
-//                Set<String> codes = taskItems.stream().map(TaskItem::getMatnrCode).collect(Collectors.toSet());
-//                List<WkOrderItem> orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>()
-//                        .in(WkOrderItem::getMatnrCode, codes)
-//                        .in(WkOrderItem::getOrderId, orderIds));
-                if (!wkOrders.isEmpty()) {
-                    throw new CoolException("鍗曟嵁涓嶅瓨鍦紒锛�");
-                }
+                Config allowChang = configService.getOne(new LambdaQueryWrapper<Config>().eq(Config::getFlag, GlobalConfigCode.ALLOW_OVER_CHANGE));
+
                 wkOrders.forEach(order -> {
-                    //妫�鏌ュ崟鎹槸鍚﹀畬鎴�
-                    if (order.getAnfme().compareTo(order.getQty()) == 0) {
-                        order.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val);
-                        if (!asnOrderService.updateById(order)) {
-                            throw new CoolException("鍑哄簱鍗曟洿鏂扮姸鎬佸け璐�");
+                    //鍒ゆ柇鏄惁鍏佽瓒呮敹锛屼笉鍏佽瓒呮敹娣诲姞鎷掓敹鍒ゆ柇
+                    if (!Objects.isNull(allowChang)) {
+                        if (!Boolean.parseBoolean(allowChang.getVal())) {
+                            if (order.getAnfme().compareTo(order.getQty()) == 0) {
+                                order.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val);
+                                if (!asnOrderService.updateById(order)) {
+                                    throw new CoolException("鍑哄簱鍗曟洿鏂扮姸鎬佸け璐�");
+                                }
+                            }
+                        } else {
+                            if (order.getAnfme().compareTo(order.getQty()) <= 0) {
+                                order.setExceStatus(AsnExceStatus.OUT_STOCK_STATUS_TASK_DONE.val);
+                                if (!asnOrderService.updateById(order)) {
+                                    throw new CoolException("鍑哄簱鍗曟洿鏂扮姸鎬佸け璐�");
+                                }
+                            }
                         }
                     }
-                });
+                    //妫�鏌ュ崟鎹槸鍚﹀畬鎴�
 
+                });
                 //鍑哄簱鍗曚笂鎶CS淇敼搴撲綅鐘舵��
                 try {
                     reportStationStatus(task);
@@ -661,6 +660,9 @@
                 itemLogs.add(itemLog);
             }
 
+            locItemWorkingService.remove(new LambdaQueryWrapper<LocItemWorking>().eq(LocItemWorking::getTaskId, task.getId()));
+
+
             if (!taskService.removeById(task.getId())) {
                 throw new CoolException("鍘熷浠诲姟鍒犻櫎澶辫触锛侊紒");
             }
@@ -673,6 +675,8 @@
                     throw new CoolException("鍘熷浠诲姟鏄庣粏鍒犻櫎澶辫触锛侊紒");
                 }
             }
+
+
         });
     }
 

--
Gitblit v1.9.1