jqtree 1.6.0 → 1.6.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (301) hide show
  1. package/.eslintrc +3 -11
  2. package/.github/workflows/ci.yml +48 -23
  3. package/.github/workflows/codeql-analysis.yml +9 -5
  4. package/.prettier +3 -0
  5. package/README.md +11 -8
  6. package/bower.json +1 -1
  7. package/{.postcssrc → config/.postcssrc} +0 -0
  8. package/config/babel.config.json +11 -0
  9. package/config/babel.coverage.config.json +4 -0
  10. package/{jest-jsdom.config.js → config/jest.config.js} +9 -5
  11. package/config/playwright.config.js +18 -0
  12. package/config/production +4 -0
  13. package/{rollup.config.js → config/rollup.config.js} +19 -14
  14. package/{jqtree.postcss → css/jqtree.postcss} +3 -0
  15. package/devserver/index.html +1 -9
  16. package/docs/Gemfile +2 -0
  17. package/docs/Gemfile.lock +263 -0
  18. package/{_config.yml → docs/_config.yml} +8 -1
  19. package/{_entries → docs/_entries}/01_general.md +0 -0
  20. package/{_entries → docs/_entries}/02_introduction.md +0 -0
  21. package/{_entries → docs/_entries}/03_features.md +1 -1
  22. package/{_entries → docs/_entries}/04_demo.html +1 -7
  23. package/{_entries → docs/_entries}/05_requirements.md +0 -0
  24. package/{_entries → docs/_entries}/06_downloads.md +0 -0
  25. package/{_entries → docs/_entries}/07_tutorial.md +0 -0
  26. package/{_entries → docs/_entries}/08_examples.md +0 -0
  27. package/{_entries → docs/_entries}/09_usecases.md +0 -0
  28. package/{_entries → docs/_entries}/10_changelog.md +14 -0
  29. package/{_entries → docs/_entries}/11_options.md +0 -0
  30. package/{_entries → docs/_entries}/12_animationspeed.md +0 -0
  31. package/{_entries → docs/_entries}/13_autoescape.md +0 -0
  32. package/{_entries → docs/_entries}/14_autoopen.md +0 -0
  33. package/{_entries → docs/_entries}/15_buttonleft.md +0 -0
  34. package/{_entries → docs/_entries}/16_closedicon.md +0 -0
  35. package/{_entries → docs/_entries}/17_data.md +0 -0
  36. package/{_entries → docs/_entries}/18_datafilter.md +0 -0
  37. package/{_entries → docs/_entries}/19_data-url.md +0 -0
  38. package/{_entries → docs/_entries}/20_draganddrop.md +0 -0
  39. package/{_entries → docs/_entries}/21_keyboardsupport.md +0 -0
  40. package/{_entries → docs/_entries}/22_oncanmove.md +0 -0
  41. package/{_entries → docs/_entries}/23_oncanmoveto.md +2 -2
  42. package/{_entries → docs/_entries}/24_oncanselectnode.md +0 -0
  43. package/{_entries → docs/_entries}/25_oncreateli.md +2 -2
  44. package/{_entries → docs/_entries}/26_ondragmove.md +0 -0
  45. package/{_entries → docs/_entries}/27_ondragstop.md +0 -0
  46. package/{_entries → docs/_entries}/28_onismovehandle.md +0 -0
  47. package/{_entries → docs/_entries}/29_onloadfailed.md +0 -0
  48. package/{_entries → docs/_entries}/30_onloading.md +2 -2
  49. package/{_entries → docs/_entries}/31_openedicon.md +0 -0
  50. package/{_entries → docs/_entries}/32_openfolderdelay.md +2 -0
  51. package/{_entries → docs/_entries}/33_rtl.md +0 -0
  52. package/{_entries → docs/_entries}/34_savestate.md +0 -0
  53. package/{_entries → docs/_entries}/35_selectable.md +0 -0
  54. package/{_entries → docs/_entries}/36_showemptyfolder.md +0 -0
  55. package/{_entries → docs/_entries}/37_slide.md +0 -0
  56. package/{_entries → docs/_entries}/38_start_dnd_delay.md +0 -0
  57. package/{_entries → docs/_entries}/39_tabindex.md +0 -0
  58. package/{_entries → docs/_entries}/40_usecontextmenu.md +0 -0
  59. package/{_entries → docs/_entries}/41_functions.md +0 -0
  60. package/{_entries → docs/_entries}/42_addparentnode.md +1 -1
  61. package/{_entries → docs/_entries}/43_addnodeafter.md +1 -1
  62. package/{_entries → docs/_entries}/44_addnodebefore.md +1 -1
  63. package/{_entries → docs/_entries}/45_appendnode.md +5 -5
  64. package/{_entries → docs/_entries}/46_closenode.md +0 -0
  65. package/{_entries → docs/_entries}/47_destroy.md +0 -0
  66. package/{_entries → docs/_entries}/48_getnodebycallback.md +0 -0
  67. package/{_entries → docs/_entries}/49_getnodebyid.md +0 -0
  68. package/{_entries → docs/_entries}/50_getnodebyhtmlelement.md +2 -2
  69. package/{_entries → docs/_entries}/51_getselectednode.md +0 -0
  70. package/{_entries → docs/_entries}/52_getstate.md +0 -0
  71. package/{_entries → docs/_entries}/53_gettree.md +1 -1
  72. package/{_entries → docs/_entries}/54_isdragging.md +1 -1
  73. package/{_entries → docs/_entries}/55_loaddata.md +3 -3
  74. package/{_entries → docs/_entries}/56_loaddatafromurl.md +4 -4
  75. package/{_entries → docs/_entries}/57_movedown.md +0 -0
  76. package/{_entries → docs/_entries}/58_movenode.md +3 -3
  77. package/{_entries → docs/_entries}/59_moveup.md +0 -0
  78. package/{_entries → docs/_entries}/60_opennode.md +3 -3
  79. package/docs/_entries/61_prependnode.md +21 -0
  80. package/docs/_entries/62_refresh.md +12 -0
  81. package/{_entries/62_reload.md → docs/_entries/63_reload.md} +2 -2
  82. package/{_entries/63_removenode.md → docs/_entries/64_removenode.md} +0 -0
  83. package/{_entries/64_selectnode.md → docs/_entries/65_selectnode.md} +0 -0
  84. package/{_entries/65_scrolltonode.md → docs/_entries/66_scrolltonode.md} +0 -0
  85. package/{_entries/66_setoption.md → docs/_entries/67_setoption.md} +0 -0
  86. package/{_entries/67_setstate.md → docs/_entries/68_setstate.md} +0 -0
  87. package/{_entries/68_toggle.md → docs/_entries/69_toggle.md} +0 -0
  88. package/{_entries/69_tojson.md → docs/_entries/70_tojson.md} +0 -0
  89. package/{_entries/70_updatenode.md → docs/_entries/71_updatenode.md} +1 -1
  90. package/{_entries/71_events.md → docs/_entries/72_events.md} +0 -0
  91. package/{_entries/72_tree-click.md → docs/_entries/73_tree-click.md} +0 -0
  92. package/{_entries/73_tree-close.md → docs/_entries/74_tree-close.md} +0 -0
  93. package/{_entries/74_tree-contextmenu.md → docs/_entries/75_tree-contextmenu.md} +0 -0
  94. package/{_entries/75_tree-dblclick.md → docs/_entries/76_tree-dblclick.md} +0 -0
  95. package/{_entries/76_tree-init.md → docs/_entries/77_tree-init.md} +0 -0
  96. package/{_entries/77_tree-load-data.md → docs/_entries/78_tree-load-data.md} +0 -0
  97. package/{_entries/78_tree-loading-data.md → docs/_entries/79_tree-loading-data.md} +0 -0
  98. package/{_entries/79_tree-move.md → docs/_entries/80_tree-move.md} +0 -0
  99. package/{_entries/80_tree-refresh.md → docs/_entries/81_tree-refresh.md} +0 -0
  100. package/{_entries/81_tree-open.md → docs/_entries/82_tree-open.md} +0 -0
  101. package/{_entries/82_tree-select.md → docs/_entries/83_tree-select.md} +0 -0
  102. package/{_entries/83_multiple-selection.md → docs/_entries/84_multiple-selection.md} +0 -0
  103. package/{_entries/84_add-to-selection.md → docs/_entries/85_add-to-selection.md} +0 -0
  104. package/{_entries/85_get-selected-nodes.md → docs/_entries/86_get-selected-nodes.md} +0 -0
  105. package/{_entries/86_is-node-selected.md → docs/_entries/87_is-node-selected.md} +1 -1
  106. package/{_entries/87_remove-from-selection.md → docs/_entries/88_remove-from-selection.md} +0 -0
  107. package/{_entries/88_node-functions.md → docs/_entries/89_node-functions.md} +0 -0
  108. package/{_entries/89_children.md → docs/_entries/90_children.md} +0 -0
  109. package/{_entries/90_getdata.md → docs/_entries/91_getdata.md} +2 -2
  110. package/{_entries/91_getlevel.md → docs/_entries/92_getlevel.md} +0 -0
  111. package/{_entries/92_getnextnode.md → docs/_entries/93_getnextnode.md} +0 -0
  112. package/{_entries/93_getnextsibling.md → docs/_entries/94_getnextsibling.md} +0 -0
  113. package/{_entries/94_getpreviousnode.md → docs/_entries/95_getpreviousnode.md} +0 -0
  114. package/{_entries/95_getprevioussibling.md → docs/_entries/96_getprevioussibling.md} +0 -0
  115. package/{_entries/96_parent.md → docs/_entries/97_parent.md} +1 -1
  116. package/{_entries → docs/_entries}/insert.py +0 -0
  117. package/{_entries → docs/_entries}/renumber.py +0 -0
  118. package/{_examples → docs/_examples}/01_load_json_data.html +3 -5
  119. package/{_examples → docs/_examples}/02_load_json_data_from_server.html +3 -5
  120. package/{_examples → docs/_examples}/03_drag_and_drop.html +3 -5
  121. package/{_examples → docs/_examples}/04_save_state.html +3 -5
  122. package/{_examples → docs/_examples}/05_load_on_demand.html +3 -5
  123. package/{_examples → docs/_examples}/06_autoescape.html +3 -5
  124. package/{_examples → docs/_examples}/07_autoscroll.html +3 -5
  125. package/{_examples → docs/_examples}/08_multiple_select.html +3 -5
  126. package/{_examples → docs/_examples}/09_custom_html.html +3 -5
  127. package/{_examples → docs/_examples}/10_icon_buttons.html +3 -5
  128. package/{_examples → docs/_examples}/11_right-to-left.html +3 -5
  129. package/{_examples → docs/_examples}/12_button_on_right.html +3 -5
  130. package/docs/_examples/13_drag_outside.html +48 -0
  131. package/docs/_examples/14_filter.html +111 -0
  132. package/docs/_layouts/example.html +7 -0
  133. package/docs/_layouts/page.html +26 -0
  134. package/docs/documentation.css +3 -0
  135. package/docs/index.html +65 -0
  136. package/docs/jqtree.css +189 -0
  137. package/docs/package.json +22 -0
  138. package/docs/pnpm-lock.yaml +768 -0
  139. package/docs/postcss.config.js +7 -0
  140. package/docs/static/bower.json +8 -0
  141. package/docs/static/bower_components/fontawesome/css/all.min.css +5 -0
  142. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-brands-400.eot +0 -0
  143. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-brands-400.svg +774 -627
  144. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-brands-400.ttf +0 -0
  145. package/docs/static/bower_components/fontawesome/webfonts/fa-brands-400.woff +0 -0
  146. package/docs/static/bower_components/fontawesome/webfonts/fa-brands-400.woff2 +0 -0
  147. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-regular-400.eot +0 -0
  148. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-regular-400.svg +93 -95
  149. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-regular-400.ttf +0 -0
  150. package/docs/static/bower_components/fontawesome/webfonts/fa-regular-400.woff +0 -0
  151. package/docs/static/bower_components/fontawesome/webfonts/fa-regular-400.woff2 +0 -0
  152. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-solid-900.eot +0 -0
  153. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-solid-900.svg +1164 -1074
  154. package/{static → docs/static}/bower_components/fontawesome/webfonts/fa-solid-900.ttf +0 -0
  155. package/docs/static/bower_components/fontawesome/webfonts/fa-solid-900.woff +0 -0
  156. package/docs/static/bower_components/fontawesome/webfonts/fa-solid-900.woff2 +0 -0
  157. package/{static → docs/static}/bower_components/jquery/dist/jquery.js +118 -109
  158. package/docs/static/bower_components/jquery/dist/jquery.min.js +2 -0
  159. package/{static → docs/static}/bower_components/jquery-mockjax/dist/jquery.mockjax.js +15 -9
  160. package/docs/static/documentation.css +1313 -0
  161. package/docs/static/documentation.js +26 -0
  162. package/{static → docs/static}/example.css +14 -33
  163. package/{static → docs/static}/example.postcss +15 -32
  164. package/{static → docs/static}/example_data.js +33 -36
  165. package/{static → docs/static}/examples/autoescape.js +0 -0
  166. package/{static → docs/static}/examples/autoscroll.js +0 -0
  167. package/{static → docs/static}/examples/button-on-right.js +0 -0
  168. package/{static → docs/static}/examples/custom_html.js +5 -9
  169. package/{static → docs/static}/examples/drag-outside.js +0 -0
  170. package/{static → docs/static}/examples/drag_and_drop.js +0 -0
  171. package/docs/static/examples/filter.js +63 -0
  172. package/{static → docs/static}/examples/icon_buttons.js +0 -0
  173. package/{static → docs/static}/examples/load_json_data.js +0 -0
  174. package/{static → docs/static}/examples/load_json_data_from_server.js +0 -0
  175. package/{static → docs/static}/examples/load_on_demand.js +0 -0
  176. package/{static → docs/static}/examples/multiple_select.js +0 -0
  177. package/{static → docs/static}/examples/right-to-left.js +0 -0
  178. package/{static → docs/static}/examples/save_state.js +0 -0
  179. package/{static → docs/static}/monokai.css +0 -0
  180. package/{static → docs/static}/spinner.gif +0 -0
  181. package/docs/tailwind.config.js +16 -0
  182. package/docs/tree.jquery.js +21 -0
  183. package/jqtree.css +4 -1
  184. package/lib/dataLoader.js +146 -98
  185. package/lib/dragAndDropHandler.js +672 -470
  186. package/lib/elementsRenderer.js +282 -197
  187. package/lib/jqtreeOptions.js +1 -2
  188. package/lib/keyHandler.js +134 -87
  189. package/lib/mouse.widget.js +285 -184
  190. package/lib/node.js +691 -505
  191. package/lib/nodeElement.js +329 -205
  192. package/lib/playwright/coverage.js +140 -0
  193. package/lib/playwright/playwright.test.js +298 -179
  194. package/lib/playwright/testUtils.js +267 -0
  195. package/lib/saveStateHandler.js +311 -204
  196. package/lib/scrollHandler.js +293 -199
  197. package/lib/selectNodeHandler.js +140 -100
  198. package/lib/simple.widget.js +184 -109
  199. package/lib/test/global.d.js +3 -0
  200. package/lib/test/jqTree/create.test.js +44 -40
  201. package/lib/test/jqTree/events.test.js +186 -138
  202. package/lib/test/jqTree/keyboard.test.js +216 -199
  203. package/lib/test/jqTree/loadOnDemand.test.js +238 -157
  204. package/lib/test/jqTree/methods.test.js +1289 -1019
  205. package/lib/test/jqTree/options.test.js +491 -410
  206. package/lib/test/node.test.js +1036 -873
  207. package/lib/test/nodeUtil.test.js +21 -20
  208. package/lib/test/support/exampleData.js +35 -23
  209. package/lib/test/support/jqTreeMatchers.js +72 -54
  210. package/lib/test/support/matchers.d.js +1 -0
  211. package/lib/test/support/setupTests.js +9 -3
  212. package/lib/test/support/testUtil.js +35 -15
  213. package/lib/test/support/treeStructure.js +41 -32
  214. package/lib/test/util.test.js +21 -20
  215. package/lib/tree.jquery.d.js +1 -0
  216. package/lib/tree.jquery.js +1264 -886
  217. package/lib/types.js +1 -2
  218. package/lib/typings.d.js +2 -0
  219. package/lib/util.js +19 -8
  220. package/lib/version.js +8 -3
  221. package/package.json +54 -47
  222. package/src/dataLoader.ts +6 -6
  223. package/src/dragAndDropHandler.ts +8 -8
  224. package/src/elementsRenderer.ts +4 -0
  225. package/src/jqtreeOptions.ts +2 -2
  226. package/src/mouse.widget.ts +19 -15
  227. package/src/node.ts +27 -41
  228. package/src/nodeElement.ts +17 -9
  229. package/src/playwright/.eslintrc +5 -0
  230. package/src/playwright/coverage.ts +41 -0
  231. package/src/playwright/playwright.test.ts +75 -77
  232. package/src/playwright/playwright.test.ts-snapshots/with-dragAndDrop-moves-a-node-1-Chromium-darwin.png +0 -0
  233. package/src/playwright/playwright.test.ts-snapshots/with-dragAndDrop-moves-a-node-1-Chromium-linux.png +0 -0
  234. package/src/playwright/playwright.test.ts-snapshots/without-dragAndDrop-displays-a-tree-1-Chromium-darwin.png +0 -0
  235. package/src/playwright/playwright.test.ts-snapshots/without-dragAndDrop-displays-a-tree-1-Chromium-linux.png +0 -0
  236. package/src/playwright/playwright.test.ts-snapshots/without-dragAndDrop-selects-a-node-1-Chromium-darwin.png +0 -0
  237. package/src/playwright/playwright.test.ts-snapshots/without-dragAndDrop-selects-a-node-1-Chromium-linux.png +0 -0
  238. package/src/playwright/testUtils.ts +122 -0
  239. package/src/saveStateHandler.ts +11 -6
  240. package/src/selectNodeHandler.ts +1 -1
  241. package/src/simple.widget.ts +1 -1
  242. package/src/test/.eslintrc +14 -0
  243. package/src/test/jqTree/create.test.ts +0 -1
  244. package/src/test/jqTree/events.test.ts +10 -10
  245. package/src/test/jqTree/keyboard.test.ts +0 -1
  246. package/src/test/jqTree/loadOnDemand.test.ts +56 -11
  247. package/src/test/jqTree/methods.test.ts +72 -55
  248. package/src/test/jqTree/options.test.ts +30 -33
  249. package/src/test/node.test.ts +2 -2
  250. package/src/test/support/jqTreeMatchers.ts +8 -9
  251. package/src/test/support/matchers.d.ts +2 -4
  252. package/src/test/support/setupTests.ts +2 -1
  253. package/src/tree.jquery.d.ts +19 -13
  254. package/src/tree.jquery.ts +35 -28
  255. package/src/version.ts +1 -1
  256. package/tree.jquery.debug.js +4810 -3325
  257. package/tree.jquery.debug.js.map +1 -1
  258. package/tree.jquery.js +3 -3
  259. package/tree.jquery.js.map +1 -1
  260. package/tsconfig.json +1 -0
  261. package/_entries/61_prependnode.md +0 -21
  262. package/_examples/13_drag_outside.html +0 -25
  263. package/_layouts/base.html +0 -55
  264. package/_layouts/frontpage.html +0 -20
  265. package/_layouts/page.html +0 -7
  266. package/index.html +0 -48
  267. package/jest-browser.config.js +0 -18
  268. package/jest-playwright.config.js +0 -21
  269. package/jest.config.js +0 -8
  270. package/lib/playwright/testUtil.js +0 -223
  271. package/lib/playwright/visualRegression.js +0 -128
  272. package/production +0 -5
  273. package/src/playwright/screenshots/displays_a_tree_Desktop.png +0 -0
  274. package/src/playwright/screenshots/displays_a_tree_iPhone 6.png +0 -0
  275. package/src/playwright/screenshots/moves_a_node_Desktop.png +0 -0
  276. package/src/playwright/screenshots/moves_a_node_iPhone 6.png +0 -0
  277. package/src/playwright/screenshots/opens_a_node_Desktop.png +0 -0
  278. package/src/playwright/screenshots/opens_a_node_iPhone 6.png +0 -0
  279. package/src/playwright/screenshots/selects_a_node_Desktop.png +0 -0
  280. package/src/playwright/screenshots/selects_a_node_iPhone 6.png +0 -0
  281. package/src/playwright/testUtil.ts +0 -171
  282. package/src/playwright/visualRegression.ts +0 -88
  283. package/static/bower.json +0 -9
  284. package/static/bower_components/bootstrap/dist/css/bootstrap-theme.min.css +0 -6
  285. package/static/bower_components/bootstrap/dist/css/bootstrap.min.css +0 -6
  286. package/static/bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.eot +0 -0
  287. package/static/bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.svg +0 -288
  288. package/static/bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.ttf +0 -0
  289. package/static/bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff +0 -0
  290. package/static/bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff2 +0 -0
  291. package/static/bower_components/bootstrap/dist/js/bootstrap.min.js +0 -6
  292. package/static/bower_components/fontawesome/css/all.min.css +0 -5
  293. package/static/bower_components/fontawesome/webfonts/fa-brands-400.woff +0 -0
  294. package/static/bower_components/fontawesome/webfonts/fa-brands-400.woff2 +0 -0
  295. package/static/bower_components/fontawesome/webfonts/fa-regular-400.woff +0 -0
  296. package/static/bower_components/fontawesome/webfonts/fa-regular-400.woff2 +0 -0
  297. package/static/bower_components/fontawesome/webfonts/fa-solid-900.woff +0 -0
  298. package/static/bower_components/fontawesome/webfonts/fa-solid-900.woff2 +0 -0
  299. package/static/bower_components/jquery/dist/jquery.min.js +0 -2
  300. package/static/documentation.css +0 -171
  301. package/static/documentation.js +0 -48
