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