primenglab 22.0.0-beta.1

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 (852) hide show
  1. package/LICENSE.md +77 -0
  2. package/README.md +11 -0
  3. package/fesm2022/primenglab-accordion.mjs +656 -0
  4. package/fesm2022/primenglab-accordion.mjs.map +1 -0
  5. package/fesm2022/primenglab-animateonscroll.mjs +166 -0
  6. package/fesm2022/primenglab-animateonscroll.mjs.map +1 -0
  7. package/fesm2022/primenglab-api.mjs +850 -0
  8. package/fesm2022/primenglab-api.mjs.map +1 -0
  9. package/fesm2022/primenglab-autocomplete.mjs +2140 -0
  10. package/fesm2022/primenglab-autocomplete.mjs.map +1 -0
  11. package/fesm2022/primenglab-autofocus.mjs +78 -0
  12. package/fesm2022/primenglab-autofocus.mjs.map +1 -0
  13. package/fesm2022/primenglab-avatar.mjs +211 -0
  14. package/fesm2022/primenglab-avatar.mjs.map +1 -0
  15. package/fesm2022/primenglab-avatargroup.mjs +99 -0
  16. package/fesm2022/primenglab-avatargroup.mjs.map +1 -0
  17. package/fesm2022/primenglab-badge.mjs +161 -0
  18. package/fesm2022/primenglab-badge.mjs.map +1 -0
  19. package/fesm2022/primenglab-base.mjs +124 -0
  20. package/fesm2022/primenglab-base.mjs.map +1 -0
  21. package/fesm2022/primenglab-basecomponent.mjs +477 -0
  22. package/fesm2022/primenglab-basecomponent.mjs.map +1 -0
  23. package/fesm2022/primenglab-baseeditableholder.mjs +70 -0
  24. package/fesm2022/primenglab-baseeditableholder.mjs.map +1 -0
  25. package/fesm2022/primenglab-baseinput.mjs +100 -0
  26. package/fesm2022/primenglab-baseinput.mjs.map +1 -0
  27. package/fesm2022/primenglab-basemodelholder.mjs +27 -0
  28. package/fesm2022/primenglab-basemodelholder.mjs.map +1 -0
  29. package/fesm2022/primenglab-bind.mjs +97 -0
  30. package/fesm2022/primenglab-bind.mjs.map +1 -0
  31. package/fesm2022/primenglab-blockui.mjs +240 -0
  32. package/fesm2022/primenglab-blockui.mjs.map +1 -0
  33. package/fesm2022/primenglab-breadcrumb.mjs +582 -0
  34. package/fesm2022/primenglab-breadcrumb.mjs.map +1 -0
  35. package/fesm2022/primenglab-button.mjs +799 -0
  36. package/fesm2022/primenglab-button.mjs.map +1 -0
  37. package/fesm2022/primenglab-buttongroup.mjs +110 -0
  38. package/fesm2022/primenglab-buttongroup.mjs.map +1 -0
  39. package/fesm2022/primenglab-card.mjs +252 -0
  40. package/fesm2022/primenglab-card.mjs.map +1 -0
  41. package/fesm2022/primenglab-carousel.mjs +2052 -0
  42. package/fesm2022/primenglab-carousel.mjs.map +1 -0
  43. package/fesm2022/primenglab-cascadeselect.mjs +1756 -0
  44. package/fesm2022/primenglab-cascadeselect.mjs.map +1 -0
  45. package/fesm2022/primenglab-chart.mjs +235 -0
  46. package/fesm2022/primenglab-chart.mjs.map +1 -0
  47. package/fesm2022/primenglab-checkbox.mjs +441 -0
  48. package/fesm2022/primenglab-checkbox.mjs.map +1 -0
  49. package/fesm2022/primenglab-chip.mjs +304 -0
  50. package/fesm2022/primenglab-chip.mjs.map +1 -0
  51. package/fesm2022/primenglab-classnames.mjs +49 -0
  52. package/fesm2022/primenglab-classnames.mjs.map +1 -0
  53. package/fesm2022/primenglab-colorpicker.mjs +741 -0
  54. package/fesm2022/primenglab-colorpicker.mjs.map +1 -0
  55. package/fesm2022/primenglab-commandmenu.mjs +419 -0
  56. package/fesm2022/primenglab-commandmenu.mjs.map +1 -0
  57. package/fesm2022/primenglab-compare.mjs +520 -0
  58. package/fesm2022/primenglab-compare.mjs.map +1 -0
  59. package/fesm2022/primenglab-config.mjs +322 -0
  60. package/fesm2022/primenglab-config.mjs.map +1 -0
  61. package/fesm2022/primenglab-confirmdialog.mjs +746 -0
  62. package/fesm2022/primenglab-confirmdialog.mjs.map +1 -0
  63. package/fesm2022/primenglab-confirmpopup.mjs +685 -0
  64. package/fesm2022/primenglab-confirmpopup.mjs.map +1 -0
  65. package/fesm2022/primenglab-contextmenu.mjs +1485 -0
  66. package/fesm2022/primenglab-contextmenu.mjs.map +1 -0
  67. package/fesm2022/primenglab-dataview.mjs +765 -0
  68. package/fesm2022/primenglab-dataview.mjs.map +1 -0
  69. package/fesm2022/primenglab-datepicker.mjs +4373 -0
  70. package/fesm2022/primenglab-datepicker.mjs.map +1 -0
  71. package/fesm2022/primenglab-dialog.mjs +1234 -0
  72. package/fesm2022/primenglab-dialog.mjs.map +1 -0
  73. package/fesm2022/primenglab-divider.mjs +160 -0
  74. package/fesm2022/primenglab-divider.mjs.map +1 -0
  75. package/fesm2022/primenglab-dock.mjs +580 -0
  76. package/fesm2022/primenglab-dock.mjs.map +1 -0
  77. package/fesm2022/primenglab-dom.mjs +778 -0
  78. package/fesm2022/primenglab-dom.mjs.map +1 -0
  79. package/fesm2022/primenglab-dragdrop.mjs +312 -0
  80. package/fesm2022/primenglab-dragdrop.mjs.map +1 -0
  81. package/fesm2022/primenglab-drawer.mjs +708 -0
  82. package/fesm2022/primenglab-drawer.mjs.map +1 -0
  83. package/fesm2022/primenglab-dynamicdialog.mjs +1096 -0
  84. package/fesm2022/primenglab-dynamicdialog.mjs.map +1 -0
  85. package/fesm2022/primenglab-editor.mjs +496 -0
  86. package/fesm2022/primenglab-editor.mjs.map +1 -0
  87. package/fesm2022/primenglab-fieldset.mjs +418 -0
  88. package/fesm2022/primenglab-fieldset.mjs.map +1 -0
  89. package/fesm2022/primenglab-fileupload.mjs +1486 -0
  90. package/fesm2022/primenglab-fileupload.mjs.map +1 -0
  91. package/fesm2022/primenglab-floatlabel.mjs +106 -0
  92. package/fesm2022/primenglab-floatlabel.mjs.map +1 -0
  93. package/fesm2022/primenglab-fluid.mjs +89 -0
  94. package/fesm2022/primenglab-fluid.mjs.map +1 -0
  95. package/fesm2022/primenglab-focustrap.mjs +113 -0
  96. package/fesm2022/primenglab-focustrap.mjs.map +1 -0
  97. package/fesm2022/primenglab-galleria.mjs +1854 -0
  98. package/fesm2022/primenglab-galleria.mjs.map +1 -0
  99. package/fesm2022/primenglab-gallery.mjs +1859 -0
  100. package/fesm2022/primenglab-gallery.mjs.map +1 -0
  101. package/fesm2022/primenglab-iconfield.mjs +97 -0
  102. package/fesm2022/primenglab-iconfield.mjs.map +1 -0
  103. package/fesm2022/primenglab-icons-angledoubledown.mjs +37 -0
  104. package/fesm2022/primenglab-icons-angledoubledown.mjs.map +1 -0
  105. package/fesm2022/primenglab-icons-angledoubleleft.mjs +37 -0
  106. package/fesm2022/primenglab-icons-angledoubleleft.mjs.map +1 -0
  107. package/fesm2022/primenglab-icons-angledoubleright.mjs +37 -0
  108. package/fesm2022/primenglab-icons-angledoubleright.mjs.map +1 -0
  109. package/fesm2022/primenglab-icons-angledoubleup.mjs +37 -0
  110. package/fesm2022/primenglab-icons-angledoubleup.mjs.map +1 -0
  111. package/fesm2022/primenglab-icons-angledown.mjs +33 -0
  112. package/fesm2022/primenglab-icons-angledown.mjs.map +1 -0
  113. package/fesm2022/primenglab-icons-angleleft.mjs +33 -0
  114. package/fesm2022/primenglab-icons-angleleft.mjs.map +1 -0
  115. package/fesm2022/primenglab-icons-angleright.mjs +33 -0
  116. package/fesm2022/primenglab-icons-angleright.mjs.map +1 -0
  117. package/fesm2022/primenglab-icons-angleup.mjs +33 -0
  118. package/fesm2022/primenglab-icons-angleup.mjs.map +1 -0
  119. package/fesm2022/primenglab-icons-arrowdown.mjs +56 -0
  120. package/fesm2022/primenglab-icons-arrowdown.mjs.map +1 -0
  121. package/fesm2022/primenglab-icons-arrowdownleft.mjs +33 -0
  122. package/fesm2022/primenglab-icons-arrowdownleft.mjs.map +1 -0
  123. package/fesm2022/primenglab-icons-arrowdownright.mjs +33 -0
  124. package/fesm2022/primenglab-icons-arrowdownright.mjs.map +1 -0
  125. package/fesm2022/primenglab-icons-arrowleft.mjs +56 -0
  126. package/fesm2022/primenglab-icons-arrowleft.mjs.map +1 -0
  127. package/fesm2022/primenglab-icons-arrowright.mjs +37 -0
  128. package/fesm2022/primenglab-icons-arrowright.mjs.map +1 -0
  129. package/fesm2022/primenglab-icons-arrowup.mjs +56 -0
  130. package/fesm2022/primenglab-icons-arrowup.mjs.map +1 -0
  131. package/fesm2022/primenglab-icons-ban.mjs +52 -0
  132. package/fesm2022/primenglab-icons-ban.mjs.map +1 -0
  133. package/fesm2022/primenglab-icons-bars.mjs +37 -0
  134. package/fesm2022/primenglab-icons-bars.mjs.map +1 -0
  135. package/fesm2022/primenglab-icons-baseicon.mjs +103 -0
  136. package/fesm2022/primenglab-icons-baseicon.mjs.map +1 -0
  137. package/fesm2022/primenglab-icons-blank.mjs +23 -0
  138. package/fesm2022/primenglab-icons-blank.mjs.map +1 -0
  139. package/fesm2022/primenglab-icons-calendar.mjs +33 -0
  140. package/fesm2022/primenglab-icons-calendar.mjs.map +1 -0
  141. package/fesm2022/primenglab-icons-caretleft.mjs +33 -0
  142. package/fesm2022/primenglab-icons-caretleft.mjs.map +1 -0
  143. package/fesm2022/primenglab-icons-caretright.mjs +33 -0
  144. package/fesm2022/primenglab-icons-caretright.mjs.map +1 -0
  145. package/fesm2022/primenglab-icons-check.mjs +33 -0
  146. package/fesm2022/primenglab-icons-check.mjs.map +1 -0
  147. package/fesm2022/primenglab-icons-chevrondown.mjs +33 -0
  148. package/fesm2022/primenglab-icons-chevrondown.mjs.map +1 -0
  149. package/fesm2022/primenglab-icons-chevronleft.mjs +33 -0
  150. package/fesm2022/primenglab-icons-chevronleft.mjs.map +1 -0
  151. package/fesm2022/primenglab-icons-chevronright.mjs +33 -0
  152. package/fesm2022/primenglab-icons-chevronright.mjs.map +1 -0
  153. package/fesm2022/primenglab-icons-chevronup.mjs +33 -0
  154. package/fesm2022/primenglab-icons-chevronup.mjs.map +1 -0
  155. package/fesm2022/primenglab-icons-exclamationtriangle.mjs +68 -0
  156. package/fesm2022/primenglab-icons-exclamationtriangle.mjs.map +1 -0
  157. package/fesm2022/primenglab-icons-eye.mjs +37 -0
  158. package/fesm2022/primenglab-icons-eye.mjs.map +1 -0
  159. package/fesm2022/primenglab-icons-eyeslash.mjs +56 -0
  160. package/fesm2022/primenglab-icons-eyeslash.mjs.map +1 -0
  161. package/fesm2022/primenglab-icons-filter.mjs +52 -0
  162. package/fesm2022/primenglab-icons-filter.mjs.map +1 -0
  163. package/fesm2022/primenglab-icons-filterfill.mjs +33 -0
  164. package/fesm2022/primenglab-icons-filterfill.mjs.map +1 -0
  165. package/fesm2022/primenglab-icons-filterslash.mjs +56 -0
  166. package/fesm2022/primenglab-icons-filterslash.mjs.map +1 -0
  167. package/fesm2022/primenglab-icons-home.mjs +56 -0
  168. package/fesm2022/primenglab-icons-home.mjs.map +1 -0
  169. package/fesm2022/primenglab-icons-infocircle.mjs +56 -0
  170. package/fesm2022/primenglab-icons-infocircle.mjs.map +1 -0
  171. package/fesm2022/primenglab-icons-minus.mjs +33 -0
  172. package/fesm2022/primenglab-icons-minus.mjs.map +1 -0
  173. package/fesm2022/primenglab-icons-pencil.mjs +52 -0
  174. package/fesm2022/primenglab-icons-pencil.mjs.map +1 -0
  175. package/fesm2022/primenglab-icons-plus.mjs +52 -0
  176. package/fesm2022/primenglab-icons-plus.mjs.map +1 -0
  177. package/fesm2022/primenglab-icons-refresh.mjs +56 -0
  178. package/fesm2022/primenglab-icons-refresh.mjs.map +1 -0
  179. package/fesm2022/primenglab-icons-search.mjs +56 -0
  180. package/fesm2022/primenglab-icons-search.mjs.map +1 -0
  181. package/fesm2022/primenglab-icons-searchminus.mjs +56 -0
  182. package/fesm2022/primenglab-icons-searchminus.mjs.map +1 -0
  183. package/fesm2022/primenglab-icons-searchplus.mjs +56 -0
  184. package/fesm2022/primenglab-icons-searchplus.mjs.map +1 -0
  185. package/fesm2022/primenglab-icons-sortalt.mjs +64 -0
  186. package/fesm2022/primenglab-icons-sortalt.mjs.map +1 -0
  187. package/fesm2022/primenglab-icons-sortamountdown.mjs +52 -0
  188. package/fesm2022/primenglab-icons-sortamountdown.mjs.map +1 -0
  189. package/fesm2022/primenglab-icons-sortamountupalt.mjs +52 -0
  190. package/fesm2022/primenglab-icons-sortamountupalt.mjs.map +1 -0
  191. package/fesm2022/primenglab-icons-spinner.mjs +52 -0
  192. package/fesm2022/primenglab-icons-spinner.mjs.map +1 -0
  193. package/fesm2022/primenglab-icons-star.mjs +52 -0
  194. package/fesm2022/primenglab-icons-star.mjs.map +1 -0
  195. package/fesm2022/primenglab-icons-starfill.mjs +52 -0
  196. package/fesm2022/primenglab-icons-starfill.mjs.map +1 -0
  197. package/fesm2022/primenglab-icons-thlarge.mjs +56 -0
  198. package/fesm2022/primenglab-icons-thlarge.mjs.map +1 -0
  199. package/fesm2022/primenglab-icons-times.mjs +33 -0
  200. package/fesm2022/primenglab-icons-times.mjs.map +1 -0
  201. package/fesm2022/primenglab-icons-timescircle.mjs +56 -0
  202. package/fesm2022/primenglab-icons-timescircle.mjs.map +1 -0
  203. package/fesm2022/primenglab-icons-trash.mjs +56 -0
  204. package/fesm2022/primenglab-icons-trash.mjs.map +1 -0
  205. package/fesm2022/primenglab-icons-undo.mjs +56 -0
  206. package/fesm2022/primenglab-icons-undo.mjs.map +1 -0
  207. package/fesm2022/primenglab-icons-upload.mjs +56 -0
  208. package/fesm2022/primenglab-icons-upload.mjs.map +1 -0
  209. package/fesm2022/primenglab-icons-windowmaximize.mjs +56 -0
  210. package/fesm2022/primenglab-icons-windowmaximize.mjs.map +1 -0
  211. package/fesm2022/primenglab-icons-windowminimize.mjs +56 -0
  212. package/fesm2022/primenglab-icons-windowminimize.mjs.map +1 -0
  213. package/fesm2022/primenglab-icons.mjs +63 -0
  214. package/fesm2022/primenglab-icons.mjs.map +1 -0
  215. package/fesm2022/primenglab-iftalabel.mjs +90 -0
  216. package/fesm2022/primenglab-iftalabel.mjs.map +1 -0
  217. package/fesm2022/primenglab-image.mjs +728 -0
  218. package/fesm2022/primenglab-image.mjs.map +1 -0
  219. package/fesm2022/primenglab-imagecompare.mjs +177 -0
  220. package/fesm2022/primenglab-imagecompare.mjs.map +1 -0
  221. package/fesm2022/primenglab-inplace.mjs +237 -0
  222. package/fesm2022/primenglab-inplace.mjs.map +1 -0
  223. package/fesm2022/primenglab-inputcolor.mjs +2262 -0
  224. package/fesm2022/primenglab-inputcolor.mjs.map +1 -0
  225. package/fesm2022/primenglab-inputgroup.mjs +121 -0
  226. package/fesm2022/primenglab-inputgroup.mjs.map +1 -0
  227. package/fesm2022/primenglab-inputgroupaddon.mjs +70 -0
  228. package/fesm2022/primenglab-inputgroupaddon.mjs.map +1 -0
  229. package/fesm2022/primenglab-inputicon.mjs +74 -0
  230. package/fesm2022/primenglab-inputicon.mjs.map +1 -0
  231. package/fesm2022/primenglab-inputmask.mjs +1495 -0
  232. package/fesm2022/primenglab-inputmask.mjs.map +1 -0
  233. package/fesm2022/primenglab-inputnumber.mjs +1624 -0
  234. package/fesm2022/primenglab-inputnumber.mjs.map +1 -0
  235. package/fesm2022/primenglab-inputotp.mjs +445 -0
  236. package/fesm2022/primenglab-inputotp.mjs.map +1 -0
  237. package/fesm2022/primenglab-inputpassword.mjs +102 -0
  238. package/fesm2022/primenglab-inputpassword.mjs.map +1 -0
  239. package/fesm2022/primenglab-inputtags.mjs +748 -0
  240. package/fesm2022/primenglab-inputtags.mjs.map +1 -0
  241. package/fesm2022/primenglab-inputtext.mjs +174 -0
  242. package/fesm2022/primenglab-inputtext.mjs.map +1 -0
  243. package/fesm2022/primenglab-keyfilter.mjs +252 -0
  244. package/fesm2022/primenglab-keyfilter.mjs.map +1 -0
  245. package/fesm2022/primenglab-knob.mjs +467 -0
  246. package/fesm2022/primenglab-knob.mjs.map +1 -0
  247. package/fesm2022/primenglab-label.mjs +85 -0
  248. package/fesm2022/primenglab-label.mjs.map +1 -0
  249. package/fesm2022/primenglab-license.mjs +39 -0
  250. package/fesm2022/primenglab-license.mjs.map +1 -0
  251. package/fesm2022/primenglab-listbox.mjs +2108 -0
  252. package/fesm2022/primenglab-listbox.mjs.map +1 -0
  253. package/fesm2022/primenglab-megamenu.mjs +1595 -0
  254. package/fesm2022/primenglab-megamenu.mjs.map +1 -0
  255. package/fesm2022/primenglab-menu.mjs +1224 -0
  256. package/fesm2022/primenglab-menu.mjs.map +1 -0
  257. package/fesm2022/primenglab-menubar.mjs +1448 -0
  258. package/fesm2022/primenglab-menubar.mjs.map +1 -0
  259. package/fesm2022/primenglab-message.mjs +306 -0
  260. package/fesm2022/primenglab-message.mjs.map +1 -0
  261. package/fesm2022/primenglab-metergroup.mjs +412 -0
  262. package/fesm2022/primenglab-metergroup.mjs.map +1 -0
  263. package/fesm2022/primenglab-motion.mjs +719 -0
  264. package/fesm2022/primenglab-motion.mjs.map +1 -0
  265. package/fesm2022/primenglab-multiselect.mjs +2543 -0
  266. package/fesm2022/primenglab-multiselect.mjs.map +1 -0
  267. package/fesm2022/primenglab-orderlist.mjs +868 -0
  268. package/fesm2022/primenglab-orderlist.mjs.map +1 -0
  269. package/fesm2022/primenglab-organizationchart.mjs +617 -0
  270. package/fesm2022/primenglab-organizationchart.mjs.map +1 -0
  271. package/fesm2022/primenglab-overlay.mjs +751 -0
  272. package/fesm2022/primenglab-overlay.mjs.map +1 -0
  273. package/fesm2022/primenglab-overlaybadge.mjs +134 -0
  274. package/fesm2022/primenglab-overlaybadge.mjs.map +1 -0
  275. package/fesm2022/primenglab-paginator.mjs +759 -0
  276. package/fesm2022/primenglab-paginator.mjs.map +1 -0
  277. package/fesm2022/primenglab-panel.mjs +487 -0
  278. package/fesm2022/primenglab-panel.mjs.map +1 -0
  279. package/fesm2022/primenglab-panelmenu.mjs +1599 -0
  280. package/fesm2022/primenglab-panelmenu.mjs.map +1 -0
  281. package/fesm2022/primenglab-passthrough.mjs +21 -0
  282. package/fesm2022/primenglab-passthrough.mjs.map +1 -0
  283. package/fesm2022/primenglab-password.mjs +1089 -0
  284. package/fesm2022/primenglab-password.mjs.map +1 -0
  285. package/fesm2022/primenglab-picklist.mjs +1992 -0
  286. package/fesm2022/primenglab-picklist.mjs.map +1 -0
  287. package/fesm2022/primenglab-popover.mjs +488 -0
  288. package/fesm2022/primenglab-popover.mjs.map +1 -0
  289. package/fesm2022/primenglab-progressbar.mjs +200 -0
  290. package/fesm2022/primenglab-progressbar.mjs.map +1 -0
  291. package/fesm2022/primenglab-progressspinner.mjs +313 -0
  292. package/fesm2022/primenglab-progressspinner.mjs.map +1 -0
  293. package/fesm2022/primenglab-radiobutton.mjs +347 -0
  294. package/fesm2022/primenglab-radiobutton.mjs.map +1 -0
  295. package/fesm2022/primenglab-rating.mjs +488 -0
  296. package/fesm2022/primenglab-rating.mjs.map +1 -0
  297. package/fesm2022/primenglab-ripple.mjs +192 -0
  298. package/fesm2022/primenglab-ripple.mjs.map +1 -0
  299. package/fesm2022/primenglab-scrollarea.mjs +730 -0
  300. package/fesm2022/primenglab-scrollarea.mjs.map +1 -0
  301. package/fesm2022/primenglab-scroller.mjs +1183 -0
  302. package/fesm2022/primenglab-scroller.mjs.map +1 -0
  303. package/fesm2022/primenglab-scrollpanel.mjs +543 -0
  304. package/fesm2022/primenglab-scrollpanel.mjs.map +1 -0
  305. package/fesm2022/primenglab-scrolltop.mjs +323 -0
  306. package/fesm2022/primenglab-scrolltop.mjs.map +1 -0
  307. package/fesm2022/primenglab-select.mjs +2287 -0
  308. package/fesm2022/primenglab-select.mjs.map +1 -0
  309. package/fesm2022/primenglab-selectbutton.mjs +390 -0
  310. package/fesm2022/primenglab-selectbutton.mjs.map +1 -0
  311. package/fesm2022/primenglab-sidebar.mjs +1461 -0
  312. package/fesm2022/primenglab-sidebar.mjs.map +1 -0
  313. package/fesm2022/primenglab-skeleton.mjs +161 -0
  314. package/fesm2022/primenglab-skeleton.mjs.map +1 -0
  315. package/fesm2022/primenglab-slider.mjs +776 -0
  316. package/fesm2022/primenglab-slider.mjs.map +1 -0
  317. package/fesm2022/primenglab-speeddial.mjs +892 -0
  318. package/fesm2022/primenglab-speeddial.mjs.map +1 -0
  319. package/fesm2022/primenglab-splitbutton.mjs +544 -0
  320. package/fesm2022/primenglab-splitbutton.mjs.map +1 -0
  321. package/fesm2022/primenglab-splitter.mjs +853 -0
  322. package/fesm2022/primenglab-splitter.mjs.map +1 -0
  323. package/fesm2022/primenglab-stepper.mjs +724 -0
  324. package/fesm2022/primenglab-stepper.mjs.map +1 -0
  325. package/fesm2022/primenglab-steps.mjs +425 -0
  326. package/fesm2022/primenglab-steps.mjs.map +1 -0
  327. package/fesm2022/primenglab-styleclass.mjs +331 -0
  328. package/fesm2022/primenglab-styleclass.mjs.map +1 -0
  329. package/fesm2022/primenglab-table.mjs +7125 -0
  330. package/fesm2022/primenglab-table.mjs.map +1 -0
  331. package/fesm2022/primenglab-tabs.mjs +932 -0
  332. package/fesm2022/primenglab-tabs.mjs.map +1 -0
  333. package/fesm2022/primenglab-tag.mjs +179 -0
  334. package/fesm2022/primenglab-tag.mjs.map +1 -0
  335. package/fesm2022/primenglab-terminal.mjs +253 -0
  336. package/fesm2022/primenglab-terminal.mjs.map +1 -0
  337. package/fesm2022/primenglab-textarea.mjs +208 -0
  338. package/fesm2022/primenglab-textarea.mjs.map +1 -0
  339. package/fesm2022/primenglab-tieredmenu.mjs +1547 -0
  340. package/fesm2022/primenglab-tieredmenu.mjs.map +1 -0
  341. package/fesm2022/primenglab-timeline.mjs +211 -0
  342. package/fesm2022/primenglab-timeline.mjs.map +1 -0
  343. package/fesm2022/primenglab-toast.mjs +1140 -0
  344. package/fesm2022/primenglab-toast.mjs.map +1 -0
  345. package/fesm2022/primenglab-togglebutton.mjs +343 -0
  346. package/fesm2022/primenglab-togglebutton.mjs.map +1 -0
  347. package/fesm2022/primenglab-toggleswitch.mjs +296 -0
  348. package/fesm2022/primenglab-toggleswitch.mjs.map +1 -0
  349. package/fesm2022/primenglab-toolbar.mjs +167 -0
  350. package/fesm2022/primenglab-toolbar.mjs.map +1 -0
  351. package/fesm2022/primenglab-tooltip.mjs +770 -0
  352. package/fesm2022/primenglab-tooltip.mjs.map +1 -0
  353. package/fesm2022/primenglab-tree.mjs +2332 -0
  354. package/fesm2022/primenglab-tree.mjs.map +1 -0
  355. package/fesm2022/primenglab-treeselect.mjs +1263 -0
  356. package/fesm2022/primenglab-treeselect.mjs.map +1 -0
  357. package/fesm2022/primenglab-treetable.mjs +4817 -0
  358. package/fesm2022/primenglab-treetable.mjs.map +1 -0
  359. package/fesm2022/primenglab-ts-helpers.mjs +4 -0
  360. package/fesm2022/primenglab-ts-helpers.mjs.map +1 -0
  361. package/fesm2022/primenglab-types-accordion.mjs +4 -0
  362. package/fesm2022/primenglab-types-accordion.mjs.map +1 -0
  363. package/fesm2022/primenglab-types-autocomplete.mjs +4 -0
  364. package/fesm2022/primenglab-types-autocomplete.mjs.map +1 -0
  365. package/fesm2022/primenglab-types-avatar.mjs +4 -0
  366. package/fesm2022/primenglab-types-avatar.mjs.map +1 -0
  367. package/fesm2022/primenglab-types-avatargroup.mjs +4 -0
  368. package/fesm2022/primenglab-types-avatargroup.mjs.map +1 -0
  369. package/fesm2022/primenglab-types-badge.mjs +4 -0
  370. package/fesm2022/primenglab-types-badge.mjs.map +1 -0
  371. package/fesm2022/primenglab-types-blockui.mjs +4 -0
  372. package/fesm2022/primenglab-types-blockui.mjs.map +1 -0
  373. package/fesm2022/primenglab-types-breadcrumb.mjs +4 -0
  374. package/fesm2022/primenglab-types-breadcrumb.mjs.map +1 -0
  375. package/fesm2022/primenglab-types-button.mjs +4 -0
  376. package/fesm2022/primenglab-types-button.mjs.map +1 -0
  377. package/fesm2022/primenglab-types-card.mjs +4 -0
  378. package/fesm2022/primenglab-types-card.mjs.map +1 -0
  379. package/fesm2022/primenglab-types-carousel.mjs +4 -0
  380. package/fesm2022/primenglab-types-carousel.mjs.map +1 -0
  381. package/fesm2022/primenglab-types-cascadeselect.mjs +4 -0
  382. package/fesm2022/primenglab-types-cascadeselect.mjs.map +1 -0
  383. package/fesm2022/primenglab-types-chart.mjs +4 -0
  384. package/fesm2022/primenglab-types-chart.mjs.map +1 -0
  385. package/fesm2022/primenglab-types-checkbox.mjs +4 -0
  386. package/fesm2022/primenglab-types-checkbox.mjs.map +1 -0
  387. package/fesm2022/primenglab-types-chip.mjs +4 -0
  388. package/fesm2022/primenglab-types-chip.mjs.map +1 -0
  389. package/fesm2022/primenglab-types-colorpicker.mjs +4 -0
  390. package/fesm2022/primenglab-types-colorpicker.mjs.map +1 -0
  391. package/fesm2022/primenglab-types-commandmenu.mjs +4 -0
  392. package/fesm2022/primenglab-types-commandmenu.mjs.map +1 -0
  393. package/fesm2022/primenglab-types-compare.mjs +4 -0
  394. package/fesm2022/primenglab-types-compare.mjs.map +1 -0
  395. package/fesm2022/primenglab-types-confirmdialog.mjs +4 -0
  396. package/fesm2022/primenglab-types-confirmdialog.mjs.map +1 -0
  397. package/fesm2022/primenglab-types-confirmpopup.mjs +4 -0
  398. package/fesm2022/primenglab-types-confirmpopup.mjs.map +1 -0
  399. package/fesm2022/primenglab-types-contextmenu.mjs +4 -0
  400. package/fesm2022/primenglab-types-contextmenu.mjs.map +1 -0
  401. package/fesm2022/primenglab-types-dataview.mjs +4 -0
  402. package/fesm2022/primenglab-types-dataview.mjs.map +1 -0
  403. package/fesm2022/primenglab-types-datepicker.mjs +4 -0
  404. package/fesm2022/primenglab-types-datepicker.mjs.map +1 -0
  405. package/fesm2022/primenglab-types-dialog.mjs +4 -0
  406. package/fesm2022/primenglab-types-dialog.mjs.map +1 -0
  407. package/fesm2022/primenglab-types-divider.mjs +4 -0
  408. package/fesm2022/primenglab-types-divider.mjs.map +1 -0
  409. package/fesm2022/primenglab-types-dock.mjs +4 -0
  410. package/fesm2022/primenglab-types-dock.mjs.map +1 -0
  411. package/fesm2022/primenglab-types-drawer.mjs +4 -0
  412. package/fesm2022/primenglab-types-drawer.mjs.map +1 -0
  413. package/fesm2022/primenglab-types-editor.mjs +4 -0
  414. package/fesm2022/primenglab-types-editor.mjs.map +1 -0
  415. package/fesm2022/primenglab-types-fieldset.mjs +4 -0
  416. package/fesm2022/primenglab-types-fieldset.mjs.map +1 -0
  417. package/fesm2022/primenglab-types-fileupload.mjs +4 -0
  418. package/fesm2022/primenglab-types-fileupload.mjs.map +1 -0
  419. package/fesm2022/primenglab-types-floatlabel.mjs +4 -0
  420. package/fesm2022/primenglab-types-floatlabel.mjs.map +1 -0
  421. package/fesm2022/primenglab-types-fluid.mjs +4 -0
  422. package/fesm2022/primenglab-types-fluid.mjs.map +1 -0
  423. package/fesm2022/primenglab-types-galleria.mjs +4 -0
  424. package/fesm2022/primenglab-types-galleria.mjs.map +1 -0
  425. package/fesm2022/primenglab-types-gallery.mjs +4 -0
  426. package/fesm2022/primenglab-types-gallery.mjs.map +1 -0
  427. package/fesm2022/primenglab-types-iconfield.mjs +4 -0
  428. package/fesm2022/primenglab-types-iconfield.mjs.map +1 -0
  429. package/fesm2022/primenglab-types-iftalabel.mjs +4 -0
  430. package/fesm2022/primenglab-types-iftalabel.mjs.map +1 -0
  431. package/fesm2022/primenglab-types-image.mjs +4 -0
  432. package/fesm2022/primenglab-types-image.mjs.map +1 -0
  433. package/fesm2022/primenglab-types-imagecompare.mjs +4 -0
  434. package/fesm2022/primenglab-types-imagecompare.mjs.map +1 -0
  435. package/fesm2022/primenglab-types-inplace.mjs +4 -0
  436. package/fesm2022/primenglab-types-inplace.mjs.map +1 -0
  437. package/fesm2022/primenglab-types-inputcolor.mjs +4 -0
  438. package/fesm2022/primenglab-types-inputcolor.mjs.map +1 -0
  439. package/fesm2022/primenglab-types-inputgroup.mjs +4 -0
  440. package/fesm2022/primenglab-types-inputgroup.mjs.map +1 -0
  441. package/fesm2022/primenglab-types-inputgroupaddon.mjs +4 -0
  442. package/fesm2022/primenglab-types-inputgroupaddon.mjs.map +1 -0
  443. package/fesm2022/primenglab-types-inputicon.mjs +4 -0
  444. package/fesm2022/primenglab-types-inputicon.mjs.map +1 -0
  445. package/fesm2022/primenglab-types-inputmask.mjs +4 -0
  446. package/fesm2022/primenglab-types-inputmask.mjs.map +1 -0
  447. package/fesm2022/primenglab-types-inputnumber.mjs +4 -0
  448. package/fesm2022/primenglab-types-inputnumber.mjs.map +1 -0
  449. package/fesm2022/primenglab-types-inputotp.mjs +4 -0
  450. package/fesm2022/primenglab-types-inputotp.mjs.map +1 -0
  451. package/fesm2022/primenglab-types-inputpassword.mjs +4 -0
  452. package/fesm2022/primenglab-types-inputpassword.mjs.map +1 -0
  453. package/fesm2022/primenglab-types-inputtags.mjs +4 -0
  454. package/fesm2022/primenglab-types-inputtags.mjs.map +1 -0
  455. package/fesm2022/primenglab-types-inputtext.mjs +4 -0
  456. package/fesm2022/primenglab-types-inputtext.mjs.map +1 -0
  457. package/fesm2022/primenglab-types-knob.mjs +4 -0
  458. package/fesm2022/primenglab-types-knob.mjs.map +1 -0
  459. package/fesm2022/primenglab-types-label.mjs +4 -0
  460. package/fesm2022/primenglab-types-label.mjs.map +1 -0
  461. package/fesm2022/primenglab-types-listbox.mjs +4 -0
  462. package/fesm2022/primenglab-types-listbox.mjs.map +1 -0
  463. package/fesm2022/primenglab-types-megamenu.mjs +4 -0
  464. package/fesm2022/primenglab-types-megamenu.mjs.map +1 -0
  465. package/fesm2022/primenglab-types-menu.mjs +4 -0
  466. package/fesm2022/primenglab-types-menu.mjs.map +1 -0
  467. package/fesm2022/primenglab-types-menubar.mjs +4 -0
  468. package/fesm2022/primenglab-types-menubar.mjs.map +1 -0
  469. package/fesm2022/primenglab-types-message.mjs +4 -0
  470. package/fesm2022/primenglab-types-message.mjs.map +1 -0
  471. package/fesm2022/primenglab-types-metergroup.mjs +4 -0
  472. package/fesm2022/primenglab-types-metergroup.mjs.map +1 -0
  473. package/fesm2022/primenglab-types-motion.mjs +4 -0
  474. package/fesm2022/primenglab-types-motion.mjs.map +1 -0
  475. package/fesm2022/primenglab-types-multiselect.mjs +4 -0
  476. package/fesm2022/primenglab-types-multiselect.mjs.map +1 -0
  477. package/fesm2022/primenglab-types-orderlist.mjs +4 -0
  478. package/fesm2022/primenglab-types-orderlist.mjs.map +1 -0
  479. package/fesm2022/primenglab-types-organizationchart.mjs +4 -0
  480. package/fesm2022/primenglab-types-organizationchart.mjs.map +1 -0
  481. package/fesm2022/primenglab-types-overlay.mjs +4 -0
  482. package/fesm2022/primenglab-types-overlay.mjs.map +1 -0
  483. package/fesm2022/primenglab-types-overlaybadge.mjs +4 -0
  484. package/fesm2022/primenglab-types-overlaybadge.mjs.map +1 -0
  485. package/fesm2022/primenglab-types-paginator.mjs +4 -0
  486. package/fesm2022/primenglab-types-paginator.mjs.map +1 -0
  487. package/fesm2022/primenglab-types-panel.mjs +4 -0
  488. package/fesm2022/primenglab-types-panel.mjs.map +1 -0
  489. package/fesm2022/primenglab-types-panelmenu.mjs +4 -0
  490. package/fesm2022/primenglab-types-panelmenu.mjs.map +1 -0
  491. package/fesm2022/primenglab-types-password.mjs +4 -0
  492. package/fesm2022/primenglab-types-password.mjs.map +1 -0
  493. package/fesm2022/primenglab-types-picklist.mjs +4 -0
  494. package/fesm2022/primenglab-types-picklist.mjs.map +1 -0
  495. package/fesm2022/primenglab-types-popover.mjs +4 -0
  496. package/fesm2022/primenglab-types-popover.mjs.map +1 -0
  497. package/fesm2022/primenglab-types-progressbar.mjs +4 -0
  498. package/fesm2022/primenglab-types-progressbar.mjs.map +1 -0
  499. package/fesm2022/primenglab-types-progressspinner.mjs +4 -0
  500. package/fesm2022/primenglab-types-progressspinner.mjs.map +1 -0
  501. package/fesm2022/primenglab-types-radiobutton.mjs +4 -0
  502. package/fesm2022/primenglab-types-radiobutton.mjs.map +1 -0
  503. package/fesm2022/primenglab-types-rating.mjs +4 -0
  504. package/fesm2022/primenglab-types-rating.mjs.map +1 -0
  505. package/fesm2022/primenglab-types-scrollarea.mjs +4 -0
  506. package/fesm2022/primenglab-types-scrollarea.mjs.map +1 -0
  507. package/fesm2022/primenglab-types-scroller.mjs +4 -0
  508. package/fesm2022/primenglab-types-scroller.mjs.map +1 -0
  509. package/fesm2022/primenglab-types-scrollpanel.mjs +4 -0
  510. package/fesm2022/primenglab-types-scrollpanel.mjs.map +1 -0
  511. package/fesm2022/primenglab-types-scrolltop.mjs +4 -0
  512. package/fesm2022/primenglab-types-scrolltop.mjs.map +1 -0
  513. package/fesm2022/primenglab-types-select.mjs +4 -0
  514. package/fesm2022/primenglab-types-select.mjs.map +1 -0
  515. package/fesm2022/primenglab-types-selectbutton.mjs +4 -0
  516. package/fesm2022/primenglab-types-selectbutton.mjs.map +1 -0
  517. package/fesm2022/primenglab-types-shared.mjs +4 -0
  518. package/fesm2022/primenglab-types-shared.mjs.map +1 -0
  519. package/fesm2022/primenglab-types-sidebar.mjs +4 -0
  520. package/fesm2022/primenglab-types-sidebar.mjs.map +1 -0
  521. package/fesm2022/primenglab-types-skeleton.mjs +4 -0
  522. package/fesm2022/primenglab-types-skeleton.mjs.map +1 -0
  523. package/fesm2022/primenglab-types-slider.mjs +4 -0
  524. package/fesm2022/primenglab-types-slider.mjs.map +1 -0
  525. package/fesm2022/primenglab-types-speeddial.mjs +4 -0
  526. package/fesm2022/primenglab-types-speeddial.mjs.map +1 -0
  527. package/fesm2022/primenglab-types-splitbutton.mjs +4 -0
  528. package/fesm2022/primenglab-types-splitbutton.mjs.map +1 -0
  529. package/fesm2022/primenglab-types-splitter.mjs +4 -0
  530. package/fesm2022/primenglab-types-splitter.mjs.map +1 -0
  531. package/fesm2022/primenglab-types-stepper.mjs +4 -0
  532. package/fesm2022/primenglab-types-stepper.mjs.map +1 -0
  533. package/fesm2022/primenglab-types-table.mjs +4 -0
  534. package/fesm2022/primenglab-types-table.mjs.map +1 -0
  535. package/fesm2022/primenglab-types-tabs.mjs +4 -0
  536. package/fesm2022/primenglab-types-tabs.mjs.map +1 -0
  537. package/fesm2022/primenglab-types-tag.mjs +4 -0
  538. package/fesm2022/primenglab-types-tag.mjs.map +1 -0
  539. package/fesm2022/primenglab-types-terminal.mjs +4 -0
  540. package/fesm2022/primenglab-types-terminal.mjs.map +1 -0
  541. package/fesm2022/primenglab-types-textarea.mjs +4 -0
  542. package/fesm2022/primenglab-types-textarea.mjs.map +1 -0
  543. package/fesm2022/primenglab-types-tieredmenu.mjs +4 -0
  544. package/fesm2022/primenglab-types-tieredmenu.mjs.map +1 -0
  545. package/fesm2022/primenglab-types-timeline.mjs +4 -0
  546. package/fesm2022/primenglab-types-timeline.mjs.map +1 -0
  547. package/fesm2022/primenglab-types-toast.mjs +4 -0
  548. package/fesm2022/primenglab-types-toast.mjs.map +1 -0
  549. package/fesm2022/primenglab-types-togglebutton.mjs +4 -0
  550. package/fesm2022/primenglab-types-togglebutton.mjs.map +1 -0
  551. package/fesm2022/primenglab-types-toggleswitch.mjs +4 -0
  552. package/fesm2022/primenglab-types-toggleswitch.mjs.map +1 -0
  553. package/fesm2022/primenglab-types-toolbar.mjs +4 -0
  554. package/fesm2022/primenglab-types-toolbar.mjs.map +1 -0
  555. package/fesm2022/primenglab-types-tooltip.mjs +4 -0
  556. package/fesm2022/primenglab-types-tooltip.mjs.map +1 -0
  557. package/fesm2022/primenglab-types-tree.mjs +4 -0
  558. package/fesm2022/primenglab-types-tree.mjs.map +1 -0
  559. package/fesm2022/primenglab-types-treeselect.mjs +4 -0
  560. package/fesm2022/primenglab-types-treeselect.mjs.map +1 -0
  561. package/fesm2022/primenglab-types-treetable.mjs +4 -0
  562. package/fesm2022/primenglab-types-treetable.mjs.map +1 -0
  563. package/fesm2022/primenglab-usestyle.mjs +54 -0
  564. package/fesm2022/primenglab-usestyle.mjs.map +1 -0
  565. package/fesm2022/primenglab-utils.mjs +332 -0
  566. package/fesm2022/primenglab-utils.mjs.map +1 -0
  567. package/fesm2022/primenglab.mjs +6 -0
  568. package/fesm2022/primenglab.mjs.map +1 -0
  569. package/package.json +1188 -0
  570. package/types/primenglab-accordion.d.ts +252 -0
  571. package/types/primenglab-animateonscroll.d.ts +68 -0
  572. package/types/primenglab-api.d.ts +2000 -0
  573. package/types/primenglab-autocomplete.d.ts +774 -0
  574. package/types/primenglab-autofocus.d.ts +29 -0
  575. package/types/primenglab-avatar.d.ts +133 -0
  576. package/types/primenglab-avatargroup.d.ts +58 -0
  577. package/types/primenglab-badge.d.ts +96 -0
  578. package/types/primenglab-base.d.ts +58 -0
  579. package/types/primenglab-basecomponent.d.ts +178 -0
  580. package/types/primenglab-baseeditableholder.d.ts +45 -0
  581. package/types/primenglab-baseinput.d.ts +74 -0
  582. package/types/primenglab-basemodelholder.d.ts +12 -0
  583. package/types/primenglab-bind.d.ts +37 -0
  584. package/types/primenglab-blockui.d.ts +97 -0
  585. package/types/primenglab-breadcrumb.d.ts +150 -0
  586. package/types/primenglab-button.d.ts +468 -0
  587. package/types/primenglab-buttongroup.d.ts +44 -0
  588. package/types/primenglab-card.d.ts +138 -0
  589. package/types/primenglab-carousel.d.ts +687 -0
  590. package/types/primenglab-cascadeselect.d.ts +581 -0
  591. package/types/primenglab-chart.d.ts +133 -0
  592. package/types/primenglab-checkbox.d.ts +227 -0
  593. package/types/primenglab-chip.d.ts +159 -0
  594. package/types/primenglab-classnames.d.ts +32 -0
  595. package/types/primenglab-colorpicker.d.ts +295 -0
  596. package/types/primenglab-commandmenu.d.ts +182 -0
  597. package/types/primenglab-compare.d.ts +225 -0
  598. package/types/primenglab-config.d.ts +313 -0
  599. package/types/primenglab-confirmdialog.d.ts +344 -0
  600. package/types/primenglab-confirmpopup.d.ts +230 -0
  601. package/types/primenglab-contextmenu.d.ts +388 -0
  602. package/types/primenglab-dataview.d.ts +361 -0
  603. package/types/primenglab-datepicker.d.ts +967 -0
  604. package/types/primenglab-dialog.d.ts +481 -0
  605. package/types/primenglab-divider.d.ts +116 -0
  606. package/types/primenglab-dock.d.ts +189 -0
  607. package/types/primenglab-dom.d.ts +109 -0
  608. package/types/primenglab-dragdrop.d.ts +117 -0
  609. package/types/primenglab-drawer.d.ts +272 -0
  610. package/types/primenglab-dynamicdialog.d.ts +576 -0
  611. package/types/primenglab-editor.d.ts +182 -0
  612. package/types/primenglab-fieldset.d.ts +182 -0
  613. package/types/primenglab-fileupload.d.ts +542 -0
  614. package/types/primenglab-floatlabel.d.ts +67 -0
  615. package/types/primenglab-fluid.d.ts +54 -0
  616. package/types/primenglab-focustrap.d.ts +32 -0
  617. package/types/primenglab-galleria.d.ts +450 -0
  618. package/types/primenglab-gallery.d.ts +653 -0
  619. package/types/primenglab-iconfield.d.ts +61 -0
  620. package/types/primenglab-icons-angledoubledown.d.ts +9 -0
  621. package/types/primenglab-icons-angledoubleleft.d.ts +9 -0
  622. package/types/primenglab-icons-angledoubleright.d.ts +9 -0
  623. package/types/primenglab-icons-angledoubleup.d.ts +9 -0
  624. package/types/primenglab-icons-angledown.d.ts +9 -0
  625. package/types/primenglab-icons-angleleft.d.ts +9 -0
  626. package/types/primenglab-icons-angleright.d.ts +9 -0
  627. package/types/primenglab-icons-angleup.d.ts +9 -0
  628. package/types/primenglab-icons-arrowdown.d.ts +11 -0
  629. package/types/primenglab-icons-arrowdownleft.d.ts +9 -0
  630. package/types/primenglab-icons-arrowdownright.d.ts +9 -0
  631. package/types/primenglab-icons-arrowleft.d.ts +11 -0
  632. package/types/primenglab-icons-arrowright.d.ts +9 -0
  633. package/types/primenglab-icons-arrowup.d.ts +11 -0
  634. package/types/primenglab-icons-ban.d.ts +11 -0
  635. package/types/primenglab-icons-bars.d.ts +9 -0
  636. package/types/primenglab-icons-baseicon.d.ts +33 -0
  637. package/types/primenglab-icons-blank.d.ts +9 -0
  638. package/types/primenglab-icons-calendar.d.ts +9 -0
  639. package/types/primenglab-icons-caretleft.d.ts +9 -0
  640. package/types/primenglab-icons-caretright.d.ts +9 -0
  641. package/types/primenglab-icons-check.d.ts +9 -0
  642. package/types/primenglab-icons-chevrondown.d.ts +9 -0
  643. package/types/primenglab-icons-chevronleft.d.ts +9 -0
  644. package/types/primenglab-icons-chevronright.d.ts +9 -0
  645. package/types/primenglab-icons-chevronup.d.ts +9 -0
  646. package/types/primenglab-icons-exclamationtriangle.d.ts +11 -0
  647. package/types/primenglab-icons-eye.d.ts +9 -0
  648. package/types/primenglab-icons-eyeslash.d.ts +11 -0
  649. package/types/primenglab-icons-filter.d.ts +11 -0
  650. package/types/primenglab-icons-filterfill.d.ts +9 -0
  651. package/types/primenglab-icons-filterslash.d.ts +11 -0
  652. package/types/primenglab-icons-home.d.ts +11 -0
  653. package/types/primenglab-icons-infocircle.d.ts +11 -0
  654. package/types/primenglab-icons-minus.d.ts +9 -0
  655. package/types/primenglab-icons-pencil.d.ts +11 -0
  656. package/types/primenglab-icons-plus.d.ts +11 -0
  657. package/types/primenglab-icons-refresh.d.ts +11 -0
  658. package/types/primenglab-icons-search.d.ts +11 -0
  659. package/types/primenglab-icons-searchminus.d.ts +11 -0
  660. package/types/primenglab-icons-searchplus.d.ts +11 -0
  661. package/types/primenglab-icons-sortalt.d.ts +11 -0
  662. package/types/primenglab-icons-sortamountdown.d.ts +11 -0
  663. package/types/primenglab-icons-sortamountupalt.d.ts +11 -0
  664. package/types/primenglab-icons-spinner.d.ts +11 -0
  665. package/types/primenglab-icons-star.d.ts +11 -0
  666. package/types/primenglab-icons-starfill.d.ts +11 -0
  667. package/types/primenglab-icons-thlarge.d.ts +11 -0
  668. package/types/primenglab-icons-times.d.ts +9 -0
  669. package/types/primenglab-icons-timescircle.d.ts +11 -0
  670. package/types/primenglab-icons-trash.d.ts +11 -0
  671. package/types/primenglab-icons-undo.d.ts +11 -0
  672. package/types/primenglab-icons-upload.d.ts +11 -0
  673. package/types/primenglab-icons-windowmaximize.d.ts +11 -0
  674. package/types/primenglab-icons-windowminimize.d.ts +11 -0
  675. package/types/primenglab-icons.d.ts +53 -0
  676. package/types/primenglab-iftalabel.d.ts +56 -0
  677. package/types/primenglab-image.d.ts +336 -0
  678. package/types/primenglab-imagecompare.d.ts +97 -0
  679. package/types/primenglab-inplace.d.ts +132 -0
  680. package/types/primenglab-inputcolor.d.ts +568 -0
  681. package/types/primenglab-inputgroup.d.ts +59 -0
  682. package/types/primenglab-inputgroupaddon.d.ts +37 -0
  683. package/types/primenglab-inputicon.d.ts +38 -0
  684. package/types/primenglab-inputmask.d.ts +385 -0
  685. package/types/primenglab-inputnumber.d.ts +424 -0
  686. package/types/primenglab-inputotp.d.ts +177 -0
  687. package/types/primenglab-inputpassword.d.ts +63 -0
  688. package/types/primenglab-inputtags.d.ts +315 -0
  689. package/types/primenglab-inputtext.d.ts +112 -0
  690. package/types/primenglab-keyfilter.d.ts +58 -0
  691. package/types/primenglab-knob.d.ts +202 -0
  692. package/types/primenglab-label.d.ts +55 -0
  693. package/types/primenglab-license.d.ts +23 -0
  694. package/types/primenglab-listbox.d.ts +775 -0
  695. package/types/primenglab-megamenu.d.ts +402 -0
  696. package/types/primenglab-menu.d.ts +382 -0
  697. package/types/primenglab-menubar.d.ts +374 -0
  698. package/types/primenglab-message.d.ts +166 -0
  699. package/types/primenglab-metergroup.d.ts +209 -0
  700. package/types/primenglab-motion.d.ts +398 -0
  701. package/types/primenglab-multiselect.d.ts +877 -0
  702. package/types/primenglab-orderlist.d.ts +390 -0
  703. package/types/primenglab-organizationchart.d.ts +189 -0
  704. package/types/primenglab-overlay.d.ts +300 -0
  705. package/types/primenglab-overlaybadge.d.ts +70 -0
  706. package/types/primenglab-paginator.d.ts +330 -0
  707. package/types/primenglab-panel.d.ts +234 -0
  708. package/types/primenglab-panelmenu.d.ts +248 -0
  709. package/types/primenglab-passthrough.d.ts +14 -0
  710. package/types/primenglab-password.d.ts +459 -0
  711. package/types/primenglab-picklist.d.ts +751 -0
  712. package/types/primenglab-popover.d.ts +183 -0
  713. package/types/primenglab-progressbar.d.ts +118 -0
  714. package/types/primenglab-progressspinner.d.ts +126 -0
  715. package/types/primenglab-radiobutton.d.ts +188 -0
  716. package/types/primenglab-rating.d.ts +210 -0
  717. package/types/primenglab-ripple.d.ts +60 -0
  718. package/types/primenglab-scrollarea.d.ts +286 -0
  719. package/types/primenglab-scroller.d.ts +462 -0
  720. package/types/primenglab-scrollpanel.d.ts +147 -0
  721. package/types/primenglab-scrolltop.d.ts +143 -0
  722. package/types/primenglab-select.d.ts +757 -0
  723. package/types/primenglab-selectbutton.d.ts +184 -0
  724. package/types/primenglab-sidebar.d.ts +669 -0
  725. package/types/primenglab-skeleton.d.ts +103 -0
  726. package/types/primenglab-slider.d.ts +327 -0
  727. package/types/primenglab-speeddial.d.ts +394 -0
  728. package/types/primenglab-splitbutton.d.ts +259 -0
  729. package/types/primenglab-splitter.d.ts +334 -0
  730. package/types/primenglab-stepper.d.ts +311 -0
  731. package/types/primenglab-steps.d.ts +153 -0
  732. package/types/primenglab-styleclass.d.ts +110 -0
  733. package/types/primenglab-table.d.ts +1953 -0
  734. package/types/primenglab-tabs.d.ts +356 -0
  735. package/types/primenglab-tag.d.ts +104 -0
  736. package/types/primenglab-terminal.d.ts +137 -0
  737. package/types/primenglab-textarea.d.ts +126 -0
  738. package/types/primenglab-tieredmenu.d.ts +419 -0
  739. package/types/primenglab-timeline.d.ts +128 -0
  740. package/types/primenglab-toast.d.ts +268 -0
  741. package/types/primenglab-togglebutton.d.ts +200 -0
  742. package/types/primenglab-toggleswitch.d.ts +161 -0
  743. package/types/primenglab-toolbar.d.ts +95 -0
  744. package/types/primenglab-tooltip.d.ts +251 -0
  745. package/types/primenglab-tree.d.ts +571 -0
  746. package/types/primenglab-treeselect.d.ts +560 -0
  747. package/types/primenglab-treetable.d.ts +1290 -0
  748. package/types/primenglab-ts-helpers.d.ts +6 -0
  749. package/types/primenglab-types-accordion.d.ts +135 -0
  750. package/types/primenglab-types-autocomplete.d.ts +312 -0
  751. package/types/primenglab-types-avatar.d.ts +50 -0
  752. package/types/primenglab-types-avatargroup.d.ts +28 -0
  753. package/types/primenglab-types-badge.d.ts +36 -0
  754. package/types/primenglab-types-blockui.d.ts +39 -0
  755. package/types/primenglab-types-breadcrumb.d.ts +96 -0
  756. package/types/primenglab-types-button.d.ts +140 -0
  757. package/types/primenglab-types-card.d.ts +75 -0
  758. package/types/primenglab-types-carousel.d.ts +244 -0
  759. package/types/primenglab-types-cascadeselect.d.ts +278 -0
  760. package/types/primenglab-types-chart.d.ts +57 -0
  761. package/types/primenglab-types-checkbox.d.ts +85 -0
  762. package/types/primenglab-types-chip.d.ts +70 -0
  763. package/types/primenglab-types-colorpicker.d.ts +83 -0
  764. package/types/primenglab-types-commandmenu.d.ts +154 -0
  765. package/types/primenglab-types-compare.d.ts +55 -0
  766. package/types/primenglab-types-confirmdialog.d.ts +161 -0
  767. package/types/primenglab-types-confirmpopup.d.ts +110 -0
  768. package/types/primenglab-types-contextmenu.d.ts +135 -0
  769. package/types/primenglab-types-dataview.d.ts +263 -0
  770. package/types/primenglab-types-datepicker.d.ts +535 -0
  771. package/types/primenglab-types-dialog.d.ts +124 -0
  772. package/types/primenglab-types-divider.d.ts +43 -0
  773. package/types/primenglab-types-dock.d.ts +75 -0
  774. package/types/primenglab-types-drawer.d.ts +83 -0
  775. package/types/primenglab-types-editor.d.ts +210 -0
  776. package/types/primenglab-types-fieldset.d.ts +120 -0
  777. package/types/primenglab-types-fileupload.d.ts +416 -0
  778. package/types/primenglab-types-floatlabel.d.ts +27 -0
  779. package/types/primenglab-types-fluid.d.ts +28 -0
  780. package/types/primenglab-types-galleria.d.ts +259 -0
  781. package/types/primenglab-types-gallery.d.ts +434 -0
  782. package/types/primenglab-types-iconfield.d.ts +27 -0
  783. package/types/primenglab-types-iftalabel.d.ts +26 -0
  784. package/types/primenglab-types-image.d.ts +149 -0
  785. package/types/primenglab-types-imagecompare.d.ts +43 -0
  786. package/types/primenglab-types-inplace.d.ts +72 -0
  787. package/types/primenglab-types-inputcolor.d.ts +206 -0
  788. package/types/primenglab-types-inputgroup.d.ts +28 -0
  789. package/types/primenglab-types-inputgroupaddon.d.ts +28 -0
  790. package/types/primenglab-types-inputicon.d.ts +26 -0
  791. package/types/primenglab-types-inputmask.d.ts +56 -0
  792. package/types/primenglab-types-inputnumber.d.ts +115 -0
  793. package/types/primenglab-types-inputotp.d.ts +101 -0
  794. package/types/primenglab-types-inputpassword.d.ts +24 -0
  795. package/types/primenglab-types-inputtags.d.ts +178 -0
  796. package/types/primenglab-types-inputtext.d.ts +24 -0
  797. package/types/primenglab-types-knob.d.ts +40 -0
  798. package/types/primenglab-types-label.d.ts +24 -0
  799. package/types/primenglab-types-listbox.d.ts +359 -0
  800. package/types/primenglab-types-megamenu.d.ts +183 -0
  801. package/types/primenglab-types-menu.d.ts +135 -0
  802. package/types/primenglab-types-menubar.d.ts +171 -0
  803. package/types/primenglab-types-message.d.ts +112 -0
  804. package/types/primenglab-types-metergroup.d.ts +178 -0
  805. package/types/primenglab-types-motion.d.ts +26 -0
  806. package/types/primenglab-types-multiselect.d.ts +454 -0
  807. package/types/primenglab-types-orderlist.d.ts +177 -0
  808. package/types/primenglab-types-organizationchart.d.ts +187 -0
  809. package/types/primenglab-types-overlay.d.ts +60 -0
  810. package/types/primenglab-types-overlaybadge.d.ts +34 -0
  811. package/types/primenglab-types-paginator.d.ts +167 -0
  812. package/types/primenglab-types-panel.d.ts +139 -0
  813. package/types/primenglab-types-panelmenu.d.ts +180 -0
  814. package/types/primenglab-types-password.d.ts +120 -0
  815. package/types/primenglab-types-picklist.d.ts +358 -0
  816. package/types/primenglab-types-popover.d.ts +59 -0
  817. package/types/primenglab-types-progressbar.d.ts +63 -0
  818. package/types/primenglab-types-progressspinner.d.ts +44 -0
  819. package/types/primenglab-types-radiobutton.d.ts +51 -0
  820. package/types/primenglab-types-rating.d.ts +94 -0
  821. package/types/primenglab-types-scrollarea.d.ts +60 -0
  822. package/types/primenglab-types-scroller.d.ts +231 -0
  823. package/types/primenglab-types-scrollpanel.d.ts +56 -0
  824. package/types/primenglab-types-scrolltop.d.ts +71 -0
  825. package/types/primenglab-types-select.d.ts +330 -0
  826. package/types/primenglab-types-selectbutton.d.ts +92 -0
  827. package/types/primenglab-types-shared.d.ts +27 -0
  828. package/types/primenglab-types-sidebar.d.ts +108 -0
  829. package/types/primenglab-types-skeleton.d.ts +28 -0
  830. package/types/primenglab-types-slider.d.ts +91 -0
  831. package/types/primenglab-types-speeddial.d.ts +110 -0
  832. package/types/primenglab-types-splitbutton.d.ts +60 -0
  833. package/types/primenglab-types-splitter.d.ts +127 -0
  834. package/types/primenglab-types-stepper.d.ts +186 -0
  835. package/types/primenglab-types-table.d.ts +902 -0
  836. package/types/primenglab-types-tabs.d.ts +120 -0
  837. package/types/primenglab-types-tag.d.ts +48 -0
  838. package/types/primenglab-types-terminal.d.ts +60 -0
  839. package/types/primenglab-types-textarea.d.ts +28 -0
  840. package/types/primenglab-types-tieredmenu.d.ts +203 -0
  841. package/types/primenglab-types-timeline.d.ts +93 -0
  842. package/types/primenglab-types-toast.d.ts +148 -0
  843. package/types/primenglab-types-togglebutton.d.ts +91 -0
  844. package/types/primenglab-types-toggleswitch.d.ts +73 -0
  845. package/types/primenglab-types-toolbar.d.ts +55 -0
  846. package/types/primenglab-types-tooltip.d.ts +42 -0
  847. package/types/primenglab-types-tree.d.ts +355 -0
  848. package/types/primenglab-types-treeselect.d.ts +266 -0
  849. package/types/primenglab-types-treetable.d.ts +659 -0
  850. package/types/primenglab-usestyle.d.ts +15 -0
  851. package/types/primenglab-utils.d.ts +43 -0
  852. package/types/primenglab.d.ts +2 -0
