@eslamdevui/ui 4.0.0 → 4.1.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 (514) hide show
  1. package/.nuxt/ui/auth-form.ts +2 -2
  2. package/.nuxt/ui/calendar.ts +221 -9
  3. package/.nuxt/ui/chat-message.ts +10 -3
  4. package/.nuxt/ui/command-palette.ts +12 -2
  5. package/.nuxt/ui/content/content-search.ts +8 -1
  6. package/.nuxt/ui/context-menu.ts +3 -1
  7. package/.nuxt/ui/dashboard-panel.ts +1 -1
  8. package/.nuxt/ui/dashboard-search.ts +8 -1
  9. package/.nuxt/ui/dashboard-sidebar.ts +1 -1
  10. package/.nuxt/ui/drawer.ts +23 -0
  11. package/.nuxt/ui/dropdown-menu.ts +3 -1
  12. package/.nuxt/ui/empty.ts +83 -0
  13. package/.nuxt/ui/index.ts +1 -0
  14. package/.nuxt/ui/input-menu.ts +12 -2
  15. package/.nuxt/ui/input-number.ts +25 -14
  16. package/.nuxt/ui/kbd.ts +1 -1
  17. package/.nuxt/ui/prose/code-tree.ts +1 -1
  18. package/.nuxt/ui/prose/img.ts +2 -1
  19. package/.nuxt/ui/select-menu.ts +12 -2
  20. package/.nuxt/ui/select.ts +4 -2
  21. package/.nuxt/ui/table.ts +8 -2
  22. package/.nuxt/ui/tree.ts +25 -11
  23. package/cli/templates.mjs +14 -2
  24. package/dist/module.d.mts +15 -0
  25. package/dist/module.json +2 -2
  26. package/dist/module.mjs +5 -2
  27. package/dist/runtime/components/Accordion.d.vue.ts +11 -6
  28. package/dist/runtime/components/Accordion.vue +4 -4
  29. package/dist/runtime/components/Accordion.vue.d.ts +11 -6
  30. package/dist/runtime/components/Alert.d.vue.ts +6 -5
  31. package/dist/runtime/components/Alert.vue +1 -1
  32. package/dist/runtime/components/Alert.vue.d.ts +6 -5
  33. package/dist/runtime/components/App.d.vue.ts +5 -4
  34. package/dist/runtime/components/App.vue +1 -1
  35. package/dist/runtime/components/App.vue.d.ts +5 -4
  36. package/dist/runtime/components/AuthForm.d.vue.ts +33 -51
  37. package/dist/runtime/components/AuthForm.vue +35 -23
  38. package/dist/runtime/components/AuthForm.vue.d.ts +33 -51
  39. package/dist/runtime/components/Avatar.d.vue.ts +6 -4
  40. package/dist/runtime/components/Avatar.vue +10 -4
  41. package/dist/runtime/components/Avatar.vue.d.ts +6 -4
  42. package/dist/runtime/components/AvatarGroup.d.vue.ts +2 -1
  43. package/dist/runtime/components/AvatarGroup.vue.d.ts +2 -1
  44. package/dist/runtime/components/Badge.d.vue.ts +11 -4
  45. package/dist/runtime/components/Badge.vue +3 -3
  46. package/dist/runtime/components/Badge.vue.d.ts +11 -4
  47. package/dist/runtime/components/Banner.d.vue.ts +6 -3
  48. package/dist/runtime/components/Banner.vue +1 -1
  49. package/dist/runtime/components/Banner.vue.d.ts +6 -3
  50. package/dist/runtime/components/BlogPost.d.vue.ts +11 -4
  51. package/dist/runtime/components/BlogPost.vue +2 -2
  52. package/dist/runtime/components/BlogPost.vue.d.ts +11 -4
  53. package/dist/runtime/components/BlogPosts.d.vue.ts +23 -13
  54. package/dist/runtime/components/BlogPosts.vue +8 -2
  55. package/dist/runtime/components/BlogPosts.vue.d.ts +23 -13
  56. package/dist/runtime/components/Breadcrumb.d.vue.ts +23 -7
  57. package/dist/runtime/components/Breadcrumb.vue +8 -8
  58. package/dist/runtime/components/Breadcrumb.vue.d.ts +23 -7
  59. package/dist/runtime/components/Button.d.vue.ts +11 -4
  60. package/dist/runtime/components/Button.vue +3 -3
  61. package/dist/runtime/components/Button.vue.d.ts +11 -4
  62. package/dist/runtime/components/Calendar.d.vue.ts +8 -8
  63. package/dist/runtime/components/Calendar.vue +3 -1
  64. package/dist/runtime/components/Calendar.vue.d.ts +8 -8
  65. package/dist/runtime/components/Card.d.vue.ts +2 -1
  66. package/dist/runtime/components/Card.vue.d.ts +2 -1
  67. package/dist/runtime/components/Carousel.d.vue.ts +5 -6
  68. package/dist/runtime/components/Carousel.vue +33 -12
  69. package/dist/runtime/components/Carousel.vue.d.ts +5 -6
  70. package/dist/runtime/components/ChangelogVersion.d.vue.ts +14 -5
  71. package/dist/runtime/components/ChangelogVersion.vue +3 -3
  72. package/dist/runtime/components/ChangelogVersion.vue.d.ts +14 -5
  73. package/dist/runtime/components/ChangelogVersions.d.vue.ts +12 -39
  74. package/dist/runtime/components/ChangelogVersions.vue +2 -2
  75. package/dist/runtime/components/ChangelogVersions.vue.d.ts +12 -39
  76. package/dist/runtime/components/ChatMessage.d.vue.ts +3 -1
  77. package/dist/runtime/components/ChatMessage.vue +1 -1
  78. package/dist/runtime/components/ChatMessage.vue.d.ts +3 -1
  79. package/dist/runtime/components/ChatMessages.d.vue.ts +16 -16
  80. package/dist/runtime/components/ChatMessages.vue +31 -13
  81. package/dist/runtime/components/ChatMessages.vue.d.ts +16 -16
  82. package/dist/runtime/components/ChatPalette.d.vue.ts +2 -1
  83. package/dist/runtime/components/ChatPalette.vue.d.ts +2 -1
  84. package/dist/runtime/components/ChatPrompt.d.vue.ts +4 -3
  85. package/dist/runtime/components/ChatPrompt.vue.d.ts +4 -3
  86. package/dist/runtime/components/ChatPromptSubmit.d.vue.ts +2 -1
  87. package/dist/runtime/components/ChatPromptSubmit.vue.d.ts +2 -1
  88. package/dist/runtime/components/Checkbox.d.vue.ts +2 -1
  89. package/dist/runtime/components/Checkbox.vue.d.ts +2 -1
  90. package/dist/runtime/components/CheckboxGroup.d.vue.ts +4 -6
  91. package/dist/runtime/components/CheckboxGroup.vue.d.ts +4 -6
  92. package/dist/runtime/components/Chip.d.vue.ts +2 -1
  93. package/dist/runtime/components/Chip.vue.d.ts +2 -1
  94. package/dist/runtime/components/Collapsible.d.vue.ts +2 -1
  95. package/dist/runtime/components/Collapsible.vue.d.ts +2 -1
  96. package/dist/runtime/components/ColorPicker.d.vue.ts +3 -2
  97. package/dist/runtime/components/ColorPicker.vue.d.ts +3 -2
  98. package/dist/runtime/components/CommandPalette.d.vue.ts +51 -26
  99. package/dist/runtime/components/CommandPalette.vue +134 -68
  100. package/dist/runtime/components/CommandPalette.vue.d.ts +51 -26
  101. package/dist/runtime/components/Container.d.vue.ts +2 -1
  102. package/dist/runtime/components/Container.vue.d.ts +2 -1
  103. package/dist/runtime/components/ContextMenu.d.vue.ts +32 -11
  104. package/dist/runtime/components/ContextMenu.vue +2 -0
  105. package/dist/runtime/components/ContextMenu.vue.d.ts +32 -11
  106. package/dist/runtime/components/ContextMenuContent.d.vue.ts +6 -12
  107. package/dist/runtime/components/ContextMenuContent.vue +21 -11
  108. package/dist/runtime/components/ContextMenuContent.vue.d.ts +6 -12
  109. package/dist/runtime/components/DashboardGroup.d.vue.ts +2 -1
  110. package/dist/runtime/components/DashboardGroup.vue.d.ts +2 -1
  111. package/dist/runtime/components/DashboardNavbar.d.vue.ts +11 -4
  112. package/dist/runtime/components/DashboardNavbar.vue +3 -3
  113. package/dist/runtime/components/DashboardNavbar.vue.d.ts +11 -4
  114. package/dist/runtime/components/DashboardPanel.d.vue.ts +2 -1
  115. package/dist/runtime/components/DashboardPanel.vue.d.ts +2 -1
  116. package/dist/runtime/components/DashboardResizeHandle.d.vue.ts +2 -1
  117. package/dist/runtime/components/DashboardResizeHandle.vue.d.ts +2 -1
  118. package/dist/runtime/components/DashboardSearch.d.vue.ts +8 -4
  119. package/dist/runtime/components/DashboardSearch.vue +19 -6
  120. package/dist/runtime/components/DashboardSearch.vue.d.ts +8 -4
  121. package/dist/runtime/components/DashboardSearchButton.d.vue.ts +2 -1
  122. package/dist/runtime/components/DashboardSearchButton.vue +2 -2
  123. package/dist/runtime/components/DashboardSearchButton.vue.d.ts +2 -1
  124. package/dist/runtime/components/DashboardSidebar.d.vue.ts +10 -8
  125. package/dist/runtime/components/DashboardSidebar.vue +4 -4
  126. package/dist/runtime/components/DashboardSidebar.vue.d.ts +10 -8
  127. package/dist/runtime/components/DashboardSidebarCollapse.d.vue.ts +2 -1
  128. package/dist/runtime/components/DashboardSidebarCollapse.vue.d.ts +2 -1
  129. package/dist/runtime/components/DashboardSidebarToggle.d.vue.ts +2 -1
  130. package/dist/runtime/components/DashboardSidebarToggle.vue.d.ts +2 -1
  131. package/dist/runtime/components/DashboardToolbar.d.vue.ts +2 -1
  132. package/dist/runtime/components/DashboardToolbar.vue.d.ts +2 -1
  133. package/dist/runtime/components/Drawer.d.vue.ts +5 -1
  134. package/dist/runtime/components/Drawer.vue +16 -5
  135. package/dist/runtime/components/Drawer.vue.d.ts +5 -1
  136. package/dist/runtime/components/DropdownMenu.d.vue.ts +32 -11
  137. package/dist/runtime/components/DropdownMenu.vue +2 -0
  138. package/dist/runtime/components/DropdownMenu.vue.d.ts +32 -11
  139. package/dist/runtime/components/DropdownMenuContent.d.vue.ts +12 -14
  140. package/dist/runtime/components/DropdownMenuContent.vue +21 -11
  141. package/dist/runtime/components/DropdownMenuContent.vue.d.ts +12 -14
  142. package/dist/runtime/components/Empty.d.vue.ts +53 -0
  143. package/dist/runtime/components/Empty.vue +68 -0
  144. package/dist/runtime/components/Empty.vue.d.ts +53 -0
  145. package/dist/runtime/components/Error.d.vue.ts +2 -2
  146. package/dist/runtime/components/Error.vue +1 -1
  147. package/dist/runtime/components/Error.vue.d.ts +2 -2
  148. package/dist/runtime/components/FieldGroup.d.vue.ts +2 -1
  149. package/dist/runtime/components/FieldGroup.vue +1 -1
  150. package/dist/runtime/components/FieldGroup.vue.d.ts +2 -1
  151. package/dist/runtime/components/FileUpload.d.vue.ts +12 -9
  152. package/dist/runtime/components/FileUpload.vue +8 -7
  153. package/dist/runtime/components/FileUpload.vue.d.ts +12 -9
  154. package/dist/runtime/components/Footer.d.vue.ts +2 -1
  155. package/dist/runtime/components/Footer.vue.d.ts +2 -1
  156. package/dist/runtime/components/FooterColumns.d.vue.ts +13 -5
  157. package/dist/runtime/components/FooterColumns.vue +2 -2
  158. package/dist/runtime/components/FooterColumns.vue.d.ts +13 -5
  159. package/dist/runtime/components/Form.d.vue.ts +5 -7
  160. package/dist/runtime/components/Form.vue.d.ts +5 -7
  161. package/dist/runtime/components/FormField.d.vue.ts +2 -1
  162. package/dist/runtime/components/FormField.vue.d.ts +2 -1
  163. package/dist/runtime/components/Header.d.vue.ts +9 -7
  164. package/dist/runtime/components/Header.vue +3 -3
  165. package/dist/runtime/components/Header.vue.d.ts +9 -7
  166. package/dist/runtime/components/Icon.d.vue.ts +2 -1
  167. package/dist/runtime/components/Icon.vue.d.ts +2 -1
  168. package/dist/runtime/components/Input.d.vue.ts +14 -11
  169. package/dist/runtime/components/Input.vue +3 -3
  170. package/dist/runtime/components/Input.vue.d.ts +14 -11
  171. package/dist/runtime/components/InputMenu.d.vue.ts +49 -28
  172. package/dist/runtime/components/InputMenu.vue +117 -65
  173. package/dist/runtime/components/InputMenu.vue.d.ts +49 -28
  174. package/dist/runtime/components/InputNumber.d.vue.ts +6 -3
  175. package/dist/runtime/components/InputNumber.vue +7 -5
  176. package/dist/runtime/components/InputNumber.vue.d.ts +6 -3
  177. package/dist/runtime/components/InputTags.d.vue.ts +16 -16
  178. package/dist/runtime/components/InputTags.vue +5 -5
  179. package/dist/runtime/components/InputTags.vue.d.ts +16 -16
  180. package/dist/runtime/components/Kbd.d.vue.ts +2 -1
  181. package/dist/runtime/components/Kbd.vue.d.ts +2 -1
  182. package/dist/runtime/components/Link.d.vue.ts +3 -2
  183. package/dist/runtime/components/Link.vue.d.ts +3 -2
  184. package/dist/runtime/components/LinkBase.d.vue.ts +3 -2
  185. package/dist/runtime/components/LinkBase.vue.d.ts +3 -2
  186. package/dist/runtime/components/Main.d.vue.ts +3 -4
  187. package/dist/runtime/components/Main.vue +1 -1
  188. package/dist/runtime/components/Main.vue.d.ts +3 -4
  189. package/dist/runtime/components/Marquee.d.vue.ts +22 -1
  190. package/dist/runtime/components/Marquee.vue +1 -1
  191. package/dist/runtime/components/Marquee.vue.d.ts +22 -1
  192. package/dist/runtime/components/Modal.d.vue.ts +4 -6
  193. package/dist/runtime/components/Modal.vue +3 -6
  194. package/dist/runtime/components/Modal.vue.d.ts +4 -6
  195. package/dist/runtime/components/NavigationMenu.d.vue.ts +20 -9
  196. package/dist/runtime/components/NavigationMenu.vue +14 -7
  197. package/dist/runtime/components/NavigationMenu.vue.d.ts +20 -9
  198. package/dist/runtime/components/OverlayProvider.d.vue.ts +2 -1
  199. package/dist/runtime/components/OverlayProvider.vue.d.ts +2 -1
  200. package/dist/runtime/components/Page.d.vue.ts +2 -1
  201. package/dist/runtime/components/Page.vue.d.ts +2 -1
  202. package/dist/runtime/components/PageAnchors.d.vue.ts +13 -5
  203. package/dist/runtime/components/PageAnchors.vue +2 -2
  204. package/dist/runtime/components/PageAnchors.vue.d.ts +13 -5
  205. package/dist/runtime/components/PageAside.d.vue.ts +2 -1
  206. package/dist/runtime/components/PageAside.vue.d.ts +2 -1
  207. package/dist/runtime/components/PageBody.d.vue.ts +2 -1
  208. package/dist/runtime/components/PageBody.vue.d.ts +2 -1
  209. package/dist/runtime/components/PageCTA.d.vue.ts +2 -1
  210. package/dist/runtime/components/PageCTA.vue.d.ts +2 -1
  211. package/dist/runtime/components/PageCard.d.vue.ts +5 -2
  212. package/dist/runtime/components/PageCard.vue +1 -1
  213. package/dist/runtime/components/PageCard.vue.d.ts +5 -2
  214. package/dist/runtime/components/PageColumns.d.vue.ts +2 -1
  215. package/dist/runtime/components/PageColumns.vue.d.ts +2 -1
  216. package/dist/runtime/components/PageFeature.d.vue.ts +5 -2
  217. package/dist/runtime/components/PageFeature.vue +1 -1
  218. package/dist/runtime/components/PageFeature.vue.d.ts +5 -2
  219. package/dist/runtime/components/PageGrid.d.vue.ts +2 -1
  220. package/dist/runtime/components/PageGrid.vue.d.ts +2 -1
  221. package/dist/runtime/components/PageHeader.d.vue.ts +2 -1
  222. package/dist/runtime/components/PageHeader.vue.d.ts +2 -1
  223. package/dist/runtime/components/PageHero.d.vue.ts +2 -1
  224. package/dist/runtime/components/PageHero.vue.d.ts +2 -1
  225. package/dist/runtime/components/PageLinks.d.vue.ts +13 -5
  226. package/dist/runtime/components/PageLinks.vue +2 -2
  227. package/dist/runtime/components/PageLinks.vue.d.ts +13 -5
  228. package/dist/runtime/components/PageList.d.vue.ts +2 -1
  229. package/dist/runtime/components/PageList.vue.d.ts +2 -1
  230. package/dist/runtime/components/PageLogos.d.vue.ts +2 -1
  231. package/dist/runtime/components/PageLogos.vue.d.ts +2 -1
  232. package/dist/runtime/components/PageSection.d.vue.ts +5 -2
  233. package/dist/runtime/components/PageSection.vue +1 -1
  234. package/dist/runtime/components/PageSection.vue.d.ts +5 -2
  235. package/dist/runtime/components/Pagination.d.vue.ts +5 -2
  236. package/dist/runtime/components/Pagination.vue +5 -5
  237. package/dist/runtime/components/Pagination.vue.d.ts +5 -2
  238. package/dist/runtime/components/PinInput.d.vue.ts +5 -9
  239. package/dist/runtime/components/PinInput.vue.d.ts +5 -9
  240. package/dist/runtime/components/Popover.d.vue.ts +22 -23
  241. package/dist/runtime/components/Popover.vue +4 -4
  242. package/dist/runtime/components/Popover.vue.d.ts +22 -23
  243. package/dist/runtime/components/PricingPlan.d.vue.ts +11 -4
  244. package/dist/runtime/components/PricingPlan.vue +3 -3
  245. package/dist/runtime/components/PricingPlan.vue.d.ts +11 -4
  246. package/dist/runtime/components/PricingPlans.d.vue.ts +21 -13
  247. package/dist/runtime/components/PricingPlans.vue +7 -1
  248. package/dist/runtime/components/PricingPlans.vue.d.ts +21 -13
  249. package/dist/runtime/components/PricingTable.d.vue.ts +4 -3
  250. package/dist/runtime/components/PricingTable.vue.d.ts +4 -3
  251. package/dist/runtime/components/Progress.d.vue.ts +2 -1
  252. package/dist/runtime/components/Progress.vue +1 -1
  253. package/dist/runtime/components/Progress.vue.d.ts +2 -1
  254. package/dist/runtime/components/RadioGroup.d.vue.ts +4 -6
  255. package/dist/runtime/components/RadioGroup.vue.d.ts +4 -6
  256. package/dist/runtime/components/Select.d.vue.ts +25 -19
  257. package/dist/runtime/components/Select.vue +18 -9
  258. package/dist/runtime/components/Select.vue.d.ts +25 -19
  259. package/dist/runtime/components/SelectMenu.d.vue.ts +46 -26
  260. package/dist/runtime/components/SelectMenu.vue +114 -61
  261. package/dist/runtime/components/SelectMenu.vue.d.ts +46 -26
  262. package/dist/runtime/components/Separator.d.vue.ts +5 -2
  263. package/dist/runtime/components/Separator.vue +1 -1
  264. package/dist/runtime/components/Separator.vue.d.ts +5 -2
  265. package/dist/runtime/components/Skeleton.d.vue.ts +2 -1
  266. package/dist/runtime/components/Skeleton.vue.d.ts +2 -1
  267. package/dist/runtime/components/Slideover.d.vue.ts +4 -6
  268. package/dist/runtime/components/Slideover.vue +3 -6
  269. package/dist/runtime/components/Slideover.vue.d.ts +4 -6
  270. package/dist/runtime/components/Slider.d.vue.ts +5 -7
  271. package/dist/runtime/components/Slider.vue.d.ts +5 -7
  272. package/dist/runtime/components/Stepper.d.vue.ts +10 -10
  273. package/dist/runtime/components/Stepper.vue +1 -1
  274. package/dist/runtime/components/Stepper.vue.d.ts +10 -10
  275. package/dist/runtime/components/Switch.d.vue.ts +2 -1
  276. package/dist/runtime/components/Switch.vue.d.ts +2 -1
  277. package/dist/runtime/components/Table.d.vue.ts +27 -20
  278. package/dist/runtime/components/Table.vue +145 -61
  279. package/dist/runtime/components/Table.vue.d.ts +27 -20
  280. package/dist/runtime/components/Tabs.d.vue.ts +13 -9
  281. package/dist/runtime/components/Tabs.vue +3 -3
  282. package/dist/runtime/components/Tabs.vue.d.ts +13 -9
  283. package/dist/runtime/components/Textarea.d.vue.ts +14 -11
  284. package/dist/runtime/components/Textarea.vue +3 -3
  285. package/dist/runtime/components/Textarea.vue.d.ts +14 -11
  286. package/dist/runtime/components/Timeline.d.vue.ts +5 -6
  287. package/dist/runtime/components/Timeline.vue.d.ts +5 -6
  288. package/dist/runtime/components/Toast.d.vue.ts +6 -5
  289. package/dist/runtime/components/Toast.vue +1 -1
  290. package/dist/runtime/components/Toast.vue.d.ts +6 -5
  291. package/dist/runtime/components/Toaster.d.vue.ts +8 -1
  292. package/dist/runtime/components/Toaster.vue +6 -3
  293. package/dist/runtime/components/Toaster.vue.d.ts +8 -1
  294. package/dist/runtime/components/Tooltip.d.vue.ts +5 -2
  295. package/dist/runtime/components/Tooltip.vue +1 -1
  296. package/dist/runtime/components/Tooltip.vue.d.ts +5 -2
  297. package/dist/runtime/components/Tree.d.vue.ts +46 -10
  298. package/dist/runtime/components/Tree.vue +169 -81
  299. package/dist/runtime/components/Tree.vue.d.ts +46 -10
  300. package/dist/runtime/components/User.d.vue.ts +5 -2
  301. package/dist/runtime/components/User.vue +1 -1
  302. package/dist/runtime/components/User.vue.d.ts +5 -2
  303. package/dist/runtime/components/color-mode/ColorModeAvatar.d.vue.ts +2 -1
  304. package/dist/runtime/components/color-mode/ColorModeAvatar.vue.d.ts +2 -1
  305. package/dist/runtime/components/color-mode/ColorModeButton.d.vue.ts +2 -1
  306. package/dist/runtime/components/color-mode/ColorModeButton.vue.d.ts +2 -1
  307. package/dist/runtime/components/color-mode/ColorModeImage.d.vue.ts +2 -1
  308. package/dist/runtime/components/color-mode/ColorModeImage.vue.d.ts +2 -1
  309. package/dist/runtime/components/color-mode/ColorModeSelect.d.vue.ts +2 -1
  310. package/dist/runtime/components/color-mode/ColorModeSelect.vue.d.ts +2 -1
  311. package/dist/runtime/components/color-mode/ColorModeSwitch.d.vue.ts +2 -1
  312. package/dist/runtime/components/color-mode/ColorModeSwitch.vue.d.ts +2 -1
  313. package/dist/runtime/components/content/ContentNavigation.d.vue.ts +5 -5
  314. package/dist/runtime/components/content/ContentNavigation.vue +19 -9
  315. package/dist/runtime/components/content/ContentNavigation.vue.d.ts +5 -5
  316. package/dist/runtime/components/content/ContentSearch.d.vue.ts +11 -10
  317. package/dist/runtime/components/content/ContentSearch.vue +21 -6
  318. package/dist/runtime/components/content/ContentSearch.vue.d.ts +11 -10
  319. package/dist/runtime/components/content/ContentSearchButton.d.vue.ts +2 -1
  320. package/dist/runtime/components/content/ContentSearchButton.vue +2 -2
  321. package/dist/runtime/components/content/ContentSearchButton.vue.d.ts +2 -1
  322. package/dist/runtime/components/content/ContentSurround.d.vue.ts +5 -3
  323. package/dist/runtime/components/content/ContentSurround.vue +4 -4
  324. package/dist/runtime/components/content/ContentSurround.vue.d.ts +5 -3
  325. package/dist/runtime/components/content/ContentToc.d.vue.ts +6 -6
  326. package/dist/runtime/components/content/ContentToc.vue +2 -2
  327. package/dist/runtime/components/content/ContentToc.vue.d.ts +6 -6
  328. package/dist/runtime/components/locale/LocaleSelect.d.vue.ts +2 -1
  329. package/dist/runtime/components/locale/LocaleSelect.vue.d.ts +2 -1
  330. package/dist/runtime/components/prose/A.d.vue.ts +2 -1
  331. package/dist/runtime/components/prose/A.vue.d.ts +2 -1
  332. package/dist/runtime/components/prose/Accordion.d.vue.ts +8 -1
  333. package/dist/runtime/components/prose/Accordion.vue +3 -2
  334. package/dist/runtime/components/prose/Accordion.vue.d.ts +8 -1
  335. package/dist/runtime/components/prose/AccordionItem.d.vue.ts +2 -1
  336. package/dist/runtime/components/prose/AccordionItem.vue.d.ts +2 -1
  337. package/dist/runtime/components/prose/Badge.d.vue.ts +2 -1
  338. package/dist/runtime/components/prose/Badge.vue.d.ts +2 -1
  339. package/dist/runtime/components/prose/Blockquote.d.vue.ts +2 -1
  340. package/dist/runtime/components/prose/Blockquote.vue.d.ts +2 -1
  341. package/dist/runtime/components/prose/Callout.d.vue.ts +2 -1
  342. package/dist/runtime/components/prose/Callout.vue.d.ts +2 -1
  343. package/dist/runtime/components/prose/Card.d.vue.ts +2 -1
  344. package/dist/runtime/components/prose/Card.vue.d.ts +2 -1
  345. package/dist/runtime/components/prose/CardGroup.d.vue.ts +2 -1
  346. package/dist/runtime/components/prose/CardGroup.vue.d.ts +2 -1
  347. package/dist/runtime/components/prose/Code.d.vue.ts +2 -1
  348. package/dist/runtime/components/prose/Code.vue.d.ts +2 -1
  349. package/dist/runtime/components/prose/CodeCollapse.d.vue.ts +2 -1
  350. package/dist/runtime/components/prose/CodeCollapse.vue.d.ts +2 -1
  351. package/dist/runtime/components/prose/CodeGroup.d.vue.ts +2 -1
  352. package/dist/runtime/components/prose/CodeGroup.vue.d.ts +2 -1
  353. package/dist/runtime/components/prose/CodeIcon.d.vue.ts +2 -1
  354. package/dist/runtime/components/prose/CodeIcon.vue.d.ts +2 -1
  355. package/dist/runtime/components/prose/CodePreview.d.vue.ts +2 -1
  356. package/dist/runtime/components/prose/CodePreview.vue.d.ts +2 -1
  357. package/dist/runtime/components/prose/CodeTree.d.vue.ts +2 -1
  358. package/dist/runtime/components/prose/CodeTree.vue +40 -36
  359. package/dist/runtime/components/prose/CodeTree.vue.d.ts +2 -1
  360. package/dist/runtime/components/prose/Collapsible.d.vue.ts +4 -3
  361. package/dist/runtime/components/prose/Collapsible.vue +2 -2
  362. package/dist/runtime/components/prose/Collapsible.vue.d.ts +4 -3
  363. package/dist/runtime/components/prose/Em.d.vue.ts +2 -1
  364. package/dist/runtime/components/prose/Em.vue.d.ts +2 -1
  365. package/dist/runtime/components/prose/Field.d.vue.ts +3 -2
  366. package/dist/runtime/components/prose/Field.vue.d.ts +3 -2
  367. package/dist/runtime/components/prose/FieldGroup.d.vue.ts +2 -1
  368. package/dist/runtime/components/prose/FieldGroup.vue.d.ts +2 -1
  369. package/dist/runtime/components/prose/H1.d.vue.ts +2 -1
  370. package/dist/runtime/components/prose/H1.vue.d.ts +2 -1
  371. package/dist/runtime/components/prose/H2.d.vue.ts +2 -1
  372. package/dist/runtime/components/prose/H2.vue.d.ts +2 -1
  373. package/dist/runtime/components/prose/H3.d.vue.ts +2 -1
  374. package/dist/runtime/components/prose/H3.vue.d.ts +2 -1
  375. package/dist/runtime/components/prose/H4.d.vue.ts +2 -1
  376. package/dist/runtime/components/prose/H4.vue.d.ts +2 -1
  377. package/dist/runtime/components/prose/Hr.d.vue.ts +2 -1
  378. package/dist/runtime/components/prose/Hr.vue.d.ts +2 -1
  379. package/dist/runtime/components/prose/Icon.d.vue.ts +2 -1
  380. package/dist/runtime/components/prose/Icon.vue.d.ts +2 -1
  381. package/dist/runtime/components/prose/Img.d.vue.ts +2 -1
  382. package/dist/runtime/components/prose/Img.vue +14 -3
  383. package/dist/runtime/components/prose/Img.vue.d.ts +2 -1
  384. package/dist/runtime/components/prose/Kbd.d.vue.ts +2 -1
  385. package/dist/runtime/components/prose/Kbd.vue.d.ts +2 -1
  386. package/dist/runtime/components/prose/Li.d.vue.ts +2 -1
  387. package/dist/runtime/components/prose/Li.vue.d.ts +2 -1
  388. package/dist/runtime/components/prose/Ol.d.vue.ts +2 -1
  389. package/dist/runtime/components/prose/Ol.vue.d.ts +2 -1
  390. package/dist/runtime/components/prose/P.d.vue.ts +2 -1
  391. package/dist/runtime/components/prose/P.vue.d.ts +2 -1
  392. package/dist/runtime/components/prose/Pre.d.vue.ts +2 -1
  393. package/dist/runtime/components/prose/Pre.vue.d.ts +2 -1
  394. package/dist/runtime/components/prose/Script.d.vue.ts +2 -1
  395. package/dist/runtime/components/prose/Script.vue.d.ts +2 -1
  396. package/dist/runtime/components/prose/Steps.d.vue.ts +2 -1
  397. package/dist/runtime/components/prose/Steps.vue.d.ts +2 -1
  398. package/dist/runtime/components/prose/Strong.d.vue.ts +2 -1
  399. package/dist/runtime/components/prose/Strong.vue.d.ts +2 -1
  400. package/dist/runtime/components/prose/Table.d.vue.ts +2 -1
  401. package/dist/runtime/components/prose/Table.vue.d.ts +2 -1
  402. package/dist/runtime/components/prose/Tabs.d.vue.ts +8 -1
  403. package/dist/runtime/components/prose/Tabs.vue +3 -2
  404. package/dist/runtime/components/prose/Tabs.vue.d.ts +8 -1
  405. package/dist/runtime/components/prose/TabsItem.d.vue.ts +2 -1
  406. package/dist/runtime/components/prose/TabsItem.vue.d.ts +2 -1
  407. package/dist/runtime/components/prose/Tbody.d.vue.ts +2 -1
  408. package/dist/runtime/components/prose/Tbody.vue.d.ts +2 -1
  409. package/dist/runtime/components/prose/Td.d.vue.ts +2 -1
  410. package/dist/runtime/components/prose/Td.vue.d.ts +2 -1
  411. package/dist/runtime/components/prose/Th.d.vue.ts +2 -1
  412. package/dist/runtime/components/prose/Th.vue.d.ts +2 -1
  413. package/dist/runtime/components/prose/Thead.d.vue.ts +2 -1
  414. package/dist/runtime/components/prose/Thead.vue.d.ts +2 -1
  415. package/dist/runtime/components/prose/Tr.d.vue.ts +2 -1
  416. package/dist/runtime/components/prose/Tr.vue.d.ts +2 -1
  417. package/dist/runtime/components/prose/Ul.d.vue.ts +2 -1
  418. package/dist/runtime/components/prose/Ul.vue.d.ts +2 -1
  419. package/dist/runtime/components/prose/callout/Caution.d.vue.ts +3 -2
  420. package/dist/runtime/components/prose/callout/Caution.vue.d.ts +3 -2
  421. package/dist/runtime/components/prose/callout/Note.d.vue.ts +3 -2
  422. package/dist/runtime/components/prose/callout/Note.vue.d.ts +3 -2
  423. package/dist/runtime/components/prose/callout/Tip.d.vue.ts +3 -2
  424. package/dist/runtime/components/prose/callout/Tip.vue.d.ts +3 -2
  425. package/dist/runtime/components/prose/callout/Warning.d.vue.ts +3 -2
  426. package/dist/runtime/components/prose/callout/Warning.vue.d.ts +3 -2
  427. package/dist/runtime/composables/useKbd.js +2 -2
  428. package/dist/runtime/composables/usePortal.d.ts +3 -3
  429. package/dist/runtime/composables/usePortal.js +5 -10
  430. package/dist/runtime/composables/useToast.d.ts +3 -1
  431. package/dist/runtime/composables/useToast.js +4 -3
  432. package/dist/runtime/inertia/components/Link.d.vue.ts +3 -2
  433. package/dist/runtime/inertia/components/Link.vue +12 -6
  434. package/dist/runtime/inertia/components/Link.vue.d.ts +3 -2
  435. package/dist/runtime/inertia/components/LinkBase.d.vue.ts +3 -2
  436. package/dist/runtime/inertia/components/LinkBase.vue.d.ts +3 -2
  437. package/dist/runtime/inertia/stubs.d.ts +1 -1
  438. package/dist/runtime/inertia/stubs.js +2 -2
  439. package/dist/runtime/locale/ar.js +5 -5
  440. package/dist/runtime/locale/az.js +5 -5
  441. package/dist/runtime/locale/bg.js +3 -3
  442. package/dist/runtime/locale/bn.js +5 -5
  443. package/dist/runtime/locale/ca.js +5 -5
  444. package/dist/runtime/locale/ckb.js +15 -15
  445. package/dist/runtime/locale/cs.js +5 -5
  446. package/dist/runtime/locale/da.js +5 -5
  447. package/dist/runtime/locale/de.js +5 -5
  448. package/dist/runtime/locale/de_ch.js +5 -5
  449. package/dist/runtime/locale/el.js +5 -5
  450. package/dist/runtime/locale/en.js +5 -5
  451. package/dist/runtime/locale/es.js +5 -5
  452. package/dist/runtime/locale/et.js +5 -5
  453. package/dist/runtime/locale/fa_ir.js +5 -5
  454. package/dist/runtime/locale/fi.js +5 -5
  455. package/dist/runtime/locale/fr.js +5 -5
  456. package/dist/runtime/locale/he.js +5 -5
  457. package/dist/runtime/locale/hi.js +5 -5
  458. package/dist/runtime/locale/hr.d.ts +3 -0
  459. package/dist/runtime/locale/hr.js +129 -0
  460. package/dist/runtime/locale/hu.js +5 -5
  461. package/dist/runtime/locale/hy.js +4 -4
  462. package/dist/runtime/locale/id.js +5 -5
  463. package/dist/runtime/locale/index.d.ts +1 -0
  464. package/dist/runtime/locale/index.js +1 -0
  465. package/dist/runtime/locale/it.js +5 -5
  466. package/dist/runtime/locale/ja.js +5 -5
  467. package/dist/runtime/locale/ka.js +5 -5
  468. package/dist/runtime/locale/kk.js +3 -3
  469. package/dist/runtime/locale/km.js +5 -5
  470. package/dist/runtime/locale/ko.js +5 -5
  471. package/dist/runtime/locale/ky.js +4 -4
  472. package/dist/runtime/locale/lb.js +4 -4
  473. package/dist/runtime/locale/lt.js +5 -5
  474. package/dist/runtime/locale/mn.js +5 -5
  475. package/dist/runtime/locale/ms.js +5 -5
  476. package/dist/runtime/locale/nb_no.js +5 -5
  477. package/dist/runtime/locale/nl.js +5 -5
  478. package/dist/runtime/locale/pl.js +5 -5
  479. package/dist/runtime/locale/pt.js +5 -5
  480. package/dist/runtime/locale/pt_br.js +5 -5
  481. package/dist/runtime/locale/ro.js +5 -5
  482. package/dist/runtime/locale/ru.js +5 -5
  483. package/dist/runtime/locale/sk.js +5 -5
  484. package/dist/runtime/locale/sl.js +5 -5
  485. package/dist/runtime/locale/sv.js +5 -5
  486. package/dist/runtime/locale/th.js +5 -5
  487. package/dist/runtime/locale/tj.js +3 -3
  488. package/dist/runtime/locale/tr.js +5 -5
  489. package/dist/runtime/locale/ug_cn.js +3 -3
  490. package/dist/runtime/locale/uk.js +5 -5
  491. package/dist/runtime/locale/ur.js +4 -4
  492. package/dist/runtime/locale/uz.js +5 -5
  493. package/dist/runtime/locale/vi.js +5 -5
  494. package/dist/runtime/locale/zh_cn.js +5 -5
  495. package/dist/runtime/locale/zh_tw.js +5 -5
  496. package/dist/runtime/types/index.d.ts +2 -1
  497. package/dist/runtime/types/index.js +2 -1
  498. package/dist/runtime/types/tv.d.ts +6 -0
  499. package/dist/runtime/vue/components/Icon.d.vue.ts +2 -1
  500. package/dist/runtime/vue/components/Icon.vue.d.ts +2 -1
  501. package/dist/runtime/vue/components/Link.d.vue.ts +3 -2
  502. package/dist/runtime/vue/components/Link.vue.d.ts +3 -2
  503. package/dist/runtime/vue/components/color-mode/ColorModeButton.d.vue.ts +2 -1
  504. package/dist/runtime/vue/components/color-mode/ColorModeButton.vue.d.ts +2 -1
  505. package/dist/runtime/vue/components/color-mode/ColorModeSelect.d.vue.ts +2 -1
  506. package/dist/runtime/vue/components/color-mode/ColorModeSelect.vue.d.ts +2 -1
  507. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.d.vue.ts +2 -1
  508. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.vue.d.ts +2 -1
  509. package/dist/runtime/vue/stubs.d.ts +1 -1
  510. package/dist/runtime/vue/stubs.js +2 -2
  511. package/dist/shared/{ui.BBlr3wu_.mjs → ui.Dy8dMbVj.mjs} +489 -114
  512. package/dist/unplugin.mjs +11 -3
  513. package/dist/vite.mjs +3 -2
  514. package/package.json +23 -21
