From 276fbf9d2e719a67df9e3ec691d384854121252a Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期五, 20 六月 2025 17:22:17 +0800
Subject: [PATCH] 出库确认优化 出库容器流动功能优化

---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java |  151 ++++++++++++------------------
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/PlatformServiceImpl.java    |    5 
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/controller/OutStockController.java   |    6 
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskTimer.java                     |    5 +
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskWaveTimer.java                 |   67 +++++++++++++
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java      |   33 ------
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/WcsApiService.java          |    4 
 7 files changed, 140 insertions(+), 131 deletions(-)

diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/controller/OutStockController.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/controller/OutStockController.java
index e0c0dbe..2d82b49 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/controller/OutStockController.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/controller/OutStockController.java
@@ -121,7 +121,7 @@
      * @return
      */
     @GetMapping("/container/converyor/{code}")
-    public R containerConveyor(@PathVariable String code) {
+    public R containerConveyor(@PathVariable String code) throws Exception {
         if (StringUtil.isNullOrEmpty(code)) {
             return R.error("瀹瑰櫒缂栫爜涓嶈兘涓虹┖锛侊紒锛�");
         }
@@ -150,9 +150,7 @@
             throw new CoolException("褰撳墠浠诲姟璁㈠崟鍙蜂笉鑳戒负绌猴紒锛�");
         }
 
-         wcsApiService.slapLightLogic(request);
-
-        return R.ok();
+       return wcsApiService.slapLightLogic(request);
     }
 
 
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java
index 31833bf..f5628e3 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java
@@ -4,10 +4,6 @@
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
-import com.fasterxml.jackson.core.JsonProcessingException;
-import com.fasterxml.jackson.databind.ObjectMapper;
-import com.fasterxml.jackson.databind.cfg.CoercionAction;
-import com.fasterxml.jackson.databind.cfg.CoercionInputShape;
 import com.zy.asrs.framework.common.R;
 import com.zy.asrs.framework.exception.CoolException;
 import com.zy.asrs.wms.apis.wcs.entity.domain.SystemProperties;
@@ -23,8 +19,6 @@
 import com.zy.asrs.wms.asrs.service.*;
 import io.jsonwebtoken.lang.Collections;
 import lombok.extern.slf4j.Slf4j;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.HttpEntity;
 import org.springframework.http.HttpHeaders;
@@ -37,7 +31,6 @@
 import org.springframework.web.client.RestTemplate;
 
 import javax.annotation.Resource;
-import java.math.BigDecimal;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -281,62 +274,53 @@
      * @return
      */
     @Override
