From 83881017b6bc8157001c16312d6e5eb08d46a4ea Mon Sep 17 00:00:00 2001
From: skyouc <creaycat@gmail.com>
Date: 星期四, 20 十一月 2025 14:05:07 +0800
Subject: [PATCH] #新增 1. 出库单完成状态修改

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/TaskSchedules.java |  101 ++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 85 insertions(+), 16 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 10ab6f3..dc089a5 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
@@ -7,6 +7,8 @@
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.fasterxml.jackson.databind.cfg.CoercionAction;
 import com.fasterxml.jackson.databind.cfg.CoercionInputShape;
+import com.vincent.rsf.framework.common.Cools;
+import com.vincent.rsf.framework.common.DateUtils;
 import com.vincent.rsf.framework.common.R;
 import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.api.config.RemotesInfoProperties;
@@ -23,6 +25,7 @@
 import com.vincent.rsf.server.manager.entity.*;
 import com.vincent.rsf.server.manager.service.*;
 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;
 import com.vincent.rsf.server.system.constant.SerialRuleCode;
 import com.vincent.rsf.server.system.entity.Config;
@@ -94,6 +97,8 @@
     private BasStationService basStationService;
     @Autowired
     private ReportMsgService reportMsgService;
+    @Autowired
+    private WaveOrderRelaService waveOrderRelaService;
 
     /**
      * @param
@@ -240,7 +245,7 @@
     /**
      * 闈炲厜鐢电珯鐐逛换鍔′笅鍙�
      */
-    @Scheduled(cron = "0/25 * * * * ?  ")
+    @Scheduled(cron = "0/55 * * * * ?  ")
     @Transactional(rollbackFor = Exception.class)
     public void pubTaskToWcs() {
         Long loginUserId = SystemAuthUtils.getLoginUserId();
@@ -252,19 +257,33 @@
                 .in(Task::getTaskType, list)
                 .in(Task::getTaskStatus, integers)
                 .orderByDesc(Task::getSort));
