From c96d7cac4e3ed8d8ab3d2ef4fbee8be372f1a3b0 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期二, 22 七月 2025 13:27:50 +0800
Subject: [PATCH] no message

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java |   70 ++++++++++++++++++++++++++---------
 1 files changed, 52 insertions(+), 18 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
index e470f48..cf17c46 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
@@ -4,11 +4,9 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.vincent.rsf.framework.exception.CoolException;
 import com.vincent.rsf.server.manager.entity.*;
-import com.vincent.rsf.server.manager.enums.CheckDiffExceStatus;
-import com.vincent.rsf.server.manager.enums.CheckExceStatus;
-import com.vincent.rsf.server.manager.enums.TaskStsType;
-import com.vincent.rsf.server.manager.enums.TaskType;
+import com.vincent.rsf.server.manager.enums.*;
 import com.vincent.rsf.server.manager.service.*;
+import com.vincent.rsf.server.manager.service.impl.LocServiceImpl;
 import com.vincent.rsf.server.system.utils.SystemAuthUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -40,6 +38,8 @@
     private CheckOrderService checkOrderService;
     @Autowired
     private CheckOrderItemService checkOrderItemService;
+    @Autowired
+    private LocServiceImpl locService;
 
     /**
      * @author Ryan
@@ -47,11 +47,25 @@
      * @description: 鑷姩鑾峰彇宸茬敓鎴愮洏鐐逛换鍔$殑鐩樼偣鍒楄〃
      * @version 1.0
      */
-    @Scheduled(cron = "0/25 * * * * ?")
+    @Scheduled(cron = "0/15 * * * * ?")
     @Transactional(rollbackFor = Exception.class)
     public void genReCheck() {
-        List<TaskItem> taskItems = taskItemService.list(new LambdaQueryWrapper<TaskItem>()
-                .notExists("SELECT 1 FROM man_check_diff_item cdi WHERE id = cdi.task_item_id"));
+        List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>()
+                .select(Task::getId)
+                        .eq(Task::getTaskStatus, TaskStsType.GENERATE_OUT.id)
+                .eq(Task::getTaskType, TaskType.TASK_TYPE_CHECK_OUT.type));
+        if (tasks.isEmpty()) {
+            return;
+        }
+        List<CheckDiffItem> list = checkDiffItemService
+                .list(new LambdaQueryWrapper<CheckDiffItem>()
+                        .select(CheckDiffItem::getTaskItemId));
+        Set<Long> taskIds = tasks.stream().map(Task::getId).collect(Collectors.toSet());
+        List<Long> itemIds = list.stream().map(CheckDiffItem::getTaskItemId).collect(Collectors.toList());
+        List<TaskItem> taskItems = taskItemService
+                .list(new LambdaQueryWrapper<TaskItem>()
+                        .in(TaskItem::getTaskId, taskIds)
+                        .notIn(!itemIds.isEmpty(), TaskItem::getId, itemIds));
         if (taskItems.isEmpty()) {
             return;
         }
@@ -60,7 +74,7 @@
         taskMps.keySet().forEach(orderId -> {
             WkOrder order = checkOrderService.getById(orderId);
             if (Objects.isNull(order)) {
-               throw new CoolException("鐩樼偣鍗曟嵁涓嶅瓨鍦紒锛�");
+                throw new CoolException("鐩樼偣鍗曟嵁涓嶅瓨鍦紒锛�");
             }
             CheckDiff checkDiff = checkDiffService.getOne(new LambdaQueryWrapper<CheckDiff>().eq(CheckDiff::getOrderId, orderId));
             if (Objects.isNull(checkDiff)) {
@@ -68,37 +82,57 @@
                 checkDiff.setAnfme(order.getAnfme())
                         .setCheckType(order.getCheckType())
                         .setOrderCode(order.getCode())
-                        .setExceStatus(CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_ING.val)
+                        .setExceStatus(CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_INIT.val)
                         .setCreateBy(loginUserId)
                         .setCreateTime(new Date())
                         .setUpdateBy(loginUserId)
                         .setUpdateTime(new Date())
                         .setOrderId(order.getId());
-                if (!checkDiffService.save(checkDiff)) {
+                if (!checkDiffService.saveOrUpdate(checkDiff)) {
                     throw new CoolException("鐩樼偣宸紓鍗曚繚瀛樺け璐ワ紒锛�");
                 }
             }
 
             List<TaskItem> items = taskMps.get(orderId);
             List<CheckDiffItem> diffItems = new ArrayList<>();
-            CheckDiff finalCheckDiff = checkDiff;
-            items.forEach(item -> {
+            for (TaskItem item : items) {
+                Task task = taskService.getById(item.getTaskId());
+                if (Objects.isNull(task)) {
+                    throw new CoolException("鏁版嵁閿欒锛氫换鍔′笉瀛樺湪锛侊紒");
+                }
                 CheckDiffItem checkDiffItem = new CheckDiffItem();
                 BeanUtils.copyProperties(item, checkDiffItem);
-                checkDiffItem.setCheckId(finalCheckDiff.getId())
+                checkDiffItem.setCheckId(checkDiff.getId())
                         .setTaskItemId(item.getId())
                         .setTaskId(item.getTaskId())
                         .setCreateBy(loginUserId)
                         .setCreateTime(new Date())
+                        .setBarcode(task.getBarcode())
                         .setUpdateBy(loginUserId)
                         .setUpdateTime(new Date())
-                        .setOrderCode(finalCheckDiff.getOrderCode());
+                        .setOrderCode(checkDiff.getOrderCode());
                 diffItems.add(checkDiffItem);
-            });
 
-           if (!checkDiffItemService.saveBatch(diffItems)) {
-               throw new CoolException("鐩樼偣宸紓鍗曚繚瀛樺け璐ワ紒锛�");
-           }
+//                if (Objects.isNull(checkDiff.getAreaId())) {
+//                    Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>()
+//                            .eq(Loc::getCode, task.getOrgLoc())
+//                            .eq(Loc::getUseStatus, LocStsType.LOC_STS_TYPE_R.type));
+//                    if (Objects.isNull(loc)) {
+//                        throw new CoolException("鐩樼偣搴撲綅涓嶅瓨鍦紒锛�");
+//                    }
+////                    finalCheckDiff.setAreaId(loc.getAreaId()).setAreaName(loc.getAreaId$());
+//                }
+            }
+
+//            checkDiff.setAreaId(finalCheckDiff.getAreaId()).setAreaName(finalCheckDiff.getAreaName());
+//
+//            if (!checkDiffService.updateById(checkDiff)) {
+//                throw new CoolException("搴撳尯淇℃伅淇敼澶辫触锛侊紒");
+//            }
+
+            if (!checkDiffItemService.saveBatch(diffItems)) {
+                throw new CoolException("鐩樼偣宸紓鍗曚繚瀛樺け璐ワ紒锛�");
+            }
         });
     }
 }

--
Gitblit v1.9.1