primevue
Version:
PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBloc
2 lines (1 loc) • 14.1 kB
JavaScript
this.primevue=this.primevue||{},this.primevue.menu=function(e,t,i,n,o,s,r){"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(n),u={name:"BaseMenu",extends:d.default,props:{popup:{type:Boolean,default:!1},model:{type:Array,default:null},appendTo:{type:[String,Object],default:"body"},autoZIndex:{type:Boolean,default:!0},baseZIndex:{type:Number,default:0},tabindex:{type:Number,default:0},ariaLabel:{type:String,default:null},ariaLabelledby:{type:String,default:null}},style:l(o).default,provide:function(){return{$parentInstance:this}}},m={name:"Menuitem",hostName:"Menu",extends:d.default,inheritAttrs:!1,emits:["item-click","item-mousemove"],props:{item:null,templates:null,id:null,focusedOptionId:null,index:null},methods:{getItemProp:function(e,t){return e&&e.item?i.ObjectUtils.getItemValue(e.item[t]):void 0},getPTOptions:function(e){return this.ptm(e,{context:{item:this.item,index:this.index,focused:this.isItemFocused(),disabled:this.disabled()}})},isItemFocused:function(){return this.focusedOptionId===this.id},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})},onItemMouseMove:function(e){this.$emit("item-mousemove",{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},getMenuItemProps:function(e){return{action:r.mergeProps({class:this.cx("action"),tabindex:"-1","aria-hidden":!0},this.getPTOptions("action")),icon:r.mergeProps({class:[this.cx("icon"),e.icon]},this.getPTOptions("icon")),label:r.mergeProps({class:this.cx("label")},this.getPTOptions("label"))}}},directives:{ripple:l(s).default}},p=["id","aria-label","aria-disabled","data-p-focused","data-p-disabled"],h=["href","target"];function f(e){return g(e)||y(e)||v(e)||b()}function b(){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 v(e,t){if(e){if("string"==typeof e)return k(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)?k(e,t):void 0}}function y(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function g(e){if(Array.isArray(e))return k(e)}function k(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}m.render=function(e,t,i,n,o,s){var l=r.resolveDirective("ripple");return s.visible()?(r.openBlock(),r.createElementBlock("li",r.mergeProps({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}),[r.createElementVNode("div",r.mergeProps({class:e.cx("content"),onClick:t[0]||(t[0]=function(e){return s.onItemClick(e)}),onMousemove:t[1]||(t[1]=function(e){return s.onItemMouseMove(e)})},s.getPTOptions("content")),[i.templates.item?i.templates.item?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(i.templates.item),{key:1,item:i.item,label:s.label(),props:s.getMenuItemProps(i.item)},null,8,["item","label","props"])):r.createCommentVNode("",!0):r.withDirectives((r.openBlock(),r.createElementBlock("a",r.mergeProps({key:0,href:i.item.url,class:e.cx("action"),target:i.item.target,tabindex:"-1","aria-hidden":"true"},s.getPTOptions("action")),[i.templates.itemicon?(r.openBlock(),r.createBlock(r.resolveDynamicComponent(i.templates.itemicon),{key:0,item:i.item,class:r.normalizeClass(e.cx("icon"))},null,8,["item","class"])):i.item.icon?(r.openBlock(),r.createElementBlock("span",r.mergeProps({key:1,class:[e.cx("icon"),i.item.icon]},s.getPTOptions("icon")),null,16)):r.createCommentVNode("",!0),r.createElementVNode("span",r.mergeProps({class:e.cx("label")},s.getPTOptions("label")),r.toDisplayString(s.label()),17)],16,h)),[[l]])],16)],16,p)):r.createCommentVNode("",!0)};var x={name:"Menu",extends:u,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||i.UniqueComponentId()}},target:null,outsideClickListener:null,scrollHandler:null,resizeListener:null,container:null,list:null,mounted:function(){this.id=this.id||i.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&&i.ZIndexUtils.clear(this.container),this.container=null},methods:{itemClick:function(e){var t=e.item;this.disabled(t)||(t.command&&t.command(e),this.overlayVisible&&this.hide(),this.popup||this.focusedOptionIndex===e.id||(this.focusedOptionIndex=e.id))},itemMouseMove:function(e){this.focused&&(this.focusedOptionIndex=e.id)},onListFocus:function(e){this.focused=!0,!this.popup&&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":case"NumpadEnter":this.onEnterKey(e);break;case"Space":this.onSpaceKey(e);break;case"Escape":this.popup&&(i.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)i.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(i.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]').length-1),e.preventDefault()},onEnterKey:function(e){var t=i.DomHandler.findSingle(this.list,'li[id="'.concat("".concat(this.focusedOptionIndex),'"]')),n=t&&i.DomHandler.findSingle(t,'a[data-pc-section="action"]');this.popup&&i.DomHandler.focus(this.target),n?n.click():t&&t.click(),e.preventDefault()},onSpaceKey:function(e){this.onEnterKey(e)},findNextOptionIndex:function(e){var t=f(i.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=f(i.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=i.DomHandler.find(this.container,'li[data-pc-section="menuitem"][data-p-disabled="false"]'),n=e>=t.length?t.length-1:e<0?0:e;n>-1&&(this.focusedOptionIndex=t[n].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){i.DomHandler.addStyles(e,{position:"absolute",top:"0",left:"0"}),this.alignOverlay(),this.bindOutsideClickListener(),this.bindResizeListener(),this.bindScrollListener(),this.autoZIndex&&i.ZIndexUtils.set("menu",e,this.baseZIndex+this.$primevue.config.zIndex.menu),this.popup&&i.DomHandler.focus(this.list),this.$emit("show")},onLeave:function(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.unbindScrollListener(),this.$emit("hide")},onAfterLeave:function(e){this.autoZIndex&&i.ZIndexUtils.clear(e)},alignOverlay:function(){i.DomHandler.absolutePosition(this.container,this.target),i.DomHandler.getOuterWidth(this.target)>i.DomHandler.getOuterWidth(this.container)&&(this.container.style.minWidth=i.DomHandler.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 i.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&&!i.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:m,Portal:c.default}},I=["id"],O=["id","tabindex","aria-activedescendant","aria-label","aria-labelledby"],L=["id"];return x.render=function(e,t,i,n,o,s){var l=r.resolveComponent("PVMenuitem"),a=r.resolveComponent("Portal");return r.openBlock(),r.createBlock(a,{appendTo:e.appendTo,disabled:!e.popup},{default:r.withCtx((function(){return[r.createVNode(r.Transition,r.mergeProps({name:"p-connected-overlay",onEnter:s.onEnter,onLeave:s.onLeave,onAfterLeave:s.onAfterLeave},e.ptm("transition")),{default:r.withCtx((function(){return[!e.popup||o.overlayVisible?(r.openBlock(),r.createElementBlock("div",r.mergeProps({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)})},e.ptmi("root")),[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.createElementVNode("ul",r.mergeProps({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")),[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(e.model,(function(t,i){return r.openBlock(),r.createElementBlock(r.Fragment,{key:s.label(t)+i.toString()},[t.items&&s.visible(t)&&!t.separator?(r.openBlock(),r.createElementBlock(r.Fragment,{key:0},[t.items?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:0,id:o.id+"_"+i,class:[e.cx("submenuHeader"),t.class],style:t.style,role:"none"},e.ptm("submenuHeader")),[r.renderSlot(e.$slots,"submenuheader",{item:t},(function(){return[r.createTextVNode(r.toDisplayString(s.label(t)),1)]}))],16,L)):r.createCommentVNode("",!0),(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(t.items,(function(n,a){return r.openBlock(),r.createElementBlock(r.Fragment,{key:n.label+i+"_"+a},[s.visible(n)&&!n.separator?(r.openBlock(),r.createBlock(l,{key:0,id:o.id+"_"+i+"_"+a,item:n,templates:e.$slots,focusedOptionId:s.focusedOptionId,unstyled:e.unstyled,onItemClick:s.itemClick,onItemMousemove:s.itemMouseMove,pt:e.pt},null,8,["id","item","templates","focusedOptionId","unstyled","onItemClick","onItemMousemove","pt"])):s.visible(n)&&n.separator?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:"separator"+i+a,class:[e.cx("separator"),t.class],style:n.style,role:"separator"},e.ptm("separator")),null,16)):r.createCommentVNode("",!0)],64)})),128))],64)):s.visible(t)&&t.separator?(r.openBlock(),r.createElementBlock("li",r.mergeProps({key:"separator"+i.toString(),class:[e.cx("separator"),t.class],style:t.style,role:"separator"},e.ptm("separator")),null,16)):(r.openBlock(),r.createBlock(l,{key:s.label(t)+i.toString(),id:o.id+"_"+i,item:t,index:i,templates:e.$slots,focusedOptionId:s.focusedOptionId,unstyled:e.unstyled,onItemClick:s.itemClick,onItemMousemove:s.itemMouseMove,pt:e.pt},null,8,["id","item","index","templates","focusedOptionId","unstyled","onItemClick","onItemMousemove","pt"]))],64)})),128))],16,O),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,I)):r.createCommentVNode("",!0)]})),_:3},16,["onEnter","onLeave","onAfterLeave"])]})),_:3},8,["appendTo","disabled"])},x}(primevue.overlayeventbus,primevue.portal,primevue.utils,primevue.basecomponent,primevue.menu.style,primevue.ripple,Vue);