From 4fe1a741d807b55f7fc14aed85e232b9d7972425 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 23 九月 2024 13:28:44 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/BusController.java |   55 +++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 43 insertions(+), 12 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 94c0b6f..84e9973 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
@@ -4,13 +4,18 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.zy.acs.framework.common.Cools;
 import com.zy.acs.framework.common.R;
-import com.zy.acs.manager.common.utils.ExcelUtil;
 import com.zy.acs.manager.common.annotation.OperationLog;
-import com.zy.acs.manager.common.domain.BaseParam;
-import com.zy.acs.manager.common.domain.KeyValVo;
-import com.zy.acs.manager.common.domain.PageParam;
+import com.zy.acs.manager.common.domain.*;
+import com.zy.acs.manager.common.utils.ExcelUtil;
+import com.zy.acs.manager.core.service.MainService;
+import com.zy.acs.manager.manager.controller.param.BusCreateParam;
+import com.zy.acs.manager.manager.controller.param.OpenBusSubmitParam;
 import com.zy.acs.manager.manager.entity.Bus;
+import com.zy.acs.manager.manager.entity.Task;
 import com.zy.acs.manager.manager.service.BusService;
+import com.zy.acs.manager.manager.service.LocService;
+import com.zy.acs.manager.manager.service.StaService;
+import com.zy.acs.manager.manager.service.TaskService;
 import com.zy.acs.manager.system.controller.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
@@ -25,13 +30,25 @@
 
     @Autowired
     private BusService busService;
+    @Autowired
+    private MainService mainService;
+    @Autowired
+    private StaService staService;
+    @Autowired
+    private LocService locService;
+    @Autowired
+    private TaskService taskService;
 
     @PreAuthorize("hasAuthority('manager:bus:list')")
     @PostMapping("/bus/page")
     public R page(@RequestBody Map<String, Object> map) {
         BaseParam baseParam = buildParam(map, BaseParam.class);
         PageParam<Bus, BaseParam> pageParam = new PageParam<>(baseParam, Bus.class);
-        return R.ok().add(busService.page(pageParam, pageParam.buildWrapper(true)));
+        PageParam<Bus, BaseParam> page = busService.page(pageParam, pageParam.buildWrapper(true));
+        for (Bus record : page.getRecords()) {
+            record.setTasksNum(taskService.count(new LambdaQueryWrapper<Task>().eq(Task::getBusId, record.getId())));
+        }
+        return R.ok().add(page);
     }
 
     @PreAuthorize("hasAuthority('manager:bus:list')")
@@ -55,14 +72,28 @@
     @PreAuthorize("hasAuthority('manager:bus:save')")
     @OperationLog("Create Bus")
     @PostMapping("/bus/save")
-    public R save(@RequestBody Bus bus) {
-        bus.setCreateBy(getLoginUserId());
-        bus.setCreateTime(new Date());
-        bus.setUpdateBy(getLoginUserId());
-        bus.setUpdateTime(new Date());
-        if (!busService.save(bus)) {
-            return R.error("Save Fail");
+    public R save(@RequestBody BusCreateParam param) {
+        OpenBusSubmitParam submitParam = new OpenBusSubmitParam();
+        submitParam.setBatch(param.getBusNo());
+        for (TaskIdByLongDto dto : param.getTaskList()) {
+            TaskDto taskDto = new TaskDto();
+            taskDto.setSeqNum(dto.getSeqNum());
+            taskDto.setPriority(dto.getPriority());
+            if (!Cools.isEmpty(dto.getOriSta())) {
+                taskDto.setOriSta(staService.getById(dto.getOriSta()).getStaNo());
+            }
+            if (!Cools.isEmpty(dto.getOriLoc())) {
+                taskDto.setOriLoc(locService.getById(dto.getOriLoc()).getLocNo());
+            }
+            if (!Cools.isEmpty(dto.getDestSta())) {
+                taskDto.setDestSta(staService.getById(dto.getDestSta()).getStaNo());
+            }
+            if (!Cools.isEmpty(dto.getDestLoc())) {
+                taskDto.setDestLoc(locService.getById(dto.getDestLoc()).getLocNo());
+            }
+            submitParam.getTaskList().add(taskDto);
         }
+        Bus bus = mainService.generateBusAndTask(submitParam, param.getMemo());
         return R.ok("Save Success").add(bus);
     }
 

--
Gitblit v1.9.1