-    public synchronized R containerConveryor(String code) {
-        List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, code));
-        if (tasks.isEmpty()) {
-            return R.error("瀹瑰櫒鐮佷换鍔′笉瀛樺湪锛侊紒");
-        } else if (tasks.size() > 1) {
-            return R.error("瀹瑰櫒鐮佷换鍔¢敊璇紒锛�");
-        }
-        tasks.forEach(task -> {
-            try {
-                ConveyorStarParam conveyorStarParam = new ConveyorStarParam();
-                conveyorStarParam.setSlotCode(task.getOriginSite())
-                        .setContainerCode(task.getBarcode());
-                if (task.getTaskType() == 101) { //浠诲姟绫诲瀷涓�101鍏ㄧ洏鍑哄簱锛岀洿鎺ュ彇涓嬪鍣紝浼�200
-                    conveyorStarParam.setDirection("200");
-                } else if (task.getTaskType() == 103 || task.getTaskType() == 107) { //濡傛灉涓轰换鍔$被鍨嬩负103锛岄渶璧板洖搴撴搷浣滐紝浼�100
-                    conveyorStarParam.setDirection("100");
-                }
-                //璋冪敤涓夋柟鎺ュ彛锛屽皢浠诲姟鎺ㄩ�佽嚦ESS骞冲彴
-                MultiValueMap<String, Object> params = new LinkedMultiValueMap<>();
-                // 璁剧疆璇锋眰鍙傛暟
-                HttpHeaders headers = new HttpHeaders();
-                headers.add("Content-Type", "application/json");
-                headers.add("api-version", "v2.0");
-                HttpEntity httpEntity = new HttpEntity<>(conveyorStarParam, headers);
-                log.info("璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", HttpEssUtils.CONVEYOR_START, JSONObject.toJSONString(conveyorStarParam));
-                ResponseEntity<String> exchange = restTemplate.exchange("http://192.168.2.200:9046/conveyor/moveContainer", HttpMethod.POST, httpEntity, String.class);
-//                HttpHeaders headers = new HttpHeaders();
-//                headers.add("Content-Type", "application/json");
-//                HttpEntity httpEntity = new HttpEntity<>(params, headers);
-//                // 璇锋眰
-//                ResponseEntity<String> exchange = restTemplate.exchange(HttpEssUtils.CONVEYOR_START, HttpMethod.POST, httpEntity, String.class);
-                log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange);
-                if (exchange.getBody() == null) {
-                    throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒");
-                } else {
-                    CommonReponse commonReponse = JSON.toJavaObject(JSON.parseObject(exchange.getBody()), CommonReponse.class);
-                    if (commonReponse.getCode() == 0) {
-                        //娴佸姩閫氱煡涓嬪彂瀹屾垚鍚庯紝淇敼浠诲姟鐘舵�佷负杈撻�佺嚎娴佸姩涓�傘��
-                        if (task.getTaskType() == 103 || task.getTaskType() == 107) {
-                            //鏇存柊搴撳瓨淇℃伅,淇敼浠诲姟鐘舵�佷负4 锛圧CS瀹瑰櫒娴佸姩浠诲姟宸蹭笅鍙戯級
-                            workService.pickTask(task.getId());
-            //                taskService.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()).set(Task::getTaskSts, TaskStsType.WCS_CONVEYOR_START))
-                        } else {
-                            taskService.update(new LambdaUpdateWrapper<Task>()
-                                    .eq(Task::getId, task.getId())
-                                    .set(Task::getTaskSts, TaskStsType.COMPLETE_OUT.id));
-                        }
-                        log.info(task.getTaskNo() + "涓嬪彂娴佸姩閫氱煡" + commonReponse.getMsg());
-                    } else {
-                        throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒");
-                    }
-                }
-            } catch (Exception ex) {
-                log.error(ex.getMessage());
+    @Transactional(rollbackFor = Exception.class)
+    public synchronized R containerConveryor(String code) throws Exception{
+        Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, code));
+        if (Objects.isNull(task)) {
+            throw new CoolException("瀹瑰櫒鐮佷换鍔′笉瀛樺湪锛侊紒");
+        } 
+        try {
+            ConveyorStarParam conveyorStarParam = new ConveyorStarParam();
+            conveyorStarParam.setSlotCode(task.getOriginSite())
+                    .setContainerCode(task.getBarcode());
+            if (task.getTaskType() == 101) { //浠诲姟绫诲瀷涓�101鍏ㄧ洏鍑哄簱锛岀洿鎺ュ彇涓嬪鍣紝浼�200
+                conveyorStarParam.setDirection("200");
+            } else if (task.getTaskType() == 103 || task.getTaskType() == 107) { //濡傛灉涓轰换鍔$被鍨嬩负103锛岄渶璧板洖搴撴搷浣滐紝浼�100
+                conveyorStarParam.setDirection("100");
             }
-        });
+            //璋冪敤涓夋柟鎺ュ彛锛屽皢浠诲姟鎺ㄩ�佽嚦ESS骞冲彴
+            MultiValueMap<String, Object> params = new LinkedMultiValueMap<>();
+            // 璁剧疆璇锋眰鍙傛暟
+            HttpHeaders headers = new HttpHeaders();
+            headers.add("Content-Type", "application/json");
+            headers.add("api-version", "v2.0");
+            HttpEntity httpEntity = new HttpEntity<>(conveyorStarParam, headers);
+            log.info("璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", HttpEssUtils.CONVEYOR_START, JSONObject.toJSONString(conveyorStarParam));
+            ResponseEntity<String> exchange = restTemplate.exchange("http://192.168.2.200:9046/conveyor/moveContainer", HttpMethod.POST, httpEntity, String.class);
+            log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange);
+            if (exchange.getBody() == null) {
+                throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒");
+            } else {
+                CommonReponse commonReponse = JSON.toJavaObject(JSON.parseObject(exchange.getBody()), CommonReponse.class);
+                if (commonReponse.getCode() == 0) {
+                    //娴佸姩閫氱煡涓嬪彂瀹屾垚鍚庯紝淇敼浠诲姟鐘舵�佷负杈撻�佺嚎娴佸姩涓�傘��
+                    if (task.getTaskType() == 103 || task.getTaskType() == 107) {
+                        //鏇存柊搴撳瓨淇℃伅,淇敼浠诲姟鐘舵�佷负4 锛圧CS瀹瑰櫒娴佸姩浠诲姟宸蹭笅鍙戯級
+                        workService.pickTask(task.getId());
+                    } else {
+                        taskService.update(new LambdaUpdateWrapper<Task>()
+                                .eq(Task::getId, task.getId())
+                                .set(Task::getTaskSts, TaskStsType.COMPLETE_OUT.id));
+                    }
+                    log.info(task.getTaskNo() + "涓嬪彂娴佸姩閫氱煡" + commonReponse.getMsg());
+                } else {
+                    throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒");
+                }
+            }
+        } catch (Exception ex) {
+            log.error("UNK",  ex);
+        }
         return R.ok();
     }
 
