<div class="layui-fluid layui-anim febs-anim" id="febs-menu" lay-title="菜单管理">
|
<div class="layui-row layui-col-space8 febs-container">
|
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
|
<div class="layui-card">
|
<div class="layui-card-body febs-table-full">
|
<form class="layui-form layui-table-form" lay-filter="menu-table-form" id="menu-table-form">
|
<div class="layui-row">
|
<div class="layui-col-md8 layui-col-sm9 layui-col-xs9">
|
<div class="layui-form-item">
|
<div class="layui-inline">
|
<label class="layui-form-label layui-form-label-sm">名称</label>
|
<div class="layui-input-inline">
|
<input type="text" name="menuName" autocomplete="off" class="layui-input">
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="layui-col-md4 layui-col-sm12 layui-col-xs12 table-action-area">
|
<div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain table-action" id="query">
|
<i class="layui-icon"></i>
|
</div>
|
<div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset">
|
<i class="layui-icon"></i>
|
</div>
|
<div class="layui-btn layui-btn-sm layui-btn-primary table-action action-more"
|
shiro:hasAnyPermissions="menu:add,menu:delete,menu:export">
|
<i class="layui-icon"></i>
|
</div>
|
</div>
|
</div>
|
</form>
|
<div class="eleTree menuTree" lay-filter="menuTree" style="margin-left: 1rem"></div>
|
</div>
|
</div>
|
</div>
|
<div class="layui-col-md6 layui-col-sm6 layui-col-xs12">
|
<div class="layui-card">
|
<div class="layui-card-header" id="form-header">新增菜单</div>
|
<div class="layui-card-body febs-table-full">
|
<form class="layui-form layui-table-form" action="" lay-filter="menu-form">
|
<div class="layui-form-item febs-hide">
|
<label class="layui-form-label febs-form-item-require">ID:</label>
|
<div class="layui-input-block">
|
<input type="text" name="menuId" class="layui-input">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">上级ID:</label>
|
<div class="layui-input-block">
|
<input type="text" value="" name="parentId" readonly class="layui-input">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label febs-form-item-require">名称:</label>
|
<div class="layui-input-block">
|
<input type="text" name="menuName" autocomplete="off" class="layui-input"
|
minlength="2" maxlength="10" lay-verify="range">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label febs-form-item-require">类型:</label>
|
<div class="layui-input-block">
|
<input type="radio" name="type" lay-filter="menu-type" value="0" title="菜单" checked="">
|
<input type="radio" name="type" lay-filter="menu-type" value="1" title="按钮">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">图标:</label>
|
<div class="layui-input-block">
|
<input type="text" name="icon" autocomplete="off" class="layui-input"
|
maxlength="50" lay-verify="range">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">URL:</label>
|
<div class="layui-input-block">
|
<input type="text" name="url" autocomplete="off" class="layui-input"
|
maxlength="50" lay-verify="range">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">权限:</label>
|
<div class="layui-input-block">
|
<input type="text" name="perms" autocomplete="off" class="layui-input"
|
maxlength="50" lay-verify="range">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">排序:</label>
|
<div class="layui-input-block">
|
<input type="text" name="orderNum" autocomplete="off" class="layui-input"
|
lay-verify="number">
|
</div>
|
</div>
|
<button type="reset" class="layui-btn febs-hide" id="reset-form"></button>
|
<button class="layui-btn febs-hide" lay-submit="" lay-filter="menu-form-submit"
|
id="submit-form"></button>
|
</form>
|
</div>
|
<div class="layui-card-footer">
|
<button class="layui-btn" id="submit">保存</button>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<script data-th-inline="none" type="text/javascript">
|
layui.use(['dropdown', 'jquery', 'laydate', 'febs', 'form', 'eleTree', 'validate'], function () {
|
var $ = layui.jquery,
|
laydate = layui.laydate,
|
febs = layui.febs,
|
form = layui.form,
|
validate = layui.validate,
|
eleTree = layui.eleTree,
|
dropdown = layui.dropdown,
|
$view = $('#febs-menu'),
|
$query = $view.find('#query'),
|
$reset = $view.find('#reset'),
|
$submit = $view.find('#submit'),
|
$searchForm = $view.find('#menu-table-form'),
|
$menuName = $searchForm.find('input[name="menuName"]'),
|
$type = $view.find('input[type="radio"][name="type"]'),
|
$icon = $view.find('input[name="icon"]'),
|
$icon_parent = $icon.parents('.layui-form-item'),
|
$url = $view.find('input[name="url"]'),
|
$url_parent = $url.parents('.layui-form-item'),
|
$order = $view.find('input[name="orderNum"]'),
|
$order_parent = $order.parents('.layui-form-item'),
|
$header = $view.find('#form-header'),
|
_currentMenuData,
|
_selectNode,
|
_menuTree,
|
tableIns;
|
|
form.verify(validate);
|
form.render();
|
|
dropdown.render({
|
elem: $view.find('.action-more'),
|
click: function (name, elem, event) {
|
if (name === 'add') {
|
reset();
|
var selected = _menuTree.getChecked(false, true);
|
if (selected.length > 1) {
|
febs.alert.warn('只能选择一个节点作为父级!');
|
return;
|
}
|
if (selected[0] && selected[0].type === '1') {
|
febs.alert.warn('不能选择按钮作为父级!');
|
return;
|
}
|
form.val("menu-form", {
|
"parentId": selected[0] ? selected[0].id : ''
|
});
|
}
|
if (name === 'delete') {
|
var checked = _menuTree.getChecked(false, true);
|
if (checked.length < 1) {
|
febs.alert.warn('请勾选需要删除的菜单或按钮');
|
return;
|
}
|
var menuIds = [];
|
layui.each(checked, function (key, item) {
|
menuIds.push(item.id)
|
});
|
febs.modal.confirm('提示', '当您点击确定按钮后,这些记录将会被彻底删除,如果其包含子记录,也将一并删除!', function () {
|
febs.get(ctx + 'menu/delete/' + menuIds.join(','), null, function () {
|
febs.alert.success('删除成功!');
|
reloadMenuTree();
|
reset();
|
})
|
});
|
}
|
if (name === 'export') {
|
febs.download(ctx + 'menu/excel', {
|
"menuName": $menuName.val().trim()
|
}, '菜单信息表.xlsx');
|
}
|
},
|
options: [{
|
name: 'add',
|
title: '新增',
|
perms: 'menu:add'
|
}, {
|
name: 'delete',
|
title: '删除',
|
perms: 'menu:delete'
|
}, {
|
name: 'export',
|
title: '导出Excel',
|
perms: 'menu:export'
|
}]
|
});
|
|
_menuTree = renderMenuTree();
|
|
eleTree.on("nodeClick(menuTree)", function (d) {
|
var data = d.data.currentData.data;
|
_currentMenuData = data;
|
$type.attr("disabled", true);
|
var type = data.type;
|
handleTypeChange(type);
|
if (type === '0') { // 菜单
|
$header.text('修改菜单');
|
} else { // 按钮
|
$header.text('修改按钮');
|
}
|
form.val("menu-form", {
|
"icon": data.icon,
|
"url": data.url,
|
"orderNum": data.orderNum,
|
"type": data.type,
|
"menuName": data.menuName,
|
"perms": data.perms,
|
"parentId": data.parentId,
|
"menuId": data.menuId
|
});
|
});
|
|
form.on("radio(menu-type)", function (data) {
|
handleTypeChange(data.value);
|
});
|
|
$reset.on('click', function () {
|
$menuName.val('');
|
reloadMenuTree();
|
reset();
|
});
|
|
$query.on('click', function () {
|
reloadMenuTree();
|
reset();
|
});
|
|
$submit.on('click', function () {
|
$view.find('#submit-form').trigger('click');
|
});
|
|
$icon.focus(function () {
|
febs.modal.open('图标选择', 'others/febs/icon', {
|
btn: ['确定'],
|
yes: function () {
|
var icon = $('#febs-icon').find('.icon-active .icon-name').text();
|
if (icon) {
|
form.val("menu-form", {
|
"icon": 'layui-icon-' + icon
|
});
|
} else {
|
form.val("menu-form", {
|
"icon": ''
|
});
|
}
|
layer.closeAll();
|
}
|
});
|
});
|
|
function reset() {
|
$view.find('#reset-form').trigger('click');
|
handleTypeChange('0');
|
$type.removeAttr("disabled");
|
}
|
|
function renderMenuTree() {
|
_menuTree = eleTree.render({
|
elem: '.menuTree',
|
url: ctx + 'menu/tree',
|
where: {
|
"menuName": $menuName.val().trim(),
|
"invalidate_ie_cache": new Date()
|
},
|
accordion: true,
|
highlightCurrent: true,
|
showCheckbox: true,
|
checkStrictly: true,
|
renderAfterExpand: false,
|
request: {
|
name: "title",
|
key: "id",
|
children: "childs",
|
checked: "checked",
|
data: "data"
|
},
|
response: {
|
statusName: "code",
|
statusCode: 200,
|
dataName: "data"
|
}
|
});
|
return _menuTree;
|
}
|
|
function reloadMenuTree() {
|
_menuTree = renderMenuTree();
|
}
|
|
var handleTypeChange = function (type) {
|
form.val("menu-form", {
|
"icon": '',
|
"url": '',
|
"orderNum": ''
|
});
|
if (type === '1') {
|
$header.text('新增按钮');
|
$icon_parent.hide();
|
$url_parent.hide();
|
$order_parent.hide();
|
} else {
|
$header.text('新增菜单');
|
$icon_parent.show();
|
$url_parent.show();
|
$order_parent.show();
|
}
|
};
|
|
form.on('submit(menu-form-submit)', function (data) {
|
if (data.field.menuId && $header.text().indexOf('修改') !== -1) {
|
if (febs.nativeEqual(data.field, _currentMenuData)) {
|
febs.alert.warn('数据未作任何修改!');
|
return false;
|
}
|
febs.post(ctx + 'menu/update', data.field, function () {
|
febs.alert.success('修改成功');
|
reloadMenuTree();
|
reset();
|
})
|
} else {
|
febs.post(ctx + 'menu', data.field, function () {
|
febs.alert.success('新增成功');
|
reloadMenuTree();
|
reset();
|
})
|
}
|
return false;
|
});
|
});
|
</script>
|