From 5b686555ac1b0a632fb1da7fd5ec717e79041c37 Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期四, 22 一月 2026 10:12:43 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/SegmentServiceImpl.java |   25 ++++++++++++++++++++-----
 1 files changed, 20 insertions(+), 5 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/SegmentServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/SegmentServiceImpl.java
index 89cdf17..7ea801d 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/SegmentServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/SegmentServiceImpl.java
@@ -74,6 +74,7 @@
                 .eq(Segment::getSerial, serial - 1)
                 .eq(Segment::getState, SegmentStateType.FINISH.toString())
                 .orderByDesc(Segment::getId)
+                .last("limit 1")
         );
     }
 
@@ -128,9 +129,10 @@
     public Boolean cancel(Long segmentId, Long userId) {
         Date now = new Date();
         Segment segment = this.getById(segmentId);
+        Long travelId = segment.getTravelId();
         String groupId = segment.getGroupId();
         // update segment list
-        List<Segment> segmentList = this.list(new LambdaQueryWrapper<Segment>().eq(Segment::getGroupId, groupId));
+        List<Segment> segmentList = this.list(new LambdaQueryWrapper<Segment>().eq(Segment::getTravelId, travelId));
         for (Segment seg : segmentList) {
             Task task = taskService.getById(segment.getTaskId());
             if (task != null &&
@@ -145,8 +147,23 @@
         }
         this.processNext(segmentList);
         // update action list
-        actionService.updateStsByGroupId(groupId, ActionStsType.EXPIRED.val());
+        if (!Cools.isEmpty(groupId)) {
+            actionService.updateStsByGroupId(groupId, ActionStsType.EXPIRED.val());
+        }
         return Boolean.TRUE;
+    }
+
+    @Override
+    public Segment getCurrWaitingSeg(Long travelId, Long agvId) {
+        List<Segment> segments = this.list(new LambdaQueryWrapper<Segment>()
+                .eq(Segment::getTravelId, travelId)
+                .eq(Segment::getAgvId, agvId)
+                .eq(Segment::getState, SegmentStateType.WAITING.toString())
+                .orderByDesc(Segment::getId)
+        );
+        if (Cools.isEmpty(segments)) {
+        }
+        return segments.stream().findFirst().orElse(null);
     }
 
     @Override
@@ -157,9 +174,7 @@
                 .eq(Segment::getEndNode, codeId)
                 .orderByDesc(Segment::getId)
         );
-
         if (Cools.isEmpty(segments)) {
-
         }
         return segments.stream().findFirst().orElse(null);
     }
@@ -169,7 +184,7 @@
         return this.baseMapper.selectUsedBackpacks(agvId, travelId);
     }
 
-    @Override
+    @Override   //todo
     public Segment getRollerWaiting(Long agvId, Long codeId, TaskPosDto.PosType posType) {
         List<Segment> segments = this.list(new LambdaQueryWrapper<Segment>()
                 .eq(Segment::getAgvId, agvId)

--
Gitblit v1.9.1