【Dict】完善新的字典功能

pull/64/head
chenjinlong 2021-01-21 21:01:13 +08:00
parent 504245a5e9
commit d4c2ced31f
2 changed files with 328 additions and 0 deletions

View File

@ -0,0 +1,220 @@
layui.use(['layer', 'form', 'table', 'util', 'admin', 'func', 'HttpRequest'], function () {
var $ = layui.jquery;
var layer = layui.layer;
var form = layui.form;
var table = layui.table;
var admin = layui.admin;
var HttpRequest = layui.HttpRequest;
var func = layui.func;
var selObj; // 左表选中数据
var Dict = {
tableId: "dictTable",
};
var DictType = {
tableId: "dictTypeTable"
};
/* 字典类型-点击新增对话框 */
DictType.openAddDlg = function () {
func.open({
height: 700,
title: '添加字典类型',
content: Feng.ctxPath + '/view/dictType/addView',
tableId: DictType.tableId
});
};
/* 字典类型-点击编辑对话框 */
DictType.openEditDlg = function (data) {
func.open({
height: 700,
title: '修改字典类型',
content: Feng.ctxPath + '/view/dictType/editView?dictTypeId=' + data.dictTypeId,
tableId: DictType.tableId
});
};
/* 字典类型-点击删除 */
DictType.onDeleteItem = function (data) {
if (data.dictTypeClass === 2) {
Feng.error("系统类型无法删除");
return;
}
var operation = function () {
var httpRequest = new HttpRequest(Feng.ctxPath + "/dictType/deleteDictType", 'post', function (data) {
Feng.success("删除成功!");
table.reload(DictType.tableId);
}, function (data) {
Feng.error("删除失败!" + data.message + "!");
});
httpRequest.set(data);
httpRequest.start(true);
};
Feng.confirm("是否删除?", operation);
};
/* 字典类型-点击搜索 */
form.on('submit(dictTypeTbSearch)', function (data) {
dictTypeTable.reload({where: data.field});
return false;
});
/* 字典类型-点击表格头工具栏 */
table.on('toolbar(dictTypeTable)', function (obj) {
var data = obj.data;
if (obj.event === 'add') { // 添加
DictType.openAddDlg();
} else if (obj.event === 'edit') { // 修改
DictType.openEditDlg(data);
} else if (obj.event === 'del') { // 删除
DictType.onDeleteItem(data);
}
});
/* 字典类型-渲染表格 */
var dictTypeTable = table.render({
elem: '#dictTypeTable',
url: Feng.ctxPath + '/dictType/getDictTypePageList',
height: 'full-100',
toolbar: '#dictTypeHtbBar',
defaultToolbar: [], //默认表格头部右侧工具栏
cols: [[
{type: 'numbers'},
{field: 'dictTypeName', title: '类型'},
{field: 'dictTypeCode', title: '编码'},
]],
done: function (res, curr, count) {
//加载后自动选中第一行并出发click事件
$('#dictTypeTable+.layui-table-view .layui-table-body tbody>tr:first').trigger('click');
},
parseData: Feng.parseData //解析成 table 组件所规定的数据格式
});
/* 字典类型-监听行单击事件 */
table.on('row(dictTypeTable)', function (obj) {
selObj = obj;
obj.tr.addClass('layui-table-click').siblings().removeClass('layui-table-click');
dictTable.reload({where: {dictTypeCode: obj.data.dictTypeCode}, page: {curr: 1}, url: Feng.ctxPath + '/dict/page'});
});
/* 删除 */
function doDel(obj) {
layer.confirm('确定要删除此字典吗?', {
skin: 'layui-layer-admin',
shade: .1
}, function (i) {
layer.close(i);
var loadIndex = layer.load(2);
$.get('../../json/ok.json', {
id: obj.data.dictId,
}, function (res) {
layer.close(loadIndex);
if (200 === res.code) {
layer.msg(res.msg, {icon: 1});
obj.del();
$('#dictTypeTable+.layui-table-view .layui-table-body tbody>tr:first').trigger('click');
} else {
layer.msg(res.msg, {icon: 2});
}
}, 'json');
});
}
/* 字典-点击新增对话框 */
Dict.openAddDlg = function (data) {
func.open({
height: 680,
title: '添加字典',
content: Feng.ctxPath + '/view/dict/addView?dictTypeId=' + data.dictTypeId,
tableId: Dict.tableId
});
};
/* 字典-点击编辑对话框 */
Dict.openEditDlg = function (data) {
func.open({
height: 680,
title: '修改字典',
content: Feng.ctxPath + '/view/dict/editView?dictId=' + data.dictId,
tableId: Dict.tableId
});
};
/* 字典-点击删除 */
Dict.onDeleteItem = function (data) {
var operation = function () {
var httpRequest = new HttpRequest(Feng.ctxPath + "/dict/deleteDict", 'post', function (data) {
Feng.success("删除成功!");
table.reload(Dict.tableId);
}, function (data) {
Feng.error("删除失败!" + data.message + "!");
});
httpRequest.set(data);
httpRequest.start(true);
};
Feng.confirm("是否删除?", operation);
};
/* 字典-点击搜索 */
form.on('submit(dictTbSearch)', function (data) {
//赋值左表dictTypeCode
data.field.dictTypeCode = selObj.data.dictTypeCode;
dictTable.reload({where: data.field});
return false;
});
/* 字典-点击操作工具栏 */
table.on('tool(dictTable)', function (obj) {
var data = obj.data;
if (obj.event === 'edit') { // 修改
Dict.openEditDlg(data);
} else if (obj.event === 'del') { // 删除
Dict.onDeleteItem(data);
}
});
// 添加按钮点击事件
$('#btnAdd').click(function () {
Dict.openAddDlg(selObj.data);
return false;
});
/* 字典-点击表格头工具栏 */
// table.on('toolbar(dictTable)', function (obj) {
// if (obj.event === 'add') { // 添加
// Dict.openAddDlg(selObj.data);
// } else if (obj.event === 'del') { // 删除
// var checkRows = table.checkStatus('dictTable');
// if (checkRows.data.length === 0) {
// layer.msg('请选择要删除的数据', {icon: 2});
// return;
// }
// var ids = checkRows.data.map(function (d) {
// return d.dictDataId;
// });
// doDel2({ids: ids});
// }
// });
/* 字典-渲染表格 */
var dictTable = table.render({
elem: '#dictTable',
data: [],
height: 'full-100',
page: true,
//toolbar: '#dictHtbBar',
cellMinWidth: 100,
cols: [[
{type: 'checkbox'},
{type: 'numbers'},
{field: 'dictName', align: "center", sort: true, title: '字典名称'},
{field: 'dictCode', align: "center", sort: true, title: '字典编码'},
{field: 'dictSort', align: "center", sort: true, title: '排序号'},
{align: 'center', toolbar: '#dictTbBar', title: '操作'}
]],
parseData: Feng.parseData
});
});

