primevue 3.16.2 → 3.17.0

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 (797) hide show
  1. package/README.md +2 -1
  2. package/accordion/Accordion.d.ts +23 -5
  3. package/accordion/Accordion.vue +194 -77
  4. package/accordion/accordion.cjs.js +202 -96
  5. package/accordion/accordion.cjs.min.js +1 -1
  6. package/accordion/accordion.esm.js +200 -98
  7. package/accordion/accordion.esm.min.js +1 -1
  8. package/accordion/accordion.js +203 -98
  9. package/accordion/accordion.min.js +1 -1
  10. package/accordiontab/AccordionTab.d.ts +33 -5
  11. package/accordiontab/AccordionTab.vue +8 -1
  12. package/accordiontab/accordiontab.cjs.js +7 -0
  13. package/accordiontab/accordiontab.cjs.min.js +1 -1
  14. package/accordiontab/accordiontab.esm.js +7 -0
  15. package/accordiontab/accordiontab.esm.min.js +1 -1
  16. package/accordiontab/accordiontab.js +7 -0
  17. package/accordiontab/accordiontab.min.js +1 -1
  18. package/api/Api.d.ts +1 -1
  19. package/api/api.cjs.js +299 -313
  20. package/api/api.esm.js +299 -313
  21. package/api/api.js +299 -313
  22. package/autocomplete/AutoComplete.d.ts +22 -17
  23. package/autocomplete/AutoComplete.vue +239 -126
  24. package/autocomplete/autocomplete.cjs.js +145 -108
  25. package/autocomplete/autocomplete.cjs.min.js +1 -1
  26. package/autocomplete/autocomplete.esm.js +146 -109
  27. package/autocomplete/autocomplete.esm.min.js +1 -1
  28. package/autocomplete/autocomplete.js +145 -108
  29. package/autocomplete/autocomplete.min.js +1 -1
  30. package/avatar/Avatar.d.ts +4 -4
  31. package/avatar/Avatar.vue +15 -11
  32. package/avatar/avatar.cjs.js +11 -7
  33. package/avatar/avatar.cjs.min.js +1 -1
  34. package/avatar/avatar.esm.js +11 -7
  35. package/avatar/avatar.esm.min.js +1 -1
  36. package/avatar/avatar.js +11 -7
  37. package/avatar/avatar.min.js +1 -1
  38. package/avatargroup/AvatarGroup.d.ts +6 -9
  39. package/avatargroup/AvatarGroup.vue +1 -1
  40. package/badge/Badge.d.ts +4 -5
  41. package/badge/Badge.vue +16 -13
  42. package/badge/badge.cjs.js +14 -11
  43. package/badge/badge.esm.js +14 -11
  44. package/badge/badge.js +14 -11
  45. package/badgedirective/badgedirective.cjs.js +8 -10
  46. package/badgedirective/badgedirective.esm.js +8 -10
  47. package/badgedirective/badgedirective.js +8 -10
  48. package/blockui/BlockUI.d.ts +6 -6
  49. package/blockui/BlockUI.vue +13 -15
  50. package/blockui/blockui.cjs.js +11 -13
  51. package/blockui/blockui.cjs.min.js +1 -1
  52. package/blockui/blockui.esm.js +11 -13
  53. package/blockui/blockui.esm.min.js +1 -1
  54. package/blockui/blockui.js +11 -13
  55. package/blockui/blockui.min.js +1 -1
  56. package/breadcrumb/Breadcrumb.d.ts +5 -6
  57. package/breadcrumb/Breadcrumb.vue +2 -2
  58. package/breadcrumb/BreadcrumbItem.vue +18 -15
  59. package/breadcrumb/breadcrumb.cjs.js +15 -12
  60. package/breadcrumb/breadcrumb.esm.js +15 -12
  61. package/breadcrumb/breadcrumb.js +15 -12
  62. package/button/Button.d.ts +10 -7
  63. package/button/Button.vue +22 -14
  64. package/button/button.cjs.js +19 -11
  65. package/button/button.cjs.min.js +1 -1
  66. package/button/button.esm.js +19 -11
  67. package/button/button.esm.min.js +1 -1
  68. package/button/button.js +19 -11
  69. package/button/button.min.js +1 -1
  70. package/calendar/Calendar.d.ts +14 -14
  71. package/calendar/Calendar.vue +793 -583
  72. package/calendar/calendar.cjs.js +581 -526
  73. package/calendar/calendar.cjs.min.js +1 -1
  74. package/calendar/calendar.esm.js +581 -526
  75. package/calendar/calendar.esm.min.js +1 -1
  76. package/calendar/calendar.js +581 -526
  77. package/calendar/calendar.min.js +1 -1
  78. package/card/Card.d.ts +5 -7
  79. package/card/Card.vue +5 -5
  80. package/carousel/Carousel.d.ts +29 -19
  81. package/carousel/Carousel.vue +537 -528
  82. package/carousel/carousel.cjs.js +496 -493
  83. package/carousel/carousel.cjs.min.js +1 -1
  84. package/carousel/carousel.esm.js +496 -493
  85. package/carousel/carousel.esm.min.js +1 -1
  86. package/carousel/carousel.js +645 -642
  87. package/carousel/carousel.min.js +1 -1
  88. package/cascadeselect/CascadeSelect.d.ts +19 -14
  89. package/cascadeselect/CascadeSelect.vue +186 -100
  90. package/cascadeselect/CascadeSelectSub.vue +44 -14
  91. package/cascadeselect/cascadeselect.cjs.js +156 -95
  92. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  93. package/cascadeselect/cascadeselect.esm.js +157 -96
  94. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  95. package/cascadeselect/cascadeselect.js +156 -95
  96. package/cascadeselect/cascadeselect.min.js +1 -1
  97. package/chart/Chart.d.ts +6 -7
  98. package/chart/Chart.vue +12 -12
  99. package/chart/chart.cjs.js +11 -11
  100. package/chart/chart.cjs.min.js +1 -1
  101. package/chart/chart.esm.js +11 -11
  102. package/chart/chart.esm.min.js +1 -1
  103. package/chart/chart.js +11 -11
  104. package/chart/chart.min.js +1 -1
  105. package/checkbox/Checkbox.d.ts +12 -12
  106. package/checkbox/Checkbox.vue +48 -20
  107. package/checkbox/checkbox.cjs.js +28 -17
  108. package/checkbox/checkbox.cjs.min.js +1 -1
  109. package/checkbox/checkbox.esm.js +28 -17
  110. package/checkbox/checkbox.esm.min.js +1 -1
  111. package/checkbox/checkbox.js +28 -17
  112. package/checkbox/checkbox.min.js +1 -1
  113. package/chip/Chip.d.ts +5 -5
  114. package/chip/Chip.vue +13 -11
  115. package/chip/chip.cjs.js +7 -4
  116. package/chip/chip.esm.js +7 -4
  117. package/chip/chip.js +7 -4
  118. package/chips/Chips.d.ts +9 -9
  119. package/chips/Chips.vue +89 -33
  120. package/chips/chips.cjs.js +48 -26
  121. package/chips/chips.cjs.min.js +1 -1
  122. package/chips/chips.esm.js +48 -26
  123. package/chips/chips.esm.min.js +1 -1
  124. package/chips/chips.js +48 -26
  125. package/chips/chips.min.js +1 -1
  126. package/colorpicker/ColorPicker.d.ts +11 -12
  127. package/colorpicker/ColorPicker.vue +146 -110
  128. package/colorpicker/colorpicker.cjs.js +113 -74
  129. package/colorpicker/colorpicker.cjs.min.js +1 -1
  130. package/colorpicker/colorpicker.esm.js +113 -74
  131. package/colorpicker/colorpicker.esm.min.js +1 -1
  132. package/colorpicker/colorpicker.js +113 -74
  133. package/colorpicker/colorpicker.min.js +1 -1
  134. package/column/Column.d.ts +5 -6
  135. package/column/Column.vue +1 -1
  136. package/columngroup/ColumnGroup.d.ts +5 -7
  137. package/columngroup/ColumnGroup.vue +1 -1
  138. package/config/PrimeVue.d.ts +4 -2
  139. package/config/config.cjs.js +14 -29
  140. package/config/config.cjs.min.js +1 -1
  141. package/config/config.esm.js +14 -29
  142. package/config/config.esm.min.js +1 -1
  143. package/config/config.js +14 -29
  144. package/config/config.min.js +1 -1
  145. package/confirmationoptions/ConfirmationOptions.d.ts +4 -0
  146. package/confirmationservice/confirmationservice.cjs.js +1 -0
  147. package/confirmationservice/confirmationservice.esm.js +1 -0
  148. package/confirmationservice/confirmationservice.js +1 -0
  149. package/confirmdialog/ConfirmDialog.d.ts +11 -5
  150. package/confirmdialog/ConfirmDialog.vue +25 -15
  151. package/confirmdialog/confirmdialog.cjs.js +34 -16
  152. package/confirmdialog/confirmdialog.cjs.min.js +1 -1
  153. package/confirmdialog/confirmdialog.esm.js +34 -16
  154. package/confirmdialog/confirmdialog.esm.min.js +1 -1
  155. package/confirmdialog/confirmdialog.js +35 -17
  156. package/confirmdialog/confirmdialog.min.js +1 -1
  157. package/confirmpopup/ConfirmPopup.d.ts +5 -8
  158. package/confirmpopup/ConfirmPopup.vue +44 -32
  159. package/confirmpopup/confirmpopup.cjs.js +24 -14
  160. package/confirmpopup/confirmpopup.cjs.min.js +1 -1
  161. package/confirmpopup/confirmpopup.esm.js +24 -14
  162. package/confirmpopup/confirmpopup.esm.min.js +1 -1
  163. package/confirmpopup/confirmpopup.js +24 -14
  164. package/confirmpopup/confirmpopup.min.js +1 -1
  165. package/contextmenu/ContextMenu.d.ts +4 -5
  166. package/contextmenu/ContextMenu.vue +23 -19
  167. package/contextmenu/ContextMenuSub.vue +54 -42
  168. package/contextmenu/contextmenu.cjs.js +52 -44
  169. package/contextmenu/contextmenu.cjs.min.js +1 -1
  170. package/contextmenu/contextmenu.esm.js +52 -44
  171. package/contextmenu/contextmenu.esm.min.js +1 -1
  172. package/contextmenu/contextmenu.js +52 -44
  173. package/contextmenu/contextmenu.min.js +1 -1
  174. package/core/core.js +1918 -1744
  175. package/core/core.min.js +14 -14
  176. package/datatable/BodyCell.vue +93 -75
  177. package/datatable/ColumnFilter.vue +137 -86
  178. package/datatable/DataTable.d.ts +24 -24
  179. package/datatable/DataTable.vue +470 -296
  180. package/datatable/FooterCell.vue +20 -13
  181. package/datatable/HeaderCell.vue +108 -51
  182. package/datatable/HeaderCheckbox.vue +12 -5
  183. package/datatable/RowCheckbox.vue +14 -6
  184. package/datatable/RowRadioButton.vue +4 -4
  185. package/datatable/TableBody.vue +135 -83
  186. package/datatable/TableFooter.vue +17 -20
  187. package/datatable/TableHeader.vue +132 -52
  188. package/datatable/TableLoadingBody.vue +3 -3
  189. package/datatable/datatable.cjs.js +696 -559
  190. package/datatable/datatable.cjs.min.js +1 -1
  191. package/datatable/datatable.esm.js +696 -559
  192. package/datatable/datatable.esm.min.js +1 -1
  193. package/datatable/datatable.js +696 -559
  194. package/datatable/datatable.min.js +1 -1
  195. package/dataview/DataView.d.ts +8 -8
  196. package/dataview/DataView.vue +80 -66
  197. package/dataview/dataview.cjs.js +31 -35
  198. package/dataview/dataview.cjs.min.js +1 -1
  199. package/dataview/dataview.esm.js +31 -35
  200. package/dataview/dataview.esm.min.js +1 -1
  201. package/dataview/dataview.js +31 -35
  202. package/dataview/dataview.min.js +1 -1
  203. package/dataviewlayoutoptions/DataViewLayoutOptions.d.ts +5 -6
  204. package/dataviewlayoutoptions/DataViewLayoutOptions.vue +28 -34
  205. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.js +19 -25
  206. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.min.js +1 -1
  207. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.js +19 -25
  208. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.min.js +1 -1
  209. package/dataviewlayoutoptions/dataviewlayoutoptions.js +46 -52
  210. package/dataviewlayoutoptions/dataviewlayoutoptions.min.js +1 -1
  211. package/deferredcontent/DeferredContent.d.ts +6 -7
  212. package/deferredcontent/DeferredContent.vue +6 -9
  213. package/deferredcontent/deferredcontent.cjs.js +5 -8
  214. package/deferredcontent/deferredcontent.esm.js +5 -8
  215. package/deferredcontent/deferredcontent.js +5 -8
  216. package/dialog/Dialog.d.ts +10 -10
  217. package/dialog/Dialog.vue +64 -60
  218. package/dialog/dialog.cjs.js +50 -46
  219. package/dialog/dialog.cjs.min.js +1 -1
  220. package/dialog/dialog.esm.js +50 -46
  221. package/dialog/dialog.esm.min.js +1 -1
  222. package/dialog/dialog.js +50 -46
  223. package/dialog/dialog.min.js +1 -1
  224. package/divider/Divider.d.ts +4 -5
  225. package/divider/Divider.vue +15 -12
  226. package/divider/divider.cjs.js +17 -12
  227. package/divider/divider.cjs.min.js +1 -1
  228. package/divider/divider.esm.js +17 -12
  229. package/divider/divider.esm.min.js +1 -1
  230. package/divider/divider.js +17 -12
  231. package/divider/divider.min.js +1 -1
  232. package/dock/Dock.d.ts +5 -6
  233. package/dock/Dock.vue +3 -3
  234. package/dock/DockSub.vue +46 -25
  235. package/dock/dock.cjs.js +30 -23
  236. package/dock/dock.cjs.min.js +1 -1
  237. package/dock/dock.esm.js +30 -23
  238. package/dock/dock.esm.min.js +1 -1
  239. package/dock/dock.js +30 -23
  240. package/dock/dock.min.js +1 -1
  241. package/dropdown/Dropdown.d.ts +31 -17
  242. package/dropdown/Dropdown.vue +255 -125
  243. package/dropdown/dropdown.cjs.js +177 -109
  244. package/dropdown/dropdown.cjs.min.js +1 -1
  245. package/dropdown/dropdown.esm.js +178 -110
  246. package/dropdown/dropdown.esm.min.js +1 -1
  247. package/dropdown/dropdown.js +177 -109
  248. package/dropdown/dropdown.min.js +1 -1
  249. package/dynamicdialog/DynamicDialog.d.ts +4 -4
  250. package/dynamicdialog/DynamicDialog.vue +10 -10
  251. package/dynamicdialog/dynamicdialog.cjs.js +11 -9
  252. package/dynamicdialog/dynamicdialog.cjs.min.js +1 -1
  253. package/dynamicdialog/dynamicdialog.esm.js +11 -9
  254. package/dynamicdialog/dynamicdialog.esm.min.js +1 -1
  255. package/dynamicdialog/dynamicdialog.js +11 -9
  256. package/dynamicdialog/dynamicdialog.min.js +1 -1
  257. package/editor/Editor.d.ts +20 -4
  258. package/editor/Editor.vue +506 -466
  259. package/editor/editor.cjs.js +99 -45
  260. package/editor/editor.cjs.min.js +1 -1
  261. package/editor/editor.esm.js +82 -42
  262. package/editor/editor.esm.min.js +1 -1
  263. package/editor/editor.js +83 -47
  264. package/editor/editor.min.js +1 -1
  265. package/fieldset/Fieldset.d.ts +9 -5
  266. package/fieldset/Fieldset.vue +28 -20
  267. package/fieldset/fieldset.cjs.js +31 -19
  268. package/fieldset/fieldset.cjs.min.js +1 -1
  269. package/fieldset/fieldset.esm.js +32 -20
  270. package/fieldset/fieldset.esm.min.js +1 -1
  271. package/fieldset/fieldset.js +31 -19
  272. package/fieldset/fieldset.min.js +1 -1
  273. package/fileupload/FileUpload.d.ts +11 -11
  274. package/fileupload/FileUpload.vue +75 -69
  275. package/fileupload/fileupload.cjs.js +56 -50
  276. package/fileupload/fileupload.cjs.min.js +1 -1
  277. package/fileupload/fileupload.esm.js +56 -50
  278. package/fileupload/fileupload.esm.min.js +1 -1
  279. package/fileupload/fileupload.js +56 -50
  280. package/fileupload/fileupload.min.js +1 -1
  281. package/fullcalendar/FullCalendar.d.ts +5 -7
  282. package/fullcalendar/FullCalendar.vue +6 -6
  283. package/fullcalendar/fullcalendar.cjs.js +3 -2
  284. package/fullcalendar/fullcalendar.esm.js +3 -2
  285. package/fullcalendar/fullcalendar.js +3 -2
  286. package/galleria/Galleria.d.ts +4 -4
  287. package/galleria/Galleria.vue +39 -34
  288. package/galleria/GalleriaContent.vue +58 -31
  289. package/galleria/GalleriaItem.vue +44 -36
  290. package/galleria/GalleriaItemSlot.vue +2 -1
  291. package/galleria/GalleriaThumbnails.vue +107 -91
  292. package/galleria/galleria.cjs.js +180 -152
  293. package/galleria/galleria.cjs.min.js +1 -1
  294. package/galleria/galleria.esm.js +180 -152
  295. package/galleria/galleria.esm.min.js +1 -1
  296. package/galleria/galleria.js +180 -152
  297. package/galleria/galleria.min.js +1 -1
  298. package/image/Image.d.ts +4 -5
  299. package/image/Image.vue +19 -15
  300. package/image/image.cjs.js +11 -7
  301. package/image/image.cjs.min.js +1 -1
  302. package/image/image.esm.js +11 -7
  303. package/image/image.esm.min.js +1 -1
  304. package/image/image.js +11 -7
  305. package/image/image.min.js +1 -1
  306. package/inlinemessage/InlineMessage.d.ts +4 -5
  307. package/inlinemessage/InlineMessage.vue +12 -9
  308. package/inlinemessage/inlinemessage.cjs.js +11 -8
  309. package/inlinemessage/inlinemessage.esm.js +11 -8
  310. package/inlinemessage/inlinemessage.js +11 -8
  311. package/inplace/Inplace.d.ts +6 -6
  312. package/inplace/Inplace.vue +11 -11
  313. package/inplace/inplace.cjs.js +9 -9
  314. package/inplace/inplace.cjs.min.js +1 -1
  315. package/inplace/inplace.esm.js +9 -9
  316. package/inplace/inplace.esm.min.js +1 -1
  317. package/inplace/inplace.js +9 -9
  318. package/inplace/inplace.min.js +1 -1
  319. package/inputmask/InputMask.d.ts +11 -12
  320. package/inputmask/InputMask.vue +119 -92
  321. package/inputmask/inputmask.cjs.js +116 -89
  322. package/inputmask/inputmask.cjs.min.js +1 -1
  323. package/inputmask/inputmask.esm.js +116 -89
  324. package/inputmask/inputmask.esm.min.js +1 -1
  325. package/inputmask/inputmask.js +116 -89
  326. package/inputmask/inputmask.min.js +1 -1
  327. package/inputnumber/InputNumber.d.ts +17 -17
  328. package/inputnumber/InputNumber.vue +237 -177
  329. package/inputnumber/inputnumber.cjs.js +208 -171
  330. package/inputnumber/inputnumber.cjs.min.js +1 -1
  331. package/inputnumber/inputnumber.esm.js +208 -171
  332. package/inputnumber/inputnumber.esm.min.js +1 -1
  333. package/inputnumber/inputnumber.js +208 -171
  334. package/inputnumber/inputnumber.min.js +1 -1
  335. package/inputswitch/InputSwitch.d.ts +10 -10
  336. package/inputswitch/InputSwitch.vue +39 -11
  337. package/inputswitch/inputswitch.cjs.js +23 -9
  338. package/inputswitch/inputswitch.cjs.min.js +1 -1
  339. package/inputswitch/inputswitch.esm.js +23 -9
  340. package/inputswitch/inputswitch.esm.min.js +1 -1
  341. package/inputswitch/inputswitch.js +23 -9
  342. package/inputswitch/inputswitch.min.js +1 -1
  343. package/inputtext/InputText.d.ts +5 -6
  344. package/inputtext/InputText.vue +3 -3
  345. package/inputtext/inputtext.cjs.js +2 -2
  346. package/inputtext/inputtext.esm.js +2 -2
  347. package/inputtext/inputtext.js +2 -2
  348. package/knob/Knob.d.ts +10 -11
  349. package/knob/Knob.vue +47 -29
  350. package/knob/knob.cjs.js +27 -25
  351. package/knob/knob.cjs.min.js +1 -1
  352. package/knob/knob.esm.js +27 -25
  353. package/knob/knob.esm.min.js +1 -1
  354. package/knob/knob.js +27 -25
  355. package/knob/knob.min.js +1 -1
  356. package/listbox/Listbox.d.ts +17 -13
  357. package/listbox/Listbox.vue +144 -97
  358. package/listbox/listbox.cjs.js +96 -86
  359. package/listbox/listbox.cjs.min.js +1 -1
  360. package/listbox/listbox.esm.js +97 -87
  361. package/listbox/listbox.esm.min.js +1 -1
  362. package/listbox/listbox.js +96 -86
  363. package/listbox/listbox.min.js +1 -1
  364. package/megamenu/MegaMenu.d.ts +5 -6
  365. package/megamenu/MegaMenu.vue +108 -94
  366. package/megamenu/megamenu.cjs.js +77 -72
  367. package/megamenu/megamenu.cjs.min.js +1 -1
  368. package/megamenu/megamenu.esm.js +77 -72
  369. package/megamenu/megamenu.esm.min.js +1 -1
  370. package/megamenu/megamenu.js +77 -72
  371. package/megamenu/megamenu.min.js +1 -1
  372. package/menu/Menu.d.ts +5 -8
  373. package/menu/Menu.vue +29 -23
  374. package/menu/Menuitem.vue +21 -18
  375. package/menu/menu.cjs.js +38 -29
  376. package/menu/menu.cjs.min.js +1 -1
  377. package/menu/menu.esm.js +38 -29
  378. package/menu/menu.esm.min.js +1 -1
  379. package/menu/menu.js +38 -29
  380. package/menu/menu.min.js +1 -1
  381. package/menubar/Menubar.d.ts +5 -6
  382. package/menubar/Menubar.vue +14 -15
  383. package/menubar/MenubarSub.vue +79 -62
  384. package/menubar/menubar.cjs.js +56 -58
  385. package/menubar/menubar.cjs.min.js +1 -1
  386. package/menubar/menubar.esm.js +56 -58
  387. package/menubar/menubar.esm.min.js +1 -1
  388. package/menubar/menubar.js +56 -58
  389. package/menubar/menubar.min.js +1 -1
  390. package/menuitem/MenuItem.d.ts +2 -2
  391. package/message/Message.d.ts +5 -5
  392. package/message/Message.vue +19 -14
  393. package/message/message.cjs.js +15 -10
  394. package/message/message.cjs.min.js +1 -1
  395. package/message/message.esm.js +15 -10
  396. package/message/message.esm.min.js +1 -1
  397. package/message/message.js +15 -10
  398. package/message/message.min.js +1 -1
  399. package/multiselect/MultiSelect.d.ts +21 -16
  400. package/multiselect/MultiSelect.vue +240 -150
  401. package/multiselect/multiselect.cjs.js +184 -133
  402. package/multiselect/multiselect.cjs.min.js +1 -1
  403. package/multiselect/multiselect.esm.js +185 -134
  404. package/multiselect/multiselect.esm.min.js +1 -1
  405. package/multiselect/multiselect.js +184 -133
  406. package/multiselect/multiselect.min.js +1 -1
  407. package/orderlist/OrderList.d.ts +5 -5
  408. package/orderlist/OrderList.vue +65 -60
  409. package/orderlist/orderlist.cjs.js +51 -53
  410. package/orderlist/orderlist.esm.js +51 -53
  411. package/orderlist/orderlist.js +51 -53
  412. package/organizationchart/OrganizationChart.d.ts +4 -4
  413. package/organizationchart/OrganizationChart.vue +13 -17
  414. package/organizationchart/OrganizationChartNode.vue +20 -12
  415. package/organizationchart/organizationchart.cjs.js +14 -16
  416. package/organizationchart/organizationchart.cjs.min.js +1 -1
  417. package/organizationchart/organizationchart.esm.js +14 -16
  418. package/organizationchart/organizationchart.esm.min.js +1 -1
  419. package/organizationchart/organizationchart.js +14 -16
  420. package/organizationchart/organizationchart.min.js +1 -1
  421. package/overlaypanel/OverlayPanel.d.ts +5 -5
  422. package/overlaypanel/OverlayPanel.vue +60 -50
  423. package/overlaypanel/overlaypanel.cjs.js +40 -32
  424. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  425. package/overlaypanel/overlaypanel.esm.js +40 -32
  426. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  427. package/overlaypanel/overlaypanel.js +40 -32
  428. package/overlaypanel/overlaypanel.min.js +1 -1
  429. package/package.json +1 -1
  430. package/paginator/CurrentPageReport.vue +47 -47
  431. package/paginator/FirstPageLink.vue +11 -8
  432. package/paginator/JumpToPageDropdown.vue +7 -6
  433. package/paginator/JumpToPageInput.vue +3 -3
  434. package/paginator/LastPageLink.vue +11 -8
  435. package/paginator/NextPageLink.vue +11 -8
  436. package/paginator/PageLinks.vue +3 -4
  437. package/paginator/Paginator.d.ts +5 -5
  438. package/paginator/Paginator.vue +39 -39
  439. package/paginator/PrevPageLink.vue +11 -8
  440. package/paginator/RowsPerPageDropdown.vue +7 -6
  441. package/paginator/paginator.cjs.js +110 -91
  442. package/paginator/paginator.cjs.min.js +1 -1
  443. package/paginator/paginator.esm.js +110 -91
  444. package/paginator/paginator.esm.min.js +1 -1
  445. package/paginator/paginator.js +633 -614
  446. package/paginator/paginator.min.js +1 -1
  447. package/panel/Panel.d.ts +9 -5
  448. package/panel/Panel.vue +29 -11
  449. package/panel/panel.cjs.js +24 -14
  450. package/panel/panel.cjs.min.js +1 -1
  451. package/panel/panel.esm.js +24 -14
  452. package/panel/panel.esm.min.js +1 -1
  453. package/panel/panel.js +24 -14
  454. package/panel/panel.min.js +1 -1
  455. package/panelmenu/PanelMenu.d.ts +5 -5
  456. package/panelmenu/PanelMenu.vue +46 -38
  457. package/panelmenu/PanelMenuSub.vue +40 -29
  458. package/panelmenu/panelmenu.cjs.js +56 -52
  459. package/panelmenu/panelmenu.cjs.min.js +1 -1
  460. package/panelmenu/panelmenu.esm.js +56 -52
  461. package/panelmenu/panelmenu.esm.min.js +1 -1
  462. package/panelmenu/panelmenu.js +56 -52
  463. package/panelmenu/panelmenu.min.js +1 -1
  464. package/password/Password.d.ts +12 -7
  465. package/password/Password.vue +156 -79
  466. package/password/password.cjs.js +135 -74
  467. package/password/password.cjs.min.js +1 -1
  468. package/password/password.esm.js +135 -74
  469. package/password/password.esm.min.js +1 -1
  470. package/password/password.js +135 -74
  471. package/password/password.min.js +1 -1
  472. package/picklist/PickList.d.ts +9 -9
  473. package/picklist/PickList.vue +99 -78
  474. package/picklist/picklist.cjs.js +71 -66
  475. package/picklist/picklist.cjs.min.js +1 -1
  476. package/picklist/picklist.esm.js +71 -66
  477. package/picklist/picklist.esm.min.js +1 -1
  478. package/picklist/picklist.js +71 -66
  479. package/picklist/picklist.min.js +1 -1
  480. package/portal/Portal.d.ts +3 -3
  481. package/portal/Portal.vue +2 -2
  482. package/portal/portal.cjs.js +1 -1
  483. package/portal/portal.esm.js +1 -1
  484. package/portal/portal.js +1 -1
  485. package/progressbar/ProgressBar.d.ts +4 -5
  486. package/progressbar/ProgressBar.vue +63 -51
  487. package/progressbar/progressbar.cjs.js +2 -2
  488. package/progressbar/progressbar.cjs.min.js +1 -1
  489. package/progressbar/progressbar.esm.js +2 -2
  490. package/progressbar/progressbar.esm.min.js +1 -1
  491. package/progressbar/progressbar.js +2 -2
  492. package/progressbar/progressbar.min.js +1 -1
  493. package/progressspinner/ProgressSpinner.d.ts +5 -7
  494. package/progressspinner/ProgressSpinner.vue +1 -1
  495. package/radiobutton/RadioButton.d.ts +9 -9
  496. package/radiobutton/RadioButton.vue +41 -13
  497. package/radiobutton/radiobutton.cjs.js +24 -10
  498. package/radiobutton/radiobutton.cjs.min.js +1 -1
  499. package/radiobutton/radiobutton.esm.js +24 -10
  500. package/radiobutton/radiobutton.esm.min.js +1 -1
  501. package/radiobutton/radiobutton.js +24 -10
  502. package/radiobutton/radiobutton.min.js +1 -1
  503. package/rating/Rating.d.ts +54 -5
  504. package/rating/Rating.vue +88 -62
  505. package/rating/rating.cjs.js +105 -84
  506. package/rating/rating.cjs.min.js +1 -1
  507. package/rating/rating.esm.js +106 -85
  508. package/rating/rating.esm.min.js +1 -1
  509. package/rating/rating.js +106 -86
  510. package/rating/rating.min.js +1 -1
  511. package/resources/themes/arya-blue/theme.css +23 -12
  512. package/resources/themes/arya-green/theme.css +23 -12
  513. package/resources/themes/arya-orange/theme.css +23 -12
  514. package/resources/themes/arya-purple/theme.css +23 -12
  515. package/resources/themes/bootstrap4-dark-blue/theme.css +24 -13
  516. package/resources/themes/bootstrap4-dark-purple/theme.css +24 -13
  517. package/resources/themes/bootstrap4-light-blue/theme.css +24 -13
  518. package/resources/themes/bootstrap4-light-purple/theme.css +24 -13
  519. package/resources/themes/fluent-light/theme.css +23 -12
  520. package/resources/themes/lara-dark-blue/theme.css +23 -12
  521. package/resources/themes/lara-dark-indigo/theme.css +23 -12
  522. package/resources/themes/lara-dark-purple/theme.css +23 -12
  523. package/resources/themes/lara-dark-teal/theme.css +23 -12
  524. package/resources/themes/lara-light-blue/theme.css +23 -12
  525. package/resources/themes/lara-light-indigo/theme.css +23 -12
  526. package/resources/themes/lara-light-purple/theme.css +23 -12
  527. package/resources/themes/lara-light-teal/theme.css +23 -12
  528. package/resources/themes/luna-amber/theme.css +24 -13
  529. package/resources/themes/luna-blue/theme.css +24 -13
  530. package/resources/themes/luna-green/theme.css +24 -13
  531. package/resources/themes/luna-pink/theme.css +24 -13
  532. package/resources/themes/md-dark-deeppurple/theme.css +46 -20
  533. package/resources/themes/md-dark-indigo/theme.css +46 -20
  534. package/resources/themes/md-light-deeppurple/theme.css +46 -20
  535. package/resources/themes/md-light-indigo/theme.css +46 -20
  536. package/resources/themes/mdc-dark-deeppurple/theme.css +46 -20
  537. package/resources/themes/mdc-dark-indigo/theme.css +46 -20
  538. package/resources/themes/mdc-light-deeppurple/theme.css +46 -20
  539. package/resources/themes/mdc-light-indigo/theme.css +46 -20
  540. package/resources/themes/nova/theme.css +24 -13
  541. package/resources/themes/nova-accent/theme.css +23 -12
  542. package/resources/themes/nova-alt/theme.css +24 -13
  543. package/resources/themes/nova-vue/theme.css +24 -13
  544. package/resources/themes/rhea/theme.css +23 -12
  545. package/resources/themes/saga-blue/theme.css +23 -12
  546. package/resources/themes/saga-green/theme.css +23 -12
  547. package/resources/themes/saga-orange/theme.css +23 -12
  548. package/resources/themes/saga-purple/theme.css +23 -12
  549. package/resources/themes/tailwind-light/theme.css +23 -12
  550. package/resources/themes/vela-blue/theme.css +23 -12
  551. package/resources/themes/vela-green/theme.css +23 -12
  552. package/resources/themes/vela-orange/theme.css +23 -12
  553. package/resources/themes/vela-purple/theme.css +23 -12
  554. package/ripple/ripple.cjs.js +7 -1
  555. package/ripple/ripple.esm.js +7 -1
  556. package/ripple/ripple.js +7 -1
  557. package/row/Row.d.ts +6 -9
  558. package/row/Row.vue +1 -1
  559. package/scrollpanel/ScrollPanel.d.ts +9 -5
  560. package/scrollpanel/ScrollPanel.vue +194 -56
  561. package/scrollpanel/scrollpanel.cjs.js +180 -56
  562. package/scrollpanel/scrollpanel.cjs.min.js +1 -1
  563. package/scrollpanel/scrollpanel.esm.js +181 -57
  564. package/scrollpanel/scrollpanel.esm.min.js +1 -1
  565. package/scrollpanel/scrollpanel.js +180 -56
  566. package/scrollpanel/scrollpanel.min.js +1 -1
  567. package/scrolltop/ScrollTop.d.ts +5 -7
  568. package/scrolltop/ScrollTop.vue +18 -23
  569. package/scrolltop/scrolltop.cjs.js +14 -19
  570. package/scrolltop/scrolltop.cjs.min.js +1 -1
  571. package/scrolltop/scrolltop.esm.js +14 -19
  572. package/scrolltop/scrolltop.esm.min.js +1 -1
  573. package/scrolltop/scrolltop.js +14 -19
  574. package/scrolltop/scrolltop.min.js +1 -1
  575. package/selectbutton/SelectButton.d.ts +11 -11
  576. package/selectbutton/SelectButton.vue +50 -32
  577. package/selectbutton/selectbutton.cjs.js +30 -25
  578. package/selectbutton/selectbutton.esm.js +30 -25
  579. package/selectbutton/selectbutton.js +30 -25
  580. package/sidebar/Sidebar.d.ts +6 -6
  581. package/sidebar/Sidebar.vue +24 -14
  582. package/sidebar/sidebar.cjs.js +20 -10
  583. package/sidebar/sidebar.cjs.min.js +1 -1
  584. package/sidebar/sidebar.esm.js +20 -10
  585. package/sidebar/sidebar.esm.min.js +1 -1
  586. package/sidebar/sidebar.js +20 -10
  587. package/sidebar/sidebar.min.js +1 -1
  588. package/skeleton/Skeleton.d.ts +5 -7
  589. package/skeleton/Skeleton.vue +12 -11
  590. package/skeleton/skeleton.cjs.js +10 -9
  591. package/skeleton/skeleton.cjs.min.js +1 -1
  592. package/skeleton/skeleton.esm.js +10 -9
  593. package/skeleton/skeleton.esm.min.js +1 -1
  594. package/skeleton/skeleton.js +10 -9
  595. package/skeleton/skeleton.min.js +1 -1
  596. package/slider/Slider.d.ts +7 -8
  597. package/slider/Slider.vue +162 -141
  598. package/slider/slider.cjs.js +100 -127
  599. package/slider/slider.cjs.min.js +1 -1
  600. package/slider/slider.esm.js +100 -127
  601. package/slider/slider.esm.min.js +1 -1
  602. package/slider/slider.js +100 -127
  603. package/slider/slider.min.js +1 -1
  604. package/speeddial/SpeedDial.d.ts +8 -8
  605. package/speeddial/SpeedDial.vue +54 -39
  606. package/speeddial/speeddial.cjs.js +44 -36
  607. package/speeddial/speeddial.esm.js +44 -36
  608. package/speeddial/speeddial.js +44 -36
  609. package/splitbutton/SplitButton.d.ts +6 -6
  610. package/splitbutton/SplitButton.vue +9 -11
  611. package/splitbutton/splitbutton.cjs.js +7 -7
  612. package/splitbutton/splitbutton.cjs.min.js +1 -1
  613. package/splitbutton/splitbutton.esm.js +7 -7
  614. package/splitbutton/splitbutton.esm.min.js +1 -1
  615. package/splitbutton/splitbutton.js +7 -7
  616. package/splitbutton/splitbutton.min.js +1 -1
  617. package/splitter/Splitter.d.ts +10 -5
  618. package/splitter/Splitter.vue +158 -53
  619. package/splitter/splitter.cjs.js +156 -52
  620. package/splitter/splitter.cjs.min.js +1 -1
  621. package/splitter/splitter.esm.js +157 -53
  622. package/splitter/splitter.esm.min.js +1 -1
  623. package/splitter/splitter.js +156 -52
  624. package/splitter/splitter.min.js +1 -1
  625. package/splitterpanel/SplitterPanel.d.ts +4 -5
  626. package/splitterpanel/SplitterPanel.vue +3 -3
  627. package/splitterpanel/splitterpanel.cjs.js +2 -2
  628. package/splitterpanel/splitterpanel.esm.js +2 -2
  629. package/splitterpanel/splitterpanel.js +2 -2
  630. package/steps/Steps.d.ts +4 -5
  631. package/steps/Steps.vue +31 -23
  632. package/steps/steps.cjs.js +24 -16
  633. package/steps/steps.esm.js +24 -16
  634. package/steps/steps.js +24 -16
  635. package/styleclass/styleclass.cjs.js +19 -21
  636. package/styleclass/styleclass.esm.js +19 -21
  637. package/styleclass/styleclass.js +19 -21
  638. package/tabmenu/TabMenu.d.ts +4 -4
  639. package/tabmenu/TabMenu.vue +45 -34
  640. package/tabmenu/tabmenu.cjs.js +36 -25
  641. package/tabmenu/tabmenu.cjs.min.js +1 -1
  642. package/tabmenu/tabmenu.esm.js +36 -25
  643. package/tabmenu/tabmenu.esm.min.js +1 -1
  644. package/tabmenu/tabmenu.js +36 -25
  645. package/tabmenu/tabmenu.min.js +1 -1
  646. package/tabpanel/TabPanel.d.ts +33 -6
  647. package/tabpanel/TabPanel.vue +8 -1
  648. package/tabpanel/tabpanel.cjs.js +7 -0
  649. package/tabpanel/tabpanel.cjs.min.js +1 -1
  650. package/tabpanel/tabpanel.esm.js +7 -0
  651. package/tabpanel/tabpanel.esm.min.js +1 -1
  652. package/tabpanel/tabpanel.js +7 -0
  653. package/tabpanel/tabpanel.min.js +1 -1
  654. package/tabview/TabView.d.ts +22 -6
  655. package/tabview/TabView.vue +280 -96
  656. package/tabview/tabview.cjs.js +294 -131
  657. package/tabview/tabview.cjs.min.js +1 -1
  658. package/tabview/tabview.esm.js +296 -133
  659. package/tabview/tabview.esm.min.js +1 -1
  660. package/tabview/tabview.js +294 -131
  661. package/tabview/tabview.min.js +1 -1
  662. package/tag/Tag.d.ts +4 -5
  663. package/tag/Tag.vue +13 -10
  664. package/tag/tag.cjs.js +10 -7
  665. package/tag/tag.esm.js +10 -7
  666. package/tag/tag.js +10 -7
  667. package/terminal/Terminal.d.ts +5 -7
  668. package/terminal/Terminal.vue +10 -10
  669. package/terminal/terminal.cjs.js +3 -3
  670. package/terminal/terminal.cjs.min.js +1 -1
  671. package/terminal/terminal.esm.js +3 -3
  672. package/terminal/terminal.esm.min.js +1 -1
  673. package/terminal/terminal.js +3 -3
  674. package/terminal/terminal.min.js +1 -1
  675. package/textarea/Textarea.d.ts +5 -6
  676. package/textarea/Textarea.vue +7 -7
  677. package/textarea/textarea.cjs.js +6 -6
  678. package/textarea/textarea.esm.js +6 -6
  679. package/textarea/textarea.js +6 -6
  680. package/tieredmenu/TieredMenu.d.ts +4 -5
  681. package/tieredmenu/TieredMenu.vue +23 -15
  682. package/tieredmenu/TieredMenuSub.vue +62 -51
  683. package/tieredmenu/tieredmenu.cjs.js +60 -50
  684. package/tieredmenu/tieredmenu.cjs.min.js +1 -1
  685. package/tieredmenu/tieredmenu.esm.js +60 -50
  686. package/tieredmenu/tieredmenu.esm.min.js +1 -1
  687. package/tieredmenu/tieredmenu.js +60 -50
  688. package/tieredmenu/tieredmenu.min.js +1 -1
  689. package/timeline/Timeline.d.ts +4 -5
  690. package/timeline/Timeline.vue +6 -10
  691. package/timeline/timeline.cjs.js +3 -7
  692. package/timeline/timeline.cjs.min.js +1 -1
  693. package/timeline/timeline.esm.js +3 -7
  694. package/timeline/timeline.esm.min.js +1 -1
  695. package/timeline/timeline.js +3 -7
  696. package/timeline/timeline.min.js +1 -1
  697. package/toast/Toast.d.ts +10 -13
  698. package/toast/Toast.vue +36 -29
  699. package/toast/ToastMessage.vue +25 -18
  700. package/toast/toast.cjs.js +37 -23
  701. package/toast/toast.cjs.min.js +1 -1
  702. package/toast/toast.esm.js +37 -23
  703. package/toast/toast.esm.min.js +1 -1
  704. package/toast/toast.js +37 -23
  705. package/toast/toast.min.js +1 -1
  706. package/toastservice/toastservice.cjs.js +1 -0
  707. package/toastservice/toastservice.esm.js +1 -0
  708. package/toastservice/toastservice.js +1 -0
  709. package/togglebutton/ToggleButton.d.ts +10 -10
  710. package/togglebutton/ToggleButton.vue +42 -18
  711. package/togglebutton/togglebutton.cjs.js +25 -13
  712. package/togglebutton/togglebutton.cjs.min.js +1 -1
  713. package/togglebutton/togglebutton.esm.js +25 -13
  714. package/togglebutton/togglebutton.esm.min.js +1 -1
  715. package/togglebutton/togglebutton.js +25 -13
  716. package/togglebutton/togglebutton.min.js +1 -1
  717. package/toolbar/Toolbar.d.ts +8 -5
  718. package/toolbar/Toolbar.vue +9 -3
  719. package/toolbar/toolbar.cjs.js +14 -7
  720. package/toolbar/toolbar.cjs.min.js +1 -1
  721. package/toolbar/toolbar.esm.js +14 -7
  722. package/toolbar/toolbar.esm.min.js +1 -1
  723. package/toolbar/toolbar.js +14 -7
  724. package/toolbar/toolbar.min.js +1 -1
  725. package/tooltip/tooltip.cjs.js +36 -24
  726. package/tooltip/tooltip.cjs.min.js +1 -1
  727. package/tooltip/tooltip.esm.js +37 -25
  728. package/tooltip/tooltip.esm.min.js +1 -1
  729. package/tooltip/tooltip.js +36 -24
  730. package/tooltip/tooltip.min.js +1 -1
  731. package/tree/Tree.d.ts +7 -7
  732. package/tree/Tree.vue +66 -56
  733. package/tree/TreeNode.vue +70 -66
  734. package/tree/tree.cjs.js +99 -102
  735. package/tree/tree.cjs.min.js +1 -1
  736. package/tree/tree.esm.js +99 -102
  737. package/tree/tree.esm.min.js +1 -1
  738. package/tree/tree.js +99 -102
  739. package/tree/tree.min.js +1 -1
  740. package/treeselect/TreeSelect.d.ts +9 -9
  741. package/treeselect/TreeSelect.vue +130 -72
  742. package/treeselect/treeselect.cjs.js +89 -59
  743. package/treeselect/treeselect.cjs.min.js +1 -1
  744. package/treeselect/treeselect.esm.js +89 -59
  745. package/treeselect/treeselect.esm.min.js +1 -1
  746. package/treeselect/treeselect.js +89 -59
  747. package/treeselect/treeselect.min.js +1 -1
  748. package/treetable/BodyCell.vue +29 -19
  749. package/treetable/FooterCell.vue +19 -11
  750. package/treetable/HeaderCell.vue +44 -36
  751. package/treetable/TreeTable.d.ts +8 -8
  752. package/treetable/TreeTable.vue +229 -178
  753. package/treetable/TreeTableRow.vue +74 -58
  754. package/treetable/treetable.cjs.js +287 -253
  755. package/treetable/treetable.cjs.min.js +1 -1
  756. package/treetable/treetable.esm.js +287 -253
  757. package/treetable/treetable.esm.min.js +1 -1
  758. package/treetable/treetable.js +287 -253
  759. package/treetable/treetable.min.js +1 -1
  760. package/tristatecheckbox/TriStateCheckbox.d.ts +9 -9
  761. package/tristatecheckbox/TriStateCheckbox.vue +39 -18
  762. package/tristatecheckbox/tristatecheckbox.cjs.js +24 -15
  763. package/tristatecheckbox/tristatecheckbox.cjs.min.js +1 -1
  764. package/tristatecheckbox/tristatecheckbox.esm.js +24 -15
  765. package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
  766. package/tristatecheckbox/tristatecheckbox.js +24 -15
  767. package/tristatecheckbox/tristatecheckbox.min.js +1 -1
  768. package/ts-helpers.d.ts +16 -10
  769. package/useconfirm/UseConfirm.d.ts +1 -1
  770. package/useconfirm/useconfirm.cjs.js +2 -1
  771. package/useconfirm/useconfirm.esm.js +2 -1
  772. package/useconfirm/useconfirm.js +2 -1
  773. package/usedialog/UseDialog.d.ts +1 -1
  774. package/usedialog/usedialog.cjs.js +2 -1
  775. package/usedialog/usedialog.esm.js +2 -1
  776. package/usedialog/usedialog.js +2 -1
  777. package/usetoast/usetoast.cjs.js +2 -1
  778. package/usetoast/usetoast.esm.js +2 -1
  779. package/usetoast/usetoast.js +2 -1
  780. package/utils/Utils.d.ts +7 -5
  781. package/utils/utils.cjs.js +183 -156
  782. package/utils/utils.cjs.min.js +1 -1
  783. package/utils/utils.esm.js +183 -156
  784. package/utils/utils.esm.min.js +1 -1
  785. package/utils/utils.js +183 -156
  786. package/utils/utils.min.js +1 -1
  787. package/vetur-attributes.json +160 -0
  788. package/vetur-tags.json +58 -8
  789. package/virtualscroller/VirtualScroller.d.ts +9 -9
  790. package/virtualscroller/VirtualScroller.vue +108 -96
  791. package/virtualscroller/virtualscroller.cjs.js +87 -89
  792. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  793. package/virtualscroller/virtualscroller.esm.js +87 -89
  794. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  795. package/virtualscroller/virtualscroller.js +87 -89
  796. package/virtualscroller/virtualscroller.min.js +1 -1
  797. package/web-types.json +488 -2
