primeng 18.0.0 → 18.0.2-patch.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 (361) hide show
  1. package/accordion/accordion.d.ts +7 -7
  2. package/autocomplete/autocomplete.d.ts +21 -8
  3. package/badge/badge.d.ts +1 -3
  4. package/basecomponent/basecomponent.d.ts +2 -5
  5. package/blockui/blockui.d.ts +10 -5
  6. package/breadcrumb/breadcrumb.d.ts +9 -6
  7. package/button/button.d.ts +10 -4
  8. package/calendar/calendar.d.ts +29 -15
  9. package/card/card.d.ts +12 -5
  10. package/carousel/carousel.d.ts +10 -4
  11. package/cascadeselect/cascadeselect.d.ts +18 -8
  12. package/checkbox/checkbox.d.ts +8 -4
  13. package/chip/chip.d.ts +9 -7
  14. package/chips/chips.d.ts +237 -0
  15. package/chips/chips.interface.d.ts +66 -0
  16. package/chips/index.d.ts +5 -0
  17. package/chips/public_api.d.ts +2 -0
  18. package/chips/style/chipsstyle.d.ts +69 -0
  19. package/confirmdialog/confirmdialog.d.ts +14 -5
  20. package/confirmpopup/confirmpopup.d.ts +11 -5
  21. package/contextmenu/contextmenu.d.ts +10 -6
  22. package/datepicker/datepicker.d.ts +113 -33
  23. package/dialog/dialog.d.ts +15 -4
  24. package/divider/divider.d.ts +1 -1
  25. package/dock/dock.d.ts +7 -4
  26. package/drawer/drawer.d.ts +18 -10
  27. package/dropdown/dropdown.d.ts +4 -3
  28. package/dynamicdialog/dynamicdialog.d.ts +1 -0
  29. package/editor/editor.d.ts +7 -3
  30. package/esm2022/accordion/accordion.mjs +58 -43
  31. package/esm2022/autocomplete/autocomplete.mjs +153 -92
  32. package/esm2022/badge/badge.mjs +39 -32
  33. package/esm2022/basecomponent/basecomponent.mjs +3 -26
  34. package/esm2022/blockui/blockui.mjs +38 -18
  35. package/esm2022/breadcrumb/breadcrumb.mjs +50 -32
  36. package/esm2022/button/button.mjs +55 -28
  37. package/esm2022/calendar/calendar.mjs +207 -143
  38. package/esm2022/card/card.mjs +96 -46
  39. package/esm2022/carousel/carousel.mjs +74 -42
  40. package/esm2022/cascadeselect/cascadeselect.mjs +100 -62
  41. package/esm2022/checkbox/checkbox.mjs +32 -14
  42. package/esm2022/chip/chip.mjs +117 -96
  43. package/esm2022/chips/chips.interface.mjs +2 -0
  44. package/esm2022/chips/chips.mjs +827 -0
  45. package/esm2022/chips/primeng-chips.mjs +5 -0
  46. package/esm2022/chips/public_api.mjs +3 -0
  47. package/esm2022/chips/style/chipsstyle.mjs +175 -0
  48. package/esm2022/confirmdialog/confirmdialog.mjs +96 -57
  49. package/esm2022/confirmpopup/confirmpopup.mjs +57 -29
  50. package/esm2022/contextmenu/contextmenu.mjs +51 -20
  51. package/esm2022/datepicker/datepicker.mjs +198 -156
  52. package/esm2022/dialog/dialog.mjs +98 -52
  53. package/esm2022/divider/divider.mjs +2 -4
  54. package/esm2022/dock/dock.mjs +31 -13
  55. package/esm2022/drawer/drawer.mjs +112 -70
  56. package/esm2022/dropdown/dropdown.mjs +13 -5
  57. package/esm2022/dynamicdialog/dynamicdialog-config.mjs +13 -13
  58. package/esm2022/dynamicdialog/dynamicdialog.mjs +9 -5
  59. package/esm2022/editor/editor.mjs +27 -11
  60. package/esm2022/fieldset/fieldset.mjs +61 -33
  61. package/esm2022/fileupload/fileupload.mjs +139 -89
  62. package/esm2022/galleria/galleria.mjs +18 -9
  63. package/esm2022/image/image.mjs +113 -66
  64. package/esm2022/imagecompare/imagecompare.mjs +31 -11
  65. package/esm2022/inplace/inplace.mjs +49 -24
  66. package/esm2022/inputmask/inputmask.mjs +30 -14
  67. package/esm2022/inputmask/style/inputmaskstyle.mjs +2 -2
  68. package/esm2022/inputnumber/inputnumber.mjs +55 -47
  69. package/esm2022/inputotp/inputotp.mjs +30 -11
  70. package/esm2022/listbox/listbox.mjs +137 -78
  71. package/esm2022/megamenu/megamenu.mjs +105 -59
  72. package/esm2022/menu/menu.mjs +26 -26
  73. package/esm2022/menubar/menubar.mjs +70 -35
  74. package/esm2022/message/message.mjs +50 -26
  75. package/esm2022/messages/messages.mjs +13 -4
  76. package/esm2022/metergroup/metergroup.mjs +63 -31
  77. package/esm2022/multiselect/multiselect.mjs +247 -156
  78. package/esm2022/orderlist/orderlist.mjs +125 -70
  79. package/esm2022/organizationchart/organizationchart.mjs +30 -14
  80. package/esm2022/overlay/overlay.mjs +27 -7
  81. package/esm2022/overlaypanel/overlaypanel.mjs +33 -10
  82. package/esm2022/paginator/paginator.mjs +92 -60
  83. package/esm2022/panel/panel.mjs +160 -100
  84. package/esm2022/panelmenu/panelmenu.mjs +55 -32
  85. package/esm2022/password/password.mjs +88 -49
  86. package/esm2022/picklist/picklist.mjs +363 -259
  87. package/esm2022/popover/popover.mjs +29 -12
  88. package/esm2022/progressbar/progressbar.mjs +27 -9
  89. package/esm2022/rating/rating.mjs +46 -22
  90. package/esm2022/scroller/scroller.mjs +47 -37
  91. package/esm2022/scrollpanel/scrollpanel.mjs +28 -9
  92. package/esm2022/scrolltop/scrolltop.mjs +17 -10
  93. package/esm2022/select/select.mjs +198 -119
  94. package/esm2022/selectbutton/selectbutton.mjs +26 -11
  95. package/esm2022/sidebar/sidebar.mjs +82 -60
  96. package/esm2022/speeddial/speeddial.mjs +54 -29
  97. package/esm2022/splitbutton/splitbutton.mjs +41 -18
  98. package/esm2022/splitter/splitter.mjs +5 -5
  99. package/esm2022/stepper/stepper.mjs +27 -13
  100. package/esm2022/table/table.mjs +107 -96
  101. package/esm2022/tabmenu/tabmenu.mjs +54 -27
  102. package/esm2022/tabs/tablist.mjs +28 -20
  103. package/esm2022/tabview/tabview.mjs +106 -54
  104. package/esm2022/tag/tag.mjs +68 -44
  105. package/esm2022/tieredmenu/tieredmenu.mjs +44 -21
  106. package/esm2022/timeline/timeline.mjs +41 -17
  107. package/esm2022/toast/toast.mjs +31 -9
  108. package/esm2022/togglebutton/togglebutton.mjs +45 -30
  109. package/esm2022/toggleswitch/toggleswitch.mjs +28 -9
  110. package/esm2022/toolbar/toolbar.mjs +47 -21
  111. package/esm2022/tooltip/tooltip.mjs +35 -70
  112. package/esm2022/tree/tree.mjs +114 -97
  113. package/esm2022/treeselect/treeselect.mjs +156 -89
  114. package/esm2022/treetable/treetable.mjs +31 -12
  115. package/esm2022/usestyle/usestyle.mjs +2 -2
  116. package/fesm2022/primeng-accordion.mjs +59 -44
  117. package/fesm2022/primeng-accordion.mjs.map +1 -1
  118. package/fesm2022/primeng-animateonscroll.mjs +1 -1
  119. package/fesm2022/primeng-api.mjs +1 -1
  120. package/fesm2022/primeng-autocomplete.mjs +152 -91
  121. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  122. package/fesm2022/primeng-avatar.mjs +1 -1
  123. package/fesm2022/primeng-avatargroup.mjs +1 -1
  124. package/fesm2022/primeng-badge.mjs +40 -33
  125. package/fesm2022/primeng-badge.mjs.map +1 -1
  126. package/fesm2022/primeng-basecomponent.mjs +2 -25
  127. package/fesm2022/primeng-basecomponent.mjs.map +1 -1
  128. package/fesm2022/primeng-blockui.mjs +37 -17
  129. package/fesm2022/primeng-blockui.mjs.map +1 -1
  130. package/fesm2022/primeng-breadcrumb.mjs +49 -31
  131. package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
  132. package/fesm2022/primeng-button.mjs +54 -27
  133. package/fesm2022/primeng-button.mjs.map +1 -1
  134. package/fesm2022/primeng-buttongroup.mjs +1 -1
  135. package/fesm2022/primeng-calendar.mjs +207 -143
  136. package/fesm2022/primeng-calendar.mjs.map +1 -1
  137. package/fesm2022/primeng-card.mjs +95 -45
  138. package/fesm2022/primeng-card.mjs.map +1 -1
  139. package/fesm2022/primeng-carousel.mjs +73 -41
  140. package/fesm2022/primeng-carousel.mjs.map +1 -1
  141. package/fesm2022/primeng-cascadeselect.mjs +99 -61
  142. package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
  143. package/fesm2022/primeng-chart.mjs +1 -1
  144. package/fesm2022/primeng-checkbox.mjs +31 -13
  145. package/fesm2022/primeng-checkbox.mjs.map +1 -1
  146. package/fesm2022/primeng-chip.mjs +116 -95
  147. package/fesm2022/primeng-chip.mjs.map +1 -1
  148. package/fesm2022/primeng-chips.mjs +1006 -0
  149. package/fesm2022/primeng-chips.mjs.map +1 -0
  150. package/fesm2022/primeng-colorpicker.mjs +1 -1
  151. package/fesm2022/primeng-confirmdialog.mjs +95 -56
  152. package/fesm2022/primeng-confirmdialog.mjs.map +1 -1
  153. package/fesm2022/primeng-confirmpopup.mjs +57 -29
  154. package/fesm2022/primeng-confirmpopup.mjs.map +1 -1
  155. package/fesm2022/primeng-contextmenu.mjs +50 -19
  156. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  157. package/fesm2022/primeng-dataview.mjs +2 -2
  158. package/fesm2022/primeng-datepicker.mjs +198 -156
  159. package/fesm2022/primeng-datepicker.mjs.map +1 -1
  160. package/fesm2022/primeng-defer.mjs +1 -1
  161. package/fesm2022/primeng-dialog.mjs +97 -51
  162. package/fesm2022/primeng-dialog.mjs.map +1 -1
  163. package/fesm2022/primeng-divider.mjs +2 -4
  164. package/fesm2022/primeng-divider.mjs.map +1 -1
  165. package/fesm2022/primeng-dock.mjs +30 -12
  166. package/fesm2022/primeng-dock.mjs.map +1 -1
  167. package/fesm2022/primeng-dragdrop.mjs +1 -1
  168. package/fesm2022/primeng-drawer.mjs +111 -69
  169. package/fesm2022/primeng-drawer.mjs.map +1 -1
  170. package/fesm2022/primeng-dropdown.mjs +12 -4
  171. package/fesm2022/primeng-dropdown.mjs.map +1 -1
  172. package/fesm2022/primeng-dynamicdialog.mjs +21 -17
  173. package/fesm2022/primeng-dynamicdialog.mjs.map +1 -1
  174. package/fesm2022/primeng-editor.mjs +26 -10
  175. package/fesm2022/primeng-editor.mjs.map +1 -1
  176. package/fesm2022/primeng-fieldset.mjs +61 -33
  177. package/fesm2022/primeng-fieldset.mjs.map +1 -1
  178. package/fesm2022/primeng-fileupload.mjs +138 -88
  179. package/fesm2022/primeng-fileupload.mjs.map +1 -1
  180. package/fesm2022/primeng-floatlabel.mjs +1 -1
  181. package/fesm2022/primeng-fluid.mjs +1 -1
  182. package/fesm2022/primeng-galleria.mjs +17 -8
  183. package/fesm2022/primeng-galleria.mjs.map +1 -1
  184. package/fesm2022/primeng-iconfield.mjs +1 -1
  185. package/fesm2022/primeng-icons-baseicon.mjs +1 -1
  186. package/fesm2022/primeng-iftalabel.mjs +1 -1
  187. package/fesm2022/primeng-image.mjs +112 -65
  188. package/fesm2022/primeng-image.mjs.map +1 -1
  189. package/fesm2022/primeng-imagecompare.mjs +30 -10
  190. package/fesm2022/primeng-imagecompare.mjs.map +1 -1
  191. package/fesm2022/primeng-inplace.mjs +48 -23
  192. package/fesm2022/primeng-inplace.mjs.map +1 -1
  193. package/fesm2022/primeng-inputgroupaddon.mjs +1 -1
  194. package/fesm2022/primeng-inputicon.mjs +1 -1
  195. package/fesm2022/primeng-inputmask.mjs +30 -14
  196. package/fesm2022/primeng-inputmask.mjs.map +1 -1
  197. package/fesm2022/primeng-inputnumber.mjs +54 -46
  198. package/fesm2022/primeng-inputnumber.mjs.map +1 -1
  199. package/fesm2022/primeng-inputotp.mjs +29 -10
  200. package/fesm2022/primeng-inputotp.mjs.map +1 -1
  201. package/fesm2022/primeng-inputswitch.mjs +1 -1
  202. package/fesm2022/primeng-inputtext.mjs +1 -1
  203. package/fesm2022/primeng-inputtextarea.mjs +1 -1
  204. package/fesm2022/primeng-keyfilter.mjs +1 -1
  205. package/fesm2022/primeng-knob.mjs +1 -1
  206. package/fesm2022/primeng-listbox.mjs +136 -77
  207. package/fesm2022/primeng-listbox.mjs.map +1 -1
  208. package/fesm2022/primeng-megamenu.mjs +104 -58
  209. package/fesm2022/primeng-megamenu.mjs.map +1 -1
  210. package/fesm2022/primeng-menu.mjs +26 -26
  211. package/fesm2022/primeng-menu.mjs.map +1 -1
  212. package/fesm2022/primeng-menubar.mjs +69 -34
  213. package/fesm2022/primeng-menubar.mjs.map +1 -1
  214. package/fesm2022/primeng-message.mjs +49 -25
  215. package/fesm2022/primeng-message.mjs.map +1 -1
  216. package/fesm2022/primeng-messages.mjs +12 -3
  217. package/fesm2022/primeng-messages.mjs.map +1 -1
  218. package/fesm2022/primeng-metergroup.mjs +62 -30
  219. package/fesm2022/primeng-metergroup.mjs.map +1 -1
  220. package/fesm2022/primeng-multiselect.mjs +246 -155
  221. package/fesm2022/primeng-multiselect.mjs.map +1 -1
  222. package/fesm2022/primeng-orderlist.mjs +124 -69
  223. package/fesm2022/primeng-orderlist.mjs.map +1 -1
  224. package/fesm2022/primeng-organizationchart.mjs +30 -14
  225. package/fesm2022/primeng-organizationchart.mjs.map +1 -1
  226. package/fesm2022/primeng-overlay.mjs +26 -6
  227. package/fesm2022/primeng-overlay.mjs.map +1 -1
  228. package/fesm2022/primeng-overlaybadge.mjs +1 -1
  229. package/fesm2022/primeng-overlaypanel.mjs +33 -10
  230. package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
  231. package/fesm2022/primeng-paginator.mjs +91 -59
  232. package/fesm2022/primeng-paginator.mjs.map +1 -1
  233. package/fesm2022/primeng-panel.mjs +160 -100
  234. package/fesm2022/primeng-panel.mjs.map +1 -1
  235. package/fesm2022/primeng-panelmenu.mjs +55 -32
  236. package/fesm2022/primeng-panelmenu.mjs.map +1 -1
  237. package/fesm2022/primeng-password.mjs +87 -48
  238. package/fesm2022/primeng-password.mjs.map +1 -1
  239. package/fesm2022/primeng-picklist.mjs +362 -258
  240. package/fesm2022/primeng-picklist.mjs.map +1 -1
  241. package/fesm2022/primeng-popover.mjs +29 -12
  242. package/fesm2022/primeng-popover.mjs.map +1 -1
  243. package/fesm2022/primeng-progressbar.mjs +26 -8
  244. package/fesm2022/primeng-progressbar.mjs.map +1 -1
  245. package/fesm2022/primeng-progressspinner.mjs +1 -1
  246. package/fesm2022/primeng-radiobutton.mjs +1 -1
  247. package/fesm2022/primeng-rating.mjs +45 -21
  248. package/fesm2022/primeng-rating.mjs.map +1 -1
  249. package/fesm2022/primeng-scroller.mjs +46 -36
  250. package/fesm2022/primeng-scroller.mjs.map +1 -1
  251. package/fesm2022/primeng-scrollpanel.mjs +27 -8
  252. package/fesm2022/primeng-scrollpanel.mjs.map +1 -1
  253. package/fesm2022/primeng-scrolltop.mjs +17 -10
  254. package/fesm2022/primeng-scrolltop.mjs.map +1 -1
  255. package/fesm2022/primeng-select.mjs +197 -118
  256. package/fesm2022/primeng-select.mjs.map +1 -1
  257. package/fesm2022/primeng-selectbutton.mjs +25 -10
  258. package/fesm2022/primeng-selectbutton.mjs.map +1 -1
  259. package/fesm2022/primeng-sidebar.mjs +81 -59
  260. package/fesm2022/primeng-sidebar.mjs.map +1 -1
  261. package/fesm2022/primeng-skeleton.mjs +1 -1
  262. package/fesm2022/primeng-slider.mjs +1 -1
  263. package/fesm2022/primeng-speeddial.mjs +53 -28
  264. package/fesm2022/primeng-speeddial.mjs.map +1 -1
  265. package/fesm2022/primeng-splitbutton.mjs +40 -17
  266. package/fesm2022/primeng-splitbutton.mjs.map +1 -1
  267. package/fesm2022/primeng-splitter.mjs +6 -6
  268. package/fesm2022/primeng-splitter.mjs.map +1 -1
  269. package/fesm2022/primeng-stepper.mjs +27 -13
  270. package/fesm2022/primeng-stepper.mjs.map +1 -1
  271. package/fesm2022/primeng-steps.mjs +1 -1
  272. package/fesm2022/primeng-styleclass.mjs +1 -1
  273. package/fesm2022/primeng-table.mjs +107 -96
  274. package/fesm2022/primeng-table.mjs.map +1 -1
  275. package/fesm2022/primeng-tabmenu.mjs +53 -26
  276. package/fesm2022/primeng-tabmenu.mjs.map +1 -1
  277. package/fesm2022/primeng-tabs.mjs +27 -19
  278. package/fesm2022/primeng-tabs.mjs.map +1 -1
  279. package/fesm2022/primeng-tabview.mjs +106 -54
  280. package/fesm2022/primeng-tabview.mjs.map +1 -1
  281. package/fesm2022/primeng-tag.mjs +67 -43
  282. package/fesm2022/primeng-tag.mjs.map +1 -1
  283. package/fesm2022/primeng-terminal.mjs +1 -1
  284. package/fesm2022/primeng-textarea.mjs +1 -1
  285. package/fesm2022/primeng-tieredmenu.mjs +43 -20
  286. package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
  287. package/fesm2022/primeng-timeline.mjs +40 -16
  288. package/fesm2022/primeng-timeline.mjs.map +1 -1
  289. package/fesm2022/primeng-toast.mjs +31 -9
  290. package/fesm2022/primeng-toast.mjs.map +1 -1
  291. package/fesm2022/primeng-togglebutton.mjs +44 -29
  292. package/fesm2022/primeng-togglebutton.mjs.map +1 -1
  293. package/fesm2022/primeng-toggleswitch.mjs +27 -8
  294. package/fesm2022/primeng-toggleswitch.mjs.map +1 -1
  295. package/fesm2022/primeng-toolbar.mjs +46 -20
  296. package/fesm2022/primeng-toolbar.mjs.map +1 -1
  297. package/fesm2022/primeng-tooltip.mjs +35 -70
  298. package/fesm2022/primeng-tooltip.mjs.map +1 -1
  299. package/fesm2022/primeng-tree.mjs +114 -97
  300. package/fesm2022/primeng-tree.mjs.map +1 -1
  301. package/fesm2022/primeng-treeselect.mjs +155 -88
  302. package/fesm2022/primeng-treeselect.mjs.map +1 -1
  303. package/fesm2022/primeng-treetable.mjs +30 -11
  304. package/fesm2022/primeng-treetable.mjs.map +1 -1
  305. package/fesm2022/primeng-usestyle.mjs +1 -1
  306. package/fesm2022/primeng-usestyle.mjs.map +1 -1
  307. package/fieldset/fieldset.d.ts +12 -6
  308. package/fileupload/fileupload.d.ts +19 -8
  309. package/galleria/galleria.d.ts +3 -2
  310. package/image/image.d.ts +18 -7
  311. package/imagecompare/imagecompare.d.ts +7 -2
  312. package/inplace/inplace.d.ts +12 -6
  313. package/inputmask/inputmask.d.ts +8 -4
  314. package/inputnumber/inputnumber.d.ts +11 -6
  315. package/inputotp/inputotp.d.ts +7 -2
  316. package/listbox/listbox.d.ts +17 -4
  317. package/megamenu/megamenu.d.ts +16 -7
  318. package/menu/menu.d.ts +6 -6
  319. package/menubar/menubar.d.ts +13 -6
  320. package/message/message.d.ts +10 -4
  321. package/messages/messages.d.ts +4 -3
  322. package/metergroup/metergroup.d.ts +11 -3
  323. package/multiselect/multiselect.d.ts +36 -17
  324. package/orderlist/orderlist.d.ts +23 -11
  325. package/organizationchart/organizationchart.d.ts +6 -4
  326. package/overlay/overlay.d.ts +6 -3
  327. package/overlaypanel/overlaypanel.d.ts +6 -3
  328. package/package.json +171 -165
  329. package/paginator/paginator.d.ts +15 -8
  330. package/panel/panel.d.ts +14 -5
  331. package/panelmenu/panelmenu.d.ts +8 -4
  332. package/password/password.d.ts +15 -7
  333. package/picklist/picklist.d.ts +23 -3
  334. package/popover/popover.d.ts +8 -5
  335. package/progressbar/progressbar.d.ts +7 -3
  336. package/rating/rating.d.ts +11 -5
  337. package/scroller/scroller.d.ts +9 -4
  338. package/scrollpanel/scrollpanel.d.ts +7 -3
  339. package/scrolltop/scrolltop.d.ts +7 -4
  340. package/select/select.d.ts +31 -13
  341. package/selectbutton/selectbutton.d.ts +7 -3
  342. package/sidebar/sidebar.d.ts +9 -2
  343. package/speeddial/speeddial.d.ts +9 -4
  344. package/splitbutton/splitbutton.d.ts +9 -5
  345. package/splitter/splitter.d.ts +4 -4
  346. package/stepper/stepper.d.ts +8 -3
  347. package/table/table.d.ts +2 -2
  348. package/tabmenu/tabmenu.d.ts +12 -7
  349. package/tabs/tablist.d.ts +6 -2
  350. package/tabview/tabview.d.ts +16 -7
  351. package/tag/tag.d.ts +8 -9
  352. package/tieredmenu/tieredmenu.d.ts +10 -6
  353. package/timeline/timeline.d.ts +7 -2
  354. package/toast/toast.d.ts +7 -3
  355. package/togglebutton/togglebutton.d.ts +8 -3
  356. package/toggleswitch/toggleswitch.d.ts +6 -2
  357. package/toolbar/toolbar.d.ts +9 -4
  358. package/tooltip/tooltip.d.ts +2 -1
  359. package/tree/tree.d.ts +23 -10
  360. package/treeselect/treeselect.d.ts +26 -12
  361. package/treetable/treetable.d.ts +7 -5
