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) • 4.68 kB
JavaScript
import*as e from"react";import{ariaLabel as t}from"primereact/api";import{useMountEffect as n}from"primereact/hooks";import{Tooltip as o}from"primereact/tooltip";import{ObjectUtils as r,DomHandler as l,classNames as i}from"primereact/utils";function a(){return a=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},a.apply(this,arguments)}function u(e){return u="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},u(e)}function c(e,t){if("object"!==u(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var o=n.call(e,t||"default");if("object"!==u(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function p(e){var t=c(e,"string");return"symbol"===u(t)?t:String(t)}function s(e){if(Array.isArray(e))return e}function f(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var o,r,l,i,a=[],u=!0,c=!1;try{if(l=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;u=!1}else for(;!(u=(o=l.call(n)).done)&&(a.push(o.value),a.length!==t);u=!0);}catch(e){c=!0,r=e}finally{try{if(!u&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(c)throw r}}return a}}function m(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,o=new Array(t);n<t;n++)o[n]=e[n];return o}function d(e,t){if(e){if("string"==typeof e)return m(e,t);var n=Object.prototype.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)?m(e,t):void 0}}function y(){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 b={defaultProps:{__TYPE:"MultiStateCheckbox",id:null,value:null,options:null,optionValue:null,optionLabel:null,optionIcon:null,iconTemplate:null,dataKey:null,style:null,className:null,disabled:!1,readOnly:!1,empty:!0,tabIndex:"0",tooltip:null,tooltipOptions:null,onChange:null,children:void 0},getProps:function(e){return r.getMergedProps(e,b.defaultProps)},getOtherProps:function(e){return r.getDiffProps(e,b.defaultProps)}},v=e.memo(e.forwardRef((function(u,c){var m,v,g=b.getProps(u),h=e.useState(!1),S=(v=2,s(m=h)||f(m,v)||d(m,v)||y()),x=S[0],P=S[1],O=e.useRef(null),E=g.optionValue?null:g.dataKey,k=function(e){return g.optionValue?r.resolveFieldData(e,g.optionValue):e},j=function(e){if(g.onChange){var t=k(g.options?C===g.options.length-1?g.empty?null:g.options[0]:g.options[C+1]:null);g.onChange({originalEvent:e,value:t,stopPropagation:function(){},preventDefault:function(){},target:{name:g.name,id:g.id,value:t}})}};e.useImperativeHandle(c,(function(){return{props:g,focus:function(){return l.focusFirstElement(O.current)},getElement:function(){return O.current}}})),n((function(){g.empty||null!==g.value||j()}));var I,N,w=(g.options&&(N=g.options.findIndex((function(e){return r.equals(g.value,k(e),E)})),I=g.options[N]),{option:I,index:N}),A=w.option,C=w.index,D=r.isNotEmpty(g.tooltip),F=b.getOtherProps(g),T=r.reduceKeys(F,l.ARIA_PROPS),V=i("p-multistatecheckbox p-checkbox p-component",g.className,{"p-checkbox-disabled":g.disabled}),K=i("p-checkbox-box",{"p-highlight":!!A,"p-disabled":g.disabled,"p-focus":x},A&&A.className),M=function(){var t,n,o,l=A&&r.resolveFieldData(A,g.optionIcon||"icon")||"",a=i("p-checkbox-icon p-c",(t={},n="".concat(l),o=!0,(n=p(n))in t?Object.defineProperty(t,n,{value:o,enumerable:!0,configurable:!0,writable:!0}):t[n]=o,t)),u=e.createElement("span",{className:a});return g.iconTemplate?r.getJSXElement(g.iconTemplate,{option:A,className:a,element:u,props:g}):u}(),R=A?function(e){var t=g.optionLabel||g.optionValue;return t?r.resolveFieldData(e,t):e}(A):t("nullLabel"),L=A?"true":"false";return e.createElement(e.Fragment,null,e.createElement("div",a({ref:O,id:g.id,className:V,style:g.style},F,{onClick:function(e){g.disabled||g.readOnly||j(e)}}),e.createElement("div",a({className:K,style:A&&A.style,tabIndex:g.tabIndex,onFocus:function(){P(!0)},onBlur:function(){P(!1)},onKeyDown:function(e){32===e.keyCode&&(j(e),e.preventDefault())},role:"checkbox","aria-checked":L},T),M),x&&e.createElement("span",{className:"p-sr-only","aria-live":"polite"},R)),D&&e.createElement(o,a({target:O,content:g.tooltip},g.tooltipOptions)))})));v.displayName="MultiStateCheckbox";export{v as MultiStateCheckbox};