@@ -1,547 +1,556 @@
1
1
  <template>
2
- <div :id="id" :class="['p-carousel p-component', {'p-carousel-vertical': isVertical(), 'p-carousel-horizontal': !isVertical()}]">
3
- <div class="p-carousel-header" v-if="$slots.header">
4
- <slot name="header"></slot>
5
- </div>
6
- <div :class="contentClasses">
7
- <div :class="containerClasses">
8
- <button :class="['p-carousel-prev p-link', {'p-disabled': backwardIsDisabled}]" :disabled="backwardIsDisabled" @click="navBackward" type="button" v-ripple>
9
- <span :class="['p-carousel-prev-icon pi', {'pi-chevron-left': !isVertical(),'pi-chevron-up': isVertical()}]"></span>
10
- </button>
11
-
12
- <div class="p-carousel-items-content" :style="[{'height': isVertical() ? verticalViewPortHeight : 'auto'}]" @touchend="onTouchEnd" @touchstart="onTouchStart" @touchmove="onTouchMove">
13
- <div ref="itemsContainer" class="p-carousel-items-container" @transitionend="onTransitionEnd">
14
- <template v-if="isCircular()">
15
- <div v-for="(item, index) of value.slice(-1 * d_numVisible)" :key="index + '_scloned'" :class="['p-carousel-item p-carousel-item-cloned',
16
- {'p-carousel-item-active': (totalShiftedItems * -1) === (value.length + d_numVisible),
17
- 'p-carousel-item-start': 0 === index,
18
- 'p-carousel-item-end': value.slice(-1 * d_numVisible).length - 1 === index}]">
19
- <slot name="item" :data="item" :index="index"></slot>
20
- </div>
21
- </template>
22
- <div v-for="(item, index) of value" :key="index" :class="['p-carousel-item',
23
- {'p-carousel-item-active': firstIndex() <= index && lastIndex() >= index,
24
- 'p-carousel-item-start': firstIndex() === index,
25
- 'p-carousel-item-end': lastIndex() === index}]">
26
- <slot name="item" :data="item" :index="index"></slot>
27
- </div>
28
- <template v-if="isCircular()">
29
- <div v-for="(item, index) of value.slice(0, d_numVisible)" :key="index + '_fcloned'" :class="['p-carousel-item p-carousel-item-cloned',
30
- {'p-carousel-item-active': totalShiftedItems === 0,
31
- 'p-carousel-item-start': 0 === index,
32
- 'p-carousel-item-end': value.slice(0, d_numVisible).length - 1 === index}]">
33
- <slot name="item" :data="item" :index="index"></slot>
34
- </div>
35
- </template>
36
- </div>
37
- </div>
38
-
39
- <button :class="['p-carousel-next p-link', {'p-disabled': forwardIsDisabled}]" :disabled="forwardIsDisabled" @click="navForward" type="button" v-ripple>
40
- <span :class="['p-carousel-prev-icon pi', {'pi-chevron-right': !isVertical(),'pi-chevron-down': isVertical()}]"></span>
41
- </button>
42
- </div>
43
- <ul v-if="totalIndicators >= 0" :class="indicatorsContentClasses">
44
- <li v-for="(indicator, i) of totalIndicators" :key="'p-carousel-indicator-' + i.toString()" :class="['p-carousel-indicator', {'p-highlight': d_page === i}]">
45
- <button class="p-link" @click="onIndicatorClick($event, i)" type="button" />
46
- </li>
47
- </ul>
48
- </div>
49
- <div class="p-carousel-footer" v-if="$slots.footer">
50
- <slot name="footer"></slot>
51
- </div>
52
- </div>
2
+ <div :id="id" :class="['p-carousel p-component', { 'p-carousel-vertical': isVertical(), 'p-carousel-horizontal': !isVertical() }]">
3
+ <div v-if="$slots.header" class="p-carousel-header">
4
+ <slot name="header"></slot>
5
+ </div>
6
+ <div :class="contentClasses">
7
+ <div :class="containerClasses">
8
+ <button v-if="showNavigators" v-ripple :class="['p-carousel-prev p-link', { 'p-disabled': backwardIsDisabled }]" :disabled="backwardIsDisabled" @click="navBackward" type="button">
9
+ <span :class="['p-carousel-prev-icon pi', { 'pi-chevron-left': !isVertical(), 'pi-chevron-up': isVertical() }]"></span>
10
+ </button>
11
+
12
+ <div class="p-carousel-items-content" :style="[{ height: isVertical() ? verticalViewPortHeight : 'auto' }]" @touchend="onTouchEnd" @touchstart="onTouchStart" @touchmove="onTouchMove">
13
+ <div ref="itemsContainer" class="p-carousel-items-container" @transitionend="onTransitionEnd">
14
+ <template v-if="isCircular()">
15
+ <div
16
+ v-for="(item, index) of value.slice(-1 * d_numVisible)"
17
+ :key="index + '_scloned'"
18
+ :class="[
19
+ 'p-carousel-item p-carousel-item-cloned',
20
+ { 'p-carousel-item-active': totalShiftedItems * -1 === value.length + d_numVisible, 'p-carousel-item-start': 0 === index, 'p-carousel-item-end': value.slice(-1 * d_numVisible).length - 1 === index }
21
+ ]"
22
+ >
23
+ <slot name="item" :data="item" :index="index"></slot>
24
+ </div>
25
+ </template>
26
+ <div
27
+ v-for="(item, index) of value"
28
+ :key="index"
29
+ :class="['p-carousel-item', { 'p-carousel-item-active': firstIndex() <= index && lastIndex() >= index, 'p-carousel-item-start': firstIndex() === index, 'p-carousel-item-end': lastIndex() === index }]"
30
+ >
31
+ <slot name="item" :data="item" :index="index"></slot>
32
+ </div>
33
+ <template v-if="isCircular()">
34
+ <div
35
+ v-for="(item, index) of value.slice(0, d_numVisible)"
36
+ :key="index + '_fcloned'"
37
+ :class="['p-carousel-item p-carousel-item-cloned', { 'p-carousel-item-active': totalShiftedItems === 0, 'p-carousel-item-start': 0 === index, 'p-carousel-item-end': value.slice(0, d_numVisible).length - 1 === index }]"
38
+ >
39
+ <slot name="item" :data="item" :index="index"></slot>
40
+ </div>
41
+ </template>
42
+ </div>
43
+ </div>
44
+
45
+ <button v-if="showNavigators" v-ripple :class="['p-carousel-next p-link', { 'p-disabled': forwardIsDisabled }]" :disabled="forwardIsDisabled" @click="navForward" type="button">
46
+ <span :class="['p-carousel-prev-icon pi', { 'pi-chevron-right': !isVertical(), 'pi-chevron-down': isVertical() }]"></span>
47
+ </button>
48
+ </div>
49
+ <ul v-if="totalIndicators >= 0 && showIndicators" :class="indicatorsContentClasses">
50
+ <li v-for="(indicator, i) of totalIndicators" :key="'p-carousel-indicator-' + i.toString()" :class="['p-carousel-indicator', { 'p-highlight': d_page === i }]">
51
+ <button class="p-link" @click="onIndicatorClick($event, i)" type="button" />
52
+ </li>
53
+ </ul>
54
+ </div>
55
+ <div v-if="$slots.footer" class="p-carousel-footer">
56
+ <slot name="footer"></slot>
57
+ </div>
58
+ </div>
53
59
  </template>
