From 1313906bb1eb983d3beece810035e7fc28d6a92f Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期二, 20 五月 2025 16:57:11 +0800 Subject: [PATCH] 新增充电桩 --- zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java | 45 ++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 42 insertions(+), 3 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..d959c93 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,15 +53,19 @@ 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); + + long taskCompleteSts = TaskStsType.COMPLETE.val(); + long taskCancelSts = TaskStsType.CANCEL.val(); for (Bus record : page.getRecords()) { List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getBusId, record.getId())); if (!Cools.isEmpty(tasks)) { record.setTaskIds(tasks.stream().map(Task::getId).collect(Collectors.toList())); - record.setTasksNum(tasks.size()); + record.setTasksNum((int)tasks.stream().filter(task -> task.getTaskSts() != taskCompleteSts && task.getTaskSts() != taskCancelSts).count()); + record.setTasksNumTotal(tasks.size()); } } return R.ok().add(page); @@ -153,4 +159,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