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,2543 @@
1
+ export * from 'primenglab/types/multiselect';
2
+ import { NgTemplateOutlet } from '@angular/common';
3
+ import * as i0 from '@angular/core';
4
+ import { InjectionToken, Injectable, inject, input, booleanAttribute, numberAttribute, output, computed, ViewEncapsulation, Component, forwardRef, model, viewChild, contentChild, signal, effect, untracked, ChangeDetectionStrategy, NgModule } from '@angular/core';
5
+ import { toSignal } from '@angular/core/rxjs-interop';
6
+ import * as i1 from '@angular/forms';
7
+ import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
8
+ import { uuid, isNotEmpty, isArray, deepEquals, equals, focus, findLastIndex, resolveFieldData, isPrintableCharacter, getFirstFocusableElement, getLastFocusableElement, findSingle, getFocusableElements } from '@primeuix/utils';
9
+ import { SharedModule, Footer, Header, FilterService, OverlayService, TranslationKeys } from 'primenglab/api';
10
+ import { AutoFocus } from 'primenglab/autofocus';
11
+ import { BaseComponent, PARENT_INSTANCE } from 'primenglab/basecomponent';
12
+ import { BaseEditableHolder } from 'primenglab/baseeditableholder';
13
+ import * as i1$1 from 'primenglab/bind';
14
+ import { Bind, BindModule } from 'primenglab/bind';
15
+ import { Checkbox } from 'primenglab/checkbox';
16
+ import { Chip } from 'primenglab/chip';
17
+ import { DomHandler, unblockBodyScroll } from 'primenglab/dom';
18
+ import { Fluid } from 'primenglab/fluid';
19
+ import { IconField } from 'primenglab/iconfield';
20
+ import { Check } from '@primeicons/angular/check';
21
+ import { ChevronDown } from '@primeicons/angular/chevron-down';
22
+ import { Search } from '@primeicons/angular/search';
23
+ import { Times } from '@primeicons/angular/times';
24
+ import { InputIcon } from 'primenglab/inputicon';
25
+ import { InputText } from 'primenglab/inputtext';
26
+ import { Overlay } from 'primenglab/overlay';
27
+ import { Scroller } from 'primenglab/scroller';
28
+ import { Tooltip } from 'primenglab/tooltip';
29
+ import { ObjectUtils } from 'primenglab/utils';
30
+ import { style } from '@primeuix/styles/multiselect';
31
+ import { BaseStyle } from 'primenglab/base';
32
+
33
+ const MULTISELECT_INSTANCE = new InjectionToken('MULTISELECT_INSTANCE');
34
+ const MULTISELECT_ITEM_INSTANCE = new InjectionToken('MULTISELECT_ITEM_INSTANCE');
35
+
36
+ const inlineStyles = {
37
+ root: ({ instance }) => ({ position: instance.$appendTo() === 'self' ? 'relative' : undefined })
38
+ };
39
+ const classes = {
40
+ root: ({ instance }) => [
41
+ 'p-multiselect p-component p-inputwrapper',
42
+ {
43
+ 'p-multiselect-display-chip': instance.display() === 'chip',
44
+ 'p-disabled': instance.$disabled(),
45
+ 'p-invalid': instance.invalid(),
46
+ 'p-variant-filled': instance.$variant() === 'filled',
47
+ 'p-focus': instance.focused,
48
+ 'p-inputwrapper-filled': instance.$filled(),
49
+ 'p-inputwrapper-focus': instance.focused || instance.overlayVisible(),
50
+ 'p-multiselect-open': instance.overlayVisible(),
51
+ 'p-multiselect-fluid': instance.hasFluid,
52
+ 'p-multiselect-sm p-inputfield-sm': instance.size() === 'small',
53
+ 'p-multiselect-lg p-inputfield-lg': instance.size() === 'large'
54
+ }
55
+ ],
56
+ labelContainer: 'p-multiselect-label-container',
57
+ label: ({ instance }) => ({
58
+ 'p-multiselect-label': true,
59
+ 'p-placeholder': instance.label() === instance.placeholder(),
60
+ 'p-multiselect-label-empty': !instance.placeholder() && (!instance.modelValue() || instance.modelValue().length === 0)
61
+ }),
62
+ clearIcon: 'p-multiselect-clear-icon',
63
+ chipItem: 'p-multiselect-chip-item',
64
+ pcChip: 'p-multiselect-chip',
65
+ chipIcon: 'p-multiselect-chip-icon',
66
+ dropdown: 'p-multiselect-dropdown',
67
+ loadingIcon: 'p-multiselect-loading-icon',
68
+ dropdownIcon: 'p-multiselect-dropdown-icon',
69
+ overlay: 'p-multiselect-overlay p-component-overlay p-component',
70
+ header: 'p-multiselect-header',
71
+ pcFilterContainer: 'p-multiselect-filter-container',
72
+ pcFilter: 'p-multiselect-filter',
73
+ listContainer: 'p-multiselect-list-container',
74
+ list: 'p-multiselect-list',
75
+ optionGroup: 'p-multiselect-option-group',
76
+ option: ({ instance }) => ({
77
+ 'p-multiselect-option': true,
78
+ 'p-multiselect-option-selected': instance.selected() && instance.highlightOnSelect(),
79
+ 'p-disabled': instance.disabled(),
80
+ 'p-focus': instance.focused()
81
+ }),
82
+ emptyMessage: 'p-multiselect-empty-message'
83
+ };
84
+ class MultiSelectStyle extends BaseStyle {
85
+ name = 'multiselect';
86
+ style = style;
87
+ classes = classes;
88
+ inlineStyles = inlineStyles;
89
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectStyle, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
90
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectStyle });
91
+ }
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectStyle, decorators: [{
93
+ type: Injectable
94
+ }] });
95
+ /**
96
+ *
97
+ * MultiSelect is used to select multiple items from a collection.
98
+ *
99
+ * [Live Demo](https://www.primeng.org/multiselect/)
100
+ *
101
+ * @module multiselectstyle
102
+ *
103
+ */
104
+ var MultiSelectClasses;
105
+ (function (MultiSelectClasses) {
106
+ /**
107
+ * Class name of the root element
108
+ */
109
+ MultiSelectClasses["root"] = "p-multiselect";
110
+ /**
111
+ * Class name of the label container element
112
+ */
113
+ MultiSelectClasses["labelContainer"] = "p-multiselect-label-container";
114
+ /**
115
+ * Class name of the label element
116
+ */
117
+ MultiSelectClasses["label"] = "p-multiselect-label";
118
+ /**
119
+ * Class name of the chip item element
120
+ */
121
+ MultiSelectClasses["chipItem"] = "p-multiselect-chip-item";
122
+ /**
123
+ * Class name of the chip element
124
+ */
125
+ MultiSelectClasses["pcChip"] = "p-multiselect-chip";
126
+ /**
127
+ * Class name of the chip icon element
128
+ */
129
+ MultiSelectClasses["chipIcon"] = "p-multiselect-chip-icon";
130
+ /**
131
+ * Class name of the dropdown element
132
+ */
133
+ MultiSelectClasses["dropdown"] = "p-multiselect-dropdown";
134
+ /**
135
+ * Class name of the loading icon element
136
+ */
137
+ MultiSelectClasses["loadingIcon"] = "p-multiselect-loading-icon";
138
+ /**
139
+ * Class name of the dropdown icon element
140
+ */
141
+ MultiSelectClasses["dropdownIcon"] = "p-multiselect-dropdown-icon";
142
+ /**
143
+ * Class name of the overlay element
144
+ */
145
+ MultiSelectClasses["overlay"] = "p-multiselect-overlay";
146
+ /**
147
+ * Class name of the header element
148
+ */
149
+ MultiSelectClasses["header"] = "p-multiselect-header";
150
+ /**
151
+ * Class name of the filter container element
152
+ */
153
+ MultiSelectClasses["pcFilterContainer"] = "p-multiselect-filter-container";
154
+ /**
155
+ * Class name of the filter element
156
+ */
157
+ MultiSelectClasses["pcFilter"] = "p-multiselect-filter";
158
+ /**
159
+ * Class name of the list container element
160
+ */
161
+ MultiSelectClasses["listContainer"] = "p-multiselect-list-container";
162
+ /**
163
+ * Class name of the list element
164
+ */
165
+ MultiSelectClasses["list"] = "p-multiselect-list";
166
+ /**
167
+ * Class name of the option group element
168
+ */
169
+ MultiSelectClasses["optionGroup"] = "p-multiselect-option-group";
170
+ /**
171
+ * Class name of the option element
172
+ */
173
+ MultiSelectClasses["option"] = "p-multiselect-option";
174
+ /**
175
+ * Class name of the empty message element
176
+ */
177
+ MultiSelectClasses["emptyMessage"] = "p-multiselect-empty-message";
178
+ /**
179
+ * Class name of the clear icon
180
+ */
181
+ MultiSelectClasses["clearIcon"] = "p-autocomplete-clear-icon";
182
+ })(MultiSelectClasses || (MultiSelectClasses = {}));
183
+
184
+ class MultiSelectItem extends BaseComponent {
185
+ $pcMultiSelectItem = inject(MULTISELECT_ITEM_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
186
+ hostName = 'MultiSelect';
187
+ getPTOptions(key) {
188
+ return this.ptm(key, {
189
+ context: {
190
+ selected: this.selected(),
191
+ focused: this.focused(),
192
+ disabled: this.disabled()
193
+ }
194
+ });
195
+ }
196
+ option = input(/* @ts-ignore */
197
+ ...(ngDevMode ? [undefined, { debugName: "option" }] : /* istanbul ignore next */ []));
198
+ selected = input(undefined, { ...(ngDevMode ? { debugName: "selected" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
199
+ label = input(/* @ts-ignore */
200
+ ...(ngDevMode ? [undefined, { debugName: "label" }] : /* istanbul ignore next */ []));
201
+ disabled = input(undefined, { ...(ngDevMode ? { debugName: "disabled" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
202
+ itemSize = input(undefined, { ...(ngDevMode ? { debugName: "itemSize" } : /* istanbul ignore next */ {}), transform: numberAttribute });
203
+ focused = input(undefined, { ...(ngDevMode ? { debugName: "focused" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
204
+ ariaPosInset = input(/* @ts-ignore */
205
+ ...(ngDevMode ? [undefined, { debugName: "ariaPosInset" }] : /* istanbul ignore next */ []));
206
+ ariaSetSize = input(/* @ts-ignore */
207
+ ...(ngDevMode ? [undefined, { debugName: "ariaSetSize" }] : /* istanbul ignore next */ []));
208
+ variant = input(/* @ts-ignore */
209
+ ...(ngDevMode ? [undefined, { debugName: "variant" }] : /* istanbul ignore next */ []));
210
+ template = input(/* @ts-ignore */
211
+ ...(ngDevMode ? [undefined, { debugName: "template" }] : /* istanbul ignore next */ []));
212
+ checkIconTemplate = input(/* @ts-ignore */
213
+ ...(ngDevMode ? [undefined, { debugName: "checkIconTemplate" }] : /* istanbul ignore next */ []));
214
+ itemCheckboxIconTemplate = input(/* @ts-ignore */
215
+ ...(ngDevMode ? [undefined, { debugName: "itemCheckboxIconTemplate" }] : /* istanbul ignore next */ []));
216
+ highlightOnSelect = input(undefined, { ...(ngDevMode ? { debugName: "highlightOnSelect" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
217
+ onClick = output();
218
+ onMouseEnter = output();
219
+ _componentStyle = inject(MultiSelectStyle);
220
+ templateContext = computed(() => ({ $implicit: this.option() }), /* @ts-ignore */
221
+ ...(ngDevMode ? [{ debugName: "templateContext" }] : /* istanbul ignore next */ []));
222
+ getCheckboxIconContext(klass) {
223
+ return { checked: this.selected(), class: klass };
224
+ }
225
+ onOptionClick(event) {
226
+ this.onClick.emit({
227
+ originalEvent: event,
228
+ option: this.option(),
229
+ selected: this.selected() ?? false
230
+ });
231
+ event.stopPropagation();
232
+ event.preventDefault();
233
+ }
234
+ onOptionMouseEnter(event) {
235
+ this.onMouseEnter.emit({
236
+ originalEvent: event,
237
+ option: this.option(),
238
+ selected: this.selected() ?? false
239
+ });
240
+ }
241
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectItem, deps: null, target: i0.ɵɵFactoryTarget.Component });
242
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: MultiSelectItem, isStandalone: true, selector: "li[pMultiSelectItem]", inputs: { option: { classPropertyName: "option", publicName: "option", isSignal: true, isRequired: false, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, itemSize: { classPropertyName: "itemSize", publicName: "itemSize", isSignal: true, isRequired: false, transformFunction: null }, focused: { classPropertyName: "focused", publicName: "focused", isSignal: true, isRequired: false, transformFunction: null }, ariaPosInset: { classPropertyName: "ariaPosInset", publicName: "ariaPosInset", isSignal: true, isRequired: false, transformFunction: null }, ariaSetSize: { classPropertyName: "ariaSetSize", publicName: "ariaSetSize", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null }, checkIconTemplate: { classPropertyName: "checkIconTemplate", publicName: "checkIconTemplate", isSignal: true, isRequired: false, transformFunction: null }, itemCheckboxIconTemplate: { classPropertyName: "itemCheckboxIconTemplate", publicName: "itemCheckboxIconTemplate", isSignal: true, isRequired: false, transformFunction: null }, highlightOnSelect: { classPropertyName: "highlightOnSelect", publicName: "highlightOnSelect", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onClick: "onClick", onMouseEnter: "onMouseEnter" }, host: { attributes: { "role": "option" }, listeners: { "click": "onOptionClick($event)", "mouseenter": "onOptionMouseEnter($event)" }, properties: { "style.height.px": "itemSize()", "attr.aria-label": "label()", "attr.aria-setsize": "ariaSetSize()", "attr.aria-posinset": "ariaPosInset()", "attr.aria-selected": "selected()", "attr.data-p-selected": "selected()", "attr.data-p-focused": "focused()", "attr.data-p-highlight": "selected()", "attr.data-p-disabled": "disabled()", "attr.aria-checked": "selected()", "class": "cx('option')" } }, providers: [MultiSelectStyle], usesInheritance: true, ngImport: i0, template: `
243
+ <p-checkbox [disabled]="disabled() ?? false" [ngModel]="selected()" [binary]="true" [tabindex]="-1" [variant]="variant()" [ariaLabel]="label()" [pt]="getPTOptions('pcOptionCheckbox')" [unstyled]="unstyled()">
244
+ @if (itemCheckboxIconTemplate()) {
245
+ <ng-template #icon let-klass="class">
246
+ <ng-container *ngTemplateOutlet="itemCheckboxIconTemplate(); context: getCheckboxIconContext(klass)"></ng-container>
247
+ </ng-template>
248
+ }
249
+ </p-checkbox>
250
+ @if (!template()) {
251
+ <span>{{ label() ?? 'empty' }}</span>
252
+ }
253
+ <ng-container *ngTemplateOutlet="template(); context: templateContext()"></ng-container>
254
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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: "ngmodule", type: SharedModule }], encapsulation: i0.ViewEncapsulation.None });
255
+ }
256
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectItem, decorators: [{
257
+ type: Component,
258
+ args: [{
259
+ selector: 'li[pMultiSelectItem]',
260
+ standalone: true,
261
+ imports: [NgTemplateOutlet, Checkbox, FormsModule, SharedModule],
262
+ template: `
263
+ <p-checkbox [disabled]="disabled() ?? false" [ngModel]="selected()" [binary]="true" [tabindex]="-1" [variant]="variant()" [ariaLabel]="label()" [pt]="getPTOptions('pcOptionCheckbox')" [unstyled]="unstyled()">
264
+ @if (itemCheckboxIconTemplate()) {
265
+ <ng-template #icon let-klass="class">
266
+ <ng-container *ngTemplateOutlet="itemCheckboxIconTemplate(); context: getCheckboxIconContext(klass)"></ng-container>
267
+ </ng-template>
268
+ }
269
+ </p-checkbox>
270
+ @if (!template()) {
271
+ <span>{{ label() ?? 'empty' }}</span>
272
+ }
273
+ <ng-container *ngTemplateOutlet="template(); context: templateContext()"></ng-container>
274
+ `,
275
+ encapsulation: ViewEncapsulation.None,
276
+ providers: [MultiSelectStyle],
277
+ host: {
278
+ '[style.height.px]': 'itemSize()',
279
+ '[attr.aria-label]': 'label()',
280
+ role: 'option',
281
+ '[attr.aria-setsize]': 'ariaSetSize()',
282
+ '[attr.aria-posinset]': 'ariaPosInset()',
283
+ '[attr.aria-selected]': 'selected()',
284
+ '[attr.data-p-selected]': 'selected()',
285
+ '[attr.data-p-focused]': 'focused()',
286
+ '[attr.data-p-highlight]': 'selected()',
287
+ '[attr.data-p-disabled]': 'disabled()',
288
+ '[attr.aria-checked]': 'selected()',
289
+ '(click)': 'onOptionClick($event)',
290
+ '(mouseenter)': 'onOptionMouseEnter($event)',
291
+ '[class]': "cx('option')"
292
+ }
293
+ }]
294
+ }], propDecorators: { option: [{ type: i0.Input, args: [{ isSignal: true, alias: "option", required: false }] }], selected: [{ type: i0.Input, args: [{ isSignal: true, alias: "selected", required: false }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }], itemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "itemSize", required: false }] }], focused: [{ type: i0.Input, args: [{ isSignal: true, alias: "focused", required: false }] }], ariaPosInset: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaPosInset", required: false }] }], ariaSetSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaSetSize", required: false }] }], variant: [{ type: i0.Input, args: [{ isSignal: true, alias: "variant", required: false }] }], template: [{ type: i0.Input, args: [{ isSignal: true, alias: "template", required: false }] }], checkIconTemplate: [{ type: i0.Input, args: [{ isSignal: true, alias: "checkIconTemplate", required: false }] }], itemCheckboxIconTemplate: [{ type: i0.Input, args: [{ isSignal: true, alias: "itemCheckboxIconTemplate", required: false }] }], highlightOnSelect: [{ type: i0.Input, args: [{ isSignal: true, alias: "highlightOnSelect", required: false }] }], onClick: [{ type: i0.Output, args: ["onClick"] }], onMouseEnter: [{ type: i0.Output, args: ["onMouseEnter"] }] } });
295
+
296
+ const MULTISELECT_VALUE_ACCESSOR = {
297
+ provide: NG_VALUE_ACCESSOR,
298
+ useExisting: forwardRef(() => MultiSelect),
299
+ multi: true
300
+ };
301
+ /**
302
+ * MultiSelect is used to select multiple items from a collection.
303
+ * @group Components
304
+ * @deprecated Use Select component with `multiple` property instead.
305
+ */
306
+ class MultiSelect extends BaseEditableHolder {
307
+ componentName = 'MultiSelect';
308
+ /**
309
+ * Unique identifier of the component
310
+ * @group Props
311
+ */
312
+ id = input(/* @ts-ignore */
313
+ ...(ngDevMode ? [undefined, { debugName: "id" }] : /* istanbul ignore next */ []));
314
+ /**
315
+ * Defines a string that labels the input for accessibility.
316
+ * @group Props
317
+ */
318
+ ariaLabel = input(/* @ts-ignore */
319
+ ...(ngDevMode ? [undefined, { debugName: "ariaLabel" }] : /* istanbul ignore next */ []));
320
+ /**
321
+ * Inline style of the overlay panel.
322
+ * @group Props
323
+ */
324
+ panelStyle = input(/* @ts-ignore */
325
+ ...(ngDevMode ? [undefined, { debugName: "panelStyle" }] : /* istanbul ignore next */ []));
326
+ /**
327
+ * Style class of the overlay panel element.
328
+ * @group Props
329
+ */
330
+ panelStyleClass = input(/* @ts-ignore */
331
+ ...(ngDevMode ? [undefined, { debugName: "panelStyleClass" }] : /* istanbul ignore next */ []));
332
+ /**
333
+ * Identifier of the focus input to match a label defined for the component.
334
+ * @group Props
335
+ */
336
+ inputId = input(/* @ts-ignore */
337
+ ...(ngDevMode ? [undefined, { debugName: "inputId" }] : /* istanbul ignore next */ []));
338
+ /**
339
+ * When present, it specifies that the component cannot be edited.
340
+ * @group Props
341
+ */
342
+ readonly = input(undefined, { ...(ngDevMode ? { debugName: "readonly" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
343
+ /**
344
+ * Whether to display options as grouped when nested options are provided.
345
+ * @group Props
346
+ */
347
+ group = input(undefined, { ...(ngDevMode ? { debugName: "group" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
348
+ /**
349
+ * When specified, displays an input field to filter the items on keyup.
350
+ * @group Props
351
+ */
352
+ filter = input(true, { ...(ngDevMode ? { debugName: "filter" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
353
+ /**
354
+ * Defines placeholder of the filter input.
355
+ * @group Props
356
+ */
357
+ filterPlaceHolder = input(/* @ts-ignore */
358
+ ...(ngDevMode ? [undefined, { debugName: "filterPlaceHolder" }] : /* istanbul ignore next */ []));
359
+ /**
360
+ * Locale to use in filtering. The default locale is the host environment's current locale.
361
+ * @group Props
362
+ */
363
+ filterLocale = input(/* @ts-ignore */
364
+ ...(ngDevMode ? [undefined, { debugName: "filterLocale" }] : /* istanbul ignore next */ []));
365
+ /**
366
+ * Specifies the visibility of the options panel.
367
+ * @group Props
368
+ */
369
+ overlayVisible = model(false, /* @ts-ignore */
370
+ ...(ngDevMode ? [{ debugName: "overlayVisible" }] : /* istanbul ignore next */ []));
371
+ /**
372
+ * Index of the element in tabbing order.
373
+ * @group Props
374
+ */
375
+ tabindex = input(0, { ...(ngDevMode ? { debugName: "tabindex" } : /* istanbul ignore next */ {}), transform: numberAttribute });
376
+ /**
377
+ * A property to uniquely identify a value in options.
378
+ * @group Props
379
+ */
380
+ dataKey = input(/* @ts-ignore */
381
+ ...(ngDevMode ? [undefined, { debugName: "dataKey" }] : /* istanbul ignore next */ []));
382
+ /**
383
+ * Establishes relationships between the component and label(s) where its value should be one or more element IDs.
384
+ * @group Props
385
+ */
386
+ ariaLabelledBy = input(/* @ts-ignore */
387
+ ...(ngDevMode ? [undefined, { debugName: "ariaLabelledBy" }] : /* istanbul ignore next */ []));
388
+ /**
389
+ * Whether to show labels of selected item labels or use default label.
390
+ * @group Props
391
+ * @defaultValue true
392
+ */
393
+ displaySelectedLabel = input(true, { ...(ngDevMode ? { debugName: "displaySelectedLabel" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
394
+ /**
395
+ * Decides how many selected item labels to show at most.
396
+ * @group Props
397
+ * @defaultValue 3
398
+ */
399
+ maxSelectedLabels = input(3, /* @ts-ignore */
400
+ ...(ngDevMode ? [{ debugName: "maxSelectedLabels" }] : /* istanbul ignore next */ []));
401
+ /**
402
+ * Maximum number of selectable items.
403
+ * @group Props
404
+ */
405
+ selectionLimit = input(undefined, { ...(ngDevMode ? { debugName: "selectionLimit" } : /* istanbul ignore next */ {}), transform: numberAttribute });
406
+ /**
407
+ * Label to display after exceeding max selected labels e.g. ({0} items selected), defaults "ellipsis" keyword to indicate a text-overflow.
408
+ * @group Props
409
+ */
410
+ selectedItemsLabel = input(/* @ts-ignore */
411
+ ...(ngDevMode ? [undefined, { debugName: "selectedItemsLabel" }] : /* istanbul ignore next */ []));
412
+ /**
413
+ * Whether to show the checkbox at header to toggle all items at once.
414
+ * @group Props
415
+ */
416
+ showToggleAll = input(true, { ...(ngDevMode ? { debugName: "showToggleAll" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
417
+ /**
418
+ * Text to display when filtering does not return any results.
419
+ * @group Props
420
+ */
421
+ emptyFilterMessage = input('', /* @ts-ignore */
422
+ ...(ngDevMode ? [{ debugName: "emptyFilterMessage" }] : /* istanbul ignore next */ []));
423
+ /**
424
+ * Text to display when there is no data. Defaults to global value in i18n translation configuration.
425
+ * @group Props
426
+ */
427
+ emptyMessage = input('', /* @ts-ignore */
428
+ ...(ngDevMode ? [{ debugName: "emptyMessage" }] : /* istanbul ignore next */ []));
429
+ /**
430
+ * Clears the filter value when hiding the dropdown.
431
+ * @group Props
432
+ */
433
+ resetFilterOnHide = input(false, { ...(ngDevMode ? { debugName: "resetFilterOnHide" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
434
+ /**
435
+ * Icon class of the dropdown icon.
436
+ * @group Props
437
+ */
438
+ dropdownIcon = input(/* @ts-ignore */
439
+ ...(ngDevMode ? [undefined, { debugName: "dropdownIcon" }] : /* istanbul ignore next */ []));
440
+ /**
441
+ * Icon class of the chip icon.
442
+ * @group Props
443
+ */
444
+ chipIcon = input(/* @ts-ignore */
445
+ ...(ngDevMode ? [undefined, { debugName: "chipIcon" }] : /* istanbul ignore next */ []));
446
+ /**
447
+ * Name of the label field of an option.
448
+ * @group Props
449
+ */
450
+ optionLabel = input(/* @ts-ignore */
451
+ ...(ngDevMode ? [undefined, { debugName: "optionLabel" }] : /* istanbul ignore next */ []));
452
+ /**
453
+ * Name of the value field of an option.
454
+ * @group Props
455
+ */
456
+ optionValue = input(/* @ts-ignore */
457
+ ...(ngDevMode ? [undefined, { debugName: "optionValue" }] : /* istanbul ignore next */ []));
458
+ /**
459
+ * Name of the disabled field of an option.
460
+ * @group Props
461
+ */
462
+ optionDisabled = input(/* @ts-ignore */
463
+ ...(ngDevMode ? [undefined, { debugName: "optionDisabled" }] : /* istanbul ignore next */ []));
464
+ /**
465
+ * Name of the label field of an option group.
466
+ * @group Props
467
+ */
468
+ optionGroupLabel = input('label', /* @ts-ignore */
469
+ ...(ngDevMode ? [{ debugName: "optionGroupLabel" }] : /* istanbul ignore next */ []));
470
+ /**
471
+ * Name of the options field of an option group.
472
+ * @group Props
473
+ */
474
+ optionGroupChildren = input('items', /* @ts-ignore */
475
+ ...(ngDevMode ? [{ debugName: "optionGroupChildren" }] : /* istanbul ignore next */ []));
476
+ /**
477
+ * Whether to show the header.
478
+ * @group Props
479
+ */
480
+ showHeader = input(true, { ...(ngDevMode ? { debugName: "showHeader" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
481
+ /**
482
+ * When filtering is enabled, filterBy decides which field or fields (comma separated) to search against.
483
+ * @group Props
484
+ */
485
+ filterBy = input(/* @ts-ignore */
486
+ ...(ngDevMode ? [undefined, { debugName: "filterBy" }] : /* istanbul ignore next */ []));
487
+ /**
488
+ * Height of the viewport in pixels, a scrollbar is defined if height of list exceeds this value.
489
+ * @group Props
490
+ */
491
+ scrollHeight = input('200px', /* @ts-ignore */
492
+ ...(ngDevMode ? [{ debugName: "scrollHeight" }] : /* istanbul ignore next */ []));
493
+ /**
494
+ * Defines if data is loaded and interacted with in lazy manner.
495
+ * @group Props
496
+ */
497
+ lazy = input(false, { ...(ngDevMode ? { debugName: "lazy" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
498
+ /**
499
+ * Whether the data should be loaded on demand during scroll.
500
+ * @group Props
501
+ */
502
+ virtualScroll = input(undefined, { ...(ngDevMode ? { debugName: "virtualScroll" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
503
+ /**
504
+ * Whether the multiselect is in loading state.
505
+ * @group Props
506
+ */
507
+ loading = input(false, { ...(ngDevMode ? { debugName: "loading" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
508
+ /**
509
+ * Height of an item in the list for VirtualScrolling.
510
+ * @group Props
511
+ */
512
+ virtualScrollItemSize = input(undefined, { ...(ngDevMode ? { debugName: "virtualScrollItemSize" } : /* istanbul ignore next */ {}), transform: numberAttribute });
513
+ /**
514
+ * Icon to display in loading state.
515
+ * @group Props
516
+ */
517
+ loadingIcon = input(/* @ts-ignore */
518
+ ...(ngDevMode ? [undefined, { debugName: "loadingIcon" }] : /* istanbul ignore next */ []));
519
+ /**
520
+ * Whether to use the scroller feature. The properties of scroller component can be used like an object in it.
521
+ * @group Props
522
+ */
523
+ virtualScrollOptions = input(/* @ts-ignore */
524
+ ...(ngDevMode ? [undefined, { debugName: "virtualScrollOptions" }] : /* istanbul ignore next */ []));
525
+ /**
526
+ * Whether to use overlay API feature. The properties of overlay API can be used like an object in it.
527
+ * @group Props
528
+ */
529
+ overlayOptions = input(/* @ts-ignore */
530
+ ...(ngDevMode ? [undefined, { debugName: "overlayOptions" }] : /* istanbul ignore next */ []));
531
+ /**
532
+ * Defines a string that labels the filter input.
533
+ * @group Props
534
+ */
535
+ ariaFilterLabel = input(/* @ts-ignore */
536
+ ...(ngDevMode ? [undefined, { debugName: "ariaFilterLabel" }] : /* istanbul ignore next */ []));
537
+ /**
538
+ * Defines how the items are filtered.
539
+ * @group Props
540
+ */
541
+ filterMatchMode = input('contains', /* @ts-ignore */
542
+ ...(ngDevMode ? [{ debugName: "filterMatchMode" }] : /* istanbul ignore next */ []));
543
+ /**
544
+ * Advisory information to display in a tooltip on hover.
545
+ * @group Props
546
+ */
547
+ tooltip = input('', /* @ts-ignore */
548
+ ...(ngDevMode ? [{ debugName: "tooltip" }] : /* istanbul ignore next */ []));
549
+ /**
550
+ * Position of the tooltip.
551
+ * @group Props
552
+ */
553
+ tooltipPosition = input('right', /* @ts-ignore */
554
+ ...(ngDevMode ? [{ debugName: "tooltipPosition" }] : /* istanbul ignore next */ []));
555
+ /**
556
+ * Type of CSS position.
557
+ * @group Props
558
+ */
559
+ tooltipPositionStyle = input('absolute', /* @ts-ignore */
560
+ ...(ngDevMode ? [{ debugName: "tooltipPositionStyle" }] : /* istanbul ignore next */ []));
561
+ /**
562
+ * Style class of the tooltip.
563
+ * @group Props
564
+ */
565
+ tooltipStyleClass = input(/* @ts-ignore */
566
+ ...(ngDevMode ? [undefined, { debugName: "tooltipStyleClass" }] : /* istanbul ignore next */ []));
567
+ /**
568
+ * Applies focus to the filter element when the overlay is shown.
569
+ * @group Props
570
+ */
571
+ autofocusFilter = input(false, { ...(ngDevMode ? { debugName: "autofocusFilter" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
572
+ /**
573
+ * Defines how the selected items are displayed.
574
+ * @group Props
575
+ */
576
+ display = input('comma', /* @ts-ignore */
577
+ ...(ngDevMode ? [{ debugName: "display" }] : /* istanbul ignore next */ []));
578
+ /**
579
+ * Defines the autocomplete is active.
580
+ * @group Props
581
+ */
582
+ autocomplete = input('off', /* @ts-ignore */
583
+ ...(ngDevMode ? [{ debugName: "autocomplete" }] : /* istanbul ignore next */ []));
584
+ /**
585
+ * When enabled, a clear icon is displayed to clear the value.
586
+ * @group Props
587
+ */
588
+ showClear = input(false, { ...(ngDevMode ? { debugName: "showClear" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
589
+ /**
590
+ * When present, it specifies that the component should automatically get focus on load.
591
+ * @group Props
592
+ */
593
+ autofocus = input(undefined, { ...(ngDevMode ? { debugName: "autofocus" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
594
+ /**
595
+ * Label to display when there are no selections.
596
+ * @group Props
597
+ */
598
+ placeholder = input(/* @ts-ignore */
599
+ ...(ngDevMode ? [undefined, { debugName: "placeholder" }] : /* istanbul ignore next */ []));
600
+ /**
601
+ * An array of objects to display as the available options.
602
+ * @group Props
603
+ */
604
+ options = input(/* @ts-ignore */
605
+ ...(ngDevMode ? [undefined, { debugName: "options" }] : /* istanbul ignore next */ []));
606
+ /**
607
+ * When specified, filter displays with this value.
608
+ * @group Props
609
+ */
610
+ filterValue = input(/* @ts-ignore */
611
+ ...(ngDevMode ? [undefined, { debugName: "filterValue" }] : /* istanbul ignore next */ []));
612
+ /**
613
+ * Whether all data is selected.
614
+ * @group Props
615
+ */
616
+ selectAll = input(/* @ts-ignore */
617
+ ...(ngDevMode ? [undefined, { debugName: "selectAll" }] : /* istanbul ignore next */ []));
618
+ /**
619
+ * Indicates whether to focus on options when hovering over them, defaults to optionLabel.
620
+ * @group Props
621
+ */
622
+ focusOnHover = input(true, { ...(ngDevMode ? { debugName: "focusOnHover" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
623
+ /**
624
+ * Fields used when filtering the options, defaults to optionLabel.
625
+ * @group Props
626
+ */
627
+ filterFields = input(/* @ts-ignore */
628
+ ...(ngDevMode ? [undefined, { debugName: "filterFields" }] : /* istanbul ignore next */ []));
629
+ /**
630
+ * Determines if the option will be selected on focus.
631
+ * @group Props
632
+ */
633
+ selectOnFocus = input(false, { ...(ngDevMode ? { debugName: "selectOnFocus" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
634
+ /**
635
+ * Whether to focus on the first visible or selected element when the overlay panel is shown.
636
+ * @group Props
637
+ */
638
+ autoOptionFocus = input(false, { ...(ngDevMode ? { debugName: "autoOptionFocus" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
639
+ /**
640
+ * Whether the selected option will be add highlight class.
641
+ * @group Props
642
+ */
643
+ highlightOnSelect = input(true, { ...(ngDevMode ? { debugName: "highlightOnSelect" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
644
+ /**
645
+ * Specifies the size of the component.
646
+ * @defaultValue undefined
647
+ * @group Props
648
+ */
649
+ size = input(/* @ts-ignore */
650
+ ...(ngDevMode ? [undefined, { debugName: "size" }] : /* istanbul ignore next */ []));
651
+ /**
652
+ * Specifies the input variant of the component.
653
+ * @defaultValue undefined
654
+ * @group Props
655
+ */
656
+ variant = input(/* @ts-ignore */
657
+ ...(ngDevMode ? [undefined, { debugName: "variant" }] : /* istanbul ignore next */ []));
658
+ /**
659
+ * Spans 100% width of the container when enabled.
660
+ * @defaultValue undefined
661
+ * @group Props
662
+ */
663
+ fluid = input(undefined, { ...(ngDevMode ? { debugName: "fluid" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
664
+ /**
665
+ * Target element to attach the overlay, valid values are "body" or a local ng-template variable of another element (note: use binding with brackets for template variables, e.g. [appendTo]="mydiv" for a div element having #mydiv as variable name).
666
+ * @defaultValue 'self'
667
+ * @group Props
668
+ */
669
+ appendTo = input(undefined, /* @ts-ignore */
670
+ ...(ngDevMode ? [{ debugName: "appendTo" }] : /* istanbul ignore next */ []));
671
+ /**
672
+ * The motion options.
673
+ * @group Props
674
+ */
675
+ motionOptions = input(undefined, /* @ts-ignore */
676
+ ...(ngDevMode ? [{ debugName: "motionOptions" }] : /* istanbul ignore next */ []));
677
+ /**
678
+ * Callback to invoke when value changes.
679
+ * @param {MultiSelectChangeEvent} event - Custom change event.
680
+ * @group Emits
681
+ */
682
+ onChange = output();
683
+ /**
684
+ * Callback to invoke when data is filtered.
685
+ * @param {MultiSelectFilterEvent} event - Custom filter event.
686
+ * @group Emits
687
+ */
688
+ onFilter = output();
689
+ /**
690
+ * Callback to invoke when multiselect receives focus.
691
+ * @param {MultiSelectFocusEvent} event - Custom focus event.
692
+ * @group Emits
693
+ */
694
+ onFocus = output();
695
+ /**
696
+ * Callback to invoke when multiselect loses focus.
697
+ * @param {MultiSelectBlurEvent} event - Custom blur event.
698
+ * @group Emits
699
+ */
700
+ onBlur = output();
701
+ /**
702
+ * Callback to invoke when component is clicked.
703
+ * @param {Event} event - Browser event.
704
+ * @group Emits
705
+ */
706
+ onClick = output();
707
+ /**
708
+ * Callback to invoke when input field is cleared.
709
+ * @group Emits
710
+ */
711
+ onClear = output();
712
+ /**
713
+ * Callback to invoke when overlay panel becomes visible.
714
+ * @param {AnimationEvent} event - Animation event.
715
+ * @group Emits
716
+ */
717
+ onPanelShow = output();
718
+ /**
719
+ * Callback to invoke when overlay panel becomes hidden.
720
+ * @param {AnimationEvent} event - Animation event.
721
+ * @group Emits
722
+ */
723
+ onPanelHide = output();
724
+ /**
725
+ * Callback to invoke in lazy mode to load new data.
726
+ * @param {MultiSelectLazyLoadEvent} event - Lazy load event.
727
+ * @group Emits
728
+ */
729
+ onLazyLoad = output();
730
+ /**
731
+ * Callback to invoke in lazy mode to load new data.
732
+ * @param {MultiSelectRemoveEvent} event - Remove event.
733
+ * @group Emits
734
+ */
735
+ onRemove = output();
736
+ /**
737
+ * Callback to invoke when all data is selected.
738
+ * @param {MultiSelectSelectAllChangeEvent} event - Custom select event.
739
+ * @group Emits
740
+ */
741
+ onSelectAllChange = output();
742
+ overlayViewChild = viewChild('overlay', /* @ts-ignore */
743
+ ...(ngDevMode ? [{ debugName: "overlayViewChild" }] : /* istanbul ignore next */ []));
744
+ filterInputChild = viewChild('filterInput', /* @ts-ignore */
745
+ ...(ngDevMode ? [{ debugName: "filterInputChild" }] : /* istanbul ignore next */ []));
746
+ focusInputViewChild = viewChild('focusInput', /* @ts-ignore */
747
+ ...(ngDevMode ? [{ debugName: "focusInputViewChild" }] : /* istanbul ignore next */ []));
748
+ itemsViewChild = viewChild('items', /* @ts-ignore */
749
+ ...(ngDevMode ? [{ debugName: "itemsViewChild" }] : /* istanbul ignore next */ []));
750
+ scroller = viewChild('scroller', /* @ts-ignore */
751
+ ...(ngDevMode ? [{ debugName: "scroller" }] : /* istanbul ignore next */ []));
752
+ lastHiddenFocusableElementOnOverlay = viewChild('lastHiddenFocusableEl', /* @ts-ignore */
753
+ ...(ngDevMode ? [{ debugName: "lastHiddenFocusableElementOnOverlay" }] : /* istanbul ignore next */ []));
754
+ firstHiddenFocusableElementOnOverlay = viewChild('firstHiddenFocusableEl', /* @ts-ignore */
755
+ ...(ngDevMode ? [{ debugName: "firstHiddenFocusableElementOnOverlay" }] : /* istanbul ignore next */ []));
756
+ headerCheckboxViewChild = viewChild('headerCheckbox', /* @ts-ignore */
757
+ ...(ngDevMode ? [{ debugName: "headerCheckboxViewChild" }] : /* istanbul ignore next */ []));
758
+ footerFacet = contentChild(Footer, { ...(ngDevMode ? { debugName: "footerFacet" } : /* istanbul ignore next */ {}), descendants: false });
759
+ headerFacet = contentChild(Header, { ...(ngDevMode ? { debugName: "headerFacet" } : /* istanbul ignore next */ {}), descendants: false });
760
+ _componentStyle = inject(MultiSelectStyle);
761
+ bindDirectiveInstance = inject(Bind, { self: true });
762
+ searchValue;
763
+ searchTimeout = null;
764
+ _disableTooltip = false;
765
+ value;
766
+ _filteredOptions;
767
+ focus;
768
+ filtered;
769
+ /**
770
+ * Custom item template.
771
+ * @group Templates
772
+ */
773
+ itemTemplate = contentChild('item', { ...(ngDevMode ? { debugName: "itemTemplate" } : /* istanbul ignore next */ {}), descendants: false });
774
+ /**
775
+ * Custom group template.
776
+ * @group Templates
777
+ */
778
+ groupTemplate = contentChild('group', { ...(ngDevMode ? { debugName: "groupTemplate" } : /* istanbul ignore next */ {}), descendants: false });
779
+ /**
780
+ * Custom loader template.
781
+ * @group Templates
782
+ */
783
+ loaderTemplate = contentChild('loader', { ...(ngDevMode ? { debugName: "loaderTemplate" } : /* istanbul ignore next */ {}), descendants: false });
784
+ /**
785
+ * Custom header template.
786
+ * @group Templates
787
+ */
788
+ headerTemplate = contentChild('header', { ...(ngDevMode ? { debugName: "headerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
789
+ /**
790
+ * Custom filter template.
791
+ * @group Templates
792
+ */
793
+ filterTemplate = contentChild('filter', { ...(ngDevMode ? { debugName: "filterTemplate" } : /* istanbul ignore next */ {}), descendants: false });
794
+ /**
795
+ * Custom footer template.
796
+ * @group Templates
797
+ */
798
+ footerTemplate = contentChild('footer', { ...(ngDevMode ? { debugName: "footerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
799
+ /**
800
+ * Custom empty filter template.
801
+ * @group Templates
802
+ */
803
+ emptyFilterTemplate = contentChild('emptyfilter', { ...(ngDevMode ? { debugName: "emptyFilterTemplate" } : /* istanbul ignore next */ {}), descendants: false });
804
+ /**
805
+ * Custom empty template.
806
+ * @group Templates
807
+ */
808
+ emptyTemplate = contentChild('empty', { ...(ngDevMode ? { debugName: "emptyTemplate" } : /* istanbul ignore next */ {}), descendants: false });
809
+ /**
810
+ * Custom selected items template.
811
+ * @group Templates
812
+ */
813
+ selectedItemsTemplate = contentChild('selecteditems', { ...(ngDevMode ? { debugName: "selectedItemsTemplate" } : /* istanbul ignore next */ {}), descendants: false });
814
+ /**
815
+ * Custom loading icon template.
816
+ * @group Templates
817
+ */
818
+ loadingIconTemplate = contentChild('loadingicon', { ...(ngDevMode ? { debugName: "loadingIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
819
+ /**
820
+ * Custom filter icon template.
821
+ * @group Templates
822
+ */
823
+ filterIconTemplate = contentChild('filtericon', { ...(ngDevMode ? { debugName: "filterIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
824
+ /**
825
+ * Custom remove token icon template.
826
+ * @group Templates
827
+ */
828
+ removeTokenIconTemplate = contentChild('removetokenicon', { ...(ngDevMode ? { debugName: "removeTokenIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
829
+ /**
830
+ * Custom chip icon template.
831
+ * @group Templates
832
+ */
833
+ chipIconTemplate = contentChild('chipicon', { ...(ngDevMode ? { debugName: "chipIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
834
+ /**
835
+ * Custom clear icon template.
836
+ * @group Templates
837
+ */
838
+ clearIconTemplate = contentChild('clearicon', { ...(ngDevMode ? { debugName: "clearIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
839
+ /**
840
+ * Custom dropdown icon template.
841
+ * @group Templates
842
+ */
843
+ dropdownIconTemplate = contentChild('dropdownicon', { ...(ngDevMode ? { debugName: "dropdownIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
844
+ /**
845
+ * Custom item checkbox icon template.
846
+ * @group Templates
847
+ */
848
+ itemCheckboxIconTemplate = contentChild('itemcheckboxicon', { ...(ngDevMode ? { debugName: "itemCheckboxIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
849
+ /**
850
+ * Custom header checkbox icon template.
851
+ * @group Templates
852
+ */
853
+ headerCheckboxIconTemplate = contentChild('headercheckboxicon', { ...(ngDevMode ? { debugName: "headerCheckboxIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
854
+ $variant = computed(() => this.variant() || this.config.inputVariant(), /* @ts-ignore */
855
+ ...(ngDevMode ? [{ debugName: "$variant" }] : /* istanbul ignore next */ []));
856
+ $appendTo = computed(() => this.appendTo() || this.config.overlayAppendTo(), /* @ts-ignore */
857
+ ...(ngDevMode ? [{ debugName: "$appendTo" }] : /* istanbul ignore next */ []));
858
+ internalId = uuid('pn_id_');
859
+ $id = computed(() => this.id() || this.internalId, /* @ts-ignore */
860
+ ...(ngDevMode ? [{ debugName: "$id" }] : /* istanbul ignore next */ []));
861
+ $pcMultiSelect = inject(MULTISELECT_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
862
+ pcFluid = inject(Fluid, { optional: true, host: true, skipSelf: true });
863
+ translation = toSignal(this.config.translationObserver, { initialValue: this.config.translation });
864
+ get hasFluid() {
865
+ return this.fluid() ?? !!this.pcFluid;
866
+ }
867
+ headerCheckboxFocus;
868
+ filterOptions;
869
+ preventModelTouched;
870
+ focused = false;
871
+ itemsWrapper = null;
872
+ modelValue = signal(null, /* @ts-ignore */
873
+ ...(ngDevMode ? [{ debugName: "modelValue" }] : /* istanbul ignore next */ []));
874
+ _filterValue = signal(null, /* @ts-ignore */
875
+ ...(ngDevMode ? [{ debugName: "_filterValue" }] : /* istanbul ignore next */ []));
876
+ _options = signal([], /* @ts-ignore */
877
+ ...(ngDevMode ? [{ debugName: "_options" }] : /* istanbul ignore next */ []));
878
+ startRangeIndex = signal(-1, /* @ts-ignore */
879
+ ...(ngDevMode ? [{ debugName: "startRangeIndex" }] : /* istanbul ignore next */ []));
880
+ focusedOptionIndex = signal(-1, /* @ts-ignore */
881
+ ...(ngDevMode ? [{ debugName: "focusedOptionIndex" }] : /* istanbul ignore next */ []));
882
+ selectedOptions = signal(null, /* @ts-ignore */
883
+ ...(ngDevMode ? [{ debugName: "selectedOptions" }] : /* istanbul ignore next */ []));
884
+ clickInProgress = false;
885
+ emptyMessageLabel = computed(() => {
886
+ const t = this.translation();
887
+ return this.emptyMessage() || t?.emptyMessage || '';
888
+ }, /* @ts-ignore */
889
+ ...(ngDevMode ? [{ debugName: "emptyMessageLabel" }] : /* istanbul ignore next */ []));
890
+ emptyFilterMessageLabel = computed(() => {
891
+ const t = this.translation();
892
+ return this.emptyFilterMessage() || t?.emptyFilterMessage || '';
893
+ }, /* @ts-ignore */
894
+ ...(ngDevMode ? [{ debugName: "emptyFilterMessageLabel" }] : /* istanbul ignore next */ []));
895
+ isVisibleClearIcon = computed(() => {
896
+ return this.modelValue() != null && this.modelValue() !== '' && isNotEmpty(this.modelValue()) && this.showClear() && !this.$disabled() && !this.readonly() && this.$filled();
897
+ }, /* @ts-ignore */
898
+ ...(ngDevMode ? [{ debugName: "isVisibleClearIcon" }] : /* istanbul ignore next */ []));
899
+ toggleAllAriaLabel = computed(() => {
900
+ const t = this.translation();
901
+ return t?.aria ? t.aria[this.allSelected() ? 'selectAll' : 'unselectAll'] : undefined;
902
+ }, /* @ts-ignore */
903
+ ...(ngDevMode ? [{ debugName: "toggleAllAriaLabel" }] : /* istanbul ignore next */ []));
904
+ listLabel = computed(() => {
905
+ const t = this.translation();
906
+ return t?.aria?.listLabel || '';
907
+ }, /* @ts-ignore */
908
+ ...(ngDevMode ? [{ debugName: "listLabel" }] : /* istanbul ignore next */ []));
909
+ placeholderLabel = computed(() => this.placeholder() || 'empty', /* @ts-ignore */
910
+ ...(ngDevMode ? [{ debugName: "placeholderLabel" }] : /* istanbul ignore next */ []));
911
+ labelDisplay = computed(() => this.label() || 'empty', /* @ts-ignore */
912
+ ...(ngDevMode ? [{ debugName: "labelDisplay" }] : /* istanbul ignore next */ []));
913
+ listId = computed(() => this.$id() + '_list', /* @ts-ignore */
914
+ ...(ngDevMode ? [{ debugName: "listId" }] : /* istanbul ignore next */ []));
915
+ getAllVisibleAndNonVisibleOptions() {
916
+ const group = this.group();
917
+ const options = this.options();
918
+ return group ? this.flatOptions(options) : options || [];
919
+ }
920
+ visibleOptions = computed(() => {
921
+ const options = this.getAllVisibleAndNonVisibleOptions();
922
+ const isArrayOfObjects = isArray(options) && ObjectUtils.isObject(options[0]);
923
+ const filterVal = this.filterValue() ?? this._filterValue();
924
+ const group = this.group();
925
+ const filterMatchMode = this.filterMatchMode();
926
+ const filterLocale = this.filterLocale();
927
+ const optionGroupChildren = this.optionGroupChildren();
928
+ if (filterVal) {
929
+ let filteredOptions;
930
+ if (isArrayOfObjects) {
931
+ filteredOptions = this.filterService.filter(options, this.searchFields(), filterVal, filterMatchMode, filterLocale);
932
+ }
933
+ else {
934
+ filteredOptions = options.filter((option) => option.toString().toLocaleLowerCase().includes(filterVal.toLocaleLowerCase()));
935
+ }
936
+ if (group) {
937
+ const optionGroups = this.options() || [];
938
+ const filtered = [];
939
+ optionGroups.forEach((grp) => {
940
+ const groupChildren = this.getOptionGroupChildren(grp);
941
+ const filteredItems = groupChildren.filter((item) => filteredOptions.includes(item));
942
+ if (filteredItems.length > 0)
943
+ filtered.push({
944
+ ...grp,
945
+ [typeof optionGroupChildren === 'string' ? optionGroupChildren : 'items']: [...filteredItems]
946
+ });
947
+ });
948
+ return this.flatOptions(filtered);
949
+ }
950
+ return filteredOptions;
951
+ }
952
+ return options;
953
+ }, /* @ts-ignore */
954
+ ...(ngDevMode ? [{ debugName: "visibleOptions" }] : /* istanbul ignore next */ []));
955
+ label = computed(() => {
956
+ let label;
957
+ const modelValue = this.modelValue();
958
+ const displaySelectedLabel = this.displaySelectedLabel();
959
+ const maxSelectedLabels = this.maxSelectedLabels();
960
+ if (modelValue && modelValue?.length && displaySelectedLabel) {
961
+ if (isNotEmpty(maxSelectedLabels) && modelValue?.length > (maxSelectedLabels || 0)) {
962
+ return this.getSelectedItemsLabel();
963
+ }
964
+ else {
965
+ label = '';
966
+ for (let i = 0; i < modelValue.length; i++) {
967
+ if (i !== 0) {
968
+ label += ', ';
969
+ }
970
+ label += this.getLabelByValue(modelValue[i]);
971
+ }
972
+ }
973
+ }
974
+ else {
975
+ label = this.placeholder() || '';
976
+ }
977
+ return label;
978
+ }, /* @ts-ignore */
979
+ ...(ngDevMode ? [{ debugName: "label" }] : /* istanbul ignore next */ []));
980
+ chipSelectedItems = computed(() => {
981
+ const maxSelectedLabels = this.maxSelectedLabels();
982
+ return isNotEmpty(maxSelectedLabels) && this.modelValue() && this.modelValue()?.length > (maxSelectedLabels || 0) ? this.modelValue()?.slice(0, maxSelectedLabels) : this.modelValue();
983
+ }, /* @ts-ignore */
984
+ ...(ngDevMode ? [{ debugName: "chipSelectedItems" }] : /* istanbul ignore next */ []));
985
+ filterService = inject(FilterService);
986
+ overlayService = inject(OverlayService);
987
+ constructor() {
988
+ super();
989
+ // Sync options input to internal signal
990
+ effect(() => {
991
+ const opts = this.options();
992
+ if (opts !== undefined &&
993
+ !deepEquals(untracked(() => this._options()), opts)) {
994
+ this._options.set(opts || []);
995
+ }
996
+ });
997
+ // Sync filterValue input to internal signal
998
+ effect(() => {
999
+ const fv = this.filterValue();
1000
+ if (fv !== undefined) {
1001
+ this._filterValue.set(fv);
1002
+ }
1003
+ });
1004
+ effect(() => {
1005
+ const modelValue = this.modelValue();
1006
+ const optionValue = this.optionValue();
1007
+ const optionLabel = this.optionLabel();
1008
+ const allVisibleAndNonVisibleOptions = this.getAllVisibleAndNonVisibleOptions();
1009
+ if (allVisibleAndNonVisibleOptions && isNotEmpty(allVisibleAndNonVisibleOptions)) {
1010
+ if (optionValue && optionLabel && modelValue) {
1011
+ this.selectedOptions.set(allVisibleAndNonVisibleOptions.filter((option) => modelValue.includes(option[optionLabel]) || modelValue.includes(option[optionValue])));
1012
+ }
1013
+ else {
1014
+ this.selectedOptions.set(modelValue);
1015
+ }
1016
+ }
1017
+ });
1018
+ }
1019
+ onInit() {
1020
+ this.autoUpdateModel();
1021
+ if (this.filterBy()) {
1022
+ this.filterOptions = {
1023
+ filter: (value) => this.onFilterInputChange(value),
1024
+ reset: () => this.resetFilter()
1025
+ };
1026
+ }
1027
+ }
1028
+ maxSelectionLimitReached() {
1029
+ const selectionLimit = this.selectionLimit();
1030
+ return selectionLimit && this.modelValue() && this.modelValue().length === selectionLimit;
1031
+ }
1032
+ onAfterViewInit() {
1033
+ if (this.overlayVisible()) {
1034
+ this.show();
1035
+ }
1036
+ }
1037
+ onAfterViewChecked() {
1038
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
1039
+ if (this.filtered) {
1040
+ setTimeout(() => {
1041
+ this.overlayViewChild()?.alignOverlay();
1042
+ }, 1);
1043
+ this.filtered = false;
1044
+ }
1045
+ }
1046
+ flatOptions(options) {
1047
+ return (options || []).reduce((result, option, index) => {
1048
+ result.push({ optionGroup: option, group: true, index });
1049
+ const optionGroupChildren = this.getOptionGroupChildren(option);
1050
+ optionGroupChildren && optionGroupChildren.forEach((o) => result.push(o));
1051
+ return result;
1052
+ }, []);
1053
+ }
1054
+ autoUpdateModel() {
1055
+ if (this.selectOnFocus() && this.autoOptionFocus() && !this.hasSelectedOption()) {
1056
+ this.focusedOptionIndex.set(this.findFirstFocusedOptionIndex());
1057
+ const value = this.getOptionValue(this.visibleOptions()[this.focusedOptionIndex()]);
1058
+ this.onOptionSelect({ originalEvent: null, option: [value] });
1059
+ }
1060
+ }
1061
+ /**
1062
+ * Updates the model value.
1063
+ * @group Method
1064
+ */
1065
+ updateModel(value, event) {
1066
+ this.value = value;
1067
+ this.onModelChange(value);
1068
+ this.writeValue(value);
1069
+ }
1070
+ onInputClick(event) {
1071
+ event.stopPropagation();
1072
+ event.preventDefault();
1073
+ this.focusedOptionIndex.set(-1);
1074
+ }
1075
+ onOptionSelect(event, isFocus = false, index = -1) {
1076
+ const { originalEvent, option } = event;
1077
+ if (this.$disabled() || this.isOptionDisabled(option)) {
1078
+ return;
1079
+ }
1080
+ let selected = this.isSelected(option);
1081
+ let value = [];
1082
+ if (selected) {
1083
+ value = this.modelValue().filter((val) => !equals(val, this.getOptionValue(option), this.equalityKey() || ''));
1084
+ }
1085
+ else {
1086
+ value = [...(this.modelValue() || []), this.getOptionValue(option)];
1087
+ }
1088
+ this.updateModel(value, originalEvent);
1089
+ index !== -1 && this.focusedOptionIndex.set(index);
1090
+ isFocus && focus(this.focusInputViewChild()?.nativeElement);
1091
+ this.onChange.emit({
1092
+ originalEvent: event,
1093
+ value: value,
1094
+ itemValue: option
1095
+ });
1096
+ }
1097
+ findSelectedOptionIndex() {
1098
+ return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;
1099
+ }
1100
+ onOptionSelectRange(event, start = -1, end = -1) {
1101
+ start === -1 && (start = this.findNearestSelectedOptionIndex(end, true));
1102
+ end === -1 && (end = this.findNearestSelectedOptionIndex(start));
1103
+ if (start !== -1 && end !== -1) {
1104
+ const rangeStart = Math.min(start, end);
1105
+ const rangeEnd = Math.max(start, end);
1106
+ const value = this.visibleOptions()
1107
+ .slice(rangeStart, rangeEnd + 1)
1108
+ .filter((option) => this.isValidOption(option))
1109
+ .map((option) => this.getOptionValue(option));
1110
+ this.updateModel(value, event);
1111
+ }
1112
+ }
1113
+ searchFields() {
1114
+ return (this.filterBy() || this.optionLabel() || 'label').split(',');
1115
+ }
1116
+ findNearestSelectedOptionIndex(index, firstCheckUp = false) {
1117
+ let matchedOptionIndex = -1;
1118
+ if (this.hasSelectedOption()) {
1119
+ if (firstCheckUp) {
1120
+ matchedOptionIndex = this.findPrevSelectedOptionIndex(index);
1121
+ matchedOptionIndex = matchedOptionIndex === -1 ? this.findNextSelectedOptionIndex(index) : matchedOptionIndex;
1122
+ }
1123
+ else {
1124
+ matchedOptionIndex = this.findNextSelectedOptionIndex(index);
1125
+ matchedOptionIndex = matchedOptionIndex === -1 ? this.findPrevSelectedOptionIndex(index) : matchedOptionIndex;
1126
+ }
1127
+ }
1128
+ return matchedOptionIndex > -1 ? matchedOptionIndex : index;
1129
+ }
1130
+ findPrevSelectedOptionIndex(index) {
1131
+ const matchedOptionIndex = this.hasSelectedOption() && index > 0 ? findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidSelectedOption(option)) : -1;
1132
+ return matchedOptionIndex > -1 ? matchedOptionIndex : -1;
1133
+ }
1134
+ findFirstFocusedOptionIndex() {
1135
+ const selectedIndex = this.findFirstSelectedOptionIndex();
1136
+ return selectedIndex < 0 ? this.findFirstOptionIndex() : selectedIndex;
1137
+ }
1138
+ findFirstOptionIndex() {
1139
+ return this.visibleOptions().findIndex((option) => this.isValidOption(option));
1140
+ }
1141
+ findFirstSelectedOptionIndex() {
1142
+ return this.hasSelectedOption() ? this.visibleOptions().findIndex((option) => this.isValidSelectedOption(option)) : -1;
1143
+ }
1144
+ findNextSelectedOptionIndex(index) {
1145
+ const matchedOptionIndex = this.hasSelectedOption() && index < this.visibleOptions().length - 1
1146
+ ? this.visibleOptions()
1147
+ .slice(index + 1)
1148
+ .findIndex((option) => this.isValidSelectedOption(option))
1149
+ : -1;
1150
+ return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : -1;
1151
+ }
1152
+ equalityKey() {
1153
+ return this.optionValue() ? null : this.dataKey();
1154
+ }
1155
+ hasSelectedOption() {
1156
+ return isNotEmpty(this.modelValue());
1157
+ }
1158
+ isValidSelectedOption(option) {
1159
+ return this.isValidOption(option) && this.isSelected(option);
1160
+ }
1161
+ isOptionGroup(option) {
1162
+ return option && (this.group() || this.optionGroupLabel()) && option.optionGroup && option.group;
1163
+ }
1164
+ isValidOption(option) {
1165
+ return option && !(this.isOptionDisabled(option) || this.isOptionGroup(option));
1166
+ }
1167
+ isOptionDisabled(option) {
1168
+ if (this.maxSelectionLimitReached() && !this.isSelected(option)) {
1169
+ return true;
1170
+ }
1171
+ const optionDisabled = this.optionDisabled();
1172
+ return optionDisabled ? resolveFieldData(option, optionDisabled) : option && option.disabled !== undefined ? option.disabled : false;
1173
+ }
1174
+ isSelected(option) {
1175
+ const optionValue = this.getOptionValue(option);
1176
+ return (this.modelValue() || []).some((value) => equals(value, optionValue, this.equalityKey() || ''));
1177
+ }
1178
+ isOptionMatched(option) {
1179
+ const filterLocale = this.filterLocale();
1180
+ return this.isValidOption(option) && this.getOptionLabel(option).toString().toLocaleLowerCase(filterLocale).startsWith(this.searchValue?.toLocaleLowerCase(filterLocale));
1181
+ }
1182
+ isEmpty() {
1183
+ return !this._options() || (this.visibleOptions() && this.visibleOptions().length === 0);
1184
+ }
1185
+ getOptionIndex(index, scrollerOptions) {
1186
+ return this.$virtualScrollerDisabled() ? index : scrollerOptions && scrollerOptions.getItemOptions(index)['index'];
1187
+ }
1188
+ getAriaPosInset(index) {
1189
+ return ((this.optionGroupLabel()
1190
+ ? index -
1191
+ this.visibleOptions()
1192
+ .slice(0, index)
1193
+ .filter((option) => this.isOptionGroup(option)).length
1194
+ : index) + 1);
1195
+ }
1196
+ $ariaSetSize = computed(() => {
1197
+ return this.visibleOptions().filter((option) => !this.isOptionGroup(option)).length;
1198
+ }, /* @ts-ignore */
1199
+ ...(ngDevMode ? [{ debugName: "$ariaSetSize" }] : /* istanbul ignore next */ []));
1200
+ getLabelByValue(value) {
1201
+ const group = this.group();
1202
+ const opts = this.options();
1203
+ const options = group ? this.flatOptions(opts) : opts || [];
1204
+ const matchedOption = options.find((option) => !this.isOptionGroup(option) && equals(this.getOptionValue(option), value, this.equalityKey() || ''));
1205
+ return matchedOption ? this.getOptionLabel(matchedOption) : null;
1206
+ }
1207
+ getSelectedItemsLabel() {
1208
+ let pattern = /{(.*?)}/;
1209
+ const selectedItemsLabel = this.selectedItemsLabel();
1210
+ let message = selectedItemsLabel ? selectedItemsLabel : this.translate(TranslationKeys.SELECTION_MESSAGE);
1211
+ if (pattern.test(message)) {
1212
+ return message.replace(message.match(pattern)[0], this.modelValue().length + '');
1213
+ }
1214
+ return message;
1215
+ }
1216
+ getOptionLabel(option) {
1217
+ const optionLabel = this.optionLabel();
1218
+ return optionLabel ? resolveFieldData(option, optionLabel) : option && option.label != undefined ? option.label : option;
1219
+ }
1220
+ getOptionValue(option) {
1221
+ const optionValue = this.optionValue();
1222
+ const optionLabel = this.optionLabel();
1223
+ return optionValue ? resolveFieldData(option, optionValue) : !optionLabel && option && option.value !== undefined ? option.value : option;
1224
+ }
1225
+ getOptionGroupLabel(optionGroup) {
1226
+ const optionGroupLabel = this.optionGroupLabel();
1227
+ return optionGroupLabel ? resolveFieldData(optionGroup, optionGroupLabel) : optionGroup && optionGroup.label != undefined ? optionGroup.label : optionGroup;
1228
+ }
1229
+ getOptionGroupChildren(optionGroup) {
1230
+ const optionGroupChildren = this.optionGroupChildren();
1231
+ return optionGroup ? (optionGroupChildren ? resolveFieldData(optionGroup, optionGroupChildren) : optionGroup.items) : [];
1232
+ }
1233
+ onKeyDown(event) {
1234
+ if (this.$disabled()) {
1235
+ event.preventDefault();
1236
+ return;
1237
+ }
1238
+ const metaKey = event.metaKey || event.ctrlKey;
1239
+ switch (event.code) {
1240
+ case 'ArrowDown':
1241
+ this.onArrowDownKey(event);
1242
+ break;
1243
+ case 'ArrowUp':
1244
+ this.onArrowUpKey(event);
1245
+ break;
1246
+ case 'Home':
1247
+ this.onHomeKey(event);
1248
+ break;
1249
+ case 'End':
1250
+ this.onEndKey(event);
1251
+ break;
1252
+ case 'PageDown':
1253
+ this.onPageDownKey(event);
1254
+ break;
1255
+ case 'PageUp':
1256
+ this.onPageUpKey(event);
1257
+ break;
1258
+ case 'Enter':
1259
+ case 'Space':
1260
+ this.onEnterKey(event);
1261
+ break;
1262
+ case 'Escape':
1263
+ this.onEscapeKey(event);
1264
+ break;
1265
+ case 'Tab':
1266
+ this.onTabKey(event);
1267
+ break;
1268
+ case 'ShiftLeft':
1269
+ case 'ShiftRight':
1270
+ this.onShiftKey();
1271
+ break;
1272
+ default:
1273
+ if (event.code === 'KeyA' && metaKey) {
1274
+ const value = this.visibleOptions()
1275
+ .filter((option) => this.isValidOption(option))
1276
+ .map((option) => this.getOptionValue(option));
1277
+ this.updateModel(value, event);
1278
+ event.preventDefault();
1279
+ break;
1280
+ }
1281
+ if (!metaKey && isPrintableCharacter(event.key)) {
1282
+ !this.overlayVisible() && this.show();
1283
+ this.searchOptions(event, event.key);
1284
+ event.preventDefault();
1285
+ }
1286
+ break;
1287
+ }
1288
+ }
1289
+ onFilterKeyDown(event) {
1290
+ switch (event.code) {
1291
+ case 'ArrowDown':
1292
+ this.onArrowDownKey(event);
1293
+ break;
1294
+ case 'ArrowUp':
1295
+ this.onArrowUpKey(event, true);
1296
+ break;
1297
+ case 'ArrowLeft':
1298
+ case 'ArrowRight':
1299
+ this.onArrowLeftKey(event, true);
1300
+ break;
1301
+ case 'Home':
1302
+ this.onHomeKey(event, true);
1303
+ break;
1304
+ case 'End':
1305
+ this.onEndKey(event, true);
1306
+ break;
1307
+ case 'Enter':
1308
+ case 'NumpadEnter':
1309
+ this.onEnterKey(event);
1310
+ break;
1311
+ case 'Escape':
1312
+ this.onEscapeKey(event);
1313
+ break;
1314
+ case 'Tab':
1315
+ this.onTabKey(event, true);
1316
+ break;
1317
+ default:
1318
+ break;
1319
+ }
1320
+ }
1321
+ onArrowLeftKey(event, pressedInInputText = false) {
1322
+ pressedInInputText && this.focusedOptionIndex.set(-1);
1323
+ }
1324
+ onArrowDownKey(event) {
1325
+ const optionIndex = this.focusedOptionIndex() !== -1 ? this.findNextOptionIndex(this.focusedOptionIndex()) : this.findFirstFocusedOptionIndex();
1326
+ if (event.shiftKey) {
1327
+ this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);
1328
+ }
1329
+ this.changeFocusedOptionIndex(event, optionIndex);
1330
+ !this.overlayVisible() && this.show();
1331
+ event.preventDefault();
1332
+ event.stopPropagation();
1333
+ }
1334
+ onArrowUpKey(event, pressedInInputText = false) {
1335
+ if (event.altKey && !pressedInInputText) {
1336
+ if (this.focusedOptionIndex() !== -1) {
1337
+ this.onOptionSelect(event, this.visibleOptions()[this.focusedOptionIndex()]);
1338
+ }
1339
+ this.overlayVisible() && this.hide();
1340
+ event.preventDefault();
1341
+ }
1342
+ else {
1343
+ const optionIndex = this.focusedOptionIndex() !== -1 ? this.findPrevOptionIndex(this.focusedOptionIndex()) : this.findLastFocusedOptionIndex();
1344
+ if (event.shiftKey) {
1345
+ this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());
1346
+ }
1347
+ this.changeFocusedOptionIndex(event, optionIndex);
1348
+ !this.overlayVisible() && this.show();
1349
+ event.preventDefault();
1350
+ }
1351
+ event.stopPropagation();
1352
+ }
1353
+ onHomeKey(event, pressedInInputText = false) {
1354
+ const { currentTarget } = event;
1355
+ if (pressedInInputText) {
1356
+ const len = currentTarget.value.length;
1357
+ currentTarget.setSelectionRange(0, event.shiftKey ? len : 0);
1358
+ this.focusedOptionIndex.set(-1);
1359
+ }
1360
+ else {
1361
+ let metaKey = event.metaKey || event.ctrlKey;
1362
+ let optionIndex = this.findFirstOptionIndex();
1363
+ if (event.shiftKey && metaKey) {
1364
+ this.onOptionSelectRange(event, optionIndex, this.startRangeIndex());
1365
+ }
1366
+ this.changeFocusedOptionIndex(event, optionIndex);
1367
+ !this.overlayVisible() && this.show();
1368
+ }
1369
+ event.preventDefault();
1370
+ }
1371
+ onEndKey(event, pressedInInputText = false) {
1372
+ const { currentTarget } = event;
1373
+ if (pressedInInputText) {
1374
+ const len = currentTarget.value.length;
1375
+ currentTarget.setSelectionRange(event.shiftKey ? 0 : len, len);
1376
+ this.focusedOptionIndex.set(-1);
1377
+ }
1378
+ else {
1379
+ let metaKey = event.metaKey || event.ctrlKey;
1380
+ let optionIndex = this.findLastFocusedOptionIndex();
1381
+ if (event.shiftKey && metaKey) {
1382
+ this.onOptionSelectRange(event, this.startRangeIndex(), optionIndex);
1383
+ }
1384
+ this.changeFocusedOptionIndex(event, optionIndex);
1385
+ !this.overlayVisible() && this.show();
1386
+ }
1387
+ event.preventDefault();
1388
+ }
1389
+ onPageDownKey(event) {
1390
+ this.scrollInView(this.visibleOptions().length - 1);
1391
+ event.preventDefault();
1392
+ }
1393
+ onPageUpKey(event) {
1394
+ this.scrollInView(0);
1395
+ event.preventDefault();
1396
+ }
1397
+ onEnterKey(event) {
1398
+ if (!this.overlayVisible()) {
1399
+ this.onArrowDownKey(event);
1400
+ }
1401
+ else {
1402
+ if (this.focusedOptionIndex() !== -1) {
1403
+ if (event.shiftKey) {
1404
+ this.onOptionSelectRange(event, this.focusedOptionIndex());
1405
+ }
1406
+ else {
1407
+ this.onOptionSelect({ originalEvent: event, option: this.visibleOptions()[this.focusedOptionIndex()] });
1408
+ }
1409
+ }
1410
+ }
1411
+ event.preventDefault();
1412
+ }
1413
+ onEscapeKey(event) {
1414
+ if (this.overlayVisible()) {
1415
+ this.hide(true);
1416
+ event.stopPropagation();
1417
+ event.preventDefault();
1418
+ }
1419
+ }
1420
+ onTabKey(event, pressedInInputText = false) {
1421
+ if (!pressedInInputText) {
1422
+ if (this.overlayVisible() && this.hasFocusableElements()) {
1423
+ focus(event.shiftKey ? this.lastHiddenFocusableElementOnOverlay()?.nativeElement : this.firstHiddenFocusableElementOnOverlay()?.nativeElement);
1424
+ event.preventDefault();
1425
+ }
1426
+ else {
1427
+ if (this.focusedOptionIndex() !== -1) {
1428
+ const option = this.visibleOptions()[this.focusedOptionIndex()];
1429
+ !this.isSelected(option) && this.onOptionSelect({ originalEvent: event, option });
1430
+ }
1431
+ this.overlayVisible() && this.hide(this.filter());
1432
+ }
1433
+ }
1434
+ }
1435
+ onShiftKey() {
1436
+ this.startRangeIndex.set(this.focusedOptionIndex());
1437
+ }
1438
+ onContainerClick(event) {
1439
+ if (this.$disabled() || this.loading() || this.readonly() || event.target?.isSameNode?.(this.focusInputViewChild()?.nativeElement)) {
1440
+ return;
1441
+ }
1442
+ const overlayViewChild = this.overlayViewChild();
1443
+ if (!overlayViewChild || !overlayViewChild.el.nativeElement.contains(event.target)) {
1444
+ if (this.clickInProgress) {
1445
+ return;
1446
+ }
1447
+ this.clickInProgress = true;
1448
+ setTimeout(() => {
1449
+ this.clickInProgress = false;
1450
+ }, 150);
1451
+ this.overlayVisible() ? this.hide(true) : this.show(true);
1452
+ }
1453
+ this.focusInputViewChild()?.nativeElement.focus({ preventScroll: true });
1454
+ this.onClick.emit(event);
1455
+ this.cd.detectChanges();
1456
+ }
1457
+ onFirstHiddenFocus(event) {
1458
+ const focusInputViewChild = this.focusInputViewChild();
1459
+ const overlayViewChild = this.overlayViewChild();
1460
+ const focusableEl = event.relatedTarget === focusInputViewChild?.nativeElement ? getFirstFocusableElement(overlayViewChild?.overlayViewChild()?.nativeElement, ':not([data-p-hidden-focusable="true"])') : focusInputViewChild?.nativeElement;
1461
+ focus(focusableEl);
1462
+ }
1463
+ onInputFocus(event) {
1464
+ this.focused = true;
1465
+ const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.overlayVisible() && this.autoOptionFocus() ? this.findFirstFocusedOptionIndex() : -1;
1466
+ this.focusedOptionIndex.set(focusedOptionIndex);
1467
+ this.overlayVisible() && this.scrollInView(this.focusedOptionIndex());
1468
+ this.onFocus.emit({ originalEvent: event });
1469
+ }
1470
+ onInputBlur(event) {
1471
+ this.focused = false;
1472
+ this.onBlur.emit({ originalEvent: event });
1473
+ if (!this.preventModelTouched) {
1474
+ this.onModelTouched();
1475
+ }
1476
+ this.preventModelTouched = false;
1477
+ }
1478
+ onFilterInputChange(event) {
1479
+ let value = event.target.value;
1480
+ this._filterValue.set(value);
1481
+ this.focusedOptionIndex.set(-1);
1482
+ this.onFilter.emit({ originalEvent: event, filter: this._filterValue() });
1483
+ !this.$virtualScrollerDisabled() && this.scroller()?.scrollToIndex(0);
1484
+ setTimeout(() => {
1485
+ this.overlayViewChild()?.alignOverlay();
1486
+ });
1487
+ }
1488
+ onLastHiddenFocus(event) {
1489
+ const focusInputViewChild = this.focusInputViewChild();
1490
+ const overlayViewChild = this.overlayViewChild();
1491
+ const focusableEl = event.relatedTarget === focusInputViewChild?.nativeElement ? getLastFocusableElement(overlayViewChild?.overlayViewChild()?.nativeElement, ':not([data-p-hidden-focusable="true"])') : focusInputViewChild?.nativeElement;
1492
+ focus(focusableEl);
1493
+ }
1494
+ onOptionMouseEnter(event, index) {
1495
+ if (this.focusOnHover()) {
1496
+ this.changeFocusedOptionIndex(event, index);
1497
+ }
1498
+ }
1499
+ onFilterBlur(event) {
1500
+ this.focusedOptionIndex.set(-1);
1501
+ }
1502
+ onToggleAll(event) {
1503
+ if (this.$disabled() || this.readonly()) {
1504
+ return;
1505
+ }
1506
+ const selectAll = this.selectAll();
1507
+ if (selectAll != null) {
1508
+ this.onSelectAllChange.emit({
1509
+ originalEvent: event,
1510
+ checked: !this.allSelected()
1511
+ });
1512
+ }
1513
+ else {
1514
+ // pre-selected disabled options should always be selected.
1515
+ const optionDisabled = this.optionDisabled();
1516
+ const selectedDisabledOptions = this.getAllVisibleAndNonVisibleOptions().filter((option) => this.isSelected(option) && (optionDisabled ? resolveFieldData(option, optionDisabled) : option && option.disabled !== undefined ? option.disabled : false));
1517
+ const visibleOptions = this.allSelected()
1518
+ ? this.visibleOptions().filter((option) => !this.isValidOption(option) && this.isSelected(option))
1519
+ : this.visibleOptions().filter((option) => this.isSelected(option) || this.isValidOption(option));
1520
+ const selectedOptionsBeforeSearch = this.filter() && !this.allSelected() ? this.getAllVisibleAndNonVisibleOptions().filter((option) => this.isSelected(option) && this.isValidOption(option)) : [];
1521
+ const optionValues = [...selectedOptionsBeforeSearch, ...selectedDisabledOptions, ...visibleOptions].map((option) => this.getOptionValue(option));
1522
+ const value = [...new Set(optionValues)];
1523
+ this.updateModel(value, event);
1524
+ // because onToggleAll could have been called during filtering, this additional test needs to be performed before calling onSelectAllChange.emit
1525
+ if (!value.length || value.length === this.getAllVisibleAndNonVisibleOptions().length) {
1526
+ this.onSelectAllChange.emit({
1527
+ originalEvent: event,
1528
+ checked: !!value.length
1529
+ });
1530
+ }
1531
+ }
1532
+ if (this.partialSelected()) {
1533
+ this.selectedOptions.set([]);
1534
+ }
1535
+ this.onChange.emit({ originalEvent: event, value: this.value });
1536
+ DomHandler.focus(this.headerCheckboxViewChild()?.inputViewChild()?.nativeElement);
1537
+ this.headerCheckboxFocus = true;
1538
+ event.originalEvent.preventDefault();
1539
+ event.originalEvent.stopPropagation();
1540
+ }
1541
+ changeFocusedOptionIndex(event, index) {
1542
+ if (this.focusedOptionIndex() !== index) {
1543
+ this.focusedOptionIndex.set(index);
1544
+ this.scrollInView();
1545
+ }
1546
+ }
1547
+ $virtualScrollerDisabled = computed(() => !this.virtualScroll(), /* @ts-ignore */
1548
+ ...(ngDevMode ? [{ debugName: "$virtualScrollerDisabled" }] : /* istanbul ignore next */ []));
1549
+ scrollInView(index = -1) {
1550
+ const id = index !== -1 ? `${this.$id()}_${index}` : this.$focusedOptionId();
1551
+ const itemsViewChild = this.itemsViewChild();
1552
+ if (itemsViewChild && itemsViewChild.nativeElement) {
1553
+ const element = findSingle(itemsViewChild.nativeElement, `li[id="${id}"]`);
1554
+ if (element) {
1555
+ element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'nearest' });
1556
+ }
1557
+ else if (!this.$virtualScrollerDisabled()) {
1558
+ setTimeout(() => {
1559
+ this.virtualScroll() && this.scroller()?.scrollToIndex(index !== -1 ? index : this.focusedOptionIndex());
1560
+ }, 0);
1561
+ }
1562
+ }
1563
+ }
1564
+ $focusedOptionId = computed(() => {
1565
+ return this.focusedOptionIndex() !== -1 ? `${this.$id()}_${this.focusedOptionIndex()}` : null;
1566
+ }, /* @ts-ignore */
1567
+ ...(ngDevMode ? [{ debugName: "$focusedOptionId" }] : /* istanbul ignore next */ []));
1568
+ allSelected() {
1569
+ const selectAll = this.selectAll();
1570
+ return selectAll !== null ? selectAll : isNotEmpty(this.visibleOptions()) && this.visibleOptions().every((option) => this.isOptionGroup(option) || this.isOptionDisabled(option) || this.isSelected(option));
1571
+ }
1572
+ partialSelected() {
1573
+ const opts = this.options();
1574
+ const selected = this.selectedOptions();
1575
+ return selected && selected.length > 0 && selected.length < (opts?.length || 0);
1576
+ }
1577
+ /**
1578
+ * Displays the panel.
1579
+ * @group Method
1580
+ */
1581
+ show(isFocus) {
1582
+ this.overlayVisible.set(true);
1583
+ const focusedOptionIndex = this.focusedOptionIndex() !== -1 ? this.focusedOptionIndex() : this.autoOptionFocus() ? this.findFirstFocusedOptionIndex() : this.findSelectedOptionIndex();
1584
+ this.focusedOptionIndex.set(focusedOptionIndex);
1585
+ if (isFocus) {
1586
+ focus(this.focusInputViewChild()?.nativeElement);
1587
+ }
1588
+ }
1589
+ /**
1590
+ * Hides the panel.
1591
+ * @group Method
1592
+ */
1593
+ hide(isFocus) {
1594
+ this.overlayVisible.set(false);
1595
+ this.focusedOptionIndex.set(-1);
1596
+ if (this.filter() && this.resetFilterOnHide()) {
1597
+ this.resetFilter();
1598
+ }
1599
+ if (this.overlayOptions()?.mode === 'modal') {
1600
+ unblockBodyScroll();
1601
+ }
1602
+ isFocus && focus(this.focusInputViewChild()?.nativeElement);
1603
+ }
1604
+ onOverlayBeforeEnter(event) {
1605
+ const overlayViewChild = this.overlayViewChild();
1606
+ const scroller = this.scroller();
1607
+ const itemsViewChild = this.itemsViewChild();
1608
+ const virtualScroll = this.virtualScroll();
1609
+ const opts = this.options();
1610
+ this.itemsWrapper = findSingle(overlayViewChild?.overlayViewChild()?.nativeElement, virtualScroll ? '[data-pc-name="virtualscroller"]' : '[data-pc-section="listcontainer"]');
1611
+ virtualScroll && scroller?.setContentEl(itemsViewChild?.nativeElement);
1612
+ if (opts && opts.length) {
1613
+ if (virtualScroll) {
1614
+ const selectedIndex = this.modelValue() ? this.focusedOptionIndex() : -1;
1615
+ if (selectedIndex !== -1) {
1616
+ scroller?.scrollToIndex(selectedIndex);
1617
+ }
1618
+ }
1619
+ else if (this.itemsWrapper) {
1620
+ let selectedListItem = findSingle(this.itemsWrapper, '[data-pc-section="option"][data-p-selected="true"]');
1621
+ if (selectedListItem) {
1622
+ selectedListItem.scrollIntoView({ block: 'nearest', inline: 'nearest' });
1623
+ }
1624
+ }
1625
+ }
1626
+ const filterInputChild = this.filterInputChild();
1627
+ if (filterInputChild && filterInputChild.nativeElement) {
1628
+ this.preventModelTouched = true;
1629
+ if (this.autofocusFilter()) {
1630
+ filterInputChild.nativeElement.focus();
1631
+ }
1632
+ }
1633
+ this.onPanelShow.emit(event);
1634
+ }
1635
+ onOverlayAfterLeave(event) {
1636
+ this.itemsWrapper = null;
1637
+ this.onModelTouched();
1638
+ this.onPanelHide.emit(event);
1639
+ }
1640
+ resetFilter() {
1641
+ const filterInputChild = this.filterInputChild();
1642
+ if (filterInputChild && filterInputChild.nativeElement) {
1643
+ filterInputChild.nativeElement.value = '';
1644
+ }
1645
+ this._filterValue.set(null);
1646
+ this._filteredOptions = null;
1647
+ }
1648
+ onOverlayHide(event) {
1649
+ // Called when overlay completes its hide animation
1650
+ // Don't call hide() again to avoid recursive calls
1651
+ this.focusedOptionIndex.set(-1);
1652
+ if (this.filter() && this.resetFilterOnHide()) {
1653
+ this.resetFilter();
1654
+ }
1655
+ }
1656
+ close(event) {
1657
+ this.hide();
1658
+ event.preventDefault();
1659
+ event.stopPropagation();
1660
+ }
1661
+ clear(event) {
1662
+ this.value = [];
1663
+ this.updateModel(null, event);
1664
+ this.selectedOptions.set([]);
1665
+ this.onClear.emit();
1666
+ this._disableTooltip = true;
1667
+ event.stopPropagation();
1668
+ }
1669
+ labelContainerMouseLeave() {
1670
+ if (this._disableTooltip)
1671
+ this._disableTooltip = false;
1672
+ }
1673
+ removeOption(optionValue, event) {
1674
+ let value = this.modelValue().filter((val) => !equals(val, optionValue, this.equalityKey() || ''));
1675
+ this.updateModel(value, event);
1676
+ this.onChange.emit({
1677
+ originalEvent: event,
1678
+ value: value,
1679
+ itemValue: optionValue
1680
+ });
1681
+ this.onRemove.emit({
1682
+ newValue: value,
1683
+ removed: optionValue
1684
+ });
1685
+ event && event.stopPropagation();
1686
+ }
1687
+ findNextOptionIndex(index) {
1688
+ const matchedOptionIndex = index < this.visibleOptions().length - 1
1689
+ ? this.visibleOptions()
1690
+ .slice(index + 1)
1691
+ .findIndex((option) => this.isValidOption(option))
1692
+ : -1;
1693
+ return matchedOptionIndex > -1 ? matchedOptionIndex + index + 1 : index;
1694
+ }
1695
+ findPrevOptionIndex(index) {
1696
+ const matchedOptionIndex = index > 0 ? findLastIndex(this.visibleOptions().slice(0, index), (option) => this.isValidOption(option)) : -1;
1697
+ return matchedOptionIndex > -1 ? matchedOptionIndex : index;
1698
+ }
1699
+ findLastSelectedOptionIndex() {
1700
+ return this.hasSelectedOption() ? findLastIndex(this.visibleOptions(), (option) => this.isValidSelectedOption(option)) : -1;
1701
+ }
1702
+ findLastFocusedOptionIndex() {
1703
+ const selectedIndex = this.findLastSelectedOptionIndex();
1704
+ return selectedIndex < 0 ? this.findLastOptionIndex() : selectedIndex;
1705
+ }
1706
+ findLastOptionIndex() {
1707
+ return findLastIndex(this.visibleOptions(), (option) => this.isValidOption(option));
1708
+ }
1709
+ searchOptions(event, char) {
1710
+ this.searchValue = (this.searchValue || '') + char;
1711
+ let optionIndex = -1;
1712
+ let matched = false;
1713
+ if (this.focusedOptionIndex() !== -1) {
1714
+ optionIndex = this.visibleOptions()
1715
+ .slice(this.focusedOptionIndex())
1716
+ .findIndex((option) => this.isOptionMatched(option));
1717
+ optionIndex =
1718
+ optionIndex === -1
1719
+ ? this.visibleOptions()
1720
+ .slice(0, this.focusedOptionIndex())
1721
+ .findIndex((option) => this.isOptionMatched(option))
1722
+ : optionIndex + this.focusedOptionIndex();
1723
+ }
1724
+ else {
1725
+ optionIndex = this.visibleOptions().findIndex((option) => this.isOptionMatched(option));
1726
+ }
1727
+ if (optionIndex !== -1) {
1728
+ matched = true;
1729
+ }
1730
+ if (optionIndex === -1 && this.focusedOptionIndex() === -1) {
1731
+ optionIndex = this.findFirstFocusedOptionIndex();
1732
+ }
1733
+ if (optionIndex !== -1) {
1734
+ this.changeFocusedOptionIndex(event, optionIndex);
1735
+ }
1736
+ if (this.searchTimeout) {
1737
+ clearTimeout(this.searchTimeout);
1738
+ }
1739
+ this.searchTimeout = setTimeout(() => {
1740
+ this.searchValue = '';
1741
+ this.searchTimeout = null;
1742
+ }, 500);
1743
+ return matched;
1744
+ }
1745
+ hasFocusableElements() {
1746
+ return getFocusableElements(this.overlayViewChild()?.overlayViewChild()?.nativeElement, ':not([data-p-hidden-focusable="true"])').length > 0;
1747
+ }
1748
+ hasFilter() {
1749
+ const filterVal = this._filterValue();
1750
+ return filterVal && filterVal.trim().length > 0;
1751
+ }
1752
+ get containerDataP() {
1753
+ return this.cn({
1754
+ invalid: this.invalid(),
1755
+ disabled: this.$disabled(),
1756
+ focus: this.focused,
1757
+ fluid: this.hasFluid,
1758
+ filled: this.$variant() === 'filled',
1759
+ [this.size()]: this.size()
1760
+ });
1761
+ }
1762
+ labelDataP = computed(() => {
1763
+ const maxSelectedLabels = this.maxSelectedLabels();
1764
+ const modelValue = this.modelValue();
1765
+ return this.cn({
1766
+ placeholder: this.label() === this.placeholder(),
1767
+ clearable: this.showClear(),
1768
+ disabled: this.$disabled(),
1769
+ [this.size()]: this.size(),
1770
+ 'has-chip': this.display() === 'chip' && modelValue && modelValue.length && (maxSelectedLabels ? modelValue.length <= maxSelectedLabels : true),
1771
+ empty: !this.placeholder() && !this.$filled()
1772
+ });
1773
+ }, /* @ts-ignore */
1774
+ ...(ngDevMode ? [{ debugName: "labelDataP" }] : /* istanbul ignore next */ []));
1775
+ dropdownIconDataP = computed(() => {
1776
+ return this.cn({
1777
+ [this.size()]: this.size()
1778
+ });
1779
+ }, /* @ts-ignore */
1780
+ ...(ngDevMode ? [{ debugName: "dropdownIconDataP" }] : /* istanbul ignore next */ []));
1781
+ overlayDataP = computed(() => {
1782
+ return this.cn({
1783
+ ['overlay-' + this.appendTo()]: 'overlay-' + this.appendTo()
1784
+ });
1785
+ }, /* @ts-ignore */
1786
+ ...(ngDevMode ? [{ debugName: "overlayDataP" }] : /* istanbul ignore next */ []));
1787
+ ariaExpanded = computed(() => this.overlayVisible() ?? false, /* @ts-ignore */
1788
+ ...(ngDevMode ? [{ debugName: "ariaExpanded" }] : /* istanbul ignore next */ []));
1789
+ ariaControls = computed(() => (this.overlayVisible() ? this.listId() : null), /* @ts-ignore */
1790
+ ...(ngDevMode ? [{ debugName: "ariaControls" }] : /* istanbul ignore next */ []));
1791
+ inputTabindex = computed(() => (!this.$disabled() ? this.tabindex() : -1), /* @ts-ignore */
1792
+ ...(ngDevMode ? [{ debugName: "inputTabindex" }] : /* istanbul ignore next */ []));
1793
+ requiredAttr = computed(() => (this.required() ? '' : undefined), /* @ts-ignore */
1794
+ ...(ngDevMode ? [{ debugName: "requiredAttr" }] : /* istanbul ignore next */ []));
1795
+ disabledAttr = computed(() => (this.$disabled() ? '' : undefined), /* @ts-ignore */
1796
+ ...(ngDevMode ? [{ debugName: "disabledAttr" }] : /* istanbul ignore next */ []));
1797
+ get ariaActivedescendant() {
1798
+ return this.focused ? this.$focusedOptionId() : undefined;
1799
+ }
1800
+ isCommaDisplay = computed(() => this.display() === 'comma', /* @ts-ignore */
1801
+ ...(ngDevMode ? [{ debugName: "isCommaDisplay" }] : /* istanbul ignore next */ []));
1802
+ isChipDisplay = computed(() => this.display() === 'chip', /* @ts-ignore */
1803
+ ...(ngDevMode ? [{ debugName: "isChipDisplay" }] : /* istanbul ignore next */ []));
1804
+ showSelectedItemsLabel = computed(() => {
1805
+ const items = this.chipSelectedItems();
1806
+ return items && items.length === this.maxSelectedLabels();
1807
+ }, /* @ts-ignore */
1808
+ ...(ngDevMode ? [{ debugName: "showSelectedItemsLabel" }] : /* istanbul ignore next */ []));
1809
+ hasChipRemoveIconTemplate = computed(() => !!(this.chipIconTemplate() || this.removeTokenIconTemplate()), /* @ts-ignore */
1810
+ ...(ngDevMode ? [{ debugName: "hasChipRemoveIconTemplate" }] : /* istanbul ignore next */ []));
1811
+ isEditable = computed(() => !this.$disabled() && !this.readonly(), /* @ts-ignore */
1812
+ ...(ngDevMode ? [{ debugName: "isEditable" }] : /* istanbul ignore next */ []));
1813
+ isModelEmpty = computed(() => {
1814
+ const value = this.modelValue();
1815
+ return !value || value.length === 0;
1816
+ }, /* @ts-ignore */
1817
+ ...(ngDevMode ? [{ debugName: "isModelEmpty" }] : /* istanbul ignore next */ []));
1818
+ showToggleAllCheckbox = computed(() => this.showToggleAll() && !this.selectionLimit(), /* @ts-ignore */
1819
+ ...(ngDevMode ? [{ debugName: "showToggleAllCheckbox" }] : /* istanbul ignore next */ []));
1820
+ showDefaultHeaderCheckIcon = computed(() => !this.headerCheckboxIconTemplate() && this.allSelected(), /* @ts-ignore */
1821
+ ...(ngDevMode ? [{ debugName: "showDefaultHeaderCheckIcon" }] : /* istanbul ignore next */ []));
1822
+ showEmptyFilterMessage = computed(() => this.hasFilter() && this.isEmpty(), /* @ts-ignore */
1823
+ ...(ngDevMode ? [{ debugName: "showEmptyFilterMessage" }] : /* istanbul ignore next */ []));
1824
+ showEmptyMessage = computed(() => !this.hasFilter() && this.isEmpty(), /* @ts-ignore */
1825
+ ...(ngDevMode ? [{ debugName: "showEmptyMessage" }] : /* istanbul ignore next */ []));
1826
+ hasFooterContent = computed(() => !!(this.footerFacet() || this.footerTemplate()), /* @ts-ignore */
1827
+ ...(ngDevMode ? [{ debugName: "hasFooterContent" }] : /* istanbul ignore next */ []));
1828
+ chipIconContext = { class: 'p-multiselect-chip-icon' };
1829
+ selectedItemsContext = computed(() => ({
1830
+ $implicit: this.selectedOptions(),
1831
+ removeChip: this.removeOption.bind(this)
1832
+ }), /* @ts-ignore */
1833
+ ...(ngDevMode ? [{ debugName: "selectedItemsContext" }] : /* istanbul ignore next */ []));
1834
+ dropdownIconContext = computed(() => ({ dataP: this.dropdownIconDataP() }), /* @ts-ignore */
1835
+ ...(ngDevMode ? [{ debugName: "dropdownIconContext" }] : /* istanbul ignore next */ []));
1836
+ filterContext = computed(() => ({ options: this.filterOptions }), /* @ts-ignore */
1837
+ ...(ngDevMode ? [{ debugName: "filterContext" }] : /* istanbul ignore next */ []));
1838
+ getHeaderCheckboxIconContext(klass) {
1839
+ return { checked: this.allSelected(), partialSelected: this.partialSelected(), class: klass };
1840
+ }
1841
+ getScrollerItemsContext(items, scrollerOptions) {
1842
+ return { $implicit: items, options: scrollerOptions };
1843
+ }
1844
+ getLoaderContext(scrollerOptions) {
1845
+ return { options: scrollerOptions };
1846
+ }
1847
+ getGroupContext(option) {
1848
+ return { $implicit: option.optionGroup };
1849
+ }
1850
+ defaultItemsContext = computed(() => ({ $implicit: this.visibleOptions(), options: {} }), /* @ts-ignore */
1851
+ ...(ngDevMode ? [{ debugName: "defaultItemsContext" }] : /* istanbul ignore next */ []));
1852
+ filterInputValue = computed(() => this._filterValue() || '', /* @ts-ignore */
1853
+ ...(ngDevMode ? [{ debugName: "filterInputValue" }] : /* istanbul ignore next */ []));
1854
+ listContainerMaxHeight = computed(() => (this.virtualScroll() ? 'auto' : this.scrollHeight() || 'auto'), /* @ts-ignore */
1855
+ ...(ngDevMode ? [{ debugName: "listContainerMaxHeight" }] : /* istanbul ignore next */ []));
1856
+ /**
1857
+ * @override
1858
+ *
1859
+ * @see {@link BaseEditableHolder.writeControlValue}
1860
+ * Writes the value to the control.
1861
+ */
1862
+ writeControlValue(value, setModelValue) {
1863
+ this.value = value;
1864
+ setModelValue(value);
1865
+ }
1866
+ getHeaderCheckboxPTOptions(key) {
1867
+ return this.ptm(key, {
1868
+ context: {
1869
+ selected: this.allSelected()
1870
+ }
1871
+ });
1872
+ }
1873
+ getPTOptions(option, itemOptions, index, key) {
1874
+ return this.ptm(key, {
1875
+ context: {
1876
+ selected: this.isSelected(option),
1877
+ focused: this.focusedOptionIndex() === this.getOptionIndex(index, itemOptions),
1878
+ disabled: this.isOptionDisabled(option)
1879
+ }
1880
+ });
1881
+ }
1882
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelect, deps: [], target: i0.ɵɵFactoryTarget.Component });
1883
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: MultiSelect, isStandalone: true, selector: "p-multiselect, p-multi-select", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "ariaLabel", isSignal: true, isRequired: false, transformFunction: null }, panelStyle: { classPropertyName: "panelStyle", publicName: "panelStyle", isSignal: true, isRequired: false, transformFunction: null }, panelStyleClass: { classPropertyName: "panelStyleClass", publicName: "panelStyleClass", isSignal: true, isRequired: false, transformFunction: null }, inputId: { classPropertyName: "inputId", publicName: "inputId", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", 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 }, overlayVisible: { classPropertyName: "overlayVisible", publicName: "overlayVisible", isSignal: true, isRequired: false, transformFunction: null }, tabindex: { classPropertyName: "tabindex", publicName: "tabindex", isSignal: true, isRequired: false, transformFunction: null }, dataKey: { classPropertyName: "dataKey", publicName: "dataKey", isSignal: true, isRequired: false, transformFunction: null }, ariaLabelledBy: { classPropertyName: "ariaLabelledBy", publicName: "ariaLabelledBy", isSignal: true, isRequired: false, transformFunction: null }, displaySelectedLabel: { classPropertyName: "displaySelectedLabel", publicName: "displaySelectedLabel", isSignal: true, isRequired: false, transformFunction: null }, maxSelectedLabels: { classPropertyName: "maxSelectedLabels", publicName: "maxSelectedLabels", isSignal: true, isRequired: false, transformFunction: null }, selectionLimit: { classPropertyName: "selectionLimit", publicName: "selectionLimit", isSignal: true, isRequired: false, transformFunction: null }, selectedItemsLabel: { classPropertyName: "selectedItemsLabel", publicName: "selectedItemsLabel", isSignal: true, isRequired: false, transformFunction: null }, showToggleAll: { classPropertyName: "showToggleAll", publicName: "showToggleAll", isSignal: true, isRequired: false, transformFunction: null }, emptyFilterMessage: { classPropertyName: "emptyFilterMessage", publicName: "emptyFilterMessage", isSignal: true, isRequired: false, transformFunction: null }, emptyMessage: { classPropertyName: "emptyMessage", publicName: "emptyMessage", isSignal: true, isRequired: false, transformFunction: null }, resetFilterOnHide: { classPropertyName: "resetFilterOnHide", publicName: "resetFilterOnHide", isSignal: true, isRequired: false, transformFunction: null }, dropdownIcon: { classPropertyName: "dropdownIcon", publicName: "dropdownIcon", isSignal: true, isRequired: false, transformFunction: null }, chipIcon: { classPropertyName: "chipIcon", publicName: "chipIcon", isSignal: true, isRequired: false, transformFunction: null }, optionLabel: { classPropertyName: "optionLabel", publicName: "optionLabel", isSignal: true, isRequired: false, transformFunction: null }, optionValue: { classPropertyName: "optionValue", publicName: "optionValue", isSignal: true, isRequired: false, transformFunction: null }, optionDisabled: { classPropertyName: "optionDisabled", publicName: "optionDisabled", isSignal: true, isRequired: false, transformFunction: null }, optionGroupLabel: { classPropertyName: "optionGroupLabel", publicName: "optionGroupLabel", isSignal: true, isRequired: false, transformFunction: null }, optionGroupChildren: { classPropertyName: "optionGroupChildren", publicName: "optionGroupChildren", isSignal: true, isRequired: false, transformFunction: null }, showHeader: { classPropertyName: "showHeader", publicName: "showHeader", isSignal: true, isRequired: false, transformFunction: null }, filterBy: { classPropertyName: "filterBy", publicName: "filterBy", 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 }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollItemSize: { classPropertyName: "virtualScrollItemSize", publicName: "virtualScrollItemSize", isSignal: true, isRequired: false, transformFunction: null }, loadingIcon: { classPropertyName: "loadingIcon", publicName: "loadingIcon", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollOptions: { classPropertyName: "virtualScrollOptions", publicName: "virtualScrollOptions", isSignal: true, isRequired: false, transformFunction: null }, overlayOptions: { classPropertyName: "overlayOptions", publicName: "overlayOptions", isSignal: true, isRequired: false, transformFunction: null }, ariaFilterLabel: { classPropertyName: "ariaFilterLabel", publicName: "ariaFilterLabel", isSignal: true, isRequired: false, transformFunction: null }, filterMatchMode: { classPropertyName: "filterMatchMode", publicName: "filterMatchMode", isSignal: true, isRequired: false, transformFunction: null }, tooltip: { classPropertyName: "tooltip", publicName: "tooltip", isSignal: true, isRequired: false, transformFunction: null }, tooltipPosition: { classPropertyName: "tooltipPosition", publicName: "tooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, tooltipPositionStyle: { classPropertyName: "tooltipPositionStyle", publicName: "tooltipPositionStyle", isSignal: true, isRequired: false, transformFunction: null }, tooltipStyleClass: { classPropertyName: "tooltipStyleClass", publicName: "tooltipStyleClass", isSignal: true, isRequired: false, transformFunction: null }, autofocusFilter: { classPropertyName: "autofocusFilter", publicName: "autofocusFilter", isSignal: true, isRequired: false, transformFunction: null }, display: { classPropertyName: "display", publicName: "display", isSignal: true, isRequired: false, transformFunction: null }, autocomplete: { classPropertyName: "autocomplete", publicName: "autocomplete", isSignal: true, isRequired: false, transformFunction: null }, showClear: { classPropertyName: "showClear", publicName: "showClear", isSignal: true, isRequired: false, transformFunction: null }, autofocus: { classPropertyName: "autofocus", publicName: "autofocus", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, filterValue: { classPropertyName: "filterValue", publicName: "filterValue", isSignal: true, isRequired: false, transformFunction: null }, selectAll: { classPropertyName: "selectAll", publicName: "selectAll", isSignal: true, isRequired: false, transformFunction: null }, focusOnHover: { classPropertyName: "focusOnHover", publicName: "focusOnHover", isSignal: true, isRequired: false, transformFunction: null }, filterFields: { classPropertyName: "filterFields", publicName: "filterFields", isSignal: true, isRequired: false, transformFunction: null }, selectOnFocus: { classPropertyName: "selectOnFocus", publicName: "selectOnFocus", isSignal: true, isRequired: false, transformFunction: null }, autoOptionFocus: { classPropertyName: "autoOptionFocus", publicName: "autoOptionFocus", isSignal: true, isRequired: false, transformFunction: null }, highlightOnSelect: { classPropertyName: "highlightOnSelect", publicName: "highlightOnSelect", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, fluid: { classPropertyName: "fluid", publicName: "fluid", isSignal: true, isRequired: false, transformFunction: null }, appendTo: { classPropertyName: "appendTo", publicName: "appendTo", isSignal: true, isRequired: false, transformFunction: null }, motionOptions: { classPropertyName: "motionOptions", publicName: "motionOptions", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { overlayVisible: "overlayVisibleChange", onChange: "onChange", onFilter: "onFilter", onFocus: "onFocus", onBlur: "onBlur", onClick: "onClick", onClear: "onClear", onPanelShow: "onPanelShow", onPanelHide: "onPanelHide", onLazyLoad: "onLazyLoad", onRemove: "onRemove", onSelectAllChange: "onSelectAllChange" }, host: { listeners: { "click": "onContainerClick($event)" }, properties: { "attr.id": "$id()", "attr.data-p": "containerDataP", "class": "cx('root')", "style": "sx('root')" } }, providers: [MULTISELECT_VALUE_ACCESSOR, MultiSelectStyle, { provide: MULTISELECT_INSTANCE, useExisting: MultiSelect }, { provide: PARENT_INSTANCE, useExisting: MultiSelect }], queries: [{ propertyName: "footerFacet", first: true, predicate: Footer, isSignal: true }, { propertyName: "headerFacet", first: true, predicate: Header, isSignal: true }, { propertyName: "itemTemplate", first: true, predicate: ["item"], isSignal: true }, { propertyName: "groupTemplate", first: true, predicate: ["group"], isSignal: true }, { propertyName: "loaderTemplate", first: true, predicate: ["loader"], isSignal: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], isSignal: true }, { propertyName: "filterTemplate", first: true, predicate: ["filter"], isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ["footer"], isSignal: true }, { propertyName: "emptyFilterTemplate", first: true, predicate: ["emptyfilter"], isSignal: true }, { propertyName: "emptyTemplate", first: true, predicate: ["empty"], isSignal: true }, { propertyName: "selectedItemsTemplate", first: true, predicate: ["selecteditems"], isSignal: true }, { propertyName: "loadingIconTemplate", first: true, predicate: ["loadingicon"], isSignal: true }, { propertyName: "filterIconTemplate", first: true, predicate: ["filtericon"], isSignal: true }, { propertyName: "removeTokenIconTemplate", first: true, predicate: ["removetokenicon"], isSignal: true }, { propertyName: "chipIconTemplate", first: true, predicate: ["chipicon"], isSignal: true }, { propertyName: "clearIconTemplate", first: true, predicate: ["clearicon"], isSignal: true }, { propertyName: "dropdownIconTemplate", first: true, predicate: ["dropdownicon"], isSignal: true }, { propertyName: "itemCheckboxIconTemplate", first: true, predicate: ["itemcheckboxicon"], isSignal: true }, { propertyName: "headerCheckboxIconTemplate", first: true, predicate: ["headercheckboxicon"], isSignal: true }], viewQueries: [{ propertyName: "overlayViewChild", first: true, predicate: ["overlay"], descendants: true, isSignal: true }, { propertyName: "filterInputChild", first: true, predicate: ["filterInput"], descendants: true, isSignal: true }, { propertyName: "focusInputViewChild", first: true, predicate: ["focusInput"], descendants: true, isSignal: true }, { propertyName: "itemsViewChild", first: true, predicate: ["items"], descendants: true, isSignal: true }, { propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true, isSignal: true }, { propertyName: "lastHiddenFocusableElementOnOverlay", first: true, predicate: ["lastHiddenFocusableEl"], descendants: true, isSignal: true }, { propertyName: "firstHiddenFocusableElementOnOverlay", first: true, predicate: ["firstHiddenFocusableEl"], descendants: true, isSignal: true }, { propertyName: "headerCheckboxViewChild", first: true, predicate: ["headerCheckbox"], descendants: true, isSignal: true }], usesInheritance: true, hostDirectives: [{ directive: i1$1.Bind }], ngImport: i0, template: `
1884
+ <div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true" [pBind]="ptm('hiddenInputContainer')">
1885
+ <input
1886
+ #focusInput
1887
+ [pTooltip]="tooltip()"
1888
+ [pTooltipUnstyled]="unstyled()"
1889
+ [tooltipPosition]="tooltipPosition()"
1890
+ [positionStyle]="tooltipPositionStyle()"
1891
+ [tooltipStyleClass]="tooltipStyleClass()"
1892
+ [attr.aria-disabled]="$disabled()"
1893
+ [attr.id]="inputId()"
1894
+ role="combobox"
1895
+ [attr.aria-label]="ariaLabel()"
1896
+ [attr.aria-labelledby]="ariaLabelledBy()"
1897
+ [attr.aria-haspopup]="'listbox'"
1898
+ [attr.aria-expanded]="ariaExpanded()"
1899
+ [attr.aria-controls]="ariaControls()"
1900
+ [attr.tabindex]="inputTabindex()"
1901
+ [attr.aria-activedescendant]="ariaActivedescendant"
1902
+ (focus)="onInputFocus($event)"
1903
+ (blur)="onInputBlur($event)"
1904
+ (keydown)="onKeyDown($event)"
1905
+ [pAutoFocus]="autofocus()"
1906
+ [attr.value]="modelValue()"
1907
+ [attr.name]="name()"
1908
+ [attr.required]="requiredAttr()"
1909
+ [attr.disabled]="disabledAttr()"
1910
+ [pBind]="ptm('hiddenInput')"
1911
+ />
1912
+ </div>
1913
+ <div
1914
+ [pBind]="ptm('labelContainer')"
1915
+ [class]="cx('labelContainer')"
1916
+ [pTooltip]="tooltip()"
1917
+ [pTooltipUnstyled]="unstyled()"
1918
+ (mouseleave)="labelContainerMouseLeave()"
1919
+ [tooltipDisabled]="_disableTooltip"
1920
+ [tooltipPosition]="tooltipPosition()"
1921
+ [positionStyle]="tooltipPositionStyle()"
1922
+ [tooltipStyleClass]="tooltipStyleClass()"
1923
+ >
1924
+ <div [pBind]="ptm('label')" [class]="cx('label')" [attr.data-p]="labelDataP()">
1925
+ @if (!selectedItemsTemplate()) {
1926
+ @if (isCommaDisplay()) {
1927
+ {{ labelDisplay() }}
1928
+ }
1929
+ @if (isChipDisplay()) {
1930
+ @if (showSelectedItemsLabel()) {
1931
+ {{ getSelectedItemsLabel() }}
1932
+ } @else {
1933
+ @for (item of chipSelectedItems(); track $index) {
1934
+ <div #token [pBind]="ptm('chipItem')" [class]="cx('chipItem')">
1935
+ <p-chip [pt]="ptm('pcChip')" [unstyled]="unstyled()" [class]="cx('pcChip')" [label]="getLabelByValue(item)" [removable]="isEditable()" (onRemove)="removeOption(item, $event)" [removeIcon]="chipIcon()">
1936
+ @if (hasChipRemoveIconTemplate()) {
1937
+ <ng-template #removeicon>
1938
+ @if (isEditable()) {
1939
+ <span [class]="cx('chipIcon')" (click)="removeOption(item, $event)" [attr.aria-hidden]="true" [pBind]="ptm('chipIcon')">
1940
+ <ng-container *ngTemplateOutlet="chipIconTemplate() || removeTokenIconTemplate(); context: chipIconContext"></ng-container>
1941
+ </span>
1942
+ }
1943
+ </ng-template>
1944
+ }
1945
+ </p-chip>
1946
+ </div>
1947
+ }
1948
+ }
1949
+ @if (isModelEmpty()) {
1950
+ {{ placeholderLabel() }}
1951
+ }
1952
+ }
1953
+ } @else {
1954
+ <ng-container *ngTemplateOutlet="selectedItemsTemplate(); context: selectedItemsContext()"></ng-container>
1955
+ @if (isModelEmpty()) {
1956
+ {{ placeholderLabel() }}
1957
+ }
1958
+ }
1959
+ </div>
1960
+ </div>
1961
+ @if (isVisibleClearIcon()) {
1962
+ @if (!clearIconTemplate()) {
1963
+ <svg data-p-icon="times" [pBind]="ptm('clearIcon')" [class]="cx('clearIcon')" (click)="clear($event)" [attr.aria-hidden]="true" />
1964
+ } @else {
1965
+ <span [pBind]="ptm('clearIcon')" [class]="cx('clearIcon')" (click)="clear($event)" [attr.aria-hidden]="true">
1966
+ <ng-template *ngTemplateOutlet="clearIconTemplate()"></ng-template>
1967
+ </span>
1968
+ }
1969
+ }
1970
+ <div [pBind]="ptm('dropdown')" [class]="cx('dropdown')">
1971
+ @if (loading()) {
1972
+ @if (loadingIconTemplate()) {
1973
+ <ng-container *ngTemplateOutlet="loadingIconTemplate()"></ng-container>
1974
+ } @else {
1975
+ @if (loadingIcon()) {
1976
+ <span [pBind]="ptm('loadingIcon')" [class]="cn(cx('loadingIcon'), 'pi-spin ' + loadingIcon())" [attr.aria-hidden]="true"></span>
1977
+ } @else {
1978
+ <span [pBind]="ptm('loadingIcon')" [class]="cn(cx('loadingIcon'), 'pi pi-spinner pi-spin')" [attr.aria-hidden]="true"></span>
1979
+ }
1980
+ }
1981
+ } @else {
1982
+ @if (!dropdownIconTemplate()) {
1983
+ @if (dropdownIcon()) {
1984
+ <span [pBind]="ptm('dropdownIcon')" [class]="cn(cx('dropdownIcon'), dropdownIcon())" [attr.aria-hidden]="true" [attr.data-p]="dropdownIconDataP()"></span>
1985
+ } @else {
1986
+ <svg data-p-icon="chevron-down" [pBind]="ptm('dropdownIcon')" [class]="cx('dropdownIcon')" [attr.aria-hidden]="true" [attr.data-p]="dropdownIconDataP()" />
1987
+ }
1988
+ } @else {
1989
+ <span [pBind]="ptm('dropdownIcon')" [class]="cx('dropdownIcon')" [attr.aria-hidden]="true">
1990
+ <ng-template *ngTemplateOutlet="dropdownIconTemplate(); context: dropdownIconContext()"></ng-template>
1991
+ </span>
1992
+ }
1993
+ }
1994
+ </div>
1995
+ <p-overlay
1996
+ #overlay
1997
+ [hostAttrSelector]="$attrSelector"
1998
+ [visible]="overlayVisible()"
1999
+ (visibleChange)="overlayVisible.set($event)"
2000
+ [options]="overlayOptions()"
2001
+ [target]="'@parent'"
2002
+ [appendTo]="$appendTo()"
2003
+ [unstyled]="unstyled()"
2004
+ [pt]="ptm('pcOverlay')"
2005
+ [motionOptions]="motionOptions()"
2006
+ (onBeforeEnter)="onOverlayBeforeEnter($event)"
2007
+ (onAfterLeave)="onOverlayAfterLeave($event)"
2008
+ (onHide)="onOverlayHide($event)"
2009
+ >
2010
+ <ng-template #content>
2011
+ <div [pBind]="ptm('overlay')" [attr.data-p]="overlayDataP()" [attr.id]="listId()" [class]="cn(cx('overlay'), panelStyleClass())" [style]="panelStyle()">
2012
+ <span
2013
+ #firstHiddenFocusableEl
2014
+ role="presentation"
2015
+ class="p-hidden-accessible p-hidden-focusable"
2016
+ [attr.tabindex]="0"
2017
+ (focus)="onFirstHiddenFocus($event)"
2018
+ [attr.data-p-hidden-accessible]="true"
2019
+ [attr.data-p-hidden-focusable]="true"
2020
+ [pBind]="ptm('firstHiddenFocusableEl')"
2021
+ >
2022
+ </span>
2023
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
2024
+ @if (showHeader()) {
2025
+ <div [pBind]="ptm('header')" [class]="cx('header')">
2026
+ <ng-content select="p-header"></ng-content>
2027
+ @if (filterTemplate()) {
2028
+ <ng-container *ngTemplateOutlet="filterTemplate(); context: filterContext()"></ng-container>
2029
+ } @else {
2030
+ @if (showToggleAllCheckbox()) {
2031
+ <p-checkbox
2032
+ [pt]="getHeaderCheckboxPTOptions('pcHeaderCheckbox')"
2033
+ [ngModel]="allSelected()"
2034
+ [ariaLabel]="toggleAllAriaLabel"
2035
+ [binary]="true"
2036
+ (onChange)="onToggleAll($event)"
2037
+ [variant]="$variant()"
2038
+ [disabled]="$disabled()"
2039
+ [unstyled]="unstyled()"
2040
+ #headerCheckbox
2041
+ >
2042
+ <ng-template #icon let-klass="class">
2043
+ @if (showDefaultHeaderCheckIcon()) {
2044
+ <svg data-p-icon="check" [class]="klass" [pBind]="getHeaderCheckboxPTOptions('pcHeaderCheckbox.icon')" />
2045
+ }
2046
+ <ng-template *ngTemplateOutlet="headerCheckboxIconTemplate(); context: getHeaderCheckboxIconContext(klass)"></ng-template>
2047
+ </ng-template>
2048
+ </p-checkbox>
2049
+ }
2050
+
2051
+ @if (filter()) {
2052
+ <p-iconfield [pt]="ptm('pcFilterContainer')" [class]="cx('pcFilterContainer')" [unstyled]="unstyled()">
2053
+ <input
2054
+ #filterInput
2055
+ pInputText
2056
+ [pt]="ptm('pcFilter')"
2057
+ [variant]="$variant()"
2058
+ type="text"
2059
+ [attr.autocomplete]="autocomplete()"
2060
+ role="searchbox"
2061
+ [attr.aria-owns]="listId()"
2062
+ [attr.aria-activedescendant]="focusedOptionId"
2063
+ [value]="filterInputValue()"
2064
+ (input)="onFilterInputChange($event)"
2065
+ (keydown)="onFilterKeyDown($event)"
2066
+ (click)="onInputClick($event)"
2067
+ (blur)="onFilterBlur($event)"
2068
+ [class]="cx('pcFilter')"
2069
+ [attr.disabled]="disabledAttr()"
2070
+ [attr.placeholder]="filterPlaceHolder()"
2071
+ [attr.aria-label]="ariaFilterLabel()"
2072
+ [unstyled]="unstyled()"
2073
+ />
2074
+ <p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
2075
+ @if (!filterIconTemplate()) {
2076
+ <svg data-p-icon="search" [pBind]="ptm('filterIcon')" />
2077
+ } @else {
2078
+ <span [pBind]="ptm('filterIcon')" class="p-multiselect-filter-icon">
2079
+ <ng-template *ngTemplateOutlet="filterIconTemplate()"></ng-template>
2080
+ </span>
2081
+ }
2082
+ </p-inputicon>
2083
+ </p-iconfield>
2084
+ }
2085
+ }
2086
+ </div>
2087
+ }
2088
+ <div [pBind]="ptm('listContainer')" [class]="cx('listContainer')" [style.max-height]="listContainerMaxHeight()">
2089
+ @if (virtualScroll()) {
2090
+ <p-scroller
2091
+ #scroller
2092
+ [items]="visibleOptions()"
2093
+ [style]="{ height: scrollHeight() }"
2094
+ [itemSize]="virtualScrollItemSize()"
2095
+ [autoSize]="true"
2096
+ [tabindex]="-1"
2097
+ [lazy]="lazy()"
2098
+ (onLazyLoad)="onLazyLoad.emit($event)"
2099
+ [options]="virtualScrollOptions()"
2100
+ >
2101
+ <ng-template #content let-items let-scrollerOptions="options">
2102
+ <ng-container *ngTemplateOutlet="buildInItems; context: getScrollerItemsContext(items, scrollerOptions)"></ng-container>
2103
+ </ng-template>
2104
+ @if (loaderTemplate()) {
2105
+ <ng-template #loader let-scrollerOptions="options">
2106
+ <ng-container *ngTemplateOutlet="loaderTemplate(); context: getLoaderContext(scrollerOptions)"></ng-container>
2107
+ </ng-template>
2108
+ }
2109
+ </p-scroller>
2110
+ } @else {
2111
+ <ng-container *ngTemplateOutlet="buildInItems; context: defaultItemsContext()"></ng-container>
2112
+ }
2113
+
2114
+ <ng-template #buildInItems let-items let-scrollerOptions="options">
2115
+ <ul #items [pBind]="ptm('list')" [class]="cn(cx('list'), scrollerOptions.contentStyleClass)" [style]="scrollerOptions.contentStyle" role="listbox" aria-multiselectable="true" [attr.aria-label]="listLabel">
2116
+ @for (option of items; track getOptionIndex(i, scrollerOptions); let i = $index) {
2117
+ @if (isOptionGroup(option)) {
2118
+ <li [pBind]="ptm('optionGroup')" [attr.id]="$id() + '_' + getOptionIndex(i, scrollerOptions)" [class]="cx('optionGroup')" [style.height.px]="scrollerOptions.itemSize" role="option">
2119
+ @if (!groupTemplate() && option.optionGroup) {
2120
+ <span>{{ getOptionGroupLabel(option.optionGroup) }}</span>
2121
+ }
2122
+ @if (option.optionGroup && groupTemplate()) {
2123
+ <ng-container [ngTemplateOutlet]="groupTemplate()" [ngTemplateOutletContext]="getGroupContext(option)"></ng-container>
2124
+ }
2125
+ </li>
2126
+ } @else {
2127
+ <li
2128
+ pMultiSelectItem
2129
+ pRipple
2130
+ [pBind]="getPTOptions(option, getItemOptions, i, 'option')"
2131
+ [id]="$id() + '_' + getOptionIndex(i, scrollerOptions)"
2132
+ [option]="option"
2133
+ [selected]="isSelected(option)"
2134
+ [label]="getOptionLabel(option)"
2135
+ [disabled]="isOptionDisabled(option)"
2136
+ [template]="itemTemplate()"
2137
+ [itemCheckboxIconTemplate]="itemCheckboxIconTemplate()"
2138
+ [itemSize]="scrollerOptions.itemSize"
2139
+ [focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
2140
+ [ariaPosInset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
2141
+ [ariaSetSize]="$ariaSetSize()"
2142
+ [variant]="$variant()"
2143
+ [highlightOnSelect]="highlightOnSelect()"
2144
+ (onClick)="onOptionSelect($event, false, getOptionIndex(i, scrollerOptions))"
2145
+ (onMouseEnter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
2146
+ [pt]="pt"
2147
+ [unstyled]="unstyled()"
2148
+ ></li>
2149
+ }
2150
+ }
2151
+
2152
+ @if (showEmptyFilterMessage()) {
2153
+ <li [pBind]="ptm('emptyMessage')" [class]="cx('emptyMessage')" [style.height.px]="scrollerOptions.itemSize" role="option">
2154
+ @if (!emptyFilterTemplate() && !emptyTemplate()) {
2155
+ {{ emptyFilterMessageLabel() }}
2156
+ } @else {
2157
+ <ng-container *ngTemplateOutlet="emptyFilterTemplate() || emptyTemplate()"></ng-container>
2158
+ }
2159
+ </li>
2160
+ }
2161
+ @if (showEmptyMessage()) {
2162
+ <li [pBind]="ptm('emptyMessage')" [class]="cx('emptyMessage')" [style.height.px]="scrollerOptions.itemSize" role="option">
2163
+ @if (!emptyTemplate()) {
2164
+ {{ emptyMessageLabel() }}
2165
+ } @else {
2166
+ <ng-container *ngTemplateOutlet="emptyTemplate()"></ng-container>
2167
+ }
2168
+ </li>
2169
+ }
2170
+ </ul>
2171
+ </ng-template>
2172
+ </div>
2173
+ @if (hasFooterContent()) {
2174
+ <div>
2175
+ <ng-content select="p-footer"></ng-content>
2176
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
2177
+ </div>
2178
+ }
2179
+
2180
+ <span
2181
+ #lastHiddenFocusableEl
2182
+ role="presentation"
2183
+ class="p-hidden-accessible p-hidden-focusable"
2184
+ [attr.tabindex]="0"
2185
+ (focus)="onLastHiddenFocus($event)"
2186
+ [attr.data-p-hidden-accessible]="true"
2187
+ [attr.data-p-hidden-focusable]="true"
2188
+ [pBind]="ptm('lastHiddenFocusableEl')"
2189
+ ></span>
2190
+ </div>
2191
+ </ng-template>
2192
+ </p-overlay>
2193
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: MultiSelectItem, selector: "li[pMultiSelectItem]", inputs: ["option", "selected", "label", "disabled", "itemSize", "focused", "ariaPosInset", "ariaSetSize", "variant", "template", "checkIconTemplate", "itemCheckboxIconTemplate", "highlightOnSelect"], outputs: ["onClick", "onMouseEnter"] }, { kind: "component", type: Overlay, selector: "p-overlay", inputs: ["hostName", "visible", "mode", "style", "styleClass", "contentStyle", "contentStyleClass", "target", "autoZIndex", "baseZIndex", "listener", "responsive", "options", "appendTo", "inline", "motionOptions", "hostAttrSelector"], outputs: ["visibleChange", "onBeforeShow", "onShow", "onBeforeHide", "onHide", "onAnimationStart", "onAnimationDone", "onBeforeEnter", "onEnter", "onAfterEnter", "onBeforeLeave", "onLeave", "onAfterLeave"] }, { kind: "ngmodule", type: SharedModule }, { kind: "directive", type: Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "showOnEllipsis", "pTooltip", "tooltipDisabled", "tooltipOptions", "appendTo", "pTooltipPT", "pTooltipUnstyled"] }, { 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: "directive", type: AutoFocus, selector: "[pAutoFocus]", inputs: ["pAutoFocus"] }, { kind: "component", type: Check, selector: "svg[data-p-icon=\"check\"]" }, { kind: "component", type: Search, selector: "svg[data-p-icon=\"search\"]" }, { kind: "component", type: Times, selector: "svg[data-p-icon=\"times\"]" }, { kind: "component", type: ChevronDown, selector: "svg[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: IconField, selector: "p-iconfield, p-icon-field", inputs: ["hostName", "iconPosition"] }, { kind: "component", type: InputIcon, selector: "p-inputicon", inputs: ["hostName"] }, { kind: "directive", type: InputText, selector: "[pInputText]", inputs: ["hostName", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: Chip, selector: "p-chip", inputs: ["label", "icon", "image", "alt", "disabled", "removable", "removeIcon", "chipProps"], outputs: ["onRemove", "onImageError"] }, { 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: "ngmodule", type: BindModule }, { kind: "directive", type: i1$1.Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
2194
+ }
2195
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelect, decorators: [{
2196
+ type: Component,
2197
+ args: [{
2198
+ selector: 'p-multiselect, p-multi-select',
2199
+ standalone: true,
2200
+ imports: [NgTemplateOutlet, MultiSelectItem, Overlay, SharedModule, Tooltip, Scroller, AutoFocus, Check, Search, Times, ChevronDown, IconField, InputIcon, InputText, Chip, Checkbox, FormsModule, BindModule],
2201
+ hostDirectives: [Bind],
2202
+ template: `
2203
+ <div class="p-hidden-accessible" [attr.data-p-hidden-accessible]="true" [pBind]="ptm('hiddenInputContainer')">
2204
+ <input
2205
+ #focusInput
2206
+ [pTooltip]="tooltip()"
2207
+ [pTooltipUnstyled]="unstyled()"
2208
+ [tooltipPosition]="tooltipPosition()"
2209
+ [positionStyle]="tooltipPositionStyle()"
2210
+ [tooltipStyleClass]="tooltipStyleClass()"
2211
+ [attr.aria-disabled]="$disabled()"
2212
+ [attr.id]="inputId()"
2213
+ role="combobox"
2214
+ [attr.aria-label]="ariaLabel()"
2215
+ [attr.aria-labelledby]="ariaLabelledBy()"
2216
+ [attr.aria-haspopup]="'listbox'"
2217
+ [attr.aria-expanded]="ariaExpanded()"
2218
+ [attr.aria-controls]="ariaControls()"
2219
+ [attr.tabindex]="inputTabindex()"
2220
+ [attr.aria-activedescendant]="ariaActivedescendant"
2221
+ (focus)="onInputFocus($event)"
2222
+ (blur)="onInputBlur($event)"
2223
+ (keydown)="onKeyDown($event)"
2224
+ [pAutoFocus]="autofocus()"
2225
+ [attr.value]="modelValue()"
2226
+ [attr.name]="name()"
2227
+ [attr.required]="requiredAttr()"
2228
+ [attr.disabled]="disabledAttr()"
2229
+ [pBind]="ptm('hiddenInput')"
2230
+ />
2231
+ </div>
2232
+ <div
2233
+ [pBind]="ptm('labelContainer')"
2234
+ [class]="cx('labelContainer')"
2235
+ [pTooltip]="tooltip()"
2236
+ [pTooltipUnstyled]="unstyled()"
2237
+ (mouseleave)="labelContainerMouseLeave()"
2238
+ [tooltipDisabled]="_disableTooltip"
2239
+ [tooltipPosition]="tooltipPosition()"
2240
+ [positionStyle]="tooltipPositionStyle()"
2241
+ [tooltipStyleClass]="tooltipStyleClass()"
2242
+ >
2243
+ <div [pBind]="ptm('label')" [class]="cx('label')" [attr.data-p]="labelDataP()">
2244
+ @if (!selectedItemsTemplate()) {
2245
+ @if (isCommaDisplay()) {
2246
+ {{ labelDisplay() }}
2247
+ }
2248
+ @if (isChipDisplay()) {
2249
+ @if (showSelectedItemsLabel()) {
2250
+ {{ getSelectedItemsLabel() }}
2251
+ } @else {
2252
+ @for (item of chipSelectedItems(); track $index) {
2253
+ <div #token [pBind]="ptm('chipItem')" [class]="cx('chipItem')">
2254
+ <p-chip [pt]="ptm('pcChip')" [unstyled]="unstyled()" [class]="cx('pcChip')" [label]="getLabelByValue(item)" [removable]="isEditable()" (onRemove)="removeOption(item, $event)" [removeIcon]="chipIcon()">
2255
+ @if (hasChipRemoveIconTemplate()) {
2256
+ <ng-template #removeicon>
2257
+ @if (isEditable()) {
2258
+ <span [class]="cx('chipIcon')" (click)="removeOption(item, $event)" [attr.aria-hidden]="true" [pBind]="ptm('chipIcon')">
2259
+ <ng-container *ngTemplateOutlet="chipIconTemplate() || removeTokenIconTemplate(); context: chipIconContext"></ng-container>
2260
+ </span>
2261
+ }
2262
+ </ng-template>
2263
+ }
2264
+ </p-chip>
2265
+ </div>
2266
+ }
2267
+ }
2268
+ @if (isModelEmpty()) {
2269
+ {{ placeholderLabel() }}
2270
+ }
2271
+ }
2272
+ } @else {
2273
+ <ng-container *ngTemplateOutlet="selectedItemsTemplate(); context: selectedItemsContext()"></ng-container>
2274
+ @if (isModelEmpty()) {
2275
+ {{ placeholderLabel() }}
2276
+ }
2277
+ }
2278
+ </div>
2279
+ </div>
2280
+ @if (isVisibleClearIcon()) {
2281
+ @if (!clearIconTemplate()) {
2282
+ <svg data-p-icon="times" [pBind]="ptm('clearIcon')" [class]="cx('clearIcon')" (click)="clear($event)" [attr.aria-hidden]="true" />
2283
+ } @else {
2284
+ <span [pBind]="ptm('clearIcon')" [class]="cx('clearIcon')" (click)="clear($event)" [attr.aria-hidden]="true">
2285
+ <ng-template *ngTemplateOutlet="clearIconTemplate()"></ng-template>
2286
+ </span>
2287
+ }
2288
+ }
2289
+ <div [pBind]="ptm('dropdown')" [class]="cx('dropdown')">
2290
+ @if (loading()) {
2291
+ @if (loadingIconTemplate()) {
2292
+ <ng-container *ngTemplateOutlet="loadingIconTemplate()"></ng-container>
2293
+ } @else {
2294
+ @if (loadingIcon()) {
2295
+ <span [pBind]="ptm('loadingIcon')" [class]="cn(cx('loadingIcon'), 'pi-spin ' + loadingIcon())" [attr.aria-hidden]="true"></span>
2296
+ } @else {
2297
+ <span [pBind]="ptm('loadingIcon')" [class]="cn(cx('loadingIcon'), 'pi pi-spinner pi-spin')" [attr.aria-hidden]="true"></span>
2298
+ }
2299
+ }
2300
+ } @else {
2301
+ @if (!dropdownIconTemplate()) {
2302
+ @if (dropdownIcon()) {
2303
+ <span [pBind]="ptm('dropdownIcon')" [class]="cn(cx('dropdownIcon'), dropdownIcon())" [attr.aria-hidden]="true" [attr.data-p]="dropdownIconDataP()"></span>
2304
+ } @else {
2305
+ <svg data-p-icon="chevron-down" [pBind]="ptm('dropdownIcon')" [class]="cx('dropdownIcon')" [attr.aria-hidden]="true" [attr.data-p]="dropdownIconDataP()" />
2306
+ }
2307
+ } @else {
2308
+ <span [pBind]="ptm('dropdownIcon')" [class]="cx('dropdownIcon')" [attr.aria-hidden]="true">
2309
+ <ng-template *ngTemplateOutlet="dropdownIconTemplate(); context: dropdownIconContext()"></ng-template>
2310
+ </span>
2311
+ }
2312
+ }
2313
+ </div>
2314
+ <p-overlay
2315
+ #overlay
2316
+ [hostAttrSelector]="$attrSelector"
2317
+ [visible]="overlayVisible()"
2318
+ (visibleChange)="overlayVisible.set($event)"
2319
+ [options]="overlayOptions()"
2320
+ [target]="'@parent'"
2321
+ [appendTo]="$appendTo()"
2322
+ [unstyled]="unstyled()"
2323
+ [pt]="ptm('pcOverlay')"
2324
+ [motionOptions]="motionOptions()"
2325
+ (onBeforeEnter)="onOverlayBeforeEnter($event)"
2326
+ (onAfterLeave)="onOverlayAfterLeave($event)"
2327
+ (onHide)="onOverlayHide($event)"
2328
+ >
2329
+ <ng-template #content>
2330
+ <div [pBind]="ptm('overlay')" [attr.data-p]="overlayDataP()" [attr.id]="listId()" [class]="cn(cx('overlay'), panelStyleClass())" [style]="panelStyle()">
2331
+ <span
2332
+ #firstHiddenFocusableEl
2333
+ role="presentation"
2334
+ class="p-hidden-accessible p-hidden-focusable"
2335
+ [attr.tabindex]="0"
2336
+ (focus)="onFirstHiddenFocus($event)"
2337
+ [attr.data-p-hidden-accessible]="true"
2338
+ [attr.data-p-hidden-focusable]="true"
2339
+ [pBind]="ptm('firstHiddenFocusableEl')"
2340
+ >
2341
+ </span>
2342
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
2343
+ @if (showHeader()) {
2344
+ <div [pBind]="ptm('header')" [class]="cx('header')">
2345
+ <ng-content select="p-header"></ng-content>
2346
+ @if (filterTemplate()) {
2347
+ <ng-container *ngTemplateOutlet="filterTemplate(); context: filterContext()"></ng-container>
2348
+ } @else {
2349
+ @if (showToggleAllCheckbox()) {
2350
+ <p-checkbox
2351
+ [pt]="getHeaderCheckboxPTOptions('pcHeaderCheckbox')"
2352
+ [ngModel]="allSelected()"
2353
+ [ariaLabel]="toggleAllAriaLabel"
2354
+ [binary]="true"
2355
+ (onChange)="onToggleAll($event)"
2356
+ [variant]="$variant()"
2357
+ [disabled]="$disabled()"
2358
+ [unstyled]="unstyled()"
2359
+ #headerCheckbox
2360
+ >
2361
+ <ng-template #icon let-klass="class">
2362
+ @if (showDefaultHeaderCheckIcon()) {
2363
+ <svg data-p-icon="check" [class]="klass" [pBind]="getHeaderCheckboxPTOptions('pcHeaderCheckbox.icon')" />
2364
+ }
2365
+ <ng-template *ngTemplateOutlet="headerCheckboxIconTemplate(); context: getHeaderCheckboxIconContext(klass)"></ng-template>
2366
+ </ng-template>
2367
+ </p-checkbox>
2368
+ }
2369
+
2370
+ @if (filter()) {
2371
+ <p-iconfield [pt]="ptm('pcFilterContainer')" [class]="cx('pcFilterContainer')" [unstyled]="unstyled()">
2372
+ <input
2373
+ #filterInput
2374
+ pInputText
2375
+ [pt]="ptm('pcFilter')"
2376
+ [variant]="$variant()"
2377
+ type="text"
2378
+ [attr.autocomplete]="autocomplete()"
2379
+ role="searchbox"
2380
+ [attr.aria-owns]="listId()"
2381
+ [attr.aria-activedescendant]="focusedOptionId"
2382
+ [value]="filterInputValue()"
2383
+ (input)="onFilterInputChange($event)"
2384
+ (keydown)="onFilterKeyDown($event)"
2385
+ (click)="onInputClick($event)"
2386
+ (blur)="onFilterBlur($event)"
2387
+ [class]="cx('pcFilter')"
2388
+ [attr.disabled]="disabledAttr()"
2389
+ [attr.placeholder]="filterPlaceHolder()"
2390
+ [attr.aria-label]="ariaFilterLabel()"
2391
+ [unstyled]="unstyled()"
2392
+ />
2393
+ <p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
2394
+ @if (!filterIconTemplate()) {
2395
+ <svg data-p-icon="search" [pBind]="ptm('filterIcon')" />
2396
+ } @else {
2397
+ <span [pBind]="ptm('filterIcon')" class="p-multiselect-filter-icon">
2398
+ <ng-template *ngTemplateOutlet="filterIconTemplate()"></ng-template>
2399
+ </span>
2400
+ }
2401
+ </p-inputicon>
2402
+ </p-iconfield>
2403
+ }
2404
+ }
2405
+ </div>
2406
+ }
2407
+ <div [pBind]="ptm('listContainer')" [class]="cx('listContainer')" [style.max-height]="listContainerMaxHeight()">
2408
+ @if (virtualScroll()) {
2409
+ <p-scroller
2410
+ #scroller
2411
+ [items]="visibleOptions()"
2412
+ [style]="{ height: scrollHeight() }"
2413
+ [itemSize]="virtualScrollItemSize()"
2414
+ [autoSize]="true"
2415
+ [tabindex]="-1"
2416
+ [lazy]="lazy()"
2417
+ (onLazyLoad)="onLazyLoad.emit($event)"
2418
+ [options]="virtualScrollOptions()"
2419
+ >
2420
+ <ng-template #content let-items let-scrollerOptions="options">
2421
+ <ng-container *ngTemplateOutlet="buildInItems; context: getScrollerItemsContext(items, scrollerOptions)"></ng-container>
2422
+ </ng-template>
2423
+ @if (loaderTemplate()) {
2424
+ <ng-template #loader let-scrollerOptions="options">
2425
+ <ng-container *ngTemplateOutlet="loaderTemplate(); context: getLoaderContext(scrollerOptions)"></ng-container>
2426
+ </ng-template>
2427
+ }
2428
+ </p-scroller>
2429
+ } @else {
2430
+ <ng-container *ngTemplateOutlet="buildInItems; context: defaultItemsContext()"></ng-container>
2431
+ }
2432
+
2433
+ <ng-template #buildInItems let-items let-scrollerOptions="options">
2434
+ <ul #items [pBind]="ptm('list')" [class]="cn(cx('list'), scrollerOptions.contentStyleClass)" [style]="scrollerOptions.contentStyle" role="listbox" aria-multiselectable="true" [attr.aria-label]="listLabel">
2435
+ @for (option of items; track getOptionIndex(i, scrollerOptions); let i = $index) {
2436
+ @if (isOptionGroup(option)) {
2437
+ <li [pBind]="ptm('optionGroup')" [attr.id]="$id() + '_' + getOptionIndex(i, scrollerOptions)" [class]="cx('optionGroup')" [style.height.px]="scrollerOptions.itemSize" role="option">
2438
+ @if (!groupTemplate() && option.optionGroup) {
2439
+ <span>{{ getOptionGroupLabel(option.optionGroup) }}</span>
2440
+ }
2441
+ @if (option.optionGroup && groupTemplate()) {
2442
+ <ng-container [ngTemplateOutlet]="groupTemplate()" [ngTemplateOutletContext]="getGroupContext(option)"></ng-container>
2443
+ }
2444
+ </li>
2445
+ } @else {
2446
+ <li
2447
+ pMultiSelectItem
2448
+ pRipple
2449
+ [pBind]="getPTOptions(option, getItemOptions, i, 'option')"
2450
+ [id]="$id() + '_' + getOptionIndex(i, scrollerOptions)"
2451
+ [option]="option"
2452
+ [selected]="isSelected(option)"
2453
+ [label]="getOptionLabel(option)"
2454
+ [disabled]="isOptionDisabled(option)"
2455
+ [template]="itemTemplate()"
2456
+ [itemCheckboxIconTemplate]="itemCheckboxIconTemplate()"
2457
+ [itemSize]="scrollerOptions.itemSize"
2458
+ [focused]="focusedOptionIndex() === getOptionIndex(i, scrollerOptions)"
2459
+ [ariaPosInset]="getAriaPosInset(getOptionIndex(i, scrollerOptions))"
2460
+ [ariaSetSize]="$ariaSetSize()"
2461
+ [variant]="$variant()"
2462
+ [highlightOnSelect]="highlightOnSelect()"
2463
+ (onClick)="onOptionSelect($event, false, getOptionIndex(i, scrollerOptions))"
2464
+ (onMouseEnter)="onOptionMouseEnter($event, getOptionIndex(i, scrollerOptions))"
2465
+ [pt]="pt"
2466
+ [unstyled]="unstyled()"
2467
+ ></li>
2468
+ }
2469
+ }
2470
+
2471
+ @if (showEmptyFilterMessage()) {
2472
+ <li [pBind]="ptm('emptyMessage')" [class]="cx('emptyMessage')" [style.height.px]="scrollerOptions.itemSize" role="option">
2473
+ @if (!emptyFilterTemplate() && !emptyTemplate()) {
2474
+ {{ emptyFilterMessageLabel() }}
2475
+ } @else {
2476
+ <ng-container *ngTemplateOutlet="emptyFilterTemplate() || emptyTemplate()"></ng-container>
2477
+ }
2478
+ </li>
2479
+ }
2480
+ @if (showEmptyMessage()) {
2481
+ <li [pBind]="ptm('emptyMessage')" [class]="cx('emptyMessage')" [style.height.px]="scrollerOptions.itemSize" role="option">
2482
+ @if (!emptyTemplate()) {
2483
+ {{ emptyMessageLabel() }}
2484
+ } @else {
2485
+ <ng-container *ngTemplateOutlet="emptyTemplate()"></ng-container>
2486
+ }
2487
+ </li>
2488
+ }
2489
+ </ul>
2490
+ </ng-template>
2491
+ </div>
2492
+ @if (hasFooterContent()) {
2493
+ <div>
2494
+ <ng-content select="p-footer"></ng-content>
2495
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
2496
+ </div>
2497
+ }
2498
+
2499
+ <span
2500
+ #lastHiddenFocusableEl
2501
+ role="presentation"
2502
+ class="p-hidden-accessible p-hidden-focusable"
2503
+ [attr.tabindex]="0"
2504
+ (focus)="onLastHiddenFocus($event)"
2505
+ [attr.data-p-hidden-accessible]="true"
2506
+ [attr.data-p-hidden-focusable]="true"
2507
+ [pBind]="ptm('lastHiddenFocusableEl')"
2508
+ ></span>
2509
+ </div>
2510
+ </ng-template>
2511
+ </p-overlay>
2512
+ `,
2513
+ providers: [MULTISELECT_VALUE_ACCESSOR, MultiSelectStyle, { provide: MULTISELECT_INSTANCE, useExisting: MultiSelect }, { provide: PARENT_INSTANCE, useExisting: MultiSelect }],
2514
+ changeDetection: ChangeDetectionStrategy.OnPush,
2515
+ encapsulation: ViewEncapsulation.None,
2516
+ host: {
2517
+ '[attr.id]': '$id()',
2518
+ '[attr.data-p]': 'containerDataP',
2519
+ '(click)': 'onContainerClick($event)',
2520
+ '[class]': "cx('root')",
2521
+ '[style]': "sx('root')"
2522
+ }
2523
+ }]
2524
+ }], ctorParameters: () => [], propDecorators: { id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: false }] }], ariaLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabel", required: false }] }], panelStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "panelStyle", required: false }] }], panelStyleClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "panelStyleClass", required: false }] }], inputId: [{ type: i0.Input, args: [{ isSignal: true, alias: "inputId", required: false }] }], readonly: [{ type: i0.Input, args: [{ isSignal: true, alias: "readonly", required: false }] }], group: [{ type: i0.Input, args: [{ isSignal: true, alias: "group", required: false }] }], filter: [{ type: i0.Input, args: [{ isSignal: true, alias: "filter", required: false }] }], filterPlaceHolder: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterPlaceHolder", required: false }] }], filterLocale: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterLocale", required: false }] }], overlayVisible: [{ type: i0.Input, args: [{ isSignal: true, alias: "overlayVisible", required: false }] }, { type: i0.Output, args: ["overlayVisibleChange"] }], tabindex: [{ type: i0.Input, args: [{ isSignal: true, alias: "tabindex", required: false }] }], dataKey: [{ type: i0.Input, args: [{ isSignal: true, alias: "dataKey", required: false }] }], ariaLabelledBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabelledBy", required: false }] }], displaySelectedLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "displaySelectedLabel", required: false }] }], maxSelectedLabels: [{ type: i0.Input, args: [{ isSignal: true, alias: "maxSelectedLabels", required: false }] }], selectionLimit: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectionLimit", required: false }] }], selectedItemsLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectedItemsLabel", required: false }] }], showToggleAll: [{ type: i0.Input, args: [{ isSignal: true, alias: "showToggleAll", required: false }] }], emptyFilterMessage: [{ type: i0.Input, args: [{ isSignal: true, alias: "emptyFilterMessage", required: false }] }], emptyMessage: [{ type: i0.Input, args: [{ isSignal: true, alias: "emptyMessage", required: false }] }], resetFilterOnHide: [{ type: i0.Input, args: [{ isSignal: true, alias: "resetFilterOnHide", required: false }] }], dropdownIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "dropdownIcon", required: false }] }], chipIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "chipIcon", required: false }] }], optionLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "optionLabel", required: false }] }], optionValue: [{ type: i0.Input, args: [{ isSignal: true, alias: "optionValue", required: false }] }], optionDisabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "optionDisabled", required: false }] }], optionGroupLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "optionGroupLabel", required: false }] }], optionGroupChildren: [{ type: i0.Input, args: [{ isSignal: true, alias: "optionGroupChildren", required: false }] }], showHeader: [{ type: i0.Input, args: [{ isSignal: true, alias: "showHeader", required: false }] }], filterBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterBy", 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 }] }], loading: [{ type: i0.Input, args: [{ isSignal: true, alias: "loading", required: false }] }], virtualScrollItemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollItemSize", required: false }] }], loadingIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingIcon", required: false }] }], virtualScrollOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollOptions", required: false }] }], overlayOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "overlayOptions", required: false }] }], ariaFilterLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaFilterLabel", required: false }] }], filterMatchMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterMatchMode", required: false }] }], tooltip: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltip", required: false }] }], tooltipPosition: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipPosition", required: false }] }], tooltipPositionStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipPositionStyle", required: false }] }], tooltipStyleClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "tooltipStyleClass", required: false }] }], autofocusFilter: [{ type: i0.Input, args: [{ isSignal: true, alias: "autofocusFilter", required: false }] }], display: [{ type: i0.Input, args: [{ isSignal: true, alias: "display", required: false }] }], autocomplete: [{ type: i0.Input, args: [{ isSignal: true, alias: "autocomplete", required: false }] }], showClear: [{ type: i0.Input, args: [{ isSignal: true, alias: "showClear", required: false }] }], autofocus: [{ type: i0.Input, args: [{ isSignal: true, alias: "autofocus", required: false }] }], placeholder: [{ type: i0.Input, args: [{ isSignal: true, alias: "placeholder", required: false }] }], options: [{ type: i0.Input, args: [{ isSignal: true, alias: "options", required: false }] }], filterValue: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterValue", required: false }] }], selectAll: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectAll", required: false }] }], focusOnHover: [{ type: i0.Input, args: [{ isSignal: true, alias: "focusOnHover", required: false }] }], filterFields: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterFields", required: false }] }], selectOnFocus: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectOnFocus", required: false }] }], autoOptionFocus: [{ type: i0.Input, args: [{ isSignal: true, alias: "autoOptionFocus", required: false }] }], highlightOnSelect: [{ type: i0.Input, args: [{ isSignal: true, alias: "highlightOnSelect", required: false }] }], size: [{ type: i0.Input, args: [{ isSignal: true, alias: "size", required: false }] }], variant: [{ type: i0.Input, args: [{ isSignal: true, alias: "variant", required: false }] }], fluid: [{ type: i0.Input, args: [{ isSignal: true, alias: "fluid", required: false }] }], appendTo: [{ type: i0.Input, args: [{ isSignal: true, alias: "appendTo", required: false }] }], motionOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "motionOptions", required: false }] }], onChange: [{ type: i0.Output, args: ["onChange"] }], onFilter: [{ type: i0.Output, args: ["onFilter"] }], onFocus: [{ type: i0.Output, args: ["onFocus"] }], onBlur: [{ type: i0.Output, args: ["onBlur"] }], onClick: [{ type: i0.Output, args: ["onClick"] }], onClear: [{ type: i0.Output, args: ["onClear"] }], onPanelShow: [{ type: i0.Output, args: ["onPanelShow"] }], onPanelHide: [{ type: i0.Output, args: ["onPanelHide"] }], onLazyLoad: [{ type: i0.Output, args: ["onLazyLoad"] }], onRemove: [{ type: i0.Output, args: ["onRemove"] }], onSelectAllChange: [{ type: i0.Output, args: ["onSelectAllChange"] }], overlayViewChild: [{ type: i0.ViewChild, args: ['overlay', { isSignal: true }] }], filterInputChild: [{ type: i0.ViewChild, args: ['filterInput', { isSignal: true }] }], focusInputViewChild: [{ type: i0.ViewChild, args: ['focusInput', { isSignal: true }] }], itemsViewChild: [{ type: i0.ViewChild, args: ['items', { isSignal: true }] }], scroller: [{ type: i0.ViewChild, args: ['scroller', { isSignal: true }] }], lastHiddenFocusableElementOnOverlay: [{ type: i0.ViewChild, args: ['lastHiddenFocusableEl', { isSignal: true }] }], firstHiddenFocusableElementOnOverlay: [{ type: i0.ViewChild, args: ['firstHiddenFocusableEl', { isSignal: true }] }], headerCheckboxViewChild: [{ type: i0.ViewChild, args: ['headerCheckbox', { isSignal: true }] }], footerFacet: [{ type: i0.ContentChild, args: [i0.forwardRef(() => Footer), { ...{ descendants: false }, isSignal: true }] }], headerFacet: [{ type: i0.ContentChild, args: [i0.forwardRef(() => Header), { ...{ descendants: false }, isSignal: true }] }], itemTemplate: [{ type: i0.ContentChild, args: ['item', { ...{ descendants: false }, isSignal: true }] }], groupTemplate: [{ type: i0.ContentChild, args: ['group', { ...{ descendants: false }, isSignal: true }] }], loaderTemplate: [{ type: i0.ContentChild, args: ['loader', { ...{ descendants: false }, isSignal: true }] }], headerTemplate: [{ type: i0.ContentChild, args: ['header', { ...{ descendants: false }, isSignal: true }] }], filterTemplate: [{ type: i0.ContentChild, args: ['filter', { ...{ descendants: false }, isSignal: true }] }], footerTemplate: [{ type: i0.ContentChild, args: ['footer', { ...{ descendants: false }, isSignal: true }] }], emptyFilterTemplate: [{ type: i0.ContentChild, args: ['emptyfilter', { ...{ descendants: false }, isSignal: true }] }], emptyTemplate: [{ type: i0.ContentChild, args: ['empty', { ...{ descendants: false }, isSignal: true }] }], selectedItemsTemplate: [{ type: i0.ContentChild, args: ['selecteditems', { ...{ descendants: false }, isSignal: true }] }], loadingIconTemplate: [{ type: i0.ContentChild, args: ['loadingicon', { ...{ descendants: false }, isSignal: true }] }], filterIconTemplate: [{ type: i0.ContentChild, args: ['filtericon', { ...{ descendants: false }, isSignal: true }] }], removeTokenIconTemplate: [{ type: i0.ContentChild, args: ['removetokenicon', { ...{ descendants: false }, isSignal: true }] }], chipIconTemplate: [{ type: i0.ContentChild, args: ['chipicon', { ...{ descendants: false }, isSignal: true }] }], clearIconTemplate: [{ type: i0.ContentChild, args: ['clearicon', { ...{ descendants: false }, isSignal: true }] }], dropdownIconTemplate: [{ type: i0.ContentChild, args: ['dropdownicon', { ...{ descendants: false }, isSignal: true }] }], itemCheckboxIconTemplate: [{ type: i0.ContentChild, args: ['itemcheckboxicon', { ...{ descendants: false }, isSignal: true }] }], headerCheckboxIconTemplate: [{ type: i0.ContentChild, args: ['headercheckboxicon', { ...{ descendants: false }, isSignal: true }] }] } });
2525
+ class MultiSelectModule {
2526
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2527
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectModule, imports: [MultiSelect, SharedModule], exports: [MultiSelect, SharedModule] });
2528
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectModule, imports: [MultiSelect, SharedModule, SharedModule] });
2529
+ }
2530
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: MultiSelectModule, decorators: [{
2531
+ type: NgModule,
2532
+ args: [{
2533
+ imports: [MultiSelect, SharedModule],
2534
+ exports: [MultiSelect, SharedModule]
2535
+ }]
2536
+ }] });
2537
+
2538
+ /**
2539
+ * Generated bundle index. Do not edit.
2540
+ */
2541
+
2542
+ export { MULTISELECT_VALUE_ACCESSOR, MultiSelect, MultiSelectClasses, MultiSelectModule, MultiSelectStyle };
2543
+ //# sourceMappingURL=primenglab-multiselect.mjs.map