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) • 10.1 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.accordion=function(e,t,n,r,a,o,i,c,l){"use strict";function s(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=s(t);function d(){return d=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},d.apply(null,arguments)}function p(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function f(e){if(Array.isArray(e))return p(e)}function b(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function m(e,t){if(e){if("string"==typeof e)return p(e,t);var n={}.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 h(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function y(e){return y="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},y(e)}function g(e,t){if("object"!=y(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=y(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function v(e){var t=g(e,"string");return"symbol"==y(t)?t:t+""}function O(e,t,n){return(t=v(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function E(e){if(Array.isArray(e))return e}function P(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,a,o,i,c=[],l=!0,s=!1;try{if(o=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;l=!1}else for(;!(l=(r=o.call(n)).done)&&(c.push(r.value),c.length!==t);l=!0);}catch(e){s=!0,a=e}finally{try{if(!l&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(s)throw a}}return c}}function S(){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 C(e,t){return E(e)||P(e,t)||m(e,t)||S()}var j=r.ComponentBase.extend({defaultProps:{__TYPE:"Accordion",id:null,activeIndex:null,className:null,style:null,multiple:!1,expandIcon:null,collapseIcon:null,transitionOptions:null,onTabOpen:null,onTabClose:null,onTabChange:null,children:void 0},css:{classes:{root:"p-accordion p-component",accordiontab:{root:function(e){return l.classNames("p-accordion-tab",{"p-accordion-tab-active":e.selected})},content:"p-accordion-content",header:function(e){return l.classNames("p-accordion-header",{"p-highlight":e.selected,"p-disabled":(0,e.getTabProp)(e.tab,"disabled")})},headeraction:"p-accordion-header-link",headericon:"p-accordion-toggle-icon",headertitle:"p-accordion-header-text",toggleablecontent:"p-toggleable-content",transition:"p-toggleable-content"}},styles:"\n@layer primereact {\n .p-accordion-header-link {\n cursor: pointer;\n display: flex;\n align-items: center;\n user-select: none;\n position: relative;\n text-decoration: none;\n }\n \n .p-accordion-header-link:focus {\n z-index: 1;\n }\n \n .p-accordion-header-text {\n line-height: 1;\n width: 100%;\n }\n}\n"}}),x=r.ComponentBase.extend({defaultProps:{__TYPE:"AccordionTab",className:null,contentClassName:null,contentStyle:null,disabled:!1,header:null,headerClassName:null,headerStyle:null,headerTemplate:null,style:null,tabIndex:0,children:void 0},getCProp:function(e,t){return l.ObjectUtils.getComponentProp(e,t,x.defaultProps)},getCProps:function(e){return l.ObjectUtils.getComponentProps(e,x.defaultProps)},getCOtherProps:function(e){return l.ObjectUtils.getComponentDiffProps(e,x.defaultProps)}});function N(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 w(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?N(Object(n),!0).forEach((function(t){O(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):N(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var D=function(){},T=u.forwardRef((function(e,t){var s=o.useMergeProps(),p=u.useContext(n.PrimeReactContext),y=j.getProps(e,p),g=C(u.useState(y.id),2),v=g[0],O=g[1],E=C(u.useState(y.activeIndex),2),P=E[0],S=E[1],N=u.useRef(null),D=y.onTabChange?y.activeIndex:P,T=u.Children.count(y.children),A={props:y,state:{id:v,activeIndex:P}},I=j.setMetaData(w({},A)),_=I.ptm,k=I.ptmo,U=I.cx;r.useHandleStyle(j.css.styles,I.isUnstyled,{name:"accordion"});var H=function(e,t){return x.getCProp(e,t)},R=function(e,t,n){var r={parent:A,context:{index:n,count:T,first:0===n,last:n===T-1,selected:Q(n),disabled:H(e,"disabled")}};return s(_("tab.".concat(t),{tab:r}),_("accordiontab.".concat(t),{accordiontab:r}),_("accordiontab.".concat(t),r),k(H(e,"pt"),t,r))},M=function(e,t,n){J(e,t,n)},J=function(e,t,n){if(!H(t,"disabled")){var r=Q(n),a=null;if(y.multiple){var o=D||[];a=r?o.filter((function(e){return e!==n})):[].concat(f(c=o)||b(c)||m(c)||h(),[n])}else a=r?null:n;var i=r?y.onTabClose:y.onTabOpen;i&&i({originalEvent:e,index:n}),y.onTabChange?y.onTabChange({originalEvent:e,index:a}):S(a)}var c;e.preventDefault()},X=function(e,t,n){switch(e.code){case"ArrowDown":z(e);break;case"ArrowUp":B(e);break;case"Home":Y(e);break;case"End":q(e);break;case"Enter":case"NumpadEnter":case"Space":K(e,t,n)}},z=function(e){var t=V(e.target.parentElement.parentElement);t?L(t):Y(e),e.preventDefault()},B=function(e){var t=$(e.target.parentElement.parentElement);t?L(t):q(e),e.preventDefault()},Y=function(e){var t=F();L(t),e.preventDefault()},q=function(e){var t=G();L(t),e.preventDefault()},K=function(e,t,n){J(e,t,n),e.preventDefault()},V=function(e){var t=l.DomHandler.findSingle(arguments.length>1&&void 0!==arguments[1]&&arguments[1]?e:e.nextElementSibling,'[data-pc-section="header"]');return t?l.DomHandler.getAttribute(t,"data-p-disabled")?V(t.parentElement):l.DomHandler.findSingle(t,'[data-pc-section="headeraction"]'):null},$=function(e){var t=l.DomHandler.findSingle(arguments.length>1&&void 0!==arguments[1]&&arguments[1]?e:e.previousElementSibling,'[data-pc-section="header"]');return t?l.DomHandler.getAttribute(t,"data-p-disabled")?$(t.parentElement):l.DomHandler.findSingle(t,'[data-pc-section="headeraction"]'):null},F=function(){return V(N.current.firstElementChild,!0)},G=function(){return $(N.current.lastElementChild,!0)},L=function(e){e&&l.DomHandler.focus(e)},Q=function(e){return y.multiple&&Array.isArray(D)?D&&D.some((function(t){return t===e})):D===e};if(u.useImperativeHandle(t,(function(){return{props:y,getElement:function(){return N.current}}})),o.useMountEffect((function(){v||O(l.UniqueComponentId())})),!v)return null;var W=function(e,t,n){var r=w(w({},H(e,"style")||{}),H(e,"headerStyle")||{}),a=v+"_header_"+n,o=v+"_content_"+n,d=H(e,"disabled")?-1:H(e,"tabIndex"),p=s({className:U("accordiontab.headertitle")},R(e,"headertitle",n)),f=x.getCProps(e),b=H(e,"headerTemplate")?l.ObjectUtils.getJSXElement(H(e,"headerTemplate"),f):u.createElement("span",p,l.ObjectUtils.getJSXElement(H(e,"header"),f)),m=s({"aria-hidden":"true",className:U("accordiontab.headericon")},R(e,"headericon",n)),h=l.IconUtils.getJSXIcon(t?y.collapseIcon||u.createElement(i.ChevronDownIcon,m):y.expandIcon||u.createElement(c.ChevronRightIcon,m),w({},m),{props:y,selected:t}),g=s({className:l.classNames(H(e,"headerClassName"),H(e,"className"),U("accordiontab.header",{selected:t,getTabProp:H,tab:e})),style:r,"data-p-highlight":t,"data-p-disabled":H(e,"disabled")},R(e,"header",n)),O=s({id:a,href:"#"+o,className:U("accordiontab.headeraction"),role:"button",tabIndex:d,onClick:function(t){return M(t,e,n)},onKeyDown:function(t){return X(t,e,n)},"aria-disabled":H(e,"disabled"),"aria-controls":o,"aria-expanded":t},R(e,"headeraction",n));return u.createElement("div",g,u.createElement("a",O,h,b))},Z=function(e,t,n){var r=w(w({},H(e,"style")||{}),H(e,"contentStyle")||{}),o=v+"_content_"+n,i=v+"_header_"+n,c=u.createRef(),p=s({id:o,ref:c,className:l.classNames(H(e,"contentClassName"),H(e,"className"),U("accordiontab.toggleablecontent")),style:r,role:"region","aria-labelledby":i},R(e,"toggleablecontent",n)),f=s({className:U("accordiontab.content")},R(e,"content",n)),b=s({classNames:U("accordiontab.transition"),timeout:{enter:1e3,exit:450},in:t,unmountOnExit:!0,options:y.transitionOptions},R(e,"transition",n));return u.createElement(a.CSSTransition,d({nodeRef:c},b),u.createElement("div",p,u.createElement("div",f,H(e,"children"))))},ee=u.Children.map(y.children,(function(e,t){if(l.ObjectUtils.isValidChild(e,"AccordionTab")){var n=v+"_"+t,r=Q(t),a=W(e,r,t),o=Z(e,r,t),i=s({key:n,className:U("accordiontab.root",{selected:r})},x.getCOtherProps(e),R(e,"root",t));return u.createElement("div",i,a,o)}return null})),te=s({className:l.classNames(y.className,U("root")),style:y.style},j.getOtherProps(y),_("root"));return u.createElement("div",d({id:v,ref:N},te),ee)}));return D.displayName="AccordionTab",T.displayName="Accordion",e.Accordion=T,e.AccordionTab=D,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.componentbase,primereact.csstransition,primereact.hooks,primereact.icons.chevrondown,primereact.icons.chevronright,primereact.utils);