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