|
@@ -1,17 +1,20 @@
|
|
package com.bizmatics.service.system.impl;
|
|
package com.bizmatics.service.system.impl;
|
|
|
|
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
import com.bizmatics.common.core.util.StringUtils;
|
|
import com.bizmatics.common.core.util.StringUtils;
|
|
|
|
+import com.bizmatics.model.PlatformArea;
|
|
import com.bizmatics.model.base.TreeSelect;
|
|
import com.bizmatics.model.base.TreeSelect;
|
|
import com.bizmatics.model.constants.Constants;
|
|
import com.bizmatics.model.constants.Constants;
|
|
import com.bizmatics.model.constants.UserConstants;
|
|
import com.bizmatics.model.constants.UserConstants;
|
|
import com.bizmatics.model.system.SysMenu;
|
|
import com.bizmatics.model.system.SysMenu;
|
|
import com.bizmatics.model.system.SysRole;
|
|
import com.bizmatics.model.system.SysRole;
|
|
import com.bizmatics.model.system.SysUser;
|
|
import com.bizmatics.model.system.SysUser;
|
|
-import com.bizmatics.model.vo.MetaVo;
|
|
|
|
-import com.bizmatics.model.vo.RouterVo;
|
|
|
|
|
|
+import com.bizmatics.model.vo.*;
|
|
import com.bizmatics.persistence.mapper.system.SysMenuMapper;
|
|
import com.bizmatics.persistence.mapper.system.SysMenuMapper;
|
|
import com.bizmatics.persistence.mapper.system.SysRoleMapper;
|
|
import com.bizmatics.persistence.mapper.system.SysRoleMapper;
|
|
import com.bizmatics.persistence.mapper.system.SysRoleMenuMapper;
|
|
import com.bizmatics.persistence.mapper.system.SysRoleMenuMapper;
|
|
|
|
+import com.bizmatics.service.impl.DeviceServiceImpl;
|
|
import com.bizmatics.service.system.ISysMenuService;
|
|
import com.bizmatics.service.system.ISysMenuService;
|
|
import com.bizmatics.service.util.SecurityUtils;
|
|
import com.bizmatics.service.util.SecurityUtils;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -23,12 +26,11 @@ import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
/**
|
|
* 菜单 业务层处理
|
|
* 菜单 业务层处理
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @author yq
|
|
* @author yq
|
|
*/
|
|
*/
|
|
@Service
|
|
@Service
|
|
-public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
-{
|
|
|
|
|
|
+public class SysMenuServiceImpl implements ISysMenuService {
|
|
public static final String PREMISSION_STRING = "perms[\"{0}\"]";
|
|
public static final String PREMISSION_STRING = "perms[\"{0}\"]";
|
|
|
|
|
|
@Autowired
|
|
@Autowired
|
|
@@ -40,35 +42,33 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
@Autowired
|
|
@Autowired
|
|
private SysRoleMenuMapper roleMenuMapper;
|
|
private SysRoleMenuMapper roleMenuMapper;
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
+ private ISysMenuService menuService;
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* 根据用户查询系统菜单列表
|
|
* 根据用户查询系统菜单列表
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param userId 用户ID
|
|
* @param userId 用户ID
|
|
* @return 菜单列表
|
|
* @return 菜单列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<SysMenu> selectMenuList(Long userId)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<SysMenu> selectMenuList(Long userId) {
|
|
return selectMenuList(new SysMenu(), userId);
|
|
return selectMenuList(new SysMenu(), userId);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 查询系统菜单列表
|
|
* 查询系统菜单列表
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 菜单列表
|
|
* @return 菜单列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<SysMenu> selectMenuList(SysMenu menu, Long userId)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<SysMenu> selectMenuList(SysMenu menu, Long userId) {
|
|
List<SysMenu> menuList = null;
|
|
List<SysMenu> menuList = null;
|
|
// 管理员显示所有菜单信息
|
|
// 管理员显示所有菜单信息
|
|
- if (SysUser.isAdmin(userId))
|
|
|
|
- {
|
|
|
|
|
|
+ if (SysUser.isAdmin(userId)) {
|
|
menuList = menuMapper.selectMenuList(menu);
|
|
menuList = menuMapper.selectMenuList(menu);
|
|
- }
|
|
|
|
- else
|
|
|
|
- {
|
|
|
|
|
|
+ } else {
|
|
menu.getParams().put("userId", userId);
|
|
menu.getParams().put("userId", userId);
|
|
menuList = menuMapper.selectMenuListByUserId(menu);
|
|
menuList = menuMapper.selectMenuListByUserId(menu);
|
|
}
|
|
}
|
|
@@ -77,19 +77,16 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 根据用户ID查询权限
|
|
* 根据用户ID查询权限
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param userId 用户ID
|
|
* @param userId 用户ID
|
|
* @return 权限列表
|
|
* @return 权限列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public Set<String> selectMenuPermsByUserId(Long userId)
|
|
|
|
- {
|
|
|
|
|
|
+ public Set<String> selectMenuPermsByUserId(Long userId) {
|
|
List<String> perms = menuMapper.selectMenuPermsByUserId(userId);
|
|
List<String> perms = menuMapper.selectMenuPermsByUserId(userId);
|
|
Set<String> permsSet = new HashSet<>();
|
|
Set<String> permsSet = new HashSet<>();
|
|
- for (String perm : perms)
|
|
|
|
- {
|
|
|
|
- if (StringUtils.isNotBlank(perm))
|
|
|
|
- {
|
|
|
|
|
|
+ for (String perm : perms) {
|
|
|
|
+ if (StringUtils.isNotBlank(perm)) {
|
|
permsSet.addAll(Arrays.asList(perm.trim().split(",")));
|
|
permsSet.addAll(Arrays.asList(perm.trim().split(",")));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -98,20 +95,16 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 根据用户ID查询菜单
|
|
* 根据用户ID查询菜单
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param userId 用户名称
|
|
* @param userId 用户名称
|
|
* @return 菜单列表
|
|
* @return 菜单列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<SysMenu> selectMenuTreeByUserId(Long userId)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<SysMenu> selectMenuTreeByUserId(Long userId) {
|
|
List<SysMenu> menus = null;
|
|
List<SysMenu> menus = null;
|
|
- if (SecurityUtils.isAdmin(userId))
|
|
|
|
- {
|
|
|
|
|
|
+ if (SecurityUtils.isAdmin(userId)) {
|
|
menus = menuMapper.selectMenuTreeAll();
|
|
menus = menuMapper.selectMenuTreeAll();
|
|
- }
|
|
|
|
- else
|
|
|
|
- {
|
|
|
|
|
|
+ } else {
|
|
menus = menuMapper.selectMenuTreeByUserId(userId);
|
|
menus = menuMapper.selectMenuTreeByUserId(userId);
|
|
}
|
|
}
|
|
return getChildPerms(menus, 0);
|
|
return getChildPerms(menus, 0);
|
|
@@ -119,29 +112,26 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 根据角色ID查询菜单树信息
|
|
* 根据角色ID查询菜单树信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param roleId 角色ID
|
|
* @param roleId 角色ID
|
|
* @return 选中菜单列表
|
|
* @return 选中菜单列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<Integer> selectMenuListByRoleId(Long roleId)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<Integer> selectMenuListByRoleId(Long roleId) {
|
|
SysRole role = roleMapper.selectRoleById(roleId);
|
|
SysRole role = roleMapper.selectRoleById(roleId);
|
|
return menuMapper.selectMenuListByRoleId(roleId, role.isMenuCheckStrictly());
|
|
return menuMapper.selectMenuListByRoleId(roleId, role.isMenuCheckStrictly());
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 构建前端路由所需要的菜单
|
|
* 构建前端路由所需要的菜单
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menus 菜单列表
|
|
* @param menus 菜单列表
|
|
* @return 路由列表
|
|
* @return 路由列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<RouterVo> buildMenus(List<SysMenu> menus)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<RouterVo> buildMenus(List<SysMenu> menus) {
|
|
List<RouterVo> routers = new LinkedList<RouterVo>();
|
|
List<RouterVo> routers = new LinkedList<RouterVo>();
|
|
- for (SysMenu menu : menus)
|
|
|
|
- {
|
|
|
|
|
|
+ for (SysMenu menu : menus) {
|
|
RouterVo router = new RouterVo();
|
|
RouterVo router = new RouterVo();
|
|
router.setHidden("1".equals(menu.getVisible()));
|
|
router.setHidden("1".equals(menu.getVisible()));
|
|
router.setName(getRouteName(menu));
|
|
router.setName(getRouteName(menu));
|
|
@@ -149,19 +139,16 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
router.setComponent(getComponent(menu));
|
|
router.setComponent(getComponent(menu));
|
|
router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath()));
|
|
router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath()));
|
|
List<SysMenu> cMenus = menu.getChildren();
|
|
List<SysMenu> cMenus = menu.getChildren();
|
|
- if (!cMenus.isEmpty() && cMenus.size() > 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType()))
|
|
|
|
- {
|
|
|
|
|
|
+ if (!cMenus.isEmpty() && cMenus.size() > 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType())) {
|
|
router.setAlwaysShow(true);
|
|
router.setAlwaysShow(true);
|
|
//TODO
|
|
//TODO
|
|
List<RouterVo> routerVos = buildMenus(cMenus);
|
|
List<RouterVo> routerVos = buildMenus(cMenus);
|
|
router.setChildren(routerVos);
|
|
router.setChildren(routerVos);
|
|
router.setRedirect(routerVos.get(0).getPath());
|
|
router.setRedirect(routerVos.get(0).getPath());
|
|
- if (router.getMeta().getTitle().equals(routerVos.get(0).getMeta().getTitle())){
|
|
|
|
|
|
+ if (router.getMeta().getTitle().equals(routerVos.get(0).getMeta().getTitle())) {
|
|
routerVos.get(0).setHidden(true);
|
|
routerVos.get(0).setHidden(true);
|
|
}
|
|
}
|
|
- }
|
|
|
|
- else if (isMenuFrame(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ } else if (isMenuFrame(menu)) {
|
|
router.setMeta(null);
|
|
router.setMeta(null);
|
|
List<RouterVo> childrenList = new ArrayList<RouterVo>();
|
|
List<RouterVo> childrenList = new ArrayList<RouterVo>();
|
|
RouterVo children = new RouterVo();
|
|
RouterVo children = new RouterVo();
|
|
@@ -171,14 +158,12 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath()));
|
|
children.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon(), StringUtils.equals("1", menu.getIsCache()), menu.getPath()));
|
|
childrenList.add(children);
|
|
childrenList.add(children);
|
|
router.setChildren(childrenList);
|
|
router.setChildren(childrenList);
|
|
- }
|
|
|
|
- else if (menu.getParentId().intValue() == 0 && isInnerLink(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ } else if (menu.getParentId().intValue() == 0 && isInnerLink(menu)) {
|
|
router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon()));
|
|
router.setMeta(new MetaVo(menu.getMenuName(), menu.getIcon()));
|
|
router.setPath("/inner");
|
|
router.setPath("/inner");
|
|
List<RouterVo> childrenList = new ArrayList<RouterVo>();
|
|
List<RouterVo> childrenList = new ArrayList<RouterVo>();
|
|
RouterVo children = new RouterVo();
|
|
RouterVo children = new RouterVo();
|
|
- String routerPath = StringUtils.replaceEach(menu.getPath(), new String[] { Constants.HTTP, Constants.HTTPS }, new String[] { "", "" });
|
|
|
|
|
|
+ String routerPath = StringUtils.replaceEach(menu.getPath(), new String[]{Constants.HTTP, Constants.HTTPS}, new String[]{"", ""});
|
|
children.setPath(routerPath);
|
|
children.setPath(routerPath);
|
|
children.setComponent(UserConstants.INNER_LINK);
|
|
children.setComponent(UserConstants.INNER_LINK);
|
|
children.setName(StringUtils.capitalize(routerPath));
|
|
children.setName(StringUtils.capitalize(routerPath));
|
|
@@ -195,13 +180,12 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
public List<RouterVo> buildMenusNew(List<SysMenu> menus) {
|
|
public List<RouterVo> buildMenusNew(List<SysMenu> menus) {
|
|
List<RouterVo> routers = new LinkedList<RouterVo>();
|
|
List<RouterVo> routers = new LinkedList<RouterVo>();
|
|
RouterVo routerOne;
|
|
RouterVo routerOne;
|
|
- for (SysMenu menu : menus)
|
|
|
|
- {
|
|
|
|
|
|
+ for (SysMenu menu : menus) {
|
|
List<RouterVo> routesList = new LinkedList<RouterVo>();
|
|
List<RouterVo> routesList = new LinkedList<RouterVo>();
|
|
routerOne = checkParent(menu, menus.indexOf(menu), true);
|
|
routerOne = checkParent(menu, menus.indexOf(menu), true);
|
|
RouterVo routerVo;
|
|
RouterVo routerVo;
|
|
- for (SysMenu sysMenu:menu.getChildren()) {
|
|
|
|
- routerVo = checkParent(sysMenu,1,false);
|
|
|
|
|
|
+ for (SysMenu sysMenu : menu.getChildren()) {
|
|
|
|
+ routerVo = checkParent(sysMenu, 1, false);
|
|
routesList.add(routerVo);
|
|
routesList.add(routerVo);
|
|
}
|
|
}
|
|
routerOne.setChildren(routesList);
|
|
routerOne.setChildren(routesList);
|
|
@@ -210,20 +194,20 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
return routers;
|
|
return routers;
|
|
}
|
|
}
|
|
|
|
|
|
- public RouterVo checkParent(SysMenu menu,Integer affix,Boolean isParent){
|
|
|
|
|
|
+ public RouterVo checkParent(SysMenu menu, Integer affix, Boolean isParent) {
|
|
RouterVo router = new RouterVo();
|
|
RouterVo router = new RouterVo();
|
|
MetaVo metaVo = new MetaVo();
|
|
MetaVo metaVo = new MetaVo();
|
|
router.setPath(menu.getPath());
|
|
router.setPath(menu.getPath());
|
|
List<SysMenu> cMenus = menu.getChildren();
|
|
List<SysMenu> cMenus = menu.getChildren();
|
|
- if (isParent){
|
|
|
|
|
|
+ if (isParent) {
|
|
String redirect = cMenus.get(0).getComponent();
|
|
String redirect = cMenus.get(0).getComponent();
|
|
- Integer index = redirect.indexOf("/",2);
|
|
|
|
- redirect =redirect.substring(index,redirect.length());
|
|
|
|
- if (!menu.getMenuName().equals("告警管理")){
|
|
|
|
|
|
+ Integer index = redirect.indexOf("/", 2);
|
|
|
|
+ redirect = redirect.substring(index, redirect.length());
|
|
|
|
+ if (!menu.getMenuName().equals("告警管理")) {
|
|
redirect = redirect.replaceAll("/index", "");
|
|
redirect = redirect.replaceAll("/index", "");
|
|
}
|
|
}
|
|
router.setRedirect(redirect);
|
|
router.setRedirect(redirect);
|
|
- if (0 == affix){
|
|
|
|
|
|
+ if (0 == affix) {
|
|
metaVo.setAffix(true);
|
|
metaVo.setAffix(true);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -236,38 +220,33 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
public static void main(String[] args) {
|
|
public static void main(String[] args) {
|
|
String url = "@/a/b/c/d/e";
|
|
String url = "@/a/b/c/d/e";
|
|
- Integer index = url.indexOf("/",2);
|
|
|
|
- url =url.substring(index,url.length());
|
|
|
|
|
|
+ Integer index = url.indexOf("/", 2);
|
|
|
|
+ url = url.substring(index, url.length());
|
|
System.out.println(url);
|
|
System.out.println(url);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 构建前端所需要树结构
|
|
* 构建前端所需要树结构
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menus 菜单列表
|
|
* @param menus 菜单列表
|
|
* @return 树结构列表
|
|
* @return 树结构列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<SysMenu> buildMenuTree(List<SysMenu> menus)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<SysMenu> buildMenuTree(List<SysMenu> menus) {
|
|
List<SysMenu> returnList = new ArrayList<SysMenu>();
|
|
List<SysMenu> returnList = new ArrayList<SysMenu>();
|
|
List<Long> tempList = new ArrayList<Long>();
|
|
List<Long> tempList = new ArrayList<Long>();
|
|
- for (SysMenu dept : menus)
|
|
|
|
- {
|
|
|
|
|
|
+ for (SysMenu dept : menus) {
|
|
tempList.add(dept.getMenuId());
|
|
tempList.add(dept.getMenuId());
|
|
}
|
|
}
|
|
- for (Iterator<SysMenu> iterator = menus.iterator(); iterator.hasNext();)
|
|
|
|
- {
|
|
|
|
|
|
+ for (Iterator<SysMenu> iterator = menus.iterator(); iterator.hasNext(); ) {
|
|
SysMenu menu = (SysMenu) iterator.next();
|
|
SysMenu menu = (SysMenu) iterator.next();
|
|
// 如果是顶级节点, 遍历该父节点的所有子节点
|
|
// 如果是顶级节点, 遍历该父节点的所有子节点
|
|
- if (!tempList.contains(menu.getParentId()))
|
|
|
|
- {
|
|
|
|
|
|
+ if (!tempList.contains(menu.getParentId())) {
|
|
recursionFn(menus, menu);
|
|
recursionFn(menus, menu);
|
|
returnList.add(menu);
|
|
returnList.add(menu);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
- if (returnList.isEmpty())
|
|
|
|
- {
|
|
|
|
|
|
+ if (returnList.isEmpty()) {
|
|
returnList = menus;
|
|
returnList = menus;
|
|
}
|
|
}
|
|
return returnList;
|
|
return returnList;
|
|
@@ -275,121 +254,216 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 构建前端所需要下拉树结构
|
|
* 构建前端所需要下拉树结构
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menus 菜单列表
|
|
* @param menus 菜单列表
|
|
* @return 下拉树结构列表
|
|
* @return 下拉树结构列表
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public List<TreeSelect> buildMenuTreeSelect(List<SysMenu> menus)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<TreeSelect> buildMenuTreeSelect(List<SysMenu> menus) {
|
|
List<SysMenu> menuTrees = buildMenuTree(menus);
|
|
List<SysMenu> menuTrees = buildMenuTree(menus);
|
|
return menuTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
|
|
return menuTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ @Override
|
|
|
|
+ public List<Object> getAuthority(){
|
|
|
|
+
|
|
|
|
+ SysUser user = SecurityUtils.getLoginUser().getUser();
|
|
|
|
+ //全部目录查询
|
|
|
|
+ List<SysMenu> sysMenuListTwo = menuMapper.getSysMenuList("M");
|
|
|
|
+ //全部菜单查询
|
|
|
|
+ List<SysMenu> sysMenuListOne = menuMapper.getSysMenuList("C");
|
|
|
|
+ //全部按钮列表
|
|
|
|
+ List<SysMenu> sysMenuListThree = menuMapper.getSysMenuList("F");
|
|
|
|
+ //已选中按钮列表
|
|
|
|
+ List<SysMenu> sysMenuListFour = menuMapper.getButtonlist(user.getUserId(), null);
|
|
|
|
+ List<SysMenuTwoVo> sysMenuVoListOne = new ArrayList<>();
|
|
|
|
+ List<SysMenuOneVo> SysMenuVoList = new ArrayList<>();
|
|
|
|
+ List<SysMenuVo> SysMenuVoListOne = new ArrayList<>();
|
|
|
|
+ List<Object> list = new ArrayList<>();
|
|
|
|
+ if (sysMenuListFour.size()>0){
|
|
|
|
+ for (int i=0;i<sysMenuListThree.size();i++){
|
|
|
|
+ SysMenuTwoVo sysMenuTwoVo = new SysMenuTwoVo();
|
|
|
|
+ sysMenuTwoVo.setId(sysMenuListThree.get(i).getMenuId());
|
|
|
|
+ sysMenuTwoVo.setName(sysMenuListThree.get(i).getMenuName());
|
|
|
|
+ sysMenuTwoVo.setFid(sysMenuListThree.get(i).getParentId());
|
|
|
|
+ long Id=sysMenuListThree.get(i).getMenuId();
|
|
|
|
+ for (int j=0;j<sysMenuListFour.size();j++){
|
|
|
|
+ long MenuId=sysMenuListFour.get(j).getMenuId();
|
|
|
|
+ if (Id==MenuId){
|
|
|
|
+ sysMenuTwoVo.setChecked(true);
|
|
|
|
+ }else {
|
|
|
|
+ sysMenuTwoVo.setChecked(false);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ sysMenuVoListOne.add(sysMenuTwoVo);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (int i=0;i<sysMenuListOne.size();i++){
|
|
|
|
+ SysMenuOneVo sysMenuOneVo = new SysMenuOneVo();
|
|
|
|
+ sysMenuOneVo.setId(sysMenuListOne.get(i).getMenuId());
|
|
|
|
+ sysMenuOneVo.setMenu(sysMenuListOne.get(i).getMenuName());
|
|
|
|
+ sysMenuOneVo.setFid(sysMenuListOne.get(i).getParentId());
|
|
|
|
+ long id = sysMenuListOne.get(i).getMenuId();
|
|
|
|
+ List<SysMenuTwoVo> sysMenuVoListTwo = new ArrayList<>();
|
|
|
|
+ for (int j=0;j<sysMenuVoListOne.size();j++){
|
|
|
|
+ long FId = sysMenuVoListOne.get(j).getFid();
|
|
|
|
+ if (id==FId){
|
|
|
|
+ sysMenuVoListTwo.add(sysMenuVoListOne.get(j));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ sysMenuOneVo.setAuthority(sysMenuVoListTwo);
|
|
|
|
+ SysMenuVoList.add(sysMenuOneVo);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (int i=0;i<sysMenuListTwo.size();i++){
|
|
|
|
+ SysMenuVo sysMenuVo = new SysMenuVo();
|
|
|
|
+ sysMenuVo.setId(sysMenuListTwo.get(i).getMenuId());
|
|
|
|
+ sysMenuVo.setMenu(sysMenuListTwo.get(i).getMenuName());
|
|
|
|
+ sysMenuVo.setFid(sysMenuListTwo.get(i).getParentId());
|
|
|
|
+ long id = sysMenuListTwo.get(i).getMenuId();
|
|
|
|
+ List<SysMenuOneVo> SysMenuVoListThree = new ArrayList<>();
|
|
|
|
+ for (int j=0;j<SysMenuVoList.size();j++){
|
|
|
|
+ long FId = SysMenuVoList.get(j).getFid();
|
|
|
|
+ if (id==FId){
|
|
|
|
+ SysMenuVoListThree.add(SysMenuVoList.get(j));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ sysMenuVo.setChildren(SysMenuVoListThree);
|
|
|
|
+ SysMenuVoListOne.add(sysMenuVo);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for (int i=0;i<SysMenuVoListOne.size();i++){
|
|
|
|
+ String name = SysMenuVoListOne.get(i).getMenu();
|
|
|
|
+ if (name.equals("数据管理")||name.equals("电能质量")||name.equals("系统管理")){
|
|
|
|
+ list.add(SysMenuVoListOne.get(i));
|
|
|
|
+ }else {
|
|
|
|
+ for (int j=0;j<SysMenuVoList.size();j++){
|
|
|
|
+ String name2 = SysMenuVoList.get(j).getMenu();
|
|
|
|
+ if (name.equals(name2)){
|
|
|
|
+ list.add(SysMenuVoList.get(j));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return list;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* 根据菜单ID查询信息
|
|
* 根据菜单ID查询信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menuId 菜单ID
|
|
* @param menuId 菜单ID
|
|
* @return 菜单信息
|
|
* @return 菜单信息
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public SysMenu selectMenuById(Long menuId)
|
|
|
|
- {
|
|
|
|
|
|
+
|
|
|
|
+ public SysMenu selectMenuById(Long menuId) {
|
|
return menuMapper.selectMenuById(menuId);
|
|
return menuMapper.selectMenuById(menuId);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 是否存在菜单子节点
|
|
* 是否存在菜单子节点
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menuId 菜单ID
|
|
* @param menuId 菜单ID
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public boolean hasChildByMenuId(Long menuId)
|
|
|
|
- {
|
|
|
|
|
|
+ public boolean hasChildByMenuId(Long menuId) {
|
|
int result = menuMapper.hasChildByMenuId(menuId);
|
|
int result = menuMapper.hasChildByMenuId(menuId);
|
|
return result > 0 ? true : false;
|
|
return result > 0 ? true : false;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 查询菜单使用数量
|
|
* 查询菜单使用数量
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menuId 菜单ID
|
|
* @param menuId 菜单ID
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public boolean checkMenuExistRole(Long menuId)
|
|
|
|
- {
|
|
|
|
|
|
+ public boolean checkMenuExistRole(Long menuId) {
|
|
int result = roleMenuMapper.checkMenuExistRole(menuId);
|
|
int result = roleMenuMapper.checkMenuExistRole(menuId);
|
|
return result > 0 ? true : false;
|
|
return result > 0 ? true : false;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 新增保存菜单信息
|
|
* 新增保存菜单信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public int insertMenu(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public int insertMenu(SysMenu menu) {
|
|
return menuMapper.insertMenu(menu);
|
|
return menuMapper.insertMenu(menu);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 修改保存菜单信息
|
|
* 修改保存菜单信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public int updateMenu(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public int updateMenu(SysMenu menu) {
|
|
return menuMapper.updateMenu(menu);
|
|
return menuMapper.updateMenu(menu);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 删除菜单管理信息
|
|
* 删除菜单管理信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menuId 菜单ID
|
|
* @param menuId 菜单ID
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public int deleteMenuById(Long menuId)
|
|
|
|
- {
|
|
|
|
|
|
+ public int deleteMenuById(Long menuId) {
|
|
return menuMapper.deleteMenuById(menuId);
|
|
return menuMapper.deleteMenuById(menuId);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 校验菜单名称是否唯一
|
|
* 校验菜单名称是否唯一
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
@Override
|
|
@Override
|
|
- public String checkMenuNameUnique(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public String checkMenuNameUnique(SysMenu menu) {
|
|
Long menuId = Objects.isNull(menu.getMenuId()) ? -1L : menu.getMenuId();
|
|
Long menuId = Objects.isNull(menu.getMenuId()) ? -1L : menu.getMenuId();
|
|
SysMenu info = menuMapper.checkMenuNameUnique(menu.getMenuName(), menu.getParentId());
|
|
SysMenu info = menuMapper.checkMenuNameUnique(menu.getMenuName(), menu.getParentId());
|
|
- if (Objects.nonNull(info) && info.getMenuId().longValue() != menuId.longValue())
|
|
|
|
- {
|
|
|
|
|
|
+ if (Objects.nonNull(info) && info.getMenuId().longValue() != menuId.longValue()) {
|
|
return UserConstants.NOT_UNIQUE;
|
|
return UserConstants.NOT_UNIQUE;
|
|
}
|
|
}
|
|
return UserConstants.UNIQUE;
|
|
return UserConstants.UNIQUE;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * 根据菜单查询按钮
|
|
|
|
+ *
|
|
|
|
+ * @param menuName 菜单名称
|
|
|
|
+ * @return
|
|
|
|
+ */
|
|
|
|
+ @Override
|
|
|
|
+ public List<SysMenu> getButtonlist(String menuName) {
|
|
|
|
+ SysUser user = SecurityUtils.getLoginUser().getUser();
|
|
|
|
+ List<SysMenu> sysMenuList = new ArrayList<>();
|
|
|
|
+ if (SecurityUtils.isAdmin(user.getUserId())) {
|
|
|
|
+ sysMenuList = menuMapper.getButtonlistOne(menuName);
|
|
|
|
+ } else {
|
|
|
|
+ sysMenuList = menuMapper.getButtonlist(user.getUserId(), menuName);
|
|
|
|
+ }
|
|
|
|
+ return sysMenuList;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* 获取路由名称
|
|
* 获取路由名称
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 路由名称
|
|
* @return 路由名称
|
|
*/
|
|
*/
|
|
- public String getRouteName(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public String getRouteName(SysMenu menu) {
|
|
String routerName = StringUtils.capitalize(menu.getPath());
|
|
String routerName = StringUtils.capitalize(menu.getPath());
|
|
// 非外链并且是一级目录(类型为目录)
|
|
// 非外链并且是一级目录(类型为目录)
|
|
- if (isMenuFrame(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ if (isMenuFrame(menu)) {
|
|
routerName = StringUtils.EMPTY;
|
|
routerName = StringUtils.EMPTY;
|
|
}
|
|
}
|
|
return routerName;
|
|
return routerName;
|
|
@@ -397,27 +471,23 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 获取路由地址
|
|
* 获取路由地址
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 路由地址
|
|
* @return 路由地址
|
|
*/
|
|
*/
|
|
- public String getRouterPath(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public String getRouterPath(SysMenu menu) {
|
|
String routerPath = menu.getPath();
|
|
String routerPath = menu.getPath();
|
|
// 内链打开外网方式
|
|
// 内链打开外网方式
|
|
- if (menu.getParentId().intValue() != 0 && isInnerLink(menu))
|
|
|
|
- {
|
|
|
|
- routerPath = StringUtils.replaceEach(routerPath, new String[] { Constants.HTTP, Constants.HTTPS }, new String[] { "", "" });
|
|
|
|
|
|
+ if (menu.getParentId().intValue() != 0 && isInnerLink(menu)) {
|
|
|
|
+ routerPath = StringUtils.replaceEach(routerPath, new String[]{Constants.HTTP, Constants.HTTPS}, new String[]{"", ""});
|
|
}
|
|
}
|
|
// 非外链并且是一级目录(类型为目录)
|
|
// 非外链并且是一级目录(类型为目录)
|
|
if (0 == menu.getParentId().intValue() && UserConstants.TYPE_DIR.equals(menu.getMenuType())
|
|
if (0 == menu.getParentId().intValue() && UserConstants.TYPE_DIR.equals(menu.getMenuType())
|
|
- && UserConstants.NO_FRAME.equals(menu.getIsFrame()))
|
|
|
|
- {
|
|
|
|
|
|
+ && UserConstants.NO_FRAME.equals(menu.getIsFrame())) {
|
|
routerPath = "/" + menu.getPath();
|
|
routerPath = "/" + menu.getPath();
|
|
}
|
|
}
|
|
// 非外链并且是一级目录(类型为菜单)
|
|
// 非外链并且是一级目录(类型为菜单)
|
|
- else if (isMenuFrame(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ else if (isMenuFrame(menu)) {
|
|
routerPath = "/";
|
|
routerPath = "/";
|
|
}
|
|
}
|
|
return routerPath;
|
|
return routerPath;
|
|
@@ -425,23 +495,17 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 获取组件信息
|
|
* 获取组件信息
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 组件信息
|
|
* @return 组件信息
|
|
*/
|
|
*/
|
|
- public String getComponent(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public String getComponent(SysMenu menu) {
|
|
String component = UserConstants.LAYOUT;
|
|
String component = UserConstants.LAYOUT;
|
|
- if (StringUtils.isNotEmpty(menu.getComponent()) && !isMenuFrame(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ if (StringUtils.isNotEmpty(menu.getComponent()) && !isMenuFrame(menu)) {
|
|
component = menu.getComponent();
|
|
component = menu.getComponent();
|
|
- }
|
|
|
|
- else if (StringUtils.isEmpty(menu.getComponent()) && menu.getParentId().intValue() != 0 && isInnerLink(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ } else if (StringUtils.isEmpty(menu.getComponent()) && menu.getParentId().intValue() != 0 && isInnerLink(menu)) {
|
|
component = UserConstants.INNER_LINK;
|
|
component = UserConstants.INNER_LINK;
|
|
- }
|
|
|
|
- else if (StringUtils.isEmpty(menu.getComponent()) && isParentView(menu))
|
|
|
|
- {
|
|
|
|
|
|
+ } else if (StringUtils.isEmpty(menu.getComponent()) && isParentView(menu)) {
|
|
component = UserConstants.PARENT_VIEW;
|
|
component = UserConstants.PARENT_VIEW;
|
|
}
|
|
}
|
|
return component;
|
|
return component;
|
|
@@ -449,54 +513,48 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 是否为菜单内部跳转
|
|
* 是否为菜单内部跳转
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
- public boolean isMenuFrame(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public boolean isMenuFrame(SysMenu menu) {
|
|
return menu.getParentId().intValue() == 0 && UserConstants.TYPE_MENU.equals(menu.getMenuType())
|
|
return menu.getParentId().intValue() == 0 && UserConstants.TYPE_MENU.equals(menu.getMenuType())
|
|
&& menu.getIsFrame().equals(UserConstants.NO_FRAME);
|
|
&& menu.getIsFrame().equals(UserConstants.NO_FRAME);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 是否为内链组件
|
|
* 是否为内链组件
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
- public boolean isInnerLink(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public boolean isInnerLink(SysMenu menu) {
|
|
return menu.getIsFrame().equals(UserConstants.NO_FRAME) && StringUtils.startsWithAny(menu.getPath(), Constants.HTTP, Constants.HTTPS);
|
|
return menu.getIsFrame().equals(UserConstants.NO_FRAME) && StringUtils.startsWithAny(menu.getPath(), Constants.HTTP, Constants.HTTPS);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 是否为parent_view组件
|
|
* 是否为parent_view组件
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param menu 菜单信息
|
|
* @param menu 菜单信息
|
|
* @return 结果
|
|
* @return 结果
|
|
*/
|
|
*/
|
|
- public boolean isParentView(SysMenu menu)
|
|
|
|
- {
|
|
|
|
|
|
+ public boolean isParentView(SysMenu menu) {
|
|
return menu.getParentId().intValue() != 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType());
|
|
return menu.getParentId().intValue() != 0 && UserConstants.TYPE_DIR.equals(menu.getMenuType());
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
* 根据父节点的ID获取所有子节点
|
|
* 根据父节点的ID获取所有子节点
|
|
- *
|
|
|
|
- * @param list 分类表
|
|
|
|
|
|
+ *
|
|
|
|
+ * @param list 分类表
|
|
* @param parentId 传入的父节点ID
|
|
* @param parentId 传入的父节点ID
|
|
* @return String
|
|
* @return String
|
|
*/
|
|
*/
|
|
- public List<SysMenu> getChildPerms(List<SysMenu> list, int parentId)
|
|
|
|
- {
|
|
|
|
|
|
+ public List<SysMenu> getChildPerms(List<SysMenu> list, int parentId) {
|
|
List<SysMenu> returnList = new ArrayList<SysMenu>();
|
|
List<SysMenu> returnList = new ArrayList<SysMenu>();
|
|
- for (Iterator<SysMenu> iterator = list.iterator(); iterator.hasNext();)
|
|
|
|
- {
|
|
|
|
|
|
+ for (Iterator<SysMenu> iterator = list.iterator(); iterator.hasNext(); ) {
|
|
SysMenu t = (SysMenu) iterator.next();
|
|
SysMenu t = (SysMenu) iterator.next();
|
|
// 一、根据传入的某个父节点ID,遍历该父节点的所有子节点
|
|
// 一、根据传入的某个父节点ID,遍历该父节点的所有子节点
|
|
- if (t.getParentId() == parentId)
|
|
|
|
- {
|
|
|
|
|
|
+ if (t.getParentId() == parentId) {
|
|
recursionFn(list, t);
|
|
recursionFn(list, t);
|
|
returnList.add(t);
|
|
returnList.add(t);
|
|
}
|
|
}
|
|
@@ -506,19 +564,16 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
|
|
|
|
/**
|
|
/**
|
|
* 递归列表
|
|
* 递归列表
|
|
- *
|
|
|
|
|
|
+ *
|
|
* @param list
|
|
* @param list
|
|
* @param t
|
|
* @param t
|
|
*/
|
|
*/
|
|
- private void recursionFn(List<SysMenu> list, SysMenu t)
|
|
|
|
- {
|
|
|
|
|
|
+ private void recursionFn(List<SysMenu> list, SysMenu t) {
|
|
// 得到子节点列表
|
|
// 得到子节点列表
|
|
List<SysMenu> childList = getChildList(list, t);
|
|
List<SysMenu> childList = getChildList(list, t);
|
|
t.setChildren(childList);
|
|
t.setChildren(childList);
|
|
- for (SysMenu tChild : childList)
|
|
|
|
- {
|
|
|
|
- if (hasChild(list, tChild))
|
|
|
|
- {
|
|
|
|
|
|
+ for (SysMenu tChild : childList) {
|
|
|
|
+ if (hasChild(list, tChild)) {
|
|
recursionFn(list, tChild);
|
|
recursionFn(list, tChild);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -527,15 +582,12 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
/**
|
|
/**
|
|
* 得到子节点列表
|
|
* 得到子节点列表
|
|
*/
|
|
*/
|
|
- private List<SysMenu> getChildList(List<SysMenu> list, SysMenu t)
|
|
|
|
- {
|
|
|
|
|
|
+ private List<SysMenu> getChildList(List<SysMenu> list, SysMenu t) {
|
|
List<SysMenu> tlist = new ArrayList<SysMenu>();
|
|
List<SysMenu> tlist = new ArrayList<SysMenu>();
|
|
Iterator<SysMenu> it = list.iterator();
|
|
Iterator<SysMenu> it = list.iterator();
|
|
- while (it.hasNext())
|
|
|
|
- {
|
|
|
|
|
|
+ while (it.hasNext()) {
|
|
SysMenu n = (SysMenu) it.next();
|
|
SysMenu n = (SysMenu) it.next();
|
|
- if (n.getParentId().longValue() == t.getMenuId().longValue())
|
|
|
|
- {
|
|
|
|
|
|
+ if (n.getParentId().longValue() == t.getMenuId().longValue()) {
|
|
tlist.add(n);
|
|
tlist.add(n);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -545,8 +597,8 @@ public class SysMenuServiceImpl implements ISysMenuService
|
|
/**
|
|
/**
|
|
* 判断是否有子节点
|
|
* 判断是否有子节点
|
|
*/
|
|
*/
|
|
- private boolean hasChild(List<SysMenu> list, SysMenu t)
|
|
|
|
- {
|
|
|
|
|
|
+ private boolean hasChild(List<SysMenu> list, SysMenu t) {
|
|
return getChildList(list, t).size() > 0 ? true : false;
|
|
return getChildList(list, t).size() > 0 ? true : false;
|
|
}
|
|
}
|
|
|
|
+
|
|
}
|
|
}
|