From ecdc2cadd4a21b80de4e30e38878fdeb39084e3f Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 23 六月 2025 17:05:12 +0800
Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/WaveSchedules.java |   84 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 84 insertions(+), 0 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/WaveSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/WaveSchedules.java
new file mode 100644
index 0000000..418a8fa
--- /dev/null
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/WaveSchedules.java
@@ -0,0 +1,84 @@
+package com.vincent.rsf.server.manager.schedules;
+
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.vincent.rsf.framework.exception.CoolException;
+import com.vincent.rsf.server.common.constant.Constants;
+import com.vincent.rsf.server.manager.entity.Wave;
+import com.vincent.rsf.server.manager.entity.WaveItem;
+import com.vincent.rsf.server.manager.enums.WaveExceStatus;
+import com.vincent.rsf.server.manager.enums.WaveItemExceStatus;
+import com.vincent.rsf.server.manager.service.WaveItemService;
+import com.vincent.rsf.server.manager.service.WaveService;
+import com.vincent.rsf.server.system.constant.GlobalConfigCode;
+import com.vincent.rsf.server.system.entity.Config;
+import com.vincent.rsf.server.system.service.ConfigService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.scheduling.annotation.Scheduled;
+import org.springframework.stereotype.Component;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+/**
+* @author Ryan
+* @description 娉㈡瀹氭椂浠诲姟
+* @param
+* @return
+* @time 2025/6/23 13:49
+*/
+@Component
+public class WaveSchedules {
+
+
+    @Autowired
+    private WaveService waveService;
+
+    @Autowired
+    private WaveItemService waveItemService;
+
+    @Autowired
+    private ConfigService configService;
+
+
+
+    /**
+    * @author Ryan
+    * @description 鑷姩涓嬪彂娉㈡浠诲姟
+    * @param
+    * @return
+    * @time 2025/6/23 13:52
+    */
+    @Scheduled(cron = "0/15 * * * * ?")
+    public void autoGenerateTask() {
+        Config config = configService.getOne(new LambdaQueryWrapper<Config>().eq(Config::getFlag, GlobalConfigCode.WAVE_AUTO_EXCE_TASK));
+        if (Objects.isNull(config) || !Boolean.parseBoolean(config.getVal())) {
+            return;
+        }
+        List<Wave> list = waveService.list(new LambdaQueryWrapper<Wave>()
+                        .select(Wave::getId)
+                .eq(Wave::getExceStatus, WaveExceStatus.WAVE_EXCE_STATUS_INIT.val));
+        if (list.isEmpty()) {
+            return;
+        }
+        List<Long> longs = list.stream().map(Wave::getId).collect(Collectors.toList());
+
+        List<WaveItem> waveItems = waveItemService.list(new LambdaQueryWrapper<WaveItem>()
+                .in(WaveItem::getId, longs)
+                .eq(WaveItem::getExceStatus, WaveItemExceStatus.WAVE_ITEM_EXCE_STATUS_UN.val)
+        );
+        if (waveItems.isEmpty()) {
+            return;
+        }
+        Map<Long, List<WaveItem>> listMap = waveItems.stream().collect(Collectors.groupingBy(WaveItem::getWaveId));
+        listMap.keySet().forEach(waveId -> {
+            Map<String, Object> params = new HashMap<>();
+            params.put("wave", waveId);
+            params.put("waveItems", waveItems);
+            waveService.waveToTask(params, waveId);
+        });
+    }
+}

--
Gitblit v1.9.1