primeng 16.0.2 → 16.2.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 (481) hide show
  1. package/accordion/accordion.d.ts +47 -11
  2. package/api/primengconfig.d.ts +1 -1
  3. package/api/translation.d.ts +78 -0
  4. package/api/treenode.d.ts +1 -1
  5. package/avatar/avatar.d.ts +11 -1
  6. package/breadcrumb/breadcrumb.d.ts +5 -1
  7. package/button/button.d.ts +4 -1
  8. package/carousel/carousel.d.ts +17 -1
  9. package/chip/chip.d.ts +1 -0
  10. package/confirmdialog/confirmdialog.d.ts +7 -1
  11. package/contextmenu/contextmenu.d.ts +160 -68
  12. package/dialog/dialog.d.ts +1 -0
  13. package/dock/dock.d.ts +47 -2
  14. package/dom/domhandler.d.ts +1 -0
  15. package/dynamicdialog/dynamicdialog-config.d.ts +4 -0
  16. package/dynamicdialog/dynamicdialog.d.ts +2 -0
  17. package/esm2022/accordion/accordion.mjs +216 -54
  18. package/esm2022/animate/animate.mjs +7 -7
  19. package/esm2022/api/confirmationservice.mjs +3 -3
  20. package/esm2022/api/contextmenuservice.mjs +3 -3
  21. package/esm2022/api/filterservice.mjs +3 -3
  22. package/esm2022/api/messageservice.mjs +3 -3
  23. package/esm2022/api/overlayservice.mjs +3 -3
  24. package/esm2022/api/primengconfig.mjs +78 -5
  25. package/esm2022/api/shared.mjs +13 -13
  26. package/esm2022/api/translation.mjs +1 -1
  27. package/esm2022/api/treedragdropservice.mjs +3 -3
  28. package/esm2022/api/treenode.mjs +1 -1
  29. package/esm2022/autocomplete/autocomplete.mjs +10 -10
  30. package/esm2022/autofocus/autofocus.mjs +7 -7
  31. package/esm2022/avatar/avatar.mjs +24 -10
  32. package/esm2022/avatargroup/avatargroup.mjs +7 -7
  33. package/esm2022/badge/badge.mjs +10 -10
  34. package/esm2022/baseicon/baseicon.mjs +3 -3
  35. package/esm2022/blockui/blockui.mjs +26 -10
  36. package/esm2022/breadcrumb/breadcrumb.mjs +56 -39
  37. package/esm2022/button/button.mjs +47 -31
  38. package/esm2022/calendar/calendar.mjs +7 -7
  39. package/esm2022/card/card.mjs +10 -10
  40. package/esm2022/carousel/carousel.mjs +153 -27
  41. package/esm2022/cascadeselect/cascadeselect.mjs +10 -10
  42. package/esm2022/chart/chart.mjs +7 -7
  43. package/esm2022/checkbox/checkbox.mjs +7 -7
  44. package/esm2022/chip/chip.mjs +25 -20
  45. package/esm2022/chips/chips.mjs +7 -7
  46. package/esm2022/colorpicker/colorpicker.mjs +7 -7
  47. package/esm2022/confirmdialog/confirmdialog.mjs +28 -12
  48. package/esm2022/confirmpopup/confirmpopup.mjs +10 -8
  49. package/esm2022/contextmenu/contextmenu.mjs +1002 -552
  50. package/esm2022/dataview/dataview.mjs +10 -10
  51. package/esm2022/defer/defer.mjs +7 -7
  52. package/esm2022/dialog/dialog.mjs +21 -16
  53. package/esm2022/divider/divider.mjs +10 -10
  54. package/esm2022/dock/dock.mjs +290 -92
  55. package/esm2022/dom/domhandler.mjs +19 -7
  56. package/esm2022/dragdrop/dragdrop.mjs +10 -10
  57. package/esm2022/dropdown/dropdown.mjs +10 -10
  58. package/esm2022/dynamicdialog/dialogservice.mjs +3 -3
  59. package/esm2022/dynamicdialog/dynamicdialog-config.mjs +5 -1
  60. package/esm2022/dynamicdialog/dynamicdialog-ref.mjs +4 -1
  61. package/esm2022/dynamicdialog/dynamicdialog.mjs +23 -13
  62. package/esm2022/dynamicdialog/dynamicdialogcontent.mjs +3 -3
  63. package/esm2022/editor/editor.mjs +7 -7
  64. package/esm2022/fieldset/fieldset.mjs +66 -39
  65. package/esm2022/fileupload/fileupload.mjs +56 -48
  66. package/esm2022/focustrap/focustrap.mjs +7 -7
  67. package/esm2022/galleria/galleria.mjs +257 -48
  68. package/esm2022/icons/angledoubledown/angledoubledown.mjs +3 -3
  69. package/esm2022/icons/angledoubleleft/angledoubleleft.mjs +3 -3
  70. package/esm2022/icons/angledoubleright/angledoubleright.mjs +3 -3
  71. package/esm2022/icons/angledoubleup/angledoubleup.mjs +3 -3
  72. package/esm2022/icons/angledown/angledown.mjs +3 -3
  73. package/esm2022/icons/angleleft/angleleft.mjs +3 -3
  74. package/esm2022/icons/angleright/angleright.mjs +3 -3
  75. package/esm2022/icons/angleup/angleup.mjs +3 -3
  76. package/esm2022/icons/arrowdown/arrowdown.mjs +3 -3
  77. package/esm2022/icons/arrowdownleft/arrowdownleft.mjs +3 -3
  78. package/esm2022/icons/arrowdownright/arrowdownright.mjs +3 -3
  79. package/esm2022/icons/arrowleft/arrowleft.mjs +3 -3
  80. package/esm2022/icons/arrowright/arrowright.mjs +3 -3
  81. package/esm2022/icons/arrowup/arrowup.mjs +3 -3
  82. package/esm2022/icons/ban/ban.mjs +3 -3
  83. package/esm2022/icons/bars/bars.mjs +3 -3
  84. package/esm2022/icons/calendar/calendar.mjs +3 -3
  85. package/esm2022/icons/caretleft/caretleft.mjs +3 -3
  86. package/esm2022/icons/caretright/caretright.mjs +3 -3
  87. package/esm2022/icons/check/check.mjs +3 -3
  88. package/esm2022/icons/chevrondown/chevrondown.mjs +3 -3
  89. package/esm2022/icons/chevronleft/chevronleft.mjs +3 -3
  90. package/esm2022/icons/chevronright/chevronright.mjs +3 -3
  91. package/esm2022/icons/chevronup/chevronup.mjs +3 -3
  92. package/esm2022/icons/exclamationtriangle/exclamationtriangle.mjs +3 -3
  93. package/esm2022/icons/eye/eye.mjs +3 -3
  94. package/esm2022/icons/eyeslash/eyeslash.mjs +3 -3
  95. package/esm2022/icons/filter/filter.mjs +3 -3
  96. package/esm2022/icons/filterslash/filterslash.mjs +3 -3
  97. package/esm2022/icons/home/home.mjs +3 -3
  98. package/esm2022/icons/infocircle/infocircle.mjs +3 -3
  99. package/esm2022/icons/minus/minus.mjs +3 -3
  100. package/esm2022/icons/pencil/pencil.mjs +3 -3
  101. package/esm2022/icons/plus/plus.mjs +3 -3
  102. package/esm2022/icons/refresh/refresh.mjs +3 -3
  103. package/esm2022/icons/search/search.mjs +3 -3
  104. package/esm2022/icons/searchminus/searchminus.mjs +3 -3
  105. package/esm2022/icons/searchplus/searchplus.mjs +3 -3
  106. package/esm2022/icons/sortalt/sortalt.mjs +3 -3
  107. package/esm2022/icons/sortamountdown/sortamountdown.mjs +3 -3
  108. package/esm2022/icons/sortamountupalt/sortamountupalt.mjs +3 -3
  109. package/esm2022/icons/spinner/spinner.mjs +3 -3
  110. package/esm2022/icons/star/star.mjs +3 -3
  111. package/esm2022/icons/starfill/starfill.mjs +3 -3
  112. package/esm2022/icons/thlarge/thlarge.mjs +3 -3
  113. package/esm2022/icons/times/times.mjs +3 -3
  114. package/esm2022/icons/timescircle/timescircle.mjs +3 -3
  115. package/esm2022/icons/trash/trash.mjs +3 -3
  116. package/esm2022/icons/undo/undo.mjs +3 -3
  117. package/esm2022/icons/upload/upload.mjs +3 -3
  118. package/esm2022/icons/windowmaximize/windowmaximize.mjs +3 -3
  119. package/esm2022/icons/windowminimize/windowminimize.mjs +3 -3
  120. package/esm2022/image/image.mjs +76 -27
  121. package/esm2022/inplace/inplace.mjs +30 -23
  122. package/esm2022/inputmask/inputmask.mjs +7 -7
  123. package/esm2022/inputnumber/inputnumber.mjs +18 -8
  124. package/esm2022/inputswitch/inputswitch.mjs +7 -7
  125. package/esm2022/inputtext/inputtext.mjs +7 -7
  126. package/esm2022/inputtextarea/inputtextarea.mjs +7 -7
  127. package/esm2022/keyfilter/keyfilter.mjs +7 -7
  128. package/esm2022/knob/knob.mjs +7 -7
  129. package/esm2022/listbox/listbox.mjs +7 -7
  130. package/esm2022/megamenu/megamenu.mjs +1011 -353
  131. package/esm2022/menu/menu.mjs +414 -183
  132. package/esm2022/menubar/menubar.mjs +916 -294
  133. package/esm2022/message/message.mjs +7 -7
  134. package/esm2022/messages/messages.mjs +34 -34
  135. package/esm2022/multiselect/multiselect.mjs +12 -11
  136. package/esm2022/orderlist/orderlist.mjs +16 -22
  137. package/esm2022/organizationchart/organizationchart.mjs +15 -15
  138. package/esm2022/overlay/overlay.mjs +7 -7
  139. package/esm2022/overlaypanel/overlaypanel.mjs +12 -8
  140. package/esm2022/paginator/paginator.mjs +7 -7
  141. package/esm2022/panel/panel.mjs +51 -40
  142. package/esm2022/panelmenu/panelmenu.mjs +1007 -350
  143. package/esm2022/password/password.mjs +13 -13
  144. package/esm2022/picklist/picklist.mjs +7 -7
  145. package/esm2022/progressbar/progressbar.mjs +26 -22
  146. package/esm2022/progressspinner/progressspinner.mjs +12 -12
  147. package/esm2022/radiobutton/radiobutton.mjs +10 -10
  148. package/esm2022/rating/rating.mjs +7 -7
  149. package/esm2022/ripple/ripple.mjs +10 -8
  150. package/esm2022/scroller/scroller.mjs +7 -7
  151. package/esm2022/scrollpanel/scrollpanel.mjs +201 -29
  152. package/esm2022/scrolltop/scrolltop.mjs +17 -8
  153. package/esm2022/selectbutton/selectbutton.mjs +9 -9
  154. package/esm2022/sidebar/sidebar.mjs +51 -20
  155. package/esm2022/skeleton/skeleton.mjs +9 -9
  156. package/esm2022/slidemenu/slidemenu.mjs +1066 -372
  157. package/esm2022/slider/slider.mjs +7 -7
  158. package/esm2022/speeddial/speeddial.mjs +297 -21
  159. package/esm2022/spinner/spinner.mjs +7 -7
  160. package/esm2022/splitbutton/splitbutton.mjs +71 -16
  161. package/esm2022/splitter/splitter.mjs +166 -35
  162. package/esm2022/steps/steps.mjs +118 -28
  163. package/esm2022/styleclass/styleclass.mjs +7 -7
  164. package/esm2022/table/table.mjs +95 -89
  165. package/esm2022/tabmenu/tabmenu.mjs +208 -70
  166. package/esm2022/tabview/tabview.mjs +236 -53
  167. package/esm2022/tag/tag.mjs +7 -7
  168. package/esm2022/terminal/terminal.mjs +10 -10
  169. package/esm2022/terminal/terminalservice.mjs +3 -3
  170. package/esm2022/tieredmenu/tieredmenu.mjs +887 -400
  171. package/esm2022/timeline/timeline.mjs +9 -9
  172. package/esm2022/toast/toast.mjs +63 -35
  173. package/esm2022/togglebutton/togglebutton.mjs +9 -9
  174. package/esm2022/toolbar/toolbar.mjs +23 -16
  175. package/esm2022/tooltip/tooltip.mjs +14 -9
  176. package/esm2022/tree/tree.mjs +13 -13
  177. package/esm2022/treeselect/treeselect.mjs +7 -7
  178. package/esm2022/treetable/treetable.mjs +72 -72
  179. package/esm2022/tristatecheckbox/tristatecheckbox.mjs +7 -7
  180. package/esm2022/utils/objectutils.mjs +31 -1
  181. package/esm2022/utils/uniquecomponentid.mjs +2 -3
  182. package/esm2022/virtualscroller/virtualscroller.mjs +7 -7
  183. package/fesm2022/primeng-accordion.mjs +215 -53
  184. package/fesm2022/primeng-accordion.mjs.map +1 -1
  185. package/fesm2022/primeng-animate.mjs +7 -7
  186. package/fesm2022/primeng-api.mjs +108 -35
  187. package/fesm2022/primeng-api.mjs.map +1 -1
  188. package/fesm2022/primeng-autocomplete.mjs +9 -9
  189. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  190. package/fesm2022/primeng-autofocus.mjs +7 -7
  191. package/fesm2022/primeng-avatar.mjs +23 -9
  192. package/fesm2022/primeng-avatar.mjs.map +1 -1
  193. package/fesm2022/primeng-avatargroup.mjs +7 -7
  194. package/fesm2022/primeng-badge.mjs +10 -10
  195. package/fesm2022/primeng-baseicon.mjs +3 -3
  196. package/fesm2022/primeng-blockui.mjs +25 -9
  197. package/fesm2022/primeng-blockui.mjs.map +1 -1
  198. package/fesm2022/primeng-breadcrumb.mjs +55 -38
  199. package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
  200. package/fesm2022/primeng-button.mjs +46 -30
  201. package/fesm2022/primeng-button.mjs.map +1 -1
  202. package/fesm2022/primeng-calendar.mjs +7 -7
  203. package/fesm2022/primeng-card.mjs +9 -9
  204. package/fesm2022/primeng-card.mjs.map +1 -1
  205. package/fesm2022/primeng-carousel.mjs +152 -26
  206. package/fesm2022/primeng-carousel.mjs.map +1 -1
  207. package/fesm2022/primeng-cascadeselect.mjs +10 -10
  208. package/fesm2022/primeng-chart.mjs +7 -7
  209. package/fesm2022/primeng-checkbox.mjs +7 -7
  210. package/fesm2022/primeng-chip.mjs +24 -19
  211. package/fesm2022/primeng-chip.mjs.map +1 -1
  212. package/fesm2022/primeng-chips.mjs +7 -7
  213. package/fesm2022/primeng-colorpicker.mjs +7 -7
  214. package/fesm2022/primeng-confirmdialog.mjs +27 -11
  215. package/fesm2022/primeng-confirmdialog.mjs.map +1 -1
  216. package/fesm2022/primeng-confirmpopup.mjs +9 -7
  217. package/fesm2022/primeng-confirmpopup.mjs.map +1 -1
  218. package/fesm2022/primeng-contextmenu.mjs +1001 -551
  219. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  220. package/fesm2022/primeng-dataview.mjs +10 -10
  221. package/fesm2022/primeng-defer.mjs +7 -7
  222. package/fesm2022/primeng-dialog.mjs +20 -15
  223. package/fesm2022/primeng-dialog.mjs.map +1 -1
  224. package/fesm2022/primeng-divider.mjs +9 -9
  225. package/fesm2022/primeng-divider.mjs.map +1 -1
  226. package/fesm2022/primeng-dock.mjs +289 -91
  227. package/fesm2022/primeng-dock.mjs.map +1 -1
  228. package/fesm2022/primeng-dom.mjs +18 -6
  229. package/fesm2022/primeng-dom.mjs.map +1 -1
  230. package/fesm2022/primeng-dragdrop.mjs +10 -10
  231. package/fesm2022/primeng-dropdown.mjs +10 -10
  232. package/fesm2022/primeng-dynamicdialog.mjs +35 -18
  233. package/fesm2022/primeng-dynamicdialog.mjs.map +1 -1
  234. package/fesm2022/primeng-editor.mjs +7 -7
  235. package/fesm2022/primeng-fieldset.mjs +64 -37
  236. package/fesm2022/primeng-fieldset.mjs.map +1 -1
  237. package/fesm2022/primeng-fileupload.mjs +55 -47
  238. package/fesm2022/primeng-fileupload.mjs.map +1 -1
  239. package/fesm2022/primeng-focustrap.mjs +7 -7
  240. package/fesm2022/primeng-galleria.mjs +256 -47
  241. package/fesm2022/primeng-galleria.mjs.map +1 -1
  242. package/fesm2022/primeng-icons-angledoubledown.mjs +3 -3
  243. package/fesm2022/primeng-icons-angledoubleleft.mjs +3 -3
  244. package/fesm2022/primeng-icons-angledoubleright.mjs +3 -3
  245. package/fesm2022/primeng-icons-angledoubleup.mjs +3 -3
  246. package/fesm2022/primeng-icons-angledown.mjs +3 -3
  247. package/fesm2022/primeng-icons-angleleft.mjs +3 -3
  248. package/fesm2022/primeng-icons-angleright.mjs +3 -3
  249. package/fesm2022/primeng-icons-angleup.mjs +3 -3
  250. package/fesm2022/primeng-icons-arrowdown.mjs +3 -3
  251. package/fesm2022/primeng-icons-arrowdownleft.mjs +3 -3
  252. package/fesm2022/primeng-icons-arrowdownright.mjs +3 -3
  253. package/fesm2022/primeng-icons-arrowleft.mjs +3 -3
  254. package/fesm2022/primeng-icons-arrowright.mjs +3 -3
  255. package/fesm2022/primeng-icons-arrowup.mjs +3 -3
  256. package/fesm2022/primeng-icons-ban.mjs +3 -3
  257. package/fesm2022/primeng-icons-bars.mjs +3 -3
  258. package/fesm2022/primeng-icons-calendar.mjs +3 -3
  259. package/fesm2022/primeng-icons-caretleft.mjs +3 -3
  260. package/fesm2022/primeng-icons-caretright.mjs +3 -3
  261. package/fesm2022/primeng-icons-check.mjs +3 -3
  262. package/fesm2022/primeng-icons-chevrondown.mjs +3 -3
  263. package/fesm2022/primeng-icons-chevronleft.mjs +3 -3
  264. package/fesm2022/primeng-icons-chevronright.mjs +3 -3
  265. package/fesm2022/primeng-icons-chevronup.mjs +3 -3
  266. package/fesm2022/primeng-icons-exclamationtriangle.mjs +3 -3
  267. package/fesm2022/primeng-icons-eye.mjs +3 -3
  268. package/fesm2022/primeng-icons-eyeslash.mjs +3 -3
  269. package/fesm2022/primeng-icons-filter.mjs +3 -3
  270. package/fesm2022/primeng-icons-filterslash.mjs +3 -3
  271. package/fesm2022/primeng-icons-home.mjs +3 -3
  272. package/fesm2022/primeng-icons-infocircle.mjs +3 -3
  273. package/fesm2022/primeng-icons-minus.mjs +3 -3
  274. package/fesm2022/primeng-icons-pencil.mjs +3 -3
  275. package/fesm2022/primeng-icons-plus.mjs +3 -3
  276. package/fesm2022/primeng-icons-refresh.mjs +3 -3
  277. package/fesm2022/primeng-icons-search.mjs +3 -3
  278. package/fesm2022/primeng-icons-searchminus.mjs +3 -3
  279. package/fesm2022/primeng-icons-searchplus.mjs +3 -3
  280. package/fesm2022/primeng-icons-sortalt.mjs +3 -3
  281. package/fesm2022/primeng-icons-sortamountdown.mjs +3 -3
  282. package/fesm2022/primeng-icons-sortamountupalt.mjs +3 -3
  283. package/fesm2022/primeng-icons-spinner.mjs +3 -3
  284. package/fesm2022/primeng-icons-star.mjs +3 -3
  285. package/fesm2022/primeng-icons-starfill.mjs +3 -3
  286. package/fesm2022/primeng-icons-thlarge.mjs +3 -3
  287. package/fesm2022/primeng-icons-times.mjs +3 -3
  288. package/fesm2022/primeng-icons-timescircle.mjs +3 -3
  289. package/fesm2022/primeng-icons-trash.mjs +3 -3
  290. package/fesm2022/primeng-icons-undo.mjs +3 -3
  291. package/fesm2022/primeng-icons-upload.mjs +3 -3
  292. package/fesm2022/primeng-icons-windowmaximize.mjs +3 -3
  293. package/fesm2022/primeng-icons-windowminimize.mjs +3 -3
  294. package/fesm2022/primeng-image.mjs +75 -26
  295. package/fesm2022/primeng-image.mjs.map +1 -1
  296. package/fesm2022/primeng-inplace.mjs +29 -22
  297. package/fesm2022/primeng-inplace.mjs.map +1 -1
  298. package/fesm2022/primeng-inputmask.mjs +7 -7
  299. package/fesm2022/primeng-inputnumber.mjs +17 -7
  300. package/fesm2022/primeng-inputnumber.mjs.map +1 -1
  301. package/fesm2022/primeng-inputswitch.mjs +7 -7
  302. package/fesm2022/primeng-inputtext.mjs +7 -7
  303. package/fesm2022/primeng-inputtextarea.mjs +7 -7
  304. package/fesm2022/primeng-keyfilter.mjs +7 -7
  305. package/fesm2022/primeng-knob.mjs +7 -7
  306. package/fesm2022/primeng-listbox.mjs +7 -7
  307. package/fesm2022/primeng-megamenu.mjs +1010 -353
  308. package/fesm2022/primeng-megamenu.mjs.map +1 -1
  309. package/fesm2022/primeng-menu.mjs +413 -182
  310. package/fesm2022/primeng-menu.mjs.map +1 -1
  311. package/fesm2022/primeng-menubar.mjs +915 -293
  312. package/fesm2022/primeng-menubar.mjs.map +1 -1
  313. package/fesm2022/primeng-message.mjs +7 -7
  314. package/fesm2022/primeng-messages.mjs +33 -33
  315. package/fesm2022/primeng-messages.mjs.map +1 -1
  316. package/fesm2022/primeng-multiselect.mjs +11 -10
  317. package/fesm2022/primeng-multiselect.mjs.map +1 -1
  318. package/fesm2022/primeng-orderlist.mjs +15 -21
  319. package/fesm2022/primeng-orderlist.mjs.map +1 -1
  320. package/fesm2022/primeng-organizationchart.mjs +14 -14
  321. package/fesm2022/primeng-organizationchart.mjs.map +1 -1
  322. package/fesm2022/primeng-overlay.mjs +7 -7
  323. package/fesm2022/primeng-overlaypanel.mjs +11 -7
  324. package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
  325. package/fesm2022/primeng-paginator.mjs +7 -7
  326. package/fesm2022/primeng-panel.mjs +51 -40
  327. package/fesm2022/primeng-panel.mjs.map +1 -1
  328. package/fesm2022/primeng-panelmenu.mjs +1006 -350
  329. package/fesm2022/primeng-panelmenu.mjs.map +1 -1
  330. package/fesm2022/primeng-password.mjs +13 -13
  331. package/fesm2022/primeng-picklist.mjs +7 -7
  332. package/fesm2022/primeng-progressbar.mjs +25 -21
  333. package/fesm2022/primeng-progressbar.mjs.map +1 -1
  334. package/fesm2022/primeng-progressspinner.mjs +11 -11
  335. package/fesm2022/primeng-progressspinner.mjs.map +1 -1
  336. package/fesm2022/primeng-radiobutton.mjs +10 -10
  337. package/fesm2022/primeng-rating.mjs +7 -7
  338. package/fesm2022/primeng-ripple.mjs +9 -7
  339. package/fesm2022/primeng-ripple.mjs.map +1 -1
  340. package/fesm2022/primeng-scroller.mjs +7 -7
  341. package/fesm2022/primeng-scrollpanel.mjs +200 -28
  342. package/fesm2022/primeng-scrollpanel.mjs.map +1 -1
  343. package/fesm2022/primeng-scrolltop.mjs +16 -7
  344. package/fesm2022/primeng-scrolltop.mjs.map +1 -1
  345. package/fesm2022/primeng-selectbutton.mjs +9 -9
  346. package/fesm2022/primeng-selectbutton.mjs.map +1 -1
  347. package/fesm2022/primeng-sidebar.mjs +50 -19
  348. package/fesm2022/primeng-sidebar.mjs.map +1 -1
  349. package/fesm2022/primeng-skeleton.mjs +8 -8
  350. package/fesm2022/primeng-skeleton.mjs.map +1 -1
  351. package/fesm2022/primeng-slidemenu.mjs +1065 -371
  352. package/fesm2022/primeng-slidemenu.mjs.map +1 -1
  353. package/fesm2022/primeng-slider.mjs +7 -7
  354. package/fesm2022/primeng-speeddial.mjs +296 -20
  355. package/fesm2022/primeng-speeddial.mjs.map +1 -1
  356. package/fesm2022/primeng-spinner.mjs +7 -7
  357. package/fesm2022/primeng-splitbutton.mjs +70 -15
  358. package/fesm2022/primeng-splitbutton.mjs.map +1 -1
  359. package/fesm2022/primeng-splitter.mjs +166 -35
  360. package/fesm2022/primeng-splitter.mjs.map +1 -1
  361. package/fesm2022/primeng-steps.mjs +117 -27
  362. package/fesm2022/primeng-steps.mjs.map +1 -1
  363. package/fesm2022/primeng-styleclass.mjs +7 -7
  364. package/fesm2022/primeng-table.mjs +94 -88
  365. package/fesm2022/primeng-table.mjs.map +1 -1
  366. package/fesm2022/primeng-tabmenu.mjs +207 -69
  367. package/fesm2022/primeng-tabmenu.mjs.map +1 -1
  368. package/fesm2022/primeng-tabview.mjs +235 -52
  369. package/fesm2022/primeng-tabview.mjs.map +1 -1
  370. package/fesm2022/primeng-tag.mjs +7 -7
  371. package/fesm2022/primeng-terminal.mjs +12 -12
  372. package/fesm2022/primeng-terminal.mjs.map +1 -1
  373. package/fesm2022/primeng-tieredmenu.mjs +886 -399
  374. package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
  375. package/fesm2022/primeng-timeline.mjs +9 -9
  376. package/fesm2022/primeng-timeline.mjs.map +1 -1
  377. package/fesm2022/primeng-toast.mjs +62 -34
  378. package/fesm2022/primeng-toast.mjs.map +1 -1
  379. package/fesm2022/primeng-togglebutton.mjs +9 -9
  380. package/fesm2022/primeng-togglebutton.mjs.map +1 -1
  381. package/fesm2022/primeng-toolbar.mjs +22 -15
  382. package/fesm2022/primeng-toolbar.mjs.map +1 -1
  383. package/fesm2022/primeng-tooltip.mjs +13 -8
  384. package/fesm2022/primeng-tooltip.mjs.map +1 -1
  385. package/fesm2022/primeng-tree.mjs +12 -12
  386. package/fesm2022/primeng-tree.mjs.map +1 -1
  387. package/fesm2022/primeng-treeselect.mjs +7 -7
  388. package/fesm2022/primeng-treetable.mjs +71 -71
  389. package/fesm2022/primeng-treetable.mjs.map +1 -1
  390. package/fesm2022/primeng-tristatecheckbox.mjs +7 -7
  391. package/fesm2022/primeng-utils.mjs +31 -2
  392. package/fesm2022/primeng-utils.mjs.map +1 -1
  393. package/fesm2022/primeng-virtualscroller.mjs +7 -7
  394. package/fieldset/fieldset.d.ts +6 -5
  395. package/galleria/galleria.d.ts +24 -4
  396. package/image/image.d.ts +11 -1
  397. package/inplace/inplace.d.ts +6 -1
  398. package/megamenu/megamenu.d.ts +140 -16
  399. package/menu/menu.d.ts +64 -7
  400. package/menubar/menubar.d.ts +119 -23
  401. package/orderlist/orderlist.d.ts +2 -1
  402. package/package.json +98 -98
  403. package/panel/panel.d.ts +6 -5
  404. package/panelmenu/panelmenu.d.ts +136 -22
  405. package/resources/components/autocomplete/autocomplete.css +9 -8
  406. package/resources/components/breadcrumb/breadcrumb.css +9 -3
  407. package/resources/components/button/button.css +4 -0
  408. package/resources/components/common/common.css +1 -1
  409. package/resources/components/contextmenu/contextmenu.css +1 -7
  410. package/resources/components/dock/dock.css +1 -1
  411. package/resources/components/megamenu/megamenu.css +9 -10
  412. package/resources/components/menubar/menubar.css +4 -0
  413. package/resources/components/panelmenu/panelmenu.css +4 -2
  414. package/resources/components/slidemenu/slidemenu.css +40 -41
  415. package/resources/components/tabview/tabview.css +3 -2
  416. package/resources/primeng.css +4 -1
  417. package/resources/primeng.min.css +1 -1
  418. package/resources/themes/arya-blue/theme.css +358 -396
  419. package/resources/themes/arya-green/theme.css +358 -396
  420. package/resources/themes/arya-orange/theme.css +358 -396
  421. package/resources/themes/arya-purple/theme.css +358 -396
  422. package/resources/themes/bootstrap4-dark-blue/theme.css +373 -422
  423. package/resources/themes/bootstrap4-dark-purple/theme.css +373 -422
  424. package/resources/themes/bootstrap4-light-blue/theme.css +385 -434
  425. package/resources/themes/bootstrap4-light-purple/theme.css +385 -434
  426. package/resources/themes/fluent-light/theme.css +368 -406
  427. package/resources/themes/lara-dark-blue/theme.css +360 -398
  428. package/resources/themes/lara-dark-indigo/theme.css +360 -398
  429. package/resources/themes/lara-dark-purple/theme.css +360 -398
  430. package/resources/themes/lara-dark-teal/theme.css +360 -398
  431. package/resources/themes/lara-light-blue/theme.css +386 -424
  432. package/resources/themes/lara-light-indigo/theme.css +386 -424
  433. package/resources/themes/lara-light-purple/theme.css +386 -424
  434. package/resources/themes/lara-light-teal/theme.css +386 -424
  435. package/resources/themes/luna-amber/theme.css +376 -414
  436. package/resources/themes/luna-blue/theme.css +376 -414
  437. package/resources/themes/luna-green/theme.css +376 -414
  438. package/resources/themes/luna-pink/theme.css +376 -414
  439. package/resources/themes/md-dark-deeppurple/theme.css +389 -409
  440. package/resources/themes/md-dark-indigo/theme.css +389 -409
  441. package/resources/themes/md-light-deeppurple/theme.css +389 -409
  442. package/resources/themes/md-light-indigo/theme.css +389 -409
  443. package/resources/themes/mdc-dark-deeppurple/theme.css +389 -409
  444. package/resources/themes/mdc-dark-indigo/theme.css +389 -409
  445. package/resources/themes/mdc-light-deeppurple/theme.css +389 -409
  446. package/resources/themes/mdc-light-indigo/theme.css +389 -409
  447. package/resources/themes/mira/theme.css +363 -401
  448. package/resources/themes/nano/theme.css +364 -402
  449. package/resources/themes/nova/theme.css +352 -390
  450. package/resources/themes/nova-accent/theme.css +352 -390
  451. package/resources/themes/nova-alt/theme.css +352 -390
  452. package/resources/themes/rhea/theme.css +352 -390
  453. package/resources/themes/saga-blue/theme.css +364 -402
  454. package/resources/themes/saga-green/theme.css +364 -402
  455. package/resources/themes/saga-orange/theme.css +364 -402
  456. package/resources/themes/saga-purple/theme.css +364 -402
  457. package/resources/themes/soho-dark/theme.css +378 -416
  458. package/resources/themes/soho-light/theme.css +386 -424
  459. package/resources/themes/tailwind-light/theme.css +377 -415
  460. package/resources/themes/vela-blue/theme.css +364 -402
  461. package/resources/themes/vela-green/theme.css +364 -402
  462. package/resources/themes/vela-orange/theme.css +364 -402
  463. package/resources/themes/vela-purple/theme.css +364 -402
  464. package/resources/themes/viva-dark/theme.css +358 -396
  465. package/resources/themes/viva-light/theme.css +364 -402
  466. package/scrollpanel/scrollpanel.d.ts +22 -4
  467. package/scrolltop/scrolltop.d.ts +6 -1
  468. package/sidebar/sidebar.d.ts +1 -0
  469. package/slidemenu/slidemenu.d.ts +192 -86
  470. package/speeddial/speeddial.d.ts +34 -1
  471. package/splitbutton/splitbutton.d.ts +5 -1
  472. package/splitter/splitter.d.ts +18 -5
  473. package/steps/steps.d.ts +20 -3
  474. package/table/table.d.ts +3 -1
  475. package/tabmenu/tabmenu.d.ts +27 -2
  476. package/tabview/tabview.d.ts +36 -5
  477. package/tieredmenu/tieredmenu.d.ts +137 -51
  478. package/toolbar/toolbar.d.ts +6 -1
  479. package/tooltip/tooltip.d.ts +1 -1
  480. package/utils/objectutils.d.ts +4 -0
  481. package/utils/uniquecomponentid.d.ts +1 -1
