UNPKG

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