增加了菜单创建接口

This commit is contained in:
WenG 2022-05-09 23:00:33 +08:00
parent 186b525816
commit 40c11f84f4
4 changed files with 152 additions and 0 deletions

View File

@ -25,6 +25,16 @@ public interface IMenuBaseService {
*/
String MENU_UNIFIED_USER = "unified-user";
/**
* 保存菜单
*
* @param menuParentId
* @param menuName
* @param menuUrl
* @return
*/
String saveAndReturnIdByParentIdAndNameAndUrl(String menuParentId, String menuName, String menuUrl);
/**
* 菜单详情
*

View File

@ -32,6 +32,11 @@ public class MenuRouteController {
return new ModelAndView("menu/list-tree-root");
}
@GetMapping("list-tree-select")
public ModelAndView listTreeSelect() {
return new ModelAndView("menu/list-tree-select");
}
@GetMapping("list")
public ModelAndView list() {
return new ModelAndView("menu/list");

View File

@ -35,6 +35,21 @@ public class MenuServiceImpl extends DefaultBaseService implements IMenuService
@Autowired
private IMenuDao menuDao;
@Override
public String saveAndReturnIdByParentIdAndNameAndUrl(String menuParentId, String menuName, String menuUrl) {
MenuVO menuVO = new MenuVO();
menuVO.setMenuParentId(menuParentId);
menuVO.setMenuName(menuName);
menuVO.setMenuSummary(menuName);
menuVO.setMenuUrl(menuUrl);
menuVO.setMenuType(1);
menuVO.setMenuStatus(0);
menuVO.setMenuIcon("fa fa-list");
menuVO.setOpenType(1);
menuVO.setMenuOrder("1000");
return saveAndReturnId(menuVO);
}
@Override
public MenuDTO get(Map<String, Object> params) {
return menuDao.get(params);

View File

@ -0,0 +1,122 @@
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<base th:href="${#request.getContextPath() + '/'}">
<meta charset="utf-8">
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
<link rel="stylesheet" href="assets/fonts/font-awesome/css/font-awesome.css"/>
<link rel="stylesheet" href="assets/layuiadmin/layui/css/layui.css" media="all">
<link rel="stylesheet" href="assets/layuiadmin/style/admin.css" media="all">
<link rel="stylesheet" href="assets/js/vendor/zTree3/css/metroStyle/metroStyle.css"/>
<link rel="stylesheet" href="assets/layuiadmin/style/common.css" media="all">
</head>
<body>
<div class="layui-anim layui-anim-fadein">
<div class="layui-row" style="padding-right: 0px;">
<div class="layui-card">
<div class="layui-card-body left-tree-wrap">
<div id="treeBox">
<ul id="tree" class="ztree"></ul>
</div>
</div>
<div class="layui-form-item layui-layout-admin">
<div class="layui-input-block">
<div class="layui-footer" style="padding: 0px;">
<div class="layui-btn-group">
<button type="button" class="layui-btn layui-btn-sm submit">确定</button>
<button type="button" class="layui-btn layui-btn-sm layui-btn-primary close">返回</button>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<script src="assets/layuiadmin/layui/layui.js"></script>
<script>
var common;
layui.config({
base: 'assets/layuiadmin/'
}).extend({
index: 'lib/index'
}).use(['index', 'ztree', 'common'], function() {
common = layui.common;
var $ = layui.$;
var $win = $(window);
var resizeTimeout = null;
var selectedNodes = [];
top.dialog.dialogData.selectedNodes = [];
function closeBox() {
parent.layer.close(parent.layer.getFrameIndex(window.name));
}
// 初始化大小
function initSize() {
$('#treeBox').css({
height: $win.height() - 52,
overflow: 'auto'
});
}
// 初始化树
function initThree() {
var setting = {
async: {
enable: true,
autoLoad: true,
type: 'get',
url: top.restAjax.path('api/menu/listztree', []),
autoParam: ['id'],
otherParam: {},
dataFilter: function (treeId, parentNode, childNodes) {
if (!childNodes) return null;
for (var i = 0, l = childNodes.length; i < l; i++) {
childNodes[i].name = childNodes[i].name.replace(/\.n/g, '.');
}
return childNodes;
}
},
callback: {
onClick: function (event, treeId, treeNode) {
var node = {
id: treeNode.id,
pId: treeNode.pId,
name: treeNode.name
};
if(selectedNodes.length == 0) {
selectedNodes.push(node)
} else {
selectedNodes[0] = node;
}
return false;
}
},
};
var zTree = $.fn.zTree.init($("#tree"), setting);
}
initSize();
initThree();
// 事件 - 页面变化
$win.on('resize', function() {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(function() {
initSize();
}, 500);
});
$('.close').on('click', function() {
closeBox();
});
$('.submit').on('click', function() {
top.dialog.dialogData.selectedNodes = selectedNodes;
closeBox();
});
});
</script>
</body>
</html>