@@ -1,13 +1,14 @@
1
1
  import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Injectable, Input, NgModule, Output, PLATFORM_ID, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Injectable, Input, NgModule, Output, PLATFORM_ID, ViewChild, ViewEncapsulation, effect, signal } from '@angular/core';
3
3
  import { RouterModule } from '@angular/router';
4
4
  import { PrimeTemplate, SharedModule } from 'primeng/api';
5
+ import { DomHandler } from 'primeng/dom';
5
6
  import { AngleDownIcon } from 'primeng/icons/angledown';
6
7
  import { AngleRightIcon } from 'primeng/icons/angleright';
7
8
  import { BarsIcon } from 'primeng/icons/bars';
8
9
  import { RippleModule } from 'primeng/ripple';
9
10
  import { TooltipModule } from 'primeng/tooltip';
10
- import { ZIndexUtils } from 'primeng/utils';
11
+ import { ObjectUtils, UniqueComponentId, ZIndexUtils } from 'primeng/utils';
11
12
  import { Subject, interval } from 'rxjs';
12
13
  import { debounce, filter } from 'rxjs/operators';
13
14
  import * as i0 from "@angular/core";
@@ -21,310 +22,403 @@ class MenubarService {
21
22
  autoHideDelay;
22
23
  mouseLeaves = new Subject();
23
24
  mouseLeft$ = this.mouseLeaves.pipe(debounce(() => interval(this.autoHideDelay)), filter((mouseLeft) => this.autoHide && mouseLeft));
24
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
25
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarService });
25
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
26
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarService });
26
27
  }
27
28
  export { MenubarService };
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarService, decorators: [{
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarService, decorators: [{
29
30
  type: Injectable
30
31
  }] });
