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) • 5.24 kB
JavaScript
this.primereact=this.primereact||{},this.primereact.selectbutton=function(e,t,n,l,r){"use strict";function o(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var l=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,l.get?l:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var a=o(t);function i(){return i=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var l in n)Object.prototype.hasOwnProperty.call(n,l)&&(e[l]=n[l])}return e},i.apply(this,arguments)}function u(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,l=new Array(t);n<t;n++)l[n]=e[n];return l}function c(e){if(Array.isArray(e))return u(e)}function s(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function p(e,t){if(e){if("string"==typeof e)return u(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)?u(e,t):void 0}}function f(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function d(e){return c(e)||s(e)||p(e)||f()}var b={defaultProps:{__TYPE:"SelectButton",id:null,value:null,options:null,optionLabel:null,optionValue:null,optionDisabled:null,tabIndex:null,multiple:!1,unselectable:!0,disabled:!1,style:null,className:null,dataKey:null,tooltip:null,tooltipOptions:null,itemTemplate:null,onChange:null,children:void 0},getProps:function(e){return l.ObjectUtils.getMergedProps(e,b.defaultProps)},getOtherProps:function(e){return l.ObjectUtils.getDiffProps(e,b.defaultProps)}};function m(e){if(Array.isArray(e))return e}function v(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var l,r,o,a,i=[],u=!0,c=!1;try{if(o=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;u=!1}else for(;!(u=(l=o.call(n)).done)&&(i.push(l.value),i.length!==t);u=!0);}catch(e){c=!0,r=e}finally{try{if(!u&&null!=n.return&&(a=n.return(),Object(a)!==a))return}finally{if(c)throw r}}return i}}function y(){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 g=a.memo((function(e){var t,n,o=a.useState(!1),i=(n=2,m(t=o)||v(t,n)||p(t,n)||y()),u=i[1],c=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option})},s=l.classNames("p-button p-component",{"p-highlight":e.selected,"p-disabled":e.disabled,"p-focus":i[0]},e.className),f=e.template?l.ObjectUtils.getJSXElement(e.template,e.option):a.createElement("span",{className:"p-button-label p-c"},e.label);return a.createElement("div",{className:s,role:"button","aria-label":e.label,"aria-pressed":e.selected,onClick:c,onKeyDown:function(e){32===e.which&&(c(e),e.preventDefault())},tabIndex:e.tabIndex,onFocus:function(){u(!0)},onBlur:function(){u(!1)}},f,!e.disabled&&a.createElement(r.Ripple,null))}));g.displayName="SelectButtonItem";var h=a.memo(a.forwardRef((function(e,t){var r=b.getProps(e),o=a.useRef(null),u=function(e){if(!r.disabled&&!p(e.option)){var t=f(e.option);if(!t||r.unselectable){var n,o=s(e.option);if(r.multiple){var a=r.value?d(r.value):[];n=t?a.filter((function(e){return!l.ObjectUtils.equals(e,o,r.dataKey)})):[].concat(d(a),[o])}else n=t?null:o;r.onChange&&r.onChange({originalEvent:e.originalEvent,value:n,stopPropagation:function(){},preventDefault:function(){},target:{name:r.name,id:r.id,value:n}})}}},c=function(e){return r.optionLabel?l.ObjectUtils.resolveFieldData(e,r.optionLabel):e&&void 0!==e.label?e.label:e},s=function(e){return r.optionValue?l.ObjectUtils.resolveFieldData(e,r.optionValue):e&&void 0!==e.value?e.value:e},p=function(e){return r.optionDisabled?l.ObjectUtils.isFunction(r.optionDisabled)?r.optionDisabled(e):l.ObjectUtils.resolveFieldData(e,r.optionDisabled):!(!e||void 0===e.disabled)&&e.disabled},f=function(e){var t=s(e);return r.multiple?!(!r.value||!r.value.length)&&r.value.some((function(e){return l.ObjectUtils.equals(e,t,r.dataKey)})):l.ObjectUtils.equals(r.value,t,r.dataKey)};a.useImperativeHandle(t,(function(){return{props:r,focus:function(){return l.DomHandler.focusFirstElement(o.current)},getElement:function(){return o.current}}}));var m=l.ObjectUtils.isNotEmpty(r.tooltip),v=b.getOtherProps(r),y=l.classNames("p-selectbutton p-buttonset p-component",r.className),h=r.options&&r.options.length?r.options.map((function(e,t){var n=r.disabled||p(e),l=c(e),o=n?null:0,i=f(e);return a.createElement(g,{key:l+"_"+t,label:l,className:e.className,option:e,onClick:u,template:r.itemTemplate,selected:i,tabIndex:o,disabled:n})})):null;return a.createElement(a.Fragment,null,a.createElement("div",i({ref:o,id:r.id,className:y,style:r.style},v,{role:"group"}),h),m&&a.createElement(n.Tooltip,i({target:o,content:r.tooltip},r.tooltipOptions)))})));return h.displayName="SelectButton",e.SelectButton=h,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.tooltip,primereact.utils,primereact.ripple);