@@ -0,0 +1,827 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, NgModule, Output, ViewChild, ViewEncapsulation, booleanAttribute, forwardRef, inject, numberAttribute } from '@angular/core';
3
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { PrimeTemplate, SharedModule } from 'primeng/api';
5
+ import { AutoFocusModule } from 'primeng/autofocus';
6
+ import { TimesIcon } from 'primeng/icons/times';
7
+ import { TimesCircleIcon } from 'primeng/icons/timescircle';
8
+ import { InputTextModule } from 'primeng/inputtext';
9
+ import { UniqueComponentId } from 'primeng/utils';
10
+ import { ChipsStyle } from './style/chipsstyle';
11
+ import { BaseComponent } from 'primeng/basecomponent';
12
+ import { ChipModule } from 'primeng/chip';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "primeng/config";
15
+ import * as i2 from "@angular/common";
16
+ import * as i3 from "primeng/autofocus";
17
+ import * as i4 from "primeng/chip";
18
+ const _c0 = ["inputtext"];
19
+ const _c1 = ["container"];
20
+ const _c2 = (a0, a1, a2, a3) => ({ "p-inputchips p-component p-input-wrapper": true, "p-disabled": a0, "p-focus": a1, "p-inputwrapper-filled": a2, "p-inputwrapper-focus": a3 });
21
+ const _c3 = a0 => ({ "p-chips-clearable": a0 });
22
+ const _c4 = a0 => ({ "p-inputchips-chip-item": true, "p-focus": a0 });
23
+ const _c5 = a0 => ({ $implicit: a0 });
24
+ const _c6 = a0 => ({ removeItem: a0 });
25
+ function Chips_li_3_ng_container_2_Template(rf, ctx) { if (rf & 1) {
26
+ i0.ɵɵelementContainer(0);
27
+ } }
28
+ function Chips_li_3_p_chip_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
29
+ i0.ɵɵelementContainer(0);
30
+ } }
31
+ function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template(rf, ctx) { if (rf & 1) {
32
+ const _r7 = i0.ɵɵgetCurrentView();
33
+ i0.ɵɵelementStart(0, "TimesCircleIcon", 16);
34
+ i0.ɵɵlistener("click", function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template_TimesCircleIcon_click_0_listener($event) { i0.ɵɵrestoreView(_r7); const i_r6 = i0.ɵɵnextContext(4).index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
35
+ i0.ɵɵelementEnd();
36
+ } if (rf & 2) {
37
+ i0.ɵɵproperty("styleClass", "p-chips-token-icon");
38
+ i0.ɵɵattribute("data-pc-section", "removeTokenIcon")("aria-hidden", true);
39
+ } }
40
+ function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_ng_template_0_Template(rf, ctx) { }
41
+ function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_Template(rf, ctx) { if (rf & 1) {
42
+ i0.ɵɵtemplate(0, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_ng_template_0_Template, 0, 0, "ng-template");
43
+ } }
44
+ function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template(rf, ctx) { if (rf & 1) {
45
+ const _r8 = i0.ɵɵgetCurrentView();
46
+ i0.ɵɵelementStart(0, "span", 17);
47
+ i0.ɵɵlistener("click", function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template_span_click_0_listener($event) { i0.ɵɵrestoreView(_r8); const i_r6 = i0.ɵɵnextContext(4).index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
48
+ i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_Template, 1, 0, null, 11);
49
+ i0.ɵɵelementEnd();
50
+ } if (rf & 2) {
51
+ const ctx_r3 = i0.ɵɵnextContext(5);
52
+ i0.ɵɵattribute("data-pc-section", "removeTokenIcon")("aria-hidden", true);
53
+ i0.ɵɵadvance();
54
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.removeTokenIconTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c6, ctx_r3.removeItem.bind(ctx_r3)));
55
+ } }
56
+ function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_Template(rf, ctx) { if (rf & 1) {
57
+ i0.ɵɵelementContainerStart(0);
58
+ i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template, 1, 3, "TimesCircleIcon", 14)(2, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template, 2, 6, "span", 15);
59
+ i0.ɵɵelementContainerEnd();
60
+ } if (rf & 2) {
61
+ const ctx_r3 = i0.ɵɵnextContext(4);
62
+ i0.ɵɵadvance();
63
+ i0.ɵɵproperty("ngIf", !ctx_r3.removeTokenIconTemplate);
64
+ i0.ɵɵadvance();
65
+ i0.ɵɵproperty("ngIf", ctx_r3.removeTokenIconTemplate);
66
+ } }
67
+ function Chips_li_3_p_chip_3_ng_template_2_Template(rf, ctx) { if (rf & 1) {
68
+ i0.ɵɵtemplate(0, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_Template, 3, 2, "ng-container", 9);
69
+ } if (rf & 2) {
70
+ const ctx_r3 = i0.ɵɵnextContext(3);
71
+ i0.ɵɵproperty("ngIf", !ctx_r3.disabled);
72
+ } }
73
+ function Chips_li_3_p_chip_3_Template(rf, ctx) { if (rf & 1) {
74
+ const _r5 = i0.ɵɵgetCurrentView();
75
+ i0.ɵɵelementStart(0, "p-chip", 13);
76
+ i0.ɵɵlistener("onRemove", function Chips_li_3_p_chip_3_Template_p_chip_onRemove_0_listener($event) { i0.ɵɵrestoreView(_r5); const i_r6 = i0.ɵɵnextContext().index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
77
+ i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_container_1_Template, 1, 0, "ng-container", 11)(2, Chips_li_3_p_chip_3_ng_template_2_Template, 1, 1, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
78
+ i0.ɵɵelementEnd();
79
+ } if (rf & 2) {
80
+ const item_r3 = i0.ɵɵnextContext().$implicit;
81
+ const ctx_r3 = i0.ɵɵnextContext();
82
+ i0.ɵɵproperty("label", ctx_r3.field ? ctx_r3.resolveFieldData(item_r3, ctx_r3.field) : item_r3)("removeIcon", ctx_r3.chipIcon);
83
+ i0.ɵɵadvance();
84
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.itemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c5, item_r3));
85
+ } }
86
+ function Chips_li_3_Template(rf, ctx) { if (rf & 1) {
87
+ const _r2 = i0.ɵɵgetCurrentView();
88
+ i0.ɵɵelementStart(0, "li", 10, 2);
89
+ i0.ɵɵlistener("click", function Chips_li_3_Template_li_click_0_listener($event) { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onItemClick($event, item_r3)); })("contextmenu", function Chips_li_3_Template_li_contextmenu_0_listener($event) { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onItemContextMenu($event, item_r3)); });
90
+ i0.ɵɵtemplate(2, Chips_li_3_ng_container_2_Template, 1, 0, "ng-container", 11)(3, Chips_li_3_p_chip_3_Template, 4, 6, "p-chip", 12);
91
+ i0.ɵɵelementEnd();
92
+ } if (rf & 2) {
93
+ const item_r3 = ctx.$implicit;
94
+ const i_r6 = ctx.index;
95
+ const ctx_r3 = i0.ɵɵnextContext();
96
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c4, ctx_r3.focusedIndex === i_r6));
97
+ i0.ɵɵattribute("id", ctx_r3.id + "_chips_item_" + i_r6)("ariaLabel", item_r3)("aria-selected", true)("aria-setsize", ctx_r3.value.length)("aria-posinset", i_r6 + 1)("data-p-focused", ctx_r3.focusedIndex === i_r6)("data-pc-section", "token");
98
+ i0.ɵɵadvance(2);
99
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.itemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(13, _c5, item_r3));
100
+ i0.ɵɵadvance();
101
+ i0.ɵɵproperty("ngIf", !ctx_r3.itemTemplate);
102
+ } }
103
+ function Chips_li_7_TimesIcon_1_Template(rf, ctx) { if (rf & 1) {
104
+ const _r9 = i0.ɵɵgetCurrentView();
105
+ i0.ɵɵelementStart(0, "TimesIcon", 16);
106
+ i0.ɵɵlistener("click", function Chips_li_7_TimesIcon_1_Template_TimesIcon_click_0_listener() { i0.ɵɵrestoreView(_r9); const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.clear()); });
107
+ i0.ɵɵelementEnd();
108
+ } if (rf & 2) {
109
+ i0.ɵɵproperty("styleClass", "p-chips-clear-icon");
110
+ } }
111
+ function Chips_li_7_span_2_1_ng_template_0_Template(rf, ctx) { }
112
+ function Chips_li_7_span_2_1_Template(rf, ctx) { if (rf & 1) {
113
+ i0.ɵɵtemplate(0, Chips_li_7_span_2_1_ng_template_0_Template, 0, 0, "ng-template");
114
+ } }
115
+ function Chips_li_7_span_2_Template(rf, ctx) { if (rf & 1) {
116
+ const _r10 = i0.ɵɵgetCurrentView();
117
+ i0.ɵɵelementStart(0, "span", 19);
118
+ i0.ɵɵlistener("click", function Chips_li_7_span_2_Template_span_click_0_listener() { i0.ɵɵrestoreView(_r10); const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.clear()); });
119
+ i0.ɵɵtemplate(1, Chips_li_7_span_2_1_Template, 1, 0, null, 20);
120
+ i0.ɵɵelementEnd();
121
+ } if (rf & 2) {
122
+ const ctx_r3 = i0.ɵɵnextContext(2);
123
+ i0.ɵɵadvance();
124
+ i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.clearIconTemplate);
125
+ } }
126
+ function Chips_li_7_Template(rf, ctx) { if (rf & 1) {
127
+ i0.ɵɵelementStart(0, "li");
128
+ i0.ɵɵtemplate(1, Chips_li_7_TimesIcon_1_Template, 1, 1, "TimesIcon", 14)(2, Chips_li_7_span_2_Template, 2, 1, "span", 18);
129
+ i0.ɵɵelementEnd();
130
+ } if (rf & 2) {
131
+ const ctx_r3 = i0.ɵɵnextContext();
132
+ i0.ɵɵadvance();
133
+ i0.ɵɵproperty("ngIf", !ctx_r3.clearIconTemplate);
134
+ i0.ɵɵadvance();
135
+ i0.ɵɵproperty("ngIf", ctx_r3.clearIconTemplate);
136
+ } }
137
+ export const CHIPS_VALUE_ACCESSOR = {
138
+ provide: NG_VALUE_ACCESSOR,
139
+ useExisting: forwardRef(() => Chips),
140
+ multi: true
141
+ };
142
+ /**
143
+ * Chips groups a collection of contents in tabs.
144
+ * @group Components
145
+ */
146
+ export class Chips extends BaseComponent {
147
+ el;
148
+ cd;
149
+ config;
150
+ /**
151
+ * Inline style of the element.
152
+ * @group Props
153
+ */
154
+ style;
155
+ /**
156
+ * Style class of the element.
157
+ * @group Props
158
+ */
159
+ styleClass;
160
+ /**
161
+ * When present, it specifies that the element should be disabled.
162
+ * @group Props
163
+ */
164
+ disabled;
165
+ /**
166
+ * Name of the property to display on a chip.
167
+ * @group Props
168
+ */
169
+ field;
170
+ /**
171
+ * Advisory information to display on input.
172
+ * @group Props
173
+ */
174
+ placeholder;
175
+ /**
176
+ * Maximum number of entries allowed.
177
+ * @group Props
178
+ */
179
+ max;
180
+ /**
181
+ * Maximum length of a chip.
182
+ * @group Props
183
+ */
184
+ maxLength;
185
+ /**
186
+ * Defines a string that labels the input for accessibility.
187
+ * @group Props
188
+ */
189
+ ariaLabel;
190
+ /**
191
+ * Establishes relationships between the component and label(s) where its value should be one or more element IDs.
192
+ * @group Props
193
+ */
194
+ ariaLabelledBy;
195
+ /**
196
+ * Index of the element in tabbing order.
197
+ * @group Props
198
+ */
199
+ tabindex;
200
+ /**
201
+ * Identifier of the focus input to match a label defined for the component.
202
+ * @group Props
203
+ */
204
+ inputId;
205
+ /**
206
+ * Whether to allow duplicate values or not.
207
+ * @group Props
208
+ */
209
+ allowDuplicate = true;
210
+ /**
211
+ * Defines whether duplication check should be case-sensitive
212
+ * @group Props
213
+ */
214
+ caseSensitiveDuplication = true;
215
+ /**
216
+ * Inline style of the input field.
217
+ * @group Props
218
+ */
219
+ inputStyle;
220
+ /**
221
+ * Style class of the input field.
222
+ * @group Props
223
+ */
224
+ inputStyleClass;
225
+ /**
226
+ * Icon to display in chip remove action..
227
+ * @group Props
228
+ */
229
+ chipIcon;
230
+ /**
231
+ * Whether to add an item on tab key press.
232
+ * @group Props
233
+ */
234
+ addOnTab;
235
+ /**
236
+ * Whether to add an item when the input loses focus.
237
+ * @group Props
238
+ */
239
+ addOnBlur;
240
+ /**
241
+ * Separator char to add an item when pressed in addition to the enter key.
242
+ * @group Props
243
+ */
244
+ separator;
245
+ /**
246
+ * When enabled, a clear icon is displayed to clear the value.
247
+ * @group Props
248
+ */
249
+ showClear = false;
250
+ /**
251
+ * When present, it specifies that the component should automatically get focus on load.
252
+ * @group Props
253
+ */
254
+ autofocus;
255
+ /**
256
+ * Specifies the input variant of the component.
257
+ * @group Props
258
+ */
259
+ variant = 'outlined';
260
+ /**
261
+ * Callback to invoke on chip add.
262
+ * @param {ChipsAddEvent} event - Custom chip add event.
263
+ * @group Emits
264
+ */
265
+ onAdd = new EventEmitter();
266
+ /**
267
+ * Callback to invoke on chip remove.
268
+ * @param {ChipsRemoveEvent} event - Custom chip remove event.
269
+ * @group Emits
270
+ */
271
+ onRemove = new EventEmitter();
272
+ /**
273
+ * Callback to invoke on focus of input field.
274
+ * @param {Event} event - Browser event.
275
+ * @group Emits
276
+ */
277
+ onFocus = new EventEmitter();
278
+ /**
279
+ * Callback to invoke on blur of input field.
280
+ * @param {Event} event - Browser event.
281
+ * @group Emits
282
+ */
283
+ onBlur = new EventEmitter();
284
+ /**
285
+ * Callback to invoke on chip clicked.
286
+ * @param {ChipsClickEvent} event - Custom chip click event.
287
+ * @group Emits
288
+ */
289
+ onChipClick = new EventEmitter();
290
+ /**
291
+ * Callback to invoke on chip contextmenu.
292
+ * @param {ChipsClickEvent} event - Custom chip contextmenu event.
293
+ * @group Emits
294
+ */
295
+ onChipContextMenu = new EventEmitter();
296
+ /**
297
+ * Callback to invoke on clear token clicked.
298
+ * @group Emits
299
+ */
300
+ onClear = new EventEmitter();
301
+ inputViewChild;
302
+ containerViewChild;
303
+ templates;
304
+ itemTemplate;
305
+ removeTokenIconTemplate;
306
+ clearIconTemplate;
307
+ value;
308
+ onModelChange = () => { };
309
+ onModelTouched = () => { };
310
+ valueChanged;
311
+ id = UniqueComponentId();
312
+ focused;
313
+ focusedIndex;
314
+ filled;
315
+ _componentStyle = inject(ChipsStyle);
316
+ get focusedOptionId() {
317
+ return this.focusedIndex !== null ? `${this.id}_chips_item_${this.focusedIndex}` : null;
318
+ }
319
+ get isMaxedOut() {
320
+ return this.max && this.value && this.max === this.value.length;
321
+ }
322
+ constructor(el, cd, config) {
323
+ super();
324
+ this.el = el;
325
+ this.cd = cd;
326
+ this.config = config;
327
+ console.log('Deprecated since v18. Use AutoComplete component instead with its typeahead property.');
328
+ }
329
+ ngAfterContentInit() {
330
+ this.templates.forEach((item) => {
331
+ switch (item.getType()) {
332
+ case 'item':
333
+ this.itemTemplate = item.template;
334
+ break;
335
+ case 'removetokenicon':
336
+ this.removeTokenIconTemplate = item.template;
337
+ break;
338
+ case 'clearicon':
339
+ this.clearIconTemplate = item.template;
340
+ break;
341
+ default:
342
+ this.itemTemplate = item.template;
343
+ break;
344
+ }
345
+ });
346
+ this.updateFilledState();
347
+ }
348
+ onWrapperClick() {
349
+ this.inputViewChild?.nativeElement.focus();
350
+ }
351
+ onContainerFocus() {
352
+ this.focused = true;
353
+ }
354
+ onContainerBlur() {
355
+ this.focusedIndex = -1;
356
+ this.focused = false;
357
+ }
358
+ onContainerKeyDown(event) {
359
+ switch (event.code) {
360
+ case 'ArrowLeft':
361
+ this.onArrowLeftKeyOn();
362
+ break;
363
+ case 'ArrowRight':
364
+ this.onArrowRightKeyOn();
365
+ break;
366
+ case 'Backspace':
367
+ this.onBackspaceKeyOn(event);
368
+ break;
369
+ case 'Space':
370
+ if (this.focusedIndex !== null && this.value && this.value.length > 0) {
371
+ this.onItemClick(event, this.value[this.focusedIndex]);
372
+ }
373
+ break;
374
+ default:
375
+ break;
376
+ }
377
+ }
378
+ onArrowLeftKeyOn() {
379
+ if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {
380
+ this.focusedIndex = this.focusedIndex === null ? this.value.length - 1 : this.focusedIndex - 1;
381
+ if (this.focusedIndex < 0)
382
+ this.focusedIndex = 0;
383
+ }
384
+ }
385
+ onArrowRightKeyOn() {
386
+ if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {
387
+ if (this.focusedIndex === this.value.length - 1) {
388
+ this.focusedIndex = null;
389
+ this.inputViewChild?.nativeElement.focus();
390
+ }
391
+ else {
392
+ this.focusedIndex++;
393
+ }
394
+ }
395
+ }
396
+ onBackspaceKeyOn(event) {
397
+ if (this.focusedIndex !== null) {
398
+ this.removeItem(event, this.focusedIndex);
399
+ }
400
+ }
401
+ onInput() {
402
+ this.updateFilledState();
403
+ this.focusedIndex = null;
404
+ }
405
+ onPaste(event) {
406
+ if (!this.disabled) {
407
+ if (this.separator) {
408
+ const pastedData = (event.clipboardData || this.document.defaultView['clipboardData']).getData('Text');
409
+ pastedData.split(this.separator).forEach((val) => {
410
+ this.addItem(event, val, true);
411
+ });
412
+ this.inputViewChild.nativeElement.value = '';
413
+ }
414
+ this.updateFilledState();
415
+ }
416
+ }
417
+ updateFilledState() {
418
+ if (!this.value || this.value.length === 0) {
419
+ this.filled = this.inputViewChild && this.inputViewChild.nativeElement && this.inputViewChild.nativeElement.value != '';
420
+ }
421
+ else {
422
+ this.filled = true;
423
+ }
424
+ }
425
+ onItemClick(event, item) {
426
+ this.onChipClick.emit({
427
+ originalEvent: event,
428
+ value: item
429
+ });
430
+ }
431
+ onItemContextMenu(event, item) {
432
+ this.onChipContextMenu.emit({
433
+ originalEvent: event,
434
+ value: item
435
+ });
436
+ }
437
+ writeValue(value) {
438
+ this.value = value;
439
+ this.updateMaxedOut();
440
+ this.updateFilledState();
441
+ this.cd.markForCheck();
442
+ }
443
+ registerOnChange(fn) {
444
+ this.onModelChange = fn;
445
+ }
446
+ registerOnTouched(fn) {
447
+ this.onModelTouched = fn;
448
+ }
449
+ setDisabledState(val) {
450
+ this.disabled = val;
451
+ this.cd.markForCheck();
452
+ }
453
+ resolveFieldData(data, field) {
454
+ if (data && field) {
455
+ if (field.indexOf('.') == -1) {
456
+ return data[field];
457
+ }
458
+ else {
459
+ let fields = field.split('.');
460
+ let value = data;
461
+ for (var i = 0, len = fields.length; i < len; ++i) {
462
+ value = value[fields[i]];
463
+ }
464
+ return value;
465
+ }
466
+ }
467
+ else {
468
+ return null;
469
+ }
470
+ }
471
+ onInputFocus(event) {
472
+ this.focused = true;
473
+ this.focusedIndex = null;
474
+ this.onFocus.emit(event);
475
+ }
476
+ onInputBlur(event) {
477
+ this.focused = false;
478
+ this.focusedIndex = null;
479
+ if (this.addOnBlur && this.inputViewChild.nativeElement.value) {
480
+ this.addItem(event, this.inputViewChild.nativeElement.value, false);
481
+ }
482
+ this.onModelTouched();
483
+ this.onBlur.emit(event);
484
+ }
485
+ removeItem(event, index) {
486
+ if (this.disabled) {
487
+ return;
488
+ }
489
+ let removedItem = this.value[index];
490
+ this.value = this.value.filter((val, i) => i != index);
491
+ this.focusedIndex = null;
492
+ this.inputViewChild.nativeElement.focus();
493
+ this.onModelChange(this.value);
494
+ this.onRemove.emit({
495
+ originalEvent: event,
496
+ value: removedItem
497
+ });
498
+ this.updateFilledState();
499
+ this.updateMaxedOut();
500
+ }
501
+ addItem(event, item, preventDefault) {
502
+ this.value = this.value || [];
503
+ if (item && item.trim().length) {
504
+ const newItemIsDuplicate = this.caseSensitiveDuplication ? this.value.includes(item) : this.value.some((val) => val.toLowerCase() === item.toLowerCase());
505
+ if ((this.allowDuplicate || !newItemIsDuplicate) && !this.isMaxedOut) {
506
+ this.value = [...this.value, item];
507
+ this.onModelChange(this.value);
508
+ this.onAdd.emit({
509
+ originalEvent: event,
510
+ value: item
511
+ });
512
+ }
513
+ }
514
+ this.updateFilledState();
515
+ this.updateMaxedOut();
516
+ this.inputViewChild.nativeElement.value = '';
517
+ if (preventDefault) {
518
+ event.preventDefault();
519
+ }
520
+ }
521
+ /**
522
+ * Callback to invoke on filter reset.
523
+ * @group Method
524
+ */
525
+ clear() {
526
+ this.value = null;
527
+ this.updateFilledState();
528
+ this.onModelChange(this.value);
529
+ this.updateMaxedOut();
530
+ this.onClear.emit();
531
+ }
532
+ onKeyDown(event) {
533
+ const inputValue = event.target.value;
534
+ switch (event.code) {
535
+ case 'Backspace':
536
+ if (inputValue.length === 0 && this.value && this.value.length > 0) {
537
+ if (this.focusedIndex !== null) {
538
+ this.removeItem(event, this.focusedIndex);
539
+ }
540
+ else
541
+ this.removeItem(event, this.value.length - 1);
542
+ }
543
+ break;
544
+ case 'Enter':
545
+ case 'NumpadEnter':
546
+ if (inputValue && inputValue.trim().length && !this.isMaxedOut) {
547
+ this.addItem(event, inputValue, true);
548
+ }
549
+ break;
550
+ case 'Tab':
551
+ if (this.addOnTab && inputValue && inputValue.trim().length && !this.isMaxedOut) {
552
+ this.addItem(event, inputValue, true);
553
+ event.preventDefault();
554
+ }
555
+ break;
556
+ case 'ArrowLeft':
557
+ if (inputValue.length === 0 && this.value && this.value.length > 0) {
558
+ this.containerViewChild?.nativeElement.focus();
559
+ }
560
+ break;
561
+ case 'ArrowRight':
562
+ event.stopPropagation();
563
+ break;
564
+ default:
565
+ if (this.separator) {
566
+ if (this.separator === event.key || event.key.match(this.separator)) {
567
+ this.addItem(event, inputValue, true);
568
+ }
569
+ }
570
+ break;
571
+ }
572
+ }
573
+ updateMaxedOut() {
574
+ if (this.inputViewChild && this.inputViewChild.nativeElement) {
575
+ if (this.isMaxedOut) {
576
+ // Calling `blur` is necessary because firefox does not call `onfocus` events
577
+ // for disabled inputs, unlike chromium browsers.
578
+ this.inputViewChild.nativeElement.blur();
579
+ this.inputViewChild.nativeElement.disabled = true;
580
+ }
581
+ else {
582
+ if (this.disabled) {
583
+ this.inputViewChild.nativeElement.blur();
584
+ }
585
+ this.inputViewChild.nativeElement.disabled = this.disabled || false;
586
+ }
587
+ }
588
+ }
589
+ static ɵfac = function Chips_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || Chips)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.PrimeNG)); };
590
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: Chips, selectors: [["p-chips"]], contentQueries: function Chips_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
591
+ i0.ɵɵcontentQuery(dirIndex, PrimeTemplate, 4);
592
+ } if (rf & 2) {
593
+ let _t;
594
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.templates = _t);
595
+ } }, viewQuery: function Chips_Query(rf, ctx) { if (rf & 1) {
596
+ i0.ɵɵviewQuery(_c0, 5);
597
+ i0.ɵɵviewQuery(_c1, 5);
598
+ } if (rf & 2) {
599
+ let _t;
600
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputViewChild = _t.first);
601
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.containerViewChild = _t.first);
602
+ } }, hostAttrs: [1, "p-element", "p-inputwrapper"], hostVars: 6, hostBindings: function Chips_HostBindings(rf, ctx) { if (rf & 2) {
603
+ i0.ɵɵclassProp("p-inputwrapper-filled", ctx.filled)("p-inputwrapper-focus", ctx.focused)("p-chips-clearable", ctx.showClear);
604
+ } }, inputs: { style: "style", styleClass: "styleClass", disabled: [2, "disabled", "disabled", booleanAttribute], field: "field", placeholder: "placeholder", max: [2, "max", "max", numberAttribute], maxLength: "maxLength", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", tabindex: [2, "tabindex", "tabindex", numberAttribute], inputId: "inputId", allowDuplicate: [2, "allowDuplicate", "allowDuplicate", booleanAttribute], caseSensitiveDuplication: [2, "caseSensitiveDuplication", "caseSensitiveDuplication", booleanAttribute], inputStyle: "inputStyle", inputStyleClass: "inputStyleClass", chipIcon: "chipIcon", addOnTab: [2, "addOnTab", "addOnTab", booleanAttribute], addOnBlur: [2, "addOnBlur", "addOnBlur", booleanAttribute], separator: "separator", showClear: [2, "showClear", "showClear", booleanAttribute], autofocus: [2, "autofocus", "autofocus", booleanAttribute], variant: "variant" }, outputs: { onAdd: "onAdd", onRemove: "onRemove", onFocus: "onFocus", onBlur: "onBlur", onChipClick: "onChipClick", onChipContextMenu: "onChipContextMenu", onClear: "onClear" }, standalone: true, features: [i0.ɵɵProvidersFeature([CHIPS_VALUE_ACCESSOR, ChipsStyle]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 8, vars: 31, consts: [["container", ""], ["inputtext", ""], ["token", ""], ["removeicon", ""], [3, "ngClass", "ngStyle"], ["tabindex", "-1", "role", "listbox", 1, "p-inputchips-input", 3, "click", "focus", "blur", "keydown"], ["role", "option", 3, "ngClass", "click", "contextmenu", 4, "ngFor", "ngForOf"], ["role", "option", 1, "p-inputchips-input-item", 3, "ngClass"], ["type", "text", "pAutoFocus", "", 1, "test", 3, "keydown", "input", "paste", "focus", "blur", "disabled", "ngStyle", "autofocus"], [4, "ngIf"], ["role", "option", 3, "click", "contextmenu", "ngClass"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["class", "p-inputchips-chip", "removable", "", 3, "label", "removeIcon", "onRemove", 4, "ngIf"], ["removable", "", 1, "p-inputchips-chip", 3, "onRemove", "label", "removeIcon"], [3, "styleClass", "click", 4, "ngIf"], ["class", "p-chips-token-icon", 3, "click", 4, "ngIf"], [3, "click", "styleClass"], [1, "p-chips-token-icon", 3, "click"], ["class", "p-chips-clear-icon", 3, "click", 4, "ngIf"], [1, "p-chips-clear-icon", 3, "click"], [4, "ngTemplateOutlet"]], template: function Chips_Template(rf, ctx) { if (rf & 1) {
605
+ const _r1 = i0.ɵɵgetCurrentView();
606
+ i0.ɵɵelementStart(0, "div", 4)(1, "ul", 5, 0);
607
+ i0.ɵɵlistener("click", function Chips_Template_ul_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onWrapperClick()); })("focus", function Chips_Template_ul_focus_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerFocus()); })("blur", function Chips_Template_ul_blur_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerBlur()); })("keydown", function Chips_Template_ul_keydown_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerKeyDown($event)); });
608
+ i0.ɵɵtemplate(3, Chips_li_3_Template, 4, 15, "li", 6);
609
+ i0.ɵɵelementStart(4, "li", 7)(5, "input", 8, 1);
610
+ i0.ɵɵlistener("keydown", function Chips_Template_input_keydown_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onKeyDown($event)); })("input", function Chips_Template_input_input_5_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInput()); })("paste", function Chips_Template_input_paste_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onPaste($event)); })("focus", function Chips_Template_input_focus_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInputFocus($event)); })("blur", function Chips_Template_input_blur_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInputBlur($event)); });
611
+ i0.ɵɵelementEnd()();
612
+ i0.ɵɵtemplate(7, Chips_li_7_Template, 3, 2, "li", 9);
613
+ i0.ɵɵelementEnd()();
614
+ } if (rf & 2) {
615
+ i0.ɵɵclassMap(ctx.styleClass);
616
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction4(24, _c2, ctx.disabled, ctx.focused, ctx.value && ctx.value.length || (ctx.inputViewChild == null ? null : ctx.inputViewChild.nativeElement.value) && (ctx.inputViewChild == null ? null : ctx.inputViewChild.nativeElement.value.length), ctx.focused))("ngStyle", ctx.style);
617
+ i0.ɵɵattribute("data-pc-name", "chips")("data-pc-section", "root");
618
+ i0.ɵɵadvance();
619
+ i0.ɵɵattribute("aria-labelledby", ctx.ariaLabelledBy)("aria-label", ctx.ariaLabel)("aria-activedescendant", ctx.focused ? ctx.focusedOptionId : undefined)("aria-orientation", "horizontal")("data-pc-section", "container");
620
+ i0.ɵɵadvance(2);
621
+ i0.ɵɵproperty("ngForOf", ctx.value);
622
+ i0.ɵɵadvance();
623
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(29, _c3, ctx.showClear && !ctx.disabled));
624
+ i0.ɵɵattribute("data-pc-section", "inputToken");
625
+ i0.ɵɵadvance();
626
+ i0.ɵɵclassMap(ctx.inputStyleClass);
627
+ i0.ɵɵproperty("disabled", ctx.disabled || ctx.isMaxedOut)("ngStyle", ctx.inputStyle)("autofocus", ctx.autofocus);
628
+ i0.ɵɵattribute("id", ctx.inputId)("maxlength", ctx.maxLength)("placeholder", ctx.value && ctx.value.length ? null : ctx.placeholder)("tabindex", ctx.tabindex);
629
+ i0.ɵɵadvance(2);
630
+ i0.ɵɵproperty("ngIf", ctx.value != null && ctx.filled && !ctx.disabled && ctx.showClear);
631
+ } }, dependencies: [CommonModule, i2.NgClass, i2.NgForOf, i2.NgIf, i2.NgTemplateOutlet, i2.NgStyle, InputTextModule, SharedModule, AutoFocusModule, i3.AutoFocus, TimesCircleIcon, TimesIcon, ChipModule, i4.Chip], encapsulation: 2, changeDetection: 0 });
632
+ }
633
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(Chips, [{
634
+ type: Component,
635
+ args: [{
636
+ selector: 'p-chips',
637
+ standalone: true,
638
+ imports: [CommonModule, InputTextModule, SharedModule, AutoFocusModule, TimesCircleIcon, TimesIcon, ChipModule],
639
+ template: `
640
+ <div
641
+ [ngClass]="{
642
+ 'p-inputchips p-component p-input-wrapper': true,
643
+ 'p-disabled': disabled,
644
+ 'p-focus': focused,
645
+ 'p-inputwrapper-filled': (value && value.length) || (this.inputViewChild?.nativeElement.value && this.inputViewChild?.nativeElement.value.length),
646
+ 'p-inputwrapper-focus': focused
647
+ }"
648
+ [ngStyle]="style"
649
+ [class]="styleClass"
650
+ [attr.data-pc-name]="'chips'"
651
+ [attr.data-pc-section]="'root'"
652
+ >
653
+ <ul
654
+ #container
655
+ class="p-inputchips-input"
656
+ tabindex="-1"
657
+ role="listbox"
658
+ [attr.aria-labelledby]="ariaLabelledBy"
659
+ [attr.aria-label]="ariaLabel"
660
+ [attr.aria-activedescendant]="focused ? focusedOptionId : undefined"
661
+ [attr.aria-orientation]="'horizontal'"
662
+ (click)="onWrapperClick()"
663
+ (focus)="onContainerFocus()"
664
+ (blur)="onContainerBlur()"
665
+ (keydown)="onContainerKeyDown($event)"
666
+ [attr.data-pc-section]="'container'"
667
+ >
668
+ <li
669
+ #token
670
+ *ngFor="let item of value; let i = index"
671
+ [attr.id]="id + '_chips_item_' + i"
672
+ role="option"
673
+ [attr.ariaLabel]="item"
674
+ [attr.aria-selected]="true"
675
+ [attr.aria-setsize]="value.length"
676
+ [attr.aria-posinset]="i + 1"
677
+ [attr.data-p-focused]="focusedIndex === i"
678
+ [ngClass]="{ 'p-inputchips-chip-item': true, 'p-focus': focusedIndex === i }"
679
+ (click)="onItemClick($event, item)"
680
+ (contextmenu)="onItemContextMenu($event, item)"
681
+ [attr.data-pc-section]="'token'"
682
+ >
683
+ <ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }"></ng-container>
684
+ <p-chip *ngIf="!itemTemplate" class="p-inputchips-chip" [label]="field ? resolveFieldData(item, field) : item" [removeIcon]="chipIcon" removable (onRemove)="removeItem($event, i)">
685
+ <ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }"></ng-container>
686
+ <ng-template #removeicon>
687
+ <ng-container *ngIf="!disabled">
688
+ <TimesCircleIcon [styleClass]="'p-chips-token-icon'" *ngIf="!removeTokenIconTemplate" (click)="removeItem($event, i)" [attr.data-pc-section]="'removeTokenIcon'" [attr.aria-hidden]="true" />
689
+ <span *ngIf="removeTokenIconTemplate" class="p-chips-token-icon" (click)="removeItem($event, i)" [attr.data-pc-section]="'removeTokenIcon'" [attr.aria-hidden]="true">
690
+ <ng-template *ngTemplateOutlet="removeTokenIconTemplate; context: { removeItem: removeItem.bind(this) }"></ng-template>
691
+ </span>
692
+ </ng-container>
693
+ </ng-template>
694
+ </p-chip>
695
+ </li>
696
+ <li class="p-inputchips-input-item" [ngClass]="{ 'p-chips-clearable': showClear && !disabled }" [attr.data-pc-section]="'inputToken'" role="option">
697
+ <input
698
+ #inputtext
699
+ type="text"
700
+ [attr.id]="inputId"
701
+ [attr.maxlength]="maxLength"
702
+ [attr.placeholder]="value && value.length ? null : placeholder"
703
+ [attr.tabindex]="tabindex"
704
+ (keydown)="onKeyDown($event)"
705
+ (input)="onInput()"
706
+ (paste)="onPaste($event)"
707
+ (focus)="onInputFocus($event)"
708
+ (blur)="onInputBlur($event)"
709
+ [disabled]="disabled || isMaxedOut"
710
+ [ngStyle]="inputStyle"
711
+ [class]="inputStyleClass"
712
+ pAutoFocus
713
+ [autofocus]="autofocus"
714
+ class="test"
715
+ />
716
+ </li>
717
+ <li *ngIf="value != null && filled && !disabled && showClear">
718
+ <TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-chips-clear-icon'" (click)="clear()" />
719
+ <span *ngIf="clearIconTemplate" class="p-chips-clear-icon" (click)="clear()">
720
+ <ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
721
+ </span>
722
+ </li>
723
+ </ul>
724
+ </div>
725
+ `,
726
+ host: {
727
+ class: 'p-element p-inputwrapper',
728
+ '[class.p-inputwrapper-filled]': 'filled',
729
+ '[class.p-inputwrapper-focus]': 'focused',
730
+ '[class.p-chips-clearable]': 'showClear'
731
+ },
732
+ providers: [CHIPS_VALUE_ACCESSOR, ChipsStyle],
733
+ changeDetection: ChangeDetectionStrategy.OnPush,
734
+ encapsulation: ViewEncapsulation.None
735
+ }]
736
+ }], () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.PrimeNG }], { style: [{
737
+ type: Input
738
+ }], styleClass: [{
739
+ type: Input
740
+ }], disabled: [{
741
+ type: Input,
742
+ args: [{ transform: booleanAttribute }]
743
+ }], field: [{
744
+ type: Input
745
+ }], placeholder: [{
746
+ type: Input
747
+ }], max: [{
748
+ type: Input,
749
+ args: [{ transform: numberAttribute }]
750
+ }], maxLength: [{
751
+ type: Input
752
+ }], ariaLabel: [{
753
+ type: Input
754
+ }], ariaLabelledBy: [{
755
+ type: Input
756
+ }], tabindex: [{
757
+ type: Input,
758
+ args: [{ transform: numberAttribute }]
759
+ }], inputId: [{
760
+ type: Input
761
+ }], allowDuplicate: [{
762
+ type: Input,
763
+ args: [{ transform: booleanAttribute }]
764
+ }], caseSensitiveDuplication: [{
765
+ type: Input,
766
+ args: [{ transform: booleanAttribute }]
767
+ }], inputStyle: [{
768
+ type: Input
769
+ }], inputStyleClass: [{
770
+ type: Input
771
+ }], chipIcon: [{
772
+ type: Input
773
+ }], addOnTab: [{
774
+ type: Input,
775
+ args: [{ transform: booleanAttribute }]
776
+ }], addOnBlur: [{
777
+ type: Input,
778
+ args: [{ transform: booleanAttribute }]
779
+ }], separator: [{
780
+ type: Input
781
+ }], showClear: [{
782
+ type: Input,
783
+ args: [{ transform: booleanAttribute }]
784
+ }], autofocus: [{
785
+ type: Input,
786
+ args: [{ transform: booleanAttribute }]
787
+ }], variant: [{
788
+ type: Input
789
+ }], onAdd: [{
790
+ type: Output
791
+ }], onRemove: [{
792
+ type: Output
793
+ }], onFocus: [{
794
+ type: Output
795
+ }], onBlur: [{
796
+ type: Output
797
+ }], onChipClick: [{
798
+ type: Output
799
+ }], onChipContextMenu: [{
800
+ type: Output
801
+ }], onClear: [{
802
+ type: Output
803
+ }], inputViewChild: [{
804
+ type: ViewChild,
805
+ args: ['inputtext']
806
+ }], containerViewChild: [{
807
+ type: ViewChild,
808
+ args: ['container']
809
+ }], templates: [{
810
+ type: ContentChildren,
811
+ args: [PrimeTemplate]
812
+ }] }); })();
813
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(Chips, { className: "Chips" }); })();
814
+ export class ChipsModule {
815
+ static ɵfac = function ChipsModule_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ChipsModule)(); };
816
+ static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: ChipsModule });
817
+ static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [Chips, SharedModule, SharedModule] });
818
+ }
819
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChipsModule, [{
820
+ type: NgModule,
821
+ args: [{
822
+ imports: [Chips, SharedModule],
823
+ exports: [Chips, SharedModule]
824
+ }]
825
+ }], null, null); })();
826
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(ChipsModule, { imports: [Chips, SharedModule], exports: [Chips, SharedModule] }); })();
827
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chips.js","sourceRoot":"","sources":["../../../src/chips/chips.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgModule,\n    Output,\n    QueryList,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    booleanAttribute,\n    forwardRef,\n    inject,\n    numberAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PrimeTemplate, SharedModule } from 'primeng/api';\nimport { AutoFocusModule } from 'primeng/autofocus';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { Nullable } from 'primeng/ts-helpers';\nimport { UniqueComponentId } from 'primeng/utils';\nimport { ChipsAddEvent, ChipsClickEvent, ChipsContextMenuEvent, ChipsRemoveEvent } from './chips.interface';\nimport { PrimeNG } from 'primeng/config';\nimport { ChipsStyle } from './style/chipsstyle';\nimport { BaseComponent } from 'primeng/basecomponent';\nimport { ChipModule } from 'primeng/chip';\n\nexport const CHIPS_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => Chips),\n    multi: true\n};\n/**\n * Chips groups a collection of contents in tabs.\n * @group Components\n */\n@Component({\n    selector: 'p-chips',\n    standalone: true,\n    imports: [CommonModule, InputTextModule, SharedModule, AutoFocusModule, TimesCircleIcon, TimesIcon, ChipModule],\n    template: `\n        <div\n            [ngClass]=\"{\n                'p-inputchips p-component p-input-wrapper': true,\n                'p-disabled': disabled,\n                'p-focus': focused,\n                'p-inputwrapper-filled': (value && value.length) || (this.inputViewChild?.nativeElement.value && this.inputViewChild?.nativeElement.value.length),\n                'p-inputwrapper-focus': focused\n            }\"\n            [ngStyle]=\"style\"\n            [class]=\"styleClass\"\n            [attr.data-pc-name]=\"'chips'\"\n            [attr.data-pc-section]=\"'root'\"\n        >\n            <ul\n                #container\n                class=\"p-inputchips-input\"\n                tabindex=\"-1\"\n                role=\"listbox\"\n                [attr.aria-labelledby]=\"ariaLabelledBy\"\n                [attr.aria-label]=\"ariaLabel\"\n                [attr.aria-activedescendant]=\"focused ? focusedOptionId : undefined\"\n                [attr.aria-orientation]=\"'horizontal'\"\n                (click)=\"onWrapperClick()\"\n                (focus)=\"onContainerFocus()\"\n                (blur)=\"onContainerBlur()\"\n                (keydown)=\"onContainerKeyDown($event)\"\n                [attr.data-pc-section]=\"'container'\"\n            >\n                <li\n                    #token\n                    *ngFor=\"let item of value; let i = index\"\n                    [attr.id]=\"id + '_chips_item_' + i\"\n                    role=\"option\"\n                    [attr.ariaLabel]=\"item\"\n                    [attr.aria-selected]=\"true\"\n                    [attr.aria-setsize]=\"value.length\"\n                    [attr.aria-posinset]=\"i + 1\"\n                    [attr.data-p-focused]=\"focusedIndex === i\"\n                    [ngClass]=\"{ 'p-inputchips-chip-item': true, 'p-focus': focusedIndex === i }\"\n                    (click)=\"onItemClick($event, item)\"\n                    (contextmenu)=\"onItemContextMenu($event, item)\"\n                    [attr.data-pc-section]=\"'token'\"\n                >\n                    <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-container>\n                    <p-chip *ngIf=\"!itemTemplate\" class=\"p-inputchips-chip\" [label]=\"field ? resolveFieldData(item, field) : item\" [removeIcon]=\"chipIcon\" removable (onRemove)=\"removeItem($event, i)\">\n                        <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-container>\n                        <ng-template #removeicon>\n                            <ng-container *ngIf=\"!disabled\">\n                                <TimesCircleIcon [styleClass]=\"'p-chips-token-icon'\" *ngIf=\"!removeTokenIconTemplate\" (click)=\"removeItem($event, i)\" [attr.data-pc-section]=\"'removeTokenIcon'\" [attr.aria-hidden]=\"true\" />\n                                <span *ngIf=\"removeTokenIconTemplate\" class=\"p-chips-token-icon\" (click)=\"removeItem($event, i)\" [attr.data-pc-section]=\"'removeTokenIcon'\" [attr.aria-hidden]=\"true\">\n                                    <ng-template *ngTemplateOutlet=\"removeTokenIconTemplate; context: { removeItem: removeItem.bind(this) }\"></ng-template>\n                                </span>\n                            </ng-container>\n                        </ng-template>\n                    </p-chip>\n                </li>\n                <li class=\"p-inputchips-input-item\" [ngClass]=\"{ 'p-chips-clearable': showClear && !disabled }\" [attr.data-pc-section]=\"'inputToken'\" role=\"option\">\n                    <input\n                        #inputtext\n                        type=\"text\"\n                        [attr.id]=\"inputId\"\n                        [attr.maxlength]=\"maxLength\"\n                        [attr.placeholder]=\"value && value.length ? null : placeholder\"\n                        [attr.tabindex]=\"tabindex\"\n                        (keydown)=\"onKeyDown($event)\"\n                        (input)=\"onInput()\"\n                        (paste)=\"onPaste($event)\"\n                        (focus)=\"onInputFocus($event)\"\n                        (blur)=\"onInputBlur($event)\"\n                        [disabled]=\"disabled || isMaxedOut\"\n                        [ngStyle]=\"inputStyle\"\n                        [class]=\"inputStyleClass\"\n                        pAutoFocus\n                        [autofocus]=\"autofocus\"\n                        class=\"test\"\n                    />\n                </li>\n                <li *ngIf=\"value != null && filled && !disabled && showClear\">\n                    <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-chips-clear-icon'\" (click)=\"clear()\" />\n                    <span *ngIf=\"clearIconTemplate\" class=\"p-chips-clear-icon\" (click)=\"clear()\">\n                        <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                    </span>\n                </li>\n            </ul>\n        </div>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': 'focused',\n        '[class.p-chips-clearable]': 'showClear'\n    },\n    providers: [CHIPS_VALUE_ACCESSOR, ChipsStyle],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class Chips extends BaseComponent implements AfterContentInit, ControlValueAccessor {\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * When present, it specifies that the element should be disabled.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) disabled: boolean | undefined;\n    /**\n     * Name of the property to display on a chip.\n     * @group Props\n     */\n    @Input() field: string | undefined;\n    /**\n     * Advisory information to display on input.\n     * @group Props\n     */\n    @Input() placeholder: string | undefined;\n    /**\n     * Maximum number of entries allowed.\n     * @group Props\n     */\n    @Input({ transform: numberAttribute }) max: number | undefined;\n    /**\n     * Maximum length of a chip.\n     * @group Props\n     */\n    @Input() maxLength: number | undefined;\n    /**\n     * Defines a string that labels the input for accessibility.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Establishes relationships between the component and label(s) where its value should be one or more element IDs.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input({ transform: numberAttribute }) tabindex: number | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * Whether to allow duplicate values or not.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) allowDuplicate: boolean = true;\n    /**\n     * Defines whether duplication check should be case-sensitive\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) caseSensitiveDuplication: boolean = true;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the input field.\n     * @group Props\n     */\n    @Input() inputStyleClass: string | undefined;\n    /**\n     * Icon to display in chip remove action..\n     * @group Props\n     */\n    @Input() chipIcon: string | undefined;\n    /**\n     * Whether to add an item on tab key press.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) addOnTab: boolean | undefined;\n    /**\n     * Whether to add an item when the input loses focus.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) addOnBlur: boolean | undefined;\n    /**\n     * Separator char to add an item when pressed in addition to the enter key.\n     * @group Props\n     */\n    @Input() separator: string | RegExp | undefined;\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) showClear: boolean = false;\n    /**\n     * When present, it specifies that the component should automatically get focus on load.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) autofocus: boolean | undefined;\n    /**\n     * Specifies the input variant of the component.\n     * @group Props\n     */\n    @Input() variant: 'filled' | 'outlined' = 'outlined';\n    /**\n     * Callback to invoke on chip add.\n     * @param {ChipsAddEvent} event - Custom chip add event.\n     * @group Emits\n     */\n    @Output() onAdd: EventEmitter<ChipsAddEvent> = new EventEmitter<ChipsAddEvent>();\n    /**\n     * Callback to invoke on chip remove.\n     * @param {ChipsRemoveEvent} event - Custom chip remove event.\n     * @group Emits\n     */\n    @Output() onRemove: EventEmitter<ChipsRemoveEvent> = new EventEmitter<ChipsRemoveEvent>();\n    /**\n     * Callback to invoke on focus of input field.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on blur of input field.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on chip clicked.\n     * @param {ChipsClickEvent} event - Custom chip click event.\n     * @group Emits\n     */\n    @Output() onChipClick: EventEmitter<ChipsClickEvent> = new EventEmitter<ChipsClickEvent>();\n    /**\n     * Callback to invoke on chip contextmenu.\n     * @param {ChipsClickEvent} event - Custom chip contextmenu event.\n     * @group Emits\n     */\n    @Output() onChipContextMenu: EventEmitter<ChipsContextMenuEvent> = new EventEmitter<ChipsContextMenuEvent>();\n    /**\n     * Callback to invoke on clear token clicked.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('inputtext') inputViewChild!: ElementRef;\n\n    @ViewChild('container') containerViewChild!: ElementRef;\n\n    @ContentChildren(PrimeTemplate) templates!: QueryList<any>;\n\n    public itemTemplate: Nullable<TemplateRef<any>>;\n\n    removeTokenIconTemplate: Nullable<TemplateRef<any>>;\n\n    clearIconTemplate: Nullable<TemplateRef<any>>;\n\n    value: any;\n\n    onModelChange: Function = () => {};\n\n    onModelTouched: Function = () => {};\n\n    valueChanged: Nullable<boolean>;\n\n    id = UniqueComponentId();\n\n    focused: Nullable<boolean>;\n\n    focusedIndex: Nullable<number>;\n\n    filled: Nullable<boolean>;\n\n    _componentStyle = inject(ChipsStyle);\n\n    get focusedOptionId() {\n        return this.focusedIndex !== null ? `${this.id}_chips_item_${this.focusedIndex}` : null;\n    }\n\n    get isMaxedOut(): boolean {\n        return this.max && this.value && this.max === this.value.length;\n    }\n\n    constructor(\n        public el: ElementRef,\n        public cd: ChangeDetectorRef,\n        public config: PrimeNG\n    ) {\n        super();\n        console.log('Deprecated since v18. Use AutoComplete component instead with its typeahead property.');\n    }\n\n    ngAfterContentInit() {\n        this.templates.forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeTokenIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n\n        this.updateFilledState();\n    }\n\n    onWrapperClick() {\n        this.inputViewChild?.nativeElement.focus();\n    }\n\n    onContainerFocus() {\n        this.focused = true;\n    }\n\n    onContainerBlur() {\n        this.focusedIndex = -1;\n        this.focused = false;\n    }\n\n    onContainerKeyDown(event) {\n        switch (event.code) {\n            case 'ArrowLeft':\n                this.onArrowLeftKeyOn();\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKeyOn();\n                break;\n\n            case 'Backspace':\n                this.onBackspaceKeyOn(event);\n                break;\n\n            case 'Space':\n                if (this.focusedIndex !== null && this.value && this.value.length > 0) {\n                    this.onItemClick(event, this.value[this.focusedIndex]);\n                }\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    onArrowLeftKeyOn() {\n        if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {\n            this.focusedIndex = this.focusedIndex === null ? this.value.length - 1 : this.focusedIndex - 1;\n            if (this.focusedIndex < 0) this.focusedIndex = 0;\n        }\n    }\n\n    onArrowRightKeyOn() {\n        if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {\n            if (this.focusedIndex === this.value.length - 1) {\n                this.focusedIndex = null;\n                this.inputViewChild?.nativeElement.focus();\n            } else {\n                this.focusedIndex++;\n            }\n        }\n    }\n\n    onBackspaceKeyOn(event) {\n        if (this.focusedIndex !== null) {\n            this.removeItem(event, this.focusedIndex);\n        }\n    }\n\n    onInput() {\n        this.updateFilledState();\n        this.focusedIndex = null;\n    }\n\n    onPaste(event: any) {\n        if (!this.disabled) {\n            if (this.separator) {\n                const pastedData: string = (event.clipboardData || (this.document.defaultView as any)['clipboardData']).getData('Text');\n                pastedData.split(this.separator).forEach((val: any) => {\n                    this.addItem(event, val, true);\n                });\n                this.inputViewChild.nativeElement.value = '';\n            }\n\n            this.updateFilledState();\n        }\n    }\n\n    updateFilledState() {\n        if (!this.value || this.value.length === 0) {\n            this.filled = this.inputViewChild && this.inputViewChild.nativeElement && this.inputViewChild.nativeElement.value != '';\n        } else {\n            this.filled = true;\n        }\n    }\n\n    onItemClick(event: Event, item: any) {\n        this.onChipClick.emit({\n            originalEvent: event,\n            value: item\n        });\n    }\n\n    onItemContextMenu(event: Event, item: any) {\n        this.onChipContextMenu.emit({\n            originalEvent: event,\n            value: item\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.updateMaxedOut();\n        this.updateFilledState();\n        this.cd.markForCheck();\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    resolveFieldData(data: any, field: string): any {\n        if (data && field) {\n            if (field.indexOf('.') == -1) {\n                return data[field];\n            } else {\n                let fields: string[] = field.split('.');\n                let value = data;\n                for (var i = 0, len = fields.length; i < len; ++i) {\n                    value = value[fields[i]];\n                }\n                return value;\n            }\n        } else {\n            return null;\n        }\n    }\n\n    onInputFocus(event: FocusEvent) {\n        this.focused = true;\n        this.focusedIndex = null;\n        this.onFocus.emit(event);\n    }\n\n    onInputBlur(event: FocusEvent) {\n        this.focused = false;\n        this.focusedIndex = null;\n        if (this.addOnBlur && this.inputViewChild.nativeElement.value) {\n            this.addItem(event, this.inputViewChild.nativeElement.value, false);\n        }\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    removeItem(event: Event, index: number): void {\n        if (this.disabled) {\n            return;\n        }\n\n        let removedItem = this.value[index];\n        this.value = this.value.filter((val: any, i: number) => i != index);\n        this.focusedIndex = null;\n        this.inputViewChild.nativeElement.focus();\n\n        this.onModelChange(this.value);\n        this.onRemove.emit({\n            originalEvent: event,\n            value: removedItem\n        });\n        this.updateFilledState();\n        this.updateMaxedOut();\n    }\n\n    addItem(event: Event, item: string, preventDefault: boolean): void {\n        this.value = this.value || [];\n\n        if (item && item.trim().length) {\n            const newItemIsDuplicate = this.caseSensitiveDuplication ? this.value.includes(item) : this.value.some((val) => val.toLowerCase() === item.toLowerCase());\n\n            if ((this.allowDuplicate || !newItemIsDuplicate) && !this.isMaxedOut) {\n                this.value = [...this.value, item];\n                this.onModelChange(this.value);\n                this.onAdd.emit({\n                    originalEvent: event,\n                    value: item\n                });\n            }\n        }\n\n        this.updateFilledState();\n        this.updateMaxedOut();\n        this.inputViewChild.nativeElement.value = '';\n\n        if (preventDefault) {\n            event.preventDefault();\n        }\n    }\n\n    /**\n     * Callback to invoke on filter reset.\n     * @group Method\n     */\n    public clear() {\n        this.value = null;\n        this.updateFilledState();\n        this.onModelChange(this.value);\n        this.updateMaxedOut();\n        this.onClear.emit();\n    }\n\n    onKeyDown(event) {\n        const inputValue = event.target.value;\n\n        switch (event.code) {\n            case 'Backspace':\n                if (inputValue.length === 0 && this.value && this.value.length > 0) {\n                    if (this.focusedIndex !== null) {\n                        this.removeItem(event, this.focusedIndex);\n                    } else this.removeItem(event, this.value.length - 1);\n                }\n\n                break;\n\n            case 'Enter':\n            case 'NumpadEnter':\n                if (inputValue && inputValue.trim().length && !this.isMaxedOut) {\n                    this.addItem(event, inputValue, true);\n                }\n\n                break;\n\n            case 'Tab':\n                if (this.addOnTab && inputValue && inputValue.trim().length && !this.isMaxedOut) {\n                    this.addItem(event, inputValue, true);\n                    event.preventDefault();\n                }\n\n                break;\n\n            case 'ArrowLeft':\n                if (inputValue.length === 0 && this.value && this.value.length > 0) {\n                    this.containerViewChild?.nativeElement.focus();\n                }\n\n                break;\n\n            case 'ArrowRight':\n                event.stopPropagation();\n                break;\n\n            default:\n                if (this.separator) {\n                    if (this.separator === event.key || event.key.match(this.separator)) {\n                        this.addItem(event, inputValue, true);\n                    }\n                }\n\n                break;\n        }\n    }\n\n    updateMaxedOut(): void {\n        if (this.inputViewChild && this.inputViewChild.nativeElement) {\n            if (this.isMaxedOut) {\n                // Calling `blur` is necessary because firefox does not call `onfocus` events\n                // for disabled inputs, unlike chromium browsers.\n                this.inputViewChild.nativeElement.blur();\n                this.inputViewChild.nativeElement.disabled = true;\n            } else {\n                if (this.disabled) {\n                    this.inputViewChild.nativeElement.blur();\n                }\n\n                this.inputViewChild.nativeElement.disabled = this.disabled || false;\n            }\n        }\n    }\n}\n\n@NgModule({\n    imports: [Chips, SharedModule],\n    exports: [Chips, SharedModule]\n})\nexport class ChipsModule {}\n"]}