var pageCurr; var tableRender; layui.config({ base: baseUrl + "/static/layui/lay/modules/" // 配置模块所在的目录 }).use(['table','laydate', 'form','treeTable'], function(){ var table = layui.table; var $ = layui.jquery; var layer = layui.layer; var layDate = layui.laydate; var form = layui.form; var treetable = layui.treeTable; tableRender = function() { var tableIdx = treetable.render({ elem: '#tag', url: baseUrl+'/tag/list/auth', headers: {token: localStorage.getItem('token')}, height: 'full-200', tree: { iconIndex: 1, // 折叠图标显示在第几列 isPidData: true, // 是否是id、pid形式数据 idName: 'id', // id字段名称 pidName: 'parentId' // pid字段名称 }, toolbar: 'default', cols: [[ {type: 'checkbox'} ,{field: 'uuid', align: 'center',title: '编号'} ,{field: 'name', align: 'center',title: '名称'} ,{field: 'parentId', align: 'center',title: '父级'} ,{field: 'parentName', align: 'center',title: '父级名称'} // ,{field: 'path', align: 'center',title: '关联路径'} // ,{field: 'pathName', align: 'center',title: '关联路径名'} ,{field: 'type$', align: 'center',title: '类型'} ,{field: 'leading', align: 'center',title: '负责人'} ,{field: 'img', align: 'center',title: '图片'} ,{field: 'brief', align: 'center',title: '简要描述'} ,{field: 'count', align: 'center',title: '数量'} ,{field: 'level', align: 'center',title: '等级'} ,{field: 'sort', align: 'center',title: '排序'} ,{field: 'status$', align: 'center',title: '状态'} ,{field: 'updateTime$', align: 'center',title: '修改时间'} ,{field: 'updateBy$', align: 'center',title: '修改人员', hide: true} ,{field: 'memo', align: 'center',title: '备注', hide: true} ,{fixed: 'right', title:'操作', align: 'center', toolbar: '#operate', width:150} ]], done: function () { tableIdx.expandAll(); // $(".ew-tree-table .ew-tree-table-tool .ew-tree-table-tool-item").css("display", "none"); limit() } }); } tableRender(); // 头部工具栏点击事件 treetable.on('toolbar(tag)', function (obj) { switch (obj.event) { case 'add': layer.open({ type: 2, title: '新增归类', maxmin: true, area: ['40%', top.detailHeight], content: 'tag_detail.html', success: function(layero, index){ layer.getChildFrame('#data-detail-submit-edit', index).hide(); clearFormVal(layer.getChildFrame('#detail', index)); layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"}); } }); break; case 'delete': layer.msg('禁用'); break; case 'update': layer.msg('禁用'); break; } }); // 监听行工具事件 table.on('tool(tag)', function(obj){ var data = obj.data; switch (obj.event) { // 编辑 case 'edit': layer.open({ type: 2, title: '修改', maxmin: true, area: [top.detailWidth, top.detailHeight], content: 'tag_detail.html', success: function(layero, index){ layer.getChildFrame('#data-detail-submit-save', index).hide(); setFormVal(layer.getChildFrame('#detail', index), data, false); top.convertDisabled(layer.getChildFrame('#data-detail :input', index), false); top.convertDisabled(layer.getChildFrame('#id', index), true); layer.iframeAuto(index);layer.style(index, {top: (($(window).height()-layer.getChildFrame('#data-detail', index).height())/3)+"px"}); layero.find('iframe')[0].contentWindow.layui.form.render('select'); layero.find('iframe')[0].contentWindow.layui.form.render('checkbox'); } }); break; } }); // 数据保存动作 form.on('submit(save)', function () { if (banMsg != null){ layer.msg(banMsg); return; } method("add"); }); // 数据修改动作 form.on('submit(edit)', function () { method("update") }); function method(name){ var index = layer.load(1, { shade: [0.5,'#000'] //0.1透明度的背景 }); var data = { // id: $('#id').val(), id: $('#id').val(), uuid: $('#uuid').val(), name: $('#name').val(), parentId: $('#parentId').val(), parentName: $('#parentName').val(), path: $('#path').val(), pathName: $('#pathName').val(), type: $('#type').val(), leading: $('#leading').val(), img: $('#img').val(), brief: $('#brief').val(), count: $('#count').val(), level: $('#level').val(), sort: $('#sort').val(), status: $('#status').val(), createTime: top.strToDate($('#createTime\\$').val()), createBy: $('#createBy').val(), updateTime: top.strToDate($('#updateTime\\$').val()), updateBy: $('#updateBy').val(), memo: $('#memo').val(), }; $.ajax({ url: baseUrl+"/tag/"+name+"/auth", headers: {'token': localStorage.getItem('token')}, data: top.reObject(data), method: 'POST', success: function (res) { if (res.code === 200){ parent.layer.closeAll(); parent.$(".layui-laypage-btn")[0].click(); $("#data-detail :input").each(function () { $(this).val(""); }); } else if (res.code === 403){ top.location.href = baseUrl+"/"; }else { layer.msg(res.msg) } layer.close(index); } }) } // 复选框事件 form.on('checkbox(detailCheckbox)', function (data) { var el = data.elem; if (el.checked) { $(el).val('Y'); } else { $(el).val('N'); } }); // 搜索栏搜索事件 form.on('submit(search)', function (data) { pageCurr = 1; tableReload(false); }); // 搜索栏重置事件 form.on('submit(reset)', function (data) { pageCurr = 1; clearFormVal($('#search-box')); tableReload(false); }); // 时间选择器 layDate.render({ elem: '#createTime\\$', type: 'datetime' }); layDate.render({ elem: '#updateTime\\$', type: 'datetime' }); }); // 关闭动作 $(document).on('click','#data-detail-close', function () { parent.layer.closeAll(); }); function tableReload(child) { var searchData = {}; $.each($('#search-box [name]').serializeArray(), function() { searchData[this.name] = this.value; }); (child ? parent.tableIns : tableIns).reload({ where: searchData, page: { curr: pageCurr }, done: function (res, curr, count) { if (res.code === 403) { top.location.href = baseUrl+"/"; } pageCurr=curr; if (res.data.length === 0 && count !== 0) { tableIns.reload({ where: searchData, page: { curr: pageCurr-1 } }); pageCurr -= 1; } limit(child); } }); } function setFormVal(el, data, showImg) { for (var val in data) { var find = el.find(":input[id='" + val + "']"); if (find[0]!=null){ if (find[0].type === 'checkbox'){ if (data[val]==='Y'){ find.attr("checked","checked"); find.val('Y'); } else { find.remove("checked"); find.val('N'); } continue; } } find.val(data[val]); if (showImg){ var next = find.next(); if (next.get(0)){ if (next.get(0).localName === "img") { find.hide(); next.attr("src", data[val]); next.show(); } } } } } function clearFormVal(el) { $(':input', el) .val('') .removeAttr('checked') .removeAttr('selected'); } function detailScreen(index) { var detail = layer.getChildFrame('#data-detail', index); var height = detail.height()+60; if (height > ($(window).height()*0.9)) { height = ($(window).height()*0.8); } layer.style(index, { // top: (($(window).height()-height)/3)+"px", height: height+'px' }); } $('body').keydown(function () { if (event.keyCode === 13) { $("#search").click(); } });