<div class="layui-fluid layui-anim febs-anim" id="febs-role" lay-title="角色管理">
|
<div class="layui-row layui-col-space8 febs-container">
|
<div class="layui-col-md7 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="role-table-form" id="role-table-form">
|
<div class="layui-row">
|
<div class="layui-col-md9 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="roleName" autocomplete="off" class="layui-input">
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="layui-col-md3 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="role:add,user:delete,role:export">
|
<i class="layui-icon"></i>
|
</div>
|
</div>
|
</div>
|
</form>
|
<table lay-filter="roleTable" lay-data="{id: 'roleTable'}"></table>
|
</div>
|
</div>
|
</div>
|
<div class="layui-col-md5 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="role-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="roleId" 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="roleName" autocomplete="off" class="layui-input" minlength="2"
|
maxlength="10" lay-verify="range">
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">角色描述:</label>
|
<div class="layui-input-block">
|
<textarea name="remark" maxlength="50" class="layui-textarea"></textarea>
|
</div>
|
</div>
|
<div class="layui-form-item">
|
<label class="layui-form-label">角色权限:</label>
|
<div class="layui-input-block menu-tree" style="margin-top: .8rem;"></div>
|
</div>
|
<div class="layui-form-item febs-hide">
|
<button type="reset" class="layui-btn" id="reset-form"></button>
|
<button class="layui-btn" lay-submit="" lay-filter="role-form-submit"
|
id="submit-form"></button>
|
</div>
|
</form>
|
</div>
|
<div class="layui-card-footer">
|
<button class="layui-btn" id="submit">保存</button>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<script type="text/html" id="role-option">
|
<span shiro:lacksPermission="role:update,role:delete">
|
<span class="layui-badge-dot febs-bg-orange"></span> 无权限
|
</span>
|
<a lay-event="edit" shiro:hasPermission="role:update"><i class="layui-icon febs-edit-area febs-blue"></i></a>
|
<a lay-event="del" shiro:hasPermission="role:delete"><i class="layui-icon febs-edit-area febs-red"></i></a>
|
</script>
|
<script data-th-inline="none" type="text/javascript">
|
layui.use(['dropdown', 'jquery', 'laydate', 'febs', 'form', 'eleTree', 'table', 'validate'], function () {
|
var $ = layui.jquery,
|
laydate = layui.laydate,
|
febs = layui.febs,
|
form = layui.form,
|
table = layui.table,
|
eleTree = layui.eleTree,
|
dropdown = layui.dropdown,
|
validate = layui.validate,
|
$view = $('#febs-role'),
|
$query = $view.find('#query'),
|
$reset = $view.find('#reset'),
|
$submit = $view.find('#submit'),
|
$searchForm = $view.find('#role-table-form'),
|
$header = $view.find('#form-header'),
|
tableIns;
|
|
form.verify(validate);
|
form.render();
|
|
initTable();
|
|
laydate.render({
|
elem: '#createTime',
|
range: true
|
});
|
|
var menuTree = eleTree.render({
|
elem: '.menu-tree',
|
url: ctx + 'menu/tree',
|
showCheckbox: true,
|
where: {
|
"invalidate_ie_cache": new Date()
|
},
|
accordion: true,
|
checkStrictly: true,
|
renderAfterExpand: false,
|
request: {
|
name: "title",
|
key: "id",
|
children: "childs",
|
checked: "checked",
|
data: "data"
|
},
|
response: {
|
statusName: "code",
|
statusCode: 200,
|
dataName: "data"
|
}
|
});
|
|
dropdown.render({
|
elem: $view.find('.action-more'),
|
click: function (name, elem, event) {
|
var checkStatus = table.checkStatus('roleTable');
|
if (name === 'add') {
|
resetRoleForm();
|
}
|
if (name === 'delete') {
|
if (!checkStatus.data.length) {
|
febs.alert.warn('请选择需要删除的角色');
|
} else {
|
febs.modal.confirm('删除角色', '确定删除所选角色?', function () {
|
var roleIds = [];
|
layui.each(checkStatus.data, function (key, item) {
|
roleIds.push(item.roleId);
|
});
|
deleteRoles(roleIds.join(','));
|
});
|
}
|
}
|
if (name === 'export') {
|
var params = getQueryParams();
|
params.pageSize = $view.find(".layui-laypage-limits option:selected").val();
|
params.pageNum = $view.find(".layui-laypage-em").next().html();
|
febs.download(ctx + 'role/excel', params, '角色信息表.xlsx');
|
}
|
},
|
options: [{
|
name: 'add',
|
title: '新增角色',
|
perms: 'role:add'
|
}, {
|
name: 'delete',
|
title: '删除角色',
|
perms: 'role:delete'
|
}, {
|
name: 'export',
|
title: '导出Excel',
|
perms: 'role:export'
|
}]
|
});
|
|
table.on('tool(roleTable)', function (obj) {
|
var data = obj.data,
|
layEvent = obj.event;
|
if (layEvent === 'edit') {
|
$header.text('修改角色');
|
form.val("role-form", {
|
"roleId": data.roleId,
|
"roleName": data.roleName,
|
"remark": data.remark
|
});
|
if (data.menuIds) {
|
menuTree.setChecked(data.menuIds.split(','), true);
|
} else {
|
menuTree.setChecked([], true);
|
}
|
}
|
if (layEvent === 'del') {
|
febs.modal.confirm('删除角色', '确定删除该角色?', function () {
|
deleteRoles(data.roleId);
|
});
|
}
|
});
|
|
$query.on('click', function () {
|
resetRoleForm();
|
tableIns.reload({where: getQueryParams(), page: {curr: 1}});
|
});
|
|
$reset.on('click', function () {
|
resetRoleForm();
|
$searchForm[0].reset();
|
tableIns.reload({where: getQueryParams(), page: {curr: 1}});
|
});
|
|
$submit.on('click', function () {
|
$view.find('#submit-form').trigger('click');
|
});
|
|
function initTable() {
|
tableIns = febs.table.init({
|
elem: $view.find('table'),
|
id: 'roleTable',
|
url: ctx + 'role/list',
|
cols: [[
|
{type: 'checkbox'},
|
{field: 'roleName', title: '角色名称', minWidth: 120},
|
{field: 'remark', title: '角色描述'},
|
{field: 'createTime', title: '创建时间', minWidth: 180},
|
{title: '操作', toolbar: '#role-option', width: 100}
|
]]
|
});
|
}
|
|
function getQueryParams() {
|
return {
|
roleName: $searchForm.find('input[name="roleName"]').val().trim(),
|
invalidate_ie_cache: new Date()
|
};
|
}
|
|
function resetRoleForm() {
|
$view.find('#reset-form').trigger('click');
|
$header.text('新增角色');
|
menuTree.setChecked([], true);
|
menuTree.unExpandAll();
|
}
|
|
form.on('submit(role-form-submit)', function (data) {
|
var selected = menuTree.getChecked(false, true);
|
var menuIds = [];
|
layui.each(selected, function (key, item) {
|
menuIds.push(item.id)
|
});
|
data.field.menuIds = menuIds.join(',');
|
if (!menuIds.length) {
|
febs.modal.confirm('提示', '当前角色未授予任何权限,是否继续?', function () {
|
addOrUpdateRole(data.field);
|
});
|
} else {
|
addOrUpdateRole(data.field);
|
}
|
return false;
|
});
|
|
function deleteRoles(roleIds) {
|
febs.get(ctx + 'role/delete/' + roleIds, null, function () {
|
febs.alert.success('删除角色成功');
|
$query.trigger('click');
|
})
|
}
|
|
var addOrUpdateRole = function (data) {
|
if (data.roleId && $header.text() === '修改角色') {
|
febs.post(ctx + 'role/update', data, function () {
|
febs.alert.success('修改角色成功');
|
$query.trigger('click');
|
});
|
} else {
|
febs.post(ctx + 'role', data, function () {
|
febs.alert.success('新增角色成功');
|
$query.trigger('click');
|
});
|
}
|
}
|
});
|
</script>
|