UNPKG

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) 9.78 kB
import*as e from"react";import{PrimeReactContext as t,ariaLabel as n}from"primereact/api";import{ComponentBase as o,useHandleStyle as r}from"primereact/componentbase";import{useMergeProps as l,useUpdateEffect as i,useMountEffect as a}from"primereact/hooks";import{CheckIcon as c}from"primereact/icons/check";import{Tooltip as u}from"primereact/tooltip";import{classNames as s,DomHandler as p,ObjectUtils as d,IconUtils as f,UniqueComponentId as m}from"primereact/utils";function b(){return b=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)({}).hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},b.apply(null,arguments)}function v(e){return v="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},v(e)}function y(e,t){if("object"!=v(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var o=n.call(e,t||"default");if("object"!=v(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function h(e){var t=y(e,"string");return"symbol"==v(t)?t:t+""}function g(e,t,n){return(t=h(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function O(e){if(Array.isArray(e))return e}function x(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var o,r,l,i,a=[],c=!0,u=!1;try{if(l=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(o=l.call(n)).done)&&(a.push(o.value),a.length!==t);c=!0);}catch(e){u=!0,r=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(u)throw r}}return a}}function k(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,o=Array(t);n<t;n++)o[n]=e[n];return o}function P(e,t){if(e){if("string"==typeof e)return k(e,t);var n={}.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)?k(e,t):void 0}}function j(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function E(e,t){return O(e)||x(e,t)||P(e,t)||j()}var S=o.extend({defaultProps:{__TYPE:"Checkbox",autoFocus:!1,checked:!1,className:null,disabled:!1,falseValue:!1,icon:null,id:null,inputId:null,inputRef:null,invalid:!1,variant:null,name:null,onChange:null,onContextMenu:null,onMouseDown:null,readOnly:!1,required:!1,style:null,tabIndex:null,tooltip:null,tooltipOptions:null,trueValue:!0,value:null,children:void 0},css:{classes:{box:"p-checkbox-box",input:"p-checkbox-input",icon:"p-checkbox-icon",root:function(e){var t=e.props,n=e.context;return s("p-checkbox p-component",{"p-highlight":e.checked,"p-disabled":t.disabled,"p-invalid":t.invalid,"p-variant-filled":t.variant?"filled"===t.variant:n&&"filled"===n.inputStyle})}}}});function w(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,o)}return n}function I(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?w(Object(n),!0).forEach(function(t){g(e,t,n[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):w(Object(n)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))})}return e}var D=e.memo(e.forwardRef(function(n,o){var m=l(),v=e.useContext(t),y=S.getProps(n,v),h=E(e.useState(!1),2),g=h[1],O=S.setMetaData({props:y,state:{focused:h[0]},context:{checked:y.checked===y.trueValue,disabled:y.disabled}}),x=O.ptm,k=O.cx;r(S.css.styles,O.isUnstyled,{name:"checkbox"});var P=e.useRef(null),j=e.useRef(y.inputRef),w=function(){return y.checked===y.trueValue},D=function(e){if(!y.disabled&&!y.readOnly&&y.onChange){var t,n=w()?y.falseValue:y.trueValue;if(null==y||null===(t=y.onChange)||void 0===t||t.call(y,{originalEvent:e,value:y.value,checked:n,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{type:"checkbox",name:y.name,id:y.id,value:y.value,checked:n}}),e.defaultPrevented)return;p.focus(j.current)}};e.useImperativeHandle(o,function(){return{props:y,focus:function(){return p.focus(j.current)},getElement:function(){return P.current},getInput:function(){return j.current}}}),e.useEffect(function(){d.combinedRefs(j,y.inputRef)},[j,y.inputRef]),i(function(){j.current.checked=w()},[y.checked,y.trueValue]),a(function(){y.autoFocus&&p.focus(j.current,y.autoFocus)});var C,N,F,R,M,V=w(),A=d.isNotEmpty(y.tooltip),_=S.getOtherProps(y),T=m({id:y.id,className:s(y.className,k("root",{checked:V,context:v})),style:y.style,"data-p-highlight":V,"data-p-disabled":y.disabled,onContextMenu:y.onContextMenu,onMouseDown:y.onMouseDown},_,x("root"));return e.createElement(e.Fragment,null,e.createElement("div",b({ref:P},T),(R=d.reduceKeys(_,p.ARIA_PROPS),M=m(I({id:y.inputId,type:"checkbox",className:k("input"),name:y.name,tabIndex:y.tabIndex,onFocus:function(e){return t=e,g(!0),void(null==y||null===(n=y.onFocus)||void 0===n||n.call(y,t));var t,n},onBlur:function(e){return t=e,g(!1),void(null==y||null===(n=y.onBlur)||void 0===n||n.call(y,t));var t,n},onChange:function(e){return D(e)},disabled:y.disabled,readOnly:y.readOnly,required:y.required,"aria-invalid":y.invalid,checked:V},R),x("input")),e.createElement("input",b({ref:j},M))),(C=m({className:k("icon")},x("icon")),N=m({className:k("box",{checked:V}),"data-p-highlight":V,"data-p-disabled":y.disabled},x("box")),F=f.getJSXIcon(V?y.icon||e.createElement(c,C):null,I({},C),{props:y,checked:V}),e.createElement("div",N,F))),A&&e.createElement(u,b({target:P,content:y.tooltip,pt:x("tooltip")},y.tooltipOptions)))}));D.displayName="Checkbox";var C=o.extend({defaultProps:{__TYPE:"MultiStateCheckbox",autoFocus:!1,className:null,dataKey:null,disabled:!1,empty:!0,iconTemplate:null,id:null,onChange:null,optionIcon:null,optionLabel:null,optionValue:null,options:null,readOnly:!1,style:null,tabIndex:"0",tooltip:null,tooltipOptions:null,value:null,children:void 0,invalid:!1,variant:null},css:{classes:{icon:function(e){return s("p-checkbox-icon p-c",g({},"".concat(e.icon),!0))},root:function(e){var t=e.props;return s("p-multistatecheckbox p-checkbox p-component",t.classNames,{"p-variant-filled":"filled"===t.variant})},checkbox:function(e){var t=e.props;return s(t.className,{"p-invalid":t.invalid})}},inlineStyles:{checkbox:function(e){var t=e.selectedOption;return t&&t.style}}}});function N(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,o)}return n}function F(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?N(Object(n),!0).forEach(function(t){g(e,t,n[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):N(Object(n)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))})}return e}var R=e.memo(e.forwardRef(function(o,i){var c=l(),v=e.useContext(t),y=C.getProps(o,v),h=E(e.useState(!1),2),O=h[0],x=h[1],k=e.useRef(null),P=y.optionValue?null:y.dataKey,j=C.setMetaData({props:y,state:{focused:O}}),S=j.ptm,w=j.cx,I=j.sx;r(C.css.styles,j.isUnstyled,{name:"multistatecheckbox"});var N=function(e){y.disabled||y.readOnly||M(e)},R=function(e){return y.optionValue?d.resolveFieldData(e,y.optionValue):e},M=function(e){if(y.onChange){var t=R(y.options?K===y.options.length-1?y.empty?null:y.options[0]:y.options[K+1]:null);y.onChange({originalEvent:e,value:t,stopPropagation:function(){null==e||e.stopPropagation()},preventDefault:function(){null==e||e.preventDefault()},target:{name:y.name,id:y.id,value:t}})}};e.useImperativeHandle(i,function(){return{props:y,focus:function(){return p.focusFirstElement(k.current)},getElement:function(){return k.current}}}),a(function(){y.empty||null!==y.value||M(),y.autoFocus&&p.focusFirstElement(k.current)});var V,A,_=(y.options&&(A=y.options.findIndex(function(e){return d.equals(y.value,R(e),P)}),V=y.options[A]),{option:V,index:A}),T=_.option,K=_.index,q=d.isNotEmpty(y.tooltip),B=C.getOtherProps(y),J=d.reduceKeys(B,p.ARIA_PROPS),L=function(){var e=T&&d.resolveFieldData(T,y.optionIcon||"icon")||"",t=s("p-checkbox-icon p-c",g({},"".concat(e),!0)),n=c({className:w("icon",{icon:e})},S("icon")),o=f.getJSXIcon(e,F({},n),{props:y});return y.iconTemplate?d.getJSXElement(y.iconTemplate,{option:T,className:t,element:o,props:y}):o}(),U=T?function(e){var t=y.optionLabel||y.optionValue;return t?d.resolveFieldData(e,t):e}(T):n("nullLabel"),X=c({ref:k,id:y.id,className:s(y.className,w("root")),style:y.style,onClick:N},C.getOtherProps(y),S("root")),H=e.useMemo(function(){return y.id||m()},[y.id]),Y=c(F({id:H+"_checkbox",inputId:y.inputId||H+"_multistatecheckbox",className:w("checkbox"),style:I("checkbox",{selectedOption:T}),tabIndex:y.tabIndex,onFocus:function(){x(!0)},onBlur:function(){x(!1)},onKeyDown:function(e){32===e.keyCode&&(M(e),e.preventDefault())},onChange:N,checked:!!T,disabled:null==y?void 0:y.disabled,icon:L},J),S("checkbox")),$=c({className:"p-hidden-accessible","aria-live":"polite"},S("srOnlyAria"));return e.createElement(e.Fragment,null,e.createElement("div",X,e.createElement(D,Y),O&&e.createElement("span",$,U)),q&&e.createElement(u,b({target:k,content:y.tooltip,pt:S("tooltip")},y.tooltipOptions)))}));R.displayName="MultiStateCheckbox";export{R as MultiStateCheckbox};