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) • 2.7 kB
JavaScript
Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/ripple"),n=require("primereact/tooltip"),o=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 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 l=r(e);function c(){return c=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},c.apply(this,arguments)}var a={defaultProps:{__TYPE:"ToggleButton",id:null,onIcon:null,offIcon:null,onLabel:"Yes",offLabel:"No",iconPos:"left",style:null,className:null,checked:!1,tabIndex:0,tooltip:null,tooltipOptions:null,onChange:null,onFocus:null,onBlur:null,children:void 0},getProps:function(e){return o.ObjectUtils.getMergedProps(e,a.defaultProps)},getOtherProps:function(e){return o.ObjectUtils.getDiffProps(e,a.defaultProps)}},u=l.memo(l.forwardRef((function(e,r){var u=a.getProps(e),i=l.useRef(null),s=u.onLabel&&u.onLabel.length>0&&u.offLabel&&u.offLabel.length>0,p=u.onIcon&&u.onIcon.length>0&&u.offIcon&&u.offIcon.length>0,f=s?u.checked?u.onLabel:u.offLabel:" ",d=u.checked?u.onIcon:u.offIcon,b=function(e){!u.disabled&&u.onChange&&u.onChange({originalEvent:e,value:!u.checked,stopPropagation:function(){},preventDefault:function(){},target:{name:u.name,id:u.id,value:!u.checked}})};l.useImperativeHandle(r,(function(){return{props:u,focus:function(){return o.DomHandler.focusFirstElement(i.current)},getElement:function(){return i.current}}}));var g=o.ObjectUtils.isNotEmpty(u.tooltip),m=u.disabled?-1:u.tabIndex,h=a.getOtherProps(u),v=o.classNames("p-button p-togglebutton p-component",{"p-button-icon-only":p&&!s,"p-highlight":u.checked,"p-disabled":u.disabled},u.className),O=function(){if(p){var e=o.classNames("p-button-icon p-c",{"p-button-icon-left":"left"===u.iconPos&&f,"p-button-icon-right":"right"===u.iconPos&&f});return o.IconUtils.getJSXIcon(d,{className:e},{props:u})}return null}();return l.createElement(l.Fragment,null,l.createElement("div",c({ref:i,id:u.id,className:v,style:u.style},h,{onClick:b,onFocus:u.onFocus,onBlur:u.onBlur,onKeyDown:function(e){32===e.keyCode&&(b(e),e.preventDefault())},tabIndex:m,role:"button","aria-pressed":u.checked}),O,l.createElement("span",{className:"p-button-label"},f),l.createElement(t.Ripple,null)),g&&l.createElement(n.Tooltip,c({target:i,content:u.tooltip},u.tooltipOptions)))})));u.displayName="ToggleButton",exports.ToggleButton=u;
;