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