primereact 8.1.0 → 8.3.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 (691) hide show
  1. package/README.md +6 -0
  2. package/accordion/accordion.cjs.js +9 -0
  3. package/accordion/accordion.cjs.min.js +1 -1
  4. package/accordion/accordion.d.ts +4 -5
  5. package/accordion/accordion.esm.js +9 -0
  6. package/accordion/accordion.esm.min.js +1 -1
  7. package/accordion/accordion.js +9 -0
  8. package/accordion/accordion.min.js +1 -1
  9. package/autocomplete/autocomplete.cjs.js +65 -36
  10. package/autocomplete/autocomplete.cjs.min.js +1 -1
  11. package/autocomplete/autocomplete.d.ts +5 -1
  12. package/autocomplete/autocomplete.esm.js +66 -37
  13. package/autocomplete/autocomplete.esm.min.js +1 -1
  14. package/autocomplete/autocomplete.js +65 -36
  15. package/autocomplete/autocomplete.min.js +1 -1
  16. package/avatar/avatar.cjs.js +35 -7
  17. package/avatar/avatar.cjs.min.js +1 -1
  18. package/avatar/avatar.d.ts +4 -4
  19. package/avatar/avatar.esm.js +35 -7
  20. package/avatar/avatar.esm.min.js +1 -1
  21. package/avatar/avatar.js +35 -7
  22. package/avatar/avatar.min.js +1 -1
  23. package/avatargroup/avatargroup.cjs.js +27 -0
  24. package/avatargroup/avatargroup.cjs.min.js +1 -1
  25. package/avatargroup/avatargroup.d.ts +4 -4
  26. package/avatargroup/avatargroup.esm.js +27 -0
  27. package/avatargroup/avatargroup.esm.min.js +1 -1
  28. package/avatargroup/avatargroup.js +27 -0
  29. package/avatargroup/avatargroup.min.js +1 -1
  30. package/badge/badge.cjs.js +14 -2
  31. package/badge/badge.cjs.min.js +1 -1
  32. package/badge/badge.d.ts +5 -5
  33. package/badge/badge.esm.js +14 -2
  34. package/badge/badge.esm.min.js +1 -1
  35. package/badge/badge.js +14 -2
  36. package/badge/badge.min.js +1 -1
  37. package/blockui/blockui.cjs.js +26 -3
  38. package/blockui/blockui.cjs.min.js +1 -1
  39. package/blockui/blockui.d.ts +2 -4
  40. package/blockui/blockui.esm.js +26 -3
  41. package/blockui/blockui.esm.min.js +1 -1
  42. package/blockui/blockui.js +26 -3
  43. package/blockui/blockui.min.js +1 -1
  44. package/breadcrumb/breadcrumb.cjs.js +28 -0
  45. package/breadcrumb/breadcrumb.cjs.min.js +1 -1
  46. package/breadcrumb/breadcrumb.d.ts +4 -5
  47. package/breadcrumb/breadcrumb.esm.js +28 -0
  48. package/breadcrumb/breadcrumb.esm.min.js +1 -1
  49. package/breadcrumb/breadcrumb.js +28 -0
  50. package/breadcrumb/breadcrumb.min.js +1 -1
  51. package/button/button.d.ts +3 -1
  52. package/calendar/calendar.cjs.js +138 -46
  53. package/calendar/calendar.cjs.min.js +1 -1
  54. package/calendar/calendar.d.ts +4 -0
  55. package/calendar/calendar.esm.js +138 -46
  56. package/calendar/calendar.esm.min.js +1 -1
  57. package/calendar/calendar.js +138 -46
  58. package/calendar/calendar.min.js +1 -1
  59. package/captcha/captcha.cjs.js +24 -3
  60. package/captcha/captcha.cjs.min.js +1 -1
  61. package/captcha/captcha.d.ts +2 -3
  62. package/captcha/captcha.esm.js +24 -3
  63. package/captcha/captcha.esm.min.js +1 -1
  64. package/captcha/captcha.js +24 -3
  65. package/captcha/captcha.min.js +1 -1
  66. package/card/card.d.ts +1 -4
  67. package/carousel/carousel.cjs.js +25 -0
  68. package/carousel/carousel.cjs.min.js +1 -1
  69. package/carousel/carousel.d.ts +4 -5
  70. package/carousel/carousel.esm.js +25 -0
  71. package/carousel/carousel.esm.min.js +1 -1
  72. package/carousel/carousel.js +25 -0
  73. package/carousel/carousel.min.js +1 -1
  74. package/cascadeselect/cascadeselect.cjs.js +38 -3
  75. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  76. package/cascadeselect/cascadeselect.d.ts +7 -2
  77. package/cascadeselect/cascadeselect.esm.js +38 -3
  78. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  79. package/cascadeselect/cascadeselect.js +38 -3
  80. package/cascadeselect/cascadeselect.min.js +1 -1
  81. package/chart/chart.cjs.js +72 -25
  82. package/chart/chart.cjs.min.js +1 -1
  83. package/chart/chart.d.ts +1 -0
  84. package/chart/chart.esm.js +72 -25
  85. package/chart/chart.esm.min.js +1 -1
  86. package/chart/chart.js +72 -25
  87. package/chart/chart.min.js +1 -1
  88. package/checkbox/checkbox.cjs.js +30 -1
  89. package/checkbox/checkbox.cjs.min.js +1 -1
  90. package/checkbox/checkbox.d.ts +4 -1
  91. package/checkbox/checkbox.esm.js +31 -2
  92. package/checkbox/checkbox.esm.min.js +1 -1
  93. package/checkbox/checkbox.js +30 -1
  94. package/checkbox/checkbox.min.js +1 -1
  95. package/chip/chip.cjs.js +28 -0
  96. package/chip/chip.cjs.min.js +1 -1
  97. package/chip/chip.d.ts +4 -4
  98. package/chip/chip.esm.js +28 -0
  99. package/chip/chip.esm.min.js +1 -1
  100. package/chip/chip.js +28 -0
  101. package/chip/chip.min.js +1 -1
  102. package/chips/chips.cjs.js +56 -2
  103. package/chips/chips.cjs.min.js +1 -1
  104. package/chips/chips.d.ts +9 -5
  105. package/chips/chips.esm.js +57 -3
  106. package/chips/chips.esm.min.js +1 -1
  107. package/chips/chips.js +57 -4
  108. package/chips/chips.min.js +1 -1
  109. package/colorpicker/colorpicker.cjs.js +33 -0
  110. package/colorpicker/colorpicker.cjs.min.js +1 -1
  111. package/colorpicker/colorpicker.d.ts +7 -1
  112. package/colorpicker/colorpicker.esm.js +33 -0
  113. package/colorpicker/colorpicker.esm.min.js +1 -1
  114. package/colorpicker/colorpicker.js +33 -0
  115. package/colorpicker/colorpicker.min.js +1 -1
  116. package/column/column.d.ts +1 -0
  117. package/confirmdialog/confirmdialog.cjs.js +3 -3
  118. package/confirmdialog/confirmdialog.cjs.min.js +1 -1
  119. package/confirmdialog/confirmdialog.d.ts +1 -6
  120. package/confirmdialog/confirmdialog.esm.js +3 -3
  121. package/confirmdialog/confirmdialog.esm.min.js +1 -1
  122. package/confirmdialog/confirmdialog.js +3 -3
  123. package/confirmdialog/confirmdialog.min.js +1 -1
  124. package/confirmpopup/confirmpopup.cjs.js +2 -2
  125. package/confirmpopup/confirmpopup.cjs.min.js +1 -1
  126. package/confirmpopup/confirmpopup.esm.js +2 -2
  127. package/confirmpopup/confirmpopup.esm.min.js +1 -1
  128. package/confirmpopup/confirmpopup.js +2 -2
  129. package/confirmpopup/confirmpopup.min.js +1 -1
  130. package/contextmenu/contextmenu.cjs.js +25 -3
  131. package/contextmenu/contextmenu.cjs.min.js +1 -1
  132. package/contextmenu/contextmenu.d.ts +2 -4
  133. package/contextmenu/contextmenu.esm.js +25 -3
  134. package/contextmenu/contextmenu.esm.min.js +1 -1
  135. package/contextmenu/contextmenu.js +25 -3
  136. package/contextmenu/contextmenu.min.js +1 -1
  137. package/core/core.js +599 -180
  138. package/core/core.min.js +12 -12
  139. package/datascroller/datascroller.cjs.js +29 -3
  140. package/datascroller/datascroller.cjs.min.js +1 -1
  141. package/datascroller/datascroller.d.ts +2 -4
  142. package/datascroller/datascroller.esm.js +29 -3
  143. package/datascroller/datascroller.esm.min.js +1 -1
  144. package/datascroller/datascroller.js +29 -3
  145. package/datascroller/datascroller.min.js +1 -1
  146. package/datatable/datatable.cjs.js +92 -30
  147. package/datatable/datatable.cjs.min.js +1 -1
  148. package/datatable/datatable.d.ts +5 -1
  149. package/datatable/datatable.esm.js +93 -31
  150. package/datatable/datatable.esm.min.js +1 -1
  151. package/datatable/datatable.js +92 -30
  152. package/datatable/datatable.min.js +1 -1
  153. package/dataview/dataview.cjs.js +12 -0
  154. package/dataview/dataview.cjs.min.js +1 -1
  155. package/dataview/dataview.d.ts +4 -5
  156. package/dataview/dataview.esm.js +12 -0
  157. package/dataview/dataview.esm.min.js +1 -1
  158. package/dataview/dataview.js +12 -0
  159. package/dataview/dataview.min.js +1 -1
  160. package/deferredcontent/deferredcontent.cjs.js +25 -0
  161. package/deferredcontent/deferredcontent.cjs.min.js +1 -1
  162. package/deferredcontent/deferredcontent.d.ts +4 -2
  163. package/deferredcontent/deferredcontent.esm.js +25 -0
  164. package/deferredcontent/deferredcontent.esm.min.js +1 -1
  165. package/deferredcontent/deferredcontent.js +25 -0
  166. package/deferredcontent/deferredcontent.min.js +1 -1
  167. package/dialog/dialog.cjs.js +46 -6
  168. package/dialog/dialog.cjs.min.js +1 -1
  169. package/dialog/dialog.d.ts +8 -0
  170. package/dialog/dialog.esm.js +46 -6
  171. package/dialog/dialog.esm.min.js +1 -1
  172. package/dialog/dialog.js +46 -6
  173. package/dialog/dialog.min.js +1 -1
  174. package/divider/divider.cjs.js +27 -0
  175. package/divider/divider.cjs.min.js +1 -1
  176. package/divider/divider.d.ts +4 -4
  177. package/divider/divider.esm.js +27 -0
  178. package/divider/divider.esm.min.js +1 -1
  179. package/divider/divider.js +27 -0
  180. package/divider/divider.min.js +1 -1
  181. package/dock/dock.cjs.js +28 -0
  182. package/dock/dock.cjs.min.js +1 -1
  183. package/dock/dock.d.ts +4 -5
  184. package/dock/dock.esm.js +28 -0
  185. package/dock/dock.esm.min.js +1 -1
  186. package/dock/dock.js +28 -0
  187. package/dock/dock.min.js +1 -1
  188. package/dropdown/dropdown.cjs.js +85 -23
  189. package/dropdown/dropdown.cjs.min.js +1 -1
  190. package/dropdown/dropdown.d.ts +15 -2
  191. package/dropdown/dropdown.esm.js +85 -23
  192. package/dropdown/dropdown.esm.min.js +1 -1
  193. package/dropdown/dropdown.js +85 -23
  194. package/dropdown/dropdown.min.js +1 -1
  195. package/editor/editor.cjs.js +27 -11
  196. package/editor/editor.cjs.min.js +1 -1
  197. package/editor/editor.d.ts +3 -0
  198. package/editor/editor.esm.js +27 -11
  199. package/editor/editor.esm.min.js +1 -1
  200. package/editor/editor.js +27 -11
  201. package/editor/editor.min.js +1 -1
  202. package/fieldset/fieldset.cjs.js +30 -0
  203. package/fieldset/fieldset.cjs.min.js +1 -1
  204. package/fieldset/fieldset.d.ts +5 -5
  205. package/fieldset/fieldset.esm.js +30 -0
  206. package/fieldset/fieldset.esm.min.js +1 -1
  207. package/fieldset/fieldset.js +30 -0
  208. package/fieldset/fieldset.min.js +1 -1
  209. package/fileupload/fileupload.cjs.js +28 -3
  210. package/fileupload/fileupload.cjs.min.js +1 -1
  211. package/fileupload/fileupload.d.ts +2 -0
  212. package/fileupload/fileupload.esm.js +28 -3
  213. package/fileupload/fileupload.esm.min.js +1 -1
  214. package/fileupload/fileupload.js +28 -3
  215. package/fileupload/fileupload.min.js +1 -1
  216. package/fullcalendar/fullcalendar.cjs.js +25 -0
  217. package/fullcalendar/fullcalendar.cjs.min.js +1 -1
  218. package/fullcalendar/fullcalendar.d.ts +3 -1
  219. package/fullcalendar/fullcalendar.esm.js +25 -0
  220. package/fullcalendar/fullcalendar.esm.min.js +1 -1
  221. package/fullcalendar/fullcalendar.js +25 -0
  222. package/fullcalendar/fullcalendar.min.js +1 -1
  223. package/galleria/galleria.cjs.js +27 -3
  224. package/galleria/galleria.cjs.min.js +1 -1
  225. package/galleria/galleria.d.ts +2 -4
  226. package/galleria/galleria.esm.js +27 -3
  227. package/galleria/galleria.esm.min.js +1 -1
  228. package/galleria/galleria.js +27 -3
  229. package/galleria/galleria.min.js +1 -1
  230. package/gmap/gmap.cjs.js +25 -3
  231. package/gmap/gmap.cjs.min.js +1 -1
  232. package/gmap/gmap.d.ts +5 -4
  233. package/gmap/gmap.esm.js +25 -3
  234. package/gmap/gmap.esm.min.js +1 -1
  235. package/gmap/gmap.js +25 -3
  236. package/gmap/gmap.min.js +1 -1
  237. package/hooks/hooks.cjs.js +48 -2
  238. package/hooks/hooks.cjs.min.js +1 -1
  239. package/hooks/hooks.d.ts +3 -1
  240. package/hooks/hooks.esm.js +47 -3
  241. package/hooks/hooks.esm.min.js +1 -1
  242. package/hooks/hooks.js +48 -2
  243. package/hooks/hooks.min.js +1 -1
  244. package/image/image.cjs.js +35 -5
  245. package/image/image.cjs.min.js +1 -1
  246. package/image/image.d.ts +5 -4
  247. package/image/image.esm.js +35 -5
  248. package/image/image.esm.min.js +1 -1
  249. package/image/image.js +35 -5
  250. package/image/image.min.css +1 -1
  251. package/image/image.min.js +1 -1
  252. package/inplace/inplace.cjs.js +28 -1
  253. package/inplace/inplace.cjs.min.js +1 -1
  254. package/inplace/inplace.d.ts +4 -5
  255. package/inplace/inplace.esm.js +28 -1
  256. package/inplace/inplace.esm.min.js +1 -1
  257. package/inplace/inplace.js +28 -1
  258. package/inplace/inplace.min.js +1 -1
  259. package/inputmask/inputmask.cjs.js +32 -5
  260. package/inputmask/inputmask.cjs.min.js +1 -1
  261. package/inputmask/inputmask.d.ts +5 -13
  262. package/inputmask/inputmask.esm.js +32 -5
  263. package/inputmask/inputmask.esm.min.js +1 -1
  264. package/inputmask/inputmask.js +32 -5
  265. package/inputmask/inputmask.min.js +1 -1
  266. package/inputnumber/inputnumber.cjs.js +11 -5
  267. package/inputnumber/inputnumber.cjs.min.js +1 -1
  268. package/inputnumber/inputnumber.d.ts +4 -4
  269. package/inputnumber/inputnumber.esm.js +11 -5
  270. package/inputnumber/inputnumber.esm.min.js +1 -1
  271. package/inputnumber/inputnumber.js +11 -5
  272. package/inputnumber/inputnumber.min.js +1 -1
  273. package/inputswitch/inputswitch.cjs.js +29 -1
  274. package/inputswitch/inputswitch.cjs.min.js +1 -1
  275. package/inputswitch/inputswitch.d.ts +4 -1
  276. package/inputswitch/inputswitch.esm.js +30 -2
  277. package/inputswitch/inputswitch.esm.min.js +1 -1
  278. package/inputswitch/inputswitch.js +29 -1
  279. package/inputswitch/inputswitch.min.css +1 -1
  280. package/inputswitch/inputswitch.min.js +1 -1
  281. package/inputtext/inputtext.d.ts +4 -1
  282. package/inputtext/inputtext.min.css +1 -1
  283. package/inputtextarea/inputtextarea.d.ts +4 -1
  284. package/knob/knob.cjs.js +25 -0
  285. package/knob/knob.cjs.min.js +1 -1
  286. package/knob/knob.d.ts +3 -1
  287. package/knob/knob.esm.js +25 -0
  288. package/knob/knob.esm.min.js +1 -1
  289. package/knob/knob.js +25 -0
  290. package/knob/knob.min.js +1 -1
  291. package/listbox/listbox.cjs.js +128 -20
  292. package/listbox/listbox.cjs.min.js +1 -1
  293. package/listbox/listbox.d.ts +14 -7
  294. package/listbox/listbox.esm.js +129 -21
  295. package/listbox/listbox.esm.min.js +1 -1
  296. package/listbox/listbox.js +129 -22
  297. package/listbox/listbox.min.js +1 -1
  298. package/megamenu/megamenu.cjs.js +57 -12
  299. package/megamenu/megamenu.cjs.min.js +1 -1
  300. package/megamenu/megamenu.d.ts +11 -5
  301. package/megamenu/megamenu.esm.js +57 -12
  302. package/megamenu/megamenu.esm.min.js +1 -1
  303. package/megamenu/megamenu.js +57 -12
  304. package/megamenu/megamenu.min.css +1 -1
  305. package/megamenu/megamenu.min.js +1 -1
  306. package/mention/mention.cjs.js +16 -1
  307. package/mention/mention.cjs.min.js +1 -1
  308. package/mention/mention.d.ts +7 -5
  309. package/mention/mention.esm.js +16 -1
  310. package/mention/mention.esm.min.js +1 -1
  311. package/mention/mention.js +16 -1
  312. package/mention/mention.min.js +1 -1
  313. package/menu/menu.cjs.js +27 -3
  314. package/menu/menu.cjs.min.js +1 -1
  315. package/menu/menu.d.ts +3 -4
  316. package/menu/menu.esm.js +27 -3
  317. package/menu/menu.esm.min.js +1 -1
  318. package/menu/menu.js +27 -3
  319. package/menu/menu.min.js +1 -1
  320. package/menubar/menubar.cjs.js +32 -3
  321. package/menubar/menubar.cjs.min.js +1 -1
  322. package/menubar/menubar.d.ts +6 -5
  323. package/menubar/menubar.esm.js +32 -3
  324. package/menubar/menubar.esm.min.js +1 -1
  325. package/menubar/menubar.js +32 -3
  326. package/menubar/menubar.min.js +1 -1
  327. package/menuitem/menuitem.d.ts +2 -0
  328. package/message/message.cjs.js +28 -0
  329. package/message/message.cjs.min.js +1 -1
  330. package/message/message.d.ts +5 -6
  331. package/message/message.esm.js +28 -0
  332. package/message/message.esm.min.js +1 -1
  333. package/message/message.js +28 -0
  334. package/message/message.min.js +1 -1
  335. package/messages/messages.cjs.js +30 -5
  336. package/messages/messages.cjs.min.js +1 -1
  337. package/messages/messages.d.ts +3 -5
  338. package/messages/messages.esm.js +30 -5
  339. package/messages/messages.esm.min.js +1 -1
  340. package/messages/messages.js +30 -5
  341. package/messages/messages.min.js +1 -1
  342. package/multiselect/multiselect.cjs.js +78 -12
  343. package/multiselect/multiselect.cjs.min.js +1 -1
  344. package/multiselect/multiselect.d.ts +16 -2
  345. package/multiselect/multiselect.esm.js +78 -12
  346. package/multiselect/multiselect.esm.min.js +1 -1
  347. package/multiselect/multiselect.js +78 -12
  348. package/multiselect/multiselect.min.js +1 -1
  349. package/multistatecheckbox/multistatecheckbox.cjs.js +10 -0
  350. package/multistatecheckbox/multistatecheckbox.cjs.min.js +1 -1
  351. package/multistatecheckbox/multistatecheckbox.d.ts +4 -6
  352. package/multistatecheckbox/multistatecheckbox.esm.js +10 -0
  353. package/multistatecheckbox/multistatecheckbox.esm.min.js +1 -1
  354. package/multistatecheckbox/multistatecheckbox.js +10 -0
  355. package/multistatecheckbox/multistatecheckbox.min.js +1 -1
  356. package/orderlist/orderlist.cjs.js +145 -4
  357. package/orderlist/orderlist.cjs.min.js +1 -1
  358. package/orderlist/orderlist.d.ts +17 -6
  359. package/orderlist/orderlist.esm.js +145 -4
  360. package/orderlist/orderlist.esm.min.js +1 -1
  361. package/orderlist/orderlist.js +146 -6
  362. package/orderlist/orderlist.min.css +1 -1
  363. package/orderlist/orderlist.min.js +1 -1
  364. package/organizationchart/organizationchart.cjs.js +27 -0
  365. package/organizationchart/organizationchart.cjs.min.js +1 -1
  366. package/organizationchart/organizationchart.d.ts +4 -5
  367. package/organizationchart/organizationchart.esm.js +27 -0
  368. package/organizationchart/organizationchart.esm.min.js +1 -1
  369. package/organizationchart/organizationchart.js +27 -0
  370. package/organizationchart/organizationchart.min.js +1 -1
  371. package/overlaypanel/overlaypanel.cjs.js +25 -4
  372. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  373. package/overlaypanel/overlaypanel.d.ts +2 -4
  374. package/overlaypanel/overlaypanel.esm.js +25 -4
  375. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  376. package/overlaypanel/overlaypanel.js +25 -4
  377. package/overlaypanel/overlaypanel.min.js +1 -1
  378. package/package.json +1 -1
  379. package/paginator/paginator.cjs.js +15 -3
  380. package/paginator/paginator.cjs.min.js +1 -1
  381. package/paginator/paginator.d.ts +4 -4
  382. package/paginator/paginator.esm.js +15 -3
  383. package/paginator/paginator.esm.min.js +1 -1
  384. package/paginator/paginator.js +15 -3
  385. package/paginator/paginator.min.js +1 -1
  386. package/panel/panel.cjs.js +28 -0
  387. package/panel/panel.cjs.min.js +1 -1
  388. package/panel/panel.d.ts +5 -5
  389. package/panel/panel.esm.js +28 -0
  390. package/panel/panel.esm.min.js +1 -1
  391. package/panel/panel.js +28 -0
  392. package/panel/panel.min.js +1 -1
  393. package/panelmenu/panelmenu.cjs.js +28 -0
  394. package/panelmenu/panelmenu.cjs.min.js +1 -1
  395. package/panelmenu/panelmenu.d.ts +4 -5
  396. package/panelmenu/panelmenu.esm.js +28 -0
  397. package/panelmenu/panelmenu.esm.min.js +1 -1
  398. package/panelmenu/panelmenu.js +28 -0
  399. package/panelmenu/panelmenu.min.js +1 -1
  400. package/password/password.cjs.js +31 -0
  401. package/password/password.cjs.min.js +1 -1
  402. package/password/password.d.ts +6 -4
  403. package/password/password.esm.js +31 -0
  404. package/password/password.esm.min.js +1 -1
  405. package/password/password.js +31 -0
  406. package/password/password.min.js +1 -1
  407. package/picklist/picklist.cjs.js +196 -14
  408. package/picklist/picklist.cjs.min.js +1 -1
  409. package/picklist/picklist.d.ts +32 -1
  410. package/picklist/picklist.esm.js +196 -14
  411. package/picklist/picklist.esm.min.js +1 -1
  412. package/picklist/picklist.js +197 -16
  413. package/picklist/picklist.min.css +1 -1
  414. package/picklist/picklist.min.js +1 -1
  415. package/primereact.all.cjs.js +2483 -655
  416. package/primereact.all.cjs.min.js +1 -1
  417. package/primereact.all.esm.js +2481 -655
  418. package/primereact.all.esm.min.js +1 -1
  419. package/primereact.all.js +2483 -655
  420. package/primereact.all.min.js +1 -1
  421. package/progressbar/progressbar.cjs.js +29 -0
  422. package/progressbar/progressbar.cjs.min.js +1 -1
  423. package/progressbar/progressbar.d.ts +4 -5
  424. package/progressbar/progressbar.esm.js +29 -0
  425. package/progressbar/progressbar.esm.min.js +1 -1
  426. package/progressbar/progressbar.js +29 -0
  427. package/progressbar/progressbar.min.js +1 -1
  428. package/progressspinner/progressspinner.cjs.js +27 -0
  429. package/progressspinner/progressspinner.cjs.min.js +1 -1
  430. package/progressspinner/progressspinner.d.ts +4 -5
  431. package/progressspinner/progressspinner.esm.js +27 -0
  432. package/progressspinner/progressspinner.esm.min.js +1 -1
  433. package/progressspinner/progressspinner.js +27 -0
  434. package/progressspinner/progressspinner.min.js +1 -1
  435. package/radiobutton/radiobutton.cjs.js +29 -4
  436. package/radiobutton/radiobutton.cjs.min.js +1 -1
  437. package/radiobutton/radiobutton.d.ts +2 -4
  438. package/radiobutton/radiobutton.esm.js +30 -5
  439. package/radiobutton/radiobutton.esm.min.js +1 -1
  440. package/radiobutton/radiobutton.js +29 -4
  441. package/radiobutton/radiobutton.min.js +1 -1
  442. package/rating/rating.cjs.js +25 -0
  443. package/rating/rating.cjs.min.js +1 -1
  444. package/rating/rating.d.ts +3 -4
  445. package/rating/rating.esm.js +25 -0
  446. package/rating/rating.esm.min.js +1 -1
  447. package/rating/rating.js +25 -0
  448. package/rating/rating.min.js +1 -1
  449. package/resources/primereact.css +213 -145
  450. package/resources/primereact.min.css +1 -1
  451. package/resources/themes/arya-blue/theme.css +39 -6
  452. package/resources/themes/arya-green/theme.css +39 -6
  453. package/resources/themes/arya-orange/theme.css +39 -6
  454. package/resources/themes/arya-purple/theme.css +39 -6
  455. package/resources/themes/bootstrap4-dark-blue/theme.css +39 -6
  456. package/resources/themes/bootstrap4-dark-purple/theme.css +39 -6
  457. package/resources/themes/bootstrap4-light-blue/theme.css +38 -5
  458. package/resources/themes/bootstrap4-light-purple/theme.css +38 -5
  459. package/resources/themes/fluent-light/theme.css +39 -6
  460. package/resources/themes/lara-dark-blue/theme.css +39 -6
  461. package/resources/themes/lara-dark-indigo/theme.css +39 -6
  462. package/resources/themes/lara-dark-purple/theme.css +39 -6
  463. package/resources/themes/lara-dark-teal/theme.css +39 -6
  464. package/resources/themes/lara-light-blue/theme.css +39 -6
  465. package/resources/themes/lara-light-indigo/theme.css +39 -6
  466. package/resources/themes/lara-light-purple/theme.css +39 -6
  467. package/resources/themes/lara-light-teal/theme.css +39 -6
  468. package/resources/themes/luna-amber/theme.css +39 -6
  469. package/resources/themes/luna-blue/theme.css +39 -6
  470. package/resources/themes/luna-green/theme.css +39 -6
  471. package/resources/themes/luna-pink/theme.css +39 -6
  472. package/resources/themes/md-dark-deeppurple/theme.css +39 -6
  473. package/resources/themes/md-dark-indigo/theme.css +39 -6
  474. package/resources/themes/md-light-deeppurple/theme.css +39 -6
  475. package/resources/themes/md-light-indigo/theme.css +39 -6
  476. package/resources/themes/mdc-dark-deeppurple/theme.css +39 -6
  477. package/resources/themes/mdc-dark-indigo/theme.css +39 -6
  478. package/resources/themes/mdc-light-deeppurple/theme.css +39 -6
  479. package/resources/themes/mdc-light-indigo/theme.css +39 -6
  480. package/resources/themes/nova/theme.css +39 -6
  481. package/resources/themes/nova-accent/theme.css +39 -6
  482. package/resources/themes/nova-alt/theme.css +39 -6
  483. package/resources/themes/rhea/theme.css +39 -6
  484. package/resources/themes/saga-blue/theme.css +39 -6
  485. package/resources/themes/saga-green/theme.css +39 -6
  486. package/resources/themes/saga-orange/theme.css +39 -6
  487. package/resources/themes/saga-purple/theme.css +39 -6
  488. package/resources/themes/tailwind-light/theme.css +39 -6
  489. package/resources/themes/vela-blue/theme.css +39 -6
  490. package/resources/themes/vela-green/theme.css +39 -6
  491. package/resources/themes/vela-orange/theme.css +39 -6
  492. package/resources/themes/vela-purple/theme.css +39 -6
  493. package/scrollpanel/scrollpanel.cjs.js +33 -3
  494. package/scrollpanel/scrollpanel.cjs.min.js +1 -1
  495. package/scrollpanel/scrollpanel.d.ts +7 -5
  496. package/scrollpanel/scrollpanel.esm.js +33 -3
  497. package/scrollpanel/scrollpanel.esm.min.js +1 -1
  498. package/scrollpanel/scrollpanel.js +33 -3
  499. package/scrollpanel/scrollpanel.min.js +1 -1
  500. package/scrolltop/scrolltop.cjs.js +25 -0
  501. package/scrolltop/scrolltop.cjs.min.js +1 -1
  502. package/scrolltop/scrolltop.d.ts +3 -1
  503. package/scrolltop/scrolltop.esm.js +25 -0
  504. package/scrolltop/scrolltop.esm.min.js +1 -1
  505. package/scrolltop/scrolltop.js +25 -0
  506. package/scrolltop/scrolltop.min.js +1 -1
  507. package/selectbutton/selectbutton.cjs.js +25 -0
  508. package/selectbutton/selectbutton.cjs.min.js +1 -1
  509. package/selectbutton/selectbutton.d.ts +4 -5
  510. package/selectbutton/selectbutton.esm.js +25 -0
  511. package/selectbutton/selectbutton.esm.min.js +1 -1
  512. package/selectbutton/selectbutton.js +25 -0
  513. package/selectbutton/selectbutton.min.js +1 -1
  514. package/sidebar/sidebar.cjs.js +31 -0
  515. package/sidebar/sidebar.cjs.min.js +1 -1
  516. package/sidebar/sidebar.d.ts +6 -5
  517. package/sidebar/sidebar.esm.js +31 -0
  518. package/sidebar/sidebar.esm.min.js +1 -1
  519. package/sidebar/sidebar.js +31 -0
  520. package/sidebar/sidebar.min.js +1 -1
  521. package/skeleton/skeleton.cjs.js +27 -0
  522. package/skeleton/skeleton.cjs.min.js +1 -1
  523. package/skeleton/skeleton.d.ts +4 -4
  524. package/skeleton/skeleton.esm.js +27 -0
  525. package/skeleton/skeleton.esm.min.js +1 -1
  526. package/skeleton/skeleton.js +27 -0
  527. package/skeleton/skeleton.min.js +1 -1
  528. package/slidemenu/slidemenu.cjs.js +28 -21
  529. package/slidemenu/slidemenu.cjs.min.js +1 -1
  530. package/slidemenu/slidemenu.d.ts +2 -4
  531. package/slidemenu/slidemenu.esm.js +28 -21
  532. package/slidemenu/slidemenu.esm.min.js +1 -1
  533. package/slidemenu/slidemenu.js +28 -21
  534. package/slidemenu/slidemenu.min.js +1 -1
  535. package/slider/slider.cjs.js +25 -0
  536. package/slider/slider.cjs.min.js +1 -1
  537. package/slider/slider.d.ts +4 -6
  538. package/slider/slider.esm.js +25 -0
  539. package/slider/slider.esm.min.js +1 -1
  540. package/slider/slider.js +25 -0
  541. package/slider/slider.min.js +1 -1
  542. package/speeddial/speeddial.cjs.js +6 -3
  543. package/speeddial/speeddial.cjs.min.js +1 -1
  544. package/speeddial/speeddial.d.ts +2 -4
  545. package/speeddial/speeddial.esm.js +6 -3
  546. package/speeddial/speeddial.esm.min.js +1 -1
  547. package/speeddial/speeddial.js +6 -3
  548. package/speeddial/speeddial.min.js +1 -1
  549. package/splitbutton/splitbutton.cjs.js +28 -3
  550. package/splitbutton/splitbutton.cjs.min.js +1 -1
  551. package/splitbutton/splitbutton.d.ts +4 -5
  552. package/splitbutton/splitbutton.esm.js +28 -3
  553. package/splitbutton/splitbutton.esm.min.js +1 -1
  554. package/splitbutton/splitbutton.js +28 -3
  555. package/splitbutton/splitbutton.min.js +1 -1
  556. package/splitter/splitter.cjs.js +34 -5
  557. package/splitter/splitter.cjs.min.js +1 -1
  558. package/splitter/splitter.d.ts +4 -5
  559. package/splitter/splitter.esm.js +35 -6
  560. package/splitter/splitter.esm.min.js +1 -1
  561. package/splitter/splitter.js +34 -5
  562. package/splitter/splitter.min.js +1 -1
  563. package/steps/steps.cjs.js +29 -0
  564. package/steps/steps.cjs.min.js +1 -1
  565. package/steps/steps.d.ts +4 -5
  566. package/steps/steps.esm.js +29 -0
  567. package/steps/steps.esm.min.js +1 -1
  568. package/steps/steps.js +29 -0
  569. package/steps/steps.min.js +1 -1
  570. package/styleclass/styleclass.cjs.js +40 -17
  571. package/styleclass/styleclass.cjs.min.js +1 -1
  572. package/styleclass/styleclass.d.ts +5 -2
  573. package/styleclass/styleclass.esm.js +40 -17
  574. package/styleclass/styleclass.esm.min.js +1 -1
  575. package/styleclass/styleclass.js +40 -17
  576. package/styleclass/styleclass.min.js +1 -1
  577. package/tabmenu/tabmenu.cjs.js +27 -0
  578. package/tabmenu/tabmenu.cjs.min.js +1 -1
  579. package/tabmenu/tabmenu.d.ts +4 -5
  580. package/tabmenu/tabmenu.esm.js +27 -0
  581. package/tabmenu/tabmenu.esm.min.js +1 -1
  582. package/tabmenu/tabmenu.js +27 -0
  583. package/tabmenu/tabmenu.min.js +1 -1
  584. package/tabview/tabview.cjs.js +8 -3
  585. package/tabview/tabview.cjs.min.js +1 -1
  586. package/tabview/tabview.d.ts +2 -4
  587. package/tabview/tabview.esm.js +8 -3
  588. package/tabview/tabview.esm.min.js +1 -1
  589. package/tabview/tabview.js +8 -3
  590. package/tabview/tabview.min.js +1 -1
  591. package/tag/tag.cjs.js +12 -0
  592. package/tag/tag.cjs.min.js +1 -1
  593. package/tag/tag.d.ts +5 -5
  594. package/tag/tag.esm.js +12 -0
  595. package/tag/tag.esm.min.js +1 -1
  596. package/tag/tag.js +12 -0
  597. package/tag/tag.min.js +1 -1
  598. package/terminal/terminal.cjs.js +26 -1
  599. package/terminal/terminal.cjs.min.js +1 -1
  600. package/terminal/terminal.d.ts +4 -5
  601. package/terminal/terminal.esm.js +27 -2
  602. package/terminal/terminal.esm.min.js +1 -1
  603. package/terminal/terminal.js +26 -1
  604. package/terminal/terminal.min.js +1 -1
  605. package/tieredmenu/tieredmenu.cjs.js +27 -4
  606. package/tieredmenu/tieredmenu.cjs.min.js +1 -1
  607. package/tieredmenu/tieredmenu.d.ts +2 -4
  608. package/tieredmenu/tieredmenu.esm.js +27 -4
  609. package/tieredmenu/tieredmenu.esm.min.js +1 -1
  610. package/tieredmenu/tieredmenu.js +27 -4
  611. package/tieredmenu/tieredmenu.min.js +1 -1
  612. package/timeline/timeline.cjs.js +13 -0
  613. package/timeline/timeline.cjs.min.js +1 -1
  614. package/timeline/timeline.d.ts +4 -5
  615. package/timeline/timeline.esm.js +13 -0
  616. package/timeline/timeline.esm.min.js +1 -1
  617. package/timeline/timeline.js +13 -0
  618. package/timeline/timeline.min.js +1 -1
  619. package/toast/toast.cjs.js +18 -17
  620. package/toast/toast.cjs.min.js +1 -1
  621. package/toast/toast.d.ts +4 -5
  622. package/toast/toast.esm.js +18 -17
  623. package/toast/toast.esm.min.js +1 -1
  624. package/toast/toast.js +18 -17
  625. package/toast/toast.min.css +1 -1
  626. package/toast/toast.min.js +1 -1
  627. package/togglebutton/togglebutton.cjs.js +25 -0
  628. package/togglebutton/togglebutton.cjs.min.js +1 -1
  629. package/togglebutton/togglebutton.d.ts +4 -6
  630. package/togglebutton/togglebutton.esm.js +25 -0
  631. package/togglebutton/togglebutton.esm.min.js +1 -1
  632. package/togglebutton/togglebutton.js +25 -0
  633. package/togglebutton/togglebutton.min.js +1 -1
  634. package/toolbar/toolbar.cjs.js +27 -0
  635. package/toolbar/toolbar.cjs.min.js +1 -1
  636. package/toolbar/toolbar.d.ts +4 -5
  637. package/toolbar/toolbar.esm.js +27 -0
  638. package/toolbar/toolbar.esm.min.js +1 -1
  639. package/toolbar/toolbar.js +27 -0
  640. package/toolbar/toolbar.min.js +1 -1
  641. package/tooltip/tooltip.cjs.js +76 -53
  642. package/tooltip/tooltip.cjs.min.js +1 -1
  643. package/tooltip/tooltip.d.ts +2 -0
  644. package/tooltip/tooltip.esm.js +76 -53
  645. package/tooltip/tooltip.esm.min.js +1 -1
  646. package/tooltip/tooltip.js +76 -53
  647. package/tooltip/tooltip.min.js +1 -1
  648. package/tree/tree.cjs.js +51 -9
  649. package/tree/tree.cjs.min.js +1 -1
  650. package/tree/tree.d.ts +9 -0
  651. package/tree/tree.esm.js +51 -9
  652. package/tree/tree.esm.min.js +1 -1
  653. package/tree/tree.js +51 -9
  654. package/tree/tree.min.js +1 -1
  655. package/treeselect/treeselect.cjs.js +34 -5
  656. package/treeselect/treeselect.cjs.min.js +1 -1
  657. package/treeselect/treeselect.d.ts +11 -5
  658. package/treeselect/treeselect.esm.js +34 -5
  659. package/treeselect/treeselect.esm.min.js +1 -1
  660. package/treeselect/treeselect.js +34 -5
  661. package/treeselect/treeselect.min.js +1 -1
  662. package/treetable/treetable.cjs.js +12 -8
  663. package/treetable/treetable.cjs.min.js +1 -1
  664. package/treetable/treetable.d.ts +4 -3
  665. package/treetable/treetable.esm.js +12 -8
  666. package/treetable/treetable.esm.min.js +1 -1
  667. package/treetable/treetable.js +12 -8
  668. package/treetable/treetable.min.js +1 -1
  669. package/tristatecheckbox/tristatecheckbox.cjs.js +25 -0
  670. package/tristatecheckbox/tristatecheckbox.cjs.min.js +1 -1
  671. package/tristatecheckbox/tristatecheckbox.d.ts +3 -5
  672. package/tristatecheckbox/tristatecheckbox.esm.js +25 -0
  673. package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
  674. package/tristatecheckbox/tristatecheckbox.js +25 -0
  675. package/tristatecheckbox/tristatecheckbox.min.js +1 -1
  676. package/utils/utils.cjs.js +21 -5
  677. package/utils/utils.cjs.min.js +1 -1
  678. package/utils/utils.d.ts +1 -0
  679. package/utils/utils.esm.js +21 -5
  680. package/utils/utils.esm.min.js +1 -1
  681. package/utils/utils.js +21 -5
  682. package/utils/utils.min.js +1 -1
  683. package/virtualscroller/virtualscroller.cjs.js +157 -68
  684. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  685. package/virtualscroller/virtualscroller.d.ts +12 -0
  686. package/virtualscroller/virtualscroller.esm.js +159 -70
  687. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  688. package/virtualscroller/virtualscroller.js +157 -68
  689. package/virtualscroller/virtualscroller.min.css +1 -1
  690. package/virtualscroller/virtualscroller.min.js +1 -1
  691. package/web-types.json +301 -5
