primevue 3.12.4 → 3.13.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 (687) hide show
  1. package/README.md +4 -4
  2. package/accordion/accordion.cjs.js +18 -16
  3. package/accordion/accordion.cjs.min.js +1 -1
  4. package/accordion/accordion.esm.js +20 -18
  5. package/accordion/accordion.esm.min.js +1 -1
  6. package/accordion/accordion.js +19 -17
  7. package/accordion/accordion.min.js +1 -1
  8. package/accordiontab/accordiontab.esm.js +1 -1
  9. package/accordiontab/accordiontab.esm.min.js +1 -1
  10. package/accordiontab/accordiontab.js +1 -1
  11. package/api/api.js +1 -1
  12. package/autocomplete/AutoComplete.d.ts +5 -0
  13. package/autocomplete/AutoComplete.vue +15 -12
  14. package/autocomplete/autocomplete.cjs.js +165 -154
  15. package/autocomplete/autocomplete.cjs.min.js +1 -1
  16. package/autocomplete/autocomplete.esm.js +163 -153
  17. package/autocomplete/autocomplete.esm.min.js +1 -1
  18. package/autocomplete/autocomplete.js +166 -156
  19. package/autocomplete/autocomplete.min.js +1 -1
  20. package/avatar/avatar.cjs.js +9 -6
  21. package/avatar/avatar.cjs.min.js +1 -1
  22. package/avatar/avatar.esm.js +11 -8
  23. package/avatar/avatar.esm.min.js +1 -1
  24. package/avatar/avatar.js +10 -7
  25. package/avatar/avatar.min.js +1 -1
  26. package/avatargroup/avatargroup.cjs.js +1 -1
  27. package/avatargroup/avatargroup.cjs.min.js +1 -1
  28. package/avatargroup/avatargroup.esm.js +3 -3
  29. package/avatargroup/avatargroup.esm.min.js +1 -1
  30. package/avatargroup/avatargroup.js +2 -2
  31. package/avatargroup/avatargroup.min.js +1 -1
  32. package/badge/badge.cjs.js +3 -1
  33. package/badge/badge.cjs.min.js +1 -1
  34. package/badge/badge.esm.js +5 -3
  35. package/badge/badge.esm.min.js +1 -1
  36. package/badge/badge.js +4 -2
  37. package/badge/badge.min.js +1 -1
  38. package/badgedirective/badgedirective.esm.js +1 -1
  39. package/badgedirective/badgedirective.esm.min.js +1 -1
  40. package/badgedirective/badgedirective.js +1 -1
  41. package/blockui/blockui.cjs.js +1 -1
  42. package/blockui/blockui.cjs.min.js +1 -1
  43. package/blockui/blockui.esm.js +3 -3
  44. package/blockui/blockui.esm.min.js +1 -1
  45. package/blockui/blockui.js +2 -2
  46. package/blockui/blockui.min.js +1 -1
  47. package/breadcrumb/breadcrumb.cjs.js +25 -23
  48. package/breadcrumb/breadcrumb.cjs.min.js +1 -1
  49. package/breadcrumb/breadcrumb.esm.js +27 -25
  50. package/breadcrumb/breadcrumb.esm.min.js +1 -1
  51. package/breadcrumb/breadcrumb.js +26 -24
  52. package/breadcrumb/breadcrumb.min.js +1 -1
  53. package/button/button.cjs.js +13 -12
  54. package/button/button.cjs.min.js +1 -1
  55. package/button/button.esm.js +14 -13
  56. package/button/button.esm.min.js +1 -1
  57. package/button/button.js +14 -13
  58. package/button/button.min.js +1 -1
  59. package/calendar/Calendar.vue +22 -17
  60. package/calendar/calendar.cjs.js +464 -429
  61. package/calendar/calendar.cjs.min.js +1 -1
  62. package/calendar/calendar.esm.js +463 -429
  63. package/calendar/calendar.esm.min.js +1 -1
  64. package/calendar/calendar.js +465 -431
  65. package/calendar/calendar.min.js +1 -1
  66. package/card/card.cjs.js +7 -7
  67. package/card/card.cjs.min.js +1 -1
  68. package/card/card.esm.js +9 -9
  69. package/card/card.esm.min.js +1 -1
  70. package/card/card.js +8 -8
  71. package/card/card.min.js +1 -1
  72. package/carousel/Carousel.vue +1 -1
  73. package/carousel/carousel.cjs.js +57 -49
  74. package/carousel/carousel.cjs.min.js +1 -1
  75. package/carousel/carousel.esm.js +58 -50
  76. package/carousel/carousel.esm.min.js +1 -1
  77. package/carousel/carousel.js +58 -50
  78. package/carousel/carousel.min.js +1 -1
  79. package/cascadeselect/CascadeSelect.vue +7 -11
  80. package/cascadeselect/cascadeselect.cjs.js +80 -75
  81. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  82. package/cascadeselect/cascadeselect.esm.js +79 -75
  83. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  84. package/cascadeselect/cascadeselect.js +81 -77
  85. package/cascadeselect/cascadeselect.min.js +1 -1
  86. package/chart/chart.cjs.js +7 -8
  87. package/chart/chart.cjs.min.js +1 -1
  88. package/chart/chart.esm.js +7 -6
  89. package/chart/chart.esm.min.js +1 -1
  90. package/chart/chart.js +6 -5
  91. package/chart/chart.min.js +1 -1
  92. package/checkbox/checkbox.cjs.js +16 -14
  93. package/checkbox/checkbox.cjs.min.js +1 -1
  94. package/checkbox/checkbox.esm.js +18 -16
  95. package/checkbox/checkbox.esm.min.js +1 -1
  96. package/checkbox/checkbox.js +17 -15
  97. package/checkbox/checkbox.min.js +1 -1
  98. package/chip/chip.cjs.js +13 -12
  99. package/chip/chip.cjs.min.js +1 -1
  100. package/chip/chip.esm.js +15 -14
  101. package/chip/chip.esm.min.js +1 -1
  102. package/chip/chip.js +14 -13
  103. package/chip/chip.min.js +1 -1
  104. package/chips/chips.cjs.js +22 -20
  105. package/chips/chips.cjs.min.js +1 -1
  106. package/chips/chips.esm.js +24 -22
  107. package/chips/chips.esm.min.js +1 -1
  108. package/chips/chips.js +23 -21
  109. package/chips/chips.min.js +1 -1
  110. package/colorpicker/ColorPicker.vue +9 -11
  111. package/colorpicker/colorpicker.cjs.js +74 -72
  112. package/colorpicker/colorpicker.cjs.min.js +1 -1
  113. package/colorpicker/colorpicker.esm.js +74 -73
  114. package/colorpicker/colorpicker.esm.min.js +1 -1
  115. package/colorpicker/colorpicker.js +75 -74
  116. package/colorpicker/colorpicker.min.js +1 -1
  117. package/column/Column.d.ts +4 -0
  118. package/column/column.esm.js +1 -1
  119. package/column/column.esm.min.js +1 -1
  120. package/column/column.js +1 -1
  121. package/columngroup/columngroup.esm.js +1 -1
  122. package/columngroup/columngroup.esm.min.js +1 -1
  123. package/columngroup/columngroup.js +1 -1
  124. package/config/config.cjs.js +1 -1
  125. package/config/config.esm.js +1 -2
  126. package/config/config.esm.min.js +1 -1
  127. package/config/config.js +2 -2
  128. package/confirmationeventbus/confirmationeventbus.esm.js +1 -1
  129. package/confirmationeventbus/confirmationeventbus.esm.min.js +1 -1
  130. package/confirmationeventbus/confirmationeventbus.js +1 -1
  131. package/confirmationoptions/ConfirmationOptions.d.ts +8 -0
  132. package/confirmationservice/confirmationservice.cjs.js +2 -2
  133. package/confirmationservice/confirmationservice.esm.js +1 -1
  134. package/confirmationservice/confirmationservice.esm.min.js +1 -1
  135. package/confirmationservice/confirmationservice.js +3 -3
  136. package/confirmdialog/confirmdialog.cjs.js +15 -13
  137. package/confirmdialog/confirmdialog.cjs.min.js +1 -1
  138. package/confirmdialog/confirmdialog.esm.js +11 -9
  139. package/confirmdialog/confirmdialog.esm.min.js +1 -1
  140. package/confirmdialog/confirmdialog.js +16 -14
  141. package/confirmdialog/confirmdialog.min.js +1 -1
  142. package/confirmpopup/ConfirmPopup.vue +6 -4
  143. package/confirmpopup/confirmpopup.cjs.js +62 -53
  144. package/confirmpopup/confirmpopup.cjs.min.js +1 -1
  145. package/confirmpopup/confirmpopup.esm.js +58 -50
  146. package/confirmpopup/confirmpopup.esm.min.js +1 -1
  147. package/confirmpopup/confirmpopup.js +63 -55
  148. package/confirmpopup/confirmpopup.min.js +1 -1
  149. package/contextmenu/ContextMenu.vue +6 -4
  150. package/contextmenu/contextmenu.cjs.js +68 -58
  151. package/contextmenu/contextmenu.cjs.min.js +1 -1
  152. package/contextmenu/contextmenu.esm.js +68 -59
  153. package/contextmenu/contextmenu.esm.min.js +1 -1
  154. package/contextmenu/contextmenu.js +69 -60
  155. package/contextmenu/contextmenu.min.js +1 -1
  156. package/core/core.js +780 -642
  157. package/core/core.min.js +19 -14
  158. package/datatable/ColumnFilter.vue +6 -4
  159. package/datatable/DataTable.d.ts +5 -2
  160. package/datatable/DataTable.vue +17 -7
  161. package/datatable/HeaderCell.vue +6 -1
  162. package/datatable/TableBody.vue +1 -6
  163. package/datatable/TableHeader.vue +5 -1
  164. package/datatable/datatable.cjs.js +509 -470
  165. package/datatable/datatable.cjs.min.js +1 -1
  166. package/datatable/datatable.esm.js +499 -461
  167. package/datatable/datatable.esm.min.js +1 -1
  168. package/datatable/datatable.js +510 -472
  169. package/datatable/datatable.min.js +1 -1
  170. package/dataview/dataview.cjs.js +16 -14
  171. package/dataview/dataview.cjs.min.js +1 -1
  172. package/dataview/dataview.esm.js +17 -15
  173. package/dataview/dataview.esm.min.js +1 -1
  174. package/dataview/dataview.js +17 -15
  175. package/dataview/dataview.min.js +1 -1
  176. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.js +17 -15
  177. package/dataviewlayoutoptions/dataviewlayoutoptions.cjs.min.js +1 -1
  178. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.js +19 -17
  179. package/dataviewlayoutoptions/dataviewlayoutoptions.esm.min.js +1 -1
  180. package/dataviewlayoutoptions/dataviewlayoutoptions.js +18 -16
  181. package/dataviewlayoutoptions/dataviewlayoutoptions.min.js +1 -1
  182. package/deferredcontent/deferredcontent.cjs.js +1 -1
  183. package/deferredcontent/deferredcontent.cjs.min.js +1 -1
  184. package/deferredcontent/deferredcontent.esm.js +3 -3
  185. package/deferredcontent/deferredcontent.esm.min.js +1 -1
  186. package/deferredcontent/deferredcontent.js +2 -2
  187. package/deferredcontent/deferredcontent.min.js +1 -1
  188. package/dialog/Dialog.vue +6 -8
  189. package/dialog/dialog.cjs.js +113 -107
  190. package/dialog/dialog.cjs.min.js +1 -1
  191. package/dialog/dialog.esm.js +113 -108
  192. package/dialog/dialog.esm.min.js +1 -1
  193. package/dialog/dialog.js +114 -109
  194. package/dialog/dialog.min.js +1 -1
  195. package/divider/divider.cjs.js +3 -3
  196. package/divider/divider.cjs.min.js +1 -1
  197. package/divider/divider.esm.js +5 -5
  198. package/divider/divider.esm.min.js +1 -1
  199. package/divider/divider.js +4 -4
  200. package/divider/divider.min.js +1 -1
  201. package/dock/dock.cjs.js +26 -23
  202. package/dock/dock.cjs.min.js +1 -1
  203. package/dock/dock.esm.js +26 -23
  204. package/dock/dock.esm.min.js +1 -1
  205. package/dock/dock.js +27 -24
  206. package/dock/dock.min.js +1 -1
  207. package/dropdown/Dropdown.vue +13 -15
  208. package/dropdown/dropdown.cjs.js +187 -179
  209. package/dropdown/dropdown.cjs.min.js +1 -1
  210. package/dropdown/dropdown.esm.js +186 -179
  211. package/dropdown/dropdown.esm.min.js +1 -1
  212. package/dropdown/dropdown.js +188 -181
  213. package/dropdown/dropdown.min.js +1 -1
  214. package/editor/editor.cjs.js +22 -22
  215. package/editor/editor.cjs.min.js +1 -1
  216. package/editor/editor.esm.js +23 -23
  217. package/editor/editor.esm.min.js +1 -1
  218. package/editor/editor.js +23 -23
  219. package/editor/editor.min.js +1 -1
  220. package/fieldset/fieldset.cjs.js +22 -17
  221. package/fieldset/fieldset.cjs.min.js +1 -1
  222. package/fieldset/fieldset.esm.js +23 -18
  223. package/fieldset/fieldset.esm.min.js +1 -1
  224. package/fieldset/fieldset.js +23 -18
  225. package/fieldset/fieldset.min.js +1 -1
  226. package/fileupload/FileUpload.d.ts +12 -0
  227. package/fileupload/FileUpload.vue +21 -7
  228. package/fileupload/fileupload.cjs.js +85 -65
  229. package/fileupload/fileupload.cjs.min.js +1 -1
  230. package/fileupload/fileupload.esm.js +83 -63
  231. package/fileupload/fileupload.esm.min.js +1 -1
  232. package/fileupload/fileupload.js +86 -66
  233. package/fileupload/fileupload.min.js +1 -1
  234. package/fullcalendar/fullcalendar.cjs.js +1 -31
  235. package/fullcalendar/fullcalendar.cjs.min.js +1 -1
  236. package/fullcalendar/fullcalendar.esm.js +3 -33
  237. package/fullcalendar/fullcalendar.esm.min.js +1 -1
  238. package/fullcalendar/fullcalendar.js +2 -32
  239. package/fullcalendar/fullcalendar.min.js +1 -1
  240. package/galleria/Galleria.vue +5 -3
  241. package/galleria/galleria.cjs.js +130 -112
  242. package/galleria/galleria.cjs.min.js +1 -1
  243. package/galleria/galleria.esm.js +128 -111
  244. package/galleria/galleria.esm.min.js +1 -1
  245. package/galleria/galleria.js +131 -114
  246. package/galleria/galleria.min.js +1 -1
  247. package/image/Image.vue +6 -2
  248. package/image/image.cjs.js +105 -84
  249. package/image/image.cjs.min.js +1 -1
  250. package/image/image.esm.js +103 -86
  251. package/image/image.esm.min.js +1 -1
  252. package/image/image.js +106 -86
  253. package/image/image.min.js +1 -1
  254. package/inlinemessage/inlinemessage.cjs.js +6 -4
  255. package/inlinemessage/inlinemessage.cjs.min.js +1 -1
  256. package/inlinemessage/inlinemessage.esm.js +8 -6
  257. package/inlinemessage/inlinemessage.esm.min.js +1 -1
  258. package/inlinemessage/inlinemessage.js +7 -5
  259. package/inlinemessage/inlinemessage.min.js +1 -1
  260. package/inplace/inplace.cjs.js +12 -9
  261. package/inplace/inplace.cjs.min.js +1 -1
  262. package/inplace/inplace.esm.js +13 -10
  263. package/inplace/inplace.esm.min.js +1 -1
  264. package/inplace/inplace.js +13 -10
  265. package/inplace/inplace.min.js +1 -1
  266. package/inputmask/inputmask.cjs.js +7 -7
  267. package/inputmask/inputmask.cjs.min.js +1 -1
  268. package/inputmask/inputmask.esm.js +9 -9
  269. package/inputmask/inputmask.esm.min.js +1 -1
  270. package/inputmask/inputmask.js +8 -8
  271. package/inputmask/inputmask.min.js +1 -1
  272. package/inputnumber/InputNumber.d.ts +4 -0
  273. package/inputnumber/InputNumber.vue +22 -3
  274. package/inputnumber/inputnumber.cjs.js +29 -9
  275. package/inputnumber/inputnumber.cjs.min.js +1 -1
  276. package/inputnumber/inputnumber.esm.js +29 -9
  277. package/inputnumber/inputnumber.esm.min.js +1 -1
  278. package/inputnumber/inputnumber.js +30 -10
  279. package/inputnumber/inputnumber.min.js +1 -1
  280. package/inputswitch/inputswitch.cjs.js +13 -12
  281. package/inputswitch/inputswitch.cjs.min.js +1 -1
  282. package/inputswitch/inputswitch.esm.js +15 -14
  283. package/inputswitch/inputswitch.esm.min.js +1 -1
  284. package/inputswitch/inputswitch.js +14 -13
  285. package/inputswitch/inputswitch.min.js +1 -1
  286. package/inputtext/InputText.d.ts +2 -2
  287. package/inputtext/InputText.vue +1 -0
  288. package/inputtext/inputtext.cjs.js +6 -3
  289. package/inputtext/inputtext.cjs.min.js +1 -1
  290. package/inputtext/inputtext.esm.js +8 -5
  291. package/inputtext/inputtext.esm.min.js +1 -1
  292. package/inputtext/inputtext.js +7 -4
  293. package/inputtext/inputtext.min.js +1 -1
  294. package/knob/knob.cjs.js +21 -14
  295. package/knob/knob.cjs.min.js +1 -1
  296. package/knob/knob.esm.js +23 -16
  297. package/knob/knob.esm.min.js +1 -1
  298. package/knob/knob.js +22 -15
  299. package/knob/knob.min.js +1 -1
  300. package/listbox/listbox.cjs.js +37 -34
  301. package/listbox/listbox.cjs.min.js +1 -1
  302. package/listbox/listbox.esm.js +37 -34
  303. package/listbox/listbox.esm.min.js +1 -1
  304. package/listbox/listbox.js +38 -35
  305. package/listbox/listbox.min.js +1 -1
  306. package/megamenu/megamenu.cjs.js +73 -66
  307. package/megamenu/megamenu.cjs.min.js +1 -1
  308. package/megamenu/megamenu.esm.js +74 -67
  309. package/megamenu/megamenu.esm.min.js +1 -1
  310. package/megamenu/megamenu.js +74 -67
  311. package/megamenu/megamenu.min.js +1 -1
  312. package/menu/Menu.d.ts +0 -1
  313. package/menu/Menu.vue +10 -5
  314. package/menu/menu.cjs.js +113 -101
  315. package/menu/menu.cjs.min.js +1 -1
  316. package/menu/menu.esm.js +112 -101
  317. package/menu/menu.esm.min.js +1 -1
  318. package/menu/menu.js +114 -103
  319. package/menu/menu.min.js +1 -1
  320. package/menubar/menubar.cjs.js +47 -40
  321. package/menubar/menubar.cjs.min.js +1 -1
  322. package/menubar/menubar.esm.js +48 -41
  323. package/menubar/menubar.esm.min.js +1 -1
  324. package/menubar/menubar.js +48 -41
  325. package/menubar/menubar.min.js +1 -1
  326. package/message/message.cjs.js +15 -12
  327. package/message/message.cjs.min.js +1 -1
  328. package/message/message.esm.js +16 -13
  329. package/message/message.esm.min.js +1 -1
  330. package/message/message.js +16 -13
  331. package/message/message.min.js +1 -1
  332. package/multiselect/MultiSelect.vue +11 -15
  333. package/multiselect/multiselect.cjs.js +255 -245
  334. package/multiselect/multiselect.cjs.min.js +1 -1
  335. package/multiselect/multiselect.esm.js +254 -245
  336. package/multiselect/multiselect.esm.min.js +1 -1
  337. package/multiselect/multiselect.js +256 -247
  338. package/multiselect/multiselect.min.js +1 -1
  339. package/orderlist/orderlist.cjs.js +15 -12
  340. package/orderlist/orderlist.cjs.min.js +1 -1
  341. package/orderlist/orderlist.esm.js +15 -12
  342. package/orderlist/orderlist.esm.min.js +1 -1
  343. package/orderlist/orderlist.js +16 -13
  344. package/orderlist/orderlist.min.js +1 -1
  345. package/organizationchart/organizationchart.cjs.js +42 -37
  346. package/organizationchart/organizationchart.cjs.min.js +1 -1
  347. package/organizationchart/organizationchart.esm.js +44 -39
  348. package/organizationchart/organizationchart.esm.min.js +1 -1
  349. package/organizationchart/organizationchart.js +43 -38
  350. package/organizationchart/organizationchart.min.js +1 -1
  351. package/overlayeventbus/overlayeventbus.esm.js +1 -1
  352. package/overlayeventbus/overlayeventbus.esm.min.js +1 -1
  353. package/overlayeventbus/overlayeventbus.js +1 -1
  354. package/overlaypanel/OverlayPanel.vue +7 -3
  355. package/overlaypanel/overlaypanel.cjs.js +60 -49
  356. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  357. package/overlaypanel/overlaypanel.esm.js +56 -46
  358. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  359. package/overlaypanel/overlaypanel.js +61 -51
  360. package/overlaypanel/overlaypanel.min.js +1 -1
  361. package/package.json +1 -1
  362. package/paginator/paginator.cjs.js +59 -54
  363. package/paginator/paginator.cjs.min.js +1 -1
  364. package/paginator/paginator.esm.js +53 -48
  365. package/paginator/paginator.esm.min.js +1 -1
  366. package/paginator/paginator.js +60 -55
  367. package/paginator/paginator.min.js +1 -1
  368. package/panel/panel.cjs.js +21 -16
  369. package/panel/panel.cjs.min.js +1 -1
  370. package/panel/panel.esm.js +22 -17
  371. package/panel/panel.esm.min.js +1 -1
  372. package/panel/panel.js +22 -17
  373. package/panel/panel.min.js +1 -1
  374. package/panelmenu/PanelMenuSub.vue +1 -1
  375. package/panelmenu/panelmenu.cjs.js +62 -57
  376. package/panelmenu/panelmenu.cjs.min.js +1 -1
  377. package/panelmenu/panelmenu.esm.js +64 -59
  378. package/panelmenu/panelmenu.esm.min.js +1 -1
  379. package/panelmenu/panelmenu.js +63 -58
  380. package/panelmenu/panelmenu.min.js +1 -1
  381. package/password/Password.d.ts +2 -2
  382. package/password/Password.vue +8 -12
  383. package/password/password.cjs.js +49 -51
  384. package/password/password.cjs.min.js +1 -1
  385. package/password/password.esm.js +49 -52
  386. package/password/password.esm.min.js +1 -1
  387. package/password/password.js +50 -53
  388. package/password/password.min.js +1 -1
  389. package/picklist/picklist.cjs.js +38 -34
  390. package/picklist/picklist.cjs.min.js +1 -1
  391. package/picklist/picklist.esm.js +38 -34
  392. package/picklist/picklist.esm.min.js +1 -1
  393. package/picklist/picklist.js +39 -35
  394. package/picklist/picklist.min.js +1 -1
  395. package/portal/Portal.d.ts +36 -0
  396. package/portal/Portal.vue +41 -0
  397. package/portal/package.json +9 -0
  398. package/portal/portal.cjs.js +48 -0
  399. package/portal/portal.cjs.min.js +1 -0
  400. package/portal/portal.esm.js +46 -0
  401. package/portal/portal.esm.min.js +1 -0
  402. package/portal/portal.js +49 -0
  403. package/portal/portal.min.js +1 -0
  404. package/progressbar/progressbar.cjs.js +14 -12
  405. package/progressbar/progressbar.cjs.min.js +1 -1
  406. package/progressbar/progressbar.esm.js +16 -14
  407. package/progressbar/progressbar.esm.min.js +1 -1
  408. package/progressbar/progressbar.js +15 -13
  409. package/progressbar/progressbar.min.js +1 -1
  410. package/progressspinner/ProgressSpinner.vue +3 -3
  411. package/progressspinner/progressspinner.cjs.js +7 -6
  412. package/progressspinner/progressspinner.cjs.min.js +1 -1
  413. package/progressspinner/progressspinner.esm.js +9 -8
  414. package/progressspinner/progressspinner.esm.min.js +1 -1
  415. package/progressspinner/progressspinner.js +8 -7
  416. package/progressspinner/progressspinner.min.js +1 -1
  417. package/radiobutton/RadioButton.vue +3 -3
  418. package/radiobutton/radiobutton.cjs.js +18 -15
  419. package/radiobutton/radiobutton.cjs.min.js +1 -1
  420. package/radiobutton/radiobutton.esm.js +20 -17
  421. package/radiobutton/radiobutton.esm.min.js +1 -1
  422. package/radiobutton/radiobutton.js +19 -16
  423. package/radiobutton/radiobutton.min.js +1 -1
  424. package/rating/rating.cjs.js +13 -8
  425. package/rating/rating.cjs.min.js +1 -1
  426. package/rating/rating.esm.js +15 -10
  427. package/rating/rating.esm.min.js +1 -1
  428. package/rating/rating.js +14 -9
  429. package/rating/rating.min.js +1 -1
  430. package/resources/primevue.css +0 -4
  431. package/resources/primevue.min.css +1 -1
  432. package/resources/themes/arya-blue/theme.css +15 -2
  433. package/resources/themes/arya-green/theme.css +15 -2
  434. package/resources/themes/arya-orange/theme.css +15 -2
  435. package/resources/themes/arya-purple/theme.css +15 -2
  436. package/resources/themes/bootstrap4-dark-blue/theme.css +15 -2
  437. package/resources/themes/bootstrap4-dark-purple/theme.css +15 -2
  438. package/resources/themes/bootstrap4-light-blue/theme.css +14 -1
  439. package/resources/themes/bootstrap4-light-purple/theme.css +14 -1
  440. package/resources/themes/fluent-light/theme.css +15 -2
  441. package/resources/themes/lara-dark-blue/theme.css +15 -2
  442. package/resources/themes/lara-dark-indigo/theme.css +15 -2
  443. package/resources/themes/lara-dark-purple/theme.css +15 -2
  444. package/resources/themes/lara-dark-teal/theme.css +15 -2
  445. package/resources/themes/lara-light-blue/theme.css +15 -2
  446. package/resources/themes/lara-light-indigo/theme.css +15 -2
  447. package/resources/themes/lara-light-purple/theme.css +15 -2
  448. package/resources/themes/lara-light-teal/theme.css +15 -2
  449. package/resources/themes/luna-amber/theme.css +15 -2
  450. package/resources/themes/luna-blue/theme.css +15 -2
  451. package/resources/themes/luna-green/theme.css +15 -2
  452. package/resources/themes/luna-pink/theme.css +15 -2
  453. package/resources/themes/md-dark-deeppurple/theme.css +16 -5
  454. package/resources/themes/md-dark-indigo/theme.css +16 -5
  455. package/resources/themes/md-light-deeppurple/theme.css +16 -5
  456. package/resources/themes/md-light-indigo/theme.css +16 -5
  457. package/resources/themes/mdc-dark-deeppurple/theme.css +16 -5
  458. package/resources/themes/mdc-dark-indigo/theme.css +16 -5
  459. package/resources/themes/mdc-light-deeppurple/theme.css +16 -5
  460. package/resources/themes/mdc-light-indigo/theme.css +16 -5
  461. package/resources/themes/nova/theme.css +15 -2
  462. package/resources/themes/nova-accent/theme.css +15 -2
  463. package/resources/themes/nova-alt/theme.css +15 -2
  464. package/resources/themes/nova-vue/theme.css +15 -2
  465. package/resources/themes/rhea/theme.css +15 -2
  466. package/resources/themes/saga-blue/theme.css +15 -2
  467. package/resources/themes/saga-green/theme.css +15 -2
  468. package/resources/themes/saga-orange/theme.css +15 -2
  469. package/resources/themes/saga-purple/theme.css +15 -2
  470. package/resources/themes/tailwind-light/theme.css +15 -2
  471. package/resources/themes/vela-blue/theme.css +15 -2
  472. package/resources/themes/vela-green/theme.css +15 -2
  473. package/resources/themes/vela-orange/theme.css +15 -2
  474. package/resources/themes/vela-purple/theme.css +15 -2
  475. package/ripple/ripple.esm.js +1 -1
  476. package/ripple/ripple.esm.min.js +1 -1
  477. package/ripple/ripple.js +1 -1
  478. package/row/row.esm.js +1 -1
  479. package/row/row.esm.min.js +1 -1
  480. package/row/row.js +1 -1
  481. package/scrollpanel/scrollpanel.cjs.js +9 -9
  482. package/scrollpanel/scrollpanel.cjs.min.js +1 -1
  483. package/scrollpanel/scrollpanel.esm.js +11 -11
  484. package/scrollpanel/scrollpanel.esm.min.js +1 -1
  485. package/scrollpanel/scrollpanel.js +10 -10
  486. package/scrollpanel/scrollpanel.min.js +1 -1
  487. package/scrolltop/scrolltop.cjs.js +6 -4
  488. package/scrolltop/scrolltop.cjs.min.js +1 -1
  489. package/scrolltop/scrolltop.esm.js +8 -6
  490. package/scrolltop/scrolltop.esm.min.js +1 -1
  491. package/scrolltop/scrolltop.js +7 -5
  492. package/scrolltop/scrolltop.min.js +1 -1
  493. package/selectbutton/selectbutton.cjs.js +12 -11
  494. package/selectbutton/selectbutton.cjs.min.js +1 -1
  495. package/selectbutton/selectbutton.esm.js +13 -12
  496. package/selectbutton/selectbutton.esm.min.js +1 -1
  497. package/selectbutton/selectbutton.js +13 -12
  498. package/selectbutton/selectbutton.min.js +1 -1
  499. package/sidebar/Sidebar.d.ts +4 -0
  500. package/sidebar/Sidebar.vue +9 -2
  501. package/sidebar/sidebar.cjs.js +66 -45
  502. package/sidebar/sidebar.cjs.min.js +1 -1
  503. package/sidebar/sidebar.esm.js +66 -46
  504. package/sidebar/sidebar.esm.min.js +1 -1
  505. package/sidebar/sidebar.js +67 -47
  506. package/sidebar/sidebar.min.js +1 -1
  507. package/skeleton/skeleton.cjs.js +3 -3
  508. package/skeleton/skeleton.cjs.min.js +1 -1
  509. package/skeleton/skeleton.esm.js +5 -5
  510. package/skeleton/skeleton.esm.min.js +1 -1
  511. package/skeleton/skeleton.js +4 -4
  512. package/skeleton/skeleton.min.js +1 -1
  513. package/slider/Slider.vue +1 -1
  514. package/slider/slider.cjs.js +34 -30
  515. package/slider/slider.cjs.min.js +1 -1
  516. package/slider/slider.esm.js +36 -32
  517. package/slider/slider.esm.min.js +1 -1
  518. package/slider/slider.js +35 -31
  519. package/slider/slider.min.js +1 -1
  520. package/speeddial/speeddial.cjs.js +23 -21
  521. package/speeddial/speeddial.cjs.min.js +1 -1
  522. package/speeddial/speeddial.esm.js +22 -20
  523. package/speeddial/speeddial.esm.min.js +1 -1
  524. package/speeddial/speeddial.js +24 -22
  525. package/speeddial/speeddial.min.js +1 -1
  526. package/splitbutton/splitbutton.cjs.js +7 -9
  527. package/splitbutton/splitbutton.cjs.min.js +1 -1
  528. package/splitbutton/splitbutton.esm.js +7 -9
  529. package/splitbutton/splitbutton.esm.min.js +1 -1
  530. package/splitbutton/splitbutton.js +8 -10
  531. package/splitbutton/splitbutton.min.js +1 -1
  532. package/splitter/splitter.cjs.js +13 -9
  533. package/splitter/splitter.cjs.min.js +1 -1
  534. package/splitter/splitter.esm.js +15 -11
  535. package/splitter/splitter.esm.min.js +1 -1
  536. package/splitter/splitter.js +14 -10
  537. package/splitter/splitter.min.js +1 -1
  538. package/splitterpanel/splitterpanel.cjs.js +2 -2
  539. package/splitterpanel/splitterpanel.cjs.min.js +1 -1
  540. package/splitterpanel/splitterpanel.esm.js +4 -4
  541. package/splitterpanel/splitterpanel.esm.min.js +1 -1
  542. package/splitterpanel/splitterpanel.js +3 -3
  543. package/splitterpanel/splitterpanel.min.js +1 -1
  544. package/steps/Steps.vue +1 -4
  545. package/steps/steps.cjs.js +29 -29
  546. package/steps/steps.cjs.min.js +1 -1
  547. package/steps/steps.esm.js +31 -31
  548. package/steps/steps.esm.min.js +1 -1
  549. package/steps/steps.js +30 -30
  550. package/steps/steps.min.js +1 -1
  551. package/styleclass/styleclass.esm.js +1 -1
  552. package/styleclass/styleclass.esm.min.js +1 -1
  553. package/styleclass/styleclass.js +1 -1
  554. package/tabmenu/TabMenu.vue +3 -3
  555. package/tabmenu/tabmenu.cjs.js +26 -24
  556. package/tabmenu/tabmenu.cjs.min.js +1 -1
  557. package/tabmenu/tabmenu.esm.js +27 -25
  558. package/tabmenu/tabmenu.esm.min.js +1 -1
  559. package/tabmenu/tabmenu.js +27 -25
  560. package/tabmenu/tabmenu.min.js +1 -1
  561. package/tabpanel/tabpanel.esm.js +1 -1
  562. package/tabpanel/tabpanel.esm.min.js +1 -1
  563. package/tabpanel/tabpanel.js +1 -1
  564. package/tabview/tabview.cjs.js +41 -36
  565. package/tabview/tabview.cjs.min.js +1 -1
  566. package/tabview/tabview.esm.js +42 -37
  567. package/tabview/tabview.esm.min.js +1 -1
  568. package/tabview/tabview.js +42 -37
  569. package/tabview/tabview.min.js +1 -1
  570. package/tag/tag.cjs.js +4 -4
  571. package/tag/tag.cjs.min.js +1 -1
  572. package/tag/tag.esm.js +6 -6
  573. package/tag/tag.esm.min.js +1 -1
  574. package/tag/tag.js +5 -5
  575. package/tag/tag.min.js +1 -1
  576. package/terminal/terminal.cjs.js +17 -17
  577. package/terminal/terminal.cjs.min.js +1 -1
  578. package/terminal/terminal.esm.js +16 -16
  579. package/terminal/terminal.esm.min.js +1 -1
  580. package/terminal/terminal.js +18 -18
  581. package/terminal/terminal.min.js +1 -1
  582. package/terminalservice/terminalservice.esm.js +1 -1
  583. package/terminalservice/terminalservice.esm.min.js +1 -1
  584. package/terminalservice/terminalservice.js +1 -1
  585. package/textarea/Textarea.vue +2 -1
  586. package/textarea/textarea.cjs.js +7 -4
  587. package/textarea/textarea.cjs.min.js +1 -1
  588. package/textarea/textarea.esm.js +9 -6
  589. package/textarea/textarea.esm.min.js +1 -1
  590. package/textarea/textarea.js +8 -5
  591. package/textarea/textarea.min.js +1 -1
  592. package/tieredmenu/TieredMenu.d.ts +0 -1
  593. package/tieredmenu/TieredMenu.vue +6 -4
  594. package/tieredmenu/tieredmenu.cjs.js +74 -64
  595. package/tieredmenu/tieredmenu.cjs.min.js +1 -1
  596. package/tieredmenu/tieredmenu.esm.js +73 -64
  597. package/tieredmenu/tieredmenu.esm.min.js +1 -1
  598. package/tieredmenu/tieredmenu.js +75 -66
  599. package/tieredmenu/tieredmenu.min.js +1 -1
  600. package/timeline/Timeline.d.ts +1 -1
  601. package/timeline/timeline.cjs.js +10 -8
  602. package/timeline/timeline.cjs.min.js +1 -1
  603. package/timeline/timeline.esm.js +12 -10
  604. package/timeline/timeline.esm.min.js +1 -1
  605. package/timeline/timeline.js +11 -9
  606. package/timeline/timeline.min.js +1 -1
  607. package/toast/Toast.vue +7 -5
  608. package/toast/toast.cjs.js +59 -49
  609. package/toast/toast.cjs.min.js +1 -1
  610. package/toast/toast.esm.js +54 -45
  611. package/toast/toast.esm.min.js +1 -1
  612. package/toast/toast.js +60 -51
  613. package/toast/toast.min.js +1 -1
  614. package/toasteventbus/toasteventbus.esm.js +1 -1
  615. package/toasteventbus/toasteventbus.esm.min.js +1 -1
  616. package/toasteventbus/toasteventbus.js +1 -1
  617. package/toastservice/toastservice.cjs.js +3 -3
  618. package/toastservice/toastservice.esm.js +1 -1
  619. package/toastservice/toastservice.esm.min.js +1 -1
  620. package/toastservice/toastservice.js +4 -4
  621. package/togglebutton/togglebutton.cjs.js +10 -9
  622. package/togglebutton/togglebutton.cjs.min.js +1 -1
  623. package/togglebutton/togglebutton.esm.js +11 -10
  624. package/togglebutton/togglebutton.esm.min.js +1 -1
  625. package/togglebutton/togglebutton.js +11 -10
  626. package/togglebutton/togglebutton.min.js +1 -1
  627. package/toolbar/Toolbar.vue +2 -2
  628. package/toolbar/toolbar.cjs.js +3 -3
  629. package/toolbar/toolbar.cjs.min.js +1 -1
  630. package/toolbar/toolbar.esm.js +5 -5
  631. package/toolbar/toolbar.esm.min.js +1 -1
  632. package/toolbar/toolbar.js +4 -4
  633. package/toolbar/toolbar.min.js +1 -1
  634. package/tooltip/tooltip.cjs.js +7 -1
  635. package/tooltip/tooltip.cjs.min.js +1 -1
  636. package/tooltip/tooltip.esm.js +8 -2
  637. package/tooltip/tooltip.esm.min.js +1 -1
  638. package/tooltip/tooltip.js +8 -2
  639. package/tooltip/tooltip.min.js +1 -1
  640. package/tree/TreeNode.vue +1 -4
  641. package/tree/tree.cjs.js +57 -45
  642. package/tree/tree.cjs.min.js +1 -1
  643. package/tree/tree.esm.js +58 -46
  644. package/tree/tree.esm.min.js +1 -1
  645. package/tree/tree.js +58 -46
  646. package/tree/tree.min.js +1 -1
  647. package/treeselect/TreeSelect.vue +7 -11
  648. package/treeselect/treeselect.cjs.js +92 -91
  649. package/treeselect/treeselect.cjs.min.js +1 -1
  650. package/treeselect/treeselect.esm.js +91 -91
  651. package/treeselect/treeselect.esm.min.js +1 -1
  652. package/treeselect/treeselect.js +93 -93
  653. package/treeselect/treeselect.min.js +1 -1
  654. package/treetable/FooterCell.vue +1 -1
  655. package/treetable/TreeTable.d.ts +1 -1
  656. package/treetable/TreeTableRow.vue +2 -2
  657. package/treetable/treetable.cjs.js +97 -88
  658. package/treetable/treetable.cjs.min.js +1 -1
  659. package/treetable/treetable.esm.js +97 -88
  660. package/treetable/treetable.esm.min.js +1 -1
  661. package/treetable/treetable.js +98 -89
  662. package/treetable/treetable.min.js +1 -1
  663. package/tristatecheckbox/TriStateCheckbox.vue +3 -3
  664. package/tristatecheckbox/tristatecheckbox.cjs.js +16 -14
  665. package/tristatecheckbox/tristatecheckbox.cjs.min.js +1 -1
  666. package/tristatecheckbox/tristatecheckbox.esm.js +18 -16
  667. package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
  668. package/tristatecheckbox/tristatecheckbox.js +17 -15
  669. package/tristatecheckbox/tristatecheckbox.min.js +1 -1
  670. package/useconfirm/useconfirm.js +1 -1
  671. package/usetoast/usetoast.js +1 -1
  672. package/utils/Utils.d.ts +1 -0
  673. package/utils/utils.cjs.js +4 -0
  674. package/utils/utils.cjs.min.js +1 -1
  675. package/utils/utils.esm.js +4 -0
  676. package/utils/utils.esm.min.js +1 -1
  677. package/utils/utils.js +5 -1
  678. package/utils/utils.min.js +1 -1
  679. package/vetur-attributes.json +32 -4
  680. package/vetur-tags.json +12 -0
  681. package/virtualscroller/virtualscroller.cjs.js +15 -15
  682. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  683. package/virtualscroller/virtualscroller.esm.js +17 -17
  684. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  685. package/virtualscroller/virtualscroller.js +16 -16
  686. package/virtualscroller/virtualscroller.min.js +1 -1
  687. package/web-types.json +96 -6
