treetable.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. layui.define(['layer', 'table'], function (exports) {
  2. var $ = layui.jquery;
  3. var layer = layui.layer;
  4. var table = layui.table;
  5. var treetable = {
  6. // 渲染树形表格
  7. render: function (param) {
  8. // 检查参数
  9. if (!treetable.checkParam(param)) {
  10. return;
  11. }
  12. // 获取数据
  13. if (param.data) {
  14. treetable.init(param, param.data);
  15. } else {
  16. $.getJSON(param.url, param.where, function (res) {
  17. treetable.init(param, res.data);
  18. });
  19. }
  20. },
  21. // 渲染表格
  22. init: function (param, data) {
  23. var mData = [];
  24. var doneCallback = param.done;
  25. var tNodes = data;
  26. // 补上id和pid字段
  27. for (var i = 0; i < tNodes.length; i++) {
  28. var tt = tNodes[i];
  29. if (!tt.id) {
  30. if (!param.treeIdName) {
  31. layer.msg('参数treeIdName不能为空', {icon: 5});
  32. return;
  33. }
  34. tt.id = tt[param.treeIdName];
  35. }
  36. if (!tt.pid) {
  37. if (!param.treePidName) {
  38. layer.msg('参数treePidName不能为空', {icon: 5});
  39. return;
  40. }
  41. tt.pid = tt[param.treePidName];
  42. }
  43. }
  44. // 对数据进行排序
  45. var sort = function (s_pid, data) {
  46. for (var i = 0; i < data.length; i++) {
  47. if (data[i].pid == s_pid) {
  48. var len = mData.length;
  49. if (len > 0 && mData[len - 1].id == s_pid) {
  50. mData[len - 1].isParent = true;
  51. }
  52. mData.push(data[i]);
  53. sort(data[i].id, data);
  54. }
  55. }
  56. };
  57. sort(param.treeSpid, tNodes);
  58. // 重写参数
  59. param.url = undefined;
  60. param.data = mData;
  61. param.page = {
  62. count: param.data.length,
  63. limit: param.data.length
  64. };
  65. param.cols[0][param.treeColIndex].templet = function (d) {
  66. var mId = d.id;
  67. var mPid = d.pid;
  68. var isDir = d.isParent;
  69. var emptyNum = treetable.getEmptyNum(mPid, mData);
  70. var iconHtml = '';
  71. for (var i = 0; i < emptyNum; i++) {
  72. iconHtml += '<span class="treeTable-empty"></span>';
  73. }
  74. if (isDir) {
  75. iconHtml += '<i class="layui-icon layui-icon-triangle-d"></i>';
  76. }
  77. iconHtml += '&nbsp;&nbsp;';
  78. var ttype = isDir ? 'dir' : 'file';
  79. var vg = '<span class="treeTable-icon open" lay-tid="' + mId + '" lay-tpid="' + mPid + '" lay-ttype="' + ttype + '">';
  80. return vg + iconHtml + d[param.cols[0][param.treeColIndex].field] + '</span>'
  81. };
  82. param.done = function (res, curr, count) {
  83. $(param.elem).next().addClass('treeTable');
  84. $('.treeTable .layui-table-page').css('display', 'none');
  85. $(param.elem).next().attr('treeLinkage', param.treeLinkage);
  86. // 绑定事件换成对body绑定
  87. /*$('.treeTable .treeTable-icon').click(function () {
  88. treetable.toggleRows($(this), param.treeLinkage);
  89. });*/
  90. if (param.treeDefaultClose) {
  91. treetable.foldAll(param.elem);
  92. }
  93. if (doneCallback) {
  94. doneCallback(res, curr, count);
  95. }
  96. };
  97. // 渲染表格
  98. table.render(param);
  99. },
  100. // 计算缩进的数量
  101. getEmptyNum: function (pid, data) {
  102. var num = 0;
  103. if (!pid) {
  104. return num;
  105. }
  106. var tPid;
  107. for (var i = 0; i < data.length; i++) {
  108. if (pid == data[i].id) {
  109. num += 1;
  110. tPid = data[i].pid;
  111. break;
  112. }
  113. }
  114. return num + treetable.getEmptyNum(tPid, data);
  115. },
  116. // 展开/折叠行
  117. toggleRows: function ($dom, linkage) {
  118. var type = $dom.attr('lay-ttype');
  119. if ('file' == type) {
  120. return;
  121. }
  122. var mId = $dom.attr('lay-tid');
  123. var isOpen = $dom.hasClass('open');
  124. if (isOpen) {
  125. $dom.removeClass('open');
  126. } else {
  127. $dom.addClass('open');
  128. }
  129. $dom.closest('tbody').find('tr').each(function () {
  130. var $ti = $(this).find('.treeTable-icon');
  131. var pid = $ti.attr('lay-tpid');
  132. var ttype = $ti.attr('lay-ttype');
  133. var tOpen = $ti.hasClass('open');
  134. if (mId == pid) {
  135. if (isOpen) {
  136. $(this).hide();
  137. if ('dir' == ttype && tOpen == isOpen) {
  138. $ti.trigger('click');
  139. }
  140. } else {
  141. $(this).show();
  142. if (linkage && 'dir' == ttype && tOpen == isOpen) {
  143. $ti.trigger('click');
  144. }
  145. }
  146. }
  147. });
  148. },
  149. // 检查参数
  150. checkParam: function (param) {
  151. if (!param.treeSpid && param.treeSpid != 0) {
  152. layer.msg('参数treeSpid不能为空', {icon: 5});
  153. return false;
  154. }
  155. if (!param.treeColIndex && param.treeColIndex != 0) {
  156. layer.msg('参数treeColIndex不能为空', {icon: 5});
  157. return false;
  158. }
  159. return true;
  160. },
  161. // 展开所有
  162. expandAll: function (dom) {
  163. $(dom).next('.treeTable').find('.layui-table-body tbody tr').each(function () {
  164. var $ti = $(this).find('.treeTable-icon');
  165. var ttype = $ti.attr('lay-ttype');
  166. var tOpen = $ti.hasClass('open');
  167. if ('dir' == ttype && !tOpen) {
  168. $ti.trigger('click');
  169. }
  170. });
  171. },
  172. // 折叠所有
  173. foldAll: function (dom) {
  174. $(dom).next('.treeTable').find('.layui-table-body tbody tr').each(function () {
  175. var $ti = $(this).find('.treeTable-icon');
  176. var ttype = $ti.attr('lay-ttype');
  177. var tOpen = $ti.hasClass('open');
  178. if ('dir' == ttype && tOpen) {
  179. $ti.trigger('click');
  180. }
  181. });
  182. }
  183. };
  184. layui.link(layui.cache.base + 'treetable-lay/treetable.css');
  185. // 给图标列绑定事件
  186. $('body').on('click', '.treeTable .treeTable-icon', function () {
  187. var treeLinkage = $(this).parents('.treeTable').attr('treeLinkage');
  188. if ('true' == treeLinkage) {
  189. treetable.toggleRows($(this), true);
  190. } else {
  191. treetable.toggleRows($(this), false);
  192. }
  193. });
  194. exports('treetable', treetable);
  195. });