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