2020-01-09 18:03:33 +08:00
|
|
|
|
2021-05-10 13:59:58 +08:00
|
|
|
{extend name="public:base" /}
|
|
|
|
{block name="css"}<link rel="stylesheet" href="/static/admin/tree/css/treeTable.css">{/block}
|
2020-01-09 18:03:33 +08:00
|
|
|
{block name="body"}
|
2020-11-20 14:51:52 +08:00
|
|
|
|
2021-05-10 13:59:58 +08:00
|
|
|
|
|
|
|
<body class="layui-hide">
|
|
|
|
|
|
|
|
<div class="page-wrapper">
|
|
|
|
<div class="demo-side">
|
|
|
|
<table id="LAY-user-auth-rule"></table>
|
2020-01-09 18:03:33 +08:00
|
|
|
</div>
|
2021-05-10 13:59:58 +08:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<!-- 表格操作列 -->
|
|
|
|
<script type="text/html" id="tbBar">
|
|
|
|
<a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="edit">修改</a>
|
|
|
|
<!--a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a-->
|
|
|
|
{{# if(d.id == '1' | d.id == '2' | d.id == '9' | d.id == '10' ){ }}<a class="layui-btn layui-btn-disabled layui-btn-xs">删除</a>
|
|
|
|
{{# } else { }}
|
2022-04-19 17:26:10 +08:00
|
|
|
{if condition="checkRuleButton('authrule/delete')"}<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
|
2021-05-10 13:59:58 +08:00
|
|
|
{else /}<a class="layui-btn layui-btn-danger layui-btn-xs layui-btn-disabled">删除</a>{/if}
|
|
|
|
{{# } }}
|
|
|
|
</script>
|
2020-01-09 18:03:33 +08:00
|
|
|
|
|
|
|
{/block}
|
2021-05-10 13:59:58 +08:00
|
|
|
|
2020-01-09 18:03:33 +08:00
|
|
|
{block name="js"}
|
|
|
|
<script>
|
2021-05-10 13:59:58 +08:00
|
|
|
layui.config({
|
|
|
|
base: '/static/admin/modules/'
|
|
|
|
}).use(['layer', 'util', 'treeTable'], function () {
|
|
|
|
var $ = layui.jquery;
|
|
|
|
var layer = layui.layer;
|
|
|
|
var util = layui.util;
|
|
|
|
var treeTable = layui.treeTable;
|
|
|
|
$('body').removeClass('layui-hide');
|
2020-04-28 18:44:40 +08:00
|
|
|
|
2021-05-10 13:59:58 +08:00
|
|
|
// 渲染表格
|
|
|
|
var insTb = treeTable.render({
|
|
|
|
elem: '#LAY-user-auth-rule',
|
|
|
|
url: "{:url('AuthRule/index')}",
|
|
|
|
toolbar: 'default',
|
|
|
|
//height: 'full-200',
|
|
|
|
tree: {
|
|
|
|
iconIndex: 2,
|
|
|
|
isPidData: true,
|
|
|
|
idName: 'id',
|
|
|
|
pidName: 'pid'
|
|
|
|
},
|
|
|
|
defaultToolbar: ['filter', 'print', 'exports'],
|
|
|
|
cols: [
|
|
|
|
[
|
|
|
|
{type: 'checkbox'},
|
2022-11-18 10:31:44 +08:00
|
|
|
{field: 'id', title: 'ID',width: 40},
|
2021-05-10 13:59:58 +08:00
|
|
|
{field: 'title', title: '菜单名称', minWidth: 165},
|
|
|
|
{field: 'url', title: '菜单地址', rowspan: 2},
|
|
|
|
{
|
|
|
|
title: '菜单图标', align: 'center',
|
|
|
|
templet: '<p><i class="layui-icon {{d.icon}}"></i></p>'
|
|
|
|
},
|
|
|
|
{field: 'authority', title: '权限标识'},
|
2022-11-18 10:31:44 +08:00
|
|
|
{field: 'ismenu', title: '类型', templet: type, align: 'center', width: 60},
|
|
|
|
// {title: '类型', templet: '<p>{{d.ismenu ? "菜单" : "按钮"}}</p>', align: 'center', width: 60},
|
2021-05-10 13:59:58 +08:00
|
|
|
{field: 'sort', title: '排序', align: 'center', width: 60},
|
2022-11-18 10:31:44 +08:00
|
|
|
{field: 'create_time',title: '创建时间'},
|
2021-05-10 13:59:58 +08:00
|
|
|
{align: 'center', toolbar: '#tbBar', title: '操作', width: 120}
|
|
|
|
]
|
|
|
|
],
|
|
|
|
style: 'margin-top:0;'
|
|
|
|
});
|
|
|
|
|
|
|
|
//自定义“状态”列
|
|
|
|
function type(data) {
|
2022-11-18 10:31:44 +08:00
|
|
|
var isMenu = data.ismenu;
|
2021-05-10 13:59:58 +08:00
|
|
|
var btns = "";
|
|
|
|
if (isMenu == -1) {
|
|
|
|
return "目录";
|
2020-01-09 18:03:33 +08:00
|
|
|
}
|
2021-05-10 13:59:58 +08:00
|
|
|
if (isMenu == 1) {
|
|
|
|
btns += '<span class="layui-btn layui-btn-sm">菜单</span>';
|
|
|
|
//return "菜单";
|
|
|
|
}
|
|
|
|
if (isMenu == 0) {
|
|
|
|
btns += '<span class="layui-btn layui-btn-normal layui-btn-sm">按钮</span>';
|
|
|
|
//return "按钮";
|
2020-01-09 18:03:33 +08:00
|
|
|
}
|
2021-05-10 13:59:58 +08:00
|
|
|
return btns;
|
|
|
|
}
|
2020-01-09 18:03:33 +08:00
|
|
|
|
|
|
|
|
2021-05-10 13:59:58 +08:00
|
|
|
// 工具列点击事件
|
|
|
|
treeTable.on('tool(LAY-user-auth-rule)', function (obj) {
|
|
|
|
var event = obj.event;
|
|
|
|
var data = obj.data;
|
|
|
|
if (event === 'del') {
|
|
|
|
|
|
|
|
layer.prompt({
|
|
|
|
formType: 1
|
|
|
|
,title: '敏感操作,请验证口令'
|
|
|
|
}, function(value, index){
|
|
|
|
layer.close(index);
|
|
|
|
layer.confirm('确定删除此权限?', function(index){
|
|
|
|
$.ajax({
|
|
|
|
type:'post',
|
|
|
|
url:"{:url('AuthRule/delete')}",
|
|
|
|
data:{id:data.id},
|
|
|
|
dataType:'json',
|
|
|
|
success:function(data){
|
|
|
|
if(data.code == 0){
|
|
|
|
layer.msg(data.msg,{
|
|
|
|
icon:6,
|
|
|
|
time:2000
|
|
|
|
},function(){
|
|
|
|
location.reload();
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
layer.open({
|
|
|
|
title:'删除失败',
|
|
|
|
content:data.msg,
|
|
|
|
icon:5,
|
|
|
|
adim:6
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2020-01-09 18:03:33 +08:00
|
|
|
});
|
2021-05-10 13:59:58 +08:00
|
|
|
layer.close(index);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
} else if (event === 'edit') {
|
|
|
|
|
|
|
|
layer.open({
|
|
|
|
type: 2
|
|
|
|
,title: '编辑权限'
|
|
|
|
,content: "{:url('AuthRule/edit')}" +'?id='+ data.id
|
|
|
|
,area: ['420px', '550px']
|
|
|
|
,btn: ['确定', '取消']
|
|
|
|
,yes: function(index, layero){
|
|
|
|
var iframeWindow = window['layui-layer-iframe'+ index]
|
|
|
|
,submitID = 'LAY-user-rule-submit'
|
|
|
|
,submit = layero.find('iframe').contents().find('#'+ submitID);
|
|
|
|
|
|
|
|
//监听提交
|
|
|
|
iframeWindow.layui.form.on('submit('+ submitID +')', function(data){
|
|
|
|
var field = data.field; //获取提交的字段
|
|
|
|
|
|
|
|
//提交 Ajax 成功后,静态更新表格中的数据
|
|
|
|
$.ajax({
|
|
|
|
type:"post",
|
|
|
|
url:"{:url('AuthRule/edit')}",
|
2022-11-18 10:31:44 +08:00
|
|
|
data: field,
|
2021-05-10 13:59:58 +08:00
|
|
|
daType:"json",
|
|
|
|
success:function (res){
|
|
|
|
if (res.code == 0) {
|
|
|
|
layer.msg(res.msg,{
|
|
|
|
icon:6,
|
|
|
|
time:2000
|
|
|
|
}, function(){
|
|
|
|
location.reload();
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
layer.open({
|
|
|
|
tiele:'修改失败',
|
|
|
|
content:res.msg,
|
|
|
|
icon:5,
|
|
|
|
anim:6
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2020-01-09 18:03:33 +08:00
|
|
|
});
|
2021-05-10 13:59:58 +08:00
|
|
|
|
|
|
|
//treeTable.reload('LAY-user-auth-rule'); //数据刷新
|
|
|
|
layer.close(index); //关闭弹层
|
|
|
|
});
|
|
|
|
|
|
|
|
submit.trigger('click');
|
|
|
|
}
|
|
|
|
,success: function(layero, index){
|
|
|
|
|
2020-01-09 18:03:33 +08:00
|
|
|
}
|
2021-05-10 13:59:58 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// 头部工具栏点击事件
|
|
|
|
treeTable.on('toolbar(LAY-user-auth-rule)', function (obj) {
|
|
|
|
switch (obj.event) {
|
|
|
|
case 'add':
|
|
|
|
layer.msg('添加');
|
|
|
|
layer.open({
|
|
|
|
type: 2
|
|
|
|
,title: '添加权限'
|
|
|
|
,content: 'add.html'
|
|
|
|
,area: ['420px', '550px']
|
|
|
|
,btn: ['确定', '取消']
|
|
|
|
,yes: function(index, layero){
|
|
|
|
var iframeWindow = window['layui-layer-iframe'+ index]
|
|
|
|
,submitID = 'LAY-user-rule-submit'
|
|
|
|
,submit = layero.find('iframe').contents().find('#'+ submitID);
|
|
|
|
|
|
|
|
//监听提交
|
|
|
|
iframeWindow.layui.form.on('submit('+ submitID +')', function(data){
|
|
|
|
var field = data.field; //获取提交的字段
|
|
|
|
|
|
|
|
//提交 Ajax 成功后,静态更新表格中的数据
|
|
|
|
$.ajax({
|
|
|
|
type:"post",
|
|
|
|
url:"{:url('AuthRule/add')}",
|
2022-11-18 10:31:44 +08:00
|
|
|
data: field,
|
2021-05-10 13:59:58 +08:00
|
|
|
daType:"json",
|
|
|
|
success:function (data){
|
|
|
|
if (data.code == 0) {
|
|
|
|
layer.msg(data.msg,{
|
|
|
|
icon:6,
|
|
|
|
time:2000
|
|
|
|
}, function(){
|
|
|
|
location.reload();
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
layer.open({
|
|
|
|
title:'添加失败',
|
|
|
|
content:data.msg,
|
|
|
|
icon:5,
|
|
|
|
anim:6
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
treeTable.reload('LAY-user-auth-rule'); //数据刷新
|
|
|
|
layer.close(index); //关闭弹层
|
|
|
|
});
|
|
|
|
|
|
|
|
submit.trigger('click');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 'delete':
|
|
|
|
layer.msg('删除');
|
|
|
|
break;
|
|
|
|
case 'update':
|
|
|
|
layer.msg('编辑');
|
|
|
|
break;
|
|
|
|
case 'LAYTABLE_TIPS':
|
|
|
|
layer.msg('提示');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// 全部展开
|
|
|
|
$('#btnExpandAll').click(function () {
|
|
|
|
insTb.expandAll();
|
|
|
|
});
|
|
|
|
|
|
|
|
// 全部折叠
|
|
|
|
$('#btnFoldAll').click(function () {
|
|
|
|
insTb.foldAll();
|
|
|
|
});
|
|
|
|
|
|
|
|
// 展开指定
|
|
|
|
$('#btnExpand').click(function () {
|
|
|
|
insTb.expand(2);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 折叠指定
|
|
|
|
$('#btnFold').click(function () {
|
|
|
|
insTb.fold(2);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 设置选中
|
|
|
|
$('#btnChecked').click(function () {
|
|
|
|
insTb.expand(4);
|
|
|
|
insTb.setChecked([4]);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 搜索
|
|
|
|
$('#btnSearch').click(function () {
|
|
|
|
var keywords = $('#edtSearch').val();
|
|
|
|
if (keywords) {
|
|
|
|
insTb.filterData(keywords);
|
|
|
|
} else {
|
|
|
|
insTb.clearFilter();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// 清除搜索
|
|
|
|
$('#btnClearSearch').click(function () {
|
|
|
|
insTb.clearFilter();
|
|
|
|
});
|
|
|
|
|
|
|
|
// 重载
|
|
|
|
$('#btnReload').click(function () {
|
|
|
|
insTb.reload();
|
|
|
|
});
|
|
|
|
$('#btnRefresh').click(function () {
|
|
|
|
insTb.refresh();
|
|
|
|
});
|
|
|
|
|
|
|
|
// 获取选中
|
|
|
|
$('#btnGetChecked').click(function () {
|
|
|
|
layer.alert('<pre>' + JSON.stringify(insTb.checkStatus().map(function (d) {
|
|
|
|
return {
|
|
|
|
authorityName: d.authorityName,
|
|
|
|
authorityId: d.authorityId,
|
|
|
|
LAY_INDETERMINATE: d.LAY_INDETERMINATE
|
|
|
|
};
|
|
|
|
}), null, 3) + '</pre>');
|
|
|
|
});
|
|
|
|
|
|
|
|
// 演示侧边栏
|
|
|
|
$('#btnToggleSide').click(function () {
|
|
|
|
$('.demo-side').toggleClass('show');
|
|
|
|
});
|
|
|
|
|
2020-01-09 18:03:33 +08:00
|
|
|
});
|
2021-05-10 13:59:58 +08:00
|
|
|
</script>
|
|
|
|
{/block}
|