primevue 3.40.0 → 3.41.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.
- package/README.md +2 -20
- package/autocomplete/AutoComplete.vue +1 -1
- package/autocomplete/autocomplete.cjs.js +1 -1
- package/autocomplete/autocomplete.cjs.min.js +1 -1
- package/autocomplete/autocomplete.esm.js +1 -1
- package/autocomplete/autocomplete.esm.min.js +1 -1
- package/autocomplete/autocomplete.js +1 -1
- package/autocomplete/autocomplete.min.js +1 -1
- package/baseicon/BaseIcon.vue +3 -0
- package/baseicon/baseicon.cjs.js +4 -0
- package/baseicon/baseicon.cjs.min.js +1 -1
- package/baseicon/baseicon.esm.js +3 -0
- package/baseicon/baseicon.esm.min.js +1 -1
- package/baseicon/baseicon.js +5 -2
- package/baseicon/baseicon.min.js +1 -1
- package/breadcrumb/BreadcrumbItem.vue +1 -1
- package/breadcrumb/breadcrumb.cjs.js +1 -1
- package/breadcrumb/breadcrumb.cjs.min.js +1 -1
- package/breadcrumb/breadcrumb.esm.js +1 -1
- package/breadcrumb/breadcrumb.esm.min.js +1 -1
- package/breadcrumb/breadcrumb.js +1 -1
- package/breadcrumb/breadcrumb.min.js +1 -1
- package/calendar/BaseCalendar.vue +4 -0
- package/calendar/Calendar.d.ts +6 -1
- package/calendar/Calendar.vue +9 -1
- package/calendar/calendar.cjs.js +54 -43
- package/calendar/calendar.cjs.min.js +1 -1
- package/calendar/calendar.esm.js +54 -43
- package/calendar/calendar.esm.min.js +1 -1
- package/calendar/calendar.js +54 -43
- package/calendar/calendar.min.js +1 -1
- package/calendar/style/calendarstyle.cjs.js +1 -0
- package/calendar/style/calendarstyle.cjs.min.js +1 -1
- package/calendar/style/calendarstyle.esm.js +1 -0
- package/calendar/style/calendarstyle.esm.min.js +1 -1
- package/calendar/style/calendarstyle.js +1 -0
- package/calendar/style/calendarstyle.min.js +1 -1
- package/confirmationoptions/ConfirmationOptions.d.ts +5 -1
- package/confirmdialog/ConfirmDialog.d.ts +2 -2
- package/core/core.js +65 -50
- package/core/core.min.js +17 -17
- package/datatable/DataTable.vue +3 -2
- package/datatable/datatable.cjs.js +3 -2
- package/datatable/datatable.cjs.min.js +1 -1
- package/datatable/datatable.esm.js +3 -2
- package/datatable/datatable.esm.min.js +1 -1
- package/datatable/datatable.js +3 -2
- package/datatable/datatable.min.js +1 -1
- package/dataview/DataView.d.ts +9 -19
- package/dataview/DataView.vue +11 -10
- package/dataview/dataview.cjs.js +18 -18
- package/dataview/dataview.cjs.min.js +1 -1
- package/dataview/dataview.esm.js +19 -19
- package/dataview/dataview.esm.min.js +1 -1
- package/dataview/dataview.js +18 -18
- package/dataview/dataview.min.js +1 -1
- package/dataview/style/dataviewstyle.cjs.js +0 -2
- package/dataview/style/dataviewstyle.cjs.min.js +1 -1
- package/dataview/style/dataviewstyle.esm.js +0 -2
- package/dataview/style/dataviewstyle.esm.min.js +1 -1
- package/dataview/style/dataviewstyle.js +0 -2
- package/dataview/style/dataviewstyle.min.js +1 -1
- package/dialog/Dialog.d.ts +2 -2
- package/dialog/Dialog.vue +4 -4
- package/dialog/dialog.cjs.js +6 -6
- package/dialog/dialog.cjs.min.js +1 -1
- package/dialog/dialog.esm.js +6 -6
- package/dialog/dialog.esm.min.js +1 -1
- package/dialog/dialog.js +6 -6
- package/dialog/dialog.min.js +1 -1
- package/dialog/style/dialogstyle.cjs.js +2 -2
- package/dialog/style/dialogstyle.cjs.min.js +1 -1
- package/dialog/style/dialogstyle.esm.js +2 -2
- package/dialog/style/dialogstyle.esm.min.js +1 -1
- package/dialog/style/dialogstyle.js +2 -2
- package/dialog/style/dialogstyle.min.js +1 -1
- package/dock/BaseDock.vue +4 -0
- package/dock/Dock.d.ts +5 -0
- package/dock/Dock.vue +14 -0
- package/dock/dock.cjs.js +17 -0
- package/dock/dock.cjs.min.js +1 -1
- package/dock/dock.esm.js +17 -0
- package/dock/dock.esm.min.js +1 -1
- package/dock/dock.js +17 -0
- package/dock/dock.min.js +1 -1
- package/dock/style/dockstyle.cjs.js +5 -2
- package/dock/style/dockstyle.cjs.min.js +1 -1
- package/dock/style/dockstyle.esm.js +5 -2
- package/dock/style/dockstyle.esm.min.js +1 -1
- package/dock/style/dockstyle.js +5 -2
- package/dock/style/dockstyle.min.js +1 -1
- package/fileupload/FileContent.vue +1 -1
- package/fileupload/FileUpload.vue +1 -1
- package/fileupload/fileupload.cjs.js +2 -2
- package/fileupload/fileupload.cjs.min.js +1 -1
- package/fileupload/fileupload.esm.js +2 -2
- package/fileupload/fileupload.esm.min.js +1 -1
- package/fileupload/fileupload.js +2 -2
- package/fileupload/fileupload.min.js +1 -1
- package/focustrap/focustrap.cjs.js +1 -1
- package/focustrap/focustrap.cjs.min.js +1 -1
- package/focustrap/focustrap.esm.js +1 -1
- package/focustrap/focustrap.esm.min.js +1 -1
- package/focustrap/focustrap.js +1 -1
- package/focustrap/focustrap.min.js +1 -1
- package/inputgroupaddon/package.json +1 -1
- package/inputnumber/style/inputnumberstyle.cjs.js +1 -1
- package/inputnumber/style/inputnumberstyle.cjs.min.js +1 -1
- package/inputnumber/style/inputnumberstyle.esm.js +1 -1
- package/inputnumber/style/inputnumberstyle.esm.min.js +1 -1
- package/inputnumber/style/inputnumberstyle.js +1 -1
- package/inputnumber/style/inputnumberstyle.min.js +1 -1
- package/megamenu/BaseMegaMenu.vue +4 -0
- package/megamenu/MegaMenu.d.ts +9 -0
- package/megamenu/MegaMenu.vue +74 -6
- package/megamenu/MegaMenuSub.vue +6 -1
- package/megamenu/megamenu.cjs.js +118 -35
- package/megamenu/megamenu.cjs.min.js +1 -1
- package/megamenu/megamenu.esm.js +119 -37
- package/megamenu/megamenu.esm.min.js +1 -1
- package/megamenu/megamenu.js +119 -37
- package/megamenu/megamenu.min.js +1 -1
- package/megamenu/style/megamenustyle.cjs.js +22 -17
- package/megamenu/style/megamenustyle.cjs.min.js +1 -1
- package/megamenu/style/megamenustyle.esm.js +22 -17
- package/megamenu/style/megamenustyle.esm.min.js +1 -1
- package/megamenu/style/megamenustyle.js +22 -17
- package/megamenu/style/megamenustyle.min.js +1 -1
- package/menu/Menu.d.ts +1 -1
- package/menu/Menuitem.vue +0 -1
- package/menubar/BaseMenubar.vue +4 -0
- package/menubar/Menubar.d.ts +5 -0
- package/menubar/Menubar.vue +10 -1
- package/menubar/menubar.cjs.js +48 -36
- package/menubar/menubar.cjs.min.js +1 -1
- package/menubar/menubar.esm.js +48 -36
- package/menubar/menubar.esm.min.js +1 -1
- package/menubar/menubar.js +48 -36
- package/menubar/menubar.min.js +1 -1
- package/menubar/style/menubarstyle.cjs.js +2 -1
- package/menubar/style/menubarstyle.cjs.min.js +1 -1
- package/menubar/style/menubarstyle.esm.js +2 -1
- package/menubar/style/menubarstyle.esm.min.js +1 -1
- package/menubar/style/menubarstyle.js +2 -1
- package/menubar/style/menubarstyle.min.js +1 -1
- package/orderlist/OrderList.vue +18 -2
- package/orderlist/orderlist.cjs.js +16 -2
- package/orderlist/orderlist.cjs.min.js +1 -1
- package/orderlist/orderlist.esm.js +16 -2
- package/orderlist/orderlist.esm.min.js +1 -1
- package/orderlist/orderlist.js +16 -2
- package/orderlist/orderlist.min.js +1 -1
- package/overlaypanel/OverlayPanel.d.ts +14 -14
- package/package.json +1 -1
- package/paginator/Paginator.vue +21 -13
- package/paginator/paginator.cjs.js +9 -2
- package/paginator/paginator.cjs.min.js +1 -1
- package/paginator/paginator.esm.js +9 -2
- package/paginator/paginator.esm.min.js +1 -1
- package/paginator/paginator.js +9 -2
- package/paginator/paginator.min.js +1 -1
- package/panelmenu/BasePanelMenu.vue +4 -0
- package/panelmenu/PanelMenu.d.ts +5 -0
- package/panelmenu/PanelMenu.vue +13 -2
- package/panelmenu/panelmenu.cjs.js +21 -2
- package/panelmenu/panelmenu.cjs.min.js +1 -1
- package/panelmenu/panelmenu.esm.js +21 -2
- package/panelmenu/panelmenu.esm.min.js +1 -1
- package/panelmenu/panelmenu.js +21 -2
- package/panelmenu/panelmenu.min.js +1 -1
- package/passthrough/tailwind/index.cjs.js +4 -4
- package/passthrough/tailwind/index.cjs.min.js +1 -1
- package/passthrough/tailwind/index.esm.js +4 -4
- package/passthrough/tailwind/index.esm.min.js +1 -1
- package/passthrough/tailwind/index.js +4 -4
- package/passthrough/tailwind/index.min.js +1 -1
- package/picklist/PickList.vue +16 -2
- package/picklist/picklist.cjs.js +15 -2
- package/picklist/picklist.cjs.min.js +1 -1
- package/picklist/picklist.esm.js +15 -2
- package/picklist/picklist.esm.min.js +1 -1
- package/picklist/picklist.js +15 -2
- package/picklist/picklist.min.js +1 -1
- package/resources/themes/arya-blue/theme.css +133 -117
- package/resources/themes/arya-green/theme.css +133 -117
- package/resources/themes/arya-orange/theme.css +133 -117
- package/resources/themes/arya-purple/theme.css +133 -117
- package/resources/themes/bootstrap4-dark-blue/theme.css +133 -117
- package/resources/themes/bootstrap4-dark-purple/theme.css +133 -117
- package/resources/themes/bootstrap4-light-blue/theme.css +133 -117
- package/resources/themes/bootstrap4-light-purple/theme.css +133 -117
- package/resources/themes/fluent-light/theme.css +133 -117
- package/resources/themes/lara-dark-amber/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-dark-amber/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-dark-amber/theme.css +5757 -0
- package/resources/themes/lara-dark-blue/theme.css +337 -321
- package/resources/themes/lara-dark-cyan/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-dark-cyan/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-dark-cyan/theme.css +5757 -0
- package/resources/themes/lara-dark-green/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-dark-green/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-dark-green/theme.css +5757 -0
- package/resources/themes/lara-dark-indigo/theme.css +337 -321
- package/resources/themes/lara-dark-pink/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-dark-pink/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-dark-pink/theme.css +5757 -0
- package/resources/themes/lara-dark-purple/theme.css +337 -321
- package/resources/themes/lara-dark-teal/theme.css +577 -561
- package/resources/themes/lara-light-amber/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-light-amber/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-light-amber/theme.css +5749 -0
- package/resources/themes/lara-light-blue/theme.css +192 -176
- package/resources/themes/lara-light-cyan/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-light-cyan/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-light-cyan/theme.css +5749 -0
- package/resources/themes/lara-light-green/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-light-green/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-light-green/theme.css +5749 -0
- package/resources/themes/lara-light-indigo/theme.css +192 -176
- package/resources/themes/lara-light-pink/fonts/Inter-italic.var.woff2 +0 -0
- package/resources/themes/lara-light-pink/fonts/Inter-roman.var.woff2 +0 -0
- package/resources/themes/lara-light-pink/theme.css +5749 -0
- package/resources/themes/lara-light-purple/theme.css +192 -176
- package/resources/themes/lara-light-teal/theme.css +483 -467
- package/resources/themes/luna-amber/theme.css +133 -117
- package/resources/themes/luna-blue/theme.css +133 -117
- package/resources/themes/luna-green/theme.css +133 -117
- package/resources/themes/luna-pink/theme.css +133 -117
- package/resources/themes/md-dark-deeppurple/theme.css +133 -117
- package/resources/themes/md-dark-indigo/theme.css +133 -117
- package/resources/themes/md-light-deeppurple/theme.css +133 -117
- package/resources/themes/md-light-indigo/theme.css +133 -117
- package/resources/themes/mdc-dark-deeppurple/theme.css +133 -117
- package/resources/themes/mdc-dark-indigo/theme.css +133 -117
- package/resources/themes/mdc-light-deeppurple/theme.css +133 -117
- package/resources/themes/mdc-light-indigo/theme.css +133 -117
- package/resources/themes/mira/theme.css +133 -117
- package/resources/themes/nano/theme.css +133 -117
- package/resources/themes/nova/theme.css +133 -117
- package/resources/themes/nova-accent/theme.css +133 -117
- package/resources/themes/nova-alt/theme.css +133 -117
- package/resources/themes/nova-vue/theme.css +133 -117
- package/resources/themes/rhea/theme.css +133 -117
- package/resources/themes/saga-blue/theme.css +133 -117
- package/resources/themes/saga-green/theme.css +133 -117
- package/resources/themes/saga-orange/theme.css +133 -117
- package/resources/themes/saga-purple/theme.css +133 -117
- package/resources/themes/soho-dark/theme.css +133 -117
- package/resources/themes/soho-light/theme.css +133 -117
- package/resources/themes/tailwind-light/theme.css +133 -117
- package/resources/themes/vela-blue/theme.css +133 -117
- package/resources/themes/vela-green/theme.css +133 -117
- package/resources/themes/vela-orange/theme.css +133 -117
- package/resources/themes/vela-purple/theme.css +133 -117
- package/resources/themes/viva-dark/theme.css +133 -117
- package/resources/themes/viva-light/theme.css +133 -117
- package/sidebar/BaseSidebar.vue +4 -0
- package/sidebar/Sidebar.d.ts +12 -2
- package/sidebar/Sidebar.vue +3 -3
- package/sidebar/sidebar.cjs.js +12 -4
- package/sidebar/sidebar.cjs.min.js +1 -1
- package/sidebar/sidebar.esm.js +13 -5
- package/sidebar/sidebar.esm.min.js +1 -1
- package/sidebar/sidebar.js +12 -4
- package/sidebar/sidebar.min.js +1 -1
- package/sidebar/style/sidebarstyle.cjs.js +2 -2
- package/sidebar/style/sidebarstyle.cjs.min.js +1 -1
- package/sidebar/style/sidebarstyle.esm.js +2 -2
- package/sidebar/style/sidebarstyle.esm.min.js +1 -1
- package/sidebar/style/sidebarstyle.js +2 -2
- package/sidebar/style/sidebarstyle.min.js +1 -1
- package/speeddial/style/speeddialstyle.cjs.js +2 -2
- package/speeddial/style/speeddialstyle.cjs.min.js +1 -1
- package/speeddial/style/speeddialstyle.esm.js +2 -2
- package/speeddial/style/speeddialstyle.esm.min.js +1 -1
- package/speeddial/style/speeddialstyle.js +2 -2
- package/speeddial/style/speeddialstyle.min.js +1 -1
- package/splitter/Splitter.vue +3 -1
- package/splitter/splitter.cjs.js +3 -1
- package/splitter/splitter.cjs.min.js +1 -1
- package/splitter/splitter.esm.js +3 -1
- package/splitter/splitter.esm.min.js +1 -1
- package/splitter/splitter.js +3 -1
- package/splitter/splitter.min.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.cjs.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.cjs.min.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.esm.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.esm.min.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.js +1 -1
- package/splitterpanel/style/splitterpanelstyle.min.js +1 -1
- package/tree/TreeNode.vue +1 -1
- package/tree/style/treestyle.cjs.js +1 -4
- package/tree/style/treestyle.cjs.min.js +1 -1
- package/tree/style/treestyle.esm.js +1 -4
- package/tree/style/treestyle.esm.min.js +1 -1
- package/tree/style/treestyle.js +1 -4
- package/tree/style/treestyle.min.js +1 -1
- package/tree/tree.cjs.js +1 -1
- package/tree/tree.cjs.min.js +1 -1
- package/tree/tree.esm.js +1 -1
- package/tree/tree.esm.min.js +1 -1
- package/tree/tree.js +1 -1
- package/tree/tree.min.js +1 -1
- package/treeselect/TreeSelect.vue +67 -2
- package/treeselect/treeselect.cjs.js +73 -9
- package/treeselect/treeselect.cjs.min.js +1 -1
- package/treeselect/treeselect.esm.js +73 -9
- package/treeselect/treeselect.esm.min.js +1 -1
- package/treeselect/treeselect.js +73 -9
- package/treeselect/treeselect.min.js +1 -1
- package/web-types.json +1 -1
- /package/dynamicdialog/style/{AccordionStyle.d.ts → DynamicDialogStyle.d.ts} +0 -0
package/megamenu/megamenu.esm.js
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import BarsIcon from 'primevue/icons/bars';
|
|
2
|
+
import { ObjectUtils, UniqueComponentId, ZIndexUtils, DomHandler } from 'primevue/utils';
|
|
2
3
|
import BaseComponent from 'primevue/basecomponent';
|
|
3
4
|
import MegaMenuStyle from 'primevue/megamenu/style';
|
|
4
5
|
import AngleDownIcon from 'primevue/icons/angledown';
|
|
5
6
|
import AngleRightIcon from 'primevue/icons/angleright';
|
|
6
7
|
import Ripple from 'primevue/ripple';
|
|
7
|
-
import { mergeProps, resolveComponent, resolveDirective, openBlock, createElementBlock, toDisplayString, createCommentVNode, Fragment, renderList, createElementVNode, withDirectives, createBlock, resolveDynamicComponent, normalizeClass, normalizeStyle, renderSlot, createVNode } from 'vue';
|
|
8
|
+
import { mergeProps, resolveComponent, resolveDirective, openBlock, createElementBlock, toDisplayString, createCommentVNode, Fragment, renderList, createElementVNode, withDirectives, createBlock, resolveDynamicComponent, normalizeClass, normalizeStyle, renderSlot, createVNode, normalizeProps, guardReactiveProps } from 'vue';
|
|
8
9
|
|
|
9
10
|
var script$2 = {
|
|
10
11
|
name: 'BaseMegaMenu',
|
|
@@ -18,6 +19,10 @@ var script$2 = {
|
|
|
18
19
|
type: String,
|
|
19
20
|
"default": 'horizontal'
|
|
20
21
|
},
|
|
22
|
+
breakpoint: {
|
|
23
|
+
type: String,
|
|
24
|
+
"default": '960px'
|
|
25
|
+
},
|
|
21
26
|
disabled: {
|
|
22
27
|
type: Boolean,
|
|
23
28
|
"default": false
|
|
@@ -65,6 +70,10 @@ var script$1 = {
|
|
|
65
70
|
type: Object,
|
|
66
71
|
"default": null
|
|
67
72
|
},
|
|
73
|
+
mobileActive: {
|
|
74
|
+
type: Boolean,
|
|
75
|
+
"default": false
|
|
76
|
+
},
|
|
68
77
|
items: {
|
|
69
78
|
type: Array,
|
|
70
79
|
"default": null
|
|
@@ -189,7 +198,7 @@ var script$1 = {
|
|
|
189
198
|
};
|
|
190
199
|
|
|
191
200
|
var _hoisted_1$1 = ["tabindex"];
|
|
192
|
-
var _hoisted_2 = ["id", "aria-label", "aria-disabled", "aria-expanded", "aria-haspopup", "aria-level", "aria-setsize", "aria-posinset", "data-p-highlight", "data-p-focused", "data-p-disabled"];
|
|
201
|
+
var _hoisted_2$1 = ["id", "aria-label", "aria-disabled", "aria-expanded", "aria-haspopup", "aria-level", "aria-setsize", "aria-posinset", "data-p-highlight", "data-p-focused", "data-p-disabled"];
|
|
193
202
|
var _hoisted_3 = ["onClick", "onMouseenter"];
|
|
194
203
|
var _hoisted_4 = ["href", "target"];
|
|
195
204
|
var _hoisted_5 = ["id"];
|
|
@@ -258,7 +267,7 @@ function render$1(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
258
267
|
key: 0,
|
|
259
268
|
active: $options.isItemActive(processedItem),
|
|
260
269
|
"class": _ctx.cx('submenuIcon')
|
|
261
|
-
}, $options.getPTOptions(processedItem, index, 'submenuIcon')), null, 16, ["active", "class"])) : (openBlock(), createBlock(resolveDynamicComponent($props.horizontal ? 'AngleDownIcon' : 'AngleRightIcon'), mergeProps({
|
|
270
|
+
}, $options.getPTOptions(processedItem, index, 'submenuIcon')), null, 16, ["active", "class"])) : (openBlock(), createBlock(resolveDynamicComponent($props.horizontal || $props.mobileActive ? 'AngleDownIcon' : 'AngleRightIcon'), mergeProps({
|
|
262
271
|
key: 1,
|
|
263
272
|
"class": _ctx.cx('submenuIcon')
|
|
264
273
|
}, $options.getPTOptions(processedItem, index, 'submenuIcon')), null, 16, ["class"]))], 64)) : createCommentVNode("", true)], 16, _hoisted_4)), [[_directive_ripple]]) : (openBlock(), createBlock(resolveDynamicComponent($props.templates.item), {
|
|
@@ -292,6 +301,7 @@ function render$1(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
292
301
|
items: submenu.items,
|
|
293
302
|
templates: $props.templates,
|
|
294
303
|
level: $props.level + 1,
|
|
304
|
+
mobileActive: $props.mobileActive,
|
|
295
305
|
pt: _ctx.pt,
|
|
296
306
|
unstyled: _ctx.unstyled,
|
|
297
307
|
onItemClick: _cache[0] || (_cache[0] = function ($event) {
|
|
@@ -300,9 +310,9 @@ function render$1(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
300
310
|
onItemMouseenter: _cache[1] || (_cache[1] = function ($event) {
|
|
301
311
|
return _ctx.$emit('item-mouseenter', $event);
|
|
302
312
|
})
|
|
303
|
-
}, null, 8, ["id", "style", "menuId", "focusedItemId", "submenu", "items", "templates", "level", "pt", "unstyled"]);
|
|
313
|
+
}, null, 8, ["id", "style", "menuId", "focusedItemId", "submenu", "items", "templates", "level", "mobileActive", "pt", "unstyled"]);
|
|
304
314
|
}), 128))], 16);
|
|
305
|
-
}), 128))], 16)], 16)) : createCommentVNode("", true)], 16, _hoisted_2)) : createCommentVNode("", true), $options.isItemVisible(processedItem) && $options.getItemProp(processedItem, 'separator') ? (openBlock(), createElementBlock("li", mergeProps({
|
|
315
|
+
}), 128))], 16)], 16)) : createCommentVNode("", true)], 16, _hoisted_2$1)) : createCommentVNode("", true), $options.isItemVisible(processedItem) && $options.getItemProp(processedItem, 'separator') ? (openBlock(), createElementBlock("li", mergeProps({
|
|
306
316
|
key: 1,
|
|
307
317
|
id: $options.getItemId(processedItem),
|
|
308
318
|
"class": [_ctx.cx('separator'), $options.getItemProp(processedItem, 'class')],
|
|
@@ -327,6 +337,7 @@ var script = {
|
|
|
327
337
|
data: function data() {
|
|
328
338
|
return {
|
|
329
339
|
id: this.$attrs.id,
|
|
340
|
+
mobileActive: false,
|
|
330
341
|
focused: false,
|
|
331
342
|
focusedItemInfo: {
|
|
332
343
|
index: -1,
|
|
@@ -334,7 +345,8 @@ var script = {
|
|
|
334
345
|
parentKey: ''
|
|
335
346
|
},
|
|
336
347
|
activeItem: null,
|
|
337
|
-
dirty: false
|
|
348
|
+
dirty: false,
|
|
349
|
+
queryMatches: false
|
|
338
350
|
};
|
|
339
351
|
},
|
|
340
352
|
watch: {
|
|
@@ -352,9 +364,17 @@ var script = {
|
|
|
352
364
|
}
|
|
353
365
|
},
|
|
354
366
|
mounted: function mounted() {
|
|
367
|
+
var _this = this;
|
|
355
368
|
this.id = this.id || UniqueComponentId();
|
|
369
|
+
var query = matchMedia("(max-width: ".concat(this.breakpoint, ")"));
|
|
370
|
+
this.queryMatches = query.matches;
|
|
371
|
+
query.addEventListener('change', function () {
|
|
372
|
+
_this.queryMatches = query.matches;
|
|
373
|
+
_this.mobileActive = false;
|
|
374
|
+
});
|
|
356
375
|
},
|
|
357
376
|
beforeUnmount: function beforeUnmount() {
|
|
377
|
+
this.mobileActive = false;
|
|
358
378
|
this.unbindOutsideClickListener();
|
|
359
379
|
this.unbindResizeListener();
|
|
360
380
|
},
|
|
@@ -380,7 +400,38 @@ var script = {
|
|
|
380
400
|
isProccessedItemGroup: function isProccessedItemGroup(processedItem) {
|
|
381
401
|
return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
|
|
382
402
|
},
|
|
403
|
+
toggle: function toggle(event) {
|
|
404
|
+
var _this2 = this;
|
|
405
|
+
if (this.mobileActive) {
|
|
406
|
+
this.mobileActive = false;
|
|
407
|
+
ZIndexUtils.clear(this.menubar);
|
|
408
|
+
this.hide();
|
|
409
|
+
} else {
|
|
410
|
+
this.mobileActive = true;
|
|
411
|
+
ZIndexUtils.set('menu', this.menubar, this.$primevue.config.zIndex.menu);
|
|
412
|
+
setTimeout(function () {
|
|
413
|
+
_this2.show();
|
|
414
|
+
}, 1);
|
|
415
|
+
}
|
|
416
|
+
this.bindOutsideClickListener();
|
|
417
|
+
event.preventDefault();
|
|
418
|
+
},
|
|
419
|
+
show: function show() {
|
|
420
|
+
this.focusedItemInfo = {
|
|
421
|
+
index: this.findFirstFocusedItemIndex(),
|
|
422
|
+
level: 0,
|
|
423
|
+
parentKey: ''
|
|
424
|
+
};
|
|
425
|
+
DomHandler.focus(this.menubar);
|
|
426
|
+
},
|
|
383
427
|
hide: function hide(event, isFocus) {
|
|
428
|
+
var _this3 = this;
|
|
429
|
+
if (this.mobileActive) {
|
|
430
|
+
this.mobileActive = false;
|
|
431
|
+
setTimeout(function () {
|
|
432
|
+
DomHandler.focus(_this3.$refs.menubutton);
|
|
433
|
+
}, 0);
|
|
434
|
+
}
|
|
384
435
|
this.activeItem = null;
|
|
385
436
|
this.focusedItemInfo = {
|
|
386
437
|
index: -1,
|
|
@@ -508,15 +559,22 @@ var script = {
|
|
|
508
559
|
var rootProcessedItem = root ? processedItem : this.activeItem;
|
|
509
560
|
this.hide(originalEvent);
|
|
510
561
|
this.changeFocusedItemInfo(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);
|
|
562
|
+
this.mobileActive = false;
|
|
511
563
|
DomHandler.focus(this.menubar);
|
|
512
564
|
}
|
|
513
565
|
}
|
|
514
566
|
},
|
|
515
567
|
onItemMouseEnter: function onItemMouseEnter(event) {
|
|
516
|
-
if (this.dirty) {
|
|
568
|
+
if (!this.mobileActive && this.dirty) {
|
|
517
569
|
this.onItemChange(event);
|
|
518
570
|
}
|
|
519
571
|
},
|
|
572
|
+
menuButtonClick: function menuButtonClick(event) {
|
|
573
|
+
this.toggle(event);
|
|
574
|
+
},
|
|
575
|
+
menuButtonKeydown: function menuButtonKeydown(event) {
|
|
576
|
+
(event.code === 'Enter' || event.code === 'Space') && this.menuButtonClick(event);
|
|
577
|
+
},
|
|
520
578
|
onArrowDownKey: function onArrowDownKey(event) {
|
|
521
579
|
if (this.horizontal) {
|
|
522
580
|
if (ObjectUtils.isNotEmpty(this.activeItem) && this.activeItem.key === this.focusedItemInfo.key) {
|
|
@@ -681,13 +739,13 @@ var script = {
|
|
|
681
739
|
this.hide();
|
|
682
740
|
},
|
|
683
741
|
bindOutsideClickListener: function bindOutsideClickListener() {
|
|
684
|
-
var
|
|
742
|
+
var _this4 = this;
|
|
685
743
|
if (!this.outsideClickListener) {
|
|
686
744
|
this.outsideClickListener = function (event) {
|
|
687
|
-
var isOutsideContainer =
|
|
688
|
-
var isOutsideTarget =
|
|
745
|
+
var isOutsideContainer = _this4.container && !_this4.container.contains(event.target);
|
|
746
|
+
var isOutsideTarget = !(_this4.target && (_this4.target === event.target || _this4.target.contains(event.target)));
|
|
689
747
|
if (isOutsideContainer && isOutsideTarget) {
|
|
690
|
-
|
|
748
|
+
_this4.hide();
|
|
691
749
|
}
|
|
692
750
|
};
|
|
693
751
|
document.addEventListener('click', this.outsideClickListener);
|
|
@@ -700,12 +758,13 @@ var script = {
|
|
|
700
758
|
}
|
|
701
759
|
},
|
|
702
760
|
bindResizeListener: function bindResizeListener() {
|
|
703
|
-
var
|
|
761
|
+
var _this5 = this;
|
|
704
762
|
if (!this.resizeListener) {
|
|
705
763
|
this.resizeListener = function (event) {
|
|
706
764
|
if (!DomHandler.isTouchDevice()) {
|
|
707
|
-
|
|
765
|
+
_this5.hide(event, true);
|
|
708
766
|
}
|
|
767
|
+
_this5.mobileActive = false;
|
|
709
768
|
};
|
|
710
769
|
window.addEventListener('resize', this.resizeListener);
|
|
711
770
|
}
|
|
@@ -729,35 +788,35 @@ var script = {
|
|
|
729
788
|
return ObjectUtils.isNotEmpty(this.activeItem) ? this.activeItem.key === processedItem.key : false;
|
|
730
789
|
},
|
|
731
790
|
findFirstItemIndex: function findFirstItemIndex() {
|
|
732
|
-
var
|
|
791
|
+
var _this6 = this;
|
|
733
792
|
return this.visibleItems.findIndex(function (processedItem) {
|
|
734
|
-
return
|
|
793
|
+
return _this6.isValidItem(processedItem);
|
|
735
794
|
});
|
|
736
795
|
},
|
|
737
796
|
findLastItemIndex: function findLastItemIndex() {
|
|
738
|
-
var
|
|
797
|
+
var _this7 = this;
|
|
739
798
|
return ObjectUtils.findLastIndex(this.visibleItems, function (processedItem) {
|
|
740
|
-
return
|
|
799
|
+
return _this7.isValidItem(processedItem);
|
|
741
800
|
});
|
|
742
801
|
},
|
|
743
802
|
findNextItemIndex: function findNextItemIndex(index) {
|
|
744
|
-
var
|
|
803
|
+
var _this8 = this;
|
|
745
804
|
var matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex(function (processedItem) {
|
|
746
|
-
return
|
|
805
|
+
return _this8.isValidItem(processedItem);
|
|
747
806
|
}) : -1;
|
|
748
807
|
return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
|
|
749
808
|
},
|
|
750
809
|
findPrevItemIndex: function findPrevItemIndex(index) {
|
|
751
|
-
var
|
|
810
|
+
var _this9 = this;
|
|
752
811
|
var matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), function (processedItem) {
|
|
753
|
-
return
|
|
812
|
+
return _this9.isValidItem(processedItem);
|
|
754
813
|
}) : -1;
|
|
755
814
|
return matchedItemIndex > -1 ? matchedItemIndex : index;
|
|
756
815
|
},
|
|
757
816
|
findSelectedItemIndex: function findSelectedItemIndex() {
|
|
758
|
-
var
|
|
817
|
+
var _this10 = this;
|
|
759
818
|
return this.visibleItems.findIndex(function (processedItem) {
|
|
760
|
-
return
|
|
819
|
+
return _this10.isValidSelectedItem(processedItem);
|
|
761
820
|
});
|
|
762
821
|
},
|
|
763
822
|
findFirstFocusedItemIndex: function findFirstFocusedItemIndex() {
|
|
@@ -772,20 +831,20 @@ var script = {
|
|
|
772
831
|
return ObjectUtils.isNotEmpty(this.visibleItems) ? this.visibleItems[index] : null;
|
|
773
832
|
},
|
|
774
833
|
searchItems: function searchItems(event, _char) {
|
|
775
|
-
var
|
|
834
|
+
var _this11 = this;
|
|
776
835
|
this.searchValue = (this.searchValue || '') + _char;
|
|
777
836
|
var itemIndex = -1;
|
|
778
837
|
var matched = false;
|
|
779
838
|
if (this.focusedItemInfo.index !== -1) {
|
|
780
839
|
itemIndex = this.visibleItems.slice(this.focusedItemInfo.index).findIndex(function (processedItem) {
|
|
781
|
-
return
|
|
840
|
+
return _this11.isItemMatched(processedItem);
|
|
782
841
|
});
|
|
783
842
|
itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo.index).findIndex(function (processedItem) {
|
|
784
|
-
return
|
|
843
|
+
return _this11.isItemMatched(processedItem);
|
|
785
844
|
}) : itemIndex + this.focusedItemInfo.index;
|
|
786
845
|
} else {
|
|
787
846
|
itemIndex = this.visibleItems.findIndex(function (processedItem) {
|
|
788
|
-
return
|
|
847
|
+
return _this11.isItemMatched(processedItem);
|
|
789
848
|
});
|
|
790
849
|
}
|
|
791
850
|
if (itemIndex !== -1) {
|
|
@@ -801,8 +860,8 @@ var script = {
|
|
|
801
860
|
clearTimeout(this.searchTimeout);
|
|
802
861
|
}
|
|
803
862
|
this.searchTimeout = setTimeout(function () {
|
|
804
|
-
|
|
805
|
-
|
|
863
|
+
_this11.searchValue = '';
|
|
864
|
+
_this11.searchTimeout = null;
|
|
806
865
|
}, 500);
|
|
807
866
|
return matched;
|
|
808
867
|
},
|
|
@@ -824,7 +883,7 @@ var script = {
|
|
|
824
883
|
}
|
|
825
884
|
},
|
|
826
885
|
createProcessedItems: function createProcessedItems(items) {
|
|
827
|
-
var
|
|
886
|
+
var _this12 = this;
|
|
828
887
|
var level = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
829
888
|
var parent = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
830
889
|
var parentKey = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '';
|
|
@@ -842,8 +901,8 @@ var script = {
|
|
|
842
901
|
columnIndex: columnIndex !== undefined ? columnIndex : parent.columnIndex !== undefined ? parent.columnIndex : index
|
|
843
902
|
};
|
|
844
903
|
newItem['items'] = level === 0 && item.items && item.items.length > 0 ? item.items.map(function (_items, _index) {
|
|
845
|
-
return
|
|
846
|
-
}) :
|
|
904
|
+
return _this12.createProcessedItems(_items, level + 1, newItem, key, _index);
|
|
905
|
+
}) : _this12.createProcessedItems(item.items, level + 1, newItem, key);
|
|
847
906
|
processedItems.push(newItem);
|
|
848
907
|
});
|
|
849
908
|
return processedItems;
|
|
@@ -881,12 +940,16 @@ var script = {
|
|
|
881
940
|
}
|
|
882
941
|
},
|
|
883
942
|
components: {
|
|
884
|
-
MegaMenuSub: script$1
|
|
943
|
+
MegaMenuSub: script$1,
|
|
944
|
+
BarsIcon: BarsIcon
|
|
885
945
|
}
|
|
886
946
|
};
|
|
887
947
|
|
|
888
948
|
var _hoisted_1 = ["id"];
|
|
949
|
+
var _hoisted_2 = ["aria-haspopup", "aria-expanded", "aria-controls", "aria-label"];
|
|
889
950
|
function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
951
|
+
var _ctx$$primevue$config;
|
|
952
|
+
var _component_BarsIcon = resolveComponent("BarsIcon");
|
|
890
953
|
var _component_MegaMenuSub = resolveComponent("MegaMenuSub");
|
|
891
954
|
return openBlock(), createElementBlock("div", mergeProps({
|
|
892
955
|
ref: $options.containerRef,
|
|
@@ -897,7 +960,25 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
897
960
|
}), [_ctx.$slots.start ? (openBlock(), createElementBlock("div", mergeProps({
|
|
898
961
|
key: 0,
|
|
899
962
|
"class": _ctx.cx('start')
|
|
900
|
-
}, _ctx.ptm('start')), [renderSlot(_ctx.$slots, "start")], 16)) : createCommentVNode("", true),
|
|
963
|
+
}, _ctx.ptm('start')), [renderSlot(_ctx.$slots, "start")], 16)) : createCommentVNode("", true), _ctx.model && _ctx.model.length > 0 ? (openBlock(), createElementBlock("a", mergeProps({
|
|
964
|
+
key: 1,
|
|
965
|
+
ref: "menubutton",
|
|
966
|
+
role: "button",
|
|
967
|
+
tabindex: "0",
|
|
968
|
+
"class": _ctx.cx('menubutton'),
|
|
969
|
+
"aria-haspopup": _ctx.model.length && _ctx.model.length > 0 ? true : false,
|
|
970
|
+
"aria-expanded": $data.mobileActive,
|
|
971
|
+
"aria-controls": $data.id,
|
|
972
|
+
"aria-label": (_ctx$$primevue$config = _ctx.$primevue.config.locale.aria) === null || _ctx$$primevue$config === void 0 ? void 0 : _ctx$$primevue$config.navigation,
|
|
973
|
+
onClick: _cache[0] || (_cache[0] = function ($event) {
|
|
974
|
+
return $options.menuButtonClick($event);
|
|
975
|
+
}),
|
|
976
|
+
onKeydown: _cache[1] || (_cache[1] = function ($event) {
|
|
977
|
+
return $options.menuButtonKeydown($event);
|
|
978
|
+
})
|
|
979
|
+
}, _ctx.ptm('menubutton')), [renderSlot(_ctx.$slots, "menubuttonicon", {}, function () {
|
|
980
|
+
return [createVNode(_component_BarsIcon, normalizeProps(guardReactiveProps(_ctx.ptm('menubuttonicon'))), null, 16)];
|
|
981
|
+
})], 16, _hoisted_2)) : createCommentVNode("", true), createVNode(_component_MegaMenuSub, {
|
|
901
982
|
ref: $options.menubarRef,
|
|
902
983
|
id: $data.id + '_list',
|
|
903
984
|
tabindex: !_ctx.disabled ? _ctx.tabindex : -1,
|
|
@@ -913,6 +994,7 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
913
994
|
horizontal: $options.horizontal,
|
|
914
995
|
templates: _ctx.$slots,
|
|
915
996
|
activeItem: $data.activeItem,
|
|
997
|
+
mobileActive: $data.mobileActive,
|
|
916
998
|
level: 0,
|
|
917
999
|
pt: _ctx.pt,
|
|
918
1000
|
unstyled: _ctx.unstyled,
|
|
@@ -921,8 +1003,8 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
921
1003
|
onKeydown: $options.onKeyDown,
|
|
922
1004
|
onItemClick: $options.onItemClick,
|
|
923
1005
|
onItemMouseenter: $options.onItemMouseEnter
|
|
924
|
-
}, null, 8, ["id", "tabindex", "aria-label", "aria-labelledby", "aria-disabled", "aria-orientation", "aria-activedescendant", "menuId", "focusedItemId", "items", "horizontal", "templates", "activeItem", "pt", "unstyled", "onFocus", "onBlur", "onKeydown", "onItemClick", "onItemMouseenter"]), _ctx.$slots.end ? (openBlock(), createElementBlock("div", mergeProps({
|
|
925
|
-
key:
|
|
1006
|
+
}, null, 8, ["id", "tabindex", "aria-label", "aria-labelledby", "aria-disabled", "aria-orientation", "aria-activedescendant", "menuId", "focusedItemId", "items", "horizontal", "templates", "activeItem", "mobileActive", "pt", "unstyled", "onFocus", "onBlur", "onKeydown", "onItemClick", "onItemMouseenter"]), _ctx.$slots.end ? (openBlock(), createElementBlock("div", mergeProps({
|
|
1007
|
+
key: 2,
|
|
926
1008
|
"class": _ctx.cx('end')
|
|
927
1009
|
}, _ctx.ptm('end')), [renderSlot(_ctx.$slots, "end")], 16)) : createCommentVNode("", true)], 16, _hoisted_1);
|
|
928
1010
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{ObjectUtils as e,UniqueComponentId as t,DomHandler as i}from"primevue/utils";import n from"primevue/basecomponent";import s from"primevue/megamenu/style";import o from"primevue/icons/angledown";import r from"primevue/icons/angleright";import a from"primevue/ripple";import{mergeProps as c,resolveComponent as u,resolveDirective as m,openBlock as d,createElementBlock as l,toDisplayString as I,createCommentVNode as h,Fragment as f,renderList as p,createElementVNode as v,withDirectives as b,createBlock as y,resolveDynamicComponent as g,normalizeClass as x,normalizeStyle as k,renderSlot as P,createVNode as L}from"vue";var K={name:"BaseMegaMenu",extends:n,props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},style:s,provide:function(){return{$parentInstance:this}}},E={name:"MegaMenuSub",hostName:"MegaMenu",extends:n,emits:["item-click","item-mouseenter"],props:{menuId:{type:String,default:null},focusedItemId:{type:String,default:null},horizontal:{type:Boolean,default:!1},submenu:{type:Object,default:null},items:{type:Array,default:null},level:{type:Number,default:0},templates:{type:Object,default:null},activeItem:{type:Object,default:null},tabindex:{type:Number,default:0}},methods:{getSubListId:function(e){return"".concat(this.getItemId(e),"_list")},getSubListKey:function(e){return this.getSubListId(e)},getItemId:function(e){return"".concat(this.menuId,"_").concat(e.key)},getItemKey:function(e){return this.getItemId(e)},getItemProp:function(t,i,n){return t&&t.item?e.getItemValue(t.item[i],n):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},getPTOptions:function(e,t,i){return this.ptm(i,{context:{item:e,index:t,active:this.isItemActive(e),focused:this.isItemFocused(e),disabled:this.isItemDisabled(e)}})},isItemActive:function(t){return!!e.isNotEmpty(this.activeItem)&&this.activeItem.key===t.key},isItemVisible:function(e){return!1!==this.getItemProp(e,"visible")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemFocused:function(e){return this.focusedItemId===this.getItemId(e)},isItemGroup:function(t){return e.isNotEmpty(t.items)},onItemClick:function(e,t){this.getItemProp(t,"command",{originalEvent:e,item:t.item}),this.$emit("item-click",{originalEvent:e,processedItem:t,isFocus:!0})},onItemMouseEnter:function(e,t){this.$emit("item-mouseenter",{originalEvent:e,processedItem:t})},getAriaSetSize:function(){var e=this;return this.items.filter((function(t){return e.isItemVisible(t)&&!e.getItemProp(t,"separator")})).length},getAriaPosInset:function(e){var t=this;return e-this.items.slice(0,e).filter((function(e){return t.isItemVisible(e)&&t.getItemProp(e,"separator")})).length+1},getMenuItemProps:function(e,t){return{action:c({class:this.cx("action"),tabindex:-1,"aria-hidden":!0},this.getPTOptions(e,t,"action")),icon:c({class:[this.cx("icon"),this.getItemProp(e,"icon")]},this.getPTOptions(e,t,"icon")),label:c({class:this.cx("label")},this.getPTOptions(e,t,"label")),submenuicon:c({class:this.cx("submenuIcon")},this.getPTOptions(e,t,"submenuIcon"))}}},components:{AngleRightIcon:r,AngleDownIcon:o},directives:{ripple:a}},F=["tabindex"],S=["id","aria-label","aria-disabled","aria-expanded","aria-haspopup","aria-level","aria-setsize","aria-posinset","data-p-highlight","data-p-focused","data-p-disabled"],V=["onClick","onMouseenter"],w=["href","target"],C=["id"];E.render=function(e,t,i,n,s,o){var r=u("MegaMenuSub",!0),a=m("ripple");return d(),l("ul",c({class:e.cx(0===i.level?"menu":"submenu"),tabindex:i.tabindex},e.ptm(0===i.level?"menu":"submenu")),[i.submenu?(d(),l("li",c({key:0,class:[e.cx("submenuHeader",{submenu:i.submenu}),o.getItemProp(i.submenu,"class")],style:o.getItemProp(i.submenu,"style"),role:"presentation"},e.ptm("submenuHeader")),I(o.getItemLabel(i.submenu)),17)):h("",!0),(d(!0),l(f,null,p(i.items,(function(n,s){return d(),l(f,{key:o.getItemKey(n)},[o.isItemVisible(n)&&!o.getItemProp(n,"separator")?(d(),l("li",c({key:0,id:o.getItemId(n),style:o.getItemProp(n,"style"),class:[e.cx("menuitem",{processedItem:n}),o.getItemProp(n,"class")],role:"menuitem","aria-label":o.getItemLabel(n),"aria-disabled":o.isItemDisabled(n)||void 0,"aria-expanded":o.isItemGroup(n)?o.isItemActive(n):void 0,"aria-haspopup":o.isItemGroup(n)&&!o.getItemProp(n,"to")?"menu":void 0,"aria-level":i.level+1,"aria-setsize":o.getAriaSetSize(),"aria-posinset":o.getAriaPosInset(s)},o.getPTOptions(n,s,"menuitem"),{"data-p-highlight":o.isItemActive(n),"data-p-focused":o.isItemFocused(n),"data-p-disabled":o.isItemDisabled(n)}),[v("div",c({class:e.cx("content"),onClick:function(e){return o.onItemClick(e,n)},onMouseenter:function(e){return o.onItemMouseEnter(e,n)}},o.getPTOptions(n,s,"content")),[i.templates.item?(d(),y(g(i.templates.item),{key:1,item:n.item,hasSubmenu:o.isItemGroup(n),label:o.getItemLabel(n),props:o.getMenuItemProps(n,s)},null,8,["item","hasSubmenu","label","props"])):b((d(),l("a",c({key:0,href:o.getItemProp(n,"url"),class:e.cx("action"),target:o.getItemProp(n,"target"),tabindex:"-1","aria-hidden":"true"},o.getPTOptions(n,s,"action")),[i.templates.itemicon?(d(),y(g(i.templates.itemicon),{key:0,item:n.item,class:x([e.cx("icon"),o.getItemProp(n,"icon")])},null,8,["item","class"])):o.getItemProp(n,"icon")?(d(),l("span",c({key:1,class:[e.cx("icon"),o.getItemProp(n,"icon")]},o.getPTOptions(n,s,"icon")),null,16)):h("",!0),v("span",c({class:e.cx(0===i.level?"label":"submenuLabel")},o.getPTOptions(n,s,0===i.level?"label":"submenuLabel")),I(o.getItemLabel(n)),17),o.isItemGroup(n)?(d(),l(f,{key:2},[i.templates.submenuicon?(d(),y(g(i.templates.submenuicon),c({key:0,active:o.isItemActive(n),class:e.cx("submenuIcon")},o.getPTOptions(n,s,"submenuIcon")),null,16,["active","class"])):(d(),y(g(i.horizontal?"AngleDownIcon":"AngleRightIcon"),c({key:1,class:e.cx("submenuIcon")},o.getPTOptions(n,s,"submenuIcon")),null,16,["class"]))],64)):h("",!0)],16,w)),[[a]])],16,V),o.isItemVisible(n)&&o.isItemGroup(n)?(d(),l("div",c({key:0,class:e.cx("panel")},e.ptm("panel")),[v("div",c({class:e.cx("grid")},e.ptm("grid")),[(d(!0),l(f,null,p(n.items,(function(s){return d(),l("div",c({key:o.getItemKey(s),class:e.cx("column",{processedItem:n})},e.ptm("column")),[(d(!0),l(f,null,p(s,(function(s){return d(),y(r,{key:o.getSubListKey(s),id:o.getSubListId(s),style:k(e.sx("submenu",!0,{processedItem:n})),role:"menu",menuId:i.menuId,focusedItemId:i.focusedItemId,submenu:s,items:s.items,templates:i.templates,level:i.level+1,pt:e.pt,unstyled:e.unstyled,onItemClick:t[0]||(t[0]=function(t){return e.$emit("item-click",t)}),onItemMouseenter:t[1]||(t[1]=function(t){return e.$emit("item-mouseenter",t)})},null,8,["id","style","menuId","focusedItemId","submenu","items","templates","level","pt","unstyled"])})),128))],16)})),128))],16)],16)):h("",!0)],16,S)):h("",!0),o.isItemVisible(n)&&o.getItemProp(n,"separator")?(d(),l("li",c({key:1,id:o.getItemId(n),class:[e.cx("separator"),o.getItemProp(n,"class")],style:o.getItemProp(n,"style"),role:"separator"},e.ptm("separator")),null,16,C)):h("",!0)],64)})),128))],16,F)};var z={name:"MegaMenu",extends:K,emits:["focus","blur"],outsideClickListener:null,resizeListener:null,container:null,menubar:null,searchTimeout:null,searchValue:null,data:function(){return{id:this.$attrs.id,focused:!1,focusedItemInfo:{index:-1,key:"",parentKey:""},activeItem:null,dirty:!1}},watch:{"$attrs.id":function(e){this.id=e||t()},activeItem:function(t){e.isNotEmpty(t)?(this.bindOutsideClickListener(),this.bindResizeListener()):(this.unbindOutsideClickListener(),this.unbindResizeListener())}},mounted:function(){this.id=this.id||t()},beforeUnmount:function(){this.unbindOutsideClickListener(),this.unbindResizeListener()},methods:{getItemProp:function(t,i){return t?e.getItemValue(t[i]):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemGroup:function(t){return e.isNotEmpty(this.getItemProp(t,"items"))},isItemSeparator:function(e){return this.getItemProp(e,"separator")},getProccessedItemLabel:function(e){return e?this.getItemLabel(e.item):void 0},isProccessedItemGroup:function(t){return t&&e.isNotEmpty(t.items)},hide:function(e,t){this.activeItem=null,this.focusedItemInfo={index:-1,key:"",parentKey:""},t&&i.focus(this.menubar),this.dirty=!1},onFocus:function(e){if(this.focused=!0,-1===this.focusedItemInfo.index){var t=this.findFirstFocusedItemIndex(),i=this.findVisibleItem(t);this.focusedItemInfo={index:t,key:i.key,parentKey:i.parentKey}}this.$emit("focus",e)},onBlur:function(e){this.focused=!1,this.focusedItemInfo={index:-1,key:"",parentKey:""},this.searchValue="",this.dirty=!1,this.$emit("blur",e)},onKeyDown:function(t){if(this.disabled)t.preventDefault();else{var i=t.metaKey||t.ctrlKey;switch(t.code){case"ArrowDown":this.onArrowDownKey(t);break;case"ArrowUp":this.onArrowUpKey(t);break;case"ArrowLeft":this.onArrowLeftKey(t);break;case"ArrowRight":this.onArrowRightKey(t);break;case"Home":this.onHomeKey(t);break;case"End":this.onEndKey(t);break;case"Space":this.onSpaceKey(t);break;case"Enter":this.onEnterKey(t);break;case"Escape":this.onEscapeKey(t);break;case"Tab":this.onTabKey(t);break;case"PageDown":case"PageUp":case"Backspace":case"ShiftLeft":case"ShiftRight":break;default:!i&&e.isPrintableCharacter(t.key)&&this.searchItems(t,t.key)}}},onItemChange:function(t){var n=t.processedItem,s=t.isFocus;if(!e.isEmpty(n)){var o=n.index,r=n.key,a=n.parentKey,c=e.isNotEmpty(n.items);c&&(this.activeItem=n),this.focusedItemInfo={index:o,key:r,parentKey:a},c&&(this.dirty=!0),s&&i.focus(this.menubar)}},onItemClick:function(t){var n=t.originalEvent,s=t.processedItem,o=this.isProccessedItemGroup(s),r=e.isEmpty(s.parent);if(this.isSelected(s)){var a=s.index,c=s.key,u=s.parentKey;this.activeItem=null,this.focusedItemInfo={index:a,key:c,parentKey:u},this.dirty=!r,i.focus(this.menubar)}else if(o)this.onItemChange(t);else{var m=r?s:this.activeItem;this.hide(n),this.changeFocusedItemInfo(n,m?m.index:-1),i.focus(this.menubar)}},onItemMouseEnter:function(e){this.dirty&&this.onItemChange(e)},onArrowDownKey:function(t){if(this.horizontal)if(e.isNotEmpty(this.activeItem)&&this.activeItem.key===this.focusedItemInfo.key)this.focusedItemInfo={index:-1,key:"",parentKey:this.activeItem.key};else{var i=this.findVisibleItem(this.focusedItemInfo.index);this.isProccessedItemGroup(i)&&(this.onItemChange({originalEvent:t,processedItem:i}),this.focusedItemInfo={index:-1,key:i.key,parentKey:i.parentKey},this.searchValue="")}var n=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,n),t.preventDefault()},onArrowUpKey:function(t){if(t.altKey&&this.horizontal){if(-1!==this.focusedItemInfo.index){var i=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(i)&&e.isNotEmpty(this.activeItem)&&(0===this.focusedItemInfo.index?(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null):this.changeFocusedItemInfo(t,this.findFirstItemIndex()))}t.preventDefault()}else{var n=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,n),t.preventDefault()}},onArrowLeftKey:function(t){var i=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(i)){if(this.horizontal){var n=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,n)}}else{this.vertical&&e.isNotEmpty(this.activeItem)&&0===i.columnIndex&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null);var s=i.columnIndex-1,o=this.visibleItems.findIndex((function(e){return e.columnIndex===s}));-1!==o&&this.changeFocusedItemInfo(t,o)}t.preventDefault()},onArrowRightKey:function(t){var i=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(i)){if(this.vertical)if(e.isNotEmpty(this.activeItem)&&this.activeItem.key===i.key)this.focusedItemInfo={index:-1,key:"",parentKey:this.activeItem.key};else{var n=this.findVisibleItem(this.focusedItemInfo.index);this.isProccessedItemGroup(n)&&(this.onItemChange({originalEvent:t,processedItem:n}),this.focusedItemInfo={index:-1,key:n.key,parentKey:n.parentKey},this.searchValue="")}var s=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,s)}else{var o=i.columnIndex+1,r=this.visibleItems.findIndex((function(e){return e.columnIndex===o}));-1!==r&&this.changeFocusedItemInfo(t,r)}t.preventDefault()},onHomeKey:function(e){this.changeFocusedItemInfo(e,this.findFirstItemIndex()),e.preventDefault()},onEndKey:function(e){this.changeFocusedItemInfo(e,this.findLastItemIndex()),e.preventDefault()},onEnterKey:function(e){if(-1!==this.focusedItemInfo.index){var t=i.findSingle(this.menubar,'li[id="'.concat("".concat(this.focusedItemId),'"]')),n=t&&i.findSingle(t,'a[data-pc-section="action"]');n?n.click():t&&t.click(),!this.isProccessedItemGroup(this.visibleItems[this.focusedItemInfo.index])&&this.changeFocusedItemInfo(e,this.findFirstFocusedItemIndex())}e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},onEscapeKey:function(t){e.isNotEmpty(this.activeItem)&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key},this.activeItem=null),t.preventDefault()},onTabKey:function(e){if(-1!==this.focusedItemInfo.index){var t=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(t)&&this.onItemChange({originalEvent:e,processedItem:t})}this.hide()},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var i=e.container&&!e.container.contains(t.target),n=!e.popup||!(e.target&&(e.target===t.target||e.target.contains(t.target)));i&&n&&e.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(t){i.isTouchDevice()||e.hide(t,!0)},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},isItemMatched:function(e){return this.isValidItem(e)&&this.getProccessedItemLabel(e).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase())},isValidItem:function(e){return!!e&&!this.isItemDisabled(e.item)&&!this.isItemSeparator(e.item)},isValidSelectedItem:function(e){return this.isValidItem(e)&&this.isSelected(e)},isSelected:function(t){return!!e.isNotEmpty(this.activeItem)&&this.activeItem.key===t.key},findFirstItemIndex:function(){var e=this;return this.visibleItems.findIndex((function(t){return e.isValidItem(t)}))},findLastItemIndex:function(){var t=this;return e.findLastIndex(this.visibleItems,(function(e){return t.isValidItem(e)}))},findNextItemIndex:function(e){var t=this,i=e<this.visibleItems.length-1?this.visibleItems.slice(e+1).findIndex((function(e){return t.isValidItem(e)})):-1;return i>-1?i+e+1:e},findPrevItemIndex:function(t){var i=this,n=t>0?e.findLastIndex(this.visibleItems.slice(0,t),(function(e){return i.isValidItem(e)})):-1;return n>-1?n:t},findSelectedItemIndex:function(){var e=this;return this.visibleItems.findIndex((function(t){return e.isValidSelectedItem(t)}))},findFirstFocusedItemIndex:function(){var e=this.findSelectedItemIndex();return e<0?this.findFirstItemIndex():e},findLastFocusedItemIndex:function(){var e=this.findSelectedItemIndex();return e<0?this.findLastItemIndex():e},findVisibleItem:function(t){return e.isNotEmpty(this.visibleItems)?this.visibleItems[t]:null},searchItems:function(e,t){var i=this;this.searchValue=(this.searchValue||"")+t;var n=-1,s=!1;return-1!==(n=-1!==this.focusedItemInfo.index?-1===(n=this.visibleItems.slice(this.focusedItemInfo.index).findIndex((function(e){return i.isItemMatched(e)})))?this.visibleItems.slice(0,this.focusedItemInfo.index).findIndex((function(e){return i.isItemMatched(e)})):n+this.focusedItemInfo.index:this.visibleItems.findIndex((function(e){return i.isItemMatched(e)})))&&(s=!0),-1===n&&-1===this.focusedItemInfo.index&&(n=this.findFirstFocusedItemIndex()),-1!==n&&this.changeFocusedItemInfo(e,n),this.searchTimeout&&clearTimeout(this.searchTimeout),this.searchTimeout=setTimeout((function(){i.searchValue="",i.searchTimeout=null}),500),s},changeFocusedItemInfo:function(t,i){var n=this.findVisibleItem(i);this.focusedItemInfo.index=i,this.focusedItemInfo.key=e.isNotEmpty(n)?n.key:"",this.scrollInView()},scrollInView:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1,t=-1!==e?"".concat(this.id,"_").concat(e):this.focusedItemId,n=i.findSingle(this.menubar,'li[id="'.concat(t,'"]'));n&&n.scrollIntoView&&n.scrollIntoView({block:"nearest",inline:"start"})},createProcessedItems:function(e){var t=this,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},s=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"",o=arguments.length>4?arguments[4]:void 0,r=[];return e&&e.forEach((function(e,a){var c=(""!==s?s+"_":"")+(void 0!==o?o+"_":"")+a,u={item:e,index:a,level:i,key:c,parent:n,parentKey:s,columnIndex:void 0!==o?o:void 0!==n.columnIndex?n.columnIndex:a};u.items=0===i&&e.items&&e.items.length>0?e.items.map((function(e,n){return t.createProcessedItems(e,i+1,u,c,n)})):t.createProcessedItems(e.items,i+1,u,c),r.push(u)})),r},containerRef:function(e){this.container=e},menubarRef:function(e){this.menubar=e?e.$el:void 0}},computed:{processedItems:function(){return this.createProcessedItems(this.model||[])},visibleItems:function(){var t=e.isNotEmpty(this.activeItem)?this.activeItem:null;return t&&t.key===this.focusedItemInfo.parentKey?t.items.reduce((function(e,t){return t.forEach((function(t){t.items.forEach((function(t){e.push(t)}))})),e}),[]):this.processedItems},horizontal:function(){return"horizontal"===this.orientation},vertical:function(){return"vertical"===this.orientation},focusedItemId:function(){return e.isNotEmpty(this.focusedItemInfo.key)?"".concat(this.id,"_").concat(this.focusedItemInfo.key):null}},components:{MegaMenuSub:E}},M=["id"];z.render=function(e,t,i,n,s,o){var r=u("MegaMenuSub");return d(),l("div",c({ref:o.containerRef,id:s.id,class:e.cx("root")},e.ptm("root"),{"data-pc-name":"megamenu"}),[e.$slots.start?(d(),l("div",c({key:0,class:e.cx("start")},e.ptm("start")),[P(e.$slots,"start")],16)):h("",!0),L(r,{ref:o.menubarRef,id:s.id+"_list",tabindex:e.disabled?-1:e.tabindex,role:"menubar","aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,"aria-disabled":e.disabled||void 0,"aria-orientation":e.orientation,"aria-activedescendant":s.focused?o.focusedItemId:void 0,menuId:s.id,focusedItemId:s.focused?o.focusedItemId:void 0,items:o.processedItems,horizontal:o.horizontal,templates:e.$slots,activeItem:s.activeItem,level:0,pt:e.pt,unstyled:e.unstyled,onFocus:o.onFocus,onBlur:o.onBlur,onKeydown:o.onKeyDown,onItemClick:o.onItemClick,onItemMouseenter:o.onItemMouseEnter},null,8,["id","tabindex","aria-label","aria-labelledby","aria-disabled","aria-orientation","aria-activedescendant","menuId","focusedItemId","items","horizontal","templates","activeItem","pt","unstyled","onFocus","onBlur","onKeydown","onItemClick","onItemMouseenter"]),e.$slots.end?(d(),l("div",c({key:1,class:e.cx("end")},e.ptm("end")),[P(e.$slots,"end")],16)):h("",!0)],16,M)};export{z as default};
|
|
1
|
+
import e from"primevue/icons/bars";import{ObjectUtils as t,UniqueComponentId as i,ZIndexUtils as n,DomHandler as s}from"primevue/utils";import o from"primevue/basecomponent";import r from"primevue/megamenu/style";import a from"primevue/icons/angledown";import c from"primevue/icons/angleright";import u from"primevue/ripple";import{mergeProps as m,resolveComponent as d,resolveDirective as l,openBlock as I,createElementBlock as h,toDisplayString as f,createCommentVNode as p,Fragment as v,renderList as b,createElementVNode as y,withDirectives as g,createBlock as x,resolveDynamicComponent as k,normalizeClass as L,normalizeStyle as P,renderSlot as K,createVNode as E,normalizeProps as A,guardReactiveProps as F}from"vue";var w={name:"BaseMegaMenu",extends:o,props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},breakpoint:{type:String,default:"960px"},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},style:r,provide:function(){return{$parentInstance:this}}},S={name:"MegaMenuSub",hostName:"MegaMenu",extends:o,emits:["item-click","item-mouseenter"],props:{menuId:{type:String,default:null},focusedItemId:{type:String,default:null},horizontal:{type:Boolean,default:!1},submenu:{type:Object,default:null},mobileActive:{type:Boolean,default:!1},items:{type:Array,default:null},level:{type:Number,default:0},templates:{type:Object,default:null},activeItem:{type:Object,default:null},tabindex:{type:Number,default:0}},methods:{getSubListId:function(e){return"".concat(this.getItemId(e),"_list")},getSubListKey:function(e){return this.getSubListId(e)},getItemId:function(e){return"".concat(this.menuId,"_").concat(e.key)},getItemKey:function(e){return this.getItemId(e)},getItemProp:function(e,i,n){return e&&e.item?t.getItemValue(e.item[i],n):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},getPTOptions:function(e,t,i){return this.ptm(i,{context:{item:e,index:t,active:this.isItemActive(e),focused:this.isItemFocused(e),disabled:this.isItemDisabled(e)}})},isItemActive:function(e){return!!t.isNotEmpty(this.activeItem)&&this.activeItem.key===e.key},isItemVisible:function(e){return!1!==this.getItemProp(e,"visible")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemFocused:function(e){return this.focusedItemId===this.getItemId(e)},isItemGroup:function(e){return t.isNotEmpty(e.items)},onItemClick:function(e,t){this.getItemProp(t,"command",{originalEvent:e,item:t.item}),this.$emit("item-click",{originalEvent:e,processedItem:t,isFocus:!0})},onItemMouseEnter:function(e,t){this.$emit("item-mouseenter",{originalEvent:e,processedItem:t})},getAriaSetSize:function(){var e=this;return this.items.filter((function(t){return e.isItemVisible(t)&&!e.getItemProp(t,"separator")})).length},getAriaPosInset:function(e){var t=this;return e-this.items.slice(0,e).filter((function(e){return t.isItemVisible(e)&&t.getItemProp(e,"separator")})).length+1},getMenuItemProps:function(e,t){return{action:m({class:this.cx("action"),tabindex:-1,"aria-hidden":!0},this.getPTOptions(e,t,"action")),icon:m({class:[this.cx("icon"),this.getItemProp(e,"icon")]},this.getPTOptions(e,t,"icon")),label:m({class:this.cx("label")},this.getPTOptions(e,t,"label")),submenuicon:m({class:this.cx("submenuIcon")},this.getPTOptions(e,t,"submenuIcon"))}}},components:{AngleRightIcon:c,AngleDownIcon:a},directives:{ripple:u}},V=["tabindex"],C=["id","aria-label","aria-disabled","aria-expanded","aria-haspopup","aria-level","aria-setsize","aria-posinset","data-p-highlight","data-p-focused","data-p-disabled"],M=["onClick","onMouseenter"],z=["href","target"],D=["id"];S.render=function(e,t,i,n,s,o){var r=d("MegaMenuSub",!0),a=l("ripple");return I(),h("ul",m({class:e.cx(0===i.level?"menu":"submenu"),tabindex:i.tabindex},e.ptm(0===i.level?"menu":"submenu")),[i.submenu?(I(),h("li",m({key:0,class:[e.cx("submenuHeader",{submenu:i.submenu}),o.getItemProp(i.submenu,"class")],style:o.getItemProp(i.submenu,"style"),role:"presentation"},e.ptm("submenuHeader")),f(o.getItemLabel(i.submenu)),17)):p("",!0),(I(!0),h(v,null,b(i.items,(function(n,s){return I(),h(v,{key:o.getItemKey(n)},[o.isItemVisible(n)&&!o.getItemProp(n,"separator")?(I(),h("li",m({key:0,id:o.getItemId(n),style:o.getItemProp(n,"style"),class:[e.cx("menuitem",{processedItem:n}),o.getItemProp(n,"class")],role:"menuitem","aria-label":o.getItemLabel(n),"aria-disabled":o.isItemDisabled(n)||void 0,"aria-expanded":o.isItemGroup(n)?o.isItemActive(n):void 0,"aria-haspopup":o.isItemGroup(n)&&!o.getItemProp(n,"to")?"menu":void 0,"aria-level":i.level+1,"aria-setsize":o.getAriaSetSize(),"aria-posinset":o.getAriaPosInset(s)},o.getPTOptions(n,s,"menuitem"),{"data-p-highlight":o.isItemActive(n),"data-p-focused":o.isItemFocused(n),"data-p-disabled":o.isItemDisabled(n)}),[y("div",m({class:e.cx("content"),onClick:function(e){return o.onItemClick(e,n)},onMouseenter:function(e){return o.onItemMouseEnter(e,n)}},o.getPTOptions(n,s,"content")),[i.templates.item?(I(),x(k(i.templates.item),{key:1,item:n.item,hasSubmenu:o.isItemGroup(n),label:o.getItemLabel(n),props:o.getMenuItemProps(n,s)},null,8,["item","hasSubmenu","label","props"])):g((I(),h("a",m({key:0,href:o.getItemProp(n,"url"),class:e.cx("action"),target:o.getItemProp(n,"target"),tabindex:"-1","aria-hidden":"true"},o.getPTOptions(n,s,"action")),[i.templates.itemicon?(I(),x(k(i.templates.itemicon),{key:0,item:n.item,class:L([e.cx("icon"),o.getItemProp(n,"icon")])},null,8,["item","class"])):o.getItemProp(n,"icon")?(I(),h("span",m({key:1,class:[e.cx("icon"),o.getItemProp(n,"icon")]},o.getPTOptions(n,s,"icon")),null,16)):p("",!0),y("span",m({class:e.cx(0===i.level?"label":"submenuLabel")},o.getPTOptions(n,s,0===i.level?"label":"submenuLabel")),f(o.getItemLabel(n)),17),o.isItemGroup(n)?(I(),h(v,{key:2},[i.templates.submenuicon?(I(),x(k(i.templates.submenuicon),m({key:0,active:o.isItemActive(n),class:e.cx("submenuIcon")},o.getPTOptions(n,s,"submenuIcon")),null,16,["active","class"])):(I(),x(k(i.horizontal||i.mobileActive?"AngleDownIcon":"AngleRightIcon"),m({key:1,class:e.cx("submenuIcon")},o.getPTOptions(n,s,"submenuIcon")),null,16,["class"]))],64)):p("",!0)],16,z)),[[a]])],16,M),o.isItemVisible(n)&&o.isItemGroup(n)?(I(),h("div",m({key:0,class:e.cx("panel")},e.ptm("panel")),[y("div",m({class:e.cx("grid")},e.ptm("grid")),[(I(!0),h(v,null,b(n.items,(function(s){return I(),h("div",m({key:o.getItemKey(s),class:e.cx("column",{processedItem:n})},e.ptm("column")),[(I(!0),h(v,null,b(s,(function(s){return I(),x(r,{key:o.getSubListKey(s),id:o.getSubListId(s),style:P(e.sx("submenu",!0,{processedItem:n})),role:"menu",menuId:i.menuId,focusedItemId:i.focusedItemId,submenu:s,items:s.items,templates:i.templates,level:i.level+1,mobileActive:i.mobileActive,pt:e.pt,unstyled:e.unstyled,onItemClick:t[0]||(t[0]=function(t){return e.$emit("item-click",t)}),onItemMouseenter:t[1]||(t[1]=function(t){return e.$emit("item-mouseenter",t)})},null,8,["id","style","menuId","focusedItemId","submenu","items","templates","level","mobileActive","pt","unstyled"])})),128))],16)})),128))],16)],16)):p("",!0)],16,C)):p("",!0),o.isItemVisible(n)&&o.getItemProp(n,"separator")?(I(),h("li",m({key:1,id:o.getItemId(n),class:[e.cx("separator"),o.getItemProp(n,"class")],style:o.getItemProp(n,"style"),role:"separator"},e.ptm("separator")),null,16,D)):p("",!0)],64)})),128))],16,V)};var T={name:"MegaMenu",extends:w,emits:["focus","blur"],outsideClickListener:null,resizeListener:null,container:null,menubar:null,searchTimeout:null,searchValue:null,data:function(){return{id:this.$attrs.id,mobileActive:!1,focused:!1,focusedItemInfo:{index:-1,key:"",parentKey:""},activeItem:null,dirty:!1,queryMatches:!1}},watch:{"$attrs.id":function(e){this.id=e||i()},activeItem:function(e){t.isNotEmpty(e)?(this.bindOutsideClickListener(),this.bindResizeListener()):(this.unbindOutsideClickListener(),this.unbindResizeListener())}},mounted:function(){var e=this;this.id=this.id||i();var t=matchMedia("(max-width: ".concat(this.breakpoint,")"));this.queryMatches=t.matches,t.addEventListener("change",(function(){e.queryMatches=t.matches,e.mobileActive=!1}))},beforeUnmount:function(){this.mobileActive=!1,this.unbindOutsideClickListener(),this.unbindResizeListener()},methods:{getItemProp:function(e,i){return e?t.getItemValue(e[i]):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemGroup:function(e){return t.isNotEmpty(this.getItemProp(e,"items"))},isItemSeparator:function(e){return this.getItemProp(e,"separator")},getProccessedItemLabel:function(e){return e?this.getItemLabel(e.item):void 0},isProccessedItemGroup:function(e){return e&&t.isNotEmpty(e.items)},toggle:function(e){var t=this;this.mobileActive?(this.mobileActive=!1,n.clear(this.menubar),this.hide()):(this.mobileActive=!0,n.set("menu",this.menubar,this.$primevue.config.zIndex.menu),setTimeout((function(){t.show()}),1)),this.bindOutsideClickListener(),e.preventDefault()},show:function(){this.focusedItemInfo={index:this.findFirstFocusedItemIndex(),level:0,parentKey:""},s.focus(this.menubar)},hide:function(e,t){var i=this;this.mobileActive&&(this.mobileActive=!1,setTimeout((function(){s.focus(i.$refs.menubutton)}),0)),this.activeItem=null,this.focusedItemInfo={index:-1,key:"",parentKey:""},t&&s.focus(this.menubar),this.dirty=!1},onFocus:function(e){if(this.focused=!0,-1===this.focusedItemInfo.index){var t=this.findFirstFocusedItemIndex(),i=this.findVisibleItem(t);this.focusedItemInfo={index:t,key:i.key,parentKey:i.parentKey}}this.$emit("focus",e)},onBlur:function(e){this.focused=!1,this.focusedItemInfo={index:-1,key:"",parentKey:""},this.searchValue="",this.dirty=!1,this.$emit("blur",e)},onKeyDown:function(e){if(this.disabled)e.preventDefault();else{var i=e.metaKey||e.ctrlKey;switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"ArrowLeft":this.onArrowLeftKey(e);break;case"ArrowRight":this.onArrowRightKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Space":this.onSpaceKey(e);break;case"Enter":this.onEnterKey(e);break;case"Escape":this.onEscapeKey(e);break;case"Tab":this.onTabKey(e);break;case"PageDown":case"PageUp":case"Backspace":case"ShiftLeft":case"ShiftRight":break;default:!i&&t.isPrintableCharacter(e.key)&&this.searchItems(e,e.key)}}},onItemChange:function(e){var i=e.processedItem,n=e.isFocus;if(!t.isEmpty(i)){var o=i.index,r=i.key,a=i.parentKey,c=t.isNotEmpty(i.items);c&&(this.activeItem=i),this.focusedItemInfo={index:o,key:r,parentKey:a},c&&(this.dirty=!0),n&&s.focus(this.menubar)}},onItemClick:function(e){var i=e.originalEvent,n=e.processedItem,o=this.isProccessedItemGroup(n),r=t.isEmpty(n.parent);if(this.isSelected(n)){var a=n.index,c=n.key,u=n.parentKey;this.activeItem=null,this.focusedItemInfo={index:a,key:c,parentKey:u},this.dirty=!r,s.focus(this.menubar)}else if(o)this.onItemChange(e);else{var m=r?n:this.activeItem;this.hide(i),this.changeFocusedItemInfo(i,m?m.index:-1),this.mobileActive=!1,s.focus(this.menubar)}},onItemMouseEnter:function(e){!this.mobileActive&&this.dirty&&this.onItemChange(e)},menuButtonClick:function(e){this.toggle(e)},menuButtonKeydown:function(e){("Enter"===e.code||"Space"===e.code)&&this.menuButtonClick(e)},onArrowDownKey:function(e){if(this.horizontal)if(t.isNotEmpty(this.activeItem)&&this.activeItem.key===this.focusedItemInfo.key)this.focusedItemInfo={index:-1,key:"",parentKey:this.activeItem.key};else{var i=this.findVisibleItem(this.focusedItemInfo.index);this.isProccessedItemGroup(i)&&(this.onItemChange({originalEvent:e,processedItem:i}),this.focusedItemInfo={index:-1,key:i.key,parentKey:i.parentKey},this.searchValue="")}var n=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(e,n),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.horizontal){if(-1!==this.focusedItemInfo.index){var i=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(i)&&t.isNotEmpty(this.activeItem)&&(0===this.focusedItemInfo.index?(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null):this.changeFocusedItemInfo(e,this.findFirstItemIndex()))}e.preventDefault()}else{var n=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(e,n),e.preventDefault()}},onArrowLeftKey:function(e){var i=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(i)){if(this.horizontal){var n=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(e,n)}}else{this.vertical&&t.isNotEmpty(this.activeItem)&&0===i.columnIndex&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null);var s=i.columnIndex-1,o=this.visibleItems.findIndex((function(e){return e.columnIndex===s}));-1!==o&&this.changeFocusedItemInfo(e,o)}e.preventDefault()},onArrowRightKey:function(e){var i=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(i)){if(this.vertical)if(t.isNotEmpty(this.activeItem)&&this.activeItem.key===i.key)this.focusedItemInfo={index:-1,key:"",parentKey:this.activeItem.key};else{var n=this.findVisibleItem(this.focusedItemInfo.index);this.isProccessedItemGroup(n)&&(this.onItemChange({originalEvent:e,processedItem:n}),this.focusedItemInfo={index:-1,key:n.key,parentKey:n.parentKey},this.searchValue="")}var s=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(e,s)}else{var o=i.columnIndex+1,r=this.visibleItems.findIndex((function(e){return e.columnIndex===o}));-1!==r&&this.changeFocusedItemInfo(e,r)}e.preventDefault()},onHomeKey:function(e){this.changeFocusedItemInfo(e,this.findFirstItemIndex()),e.preventDefault()},onEndKey:function(e){this.changeFocusedItemInfo(e,this.findLastItemIndex()),e.preventDefault()},onEnterKey:function(e){if(-1!==this.focusedItemInfo.index){var t=s.findSingle(this.menubar,'li[id="'.concat("".concat(this.focusedItemId),'"]')),i=t&&s.findSingle(t,'a[data-pc-section="action"]');i?i.click():t&&t.click(),!this.isProccessedItemGroup(this.visibleItems[this.focusedItemInfo.index])&&this.changeFocusedItemInfo(e,this.findFirstFocusedItemIndex())}e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},onEscapeKey:function(e){t.isNotEmpty(this.activeItem)&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key},this.activeItem=null),e.preventDefault()},onTabKey:function(e){if(-1!==this.focusedItemInfo.index){var t=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(t)&&this.onItemChange({originalEvent:e,processedItem:t})}this.hide()},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var i=e.container&&!e.container.contains(t.target),n=!(e.target&&(e.target===t.target||e.target.contains(t.target)));i&&n&&e.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(t){s.isTouchDevice()||e.hide(t,!0),e.mobileActive=!1},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},isItemMatched:function(e){return this.isValidItem(e)&&this.getProccessedItemLabel(e).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase())},isValidItem:function(e){return!!e&&!this.isItemDisabled(e.item)&&!this.isItemSeparator(e.item)},isValidSelectedItem:function(e){return this.isValidItem(e)&&this.isSelected(e)},isSelected:function(e){return!!t.isNotEmpty(this.activeItem)&&this.activeItem.key===e.key},findFirstItemIndex:function(){var e=this;return this.visibleItems.findIndex((function(t){return e.isValidItem(t)}))},findLastItemIndex:function(){var e=this;return t.findLastIndex(this.visibleItems,(function(t){return e.isValidItem(t)}))},findNextItemIndex:function(e){var t=this,i=e<this.visibleItems.length-1?this.visibleItems.slice(e+1).findIndex((function(e){return t.isValidItem(e)})):-1;return i>-1?i+e+1:e},findPrevItemIndex:function(e){var i=this,n=e>0?t.findLastIndex(this.visibleItems.slice(0,e),(function(e){return i.isValidItem(e)})):-1;return n>-1?n:e},findSelectedItemIndex:function(){var e=this;return this.visibleItems.findIndex((function(t){return e.isValidSelectedItem(t)}))},findFirstFocusedItemIndex:function(){var e=this.findSelectedItemIndex();return e<0?this.findFirstItemIndex():e},findLastFocusedItemIndex:function(){var e=this.findSelectedItemIndex();return e<0?this.findLastItemIndex():e},findVisibleItem:function(e){return t.isNotEmpty(this.visibleItems)?this.visibleItems[e]:null},searchItems:function(e,t){var i=this;this.searchValue=(this.searchValue||"")+t;var n=-1,s=!1;return-1!==(n=-1!==this.focusedItemInfo.index?-1===(n=this.visibleItems.slice(this.focusedItemInfo.index).findIndex((function(e){return i.isItemMatched(e)})))?this.visibleItems.slice(0,this.focusedItemInfo.index).findIndex((function(e){return i.isItemMatched(e)})):n+this.focusedItemInfo.index:this.visibleItems.findIndex((function(e){return i.isItemMatched(e)})))&&(s=!0),-1===n&&-1===this.focusedItemInfo.index&&(n=this.findFirstFocusedItemIndex()),-1!==n&&this.changeFocusedItemInfo(e,n),this.searchTimeout&&clearTimeout(this.searchTimeout),this.searchTimeout=setTimeout((function(){i.searchValue="",i.searchTimeout=null}),500),s},changeFocusedItemInfo:function(e,i){var n=this.findVisibleItem(i);this.focusedItemInfo.index=i,this.focusedItemInfo.key=t.isNotEmpty(n)?n.key:"",this.scrollInView()},scrollInView:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1,t=-1!==e?"".concat(this.id,"_").concat(e):this.focusedItemId,i=s.findSingle(this.menubar,'li[id="'.concat(t,'"]'));i&&i.scrollIntoView&&i.scrollIntoView({block:"nearest",inline:"start"})},createProcessedItems:function(e){var t=this,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},s=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"",o=arguments.length>4?arguments[4]:void 0,r=[];return e&&e.forEach((function(e,a){var c=(""!==s?s+"_":"")+(void 0!==o?o+"_":"")+a,u={item:e,index:a,level:i,key:c,parent:n,parentKey:s,columnIndex:void 0!==o?o:void 0!==n.columnIndex?n.columnIndex:a};u.items=0===i&&e.items&&e.items.length>0?e.items.map((function(e,n){return t.createProcessedItems(e,i+1,u,c,n)})):t.createProcessedItems(e.items,i+1,u,c),r.push(u)})),r},containerRef:function(e){this.container=e},menubarRef:function(e){this.menubar=e?e.$el:void 0}},computed:{processedItems:function(){return this.createProcessedItems(this.model||[])},visibleItems:function(){var e=t.isNotEmpty(this.activeItem)?this.activeItem:null;return e&&e.key===this.focusedItemInfo.parentKey?e.items.reduce((function(e,t){return t.forEach((function(t){t.items.forEach((function(t){e.push(t)}))})),e}),[]):this.processedItems},horizontal:function(){return"horizontal"===this.orientation},vertical:function(){return"vertical"===this.orientation},focusedItemId:function(){return t.isNotEmpty(this.focusedItemInfo.key)?"".concat(this.id,"_").concat(this.focusedItemInfo.key):null}},components:{MegaMenuSub:S,BarsIcon:e}},N=["id"],O=["aria-haspopup","aria-expanded","aria-controls","aria-label"];T.render=function(e,t,i,n,s,o){var r,a=d("BarsIcon"),c=d("MegaMenuSub");return I(),h("div",m({ref:o.containerRef,id:s.id,class:e.cx("root")},e.ptm("root"),{"data-pc-name":"megamenu"}),[e.$slots.start?(I(),h("div",m({key:0,class:e.cx("start")},e.ptm("start")),[K(e.$slots,"start")],16)):p("",!0),e.model&&e.model.length>0?(I(),h("a",m({key:1,ref:"menubutton",role:"button",tabindex:"0",class:e.cx("menubutton"),"aria-haspopup":!!(e.model.length&&e.model.length>0),"aria-expanded":s.mobileActive,"aria-controls":s.id,"aria-label":null===(r=e.$primevue.config.locale.aria)||void 0===r?void 0:r.navigation,onClick:t[0]||(t[0]=function(e){return o.menuButtonClick(e)}),onKeydown:t[1]||(t[1]=function(e){return o.menuButtonKeydown(e)})},e.ptm("menubutton")),[K(e.$slots,"menubuttonicon",{},(function(){return[E(a,A(F(e.ptm("menubuttonicon"))),null,16)]}))],16,O)):p("",!0),E(c,{ref:o.menubarRef,id:s.id+"_list",tabindex:e.disabled?-1:e.tabindex,role:"menubar","aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,"aria-disabled":e.disabled||void 0,"aria-orientation":e.orientation,"aria-activedescendant":s.focused?o.focusedItemId:void 0,menuId:s.id,focusedItemId:s.focused?o.focusedItemId:void 0,items:o.processedItems,horizontal:o.horizontal,templates:e.$slots,activeItem:s.activeItem,mobileActive:s.mobileActive,level:0,pt:e.pt,unstyled:e.unstyled,onFocus:o.onFocus,onBlur:o.onBlur,onKeydown:o.onKeyDown,onItemClick:o.onItemClick,onItemMouseenter:o.onItemMouseEnter},null,8,["id","tabindex","aria-label","aria-labelledby","aria-disabled","aria-orientation","aria-activedescendant","menuId","focusedItemId","items","horizontal","templates","activeItem","mobileActive","pt","unstyled","onFocus","onBlur","onKeydown","onItemClick","onItemMouseenter"]),e.$slots.end?(I(),h("div",m({key:2,class:e.cx("end")},e.ptm("end")),[K(e.$slots,"end")],16)):p("",!0)],16,N)};export{T as default};
|