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.21 kB
JavaScript
Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/tooltip"),n=require("primereact/utils"),l=require("primereact/ripple");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 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 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 l in n)Object.prototype.hasOwnProperty.call(n,l)&&(e[l]=n[l])}return e},a.apply(this,arguments)}function i(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 u(e){if(Array.isArray(e))return i(e)}function s(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}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 p(){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 f(e){return u(e)||s(e)||c(e)||p()}var d={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 n.ObjectUtils.getMergedProps(e,d.defaultProps)},getOtherProps:function(e){return n.ObjectUtils.getDiffProps(e,d.defaultProps)}};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 l,r,o,a,i=[],u=!0,s=!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){s=!0,r=e}finally{try{if(!u&&null!=n.return&&(a=n.return(),Object(a)!==a))return}finally{if(s)throw r}}return i}}function v(){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 y=o.memo((function(e){var t,r,a=o.useState(!1),i=(r=2,b(t=a)||m(t,r)||c(t,r)||v()),u=i[1],s=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option})},p=n.classNames("p-button p-component",{"p-highlight":e.selected,"p-disabled":e.disabled,"p-focus":i[0]},e.className),f=e.template?n.ObjectUtils.getJSXElement(e.template,e.option):o.createElement("span",{className:"p-button-label p-c"},e.label);return o.createElement("div",{className:p,role:"button","aria-label":e.label,"aria-pressed":e.selected,onClick:s,onKeyDown:function(e){32===e.which&&(s(e),e.preventDefault())},tabIndex:e.tabIndex,onFocus:function(){u(!0)},onBlur:function(){u(!1)}},f,!e.disabled&&o.createElement(l.Ripple,null))}));y.displayName="SelectButtonItem";var g=o.memo(o.forwardRef((function(e,l){var r=d.getProps(e),i=o.useRef(null),u=function(e){if(!r.disabled&&!p(e.option)){var t=b(e.option);if(!t||r.unselectable){var l,o=c(e.option);if(r.multiple){var a=r.value?f(r.value):[];l=t?a.filter((function(e){return!n.ObjectUtils.equals(e,o,r.dataKey)})):[].concat(f(a),[o])}else l=t?null:o;r.onChange&&r.onChange({originalEvent:e.originalEvent,value:l,stopPropagation:function(){},preventDefault:function(){},target:{name:r.name,id:r.id,value:l}})}}},s=function(e){return r.optionLabel?n.ObjectUtils.resolveFieldData(e,r.optionLabel):e&&void 0!==e.label?e.label:e},c=function(e){return r.optionValue?n.ObjectUtils.resolveFieldData(e,r.optionValue):e&&void 0!==e.value?e.value:e},p=function(e){return r.optionDisabled?n.ObjectUtils.isFunction(r.optionDisabled)?r.optionDisabled(e):n.ObjectUtils.resolveFieldData(e,r.optionDisabled):!(!e||void 0===e.disabled)&&e.disabled},b=function(e){var t=c(e);return r.multiple?!(!r.value||!r.value.length)&&r.value.some((function(e){return n.ObjectUtils.equals(e,t,r.dataKey)})):n.ObjectUtils.equals(r.value,t,r.dataKey)};o.useImperativeHandle(l,(function(){return{props:r,focus:function(){return n.DomHandler.focusFirstElement(i.current)},getElement:function(){return i.current}}}));var m=n.ObjectUtils.isNotEmpty(r.tooltip),v=d.getOtherProps(r),g=n.classNames("p-selectbutton p-buttonset p-component",r.className),O=r.options&&r.options.length?r.options.map((function(e,t){var n=r.disabled||p(e),l=s(e),a=n?null:0,i=b(e);return o.createElement(y,{key:l+"_"+t,label:l,className:e.className,option:e,onClick:u,template:r.itemTemplate,selected:i,tabIndex:a,disabled:n})})):null;return o.createElement(o.Fragment,null,o.createElement("div",a({ref:i,id:r.id,className:g,style:r.style},v,{role:"group"}),O),m&&o.createElement(t.Tooltip,a({target:i,content:r.tooltip},r.tooltipOptions)))})));g.displayName="SelectButton",exports.SelectButton=g;
;