From 7d3040d4c742af5e13f7327e7397a0524c1ffdec Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 21 二月 2024 16:06:31 +0800
Subject: [PATCH] #

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/MenuController.java |   46 +++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 39 insertions(+), 7 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/MenuController.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/MenuController.java
index f4a6da7..1335746 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/MenuController.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/system/controller/MenuController.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.wcs.system.controller;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.zy.asrs.framework.common.Cools;
 import com.zy.asrs.framework.common.R;
@@ -18,10 +19,7 @@
 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")
@@ -47,7 +45,9 @@
     @PreAuthorize("hasAuthority('system:menu:list')")
     @PostMapping("/menu/tree")
     public R tree(@RequestBody Map<String, Object> map) {
-        List<Menu> menus = menuService.list();
+        PageParam<Menu, BaseParam> param = new PageParam<>(buildParam(map, BaseParam.class), Menu.class);
+        QueryWrapper<Menu> wrapper = param.buildWrapper(true, queryWrapper -> queryWrapper.orderByAsc("sort"));
+        List<Menu> menus = menuService.list(wrapper);
         return R.ok().add(Utils.toTreeData(menus, 0L, Menu::getParentId, Menu::getId, Menu::setChildren));
     }
 
@@ -61,11 +61,27 @@
     @OperationLog("娣诲姞鑿滃崟")
     @PostMapping("/menu/save")
     public R save(@RequestBody Menu menu) {
+        if (menu.getParentId() != null && menu.getParentId() > 0) {
+            Menu parent = menuService.getById(menu.getParentId());
+            if (parent != null) {
+                menu.setParentName(parent.getName());
+            }
+        } else {
+            menu.setParentId(0L);
+        }
+
+        NodeUtils nodeUtils = new NodeUtils();
+        nodeUtils.generatePath0(item -> menuService.getById(item.getParentId()), menu, Menu::getId, Menu::getName, Menu::getParentId);
+        menu.setPath(nodeUtils.path.toString());
+        menu.setPathName(nodeUtils.pathName.toString());
+
+        menu.setCreateBy(getLoginUserId());
+        menu.setCreateTime(new Date());
+        menu.setUpdateBy(getLoginUserId());
+        menu.setUpdateTime(new Date());
         if (!menuService.save(menu)) {
             return R.error("娣诲姞澶辫触");
         }
-        NodeUtils nodeUtils = new NodeUtils();
-        nodeUtils.generatePath(Menu.class, menu, Menu::getId, Menu::getName, Menu::getParentId);
         return R.ok("娣诲姞鎴愬姛");
     }
 
@@ -73,6 +89,22 @@
     @OperationLog("淇敼鑿滃崟")
     @PostMapping("/menu/update")
     public R update(@RequestBody Menu menu) {
+        if (menu.getParentId() != null && menu.getParentId() > 0) {
+            Menu parent = menuService.getById(menu.getParentId());
+            if (parent != null) {
+                menu.setParentName(parent.getName());
+            }
+        } else {
+            menu.setParentId(0L);
+        }
+
+        NodeUtils nodeUtils = new NodeUtils();
+        nodeUtils.generatePath0(item -> menuService.getById(item.getParentId()), menu, Menu::getId, Menu::getName, Menu::getParentId);
+        menu.setPath(nodeUtils.path.toString());
+        menu.setPathName(nodeUtils.pathName.toString());
+
+        menu.setUpdateBy(getLoginUserId());
+        menu.setUpdateTime(new Date());
         if (!menuService.updateById(menu)) {
             return R.error("淇敼澶辫触");
         }

--
Gitblit v1.9.1