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,6 +1,6 @@
1
- import { DomHandler } from 'primevue/utils';
1
+ import { DomHandler, UniqueComponentId } from 'primevue/utils';
2
2
  import Ripple from 'primevue/ripple';
3
- import { resolveDirective, openBlock, createElementBlock, normalizeClass, createElementVNode, withDirectives, createCommentVNode, Fragment, renderList, toDisplayString, createBlock, resolveDynamicComponent, vShow } from 'vue';
3
+ import { resolveDirective, openBlock, createElementBlock, normalizeClass, createElementVNode, withDirectives, mergeProps, createCommentVNode, Fragment, renderList, toDisplayString, createBlock, resolveDynamicComponent, vShow } from 'vue';
4
4
 
5
5
  var script = {
6
6
  name: 'TabView',
@@ -17,165 +17,313 @@ var script = {
17
17
  scrollable: {
18
18
  type: Boolean,
19
19
  default: false
20
- }
20
+ },
21
+ tabindex: {
22
+ type: Number,
23
+ default: 0
24
+ },
25
+ selectOnFocus: {
26
+ type: Boolean,
27
+ default: false
28
+ },
29
+ previousButtonProps: null,
30
+ nextButtonProps: null
21
31
  },
22
32
  data() {
23
33
  return {
24
34
  d_activeIndex: this.activeIndex,
25
- backwardIsDisabled: true,
26
- forwardIsDisabled: false
27
- }
35
+ focusedTabIndex: -1,
36
+ isPrevButtonDisabled: true,
37
+ isNextButtonDisabled: false
38
+ };
28
39
  },
29
40
  watch: {
30
41
  activeIndex(newValue) {
31
42
  this.d_activeIndex = newValue;
32
43
 
33
- this.updateScrollBar(newValue);
44
+ this.scrollInView({ index: newValue });
34
45
  }
35
46
  },
