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