primevue 3.16.2 → 3.18.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 (824) hide show
  1. package/LICENSE.md +1 -1
  2. package/README.md +2 -1
  3. package/accordion/Accordion.d.ts +23 -5
  4. package/accordion/Accordion.vue +196 -79
  5. package/accordion/accordion.cjs.js +204 -98
  6. package/accordion/accordion.cjs.min.js +1 -1
  7. package/accordion/accordion.esm.js +202 -100
  8. package/accordion/accordion.esm.min.js +1 -1
  9. package/accordion/accordion.js +205 -100
  10. package/accordion/accordion.min.js +1 -1
  11. package/accordiontab/AccordionTab.d.ts +33 -5
  12. package/accordiontab/AccordionTab.vue +8 -1
  13. package/accordiontab/accordiontab.cjs.js +7 -0
  14. package/accordiontab/accordiontab.cjs.min.js +1 -1
  15. package/accordiontab/accordiontab.esm.js +7 -0
  16. package/accordiontab/accordiontab.esm.min.js +1 -1
  17. package/accordiontab/accordiontab.js +7 -0
  18. package/accordiontab/accordiontab.min.js +1 -1
  19. package/api/Api.d.ts +1 -1
  20. package/api/api.cjs.js +321 -313
  21. package/api/api.cjs.min.js +1 -1
  22. package/api/api.esm.js +321 -313
  23. package/api/api.esm.min.js +1 -1
  24. package/api/api.js +321 -313
  25. package/api/api.min.js +1 -1
  26. package/autocomplete/AutoComplete.d.ts +32 -17
  27. package/autocomplete/AutoComplete.vue +252 -131
  28. package/autocomplete/autocomplete.cjs.js +163 -118
  29. package/autocomplete/autocomplete.cjs.min.js +1 -1
  30. package/autocomplete/autocomplete.esm.js +161 -116
  31. package/autocomplete/autocomplete.esm.min.js +1 -1
  32. package/autocomplete/autocomplete.js +162 -117
  33. package/autocomplete/autocomplete.min.js +1 -1
  34. package/avatar/Avatar.d.ts +4 -4
  35. package/avatar/Avatar.vue +15 -11
  36. package/avatar/avatar.cjs.js +11 -7
  37. package/avatar/avatar.cjs.min.js +1 -1
  38. package/avatar/avatar.esm.js +11 -7
  39. package/avatar/avatar.esm.min.js +1 -1
  40. package/avatar/avatar.js +11 -7
  41. package/avatar/avatar.min.js +1 -1
  42. package/avatargroup/AvatarGroup.d.ts +6 -9
  43. package/avatargroup/AvatarGroup.vue +1 -1
  44. package/badge/Badge.d.ts +4 -5
  45. package/badge/Badge.vue +16 -13
  46. package/badge/badge.cjs.js +14 -11
  47. package/badge/badge.esm.js +14 -11
  48. package/badge/badge.js +14 -11
  49. package/badgedirective/badgedirective.cjs.js +8 -10
  50. package/badgedirective/badgedirective.esm.js +8 -10
  51. package/badgedirective/badgedirective.js +8 -10
  52. package/blockui/BlockUI.d.ts +6 -6
  53. package/blockui/BlockUI.vue +13 -15
  54. package/blockui/blockui.cjs.js +11 -13
  55. package/blockui/blockui.cjs.min.js +1 -1
  56. package/blockui/blockui.esm.js +11 -13
  57. package/blockui/blockui.esm.min.js +1 -1
  58. package/blockui/blockui.js +11 -13
  59. package/blockui/blockui.min.js +1 -1
  60. package/breadcrumb/Breadcrumb.d.ts +14 -7
  61. package/breadcrumb/Breadcrumb.vue +16 -7
  62. package/breadcrumb/BreadcrumbItem.vue +24 -15
  63. package/breadcrumb/breadcrumb.cjs.js +39 -25
  64. package/breadcrumb/breadcrumb.cjs.min.js +1 -1
  65. package/breadcrumb/breadcrumb.esm.js +39 -25
  66. package/breadcrumb/breadcrumb.esm.min.js +1 -1
  67. package/breadcrumb/breadcrumb.js +39 -25
  68. package/breadcrumb/breadcrumb.min.js +1 -1
  69. package/button/Button.d.ts +10 -7
  70. package/button/Button.vue +28 -17
  71. package/button/button.cjs.js +25 -14
  72. package/button/button.cjs.min.js +1 -1
  73. package/button/button.esm.js +25 -14
  74. package/button/button.esm.min.js +1 -1
  75. package/button/button.js +25 -14
  76. package/button/button.min.js +1 -1
  77. package/calendar/Calendar.d.ts +14 -14
  78. package/calendar/Calendar.vue +856 -601
  79. package/calendar/calendar.cjs.js +714 -614
  80. package/calendar/calendar.cjs.min.js +1 -1
  81. package/calendar/calendar.esm.js +712 -612
  82. package/calendar/calendar.esm.min.js +1 -1
  83. package/calendar/calendar.js +713 -613
  84. package/calendar/calendar.min.js +1 -1
  85. package/card/Card.d.ts +5 -7
  86. package/card/Card.vue +5 -5
  87. package/carousel/Carousel.d.ts +29 -19
  88. package/carousel/Carousel.vue +537 -528
  89. package/carousel/carousel.cjs.js +496 -493
  90. package/carousel/carousel.cjs.min.js +1 -1
  91. package/carousel/carousel.esm.js +496 -493
  92. package/carousel/carousel.esm.min.js +1 -1
  93. package/carousel/carousel.js +645 -642
  94. package/carousel/carousel.min.js +1 -1
  95. package/cascadeselect/CascadeSelect.d.ts +29 -14
  96. package/cascadeselect/CascadeSelect.vue +197 -102
  97. package/cascadeselect/CascadeSelectSub.vue +50 -15
  98. package/cascadeselect/cascadeselect.cjs.js +185 -111
  99. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  100. package/cascadeselect/cascadeselect.esm.js +184 -110
  101. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  102. package/cascadeselect/cascadeselect.js +185 -111
  103. package/cascadeselect/cascadeselect.min.js +1 -1
  104. package/chart/Chart.d.ts +6 -7
  105. package/chart/Chart.vue +12 -12
  106. package/chart/chart.cjs.js +11 -11
  107. package/chart/chart.cjs.min.js +1 -1
  108. package/chart/chart.esm.js +11 -11
  109. package/chart/chart.esm.min.js +1 -1
  110. package/chart/chart.js +11 -11
  111. package/chart/chart.min.js +1 -1
  112. package/checkbox/Checkbox.d.ts +12 -12
  113. package/checkbox/Checkbox.vue +48 -20
  114. package/checkbox/checkbox.cjs.js +28 -17
  115. package/checkbox/checkbox.cjs.min.js +1 -1
  116. package/checkbox/checkbox.esm.js +28 -17
  117. package/checkbox/checkbox.esm.min.js +1 -1
  118. package/checkbox/checkbox.js +28 -17
  119. package/checkbox/checkbox.min.js +1 -1
  120. package/chip/Chip.d.ts +5 -5
  121. package/chip/Chip.vue +13 -11
  122. package/chip/chip.cjs.js +7 -4
  123. package/chip/chip.esm.js +7 -4
  124. package/chip/chip.js +7 -4
  125. package/chips/Chips.d.ts +9 -9
  126. package/chips/Chips.vue +89 -33
  127. package/chips/chips.cjs.js +48 -26
  128. package/chips/chips.cjs.min.js +1 -1
  129. package/chips/chips.esm.js +48 -26
  130. package/chips/chips.esm.min.js +1 -1
  131. package/chips/chips.js +48 -26
  132. package/chips/chips.min.js +1 -1
  133. package/colorpicker/ColorPicker.d.ts +11 -12
  134. package/colorpicker/ColorPicker.vue +146 -110
  135. package/colorpicker/colorpicker.cjs.js +113 -74
  136. package/colorpicker/colorpicker.cjs.min.js +1 -1
  137. package/colorpicker/colorpicker.esm.js +113 -74
  138. package/colorpicker/colorpicker.esm.min.js +1 -1
  139. package/colorpicker/colorpicker.js +113 -74
  140. package/colorpicker/colorpicker.min.js +1 -1
  141. package/column/Column.d.ts +5 -6
  142. package/column/Column.vue +1 -1
  143. package/columngroup/ColumnGroup.d.ts +5 -7
  144. package/columngroup/ColumnGroup.vue +1 -1
  145. package/config/PrimeVue.d.ts +8 -3
  146. package/config/config.cjs.js +18 -30
  147. package/config/config.cjs.min.js +1 -1
  148. package/config/config.esm.js +18 -30
  149. package/config/config.esm.min.js +1 -1
  150. package/config/config.js +19 -31
  151. package/config/config.min.js +1 -1
  152. package/confirmationoptions/ConfirmationOptions.d.ts +4 -0
  153. package/confirmationservice/confirmationservice.cjs.js +1 -0
  154. package/confirmationservice/confirmationservice.esm.js +1 -0
  155. package/confirmationservice/confirmationservice.js +1 -0
  156. package/confirmdialog/ConfirmDialog.d.ts +11 -5
  157. package/confirmdialog/ConfirmDialog.vue +25 -15
  158. package/confirmdialog/confirmdialog.cjs.js +34 -16
  159. package/confirmdialog/confirmdialog.cjs.min.js +1 -1
  160. package/confirmdialog/confirmdialog.esm.js +34 -16
  161. package/confirmdialog/confirmdialog.esm.min.js +1 -1
  162. package/confirmdialog/confirmdialog.js +35 -17
  163. package/confirmdialog/confirmdialog.min.js +1 -1
  164. package/confirmpopup/ConfirmPopup.d.ts +5 -8
  165. package/confirmpopup/ConfirmPopup.vue +44 -32
  166. package/confirmpopup/confirmpopup.cjs.js +24 -14
  167. package/confirmpopup/confirmpopup.cjs.min.js +1 -1
  168. package/confirmpopup/confirmpopup.esm.js +24 -14
  169. package/confirmpopup/confirmpopup.esm.min.js +1 -1
  170. package/confirmpopup/confirmpopup.js +24 -14
  171. package/confirmpopup/confirmpopup.min.js +1 -1
  172. package/contextmenu/ContextMenu.d.ts +43 -5
  173. package/contextmenu/ContextMenu.vue +449 -38
  174. package/contextmenu/ContextMenuSub.vue +134 -101
  175. package/contextmenu/contextmenu.cjs.js +639 -206
  176. package/contextmenu/contextmenu.cjs.min.js +1 -1
  177. package/contextmenu/contextmenu.esm.js +640 -207
  178. package/contextmenu/contextmenu.esm.min.js +1 -1
  179. package/contextmenu/contextmenu.js +640 -207
  180. package/contextmenu/contextmenu.min.js +1 -1
  181. package/core/core.js +2984 -2116
  182. package/core/core.min.js +16 -16
  183. package/datatable/BodyCell.vue +93 -75
  184. package/datatable/ColumnFilter.vue +137 -86
  185. package/datatable/DataTable.d.ts +25 -26
  186. package/datatable/DataTable.vue +472 -298
  187. package/datatable/FooterCell.vue +20 -13
  188. package/datatable/HeaderCell.vue +108 -51
  189. package/datatable/HeaderCheckbox.vue +12 -5
  190. package/datatable/RowCheckbox.vue +14 -6
  191. package/datatable/RowRadioButton.vue +4 -4
  192. package/datatable/TableBody.vue +135 -83
  193. package/datatable/TableFooter.vue +17 -20
  194. package/datatable/TableHeader.vue +132 -52
  195. package/datatable/TableLoadingBody.vue +3 -3
  196. package/datatable/datatable.cjs.js +2674 -2537
  197. package/datatable/datatable.cjs.min.js +1 -1
  198. package/datatable/datatable.esm.js +2676 -2539
  199. package/datatable/datatable.esm.min.js +1 -1
  200. package/datatable/datatable.js +2676 -2539
  201. package/datatable/datatable.min.js +1 -1
  202. package/dataview/DataView.d.ts +8 -8
  203. package/dataview/DataView.vue +80 -66
  204. package/dataview/dataview.cjs.js +31 -35
  205. package/dataview/dataview.cjs.min.js +1 -1
  206. package/dataview/dataview.esm.js +31 -35
  207. package/dataview/dataview.esm.min.js +1 -1
  208. package/dataview/dataview.js +31 -35
  209. package/dataview/dataview.min.js +1 -1
  210. package/dataviewlayoutoptions/DataViewLayoutOptions.d.ts +5 -6
  211. package/dataviewlayoutoptions/DataViewLayoutOptions.vue +28 -34
  212. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.js +19 -25
  213. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.min.js +1 -1
  214. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.js +19 -25
  215. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.min.js +1 -1
  216. package/dataviewlayoutoptions/dataviewlayoutoptions.js +46 -52
  217. package/dataviewlayoutoptions/dataviewlayoutoptions.min.js +1 -1
  218. package/deferredcontent/DeferredContent.d.ts +6 -7
  219. package/deferredcontent/DeferredContent.vue +6 -9
  220. package/deferredcontent/deferredcontent.cjs.js +5 -8
  221. package/deferredcontent/deferredcontent.esm.js +5 -8
  222. package/deferredcontent/deferredcontent.js +5 -8
  223. package/dialog/Dialog.d.ts +10 -10
  224. package/dialog/Dialog.vue +64 -60
  225. package/dialog/dialog.cjs.js +50 -46
  226. package/dialog/dialog.cjs.min.js +1 -1
  227. package/dialog/dialog.esm.js +50 -46
  228. package/dialog/dialog.esm.min.js +1 -1
  229. package/dialog/dialog.js +50 -46
  230. package/dialog/dialog.min.js +1 -1
  231. package/divider/Divider.d.ts +4 -5
  232. package/divider/Divider.vue +15 -12
  233. package/divider/divider.cjs.js +17 -12
  234. package/divider/divider.cjs.min.js +1 -1
  235. package/divider/divider.esm.js +17 -12
  236. package/divider/divider.esm.min.js +1 -1
  237. package/divider/divider.js +17 -12
  238. package/divider/divider.min.js +1 -1
  239. package/dock/Dock.d.ts +36 -6
  240. package/dock/Dock.vue +21 -5
  241. package/dock/DockSub.vue +229 -55
  242. package/dock/dock.cjs.js +284 -106
  243. package/dock/dock.cjs.min.js +1 -1
  244. package/dock/dock.esm.js +284 -106
  245. package/dock/dock.esm.min.js +1 -1
  246. package/dock/dock.js +285 -108
  247. package/dock/dock.min.js +1 -1
  248. package/dropdown/Dropdown.d.ts +46 -17
  249. package/dropdown/Dropdown.vue +271 -129
  250. package/dropdown/dropdown.cjs.js +213 -132
  251. package/dropdown/dropdown.cjs.min.js +1 -1
  252. package/dropdown/dropdown.esm.js +212 -131
  253. package/dropdown/dropdown.esm.min.js +1 -1
  254. package/dropdown/dropdown.js +212 -131
  255. package/dropdown/dropdown.min.js +1 -1
  256. package/dynamicdialog/DynamicDialog.d.ts +4 -4
  257. package/dynamicdialog/DynamicDialog.vue +10 -10
  258. package/dynamicdialog/dynamicdialog.cjs.js +11 -9
  259. package/dynamicdialog/dynamicdialog.cjs.min.js +1 -1
  260. package/dynamicdialog/dynamicdialog.esm.js +11 -9
  261. package/dynamicdialog/dynamicdialog.esm.min.js +1 -1
  262. package/dynamicdialog/dynamicdialog.js +11 -9
  263. package/dynamicdialog/dynamicdialog.min.js +1 -1
  264. package/editor/Editor.d.ts +20 -4
  265. package/editor/Editor.vue +506 -466
  266. package/editor/editor.cjs.js +99 -45
  267. package/editor/editor.cjs.min.js +1 -1
  268. package/editor/editor.esm.js +82 -42
  269. package/editor/editor.esm.min.js +1 -1
  270. package/editor/editor.js +83 -47
  271. package/editor/editor.min.js +1 -1
  272. package/fieldset/Fieldset.d.ts +9 -5
  273. package/fieldset/Fieldset.vue +28 -20
  274. package/fieldset/fieldset.cjs.js +31 -19
  275. package/fieldset/fieldset.cjs.min.js +1 -1
  276. package/fieldset/fieldset.esm.js +32 -20
  277. package/fieldset/fieldset.esm.min.js +1 -1
  278. package/fieldset/fieldset.js +31 -19
  279. package/fieldset/fieldset.min.js +1 -1
  280. package/fileupload/FileContent.vue +51 -0
  281. package/fileupload/FileUpload.d.ts +32 -12
  282. package/fileupload/FileUpload.vue +122 -102
  283. package/fileupload/fileupload.cjs.js +265 -160
  284. package/fileupload/fileupload.cjs.min.js +1 -1
  285. package/fileupload/fileupload.esm.js +265 -160
  286. package/fileupload/fileupload.esm.min.js +1 -1
  287. package/fileupload/fileupload.js +265 -160
  288. package/fileupload/fileupload.min.js +1 -1
  289. package/fullcalendar/FullCalendar.d.ts +5 -7
  290. package/fullcalendar/FullCalendar.vue +6 -6
  291. package/fullcalendar/fullcalendar.cjs.js +3 -2
  292. package/fullcalendar/fullcalendar.esm.js +3 -2
  293. package/fullcalendar/fullcalendar.js +3 -2
  294. package/galleria/Galleria.d.ts +4 -4
  295. package/galleria/Galleria.vue +39 -34
  296. package/galleria/GalleriaContent.vue +58 -31
  297. package/galleria/GalleriaItem.vue +44 -36
  298. package/galleria/GalleriaItemSlot.vue +2 -1
  299. package/galleria/GalleriaThumbnails.vue +108 -92
  300. package/galleria/galleria.cjs.js +181 -153
  301. package/galleria/galleria.cjs.min.js +1 -1
  302. package/galleria/galleria.esm.js +181 -153
  303. package/galleria/galleria.esm.min.js +1 -1
  304. package/galleria/galleria.js +181 -153
  305. package/galleria/galleria.min.js +1 -1
  306. package/image/Image.d.ts +4 -5
  307. package/image/Image.vue +19 -15
  308. package/image/image.cjs.js +11 -7
  309. package/image/image.cjs.min.js +1 -1
  310. package/image/image.esm.js +11 -7
  311. package/image/image.esm.min.js +1 -1
  312. package/image/image.js +11 -7
  313. package/image/image.min.js +1 -1
  314. package/inlinemessage/InlineMessage.d.ts +4 -5
  315. package/inlinemessage/InlineMessage.vue +12 -9
  316. package/inlinemessage/inlinemessage.cjs.js +12 -10
  317. package/inlinemessage/inlinemessage.cjs.min.js +1 -1
  318. package/inlinemessage/inlinemessage.esm.js +12 -10
  319. package/inlinemessage/inlinemessage.esm.min.js +1 -1
  320. package/inlinemessage/inlinemessage.js +12 -10
  321. package/inlinemessage/inlinemessage.min.js +1 -1
  322. package/inplace/Inplace.d.ts +6 -6
  323. package/inplace/Inplace.vue +11 -11
  324. package/inplace/inplace.cjs.js +9 -9
  325. package/inplace/inplace.cjs.min.js +1 -1
  326. package/inplace/inplace.esm.js +9 -9
  327. package/inplace/inplace.esm.min.js +1 -1
  328. package/inplace/inplace.js +9 -9
  329. package/inplace/inplace.min.js +1 -1
  330. package/inputmask/InputMask.d.ts +11 -12
  331. package/inputmask/InputMask.vue +119 -92
  332. package/inputmask/inputmask.cjs.js +116 -89
  333. package/inputmask/inputmask.cjs.min.js +1 -1
  334. package/inputmask/inputmask.esm.js +116 -89
  335. package/inputmask/inputmask.esm.min.js +1 -1
  336. package/inputmask/inputmask.js +116 -89
  337. package/inputmask/inputmask.min.js +1 -1
  338. package/inputnumber/InputNumber.d.ts +17 -17
  339. package/inputnumber/InputNumber.vue +247 -180
  340. package/inputnumber/inputnumber.cjs.js +219 -175
  341. package/inputnumber/inputnumber.cjs.min.js +1 -1
  342. package/inputnumber/inputnumber.esm.js +218 -174
  343. package/inputnumber/inputnumber.esm.min.js +1 -1
  344. package/inputnumber/inputnumber.js +219 -176
  345. package/inputnumber/inputnumber.min.js +1 -1
  346. package/inputswitch/InputSwitch.d.ts +10 -10
  347. package/inputswitch/InputSwitch.vue +39 -11
  348. package/inputswitch/inputswitch.cjs.js +23 -9
  349. package/inputswitch/inputswitch.cjs.min.js +1 -1
  350. package/inputswitch/inputswitch.esm.js +23 -9
  351. package/inputswitch/inputswitch.esm.min.js +1 -1
  352. package/inputswitch/inputswitch.js +23 -9
  353. package/inputswitch/inputswitch.min.js +1 -1
  354. package/inputtext/InputText.d.ts +5 -6
  355. package/inputtext/InputText.vue +3 -3
  356. package/inputtext/inputtext.cjs.js +2 -2
  357. package/inputtext/inputtext.esm.js +2 -2
  358. package/inputtext/inputtext.js +2 -2
  359. package/knob/Knob.d.ts +10 -11
  360. package/knob/Knob.vue +47 -29
  361. package/knob/knob.cjs.js +27 -25
  362. package/knob/knob.cjs.min.js +1 -1
  363. package/knob/knob.esm.js +27 -25
  364. package/knob/knob.esm.min.js +1 -1
  365. package/knob/knob.js +27 -25
  366. package/knob/knob.min.js +1 -1
  367. package/listbox/Listbox.d.ts +22 -13
  368. package/listbox/Listbox.vue +149 -98
  369. package/listbox/listbox.cjs.js +121 -106
  370. package/listbox/listbox.cjs.min.js +1 -1
  371. package/listbox/listbox.esm.js +122 -107
  372. package/listbox/listbox.esm.min.js +1 -1
  373. package/listbox/listbox.js +121 -106
  374. package/listbox/listbox.min.js +1 -1
  375. package/megamenu/MegaMenu.d.ts +32 -6
  376. package/megamenu/MegaMenu.vue +510 -238
  377. package/megamenu/MegaMenuSub.vue +231 -0
  378. package/megamenu/megamenu.cjs.js +837 -391
  379. package/megamenu/megamenu.cjs.min.js +1 -1
  380. package/megamenu/megamenu.esm.js +839 -393
  381. package/megamenu/megamenu.esm.min.js +1 -1
  382. package/megamenu/megamenu.js +837 -391
  383. package/megamenu/megamenu.min.js +1 -1
  384. package/menu/Menu.d.ts +28 -8
  385. package/menu/Menu.vue +204 -34
  386. package/menu/Menuitem.vue +48 -38
  387. package/menu/menu.cjs.js +325 -137
  388. package/menu/menu.cjs.min.js +1 -1
  389. package/menu/menu.esm.js +325 -137
  390. package/menu/menu.esm.min.js +1 -1
  391. package/menu/menu.js +325 -137
  392. package/menu/menu.min.js +1 -1
  393. package/menubar/Menubar.d.ts +19 -8
  394. package/menubar/Menubar.vue +536 -26
  395. package/menubar/MenubarSub.vue +123 -239
  396. package/menubar/menubar.cjs.js +708 -335
  397. package/menubar/menubar.cjs.min.js +1 -1
  398. package/menubar/menubar.esm.js +710 -337
  399. package/menubar/menubar.esm.min.js +1 -1
  400. package/menubar/menubar.js +708 -335
  401. package/menubar/menubar.min.js +1 -1
  402. package/menuitem/MenuItem.d.ts +2 -2
  403. package/message/Message.d.ts +5 -5
  404. package/message/Message.vue +19 -14
  405. package/message/message.cjs.js +15 -10
  406. package/message/message.cjs.min.js +1 -1
  407. package/message/message.esm.js +15 -10
  408. package/message/message.esm.min.js +1 -1
  409. package/message/message.js +15 -10
  410. package/message/message.min.js +1 -1
  411. package/multiselect/MultiSelect.d.ts +46 -16
  412. package/multiselect/MultiSelect.vue +266 -156
  413. package/multiselect/multiselect.cjs.js +239 -167
  414. package/multiselect/multiselect.cjs.min.js +1 -1
  415. package/multiselect/multiselect.esm.js +238 -166
  416. package/multiselect/multiselect.esm.min.js +1 -1
  417. package/multiselect/multiselect.js +238 -166
  418. package/multiselect/multiselect.min.js +1 -1
  419. package/orderlist/OrderList.d.ts +5 -5
  420. package/orderlist/OrderList.vue +65 -60
  421. package/orderlist/orderlist.cjs.js +51 -53
  422. package/orderlist/orderlist.esm.js +51 -53
  423. package/orderlist/orderlist.js +51 -53
  424. package/organizationchart/OrganizationChart.d.ts +4 -4
  425. package/organizationchart/OrganizationChart.vue +13 -17
  426. package/organizationchart/OrganizationChartNode.vue +20 -12
  427. package/organizationchart/organizationchart.cjs.js +14 -16
  428. package/organizationchart/organizationchart.cjs.min.js +1 -1
  429. package/organizationchart/organizationchart.esm.js +14 -16
  430. package/organizationchart/organizationchart.esm.min.js +1 -1
  431. package/organizationchart/organizationchart.js +14 -16
  432. package/organizationchart/organizationchart.min.js +1 -1
  433. package/overlaypanel/OverlayPanel.d.ts +5 -5
  434. package/overlaypanel/OverlayPanel.vue +60 -50
  435. package/overlaypanel/overlaypanel.cjs.js +40 -32
  436. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  437. package/overlaypanel/overlaypanel.esm.js +40 -32
  438. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  439. package/overlaypanel/overlaypanel.js +40 -32
  440. package/overlaypanel/overlaypanel.min.js +1 -1
  441. package/package.json +3 -3
  442. package/paginator/CurrentPageReport.vue +47 -47
  443. package/paginator/FirstPageLink.vue +11 -8
  444. package/paginator/JumpToPageDropdown.vue +7 -6
  445. package/paginator/JumpToPageInput.vue +3 -3
  446. package/paginator/LastPageLink.vue +11 -8
  447. package/paginator/NextPageLink.vue +11 -8
  448. package/paginator/PageLinks.vue +3 -4
  449. package/paginator/Paginator.d.ts +7 -7
  450. package/paginator/Paginator.vue +144 -49
  451. package/paginator/PrevPageLink.vue +11 -8
  452. package/paginator/RowsPerPageDropdown.vue +7 -6
  453. package/paginator/paginator.cjs.js +373 -259
  454. package/paginator/paginator.cjs.min.js +1 -1
  455. package/paginator/paginator.esm.js +374 -260
  456. package/paginator/paginator.esm.min.js +1 -1
  457. package/paginator/paginator.js +651 -538
  458. package/paginator/paginator.min.js +1 -1
  459. package/panel/Panel.d.ts +9 -5
  460. package/panel/Panel.vue +29 -11
  461. package/panel/panel.cjs.js +24 -14
  462. package/panel/panel.cjs.min.js +1 -1
  463. package/panel/panel.esm.js +24 -14
  464. package/panel/panel.esm.min.js +1 -1
  465. package/panel/panel.js +24 -14
  466. package/panel/panel.min.js +1 -1
  467. package/panelmenu/PanelMenu.d.ts +37 -6
  468. package/panelmenu/PanelMenu.vue +202 -88
  469. package/panelmenu/PanelMenuList.vue +335 -0
  470. package/panelmenu/PanelMenuSub.vue +130 -80
  471. package/panelmenu/panelmenu.cjs.js +1385 -283
  472. package/panelmenu/panelmenu.cjs.min.js +1 -1
  473. package/panelmenu/panelmenu.esm.js +1382 -284
  474. package/panelmenu/panelmenu.esm.min.js +1 -1
  475. package/panelmenu/panelmenu.js +1385 -284
  476. package/panelmenu/panelmenu.min.js +1 -1
  477. package/password/Password.d.ts +12 -7
  478. package/password/Password.vue +158 -80
  479. package/password/password.cjs.js +140 -78
  480. package/password/password.cjs.min.js +1 -1
  481. package/password/password.esm.js +139 -77
  482. package/password/password.esm.min.js +1 -1
  483. package/password/password.js +140 -78
  484. package/password/password.min.js +1 -1
  485. package/picklist/PickList.d.ts +9 -9
  486. package/picklist/PickList.vue +99 -78
  487. package/picklist/picklist.cjs.js +71 -66
  488. package/picklist/picklist.cjs.min.js +1 -1
  489. package/picklist/picklist.esm.js +71 -66
  490. package/picklist/picklist.esm.min.js +1 -1
  491. package/picklist/picklist.js +71 -66
  492. package/picklist/picklist.min.js +1 -1
  493. package/portal/Portal.d.ts +3 -3
  494. package/portal/Portal.vue +2 -2
  495. package/portal/portal.cjs.js +1 -1
  496. package/portal/portal.esm.js +1 -1
  497. package/portal/portal.js +1 -1
  498. package/progressbar/ProgressBar.d.ts +4 -5
  499. package/progressbar/ProgressBar.vue +63 -51
  500. package/progressbar/progressbar.cjs.js +2 -2
  501. package/progressbar/progressbar.cjs.min.js +1 -1
  502. package/progressbar/progressbar.esm.js +2 -2
  503. package/progressbar/progressbar.esm.min.js +1 -1
  504. package/progressbar/progressbar.js +2 -2
  505. package/progressbar/progressbar.min.js +1 -1
  506. package/progressspinner/ProgressSpinner.d.ts +5 -7
  507. package/progressspinner/ProgressSpinner.vue +1 -1
  508. package/radiobutton/RadioButton.d.ts +9 -9
  509. package/radiobutton/RadioButton.vue +41 -13
  510. package/radiobutton/radiobutton.cjs.js +24 -10
  511. package/radiobutton/radiobutton.cjs.min.js +1 -1
  512. package/radiobutton/radiobutton.esm.js +24 -10
  513. package/radiobutton/radiobutton.esm.min.js +1 -1
  514. package/radiobutton/radiobutton.js +24 -10
  515. package/radiobutton/radiobutton.min.js +1 -1
  516. package/rating/Rating.d.ts +54 -5
  517. package/rating/Rating.vue +88 -62
  518. package/rating/rating.cjs.js +105 -84
  519. package/rating/rating.cjs.min.js +1 -1
  520. package/rating/rating.esm.js +106 -85
  521. package/rating/rating.esm.min.js +1 -1
  522. package/rating/rating.js +106 -86
  523. package/rating/rating.min.js +1 -1
  524. package/resources/primevue.css +21 -2
  525. package/resources/primevue.min.css +1 -1
  526. package/resources/themes/arya-blue/theme.css +340 -282
  527. package/resources/themes/arya-green/theme.css +340 -282
  528. package/resources/themes/arya-orange/theme.css +340 -282
  529. package/resources/themes/arya-purple/theme.css +340 -282
  530. package/resources/themes/bootstrap4-dark-blue/theme.css +356 -298
  531. package/resources/themes/bootstrap4-dark-purple/theme.css +356 -298
  532. package/resources/themes/bootstrap4-light-blue/theme.css +369 -311
  533. package/resources/themes/bootstrap4-light-purple/theme.css +369 -311
  534. package/resources/themes/fluent-light/theme.css +350 -292
  535. package/resources/themes/lara-dark-blue/theme.css +343 -285
  536. package/resources/themes/lara-dark-indigo/theme.css +343 -285
  537. package/resources/themes/lara-dark-purple/theme.css +343 -285
  538. package/resources/themes/lara-dark-teal/theme.css +343 -285
  539. package/resources/themes/lara-light-blue/theme.css +367 -309
  540. package/resources/themes/lara-light-indigo/theme.css +367 -309
  541. package/resources/themes/lara-light-purple/theme.css +367 -309
  542. package/resources/themes/lara-light-teal/theme.css +367 -309
  543. package/resources/themes/luna-amber/theme.css +372 -314
  544. package/resources/themes/luna-blue/theme.css +372 -314
  545. package/resources/themes/luna-green/theme.css +372 -314
  546. package/resources/themes/luna-pink/theme.css +372 -314
  547. package/resources/themes/md-dark-deeppurple/theme.css +413 -318
  548. package/resources/themes/md-dark-indigo/theme.css +413 -318
  549. package/resources/themes/md-light-deeppurple/theme.css +413 -318
  550. package/resources/themes/md-light-indigo/theme.css +413 -318
  551. package/resources/themes/mdc-dark-deeppurple/theme.css +413 -318
  552. package/resources/themes/mdc-dark-indigo/theme.css +413 -318
  553. package/resources/themes/mdc-light-deeppurple/theme.css +413 -318
  554. package/resources/themes/mdc-light-indigo/theme.css +413 -318
  555. package/resources/themes/nova/theme.css +336 -278
  556. package/resources/themes/nova-accent/theme.css +335 -277
  557. package/resources/themes/nova-alt/theme.css +336 -278
  558. package/resources/themes/nova-vue/theme.css +336 -278
  559. package/resources/themes/rhea/theme.css +335 -277
  560. package/resources/themes/saga-blue/theme.css +347 -289
  561. package/resources/themes/saga-green/theme.css +347 -289
  562. package/resources/themes/saga-orange/theme.css +347 -289
  563. package/resources/themes/saga-purple/theme.css +347 -289
  564. package/resources/themes/tailwind-light/theme.css +359 -301
  565. package/resources/themes/vela-blue/theme.css +347 -289
  566. package/resources/themes/vela-green/theme.css +347 -289
  567. package/resources/themes/vela-orange/theme.css +347 -289
  568. package/resources/themes/vela-purple/theme.css +347 -289
  569. package/ripple/ripple.cjs.js +19 -1
  570. package/ripple/ripple.cjs.min.js +1 -1
  571. package/ripple/ripple.esm.js +19 -1
  572. package/ripple/ripple.esm.min.js +1 -1
  573. package/ripple/ripple.js +19 -1
  574. package/ripple/ripple.min.js +1 -1
  575. package/row/Row.d.ts +6 -9
  576. package/row/Row.vue +1 -1
  577. package/scrollpanel/ScrollPanel.d.ts +9 -5
  578. package/scrollpanel/ScrollPanel.vue +194 -56
  579. package/scrollpanel/scrollpanel.cjs.js +180 -56
  580. package/scrollpanel/scrollpanel.cjs.min.js +1 -1
  581. package/scrollpanel/scrollpanel.esm.js +181 -57
  582. package/scrollpanel/scrollpanel.esm.min.js +1 -1
  583. package/scrollpanel/scrollpanel.js +180 -56
  584. package/scrollpanel/scrollpanel.min.js +1 -1
  585. package/scrolltop/ScrollTop.d.ts +5 -7
  586. package/scrolltop/ScrollTop.vue +18 -23
  587. package/scrolltop/scrolltop.cjs.js +14 -19
  588. package/scrolltop/scrolltop.cjs.min.js +1 -1
  589. package/scrolltop/scrolltop.esm.js +14 -19
  590. package/scrolltop/scrolltop.esm.min.js +1 -1
  591. package/scrolltop/scrolltop.js +14 -19
  592. package/scrolltop/scrolltop.min.js +1 -1
  593. package/selectbutton/SelectButton.d.ts +11 -11
  594. package/selectbutton/SelectButton.vue +50 -32
  595. package/selectbutton/selectbutton.cjs.js +30 -25
  596. package/selectbutton/selectbutton.esm.js +30 -25
  597. package/selectbutton/selectbutton.js +30 -25
  598. package/sidebar/Sidebar.d.ts +6 -6
  599. package/sidebar/Sidebar.vue +24 -14
  600. package/sidebar/sidebar.cjs.js +20 -10
  601. package/sidebar/sidebar.cjs.min.js +1 -1
  602. package/sidebar/sidebar.esm.js +20 -10
  603. package/sidebar/sidebar.esm.min.js +1 -1
  604. package/sidebar/sidebar.js +20 -10
  605. package/sidebar/sidebar.min.js +1 -1
  606. package/skeleton/Skeleton.d.ts +5 -7
  607. package/skeleton/Skeleton.vue +12 -11
  608. package/skeleton/skeleton.cjs.js +10 -9
  609. package/skeleton/skeleton.cjs.min.js +1 -1
  610. package/skeleton/skeleton.esm.js +10 -9
  611. package/skeleton/skeleton.esm.min.js +1 -1
  612. package/skeleton/skeleton.js +10 -9
  613. package/skeleton/skeleton.min.js +1 -1
  614. package/slider/Slider.d.ts +7 -8
  615. package/slider/Slider.vue +162 -141
  616. package/slider/slider.cjs.js +100 -127
  617. package/slider/slider.cjs.min.js +1 -1
  618. package/slider/slider.esm.js +100 -127
  619. package/slider/slider.esm.min.js +1 -1
  620. package/slider/slider.js +100 -127
  621. package/slider/slider.min.js +1 -1
  622. package/speeddial/SpeedDial.d.ts +8 -8
  623. package/speeddial/SpeedDial.vue +66 -46
  624. package/speeddial/speeddial.cjs.js +77 -62
  625. package/speeddial/speeddial.cjs.min.js +1 -1
  626. package/speeddial/speeddial.esm.js +77 -62
  627. package/speeddial/speeddial.esm.min.js +1 -1
  628. package/speeddial/speeddial.js +77 -62
  629. package/speeddial/speeddial.min.js +1 -1
  630. package/splitbutton/SplitButton.d.ts +6 -6
  631. package/splitbutton/SplitButton.vue +9 -11
  632. package/splitbutton/splitbutton.cjs.js +7 -7
  633. package/splitbutton/splitbutton.cjs.min.js +1 -1
  634. package/splitbutton/splitbutton.esm.js +7 -7
  635. package/splitbutton/splitbutton.esm.min.js +1 -1
  636. package/splitbutton/splitbutton.js +7 -7
  637. package/splitbutton/splitbutton.min.js +1 -1
  638. package/splitter/Splitter.d.ts +10 -5
  639. package/splitter/Splitter.vue +158 -53
  640. package/splitter/splitter.cjs.js +156 -52
  641. package/splitter/splitter.cjs.min.js +1 -1
  642. package/splitter/splitter.esm.js +157 -53
  643. package/splitter/splitter.esm.min.js +1 -1
  644. package/splitter/splitter.js +156 -52
  645. package/splitter/splitter.min.js +1 -1
  646. package/splitterpanel/SplitterPanel.d.ts +4 -5
  647. package/splitterpanel/SplitterPanel.vue +3 -3
  648. package/splitterpanel/splitterpanel.cjs.js +2 -2
  649. package/splitterpanel/splitterpanel.esm.js +2 -2
  650. package/splitterpanel/splitterpanel.js +2 -2
  651. package/steps/Steps.d.ts +4 -5
  652. package/steps/Steps.vue +137 -30
  653. package/steps/steps.cjs.js +135 -36
  654. package/steps/steps.cjs.min.js +1 -1
  655. package/steps/steps.esm.js +136 -37
  656. package/steps/steps.esm.min.js +1 -1
  657. package/steps/steps.js +135 -36
  658. package/steps/steps.min.js +1 -1
  659. package/styleclass/styleclass.cjs.js +20 -22
  660. package/styleclass/styleclass.cjs.min.js +1 -1
  661. package/styleclass/styleclass.esm.js +20 -22
  662. package/styleclass/styleclass.esm.min.js +1 -1
  663. package/styleclass/styleclass.js +20 -22
  664. package/styleclass/styleclass.min.js +1 -1
  665. package/tabmenu/TabMenu.d.ts +13 -5
  666. package/tabmenu/TabMenu.vue +176 -36
  667. package/tabmenu/tabmenu.cjs.js +173 -42
  668. package/tabmenu/tabmenu.cjs.min.js +1 -1
  669. package/tabmenu/tabmenu.esm.js +173 -42
  670. package/tabmenu/tabmenu.esm.min.js +1 -1
  671. package/tabmenu/tabmenu.js +174 -43
  672. package/tabmenu/tabmenu.min.js +1 -1
  673. package/tabpanel/TabPanel.d.ts +33 -6
  674. package/tabpanel/TabPanel.vue +8 -1
  675. package/tabpanel/tabpanel.cjs.js +7 -0
  676. package/tabpanel/tabpanel.cjs.min.js +1 -1
  677. package/tabpanel/tabpanel.esm.js +7 -0
  678. package/tabpanel/tabpanel.esm.min.js +1 -1
  679. package/tabpanel/tabpanel.js +7 -0
  680. package/tabpanel/tabpanel.min.js +1 -1
  681. package/tabview/TabView.d.ts +22 -6
  682. package/tabview/TabView.vue +280 -96
  683. package/tabview/tabview.cjs.js +295 -132
  684. package/tabview/tabview.cjs.min.js +1 -1
  685. package/tabview/tabview.esm.js +296 -133
  686. package/tabview/tabview.esm.min.js +1 -1
  687. package/tabview/tabview.js +296 -133
  688. package/tabview/tabview.min.js +1 -1
  689. package/tag/Tag.d.ts +4 -5
  690. package/tag/Tag.vue +13 -10
  691. package/tag/tag.cjs.js +10 -7
  692. package/tag/tag.esm.js +10 -7
  693. package/tag/tag.js +10 -7
  694. package/terminal/Terminal.d.ts +5 -7
  695. package/terminal/Terminal.vue +10 -10
  696. package/terminal/terminal.cjs.js +3 -3
  697. package/terminal/terminal.cjs.min.js +1 -1
  698. package/terminal/terminal.esm.js +3 -3
  699. package/terminal/terminal.esm.min.js +1 -1
  700. package/terminal/terminal.js +3 -3
  701. package/terminal/terminal.min.js +1 -1
  702. package/textarea/Textarea.d.ts +5 -6
  703. package/textarea/Textarea.vue +7 -7
  704. package/textarea/textarea.cjs.js +6 -6
  705. package/textarea/textarea.esm.js +6 -6
  706. package/textarea/textarea.js +6 -6
  707. package/tieredmenu/TieredMenu.d.ts +48 -6
  708. package/tieredmenu/TieredMenu.vue +500 -58
  709. package/tieredmenu/TieredMenuSub.vue +126 -208
  710. package/tieredmenu/tieredmenu.cjs.js +684 -338
  711. package/tieredmenu/tieredmenu.cjs.min.js +1 -1
  712. package/tieredmenu/tieredmenu.esm.js +685 -339
  713. package/tieredmenu/tieredmenu.esm.min.js +1 -1
  714. package/tieredmenu/tieredmenu.js +685 -339
  715. package/tieredmenu/tieredmenu.min.js +1 -1
  716. package/timeline/Timeline.d.ts +4 -5
  717. package/timeline/Timeline.vue +6 -10
  718. package/timeline/timeline.cjs.js +3 -7
  719. package/timeline/timeline.cjs.min.js +1 -1
  720. package/timeline/timeline.esm.js +3 -7
  721. package/timeline/timeline.esm.min.js +1 -1
  722. package/timeline/timeline.js +3 -7
  723. package/timeline/timeline.min.js +1 -1
  724. package/toast/Toast.d.ts +10 -13
  725. package/toast/Toast.vue +40 -31
  726. package/toast/ToastMessage.vue +29 -20
  727. package/toast/toast.cjs.js +56 -38
  728. package/toast/toast.cjs.min.js +1 -1
  729. package/toast/toast.esm.js +55 -37
  730. package/toast/toast.esm.min.js +1 -1
  731. package/toast/toast.js +56 -38
  732. package/toast/toast.min.js +1 -1
  733. package/toastservice/toastservice.cjs.js +1 -0
  734. package/toastservice/toastservice.esm.js +1 -0
  735. package/toastservice/toastservice.js +1 -0
  736. package/togglebutton/ToggleButton.d.ts +10 -10
  737. package/togglebutton/ToggleButton.vue +82 -23
  738. package/togglebutton/togglebutton.cjs.js +66 -18
  739. package/togglebutton/togglebutton.cjs.min.js +1 -1
  740. package/togglebutton/togglebutton.esm.js +66 -18
  741. package/togglebutton/togglebutton.esm.min.js +1 -1
  742. package/togglebutton/togglebutton.js +66 -18
  743. package/togglebutton/togglebutton.min.js +1 -1
  744. package/toolbar/Toolbar.d.ts +8 -5
  745. package/toolbar/Toolbar.vue +9 -3
  746. package/toolbar/toolbar.cjs.js +14 -7
  747. package/toolbar/toolbar.cjs.min.js +1 -1
  748. package/toolbar/toolbar.esm.js +14 -7
  749. package/toolbar/toolbar.esm.min.js +1 -1
  750. package/toolbar/toolbar.js +14 -7
  751. package/toolbar/toolbar.min.js +1 -1
  752. package/tooltip/tooltip.cjs.js +36 -24
  753. package/tooltip/tooltip.cjs.min.js +1 -1
  754. package/tooltip/tooltip.esm.js +37 -25
  755. package/tooltip/tooltip.esm.min.js +1 -1
  756. package/tooltip/tooltip.js +36 -24
  757. package/tooltip/tooltip.min.js +1 -1
  758. package/tree/Tree.d.ts +15 -7
  759. package/tree/Tree.vue +66 -56
  760. package/tree/TreeNode.vue +70 -66
  761. package/tree/tree.cjs.js +99 -102
  762. package/tree/tree.cjs.min.js +1 -1
  763. package/tree/tree.esm.js +99 -102
  764. package/tree/tree.esm.min.js +1 -1
  765. package/tree/tree.js +99 -102
  766. package/tree/tree.min.js +1 -1
  767. package/treeselect/TreeSelect.d.ts +9 -9
  768. package/treeselect/TreeSelect.vue +130 -72
  769. package/treeselect/treeselect.cjs.js +89 -59
  770. package/treeselect/treeselect.cjs.min.js +1 -1
  771. package/treeselect/treeselect.esm.js +89 -59
  772. package/treeselect/treeselect.esm.min.js +1 -1
  773. package/treeselect/treeselect.js +89 -59
  774. package/treeselect/treeselect.min.js +1 -1
  775. package/treetable/BodyCell.vue +29 -19
  776. package/treetable/FooterCell.vue +19 -11
  777. package/treetable/HeaderCell.vue +44 -36
  778. package/treetable/TreeTable.d.ts +8 -8
  779. package/treetable/TreeTable.vue +229 -178
  780. package/treetable/TreeTableRow.vue +74 -58
  781. package/treetable/treetable.cjs.js +287 -253
  782. package/treetable/treetable.cjs.min.js +1 -1
  783. package/treetable/treetable.esm.js +287 -253
  784. package/treetable/treetable.esm.min.js +1 -1
  785. package/treetable/treetable.js +287 -253
  786. package/treetable/treetable.min.js +1 -1
  787. package/tristatecheckbox/TriStateCheckbox.d.ts +9 -9
  788. package/tristatecheckbox/TriStateCheckbox.vue +39 -18
  789. package/tristatecheckbox/tristatecheckbox.cjs.js +24 -15
  790. package/tristatecheckbox/tristatecheckbox.cjs.min.js +1 -1
  791. package/tristatecheckbox/tristatecheckbox.esm.js +24 -15
  792. package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
  793. package/tristatecheckbox/tristatecheckbox.js +24 -15
  794. package/tristatecheckbox/tristatecheckbox.min.js +1 -1
  795. package/ts-helpers.d.ts +16 -10
  796. package/useconfirm/UseConfirm.d.ts +1 -1
  797. package/useconfirm/useconfirm.cjs.js +2 -1
  798. package/useconfirm/useconfirm.esm.js +2 -1
  799. package/useconfirm/useconfirm.js +2 -1
  800. package/usedialog/UseDialog.d.ts +1 -1
  801. package/usedialog/usedialog.cjs.js +2 -1
  802. package/usedialog/usedialog.esm.js +2 -1
  803. package/usedialog/usedialog.js +2 -1
  804. package/usetoast/usetoast.cjs.js +2 -1
  805. package/usetoast/usetoast.esm.js +2 -1
  806. package/usetoast/usetoast.js +2 -1
  807. package/utils/Utils.d.ts +10 -5
  808. package/utils/utils.cjs.js +209 -156
  809. package/utils/utils.cjs.min.js +1 -1
  810. package/utils/utils.esm.js +209 -156
  811. package/utils/utils.esm.min.js +1 -1
  812. package/utils/utils.js +209 -156
  813. package/utils/utils.min.js +1 -1
  814. package/vetur-attributes.json +335 -3
  815. package/vetur-tags.json +112 -19
  816. package/virtualscroller/VirtualScroller.d.ts +9 -9
  817. package/virtualscroller/VirtualScroller.vue +108 -96
  818. package/virtualscroller/virtualscroller.cjs.js +87 -89
  819. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  820. package/virtualscroller/virtualscroller.esm.js +87 -89
  821. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  822. package/virtualscroller/virtualscroller.js +87 -89
  823. package/virtualscroller/virtualscroller.min.js +1 -1
  824. package/web-types.json +1183 -73