36
- updated() {
47
+ mounted() {
37
48
  this.updateInkBar();
38
49
  },
39
- mounted() {
50
+ updated() {
40
51
  this.updateInkBar();
41
52
  },
42
53
  methods: {
43
- onTabClick(event, i) {
44
- if (!this.isTabDisabled(this.tabs[i]) && i !== this.d_activeIndex) {
45
- this.d_activeIndex = i;
46
- this.$emit('update:activeIndex', this.d_activeIndex);
47
-
48
- this.$emit('tab-change', {
49
- originalEvent: event,
50
- index: i
51
- });
52
-
53
- this.updateScrollBar(i);
54
- }
55
-
56
- this.$emit('tab-click', {
57
- originalEvent: event,
58
- index: i
59
- });
60
- },
61
- onTabKeydown(event, i) {
62
- if (event.which === 13) {
63
- this.onTabClick(event, i);
64
- }
65
- },
66
- updateInkBar() {
67
- let tabHeader = this.$refs.nav.children[this.d_activeIndex];
68
- this.$refs.inkbar.style.width = DomHandler.getWidth(tabHeader) + 'px';
69
- this.$refs.inkbar.style.left = DomHandler.getOffset(tabHeader).left - DomHandler.getOffset(this.$refs.nav).left + 'px';
54
+ isTabPanel(child) {
55
+ return child.type.name === 'TabPanel';
70
56
  },
71
- updateScrollBar(index) {
72
- let tabHeader = this.$refs.nav.children[index];
73
- tabHeader.scrollIntoView({ block: 'nearest' });
57
+ isTabActive(index) {
58
+ return this.d_activeIndex === index;
74
59
  },
75
- updateButtonState() {
76
- const content = this.$refs.content;
77
- const { scrollLeft, scrollWidth } = content;
78
- const width = DomHandler.getWidth(content);
79
-
80
- this.backwardIsDisabled = scrollLeft === 0;
81
- this.forwardIsDisabled = parseInt(scrollLeft) === scrollWidth - width;
60
+ getTabProp(tab, name) {
61
+ return tab.props ? tab.props[name] : undefined;
82
62
  },
83
- getKey(tab, i) {
84
- return (tab.props && tab.props.header) ? tab.props.header : i;
63
+ getKey(tab, index) {
64
+ return this.getTabProp(tab, 'header') || index;
85
65
  },
86
- isTabDisabled(tab) {
87
- return (tab.props && tab.props.disabled);
66
+ getTabHeaderActionId(index) {
67
+ return `${this.id}_${index}_header_action`;
88
68
  },
89
- isTabPanel(child) {
90
- return child.type.name === 'TabPanel'
69
+ getTabContentId(index) {
70
+ return `${this.id}_${index}_content`;
91
71
  },
92
72
  onScroll(event) {
93
73
  this.scrollable && this.updateButtonState();
94
74
 
95
75
  event.preventDefault();
96
76
  },
97
- getVisibleButtonWidths() {
98
- const { prevBtn, nextBtn } = this.$refs;
99
-
100
- return [prevBtn, nextBtn].reduce((acc, el) => el ? acc + DomHandler.getWidth(el) : acc, 0);
101
- },
102
- navBackward() {
77
+ onPrevButtonClick() {
103
78
  const content = this.$refs.content;
104
79
  const width = DomHandler.getWidth(content) - this.getVisibleButtonWidths();
105
80
  const pos = content.scrollLeft - width;
81
+
106
82
  content.scrollLeft = pos <= 0 ? 0 : pos;
107
83
  },
108
- navForward() {
84
+ onNextButtonClick() {
109
85
  const content = this.$refs.content;
110
86
  const width = DomHandler.getWidth(content) - this.getVisibleButtonWidths();
111
87
  const pos = content.scrollLeft + width;
112
88
  const lastPos = content.scrollWidth - width;
113
89
 
114
90
  content.scrollLeft = pos >= lastPos ? lastPos : pos;
91
+ },
92
+ onTabClick(event, tab, index) {
93
+ this.changeActiveIndex(event, tab, index);
94
+ this.$emit('tab-click', { originalEvent: event, index });
95
+ },
96
+ onTabKeyDown(event, tab, index) {
97
+ switch (event.code) {
98
+ case 'ArrowLeft':
99
+ this.onTabArrowLeftKey(event);
100
+ break;
101
+
102
+ case 'ArrowRight':
103
+ this.onTabArrowRightKey(event);
104
+ break;
105
+
106
+ case 'Home':
107
+ this.onTabHomeKey(event);
108
+ break;
109
+
110
+ case 'End':
111
+ this.onTabEndKey(event);
112
+ break;
113
+
114
+ case 'PageDown':
115
+ this.onPageDownKey(event);
116
+ break;
117
+
118
+ case 'PageUp':
119
+ this.onPageUpKey(event);
120
+ break;
121
+
122
+ case 'Enter':
123
+ case 'Space':
124
+ this.onTabEnterKey(event, tab, index);
125
+ break;
126
+ }
127
+ },
128
+ onTabArrowRightKey(event) {
129
+ const nextHeaderAction = this.findNextHeaderAction(event.target.parentElement);
130
+
131
+ nextHeaderAction ? this.changeFocusedTab(event, nextHeaderAction) : this.onTabHomeKey(event);
132
+ event.preventDefault();
133
+ },
134
+ onTabArrowLeftKey(event) {
135
+ const prevHeaderAction = this.findPrevHeaderAction(event.target.parentElement);
136
+
137
+ prevHeaderAction ? this.changeFocusedTab(event, prevHeaderAction) : this.onTabEndKey(event);
138
+ event.preventDefault();
139
+ },
140
+ onTabHomeKey(event) {
141
+ const firstHeaderAction = this.findFirstHeaderAction();
142
+
143
+ this.changeFocusedTab(event, firstHeaderAction);
144
+ event.preventDefault();
145
+ },
146
+ onTabEndKey(event) {
147
+ const lastHeaderAction = this.findLastHeaderAction();
148
+
149
+ this.changeFocusedTab(event, lastHeaderAction);
150
+ event.preventDefault();
151
+ },
152
+ onPageDownKey(event) {
153
+ this.scrollInView({ index: this.$refs.nav.children.length - 2 });
154
+ event.preventDefault();
155
+ },
156
+ onPageUpKey(event) {
157
+ this.scrollInView({ index: 0 });
158
+ event.preventDefault();
159
+ },
160
+ onTabEnterKey(event, tab, index) {
161
+ this.changeActiveIndex(event, tab, index);
162
+
163
+ event.preventDefault();
164
+ },
165
+ findNextHeaderAction(tabElement, selfCheck = false) {
166
+ const headerElement = selfCheck ? tabElement : tabElement.nextElementSibling;
167
+
168
+ return headerElement
169
+ ? DomHandler.hasClass(headerElement, 'p-disabled') || DomHandler.hasClass(headerElement, 'p-tabview-ink-bar')
170
+ ? this.findNextHeaderAction(headerElement)
171
+ : DomHandler.findSingle(headerElement, '.p-tabview-header-action')
172
+ : null;
173
+ },
174
+ findPrevHeaderAction(tabElement, selfCheck = false) {
175
+ const headerElement = selfCheck ? tabElement : tabElement.previousElementSibling;
176
+
177
+ return headerElement
178
+ ? DomHandler.hasClass(headerElement, 'p-disabled') || DomHandler.hasClass(headerElement, 'p-tabview-ink-bar')
179
+ ? this.findPrevHeaderAction(headerElement)
180
+ : DomHandler.findSingle(headerElement, '.p-tabview-header-action')
181
+ : null;
182
+ },
183
+ findFirstHeaderAction() {
184
+ return this.findNextHeaderAction(this.$refs.nav.firstElementChild, true);
185
+ },
186
+ findLastHeaderAction() {
187
+ return this.findPrevHeaderAction(this.$refs.nav.lastElementChild, true);
188
+ },
189
+ changeActiveIndex(event, tab, index) {
190
+ if (!this.getTabProp(tab, 'disabled') && this.d_activeIndex !== index) {
191
+ this.d_activeIndex = index;
192
+
193
+ this.$emit('update:activeIndex', index);
194
+ this.$emit('tab-change', { originalEvent: event, index });
195
+
196
+ this.scrollInView({ index });
197
+ }
198
+ },
199
+ changeFocusedTab(event, element) {
200
+ if (element) {
201
+ DomHandler.focus(element);
202
+ this.scrollInView({ element });
203
+
204
+ if (this.selectOnFocus) {
205
+ const index = parseInt(element.parentElement.dataset.index, 10);
206
+ const tab = this.tabs[index];
207
+
208
+ this.changeActiveIndex(event, tab, index);
209
+ }
210
+ }
211
+ },
212
+ scrollInView({ element, index = -1 }) {
213
+ const currentElement = element || this.$refs.nav.children[index];
214
+
215
+ if (currentElement) {
216
+ currentElement.scrollIntoView && currentElement.scrollIntoView({ block: 'nearest' });
217
+ }
218
+ },
219
+ updateInkBar() {
220
+ let tabHeader = this.$refs.nav.children[this.d_activeIndex];
221
+
222
+ this.$refs.inkbar.style.width = DomHandler.getWidth(tabHeader) + 'px';
223
+ this.$refs.inkbar.style.left = DomHandler.getOffset(tabHeader).left - DomHandler.getOffset(this.$refs.nav).left + 'px';
224
+ },
225
+ updateButtonState() {
226
+ const content = this.$refs.content;
227
+ const { scrollLeft, scrollWidth } = content;
228
+ const width = DomHandler.getWidth(content);
229
+
230
+ this.isPrevButtonDisabled = scrollLeft === 0;
231
+ this.isNextButtonDisabled = parseInt(scrollLeft) === scrollWidth - width;
232
+ },
233
+ getVisibleButtonWidths() {
234
+ const { prevBtn, nextBtn } = this.$refs;
235
+
236
+ return [prevBtn, nextBtn].reduce((acc, el) => (el ? acc + DomHandler.getWidth(el) : acc), 0);
237
+ },
238
+ getTabHeaderClass(tab, i) {
239
+ return [
240
+ 'p-tabview-header',
241
+ this.getTabProp(tab, 'headerClass'),
242
+ {
243
+ 'p-highlight': this.d_activeIndex === i,
244
+ 'p-disabled': this.getTabProp(tab, 'disabled')
245
+ }
246
+ ];
247
+ },
248
+ getTabContentClass(tab) {
249
+ return ['p-tabview-panel', this.getTabProp(tab, 'contentClass')];
115
250
  }
116
251
  },
117
252
  computed: {
118
253
  contentClasses() {
119
- return ['p-tabview p-component', {'p-tabview-scrollable': this.scrollable}];
120
- },
121
- prevButtonClasses() {
122
- return ['p-tabview-nav-prev p-tabview-nav-btn p-link']
123
- },
124
- nextButtonClasses() {
125
- return ['p-tabview-nav-next p-tabview-nav-btn p-link']
254
+ return [
255
+ 'p-tabview p-component',
256
+ {
257
+ 'p-tabview-scrollable': this.scrollable
258
+ }
259
+ ];
126
260
  },
127
261
  tabs() {
128
- const tabs = [];
129
- this.$slots.default().forEach(child => {
130
- if (this.isTabPanel(child)) {
131
- tabs.push(child);
132
- }
133
- else if (child.children && child.children instanceof Array) {
134
- child.children.forEach(nestedChild => {
135
- if (this.isTabPanel(nestedChild)) {
136
- tabs.push(nestedChild);
137
- }
138
- });
139
- }
262
+ return this.$slots.default().reduce((tabs, child) => {
263
+ if (this.isTabPanel(child)) {
264
+ tabs.push(child);
265
+ } else if (child.children && child.children instanceof Array) {
266
+ child.children.forEach((nestedChild) => {
267
+ if (this.isTabPanel(nestedChild)) {
268
+ tabs.push(nestedChild);
269
+ }
270
+ });
140
271
  }
141
- );
142
- return tabs;
272
+
273
+ return tabs;
274
+ }, []);
275
+ },
276
+ prevButtonAriaLabel() {
277
+ return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.previous : undefined;
278
+ },
279
+ nextButtonAriaLabel() {
280
+ return this.$primevue.config.locale.aria ? this.$primevue.config.locale.aria.next : undefined;
281
+ },
282
+ id() {
283
+ return this.$attrs.id || UniqueComponentId();
143
284
  }
144
285
  },
145
286
  directives: {
146
- 'ripple': Ripple
287
+ ripple: Ripple
147
288
  }
148
289
  };
149
290
 
150
291
  const _hoisted_1 = { class: "p-tabview-nav-container" };
151
- const _hoisted_2 = /*#__PURE__*/createElementVNode("span", { class: "pi pi-chevron-left" }, null, -1);
152
- const _hoisted_3 = [
153
- _hoisted_2
292
+ const _hoisted_2 = ["tabindex", "aria-label"];
293
+ const _hoisted_3 = /*#__PURE__*/createElementVNode("span", {
294
+ class: "pi pi-chevron-left",
295
+ "aria-hidden": "true"
296
+ }, null, -1);
297
+ const _hoisted_4 = [
298
+ _hoisted_3
154
299
  ];
155
- const _hoisted_4 = {
300
+ const _hoisted_5 = {
156
301
  ref: "nav",
157
302
  class: "p-tabview-nav",
158
303
  role: "tablist"
159
304
  };
160
- const _hoisted_5 = ["onClick", "onKeydown", "tabindex", "aria-selected"];
161
- const _hoisted_6 = {
305
+ const _hoisted_6 = ["data-index"];
306
+ const _hoisted_7 = ["id", "tabindex", "aria-disabled", "aria-selected", "aria-controls", "onClick", "onKeydown"];
307
+ const _hoisted_8 = {
162
308
  key: 0,
163
309
  class: "p-tabview-title"
164
310
  };
165
- const _hoisted_7 = {
311
+ const _hoisted_9 = {
166
312
  ref: "inkbar",
167
- class: "p-tabview-ink-bar"
313
+ class: "p-tabview-ink-bar",
314
+ role: "presentation",
315
+ "aria-hidden": "true"
168
316
  };
169
- const _hoisted_8 = /*#__PURE__*/createElementVNode("span", { class: "pi pi-chevron-right" }, null, -1);
170
- const _hoisted_9 = [
171
- _hoisted_8
317
+ const _hoisted_10 = ["tabindex", "aria-label"];
318
+ const _hoisted_11 = /*#__PURE__*/createElementVNode("span", {
319
+ class: "pi pi-chevron-right",
320
+ "aria-hidden": "true"
321
+ }, null, -1);
322
+ const _hoisted_12 = [
323
+ _hoisted_11
172
324
  ];
173
- const _hoisted_10 = { class: "p-tabview-panels" };
174
- const _hoisted_11 = {
175
- key: 0,
176
- class: "p-tabview-panel",
177
- role: "tabpanel"
178
- };
325
+ const _hoisted_13 = { class: "p-tabview-panels" };
326
+ const _hoisted_14 = ["aria-labelledby"];
179
327
 
180
328
  function render(_ctx, _cache, $props, $setup, $data, $options) {
181
329
  const _directive_ripple = resolveDirective("ripple");
@@ -184,14 +332,16 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
184
332
  class: normalizeClass($options.contentClasses)
185
333
  }, [
186
334
  createElementVNode("div", _hoisted_1, [
187
- ($props.scrollable && !$data.backwardIsDisabled)
188
- ? withDirectives((openBlock(), createElementBlock("button", {
335
+ ($props.scrollable && !$data.isPrevButtonDisabled)
336
+ ? withDirectives((openBlock(), createElementBlock("button", mergeProps({
189
337
  key: 0,
190
338
  ref: "prevBtn",
191
- class: normalizeClass($options.prevButtonClasses),
192
- onClick: _cache[0] || (_cache[0] = (...args) => ($options.navBackward && $options.navBackward(...args))),
193
- type: "button"
194
- }, _hoisted_3, 2)), [
339
+ type: "button",
340
+ class: "p-tabview-nav-prev p-tabview-nav-btn p-link",
341
+ tabindex: $props.tabindex,
342
+ "aria-label": $options.prevButtonAriaLabel,
343
+ onClick: _cache[0] || (_cache[0] = (...args) => ($options.onPrevButtonClick && $options.onPrevButtonClick(...args)))
344
+ }, $props.previousButtonProps), _hoisted_4, 16, _hoisted_2)), [
195
345
  [_directive_ripple]
196
346
  ])
197
347
  : createCommentVNode("", true),
@@ -200,57 +350,70 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
200
350
  class: "p-tabview-nav-content",
201
351
  onScroll: _cache[1] || (_cache[1] = (...args) => ($options.onScroll && $options.onScroll(...args)))
202
352
  }, [
203
- createElementVNode("ul", _hoisted_4, [
353
+ createElementVNode("ul", _hoisted_5, [
204
354
  (openBlock(true), createElementBlock(Fragment, null, renderList($options.tabs, (tab, i) => {
205
- return (openBlock(), createElementBlock("li", {
355
+ return (openBlock(), createElementBlock("li", mergeProps({
356
+ key: $options.getKey(tab, i),
357
+ style: $options.getTabProp(tab, 'headerStyle'),
358
+ class: $options.getTabHeaderClass(tab, i),
206
359
  role: "presentation",
207
- key: $options.getKey(tab,i),
208
- class: normalizeClass([{'p-highlight': ($data.d_activeIndex === i), 'p-disabled': $options.isTabDisabled(tab)}])
209
- }, [
210
- withDirectives((openBlock(), createElementBlock("a", {
360
+ "data-index": i
361
+ }, $options.getTabProp(tab, 'headerProps')), [
362
+ withDirectives((openBlock(), createElementBlock("a", mergeProps({
363
+ id: $options.getTabHeaderActionId(i),
364
+ class: "p-tabview-nav-link p-tabview-header-action",
365
+ tabindex: $options.getTabProp(tab, 'disabled') || !$options.isTabActive(i) ? -1 : $props.tabindex,
211
366
  role: "tab",
212
- class: "p-tabview-nav-link",
213
- onClick: $event => ($options.onTabClick($event, i)),
214
- onKeydown: $event => ($options.onTabKeydown($event, i)),
215
- tabindex: $options.isTabDisabled(tab) ? null : '0',
216
- "aria-selected": $data.d_activeIndex === i
217
- }, [
367
+ "aria-disabled": $options.getTabProp(tab, 'disabled'),
368
+ "aria-selected": $options.isTabActive(i),
369
+ "aria-controls": $options.getTabContentId(i),
370
+ onClick: $event => ($options.onTabClick($event, tab, i)),
371
+ onKeydown: $event => ($options.onTabKeyDown($event, tab, i))
372
+ }, $options.getTabProp(tab, 'headerActionProps')), [
218
373
  (tab.props && tab.props.header)
219
- ? (openBlock(), createElementBlock("span", _hoisted_6, toDisplayString(tab.props.header), 1))
374
+ ? (openBlock(), createElementBlock("span", _hoisted_8, toDisplayString(tab.props.header), 1))
220
375
  : createCommentVNode("", true),
221
376
  (tab.children && tab.children.header)
222
377
  ? (openBlock(), createBlock(resolveDynamicComponent(tab.children.header), { key: 1 }))
223
378
  : createCommentVNode("", true)
224
- ], 40, _hoisted_5)), [
379
+ ], 16, _hoisted_7)), [
225
380
  [_directive_ripple]
226
381
  ])
227
- ], 2))
382
+ ], 16, _hoisted_6))
228
383
  }), 128)),
229
- createElementVNode("li", _hoisted_7, null, 512)
384
+ createElementVNode("li", _hoisted_9, null, 512)
230
385
  ], 512)
231
386
  ], 544),
232
- ($props.scrollable && !$data.forwardIsDisabled)
233
- ? withDirectives((openBlock(), createElementBlock("button", {
387
+ ($props.scrollable && !$data.isNextButtonDisabled)
388
+ ? withDirectives((openBlock(), createElementBlock("button", mergeProps({
234
389
  key: 1,
235
390
  ref: "nextBtn",
236
- class: normalizeClass($options.nextButtonClasses),
237
- onClick: _cache[2] || (_cache[2] = (...args) => ($options.navForward && $options.navForward(...args))),
238
- type: "button"
239
- }, _hoisted_9, 2)), [
391
+ type: "button",
392
+ class: "p-tabview-nav-next p-tabview-nav-btn p-link",
393
+ tabindex: $props.tabindex,
394
+ "aria-label": $options.nextButtonAriaLabel,
395
+ onClick: _cache[2] || (_cache[2] = (...args) => ($options.onNextButtonClick && $options.onNextButtonClick(...args)))
396
+ }, $props.nextButtonProps), _hoisted_12, 16, _hoisted_10)), [
240
397
  [_directive_ripple]
241
398
  ])
242
399
  : createCommentVNode("", true)
243
400
  ]),
244
- createElementVNode("div", _hoisted_10, [
401
+ createElementVNode("div", _hoisted_13, [
245
402
  (openBlock(true), createElementBlock(Fragment, null, renderList($options.tabs, (tab, i) => {
246
403
  return (openBlock(), createElementBlock(Fragment, {
247
- key: $options.getKey(tab,i)
404
+ key: $options.getKey(tab, i)
248
405
  }, [
249
- ($props.lazy ? ($data.d_activeIndex === i) : true)
250
- ? withDirectives((openBlock(), createElementBlock("div", _hoisted_11, [
406
+ ($props.lazy ? $options.isTabActive(i) : true)
407
+ ? withDirectives((openBlock(), createElementBlock("div", mergeProps({
408
+ key: 0,
409
+ style: $options.getTabProp(tab, 'contentStyle'),
410
+ class: $options.getTabContentClass(tab),
411
+ role: "tabpanel",
412
+ "aria-labelledby": $options.getTabHeaderActionId(i)
413
+ }, $options.getTabProp(tab, 'contentProps')), [
251
414
  (openBlock(), createBlock(resolveDynamicComponent(tab)))
252
- ], 512)), [
253
- [vShow, $props.lazy ? true: ($data.d_activeIndex === i)]
415
+ ], 16, _hoisted_14)), [
416
+ [vShow, $props.lazy ? true : $options.isTabActive(i)]
254
417
  ])
255
418
  : createCommentVNode("", true)
256
419
  ], 64))
@@ -286,7 +449,7 @@ function styleInject(css, ref) {
286
449
  }
287
450
  }
288
451
 
289
- var css_248z = "\n.p-tabview-nav-container {\n position: relative;\n}\n.p-tabview-scrollable .p-tabview-nav-container {\n overflow: hidden;\n}\n.p-tabview-nav-content {\n overflow-x: auto;\n overflow-y: hidden;\n scroll-behavior: smooth;\n scrollbar-width: none;\n -ms-scroll-chaining: contain auto;\n overscroll-behavior: contain auto;\n}\n.p-tabview-nav {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n margin: 0;\n padding: 0;\n list-style-type: none;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n}\n.p-tabview-nav-link {\n cursor: pointer;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n position: relative;\n text-decoration: none;\n overflow: hidden;\n}\n.p-tabview-ink-bar {\n display: none;\n z-index: 1;\n}\n.p-tabview-nav-link:focus {\n z-index: 1;\n}\n.p-tabview-title {\n line-height: 1;\n white-space: nowrap;\n}\n.p-tabview-nav-btn {\n position: absolute;\n top: 0;\n z-index: 2;\n height: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n.p-tabview-nav-prev {\n left: 0;\n}\n.p-tabview-nav-next {\n right: 0;\n}\n.p-tabview-nav-content::-webkit-scrollbar {\n display: none;\n}\n";
452
+ var css_248z = "\n.p-tabview-nav-container {\n position: relative;\n}\n.p-tabview-scrollable .p-tabview-nav-container {\n overflow: hidden;\n}\n.p-tabview-nav-content {\n overflow-x: auto;\n overflow-y: hidden;\n scroll-behavior: smooth;\n scrollbar-width: none;\n -ms-scroll-chaining: contain auto;\n overscroll-behavior: contain auto;\n}\n.p-tabview-nav {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n margin: 0;\n padding: 0;\n list-style-type: none;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n}\n.p-tabview-header-action {\n cursor: pointer;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n position: relative;\n text-decoration: none;\n overflow: hidden;\n}\n.p-tabview-ink-bar {\n display: none;\n z-index: 1;\n}\n.p-tabview-header-action:focus {\n z-index: 1;\n}\n.p-tabview-title {\n line-height: 1;\n white-space: nowrap;\n}\n.p-tabview-nav-btn {\n position: absolute;\n top: 0;\n z-index: 2;\n height: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n.p-tabview-nav-prev {\n left: 0;\n}\n.p-tabview-nav-next {\n right: 0;\n}\n.p-tabview-nav-content::-webkit-scrollbar {\n display: none;\n}\n";
290
453
  styleInject(css_248z);
291
454
 
292
455
  script.render = render;
@@ -1 +1 @@
1
- import{DomHandler as e}from"primevue/utils";import t from"primevue/ripple";import{resolveDirective as n,openBlock as a,createElementBlock as i,normalizeClass as s,createElementVNode as l,withDirectives as o,createCommentVNode as r,Fragment as d,renderList as c,toDisplayString as p,createBlock as b,resolveDynamicComponent as v,vShow as h}from"vue";var u={name:"TabView",emits:["update:activeIndex","tab-change","tab-click"],props:{activeIndex:{type:Number,default:0},lazy:{type:Boolean,default:!1},scrollable:{type:Boolean,default:!1}},data(){return{d_activeIndex:this.activeIndex,backwardIsDisabled:!0,forwardIsDisabled:!1}},watch:{activeIndex(e){this.d_activeIndex=e,this.updateScrollBar(e)}},updated(){this.updateInkBar()},mounted(){this.updateInkBar()},methods:{onTabClick(e,t){this.isTabDisabled(this.tabs[t])||t===this.d_activeIndex||(this.d_activeIndex=t,this.$emit("update:activeIndex",this.d_activeIndex),this.$emit("tab-change",{originalEvent:e,index:t}),this.updateScrollBar(t)),this.$emit("tab-click",{originalEvent:e,index:t})},onTabKeydown(e,t){13===e.which&&this.onTabClick(e,t)},updateInkBar(){let t=this.$refs.nav.children[this.d_activeIndex];this.$refs.inkbar.style.width=e.getWidth(t)+"px",this.$refs.inkbar.style.left=e.getOffset(t).left-e.getOffset(this.$refs.nav).left+"px"},updateScrollBar(e){this.$refs.nav.children[e].scrollIntoView({block:"nearest"})},updateButtonState(){const t=this.$refs.content,{scrollLeft:n,scrollWidth:a}=t,i=e.getWidth(t);this.backwardIsDisabled=0===n,this.forwardIsDisabled=parseInt(n)===a-i},getKey:(e,t)=>e.props&&e.props.header?e.props.header:t,isTabDisabled:e=>e.props&&e.props.disabled,isTabPanel:e=>"TabPanel"===e.type.name,onScroll(e){this.scrollable&&this.updateButtonState(),e.preventDefault()},getVisibleButtonWidths(){const{prevBtn:t,nextBtn:n}=this.$refs;return[t,n].reduce(((t,n)=>n?t+e.getWidth(n):t),0)},navBackward(){const t=this.$refs.content,n=e.getWidth(t)-this.getVisibleButtonWidths(),a=t.scrollLeft-n;t.scrollLeft=a<=0?0:a},navForward(){const t=this.$refs.content,n=e.getWidth(t)-this.getVisibleButtonWidths(),a=t.scrollLeft+n,i=t.scrollWidth-n;t.scrollLeft=a>=i?i:a}},computed:{contentClasses(){return["p-tabview p-component",{"p-tabview-scrollable":this.scrollable}]},prevButtonClasses:()=>["p-tabview-nav-prev p-tabview-nav-btn p-link"],nextButtonClasses:()=>["p-tabview-nav-next p-tabview-nav-btn p-link"],tabs(){const e=[];return this.$slots.default().forEach((t=>{this.isTabPanel(t)?e.push(t):t.children&&t.children instanceof Array&&t.children.forEach((t=>{this.isTabPanel(t)&&e.push(t)}))})),e}},directives:{ripple:t}};const f={class:"p-tabview-nav-container"},w=[l("span",{class:"pi pi-chevron-left"},null,-1)],x={ref:"nav",class:"p-tabview-nav",role:"tablist"},k=["onClick","onKeydown","tabindex","aria-selected"],y={key:0,class:"p-tabview-title"},m={ref:"inkbar",class:"p-tabview-ink-bar"},g=[l("span",{class:"pi pi-chevron-right"},null,-1)],B={class:"p-tabview-panels"},I={key:0,class:"p-tabview-panel",role:"tabpanel"};!function(e,t){void 0===t&&(t={});var n=t.insertAt;if(e&&"undefined"!=typeof document){var a=document.head||document.getElementsByTagName("head")[0],i=document.createElement("style");i.type="text/css","top"===n&&a.firstChild?a.insertBefore(i,a.firstChild):a.appendChild(i),i.styleSheet?i.styleSheet.cssText=e:i.appendChild(document.createTextNode(e))}}("\n.p-tabview-nav-container {\n position: relative;\n}\n.p-tabview-scrollable .p-tabview-nav-container {\n overflow: hidden;\n}\n.p-tabview-nav-content {\n overflow-x: auto;\n overflow-y: hidden;\n scroll-behavior: smooth;\n scrollbar-width: none;\n -ms-scroll-chaining: contain auto;\n overscroll-behavior: contain auto;\n}\n.p-tabview-nav {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n margin: 0;\n padding: 0;\n list-style-type: none;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n}\n.p-tabview-nav-link {\n cursor: pointer;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n position: relative;\n text-decoration: none;\n overflow: hidden;\n}\n.p-tabview-ink-bar {\n display: none;\n z-index: 1;\n}\n.p-tabview-nav-link:focus {\n z-index: 1;\n}\n.p-tabview-title {\n line-height: 1;\n white-space: nowrap;\n}\n.p-tabview-nav-btn {\n position: absolute;\n top: 0;\n z-index: 2;\n height: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n.p-tabview-nav-prev {\n left: 0;\n}\n.p-tabview-nav-next {\n right: 0;\n}\n.p-tabview-nav-content::-webkit-scrollbar {\n display: none;\n}\n"),u.render=function(e,t,u,C,T,$){const D=n("ripple");return a(),i("div",{class:s($.contentClasses)},[l("div",f,[u.scrollable&&!T.backwardIsDisabled?o((a(),i("button",{key:0,ref:"prevBtn",class:s($.prevButtonClasses),onClick:t[0]||(t[0]=(...e)=>$.navBackward&&$.navBackward(...e)),type:"button"},w,2)),[[D]]):r("",!0),l("div",{ref:"content",class:"p-tabview-nav-content",onScroll:t[1]||(t[1]=(...e)=>$.onScroll&&$.onScroll(...e))},[l("ul",x,[(a(!0),i(d,null,c($.tabs,((e,t)=>(a(),i("li",{role:"presentation",key:$.getKey(e,t),class:s([{"p-highlight":T.d_activeIndex===t,"p-disabled":$.isTabDisabled(e)}])},[o((a(),i("a",{role:"tab",class:"p-tabview-nav-link",onClick:e=>$.onTabClick(e,t),onKeydown:e=>$.onTabKeydown(e,t),tabindex:$.isTabDisabled(e)?null:"0","aria-selected":T.d_activeIndex===t},[e.props&&e.props.header?(a(),i("span",y,p(e.props.header),1)):r("",!0),e.children&&e.children.header?(a(),b(v(e.children.header),{key:1})):r("",!0)],40,k)),[[D]])],2)))),128)),l("li",m,null,512)],512)],544),u.scrollable&&!T.forwardIsDisabled?o((a(),i("button",{key:1,ref:"nextBtn",class:s($.nextButtonClasses),onClick:t[2]||(t[2]=(...e)=>$.navForward&&$.navForward(...e)),type:"button"},g,2)),[[D]]):r("",!0)]),l("div",B,[(a(!0),i(d,null,c($.tabs,((e,t)=>(a(),i(d,{key:$.getKey(e,t)},[u.lazy&&T.d_activeIndex!==t?r("",!0):o((a(),i("div",I,[(a(),b(v(e)))],512)),[[h,!!u.lazy||T.d_activeIndex===t]])],64)))),128))])],2)};export{u as default};
1
+ import{DomHandler as e,UniqueComponentId as t}from"primevue/utils";import n from"primevue/ripple";import{resolveDirective as a,openBlock as i,createElementBlock as s,normalizeClass as r,createElementVNode as o,withDirectives as l,mergeProps as d,createCommentVNode as c,Fragment as b,renderList as p,toDisplayString as h,createBlock as v,resolveDynamicComponent as u,vShow as f}from"vue";var x={name:"TabView",emits:["update:activeIndex","tab-change","tab-click"],props:{activeIndex:{type:Number,default:0},lazy:{type:Boolean,default:!1},scrollable:{type:Boolean,default:!1},tabindex:{type:Number,default:0},selectOnFocus:{type:Boolean,default:!1},previousButtonProps:null,nextButtonProps:null},data(){return{d_activeIndex:this.activeIndex,focusedTabIndex:-1,isPrevButtonDisabled:!0,isNextButtonDisabled:!1}},watch:{activeIndex(e){this.d_activeIndex=e,this.scrollInView({index:e})}},mounted(){this.updateInkBar()},updated(){this.updateInkBar()},methods:{isTabPanel:e=>"TabPanel"===e.type.name,isTabActive(e){return this.d_activeIndex===e},getTabProp:(e,t)=>e.props?e.props[t]:void 0,getKey(e,t){return this.getTabProp(e,"header")||t},getTabHeaderActionId(e){return`${this.id}_${e}_header_action`},getTabContentId(e){return`${this.id}_${e}_content`},onScroll(e){this.scrollable&&this.updateButtonState(),e.preventDefault()},onPrevButtonClick(){const t=this.$refs.content,n=e.getWidth(t)-this.getVisibleButtonWidths(),a=t.scrollLeft-n;t.scrollLeft=a<=0?0:a},onNextButtonClick(){const t=this.$refs.content,n=e.getWidth(t)-this.getVisibleButtonWidths(),a=t.scrollLeft+n,i=t.scrollWidth-n;t.scrollLeft=a>=i?i:a},onTabClick(e,t,n){this.changeActiveIndex(e,t,n),this.$emit("tab-click",{originalEvent:e,index:n})},onTabKeyDown(e,t,n){switch(e.code){case"ArrowLeft":this.onTabArrowLeftKey(e);break;case"ArrowRight":this.onTabArrowRightKey(e);break;case"Home":this.onTabHomeKey(e);break;case"End":this.onTabEndKey(e);break;case"PageDown":this.onPageDownKey(e);break;case"PageUp":this.onPageUpKey(e);break;case"Enter":case"Space":this.onTabEnterKey(e,t,n)}},onTabArrowRightKey(e){const t=this.findNextHeaderAction(e.target.parentElement);t?this.changeFocusedTab(e,t):this.onTabHomeKey(e),e.preventDefault()},onTabArrowLeftKey(e){const t=this.findPrevHeaderAction(e.target.parentElement);t?this.changeFocusedTab(e,t):this.onTabEndKey(e),e.preventDefault()},onTabHomeKey(e){const t=this.findFirstHeaderAction();this.changeFocusedTab(e,t),e.preventDefault()},onTabEndKey(e){const t=this.findLastHeaderAction();this.changeFocusedTab(e,t),e.preventDefault()},onPageDownKey(e){this.scrollInView({index:this.$refs.nav.children.length-2}),e.preventDefault()},onPageUpKey(e){this.scrollInView({index:0}),e.preventDefault()},onTabEnterKey(e,t,n){this.changeActiveIndex(e,t,n),e.preventDefault()},findNextHeaderAction(t,n=!1){const a=n?t:t.nextElementSibling;return a?e.hasClass(a,"p-disabled")||e.hasClass(a,"p-tabview-ink-bar")?this.findNextHeaderAction(a):e.findSingle(a,".p-tabview-header-action"):null},findPrevHeaderAction(t,n=!1){const a=n?t:t.previousElementSibling;return a?e.hasClass(a,"p-disabled")||e.hasClass(a,"p-tabview-ink-bar")?this.findPrevHeaderAction(a):e.findSingle(a,".p-tabview-header-action"):null},findFirstHeaderAction(){return this.findNextHeaderAction(this.$refs.nav.firstElementChild,!0)},findLastHeaderAction(){return this.findPrevHeaderAction(this.$refs.nav.lastElementChild,!0)},changeActiveIndex(e,t,n){this.getTabProp(t,"disabled")||this.d_activeIndex===n||(this.d_activeIndex=n,this.$emit("update:activeIndex",n),this.$emit("tab-change",{originalEvent:e,index:n}),this.scrollInView({index:n}))},changeFocusedTab(t,n){if(n&&(e.focus(n),this.scrollInView({element:n}),this.selectOnFocus)){const e=parseInt(n.parentElement.dataset.index,10),a=this.tabs[e];this.changeActiveIndex(t,a,e)}},scrollInView({element:e,index:t=-1}){const n=e||this.$refs.nav.children[t];n&&n.scrollIntoView&&n.scrollIntoView({block:"nearest"})},updateInkBar(){let t=this.$refs.nav.children[this.d_activeIndex];this.$refs.inkbar.style.width=e.getWidth(t)+"px",this.$refs.inkbar.style.left=e.getOffset(t).left-e.getOffset(this.$refs.nav).left+"px"},updateButtonState(){const t=this.$refs.content,{scrollLeft:n,scrollWidth:a}=t,i=e.getWidth(t);this.isPrevButtonDisabled=0===n,this.isNextButtonDisabled=parseInt(n)===a-i},getVisibleButtonWidths(){const{prevBtn:t,nextBtn:n}=this.$refs;return[t,n].reduce(((t,n)=>n?t+e.getWidth(n):t),0)},getTabHeaderClass(e,t){return["p-tabview-header",this.getTabProp(e,"headerClass"),{"p-highlight":this.d_activeIndex===t,"p-disabled":this.getTabProp(e,"disabled")}]},getTabContentClass(e){return["p-tabview-panel",this.getTabProp(e,"contentClass")]}},computed:{contentClasses(){return["p-tabview p-component",{"p-tabview-scrollable":this.scrollable}]},tabs(){return this.$slots.default().reduce(((e,t)=>(this.isTabPanel(t)?e.push(t):t.children&&t.children instanceof Array&&t.children.forEach((t=>{this.isTabPanel(t)&&e.push(t)})),e)),[])},prevButtonAriaLabel(){return this.$primevue.config.locale.aria?this.$primevue.config.locale.aria.previous:void 0},nextButtonAriaLabel(){return this.$primevue.config.locale.aria?this.$primevue.config.locale.aria.next:void 0},id(){return this.$attrs.id||t()}},directives:{ripple:n}};const g={class:"p-tabview-nav-container"},w=["tabindex","aria-label"],y=[o("span",{class:"pi pi-chevron-left","aria-hidden":"true"},null,-1)],m={ref:"nav",class:"p-tabview-nav",role:"tablist"},T=["data-index"],k=["id","tabindex","aria-disabled","aria-selected","aria-controls","onClick","onKeydown"],P={key:0,class:"p-tabview-title"},A={ref:"inkbar",class:"p-tabview-ink-bar",role:"presentation","aria-hidden":"true"},B=["tabindex","aria-label"],I=[o("span",{class:"pi pi-chevron-right","aria-hidden":"true"},null,-1)],C={class:"p-tabview-panels"},$=["aria-labelledby"];!function(e,t){void 0===t&&(t={});var n=t.insertAt;if(e&&"undefined"!=typeof document){var a=document.head||document.getElementsByTagName("head")[0],i=document.createElement("style");i.type="text/css","top"===n&&a.firstChild?a.insertBefore(i,a.firstChild):a.appendChild(i),i.styleSheet?i.styleSheet.cssText=e:i.appendChild(document.createTextNode(e))}}("\n.p-tabview-nav-container {\n position: relative;\n}\n.p-tabview-scrollable .p-tabview-nav-container {\n overflow: hidden;\n}\n.p-tabview-nav-content {\n overflow-x: auto;\n overflow-y: hidden;\n scroll-behavior: smooth;\n scrollbar-width: none;\n -ms-scroll-chaining: contain auto;\n overscroll-behavior: contain auto;\n}\n.p-tabview-nav {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n margin: 0;\n padding: 0;\n list-style-type: none;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n}\n.p-tabview-header-action {\n cursor: pointer;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n position: relative;\n text-decoration: none;\n overflow: hidden;\n}\n.p-tabview-ink-bar {\n display: none;\n z-index: 1;\n}\n.p-tabview-header-action:focus {\n z-index: 1;\n}\n.p-tabview-title {\n line-height: 1;\n white-space: nowrap;\n}\n.p-tabview-nav-btn {\n position: absolute;\n top: 0;\n z-index: 2;\n height: 100%;\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n.p-tabview-nav-prev {\n left: 0;\n}\n.p-tabview-nav-next {\n right: 0;\n}\n.p-tabview-nav-content::-webkit-scrollbar {\n display: none;\n}\n"),x.render=function(e,t,n,x,K,H){const D=a("ripple");return i(),s("div",{class:r(H.contentClasses)},[o("div",g,[n.scrollable&&!K.isPrevButtonDisabled?l((i(),s("button",d({key:0,ref:"prevBtn",type:"button",class:"p-tabview-nav-prev p-tabview-nav-btn p-link",tabindex:n.tabindex,"aria-label":H.prevButtonAriaLabel,onClick:t[0]||(t[0]=(...e)=>H.onPrevButtonClick&&H.onPrevButtonClick(...e))},n.previousButtonProps),y,16,w)),[[D]]):c("",!0),o("div",{ref:"content",class:"p-tabview-nav-content",onScroll:t[1]||(t[1]=(...e)=>H.onScroll&&H.onScroll(...e))},[o("ul",m,[(i(!0),s(b,null,p(H.tabs,((e,t)=>(i(),s("li",d({key:H.getKey(e,t),style:H.getTabProp(e,"headerStyle"),class:H.getTabHeaderClass(e,t),role:"presentation","data-index":t},H.getTabProp(e,"headerProps")),[l((i(),s("a",d({id:H.getTabHeaderActionId(t),class:"p-tabview-nav-link p-tabview-header-action",tabindex:H.getTabProp(e,"disabled")||!H.isTabActive(t)?-1:n.tabindex,role:"tab","aria-disabled":H.getTabProp(e,"disabled"),"aria-selected":H.isTabActive(t),"aria-controls":H.getTabContentId(t),onClick:n=>H.onTabClick(n,e,t),onKeydown:n=>H.onTabKeyDown(n,e,t)},H.getTabProp(e,"headerActionProps")),[e.props&&e.props.header?(i(),s("span",P,h(e.props.header),1)):c("",!0),e.children&&e.children.header?(i(),v(u(e.children.header),{key:1})):c("",!0)],16,k)),[[D]])],16,T)))),128)),o("li",A,null,512)],512)],544),n.scrollable&&!K.isNextButtonDisabled?l((i(),s("button",d({key:1,ref:"nextBtn",type:"button",class:"p-tabview-nav-next p-tabview-nav-btn p-link",tabindex:n.tabindex,"aria-label":H.nextButtonAriaLabel,onClick:t[2]||(t[2]=(...e)=>H.onNextButtonClick&&H.onNextButtonClick(...e))},n.nextButtonProps),I,16,B)),[[D]]):c("",!0)]),o("div",C,[(i(!0),s(b,null,p(H.tabs,((e,t)=>(i(),s(b,{key:H.getKey(e,t)},[!n.lazy||H.isTabActive(t)?l((i(),s("div",d({key:0,style:H.getTabProp(e,"contentStyle"),class:H.getTabContentClass(e),role:"tabpanel","aria-labelledby":H.getTabHeaderActionId(t)},H.getTabProp(e,"contentProps")),[(i(),v(u(e)))],16,$)),[[f,!!n.lazy||H.isTabActive(t)]]):c("",!0)],64)))),128))])],2)};export{x as default};