31
32
  class MenubarSub {
32
- document;
33
- platformId;
34
33
  el;
35
34
  renderer;
36
35
  cd;
37
36
  menubarService;
38
- menubar;
39
- item;
40
- root;
37
+ items;
38
+ root = false;
41
39
  autoZIndex = true;
42
40
  baseZIndex = 0;
43
41
  mobileActive;
44
42
  autoDisplay;
45
- get parentActive() {
46
- return this._parentActive;
47
- }
48
- set parentActive(value) {
49
- if (!this.root) {
50
- this._parentActive = value;
51
- if (!value)
52
- this.activeItem = null;
53
- }
54
- }
55
- leafClick = new EventEmitter();
56
- _parentActive;
57
- documentClickListener;
58
- menuHoverActive = false;
59
- activeItem;
43
+ menuId;
44
+ ariaLabel;
45
+ ariaLabelledBy;
46
+ level = 0;
47
+ focusedItemId;
48
+ activeItemPath;
49
+ itemClick = new EventEmitter();
50
+ itemMouseEnter = new EventEmitter();
51
+ menuFocus = new EventEmitter();
52
+ menuBlur = new EventEmitter();
53
+ menuKeydown = new EventEmitter();
54
+ menubarViewChild;
60
55
  mouseLeaveSubscriber;
61
- constructor(document, platformId, el, renderer, cd, menubarService, menubar) {
62
- this.document = document;
63
- this.platformId = platformId;
56
+ constructor(el, renderer, cd, menubarService) {
64
57
  this.el = el;
65
58
  this.renderer = renderer;
66
59
  this.cd = cd;
67
60
  this.menubarService = menubarService;
68
- this.menubar = menubar;
69
61
  }
70
62
  ngOnInit() {
71
63
  this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => {
72
- this.activeItem = null;
73
64
  this.cd.markForCheck();
74
- this.unbindDocumentClickListener();
75
65
  });
76
66
  }
77
- onItemClick(event, item) {
78
- if (item.disabled) {
79
- event.preventDefault();
80
- return;
81
- }
82
- if (!item.url && !item.routerLink) {
83
- event.preventDefault();
84
- }
85
- if (item.command) {
86
- item.command({
87
- originalEvent: event,
88
- item: item
89
- });
90
- }
91
- if (item.items) {
92
- if (this.activeItem && item === this.activeItem) {
93
- this.activeItem = null;
94
- this.unbindDocumentClickListener();
95
- }
96
- else {
97
- this.activeItem = item;
98
- if (this.root) {
99
- this.bindDocumentClickListener();
100
- }
101
- }
102
- }
103
- if (!item.items) {
104
- this.onLeafClick();
105
- }
67
+ onItemClick(event, processedItem) {
68
+ this.getItemProp(processedItem, 'command', { originalEvent: event, item: processedItem.item });
69
+ this.itemClick.emit({ originalEvent: event, processedItem, isFocus: true });
106
70
  }
107
- onItemMouseLeave() {
108
- this.menubarService.mouseLeaves.next(true);
71
+ getItemProp(processedItem, name, params = null) {
72
+ return processedItem && processedItem.item ? ObjectUtils.getItemValue(processedItem.item[name], params) : undefined;
109
73
  }
110
- onItemMouseEnter(event, item) {
111
- this.menubarService.mouseLeaves.next(false);
112
- if (item.disabled || this.mobileActive) {
113
- event.preventDefault();
114
- return;
115
- }
116
- if (this.root) {
117
- if (this.activeItem || this.autoDisplay) {
118
- this.activeItem = item;
119
- this.bindDocumentClickListener();
120
- }
121
- }
122
- else {
123
- this.activeItem = item;
124
- this.bindDocumentClickListener();
125
- }
74
+ getItemId(processedItem) {
75
+ return `${this.menuId}_${processedItem.key}`;
126
76
  }
127
- onLeafClick() {
128
- this.activeItem = null;
129
- if (this.root) {
130
- this.unbindDocumentClickListener();
131
- }
132
- this.leafClick.emit();
77
+ getItemKey(processedItem) {
78
+ return this.getItemId(processedItem);
133
79
  }
134
- bindDocumentClickListener() {
135
- if (isPlatformBrowser(this.platformId)) {
136
- if (!this.documentClickListener) {
137
- this.documentClickListener = this.renderer.listen(this.document, 'click', (event) => {
138
- if (this.el && !this.el.nativeElement.contains(event.target)) {
139
- this.activeItem = null;
140
- this.cd.markForCheck();
141
- this.unbindDocumentClickListener();
142
- }
143
- });
144
- }
80
+ getItemClass(processedItem) {
81
+ return {
82
+ ...this.getItemProp(processedItem, 'class'),
83
+ 'p-menuitem': true,
84
+ 'p-highlight': this.isItemActive(processedItem),
85
+ 'p-menuitem-active': this.isItemActive(processedItem),
86
+ 'p-focus': this.isItemFocused(processedItem),
87
+ 'p-disabled': this.isItemDisabled(processedItem)
88
+ };
89
+ }
90
+ getItemLabel(processedItem) {
91
+ return this.getItemProp(processedItem, 'label');
92
+ }
93
+ getSeparatorItemClass(processedItem) {
94
+ return {
95
+ ...this.getItemProp(processedItem, 'class'),
96
+ 'p-menuitem-separator': true
97
+ };
98
+ }
99
+ isItemVisible(processedItem) {
100
+ return this.getItemProp(processedItem, 'visible') !== false;
101
+ }
102
+ isItemActive(processedItem) {
103
+ if (this.activeItemPath) {
104
+ return this.activeItemPath.some((path) => path.key === processedItem.key);
145
105
  }
146
106
  }
147
- unbindDocumentClickListener() {
148
- if (this.documentClickListener) {
149
- this.documentClickListener();
150
- this.documentClickListener = null;
107
+ isItemDisabled(processedItem) {
108
+ return this.getItemProp(processedItem, 'disabled');
109
+ }
110
+ isItemFocused(processedItem) {
111
+ return this.focusedItemId === this.getItemId(processedItem);
112
+ }
113
+ isItemGroup(processedItem) {
114
+ return ObjectUtils.isNotEmpty(processedItem.items);
115
+ }
116
+ getAriaSetSize() {
117
+ return this.items.filter((processedItem) => this.isItemVisible(processedItem) && !this.getItemProp(processedItem, 'separator')).length;
118
+ }
119
+ getAriaPosInset(index) {
120
+ return index - this.items.slice(0, index).filter((processedItem) => this.isItemVisible(processedItem) && this.getItemProp(processedItem, 'separator')).length + 1;
121
+ }
122
+ onItemMouseLeave() {
123
+ this.menubarService.mouseLeaves.next(true);
124
+ }
125
+ onItemMouseEnter(param) {
126
+ if (this.autoDisplay) {
127
+ this.menubarService.mouseLeaves.next(false);
128
+ const { event, processedItem } = param;
129
+ this.itemMouseEnter.emit({ originalEvent: event, processedItem });
151
130
  }
152
131
  }
153
132
  ngOnDestroy() {
154
133
  this.mouseLeaveSubscriber?.unsubscribe();
155
- this.unbindDocumentClickListener();
156
134
  }
157
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarSub, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: MenubarService }, { token: Menubar }], target: i0.ɵɵFactoryTarget.Component });
158
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: MenubarSub, selector: "p-menubarSub", inputs: { item: "item", root: "root", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", mobileActive: "mobileActive", autoDisplay: "autoDisplay", parentActive: "parentActive" }, outputs: { leafClick: "leafClick" }, host: { classAttribute: "p-element" }, ngImport: i0, template: `
159
- <ul [ngClass]="{ 'p-submenu-list': !root, 'p-menubar-root-list': root }" [attr.role]="root ? 'menubar' : 'menu'">
160
- <ng-template ngFor let-child [ngForOf]="root ? item : item?.items">
161
- <li *ngIf="child.separator" class="p-menu-separator" [ngClass]="{ 'p-hidden': child.visible === false }" role="separator"></li>
135
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarSub, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: MenubarService }], target: i0.ɵɵFactoryTarget.Component });
136
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: MenubarSub, selector: "p-menubarSub", inputs: { items: "items", root: "root", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", mobileActive: "mobileActive", autoDisplay: "autoDisplay", menuId: "menuId", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", level: "level", focusedItemId: "focusedItemId", activeItemPath: "activeItemPath" }, outputs: { itemClick: "itemClick", itemMouseEnter: "itemMouseEnter", menuFocus: "menuFocus", menuBlur: "menuBlur", menuKeydown: "menuKeydown" }, host: { classAttribute: "p-element" }, viewQueries: [{ propertyName: "menubarViewChild", first: true, predicate: ["menubar"], descendants: true, static: true }], ngImport: i0, template: `
137
+ <ul
138
+ #menubar
139
+ [ngClass]="{ 'p-submenu-list': !root, 'p-menubar-root-list': root }"
140
+ [attr.data-pc-section]="'menu'"
141
+ role="menu"
142
+ (focus)="menuFocus.emit($event)"
143
+ (blur)="menuBlur.emit($event)"
144
+ [tabindex]="0"
145
+ [attr.aria-label]="ariaLabel"
146
+ [attr.aria-labelledBy]="ariaLabelledBy"
147
+ (keydown)="menuKeydown.emit($event)"
148
+ [id]="menuId"
149
+ [attr.aria-activedescendant]="focusedItemId"
150
+ >
151
+ <ng-template ngFor let-processedItem [ngForOf]="items" let-index="index">
152
+ <li
153
+ *ngIf="isItemVisible(processedItem) && getItemProp(processedItem, 'separator')"
154
+ [id]="getItemId(processedItem)"
155
+ [style]="getItemProp(processedItem, 'style')"
156
+ [ngClass]="getSeparatorItemClass(processedItem)"
157
+ role="separator"
158
+ [attr.data-pc-section]="'separator'"
159
+ ></li>
162
160
  <li
163
- *ngIf="!child.separator"
164
161
  #listItem
165
- [ngClass]="{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }"
166
- [ngStyle]="child.style"
167
- [class]="child.styleClass"
168
- role="none"
162
+ *ngIf="isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')"
163
+ role="menuitem"
164
+ [id]="getItemId(processedItem)"
165
+ [attr.data-pc-section]="'menuitem'"
166
+ [attr.data-p-highlight]="isItemActive(processedItem)"
167
+ [attr.data-p-focused]="isItemFocused(processedItem)"
168
+ [attr.data-p-disabled]="isItemDisabled(processedItem)"
169
+ [attr.aria-label]="getItemLabel(processedItem)"
170
+ [attr.aria-disabled]="isItemDisabled(processedItem) || undefined"
171
+ [attr.aria-haspopup]="isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined"
172
+ [attr.aria-expanded]="isItemGroup(processedItem) ? isItemActive(processedItem) : undefined"
173
+ [attr.aria-level]="level + 1"
174
+ [attr.aria-setsize]="getAriaSetSize()"
175
+ [attr.aria-posinset]="getAriaPosInset(index)"
176
+ [ngStyle]="getItemProp(processedItem, 'style')"
177
+ [ngClass]="getItemClass(processedItem)"
178
+ [class]="getItemProp(processedItem, 'styleClass')"
169
179
  pTooltip
170
- [tooltipOptions]="child.tooltipOptions"
180
+ [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
171
181
  >
172
- <a
173
- *ngIf="!child.routerLink"
174
- [attr.href]="child.url"
175
- [attr.data-automationid]="child.automationId"
176
- [target]="child.target"
177
- [attr.title]="child.title"
178
- [attr.id]="child.id"
179
- role="menuitem"
180
- (click)="onItemClick($event, child)"
181
- (mouseenter)="onItemMouseEnter($event, child)"
182
- (mouseleave)="onItemMouseLeave($event, child)"
183
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
184
- [attr.tabindex]="child.disabled ? null : '0'"
185
- [attr.aria-haspopup]="item.items != null"
186
- [attr.aria-expanded]="item === activeItem"
187
- pRipple
188
- >
189
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
190
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{ child.label }}</span>
191
- <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
192
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
193
- <ng-container *ngIf="child.items">
194
- <ng-container *ngIf="!menubar.submenuIconTemplate">
195
- <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" />
196
- <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" />
182
+ <div class="p-menuitem-content" [attr.data-pc-section]="'content'" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
183
+ <a
184
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
185
+ [attr.href]="getItemProp(processedItem, 'url')"
186
+ [attr.aria-hidden]="true"
187
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
188
+ [attr.data-pc-section]="'action'"
189
+ [target]="getItemProp(processedItem, 'target')"
190
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
191
+ [attr.tabindex]="-1"
192
+ pRipple
193
+ >
194
+ <span
195
+ *ngIf="getItemProp(processedItem, 'icon')"
196
+ class="p-menuitem-icon"
197
+ [ngClass]="getItemProp(processedItem, 'icon')"
198
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
199
+ [attr.data-pc-section]="'icon'"
200
+ [attr.aria-hidden]="true"
201
+ [attr.tabindex]="-1"
202
+ >
203
+ </span>
204
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
205
+ {{ getItemLabel(processedItem) }}
206
+ </span>
207
+ <ng-template #htmlLabel>
208
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
209
+ </ng-template>
210
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
211
+
212
+ <ng-container *ngIf="isItemGroup(processedItem)">
213
+ <ng-container *ngIf="!menubar.submenuIconTemplate">
214
+ <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
215
+ <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
216
+ </ng-container>
217
+ <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
197
218
  </ng-container>
198
- <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate"></ng-template>
199
- </ng-container>
200
- </a>
201
- <a
202
- *ngIf="child.routerLink"
203
- [routerLink]="child.routerLink"
204
- [attr.data-automationid]="child.automationId"
205
- [queryParams]="child.queryParams"
206
- [routerLinkActive]="'p-menuitem-link-active'"
207
- [routerLinkActiveOptions]="child.routerLinkActiveOptions || { exact: false }"
208
- [target]="child.target"
209
- [attr.title]="child.title"
210
- [attr.id]="child.id"
211
- [attr.tabindex]="child.disabled ? null : '0'"
212
- role="menuitem"
213
- (click)="onItemClick($event, child)"
214
- (mouseenter)="onItemMouseEnter($event, child)"
215
- (mouseleave)="onItemMouseLeave($event, child)"
216
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
217
- [fragment]="child.fragment"
218
- [queryParamsHandling]="child.queryParamsHandling"
219
- [preserveFragment]="child.preserveFragment"
220
- [skipLocationChange]="child.skipLocationChange"
221
- [replaceUrl]="child.replaceUrl"
222
- [state]="child.state"
223
- pRipple
224
- >
225
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
226
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{ child.label }}</span>
227
- <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
228
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
229
- <ng-container *ngIf="child.items">
230
- <ng-container *ngIf="!menubar.submenuIconTemplate">
231
- <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" />
232
- <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" />
219
+ </a>
220
+ <a
221
+ *ngIf="getItemProp(processedItem, 'routerLink')"
222
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
223
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
224
+ [attr.tabindex]="-1"
225
+ [attr.aria-hidden]="true"
226
+ [attr.data-pc-section]="'action'"
227
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
228
+ [routerLinkActive]="'p-menuitem-link-active'"
229
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
230
+ [target]="getItemProp(processedItem, 'target')"
231
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
232
+ [fragment]="getItemProp(processedItem, 'fragment')"
233
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
234
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
235
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
236
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
237
+ [state]="getItemProp(processedItem, 'state')"
238
+ pRipple
239
+ >
240
+ <span
241
+ class="p-menuitem-icon"
242
+ *ngIf="getItemProp(processedItem, 'icon')"
243
+ [ngClass]="getItemProp(processedItem, 'icon')"
244
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
245
+ [attr.data-pc-section]="'icon'"
246
+ [attr.aria-hidden]="true"
247
+ [attr.tabindex]="-1"
248
+ ></span>
249
+ <span class="p-menuitem-text" *ngIf="getItemProp(processedItem, 'escape'); else htmlRouteLabel">{{ getItemLabel(processedItem) }}</span>
250
+ <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span></ng-template>
251
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
252
+ <ng-container *ngIf="isItemGroup(processedItem)">
253
+ <ng-container *ngIf="!menubar.submenuIconTemplate">
254
+ <AngleDownIcon [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" *ngIf="root" />
255
+ <AngleRightIcon [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" *ngIf="!root" />
256
+ </ng-container>
257
+ <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
233
258
  </ng-container>
234
- <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate"></ng-template>
235
- </ng-container>
236
- </a>
237
- <p-menubarSub [parentActive]="child === activeItem" [item]="child" *ngIf="child.items" [mobileActive]="mobileActive" [autoDisplay]="autoDisplay" (leafClick)="onLeafClick()"></p-menubarSub>
259
+ </a>
260
+ </div>
261
+ <p-menubarSub
262
+ *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
263
+ [items]="processedItem.items"
264
+ [mobileActive]="mobileActive"
265
+ [autoDisplay]="autoDisplay"
266
+ [menuId]="menuId"
267
+ [activeItemPath]="activeItemPath"
268
+ [focusedItemId]="focusedItemId"
269
+ [level]="level + 1"
270
+ (itemClick)="itemClick.emit($event)"
271
+ (itemMouseEnter)="onItemMouseEnter($event)"
272
+ >
273
+ </p-menubarSub>
238
274
  </li>
239
275
  </ng-template>
240
276
  </ul>
241
- `, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLink; }), selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.Ripple; }), selector: "[pRipple]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i0.forwardRef(function () { return AngleDownIcon; }), selector: "AngleDownIcon" }, { kind: "component", type: i0.forwardRef(function () { return AngleRightIcon; }), selector: "AngleRightIcon" }, { kind: "component", type: i0.forwardRef(function () { return MenubarSub; }), selector: "p-menubarSub", inputs: ["item", "root", "autoZIndex", "baseZIndex", "mobileActive", "autoDisplay", "parentActive"], outputs: ["leafClick"] }], encapsulation: i0.ViewEncapsulation.None });
277
+ `, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLink; }), selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.Ripple; }), selector: "[pRipple]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i0.forwardRef(function () { return AngleDownIcon; }), selector: "AngleDownIcon" }, { kind: "component", type: i0.forwardRef(function () { return AngleRightIcon; }), selector: "AngleRightIcon" }, { kind: "component", type: i0.forwardRef(function () { return MenubarSub; }), selector: "p-menubarSub", inputs: ["items", "root", "autoZIndex", "baseZIndex", "mobileActive", "autoDisplay", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], encapsulation: i0.ViewEncapsulation.None });
242
278
  }
243
279
  export { MenubarSub };
244
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarSub, decorators: [{
280
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarSub, decorators: [{
245
281
  type: Component,
246
282
  args: [{
247
283
  selector: 'p-menubarSub',
248
284
  template: `
249
- <ul [ngClass]="{ 'p-submenu-list': !root, 'p-menubar-root-list': root }" [attr.role]="root ? 'menubar' : 'menu'">
250
- <ng-template ngFor let-child [ngForOf]="root ? item : item?.items">
251
- <li *ngIf="child.separator" class="p-menu-separator" [ngClass]="{ 'p-hidden': child.visible === false }" role="separator"></li>
285
+ <ul
286
+ #menubar
287
+ [ngClass]="{ 'p-submenu-list': !root, 'p-menubar-root-list': root }"
288
+ [attr.data-pc-section]="'menu'"
289
+ role="menu"
290
+ (focus)="menuFocus.emit($event)"
291
+ (blur)="menuBlur.emit($event)"
292
+ [tabindex]="0"
293
+ [attr.aria-label]="ariaLabel"
294
+ [attr.aria-labelledBy]="ariaLabelledBy"
295
+ (keydown)="menuKeydown.emit($event)"
296
+ [id]="menuId"
297
+ [attr.aria-activedescendant]="focusedItemId"
298
+ >
299
+ <ng-template ngFor let-processedItem [ngForOf]="items" let-index="index">
300
+ <li
301
+ *ngIf="isItemVisible(processedItem) && getItemProp(processedItem, 'separator')"
302
+ [id]="getItemId(processedItem)"
303
+ [style]="getItemProp(processedItem, 'style')"
304
+ [ngClass]="getSeparatorItemClass(processedItem)"
305
+ role="separator"
306
+ [attr.data-pc-section]="'separator'"
307
+ ></li>
252
308
  <li
253
- *ngIf="!child.separator"
254
309
  #listItem