@@ -3,10 +3,10 @@ import theme from "#build/ui/command-palette";
3
3
  </script>
4
4
 
5
5
  <script setup>
6
- import { computed, ref, useTemplateRef } from "vue";
7
- import { ListboxRoot, ListboxFilter, ListboxContent, ListboxGroup, ListboxGroupLabel, ListboxItem, ListboxItemIndicator, useForwardProps, useForwardPropsEmits } from "reka-ui";
6
+ import { computed, ref, useTemplateRef, toRef } from "vue";
7
+ import { ListboxRoot, ListboxFilter, ListboxContent, ListboxGroup, ListboxGroupLabel, ListboxVirtualizer, ListboxItem, ListboxItemIndicator, useForwardProps, useForwardPropsEmits } from "reka-ui";
8
8
  import { defu } from "defu";
9
- import { reactivePick } from "@vueuse/core";
9
+ import { reactivePick, createReusableTemplate } from "@vueuse/core";
10
10
  import { useFuse } from "@vueuse/integrations/useFuse";
11
11
  import { useAppConfig } from "#imports";
12
12
  import { useLocale } from "../composables/useLocale";
@@ -25,8 +25,9 @@ import UKbd from "./Kbd.vue";
25
25
  const props = defineProps({
26
26
  as: { type: null, required: false },
27
27
  icon: { type: [String, Object], required: false },
28
- selectedIcon: { type: [String, Object], required: false },
29
28
  trailingIcon: { type: [String, Object], required: false },
29
+ selectedIcon: { type: [String, Object], required: false },
30
+ childrenIcon: { type: [String, Object], required: false },
30
31
  placeholder: { type: String, required: false },
31
32
  autofocus: { type: Boolean, required: false, default: true },
32
33
  close: { type: [Boolean, Object], required: false },
@@ -35,14 +36,17 @@ const props = defineProps({
35
36
  backIcon: { type: [String, Object], required: false },
36
37
  groups: { type: Array, required: false },
37
38
  fuse: { type: Object, required: false },
39
+ virtualize: { type: [Boolean, Object], required: false, default: false },
38
40
  labelKey: { type: null, required: false, default: "label" },
41
+ descriptionKey: { type: null, required: false, default: "description" },
42
+ preserveGroupOrder: { type: Boolean, required: false, default: false },
39
43
  class: { type: null, required: false },
40
44
  ui: { type: null, required: false },
41
45
  multiple: { type: Boolean, required: false },
42
46
  disabled: { type: Boolean, required: false },
43
47
  modelValue: { type: null, required: false, default: "" },
44
48
  defaultValue: { type: null, required: false },
45
- highlightOnHover: { type: Boolean, required: false },
49
+ highlightOnHover: { type: Boolean, required: false, default: true },
46
50
  selectionBehavior: { type: String, required: false },
47
51
  loading: { type: Boolean, required: false },
48
52
  loadingIcon: { type: [String, Object], required: false }
@@ -54,7 +58,26 @@ const { t } = useLocale();
54
58
  const appConfig = useAppConfig();
55
59
  const rootProps = useForwardPropsEmits(reactivePick(props, "as", "disabled", "multiple", "modelValue", "defaultValue", "highlightOnHover"), emits);
56
60
  const inputProps = useForwardProps(reactivePick(props, "loading"));
57
- const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.commandPalette || {} })());
61
+ const virtualizerProps = toRef(() => !!props.virtualize && defu(typeof props.virtualize === "boolean" ? {} : props.virtualize, { estimateSize: 32 }));
62
+ const [DefineItemTemplate, ReuseItemTemplate] = createReusableTemplate({
63
+ props: {
64
+ item: {
65
+ type: Object,
66
+ required: true
67
+ },
68
+ group: {
69
+ type: Object,
70
+ required: false
71
+ },
72
+ index: {
73
+ type: Number,
74
+ required: false
75
+ }
76
+ }
77
+ });
78
+ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.commandPalette || {} })({
79
+ virtualize: !!props.virtualize
80
+ }));
58
81
  const fuse = computed(() => defu({}, props.fuse, {
59
82
  fuseOptions: {
60
83
  ignoreLocation: true,
@@ -103,6 +126,19 @@ const filteredGroups = computed(() => {
103
126
  acc[item.group]?.push({ ...item, matches });
104
127
  return acc;
105
128
  }, {});
129
+ if (props.preserveGroupOrder) {
130
+ const processedGroups = [];
131
+ for (const group of groups.value || []) {
132
+ if (!group.items?.length) {
133
+ continue;
134
+ }
135
+ const items2 = group.ignoreFilter ? group.items : groupsById[group.id];
136
+ if (items2?.length) {
137
+ processedGroups.push(getGroupWithItems(group, items2));
138
+ }
139
+ }
140
+ return processedGroups;
141
+ }
106
142
  const fuseGroups = Object.entries(groupsById).map(([id, items2]) => {
107
143
  const group = groups.value?.find((group2) => group2.id === id);
108
144
  if (!group) {
@@ -116,6 +152,7 @@ const filteredGroups = computed(() => {
116
152
  return acc;
117
153
  }, [...fuseGroups]);
118
154
  });
155
+ const filteredItems = computed(() => filteredGroups.value.flatMap((group) => group.items || []));
119
156
  const listboxRootRef = useTemplateRef("listboxRootRef");
120
157
  function navigate(item) {
121
158
  if (!item.children?.length) {
@@ -155,6 +192,73 @@ function onSelect(e, item) {
155
192
  </script>
156
193
 
157
194
  <template>
195
+ <DefineItemTemplate v-slot="{ item, index, group }">
196
+ <ListboxItem
197
+ :value="omit(item, ['matches', 'group', 'onSelect', 'labelHtml', 'suffixHtml', 'children'])"
198
+ :disabled="item.disabled"
199
+ as-child
200
+ @select="onSelect($event, item)"
201
+ >
202
+ <ULink v-slot="{ active, ...slotProps }" v-bind="pickLinkProps(item)" custom>
203
+ <ULinkBase v-bind="slotProps" :class="ui.item({ class: [props.ui?.item, item.ui?.item, item.class], active: active || item.active })">
204
+ <slot :name="item.slot || group?.slot || 'item'" :item="item" :index="index" :ui="ui">
205
+ <slot :name="item.slot ? `${item.slot}-leading` : group?.slot ? `${group.slot}-leading` : `item-leading`" :item="item" :index="index" :ui="ui">
206
+ <UIcon v-if="item.loading" :name="loadingIcon || appConfig.ui.icons.loading" :class="ui.itemLeadingIcon({ class: [props.ui?.itemLeadingIcon, item.ui?.itemLeadingIcon], loading: true })" />
207
+ <UIcon v-else-if="item.icon" :name="item.icon" :class="ui.itemLeadingIcon({ class: [props.ui?.itemLeadingIcon, item.ui?.itemLeadingIcon], active: active || item.active })" />
208
+ <UAvatar v-else-if="item.avatar" :size="item.ui?.itemLeadingAvatarSize || props.ui?.itemLeadingAvatarSize || ui.itemLeadingAvatarSize()" v-bind="item.avatar" :class="ui.itemLeadingAvatar({ class: [props.ui?.itemLeadingAvatar, item.ui?.itemLeadingAvatar], active: active || item.active })" />
209
+ <UChip
210
+ v-else-if="item.chip"
211
+ :size="item.ui?.itemLeadingChipSize || props.ui?.itemLeadingChipSize || ui.itemLeadingChipSize()"
212
+ inset
213
+ standalone
214
+ v-bind="item.chip"
215
+ :class="ui.itemLeadingChip({ class: [props.ui?.itemLeadingChip, item.ui?.itemLeadingChip], active: active || item.active })"
216
+ />
217
+ </slot>
218
+
219
+ <span v-if="item.prefix || (item.labelHtml || get(item, props.labelKey)) || (item.suffixHtml || item.suffix) || !!slots[item.slot ? `${item.slot}-label` : group?.slot ? `${group.slot}-label` : `item-label`] || (get(item, props.descriptionKey) || !!slots[item.slot ? `${item.slot}-description` : group?.slot ? `${group.slot}-description` : `item-description`])" :class="ui.itemWrapper({ class: [props.ui?.itemWrapper, item.ui?.itemWrapper] })">
220
+ <span :class="ui.itemLabel({ class: [props.ui?.itemLabel, item.ui?.itemLabel], active: active || item.active })">
221
+ <slot :name="item.slot ? `${item.slot}-label` : group?.slot ? `${group.slot}-label` : `item-label`" :item="item" :index="index" :ui="ui">
222
+ <span v-if="item.prefix" :class="ui.itemLabelPrefix({ class: [props.ui?.itemLabelPrefix, item.ui?.itemLabelPrefix] })">{{ item.prefix }}</span>
223
+
224
+ <span :class="ui.itemLabelBase({ class: [props.ui?.itemLabelBase, item.ui?.itemLabelBase], active: active || item.active })" v-html="item.labelHtml || get(item, props.labelKey)" />
225
+
226
+ <span :class="ui.itemLabelSuffix({ class: [props.ui?.itemLabelSuffix, item.ui?.itemLabelSuffix], active: active || item.active })" v-html="item.suffixHtml || item.suffix" />
227
+ </slot>
228
+ </span>
229
+
230
+ <span v-if="get(item, props.descriptionKey)" :class="ui.itemDescription({ class: [props.ui?.itemDescription, item.ui?.itemDescription] })">
231
+ <slot :name="item.slot ? `${item.slot}-description` : group?.slot ? `${group.slot}-description` : `item-description`" :item="item" :index="index" :ui="ui">
232
+ {{ get(item, props.descriptionKey) }}
233
+ </slot>
234
+ </span>
235
+ </span>
236
+
237
+ <span :class="ui.itemTrailing({ class: [props.ui?.itemTrailing, item.ui?.itemTrailing] })">
238
+ <slot :name="item.slot ? `${item.slot}-trailing` : group?.slot ? `${group.slot}-trailing` : `item-trailing`" :item="item" :index="index" :ui="ui">
239
+ <UIcon
240
+ v-if="item.children && item.children.length > 0"
241
+ :name="childrenIcon || appConfig.ui.icons.chevronRight"
242
+ :class="ui.itemTrailingIcon({ class: [props.ui?.itemTrailingIcon, item.ui?.itemTrailingIcon] })"
243
+ />
244
+
245
+ <span v-else-if="item.kbds?.length" :class="ui.itemTrailingKbds({ class: [props.ui?.itemTrailingKbds, item.ui?.itemTrailingKbds] })">
246
+ <UKbd v-for="(kbd, kbdIndex) in item.kbds" :key="kbdIndex" :size="item.ui?.itemTrailingKbdsSize || props.ui?.itemTrailingKbdsSize || ui.itemTrailingKbdsSize()" v-bind="typeof kbd === 'string' ? { value: kbd } : kbd" />
247
+ </span>
248
+
249
+ <UIcon v-else-if="group?.highlightedIcon" :name="group.highlightedIcon" :class="ui.itemTrailingHighlightedIcon({ class: [props.ui?.itemTrailingHighlightedIcon, item.ui?.itemTrailingHighlightedIcon] })" />
250
+ </slot>
251
+
252
+ <ListboxItemIndicator v-if="!item.children?.length" as-child>
253
+ <UIcon :name="selectedIcon || appConfig.ui.icons.check" :class="ui.itemTrailingIcon({ class: [props.ui?.itemTrailingIcon, item.ui?.itemTrailingIcon] })" />
254
+ </ListboxItemIndicator>
255
+ </span>
256
+ </slot>
257
+ </ULinkBase>
258
+ </ULink>
259
+ </ListboxItem>
260
+ </DefineItemTemplate>
261
+
158
262
  <ListboxRoot v-bind="rootProps" ref="listboxRootRef" :selection-behavior="selectionBehavior" :class="ui.root({ class: [props.ui?.root, props.class] })">
159
263
  <ListboxFilter v-model="searchTerm" as-child>
160
264
  <UInput
@@ -163,6 +267,7 @@ function onSelect(e, item) {
163
267
  :autofocus="autofocus"
164
268
  v-bind="inputProps"
165
269
  :loading-icon="loadingIcon"
270
+ :trailing-icon="trailingIcon"
166
271
  :icon="icon || appConfig.ui.icons.search"
167
272
  :class="ui.input({ class: props.ui?.input })"
168
273
  @keydown.backspace="onBackspace"
@@ -200,70 +305,31 @@ function onSelect(e, item) {
200
305
 
201
306
  <ListboxContent :class="ui.content({ class: props.ui?.content })">
202
307
  <div v-if="filteredGroups?.length" role="presentation" :class="ui.viewport({ class: props.ui?.viewport })">
203
- <ListboxGroup v-for="group in filteredGroups" :key="`group-${group.id}`" :class="ui.group({ class: props.ui?.group })">
204
- <ListboxGroupLabel v-if="get(group, props.labelKey)" :class="ui.label({ class: props.ui?.label })">
205
- {{ get(group, props.labelKey) }}
206
- </ListboxGroupLabel>
207
-
208
- <ListboxItem
209
- v-for="(item, index) in group.items"
210
- :key="`group-${group.id}-${index}`"
211
- :value="omit(item, ['matches', 'group', 'onSelect', 'labelHtml', 'suffixHtml', 'children'])"
212
- :disabled="item.disabled"
213
- as-child
214
- @select="onSelect($event, item)"
215
- >
216
- <ULink v-slot="{ active, ...slotProps }" v-bind="pickLinkProps(item)" custom>
217
- <ULinkBase v-bind="slotProps" :class="ui.item({ class: [props.ui?.item, item.ui?.item, item.class], active: active || item.active })">
218
- <slot :name="item.slot || group.slot || 'item'" :item="item" :index="index">
219
- <slot :name="item.slot ? `${item.slot}-leading` : group.slot ? `${group.slot}-leading` : `item-leading`" :item="item" :index="index">
220
- <UIcon v-if="item.loading" :name="loadingIcon || appConfig.ui.icons.loading" :class="ui.itemLeadingIcon({ class: [props.ui?.itemLeadingIcon, item.ui?.itemLeadingIcon], loading: true })" />
221
- <UIcon v-else-if="item.icon" :name="item.icon" :class="ui.itemLeadingIcon({ class: [props.ui?.itemLeadingIcon, item.ui?.itemLeadingIcon], active: active || item.active })" />
222
- <UAvatar v-else-if="item.avatar" :size="item.ui?.itemLeadingAvatarSize || props.ui?.itemLeadingAvatarSize || ui.itemLeadingAvatarSize()" v-bind="item.avatar" :class="ui.itemLeadingAvatar({ class: [props.ui?.itemLeadingAvatar, item.ui?.itemLeadingAvatar], active: active || item.active })" />
223
- <UChip
224
- v-else-if="item.chip"
225
- :size="item.ui?.itemLeadingChipSize || props.ui?.itemLeadingChipSize || ui.itemLeadingChipSize()"
226
- inset
227
- standalone
228
- v-bind="item.chip"
229
- :class="ui.itemLeadingChip({ class: [props.ui?.itemLeadingChip, item.ui?.itemLeadingChip], active: active || item.active })"
230
- />
231
- </slot>
232
-
233
- <span v-if="item.labelHtml || get(item, props.labelKey) || !!slots[item.slot ? `${item.slot}-label` : group.slot ? `${group.slot}-label` : `item-label`]" :class="ui.itemLabel({ class: [props.ui?.itemLabel, item.ui?.itemLabel], active: active || item.active })">
234
- <slot :name="item.slot ? `${item.slot}-label` : group.slot ? `${group.slot}-label` : `item-label`" :item="item" :index="index">
235
- <span v-if="item.prefix" :class="ui.itemLabelPrefix({ class: [props.ui?.itemLabelPrefix, item.ui?.itemLabelPrefix] })">{{ item.prefix }}</span>
308
+ <ListboxVirtualizer
309
+ v-if="!!virtualize"
310
+ v-slot="{ option: item, virtualItem }"
311
+ :options="filteredItems"
312
+ :text-content="(item2) => get(item2, props.labelKey)"
313
+ v-bind="virtualizerProps"
314
+ >
315
+ <ReuseItemTemplate :item="item" :index="virtualItem.index" />
316
+ </ListboxVirtualizer>
236
317
 
237
- <span :class="ui.itemLabelBase({ class: [props.ui?.itemLabelBase, item.ui?.itemLabelBase], active: active || item.active })" v-html="item.labelHtml || get(item, props.labelKey)" />
318
+ <template v-else>
319
+ <ListboxGroup v-for="group in filteredGroups" :key="`group-${group.id}`" :class="ui.group({ class: props.ui?.group })">
320
+ <ListboxGroupLabel v-if="get(group, props.labelKey)" :class="ui.label({ class: props.ui?.label })">
321
+ {{ get(group, props.labelKey) }}
322
+ </ListboxGroupLabel>
238
323
 
239
- <span :class="ui.itemLabelSuffix({ class: [props.ui?.itemLabelSuffix, item.ui?.itemLabelSuffix], active: active || item.active })" v-html="item.suffixHtml || item.suffix" />
240
- </slot>
241
- </span>
242
-
243
- <span :class="ui.itemTrailing({ class: [props.ui?.itemTrailing, item.ui?.itemTrailing] })">
244
- <slot :name="item.slot ? `${item.slot}-trailing` : group.slot ? `${group.slot}-trailing` : `item-trailing`" :item="item" :index="index">
245
- <UIcon
246
- v-if="item.children && item.children.length > 0"
247
- :name="trailingIcon || appConfig.ui.icons.chevronRight"
248
- :class="ui.itemTrailingIcon({ class: [props.ui?.itemTrailingIcon, item.ui?.itemTrailingIcon] })"
249
- />
250
-
251
- <span v-else-if="item.kbds?.length" :class="ui.itemTrailingKbds({ class: [props.ui?.itemTrailingKbds, item.ui?.itemTrailingKbds] })">
252
- <UKbd v-for="(kbd, kbdIndex) in item.kbds" :key="kbdIndex" :size="item.ui?.itemTrailingKbdsSize || props.ui?.itemTrailingKbdsSize || ui.itemTrailingKbdsSize()" v-bind="typeof kbd === 'string' ? { value: kbd } : kbd" />
253
- </span>
254
-
255
- <UIcon v-else-if="group.highlightedIcon" :name="group.highlightedIcon" :class="ui.itemTrailingHighlightedIcon({ class: [props.ui?.itemTrailingHighlightedIcon, item.ui?.itemTrailingHighlightedIcon] })" />
256
- </slot>
257
-
258
- <ListboxItemIndicator v-if="!item.children?.length" as-child>
259
- <UIcon :name="selectedIcon || appConfig.ui.icons.check" :class="ui.itemTrailingIcon({ class: [props.ui?.itemTrailingIcon, item.ui?.itemTrailingIcon] })" />
260
- </ListboxItemIndicator>
261
- </span>
262
- </slot>
263
- </ULinkBase>
264
- </ULink>
265
- </ListboxItem>
266
- </ListboxGroup>
324
+ <ReuseItemTemplate
325
+ v-for="(item, index) in group.items"
326
+ :key="`group-${group.id}-${index}`"
327
+ :item="item"
328
+ :index="index"
329
+ :group="group"
330
+ />
331
+ </ListboxGroup>
332
+ </template>
267
333
  </div>
268
334
 
269
335
  <div v-else :class="ui.empty({ class: props.ui?.empty })">
@@ -11,6 +11,7 @@ export interface CommandPaletteItem extends Omit<LinkProps, 'type' | 'raw' | 'cu
11
11
  prefix?: string;
12
12
  label?: string;
13
13
  suffix?: string;
14
+ description?: string;
14
15
  /**
15
16
  * @IconifyIcon
16
17
  */
@@ -27,9 +28,9 @@ export interface CommandPaletteItem extends Omit<LinkProps, 'type' | 'raw' | 'cu
27
28
  */
28
29
  placeholder?: string;
29
30
  children?: CommandPaletteItem[];
30
- onSelect?(e?: Event): void;
31
+ onSelect?: (e: Event) => void;
31
32
  class?: any;
32
- ui?: Pick<CommandPalette['slots'], 'item' | 'itemLeadingIcon' | 'itemLeadingAvatarSize' | 'itemLeadingAvatar' | 'itemLeadingChipSize' | 'itemLeadingChip' | 'itemLabel' | 'itemLabelPrefix' | 'itemLabelBase' | 'itemLabelSuffix' | 'itemTrailing' | 'itemTrailingKbds' | 'itemTrailingKbdsSize' | 'itemTrailingHighlightedIcon' | 'itemTrailingIcon'>;
33
+ ui?: Pick<CommandPalette['slots'], 'item' | 'itemLeadingIcon' | 'itemLeadingAvatarSize' | 'itemLeadingAvatar' | 'itemLeadingChipSize' | 'itemLeadingChip' | 'itemWrapper' | 'itemLabel' | 'itemDescription' | 'itemLabelPrefix' | 'itemLabelBase' | 'itemLabelSuffix' | 'itemTrailing' | 'itemTrailingKbds' | 'itemTrailingKbdsSize' | 'itemTrailingHighlightedIcon' | 'itemTrailingIcon'>;
33
34
  [key: string]: any;
34
35
  }
35
36
  export interface CommandPaletteGroup<T extends CommandPaletteItem = CommandPaletteItem> {
@@ -63,6 +64,12 @@ export interface CommandPaletteProps<G extends CommandPaletteGroup<T> = CommandP
63
64
  * @IconifyIcon
64
65
  */
65
66
  icon?: IconProps['name'];
67
+ /**
68
+ * The icon displayed on the right side of the input.
69
+ * @defaultValue appConfig.ui.icons.search
70
+ * @IconifyIcon
71
+ */
72
+ trailingIcon?: IconProps['name'];
66
73
  /**
67
74
  * The icon displayed when an item is selected.
68
75
  * @defaultValue appConfig.ui.icons.check
@@ -74,7 +81,7 @@ export interface CommandPaletteProps<G extends CommandPaletteGroup<T> = CommandP
74
81
  * @defaultValue appConfig.ui.icons.chevronRight
75
82
  * @IconifyIcon
76
83
  */
77
- trailingIcon?: IconProps['name'];
84
+ childrenIcon?: IconProps['name'];
78
85
  /**
79
86
  * The placeholder text for the input.
80
87
  * @defaultValue t('commandPalette.placeholder')
@@ -124,11 +131,39 @@ export interface CommandPaletteProps<G extends CommandPaletteGroup<T> = CommandP
124
131
  }
125
132
  */
126
133
  fuse?: UseFuseOptions<T>;
134
+ /**
135
+ * Enable virtualization for large lists.
136
+ * Note: when enabled, all groups are flattened into a single list due to a limitation of Reka UI (https://github.com/unovue/reka-ui/issues/1885).
137
+ * @defaultValue false
138
+ */
139
+ virtualize?: boolean | {
140
+ /**
141
+ * Number of items rendered outside the visible area
142
+ * @defaultValue 12
143
+ */
144
+ overscan?: number;
145
+ /**
146
+ * Estimated size (in px) of each item
147
+ * @defaultValue 32
148
+ */
149
+ estimateSize?: number;
150
+ };
127
151
  /**
128
152
  * The key used to get the label from the item.
129
153
  * @defaultValue 'label'
130
154
  */
131
155
  labelKey?: GetItemKeys<T>;
156
+ /**
157
+ * The key used to get the description from the item.
158
+ * @defaultValue 'description'
159
+ */
160
+ descriptionKey?: GetItemKeys<T>;
161
+ /**
162
+ * Whether to preserve the order of groups as defined in the `groups` prop when filtering.
163
+ * When `false`, groups will appear based on item matches.
164
+ * @defaultValue false
165
+ */
166
+ preserveGroupOrder?: boolean;
132
167
  class?: any;
133
168
  ui?: CommandPalette['slots'];
134
169
  }
@@ -138,46 +173,35 @@ export type CommandPaletteEmits<T extends CommandPaletteItem = CommandPaletteIte
138
173
  type SlotProps<T> = (props: {
139
174
  item: T;
140
175
  index: number;
176
+ ui: CommandPalette['ui'];
141
177
  }) => any;
142
178
  export type CommandPaletteSlots<G extends CommandPaletteGroup<T> = CommandPaletteGroup<any>, T extends CommandPaletteItem = CommandPaletteItem> = {
143
179
  'empty'(props: {
144
180
  searchTerm?: string;
145
181
  }): any;
146
182
  'footer'(props: {
147
- ui: {
148
- [K in keyof Required<CommandPalette['slots']>]: (props?: Record<string, any>) => string;
149
- };
183
+ ui: CommandPalette['ui'];
150
184
  }): any;
151
185
  'back'(props: {
152
- ui: {
153
- [K in keyof Required<CommandPalette['slots']>]: (props?: Record<string, any>) => string;
154
- };
186
+ ui: CommandPalette['ui'];
155
187
  }): any;
156
188
  'close'(props: {
157
- ui: {
158
- [K in keyof Required<CommandPalette['slots']>]: (props?: Record<string, any>) => string;
159
- };
189
+ ui: CommandPalette['ui'];
160
190
  }): any;
161
191
  'item': SlotProps<T>;
162
192
  'item-leading': SlotProps<T>;
163
193
  'item-label': SlotProps<T>;
194
+ 'item-description': SlotProps<T>;
164
195
  'item-trailing': SlotProps<T>;
165
196
  } & Record<string, SlotProps<G>> & Record<string, SlotProps<T>>;
166
- declare const _default: <G extends CommandPaletteGroup<T>, T extends CommandPaletteItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
167
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
168
- readonly "onUpdate:open"?: ((value: boolean) => any) | undefined;
169
- readonly "onUpdate:modelValue"?: ((value: T) => any) | undefined;
170
- readonly onHighlight?: ((payload: {
171
- ref: HTMLElement;
172
- value: T;
173
- } | undefined) => any) | undefined;
174
- readonly "onUpdate:searchTerm"?: ((value: string) => any) | undefined;
175
- readonly onEntryFocus?: ((event: CustomEvent<any>) => any) | undefined;
176
- readonly onLeave?: ((event: Event) => any) | undefined;
177
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:open" | "onUpdate:modelValue" | "onHighlight" | "onUpdate:searchTerm" | "onEntryFocus" | "onLeave"> & (CommandPaletteProps<G, T> & {
197
+ declare const __VLS_export: <G extends CommandPaletteGroup<T>, T extends CommandPaletteItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
198
+ props: __VLS_PrettifyLocal<(CommandPaletteProps<G, T> & {
178
199
  searchTerm?: string;
179
- }) & {}> & import("vue").PublicProps;
180
- expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
200
+ }) & __VLS_EmitsToProps<__VLS_NormalizeEmits<((evt: "update:open", value: boolean) => void) & ((evt: "update:modelValue", value: T) => void) & ((evt: "highlight", payload: {
201
+ ref: HTMLElement;
202
+ value: T;
203
+ } | undefined) => void) & ((evt: "entryFocus", event: CustomEvent<any>) => void) & ((evt: "leave", event: Event) => void) & ((evt: "update:searchTerm", value: string) => void)>>> & import("vue").PublicProps;
204
+ expose: (exposed: {}) => void;
181
205
  attrs: any;
182
206
  slots: CommandPaletteSlots<G, T>;
183
207
  emit: (((evt: "update:open", value: boolean) => void) & ((evt: "update:modelValue", value: T) => void) & ((evt: "highlight", payload: {
@@ -187,6 +211,7 @@ declare const _default: <G extends CommandPaletteGroup<T>, T extends CommandPale
187
211
  }>) => import("vue").VNode & {
188
212
  __ctx?: Awaited<typeof __VLS_setup>;
189
213
  };
214
+ declare const _default: typeof __VLS_export;
190
215
  export default _default;
191
216
  type __VLS_PrettifyLocal<T> = {
192
217
  [K in keyof T as K]: T[K];
@@ -9,7 +9,8 @@ export interface ContainerProps {
9
9
  export interface ContainerSlots {
10
10
  default(props?: {}): any;
11
11
  }
12
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ContainerProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ContainerProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ContainerSlots>;
12
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<ContainerProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ContainerProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ContainerSlots>;
13
+ declare const _default: typeof __VLS_export;
13
14
  export default _default;
14
15
  type __VLS_WithSlots<T, S> = T & {
15
16
  new (): {
@@ -9,7 +9,8 @@ export interface ContainerProps {
9
9
  export interface ContainerSlots {
10
10
  default(props?: {}): any;
11
11
  }
12
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ContainerProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ContainerProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ContainerSlots>;
12
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<ContainerProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ContainerProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ContainerSlots>;
13
+ declare const _default: typeof __VLS_export;
13
14
  export default _default;
14
15
  type __VLS_WithSlots<T, S> = T & {
15
16
  new (): {
@@ -7,13 +7,16 @@ import type { ComponentConfig } from '../types/tv';
7
7
  type ContextMenu = ComponentConfig<typeof theme, AppConfig, 'contextMenu'>;
8
8
  export interface ContextMenuItem extends Omit<LinkProps, 'type' | 'raw' | 'custom'> {
9
9
  label?: string;
10
+ description?: string;
10
11
  /**
11
12
  * @IconifyIcon
12
13
  */
13
14
  icon?: IconProps['name'];
14
15
  color?: ContextMenu['variants']['color'];
15
16
  avatar?: AvatarProps;
16
- content?: Omit<ContextMenuContentProps, 'as' | 'asChild' | 'forceMount'> & Partial<EmitsToProps<ContextMenuContentEmits>>;
17
+ content?: Omit<ContextMenuContentProps, 'as' | 'asChild' | 'forceMount'> & {
18
+ class?: any;
19
+ } & Partial<EmitsToProps<ContextMenuContentEmits>>;
17
20
  kbds?: KbdProps['value'][] | KbdProps[];
18
21
  /**
19
22
  * The item type.
@@ -27,10 +30,10 @@ export interface ContextMenuItem extends Omit<LinkProps, 'type' | 'raw' | 'custo
27
30
  open?: boolean;
28
31
  defaultOpen?: boolean;
29
32
  children?: ArrayOrNested<ContextMenuItem>;
30
- onSelect?(e: Event): void;
31
- onUpdateChecked?(checked: boolean): void;
33
+ onSelect?: (e: Event) => void;
34
+ onUpdateChecked?: (checked: boolean) => void;
32
35
  class?: any;
33
- ui?: Pick<ContextMenu['slots'], 'item' | 'label' | 'separator' | 'itemLeadingIcon' | 'itemLeadingAvatarSize' | 'itemLeadingAvatar' | 'itemLabel' | 'itemLabelExternalIcon' | 'itemTrailing' | 'itemTrailingIcon' | 'itemTrailingKbds' | 'itemTrailingKbdsSize'>;
36
+ ui?: Pick<ContextMenu['slots'], 'content' | 'item' | 'label' | 'separator' | 'itemLeadingIcon' | 'itemLeadingAvatarSize' | 'itemLeadingAvatar' | 'itemWrapper' | 'itemLabel' | 'itemDescription' | 'itemLabelExternalIcon' | 'itemTrailing' | 'itemTrailingIcon' | 'itemTrailingKbds' | 'itemTrailingKbdsSize'>;
34
37
  [key: string]: any;
35
38
  }
36
39
  export interface ContextMenuProps<T extends ArrayOrNested<ContextMenuItem> = ArrayOrNested<ContextMenuItem>> extends Omit<ContextMenuRootProps, 'dir'> {
@@ -70,6 +73,11 @@ export interface ContextMenuProps<T extends ArrayOrNested<ContextMenuItem> = Arr
70
73
  * @defaultValue 'label'
71
74
  */
72
75
  labelKey?: GetItemKeys<T>;
76
+ /**
77
+ * The key used to get the description from the item.
78
+ * @defaultValue 'description'
79
+ */
80
+ descriptionKey?: GetItemKeys<T>;
73
81
  disabled?: boolean;
74
82
  class?: any;
75
83
  ui?: ContextMenu['slots'];
@@ -80,30 +88,43 @@ type SlotProps<T extends ContextMenuItem> = (props: {
80
88
  item: T;
81
89
  active?: boolean;
82
90
  index: number;
91
+ ui: ContextMenu['ui'];
83
92
  }) => any;
84
93
  export type ContextMenuSlots<A extends ArrayOrNested<ContextMenuItem> = ArrayOrNested<ContextMenuItem>, T extends NestedItem<A> = NestedItem<A>> = {
85
94
  'default'(props?: {}): any;
86
95
  'item': SlotProps<T>;
87
96
  'item-leading': SlotProps<T>;
88
- 'item-label': SlotProps<T>;
97
+ 'item-label': (props: {
98
+ item: T;
99
+ active?: boolean;
100
+ index: number;
101
+ }) => any;
102
+ 'item-description': (props: {
103
+ item: T;
104
+ active?: boolean;
105
+ index: number;
106
+ }) => any;
89
107
  'item-trailing': SlotProps<T>;
90
108
  'content-top': (props?: {}) => any;
91
109
  'content-bottom': (props?: {}) => any;
92
- } & DynamicSlots<MergeTypes<T>, 'leading' | 'label' | 'trailing', {
110
+ } & DynamicSlots<MergeTypes<T>, 'label' | 'description', {
111
+ active?: boolean;
112
+ index: number;
113
+ }> & DynamicSlots<MergeTypes<T>, 'leading' | 'trailing', {
93
114
  active?: boolean;
94
115
  index: number;
116
+ ui: ContextMenu['ui'];
95
117
  }>;
96
- declare const _default: <T extends ArrayOrNested<ContextMenuItem>>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
97
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
98
- readonly "onUpdate:open"?: ((payload: boolean) => any) | undefined;
99
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:open"> & ContextMenuProps<T> & {}> & import("vue").PublicProps;
100
- expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
118
+ declare const __VLS_export: <T extends ArrayOrNested<ContextMenuItem>>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
119
+ props: __VLS_PrettifyLocal<ContextMenuProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<(evt: "update:open", payload: boolean) => void>>> & import("vue").PublicProps;
120
+ expose: (exposed: {}) => void;
101
121
  attrs: any;
102
122
  slots: ContextMenuSlots<T, NestedItem<T>>;
103
123
  emit: (evt: "update:open", payload: boolean) => void;
104
124
  }>) => import("vue").VNode & {
105
125
  __ctx?: Awaited<typeof __VLS_setup>;
106
126
  };
127
+ declare const _default: typeof __VLS_export;
107
128
  export default _default;
108
129
  type __VLS_PrettifyLocal<T> = {
109
130
  [K in keyof T as K]: T[K];
@@ -19,6 +19,7 @@ const props = defineProps({
19
19
  content: { type: Object, required: false },
20
20
  portal: { type: [Boolean, String], required: false, skipCheck: true, default: true },
21
21
  labelKey: { type: null, required: false, default: "label" },
22
+ descriptionKey: { type: null, required: false, default: "description" },
22
23
  disabled: { type: Boolean, required: false },
23
24
  class: { type: null, required: false },
24
25
  ui: { type: null, required: false },
@@ -50,6 +51,7 @@ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.contextMenu |
50
51
  :items="items"
51
52
  :portal="portal"
52
53
  :label-key="labelKey"
54
+ :description-key="descriptionKey"
53
55
  :checked-icon="checkedIcon"
54
56
  :loading-icon="loadingIcon"
55
57
  :external-icon="externalIcon"