UNPKG

primereact

Version:

PrimeReact is an open source UI library for React featuring a rich set of 80+ 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) 3.46 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/tooltip"),n=require("primereact/utils");function r(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 l=r(e);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 r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},a.apply(this,arguments)}function u(e){if(Array.isArray(e))return e}function o(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,l,a=[],u=!0,o=!1;try{for(n=n.call(e);!(u=(r=n.next()).done)&&(a.push(r.value),!t||a.length!==t);u=!0);}catch(e){o=!0,l=e}finally{try{u||null==n.return||n.return()}finally{if(o)throw l}}return a}}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function c(e,t){if(e){if("string"==typeof e)return i(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)?i(e,t):void 0}}function s(){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 f=l.memo(l.forwardRef((function(e,r){var i,p,d=l.useState(!1),m=(p=2,u(i=d)||o(i,p)||c(i,p)||s()),b=m[0],h=m[1],y=l.useRef(null),v=l.useRef(e.inputRef),g=e.checked===e.trueValue,O=function(t){if(e.onChange){var n=g?e.falseValue:e.trueValue;e.onChange({originalEvent:t,value:n,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:n}})}};l.useImperativeHandle(r,(function(){return{props:e,getElement:function(){return y.current},getInput:function(){return y.current}}})),l.useEffect((function(){n.ObjectUtils.combinedRefs(v,e.inputRef)}),[v,e.inputRef]);var j=n.ObjectUtils.isNotEmpty(e.tooltip),w=n.ObjectUtils.findDiffKeys(e,f.defaultProps),I=n.ObjectUtils.reduceKeys(w,n.DomHandler.ARIA_PROPS),E=n.classNames("p-inputswitch p-component",{"p-inputswitch-checked":g,"p-disabled":e.disabled,"p-focus":b},e.className);return l.createElement(l.Fragment,null,l.createElement("div",a({ref:y,id:e.id,className:E,style:e.style},w,{onClick:function(t){e.disabled||(O(t),n.DomHandler.focus(v.current),t.preventDefault())},role:"checkbox","aria-checked":g}),l.createElement("div",{className:"p-hidden-accessible"},l.createElement("input",a({ref:v,type:"checkbox",id:e.inputId,name:e.name,checked:g,onChange:O,onFocus:function(t){h(!0),e.onFocus&&e.onFocus(t)},onBlur:function(t){h(!1),e.onBlur&&e.onBlur(t)},disabled:e.disabled,role:"switch",tabIndex:e.tabIndex,"aria-checked":g},I))),l.createElement("span",{className:"p-inputswitch-slider"})),j&&l.createElement(t.Tooltip,a({target:y,content:e.tooltip},e.tooltipOptions)))})));f.displayName="InputSwitch",f.defaultProps={__TYPE:"InputSwitch",checked:!1,className:null,disabled:!1,falseValue:!1,id:null,inputId:null,inputRef:null,name:null,onBlur:null,onChange:null,onFocus:null,style:null,tabIndex:null,tooltip:null,tooltipOptions:null,trueValue:!0},exports.InputSwitch=f;