54
60
 
55
61
  <script>
56
- import {UniqueComponentId} from 'primevue/utils';
57
- import {DomHandler} from 'primevue/utils';
62
+ import { UniqueComponentId } from 'primevue/utils';
63
+ import { DomHandler } from 'primevue/utils';
58
64
  import Ripple from 'primevue/ripple';
59
65
 
60
66
  export default {
61
67
  name: 'Carousel',
62
- emits: ['update:page'],
63
- props: {
64
- value: null,
65
- page: {
66
- type: Number,
67
- default: 0
68
- },
69
- numVisible: {
70
- type: Number,
71
- default: 1
72
- },
73
- numScroll: {
74
- type: Number,
75
- default: 1
76
- },
77
- responsiveOptions: Array,
78
- orientation: {
79
- type: String,
80
- default: 'horizontal'
81
- },
82
- verticalViewPortHeight: {
83
- type: String,
84
- default: '300px'
85
- },
86
- contentClass: String,
87
- containerClass: String,
88
- indicatorsContentClass: String,
89
- circular: {
90
- type: Boolean,
91
- default: false
92
- },
93
- autoplayInterval: {
94
- type: Number,
95
- default:0
96
- }
97
- },
98
- data() {
99
- return {
100
- id : UniqueComponentId(),
101
- remainingItems: 0,
102
- d_numVisible: this.numVisible,
103
- d_numScroll: this.numScroll,
104
- d_oldNumScroll: 0,
105
- d_oldNumVisible: 0,
106
- d_oldValue: null,
107
- d_page: this.page,
108
- totalShiftedItems: this.page * this.numScroll * -1,
109
- allowAutoplay : !!this.autoplayInterval,
110
- d_circular : this.circular || this.allowAutoplay,
111
- swipeThreshold: 20
112
- }
113
- },
114
- isRemainingItemsAdded: false,
115
- watch: {
116
- page(newValue) {
117
- this.d_page = newValue;
118
- },
119
- circular(newValue) {
120
- this.d_circular = newValue;
121
- },
122
- numVisible(newValue, oldValue) {
123
- this.d_numVisible = newValue;
124
- this.d_oldNumVisible = oldValue;
125
- },
126
- numScroll(newValue, oldValue) {
127
- this.d_oldNumScroll = oldValue;
128
- this.d_numScroll = newValue;
129
- },
130
- value(oldValue) {
131
- this.d_oldValue =oldValue;
132
- }
133
- },
134
- methods: {
135
- step(dir, page) {
136
- let totalShiftedItems = this.totalShiftedItems;
137
- const isCircular = this.isCircular();
138
-
139
- if (page != null) {
140
- totalShiftedItems = (this.d_numScroll * page) * -1;
141
-
142
- if (isCircular) {
143
- totalShiftedItems -= this.d_numVisible;
144
- }
145
-
146
- this.isRemainingItemsAdded = false;
147
- }
148
- else {
149
- totalShiftedItems += (this.d_numScroll * dir);
150
- if (this.isRemainingItemsAdded) {
151
- totalShiftedItems += this.remainingItems - (this.d_numScroll * dir);
152
- this.isRemainingItemsAdded = false;
153
- }
154
-
155
- let originalShiftedItems = isCircular ? (totalShiftedItems + this.d_numVisible) : totalShiftedItems;
156
- page = Math.abs(Math.floor(originalShiftedItems / this.d_numScroll));
157
- }
158
-
159
- if (isCircular && this.d_page === (this.totalIndicators - 1) && dir === -1) {
160
- totalShiftedItems = -1 * (this.value.length + this.d_numVisible);
161
- page = 0;
162
- }
163
- else if (isCircular && this.d_page === 0 && dir === 1) {
164
- totalShiftedItems = 0;
165
- page = (this.totalIndicators - 1);
166
- }
167
- else if (page === (this.totalIndicators - 1) && this.remainingItems > 0) {
168
- totalShiftedItems += ((this.remainingItems * -1) - (this.d_numScroll * dir));
169
- this.isRemainingItemsAdded = true;
170
- }
171
-
172
- if (this.$refs.itemsContainer) {
173
- DomHandler.removeClass(this.$refs.itemsContainer, 'p-items-hidden');
174
- this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100/ this.d_numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100/ this.d_numVisible)}%, 0, 0)`;
175
- this.$refs.itemsContainer.style.transition = 'transform 500ms ease 0s';
176
- }
177
-
178
- this.totalShiftedItems = totalShiftedItems;
179
-
180
- this.$emit('update:page', page);
181
- this.d_page = page;
182
- },
183
- calculatePosition() {
184
- if (this.$refs.itemsContainer && this.responsiveOptions) {
185
- let windowWidth = window.innerWidth;
186
- let matchedResponsiveOptionsData = {
187
- numVisible: this.numVisible,
188
- numScroll: this.numScroll
189
- };
190
-
191
- for (let i = 0; i < this.responsiveOptions.length; i++) {
192
- let res = this.responsiveOptions[i];
193
-
194
- if (parseInt(res.breakpoint, 10) >= windowWidth) {
195
- matchedResponsiveOptionsData = res;
196
- }
197
- }
198
-
199
- if (this.d_numScroll !== matchedResponsiveOptionsData.numScroll) {
200
- let page = this.d_page;
201
- page = parseInt((page * this.d_numScroll) / matchedResponsiveOptionsData.numScroll);
202
-
203
- this.totalShiftedItems = (matchedResponsiveOptionsData.numScroll * page) * -1;
204
-
205
- if (this.isCircular()) {
206
- this.totalShiftedItems -= matchedResponsiveOptionsData.numVisible;
207
- }
208
-
209
- this.d_numScroll = matchedResponsiveOptionsData.numScroll;
210
-
211
- this.$emit('update:page', page);
212
- this.d_page = page;
213
- }
214
-
215
- if (this.d_numVisible !== matchedResponsiveOptionsData.numVisible) {
216
- this.d_numVisible = matchedResponsiveOptionsData.numVisible;
217
- }
218
- }
219
- },
220
- navBackward(e,index){
221
- if (this.d_circular || this.d_page !== 0) {
222
- this.step(1, index);
223
- }
224
-
225
- this.allowAutoplay = false;
226
-
227
- if (e.cancelable) {
228
- e.preventDefault();
229
- }
230
- },
231
- navForward(e,index){
232
- if (this.d_circular || this.d_page < (this.totalIndicators - 1)) {
233
- this.step(-1, index);
234
- }
235
-
236
- this.allowAutoplay = false;
237
-
238
- if (e.cancelable) {
239
- e.preventDefault();
240
- }
241
- },
242
- onIndicatorClick(e, index) {
243
- let page = this.d_page;
244
-
245
- if (index > page) {
246
- this.navForward(e, index);
247
- }
248
- else if (index < page) {
249
- this.navBackward(e, index);
250
- }
251
- },
252
- onTransitionEnd() {
253
- if (this.$refs.itemsContainer) {
254
- DomHandler.addClass(this.$refs.itemsContainer, 'p-items-hidden');
255
- this.$refs.itemsContainer.style.transition = '';
256
-
257
- if ((this.d_page === 0 || this.d_page === (this.totalIndicators - 1)) && this.isCircular()) {
258
- this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${this.totalShiftedItems * (100/ this.d_numVisible)}%, 0)` : `translate3d(${this.totalShiftedItems * (100/ this.d_numVisible)}%, 0, 0)`;
259
- }
260
- }
261
- },
262
- onTouchStart(e) {
263
- let touchobj = e.changedTouches[0];
264
-
265
- this.startPos = {
266
- x: touchobj.pageX,
267
- y: touchobj.pageY
268
- };
269
- },
270
- onTouchMove(e) {
271
- if (e.cancelable) {
272
- e.preventDefault();
273
- }
274
- },
275
- onTouchEnd(e) {
276
- let touchobj = e.changedTouches[0];
277
-
278
- if (this.isVertical()) {
279
- this.changePageOnTouch(e, (touchobj.pageY - this.startPos.y));
280
- }
281
- else {
282
- this.changePageOnTouch(e, (touchobj.pageX - this.startPos.x));
283
- }
284
- },
285
- changePageOnTouch(e, diff) {
286
- if (Math.abs(diff) > this.swipeThreshold) {
287
- if (diff < 0) { // left
288
- this.navForward(e);
289
- }
290
- else { // right
291
- this.navBackward(e);
292
- }
293
- }
294
- },
295
- bindDocumentListeners() {
296
- if (!this.documentResizeListener) {
297
- this.documentResizeListener = (e) => {
298
- this.calculatePosition(e);
299
- };
300
-
301
- window.addEventListener('resize', this.documentResizeListener);
302
- }
303
- },
304
- unbindDocumentListeners() {
305
- if(this.documentResizeListener) {
306
- window.removeEventListener('resize', this.documentResizeListener);
307
- this.documentResizeListener = null;
308
- }
309
- },
310
- startAutoplay() {
311
- this.interval = setInterval(() => {
312
- if(this.d_page === (this.totalIndicators - 1)) {
313
- this.step(-1, 0);
314
- }
315
- else {
316
- this.step(-1, this.d_page + 1);
317
- }
318
- },
319
- this.autoplayInterval);
320
- },
321
- stopAutoplay() {
322
- if (this.interval) {
323
- clearInterval(this.interval);
324
- }
325
- },
326
- createStyle() {
327
- if (!this.carouselStyle) {
328
- this.carouselStyle = document.createElement('style');
329
- this.carouselStyle.type = 'text/css';
330
- document.body.appendChild(this.carouselStyle);
331
- }
332
-
333
- let innerHTML = `
68
+ emits: ['update:page'],
69
+ props: {
70
+ value: null,
71
+ page: {
72
+ type: Number,
73
+ default: 0
74
+ },
75
+ numVisible: {
76
+ type: Number,
77
+ default: 1
78
+ },
79
+ numScroll: {
80
+ type: Number,
81
+ default: 1
82
+ },
83
+ responsiveOptions: Array,
84
+ orientation: {
85
+ type: String,
86
+ default: 'horizontal'
87
+ },
88
+ verticalViewPortHeight: {
89
+ type: String,
90
+ default: '300px'
91
+ },
92
+ contentClass: String,
93
+ containerClass: String,
94
+ indicatorsContentClass: String,
95
+ circular: {
96
+ type: Boolean,
97
+ default: false
98
+ },
99
+ autoplayInterval: {
100
+ type: Number,
101
+ default: 0
102
+ },
103
+ showNavigators: {
104
+ type: Boolean,
105
+ default: true
106
+ },
107
+ showIndicators: {
108
+ type: Boolean,
109
+ default: true
110
+ }
111
+ },
112
+ data() {
113
+ return {
114
+ id: UniqueComponentId(),
115
+ remainingItems: 0,
116
+ d_numVisible: this.numVisible,
117
+ d_numScroll: this.numScroll,
118
+ d_oldNumScroll: 0,
119
+ d_oldNumVisible: 0,
120
+ d_oldValue: null,
121
+ d_page: this.page,
122
+ totalShiftedItems: this.page * this.numScroll * -1,
123
+ allowAutoplay: !!this.autoplayInterval,
124
+ d_circular: this.circular || this.allowAutoplay,
125
+ swipeThreshold: 20
126
+ };
127
+ },
128
+ isRemainingItemsAdded: false,
129
+ watch: {
130
+ page(newValue) {
131
+ this.d_page = newValue;
132
+ },
133
+ circular(newValue) {
134
+ this.d_circular = newValue;
135
+ },
136
+ numVisible(newValue, oldValue) {
137
+ this.d_numVisible = newValue;
138
+ this.d_oldNumVisible = oldValue;
139
+ },
140
+ numScroll(newValue, oldValue) {
141
+ this.d_oldNumScroll = oldValue;
142
+ this.d_numScroll = newValue;
143
+ },
144
+ value(oldValue) {
145
+ this.d_oldValue = oldValue;
146
+ }
147
+ },
148
+ mounted() {
149
+ let stateChanged = false;
150
+
151
+ this.createStyle();
152
+ this.calculatePosition();
153
+
154
+ if (this.responsiveOptions) {
155
+ this.bindDocumentListeners();
156
+ }
157
+
158
+ if (this.isCircular()) {
159
+ let totalShiftedItems = this.totalShiftedItems;
160
+
161
+ if (this.d_page === 0) {
162
+ totalShiftedItems = -1 * this.d_numVisible;
163
+ } else if (totalShiftedItems === 0) {
164
+ totalShiftedItems = -1 * this.value.length;
165
+
166
+ if (this.remainingItems > 0) {
167
+ this.isRemainingItemsAdded = true;
168
+ }
169
+ }
170
+
171
+ if (totalShiftedItems !== this.totalShiftedItems) {
172
+ this.totalShiftedItems = totalShiftedItems;
173
+
174
+ stateChanged = true;
175
+ }
176
+ }
177
+
178
+ if (!stateChanged && this.isAutoplay()) {
179
+ this.startAutoplay();
180
+ }
181
+ },
182
+ updated() {
183
+ const isCircular = this.isCircular();
184
+ let stateChanged = false;
185
+ let totalShiftedItems = this.totalShiftedItems;
186
+
187
+ if (this.autoplayInterval) {
188
+ this.stopAutoplay();
189
+ }
190
+
191
+ if (this.d_oldNumScroll !== this.d_numScroll || this.d_oldNumVisible !== this.d_numVisible || this.d_oldValue.length !== this.value.length) {
192
+ this.remainingItems = (this.value.length - this.d_numVisible) % this.d_numScroll;
193
+
194
+ let page = this.d_page;
195
+
196
+ if (this.totalIndicators !== 0 && page >= this.totalIndicators) {
197
+ page = this.totalIndicators - 1;
198
+
199
+ this.$emit('update:page', page);
200
+ this.d_page = page;
201
+
202
+ stateChanged = true;
203
+ }
204
+
205
+ totalShiftedItems = page * this.d_numScroll * -1;
206
+
207
+ if (isCircular) {
208
+ totalShiftedItems -= this.d_numVisible;
209
+ }
210
+
211
+ if (page === this.totalIndicators - 1 && this.remainingItems > 0) {
212
+ totalShiftedItems += -1 * this.remainingItems + this.d_numScroll;
213
+ this.isRemainingItemsAdded = true;
214
+ } else {
215
+ this.isRemainingItemsAdded = false;
216
+ }
217
+
218
+ if (totalShiftedItems !== this.totalShiftedItems) {
219
+ this.totalShiftedItems = totalShiftedItems;
220
+
221
+ stateChanged = true;
222
+ }
223
+
224
+ this.d_oldNumScroll = this.d_numScroll;
225
+ this.d_oldNumVisible = this.d_numVisible;
226
+ this.d_oldValue = this.value;
227
+
228
+ this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this.d_numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this.d_numVisible)}%, 0, 0)`;
229
+ }
230
+
231
+ if (isCircular) {
232
+ if (this.d_page === 0) {
233
+ totalShiftedItems = -1 * this.d_numVisible;
234
+ } else if (totalShiftedItems === 0) {
235
+ totalShiftedItems = -1 * this.value.length;
236
+
237
+ if (this.remainingItems > 0) {
238
+ this.isRemainingItemsAdded = true;
239
+ }
240
+ }
241
+
242
+ if (totalShiftedItems !== this.totalShiftedItems) {
243
+ this.totalShiftedItems = totalShiftedItems;
244
+
245
+ stateChanged = true;
246
+ }
247
+ }
248
+
249
+ if (!stateChanged && this.isAutoplay()) {
250
+ this.startAutoplay();
251
+ }
252
+ },
253
+ beforeUnmount() {
254
+ if (this.responsiveOptions) {
255
+ this.unbindDocumentListeners();
256
+ }
257
+
258
+ if (this.autoplayInterval) {
259
+ this.stopAutoplay();
260
+ }
261
+ },
262
+ methods: {
263
+ step(dir, page) {
264
+ let totalShiftedItems = this.totalShiftedItems;
265
+ const isCircular = this.isCircular();
266
+
267
+ if (page != null) {
268
+ totalShiftedItems = this.d_numScroll * page * -1;
269
+
270
+ if (isCircular) {
271
+ totalShiftedItems -= this.d_numVisible;
272
+ }
273
+
274
+ this.isRemainingItemsAdded = false;
275
+ } else {
276
+ totalShiftedItems += this.d_numScroll * dir;
277
+
278
+ if (this.isRemainingItemsAdded) {
279
+ totalShiftedItems += this.remainingItems - this.d_numScroll * dir;
280
+ this.isRemainingItemsAdded = false;
281
+ }
282
+
283
+ let originalShiftedItems = isCircular ? totalShiftedItems + this.d_numVisible : totalShiftedItems;
284
+
285
+ page = Math.abs(Math.floor(originalShiftedItems / this.d_numScroll));
286
+ }
287
+
288
+ if (isCircular && this.d_page === this.totalIndicators - 1 && dir === -1) {
289
+ totalShiftedItems = -1 * (this.value.length + this.d_numVisible);
290
+ page = 0;
291
+ } else if (isCircular && this.d_page === 0 && dir === 1) {
292
+ totalShiftedItems = 0;
293
+ page = this.totalIndicators - 1;
294
+ } else if (page === this.totalIndicators - 1 && this.remainingItems > 0) {
295
+ totalShiftedItems += this.remainingItems * -1 - this.d_numScroll * dir;
296
+ this.isRemainingItemsAdded = true;
297
+ }
298
+
299
+ if (this.$refs.itemsContainer) {
300
+ DomHandler.removeClass(this.$refs.itemsContainer, 'p-items-hidden');
301
+ this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this.d_numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this.d_numVisible)}%, 0, 0)`;
302
+ this.$refs.itemsContainer.style.transition = 'transform 500ms ease 0s';
303
+ }
304
+
305
+ this.totalShiftedItems = totalShiftedItems;
306
+
307
+ this.$emit('update:page', page);
308
+ this.d_page = page;
309
+ },
310
+ calculatePosition() {
311
+ if (this.$refs.itemsContainer && this.responsiveOptions) {
312
+ let windowWidth = window.innerWidth;
313
+ let matchedResponsiveOptionsData = {
314
+ numVisible: this.numVisible,
315
+ numScroll: this.numScroll
316
+ };
317
+
318
+ for (let i = 0; i < this.responsiveOptions.length; i++) {
319
+ let res = this.responsiveOptions[i];
320
+
321
+ if (parseInt(res.breakpoint, 10) >= windowWidth) {
322
+ matchedResponsiveOptionsData = res;
323
+ }
324
+ }
325
+
326
+ if (this.d_numScroll !== matchedResponsiveOptionsData.numScroll) {
327
+ let page = this.d_page;
328
+
329
+ page = parseInt((page * this.d_numScroll) / matchedResponsiveOptionsData.numScroll);
330
+
331
+ this.totalShiftedItems = matchedResponsiveOptionsData.numScroll * page * -1;
332
+
333
+ if (this.isCircular()) {
334
+ this.totalShiftedItems -= matchedResponsiveOptionsData.numVisible;
335
+ }
336
+
337
+ this.d_numScroll = matchedResponsiveOptionsData.numScroll;
338
+
339
+ this.$emit('update:page', page);
340
+ this.d_page = page;
341
+ }
342
+
343
+ if (this.d_numVisible !== matchedResponsiveOptionsData.numVisible) {
344
+ this.d_numVisible = matchedResponsiveOptionsData.numVisible;
345
+ }
346
+ }
347
+ },
348
+ navBackward(e, index) {
349
+ if (this.d_circular || this.d_page !== 0) {
350
+ this.step(1, index);
351
+ }
352
+
353
+ this.allowAutoplay = false;
354
+
355
+ if (e.cancelable) {
356
+ e.preventDefault();
357
+ }
358
+ },
359
+ navForward(e, index) {
360
+ if (this.d_circular || this.d_page < this.totalIndicators - 1) {
361
+ this.step(-1, index);
362
+ }
363
+
364
+ this.allowAutoplay = false;
365
+
366
+ if (e.cancelable) {
367
+ e.preventDefault();
368
+ }
369
+ },
370
+ onIndicatorClick(e, index) {
371
+ let page = this.d_page;
372
+
373
+ if (index > page) {
374
+ this.navForward(e, index);
375
+ } else if (index < page) {
376
+ this.navBackward(e, index);
377
+ }
378
+ },
379
+ onTransitionEnd() {
380
+ if (this.$refs.itemsContainer) {
381
+ DomHandler.addClass(this.$refs.itemsContainer, 'p-items-hidden');
382
+ this.$refs.itemsContainer.style.transition = '';
383
+
384
+ if ((this.d_page === 0 || this.d_page === this.totalIndicators - 1) && this.isCircular()) {
385
+ this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${this.totalShiftedItems * (100 / this.d_numVisible)}%, 0)` : `translate3d(${this.totalShiftedItems * (100 / this.d_numVisible)}%, 0, 0)`;
386
+ }
387
+ }
388
+ },
389
+ onTouchStart(e) {
390
+ let touchobj = e.changedTouches[0];
391
+
392
+ this.startPos = {
393
+ x: touchobj.pageX,
394
+ y: touchobj.pageY
395
+ };
396
+ },
397
+ onTouchMove(e) {
398
+ if (e.cancelable) {
399
+ e.preventDefault();
400
+ }
401
+ },
402
+ onTouchEnd(e) {
403
+ let touchobj = e.changedTouches[0];
404
+
405
+ if (this.isVertical()) {
406
+ this.changePageOnTouch(e, touchobj.pageY - this.startPos.y);
407
+ } else {
408
+ this.changePageOnTouch(e, touchobj.pageX - this.startPos.x);
409
+ }
410
+ },
411
+ changePageOnTouch(e, diff) {
412
+ if (Math.abs(diff) > this.swipeThreshold) {
413
+ if (diff < 0) {
414
+ // left
415
+ this.navForward(e);
416
+ } else {
417
+ // right
418
+ this.navBackward(e);
419
+ }
420
+ }
421
+ },
422
+ bindDocumentListeners() {
423
+ if (!this.documentResizeListener) {
424
+ this.documentResizeListener = (e) => {
425
+ this.calculatePosition(e);
426
+ };
427
+
428
+ window.addEventListener('resize', this.documentResizeListener);
429
+ }
430
+ },
431
+ unbindDocumentListeners() {
432
+ if (this.documentResizeListener) {
433
+ window.removeEventListener('resize', this.documentResizeListener);
434
+ this.documentResizeListener = null;
435
+ }
436
+ },
437
+ startAutoplay() {
438
+ this.interval = setInterval(() => {
439
+ if (this.d_page === this.totalIndicators - 1) {
440
+ this.step(-1, 0);
441
+ } else {
442
+ this.step(-1, this.d_page + 1);
443
+ }
444
+ }, this.autoplayInterval);
445
+ },
446
+ stopAutoplay() {
447
+ if (this.interval) {
448
+ clearInterval(this.interval);
449
+ }
450
+ },
451
+ createStyle() {
452
+ if (!this.carouselStyle) {
453
+ this.carouselStyle = document.createElement('style');
454
+ this.carouselStyle.type = 'text/css';
455
+ document.body.appendChild(this.carouselStyle);
456
+ }
457
+
458
+ let innerHTML = `
334
459
  #${this.id} .p-carousel-item {
335
- flex: 1 0 ${ (100/ this.d_numVisible) }%
460
+ flex: 1 0 ${100 / this.d_numVisible}%
336
461
  }
337
462
  `;
338
463
 
339
- if (this.responsiveOptions) {
340
- let _responsiveOptions = [...this.responsiveOptions];
341
- _responsiveOptions.sort((data1, data2) => {
342
- const value1 = data1.breakpoint;
343
- const value2 = data2.breakpoint;
344
- let result = null;
345
-
346
- if (value1 == null && value2 != null)
347
- result = -1;
348
- else if (value1 != null && value2 == null)
349
- result = 1;
350
- else if (value1 == null && value2 == null)
351
- result = 0;
352
- else if (typeof value1 === 'string' && typeof value2 === 'string')
353
- result = value1.localeCompare(value2, undefined, { numeric: true });
354
- else
355
- result = (value1 < value2) ? -1 : (value1 > value2) ? 1 : 0;
356
-
357
- return -1 * result;
358
- });
359
-
360
- for (let i = 0; i < _responsiveOptions.length; i++) {
361
- let res = _responsiveOptions[i];
362
-
363
- innerHTML += `
464
+ if (this.responsiveOptions) {
465
+ let _responsiveOptions = [...this.responsiveOptions];
466
+
467
+ _responsiveOptions.sort((data1, data2) => {
468
+ const value1 = data1.breakpoint;
469
+ const value2 = data2.breakpoint;
470
+ let result = null;
471
+
472
+ if (value1 == null && value2 != null) result = -1;
473
+ else if (value1 != null && value2 == null) result = 1;
474
+ else if (value1 == null && value2 == null) result = 0;
475
+ else if (typeof value1 === 'string' && typeof value2 === 'string') result = value1.localeCompare(value2, undefined, { numeric: true });
476
+ else result = value1 < value2 ? -1 : value1 > value2 ? 1 : 0;
477
+
478
+ return -1 * result;
479
+ });
480
+
481
+ for (let i = 0; i < _responsiveOptions.length; i++) {
482
+ let res = _responsiveOptions[i];
483
+
484
+ innerHTML += `
364
485
  @media screen and (max-width: ${res.breakpoint}) {
365
486
  #${this.id} .p-carousel-item {
366
- flex: 1 0 ${ (100/ res.numVisible) }%
487
+ flex: 1 0 ${100 / res.numVisible}%
367
488
  }
368
489
  }
369
- `
370
- }
371
- }
372
-
373
- this.carouselStyle.innerHTML = innerHTML;
374
- },
375
- isVertical() {
376
- return this.orientation === 'vertical';
377
- },
378
- isCircular() {
379
- return this.value && this.d_circular && this.value.length >= this.d_numVisible;
380
- },
381
- isAutoplay() {
382
- return this.autoplayInterval && this.allowAutoplay;
383
- },
384
- firstIndex() {
385
- return this.isCircular()? (-1 * (this.totalShiftedItems + this.d_numVisible)) : (this.totalShiftedItems * -1);
386
- },
387
- lastIndex() {
388
- return (this.firstIndex() + this.d_numVisible - 1);
389
- }
390
- },
391
- mounted() {
392
- let stateChanged = false;
393
- this.createStyle();
394
- this.calculatePosition();
395
-
396
- if (this.responsiveOptions) {
397
- this.bindDocumentListeners();
398
- }
399
-
400
- if (this.isCircular()) {
401
- let totalShiftedItems = this.totalShiftedItems;
402
-
403
- if (this.d_page === 0) {
404
- totalShiftedItems = -1 * this.d_numVisible;
405
- }
406
- else if (totalShiftedItems === 0) {
407
- totalShiftedItems = -1 * this.value.length;
408
- if (this.remainingItems > 0) {
409
- this.isRemainingItemsAdded = true;
410
- }
411
- }
412
-
413
- if (totalShiftedItems !== this.totalShiftedItems) {
414
- this.totalShiftedItems = totalShiftedItems;
415
-
416
- stateChanged = true;
417
- }
418
- }
419
-
420
- if (!stateChanged && this.isAutoplay()) {
421
- this.startAutoplay();
422
- }
423
- },
424
- updated() {
425
- const isCircular = this.isCircular();
426
- let stateChanged = false;
427
- let totalShiftedItems = this.totalShiftedItems;
428
-
429
- if (this.autoplayInterval) {
430
- this.stopAutoplay();
431
- }
432
-
433
- if(this.d_oldNumScroll !== this.d_numScroll || this.d_oldNumVisible !== this.d_numVisible || this.d_oldValue.length !== this.value.length) {
434
- this.remainingItems = (this.value.length - this.d_numVisible) % this.d_numScroll;
435
-
436
- let page = this.d_page;
437
- if (this.totalIndicators !== 0 && page >= this.totalIndicators) {
438
- page = this.totalIndicators - 1;
439
-
440
- this.$emit('update:page', page);
441
- this.d_page = page;
442
-
443
- stateChanged = true;
444
- }
445
-
446
- totalShiftedItems = (page * this.d_numScroll) * -1;
447
- if (isCircular) {
448
- totalShiftedItems -= this.d_numVisible;
449
- }
450
-
451
- if (page === (this.totalIndicators - 1) && this.remainingItems > 0) {
452
- totalShiftedItems += (-1 * this.remainingItems) + this.d_numScroll;
453
- this.isRemainingItemsAdded = true;
454
- }
455
- else {
456
- this.isRemainingItemsAdded = false;
457
- }
458
-
459
- if (totalShiftedItems !== this.totalShiftedItems) {
460
- this.totalShiftedItems = totalShiftedItems;
461
-
462
- stateChanged = true;
463
- }
464
-
465
- this.d_oldNumScroll = this.d_numScroll;
466
- this.d_oldNumVisible = this.d_numVisible;
467
- this.d_oldValue = this.value;
468
-
469
- this.$refs.itemsContainer.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100/ this.d_numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100/ this.d_numVisible)}%, 0, 0)`;
470
- }
471
-
472
- if (isCircular) {
473
- if (this.d_page === 0) {
474
- totalShiftedItems = -1 * this.d_numVisible;
475
- }
476
- else if (totalShiftedItems === 0) {
477
- totalShiftedItems = -1 * this.value.length;
478
- if (this.remainingItems > 0) {
479
- this.isRemainingItemsAdded = true;
480
- }
481
- }
482
-
483
- if (totalShiftedItems !== this.totalShiftedItems) {
484
- this.totalShiftedItems = totalShiftedItems;
485
-
486
- stateChanged = true;
487
- }
488
- }
489
-
490
- if (!stateChanged && this.isAutoplay()) {
491
- this.startAutoplay();
492
- }
493
- },
494
- beforeUnmount() {
495
- if (this.responsiveOptions) {
496
- this.unbindDocumentListeners();
497
- }
498
-
499
- if (this.autoplayInterval) {
500
- this.stopAutoplay();
501
- }
502
- },
503
- computed: {
504
- totalIndicators() {
505
- return this.value ? Math.max(Math.ceil((this.value.length - this.d_numVisible) / this.d_numScroll) + 1, 0) : 0;
506
- },
507
- backwardIsDisabled() {
508
- return (this.value && (!this.circular || this.value.length < this.d_numVisible) && this.d_page === 0);
509
- },
510
- forwardIsDisabled() {
511
- return (this.value && (!this.circular || this.value.length < this.d_numVisible) && (this.d_page === (this.totalIndicators - 1) || this.totalIndicators === 0));
512
- },
513
- containerClasses() {
514
- return ['p-carousel-container', this.containerClass];
515
- },
516
- contentClasses() {
517
- return ['p-carousel-content ', this.contentClass];
518
- },
519
- indicatorsContentClasses() {
520
- return ['p-carousel-indicators p-reset', this.indicatorsContentClass];
521
- },
490
+ `;
491
+ }
492
+ }
493
+
494
+ this.carouselStyle.innerHTML = innerHTML;
495
+ },
496
+ isVertical() {
497
+ return this.orientation === 'vertical';
498
+ },
499
+ isCircular() {
500
+ return this.value && this.d_circular && this.value.length >= this.d_numVisible;
501
+ },
502
+ isAutoplay() {
503
+ return this.autoplayInterval && this.allowAutoplay;
504
+ },
505
+ firstIndex() {
506
+ return this.isCircular() ? -1 * (this.totalShiftedItems + this.d_numVisible) : this.totalShiftedItems * -1;
507
+ },
508
+ lastIndex() {
509
+ return this.firstIndex() + this.d_numVisible - 1;
510
+ }
511
+ },
512
+ computed: {
513
+ totalIndicators() {
514
+ return this.value ? Math.max(Math.ceil((this.value.length - this.d_numVisible) / this.d_numScroll) + 1, 0) : 0;
515
+ },
516
+ backwardIsDisabled() {
517
+ return this.value && (!this.circular || this.value.length < this.d_numVisible) && this.d_page === 0;
518
+ },
519
+ forwardIsDisabled() {
520
+ return this.value && (!this.circular || this.value.length < this.d_numVisible) && (this.d_page === this.totalIndicators - 1 || this.totalIndicators === 0);
521
+ },
522
+ containerClasses() {
523
+ return ['p-carousel-container', this.containerClass];
524
+ },
525
+ contentClasses() {
526
+ return ['p-carousel-content ', this.contentClass];
527
+ },
528
+ indicatorsContentClasses() {
529
+ return ['p-carousel-indicators p-reset', this.indicatorsContentClass];
530
+ }
522
531
  },
523
532
  directives: {
524
- 'ripple': Ripple
533
+ ripple: Ripple
525
534
  }
526
- }
535
+ };
527
536
  </script>
528
537
 
529
538
  <style>
530
539
  .p-carousel {
531
- display: flex;
532
- flex-direction: column;
540
+ display: flex;
541
+ flex-direction: column;
533
542
  }
534
543
 
535
544
  .p-carousel-content {
536
- display: flex;
537
- flex-direction: column;
538
- overflow: auto;
545
+ display: flex;
546
+ flex-direction: column;
547
+ overflow: auto;
539
548
  }
540
549
 
541
550
  .p-carousel-prev,
542
551
  .p-carousel-next {
543
- align-self: center;
544
- flex-grow: 0;
552
+ align-self: center;
553
+ flex-grow: 0;
545
554
  flex-shrink: 0;
546
555
  display: flex;
547
556
  justify-content: center;
@@ -551,25 +560,25 @@ export default {
551
560
  }
552
561
 
553
562
  .p-carousel-container {
554
- display: flex;
555
- flex-direction: row;
563
+ display: flex;
564
+ flex-direction: row;
556
565
  }
557
566
 
558
567
  .p-carousel-items-content {
559
- overflow: hidden;
568
+ overflow: hidden;
560
569
  width: 100%;
561
570
  }
562
571
 
563
572
  .p-carousel-items-container {
564
- display: flex;
565
- flex-direction: row;
573
+ display: flex;
574
+ flex-direction: row;
566
575
  }
567
576
 
568
577
  .p-carousel-indicators {
569
- display: flex;
570
- flex-direction: row;
571
- justify-content: center;
572
- flex-wrap: wrap;
578
+ display: flex;
579
+ flex-direction: row;
580
+ justify-content: center;
581
+ flex-wrap: wrap;
573
582
  }
574
583
 
575
584
  .p-carousel-indicator > button {
@@ -580,20 +589,20 @@ export default {
580
589
 
581
590
  /* Vertical */
582
591
  .p-carousel-vertical .p-carousel-container {
583
- flex-direction: column;
592
+ flex-direction: column;
584
593
  }
585
594
 
586
595
  .p-carousel-vertical .p-carousel-items-container {
587
- flex-direction: column;
588
- height: 100%;
596
+ flex-direction: column;
597
+ height: 100%;
589
598
  }
590
599
 
591
600
  /* Keyboard Support */
592
601
  .p-items-hidden .p-carousel-item {
593
- visibility: hidden;
602
+ visibility: hidden;
594
603
  }
595
604
 
596
605
  .p-items-hidden .p-carousel-item.p-carousel-item-active {
597
- visibility: visible;
606
+ visibility: visible;
598
607
  }
599
608
  </style>