From 37de2f4b0f732ca5c19582d4a340ad7c987925b5 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期三, 05 十一月 2025 22:40:47 +0800
Subject: [PATCH] feat: 部门管理多个车辆

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskController.java |  163 ++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 128 insertions(+), 35 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskController.java
index f35b74e..e9b439b 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskController.java
@@ -11,6 +11,7 @@
 import org.springframework.web.bind.annotation.PathVariable;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
 import org.springframework.web.bind.annotation.RestController;
 import com.ruoyi.common.annotation.Log;
 import com.ruoyi.common.core.controller.BaseController;
@@ -18,12 +19,14 @@
 import com.ruoyi.common.enums.BusinessType;
 import com.ruoyi.system.domain.SysTask;
 import com.ruoyi.system.domain.SysTaskLog;
+import com.ruoyi.system.domain.VehicleInfo;
 import com.ruoyi.system.domain.vo.TaskQueryVO;
 import com.ruoyi.system.domain.vo.TaskCreateVO;
 import com.ruoyi.system.domain.vo.TaskUpdateVO;
 import com.ruoyi.system.domain.vo.TaskStatisticsVO;
 import com.ruoyi.system.domain.enums.TaskStatus;
 import com.ruoyi.system.service.ISysTaskService;
+import com.ruoyi.system.service.IVehicleInfoService;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.common.core.page.TableDataInfo;
 
@@ -39,24 +42,39 @@
     
     @Autowired
     private ISysTaskService sysTaskService;
+    
+    @Autowired
+    private IVehicleInfoService vehicleInfoService;
 
     /**
-     * 鏌ヨ浠诲姟绠$悊鍒楄〃
+     * 鏌ヨ浠诲姟绠$悊鍒楄〃锛堝悗鍙扮鐞嗙锛�
+     * 绠$悊鍛樻潈闄愶紝鍙互鏌ョ湅鎵�鏈変换鍔�
      */
     @PreAuthorize("@ss.hasPermi('task:general:query')")
+    @GetMapping("/admin/list")
+    public TableDataInfo adminList(TaskQueryVO queryVO) {
+        startPage();
+        List<SysTask> list = sysTaskService.selectSysTaskList(queryVO);
+        return getDataTable(list);
+    }
+
+    /**
+     * 鏌ヨ浠诲姟鍒楄〃锛圓PP绔級
+     * 浠呮樉绀哄綋鍓嶇敤鎴风浉鍏崇殑浠诲姟锛�
+     * 1. 褰撳墠鐢ㄦ埛鎵�鍦ㄦ満鏋勭殑浠诲姟
+     * 2. 褰撳墠鐢ㄦ埛鍒涘缓鐨勪换鍔�
+     * 3. 鍒嗛厤缁欏綋鍓嶇敤鎴风殑浠诲姟
+     */
     @GetMapping("/list")
