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.23 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.tristatecheckbox=function(e,t,r,n,o,a,c,l,i){"use strict";function u(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 s=u(t);function p(){return p=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},p.apply(this,arguments)}function f(e){return f="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},f(e)}function b(e,t){if("object"!==f(e)||null===e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var n=r.call(e,t||"default");if("object"!==f(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function d(e){var t=b(e,"string");return"symbol"===f(t)?t:String(t)}function m(e){if(Array.isArray(e))return e}function y(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,a,c,l=[],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)&&(l.push(n.value),l.length!==t);i=!0);}catch(e){u=!0,o=e}finally{try{if(!i&&null!=r.return&&(c=r.return(),Object(c)!==c))return}finally{if(u)throw o}}return l}}function v(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 h(e,t){if(e){if("string"==typeof e)return v(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)?v(e,t):void 0}}function O(){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:"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 i.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 j(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 k(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?j(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)):j(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var x=s.memo(s.forwardRef((function(e,u){var f,b,d=o.useMergeProps(),v=s.useContext(r.PrimeReactContext),j=g.getProps(e,v),x=t.useState(""),P=(b=2,m(f=x)||y(f,b)||h(f,b)||O()),S=P[0],E=P[1],I=s.useRef(null),w=g.setMetaData({props:j}),N=w.ptm,D=w.cx;n.useHandleStyle(g.css.styles,w.isUnstyled,{name:"tristatecheckbox"}),t.useEffect((function(){[!0,!1,""].includes(j.value)?E(j.value):E("")}),[j.value]);var C=function(e){var t;j.disabled||j.readOnly||(""===S?t=!0:!0===S?t=!1:!1===S&&(t=""),j.onChange&&j.onChange({originalEvent:e,value:t,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:j.name,id:j.id,value:t}}))};s.useImperativeHandle(u,(function(){return{props:j,focus:function(){return i.DomHandler.focusFirstElement(I.current)},getElement:function(){return I.current}}})),o.useMountEffect((function(){j.autoFocus&&i.DomHandler.focusFirstElement(I.current)}));var A,T=i.ObjectUtils.isNotEmpty(j.tooltip),F=g.getOtherProps(j),_=i.ObjectUtils.reduceKeys(F,i.DomHandler.ARIA_PROPS),M=d({className:D("checkIcon")},N("checkIcon")),R=d({className:D("checkIcon")},N("uncheckIcon"));!1===S?A=j.uncheckIcon||s.createElement(c.TimesIcon,R):!0===S&&(A=j.checkIcon||s.createElement(a.CheckIcon,M));var H=i.IconUtils.getJSXIcon(A,k({},M),{props:j}),U=r.ariaLabel(S?"trueLabel":!1===S?"falseLabel":"nullLabel"),L=S?"true":"false",B=d(k({className:D("box"),tabIndex:j.disabled?"-1":j.tabIndex,onFocus:function(e){var t;null==j||null===(t=j.onFocus)||void 0===t||t.call(j,e)},onBlur:function(e){var t;null==j||null===(t=j.onBlur)||void 0===t||t.call(j,e)},onKeyDown:function(e){"Enter"!==e.code&&"NumpadEnter"!==e.code&&"Space"!==e.code||(C(e),e.preventDefault())},role:"checkbox","aria-checked":L},_),N("box")),K=d({className:"p-sr-only p-hidden-accessible","aria-live":"polite"},N("srOnlyAria")),z=d({className:i.classNames(j.className,D("root",{context:v})),style:j.style,"data-p-disabled":j.disabled},g.getOtherProps(j),N("root")),J=d({id:j.inputId,className:D("input"),type:"checkbox","aria-invalid":j.invalid,disabled:j.disabled,readOnly:j.readOnly,value:S,checked:S,onChange:C},N("input"));return s.createElement(s.Fragment,null,s.createElement("div",p({id:j.id,ref:I},z),s.createElement("input",J),s.createElement("span",K,U),s.createElement("div",B,H)),T&&s.createElement(l.Tooltip,p({target:I,content:j.tooltip,pt:N("tooltip")},j.tooltipOptions)))})));return x.displayName="TriStateCheckbox",e.TriStateCheckbox=x,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.componentbase,primereact.hooks,primereact.icons.check,primereact.icons.times,primereact.tooltip,primereact.utils);