255
- [ngClass]="{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }"
256
- [ngStyle]="child.style"
257
- [class]="child.styleClass"
258
- role="none"
310
+ *ngIf="isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')"
311
+ role="menuitem"
312
+ [id]="getItemId(processedItem)"
313
+ [attr.data-pc-section]="'menuitem'"
314
+ [attr.data-p-highlight]="isItemActive(processedItem)"
315
+ [attr.data-p-focused]="isItemFocused(processedItem)"
316
+ [attr.data-p-disabled]="isItemDisabled(processedItem)"
317
+ [attr.aria-label]="getItemLabel(processedItem)"
318
+ [attr.aria-disabled]="isItemDisabled(processedItem) || undefined"
319
+ [attr.aria-haspopup]="isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined"
320
+ [attr.aria-expanded]="isItemGroup(processedItem) ? isItemActive(processedItem) : undefined"
321
+ [attr.aria-level]="level + 1"
322
+ [attr.aria-setsize]="getAriaSetSize()"
323
+ [attr.aria-posinset]="getAriaPosInset(index)"
324
+ [ngStyle]="getItemProp(processedItem, 'style')"
325
+ [ngClass]="getItemClass(processedItem)"
326
+ [class]="getItemProp(processedItem, 'styleClass')"
259
327
  pTooltip
260
- [tooltipOptions]="child.tooltipOptions"
328
+ [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
261
329
  >
262
- <a
263
- *ngIf="!child.routerLink"
264
- [attr.href]="child.url"
265
- [attr.data-automationid]="child.automationId"
266
- [target]="child.target"
267
- [attr.title]="child.title"
268
- [attr.id]="child.id"
269
- role="menuitem"
270
- (click)="onItemClick($event, child)"
271
- (mouseenter)="onItemMouseEnter($event, child)"
272
- (mouseleave)="onItemMouseLeave($event, child)"
273
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
274
- [attr.tabindex]="child.disabled ? null : '0'"
275
- [attr.aria-haspopup]="item.items != null"
276
- [attr.aria-expanded]="item === activeItem"
277
- pRipple
278
- >
279
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
280
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{ child.label }}</span>
281
- <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
282
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
283
- <ng-container *ngIf="child.items">
284
- <ng-container *ngIf="!menubar.submenuIconTemplate">
285
- <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" />
286
- <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" />
330
+ <div class="p-menuitem-content" [attr.data-pc-section]="'content'" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
331
+ <a
332
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
333
+ [attr.href]="getItemProp(processedItem, 'url')"
334
+ [attr.aria-hidden]="true"
335
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
336
+ [attr.data-pc-section]="'action'"
337
+ [target]="getItemProp(processedItem, 'target')"
338
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
339
+ [attr.tabindex]="-1"
340
+ pRipple
341
+ >
342
+ <span
343
+ *ngIf="getItemProp(processedItem, 'icon')"
344
+ class="p-menuitem-icon"
345
+ [ngClass]="getItemProp(processedItem, 'icon')"
346
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
347
+ [attr.data-pc-section]="'icon'"
348
+ [attr.aria-hidden]="true"
349
+ [attr.tabindex]="-1"
350
+ >
351
+ </span>
352
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
353
+ {{ getItemLabel(processedItem) }}
354
+ </span>
355
+ <ng-template #htmlLabel>
356
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
357
+ </ng-template>
358
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
359
+
360
+ <ng-container *ngIf="isItemGroup(processedItem)">
361
+ <ng-container *ngIf="!menubar.submenuIconTemplate">
362
+ <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
363
+ <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
364
+ </ng-container>
365
+ <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
287
366
  </ng-container>
288
- <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate"></ng-template>
289
- </ng-container>
290
- </a>
291
- <a
292
- *ngIf="child.routerLink"
293
- [routerLink]="child.routerLink"
294
- [attr.data-automationid]="child.automationId"
295
- [queryParams]="child.queryParams"
296
- [routerLinkActive]="'p-menuitem-link-active'"
297
- [routerLinkActiveOptions]="child.routerLinkActiveOptions || { exact: false }"
298
- [target]="child.target"
299
- [attr.title]="child.title"
300
- [attr.id]="child.id"
301
- [attr.tabindex]="child.disabled ? null : '0'"
302
- role="menuitem"
303
- (click)="onItemClick($event, child)"
304
- (mouseenter)="onItemMouseEnter($event, child)"
305
- (mouseleave)="onItemMouseLeave($event, child)"
306
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
307
- [fragment]="child.fragment"
308
- [queryParamsHandling]="child.queryParamsHandling"
309
- [preserveFragment]="child.preserveFragment"
310
- [skipLocationChange]="child.skipLocationChange"
311
- [replaceUrl]="child.replaceUrl"
312
- [state]="child.state"
313
- pRipple
314
- >
315
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
316
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{ child.label }}</span>
317
- <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
318
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
319
- <ng-container *ngIf="child.items">
320
- <ng-container *ngIf="!menubar.submenuIconTemplate">
321
- <AngleDownIcon [styleClass]="'p-submenu-icon'" *ngIf="root" />
322
- <AngleRightIcon [styleClass]="'p-submenu-icon'" *ngIf="!root" />
367
+ </a>
368
+ <a
369
+ *ngIf="getItemProp(processedItem, 'routerLink')"
370
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
371
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
372
+ [attr.tabindex]="-1"
373
+ [attr.aria-hidden]="true"
374
+ [attr.data-pc-section]="'action'"
375
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
376
+ [routerLinkActive]="'p-menuitem-link-active'"
377
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
378
+ [target]="getItemProp(processedItem, 'target')"
379
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
380
+ [fragment]="getItemProp(processedItem, 'fragment')"
381
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
382
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
383
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
384
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
385
+ [state]="getItemProp(processedItem, 'state')"
386
+ pRipple
387
+ >
388
+ <span
389
+ class="p-menuitem-icon"
390
+ *ngIf="getItemProp(processedItem, 'icon')"
391
+ [ngClass]="getItemProp(processedItem, 'icon')"
392
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
393
+ [attr.data-pc-section]="'icon'"
394
+ [attr.aria-hidden]="true"
395
+ [attr.tabindex]="-1"
396
+ ></span>
397
+ <span class="p-menuitem-text" *ngIf="getItemProp(processedItem, 'escape'); else htmlRouteLabel">{{ getItemLabel(processedItem) }}</span>
398
+ <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span></ng-template>
399
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
400
+ <ng-container *ngIf="isItemGroup(processedItem)">
401
+ <ng-container *ngIf="!menubar.submenuIconTemplate">
402
+ <AngleDownIcon [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" *ngIf="root" />
403
+ <AngleRightIcon [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" *ngIf="!root" />
404
+ </ng-container>
405
+ <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
323
406
  </ng-container>
324
- <ng-template *ngTemplateOutlet="menubar.submenuIconTemplate"></ng-template>
325
- </ng-container>
326
- </a>
327
- <p-menubarSub [parentActive]="child === activeItem" [item]="child" *ngIf="child.items" [mobileActive]="mobileActive" [autoDisplay]="autoDisplay" (leafClick)="onLeafClick()"></p-menubarSub>
407
+ </a>
408
+ </div>
409
+ <p-menubarSub
410
+ *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
411
+ [items]="processedItem.items"
412
+ [mobileActive]="mobileActive"
413
+ [autoDisplay]="autoDisplay"
414
+ [menuId]="menuId"
415
+ [activeItemPath]="activeItemPath"
416
+ [focusedItemId]="focusedItemId"
417
+ [level]="level + 1"
418
+ (itemClick)="itemClick.emit($event)"
419
+ (itemMouseEnter)="onItemMouseEnter($event)"
420
+ >
421
+ </p-menubarSub>
328
422
  </li>
329
423
  </ng-template>
330
424
  </ul>
@@ -334,13 +428,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
334
428
  class: 'p-element'
335
429
  }
336
430
  }]
337
- }], ctorParameters: function () { return [{ type: Document, decorators: [{
338
- type: Inject,
339
- args: [DOCUMENT]
340
- }] }, { type: undefined, decorators: [{
341
- type: Inject,
342
- args: [PLATFORM_ID]
343
- }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: MenubarService }, { type: Menubar }]; }, propDecorators: { item: [{
431
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: MenubarService }]; }, propDecorators: { items: [{
344
432
  type: Input
345
433
  }], root: [{
346
434
  type: Input
@@ -352,10 +440,31 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
352
440
  type: Input
353
441
  }], autoDisplay: [{
354
442
  type: Input
355
- }], parentActive: [{
443
+ }], menuId: [{
356
444
  type: Input
357
- }], leafClick: [{
445
+ }], ariaLabel: [{
446
+ type: Input
447
+ }], ariaLabelledBy: [{
448
+ type: Input
449
+ }], level: [{
450
+ type: Input
451
+ }], focusedItemId: [{
452
+ type: Input
453
+ }], activeItemPath: [{
454
+ type: Input
455
+ }], itemClick: [{
456
+ type: Output
457
+ }], itemMouseEnter: [{
358
458
  type: Output
459
+ }], menuFocus: [{
460
+ type: Output
461
+ }], menuBlur: [{
462
+ type: Output
463
+ }], menuKeydown: [{
464
+ type: Output
465
+ }], menubarViewChild: [{
466
+ type: ViewChild,
467
+ args: ['menubar', { static: true }]
359
468
  }] } });
360
469
  /**
361
470
  * Menubar is a horizontal menu component.
@@ -373,7 +482,13 @@ class Menubar {
373
482
  * An array of menuitems.
374
483
  * @group Props
375
484
  */
376
- model;
485
+ set model(value) {
486
+ this._model = value;
487
+ this._processedItems = this.createProcessedItems(this._model || []);
488
+ }
489
+ get model() {
490
+ return this._model;
491
+ }
377
492
  /**
378
493
  * Inline style of the element.
379
494
  * @group Props
@@ -396,9 +511,10 @@ class Menubar {
396
511
  baseZIndex = 0;
397
512
  /**
398
513
  * Whether to show a root submenu on mouse over.
514
+ * @defaultValue true
399
515
  * @group Props
400
516
  */
401
- autoDisplay;
517
+ autoDisplay = true;
402
518
  /**
403
519
  * Whether to hide a root submenu when mouse leaves.
404
520
  * @group Props
@@ -409,6 +525,33 @@ class Menubar {
409
525
  * @group Props
410
526
  */
411
527
  autoHideDelay = 100;
528
+ /**
529
+ * Current id state as a string.
530
+ * @group Props
531
+ */
532
+ id;
533
+ /**
534
+ * Defines a string value that labels an interactive element.
535
+ * @group Props
536
+ */
537
+ ariaLabel;
538
+ /**
539
+ * Identifier of the underlying input element.
540
+ * @group Props
541
+ */
542
+ ariaLabelledBy;
543
+ /**
544
+ * Callback to execute when button is focused.
545
+ * @param {FocusEvent} event - Focus event.
546
+ * @group Emits
547
+ */
548
+ onFocus = new EventEmitter();
549
+ /**
550
+ * Callback to execute when button loses focus.
551
+ * @param {FocusEvent} event - Focus event.
552
+ * @group Emits
553
+ */
554
+ onBlur = new EventEmitter();
412
555
  templates;
413
556
  menubutton;
414
557
  rootmenu;
