From 5efde10d84194cb7e5ace0336f5d694898e4652b Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期一, 07 十月 2024 14:06:26 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/MissionServiceImpl.java | 63 ++++++++++++++++++++++++++++++- 1 files changed, 61 insertions(+), 2 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/MissionServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/MissionServiceImpl.java index 65656a3..6634b81 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/MissionServiceImpl.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/MissionServiceImpl.java @@ -2,15 +2,19 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.zy.acs.framework.common.Cools; +import com.zy.acs.manager.common.exception.BusinessException; import com.zy.acs.manager.manager.controller.result.MissionVo; import com.zy.acs.manager.manager.entity.*; +import com.zy.acs.manager.manager.enums.ActionStsType; +import com.zy.acs.manager.manager.enums.BusStsType; import com.zy.acs.manager.manager.enums.SegmentStateType; +import com.zy.acs.manager.manager.enums.TaskStsType; import com.zy.acs.manager.manager.service.*; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; -import java.util.ArrayList; -import java.util.List; +import java.util.*; import java.util.stream.Collectors; /** @@ -29,6 +33,8 @@ private AgvDetailService agvDetailService; @Autowired private TaskService taskService; + @Autowired + private BusService busService; @Override public List<MissionVo> getList(Long agvId, String groupNo) { @@ -112,6 +118,59 @@ return vo; } + @Override + @Transactional + public Boolean resend(List<Action> actionList) { + if (Cools.isEmpty(actionList)) { + return Boolean.FALSE; + } + String actionGroupId = actionService.getById(actionList.get(0).getId()).getGroupId(); + actionService.updateStsByGroupId(actionGroupId, ActionStsType.EXPIRED.val()); + List<Action> newActionList = new ArrayList<>(); + Date now = new Date(); + for (Action item : actionList) { + Action action = actionService.getById(item.getId()); + action.setActionSts(ActionStsType.PREPARE.val()); + action.setIoTime(now); + action.setUpdateTime(now); + newActionList.add(action); + } + int i = newActionList.size(); + for (Action action : newActionList) { + action.setPriority(i); + if (!actionService.save(action)) { + throw new BusinessException(action.getName() + " Action Update Fail!"); + } + i -= 1; + } + + Set<Long> busIds = new HashSet<>(); + List<Long> taskIds = actionService.selectTaskIdsByGroupId(actionGroupId); + for (Long taskId : taskIds) { + Task task = taskService.getById(taskId); + if (null != task) { + task.setTaskSts(TaskStsType.ASSIGN.val()); + task.setUpdateTime(now); + task.setIoTime(now); + if (!taskService.updateById(task)) { + throw new BusinessException(task.getUuid() + " Task Update Fail!"); + } + busIds.add(task.getBusId()); + } + } + for (Long busId : busIds) { + Bus bus = busService.getById(busId); + if (null != bus) { + bus.setBusSts(BusStsType.PROGRESS.val()); + bus.setUpdateTime(now); + if (!busService.updateById(bus)) { + throw new BusinessException(bus.getUuid() + " Bus Update Fail!"); + } + } + } + return Boolean.TRUE; + } + public Double calcProgress(String currCode, List<Action> actionList) { double progress = 0D; if (Cools.isEmpty(actionList, currCode)) { -- Gitblit v1.9.1