@@ -1,203 +1,288 @@
1
1
  "use strict";
2
- exports.__esModule = true;
3
- var util_1 = require("./util");
4
- var ElementsRenderer = /** @class */ (function () {
5
- function ElementsRenderer(treeWidget) {
6
- this.treeWidget = treeWidget;
7
- this.openedIconElement = this.createButtonElement(treeWidget.options.openedIcon || "+");
8
- this.closedIconElement = this.createButtonElement(treeWidget.options.closedIcon || "-");
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _util = require("./util");
9
+
10
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
11
+
12
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
13
+
14
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
15
+
16
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
17
+
18
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
19
+
20
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
21
+
22
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
23
+
24
+ var ElementsRenderer = /*#__PURE__*/function () {
25
+ function ElementsRenderer(treeWidget) {
26
+ _classCallCheck(this, ElementsRenderer);
27
+
28
+ _defineProperty(this, "openedIconElement", void 0);
29
+
30
+ _defineProperty(this, "closedIconElement", void 0);
31
+
32
+ _defineProperty(this, "treeWidget", void 0);
33
+
34
+ this.treeWidget = treeWidget;
35
+ this.openedIconElement = this.createButtonElement(treeWidget.options.openedIcon || "+");
36
+ this.closedIconElement = this.createButtonElement(treeWidget.options.closedIcon || "-");
37
+ }
38
+
39
+ _createClass(ElementsRenderer, [{
40
+ key: "render",
41
+ value: function render(fromNode) {
42
+ if (fromNode && fromNode.parent) {
43
+ this.renderFromNode(fromNode);
44
+ } else {
45
+ this.renderFromRoot();
46
+ }
9
47
  }
10
- ElementsRenderer.prototype.render = function (fromNode) {
11
- if (fromNode && fromNode.parent) {
12
- this.renderFromNode(fromNode);
13
- }
14
- else {
15
- this.renderFromRoot();
16
- }
17
- };
18
- ElementsRenderer.prototype.renderFromRoot = function () {
19
- var $element = this.treeWidget.element;
20
- $element.empty();
21
- this.createDomElements($element[0], this.treeWidget.tree.children, true, 1);
22
- };
23
- ElementsRenderer.prototype.renderFromNode = function (node) {
24
- // remember current li
25
- var $previousLi = jQuery(node.element);
26
- // create element
27
- var li = this.createLi(node, node.getLevel());
28
- this.attachNodeData(node, li);
29
- // add element to dom
30
- $previousLi.after(li);
31
- // remove previous li
32
- $previousLi.remove();
33
- // create children
34
- if (node.children) {
35
- this.createDomElements(li, node.children, false, node.getLevel() + 1);
36
- }
37
- };
38
- ElementsRenderer.prototype.createDomElements = function (element, children, isRootNode, level) {
39
- var ul = this.createUl(isRootNode);
40
- element.appendChild(ul);
41
- for (var _i = 0, children_1 = children; _i < children_1.length; _i++) {
42
- var child = children_1[_i];
43
- var li = this.createLi(child, level);
44
- ul.appendChild(li);
45
- this.attachNodeData(child, li);
46
- if (child.hasChildren()) {
47
- this.createDomElements(li, child.children, false, level + 1);
48
- }
49
- }
50
- };
51
- ElementsRenderer.prototype.attachNodeData = function (node, li) {
52
- node.element = li;
53
- jQuery(li).data("node", node);
54
- };
55
- ElementsRenderer.prototype.createUl = function (isRootNode) {
56
- var classString;
57
- var role;
58
- if (!isRootNode) {
59
- classString = "";
60
- role = "group";
61
- }
62
- else {
63
- classString = "jqtree-tree";
64
- role = "tree";
65
- if (this.treeWidget.options.rtl) {
66
- classString += " jqtree-rtl";
67
- }
68
- }
69
- if (this.treeWidget.options.dragAndDrop) {
70
- classString += " jqtree-dnd";
71
- }
72
- var ul = document.createElement("ul");
73
- ul.className = "jqtree_common " + classString;
74
- ul.setAttribute("role", role);
75
- return ul;
76
- };
77
- ElementsRenderer.prototype.createLi = function (node, level) {
78
- var isSelected = Boolean(this.treeWidget.selectNodeHandler.isNodeSelected(node));
79
- var mustShowFolder = node.isFolder() ||
80
- (node.isEmptyFolder && this.treeWidget.options.showEmptyFolder);
81
- var li = mustShowFolder
82
- ? this.createFolderLi(node, level, isSelected)
83
- : this.createNodeLi(node, level, isSelected);
84
- if (this.treeWidget.options.onCreateLi) {
85
- this.treeWidget.options.onCreateLi(node, jQuery(li), isSelected);
86
- }
87
- return li;
88
- };
89
- ElementsRenderer.prototype.createFolderLi = function (node, level, isSelected) {
90
- var buttonClasses = this.getButtonClasses(node);
91
- var folderClasses = this.getFolderClasses(node, isSelected);
92
- var iconElement = node.is_open
93
- ? this.openedIconElement
94
- : this.closedIconElement;
95
- // li
96
- var li = document.createElement("li");
97
- li.className = "jqtree_common " + folderClasses;
98
- li.setAttribute("role", "presentation");
99
- // div
100
- var div = document.createElement("div");
101
- div.className = "jqtree-element jqtree_common";
102
- div.setAttribute("role", "presentation");
103
- li.appendChild(div);
104
- // button link
105
- var buttonLink = document.createElement("a");
106
- buttonLink.className = buttonClasses;
107
- buttonLink.appendChild(iconElement.cloneNode(true));
108
- buttonLink.setAttribute("role", "presentation");
109
- buttonLink.setAttribute("aria-hidden", "true");
110
- if (this.treeWidget.options.buttonLeft) {
111
- div.appendChild(buttonLink);
48
+ }, {
49
+ key: "renderFromRoot",
50
+ value: function renderFromRoot() {
51
+ var $element = this.treeWidget.element;
52
+ $element.empty();
53
+ this.createDomElements($element[0], this.treeWidget.tree.children, true, 1);
54
+ }
55
+ }, {
56
+ key: "renderFromNode",
57
+ value: function renderFromNode(node) {
58
+ // remember current li
59
+ var $previousLi = jQuery(node.element); // create element
60
+
61
+ var li = this.createLi(node, node.getLevel());
62
+ this.attachNodeData(node, li); // add element to dom
63
+
64
+ $previousLi.after(li); // remove previous li
65
+
66
+ $previousLi.remove(); // create children
67
+
68
+ if (node.children) {
69
+ this.createDomElements(li, node.children, false, node.getLevel() + 1);
70
+ }
71
+ }
72
+ }, {
73
+ key: "createDomElements",
74
+ value: function createDomElements(element, children, isRootNode, level) {
75
+ var ul = this.createUl(isRootNode);
76
+ element.appendChild(ul);
77
+
78
+ var _iterator = _createForOfIteratorHelper(children),
79
+ _step;
80
+
81
+ try {
82
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
83
+ var child = _step.value;
84
+ var li = this.createLi(child, level);
85
+ ul.appendChild(li);
86
+ this.attachNodeData(child, li);
87
+
88
+ if (child.hasChildren()) {
89
+ this.createDomElements(li, child.children, false, level + 1);
90
+ }
112
91
  }
113
- // title span
114
- div.appendChild(this.createTitleSpan(node.name, level, isSelected, node.is_open, true));
115
- if (!this.treeWidget.options.buttonLeft) {
116
- div.appendChild(buttonLink);
92
+ } catch (err) {
93
+ _iterator.e(err);
94
+ } finally {
95
+ _iterator.f();
96
+ }
97
+ }
98
+ }, {
99
+ key: "attachNodeData",
100
+ value: function attachNodeData(node, li) {
101
+ node.element = li;
102
+ jQuery(li).data("node", node);
103
+ }
104
+ }, {
105
+ key: "createUl",
106
+ value: function createUl(isRootNode) {
107
+ var classString;
108
+ var role;
109
+
110
+ if (!isRootNode) {
111
+ classString = "";
112
+ role = "group";
113
+ } else {
114
+ classString = "jqtree-tree";
115
+ role = "tree";
116
+
117
+ if (this.treeWidget.options.rtl) {
118
+ classString += " jqtree-rtl";
117
119
  }
118
- return li;
119
- };
120
- ElementsRenderer.prototype.createNodeLi = function (node, level, isSelected) {
121
- var liClasses = ["jqtree_common"];
122
- if (isSelected) {
123
- liClasses.push("jqtree-selected");
120
+ }
121
+
122
+ if (this.treeWidget.options.dragAndDrop) {
123
+ classString += " jqtree-dnd";
124
+ }
125
+
126
+ var ul = document.createElement("ul");
127
+ ul.className = "jqtree_common ".concat(classString);
128
+ ul.setAttribute("role", role);
129
+ return ul;
130
+ }
131
+ }, {
132
+ key: "createLi",
133
+ value: function createLi(node, level) {
134
+ var isSelected = Boolean(this.treeWidget.selectNodeHandler.isNodeSelected(node));
135
+ var mustShowFolder = node.isFolder() || node.isEmptyFolder && this.treeWidget.options.showEmptyFolder;
136
+ var li = mustShowFolder ? this.createFolderLi(node, level, isSelected) : this.createNodeLi(node, level, isSelected);
137
+
138
+ if (this.treeWidget.options.onCreateLi) {
139
+ this.treeWidget.options.onCreateLi(node, jQuery(li), isSelected);
140
+ }
141
+
142
+ return li;
143
+ }
144
+ }, {
145
+ key: "createFolderLi",
146
+ value: function createFolderLi(node, level, isSelected) {
147
+ var buttonClasses = this.getButtonClasses(node);
148
+ var folderClasses = this.getFolderClasses(node, isSelected);
149
+ var iconElement = node.is_open ? this.openedIconElement : this.closedIconElement; // li
150
+
151
+ var li = document.createElement("li");
152
+ li.className = "jqtree_common ".concat(folderClasses);
153
+ li.setAttribute("role", "presentation"); // div
154
+
155
+ var div = document.createElement("div");
156
+ div.className = "jqtree-element jqtree_common";
157
+ div.setAttribute("role", "presentation");
158
+ li.appendChild(div); // button link
159
+
160
+ var buttonLink = document.createElement("a");
161
+ buttonLink.className = buttonClasses;
162
+ buttonLink.appendChild(iconElement.cloneNode(true));
163
+ buttonLink.setAttribute("role", "presentation");
164
+ buttonLink.setAttribute("aria-hidden", "true");
165
+
166
+ if (this.treeWidget.options.buttonLeft) {
167
+ div.appendChild(buttonLink);
168
+ } // title span
169
+
170
+
171
+ div.appendChild(this.createTitleSpan(node.name, level, isSelected, node.is_open, true));
172
+
173
+ if (!this.treeWidget.options.buttonLeft) {
174
+ div.appendChild(buttonLink);
175
+ }
176
+
177
+ return li;
178
+ }
179
+ }, {
180
+ key: "createNodeLi",
181
+ value: function createNodeLi(node, level, isSelected) {
182
+ var liClasses = ["jqtree_common"];
183
+
184
+ if (isSelected) {
185
+ liClasses.push("jqtree-selected");
186
+ }
187
+
188
+ var classString = liClasses.join(" "); // li
189
+
190
+ var li = document.createElement("li");
191
+ li.className = classString;
192
+ li.setAttribute("role", "presentation"); // div
193
+
194
+ var div = document.createElement("div");
195
+ div.className = "jqtree-element jqtree_common";
196
+ div.setAttribute("role", "presentation");
197
+ li.appendChild(div); // title span
198
+
199
+ div.appendChild(this.createTitleSpan(node.name, level, isSelected, node.is_open, false));
200
+ return li;
201
+ }
202
+ }, {
203
+ key: "createTitleSpan",
204
+ value: function createTitleSpan(nodeName, level, isSelected, isOpen, isFolder) {
205
+ var titleSpan = document.createElement("span");
206
+ var classes = "jqtree-title jqtree_common";
207
+
208
+ if (isFolder) {
209
+ classes += " jqtree-title-folder";
210
+ }
211
+
212
+ classes += " jqtree-title-button-".concat(this.treeWidget.options.buttonLeft ? "left" : "right");
213
+ titleSpan.className = classes;
214
+ titleSpan.setAttribute("role", "treeitem");
215
+ titleSpan.setAttribute("aria-level", "".concat(level));
216
+ titleSpan.setAttribute("aria-selected", (0, _util.getBoolString)(isSelected));
217
+ titleSpan.setAttribute("aria-expanded", (0, _util.getBoolString)(isOpen));
218
+
219
+ if (isSelected) {
220
+ var tabIndex = this.treeWidget.options.tabIndex;
221
+
222
+ if (tabIndex !== undefined) {
223
+ titleSpan.setAttribute("tabindex", "".concat(tabIndex));
124
224
  }
125
- var classString = liClasses.join(" ");
126
- // li
127
- var li = document.createElement("li");
128
- li.className = classString;
129
- li.setAttribute("role", "presentation");
130
- // div
225
+ }
226
+
227
+ if (this.treeWidget.options.autoEscape) {
228
+ titleSpan.textContent = nodeName;
229
+ } else {
230
+ titleSpan.innerHTML = nodeName;
231
+ }
232
+
233
+ return titleSpan;
234
+ }
235
+ }, {
236
+ key: "getButtonClasses",
237
+ value: function getButtonClasses(node) {
238
+ var classes = ["jqtree-toggler", "jqtree_common"];
239
+
240
+ if (!node.is_open) {
241
+ classes.push("jqtree-closed");
242
+ }
243
+
244
+ if (this.treeWidget.options.buttonLeft) {
245
+ classes.push("jqtree-toggler-left");
246
+ } else {
247
+ classes.push("jqtree-toggler-right");
248
+ }
249
+
250
+ return classes.join(" ");
251
+ }
252
+ }, {
253
+ key: "getFolderClasses",
254
+ value: function getFolderClasses(node, isSelected) {
255
+ var classes = ["jqtree-folder"];
256
+
257
+ if (!node.is_open) {
258
+ classes.push("jqtree-closed");
259
+ }
260
+
261
+ if (isSelected) {
262
+ classes.push("jqtree-selected");
263
+ }
264
+
265
+ if (node.is_loading) {
266
+ classes.push("jqtree-loading");
267
+ }
268
+
269
+ return classes.join(" ");
270
+ }
271
+ }, {
272
+ key: "createButtonElement",
273
+ value: function createButtonElement(value) {
274
+ if (typeof value === "string") {
275
+ // convert value to html
131
276
  var div = document.createElement("div");
132
- div.className = "jqtree-element jqtree_common";
133
- div.setAttribute("role", "presentation");
134
- li.appendChild(div);
135
- // title span
136
- div.appendChild(this.createTitleSpan(node.name, level, isSelected, node.is_open, false));
137
- return li;
138
- };
139
- ElementsRenderer.prototype.createTitleSpan = function (nodeName, level, isSelected, isOpen, isFolder) {
140
- var titleSpan = document.createElement("span");
141
- var classes = "jqtree-title jqtree_common";
142
- if (isFolder) {
143
- classes += " jqtree-title-folder";
144
- }
145
- titleSpan.className = classes;
146
- titleSpan.setAttribute("role", "treeitem");
147
- titleSpan.setAttribute("aria-level", "" + level);
148
- titleSpan.setAttribute("aria-selected", util_1.getBoolString(isSelected));
149
- titleSpan.setAttribute("aria-expanded", util_1.getBoolString(isOpen));
150
- if (isSelected) {
151
- var tabIndex = this.treeWidget.options.tabIndex;
152
- if (tabIndex !== undefined) {
153
- titleSpan.setAttribute("tabindex", "" + tabIndex);
154
- }
155
- }
156
- if (this.treeWidget.options.autoEscape) {
157
- titleSpan.textContent = nodeName;
158
- }
159
- else {
160
- titleSpan.innerHTML = nodeName;
161
- }
162
- return titleSpan;
163
- };
164
- ElementsRenderer.prototype.getButtonClasses = function (node) {
165
- var classes = ["jqtree-toggler", "jqtree_common"];
166
- if (!node.is_open) {
167
- classes.push("jqtree-closed");
168
- }
169
- if (this.treeWidget.options.buttonLeft) {
170
- classes.push("jqtree-toggler-left");
171
- }
172
- else {
173
- classes.push("jqtree-toggler-right");
174
- }
175
- return classes.join(" ");
176
- };
177
- ElementsRenderer.prototype.getFolderClasses = function (node, isSelected) {
178
- var classes = ["jqtree-folder"];
179
- if (!node.is_open) {
180
- classes.push("jqtree-closed");
181
- }
182
- if (isSelected) {
183
- classes.push("jqtree-selected");
184
- }
185
- if (node.is_loading) {
186
- classes.push("jqtree-loading");
187
- }
188
- return classes.join(" ");
189
- };
190
- ElementsRenderer.prototype.createButtonElement = function (value) {
191
- if (typeof value === "string") {
192
- // convert value to html
193
- var div = document.createElement("div");
194
- div.innerHTML = value;
195
- return document.createTextNode(div.innerHTML);
196
- }
197
- else {
198
- return jQuery(value)[0];
199
- }
200
- };
201
- return ElementsRenderer;
202
- }());
203
- exports["default"] = ElementsRenderer;
277
+ div.innerHTML = value;
278
+ return document.createTextNode(div.innerHTML);
279
+ } else {
280
+ return jQuery(value)[0];
281
+ }
282
+ }
283
+ }]);
284
+
285
+ return ElementsRenderer;
286
+ }();
287
+
288
+ exports["default"] = ElementsRenderer;
@@ -1,2 +1 @@
1
- "use strict";
2
- exports.__esModule = true;
1
+ "use strict";