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.
Files changed (335) hide show
  1. package/autocomplete/autocomplete.cjs.js +19 -10
  2. package/autocomplete/autocomplete.cjs.min.js +1 -1
  3. package/autocomplete/autocomplete.esm.js +20 -11
  4. package/autocomplete/autocomplete.esm.min.js +1 -1
  5. package/autocomplete/autocomplete.js +19 -10
  6. package/autocomplete/autocomplete.min.js +1 -1
  7. package/avatar/avatar.cjs.js +7 -7
  8. package/avatar/avatar.cjs.min.js +1 -1
  9. package/avatar/avatar.d.ts +1 -3
  10. package/avatar/avatar.esm.js +7 -7
  11. package/avatar/avatar.esm.min.js +1 -1
  12. package/avatar/avatar.js +7 -7
  13. package/avatar/avatar.min.js +1 -1
  14. package/badge/badge.cjs.js +2 -2
  15. package/badge/badge.cjs.min.js +1 -1
  16. package/badge/badge.d.ts +2 -4
  17. package/badge/badge.esm.js +2 -2
  18. package/badge/badge.esm.min.js +1 -1
  19. package/badge/badge.js +2 -2
  20. package/badge/badge.min.js +1 -1
  21. package/calendar/calendar.cjs.js +77 -4
  22. package/calendar/calendar.cjs.min.js +1 -1
  23. package/calendar/calendar.d.ts +1 -0
  24. package/calendar/calendar.esm.js +77 -4
  25. package/calendar/calendar.esm.min.js +1 -1
  26. package/calendar/calendar.js +77 -4
  27. package/calendar/calendar.min.js +1 -1
  28. package/card/card.d.ts +1 -4
  29. package/cascadeselect/cascadeselect.cjs.js +3 -3
  30. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  31. package/cascadeselect/cascadeselect.d.ts +1 -1
  32. package/cascadeselect/cascadeselect.esm.js +3 -3
  33. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  34. package/cascadeselect/cascadeselect.js +3 -3
  35. package/cascadeselect/cascadeselect.min.js +1 -1
  36. package/chart/chart.cjs.js +13 -7
  37. package/chart/chart.cjs.min.js +1 -1
  38. package/chart/chart.esm.js +13 -7
  39. package/chart/chart.esm.min.js +1 -1
  40. package/chart/chart.js +13 -7
  41. package/chart/chart.min.js +1 -1
  42. package/checkbox/checkbox.cjs.js +1 -1
  43. package/checkbox/checkbox.cjs.min.js +1 -1
  44. package/checkbox/checkbox.esm.js +2 -2
  45. package/checkbox/checkbox.esm.min.js +1 -1
  46. package/checkbox/checkbox.js +1 -1
  47. package/checkbox/checkbox.min.js +1 -1
  48. package/chip/chip.d.ts +1 -3
  49. package/chips/chips.cjs.js +18 -2
  50. package/chips/chips.cjs.min.js +1 -1
  51. package/chips/chips.d.ts +3 -0
  52. package/chips/chips.esm.js +19 -3
  53. package/chips/chips.esm.min.js +1 -1
  54. package/chips/chips.js +19 -4
  55. package/chips/chips.min.js +1 -1
  56. package/column/column.d.ts +1 -0
  57. package/confirmdialog/confirmdialog.d.ts +1 -6
  58. package/contextmenu/contextmenu.cjs.js +1 -0
  59. package/contextmenu/contextmenu.cjs.min.js +1 -1
  60. package/contextmenu/contextmenu.esm.js +1 -0
  61. package/contextmenu/contextmenu.esm.min.js +1 -1
  62. package/contextmenu/contextmenu.js +1 -0
  63. package/contextmenu/contextmenu.min.js +1 -1
  64. package/core/core.js +249 -117
  65. package/core/core.min.js +9 -9
  66. package/datatable/datatable.cjs.js +63 -25
  67. package/datatable/datatable.cjs.min.js +1 -1
  68. package/datatable/datatable.esm.js +64 -26
  69. package/datatable/datatable.esm.min.js +1 -1
  70. package/datatable/datatable.js +63 -25
  71. package/datatable/datatable.min.js +1 -1
  72. package/dialog/dialog.cjs.js +2 -2
  73. package/dialog/dialog.cjs.min.js +1 -1
  74. package/dialog/dialog.esm.js +2 -2
  75. package/dialog/dialog.esm.min.js +1 -1
  76. package/dialog/dialog.js +2 -2
  77. package/dialog/dialog.min.js +1 -1
  78. package/dropdown/dropdown.cjs.js +29 -17
  79. package/dropdown/dropdown.cjs.min.js +1 -1
  80. package/dropdown/dropdown.d.ts +1 -1
  81. package/dropdown/dropdown.esm.js +29 -17
  82. package/dropdown/dropdown.esm.min.js +1 -1
  83. package/dropdown/dropdown.js +29 -17
  84. package/dropdown/dropdown.min.js +1 -1
  85. package/editor/editor.cjs.js +11 -3
  86. package/editor/editor.cjs.min.js +1 -1
  87. package/editor/editor.esm.js +11 -3
  88. package/editor/editor.esm.min.js +1 -1
  89. package/editor/editor.js +11 -3
  90. package/editor/editor.min.js +1 -1
  91. package/image/image.cjs.js +5 -5
  92. package/image/image.cjs.min.js +1 -1
  93. package/image/image.d.ts +1 -3
  94. package/image/image.esm.js +5 -5
  95. package/image/image.esm.min.js +1 -1
  96. package/image/image.js +5 -5
  97. package/image/image.min.css +1 -1
  98. package/image/image.min.js +1 -1
  99. package/inplace/inplace.cjs.js +1 -1
  100. package/inplace/inplace.cjs.min.js +1 -1
  101. package/inplace/inplace.esm.js +1 -1
  102. package/inplace/inplace.esm.min.js +1 -1
  103. package/inplace/inplace.js +1 -1
  104. package/inplace/inplace.min.js +1 -1
  105. package/inputmask/inputmask.cjs.js +7 -5
  106. package/inputmask/inputmask.cjs.min.js +1 -1
  107. package/inputmask/inputmask.d.ts +0 -1
  108. package/inputmask/inputmask.esm.js +7 -5
  109. package/inputmask/inputmask.esm.min.js +1 -1
  110. package/inputmask/inputmask.js +7 -5
  111. package/inputmask/inputmask.min.js +1 -1
  112. package/inputnumber/inputnumber.cjs.js +2 -2
  113. package/inputnumber/inputnumber.cjs.min.js +1 -1
  114. package/inputnumber/inputnumber.esm.js +2 -2
  115. package/inputnumber/inputnumber.esm.min.js +1 -1
  116. package/inputnumber/inputnumber.js +2 -2
  117. package/inputnumber/inputnumber.min.js +1 -1
  118. package/inputswitch/inputswitch.cjs.js +1 -1
  119. package/inputswitch/inputswitch.cjs.min.js +1 -1
  120. package/inputswitch/inputswitch.esm.js +2 -2
  121. package/inputswitch/inputswitch.esm.min.js +1 -1
  122. package/inputswitch/inputswitch.js +1 -1
  123. package/inputswitch/inputswitch.min.css +1 -1
  124. package/inputswitch/inputswitch.min.js +1 -1
  125. package/inputtext/inputtext.min.css +1 -1
  126. package/listbox/listbox.cjs.js +66 -6
  127. package/listbox/listbox.cjs.min.js +1 -1
  128. package/listbox/listbox.d.ts +1 -1
  129. package/listbox/listbox.esm.js +66 -6
  130. package/listbox/listbox.esm.min.js +1 -1
  131. package/listbox/listbox.js +67 -8
  132. package/listbox/listbox.min.js +1 -1
  133. package/megamenu/megamenu.cjs.js +32 -12
  134. package/megamenu/megamenu.cjs.min.js +1 -1
  135. package/megamenu/megamenu.d.ts +7 -0
  136. package/megamenu/megamenu.esm.js +32 -12
  137. package/megamenu/megamenu.esm.min.js +1 -1
  138. package/megamenu/megamenu.js +32 -12
  139. package/megamenu/megamenu.min.css +1 -1
  140. package/megamenu/megamenu.min.js +1 -1
  141. package/mention/mention.cjs.js +1 -1
  142. package/mention/mention.cjs.min.js +1 -1
  143. package/mention/mention.esm.js +1 -1
  144. package/mention/mention.esm.min.js +1 -1
  145. package/mention/mention.js +1 -1
  146. package/mention/mention.min.js +1 -1
  147. package/menubar/menubar.cjs.js +1 -0
  148. package/menubar/menubar.cjs.min.js +1 -1
  149. package/menubar/menubar.esm.js +1 -0
  150. package/menubar/menubar.esm.min.js +1 -1
  151. package/menubar/menubar.js +1 -0
  152. package/menubar/menubar.min.js +1 -1
  153. package/menuitem/menuitem.d.ts +2 -0
  154. package/message/message.d.ts +1 -1
  155. package/messages/messages.cjs.js +3 -2
  156. package/messages/messages.cjs.min.js +1 -1
  157. package/messages/messages.d.ts +1 -1
  158. package/messages/messages.esm.js +3 -2
  159. package/messages/messages.esm.min.js +1 -1
  160. package/messages/messages.js +3 -2
  161. package/messages/messages.min.js +1 -1
  162. package/multiselect/multiselect.cjs.js +20 -10
  163. package/multiselect/multiselect.cjs.min.js +1 -1
  164. package/multiselect/multiselect.d.ts +1 -1
  165. package/multiselect/multiselect.esm.js +20 -10
  166. package/multiselect/multiselect.esm.min.js +1 -1
  167. package/multiselect/multiselect.js +20 -10
  168. package/multiselect/multiselect.min.js +1 -1
  169. package/overlaypanel/overlaypanel.cjs.js +1 -1
  170. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  171. package/overlaypanel/overlaypanel.esm.js +1 -1
  172. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  173. package/overlaypanel/overlaypanel.js +1 -1
  174. package/overlaypanel/overlaypanel.min.js +1 -1
  175. package/package.json +1 -1
  176. package/panelmenu/panelmenu.cjs.js +1 -0
  177. package/panelmenu/panelmenu.cjs.min.js +1 -1
  178. package/panelmenu/panelmenu.esm.js +1 -0
  179. package/panelmenu/panelmenu.esm.min.js +1 -1
  180. package/panelmenu/panelmenu.js +1 -0
  181. package/panelmenu/panelmenu.min.js +1 -1
  182. package/picklist/picklist.cjs.js +169 -14
  183. package/picklist/picklist.cjs.min.js +1 -1
  184. package/picklist/picklist.d.ts +29 -0
  185. package/picklist/picklist.esm.js +169 -14
  186. package/picklist/picklist.esm.min.js +1 -1
  187. package/picklist/picklist.js +170 -16
  188. package/picklist/picklist.min.css +1 -1
  189. package/picklist/picklist.min.js +1 -1
  190. package/primereact.all.cjs.js +924 -387
  191. package/primereact.all.cjs.min.js +1 -1
  192. package/primereact.all.esm.js +924 -387
  193. package/primereact.all.esm.min.js +1 -1
  194. package/primereact.all.js +924 -387
  195. package/primereact.all.min.js +1 -1
  196. package/radiobutton/radiobutton.cjs.js +1 -1
  197. package/radiobutton/radiobutton.cjs.min.js +1 -1
  198. package/radiobutton/radiobutton.esm.js +2 -2
  199. package/radiobutton/radiobutton.esm.min.js +1 -1
  200. package/radiobutton/radiobutton.js +1 -1
  201. package/radiobutton/radiobutton.min.js +1 -1
  202. package/resources/primereact.css +248 -194
  203. package/resources/primereact.min.css +1 -1
  204. package/resources/themes/arya-blue/theme.css +20 -6
  205. package/resources/themes/arya-green/theme.css +20 -6
  206. package/resources/themes/arya-orange/theme.css +20 -6
  207. package/resources/themes/arya-purple/theme.css +20 -6
  208. package/resources/themes/bootstrap4-dark-blue/theme.css +20 -6
  209. package/resources/themes/bootstrap4-dark-purple/theme.css +20 -6
  210. package/resources/themes/bootstrap4-light-blue/theme.css +19 -5
  211. package/resources/themes/bootstrap4-light-purple/theme.css +19 -5
  212. package/resources/themes/fluent-light/theme.css +20 -6
  213. package/resources/themes/lara-dark-blue/theme.css +20 -6
  214. package/resources/themes/lara-dark-indigo/theme.css +20 -6
  215. package/resources/themes/lara-dark-purple/theme.css +20 -6
  216. package/resources/themes/lara-dark-teal/theme.css +20 -6
  217. package/resources/themes/lara-light-blue/theme.css +20 -6
  218. package/resources/themes/lara-light-indigo/theme.css +20 -6
  219. package/resources/themes/lara-light-purple/theme.css +20 -6
  220. package/resources/themes/lara-light-teal/theme.css +20 -6
  221. package/resources/themes/luna-amber/theme.css +20 -6
  222. package/resources/themes/luna-blue/theme.css +20 -6
  223. package/resources/themes/luna-green/theme.css +20 -6
  224. package/resources/themes/luna-pink/theme.css +20 -6
  225. package/resources/themes/md-dark-deeppurple/theme.css +20 -6
  226. package/resources/themes/md-dark-indigo/theme.css +20 -6
  227. package/resources/themes/md-light-deeppurple/theme.css +20 -6
  228. package/resources/themes/md-light-indigo/theme.css +20 -6
  229. package/resources/themes/mdc-dark-deeppurple/theme.css +20 -6
  230. package/resources/themes/mdc-dark-indigo/theme.css +20 -6
  231. package/resources/themes/mdc-light-deeppurple/theme.css +20 -6
  232. package/resources/themes/mdc-light-indigo/theme.css +20 -6
  233. package/resources/themes/nova/theme.css +20 -6
  234. package/resources/themes/nova-accent/theme.css +20 -6
  235. package/resources/themes/nova-alt/theme.css +20 -6
  236. package/resources/themes/rhea/theme.css +20 -6
  237. package/resources/themes/saga-blue/theme.css +20 -6
  238. package/resources/themes/saga-green/theme.css +20 -6
  239. package/resources/themes/saga-orange/theme.css +20 -6
  240. package/resources/themes/saga-purple/theme.css +20 -6
  241. package/resources/themes/tailwind-light/theme.css +20 -6
  242. package/resources/themes/vela-blue/theme.css +20 -6
  243. package/resources/themes/vela-green/theme.css +20 -6
  244. package/resources/themes/vela-orange/theme.css +20 -6
  245. package/resources/themes/vela-purple/theme.css +20 -6
  246. package/selectbutton/selectbutton.d.ts +1 -1
  247. package/slidemenu/slidemenu.cjs.js +1 -0
  248. package/slidemenu/slidemenu.cjs.min.js +1 -1
  249. package/slidemenu/slidemenu.esm.js +1 -0
  250. package/slidemenu/slidemenu.esm.min.js +1 -1
  251. package/slidemenu/slidemenu.js +1 -0
  252. package/slidemenu/slidemenu.min.js +1 -1
  253. package/slider/slider.d.ts +1 -1
  254. package/splitbutton/splitbutton.cjs.js +4 -0
  255. package/splitbutton/splitbutton.cjs.min.js +1 -1
  256. package/splitbutton/splitbutton.d.ts +2 -0
  257. package/splitbutton/splitbutton.esm.js +4 -0
  258. package/splitbutton/splitbutton.esm.min.js +1 -1
  259. package/splitbutton/splitbutton.js +4 -0
  260. package/splitbutton/splitbutton.min.js +1 -1
  261. package/splitter/splitter.cjs.js +9 -5
  262. package/splitter/splitter.cjs.min.js +1 -1
  263. package/splitter/splitter.esm.js +10 -6
  264. package/splitter/splitter.esm.min.js +1 -1
  265. package/splitter/splitter.js +9 -5
  266. package/splitter/splitter.min.js +1 -1
  267. package/steps/steps.cjs.js +1 -0
  268. package/steps/steps.cjs.min.js +1 -1
  269. package/steps/steps.esm.js +1 -0
  270. package/steps/steps.esm.min.js +1 -1
  271. package/steps/steps.js +1 -0
  272. package/steps/steps.min.js +1 -1
  273. package/styleclass/styleclass.d.ts +1 -1
  274. package/tag/tag.d.ts +1 -1
  275. package/terminal/terminal.cjs.js +1 -1
  276. package/terminal/terminal.cjs.min.js +1 -1
  277. package/terminal/terminal.esm.js +2 -2
  278. package/terminal/terminal.esm.min.js +1 -1
  279. package/terminal/terminal.js +1 -1
  280. package/terminal/terminal.min.js +1 -1
  281. package/tieredmenu/tieredmenu.cjs.js +3 -1
  282. package/tieredmenu/tieredmenu.cjs.min.js +1 -1
  283. package/tieredmenu/tieredmenu.esm.js +3 -1
  284. package/tieredmenu/tieredmenu.esm.min.js +1 -1
  285. package/tieredmenu/tieredmenu.js +3 -1
  286. package/tieredmenu/tieredmenu.min.js +1 -1
  287. package/toast/toast.cjs.js +30 -35
  288. package/toast/toast.cjs.min.js +1 -1
  289. package/toast/toast.d.ts +2 -1
  290. package/toast/toast.esm.js +30 -35
  291. package/toast/toast.esm.min.js +1 -1
  292. package/toast/toast.js +30 -35
  293. package/toast/toast.min.css +1 -1
  294. package/toast/toast.min.js +1 -1
  295. package/tooltip/tooltip.cjs.js +28 -22
  296. package/tooltip/tooltip.cjs.min.js +1 -1
  297. package/tooltip/tooltip.esm.js +28 -22
  298. package/tooltip/tooltip.esm.min.js +1 -1
  299. package/tooltip/tooltip.js +28 -22
  300. package/tooltip/tooltip.min.js +1 -1
  301. package/tree/tree.cjs.js +9 -1
  302. package/tree/tree.cjs.min.js +1 -1
  303. package/tree/tree.esm.js +9 -1
  304. package/tree/tree.esm.min.js +1 -1
  305. package/tree/tree.js +9 -1
  306. package/tree/tree.min.js +1 -1
  307. package/treeselect/treeselect.cjs.js +2 -2
  308. package/treeselect/treeselect.cjs.min.js +1 -1
  309. package/treeselect/treeselect.esm.js +2 -2
  310. package/treeselect/treeselect.esm.min.js +1 -1
  311. package/treeselect/treeselect.js +2 -2
  312. package/treeselect/treeselect.min.js +1 -1
  313. package/treetable/treetable.cjs.js +1 -0
  314. package/treetable/treetable.cjs.min.js +1 -1
  315. package/treetable/treetable.d.ts +2 -2
  316. package/treetable/treetable.esm.js +1 -0
  317. package/treetable/treetable.esm.min.js +1 -1
  318. package/treetable/treetable.js +1 -0
  319. package/treetable/treetable.min.js +1 -1
  320. package/utils/utils.cjs.js +21 -5
  321. package/utils/utils.cjs.min.js +1 -1
  322. package/utils/utils.d.ts +1 -0
  323. package/utils/utils.esm.js +21 -5
  324. package/utils/utils.esm.min.js +1 -1
  325. package/utils/utils.js +21 -5
  326. package/utils/utils.min.js +1 -1
  327. package/virtualscroller/virtualscroller.cjs.js +154 -65
  328. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  329. package/virtualscroller/virtualscroller.d.ts +12 -0
  330. package/virtualscroller/virtualscroller.esm.js +156 -67
  331. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  332. package/virtualscroller/virtualscroller.js +154 -65
  333. package/virtualscroller/virtualscroller.min.css +1 -1
  334. package/virtualscroller/virtualscroller.min.js +1 -1
  335. package/web-types.json +167 -4
