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.37 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.checkbox=function(e,t,n,r,o){"use strict";function c(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var l=c(t);function a(){return a=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},a.apply(this,arguments)}function u(e){if(Array.isArray(e))return e}function i(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,c,l,a=[],u=!0,i=!1;try{if(c=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;u=!1}else for(;!(u=(r=c.call(n)).done)&&(a.push(r.value),a.length!==t);u=!0);}catch(e){i=!0,o=e}finally{try{if(!u&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(i)throw o}}return a}}function s(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function f(e,t){if(e){if("string"==typeof e)return s(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)?s(e,t):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.")}var p={defaultProps:{__TYPE:"Checkbox",id:null,inputRef:null,inputId:null,value:null,name:null,checked:!1,trueValue:!0,falseValue:!1,style:null,className:null,disabled:!1,required:!1,readOnly:!1,tabIndex:null,icon:"pi pi-check",tooltip:null,tooltipOptions:null,onChange:null,onMouseDown:null,onContextMenu:null,children:void 0},getProps:function(e){return o.ObjectUtils.getMergedProps(e,p.defaultProps)},getOtherProps:function(e){return o.ObjectUtils.getDiffProps(e,p.defaultProps)}},b=l.memo(l.forwardRef((function(e,t){var c,s,b=p.getProps(e),h=l.useState(!1),m=(s=2,u(c=h)||i(c,s)||f(c,s)||d()),y=m[0],g=m[1],v=l.useRef(null),O=l.useRef(b.inputRef),k=function(e){if(!b.disabled&&!b.readOnly&&b.onChange){var t=x(),n=e.target instanceof HTMLDivElement||e.target instanceof HTMLSpanElement;if(e.target===O.current||n&&e.target.checked!==t){var r=t?b.falseValue:b.trueValue;b.onChange({originalEvent:e,value:b.value,checked:r,stopPropagation:function(){},preventDefault:function(){},target:{type:"checkbox",name:b.name,id:b.id,value:b.value,checked:r}})}o.DomHandler.focus(O.current),e.preventDefault()}},x=function(){return b.checked===b.trueValue};l.useImperativeHandle(t,(function(){return{props:b,focus:function(){return o.DomHandler.focus(O.current)},getElement:function(){return v.current},getInput:function(){return O.current}}})),l.useEffect((function(){o.ObjectUtils.combinedRefs(O,b.inputRef)}),[O,b.inputRef]),n.useUpdateEffect((function(){O.current.checked=x()}),[b.checked,b.trueValue]);var j=x(),P=o.ObjectUtils.isNotEmpty(b.tooltip),E=p.getOtherProps(b),I=o.ObjectUtils.reduceKeys(E,o.DomHandler.ARIA_PROPS),C=o.classNames("p-checkbox p-component",{"p-checkbox-checked":j,"p-checkbox-disabled":b.disabled,"p-checkbox-focused":y},b.className),D=o.classNames("p-checkbox-box",{"p-highlight":j,"p-disabled":b.disabled,"p-focus":y}),M=o.IconUtils.getJSXIcon(j?b.icon:"",{className:"p-checkbox-icon p-c"},{props:b,checked:j});return l.createElement(l.Fragment,null,l.createElement("div",a({ref:v,id:b.id,className:C,style:b.style},E,{onClick:k,onContextMenu:b.onContextMenu,onMouseDown:b.onMouseDown}),l.createElement("div",{className:"p-hidden-accessible"},l.createElement("input",a({ref:O,type:"checkbox",id:b.inputId,name:b.name,tabIndex:b.tabIndex,defaultChecked:j,onFocus:function(){g(!0)},onBlur:function(){g(!1)},onKeyDown:function(e){"Space"!==e.code&&" "!==e.key||k(e)},disabled:b.disabled,readOnly:b.readOnly,required:b.required},I))),l.createElement("div",{className:D},M)),P&&l.createElement(r.Tooltip,a({target:v,content:b.tooltip},b.tooltipOptions)))})));return b.displayName="Checkbox",e.Checkbox=b,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.hooks,primereact.tooltip,primereact.utils);