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) 12 kB
this.primereact=this.primereact||{},this.primereact.listbox=function(e,t,n,r,l,i,o,a,u){"use strict";function c(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 s=c(t);function p(){return p=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},p.apply(this,arguments)}function f(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function m(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 d(e){if(Array.isArray(e))return m(e)}function b(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function v(e,t){if(e){if("string"==typeof e)return m(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)?m(e,t):void 0}}function y(){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 h(e){return d(e)||b(e)||v(e)||y()}function g(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,i=[],o=!0,a=!1;try{for(n=n.call(e);!(o=(r=n.next()).done)&&(i.push(r.value),!t||i.length!==t);o=!0);}catch(e){a=!0,l=e}finally{try{o||null==n.return||n.return()}finally{if(a)throw l}}return i}}function E(){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 j=s.memo((function(e){var t={filter:function(e){return n(e)},reset:function(){return e.resetFilter()}},n=function(t){e.onFilter&&e.onFilter({originalEvent:t,value:t.target.value})},r=function(){var r=s.createElement("div",{className:"p-listbox-filter-container"},s.createElement(a.InputText,p({type:"text",value:e.filter,onChange:n,className:"p-listbox-filter",disabled:e.disabled,placeholder:e.filterPlaceholder},e.filterInputProps)),s.createElement("span",{className:"p-listbox-filter-icon pi pi-search"}));e.filterTemplate&&(r=i.ObjectUtils.getJSXElement(e.filterTemplate,{className:"p-listbox-filter-container",element:r,filterOptions:t,filterInputChange:n,filterIconClassName:"p-dropdown-filter-icon pi pi-search",props:e}));return s.createElement("div",{className:"p-listbox-header"},r)}();return s.createElement(s.Fragment,null,r)}));j.displayName="ListBoxHeader";var x=s.memo((function(e){var t=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option}),t.preventDefault()},n=function e(t){var n=t.nextElementSibling;return n?i.DomHandler.hasClass(n,"p-disabled")||i.DomHandler.hasClass(n,"p-listbox-item-group")?e(n):n:null},r=function e(t){var n=t.previousElementSibling;return n?i.DomHandler.hasClass(n,"p-disabled")||i.DomHandler.hasClass(n,"p-listbox-item-group")?e(n):n:null},l=i.classNames("p-listbox-item",{"p-highlight":e.selected,"p-disabled":e.disabled},e.option.className),o=e.template?i.ObjectUtils.getJSXElement(e.template,e.option):e.label;return s.createElement("li",{className:l,style:e.style,onClick:t,onTouchEnd:function(t){e.onTouchEnd&&e.onTouchEnd({originalEvent:t,option:e.option})},onKeyDown:function(e){var l=e.currentTarget;switch(e.which){case 40:var i=n(l);i&&i.focus(),e.preventDefault();break;case 38:var o=r(l);o&&o.focus(),e.preventDefault();break;case 13:t(e),e.preventDefault()}},tabIndex:"-1","aria-label":e.label,key:e.label,role:"option","aria-selected":e.selected,"aria-disabled":e.disabled},o,s.createElement(u.Ripple,null))}));function S(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function D(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?S(Object(n),!0).forEach((function(t){f(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):S(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function P(e,t){var n="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!n){if(Array.isArray(e)||(n=T(e))||t&&e&&"number"==typeof e.length){n&&(e=n);var r=0,l=function(){};return{s:l,n:function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}},e:function(e){throw e},f:l}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,o=!0,a=!1;return{s:function(){n=n.call(e)},n:function(){var e=n.next();return o=e.done,e},e:function(e){a=!0,i=e},f:function(){try{o||null==n.return||n.return()}finally{if(a)throw i}}}}function T(e,t){if(e){if("string"==typeof e)return w(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)?w(e,t):void 0}}function w(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}x.displayName="ListBoxItem";var C=s.memo(s.forwardRef((function(e,t){var a,u,c=s.useState(""),f=(u=2,g(a=c)||O(a,u)||v(a,u)||E()),m=f[0],d=f[1],b=s.useRef(null),y=s.useRef(null),S=s.useRef(!1),T=(e.onFilterValueChange?e.filterValue:m)||"",w=T&&T.trim().length>0,I=function(t){var n=t.option;e.disabled||q(n)||(e.multiple?F(t.originalEvent,n):L(t.originalEvent,n),S.current=!1)},N=function(){e.disabled||(S.current=!0)},L=function(t,n){var r=_(n),l=!1,i=null;!S.current&&e.metaKeySelection?r?(t.metaKey||t.ctrlKey)&&(i=null,l=!0):(i=B(n),l=!0):(i=r?null:B(n),l=!0);l&&K(t,i)},F=function(t,n){var r=_(n),l=!1,i=null;if(!S&&e.metaKeySelection){var o=t.metaKey||t.ctrlKey;r?(i=o?k(n):[B(n)],l=!0):(i=[].concat(h(i=o&&e.value||[]),[B(n)]),l=!0)}else i=r?k(n):[].concat(h(e.value||[]),[B(n)]),l=!0;l&&e.onChange({originalEvent:t,value:i,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:i}})},U=function(t){y.current&&y.current.scrollToIndex(0);var n=t.value;e.onFilterValueChange?e.onFilterValueChange({originalEvent:t.originalEvent,value:n}):d(n)},A=function(){d(""),e.onFilter&&e.onFilter({filter:""})},K=function(t,n){e.onChange&&e.onChange({originalEvent:t,value:n,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:n}})},k=function(t){return e.value.filter((function(n){return!i.ObjectUtils.equals(n,B(t),e.dataKey)}))},V=function(){if(null!=e.value&&W){if(!e.optionGroupLabel)return M(e.value,W);for(var t=0;t<W.length;t++){var n=M(e.value,X(W[t]));if(-1!==n)return{group:t,option:n}}}return-1},G=function(){return e.optionValue?null:e.dataKey},M=function(e,t){var n=G();return t.findIndex((function(t){return i.ObjectUtils.equals(e,B(t),n)}))},_=function(t){var n=B(t),r=G();return e.multiple&&e.value?e.value.some((function(e){return i.ObjectUtils.equals(e,n,r)})):i.ObjectUtils.equals(e.value,n,r)},R=function(t){return e.optionLabel?i.ObjectUtils.resolveFieldData(t,e.optionLabel):t&&void 0!==t.label?t.label:t},B=function(t){return e.optionValue?i.ObjectUtils.resolveFieldData(t,e.optionValue):t&&void 0!==t.value?t.value:t},H=function(t){return e.dataKey?i.ObjectUtils.resolveFieldData(t,e.dataKey):R(t)},q=function(t){return e.optionDisabled?i.ObjectUtils.isFunction(e.optionDisabled)?e.optionDisabled(t):i.ObjectUtils.resolveFieldData(t,e.optionDisabled):!(!t||void 0===t.disabled)&&t.disabled},z=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},J=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},X=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupChildren)},$=function(){if(y.current){var e=V();-1!==e&&setTimeout((function(){return y.current.scrollToIndex(e)}),0)}};s.useImperativeHandle(t,(function(){return{props:e,getElement:function(){return b.current},getVirtualScroller:function(){return y.current}}})),r.useMountEffect((function(){$()}));var Y=function(t,n){return X(t).map((function(t,r){var l=R(t),i=r+"_"+H(t),o=q(t),a=o?null:e.tabIndex||0;return s.createElement(x,{key:i,label:l,option:t,style:n,template:e.itemTemplate,selected:_(t),onClick:I,onTouchEnd:N,tabIndex:a,disabled:o})}))},Q=function(t,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},l={height:r.props?r.props.itemSize:void 0};if(e.optionGroupLabel){var o=e.optionGroupTemplate?i.ObjectUtils.getJSXElement(e.optionGroupTemplate,t,n):J(t),a=Y(t,l),u=n+"_"+z(t);return s.createElement(s.Fragment,{key:u},s.createElement("li",{className:"p-listbox-item-group",style:l,role:"group"},o),a)}var c=R(t),p=n+"_"+H(t),f=q(t),m=f?null:e.tabIndex||0;return s.createElement(x,{key:p,label:c,option:t,style:l,template:e.itemTemplate,selected:_(t),onClick:I,onTouchEnd:N,tabIndex:m,disabled:f})},W=function(){if(w){var t=T.trim().toLocaleLowerCase(e.filterLocale),r=e.filterBy?e.filterBy.split(","):[e.optionLabel||"label"];if(e.optionGroupLabel){var l,i=[],o=P(e.options);try{for(o.s();!(l=o.n()).done;){var a=l.value,u=n.FilterService.filter(X(a),r,t,e.filterMatchMode,e.filterLocale);u&&u.length&&i.push(D(D({},a),{items:u}))}}catch(e){o.e(e)}finally{o.f()}return i}return n.FilterService.filter(e.options,r,t,e.filterMatchMode,e.filterLocale)}return e.options}(),Z=i.ObjectUtils.isNotEmpty(e.tooltip),ee=i.ObjectUtils.findDiffKeys(e,C.defaultProps),te=i.ObjectUtils.reduceKeys(ee,i.DomHandler.ARIA_PROPS),ne=i.classNames("p-listbox p-component",{"p-disabled":e.disabled},e.className),re=i.classNames("p-listbox-list-wrapper",e.listClassName),le=function(){if(e.virtualScrollerOptions){var t=D(D({},e.virtualScrollerOptions),{items:W,onLazyLoad:function(t){return e.virtualScrollerOptions.onLazyLoad(D(D({},t),{filter:W}))},itemTemplate:function(e,t){return e&&Q(e,t.index,t)},contentTemplate:function(t){var n=i.classNames("p-listbox-list",t.className);return s.createElement("ul",p({ref:t.contentRef,className:n,role:"listbox","aria-multiselectable":e.multiple},te),t.children)}});return s.createElement(o.VirtualScroller,p({ref:y},t))}var n=W?W.map(Q):null;return s.createElement("ul",p({className:"p-listbox-list",role:"listbox","aria-multiselectable":e.multiple},te),n)}(),ie=e.filter?s.createElement(j,{filter:T,onFilter:U,resetFilter:A,filterTemplate:e.filterTemplate,disabled:e.disabled,filterPlaceholder:e.filterPlaceholder,filterInputProps:e.filterInputProps}):null;return s.createElement(s.Fragment,null,s.createElement("div",p({ref:b,id:e.id,className:ne,style:e.style},ee),ie,s.createElement("div",{className:re,style:e.listStyle},le)),Z&&s.createElement(l.Tooltip,p({target:b,content:e.tooltip},e.tooltipOptions)))})));return C.displayName="ListBox",C.defaultProps={__TYPE:"ListBox",id:null,value:null,options:null,optionLabel:null,optionValue:null,optionDisabled:null,optionGroupLabel:null,optionGroupChildren:null,optionGroupTemplate:null,itemTemplate:null,style:null,listStyle:null,listClassName:null,className:null,virtualScrollerOptions:null,disabled:null,dataKey:null,multiple:!1,metaKeySelection:!1,filter:!1,filterTemplate:null,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,onChange:null,onFilterValueChange:null},e.ListBox=C,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.hooks,primereact.tooltip,primereact.utils,primereact.virtualscroller,primereact.inputtext,primereact.ripple);