-        for (Task task : tasks) {
-            /**绉诲簱涓嶅仛绔欑偣鎿嶄綔*/
-            if (!task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
-                BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
-                        .eq(BasStation::getStationName,
-                                task.getTaskStatus().equals(TaskStsType.GENERATE_IN.id) ? task.getOrgSite() : task.getTargSite()));
-                if (station.getType().equals(StationTypeEnum.STATION_TYPE_MUTI.type)) {
-                    continue;
+        if (tasks.isEmpty()) {
+            return;
+        }
+        Config config = configService.getOne(new LambdaQueryWrapper<Config>().eq(Config::getFlag, GlobalConfigCode.ALLOW_PUB_TASK));
+        if (!Objects.isNull(config) && !Objects.isNull(config.getVal())) {
+            Integer val = Integer.parseInt(config.getVal());
+            if (val > 1) {
+                List<Task> tasks1 = tasks.stream().sorted(Comparator.comparing(Task::getCreateTime)).collect(Collectors.toList());
+                Task task = tasks1.stream().findFirst().get();
+                if (DateUtils.diffToSeconds(task.getCreateTime(), new Date()) < val) {
+                    return;
                 }
             }
-            /**涓嬪彂鏅�氱珯鐐逛换鍔★紝鎶ラ敊鍥炴粴锛屼笉鍐嶅線涓嬫墽琛�*/
-            pubTaskToWcs(tasks);
         }
+//        for (Task task : tasks) {
+//            /**绉诲簱涓嶅仛绔欑偣鎿嶄綔*/
+//            if (!task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
+//                BasStation station = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
+//                        .eq(BasStation::getStationName,
+//                                task.getTaskStatus().equals(TaskStsType.GENERATE_IN.id) ? task.getOrgSite() : task.getTargSite()));
+//                if (station.getType().equals(StationTypeEnum.STATION_TYPE_MUTI.type)) {
+//                    continue;
+//                }
+//            }
+//        }
+        /**涓嬪彂鏅�氱珯鐐逛换鍔★紝鎶ラ敊鍥炴粴锛屼笉鍐嶅線涓嬫墽琛�*/
+        pubTaskToWcs(tasks);
     }
 
     /**
@@ -463,16 +482,19 @@
                 CommonResponse result = objectMapper.readValue(exchange.getBody(), CommonResponse.class);
                 if (result.getCode() == 200) {
                     tasks.forEach(task -> {
-                        BasStation curSta = basStationService.getOne(new LambdaQueryWrapper<BasStation>().eq(BasStation::getStationName, task.getOrgSite()));
-                        if (Objects.isNull(curSta)) {
-                            throw new CoolException("绔欑偣涓嶅瓨鍦紒锛�");
-                        }
+
                         if (task.getTaskType().equals(TaskType.TASK_TYPE_IN.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_PICK_IN.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_CHECK_IN.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_EMPITY_IN.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_MERGE_IN.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_LOC_MOVE.type)) {
+
+                            BasStation curSta = basStationService.getOne(new LambdaQueryWrapper<BasStation>().eq(BasStation::getStationName, task.getOrgSite()));
+                            if (Objects.isNull(curSta)) {
+                                throw new CoolException("绔欑偣涓嶅瓨鍦紒锛�");
+                            }
+
                             if (!taskService.update(new LambdaUpdateWrapper<Task>().eq(Task::getTaskCode, task.getTaskCode())
                                     .set(Task::getTaskStatus, TaskStsType.WCS_EXECUTE_IN.id))) {
                                 throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�");
@@ -492,6 +514,11 @@
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_MERGE_OUT.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_EMPITY_OUT.type)
                                 || task.getTaskType().equals(TaskType.TASK_TYPE_PICK_AGAIN_OUT.type)) {
+                            BasStation curSta = basStationService.getOne(new LambdaQueryWrapper<BasStation>().eq(BasStation::getStationName, task.getTargSite()));
+                            if (Objects.isNull(curSta)) {
+                                throw new CoolException("绔欑偣涓嶅瓨鍦紒锛�");
+                            }
+
                             if (!taskService.update(new LambdaUpdateWrapper<Task>().eq(Task::getTaskCode, task.getTaskCode())
                                     .set(Task::getTaskStatus, TaskStsType.WCS_EXECUTE_OUT.id))) {
                                 throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�");
@@ -552,7 +579,18 @@
             }
             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())) {
@@ -573,6 +611,37 @@
                     reportMsgService.reportOrderItem(wkOrderItem);
                 }
             } else if (task.getTaskType() >= TaskType.TASK_TYPE_OUT.type && task.getTaskType() <= TaskType.TASK_TYPE_EMPITY_OUT.type) {
+
+                /**鍒ゆ柇鍗曟嵁鏄惁瀹屾垚**/
+                Set<Long> longSet = taskItems.stream().map(TaskItem::getSourceId).collect(Collectors.toSet());
+                List<WaveOrderRela> waveOrderRelas = waveOrderRelaService.list(new LambdaQueryWrapper<WaveOrderRela>()
+                        .in(WaveOrderRela::getWaveId, longSet));
+                if (Cools.isEmpty(waveOrderRelas)) {
+                    throw new CoolException("娉㈡瀵瑰簲鍏宠仈鍗曟湭鎵惧埌");
+                }
+                Set<Long> orderIds = waveOrderRelas.stream().map(WaveOrderRela::getOrderId).collect(Collectors.toSet());
+                List<WkOrder> wkOrders = asnOrderService.listByIds(orderIds);
+                if (wkOrders.isEmpty()) {
+                    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("鍗曟嵁涓嶅瓨鍦紒锛�");
+                }
+                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("鍑哄簱鍗曟洿鏂扮姸鎬佸け璐�");
+                        }
+                    }
+                });
+
                 //鍑哄簱鍗曚笂鎶CS淇敼搴撲綅鐘舵��
                 try {
                     reportStationStatus(task);

--
Gitblit v1.9.1