@@ -418,7 +561,31 @@ class Menubar {
418
561
  submenuIconTemplate;
419
562
  mobileActive;
420
563
  outsideClickListener;
564
+ resizeListener;
421
565
  mouseLeaveSubscriber;
566
+ dirty = false;
567
+ focused = false;
568
+ activeItemPath = signal([]);
569
+ number = signal(0);
570
+ focusedItemInfo = signal({ index: -1, level: 0, parentKey: '' });
571
+ searchValue = '';
572
+ searchTimeout;
573
+ _processedItems;
574
+ _model;
575
+ get visibleItems() {
576
+ const processedItem = this.activeItemPath().find((p) => p.key === this.focusedItemInfo().parentKey);
577
+ return processedItem ? processedItem.items : this.processedItems;
578
+ }
579
+ get processedItems() {
580
+ if (!this._processedItems || !this._processedItems.length) {
581
+ this._processedItems = this.createProcessedItems(this.model || []);
582
+ }
583
+ return this._processedItems;
584
+ }
585
+ get focusedItemId() {
586
+ const focusedItemInfo = this.focusedItemInfo();
587
+ return focusedItemInfo.index !== -1 ? `${this.id}${ObjectUtils.isNotEmpty(focusedItemInfo.parentKey) ? '_' + focusedItemInfo.parentKey : ''}_${focusedItemInfo.index}` : null;
588
+ }
422
589
  constructor(document, platformId, el, renderer, cd, config, menubarService) {
423
590
  this.document = document;
424
591
  this.platformId = platformId;
@@ -427,11 +594,23 @@ class Menubar {
427
594
  this.cd = cd;
428
595
  this.config = config;
429
596
  this.menubarService = menubarService;
597
+ effect(() => {
598
+ const path = this.activeItemPath();
599
+ if (ObjectUtils.isNotEmpty(path)) {
600
+ this.bindOutsideClickListener();
601
+ this.bindResizeListener();
602
+ }
603
+ else {
604
+ this.unbindOutsideClickListener();
605
+ this.unbindResizeListener();
606
+ }
607
+ });
430
608
  }
431
609
  ngOnInit() {
432
610
  this.menubarService.autoHide = this.autoHide;
433
611
  this.menubarService.autoHideDelay = this.autoHideDelay;
434
612
  this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => this.unbindOutsideClickListener());
613
+ this.id = this.id || UniqueComponentId();
435
614
  }
436
615
  ngAfterContentInit() {
437
616
  this.templates?.forEach((item) => {
@@ -451,63 +630,465 @@ class Menubar {
451
630
  }
452
631
  });
453
632
  }
633
+ createProcessedItems(items, level = 0, parent = {}, parentKey = '') {
634
+ const processedItems = [];
635
+ items &&
636
+ items.forEach((item, index) => {
637
+ const key = (parentKey !== '' ? parentKey + '_' : '') + index;
638
+ const newItem = {
639
+ item,
640
+ index,
641
+ level,
642
+ key,
643
+ parent,
644
+ parentKey
645
+ };
646
+ newItem['items'] = this.createProcessedItems(item.items, level + 1, newItem, key);
647
+ processedItems.push(newItem);
648
+ });
649
+ return processedItems;
650
+ }
651
+ getItemProp(item, name) {
652
+ return item ? ObjectUtils.getItemValue(item[name]) : undefined;
653
+ }
654
+ menuButtonClick(event) {
655
+ this.toggle(event);
656
+ }
657
+ menuButtonKeydown(event) {
658
+ (event.code === 'Enter' || event.code === 'Space') && this.menuButtonClick(event);
659
+ }
660
+ onItemClick(event) {
661
+ const { originalEvent, processedItem } = event;
662
+ const grouped = this.isProcessedItemGroup(processedItem);
663
+ const root = ObjectUtils.isEmpty(processedItem.parent);
664
+ const selected = this.isSelected(processedItem);
665
+ if (selected) {
666
+ const { index, key, level, parentKey } = processedItem;
667
+ this.activeItemPath.set(this.activeItemPath().filter((p) => key !== p.key && key.startsWith(p.key)));
668
+ this.focusedItemInfo.set({ index, level, parentKey });
669
+ this.dirty = !root;
670
+ DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);
671
+ }
672
+ else {
673
+ if (grouped) {
674
+ this.onItemChange(event);
675
+ }
676
+ else {
677
+ const rootProcessedItem = root ? processedItem : this.activeItemPath().find((p) => p.parentKey === '');
678
+ this.hide(originalEvent);
679
+ this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);
680
+ this.mobileActive = false;
681
+ DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);
682
+ }
683
+ }
684
+ }
685
+ onItemMouseEnter(event) {
686
+ if (!DomHandler.isTouchDevice()) {
687
+ if (!this.mobileActive && this.dirty) {
688
+ this.onItemChange(event);
689
+ }
690
+ }
691
+ }
692
+ changeFocusedItemIndex(event, index) {
693
+ if (this.focusedItemInfo().index !== index) {
694
+ this.focusedItemInfo.mutate((value) => {
695
+ value.index = index;
696
+ });
697
+ this.scrollInView();
698
+ }
699
+ }
700
+ scrollInView(index = -1) {
701
+ const id = index !== -1 ? `${this.id}_${index}` : this.focusedItemId;
702
+ const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id="${id}"]`);
703
+ if (element) {
704
+ element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'start' });
705
+ }
706
+ }
707
+ onItemChange(event) {
708
+ const { processedItem, isFocus } = event;
709
+ if (ObjectUtils.isEmpty(processedItem))
710
+ return;
711
+ const { index, key, level, parentKey, items } = processedItem;
712
+ const grouped = ObjectUtils.isNotEmpty(items);
713
+ const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== parentKey && p.parentKey !== key);
714
+ grouped && activeItemPath.push(processedItem);
715
+ this.focusedItemInfo.set({ index, level, parentKey });
716
+ this.activeItemPath.set(activeItemPath);
717
+ grouped && (this.dirty = true);
718
+ isFocus && DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);
719
+ }
454
720
  toggle(event) {
455
721
  if (this.mobileActive) {
722
+ this.mobileActive = false;
723
+ ZIndexUtils.clear(this.rootmenu.el.nativeElement);
456
724
  this.hide();
457
- ZIndexUtils.clear(this.rootmenu?.el.nativeElement);
458
725
  }
459
726
  else {
460
727
  this.mobileActive = true;
461
- ZIndexUtils.set('menu', this.rootmenu?.el.nativeElement, this.config.zIndex.menu);
728
+ ZIndexUtils.set('menu', this.rootmenu.el.nativeElement, this.config.zIndex.menu);
729
+ setTimeout(() => {
730
+ this.show();
731
+ }, 0);
462
732
  }
733
+ this.cd.markForCheck();
463
734
  this.bindOutsideClickListener();
464
735
  event.preventDefault();
465
736
  }
737
+ hide(event, isFocus) {
738
+ if (this.mobileActive) {
739
+ setTimeout(() => {
740
+ DomHandler.focus(this.menubutton.nativeElement);
741
+ }, 0);
742
+ }
743
+ this.activeItemPath.set([]);
744
+ this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });
745
+ isFocus && DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);
746
+ this.dirty = false;
747
+ }
748
+ show() {
749
+ this.focusedItemInfo.set({ index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' });
750
+ DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);
751
+ }
752
+ onMenuFocus(event) {
753
+ this.focused = true;
754
+ const focusedItemInfo = this.focusedItemInfo().index !== -1 ? this.focusedItemInfo() : { index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' };
755
+ this.focusedItemInfo.set(focusedItemInfo);
756
+ this.onFocus.emit(event);
757
+ }
758
+ onMenuBlur(event) {
759
+ this.focused = false;
760
+ this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });
761
+ this.searchValue = '';
762
+ this.dirty = false;
763
+ this.onBlur.emit(event);
764
+ }
765
+ onKeyDown(event) {
766
+ const metaKey = event.metaKey || event.ctrlKey;
767
+ switch (event.code) {
768
+ case 'ArrowDown':
769
+ this.onArrowDownKey(event);
770
+ break;
771
+ case 'ArrowUp':
772
+ this.onArrowUpKey(event);
773
+ break;
774
+ case 'ArrowLeft':
775
+ this.onArrowLeftKey(event);
776
+ break;
777
+ case 'ArrowRight':
778
+ this.onArrowRightKey(event);
779
+ break;
780
+ case 'Home':
781
+ this.onHomeKey(event);
782
+ break;
783
+ case 'End':
784
+ this.onEndKey(event);
785
+ break;
786
+ case 'Space':
787
+ this.onSpaceKey(event);
788
+ break;
789
+ case 'Enter':
790
+ this.onEnterKey(event);
791
+ break;
792
+ case 'Escape':
793
+ this.onEscapeKey(event);
794
+ break;
795
+ case 'Tab':
796
+ this.onTabKey(event);
797
+ break;
798
+ case 'PageDown':
799
+ case 'PageUp':
800
+ case 'Backspace':
801
+ case 'ShiftLeft':
802
+ case 'ShiftRight':
803
+ //NOOP
804
+ break;
805
+ default:
806
+ if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {
807
+ this.searchItems(event, event.key);
808
+ }
809
+ break;
810
+ }
811
+ }
812
+ findFirstFocusedItemIndex() {
813
+ const selectedIndex = this.findSelectedItemIndex();
814
+ return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;
815
+ }
816
+ findFirstItemIndex() {
817
+ return this.visibleItems.findIndex((processedItem) => this.isValidItem(processedItem));
818
+ }
819
+ findSelectedItemIndex() {
820
+ return this.visibleItems.findIndex((processedItem) => this.isValidSelectedItem(processedItem));
821
+ }
822
+ isProcessedItemGroup(processedItem) {
823
+ return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
824
+ }
825
+ isSelected(processedItem) {
826
+ return this.activeItemPath().some((p) => p.key === processedItem.key);
827
+ }
828
+ isValidSelectedItem(processedItem) {
829
+ return this.isValidItem(processedItem) && this.isSelected(processedItem);
830
+ }
831
+ isValidItem(processedItem) {
832
+ return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item);
833
+ }
834
+ isItemDisabled(item) {
835
+ return this.getItemProp(item, 'disabled');
836
+ }
837
+ isItemSeparator(item) {
838
+ return this.getItemProp(item, 'separator');
839
+ }
840
+ isItemMatched(processedItem) {
841
+ return this.isValidItem(processedItem) && this.getProccessedItemLabel(processedItem).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase());
842
+ }
843
+ isProccessedItemGroup(processedItem) {
844
+ return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
845
+ }
846
+ searchItems(event, char) {
847
+ this.searchValue = (this.searchValue || '') + char;
848
+ let itemIndex = -1;
849
+ let matched = false;
850
+ if (this.focusedItemInfo().index !== -1) {
851
+ itemIndex = this.visibleItems.slice(this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem));
852
+ itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem)) : itemIndex + this.focusedItemInfo().index;
853
+ }
854
+ else {
855
+ itemIndex = this.visibleItems.findIndex((processedItem) => this.isItemMatched(processedItem));
856
+ }
857
+ if (itemIndex !== -1) {
858
+ matched = true;
859
+ }
860
+ if (itemIndex === -1 && this.focusedItemInfo().index === -1) {
861
+ itemIndex = this.findFirstFocusedItemIndex();
862
+ }
863
+ if (itemIndex !== -1) {
864
+ this.changeFocusedItemIndex(event, itemIndex);
865
+ }
866
+ if (this.searchTimeout) {
867
+ clearTimeout(this.searchTimeout);
868
+ }
869
+ this.searchTimeout = setTimeout(() => {
870
+ this.searchValue = '';
871
+ this.searchTimeout = null;
872
+ }, 500);
873
+ return matched;
874
+ }
875
+ getProccessedItemLabel(processedItem) {
876
+ return processedItem ? this.getItemLabel(processedItem.item) : undefined;
877
+ }
878
+ getItemLabel(item) {
879
+ return this.getItemProp(item, 'label');
880
+ }
881
+ onArrowDownKey(event) {
882
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
883
+ const root = processedItem ? ObjectUtils.isEmpty(processedItem.parent) : null;
884
+ if (root) {
885
+ const grouped = this.isProccessedItemGroup(processedItem);
886
+ if (grouped) {
887
+ this.onItemChange({ originalEvent: event, processedItem });
888
+ this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });
889
+ this.onArrowRightKey(event);
890
+ }
891
+ }
892
+ else {
893
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();
894
+ this.changeFocusedItemIndex(event, itemIndex);
895
+ event.preventDefault();
896
+ }
897
+ }
898
+ onArrowRightKey(event) {
899
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
900
+ const parentItem = processedItem ? this.activeItemPath().find((p) => p.key === processedItem.parentKey) : null;
901
+ if (parentItem) {
902
+ const grouped = this.isProccessedItemGroup(processedItem);
903
+ if (grouped) {
904
+ this.onItemChange({ originalEvent: event, processedItem });
905
+ this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });
906
+ this.onArrowDownKey(event);
907
+ }
908
+ }
909
+ else {
910
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();
911
+ this.changeFocusedItemIndex(event, itemIndex);
912
+ event.preventDefault();
913
+ }
914
+ }
915
+ onArrowUpKey(event) {
916
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
917
+ const root = ObjectUtils.isEmpty(processedItem.parent);
918
+ if (root) {
919
+ const grouped = this.isProccessedItemGroup(processedItem);
920
+ if (grouped) {
921
+ this.onItemChange({ originalEvent: event, processedItem });
922
+ this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });
923
+ const itemIndex = this.findLastItemIndex();
924
+ this.changeFocusedItemIndex(event, itemIndex);
925
+ }
926
+ }
927
+ else {
928
+ const parentItem = this.activeItemPath().find((p) => p.key === processedItem.parentKey);
929
+ if (this.focusedItemInfo().index === 0) {
930
+ this.focusedItemInfo.set({ index: -1, parentKey: parentItem ? parentItem.parentKey : '' });
931
+ this.searchValue = '';
932
+ this.onArrowLeftKey(event);
933
+ const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);
934
+ this.activeItemPath.set(activeItemPath);
935
+ }
936
+ else {
937
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();
938
+ this.changeFocusedItemIndex(event, itemIndex);
939
+ }
940
+ }
941
+ event.preventDefault();
942
+ }
943
+ onArrowLeftKey(event) {
944
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
945
+ const parentItem = processedItem ? this.activeItemPath().find((p) => p.key === processedItem.parentKey) : null;
946
+ if (parentItem) {
947
+ this.onItemChange({ originalEvent: event, processedItem: parentItem });
948
+ const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);
949
+ this.activeItemPath.set(activeItemPath);
950
+ event.preventDefault();
951
+ }
952
+ else {
953
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();
954
+ this.changeFocusedItemIndex(event, itemIndex);
955
+ event.preventDefault();
956
+ }
957
+ }
958
+ onHomeKey(event) {
959
+ this.changeFocusedItemIndex(event, this.findFirstItemIndex());
960
+ event.preventDefault();
961
+ }
962
+ onEndKey(event) {
963
+ this.changeFocusedItemIndex(event, this.findLastItemIndex());
964
+ event.preventDefault();
965
+ }
966
+ onSpaceKey(event) {
967
+ this.onEnterKey(event);
968
+ }
969
+ onEscapeKey(event) {
970
+ this.hide(event, true);
971
+ this.focusedItemInfo().index = this.findFirstFocusedItemIndex();
972
+ event.preventDefault();
973
+ }
974
+ onTabKey(event) {
975
+ if (this.focusedItemInfo().index !== -1) {
976
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
977
+ const grouped = this.isProccessedItemGroup(processedItem);
978
+ !grouped && this.onItemChange({ originalEvent: event, processedItem });
979
+ }
980
+ this.hide();
981
+ }
982
+ onEnterKey(event) {
983
+ if (this.focusedItemInfo().index !== -1) {
984
+ const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id="${`${this.focusedItemId}`}"]`);
985
+ const anchorElement = element && DomHandler.findSingle(element, 'a[data-pc-section="action"]');
986
+ anchorElement ? anchorElement.click() : element && element.click();
987
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
988
+ const grouped = this.isProccessedItemGroup(processedItem);
989
+ !grouped && (this.focusedItemInfo().index = this.findFirstFocusedItemIndex());
990
+ }
991
+ event.preventDefault();
992
+ }
993
+ findLastFocusedItemIndex() {
994
+ const selectedIndex = this.findSelectedItemIndex();
995
+ return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;
996
+ }
997
+ findLastItemIndex() {
998
+ return ObjectUtils.findLastIndex(this.visibleItems, (processedItem) => this.isValidItem(processedItem));
999
+ }
1000
+ findPrevItemIndex(index) {
1001
+ const matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), (processedItem) => this.isValidItem(processedItem)) : -1;
1002
+ return matchedItemIndex > -1 ? matchedItemIndex : index;
1003
+ }
1004
+ findNextItemIndex(index) {
1005
+ const matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex((processedItem) => this.isValidItem(processedItem)) : -1;
1006
+ return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
1007
+ }
1008
+ bindResizeListener() {
1009
+ if (isPlatformBrowser(this.platformId)) {
1010
+ if (!this.resizeListener) {
1011
+ this.resizeListener = this.renderer.listen(this.document.defaultView, 'resize', (event) => {
1012
+ if (!DomHandler.isTouchDevice()) {
1013
+ this.hide(event, true);
1014
+ }
1015
+ this.mobileActive = false;
1016
+ });
1017
+ }
1018
+ }
1019
+ }
466
1020
  bindOutsideClickListener() {
467
1021
  if (isPlatformBrowser(this.platformId)) {
468
1022
  if (!this.outsideClickListener) {
469
1023
  this.outsideClickListener = this.renderer.listen(this.document, 'click', (event) => {
470
- if (this.mobileActive &&
471
- this.rootmenu?.el.nativeElement !== event.target &&
472
- !this.rootmenu?.el.nativeElement.contains(event.target) &&
473
- this.menubutton?.nativeElement !== event.target &&
474
- !this.menubutton?.nativeElement.contains(event.target)) {
475
- this.hide();
1024
+ const isOutsideContainer = this.rootmenu.el.nativeElement !== event.target && !this.rootmenu.el.nativeElement.contains(event.target);
1025
+ const isOutsideMenuButton = this.mobileActive && this.menubutton.nativeElement !== event.target && !this.menubutton.nativeElement.contains(event.target);
1026
+ if (isOutsideContainer) {
1027
+ isOutsideMenuButton ? (this.mobileActive = false) : this.hide();
476
1028
  }
477
1029
  });
478
1030
  }
479
1031
  }
480
1032
  }
481
- hide() {
482
- this.mobileActive = false;
483
- this.cd.markForCheck();
484
- ZIndexUtils.clear(this.rootmenu?.el.nativeElement);
485
- this.unbindOutsideClickListener();
486
- }
487
- onLeafClick() {
488
- this.hide();
489
- }
490
1033
  unbindOutsideClickListener() {
491
1034
  if (this.outsideClickListener) {
492
1035
  this.outsideClickListener();
493
1036
  this.outsideClickListener = null;
494
1037
  }
495
1038
  }
1039
+ unbindResizeListener() {
1040
+ if (this.resizeListener) {
1041
+ this.resizeListener();
1042
+ this.resizeListener = null;
1043
+ }
1044
+ }
496
1045
  ngOnDestroy() {
497
1046
  this.mouseLeaveSubscriber?.unsubscribe();
498
1047
  this.unbindOutsideClickListener();
1048
+ this.unbindResizeListener();
499
1049
  }
500
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: Menubar, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i5.PrimeNGConfig }, { token: MenubarService }], target: i0.ɵɵFactoryTarget.Component });
501
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: Menubar, selector: "p-menubar", inputs: { model: "model", style: "style", styleClass: "styleClass", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", autoDisplay: "autoDisplay", autoHide: "autoHide", autoHideDelay: "autoHideDelay" }, host: { classAttribute: "p-element" }, providers: [MenubarService], queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "menubutton", first: true, predicate: ["menubutton"], descendants: true }, { propertyName: "rootmenu", first: true, predicate: ["rootmenu"], descendants: true }], ngImport: i0, template: `
502
- <div [ngClass]="{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }" [class]="styleClass" [ngStyle]="style">
1050
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: Menubar, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i5.PrimeNGConfig }, { token: MenubarService }], target: i0.ɵɵFactoryTarget.Component });
1051
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.0", type: Menubar, selector: "p-menubar", inputs: { model: "model", style: "style", styleClass: "styleClass", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", autoDisplay: "autoDisplay", autoHide: "autoHide", autoHideDelay: "autoHideDelay", id: "id", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy" }, outputs: { onFocus: "onFocus", onBlur: "onBlur" }, host: { classAttribute: "p-element" }, providers: [MenubarService], queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "menubutton", first: true, predicate: ["menubutton"], descendants: true }, { propertyName: "rootmenu", first: true, predicate: ["rootmenu"], descendants: true }], ngImport: i0, template: `
1052
+ <div [ngClass]="{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }" [class]="styleClass" [ngStyle]="style" [attr.data-pc-section]="'root'" [attr.data-pc-name]="'menubar'">
503
1053
  <div class="p-menubar-start" *ngIf="startTemplate">
504
1054
  <ng-container *ngTemplateOutlet="startTemplate"></ng-container>
505
1055
  </div>
506
- <a #menubutton tabindex="0" *ngIf="model && model.length > 0" class="p-menubar-button" (click)="toggle($event)">
1056
+ <a
1057
+ #menubutton
1058
+ tabindex="0"
1059
+ role="button"
1060
+ [attr.aria-haspopup]="model.length && model.length > 0 ? true : false"
1061
+ [attr.aria-expanded]="mobileActive"
1062
+ [attr.aria-controls]="id"
1063
+ [attr.aria-label]="config.translation.aria.navigation"
1064
+ [attr.data-pc-section]="'button'"
1065
+ *ngIf="model && model.length > 0"
1066
+ class="p-menubar-button"
1067
+ (click)="menuButtonClick($event)"
1068
+ (keydown)="menuButtonKeydown($event)"
1069
+ >
507
1070
  <BarsIcon *ngIf="!menuIconTemplate" />
508
1071
  <ng-template *ngTemplateOutlet="menuIconTemplate"></ng-template>
509
1072
  </a>
510
- <p-menubarSub #rootmenu [item]="model" root="root" [baseZIndex]="baseZIndex" (leafClick)="onLeafClick()" [autoZIndex]="autoZIndex" [mobileActive]="mobileActive" [autoDisplay]="autoDisplay"></p-menubarSub>
1073
+ <p-menubarSub
1074
+ #rootmenu
1075
+ [items]="processedItems"
1076
+ [menuId]="id"
1077
+ [root]="true"
1078
+ [baseZIndex]="baseZIndex"
1079
+ [autoZIndex]="autoZIndex"
1080
+ [mobileActive]="mobileActive"
1081
+ [autoDisplay]="autoDisplay"
1082
+ [ariaLabel]="ariaLabel"
1083
+ [ariaLabelledBy]="ariaLabelledBy"
1084
+ [focusedItemId]="focused ? focusedItemId : undefined"
1085
+ [activeItemPath]="activeItemPath()"
1086
+ (itemClick)="onItemClick($event)"
1087
+ (menuFocus)="onMenuFocus($event)"
1088
+ (menuBlur)="onMenuBlur($event)"
1089
+ (menuKeydown)="onKeyDown($event)"
1090
+ (itemMouseEnter)="onItemMouseEnter($event)"
1091
+ ></p-menubarSub>
511
1092
  <div class="p-menubar-end" *ngIf="endTemplate; else legacy">
512
1093
  <ng-container *ngTemplateOutlet="endTemplate"></ng-container>
513
1094
  </div>
