178 lines
7.0 KiB
HTML
Raw Normal View History

2019-12-17 09:02:09 +08:00
{extend name="$layout"}
2019-12-09 16:22:00 +08:00
{block name="title"}角色管理{/block}
{block name="search"}
<div class="layui-form toolbar">
<div class="layui-form-item">
2019-12-11 21:00:14 +08:00
<!--<div class="layui-inline">
2019-12-09 16:22:00 +08:00
<div class="layui-input-inline mr0">
2019-12-11 21:00:14 +08:00
<input id="edtSearchAuth" class="layui-input" type="text" placeholder="输入角色名称"/>
2019-12-09 16:22:00 +08:00
</div>
</div>
<div class="layui-inline">
<button id="btnSearchAuth" class="layui-btn icon-btn"><i class="layui-icon">&#xe615;</i>搜索
2019-12-11 21:00:14 +08:00
</button>-->
2019-12-09 16:22:00 +08:00
<button id="btnAddAuth" class="layui-btn icon-btn"><i class="layui-icon">&#xe654;</i>添加</button>
2019-12-11 21:00:14 +08:00
<!--</div>-->
2019-12-09 16:22:00 +08:00
</div>
</div>
{/block}
{block name="table"}
2019-12-11 21:00:14 +08:00
<table class="layui-table" id="tableRole"></table>
2019-12-09 16:22:00 +08:00
<!-- 表格操作列 -->
<script type="text/html" id="tableBarAuth">
2019-12-15 13:38:02 +08:00
{:editButton()}
{:addButton('新增子角色')}
{:deleteButton()}
2019-12-09 16:22:00 +08:00
</script>
{/block}
{block name="script"}
<script>
2019-12-11 21:00:14 +08:00
layui.use(['layer', 'form', 'table', 'admin', 'util', 'treeTable'], function () {
2019-12-09 16:22:00 +08:00
var $ = layui.jquery;
var layer = layui.layer;
var form = layui.form;
var table = layui.table;
2019-12-11 21:00:14 +08:00
var util = layui.util;
2019-12-09 16:22:00 +08:00
var admin = layui.admin;
2019-12-11 21:00:14 +08:00
var treeTable = layui.treeTable;
2019-12-09 16:22:00 +08:00
2019-12-11 21:00:14 +08:00
var treeTb = treeTable.render({
tree: {
arrowType: 'arrow2',
iconIndex: 1, // 折叠图标显示在第几列
idName: 'id', // 自定义id字段的名称
childName: 'children', // 自定义标识是否还有子节点的字段名称
pidName: 'parent_id',
isPidData: true,
getIcon: function(d) { // 自定义图标
// d是当前行的数据
if (d.children.length) { // 判断是否有子集
return '<i class="ew-tree-icon ew-tree-icon-folder"></i>';
} else {
return '<i class="ew-tree-icon ew-tree-icon-file"></i>';
}
}
},
elem: '#tableRole',
cellMinWidth: 100,
cols: [
{type: 'numbers', title: '#'},
{field: 'role_name', title: '角色名称', minWidth: 100},
{field: 'description', title: '角色描述'},
{
field: 'created_at', sort: true, templet: function (d) {
return util.toDateString(d.created_at);
}, title: '创建时间', maxWidth: 100
},
{templet: '#tableBarAuth', title: '操作', align: 'center', minWidth: 120}
],
reqData: function(data, callback) {
// 在这里写ajax请求通过callback方法回调数据
$.get('{:url("roles")}', function (res) {
callback(res.data); // 参数是数组类型
});
}
});
2019-12-09 16:22:00 +08:00
// 添加按钮点击事件
$('#btnAddAuth').click(function () {
showEditModel();
});
// 工具条点击事件
2019-12-11 21:00:14 +08:00
treeTable.on('tool(tableRole)', function (obj) {
2019-12-09 16:22:00 +08:00
var data = obj.data;
var layEvent = obj.event;
if (layEvent === 'edit') { // 修改
showEditModel(data);
} else if (layEvent === 'del') { // 删除
2019-12-11 21:00:14 +08:00
doDel(obj);
} else {
showEditModel(data, true);
2019-12-09 16:22:00 +08:00
}
});
// 删除
2019-12-11 21:00:14 +08:00
function doDel(obj) {
layer.confirm('确定要删除“' + obj.data.role_name + '”吗?', {
2019-12-09 16:22:00 +08:00
skin: 'layui-layer-admin',
shade: .1
}, function (index) {
layer.close(index);
2019-12-11 21:00:14 +08:00
admin.req('/role/'+ obj.data.id, {}, function (response) {
if (response.code === 10000) {
layer.msg(response.msg, {icon: 1});
obj.del()
2019-12-09 16:22:00 +08:00
} else {
2019-12-11 21:00:14 +08:00
layer.msg(response.msg, {icon: 2});
2019-12-09 16:22:00 +08:00
}
2019-12-11 21:00:14 +08:00
}, 'delete');
2019-12-09 16:22:00 +08:00
});
}
// 显示表单弹窗
// 显示表单弹窗
2019-12-11 21:00:14 +08:00
function showEditModel(mRole, addRole = false) {
2019-12-09 16:22:00 +08:00
var layIndex = admin.open({
2019-12-11 21:00:14 +08:00
title: addRole ? '新增子角色' : ((mRole ? '修改' : '添加') + '角色'),
url: addRole ? '/role/create' + '?id='+mRole.id : (mRole ? '/role/'+mRole.id + '/edit': '/role/create'),
data: addRole ? '' : mRole, // 传递数据到表单页面
2019-12-12 09:13:29 +08:00
area: '700px',
2019-12-09 16:22:00 +08:00
end: function () {
if (admin.getLayerData(layIndex, 'formOk')) { // 判断表单操作成功标识
2019-12-11 21:00:14 +08:00
if (addRole) {
treeTb.reload();
setTimeout(function () {
treeTb.expand(mRole.id)
}, 200)
} else {
if (mRole) {
treeTb.reload();
setTimeout(function () {
treeTb.expand(mRole.id)
}, 200)
} else {
treeTb.reload(); // 成功刷新表格
}
}
2019-12-09 16:22:00 +08:00
}
},
success: function (layero, dIndex) {
// 弹窗超出范围不出现滚动条
$(layero).children('.layui-layer-content').css('overflow', 'visible');
}
});
}
// 搜索按钮点击事件
$('#btnSearchAuth').click(function () {
$('#edtSearchAuth').removeClass('layui-form-danger');
var keyword = $('#edtSearchAuth').val();
var $tds = $('#tableAuth').next('.treeTable').find('.layui-table-body tbody tr td');
$tds.css('background-color', 'transparent');
if (!keyword) {
layer.tips('请输入关键字', '#edtSearchAuth', {tips: [1, '#ff4c4c']});
$('#edtSearchAuth').addClass('layui-form-danger');
$('#edtSearchAuth').focus();
return;
}
var searchCount = 0;
$tds.each(function () {
if ($(this).text().indexOf(keyword) >= 0) {
$(this).css('background-color', '#FAE6A0');
if (searchCount == 0) {
$('body,html').stop(true);
$('body,html').animate({scrollTop: $(this).offset().top - 150}, 500);
}
searchCount++;
}
});
if (searchCount == 0) {
layer.msg("没有匹配结果", {icon: 5, anim: 6});
} else {
treetable.expandAll('#tableAuth');
}
});
});
</script>
{/block}