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