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) • 5.47 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.fieldset=function(e,n,t,l,r,o,a,i,s,c){"use strict";function u(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 d=u(n);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)({}).hasOwnProperty.call(t,l)&&(e[l]=t[l])}return e},p.apply(null,arguments)}function g(e){if(Array.isArray(e))return e}function f(e,n){var t=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=t){var l,r,o,a,i=[],s=!0,c=!1;try{if(o=(t=t.call(e)).next,0===n){if(Object(t)!==t)return;s=!1}else for(;!(s=(l=o.call(t)).done)&&(i.push(l.value),i.length!==n);s=!0);}catch(e){c=!0,r=e}finally{try{if(!s&&null!=t.return&&(a=t.return(),Object(a)!==a))return}finally{if(c)throw r}}return i}}function m(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,l=Array(n);t<n;t++)l[t]=e[t];return l}function b(e,n){if(e){if("string"==typeof e)return m(e,n);var t={}.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)?m(e,n):void 0}}function v(){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 y(e,n){return g(e)||f(e,n)||b(e,n)||v()}var h=l.ComponentBase.extend({defaultProps:{__TYPE:"Fieldset",id:null,legend:null,className:null,style:null,toggleable:null,collapsed:null,collapseIcon:null,transitionOptions:null,expandIcon:null,onExpand:null,onCollapse:null,onToggle:null,onClick:null,children:void 0},css:{classes:{root:function(e){return c.classNames("p-fieldset p-component",{"p-fieldset-toggleable":e.props.toggleable})},toggleableContent:"p-toggleable-content",togglericon:"p-fieldset-toggler",legendTitle:"p-fieldset-legend-text",legend:"p-fieldset-legend p-unselectable-text",content:"p-fieldset-content",transition:"p-toggleable-content"},styles:"\n @layer primereact {\n .p-fieldset-legend > a,\n .p-fieldset-legend > span {\n display: flex;\n align-items: center;\n justify-content: center;\n }\n \n .p-fieldset-toggleable .p-fieldset-legend a {\n cursor: pointer;\n user-select: none;\n overflow: hidden;\n position: relative;\n text-decoration: none;\n }\n \n .p-fieldset-legend-text {\n line-height: 1;\n }\n }\n "}}),E=d.forwardRef((function(e,n){var u=o.useMergeProps(),g=d.useContext(t.PrimeReactContext),f=h.getProps(e,g),m=y(d.useState(f.id),2),b=m[0],v=m[1],E=y(d.useState(f.collapsed),2),x=E[1],C=!!f.toggleable&&(f.onToggle?f.collapsed:E[0]),O=d.useRef(null),I=d.useRef(null),j=b+"_header",N=b+"_content",S=h.setMetaData({props:f,state:{id:b,collapsed:C}}),T=S.ptm,P=S.cx;l.useHandleStyle(h.css.styles,S.isUnstyled,{name:"fieldset"});var w=function(e){f.toggleable&&(C?_(e):M(e),f.onToggle&&f.onToggle({originalEvent:e,value:!C})),e.preventDefault()},_=function(e){f.onToggle||x(!1),f.onExpand&&f.onExpand(e)},M=function(e){f.onToggle||x(!0),f.onCollapse&&f.onCollapse(e)};o.useMountEffect((function(){f.id||v(c.UniqueComponentId())}));var R=function(e){"Enter"!==e.code&&"NumpadEnter"!==e.code&&"Space"!==e.code||(w(e),e.preventDefault())},k=function(){if(f.toggleable){var e=u({className:P("togglericon")},T("togglericon"));return c.IconUtils.getJSXIcon(C?f.expandIcon||d.createElement(i.PlusIcon,e):f.collapseIcon||d.createElement(a.MinusIcon,e),e,{props:f})}return null},A=function(){var e=u({className:P("legendTitle")},T("legendTitle")),n=u({id:j,role:"button","aria-expanded":!C,"aria-controls":N,onKeyDown:R,onClick:w,"aria-label":f.legend,tabIndex:0},T("toggler"));if(f.toggleable){var t=k();return d.createElement("a",n,t,d.createElement("span",e,f.legend),d.createElement(s.Ripple,null))}return d.createElement("span",p({},e,{id:j}),f.legend)};d.useImperativeHandle(n,(function(){return{props:f,getElement:function(){return O.current},getContent:function(){return I.current}}}));var D,U,F,H=u({id:b,ref:O,style:f.style,className:c.classNames(f.className,P("root")),onClick:f.onClick},h.getOtherProps(f),T("root")),q=function(){var e=u({className:P("legend")},T("legend"));if(null!=f.legend||f.toggleable){var n=A();return d.createElement("legend",e,n)}}(),z=(D=u({className:P("content")},T("content")),U=u({ref:I,id:N,role:"region","aria-labelledby":j,className:P("toggleableContent")},T("toggleableContent")),F=u({classNames:P("transition"),timeout:{enter:1e3,exit:450},in:!C,unmountOnExit:!0,options:f.transitionOptions},T("transition")),d.createElement(r.CSSTransition,p({nodeRef:I},F),d.createElement("div",U,d.createElement("div",D,f.children))));return d.createElement("fieldset",H,q,z)}));return E.displayName="Fieldset",e.Fieldset=E,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.componentbase,primereact.csstransition,primereact.hooks,primereact.icons.minus,primereact.icons.plus,primereact.ripple,primereact.utils);