@@ -0,0 +1,2332 @@
1
+ export * from 'primenglab/types/tree';
2
+ import { NgTemplateOutlet } from '@angular/common';
3
+ import * as i0 from '@angular/core';
4
+ import { InjectionToken, Injectable, inject, input, booleanAttribute, signal, computed, ViewEncapsulation, ChangeDetectionStrategy, Component, model, numberAttribute, output, contentChild, viewChild, DestroyRef, effect, untracked, NgModule } from '@angular/core';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
+ import { getOuterWidth, getOuterHeight, find, findSingle, focus, removeAccents, resolveFieldData } from '@primeuix/utils';
7
+ import { TreeDragDropService, TranslationKeys } from 'primenglab/api';
8
+ import * as i2 from 'primenglab/autofocus';
9
+ import { AutoFocusModule } from 'primenglab/autofocus';
10
+ import { BaseComponent, PARENT_INSTANCE } from 'primenglab/basecomponent';
11
+ import * as i1$1 from 'primenglab/bind';
12
+ import { Bind } from 'primenglab/bind';
13
+ import { IconField } from 'primenglab/iconfield';
14
+ import { Search } from '@primeicons/angular/search';
15
+ import { Spinner } from '@primeicons/angular/spinner';
16
+ import { InputIcon } from 'primenglab/inputicon';
17
+ import { InputText } from 'primenglab/inputtext';
18
+ import { Scroller } from 'primenglab/scroller';
19
+ import * as i1 from '@angular/forms';
20
+ import { FormsModule } from '@angular/forms';
21
+ import { Checkbox } from 'primenglab/checkbox';
22
+ import { ChevronDown } from '@primeicons/angular/chevron-down';
23
+ import { ChevronRight } from '@primeicons/angular/chevron-right';
24
+ import { Ripple } from 'primenglab/ripple';
25
+ import { style } from '@primeuix/styles/tree';
26
+ import { BaseStyle } from 'primenglab/base';
27
+
28
+ const TREE_INSTANCE = new InjectionToken('TREE_INSTANCE');
29
+ const TREENODE_INSTANCE = new InjectionToken('TREENODE_INSTANCE');
30
+
31
+ const classes = {
32
+ root: ({ instance }) => [
33
+ 'p-tree p-component',
34
+ {
35
+ 'p-tree-selectable': instance.selectionMode() != null,
36
+ 'p-tree-loading': instance.loading(),
37
+ 'p-tree-flex-scrollable': instance.scrollHeight() === 'flex',
38
+ 'p-tree-node-dragover': instance.dragHover
39
+ }
40
+ ],
41
+ mask: 'p-tree-mask p-overlay-mask',
42
+ loadingIcon: 'p-tree-loading-icon',
43
+ pcFilterInput: 'p-tree-filter-input',
44
+ wrapper: 'p-tree-root',
45
+ rootChildren: 'p-tree-root-children',
46
+ node: ({ instance }) => ({ 'p-tree-node': true, 'p-tree-node-leaf': instance.isLeaf() }),
47
+ nodeContent: ({ instance }) => ({
48
+ 'p-tree-node-content': true,
49
+ 'p-tree-node-selectable': instance.selectable,
50
+ 'p-tree-node-dragover': instance.isNodeDropActive(),
51
+ 'p-tree-node-selected': instance.tree.selectionMode() === 'checkbox' && instance.tree.highlightOnSelect() ? instance.checked : instance.selected,
52
+ 'p-tree-node-contextmenu-selected': instance.isContextMenuSelected()
53
+ }),
54
+ nodeToggleButton: 'p-tree-node-toggle-button',
55
+ nodeToggleIcon: 'p-tree-node-toggle-icon',
56
+ nodeCheckbox: 'p-tree-node-checkbox',
57
+ nodeIcon: 'p-tree-node-icon',
58
+ nodeLabel: 'p-tree-node-label',
59
+ nodeChildren: 'p-tree-node-children',
60
+ emptyMessage: 'p-tree-empty-message',
61
+ dropPoint: 'p-tree-node-drop-point'
62
+ };
63
+ class TreeStyle extends BaseStyle {
64
+ name = 'tree';
65
+ style = style;
66
+ classes = classes;
67
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
68
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle });
69
+ }
70
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle, decorators: [{
71
+ type: Injectable
72
+ }] });
73
+ /**
74
+ *
75
+ * Tree is used to display hierarchical data.
76
+ *
77
+ * [Live Demo](https://www.primeng.org/tree/)
78
+ *
79
+ * @module treestyle
80
+ *
81
+ */
82
+ var TreeClasses;
83
+ (function (TreeClasses) {
84
+ /**
85
+ * Class name of the root element
86
+ */
87
+ TreeClasses["root"] = "p-tree";
88
+ /**
89
+ * Class name of the mask element
90
+ */
91
+ TreeClasses["mask"] = "p-tree-mask";
92
+ /**
93
+ * Class name of the loading icon element
94
+ */
95
+ TreeClasses["loadingIcon"] = "p-tree-loading-icon";
96
+ /**
97
+ * Class name of the filter input element
98
+ */
99
+ TreeClasses["pcFilterInput"] = "p-tree-filter-input";
100
+ /**
101
+ * Class name of the wrapper element
102
+ */
103
+ TreeClasses["wrapper"] = "p-tree-root";
104
+ /**
105
+ * Class name of the root children element
106
+ */
107
+ TreeClasses["rootChildren"] = "p-tree-root-children";
108
+ /**
109
+ * Class name of the node element
110
+ */
111
+ TreeClasses["node"] = "p-tree-node";
112
+ /**
113
+ * Class name of the node content element
114
+ */
115
+ TreeClasses["nodeContent"] = "p-tree-node-content";
116
+ /**
117
+ * Class name of the node toggle button element
118
+ */
119
+ TreeClasses["nodeToggleButton"] = "p-tree-node-toggle-button";
120
+ /**
121
+ * Class name of the node toggle icon element
122
+ */
123
+ TreeClasses["nodeToggleIcon"] = "p-tree-node-toggle-icon";
124
+ /**
125
+ * Class name of the node checkbox element
126
+ */
127
+ TreeClasses["nodeCheckbox"] = "p-tree-node-checkbox";
128
+ /**
129
+ * Class name of the node icon element
130
+ */
131
+ TreeClasses["nodeIcon"] = "p-tree-node-icon";
132
+ /**
133
+ * Class name of the node label element
134
+ */
135
+ TreeClasses["nodeLabel"] = "p-tree-node-label";
136
+ /**
137
+ * Class name of the node children element
138
+ */
139
+ TreeClasses["nodeChildren"] = "p-tree-node-children";
140
+ /**
141
+ * Class name of the empty message element
142
+ */
143
+ TreeClasses["emptyMessage"] = "p-tree-empty-message";
144
+ /**
145
+ * Class name of the drop point element
146
+ */
147
+ TreeClasses["dropPoint"] = "p-tree-node-droppoint";
148
+ })(TreeClasses || (TreeClasses = {}));
149
+
150
+ class UITreeNode extends BaseComponent {
151
+ $pcTreeNode = inject(TREENODE_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
152
+ static ICON_CLASS = 'p-tree-node-icon ';
153
+ rowNode = input(/* @ts-ignore */
154
+ ...(ngDevMode ? [undefined, { debugName: "rowNode" }] : /* istanbul ignore next */ []));
155
+ node = input(/* @ts-ignore */
156
+ ...(ngDevMode ? [undefined, { debugName: "node" }] : /* istanbul ignore next */ []));
157
+ parentNode = input(/* @ts-ignore */
158
+ ...(ngDevMode ? [undefined, { debugName: "parentNode" }] : /* istanbul ignore next */ []));
159
+ root = input(false, { ...(ngDevMode ? { debugName: "root" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
160
+ index = input(/* @ts-ignore */
161
+ ...(ngDevMode ? [undefined, { debugName: "index" }] : /* istanbul ignore next */ []));
162
+ firstChild = input(false, { ...(ngDevMode ? { debugName: "firstChild" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
163
+ lastChild = input(false, { ...(ngDevMode ? { debugName: "lastChild" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
164
+ level = input(/* @ts-ignore */
165
+ ...(ngDevMode ? [undefined, { debugName: "level" }] : /* istanbul ignore next */ []));
166
+ indentation = input(/* @ts-ignore */
167
+ ...(ngDevMode ? [undefined, { debugName: "indentation" }] : /* istanbul ignore next */ []));
168
+ itemSize = input(/* @ts-ignore */
169
+ ...(ngDevMode ? [undefined, { debugName: "itemSize" }] : /* istanbul ignore next */ []));
170
+ loadingMode = input(/* @ts-ignore */
171
+ ...(ngDevMode ? [undefined, { debugName: "loadingMode" }] : /* istanbul ignore next */ []));
172
+ tree = inject(TREE_INSTANCE);
173
+ timeout;
174
+ isPrevDropPointHovered = signal(false, /* @ts-ignore */
175
+ ...(ngDevMode ? [{ debugName: "isPrevDropPointHovered" }] : /* istanbul ignore next */ []));
176
+ isNextDropPointHovered = signal(false, /* @ts-ignore */
177
+ ...(ngDevMode ? [{ debugName: "isNextDropPointHovered" }] : /* istanbul ignore next */ []));
178
+ isNodeDropHovered = signal(false, /* @ts-ignore */
179
+ ...(ngDevMode ? [{ debugName: "isNodeDropHovered" }] : /* istanbul ignore next */ []));
180
+ isPrevDropPointActive = computed(() => this.isPrevDropPointHovered() && this.isDroppable(), /* @ts-ignore */
181
+ ...(ngDevMode ? [{ debugName: "isPrevDropPointActive" }] : /* istanbul ignore next */ []));
182
+ isNextDropPointActive = computed(() => this.isNextDropPointHovered() && this.isDroppable(), /* @ts-ignore */
183
+ ...(ngDevMode ? [{ debugName: "isNextDropPointActive" }] : /* istanbul ignore next */ []));
184
+ isNodeDropActive = computed(() => this.isNodeDropHovered() && this.isNodeDroppable(), /* @ts-ignore */
185
+ ...(ngDevMode ? [{ debugName: "isNodeDropActive" }] : /* istanbul ignore next */ []));
186
+ dropPosition = computed(() => (this.isPrevDropPointActive() ? -1 : this.isNextDropPointActive() ? 1 : 0), /* @ts-ignore */
187
+ ...(ngDevMode ? [{ debugName: "dropPosition" }] : /* istanbul ignore next */ []));
188
+ get ariaSetSize() {
189
+ return this.node()?.children?.length ?? 0;
190
+ }
191
+ get ariaExpanded() {
192
+ return this.node()?.expanded;
193
+ }
194
+ ariaPosInSet = computed(() => (this.index() ?? 0) + 1, /* @ts-ignore */
195
+ ...(ngDevMode ? [{ debugName: "ariaPosInSet" }] : /* istanbul ignore next */ []));
196
+ ariaLevel = computed(() => (this.level() ?? 0) + 1, /* @ts-ignore */
197
+ ...(ngDevMode ? [{ debugName: "ariaLevel" }] : /* istanbul ignore next */ []));
198
+ nodeTabindex = computed(() => (this.index() === 0 ? 0 : -1), /* @ts-ignore */
199
+ ...(ngDevMode ? [{ debugName: "nodeTabindex" }] : /* istanbul ignore next */ []));
200
+ nodeContentPaddingLeft = computed(() => this.level() * this.indentation() + 'rem', /* @ts-ignore */
201
+ ...(ngDevMode ? [{ debugName: "nodeContentPaddingLeft" }] : /* istanbul ignore next */ []));
202
+ get hasNodeIcon() {
203
+ return !!(this.node()?.icon || this.node()?.expandedIcon || this.node()?.collapsedIcon);
204
+ }
205
+ get showChildren() {
206
+ return !this.tree.virtualScroll() && !!this.node()?.children && !!this.node()?.expanded;
207
+ }
208
+ get showLoadingSpinner() {
209
+ return this.loadingMode() === 'icon' && !!this.node()?.loading;
210
+ }
211
+ checkboxVariant = computed(() => this.tree?.config.inputVariant() || 'outlined', /* @ts-ignore */
212
+ ...(ngDevMode ? [{ debugName: "checkboxVariant" }] : /* istanbul ignore next */ []));
213
+ get togglerIconContext() {
214
+ return {
215
+ $implicit: this.node()?.expanded,
216
+ loading: this.node()?.loading
217
+ };
218
+ }
219
+ get checkboxIconContext() {
220
+ return {
221
+ $implicit: this.isSelected(),
222
+ partialSelected: this.node()?.partialSelected,
223
+ class: this.cx('nodeCheckbox')
224
+ };
225
+ }
226
+ _componentStyle = inject(TreeStyle);
227
+ /**
228
+ * Computed signal that reactively tracks selection state.
229
+ */
230
+ _selected = computed(() => {
231
+ // Reading selection() makes this computed reactive to selection changes
232
+ this.tree.selection();
233
+ return this.tree.isSelected(this.node());
234
+ }, /* @ts-ignore */
235
+ ...(ngDevMode ? [{ debugName: "_selected" }] : /* istanbul ignore next */ []));
236
+ /**
237
+ * Computed signal that reactively tracks context menu selection state.
238
+ */
239
+ _contextMenuSelected = computed(() => {
240
+ const selection = this.tree.contextMenuSelection();
241
+ const node = this.node();
242
+ if (!selection || !node) {
243
+ return false;
244
+ }
245
+ return selection === node || (selection.key && selection.key === node.key);
246
+ }, /* @ts-ignore */
247
+ ...(ngDevMode ? [{ debugName: "_contextMenuSelected" }] : /* istanbul ignore next */ []));
248
+ get selected() {
249
+ return this.tree.selectionMode() === 'single' || this.tree.selectionMode() === 'multiple' ? this._selected() : undefined;
250
+ }
251
+ get checked() {
252
+ return this.tree.selectionMode() === 'checkbox' ? this._selected() : undefined;
253
+ }
254
+ get nodeClass() {
255
+ return this.tree._componentStyle.classes.node({ instance: this });
256
+ }
257
+ get selectable() {
258
+ return this.node()?.selectable === false ? false : this.tree?.selectionMode() != null;
259
+ }
260
+ get subNodes() {
261
+ return this.node()?.parent ? this.node().parent.children : this.tree.value();
262
+ }
263
+ getPTOptions(key) {
264
+ return this.ptm(key, {
265
+ context: {
266
+ node: this.node(),
267
+ index: this.index(),
268
+ expanded: this.node()?.expanded,
269
+ selected: this.selected,
270
+ checked: this.checked,
271
+ partialChecked: this.node()?.partialSelected,
272
+ leaf: this.isLeaf()
273
+ }
274
+ });
275
+ }
276
+ onInit() {
277
+ this.node().parent = this.parentNode();
278
+ const nativeElement = this.tree.el.nativeElement;
279
+ const pDialogWrapper = nativeElement.closest('p-dialog');
280
+ if (this.parentNode() && !pDialogWrapper) {
281
+ this.setAllNodesTabIndexes();
282
+ this.tree.syncNodeOption(this.node(), this.tree.value(), 'parent', this.tree.getNodeWithKey(this.parentNode().key, this.tree.value()));
283
+ }
284
+ }
285
+ getIcon() {
286
+ let icon;
287
+ const node = this.node();
288
+ if (node.icon)
289
+ icon = node.icon;
290
+ else
291
+ icon = node.expanded && node.children && node.children?.length ? node.expandedIcon : node.collapsedIcon;
292
+ return UITreeNode.ICON_CLASS + ' ' + icon + ' p-tree-node-icon';
293
+ }
294
+ isLeaf() {
295
+ return this.tree.isNodeLeaf(this.node());
296
+ }
297
+ isSelected() {
298
+ return this._selected();
299
+ }
300
+ isContextMenuSelected() {
301
+ return this._contextMenuSelected();
302
+ }
303
+ isSameNode(event) {
304
+ return event.currentTarget && (event.currentTarget.isSameNode(event.target) || event.currentTarget.isSameNode(event.target.closest('[role="treeitem"]')));
305
+ }
306
+ isDraggable() {
307
+ return this.tree.draggableNodes();
308
+ }
309
+ isDroppable() {
310
+ return this.tree.droppableNodes() && this.tree.allowDrop(this.tree.dragNode, this.node(), this.tree.dragNodeScope);
311
+ }
312
+ isNodeDroppable() {
313
+ return this.node()?.droppable !== false && this.isDroppable();
314
+ }
315
+ isNodeDraggable() {
316
+ return this.node()?.draggable !== false && this.isDraggable();
317
+ }
318
+ toggle(event) {
319
+ if (this.node().expanded)
320
+ this.collapse(event);
321
+ else
322
+ this.expand(event);
323
+ event.stopPropagation();
324
+ }
325
+ expand(event) {
326
+ this.node().expanded = true;
327
+ this.tree.setNodeCollapsed(this.node(), false);
328
+ if (this.tree.virtualScroll()) {
329
+ this.tree.updateSerializedValue();
330
+ this.focusVirtualNode();
331
+ }
332
+ this.tree.onNodeExpand.emit({ originalEvent: event, node: this.node() });
333
+ }
334
+ collapse(event) {
335
+ this.node().expanded = false;
336
+ this.tree.setNodeCollapsed(this.node(), true);
337
+ if (this.tree.virtualScroll()) {
338
+ this.tree.updateSerializedValue();
339
+ }
340
+ this.tree.onNodeCollapse.emit({ originalEvent: event, node: this.node() });
341
+ this.focusVirtualNode();
342
+ }
343
+ onNodeClick(event) {
344
+ this.tree.onNodeClick(event, this.node());
345
+ }
346
+ onNodeKeydown(event) {
347
+ if (event.key === 'Enter') {
348
+ this.tree.onNodeClick(event, this.node());
349
+ }
350
+ }
351
+ onNodeTouchEnd() {
352
+ this.tree.onNodeTouchEnd();
353
+ }
354
+ onNodeRightClick(event) {
355
+ this.tree.onNodeRightClick(event, this.node());
356
+ }
357
+ onNodeDblClick(event) {
358
+ this.tree.onNodeDblClick(event, this.node());
359
+ }
360
+ insertNodeOnDrop() {
361
+ const { dragNode, dragNodeIndex, dragNodeSubNodes } = this.tree;
362
+ if (!this.node() || dragNodeIndex == null || !dragNode || !dragNodeSubNodes) {
363
+ return;
364
+ }
365
+ const position = this.dropPosition();
366
+ const subNodes = this.subNodes || [];
367
+ const index = this.index() || 0;
368
+ const dropIndex = dragNodeSubNodes === subNodes ? (dragNodeIndex > index ? index : index - 1) : index;
369
+ dragNodeSubNodes.splice(dragNodeIndex, 1);
370
+ if (position < 0) {
371
+ // insert before a Node
372
+ subNodes.splice(dropIndex, 0, dragNode);
373
+ }
374
+ else if (position > 0) {
375
+ // insert after a Node
376
+ subNodes.splice(dropIndex + 1, 0, dragNode);
377
+ }
378
+ else {
379
+ // insert as child of a Node
380
+ this.node().children = this.node().children || [];
381
+ this.node().children.push(dragNode);
382
+ }
383
+ this.tree.dragDropService.stopDrag({
384
+ node: dragNode,
385
+ subNodes,
386
+ index: dragNodeIndex
387
+ });
388
+ }
389
+ onNodeDrop(event) {
390
+ event.preventDefault();
391
+ event.stopPropagation();
392
+ if (this.isDroppable()) {
393
+ const { dragNode } = this.tree;
394
+ const position = this.dropPosition();
395
+ const isValidDrop = position !== 0 || (position === 0 && this.isNodeDroppable());
396
+ const dropPoint = position === 0 ? 'node' : 'between';
397
+ if (isValidDrop) {
398
+ if (this.tree.validateDrop()) {
399
+ this.tree.onNodeDrop.emit({
400
+ originalEvent: event,
401
+ dragNode: dragNode,
402
+ dropNode: this.node(),
403
+ index: this.index(),
404
+ dropPoint: dropPoint,
405
+ accept: () => {
406
+ this.insertNodeOnDrop();
407
+ }
408
+ });
409
+ }
410
+ else {
411
+ this.insertNodeOnDrop();
412
+ this.tree.onNodeDrop.emit({
413
+ originalEvent: event,
414
+ dragNode: dragNode,
415
+ dropNode: this.node(),
416
+ index: this.index(),
417
+ dropPoint: dropPoint
418
+ });
419
+ }
420
+ }
421
+ }
422
+ this.isPrevDropPointHovered.set(false);
423
+ this.isNextDropPointHovered.set(false);
424
+ this.isNodeDropHovered.set(false);
425
+ }
426
+ onNodeDragStart(event) {
427
+ if (this.isNodeDraggable()) {
428
+ event.dataTransfer.effectAllowed = 'all';
429
+ event.dataTransfer?.setData('text', 'data');
430
+ const target = event.currentTarget;
431
+ const dragEl = target.cloneNode(true);
432
+ const toggler = dragEl.querySelector('[data-pc-section="nodetogglebutton"]');
433
+ const checkbox = dragEl.querySelector('[data-pc-name="pcnodecheckbox"]');
434
+ target.setAttribute('data-p-dragging', 'true');
435
+ dragEl.style.width = getOuterWidth(target) + 'px';
436
+ dragEl.style.height = getOuterHeight(target) + 'px';
437
+ dragEl.setAttribute('data-pc-section', 'drag-image');
438
+ toggler.style.visibility = 'hidden';
439
+ checkbox?.remove();
440
+ document.body.appendChild(dragEl);
441
+ event.dataTransfer?.setDragImage(dragEl, 0, 0);
442
+ setTimeout(() => document.body.removeChild(dragEl), 0);
443
+ this.tree.dragDropService.startDrag({
444
+ tree: this,
445
+ node: this.node(),
446
+ subNodes: this.subNodes,
447
+ index: this.index(),
448
+ scope: this.tree.draggableScope()
449
+ });
450
+ }
451
+ else {
452
+ event.preventDefault();
453
+ }
454
+ }
455
+ onNodeDragOver(event) {
456
+ if (this.isDroppable()) {
457
+ event.dataTransfer.dropEffect = 'copy';
458
+ const nodeElement = event.currentTarget;
459
+ const rect = nodeElement.getBoundingClientRect();
460
+ const y = event.clientY - parseInt(rect.top);
461
+ this.isPrevDropPointHovered.set(false);
462
+ this.isNextDropPointHovered.set(false);
463
+ this.isNodeDropHovered.set(false);
464
+ if (y < rect.height * 0.25) {
465
+ this.isPrevDropPointHovered.set(true);
466
+ }
467
+ else if (y > rect.height * 0.75) {
468
+ this.isNextDropPointHovered.set(true);
469
+ }
470
+ else if (this.isNodeDroppable()) {
471
+ this.isNodeDropHovered.set(true);
472
+ }
473
+ }
474
+ else {
475
+ event.dataTransfer.dropEffect = 'none';
476
+ }
477
+ if (this.tree.droppableNodes()) {
478
+ event.preventDefault();
479
+ event.stopPropagation();
480
+ }
481
+ }
482
+ onNodeDragLeave() {
483
+ this.isPrevDropPointHovered.set(false);
484
+ this.isNextDropPointHovered.set(false);
485
+ this.isNodeDropHovered.set(false);
486
+ }
487
+ onNodeDragEnd(event) {
488
+ event.currentTarget?.removeAttribute('data-p-dragging');
489
+ this.tree.dragDropService.stopDrag({
490
+ node: this.node(),
491
+ subNodes: this.subNodes,
492
+ index: this.index()
493
+ });
494
+ }
495
+ onKeyDown(event) {
496
+ if (!this.isSameNode(event) || (this.tree.contextMenu() && this.tree.contextMenu().containerViewChild?.nativeElement.style.display === 'block')) {
497
+ return;
498
+ }
499
+ switch (event.code) {
500
+ //down arrow
501
+ case 'ArrowDown':
502
+ this.onArrowDown(event);
503
+ break;
504
+ //up arrow
505
+ case 'ArrowUp':
506
+ this.onArrowUp(event);
507
+ break;
508
+ //right arrow
509
+ case 'ArrowRight':
510
+ this.onArrowRight(event);
511
+ break;
512
+ //left arrow
513
+ case 'ArrowLeft':
514
+ this.onArrowLeft(event);
515
+ break;
516
+ //enter
517
+ case 'Enter':
518
+ case 'Space':
519
+ case 'NumpadEnter':
520
+ this.onEnter(event);
521
+ break;
522
+ //tab
523
+ case 'Tab':
524
+ this.setAllNodesTabIndexes();
525
+ break;
526
+ default:
527
+ //no op
528
+ break;
529
+ }
530
+ }
531
+ onArrowUp(event) {
532
+ const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target.parentElement;
533
+ if (nodeElement?.previousElementSibling) {
534
+ this.focusRowChange(nodeElement, nodeElement.previousElementSibling, this.findLastVisibleDescendant(nodeElement.previousElementSibling));
535
+ }
536
+ else {
537
+ let parentNodeElement = this.getParentNodeElement(nodeElement);
538
+ if (parentNodeElement) {
539
+ this.focusRowChange(nodeElement, parentNodeElement);
540
+ }
541
+ }
542
+ event.preventDefault();
543
+ }
544
+ onArrowDown(event) {
545
+ const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target;
546
+ const listElement = nodeElement?.children[1];
547
+ if (listElement && listElement.children.length > 0) {
548
+ this.focusRowChange(nodeElement, listElement.children[0]);
549
+ }
550
+ else {
551
+ if (nodeElement?.parentElement?.nextElementSibling) {
552
+ this.focusRowChange(nodeElement, nodeElement.parentElement.nextElementSibling);
553
+ }
554
+ else {
555
+ let nextSiblingAncestor = this.findNextSiblingOfAncestor(nodeElement?.parentElement);
556
+ if (nextSiblingAncestor) {
557
+ this.focusRowChange(nodeElement, nextSiblingAncestor);
558
+ }
559
+ }
560
+ }
561
+ event.preventDefault();
562
+ }
563
+ onArrowRight(event) {
564
+ if (!this.node()?.expanded && !this.tree.isNodeLeaf(this.node())) {
565
+ this.expand(event);
566
+ event.currentTarget.tabIndex = -1;
567
+ setTimeout(() => {
568
+ this.onArrowDown(event);
569
+ }, 1);
570
+ }
571
+ event.preventDefault();
572
+ }
573
+ onArrowLeft(event) {
574
+ const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target;
575
+ if (this.level() === 0 && !this.node()?.expanded) {
576
+ return false;
577
+ }
578
+ if (this.node()?.expanded) {
579
+ this.collapse(event);
580
+ return;
581
+ }
582
+ let parentNodeElement = this.getParentNodeElement(nodeElement?.parentElement);
583
+ if (parentNodeElement) {
584
+ this.focusRowChange(event.currentTarget, parentNodeElement);
585
+ }
586
+ event.preventDefault();
587
+ }
588
+ onEnter(event) {
589
+ this.tree.onNodeClick(event, this.node());
590
+ this.setTabIndexForSelectionMode(event, this.tree.nodeTouched);
591
+ event.preventDefault();
592
+ }
593
+ setAllNodesTabIndexes() {
594
+ const nodes = find(this.tree.el.nativeElement, '[data-pc-section="node"]');
595
+ const hasSelectedNode = [...nodes].some((node) => node.getAttribute('aria-selected') === 'true' || node.getAttribute('aria-checked') === 'true');
596
+ [...nodes].forEach((node) => {
597
+ node.tabIndex = -1;
598
+ });
599
+ if (hasSelectedNode) {
600
+ const selectedNodes = [...nodes].filter((node) => node.getAttribute('aria-selected') === 'true' || node.getAttribute('aria-checked') === 'true');
601
+ selectedNodes[0].tabIndex = 0;
602
+ return;
603
+ }
604
+ if (nodes.length) {
605
+ [...nodes][0].tabIndex = 0;
606
+ }
607
+ }
608
+ setTabIndexForSelectionMode(event, nodeTouched) {
609
+ if (this.tree.selectionMode() !== null) {
610
+ const elements = [...find(this.tree.el.nativeElement, '[role="treeitem"]')];
611
+ event.currentTarget.tabIndex = nodeTouched === false ? -1 : 0;
612
+ if (elements.every((element) => element.tabIndex === -1)) {
613
+ elements[0].tabIndex = 0;
614
+ }
615
+ }
616
+ }
617
+ findNextSiblingOfAncestor(nodeElement) {
618
+ let parentNodeElement = this.getParentNodeElement(nodeElement);
619
+ if (parentNodeElement) {
620
+ if (parentNodeElement.nextElementSibling)
621
+ return parentNodeElement.nextElementSibling;
622
+ else
623
+ return this.findNextSiblingOfAncestor(parentNodeElement);
624
+ }
625
+ else {
626
+ return null;
627
+ }
628
+ }
629
+ findLastVisibleDescendant(nodeElement) {
630
+ const listElement = Array.from(nodeElement.children).find((el) => el.getAttribute('data-pc-section') === 'node');
631
+ const childrenListElement = listElement?.children[1];
632
+ if (childrenListElement && childrenListElement.children.length > 0) {
633
+ const lastChildElement = childrenListElement.children[childrenListElement.children.length - 1];
634
+ return this.findLastVisibleDescendant(lastChildElement);
635
+ }
636
+ else {
637
+ return nodeElement;
638
+ }
639
+ }
640
+ getParentNodeElement(nodeElement) {
641
+ const parentNodeElement = nodeElement.parentElement?.parentElement?.parentElement;
642
+ return parentNodeElement?.tagName === 'P-TREENODE' ? parentNodeElement : null;
643
+ }
644
+ focusNode(element) {
645
+ element.children[0].focus();
646
+ }
647
+ focusRowChange(firstFocusableRow, currentFocusedRow, lastVisibleDescendant) {
648
+ firstFocusableRow.tabIndex = '-1';
649
+ currentFocusedRow.children[0].tabIndex = '0';
650
+ this.focusNode(lastVisibleDescendant || currentFocusedRow);
651
+ }
652
+ focusVirtualNode() {
653
+ this.timeout = setTimeout(() => {
654
+ let node = findSingle(this.tree?.contentViewChild()?.nativeElement, `[data-id="${this.node()?.key ?? this.node()?.data}"]`);
655
+ focus(node);
656
+ }, 1);
657
+ }
658
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: UITreeNode, deps: null, target: i0.ɵɵFactoryTarget.Component });
659
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: UITreeNode, isStandalone: true, selector: "p-treenode", inputs: { rowNode: { classPropertyName: "rowNode", publicName: "rowNode", isSignal: true, isRequired: false, transformFunction: null }, node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: false, transformFunction: null }, parentNode: { classPropertyName: "parentNode", publicName: "parentNode", isSignal: true, isRequired: false, transformFunction: null }, root: { classPropertyName: "root", publicName: "root", isSignal: true, isRequired: false, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: false, transformFunction: null }, firstChild: { classPropertyName: "firstChild", publicName: "firstChild", isSignal: true, isRequired: false, transformFunction: null }, lastChild: { classPropertyName: "lastChild", publicName: "lastChild", isSignal: true, isRequired: false, transformFunction: null }, level: { classPropertyName: "level", publicName: "level", isSignal: true, isRequired: false, transformFunction: null }, indentation: { classPropertyName: "indentation", publicName: "indentation", isSignal: true, isRequired: false, transformFunction: null }, itemSize: { classPropertyName: "itemSize", publicName: "itemSize", isSignal: true, isRequired: false, transformFunction: null }, loadingMode: { classPropertyName: "loadingMode", publicName: "loadingMode", isSignal: true, isRequired: false, transformFunction: null } }, providers: [TreeStyle, { provide: TREENODE_INSTANCE, useExisting: UITreeNode }, { provide: PARENT_INSTANCE, useExisting: UITreeNode }], usesInheritance: true, ngImport: i0, template: `
660
+ @if (node()) {
661
+ <li
662
+ [class]="cn(cx('node'), node()!.styleClass)"
663
+ [style.height.px]="itemSize()"
664
+ [style]="node()!.style"
665
+ [attr.aria-label]="node()!.label"
666
+ [attr.aria-checked]="checked"
667
+ [attr.aria-setsize]="ariaSetSize"
668
+ [attr.aria-selected]="selected"
669
+ [attr.aria-expanded]="ariaExpanded"
670
+ [attr.aria-posinset]="ariaPosInSet()"
671
+ [attr.aria-level]="ariaLevel()"
672
+ [attr.tabindex]="nodeTabindex()"
673
+ [attr.data-id]="node()!.key"
674
+ role="treeitem"
675
+ (keydown)="onKeyDown($event)"
676
+ [pBind]="getPTOptions('node')"
677
+ >
678
+ @if (isPrevDropPointActive()) {
679
+ <div [class]="cx('dropPoint')" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
680
+ }
681
+ <div
682
+ [class]="cx('nodeContent')"
683
+ [style.paddingLeft]="nodeContentPaddingLeft()"
684
+ (click)="onNodeClick($event)"
685
+ (contextmenu)="onNodeRightClick($event)"
686
+ (dblclick)="onNodeDblClick($event)"
687
+ (touchend)="onNodeTouchEnd()"
688
+ (drop)="onNodeDrop($event)"
689
+ (dragstart)="onNodeDragStart($event)"
690
+ (dragover)="onNodeDragOver($event)"
691
+ (dragleave)="onNodeDragLeave($event)"
692
+ (dragend)="onNodeDragEnd($event)"
693
+ [draggable]="tree.draggableNodes()"
694
+ [pBind]="getPTOptions('nodeContent')"
695
+ >
696
+ <button type="button" [class]="cx('nodeToggleButton')" (click)="toggle($event)" pRipple tabindex="-1" [pBind]="getPTOptions('nodeToggleButton')">
697
+ @if (!tree.togglerIconTemplate()) {
698
+ @if (!node()!.loading) {
699
+ @if (!node()!.expanded) {
700
+ <svg data-p-icon="chevron-right" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
701
+ }
702
+ @if (node()!.expanded) {
703
+ <svg data-p-icon="chevron-down" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
704
+ }
705
+ }
706
+ @if (showLoadingSpinner) {
707
+ <svg data-p-icon="spinner" [class]="cn(cx('nodeToggleIcon'), 'animate-spin')" [pBind]="getPTOptions('nodeToggleIcon')" />
708
+ }
709
+ }
710
+ @if (tree.togglerIconTemplate()) {
711
+ <span [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')">
712
+ <ng-template *ngTemplateOutlet="tree.togglerIconTemplate()!; context: togglerIconContext"></ng-template>
713
+ </span>
714
+ }
715
+ </button>
716
+
717
+ @if (tree.selectionMode() == 'checkbox') {
718
+ <p-checkbox
719
+ [ngModel]="isSelected()"
720
+ [class]="cx('nodeCheckbox')"
721
+ [binary]="true"
722
+ [indeterminate]="node()!.partialSelected"
723
+ [disabled]="node()!.selectable === false"
724
+ [variant]="checkboxVariant()"
725
+ [attr.data-p-partialchecked]="node()!.partialSelected"
726
+ [tabindex]="-1"
727
+ (click)="$event.preventDefault()"
728
+ [pt]="getPTOptions('pcNodeCheckbox')"
729
+ [unstyled]="unstyled()"
730
+ >
731
+ @if (tree.checkboxIconTemplate()) {
732
+ <ng-template #icon>
733
+ <ng-template *ngTemplateOutlet="tree.checkboxIconTemplate()!; context: checkboxIconContext"></ng-template>
734
+ </ng-template>
735
+ }
736
+ </p-checkbox>
737
+ }
738
+
739
+ @if (hasNodeIcon) {
740
+ <span [class]="getIcon()" [pBind]="getPTOptions('nodeIcon')"></span>
741
+ }
742
+ <span [class]="cx('nodeLabel')" [pBind]="getPTOptions('nodeLabel')">
743
+ @if (!tree.getTemplateForNode(node()!)) {
744
+ <span>{{ node()!.label }}</span>
745
+ }
746
+ @if (tree.getTemplateForNode(node()!)) {
747
+ <span>
748
+ <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node()!)!; context: { $implicit: node() }"></ng-container>
749
+ </span>
750
+ }
751
+ </span>
752
+ </div>
753
+ @if (isNextDropPointActive()) {
754
+ <div [class]="cx('dropPoint', { next: true })" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
755
+ }
756
+ @if (showChildren) {
757
+ <ul [class]="cx('nodeChildren')" role="group" [pBind]="ptm('nodeChildren')">
758
+ @for (childNode of node()!.children; track tree.trackBy()($index, childNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
759
+ <p-treenode
760
+ [node]="childNode"
761
+ [parentNode]="node()"
762
+ [firstChild]="firstChild"
763
+ [lastChild]="lastChild"
764
+ [index]="idx"
765
+ [itemSize]="itemSize()"
766
+ [level]="level()! + 1"
767
+ [loadingMode]="loadingMode()"
768
+ [pt]="pt"
769
+ [unstyled]="unstyled()"
770
+ />
771
+ }
772
+ </ul>
773
+ }
774
+ </li>
775
+ }
776
+ `, isInline: true, dependencies: [{ kind: "component", type: UITreeNode, selector: "p-treenode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation", "itemSize", "loadingMode"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: Ripple, selector: "[pRipple]" }, { kind: "component", type: Checkbox, selector: "p-checkbox, p-check-box", inputs: ["value", "binary", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "inputStyle", "inputClass", "indeterminate", "formControl", "checkboxIcon", "readonly", "autofocus", "trueValue", "falseValue", "variant", "size"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ChevronRight, selector: "svg[data-p-icon=\"chevron-right\"]" }, { kind: "component", type: ChevronDown, selector: "svg[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: Spinner, selector: "svg[data-p-icon=\"spinner\"]" }, { kind: "directive", type: Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
777
+ }
778
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: UITreeNode, decorators: [{
779
+ type: Component,
780
+ args: [{
781
+ selector: 'p-treenode',
782
+ standalone: true,
783
+ imports: [NgTemplateOutlet, Ripple, Checkbox, FormsModule, ChevronRight, ChevronDown, Spinner, Bind],
784
+ changeDetection: ChangeDetectionStrategy.OnPush,
785
+ template: `
786
+ @if (node()) {
787
+ <li
788
+ [class]="cn(cx('node'), node()!.styleClass)"
789
+ [style.height.px]="itemSize()"
790
+ [style]="node()!.style"
791
+ [attr.aria-label]="node()!.label"
792
+ [attr.aria-checked]="checked"
793
+ [attr.aria-setsize]="ariaSetSize"
794
+ [attr.aria-selected]="selected"
795
+ [attr.aria-expanded]="ariaExpanded"
796
+ [attr.aria-posinset]="ariaPosInSet()"
797
+ [attr.aria-level]="ariaLevel()"
798
+ [attr.tabindex]="nodeTabindex()"
799
+ [attr.data-id]="node()!.key"
800
+ role="treeitem"
801
+ (keydown)="onKeyDown($event)"
802
+ [pBind]="getPTOptions('node')"
803
+ >
804
+ @if (isPrevDropPointActive()) {
805
+ <div [class]="cx('dropPoint')" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
806
+ }
807
+ <div
808
+ [class]="cx('nodeContent')"
809
+ [style.paddingLeft]="nodeContentPaddingLeft()"
810
+ (click)="onNodeClick($event)"
811
+ (contextmenu)="onNodeRightClick($event)"
812
+ (dblclick)="onNodeDblClick($event)"
813
+ (touchend)="onNodeTouchEnd()"
814
+ (drop)="onNodeDrop($event)"
815
+ (dragstart)="onNodeDragStart($event)"
816
+ (dragover)="onNodeDragOver($event)"
817
+ (dragleave)="onNodeDragLeave($event)"
818
+ (dragend)="onNodeDragEnd($event)"
819
+ [draggable]="tree.draggableNodes()"
820
+ [pBind]="getPTOptions('nodeContent')"
821
+ >
822
+ <button type="button" [class]="cx('nodeToggleButton')" (click)="toggle($event)" pRipple tabindex="-1" [pBind]="getPTOptions('nodeToggleButton')">
823
+ @if (!tree.togglerIconTemplate()) {
824
+ @if (!node()!.loading) {
825
+ @if (!node()!.expanded) {
826
+ <svg data-p-icon="chevron-right" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
827
+ }
828
+ @if (node()!.expanded) {
829
+ <svg data-p-icon="chevron-down" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
830
+ }
831
+ }
832
+ @if (showLoadingSpinner) {
833
+ <svg data-p-icon="spinner" [class]="cn(cx('nodeToggleIcon'), 'animate-spin')" [pBind]="getPTOptions('nodeToggleIcon')" />
834
+ }
835
+ }
836
+ @if (tree.togglerIconTemplate()) {
837
+ <span [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')">
838
+ <ng-template *ngTemplateOutlet="tree.togglerIconTemplate()!; context: togglerIconContext"></ng-template>
839
+ </span>
840
+ }
841
+ </button>
842
+
843
+ @if (tree.selectionMode() == 'checkbox') {
844
+ <p-checkbox
845
+ [ngModel]="isSelected()"
846
+ [class]="cx('nodeCheckbox')"
847
+ [binary]="true"
848
+ [indeterminate]="node()!.partialSelected"
849
+ [disabled]="node()!.selectable === false"
850
+ [variant]="checkboxVariant()"
851
+ [attr.data-p-partialchecked]="node()!.partialSelected"
852
+ [tabindex]="-1"
853
+ (click)="$event.preventDefault()"
854
+ [pt]="getPTOptions('pcNodeCheckbox')"
855
+ [unstyled]="unstyled()"
856
+ >
857
+ @if (tree.checkboxIconTemplate()) {
858
+ <ng-template #icon>
859
+ <ng-template *ngTemplateOutlet="tree.checkboxIconTemplate()!; context: checkboxIconContext"></ng-template>
860
+ </ng-template>
861
+ }
862
+ </p-checkbox>
863
+ }
864
+
865
+ @if (hasNodeIcon) {
866
+ <span [class]="getIcon()" [pBind]="getPTOptions('nodeIcon')"></span>
867
+ }
868
+ <span [class]="cx('nodeLabel')" [pBind]="getPTOptions('nodeLabel')">
869
+ @if (!tree.getTemplateForNode(node()!)) {
870
+ <span>{{ node()!.label }}</span>
871
+ }
872
+ @if (tree.getTemplateForNode(node()!)) {
873
+ <span>
874
+ <ng-container *ngTemplateOutlet="tree.getTemplateForNode(node()!)!; context: { $implicit: node() }"></ng-container>
875
+ </span>
876
+ }
877
+ </span>
878
+ </div>
879
+ @if (isNextDropPointActive()) {
880
+ <div [class]="cx('dropPoint', { next: true })" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
881
+ }
882
+ @if (showChildren) {
883
+ <ul [class]="cx('nodeChildren')" role="group" [pBind]="ptm('nodeChildren')">
884
+ @for (childNode of node()!.children; track tree.trackBy()($index, childNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
885
+ <p-treenode
886
+ [node]="childNode"
887
+ [parentNode]="node()"
888
+ [firstChild]="firstChild"
889
+ [lastChild]="lastChild"
890
+ [index]="idx"
891
+ [itemSize]="itemSize()"
892
+ [level]="level()! + 1"
893
+ [loadingMode]="loadingMode()"
894
+ [pt]="pt"
895
+ [unstyled]="unstyled()"
896
+ />
897
+ }
898
+ </ul>
899
+ }
900
+ </li>
901
+ }
902
+ `,
903
+ encapsulation: ViewEncapsulation.None,
904
+ providers: [TreeStyle, { provide: TREENODE_INSTANCE, useExisting: UITreeNode }, { provide: PARENT_INSTANCE, useExisting: UITreeNode }]
905
+ }]
906
+ }], propDecorators: { rowNode: [{ type: i0.Input, args: [{ isSignal: true, alias: "rowNode", required: false }] }], node: [{ type: i0.Input, args: [{ isSignal: true, alias: "node", required: false }] }], parentNode: [{ type: i0.Input, args: [{ isSignal: true, alias: "parentNode", required: false }] }], root: [{ type: i0.Input, args: [{ isSignal: true, alias: "root", required: false }] }], index: [{ type: i0.Input, args: [{ isSignal: true, alias: "index", required: false }] }], firstChild: [{ type: i0.Input, args: [{ isSignal: true, alias: "firstChild", required: false }] }], lastChild: [{ type: i0.Input, args: [{ isSignal: true, alias: "lastChild", required: false }] }], level: [{ type: i0.Input, args: [{ isSignal: true, alias: "level", required: false }] }], indentation: [{ type: i0.Input, args: [{ isSignal: true, alias: "indentation", required: false }] }], itemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "itemSize", required: false }] }], loadingMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingMode", required: false }] }] } });
907
+
908
+ /**
909
+ * Tree is used to display hierarchical data.
910
+ * @group Components
911
+ */
912
+ class Tree extends BaseComponent {
913
+ componentName = 'Tree';
914
+ _destroyed = false;
915
+ bindDirectiveInstance = inject(Bind, { self: true });
916
+ $pcTree = inject(TREE_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
917
+ onDestroy() {
918
+ this._destroyed = true;
919
+ }
920
+ onAfterViewChecked() {
921
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
922
+ }
923
+ /**
924
+ * An array of treenodes.
925
+ * @group Props
926
+ */
927
+ value = input(/* @ts-ignore */
928
+ ...(ngDevMode ? [undefined, { debugName: "value" }] : /* istanbul ignore next */ []));
929
+ /**
930
+ * Defines the selection mode.
931
+ * @group Props
932
+ */
933
+ selectionMode = input(/* @ts-ignore */
934
+ ...(ngDevMode ? [undefined, { debugName: "selectionMode" }] : /* istanbul ignore next */ []));
935
+ /**
936
+ * Loading mode display.
937
+ * @group Props
938
+ */
939
+ loadingMode = input('mask', /* @ts-ignore */
940
+ ...(ngDevMode ? [{ debugName: "loadingMode" }] : /* istanbul ignore next */ []));
941
+ /**
942
+ * A single treenode instance or an array to refer to the selections.
943
+ * @deprecated since v22, use `selectionKeys` instead for key-based selection state.
944
+ * @group Props
945
+ */
946
+ selection = model(null, /* @ts-ignore */
947
+ ...(ngDevMode ? [{ debugName: "selection" }] : /* istanbul ignore next */ []));
948
+ /**
949
+ * A map of node keys (by `TreeNode.key`) whose value is `true` for collapsed nodes. Two-way bindable.
950
+ * When provided it controls expansion (a node is expanded unless its key maps to `true`); leave it
951
+ * unset to keep driving expansion from each node's `expanded` flag (default, non-breaking).
952
+ * @group Props
953
+ */
954
+ collapsedKeys = model(null, /* @ts-ignore */
955
+ ...(ngDevMode ? [{ debugName: "collapsedKeys" }] : /* istanbul ignore next */ []));
956
+ /**
957
+ * A map of node keys (by `TreeNode.key`) describing the selection state. Two-way bindable.
958
+ * For single/multiple selection a key maps to `true`; for checkbox selection it maps to
959
+ * `{ checked, partialChecked }`. When provided it is kept in sync with `selection`; leave it unset
960
+ * to keep using the node-reference based `selection` model (default, non-breaking).
961
+ * @group Props
962
+ */
963
+ selectionKeys = model(null, /* @ts-ignore */
964
+ ...(ngDevMode ? [{ debugName: "selectionKeys" }] : /* istanbul ignore next */ []));
965
+ /**
966
+ * Context menu instance.
967
+ * @group Props
968
+ */
969
+ contextMenu = input(/* @ts-ignore */
970
+ ...(ngDevMode ? [undefined, { debugName: "contextMenu" }] : /* istanbul ignore next */ []));
971
+ /**
972
+ * Selected node with a context menu.
973
+ * @group Props
974
+ */
975
+ contextMenuSelection = model(null, /* @ts-ignore */
976
+ ...(ngDevMode ? [{ debugName: "contextMenuSelection" }] : /* istanbul ignore next */ []));
977
+ /**
978
+ * Scope of the draggable nodes to match a droppableScope.
979
+ * @group Props
980
+ */
981
+ draggableScope = input(/* @ts-ignore */
982
+ ...(ngDevMode ? [undefined, { debugName: "draggableScope" }] : /* istanbul ignore next */ []));
983
+ /**
984
+ * Scope of the droppable nodes to match a draggableScope.
985
+ * @group Props
986
+ */
987
+ droppableScope = input(/* @ts-ignore */
988
+ ...(ngDevMode ? [undefined, { debugName: "droppableScope" }] : /* istanbul ignore next */ []));
989
+ /**
990
+ * Whether the nodes are draggable.
991
+ * @group Props
992
+ */
993
+ draggableNodes = input(false, { ...(ngDevMode ? { debugName: "draggableNodes" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
994
+ /**
995
+ * Whether the nodes are droppable.
996
+ * @group Props
997
+ */
998
+ droppableNodes = input(false, { ...(ngDevMode ? { debugName: "droppableNodes" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
999
+ /**
1000
+ * Defines how multiple items can be selected, when true metaKey needs to be pressed to select or unselect an item and when set to false selection of each item can be toggled individually. On touch enabled devices, metaKeySelection is turned off automatically.
1001
+ * @group Props
1002
+ */
1003
+ metaKeySelection = input(false, { ...(ngDevMode ? { debugName: "metaKeySelection" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1004
+ /**
1005
+ * Whether checkbox selections propagate to ancestor nodes.
1006
+ * @group Props
1007
+ */
1008
+ propagateSelectionUp = input(true, { ...(ngDevMode ? { debugName: "propagateSelectionUp" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1009
+ /**
1010
+ * Whether checkbox selections propagate to descendant nodes.
1011
+ * @group Props
1012
+ */
1013
+ propagateSelectionDown = input(true, { ...(ngDevMode ? { debugName: "propagateSelectionDown" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1014
+ /**
1015
+ * Displays a loader to indicate data load is in progress.
1016
+ * @group Props
1017
+ */
1018
+ loading = input(false, { ...(ngDevMode ? { debugName: "loading" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1019
+ /**
1020
+ * The icon to show while indicating data load is in progress.
1021
+ * @group Props
1022
+ */
1023
+ loadingIcon = input(/* @ts-ignore */
1024
+ ...(ngDevMode ? [undefined, { debugName: "loadingIcon" }] : /* istanbul ignore next */ []));
1025
+ /**
1026
+ * Text to display when there is no data.
1027
+ * @group Props
1028
+ */
1029
+ emptyMessage = input('', /* @ts-ignore */
1030
+ ...(ngDevMode ? [{ debugName: "emptyMessage" }] : /* istanbul ignore next */ []));
1031
+ /**
1032
+ * Used to define a string that labels the tree.
1033
+ * @group Props
1034
+ */
1035
+ ariaLabel = input(/* @ts-ignore */
1036
+ ...(ngDevMode ? [undefined, { debugName: "ariaLabel" }] : /* istanbul ignore next */ []));
1037
+ /**
1038
+ * Defines a string that labels the toggler icon for accessibility.
1039
+ * @group Props
1040
+ */
1041
+ togglerAriaLabel = input(/* @ts-ignore */
1042
+ ...(ngDevMode ? [undefined, { debugName: "togglerAriaLabel" }] : /* istanbul ignore next */ []));
1043
+ /**
1044
+ * Establishes relationships between the component and label(s) where its value should be one or more element IDs.
1045
+ * @group Props
1046
+ */
1047
+ ariaLabelledBy = input(/* @ts-ignore */
1048
+ ...(ngDevMode ? [undefined, { debugName: "ariaLabelledBy" }] : /* istanbul ignore next */ []));
1049
+ /**
1050
+ * When enabled, drop can be accepted or rejected based on condition defined at onNodeDrop.
1051
+ * @group Props
1052
+ */
1053
+ validateDrop = input(false, { ...(ngDevMode ? { debugName: "validateDrop" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1054
+ /**
1055
+ * When specified, displays an input field to filter the items.
1056
+ * @group Props
1057
+ */
1058
+ filter = input(false, { ...(ngDevMode ? { debugName: "filter" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1059
+ /**
1060
+ * Determines whether the filter input should be automatically focused when the component is rendered.
1061
+ * @group Props
1062
+ */
1063
+ filterInputAutoFocus = input(false, { ...(ngDevMode ? { debugName: "filterInputAutoFocus" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1064
+ /**
1065
+ * When filtering is enabled, filterBy decides which field or fields (comma separated) to search against.
1066
+ * @group Props
1067
+ */
1068
+ filterBy = input('label', /* @ts-ignore */
1069
+ ...(ngDevMode ? [{ debugName: "filterBy" }] : /* istanbul ignore next */ []));
1070
+ /**
1071
+ * Mode for filtering valid values are "lenient" and "strict". Default is lenient.
1072
+ * @group Props
1073
+ */
1074
+ filterMode = input('lenient', /* @ts-ignore */
1075
+ ...(ngDevMode ? [{ debugName: "filterMode" }] : /* istanbul ignore next */ []));
1076
+ /**
1077
+ * Mode for filtering valid values are "lenient" and "strict". Default is lenient.
1078
+ * @group Props
1079
+ */
1080
+ filterOptions;
1081
+ /**
1082
+ * Placeholder text to show when filter input is empty.
1083
+ * @group Props
1084
+ */
1085
+ filterPlaceholder = input(/* @ts-ignore */
1086
+ ...(ngDevMode ? [undefined, { debugName: "filterPlaceholder" }] : /* istanbul ignore next */ []));
1087
+ /**
1088
+ * Values after the tree nodes are filtered.
1089
+ * @group Props
1090
+ */
1091
+ filteredNodes;
1092
+ /**
1093
+ * Locale to use in filtering. The default locale is the host environment's current locale.
1094
+ * @group Props
1095
+ */
1096
+ filterLocale = input(/* @ts-ignore */
1097
+ ...(ngDevMode ? [undefined, { debugName: "filterLocale" }] : /* istanbul ignore next */ []));
1098
+ /**
1099
+ * Height of the scrollable viewport.
1100
+ * @group Props
1101
+ */
1102
+ scrollHeight = input(/* @ts-ignore */
1103
+ ...(ngDevMode ? [undefined, { debugName: "scrollHeight" }] : /* istanbul ignore next */ []));
1104
+ /**
1105
+ * Defines if data is loaded and interacted with in lazy manner.
1106
+ * @group Props
1107
+ */
1108
+ lazy = input(false, { ...(ngDevMode ? { debugName: "lazy" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1109
+ /**
1110
+ * Whether the data should be loaded on demand during scroll.
1111
+ * @group Props
1112
+ */
1113
+ virtualScroll = input(false, { ...(ngDevMode ? { debugName: "virtualScroll" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1114
+ /**
1115
+ * Height of an item in the list for VirtualScrolling.
1116
+ * @group Props
1117
+ */
1118
+ virtualScrollItemSize = input(/* @ts-ignore */
1119
+ ...(ngDevMode ? [undefined, { debugName: "virtualScrollItemSize" }] : /* istanbul ignore next */ []));
1120
+ /**
1121
+ * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.
1122
+ * @group Props
1123
+ */
1124
+ virtualScrollOptions = input(/* @ts-ignore */
1125
+ ...(ngDevMode ? [undefined, { debugName: "virtualScrollOptions" }] : /* istanbul ignore next */ []));
1126
+ /**
1127
+ * Indentation factor for spacing of the nested node when virtual scrolling is enabled.
1128
+ * @group Props
1129
+ */
1130
+ indentation = input(1.5, { ...(ngDevMode ? { debugName: "indentation" } : /* istanbul ignore next */ {}), transform: numberAttribute });
1131
+ /**
1132
+ * Function to optimize the node list rendering, default algorithm checks for object identity.
1133
+ * @group Props
1134
+ */
1135
+ trackBy = input((index, item) => item, /* @ts-ignore */
1136
+ ...(ngDevMode ? [{ debugName: "trackBy" }] : /* istanbul ignore next */ []));
1137
+ /**
1138
+ * Highlights the node on select.
1139
+ * @group Props
1140
+ */
1141
+ highlightOnSelect = input(false, { ...(ngDevMode ? { debugName: "highlightOnSelect" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1142
+ /**
1143
+ * Callback to invoke when a node is selected.
1144
+ * @param {TreeNodeSelectEvent} event - Node select event.
1145
+ * @group Emits
1146
+ */
1147
+ onNodeSelect = output();
1148
+ /**
1149
+ * Callback to invoke when a node is unselected.
1150
+ * @param {TreeNodeUnSelectEvent} event - Node unselect event.
1151
+ * @group Emits
1152
+ */
1153
+ onNodeUnselect = output();
1154
+ /**
1155
+ * Callback to invoke when a node is expanded.
1156
+ * @param {TreeNodeExpandEvent} event - Node expand event.
1157
+ * @group Emits
1158
+ */
1159
+ onNodeExpand = output();
1160
+ /**
1161
+ * Callback to invoke when a node is collapsed.
1162
+ * @param {TreeNodeCollapseEvent} event - Node collapse event.
1163
+ * @group Emits
1164
+ */
1165
+ onNodeCollapse = output();
1166
+ /**
1167
+ * Callback to invoke when a node is selected with right click.
1168
+ * @param {onNodeContextMenuSelect} event - Node context menu select event.
1169
+ * @group Emits
1170
+ */
1171
+ onNodeContextMenuSelect = output();
1172
+ /**
1173
+ * Callback to invoke when a node is double clicked.
1174
+ * @param {TreeNodeDoubleClickEvent} event - Node double click event.
1175
+ * @group Emits
1176
+ */
1177
+ onNodeDoubleClick = output();
1178
+ /**
1179
+ * Callback to invoke when a node is dropped.
1180
+ * @param {TreeNodeDropEvent} event - Node drop event.
1181
+ * @group Emits
1182
+ */
1183
+ onNodeDrop = output();
1184
+ /**
1185
+ * Callback to invoke in lazy mode to load new data.
1186
+ * @param {TreeLazyLoadEvent} event - Custom lazy load event.
1187
+ * @group Emits
1188
+ */
1189
+ onLazyLoad = output();
1190
+ /**
1191
+ * Callback to invoke in virtual scroll mode when scroll position changes.
1192
+ * @param {TreeScrollEvent} event - Custom scroll event.
1193
+ * @group Emits
1194
+ */
1195
+ onScroll = output();
1196
+ /**
1197
+ * Callback to invoke in virtual scroll mode when scroll position and item's range in view changes.
1198
+ * @param {TreeScrollIndexChangeEvent} event - Scroll index change event.
1199
+ * @group Emits
1200
+ */
1201
+ onScrollIndexChange = output();
1202
+ /**
1203
+ * Callback to invoke when data is filtered.
1204
+ * @param {TreeFilterEvent} event - Custom filter event.
1205
+ * @group Emits
1206
+ */
1207
+ onFilter = output();
1208
+ /**
1209
+ * Custom filter template.
1210
+ * @param {TreeFilterTemplateContext} context - filter context.
1211
+ * @see {@link TreeFilterTemplateContext}
1212
+ * @group Templates
1213
+ */
1214
+ filterTemplate = contentChild('filter', { ...(ngDevMode ? { debugName: "filterTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1215
+ /**
1216
+ * Custom node template.
1217
+ * @group Templates
1218
+ */
1219
+ nodeTemplate = contentChild('node', { ...(ngDevMode ? { debugName: "nodeTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1220
+ /**
1221
+ * Custom header template.
1222
+ * @group Templates
1223
+ */
1224
+ headerTemplate = contentChild('header', { ...(ngDevMode ? { debugName: "headerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1225
+ /**
1226
+ * Custom footer template.
1227
+ * @group Templates
1228
+ */
1229
+ footerTemplate = contentChild('footer', { ...(ngDevMode ? { debugName: "footerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1230
+ /**
1231
+ * Custom loader template.
1232
+ * @param {TreeLoaderTemplateContext} context - loader context.
1233
+ * @see {@link TreeLoaderTemplateContext}
1234
+ * @group Templates
1235
+ */
1236
+ loaderTemplate = contentChild('loader', { ...(ngDevMode ? { debugName: "loaderTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1237
+ /**
1238
+ * Custom empty message template.
1239
+ * @group Templates
1240
+ */
1241
+ emptyTemplate = contentChild('empty', { ...(ngDevMode ? { debugName: "emptyTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1242
+ /**
1243
+ * Custom toggler icon template.
1244
+ * @param {TreeTogglerIconTemplateContext} context - toggler icon context.
1245
+ * @see {@link TreeTogglerIconTemplateContext}
1246
+ * @group Templates
1247
+ */
1248
+ togglerIconTemplate = contentChild('togglericon', { ...(ngDevMode ? { debugName: "togglerIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1249
+ /**
1250
+ * Custom checkbox icon template.
1251
+ * @param {TreeCheckboxIconTemplateContext} context - checkbox icon context.
1252
+ * @see {@link TreeCheckboxIconTemplateContext}
1253
+ * @group Templates
1254
+ */
1255
+ checkboxIconTemplate = contentChild('checkboxicon', { ...(ngDevMode ? { debugName: "checkboxIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1256
+ /**
1257
+ * Custom loading icon template.
1258
+ * @group Templates
1259
+ */
1260
+ loadingIconTemplate = contentChild('loadingicon', { ...(ngDevMode ? { debugName: "loadingIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1261
+ /**
1262
+ * Custom filter icon template.
1263
+ * @group Templates
1264
+ */
1265
+ filterIconTemplate = contentChild('filtericon', { ...(ngDevMode ? { debugName: "filterIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
1266
+ filterViewChild = viewChild('filter', /* @ts-ignore */
1267
+ ...(ngDevMode ? [{ debugName: "filterViewChild" }] : /* istanbul ignore next */ []));
1268
+ scroller = viewChild('scroller', /* @ts-ignore */
1269
+ ...(ngDevMode ? [{ debugName: "scroller" }] : /* istanbul ignore next */ []));
1270
+ wrapperViewChild = viewChild('wrapper', /* @ts-ignore */
1271
+ ...(ngDevMode ? [{ debugName: "wrapperViewChild" }] : /* istanbul ignore next */ []));
1272
+ contentViewChild = viewChild('content', /* @ts-ignore */
1273
+ ...(ngDevMode ? [{ debugName: "contentViewChild" }] : /* istanbul ignore next */ []));
1274
+ serializedValue;
1275
+ nodeTouched;
1276
+ dragNodeTree;
1277
+ dragNode;
1278
+ dragNodeSubNodes;
1279
+ dragNodeIndex;
1280
+ dragNodeScope;
1281
+ dragHover;
1282
+ _componentStyle = inject(TreeStyle);
1283
+ dragDropService = inject(TreeDragDropService, { optional: true });
1284
+ destroyRef = inject(DestroyRef);
1285
+ constructor() {
1286
+ super();
1287
+ effect(() => {
1288
+ this.value();
1289
+ untracked(() => {
1290
+ this.updateSerializedValue();
1291
+ if (this.hasFilterActive()) {
1292
+ this._filter(this.filterViewChild()?.nativeElement?.value);
1293
+ }
1294
+ });
1295
+ });
1296
+ // Two-way `collapsedKeys` sync: when provided, project the map onto each node's `expanded` flag
1297
+ // so the existing expansion engine keeps working unchanged. Untracked writes avoid feedback loops.
1298
+ effect(() => {
1299
+ this.collapsedKeys();
1300
+ this.value();
1301
+ untracked(() => {
1302
+ if (this.collapsedKeys() == null) {
1303
+ return;
1304
+ }
1305
+ this.applyCollapsedKeys();
1306
+ this.updateSerializedValue();
1307
+ });
1308
+ });
1309
+ // Two-way `selectionKeys` <-> `selection` projection. Value-based comparison breaks the feedback
1310
+ // loop: once the two representations agree, neither effect writes again.
1311
+ effect(() => {
1312
+ this.selectionKeys();
1313
+ this.value();
1314
+ untracked(() => {
1315
+ if (this.selectionKeys() == null) {
1316
+ return;
1317
+ }
1318
+ if (!this.isSameSelectionKeys(this.deriveSelectionKeys(), this.selectionKeys())) {
1319
+ this.applySelectionKeys();
1320
+ }
1321
+ });
1322
+ });
1323
+ effect(() => {
1324
+ this.selection();
1325
+ untracked(() => {
1326
+ if (this.selectionKeys() == null) {
1327
+ return;
1328
+ }
1329
+ const derived = this.deriveSelectionKeys();
1330
+ if (!this.isSameSelectionKeys(derived, this.selectionKeys())) {
1331
+ this.selectionKeys.set(derived);
1332
+ }
1333
+ });
1334
+ });
1335
+ }
1336
+ onInit() {
1337
+ if (this.filterBy()) {
1338
+ this.filterOptions = {
1339
+ filter: (value) => this._filter(value),
1340
+ reset: () => this.resetFilter()
1341
+ };
1342
+ }
1343
+ if (this.droppableNodes()) {
1344
+ this.dragDropService?.dragStart$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
1345
+ this.dragNodeTree = event.tree;
1346
+ this.dragNode = event.node;
1347
+ this.dragNodeSubNodes = event.subNodes;
1348
+ this.dragNodeIndex = event.index;
1349
+ this.dragNodeScope = event.scope;
1350
+ });
1351
+ this.dragDropService?.dragStop$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
1352
+ this.dragNodeTree = null;
1353
+ this.dragNode = null;
1354
+ this.dragNodeSubNodes = null;
1355
+ this.dragNodeIndex = null;
1356
+ this.dragNodeScope = null;
1357
+ this.dragHover = false;
1358
+ });
1359
+ }
1360
+ }
1361
+ showLoadingMask = computed(() => this.loading() && this.loadingMode() === 'mask', /* @ts-ignore */
1362
+ ...(ngDevMode ? [{ debugName: "showLoadingMask" }] : /* istanbul ignore next */ []));
1363
+ get showEmptyMessage() {
1364
+ return !this.loading() && (this.getRootNode() == null || this.getRootNode().length === 0);
1365
+ }
1366
+ scrollerStyleHeight = computed(() => (this.scrollHeight() !== 'flex' ? this.scrollHeight() : undefined), /* @ts-ignore */
1367
+ ...(ngDevMode ? [{ debugName: "scrollerStyleHeight" }] : /* istanbul ignore next */ []));
1368
+ scrollerScrollHeight = computed(() => (this.scrollHeight() !== 'flex' ? undefined : '100%'), /* @ts-ignore */
1369
+ ...(ngDevMode ? [{ debugName: "scrollerScrollHeight" }] : /* istanbul ignore next */ []));
1370
+ get emptyMessageLabel() {
1371
+ return this.emptyMessage() || this.translate(TranslationKeys.EMPTY_MESSAGE);
1372
+ }
1373
+ updateSerializedValue() {
1374
+ this.serializedValue = [];
1375
+ this.serializeNodes(null, this.getRootNode(), 0, true);
1376
+ }
1377
+ /**
1378
+ * Projects the current `collapsedKeys` map onto each node's `expanded` flag (a node is expanded
1379
+ * unless its key maps to `true`).
1380
+ */
1381
+ applyCollapsedKeys() {
1382
+ const collapsedKeys = this.collapsedKeys();
1383
+ if (collapsedKeys == null) {
1384
+ return;
1385
+ }
1386
+ const walk = (nodes) => {
1387
+ if (!nodes)
1388
+ return;
1389
+ for (const node of nodes) {
1390
+ if (node.key != null) {
1391
+ node.expanded = !collapsedKeys[node.key];
1392
+ }
1393
+ if (node.children) {
1394
+ walk(node.children);
1395
+ }
1396
+ }
1397
+ };
1398
+ walk(this.getRootNode());
1399
+ }
1400
+ /**
1401
+ * Reflects a node's expansion change back into the two-way `collapsedKeys` map when it is in use.
1402
+ */
1403
+ setNodeCollapsed(node, collapsed) {
1404
+ const collapsedKeys = this.collapsedKeys();
1405
+ if (collapsedKeys == null || node.key == null) {
1406
+ return;
1407
+ }
1408
+ const next = { ...collapsedKeys };
1409
+ if (collapsed) {
1410
+ next[node.key] = true;
1411
+ }
1412
+ else {
1413
+ delete next[node.key];
1414
+ }
1415
+ this.collapsedKeys.set(next);
1416
+ }
1417
+ /** Builds a `key -> node` lookup over the whole tree (for `selectionKeys` projection). */
1418
+ collectNodesByKey() {
1419
+ const map = new Map();
1420
+ const walk = (nodes) => {
1421
+ if (!nodes)
1422
+ return;
1423
+ for (const node of nodes) {
1424
+ if (node.key != null) {
1425
+ map.set(node.key, node);
1426
+ }
1427
+ if (node.children) {
1428
+ walk(node.children);
1429
+ }
1430
+ }
1431
+ };
1432
+ walk(this.getRootNode());
1433
+ return map;
1434
+ }
1435
+ /** Derives the `selectionKeys` map from the current `selection` (and `partialSelected` for checkbox). */
1436
+ deriveSelectionKeys() {
1437
+ const mode = this.selectionMode();
1438
+ const map = {};
1439
+ if (mode === 'checkbox') {
1440
+ const selection = this.selection() || [];
1441
+ const selectedKeys = new Set(selection.map((node) => node.key));
1442
+ const walk = (nodes) => {
1443
+ if (!nodes)
1444
+ return;
1445
+ for (const node of nodes) {
1446
+ if (node.key != null) {
1447
+ if (selectedKeys.has(node.key)) {
1448
+ map[node.key] = { checked: true, partialChecked: false };
1449
+ }
1450
+ else if (node.partialSelected) {
1451
+ map[node.key] = { checked: false, partialChecked: true };
1452
+ }
1453
+ }
1454
+ if (node.children) {
1455
+ walk(node.children);
1456
+ }
1457
+ }
1458
+ };
1459
+ walk(this.getRootNode());
1460
+ }
1461
+ else if (mode === 'single') {
1462
+ const selected = this.selection();
1463
+ if (selected?.key != null) {
1464
+ map[selected.key] = true;
1465
+ }
1466
+ }
1467
+ else {
1468
+ const selection = this.selection() || [];
1469
+ for (const node of selection) {
1470
+ if (node.key != null) {
1471
+ map[node.key] = true;
1472
+ }
1473
+ }
1474
+ }
1475
+ return map;
1476
+ }
1477
+ /** Applies the current `selectionKeys` map onto the `selection` model (and `partialSelected` for checkbox). */
1478
+ applySelectionKeys() {
1479
+ const keys = this.selectionKeys();
1480
+ if (keys == null) {
1481
+ return;
1482
+ }
1483
+ const mode = this.selectionMode();
1484
+ const nodesByKey = this.collectNodesByKey();
1485
+ const isChecked = (value) => value === true || value?.checked === true;
1486
+ if (mode === 'single') {
1487
+ const key = Object.keys(keys).find((k) => isChecked(keys[k]));
1488
+ this.selection.set(key != null ? (nodesByKey.get(key) ?? null) : null);
1489
+ return;
1490
+ }
1491
+ const selected = [];
1492
+ nodesByKey.forEach((node, key) => {
1493
+ const value = keys[key];
1494
+ if (mode === 'checkbox') {
1495
+ node.partialSelected = value?.partialChecked === true;
1496
+ }
1497
+ if (isChecked(value)) {
1498
+ selected.push(node);
1499
+ }
1500
+ });
1501
+ this.selection.set(selected);
1502
+ }
1503
+ /** Value-based equality for two `selectionKeys` maps (handles both boolean and `{checked,partialChecked}` values). */
1504
+ isSameSelectionKeys(a, b) {
1505
+ const aKeys = Object.keys(a || {});
1506
+ const bKeys = Object.keys(b || {});
1507
+ if (aKeys.length !== bKeys.length) {
1508
+ return false;
1509
+ }
1510
+ return aKeys.every((key) => {
1511
+ const av = a[key];
1512
+ const bv = b[key];
1513
+ if (av === bv)
1514
+ return true;
1515
+ if (av && bv && typeof av === 'object' && typeof bv === 'object') {
1516
+ return av.checked === bv.checked && av.partialChecked === bv.partialChecked;
1517
+ }
1518
+ return false;
1519
+ });
1520
+ }
1521
+ serializeNodes(parent, nodes, level, visible) {
1522
+ if (nodes && nodes.length) {
1523
+ for (let node of nodes) {
1524
+ node.parent = parent;
1525
+ const rowNode = {
1526
+ node: node,
1527
+ parent: parent,
1528
+ level: level,
1529
+ visible: visible && (parent ? parent.expanded : true)
1530
+ };
1531
+ this.serializedValue.push(rowNode);
1532
+ if (rowNode.visible && node.expanded) {
1533
+ this.serializeNodes(node, node.children, level + 1, rowNode.visible);
1534
+ }
1535
+ }
1536
+ }
1537
+ }
1538
+ onNodeClick(event, node) {
1539
+ let eventTarget = event.target;
1540
+ const section = eventTarget?.getAttribute?.('data-pc-section');
1541
+ if (section === 'nodetogglebutton' || section === 'nodetoggleicon') {
1542
+ return;
1543
+ }
1544
+ if (this.selectionMode()) {
1545
+ if (node.selectable === false) {
1546
+ return;
1547
+ }
1548
+ if (this.hasFilteredNodes()) {
1549
+ node = this.getNodeWithKey(node.key, this.filteredNodes);
1550
+ if (!node) {
1551
+ return;
1552
+ }
1553
+ }
1554
+ let index = this.findIndexInSelection(node);
1555
+ let selected = index >= 0;
1556
+ const currentSelection = this.selection();
1557
+ if (this.isCheckboxSelectionMode()) {
1558
+ if (selected) {
1559
+ if (this.propagateSelectionDown())
1560
+ this.propagateDown(node, false);
1561
+ else
1562
+ this.selection.set(currentSelection.filter((_val, i) => i != index));
1563
+ if (this.propagateSelectionUp() && node.parent) {
1564
+ this.propagateUp(node.parent, false);
1565
+ }
1566
+ this.onNodeUnselect.emit({ originalEvent: event, node: node });
1567
+ }
1568
+ else {
1569
+ if (this.propagateSelectionDown())
1570
+ this.propagateDown(node, true);
1571
+ else
1572
+ this.selection.set([...(currentSelection || []), node]);
1573
+ if (this.propagateSelectionUp() && node.parent) {
1574
+ this.propagateUp(node.parent, true);
1575
+ }
1576
+ this.onNodeSelect.emit({ originalEvent: event, node: node });
1577
+ }
1578
+ }
1579
+ else {
1580
+ let metaSelection = this.nodeTouched ? false : this.metaKeySelection();
1581
+ if (metaSelection) {
1582
+ let metaKey = event.metaKey || event.ctrlKey;
1583
+ if (selected && metaKey) {
1584
+ if (this.isSingleSelectionMode()) {
1585
+ this.selection.set(null);
1586
+ }
1587
+ else {
1588
+ this.selection.set(currentSelection.filter((_val, i) => i != index));
1589
+ }
1590
+ this.onNodeUnselect.emit({ originalEvent: event, node: node });
1591
+ }
1592
+ else {
1593
+ if (this.isSingleSelectionMode()) {
1594
+ this.selection.set(node);
1595
+ }
1596
+ else if (this.isMultipleSelectionMode()) {
1597
+ const base = !metaKey ? [] : currentSelection || [];
1598
+ this.selection.set([...base, node]);
1599
+ }
1600
+ this.onNodeSelect.emit({ originalEvent: event, node: node });
1601
+ }
1602
+ }
1603
+ else {
1604
+ if (this.isSingleSelectionMode()) {
1605
+ if (selected) {
1606
+ this.selection.set(null);
1607
+ this.onNodeUnselect.emit({ originalEvent: event, node: node });
1608
+ }
1609
+ else {
1610
+ this.selection.set(node);
1611
+ setTimeout(() => {
1612
+ if (this._destroyed)
1613
+ return;
1614
+ this.onNodeSelect.emit({ originalEvent: event, node: node });
1615
+ });
1616
+ }
1617
+ }
1618
+ else {
1619
+ if (selected) {
1620
+ this.selection.set(currentSelection.filter((_val, i) => i != index));
1621
+ this.onNodeUnselect.emit({ originalEvent: event, node: node });
1622
+ }
1623
+ else {
1624
+ this.selection.set([...(currentSelection || []), node]);
1625
+ setTimeout(() => {
1626
+ if (this._destroyed)
1627
+ return;
1628
+ this.onNodeSelect.emit({ originalEvent: event, node: node });
1629
+ });
1630
+ }
1631
+ }
1632
+ }
1633
+ }
1634
+ }
1635
+ this.nodeTouched = false;
1636
+ }
1637
+ onNodeTouchEnd() {
1638
+ this.nodeTouched = true;
1639
+ }
1640
+ onNodeRightClick(event, node) {
1641
+ if (this.contextMenu()) {
1642
+ let eventTarget = event.target;
1643
+ const section = eventTarget.getAttribute('data-pc-section');
1644
+ if (section === 'nodetogglebutton' || section === 'nodetoggleicon') {
1645
+ return;
1646
+ }
1647
+ let index = this.findIndexInSelection(node);
1648
+ let isNodeSelected = index >= 0;
1649
+ const onContextMenuCallback = () => {
1650
+ this.contextMenu().show(event);
1651
+ this.contextMenu().hideCallback = () => {
1652
+ this.contextMenuSelection.set(null);
1653
+ };
1654
+ this.onNodeContextMenuSelect.emit({ originalEvent: event, node: node });
1655
+ };
1656
+ this.contextMenuSelection.set(node);
1657
+ onContextMenuCallback();
1658
+ }
1659
+ }
1660
+ onNodeDblClick(event, node) {
1661
+ this.onNodeDoubleClick.emit({ originalEvent: event, node: node });
1662
+ }
1663
+ findIndexInSelection(node) {
1664
+ let index = -1;
1665
+ const currentSelection = this.selection();
1666
+ if (this.selectionMode() && currentSelection) {
1667
+ if (this.isSingleSelectionMode()) {
1668
+ const sel = currentSelection;
1669
+ let areNodesEqual = (sel.key && sel.key === node.key) || sel == node;
1670
+ index = areNodesEqual ? 0 : -1;
1671
+ }
1672
+ else {
1673
+ const selArray = currentSelection;
1674
+ for (let i = 0; i < selArray.length; i++) {
1675
+ let selectedNode = selArray[i];
1676
+ let areNodesEqual = (selectedNode.key && selectedNode.key === node.key) || selectedNode == node;
1677
+ if (areNodesEqual) {
1678
+ index = i;
1679
+ break;
1680
+ }
1681
+ }
1682
+ }
1683
+ }
1684
+ return index;
1685
+ }
1686
+ syncNodeOption(node, parentNodes, option, value) {
1687
+ // to synchronize the node option between the filtered nodes and the original nodes(this.value)
1688
+ const _node = this.hasFilteredNodes() ? this.getNodeWithKey(node.key, parentNodes) : null;
1689
+ if (_node) {
1690
+ _node[option] = value || node[option];
1691
+ }
1692
+ }
1693
+ hasFilteredNodes() {
1694
+ return this.filter() && this.filteredNodes && this.filteredNodes.length;
1695
+ }
1696
+ hasFilterActive() {
1697
+ return this.filter() && this.filterViewChild()?.nativeElement?.value.length > 0;
1698
+ }
1699
+ getNodeWithKey(key, nodes) {
1700
+ for (let node of nodes) {
1701
+ if (node.key === key) {
1702
+ return node;
1703
+ }
1704
+ if (node.children) {
1705
+ let matchedNode = this.getNodeWithKey(key, node.children);
1706
+ if (matchedNode) {
1707
+ return matchedNode;
1708
+ }
1709
+ }
1710
+ }
1711
+ }
1712
+ propagateUp(node, select) {
1713
+ if (node.children && node.children.length) {
1714
+ let selectedCount = 0;
1715
+ let childPartialSelected = false;
1716
+ for (let child of node.children) {
1717
+ if (this.isSelected(child)) {
1718
+ selectedCount++;
1719
+ }
1720
+ else if (child.partialSelected) {
1721
+ childPartialSelected = true;
1722
+ }
1723
+ }
1724
+ const currentSelection = this.selection() || [];
1725
+ if (select && selectedCount == node.children.length) {
1726
+ this.selection.set([...currentSelection, node]);
1727
+ node.partialSelected = false;
1728
+ }
1729
+ else {
1730
+ if (!select) {
1731
+ let index = this.findIndexInSelection(node);
1732
+ if (index >= 0) {
1733
+ this.selection.set(currentSelection.filter((_val, i) => i != index));
1734
+ }
1735
+ }
1736
+ if (childPartialSelected || (selectedCount > 0 && selectedCount != node.children.length))
1737
+ node.partialSelected = true;
1738
+ else
1739
+ node.partialSelected = false;
1740
+ }
1741
+ this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
1742
+ }
1743
+ let parent = node.parent;
1744
+ if (parent) {
1745
+ this.propagateUp(parent, select);
1746
+ }
1747
+ }
1748
+ propagateDown(node, select) {
1749
+ let index = this.findIndexInSelection(node);
1750
+ const currentSelection = this.selection() || [];
1751
+ if (select && index == -1) {
1752
+ this.selection.set([...currentSelection, node]);
1753
+ }
1754
+ else if (!select && index > -1) {
1755
+ this.selection.set(currentSelection.filter((_val, i) => i != index));
1756
+ }
1757
+ node.partialSelected = false;
1758
+ this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
1759
+ if (node.children && node.children.length) {
1760
+ for (let child of node.children) {
1761
+ this.propagateDown(child, select);
1762
+ }
1763
+ }
1764
+ }
1765
+ isSelected(node) {
1766
+ return this.findIndexInSelection(node) != -1;
1767
+ }
1768
+ isSingleSelectionMode() {
1769
+ return this.selectionMode() && this.selectionMode() == 'single';
1770
+ }
1771
+ isMultipleSelectionMode() {
1772
+ return this.selectionMode() && this.selectionMode() == 'multiple';
1773
+ }
1774
+ isCheckboxSelectionMode() {
1775
+ return this.selectionMode() && this.selectionMode() == 'checkbox';
1776
+ }
1777
+ isNodeLeaf(node) {
1778
+ return node.leaf == false ? false : !(node.children && node.children.length);
1779
+ }
1780
+ getRootNode() {
1781
+ return this.filteredNodes ? this.filteredNodes : this.value();
1782
+ }
1783
+ getTemplateForNode(node) {
1784
+ return this.nodeTemplate() ?? null;
1785
+ }
1786
+ onDragOver(event) {
1787
+ if (this.droppableNodes() && this.allowDrop(this.dragNode, null, this.dragNodeScope)) {
1788
+ event.dataTransfer.dropEffect = 'copy';
1789
+ event.preventDefault();
1790
+ }
1791
+ }
1792
+ onDrop(event) {
1793
+ if (this.droppableNodes()) {
1794
+ event.preventDefault();
1795
+ let dragNode = this.dragNode;
1796
+ if (this.isSameTreeScope(this.dragNodeScope)) {
1797
+ return;
1798
+ }
1799
+ if (this.allowDrop(dragNode, null, this.dragNodeScope)) {
1800
+ let dragNodeIndex = this.dragNodeIndex;
1801
+ let currentValue = this.value() || [];
1802
+ if (this.validateDrop()) {
1803
+ this.onNodeDrop.emit({
1804
+ originalEvent: event,
1805
+ dragNode: dragNode,
1806
+ dropNode: null,
1807
+ index: dragNodeIndex,
1808
+ accept: () => {
1809
+ this.processTreeDrop(dragNode, dragNodeIndex);
1810
+ }
1811
+ });
1812
+ }
1813
+ else {
1814
+ this.onNodeDrop.emit({
1815
+ originalEvent: event,
1816
+ dragNode: dragNode,
1817
+ dropNode: null,
1818
+ index: dragNodeIndex
1819
+ });
1820
+ this.processTreeDrop(dragNode, dragNodeIndex);
1821
+ }
1822
+ }
1823
+ }
1824
+ }
1825
+ processTreeDrop(dragNode, dragNodeIndex) {
1826
+ this.dragNodeSubNodes.splice(dragNodeIndex, 1);
1827
+ this.value().push(dragNode);
1828
+ this.dragDropService.stopDrag({
1829
+ node: dragNode
1830
+ });
1831
+ }
1832
+ onDragEnter() {
1833
+ if (this.droppableNodes() && this.allowDrop(this.dragNode, null, this.dragNodeScope)) {
1834
+ this.dragHover = true;
1835
+ }
1836
+ }
1837
+ onDragLeave(event) {
1838
+ if (this.droppableNodes()) {
1839
+ let rect = event.currentTarget.getBoundingClientRect();
1840
+ if (event.x > parseInt(rect.left) + rect.width || event.x < parseInt(rect.left) || event.y > parseInt(rect.top) + rect.height || event.y < parseInt(rect.top)) {
1841
+ this.dragHover = false;
1842
+ }
1843
+ }
1844
+ }
1845
+ allowDrop(dragNode, dropNode, dragNodeScope) {
1846
+ if (!dragNode) {
1847
+ //prevent random html elements to be dragged
1848
+ return false;
1849
+ }
1850
+ else if (this.isValidDragScope(dragNodeScope)) {
1851
+ let allow = true;
1852
+ if (dropNode) {
1853
+ if (dragNode === dropNode) {
1854
+ allow = false;
1855
+ }
1856
+ else {
1857
+ let parent = dropNode.parent;
1858
+ while (parent != null) {
1859
+ if (parent === dragNode) {
1860
+ allow = false;
1861
+ break;
1862
+ }
1863
+ parent = parent.parent;
1864
+ }
1865
+ }
1866
+ }
1867
+ return allow;
1868
+ }
1869
+ else {
1870
+ return false;
1871
+ }
1872
+ }
1873
+ hasCommonScope(dragScope, dropScope) {
1874
+ if (typeof dropScope === 'string') {
1875
+ if (typeof dragScope === 'string')
1876
+ return dropScope === dragScope;
1877
+ else if (Array.isArray(dragScope))
1878
+ return dragScope.indexOf(dropScope) != -1;
1879
+ }
1880
+ else if (Array.isArray(dropScope)) {
1881
+ if (typeof dragScope === 'string') {
1882
+ return dropScope.indexOf(dragScope) != -1;
1883
+ }
1884
+ else if (Array.isArray(dragScope)) {
1885
+ for (let s of dropScope) {
1886
+ for (let ds of dragScope) {
1887
+ if (s === ds) {
1888
+ return true;
1889
+ }
1890
+ }
1891
+ }
1892
+ }
1893
+ }
1894
+ return false;
1895
+ }
1896
+ isSameTreeScope(dragScope) {
1897
+ return this.hasCommonScope(dragScope, this.draggableScope());
1898
+ }
1899
+ isValidDragScope(dragScope) {
1900
+ let dropScope = this.droppableScope();
1901
+ if (dropScope) {
1902
+ return this.hasCommonScope(dragScope, dropScope);
1903
+ }
1904
+ else {
1905
+ return true;
1906
+ }
1907
+ }
1908
+ _filter(value) {
1909
+ let filterValue = value;
1910
+ if (filterValue === '') {
1911
+ this.filteredNodes = null;
1912
+ }
1913
+ else {
1914
+ this.filteredNodes = [];
1915
+ const searchFields = this.filterBy().split(',');
1916
+ const filterText = removeAccents(filterValue).toLocaleLowerCase(this.filterLocale());
1917
+ const isStrictMode = this.filterMode() === 'strict';
1918
+ for (let node of this.value()) {
1919
+ let copyNode = { ...node };
1920
+ let paramsWithoutNode = { searchFields, filterText, isStrictMode };
1921
+ if ((isStrictMode && (this.findFilteredNodes(copyNode, paramsWithoutNode) || this.isFilterMatched(copyNode, paramsWithoutNode))) ||
1922
+ (!isStrictMode && (this.isFilterMatched(copyNode, paramsWithoutNode) || this.findFilteredNodes(copyNode, paramsWithoutNode)))) {
1923
+ this.filteredNodes.push(copyNode);
1924
+ }
1925
+ }
1926
+ }
1927
+ this.updateSerializedValue();
1928
+ this.onFilter.emit({
1929
+ filter: filterValue,
1930
+ filteredValue: this.filteredNodes
1931
+ });
1932
+ }
1933
+ /**
1934
+ * Resets filter.
1935
+ * @group Method
1936
+ */
1937
+ resetFilter() {
1938
+ this.filteredNodes = null;
1939
+ const filterEl = this.filterViewChild();
1940
+ if (filterEl && filterEl.nativeElement) {
1941
+ filterEl.nativeElement.value = '';
1942
+ }
1943
+ }
1944
+ /**
1945
+ * Scrolls to virtual index.
1946
+ * @param {number} number - Index to be scrolled.
1947
+ * @group Method
1948
+ */
1949
+ scrollToVirtualIndex(index) {
1950
+ this.virtualScroll() && this.scroller()?.scrollToIndex(index);
1951
+ }
1952
+ /**
1953
+ * Scrolls to virtual index.
1954
+ * @param {ScrollToOptions} options - Scroll options.
1955
+ * @group Method
1956
+ */
1957
+ scrollTo(options) {
1958
+ if (this.virtualScroll()) {
1959
+ this.scroller()?.scrollTo(options);
1960
+ }
1961
+ else {
1962
+ const wrapper = this.wrapperViewChild();
1963
+ if (wrapper && wrapper.nativeElement) {
1964
+ if (wrapper.nativeElement.scrollTo) {
1965
+ wrapper.nativeElement.scrollTo(options);
1966
+ }
1967
+ else {
1968
+ wrapper.nativeElement.scrollLeft = options.left;
1969
+ wrapper.nativeElement.scrollTop = options.top;
1970
+ }
1971
+ }
1972
+ }
1973
+ }
1974
+ findFilteredNodes(node, paramsWithoutNode) {
1975
+ if (node) {
1976
+ let matched = false;
1977
+ if (node.children) {
1978
+ let childNodes = [...node.children];
1979
+ node.children = [];
1980
+ for (let childNode of childNodes) {
1981
+ let copyChildNode = { ...childNode };
1982
+ if (this.isFilterMatched(copyChildNode, paramsWithoutNode)) {
1983
+ matched = true;
1984
+ node.children.push(copyChildNode);
1985
+ }
1986
+ }
1987
+ }
1988
+ if (matched) {
1989
+ node.expanded = true;
1990
+ return true;
1991
+ }
1992
+ }
1993
+ }
1994
+ isFilterMatched(node, params) {
1995
+ let { searchFields, filterText, isStrictMode } = params;
1996
+ let matched = false;
1997
+ for (let field of searchFields) {
1998
+ let fieldValue = removeAccents(String(resolveFieldData(node, field))).toLocaleLowerCase(this.filterLocale());
1999
+ if (fieldValue.indexOf(filterText) > -1) {
2000
+ matched = true;
2001
+ }
2002
+ }
2003
+ if (!matched || (isStrictMode && !this.isNodeLeaf(node))) {
2004
+ matched = this.findFilteredNodes(node, { searchFields, filterText, isStrictMode }) || matched;
2005
+ }
2006
+ return matched;
2007
+ }
2008
+ getIndex(options, index) {
2009
+ const getItemOptions = options['getItemOptions'];
2010
+ return getItemOptions ? getItemOptions(index).index : index;
2011
+ }
2012
+ getBlockableElement() {
2013
+ return this.el.nativeElement.children[0];
2014
+ }
2015
+ get containerDataP() {
2016
+ return this.cn({
2017
+ loading: this.loading(),
2018
+ scrollable: this.scrollHeight() === 'flex'
2019
+ });
2020
+ }
2021
+ get wrapperDataP() {
2022
+ return this.cn({
2023
+ scrollable: this.scrollHeight() === 'flex'
2024
+ });
2025
+ }
2026
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Tree, deps: [], target: i0.ɵɵFactoryTarget.Component });
2027
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: Tree, isStandalone: true, selector: "p-tree", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, selectionMode: { classPropertyName: "selectionMode", publicName: "selectionMode", isSignal: true, isRequired: false, transformFunction: null }, loadingMode: { classPropertyName: "loadingMode", publicName: "loadingMode", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, collapsedKeys: { classPropertyName: "collapsedKeys", publicName: "collapsedKeys", isSignal: true, isRequired: false, transformFunction: null }, selectionKeys: { classPropertyName: "selectionKeys", publicName: "selectionKeys", isSignal: true, isRequired: false, transformFunction: null }, contextMenu: { classPropertyName: "contextMenu", publicName: "contextMenu", isSignal: true, isRequired: false, transformFunction: null }, contextMenuSelection: { classPropertyName: "contextMenuSelection", publicName: "contextMenuSelection", isSignal: true, isRequired: false, transformFunction: null }, draggableScope: { classPropertyName: "draggableScope", publicName: "draggableScope", isSignal: true, isRequired: false, transformFunction: null }, droppableScope: { classPropertyName: "droppableScope", publicName: "droppableScope", isSignal: true, isRequired: false, transformFunction: null }, draggableNodes: { classPropertyName: "draggableNodes", publicName: "draggableNodes", isSignal: true, isRequired: false, transformFunction: null }, droppableNodes: { classPropertyName: "droppableNodes", publicName: "droppableNodes", isSignal: true, isRequired: false, transformFunction: null }, metaKeySelection: { classPropertyName: "metaKeySelection", publicName: "metaKeySelection", isSignal: true, isRequired: false, transformFunction: null }, propagateSelectionUp: { classPropertyName: "propagateSelectionUp", publicName: "propagateSelectionUp", isSignal: true, isRequired: false, transformFunction: null }, propagateSelectionDown: { classPropertyName: "propagateSelectionDown", publicName: "propagateSelectionDown", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, loadingIcon: { classPropertyName: "loadingIcon", publicName: "loadingIcon", isSignal: true, isRequired: false, transformFunction: null }, emptyMessage: { classPropertyName: "emptyMessage", publicName: "emptyMessage", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "ariaLabel", isSignal: true, isRequired: false, transformFunction: null }, togglerAriaLabel: { classPropertyName: "togglerAriaLabel", publicName: "togglerAriaLabel", isSignal: true, isRequired: false, transformFunction: null }, ariaLabelledBy: { classPropertyName: "ariaLabelledBy", publicName: "ariaLabelledBy", isSignal: true, isRequired: false, transformFunction: null }, validateDrop: { classPropertyName: "validateDrop", publicName: "validateDrop", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: false, transformFunction: null }, filterInputAutoFocus: { classPropertyName: "filterInputAutoFocus", publicName: "filterInputAutoFocus", isSignal: true, isRequired: false, transformFunction: null }, filterBy: { classPropertyName: "filterBy", publicName: "filterBy", isSignal: true, isRequired: false, transformFunction: null }, filterMode: { classPropertyName: "filterMode", publicName: "filterMode", isSignal: true, isRequired: false, transformFunction: null }, filterPlaceholder: { classPropertyName: "filterPlaceholder", publicName: "filterPlaceholder", isSignal: true, isRequired: false, transformFunction: null }, filterLocale: { classPropertyName: "filterLocale", publicName: "filterLocale", isSignal: true, isRequired: false, transformFunction: null }, scrollHeight: { classPropertyName: "scrollHeight", publicName: "scrollHeight", isSignal: true, isRequired: false, transformFunction: null }, lazy: { classPropertyName: "lazy", publicName: "lazy", isSignal: true, isRequired: false, transformFunction: null }, virtualScroll: { classPropertyName: "virtualScroll", publicName: "virtualScroll", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollItemSize: { classPropertyName: "virtualScrollItemSize", publicName: "virtualScrollItemSize", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollOptions: { classPropertyName: "virtualScrollOptions", publicName: "virtualScrollOptions", isSignal: true, isRequired: false, transformFunction: null }, indentation: { classPropertyName: "indentation", publicName: "indentation", isSignal: true, isRequired: false, transformFunction: null }, trackBy: { classPropertyName: "trackBy", publicName: "trackBy", isSignal: true, isRequired: false, transformFunction: null }, highlightOnSelect: { classPropertyName: "highlightOnSelect", publicName: "highlightOnSelect", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange", collapsedKeys: "collapsedKeysChange", selectionKeys: "selectionKeysChange", contextMenuSelection: "contextMenuSelectionChange", onNodeSelect: "onNodeSelect", onNodeUnselect: "onNodeUnselect", onNodeExpand: "onNodeExpand", onNodeCollapse: "onNodeCollapse", onNodeContextMenuSelect: "onNodeContextMenuSelect", onNodeDoubleClick: "onNodeDoubleClick", onNodeDrop: "onNodeDrop", onLazyLoad: "onLazyLoad", onScroll: "onScroll", onScrollIndexChange: "onScrollIndexChange", onFilter: "onFilter" }, host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragenter": "onDragEnter()", "dragleave": "onDragLeave($event)" }, properties: { "class": "cx('root')", "attr.data-p": "containerDataP" } }, providers: [TreeStyle, { provide: TREE_INSTANCE, useExisting: Tree }, { provide: PARENT_INSTANCE, useExisting: Tree }], queries: [{ propertyName: "filterTemplate", first: true, predicate: ["filter"], isSignal: true }, { propertyName: "nodeTemplate", first: true, predicate: ["node"], isSignal: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ["footer"], isSignal: true }, { propertyName: "loaderTemplate", first: true, predicate: ["loader"], isSignal: true }, { propertyName: "emptyTemplate", first: true, predicate: ["empty"], isSignal: true }, { propertyName: "togglerIconTemplate", first: true, predicate: ["togglericon"], isSignal: true }, { propertyName: "checkboxIconTemplate", first: true, predicate: ["checkboxicon"], isSignal: true }, { propertyName: "loadingIconTemplate", first: true, predicate: ["loadingicon"], isSignal: true }, { propertyName: "filterIconTemplate", first: true, predicate: ["filtericon"], isSignal: true }], viewQueries: [{ propertyName: "filterViewChild", first: true, predicate: ["filter"], descendants: true, isSignal: true }, { propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true, isSignal: true }, { propertyName: "wrapperViewChild", first: true, predicate: ["wrapper"], descendants: true, isSignal: true }, { propertyName: "contentViewChild", first: true, predicate: ["content"], descendants: true, isSignal: true }], usesInheritance: true, hostDirectives: [{ directive: i1$1.Bind }], ngImport: i0, template: `
2028
+ @if (showLoadingMask()) {
2029
+ <div [class]="cx('mask')" [pBind]="ptm('mask')" animate.enter="p-overlay-mask-enter-active" animate.leave="p-overlay-mask-leave-active">
2030
+ @if (loadingIcon()) {
2031
+ <i [class]="cn(cx('loadingIcon'), 'pi-spin' + loadingIcon())" [pBind]="ptm('loadingIcon')"></i>
2032
+ }
2033
+ @if (!loadingIcon()) {
2034
+ @if (!loadingIconTemplate()) {
2035
+ <svg data-p-icon="spinner" [class]="cn(cx('loadingIcon'), 'animate-spin')" [pBind]="ptm('loadingIcon')" />
2036
+ }
2037
+ @if (loadingIconTemplate()) {
2038
+ <span [class]="cx('loadingIcon')" [pBind]="ptm('loadingIcon')">
2039
+ <ng-template *ngTemplateOutlet="loadingIconTemplate()!"></ng-template>
2040
+ </span>
2041
+ }
2042
+ }
2043
+ </div>
2044
+ }
2045
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
2046
+ @if (filterTemplate()) {
2047
+ <ng-container *ngTemplateOutlet="filterTemplate()!; context: { $implicit: filterOptions }"></ng-container>
2048
+ } @else {
2049
+ @if (filter()) {
2050
+ <p-iconfield [class]="cx('pcFilterContainer')" [pt]="ptm('pcFilterContainer')" [unstyled]="unstyled()">
2051
+ <input
2052
+ #filter
2053
+ [pAutoFocus]="filterInputAutoFocus()"
2054
+ pInputText
2055
+ type="search"
2056
+ autocomplete="off"
2057
+ [class]="cx('pcFilterInput')"
2058
+ [attr.placeholder]="filterPlaceholder()"
2059
+ (keydown.enter)="$event.preventDefault()"
2060
+ (input)="_filter($event.target?.value)"
2061
+ [pt]="ptm('pcFilterInput')"
2062
+ [unstyled]="unstyled()"
2063
+ />
2064
+ <p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
2065
+ @if (!filterIconTemplate()) {
2066
+ <svg data-p-icon="search" [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')" />
2067
+ }
2068
+ @if (filterIconTemplate()) {
2069
+ <span [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')">
2070
+ <ng-template *ngTemplateOutlet="filterIconTemplate()!"></ng-template>
2071
+ </span>
2072
+ }
2073
+ </p-inputicon>
2074
+ </p-iconfield>
2075
+ }
2076
+ }
2077
+
2078
+ @if (getRootNode()?.length) {
2079
+ @if (virtualScroll()) {
2080
+ <p-scroller
2081
+ #scroller
2082
+ [items]="serializedValue"
2083
+ [tabindex]="-1"
2084
+ [styleClass]="cx('wrapper')"
2085
+ [style]="{ height: scrollerStyleHeight() }"
2086
+ [scrollHeight]="scrollerScrollHeight()"
2087
+ [itemSize]="virtualScrollItemSize()"
2088
+ [lazy]="lazy()"
2089
+ (onScroll)="onScroll.emit($event)"
2090
+ (onScrollIndexChange)="onScrollIndexChange.emit($event)"
2091
+ (onLazyLoad)="onLazyLoad.emit($event)"
2092
+ [options]="virtualScrollOptions()"
2093
+ [pt]="ptm('virtualScroller')"
2094
+ hostName="tree"
2095
+ [attr.data-p]="wrapperDataP"
2096
+ >
2097
+ <ng-template #content let-items let-scrollerOptions="options">
2098
+ @if (items) {
2099
+ <ul
2100
+ #content
2101
+ [class]="cn(cx('rootChildren'), scrollerOptions.contentStyleClass)"
2102
+ [style]="scrollerOptions.contentStyle"
2103
+ role="tree"
2104
+ [attr.aria-label]="ariaLabel()"
2105
+ [attr.aria-labelledby]="ariaLabelledBy()"
2106
+ [pBind]="ptm('rootChildren')"
2107
+ >
2108
+ @for (rowNode of items; track trackBy()($index, rowNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
2109
+ <p-treenode
2110
+ #treeNode
2111
+ [level]="rowNode.level"
2112
+ [rowNode]="rowNode"
2113
+ [node]="rowNode.node"
2114
+ [parentNode]="rowNode.parent"
2115
+ [firstChild]="firstChild"
2116
+ [lastChild]="lastChild"
2117
+ [index]="getIndex(scrollerOptions, idx)"
2118
+ [itemSize]="scrollerOptions.itemSize"
2119
+ [indentation]="indentation()"
2120
+ [loadingMode]="loadingMode()"
2121
+ [pt]="pt"
2122
+ [unstyled]="unstyled()"
2123
+ />
2124
+ }
2125
+ </ul>
2126
+ }
2127
+ </ng-template>
2128
+ @if (loaderTemplate()) {
2129
+ <ng-template #loader let-scrollerOptions="options">
2130
+ <ng-container *ngTemplateOutlet="loaderTemplate()!; context: { options: scrollerOptions }"></ng-container>
2131
+ </ng-template>
2132
+ }
2133
+ </p-scroller>
2134
+ }
2135
+ @if (!virtualScroll()) {
2136
+ <div #wrapper [class]="cx('wrapper')" [style.max-height]="scrollHeight()" [pBind]="ptm('wrapper')" [attr.data-p]="wrapperDataP">
2137
+ @if (getRootNode()) {
2138
+ <ul #content [class]="cx('rootChildren')" role="tree" [attr.aria-label]="ariaLabel()" [attr.aria-labelledby]="ariaLabelledBy()" [pBind]="ptm('rootChildren')">
2139
+ @for (node of getRootNode(); track trackBy().bind(this)($index, node); let firstChild = $first; let lastChild = $last; let idx = $index) {
2140
+ <p-treenode [node]="node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="idx" [level]="0" [loadingMode]="loadingMode()" [pt]="pt" [unstyled]="unstyled()" />
2141
+ }
2142
+ </ul>
2143
+ }
2144
+ </div>
2145
+ }
2146
+ }
2147
+
2148
+ @if (showEmptyMessage) {
2149
+ <div [class]="cx('emptyMessage')" [pBind]="ptm('emptyMessage')">
2150
+ @if (!emptyTemplate()) {
2151
+ {{ emptyMessageLabel }}
2152
+ }
2153
+ @if (emptyTemplate()) {
2154
+ <ng-template *ngTemplateOutlet="emptyTemplate()!"></ng-template>
2155
+ }
2156
+ </div>
2157
+ }
2158
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
2159
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: Scroller, selector: "p-scroller, p-virtualscroller, p-virtual-scroller", inputs: ["hostName", "id", "style", "styleClass", "tabindex", "items", "itemSize", "scrollHeight", "scrollWidth", "orientation", "step", "delay", "resizeDelay", "appendOnly", "inline", "lazy", "disabled", "loaderDisabled", "columns", "showSpacer", "showLoader", "numToleratedItems", "loading", "autoSize", "trackBy", "options"], outputs: ["onLazyLoad", "onScroll", "onScrollIndexChange"] }, { kind: "component", type: Search, selector: "svg[data-p-icon=\"search\"]" }, { kind: "component", type: Spinner, selector: "svg[data-p-icon=\"spinner\"]" }, { kind: "directive", type: InputText, selector: "[pInputText]", inputs: ["hostName", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: IconField, selector: "p-iconfield, p-icon-field", inputs: ["hostName", "iconPosition"] }, { kind: "component", type: InputIcon, selector: "p-inputicon", inputs: ["hostName"] }, { kind: "component", type: UITreeNode, selector: "p-treenode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation", "itemSize", "loadingMode"] }, { kind: "ngmodule", type: AutoFocusModule }, { kind: "directive", type: i2.AutoFocus, selector: "[pAutoFocus]", inputs: ["pAutoFocus"] }, { kind: "directive", type: Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
2160
+ }
2161
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Tree, decorators: [{
2162
+ type: Component,
2163
+ args: [{
2164
+ selector: 'p-tree',
2165
+ standalone: true,
2166
+ imports: [NgTemplateOutlet, Scroller, Search, Spinner, InputText, IconField, InputIcon, UITreeNode, AutoFocusModule, Bind],
2167
+ template: `
2168
+ @if (showLoadingMask()) {
2169
+ <div [class]="cx('mask')" [pBind]="ptm('mask')" animate.enter="p-overlay-mask-enter-active" animate.leave="p-overlay-mask-leave-active">
2170
+ @if (loadingIcon()) {
2171
+ <i [class]="cn(cx('loadingIcon'), 'pi-spin' + loadingIcon())" [pBind]="ptm('loadingIcon')"></i>
2172
+ }
2173
+ @if (!loadingIcon()) {
2174
+ @if (!loadingIconTemplate()) {
2175
+ <svg data-p-icon="spinner" [class]="cn(cx('loadingIcon'), 'animate-spin')" [pBind]="ptm('loadingIcon')" />
2176
+ }
2177
+ @if (loadingIconTemplate()) {
2178
+ <span [class]="cx('loadingIcon')" [pBind]="ptm('loadingIcon')">
2179
+ <ng-template *ngTemplateOutlet="loadingIconTemplate()!"></ng-template>
2180
+ </span>
2181
+ }
2182
+ }
2183
+ </div>
2184
+ }
2185
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
2186
+ @if (filterTemplate()) {
2187
+ <ng-container *ngTemplateOutlet="filterTemplate()!; context: { $implicit: filterOptions }"></ng-container>
2188
+ } @else {
2189
+ @if (filter()) {
2190
+ <p-iconfield [class]="cx('pcFilterContainer')" [pt]="ptm('pcFilterContainer')" [unstyled]="unstyled()">
2191
+ <input
2192
+ #filter
2193
+ [pAutoFocus]="filterInputAutoFocus()"
2194
+ pInputText
2195
+ type="search"
2196
+ autocomplete="off"
2197
+ [class]="cx('pcFilterInput')"
2198
+ [attr.placeholder]="filterPlaceholder()"
2199
+ (keydown.enter)="$event.preventDefault()"
2200
+ (input)="_filter($event.target?.value)"
2201
+ [pt]="ptm('pcFilterInput')"
2202
+ [unstyled]="unstyled()"
2203
+ />
2204
+ <p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
2205
+ @if (!filterIconTemplate()) {
2206
+ <svg data-p-icon="search" [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')" />
2207
+ }
2208
+ @if (filterIconTemplate()) {
2209
+ <span [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')">
2210
+ <ng-template *ngTemplateOutlet="filterIconTemplate()!"></ng-template>
2211
+ </span>
2212
+ }
2213
+ </p-inputicon>
2214
+ </p-iconfield>
2215
+ }
2216
+ }
2217
+
2218
+ @if (getRootNode()?.length) {
2219
+ @if (virtualScroll()) {
2220
+ <p-scroller
2221
+ #scroller
2222
+ [items]="serializedValue"
2223
+ [tabindex]="-1"
2224
+ [styleClass]="cx('wrapper')"
2225
+ [style]="{ height: scrollerStyleHeight() }"
2226
+ [scrollHeight]="scrollerScrollHeight()"
2227
+ [itemSize]="virtualScrollItemSize()"
2228
+ [lazy]="lazy()"
2229
+ (onScroll)="onScroll.emit($event)"
2230
+ (onScrollIndexChange)="onScrollIndexChange.emit($event)"
2231
+ (onLazyLoad)="onLazyLoad.emit($event)"
2232
+ [options]="virtualScrollOptions()"
2233
+ [pt]="ptm('virtualScroller')"
2234
+ hostName="tree"
2235
+ [attr.data-p]="wrapperDataP"
2236
+ >
2237
+ <ng-template #content let-items let-scrollerOptions="options">
2238
+ @if (items) {
2239
+ <ul
2240
+ #content
2241
+ [class]="cn(cx('rootChildren'), scrollerOptions.contentStyleClass)"
2242
+ [style]="scrollerOptions.contentStyle"
2243
+ role="tree"
2244
+ [attr.aria-label]="ariaLabel()"
2245
+ [attr.aria-labelledby]="ariaLabelledBy()"
2246
+ [pBind]="ptm('rootChildren')"
2247
+ >
2248
+ @for (rowNode of items; track trackBy()($index, rowNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
2249
+ <p-treenode
2250
+ #treeNode
2251
+ [level]="rowNode.level"
2252
+ [rowNode]="rowNode"
2253
+ [node]="rowNode.node"
2254
+ [parentNode]="rowNode.parent"
2255
+ [firstChild]="firstChild"
2256
+ [lastChild]="lastChild"
2257
+ [index]="getIndex(scrollerOptions, idx)"
2258
+ [itemSize]="scrollerOptions.itemSize"
2259
+ [indentation]="indentation()"
2260
+ [loadingMode]="loadingMode()"
2261
+ [pt]="pt"
2262
+ [unstyled]="unstyled()"
2263
+ />
2264
+ }
2265
+ </ul>
2266
+ }
2267
+ </ng-template>
2268
+ @if (loaderTemplate()) {
2269
+ <ng-template #loader let-scrollerOptions="options">
2270
+ <ng-container *ngTemplateOutlet="loaderTemplate()!; context: { options: scrollerOptions }"></ng-container>
2271
+ </ng-template>
2272
+ }
2273
+ </p-scroller>
2274
+ }
2275
+ @if (!virtualScroll()) {
2276
+ <div #wrapper [class]="cx('wrapper')" [style.max-height]="scrollHeight()" [pBind]="ptm('wrapper')" [attr.data-p]="wrapperDataP">
2277
+ @if (getRootNode()) {
2278
+ <ul #content [class]="cx('rootChildren')" role="tree" [attr.aria-label]="ariaLabel()" [attr.aria-labelledby]="ariaLabelledBy()" [pBind]="ptm('rootChildren')">
2279
+ @for (node of getRootNode(); track trackBy().bind(this)($index, node); let firstChild = $first; let lastChild = $last; let idx = $index) {
2280
+ <p-treenode [node]="node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="idx" [level]="0" [loadingMode]="loadingMode()" [pt]="pt" [unstyled]="unstyled()" />
2281
+ }
2282
+ </ul>
2283
+ }
2284
+ </div>
2285
+ }
2286
+ }
2287
+
2288
+ @if (showEmptyMessage) {
2289
+ <div [class]="cx('emptyMessage')" [pBind]="ptm('emptyMessage')">
2290
+ @if (!emptyTemplate()) {
2291
+ {{ emptyMessageLabel }}
2292
+ }
2293
+ @if (emptyTemplate()) {
2294
+ <ng-template *ngTemplateOutlet="emptyTemplate()!"></ng-template>
2295
+ }
2296
+ </div>
2297
+ }
2298
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
2299
+ `,
2300
+ changeDetection: ChangeDetectionStrategy.OnPush,
2301
+ encapsulation: ViewEncapsulation.None,
2302
+ providers: [TreeStyle, { provide: TREE_INSTANCE, useExisting: Tree }, { provide: PARENT_INSTANCE, useExisting: Tree }],
2303
+ host: {
2304
+ '[class]': "cx('root')",
2305
+ '[attr.data-p]': 'containerDataP',
2306
+ '(drop)': 'onDrop($event)',
2307
+ '(dragover)': 'onDragOver($event)',
2308
+ '(dragenter)': 'onDragEnter()',
2309
+ '(dragleave)': 'onDragLeave($event)'
2310
+ },
2311
+ hostDirectives: [Bind]
2312
+ }]
2313
+ }], ctorParameters: () => [], propDecorators: { value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }], selectionMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectionMode", required: false }] }], loadingMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingMode", required: false }] }], selection: [{ type: i0.Input, args: [{ isSignal: true, alias: "selection", required: false }] }, { type: i0.Output, args: ["selectionChange"] }], collapsedKeys: [{ type: i0.Input, args: [{ isSignal: true, alias: "collapsedKeys", required: false }] }, { type: i0.Output, args: ["collapsedKeysChange"] }], selectionKeys: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectionKeys", required: false }] }, { type: i0.Output, args: ["selectionKeysChange"] }], contextMenu: [{ type: i0.Input, args: [{ isSignal: true, alias: "contextMenu", required: false }] }], contextMenuSelection: [{ type: i0.Input, args: [{ isSignal: true, alias: "contextMenuSelection", required: false }] }, { type: i0.Output, args: ["contextMenuSelectionChange"] }], draggableScope: [{ type: i0.Input, args: [{ isSignal: true, alias: "draggableScope", required: false }] }], droppableScope: [{ type: i0.Input, args: [{ isSignal: true, alias: "droppableScope", required: false }] }], draggableNodes: [{ type: i0.Input, args: [{ isSignal: true, alias: "draggableNodes", required: false }] }], droppableNodes: [{ type: i0.Input, args: [{ isSignal: true, alias: "droppableNodes", required: false }] }], metaKeySelection: [{ type: i0.Input, args: [{ isSignal: true, alias: "metaKeySelection", required: false }] }], propagateSelectionUp: [{ type: i0.Input, args: [{ isSignal: true, alias: "propagateSelectionUp", required: false }] }], propagateSelectionDown: [{ type: i0.Input, args: [{ isSignal: true, alias: "propagateSelectionDown", required: false }] }], loading: [{ type: i0.Input, args: [{ isSignal: true, alias: "loading", required: false }] }], loadingIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingIcon", required: false }] }], emptyMessage: [{ type: i0.Input, args: [{ isSignal: true, alias: "emptyMessage", required: false }] }], ariaLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabel", required: false }] }], togglerAriaLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "togglerAriaLabel", required: false }] }], ariaLabelledBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabelledBy", required: false }] }], validateDrop: [{ type: i0.Input, args: [{ isSignal: true, alias: "validateDrop", required: false }] }], filter: [{ type: i0.Input, args: [{ isSignal: true, alias: "filter", required: false }] }], filterInputAutoFocus: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterInputAutoFocus", required: false }] }], filterBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterBy", required: false }] }], filterMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterMode", required: false }] }], filterPlaceholder: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterPlaceholder", required: false }] }], filterLocale: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterLocale", required: false }] }], scrollHeight: [{ type: i0.Input, args: [{ isSignal: true, alias: "scrollHeight", required: false }] }], lazy: [{ type: i0.Input, args: [{ isSignal: true, alias: "lazy", required: false }] }], virtualScroll: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScroll", required: false }] }], virtualScrollItemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollItemSize", required: false }] }], virtualScrollOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollOptions", required: false }] }], indentation: [{ type: i0.Input, args: [{ isSignal: true, alias: "indentation", required: false }] }], trackBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "trackBy", required: false }] }], highlightOnSelect: [{ type: i0.Input, args: [{ isSignal: true, alias: "highlightOnSelect", required: false }] }], onNodeSelect: [{ type: i0.Output, args: ["onNodeSelect"] }], onNodeUnselect: [{ type: i0.Output, args: ["onNodeUnselect"] }], onNodeExpand: [{ type: i0.Output, args: ["onNodeExpand"] }], onNodeCollapse: [{ type: i0.Output, args: ["onNodeCollapse"] }], onNodeContextMenuSelect: [{ type: i0.Output, args: ["onNodeContextMenuSelect"] }], onNodeDoubleClick: [{ type: i0.Output, args: ["onNodeDoubleClick"] }], onNodeDrop: [{ type: i0.Output, args: ["onNodeDrop"] }], onLazyLoad: [{ type: i0.Output, args: ["onLazyLoad"] }], onScroll: [{ type: i0.Output, args: ["onScroll"] }], onScrollIndexChange: [{ type: i0.Output, args: ["onScrollIndexChange"] }], onFilter: [{ type: i0.Output, args: ["onFilter"] }], filterTemplate: [{ type: i0.ContentChild, args: ['filter', { ...{ descendants: false }, isSignal: true }] }], nodeTemplate: [{ type: i0.ContentChild, args: ['node', { ...{ descendants: false }, isSignal: true }] }], headerTemplate: [{ type: i0.ContentChild, args: ['header', { ...{ descendants: false }, isSignal: true }] }], footerTemplate: [{ type: i0.ContentChild, args: ['footer', { ...{ descendants: false }, isSignal: true }] }], loaderTemplate: [{ type: i0.ContentChild, args: ['loader', { ...{ descendants: false }, isSignal: true }] }], emptyTemplate: [{ type: i0.ContentChild, args: ['empty', { ...{ descendants: false }, isSignal: true }] }], togglerIconTemplate: [{ type: i0.ContentChild, args: ['togglericon', { ...{ descendants: false }, isSignal: true }] }], checkboxIconTemplate: [{ type: i0.ContentChild, args: ['checkboxicon', { ...{ descendants: false }, isSignal: true }] }], loadingIconTemplate: [{ type: i0.ContentChild, args: ['loadingicon', { ...{ descendants: false }, isSignal: true }] }], filterIconTemplate: [{ type: i0.ContentChild, args: ['filtericon', { ...{ descendants: false }, isSignal: true }] }], filterViewChild: [{ type: i0.ViewChild, args: ['filter', { isSignal: true }] }], scroller: [{ type: i0.ViewChild, args: ['scroller', { isSignal: true }] }], wrapperViewChild: [{ type: i0.ViewChild, args: ['wrapper', { isSignal: true }] }], contentViewChild: [{ type: i0.ViewChild, args: ['content', { isSignal: true }] }] } });
2314
+ class TreeModule {
2315
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2316
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, imports: [Tree], exports: [Tree] });
2317
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, imports: [Tree] });
2318
+ }
2319
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, decorators: [{
2320
+ type: NgModule,
2321
+ args: [{
2322
+ imports: [Tree],
2323
+ exports: [Tree]
2324
+ }]
2325
+ }] });
2326
+
2327
+ /**
2328
+ * Generated bundle index. Do not edit.
2329
+ */
2330
+
2331
+ export { Tree, TreeClasses, TreeModule, TreeStyle };
2332
+ //# sourceMappingURL=primenglab-tree.mjs.map