@@ -517,21 +1098,52 @@ class Menubar {
517
1098
  </div>
518
1099
  </ng-template>
519
1100
  </div>
520
- `, isInline: true, styles: [".p-menubar{display:flex;align-items:center}.p-menubar ul{margin:0;padding:0;list-style:none}.p-menubar .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-menubar .p-menuitem-text{line-height:1}.p-menubar .p-menuitem{position:relative}.p-menubar-root-list{display:flex;align-items:center;flex-wrap:wrap}.p-menubar-root-list>li ul{display:none;z-index:1}.p-menubar-root-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block}.p-menubar .p-submenu-list{display:none;position:absolute;z-index:2}.p-menubar .p-submenu-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block;left:100%;top:0}.p-menubar .p-submenu-list .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-menubar .p-submenu-list .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-menubar .p-menubar-custom,.p-menubar .p-menubar-end{margin-left:auto;align-self:center}.p-menubar-button{display:none;cursor:pointer;align-items:center;justify-content:center}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return BarsIcon; }), selector: "BarsIcon" }, { kind: "component", type: i0.forwardRef(function () { return MenubarSub; }), selector: "p-menubarSub", inputs: ["item", "root", "autoZIndex", "baseZIndex", "mobileActive", "autoDisplay", "parentActive"], outputs: ["leafClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1101
+ `, isInline: true, styles: [".p-menubar{display:flex;align-items:center}.p-menubar ul{margin:0;padding:0;list-style:none}.p-menubar .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-menubar .p-menuitem-text{line-height:1}.p-menubar .p-menuitem{position:relative}.p-menubar-root-list{display:flex;align-items:center;flex-wrap:wrap}.p-menubar-root-list>li ul{display:none;z-index:1}.p-menubar-root-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block}.p-menubar .p-submenu-list{display:none;position:absolute;z-index:2}.p-menubar .p-submenu-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block;left:100%;top:0}.p-menubar .p-submenu-list .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-menubar .p-menubar-root-list .p-icon-wrapper,.p-menubar .p-submenu-list .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-menubar .p-menubar-custom,.p-menubar .p-menubar-end{margin-left:auto;align-self:center}.p-menubar-button{display:none;cursor:pointer;align-items:center;justify-content:center}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i0.forwardRef(function () { return BarsIcon; }), selector: "BarsIcon" }, { kind: "component", type: i0.forwardRef(function () { return MenubarSub; }), selector: "p-menubarSub", inputs: ["items", "root", "autoZIndex", "baseZIndex", "mobileActive", "autoDisplay", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
521
1102
  }
522
1103
  export { Menubar };
523
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: Menubar, decorators: [{
1104
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: Menubar, decorators: [{
524
1105
  type: Component,
525
1106
  args: [{ selector: 'p-menubar', template: `
526
- <div [ngClass]="{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }" [class]="styleClass" [ngStyle]="style">
1107
+ <div [ngClass]="{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }" [class]="styleClass" [ngStyle]="style" [attr.data-pc-section]="'root'" [attr.data-pc-name]="'menubar'">
527
1108
  <div class="p-menubar-start" *ngIf="startTemplate">
528
1109
  <ng-container *ngTemplateOutlet="startTemplate"></ng-container>
529
1110
  </div>
530
- <a #menubutton tabindex="0" *ngIf="model && model.length > 0" class="p-menubar-button" (click)="toggle($event)">
1111
+ <a
1112
+ #menubutton
1113
+ tabindex="0"
1114
+ role="button"
1115
+ [attr.aria-haspopup]="model.length && model.length > 0 ? true : false"
1116
+ [attr.aria-expanded]="mobileActive"
1117
+ [attr.aria-controls]="id"
1118
+ [attr.aria-label]="config.translation.aria.navigation"
1119
+ [attr.data-pc-section]="'button'"
1120
+ *ngIf="model && model.length > 0"
1121
+ class="p-menubar-button"
1122
+ (click)="menuButtonClick($event)"
1123
+ (keydown)="menuButtonKeydown($event)"
1124
+ >
531
1125
  <BarsIcon *ngIf="!menuIconTemplate" />
532
1126
  <ng-template *ngTemplateOutlet="menuIconTemplate"></ng-template>
533
1127
  </a>
534
- <p-menubarSub #rootmenu [item]="model" root="root" [baseZIndex]="baseZIndex" (leafClick)="onLeafClick()" [autoZIndex]="autoZIndex" [mobileActive]="mobileActive" [autoDisplay]="autoDisplay"></p-menubarSub>
1128
+ <p-menubarSub
1129
+ #rootmenu
1130
+ [items]="processedItems"
1131
+ [menuId]="id"
1132
+ [root]="true"
1133
+ [baseZIndex]="baseZIndex"
1134
+ [autoZIndex]="autoZIndex"
1135
+ [mobileActive]="mobileActive"
1136
+ [autoDisplay]="autoDisplay"
1137
+ [ariaLabel]="ariaLabel"
1138
+ [ariaLabelledBy]="ariaLabelledBy"
1139
+ [focusedItemId]="focused ? focusedItemId : undefined"
1140
+ [activeItemPath]="activeItemPath()"
1141
+ (itemClick)="onItemClick($event)"
1142
+ (menuFocus)="onMenuFocus($event)"
1143
+ (menuBlur)="onMenuBlur($event)"
1144
+ (menuKeydown)="onKeyDown($event)"
1145
+ (itemMouseEnter)="onItemMouseEnter($event)"
1146
+ ></p-menubarSub>
535
1147
  <div class="p-menubar-end" *ngIf="endTemplate; else legacy">
536
1148
  <ng-container *ngTemplateOutlet="endTemplate"></ng-container>
537
1149
  </div>
@@ -543,7 +1155,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
543
1155
  </div>
544
1156
  `, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
545
1157
  class: 'p-element'
546
- }, providers: [MenubarService], styles: [".p-menubar{display:flex;align-items:center}.p-menubar ul{margin:0;padding:0;list-style:none}.p-menubar .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-menubar .p-menuitem-text{line-height:1}.p-menubar .p-menuitem{position:relative}.p-menubar-root-list{display:flex;align-items:center;flex-wrap:wrap}.p-menubar-root-list>li ul{display:none;z-index:1}.p-menubar-root-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block}.p-menubar .p-submenu-list{display:none;position:absolute;z-index:2}.p-menubar .p-submenu-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block;left:100%;top:0}.p-menubar .p-submenu-list .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-menubar .p-submenu-list .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-menubar .p-menubar-custom,.p-menubar .p-menubar-end{margin-left:auto;align-self:center}.p-menubar-button{display:none;cursor:pointer;align-items:center;justify-content:center}\n"] }]
1158
+ }, providers: [MenubarService], styles: [".p-menubar{display:flex;align-items:center}.p-menubar ul{margin:0;padding:0;list-style:none}.p-menubar .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-menubar .p-menuitem-text{line-height:1}.p-menubar .p-menuitem{position:relative}.p-menubar-root-list{display:flex;align-items:center;flex-wrap:wrap}.p-menubar-root-list>li ul{display:none;z-index:1}.p-menubar-root-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block}.p-menubar .p-submenu-list{display:none;position:absolute;z-index:2}.p-menubar .p-submenu-list>.p-menuitem-active>p-menubarsub>.p-submenu-list{display:block;left:100%;top:0}.p-menubar .p-submenu-list .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-menubar .p-menubar-root-list .p-icon-wrapper,.p-menubar .p-submenu-list .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-menubar .p-menubar-custom,.p-menubar .p-menubar-end{margin-left:auto;align-self:center}.p-menubar-button{display:none;cursor:pointer;align-items:center;justify-content:center}\n"] }]
547
1159
  }], ctorParameters: function () { return [{ type: Document, decorators: [{
548
1160
  type: Inject,
549
1161
  args: [DOCUMENT]
@@ -566,6 +1178,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
566
1178
  type: Input
567
1179
  }], autoHideDelay: [{
568
1180
  type: Input
1181
+ }], id: [{
1182
+ type: Input
1183
+ }], ariaLabel: [{
1184
+ type: Input
1185
+ }], ariaLabelledBy: [{
1186
+ type: Input
1187
+ }], onFocus: [{
1188
+ type: Output
1189
+ }], onBlur: [{
1190
+ type: Output
569
1191
  }], templates: [{
570
1192
  type: ContentChildren,
571
1193
  args: [PrimeTemplate]
@@ -577,12 +1199,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
577
1199
  args: ['rootmenu']
578
1200
  }] } });
579
1201
  class MenubarModule {
580
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
581
- static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.2", ngImport: i0, type: MenubarModule, declarations: [Menubar, MenubarSub], imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon], exports: [Menubar, RouterModule, TooltipModule, SharedModule] });
582
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarModule, imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon, RouterModule, TooltipModule, SharedModule] });
1202
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1203
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.0", ngImport: i0, type: MenubarModule, declarations: [Menubar, MenubarSub], imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon], exports: [Menubar, RouterModule, TooltipModule, SharedModule] });
1204
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarModule, imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon, RouterModule, TooltipModule, SharedModule] });
583
1205
  }
584
1206
  export { MenubarModule };
585
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: MenubarModule, decorators: [{
1207
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: MenubarModule, decorators: [{
586
1208
  type: NgModule,
587
1209
  args: [{
588
1210
  imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon],
@@ -590,4 +1212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
590
1212
  declarations: [Menubar, MenubarSub]
591
1213
  }]
592
1214
  }] });
