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,2052 @@
1
+ export * from 'primenglab/types/carousel';
2
+ import { isPlatformBrowser, NgTemplateOutlet } from '@angular/common';
3
+ import * as i0 from '@angular/core';
4
+ import { Injectable, InjectionToken, inject, computed, afterNextRender, ViewEncapsulation, ChangeDetectionStrategy, Component, input, Directive, numberAttribute, booleanAttribute, output, viewChild, contentChild, signal, effect, untracked, contentChildren, NgModule } from '@angular/core';
5
+ import { Header, Footer, SharedModule } from 'primenglab/api';
6
+ import { BaseComponent, PARENT_INSTANCE } from 'primenglab/basecomponent';
7
+ import * as i1 from 'primenglab/bind';
8
+ import { Bind, BindModule } from 'primenglab/bind';
9
+ import { ButtonDirective } from 'primenglab/button';
10
+ import { ChevronDown } from '@primeicons/angular/chevron-down';
11
+ import { ChevronLeft } from '@primeicons/angular/chevron-left';
12
+ import { ChevronRight } from '@primeicons/angular/chevron-right';
13
+ import { ChevronUp } from '@primeicons/angular/chevron-up';
14
+ import { style } from '@primeuix/styles/carousel';
15
+ import { BaseStyle } from 'primenglab/base';
16
+ import { uuid, setAttribute, find, getAttribute, findSingle, removeClass, addClass } from '@primeuix/utils';
17
+
18
+ const classes = {
19
+ root: ({ instance }) => [
20
+ 'p-carousel p-component',
21
+ {
22
+ 'p-carousel-vertical': instance.isVertical(),
23
+ 'p-carousel-horizontal': !instance.isVertical()
24
+ }
25
+ ],
26
+ header: 'p-carousel-header',
27
+ contentContainer: 'p-carousel-content-container',
28
+ content: 'p-carousel-content',
29
+ pcPrevButton: ({ instance }) => [
30
+ 'p-carousel-prev-button',
31
+ {
32
+ 'p-disabled': instance.isBackwardNavDisabled()
33
+ }
34
+ ],
35
+ viewport: 'p-carousel-viewport',
36
+ itemList: 'p-carousel-item-list',
37
+ itemClone: ({ instance, index }) => [
38
+ 'p-carousel-item p-carousel-item-clone',
39
+ {
40
+ 'p-carousel-item-active': instance.totalShiftedItems() * -1 === instance.value()?.length,
41
+ 'p-carousel-item-start': 0 === index,
42
+ 'p-carousel-item-end': instance.clonedItemsForStarting().length - 1 === index
43
+ }
44
+ ],
45
+ item: ({ instance, index }) => [
46
+ 'p-carousel-item',
47
+ {
48
+ 'p-carousel-item-active': instance.firstIndex() <= index && instance.lastIndex() >= index,
49
+ 'p-carousel-item-start': instance.firstIndex() === index,
50
+ 'p-carousel-item-end': instance.lastIndex() === index
51
+ }
52
+ ],
53
+ pcNextButton: ({ instance }) => [
54
+ 'p-carousel-next-button',
55
+ {
56
+ 'p-disabled': instance.isForwardNavDisabled()
57
+ }
58
+ ],
59
+ indicatorList: ({ instance }) => ['p-carousel-indicator-list', instance.indicatorsContentClass()],
60
+ indicator: ({ instance, index }) => [
61
+ 'p-carousel-indicator',
62
+ {
63
+ 'p-carousel-indicator-active': instance._page() === index
64
+ }
65
+ ],
66
+ indicatorButton: ({ instance }) => ['p-carousel-indicator-button', instance.indicatorStyleClass()],
67
+ footer: 'p-carousel-footer',
68
+ // Composition mode
69
+ compositionRoot: 'p-carousel p-component',
70
+ compositionIndicator: ({ instance, index }) => ['p-carousel-indicator-button', { 'p-carousel-indicator-active': instance.pageState() === index }],
71
+ compositionContent: ({ instance }) => ['p-carousel-content', instance.orientation() === 'vertical' ? 'p-carousel-content-vertical' : 'p-carousel-content-horizontal'],
72
+ compositionItem: 'p-carousel-item',
73
+ compositionPrev: ({ instance }) => [{ 'p-disabled': instance.isPrevDisabled() }],
74
+ compositionNext: ({ instance }) => [{ 'p-disabled': instance.isNextDisabled() }]
75
+ };
76
+ class CarouselStyle extends BaseStyle {
77
+ name = 'carousel';
78
+ style = style;
79
+ classes = classes;
80
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselStyle, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
81
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselStyle });
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselStyle, decorators: [{
84
+ type: Injectable
85
+ }] });
86
+ /**
87
+ *
88
+ * Carousel is a content slider featuring various customization options.
89
+ *
90
+ * [Live Demo](https://www.primeng.org/carousel/)
91
+ *
92
+ * @module carouselstyle
93
+ *
94
+ */
95
+ var CarouselClasses;
96
+ (function (CarouselClasses) {
97
+ /**
98
+ * Class name of the root element
99
+ */
100
+ CarouselClasses["root"] = "p-carousel";
101
+ /**
102
+ * Class name of the header element
103
+ */
104
+ CarouselClasses["header"] = "p-carousel-header";
105
+ /**
106
+ * Class name of the content container element
107
+ */
108
+ CarouselClasses["contentContainer"] = "p-carousel-content-container";
109
+ /**
110
+ * Class name of the content element
111
+ */
112
+ CarouselClasses["content"] = "p-carousel-content";
113
+ /**
114
+ * Class name of the previous button element
115
+ */
116
+ CarouselClasses["pcPrevButton"] = "p-carousel-prev-button";
117
+ /**
118
+ * Class name of the viewport element
119
+ */
120
+ CarouselClasses["viewport"] = "p-carousel-viewport";
121
+ /**
122
+ * Class name of the item list element
123
+ */
124
+ CarouselClasses["itemList"] = "p-carousel-item-list";
125
+ /**
126
+ * Class name of the item clone element
127
+ */
128
+ CarouselClasses["itemClone"] = "p-carousel-item-clone";
129
+ /**
130
+ * Class name of the item element
131
+ */
132
+ CarouselClasses["item"] = "p-carousel-item";
133
+ /**
134
+ * Class name of the next button element
135
+ */
136
+ CarouselClasses["pcNextButton"] = "p-carousel-next-button";
137
+ /**
138
+ * Class name of the indicator list element
139
+ */
140
+ CarouselClasses["indicatorList"] = "p-carousel-indicator-list";
141
+ /**
142
+ * Class name of the indicator element
143
+ */
144
+ CarouselClasses["indicator"] = "p-carousel-indicator";
145
+ /**
146
+ * Class name of the indicator button element
147
+ */
148
+ CarouselClasses["indicatorButton"] = "p-carousel-indicator-button";
149
+ /**
150
+ * Class name of the footer element
151
+ */
152
+ CarouselClasses["footer"] = "p-carousel-footer";
153
+ })(CarouselClasses || (CarouselClasses = {}));
154
+
155
+ const CAROUSEL_ROOT = new InjectionToken('CAROUSEL_ROOT');
156
+
157
+ /**
158
+ * CarouselContent is the scrollable track element that contains carousel items.
159
+ * @group Components
160
+ */
161
+ class CarouselContent extends BaseComponent {
162
+ componentName = 'CarouselContent';
163
+ bindDirectiveInstance = inject(Bind, { self: true });
164
+ root = inject(CAROUSEL_ROOT);
165
+ isVertical = computed(() => this.root.orientation() === 'vertical', /* @ts-ignore */
166
+ ...(ngDevMode ? [{ debugName: "isVertical" }] : /* istanbul ignore next */ []));
167
+ flexDirection = computed(() => (this.isVertical() ? 'column' : 'row'), /* @ts-ignore */
168
+ ...(ngDevMode ? [{ debugName: "flexDirection" }] : /* istanbul ignore next */ []));
169
+ overflowX = computed(() => (this.isVertical() ? null : 'scroll'), /* @ts-ignore */
170
+ ...(ngDevMode ? [{ debugName: "overflowX" }] : /* istanbul ignore next */ []));
171
+ overflowY = computed(() => (this.isVertical() ? 'scroll' : null), /* @ts-ignore */
172
+ ...(ngDevMode ? [{ debugName: "overflowY" }] : /* istanbul ignore next */ []));
173
+ overscrollX = computed(() => (this.isVertical() ? null : 'contain'), /* @ts-ignore */
174
+ ...(ngDevMode ? [{ debugName: "overscrollX" }] : /* istanbul ignore next */ []));
175
+ overscrollY = computed(() => (this.isVertical() ? 'contain' : null), /* @ts-ignore */
176
+ ...(ngDevMode ? [{ debugName: "overscrollY" }] : /* istanbul ignore next */ []));
177
+ dataAutosize = computed(() => (this.root.autoSize() ? '' : null), /* @ts-ignore */
178
+ ...(ngDevMode ? [{ debugName: "dataAutosize" }] : /* istanbul ignore next */ []));
179
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
180
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
181
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
182
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
183
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
184
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
185
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
186
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
187
+ slidesPerPage = computed(() => this.root.slidesPerPage(), /* @ts-ignore */
188
+ ...(ngDevMode ? [{ debugName: "slidesPerPage" }] : /* istanbul ignore next */ []));
189
+ spacingItems = computed(() => this.root.spacing() + 'px', /* @ts-ignore */
190
+ ...(ngDevMode ? [{ debugName: "spacingItems" }] : /* istanbul ignore next */ []));
191
+ scrollSnapType = computed(() => this.root.resolveSnapType(), /* @ts-ignore */
192
+ ...(ngDevMode ? [{ debugName: "scrollSnapType" }] : /* istanbul ignore next */ []));
193
+ onPointerDown(e) {
194
+ this.root.onContentPointerDown(e);
195
+ }
196
+ onPointerMove(e) {
197
+ this.root.onContentPointerMove(e);
198
+ }
199
+ onPointerUp(e) {
200
+ this.root.onContentPointerUp(e);
201
+ }
202
+ onWheel(e) {
203
+ this.root.onContentWheel(e);
204
+ }
205
+ onAfterViewChecked() {
206
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
207
+ }
208
+ constructor() {
209
+ super();
210
+ afterNextRender(() => {
211
+ this.root.setContentEl(this.$el);
212
+ this.root.setupObservers();
213
+ });
214
+ }
215
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselContent, deps: [], target: i0.ɵɵFactoryTarget.Component });
216
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "22.0.3", type: CarouselContent, isStandalone: true, selector: "p-carousel-content", host: { listeners: { "pointerdown": "onPointerDown($event)", "pointermove": "onPointerMove($event)", "pointerup": "onPointerUp($event)", "wheel": "onWheel($event)" }, properties: { "class": "root.cx('compositionContent')", "attr.data-scope": "'carousel'", "attr.data-part": "'content'", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-autosize": "dataAutosize()", "attr.data-swiping": "dataSwiping()", "style.display": "'flex'", "style.flex-direction": "flexDirection()", "style.overflow-x": "overflowX()", "style.overflow-y": "overflowY()", "style.overscroll-behavior-x": "overscrollX()", "style.overscroll-behavior-y": "overscrollY()", "style.gap": "'var(--px-spacing-items)'", "style.scroll-snap-type": "'var(--px-scroll-snap-type)'", "style.scrollbar-width": "'none'", "style.position": "'relative'", "style.--px-slides-per-page": "slidesPerPage()", "style.--px-spacing-items": "spacingItems()", "style.--px-scroll-snap-type": "scrollSnapType()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselContent }], usesInheritance: true, hostDirectives: [{ directive: i1.Bind }], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, dependencies: [{ kind: "ngmodule", type: BindModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
217
+ }
218
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselContent, decorators: [{
219
+ type: Component,
220
+ args: [{
221
+ selector: 'p-carousel-content',
222
+ standalone: true,
223
+ imports: [BindModule],
224
+ template: `<ng-content></ng-content>`,
225
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselContent }],
226
+ changeDetection: ChangeDetectionStrategy.OnPush,
227
+ encapsulation: ViewEncapsulation.None,
228
+ host: {
229
+ '[class]': "root.cx('compositionContent')",
230
+ '[attr.data-scope]': "'carousel'",
231
+ '[attr.data-part]': "'content'",
232
+ '[attr.data-orientation]': 'dataOrientation()',
233
+ '[attr.data-align]': 'dataAlign()',
234
+ '[attr.data-page]': 'dataPage()',
235
+ '[attr.data-autosize]': 'dataAutosize()',
236
+ '[attr.data-swiping]': 'dataSwiping()',
237
+ '[style.display]': "'flex'",
238
+ '[style.flex-direction]': 'flexDirection()',
239
+ '[style.overflow-x]': 'overflowX()',
240
+ '[style.overflow-y]': 'overflowY()',
241
+ '[style.overscroll-behavior-x]': 'overscrollX()',
242
+ '[style.overscroll-behavior-y]': 'overscrollY()',
243
+ '[style.gap]': "'var(--px-spacing-items)'",
244
+ '[style.scroll-snap-type]': "'var(--px-scroll-snap-type)'",
245
+ '[style.scrollbar-width]': "'none'",
246
+ '[style.position]': "'relative'",
247
+ '[style.--px-slides-per-page]': 'slidesPerPage()',
248
+ '[style.--px-spacing-items]': 'spacingItems()',
249
+ '[style.--px-scroll-snap-type]': 'scrollSnapType()',
250
+ '(pointerdown)': 'onPointerDown($event)',
251
+ '(pointermove)': 'onPointerMove($event)',
252
+ '(pointerup)': 'onPointerUp($event)',
253
+ '(wheel)': 'onWheel($event)'
254
+ },
255
+ hostDirectives: [Bind]
256
+ }]
257
+ }], ctorParameters: () => [] });
258
+
259
+ /**
260
+ * CarouselItem represents an individual item in the composition-based carousel.
261
+ * @group Components
262
+ */
263
+ class CarouselItem extends BaseComponent {
264
+ componentName = 'CarouselItem';
265
+ bindDirectiveInstance = inject(Bind, { self: true });
266
+ /**
267
+ * The value/identifier of the carousel item.
268
+ * @group Props
269
+ */
270
+ value = input(/* @ts-ignore */
271
+ ...(ngDevMode ? [undefined, { debugName: "value" }] : /* istanbul ignore next */ []));
272
+ root = inject(CAROUSEL_ROOT);
273
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
274
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
275
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
276
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
277
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
278
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
279
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
280
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
281
+ dataAutosize = computed(() => (this.root.autoSize() ? '' : null), /* @ts-ignore */
282
+ ...(ngDevMode ? [{ debugName: "dataAutosize" }] : /* istanbul ignore next */ []));
283
+ flexBasis = computed(() => (this.root.autoSize() ? 'auto' : 'calc(100% / var(--px-slides-per-page) - var(--px-spacing-items) * (var(--px-slides-per-page) - 1) / var(--px-slides-per-page))'), /* @ts-ignore */
284
+ ...(ngDevMode ? [{ debugName: "flexBasis" }] : /* istanbul ignore next */ []));
285
+ scrollSnapAlign = computed(() => this.root.align(), /* @ts-ignore */
286
+ ...(ngDevMode ? [{ debugName: "scrollSnapAlign" }] : /* istanbul ignore next */ []));
287
+ onAfterViewChecked() {
288
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
289
+ }
290
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselItem, deps: null, target: i0.ɵɵFactoryTarget.Component });
291
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "22.0.3", type: CarouselItem, isStandalone: true, selector: "p-carousel-item", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "root.cx('compositionItem')", "attr.data-scope": "'carousel'", "attr.data-part": "'item'", "attr.data-item": "''", "attr.data-value": "value()", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-swiping": "dataSwiping()", "attr.data-autosize": "dataAutosize()", "style.flex-grow": "0", "style.flex-shrink": "0", "style.min-width": "0", "style.flex-basis": "flexBasis()", "style.scroll-snap-align": "scrollSnapAlign()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselItem }], usesInheritance: true, hostDirectives: [{ directive: i1.Bind }], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, dependencies: [{ kind: "ngmodule", type: BindModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
292
+ }
293
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselItem, decorators: [{
294
+ type: Component,
295
+ args: [{
296
+ selector: 'p-carousel-item',
297
+ standalone: true,
298
+ imports: [BindModule],
299
+ template: `<ng-content></ng-content>`,
300
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselItem }],
301
+ changeDetection: ChangeDetectionStrategy.OnPush,
302
+ encapsulation: ViewEncapsulation.None,
303
+ host: {
304
+ '[class]': "root.cx('compositionItem')",
305
+ '[attr.data-scope]': "'carousel'",
306
+ '[attr.data-part]': "'item'",
307
+ '[attr.data-item]': "''",
308
+ '[attr.data-value]': 'value()',
309
+ '[attr.data-orientation]': 'dataOrientation()',
310
+ '[attr.data-align]': 'dataAlign()',
311
+ '[attr.data-page]': 'dataPage()',
312
+ '[attr.data-swiping]': 'dataSwiping()',
313
+ '[attr.data-autosize]': 'dataAutosize()',
314
+ '[style.flex-grow]': '0',
315
+ '[style.flex-shrink]': '0',
316
+ '[style.min-width]': '0',
317
+ '[style.flex-basis]': 'flexBasis()',
318
+ '[style.scroll-snap-align]': 'scrollSnapAlign()'
319
+ },
320
+ hostDirectives: [Bind]
321
+ }]
322
+ }], propDecorators: { value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }] } });
323
+
324
+ /**
325
+ * CarouselNext is a directive for the next navigation button.
326
+ * @group Directives
327
+ */
328
+ class CarouselNext extends BaseComponent {
329
+ componentName = 'CarouselNext';
330
+ root = inject(CAROUSEL_ROOT);
331
+ _componentStyle = inject(CarouselStyle);
332
+ hostClass = computed(() => this.root.cx('compositionNext'), /* @ts-ignore */
333
+ ...(ngDevMode ? [{ debugName: "hostClass" }] : /* istanbul ignore next */ []));
334
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
335
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
336
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
337
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
338
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
339
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
340
+ dataDisabled = computed(() => this.root.isNextDisabled(), /* @ts-ignore */
341
+ ...(ngDevMode ? [{ debugName: "dataDisabled" }] : /* istanbul ignore next */ []));
342
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
343
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
344
+ attrDisabled = computed(() => (this.root.isNextDisabled() ? true : null), /* @ts-ignore */
345
+ ...(ngDevMode ? [{ debugName: "attrDisabled" }] : /* istanbul ignore next */ []));
346
+ onClick() {
347
+ this.root.next();
348
+ }
349
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselNext, deps: null, target: i0.ɵɵFactoryTarget.Directive });
350
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "22.0.3", type: CarouselNext, isStandalone: true, selector: "[pCarouselNext]", host: { listeners: { "click": "onClick()" }, properties: { "class": "hostClass()", "attr.data-scope": "'carousel'", "attr.data-part": "'next'", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-disabled": "dataDisabled()", "attr.data-swiping": "dataSwiping()", "attr.disabled": "attrDisabled()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselNext }], usesInheritance: true, ngImport: i0 });
351
+ }
352
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselNext, decorators: [{
353
+ type: Directive,
354
+ args: [{
355
+ selector: '[pCarouselNext]',
356
+ standalone: true,
357
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselNext }],
358
+ host: {
359
+ '[class]': 'hostClass()',
360
+ '[attr.data-scope]': "'carousel'",
361
+ '[attr.data-part]': "'next'",
362
+ '[attr.data-orientation]': 'dataOrientation()',
363
+ '[attr.data-align]': 'dataAlign()',
364
+ '[attr.data-page]': 'dataPage()',
365
+ '[attr.data-disabled]': 'dataDisabled()',
366
+ '[attr.data-swiping]': 'dataSwiping()',
367
+ '[attr.disabled]': 'attrDisabled()',
368
+ '(click)': 'onClick()'
369
+ }
370
+ }]
371
+ }] });
372
+
373
+ /**
374
+ * CarouselPrev is a directive for the previous navigation button.
375
+ * @group Directives
376
+ */
377
+ class CarouselPrev extends BaseComponent {
378
+ componentName = 'CarouselPrev';
379
+ root = inject(CAROUSEL_ROOT);
380
+ _componentStyle = inject(CarouselStyle);
381
+ hostClass = computed(() => this.root.cx('compositionPrev'), /* @ts-ignore */
382
+ ...(ngDevMode ? [{ debugName: "hostClass" }] : /* istanbul ignore next */ []));
383
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
384
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
385
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
386
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
387
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
388
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
389
+ dataDisabled = computed(() => this.root.isPrevDisabled(), /* @ts-ignore */
390
+ ...(ngDevMode ? [{ debugName: "dataDisabled" }] : /* istanbul ignore next */ []));
391
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
392
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
393
+ attrDisabled = computed(() => (this.root.isPrevDisabled() ? true : null), /* @ts-ignore */
394
+ ...(ngDevMode ? [{ debugName: "attrDisabled" }] : /* istanbul ignore next */ []));
395
+ onClick() {
396
+ this.root.prev();
397
+ }
398
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselPrev, deps: null, target: i0.ɵɵFactoryTarget.Directive });
399
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "22.0.3", type: CarouselPrev, isStandalone: true, selector: "[pCarouselPrev]", host: { listeners: { "click": "onClick()" }, properties: { "class": "hostClass()", "attr.data-scope": "'carousel'", "attr.data-part": "'prev'", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-disabled": "dataDisabled()", "attr.data-swiping": "dataSwiping()", "attr.disabled": "attrDisabled()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselPrev }], usesInheritance: true, ngImport: i0 });
400
+ }
401
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselPrev, decorators: [{
402
+ type: Directive,
403
+ args: [{
404
+ selector: '[pCarouselPrev]',
405
+ standalone: true,
406
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselPrev }],
407
+ host: {
408
+ '[class]': 'hostClass()',
409
+ '[attr.data-scope]': "'carousel'",
410
+ '[attr.data-part]': "'prev'",
411
+ '[attr.data-orientation]': 'dataOrientation()',
412
+ '[attr.data-align]': 'dataAlign()',
413
+ '[attr.data-page]': 'dataPage()',
414
+ '[attr.data-disabled]': 'dataDisabled()',
415
+ '[attr.data-swiping]': 'dataSwiping()',
416
+ '[attr.disabled]': 'attrDisabled()',
417
+ '(click)': 'onClick()'
418
+ }
419
+ }]
420
+ }] });
421
+
422
+ /**
423
+ * CarouselIndicator is a directive for an individual page indicator button.
424
+ * @group Directives
425
+ */
426
+ class CarouselIndicator extends BaseComponent {
427
+ componentName = 'CarouselIndicator';
428
+ /**
429
+ * The page index this indicator represents.
430
+ * @group Props
431
+ */
432
+ page = input(0, { ...(ngDevMode ? { debugName: "page" } : /* istanbul ignore next */ {}), transform: numberAttribute });
433
+ root = inject(CAROUSEL_ROOT);
434
+ bindDirectiveInstance = inject(Bind, { self: true });
435
+ _componentStyle = inject(CarouselStyle);
436
+ isActive = computed(() => this.root.pageState() === this.page(), /* @ts-ignore */
437
+ ...(ngDevMode ? [{ debugName: "isActive" }] : /* istanbul ignore next */ []));
438
+ hostClass = computed(() => this.root.cx('compositionIndicator', { index: this.page() }), /* @ts-ignore */
439
+ ...(ngDevMode ? [{ debugName: "hostClass" }] : /* istanbul ignore next */ []));
440
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
441
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
442
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
443
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
444
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
445
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
446
+ dataActive = computed(() => (this.isActive() ? '' : null), /* @ts-ignore */
447
+ ...(ngDevMode ? [{ debugName: "dataActive" }] : /* istanbul ignore next */ []));
448
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
449
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
450
+ onClick() {
451
+ this.root.scrollToPage(this.page());
452
+ }
453
+ onAfterViewChecked() {
454
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
455
+ }
456
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselIndicator, deps: null, target: i0.ɵɵFactoryTarget.Directive });
457
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "22.0.3", type: CarouselIndicator, isStandalone: true, selector: "[pCarouselIndicator]", inputs: { page: { classPropertyName: "page", publicName: "page", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "click": "onClick()" }, properties: { "class": "hostClass()", "attr.data-scope": "'carousel'", "attr.data-part": "'indicator'", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-active": "dataActive()", "attr.data-swiping": "dataSwiping()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselIndicator }], usesInheritance: true, hostDirectives: [{ directive: i1.Bind }], ngImport: i0 });
458
+ }
459
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselIndicator, decorators: [{
460
+ type: Directive,
461
+ args: [{
462
+ selector: '[pCarouselIndicator]',
463
+ standalone: true,
464
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: CarouselIndicator }],
465
+ host: {
466
+ '[class]': 'hostClass()',
467
+ '[attr.data-scope]': "'carousel'",
468
+ '[attr.data-part]': "'indicator'",
469
+ '[attr.data-orientation]': 'dataOrientation()',
470
+ '[attr.data-align]': 'dataAlign()',
471
+ '[attr.data-page]': 'dataPage()',
472
+ '[attr.data-active]': 'dataActive()',
473
+ '[attr.data-swiping]': 'dataSwiping()',
474
+ '(click)': 'onClick()'
475
+ },
476
+ hostDirectives: [Bind]
477
+ }]
478
+ }], propDecorators: { page: [{ type: i0.Input, args: [{ isSignal: true, alias: "page", required: false }] }] } });
479
+
480
+ /**
481
+ * CarouselIndicators renders the list of page indicators.
482
+ * Auto-generates button indicators based on snap points.
483
+ * @group Components
484
+ */
485
+ class CarouselIndicators extends BaseComponent {
486
+ componentName = 'CarouselIndicators';
487
+ bindDirectiveInstance = inject(Bind, { self: true });
488
+ root = inject(CAROUSEL_ROOT);
489
+ hostClass = computed(() => this.root.cx('indicatorList'), /* @ts-ignore */
490
+ ...(ngDevMode ? [{ debugName: "hostClass" }] : /* istanbul ignore next */ []));
491
+ dataOrientation = computed(() => this.root.orientation(), /* @ts-ignore */
492
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
493
+ dataAlign = computed(() => this.root.align(), /* @ts-ignore */
494
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
495
+ dataPage = computed(() => this.root.pageState(), /* @ts-ignore */
496
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
497
+ dataSwiping = computed(() => (this.root.swiping() ? '' : null), /* @ts-ignore */
498
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
499
+ pages = computed(() => {
500
+ const points = this.root.snapPoints();
501
+ return Array.from(points).map((_, i) => i);
502
+ }, /* @ts-ignore */
503
+ ...(ngDevMode ? [{ debugName: "pages" }] : /* istanbul ignore next */ []));
504
+ onAfterViewChecked() {
505
+ this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
506
+ }
507
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselIndicators, deps: null, target: i0.ɵɵFactoryTarget.Component });
508
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: CarouselIndicators, isStandalone: true, selector: "p-carousel-indicators", host: { properties: { "class": "hostClass()", "attr.data-scope": "'carousel'", "attr.data-part": "'indicators'", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-swiping": "dataSwiping()" } }, providers: [{ provide: PARENT_INSTANCE, useExisting: CarouselIndicators }], usesInheritance: true, hostDirectives: [{ directive: i1.Bind }], ngImport: i0, template: `
509
+ @for (page of pages(); track page) {
510
+ <button type="button" pCarouselIndicator [page]="page"></button>
511
+ }
512
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: BindModule }, { kind: "directive", type: CarouselIndicator, selector: "[pCarouselIndicator]", inputs: ["page"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
513
+ }
514
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselIndicators, decorators: [{
515
+ type: Component,
516
+ args: [{
517
+ selector: 'p-carousel-indicators',
518
+ standalone: true,
519
+ imports: [BindModule, CarouselIndicator],
520
+ template: `
521
+ @for (page of pages(); track page) {
522
+ <button type="button" pCarouselIndicator [page]="page"></button>
523
+ }
524
+ `,
525
+ providers: [{ provide: PARENT_INSTANCE, useExisting: CarouselIndicators }],
526
+ changeDetection: ChangeDetectionStrategy.OnPush,
527
+ encapsulation: ViewEncapsulation.None,
528
+ host: {
529
+ '[class]': 'hostClass()',
530
+ '[attr.data-scope]': "'carousel'",
531
+ '[attr.data-part]': "'indicators'",
532
+ '[attr.data-orientation]': 'dataOrientation()',
533
+ '[attr.data-align]': 'dataAlign()',
534
+ '[attr.data-page]': 'dataPage()',
535
+ '[attr.data-swiping]': 'dataSwiping()'
536
+ },
537
+ hostDirectives: [Bind]
538
+ }]
539
+ }] });
540
+
541
+ /**
542
+ * Base class containing all legacy (data-driven) carousel logic.
543
+ * Extended by the Carousel component.
544
+ * @deprecated Use the composition API of Carousel instead (e.g. p-carousel-content, p-carousel-item).
545
+ */
546
+ class CarouselLegacyBase extends BaseComponent {
547
+ /**
548
+ * Index of the first item.
549
+ * @defaultValue 0
550
+ * @group Props
551
+ */
552
+ page = input(0, { ...(ngDevMode ? { debugName: "page" } : /* istanbul ignore next */ {}), transform: numberAttribute });
553
+ /**
554
+ * Number of items per page.
555
+ * @defaultValue 1
556
+ * @group Props
557
+ */
558
+ numVisible = input(1, { ...(ngDevMode ? { debugName: "numVisible" } : /* istanbul ignore next */ {}), transform: numberAttribute });
559
+ /**
560
+ * Number of items to scroll.
561
+ * @defaultValue 1
562
+ * @group Props
563
+ */
564
+ numScroll = input(1, { ...(ngDevMode ? { debugName: "numScroll" } : /* istanbul ignore next */ {}), transform: numberAttribute });
565
+ /**
566
+ * An array of options for responsive design.
567
+ * @see {CarouselResponsiveOptions}
568
+ * @group Props
569
+ */
570
+ responsiveOptions = input(/* @ts-ignore */
571
+ ...(ngDevMode ? [undefined, { debugName: "responsiveOptions" }] : /* istanbul ignore next */ []));
572
+ /**
573
+ * Specifies the layout of the component.
574
+ * @group Props
575
+ */
576
+ orientation = input('horizontal', /* @ts-ignore */
577
+ ...(ngDevMode ? [{ debugName: "orientation" }] : /* istanbul ignore next */ []));
578
+ /**
579
+ * Height of the viewport in vertical layout.
580
+ * @group Props
581
+ */
582
+ verticalViewPortHeight = input('300px', /* @ts-ignore */
583
+ ...(ngDevMode ? [{ debugName: "verticalViewPortHeight" }] : /* istanbul ignore next */ []));
584
+ /**
585
+ * Style class of main content.
586
+ * @group Props
587
+ */
588
+ contentClass = input('', /* @ts-ignore */
589
+ ...(ngDevMode ? [{ debugName: "contentClass" }] : /* istanbul ignore next */ []));
590
+ /**
591
+ * Style class of the indicator items.
592
+ * @group Props
593
+ */
594
+ indicatorsContentClass = input('', /* @ts-ignore */
595
+ ...(ngDevMode ? [{ debugName: "indicatorsContentClass" }] : /* istanbul ignore next */ []));
596
+ /**
597
+ * Inline style of the indicator items.
598
+ * @group Props
599
+ */
600
+ indicatorsContentStyle = input(/* @ts-ignore */
601
+ ...(ngDevMode ? [undefined, { debugName: "indicatorsContentStyle" }] : /* istanbul ignore next */ []));
602
+ /**
603
+ * Style class of the indicators.
604
+ * @group Props
605
+ */
606
+ indicatorStyleClass = input('', /* @ts-ignore */
607
+ ...(ngDevMode ? [{ debugName: "indicatorStyleClass" }] : /* istanbul ignore next */ []));
608
+ /**
609
+ * Style of the indicators.
610
+ * @group Props
611
+ */
612
+ indicatorStyle = input(/* @ts-ignore */
613
+ ...(ngDevMode ? [undefined, { debugName: "indicatorStyle" }] : /* istanbul ignore next */ []));
614
+ /**
615
+ * An array of objects to display.
616
+ * @defaultValue null
617
+ * @group Props
618
+ */
619
+ value = input(/* @ts-ignore */
620
+ ...(ngDevMode ? [undefined, { debugName: "value" }] : /* istanbul ignore next */ []));
621
+ /**
622
+ * Defines if scrolling would be infinite.
623
+ * @group Props
624
+ */
625
+ circular = input(false, { ...(ngDevMode ? { debugName: "circular" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
626
+ /**
627
+ * Whether to display indicator container.
628
+ * @group Props
629
+ */
630
+ showIndicators = input(true, { ...(ngDevMode ? { debugName: "showIndicators" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
631
+ /**
632
+ * Whether to display navigation buttons in container.
633
+ * @group Props
634
+ */
635
+ showNavigators = input(true, { ...(ngDevMode ? { debugName: "showNavigators" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
636
+ /**
637
+ * Time in milliseconds to scroll items automatically.
638
+ * @group Props
639
+ */
640
+ autoplayInterval = input(0, { ...(ngDevMode ? { debugName: "autoplayInterval" } : /* istanbul ignore next */ {}), transform: numberAttribute });
641
+ /**
642
+ * Configuration object forwarded to the underlying button.
643
+ * @group Props
644
+ */
645
+ prevButtonProps = input({
646
+ severity: 'secondary',
647
+ variant: 'text',
648
+ rounded: true
649
+ }, /* @ts-ignore */
650
+ ...(ngDevMode ? [{ debugName: "prevButtonProps" }] : /* istanbul ignore next */ []));
651
+ /**
652
+ * Configuration object forwarded to the underlying button.
653
+ * @group Props
654
+ */
655
+ nextButtonProps = input({
656
+ severity: 'secondary',
657
+ variant: 'text',
658
+ rounded: true
659
+ }, /* @ts-ignore */
660
+ ...(ngDevMode ? [{ debugName: "nextButtonProps" }] : /* istanbul ignore next */ []));
661
+ /**
662
+ * Callback to invoke after scroll.
663
+ * @param {CarouselPageEvent} event - Custom page event.
664
+ * @group Emits
665
+ */
666
+ onPage = output();
667
+ itemsContainer = viewChild('itemsContainer', /* @ts-ignore */
668
+ ...(ngDevMode ? [{ debugName: "itemsContainer" }] : /* istanbul ignore next */ []));
669
+ indicatorContent = viewChild('indicatorContent', /* @ts-ignore */
670
+ ...(ngDevMode ? [{ debugName: "indicatorContent" }] : /* istanbul ignore next */ []));
671
+ headerFacet = contentChild(Header, { ...(ngDevMode ? { debugName: "headerFacet" } : /* istanbul ignore next */ {}), descendants: false });
672
+ footerFacet = contentChild(Footer, { ...(ngDevMode ? { debugName: "footerFacet" } : /* istanbul ignore next */ {}), descendants: false });
673
+ /**
674
+ * Custom item template.
675
+ * @group Templates
676
+ */
677
+ itemTemplate = contentChild('item', { ...(ngDevMode ? { debugName: "itemTemplate" } : /* istanbul ignore next */ {}), descendants: false });
678
+ /**
679
+ * Custom header template.
680
+ * @group Templates
681
+ */
682
+ headerTemplate = contentChild('header', { ...(ngDevMode ? { debugName: "headerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
683
+ /**
684
+ * Custom footer template.
685
+ * @group Templates
686
+ */
687
+ footerTemplate = contentChild('footer', { ...(ngDevMode ? { debugName: "footerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
688
+ /**
689
+ * Custom previous icon template.
690
+ * @group Templates
691
+ */
692
+ previousIconTemplate = contentChild('previousicon', { ...(ngDevMode ? { debugName: "previousIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
693
+ /**
694
+ * Custom next icon template.
695
+ * @group Templates
696
+ */
697
+ nextIconTemplate = contentChild('nexticon', { ...(ngDevMode ? { debugName: "nextIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
698
+ _componentStyle = inject(CarouselStyle);
699
+ _numVisible = 1;
700
+ _numScroll = 1;
701
+ _oldNumScroll = 0;
702
+ prevState = {
703
+ numScroll: 0,
704
+ numVisible: 0,
705
+ value: []
706
+ };
707
+ defaultNumScroll = 1;
708
+ defaultNumVisible = 1;
709
+ _page = signal(0, /* @ts-ignore */
710
+ ...(ngDevMode ? [{ debugName: "_page" }] : /* istanbul ignore next */ []));
711
+ carouselStyle = null;
712
+ id;
713
+ totalShiftedItems = signal(0, /* @ts-ignore */
714
+ ...(ngDevMode ? [{ debugName: "totalShiftedItems" }] : /* istanbul ignore next */ []));
715
+ isRemainingItemsAdded = false;
716
+ animationTimeout;
717
+ translateTimeout;
718
+ remainingItems = 0;
719
+ startPos = null;
720
+ documentResizeListener = null;
721
+ clonedItemsForStarting = signal([], /* @ts-ignore */
722
+ ...(ngDevMode ? [{ debugName: "clonedItemsForStarting" }] : /* istanbul ignore next */ []));
723
+ clonedItemsForFinishing = signal([], /* @ts-ignore */
724
+ ...(ngDevMode ? [{ debugName: "clonedItemsForFinishing" }] : /* istanbul ignore next */ []));
725
+ allowAutoplay = signal(false, /* @ts-ignore */
726
+ ...(ngDevMode ? [{ debugName: "allowAutoplay" }] : /* istanbul ignore next */ []));
727
+ interval;
728
+ isCreated = false;
729
+ swipeThreshold = 20;
730
+ window;
731
+ viewportStyle = computed(() => {
732
+ return { height: this.isVertical() ? this.verticalViewPortHeight() : 'auto' };
733
+ }, /* @ts-ignore */
734
+ ...(ngDevMode ? [{ debugName: "viewportStyle" }] : /* istanbul ignore next */ []));
735
+ constructor() {
736
+ super();
737
+ this.window = this.document.defaultView;
738
+ this.totalShiftedItems.set(this.page() * this.numScroll() * -1);
739
+ // Effect for page changes
740
+ effect(() => {
741
+ const pageVal = this.page();
742
+ untracked(() => {
743
+ if (this.isCreated && pageVal !== this._page()) {
744
+ if (this.autoplayInterval()) {
745
+ this.stopAutoplay();
746
+ }
747
+ if (pageVal > this._page() && pageVal <= this.totalDots() - 1) {
748
+ this.step(-1, pageVal);
749
+ }
750
+ else if (pageVal < this._page()) {
751
+ this.step(1, pageVal);
752
+ }
753
+ }
754
+ this._page.set(pageVal);
755
+ });
756
+ });
757
+ // Effect for value changes
758
+ effect(() => {
759
+ const val = this.value();
760
+ if (isPlatformBrowser(this.platformId)) {
761
+ if (this.circular() && val) {
762
+ this.setCloneItems();
763
+ }
764
+ }
765
+ });
766
+ // Effect for numVisible/numScroll changes
767
+ effect(() => {
768
+ const numVisibleVal = this.numVisible();
769
+ const numScrollVal = this.numScroll();
770
+ const responsiveOpts = this.responsiveOptions();
771
+ untracked(() => {
772
+ if (this.isCreated) {
773
+ if (responsiveOpts) {
774
+ this.defaultNumVisible = numVisibleVal;
775
+ this.defaultNumScroll = numScrollVal;
776
+ }
777
+ if (this.isCircular()) {
778
+ this.setCloneItems();
779
+ }
780
+ this.createStyle();
781
+ this.calculatePosition();
782
+ }
783
+ this._numVisible = numVisibleVal;
784
+ this._numScroll = numScrollVal;
785
+ });
786
+ });
787
+ }
788
+ legacyOnAfterContentInit() {
789
+ this.id = uuid('pn_id_');
790
+ if (isPlatformBrowser(this.platformId)) {
791
+ this.allowAutoplay.set(!!this.autoplayInterval());
792
+ if (this.circular()) {
793
+ this.setCloneItems();
794
+ }
795
+ if (this.responsiveOptions()) {
796
+ this.defaultNumScroll = this._numScroll;
797
+ this.defaultNumVisible = this._numVisible;
798
+ }
799
+ this.createStyle();
800
+ this.calculatePosition();
801
+ if (this.responsiveOptions()) {
802
+ this.bindDocumentListeners();
803
+ }
804
+ }
805
+ }
806
+ legacyOnAfterContentChecked() {
807
+ if (isPlatformBrowser(this.platformId)) {
808
+ const isCircular = this.isCircular();
809
+ let totalShiftedItems = this.totalShiftedItems();
810
+ const val = this.value();
811
+ if (val && this.itemsContainer() && (this.prevState.numScroll !== this._numScroll || this.prevState.numVisible !== this._numVisible || this.prevState.value.length !== val.length)) {
812
+ if (this.autoplayInterval()) {
813
+ this.stopAutoplay(false);
814
+ }
815
+ this.remainingItems = (val.length - this._numVisible) % this._numScroll;
816
+ let page = this._page();
817
+ if (this.totalDots() !== 0 && page >= this.totalDots()) {
818
+ page = this.totalDots() - 1;
819
+ this._page.set(page);
820
+ this.onPage.emit({
821
+ page: this._page()
822
+ });
823
+ }
824
+ totalShiftedItems = page * this._numScroll * -1;
825
+ if (isCircular) {
826
+ totalShiftedItems -= this._numVisible;
827
+ }
828
+ if (page === this.totalDots() - 1 && this.remainingItems > 0) {
829
+ totalShiftedItems += -1 * this.remainingItems + this._numScroll;
830
+ this.isRemainingItemsAdded = true;
831
+ }
832
+ else {
833
+ this.isRemainingItemsAdded = false;
834
+ }
835
+ if (totalShiftedItems !== this.totalShiftedItems()) {
836
+ this.totalShiftedItems.set(totalShiftedItems);
837
+ }
838
+ this._oldNumScroll = this._numScroll;
839
+ this.prevState.numScroll = this._numScroll;
840
+ this.prevState.numVisible = this._numVisible;
841
+ this.prevState.value = [...val];
842
+ const itemsContainerEl = this.itemsContainer();
843
+ if (this.totalDots() > 0 && itemsContainerEl?.nativeElement) {
844
+ itemsContainerEl.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this._numVisible)}%, 0, 0)`;
845
+ }
846
+ this.isCreated = true;
847
+ if (this.autoplayInterval() && this.isAutoplay()) {
848
+ this.startAutoplay();
849
+ }
850
+ }
851
+ if (isCircular && val) {
852
+ if (this._page() === 0) {
853
+ totalShiftedItems = -1 * this._numVisible;
854
+ }
855
+ else if (totalShiftedItems === 0) {
856
+ totalShiftedItems = -1 * val.length;
857
+ if (this.remainingItems > 0) {
858
+ this.isRemainingItemsAdded = true;
859
+ }
860
+ }
861
+ if (totalShiftedItems !== this.totalShiftedItems()) {
862
+ this.totalShiftedItems.set(totalShiftedItems);
863
+ }
864
+ }
865
+ }
866
+ }
867
+ createStyle() {
868
+ if (!this.carouselStyle) {
869
+ const styleEl = this.renderer.createElement('style');
870
+ setAttribute(styleEl, 'nonce', this.config?.csp()?.nonce);
871
+ this.renderer.appendChild(this.document.head, styleEl);
872
+ this.carouselStyle = styleEl;
873
+ }
874
+ let innerHTML = `
875
+ #${this.id} .p-carousel-item {
876
+ flex: 1 0 ${100 / this._numVisible}%
877
+ }
878
+ `;
879
+ const responsiveOpts = this.responsiveOptions();
880
+ if (responsiveOpts && !this.$unstyled()) {
881
+ responsiveOpts.sort((data1, data2) => {
882
+ const value1 = data1.breakpoint;
883
+ const value2 = data2.breakpoint;
884
+ let result = null;
885
+ if (value1 == null && value2 != null)
886
+ result = -1;
887
+ else if (value1 != null && value2 == null)
888
+ result = 1;
889
+ else if (value1 == null && value2 == null)
890
+ result = 0;
891
+ else if (typeof value1 === 'string' && typeof value2 === 'string')
892
+ result = value1.localeCompare(value2, undefined, { numeric: true });
893
+ else
894
+ result = value1 < value2 ? -1 : value1 > value2 ? 1 : 0;
895
+ return -1 * result;
896
+ });
897
+ for (let i = 0; i < responsiveOpts.length; i++) {
898
+ let res = responsiveOpts[i];
899
+ innerHTML += `
900
+ @media screen and (max-width: ${res.breakpoint}) {
901
+ #${this.id} .p-carousel-item {
902
+ flex: 1 0 ${100 / res.numVisible}%
903
+ }
904
+ }
905
+ `;
906
+ }
907
+ }
908
+ this.carouselStyle.innerHTML = innerHTML;
909
+ }
910
+ calculatePosition() {
911
+ const responsiveOpts = this.responsiveOptions();
912
+ if (responsiveOpts) {
913
+ let matchedResponsiveData = {
914
+ numVisible: this.defaultNumVisible,
915
+ numScroll: this.defaultNumScroll
916
+ };
917
+ if (typeof window !== 'undefined') {
918
+ let windowWidth = window.innerWidth;
919
+ for (let i = 0; i < responsiveOpts.length; i++) {
920
+ let res = responsiveOpts[i];
921
+ if (parseInt(res.breakpoint, 10) >= windowWidth) {
922
+ matchedResponsiveData = res;
923
+ }
924
+ }
925
+ }
926
+ if (this._numScroll !== matchedResponsiveData.numScroll) {
927
+ let page = this._page();
928
+ page = Math.floor((page * this._numScroll) / matchedResponsiveData.numScroll);
929
+ let totalShiftedItems = matchedResponsiveData.numScroll * this._page() * -1;
930
+ if (this.isCircular()) {
931
+ totalShiftedItems -= matchedResponsiveData.numVisible;
932
+ }
933
+ this.totalShiftedItems.set(totalShiftedItems);
934
+ this._numScroll = matchedResponsiveData.numScroll;
935
+ this._page.set(page);
936
+ this.onPage.emit({
937
+ page: this._page()
938
+ });
939
+ }
940
+ if (this._numVisible !== matchedResponsiveData.numVisible) {
941
+ this._numVisible = matchedResponsiveData.numVisible;
942
+ this.setCloneItems();
943
+ }
944
+ }
945
+ }
946
+ setCloneItems() {
947
+ const val = this.value();
948
+ if (this.isCircular() && val) {
949
+ this.clonedItemsForStarting.set([...val.slice(-1 * this._numVisible)]);
950
+ this.clonedItemsForFinishing.set([...val.slice(0, this._numVisible)]);
951
+ }
952
+ else {
953
+ this.clonedItemsForStarting.set([]);
954
+ this.clonedItemsForFinishing.set([]);
955
+ }
956
+ }
957
+ firstIndex() {
958
+ return this.isCircular() ? -1 * (this.totalShiftedItems() + this._numVisible) : this.totalShiftedItems() * -1;
959
+ }
960
+ lastIndex() {
961
+ return this.firstIndex() + this._numVisible - 1;
962
+ }
963
+ totalDots() {
964
+ const val = this.value();
965
+ return val?.length ? Math.ceil((val.length - this._numVisible) / this._numScroll) + 1 : 0;
966
+ }
967
+ totalDotsArray() {
968
+ const totalDots = this.totalDots();
969
+ return totalDots <= 0 ? [] : Array.from({ length: totalDots }, (_, i) => i);
970
+ }
971
+ isVertical() {
972
+ return this.orientation() === 'vertical';
973
+ }
974
+ isCircular() {
975
+ const val = this.value();
976
+ return this.circular() && val && val.length >= this._numVisible;
977
+ }
978
+ isAutoplay() {
979
+ return this.autoplayInterval() && this.allowAutoplay();
980
+ }
981
+ isForwardNavDisabled() {
982
+ return this.isEmpty() || (this._page() >= this.totalDots() - 1 && !this.isCircular());
983
+ }
984
+ isBackwardNavDisabled() {
985
+ return this.isEmpty() || (this._page() <= 0 && !this.isCircular());
986
+ }
987
+ isEmpty() {
988
+ const val = this.value();
989
+ return !val || val.length === 0;
990
+ }
991
+ // Template helper methods
992
+ hasHeader() {
993
+ return !!(this.headerFacet() || this.headerTemplate());
994
+ }
995
+ hasFooter() {
996
+ return !!(this.footerFacet() || this.footerTemplate());
997
+ }
998
+ ariaLive() {
999
+ return this.allowAutoplay() ? 'polite' : 'off';
1000
+ }
1001
+ showDefaultPrevIcon() {
1002
+ return !this.previousIconTemplate();
1003
+ }
1004
+ showPrevIconTemplate() {
1005
+ return !!this.previousIconTemplate();
1006
+ }
1007
+ showDefaultNextIcon() {
1008
+ return !this.nextIconTemplate();
1009
+ }
1010
+ showNextIconTemplate() {
1011
+ return !!this.nextIconTemplate();
1012
+ }
1013
+ // Clone items (starting) helpers
1014
+ isCloneStartAriaHidden() {
1015
+ return !(this.totalShiftedItems() * -1 === this.value()?.length);
1016
+ }
1017
+ isCloneStartActive() {
1018
+ return this.totalShiftedItems() * -1 === (this.value()?.length ?? 0) + this.numVisible();
1019
+ }
1020
+ isCloneStartEnd(index) {
1021
+ const cloned = this.clonedItemsForStarting();
1022
+ return cloned.length > 0 && cloned.length - 1 === index;
1023
+ }
1024
+ // Main items helpers
1025
+ isItemActive(index) {
1026
+ return this.firstIndex() <= index && this.lastIndex() >= index;
1027
+ }
1028
+ isItemAriaHidden(index) {
1029
+ return !this.isItemActive(index);
1030
+ }
1031
+ isItemStart(index) {
1032
+ return this.firstIndex() === index;
1033
+ }
1034
+ isItemEnd(index) {
1035
+ return this.lastIndex() === index;
1036
+ }
1037
+ // Indicator helpers
1038
+ isIndicatorActive(index) {
1039
+ return this._page() === index;
1040
+ }
1041
+ getIndicatorAriaCurrent(index) {
1042
+ return this._page() === index ? 'page' : undefined;
1043
+ }
1044
+ getIndicatorTabindex(index) {
1045
+ return this._page() === index ? 0 : -1;
1046
+ }
1047
+ navForward(e, index) {
1048
+ if (this.isCircular() || this._page() < this.totalDots() - 1) {
1049
+ this.step(-1, index);
1050
+ }
1051
+ if (this.autoplayInterval()) {
1052
+ this.stopAutoplay();
1053
+ }
1054
+ if (e && e.cancelable) {
1055
+ e.preventDefault();
1056
+ }
1057
+ }
1058
+ navBackward(e, index) {
1059
+ if (this.isCircular() || this._page() !== 0) {
1060
+ this.step(1, index);
1061
+ }
1062
+ if (this.autoplayInterval()) {
1063
+ this.stopAutoplay();
1064
+ }
1065
+ if (e && e.cancelable) {
1066
+ e.preventDefault();
1067
+ }
1068
+ }
1069
+ onDotClick(e, index) {
1070
+ let page = this._page();
1071
+ if (this.autoplayInterval()) {
1072
+ this.stopAutoplay();
1073
+ }
1074
+ if (index > page) {
1075
+ this.navForward(e, index);
1076
+ }
1077
+ else if (index < page) {
1078
+ this.navBackward(e, index);
1079
+ }
1080
+ }
1081
+ onIndicatorKeydown(event) {
1082
+ switch (event.code) {
1083
+ case 'ArrowRight':
1084
+ this.onRightKey();
1085
+ break;
1086
+ case 'ArrowLeft':
1087
+ this.onLeftKey();
1088
+ break;
1089
+ }
1090
+ }
1091
+ onRightKey() {
1092
+ const indicators = [...find(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"]')];
1093
+ const activeIndex = this.findFocusedIndicatorIndex();
1094
+ this.changedFocusedIndicator(activeIndex, activeIndex + 1 === indicators.length ? indicators.length - 1 : activeIndex + 1);
1095
+ }
1096
+ onLeftKey() {
1097
+ const activeIndex = this.findFocusedIndicatorIndex();
1098
+ this.changedFocusedIndicator(activeIndex, activeIndex - 1 <= 0 ? 0 : activeIndex - 1);
1099
+ }
1100
+ onHomeKey() {
1101
+ const activeIndex = this.findFocusedIndicatorIndex();
1102
+ this.changedFocusedIndicator(activeIndex, 0);
1103
+ }
1104
+ onEndKey() {
1105
+ const indicators = [...find(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"]')];
1106
+ const activeIndex = this.findFocusedIndicatorIndex();
1107
+ this.changedFocusedIndicator(activeIndex, indicators.length - 1);
1108
+ }
1109
+ onTabKey() {
1110
+ const indicators = [...find(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"]')];
1111
+ const highlightedIndex = indicators.findIndex((ind) => getAttribute(ind, 'data-p-highlight') === true);
1112
+ const activeIndicator = findSingle(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"] > button[tabindex="0"]');
1113
+ const activeIndex = indicators.findIndex((ind) => ind === activeIndicator?.parentElement);
1114
+ if (activeIndex >= 0 && highlightedIndex >= 0) {
1115
+ indicators[activeIndex].children[0].tabIndex = -1;
1116
+ indicators[highlightedIndex].children[0].tabIndex = 0;
1117
+ }
1118
+ }
1119
+ findFocusedIndicatorIndex() {
1120
+ const indicators = [...find(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"]')];
1121
+ const activeIndicator = findSingle(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"] > button[tabindex="0"]');
1122
+ return indicators.findIndex((ind) => ind === activeIndicator?.parentElement);
1123
+ }
1124
+ changedFocusedIndicator(prevInd, nextInd) {
1125
+ const indicators = [...find(this.indicatorContent()?.nativeElement, '[data-pc-section="indicator"]')];
1126
+ if (indicators[prevInd] && indicators[nextInd]) {
1127
+ indicators[prevInd].children[0].tabIndex = -1;
1128
+ indicators[nextInd].children[0].tabIndex = 0;
1129
+ indicators[nextInd].children[0].focus();
1130
+ }
1131
+ }
1132
+ step(dir, page) {
1133
+ let totalShiftedItems = this.totalShiftedItems();
1134
+ const isCircular = this.isCircular();
1135
+ const val = this.value();
1136
+ if (page != null) {
1137
+ totalShiftedItems = this._numScroll * page * -1;
1138
+ if (isCircular) {
1139
+ totalShiftedItems -= this._numVisible;
1140
+ }
1141
+ this.isRemainingItemsAdded = false;
1142
+ }
1143
+ else {
1144
+ totalShiftedItems += this._numScroll * dir;
1145
+ if (this.isRemainingItemsAdded) {
1146
+ totalShiftedItems += this.remainingItems - this._numScroll * dir;
1147
+ this.isRemainingItemsAdded = false;
1148
+ }
1149
+ let originalShiftedItems = isCircular ? totalShiftedItems + this._numVisible : totalShiftedItems;
1150
+ page = Math.abs(Math.floor(originalShiftedItems / this._numScroll));
1151
+ }
1152
+ if (isCircular && this._page() === this.totalDots() - 1 && dir === -1 && val) {
1153
+ totalShiftedItems = -1 * (val.length + this._numVisible);
1154
+ page = 0;
1155
+ }
1156
+ else if (isCircular && this._page() === 0 && dir === 1) {
1157
+ totalShiftedItems = 0;
1158
+ page = this.totalDots() - 1;
1159
+ }
1160
+ else if (page === this.totalDots() - 1 && this.remainingItems > 0) {
1161
+ totalShiftedItems += this.remainingItems * -1 - this._numScroll * dir;
1162
+ this.isRemainingItemsAdded = true;
1163
+ }
1164
+ const itemsContainerEl = this.itemsContainer();
1165
+ if (itemsContainerEl) {
1166
+ !this.$unstyled() && removeClass(itemsContainerEl.nativeElement, 'p-items-hidden');
1167
+ itemsContainerEl.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this._numVisible)}%, 0, 0)`;
1168
+ itemsContainerEl.nativeElement.style.transition = 'transform 500ms ease 0s';
1169
+ }
1170
+ this.totalShiftedItems.set(totalShiftedItems);
1171
+ this._page.set(page);
1172
+ this.onPage.emit({
1173
+ page: this._page()
1174
+ });
1175
+ }
1176
+ startAutoplay() {
1177
+ if (this.interval) {
1178
+ clearInterval(this.interval);
1179
+ }
1180
+ this.interval = setInterval(() => {
1181
+ if (this.totalDots() > 0) {
1182
+ if (this._page() === this.totalDots() - 1) {
1183
+ this.step(-1, 0);
1184
+ }
1185
+ else {
1186
+ this.step(-1, this._page() + 1);
1187
+ }
1188
+ }
1189
+ }, this.autoplayInterval());
1190
+ this.allowAutoplay.set(true);
1191
+ }
1192
+ stopAutoplay(changeAllow = true) {
1193
+ if (this.interval) {
1194
+ clearInterval(this.interval);
1195
+ this.interval = undefined;
1196
+ if (changeAllow) {
1197
+ this.allowAutoplay.set(false);
1198
+ }
1199
+ }
1200
+ }
1201
+ isPlaying() {
1202
+ return !!this.interval;
1203
+ }
1204
+ onTransitionEnd() {
1205
+ const itemsContainerEl = this.itemsContainer();
1206
+ if (itemsContainerEl) {
1207
+ !this.$unstyled() && addClass(itemsContainerEl.nativeElement, 'p-items-hidden');
1208
+ itemsContainerEl.nativeElement.style.transition = '';
1209
+ if ((this._page() === 0 || this._page() === this.totalDots() - 1) && this.isCircular()) {
1210
+ itemsContainerEl.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${this.totalShiftedItems() * (100 / this._numVisible)}%, 0)` : `translate3d(${this.totalShiftedItems() * (100 / this._numVisible)}%, 0, 0)`;
1211
+ }
1212
+ }
1213
+ }
1214
+ onTouchStart(e) {
1215
+ let touchobj = e.changedTouches[0];
1216
+ this.startPos = {
1217
+ x: touchobj.pageX,
1218
+ y: touchobj.pageY
1219
+ };
1220
+ }
1221
+ onTouchMove(e) {
1222
+ if (e.cancelable) {
1223
+ e.preventDefault();
1224
+ }
1225
+ }
1226
+ onTouchEnd(e) {
1227
+ if (!this.startPos)
1228
+ return;
1229
+ const touchobj = e.changedTouches[0];
1230
+ if (this.isVertical()) {
1231
+ this.changePageOnTouch(e, touchobj.pageY - this.startPos.y);
1232
+ }
1233
+ else {
1234
+ this.changePageOnTouch(e, touchobj.pageX - this.startPos.x);
1235
+ }
1236
+ }
1237
+ changePageOnTouch(e, diff) {
1238
+ if (Math.abs(diff) > this.swipeThreshold) {
1239
+ if (diff < 0) {
1240
+ this.navForward(e);
1241
+ }
1242
+ else {
1243
+ this.navBackward(e);
1244
+ }
1245
+ }
1246
+ }
1247
+ ariaPrevButtonLabel() {
1248
+ return this.config.translation.aria ? this.config.translation.aria?.prevPageLabel : undefined;
1249
+ }
1250
+ ariaSlideLabel() {
1251
+ return this.config.translation.aria ? this.config.translation.aria?.slide : undefined;
1252
+ }
1253
+ ariaNextButtonLabel() {
1254
+ return this.config.translation.aria ? this.config.translation.aria?.nextPageLabel : undefined;
1255
+ }
1256
+ ariaSlideNumber(value) {
1257
+ return this.config.translation.aria ? this.config.translation.aria?.slideNumber?.replace(/{slideNumber}/g, String(value)) : undefined;
1258
+ }
1259
+ ariaPageLabel(value) {
1260
+ return this.config.translation.aria ? this.config.translation.aria?.pageLabel?.replace(/{page}/g, String(value)) : undefined;
1261
+ }
1262
+ getIndicatorPTOptions(key, index) {
1263
+ return this.ptm(key, {
1264
+ context: {
1265
+ highlighted: index === this._page()
1266
+ }
1267
+ });
1268
+ }
1269
+ getItemPTOptions(key, index) {
1270
+ return this.ptm(key, {
1271
+ context: {
1272
+ index,
1273
+ active: this.firstIndex() <= index && this.lastIndex() >= index,
1274
+ start: this.firstIndex() === index,
1275
+ end: this.lastIndex() === index
1276
+ }
1277
+ });
1278
+ }
1279
+ bindDocumentListeners() {
1280
+ if (isPlatformBrowser(this.platformId)) {
1281
+ if (!this.documentResizeListener) {
1282
+ this.documentResizeListener = this.renderer.listen(this.window, 'resize', () => {
1283
+ this.calculatePosition();
1284
+ });
1285
+ }
1286
+ }
1287
+ }
1288
+ unbindDocumentListeners() {
1289
+ if (isPlatformBrowser(this.platformId)) {
1290
+ if (this.documentResizeListener) {
1291
+ this.documentResizeListener();
1292
+ this.documentResizeListener = null;
1293
+ }
1294
+ }
1295
+ }
1296
+ legacyOnDestroy() {
1297
+ this.unbindDocumentListeners();
1298
+ this.stopAutoplay();
1299
+ if (this.carouselStyle) {
1300
+ this.carouselStyle.remove();
1301
+ this.carouselStyle = null;
1302
+ }
1303
+ }
1304
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselLegacyBase, deps: [], target: i0.ɵɵFactoryTarget.Directive });
1305
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "22.0.3", type: CarouselLegacyBase, isStandalone: true, inputs: { page: { classPropertyName: "page", publicName: "page", isSignal: true, isRequired: false, transformFunction: null }, numVisible: { classPropertyName: "numVisible", publicName: "numVisible", isSignal: true, isRequired: false, transformFunction: null }, numScroll: { classPropertyName: "numScroll", publicName: "numScroll", isSignal: true, isRequired: false, transformFunction: null }, responsiveOptions: { classPropertyName: "responsiveOptions", publicName: "responsiveOptions", isSignal: true, isRequired: false, transformFunction: null }, orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null }, verticalViewPortHeight: { classPropertyName: "verticalViewPortHeight", publicName: "verticalViewPortHeight", isSignal: true, isRequired: false, transformFunction: null }, contentClass: { classPropertyName: "contentClass", publicName: "contentClass", isSignal: true, isRequired: false, transformFunction: null }, indicatorsContentClass: { classPropertyName: "indicatorsContentClass", publicName: "indicatorsContentClass", isSignal: true, isRequired: false, transformFunction: null }, indicatorsContentStyle: { classPropertyName: "indicatorsContentStyle", publicName: "indicatorsContentStyle", isSignal: true, isRequired: false, transformFunction: null }, indicatorStyleClass: { classPropertyName: "indicatorStyleClass", publicName: "indicatorStyleClass", isSignal: true, isRequired: false, transformFunction: null }, indicatorStyle: { classPropertyName: "indicatorStyle", publicName: "indicatorStyle", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, circular: { classPropertyName: "circular", publicName: "circular", isSignal: true, isRequired: false, transformFunction: null }, showIndicators: { classPropertyName: "showIndicators", publicName: "showIndicators", isSignal: true, isRequired: false, transformFunction: null }, showNavigators: { classPropertyName: "showNavigators", publicName: "showNavigators", isSignal: true, isRequired: false, transformFunction: null }, autoplayInterval: { classPropertyName: "autoplayInterval", publicName: "autoplayInterval", isSignal: true, isRequired: false, transformFunction: null }, prevButtonProps: { classPropertyName: "prevButtonProps", publicName: "prevButtonProps", isSignal: true, isRequired: false, transformFunction: null }, nextButtonProps: { classPropertyName: "nextButtonProps", publicName: "nextButtonProps", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onPage: "onPage" }, queries: [{ propertyName: "headerFacet", first: true, predicate: Header, isSignal: true }, { propertyName: "footerFacet", first: true, predicate: Footer, isSignal: true }, { propertyName: "itemTemplate", first: true, predicate: ["item"], isSignal: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ["footer"], isSignal: true }, { propertyName: "previousIconTemplate", first: true, predicate: ["previousicon"], isSignal: true }, { propertyName: "nextIconTemplate", first: true, predicate: ["nexticon"], isSignal: true }], viewQueries: [{ propertyName: "itemsContainer", first: true, predicate: ["itemsContainer"], descendants: true, isSignal: true }, { propertyName: "indicatorContent", first: true, predicate: ["indicatorContent"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0 });
1306
+ }
1307
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselLegacyBase, decorators: [{
1308
+ type: Directive
1309
+ }], ctorParameters: () => [], propDecorators: { page: [{ type: i0.Input, args: [{ isSignal: true, alias: "page", required: false }] }], numVisible: [{ type: i0.Input, args: [{ isSignal: true, alias: "numVisible", required: false }] }], numScroll: [{ type: i0.Input, args: [{ isSignal: true, alias: "numScroll", required: false }] }], responsiveOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "responsiveOptions", required: false }] }], orientation: [{ type: i0.Input, args: [{ isSignal: true, alias: "orientation", required: false }] }], verticalViewPortHeight: [{ type: i0.Input, args: [{ isSignal: true, alias: "verticalViewPortHeight", required: false }] }], contentClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "contentClass", required: false }] }], indicatorsContentClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "indicatorsContentClass", required: false }] }], indicatorsContentStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "indicatorsContentStyle", required: false }] }], indicatorStyleClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "indicatorStyleClass", required: false }] }], indicatorStyle: [{ type: i0.Input, args: [{ isSignal: true, alias: "indicatorStyle", required: false }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }], circular: [{ type: i0.Input, args: [{ isSignal: true, alias: "circular", required: false }] }], showIndicators: [{ type: i0.Input, args: [{ isSignal: true, alias: "showIndicators", required: false }] }], showNavigators: [{ type: i0.Input, args: [{ isSignal: true, alias: "showNavigators", required: false }] }], autoplayInterval: [{ type: i0.Input, args: [{ isSignal: true, alias: "autoplayInterval", required: false }] }], prevButtonProps: [{ type: i0.Input, args: [{ isSignal: true, alias: "prevButtonProps", required: false }] }], nextButtonProps: [{ type: i0.Input, args: [{ isSignal: true, alias: "nextButtonProps", required: false }] }], onPage: [{ type: i0.Output, args: ["onPage"] }], itemsContainer: [{ type: i0.ViewChild, args: ['itemsContainer', { isSignal: true }] }], indicatorContent: [{ type: i0.ViewChild, args: ['indicatorContent', { isSignal: true }] }], headerFacet: [{ type: i0.ContentChild, args: [i0.forwardRef(() => Header), { ...{ descendants: false }, isSignal: true }] }], footerFacet: [{ type: i0.ContentChild, args: [i0.forwardRef(() => Footer), { ...{ descendants: false }, isSignal: true }] }], itemTemplate: [{ type: i0.ContentChild, args: ['item', { ...{ descendants: false }, isSignal: true }] }], headerTemplate: [{ type: i0.ContentChild, args: ['header', { ...{ descendants: false }, isSignal: true }] }], footerTemplate: [{ type: i0.ContentChild, args: ['footer', { ...{ descendants: false }, isSignal: true }] }], previousIconTemplate: [{ type: i0.ContentChild, args: ['previousicon', { ...{ descendants: false }, isSignal: true }] }], nextIconTemplate: [{ type: i0.ContentChild, args: ['nexticon', { ...{ descendants: false }, isSignal: true }] }] } });
1310
+
1311
+ /**
1312
+ * Carousel is a content slider featuring various customization options.
1313
+ * @group Components
1314
+ */
1315
+ class Carousel extends CarouselLegacyBase {
1316
+ componentName = 'Carousel';
1317
+ bindDirectiveInstance = inject(Bind, { self: true });
1318
+ onAfterViewChecked() {
1319
+ this.bindDirectiveInstance.setAttrs(this.ptm('root'));
1320
+ }
1321
+ _compositionContent = contentChildren(CarouselContent, { ...(ngDevMode ? { debugName: "_compositionContent" } : /* istanbul ignore next */ {}), descendants: true });
1322
+ isCompositionMode = computed(() => this._compositionContent().length > 0, /* @ts-ignore */
1323
+ ...(ngDevMode ? [{ debugName: "isCompositionMode" }] : /* istanbul ignore next */ []));
1324
+ hostClass = computed(() => (this.isCompositionMode() ? this.cx('compositionRoot') : this.cx('root')), /* @ts-ignore */
1325
+ ...(ngDevMode ? [{ debugName: "hostClass" }] : /* istanbul ignore next */ []));
1326
+ /**
1327
+ * Alignment of the carousel items (composition mode).
1328
+ * @group Props
1329
+ * @defaultValue 'start'
1330
+ */
1331
+ align = input('start', /* @ts-ignore */
1332
+ ...(ngDevMode ? [{ debugName: "align" }] : /* istanbul ignore next */ []));
1333
+ /**
1334
+ * Alias for orientation used by composition mode host bindings.
1335
+ * Delegates to the existing `orientation` input.
1336
+ */
1337
+ compositionOrientation = computed(() => this.orientation(), /* @ts-ignore */
1338
+ ...(ngDevMode ? [{ debugName: "compositionOrientation" }] : /* istanbul ignore next */ []));
1339
+ /**
1340
+ * Alias for align used by composition mode host bindings.
1341
+ * Delegates to the `align` input.
1342
+ */
1343
+ compositionAlign = computed(() => this.align(), /* @ts-ignore */
1344
+ ...(ngDevMode ? [{ debugName: "compositionAlign" }] : /* istanbul ignore next */ []));
1345
+ /**
1346
+ * Whether the carousel should loop (composition mode).
1347
+ * @group Props
1348
+ * @defaultValue false
1349
+ */
1350
+ loop = input(false, { ...(ngDevMode ? { debugName: "loop" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1351
+ /**
1352
+ * Scroll snap type applied to the track (composition mode).
1353
+ * @group Props
1354
+ * @defaultValue 'mandatory'
1355
+ */
1356
+ snapType = input('mandatory', /* @ts-ignore */
1357
+ ...(ngDevMode ? [{ debugName: "snapType" }] : /* istanbul ignore next */ []));
1358
+ /**
1359
+ * Spacing between carousel items in pixels (composition mode).
1360
+ * @group Props
1361
+ * @defaultValue 16
1362
+ */
1363
+ spacing = input(16, { ...(ngDevMode ? { debugName: "spacing" } : /* istanbul ignore next */ {}), transform: numberAttribute });
1364
+ /**
1365
+ * Whether the carousel should auto size items (composition mode).
1366
+ * @group Props
1367
+ * @defaultValue false
1368
+ */
1369
+ autoSize = input(false, { ...(ngDevMode ? { debugName: "autoSize" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
1370
+ /**
1371
+ * Alias for autoSize used by composition mode host bindings.
1372
+ */
1373
+ compositionAutoSize = computed(() => this.autoSize(), /* @ts-ignore */
1374
+ ...(ngDevMode ? [{ debugName: "compositionAutoSize" }] : /* istanbul ignore next */ []));
1375
+ // Host data attributes (composition mode only)
1376
+ dataScope = computed(() => (this.isCompositionMode() ? 'carousel' : null), /* @ts-ignore */
1377
+ ...(ngDevMode ? [{ debugName: "dataScope" }] : /* istanbul ignore next */ []));
1378
+ dataPart = computed(() => (this.isCompositionMode() ? 'root' : null), /* @ts-ignore */
1379
+ ...(ngDevMode ? [{ debugName: "dataPart" }] : /* istanbul ignore next */ []));
1380
+ dataOrientation = computed(() => (this.isCompositionMode() ? this.compositionOrientation() : null), /* @ts-ignore */
1381
+ ...(ngDevMode ? [{ debugName: "dataOrientation" }] : /* istanbul ignore next */ []));
1382
+ dataAlign = computed(() => (this.isCompositionMode() ? this.compositionAlign() : null), /* @ts-ignore */
1383
+ ...(ngDevMode ? [{ debugName: "dataAlign" }] : /* istanbul ignore next */ []));
1384
+ dataPage = computed(() => (this.isCompositionMode() ? this.pageState() : null), /* @ts-ignore */
1385
+ ...(ngDevMode ? [{ debugName: "dataPage" }] : /* istanbul ignore next */ []));
1386
+ dataSwiping = computed(() => (this.isCompositionMode() && this.swiping() ? '' : null), /* @ts-ignore */
1387
+ ...(ngDevMode ? [{ debugName: "dataSwiping" }] : /* istanbul ignore next */ []));
1388
+ dataAutosize = computed(() => (this.isCompositionMode() && this.compositionAutoSize() ? '' : null), /* @ts-ignore */
1389
+ ...(ngDevMode ? [{ debugName: "dataAutosize" }] : /* istanbul ignore next */ []));
1390
+ /**
1391
+ * How many slides are visible per page (composition mode). Supports fractions (e.g. 1.5).
1392
+ * @group Props
1393
+ * @defaultValue 1
1394
+ */
1395
+ slidesPerPage = input(1, { ...(ngDevMode ? { debugName: "slidesPerPage" } : /* istanbul ignore next */ {}), transform: numberAttribute });
1396
+ /**
1397
+ * Index of the active slide (composition mode).
1398
+ * @group Props
1399
+ */
1400
+ slide = input(undefined, /* @ts-ignore */
1401
+ ...(ngDevMode ? [{ debugName: "slide" }] : /* istanbul ignore next */ []));
1402
+ /**
1403
+ * Callback fired when the carousel's page changes (composition mode).
1404
+ * @group Emits
1405
+ */
1406
+ onPageChange = output();
1407
+ /**
1408
+ * Callback fired when the active slide changes (composition mode).
1409
+ * @group Emits
1410
+ */
1411
+ onSlideChange = output();
1412
+ // ==========================================
1413
+ // Composition mode signals
1414
+ // ==========================================
1415
+ swiping = signal(false, /* @ts-ignore */
1416
+ ...(ngDevMode ? [{ debugName: "swiping" }] : /* istanbul ignore next */ []));
1417
+ isNextDisabled = signal(false, /* @ts-ignore */
1418
+ ...(ngDevMode ? [{ debugName: "isNextDisabled" }] : /* istanbul ignore next */ []));
1419
+ isPrevDisabled = signal(false, /* @ts-ignore */
1420
+ ...(ngDevMode ? [{ debugName: "isPrevDisabled" }] : /* istanbul ignore next */ []));
1421
+ snapPoints = signal(new Set(), /* @ts-ignore */
1422
+ ...(ngDevMode ? [{ debugName: "snapPoints" }] : /* istanbul ignore next */ []));
1423
+ pageState = signal(0, /* @ts-ignore */
1424
+ ...(ngDevMode ? [{ debugName: "pageState" }] : /* istanbul ignore next */ []));
1425
+ contentEl = signal(null, /* @ts-ignore */
1426
+ ...(ngDevMode ? [{ debugName: "contentEl" }] : /* istanbul ignore next */ []));
1427
+ _snapPointsRef = new Set();
1428
+ _scrollSnapsRef = [];
1429
+ _initialPageApplied = false;
1430
+ _initialControlledScroll = false;
1431
+ _resizeObserver = null;
1432
+ _mutationObserver = null;
1433
+ _intersectionObserver = null;
1434
+ _scrollTimeout = null;
1435
+ _wheelTimeout = null;
1436
+ _scrollListener = null;
1437
+ _destroyed = false;
1438
+ _swipeStartPoint = { x: 0, y: 0 };
1439
+ _isRealSwipe = false;
1440
+ _itemSelector = '[data-item]';
1441
+ _areSetsEqual(a, b) {
1442
+ if (a.size !== b.size)
1443
+ return false;
1444
+ for (const value of a) {
1445
+ if (!b.has(value))
1446
+ return false;
1447
+ }
1448
+ return true;
1449
+ }
1450
+ constructor() {
1451
+ super();
1452
+ // Composition mode: watch slide input changes
1453
+ effect(() => {
1454
+ const slideVal = this.slide();
1455
+ if (slideVal === undefined || slideVal === null)
1456
+ return;
1457
+ if (!this.isCompositionMode())
1458
+ return;
1459
+ untracked(() => {
1460
+ if (this._snapPointsRef.size > 0) {
1461
+ this.scrollToSlide(slideVal);
1462
+ }
1463
+ });
1464
+ });
1465
+ }
1466
+ onAfterContentInit() {
1467
+ this.legacyOnAfterContentInit();
1468
+ }
1469
+ onAfterContentChecked() {
1470
+ this.legacyOnAfterContentChecked();
1471
+ }
1472
+ onDestroy() {
1473
+ this._destroyed = true;
1474
+ this.legacyOnDestroy();
1475
+ // Composition mode cleanup
1476
+ this._resizeObserver?.disconnect();
1477
+ this._mutationObserver?.disconnect();
1478
+ this._intersectionObserver?.disconnect();
1479
+ this._scrollListener?.();
1480
+ if (this._scrollTimeout)
1481
+ clearTimeout(this._scrollTimeout);
1482
+ if (this._wheelTimeout)
1483
+ clearTimeout(this._wheelTimeout);
1484
+ }
1485
+ resolveSnapType() {
1486
+ const axis = this.orientation() === 'vertical' ? 'y' : 'x';
1487
+ return `${axis} ${this.snapType()}`;
1488
+ }
1489
+ setupObservers() {
1490
+ const content = this.contentEl();
1491
+ if (!content)
1492
+ return;
1493
+ // ResizeObserver
1494
+ this._resizeObserver = new ResizeObserver(() => {
1495
+ this.computeSnapPoints();
1496
+ const closest = this.setToClosest();
1497
+ this.scrollToPage(closest ?? this.pageState(), true);
1498
+ });
1499
+ this._resizeObserver.observe(content);
1500
+ this._observeResizeItems(content);
1501
+ // Delay initial computation to ensure items have their data-item attributes
1502
+ requestAnimationFrame(() => {
1503
+ this.computeSnapPoints();
1504
+ this._observeResizeItems(content);
1505
+ this._observeIntersectionItems(content);
1506
+ this._applyInitialPage();
1507
+ this._applyControlledPage();
1508
+ this._applyControlledSlide();
1509
+ });
1510
+ // MutationObserver
1511
+ this._mutationObserver = new MutationObserver((mutations) => {
1512
+ mutations.forEach(() => {
1513
+ this.computeSnapPoints();
1514
+ this._observeResizeItems(content);
1515
+ this._observeIntersectionItems(content);
1516
+ requestAnimationFrame(() => {
1517
+ const closest = this.setToClosest();
1518
+ this.scrollToPage(closest ?? this.pageState(), true);
1519
+ });
1520
+ });
1521
+ });
1522
+ this._mutationObserver.observe(content, { childList: true, subtree: true });
1523
+ // IntersectionObserver
1524
+ this._intersectionObserver = new IntersectionObserver((entries) => {
1525
+ entries.forEach((entry) => {
1526
+ if (entry.isIntersecting)
1527
+ entry.target.setAttribute('data-inview', '');
1528
+ else
1529
+ entry.target.removeAttribute('data-inview');
1530
+ });
1531
+ }, { root: content, threshold: 0.6 });
1532
+ this._observeIntersectionItems(content);
1533
+ // Scroll listener
1534
+ const onScroll = () => {
1535
+ if (this._scrollTimeout)
1536
+ clearTimeout(this._scrollTimeout);
1537
+ this._scrollTimeout = setTimeout(() => {
1538
+ this.setToClosest();
1539
+ }, 80);
1540
+ };
1541
+ onScroll();
1542
+ content.addEventListener('scroll', onScroll, { passive: true });
1543
+ this._scrollListener = () => content.removeEventListener('scroll', onScroll);
1544
+ }
1545
+ _applyInitialPage() {
1546
+ if (this._initialPageApplied)
1547
+ return;
1548
+ const slideInput = this.slide();
1549
+ if (slideInput !== undefined && slideInput !== null)
1550
+ return;
1551
+ const size = this._snapPointsRef.size || this.snapPoints().size;
1552
+ if (size === 0)
1553
+ return;
1554
+ this._initialPageApplied = true;
1555
+ this.scrollToPage(0, true);
1556
+ }
1557
+ _applyControlledPage() {
1558
+ const pageInput = this.page();
1559
+ const slideInput = this.slide();
1560
+ if (pageInput === undefined || pageInput === null)
1561
+ return;
1562
+ if (slideInput !== undefined && slideInput !== null)
1563
+ return;
1564
+ if (this._snapPointsRef.size === 0 && this.snapPoints().size === 0)
1565
+ return;
1566
+ const instant = !this._initialControlledScroll;
1567
+ this._initialControlledScroll = true;
1568
+ this.scrollToPage(pageInput, instant);
1569
+ }
1570
+ _applyControlledSlide() {
1571
+ const slideInput = this.slide();
1572
+ if (slideInput === undefined || slideInput === null)
1573
+ return;
1574
+ if (this._snapPointsRef.size === 0 && this.snapPoints().size === 0)
1575
+ return;
1576
+ const instant = !this._initialControlledScroll;
1577
+ this._initialControlledScroll = true;
1578
+ this.scrollToSlide(slideInput, instant);
1579
+ }
1580
+ _observeResizeItems(content) {
1581
+ if (!this._resizeObserver)
1582
+ return;
1583
+ content.querySelectorAll(this._itemSelector).forEach((item) => this._resizeObserver.observe(item));
1584
+ }
1585
+ _observeIntersectionItems(content) {
1586
+ if (!this._intersectionObserver)
1587
+ return;
1588
+ content.querySelectorAll(this._itemSelector).forEach((item) => this._intersectionObserver.observe(item));
1589
+ }
1590
+ computeSnapPoints() {
1591
+ const content = this.contentEl();
1592
+ if (!content)
1593
+ return;
1594
+ const isHorizontal = this.orientation() !== 'vertical';
1595
+ const trackSize = isHorizontal ? content.clientWidth : content.clientHeight;
1596
+ const maxOffset = Math.max(0, isHorizontal ? content.scrollWidth - trackSize : content.scrollHeight - trackSize);
1597
+ const snaps = [];
1598
+ const alignValue = this.align();
1599
+ this._scrollSnapsRef = [];
1600
+ content.querySelectorAll(this._itemSelector).forEach((item) => {
1601
+ const offset = isHorizontal ? item.offsetLeft : item.offsetTop;
1602
+ const size = isHorizontal ? item.clientWidth : item.clientHeight;
1603
+ let snapPoint = offset;
1604
+ if (alignValue === 'center') {
1605
+ snapPoint = offset - (trackSize - size) / 2;
1606
+ }
1607
+ else if (alignValue === 'end') {
1608
+ snapPoint = offset - (trackSize - size);
1609
+ }
1610
+ const clamped = Math.max(0, Math.min(snapPoint, maxOffset));
1611
+ this._scrollSnapsRef.push(clamped);
1612
+ snaps.push(clamped);
1613
+ });
1614
+ const newSnapPoints = new Set(snaps.map(Number));
1615
+ if (this._areSetsEqual(this._snapPointsRef, newSnapPoints))
1616
+ return;
1617
+ this._snapPointsRef = newSnapPoints;
1618
+ this.snapPoints.set(newSnapPoints);
1619
+ }
1620
+ setPage(page) {
1621
+ // Pending requestAnimationFrame/observer callbacks can still reach this after teardown;
1622
+ // bail so we don't emit on a destroyed OutputRef.
1623
+ if (this._destroyed)
1624
+ return;
1625
+ if (!this.loop()) {
1626
+ const size = this._snapPointsRef.size || this.snapPoints().size;
1627
+ this.isPrevDisabled.set(page === 0);
1628
+ this.isNextDisabled.set(page === size - 1);
1629
+ }
1630
+ this.pageState.set(page);
1631
+ this.onPageChange.emit({ value: page });
1632
+ this.onSlideChange.emit({ value: page });
1633
+ }
1634
+ setToClosest() {
1635
+ const content = this.contentEl();
1636
+ const points = this._snapPointsRef;
1637
+ if (!content || points.size === 0)
1638
+ return undefined;
1639
+ const scrollPos = this.orientation() === 'horizontal' ? content.scrollLeft : content.scrollTop;
1640
+ const closestSnapPoint = Array.from(points).reduce((closest, point) => {
1641
+ return Math.abs(point - scrollPos) < Math.abs(closest - scrollPos) ? point : closest;
1642
+ }, Infinity);
1643
+ const index = Array.from(points).indexOf(closestSnapPoint);
1644
+ this.setPage(index);
1645
+ return index;
1646
+ }
1647
+ scrollToPage(pageNum, instant = false) {
1648
+ const points = this._snapPointsRef;
1649
+ if (points.size === 0)
1650
+ return;
1651
+ const target = pageNum ?? this.pageState();
1652
+ const clampedPage = this.loop() ? (target + points.size) % points.size : Math.max(0, Math.min(target, points.size - 1));
1653
+ this.setPage(clampedPage);
1654
+ this.scrollTo(Array.from(points)[clampedPage], instant);
1655
+ }
1656
+ next() {
1657
+ this.scrollToPage(this.pageState() + 1);
1658
+ }
1659
+ prev() {
1660
+ this.scrollToPage(this.pageState() - 1);
1661
+ }
1662
+ scrollTo(snapPoint, instant = false) {
1663
+ const content = this.contentEl();
1664
+ if (!content)
1665
+ return;
1666
+ content.scrollTo({
1667
+ [this.orientation() === 'horizontal' ? 'left' : 'top']: snapPoint,
1668
+ behavior: instant ? 'instant' : 'smooth'
1669
+ });
1670
+ }
1671
+ scrollToSlide(slideNum, instant = false) {
1672
+ const points = this._snapPointsRef;
1673
+ const snaps = this._scrollSnapsRef;
1674
+ if (points.size === 0 || snaps.length === 0)
1675
+ return;
1676
+ const clampedSlide = Math.max(0, Math.min(slideNum, snaps.length - 1));
1677
+ const snap = snaps[clampedSlide];
1678
+ this.scrollTo(snap, instant);
1679
+ const pageIdx = Array.from(points).indexOf(snap);
1680
+ this.setPage(pageIdx);
1681
+ }
1682
+ setContentEl(el) {
1683
+ this.contentEl.set(el);
1684
+ }
1685
+ // Pointer event handlers (called by CarouselContent)
1686
+ onContentPointerDown(e) {
1687
+ if (e.button !== 0)
1688
+ return;
1689
+ if (e.pointerType === 'touch')
1690
+ return;
1691
+ this.swiping.set(true);
1692
+ this._swipeStartPoint = { x: e.clientX, y: e.clientY };
1693
+ this._isRealSwipe = false;
1694
+ }
1695
+ onContentPointerMove(e) {
1696
+ const content = this.contentEl();
1697
+ if (!this.swiping() || !content || e.pointerType === 'touch')
1698
+ return;
1699
+ const deltaX = e.clientX - this._swipeStartPoint.x;
1700
+ const deltaY = e.clientY - this._swipeStartPoint.y;
1701
+ const distance = Math.abs(deltaX) + Math.abs(deltaY);
1702
+ if (distance < 6)
1703
+ return;
1704
+ if ((window.getSelection()?.toString().length ?? 0) > 0)
1705
+ return;
1706
+ e.currentTarget.setPointerCapture(e.pointerId);
1707
+ content.style.userSelect = 'none';
1708
+ this._isRealSwipe = true;
1709
+ content.style.scrollSnapType = 'none';
1710
+ content.scrollBy({ left: -e.movementX, top: -e.movementY, behavior: 'instant' });
1711
+ e.preventDefault();
1712
+ }
1713
+ onContentPointerUp(e) {
1714
+ this.swiping.set(false);
1715
+ e.currentTarget.releasePointerCapture(e.pointerId);
1716
+ if (!this._isRealSwipe)
1717
+ return;
1718
+ const content = this.contentEl();
1719
+ if (!content)
1720
+ return;
1721
+ content.style.userSelect = '';
1722
+ const scrollPos = this.orientation() === 'horizontal' ? content.scrollLeft : content.scrollTop;
1723
+ const snapPointsSet = this._snapPointsRef;
1724
+ const closestSnapPoint = Array.from(snapPointsSet).reduce((closest, point) => {
1725
+ return Math.abs(point - scrollPos) < Math.abs(closest - scrollPos) ? point : closest;
1726
+ }, Infinity);
1727
+ const index = Array.from(snapPointsSet).indexOf(closestSnapPoint);
1728
+ requestAnimationFrame(() => {
1729
+ if (closestSnapPoint !== undefined)
1730
+ this.scrollToPage(index);
1731
+ requestAnimationFrame(() => {
1732
+ content.style.scrollSnapType = this.resolveSnapType();
1733
+ });
1734
+ });
1735
+ }
1736
+ onContentWheel(e) {
1737
+ if (this._wheelTimeout)
1738
+ clearTimeout(this._wheelTimeout);
1739
+ this._wheelTimeout = setTimeout(() => {
1740
+ const primaryDelta = this.orientation() === 'horizontal' ? e.deltaX || e.deltaY : e.deltaY || e.deltaX;
1741
+ if (primaryDelta > 0 && this.isNextDisabled())
1742
+ return;
1743
+ if (primaryDelta < 0 && this.isPrevDisabled())
1744
+ return;
1745
+ this.setToClosest();
1746
+ }, 80);
1747
+ }
1748
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Carousel, deps: [], target: i0.ɵɵFactoryTarget.Component });
1749
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: Carousel, isStandalone: true, selector: "p-carousel", inputs: { align: { classPropertyName: "align", publicName: "align", isSignal: true, isRequired: false, transformFunction: null }, loop: { classPropertyName: "loop", publicName: "loop", isSignal: true, isRequired: false, transformFunction: null }, snapType: { classPropertyName: "snapType", publicName: "snapType", isSignal: true, isRequired: false, transformFunction: null }, spacing: { classPropertyName: "spacing", publicName: "spacing", isSignal: true, isRequired: false, transformFunction: null }, autoSize: { classPropertyName: "autoSize", publicName: "autoSize", isSignal: true, isRequired: false, transformFunction: null }, slidesPerPage: { classPropertyName: "slidesPerPage", publicName: "slidesPerPage", isSignal: true, isRequired: false, transformFunction: null }, slide: { classPropertyName: "slide", publicName: "slide", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onPageChange: "onPageChange", onSlideChange: "onSlideChange" }, host: { properties: { "attr.id": "id", "attr.role": "'region'", "class": "hostClass()", "attr.data-scope": "dataScope()", "attr.data-part": "dataPart()", "attr.data-orientation": "dataOrientation()", "attr.data-align": "dataAlign()", "attr.data-page": "dataPage()", "attr.data-swiping": "dataSwiping()", "attr.data-autosize": "dataAutosize()" } }, providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: Carousel }, { provide: CAROUSEL_ROOT, useExisting: Carousel }], queries: [{ propertyName: "_compositionContent", predicate: CarouselContent, descendants: true, isSignal: true }], usesInheritance: true, hostDirectives: [{ directive: i1.Bind }], ngImport: i0, template: `
1750
+ @if (isCompositionMode()) {
1751
+ <ng-content></ng-content>
1752
+ } @else {
1753
+ @if (hasHeader()) {
1754
+ <div [class]="cx('header')" [pBind]="ptm('header')">
1755
+ <ng-content select="p-header"></ng-content>
1756
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
1757
+ </div>
1758
+ }
1759
+ <div [class]="cn(cx('contentContainer'), contentClass())" [pBind]="ptm('contentContainer')">
1760
+ <div [class]="cx('content')" [attr.aria-live]="ariaLive()" [pBind]="ptm('content')">
1761
+ @if (showNavigators()) {
1762
+ <button
1763
+ type="button"
1764
+ iconOnly
1765
+ [pButton]="prevButtonProps()"
1766
+ [text]="true"
1767
+ [class]="cx('pcPrevButton')"
1768
+ [attr.aria-label]="ariaPrevButtonLabel()"
1769
+ attr.data-pc-group-section="navigator"
1770
+ [pButtonPT]="ptm('pcPrevButton')"
1771
+ [pButtonUnstyled]="unstyled()"
1772
+ (click)="navBackward($event)"
1773
+ >
1774
+ @if (showDefaultPrevIcon()) {
1775
+ @if (!isVertical()) {
1776
+ <svg data-p-icon="chevron-left" />
1777
+ }
1778
+ @if (isVertical()) {
1779
+ <svg data-p-icon="chevron-up" />
1780
+ }
1781
+ }
1782
+ @if (showPrevIconTemplate()) {
1783
+ <ng-template *ngTemplateOutlet="previousIconTemplate()"></ng-template>
1784
+ }
1785
+ </button>
1786
+ }
1787
+ <div [class]="cx('viewport')" [style]="viewportStyle()" (touchend)="onTouchEnd($event)" (touchstart)="onTouchStart($event)" (touchmove)="onTouchMove($event)" [pBind]="ptm('viewport')">
1788
+ <div #itemsContainer [class]="cx('itemList')" (transitionend)="onTransitionEnd()" [pBind]="ptm('itemList')">
1789
+ @for (item of clonedItemsForStarting(); track $index; let i = $index) {
1790
+ <div
1791
+ [class]="cx('itemClone', { index: i })"
1792
+ [attr.aria-hidden]="isCloneStartAriaHidden()"
1793
+ [attr.aria-label]="ariaSlideNumber(i)"
1794
+ [attr.aria-roledescription]="ariaSlideLabel()"
1795
+ [attr.data-p-carousel-item-active]="isCloneStartActive()"
1796
+ [attr.data-p-carousel-item-start]="i === 0"
1797
+ [attr.data-p-carousel-item-end]="isCloneStartEnd(i)"
1798
+ [pBind]="ptm('itemClone')"
1799
+ >
1800
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1801
+ </div>
1802
+ }
1803
+ @for (item of value(); track $index; let i = $index) {
1804
+ <div
1805
+ [class]="cx('item', { index: i })"
1806
+ role="group"
1807
+ [attr.aria-hidden]="isItemAriaHidden(i)"
1808
+ [attr.aria-label]="ariaSlideNumber(i)"
1809
+ [attr.aria-roledescription]="ariaSlideLabel()"
1810
+ [attr.data-p-carousel-item-active]="isItemActive(i)"
1811
+ [attr.data-p-carousel-item-start]="isItemStart(i)"
1812
+ [attr.data-p-carousel-item-end]="isItemEnd(i)"
1813
+ [pBind]="getItemPTOptions('item', i)"
1814
+ >
1815
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1816
+ </div>
1817
+ }
1818
+ @for (item of clonedItemsForFinishing(); track $index) {
1819
+ <div [class]="cx('itemClone', { index: 0 })" [attr.data-p-carousel-item-active]="false" [attr.data-p-carousel-item-start]="false" [attr.data-p-carousel-item-end]="false" [pBind]="ptm('itemClone')">
1820
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1821
+ </div>
1822
+ }
1823
+ </div>
1824
+ </div>
1825
+ @if (showNavigators()) {
1826
+ <button
1827
+ type="button"
1828
+ iconOnly
1829
+ [pButton]="nextButtonProps()"
1830
+ [text]="true"
1831
+ [class]="cx('pcNextButton')"
1832
+ [attr.aria-label]="ariaNextButtonLabel()"
1833
+ attr.data-pc-group-section="navigator"
1834
+ [pButtonPT]="ptm('pcNextButton')"
1835
+ [pButtonUnstyled]="unstyled()"
1836
+ (click)="navForward($event)"
1837
+ >
1838
+ @if (showDefaultNextIcon()) {
1839
+ @if (!isVertical()) {
1840
+ <svg data-p-icon="chevron-right" />
1841
+ }
1842
+ @if (isVertical()) {
1843
+ <svg data-p-icon="chevron-down" />
1844
+ }
1845
+ }
1846
+ @if (showNextIconTemplate()) {
1847
+ <ng-template *ngTemplateOutlet="nextIconTemplate()"></ng-template>
1848
+ }
1849
+ </button>
1850
+ }
1851
+ </div>
1852
+ @if (showIndicators()) {
1853
+ <ul #indicatorContent [class]="cx('indicatorList')" [style]="indicatorsContentStyle()" (keydown)="onIndicatorKeydown($event)" [pBind]="ptm('indicatorList')">
1854
+ @for (dot of totalDotsArray(); track dot) {
1855
+ <li [class]="cx('indicator', { index: dot })" [attr.data-p-active]="isIndicatorActive(dot)" [pBind]="getIndicatorPTOptions('indicator', dot)">
1856
+ <button
1857
+ type="button"
1858
+ [class]="cx('indicatorButton')"
1859
+ (click)="onDotClick($event, dot)"
1860
+ [style]="indicatorStyle()"
1861
+ [attr.aria-label]="ariaPageLabel(dot + 1)"
1862
+ [attr.aria-current]="getIndicatorAriaCurrent(dot)"
1863
+ [tabindex]="getIndicatorTabindex(dot)"
1864
+ [pBind]="getIndicatorPTOptions('indicatorButton', dot)"
1865
+ ></button>
1866
+ </li>
1867
+ }
1868
+ </ul>
1869
+ }
1870
+ </div>
1871
+ @if (hasFooter()) {
1872
+ <div [class]="cx('footer')" [pBind]="ptm('footer')">
1873
+ <ng-content select="p-footer"></ng-content>
1874
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
1875
+ </div>
1876
+ }
1877
+ }
1878
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ChevronRight, selector: "svg[data-p-icon=\"chevron-right\"]" }, { kind: "directive", type: ButtonDirective, selector: "[pButton]", inputs: ["pButton", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "link", "rounded", "fluid", "variant", "iconOnly", "loading", "severity"] }, { kind: "component", type: ChevronLeft, selector: "svg[data-p-icon=\"chevron-left\"]" }, { kind: "component", type: ChevronDown, selector: "svg[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: ChevronUp, selector: "svg[data-p-icon=\"chevron-up\"]" }, { kind: "ngmodule", type: SharedModule }, { kind: "ngmodule", type: BindModule }, { kind: "directive", type: i1.Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1879
+ }
1880
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Carousel, decorators: [{
1881
+ type: Component,
1882
+ args: [{
1883
+ selector: 'p-carousel',
1884
+ standalone: true,
1885
+ imports: [NgTemplateOutlet, ChevronRight, ButtonDirective, ChevronLeft, ChevronDown, ChevronUp, SharedModule, BindModule],
1886
+ template: `
1887
+ @if (isCompositionMode()) {
1888
+ <ng-content></ng-content>
1889
+ } @else {
1890
+ @if (hasHeader()) {
1891
+ <div [class]="cx('header')" [pBind]="ptm('header')">
1892
+ <ng-content select="p-header"></ng-content>
1893
+ <ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
1894
+ </div>
1895
+ }
1896
+ <div [class]="cn(cx('contentContainer'), contentClass())" [pBind]="ptm('contentContainer')">
1897
+ <div [class]="cx('content')" [attr.aria-live]="ariaLive()" [pBind]="ptm('content')">
1898
+ @if (showNavigators()) {
1899
+ <button
1900
+ type="button"
1901
+ iconOnly
1902
+ [pButton]="prevButtonProps()"
1903
+ [text]="true"
1904
+ [class]="cx('pcPrevButton')"
1905
+ [attr.aria-label]="ariaPrevButtonLabel()"
1906
+ attr.data-pc-group-section="navigator"
1907
+ [pButtonPT]="ptm('pcPrevButton')"
1908
+ [pButtonUnstyled]="unstyled()"
1909
+ (click)="navBackward($event)"
1910
+ >
1911
+ @if (showDefaultPrevIcon()) {
1912
+ @if (!isVertical()) {
1913
+ <svg data-p-icon="chevron-left" />
1914
+ }
1915
+ @if (isVertical()) {
1916
+ <svg data-p-icon="chevron-up" />
1917
+ }
1918
+ }
1919
+ @if (showPrevIconTemplate()) {
1920
+ <ng-template *ngTemplateOutlet="previousIconTemplate()"></ng-template>
1921
+ }
1922
+ </button>
1923
+ }
1924
+ <div [class]="cx('viewport')" [style]="viewportStyle()" (touchend)="onTouchEnd($event)" (touchstart)="onTouchStart($event)" (touchmove)="onTouchMove($event)" [pBind]="ptm('viewport')">
1925
+ <div #itemsContainer [class]="cx('itemList')" (transitionend)="onTransitionEnd()" [pBind]="ptm('itemList')">
1926
+ @for (item of clonedItemsForStarting(); track $index; let i = $index) {
1927
+ <div
1928
+ [class]="cx('itemClone', { index: i })"
1929
+ [attr.aria-hidden]="isCloneStartAriaHidden()"
1930
+ [attr.aria-label]="ariaSlideNumber(i)"
1931
+ [attr.aria-roledescription]="ariaSlideLabel()"
1932
+ [attr.data-p-carousel-item-active]="isCloneStartActive()"
1933
+ [attr.data-p-carousel-item-start]="i === 0"
1934
+ [attr.data-p-carousel-item-end]="isCloneStartEnd(i)"
1935
+ [pBind]="ptm('itemClone')"
1936
+ >
1937
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1938
+ </div>
1939
+ }
1940
+ @for (item of value(); track $index; let i = $index) {
1941
+ <div
1942
+ [class]="cx('item', { index: i })"
1943
+ role="group"
1944
+ [attr.aria-hidden]="isItemAriaHidden(i)"
1945
+ [attr.aria-label]="ariaSlideNumber(i)"
1946
+ [attr.aria-roledescription]="ariaSlideLabel()"
1947
+ [attr.data-p-carousel-item-active]="isItemActive(i)"
1948
+ [attr.data-p-carousel-item-start]="isItemStart(i)"
1949
+ [attr.data-p-carousel-item-end]="isItemEnd(i)"
1950
+ [pBind]="getItemPTOptions('item', i)"
1951
+ >
1952
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1953
+ </div>
1954
+ }
1955
+ @for (item of clonedItemsForFinishing(); track $index) {
1956
+ <div [class]="cx('itemClone', { index: 0 })" [attr.data-p-carousel-item-active]="false" [attr.data-p-carousel-item-start]="false" [attr.data-p-carousel-item-end]="false" [pBind]="ptm('itemClone')">
1957
+ <ng-container *ngTemplateOutlet="itemTemplate(); context: { $implicit: item }"></ng-container>
1958
+ </div>
1959
+ }
1960
+ </div>
1961
+ </div>
1962
+ @if (showNavigators()) {
1963
+ <button
1964
+ type="button"
1965
+ iconOnly
1966
+ [pButton]="nextButtonProps()"
1967
+ [text]="true"
1968
+ [class]="cx('pcNextButton')"
1969
+ [attr.aria-label]="ariaNextButtonLabel()"
1970
+ attr.data-pc-group-section="navigator"
1971
+ [pButtonPT]="ptm('pcNextButton')"
1972
+ [pButtonUnstyled]="unstyled()"
1973
+ (click)="navForward($event)"
1974
+ >
1975
+ @if (showDefaultNextIcon()) {
1976
+ @if (!isVertical()) {
1977
+ <svg data-p-icon="chevron-right" />
1978
+ }
1979
+ @if (isVertical()) {
1980
+ <svg data-p-icon="chevron-down" />
1981
+ }
1982
+ }
1983
+ @if (showNextIconTemplate()) {
1984
+ <ng-template *ngTemplateOutlet="nextIconTemplate()"></ng-template>
1985
+ }
1986
+ </button>
1987
+ }
1988
+ </div>
1989
+ @if (showIndicators()) {
1990
+ <ul #indicatorContent [class]="cx('indicatorList')" [style]="indicatorsContentStyle()" (keydown)="onIndicatorKeydown($event)" [pBind]="ptm('indicatorList')">
1991
+ @for (dot of totalDotsArray(); track dot) {
1992
+ <li [class]="cx('indicator', { index: dot })" [attr.data-p-active]="isIndicatorActive(dot)" [pBind]="getIndicatorPTOptions('indicator', dot)">
1993
+ <button
1994
+ type="button"
1995
+ [class]="cx('indicatorButton')"
1996
+ (click)="onDotClick($event, dot)"
1997
+ [style]="indicatorStyle()"
1998
+ [attr.aria-label]="ariaPageLabel(dot + 1)"
1999
+ [attr.aria-current]="getIndicatorAriaCurrent(dot)"
2000
+ [tabindex]="getIndicatorTabindex(dot)"
2001
+ [pBind]="getIndicatorPTOptions('indicatorButton', dot)"
2002
+ ></button>
2003
+ </li>
2004
+ }
2005
+ </ul>
2006
+ }
2007
+ </div>
2008
+ @if (hasFooter()) {
2009
+ <div [class]="cx('footer')" [pBind]="ptm('footer')">
2010
+ <ng-content select="p-footer"></ng-content>
2011
+ <ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
2012
+ </div>
2013
+ }
2014
+ }
2015
+ `,
2016
+ changeDetection: ChangeDetectionStrategy.OnPush,
2017
+ encapsulation: ViewEncapsulation.None,
2018
+ providers: [CarouselStyle, { provide: PARENT_INSTANCE, useExisting: Carousel }, { provide: CAROUSEL_ROOT, useExisting: Carousel }],
2019
+ hostDirectives: [Bind],
2020
+ host: {
2021
+ '[attr.id]': 'id',
2022
+ '[attr.role]': "'region'",
2023
+ '[class]': 'hostClass()',
2024
+ '[attr.data-scope]': 'dataScope()',
2025
+ '[attr.data-part]': 'dataPart()',
2026
+ '[attr.data-orientation]': 'dataOrientation()',
2027
+ '[attr.data-align]': 'dataAlign()',
2028
+ '[attr.data-page]': 'dataPage()',
2029
+ '[attr.data-swiping]': 'dataSwiping()',
2030
+ '[attr.data-autosize]': 'dataAutosize()'
2031
+ }
2032
+ }]
2033
+ }], ctorParameters: () => [], propDecorators: { _compositionContent: [{ type: i0.ContentChildren, args: [i0.forwardRef(() => CarouselContent), { ...{ descendants: true }, isSignal: true }] }], align: [{ type: i0.Input, args: [{ isSignal: true, alias: "align", required: false }] }], loop: [{ type: i0.Input, args: [{ isSignal: true, alias: "loop", required: false }] }], snapType: [{ type: i0.Input, args: [{ isSignal: true, alias: "snapType", required: false }] }], spacing: [{ type: i0.Input, args: [{ isSignal: true, alias: "spacing", required: false }] }], autoSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "autoSize", required: false }] }], slidesPerPage: [{ type: i0.Input, args: [{ isSignal: true, alias: "slidesPerPage", required: false }] }], slide: [{ type: i0.Input, args: [{ isSignal: true, alias: "slide", required: false }] }], onPageChange: [{ type: i0.Output, args: ["onPageChange"] }], onSlideChange: [{ type: i0.Output, args: ["onSlideChange"] }] } });
2034
+ class CarouselModule {
2035
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2036
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "22.0.3", ngImport: i0, type: CarouselModule, imports: [Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrev, CarouselIndicators, CarouselIndicator, SharedModule], exports: [Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrev, CarouselIndicators, CarouselIndicator, SharedModule] });
2037
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselModule, imports: [Carousel, CarouselContent, CarouselItem, CarouselIndicators, SharedModule, SharedModule] });
2038
+ }
2039
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: CarouselModule, decorators: [{
2040
+ type: NgModule,
2041
+ args: [{
2042
+ imports: [Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrev, CarouselIndicators, CarouselIndicator, SharedModule],
2043
+ exports: [Carousel, CarouselContent, CarouselItem, CarouselNext, CarouselPrev, CarouselIndicators, CarouselIndicator, SharedModule]
2044
+ }]
2045
+ }] });
2046
+
2047
+ /**
2048
+ * Generated bundle index. Do not edit.
2049
+ */
2050
+
2051
+ export { Carousel, CarouselClasses, CarouselContent, CarouselIndicator, CarouselIndicators, CarouselItem, CarouselModule, CarouselNext, CarouselPrev, CarouselStyle };
2052
+ //# sourceMappingURL=primenglab-carousel.mjs.map