@@ -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, props.dataKey);
368
- }) : ObjectUtils.equals(props.value, optionValue, props.dataKey);
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, option) {
515
- return item && createItem(item, option.index);
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};
@@ -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, props.dataKey);
384
- }) : utils.ObjectUtils.equals(props.value, optionValue, props.dataKey);
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, option) {
531
- return item && createItem(item, option.index);
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);
@@ -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);
@@ -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 props.model.map(function (item, index) {
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 createCustomContent = function createCustomContent() {
479
- if (props.children) {
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-custom"
482
- }, props.children);
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 customContent = createCustomContent();
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), /*#__PURE__*/React__namespace.createElement("ul", {
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?h(t):D(n),e.preventDefault();break;case 38:f?j(n):t.items&&t===i&&N(),e.preventDefault();break;case 39:p?D(n):h(t),e.preventDefault();break;case 37:p?j(n):t.items&&t===i&&N(),e.preventDefault()}},h=function(e){e.items&&c(e)},N=function(e){c(null)},E=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},D=function(e){var t=E(e);t&&t.children[0].focus()},j=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,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",{className:t,style:e.style,role:"presentation"},e.label),n)},_=function(e){return e.map(M)},C=function(e,t,n,a){var r=e.label+"_column_"+n,l=_(t);return u.createElement("div",{key:r,className:a},u.createElement("ul",{className:"p-megamenu-submenu",role:"menu"},l))},U=function(e){if(e.items){var t=S(e);return e.items.map((function(n,a){return C(e,n,a,t)}))}return null},P=function(e){if(e.items){var t=U(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,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),q=r.classNames("p-megamenu p-component",{"p-megamenu-horizontal":"horizontal"===e.orientation,"p-megamenu-vertical":"vertical"===e.orientation},e.className),H=e.model?e.model.map((function(e,t){return z(e,t)})):null,J=e.children?u.createElement("div",{className:"p-megamenu-custom"},e.children):null;return u.createElement("div",m({ref:o,id:e.id,className:q,style:e.style},A),u.createElement("ul",{className:"p-megamenu-root-list",role:"menubar"},H),J)})));b.displayName="MegaMenu",b.defaultProps={__TYPE:"MegaMenu",id:null,model:null,style:null,className:null,orientation:"horizontal"},exports.MegaMenu=b;
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;
@@ -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