@@ -1,7 +1,8 @@
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
- import { classNames, ObjectUtils, DomHandler } from 'primereact/utils';
5
+ import { ObjectUtils, classNames, DomHandler } from 'primereact/utils';
5
6
  import { VirtualScroller } from 'primereact/virtualscroller';
6
7
  import { InputText } from 'primereact/inputtext';
7
8
  import { Ripple } from 'primereact/ripple';
@@ -117,6 +118,15 @@ function _slicedToArray(arr, i) {
117
118
  }
118
119
 
119
120
  var ListBoxHeader = /*#__PURE__*/React.memo(function (props) {
121
+ var filterOptions = {
122
+ filter: function filter(e) {
123
+ return onFilter(e);
124
+ },
125
+ reset: function reset() {
126
+ return props.resetFilter();
127
+ }
128
+ };
129
+
120
130
  var onFilter = function onFilter(event) {
121
131
  if (props.onFilter) {
122
132
  props.onFilter({
@@ -126,20 +136,39 @@ var ListBoxHeader = /*#__PURE__*/React.memo(function (props) {
126
136
  }
127
137
  };
128
138
 
129
- return /*#__PURE__*/React.createElement("div", {
130
- className: "p-listbox-header"
131
- }, /*#__PURE__*/React.createElement("div", {
132
- className: "p-listbox-filter-container"
133
- }, /*#__PURE__*/React.createElement(InputText, _extends({
134
- type: "text",
135
- value: props.filter,
136
- onChange: onFilter,
137
- className: "p-listbox-filter",
138
- disabled: props.disabled,
139
- placeholder: props.filterPlaceholder
140
- }, props.filterInputProps)), /*#__PURE__*/React.createElement("span", {
141
- className: "p-listbox-filter-icon pi pi-search"
142
- })));
139
+ var createHeader = function createHeader() {
140
+ var content = /*#__PURE__*/React.createElement("div", {
141
+ className: "p-listbox-filter-container"
142
+ }, /*#__PURE__*/React.createElement(InputText, _extends({
143
+ type: "text",
144
+ value: props.filter,
145
+ onChange: onFilter,
146
+ className: "p-listbox-filter",
147
+ disabled: props.disabled,
148
+ placeholder: props.filterPlaceholder
149
+ }, props.filterInputProps)), /*#__PURE__*/React.createElement("span", {
150
+ className: "p-listbox-filter-icon pi pi-search"
151
+ }));
152
+
153
+ if (props.filterTemplate) {
154
+ var defaultContentOptions = {
155
+ className: 'p-listbox-filter-container',
156
+ element: content,
157
+ filterOptions: filterOptions,
158
+ filterInputChange: onFilter,
159
+ filterIconClassName: 'p-dropdown-filter-icon pi pi-search',
160
+ props: props
161
+ };
162
+ content = ObjectUtils.getJSXElement(props.filterTemplate, defaultContentOptions);
163
+ }
164
+
165
+ return /*#__PURE__*/React.createElement("div", {
166
+ className: "p-listbox-header"
167
+ }, content);
168
+ };
169
+
170
+ var content = createHeader();
171
+ return /*#__PURE__*/React.createElement(React.Fragment, null, content);
143
172
  });
144
173
  ListBoxHeader.displayName = 'ListBoxHeader';
145
174
 
@@ -207,6 +236,7 @@ var ListBoxItem = /*#__PURE__*/React.memo(function (props) {
207
236
  var content = props.template ? ObjectUtils.getJSXElement(props.template, props.option) : props.label;
208
237
  return /*#__PURE__*/React.createElement("li", {
209
238
  className: className,
239
+ style: props.style,
210
240
  onClick: onClick,
211
241
  onTouchEnd: onTouchEnd,
212
242
  onKeyDown: onKeyDown,
@@ -326,6 +356,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
326
356
  };
327
357
 
328
358
  var onFilter = function onFilter(event) {
359
+ virtualScrollerRef.current && virtualScrollerRef.current.scrollToIndex(0);
329
360
  var originalEvent = event.originalEvent,
330
361
  value = event.value;
331
362
 
@@ -339,6 +370,13 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
339
370
  }
340
371
  };
341
372
 
373
+ var resetFilter = function resetFilter() {
374
+ setFilterValueState('');
375
+ props.onFilter && props.onFilter({
376
+ filter: ''
377
+ });
378
+ };
379
+
342
380
  var updateModel = function updateModel(event, value) {
343
381
  if (props.onChange) {
344
382
  props.onChange({
@@ -361,11 +399,44 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
361
399
  });
362
400
  };
363
401
 
402
+ var getSelectedOptionIndex = function getSelectedOptionIndex() {
403
+ if (props.value != null && visibleOptions) {
404
+ if (props.optionGroupLabel) {
405
+ for (var i = 0; i < visibleOptions.length; i++) {
406
+ var selectedOptionIndex = findOptionIndexInList(props.value, getOptionGroupChildren(visibleOptions[i]));
407
+
408
+ if (selectedOptionIndex !== -1) {
409
+ return {
410
+ group: i,
411
+ option: selectedOptionIndex
412
+ };
413
+ }
414
+ }
415
+ } else {
416
+ return findOptionIndexInList(props.value, visibleOptions);
417
+ }
418
+ }
419
+
420
+ return -1;
421
+ };
422
+
423
+ var equalityKey = function equalityKey() {
424
+ return props.optionValue ? null : props.dataKey;
425
+ };
426
+
427
+ var findOptionIndexInList = function findOptionIndexInList(value, list) {
428
+ var key = equalityKey();
429
+ return list.findIndex(function (item) {
430
+ return ObjectUtils.equals(value, getOptionValue(item), key);
431
+ });
432
+ };
433
+
364
434
  var isSelected = function isSelected(option) {
365
435
  var optionValue = getOptionValue(option);
436
+ var key = equalityKey();
366
437
  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);
438
+ return ObjectUtils.equals(val, optionValue, key);
439
+ }) : ObjectUtils.equals(props.value, optionValue, key);
369
440
  };
370
441
 
371
442
  var getOptionLabel = function getOptionLabel(option) {
@@ -437,17 +508,45 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
437
508
  }
438
509
  };
439
510
 
511
+ var scrollToSelectedIndex = function scrollToSelectedIndex() {
512
+ if (virtualScrollerRef.current) {
513
+ var selectedIndex = getSelectedOptionIndex();
514
+
515
+ if (selectedIndex !== -1) {
516
+ setTimeout(function () {
517
+ return virtualScrollerRef.current.scrollToIndex(selectedIndex);
518
+ }, 0);
519
+ }
520
+ }
521
+ };
522
+
523
+ React.useImperativeHandle(ref, function () {
524
+ return _objectSpread({
525
+ getElement: function getElement() {
526
+ return elementRef.current;
527
+ },
528
+ getVirtualScroller: function getVirtualScroller() {
529
+ return virtualScrollerRef.current;
530
+ }
531
+ }, props);
532
+ });
533
+ useMountEffect(function () {
534
+ scrollToSelectedIndex();
535
+ });
536
+
440
537
  var createHeader = function createHeader() {
441
538
  return props.filter ? /*#__PURE__*/React.createElement(ListBoxHeader, {
442
539
  filter: filteredValue,
443
540
  onFilter: onFilter,
541
+ resetFilter: resetFilter,
542
+ filterTemplate: props.filterTemplate,
444
543
  disabled: props.disabled,
445
544
  filterPlaceholder: props.filterPlaceholder,
446
545
  filterInputProps: props.filterInputProps
447
546
  }) : null;
448
547
  };
449
548
 
450
- var createGroupChildren = function createGroupChildren(optionGroup) {
549
+ var createGroupChildren = function createGroupChildren(optionGroup, style) {
451
550
  var groupChildren = getOptionGroupChildren(optionGroup);
452
551
  return groupChildren.map(function (option, j) {
453
552
  var optionLabel = getOptionLabel(option);
@@ -458,6 +557,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
458
557
  key: optionKey,
459
558
  label: optionLabel,
460
559
  option: option,
560
+ style: style,
461
561
  template: props.itemTemplate,
462
562
  selected: isSelected(option),
463
563
  onClick: onOptionSelect,
@@ -469,14 +569,20 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
469
569
  };
470
570
 
471
571
  var createItem = function createItem(option, index) {
572
+ var scrollerOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
573
+ var style = {
574
+ height: scrollerOptions.props ? scrollerOptions.props.itemSize : undefined
575
+ };
576
+
472
577
  if (props.optionGroupLabel) {
473
578
  var groupContent = props.optionGroupTemplate ? ObjectUtils.getJSXElement(props.optionGroupTemplate, option, index) : getOptionGroupLabel(option);
474
- var groupChildrenContent = createGroupChildren(option);
579
+ var groupChildrenContent = createGroupChildren(option, style);
475
580
  var key = index + '_' + getOptionGroupRenderKey(option);
476
581
  return /*#__PURE__*/React.createElement(React.Fragment, {
477
582
  key: key
478
583
  }, /*#__PURE__*/React.createElement("li", {
479
584
  className: "p-listbox-item-group",
585
+ style: style,
480
586
  role: "group"
481
587
  }, groupContent), groupChildrenContent);
482
588
  } else {
@@ -488,6 +594,7 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
488
594
  key: optionKey,
489
595
  label: optionLabel,
490
596
  option: option,
597
+ style: style,
491
598
  template: props.itemTemplate,
492
599
  selected: isSelected(option),
493
600
  onClick: onOptionSelect,
@@ -511,8 +618,8 @@ var ListBox = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (p
511
618
  filter: visibleOptions
512
619
  }));
513
620
  },
514
- itemTemplate: function itemTemplate(item, option) {
515
- return item && createItem(item, option.index);
621
+ itemTemplate: function itemTemplate(item, options) {
622
+ return item && createItem(item, options.index, options);
516
623
  },
517
624
  contentTemplate: function contentTemplate(option) {
518
625
  var className = classNames('p-listbox-list', option.className);
@@ -587,6 +694,7 @@ ListBox.defaultProps = {
587
694
  multiple: false,
588
695
  metaKeySelection: false,
589
696
  filter: false,
697
+ filterTemplate: null,
590
698
  filterBy: null,
591
699
  filterValue: null,
592
700
  filterMatchMode: 'contains',
@@ -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 r}from"primereact/hooks";import{Tooltip as n}from"primereact/tooltip";import{ObjectUtils as l,classNames 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 r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},s.apply(this,arguments)}function p(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function f(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}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 r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?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 r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,l,a=[],o=!0,i=!1;try{for(r=r.call(e);!(o=(n=r.next()).done)&&(a.push(n.value),!t||a.length!==t);o=!0);}catch(e){i=!0,l=e}finally{try{o||null==r.return||r.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){var r={filter:function(e){return n(e)},reset:function(){return t.resetFilter()}},n=function(e){t.onFilter&&t.onFilter({originalEvent:e,value:e.target.value})},a=function(){var a=e.createElement("div",{className:"p-listbox-filter-container"},e.createElement(u,s({type:"text",value:t.filter,onChange:n,className:"p-listbox-filter",disabled:t.disabled,placeholder:t.filterPlaceholder},t.filterInputProps)),e.createElement("span",{className:"p-listbox-filter-icon pi pi-search"}));t.filterTemplate&&(a=l.getJSXElement(t.filterTemplate,{className:"p-listbox-filter-container",element:a,filterOptions:r,filterInputChange:n,filterIconClassName:"p-dropdown-filter-icon pi pi-search",props:t}));return e.createElement("div",{className:"p-listbox-header"},a)}();return e.createElement(e.Fragment,null,a)}));x.displayName="ListBoxHeader";var O=e.memo((function(t){var r=function(e){t.onClick&&t.onClick({originalEvent:e,option:t.option}),e.preventDefault()},n=function e(t){var r=t.nextElementSibling;return r?o.hasClass(r,"p-disabled")||o.hasClass(r,"p-listbox-item-group")?e(r):r:null},i=function e(t){var r=t.previousElementSibling;return r?o.hasClass(r,"p-disabled")||o.hasClass(r,"p-listbox-item-group")?e(r):r:null},u=a("p-listbox-item",{"p-highlight":t.selected,"p-disabled":t.disabled},t.option.className),s=t.template?l.getJSXElement(t.template,t.option):t.label;return e.createElement("li",{className:u,style:t.style,onClick:r,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=n(t);l&&l.focus(),e.preventDefault();break;case 38:var a=i(t);a&&a.focus(),e.preventDefault();break;case 13:r(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 r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function C(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?S(Object(r),!0).forEach((function(t){p(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):S(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}function w(e,t){var r="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!r){if(Array.isArray(e)||(r=T(e))||t&&e&&"number"==typeof e.length){r&&(e=r);var n=0,l=function(){};return{s:l,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},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(){r=r.call(e)},n:function(){var e=r.next();return o=e.done,e},e:function(e){i=!0,a=e},f:function(){try{o||null==r.return||r.return()}finally{if(i)throw a}}}}function T(e,t){if(e){if("string"==typeof e)return I(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?I(e,t):void 0}}function I(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}O.displayName="ListBoxItem";var D=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),T=e.useRef(null),I=e.useRef(!1),L=(o.onFilterValueChange?o.filterValue:d)||"",P=L&&L.trim().length>0,F=function(e){var t=e.option;o.disabled||X(t)||(o.multiple?A(e.originalEvent,t):j(e.originalEvent,t),I.current=!1)},N=function(){o.disabled||(I.current=!0)},j=function(e,t){var r=_(t),n=!1,l=null;!I.current&&o.metaKeySelection?r?(e.metaKey||e.ctrlKey)&&(l=null,n=!0):(l=z(t),n=!0):(l=r?null:z(t),n=!0);n&&G(e,l)},A=function(e,t){var r=_(t),n=!1,l=null;if(!I&&o.metaKeySelection){var a=e.metaKey||e.ctrlKey;r?(l=a?V(t):[z(t)],n=!0):(l=[].concat(y(l=a&&o.value||[]),[z(t)]),n=!0)}else l=r?V(t):[].concat(y(o.value||[]),[z(t)]),n=!0;n&&o.onChange({originalEvent:e,value:l,stopPropagation:function(){},preventDefault:function(){},target:{name:o.name,id:o.id,value:l}})},K=function(e){T.current&&T.current.scrollToIndex(0);var t=e.value;o.onFilterValueChange?o.onFilterValueChange({originalEvent:e.originalEvent,value:t}):v(t)},k=function(){v(""),o.onFilter&&o.onFilter({filter:""})},G=function(e,t){o.onChange&&o.onChange({originalEvent:e,value:t,stopPropagation:function(){},preventDefault:function(){},target:{name:o.name,id:o.id,value:t}})},V=function(e){return o.value.filter((function(t){return!l.equals(t,z(e),o.dataKey)}))},M=function(){if(null!=o.value&&Z){if(!o.optionGroupLabel)return R(o.value,Z);for(var e=0;e<Z.length;e++){var t=R(o.value,$(Z[e]));if(-1!==t)return{group:e,option:t}}}return-1},B=function(){return o.optionValue?null:o.dataKey},R=function(e,t){var r=B();return t.findIndex((function(t){return l.equals(e,z(t),r)}))},_=function(e){var t=z(e),r=B();return o.multiple&&o.value?o.value.some((function(e){return l.equals(e,t,r)})):l.equals(o.value,t,r)},q=function(e){return o.optionLabel?l.resolveFieldData(e,o.optionLabel):e&&void 0!==e.label?e.label:e},z=function(e){return o.optionValue?l.resolveFieldData(e,o.optionValue):e&&void 0!==e.value?e.value:e},J=function(e){return o.dataKey?l.resolveFieldData(e,o.dataKey):q(e)},X=function(e){return o.optionDisabled?l.isFunction(o.optionDisabled)?o.optionDisabled(e):l.resolveFieldData(e,o.optionDisabled):!(!e||void 0===e.disabled)&&e.disabled},H=function(e){return l.resolveFieldData(e,o.optionGroupLabel)},U=function(e){return l.resolveFieldData(e,o.optionGroupLabel)},$=function(e){return l.resolveFieldData(e,o.optionGroupChildren)},Y=function(){if(T.current){var e=M();-1!==e&&setTimeout((function(){return T.current.scrollToIndex(e)}),0)}};e.useImperativeHandle(u,(function(){return C({getElement:function(){return S.current},getVirtualScroller:function(){return T.current}},o)})),r((function(){Y()}));var Q=function(t,r){return $(t).map((function(t,n){var l=q(t),a=n+"_"+J(t),i=X(t),u=i?null:o.tabIndex||0;return e.createElement(O,{key:a,label:l,option:t,style:r,template:o.itemTemplate,selected:_(t),onClick:F,onTouchEnd:N,tabIndex:u,disabled:i})}))},W=function(t,r){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a={height:n.props?n.props.itemSize:void 0};if(o.optionGroupLabel){var i=o.optionGroupTemplate?l.getJSXElement(o.optionGroupTemplate,t,r):U(t),u=Q(t,a),c=r+"_"+H(t);return e.createElement(e.Fragment,{key:c},e.createElement("li",{className:"p-listbox-item-group",style:a,role:"group"},i),u)}var s=q(t),p=r+"_"+J(t),f=X(t),m=f?null:o.tabIndex||0;return e.createElement(O,{key:p,label:s,option:t,style:a,template:o.itemTemplate,selected:_(t),onClick:F,onTouchEnd:N,tabIndex:m,disabled:f})},Z=function(){if(P){var e=L.trim().toLocaleLowerCase(o.filterLocale),r=o.filterBy?o.filterBy.split(","):[o.optionLabel||"label"];if(o.optionGroupLabel){var n,l=[],a=w(o.options);try{for(a.s();!(n=a.n()).done;){var i=n.value,u=t.filter($(i),r,e,o.filterMatchMode,o.filterLocale);u&&u.length&&l.push(C(C({},i),{items:u}))}}catch(e){a.e(e)}finally{a.f()}return l}return t.filter(o.options,r,e,o.filterMatchMode,o.filterLocale)}return o.options}(),ee=l.isNotEmpty(o.tooltip),te=l.findDiffKeys(o,D.defaultProps),re=a("p-listbox p-component",{"p-disabled":o.disabled},o.className),ne=a("p-listbox-list-wrapper",o.listClassName),le=function(){if(o.virtualScrollerOptions){var t=C(C({},o.virtualScrollerOptions),{items:Z,onLazyLoad:function(e){return o.virtualScrollerOptions.onLazyLoad(C(C({},e),{filter:Z}))},itemTemplate:function(e,t){return e&&W(e,t.index,t)},contentTemplate:function(t){var r=a("p-listbox-list",t.className);return e.createElement("ul",{ref:t.contentRef,className:r,role:"listbox","aria-multiselectable":o.multiple,"aria-labelledby":o["aria-labelledby"],"aria-label":o["aria-label"]},t.children)}});return e.createElement(i,s({ref:T},t))}var r=Z?Z.map(W):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"]},r)}(),ae=o.filter?e.createElement(x,{filter:L,onFilter:K,resetFilter:k,filterTemplate:o.filterTemplate,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:re,style:o.style},te),ae,e.createElement("div",{className:ne,style:o.listStyle},le)),ee&&e.createElement(n,s({target:S,content:o.tooltip},o.tooltipOptions)))})));D.displayName="ListBox",D.defaultProps={__TYPE:"ListBox",id:null,value:null,options:null,optionLabel:null,optionValue:null,optionDisabled:null,optionGroupLabel:null,optionGroupChildren:null,optionGroupTemplate:null,itemTemplate:null,style:null,listStyle:null,listClassName:null,className:null,virtualScrollerOptions:null,disabled:null,dataKey:null,multiple:!1,metaKeySelection:!1,filter:!1,filterTemplate:null,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null};export{D 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) {
@@ -133,6 +133,15 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
133
133
  }
134
134
 
135
135
  var ListBoxHeader = /*#__PURE__*/React__namespace.memo(function (props) {
136
+ var filterOptions = {
137
+ filter: function filter(e) {
138
+ return onFilter(e);
139
+ },
140
+ reset: function reset() {
141
+ return props.resetFilter();
142
+ }
143
+ };
144
+
136
145
  var onFilter = function onFilter(event) {
137
146
  if (props.onFilter) {
138
147
  props.onFilter({
@@ -142,20 +151,39 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
142
151
  }
143
152
  };
144
153
 
145
- return /*#__PURE__*/React__namespace.createElement("div", {
146
- className: "p-listbox-header"
147
- }, /*#__PURE__*/React__namespace.createElement("div", {
148
- className: "p-listbox-filter-container"
149
- }, /*#__PURE__*/React__namespace.createElement(inputtext.InputText, _extends({
150
- type: "text",
151
- value: props.filter,
152
- onChange: onFilter,
153
- className: "p-listbox-filter",
154
- disabled: props.disabled,
155
- placeholder: props.filterPlaceholder
156
- }, props.filterInputProps)), /*#__PURE__*/React__namespace.createElement("span", {
157
- className: "p-listbox-filter-icon pi pi-search"
158
- })));
154
+ var createHeader = function createHeader() {
155
+ var content = /*#__PURE__*/React__namespace.createElement("div", {
156
+ className: "p-listbox-filter-container"
157
+ }, /*#__PURE__*/React__namespace.createElement(inputtext.InputText, _extends({
158
+ type: "text",
159
+ value: props.filter,
160
+ onChange: onFilter,
161
+ className: "p-listbox-filter",
162
+ disabled: props.disabled,
163
+ placeholder: props.filterPlaceholder
164
+ }, props.filterInputProps)), /*#__PURE__*/React__namespace.createElement("span", {
165
+ className: "p-listbox-filter-icon pi pi-search"
166
+ }));
167
+
168
+ if (props.filterTemplate) {
169
+ var defaultContentOptions = {
170
+ className: 'p-listbox-filter-container',
171
+ element: content,
172
+ filterOptions: filterOptions,
173
+ filterInputChange: onFilter,
174
+ filterIconClassName: 'p-dropdown-filter-icon pi pi-search',
175
+ props: props
176
+ };
177
+ content = utils.ObjectUtils.getJSXElement(props.filterTemplate, defaultContentOptions);
178
+ }
179
+
180
+ return /*#__PURE__*/React__namespace.createElement("div", {
181
+ className: "p-listbox-header"
182
+ }, content);
183
+ };
184
+
185
+ var content = createHeader();
186
+ return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, content);
159
187
  });
160
188
  ListBoxHeader.displayName = 'ListBoxHeader';
161
189
 
@@ -223,6 +251,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
223
251
  var content = props.template ? utils.ObjectUtils.getJSXElement(props.template, props.option) : props.label;
224
252
  return /*#__PURE__*/React__namespace.createElement("li", {
225
253
  className: className,
254
+ style: props.style,
226
255
  onClick: onClick,
227
256
  onTouchEnd: onTouchEnd,
228
257
  onKeyDown: onKeyDown,
@@ -342,6 +371,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
342
371
  };
343
372
 
344
373
  var onFilter = function onFilter(event) {
374
+ virtualScrollerRef.current && virtualScrollerRef.current.scrollToIndex(0);
345
375
  var originalEvent = event.originalEvent,
346
376
  value = event.value;
347
377
 
@@ -355,6 +385,13 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
355
385
  }
356
386
  };
357
387
 
388
+ var resetFilter = function resetFilter() {
389
+ setFilterValueState('');
390
+ props.onFilter && props.onFilter({
391
+ filter: ''
392
+ });
393
+ };
394
+
358
395
  var updateModel = function updateModel(event, value) {
359
396
  if (props.onChange) {
360
397
  props.onChange({
@@ -377,11 +414,44 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
377
414
  });
378
415
  };
379
416
 
417
+ var getSelectedOptionIndex = function getSelectedOptionIndex() {
418
+ if (props.value != null && visibleOptions) {
419
+ if (props.optionGroupLabel) {
420
+ for (var i = 0; i < visibleOptions.length; i++) {
421
+ var selectedOptionIndex = findOptionIndexInList(props.value, getOptionGroupChildren(visibleOptions[i]));
422
+
423
+ if (selectedOptionIndex !== -1) {
424
+ return {
425
+ group: i,
426
+ option: selectedOptionIndex
427
+ };
428
+ }
429
+ }
430
+ } else {
431
+ return findOptionIndexInList(props.value, visibleOptions);
432
+ }
433
+ }
434
+
435
+ return -1;
436
+ };
437
+
438
+ var equalityKey = function equalityKey() {
439
+ return props.optionValue ? null : props.dataKey;
440
+ };
441
+
442
+ var findOptionIndexInList = function findOptionIndexInList(value, list) {
443
+ var key = equalityKey();
444
+ return list.findIndex(function (item) {
445
+ return utils.ObjectUtils.equals(value, getOptionValue(item), key);
446
+ });
447
+ };
448
+
380
449
  var isSelected = function isSelected(option) {
381
450
  var optionValue = getOptionValue(option);
451
+ var key = equalityKey();
382
452
  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);
453
+ return utils.ObjectUtils.equals(val, optionValue, key);
454
+ }) : utils.ObjectUtils.equals(props.value, optionValue, key);
385
455
  };
386
456
 
387
457
  var getOptionLabel = function getOptionLabel(option) {
@@ -453,17 +523,45 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
453
523
  }
454
524
  };
455
525
 
526
+ var scrollToSelectedIndex = function scrollToSelectedIndex() {
527
+ if (virtualScrollerRef.current) {
528
+ var selectedIndex = getSelectedOptionIndex();
529
+
530
+ if (selectedIndex !== -1) {
531
+ setTimeout(function () {
532
+ return virtualScrollerRef.current.scrollToIndex(selectedIndex);
533
+ }, 0);
534
+ }
535
+ }
536
+ };
537
+
538
+ React__namespace.useImperativeHandle(ref, function () {
539
+ return _objectSpread({
540
+ getElement: function getElement() {
541
+ return elementRef.current;
542
+ },
543
+ getVirtualScroller: function getVirtualScroller() {
544
+ return virtualScrollerRef.current;
545
+ }
546
+ }, props);
547
+ });
548
+ hooks.useMountEffect(function () {
549
+ scrollToSelectedIndex();
550
+ });
551
+
456
552
  var createHeader = function createHeader() {
457
553
  return props.filter ? /*#__PURE__*/React__namespace.createElement(ListBoxHeader, {
458
554
  filter: filteredValue,
459
555
  onFilter: onFilter,
556
+ resetFilter: resetFilter,
557
+ filterTemplate: props.filterTemplate,
460
558
  disabled: props.disabled,
461
559
  filterPlaceholder: props.filterPlaceholder,
462
560
  filterInputProps: props.filterInputProps
463
561
  }) : null;
464
562
  };
465
563
 
466
- var createGroupChildren = function createGroupChildren(optionGroup) {
564
+ var createGroupChildren = function createGroupChildren(optionGroup, style) {
467
565
  var groupChildren = getOptionGroupChildren(optionGroup);
468
566
  return groupChildren.map(function (option, j) {
469
567
  var optionLabel = getOptionLabel(option);
@@ -474,6 +572,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
474
572
  key: optionKey,
475
573
  label: optionLabel,
476
574
  option: option,
575
+ style: style,
477
576
  template: props.itemTemplate,
478
577
  selected: isSelected(option),
479
578
  onClick: onOptionSelect,
@@ -485,14 +584,20 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
485
584
  };
486
585
 
487
586
  var createItem = function createItem(option, index) {
587
+ var scrollerOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
588
+ var style = {
589
+ height: scrollerOptions.props ? scrollerOptions.props.itemSize : undefined
590
+ };
591
+
488
592
  if (props.optionGroupLabel) {
489
593
  var groupContent = props.optionGroupTemplate ? utils.ObjectUtils.getJSXElement(props.optionGroupTemplate, option, index) : getOptionGroupLabel(option);
490
- var groupChildrenContent = createGroupChildren(option);
594
+ var groupChildrenContent = createGroupChildren(option, style);
491
595
  var key = index + '_' + getOptionGroupRenderKey(option);
492
596
  return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, {
493
597
  key: key
494
598
  }, /*#__PURE__*/React__namespace.createElement("li", {
495
599
  className: "p-listbox-item-group",
600
+ style: style,
496
601
  role: "group"
497
602
  }, groupContent), groupChildrenContent);
498
603
  } else {
@@ -504,6 +609,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
504
609
  key: optionKey,
505
610
  label: optionLabel,
506
611
  option: option,
612
+ style: style,
507
613
  template: props.itemTemplate,
508
614
  selected: isSelected(option),
509
615
  onClick: onOptionSelect,
@@ -527,8 +633,8 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
527
633
  filter: visibleOptions
528
634
  }));
529
635
  },
530
- itemTemplate: function itemTemplate(item, option) {
531
- return item && createItem(item, option.index);
636
+ itemTemplate: function itemTemplate(item, options) {
637
+ return item && createItem(item, options.index, options);
532
638
  },
533
639
  contentTemplate: function contentTemplate(option) {
534
640
  var className = utils.classNames('p-listbox-list', option.className);
@@ -603,6 +709,7 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
603
709
  multiple: false,
604
710
  metaKeySelection: false,
605
711
  filter: false,
712
+ filterTemplate: null,
606
713
  filterBy: null,
607
714
  filterValue: null,
608
715
  filterMatchMode: 'contains',
@@ -624,4 +731,4 @@ this.primereact.listbox = (function (exports, React, api, tooltip, utils, virtua
624
731
 
625
732
  return exports;
626
733
 
627
- })({}, React, primereact.api, primereact.tooltip, primereact.utils, primereact.virtualscroller, primereact.inputtext, primereact.ripple);
734
+ })({}, 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,r,l,n,i,a,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(r){if("default"!==r){var l=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,l.get?l:{enumerable:!0,get:function(){return e[r]}})}})),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 r=arguments[t];for(var l in r)Object.prototype.hasOwnProperty.call(r,l)&&(e[l]=r[l])}return e},p.apply(this,arguments)}function f(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function d(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,l=new Array(t);r<t;r++)l[r]=e[r];return l}function m(e){if(Array.isArray(e))return d(e)}function b(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function v(e,t){if(e){if("string"==typeof e)return d(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?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 m(e)||b(e)||v(e)||y()}function g(e){if(Array.isArray(e))return e}function O(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var l,n,i=[],a=!0,o=!1;try{for(r=r.call(e);!(a=(l=r.next()).done)&&(i.push(l.value),!t||i.length!==t);a=!0);}catch(e){o=!0,n=e}finally{try{a||null==r.return||r.return()}finally{if(o)throw n}}return i}}function E(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var j=s.memo((function(e){var t={filter:function(e){return r(e)},reset:function(){return e.resetFilter()}},r=function(t){e.onFilter&&e.onFilter({originalEvent:t,value:t.target.value})},l=function(){var l=s.createElement("div",{className:"p-listbox-filter-container"},s.createElement(o.InputText,p({type:"text",value:e.filter,onChange:r,className:"p-listbox-filter",disabled:e.disabled,placeholder:e.filterPlaceholder},e.filterInputProps)),s.createElement("span",{className:"p-listbox-filter-icon pi pi-search"}));e.filterTemplate&&(l=i.ObjectUtils.getJSXElement(e.filterTemplate,{className:"p-listbox-filter-container",element:l,filterOptions:t,filterInputChange:r,filterIconClassName:"p-dropdown-filter-icon pi pi-search",props:e}));return s.createElement("div",{className:"p-listbox-header"},l)}();return s.createElement(s.Fragment,null,l)}));j.displayName="ListBoxHeader";var x=s.memo((function(e){var t=function(t){e.onClick&&e.onClick({originalEvent:t,option:e.option}),t.preventDefault()},r=function e(t){var r=t.nextElementSibling;return r?i.DomHandler.hasClass(r,"p-disabled")||i.DomHandler.hasClass(r,"p-listbox-item-group")?e(r):r:null},l=function e(t){var r=t.previousElementSibling;return r?i.DomHandler.hasClass(r,"p-disabled")||i.DomHandler.hasClass(r,"p-listbox-item-group")?e(r):r:null},n=i.classNames("p-listbox-item",{"p-highlight":e.selected,"p-disabled":e.disabled},e.option.className),a=e.template?i.ObjectUtils.getJSXElement(e.template,e.option):e.label;return s.createElement("li",{className:n,style:e.style,onClick:t,onTouchEnd:function(t){e.onTouchEnd&&e.onTouchEnd({originalEvent:t,option:e.option})},onKeyDown:function(e){var n=e.currentTarget;switch(e.which){case 40:var i=r(n);i&&i.focus(),e.preventDefault();break;case 38:var a=l(n);a&&a.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},a,s.createElement(u.Ripple,null))}));function S(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var l=Object.getOwnPropertySymbols(e);t&&(l=l.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,l)}return r}function D(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?S(Object(r),!0).forEach((function(t){f(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):S(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}function T(e,t){var r="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!r){if(Array.isArray(e)||(r=w(e))||t&&e&&"number"==typeof e.length){r&&(e=r);var l=0,n=function(){};return{s:n,n:function(){return l>=e.length?{done:!0}:{done:!1,value:e[l++]}},e:function(e){throw e},f:n}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,o=!1;return{s:function(){r=r.call(e)},n:function(){var e=r.next();return a=e.done,e},e:function(e){o=!0,i=e},f:function(){try{a||null==r.return||r.return()}finally{if(o)throw i}}}}function w(e,t){if(e){if("string"==typeof e)return C(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?C(e,t):void 0}}function C(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,l=new Array(t);r<t;r++)l[r]=e[r];return l}x.displayName="ListBoxItem";var I=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],m=f[1],b=s.useRef(null),y=s.useRef(null),S=s.useRef(!1),w=(e.onFilterValueChange?e.filterValue:d)||"",C=w&&w.trim().length>0,N=function(t){var r=t.option;e.disabled||q(r)||(e.multiple?F(t.originalEvent,r):L(t.originalEvent,r),S.current=!1)},P=function(){e.disabled||(S.current=!0)},L=function(t,r){var l=_(r),n=!1,i=null;!S.current&&e.metaKeySelection?l?(t.metaKey||t.ctrlKey)&&(i=null,n=!0):(i=R(r),n=!0):(i=l?null:R(r),n=!0);n&&k(t,i)},F=function(t,r){var l=_(r),n=!1,i=null;if(!S&&e.metaKeySelection){var a=t.metaKey||t.ctrlKey;l?(i=a?K(r):[R(r)],n=!0):(i=[].concat(h(i=a&&e.value||[]),[R(r)]),n=!0)}else i=l?K(r):[].concat(h(e.value||[]),[R(r)]),n=!0;n&&e.onChange({originalEvent:t,value:i,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:i}})},U=function(t){y.current&&y.current.scrollToIndex(0);var r=t.value;e.onFilterValueChange?e.onFilterValueChange({originalEvent:t.originalEvent,value:r}):m(r)},A=function(){m(""),e.onFilter&&e.onFilter({filter:""})},k=function(t,r){e.onChange&&e.onChange({originalEvent:t,value:r,stopPropagation:function(){},preventDefault:function(){},target:{name:e.name,id:e.id,value:r}})},K=function(t){return e.value.filter((function(r){return!i.ObjectUtils.equals(r,R(t),e.dataKey)}))},V=function(){if(null!=e.value&&W){if(!e.optionGroupLabel)return M(e.value,W);for(var t=0;t<W.length;t++){var r=M(e.value,X(W[t]));if(-1!==r)return{group:t,option:r}}}return-1},G=function(){return e.optionValue?null:e.dataKey},M=function(e,t){var r=G();return t.findIndex((function(t){return i.ObjectUtils.equals(e,R(t),r)}))},_=function(t){var r=R(t),l=G();return e.multiple&&e.value?e.value.some((function(e){return i.ObjectUtils.equals(e,r,l)})):i.ObjectUtils.equals(e.value,r,l)},B=function(t){return e.optionLabel?i.ObjectUtils.resolveFieldData(t,e.optionLabel):t&&void 0!==t.label?t.label:t},R=function(t){return e.optionValue?i.ObjectUtils.resolveFieldData(t,e.optionValue):t&&void 0!==t.value?t.value:t},H=function(t){return e.dataKey?i.ObjectUtils.resolveFieldData(t,e.dataKey):B(t)},q=function(t){return e.optionDisabled?i.ObjectUtils.isFunction(e.optionDisabled)?e.optionDisabled(t):i.ObjectUtils.resolveFieldData(t,e.optionDisabled):!(!t||void 0===t.disabled)&&t.disabled},z=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},J=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupLabel)},X=function(t){return i.ObjectUtils.resolveFieldData(t,e.optionGroupChildren)},$=function(){if(y.current){var e=V();-1!==e&&setTimeout((function(){return y.current.scrollToIndex(e)}),0)}};s.useImperativeHandle(t,(function(){return D({getElement:function(){return b.current},getVirtualScroller:function(){return y.current}},e)})),l.useMountEffect((function(){$()}));var Y=function(t,r){return X(t).map((function(t,l){var n=B(t),i=l+"_"+H(t),a=q(t),o=a?null:e.tabIndex||0;return s.createElement(x,{key:i,label:n,option:t,style:r,template:e.itemTemplate,selected:_(t),onClick:N,onTouchEnd:P,tabIndex:o,disabled:a})}))},Q=function(t,r){var l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n={height:l.props?l.props.itemSize:void 0};if(e.optionGroupLabel){var a=e.optionGroupTemplate?i.ObjectUtils.getJSXElement(e.optionGroupTemplate,t,r):J(t),o=Y(t,n),u=r+"_"+z(t);return s.createElement(s.Fragment,{key:u},s.createElement("li",{className:"p-listbox-item-group",style:n,role:"group"},a),o)}var c=B(t),p=r+"_"+H(t),f=q(t),d=f?null:e.tabIndex||0;return s.createElement(x,{key:p,label:c,option:t,style:n,template:e.itemTemplate,selected:_(t),onClick:N,onTouchEnd:P,tabIndex:d,disabled:f})},W=function(){if(C){var t=w.trim().toLocaleLowerCase(e.filterLocale),l=e.filterBy?e.filterBy.split(","):[e.optionLabel||"label"];if(e.optionGroupLabel){var n,i=[],a=T(e.options);try{for(a.s();!(n=a.n()).done;){var o=n.value,u=r.FilterService.filter(X(o),l,t,e.filterMatchMode,e.filterLocale);u&&u.length&&i.push(D(D({},o),{items:u}))}}catch(e){a.e(e)}finally{a.f()}return i}return r.FilterService.filter(e.options,l,t,e.filterMatchMode,e.filterLocale)}return e.options}(),Z=i.ObjectUtils.isNotEmpty(e.tooltip),ee=i.ObjectUtils.findDiffKeys(e,I.defaultProps),te=i.classNames("p-listbox p-component",{"p-disabled":e.disabled},e.className),re=i.classNames("p-listbox-list-wrapper",e.listClassName),le=function(){if(e.virtualScrollerOptions){var t=D(D({},e.virtualScrollerOptions),{items:W,onLazyLoad:function(t){return e.virtualScrollerOptions.onLazyLoad(D(D({},t),{filter:W}))},itemTemplate:function(e,t){return e&&Q(e,t.index,t)},contentTemplate:function(t){var r=i.classNames("p-listbox-list",t.className);return s.createElement("ul",{ref:t.contentRef,className:r,role:"listbox","aria-multiselectable":e.multiple,"aria-labelledby":e["aria-labelledby"],"aria-label":e["aria-label"]},t.children)}});return s.createElement(a.VirtualScroller,p({ref:y},t))}var r=W?W.map(Q):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"]},r)}(),ne=e.filter?s.createElement(j,{filter:w,onFilter:U,resetFilter:A,filterTemplate:e.filterTemplate,disabled:e.disabled,filterPlaceholder:e.filterPlaceholder,filterInputProps:e.filterInputProps}):null;return s.createElement(s.Fragment,null,s.createElement("div",p({ref:b,id:e.id,className:te,style:e.style},ee),ne,s.createElement("div",{className:re,style:e.listStyle},le)),Z&&s.createElement(n.Tooltip,p({target:b,content:e.tooltip},e.tooltipOptions)))})));return I.displayName="ListBox",I.defaultProps={__TYPE:"ListBox",id:null,value:null,options:null,optionLabel:null,optionValue:null,optionDisabled:null,optionGroupLabel:null,optionGroupChildren:null,optionGroupTemplate:null,itemTemplate:null,style:null,listStyle:null,listClassName:null,className:null,virtualScrollerOptions:null,disabled:null,dataKey:null,multiple:!1,metaKeySelection:!1,filter:!1,filterTemplate:null,filterBy:null,filterValue:null,filterMatchMode:"contains",filterPlaceholder:null,filterLocale:void 0,filterInputProps:null,tabIndex:0,tooltip:null,tooltipOptions:null,"aria-label":null,"aria-labelledby":null,onChange:null,onFilterValueChange:null},e.ListBox=I,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.hooks,primereact.tooltip,primereact.utils,primereact.virtualscroller,primereact.inputtext,primereact.ripple);