layui.define(['layer', 'table'], function (exports) { var $ = layui.jquery; var layer = layui.layer; var table = layui.table; var instances = []; var treetable = { render: function (param) { param.method = param.method?param.method:"GET"; if (!treetable.checkParam(param)) { return; } if (param.data) { treetable.init(param, param.data); } else { if(param.method === 'post' || param.method === 'POST') { $.post(param.url, param.where, function(res){ if(param.parseData){ res = param.parseData(res); param.data = res.data; } treetable.init(param, res.data); }); } else { $.get(param.url, param.where, function(res){ if(param.parseData){ res = param.parseData(res); param.data = res.data; } treetable.init(param, res.data); }); } } }, // 渲染表格 init: function (param, data) { var mData = []; var doneCallback = param.done; var tNodes = data; for (var i = 0; i < tNodes.length; i++) { var tt = tNodes[i]; if (!tt.id) { tt.id = tt[param.treeIdName]; } if (!tt.pid) { tt.pid = tt[param.treePidName]; } } var sort = function (s_pid, data) { for (var i = 0; i < data.length; i++) { if (data[i].pid == s_pid) { var len = mData.length; if (len > 0 && mData[len - 1].id == s_pid) { mData[len - 1].isParent = true; } mData.push(data[i]); sort(data[i].id, data); } } }; sort(param.treeSpid, tNodes); param.prevUrl = param.url; param.url = undefined; param.data = mData; param.page = { count: param.data.length, limit: param.data.length }; param.cols[0][param.treeColIndex].templet = function (d) { var mId = d.id; var mPid = d.pid; var isDir = d.isParent; var emptyNum = treetable.getEmptyNum(mPid, mData); var iconHtml = ''; for (var i = 0; i < emptyNum; i++) { iconHtml += ''; } if (isDir) { iconHtml += ' '; } else { iconHtml += ''; } iconHtml += '  '; var ttype = isDir ? 'dir' : 'file'; var vg = ''; return vg + iconHtml + d[param.cols[0][param.treeColIndex].field] + '' }; param.done = function (res, curr, count) { $(param.elem).next().addClass('treeTable'); $('.treeTable .layui-table-page').css('display', 'none'); $(param.elem).next().attr('treeLinkage', param.treeLinkage); if (param.treeDefaultClose) { treetable.foldAll(param.elem); } if (doneCallback) { doneCallback(res, curr, count); } }; // 渲染表格 table.render(param); var result = instances.some(item=>item.key===param.elem); if(!result){ instances.push({key:param.elem,value:param}); } }, reload: function(elem) { instances.forEach(function(item){ if(item.key === elem) { $(elem).next().remove(); item.value.data = undefined; item.value.url = item.value.prevUrl; treetable.render(item.value); } }) }, search: function(elem,keyword) { var $tds = $(elem).next('.treeTable').find('.layui-table-body tbody tr td'); if (!keyword) { $tds.css('background-color', 'transparent'); layer.msg("请输入关键字", {icon: 5}); return; } var searchCount = 0; $tds.each(function () { $(this).css('background-color', 'transparent'); if ($(this).text().indexOf(keyword) >= 0) { $(this).css('background-color', 'rgba(250,230,160,0.5)'); if (searchCount == 0) { $('body,html').stop(true); $('body,html').animate({scrollTop: $(this).offset().top - 150}, 500); } searchCount++; } }); if (searchCount == 0) { layer.msg("没有匹配结果", {icon: 5}); } else { treetable.expandAll(elem); } }, getEmptyNum: function (pid, data) { var num = 0; if (!pid) { return num; } var tPid; for (var i = 0; i < data.length; i++) { if (pid == data[i].id) { num += 1; tPid = data[i].pid; break; } } return num + treetable.getEmptyNum(tPid, data); }, // 展开/折叠行 toggleRows: function ($dom, linkage) { var type = $dom.attr('lay-ttype'); if ('file' == type) { return; } var mId = $dom.attr('lay-tid'); var isOpen = $dom.hasClass('open'); if (isOpen) { $dom.removeClass('open'); } else { $dom.addClass('open'); } $dom.closest('tbody').find('tr').each(function () { var $ti = $(this).find('.treeTable-icon'); var pid = $ti.attr('lay-tpid'); var ttype = $ti.attr('lay-ttype'); var tOpen = $ti.hasClass('open'); if (mId == pid) { if (isOpen) { $(this).hide(); if ('dir' == ttype && tOpen == isOpen) { $ti.trigger('click'); } } else { $(this).show(); if (linkage && 'dir' == ttype && tOpen == isOpen) { $ti.trigger('click'); } } } }); }, // 检查参数 checkParam: function (param) { if (!param.treeSpid && param.treeSpid != 0) { layer.msg('参数treeSpid不能为空', {icon: 5}); return false; } if (!param.treeIdName) { layer.msg('参数treeIdName不能为空', {icon: 5}); return false; } if (!param.treePidName) { layer.msg('参数treePidName不能为空', {icon: 5}); return false; } if (!param.treeColIndex && param.treeColIndex != 0) { layer.msg('参数treeColIndex不能为空', {icon: 5}); return false; } return true; }, // 展开所有 expandAll: function (dom) { $(dom).next('.treeTable').find('.layui-table-body tbody tr').each(function () { var $ti = $(this).find('.treeTable-icon'); var ttype = $ti.attr('lay-ttype'); var tOpen = $ti.hasClass('open'); if ('dir' == ttype && !tOpen) { $ti.trigger('click'); } }); }, // 折叠所有 foldAll: function (dom) { $(dom).next('.treeTable').find('.layui-table-body tbody tr').each(function () { var $ti = $(this).find('.treeTable-icon'); var ttype = $ti.attr('lay-ttype'); var tOpen = $ti.hasClass('open'); if ('dir' == ttype && tOpen) { $ti.trigger('click'); } }); } }; // 给图标列绑定事件 $('body').on('click', '.treeTable .treeTable-icon', function () { var treeLinkage = $(this).parents('.treeTable').attr('treeLinkage'); if ('true' == treeLinkage) { treetable.toggleRows($(this), true); } else { treetable.toggleRows($(this), false); } }); exports('treetable', treetable); });