primereact
Version:
PrimeReact is an open source UI library for React 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 Prime
2 lines (1 loc) • 5.58 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.menu=function(e,n,t,r,a,l,i,o){"use strict";function u(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function s(e){if(e&&e.__esModule)return e;var n=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var r=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,r.get?r:{enumerable:!0,get:function(){return e[t]}})}})),n.default=e,Object.freeze(n)}var c=s(n),m=u(t);function p(){return p=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},p.apply(this,arguments)}function f(e){if(Array.isArray(e))return e}function d(e,n){var t=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=t){var r,a,l=[],i=!0,o=!1;try{for(t=t.call(e);!(i=(r=t.next()).done)&&(l.push(r.value),!n||l.length!==n);i=!0);}catch(e){o=!0,a=e}finally{try{i||null==t.return||t.return()}finally{if(o)throw a}}return l}}function b(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=new Array(n);t<n;t++)r[t]=e[t];return r}function v(e,n){if(e){if("string"==typeof e)return b(e,n);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?b(e,n):void 0}}function y(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function h(e,n){return f(e)||d(e,n)||v(e,n)||y()}var g=c.memo(c.forwardRef((function(e,n){var t=h(c.useState(!e.popup),2),u=t[0],s=t[1],f=c.useRef(null),d=c.useRef(null),b=h(a.useOverlayListener({target:d,overlay:f,listener:function(e,n){n.valid&&j(e)},when:u}),2),v=b[0],y=b[1],E=function(n){e.popup&&l.OverlayService.emit("overlay-click",{originalEvent:n,target:d.current})},N=function(n,t){t.disabled?n.preventDefault():(t.url||n.preventDefault(),t.command&&t.command({originalEvent:n,item:t}),e.popup&&j(n))},O=function(e,n){var t=e.currentTarget.parentElement;switch(e.which){case 40:var r=x(t);r&&r.children[0].focus(),e.preventDefault();break;case 38:var a=w(t);a&&a.children[0].focus(),e.preventDefault()}},x=function e(n){var t=n.nextElementSibling;return t?o.DomHandler.hasClass(t,"p-disabled")||!o.DomHandler.hasClass(t,"p-menuitem")?e(t):t:null},w=function e(n){var t=n.previousElementSibling;return t?o.DomHandler.hasClass(t,"p-disabled")||!o.DomHandler.hasClass(t,"p-menuitem")?e(t):t:null},I=function(n){e.popup&&(u?j(n):S(n))},S=function(n){d.current=n.currentTarget,s(!0),e.onShow&&e.onShow(n)},j=function(n){d.current=n.currentTarget,s(!1),e.onHide&&e.onHide(n)},D=function(){o.ZIndexUtils.set("menu",f.current,m.default.autoZIndex,e.baseZIndex||m.default.zIndex.menu),o.DomHandler.absolutePosition(f.current,d.current)},k=function(){v()},C=function(){d.current=null,y()},T=function(){o.ZIndexUtils.clear(f.current)};a.useUnmountEffect((function(){o.ZIndexUtils.clear(f.current)})),c.useImperativeHandle(n,(function(){return{props:e,toggle:I,show:S,hide:j,getElement:function(){return f.current},getTarget:function(){return d.current}}}));var H=function(e,n){var t=e.label+"_"+n,r=o.classNames("p-submenu-header",{"p-disabled":e.disabled},e.className),a=e.items.map(_);return c.createElement(c.Fragment,{key:t},c.createElement("li",{className:r,style:e.style,role:"presentation"},e.label),a)},P=function(e){return c.createElement("li",{key:"separator_"+e,className:"p-menu-separator",role:"separator"})},_=function(n,t){if(!1===n.visible)return null;var r=o.classNames("p-menuitem",n.className),a=o.classNames("p-menuitem-link",{"p-disabled":n.disabled}),l=o.classNames("p-menuitem-icon",n.icon),i=o.IconUtils.getJSXIcon(n.icon,{className:"p-menuitem-icon"},{props:e}),u=n.disabled?null:0,s=n.label+"_"+t,m=c.createElement("a",{href:n.url||"#",className:a,role:"menuitem",target:n.target,onClick:function(e){return N(e,n)},onKeyDown:function(e){return O(e)},tabIndex:u,"aria-disabled":n.disabled},i,n.label&&c.createElement("span",{className:"p-menuitem-text"},n.label));n.template&&(m=o.ObjectUtils.getJSXElement(n.template,n,{onClick:function(e){return N(e,n)},onKeyDown:function(e){return O(e)},className:a,tabIndex:u,labelClassName:"p-menuitem-text",iconClassName:l,element:m,props:e}));return c.createElement("li",{key:s,className:r,style:n.style,role:"none"},m)},U=function(e,n){return e.separator?P(n):e.items?H(e,n):_(e,n)},Z=function(){if(e.model){var n=o.ObjectUtils.findDiffKeys(e,g.defaultProps),t=o.classNames("p-menu p-component",{"p-menu-overlay":e.popup},e.className),a=e.model.map(U);return c.createElement(r.CSSTransition,{nodeRef:f,classNames:"p-connected-overlay",in:u,timeout:{enter:120,exit:100},options:e.transitionOptions,unmountOnExit:!0,onEnter:D,onEntered:k,onExit:C,onExited:T},c.createElement("div",p({ref:f,id:e.id,className:t,style:e.style},n,{onClick:E}),c.createElement("ul",{className:"p-menu-list p-reset",role:"menu"},a)))}return null}();return e.popup?c.createElement(i.Portal,{element:Z,appendTo:e.appendTo}):Z})));return g.displayName="Menu",g.defaultProps={__TYPE:"Menu",id:null,model:null,popup:!1,style:null,className:null,autoZIndex:!0,baseZIndex:0,appendTo:null,transitionOptions:null,onShow:null,onHide:null},e.Menu=g,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.csstransition,primereact.hooks,primereact.overlayservice,primereact.portal,primereact.utils);