catchAdmin/catch/user/view/index.html

194 lines
7.3 KiB
HTML
Raw Normal View History

2019-12-17 09:02:00 +08:00
{extend name="$layout"}
2019-12-06 08:24:07 +08:00
{block name="title"}用户管理{/block}
{block name="search"}
<div class="layui-form toolbar">
<div class="layui-form-item">
<div class="layui-inline">
2019-12-07 17:31:38 +08:00
<label class="layui-form-label w-auto">用户名:</label>
<div class="layui-input-inline">
<input name="username" class="layui-input" type="text" placeholder="输入用户名"/>
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label w-auto">邮箱:</label>
2019-12-06 08:24:07 +08:00
<div class="layui-input-inline mr0">
2019-12-07 17:31:38 +08:00
<input name="email" class="layui-input" type="text" placeholder="输入邮箱"/>
2019-12-06 08:24:07 +08:00
</div>
</div>
<div class="layui-inline">
2019-12-07 17:31:38 +08:00
<label class="layui-form-label w-auto">状态:</label>
2019-12-06 08:24:07 +08:00
<div class="layui-input-inline mr0">
2019-12-07 17:31:38 +08:00
<select name="status">
<option value="">选择状态</option>
<option value="1">正常</option>
<option value="2">禁用</option>
</select>
2019-12-06 08:24:07 +08:00
</div>
</div>
<div class="layui-inline">
2019-12-07 17:31:38 +08:00
<label class="layui-form-label w-auto">回收站:</label>
2019-12-06 08:24:07 +08:00
<div class="layui-input-inline mr0">
2019-12-07 17:31:38 +08:00
<select name="trash">
<option value="">选择</option>
<option value="1">恢复数据</option>
2019-12-06 08:24:07 +08:00
</select>
</div>
</div>
<div class="layui-inline" style="padding-right: 110px;">
<button class="layui-btn icon-btn" lay-filter="formSubSearchUser" lay-submit>
<i class="layui-icon">&#xe615;</i>搜索
</button>
<button id="btnAddUser" class="layui-btn icon-btn"><i class="layui-icon">&#xe654;</i>添加</button>
</div>
</div>
</div>
{/block}
{block name="table"}
2019-12-07 17:31:38 +08:00
<table class="layui-table" id="tableUser" lay-filter="tableUser"></table>
<!-- 表格操作列 -->
<script type="text/html" id="tableBarUser">
2019-12-15 13:38:02 +08:00
{:editButton()}
2019-12-07 17:31:38 +08:00
<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="{{d.deleted_at ? 'recover' : 'del'}}">{{d.deleted_at ? '恢复' : '删除'}}</a>
</script>
<!-- 表格状态列 -->
<script type="text/html" id="tableStateUser">
<input type="checkbox" lay-filter="ckStateUser" value="{{d.id}}" lay-skin="switch"
lay-text="正常|禁用" {{d.status==1?'checked':''}}/>
</script>
2019-12-06 08:24:07 +08:00
{/block}
{block name="script"}
<script>
layui.use(['layer', 'form', 'table', 'util', 'admin'], function () {
var $ = layui.jquery;
var layer = layui.layer;
var form = layui.form;
var table = layui.table;
var util = layui.util;
var admin = layui.admin;
// 渲染表格
var insTb = table.render({
elem: '#tableUser',
2019-12-07 17:31:38 +08:00
url: '{:url("users")}',
2019-12-06 08:24:07 +08:00
page: true,
2019-12-07 17:31:38 +08:00
response: {
statusCode: 10000,
},
2019-12-06 08:24:07 +08:00
toolbar: true,
cellMinWidth: 100,
cols: [[
2019-12-07 17:31:38 +08:00
{type: 'id', title: '#', field: 'id'},
{field: 'username', sort: true, title: '用户名'},
{field: 'email', sort: true, title: '邮箱'},
{field: 'status', sort: true, title: '状态', templet: '#tableStateUser'},
2019-12-06 08:24:07 +08:00
{
2019-12-07 17:31:38 +08:00
field: 'created_at', sort: true, templet: function (d) {
return util.toDateString(d.created_at);
2019-12-06 08:24:07 +08:00
}, title: '创建时间'
},
2019-12-07 17:31:38 +08:00
{
field: 'updated_at', sort: true, templet: function (d) {
return util.toDateString(d.updated_at);
}, title: '更新时间'
},
2019-12-06 08:24:07 +08:00
{align: 'center', toolbar: '#tableBarUser', title: '操作', minWidth: 200}
2019-12-07 17:31:38 +08:00
]],
2019-12-06 08:24:07 +08:00
});
// 添加
$('#btnAddUser').click(function () {
showEditModel();
});
// 搜索
form.on('submit(formSubSearchUser)', function (data) {
insTb.reload({where: data.field}, 'data');
});
// 工具条点击事件
table.on('tool(tableUser)', function (obj) {
var data = obj.data;
var layEvent = obj.event;
if (layEvent === 'edit') { // 修改
showEditModel(data);
} else if (layEvent === 'del') { // 删除
2019-12-07 17:31:38 +08:00
doDel(data.id, data.username);
2019-12-06 08:24:07 +08:00
} else if (layEvent === 'reset') { // 重置密码
2019-12-07 17:31:38 +08:00
resetPsw(data.id, data.username);
} else if (layEvent === 'recover') {
recover(data.id, data.username);
2019-12-06 08:24:07 +08:00
}
2019-12-07 17:31:38 +08:00
2019-12-06 08:24:07 +08:00
});
2019-12-07 17:31:38 +08:00
function recover(uid, username) {
layer.confirm('确定要恢复“' + username + '”吗?', {
skin: 'layui-layer-admin',
shade: .1
}, function (i) {
layer.close(i);
admin.req('/user/recover/'+ uid,{}, function(res){
layer.closeAll('loading');
if (res.code == 10000) {
layer.msg(res.msg, {icon: 1});
insTb.reload({}, 'data');
} else {
layer.msg(res.msg, {icon: 2});
}
}, 'put');
});
}
2019-12-06 08:24:07 +08:00
// 显示表单弹窗
function showEditModel(mUser) {
2019-12-07 17:31:38 +08:00
var layIndex = admin.open({
2019-12-06 08:24:07 +08:00
title: (mUser ? '修改' : '添加') + '用户',
2019-12-07 17:31:38 +08:00
url: mUser ? '/user/'+mUser.id + '/edit':'/user/create',
data: mUser, // 传递数据到表单页面
2019-12-12 18:52:24 +08:00
area: '500px',
2019-12-07 17:31:38 +08:00
end: function () {
if (admin.getLayerData(layIndex, 'formOk')) { // 判断表单操作成功标识
insTb.reload(); // 成功刷新表格
}
},
2019-12-06 08:24:07 +08:00
success: function (layero, dIndex) {
2019-12-07 17:31:38 +08:00
// 弹窗超出范围不出现滚动条
2019-12-06 08:24:07 +08:00
$(layero).children('.layui-layer-content').css('overflow', 'visible');
}
});
}
// 删除
function doDel(userId, nickName) {
layer.confirm('确定要删除“' + nickName + '”吗?', {
skin: 'layui-layer-admin',
shade: .1
}, function (i) {
layer.close(i);
2019-12-07 17:31:38 +08:00
admin.req('/user/'+ userId,{}, function(res){
2019-12-06 08:24:07 +08:00
layer.closeAll('loading');
2019-12-07 17:31:38 +08:00
if (res.code == 10000) {
2019-12-06 08:24:07 +08:00
layer.msg(res.msg, {icon: 1});
insTb.reload({}, 'data');
} else {
layer.msg(res.msg, {icon: 2});
}
2019-12-07 17:31:38 +08:00
}, 'delete');
2019-12-06 08:24:07 +08:00
});
}
// 修改用户状态
form.on('switch(ckStateUser)', function (obj) {
2019-12-07 17:31:38 +08:00
admin.req('/user/switch/status/'+obj.value,{}, function(res){
2019-12-06 08:24:07 +08:00
layer.closeAll('loading');
2019-12-07 17:31:38 +08:00
if (res.code == 10000) {
2019-12-06 08:24:07 +08:00
layer.msg(res.msg, {icon: 1});
} else {
layer.msg(res.msg, {icon: 2});
$(obj.elem).prop('checked', !obj.elem.checked);
form.render('checkbox');
}
2019-12-07 17:31:38 +08:00
}, 'put');
2019-12-06 08:24:07 +08:00
});
});
</script>
{/block}