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.15 kB
JavaScript
;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 o=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 i(e){if(Array.isArray(e))return e}function u(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,i,u=[],c=!0,l=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=a.call(n)).done)&&(u.push(r.value),u.length!==t);c=!0);}catch(e){l=!0,o=e}finally{try{if(!c&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(l)throw o}}return u}}function c(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 l(e,t){if(e){if("string"==typeof e)return c(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)?c(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 d={defaultProps:{__TYPE:"RadioButton",id:null,inputRef:null,inputId:null,name:null,value:null,checked:!1,style:null,className:null,disabled:!1,required:!1,tabIndex:null,tooltip:null,tooltipOptions:null,onChange:null,children:void 0},getProps:function(e){return n.ObjectUtils.getMergedProps(e,d.defaultProps)},getOtherProps:function(e){return n.ObjectUtils.getDiffProps(e,d.defaultProps)}},f=o.memo(o.forwardRef((function(e,r){var c,f,p=d.getProps(e),b=o.useState(!1),m=(f=2,i(c=b)||u(c,f)||l(c,f)||s()),h=m[0],v=m[1],g=o.useRef(null),y=o.useRef(p.inputRef),O=function(e){j(e)},j=function(e){if(!p.disabled&&p.onChange){var t=p.checked,r=e.target instanceof HTMLDivElement,o=e.target===y.current&&e.target.checked!==t,a=r&&n.DomHandler.hasClass(g.current,"p-radiobutton-checked")===t&&!t;if(o||a){var i=!t;p.onChange({originalEvent:e,value:p.value,checked:i,stopPropagation:function(){},preventDefault:function(){},target:{type:"radio",name:p.name,id:p.id,value:p.value,checked:i}}),a&&(y.current.checked=i)}n.DomHandler.focus(y.current),e.preventDefault()}};o.useEffect((function(){y.current&&(y.current.checked=p.checked)}),[p.checked]),o.useEffect((function(){n.ObjectUtils.combinedRefs(y,p.inputRef)}),[y,p.inputRef]),o.useImperativeHandle(r,(function(){return{props:p,select:O,focus:function(){return n.DomHandler.focus(y.current)},getElement:function(){return g.current},getInput:function(){return y.current}}}));var k=n.ObjectUtils.isNotEmpty(p.tooltip),P=d.getOtherProps(p),E=n.ObjectUtils.reduceKeys(P,n.DomHandler.ARIA_PROPS),R=n.classNames("p-radiobutton p-component",{"p-radiobutton-checked":p.checked,"p-radiobutton-disabled":p.disabled,"p-radiobutton-focused":h},p.className),I=n.classNames("p-radiobutton-box",{"p-highlight":p.checked,"p-disabled":p.disabled,"p-focus":h});return o.createElement(o.Fragment,null,o.createElement("div",a({ref:g,id:p.id,className:R,style:p.style},P,{onClick:j}),o.createElement("div",{className:"p-hidden-accessible"},o.createElement("input",a({ref:y,id:p.inputId,type:"radio",name:p.name,defaultChecked:p.checked,onFocus:function(){v(!0)},onBlur:function(){v(!1)},onKeyDown:function(e){"Space"!==e.code&&" "!==e.key||j(e)},disabled:p.disabled,required:p.required,tabIndex:p.tabIndex},E))),o.createElement("div",{className:I},o.createElement("div",{className:"p-radiobutton-icon"}))),k&&o.createElement(t.Tooltip,a({target:g,content:p.tooltip},p.tooltipOptions)))})));f.displayName="RadioButton",exports.RadioButton=f;