@@ -1,11 +1,335 @@
1
- import { DomHandler } from 'primevue/utils';
1
+ import { ObjectUtils, DomHandler, UniqueComponentId } from 'primevue/utils';
2
2
  import Ripple from 'primevue/ripple';
3
- import { resolveComponent, resolveDirective, openBlock, createElementBlock, normalizeClass, renderSlot, createCommentVNode, createElementVNode, Fragment, renderList, normalizeStyle, createBlock, withCtx, withDirectives, toDisplayString, resolveDynamicComponent } from 'vue';
3
+ import { resolveComponent, resolveDirective, openBlock, createElementBlock, normalizeClass, normalizeStyle, toDisplayString, createCommentVNode, Fragment, renderList, createElementVNode, createBlock, withCtx, withDirectives, resolveDynamicComponent, renderSlot, createVNode } from 'vue';
4
+
5
+ var script$1 = {
6
+ name: 'MegaMenuSub',
7
+ emits: ['item-click', 'item-mouseenter'],
8
+ props: {
9
+ menuId: {
10
+ type: String,
11
+ default: null
12
+ },
13
+ focusedItemId: {
14
+ type: String,
15
+ default: null
16
+ },
17
+ horizontal: {
18
+ type: Boolean,
19
+ default: false
20
+ },
21
+ submenu: {
22
+ type: Object,
23
+ default: null
24
+ },
25
+ items: {
26
+ type: Array,
27
+ default: null
28
+ },
29
+ level: {
30
+ type: Number,
31
+ default: 0
32
+ },
33
+ template: {
34
+ type: Function,
35
+ default: null
36
+ },
37
+ activeItem: {
38
+ type: Object,
39
+ default: null
40
+ },
41
+ exact: {
42
+ type: Boolean,
43
+ default: true
44
+ }
45
+ },
46
+ methods: {
47
+ getSubListId(processedItem) {
48
+ return `${this.getItemId(processedItem)}_list`;
49
+ },
50
+ getSubListKey(processedItem) {
51
+ return this.getSubListId(processedItem);
52
+ },
53
+ getItemId(processedItem) {
54
+ return `${this.menuId}_${processedItem.key}`;
55
+ },
56
+ getItemKey(processedItem) {
57
+ return this.getItemId(processedItem);
58
+ },
59
+ getItemProp(processedItem, name) {
60
+ return processedItem && processedItem.item ? ObjectUtils.getItemValue(processedItem.item[name]) : undefined;
61
+ },
62
+ getItemLabel(processedItem) {
63
+ return this.getItemProp(processedItem, 'label');
64
+ },
65
+ isItemActive(processedItem) {
66
+ return ObjectUtils.isNotEmpty(this.activeItem) ? this.activeItem.key === processedItem.key : false;
67
+ },
68
+ isItemVisible(processedItem) {
69
+ return this.getItemProp(processedItem, 'visible') !== false;
70
+ },
71
+ isItemDisabled(processedItem) {
72
+ return this.getItemProp(processedItem, 'disabled');
73
+ },
74
+ isItemFocused(processedItem) {
75
+ return this.focusedItemId === this.getItemId(processedItem);
76
+ },
77
+ isItemGroup(processedItem) {
78
+ return ObjectUtils.isNotEmpty(processedItem.items);
79
+ },
80
+ onItemClick(event, processedItem) {
81
+ const command = this.getItemProp(processedItem, 'command');
82
+
83
+ command && command({ originalEvent: event, item: processedItem.item });
84
+ this.$emit('item-click', { originalEvent: event, processedItem, isFocus: true });
85
+ },
86
+ onItemMouseEnter(event, processedItem) {
87
+ this.$emit('item-mouseenter', { originalEvent: event, processedItem });
88
+ },
89
+ onItemActionClick(event, navigate) {
90
+ navigate && navigate(event);
91
+ },
92
+ getAriaSetSize() {
93
+ return this.items.filter((processedItem) => this.isItemVisible(processedItem) && !this.getItemProp(processedItem, 'separator')).length;
94
+ },
95
+ getAriaPosInset(index) {
96
+ return index - this.items.slice(0, index).filter((processedItem) => this.isItemVisible(processedItem) && this.getItemProp(processedItem, 'separator')).length + 1;
97
+ },
98
+ getSubmenuHeaderClass(processedItem) {
99
+ return [
100
+ 'p-megamenu-submenu-header p-submenu-header',
101
+ this.getItemProp(processedItem, 'class'),
102
+ {
103
+ 'p-disabled': this.isItemDisabled(processedItem)
104
+ }
105
+ ];
106
+ },
107
+ getColumnClass(processedItem) {
108
+ let length = this.isItemGroup(processedItem) ? processedItem.items.length : 0;
109
+ let columnClass;
110
+
111
+ switch (length) {
112
+ case 2:
113
+ columnClass = 'p-megamenu-col-6';
114
+ break;
115
+
116
+ case 3:
117
+ columnClass = 'p-megamenu-col-4';
118
+ break;
119
+
120
+ case 4:
121
+ columnClass = 'p-megamenu-col-3';
122
+ break;
123
+
124
+ case 6:
125
+ columnClass = 'p-megamenu-col-2';
126
+ break;
127
+
128
+ default:
129
+ columnClass = 'p-megamenu-col-12';
130
+ break;
131
+ }
132
+
133
+ return columnClass;
134
+ },
135
+ getItemClass(processedItem) {
136
+ return [
137
+ 'p-menuitem',
138
+ this.getItemProp(processedItem, 'class'),
139
+ {
140
+ 'p-menuitem-active p-highlight': this.isItemActive(processedItem),
141
+ 'p-focus': this.isItemFocused(processedItem),
142
+ 'p-disabled': this.isItemDisabled(processedItem)
143
+ }
144
+ ];
145
+ },
146
+ getItemActionClass(processedItem, routerProps) {
147
+ return [
148
+ 'p-menuitem-link',
149
+ {
150
+ 'router-link-active': routerProps && routerProps.isActive,
151
+ 'router-link-active-exact': this.exact && routerProps && routerProps.isExactActive
152
+ }
153
+ ];
154
+ },
155
+ getItemIconClass(processedItem) {
156
+ return ['p-menuitem-icon', this.getItemProp(processedItem, 'icon')];
157
+ },
158
+ getItemToggleIconClass() {
159
+ return ['p-submenu-icon', this.horizontal ? 'pi pi-angle-down' : 'pi pi-angle-right'];
160
+ },
161
+ getSeparatorItemClass(processedItem) {
162
+ return ['p-menuitem-separator', this.getItemProp(processedItem, 'class')];
163
+ }
164
+ },
165
+ directives: {
166
+ ripple: Ripple
167
+ }
168
+ };
169
+
170
+ const _hoisted_1$1 = ["id", "aria-label", "aria-disabled", "aria-expanded", "aria-haspopup", "aria-level", "aria-setsize", "aria-posinset"];
171
+ const _hoisted_2$1 = ["onClick", "onMouseenter"];
172
+ const _hoisted_3$1 = ["href", "onClick"];
173
+ const _hoisted_4 = { class: "p-menuitem-text" };
174
+ const _hoisted_5 = ["href", "target"];
175
+ const _hoisted_6 = { class: "p-menuitem-text" };
176
+ const _hoisted_7 = {
177
+ key: 0,
178
+ class: "p-megamenu-panel"
179
+ };
180
+ const _hoisted_8 = { class: "p-megamenu-grid" };
181
+ const _hoisted_9 = ["id"];
182
+
183
+ function render$1(_ctx, _cache, $props, $setup, $data, $options) {
184
+ const _component_router_link = resolveComponent("router-link");
185
+ const _component_MegaMenuSub = resolveComponent("MegaMenuSub", true);
186
+ const _directive_ripple = resolveDirective("ripple");
187
+
188
+ return (openBlock(), createElementBlock("ul", null, [
189
+ ($props.submenu)
190
+ ? (openBlock(), createElementBlock("li", {
191
+ key: 0,
192
+ class: normalizeClass($options.getSubmenuHeaderClass($props.submenu)),
193
+ style: normalizeStyle($options.getItemProp($props.submenu, 'style')),
194
+ role: "presentation"
195
+ }, toDisplayString($options.getItemLabel($props.submenu)), 7))
196
+ : createCommentVNode("", true),
197
+ (openBlock(true), createElementBlock(Fragment, null, renderList($props.items, (processedItem, index) => {
198
+ return (openBlock(), createElementBlock(Fragment, {
199
+ key: $options.getItemKey(processedItem)
200
+ }, [
201
+ ($options.isItemVisible(processedItem) && !$options.getItemProp(processedItem, 'separator'))
202
+ ? (openBlock(), createElementBlock("li", {
203
+ key: 0,
204
+ id: $options.getItemId(processedItem),
205
+ style: normalizeStyle($options.getItemProp(processedItem, 'style')),
206
+ class: normalizeClass($options.getItemClass(processedItem)),
207
+ role: "menuitem",
208
+ "aria-label": $options.getItemLabel(processedItem),
209
+ "aria-disabled": $options.isItemDisabled(processedItem) || undefined,
210
+ "aria-expanded": $options.isItemGroup(processedItem) ? $options.isItemActive(processedItem) : undefined,
211
+ "aria-haspopup": $options.isItemGroup(processedItem) && !$options.getItemProp(processedItem, 'to') ? 'menu' : undefined,
212
+ "aria-level": $props.level + 1,
213
+ "aria-setsize": $options.getAriaSetSize(),
214
+ "aria-posinset": $options.getAriaPosInset(index)
215
+ }, [
216
+ createElementVNode("div", {
217
+ class: "p-menuitem-content",
218
+ onClick: $event => ($options.onItemClick($event, processedItem)),
219
+ onMouseenter: $event => ($options.onItemMouseEnter($event, processedItem))
220
+ }, [
221
+ (!$props.template)
222
+ ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
223
+ ($options.getItemProp(processedItem, 'to') && !$options.isItemDisabled(processedItem))
224
+ ? (openBlock(), createBlock(_component_router_link, {
225
+ key: 0,
226
+ to: $options.getItemProp(processedItem, 'to'),
227
+ custom: ""
228
+ }, {
229
+ default: withCtx(({ navigate, href, isActive, isExactActive }) => [
230
+ withDirectives((openBlock(), createElementBlock("a", {
231
+ href: href,
232
+ class: normalizeClass($options.getItemActionClass(processedItem, { isActive, isExactActive })),
233
+ tabindex: "-1",
234
+ "aria-hidden": "true",
235
+ onClick: $event => ($options.onItemActionClick($event, navigate))
236
+ }, [
237
+ ($options.getItemProp(processedItem, 'icon'))
238
+ ? (openBlock(), createElementBlock("span", {
239
+ key: 0,
240
+ class: normalizeClass($options.getItemIconClass(processedItem))
241
+ }, null, 2))
242
+ : createCommentVNode("", true),
243
+ createElementVNode("span", _hoisted_4, toDisplayString($options.getItemLabel(processedItem)), 1)
244
+ ], 10, _hoisted_3$1)), [
245
+ [_directive_ripple]
246
+ ])
247
+ ]),
248
+ _: 2
249
+ }, 1032, ["to"]))
250
+ : withDirectives((openBlock(), createElementBlock("a", {
251
+ key: 1,
252
+ href: $options.getItemProp(processedItem, 'url'),
253
+ class: normalizeClass($options.getItemActionClass(processedItem)),
254
+ target: $options.getItemProp(processedItem, 'target'),
255
+ tabindex: "-1",
256
+ "aria-hidden": "true"
257
+ }, [
258
+ ($options.getItemProp(processedItem, 'icon'))
259
+ ? (openBlock(), createElementBlock("span", {
260
+ key: 0,
261
+ class: normalizeClass($options.getItemIconClass(processedItem))
262
+ }, null, 2))
263
+ : createCommentVNode("", true),
264
+ createElementVNode("span", _hoisted_6, toDisplayString($options.getItemLabel(processedItem)), 1),
265
+ ($options.isItemGroup(processedItem))
266
+ ? (openBlock(), createElementBlock("span", {
267
+ key: 1,
268
+ class: normalizeClass($options.getItemToggleIconClass())
269
+ }, null, 2))
270
+ : createCommentVNode("", true)
271
+ ], 10, _hoisted_5)), [
272
+ [_directive_ripple]
273
+ ])
274
+ ], 64))
275
+ : (openBlock(), createBlock(resolveDynamicComponent($props.template), {
276
+ key: 1,
277
+ item: processedItem.item
278
+ }, null, 8, ["item"]))
279
+ ], 40, _hoisted_2$1),
280
+ ($options.isItemVisible(processedItem) && $options.isItemGroup(processedItem))
281
+ ? (openBlock(), createElementBlock("div", _hoisted_7, [
282
+ createElementVNode("div", _hoisted_8, [
283
+ (openBlock(true), createElementBlock(Fragment, null, renderList(processedItem.items, (col) => {
284
+ return (openBlock(), createElementBlock("div", {
285
+ key: $options.getItemKey(col),
286
+ class: normalizeClass($options.getColumnClass(processedItem))
287
+ }, [
288
+ (openBlock(true), createElementBlock(Fragment, null, renderList(col, (submenu) => {
289
+ return (openBlock(), createBlock(_component_MegaMenuSub, {
290
+ key: $options.getSubListKey(submenu),
291
+ id: $options.getSubListId(submenu),
292
+ role: "menu",
293
+ class: "p-submenu-list p-megamenu-submenu",
294
+ menuId: $props.menuId,
295
+ focusedItemId: $props.focusedItemId,
296
+ submenu: submenu,
297
+ items: submenu.items,
298
+ template: $props.template,
299
+ exact: $props.exact,
300
+ level: $props.level + 1,
301
+ onItemClick: _cache[0] || (_cache[0] = $event => (_ctx.$emit('item-click', $event))),
302
+ onItemMouseenter: _cache[1] || (_cache[1] = $event => (_ctx.$emit('item-mouseenter', $event)))
303
+ }, null, 8, ["id", "menuId", "focusedItemId", "submenu", "items", "template", "exact", "level"]))
304
+ }), 128))
305
+ ], 2))
306
+ }), 128))
307
+ ])
308
+ ]))
309
+ : createCommentVNode("", true)
310
+ ], 14, _hoisted_1$1))
311
+ : createCommentVNode("", true),
312
+ ($options.isItemVisible(processedItem) && $options.getItemProp(processedItem, 'separator'))
313
+ ? (openBlock(), createElementBlock("li", {
314
+ key: 1,
315
+ id: $options.getItemId(processedItem),
316
+ style: normalizeStyle($options.getItemProp(processedItem, 'style')),
317
+ class: normalizeClass($options.getSeparatorItemClass(processedItem)),
318
+ role: "separator"
319
+ }, null, 14, _hoisted_9))
320
+ : createCommentVNode("", true)
321
+ ], 64))
322
+ }), 128))
323
+ ]))
324
+ }
325
+
326
+ script$1.render = render$1;
4
327
 
