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