@@ -3,7 +3,8 @@ import OverlayEventBus from 'primevue/overlayeventbus';
3
3
  import { FilterService } from 'primevue/api';
4
4
  import Ripple from 'primevue/ripple';
5
5
  import VirtualScroller from 'primevue/virtualscroller';
6
- import { resolveComponent, resolveDirective, openBlock, createBlock, createVNode, createCommentVNode, renderSlot, createTextVNode, toDisplayString, Teleport, Transition, withCtx, mergeProps, createSlots, Fragment, renderList, withDirectives } from 'vue';
6
+ import Portal from 'primevue/portal';
7
+ import { resolveComponent, resolveDirective, openBlock, createElementBlock, normalizeClass, createElementVNode, createCommentVNode, renderSlot, createTextVNode, toDisplayString, createVNode, withCtx, Transition, normalizeStyle, mergeProps, createSlots, Fragment, renderList, withDirectives } from 'vue';
7
8
 
8
9
  var script = {
9
10
  name: 'Dropdown',
@@ -121,8 +122,8 @@ var script = {
121
122
  getOptionValue(option) {
122
123
  return this.optionValue ? ObjectUtils.resolveFieldData(option, this.optionValue) : option;
123
124
  },
124
- getOptionRenderKey(option) {
125
- return this.dataKey ? ObjectUtils.resolveFieldData(option, this.dataKey) : this.getOptionLabel(option);
125
+ getOptionRenderKey(option, index) {
126
+ return this.dataKey ? ObjectUtils.resolveFieldData(option, this.dataKey) : this.getOptionLabel(option) + '_' + index.toString();
126
127
  },
127
128
  isOptionDisabled(option) {
128
129
  return this.optionDisabled ? ObjectUtils.resolveFieldData(option, this.optionDisabled) : false;
@@ -169,9 +170,11 @@ var script = {
169
170
  isSelected(option) {
170
171
  return ObjectUtils.equals(this.modelValue, this.getOptionValue(option), this.equalityKey);
171
172
  },
172
- show() {
173
+ show(isFocus) {
173
174
  this.$emit('before-show');
174
175
  this.overlayVisible = true;
176
+
177
+ isFocus && this.$refs.focusInput.focus();
175
178
  },
176
179
  hide() {
177
180
  this.$emit('before-hide');
@@ -400,7 +403,7 @@ var script = {
400
403
  ZIndexUtils.clear(el);
401
404
  },
402
405
  alignOverlay() {
403
- if (this.appendDisabled) {
406
+ if (this.appendTo === 'self') {
404
407
  DomHandler.relativePosition(this.overlay, this.$el);
405
408
  }
406
409
  else {
@@ -649,15 +652,9 @@ var script = {
649
652
  emptyMessageText() {
650
653
  return this.emptyMessage || this.$primevue.config.locale.emptyMessage;
651
654
  },
652
- appendDisabled() {
653
- return this.appendTo === 'self';
654
- },
655
655
  virtualScrollerDisabled() {
656
656
  return !this.virtualScrollerOptions;
657
657
  },
658
- appendTarget() {
659
- return this.appendDisabled ? null : this.appendTo;
660
- },
661
658
  dropdownIconClass() {
662
659
  return ['p-dropdown-trigger-icon', this.loading ? this.loadingIcon : 'pi pi-chevron-down'];
663
660
  }
@@ -666,71 +663,79 @@ var script = {
666
663
  'ripple': Ripple
667
664
  },
668
665
  components: {
669
- 'VirtualScroller': VirtualScroller
666
+ 'VirtualScroller': VirtualScroller,
667
+ 'Portal': Portal
670
668
  }
671
669
  };
672
670
 
673
671
  const _hoisted_1 = { class: "p-hidden-accessible" };
674
- const _hoisted_2 = {
672
+ const _hoisted_2 = ["id", "disabled", "tabindex", "aria-expanded", "aria-labelledby"];
673
+ const _hoisted_3 = ["disabled", "placeholder", "value", "aria-expanded"];
674
+ const _hoisted_4 = ["aria-expanded"];
675
+ const _hoisted_5 = {
675
676
  key: 0,
676
677
  class: "p-dropdown-header"
677
678
  };
678
- const _hoisted_3 = { class: "p-dropdown-filter-container" };
679
- const _hoisted_4 = /*#__PURE__*/createVNode("span", { class: "p-dropdown-filter-icon pi pi-search" }, null, -1);
680
- const _hoisted_5 = { class: "p-dropdown-item-group" };
681
- const _hoisted_6 = {
679
+ const _hoisted_6 = { class: "p-dropdown-filter-container" };
680
+ const _hoisted_7 = ["value", "placeholder"];
681
+ const _hoisted_8 = /*#__PURE__*/createElementVNode("span", { class: "p-dropdown-filter-icon pi pi-search" }, null, -1);
682
+ const _hoisted_9 = ["onClick", "aria-label", "aria-selected"];
683
+ const _hoisted_10 = { class: "p-dropdown-item-group" };
684
+ const _hoisted_11 = ["onClick", "aria-label", "aria-selected"];
685
+ const _hoisted_12 = {
682
686
  key: 2,
683
687
  class: "p-dropdown-empty-message"
684
688
  };
685
- const _hoisted_7 = {
689
+ const _hoisted_13 = {
686
690
  key: 3,
687
691
  class: "p-dropdown-empty-message"
688
692
  };
689
693
 
690
694
  function render(_ctx, _cache, $props, $setup, $data, $options) {
691
695
  const _component_VirtualScroller = resolveComponent("VirtualScroller");
696
+ const _component_Portal = resolveComponent("Portal");
692
697
  const _directive_ripple = resolveDirective("ripple");
693
698
 
694
- return (openBlock(), createBlock("div", {
699
+ return (openBlock(), createElementBlock("div", {
695
700
  ref: "container",
696
- class: $options.containerClass,
697
- onClick: _cache[12] || (_cache[12] = $event => ($options.onClick($event)))
701
+ class: normalizeClass($options.containerClass),
702
+ onClick: _cache[11] || (_cache[11] = $event => ($options.onClick($event)))
698
703
  }, [
699
- createVNode("div", _hoisted_1, [
700
- createVNode("input", {
704
+ createElementVNode("div", _hoisted_1, [
705
+ createElementVNode("input", {
701
706
  ref: "focusInput",
702
707
  type: "text",
703
708
  id: $props.inputId,
704
709
  readonly: "",
705
710
  disabled: $props.disabled,
706
- onFocus: _cache[1] || (_cache[1] = (...args) => ($options.onFocus && $options.onFocus(...args))),
707
- onBlur: _cache[2] || (_cache[2] = (...args) => ($options.onBlur && $options.onBlur(...args))),
708
- onKeydown: _cache[3] || (_cache[3] = (...args) => ($options.onKeyDown && $options.onKeyDown(...args))),
711
+ onFocus: _cache[0] || (_cache[0] = (...args) => ($options.onFocus && $options.onFocus(...args))),
712
+ onBlur: _cache[1] || (_cache[1] = (...args) => ($options.onBlur && $options.onBlur(...args))),
713
+ onKeydown: _cache[2] || (_cache[2] = (...args) => ($options.onKeyDown && $options.onKeyDown(...args))),
709
714
  tabindex: $props.tabindex,
710
715
  "aria-haspopup": "true",
711
716
  "aria-expanded": $data.overlayVisible,
712
717
  "aria-labelledby": $props.ariaLabelledBy
713
- }, null, 40, ["id", "disabled", "tabindex", "aria-expanded", "aria-labelledby"])
718
+ }, null, 40, _hoisted_2)
714
719
  ]),
715
720
  ($props.editable)
716
- ? (openBlock(), createBlock("input", {
721
+ ? (openBlock(), createElementBlock("input", {
717
722
  key: 0,
718
723
  type: "text",
719
724
  class: "p-dropdown-label p-inputtext",
720
725
  disabled: $props.disabled,
721
- onFocus: _cache[4] || (_cache[4] = (...args) => ($options.onFocus && $options.onFocus(...args))),
722
- onBlur: _cache[5] || (_cache[5] = (...args) => ($options.onBlur && $options.onBlur(...args))),
726
+ onFocus: _cache[3] || (_cache[3] = (...args) => ($options.onFocus && $options.onFocus(...args))),
727
+ onBlur: _cache[4] || (_cache[4] = (...args) => ($options.onBlur && $options.onBlur(...args))),
723
728
  placeholder: $props.placeholder,
724
729
  value: $options.editableInputValue,
725
- onInput: _cache[6] || (_cache[6] = (...args) => ($options.onEditableInput && $options.onEditableInput(...args))),
730
+ onInput: _cache[5] || (_cache[5] = (...args) => ($options.onEditableInput && $options.onEditableInput(...args))),
726
731
  "aria-haspopup": "listbox",
727
732
  "aria-expanded": $data.overlayVisible
728
- }, null, 40, ["disabled", "placeholder", "value", "aria-expanded"]))
733
+ }, null, 40, _hoisted_3))
729
734
  : createCommentVNode("", true),
730
735
  (!$props.editable)
731
- ? (openBlock(), createBlock("span", {
736
+ ? (openBlock(), createElementBlock("span", {
732
737
  key: 1,
733
- class: $options.labelClass
738
+ class: normalizeClass($options.labelClass)
734
739
  }, [
735
740
  renderSlot(_ctx.$slots, "value", {
736
741
  value: $props.modelValue,
@@ -741,170 +746,172 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
741
746
  ], 2))
742
747
  : createCommentVNode("", true),
743
748
  ($props.showClear && $props.modelValue != null)
744
- ? (openBlock(), createBlock("i", {
749
+ ? (openBlock(), createElementBlock("i", {
745
750
  key: 2,
746
751
  class: "p-dropdown-clear-icon pi pi-times",
747
- onClick: _cache[7] || (_cache[7] = $event => ($options.onClearClick($event)))
752
+ onClick: _cache[6] || (_cache[6] = $event => ($options.onClearClick($event)))
748
753
  }))
749
754
  : createCommentVNode("", true),
750
- createVNode("div", {
755
+ createElementVNode("div", {
751
756
  class: "p-dropdown-trigger",
752
757
  role: "button",
753
758
  "aria-haspopup": "listbox",
754
759
  "aria-expanded": $data.overlayVisible
755
760
  }, [
756
761
  renderSlot(_ctx.$slots, "indicator", {}, () => [
757
- createVNode("span", { class: $options.dropdownIconClass }, null, 2)
762
+ createElementVNode("span", {
763
+ class: normalizeClass($options.dropdownIconClass)
764
+ }, null, 2)
758
765
  ])
759
- ], 8, ["aria-expanded"]),
760
- (openBlock(), createBlock(Teleport, {
761
- to: $options.appendTarget,
762
- disabled: $options.appendDisabled
763
- }, [
764
- createVNode(Transition, {
765
- name: "p-connected-overlay",
766
- onEnter: $options.onOverlayEnter,
767
- onAfterEnter: $options.onOverlayAfterEnter,
768
- onLeave: $options.onOverlayLeave,
769
- onAfterLeave: $options.onOverlayAfterLeave
770
- }, {
771
- default: withCtx(() => [
772
- ($data.overlayVisible)
773
- ? (openBlock(), createBlock("div", {
774
- key: 0,
775
- ref: $options.overlayRef,
776
- class: $options.panelStyleClass,
777
- onClick: _cache[11] || (_cache[11] = (...args) => ($options.onOverlayClick && $options.onOverlayClick(...args)))
778
- }, [
779
- renderSlot(_ctx.$slots, "header", {
780
- value: $props.modelValue,
781
- options: $options.visibleOptions
782
- }),
783
- ($props.filter)
784
- ? (openBlock(), createBlock("div", _hoisted_2, [
785
- createVNode("div", _hoisted_3, [
786
- createVNode("input", {
787
- type: "text",
788
- ref: "filterInput",
789
- value: $data.filterValue,
790
- onVnodeUpdated: _cache[8] || (_cache[8] = (...args) => ($options.onFilterUpdated && $options.onFilterUpdated(...args))),
791
- autoComplete: "off",
792
- class: "p-dropdown-filter p-inputtext p-component",
793
- placeholder: $props.filterPlaceholder,
794
- onKeydown: _cache[9] || (_cache[9] = (...args) => ($options.onFilterKeyDown && $options.onFilterKeyDown(...args))),
795
- onInput: _cache[10] || (_cache[10] = (...args) => ($options.onFilterChange && $options.onFilterChange(...args)))
796
- }, null, 40, ["value", "placeholder"]),
797
- _hoisted_4
798
- ])
799
- ]))
800
- : createCommentVNode("", true),
801
- createVNode("div", {
802
- ref: $options.itemsWrapperRef,
803
- class: "p-dropdown-items-wrapper",
804
- style: {'max-height': $options.virtualScrollerDisabled ? $props.scrollHeight : ''}
766
+ ], 8, _hoisted_4),
767
+ createVNode(_component_Portal, { appendTo: $props.appendTo }, {
768
+ default: withCtx(() => [
769
+ createVNode(Transition, {
770
+ name: "p-connected-overlay",
771
+ onEnter: $options.onOverlayEnter,
772
+ onAfterEnter: $options.onOverlayAfterEnter,
773
+ onLeave: $options.onOverlayLeave,
774
+ onAfterLeave: $options.onOverlayAfterLeave
775
+ }, {
776
+ default: withCtx(() => [
777
+ ($data.overlayVisible)
778
+ ? (openBlock(), createElementBlock("div", {
779
+ key: 0,
780
+ ref: $options.overlayRef,
781
+ class: normalizeClass($options.panelStyleClass),
782
+ onClick: _cache[10] || (_cache[10] = (...args) => ($options.onOverlayClick && $options.onOverlayClick(...args)))
805
783
  }, [
806
- createVNode(_component_VirtualScroller, mergeProps({ ref: $options.virtualScrollerRef }, $props.virtualScrollerOptions, {
807
- items: $options.visibleOptions,
808
- style: {'height': $props.scrollHeight},
809
- disabled: $options.virtualScrollerDisabled
810
- }), createSlots({
811
- content: withCtx(({ styleClass, contentRef, items, getItemOptions, contentStyle }) => [
812
- createVNode("ul", {
813
- ref: contentRef,
814
- class: ['p-dropdown-items', styleClass],
815
- style: contentStyle,
816
- role: "listbox"
817
- }, [
818
- (!$props.optionGroupLabel)
819
- ? (openBlock(true), createBlock(Fragment, { key: 0 }, renderList(items, (option, i) => {
820
- return withDirectives((openBlock(), createBlock("li", {
821
- class: ['p-dropdown-item', {'p-highlight': $options.isSelected(option), 'p-disabled': $options.isOptionDisabled(option)}],
822
- key: $options.getOptionRenderKey(option),
823
- onClick: $event => ($options.onOptionSelect($event, option)),
824
- role: "option",
825
- "aria-label": $options.getOptionLabel(option),
826
- "aria-selected": $options.isSelected(option)
827
- }, [
828
- renderSlot(_ctx.$slots, "option", {
829
- option: option,
830
- index: $options.getOptionIndex(i, getItemOptions)
831
- }, () => [
832
- createTextVNode(toDisplayString($options.getOptionLabel(option)), 1)
833
- ])
834
- ], 10, ["onClick", "aria-label", "aria-selected"])), [
835
- [_directive_ripple]
836
- ])
837
- }), 128))
838
- : (openBlock(true), createBlock(Fragment, { key: 1 }, renderList(items, (optionGroup, i) => {
839
- return (openBlock(), createBlock(Fragment, {
840
- key: $options.getOptionGroupRenderKey(optionGroup)
841
- }, [
842
- createVNode("li", _hoisted_5, [
843
- renderSlot(_ctx.$slots, "optiongroup", {
844
- option: optionGroup,
784
+ renderSlot(_ctx.$slots, "header", {
785
+ value: $props.modelValue,
786
+ options: $options.visibleOptions
787
+ }),
788
+ ($props.filter)
789
+ ? (openBlock(), createElementBlock("div", _hoisted_5, [
790
+ createElementVNode("div", _hoisted_6, [
791
+ createElementVNode("input", {
792
+ type: "text",
793
+ ref: "filterInput",
794
+ value: $data.filterValue,
795
+ onVnodeUpdated: _cache[7] || (_cache[7] = (...args) => ($options.onFilterUpdated && $options.onFilterUpdated(...args))),
796
+ autoComplete: "off",
797
+ class: "p-dropdown-filter p-inputtext p-component",
798
+ placeholder: $props.filterPlaceholder,
799
+ onKeydown: _cache[8] || (_cache[8] = (...args) => ($options.onFilterKeyDown && $options.onFilterKeyDown(...args))),
800
+ onInput: _cache[9] || (_cache[9] = (...args) => ($options.onFilterChange && $options.onFilterChange(...args)))
801
+ }, null, 40, _hoisted_7),
802
+ _hoisted_8
803
+ ])
804
+ ]))
805
+ : createCommentVNode("", true),
806
+ createElementVNode("div", {
807
+ ref: $options.itemsWrapperRef,
808
+ class: "p-dropdown-items-wrapper",
809
+ style: normalizeStyle({'max-height': $options.virtualScrollerDisabled ? $props.scrollHeight : ''})
810
+ }, [
811
+ createVNode(_component_VirtualScroller, mergeProps({ ref: $options.virtualScrollerRef }, $props.virtualScrollerOptions, {
812
+ items: $options.visibleOptions,
813
+ style: {'height': $props.scrollHeight},
814
+ disabled: $options.virtualScrollerDisabled
815
+ }), createSlots({
816
+ content: withCtx(({ styleClass, contentRef, items, getItemOptions, contentStyle }) => [
817
+ createElementVNode("ul", {
818
+ ref: contentRef,
819
+ class: normalizeClass(['p-dropdown-items', styleClass]),
820
+ style: normalizeStyle(contentStyle),
821
+ role: "listbox"
822
+ }, [
823
+ (!$props.optionGroupLabel)
824
+ ? (openBlock(true), createElementBlock(Fragment, { key: 0 }, renderList(items, (option, i) => {
825
+ return withDirectives((openBlock(), createElementBlock("li", {
826
+ class: normalizeClass(['p-dropdown-item', {'p-highlight': $options.isSelected(option), 'p-disabled': $options.isOptionDisabled(option)}]),
827
+ key: $options.getOptionRenderKey(option, i),
828
+ onClick: $event => ($options.onOptionSelect($event, option)),
829
+ role: "option",
830
+ "aria-label": $options.getOptionLabel(option),
831
+ "aria-selected": $options.isSelected(option)
832
+ }, [
833
+ renderSlot(_ctx.$slots, "option", {
834
+ option: option,
845
835
  index: $options.getOptionIndex(i, getItemOptions)
846
836
  }, () => [
847
- createTextVNode(toDisplayString($options.getOptionGroupLabel(optionGroup)), 1)
837
+ createTextVNode(toDisplayString($options.getOptionLabel(option)), 1)
848
838
  ])
849
- ]),
850
- (openBlock(true), createBlock(Fragment, null, renderList($options.getOptionGroupChildren(optionGroup), (option, i) => {
851
- return withDirectives((openBlock(), createBlock("li", {
852
- class: ['p-dropdown-item', {'p-highlight': $options.isSelected(option), 'p-disabled': $options.isOptionDisabled(option)}],
853
- key: $options.getOptionRenderKey(option),
854
- onClick: $event => ($options.onOptionSelect($event, option)),
855
- role: "option",
856
- "aria-label": $options.getOptionLabel(option),
857
- "aria-selected": $options.isSelected(option)
858
- }, [
859
- renderSlot(_ctx.$slots, "option", {
860
- option: option,
839
+ ], 10, _hoisted_9)), [
840
+ [_directive_ripple]
841
+ ])
842
+ }), 128))
843
+ : (openBlock(true), createElementBlock(Fragment, { key: 1 }, renderList(items, (optionGroup, i) => {
844
+ return (openBlock(), createElementBlock(Fragment, {
845
+ key: $options.getOptionGroupRenderKey(optionGroup)
846
+ }, [
847
+ createElementVNode("li", _hoisted_10, [
848
+ renderSlot(_ctx.$slots, "optiongroup", {
849
+ option: optionGroup,
861
850
  index: $options.getOptionIndex(i, getItemOptions)
862
851
  }, () => [
863
- createTextVNode(toDisplayString($options.getOptionLabel(option)), 1)
852
+ createTextVNode(toDisplayString($options.getOptionGroupLabel(optionGroup)), 1)
864
853
  ])
865
- ], 10, ["onClick", "aria-label", "aria-selected"])), [
866
- [_directive_ripple]
867
- ])
868
- }), 128))
869
- ], 64))
870
- }), 128)),
871
- ($data.filterValue && (!items || (items && items.length === 0)))
872
- ? (openBlock(), createBlock("li", _hoisted_6, [
873
- renderSlot(_ctx.$slots, "emptyfilter", {}, () => [
874
- createTextVNode(toDisplayString($options.emptyFilterMessageText), 1)
875
- ])
876
- ]))
877
- : ((!$props.options || ($props.options && $props.options.length === 0)))
878
- ? (openBlock(), createBlock("li", _hoisted_7, [
879
- renderSlot(_ctx.$slots, "empty", {}, () => [
880
- createTextVNode(toDisplayString($options.emptyMessageText), 1)
854
+ ]),
855
+ (openBlock(true), createElementBlock(Fragment, null, renderList($options.getOptionGroupChildren(optionGroup), (option, i) => {
856
+ return withDirectives((openBlock(), createElementBlock("li", {
857
+ class: normalizeClass(['p-dropdown-item', {'p-highlight': $options.isSelected(option), 'p-disabled': $options.isOptionDisabled(option)}]),
858
+ key: $options.getOptionRenderKey(option, i),
859
+ onClick: $event => ($options.onOptionSelect($event, option)),
860
+ role: "option",
861
+ "aria-label": $options.getOptionLabel(option),
862
+ "aria-selected": $options.isSelected(option)
863
+ }, [
864
+ renderSlot(_ctx.$slots, "option", {
865
+ option: option,
866
+ index: $options.getOptionIndex(i, getItemOptions)
867
+ }, () => [
868
+ createTextVNode(toDisplayString($options.getOptionLabel(option)), 1)
869
+ ])
870
+ ], 10, _hoisted_11)), [
871
+ [_directive_ripple]
872
+ ])
873
+ }), 128))
874
+ ], 64))
875
+ }), 128)),
876
+ ($data.filterValue && (!items || (items && items.length === 0)))
877
+ ? (openBlock(), createElementBlock("li", _hoisted_12, [
878
+ renderSlot(_ctx.$slots, "emptyfilter", {}, () => [
879
+ createTextVNode(toDisplayString($options.emptyFilterMessageText), 1)
881
880
  ])
882
881
  ]))
883
- : createCommentVNode("", true)
884
- ], 6)
885
- ]),
886
- _: 2
887
- }, [
888
- (_ctx.$slots.loader)
889
- ? {
890
- name: "loader",
891
- fn: withCtx(({ options }) => [
892
- renderSlot(_ctx.$slots, "loader", { options: options })
893
- ])
894
- }
895
- : undefined
896
- ]), 1040, ["items", "style", "disabled"])
897
- ], 4),
898
- renderSlot(_ctx.$slots, "footer", {
899
- value: $props.modelValue,
900
- options: $options.visibleOptions
901
- })
902
- ], 2))
903
- : createCommentVNode("", true)
904
- ]),
905
- _: 3
906
- }, 8, ["onEnter", "onAfterEnter", "onLeave", "onAfterLeave"])
907
- ], 8, ["to", "disabled"]))
882
+ : ((!$props.options || ($props.options && $props.options.length === 0)))
883
+ ? (openBlock(), createElementBlock("li", _hoisted_13, [
884
+ renderSlot(_ctx.$slots, "empty", {}, () => [
885
+ createTextVNode(toDisplayString($options.emptyMessageText), 1)
886
+ ])
887
+ ]))
888
+ : createCommentVNode("", true)
889
+ ], 6)
890
+ ]),
891
+ _: 2
892
+ }, [
893
+ (_ctx.$slots.loader)
894
+ ? {
895
+ name: "loader",
896
+ fn: withCtx(({ options }) => [
897
+ renderSlot(_ctx.$slots, "loader", { options: options })
898
+ ])
899
+ }
900
+ : undefined
901
+ ]), 1040, ["items", "style", "disabled"])
902
+ ], 4),
903
+ renderSlot(_ctx.$slots, "footer", {
904
+ value: $props.modelValue,
905
+ options: $options.visibleOptions
906
+ })
907
+ ], 2))
908
+ : createCommentVNode("", true)
909
+ ]),
910
+ _: 3
911
+ }, 8, ["onEnter", "onAfterEnter", "onLeave", "onAfterLeave"])
912
+ ]),
913
+ _: 3
914
+ }, 8, ["appendTo"])
908
915
  ], 2))
909
916
  }
910
917
 
@@ -940,4 +947,4 @@ styleInject(css_248z);
940
947
 
941
948
  script.render = render;
942
949
 
943
- export default script;
950
+ export { script as default };
@@ -1 +1 @@
1
- import{ZIndexUtils as e,ObjectUtils as t,DomHandler as i,ConnectedOverlayScrollHandler as l}from"primevue/utils";import n from"primevue/overlayeventbus";import{FilterService as o}from"primevue/api";import s from"primevue/ripple";import r from"primevue/virtualscroller";import{resolveComponent as a,resolveDirective as p,openBlock as d,createBlock as h,createVNode as u,createCommentVNode as c,renderSlot as b,createTextVNode as f,toDisplayString as v,Teleport as g,Transition as y,withCtx as m,mergeProps as O,createSlots as w,Fragment as L,renderList as V,withDirectives as x}from"vue";var C={name:"Dropdown",emits:["update:modelValue","before-show","before-hide","show","hide","change","filter","focus","blur"],props:{modelValue:null,options:Array,optionLabel:null,optionValue:null,optionDisabled:null,optionGroupLabel:null,optionGroupChildren:null,scrollHeight:{type:String,default:"200px"},filter:Boolean,filterPlaceholder:String,filterLocale:String,filterMatchMode:{type:String,default:"contains"},filterFields:{type:Array,default:null},editable:Boolean,placeholder:String,disabled:Boolean,dataKey:null,showClear:Boolean,inputId:String,tabindex:String,ariaLabelledBy:null,appendTo:{type:String,default:"body"},emptyFilterMessage:{type:String,default:null},emptyMessage:{type:String,default:null},panelClass:null,loading:{type:Boolean,default:!1},loadingIcon:{type:String,default:"pi pi-spinner pi-spin"},virtualScrollerOptions:{type:Object,default:null}},data:()=>({focused:!1,filterValue:null,overlayVisible:!1}),watch:{modelValue(){this.isModelValueChanged=!0}},outsideClickListener:null,scrollHandler:null,resizeListener:null,searchTimeout:null,currentSearchChar:null,previousSearchChar:null,searchValue:null,overlay:null,itemsWrapper:null,virtualScroller:null,isModelValueChanged:!1,updated(){this.overlayVisible&&this.isModelValueChanged&&this.scrollValueInView(),this.isModelValueChanged=!1},beforeUnmount(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.itemsWrapper=null,this.overlay&&(e.clear(this.overlay),this.overlay=null)},methods:{getOptionIndex(e,t){return this.virtualScrollerDisabled?e:t&&t(e).index},getOptionLabel(e){return this.optionLabel?t.resolveFieldData(e,this.optionLabel):e},getOptionValue(e){return this.optionValue?t.resolveFieldData(e,this.optionValue):e},getOptionRenderKey(e){return this.dataKey?t.resolveFieldData(e,this.dataKey):this.getOptionLabel(e)},isOptionDisabled(e){return!!this.optionDisabled&&t.resolveFieldData(e,this.optionDisabled)},getOptionGroupRenderKey(e){return t.resolveFieldData(e,this.optionGroupLabel)},getOptionGroupLabel(e){return t.resolveFieldData(e,this.optionGroupLabel)},getOptionGroupChildren(e){return t.resolveFieldData(e,this.optionGroupChildren)},getSelectedOption(){let e=this.getSelectedOptionIndex();return-1!==e?this.optionGroupLabel?this.getOptionGroupChildren(this.visibleOptions[e.group])[e.option]:this.visibleOptions[e]:null},getSelectedOptionIndex(){if(null!=this.modelValue&&this.visibleOptions){if(!this.optionGroupLabel)return this.findOptionIndexInList(this.modelValue,this.visibleOptions);for(let e=0;e<this.visibleOptions.length;e++){let t=this.findOptionIndexInList(this.modelValue,this.getOptionGroupChildren(this.visibleOptions[e]));if(-1!==t)return{group:e,option:t}}}return-1},findOptionIndexInList(e,i){for(let l=0;l<i.length;l++)if(t.equals(e,this.getOptionValue(i[l]),this.equalityKey))return l;return-1},isSelected(e){return t.equals(this.modelValue,this.getOptionValue(e),this.equalityKey)},show(){this.$emit("before-show"),this.overlayVisible=!0},hide(){this.$emit("before-hide"),this.overlayVisible=!1},onFocus(e){this.focused=!0,this.$emit("focus",e)},onBlur(e){this.focused=!1,this.$emit("blur",e)},onKeyDown(e){switch(e.which){case 40:this.onDownKey(e);break;case 38:this.onUpKey(e);break;case 32:this.overlayVisible||(this.show(),e.preventDefault());break;case 13:case 27:this.overlayVisible&&(this.hide(),e.preventDefault());break;case 9:this.hide();break;default:this.search(e)}},onFilterKeyDown(e){switch(e.which){case 40:this.onDownKey(e);break;case 38:this.onUpKey(e);break;case 13:case 27:this.overlayVisible=!1,e.preventDefault()}},onDownKey(e){if(this.visibleOptions)if(!this.overlayVisible&&e.altKey)this.show();else{let t=this.visibleOptions&&this.visibleOptions.length>0?this.findNextOption(this.getSelectedOptionIndex()):null;t&&this.updateModel(e,this.getOptionValue(t))}e.preventDefault()},onUpKey(e){if(this.visibleOptions){let t=this.findPrevOption(this.getSelectedOptionIndex());t&&this.updateModel(e,this.getOptionValue(t))}e.preventDefault()},findNextOption(e){if(this.optionGroupLabel){let t=-1===e?0:e.group,i=-1===e?-1:e.option,l=this.findNextOptionInList(this.getOptionGroupChildren(this.visibleOptions[t]),i);return l||(t+1!==this.visibleOptions.length?this.findNextOption({group:t+1,option:-1}):null)}return this.findNextOptionInList(this.visibleOptions,e)},findNextOptionInList(e,t){let i=t+1;if(i===e.length)return null;let l=e[i];return this.isOptionDisabled(l)?this.findNextOptionInList(i):l},findPrevOption(e){if(-1===e)return null;if(this.optionGroupLabel){let t=e.group,i=e.option,l=this.findPrevOptionInList(this.getOptionGroupChildren(this.visibleOptions[t]),i);return l||(t>0?this.findPrevOption({group:t-1,option:this.getOptionGroupChildren(this.visibleOptions[t-1]).length}):null)}return this.findPrevOptionInList(this.visibleOptions,e)},findPrevOptionInList(e,t){let i=t-1;if(i<0)return null;let l=e[i];return this.isOptionDisabled(l)?this.findPrevOption(i):l},onClearClick(e){this.updateModel(e,null)},onClick(e){this.disabled||this.loading||i.hasClass(e.target,"p-dropdown-clear-icon")||"INPUT"===e.target.tagName||this.overlay&&this.overlay.contains(e.target)||(this.overlayVisible?this.hide():this.show(),this.$refs.focusInput.focus())},onOptionSelect(e,t){let i=this.getOptionValue(t);this.updateModel(e,i),this.$refs.focusInput.focus(),setTimeout((()=>{this.hide()}),200)},onEditableInput(e){this.$emit("update:modelValue",e.target.value)},onOverlayEnter(t){if(e.set("overlay",t,this.$primevue.config.zIndex.overlay),this.alignOverlay(),this.scrollValueInView(),!this.virtualScrollerDisabled){const e=this.getSelectedOptionIndex();-1!==e&&setTimeout((()=>{this.virtualScroller&&this.virtualScroller.scrollToIndex(e)}),0)}},onOverlayAfterEnter(){this.filter&&this.$refs.filterInput.focus(),this.bindOutsideClickListener(),this.bindScrollListener(),this.bindResizeListener(),this.$emit("show")},onOverlayLeave(){this.unbindOutsideClickListener(),this.unbindScrollListener(),this.unbindResizeListener(),this.$emit("hide"),this.itemsWrapper=null,this.overlay=null},onOverlayAfterLeave(t){e.clear(t)},alignOverlay(){this.appendDisabled?i.relativePosition(this.overlay,this.$el):(this.overlay.style.minWidth=i.getOuterWidth(this.$el)+"px",i.absolutePosition(this.overlay,this.$el))},updateModel(e,t){this.$emit("update:modelValue",t),this.$emit("change",{originalEvent:e,value:t})},bindOutsideClickListener(){this.outsideClickListener||(this.outsideClickListener=e=>{this.overlayVisible&&this.overlay&&!this.$el.contains(e.target)&&!this.overlay.contains(e.target)&&this.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener(){this.scrollHandler||(this.scrollHandler=new l(this.$refs.container,(()=>{this.overlayVisible&&this.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener(){this.resizeListener||(this.resizeListener=()=>{this.overlayVisible&&!i.isTouchDevice()&&this.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},search(e){if(!this.visibleOptions)return;this.searchTimeout&&clearTimeout(this.searchTimeout);const t=e.key;if(this.previousSearchChar=this.currentSearchChar,this.currentSearchChar=t,this.previousSearchChar===this.currentSearchChar?this.searchValue=this.currentSearchChar:this.searchValue=this.searchValue?this.searchValue+t:t,this.searchValue){let t=this.getSelectedOptionIndex(),i=this.optionGroupLabel?this.searchOptionInGroup(t):this.searchOption(++t);i&&this.updateModel(e,this.getOptionValue(i))}this.searchTimeout=setTimeout((()=>{this.searchValue=null}),250)},searchOption(e){let t;return this.searchValue&&(t=this.searchOptionInRange(e,this.visibleOptions.length),t||(t=this.searchOptionInRange(0,e))),t},searchOptionInRange(e,t){for(let i=e;i<t;i++){let e=this.visibleOptions[i];if(this.matchesSearchValue(e))return e}return null},searchOptionInGroup(e){let t=-1===e?{group:0,option:-1}:e;for(let e=t.group;e<this.visibleOptions.length;e++){let i=this.getOptionGroupChildren(this.visibleOptions[e]);for(let l=t.group===e?t.option+1:0;l<i.length;l++)if(this.matchesSearchValue(i[l]))return i[l]}for(let e=0;e<=t.group;e++){let i=this.getOptionGroupChildren(this.visibleOptions[e]);for(let l=0;l<(t.group===e?t.option:i.length);l++)if(this.matchesSearchValue(i[l]))return i[l]}return null},matchesSearchValue(e){return this.getOptionLabel(e).toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale))},onFilterChange(e){this.filterValue=e.target.value,this.$emit("filter",{originalEvent:e,value:e.target.value})},onFilterUpdated(){this.overlayVisible&&this.alignOverlay()},overlayRef(e){this.overlay=e},itemsWrapperRef(e){this.itemsWrapper=e},virtualScrollerRef(e){this.virtualScroller=e},scrollValueInView(){if(this.overlay){let e=i.findSingle(this.overlay,"li.p-highlight");e&&e.scrollIntoView({block:"nearest",inline:"start"})}},onOverlayClick(e){n.emit("overlay-click",{originalEvent:e,target:this.$el})}},computed:{visibleOptions(){if(this.filterValue){if(this.optionGroupLabel){let e=[];for(let t of this.options){let i=o.filter(this.getOptionGroupChildren(t),this.searchFields,this.filterValue,this.filterMatchMode,this.filterLocale);if(i&&i.length){let l={...t};l[this.optionGroupChildren]=i,e.push(l)}}return e}return o.filter(this.options,this.searchFields,this.filterValue,this.filterMatchMode,this.filterLocale)}return this.options},containerClass(){return["p-dropdown p-component p-inputwrapper",{"p-disabled":this.disabled,"p-dropdown-clearable":this.showClear&&!this.disabled,"p-focus":this.focused,"p-inputwrapper-filled":this.modelValue,"p-inputwrapper-focus":this.focused||this.overlayVisible}]},labelClass(){return["p-dropdown-label p-inputtext",{"p-placeholder":this.label===this.placeholder,"p-dropdown-label-empty":!this.$slots.value&&("p-emptylabel"===this.label||0===this.label.length)}]},panelStyleClass(){return["p-dropdown-panel p-component",this.panelClass,{"p-input-filled":"filled"===this.$primevue.config.inputStyle,"p-ripple-disabled":!1===this.$primevue.config.ripple}]},label(){let e=this.getSelectedOption();return null!==e?this.getOptionLabel(e):this.placeholder||"p-emptylabel"},editableInputValue(){let e=this.getSelectedOption();return e?this.getOptionLabel(e):this.modelValue},equalityKey(){return this.optionValue?null:this.dataKey},searchFields(){return this.filterFields||[this.optionLabel]},emptyFilterMessageText(){return this.emptyFilterMessage||this.$primevue.config.locale.emptyFilterMessage},emptyMessageText(){return this.emptyMessage||this.$primevue.config.locale.emptyMessage},appendDisabled(){return"self"===this.appendTo},virtualScrollerDisabled(){return!this.virtualScrollerOptions},appendTarget(){return this.appendDisabled?null:this.appendTo},dropdownIconClass(){return["p-dropdown-trigger-icon",this.loading?this.loadingIcon:"pi pi-chevron-down"]}},directives:{ripple:s},components:{VirtualScroller:r}};const S={class:"p-hidden-accessible"},k={key:0,class:"p-dropdown-header"},I={class:"p-dropdown-filter-container"},D=u("span",{class:"p-dropdown-filter-icon pi pi-search"},null,-1),$={class:"p-dropdown-item-group"},F={key:2,class:"p-dropdown-empty-message"},G={key:3,class:"p-dropdown-empty-message"};!function(e,t){void 0===t&&(t={});var i=t.insertAt;if(e&&"undefined"!=typeof document){var l=document.head||document.getElementsByTagName("head")[0],n=document.createElement("style");n.type="text/css","top"===i&&l.firstChild?l.insertBefore(n,l.firstChild):l.appendChild(n),n.styleSheet?n.styleSheet.cssText=e:n.appendChild(document.createTextNode(e))}}("\n.p-dropdown {\n display: -webkit-inline-box;\n display: -ms-inline-flexbox;\n display: inline-flex;\n cursor: pointer;\n position: relative;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n}\n.p-dropdown-clear-icon {\n position: absolute;\n top: 50%;\n margin-top: -.5rem;\n}\n.p-dropdown-trigger {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n -ms-flex-negative: 0;\n flex-shrink: 0;\n}\n.p-dropdown-label {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n width: 1%;\n text-overflow: ellipsis;\n cursor: pointer;\n}\n.p-dropdown-label-empty {\n overflow: hidden;\n visibility: hidden;\n}\ninput.p-dropdown-label {\n cursor: default;\n}\n.p-dropdown .p-dropdown-panel {\n min-width: 100%;\n}\n.p-dropdown-panel {\n position: absolute;\n top: 0;\n left: 0;\n}\n.p-dropdown-items-wrapper {\n overflow: auto;\n}\n.p-dropdown-item {\n cursor: pointer;\n font-weight: normal;\n white-space: nowrap;\n position: relative;\n overflow: hidden;\n}\n.p-dropdown-item-group {\n cursor: auto;\n}\n.p-dropdown-items {\n margin: 0;\n padding: 0;\n list-style-type: none;\n}\n.p-dropdown-filter {\n width: 100%;\n}\n.p-dropdown-filter-container {\n position: relative;\n}\n.p-dropdown-filter-icon {\n position: absolute;\n top: 50%;\n margin-top: -.5rem;\n}\n.p-fluid .p-dropdown {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n}\n.p-fluid .p-dropdown .p-dropdown-label {\n width: 1%;\n}\n"),C.render=function(e,t,i,l,n,o){const s=a("VirtualScroller"),r=p("ripple");return d(),h("div",{ref:"container",class:o.containerClass,onClick:t[12]||(t[12]=e=>o.onClick(e))},[u("div",S,[u("input",{ref:"focusInput",type:"text",id:i.inputId,readonly:"",disabled:i.disabled,onFocus:t[1]||(t[1]=(...e)=>o.onFocus&&o.onFocus(...e)),onBlur:t[2]||(t[2]=(...e)=>o.onBlur&&o.onBlur(...e)),onKeydown:t[3]||(t[3]=(...e)=>o.onKeyDown&&o.onKeyDown(...e)),tabindex:i.tabindex,"aria-haspopup":"true","aria-expanded":n.overlayVisible,"aria-labelledby":i.ariaLabelledBy},null,40,["id","disabled","tabindex","aria-expanded","aria-labelledby"])]),i.editable?(d(),h("input",{key:0,type:"text",class:"p-dropdown-label p-inputtext",disabled:i.disabled,onFocus:t[4]||(t[4]=(...e)=>o.onFocus&&o.onFocus(...e)),onBlur:t[5]||(t[5]=(...e)=>o.onBlur&&o.onBlur(...e)),placeholder:i.placeholder,value:o.editableInputValue,onInput:t[6]||(t[6]=(...e)=>o.onEditableInput&&o.onEditableInput(...e)),"aria-haspopup":"listbox","aria-expanded":n.overlayVisible},null,40,["disabled","placeholder","value","aria-expanded"])):c("",!0),i.editable?c("",!0):(d(),h("span",{key:1,class:o.labelClass},[b(e.$slots,"value",{value:i.modelValue,placeholder:i.placeholder},(()=>[f(v(o.label||"empty"),1)]))],2)),i.showClear&&null!=i.modelValue?(d(),h("i",{key:2,class:"p-dropdown-clear-icon pi pi-times",onClick:t[7]||(t[7]=e=>o.onClearClick(e))})):c("",!0),u("div",{class:"p-dropdown-trigger",role:"button","aria-haspopup":"listbox","aria-expanded":n.overlayVisible},[b(e.$slots,"indicator",{},(()=>[u("span",{class:o.dropdownIconClass},null,2)]))],8,["aria-expanded"]),(d(),h(g,{to:o.appendTarget,disabled:o.appendDisabled},[u(y,{name:"p-connected-overlay",onEnter:o.onOverlayEnter,onAfterEnter:o.onOverlayAfterEnter,onLeave:o.onOverlayLeave,onAfterLeave:o.onOverlayAfterLeave},{default:m((()=>[n.overlayVisible?(d(),h("div",{key:0,ref:o.overlayRef,class:o.panelStyleClass,onClick:t[11]||(t[11]=(...e)=>o.onOverlayClick&&o.onOverlayClick(...e))},[b(e.$slots,"header",{value:i.modelValue,options:o.visibleOptions}),i.filter?(d(),h("div",k,[u("div",I,[u("input",{type:"text",ref:"filterInput",value:n.filterValue,onVnodeUpdated:t[8]||(t[8]=(...e)=>o.onFilterUpdated&&o.onFilterUpdated(...e)),autoComplete:"off",class:"p-dropdown-filter p-inputtext p-component",placeholder:i.filterPlaceholder,onKeydown:t[9]||(t[9]=(...e)=>o.onFilterKeyDown&&o.onFilterKeyDown(...e)),onInput:t[10]||(t[10]=(...e)=>o.onFilterChange&&o.onFilterChange(...e))},null,40,["value","placeholder"]),D])])):c("",!0),u("div",{ref:o.itemsWrapperRef,class:"p-dropdown-items-wrapper",style:{"max-height":o.virtualScrollerDisabled?i.scrollHeight:""}},[u(s,O({ref:o.virtualScrollerRef},i.virtualScrollerOptions,{items:o.visibleOptions,style:{height:i.scrollHeight},disabled:o.virtualScrollerDisabled}),w({content:m((({styleClass:t,contentRef:l,items:s,getItemOptions:a,contentStyle:p})=>[u("ul",{ref:l,class:["p-dropdown-items",t],style:p,role:"listbox"},[i.optionGroupLabel?(d(!0),h(L,{key:1},V(s,((t,i)=>(d(),h(L,{key:o.getOptionGroupRenderKey(t)},[u("li",$,[b(e.$slots,"optiongroup",{option:t,index:o.getOptionIndex(i,a)},(()=>[f(v(o.getOptionGroupLabel(t)),1)]))]),(d(!0),h(L,null,V(o.getOptionGroupChildren(t),((t,i)=>x((d(),h("li",{class:["p-dropdown-item",{"p-highlight":o.isSelected(t),"p-disabled":o.isOptionDisabled(t)}],key:o.getOptionRenderKey(t),onClick:e=>o.onOptionSelect(e,t),role:"option","aria-label":o.getOptionLabel(t),"aria-selected":o.isSelected(t)},[b(e.$slots,"option",{option:t,index:o.getOptionIndex(i,a)},(()=>[f(v(o.getOptionLabel(t)),1)]))],10,["onClick","aria-label","aria-selected"])),[[r]]))),128))],64)))),128)):(d(!0),h(L,{key:0},V(s,((t,i)=>x((d(),h("li",{class:["p-dropdown-item",{"p-highlight":o.isSelected(t),"p-disabled":o.isOptionDisabled(t)}],key:o.getOptionRenderKey(t),onClick:e=>o.onOptionSelect(e,t),role:"option","aria-label":o.getOptionLabel(t),"aria-selected":o.isSelected(t)},[b(e.$slots,"option",{option:t,index:o.getOptionIndex(i,a)},(()=>[f(v(o.getOptionLabel(t)),1)]))],10,["onClick","aria-label","aria-selected"])),[[r]]))),128)),n.filterValue&&(!s||s&&0===s.length)?(d(),h("li",F,[b(e.$slots,"emptyfilter",{},(()=>[f(v(o.emptyFilterMessageText),1)]))])):!i.options||i.options&&0===i.options.length?(d(),h("li",G,[b(e.$slots,"empty",{},(()=>[f(v(o.emptyMessageText),1)]))])):c("",!0)],6)])),_:2},[e.$slots.loader?{name:"loader",fn:m((({options:t})=>[b(e.$slots,"loader",{options:t})]))}:void 0]),1040,["items","style","disabled"])],4),b(e.$slots,"footer",{value:i.modelValue,options:o.visibleOptions})],2)):c("",!0)])),_:3},8,["onEnter","onAfterEnter","onLeave","onAfterLeave"])],8,["to","disabled"]))],2)};export default C;
1
+ import{ZIndexUtils as e,ObjectUtils as t,DomHandler as i,ConnectedOverlayScrollHandler as l}from"primevue/utils";import n from"primevue/overlayeventbus";import{FilterService as o}from"primevue/api";import s from"primevue/ripple";import r from"primevue/virtualscroller";import a from"primevue/portal";import{resolveComponent as p,resolveDirective as d,openBlock as h,createElementBlock as u,normalizeClass as c,createElementVNode as f,createCommentVNode as b,renderSlot as v,createTextVNode as g,toDisplayString as y,createVNode as m,withCtx as O,Transition as w,normalizeStyle as L,mergeProps as V,createSlots as x,Fragment as C,renderList as S,withDirectives as k}from"vue";var I={name:"Dropdown",emits:["update:modelValue","before-show","before-hide","show","hide","change","filter","focus","blur"],props:{modelValue:null,options:Array,optionLabel:null,optionValue:null,optionDisabled:null,optionGroupLabel:null,optionGroupChildren:null,scrollHeight:{type:String,default:"200px"},filter:Boolean,filterPlaceholder:String,filterLocale:String,filterMatchMode:{type:String,default:"contains"},filterFields:{type:Array,default:null},editable:Boolean,placeholder:String,disabled:Boolean,dataKey:null,showClear:Boolean,inputId:String,tabindex:String,ariaLabelledBy:null,appendTo:{type:String,default:"body"},emptyFilterMessage:{type:String,default:null},emptyMessage:{type:String,default:null},panelClass:null,loading:{type:Boolean,default:!1},loadingIcon:{type:String,default:"pi pi-spinner pi-spin"},virtualScrollerOptions:{type:Object,default:null}},data:()=>({focused:!1,filterValue:null,overlayVisible:!1}),watch:{modelValue(){this.isModelValueChanged=!0}},outsideClickListener:null,scrollHandler:null,resizeListener:null,searchTimeout:null,currentSearchChar:null,previousSearchChar:null,searchValue:null,overlay:null,itemsWrapper:null,virtualScroller:null,isModelValueChanged:!1,updated(){this.overlayVisible&&this.isModelValueChanged&&this.scrollValueInView(),this.isModelValueChanged=!1},beforeUnmount(){this.unbindOutsideClickListener(),this.unbindResizeListener(),this.scrollHandler&&(this.scrollHandler.destroy(),this.scrollHandler=null),this.itemsWrapper=null,this.overlay&&(e.clear(this.overlay),this.overlay=null)},methods:{getOptionIndex(e,t){return this.virtualScrollerDisabled?e:t&&t(e).index},getOptionLabel(e){return this.optionLabel?t.resolveFieldData(e,this.optionLabel):e},getOptionValue(e){return this.optionValue?t.resolveFieldData(e,this.optionValue):e},getOptionRenderKey(e,i){return this.dataKey?t.resolveFieldData(e,this.dataKey):this.getOptionLabel(e)+"_"+i.toString()},isOptionDisabled(e){return!!this.optionDisabled&&t.resolveFieldData(e,this.optionDisabled)},getOptionGroupRenderKey(e){return t.resolveFieldData(e,this.optionGroupLabel)},getOptionGroupLabel(e){return t.resolveFieldData(e,this.optionGroupLabel)},getOptionGroupChildren(e){return t.resolveFieldData(e,this.optionGroupChildren)},getSelectedOption(){let e=this.getSelectedOptionIndex();return-1!==e?this.optionGroupLabel?this.getOptionGroupChildren(this.visibleOptions[e.group])[e.option]:this.visibleOptions[e]:null},getSelectedOptionIndex(){if(null!=this.modelValue&&this.visibleOptions){if(!this.optionGroupLabel)return this.findOptionIndexInList(this.modelValue,this.visibleOptions);for(let e=0;e<this.visibleOptions.length;e++){let t=this.findOptionIndexInList(this.modelValue,this.getOptionGroupChildren(this.visibleOptions[e]));if(-1!==t)return{group:e,option:t}}}return-1},findOptionIndexInList(e,i){for(let l=0;l<i.length;l++)if(t.equals(e,this.getOptionValue(i[l]),this.equalityKey))return l;return-1},isSelected(e){return t.equals(this.modelValue,this.getOptionValue(e),this.equalityKey)},show(e){this.$emit("before-show"),this.overlayVisible=!0,e&&this.$refs.focusInput.focus()},hide(){this.$emit("before-hide"),this.overlayVisible=!1},onFocus(e){this.focused=!0,this.$emit("focus",e)},onBlur(e){this.focused=!1,this.$emit("blur",e)},onKeyDown(e){switch(e.which){case 40:this.onDownKey(e);break;case 38:this.onUpKey(e);break;case 32:this.overlayVisible||(this.show(),e.preventDefault());break;case 13:case 27:this.overlayVisible&&(this.hide(),e.preventDefault());break;case 9:this.hide();break;default:this.search(e)}},onFilterKeyDown(e){switch(e.which){case 40:this.onDownKey(e);break;case 38:this.onUpKey(e);break;case 13:case 27:this.overlayVisible=!1,e.preventDefault()}},onDownKey(e){if(this.visibleOptions)if(!this.overlayVisible&&e.altKey)this.show();else{let t=this.visibleOptions&&this.visibleOptions.length>0?this.findNextOption(this.getSelectedOptionIndex()):null;t&&this.updateModel(e,this.getOptionValue(t))}e.preventDefault()},onUpKey(e){if(this.visibleOptions){let t=this.findPrevOption(this.getSelectedOptionIndex());t&&this.updateModel(e,this.getOptionValue(t))}e.preventDefault()},findNextOption(e){if(this.optionGroupLabel){let t=-1===e?0:e.group,i=-1===e?-1:e.option,l=this.findNextOptionInList(this.getOptionGroupChildren(this.visibleOptions[t]),i);return l||(t+1!==this.visibleOptions.length?this.findNextOption({group:t+1,option:-1}):null)}return this.findNextOptionInList(this.visibleOptions,e)},findNextOptionInList(e,t){let i=t+1;if(i===e.length)return null;let l=e[i];return this.isOptionDisabled(l)?this.findNextOptionInList(i):l},findPrevOption(e){if(-1===e)return null;if(this.optionGroupLabel){let t=e.group,i=e.option,l=this.findPrevOptionInList(this.getOptionGroupChildren(this.visibleOptions[t]),i);return l||(t>0?this.findPrevOption({group:t-1,option:this.getOptionGroupChildren(this.visibleOptions[t-1]).length}):null)}return this.findPrevOptionInList(this.visibleOptions,e)},findPrevOptionInList(e,t){let i=t-1;if(i<0)return null;let l=e[i];return this.isOptionDisabled(l)?this.findPrevOption(i):l},onClearClick(e){this.updateModel(e,null)},onClick(e){this.disabled||this.loading||i.hasClass(e.target,"p-dropdown-clear-icon")||"INPUT"===e.target.tagName||this.overlay&&this.overlay.contains(e.target)||(this.overlayVisible?this.hide():this.show(),this.$refs.focusInput.focus())},onOptionSelect(e,t){let i=this.getOptionValue(t);this.updateModel(e,i),this.$refs.focusInput.focus(),setTimeout((()=>{this.hide()}),200)},onEditableInput(e){this.$emit("update:modelValue",e.target.value)},onOverlayEnter(t){if(e.set("overlay",t,this.$primevue.config.zIndex.overlay),this.alignOverlay(),this.scrollValueInView(),!this.virtualScrollerDisabled){const e=this.getSelectedOptionIndex();-1!==e&&setTimeout((()=>{this.virtualScroller&&this.virtualScroller.scrollToIndex(e)}),0)}},onOverlayAfterEnter(){this.filter&&this.$refs.filterInput.focus(),this.bindOutsideClickListener(),this.bindScrollListener(),this.bindResizeListener(),this.$emit("show")},onOverlayLeave(){this.unbindOutsideClickListener(),this.unbindScrollListener(),this.unbindResizeListener(),this.$emit("hide"),this.itemsWrapper=null,this.overlay=null},onOverlayAfterLeave(t){e.clear(t)},alignOverlay(){"self"===this.appendTo?i.relativePosition(this.overlay,this.$el):(this.overlay.style.minWidth=i.getOuterWidth(this.$el)+"px",i.absolutePosition(this.overlay,this.$el))},updateModel(e,t){this.$emit("update:modelValue",t),this.$emit("change",{originalEvent:e,value:t})},bindOutsideClickListener(){this.outsideClickListener||(this.outsideClickListener=e=>{this.overlayVisible&&this.overlay&&!this.$el.contains(e.target)&&!this.overlay.contains(e.target)&&this.hide()},document.addEventListener("click",this.outsideClickListener))},unbindOutsideClickListener(){this.outsideClickListener&&(document.removeEventListener("click",this.outsideClickListener),this.outsideClickListener=null)},bindScrollListener(){this.scrollHandler||(this.scrollHandler=new l(this.$refs.container,(()=>{this.overlayVisible&&this.hide()}))),this.scrollHandler.bindScrollListener()},unbindScrollListener(){this.scrollHandler&&this.scrollHandler.unbindScrollListener()},bindResizeListener(){this.resizeListener||(this.resizeListener=()=>{this.overlayVisible&&!i.isTouchDevice()&&this.hide()},window.addEventListener("resize",this.resizeListener))},unbindResizeListener(){this.resizeListener&&(window.removeEventListener("resize",this.resizeListener),this.resizeListener=null)},search(e){if(!this.visibleOptions)return;this.searchTimeout&&clearTimeout(this.searchTimeout);const t=e.key;if(this.previousSearchChar=this.currentSearchChar,this.currentSearchChar=t,this.previousSearchChar===this.currentSearchChar?this.searchValue=this.currentSearchChar:this.searchValue=this.searchValue?this.searchValue+t:t,this.searchValue){let t=this.getSelectedOptionIndex(),i=this.optionGroupLabel?this.searchOptionInGroup(t):this.searchOption(++t);i&&this.updateModel(e,this.getOptionValue(i))}this.searchTimeout=setTimeout((()=>{this.searchValue=null}),250)},searchOption(e){let t;return this.searchValue&&(t=this.searchOptionInRange(e,this.visibleOptions.length),t||(t=this.searchOptionInRange(0,e))),t},searchOptionInRange(e,t){for(let i=e;i<t;i++){let e=this.visibleOptions[i];if(this.matchesSearchValue(e))return e}return null},searchOptionInGroup(e){let t=-1===e?{group:0,option:-1}:e;for(let e=t.group;e<this.visibleOptions.length;e++){let i=this.getOptionGroupChildren(this.visibleOptions[e]);for(let l=t.group===e?t.option+1:0;l<i.length;l++)if(this.matchesSearchValue(i[l]))return i[l]}for(let e=0;e<=t.group;e++){let i=this.getOptionGroupChildren(this.visibleOptions[e]);for(let l=0;l<(t.group===e?t.option:i.length);l++)if(this.matchesSearchValue(i[l]))return i[l]}return null},matchesSearchValue(e){return this.getOptionLabel(e).toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale))},onFilterChange(e){this.filterValue=e.target.value,this.$emit("filter",{originalEvent:e,value:e.target.value})},onFilterUpdated(){this.overlayVisible&&this.alignOverlay()},overlayRef(e){this.overlay=e},itemsWrapperRef(e){this.itemsWrapper=e},virtualScrollerRef(e){this.virtualScroller=e},scrollValueInView(){if(this.overlay){let e=i.findSingle(this.overlay,"li.p-highlight");e&&e.scrollIntoView({block:"nearest",inline:"start"})}},onOverlayClick(e){n.emit("overlay-click",{originalEvent:e,target:this.$el})}},computed:{visibleOptions(){if(this.filterValue){if(this.optionGroupLabel){let e=[];for(let t of this.options){let i=o.filter(this.getOptionGroupChildren(t),this.searchFields,this.filterValue,this.filterMatchMode,this.filterLocale);if(i&&i.length){let l={...t};l[this.optionGroupChildren]=i,e.push(l)}}return e}return o.filter(this.options,this.searchFields,this.filterValue,this.filterMatchMode,this.filterLocale)}return this.options},containerClass(){return["p-dropdown p-component p-inputwrapper",{"p-disabled":this.disabled,"p-dropdown-clearable":this.showClear&&!this.disabled,"p-focus":this.focused,"p-inputwrapper-filled":this.modelValue,"p-inputwrapper-focus":this.focused||this.overlayVisible}]},labelClass(){return["p-dropdown-label p-inputtext",{"p-placeholder":this.label===this.placeholder,"p-dropdown-label-empty":!this.$slots.value&&("p-emptylabel"===this.label||0===this.label.length)}]},panelStyleClass(){return["p-dropdown-panel p-component",this.panelClass,{"p-input-filled":"filled"===this.$primevue.config.inputStyle,"p-ripple-disabled":!1===this.$primevue.config.ripple}]},label(){let e=this.getSelectedOption();return null!==e?this.getOptionLabel(e):this.placeholder||"p-emptylabel"},editableInputValue(){let e=this.getSelectedOption();return e?this.getOptionLabel(e):this.modelValue},equalityKey(){return this.optionValue?null:this.dataKey},searchFields(){return this.filterFields||[this.optionLabel]},emptyFilterMessageText(){return this.emptyFilterMessage||this.$primevue.config.locale.emptyFilterMessage},emptyMessageText(){return this.emptyMessage||this.$primevue.config.locale.emptyMessage},virtualScrollerDisabled(){return!this.virtualScrollerOptions},dropdownIconClass(){return["p-dropdown-trigger-icon",this.loading?this.loadingIcon:"pi pi-chevron-down"]}},directives:{ripple:s},components:{VirtualScroller:r,Portal:a}};const $={class:"p-hidden-accessible"},D=["id","disabled","tabindex","aria-expanded","aria-labelledby"],F=["disabled","placeholder","value","aria-expanded"],G=["aria-expanded"],K={key:0,class:"p-dropdown-header"},M={class:"p-dropdown-filter-container"},T=["value","placeholder"],E=f("span",{class:"p-dropdown-filter-icon pi pi-search"},null,-1),R=["onClick","aria-label","aria-selected"],z={class:"p-dropdown-item-group"},B=["onClick","aria-label","aria-selected"],P={key:2,class:"p-dropdown-empty-message"},H={key:3,class:"p-dropdown-empty-message"};!function(e,t){void 0===t&&(t={});var i=t.insertAt;if(e&&"undefined"!=typeof document){var l=document.head||document.getElementsByTagName("head")[0],n=document.createElement("style");n.type="text/css","top"===i&&l.firstChild?l.insertBefore(n,l.firstChild):l.appendChild(n),n.styleSheet?n.styleSheet.cssText=e:n.appendChild(document.createTextNode(e))}}("\n.p-dropdown {\n display: -webkit-inline-box;\n display: -ms-inline-flexbox;\n display: inline-flex;\n cursor: pointer;\n position: relative;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n}\n.p-dropdown-clear-icon {\n position: absolute;\n top: 50%;\n margin-top: -.5rem;\n}\n.p-dropdown-trigger {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n -ms-flex-negative: 0;\n flex-shrink: 0;\n}\n.p-dropdown-label {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n -webkit-box-flex: 1;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n width: 1%;\n text-overflow: ellipsis;\n cursor: pointer;\n}\n.p-dropdown-label-empty {\n overflow: hidden;\n visibility: hidden;\n}\ninput.p-dropdown-label {\n cursor: default;\n}\n.p-dropdown .p-dropdown-panel {\n min-width: 100%;\n}\n.p-dropdown-panel {\n position: absolute;\n top: 0;\n left: 0;\n}\n.p-dropdown-items-wrapper {\n overflow: auto;\n}\n.p-dropdown-item {\n cursor: pointer;\n font-weight: normal;\n white-space: nowrap;\n position: relative;\n overflow: hidden;\n}\n.p-dropdown-item-group {\n cursor: auto;\n}\n.p-dropdown-items {\n margin: 0;\n padding: 0;\n list-style-type: none;\n}\n.p-dropdown-filter {\n width: 100%;\n}\n.p-dropdown-filter-container {\n position: relative;\n}\n.p-dropdown-filter-icon {\n position: absolute;\n top: 50%;\n margin-top: -.5rem;\n}\n.p-fluid .p-dropdown {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n}\n.p-fluid .p-dropdown .p-dropdown-label {\n width: 1%;\n}\n"),I.render=function(e,t,i,l,n,o){const s=p("VirtualScroller"),r=p("Portal"),a=d("ripple");return h(),u("div",{ref:"container",class:c(o.containerClass),onClick:t[11]||(t[11]=e=>o.onClick(e))},[f("div",$,[f("input",{ref:"focusInput",type:"text",id:i.inputId,readonly:"",disabled:i.disabled,onFocus:t[0]||(t[0]=(...e)=>o.onFocus&&o.onFocus(...e)),onBlur:t[1]||(t[1]=(...e)=>o.onBlur&&o.onBlur(...e)),onKeydown:t[2]||(t[2]=(...e)=>o.onKeyDown&&o.onKeyDown(...e)),tabindex:i.tabindex,"aria-haspopup":"true","aria-expanded":n.overlayVisible,"aria-labelledby":i.ariaLabelledBy},null,40,D)]),i.editable?(h(),u("input",{key:0,type:"text",class:"p-dropdown-label p-inputtext",disabled:i.disabled,onFocus:t[3]||(t[3]=(...e)=>o.onFocus&&o.onFocus(...e)),onBlur:t[4]||(t[4]=(...e)=>o.onBlur&&o.onBlur(...e)),placeholder:i.placeholder,value:o.editableInputValue,onInput:t[5]||(t[5]=(...e)=>o.onEditableInput&&o.onEditableInput(...e)),"aria-haspopup":"listbox","aria-expanded":n.overlayVisible},null,40,F)):b("",!0),i.editable?b("",!0):(h(),u("span",{key:1,class:c(o.labelClass)},[v(e.$slots,"value",{value:i.modelValue,placeholder:i.placeholder},(()=>[g(y(o.label||"empty"),1)]))],2)),i.showClear&&null!=i.modelValue?(h(),u("i",{key:2,class:"p-dropdown-clear-icon pi pi-times",onClick:t[6]||(t[6]=e=>o.onClearClick(e))})):b("",!0),f("div",{class:"p-dropdown-trigger",role:"button","aria-haspopup":"listbox","aria-expanded":n.overlayVisible},[v(e.$slots,"indicator",{},(()=>[f("span",{class:c(o.dropdownIconClass)},null,2)]))],8,G),m(r,{appendTo:i.appendTo},{default:O((()=>[m(w,{name:"p-connected-overlay",onEnter:o.onOverlayEnter,onAfterEnter:o.onOverlayAfterEnter,onLeave:o.onOverlayLeave,onAfterLeave:o.onOverlayAfterLeave},{default:O((()=>[n.overlayVisible?(h(),u("div",{key:0,ref:o.overlayRef,class:c(o.panelStyleClass),onClick:t[10]||(t[10]=(...e)=>o.onOverlayClick&&o.onOverlayClick(...e))},[v(e.$slots,"header",{value:i.modelValue,options:o.visibleOptions}),i.filter?(h(),u("div",K,[f("div",M,[f("input",{type:"text",ref:"filterInput",value:n.filterValue,onVnodeUpdated:t[7]||(t[7]=(...e)=>o.onFilterUpdated&&o.onFilterUpdated(...e)),autoComplete:"off",class:"p-dropdown-filter p-inputtext p-component",placeholder:i.filterPlaceholder,onKeydown:t[8]||(t[8]=(...e)=>o.onFilterKeyDown&&o.onFilterKeyDown(...e)),onInput:t[9]||(t[9]=(...e)=>o.onFilterChange&&o.onFilterChange(...e))},null,40,T),E])])):b("",!0),f("div",{ref:o.itemsWrapperRef,class:"p-dropdown-items-wrapper",style:L({"max-height":o.virtualScrollerDisabled?i.scrollHeight:""})},[m(s,V({ref:o.virtualScrollerRef},i.virtualScrollerOptions,{items:o.visibleOptions,style:{height:i.scrollHeight},disabled:o.virtualScrollerDisabled}),x({content:O((({styleClass:t,contentRef:l,items:s,getItemOptions:r,contentStyle:p})=>[f("ul",{ref:l,class:c(["p-dropdown-items",t]),style:L(p),role:"listbox"},[i.optionGroupLabel?(h(!0),u(C,{key:1},S(s,((t,i)=>(h(),u(C,{key:o.getOptionGroupRenderKey(t)},[f("li",z,[v(e.$slots,"optiongroup",{option:t,index:o.getOptionIndex(i,r)},(()=>[g(y(o.getOptionGroupLabel(t)),1)]))]),(h(!0),u(C,null,S(o.getOptionGroupChildren(t),((t,i)=>k((h(),u("li",{class:c(["p-dropdown-item",{"p-highlight":o.isSelected(t),"p-disabled":o.isOptionDisabled(t)}]),key:o.getOptionRenderKey(t,i),onClick:e=>o.onOptionSelect(e,t),role:"option","aria-label":o.getOptionLabel(t),"aria-selected":o.isSelected(t)},[v(e.$slots,"option",{option:t,index:o.getOptionIndex(i,r)},(()=>[g(y(o.getOptionLabel(t)),1)]))],10,B)),[[a]]))),128))],64)))),128)):(h(!0),u(C,{key:0},S(s,((t,i)=>k((h(),u("li",{class:c(["p-dropdown-item",{"p-highlight":o.isSelected(t),"p-disabled":o.isOptionDisabled(t)}]),key:o.getOptionRenderKey(t,i),onClick:e=>o.onOptionSelect(e,t),role:"option","aria-label":o.getOptionLabel(t),"aria-selected":o.isSelected(t)},[v(e.$slots,"option",{option:t,index:o.getOptionIndex(i,r)},(()=>[g(y(o.getOptionLabel(t)),1)]))],10,R)),[[a]]))),128)),n.filterValue&&(!s||s&&0===s.length)?(h(),u("li",P,[v(e.$slots,"emptyfilter",{},(()=>[g(y(o.emptyFilterMessageText),1)]))])):!i.options||i.options&&0===i.options.length?(h(),u("li",H,[v(e.$slots,"empty",{},(()=>[g(y(o.emptyMessageText),1)]))])):b("",!0)],6)])),_:2},[e.$slots.loader?{name:"loader",fn:O((({options:t})=>[v(e.$slots,"loader",{options:t})]))}:void 0]),1040,["items","style","disabled"])],4),v(e.$slots,"footer",{value:i.modelValue,options:o.visibleOptions})],2)):b("",!0)])),_:3},8,["onEnter","onAfterEnter","onLeave","onAfterLeave"])])),_:3},8,["appendTo"])],2)};export{I as default};