primevue 3.30.2 → 3.31.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/breadcrumb/Breadcrumb.d.ts +15 -0
- package/breadcrumb/BreadcrumbItem.vue +18 -8
- package/breadcrumb/breadcrumb.cjs.js +18 -8
- package/breadcrumb/breadcrumb.cjs.min.js +1 -1
- package/breadcrumb/breadcrumb.esm.js +18 -8
- package/breadcrumb/breadcrumb.esm.min.js +1 -1
- package/breadcrumb/breadcrumb.js +18 -8
- package/breadcrumb/breadcrumb.min.js +1 -1
- package/cascadeselect/CascadeSelect.vue +1 -0
- package/cascadeselect/CascadeSelectSub.vue +1 -0
- package/cascadeselect/cascadeselect.cjs.js +6 -4
- package/cascadeselect/cascadeselect.cjs.min.js +1 -1
- package/cascadeselect/cascadeselect.esm.js +6 -4
- package/cascadeselect/cascadeselect.esm.min.js +1 -1
- package/cascadeselect/cascadeselect.js +6 -4
- package/cascadeselect/cascadeselect.min.js +1 -1
- package/config/PrimeVue.d.ts +14 -0
- package/contextmenu/ContextMenu.d.ts +8 -0
- package/contextmenu/ContextMenuSub.vue +13 -11
- package/contextmenu/contextmenu.cjs.js +13 -11
- package/contextmenu/contextmenu.cjs.min.js +1 -1
- package/contextmenu/contextmenu.esm.js +13 -11
- package/contextmenu/contextmenu.esm.min.js +1 -1
- package/contextmenu/contextmenu.js +13 -11
- package/contextmenu/contextmenu.min.js +1 -1
- package/core/core.js +3417 -18
- package/core/core.min.js +5 -3
- package/dock/Dock.d.ts +4 -0
- package/dock/DockSub.vue +8 -7
- package/dock/dock.cjs.js +8 -7
- package/dock/dock.cjs.min.js +1 -1
- package/dock/dock.esm.js +8 -7
- package/dock/dock.esm.min.js +1 -1
- package/dock/dock.js +8 -7
- package/dock/dock.min.js +1 -1
- package/dropdown/BaseDropdown.vue +5 -5
- package/dropdown/dropdown.cjs.js +5 -5
- package/dropdown/dropdown.cjs.min.js +1 -1
- package/dropdown/dropdown.esm.js +5 -5
- package/dropdown/dropdown.esm.min.js +1 -1
- package/dropdown/dropdown.js +5 -5
- package/dropdown/dropdown.min.js +1 -1
- package/image/Image.vue +2 -2
- package/image/image.cjs.js +2 -2
- package/image/image.cjs.min.js +1 -1
- package/image/image.esm.js +2 -2
- package/image/image.esm.min.js +1 -1
- package/image/image.js +2 -2
- package/image/image.min.js +1 -1
- package/inputswitch/InputSwitch.d.ts +2 -2
- package/megamenu/MegaMenu.d.ts +8 -0
- package/megamenu/MegaMenuSub.vue +13 -11
- package/megamenu/megamenu.cjs.js +13 -11
- package/megamenu/megamenu.cjs.min.js +1 -1
- package/megamenu/megamenu.esm.js +13 -11
- package/megamenu/megamenu.esm.min.js +1 -1
- package/megamenu/megamenu.js +13 -11
- package/megamenu/megamenu.min.js +1 -1
- package/menu/Menu.d.ts +8 -0
- package/menu/Menu.vue +1 -1
- package/menu/Menuitem.vue +4 -1
- package/menu/menu.cjs.js +6 -2
- package/menu/menu.cjs.min.js +1 -1
- package/menu/menu.esm.js +6 -2
- package/menu/menu.esm.min.js +1 -1
- package/menu/menu.js +6 -2
- package/menu/menu.min.js +1 -1
- package/menubar/Menubar.d.ts +8 -0
- package/menubar/MenubarSub.vue +12 -10
- package/menubar/menubar.cjs.js +12 -10
- package/menubar/menubar.cjs.min.js +1 -1
- package/menubar/menubar.esm.js +12 -10
- package/menubar/menubar.esm.min.js +1 -1
- package/menubar/menubar.js +12 -10
- package/menubar/menubar.min.js +1 -1
- package/package.json +1 -1
- package/panelmenu/PanelMenu.d.ts +8 -0
- package/panelmenu/PanelMenu.vue +12 -11
- package/panelmenu/PanelMenuSub.vue +13 -11
- package/panelmenu/panelmenu.cjs.js +25 -22
- package/panelmenu/panelmenu.cjs.min.js +1 -1
- package/panelmenu/panelmenu.esm.js +25 -22
- package/panelmenu/panelmenu.esm.min.js +1 -1
- package/panelmenu/panelmenu.js +25 -22
- package/panelmenu/panelmenu.min.js +1 -1
- package/resources/themes/bootstrap4-dark-blue/theme.css +0 -7
- package/resources/themes/bootstrap4-dark-purple/theme.css +0 -7
- package/resources/themes/bootstrap4-light-blue/theme.css +0 -7
- package/resources/themes/bootstrap4-light-purple/theme.css +0 -7
- package/splitterpanel/SplitterPanel.d.ts +11 -0
- package/splitterpanel/SplitterPanel.vue +7 -0
- package/splitterpanel/splitterpanel.cjs.js +7 -0
- package/splitterpanel/splitterpanel.cjs.min.js +1 -1
- package/splitterpanel/splitterpanel.esm.js +7 -0
- package/splitterpanel/splitterpanel.esm.min.js +1 -1
- package/splitterpanel/splitterpanel.js +7 -0
- package/splitterpanel/splitterpanel.min.js +1 -1
- package/steps/BaseSteps.vue +1 -1
- package/steps/Steps.d.ts +25 -0
- package/steps/Steps.vue +17 -7
- package/steps/steps.cjs.js +19 -9
- package/steps/steps.cjs.min.js +1 -1
- package/steps/steps.esm.js +19 -9
- package/steps/steps.esm.min.js +1 -1
- package/steps/steps.js +19 -9
- package/steps/steps.min.js +1 -1
- package/tabmenu/TabMenu.d.ts +6 -2
- package/tabmenu/TabMenu.vue +11 -10
- package/tabmenu/tabmenu.cjs.js +11 -10
- package/tabmenu/tabmenu.cjs.min.js +1 -1
- package/tabmenu/tabmenu.esm.js +11 -10
- package/tabmenu/tabmenu.esm.min.js +1 -1
- package/tabmenu/tabmenu.js +11 -10
- package/tabmenu/tabmenu.min.js +1 -1
- package/tabview/TabView.vue +1 -0
- package/tabview/tabview.cjs.js +2 -1
- package/tabview/tabview.cjs.min.js +1 -1
- package/tabview/tabview.esm.js +2 -1
- package/tabview/tabview.esm.min.js +1 -1
- package/tabview/tabview.js +2 -1
- package/tabview/tabview.min.js +1 -1
- package/tailwind/Tailwind.d.ts +5 -0
- package/tailwind/package.json +6 -0
- package/tailwind/tailwind.cjs.js +3388 -0
- package/tailwind/tailwind.cjs.min.js +1 -0
- package/tailwind/tailwind.esm.js +3386 -0
- package/tailwind/tailwind.esm.min.js +1 -0
- package/tailwind/tailwind.js +3392 -0
- package/tailwind/tailwind.min.js +1 -0
- package/tieredmenu/TieredMenu.d.ts +8 -0
- package/tieredmenu/TieredMenuSub.vue +13 -11
- package/tieredmenu/tieredmenu.cjs.js +13 -11
- package/tieredmenu/tieredmenu.cjs.min.js +1 -1
- package/tieredmenu/tieredmenu.esm.js +13 -11
- package/tieredmenu/tieredmenu.esm.min.js +1 -1
- package/tieredmenu/tieredmenu.js +13 -11
- package/tieredmenu/tieredmenu.min.js +1 -1
- package/web-types.json +1 -1
package/megamenu/megamenu.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
this.primevue=this.primevue||{},this.primevue.megamenu=function(e,t,n,i,s,o,r){"use strict";function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(t),m=a(i),l=a(s),u=a(o),d=n.useStyle("\n.p-megamenu {\n display: flex;\n}\n\n.p-megamenu-root-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-megamenu-root-list > .p-menuitem {\n position: relative;\n}\n\n.p-megamenu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-megamenu .p-menuitem-text {\n line-height: 1;\n}\n\n.p-megamenu-panel {\n display: none;\n position: absolute;\n width: auto;\n z-index: 1;\n}\n\n.p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n display: block;\n}\n\n.p-megamenu-submenu {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n/* Horizontal */\n.p-megamenu-horizontal {\n align-items: center;\n}\n\n.p-megamenu-horizontal .p-megamenu-root-list {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n}\n\n.p-megamenu-horizontal .p-megamenu-end {\n margin-left: auto;\n align-self: center;\n}\n\n/* Vertical */\n.p-megamenu-vertical {\n flex-direction: column;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list {\n flex-direction: column;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n left: 100%;\n top: 0;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem > .p-menuitem-content > .p-menuitem-link > .p-submenu-icon {\n margin-left: auto;\n}\n\n.p-megamenu-grid {\n display: flex;\n}\n\n.p-megamenu-col-2,\n.p-megamenu-col-3,\n.p-megamenu-col-4,\n.p-megamenu-col-6,\n.p-megamenu-col-12 {\n flex: 0 0 auto;\n padding: 0.5rem;\n}\n\n.p-megamenu-col-2 {\n width: 16.6667%;\n}\n\n.p-megamenu-col-3 {\n width: 25%;\n}\n\n.p-megamenu-col-4 {\n width: 33.3333%;\n}\n\n.p-megamenu-col-6 {\n width: 50%;\n}\n\n.p-megamenu-col-12 {\n width: 100%;\n}\n",{name:"megamenu",manual:!0}),I={name:"BaseMegaMenu",extends:c.default,props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},exact:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-megamenu p-component",{"p-megamenu-horizontal":t.horizontal,"p-megamenu-vertical":t.vertical}]},start:"p-megamenu-start",menu:"p-megamenu-root-list",submenuHeader:function(e){return["p-megamenu-submenu-header p-submenu-header",{"p-disabled":e.instance.isItemDisabled(e.processedItem)}]},menuitem:function(e){var t=e.instance,n=e.processedItem;return["p-menuitem",{"p-menuitem-active p-highlight":t.isItemActive(n),"p-focus":t.isItemFocused(n),"p-disabled":t.isItemDisabled(n)}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text",submenuIcon:"p-submenu-icon",panel:"p-megamenu-panel",grid:"p-megamenu-grid",column:function(e){var t,n=e.processedItem;switch(e.instance.isItemGroup(n)?n.items.length:0){case 2:t="p-megamenu-col-6";break;case 3:t="p-megamenu-col-4";break;case 4:t="p-megamenu-col-3";break;case 6:t="p-megamenu-col-2";break;default:t="p-megamenu-col-12"}return t},submenu:"p-submenu-list p-megamenu-submenu",separator:"p-menuitem-separator",end:"p-megamenu-end"},inlineStyles:{submenu:function(e){return{display:e.instance.isItemActive(e.processedItem)?"block":"none"}}},loadStyle:d.load},provide:function(){return{$parentInstance:this}}},p={name:"MegaMenuSub",hostName:"MegaMenu",extends:c.default,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},exact:{type:Boolean,default:!0},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,n,i){return t&&t.item?e.ObjectUtils.getItemValue(t.item[n],i):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},getPTOptions:function(e,t){return this.ptm(t,{context:{active:this.isItemActive(e),focused:this.isItemFocused(e)}})},isItemActive:function(t){return!!e.ObjectUtils.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.ObjectUtils.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})},onItemActionClick:function(e,t){t&&t(e)},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}},components:{AngleRightIcon:l.default,AngleDownIcon:m.default},directives:{ripple:u.default}},f=["tabindex"],h=["id","aria-label","aria-disabled","aria-expanded","aria-haspopup","aria-level","aria-setsize","aria-posinset","data-p-highlight","data-p-focused","data-p-disabled"],g=["onClick","onMouseenter"],v=["href","onClick"],b=["href","target"],y=["id"];p.render=function(e,t,n,i,s,o){var a=r.resolveComponent("router-link"),c=r.resolveComponent("MegaMenuSub",!0),m=r.resolveDirective("ripple");return r.openBlock(),r.createElementBlock("ul",r.mergeProps({class:e.cx(0===n.level?"menu":"submenu"),tabindex:n.tabindex},e.ptm(0===n.level?"menu":"submenu")),[n.submenu?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:0,class:[e.cx("submenuHeader",{submenu:n.submenu}),o.getItemProp(n.submenu,"class")],style:o.getItemProp(n.submenu,"style"),role:"presentation"},e.ptm("submenuHeader")),r.toDisplayString(o.getItemLabel(n.submenu)),17)):r.createCommentVNode("",!0),(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(n.items,(function(i,s){return r.openBlock(),r.createElementBlock(r.Fragment,{key:o.getItemKey(i)},[o.isItemVisible(i)&&!o.getItemProp(i,"separator")?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:0,id:o.getItemId(i),style:o.getItemProp(i,"style"),class:[e.cx("menuitem",{processedItem:i}),o.getItemProp(i,"class")],role:"menuitem","aria-label":o.getItemLabel(i),"aria-disabled":o.isItemDisabled(i)||void 0,"aria-expanded":o.isItemGroup(i)?o.isItemActive(i):void 0,"aria-haspopup":o.isItemGroup(i)&&!o.getItemProp(i,"to")?"menu":void 0,"aria-level":n.level+1,"aria-setsize":o.getAriaSetSize(),"aria-posinset":o.getAriaPosInset(s)},o.getPTOptions(i,"menuitem"),{"data-p-highlight":o.isItemActive(i),"data-p-focused":o.isItemFocused(i),"data-p-disabled":o.isItemDisabled(i)}),[r.createElementVNode("div",r.mergeProps({class:e.cx("content"),onClick:function(e){return o.onItemClick(e,i)},onMouseenter:function(e){return o.onItemMouseEnter(e,i)}},o.getPTOptions(i,"content")),[n.templates.item?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.item),{key:1,item:i.item},null,8,["item"])):(r.openBlock(),r.createElementBlock(r.Fragment,{key:0},[o.getItemProp(i,"to")&&!o.isItemDisabled(i)?(r.openBlock(),r.createBlock(a,{key:0,to:o.getItemProp(i,"to"),custom:""},{default:r.withCtx((function(t){var s=t.navigate,a=t.href,c=t.isActive,l=t.isExactActive;return[r.withDirectives((r.openBlock(),r.createElementBlock("a",r.mergeProps({href:a,class:e.cx("action",{isActive:c,isExactActive:l}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return o.onItemActionClick(e,s)}},o.getPTOptions(i,"action")),[n.templates.itemicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.itemicon),{key:0,item:i.item,class:r.normalizeClass([e.cx("icon"),o.getItemProp(i,"icon")])},null,8,["item","class"])):o.getItemProp(i,"icon")?(r.openBlock(),r.createElementBlock("span",r.mergeProps({key:1,class:[e.cx("icon"),o.getItemProp(i,"icon")]},o.getPTOptions(i,"icon")),null,16)):r.createCommentVNode("",!0),r.createElementVNode("span",r.mergeProps({class:e.cx("text")},o.getPTOptions(i,"label")),r.toDisplayString(o.getItemLabel(i)),17)],16,v)),[[m]])]})),_:2},1032,["to"])):r.withDirectives((r.openBlock(),r.createElementBlock("a",r.mergeProps({key:1,href:o.getItemProp(i,"url"),class:e.cx("action"),target:o.getItemProp(i,"target"),tabindex:"-1","aria-hidden":"true"},o.getPTOptions(i,"action")),[n.templates.itemicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.itemicon),{key:0,item:i.item,class:r.normalizeClass([e.cx("icon"),o.getItemProp(i,"icon")])},null,8,["item","class"])):o.getItemProp(i,"icon")?(r.openBlock(),r.createElementBlock("span",r.mergeProps({key:1,class:[e.cx("icon"),o.getItemProp(i,"icon")]},o.getPTOptions(i,"icon")),null,16)):r.createCommentVNode("",!0),r.createElementVNode("span",r.mergeProps({class:e.cx("text")},o.getPTOptions(i,"label")),r.toDisplayString(o.getItemLabel(i)),17),o.isItemGroup(i)?(r.openBlock(),r.createElementBlock(r.Fragment,{key:2},[n.templates.submenuicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.submenuicon),r.mergeProps({key:0,active:o.isItemActive(i),class:e.cx("submenuIcon")},o.getPTOptions(i,"submenuIcon")),null,16,["active","class"])):(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.horizontal?"AngleDownIcon":"AngleRightIcon"),r.mergeProps({key:1,class:e.cx("submenuIcon")},o.getPTOptions(i,"submenuIcon")),null,16,["class"]))],64)):r.createCommentVNode("",!0)],16,b)),[[m]])],64))],16,g),o.isItemVisible(i)&&o.isItemGroup(i)?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:0,class:e.cx("panel")},e.ptm("panel")),[r.createElementVNode("div",r.mergeProps({class:e.cx("grid")},e.ptm("grid")),[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(i.items,(function(s){return r.openBlock(),r.createElementBlock("div",r.mergeProps({key:o.getItemKey(s),class:e.cx("column",{processedItem:i})},e.ptm("column")),[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(s,(function(s){return r.openBlock(),r.createBlock(c,{key:o.getSubListKey(s),id:o.getSubListId(s),style:r.normalizeStyle(e.sx("submenu",!0,{processedItem:i})),role:"menu",menuId:n.menuId,focusedItemId:n.focusedItemId,submenu:s,items:s.items,templates:n.templates,exact:n.exact,level:n.level+1,pt:e.pt,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","exact","level","pt"])})),128))],16)})),128))],16)],16)):r.createCommentVNode("",!0)],16,h)):r.createCommentVNode("",!0),o.isItemVisible(i)&&o.getItemProp(i,"separator")?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:1,id:o.getItemId(i),class:[e.cx("separator"),o.getItemProp(i,"class")],style:o.getItemProp(i,"style"),role:"separator"},e.ptm("separator")),null,16,y)):r.createCommentVNode("",!0)],64)})),128))],16,f)};var k={name:"MegaMenu",extends:I,emits:["focus","blur"],props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},exact:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},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(t){this.id=t||e.UniqueComponentId()},activeItem:function(t){e.ObjectUtils.isNotEmpty(t)?(this.bindOutsideClickListener(),this.bindResizeListener()):(this.unbindOutsideClickListener(),this.unbindResizeListener())}},mounted:function(){this.id=this.id||e.UniqueComponentId()},beforeUnmount:function(){this.unbindOutsideClickListener(),this.unbindResizeListener()},methods:{getItemProp:function(t,n){return t?e.ObjectUtils.getItemValue(t[n]):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemGroup:function(t){return e.ObjectUtils.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.ObjectUtils.isNotEmpty(t.items)},hide:function(t,n){this.activeItem=null,this.focusedItemInfo={index:-1,key:"",parentKey:""},n&&e.DomHandler.focus(this.menubar),this.dirty=!1},onFocus:function(e){if(this.focused=!0,-1===this.focusedItemInfo.index){var t=this.findFirstFocusedItemIndex(),n=this.findVisibleItem(t);this.focusedItemInfo={index:t,key:n.key,parentKey:n.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 n=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:!n&&e.ObjectUtils.isPrintableCharacter(t.key)&&this.searchItems(t,t.key)}}},onItemChange:function(t){var n=t.processedItem,i=t.isFocus;if(!e.ObjectUtils.isEmpty(n)){var s=n.index,o=n.key,r=n.parentKey,a=e.ObjectUtils.isNotEmpty(n.items);a&&(this.activeItem=n),this.focusedItemInfo={index:s,key:o,parentKey:r},a&&(this.dirty=!0),i&&e.DomHandler.focus(this.menubar)}},onItemClick:function(t){var n=t.originalEvent,i=t.processedItem,s=this.isProccessedItemGroup(i),o=e.ObjectUtils.isEmpty(i.parent);if(this.isSelected(i)){var r=i.index,a=i.key,c=i.parentKey;this.activeItem=null,this.focusedItemInfo={index:r,key:a,parentKey:c},this.dirty=!o,e.DomHandler.focus(this.menubar)}else if(s)this.onItemChange(t);else{var m=o?i:this.activeItem;this.hide(n),this.changeFocusedItemInfo(n,m?m.index:-1),e.DomHandler.focus(this.menubar)}},onItemMouseEnter:function(e){this.dirty&&this.onItemChange(e)},onArrowDownKey:function(t){if(this.horizontal)if(e.ObjectUtils.isNotEmpty(this.activeItem)&&this.activeItem.key===this.focusedItemInfo.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 i=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,i),t.preventDefault()},onArrowUpKey:function(t){if(t.altKey&&this.horizontal){if(-1!==this.focusedItemInfo.index){var n=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(n)&&e.ObjectUtils.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 i=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,i),t.preventDefault()}},onArrowLeftKey:function(t){var n=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(n)){if(this.horizontal){var i=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,i)}}else{this.vertical&&e.ObjectUtils.isNotEmpty(this.activeItem)&&0===n.columnIndex&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null);var s=n.columnIndex-1,o=this.visibleItems.findIndex((function(e){return e.columnIndex===s}));-1!==o&&this.changeFocusedItemInfo(t,o)}t.preventDefault()},onArrowRightKey:function(t){var n=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(n)){if(this.vertical)if(e.ObjectUtils.isNotEmpty(this.activeItem)&&this.activeItem.key===n.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 s=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,s)}else{var o=n.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(t){if(-1!==this.focusedItemInfo.index){var n=e.DomHandler.findSingle(this.menubar,'li[id="'.concat("".concat(this.focusedItemId),'"]')),i=n&&e.DomHandler.findSingle(n,'a[data-pc-section="action"]');i?i.click():n&&n.click(),!this.isProccessedItemGroup(this.visibleItems[this.focusedItemInfo.index])&&this.changeFocusedItemInfo(t,this.findFirstFocusedItemIndex())}t.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},onEscapeKey:function(t){e.ObjectUtils.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 n=e.container&&!e.container.contains(t.target),i=!e.popup||!(e.target&&(e.target===t.target||e.target.contains(t.target)));n&&i&&e.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindResizeListener:function(){var t=this;this.resizeListener||(this.resizeListener=function(n){e.DomHandler.isTouchDevice()||t.hide(n,!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.ObjectUtils.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.ObjectUtils.findLastIndex(this.visibleItems,(function(e){return t.isValidItem(e)}))},findNextItemIndex:function(e){var t=this,n=e<this.visibleItems.length-1?this.visibleItems.slice(e+1).findIndex((function(e){return t.isValidItem(e)})):-1;return n>-1?n+e+1:e},findPrevItemIndex:function(t){var n=this,i=t>0?e.ObjectUtils.findLastIndex(this.visibleItems.slice(0,t),(function(e){return n.isValidItem(e)})):-1;return i>-1?i: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.ObjectUtils.isNotEmpty(this.visibleItems)?this.visibleItems[t]:null},searchItems:function(e,t){var n=this;this.searchValue=(this.searchValue||"")+t;var i=-1,s=!1;return-1!==(i=-1!==this.focusedItemInfo.index?-1===(i=this.visibleItems.slice(this.focusedItemInfo.index).findIndex((function(e){return n.isItemMatched(e)})))?this.visibleItems.slice(0,this.focusedItemInfo.index).findIndex((function(e){return n.isItemMatched(e)})):i+this.focusedItemInfo.index:this.visibleItems.findIndex((function(e){return n.isItemMatched(e)})))&&(s=!0),-1===i&&-1===this.focusedItemInfo.index&&(i=this.findFirstFocusedItemIndex()),-1!==i&&this.changeFocusedItemInfo(e,i),this.searchTimeout&&clearTimeout(this.searchTimeout),this.searchTimeout=setTimeout((function(){n.searchValue="",n.searchTimeout=null}),500),s},changeFocusedItemInfo:function(t,n){var i=this.findVisibleItem(n);this.focusedItemInfo.index=n,this.focusedItemInfo.key=e.ObjectUtils.isNotEmpty(i)?i.key:"",this.scrollInView()},scrollInView:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1,n=-1!==t?"".concat(this.id,"_").concat(t):this.focusedItemId,i=e.DomHandler.findSingle(this.menubar,'li[id="'.concat(n,'"]'));i&&i.scrollIntoView&&i.scrollIntoView({block:"nearest",inline:"start"})},createProcessedItems:function(e){var t=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=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,m={item:e,index:a,level:n,key:c,parent:i,parentKey:s,columnIndex:void 0!==o?o:void 0!==i.columnIndex?i.columnIndex:a};m.items=0===n&&e.items&&e.items.length>0?e.items.map((function(e,i){return t.createProcessedItems(e,n+1,m,c,i)})):t.createProcessedItems(e.items,n+1,m,c),r.push(m)})),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.ObjectUtils.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.ObjectUtils.isNotEmpty(this.focusedItemInfo.key)?"".concat(this.id,"_").concat(this.focusedItemInfo.key):null}},components:{MegaMenuSub:p}},x=["id"];return k.render=function(e,t,n,i,s,o){var a=r.resolveComponent("MegaMenuSub");return r.openBlock(),r.createElementBlock("div",r.mergeProps({ref:o.containerRef,id:s.id,class:e.cx("root")},e.ptm("root"),{"data-pc-name":"megamenu"}),[e.$slots.start?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[r.renderSlot(e.$slots,"start")],16)):r.createCommentVNode("",!0),r.createVNode(a,{ref:o.menubarRef,id:s.id+"_list",tabindex:n.disabled?-1:n.tabindex,role:"menubar","aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,"aria-disabled":n.disabled||void 0,"aria-orientation":n.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,exact:n.exact,level:0,pt:e.pt,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","exact","pt","onFocus","onBlur","onKeydown","onItemClick","onItemMouseenter"]),e.$slots.end?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[r.renderSlot(e.$slots,"end")],16)):r.createCommentVNode("",!0)],16,x)},k}(primevue.utils,primevue.basecomponent,primevue.usestyle,primevue.icons.angledown,primevue.icons.angleright,primevue.ripple,Vue);
|
|
1
|
+
this.primevue=this.primevue||{},this.primevue.megamenu=function(e,t,n,i,s,o,r){"use strict";function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var c=a(t),m=a(i),l=a(s),u=a(o),d=n.useStyle("\n.p-megamenu {\n display: flex;\n}\n\n.p-megamenu-root-list {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-megamenu-root-list > .p-menuitem {\n position: relative;\n}\n\n.p-megamenu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-megamenu .p-menuitem-text {\n line-height: 1;\n}\n\n.p-megamenu-panel {\n display: none;\n position: absolute;\n width: auto;\n z-index: 1;\n}\n\n.p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n display: block;\n}\n\n.p-megamenu-submenu {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n/* Horizontal */\n.p-megamenu-horizontal {\n align-items: center;\n}\n\n.p-megamenu-horizontal .p-megamenu-root-list {\n display: flex;\n align-items: center;\n flex-wrap: wrap;\n}\n\n.p-megamenu-horizontal .p-megamenu-end {\n margin-left: auto;\n align-self: center;\n}\n\n/* Vertical */\n.p-megamenu-vertical {\n flex-direction: column;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list {\n flex-direction: column;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem-active > .p-megamenu-panel {\n left: 100%;\n top: 0;\n}\n\n.p-megamenu-vertical .p-megamenu-root-list > .p-menuitem > .p-menuitem-content > .p-menuitem-link > .p-submenu-icon {\n margin-left: auto;\n}\n\n.p-megamenu-grid {\n display: flex;\n}\n\n.p-megamenu-col-2,\n.p-megamenu-col-3,\n.p-megamenu-col-4,\n.p-megamenu-col-6,\n.p-megamenu-col-12 {\n flex: 0 0 auto;\n padding: 0.5rem;\n}\n\n.p-megamenu-col-2 {\n width: 16.6667%;\n}\n\n.p-megamenu-col-3 {\n width: 25%;\n}\n\n.p-megamenu-col-4 {\n width: 33.3333%;\n}\n\n.p-megamenu-col-6 {\n width: 50%;\n}\n\n.p-megamenu-col-12 {\n width: 100%;\n}\n",{name:"megamenu",manual:!0}),I={name:"BaseMegaMenu",extends:c.default,props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},exact:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-megamenu p-component",{"p-megamenu-horizontal":t.horizontal,"p-megamenu-vertical":t.vertical}]},start:"p-megamenu-start",menu:"p-megamenu-root-list",submenuHeader:function(e){return["p-megamenu-submenu-header p-submenu-header",{"p-disabled":e.instance.isItemDisabled(e.processedItem)}]},menuitem:function(e){var t=e.instance,n=e.processedItem;return["p-menuitem",{"p-menuitem-active p-highlight":t.isItemActive(n),"p-focus":t.isItemFocused(n),"p-disabled":t.isItemDisabled(n)}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text",submenuIcon:"p-submenu-icon",panel:"p-megamenu-panel",grid:"p-megamenu-grid",column:function(e){var t,n=e.processedItem;switch(e.instance.isItemGroup(n)?n.items.length:0){case 2:t="p-megamenu-col-6";break;case 3:t="p-megamenu-col-4";break;case 4:t="p-megamenu-col-3";break;case 6:t="p-megamenu-col-2";break;default:t="p-megamenu-col-12"}return t},submenu:"p-submenu-list p-megamenu-submenu",separator:"p-menuitem-separator",end:"p-megamenu-end"},inlineStyles:{submenu:function(e){return{display:e.instance.isItemActive(e.processedItem)?"block":"none"}}},loadStyle:d.load},provide:function(){return{$parentInstance:this}}},p={name:"MegaMenuSub",hostName:"MegaMenu",extends:c.default,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},exact:{type:Boolean,default:!0},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,n,i){return t&&t.item?e.ObjectUtils.getItemValue(t.item[n],i):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},getPTOptions:function(e,t,n){return this.ptm(n,{context:{item:e,index:t,active:this.isItemActive(e),focused:this.isItemFocused(e)}})},isItemActive:function(t){return!!e.ObjectUtils.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.ObjectUtils.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})},onItemActionClick:function(e,t){t&&t(e)},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}},components:{AngleRightIcon:l.default,AngleDownIcon:m.default},directives:{ripple:u.default}},f=["tabindex"],h=["id","aria-label","aria-disabled","aria-expanded","aria-haspopup","aria-level","aria-setsize","aria-posinset","data-p-highlight","data-p-focused","data-p-disabled"],g=["onClick","onMouseenter"],v=["href","onClick"],b=["href","target"],y=["id"];p.render=function(e,t,n,i,s,o){var a=r.resolveComponent("router-link"),c=r.resolveComponent("MegaMenuSub",!0),m=r.resolveDirective("ripple");return r.openBlock(),r.createElementBlock("ul",r.mergeProps({class:e.cx(0===n.level?"menu":"submenu"),tabindex:n.tabindex},e.ptm(0===n.level?"menu":"submenu")),[n.submenu?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:0,class:[e.cx("submenuHeader",{submenu:n.submenu}),o.getItemProp(n.submenu,"class")],style:o.getItemProp(n.submenu,"style"),role:"presentation"},e.ptm("submenuHeader")),r.toDisplayString(o.getItemLabel(n.submenu)),17)):r.createCommentVNode("",!0),(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(n.items,(function(i,s){return r.openBlock(),r.createElementBlock(r.Fragment,{key:o.getItemKey(i)},[o.isItemVisible(i)&&!o.getItemProp(i,"separator")?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:0,id:o.getItemId(i),style:o.getItemProp(i,"style"),class:[e.cx("menuitem",{processedItem:i}),o.getItemProp(i,"class")],role:"menuitem","aria-label":o.getItemLabel(i),"aria-disabled":o.isItemDisabled(i)||void 0,"aria-expanded":o.isItemGroup(i)?o.isItemActive(i):void 0,"aria-haspopup":o.isItemGroup(i)&&!o.getItemProp(i,"to")?"menu":void 0,"aria-level":n.level+1,"aria-setsize":o.getAriaSetSize(),"aria-posinset":o.getAriaPosInset(s)},o.getPTOptions(i,s,"menuitem"),{"data-p-highlight":o.isItemActive(i),"data-p-focused":o.isItemFocused(i),"data-p-disabled":o.isItemDisabled(i)}),[r.createElementVNode("div",r.mergeProps({class:e.cx("content"),onClick:function(e){return o.onItemClick(e,i)},onMouseenter:function(e){return o.onItemMouseEnter(e,i)}},o.getPTOptions(i,s,"content")),[n.templates.item?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.item),{key:1,item:i.item},null,8,["item"])):(r.openBlock(),r.createElementBlock(r.Fragment,{key:0},[o.getItemProp(i,"to")&&!o.isItemDisabled(i)?(r.openBlock(),r.createBlock(a,{key:0,to:o.getItemProp(i,"to"),custom:""},{default:r.withCtx((function(t){var a=t.navigate,c=t.href,l=t.isActive,u=t.isExactActive;return[r.withDirectives((r.openBlock(),r.createElementBlock("a",r.mergeProps({href:c,class:e.cx("action",{isActive:l,isExactActive:u}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return o.onItemActionClick(e,a)}},o.getPTOptions(i,s,"action")),[n.templates.itemicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.itemicon),{key:0,item:i.item,class:r.normalizeClass([e.cx("icon"),o.getItemProp(i,"icon")])},null,8,["item","class"])):o.getItemProp(i,"icon")?(r.openBlock(),r.createElementBlock("span",r.mergeProps({key:1,class:[e.cx("icon"),o.getItemProp(i,"icon")]},o.getPTOptions(i,s,"icon")),null,16)):r.createCommentVNode("",!0),r.createElementVNode("span",r.mergeProps({class:e.cx("text")},o.getPTOptions(i,s,"label")),r.toDisplayString(o.getItemLabel(i)),17)],16,v)),[[m]])]})),_:2},1032,["to"])):r.withDirectives((r.openBlock(),r.createElementBlock("a",r.mergeProps({key:1,href:o.getItemProp(i,"url"),class:e.cx("action"),target:o.getItemProp(i,"target"),tabindex:"-1","aria-hidden":"true"},o.getPTOptions(i,s,"action")),[n.templates.itemicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.itemicon),{key:0,item:i.item,class:r.normalizeClass([e.cx("icon"),o.getItemProp(i,"icon")])},null,8,["item","class"])):o.getItemProp(i,"icon")?(r.openBlock(),r.createElementBlock("span",r.mergeProps({key:1,class:[e.cx("icon"),o.getItemProp(i,"icon")]},o.getPTOptions(i,s,"icon")),null,16)):r.createCommentVNode("",!0),r.createElementVNode("span",r.mergeProps({class:e.cx("text")},o.getPTOptions(i,s,"label")),r.toDisplayString(o.getItemLabel(i)),17),o.isItemGroup(i)?(r.openBlock(),r.createElementBlock(r.Fragment,{key:2},[n.templates.submenuicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.templates.submenuicon),r.mergeProps({key:0,active:o.isItemActive(i),class:e.cx("submenuIcon")},o.getPTOptions(i,s,"submenuIcon")),null,16,["active","class"])):(r.openBlock(),r.createBlock(r.resolveDynamicComponent(n.horizontal?"AngleDownIcon":"AngleRightIcon"),r.mergeProps({key:1,class:e.cx("submenuIcon")},o.getPTOptions(i,s,"submenuIcon")),null,16,["class"]))],64)):r.createCommentVNode("",!0)],16,b)),[[m]])],64))],16,g),o.isItemVisible(i)&&o.isItemGroup(i)?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:0,class:e.cx("panel")},e.ptm("panel")),[r.createElementVNode("div",r.mergeProps({class:e.cx("grid")},e.ptm("grid")),[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(i.items,(function(s){return r.openBlock(),r.createElementBlock("div",r.mergeProps({key:o.getItemKey(s),class:e.cx("column",{processedItem:i})},e.ptm("column")),[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(s,(function(s){return r.openBlock(),r.createBlock(c,{key:o.getSubListKey(s),id:o.getSubListId(s),style:r.normalizeStyle(e.sx("submenu",!0,{processedItem:i})),role:"menu",menuId:n.menuId,focusedItemId:n.focusedItemId,submenu:s,items:s.items,templates:n.templates,exact:n.exact,level:n.level+1,pt:e.pt,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","exact","level","pt"])})),128))],16)})),128))],16)],16)):r.createCommentVNode("",!0)],16,h)):r.createCommentVNode("",!0),o.isItemVisible(i)&&o.getItemProp(i,"separator")?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:1,id:o.getItemId(i),class:[e.cx("separator"),o.getItemProp(i,"class")],style:o.getItemProp(i,"style"),role:"separator"},e.ptm("separator")),null,16,y)):r.createCommentVNode("",!0)],64)})),128))],16,f)};var k={name:"MegaMenu",extends:I,emits:["focus","blur"],props:{model:{type:Array,default:null},orientation:{type:String,default:"horizontal"},exact:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1},tabindex:{type:Number,default:0},"aria-labelledby":{type:String,default:null},"aria-label":{type:String,default:null}},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(t){this.id=t||e.UniqueComponentId()},activeItem:function(t){e.ObjectUtils.isNotEmpty(t)?(this.bindOutsideClickListener(),this.bindResizeListener()):(this.unbindOutsideClickListener(),this.unbindResizeListener())}},mounted:function(){this.id=this.id||e.UniqueComponentId()},beforeUnmount:function(){this.unbindOutsideClickListener(),this.unbindResizeListener()},methods:{getItemProp:function(t,n){return t?e.ObjectUtils.getItemValue(t[n]):void 0},getItemLabel:function(e){return this.getItemProp(e,"label")},isItemDisabled:function(e){return this.getItemProp(e,"disabled")},isItemGroup:function(t){return e.ObjectUtils.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.ObjectUtils.isNotEmpty(t.items)},hide:function(t,n){this.activeItem=null,this.focusedItemInfo={index:-1,key:"",parentKey:""},n&&e.DomHandler.focus(this.menubar),this.dirty=!1},onFocus:function(e){if(this.focused=!0,-1===this.focusedItemInfo.index){var t=this.findFirstFocusedItemIndex(),n=this.findVisibleItem(t);this.focusedItemInfo={index:t,key:n.key,parentKey:n.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 n=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:!n&&e.ObjectUtils.isPrintableCharacter(t.key)&&this.searchItems(t,t.key)}}},onItemChange:function(t){var n=t.processedItem,i=t.isFocus;if(!e.ObjectUtils.isEmpty(n)){var s=n.index,o=n.key,r=n.parentKey,a=e.ObjectUtils.isNotEmpty(n.items);a&&(this.activeItem=n),this.focusedItemInfo={index:s,key:o,parentKey:r},a&&(this.dirty=!0),i&&e.DomHandler.focus(this.menubar)}},onItemClick:function(t){var n=t.originalEvent,i=t.processedItem,s=this.isProccessedItemGroup(i),o=e.ObjectUtils.isEmpty(i.parent);if(this.isSelected(i)){var r=i.index,a=i.key,c=i.parentKey;this.activeItem=null,this.focusedItemInfo={index:r,key:a,parentKey:c},this.dirty=!o,e.DomHandler.focus(this.menubar)}else if(s)this.onItemChange(t);else{var m=o?i:this.activeItem;this.hide(n),this.changeFocusedItemInfo(n,m?m.index:-1),e.DomHandler.focus(this.menubar)}},onItemMouseEnter:function(e){this.dirty&&this.onItemChange(e)},onArrowDownKey:function(t){if(this.horizontal)if(e.ObjectUtils.isNotEmpty(this.activeItem)&&this.activeItem.key===this.focusedItemInfo.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 i=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,i),t.preventDefault()},onArrowUpKey:function(t){if(t.altKey&&this.horizontal){if(-1!==this.focusedItemInfo.index){var n=this.findVisibleItem(this.focusedItemInfo.index);!this.isProccessedItemGroup(n)&&e.ObjectUtils.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 i=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,i),t.preventDefault()}},onArrowLeftKey:function(t){var n=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(n)){if(this.horizontal){var i=-1!==this.focusedItemInfo.index?this.findPrevItemIndex(this.focusedItemInfo.index):this.findLastFocusedItemIndex();this.changeFocusedItemInfo(t,i)}}else{this.vertical&&e.ObjectUtils.isNotEmpty(this.activeItem)&&0===n.columnIndex&&(this.focusedItemInfo={index:this.activeItem.index,key:this.activeItem.key,parentKey:this.activeItem.parentKey},this.activeItem=null);var s=n.columnIndex-1,o=this.visibleItems.findIndex((function(e){return e.columnIndex===s}));-1!==o&&this.changeFocusedItemInfo(t,o)}t.preventDefault()},onArrowRightKey:function(t){var n=this.findVisibleItem(this.focusedItemInfo.index);if(this.isProccessedItemGroup(n)){if(this.vertical)if(e.ObjectUtils.isNotEmpty(this.activeItem)&&this.activeItem.key===n.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 s=-1!==this.focusedItemInfo.index?this.findNextItemIndex(this.focusedItemInfo.index):this.findFirstFocusedItemIndex();this.changeFocusedItemInfo(t,s)}else{var o=n.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(t){if(-1!==this.focusedItemInfo.index){var n=e.DomHandler.findSingle(this.menubar,'li[id="'.concat("".concat(this.focusedItemId),'"]')),i=n&&e.DomHandler.findSingle(n,'a[data-pc-section="action"]');i?i.click():n&&n.click(),!this.isProccessedItemGroup(this.visibleItems[this.focusedItemInfo.index])&&this.changeFocusedItemInfo(t,this.findFirstFocusedItemIndex())}t.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},onEscapeKey:function(t){e.ObjectUtils.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 n=e.container&&!e.container.contains(t.target),i=!e.popup||!(e.target&&(e.target===t.target||e.target.contains(t.target)));n&&i&&e.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindResizeListener:function(){var t=this;this.resizeListener||(this.resizeListener=function(n){e.DomHandler.isTouchDevice()||t.hide(n,!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.ObjectUtils.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.ObjectUtils.findLastIndex(this.visibleItems,(function(e){return t.isValidItem(e)}))},findNextItemIndex:function(e){var t=this,n=e<this.visibleItems.length-1?this.visibleItems.slice(e+1).findIndex((function(e){return t.isValidItem(e)})):-1;return n>-1?n+e+1:e},findPrevItemIndex:function(t){var n=this,i=t>0?e.ObjectUtils.findLastIndex(this.visibleItems.slice(0,t),(function(e){return n.isValidItem(e)})):-1;return i>-1?i: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.ObjectUtils.isNotEmpty(this.visibleItems)?this.visibleItems[t]:null},searchItems:function(e,t){var n=this;this.searchValue=(this.searchValue||"")+t;var i=-1,s=!1;return-1!==(i=-1!==this.focusedItemInfo.index?-1===(i=this.visibleItems.slice(this.focusedItemInfo.index).findIndex((function(e){return n.isItemMatched(e)})))?this.visibleItems.slice(0,this.focusedItemInfo.index).findIndex((function(e){return n.isItemMatched(e)})):i+this.focusedItemInfo.index:this.visibleItems.findIndex((function(e){return n.isItemMatched(e)})))&&(s=!0),-1===i&&-1===this.focusedItemInfo.index&&(i=this.findFirstFocusedItemIndex()),-1!==i&&this.changeFocusedItemInfo(e,i),this.searchTimeout&&clearTimeout(this.searchTimeout),this.searchTimeout=setTimeout((function(){n.searchValue="",n.searchTimeout=null}),500),s},changeFocusedItemInfo:function(t,n){var i=this.findVisibleItem(n);this.focusedItemInfo.index=n,this.focusedItemInfo.key=e.ObjectUtils.isNotEmpty(i)?i.key:"",this.scrollInView()},scrollInView:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:-1,n=-1!==t?"".concat(this.id,"_").concat(t):this.focusedItemId,i=e.DomHandler.findSingle(this.menubar,'li[id="'.concat(n,'"]'));i&&i.scrollIntoView&&i.scrollIntoView({block:"nearest",inline:"start"})},createProcessedItems:function(e){var t=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=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,m={item:e,index:a,level:n,key:c,parent:i,parentKey:s,columnIndex:void 0!==o?o:void 0!==i.columnIndex?i.columnIndex:a};m.items=0===n&&e.items&&e.items.length>0?e.items.map((function(e,i){return t.createProcessedItems(e,n+1,m,c,i)})):t.createProcessedItems(e.items,n+1,m,c),r.push(m)})),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.ObjectUtils.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.ObjectUtils.isNotEmpty(this.focusedItemInfo.key)?"".concat(this.id,"_").concat(this.focusedItemInfo.key):null}},components:{MegaMenuSub:p}},x=["id"];return k.render=function(e,t,n,i,s,o){var a=r.resolveComponent("MegaMenuSub");return r.openBlock(),r.createElementBlock("div",r.mergeProps({ref:o.containerRef,id:s.id,class:e.cx("root")},e.ptm("root"),{"data-pc-name":"megamenu"}),[e.$slots.start?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[r.renderSlot(e.$slots,"start")],16)):r.createCommentVNode("",!0),r.createVNode(a,{ref:o.menubarRef,id:s.id+"_list",tabindex:n.disabled?-1:n.tabindex,role:"menubar","aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,"aria-disabled":n.disabled||void 0,"aria-orientation":n.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,exact:n.exact,level:0,pt:e.pt,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","exact","pt","onFocus","onBlur","onKeydown","onItemClick","onItemMouseenter"]),e.$slots.end?(r.openBlock(),r.createElementBlock("div",r.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[r.renderSlot(e.$slots,"end")],16)):r.createCommentVNode("",!0)],16,x)},k}(primevue.utils,primevue.basecomponent,primevue.usestyle,primevue.icons.angledown,primevue.icons.angleright,primevue.ripple,Vue);
|
package/menu/Menu.d.ts
CHANGED
|
@@ -119,6 +119,14 @@ export interface MenuState {
|
|
|
119
119
|
* Defines current options in Menu component.
|
|
120
120
|
*/
|
|
121
121
|
export interface MenuContext {
|
|
122
|
+
/**
|
|
123
|
+
* Current menuitem
|
|
124
|
+
*/
|
|
125
|
+
item: any;
|
|
126
|
+
/**
|
|
127
|
+
* Current index of the menuitem.
|
|
128
|
+
*/
|
|
129
|
+
index: number;
|
|
122
130
|
/**
|
|
123
131
|
* Current focused state of menuitem as a boolean.
|
|
124
132
|
* @defaultValue false
|
package/menu/Menu.vue
CHANGED
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
</template>
|
|
31
31
|
</template>
|
|
32
32
|
<li v-else-if="visible(item) && item.separator" :key="'separator' + i.toString()" :class="[cx('separator'), item.class]" :style="item.style" role="separator" v-bind="ptm('separator')"></li>
|
|
33
|
-
<PVMenuitem v-else :key="label(item) + i.toString()" :id="id + '_' + i" :item="item" :templates="$slots" :exact="exact" :focusedOptionId="focusedOptionId" @item-click="itemClick" :pt="pt" />
|
|
33
|
+
<PVMenuitem v-else :key="label(item) + i.toString()" :id="id + '_' + i" :item="item" :index="i" :templates="$slots" :exact="exact" :focusedOptionId="focusedOptionId" @item-click="itemClick" :pt="pt" />
|
|
34
34
|
</template>
|
|
35
35
|
</ul>
|
|
36
36
|
<div v-if="$slots.end" :class="cx('end')" v-bind="ptm('end')">
|
package/menu/Menuitem.vue
CHANGED
|
@@ -47,7 +47,8 @@ export default {
|
|
|
47
47
|
templates: null,
|
|
48
48
|
exact: null,
|
|
49
49
|
id: null,
|
|
50
|
-
focusedOptionId: null
|
|
50
|
+
focusedOptionId: null,
|
|
51
|
+
index: null
|
|
51
52
|
},
|
|
52
53
|
methods: {
|
|
53
54
|
getItemProp(processedItem, name) {
|
|
@@ -56,6 +57,8 @@ export default {
|
|
|
56
57
|
getPTOptions(key) {
|
|
57
58
|
return this.ptm(key, {
|
|
58
59
|
context: {
|
|
60
|
+
item: this.item,
|
|
61
|
+
index: this.index,
|
|
59
62
|
focused: this.isItemFocused()
|
|
60
63
|
}
|
|
61
64
|
});
|
package/menu/menu.cjs.js
CHANGED
|
@@ -119,7 +119,8 @@ var script$1 = {
|
|
|
119
119
|
templates: null,
|
|
120
120
|
exact: null,
|
|
121
121
|
id: null,
|
|
122
|
-
focusedOptionId: null
|
|
122
|
+
focusedOptionId: null,
|
|
123
|
+
index: null
|
|
123
124
|
},
|
|
124
125
|
methods: {
|
|
125
126
|
getItemProp: function getItemProp(processedItem, name) {
|
|
@@ -128,6 +129,8 @@ var script$1 = {
|
|
|
128
129
|
getPTOptions: function getPTOptions(key) {
|
|
129
130
|
return this.ptm(key, {
|
|
130
131
|
context: {
|
|
132
|
+
item: this.item,
|
|
133
|
+
index: this.index,
|
|
131
134
|
focused: this.isItemFocused()
|
|
132
135
|
}
|
|
133
136
|
});
|
|
@@ -640,12 +643,13 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
640
643
|
key: $options.label(item) + i.toString(),
|
|
641
644
|
id: $data.id + '_' + i,
|
|
642
645
|
item: item,
|
|
646
|
+
index: i,
|
|
643
647
|
templates: _ctx.$slots,
|
|
644
648
|
exact: _ctx.exact,
|
|
645
649
|
focusedOptionId: $options.focusedOptionId,
|
|
646
650
|
onItemClick: $options.itemClick,
|
|
647
651
|
pt: _ctx.pt
|
|
648
|
-
}, null, 8, ["id", "item", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
652
|
+
}, null, 8, ["id", "item", "index", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
649
653
|
}), 128))], 16, _hoisted_2), _ctx.$slots.end ? (vue.openBlock(), vue.createElementBlock("div", vue.mergeProps({
|
|
650
654
|
key: 1,
|
|
651
655
|
"class": _ctx.cx('end')
|
package/menu/menu.cjs.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var e=require("primevue/overlayeventbus"),t=require("primevue/portal"),n=require("primevue/utils"),i=require("primevue/basecomponent"),o=require("primevue/usestyle"),r=require("primevue/ripple"),s=require("vue");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=l(e),c=l(t),u=l(i),d=l(r),p=o.useStyle("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),m={name:"BaseMenu",extends:u.default,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:p.load},provide:function(){return{$parentInstance:this}}},f={name:"Menuitem",hostName:"Menu",extends:u.default,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null},methods:{getItemProp:function(e,t){return e&&e.item?n.ObjectUtils.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:d.default}},h=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],b=["href","onClick"],y=["href","target"];function v(e){return O(e)||x(e)||g(e)||k()}function k(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function g(e,t){if(e){if("string"==typeof e)return I(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}function x(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function O(e){if(Array.isArray(e))return I(e)}function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,i=new Array(t);n<t;n++)i[n]=e[n];return i}f.render=function(e,t,n,i,o,r){var l=s.resolveComponent("router-link"),a=s.resolveDirective("ripple");return r.visible()?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:n.id,class:[e.cx("menuitem"),n.item.class],role:"menuitem",style:n.item.style,"aria-label":r.label(),"aria-disabled":r.disabled()},r.getPTOptions("menuitem"),{"data-p-focused":r.isItemFocused(),"data-p-disabled":r.disabled()||!1}),[s.createElementVNode("div",s.mergeProps({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return r.onItemClick(e)})},r.getPTOptions("content")),[n.templates.item?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.item),{key:1,item:n.item},null,8,["item"])):(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[n.item.to&&!r.disabled()?(s.openBlock(),s.createBlock(l,{key:0,to:n.item.to,custom:""},{default:s.withCtx((function(t){var i=t.navigate,o=t.href,l=t.isActive,c=t.isExactActive;return[s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({href:o,class:e.cx("action",{isActive:l,isExactActive:c}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return r.onItemActionClick(e,i)}},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,b)),[[a]])]})),_:1},8,["to"])):s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({key:1,href:n.item.url,class:e.cx("action"),target:n.item.target,tabindex:"-1","aria-hidden":"true"},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,y)),[[a]])],64))],16)],16,h)):s.createCommentVNode("",!0)};var L={name:"Menu",extends:m,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n.UniqueComponentId()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n.UniqueComponentId(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&n.ZIndexUtils.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(n.DomHandler.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)n.DomHandler.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=n.DomHandler.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&n.DomHandler.findSingle(t,'a[data-pc-section="action"]');this.popup&&n.DomHandler.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){n.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&n.ZIndexUtils.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(n.DomHandler.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&n.ZIndexUtils.clear(e)},alignOverlay:function(){n.DomHandler.absolutePosition(this.container,this.target),this.container.style.minWidth=n.DomHandler.getOuterWidth(this.target)+"px"},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var n=e.container&&!e.container.contains(t.target),i=!(e.target&&(e.target===t.target||e.target.contains(t.target)));e.overlayVisible&&n&&i?e.hide():!e.popup&&n&&i&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new n.ConnectedOverlayScrollHandler(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!n.DomHandler.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(e){a.default.emit("overlay-click",{originalEvent:e,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:f,Portal:c.default}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function C(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function E(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?C(Object(n),!0).forEach((function(t){P(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):C(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function P(e,t,n){return(t=S(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function S(e){var t=w(e,"string");return"symbol"===B(t)?t:String(t)}function w(e,t){if("object"!==B(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var i=n.call(e,t||"default");if("object"!==B(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var D=["id"],H=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],A=["id"];L.render=function(e,t,n,i,o,r){var l=s.resolveComponent("PVMenuitem"),a=s.resolveComponent("Portal");return s.openBlock(),s.createBlock(a,{appendTo:e.appendTo,disabled:!e.popup},{default:s.withCtx((function(){return[s.createVNode(s.Transition,{name:"p-connected-overlay",onEnter:r.onEnter,onLeave:r.onLeave,onAfterLeave:r.onAfterLeave},{default:s.withCtx((function(){return[!e.popup||o.overlayVisible?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,ref:r.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return r.onOverlayClick&&r.onOverlayClick.apply(r,arguments)})},E(E({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[s.renderSlot(e.$slots,"start")],16)):s.createCommentVNode("",!0),s.createElementVNode("ul",s.mergeProps({ref:r.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?r.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return r.onListFocus&&r.onListFocus.apply(r,arguments)}),onBlur:t[1]||(t[1]=function(){return r.onListBlur&&r.onListBlur.apply(r,arguments)}),onKeydown:t[2]||(t[2]=function(){return r.onListKeyDown&&r.onListKeyDown.apply(r,arguments)})},e.ptm("menu")),[(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(e.model,(function(t,n){return s.openBlock(),s.createElementBlock(s.Fragment,{key:r.label(t)+n.toString()},[t.items&&r.visible(t)&&!t.separator?(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[t.items?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:o.id+"_"+n,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[s.renderSlot(e.$slots,"item",{item:t},(function(){return[s.createTextVNode(s.toDisplayString(r.label(t)),1)]}))],16,A)):s.createCommentVNode("",!0),(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(t.items,(function(i,a){return s.openBlock(),s.createElementBlock(s.Fragment,{key:i.label+n+"_"+a},[r.visible(i)&&!i.separator?(s.openBlock(),s.createBlock(l,{key:0,id:o.id+"_"+n+"_"+a,item:i,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):r.visible(i)&&i.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n+a,class:[e.cx("separator"),t.class],style:i.style,role:"separator"},e.ptm("separator")),null,16)):s.createCommentVNode("",!0)],64)})),128))],64)):r.visible(t)&&t.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(s.openBlock(),s.createBlock(l,{key:r.label(t)+n.toString(),id:o.id+"_"+n,item:t,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,H),e.$slots.end?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[s.renderSlot(e.$slots,"end")],16)):s.createCommentVNode("",!0)],16,D)):s.createCommentVNode("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])},module.exports=L;
|
|
1
|
+
"use strict";var e=require("primevue/overlayeventbus"),t=require("primevue/portal"),n=require("primevue/utils"),i=require("primevue/basecomponent"),o=require("primevue/usestyle"),r=require("primevue/ripple"),s=require("vue");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=l(e),c=l(t),u=l(i),d=l(r),p=o.useStyle("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),m={name:"BaseMenu",extends:u.default,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:p.load},provide:function(){return{$parentInstance:this}}},f={name:"Menuitem",hostName:"Menu",extends:u.default,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null,index:null},methods:{getItemProp:function(e,t){return e&&e.item?n.ObjectUtils.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{item:this.item,index:this.index,focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:d.default}},h=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],b=["href","onClick"],y=["href","target"];function v(e){return O(e)||x(e)||g(e)||k()}function k(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function g(e,t){if(e){if("string"==typeof e)return I(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}function x(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function O(e){if(Array.isArray(e))return I(e)}function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,i=new Array(t);n<t;n++)i[n]=e[n];return i}f.render=function(e,t,n,i,o,r){var l=s.resolveComponent("router-link"),a=s.resolveDirective("ripple");return r.visible()?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:n.id,class:[e.cx("menuitem"),n.item.class],role:"menuitem",style:n.item.style,"aria-label":r.label(),"aria-disabled":r.disabled()},r.getPTOptions("menuitem"),{"data-p-focused":r.isItemFocused(),"data-p-disabled":r.disabled()||!1}),[s.createElementVNode("div",s.mergeProps({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return r.onItemClick(e)})},r.getPTOptions("content")),[n.templates.item?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.item),{key:1,item:n.item},null,8,["item"])):(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[n.item.to&&!r.disabled()?(s.openBlock(),s.createBlock(l,{key:0,to:n.item.to,custom:""},{default:s.withCtx((function(t){var i=t.navigate,o=t.href,l=t.isActive,c=t.isExactActive;return[s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({href:o,class:e.cx("action",{isActive:l,isExactActive:c}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return r.onItemActionClick(e,i)}},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,b)),[[a]])]})),_:1},8,["to"])):s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({key:1,href:n.item.url,class:e.cx("action"),target:n.item.target,tabindex:"-1","aria-hidden":"true"},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,y)),[[a]])],64))],16)],16,h)):s.createCommentVNode("",!0)};var L={name:"Menu",extends:m,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n.UniqueComponentId()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n.UniqueComponentId(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&n.ZIndexUtils.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(n.DomHandler.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)n.DomHandler.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=n.DomHandler.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&n.DomHandler.findSingle(t,'a[data-pc-section="action"]');this.popup&&n.DomHandler.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){n.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&n.ZIndexUtils.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(n.DomHandler.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&n.ZIndexUtils.clear(e)},alignOverlay:function(){n.DomHandler.absolutePosition(this.container,this.target),this.container.style.minWidth=n.DomHandler.getOuterWidth(this.target)+"px"},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var n=e.container&&!e.container.contains(t.target),i=!(e.target&&(e.target===t.target||e.target.contains(t.target)));e.overlayVisible&&n&&i?e.hide():!e.popup&&n&&i&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new n.ConnectedOverlayScrollHandler(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!n.DomHandler.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(e){a.default.emit("overlay-click",{originalEvent:e,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:f,Portal:c.default}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function C(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function E(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?C(Object(n),!0).forEach((function(t){P(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):C(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function P(e,t,n){return(t=S(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function S(e){var t=w(e,"string");return"symbol"===B(t)?t:String(t)}function w(e,t){if("object"!==B(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var i=n.call(e,t||"default");if("object"!==B(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var D=["id"],H=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],A=["id"];L.render=function(e,t,n,i,o,r){var l=s.resolveComponent("PVMenuitem"),a=s.resolveComponent("Portal");return s.openBlock(),s.createBlock(a,{appendTo:e.appendTo,disabled:!e.popup},{default:s.withCtx((function(){return[s.createVNode(s.Transition,{name:"p-connected-overlay",onEnter:r.onEnter,onLeave:r.onLeave,onAfterLeave:r.onAfterLeave},{default:s.withCtx((function(){return[!e.popup||o.overlayVisible?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,ref:r.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return r.onOverlayClick&&r.onOverlayClick.apply(r,arguments)})},E(E({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[s.renderSlot(e.$slots,"start")],16)):s.createCommentVNode("",!0),s.createElementVNode("ul",s.mergeProps({ref:r.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?r.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return r.onListFocus&&r.onListFocus.apply(r,arguments)}),onBlur:t[1]||(t[1]=function(){return r.onListBlur&&r.onListBlur.apply(r,arguments)}),onKeydown:t[2]||(t[2]=function(){return r.onListKeyDown&&r.onListKeyDown.apply(r,arguments)})},e.ptm("menu")),[(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(e.model,(function(t,n){return s.openBlock(),s.createElementBlock(s.Fragment,{key:r.label(t)+n.toString()},[t.items&&r.visible(t)&&!t.separator?(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[t.items?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:o.id+"_"+n,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[s.renderSlot(e.$slots,"item",{item:t},(function(){return[s.createTextVNode(s.toDisplayString(r.label(t)),1)]}))],16,A)):s.createCommentVNode("",!0),(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(t.items,(function(i,a){return s.openBlock(),s.createElementBlock(s.Fragment,{key:i.label+n+"_"+a},[r.visible(i)&&!i.separator?(s.openBlock(),s.createBlock(l,{key:0,id:o.id+"_"+n+"_"+a,item:i,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):r.visible(i)&&i.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n+a,class:[e.cx("separator"),t.class],style:i.style,role:"separator"},e.ptm("separator")),null,16)):s.createCommentVNode("",!0)],64)})),128))],64)):r.visible(t)&&t.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(s.openBlock(),s.createBlock(l,{key:r.label(t)+n.toString(),id:o.id+"_"+n,item:t,index:n,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","index","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,H),e.$slots.end?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[s.renderSlot(e.$slots,"end")],16)):s.createCommentVNode("",!0)],16,D)):s.createCommentVNode("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])},module.exports=L;
|
package/menu/menu.esm.js
CHANGED
|
@@ -110,7 +110,8 @@ var script$1 = {
|
|
|
110
110
|
templates: null,
|
|
111
111
|
exact: null,
|
|
112
112
|
id: null,
|
|
113
|
-
focusedOptionId: null
|
|
113
|
+
focusedOptionId: null,
|
|
114
|
+
index: null
|
|
114
115
|
},
|
|
115
116
|
methods: {
|
|
116
117
|
getItemProp: function getItemProp(processedItem, name) {
|
|
@@ -119,6 +120,8 @@ var script$1 = {
|
|
|
119
120
|
getPTOptions: function getPTOptions(key) {
|
|
120
121
|
return this.ptm(key, {
|
|
121
122
|
context: {
|
|
123
|
+
item: this.item,
|
|
124
|
+
index: this.index,
|
|
122
125
|
focused: this.isItemFocused()
|
|
123
126
|
}
|
|
124
127
|
});
|
|
@@ -631,12 +634,13 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
631
634
|
key: $options.label(item) + i.toString(),
|
|
632
635
|
id: $data.id + '_' + i,
|
|
633
636
|
item: item,
|
|
637
|
+
index: i,
|
|
634
638
|
templates: _ctx.$slots,
|
|
635
639
|
exact: _ctx.exact,
|
|
636
640
|
focusedOptionId: $options.focusedOptionId,
|
|
637
641
|
onItemClick: $options.itemClick,
|
|
638
642
|
pt: _ctx.pt
|
|
639
|
-
}, null, 8, ["id", "item", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
643
|
+
}, null, 8, ["id", "item", "index", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
640
644
|
}), 128))], 16, _hoisted_2), _ctx.$slots.end ? (openBlock(), createElementBlock("div", mergeProps({
|
|
641
645
|
key: 1,
|
|
642
646
|
"class": _ctx.cx('end')
|
package/menu/menu.esm.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import e from"primevue/overlayeventbus";import t from"primevue/portal";import{ObjectUtils as i,UniqueComponentId as n,ZIndexUtils as o,DomHandler as s,ConnectedOverlayScrollHandler as r}from"primevue/utils";import a from"primevue/basecomponent";import{useStyle as l}from"primevue/usestyle";import c from"primevue/ripple";import{resolveComponent as u,resolveDirective as d,openBlock as p,createElementBlock as m,mergeProps as f,createElementVNode as h,Fragment as b,createBlock as y,withCtx as v,withDirectives as g,resolveDynamicComponent as x,normalizeClass as O,createCommentVNode as k,toDisplayString as I,createVNode as L,Transition as w,renderSlot as S,renderList as C,createTextVNode as A}from"vue";var P=l("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),E={name:"BaseMenu",extends:a,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:P.load},provide:function(){return{$parentInstance:this}}},$={name:"Menuitem",hostName:"Menu",extends:a,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null},methods:{getItemProp:function(e,t){return e&&e.item?i.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:c}},K=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],T=["href","onClick"],j=["href","target"];function D(e){return V(e)||H(e)||F(e)||z()}function z(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function F(e,t){if(e){if("string"==typeof e)return R(e,t);var i=Object.prototype.toString.call(e).slice(8,-1);return"Object"===i&&e.constructor&&(i=e.constructor.name),"Map"===i||"Set"===i?Array.from(e):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?R(e,t):void 0}}function H(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function V(e){if(Array.isArray(e))return R(e)}function R(e,t){(null==t||t>e.length)&&(t=e.length);for(var i=0,n=new Array(t);i<t;i++)n[i]=e[i];return n}$.render=function(e,t,i,n,o,s){var r=u("router-link"),a=d("ripple");return s.visible()?(p(),m("li",f({key:0,id:i.id,class:[e.cx("menuitem"),i.item.class],role:"menuitem",style:i.item.style,"aria-label":s.label(),"aria-disabled":s.disabled()},s.getPTOptions("menuitem"),{"data-p-focused":s.isItemFocused(),"data-p-disabled":s.disabled()||!1}),[h("div",f({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return s.onItemClick(e)})},s.getPTOptions("content")),[i.templates.item?(p(),y(x(i.templates.item),{key:1,item:i.item},null,8,["item"])):(p(),m(b,{key:0},[i.item.to&&!s.disabled()?(p(),y(r,{key:0,to:i.item.to,custom:""},{default:v((function(t){var n=t.navigate,o=t.href,r=t.isActive,l=t.isExactActive;return[g((p(),m("a",f({href:o,class:e.cx("action",{isActive:r,isExactActive:l}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return s.onItemActionClick(e,n)}},s.getPTOptions("action")),[i.templates.itemicon?(p(),y(x(i.templates.itemicon),{key:0,item:i.item,class:O([e.cx("icon"),i.item.icon])},null,8,["item","class"])):i.item.icon?(p(),m("span",f({key:1,class:[e.cx("icon"),i.item.icon]},s.getPTOptions("icon")),null,16)):k("",!0),h("span",f({class:e.cx("label")},s.getPTOptions("label")),I(s.label()),17)],16,T)),[[a]])]})),_:1},8,["to"])):g((p(),m("a",f({key:1,href:i.item.url,class:e.cx("action"),target:i.item.target,tabindex:"-1","aria-hidden":"true"},s.getPTOptions("action")),[i.templates.itemicon?(p(),y(x(i.templates.itemicon),{key:0,item:i.item,class:O([e.cx("icon"),i.item.icon])},null,8,["item","class"])):i.item.icon?(p(),m("span",f({key:1,class:[e.cx("icon"),i.item.icon]},s.getPTOptions("icon")),null,16)):k("",!0),h("span",f({class:e.cx("label")},s.getPTOptions("label")),I(s.label()),17)],16,j)),[[a]])],64))],16)],16,K)):k("",!0)};var _={name:"Menu",extends:E,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&o.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(s.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)s.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=s.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&s.findSingle(t,'a[data-pc-section="action"]');this.popup&&s.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=D(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=D(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){s.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&o.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(s.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&o.clear(e)},alignOverlay:function(){s.absolutePosition(this.container,this.target),this.container.style.minWidth=s.getOuterWidth(this.target)+"px"},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)));e.overlayVisible&&i&&n?e.hide():!e.popup&&i&&n&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new r(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!s.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(t){e.emit("overlay-click",{originalEvent:t,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:$,Portal:t}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function M(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function N(e){for(var t=1;t<arguments.length;t++){var i=null!=arguments[t]?arguments[t]:{};t%2?M(Object(i),!0).forEach((function(t){Z(e,t,i[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(i)):M(Object(i)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(i,t))}))}return e}function Z(e,t,i){return(t=U(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function U(e){var t=W(e,"string");return"symbol"===B(t)?t:String(t)}function W(e,t){if("object"!==B(e)||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var n=i.call(e,t||"default");if("object"!==B(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var q=["id"],G=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],J=["id"];_.render=function(e,t,i,n,o,s){var r=u("PVMenuitem"),a=u("Portal");return p(),y(a,{appendTo:e.appendTo,disabled:!e.popup},{default:v((function(){return[L(w,{name:"p-connected-overlay",onEnter:s.onEnter,onLeave:s.onLeave,onAfterLeave:s.onAfterLeave},{default:v((function(){return[!e.popup||o.overlayVisible?(p(),m("div",f({key:0,ref:s.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return s.onOverlayClick&&s.onOverlayClick.apply(s,arguments)})},N(N({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(p(),m("div",f({key:0,class:e.cx("start")},e.ptm("start")),[S(e.$slots,"start")],16)):k("",!0),h("ul",f({ref:s.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?s.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return s.onListFocus&&s.onListFocus.apply(s,arguments)}),onBlur:t[1]||(t[1]=function(){return s.onListBlur&&s.onListBlur.apply(s,arguments)}),onKeydown:t[2]||(t[2]=function(){return s.onListKeyDown&&s.onListKeyDown.apply(s,arguments)})},e.ptm("menu")),[(p(!0),m(b,null,C(e.model,(function(t,i){return p(),m(b,{key:s.label(t)+i.toString()},[t.items&&s.visible(t)&&!t.separator?(p(),m(b,{key:0},[t.items?(p(),m("li",f({key:0,id:o.id+"_"+i,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[S(e.$slots,"item",{item:t},(function(){return[A(I(s.label(t)),1)]}))],16,J)):k("",!0),(p(!0),m(b,null,C(t.items,(function(n,a){return p(),m(b,{key:n.label+i+"_"+a},[s.visible(n)&&!n.separator?(p(),y(r,{key:0,id:o.id+"_"+i+"_"+a,item:n,templates:e.$slots,exact:e.exact,focusedOptionId:s.focusedOptionId,onItemClick:s.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):s.visible(n)&&n.separator?(p(),m("li",f({key:"separator"+i+a,class:[e.cx("separator"),t.class],style:n.style,role:"separator"},e.ptm("separator")),null,16)):k("",!0)],64)})),128))],64)):s.visible(t)&&t.separator?(p(),m("li",f({key:"separator"+i.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(p(),y(r,{key:s.label(t)+i.toString(),id:o.id+"_"+i,item:t,templates:e.$slots,exact:e.exact,focusedOptionId:s.focusedOptionId,onItemClick:s.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,G),e.$slots.end?(p(),m("div",f({key:1,class:e.cx("end")},e.ptm("end")),[S(e.$slots,"end")],16)):k("",!0)],16,q)):k("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])};export{_ as default};
|
|
1
|
+
import e from"primevue/overlayeventbus";import t from"primevue/portal";import{ObjectUtils as i,UniqueComponentId as n,ZIndexUtils as o,DomHandler as s,ConnectedOverlayScrollHandler as r}from"primevue/utils";import a from"primevue/basecomponent";import{useStyle as l}from"primevue/usestyle";import c from"primevue/ripple";import{resolveComponent as u,resolveDirective as d,openBlock as p,createElementBlock as m,mergeProps as f,createElementVNode as h,Fragment as b,createBlock as y,withCtx as v,withDirectives as g,resolveDynamicComponent as x,normalizeClass as O,createCommentVNode as k,toDisplayString as I,createVNode as L,Transition as w,renderSlot as S,renderList as C,createTextVNode as A}from"vue";var P=l("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),E={name:"BaseMenu",extends:a,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:P.load},provide:function(){return{$parentInstance:this}}},$={name:"Menuitem",hostName:"Menu",extends:a,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null,index:null},methods:{getItemProp:function(e,t){return e&&e.item?i.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{item:this.item,index:this.index,focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:c}},K=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],T=["href","onClick"],j=["href","target"];function D(e){return V(e)||H(e)||F(e)||z()}function z(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function F(e,t){if(e){if("string"==typeof e)return R(e,t);var i=Object.prototype.toString.call(e).slice(8,-1);return"Object"===i&&e.constructor&&(i=e.constructor.name),"Map"===i||"Set"===i?Array.from(e):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?R(e,t):void 0}}function H(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function V(e){if(Array.isArray(e))return R(e)}function R(e,t){(null==t||t>e.length)&&(t=e.length);for(var i=0,n=new Array(t);i<t;i++)n[i]=e[i];return n}$.render=function(e,t,i,n,o,s){var r=u("router-link"),a=d("ripple");return s.visible()?(p(),m("li",f({key:0,id:i.id,class:[e.cx("menuitem"),i.item.class],role:"menuitem",style:i.item.style,"aria-label":s.label(),"aria-disabled":s.disabled()},s.getPTOptions("menuitem"),{"data-p-focused":s.isItemFocused(),"data-p-disabled":s.disabled()||!1}),[h("div",f({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return s.onItemClick(e)})},s.getPTOptions("content")),[i.templates.item?(p(),y(x(i.templates.item),{key:1,item:i.item},null,8,["item"])):(p(),m(b,{key:0},[i.item.to&&!s.disabled()?(p(),y(r,{key:0,to:i.item.to,custom:""},{default:v((function(t){var n=t.navigate,o=t.href,r=t.isActive,l=t.isExactActive;return[g((p(),m("a",f({href:o,class:e.cx("action",{isActive:r,isExactActive:l}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return s.onItemActionClick(e,n)}},s.getPTOptions("action")),[i.templates.itemicon?(p(),y(x(i.templates.itemicon),{key:0,item:i.item,class:O([e.cx("icon"),i.item.icon])},null,8,["item","class"])):i.item.icon?(p(),m("span",f({key:1,class:[e.cx("icon"),i.item.icon]},s.getPTOptions("icon")),null,16)):k("",!0),h("span",f({class:e.cx("label")},s.getPTOptions("label")),I(s.label()),17)],16,T)),[[a]])]})),_:1},8,["to"])):g((p(),m("a",f({key:1,href:i.item.url,class:e.cx("action"),target:i.item.target,tabindex:"-1","aria-hidden":"true"},s.getPTOptions("action")),[i.templates.itemicon?(p(),y(x(i.templates.itemicon),{key:0,item:i.item,class:O([e.cx("icon"),i.item.icon])},null,8,["item","class"])):i.item.icon?(p(),m("span",f({key:1,class:[e.cx("icon"),i.item.icon]},s.getPTOptions("icon")),null,16)):k("",!0),h("span",f({class:e.cx("label")},s.getPTOptions("label")),I(s.label()),17)],16,j)),[[a]])],64))],16)],16,K)):k("",!0)};var _={name:"Menu",extends:E,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&o.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(s.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)s.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=s.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&s.findSingle(t,'a[data-pc-section="action"]');this.popup&&s.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=D(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=D(s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=s.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){s.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&o.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(s.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&o.clear(e)},alignOverlay:function(){s.absolutePosition(this.container,this.target),this.container.style.minWidth=s.getOuterWidth(this.target)+"px"},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)));e.overlayVisible&&i&&n?e.hide():!e.popup&&i&&n&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new r(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!s.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(t){e.emit("overlay-click",{originalEvent:t,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:$,Portal:t}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function M(e,t){var i=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),i.push.apply(i,n)}return i}function N(e){for(var t=1;t<arguments.length;t++){var i=null!=arguments[t]?arguments[t]:{};t%2?M(Object(i),!0).forEach((function(t){Z(e,t,i[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(i)):M(Object(i)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(i,t))}))}return e}function Z(e,t,i){return(t=U(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}function U(e){var t=W(e,"string");return"symbol"===B(t)?t:String(t)}function W(e,t){if("object"!==B(e)||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var n=i.call(e,t||"default");if("object"!==B(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var q=["id"],G=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],J=["id"];_.render=function(e,t,i,n,o,s){var r=u("PVMenuitem"),a=u("Portal");return p(),y(a,{appendTo:e.appendTo,disabled:!e.popup},{default:v((function(){return[L(w,{name:"p-connected-overlay",onEnter:s.onEnter,onLeave:s.onLeave,onAfterLeave:s.onAfterLeave},{default:v((function(){return[!e.popup||o.overlayVisible?(p(),m("div",f({key:0,ref:s.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return s.onOverlayClick&&s.onOverlayClick.apply(s,arguments)})},N(N({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(p(),m("div",f({key:0,class:e.cx("start")},e.ptm("start")),[S(e.$slots,"start")],16)):k("",!0),h("ul",f({ref:s.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?s.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return s.onListFocus&&s.onListFocus.apply(s,arguments)}),onBlur:t[1]||(t[1]=function(){return s.onListBlur&&s.onListBlur.apply(s,arguments)}),onKeydown:t[2]||(t[2]=function(){return s.onListKeyDown&&s.onListKeyDown.apply(s,arguments)})},e.ptm("menu")),[(p(!0),m(b,null,C(e.model,(function(t,i){return p(),m(b,{key:s.label(t)+i.toString()},[t.items&&s.visible(t)&&!t.separator?(p(),m(b,{key:0},[t.items?(p(),m("li",f({key:0,id:o.id+"_"+i,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[S(e.$slots,"item",{item:t},(function(){return[A(I(s.label(t)),1)]}))],16,J)):k("",!0),(p(!0),m(b,null,C(t.items,(function(n,a){return p(),m(b,{key:n.label+i+"_"+a},[s.visible(n)&&!n.separator?(p(),y(r,{key:0,id:o.id+"_"+i+"_"+a,item:n,templates:e.$slots,exact:e.exact,focusedOptionId:s.focusedOptionId,onItemClick:s.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):s.visible(n)&&n.separator?(p(),m("li",f({key:"separator"+i+a,class:[e.cx("separator"),t.class],style:n.style,role:"separator"},e.ptm("separator")),null,16)):k("",!0)],64)})),128))],64)):s.visible(t)&&t.separator?(p(),m("li",f({key:"separator"+i.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(p(),y(r,{key:s.label(t)+i.toString(),id:o.id+"_"+i,item:t,index:i,templates:e.$slots,exact:e.exact,focusedOptionId:s.focusedOptionId,onItemClick:s.itemClick,pt:e.pt},null,8,["id","item","index","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,G),e.$slots.end?(p(),m("div",f({key:1,class:e.cx("end")},e.ptm("end")),[S(e.$slots,"end")],16)):k("",!0)],16,q)):k("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])};export{_ as default};
|
package/menu/menu.js
CHANGED
|
@@ -113,7 +113,8 @@ this.primevue.menu = (function (OverlayEventBus, Portal, utils, BaseComponent, u
|
|
|
113
113
|
templates: null,
|
|
114
114
|
exact: null,
|
|
115
115
|
id: null,
|
|
116
|
-
focusedOptionId: null
|
|
116
|
+
focusedOptionId: null,
|
|
117
|
+
index: null
|
|
117
118
|
},
|
|
118
119
|
methods: {
|
|
119
120
|
getItemProp: function getItemProp(processedItem, name) {
|
|
@@ -122,6 +123,8 @@ this.primevue.menu = (function (OverlayEventBus, Portal, utils, BaseComponent, u
|
|
|
122
123
|
getPTOptions: function getPTOptions(key) {
|
|
123
124
|
return this.ptm(key, {
|
|
124
125
|
context: {
|
|
126
|
+
item: this.item,
|
|
127
|
+
index: this.index,
|
|
125
128
|
focused: this.isItemFocused()
|
|
126
129
|
}
|
|
127
130
|
});
|
|
@@ -634,12 +637,13 @@ this.primevue.menu = (function (OverlayEventBus, Portal, utils, BaseComponent, u
|
|
|
634
637
|
key: $options.label(item) + i.toString(),
|
|
635
638
|
id: $data.id + '_' + i,
|
|
636
639
|
item: item,
|
|
640
|
+
index: i,
|
|
637
641
|
templates: _ctx.$slots,
|
|
638
642
|
exact: _ctx.exact,
|
|
639
643
|
focusedOptionId: $options.focusedOptionId,
|
|
640
644
|
onItemClick: $options.itemClick,
|
|
641
645
|
pt: _ctx.pt
|
|
642
|
-
}, null, 8, ["id", "item", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
646
|
+
}, null, 8, ["id", "item", "index", "templates", "exact", "focusedOptionId", "onItemClick", "pt"]))], 64);
|
|
643
647
|
}), 128))], 16, _hoisted_2), _ctx.$slots.end ? (vue.openBlock(), vue.createElementBlock("div", vue.mergeProps({
|
|
644
648
|
key: 1,
|
|
645
649
|
"class": _ctx.cx('end')
|
package/menu/menu.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
this.primevue=this.primevue||{},this.primevue.menu=function(e,t,n,i,o,r,s){"use strict";function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=l(e),c=l(t),u=l(i),d=l(r),p=o.useStyle("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),m={name:"BaseMenu",extends:u.default,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:p.load},provide:function(){return{$parentInstance:this}}},f={name:"Menuitem",hostName:"Menu",extends:u.default,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null},methods:{getItemProp:function(e,t){return e&&e.item?n.ObjectUtils.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:d.default}},h=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],b=["href","onClick"],y=["href","target"];function v(e){return O(e)||x(e)||g(e)||k()}function k(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function g(e,t){if(e){if("string"==typeof e)return I(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}function x(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function O(e){if(Array.isArray(e))return I(e)}function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,i=new Array(t);n<t;n++)i[n]=e[n];return i}f.render=function(e,t,n,i,o,r){var l=s.resolveComponent("router-link"),a=s.resolveDirective("ripple");return r.visible()?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:n.id,class:[e.cx("menuitem"),n.item.class],role:"menuitem",style:n.item.style,"aria-label":r.label(),"aria-disabled":r.disabled()},r.getPTOptions("menuitem"),{"data-p-focused":r.isItemFocused(),"data-p-disabled":r.disabled()||!1}),[s.createElementVNode("div",s.mergeProps({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return r.onItemClick(e)})},r.getPTOptions("content")),[n.templates.item?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.item),{key:1,item:n.item},null,8,["item"])):(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[n.item.to&&!r.disabled()?(s.openBlock(),s.createBlock(l,{key:0,to:n.item.to,custom:""},{default:s.withCtx((function(t){var i=t.navigate,o=t.href,l=t.isActive,c=t.isExactActive;return[s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({href:o,class:e.cx("action",{isActive:l,isExactActive:c}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return r.onItemActionClick(e,i)}},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,b)),[[a]])]})),_:1},8,["to"])):s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({key:1,href:n.item.url,class:e.cx("action"),target:n.item.target,tabindex:"-1","aria-hidden":"true"},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,y)),[[a]])],64))],16)],16,h)):s.createCommentVNode("",!0)};var L={name:"Menu",extends:m,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n.UniqueComponentId()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n.UniqueComponentId(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&n.ZIndexUtils.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(n.DomHandler.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)n.DomHandler.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=n.DomHandler.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&n.DomHandler.findSingle(t,'a[data-pc-section="action"]');this.popup&&n.DomHandler.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){n.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&n.ZIndexUtils.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(n.DomHandler.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&n.ZIndexUtils.clear(e)},alignOverlay:function(){n.DomHandler.absolutePosition(this.container,this.target),this.container.style.minWidth=n.DomHandler.getOuterWidth(this.target)+"px"},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var n=e.container&&!e.container.contains(t.target),i=!(e.target&&(e.target===t.target||e.target.contains(t.target)));e.overlayVisible&&n&&i?e.hide():!e.popup&&n&&i&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new n.ConnectedOverlayScrollHandler(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!n.DomHandler.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(e){a.default.emit("overlay-click",{originalEvent:e,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:f,Portal:c.default}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function C(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function E(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?C(Object(n),!0).forEach((function(t){P(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):C(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function P(e,t,n){return(t=S(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function S(e){var t=w(e,"string");return"symbol"===B(t)?t:String(t)}function w(e,t){if("object"!==B(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var i=n.call(e,t||"default");if("object"!==B(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var D=["id"],H=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],A=["id"];return L.render=function(e,t,n,i,o,r){var l=s.resolveComponent("PVMenuitem"),a=s.resolveComponent("Portal");return s.openBlock(),s.createBlock(a,{appendTo:e.appendTo,disabled:!e.popup},{default:s.withCtx((function(){return[s.createVNode(s.Transition,{name:"p-connected-overlay",onEnter:r.onEnter,onLeave:r.onLeave,onAfterLeave:r.onAfterLeave},{default:s.withCtx((function(){return[!e.popup||o.overlayVisible?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,ref:r.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return r.onOverlayClick&&r.onOverlayClick.apply(r,arguments)})},E(E({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[s.renderSlot(e.$slots,"start")],16)):s.createCommentVNode("",!0),s.createElementVNode("ul",s.mergeProps({ref:r.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?r.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return r.onListFocus&&r.onListFocus.apply(r,arguments)}),onBlur:t[1]||(t[1]=function(){return r.onListBlur&&r.onListBlur.apply(r,arguments)}),onKeydown:t[2]||(t[2]=function(){return r.onListKeyDown&&r.onListKeyDown.apply(r,arguments)})},e.ptm("menu")),[(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(e.model,(function(t,n){return s.openBlock(),s.createElementBlock(s.Fragment,{key:r.label(t)+n.toString()},[t.items&&r.visible(t)&&!t.separator?(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[t.items?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:o.id+"_"+n,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[s.renderSlot(e.$slots,"item",{item:t},(function(){return[s.createTextVNode(s.toDisplayString(r.label(t)),1)]}))],16,A)):s.createCommentVNode("",!0),(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(t.items,(function(i,a){return s.openBlock(),s.createElementBlock(s.Fragment,{key:i.label+n+"_"+a},[r.visible(i)&&!i.separator?(s.openBlock(),s.createBlock(l,{key:0,id:o.id+"_"+n+"_"+a,item:i,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):r.visible(i)&&i.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n+a,class:[e.cx("separator"),t.class],style:i.style,role:"separator"},e.ptm("separator")),null,16)):s.createCommentVNode("",!0)],64)})),128))],64)):r.visible(t)&&t.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(s.openBlock(),s.createBlock(l,{key:r.label(t)+n.toString(),id:o.id+"_"+n,item:t,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,H),e.$slots.end?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[s.renderSlot(e.$slots,"end")],16)):s.createCommentVNode("",!0)],16,D)):s.createCommentVNode("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])},L}(primevue.overlayeventbus,primevue.portal,primevue.utils,primevue.basecomponent,primevue.usestyle,primevue.ripple,Vue);
|
|
1
|
+
this.primevue=this.primevue||{},this.primevue.menu=function(e,t,n,i,o,r,s){"use strict";function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var a=l(e),c=l(t),d=l(i),u=l(r),p=o.useStyle("\n.p-menu ul {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n.p-menu .p-menuitem-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n text-decoration: none;\n overflow: hidden;\n position: relative;\n}\n\n.p-menu .p-menuitem-text {\n line-height: 1;\n}\n",{name:"menu",manual:!0}),m={name:"BaseMenu",extends:d.default,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:String,default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},exact:{type:Boolean,default:!0},tabindex:{type:Number,default:0},"aria-label":{type:String,default:null},"aria-labelledby":{type:String,default:null}},css:{classes:{root:function(e){var t=e.instance;return["p-menu p-component",{"p-menu-overlay":e.props.popup,"p-input-filled":"filled"===t.$primevue.config.inputStyle,"p-ripple-disabled":!1===t.$primevue.config.ripple}]},start:"p-menu-start",menu:"p-menu-list p-reset",submenuHeader:"p-submenu-header",separator:"p-menuitem-separator",end:"p-menu-end",menuitem:function(e){var t=e.instance;return["p-menuitem",{"p-focus":t.id===t.focusedOptionId,"p-disabled":t.disabled()}]},content:"p-menuitem-content",action:function(e){return["p-menuitem-link",{"router-link-active":e.isActive,"router-link-active-exact":e.props.exact&&e.isExactActive}]},icon:"p-menuitem-icon",label:"p-menuitem-text"},loadStyle:p.load},provide:function(){return{$parentInstance:this}}},f={name:"Menuitem",hostName:"Menu",extends:d.default,inheritAttrs:!1,emits:["item-click"],props:{item:null,templates:null,exact:null,id:null,focusedOptionId:null,index:null},methods:{getItemProp:function(e,t){return e&&e.item?n.ObjectUtils.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{item:this.item,index:this.index,focused:this.isItemFocused()}})},isItemFocused:function(){return this.focusedOptionId===this.id},onItemActionClick:function(e,t){t&&t(e)},onItemClick:function(e){var t=this.getItemProp(this.item,"command");t&&t({originalEvent:e,item:this.item.item}),this.$emit("item-click",{originalEvent:e,item:this.item,id:this.id})},visible:function(){return"function"==typeof this.item.visible?this.item.visible():!1!==this.item.visible},disabled:function(){return"function"==typeof this.item.disabled?this.item.disabled():this.item.disabled},label:function(){return"function"==typeof this.item.label?this.item.label():this.item.label}},directives:{ripple:u.default}},h=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],b=["href","onClick"],y=["href","target"];function v(e){return O(e)||x(e)||g(e)||k()}function k(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function g(e,t){if(e){if("string"==typeof e)return I(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?I(e,t):void 0}}function x(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function O(e){if(Array.isArray(e))return I(e)}function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,i=new Array(t);n<t;n++)i[n]=e[n];return i}f.render=function(e,t,n,i,o,r){var l=s.resolveComponent("router-link"),a=s.resolveDirective("ripple");return r.visible()?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:n.id,class:[e.cx("menuitem"),n.item.class],role:"menuitem",style:n.item.style,"aria-label":r.label(),"aria-disabled":r.disabled()},r.getPTOptions("menuitem"),{"data-p-focused":r.isItemFocused(),"data-p-disabled":r.disabled()||!1}),[s.createElementVNode("div",s.mergeProps({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return r.onItemClick(e)})},r.getPTOptions("content")),[n.templates.item?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.item),{key:1,item:n.item},null,8,["item"])):(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[n.item.to&&!r.disabled()?(s.openBlock(),s.createBlock(l,{key:0,to:n.item.to,custom:""},{default:s.withCtx((function(t){var i=t.navigate,o=t.href,l=t.isActive,c=t.isExactActive;return[s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({href:o,class:e.cx("action",{isActive:l,isExactActive:c}),tabindex:"-1","aria-hidden":"true",onClick:function(e){return r.onItemActionClick(e,i)}},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,b)),[[a]])]})),_:1},8,["to"])):s.withDirectives((s.openBlock(),s.createElementBlock("a",s.mergeProps({key:1,href:n.item.url,class:e.cx("action"),target:n.item.target,tabindex:"-1","aria-hidden":"true"},r.getPTOptions("action")),[n.templates.itemicon?(s.openBlock(),s.createBlock(s.resolveDynamicComponent(n.templates.itemicon),{key:0,item:n.item,class:s.normalizeClass([e.cx("icon"),n.item.icon])},null,8,["item","class"])):n.item.icon?(s.openBlock(),s.createElementBlock("span",s.mergeProps({key:1,class:[e.cx("icon"),n.item.icon]},r.getPTOptions("icon")),null,16)):s.createCommentVNode("",!0),s.createElementVNode("span",s.mergeProps({class:e.cx("label")},r.getPTOptions("label")),s.toDisplayString(r.label()),17)],16,y)),[[a]])],64))],16)],16,h)):s.createCommentVNode("",!0)};var L={name:"Menu",extends:m,inheritAttrs:!1,emits:["show","hide","focus","blur"],data:function(){return{id:this.$attrs.id,overlayVisible:!1,focused:!1,focusedOptionIndex:-1,selectedOptionIndex:-1}},watch:{"$attrs.id":function(e){this.id=e||n.UniqueComponentId()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||n.UniqueComponentId(),this.popup||(this.bindResizeListener(),this.bindOutsideClickListener())},beforeUnmount:function(){this.unbindResizeListener(),this.unbindOutsideClickListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.target=null,this.container&&this.autoZIndex&&n.ZIndexUtils.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),t.to&&e.navigate&&e.navigate(e.originalEvent),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},onListFocus:function(e){this.focused=!0,this.popup||(-1!==this.selectedOptionIndex?(this.changeFocusedOptionIndex(this.selectedOptionIndex),this.selectedOptionIndex=-1):this.changeFocusedOptionIndex(0)),this.$emit("focus",e)},onListBlur:function(e){this.focused=!1,this.focusedOptionIndex=-1,this.$emit("blur",e)},onListKeyDown:function(e){switch(e.code){case"ArrowDown":this.onArrowDownKey(e);break;case"ArrowUp":this.onArrowUpKey(e);break;case"Home":this.onHomeKey(e);break;case"End":this.onEndKey(e);break;case"Enter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(n.DomHandler.focus(this.target),this.hide());case"Tab":this.overlayVisible&&this.hide()}},onArrowDownKey:function(e){var t=this.findNextOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()},onArrowUpKey:function(e){if(e.altKey&&this.popup)n.DomHandler.focus(this.target),this.hide(),e.preventDefault();else{var t=this.findPrevOptionIndex(this.focusedOptionIndex);this.changeFocusedOptionIndex(t),e.preventDefault()}},onHomeKey:function(e){this.changeFocusedOptionIndex(0),e.preventDefault()},onEndKey:function(e){this.changeFocusedOptionIndex(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=n.DomHandler.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),i=t&&n.DomHandler.findSingle(t,'a[data-pc-section="action"]');this.popup&&n.DomHandler.focus(this.target),i?i.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t+1:0},findPrevOptionIndex:function(e){var t=v(n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]')).findIndex((function(t){return t.id===e}));return t>-1?t-1:0},changeFocusedOptionIndex:function(e){var t=n.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),i=e>=t.length?t.length-1:e<0?0:e;i>-1&&(this.focusedOptionIndex=t[i].getAttribute("id"))},toggle:function(e){this.overlayVisible?this.hide():this.show(e)},show:function(e){this.overlayVisible=!0,this.target=e.currentTarget},hide:function(){this.overlayVisible=!1,this.target=null},onEnter:function(e){n.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&n.ZIndexUtils.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&(n.DomHandler.focus(this.list),this.changeFocusedOptionIndex(0)),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&n.ZIndexUtils.clear(e)},alignOverlay:function(){n.DomHandler.absolutePosition(this.container,this.target),this.container.style.minWidth=n.DomHandler.getOuterWidth(this.target)+"px"},bindOutsideClickListener:function(){var e=this;this.outsideClickListener||(this.outsideClickListener=function(t){var n=e.container&&!e.container.contains(t.target),i=!(e.target&&(e.target===t.target||e.target.contains(t.target)));e.overlayVisible&&n&&i?e.hide():!e.popup&&n&&i&&(e.focusedOptionIndex=-1)},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener:function(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener:function(){var e=this;this.scrollHandler||(this.scrollHandler=new n.ConnectedOverlayScrollHandler(this.target,(function(){e.overlayVisible&&e.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener:function(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener:function(){var e=this;this.resizeListener||(this.resizeListener=function(){e.overlayVisible&&!n.DomHandler.isTouchDevice()&&e.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener:function(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},visible:function(e){return"function"==typeof e.visible?e.visible():!1!==e.visible},disabled:function(e){return"function"==typeof e.disabled?e.disabled():e.disabled},label:function(e){return"function"==typeof e.label?e.label():e.label},onOverlayClick:function(e){a.default.emit("overlay-click",{originalEvent:e,target:this.target})},containerRef:function(e){this.container=e},listRef:function(e){this.list=e}},computed:{focusedOptionId:function(){return-1!==this.focusedOptionIndex?this.focusedOptionIndex:null}},components:{PVMenuitem:f,Portal:c.default}};function B(e){return B="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},B(e)}function C(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);t&&(i=i.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,i)}return n}function E(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?C(Object(n),!0).forEach((function(t){P(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):C(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function P(e,t,n){return(t=S(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function S(e){var t=w(e,"string");return"symbol"===B(t)?t:String(t)}function w(e,t){if("object"!==B(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var i=n.call(e,t||"default");if("object"!==B(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}var D=["id"],H=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],A=["id"];return L.render=function(e,t,n,i,o,r){var l=s.resolveComponent("PVMenuitem"),a=s.resolveComponent("Portal");return s.openBlock(),s.createBlock(a,{appendTo:e.appendTo,disabled:!e.popup},{default:s.withCtx((function(){return[s.createVNode(s.Transition,{name:"p-connected-overlay",onEnter:r.onEnter,onLeave:r.onLeave,onAfterLeave:r.onAfterLeave},{default:s.withCtx((function(){return[!e.popup||o.overlayVisible?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,ref:r.containerRef,id:o.id,class:e.cx("root"),onClick:t[3]||(t[3]=function(){return r.onOverlayClick&&r.onOverlayClick.apply(r,arguments)})},E(E({},e.$attrs),e.ptm("root")),{"data-pc-name":"menu"}),[e.$slots.start?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:0,class:e.cx("start")},e.ptm("start")),[s.renderSlot(e.$slots,"start")],16)):s.createCommentVNode("",!0),s.createElementVNode("ul",s.mergeProps({ref:r.listRef,id:o.id+"_list",class:e.cx("menu"),role:"menu",tabindex:e.tabindex,"aria-activedescendant":o.focused?r.focusedOptionId:void 0,"aria-label":e.ariaLabel,"aria-labelledby":e.ariaLabelledby,onFocus:t[0]||(t[0]=function(){return r.onListFocus&&r.onListFocus.apply(r,arguments)}),onBlur:t[1]||(t[1]=function(){return r.onListBlur&&r.onListBlur.apply(r,arguments)}),onKeydown:t[2]||(t[2]=function(){return r.onListKeyDown&&r.onListKeyDown.apply(r,arguments)})},e.ptm("menu")),[(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(e.model,(function(t,n){return s.openBlock(),s.createElementBlock(s.Fragment,{key:r.label(t)+n.toString()},[t.items&&r.visible(t)&&!t.separator?(s.openBlock(),s.createElementBlock(s.Fragment,{key:0},[t.items?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:0,id:o.id+"_"+n,class:e.cx("submenuHeader"),role:"none"},e.ptm("submenuHeader")),[s.renderSlot(e.$slots,"item",{item:t},(function(){return[s.createTextVNode(s.toDisplayString(r.label(t)),1)]}))],16,A)):s.createCommentVNode("",!0),(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(t.items,(function(i,a){return s.openBlock(),s.createElementBlock(s.Fragment,{key:i.label+n+"_"+a},[r.visible(i)&&!i.separator?(s.openBlock(),s.createBlock(l,{key:0,id:o.id+"_"+n+"_"+a,item:i,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","templates","exact","focusedOptionId","onItemClick","pt"])):r.visible(i)&&i.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n+a,class:[e.cx("separator"),t.class],style:i.style,role:"separator"},e.ptm("separator")),null,16)):s.createCommentVNode("",!0)],64)})),128))],64)):r.visible(t)&&t.separator?(s.openBlock(),s.createElementBlock("li",s.mergeProps({key:"separator"+n.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(s.openBlock(),s.createBlock(l,{key:r.label(t)+n.toString(),id:o.id+"_"+n,item:t,index:n,templates:e.$slots,exact:e.exact,focusedOptionId:r.focusedOptionId,onItemClick:r.itemClick,pt:e.pt},null,8,["id","item","index","templates","exact","focusedOptionId","onItemClick","pt"]))],64)})),128))],16,H),e.$slots.end?(s.openBlock(),s.createElementBlock("div",s.mergeProps({key:1,class:e.cx("end")},e.ptm("end")),[s.renderSlot(e.$slots,"end")],16)):s.createCommentVNode("",!0)],16,D)):s.createCommentVNode("",!0)]})),_:3},8,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])},L}(primevue.overlayeventbus,primevue.portal,primevue.utils,primevue.basecomponent,primevue.usestyle,primevue.ripple,Vue);
|
package/menubar/Menubar.d.ts
CHANGED
|
@@ -151,6 +151,14 @@ export interface MenubarState {
|
|
|
151
151
|
* Defines current options in Menubar component.
|
|
152
152
|
*/
|
|
153
153
|
export interface MenubarContext {
|
|
154
|
+
/**
|
|
155
|
+
* Current menuitem
|
|
156
|
+
*/
|
|
157
|
+
item: any;
|
|
158
|
+
/**
|
|
159
|
+
* Current index of the menuitem.
|
|
160
|
+
*/
|
|
161
|
+
index: number;
|
|
154
162
|
/**
|
|
155
163
|
* Current active state of menuitem as a boolean.
|
|
156
164
|
* @defaultValue false
|