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) • 4.53 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.panel=function(e,t,n,l,r,a){"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 l=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,l.get?l:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var i=o(t);function c(){return c=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var l in n)Object.prototype.hasOwnProperty.call(n,l)&&(e[l]=n[l])}return e},c.apply(this,arguments)}function s(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 l,r,a,o,i=[],c=!0,s=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(l=a.call(n)).done)&&(i.push(l.value),i.length!==t);c=!0);}catch(e){s=!0,r=e}finally{try{if(!c&&null!=n.return&&(o=n.return(),Object(o)!==o))return}finally{if(s)throw r}}return i}}function u(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,l=new Array(t);n<t;n++)l[n]=e[n];return l}function d(e,t){if(e){if("string"==typeof e)return u(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)?u(e,t):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 f(e,t){return s(e)||p(e,t)||d(e,t)||g()}var m={defaultProps:{__TYPE:"Panel",id:null,header:null,headerTemplate:null,toggleable:null,style:null,className:null,collapsed:null,expandIcon:"pi pi-plus",collapseIcon:"pi pi-minus",icons:null,transitionOptions:null,onExpand:null,onCollapse:null,onToggle:null,children:void 0},getProps:function(e){return a.ObjectUtils.getMergedProps(e,m.defaultProps)},getOtherProps:function(e){return a.ObjectUtils.getDiffProps(e,m.defaultProps)}},b=i.forwardRef((function(e,t){var o=m.getProps(e),s=f(i.useState(o.id),2),p=s[0],u=s[1],d=f(i.useState(o.collapsed),2),g=d[0],b=d[1],h=i.useRef(t),v=i.useRef(null),y=!!o.toggleable&&(o.onToggle?o.collapsed:g),E=p+"_header",O=p+"_content",j=function(e){o.toggleable&&(y?N(e):P(e),o.onToggle&&o.onToggle({originalEvent:e,value:!y})),e.preventDefault()},N=function(e){o.onToggle||b(!1),o.onExpand&&o.onExpand(e)},P=function(e){o.onToggle||b(!0),o.onCollapse&&o.onCollapse(e)};i.useImperativeHandle(t,(function(){return{props:o,getElement:function(){return h.current},getContent:function(){return v.current}}})),i.useEffect((function(){a.ObjectUtils.combinedRefs(h,t)}),[h,t]),l.useMountEffect((function(){p||u(a.UniqueComponentId())}));var I=m.getOtherProps(o),C=a.classNames("p-panel p-component",{"p-panel-toggleable":o.toggleable},o.className),S=function(){var e=a.ObjectUtils.getJSXElement(o.header,o),t=a.ObjectUtils.getJSXElement(o.icons,o),n=o.toggleable?i.createElement("button",{className:"p-panel-header-icon p-panel-toggler p-link",onClick:j,id:p+"_label","aria-controls":O,"aria-expanded":!y,role:"tab"},a.IconUtils.getJSXIcon(y?o.expandIcon:o.collapseIcon,void 0,{props:o,collapsed:y}),i.createElement(r.Ripple,null)):null,l=i.createElement("span",{className:"p-panel-title",id:E},e),c=i.createElement("div",{className:"p-panel-icons"},t,n),s=i.createElement("div",{className:"p-panel-header"},l,c);return o.headerTemplate?a.ObjectUtils.getJSXElement(o.headerTemplate,{className:"p-panel-header",titleClassName:"p-panel-title",iconsClassName:"p-panel-icons",togglerClassName:"p-panel-header-icon p-panel-toggler p-link",togglerIconClassName:y?o.expandIcon:o.collapseIcon,onTogglerClick:j,titleElement:l,iconsElement:c,togglerElement:n,element:s,props:o,collapsed:y}):o.header||o.toggleable?s:null}(),T=i.createElement(n.CSSTransition,{nodeRef:v,classNames:"p-toggleable-content",timeout:{enter:1e3,exit:450},in:!y,unmountOnExit:!0,options:o.transitionOptions},i.createElement("div",{ref:v,className:"p-toggleable-content","aria-hidden":y,role:"region",id:O,"aria-labelledby":E},i.createElement("div",{className:"p-panel-content"},o.children)));return i.createElement("div",c({id:o.id,ref:h,className:C,style:o.style},I),S,T)}));return b.displayName="Panel",e.Panel=b,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.csstransition,primereact.hooks,primereact.ripple,primereact.utils);