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.07 kB
JavaScript
import*as e from"react";import n from"primereact/api";import{CSSTransition as t}from"primereact/csstransition";import{useOverlayListener as r,useUnmountEffect as a}from"primereact/hooks";import{OverlayService as l}from"primereact/overlayservice";import{Portal as o}from"primereact/portal";import{ZIndexUtils as i,ObjectUtils as u,classNames as s,DomHandler as c,IconUtils as m}from"primereact/utils";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=[],o=!0,i=!1;try{for(t=t.call(e);!(o=(r=t.next()).done)&&(l.push(r.value),!n||l.length!==n);o=!0);}catch(e){i=!0,a=e}finally{try{o||null==t.return||t.return()}finally{if(i)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=e.memo(e.forwardRef((function(f,d){var b=h(e.useState(!f.popup),2),v=b[0],y=b[1],E=e.useRef(null),N=e.useRef(null),x=h(r({target:N,overlay:E,listener:function(e,n){n.valid&&A(e)},when:v}),2),w=x[0],S=x[1],I=function(e){f.popup&&l.emit("overlay-click",{originalEvent:e,target:N.current})},k=function(e,n){n.disabled?e.preventDefault():(n.url||e.preventDefault(),n.command&&n.command({originalEvent:e,item:n}),f.popup&&A(e))},C=function(e,n){var t=e.currentTarget.parentElement;switch(e.which){case 40:var r=O(t);r&&r.children[0].focus(),e.preventDefault();break;case 38:var a=T(t);a&&a.children[0].focus(),e.preventDefault()}},O=function e(n){var t=n.nextElementSibling;return t?c.hasClass(t,"p-disabled")||!c.hasClass(t,"p-menuitem")?e(t):t:null},T=function e(n){var t=n.previousElementSibling;return t?c.hasClass(t,"p-disabled")||!c.hasClass(t,"p-menuitem")?e(t):t:null},D=function(e){f.popup&&(v?A(e):j(e))},j=function(e){N.current=e.currentTarget,y(!0),f.onShow&&f.onShow(e)},A=function(e){N.current=e.currentTarget,y(!1),f.onHide&&f.onHide(e)},P=function(){i.set("menu",E.current,n.autoZIndex,f.baseZIndex||n.zIndex.menu),c.absolutePosition(E.current,N.current)},_=function(){w()},H=function(){N.current=null,S()},R=function(){i.clear(E.current)};a((function(){i.clear(E.current)})),e.useImperativeHandle(d,(function(){return{props:f,toggle:D,show:j,hide:A,getElement:function(){return E.current},getTarget:function(){return N.current}}}));var Z=function(n,t){var r=n.label+"_"+t,a=s("p-submenu-header",{"p-disabled":n.disabled},n.className),l=n.items.map(M);return e.createElement(e.Fragment,{key:r},e.createElement("li",{className:a,style:n.style,role:"presentation"},n.label),l)},K=function(n){return e.createElement("li",{key:"separator_"+n,className:"p-menu-separator",role:"separator"})},M=function(n,t){if(!1===n.visible)return null;var r=s("p-menuitem",n.className),a=s("p-menuitem-link",{"p-disabled":n.disabled}),l=s("p-menuitem-icon",n.icon),o=m.getJSXIcon(n.icon,{className:"p-menuitem-icon"},{props:f}),i=n.disabled?null:0,c=n.label+"_"+t,p=e.createElement("a",{href:n.url||"#",className:a,role:"menuitem",target:n.target,onClick:function(e){return k(e,n)},onKeyDown:function(e){return C(e)},tabIndex:i,"aria-disabled":n.disabled},o,n.label&&e.createElement("span",{className:"p-menuitem-text"},n.label));n.template&&(p=u.getJSXElement(n.template,n,{onClick:function(e){return k(e,n)},onKeyDown:function(e){return C(e)},className:a,tabIndex:i,labelClassName:"p-menuitem-text",iconClassName:l,element:p,props:f}));return e.createElement("li",{key:c,className:r,style:n.style,role:"none"},p)},J=function(e,n){return e.separator?K(n):e.items?Z(e,n):M(e,n)},X=function(){if(f.model){var n=u.findDiffKeys(f,g.defaultProps),r=s("p-menu p-component",{"p-menu-overlay":f.popup},f.className),a=f.model.map(J);return e.createElement(t,{nodeRef:E,classNames:"p-connected-overlay",in:v,timeout:{enter:120,exit:100},options:f.transitionOptions,unmountOnExit:!0,onEnter:P,onEntered:_,onExit:H,onExited:R},e.createElement("div",p({ref:E,id:f.id,className:r,style:f.style},n,{onClick:I}),e.createElement("ul",{className:"p-menu-list p-reset",role:"menu"},a)))}return null}();return f.popup?e.createElement(o,{element:X,appendTo:f.appendTo}):X})));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};export{g as Menu};