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) 4.28 kB
this.primereact=this.primereact||{},this.primereact.panel=function(e,n,t,l,a,r){"use strict";function o(e){if(e&&e.__esModule)return e;var n=Object.create(null);return e&&Object.keys(e).forEach((function(t){if("default"!==t){var l=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,l.get?l:{enumerable:!0,get:function(){return e[t]}})}})),n.default=e,Object.freeze(n)}var i=o(n);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 s(e){if(Array.isArray(e))return e}function p(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 d(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 f(){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 s(e)||p(e,n)||d(e,n)||f()}var m=i.forwardRef((function(e,n){var o=g(i.useState(e.id),2),s=o[0],p=o[1],u=g(i.useState(e.collapsed),2),d=u[0],f=u[1],b=i.useRef(n),h=i.useRef(null),y=!!e.toggleable&&(e.onToggle?e.collapsed:d),v=s+"_header",E=s+"_content",O=function(n){e.toggleable&&(y?j(n):N(n),e.onToggle&&e.onToggle({originalEvent:n,value:!y})),n.preventDefault()},j=function(n){e.onToggle||f(!1),e.onExpand&&e.onExpand(n)},N=function(n){e.onToggle||f(!0),e.onCollapse&&e.onCollapse(n)};i.useImperativeHandle(n,(function(){return{props:e,getElement:function(){return b.current},getContent:function(){return h.current}}})),i.useEffect((function(){r.ObjectUtils.combinedRefs(b,n)}),[b,n]),l.useMountEffect((function(){s||p(r.UniqueComponentId())}));var I=r.ObjectUtils.findDiffKeys(e,m.defaultProps),C=r.classNames("p-panel p-component",{"p-panel-toggleable":e.toggleable},e.className),S=function(){var n=r.ObjectUtils.getJSXElement(e.header,e),t=r.ObjectUtils.getJSXElement(e.icons,e),l=e.toggleable?i.createElement("button",{className:"p-panel-header-icon p-panel-toggler p-link",onClick:O,id:s+"_label","aria-controls":E,"aria-expanded":!y,role:"tab"},r.IconUtils.getJSXIcon(y?e.expandIcon:e.collapseIcon,void 0,{props:e,collapsed:y}),i.createElement(a.Ripple,null)):null,o=i.createElement("span",{className:"p-panel-title",id:v},n),c=i.createElement("div",{className:"p-panel-icons"},t,l),p=i.createElement("div",{className:"p-panel-header"},o,c);return e.headerTemplate?r.ObjectUtils.getJSXElement(e.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?e.expandIcon:e.collapseIcon,onTogglerClick:O,titleElement:o,iconsElement:c,togglerElement:l,element:p,props:e,collapsed:y}):e.header||e.toggleable?p:null}(),T=i.createElement(t.CSSTransition,{nodeRef:h,classNames:"p-toggleable-content",timeout:{enter:1e3,exit:450},in:!y,unmountOnExit:!0,options:e.transitionOptions},i.createElement("div",{ref:h,className:"p-toggleable-content","aria-hidden":y,role:"region",id:E,"aria-labelledby":v},i.createElement("div",{className:"p-panel-content"},e.children)));return i.createElement("div",c({id:e.id,ref:b,className:C,style:e.style},I),S,T)}));return m.displayName="Panel",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},e.Panel=m,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.csstransition,primereact.hooks,primereact.ripple,primereact.utils);