UNPKG

primereact

Version:

PrimeReact is an open source UI library for React featuring a rich set of 80+ 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) 3.89 kB
import*as e from"react";import{CSSTransition as n}from"primereact/csstransition";import{useMountEffect as t}from"primereact/hooks";import{Ripple as l}from"primereact/ripple";import{ObjectUtils as a,UniqueComponentId as r,classNames as o,IconUtils as i}from"primereact/utils";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 l in t)Object.prototype.hasOwnProperty.call(t,l)&&(e[l]=t[l])}return e},c.apply(this,arguments)}function p(e){if(Array.isArray(e))return e}function s(e,n){var t=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=t){var l,a,r=[],o=!0,i=!1;try{for(t=t.call(e);!(o=(l=t.next()).done)&&(r.push(l.value),!n||r.length!==n);o=!0);}catch(e){i=!0,a=e}finally{try{o||null==t.return||t.return()}finally{if(i)throw a}}return r}}function u(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,l=new Array(n);t<n;t++)l[t]=e[t];return l}function m(e,n){if(e){if("string"==typeof e)return u(e,n);var t=Object.prototype.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)?u(e,n):void 0}}function d(){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 g(e,n){return p(e)||s(e,n)||m(e,n)||d()}var f=e.forwardRef((function(p,s){var u=g(e.useState(p.id),2),m=u[0],d=u[1],b=g(e.useState(p.collapsed),2),h=b[0],y=b[1],v=e.useRef(s),E=e.useRef(null),N=!!p.toggleable&&(p.onToggle?p.collapsed:h),I=m+"_header",T=m+"_content",x=function(e){p.toggleable&&(N?C(e):S(e),p.onToggle&&p.onToggle({originalEvent:e,value:!N})),e.preventDefault()},C=function(e){p.onToggle||y(!1),p.onExpand&&p.onExpand(e)},S=function(e){p.onToggle||y(!0),p.onCollapse&&p.onCollapse(e)};e.useImperativeHandle(s,(function(){return{props:p,getElement:function(){return v.current},getContent:function(){return E.current}}})),e.useEffect((function(){a.combinedRefs(v,s)}),[v,s]),t((function(){m||d(r())}));var O=a.findDiffKeys(p,f.defaultProps),j=o("p-panel p-component",{"p-panel-toggleable":p.toggleable},p.className),w=function(){var n=a.getJSXElement(p.header,p),t=a.getJSXElement(p.icons,p),r=p.toggleable?e.createElement("button",{className:"p-panel-header-icon p-panel-toggler p-link",onClick:x,id:m+"_label","aria-controls":T,"aria-expanded":!N,role:"tab"},i.getJSXIcon(N?p.expandIcon:p.collapseIcon,void 0,{props:p,collapsed:N}),e.createElement(l,null)):null,o=e.createElement("span",{className:"p-panel-title",id:I},n),c=e.createElement("div",{className:"p-panel-icons"},t,r),s=e.createElement("div",{className:"p-panel-header"},o,c);return p.headerTemplate?a.getJSXElement(p.headerTemplate,{className:"p-panel-header",titleClassName:"p-panel-title",iconsClassName:"p-panel-icons",togglerClassName:"p-panel-header-icon p-panel-toggler p-link",togglerIconClassName:N?p.expandIcon:p.collapseIcon,onTogglerClick:x,titleElement:o,iconsElement:c,togglerElement:r,element:s,props:p,collapsed:N}):p.header||p.toggleable?s:null}(),A=e.createElement(n,{nodeRef:E,classNames:"p-toggleable-content",timeout:{enter:1e3,exit:450},in:!N,unmountOnExit:!0,options:p.transitionOptions},e.createElement("div",{ref:E,className:"p-toggleable-content","aria-hidden":N,role:"region",id:T,"aria-labelledby":I},e.createElement("div",{className:"p-panel-content"},p.children)));return e.createElement("div",c({id:p.id,ref:v,className:j,style:p.style},O),w,A)}));f.displayName="Panel",f.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};export{f as Panel};