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.24 kB
JavaScript
Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),r=require("primereact/componentbase"),n=require("primereact/hooks"),o=require("primereact/icons/check"),a=require("primereact/icons/times"),l=require("primereact/tooltip"),c=require("primereact/utils");function i(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var u=i(e);function s(){return s=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},s.apply(this,arguments)}function p(e){return p="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},p(e)}function f(e,t){if("object"!==p(e)||null===e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var n=r.call(e,t||"default");if("object"!==p(n))return n;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"===p(t)?t:String(t)}function b(e){if(Array.isArray(e))return e}function m(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,a,l,c=[],i=!0,u=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;i=!1}else for(;!(i=(n=a.call(r)).done)&&(c.push(n.value),c.length!==t);i=!0);}catch(e){u=!0,o=e}finally{try{if(!i&&null!=r.return&&(l=r.return(),Object(l)!==l))return}finally{if(u)throw o}}return c}}function y(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}function v(e,t){if(e){if("string"==typeof e)return y(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?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 O=r.ComponentBase.extend({defaultProps:{__TYPE:"TriStateCheckbox",autoFocus:!1,checkIcon:null,className:null,disabled:!1,id:null,invalid:!1,variant:null,onChange:null,readOnly:!1,style:null,tabIndex:"0",tooltip:null,tooltipOptions:null,uncheckIcon:null,value:"",children:void 0},css:{classes:{root:function(e){var t=e.props,r=e.context;return c.classNames("p-tristatecheckbox p-checkbox p-component",{"p-highlight":""!==t.value&&null!==t.value,"p-disabled":t.disabled,"p-invalid":t.invalid,"p-variant-filled":t.variant?"filled"===t.variant:r&&"filled"===r.inputStyle})},checkIcon:"p-checkbox-icon p-c",box:"p-checkbox-box",input:"p-checkbox-input"}}});function g(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function j(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?g(Object(r),!0).forEach((function(t){var n,o,a;n=e,a=r[t],(o=d(o=t))in n?Object.defineProperty(n,o,{value:a,enumerable:!0,configurable:!0,writable:!0}):n[o]=a})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):g(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var k=u.memo(u.forwardRef((function(i,p){var f,d,y=n.useMergeProps(),g=u.useContext(t.PrimeReactContext),k=O.getProps(i,g),x=e.useState(""),P=(d=2,b(f=x)||m(f,d)||v(f,d)||h()),S=P[0],E=P[1],I=u.useRef(null),w=O.setMetaData({props:k}),N=w.ptm,D=w.cx;r.useHandleStyle(O.css.styles,w.isUnstyled,{name:"tristatecheckbox"}),e.useEffect((function(){[!0,!1,""].includes(k.value)?E(k.value):E("")}),[k.value]);var C=function(e){var t;k.disabled||k.readOnly||(""===S?t=!0:!0===S?t=!1:!1===S&&(t=""),k.onChange&&k.onChange({originalEvent:e,value:t,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:k.name,id:k.id,value:t}}))};u.useImperativeHandle(p,(function(){return{props:k,focus:function(){return c.DomHandler.focusFirstElement(I.current)},getElement:function(){return I.current}}})),n.useMountEffect((function(){k.autoFocus&&c.DomHandler.focusFirstElement(I.current)}));var A,q=c.ObjectUtils.isNotEmpty(k.tooltip),T=O.getOtherProps(k),F=c.ObjectUtils.reduceKeys(T,c.DomHandler.ARIA_PROPS),_=y({className:D("checkIcon")},N("checkIcon")),M=y({className:D("checkIcon")},N("uncheckIcon"));!1===S?A=k.uncheckIcon||u.createElement(a.TimesIcon,M):!0===S&&(A=k.checkIcon||u.createElement(o.CheckIcon,_));var H=c.IconUtils.getJSXIcon(A,j({},_),{props:k}),R=t.ariaLabel(S?"trueLabel":!1===S?"falseLabel":"nullLabel"),U=S?"true":"false",L=y(j({className:D("box"),tabIndex:k.disabled?"-1":k.tabIndex,onFocus:function(e){var t;null==k||null===(t=k.onFocus)||void 0===t||t.call(k,e)},onBlur:function(e){var t;null==k||null===(t=k.onBlur)||void 0===t||t.call(k,e)},onKeyDown:function(e){"Enter"!==e.code&&"NumpadEnter"!==e.code&&"Space"!==e.code||(C(e),e.preventDefault())},role:"checkbox","aria-checked":U},F),N("box")),B=y({className:"p-sr-only p-hidden-accessible","aria-live":"polite"},N("srOnlyAria")),K=y({className:c.classNames(k.className,D("root",{context:g})),style:k.style,"data-p-disabled":k.disabled},O.getOtherProps(k),N("root")),z=y({id:k.inputId,className:D("input"),type:"checkbox","aria-invalid":k.invalid,disabled:k.disabled,readOnly:k.readOnly,value:S,checked:S,onChange:C},N("input"));return u.createElement(u.Fragment,null,u.createElement("div",s({id:k.id,ref:I},K),u.createElement("input",z),u.createElement("span",B,R),u.createElement("div",L,H)),q&&u.createElement(l.Tooltip,s({target:I,content:k.tooltip,pt:N("tooltip")},k.tooltipOptions)))})));k.displayName="TriStateCheckbox",exports.TriStateCheckbox=k;
;