593
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menubar.js","sourceRoot":"","sources":["../../../src/app/components/menubar/menubar.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Injectable,\n    Input,\n    NgModule,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { MenuItem, PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { AngleDownIcon } from 'primeng/icons/angledown';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { BarsIcon } from 'primeng/icons/bars';\nimport { RippleModule } from 'primeng/ripple';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { VoidListener } from 'primeng/ts-helpers';\nimport { ZIndexUtils } from 'primeng/utils';\nimport { Subject, Subscription, interval } from 'rxjs';\nimport { debounce, filter } from 'rxjs/operators';\n\n@Injectable()\nexport class MenubarService {\n    autoHide: boolean | undefined;\n\n    autoHideDelay: number | undefined;\n\n    readonly mouseLeaves = new Subject<boolean>();\n\n    readonly mouseLeft$ = this.mouseLeaves.pipe(\n        debounce(() => interval(this.autoHideDelay)),\n        filter((mouseLeft) => (this.autoHide as boolean) && mouseLeft)\n    );\n}\n\n@Component({\n    selector: 'p-menubarSub',\n    template: `\n        <ul [ngClass]=\"{ 'p-submenu-list': !root, 'p-menubar-root-list': root }\" [attr.role]=\"root ? 'menubar' : 'menu'\">\n            <ng-template ngFor let-child [ngForOf]=\"root ? item : item?.items\">\n                <li *ngIf=\"child.separator\" class=\"p-menu-separator\" [ngClass]=\"{ 'p-hidden': child.visible === false }\" role=\"separator\"></li>\n                <li\n                    *ngIf=\"!child.separator\"\n                    #listItem\n                    [ngClass]=\"{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }\"\n                    [ngStyle]=\"child.style\"\n                    [class]=\"child.styleClass\"\n                    role=\"none\"\n                    pTooltip\n                    [tooltipOptions]=\"child.tooltipOptions\"\n                >\n                    <a\n                        *ngIf=\"!child.routerLink\"\n                        [attr.href]=\"child.url\"\n                        [attr.data-automationid]=\"child.automationId\"\n                        [target]=\"child.target\"\n                        [attr.title]=\"child.title\"\n                        [attr.id]=\"child.id\"\n                        role=\"menuitem\"\n                        (click)=\"onItemClick($event, child)\"\n                        (mouseenter)=\"onItemMouseEnter($event, child)\"\n                        (mouseleave)=\"onItemMouseLeave($event, child)\"\n                        [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': child.disabled }\"\n                        [attr.tabindex]=\"child.disabled ? null : '0'\"\n                        [attr.aria-haspopup]=\"item.items != null\"\n                        [attr.aria-expanded]=\"item === activeItem\"\n                        pRipple\n                    >\n                        <span class=\"p-menuitem-icon\" *ngIf=\"child.icon\" [ngClass]=\"child.icon\" [ngStyle]=\"child.iconStyle\"></span>\n                        <span class=\"p-menuitem-text\" *ngIf=\"child.escape !== false; else htmlLabel\">{{ child.label }}</span>\n                        <ng-template #htmlLabel><span class=\"p-menuitem-text\" [innerHTML]=\"child.label\"></span></ng-template>\n                        <span class=\"p-menuitem-badge\" *ngIf=\"child.badge\" [ngClass]=\"child.badgeStyleClass\">{{ child.badge }}</span>\n                        <ng-container *ngIf=\"child.items\">\n                            <ng-container *ngIf=\"!menubar.submenuIconTemplate\">\n                                <AngleDownIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"root\" />\n                                <AngleRightIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"!root\" />\n                            </ng-container>\n                            <ng-template *ngTemplateOutlet=\"menubar.submenuIconTemplate\"></ng-template>\n                        </ng-container>\n                    </a>\n                    <a\n                        *ngIf=\"child.routerLink\"\n                        [routerLink]=\"child.routerLink\"\n                        [attr.data-automationid]=\"child.automationId\"\n                        [queryParams]=\"child.queryParams\"\n                        [routerLinkActive]=\"'p-menuitem-link-active'\"\n                        [routerLinkActiveOptions]=\"child.routerLinkActiveOptions || { exact: false }\"\n                        [target]=\"child.target\"\n                        [attr.title]=\"child.title\"\n                        [attr.id]=\"child.id\"\n                        [attr.tabindex]=\"child.disabled ? null : '0'\"\n                        role=\"menuitem\"\n                        (click)=\"onItemClick($event, child)\"\n                        (mouseenter)=\"onItemMouseEnter($event, child)\"\n                        (mouseleave)=\"onItemMouseLeave($event, child)\"\n                        [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': child.disabled }\"\n                        [fragment]=\"child.fragment\"\n                        [queryParamsHandling]=\"child.queryParamsHandling\"\n                        [preserveFragment]=\"child.preserveFragment\"\n                        [skipLocationChange]=\"child.skipLocationChange\"\n                        [replaceUrl]=\"child.replaceUrl\"\n                        [state]=\"child.state\"\n                        pRipple\n                    >\n                        <span class=\"p-menuitem-icon\" *ngIf=\"child.icon\" [ngClass]=\"child.icon\" [ngStyle]=\"child.iconStyle\"></span>\n                        <span class=\"p-menuitem-text\" *ngIf=\"child.escape !== false; else htmlRouteLabel\">{{ child.label }}</span>\n                        <ng-template #htmlRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"child.label\"></span></ng-template>\n                        <span class=\"p-menuitem-badge\" *ngIf=\"child.badge\" [ngClass]=\"child.badgeStyleClass\">{{ child.badge }}</span>\n                        <ng-container *ngIf=\"child.items\">\n                            <ng-container *ngIf=\"!menubar.submenuIconTemplate\">\n                                <AngleDownIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"root\" />\n                                <AngleRightIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"!root\" />\n                            </ng-container>\n                            <ng-template *ngTemplateOutlet=\"menubar.submenuIconTemplate\"></ng-template>\n                        </ng-container>\n                    </a>\n                    <p-menubarSub [parentActive]=\"child === activeItem\" [item]=\"child\" *ngIf=\"child.items\" [mobileActive]=\"mobileActive\" [autoDisplay]=\"autoDisplay\" (leafClick)=\"onLeafClick()\"></p-menubarSub>\n                </li>\n            </ng-template>\n        </ul>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class MenubarSub implements OnInit, OnDestroy {\n    @Input() item: MenuItem | undefined;\n\n    @Input() root: boolean | undefined;\n\n    @Input() autoZIndex: boolean = true;\n\n    @Input() baseZIndex: number = 0;\n\n    @Input() mobileActive: boolean | undefined;\n\n    @Input() autoDisplay: boolean | undefined;\n\n    @Input() get parentActive(): boolean {\n        return this._parentActive as boolean;\n    }\n    set parentActive(value) {\n        if (!this.root) {\n            this._parentActive = value;\n\n            if (!value) this.activeItem = null;\n        }\n    }\n\n    @Output() leafClick: EventEmitter<any> = new EventEmitter();\n\n    _parentActive: boolean | undefined;\n\n    documentClickListener: VoidListener;\n\n    menuHoverActive: boolean = false;\n\n    activeItem: any;\n\n    mouseLeaveSubscriber: Subscription | undefined;\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        @Inject(PLATFORM_ID) private platformId: any,\n        public el: ElementRef,\n        public renderer: Renderer2,\n        private cd: ChangeDetectorRef,\n        private menubarService: MenubarService,\n        private menubar: Menubar\n    ) {}\n\n    ngOnInit() {\n        this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => {\n            this.activeItem = null;\n            this.cd.markForCheck();\n            this.unbindDocumentClickListener();\n        });\n    }\n\n    onItemClick(event: MouseEvent, item: MenuItem) {\n        if (item.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        if (!item.url && !item.routerLink) {\n            event.preventDefault();\n        }\n\n        if (item.command) {\n            item.command({\n                originalEvent: event,\n                item: item\n            });\n        }\n\n        if (item.items) {\n            if (this.activeItem && item === this.activeItem) {\n                this.activeItem = null;\n                this.unbindDocumentClickListener();\n            } else {\n                this.activeItem = item;\n                if (this.root) {\n                    this.bindDocumentClickListener();\n                }\n            }\n        }\n\n        if (!item.items) {\n            this.onLeafClick();\n        }\n    }\n\n    onItemMouseLeave() {\n        this.menubarService.mouseLeaves.next(true);\n    }\n\n    onItemMouseEnter(event: MouseEvent, item: MenuItem) {\n        this.menubarService.mouseLeaves.next(false);\n\n        if (item.disabled || this.mobileActive) {\n            event.preventDefault();\n            return;\n        }\n\n        if (this.root) {\n            if (this.activeItem || this.autoDisplay) {\n                this.activeItem = item;\n                this.bindDocumentClickListener();\n            }\n        } else {\n            this.activeItem = item;\n            this.bindDocumentClickListener();\n        }\n    }\n\n    onLeafClick() {\n        this.activeItem = null;\n        if (this.root) {\n            this.unbindDocumentClickListener();\n        }\n\n        this.leafClick.emit();\n    }\n\n    bindDocumentClickListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.documentClickListener) {\n                this.documentClickListener = this.renderer.listen(this.document, 'click', (event) => {\n                    if (this.el && !this.el.nativeElement.contains(event.target)) {\n                        this.activeItem = null;\n                        this.cd.markForCheck();\n                        this.unbindDocumentClickListener();\n                    }\n                });\n            }\n        }\n    }\n\n    unbindDocumentClickListener() {\n        if (this.documentClickListener) {\n            this.documentClickListener();\n            this.documentClickListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.mouseLeaveSubscriber?.unsubscribe();\n        this.unbindDocumentClickListener();\n    }\n}\n/**\n * Menubar is a horizontal menu component.\n * @group Components\n */\n@Component({\n    selector: 'p-menubar',\n    template: `\n        <div [ngClass]=\"{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }\" [class]=\"styleClass\" [ngStyle]=\"style\">\n            <div class=\"p-menubar-start\" *ngIf=\"startTemplate\">\n                <ng-container *ngTemplateOutlet=\"startTemplate\"></ng-container>\n            </div>\n            <a #menubutton tabindex=\"0\" *ngIf=\"model && model.length > 0\" class=\"p-menubar-button\" (click)=\"toggle($event)\">\n                <BarsIcon *ngIf=\"!menuIconTemplate\" />\n                <ng-template *ngTemplateOutlet=\"menuIconTemplate\"></ng-template>\n            </a>\n            <p-menubarSub #rootmenu [item]=\"model\" root=\"root\" [baseZIndex]=\"baseZIndex\" (leafClick)=\"onLeafClick()\" [autoZIndex]=\"autoZIndex\" [mobileActive]=\"mobileActive\" [autoDisplay]=\"autoDisplay\"></p-menubarSub>\n            <div class=\"p-menubar-end\" *ngIf=\"endTemplate; else legacy\">\n                <ng-container *ngTemplateOutlet=\"endTemplate\"></ng-container>\n            </div>\n            <ng-template #legacy>\n                <div class=\"p-menubar-end\">\n                    <ng-content></ng-content>\n                </div>\n            </ng-template>\n        </div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./menubar.css'],\n    host: {\n        class: 'p-element'\n    },\n    providers: [MenubarService]\n})\nexport class Menubar implements AfterContentInit, OnDestroy, OnInit {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() model: MenuItem[] | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() autoZIndex: boolean = true;\n    /**\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() baseZIndex: number = 0;\n    /**\n     * Whether to show a root submenu on mouse over.\n     * @group Props\n     */\n    @Input() autoDisplay: boolean | undefined;\n    /**\n     * Whether to hide a root submenu when mouse leaves.\n     * @group Props\n     */\n    @Input() autoHide: boolean | undefined;\n    /**\n     * Delay to hide the root submenu in milliseconds when mouse leaves.\n     * @group Props\n     */\n    @Input() autoHideDelay: number = 100;\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    @ViewChild('menubutton') menubutton: ElementRef | undefined;\n\n    @ViewChild('rootmenu') rootmenu: MenubarSub | undefined;\n\n    startTemplate: TemplateRef<any> | undefined;\n\n    endTemplate: TemplateRef<any> | undefined;\n\n    menuIconTemplate: TemplateRef<any> | undefined;\n\n    submenuIconTemplate: TemplateRef<any> | undefined;\n\n    mobileActive: boolean | undefined;\n\n    outsideClickListener: VoidListener;\n\n    mouseLeaveSubscriber: Subscription | undefined;\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        @Inject(PLATFORM_ID) private platformId: any,\n        public el: ElementRef,\n        public renderer: Renderer2,\n        public cd: ChangeDetectorRef,\n        public config: PrimeNGConfig,\n        private menubarService: MenubarService\n    ) {}\n\n    ngOnInit(): void {\n        this.menubarService.autoHide = this.autoHide;\n        this.menubarService.autoHideDelay = this.autoHideDelay;\n        this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => this.unbindOutsideClickListener());\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'start':\n                    this.startTemplate = item.template;\n                    break;\n\n                case 'end':\n                    this.endTemplate = item.template;\n                    break;\n\n                case 'menuicon':\n                    this.menuIconTemplate = item.template;\n                    break;\n\n                case 'submenuicon':\n                    this.submenuIconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    toggle(event: MouseEvent) {\n        if (this.mobileActive) {\n            this.hide();\n            ZIndexUtils.clear(this.rootmenu?.el.nativeElement);\n        } else {\n            this.mobileActive = true;\n            ZIndexUtils.set('menu', this.rootmenu?.el.nativeElement, this.config.zIndex.menu);\n        }\n\n        this.bindOutsideClickListener();\n        event.preventDefault();\n    }\n\n    bindOutsideClickListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.outsideClickListener) {\n                this.outsideClickListener = this.renderer.listen(this.document, 'click', (event) => {\n                    if (\n                        this.mobileActive &&\n                        this.rootmenu?.el.nativeElement !== event.target &&\n                        !this.rootmenu?.el.nativeElement.contains(event.target) &&\n                        this.menubutton?.nativeElement !== event.target &&\n                        !this.menubutton?.nativeElement.contains(event.target)\n                    ) {\n                        this.hide();\n                    }\n                });\n            }\n        }\n    }\n\n    hide() {\n        this.mobileActive = false;\n        this.cd.markForCheck();\n        ZIndexUtils.clear(this.rootmenu?.el.nativeElement);\n        this.unbindOutsideClickListener();\n    }\n\n    onLeafClick() {\n        this.hide();\n    }\n\n    unbindOutsideClickListener() {\n        if (this.outsideClickListener) {\n            this.outsideClickListener();\n            this.outsideClickListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.mouseLeaveSubscriber?.unsubscribe();\n        this.unbindOutsideClickListener();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon],\n    exports: [Menubar, RouterModule, TooltipModule, SharedModule],\n    declarations: [Menubar, MenubarSub]\n})\nexport class MenubarModule {}\n"]}
1215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menubar.js","sourceRoot":"","sources":["../../../src/app/components/menubar/menubar.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Injectable,\n    Input,\n    NgModule,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    effect,\n    signal\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { MenuItem, PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { AngleDownIcon } from 'primeng/icons/angledown';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { BarsIcon } from 'primeng/icons/bars';\nimport { RippleModule } from 'primeng/ripple';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { VoidListener } from 'primeng/ts-helpers';\nimport { ObjectUtils, UniqueComponentId, ZIndexUtils } from 'primeng/utils';\nimport { Subject, Subscription, interval } from 'rxjs';\nimport { debounce, filter } from 'rxjs/operators';\n\n@Injectable()\nexport class MenubarService {\n    autoHide: boolean | undefined;\n\n    autoHideDelay: number | undefined;\n\n    readonly mouseLeaves = new Subject<boolean>();\n\n    readonly mouseLeft$ = this.mouseLeaves.pipe(\n        debounce(() => interval(this.autoHideDelay)),\n        filter((mouseLeft) => (this.autoHide as boolean) && mouseLeft)\n    );\n}\n\n@Component({\n    selector: 'p-menubarSub',\n    template: `\n        <ul\n            #menubar\n            [ngClass]=\"{ 'p-submenu-list': !root, 'p-menubar-root-list': root }\"\n            [attr.data-pc-section]=\"'menu'\"\n            role=\"menu\"\n            (focus)=\"menuFocus.emit($event)\"\n            (blur)=\"menuBlur.emit($event)\"\n            [tabindex]=\"0\"\n            [attr.aria-label]=\"ariaLabel\"\n            [attr.aria-labelledBy]=\"ariaLabelledBy\"\n            (keydown)=\"menuKeydown.emit($event)\"\n            [id]=\"menuId\"\n            [attr.aria-activedescendant]=\"focusedItemId\"\n        >\n            <ng-template ngFor let-processedItem [ngForOf]=\"items\" let-index=\"index\">\n                <li\n                    *ngIf=\"isItemVisible(processedItem) && getItemProp(processedItem, 'separator')\"\n                    [id]=\"getItemId(processedItem)\"\n                    [style]=\"getItemProp(processedItem, 'style')\"\n                    [ngClass]=\"getSeparatorItemClass(processedItem)\"\n                    role=\"separator\"\n                    [attr.data-pc-section]=\"'separator'\"\n                ></li>\n                <li\n                    #listItem\n                    *ngIf=\"isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')\"\n                    role=\"menuitem\"\n                    [id]=\"getItemId(processedItem)\"\n                    [attr.data-pc-section]=\"'menuitem'\"\n                    [attr.data-p-highlight]=\"isItemActive(processedItem)\"\n                    [attr.data-p-focused]=\"isItemFocused(processedItem)\"\n                    [attr.data-p-disabled]=\"isItemDisabled(processedItem)\"\n                    [attr.aria-label]=\"getItemLabel(processedItem)\"\n                    [attr.aria-disabled]=\"isItemDisabled(processedItem) || undefined\"\n                    [attr.aria-haspopup]=\"isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined\"\n                    [attr.aria-expanded]=\"isItemGroup(processedItem) ? isItemActive(processedItem) : undefined\"\n                    [attr.aria-level]=\"level + 1\"\n                    [attr.aria-setsize]=\"getAriaSetSize()\"\n                    [attr.aria-posinset]=\"getAriaPosInset(index)\"\n                    [ngStyle]=\"getItemProp(processedItem, 'style')\"\n                    [ngClass]=\"getItemClass(processedItem)\"\n                    [class]=\"getItemProp(processedItem, 'styleClass')\"\n                    pTooltip\n                    [tooltipOptions]=\"getItemProp(processedItem, 'tooltipOptions')\"\n                >\n                    <div class=\"p-menuitem-content\" [attr.data-pc-section]=\"'content'\" (click)=\"onItemClick($event, processedItem)\" (mouseenter)=\"onItemMouseEnter({$event, processedItem})\">\n                        <a\n                            *ngIf=\"!getItemProp(processedItem, 'routerLink')\"\n                            [attr.href]=\"getItemProp(processedItem, 'url')\"\n                            [attr.aria-hidden]=\"true\"\n                            [attr.data-automationid]=\"getItemProp(processedItem, 'automationId')\"\n                            [attr.data-pc-section]=\"'action'\"\n                            [target]=\"getItemProp(processedItem, 'target')\"\n                            [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }\"\n                            [attr.tabindex]=\"-1\"\n                            pRipple\n                        >\n                            <span\n                                *ngIf=\"getItemProp(processedItem, 'icon')\"\n                                class=\"p-menuitem-icon\"\n                                [ngClass]=\"getItemProp(processedItem, 'icon')\"\n                                [ngStyle]=\"getItemProp(processedItem, 'iconStyle')\"\n                                [attr.data-pc-section]=\"'icon'\"\n                                [attr.aria-hidden]=\"true\"\n                                [attr.tabindex]=\"-1\"\n                            >\n                            </span>\n                            <span *ngIf=\"getItemProp(processedItem, 'escape'); else htmlLabel\" class=\"p-menuitem-text\" [attr.data-pc-section]=\"'label'\">\n                                {{ getItemLabel(processedItem) }}\n                            </span>\n                            <ng-template #htmlLabel>\n                                <span class=\"p-menuitem-text\" [innerHTML]=\"getItemLabel(processedItem)\" [attr.data-pc-section]=\"'label'\"></span>\n                            </ng-template>\n                            <span class=\"p-menuitem-badge\" *ngIf=\"getItemProp(processedItem, 'badge')\" [ngClass]=\"getItemProp(processedItem, 'badgeStyleClass')\">{{ child.badge }}</span>\n\n                            <ng-container *ngIf=\"isItemGroup(processedItem)\">\n                                <ng-container *ngIf=\"!menubar.submenuIconTemplate\">\n                                    <AngleDownIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"root\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" />\n                                    <AngleRightIcon [styleClass]=\"'p-submenu-icon'\" *ngIf=\"!root\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" />\n                                </ng-container>\n                                <ng-template *ngTemplateOutlet=\"menubar.submenuIconTemplate\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\"></ng-template>\n                            </ng-container>\n                        </a>\n                        <a\n                            *ngIf=\"getItemProp(processedItem, 'routerLink')\"\n                            [routerLink]=\"getItemProp(processedItem, 'routerLink')\"\n                            [attr.data-automationid]=\"getItemProp(processedItem, 'automationId')\"\n                            [attr.tabindex]=\"-1\"\n                            [attr.aria-hidden]=\"true\"\n                            [attr.data-pc-section]=\"'action'\"\n                            [queryParams]=\"getItemProp(processedItem, 'queryParams')\"\n                            [routerLinkActive]=\"'p-menuitem-link-active'\"\n                            [routerLinkActiveOptions]=\"getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }\"\n                            [target]=\"getItemProp(processedItem, 'target')\"\n                            [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }\"\n                            [fragment]=\"getItemProp(processedItem, 'fragment')\"\n                            [queryParamsHandling]=\"getItemProp(processedItem, 'queryParamsHandling')\"\n                            [preserveFragment]=\"getItemProp(processedItem, 'preserveFragment')\"\n                            [skipLocationChange]=\"getItemProp(processedItem, 'skipLocationChange')\"\n                            [replaceUrl]=\"getItemProp(processedItem, 'replaceUrl')\"\n                            [state]=\"getItemProp(processedItem, 'state')\"\n                            pRipple\n                        >\n                            <span\n                                class=\"p-menuitem-icon\"\n                                *ngIf=\"getItemProp(processedItem, 'icon')\"\n                                [ngClass]=\"getItemProp(processedItem, 'icon')\"\n                                [ngStyle]=\"getItemProp(processedItem, 'iconStyle')\"\n                                [attr.data-pc-section]=\"'icon'\"\n                                [attr.aria-hidden]=\"true\"\n                                [attr.tabindex]=\"-1\"\n                            ></span>\n                            <span class=\"p-menuitem-text\" *ngIf=\"getItemProp(processedItem, 'escape'); else htmlRouteLabel\">{{ getItemLabel(processedItem) }}</span>\n                            <ng-template #htmlRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"getItemLabel(processedItem)\" [attr.data-pc-section]=\"'label'\"></span></ng-template>\n                            <span class=\"p-menuitem-badge\" *ngIf=\"getItemProp(processedItem, 'badge')\" [ngClass]=\"getItemProp(processedItem, 'badgeStyleClass')\">{{ getItemProp(processedItem, 'badge') }}</span>\n                            <ng-container *ngIf=\"isItemGroup(processedItem)\">\n                                <ng-container *ngIf=\"!menubar.submenuIconTemplate\">\n                                    <AngleDownIcon [styleClass]=\"'p-submenu-icon'\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" *ngIf=\"root\" />\n                                    <AngleRightIcon [styleClass]=\"'p-submenu-icon'\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" *ngIf=\"!root\" />\n                                </ng-container>\n                                <ng-template *ngTemplateOutlet=\"menubar.submenuIconTemplate\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\"></ng-template>\n                            </ng-container>\n                        </a>\n                    </div>\n                    <p-menubarSub\n                        *ngIf=\"isItemVisible(processedItem) && isItemGroup(processedItem)\"\n                        [items]=\"processedItem.items\"\n                        [mobileActive]=\"mobileActive\"\n                        [autoDisplay]=\"autoDisplay\"\n                        [menuId]=\"menuId\"\n                        [activeItemPath]=\"activeItemPath\"\n                        [focusedItemId]=\"focusedItemId\"\n                        [level]=\"level + 1\"\n                        (itemClick)=\"itemClick.emit($event)\"\n                        (itemMouseEnter)=\"onItemMouseEnter($event)\"\n                    >\n                    </p-menubarSub>\n                </li>\n            </ng-template>\n        </ul>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class MenubarSub implements OnInit, OnDestroy {\n    @Input() items: any[];\n\n    @Input() root: boolean = false;\n\n    @Input() autoZIndex: boolean = true;\n\n    @Input() baseZIndex: number = 0;\n\n    @Input() mobileActive: boolean | undefined;\n\n    @Input() autoDisplay: boolean | undefined;\n\n    @Input() menuId: string | undefined;\n\n    @Input() ariaLabel: string | undefined;\n\n    @Input() ariaLabelledBy: string | undefined;\n\n    @Input() level: number = 0;\n\n    @Input() focusedItemId: string | undefined;\n\n    @Input() activeItemPath: any[];\n\n    @Output() itemClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() itemMouseEnter: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuFocus: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuBlur: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuKeydown: EventEmitter<any> = new EventEmitter();\n\n    @ViewChild('menubar', { static: true }) menubarViewChild: ElementRef;\n\n    mouseLeaveSubscriber: Subscription | undefined;\n\n    constructor(public el: ElementRef, public renderer: Renderer2, private cd: ChangeDetectorRef, private menubarService: MenubarService) {}\n\n    ngOnInit() {\n        this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => {\n            this.cd.markForCheck();\n        });\n    }\n\n    onItemClick(event: any, processedItem: any) {\n        this.getItemProp(processedItem, 'command', { originalEvent: event, item: processedItem.item });\n        this.itemClick.emit({ originalEvent: event, processedItem, isFocus: true });\n    }\n\n    getItemProp(processedItem: any, name: string, params: any | null = null) {\n        return processedItem && processedItem.item ? ObjectUtils.getItemValue(processedItem.item[name], params) : undefined;\n    }\n\n    getItemId(processedItem: any): string {\n        return `${this.menuId}_${processedItem.key}`;\n    }\n\n    getItemKey(processedItem: any): string {\n        return this.getItemId(processedItem);\n    }\n\n    getItemClass(processedItem: any) {\n        return {\n            ...this.getItemProp(processedItem, 'class'),\n            'p-menuitem': true,\n            'p-highlight': this.isItemActive(processedItem),\n            'p-menuitem-active': this.isItemActive(processedItem),\n            'p-focus': this.isItemFocused(processedItem),\n            'p-disabled': this.isItemDisabled(processedItem)\n        };\n    }\n\n    getItemLabel(processedItem: any): string {\n        return this.getItemProp(processedItem, 'label');\n    }\n\n    getSeparatorItemClass(processedItem: any) {\n        return {\n            ...this.getItemProp(processedItem, 'class'),\n            'p-menuitem-separator': true\n        };\n    }\n\n    isItemVisible(processedItem: any): boolean {\n        return this.getItemProp(processedItem, 'visible') !== false;\n    }\n\n    isItemActive(processedItem: any): boolean {\n        if (this.activeItemPath) {\n            return this.activeItemPath.some((path) => path.key === processedItem.key);\n        }\n    }\n\n    isItemDisabled(processedItem: any): boolean {\n        return this.getItemProp(processedItem, 'disabled');\n    }\n\n    isItemFocused(processedItem: any): boolean {\n        return this.focusedItemId === this.getItemId(processedItem);\n    }\n\n    isItemGroup(processedItem: any): boolean {\n        return ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    getAriaSetSize() {\n        return this.items.filter((processedItem) => this.isItemVisible(processedItem) && !this.getItemProp(processedItem, 'separator')).length;\n    }\n\n    getAriaPosInset(index: number) {\n        return index - this.items.slice(0, index).filter((processedItem) => this.isItemVisible(processedItem) && this.getItemProp(processedItem, 'separator')).length + 1;\n    }\n\n    onItemMouseLeave() {\n        this.menubarService.mouseLeaves.next(true);\n    }\n\n    onItemMouseEnter(param: any) {\n        if (this.autoDisplay) {\n            this.menubarService.mouseLeaves.next(false);\n            const { event, processedItem } = param;\n            this.itemMouseEnter.emit({ originalEvent: event, processedItem });\n        }\n    }\n\n    ngOnDestroy() {\n        this.mouseLeaveSubscriber?.unsubscribe();\n    }\n}\n/**\n * Menubar is a horizontal menu component.\n * @group Components\n */\n@Component({\n    selector: 'p-menubar',\n    template: `\n        <div [ngClass]=\"{ 'p-menubar p-component': true, 'p-menubar-mobile-active': mobileActive }\" [class]=\"styleClass\" [ngStyle]=\"style\" [attr.data-pc-section]=\"'root'\" [attr.data-pc-name]=\"'menubar'\">\n            <div class=\"p-menubar-start\" *ngIf=\"startTemplate\">\n                <ng-container *ngTemplateOutlet=\"startTemplate\"></ng-container>\n            </div>\n            <a\n                #menubutton\n                tabindex=\"0\"\n                role=\"button\"\n                [attr.aria-haspopup]=\"model.length && model.length > 0 ? true : false\"\n                [attr.aria-expanded]=\"mobileActive\"\n                [attr.aria-controls]=\"id\"\n                [attr.aria-label]=\"config.translation.aria.navigation\"\n                [attr.data-pc-section]=\"'button'\"\n                *ngIf=\"model && model.length > 0\"\n                class=\"p-menubar-button\"\n                (click)=\"menuButtonClick($event)\"\n                (keydown)=\"menuButtonKeydown($event)\"\n            >\n                <BarsIcon *ngIf=\"!menuIconTemplate\" />\n                <ng-template *ngTemplateOutlet=\"menuIconTemplate\"></ng-template>\n            </a>\n            <p-menubarSub\n                #rootmenu\n                [items]=\"processedItems\"\n                [menuId]=\"id\"\n                [root]=\"true\"\n                [baseZIndex]=\"baseZIndex\"\n                [autoZIndex]=\"autoZIndex\"\n                [mobileActive]=\"mobileActive\"\n                [autoDisplay]=\"autoDisplay\"\n                [ariaLabel]=\"ariaLabel\"\n                [ariaLabelledBy]=\"ariaLabelledBy\"\n                [focusedItemId]=\"focused ? focusedItemId : undefined\"\n                [activeItemPath]=\"activeItemPath()\"\n                (itemClick)=\"onItemClick($event)\"\n                (menuFocus)=\"onMenuFocus($event)\"\n                (menuBlur)=\"onMenuBlur($event)\"\n                (menuKeydown)=\"onKeyDown($event)\"\n                (itemMouseEnter)=\"onItemMouseEnter($event)\"\n            ></p-menubarSub>\n            <div class=\"p-menubar-end\" *ngIf=\"endTemplate; else legacy\">\n                <ng-container *ngTemplateOutlet=\"endTemplate\"></ng-container>\n            </div>\n            <ng-template #legacy>\n                <div class=\"p-menubar-end\">\n                    <ng-content></ng-content>\n                </div>\n            </ng-template>\n        </div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./menubar.css'],\n    host: {\n        class: 'p-element'\n    },\n    providers: [MenubarService]\n})\nexport class Menubar implements AfterContentInit, OnDestroy, OnInit {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() set model(value: MenuItem[] | undefined) {\n        this._model = value;\n        this._processedItems = this.createProcessedItems(this._model || []);\n    }\n    get model(): MenuItem[] | undefined {\n        return this._model;\n    }\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() autoZIndex: boolean = true;\n    /**\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() baseZIndex: number = 0;\n    /**\n     * Whether to show a root submenu on mouse over.\n     * @defaultValue true\n     * @group Props\n     */\n    @Input() autoDisplay: boolean | undefined = true;\n    /**\n     * Whether to hide a root submenu when mouse leaves.\n     * @group Props\n     */\n    @Input() autoHide: boolean | undefined;\n    /**\n     * Delay to hide the root submenu in milliseconds when mouse leaves.\n     * @group Props\n     */\n    @Input() autoHideDelay: number = 100;\n    /**\n     * Current id state as a string.\n     * @group Props\n     */\n    @Input() id: string | undefined;\n    /**\n     * Defines a string value that labels an interactive element.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Identifier of the underlying input element.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Callback to execute when button is focused.\n     * @param {FocusEvent} event - Focus event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n    /**\n     * Callback to execute when button loses focus.\n     * @param {FocusEvent} event - Focus event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    @ViewChild('menubutton') menubutton: ElementRef | undefined;\n\n    @ViewChild('rootmenu') rootmenu: MenubarSub | undefined;\n\n    startTemplate: TemplateRef<any> | undefined;\n\n    endTemplate: TemplateRef<any> | undefined;\n\n    menuIconTemplate: TemplateRef<any> | undefined;\n\n    submenuIconTemplate: TemplateRef<any> | undefined;\n\n    mobileActive: boolean | undefined;\n\n    outsideClickListener: VoidListener;\n\n    resizeListener: VoidListener;\n\n    mouseLeaveSubscriber: Subscription | undefined;\n\n    dirty: boolean = false;\n\n    focused: boolean = false;\n\n    activeItemPath = signal<any>([]);\n\n    number = signal<number>(0);\n\n    focusedItemInfo = signal<any>({ index: -1, level: 0, parentKey: '' });\n\n    searchValue: string = '';\n\n    searchTimeout: any;\n\n    _processedItems: any[];\n\n    _model: MenuItem[] | undefined;\n\n    get visibleItems() {\n        const processedItem = this.activeItemPath().find((p) => p.key === this.focusedItemInfo().parentKey);\n\n        return processedItem ? processedItem.items : this.processedItems;\n    }\n\n    get processedItems() {\n        if (!this._processedItems || !this._processedItems.length) {\n            this._processedItems = this.createProcessedItems(this.model || []);\n        }\n        return this._processedItems;\n    }\n\n    get focusedItemId() {\n        const focusedItemInfo = this.focusedItemInfo();\n        return focusedItemInfo.index !== -1 ? `${this.id}${ObjectUtils.isNotEmpty(focusedItemInfo.parentKey) ? '_' + focusedItemInfo.parentKey : ''}_${focusedItemInfo.index}` : null;\n    }\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        @Inject(PLATFORM_ID) private platformId: any,\n        public el: ElementRef,\n        public renderer: Renderer2,\n        public cd: ChangeDetectorRef,\n        public config: PrimeNGConfig,\n        private menubarService: MenubarService\n    ) {\n        effect(() => {\n            const path = this.activeItemPath();\n\n            if (ObjectUtils.isNotEmpty(path)) {\n                this.bindOutsideClickListener();\n                this.bindResizeListener();\n            } else {\n                this.unbindOutsideClickListener();\n                this.unbindResizeListener();\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        this.menubarService.autoHide = this.autoHide;\n        this.menubarService.autoHideDelay = this.autoHideDelay;\n        this.mouseLeaveSubscriber = this.menubarService.mouseLeft$.subscribe(() => this.unbindOutsideClickListener());\n        this.id = this.id || UniqueComponentId();\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'start':\n                    this.startTemplate = item.template;\n                    break;\n\n                case 'end':\n                    this.endTemplate = item.template;\n                    break;\n\n                case 'menuicon':\n                    this.menuIconTemplate = item.template;\n                    break;\n\n                case 'submenuicon':\n                    this.submenuIconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    createProcessedItems(items: any, level: number = 0, parent: any = {}, parentKey: any = '') {\n        const processedItems = [];\n\n        items &&\n            items.forEach((item, index) => {\n                const key = (parentKey !== '' ? parentKey + '_' : '') + index;\n                const newItem = {\n                    item,\n                    index,\n                    level,\n                    key,\n                    parent,\n                    parentKey\n                };\n\n                newItem['items'] = this.createProcessedItems(item.items, level + 1, newItem, key);\n                processedItems.push(newItem);\n            });\n\n        return processedItems;\n    }\n\n    getItemProp(item: any, name: string) {\n        return item ? ObjectUtils.getItemValue(item[name]) : undefined;\n    }\n\n    menuButtonClick(event: MouseEvent) {\n        this.toggle(event);\n    }\n\n    menuButtonKeydown(event: any) {\n        (event.code === 'Enter' || event.code === 'Space') && this.menuButtonClick(event);\n    }\n\n    onItemClick(event: any) {\n        const { originalEvent, processedItem } = event;\n        const grouped = this.isProcessedItemGroup(processedItem);\n        const root = ObjectUtils.isEmpty(processedItem.parent);\n        const selected = this.isSelected(processedItem);\n\n        if (selected) {\n            const { index, key, level, parentKey } = processedItem;\n\n            this.activeItemPath.set(this.activeItemPath().filter((p) => key !== p.key && key.startsWith(p.key)));\n            this.focusedItemInfo.set({ index, level, parentKey });\n\n            this.dirty = !root;\n            DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);\n        } else {\n            if (grouped) {\n                this.onItemChange(event);\n            } else {\n                const rootProcessedItem = root ? processedItem : this.activeItemPath().find((p) => p.parentKey === '');\n                this.hide(originalEvent);\n                this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);\n\n                this.mobileActive = false;\n                DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);\n            }\n        }\n    }\n\n    onItemMouseEnter(event: any) {\n        if (!DomHandler.isTouchDevice()) {\n            if (!this.mobileActive && this.dirty) {\n                this.onItemChange(event);\n            }\n        }\n    }\n\n    changeFocusedItemIndex(event: any, index: number) {\n        if (this.focusedItemInfo().index !== index) {\n            this.focusedItemInfo.mutate((value) => {\n                value.index = index;\n            });\n            this.scrollInView();\n        }\n    }\n\n    scrollInView(index: number = -1) {\n        const id = index !== -1 ? `${this.id}_${index}` : this.focusedItemId;\n        const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id=\"${id}\"]`);\n\n        if (element) {\n            element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'start' });\n        }\n    }\n\n    onItemChange(event: any) {\n        const { processedItem, isFocus } = event;\n\n        if (ObjectUtils.isEmpty(processedItem)) return;\n\n        const { index, key, level, parentKey, items } = processedItem;\n        const grouped = ObjectUtils.isNotEmpty(items);\n        const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== parentKey && p.parentKey !== key);\n\n        grouped && activeItemPath.push(processedItem);\n        this.focusedItemInfo.set({ index, level, parentKey });\n        this.activeItemPath.set(activeItemPath);\n\n        grouped && (this.dirty = true);\n        isFocus && DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);\n    }\n\n    toggle(event: MouseEvent) {\n        if (this.mobileActive) {\n            this.mobileActive = false;\n            ZIndexUtils.clear(this.rootmenu.el.nativeElement);\n            this.hide();\n        } else {\n            this.mobileActive = true;\n            ZIndexUtils.set('menu', this.rootmenu.el.nativeElement, this.config.zIndex.menu);\n            setTimeout(() => {\n                this.show();\n            }, 0);\n        }\n        this.cd.markForCheck();\n        this.bindOutsideClickListener();\n        event.preventDefault();\n    }\n\n    hide(event?, isFocus?: boolean) {\n        if (this.mobileActive) {\n            setTimeout(() => {\n                DomHandler.focus(this.menubutton.nativeElement);\n            }, 0);\n        }\n\n        this.activeItemPath.set([]);\n        this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });\n\n        isFocus && DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);\n        this.dirty = false;\n    }\n\n    show() {\n        this.focusedItemInfo.set({ index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' });\n        DomHandler.focus(this.rootmenu.menubarViewChild.nativeElement);\n    }\n\n    onMenuFocus(event: any) {\n        this.focused = true;\n        const focusedItemInfo = this.focusedItemInfo().index !== -1 ? this.focusedItemInfo() : { index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' };\n\n        this.focusedItemInfo.set(focusedItemInfo);\n        this.onFocus.emit(event);\n    }\n\n    onMenuBlur(event: any) {\n        this.focused = false;\n        this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });\n        this.searchValue = '';\n        this.dirty = false;\n        this.onBlur.emit(event);\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        const metaKey = event.metaKey || event.ctrlKey;\n\n        switch (event.code) {\n            case 'ArrowDown':\n                this.onArrowDownKey(event);\n                break;\n\n            case 'ArrowUp':\n                this.onArrowUpKey(event);\n                break;\n\n            case 'ArrowLeft':\n                this.onArrowLeftKey(event);\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKey(event);\n                break;\n\n            case 'Home':\n                this.onHomeKey(event);\n                break;\n\n            case 'End':\n                this.onEndKey(event);\n                break;\n\n            case 'Space':\n                this.onSpaceKey(event);\n                break;\n\n            case 'Enter':\n                this.onEnterKey(event);\n                break;\n\n            case 'Escape':\n                this.onEscapeKey(event);\n                break;\n\n            case 'Tab':\n                this.onTabKey(event);\n                break;\n\n            case 'PageDown':\n            case 'PageUp':\n            case 'Backspace':\n            case 'ShiftLeft':\n            case 'ShiftRight':\n                //NOOP\n                break;\n\n            default:\n                if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {\n                    this.searchItems(event, event.key);\n                }\n\n                break;\n        }\n    }\n\n    findFirstFocusedItemIndex() {\n        const selectedIndex = this.findSelectedItemIndex();\n\n        return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;\n    }\n\n    findFirstItemIndex() {\n        return this.visibleItems.findIndex((processedItem) => this.isValidItem(processedItem));\n    }\n\n    findSelectedItemIndex() {\n        return this.visibleItems.findIndex((processedItem) => this.isValidSelectedItem(processedItem));\n    }\n\n    isProcessedItemGroup(processedItem: any): boolean {\n        return processedItem && ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    isSelected(processedItem: any): boolean {\n        return this.activeItemPath().some((p) => p.key === processedItem.key);\n    }\n\n    isValidSelectedItem(processedItem: any): boolean {\n        return this.isValidItem(processedItem) && this.isSelected(processedItem);\n    }\n\n    isValidItem(processedItem: any): boolean {\n        return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item);\n    }\n\n    isItemDisabled(item: any): boolean {\n        return this.getItemProp(item, 'disabled');\n    }\n\n    isItemSeparator(item: any): boolean {\n        return this.getItemProp(item, 'separator');\n    }\n\n    isItemMatched(processedItem: any): boolean {\n        return this.isValidItem(processedItem) && this.getProccessedItemLabel(processedItem).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase());\n    }\n\n    isProccessedItemGroup(processedItem: any): boolean {\n        return processedItem && ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    searchItems(event: any, char: string) {\n        this.searchValue = (this.searchValue || '') + char;\n\n        let itemIndex = -1;\n        let matched = false;\n\n        if (this.focusedItemInfo().index !== -1) {\n            itemIndex = this.visibleItems.slice(this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem));\n            itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem)) : itemIndex + this.focusedItemInfo().index;\n        } else {\n            itemIndex = this.visibleItems.findIndex((processedItem) => this.isItemMatched(processedItem));\n        }\n\n        if (itemIndex !== -1) {\n            matched = true;\n        }\n\n        if (itemIndex === -1 && this.focusedItemInfo().index === -1) {\n            itemIndex = this.findFirstFocusedItemIndex();\n        }\n\n        if (itemIndex !== -1) {\n            this.changeFocusedItemIndex(event, itemIndex);\n        }\n\n        if (this.searchTimeout) {\n            clearTimeout(this.searchTimeout);\n        }\n\n        this.searchTimeout = setTimeout(() => {\n            this.searchValue = '';\n            this.searchTimeout = null;\n        }, 500);\n\n        return matched;\n    }\n\n    getProccessedItemLabel(processedItem: any) {\n        return processedItem ? this.getItemLabel(processedItem.item) : undefined;\n    }\n\n    getItemLabel(item: any) {\n        return this.getItemProp(item, 'label');\n    }\n\n    onArrowDownKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const root = processedItem ? ObjectUtils.isEmpty(processedItem.parent) : null;\n\n        if (root) {\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            if (grouped) {\n                this.onItemChange({ originalEvent: event, processedItem });\n                this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });\n                this.onArrowRightKey(event);\n            }\n        } else {\n            const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();\n\n            this.changeFocusedItemIndex(event, itemIndex);\n            event.preventDefault();\n        }\n    }\n\n    onArrowRightKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const parentItem = processedItem ? this.activeItemPath().find((p) => p.key === processedItem.parentKey) : null;\n\n        if (parentItem) {\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            if (grouped) {\n                this.onItemChange({ originalEvent: event, processedItem });\n                this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });\n                this.onArrowDownKey(event);\n            }\n        } else {\n            const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();\n\n            this.changeFocusedItemIndex(event, itemIndex);\n            event.preventDefault();\n        }\n    }\n\n    onArrowUpKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const root = ObjectUtils.isEmpty(processedItem.parent);\n\n        if (root) {\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            if (grouped) {\n                this.onItemChange({ originalEvent: event, processedItem });\n                this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });\n                const itemIndex = this.findLastItemIndex();\n\n                this.changeFocusedItemIndex(event, itemIndex);\n            }\n        } else {\n            const parentItem = this.activeItemPath().find((p) => p.key === processedItem.parentKey);\n            if (this.focusedItemInfo().index === 0) {\n                this.focusedItemInfo.set({ index: -1, parentKey: parentItem ? parentItem.parentKey : '' });\n                this.searchValue = '';\n                this.onArrowLeftKey(event);\n                const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);\n                this.activeItemPath.set(activeItemPath);\n            } else {\n                const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();\n                this.changeFocusedItemIndex(event, itemIndex);\n            }\n        }\n\n        event.preventDefault();\n    }\n\n    onArrowLeftKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const parentItem = processedItem ? this.activeItemPath().find((p) => p.key === processedItem.parentKey) : null;\n\n        if (parentItem) {\n            this.onItemChange({ originalEvent: event, processedItem: parentItem });\n            const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);\n            this.activeItemPath.set(activeItemPath);\n\n            event.preventDefault();\n        } else {\n            const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();\n            this.changeFocusedItemIndex(event, itemIndex);\n            event.preventDefault();\n        }\n    }\n\n    onHomeKey(event: KeyboardEvent) {\n        this.changeFocusedItemIndex(event, this.findFirstItemIndex());\n        event.preventDefault();\n    }\n\n    onEndKey(event: KeyboardEvent) {\n        this.changeFocusedItemIndex(event, this.findLastItemIndex());\n        event.preventDefault();\n    }\n\n    onSpaceKey(event: KeyboardEvent) {\n        this.onEnterKey(event);\n    }\n\n    onEscapeKey(event: KeyboardEvent) {\n        this.hide(event, true);\n        this.focusedItemInfo().index = this.findFirstFocusedItemIndex();\n\n        event.preventDefault();\n    }\n\n    onTabKey(event: KeyboardEvent) {\n        if (this.focusedItemInfo().index !== -1) {\n            const processedItem = this.visibleItems[this.focusedItemInfo().index];\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            !grouped && this.onItemChange({ originalEvent: event, processedItem });\n        }\n\n        this.hide();\n    }\n\n    onEnterKey(event: KeyboardEvent) {\n        if (this.focusedItemInfo().index !== -1) {\n            const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id=\"${`${this.focusedItemId}`}\"]`);\n            const anchorElement = element && DomHandler.findSingle(element, 'a[data-pc-section=\"action\"]');\n\n            anchorElement ? anchorElement.click() : element && element.click();\n\n            const processedItem = this.visibleItems[this.focusedItemInfo().index];\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            !grouped && (this.focusedItemInfo().index = this.findFirstFocusedItemIndex());\n        }\n\n        event.preventDefault();\n    }\n\n    findLastFocusedItemIndex() {\n        const selectedIndex = this.findSelectedItemIndex();\n        return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;\n    }\n\n    findLastItemIndex() {\n        return ObjectUtils.findLastIndex(this.visibleItems, (processedItem) => this.isValidItem(processedItem));\n    }\n\n    findPrevItemIndex(index: number) {\n        const matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), (processedItem) => this.isValidItem(processedItem)) : -1;\n\n        return matchedItemIndex > -1 ? matchedItemIndex : index;\n    }\n\n    findNextItemIndex(index: number) {\n        const matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex((processedItem) => this.isValidItem(processedItem)) : -1;\n\n        return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;\n    }\n\n    bindResizeListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.resizeListener) {\n                this.resizeListener = this.renderer.listen(this.document.defaultView, 'resize', (event) => {\n                    if (!DomHandler.isTouchDevice()) {\n                        this.hide(event, true);\n                    }\n\n                    this.mobileActive = false;\n                });\n            }\n        }\n    }\n\n    bindOutsideClickListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.outsideClickListener) {\n                this.outsideClickListener = this.renderer.listen(this.document, 'click', (event) => {\n                    const isOutsideContainer = this.rootmenu.el.nativeElement !== event.target && !this.rootmenu.el.nativeElement.contains(event.target);\n                    const isOutsideMenuButton = this.mobileActive && this.menubutton.nativeElement !== event.target && !this.menubutton.nativeElement.contains(event.target);\n\n                    if (isOutsideContainer) {\n                        isOutsideMenuButton ? (this.mobileActive = false) : this.hide();\n                    }\n                });\n            }\n        }\n    }\n\n    unbindOutsideClickListener() {\n        if (this.outsideClickListener) {\n            this.outsideClickListener();\n            this.outsideClickListener = null;\n        }\n    }\n\n    unbindResizeListener() {\n        if (this.resizeListener) {\n            this.resizeListener();\n            this.resizeListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.mouseLeaveSubscriber?.unsubscribe();\n        this.unbindOutsideClickListener();\n        this.unbindResizeListener();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, RippleModule, TooltipModule, SharedModule, BarsIcon, AngleDownIcon, AngleRightIcon],\n    exports: [Menubar, RouterModule, TooltipModule, SharedModule],\n    declarations: [Menubar, MenubarSub]\n})\nexport class MenubarModule {}\n"]}