UNPKG

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) 6.01 kB
import*as e from"react";import{PrimeReactContext as t}from"primereact/api";import{ComponentBase as n,useHandleStyle as r}from"primereact/componentbase";import{useMergeProps as o,useUpdateEffect as l,useMountEffect as i}from"primereact/hooks";import{CheckIcon as u}from"primereact/icons/check";import{Tooltip as a}from"primereact/tooltip";import{classNames as c,DomHandler as s,ObjectUtils as p,IconUtils as f}from"primereact/utils";function d(){return d=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},d.apply(null,arguments)}function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function b(e,t){if("object"!=m(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=m(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function y(e){var t=b(e,"string");return"symbol"==m(t)?t:t+""}function v(e,t,n){return(t=y(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function h(e){if(Array.isArray(e))return e}function g(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,l,i,u=[],a=!0,c=!1;try{if(l=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;a=!1}else for(;!(a=(r=l.call(n)).done)&&(u.push(r.value),u.length!==t);a=!0);}catch(e){c=!0,o=e}finally{try{if(!a&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(c)throw o}}return u}}function O(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function x(e,t){if(e){if("string"==typeof e)return O(e,t);var n={}.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)?O(e,t):void 0}}function k(){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=n.extend({defaultProps:{__TYPE:"Checkbox",autoFocus:!1,checked:!1,className:null,disabled:!1,falseValue:!1,icon:null,id:null,inputId:null,inputRef:null,invalid:!1,variant:null,name:null,onChange:null,onContextMenu:null,onMouseDown:null,readOnly:!1,required:!1,style:null,tabIndex:null,tooltip:null,tooltipOptions:null,trueValue:!0,value:null,children:void 0},css:{classes:{box:"p-checkbox-box",input:"p-checkbox-input",icon:"p-checkbox-icon",root:function(e){var t=e.props,n=e.context;return c("p-checkbox p-component",{"p-highlight":e.checked,"p-disabled":t.disabled,"p-invalid":t.invalid,"p-variant-filled":t.variant?"filled"===t.variant:n&&"filled"===n.inputStyle})}}}});function j(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function S(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?j(Object(n),!0).forEach((function(t){v(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):j(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var w=e.memo(e.forwardRef((function(n,m){var b,y,v=o(),O=e.useContext(t),j=P.getProps(n,O),w=e.useState(!1),E=(y=2,h(b=w)||g(b,y)||x(b,y)||k()),I=E[1],C=P.setMetaData({props:j,state:{focused:E[0]},context:{checked:j.checked===j.trueValue,disabled:j.disabled}}),D=C.ptm,R=C.cx;r(P.css.styles,C.isUnstyled,{name:"checkbox"});var N=e.useRef(null),A=e.useRef(j.inputRef),M=function(){return j.checked===j.trueValue},V=function(e){if(!j.disabled&&!j.readOnly&&j.onChange){var t,n=M()?j.falseValue:j.trueValue;if(null==j||null===(t=j.onChange)||void 0===t||t.call(j,{originalEvent:e,value:j.value,checked:n,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{type:"checkbox",name:j.name,id:j.id,value:j.value,checked:n}}),e.defaultPrevented)return;s.focus(A.current)}};e.useImperativeHandle(m,(function(){return{props:j,focus:function(){return s.focus(A.current)},getElement:function(){return N.current},getInput:function(){return A.current}}})),e.useEffect((function(){p.combinedRefs(A,j.inputRef)}),[A,j.inputRef]),l((function(){A.current.checked=M()}),[j.checked,j.trueValue]),i((function(){j.autoFocus&&s.focus(A.current,j.autoFocus)}));var F,q,T,_,B,U=M(),H=p.isNotEmpty(j.tooltip),J=P.getOtherProps(j),K=v({id:j.id,className:c(j.className,R("root",{checked:U,context:O})),style:j.style,"data-p-highlight":U,"data-p-disabled":j.disabled,onContextMenu:j.onContextMenu,onMouseDown:j.onMouseDown},J,D("root"));return e.createElement(e.Fragment,null,e.createElement("div",d({ref:N},K),(_=p.reduceKeys(J,s.ARIA_PROPS),B=v(S({id:j.inputId,type:"checkbox",className:R("input"),name:j.name,tabIndex:j.tabIndex,onFocus:function(e){return t=e,I(!0),void(null==j||null===(n=j.onFocus)||void 0===n||n.call(j,t));var t,n},onBlur:function(e){return t=e,I(!1),void(null==j||null===(n=j.onBlur)||void 0===n||n.call(j,t));var t,n},onChange:function(e){return V(e)},disabled:j.disabled,readOnly:j.readOnly,required:j.required,"aria-invalid":j.invalid,checked:U},_),D("input")),e.createElement("input",d({ref:A},B))),(F=v({className:R("icon")},D("icon")),q=v({className:R("box",{checked:U}),"data-p-highlight":U,"data-p-disabled":j.disabled},D("box")),T=f.getJSXIcon(U?j.icon||e.createElement(u,F):null,S({},F),{props:j,checked:U}),e.createElement("div",q,T))),H&&e.createElement(a,d({target:N,content:j.tooltip,pt:D("tooltip")},j.tooltipOptions)))})));w.displayName="Checkbox";export{w as Checkbox};