@@ -355,10 +339,11 @@
      * 鎷嶇伅鎷f枡閫昏緫锛岃缁嗚鏄庤鎺ュ彛璋冪敤璇存槑
      *
      * @param request
+     * @return
      */
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public void slapLightLogic(Map<String, Object> request) {
+    public R slapLightLogic(Map<String, Object> request) {
         String taskNo = request.get("taskNo").toString();
         String orderNo = request.get("orderNo").toString();
 
@@ -370,19 +355,17 @@
         //* 1. 鍒ゆ柇褰撳墠瀹瑰櫒鏄惁杩樻湁鐗╂枡鏈嫞锛屾湭鎷e畬闂伅锛屾嫞瀹岄�氱煡瀹瑰櫒娴佸姩锛屽苟鐏伅
         SlapLightControlParam slapParam = new SlapLightControlParam();
         MultiValueMap<String, Object> params = new LinkedMultiValueMap<>();
-        //榛樿娴佸姩
-        boolean converyor = false;
         //鍒ゆ柇褰撳墠浠诲姟鏄惁杩樻湁鐗╂枡鏈嫞
         if (!checked(orderNo, taskNo)) {
+            log.info("鏈畬鎴愰棯鐏姹傚湴鍧�锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
             //璋冪敤涓夋柟鎺ュ彛,闂伅涓嶅仛鎿嶄綔
             // 璁剧疆璇锋眰鍙傛暟
-            params.add("params", JSONObject.toJSONString(slapParam));
-            log.info("鏈畬鎴愰棯鐏姹傚湴鍧�锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
+            throw new CoolException("褰撳墠浠诲姟鏈畬鎴愶紝涓嶈兘鎵ц姝ゆ搷浣滐紒锛�");
+//            params.add("params", JSONObject.toJSONString(slapParam));
         } else {
             //璋冪敤涓夋柟鎺ュ彛,鐏伅閫氱煡瀹瑰櫒娴佸姩锛� 浼犵伃鐏弬鏁�
             //todo 鍒ゆ柇褰撳墠璁㈠崟鏄惁瀹屾垚锛屽畬鎴愮伃鐏紝鏈畬鎴愪繚鎸佹嫞璐х姸鎬佷寒鐏�
             Order one = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, orderNo));
-
             if (Objects.isNull(one)) {
                 throw new CoolException("褰撳墠璁㈠崟鏄庣粏涓嶅瓨鍦紒锛�");
             }
@@ -410,36 +393,22 @@
                     }
                 }
             }
-            converyor = true;
             params.add("params", JSONObject.toJSONString(slapParam));
             log.info("瀹屾垚鐏伅璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam));
         }
 
-        if (converyor) {
-            Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getTaskNo, request.get("taskNo")));
-            if (Objects.isNull(task)) {
-                throw new CoolException("浠诲姟涓嶅瓨鍦紒锛�");
-            }
+        Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getTaskNo, request.get("taskNo")));
+        if (Objects.isNull(task)) {
+            throw new CoolException("浠诲姟涓嶅瓨鍦紒锛�");
+        }
+        try {
             containerConveryor(task.getBarcode());
+        } catch (Exception e) {
+            log.error("鎵ц寮傚父:UNK",  e);
+            throw new CoolException(e.getMessage());
         }
 
