@eslamdevui/ui 4.0.0 → 4.1.1-rc.1

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 +101 -76
  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,9 +3,10 @@ import theme from "#build/ui/tree";
3
3
  </script>
4
4
 
5
5
  <script setup>
6
- import { computed } from "vue";
7
- import { TreeRoot, TreeItem, useForwardPropsEmits } from "reka-ui";
6
+ import { computed, toRef, ref } from "vue";
7
+ import { TreeRoot, TreeItem, TreeVirtualizer, useForwardPropsEmits } from "reka-ui";
8
8
  import { reactivePick, createReusableTemplate } from "@vueuse/core";
9
+ import { defu } from "defu";
9
10
  import { useAppConfig } from "#imports";
10
11
  import { get } from "../utils";
11
12
  import { tv } from "../utils/tv";
@@ -24,6 +25,10 @@ const props = defineProps({
24
25
  modelValue: { type: null, required: false },
25
26
  defaultValue: { type: null, required: false },
26
27
  multiple: { type: Boolean, required: false },
28
+ nested: { type: Boolean, required: false, default: true },
29
+ virtualize: { type: [Boolean, Object], required: false, default: false },
30
+ onSelect: { type: Function, required: false },
31
+ onToggle: { type: Function, required: false },
27
32
  class: { type: null, required: false },
28
33
  ui: { type: null, required: false },
29
34
  expanded: { type: Array, required: false },
@@ -36,12 +41,62 @@ const props = defineProps({
36
41
  const emits = defineEmits(["update:modelValue", "update:expanded"]);
37
42
  const slots = defineSlots();
38
43
  const appConfig = useAppConfig();
39
- const rootProps = useForwardPropsEmits(reactivePick(props, "as", "items", "multiple", "expanded", "disabled", "propagateSelect", "bubbleSelect"), emits);
44
+ const rootProps = useForwardPropsEmits(reactivePick(props, "items", "multiple", "expanded", "disabled", "propagateSelect", "bubbleSelect"), emits);
45
+ const as = computed(() => {
46
+ if (typeof props.as === "string" || typeof props.as?.render === "function") {
47
+ return { root: props.as, link: "button" };
48
+ }
49
+ return defu(props.as, { root: "ul", link: "button" });
50
+ });
51
+ const nested = computed(() => props.virtualize ? false : props.nested);
52
+ const flattenedPaddingFormula = computed(() => {
53
+ const sizeConfig = {
54
+ xs: { base: 2, perLevel: 5.5 },
55
+ // px-2, ms-4 + ps-1.5
56
+ sm: { base: 2.5, perLevel: 6 },
57
+ // px-2.5, ms-4.5 + ps-1.5
58
+ md: { base: 2.5, perLevel: 6.5 },
59
+ // px-2.5, ms-5 + ps-1.5
60
+ lg: { base: 3, perLevel: 7 },
61
+ // px-3, ms-5.5 + ps-1.5
62
+ xl: { base: 3, perLevel: 7.5 }
63
+ // px-3, ms-6 + ps-1.5
64
+ };
65
+ const config = sizeConfig[props.size || "md"];
66
+ return (level) => `calc(var(--spacing) * ${(level - 1) * config.perLevel + config.base})`;
67
+ });
68
+ const virtualizerProps = toRef(() => !!props.virtualize && defu(typeof props.virtualize === "boolean" ? {} : props.virtualize, {
69
+ estimateSize: {
70
+ xs: 24,
71
+ sm: 28,
72
+ md: 32,
73
+ lg: 36,
74
+ xl: 40
75
+ }[props.size || "md"]
76
+ }));
40
77
  const [DefineTreeTemplate, ReuseTreeTemplate] = createReusableTemplate();
78
+ const [DefineItemTemplate, ReuseItemTemplate] = createReusableTemplate({
79
+ props: {
80
+ item: {
81
+ type: Object,
82
+ required: true
83
+ },
84
+ index: {
85
+ type: Number,
86
+ required: true
87
+ },
88
+ level: {
89
+ type: Number,
90
+ required: true
91
+ }
92
+ }
93
+ });
41
94
  const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.tree || {} })({
42
95
  color: props.color,
43
- size: props.size
96
+ size: props.size,
97
+ virtualize: !!props.virtualize
44
98
  }));
99
+ const rootRef = ref();
45
100
  function getItemLabel(item) {
46
101
  return get(item, props.labelKey);
47
102
  }
@@ -53,106 +108,120 @@ function getDefaultOpenedItems(item) {
53
108
  const childItems = item.children?.flatMap((child) => getDefaultOpenedItems(child)) ?? [];
54
109
  return [currentItem, ...childItems].filter(Boolean);
55
110
  }
56
- const defaultExpanded = computed(
57
- () => props.defaultExpanded ?? props.items?.flatMap((item) => getDefaultOpenedItems(item))
58
- );
111
+ const defaultExpanded = computed(() => props.defaultExpanded ?? props.items?.flatMap((item) => getDefaultOpenedItems(item)));
112
+ defineExpose({
113
+ get $el() {
114
+ return rootRef.value?.$el;
115
+ }
116
+ });
59
117
  </script>
60
118
 
61
119
  <template>
62
- <DefineTreeTemplate v-slot="{ items, level }">
63
- <TreeItem
64
- v-for="(item, index) in items"
65
- :key="`${level}-${index}`"
66
- v-slot="{ isExpanded, isSelected }"
67
- :level="level"
68
- :value="item"
69
- :class="level > 1 ? ui.itemWithChildren({ class: [props.ui?.itemWithChildren, item.ui?.itemWithChildren] }) : ui.item({ class: [props.ui?.item, item.ui?.item] })"
70
- @toggle="item.onToggle"
71
- @select="item.onSelect"
120
+ <DefineItemTemplate v-slot="{ item, index, level }">
121
+ <li
122
+ role="presentation"
123
+ :class="!!nested && level > 1 ? ui.itemWithChildren({ class: [props.ui?.itemWithChildren, item.ui?.itemWithChildren] }) : ui.item({ class: [props.ui?.item, item.ui?.item] })"
72
124
  >
73
- <slot
74
- :name="item.slot ? `${item.slot}-wrapper` : 'item-wrapper'"
75
- v-bind="{ index, level, expanded: isExpanded, selected: isSelected }"
76
- :item="item"
125
+ <TreeItem
126
+ v-slot="{ isExpanded, isSelected, isIndeterminate, handleSelect, handleToggle }"
127
+ :level="level"
128
+ :value="item"
129
+ as-child
130
+ @toggle="(item.onToggle ?? props.onToggle)?.($event, item)"
131
+ @select="(item.onSelect ?? props.onSelect)?.($event, item)"
77
132
  >
78
- <button
79
- type="button"
80
- :disabled="item.disabled || disabled"
81
- :data-expanded="isExpanded"
82
- :class="ui.link({ class: [props.ui?.link, item.ui?.link, item.class], selected: isSelected, disabled: item.disabled || disabled })"
133
+ <slot
134
+ :name="item.slot ? `${item.slot}-wrapper` : 'item-wrapper'"
135
+ v-bind="{ index, level, expanded: isExpanded, selected: isSelected, indeterminate: isIndeterminate, handleSelect, handleToggle, ui }"
136
+ :item="item"
83
137
  >
84
- <slot
85
- :name="item.slot || 'item'"
86
- v-bind="{ index, level, expanded: isExpanded, selected: isSelected }"
87
- :item="item"
138
+ <component
139
+ :is="as.link"
140
+ :type="as.link === 'button' ? 'button' : void 0"
141
+ :disabled="item.disabled || disabled"
142
+ :class="ui.link({ class: [props.ui?.link, item.ui?.link, item.class], selected: isSelected, disabled: item.disabled || disabled })"
143
+ :style="!nested && level > 1 ? { paddingLeft: flattenedPaddingFormula(level) } : void 0"
88
144
  >
89
145
  <slot
90
- :name="item.slot ? `${item.slot}-leading` : 'item-leading'"
91
- v-bind="{ index, level, expanded: isExpanded, selected: isSelected }"
146
+ :name="item.slot || 'item'"
147
+ v-bind="{ index, level, expanded: isExpanded, selected: isSelected, indeterminate: isIndeterminate, handleSelect, handleToggle, ui }"
92
148
  :item="item"
93
- >
94
- <UIcon
95
- v-if="item.icon"
96
- :name="item.icon"
97
- :class="ui.linkLeadingIcon({ class: [props.ui?.linkLeadingIcon, item.ui?.linkLeadingIcon] })"
98
- />
99
- <UIcon
100
- v-else-if="item.children?.length"
101
- :name="isExpanded ? expandedIcon ?? appConfig.ui.icons.folderOpen : collapsedIcon ?? appConfig.ui.icons.folder"
102
- :class="ui.linkLeadingIcon({ class: [props.ui?.linkLeadingIcon, item.ui?.linkLeadingIcon] })"
103
- />
104
- </slot>
105
-
106
- <span
107
- v-if="getItemLabel(item) || !!slots[item.slot ? `${item.slot}-label` : 'item-label']"
108
- :class="ui.linkLabel({ class: [props.ui?.linkLabel, item.ui?.linkLabel] })"
109
149
  >
110
150
  <slot
111
- :name="item.slot ? `${item.slot}-label` : 'item-label'"
112
- v-bind="{ index, level, expanded: isExpanded, selected: isSelected }"
113
- :item="item"
114
- >
115
- {{ getItemLabel(item) }}
116
- </slot>
117
- </span>
118
-
119
- <span
120
- v-if="item.trailingIcon || item.children?.length || !!slots[item.slot ? `${item.slot}-trailing` : 'item-trailing']"
121
- :class="ui.linkTrailing({ class: [props.ui?.linkTrailing, item.ui?.linkTrailing] })"
122
- >
123
- <slot
124
- :name="item.slot ? `${item.slot}-trailing` : 'item-trailing'"
125
- v-bind="{ index, level, expanded: isExpanded, selected: isSelected }"
151
+ :name="item.slot ? `${item.slot}-leading` : 'item-leading'"
152
+ v-bind="{ index, level, expanded: isExpanded, selected: isSelected, indeterminate: isIndeterminate, handleSelect, handleToggle, ui }"
126
153
  :item="item"
127
154
  >
128
155
  <UIcon
129
- v-if="item.trailingIcon"
130
- :name="item.trailingIcon"
131
- :class="ui.linkTrailingIcon({ class: [props.ui?.linkTrailingIcon, item.ui?.linkTrailingIcon] })"
156
+ v-if="item.icon"
157
+ :name="item.icon"
158
+ :class="ui.linkLeadingIcon({ class: [props.ui?.linkLeadingIcon, item.ui?.linkLeadingIcon] })"
132
159
  />
133
160
  <UIcon
134
161
  v-else-if="item.children?.length"
135
- :name="trailingIcon ?? appConfig.ui.icons.chevronDown"
136
- :class="ui.linkTrailingIcon({ class: [props.ui?.linkTrailingIcon, item.ui?.linkTrailingIcon] })"
162
+ :name="isExpanded ? expandedIcon ?? appConfig.ui.icons.folderOpen : collapsedIcon ?? appConfig.ui.icons.folder"
163
+ :class="ui.linkLeadingIcon({ class: [props.ui?.linkLeadingIcon, item.ui?.linkLeadingIcon] })"
137
164
  />
138
165
  </slot>
139
- </span>
140
- </slot>
141
- </button>
142
- </slot>
143
166
 
144
- <ul
145
- v-if="item.children?.length && isExpanded"
146
- role="group"
147
- :class="ui.listWithChildren({ class: [props.ui?.listWithChildren, item.ui?.listWithChildren] })"
148
- >
149
- <ReuseTreeTemplate :items="item.children" :level="level + 1" />
150
- </ul>
151
- </TreeItem>
167
+ <span
168
+ v-if="getItemLabel(item) || !!slots[item.slot ? `${item.slot}-label` : 'item-label']"
169
+ :class="ui.linkLabel({ class: [props.ui?.linkLabel, item.ui?.linkLabel] })"
170
+ >
171
+ <slot
172
+ :name="item.slot ? `${item.slot}-label` : 'item-label'"
173
+ v-bind="{ index, level, expanded: isExpanded, selected: isSelected, indeterminate: isIndeterminate, handleSelect, handleToggle, ui }"
174
+ :item="item"
175
+ >
176
+ {{ getItemLabel(item) }}
177
+ </slot>
178
+ </span>
179
+
180
+ <span
181
+ v-if="item.trailingIcon || item.children?.length || !!slots[item.slot ? `${item.slot}-trailing` : 'item-trailing']"
182
+ :class="ui.linkTrailing({ class: [props.ui?.linkTrailing, item.ui?.linkTrailing] })"
183
+ >
184
+ <slot
185
+ :name="item.slot ? `${item.slot}-trailing` : 'item-trailing'"
186
+ v-bind="{ index, level, expanded: isExpanded, selected: isSelected, indeterminate: isIndeterminate, handleSelect, handleToggle, ui }"
187
+ :item="item"
188
+ >
189
+ <UIcon
190
+ v-if="item.trailingIcon"
191
+ :name="item.trailingIcon"
192
+ :class="ui.linkTrailingIcon({ class: [props.ui?.linkTrailingIcon, item.ui?.linkTrailingIcon] })"
193
+ />
194
+ <UIcon
195
+ v-else-if="item.children?.length"
196
+ :name="trailingIcon ?? appConfig.ui.icons.chevronDown"
197
+ :class="ui.linkTrailingIcon({ class: [props.ui?.linkTrailingIcon, item.ui?.linkTrailingIcon] })"
198
+ />
199
+ </slot>
200
+ </span>
201
+ </slot>
202
+ </component>
203
+ </slot>
204
+
205
+ <ul
206
+ v-if="nested && item.children?.length && isExpanded"
207
+ role="group"
208
+ :class="ui.listWithChildren({ class: [props.ui?.listWithChildren, item.ui?.listWithChildren] })"
209
+ >
210
+ <ReuseTreeTemplate :items="item.children" :level="level + 1" />
211
+ </ul>
212
+ </TreeItem>
213
+ </li>
214
+ </DefineItemTemplate>
215
+
216
+ <DefineTreeTemplate v-slot="{ items, level }">
217
+ <ReuseItemTemplate v-for="(item, index) in items" :key="`${level}-${index}`" :item="item" :index="index" :level="level" />
152
218
  </DefineTreeTemplate>
153
219
 
154
220
  <TreeRoot
221
+ ref="rootRef"
222
+ v-slot="{ flattenItems }"
155
223
  v-bind="{ ...rootProps, ...$attrs }"
224
+ :as="as.root"
156
225
  :model-value="modelValue"
157
226
  :default-value="defaultValue"
158
227
  :class="ui.root({ class: [props.ui?.root, props.class] })"
@@ -160,6 +229,25 @@ const defaultExpanded = computed(
160
229
  :default-expanded="defaultExpanded"
161
230
  :selection-behavior="selectionBehavior"
162
231
  >
163
- <ReuseTreeTemplate :items="items" :level="1" />
232
+ <TreeVirtualizer
233
+ v-if="!!virtualize"
234
+ v-slot="{ item, virtualItem }"
235
+ :text-content="(item2) => getItemLabel(item2.value)"
236
+ v-bind="virtualizerProps"
237
+ >
238
+ <ReuseItemTemplate :item="item.value" :index="virtualItem.index" :level="item.level" />
239
+ </TreeVirtualizer>
240
+
241
+ <template v-else-if="!nested">
242
+ <ReuseItemTemplate
243
+ v-for="(item, index) in flattenItems"
244
+ :key="item._id"
245
+ :item="item.value"
246
+ :index="index"
247
+ :level="item.level"
248
+ />
249
+ </template>
250
+
251
+ <ReuseTreeTemplate v-else :items="items" :level="1" />
164
252
  </TreeRoot>
165
253
  </template>
@@ -1,4 +1,4 @@
1
- import type { TreeRootProps, TreeRootEmits } from 'reka-ui';
1
+ import type { TreeRootProps, TreeRootEmits, TreeItemSelectEvent, TreeItemToggleEvent } from 'reka-ui';
2
2
  import type { AppConfig } from '@nuxt/schema';
3
3
  import theme from '#build/ui/tree';
4
4
  import type { IconProps } from '../types';
@@ -19,8 +19,8 @@ export type TreeItem = {
19
19
  disabled?: boolean;
20
20
  slot?: string;
21
21
  children?: TreeItem[];
22
- onToggle?(e: Event): void;
23
- onSelect?(e?: Event): void;
22
+ onToggle?: (e: TreeItemToggleEvent<TreeItem>) => void;
23
+ onSelect?: (e: TreeItemSelectEvent<TreeItem>) => void;
24
24
  class?: any;
25
25
  ui?: Pick<Tree['slots'], 'item' | 'itemWithChildren' | 'link' | 'linkLeadingIcon' | 'linkLabel' | 'linkTrailing' | 'linkTrailingIcon' | 'listWithChildren'>;
26
26
  [key: string]: any;
@@ -30,7 +30,10 @@ export interface TreeProps<T extends TreeItem[] = TreeItem[], M extends boolean
30
30
  * The element or component this component should render as.
31
31
  * @defaultValue 'ul'
32
32
  */
33
- as?: any;
33
+ as?: any | {
34
+ root?: any;
35
+ link?: any;
36
+ };
34
37
  /**
35
38
  * @defaultValue 'primary'
36
39
  */
@@ -71,6 +74,31 @@ export interface TreeProps<T extends TreeItem[] = TreeItem[], M extends boolean
71
74
  defaultValue?: M extends true ? T[number][] : T[number];
72
75
  /** Whether multiple options can be selected or not. */
73
76
  multiple?: M & boolean;
77
+ /**
78
+ * Use nested DOM structure (children inside parents) vs flattened structure (all items at same level).
79
+ * When `virtualize` is enabled, this is automatically set to `false`.
80
+ * @defaultValue true
81
+ */
82
+ nested?: boolean;
83
+ /**
84
+ * Enable virtualization for large lists.
85
+ * Note: when enabled, the tree structure is flattened like if `nested` was set to `false`.
86
+ * @defaultValue false
87
+ */
88
+ virtualize?: boolean | {
89
+ /**
90
+ * Number of items rendered outside the visible area
91
+ * @defaultValue 12
92
+ */
93
+ overscan?: number;
94
+ /**
95
+ * Estimated size (in px) of each item
96
+ * @defaultValue 32
97
+ */
98
+ estimateSize?: number;
99
+ };
100
+ onSelect?: (e: TreeItemSelectEvent<T[number]>, item: T[number]) => void;
101
+ onToggle?: (e: TreeItemToggleEvent<T[number]>, item: T[number]) => void;
74
102
  class?: any;
75
103
  ui?: Tree['slots'];
76
104
  }
@@ -81,6 +109,10 @@ type SlotProps<T extends TreeItem> = (props: {
81
109
  level: number;
82
110
  expanded: boolean;
83
111
  selected: boolean;
112
+ indeterminate: boolean | undefined;
113
+ handleSelect: () => void;
114
+ handleToggle: () => void;
115
+ ui: Tree['ui'];
84
116
  }) => any;
85
117
  export type TreeSlots<T extends TreeItem[] = TreeItem[]> = {
86
118
  'item-wrapper': SlotProps<T[number]>;
@@ -92,20 +124,24 @@ export type TreeSlots<T extends TreeItem[] = TreeItem[]> = {
92
124
  index: number;
93
125
  level: number;
94
126
  expanded: boolean;
127
+ ui: Tree['ui'];
95
128
  selected: boolean;
129
+ indeterminate: boolean | undefined;
130
+ handleSelect: () => void;
131
+ handleToggle: () => void;
96
132
  }>;
97
- declare const _default: <T extends TreeItem[], M extends boolean = false>(__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<{
98
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
99
- readonly "onUpdate:modelValue"?: ((val: M extends true ? T[number][] : T[number]) => any) | undefined;
100
- readonly "onUpdate:expanded"?: ((val: string[]) => any) | undefined;
101
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:modelValue" | "onUpdate:expanded"> & TreeProps<T, M> & {}> & import("vue").PublicProps;
102
- expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
133
+ declare const __VLS_export: <T extends TreeItem[], M extends boolean = false>(__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<{
134
+ props: __VLS_PrettifyLocal<TreeProps<T, M> & __VLS_EmitsToProps<__VLS_NormalizeEmits<((evt: "update:modelValue", val: M extends true ? T[number][] : T[number]) => void) & ((evt: "update:expanded", val: string[]) => void)>>> & import("vue").PublicProps;
135
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
136
+ readonly $el: any;
137
+ }>) => void;
103
138
  attrs: any;
104
139
  slots: TreeSlots<T>;
105
140
  emit: ((evt: "update:modelValue", val: M extends true ? T[number][] : T[number]) => void) & ((evt: "update:expanded", val: string[]) => void);
106
141
  }>) => import("vue").VNode & {
107
142
  __ctx?: Awaited<typeof __VLS_setup>;
108
143
  };
144
+ declare const _default: typeof __VLS_export;
109
145
  export default _default;
110
146
  type __VLS_PrettifyLocal<T> = {
111
147
  [K in keyof T as K]: T[K];
@@ -31,14 +31,17 @@ export interface UserProps {
31
31
  ui?: User['slots'];
32
32
  }
33
33
  export interface UserSlots {
34
- avatar(props?: {}): any;
34
+ avatar(props: {
35
+ ui: User['ui'];
36
+ }): any;
35
37
  name(props?: {}): any;
36
38
  description(props?: {}): any;
37
39
  default(props?: {}): any;
38
40
  }
39
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<UserProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<UserProps> & Readonly<{}>, {
41
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<UserProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<UserProps> & Readonly<{}>, {
40
42
  orientation: User["variants"]["orientation"];
41
43
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, UserSlots>;
44
+ declare const _default: typeof __VLS_export;
42
45
  export default _default;
43
46
  type __VLS_WithSlots<T, S> = T & {
44
47
  new (): {
@@ -36,7 +36,7 @@ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.user || {} })
36
36
 
37
37
  <template>
38
38
  <Primitive :as="as" :data-orientation="orientation" :class="ui.root({ class: [props.ui?.root, props.class] })" @click="onClick">
39
- <slot name="avatar">
39
+ <slot name="avatar" :ui="ui">
40
40
  <UChip v-if="chip && avatar" inset v-bind="typeof chip === 'object' ? chip : {}" :size="size">
41
41
  <UAvatar :alt="name" v-bind="avatar" :size="size" :class="ui.avatar({ class: props.ui?.avatar })" />
42
42
  </UChip>
@@ -31,14 +31,17 @@ export interface UserProps {
31
31
  ui?: User['slots'];
32
32
  }
33
33
  export interface UserSlots {
34
- avatar(props?: {}): any;
34
+ avatar(props: {
35
+ ui: User['ui'];
36
+ }): any;
35
37
  name(props?: {}): any;
36
38
  description(props?: {}): any;
37
39
  default(props?: {}): any;
38
40
  }
39
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<UserProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<UserProps> & Readonly<{}>, {
41
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<UserProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<UserProps> & Readonly<{}>, {
40
42
  orientation: User["variants"]["orientation"];
41
43
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, UserSlots>;
44
+ declare const _default: typeof __VLS_export;
42
45
  export default _default;
43
46
  type __VLS_WithSlots<T, S> = T & {
44
47
  new (): {
@@ -3,5 +3,6 @@ export interface ColorModeAvatarProps extends /** @vue-ignore */ Omit<AvatarProp
3
3
  light: string;
4
4
  dark: string;
5
5
  }
6
- declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
6
+ declare const __VLS_export: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
7
+ declare const _default: typeof __VLS_export;
7
8
  export default _default;
@@ -3,5 +3,6 @@ export interface ColorModeAvatarProps extends /** @vue-ignore */ Omit<AvatarProp
3
3
  light: string;
4
4
  dark: string;
5
5
  }
6
- declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
6
+ declare const __VLS_export: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
7
+ declare const _default: typeof __VLS_export;
7
8
  export default _default;
@@ -9,12 +9,13 @@ export interface ColorModeButtonProps extends /** @vue-ignore */ Pick<ButtonProp
9
9
  */
10
10
  variant?: ButtonProps['variant'];
11
11
  }
12
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ColorModeButtonProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeButtonProps> & Readonly<{}>, {
12
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<ColorModeButtonProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeButtonProps> & Readonly<{}>, {
13
13
  color: ButtonProps["color"];
14
14
  variant: ButtonProps["variant"];
15
15
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, {
16
16
  fallback(props?: {}): any;
17
17
  }>;
18
+ declare const _default: typeof __VLS_export;
18
19
  export default _default;
19
20
  type __VLS_WithSlots<T, S> = T & {
20
21
  new (): {
@@ -9,12 +9,13 @@ export interface ColorModeButtonProps extends /** @vue-ignore */ Pick<ButtonProp
9
9
  */
10
10
  variant?: ButtonProps['variant'];
11
11
  }
12
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ColorModeButtonProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeButtonProps> & Readonly<{}>, {
12
+ declare const __VLS_export: __VLS_WithSlots<import("vue").DefineComponent<ColorModeButtonProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeButtonProps> & Readonly<{}>, {
13
13
  color: ButtonProps["color"];
14
14
  variant: ButtonProps["variant"];
15
15
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, {
16
16
  fallback(props?: {}): any;
17
17
  }>;
18
+ declare const _default: typeof __VLS_export;
18
19
  export default _default;
19
20
  type __VLS_WithSlots<T, S> = T & {
20
21
  new (): {
@@ -2,5 +2,6 @@ type __VLS_Props = {
2
2
  dark: string;
3
3
  light: string;
4
4
  };
5
- declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
6
+ declare const _default: typeof __VLS_export;
6
7
  export default _default;
@@ -2,5 +2,6 @@ type __VLS_Props = {
2
2
  dark: string;
3
3
  light: string;
4
4
  };
5
- declare const _default: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
6
+ declare const _default: typeof __VLS_export;
6
7
  export default _default;
@@ -1,5 +1,6 @@
1
1
  import type { SelectMenuProps } from '@eslamdevui/ui';
2
2
  export interface ColorModeSelectProps extends /** @vue-ignore */ Pick<SelectMenuProps<any>, 'color' | 'variant' | 'size' | 'trailingIcon' | 'selectedIcon' | 'content' | 'arrow' | 'portal' | 'disabled' | 'ui'> {
3
3
  }
4
- declare const _default: import("vue").DefineComponent<ColorModeSelectProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSelectProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
4
+ declare const __VLS_export: import("vue").DefineComponent<ColorModeSelectProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSelectProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const _default: typeof __VLS_export;
5
6
  export default _default;
@@ -1,5 +1,6 @@
1
1
  import type { SelectMenuProps } from '@eslamdevui/ui';
2
2
  export interface ColorModeSelectProps extends /** @vue-ignore */ Pick<SelectMenuProps<any>, 'color' | 'variant' | 'size' | 'trailingIcon' | 'selectedIcon' | 'content' | 'arrow' | 'portal' | 'disabled' | 'ui'> {
3
3
  }
4
- declare const _default: import("vue").DefineComponent<ColorModeSelectProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSelectProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
4
+ declare const __VLS_export: import("vue").DefineComponent<ColorModeSelectProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSelectProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const _default: typeof __VLS_export;
5
6
  export default _default;
@@ -1,5 +1,6 @@
1
1
  import type { SwitchProps } from '@eslamdevui/ui';
2
2
  export interface ColorModeSwitchProps extends /** @vue-ignore */ Pick<SwitchProps, 'as' | 'color' | 'size' | 'disabled' | 'ui'> {
3
3
  }
4
- declare const _default: import("vue").DefineComponent<ColorModeSwitchProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSwitchProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
4
+ declare const __VLS_export: import("vue").DefineComponent<ColorModeSwitchProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSwitchProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const _default: typeof __VLS_export;
5
6
  export default _default;
@@ -1,5 +1,6 @@
1
1
  import type { SwitchProps } from '@eslamdevui/ui';
2
2
  export interface ColorModeSwitchProps extends /** @vue-ignore */ Pick<SwitchProps, 'as' | 'color' | 'size' | 'disabled' | 'ui'> {
3
3
  }
4
- declare const _default: import("vue").DefineComponent<ColorModeSwitchProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSwitchProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
4
+ declare const __VLS_export: import("vue").DefineComponent<ColorModeSwitchProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ColorModeSwitchProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
5
+ declare const _default: typeof __VLS_export;
5
6
  export default _default;
@@ -78,6 +78,7 @@ export interface ContentNavigationEmits extends AccordionRootEmits {
78
78
  type SlotProps<T> = (props: {
79
79
  link: T;
80
80
  active?: boolean;
81
+ ui: ContentNavigation['ui'];
81
82
  }) => any;
82
83
  export interface ContentNavigationSlots<T extends ContentNavigationLink = ContentNavigationLink> {
83
84
  'link': SlotProps<T>;
@@ -85,17 +86,16 @@ export interface ContentNavigationSlots<T extends ContentNavigationLink = Conten
85
86
  'link-title': SlotProps<T>;
86
87
  'link-trailing': SlotProps<T>;
87
88
  }
88
- declare const _default: <T extends ContentNavigationLink>(__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<{
89
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
90
- readonly "onUpdate:modelValue"?: ((value: string | string[] | undefined) => any) | undefined;
91
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:modelValue"> & ContentNavigationProps<T> & {}> & import("vue").PublicProps;
92
- expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
89
+ declare const __VLS_export: <T extends ContentNavigationLink>(__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<{
90
+ props: __VLS_PrettifyLocal<ContentNavigationProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<(evt: "update:modelValue", value: string | string[] | undefined) => void>>> & import("vue").PublicProps;
91
+ expose: (exposed: {}) => void;
93
92
  attrs: any;
94
93
  slots: ContentNavigationSlots<T>;
95
94
  emit: (evt: "update:modelValue", value: string | string[] | undefined) => void;
96
95
  }>) => import("vue").VNode & {
97
96
  __ctx?: Awaited<typeof __VLS_setup>;
98
97
  };
98
+ declare const _default: typeof __VLS_export;
99
99
  export default _default;
100
100
  type __VLS_PrettifyLocal<T> = {
101
101
  [K in keyof T as K]: T[K];