-    public TableDataInfo list(TaskQueryVO queryVO) {
+    public TableDataInfo appList(TaskQueryVO queryVO) {
         // 鍦ㄥ悗绔嚜鍔ㄨ幏鍙栧綋鍓嶇敤鎴蜂俊鎭紝瀹炵幇缁煎悎鏌ヨ
-        // 缁煎悎鏌ヨ锛氬綋鍓嶇敤鎴锋墍鍦ㄦ満鏋勪换鍔� + 褰撳墠鐢ㄦ埛鍒涘缓鐨勪换鍔� + 鍒嗛厤缁欏綋鍓嶇敤鎴风殑浠诲姟
         Long currentUserId = getUserId();
         Long currentDeptId = getDeptId();
         
-        // 濡傛灉鍓嶇娌℃湁浼犻�掕繖浜涘弬鏁帮紝鍒欎娇鐢ㄥ綋鍓嶇櫥褰曠敤鎴蜂俊鎭�
-        if (queryVO.getCreatorId() == null && queryVO.getAssigneeId() == null && queryVO.getDeptId() == null) {
-            queryVO.setDeptId(currentDeptId);
-            queryVO.setCreatorId(currentUserId);
-            queryVO.setAssigneeId(currentUserId);
-        }
+        // APP绔己鍒朵娇鐢ㄥ綋鍓嶇櫥褰曠敤鎴蜂俊鎭繘琛岃繃婊�
+        queryVO.setDeptId(currentDeptId);
+        queryVO.setCreatorId(currentUserId);
+        queryVO.setAssigneeId(currentUserId);
         
         startPage();
         List<SysTask> list = sysTaskService.selectSysTaskList(queryVO);
@@ -64,11 +82,11 @@
     }
 
     /**
-     * 瀵煎嚭浠诲姟绠$悊鍒楄〃
+     * 瀵煎嚭浠诲姟绠$悊鍒楄〃锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:export')")
     @Log(title = "浠诲姟绠$悊", businessType = BusinessType.EXPORT)
-    @PostMapping("/export")
+    @PostMapping("/admin/export")
     public void export(HttpServletResponse response, TaskQueryVO queryVO) {
         List<SysTask> list = sysTaskService.selectSysTaskList(queryVO);
         ExcelUtil<SysTask> util = new ExcelUtil<SysTask>(SysTask.class);
@@ -76,61 +94,119 @@
     }
 
     /**
-     * 鑾峰彇浠诲姟绠$悊璇︾粏淇℃伅
+     * 鑾峰彇浠诲姟璇︾粏淇℃伅锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:query')")
-    @GetMapping(value = "/{taskId}")
-    public AjaxResult getInfo(@PathVariable("taskId") Long taskId) {
+    @GetMapping(value = "/admin/{taskId}")
+    public AjaxResult adminGetInfo(@PathVariable("taskId") Long taskId) {
         return success(sysTaskService.getTaskDetail(taskId));
     }
 
     /**
-     * 鏂板浠诲姟绠$悊
+     * 鑾峰彇浠诲姟璇︾粏淇℃伅锛圓PP绔級
+     */
+    @GetMapping(value = "/{taskId}")
+    public AjaxResult appGetInfo(@PathVariable("taskId") Long taskId) {
+        return success(sysTaskService.getTaskDetail(taskId));
+    }
+
+    /**
+     * 鏂板浠诲姟锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:add')")
     @Log(title = "浠诲姟绠$悊", businessType = BusinessType.INSERT)
-    @PostMapping
-    public AjaxResult add(@RequestBody TaskCreateVO createVO) {
+    @PostMapping("/admin")
+    public AjaxResult adminAdd(@RequestBody TaskCreateVO createVO) {
         return toAjax(sysTaskService.insertSysTask(createVO));
     }
 
     /**
-     * 淇敼浠诲姟绠$悊
+     * 鏂板浠诲姟锛圓PP绔級
+     */
+    @Log(title = "浠诲姟鍒涘缓", businessType = BusinessType.INSERT)
+    @PostMapping
+    public AjaxResult appAdd(@RequestBody TaskCreateVO createVO) {
+        return toAjax(sysTaskService.insertSysTask(createVO));
+    }
+
+    /**
+     * 淇敼浠诲姟锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:edit')")
     @Log(title = "浠诲姟绠$悊", businessType = BusinessType.UPDATE)
-    @PutMapping
-    public AjaxResult edit(@RequestBody TaskUpdateVO updateVO) {
+    @PutMapping("/admin")
+    public AjaxResult adminEdit(@RequestBody TaskUpdateVO updateVO) {
         return toAjax(sysTaskService.updateSysTask(updateVO));
     }
 
     /**
-     * 鍒犻櫎浠诲姟绠$悊
+     * 淇敼浠诲姟锛圓PP绔級
      */
-    @PreAuthorize("@ss.hasPermi('task:general:remove')")
-    @Log(title = "浠诲姟绠$悊", businessType = BusinessType.DELETE)
+    @Log(title = "浠诲姟淇敼", businessType = BusinessType.UPDATE)
+    @PutMapping
+    public AjaxResult appEdit(@RequestBody TaskUpdateVO updateVO) {
+        return toAjax(sysTaskService.updateSysTask(updateVO));
+    }
+
+    /**
+     * 鍒犻櫎浠诲姟锛圓PP绔級
+     */
+    @Log(title = "浠诲姟鍒犻櫎", businessType = BusinessType.DELETE)
     @DeleteMapping("/{taskIds}")
-    public AjaxResult remove(@PathVariable Long[] taskIds) {
+    public AjaxResult appRemove(@PathVariable Long[] taskIds) {
         return toAjax(sysTaskService.deleteSysTaskByTaskIds(taskIds));
     }
 
     /**
-     * 鍒嗛厤浠诲姟
+     * 鍒犻櫎浠诲姟锛堝悗鍙扮鐞嗙锛�
      */
-    @PreAuthorize("@ss.hasPermi('task:general:assign')")
+    @PreAuthorize("@ss.hasPermi('task:general:remove')")
+    @Log(title = "浠诲姟绠$悊", businessType = BusinessType.DELETE)
+    @DeleteMapping("/admin/{taskIds}")
+    public AjaxResult adminRemove(@PathVariable Long[] taskIds) {
+        return toAjax(sysTaskService.deleteSysTaskByTaskIds(taskIds));
+    }
+
+    /**
+     * 鍒嗛厤浠诲姟锛堝悗鍙扮鐞嗙锛�
+     */
+    @PreAuthorize("@ss.hasPermi('task:general:edit')")
     @Log(title = "浠诲姟鍒嗛厤", businessType = BusinessType.UPDATE)
-    @PutMapping("/{taskId}/assign")
-    public AjaxResult assignTask(@PathVariable Long taskId, @RequestBody AssignTaskRequest request) {
+    @PutMapping("/admin/{taskId}/assign")
+    public AjaxResult adminAssignTask(@PathVariable Long taskId, @RequestBody AssignTaskRequest request) {
         return toAjax(sysTaskService.assignTask(taskId, request.getAssigneeId(), request.getRemark()));
     }
 
     /**
-     * 鏇存柊浠诲姟鐘舵��
+     * 鍒嗛厤浠诲姟锛圓PP绔級
      */
-    @PreAuthorize("@ss.hasPermi('task:general:status')")
+    @Log(title = "浠诲姟鍒嗛厤", businessType = BusinessType.UPDATE)
+    @PutMapping("/{taskId}/assign")
+    public AjaxResult appAssignTask(@PathVariable Long taskId, @RequestBody AssignTaskRequest request) {
+        return toAjax(sysTaskService.assignTask(taskId, request.getAssigneeId(), request.getRemark()));
+    }
+
+    /**
+     * 鏇存柊浠诲姟鐘舵�侊紙鍚庡彴绠$悊绔級
+     */
+    @PreAuthorize("@ss.hasPermi('task:general:edit')")
+    @Log(title = "浠诲姟鐘舵�佸彉鏇�", businessType = BusinessType.UPDATE)
+    @PutMapping("/admin/{taskId}/status")
+    public AjaxResult adminChangeTaskStatus(@PathVariable Long taskId, @RequestBody ChangeStatusRequest request) {
+        TaskStatus newStatus = TaskStatus.getByCode(request.getTaskStatus());
+        if (newStatus == null) {
+            return error("鏃犳晥鐨勪换鍔$姸鎬�");
+        }
+        return toAjax(sysTaskService.changeTaskStatus(taskId, newStatus, request.getRemark()));
+    }
+
+    /**
+     * 鏇存柊浠诲姟鐘舵�侊紙APP绔級
+     * 鏀寔GPS浣嶇疆淇℃伅涓婃姤
+     */
     @Log(title = "浠诲姟鐘舵�佸彉鏇�", businessType = BusinessType.UPDATE)
     @PutMapping("/{taskId}/status")
-    public AjaxResult changeTaskStatus(@PathVariable Long taskId, @RequestBody ChangeStatusRequest request) {
+    public AjaxResult appChangeTaskStatus(@PathVariable Long taskId, @RequestBody ChangeStatusRequest request) {
         TaskStatus newStatus = TaskStatus.getByCode(request.getTaskStatus());
         if (newStatus == null) {
             return error("鏃犳晥鐨勪换鍔$姸鎬�");
@@ -157,9 +233,8 @@
     }
 
     /**
-     * 鏌ヨ浠诲姟缁熻淇℃伅
+     * 鏌ヨ浠诲姟缁熻淇℃伅锛圓PP绔級
      */
-    @PreAuthorize("@ss.hasPermi('task:general:query')")
     @GetMapping("/statistics")
     public AjaxResult getStatistics() {
         TaskStatisticsVO statistics = sysTaskService.getTaskStatistics();
@@ -167,9 +242,18 @@
     }
 
     /**
-     * 鏌ヨ瓒呮椂浠诲姟鍒楄〃
+     * 鏌ヨ浠诲姟缁熻淇℃伅锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:query')")
+    @GetMapping("/admin/statistics")
+    public AjaxResult adminGetStatistics() {
+        TaskStatisticsVO statistics = sysTaskService.getTaskStatistics();
+        return success(statistics);
+    }
+
+    /**
+     * 鏌ヨ瓒呮椂浠诲姟鍒楄〃锛圓PP绔級
+     */
     @GetMapping("/overdue")
     public AjaxResult getOverdueTasks() {
         List<SysTask> list = sysTaskService.selectOverdueTasks();
@@ -177,9 +261,18 @@
     }
 
     /**
-     * 鏌ヨ鎴戠殑浠诲姟鍒楄〃
+     * 鏌ヨ瓒呮椂浠诲姟鍒楄〃锛堝悗鍙扮鐞嗙锛�
      */
     @PreAuthorize("@ss.hasPermi('task:general:query')")
+    @GetMapping("/admin/overdue")
+    public AjaxResult adminGetOverdueTasks() {
+        List<SysTask> list = sysTaskService.selectOverdueTasks();
+        return success(list);
+    }
+
+    /**
+     * 鏌ヨ鎴戠殑浠诲姟鍒楄〃锛圓PP绔級
+     */
     @GetMapping("/my")
     public AjaxResult getMyTasks() {
         List<SysTask> list = sysTaskService.selectMyTasks(getUserId());

--
Gitblit v1.9.1