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.13 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 d(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 b(e){var t=d(e,"string");return"symbol"===p(t)?t:String(t)}var f=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,r=e.context;return c.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:r&&"filled"===r.inputStyle})},checkIcon:"p-checkbox-icon p-c",box:"p-checkbox-box",input:"p-checkbox-input"}}});function m(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 v(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?m(Object(r),!0).forEach((function(t){var n,o,a;n=e,a=r[t],(o=b(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)):m(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var y=u.memo(u.forwardRef((function(e,i){var p=n.useMergeProps(),d=u.useContext(t.PrimeReactContext),b=f.getProps(e,d),m=u.useRef(null),y=f.setMetaData({props:b}),h=y.ptm,O=y.cx;r.useHandleStyle(f.css.styles,y.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}}))};u.useImperativeHandle(i,(function(){return{props:b,focus:function(){return c.DomHandler.focusFirstElement(m.current)},getElement:function(){return m.current}}})),n.useMountEffect((function(){b.autoFocus&&c.DomHandler.focusFirstElement(m.current)}));var k,x=c.ObjectUtils.isNotEmpty(b.tooltip),P=f.getOtherProps(b),j=c.ObjectUtils.reduceKeys(P,c.DomHandler.ARIA_PROPS),E=p({className:O("checkIcon")},h("checkIcon")),I=p({className:O("checkIcon")},h("uncheckIcon"));!1===b.value?k=b.uncheckIcon||u.createElement(a.TimesIcon,I):!0===b.value&&(k=b.checkIcon||u.createElement(o.CheckIcon,E));var S=c.IconUtils.getJSXIcon(k,v({},E),{props:b}),N=t.ariaLabel(b.value?"trueLabel":!1===b.value?"falseLabel":"nullLabel"),w=b.value?"true":"false",D=p(v({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},j),h("box")),C=p({className:"p-sr-only p-hidden-accessible","aria-live":"polite"},h("srOnlyAria")),q=p({className:c.classNames(b.className,O("root",{context:d})),style:b.style,"data-p-disabled":b.disabled},f.getOtherProps(b),h("root")),F=p({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 u.createElement(u.Fragment,null,u.createElement("div",s({id:b.id,ref:m},q),u.createElement("input",F),u.createElement("span",C,N),u.createElement("div",D,S)),x&&u.createElement(l.Tooltip,s({target:m,content:b.tooltip,pt:h("tooltip")},b.tooltipOptions)))})));y.displayName="TriStateCheckbox",exports.TriStateCheckbox=y;
;