View File

@ -0,0 +1,108 @@
@layout("/layout/_container.html",{js:["/assets/modular/system/dict/dictionary.js"]}){
<style>
#dictTypeTable + .layui-table-view .layui-table-tool-temp {
padding-right: 0;
}
#dictTypeTable + .layui-table-view .layui-table-body tbody > tr td {
cursor: pointer;
}
#dictTypeTable + .layui-table-view .layui-table-body tbody > tr.layui-table-click {
background-color: #fff3e0;
}
#dictTypeTable + .layui-table-view .layui-table-body tbody > tr.layui-table-click td:last-child > div:before {
position: absolute;
right: 6px;
content: "\e602";
font-size: 12px;
font-style: normal;
font-family: layui-icon !important;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
</style>
<div class="layui-fluid" style="padding-bottom: 0;">
<div class="layui-row layui-col-space15">
<div class="layui-col-md3">
<div class="layui-card">
<div class="layui-card-body" style="padding: 10px;">
<!-- 表格工具栏1 -->
<form class="layui-form toolbar">
<div class="layui-form-item">
<div class="layui-inline" style="max-width: 140px;">
<input name="dictTypeName" class="layui-input" type="text" placeholder="类型" autocomplete="off"/>
</div>
<div class="layui-inline" style="max-width: 140px;">
<input name="dictTypeCode" class="layui-input" type="text" placeholder="编码" autocomplete="off"/>
</div>
<div class="layui-inline">
<button class="layui-btn icon-btn" lay-filter="dictTypeTbSearch" lay-submit>
<i class="layui-icon">&#xe615;</i>搜索
</button>
</div>
</div>
</form>
<!-- 数据表格1 -->
<table id="dictTypeTable" lay-filter="dictTypeTable"></table>
</div>
</div>
</div>
<div class="layui-col-md9">
<div class="layui-card">
<div class="layui-card-body" style="padding: 10px;">
<!-- 表格工具栏2 -->
<form class="layui-form toolbar">
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label">字典名称:</label>
<div class="layui-input-inline">
<input name="dictName" class="layui-input" placeholder="输入字典名称"/>
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label">字典编码:</label>
<div class="layui-input-inline">
<input name="dictCode" class="layui-input" placeholder="输入字典键值"/>
</div>
</div>
<div class="layui-inline">&emsp;
<button class="layui-btn icon-btn" lay-filter="dictTbSearch" lay-submit><i class="layui-icon">&#xe615;</i>搜索</button>
<button id="btnAdd" class="layui-btn icon-btn"><i class="layui-icon">&#xe654;</i>添加</button>
</div>
</div>
</form>
<!-- 数据表格2 -->
<table id="dictTable" lay-filter="dictTable"></table>
</div>
</div>
</div>
</div>
</div>
<!-- 表格头部操作列 -->
<script type="text/html" id="dictTypeHtbBar">
<button lay-event="add" class="layui-btn layui-btn-sm icon-btn"><i class="layui-icon">&#xe654;</i>添加</button>
<button lay-event="edit" class="layui-btn layui-btn-sm layui-btn-warm icon-btn"><i class="layui-icon">&#xe642;</i>修改</button>
<button lay-event="del" class="layui-btn layui-btn-sm layui-btn-danger icon-btn"><i class="layui-icon">&#xe640;</i>删除</button>
</script>
<!-- 表格头部操作列结束 -->
<!-- 表格头部操作列 -->
<script type="text/html" id="dictHtbBar">
<button lay-event="add" class="layui-btn layui-btn-sm icon-btn"><i class="layui-icon">&#xe654;</i>添加</button>
<button lay-event="del" class="layui-btn layui-btn-sm layui-btn-danger icon-btn"><i class="layui-icon">&#xe640;</i>删除</button>
</script>
<!-- 表格头部操作列结束 -->
<!-- 表格操作列 -->
<script type="text/html" id="dictTbBar">
<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>
</script>
<!-- 表格操作列结束 -->
@}