5
328
  var script = {
6
329
  name: 'MegaMenu',
330
+ emits: ['focus', 'blur'],
7
331
  props: {
8
- model: {
332
+ model: {
9
333
  type: Array,
10
334
  default: null
11
335
  },
@@ -16,490 +340,612 @@ var script = {
16
340
  exact: {
17
341
  type: Boolean,
18
342
  default: true
343
+ },
344
+ disabled: {
345
+ type: Boolean,
346
+ default: false
347
+ },
348
+ tabindex: {
349
+ type: Number,
350
+ default: 0
351
+ },
352
+ 'aria-labelledby': {
353
+ type: String,
354
+ default: null
355
+ },
356
+ 'aria-label': {
357
+ type: String,
358
+ default: null
19
359
  }
20
360
  },
21
- documentClickListener: null,
361
+ outsideClickListener: null,
362
+ resizeListener: null,
363
+ container: null,
364
+ menubar: null,
365
+ searchTimeout: null,
366
+ searchValue: null,
22
367
  data() {
23
368
  return {
24
- activeItem: null
369
+ focused: false,
370
+ focusedItemInfo: { index: -1, key: '', parentKey: '' },
371
+ activeItem: null,
372
+ dirty: false
373
+ };
374
+ },
375
+ watch: {
376
+ activeItem(newItem) {
377
+ if (ObjectUtils.isNotEmpty(newItem)) {
378
+ this.bindOutsideClickListener();
379
+ this.bindResizeListener();
380
+ } else {
381
+ this.unbindOutsideClickListener();
382
+ this.unbindResizeListener();
383
+ }
25
384
  }
26
385
  },
27
386
  beforeUnmount() {
28
- this.unbindDocumentClickListener();
387
+ this.unbindOutsideClickListener();
388
+ this.unbindResizeListener();
29
389
  },
30
390
  methods: {
31
- onLeafClick(event, item, navigate) {
32
- if (this.disabled(item)) {
391
+ getItemProp(item, name) {
392
+ return item ? ObjectUtils.getItemValue(item[name]) : undefined;
393
+ },
394
+ getItemLabel(item) {
395
+ return this.getItemProp(item, 'label');
396
+ },
397
+ isItemDisabled(item) {
398
+ return this.getItemProp(item, 'disabled');
399
+ },
400
+ isItemGroup(item) {
401
+ return ObjectUtils.isNotEmpty(this.getItemProp(item, 'items'));
402
+ },
403
+ isItemSeparator(item) {
404
+ return this.getItemProp(item, 'separator');
405
+ },
406
+ getProccessedItemLabel(processedItem) {
407
+ return processedItem ? this.getItemLabel(processedItem.item) : undefined;
408
+ },
409
+ isProccessedItemGroup(processedItem) {
410
+ return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
411
+ },
412
+ hide(event, isFocus) {
413
+ this.activeItem = null;
414
+ this.focusedItemInfo = { index: -1, key: '', parentKey: '' };
415
+
416
+ isFocus && DomHandler.focus(this.menubar);
417
+ this.dirty = false;
418
+ },
419
+ onFocus(event) {
420
+ this.focused = true;
421
+
422
+ if (this.focusedItemInfo.index === -1) {
423
+ const index = this.findFirstFocusedItemIndex();
424
+ const processedItem = this.findVisibleItem(index);
425
+
426
+ this.focusedItemInfo = { index, key: processedItem.key, parentKey: processedItem.parentKey };
427
+ }
428
+
429
+ this.$emit('focus', event);
430
+ },
431
+ onBlur(event) {
432
+ this.focused = false;
433
+ this.focusedItemInfo = { index: -1, key: '', parentKey: '' };
434
+ this.searchValue = '';
435
+ this.dirty = false;
436
+ this.$emit('blur', event);
437
+ },
438
+ onKeyDown(event) {
439
+ if (this.disabled) {
33
440
  event.preventDefault();
441
+
34
442
  return;
35
443
  }
36
444
 
37
- if (item.command) {
38
- item.command({
39
- originalEvent: event,
40
- item: item
41
- });
445
+ const metaKey = event.metaKey || event.ctrlKey;
446
+
447
+ switch (event.code) {
448
+ case 'ArrowDown':
449
+ this.onArrowDownKey(event);
450
+ break;
451
+
452
+ case 'ArrowUp':
453
+ this.onArrowUpKey(event);
454
+ break;
455
+
456
+ case 'ArrowLeft':
457
+ this.onArrowLeftKey(event);
458
+ break;
459
+
460
+ case 'ArrowRight':
461
+ this.onArrowRightKey(event);
462
+ break;
463
+
464
+ case 'Home':
465
+ this.onHomeKey(event);
466
+ break;
467
+
468
+ case 'End':
469
+ this.onEndKey(event);
470
+ break;
471
+
472
+ case 'Space':
473
+ this.onSpaceKey(event);
474
+ break;
475
+
476
+ case 'Enter':
477
+ this.onEnterKey(event);
478
+ break;
479
+
480
+ case 'Escape':
481
+ this.onEscapeKey(event);
482
+ break;
483
+
484
+ case 'Tab':
485
+ this.onTabKey(event);
486
+ break;
487
+
488
+ case 'PageDown':
489
+ case 'PageUp':
490
+ case 'Backspace':
491
+ case 'ShiftLeft':
492
+ case 'ShiftRight':
493
+ //NOOP
494
+ break;
495
+
496
+ default:
497
+ if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {
498
+ this.searchItems(event, event.key);
499
+ }
500
+
501
+ break;
42
502
  }
503
+ },
504
+ onItemChange(event) {
505
+ const { processedItem, isFocus } = event;
43
506
 
44
- this.activeItem = null;
507
+ if (ObjectUtils.isEmpty(processedItem)) return;
508
+
509
+ const { index, key, parentKey, items } = processedItem;
510
+ const grouped = ObjectUtils.isNotEmpty(items);
511
+
512
+ grouped && (this.activeItem = processedItem);
513
+ this.focusedItemInfo = { index, key, parentKey };
45
514
 
46
- if (item.to && navigate) {
47
- navigate(event);
515
+ grouped && (this.dirty = true);
516
+ isFocus && DomHandler.focus(this.menubar);
517
+ },
518
+ onItemClick(event) {
519
+ const { originalEvent, processedItem } = event;
520
+ const grouped = this.isProccessedItemGroup(processedItem);
521
+ const root = ObjectUtils.isEmpty(processedItem.parent);
522
+ const selected = this.isSelected(processedItem);
523
+
524
+ if (selected) {
525
+ const { index, key, parentKey } = processedItem;
526
+
527
+ this.activeItem = null;
528
+ this.focusedItemInfo = { index, key, parentKey };
529
+
530
+ this.dirty = !root;
531
+ DomHandler.focus(this.menubar);
532
+ } else {
533
+ grouped ? this.onItemChange(event) : this.hide(originalEvent, !root);
48
534
  }
49
535
  },
50
- onCategoryMouseEnter(event, category) {
51
- if (this.disabled(category)) {
52
- event.preventDefault();
53
- return;
536
+ onItemMouseEnter(event) {
537
+ if (this.dirty) {
538
+ this.onItemChange(event);
54
539
  }
55
-
56
- if (this.activeItem) {
57
- this.activeItem = category;
540
+ },
541
+ onArrowDownKey(event) {
542
+ if (this.horizontal) {
543
+ if (ObjectUtils.isNotEmpty(this.activeItem) && this.activeItem.key === this.focusedItemInfo.key) {
544
+ this.focusedItemInfo = { index: -1, key: '', parentKey: this.activeItem.key };
545
+ } else {
546
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
547
+ const grouped = this.isProccessedItemGroup(processedItem);
548
+
549
+ if (grouped) {
550
+ this.onItemChange({ originalEvent: event, processedItem });
551
+ this.focusedItemInfo = { index: -1, key: processedItem.key, parentKey: processedItem.parentKey };
552
+ this.searchValue = '';
553
+ }
554
+ }
58
555
  }
556
+
557
+ const itemIndex = this.focusedItemInfo.index !== -1 ? this.findNextItemIndex(this.focusedItemInfo.index) : this.findFirstFocusedItemIndex();
558
+
559
+ this.changeFocusedItemInfo(event, itemIndex);
560
+ event.preventDefault();
59
561
  },
60
- onCategoryClick(event, category, navigate) {
61
- if (this.disabled(category)) {
562
+ onArrowUpKey(event) {
563
+ if (event.altKey && this.horizontal) {
564
+ if (this.focusedItemInfo.index !== -1) {
565
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
566
+ const grouped = this.isProccessedItemGroup(processedItem);
567
+
568
+ if (!grouped && ObjectUtils.isNotEmpty(this.activeItem)) {
569
+ if (this.focusedItemInfo.index === 0) {
570
+ this.focusedItemInfo = { index: this.activeItem.index, key: this.activeItem.key, parentKey: this.activeItem.parentKey };
571
+ this.activeItem = null;
572
+ } else {
573
+ this.changeFocusedItemInfo(event, this.findFirstItemIndex());
574
+ }
575
+ }
576
+ }
577
+
62
578
  event.preventDefault();
63
- return;
64
- }
579
+ } else {
580
+ const itemIndex = this.focusedItemInfo.index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo.index) : this.findLastFocusedItemIndex();
65
581
 
66
- if (category.command) {
67
- category.command({
68
- originalEvent: event,
69
- item: category
70
- });
582
+ this.changeFocusedItemInfo(event, itemIndex);
583
+ event.preventDefault();
71
584
  }
585
+ },
586
+ onArrowLeftKey(event) {
587
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
588
+ const grouped = this.isProccessedItemGroup(processedItem);
589
+
590
+ if (grouped) {
591
+ if (this.horizontal) {
592
+ const itemIndex = this.focusedItemInfo.index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo.index) : this.findLastFocusedItemIndex();
72
593
 
73
- if (category.items) {
74
- if (this.activeItem && this.activeItem === category) {
75
- this.activeItem = null;
76
- this.unbindDocumentClickListener();
594
+ this.changeFocusedItemInfo(event, itemIndex);
77
595
  }
78
- else {
79
- this.activeItem = category;
80
- this.bindDocumentClickListener();
596
+ } else {
597
+ if (this.vertical && ObjectUtils.isNotEmpty(this.activeItem)) {
598
+ if (processedItem.columnIndex === 0) {
599
+ this.focusedItemInfo = { index: this.activeItem.index, key: this.activeItem.key, parentKey: this.activeItem.parentKey };
600
+ this.activeItem = null;
601
+ }
81
602
  }
82
- }
83
603
 
84
- if (category.to && navigate) {
85
- navigate(event);
604
+ const columnIndex = processedItem.columnIndex - 1;
605
+ const itemIndex = this.visibleItems.findIndex((item) => item.columnIndex === columnIndex);
606
+
607
+ itemIndex !== -1 && this.changeFocusedItemInfo(event, itemIndex);
86
608
  }
609
+
610
+ event.preventDefault();
87
611
  },
88
- onCategoryKeydown(event, category) {
89
- let listItem = event.currentTarget.parentElement;
90
-
91
- switch(event.which) {
92
- //down
93
- case 40:
94
- if (this.horizontal)
95
- this.expandMenu(category);
96
- else
97
- this.navigateToNextItem(listItem);
98
-
99
- event.preventDefault();
100
- break;
101
-
102
- //up
103
- case 38:
104
- if (this.vertical)
105
- this.navigateToPrevItem(listItem);
106
- else if (category.items && category === this.activeItem)
107
- this.collapseMenu();
108
-
109
- event.preventDefault();
110
- break;
111
-
112
- //right
113
- case 39:
114
- if (this.horizontal)
115
- this.navigateToNextItem(listItem);
116
- else
117
- this.expandMenu(category);
118
-
119
- event.preventDefault();
120
- break;
121
-
122
- //left
123
- case 37:
124
- if (this.horizontal)
125
- this.navigateToPrevItem(listItem);
126
- else if (category.items && category === this.activeItem)
127
- this.collapseMenu();
128
-
129
- event.preventDefault();
130
- break;
612
+ onArrowRightKey(event) {
613
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
614
+ const grouped = this.isProccessedItemGroup(processedItem);
615
+
616
+ if (grouped) {
617
+ if (this.vertical) {
618
+ if (ObjectUtils.isNotEmpty(this.activeItem) && this.activeItem.key === processedItem.key) {
619
+ this.focusedItemInfo = { index: -1, key: '', parentKey: this.activeItem.key };
620
+ } else {
621
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
622
+ const grouped = this.isProccessedItemGroup(processedItem);
623
+
624
+ if (grouped) {
625
+ this.onItemChange({ originalEvent: event, processedItem });
626
+ this.focusedItemInfo = { index: -1, key: processedItem.key, parentKey: processedItem.parentKey };
627
+ this.searchValue = '';
628
+ }
629
+ }
630
+ }
631
+
632
+ const itemIndex = this.focusedItemInfo.index !== -1 ? this.findNextItemIndex(this.focusedItemInfo.index) : this.findFirstFocusedItemIndex();
633
+
634
+ this.changeFocusedItemInfo(event, itemIndex);
635
+ } else {
636
+ const columnIndex = processedItem.columnIndex + 1;
637
+ const itemIndex = this.visibleItems.findIndex((item) => item.columnIndex === columnIndex);
638
+
639
+ itemIndex !== -1 && this.changeFocusedItemInfo(event, itemIndex);
131
640
  }
641
+
642
+ event.preventDefault();
643
+ },
644
+ onHomeKey(event) {
645
+ this.changeFocusedItemInfo(event, this.findFirstItemIndex());
646
+ event.preventDefault();
132
647
  },
133
- expandMenu(item) {
134
- if (item.items) {
135
- this.activeItem = item;
648
+ onEndKey(event) {
649
+ this.changeFocusedItemInfo(event, this.findLastItemIndex());
650
+ event.preventDefault();
651
+ },
652
+ onEnterKey(event) {
653
+ if (this.focusedItemInfo.index !== -1) {
654
+ const element = DomHandler.findSingle(this.menubar, `li[id="${`${this.focusedItemId}`}"]`);
655
+ const anchorElement = element && DomHandler.findSingle(element, '.p-menuitem-link');
656
+
657
+ anchorElement ? anchorElement.click() : element && element.click();
658
+
659
+ const processedItem = this.visibleItems[this.focusedItemInfo.index];
660
+ const grouped = this.isProccessedItemGroup(processedItem);
661
+
662
+ !grouped && this.changeFocusedItemInfo(event, this.findFirstFocusedItemIndex());
136
663
  }
664
+
665
+ event.preventDefault();
137
666
  },
138
- collapseMenu() {
139
- this.activeItem = null;
667
+ onSpaceKey(event) {
668
+ this.onEnterKey(event);
140
669
  },
141
- findNextItem(item) {
142
- let nextItem = item.nextElementSibling;
670
+ onEscapeKey(event) {
671
+ if (ObjectUtils.isNotEmpty(this.activeItem)) {
672
+ this.focusedItemInfo = { index: this.activeItem.index, key: this.activeItem.key };
673
+ this.activeItem = null;
674
+ }
143
675
 
144
- if (nextItem)
145
- return DomHandler.hasClass(nextItem, 'p-disabled') || !DomHandler.hasClass(nextItem, 'p-menuitem') ? this.findNextItem(nextItem) : nextItem;
146
- else
147
- return null;
676
+ event.preventDefault();
148
677
  },
149
- findPrevItem(item) {
150
- let prevItem = item.previousElementSibling;
678
+ onTabKey(event) {
679
+ if (this.focusedItemInfo.index !== -1) {
680
+ const processedItem = this.findVisibleItem(this.focusedItemInfo.index);
681
+ const grouped = this.isProccessedItemGroup(processedItem);
151
682
 
152
- if (prevItem)
153
- return DomHandler.hasClass(prevItem, 'p-disabled') || !DomHandler.hasClass(prevItem, 'p-menuitem') ? this.findPrevItem(prevItem) : prevItem;
154
- else
155
- return null;
683
+ !grouped && this.onItemChange({ originalEvent: event, processedItem });
684
+ }
685
+
686
+ this.hide();
156
687
  },
157
- navigateToNextItem(listItem) {
158
- var nextItem = this.findNextItem(listItem);
159
- if (nextItem) {
160
- nextItem.children[0].focus();
688
+ bindOutsideClickListener() {
689
+ if (!this.outsideClickListener) {
690
+ this.outsideClickListener = (event) => {
691
+ const isOutsideContainer = this.container && !this.container.contains(event.target);
692
+ const isOutsideTarget = this.popup ? !(this.target && (this.target === event.target || this.target.contains(event.target))) : true;
693
+
694
+ if (isOutsideContainer && isOutsideTarget) {
695
+ this.hide();
696
+ }
697
+ };
698
+
699
+ document.addEventListener('click', this.outsideClickListener);
161
700
  }
162
701
  },
163
- navigateToPrevItem(listItem) {
164
- var prevItem = this.findPrevItem(listItem);
165
- if (prevItem) {
166
- prevItem.children[0].focus();
702
+ unbindOutsideClickListener() {
703
+ if (this.outsideClickListener) {
704
+ document.removeEventListener('click', this.outsideClickListener);
705
+ this.outsideClickListener = null;
167
706
  }
168
707
  },
169
- getCategoryClass(category) {
170
- return ['p-menuitem', {
171
- 'p-menuitem-active': category === this.activeItem
172
- }, category.class];
708
+ bindResizeListener() {
709
+ if (!this.resizeListener) {
710
+ this.resizeListener = (event) => {
711
+ if (!DomHandler.isTouchDevice()) {
712
+ this.hide(event, true);
713
+ }
714
+ };
715
+
716
+ window.addEventListener('resize', this.resizeListener);
717
+ }
173
718
  },
174
- getCategorySubMenuIcon() {
175
- return ['p-submenu-icon pi', {
176
- 'pi-angle-down': this.horizontal,
177
- 'pi-angle-right': this.vertical
178
- }];
719
+ unbindResizeListener() {
720
+ if (this.resizeListener) {
721
+ window.removeEventListener('resize', this.resizeListener);
722
+ this.resizeListener = null;
723
+ }
179
724
  },
180
- getCategoryIcon(category) {
181
- return ['p-menuitem-icon', category.icon];
725
+ isItemMatched(processedItem) {
726
+ return this.isValidItem(processedItem) && this.getProccessedItemLabel(processedItem).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase());
182
727
  },
183
- getColumnClassName(category) {
184
- let length = category.items ? category.items.length: 0;
185
- let columnClass;
728
+ isValidItem(processedItem) {
729
+ return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item);
730
+ },
731
+ isValidSelectedItem(processedItem) {
732
+ return this.isValidItem(processedItem) && this.isSelected(processedItem);
733
+ },
734
+ isSelected(processedItem) {
735
+ return ObjectUtils.isNotEmpty(this.activeItem) ? this.activeItem.key === processedItem.key : false;
736
+ },
737
+ findFirstItemIndex() {
738
+ return this.visibleItems.findIndex((processedItem) => this.isValidItem(processedItem));
739
+ },
740
+ findLastItemIndex() {
741
+ return ObjectUtils.findLastIndex(this.visibleItems, (processedItem) => this.isValidItem(processedItem));
742
+ },
743
+ findNextItemIndex(index) {
744
+ const matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex((processedItem) => this.isValidItem(processedItem)) : -1;
186
745
 
187
- switch(length) {
188
- case 2:
189
- columnClass= 'p-megamenu-col-6';
190
- break;
746
+ return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
747
+ },
748
+ findPrevItemIndex(index) {
749
+ const matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), (processedItem) => this.isValidItem(processedItem)) : -1;
191
750
 
192
- case 3:
193
- columnClass= 'p-megamenu-col-4';
194
- break;
751
+ return matchedItemIndex > -1 ? matchedItemIndex : index;
752
+ },
753
+ findSelectedItemIndex() {
754
+ return this.visibleItems.findIndex((processedItem) => this.isValidSelectedItem(processedItem));
755
+ },
756
+ findFirstFocusedItemIndex() {
757
+ const selectedIndex = this.findSelectedItemIndex();
195
758
 
196
- case 4:
197
- columnClass= 'p-megamenu-col-3';
198
- break;
759
+ return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;
760
+ },
761
+ findLastFocusedItemIndex() {
762
+ const selectedIndex = this.findSelectedItemIndex();
199
763
 
200
- case 6:
201
- columnClass= 'p-megamenu-col-2';
202
- break;
764
+ return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;
765
+ },
766
+ findVisibleItem(index) {
767
+ return ObjectUtils.isNotEmpty(this.visibleItems) ? this.visibleItems[index] : null;
768
+ },
769
+ searchItems(event, char) {
770
+ this.searchValue = (this.searchValue || '') + char;
203
771
 
204
- default:
205
- columnClass= 'p-megamenu-col-12';
206
- break;
772
+ let itemIndex = -1;
773
+ let matched = false;
774
+
775
+ if (this.focusedItemInfo.index !== -1) {
776
+ itemIndex = this.visibleItems.slice(this.focusedItemInfo.index).findIndex((processedItem) => this.isItemMatched(processedItem));
777
+ itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo.index).findIndex((processedItem) => this.isItemMatched(processedItem)) : itemIndex + this.focusedItemInfo.index;
778
+ } else {
779
+ itemIndex = this.visibleItems.findIndex((processedItem) => this.isItemMatched(processedItem));
207
780
  }
208
781
 
209
- return columnClass;
210
- },
211
- getSubmenuHeaderClass(submenu) {
212
- return ['p-megamenu-submenu-header', submenu.class, {'p-disabled': this.disabled(submenu)}];
213
- },
214
- getSubmenuItemClass(item) {
215
- return ['p-menuitem', item.class];
216
- },
217
- linkClass(item, routerProps) {
218
- return ['p-menuitem-link', {
219
- 'p-disabled': this.disabled(item),
220
- 'router-link-active': routerProps && routerProps.isActive,
221
- 'router-link-active-exact': this.exact && routerProps && routerProps.isExactActive
222
- }];
223
- },
224
- bindDocumentClickListener() {
225
- if (!this.documentClickListener) {
226
- this.documentClickListener = (event) => {
227
- if (this.$el && !this.$el.contains(event.target)) {
228
- this.activeItem = null;
229
- this.unbindDocumentClickListener();
230
- }
231
- };
782
+ if (itemIndex !== -1) {
783
+ matched = true;
784
+ }
785
+
786
+ if (itemIndex === -1 && this.focusedItemInfo.index === -1) {
787
+ itemIndex = this.findFirstFocusedItemIndex();
788
+ }
789
+
790
+ if (itemIndex !== -1) {
791
+ this.changeFocusedItemInfo(event, itemIndex);
792
+ }
232
793
 
233
- document.addEventListener('click', this.documentClickListener);
794
+ if (this.searchTimeout) {
795
+ clearTimeout(this.searchTimeout);
234
796
  }
797
+
798
+ this.searchTimeout = setTimeout(() => {
799
+ this.searchValue = '';
800
+ this.searchTimeout = null;
801
+ }, 500);
802
+
803
+ return matched;
235
804
  },
236
- unbindDocumentClickListener() {
237
- if (this.documentClickListener) {
238
- document.removeEventListener('click', this.documentClickListener);
239
- this.documentClickListener = null;
805
+ changeFocusedItemInfo(event, index) {
806
+ const processedItem = this.findVisibleItem(index);
807
+
808
+ this.focusedItemInfo.index = index;
809
+ this.focusedItemInfo.key = ObjectUtils.isNotEmpty(processedItem) ? processedItem.key : '';
810
+ this.scrollInView();
811
+ },
812
+ scrollInView(index = -1) {
813
+ const id = index !== -1 ? `${this.id}_${index}` : this.focusedItemId;
814
+ const element = DomHandler.findSingle(this.menubar, `li[id="${id}"]`);
815
+
816
+ if (element) {
817
+ element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'start' });
240
818
  }
241
819
  },
242
- visible(item) {
243
- return (typeof item.visible === 'function' ? item.visible() : item.visible !== false);
820
+ createProcessedItems(items, level = 0, parent = {}, parentKey = '', columnIndex) {
821
+ const processedItems = [];
822
+
823
+ items &&
824
+ items.forEach((item, index) => {
825
+ const key = (parentKey !== '' ? parentKey + '_' : '') + (columnIndex !== undefined ? columnIndex + '_' : '') + index;
826
+ const newItem = {
827
+ item,
828
+ index,
829
+ level,
830
+ key,
831
+ parent,
832
+ parentKey,
833
+ columnIndex: columnIndex !== undefined ? columnIndex : parent.columnIndex
834
+ };
835
+
836
+ newItem['items'] = level === 0 ? item.items.map((_items, _index) => this.createProcessedItems(_items, level + 1, newItem, key, _index)) : this.createProcessedItems(item.items, level + 1, newItem, key);
837
+ processedItems.push(newItem);
838
+ });
839
+
840
+ return processedItems;
244
841
  },
245
- disabled(item) {
246
- return (typeof item.disabled === 'function' ? item.disabled() : item.disabled);
842
+ containerRef(el) {
843
+ this.container = el;
247
844
  },
248
- label(item) {
249
- return (typeof item.disabled === 'function' ? item.label() : item.label);
845
+ menubarRef(el) {
846
+ this.menubar = el ? el.$el : undefined;
250
847
  }
251
848
  },
252
849
  computed: {
253
850
  containerClass() {
254
- return ['p-megamenu p-component', {
255
- 'p-megamenu-horizontal': this.horizontal,
256
- 'p-megamenu-vertical': this.vertical
257
- }];
851
+ return [
852
+ 'p-megamenu p-component',
853
+ {
854
+ 'p-megamenu-horizontal': this.horizontal,
855
+ 'p-megamenu-vertical': this.vertical
856
+ }
857
+ ];
858
+ },
859
+ processedItems() {
860
+ return this.createProcessedItems(this.model || []);
861
+ },
862
+ visibleItems() {
863
+ const processedItem = ObjectUtils.isNotEmpty(this.activeItem) ? this.activeItem : null;
864
+
865
+ return processedItem && processedItem.key === this.focusedItemInfo.parentKey
866
+ ? processedItem.items.reduce((items, col) => {
867
+ col.forEach((submenu) => {
868
+ submenu.items.forEach((a) => {
869
+ items.push(a);
870
+ });
871
+ });
872
+
873
+ return items;
874
+ }, [])
875
+ : this.processedItems;
258
876
  },
259
877
  horizontal() {
260
878
  return this.orientation === 'horizontal';
261
879
  },
262
880
  vertical() {
263
881
  return this.orientation === 'vertical';
882
+ },
883
+ id() {
884
+ return this.$attrs.id || UniqueComponentId();
885
+ },
886
+ focusedItemId() {
887
+ return ObjectUtils.isNotEmpty(this.focusedItemInfo.key) ? `${this.id}_${this.focusedItemInfo.key}` : null;
264
888
  }
265
889
  },
266
- directives: {
267
- 'ripple': Ripple
890
+ components: {
891
+ MegaMenuSub: script$1
268
892
  }
269
893
  };
270
894
 
271
- const _hoisted_1 = {
895
+ const _hoisted_1 = ["id"];
896
+ const _hoisted_2 = {
272
897
  key: 0,
273
898
  class: "p-megamenu-start"
274
899
  };
275
- const _hoisted_2 = {
276
- class: "p-megamenu-root-list",
277
- role: "menubar"
278
- };
279
- const _hoisted_3 = ["onMouseenter"];
280
- const _hoisted_4 = ["href", "onClick", "onKeydown"];
281
- const _hoisted_5 = { class: "p-menuitem-text" };
282
- const _hoisted_6 = ["href", "target", "onClick", "onKeydown", "aria-haspopup", "aria-expanded", "tabindex"];
283
- const _hoisted_7 = { class: "p-menuitem-text" };
284
- const _hoisted_8 = {
285
- key: 2,
286
- class: "p-megamenu-panel"
287
- };
288
- const _hoisted_9 = { class: "p-megamenu-grid" };
289
- const _hoisted_10 = ["href", "onClick"];
290
- const _hoisted_11 = { class: "p-menuitem-text" };
291
- const _hoisted_12 = ["href", "target", "onClick", "tabindex"];
292
- const _hoisted_13 = { class: "p-menuitem-text" };
293
- const _hoisted_14 = {
900
+ const _hoisted_3 = {
294
901
  key: 1,
295
902
  class: "p-megamenu-end"
296
903
  };
297
904
 
298
905
  function render(_ctx, _cache, $props, $setup, $data, $options) {
299
- const _component_router_link = resolveComponent("router-link");
300
- const _directive_ripple = resolveDirective("ripple");
906
+ const _component_MegaMenuSub = resolveComponent("MegaMenuSub");
301
907
 
302
908
  return (openBlock(), createElementBlock("div", {
909
+ ref: $options.containerRef,
910
+ id: $options.id,
303
911
  class: normalizeClass($options.containerClass)
304
912
  }, [
305
913
  (_ctx.$slots.start)
306
- ? (openBlock(), createElementBlock("div", _hoisted_1, [
914
+ ? (openBlock(), createElementBlock("div", _hoisted_2, [
307
915
  renderSlot(_ctx.$slots, "start")
308
916
  ]))
309
917
  : createCommentVNode("", true),
310
- createElementVNode("ul", _hoisted_2, [
311
- (openBlock(true), createElementBlock(Fragment, null, renderList($props.model, (category, index) => {
312
- return (openBlock(), createElementBlock(Fragment, {
313
- key: $options.label(category) + '_' + index
314
- }, [
315
- ($options.visible(category))
316
- ? (openBlock(), createElementBlock("li", {
317
- key: 0,
318
- class: normalizeClass($options.getCategoryClass(category)),
319
- style: normalizeStyle(category.style),
320
- onMouseenter: $event => ($options.onCategoryMouseEnter($event, category)),
321
- role: "none"
322
- }, [
323
- (!_ctx.$slots.item)
324
- ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
325
- (category.to && !$options.disabled(category))
326
- ? (openBlock(), createBlock(_component_router_link, {
327
- key: 0,
328
- to: category.to,
329
- custom: ""
330
- }, {
331
- default: withCtx(({navigate, href, isActive, isExactActive}) => [
332
- withDirectives((openBlock(), createElementBlock("a", {
333
- href: href,
334
- class: normalizeClass($options.linkClass(category, {isActive, isExactActive})),
335
- onClick: $event => ($options.onCategoryClick($event, category, navigate)),
336
- onKeydown: $event => ($options.onCategoryKeydown($event, category)),
337
- role: "menuitem"
338
- }, [
339
- (category.icon)
340
- ? (openBlock(), createElementBlock("span", {
341
- key: 0,
342
- class: normalizeClass($options.getCategoryIcon(category))
343
- }, null, 2))
344
- : createCommentVNode("", true),
345
- createElementVNode("span", _hoisted_5, toDisplayString($options.label(category)), 1)
346
- ], 42, _hoisted_4)), [
347
- [_directive_ripple]
348
- ])
349
- ]),
350
- _: 2
351
- }, 1032, ["to"]))
352
- : withDirectives((openBlock(), createElementBlock("a", {
353
- key: 1,
354
- href: category.url,
355
- class: normalizeClass($options.linkClass(category)),
356
- target: category.target,
357
- onClick: $event => ($options.onCategoryClick($event, category)),
358
- onKeydown: $event => ($options.onCategoryKeydown($event, category)),
359
- role: "menuitem",
360
- "aria-haspopup": category.items != null,
361
- "aria-expanded": category === $data.activeItem,
362
- tabindex: $options.disabled(category) ? null : '0'
363
- }, [
364
- (category.icon)
365
- ? (openBlock(), createElementBlock("span", {
366
- key: 0,
367
- class: normalizeClass($options.getCategoryIcon(category))
368
- }, null, 2))
369
- : createCommentVNode("", true),
370
- createElementVNode("span", _hoisted_7, toDisplayString($options.label(category)), 1),
371
- (category.items)
372
- ? (openBlock(), createElementBlock("span", {
373
- key: 1,
374
- class: normalizeClass($options.getCategorySubMenuIcon())
375
- }, null, 2))
376
- : createCommentVNode("", true)
377
- ], 42, _hoisted_6)), [
378
- [_directive_ripple]
379
- ])
380
- ], 64))
381
- : (openBlock(), createBlock(resolveDynamicComponent(_ctx.$slots.item), {
382
- key: 1,
383
- item: category
384
- }, null, 8, ["item"])),
385
- (category.items)
386
- ? (openBlock(), createElementBlock("div", _hoisted_8, [
387
- createElementVNode("div", _hoisted_9, [
388
- (openBlock(true), createElementBlock(Fragment, null, renderList(category.items, (column, columnIndex) => {
389
- return (openBlock(), createElementBlock("div", {
390
- key: $options.label(category) + '_column_' + columnIndex,
391
- class: normalizeClass($options.getColumnClassName(category))
392
- }, [
393
- (openBlock(true), createElementBlock(Fragment, null, renderList(column, (submenu, submenuIndex) => {
394
- return (openBlock(), createElementBlock("ul", {
395
- class: "p-megamenu-submenu",
396
- key: submenu.label + '_submenu_' + submenuIndex,
397
- role: "menu"
398
- }, [
399
- createElementVNode("li", {
400
- class: normalizeClass($options.getSubmenuHeaderClass(submenu)),
401
- style: normalizeStyle(submenu.style),
402
- role: "presentation"
403
- }, toDisplayString(submenu.label), 7),
404
- (openBlock(true), createElementBlock(Fragment, null, renderList(submenu.items, (item, i) => {
405
- return (openBlock(), createElementBlock(Fragment, {
406
- key: $options.label(item) + i.toString()
407
- }, [
408
- ($options.visible(item) && !item.separator)
409
- ? (openBlock(), createElementBlock("li", {
410
- key: 0,
411
- role: "none",
412
- class: normalizeClass($options.getSubmenuItemClass(item)),
413
- style: normalizeStyle(item.style)
414
- }, [
415
- (!_ctx.$slots.item)
416
- ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
417
- (item.to && !$options.disabled(item))
418
- ? (openBlock(), createBlock(_component_router_link, {
419
- key: 0,
420
- to: item.to,
421
- custom: ""
422
- }, {
423
- default: withCtx(({navigate, href, isActive, isExactActive}) => [
424
- withDirectives((openBlock(), createElementBlock("a", {
425
- href: href,
426
- class: normalizeClass($options.linkClass(item, {isActive, isExactActive})),
427
- onClick: $event => ($options.onLeafClick($event, item, navigate)),
428
- role: "menuitem"
429
- }, [
430
- (item.icon)
431
- ? (openBlock(), createElementBlock("span", {
432
- key: 0,
433
- class: normalizeClass(['p-menuitem-icon', item.icon])
434
- }, null, 2))
435
- : createCommentVNode("", true),
436
- createElementVNode("span", _hoisted_11, toDisplayString($options.label(item)), 1)
437
- ], 10, _hoisted_10)), [
438
- [_directive_ripple]
439
- ])
440
- ]),
441
- _: 2
442
- }, 1032, ["to"]))
443
- : withDirectives((openBlock(), createElementBlock("a", {
444
- key: 1,
445
- href: item.url,
446
- class: normalizeClass($options.linkClass(item)),
447
- target: item.target,
448
- onClick: $event => ($options.onLeafClick($event, item)),
449
- role: "menuitem",
450
- tabindex: $options.disabled(item) ? null : '0'
451
- }, [
452
- (item.icon)
453
- ? (openBlock(), createElementBlock("span", {
454
- key: 0,
455
- class: normalizeClass(['p-menuitem-icon', item.icon])
456
- }, null, 2))
457
- : createCommentVNode("", true),
458
- createElementVNode("span", _hoisted_13, toDisplayString($options.label(item)), 1),
459
- (item.items)
460
- ? (openBlock(), createElementBlock("span", {
461
- key: 1,
462
- class: normalizeClass(_ctx.getSubmenuIcon())
463
- }, null, 2))
464
- : createCommentVNode("", true)
465
- ], 10, _hoisted_12)), [
466
- [_directive_ripple]
467
- ])
468
- ], 64))
469
- : (openBlock(), createBlock(resolveDynamicComponent(_ctx.$slots.item), {
470
- key: 1,
471
- item: item
472
- }, null, 8, ["item"]))
473
- ], 6))
474
- : createCommentVNode("", true),
475
- ($options.visible(item) && item.separator)
476
- ? (openBlock(), createElementBlock("li", {
477
- class: normalizeClass(['p-menu-separator', item.class]),
478
- style: normalizeStyle(item.style),
479
- key: 'separator' + i.toString(),
480
- role: "separator"
481
- }, null, 6))
482
- : createCommentVNode("", true)
483
- ], 64))
484
- }), 128))
485
- ]))
486
- }), 128))
487
- ], 2))
488
- }), 128))
489
- ])
490
- ]))
491
- : createCommentVNode("", true)
492
- ], 46, _hoisted_3))
493
- : createCommentVNode("", true)
494
- ], 64))
495
- }), 128))
496
- ]),
918
+ createVNode(_component_MegaMenuSub, {
919
+ ref: $options.menubarRef,
920
+ id: $options.id + '_list',
921
+ class: "p-megamenu-root-list",
922
+ tabindex: !$props.disabled ? $props.tabindex : -1,
923
+ role: "menubar",
924
+ "aria-label": _ctx.ariaLabel,
925
+ "aria-labelledby": _ctx.ariaLabelledby,
926
+ "aria-disabled": $props.disabled || undefined,
927
+ "aria-orientation": $props.orientation,
928
+ "aria-activedescendant": $data.focused ? $options.focusedItemId : undefined,
929
+ menuId: $options.id,
930
+ focusedItemId: $data.focused ? $options.focusedItemId : undefined,
931
+ items: $options.processedItems,
932
+ horizontal: $options.horizontal,
933
+ template: _ctx.$slots.item,
934
+ activeItem: $data.activeItem,
935
+ exact: $props.exact,
936
+ level: 0,
937
+ onFocus: $options.onFocus,
938
+ onBlur: $options.onBlur,
939
+ onKeydown: $options.onKeyDown,
940
+ onItemClick: $options.onItemClick,
941
+ onItemMouseenter: $options.onItemMouseEnter
942
+ }, null, 8, ["id", "tabindex", "aria-label", "aria-labelledby", "aria-disabled", "aria-orientation", "aria-activedescendant", "menuId", "focusedItemId", "items", "horizontal", "template", "activeItem", "exact", "onFocus", "onBlur", "onKeydown", "onItemClick", "onItemMouseenter"]),
497
943
  (_ctx.$slots.end)
498
- ? (openBlock(), createElementBlock("div", _hoisted_14, [
944
+ ? (openBlock(), createElementBlock("div", _hoisted_3, [
499
945
  renderSlot(_ctx.$slots, "end")
500
946
  ]))
501
947
  : createCommentVNode("", true)
502
- ], 2))
948
+ ], 10, _hoisted_1))
503
949
  }
504
950
 
505
951
  function styleInject(css, ref) {
@@ -529,7 +975,7 @@ function styleInject(css, ref) {
529
975
  }
530
976
  }
531
977
 
532
- var css_248z = "\n.p-megamenu-root-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n.p-megamenu-root-list > .p-menuitem {\n position: relative;\n}\n.p-megamenu .p-menuitem-link {\n cursor: pointer;\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 text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n.p-megamenu .p-menuitem-text {\n line-height: 1;\n}\n.p-megamenu-panel {\n display: none;\n position: absolute;\n width: auto;\n z-index: 1;\n}\n.p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n display: block;\n}\n.p-megamenu-submenu {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n/* Horizontal */\n.p-megamenu-horizontal .p-megamenu-root-list {\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 -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n}\n\n/* Vertical */\n.p-megamenu-vertical .p-megamenu-root-list {\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n -ms-flex-direction: column;\n flex-direction: column;\n}\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n left: 100%;\n top: 0;\n}\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem > .p-menuitem-link > .p-submenu-icon {\n margin-left: auto;\n}\n.p-megamenu-grid {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n}\n.p-megamenu-col-2,\n.p-megamenu-col-3,\n.p-megamenu-col-4,\n.p-megamenu-col-6,\n.p-megamenu-col-12 {\n -webkit-box-flex: 0;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n padding: 0.5rem;\n}\n.p-megamenu-col-2 {\n width: 16.6667%;\n}\n.p-megamenu-col-3 {\n width: 25%;\n}\n.p-megamenu-col-4 {\n width: 33.3333%;\n}\n.p-megamenu-col-6 {\n width: 50%;\n}\n.p-megamenu-col-12 {\n width: 100%;\n}\n";
978
+ var css_248z = "\n.p-megamenu-root-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n.p-megamenu-root-list > .p-menuitem {\n position: relative;\n}\n.p-megamenu .p-menuitem-link {\n cursor: pointer;\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 text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n.p-megamenu .p-menuitem-text {\n line-height: 1;\n}\n.p-megamenu-panel {\n display: none;\n position: absolute;\n width: auto;\n z-index: 1;\n}\n.p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n display: block;\n}\n.p-megamenu-submenu {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n/* Horizontal */\n.p-megamenu-horizontal .p-megamenu-root-list {\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 -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n}\n\n/* Vertical */\n.p-megamenu-vertical .p-megamenu-root-list {\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n -ms-flex-direction: column;\n flex-direction: column;\n}\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n left: 100%;\n top: 0;\n}\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem > .p-menuitem-content > .p-menuitem-link > .p-submenu-icon {\n margin-left: auto;\n}\n.p-megamenu-grid {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n}\n.p-megamenu-col-2,\n.p-megamenu-col-3,\n.p-megamenu-col-4,\n.p-megamenu-col-6,\n.p-megamenu-col-12 {\n -webkit-box-flex: 0;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n padding: 0.5rem;\n}\n.p-megamenu-col-2 {\n width: 16.6667%;\n}\n.p-megamenu-col-3 {\n width: 25%;\n}\n.p-megamenu-col-4 {\n width: 33.3333%;\n}\n.p-megamenu-col-6 {\n width: 50%;\n}\n.p-megamenu-col-12 {\n width: 100%;\n}\n";
533
979
  styleInject(css_248z);
534
980
 
535
981
  script.render = render;