primereact 8.1.1 → 8.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/autocomplete/autocomplete.cjs.js +19 -10
- package/autocomplete/autocomplete.cjs.min.js +1 -1
- package/autocomplete/autocomplete.esm.js +20 -11
- package/autocomplete/autocomplete.esm.min.js +1 -1
- package/autocomplete/autocomplete.js +19 -10
- package/autocomplete/autocomplete.min.js +1 -1
- package/avatar/avatar.cjs.js +7 -7
- package/avatar/avatar.cjs.min.js +1 -1
- package/avatar/avatar.d.ts +1 -3
- package/avatar/avatar.esm.js +7 -7
- package/avatar/avatar.esm.min.js +1 -1
- package/avatar/avatar.js +7 -7
- package/avatar/avatar.min.js +1 -1
- package/badge/badge.cjs.js +2 -2
- package/badge/badge.cjs.min.js +1 -1
- package/badge/badge.d.ts +2 -4
- package/badge/badge.esm.js +2 -2
- package/badge/badge.esm.min.js +1 -1
- package/badge/badge.js +2 -2
- package/badge/badge.min.js +1 -1
- package/calendar/calendar.cjs.js +77 -4
- package/calendar/calendar.cjs.min.js +1 -1
- package/calendar/calendar.d.ts +1 -0
- package/calendar/calendar.esm.js +77 -4
- package/calendar/calendar.esm.min.js +1 -1
- package/calendar/calendar.js +77 -4
- package/calendar/calendar.min.js +1 -1
- package/card/card.d.ts +1 -4
- package/cascadeselect/cascadeselect.cjs.js +3 -3
- package/cascadeselect/cascadeselect.cjs.min.js +1 -1
- package/cascadeselect/cascadeselect.d.ts +1 -1
- package/cascadeselect/cascadeselect.esm.js +3 -3
- package/cascadeselect/cascadeselect.esm.min.js +1 -1
- package/cascadeselect/cascadeselect.js +3 -3
- package/cascadeselect/cascadeselect.min.js +1 -1
- package/chart/chart.cjs.js +13 -7
- package/chart/chart.cjs.min.js +1 -1
- package/chart/chart.esm.js +13 -7
- package/chart/chart.esm.min.js +1 -1
- package/chart/chart.js +13 -7
- package/chart/chart.min.js +1 -1
- package/checkbox/checkbox.cjs.js +1 -1
- package/checkbox/checkbox.cjs.min.js +1 -1
- package/checkbox/checkbox.esm.js +2 -2
- package/checkbox/checkbox.esm.min.js +1 -1
- package/checkbox/checkbox.js +1 -1
- package/checkbox/checkbox.min.js +1 -1
- package/chip/chip.d.ts +1 -3
- package/chips/chips.cjs.js +18 -2
- package/chips/chips.cjs.min.js +1 -1
- package/chips/chips.d.ts +3 -0
- package/chips/chips.esm.js +19 -3
- package/chips/chips.esm.min.js +1 -1
- package/chips/chips.js +19 -4
- package/chips/chips.min.js +1 -1
- package/column/column.d.ts +1 -0
- package/confirmdialog/confirmdialog.d.ts +1 -6
- package/contextmenu/contextmenu.cjs.js +1 -0
- package/contextmenu/contextmenu.cjs.min.js +1 -1
- package/contextmenu/contextmenu.esm.js +1 -0
- package/contextmenu/contextmenu.esm.min.js +1 -1
- package/contextmenu/contextmenu.js +1 -0
- package/contextmenu/contextmenu.min.js +1 -1
- package/core/core.js +249 -117
- package/core/core.min.js +9 -9
- package/datatable/datatable.cjs.js +63 -25
- package/datatable/datatable.cjs.min.js +1 -1
- package/datatable/datatable.esm.js +64 -26
- package/datatable/datatable.esm.min.js +1 -1
- package/datatable/datatable.js +63 -25
- package/datatable/datatable.min.js +1 -1
- package/dialog/dialog.cjs.js +2 -2
- package/dialog/dialog.cjs.min.js +1 -1
- package/dialog/dialog.esm.js +2 -2
- package/dialog/dialog.esm.min.js +1 -1
- package/dialog/dialog.js +2 -2
- package/dialog/dialog.min.js +1 -1
- package/dropdown/dropdown.cjs.js +29 -17
- package/dropdown/dropdown.cjs.min.js +1 -1
- package/dropdown/dropdown.d.ts +1 -1
- package/dropdown/dropdown.esm.js +29 -17
- package/dropdown/dropdown.esm.min.js +1 -1
- package/dropdown/dropdown.js +29 -17
- package/dropdown/dropdown.min.js +1 -1
- package/editor/editor.cjs.js +11 -3
- package/editor/editor.cjs.min.js +1 -1
- package/editor/editor.esm.js +11 -3
- package/editor/editor.esm.min.js +1 -1
- package/editor/editor.js +11 -3
- package/editor/editor.min.js +1 -1
- package/image/image.cjs.js +5 -5
- package/image/image.cjs.min.js +1 -1
- package/image/image.d.ts +1 -3
- package/image/image.esm.js +5 -5
- package/image/image.esm.min.js +1 -1
- package/image/image.js +5 -5
- package/image/image.min.css +1 -1
- package/image/image.min.js +1 -1
- package/inplace/inplace.cjs.js +1 -1
- package/inplace/inplace.cjs.min.js +1 -1
- package/inplace/inplace.esm.js +1 -1
- package/inplace/inplace.esm.min.js +1 -1
- package/inplace/inplace.js +1 -1
- package/inplace/inplace.min.js +1 -1
- package/inputmask/inputmask.cjs.js +7 -5
- package/inputmask/inputmask.cjs.min.js +1 -1
- package/inputmask/inputmask.d.ts +0 -1
- package/inputmask/inputmask.esm.js +7 -5
- package/inputmask/inputmask.esm.min.js +1 -1
- package/inputmask/inputmask.js +7 -5
- package/inputmask/inputmask.min.js +1 -1
- package/inputnumber/inputnumber.cjs.js +2 -2
- package/inputnumber/inputnumber.cjs.min.js +1 -1
- package/inputnumber/inputnumber.esm.js +2 -2
- package/inputnumber/inputnumber.esm.min.js +1 -1
- package/inputnumber/inputnumber.js +2 -2
- package/inputnumber/inputnumber.min.js +1 -1
- package/inputswitch/inputswitch.cjs.js +1 -1
- package/inputswitch/inputswitch.cjs.min.js +1 -1
- package/inputswitch/inputswitch.esm.js +2 -2
- package/inputswitch/inputswitch.esm.min.js +1 -1
- package/inputswitch/inputswitch.js +1 -1
- package/inputswitch/inputswitch.min.css +1 -1
- package/inputswitch/inputswitch.min.js +1 -1
- package/inputtext/inputtext.min.css +1 -1
- package/listbox/listbox.cjs.js +66 -6
- package/listbox/listbox.cjs.min.js +1 -1
- package/listbox/listbox.d.ts +1 -1
- package/listbox/listbox.esm.js +66 -6
- package/listbox/listbox.esm.min.js +1 -1
- package/listbox/listbox.js +67 -8
- package/listbox/listbox.min.js +1 -1
- package/megamenu/megamenu.cjs.js +32 -12
- package/megamenu/megamenu.cjs.min.js +1 -1
- package/megamenu/megamenu.d.ts +7 -0
- package/megamenu/megamenu.esm.js +32 -12
- package/megamenu/megamenu.esm.min.js +1 -1
- package/megamenu/megamenu.js +32 -12
- package/megamenu/megamenu.min.css +1 -1
- package/megamenu/megamenu.min.js +1 -1
- package/mention/mention.cjs.js +1 -1
- package/mention/mention.cjs.min.js +1 -1
- package/mention/mention.esm.js +1 -1
- package/mention/mention.esm.min.js +1 -1
- package/mention/mention.js +1 -1
- package/mention/mention.min.js +1 -1
- package/menubar/menubar.cjs.js +1 -0
- package/menubar/menubar.cjs.min.js +1 -1
- package/menubar/menubar.esm.js +1 -0
- package/menubar/menubar.esm.min.js +1 -1
- package/menubar/menubar.js +1 -0
- package/menubar/menubar.min.js +1 -1
- package/menuitem/menuitem.d.ts +2 -0
- package/message/message.d.ts +1 -1
- package/messages/messages.cjs.js +3 -2
- package/messages/messages.cjs.min.js +1 -1
- package/messages/messages.d.ts +1 -1
- package/messages/messages.esm.js +3 -2
- package/messages/messages.esm.min.js +1 -1
- package/messages/messages.js +3 -2
- package/messages/messages.min.js +1 -1
- package/multiselect/multiselect.cjs.js +20 -10
- package/multiselect/multiselect.cjs.min.js +1 -1
- package/multiselect/multiselect.d.ts +1 -1
- package/multiselect/multiselect.esm.js +20 -10
- package/multiselect/multiselect.esm.min.js +1 -1
- package/multiselect/multiselect.js +20 -10
- package/multiselect/multiselect.min.js +1 -1
- package/overlaypanel/overlaypanel.cjs.js +1 -1
- package/overlaypanel/overlaypanel.cjs.min.js +1 -1
- package/overlaypanel/overlaypanel.esm.js +1 -1
- package/overlaypanel/overlaypanel.esm.min.js +1 -1
- package/overlaypanel/overlaypanel.js +1 -1
- package/overlaypanel/overlaypanel.min.js +1 -1
- package/package.json +1 -1
- package/panelmenu/panelmenu.cjs.js +1 -0
- package/panelmenu/panelmenu.cjs.min.js +1 -1
- package/panelmenu/panelmenu.esm.js +1 -0
- package/panelmenu/panelmenu.esm.min.js +1 -1
- package/panelmenu/panelmenu.js +1 -0
- package/panelmenu/panelmenu.min.js +1 -1
- package/picklist/picklist.cjs.js +169 -14
- package/picklist/picklist.cjs.min.js +1 -1
- package/picklist/picklist.d.ts +29 -0
- package/picklist/picklist.esm.js +169 -14
- package/picklist/picklist.esm.min.js +1 -1
- package/picklist/picklist.js +170 -16
- package/picklist/picklist.min.css +1 -1
- package/picklist/picklist.min.js +1 -1
- package/primereact.all.cjs.js +924 -387
- package/primereact.all.cjs.min.js +1 -1
- package/primereact.all.esm.js +924 -387
- package/primereact.all.esm.min.js +1 -1
- package/primereact.all.js +924 -387
- package/primereact.all.min.js +1 -1
- package/radiobutton/radiobutton.cjs.js +1 -1
- package/radiobutton/radiobutton.cjs.min.js +1 -1
- package/radiobutton/radiobutton.esm.js +2 -2
- package/radiobutton/radiobutton.esm.min.js +1 -1
- package/radiobutton/radiobutton.js +1 -1
- package/radiobutton/radiobutton.min.js +1 -1
- package/resources/primereact.css +248 -194
- package/resources/primereact.min.css +1 -1
- package/resources/themes/arya-blue/theme.css +20 -6
- package/resources/themes/arya-green/theme.css +20 -6
- package/resources/themes/arya-orange/theme.css +20 -6
- package/resources/themes/arya-purple/theme.css +20 -6
- package/resources/themes/bootstrap4-dark-blue/theme.css +20 -6
- package/resources/themes/bootstrap4-dark-purple/theme.css +20 -6
- package/resources/themes/bootstrap4-light-blue/theme.css +19 -5
- package/resources/themes/bootstrap4-light-purple/theme.css +19 -5
- package/resources/themes/fluent-light/theme.css +20 -6
- package/resources/themes/lara-dark-blue/theme.css +20 -6
- package/resources/themes/lara-dark-indigo/theme.css +20 -6
- package/resources/themes/lara-dark-purple/theme.css +20 -6
- package/resources/themes/lara-dark-teal/theme.css +20 -6
- package/resources/themes/lara-light-blue/theme.css +20 -6
- package/resources/themes/lara-light-indigo/theme.css +20 -6
- package/resources/themes/lara-light-purple/theme.css +20 -6
- package/resources/themes/lara-light-teal/theme.css +20 -6
- package/resources/themes/luna-amber/theme.css +20 -6
- package/resources/themes/luna-blue/theme.css +20 -6
- package/resources/themes/luna-green/theme.css +20 -6
- package/resources/themes/luna-pink/theme.css +20 -6
- package/resources/themes/md-dark-deeppurple/theme.css +20 -6
- package/resources/themes/md-dark-indigo/theme.css +20 -6
- package/resources/themes/md-light-deeppurple/theme.css +20 -6
- package/resources/themes/md-light-indigo/theme.css +20 -6
- package/resources/themes/mdc-dark-deeppurple/theme.css +20 -6
- package/resources/themes/mdc-dark-indigo/theme.css +20 -6
- package/resources/themes/mdc-light-deeppurple/theme.css +20 -6
- package/resources/themes/mdc-light-indigo/theme.css +20 -6
- package/resources/themes/nova/theme.css +20 -6
- package/resources/themes/nova-accent/theme.css +20 -6
- package/resources/themes/nova-alt/theme.css +20 -6
- package/resources/themes/rhea/theme.css +20 -6
- package/resources/themes/saga-blue/theme.css +20 -6
- package/resources/themes/saga-green/theme.css +20 -6
- package/resources/themes/saga-orange/theme.css +20 -6
- package/resources/themes/saga-purple/theme.css +20 -6
- package/resources/themes/tailwind-light/theme.css +20 -6
- package/resources/themes/vela-blue/theme.css +20 -6
- package/resources/themes/vela-green/theme.css +20 -6
- package/resources/themes/vela-orange/theme.css +20 -6
- package/resources/themes/vela-purple/theme.css +20 -6
- package/selectbutton/selectbutton.d.ts +1 -1
- package/slidemenu/slidemenu.cjs.js +1 -0
- package/slidemenu/slidemenu.cjs.min.js +1 -1
- package/slidemenu/slidemenu.esm.js +1 -0
- package/slidemenu/slidemenu.esm.min.js +1 -1
- package/slidemenu/slidemenu.js +1 -0
- package/slidemenu/slidemenu.min.js +1 -1
- package/slider/slider.d.ts +1 -1
- package/splitbutton/splitbutton.cjs.js +4 -0
- package/splitbutton/splitbutton.cjs.min.js +1 -1
- package/splitbutton/splitbutton.d.ts +2 -0
- package/splitbutton/splitbutton.esm.js +4 -0
- package/splitbutton/splitbutton.esm.min.js +1 -1
- package/splitbutton/splitbutton.js +4 -0
- package/splitbutton/splitbutton.min.js +1 -1
- package/splitter/splitter.cjs.js +9 -5
- package/splitter/splitter.cjs.min.js +1 -1
- package/splitter/splitter.esm.js +10 -6
- package/splitter/splitter.esm.min.js +1 -1
- package/splitter/splitter.js +9 -5
- package/splitter/splitter.min.js +1 -1
- package/steps/steps.cjs.js +1 -0
- package/steps/steps.cjs.min.js +1 -1
- package/steps/steps.esm.js +1 -0
- package/steps/steps.esm.min.js +1 -1
- package/steps/steps.js +1 -0
- package/steps/steps.min.js +1 -1
- package/styleclass/styleclass.d.ts +1 -1
- package/tag/tag.d.ts +1 -1
- package/terminal/terminal.cjs.js +1 -1
- package/terminal/terminal.cjs.min.js +1 -1
- package/terminal/terminal.esm.js +2 -2
- package/terminal/terminal.esm.min.js +1 -1
- package/terminal/terminal.js +1 -1
- package/terminal/terminal.min.js +1 -1
- package/tieredmenu/tieredmenu.cjs.js +3 -1
- package/tieredmenu/tieredmenu.cjs.min.js +1 -1
- package/tieredmenu/tieredmenu.esm.js +3 -1
- package/tieredmenu/tieredmenu.esm.min.js +1 -1
- package/tieredmenu/tieredmenu.js +3 -1
- package/tieredmenu/tieredmenu.min.js +1 -1
- package/toast/toast.cjs.js +30 -35
- package/toast/toast.cjs.min.js +1 -1
- package/toast/toast.d.ts +2 -1
- package/toast/toast.esm.js +30 -35
- package/toast/toast.esm.min.js +1 -1
- package/toast/toast.js +30 -35
- package/toast/toast.min.css +1 -1
- package/toast/toast.min.js +1 -1
- package/tooltip/tooltip.cjs.js +28 -22
- package/tooltip/tooltip.cjs.min.js +1 -1
- package/tooltip/tooltip.esm.js +28 -22
- package/tooltip/tooltip.esm.min.js +1 -1
- package/tooltip/tooltip.js +28 -22
- package/tooltip/tooltip.min.js +1 -1
- package/tree/tree.cjs.js +9 -1
- package/tree/tree.cjs.min.js +1 -1
- package/tree/tree.esm.js +9 -1
- package/tree/tree.esm.min.js +1 -1
- package/tree/tree.js +9 -1
- package/tree/tree.min.js +1 -1
- package/treeselect/treeselect.cjs.js +2 -2
- package/treeselect/treeselect.cjs.min.js +1 -1
- package/treeselect/treeselect.esm.js +2 -2
- package/treeselect/treeselect.esm.min.js +1 -1
- package/treeselect/treeselect.js +2 -2
- package/treeselect/treeselect.min.js +1 -1
- package/treetable/treetable.cjs.js +1 -0
- package/treetable/treetable.cjs.min.js +1 -1
- package/treetable/treetable.d.ts +2 -2
- package/treetable/treetable.esm.js +1 -0
- package/treetable/treetable.esm.min.js +1 -1
- package/treetable/treetable.js +1 -0
- package/treetable/treetable.min.js +1 -1
- package/utils/utils.cjs.js +21 -5
- package/utils/utils.cjs.min.js +1 -1
- package/utils/utils.d.ts +1 -0
- package/utils/utils.esm.js +21 -5
- package/utils/utils.esm.min.js +1 -1
- package/utils/utils.js +21 -5
- package/utils/utils.min.js +1 -1
- package/virtualscroller/virtualscroller.cjs.js +154 -65
- package/virtualscroller/virtualscroller.cjs.min.js +1 -1
- package/virtualscroller/virtualscroller.d.ts +12 -0
- package/virtualscroller/virtualscroller.esm.js +156 -67
- package/virtualscroller/virtualscroller.esm.min.js +1 -1
- package/virtualscroller/virtualscroller.js +154 -65
- package/virtualscroller/virtualscroller.min.css +1 -1
- package/virtualscroller/virtualscroller.min.js +1 -1
- package/web-types.json +167 -4
package/listbox/listbox.esm.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { FilterService } from 'primereact/api';
|
|
3
|
+
import { useMountEffect } from 'primereact/hooks';
|
|
3
4
|
import { Tooltip } from 'primereact/tooltip';
|
|
4
5
|
import { classNames, ObjectUtils, DomHandler } from 'primereact/utils';
|
|
5
6
|
import { VirtualScroller } from 'primereact/virtualscroller';
|
|
@@ -207,6 +208,7 @@ var ListBoxItem = /*#__PURE__*/React.memo(function (props) {
|
|
|
207
208
|
var content = props.template ? ObjectUtils.getJSXElement(props.template, props.option) : props.label;
|
|
208
209
|
return /*#__PURE__*/React.createElement("li", {
|
|
209
210
|
className: className,
|
|
211
|
+
style: props.style,
|
|
210
212
|
onClick: onClick,
|
|
211
213
|
onTouchEnd: onTouchEnd,
|
|
212
214
|
onKeyDown: onKeyDown,
|
|
@@ -326,6 +328,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
326
328
|
};
|
|
327
329
|
|
|
328
330
|
var onFilter = function onFilter(event) {
|
|
331
|
+
virtualScrollerRef.current && virtualScrollerRef.current.scrollToIndex(0);
|
|
329
332
|
var originalEvent = event.originalEvent,
|
|
330
333
|
value = event.value;
|
|
331
334
|
|
|
@@ -361,11 +364,44 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
361
364
|
});
|
|
362
365
|
};
|
|
363
366
|
|
|
367
|
+
var getSelectedOptionIndex = function getSelectedOptionIndex() {
|
|
368
|
+
if (props.value != null && visibleOptions) {
|
|
369
|
+
if (props.optionGroupLabel) {
|
|
370
|
+
for (var i = 0; i < visibleOptions.length; i++) {
|
|
371
|
+
var selectedOptionIndex = findOptionIndexInList(props.value, getOptionGroupChildren(visibleOptions[i]));
|
|
372
|
+
|
|
373
|
+
if (selectedOptionIndex !== -1) {
|
|
374
|
+
return {
|
|
375
|
+
group: i,
|
|
376
|
+
option: selectedOptionIndex
|
|
377
|
+
};
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
} else {
|
|
381
|
+
return findOptionIndexInList(props.value, visibleOptions);
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
return -1;
|
|
386
|
+
};
|
|
387
|
+
|
|
388
|
+
var equalityKey = function equalityKey() {
|
|
389
|
+
return props.optionValue ? null : props.dataKey;
|
|
390
|
+
};
|
|
391
|
+
|
|
392
|
+
var findOptionIndexInList = function findOptionIndexInList(value, list) {
|
|
393
|
+
var key = equalityKey();
|
|
394
|
+
return list.findIndex(function (item) {
|
|
395
|
+
return ObjectUtils.equals(value, getOptionValue(item), key);
|
|
396
|
+
});
|
|
397
|
+
};
|
|
398
|
+
|
|
364
399
|
var isSelected = function isSelected(option) {
|
|
365
400
|
var optionValue = getOptionValue(option);
|
|
401
|
+
var key = equalityKey();
|
|
366
402
|
return props.multiple && props.value ? props.value.some(function (val) {
|
|
367
|
-
return ObjectUtils.equals(val, optionValue,
|
|
368
|
-
}) : ObjectUtils.equals(props.value, optionValue,
|
|
403
|
+
return ObjectUtils.equals(val, optionValue, key);
|
|
404
|
+
}) : ObjectUtils.equals(props.value, optionValue, key);
|
|
369
405
|
};
|
|
370
406
|
|
|
371
407
|
var getOptionLabel = function getOptionLabel(option) {
|
|
@@ -437,6 +473,22 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
437
473
|
}
|
|
438
474
|
};
|
|
439
475
|
|
|
476
|
+
var scrollToSelectedIndex = function scrollToSelectedIndex() {
|
|
477
|
+
if (virtualScrollerRef.current) {
|
|
478
|
+
var selectedIndex = getSelectedOptionIndex();
|
|
479
|
+
|
|
480
|
+
if (selectedIndex !== -1) {
|
|
481
|
+
setTimeout(function () {
|
|
482
|
+
return virtualScrollerRef.current.scrollToIndex(selectedIndex);
|
|
483
|
+
}, 0);
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
};
|
|
487
|
+
|
|
488
|
+
useMountEffect(function () {
|
|
489
|
+
scrollToSelectedIndex();
|
|
490
|
+
});
|
|
491
|
+
|
|
440
492
|
var createHeader = function createHeader() {
|
|
441
493
|
return props.filter ? /*#__PURE__*/React.createElement(ListBoxHeader, {
|
|
442
494
|
filter: filteredValue,
|
|
@@ -447,7 +499,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
447
499
|
}) : null;
|
|
448
500
|
};
|
|
449
501
|
|
|
450
|
-
var createGroupChildren = function createGroupChildren(optionGroup) {
|
|
502
|
+
var createGroupChildren = function createGroupChildren(optionGroup, style) {
|
|
451
503
|
var groupChildren = getOptionGroupChildren(optionGroup);
|
|
452
504
|
return groupChildren.map(function (option, j) {
|
|
453
505
|
var optionLabel = getOptionLabel(option);
|
|
@@ -458,6 +510,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
458
510
|
key: optionKey,
|
|
459
511
|
label: optionLabel,
|
|
460
512
|
option: option,
|
|
513
|
+
style: style,
|
|
461
514
|
template: props.itemTemplate,
|
|
462
515
|
selected: isSelected(option),
|
|
463
516
|
onClick: onOptionSelect,
|
|
@@ -469,14 +522,20 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
469
522
|
};
|
|
470
523
|
|
|
471
524
|
var createItem = function createItem(option, index) {
|
|
525
|
+
var scrollerOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
526
|
+
var style = {
|
|
527
|
+
height: scrollerOptions.props ? scrollerOptions.props.itemSize : undefined
|
|
528
|
+
};
|
|
529
|
+
|
|
472
530
|
if (props.optionGroupLabel) {
|
|
473
531
|
var groupContent = props.optionGroupTemplate ? ObjectUtils.getJSXElement(props.optionGroupTemplate, option, index) : getOptionGroupLabel(option);
|
|
474
|
-
var groupChildrenContent = createGroupChildren(option);
|
|
532
|
+
var groupChildrenContent = createGroupChildren(option, style);
|
|
475
533
|
var key = index + '_' + getOptionGroupRenderKey(option);
|
|
476
534
|
return /*#__PURE__*/React.createElement(React.Fragment, {
|
|
477
535
|
key: key
|
|
478
536
|
}, /*#__PURE__*/React.createElement("li", {
|
|
479
537
|
className: "p-listbox-item-group",
|
|
538
|
+
style: style,
|
|
480
539
|
role: "group"
|
|
481
540
|
}, groupContent), groupChildrenContent);
|
|
482
541
|
} else {
|
|
@@ -488,6 +547,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
488
547
|
key: optionKey,
|
|
489
548
|
label: optionLabel,
|
|
490
549
|
option: option,
|
|
550
|
+
style: style,
|
|
491
551
|
template: props.itemTemplate,
|
|
492
552
|
selected: isSelected(option),
|
|
493
553
|
onClick: onOptionSelect,
|
|
@@ -511,8 +571,8 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
|
|
|
511
571
|
filter: visibleOptions
|
|
512
572
|
}));
|
|
513
573
|
},
|
|
514
|
-
itemTemplate: function itemTemplate(item,
|
|
515
|
-
return item && createItem(item,
|
|
574
|
+
itemTemplate: function itemTemplate(item, options) {
|
|
575
|
+
return item && createItem(item, options.index, options);
|
|
516
576
|
},
|
|
517
577
|
contentTemplate: function contentTemplate(option) {
|
|
518
578
|
var className = classNames('p-listbox-list', option.className);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import*as e from"react";import{FilterService as t}from"primereact/api";import{Tooltip as l}from"primereact/tooltip";import{classNames as n,ObjectUtils as r,DomHandler as a}from"primereact/utils";import{VirtualScroller as o}from"primereact/virtualscroller";import{InputText as i}from"primereact/inputtext";import{Ripple as u}from"primereact/ripple";function c(){return c=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var l=arguments[t];for(var n in l)Object.prototype.hasOwnProperty.call(l,n)&&(e[n]=l[n])}return e},c.apply(this,arguments)}function s(e,t,l){return t in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}function p(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}function f(e){if(Array.isArray(e))return p(e)}function m(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function d(e,t){if(e){if("string"==typeof e)return p(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?p(e,t):void 0}}function b(){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 v(e){return f(e)||m(e)||d(e)||b()}function y(e){if(Array.isArray(e))return e}function h(e,t){var l=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=l){var n,r,a=[],o=!0,i=!1;try{for(l=l.call(e);!(o=(n=l.next()).done)&&(a.push(n.value),!t||a.length!==t);o=!0);}catch(e){i=!0,r=e}finally{try{o||null==l.return||l.return()}finally{if(i)throw r}}return a}}function g(){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 E=e.memo((function(t){return e.createElement("div",{className:"p-listbox-header"},e.createElement("div",{className:"p-listbox-filter-container"},e.createElement(i,c({type:"text",value:t.filter,onChange:function(e){t.onFilter&&t.onFilter({originalEvent:e,value:e.target.value})},className:"p-listbox-filter",disabled:t.disabled,placeholder:t.filterPlaceholder},t.filterInputProps)),e.createElement("span",{className:"p-listbox-filter-icon pi pi-search"})))}));E.displayName="ListBoxHeader";var x=e.memo((function(t){var l=function(e){t.onClick&&t.onClick({originalEvent:e,option:t.option}),e.preventDefault()},o=function e(t){var l=t.nextElementSibling;return l?a.hasClass(l,"p-disabled")||a.hasClass(l,"p-listbox-item-group")?e(l):l:null},i=function e(t){var l=t.previousElementSibling;return l?a.hasClass(l,"p-disabled")||a.hasClass(l,"p-listbox-item-group")?e(l):l:null},c=n("p-listbox-item",{"p-highlight":t.selected,"p-disabled":t.disabled},t.option.className),s=t.template?r.getJSXElement(t.template,t.option):t.label;return e.createElement("li",{className:c,onClick:l,onTouchEnd:function(e){t.onTouchEnd&&t.onTouchEnd({originalEvent:e,option:t.option})},onKeyDown:function(e){var t=e.currentTarget;switch(e.which){case 40:var n=o(t);n&&n.focus(),e.preventDefault();break;case 38:var r=i(t);r&&r.focus(),e.preventDefault();break;case 13:l(e),e.preventDefault()}},tabIndex:"-1","aria-label":t.label,key:t.label,role:"option","aria-selected":t.selected,"aria-disabled":t.disabled},s,e.createElement(u,null))}));function O(e,t){var l=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),l.push.apply(l,n)}return l}function S(e){for(var t=1;t<arguments.length;t++){var l=null!=arguments[t]?arguments[t]:{};t%2?O(Object(l),!0).forEach((function(t){s(e,t,l[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(l)):O(Object(l)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(l,t))}))}return e}function w(e,t){var l="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!l){if(Array.isArray(e)||(l=C(e))||t&&e&&"number"==typeof e.length){l&&(e=l);var n=0,r=function(){};return{s:r,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:r}}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 a,o=!0,i=!1;return{s:function(){l=l.call(e)},n:function(){var e=l.next();return o=e.done,e},e:function(e){i=!0,a=e},f:function(){try{o||null==l.return||l.return()}finally{if(i)throw a}}}}function C(e,t){if(e){if("string"==typeof e)return D(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?D(e,t):void 0}}function D(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}x.displayName="ListBoxItem";var L=e.memo(e.forwardRef((function(a,i){var u,s,p=e.useState(""),f=(s=2,y(u=p)||h(u,s)||d(u,s)||g()),m=f[0],b=f[1],O=e.useRef(null),C=e.useRef(null),D=e.useRef(!1),P=(a.onFilterValueChange?a.filterValue:m)||"",j=P&&P.trim().length>0,N=function(e){var t=e.option;a.disabled||R(t)||(a.multiple?F(e.originalEvent,t):T(e.originalEvent,t),D.current=!1)},I=function(){a.disabled||(D.current=!0)},T=function(e,t){var l=G(t),n=!1,r=null;!D.current&&a.metaKeySelection?l?(e.metaKey||e.ctrlKey)&&(r=null,n=!0):(r=M(t),n=!0):(r=l?null:M(t),n=!0);n&&K(e,r)},F=function(e,t){var l=G(t),n=!1,r=null;if(!D&&a.metaKeySelection){var o=e.metaKey||e.ctrlKey;l?(r=o?k(t):[M(t)],n=!0):(r=[].concat(v(r=o&&a.value||[]),[M(t)]),n=!0)}else r=l?k(t):[].concat(v(a.value||[]),[M(t)]),n=!0;n&&a.onChange({originalEvent:e,value:r,stopPropagation:function(){},preventDefault:function(){},target:{name:a.name,id:a.id,value:r}})},A=function(e){var t=e.value;a.onFilterValueChange?a.onFilterValueChange({originalEvent:e.originalEvent,value:t}):b(t)},K=function(e,t){a.onChange&&a.onChange({originalEvent:e,value:t,stopPropagation:function(){},preventDefault:function(){},target:{name:a.name,id:a.id,value:t}})},k=function(e){return a.value.filter((function(t){return!r.equals(t,M(e),a.dataKey)}))},G=function(e){var t=M(e);return a.multiple&&a.value?a.value.some((function(e){return r.equals(e,t,a.dataKey)})):r.equals(a.value,t,a.dataKey)},V=function(e){return a.optionLabel?r.resolveFieldData(e,a.optionLabel):e&&void 0!==e.label?e.label:e},M=function(e){return a.optionValue?r.resolveFieldData(e,a.optionValue):e&&void 0!==e.value?e.value:e},B=function(e){return a.dataKey?r.resolveFieldData(e,a.dataKey):V(e)},R=function(e){return a.optionDisabled?r.isFunction(a.optionDisabled)?a.optionDisabled(e):r.resolveFieldData(e,a.optionDisabled):!(!e||void 0===e.disabled)&&e.disabled},_=function(e){return r.resolveFieldData(e,a.optionGroupLabel)},q=function(e){return r.resolveFieldData(e,a.optionGroupChildren)},z=function(t){return q(t).map((function(t,l){var n=V(t),r=l+"_"+B(t),o=R(t),i=o?null:a.tabIndex||0;return e.createElement(x,{key:r,label:n,option:t,template:a.itemTemplate,selected:G(t),onClick:N,onTouchEnd:I,tabIndex:i,disabled:o})}))},J=function(t,l){if(a.optionGroupLabel){var n=a.optionGroupTemplate?r.getJSXElement(a.optionGroupTemplate,t,l):r.resolveFieldData(t,a.optionGroupLabel),o=z(t),i=l+"_"+_(t);return e.createElement(e.Fragment,{key:i},e.createElement("li",{className:"p-listbox-item-group",role:"group"},n),o)}var u=V(t),c=l+"_"+B(t),s=R(t),p=s?null:a.tabIndex||0;return e.createElement(x,{key:c,label:u,option:t,template:a.itemTemplate,selected:G(t),onClick:N,onTouchEnd:I,tabIndex:p,disabled:s})},U=function(){if(j){var e=P.trim().toLocaleLowerCase(a.filterLocale),l=a.filterBy?a.filterBy.split(","):[a.optionLabel||"label"];if(a.optionGroupLabel){var n,r=[],o=w(a.options);try{for(o.s();!(n=o.n()).done;){var i=n.value,u=t.filter(q(i),l,e,a.filterMatchMode,a.filterLocale);u&&u.length&&r.push(S(S({},i),{items:u}))}}catch(e){o.e(e)}finally{o.f()}return r}return t.filter(a.options,l,e,a.filterMatchMode,a.filterLocale)}return a.options}(),X=r.isNotEmpty(a.tooltip),$=r.findDiffKeys(a,L.defaultProps),H=n("p-listbox p-component",{"p-disabled":a.disabled},a.className),Y=n("p-listbox-list-wrapper",a.listClassName),Q=function(){if(a.virtualScrollerOptions){var t=S(S({},a.virtualScrollerOptions),{items:U,onLazyLoad:function(e){return a.virtualScrollerOptions.onLazyLoad(S(S({},e),{filter:U}))},itemTemplate:function(e,t){return e&&J(e,t.index)},contentTemplate:function(t){var l=n("p-listbox-list",t.className);return e.createElement("ul",{ref:t.contentRef,className:l,role:"listbox","aria-multiselectable":a.multiple,"aria-labelledby":a["aria-labelledby"],"aria-label":a["aria-label"]},t.children)}});return e.createElement(o,c({ref:C},t))}var l=U?U.map(J):null;return e.createElement("ul",{className:"p-listbox-list",role:"listbox","aria-multiselectable":a.multiple,"aria-labelledby":a["aria-labelledby"],"aria-label":a["aria-label"]},l)}(),W=a.filter?e.createElement(E,{filter:P,onFilter:A,disabled:a.disabled,filterPlaceholder:a.filterPlaceholder,filterInputProps:a.filterInputProps}):null;return e.createElement(e.Fragment,null,e.createElement("div",c({ref:O,id:a.id,className:H,style:a.style},$),W,e.createElement("div",{className:Y,style:a.listStyle},Q)),X&&e.createElement(l,c({target:O,content:a.tooltip},a.tooltipOptions)))})));L.displayName="ListBox",L.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,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null};export{L as ListBox};
|
|
1
|
+
import*as e from"react";import{FilterService as t}from"primereact/api";import{useMountEffect as n}from"primereact/hooks";import{Tooltip as r}from"primereact/tooltip";import{classNames as l,ObjectUtils as a,DomHandler as o}from"primereact/utils";import{VirtualScroller as i}from"primereact/virtualscroller";import{InputText as u}from"primereact/inputtext";import{Ripple as c}from"primereact/ripple";function s(){return s=Object.assign||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},s.apply(this,arguments)}function p(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function f(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 m(e){if(Array.isArray(e))return f(e)}function d(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function b(e,t){if(e){if("string"==typeof e)return f(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)?f(e,t):void 0}}function v(){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 y(e){return m(e)||d(e)||b(e)||v()}function h(e){if(Array.isArray(e))return e}function g(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,l,a=[],o=!0,i=!1;try{for(n=n.call(e);!(o=(r=n.next()).done)&&(a.push(r.value),!t||a.length!==t);o=!0);}catch(e){i=!0,l=e}finally{try{o||null==n.return||n.return()}finally{if(i)throw l}}return a}}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 x=e.memo((function(t){return e.createElement("div",{className:"p-listbox-header"},e.createElement("div",{className:"p-listbox-filter-container"},e.createElement(u,s({type:"text",value:t.filter,onChange:function(e){t.onFilter&&t.onFilter({originalEvent:e,value:e.target.value})},className:"p-listbox-filter",disabled:t.disabled,placeholder:t.filterPlaceholder},t.filterInputProps)),e.createElement("span",{className:"p-listbox-filter-icon pi pi-search"})))}));x.displayName="ListBoxHeader";var O=e.memo((function(t){var n=function(e){t.onClick&&t.onClick({originalEvent:e,option:t.option}),e.preventDefault()},r=function e(t){var n=t.nextElementSibling;return n?o.hasClass(n,"p-disabled")||o.hasClass(n,"p-listbox-item-group")?e(n):n:null},i=function e(t){var n=t.previousElementSibling;return n?o.hasClass(n,"p-disabled")||o.hasClass(n,"p-listbox-item-group")?e(n):n:null},u=l("p-listbox-item",{"p-highlight":t.selected,"p-disabled":t.disabled},t.option.className),s=t.template?a.getJSXElement(t.template,t.option):t.label;return e.createElement("li",{className:u,style:t.style,onClick:n,onTouchEnd:function(e){t.onTouchEnd&&t.onTouchEnd({originalEvent:e,option:t.option})},onKeyDown:function(e){var t=e.currentTarget;switch(e.which){case 40:var l=r(t);l&&l.focus(),e.preventDefault();break;case 38:var a=i(t);a&&a.focus(),e.preventDefault();break;case 13:n(e),e.preventDefault()}},tabIndex:"-1","aria-label":t.label,key:t.label,role:"option","aria-selected":t.selected,"aria-disabled":t.disabled},s,e.createElement(c,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 w(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){p(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 C(e,t){var n="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!n){if(Array.isArray(e)||(n=D(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 a,o=!0,i=!1;return{s:function(){n=n.call(e)},n:function(){var e=n.next();return o=e.done,e},e:function(e){i=!0,a=e},f:function(){try{o||null==n.return||n.return()}finally{if(i)throw a}}}}function D(e,t){if(e){if("string"==typeof e)return L(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)?L(e,t):void 0}}function L(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}O.displayName="ListBoxItem";var P=e.memo(e.forwardRef((function(o,u){var c,p,f=e.useState(""),m=(p=2,h(c=f)||g(c,p)||b(c,p)||E()),d=m[0],v=m[1],S=e.useRef(null),D=e.useRef(null),L=e.useRef(!1),I=(o.onFilterValueChange?o.filterValue:d)||"",j=I&&I.trim().length>0,T=function(e){var t=e.option;o.disabled||J(t)||(o.multiple?A(e.originalEvent,t):F(e.originalEvent,t),L.current=!1)},N=function(){o.disabled||(L.current=!0)},F=function(e,t){var n=R(t),r=!1,l=null;!L.current&&o.metaKeySelection?n?(e.metaKey||e.ctrlKey)&&(l=null,r=!0):(l=q(t),r=!0):(l=n?null:q(t),r=!0);r&&k(e,l)},A=function(e,t){var n=R(t),r=!1,l=null;if(!L&&o.metaKeySelection){var a=e.metaKey||e.ctrlKey;n?(l=a?G(t):[q(t)],r=!0):(l=[].concat(y(l=a&&o.value||[]),[q(t)]),r=!0)}else l=n?G(t):[].concat(y(o.value||[]),[q(t)]),r=!0;r&&o.onChange({originalEvent:e,value:l,stopPropagation:function(){},preventDefault:function(){},target:{name:o.name,id:o.id,value:l}})},K=function(e){D.current&&D.current.scrollToIndex(0);var t=e.value;o.onFilterValueChange?o.onFilterValueChange({originalEvent:e.originalEvent,value:t}):v(t)},k=function(e,t){o.onChange&&o.onChange({originalEvent:e,value:t,stopPropagation:function(){},preventDefault:function(){},target:{name:o.name,id:o.id,value:t}})},G=function(e){return o.value.filter((function(t){return!a.equals(t,q(e),o.dataKey)}))},V=function(){if(null!=o.value&&W){if(!o.optionGroupLabel)return B(o.value,W);for(var e=0;e<W.length;e++){var t=B(o.value,$(W[e]));if(-1!==t)return{group:e,option:t}}}return-1},M=function(){return o.optionValue?null:o.dataKey},B=function(e,t){var n=M();return t.findIndex((function(t){return a.equals(e,q(t),n)}))},R=function(e){var t=q(e),n=M();return o.multiple&&o.value?o.value.some((function(e){return a.equals(e,t,n)})):a.equals(o.value,t,n)},_=function(e){return o.optionLabel?a.resolveFieldData(e,o.optionLabel):e&&void 0!==e.label?e.label:e},q=function(e){return o.optionValue?a.resolveFieldData(e,o.optionValue):e&&void 0!==e.value?e.value:e},z=function(e){return o.dataKey?a.resolveFieldData(e,o.dataKey):_(e)},J=function(e){return o.optionDisabled?a.isFunction(o.optionDisabled)?o.optionDisabled(e):a.resolveFieldData(e,o.optionDisabled):!(!e||void 0===e.disabled)&&e.disabled},U=function(e){return a.resolveFieldData(e,o.optionGroupLabel)},X=function(e){return a.resolveFieldData(e,o.optionGroupLabel)},$=function(e){return a.resolveFieldData(e,o.optionGroupChildren)},H=function(){if(D.current){var e=V();-1!==e&&setTimeout((function(){return D.current.scrollToIndex(e)}),0)}};n((function(){H()}));var Y=function(t,n){return $(t).map((function(t,r){var l=_(t),a=r+"_"+z(t),i=J(t),u=i?null:o.tabIndex||0;return e.createElement(O,{key:a,label:l,option:t,style:n,template:o.itemTemplate,selected:R(t),onClick:T,onTouchEnd:N,tabIndex:u,disabled:i})}))},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(o.optionGroupLabel){var i=o.optionGroupTemplate?a.getJSXElement(o.optionGroupTemplate,t,n):X(t),u=Y(t,l),c=n+"_"+U(t);return e.createElement(e.Fragment,{key:c},e.createElement("li",{className:"p-listbox-item-group",style:l,role:"group"},i),u)}var s=_(t),p=n+"_"+z(t),f=J(t),m=f?null:o.tabIndex||0;return e.createElement(O,{key:p,label:s,option:t,style:l,template:o.itemTemplate,selected:R(t),onClick:T,onTouchEnd:N,tabIndex:m,disabled:f})},W=function(){if(j){var e=I.trim().toLocaleLowerCase(o.filterLocale),n=o.filterBy?o.filterBy.split(","):[o.optionLabel||"label"];if(o.optionGroupLabel){var r,l=[],a=C(o.options);try{for(a.s();!(r=a.n()).done;){var i=r.value,u=t.filter($(i),n,e,o.filterMatchMode,o.filterLocale);u&&u.length&&l.push(w(w({},i),{items:u}))}}catch(e){a.e(e)}finally{a.f()}return l}return t.filter(o.options,n,e,o.filterMatchMode,o.filterLocale)}return o.options}(),Z=a.isNotEmpty(o.tooltip),ee=a.findDiffKeys(o,P.defaultProps),te=l("p-listbox p-component",{"p-disabled":o.disabled},o.className),ne=l("p-listbox-list-wrapper",o.listClassName),re=function(){if(o.virtualScrollerOptions){var t=w(w({},o.virtualScrollerOptions),{items:W,onLazyLoad:function(e){return o.virtualScrollerOptions.onLazyLoad(w(w({},e),{filter:W}))},itemTemplate:function(e,t){return e&&Q(e,t.index,t)},contentTemplate:function(t){var n=l("p-listbox-list",t.className);return e.createElement("ul",{ref:t.contentRef,className:n,role:"listbox","aria-multiselectable":o.multiple,"aria-labelledby":o["aria-labelledby"],"aria-label":o["aria-label"]},t.children)}});return e.createElement(i,s({ref:D},t))}var n=W?W.map(Q):null;return e.createElement("ul",{className:"p-listbox-list",role:"listbox","aria-multiselectable":o.multiple,"aria-labelledby":o["aria-labelledby"],"aria-label":o["aria-label"]},n)}(),le=o.filter?e.createElement(x,{filter:I,onFilter:K,disabled:o.disabled,filterPlaceholder:o.filterPlaceholder,filterInputProps:o.filterInputProps}):null;return e.createElement(e.Fragment,null,e.createElement("div",s({ref:S,id:o.id,className:te,style:o.style},ee),le,e.createElement("div",{className:ne,style:o.listStyle},re)),Z&&e.createElement(r,s({target:S,content:o.tooltip},o.tooltipOptions)))})));P.displayName="ListBox",P.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,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null};export{P as ListBox};
|
package/listbox/listbox.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
this.primereact = this.primereact || {};
|
|
2
|
-
this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtualscroller, inputtext, ripple) {
|
|
2
|
+
this.primereact.listbox = (function (exports, React, api, hooks, tooltip, utils, virtualscroller, inputtext, ripple) {
|
|
3
3
|
'use strict';
|
|
4
4
|
|
|
5
5
|
function _interopNamespace(e) {
|
|
@@ -223,6 +223,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
223
223
|
var content = props.template ? utils.ObjectUtils.getJSXElement(props.template, props.option) : props.label;
|
|
224
224
|
return /*#__PURE__*/React__namespace.createElement("li", {
|
|
225
225
|
className: className,
|
|
226
|
+
style: props.style,
|
|
226
227
|
onClick: onClick,
|
|
227
228
|
onTouchEnd: onTouchEnd,
|
|
228
229
|
onKeyDown: onKeyDown,
|
|
@@ -342,6 +343,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
342
343
|
};
|
|
343
344
|
|
|
344
345
|
var onFilter = function onFilter(event) {
|
|
346
|
+
virtualScrollerRef.current && virtualScrollerRef.current.scrollToIndex(0);
|
|
345
347
|
var originalEvent = event.originalEvent,
|
|
346
348
|
value = event.value;
|
|
347
349
|
|
|
@@ -377,11 +379,44 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
377
379
|
});
|
|
378
380
|
};
|
|
379
381
|
|
|
382
|
+
var getSelectedOptionIndex = function getSelectedOptionIndex() {
|
|
383
|
+
if (props.value != null && visibleOptions) {
|
|
384
|
+
if (props.optionGroupLabel) {
|
|
385
|
+
for (var i = 0; i < visibleOptions.length; i++) {
|
|
386
|
+
var selectedOptionIndex = findOptionIndexInList(props.value, getOptionGroupChildren(visibleOptions[i]));
|
|
387
|
+
|
|
388
|
+
if (selectedOptionIndex !== -1) {
|
|
389
|
+
return {
|
|
390
|
+
group: i,
|
|
391
|
+
option: selectedOptionIndex
|
|
392
|
+
};
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
} else {
|
|
396
|
+
return findOptionIndexInList(props.value, visibleOptions);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
return -1;
|
|
401
|
+
};
|
|
402
|
+
|
|
403
|
+
var equalityKey = function equalityKey() {
|
|
404
|
+
return props.optionValue ? null : props.dataKey;
|
|
405
|
+
};
|
|
406
|
+
|
|
407
|
+
var findOptionIndexInList = function findOptionIndexInList(value, list) {
|
|
408
|
+
var key = equalityKey();
|
|
409
|
+
return list.findIndex(function (item) {
|
|
410
|
+
return utils.ObjectUtils.equals(value, getOptionValue(item), key);
|
|
411
|
+
});
|
|
412
|
+
};
|
|
413
|
+
|
|
380
414
|
var isSelected = function isSelected(option) {
|
|
381
415
|
var optionValue = getOptionValue(option);
|
|
416
|
+
var key = equalityKey();
|
|
382
417
|
return props.multiple && props.value ? props.value.some(function (val) {
|
|
383
|
-
return utils.ObjectUtils.equals(val, optionValue,
|
|
384
|
-
}) : utils.ObjectUtils.equals(props.value, optionValue,
|
|
418
|
+
return utils.ObjectUtils.equals(val, optionValue, key);
|
|
419
|
+
}) : utils.ObjectUtils.equals(props.value, optionValue, key);
|
|
385
420
|
};
|
|
386
421
|
|
|
387
422
|
var getOptionLabel = function getOptionLabel(option) {
|
|
@@ -453,6 +488,22 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
453
488
|
}
|
|
454
489
|
};
|
|
455
490
|
|
|
491
|
+
var scrollToSelectedIndex = function scrollToSelectedIndex() {
|
|
492
|
+
if (virtualScrollerRef.current) {
|
|
493
|
+
var selectedIndex = getSelectedOptionIndex();
|
|
494
|
+
|
|
495
|
+
if (selectedIndex !== -1) {
|
|
496
|
+
setTimeout(function () {
|
|
497
|
+
return virtualScrollerRef.current.scrollToIndex(selectedIndex);
|
|
498
|
+
}, 0);
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
};
|
|
502
|
+
|
|
503
|
+
hooks.useMountEffect(function () {
|
|
504
|
+
scrollToSelectedIndex();
|
|
505
|
+
});
|
|
506
|
+
|
|
456
507
|
var createHeader = function createHeader() {
|
|
457
508
|
return props.filter ? /*#__PURE__*/React__namespace.createElement(ListBoxHeader, {
|
|
458
509
|
filter: filteredValue,
|
|
@@ -463,7 +514,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
463
514
|
}) : null;
|
|
464
515
|
};
|
|
465
516
|
|
|
466
|
-
var createGroupChildren = function createGroupChildren(optionGroup) {
|
|
517
|
+
var createGroupChildren = function createGroupChildren(optionGroup, style) {
|
|
467
518
|
var groupChildren = getOptionGroupChildren(optionGroup);
|
|
468
519
|
return groupChildren.map(function (option, j) {
|
|
469
520
|
var optionLabel = getOptionLabel(option);
|
|
@@ -474,6 +525,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
474
525
|
key: optionKey,
|
|
475
526
|
label: optionLabel,
|
|
476
527
|
option: option,
|
|
528
|
+
style: style,
|
|
477
529
|
template: props.itemTemplate,
|
|
478
530
|
selected: isSelected(option),
|
|
479
531
|
onClick: onOptionSelect,
|
|
@@ -485,14 +537,20 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
485
537
|
};
|
|
486
538
|
|
|
487
539
|
var createItem = function createItem(option, index) {
|
|
540
|
+
var scrollerOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
541
|
+
var style = {
|
|
542
|
+
height: scrollerOptions.props ? scrollerOptions.props.itemSize : undefined
|
|
543
|
+
};
|
|
544
|
+
|
|
488
545
|
if (props.optionGroupLabel) {
|
|
489
546
|
var groupContent = props.optionGroupTemplate ? utils.ObjectUtils.getJSXElement(props.optionGroupTemplate, option, index) : getOptionGroupLabel(option);
|
|
490
|
-
var groupChildrenContent = createGroupChildren(option);
|
|
547
|
+
var groupChildrenContent = createGroupChildren(option, style);
|
|
491
548
|
var key = index + '_' + getOptionGroupRenderKey(option);
|
|
492
549
|
return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, {
|
|
493
550
|
key: key
|
|
494
551
|
}, /*#__PURE__*/React__namespace.createElement("li", {
|
|
495
552
|
className: "p-listbox-item-group",
|
|
553
|
+
style: style,
|
|
496
554
|
role: "group"
|
|
497
555
|
}, groupContent), groupChildrenContent);
|
|
498
556
|
} else {
|
|
@@ -504,6 +562,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
504
562
|
key: optionKey,
|
|
505
563
|
label: optionLabel,
|
|
506
564
|
option: option,
|
|
565
|
+
style: style,
|
|
507
566
|
template: props.itemTemplate,
|
|
508
567
|
selected: isSelected(option),
|
|
509
568
|
onClick: onOptionSelect,
|
|
@@ -527,8 +586,8 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
527
586
|
filter: visibleOptions
|
|
528
587
|
}));
|
|
529
588
|
},
|
|
530
|
-
itemTemplate: function itemTemplate(item,
|
|
531
|
-
return item && createItem(item,
|
|
589
|
+
itemTemplate: function itemTemplate(item, options) {
|
|
590
|
+
return item && createItem(item, options.index, options);
|
|
532
591
|
},
|
|
533
592
|
contentTemplate: function contentTemplate(option) {
|
|
534
593
|
var className = utils.classNames('p-listbox-list', option.className);
|
|
@@ -624,4 +683,4 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
|
|
|
624
683
|
|
|
625
684
|
return exports;
|
|
626
685
|
|
|
627
|
-
})({}, React, primereact.api, primereact.tooltip, primereact.utils, primereact.virtualscroller, primereact.inputtext, primereact.ripple);
|
|
686
|
+
})({}, React, primereact.api, primereact.hooks, primereact.tooltip, primereact.utils, primereact.virtualscroller, primereact.inputtext, primereact.ripple);
|
package/listbox/listbox.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
this.primereact=this.primereact||{},this.primereact.listbox=function(e,t,l,n,r,a,i,o){"use strict";function u(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(l){if("default"!==l){var n=Object.getOwnPropertyDescriptor(e,l);Object.defineProperty(t,l,n.get?n:{enumerable:!0,get:function(){return e[l]}})}})),t.default=e,Object.freeze(t)}var c=u(t);function s(){return s=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var l=arguments[t];for(var n in l)Object.prototype.hasOwnProperty.call(l,n)&&(e[n]=l[n])}return e},s.apply(this,arguments)}function p(e,t,l){return t in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}function f(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}function d(e){if(Array.isArray(e))return f(e)}function b(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function m(e,t){if(e){if("string"==typeof e)return f(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?f(e,t):void 0}}function v(){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 y(e){return d(e)||b(e)||m(e)||v()}function h(e){if(Array.isArray(e))return e}function g(e,t){var l=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=l){var n,r,a=[],i=!0,o=!1;try{for(l=l.call(e);!(i=(n=l.next()).done)&&(a.push(n.value),!t||a.length!==t);i=!0);}catch(e){o=!0,r=e}finally{try{i||null==l.return||l.return()}finally{if(o)throw r}}return a}}function O(){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 E=c.memo((function(e){return c.createElement("div",{className:"p-listbox-header"},c.createElement("div",{className:"p-listbox-filter-container"},c.createElement(i.InputText,s({type:"text",value:e.filter,onChange:function(t){e.onFilter&&e.onFilter({originalEvent:t,value:t.target.value})},className:"p-listbox-filter",disabled:e.disabled,placeholder:e.filterPlaceholder},e.filterInputProps)),c.createElement("span",{className:"p-listbox-filter-icon pi pi-search"})))}));E.displayName="ListBoxHeader";var j=c.memo((function(e){var t=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option}),t.preventDefault()},l=function e(t){var l=t.nextElementSibling;return l?r.DomHandler.hasClass(l,"p-disabled")||r.DomHandler.hasClass(l,"p-listbox-item-group")?e(l):l:null},n=function e(t){var l=t.previousElementSibling;return l?r.DomHandler.hasClass(l,"p-disabled")||r.DomHandler.hasClass(l,"p-listbox-item-group")?e(l):l:null},a=r.classNames("p-listbox-item",{"p-highlight":e.selected,"p-disabled":e.disabled},e.option.className),i=e.template?r.ObjectUtils.getJSXElement(e.template,e.option):e.label;return c.createElement("li",{className:a,onClick:t,onTouchEnd:function(t){e.onTouchEnd&&e.onTouchEnd({originalEvent:t,option:e.option})},onKeyDown:function(e){var r=e.currentTarget;switch(e.which){case 40:var a=l(r);a&&a.focus(),e.preventDefault();break;case 38:var i=n(r);i&&i.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},i,c.createElement(o.Ripple,null))}));function x(e,t){var l=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),l.push.apply(l,n)}return l}function S(e){for(var t=1;t<arguments.length;t++){var l=null!=arguments[t]?arguments[t]:{};t%2?x(Object(l),!0).forEach((function(t){p(e,t,l[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(l)):x(Object(l)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(l,t))}))}return e}function D(e,t){var l="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!l){if(Array.isArray(e)||(l=w(e))||t&&e&&"number"==typeof e.length){l&&(e=l);var n=0,r=function(){};return{s:r,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:r}}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 a,i=!0,o=!1;return{s:function(){l=l.call(e)},n:function(){var e=l.next();return i=e.done,e},e:function(e){o=!0,a=e},f:function(){try{i||null==l.return||l.return()}finally{if(o)throw a}}}}function w(e,t){if(e){if("string"==typeof e)return P(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?P(e,t):void 0}}function P(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}j.displayName="ListBoxItem";var C=c.memo(c.forwardRef((function(e,t){var i,o,u=c.useState(""),p=(o=2,h(i=u)||g(i,o)||m(i,o)||O()),f=p[0],d=p[1],b=c.useRef(null),v=c.useRef(null),x=c.useRef(!1),w=(e.onFilterValueChange?e.filterValue:f)||"",P=w&&w.trim().length>0,L=function(t){var l=t.option;e.disabled||V(l)||(e.multiple?T(t.originalEvent,l):I(t.originalEvent,l),x.current=!1)},N=function(){e.disabled||(x.current=!0)},I=function(t,l){var n=K(l),r=!1,a=null;!x.current&&e.metaKeySelection?n?(t.metaKey||t.ctrlKey)&&(a=null,r=!0):(a=G(l),r=!0):(a=n?null:G(l),r=!0);r&&U(t,a)},T=function(t,l){var n=K(l),r=!1,a=null;if(!x&&e.metaKeySelection){var i=t.metaKey||t.ctrlKey;n?(a=i?A(l):[G(l)],r=!0):(a=[].concat(y(a=i&&e.value||[]),[G(l)]),r=!0)}else a=n?A(l):[].concat(y(e.value||[]),[G(l)]),r=!0;r&&e.onChange({originalEvent:t,value:a,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:a}})},F=function(t){var l=t.value;e.onFilterValueChange?e.onFilterValueChange({originalEvent:t.originalEvent,value:l}):d(l)},U=function(t,l){e.onChange&&e.onChange({originalEvent:t,value:l,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:l}})},A=function(t){return e.value.filter((function(l){return!r.ObjectUtils.equals(l,G(t),e.dataKey)}))},K=function(t){var l=G(t);return e.multiple&&e.value?e.value.some((function(t){return r.ObjectUtils.equals(t,l,e.dataKey)})):r.ObjectUtils.equals(e.value,l,e.dataKey)},k=function(t){return e.optionLabel?r.ObjectUtils.resolveFieldData(t,e.optionLabel):t&&void 0!==t.label?t.label:t},G=function(t){return e.optionValue?r.ObjectUtils.resolveFieldData(t,e.optionValue):t&&void 0!==t.value?t.value:t},M=function(t){return e.dataKey?r.ObjectUtils.resolveFieldData(t,e.dataKey):k(t)},V=function(t){return e.optionDisabled?r.ObjectUtils.isFunction(e.optionDisabled)?e.optionDisabled(t):r.ObjectUtils.resolveFieldData(t,e.optionDisabled):!(!t||void 0===t.disabled)&&t.disabled},_=function(t){return r.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},B=function(t){return r.ObjectUtils.resolveFieldData(t,e.optionGroupChildren)},R=function(t){return B(t).map((function(t,l){var n=k(t),r=l+"_"+M(t),a=V(t),i=a?null:e.tabIndex||0;return c.createElement(j,{key:r,label:n,option:t,template:e.itemTemplate,selected:K(t),onClick:L,onTouchEnd:N,tabIndex:i,disabled:a})}))},H=function(t,l){if(e.optionGroupLabel){var n=e.optionGroupTemplate?r.ObjectUtils.getJSXElement(e.optionGroupTemplate,t,l):r.ObjectUtils.resolveFieldData(t,e.optionGroupLabel),a=R(t),i=l+"_"+_(t);return c.createElement(c.Fragment,{key:i},c.createElement("li",{className:"p-listbox-item-group",role:"group"},n),a)}var o=k(t),u=l+"_"+M(t),s=V(t),p=s?null:e.tabIndex||0;return c.createElement(j,{key:u,label:o,option:t,template:e.itemTemplate,selected:K(t),onClick:L,onTouchEnd:N,tabIndex:p,disabled:s})},q=function(){if(P){var t=w.trim().toLocaleLowerCase(e.filterLocale),n=e.filterBy?e.filterBy.split(","):[e.optionLabel||"label"];if(e.optionGroupLabel){var r,a=[],i=D(e.options);try{for(i.s();!(r=i.n()).done;){var o=r.value,u=l.FilterService.filter(B(o),n,t,e.filterMatchMode,e.filterLocale);u&&u.length&&a.push(S(S({},o),{items:u}))}}catch(e){i.e(e)}finally{i.f()}return a}return l.FilterService.filter(e.options,n,t,e.filterMatchMode,e.filterLocale)}return e.options}(),z=r.ObjectUtils.isNotEmpty(e.tooltip),J=r.ObjectUtils.findDiffKeys(e,C.defaultProps),X=r.classNames("p-listbox p-component",{"p-disabled":e.disabled},e.className),$=r.classNames("p-listbox-list-wrapper",e.listClassName),Y=function(){if(e.virtualScrollerOptions){var t=S(S({},e.virtualScrollerOptions),{items:q,onLazyLoad:function(t){return e.virtualScrollerOptions.onLazyLoad(S(S({},t),{filter:q}))},itemTemplate:function(e,t){return e&&H(e,t.index)},contentTemplate:function(t){var l=r.classNames("p-listbox-list",t.className);return c.createElement("ul",{ref:t.contentRef,className:l,role:"listbox","aria-multiselectable":e.multiple,"aria-labelledby":e["aria-labelledby"],"aria-label":e["aria-label"]},t.children)}});return c.createElement(a.VirtualScroller,s({ref:v},t))}var l=q?q.map(H):null;return c.createElement("ul",{className:"p-listbox-list",role:"listbox","aria-multiselectable":e.multiple,"aria-labelledby":e["aria-labelledby"],"aria-label":e["aria-label"]},l)}(),Q=e.filter?c.createElement(E,{filter:w,onFilter:F,disabled:e.disabled,filterPlaceholder:e.filterPlaceholder,filterInputProps:e.filterInputProps}):null;return c.createElement(c.Fragment,null,c.createElement("div",s({ref:b,id:e.id,className:X,style:e.style},J),Q,c.createElement("div",{className:$,style:e.listStyle},Y)),z&&c.createElement(n.Tooltip,s({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,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null},e.ListBox=C,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.tooltip,primereact.utils,primereact.virtualscroller,primereact.inputtext,primereact.ripple);
|
|
1
|
+
this.primereact=this.primereact||{},this.primereact.listbox=function(e,t,l,n,r,a,i,o,u){"use strict";function c(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(l){if("default"!==l){var n=Object.getOwnPropertyDescriptor(e,l);Object.defineProperty(t,l,n.get?n:{enumerable:!0,get:function(){return e[l]}})}})),t.default=e,Object.freeze(t)}var s=c(t);function p(){return p=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var l=arguments[t];for(var n in l)Object.prototype.hasOwnProperty.call(l,n)&&(e[n]=l[n])}return e},p.apply(this,arguments)}function f(e,t,l){return t in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}function d(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}function b(e){if(Array.isArray(e))return d(e)}function m(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 d(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?d(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 b(e)||m(e)||v(e)||y()}function g(e){if(Array.isArray(e))return e}function O(e,t){var l=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=l){var n,r,a=[],i=!0,o=!1;try{for(l=l.call(e);!(i=(n=l.next()).done)&&(a.push(n.value),!t||a.length!==t);i=!0);}catch(e){o=!0,r=e}finally{try{i||null==l.return||l.return()}finally{if(o)throw r}}return a}}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){return s.createElement("div",{className:"p-listbox-header"},s.createElement("div",{className:"p-listbox-filter-container"},s.createElement(o.InputText,p({type:"text",value:e.filter,onChange:function(t){e.onFilter&&e.onFilter({originalEvent:t,value:t.target.value})},className:"p-listbox-filter",disabled:e.disabled,placeholder:e.filterPlaceholder},e.filterInputProps)),s.createElement("span",{className:"p-listbox-filter-icon pi pi-search"})))}));j.displayName="ListBoxHeader";var x=s.memo((function(e){var t=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option}),t.preventDefault()},l=function e(t){var l=t.nextElementSibling;return l?a.DomHandler.hasClass(l,"p-disabled")||a.DomHandler.hasClass(l,"p-listbox-item-group")?e(l):l:null},n=function e(t){var l=t.previousElementSibling;return l?a.DomHandler.hasClass(l,"p-disabled")||a.DomHandler.hasClass(l,"p-listbox-item-group")?e(l):l:null},r=a.classNames("p-listbox-item",{"p-highlight":e.selected,"p-disabled":e.disabled},e.option.className),i=e.template?a.ObjectUtils.getJSXElement(e.template,e.option):e.label;return s.createElement("li",{className:r,style:e.style,onClick:t,onTouchEnd:function(t){e.onTouchEnd&&e.onTouchEnd({originalEvent:t,option:e.option})},onKeyDown:function(e){var r=e.currentTarget;switch(e.which){case 40:var a=l(r);a&&a.focus(),e.preventDefault();break;case 38:var i=n(r);i&&i.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},i,s.createElement(u.Ripple,null))}));function S(e,t){var l=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),l.push.apply(l,n)}return l}function D(e){for(var t=1;t<arguments.length;t++){var l=null!=arguments[t]?arguments[t]:{};t%2?S(Object(l),!0).forEach((function(t){f(e,t,l[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(l)):S(Object(l)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(l,t))}))}return e}function w(e,t){var l="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!l){if(Array.isArray(e)||(l=P(e))||t&&e&&"number"==typeof e.length){l&&(e=l);var n=0,r=function(){};return{s:r,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:r}}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 a,i=!0,o=!1;return{s:function(){l=l.call(e)},n:function(){var e=l.next();return i=e.done,e},e:function(e){o=!0,a=e},f:function(){try{i||null==l.return||l.return()}finally{if(o)throw a}}}}function P(e,t){if(e){if("string"==typeof e)return C(e,t);var l=Object.prototype.toString.call(e).slice(8,-1);return"Object"===l&&e.constructor&&(l=e.constructor.name),"Map"===l||"Set"===l?Array.from(e):"Arguments"===l||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(l)?C(e,t):void 0}}function C(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=new Array(t);l<t;l++)n[l]=e[l];return n}x.displayName="ListBoxItem";var L=s.memo(s.forwardRef((function(e,t){var o,u,c=s.useState(""),f=(u=2,g(o=c)||O(o,u)||v(o,u)||E()),d=f[0],b=f[1],m=s.useRef(null),y=s.useRef(null),S=s.useRef(!1),P=(e.onFilterValueChange?e.filterValue:d)||"",C=P&&P.trim().length>0,N=function(t){var l=t.option;e.disabled||H(l)||(e.multiple?F(t.originalEvent,l):T(t.originalEvent,l),S.current=!1)},I=function(){e.disabled||(S.current=!0)},T=function(t,l){var n=V(l),r=!1,a=null;!S.current&&e.metaKeySelection?n?(t.metaKey||t.ctrlKey)&&(a=null,r=!0):(a=B(l),r=!0):(a=n?null:B(l),r=!0);r&&A(t,a)},F=function(t,l){var n=V(l),r=!1,a=null;if(!S&&e.metaKeySelection){var i=t.metaKey||t.ctrlKey;n?(a=i?k(l):[B(l)],r=!0):(a=[].concat(h(a=i&&e.value||[]),[B(l)]),r=!0)}else a=n?k(l):[].concat(h(e.value||[]),[B(l)]),r=!0;r&&e.onChange({originalEvent:t,value:a,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:a}})},U=function(t){y.current&&y.current.scrollToIndex(0);var l=t.value;e.onFilterValueChange?e.onFilterValueChange({originalEvent:t.originalEvent,value:l}):b(l)},A=function(t,l){e.onChange&&e.onChange({originalEvent:t,value:l,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:l}})},k=function(t){return e.value.filter((function(l){return!a.ObjectUtils.equals(l,B(t),e.dataKey)}))},K=function(){if(null!=e.value&&Q){if(!e.optionGroupLabel)return M(e.value,Q);for(var t=0;t<Q.length;t++){var l=M(e.value,J(Q[t]));if(-1!==l)return{group:t,option:l}}}return-1},G=function(){return e.optionValue?null:e.dataKey},M=function(e,t){var l=G();return t.findIndex((function(t){return a.ObjectUtils.equals(e,B(t),l)}))},V=function(t){var l=B(t),n=G();return e.multiple&&e.value?e.value.some((function(e){return a.ObjectUtils.equals(e,l,n)})):a.ObjectUtils.equals(e.value,l,n)},_=function(t){return e.optionLabel?a.ObjectUtils.resolveFieldData(t,e.optionLabel):t&&void 0!==t.label?t.label:t},B=function(t){return e.optionValue?a.ObjectUtils.resolveFieldData(t,e.optionValue):t&&void 0!==t.value?t.value:t},R=function(t){return e.dataKey?a.ObjectUtils.resolveFieldData(t,e.dataKey):_(t)},H=function(t){return e.optionDisabled?a.ObjectUtils.isFunction(e.optionDisabled)?e.optionDisabled(t):a.ObjectUtils.resolveFieldData(t,e.optionDisabled):!(!t||void 0===t.disabled)&&t.disabled},q=function(t){return a.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},z=function(t){return a.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},J=function(t){return a.ObjectUtils.resolveFieldData(t,e.optionGroupChildren)},X=function(){if(y.current){var e=K();-1!==e&&setTimeout((function(){return y.current.scrollToIndex(e)}),0)}};n.useMountEffect((function(){X()}));var $=function(t,l){return J(t).map((function(t,n){var r=_(t),a=n+"_"+R(t),i=H(t),o=i?null:e.tabIndex||0;return s.createElement(x,{key:a,label:r,option:t,style:l,template:e.itemTemplate,selected:V(t),onClick:N,onTouchEnd:I,tabIndex:o,disabled:i})}))},Y=function(t,l){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r={height:n.props?n.props.itemSize:void 0};if(e.optionGroupLabel){var i=e.optionGroupTemplate?a.ObjectUtils.getJSXElement(e.optionGroupTemplate,t,l):z(t),o=$(t,r),u=l+"_"+q(t);return s.createElement(s.Fragment,{key:u},s.createElement("li",{className:"p-listbox-item-group",style:r,role:"group"},i),o)}var c=_(t),p=l+"_"+R(t),f=H(t),d=f?null:e.tabIndex||0;return s.createElement(x,{key:p,label:c,option:t,style:r,template:e.itemTemplate,selected:V(t),onClick:N,onTouchEnd:I,tabIndex:d,disabled:f})},Q=function(){if(C){var t=P.trim().toLocaleLowerCase(e.filterLocale),n=e.filterBy?e.filterBy.split(","):[e.optionLabel||"label"];if(e.optionGroupLabel){var r,a=[],i=w(e.options);try{for(i.s();!(r=i.n()).done;){var o=r.value,u=l.FilterService.filter(J(o),n,t,e.filterMatchMode,e.filterLocale);u&&u.length&&a.push(D(D({},o),{items:u}))}}catch(e){i.e(e)}finally{i.f()}return a}return l.FilterService.filter(e.options,n,t,e.filterMatchMode,e.filterLocale)}return e.options}(),W=a.ObjectUtils.isNotEmpty(e.tooltip),Z=a.ObjectUtils.findDiffKeys(e,L.defaultProps),ee=a.classNames("p-listbox p-component",{"p-disabled":e.disabled},e.className),te=a.classNames("p-listbox-list-wrapper",e.listClassName),le=function(){if(e.virtualScrollerOptions){var t=D(D({},e.virtualScrollerOptions),{items:Q,onLazyLoad:function(t){return e.virtualScrollerOptions.onLazyLoad(D(D({},t),{filter:Q}))},itemTemplate:function(e,t){return e&&Y(e,t.index,t)},contentTemplate:function(t){var l=a.classNames("p-listbox-list",t.className);return s.createElement("ul",{ref:t.contentRef,className:l,role:"listbox","aria-multiselectable":e.multiple,"aria-labelledby":e["aria-labelledby"],"aria-label":e["aria-label"]},t.children)}});return s.createElement(i.VirtualScroller,p({ref:y},t))}var l=Q?Q.map(Y):null;return s.createElement("ul",{className:"p-listbox-list",role:"listbox","aria-multiselectable":e.multiple,"aria-labelledby":e["aria-labelledby"],"aria-label":e["aria-label"]},l)}(),ne=e.filter?s.createElement(j,{filter:P,onFilter:U,disabled:e.disabled,filterPlaceholder:e.filterPlaceholder,filterInputProps:e.filterInputProps}):null;return s.createElement(s.Fragment,null,s.createElement("div",p({ref:m,id:e.id,className:ee,style:e.style},Z),ne,s.createElement("div",{className:te,style:e.listStyle},le)),W&&s.createElement(r.Tooltip,p({target:m,content:e.tooltip},e.tooltipOptions)))})));return L.displayName="ListBox",L.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,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null},e.ListBox=L,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.hooks,primereact.tooltip,primereact.utils,primereact.virtualscroller,primereact.inputtext,primereact.ripple);
|
package/megamenu/megamenu.cjs.js
CHANGED
|
@@ -363,6 +363,7 @@ var MegaMenu = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
|
|
|
363
363
|
|
|
364
364
|
return /*#__PURE__*/React__namespace.createElement("li", {
|
|
365
365
|
key: key,
|
|
366
|
+
id: item.id,
|
|
366
367
|
className: _className2,
|
|
367
368
|
style: item.style,
|
|
368
369
|
role: "none"
|
|
@@ -378,6 +379,7 @@ var MegaMenu = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
|
|
|
378
379
|
return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, {
|
|
379
380
|
key: submenu.label
|
|
380
381
|
}, /*#__PURE__*/React__namespace.createElement("li", {
|
|
382
|
+
id: submenu.id,
|
|
381
383
|
className: className,
|
|
382
384
|
style: submenu.style,
|
|
383
385
|
role: "presentation"
|
|
@@ -444,6 +446,7 @@ var MegaMenu = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
|
|
|
444
446
|
var panel = createCategoryPanel(category);
|
|
445
447
|
return /*#__PURE__*/React__namespace.createElement("li", {
|
|
446
448
|
key: category.label + '_' + index,
|
|
449
|
+
id: category.id,
|
|
447
450
|
className: className,
|
|
448
451
|
style: category.style,
|
|
449
452
|
onMouseEnter: function onMouseEnter(e) {
|
|
@@ -467,19 +470,36 @@ var MegaMenu = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
|
|
|
467
470
|
|
|
468
471
|
var createMenu = function createMenu() {
|
|
469
472
|
if (props.model) {
|
|
470
|
-
return
|
|
473
|
+
return /*#__PURE__*/React__namespace.createElement("ul", {
|
|
474
|
+
className: "p-megamenu-root-list",
|
|
475
|
+
role: "menubar"
|
|
476
|
+
}, props.model.map(function (item, index) {
|
|
471
477
|
return createCategory(item, index);
|
|
472
|
-
});
|
|
478
|
+
}));
|
|
473
479
|
}
|
|
474
480
|
|
|
475
481
|
return null;
|
|
476
482
|
};
|
|
477
483
|
|
|
478
|
-
var
|
|
479
|
-
if (props.
|
|
484
|
+
var createStartContent = function createStartContent() {
|
|
485
|
+
if (props.start) {
|
|
486
|
+
var _start = utils.ObjectUtils.getJSXElement(props.start, props);
|
|
487
|
+
|
|
488
|
+
return /*#__PURE__*/React__namespace.createElement("div", {
|
|
489
|
+
className: "p-megamenu-start"
|
|
490
|
+
}, _start);
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
return null;
|
|
494
|
+
};
|
|
495
|
+
|
|
496
|
+
var createEndContent = function createEndContent() {
|
|
497
|
+
if (props.end) {
|
|
498
|
+
var _end = utils.ObjectUtils.getJSXElement(props.end, props);
|
|
499
|
+
|
|
480
500
|
return /*#__PURE__*/React__namespace.createElement("div", {
|
|
481
|
-
className: "p-megamenu-
|
|
482
|
-
},
|
|
501
|
+
className: "p-megamenu-end"
|
|
502
|
+
}, _end);
|
|
483
503
|
}
|
|
484
504
|
|
|
485
505
|
return null;
|
|
@@ -491,16 +511,14 @@ var MegaMenu = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
|
|
|
491
511
|
'p-megamenu-vertical': props.orientation === 'vertical'
|
|
492
512
|
}, props.className);
|
|
493
513
|
var menu = createMenu();
|
|
494
|
-
var
|
|
514
|
+
var start = createStartContent();
|
|
515
|
+
var end = createEndContent();
|
|
495
516
|
return /*#__PURE__*/React__namespace.createElement("div", _extends({
|
|
496
517
|
ref: elementRef,
|
|
497
518
|
id: props.id,
|
|
498
519
|
className: className,
|
|
499
520
|
style: props.style
|
|
500
|
-
}, otherProps),
|
|
501
|
-
className: "p-megamenu-root-list",
|
|
502
|
-
role: "menubar"
|
|
503
|
-
}, menu), customContent);
|
|
521
|
+
}, otherProps), start, menu, end);
|
|
504
522
|
}));
|
|
505
523
|
MegaMenu.displayName = 'MegaMenu';
|
|
506
524
|
MegaMenu.defaultProps = {
|
|
@@ -509,7 +527,9 @@ MegaMenu.defaultProps = {
|
|
|
509
527
|
model: null,
|
|
510
528
|
style: null,
|
|
511
529
|
className: null,
|
|
512
|
-
orientation: 'horizontal'
|
|
530
|
+
orientation: 'horizontal',
|
|
531
|
+
start: null,
|
|
532
|
+
end: null
|
|
513
533
|
};
|
|
514
534
|
|
|
515
535
|
exports.MegaMenu = MegaMenu;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),n=require("primereact/hooks"),a=require("primereact/ripple"),r=require("primereact/utils");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function i(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var a=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,a.get?a:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var u=i(e),s=l(t);function m(){return m=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},m.apply(this,arguments)}function c(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 a,r,l=[],i=!0,u=!1;try{for(n=n.call(e);!(i=(a=n.next()).done)&&(l.push(a.value),!t||l.length!==t);i=!0);}catch(e){u=!0,r=e}finally{try{i||null==n.return||n.return()}finally{if(u)throw r}}return l}}function p(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,a=new Array(t);n<t;n++)a[n]=e[n];return a}function f(e,t){if(e){if("string"==typeof e)return p(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)?p(e,t):void 0}}function d(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function v(e,t){return c(e)||o(e,t)||f(e,t)||d()}var b=u.memo(u.forwardRef((function(e,t){var l=v(u.useState(null),2),i=l[0],c=l[1],o=u.useRef(null),p="horizontal"===e.orientation,f="vertical"===e.orientation,d=v(n.useEventListener({type:"click",listener:function(e){O(e)&&c(null)}}),1)[0],g=function(e,t){t.disabled?e.preventDefault():(t.url||e.preventDefault(),t.command&&t.command({originalEvent:e,item:t}),c(null))},y=function(e,t){var n=e.currentTarget.parentElement;switch(e.which){case 40:p?
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),n=require("primereact/hooks"),a=require("primereact/ripple"),r=require("primereact/utils");function l(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function i(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var a=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,a.get?a:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var u=i(e),s=l(t);function m(){return m=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},m.apply(this,arguments)}function c(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 a,r,l=[],i=!0,u=!1;try{for(n=n.call(e);!(i=(a=n.next()).done)&&(l.push(a.value),!t||l.length!==t);i=!0);}catch(e){u=!0,r=e}finally{try{i||null==n.return||n.return()}finally{if(u)throw r}}return l}}function p(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,a=new Array(t);n<t;n++)a[n]=e[n];return a}function f(e,t){if(e){if("string"==typeof e)return p(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)?p(e,t):void 0}}function d(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function v(e,t){return c(e)||o(e,t)||f(e,t)||d()}var b=u.memo(u.forwardRef((function(e,t){var l=v(u.useState(null),2),i=l[0],c=l[1],o=u.useRef(null),p="horizontal"===e.orientation,f="vertical"===e.orientation,d=v(n.useEventListener({type:"click",listener:function(e){O(e)&&c(null)}}),1)[0],g=function(e,t){t.disabled?e.preventDefault():(t.url||e.preventDefault(),t.command&&t.command({originalEvent:e,item:t}),c(null))},y=function(e,t){var n=e.currentTarget.parentElement;switch(e.which){case 40:p?N(t):j(n),e.preventDefault();break;case 38:f?D(n):t.items&&t===i&&E(),e.preventDefault();break;case 39:p?j(n):N(t),e.preventDefault();break;case 37:p?D(n):t.items&&t===i&&E(),e.preventDefault()}},N=function(e){e.items&&c(e)},E=function(e){c(null)},h=function e(t){var n=t.nextElementSibling;return n?r.DomHandler.hasClass(n,"p-disabled")||!r.DomHandler.hasClass(n,"p-menuitem")?e(n):n:null},k=function e(t){var n=t.previousElementSibling;return n?r.DomHandler.hasClass(n,"p-disabled")||!r.DomHandler.hasClass(n,"p-menuitem")?e(n):n:null},j=function(e){var t=h(e);t&&t.children[0].focus()},D=function(e){var t=k(e);t&&t.children[0].focus()},O=function(e){return o.current&&!(o.current.isSameNode(e.target)||o.current.contains(e.target))},S=function(e){var t;switch(e.items?e.items.length:0){case 2:t="p-megamenu-col-6";break;case 3:t="p-megamenu-col-4";break;case 4:t="p-megamenu-col-3";break;case 6:t="p-megamenu-col-2";break;default:t="p-megamenu-col-12"}return t};n.useMountEffect((function(){d()})),n.useUpdateEffect((function(){var e=r.DomHandler.findSingle(o.current,".p-menuitem-active > .p-megamenu-panel");return i&&r.ZIndexUtils.set("menu",e,s.default.autoZIndex,s.default.zIndex.menu),function(){r.ZIndexUtils.clear(e)}}),[i]);var w=function(e){return u.createElement("li",{key:"separator_"+e,className:"p-menu-separator",role:"separator"})},x=function(e){if(e.items){var t=r.classNames("p-submenu-icon pi",{"pi-angle-down":p,"pi-angle-right":f});return u.createElement("span",{className:t})}return null},I=function(t,n){if(t.separator)return w(n);var l=t.label+"_"+n,i=r.classNames("p-menuitem",t.className),s=r.classNames("p-menuitem-link",{"p-disabled":t.disabled}),m=r.classNames(t.icon,"p-menuitem-icon"),c=r.IconUtils.getJSXIcon(t.icon,{className:"p-menuitem-icon"},{props:e}),o=u.createElement("a",{href:t.url||"#",className:s,target:t.target,onClick:function(e){return g(e,t)},role:"menuitem","aria-disabled":t.disabled},c,t.label&&u.createElement("span",{className:"p-menuitem-text"},t.label),u.createElement(a.Ripple,null));return t.template&&(o=r.ObjectUtils.getJSXElement(t.template,t,{onClick:function(e){return g(e,t)},className:s,labelClassName:"p-menuitem-text",iconClassName:m,element:o,props:e})),u.createElement("li",{key:l,id:t.id,className:i,style:t.style,role:"none"},o)},M=function(e){var t=r.classNames("p-megamenu-submenu-header",{"p-disabled":e.disabled},e.className),n=e.items.map(I);return u.createElement(u.Fragment,{key:e.label},u.createElement("li",{id:e.id,className:t,style:e.style,role:"presentation"},e.label),n)},U=function(e){return e.map(M)},_=function(e,t,n,a){var r=e.label+"_column_"+n,l=U(t);return u.createElement("div",{key:r,className:a},u.createElement("ul",{className:"p-megamenu-submenu",role:"menu"},l))},C=function(e){if(e.items){var t=S(e);return e.items.map((function(n,a){return _(e,n,a,t)}))}return null},P=function(e){if(e.items){var t=C(e);return u.createElement("div",{className:"p-megamenu-panel"},u.createElement("div",{className:"p-megamenu-grid"},t))}return null},z=function(t,n){var l=r.classNames("p-menuitem",{"p-menuitem-active":t===i},t.className),s=r.classNames("p-menuitem-link",{"p-disabled":t.disabled}),m=r.IconUtils.getJSXIcon(t.icon,{className:"p-menuitem-icon"},{props:e}),o=t.label&&u.createElement("span",{className:"p-menuitem-text"},t.label),p=t.template?r.ObjectUtils.getJSXElement(t.template,t):null,f=x(t),d=P(t);return u.createElement("li",{key:t.label+"_"+n,id:t.id,className:l,style:t.style,onMouseEnter:function(e){return n=e,void((a=t).disabled?n.preventDefault():i&&c(a));var n,a},role:"none"},u.createElement("a",{href:t.url||"#",className:s,target:t.target,onClick:function(n){return a=n,(r=t).disabled||(r.url||a.preventDefault(),r.command&&r.command({originalEvent:a,item:e.item}),r.items&&c(i&&i===r?null:r)),void a.preventDefault();var a,r},onKeyDown:function(e){return y(e,t)},role:"menuitem","aria-haspopup":null!=t.items},m,o,p,f,u.createElement(a.Ripple,null)),d)},A=r.ObjectUtils.findDiffKeys(e,b.defaultProps),J=r.classNames("p-megamenu p-component",{"p-megamenu-horizontal":"horizontal"===e.orientation,"p-megamenu-vertical":"vertical"===e.orientation},e.className),X=e.model?u.createElement("ul",{className:"p-megamenu-root-list",role:"menubar"},e.model.map((function(e,t){return z(e,t)}))):null,q=function(){if(e.start){var t=r.ObjectUtils.getJSXElement(e.start,e);return u.createElement("div",{className:"p-megamenu-start"},t)}return null}(),H=function(){if(e.end){var t=r.ObjectUtils.getJSXElement(e.end,e);return u.createElement("div",{className:"p-megamenu-end"},t)}return null}();return u.createElement("div",m({ref:o,id:e.id,className:J,style:e.style},A),q,X,H)})));b.displayName="MegaMenu",b.defaultProps={__TYPE:"MegaMenu",id:null,model:null,style:null,className:null,orientation:"horizontal",start:null,end:null},exports.MegaMenu=b;
|
package/megamenu/megamenu.d.ts
CHANGED
|
@@ -3,12 +3,19 @@ import { MenuItem } from '../menuitem';
|
|
|
3
3
|
|
|
4
4
|
type MegaMenuOrientationType = 'vertical' | 'horizontal';
|
|
5
5
|
|
|
6
|
+
type MegaMenuStartTemplate = React.ReactNode | ((props: MegaMenuProps) => React.ReactNode);
|
|
7
|
+
|
|
8
|
+
type MegaMenuEndTemplate = React.ReactNode | ((props: MegaMenuProps) => React.ReactNode);
|
|
9
|
+
|
|
10
|
+
|
|
6
11
|
export interface MegaMenuProps {
|
|
7
12
|
id?: string;
|
|
8
13
|
model?: MenuItem[];
|
|
9
14
|
style?: object;
|
|
10
15
|
className?: string;
|
|
11
16
|
orientation?: MegaMenuOrientationType;
|
|
17
|
+
start?: MegaMenuStartTemplate;
|
|
18
|
+
end?: MegaMenuEndTemplate;
|
|
12
19
|
children?: React.ReactNode;
|
|
13
20
|
}
|
|
14
21
|
|