dialogtree.blade.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <a href="javascript:void(0)" class="grid-dialog-tree"
  2. data-url="{{ $url }}"
  3. data-title="{{ $title }}"
  4. data-checked="{{ $checkAll }}"
  5. data-val="{{ $value }}">
  6. <i class='feather icon-align-right'></i> {{ trans('admin.view') }}
  7. </a>
  8. <template id="dialog-tree-tpl">
  9. <div class="jstree-wrapper p-1" style="border:0"><div class="da-tree" style="margin-top:10px"></div></div>
  10. </template>
  11. <script require="@jstree" once>
  12. window.resolveDialogTree = function (options) {
  13. var tpl = $('#dialog-tree-tpl').html(),
  14. t = $(this),
  15. val = t.data('val'),
  16. url = t.data('url'),
  17. title = t.data('title'),
  18. ckall = t.data('checked'),
  19. idx,
  20. loading;
  21. val = val ? String(val).split(',') : [];
  22. if (url) {
  23. if (loading) return;
  24. loading = 1;
  25. t.buttonLoading();
  26. $.ajax(url, {data: {value: val}}).then(function (resp) {
  27. loading = 0;
  28. t.buttonLoading(false);
  29. if (!resp.status) {
  30. return Dcat.error(resp.message || '系统繁忙,请稍后再试');
  31. }
  32. open(resp.value);
  33. });
  34. } else {
  35. open(val);
  36. }
  37. function open(val) {
  38. options.config.core.data = formatNodes(val, options.nodes);
  39. idx = layer.open({
  40. type: 1,
  41. area: options.area,
  42. content: tpl,
  43. title: title,
  44. success: function (a, idx) {
  45. var tree = $('#layui-layer'+idx).find('.da-tree');
  46. tree.on("loaded.jstree", function () {
  47. tree.jstree('open_all');
  48. }).jstree(options.config);
  49. }
  50. });
  51. $(document).one('pjax:complete', function () {
  52. layer.close(idx);
  53. });
  54. }
  55. function formatNodes(value, all) {
  56. var idColumn = options.columns.id,
  57. textColumn = options.columns.text,
  58. parentColumn = options.columns.parent,
  59. parentIds = [], nodes = [], i, v, parentId;
  60. for (i in all) {
  61. v = all[i];
  62. if (!v[idColumn]) continue;
  63. parentId = v[parentColumn] || '#';
  64. if (!parentId) {
  65. parentId = '#';
  66. } else {
  67. parentIds.push(parentId);
  68. }
  69. v['state'] = {'disabled': true};
  70. if (ckall || (value && Dcat.helpers.inObject(value, v[idColumn]))) {
  71. v['state']['selected'] = true;
  72. }
  73. nodes.push({
  74. 'id' : v[idColumn],
  75. 'text' : v[textColumn] || null,
  76. 'parent' : parentId,
  77. 'state' : v['state'],
  78. });
  79. }
  80. return nodes;
  81. }
  82. }
  83. </script>
  84. <script require="@jstree">
  85. var nodes = {!! json_encode($nodes) !!};
  86. var options = {!! admin_javascript_json($options) !!};
  87. var area = {!! json_encode($area) !!};
  88. $('.grid-dialog-tree').off('click').on('click', function () {
  89. resolveDialogTree.call(this, {config: options, nodes: nodes, area: area, columns: {!! json_encode($columnNames) !!}});
  90. });
  91. </script>