From b016d1eb02dd09fd1ffcd24e4e6ddee72fd1b3d6 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 28 二月 2024 10:27:25 +0800
Subject: [PATCH] #

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/DeptController.java |   55 +++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 51 insertions(+), 4 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/DeptController.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/DeptController.java
index 5be3efb..7dbd864 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/DeptController.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/DeptController.java
@@ -11,15 +11,14 @@
 import com.zy.asrs.wcs.system.entity.Dept;
 import com.zy.asrs.wcs.system.service.DeptService;
 import com.zy.asrs.wcs.utils.ExcelUtil;
+import com.zy.asrs.wcs.utils.NodeUtils;
+import com.zy.asrs.wcs.utils.Utils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletResponse;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 @RestController
 @RequestMapping("/api")
@@ -43,6 +42,20 @@
     }
 
     @PreAuthorize("hasAuthority('system:dept:list')")
+    @PostMapping("/dept/tree")
+    public R tree(@RequestBody Map<String, Object> map) {
+//        PageParam<Dept, BaseParam> param = new PageParam<>(buildParam(map, BaseParam.class), Dept.class);
+//        QueryWrapper<Dept> wrapper = param.buildWrapper(true, queryWrapper -> queryWrapper.orderByAsc("sort"));
+        List<Dept> deptList = deptService.list(new LambdaQueryWrapper<Dept>().orderByAsc(Dept::getSort));
+        List<Dept> treeData = Utils.toTreeData(deptList, 0L, Dept::getParentId, Dept::getId, Dept::setChildren);
+        if (!Cools.isEmpty(map.get("condition"))) {
+            Utils.treeRemove(treeData, String.valueOf(map.get("condition")), Dept::getName, Dept::getChildren);
+            Utils.treeRemove(treeData, String.valueOf(map.get("condition")), Dept::getName, Dept::getChildren);
+        }
+        return R.ok().add(treeData);
+    }
+
+    @PreAuthorize("hasAuthority('system:dept:list')")
     @GetMapping("/dept/{id}")
     public R get(@PathVariable("id") Long id) {
         return R.ok().add(deptService.getById(id));
@@ -52,6 +65,24 @@
     @OperationLog("娣诲姞閮ㄩ棬")
     @PostMapping("/dept/save")
     public R save(@RequestBody Dept dept) {
+        if (dept.getParentId() != null && dept.getParentId() > 0) {
+            Dept parent = deptService.getById(dept.getParentId());
+            if (parent != null) {
+                dept.setParentName(parent.getName());
+            }
+        } else {
+            dept.setParentId(0L);
+        }
+
+        NodeUtils nodeUtils = new NodeUtils();
+        nodeUtils.generatePath0(item -> deptService.getById(item.getParentId()), dept, Dept::getId, Dept::getName, Dept::getParentId);
+        dept.setPath(nodeUtils.path.toString());
+        dept.setPathName(nodeUtils.pathName.toString());
+
+        dept.setCreateBy(getLoginUserId());
+        dept.setCreateTime(new Date());
+        dept.setUpdateBy(getLoginUserId());
+        dept.setUpdateTime(new Date());
         if (!deptService.save(dept)) {
             return R.error("娣诲姞澶辫触");
         }
@@ -62,6 +93,22 @@
     @OperationLog("淇敼閮ㄩ棬")
     @PostMapping("/dept/update")
     public R update(@RequestBody Dept dept) {
+        if (dept.getParentId() != null && dept.getParentId() > 0) {
+            Dept parent = deptService.getById(dept.getParentId());
+            if (parent != null) {
+                dept.setParentName(parent.getName());
+            }
+        } else {
+            dept.setParentId(0L);
+        }
+
+        NodeUtils nodeUtils = new NodeUtils();
+        nodeUtils.generatePath0(item -> deptService.getById(item.getParentId()), dept, Dept::getId, Dept::getName, Dept::getParentId);
+        dept.setPath(nodeUtils.path.toString());
+        dept.setPathName(nodeUtils.pathName.toString());
+
+        dept.setUpdateBy(getLoginUserId());
+        dept.setUpdateTime(new Date());
         if (!deptService.updateById(dept)) {
             return R.error("淇敼澶辫触");
         }

--
Gitblit v1.9.1