From f532c3f25335deb1bc5ff9cd6fa712cf9b222343 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 24 九月 2024 15:09:01 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java | 39 +++++++++++++++++++++++++++++++++++++-- 1 files changed, 37 insertions(+), 2 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java index 6a62262..02329f3 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java @@ -15,6 +15,7 @@ import com.zy.acs.manager.manager.entity.Bus; import com.zy.acs.manager.manager.entity.Task; import com.zy.acs.manager.manager.enums.BusStsType; +import com.zy.acs.manager.manager.enums.TaskStsType; import com.zy.acs.manager.manager.service.BusService; import com.zy.acs.manager.manager.service.LocService; import com.zy.acs.manager.manager.service.StaService; @@ -22,6 +23,7 @@ import com.zy.acs.manager.system.controller.BaseController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; +import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; @@ -51,8 +53,8 @@ BaseParam baseParam = buildParam(map, BaseParam.class); PageParam<Bus, BaseParam> pageParam = new PageParam<>(baseParam, Bus.class); QueryWrapper<Bus> wrapper = pageParam.buildWrapper(true); - if (createTimeDesc(pageParam.getOrders())) { - wrapper.last(businessSortService.getSql(BusStsType.class, "bus_sts")); + if (hasCreateTimeDesc(pageParam.getOrders())) { + wrapper.last(businessSortService.getOrderBySql(BusStsType.class, "bus_sts")); } PageParam<Bus, BaseParam> page = busService.page(pageParam, wrapper); for (Bus record : page.getRecords()) { @@ -153,4 +155,37 @@ ExcelUtil.build(ExcelUtil.create(busService.list(), Bus.class), response); } + @PreAuthorize("hasAuthority('manager:bus:update')") + @OperationLog("Cancel Bus") + @GetMapping("/bus/cancel/{id}") + @Transactional + public R cancel(@PathVariable Long id) { + Bus bus = busService.getById(id); + if (null == bus) { + return R.error("Cancel Fail"); + } + if (!bus.getBusStsEl().equals(BusStsType.RECEIVE.toString())) { + return R.error("Cancel Fail"); + } + List<Task> taskList = taskService.list(new LambdaQueryWrapper<Task>() + .eq(Task::getBusId, bus.getId()) + .in(Task::getTaskSts, TaskStsType.INIT.val(), TaskStsType.WAITING.val())); + if (!Cools.isEmpty(taskList)) { + for (Task task : taskList) { + taskService.cancel(task.getId(), getLoginUserId()); + } + } + if (0 == taskService.count(new LambdaQueryWrapper<Task>().eq(Task::getBusId, bus.getId()).eq(Task::getTaskSts, TaskStsType.COMPLETE.val()))) { + bus.setBusSts(BusStsType.CANCEL.val()); + } else { + bus.setBusSts(BusStsType.FINISH.val()); + } + bus.setUpdateTime(new Date()); + bus.setUpdateBy(getLoginUserId()); + if (!busService.updateById(bus)) { + return R.error("Cancel Fail"); + } + return R.ok("Cancel Success"); + } + } -- Gitblit v1.9.1