-//        HttpHeaders headers = new HttpHeaders();
-//        headers.add("Content-Type", "application/json");
-//        HttpEntity httpEntity = new HttpEntity<>(params, headers);
-//        // 璇锋眰
-//        ResponseEntity<CommonReponse> exchange = restTemplate.exchange(SystemProperties.CONVEYOR_START, HttpMethod.POST, httpEntity, CommonReponse.class);
-//        log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange);
-//        if (exchange.getBody() == null) {
-//            throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒");
-//        } else {
-//            CommonReponse response = exchange.getBody();
-//            if (response.getCode() == 0) {
-//                if (!converyor) {
-//                    //* 2. 瀹瑰櫒娴佸姩鍒ゆ柇锛屽鏋滄枡绠辨病鏈夌墿鏂� code浼�200锛� 鏈夌墿鏂欎紶100 鎵ц鍥炲簱浠诲姟,淇敼浠诲姟鐘舵�佷负  璋冪敤containerConveryor锛坱askNo锛夋柟娉�
-//                    containerConveryor(request.get("taskNo").toString());
-//                }
-//            }
-//        }
+        return R.ok();
     }
 
     /**
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/WcsApiService.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/WcsApiService.java
index 1f3dc37..04df58e 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/WcsApiService.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/WcsApiService.java
@@ -13,9 +13,9 @@
 
     void receiveTaskStatus(TasksStatusCallbackParam callbackParam, String stockType, Long hostId);
 
-    R containerConveryor(String code);
+    R containerConveryor(String code) throws Exception;
 
-    void slapLightLogic(Map<String, Object> request);
+    R slapLightLogic(Map<String, Object> request);
 
     R rfidCallback(RfidSingalRequest request);
 
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
index fa0028a..4d47603 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/MobileServiceImpl.java
@@ -531,39 +531,6 @@
             }
         });
 
-        Set<Long> waveIds = orderList.stream().map(Order::getWaveId).collect(Collectors.toSet());
-        if (waveIds.isEmpty()) {
-            throw new CoolException("娉㈡淇℃伅涓虹┖锛侊紒");
-        }
-        List<Wave> waves = waveService.list(new LambdaQueryWrapper<Wave>().in(Wave::getId, waveIds));
-        for (Wave wave : waves) {
-            WaveLog waveLog = new WaveLog();
-            waveLog.sync(wave);
-            waveLog.setId(null);
-            if (!waveLogService.save(waveLog)) {
-                throw new CoolException("娉㈡杞巻鍙插け璐�");
-            }
-
-            List<WaveDetl> waveDetls = waveDetlService.list(new LambdaQueryWrapper<WaveDetl>().eq(WaveDetl::getWaveId, wave.getId()));
-            for (WaveDetl waveDetl : waveDetls) {
-                WaveDetlLog waveDetlLog = new WaveDetlLog();
-                waveDetlLog.sync(waveDetl);
-                waveDetlLog.setId(null);
-                waveDetlLog.setWaveId(waveLog.getId());
-                if (!waveDetlLogService.save(waveDetlLog)) {
-                    throw new CoolException("娉㈡鏄庣粏杞巻鍙插け璐�");
-                }
-
-                if (!waveDetlService.removeById(waveDetl.getId())) {
-                    throw new CoolException("娉㈡鏄庣粏鍒犻櫎澶辫触");
-                }
-            }
-
-            if (!waveService.removeById(wave.getId())) {
-                throw new CoolException("娉㈡鍒犻櫎澶辫触");
-            }
-        }
-
         Set<Long> ordersSet = orderList.stream().map(Order::getId).collect(Collectors.toSet());
         List<PlatformDetl> platDetls = platformDetlService.list(new LambdaQueryWrapper<PlatformDetl>().in(PlatformDetl::getOrderId, ordersSet));
         if (platDetls.isEmpty()) {
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/PlatformServiceImpl.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/PlatformServiceImpl.java
index 0e3f61e..76f4ad9 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/PlatformServiceImpl.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/service/impl/PlatformServiceImpl.java
@@ -200,7 +200,10 @@
             platformDetl.setPlatformId(pl.getId());
             platformDetl.setPlatformNo(pl.getPlatformNo());
 
-            List<PlatformDetl> list = platformDetlService.list(new LambdaQueryWrapper<PlatformDetl>().eq(PlatformDetl::getTaskDetlId, waveSeed.getTaskDetlId()).eq(PlatformDetl::getOrderDetlId, waveSeed.getOrderDetlId()).eq(PlatformDetl::getMatnr, waveSeed.getMatnr()));
+            List<PlatformDetl> list = platformDetlService.list(new LambdaQueryWrapper<PlatformDetl>()
+                    .eq(PlatformDetl::getTaskDetlId, waveSeed.getTaskDetlId())
+                    .eq(PlatformDetl::getOrderDetlId, waveSeed.getOrderDetlId())
+                    .eq(PlatformDetl::getMatnr, waveSeed.getMatnr()));
             if (!list.isEmpty()) {
                 throw new CoolException("璁㈠崟宸插叆闆嗚揣鍖猴紒锛�");
             }
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskTimer.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskTimer.java
index 597148b..2d4ffaa 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskTimer.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskTimer.java
@@ -422,6 +422,11 @@
                 }
             }
         }
+
+
+
+
+
     }
 
     /**
diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskWaveTimer.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskWaveTimer.java
index 704f4c3..9572fb5 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskWaveTimer.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/timer/TaskWaveTimer.java
@@ -10,6 +10,10 @@
 import com.zy.asrs.wms.asrs.entity.enums.OrderSettleType;
 import com.zy.asrs.wms.asrs.entity.enums.TaskStsType;
 import com.zy.asrs.wms.asrs.service.*;
+import com.zy.asrs.wms.asrs.service.impl.WaveDetlLogServiceImpl;
+import com.zy.asrs.wms.asrs.service.impl.WaveDetlServiceImpl;
+import com.zy.asrs.wms.asrs.service.impl.WaveLogServiceImpl;
+import com.zy.asrs.wms.asrs.service.impl.WaveServiceImpl;
 import com.zy.asrs.wms.system.entity.Dict;
 import com.zy.asrs.wms.system.service.DictService;
 import com.zy.asrs.wms.utils.OrderUtils;
@@ -42,6 +46,69 @@
     private WaveSeedService waveSeedService;
     @Autowired
     private DictService dictService;
+    @Autowired
+    private WaveServiceImpl waveService;
+    @Autowired
+    private WaveLogServiceImpl waveLogService;
+    @Autowired
+    private WaveDetlServiceImpl waveDetlService;
+    @Autowired
+    private WaveDetlLogServiceImpl waveDetlLogService;
+
+
+    /**
+     * @author Ryan
+     * @date 2025/6/20
+     * @description: 娉㈡鍔犲叆鍘嗗彶妗�
+     * @version 1.0
+     */
+    @Scheduled(cron = "0/30 * * * * ? ")
+    @Transactional(rollbackFor = Exception.class)
+    public void addWaveHistories() {
+        List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getTaskSts, TaskStsType.COMPLETE_OUT.id));
+        if (tasks.isEmpty()) {
+            return;
+        }
+        for (Task task : tasks) {
+            List<TaskDetl> detls = taskDetlService.list(new LambdaQueryWrapper<TaskDetl>().eq(TaskDetl::getTaskId, task.getId()));
+            if (detls.isEmpty()) {
+                continue;
+            }
+            Set<Long> waveIds = detls.stream().map(TaskDetl::getWaveId).collect(Collectors.toSet());
+
+            if (waveIds.isEmpty()) {
+                throw new CoolException("娉㈡淇℃伅涓虹┖锛侊紒");
+            }
+            List<Wave> waves = waveService.list(new LambdaQueryWrapper<Wave>().in(Wave::getId, waveIds));
+            for (Wave wave : waves) {
+                WaveLog waveLog = new WaveLog();
+                waveLog.sync(wave);
+                waveLog.setId(null);
+                if (!waveLogService.save(waveLog)) {
+                    throw new CoolException("娉㈡杞巻鍙插け璐�");
+                }
+
+                List<WaveDetl> waveDetls = waveDetlService.list(new LambdaQueryWrapper<WaveDetl>().eq(WaveDetl::getWaveId, wave.getId()));
+                for (WaveDetl waveDetl : waveDetls) {
+                    WaveDetlLog waveDetlLog = new WaveDetlLog();
+                    waveDetlLog.sync(waveDetl);
+                    waveDetlLog.setId(null);
+                    waveDetlLog.setWaveId(waveLog.getId());
+                    if (!waveDetlLogService.save(waveDetlLog)) {
+                        throw new CoolException("娉㈡鏄庣粏杞巻鍙插け璐�");
+                    }
+                    if (!waveDetlService.removeById(waveDetl.getId())) {
+                        throw new CoolException("娉㈡鏄庣粏鍒犻櫎澶辫触");
+                    }
+                }
+                if (!waveService.removeById(wave.getId())) {
+                    throw new CoolException("娉㈡鍒犻櫎澶辫触");
+                }
+            }
+        }
+    }
+
+
 
     /**
      * modifty锛�

--
Gitblit v1.9.1