primereact
Version:
PrimeReact is an open source UI library for React featuring a rich set of 90+ 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) • 8.62 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.tabmenu=function(e,n,t,r,a,i,l){"use strict";function o(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 u=o(n);function c(){return c=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var r in t)({}).hasOwnProperty.call(t,r)&&(e[r]=t[r])}return e},c.apply(null,arguments)}function s(e){return s="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},s(e)}function m(e,n){if("object"!=s(e)||!e)return e;var t=e[Symbol.toPrimitive];if(void 0!==t){var r=t.call(e,n||"default");if("object"!=s(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===n?String:Number)(e)}function f(e){var n=m(e,"string");return"symbol"==s(n)?n:n+""}function d(e,n,t){return(n=f(n))in e?Object.defineProperty(e,n,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[n]=t,e}function p(e){if(Array.isArray(e))return e}function b(e,n){var t=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=t){var r,a,i,l,o=[],u=!0,c=!1;try{if(i=(t=t.call(e)).next,0===n){if(Object(t)!==t)return;u=!1}else for(;!(u=(r=i.call(t)).done)&&(o.push(r.value),o.length!==n);u=!0);}catch(e){c=!0,a=e}finally{try{if(!u&&null!=t.return&&(l=t.return(),Object(l)!==l))return}finally{if(c)throw a}}return o}}function v(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=Array(n);t<n;t++)r[t]=e[t];return r}function y(e,n){if(e){if("string"==typeof e)return v(e,n);var t={}.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)?v(e,n):void 0}}function g(){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 p(e)||b(e,n)||y(e,n)||g()}var x=r.ComponentBase.extend({defaultProps:{__TYPE:"TabMenu",id:null,model:null,activeIndex:0,ariaLabel:null,ariaLabelledBy:null,style:null,className:null,onTabChange:null,children:void 0},css:{classes:{icon:function(e){return l.classNames("p-menuitem-icon",e._icon)},label:"p-menuitem-text",action:"p-menuitem-link",menuitem:function(e){return l.classNames("p-tabmenuitem",{"p-highlight":e.active,"p-disabled":e.disabled},e._className)},inkbar:"p-tabmenu-ink-bar",menu:"p-tabmenu-nav p-reset",root:"p-tabmenu p-component"},styles:"\n@layer primereact {\n .p-tabmenu {\n overflow-x: auto;\n }\n\n .p-tabmenu-nav {\n display: flex;\n margin: 0;\n padding: 0;\n list-style-type: none;\n flex-wrap: nowrap;\n }\n\n .p-tabmenu-nav a {\n cursor: pointer;\n user-select: none;\n display: flex;\n align-items: center;\n position: relative;\n text-decoration: none;\n text-decoration: none;\n overflow: hidden;\n }\n\n .p-tabmenu-nav a:focus {\n z-index: 1;\n }\n\n .p-tabmenu-nav .p-menuitem-text {\n line-height: 1;\n }\n\n .p-tabmenu-ink-bar {\n display: none;\n z-index: 1;\n }\n\n .p-tabmenu::-webkit-scrollbar {\n display: none;\n }\n}\n"}});function O(e,n){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);n&&(r=r.filter((function(n){return Object.getOwnPropertyDescriptor(e,n).enumerable}))),t.push.apply(t,r)}return t}function j(e){for(var n=1;n<arguments.length;n++){var t=null!=arguments[n]?arguments[n]:{};n%2?O(Object(t),!0).forEach((function(n){d(e,n,t[n])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):O(Object(t)).forEach((function(n){Object.defineProperty(e,n,Object.getOwnPropertyDescriptor(t,n))}))}return e}var w=u.memo(u.forwardRef((function(e,n){var o=a.useMergeProps(),s=u.useContext(t.PrimeReactContext),m=x.getProps(e,s),f=h(u.useState(m.id),2),d=f[0],p=f[1],b=h(u.useState(m.activeIndex),2),v=b[0],y=b[1],g=u.useRef(null),O=u.useRef(null),w=u.useRef(null),E=u.useRef({}),S=m.onTabChange?m.activeIndex:v,D={props:m,state:{id:d,activeIndex:S}},N=x.setMetaData(j({},D)),P=N.ptm,k=N.cx,I=function(e,n,t){return P(e,{parent:D,context:{item:n,index:t}})};r.useHandleStyle(x.css.styles,N.isUnstyled,{name:"tabmenu"});var C=function(e,n,t){n.disabled?e.preventDefault():(n.command&&n.command({originalEvent:e,item:n}),m.onTabChange?m.onTabChange({originalEvent:e,value:n,index:t}):y(t),n.url||(e.preventDefault(),e.stopPropagation()))},H=function(e){return e===(S||0)},_=function(){if(m.model){for(var e=w.current.children,n=!1,t=0;t<e.length;t++){var r=e[t];l.DomHandler.getAttribute(r,"data-p-highlight")&&(O.current.style.width=l.DomHandler.getWidth(r)+"px",O.current.style.left=l.DomHandler.getOffset(r).left-l.DomHandler.getOffset(w.current).left+"px",n=!0)}n||(O.current.style.width="0px",O.current.style.left="0px")}};a.useMountEffect((function(){d||p(l.UniqueComponentId())})),u.useImperativeHandle(n,(function(){return{props:m,getElement:function(){return g.current}}})),u.useEffect((function(){_()}));var A=function(e,n,t){switch(e.code){case"ArrowRight":T(e.target),e.preventDefault();break;case"ArrowLeft":M(e.target),e.preventDefault();break;case"Home":R(e.target),e.preventDefault();break;case"End":L(e.target),e.preventDefault();break;case"Space":case"Enter":case"NumpadEnter":C(e,n,t),e.preventDefault();break;case"Tab":q()}},T=function(e){var n=U(e);n&&X(e,n)},M=function(e){var n=z(e);n&&X(e,n)},R=function(e){var n=B();n&&X(e,n)},L=function(e){var n=J();n&&X(e,n)},U=function(e){var n=e.parentElement.nextElementSibling;return n?!0===l.DomHandler.getAttribute(n,"data-p-disabled")?U(n.children[0]):n.children[0]:null},z=function(e){var n=e.parentElement.previousElementSibling;return n?!0===l.DomHandler.getAttribute(n,"data-p-disabled")?z(n.children[0]):n.children[0]:null},B=function(){var e=l.DomHandler.findSingle(w.current,'[data-pc-section="menuitem"][data-p-disabled="false"]');return e?e.children[0]:null},J=function(){var e=l.DomHandler.find(w.current,'[data-pc-section="menuitem"][data-p-disabled="false"]');return e?e[e.length-1].children[0]:null},X=function(e,n){e.tabIndex="-1",n.tabIndex="0",n.focus()},q=function(){var e=l.DomHandler.findSingle(w.current,'[data-pc-section="menuitem"][data-p-disabled="false"][data-p-highlight="true"]'),n=l.DomHandler.findSingle(w.current,'[data-pc-section="action"][tabindex="0"]');n!==e.children[0]&&(e&&(e.children[0].tabIndex="0"),n.tabIndex="-1")},K=function(e,n){if(!1===e.visible)return null;var t=e.className,r=e.style,a=e.disabled,s=e.icon,f=e.label,p=e.template,b=e.url,v=e.target,y=e.id||d+"_"+n,g=H(n),h=l.classNames("p-menuitem-icon",s),x=o({className:k("icon",{_icon:s})},I("icon",e,n)),O=l.IconUtils.getJSXIcon(s,j({},x),{props:m}),w=o({className:k("label")},I("label",e,n)),S=f&&u.createElement("span",w,f),D=o({href:b||"#",role:"menuitem","aria-label":f,tabIndex:g?"0":"-1",className:k("action"),target:v,onClick:function(t){return C(t,e,n)}},I("action",e,n)),N=u.createElement("a",D,O,S,u.createElement(i.Ripple,null));p&&(N=l.ObjectUtils.getJSXElement(p,e,{onClick:function(t){return C(t,e,n)},className:"p-menuitem-link",labelClassName:"p-menuitem-text",iconClassName:h,element:N,props:m,active:g,index:n,disabled:a}));var P=o({ref:E.current["tab_".concat(n)],id:y,onKeyDown:function(t){return A(t,e,n)},className:k("menuitem",{_className:t,active:g,disabled:a}),style:r,role:"presentation","data-p-highlight":g,"data-p-disabled":a||!1,"aria-disabled":a},I("menuitem",e,n));return u.createElement("li",c({},P,{key:y}),N)};if(m.model){var W=m.model.map(K),Y=o({ref:O,role:"none",className:k("inkbar")},P("inkbar")),$=o({ref:w,"aria-label":m.ariaLabel,"aria-labelledby":m.ariaLabelledBy,className:k("menu"),role:"menubar"},P("menu")),F=o({id:m.id,ref:g,className:l.classNames(m.className,k("root")),style:m.style},x.getOtherProps(m),P("root"));return u.createElement("div",F,u.createElement("ul",$,W,u.createElement("li",Y)))}return null})));return w.displayName="TabMenu",e.TabMenu=w,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.componentbase,primereact.hooks,primereact.ripple,primereact.utils);