@eslamdevui/ui 3.3.4 → 4.0.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 (622) hide show
  1. package/.nuxt/ui/alert.ts +0 -5
  2. package/.nuxt/ui/badge.ts +1 -6
  3. package/.nuxt/ui/banner.ts +4 -1
  4. package/.nuxt/ui/blog-post.ts +3 -1
  5. package/.nuxt/ui/blog-posts.ts +0 -5
  6. package/.nuxt/ui/button.ts +1 -6
  7. package/.nuxt/ui/carousel.ts +0 -5
  8. package/.nuxt/ui/changelog-version.ts +1 -1
  9. package/.nuxt/ui/changelog-versions.ts +2 -2
  10. package/.nuxt/ui/chat-message.ts +1 -1
  11. package/.nuxt/ui/content/content-navigation.ts +110 -83
  12. package/.nuxt/ui/content/content-surround.ts +0 -5
  13. package/.nuxt/ui/content/content-toc.ts +12 -7
  14. package/.nuxt/ui/dashboard-navbar.ts +0 -5
  15. package/.nuxt/ui/dashboard-sidebar-collapse.ts +0 -5
  16. package/.nuxt/ui/dashboard-sidebar-toggle.ts +0 -5
  17. package/.nuxt/ui/dashboard-sidebar.ts +0 -10
  18. package/.nuxt/ui/drawer.ts +1 -1
  19. package/.nuxt/ui/{button-group.ts → field-group.ts} +0 -13
  20. package/.nuxt/ui/file-upload.ts +0 -5
  21. package/.nuxt/ui/header.ts +0 -5
  22. package/.nuxt/ui/index.ts +10 -11
  23. package/.nuxt/ui/input-menu.ts +1 -10
  24. package/.nuxt/ui/input-number.ts +1 -6
  25. package/.nuxt/ui/input-tags.ts +1 -10
  26. package/.nuxt/ui/input.ts +2 -11
  27. package/.nuxt/ui/{page-marquee.ts → marquee.ts} +1 -1
  28. package/.nuxt/ui/page-card.ts +23 -20
  29. package/.nuxt/ui/page-cta.ts +4 -6
  30. package/.nuxt/ui/page-feature.ts +0 -5
  31. package/.nuxt/ui/page-hero.ts +4 -6
  32. package/.nuxt/ui/page-section.ts +0 -4
  33. package/.nuxt/ui/pricing-plans.ts +0 -5
  34. package/.nuxt/ui/progress.ts +3 -3
  35. package/.nuxt/ui/prose/code-tree.ts +1 -1
  36. package/.nuxt/ui/prose/img.ts +20 -1
  37. package/.nuxt/ui/select-menu.ts +1 -10
  38. package/.nuxt/ui/select.ts +8 -17
  39. package/.nuxt/ui/table.ts +0 -6
  40. package/.nuxt/ui/textarea.ts +2 -11
  41. package/.nuxt/ui/toast.ts +0 -5
  42. package/.nuxt/ui/tree.ts +1 -1
  43. package/.nuxt/ui/user.ts +0 -5
  44. package/README.md +21 -12
  45. package/cli/commands/make/component.mjs +2 -15
  46. package/cli/templates.mjs +32 -48
  47. package/dist/module.d.mts +8 -8
  48. package/dist/module.json +4 -4
  49. package/dist/module.mjs +48 -60
  50. package/dist/runtime/components/Accordion.d.vue.ts +79 -0
  51. package/dist/runtime/components/Accordion.vue +4 -4
  52. package/dist/runtime/components/Accordion.vue.d.ts +8 -6
  53. package/dist/runtime/components/Alert.d.vue.ts +81 -0
  54. package/dist/runtime/components/Alert.vue +2 -2
  55. package/dist/runtime/components/Alert.vue.d.ts +5 -5
  56. package/dist/runtime/components/App.d.vue.ts +25 -0
  57. package/dist/runtime/components/App.vue +1 -1
  58. package/dist/runtime/components/App.vue.d.ts +3 -2
  59. package/dist/runtime/components/AuthForm.d.vue.ts +128 -0
  60. package/dist/runtime/components/AuthForm.vue +31 -12
  61. package/dist/runtime/components/AuthForm.vue.d.ts +63 -20
  62. package/dist/runtime/components/Avatar.d.vue.ts +41 -0
  63. package/dist/runtime/components/Avatar.vue +1 -1
  64. package/dist/runtime/components/Avatar.vue.d.ts +4 -4
  65. package/dist/runtime/components/AvatarGroup.d.vue.ts +31 -0
  66. package/dist/runtime/components/AvatarGroup.vue.d.ts +2 -2
  67. package/dist/runtime/components/Badge.d.vue.ts +43 -0
  68. package/dist/runtime/components/Badge.vue +7 -7
  69. package/dist/runtime/components/Badge.vue.d.ts +2 -2
  70. package/dist/runtime/components/Banner.d.vue.ts +72 -0
  71. package/dist/runtime/components/Banner.vue +9 -5
  72. package/dist/runtime/components/Banner.vue.d.ts +13 -5
  73. package/dist/runtime/components/BlogPost.d.vue.ts +60 -0
  74. package/dist/runtime/components/BlogPost.vue +5 -1
  75. package/dist/runtime/components/BlogPost.vue.d.ts +4 -3
  76. package/dist/runtime/components/BlogPosts.d.vue.ts +31 -0
  77. package/dist/runtime/components/BlogPosts.vue.d.ts +4 -3
  78. package/dist/runtime/components/Breadcrumb.d.vue.ts +67 -0
  79. package/dist/runtime/components/Breadcrumb.vue +2 -2
  80. package/dist/runtime/components/Breadcrumb.vue.d.ts +7 -6
  81. package/dist/runtime/components/Button.d.vue.ts +44 -0
  82. package/dist/runtime/components/Button.vue +7 -7
  83. package/dist/runtime/components/Button.vue.d.ts +2 -2
  84. package/dist/runtime/components/Calendar.d.vue.ts +112 -0
  85. package/dist/runtime/components/Calendar.vue +5 -5
  86. package/dist/runtime/components/Calendar.vue.d.ts +9 -8
  87. package/dist/runtime/components/Card.d.vue.ts +29 -0
  88. package/dist/runtime/components/Card.vue.d.ts +2 -2
  89. package/dist/runtime/components/Carousel.d.vue.ts +127 -0
  90. package/dist/runtime/components/Carousel.vue +3 -3
  91. package/dist/runtime/components/Carousel.vue.d.ts +15 -15
  92. package/dist/runtime/components/ChangelogVersion.d.vue.ts +59 -0
  93. package/dist/runtime/components/ChangelogVersion.vue +3 -2
  94. package/dist/runtime/components/ChangelogVersion.vue.d.ts +4 -3
  95. package/dist/runtime/components/ChangelogVersions.d.vue.ts +78 -0
  96. package/dist/runtime/components/ChangelogVersions.vue +3 -3
  97. package/dist/runtime/components/ChangelogVersions.vue.d.ts +15 -11
  98. package/dist/runtime/components/ChatMessage.d.vue.ts +67 -0
  99. package/dist/runtime/components/ChatMessage.vue +58 -56
  100. package/dist/runtime/components/ChatMessage.vue.d.ts +25 -84
  101. package/dist/runtime/components/ChatMessages.d.vue.ts +83 -0
  102. package/dist/runtime/components/ChatMessages.vue +20 -36
  103. package/dist/runtime/components/ChatMessages.vue.d.ts +10 -9
  104. package/dist/runtime/components/ChatPalette.d.vue.ts +24 -0
  105. package/dist/runtime/components/ChatPalette.vue.d.ts +3 -3
  106. package/dist/runtime/components/ChatPrompt.d.vue.ts +61 -0
  107. package/dist/runtime/components/ChatPrompt.vue +25 -22
  108. package/dist/runtime/components/ChatPrompt.vue.d.ts +8 -7
  109. package/dist/runtime/components/ChatPromptSubmit.d.vue.ts +100 -0
  110. package/dist/runtime/components/ChatPromptSubmit.vue +43 -38
  111. package/dist/runtime/components/ChatPromptSubmit.vue.d.ts +15 -14
  112. package/dist/runtime/components/Checkbox.d.vue.ts +74 -0
  113. package/dist/runtime/components/Checkbox.vue +2 -2
  114. package/dist/runtime/components/Checkbox.vue.d.ts +8 -7
  115. package/dist/runtime/components/CheckboxGroup.d.vue.ts +89 -0
  116. package/dist/runtime/components/CheckboxGroup.vue +9 -9
  117. package/dist/runtime/components/CheckboxGroup.vue.d.ts +23 -18
  118. package/dist/runtime/components/Chip.d.vue.ts +57 -0
  119. package/dist/runtime/components/Chip.vue.d.ts +3 -3
  120. package/dist/runtime/components/Collapsible.d.vue.ts +35 -0
  121. package/dist/runtime/components/Collapsible.vue.d.ts +2 -2
  122. package/dist/runtime/components/ColorPicker.d.vue.ts +48 -0
  123. package/dist/runtime/components/ColorPicker.vue.d.ts +3 -3
  124. package/dist/runtime/components/CommandPalette.d.vue.ts +193 -0
  125. package/dist/runtime/components/CommandPalette.vue +11 -10
  126. package/dist/runtime/components/CommandPalette.vue.d.ts +12 -11
  127. package/dist/runtime/components/Container.d.vue.ts +18 -0
  128. package/dist/runtime/components/Container.vue.d.ts +1 -1
  129. package/dist/runtime/components/ContextMenu.d.vue.ts +110 -0
  130. package/dist/runtime/components/ContextMenu.vue +6 -5
  131. package/dist/runtime/components/ContextMenu.vue.d.ts +9 -8
  132. package/dist/runtime/components/ContextMenuContent.d.vue.ts +50 -0
  133. package/dist/runtime/components/ContextMenuContent.vue +10 -8
  134. package/dist/runtime/components/ContextMenuContent.vue.d.ts +8 -7
  135. package/dist/runtime/components/DashboardGroup.d.vue.ts +24 -0
  136. package/dist/runtime/components/DashboardGroup.vue +14 -12
  137. package/dist/runtime/components/DashboardGroup.vue.d.ts +2 -5
  138. package/dist/runtime/components/DashboardNavbar.d.vue.ts +52 -0
  139. package/dist/runtime/components/DashboardNavbar.vue +21 -23
  140. package/dist/runtime/components/DashboardNavbar.vue.d.ts +7 -8
  141. package/dist/runtime/components/DashboardPanel.d.vue.ts +30 -0
  142. package/dist/runtime/components/DashboardPanel.vue +19 -13
  143. package/dist/runtime/components/DashboardPanel.vue.d.ts +5 -3
  144. package/dist/runtime/components/DashboardResizeHandle.d.vue.ts +18 -0
  145. package/dist/runtime/components/DashboardResizeHandle.vue +1 -6
  146. package/dist/runtime/components/DashboardResizeHandle.vue.d.ts +1 -5
  147. package/dist/runtime/components/DashboardSearch.d.vue.ts +91 -0
  148. package/dist/runtime/components/DashboardSearch.vue +58 -57
  149. package/dist/runtime/components/DashboardSearch.vue.d.ts +53 -10
  150. package/dist/runtime/components/DashboardSearchButton.d.vue.ts +59 -0
  151. package/dist/runtime/components/DashboardSearchButton.vue +35 -47
  152. package/dist/runtime/components/DashboardSearchButton.vue.d.ts +7 -6
  153. package/dist/runtime/components/DashboardSidebar.d.vue.ts +75 -0
  154. package/dist/runtime/components/DashboardSidebar.vue +58 -66
  155. package/dist/runtime/components/DashboardSidebar.vue.d.ts +41 -38
  156. package/dist/runtime/components/DashboardSidebarCollapse.d.vue.ts +19 -0
  157. package/dist/runtime/components/DashboardSidebarCollapse.vue +9 -19
  158. package/dist/runtime/components/DashboardSidebarCollapse.vue.d.ts +8 -4
  159. package/dist/runtime/components/DashboardSidebarToggle.d.vue.ts +19 -0
  160. package/dist/runtime/components/DashboardSidebarToggle.vue +6 -4
  161. package/dist/runtime/components/DashboardSidebarToggle.vue.d.ts +3 -6
  162. package/dist/runtime/components/DashboardToolbar.d.vue.ts +25 -0
  163. package/dist/runtime/components/DashboardToolbar.vue.d.ts +3 -3
  164. package/dist/runtime/components/Drawer.d.vue.ts +84 -0
  165. package/dist/runtime/components/Drawer.vue.d.ts +3 -2
  166. package/dist/runtime/components/DropdownMenu.d.vue.ts +120 -0
  167. package/dist/runtime/components/DropdownMenu.vue +5 -5
  168. package/dist/runtime/components/DropdownMenu.vue.d.ts +9 -8
  169. package/dist/runtime/components/DropdownMenuContent.d.vue.ts +56 -0
  170. package/dist/runtime/components/DropdownMenuContent.vue +10 -8
  171. package/dist/runtime/components/DropdownMenuContent.vue.d.ts +8 -7
  172. package/dist/runtime/components/Error.d.vue.ts +47 -0
  173. package/dist/runtime/components/Error.vue +34 -31
  174. package/dist/runtime/components/Error.vue.d.ts +5 -10
  175. package/dist/runtime/components/FieldGroup.d.vue.ts +34 -0
  176. package/dist/runtime/components/{ButtonGroup.vue → FieldGroup.vue} +4 -4
  177. package/dist/runtime/components/FieldGroup.vue.d.ts +34 -0
  178. package/dist/runtime/components/FileUpload.d.vue.ts +166 -0
  179. package/dist/runtime/components/FileUpload.vue +12 -5
  180. package/dist/runtime/components/FileUpload.vue.d.ts +10 -11
  181. package/dist/runtime/components/Footer.d.vue.ts +29 -0
  182. package/dist/runtime/components/Footer.vue +1 -0
  183. package/dist/runtime/components/Footer.vue.d.ts +3 -3
  184. package/dist/runtime/components/FooterColumns.d.vue.ts +57 -0
  185. package/dist/runtime/components/FooterColumns.vue +4 -1
  186. package/dist/runtime/components/FooterColumns.vue.d.ts +16 -11
  187. package/dist/runtime/components/Form.d.vue.ts +114 -0
  188. package/dist/runtime/components/Form.vue +145 -61
  189. package/dist/runtime/components/Form.vue.d.ts +60 -17
  190. package/dist/runtime/components/FormField.d.vue.ts +61 -0
  191. package/dist/runtime/components/FormField.vue +10 -4
  192. package/dist/runtime/components/FormField.vue.d.ts +2 -2
  193. package/dist/runtime/components/Header.d.vue.ts +68 -0
  194. package/dist/runtime/components/Header.vue +12 -8
  195. package/dist/runtime/components/Header.vue.d.ts +19 -23
  196. package/dist/runtime/components/Icon.d.vue.ts +8 -0
  197. package/dist/runtime/components/Icon.vue +3 -2
  198. package/dist/runtime/components/Icon.vue.d.ts +2 -2
  199. package/dist/runtime/components/Input.d.vue.ts +74 -0
  200. package/dist/runtime/components/Input.vue +12 -9
  201. package/dist/runtime/components/Input.vue.d.ts +12 -15
  202. package/dist/runtime/components/InputMenu.d.vue.ts +330 -0
  203. package/dist/runtime/components/InputMenu.vue +24 -19
  204. package/dist/runtime/components/InputMenu.vue.d.ts +24 -231
  205. package/dist/runtime/components/InputNumber.d.vue.ts +188 -0
  206. package/dist/runtime/components/InputNumber.vue +16 -9
  207. package/dist/runtime/components/InputNumber.vue.d.ts +15 -87
  208. package/dist/runtime/components/InputTags.d.vue.ts +186 -0
  209. package/dist/runtime/components/InputTags.vue +11 -11
  210. package/dist/runtime/components/InputTags.vue.d.ts +8 -7
  211. package/dist/runtime/components/Kbd.d.vue.ts +38 -0
  212. package/dist/runtime/components/Kbd.vue.d.ts +2 -2
  213. package/dist/runtime/components/Link.d.vue.ts +91 -0
  214. package/dist/runtime/components/Link.vue.d.ts +1 -1
  215. package/dist/runtime/components/LinkBase.d.vue.ts +25 -0
  216. package/dist/runtime/components/LinkBase.vue.d.ts +1 -1
  217. package/dist/runtime/components/Main.d.vue.ts +20 -0
  218. package/dist/runtime/components/Main.vue.d.ts +1 -1
  219. package/dist/runtime/components/Marquee.d.vue.ts +32 -0
  220. package/dist/runtime/components/{PageMarquee.vue → Marquee.vue} +4 -4
  221. package/dist/runtime/components/Marquee.vue.d.ts +32 -0
  222. package/dist/runtime/components/Modal.d.vue.ts +107 -0
  223. package/dist/runtime/components/Modal.vue +1 -1
  224. package/dist/runtime/components/Modal.vue.d.ts +6 -5
  225. package/dist/runtime/components/NavigationMenu.d.vue.ts +171 -0
  226. package/dist/runtime/components/NavigationMenu.vue +2 -2
  227. package/dist/runtime/components/NavigationMenu.vue.d.ts +9 -8
  228. package/dist/runtime/components/OverlayProvider.d.vue.ts +2 -0
  229. package/dist/runtime/components/OverlayProvider.vue.d.ts +1 -1
  230. package/dist/runtime/components/Page.d.vue.ts +25 -0
  231. package/dist/runtime/components/Page.vue.d.ts +3 -3
  232. package/dist/runtime/components/PageAnchors.d.vue.ts +47 -0
  233. package/dist/runtime/components/PageAnchors.vue +4 -1
  234. package/dist/runtime/components/PageAnchors.vue.d.ts +16 -11
  235. package/dist/runtime/components/PageAside.d.vue.ts +27 -0
  236. package/dist/runtime/components/PageAside.vue.d.ts +3 -3
  237. package/dist/runtime/components/PageBody.d.vue.ts +18 -0
  238. package/dist/runtime/components/PageBody.vue.d.ts +1 -1
  239. package/dist/runtime/components/PageCTA.d.vue.ts +56 -0
  240. package/dist/runtime/components/PageCTA.vue +31 -13
  241. package/dist/runtime/components/PageCTA.vue.d.ts +11 -4
  242. package/dist/runtime/components/PageCard.d.vue.ts +72 -0
  243. package/dist/runtime/components/PageCard.vue +4 -3
  244. package/dist/runtime/components/PageCard.vue.d.ts +5 -4
  245. package/dist/runtime/components/PageColumns.d.vue.ts +18 -0
  246. package/dist/runtime/components/PageColumns.vue.d.ts +1 -1
  247. package/dist/runtime/components/PageFeature.d.vue.ts +44 -0
  248. package/dist/runtime/components/PageFeature.vue +4 -2
  249. package/dist/runtime/components/PageFeature.vue.d.ts +5 -4
  250. package/dist/runtime/components/PageGrid.d.vue.ts +18 -0
  251. package/dist/runtime/components/PageGrid.vue.d.ts +1 -1
  252. package/dist/runtime/components/PageHeader.d.vue.ts +36 -0
  253. package/dist/runtime/components/PageHeader.vue +1 -0
  254. package/dist/runtime/components/PageHeader.vue.d.ts +4 -3
  255. package/dist/runtime/components/PageHero.d.vue.ts +53 -0
  256. package/dist/runtime/components/PageHero.vue +31 -17
  257. package/dist/runtime/components/PageHero.vue.d.ts +9 -5
  258. package/dist/runtime/components/PageLinks.d.vue.ts +49 -0
  259. package/dist/runtime/components/PageLinks.vue +4 -1
  260. package/dist/runtime/components/PageLinks.vue.d.ts +16 -11
  261. package/dist/runtime/components/PageList.d.vue.ts +21 -0
  262. package/dist/runtime/components/PageList.vue.d.ts +1 -1
  263. package/dist/runtime/components/PageLogos.d.vue.ts +33 -0
  264. package/dist/runtime/components/PageLogos.vue +5 -4
  265. package/dist/runtime/components/PageLogos.vue.d.ts +6 -5
  266. package/dist/runtime/components/PageSection.d.vue.ts +68 -0
  267. package/dist/runtime/components/PageSection.vue +49 -33
  268. package/dist/runtime/components/PageSection.vue.d.ts +12 -8
  269. package/dist/runtime/components/Pagination.d.vue.ts +118 -0
  270. package/dist/runtime/components/Pagination.vue +5 -5
  271. package/dist/runtime/components/Pagination.vue.d.ts +10 -10
  272. package/dist/runtime/components/PinInput.d.vue.ts +60 -0
  273. package/dist/runtime/components/PinInput.vue +3 -1
  274. package/dist/runtime/components/PinInput.vue.d.ts +10 -10
  275. package/dist/runtime/components/Popover.d.vue.ts +71 -0
  276. package/dist/runtime/components/Popover.vue.d.ts +3 -2
  277. package/dist/runtime/components/PricingPlan.d.vue.ts +112 -0
  278. package/dist/runtime/components/PricingPlan.vue +17 -9
  279. package/dist/runtime/components/PricingPlan.vue.d.ts +7 -4
  280. package/dist/runtime/components/PricingPlans.d.vue.ts +44 -0
  281. package/dist/runtime/components/PricingPlans.vue +2 -2
  282. package/dist/runtime/components/PricingPlans.vue.d.ts +6 -3
  283. package/dist/runtime/components/PricingTable.d.vue.ts +105 -0
  284. package/dist/runtime/components/PricingTable.vue +22 -77
  285. package/dist/runtime/components/PricingTable.vue.d.ts +15 -8
  286. package/dist/runtime/components/Progress.d.vue.ts +66 -0
  287. package/dist/runtime/components/Progress.vue +2 -3
  288. package/dist/runtime/components/Progress.vue.d.ts +2 -2
  289. package/dist/runtime/components/RadioGroup.d.vue.ts +99 -0
  290. package/dist/runtime/components/RadioGroup.vue +13 -11
  291. package/dist/runtime/components/RadioGroup.vue.d.ts +21 -16
  292. package/dist/runtime/components/Select.d.vue.ts +254 -0
  293. package/dist/runtime/components/Select.vue +28 -18
  294. package/dist/runtime/components/Select.vue.d.ts +22 -21
  295. package/dist/runtime/components/SelectMenu.d.vue.ts +303 -0
  296. package/dist/runtime/components/SelectMenu.vue +19 -14
  297. package/dist/runtime/components/SelectMenu.vue.d.ts +22 -21
  298. package/dist/runtime/components/Separator.d.vue.ts +54 -0
  299. package/dist/runtime/components/Separator.vue +1 -1
  300. package/dist/runtime/components/Separator.vue.d.ts +4 -4
  301. package/dist/runtime/components/Skeleton.d.vue.ts +17 -0
  302. package/dist/runtime/components/Skeleton.vue.d.ts +1 -1
  303. package/dist/runtime/components/Slideover.d.vue.ts +108 -0
  304. package/dist/runtime/components/Slideover.vue +1 -1
  305. package/dist/runtime/components/Slideover.vue.d.ts +6 -5
  306. package/dist/runtime/components/Slider.d.vue.ts +57 -0
  307. package/dist/runtime/components/Slider.vue +1 -1
  308. package/dist/runtime/components/Slider.vue.d.ts +7 -8
  309. package/dist/runtime/components/Stepper.d.vue.ts +87 -0
  310. package/dist/runtime/components/Stepper.vue.d.ts +11 -9
  311. package/dist/runtime/components/Switch.d.vue.ts +71 -0
  312. package/dist/runtime/components/Switch.vue +3 -3
  313. package/dist/runtime/components/Switch.vue.d.ts +9 -8
  314. package/dist/runtime/components/Table.d.vue.ts +201 -0
  315. package/dist/runtime/components/Table.vue +2 -2
  316. package/dist/runtime/components/Table.vue.d.ts +28 -28
  317. package/dist/runtime/components/Tabs.d.vue.ts +99 -0
  318. package/dist/runtime/components/Tabs.vue +17 -30
  319. package/dist/runtime/components/Tabs.vue.d.ts +6 -5
  320. package/dist/runtime/components/Textarea.d.vue.ts +74 -0
  321. package/dist/runtime/components/Textarea.vue +8 -5
  322. package/dist/runtime/components/Textarea.vue.d.ts +7 -12
  323. package/dist/runtime/components/Timeline.d.vue.ts +71 -0
  324. package/dist/runtime/components/Timeline.vue.d.ts +5 -4
  325. package/dist/runtime/components/Toast.d.vue.ts +165 -0
  326. package/dist/runtime/components/Toast.vue +2 -2
  327. package/dist/runtime/components/Toast.vue.d.ts +9 -8
  328. package/dist/runtime/components/Toaster.d.vue.ts +44 -0
  329. package/dist/runtime/components/Toaster.vue.d.ts +2 -2
  330. package/dist/runtime/components/Tooltip.d.vue.ts +57 -0
  331. package/dist/runtime/components/Tooltip.vue +2 -2
  332. package/dist/runtime/components/Tooltip.vue.d.ts +3 -2
  333. package/dist/runtime/components/Tree.d.vue.ts +112 -0
  334. package/dist/runtime/components/Tree.vue +77 -34
  335. package/dist/runtime/components/Tree.vue.d.ts +27 -28
  336. package/dist/runtime/components/User.d.vue.ts +47 -0
  337. package/dist/runtime/components/User.vue +3 -0
  338. package/dist/runtime/components/User.vue.d.ts +4 -3
  339. package/dist/runtime/components/color-mode/ColorModeAvatar.d.vue.ts +7 -0
  340. package/dist/runtime/components/color-mode/ColorModeAvatar.vue +1 -0
  341. package/dist/runtime/components/color-mode/ColorModeAvatar.vue.d.ts +2 -2
  342. package/dist/runtime/components/color-mode/ColorModeButton.d.vue.ts +23 -0
  343. package/dist/runtime/components/color-mode/ColorModeButton.vue +3 -2
  344. package/dist/runtime/components/color-mode/ColorModeButton.vue.d.ts +6 -7
  345. package/dist/runtime/components/color-mode/ColorModeImage.d.vue.ts +6 -0
  346. package/dist/runtime/components/color-mode/ColorModeImage.vue +0 -4
  347. package/dist/runtime/components/color-mode/ColorModeImage.vue.d.ts +3 -3
  348. package/dist/runtime/components/color-mode/ColorModeSelect.d.vue.ts +5 -0
  349. package/dist/runtime/components/color-mode/ColorModeSelect.vue +5 -3
  350. package/dist/runtime/components/color-mode/ColorModeSelect.vue.d.ts +3 -5
  351. package/dist/runtime/components/color-mode/ColorModeSwitch.d.vue.ts +5 -0
  352. package/dist/runtime/components/color-mode/ColorModeSwitch.vue +3 -2
  353. package/dist/runtime/components/color-mode/ColorModeSwitch.vue.d.ts +3 -5
  354. package/dist/runtime/components/content/ContentNavigation.d.vue.ts +102 -0
  355. package/dist/runtime/components/content/ContentNavigation.vue +44 -81
  356. package/dist/runtime/components/content/ContentNavigation.vue.d.ts +76 -27
  357. package/dist/runtime/components/content/ContentSearch.d.vue.ts +114 -0
  358. package/dist/runtime/components/content/ContentSearch.vue +40 -58
  359. package/dist/runtime/components/content/ContentSearch.vue.d.ts +28 -29
  360. package/dist/runtime/components/content/ContentSearchButton.d.vue.ts +59 -0
  361. package/dist/runtime/components/content/ContentSearchButton.vue +21 -35
  362. package/dist/runtime/components/content/ContentSearchButton.vue.d.ts +6 -5
  363. package/dist/runtime/components/content/ContentSurround.d.vue.ts +59 -0
  364. package/dist/runtime/components/content/ContentSurround.vue +15 -14
  365. package/dist/runtime/components/content/ContentSurround.vue.d.ts +18 -11
  366. package/dist/runtime/components/content/ContentToc.d.vue.ts +88 -0
  367. package/dist/runtime/components/content/ContentToc.vue +18 -28
  368. package/dist/runtime/components/content/ContentToc.vue.d.ts +19 -17
  369. package/dist/runtime/components/locale/LocaleSelect.d.vue.ts +15 -0
  370. package/dist/runtime/components/locale/LocaleSelect.vue +34 -5
  371. package/dist/runtime/components/locale/LocaleSelect.vue.d.ts +6 -7
  372. package/dist/runtime/components/prose/A.d.vue.ts +15 -0
  373. package/dist/runtime/components/prose/A.vue.d.ts +1 -1
  374. package/dist/runtime/components/prose/Accordion.d.vue.ts +16 -0
  375. package/dist/runtime/components/prose/Accordion.vue +2 -1
  376. package/dist/runtime/components/prose/Accordion.vue.d.ts +1 -1
  377. package/dist/runtime/components/prose/AccordionItem.d.vue.ts +15 -0
  378. package/dist/runtime/components/prose/AccordionItem.vue.d.ts +1 -1
  379. package/dist/runtime/components/prose/Badge.d.vue.ts +13 -0
  380. package/dist/runtime/components/prose/Badge.vue +1 -0
  381. package/dist/runtime/components/prose/Badge.vue.d.ts +1 -1
  382. package/dist/runtime/components/prose/Blockquote.d.vue.ts +13 -0
  383. package/dist/runtime/components/prose/Blockquote.vue.d.ts +1 -1
  384. package/dist/runtime/components/prose/Callout.d.vue.ts +26 -0
  385. package/dist/runtime/components/prose/Callout.vue +5 -19
  386. package/dist/runtime/components/prose/Callout.vue.d.ts +9 -9
  387. package/dist/runtime/components/prose/Card.d.vue.ts +29 -0
  388. package/dist/runtime/components/prose/Card.vue +15 -37
  389. package/dist/runtime/components/prose/Card.vue.d.ts +7 -8
  390. package/dist/runtime/components/prose/CardGroup.d.vue.ts +13 -0
  391. package/dist/runtime/components/prose/CardGroup.vue.d.ts +1 -1
  392. package/dist/runtime/components/prose/Code.d.vue.ts +22 -0
  393. package/dist/runtime/components/prose/Code.vue.d.ts +3 -3
  394. package/dist/runtime/components/prose/CodeCollapse.d.vue.ts +47 -0
  395. package/dist/runtime/components/prose/CodeCollapse.vue +4 -3
  396. package/dist/runtime/components/prose/CodeCollapse.vue.d.ts +7 -6
  397. package/dist/runtime/components/prose/CodeGroup.d.vue.ts +37 -0
  398. package/dist/runtime/components/prose/CodeGroup.vue +3 -3
  399. package/dist/runtime/components/prose/CodeGroup.vue.d.ts +5 -5
  400. package/dist/runtime/components/prose/CodeIcon.d.vue.ts +7 -0
  401. package/dist/runtime/components/prose/CodeIcon.vue +11 -7
  402. package/dist/runtime/components/prose/CodeIcon.vue.d.ts +3 -20
  403. package/dist/runtime/components/prose/CodePreview.d.vue.ts +19 -0
  404. package/dist/runtime/components/prose/CodePreview.vue.d.ts +3 -3
  405. package/dist/runtime/components/prose/CodeTree.d.vue.ts +28 -0
  406. package/dist/runtime/components/prose/CodeTree.vue +74 -78
  407. package/dist/runtime/components/prose/CodeTree.vue.d.ts +3 -5
  408. package/dist/runtime/components/prose/Collapsible.d.vue.ts +39 -0
  409. package/dist/runtime/components/prose/Collapsible.vue +5 -3
  410. package/dist/runtime/components/prose/Collapsible.vue.d.ts +5 -4
  411. package/dist/runtime/components/prose/Em.d.vue.ts +13 -0
  412. package/dist/runtime/components/prose/Em.vue.d.ts +1 -1
  413. package/dist/runtime/components/prose/Field.d.vue.ts +39 -0
  414. package/dist/runtime/components/prose/Field.vue.d.ts +3 -3
  415. package/dist/runtime/components/prose/FieldGroup.d.vue.ts +18 -0
  416. package/dist/runtime/components/prose/FieldGroup.vue.d.ts +1 -1
  417. package/dist/runtime/components/prose/H1.d.vue.ts +19 -0
  418. package/dist/runtime/components/prose/H1.vue +1 -1
  419. package/dist/runtime/components/prose/H1.vue.d.ts +3 -3
  420. package/dist/runtime/components/prose/H2.d.vue.ts +19 -0
  421. package/dist/runtime/components/prose/H2.vue +2 -1
  422. package/dist/runtime/components/prose/H2.vue.d.ts +3 -3
  423. package/dist/runtime/components/prose/H3.d.vue.ts +19 -0
  424. package/dist/runtime/components/prose/H3.vue +2 -1
  425. package/dist/runtime/components/prose/H3.vue.d.ts +3 -3
  426. package/dist/runtime/components/prose/H4.d.vue.ts +19 -0
  427. package/dist/runtime/components/prose/H4.vue +1 -1
  428. package/dist/runtime/components/prose/H4.vue.d.ts +3 -3
  429. package/dist/runtime/components/prose/Hr.d.vue.ts +5 -0
  430. package/dist/runtime/components/prose/Hr.vue.d.ts +1 -1
  431. package/dist/runtime/components/prose/Icon.d.vue.ts +6 -0
  432. package/dist/runtime/components/prose/Icon.vue +1 -0
  433. package/dist/runtime/components/prose/Icon.vue.d.ts +1 -1
  434. package/dist/runtime/components/prose/Img.d.vue.ts +21 -0
  435. package/dist/runtime/components/prose/Img.vue +53 -11
  436. package/dist/runtime/components/prose/Img.vue.d.ts +13 -1
  437. package/dist/runtime/components/prose/Kbd.d.vue.ts +6 -0
  438. package/dist/runtime/components/prose/Kbd.vue +1 -0
  439. package/dist/runtime/components/prose/Kbd.vue.d.ts +1 -1
  440. package/dist/runtime/components/prose/Li.d.vue.ts +13 -0
  441. package/dist/runtime/components/prose/Li.vue.d.ts +1 -1
  442. package/dist/runtime/components/prose/Ol.d.vue.ts +13 -0
  443. package/dist/runtime/components/prose/Ol.vue.d.ts +1 -1
  444. package/dist/runtime/components/prose/P.d.vue.ts +13 -0
  445. package/dist/runtime/components/prose/P.vue.d.ts +1 -1
  446. package/dist/runtime/components/prose/Pre.d.vue.ts +26 -0
  447. package/dist/runtime/components/prose/Pre.vue +9 -16
  448. package/dist/runtime/components/prose/Pre.vue.d.ts +4 -3
  449. package/dist/runtime/components/prose/Script.d.vue.ts +5 -0
  450. package/dist/runtime/components/prose/Script.vue.d.ts +4 -11
  451. package/dist/runtime/components/prose/Steps.d.vue.ts +22 -0
  452. package/dist/runtime/components/prose/Steps.vue.d.ts +2 -2
  453. package/dist/runtime/components/prose/Strong.d.vue.ts +13 -0
  454. package/dist/runtime/components/prose/Strong.vue.d.ts +1 -1
  455. package/dist/runtime/components/prose/Table.d.vue.ts +18 -0
  456. package/dist/runtime/components/prose/Table.vue.d.ts +3 -3
  457. package/dist/runtime/components/prose/Tabs.d.vue.ts +36 -0
  458. package/dist/runtime/components/prose/Tabs.vue +2 -1
  459. package/dist/runtime/components/prose/Tabs.vue.d.ts +3 -3
  460. package/dist/runtime/components/prose/TabsItem.d.vue.ts +15 -0
  461. package/dist/runtime/components/prose/TabsItem.vue.d.ts +1 -1
  462. package/dist/runtime/components/prose/Tbody.d.vue.ts +13 -0
  463. package/dist/runtime/components/prose/Tbody.vue.d.ts +1 -1
  464. package/dist/runtime/components/prose/Td.d.vue.ts +13 -0
  465. package/dist/runtime/components/prose/Td.vue.d.ts +1 -1
  466. package/dist/runtime/components/prose/Th.d.vue.ts +13 -0
  467. package/dist/runtime/components/prose/Th.vue.d.ts +1 -1
  468. package/dist/runtime/components/prose/Thead.d.vue.ts +13 -0
  469. package/dist/runtime/components/prose/Thead.vue.d.ts +1 -1
  470. package/dist/runtime/components/prose/Tr.d.vue.ts +13 -0
  471. package/dist/runtime/components/prose/Tr.vue.d.ts +1 -1
  472. package/dist/runtime/components/prose/Ul.d.vue.ts +13 -0
  473. package/dist/runtime/components/prose/Ul.vue.d.ts +1 -1
  474. package/dist/runtime/components/prose/callout/Caution.d.vue.ts +14 -0
  475. package/dist/runtime/components/prose/callout/Caution.vue.d.ts +1 -1
  476. package/dist/runtime/components/prose/callout/Note.d.vue.ts +14 -0
  477. package/dist/runtime/components/prose/callout/Note.vue.d.ts +1 -1
  478. package/dist/runtime/components/prose/callout/Tip.d.vue.ts +14 -0
  479. package/dist/runtime/components/prose/callout/Tip.vue.d.ts +1 -1
  480. package/dist/runtime/components/prose/callout/Warning.d.vue.ts +14 -0
  481. package/dist/runtime/components/prose/callout/Warning.vue.d.ts +1 -1
  482. package/dist/runtime/composables/useAvatarGroup.js +1 -1
  483. package/dist/runtime/composables/useComponentIcons.d.ts +5 -5
  484. package/dist/runtime/composables/useContentSearch.d.ts +1 -2
  485. package/dist/runtime/composables/{useButtonGroup.d.ts → useFieldGroup.d.ts} +5 -5
  486. package/dist/runtime/composables/useFieldGroup.js +9 -0
  487. package/dist/runtime/composables/useFileUpload.js +7 -1
  488. package/dist/runtime/composables/useFormField.d.ts +3 -1
  489. package/dist/runtime/composables/useFormField.js +8 -10
  490. package/dist/runtime/composables/useLocale.js +1 -1
  491. package/dist/runtime/composables/useOverlay.d.ts +1 -1
  492. package/dist/runtime/composables/useOverlay.js +4 -3
  493. package/dist/runtime/composables/usePortal.js +1 -1
  494. package/dist/runtime/composables/useResizable.d.ts +49 -0
  495. package/dist/runtime/composables/useResizable.js +77 -47
  496. package/dist/runtime/composables/useScrollspy.d.ts +2 -3
  497. package/dist/runtime/composables/useScrollspy.js +16 -13
  498. package/dist/runtime/index.css +1 -1
  499. package/dist/runtime/inertia/components/Link.d.vue.ts +63 -0
  500. package/dist/runtime/inertia/components/Link.vue +3 -0
  501. package/dist/runtime/inertia/components/Link.vue.d.ts +1 -1
  502. package/dist/runtime/inertia/components/LinkBase.d.vue.ts +25 -0
  503. package/dist/runtime/inertia/components/LinkBase.vue.d.ts +1 -1
  504. package/dist/runtime/inertia/stubs.d.ts +1 -1
  505. package/dist/runtime/locale/ar.js +101 -28
  506. package/dist/runtime/locale/az.js +101 -28
  507. package/dist/runtime/locale/bg.js +101 -28
  508. package/dist/runtime/locale/bn.js +101 -28
  509. package/dist/runtime/locale/ca.js +101 -28
  510. package/dist/runtime/locale/ckb.js +101 -28
  511. package/dist/runtime/locale/cs.js +101 -28
  512. package/dist/runtime/locale/da.js +101 -28
  513. package/dist/runtime/locale/de.js +101 -28
  514. package/dist/runtime/locale/de_ch.d.ts +3 -0
  515. package/dist/runtime/locale/de_ch.js +129 -0
  516. package/dist/runtime/locale/el.js +101 -28
  517. package/dist/runtime/locale/en.js +60 -57
  518. package/dist/runtime/locale/es.js +101 -28
  519. package/dist/runtime/locale/et.js +101 -28
  520. package/dist/runtime/locale/fa_ir.js +101 -28
  521. package/dist/runtime/locale/fi.js +101 -28
  522. package/dist/runtime/locale/fr.js +101 -28
  523. package/dist/runtime/locale/he.js +101 -26
  524. package/dist/runtime/locale/hi.js +101 -28
  525. package/dist/runtime/locale/hu.js +101 -28
  526. package/dist/runtime/locale/hy.js +101 -28
  527. package/dist/runtime/locale/id.js +102 -29
  528. package/dist/runtime/locale/index.d.ts +2 -0
  529. package/dist/runtime/locale/index.js +2 -0
  530. package/dist/runtime/locale/it.js +101 -28
  531. package/dist/runtime/locale/ja.js +101 -28
  532. package/dist/runtime/locale/ka.d.ts +3 -0
  533. package/dist/runtime/locale/ka.js +132 -0
  534. package/dist/runtime/locale/kk.js +100 -27
  535. package/dist/runtime/locale/km.js +101 -28
  536. package/dist/runtime/locale/ko.js +101 -28
  537. package/dist/runtime/locale/ky.js +101 -28
  538. package/dist/runtime/locale/lb.js +101 -28
  539. package/dist/runtime/locale/lt.js +101 -28
  540. package/dist/runtime/locale/mn.js +101 -28
  541. package/dist/runtime/locale/ms.js +101 -28
  542. package/dist/runtime/locale/nb_no.js +101 -28
  543. package/dist/runtime/locale/nl.js +101 -28
  544. package/dist/runtime/locale/pl.js +101 -28
  545. package/dist/runtime/locale/pt.js +101 -28
  546. package/dist/runtime/locale/pt_br.js +101 -28
  547. package/dist/runtime/locale/ro.js +101 -28
  548. package/dist/runtime/locale/ru.js +101 -28
  549. package/dist/runtime/locale/sk.js +101 -28
  550. package/dist/runtime/locale/sl.js +101 -28
  551. package/dist/runtime/locale/sv.js +101 -28
  552. package/dist/runtime/locale/th.js +101 -28
  553. package/dist/runtime/locale/tj.js +101 -28
  554. package/dist/runtime/locale/tr.js +101 -28
  555. package/dist/runtime/locale/ug_cn.js +100 -27
  556. package/dist/runtime/locale/uk.js +101 -28
  557. package/dist/runtime/locale/ur.js +101 -28
  558. package/dist/runtime/locale/uz.js +101 -28
  559. package/dist/runtime/locale/vi.js +101 -28
  560. package/dist/runtime/locale/zh_cn.js +101 -28
  561. package/dist/runtime/locale/zh_tw.js +101 -28
  562. package/dist/runtime/plugins/colors.js +3 -3
  563. package/dist/runtime/types/form.d.ts +12 -13
  564. package/dist/runtime/types/form.js +1 -3
  565. package/dist/runtime/types/index.d.ts +12 -15
  566. package/dist/runtime/types/index.js +12 -15
  567. package/dist/runtime/types/input.d.ts +8 -0
  568. package/dist/runtime/types/input.js +0 -0
  569. package/dist/runtime/types/locale.d.ts +84 -71
  570. package/dist/runtime/types/tv.d.ts +9 -2
  571. package/dist/runtime/types/utils.d.ts +9 -5
  572. package/dist/runtime/types/utils.js +0 -1
  573. package/dist/runtime/utils/ai.d.ts +2 -0
  574. package/dist/runtime/utils/ai.js +3 -0
  575. package/dist/runtime/utils/content.d.ts +2 -13
  576. package/dist/runtime/utils/content.js +7 -59
  577. package/dist/runtime/utils/dashboard.js +1 -4
  578. package/dist/runtime/utils/form.d.ts +2 -6
  579. package/dist/runtime/utils/form.js +28 -60
  580. package/dist/runtime/utils/fuse.d.ts +2 -1
  581. package/dist/runtime/utils/index.d.ts +8 -4
  582. package/dist/runtime/utils/index.js +59 -27
  583. package/dist/runtime/utils/tv.d.ts +1 -1
  584. package/dist/runtime/vue/components/Icon.d.vue.ts +6 -0
  585. package/dist/runtime/vue/components/Icon.vue +3 -2
  586. package/dist/runtime/vue/components/Icon.vue.d.ts +3 -2
  587. package/dist/runtime/vue/components/Link.d.vue.ts +93 -0
  588. package/dist/runtime/vue/components/Link.vue.d.ts +1 -1
  589. package/dist/runtime/vue/components/color-mode/ColorModeButton.d.vue.ts +16 -0
  590. package/dist/runtime/vue/components/color-mode/ColorModeButton.vue +3 -2
  591. package/dist/runtime/vue/components/color-mode/ColorModeButton.vue.d.ts +4 -26
  592. package/dist/runtime/vue/components/color-mode/ColorModeSelect.d.vue.ts +5 -0
  593. package/dist/runtime/vue/components/color-mode/ColorModeSelect.vue +4 -3
  594. package/dist/runtime/vue/components/color-mode/ColorModeSelect.vue.d.ts +1 -1
  595. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.d.vue.ts +5 -0
  596. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.vue +3 -2
  597. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.vue.d.ts +1 -1
  598. package/dist/runtime/vue/stubs.d.ts +1 -1
  599. package/dist/shared/{ui.CgUuvRXi.mjs → ui.BBlr3wu_.mjs} +1053 -1166
  600. package/dist/unplugin.d.mts +14 -14
  601. package/dist/unplugin.mjs +51 -32
  602. package/dist/vite.mjs +4 -4
  603. package/package.json +48 -68
  604. package/.nuxt/ui/content/index.ts +0 -5
  605. package/.nuxt/ui/content-navigation.ts +0 -341
  606. package/.nuxt/ui/content-search-button.ts +0 -6
  607. package/.nuxt/ui/content-search.ts +0 -6
  608. package/.nuxt/ui/content-surround.ts +0 -39
  609. package/.nuxt/ui/content-toc.ts +0 -150
  610. package/.nuxt/ui/page-accordion.ts +0 -7
  611. package/.nuxt/ui/scroll-to-section.ts +0 -3
  612. package/dist/runtime/components/ButtonGroup.vue.d.ts +0 -34
  613. package/dist/runtime/components/PageAccordion.vue +0 -26
  614. package/dist/runtime/components/PageAccordion.vue.d.ts +0 -21
  615. package/dist/runtime/components/PageMarquee.vue.d.ts +0 -32
  616. package/dist/runtime/components/ScrollToSection.vue +0 -62
  617. package/dist/runtime/components/ScrollToSection.vue.d.ts +0 -36
  618. package/dist/runtime/composables/useBreakpoint.d.ts +0 -11
  619. package/dist/runtime/composables/useBreakpoint.js +0 -53
  620. package/dist/runtime/composables/useButtonGroup.js +0 -9
  621. package/dist/runtime/composables/useLocalePro.d.ts +0 -3
  622. package/dist/runtime/composables/useLocalePro.js +0 -11
@@ -0,0 +1,120 @@
1
+ import type { DropdownMenuRootProps, DropdownMenuRootEmits, DropdownMenuContentProps, DropdownMenuContentEmits, DropdownMenuArrowProps } from 'reka-ui';
2
+ import type { AppConfig } from '@nuxt/schema';
3
+ import theme from '#build/ui/dropdown-menu';
4
+ import type { AvatarProps, IconProps, KbdProps, LinkProps } from '../types';
5
+ import type { ArrayOrNested, DynamicSlots, GetItemKeys, MergeTypes, NestedItem, EmitsToProps } from '../types/utils';
6
+ import type { ComponentConfig } from '../types/tv';
7
+ type DropdownMenu = ComponentConfig<typeof theme, AppConfig, 'dropdownMenu'>;
8
+ export interface DropdownMenuItem extends Omit<LinkProps, 'type' | 'raw' | 'custom'> {
9
+ label?: string;
10
+ /**
11
+ * @IconifyIcon
12
+ */
13
+ icon?: IconProps['name'];
14
+ color?: DropdownMenu['variants']['color'];
15
+ avatar?: AvatarProps;
16
+ content?: Omit<DropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> & Partial<EmitsToProps<DropdownMenuContentEmits>>;
17
+ kbds?: KbdProps['value'][] | KbdProps[];
18
+ /**
19
+ * The item type.
20
+ * @defaultValue 'link'
21
+ */
22
+ type?: 'label' | 'separator' | 'link' | 'checkbox';
23
+ slot?: string;
24
+ loading?: boolean;
25
+ disabled?: boolean;
26
+ checked?: boolean;
27
+ open?: boolean;
28
+ defaultOpen?: boolean;
29
+ children?: ArrayOrNested<DropdownMenuItem>;
30
+ onSelect?(e: Event): void;
31
+ onUpdateChecked?(checked: boolean): void;
32
+ class?: any;
33
+ ui?: Pick<DropdownMenu['slots'], 'item' | 'label' | 'separator' | 'itemLeadingIcon' | 'itemLeadingAvatarSize' | 'itemLeadingAvatar' | 'itemLabel' | 'itemLabelExternalIcon' | 'itemTrailing' | 'itemTrailingIcon' | 'itemTrailingKbds' | 'itemTrailingKbdsSize'>;
34
+ [key: string]: any;
35
+ }
36
+ export interface DropdownMenuProps<T extends ArrayOrNested<DropdownMenuItem> = ArrayOrNested<DropdownMenuItem>> extends Omit<DropdownMenuRootProps, 'dir'> {
37
+ /**
38
+ * @defaultValue 'md'
39
+ */
40
+ size?: DropdownMenu['variants']['size'];
41
+ items?: T;
42
+ /**
43
+ * The icon displayed when an item is checked.
44
+ * @defaultValue appConfig.ui.icons.check
45
+ * @IconifyIcon
46
+ */
47
+ checkedIcon?: IconProps['name'];
48
+ /**
49
+ * The icon displayed when an item is loading.
50
+ * @defaultValue appConfig.ui.icons.loading
51
+ * @IconifyIcon
52
+ */
53
+ loadingIcon?: IconProps['name'];
54
+ /**
55
+ * The icon displayed when the item is an external link.
56
+ * Set to `false` to hide the external icon.
57
+ * @defaultValue appConfig.ui.icons.external
58
+ * @IconifyIcon
59
+ */
60
+ externalIcon?: boolean | IconProps['name'];
61
+ /**
62
+ * The content of the menu.
63
+ * @defaultValue { side: 'bottom', sideOffset: 8, collisionPadding: 8 }
64
+ */
65
+ content?: Omit<DropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> & Partial<EmitsToProps<DropdownMenuContentEmits>>;
66
+ /**
67
+ * Display an arrow alongside the menu.
68
+ * @defaultValue false
69
+ */
70
+ arrow?: boolean | Omit<DropdownMenuArrowProps, 'as' | 'asChild'>;
71
+ /**
72
+ * Render the menu in a portal.
73
+ * @defaultValue true
74
+ */
75
+ portal?: boolean | string | HTMLElement;
76
+ /**
77
+ * The key used to get the label from the item.
78
+ * @defaultValue 'label'
79
+ */
80
+ labelKey?: GetItemKeys<T>;
81
+ disabled?: boolean;
82
+ class?: any;
83
+ ui?: DropdownMenu['slots'];
84
+ }
85
+ export interface DropdownMenuEmits extends DropdownMenuRootEmits {
86
+ }
87
+ type SlotProps<T extends DropdownMenuItem> = (props: {
88
+ item: T;
89
+ active?: boolean;
90
+ index: number;
91
+ }) => any;
92
+ export type DropdownMenuSlots<A extends ArrayOrNested<DropdownMenuItem> = ArrayOrNested<DropdownMenuItem>, T extends NestedItem<A> = NestedItem<A>> = {
93
+ 'default'(props: {
94
+ open: boolean;
95
+ }): any;
96
+ 'item': SlotProps<T>;
97
+ 'item-leading': SlotProps<T>;
98
+ 'item-label': SlotProps<T>;
99
+ 'item-trailing': SlotProps<T>;
100
+ 'content-top': (props?: {}) => any;
101
+ 'content-bottom': (props?: {}) => any;
102
+ } & DynamicSlots<MergeTypes<T>, 'leading' | 'label' | 'trailing', {
103
+ active?: boolean;
104
+ index: number;
105
+ }>;
106
+ declare const _default: <T extends ArrayOrNested<DropdownMenuItem>>(__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<{
107
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
108
+ readonly "onUpdate:open"?: ((payload: boolean) => any) | undefined;
109
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:open"> & DropdownMenuProps<T> & {}> & import("vue").PublicProps;
110
+ expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
111
+ attrs: any;
112
+ slots: DropdownMenuSlots<T, NestedItem<T>>;
113
+ emit: (evt: "update:open", payload: boolean) => void;
114
+ }>) => import("vue").VNode & {
115
+ __ctx?: Awaited<typeof __VLS_setup>;
116
+ };
117
+ export default _default;
118
+ type __VLS_PrettifyLocal<T> = {
119
+ [K in keyof T as K]: T[K];
120
+ } & {};
@@ -14,9 +14,9 @@ import UDropdownMenuContent from "./DropdownMenuContent.vue";
14
14
  const props = defineProps({
15
15
  size: { type: null, required: false },
16
16
  items: { type: null, required: false },
17
- checkedIcon: { type: String, required: false },
18
- loadingIcon: { type: String, required: false },
19
- externalIcon: { type: [Boolean, String], required: false, default: true },
17
+ checkedIcon: { type: [String, Object], required: false },
18
+ loadingIcon: { type: [String, Object], required: false },
19
+ externalIcon: { type: [Boolean, String, Object], required: false, default: true },
20
20
  content: { type: Object, required: false },
21
21
  arrow: { type: [Boolean, Object], required: false },
22
22
  portal: { type: [Boolean, String], required: false, skipCheck: true, default: true },
@@ -34,7 +34,7 @@ const appConfig = useAppConfig();
34
34
  const rootProps = useForwardPropsEmits(reactivePick(props, "defaultOpen", "open", "modal"), emits);
35
35
  const contentProps = toRef(() => defu(props.content, { side: "bottom", sideOffset: 8, collisionPadding: 8 }));
36
36
  const arrowProps = toRef(() => props.arrow);
37
- const proxySlots = omit(slots, ["default"]);
37
+ const getProxySlots = () => omit(slots, ["default"]);
38
38
  const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.dropdownMenu || {} })({
39
39
  size: props.size
40
40
  }));
@@ -58,7 +58,7 @@ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.dropdownMenu
58
58
  :loading-icon="loadingIcon"
59
59
  :external-icon="externalIcon"
60
60
  >
61
- <template v-for="(_, name) in proxySlots" #[name]="slotData">
61
+ <template v-for="(_, name) in getProxySlots()" #[name]="slotData">
62
62
  <slot :name="name" v-bind="slotData" />
63
63
  </template>
64
64
 
@@ -1,15 +1,16 @@
1
1
  import type { DropdownMenuRootProps, DropdownMenuRootEmits, DropdownMenuContentProps, DropdownMenuContentEmits, DropdownMenuArrowProps } from 'reka-ui';
2
2
  import type { AppConfig } from '@nuxt/schema';
3
3
  import theme from '#build/ui/dropdown-menu';
4
- import type { AvatarProps, KbdProps, LinkProps } from '../types';
5
- import type { ArrayOrNested, DynamicSlots, MergeTypes, NestedItem, EmitsToProps, ComponentConfig } from '../types/utils';
4
+ import type { AvatarProps, IconProps, KbdProps, LinkProps } from '../types';
5
+ import type { ArrayOrNested, DynamicSlots, GetItemKeys, MergeTypes, NestedItem, EmitsToProps } from '../types/utils';
6
+ import type { ComponentConfig } from '../types/tv';
6
7
  type DropdownMenu = ComponentConfig<typeof theme, AppConfig, 'dropdownMenu'>;
7
8
  export interface DropdownMenuItem extends Omit<LinkProps, 'type' | 'raw' | 'custom'> {
8
9
  label?: string;
9
10
  /**
10
11
  * @IconifyIcon
11
12
  */
12
- icon?: string;
13
+ icon?: IconProps['name'];
13
14
  color?: DropdownMenu['variants']['color'];
14
15
  avatar?: AvatarProps;
15
16
  content?: Omit<DropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> & Partial<EmitsToProps<DropdownMenuContentEmits>>;
@@ -43,20 +44,20 @@ export interface DropdownMenuProps<T extends ArrayOrNested<DropdownMenuItem> = A
43
44
  * @defaultValue appConfig.ui.icons.check
44
45
  * @IconifyIcon
45
46
  */
46
- checkedIcon?: string;
47
+ checkedIcon?: IconProps['name'];
47
48
  /**
48
49
  * The icon displayed when an item is loading.
49
50
  * @defaultValue appConfig.ui.icons.loading
50
51
  * @IconifyIcon
51
52
  */
52
- loadingIcon?: string;
53
+ loadingIcon?: IconProps['name'];
53
54
  /**
54
55
  * The icon displayed when the item is an external link.
55
56
  * Set to `false` to hide the external icon.
56
57
  * @defaultValue appConfig.ui.icons.external
57
58
  * @IconifyIcon
58
59
  */
59
- externalIcon?: boolean | string;
60
+ externalIcon?: boolean | IconProps['name'];
60
61
  /**
61
62
  * The content of the menu.
62
63
  * @defaultValue { side: 'bottom', sideOffset: 8, collisionPadding: 8 }
@@ -76,7 +77,7 @@ export interface DropdownMenuProps<T extends ArrayOrNested<DropdownMenuItem> = A
76
77
  * The key used to get the label from the item.
77
78
  * @defaultValue 'label'
78
79
  */
79
- labelKey?: keyof NestedItem<T>;
80
+ labelKey?: GetItemKeys<T>;
80
81
  disabled?: boolean;
81
82
  class?: any;
82
83
  ui?: DropdownMenu['slots'];
@@ -105,7 +106,7 @@ export type DropdownMenuSlots<A extends ArrayOrNested<DropdownMenuItem> = ArrayO
105
106
  declare const _default: <T extends ArrayOrNested<DropdownMenuItem>>(__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<{
106
107
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
107
108
  readonly "onUpdate:open"?: ((payload: boolean) => any) | undefined;
108
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:open"> & DropdownMenuProps<T> & Partial<{}>> & import("vue").PublicProps;
109
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:open"> & DropdownMenuProps<T> & {}> & import("vue").PublicProps;
109
110
  expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
110
111
  attrs: any;
111
112
  slots: DropdownMenuSlots<T, NestedItem<T>>;
@@ -0,0 +1,56 @@
1
+ import { DropdownMenu } from 'reka-ui/namespaced';
2
+ import type { DropdownMenuContentProps as RekaDropdownMenuContentProps } from 'reka-ui';
3
+ import type { AppConfig } from '@nuxt/schema';
4
+ import type theme from '#build/ui/dropdown-menu';
5
+ import type { DropdownMenuItem, DropdownMenuSlots, IconProps } from '../types';
6
+ import type { ArrayOrNested, GetItemKeys, NestedItem, DynamicSlots, MergeTypes } from '../types/utils';
7
+ import type { ComponentConfig } from '../types/tv';
8
+ type DropdownMenu = ComponentConfig<typeof theme, AppConfig, 'dropdownMenu'>;
9
+ interface DropdownMenuContentProps<T extends ArrayOrNested<DropdownMenuItem>> extends Omit<RekaDropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> {
10
+ items?: T;
11
+ portal?: boolean | string | HTMLElement;
12
+ sub?: boolean;
13
+ labelKey: GetItemKeys<T>;
14
+ /**
15
+ * @IconifyIcon
16
+ */
17
+ checkedIcon?: IconProps['name'];
18
+ /**
19
+ * @IconifyIcon
20
+ */
21
+ loadingIcon?: IconProps['name'];
22
+ /**
23
+ * @IconifyIcon
24
+ */
25
+ externalIcon?: boolean | IconProps['name'];
26
+ class?: any;
27
+ ui: {
28
+ [K in keyof Required<DropdownMenu['slots']>]: (props?: Record<string, any>) => string;
29
+ };
30
+ uiOverride?: DropdownMenu['slots'];
31
+ }
32
+ type DropdownMenuContentSlots<A extends ArrayOrNested<DropdownMenuItem> = ArrayOrNested<DropdownMenuItem>, T extends NestedItem<A> = NestedItem<A>> = Pick<DropdownMenuSlots<A>, 'item' | 'item-leading' | 'item-label' | 'item-trailing' | 'content-top' | 'content-bottom'> & {
33
+ default(props?: {}): any;
34
+ } & DynamicSlots<MergeTypes<T>, 'leading' | 'label' | 'trailing', {
35
+ active?: boolean;
36
+ index: number;
37
+ }>;
38
+ declare const _default: <T extends ArrayOrNested<DropdownMenuItem>>(__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<{
39
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
40
+ readonly onEscapeKeyDown?: ((event: KeyboardEvent) => any) | undefined;
41
+ readonly onPointerDownOutside?: ((event: import("reka-ui").PointerDownOutsideEvent) => any) | undefined;
42
+ readonly onFocusOutside?: ((event: import("reka-ui").FocusOutsideEvent) => any) | undefined;
43
+ readonly onInteractOutside?: ((event: import("reka-ui").PointerDownOutsideEvent | import("reka-ui").FocusOutsideEvent) => any) | undefined;
44
+ readonly onCloseAutoFocus?: ((event: Event) => any) | undefined;
45
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onEscapeKeyDown" | "onPointerDownOutside" | "onFocusOutside" | "onInteractOutside" | "onCloseAutoFocus"> & DropdownMenuContentProps<T> & {}> & import("vue").PublicProps;
46
+ expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
47
+ attrs: any;
48
+ slots: DropdownMenuContentSlots<T, NestedItem<T>>;
49
+ emit: ((evt: "escapeKeyDown", event: KeyboardEvent) => void) & ((evt: "pointerDownOutside", event: import("reka-ui").PointerDownOutsideEvent) => void) & ((evt: "focusOutside", event: import("reka-ui").FocusOutsideEvent) => void) & ((evt: "interactOutside", event: import("reka-ui").PointerDownOutsideEvent | import("reka-ui").FocusOutsideEvent) => void) & ((evt: "closeAutoFocus", event: Event) => void);
50
+ }>) => import("vue").VNode & {
51
+ __ctx?: Awaited<typeof __VLS_setup>;
52
+ };
53
+ export default _default;
54
+ type __VLS_PrettifyLocal<T> = {
55
+ [K in keyof T as K]: T[K];
56
+ } & {};
@@ -23,17 +23,19 @@ const props = defineProps({
23
23
  portal: { type: [Boolean, String], required: false, skipCheck: true },
24
24
  sub: { type: Boolean, required: false },
25
25
  labelKey: { type: null, required: true },
26
- checkedIcon: { type: String, required: false },
27
- loadingIcon: { type: String, required: false },
28
- externalIcon: { type: [Boolean, String], required: false },
26
+ checkedIcon: { type: [String, Object], required: false },
27
+ loadingIcon: { type: [String, Object], required: false },
28
+ externalIcon: { type: [Boolean, String, Object], required: false },
29
29
  class: { type: null, required: false },
30
30
  ui: { type: null, required: true },
31
31
  uiOverride: { type: null, required: false },
32
32
  loop: { type: Boolean, required: false },
33
33
  side: { type: null, required: false },
34
34
  sideOffset: { type: Number, required: false },
35
+ sideFlip: { type: Boolean, required: false },
35
36
  align: { type: null, required: false },
36
37
  alignOffset: { type: Number, required: false },
38
+ alignFlip: { type: Boolean, required: false },
37
39
  avoidCollisions: { type: Boolean, required: false },
38
40
  collisionBoundary: { type: null, required: false },
39
41
  collisionPadding: { type: [Number, Object], required: false },
@@ -52,7 +54,7 @@ const { dir } = useLocale();
52
54
  const appConfig = useAppConfig();
53
55
  const portalProps = usePortal(toRef(() => props.portal));
54
56
  const contentProps = useForwardPropsEmits(reactiveOmit(props, "sub", "items", "portal", "labelKey", "checkedIcon", "loadingIcon", "externalIcon", "class", "ui", "uiOverride"), emits);
55
- const proxySlots = omit(slots, ["default"]);
57
+ const getProxySlots = () => omit(slots, ["default"]);
56
58
  const [DefineItemTemplate, ReuseItemTemplate] = createReusableTemplate();
57
59
  const childrenIcon = computed(() => dir.value === "rtl" ? appConfig.ui.icons.chevronLeft : appConfig.ui.icons.chevronRight);
58
60
  const groups = computed(
@@ -66,7 +68,7 @@ const groups = computed(
66
68
  <slot :name="item.slot ? `${item.slot}-leading` : 'item-leading'" :item="item" :active="active" :index="index">
67
69
  <UIcon v-if="item.loading" :name="loadingIcon || appConfig.ui.icons.loading" :class="ui.itemLeadingIcon({ class: [uiOverride?.itemLeadingIcon, item.ui?.itemLeadingIcon], color: item?.color, loading: true })" />
68
70
  <UIcon v-else-if="item.icon" :name="item.icon" :class="ui.itemLeadingIcon({ class: [uiOverride?.itemLeadingIcon, item.ui?.itemLeadingIcon], color: item?.color, active })" />
69
- <UAvatar v-else-if="item.avatar" :size="item.ui?.itemLeadingAvatarSize || props.uiOverride?.itemLeadingAvatarSize || ui.itemLeadingAvatarSize()" v-bind="item.avatar" :class="ui.itemLeadingAvatar({ class: [uiOverride?.itemLeadingAvatar, item.ui?.itemLeadingAvatar], active })" />
71
+ <UAvatar v-else-if="item.avatar" :size="item.ui?.itemLeadingAvatarSize || uiOverride?.itemLeadingAvatarSize || ui.itemLeadingAvatarSize()" v-bind="item.avatar" :class="ui.itemLeadingAvatar({ class: [uiOverride?.itemLeadingAvatar, item.ui?.itemLeadingAvatar], active })" />
70
72
  </slot>
71
73
 
72
74
  <span v-if="get(item, props.labelKey) || !!slots[item.slot ? `${item.slot}-label` : 'item-label']" :class="ui.itemLabel({ class: [uiOverride?.itemLabel, item.ui?.itemLabel], active })">
@@ -81,7 +83,7 @@ const groups = computed(
81
83
  <slot :name="item.slot ? `${item.slot}-trailing` : 'item-trailing'" :item="item" :active="active" :index="index">
82
84
  <UIcon v-if="item.children?.length" :name="childrenIcon" :class="ui.itemTrailingIcon({ class: [uiOverride?.itemTrailingIcon, item.ui?.itemTrailingIcon], color: item?.color, active })" />
83
85
  <span v-else-if="item.kbds?.length" :class="ui.itemTrailingKbds({ class: [uiOverride?.itemTrailingKbds, item.ui?.itemTrailingKbds] })">
84
- <UKbd v-for="(kbd, kbdIndex) in item.kbds" :key="kbdIndex" :size="item.ui?.itemTrailingKbdsSize || props.uiOverride?.itemTrailingKbdsSize || ui.itemTrailingKbdsSize()" v-bind="typeof kbd === 'string' ? { value: kbd } : kbd" />
86
+ <UKbd v-for="(kbd, kbdIndex) in item.kbds" :key="kbdIndex" :size="item.ui?.itemTrailingKbdsSize || uiOverride?.itemTrailingKbdsSize || ui.itemTrailingKbdsSize()" v-bind="typeof kbd === 'string' ? { value: kbd } : kbd" />
85
87
  </span>
86
88
  </slot>
87
89
 
@@ -96,7 +98,7 @@ const groups = computed(
96
98
  <component :is="sub ? DropdownMenu.SubContent : DropdownMenu.Content" :class="props.class" v-bind="contentProps">
97
99
  <slot name="content-top" />
98
100
 
99
- <div role="presentation" :class="ui.viewport({ class: props.ui?.viewport })">
101
+ <div role="presentation" :class="ui.viewport({ class: uiOverride?.viewport })">
100
102
  <DropdownMenu.Group v-for="(group, groupIndex) in groups" :key="`group-${groupIndex}`" :class="ui.group({ class: uiOverride?.group })">
101
103
  <template v-for="(item, index) in group" :key="`group-${groupIndex}-${index}`">
102
104
  <DropdownMenu.Label v-if="item.type === 'label'" :class="ui.label({ class: [uiOverride?.label, item.ui?.label, item.class] })">
@@ -130,7 +132,7 @@ const groups = computed(
130
132
  :external-icon="externalIcon"
131
133
  v-bind="item.content"
132
134
  >
133
- <template v-for="(_, name) in proxySlots" #[name]="slotData">
135
+ <template v-for="(_, name) in getProxySlots()" #[name]="slotData">
134
136
  <slot :name="name" v-bind="slotData" />
135
137
  </template>
136
138
  </UDropdownMenuContent>
@@ -2,26 +2,27 @@ import { DropdownMenu } from 'reka-ui/namespaced';
2
2
  import type { DropdownMenuContentProps as RekaDropdownMenuContentProps } from 'reka-ui';
3
3
  import type { AppConfig } from '@nuxt/schema';
4
4
  import type theme from '#build/ui/dropdown-menu';
5
- import type { DropdownMenuItem, DropdownMenuSlots, DynamicSlots, MergeTypes } from '../types';
6
- import type { ArrayOrNested, NestedItem, ComponentConfig } from '../types/utils';
5
+ import type { DropdownMenuItem, DropdownMenuSlots, IconProps } from '../types';
6
+ import type { ArrayOrNested, GetItemKeys, NestedItem, DynamicSlots, MergeTypes } from '../types/utils';
7
+ import type { ComponentConfig } from '../types/tv';
7
8
  type DropdownMenu = ComponentConfig<typeof theme, AppConfig, 'dropdownMenu'>;
8
9
  interface DropdownMenuContentProps<T extends ArrayOrNested<DropdownMenuItem>> extends Omit<RekaDropdownMenuContentProps, 'as' | 'asChild' | 'forceMount'> {
9
10
  items?: T;
10
11
  portal?: boolean | string | HTMLElement;
11
12
  sub?: boolean;
12
- labelKey: keyof NestedItem<T>;
13
+ labelKey: GetItemKeys<T>;
13
14
  /**
14
15
  * @IconifyIcon
15
16
  */
16
- checkedIcon?: string;
17
+ checkedIcon?: IconProps['name'];
17
18
  /**
18
19
  * @IconifyIcon
19
20
  */
20
- loadingIcon?: string;
21
+ loadingIcon?: IconProps['name'];
21
22
  /**
22
23
  * @IconifyIcon
23
24
  */
24
- externalIcon?: boolean | string;
25
+ externalIcon?: boolean | IconProps['name'];
25
26
  class?: any;
26
27
  ui: {
27
28
  [K in keyof Required<DropdownMenu['slots']>]: (props?: Record<string, any>) => string;
@@ -41,7 +42,7 @@ declare const _default: <T extends ArrayOrNested<DropdownMenuItem>>(__VLS_props:
41
42
  readonly onFocusOutside?: ((event: import("reka-ui").FocusOutsideEvent) => any) | undefined;
42
43
  readonly onInteractOutside?: ((event: import("reka-ui").PointerDownOutsideEvent | import("reka-ui").FocusOutsideEvent) => any) | undefined;
43
44
  readonly onCloseAutoFocus?: ((event: Event) => any) | undefined;
44
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onEscapeKeyDown" | "onPointerDownOutside" | "onFocusOutside" | "onInteractOutside" | "onCloseAutoFocus"> & DropdownMenuContentProps<T> & Partial<{}>> & import("vue").PublicProps;
45
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onEscapeKeyDown" | "onPointerDownOutside" | "onFocusOutside" | "onInteractOutside" | "onCloseAutoFocus"> & DropdownMenuContentProps<T> & {}> & import("vue").PublicProps;
45
46
  expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
46
47
  attrs: any;
47
48
  slots: DropdownMenuContentSlots<T, NestedItem<T>>;
@@ -0,0 +1,47 @@
1
+ import type { AppConfig } from '@nuxt/schema';
2
+ import type { NuxtError } from '#app';
3
+ import theme from '#build/ui/error';
4
+ import type { ButtonProps } from '../types';
5
+ import type { ComponentConfig } from '../types/tv';
6
+ type Error = ComponentConfig<typeof theme, AppConfig, 'error'>;
7
+ export interface ErrorProps {
8
+ /**
9
+ * The element or component this component should render as.
10
+ * @defaultValue 'div'
11
+ */
12
+ as?: any;
13
+ error?: Partial<NuxtError & {
14
+ message: string;
15
+ }>;
16
+ /**
17
+ * The URL to redirect to when the error is cleared.
18
+ * @defaultValue '/'
19
+ */
20
+ redirect?: string;
21
+ /**
22
+ * Display a button to clear the error in the links slot.
23
+ * `{ size: 'lg', color: 'primary', variant: 'solid', label: 'Back to home' }`{lang="ts-type"}
24
+ * @defaultValue true
25
+ */
26
+ clear?: boolean | Partial<ButtonProps>;
27
+ class?: any;
28
+ ui?: Error['slots'];
29
+ }
30
+ export interface ErrorSlots {
31
+ default(props?: {}): any;
32
+ statusCode(props?: {}): any;
33
+ statusMessage(props?: {}): any;
34
+ message(props?: {}): any;
35
+ links(props?: {}): any;
36
+ }
37
+ declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ErrorProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ErrorProps> & Readonly<{}>, {
38
+ clear: boolean | Partial<ButtonProps>;
39
+ as: any;
40
+ redirect: string;
41
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ErrorSlots>;
42
+ export default _default;
43
+ type __VLS_WithSlots<T, S> = T & {
44
+ new (): {
45
+ $slots: S;
46
+ };
47
+ };
@@ -5,53 +5,56 @@ import theme from "#build/ui/error";
5
5
  <script setup>
6
6
  import { computed } from "vue";
7
7
  import { Primitive } from "reka-ui";
8
- import { useAppConfig, useRouter } from "#imports";
9
- import { useLocalePro } from "../composables/useLocalePro";
8
+ import { clearError, useAppConfig } from "#imports";
9
+ import { useLocale } from "../composables/useLocale";
10
10
  import { tv } from "../utils/tv";
11
11
  import UButton from "./Button.vue";
12
12
  const props = defineProps({
13
13
  as: { type: null, required: false, default: "main" },
14
- error: { type: Object, required: false, default: () => ({}) },
14
+ error: { type: Object, required: false },
15
15
  redirect: { type: String, required: false, default: "/" },
16
16
  clear: { type: [Boolean, Object], required: false, default: true },
17
17
  class: { type: null, required: false },
18
18
  ui: { type: null, required: false }
19
19
  });
20
- const emit = defineEmits(["clear"]);
21
- defineSlots();
22
- const { t } = useLocalePro();
20
+ const slots = defineSlots();
21
+ const { t } = useLocale();
23
22
  const appConfig = useAppConfig();
24
- const router = useRouter();
25
- const uiPro = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.error || {} })());
26
- const handleError = () => {
27
- if (props.error) {
28
- emit("clear");
29
- }
30
- router.push(props.redirect);
31
- };
23
+ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.error || {} })());
24
+ function handleError() {
25
+ clearError({ redirect: props.redirect });
26
+ }
32
27
  </script>
33
28
 
34
29
  <template>
35
- <Primitive :as="as" :class="uiPro.root({ class: [props.ui?.root, props.class] })">
36
- <p :class="uiPro.statusCode({ class: props.ui?.statusCode })">
37
- {{ props.error?.statusCode }}
30
+ <Primitive :as="as" :class="ui.root({ class: [props.ui?.root, props.class] })">
31
+ <p v-if="!!props.error?.statusCode || !!slots.statusCode" :class="ui.statusCode({ class: props.ui?.statusCode })">
32
+ <slot name="statusCode">
33
+ {{ props.error?.statusCode }}
34
+ </slot>
38
35
  </p>
39
- <h1 v-if="props.error?.statusMessage" :class="uiPro.statusMessage({ class: props.ui?.statusMessage })">
40
- {{ props.error.statusMessage }}
36
+ <h1 v-if="!!props.error?.statusMessage || !!slots.statusMessage" :class="ui.statusMessage({ class: props.ui?.statusMessage })">
37
+ <slot name="statusMessage">
38
+ {{ props.error?.statusMessage }}
39
+ </slot>
41
40
  </h1>
42
- <p v-if="props.error?.message && props.error.message !== props.error.statusMessage" :class="uiPro.message({ class: props.ui?.message })">
43
- {{ props.error?.message }}
41
+ <p v-if="props.error?.message && props.error.message !== props.error.statusMessage || !!slots.message" :class="ui.message({ class: props.ui?.message })">
42
+ <slot name="message">
43
+ {{ props.error?.message }}
44
+ </slot>
44
45
  </p>
45
- <div :class="uiPro.links({ class: props.ui?.links })">
46
- <UButton
47
- v-if="clear"
48
- size="lg"
49
- color="primary"
50
- variant="solid"
51
- :label="t('error.clear')"
52
- v-bind="typeof clear === 'object' ? clear : {}"
53
- @click="handleError"
54
- />
46
+ <div v-if="!!clear || !!slots.links" :class="ui.links({ class: props.ui?.links })">
47
+ <slot name="links">
48
+ <UButton
49
+ v-if="clear"
50
+ size="lg"
51
+ color="primary"
52
+ variant="solid"
53
+ :label="t('error.clear')"
54
+ v-bind="typeof clear === 'object' ? clear : {}"
55
+ @click="handleError"
56
+ />
57
+ </slot>
55
58
  </div>
56
59
  </Primitive>
57
60
  </template>
@@ -1,12 +1,13 @@
1
1
  import type { AppConfig } from '@nuxt/schema';
2
- import type { ButtonProps, ComponentConfig } from '../types';
3
2
  import type { NuxtError } from '#app';
4
3
  import theme from '#build/ui/error';
4
+ import type { ButtonProps } from '../types';
5
+ import type { ComponentConfig } from '../types/tv';
5
6
  type Error = ComponentConfig<typeof theme, AppConfig, 'error'>;
6
7
  export interface ErrorProps {
7
8
  /**
8
9
  * The element or component this component should render as.
9
- * @defaultValue 'main'
10
+ * @defaultValue 'div'
10
11
  */
11
12
  as?: any;
12
13
  error?: Partial<NuxtError & {
@@ -30,16 +31,10 @@ export interface ErrorSlots {
30
31
  default(props?: {}): any;
31
32
  statusCode(props?: {}): any;
32
33
  statusMessage(props?: {}): any;
34
+ message(props?: {}): any;
33
35
  links(props?: {}): any;
34
36
  }
35
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ErrorProps, void, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
36
- clear: () => any;
37
- }, string, import("vue").PublicProps, Readonly<ErrorProps> & Readonly<{
38
- onClear?: (() => any) | undefined;
39
- }>, {
40
- error: Partial<NuxtError & {
41
- message: string;
42
- }>;
37
+ declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ErrorProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<ErrorProps> & Readonly<{}>, {
43
38
  clear: boolean | Partial<ButtonProps>;
44
39
  as: any;
45
40
  redirect: string;
@@ -0,0 +1,34 @@
1
+ import type { AppConfig } from '@nuxt/schema';
2
+ import theme from '#build/ui/field-group';
3
+ import type { ComponentConfig } from '../types/tv';
4
+ type FieldGroup = ComponentConfig<typeof theme, AppConfig, 'fieldGroup'>;
5
+ export interface FieldGroupProps {
6
+ /**
7
+ * The element or component this component should render as.
8
+ * @defaultValue 'div'
9
+ */
10
+ as?: any;
11
+ /**
12
+ * @defaultValue 'md'
13
+ */
14
+ size?: FieldGroup['variants']['size'];
15
+ /**
16
+ * The orientation the buttons are laid out.
17
+ * @defaultValue 'horizontal'
18
+ */
19
+ orientation?: FieldGroup['variants']['orientation'];
20
+ class?: any;
21
+ ui?: FieldGroup['slots'];
22
+ }
23
+ export interface FieldGroupSlots {
24
+ default(props?: {}): any;
25
+ }
26
+ declare const _default: __VLS_WithSlots<import("vue").DefineComponent<FieldGroupProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<FieldGroupProps> & Readonly<{}>, {
27
+ orientation: FieldGroup["variants"]["orientation"];
28
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, FieldGroupSlots>;
29
+ export default _default;
30
+ type __VLS_WithSlots<T, S> = T & {
31
+ new (): {
32
+ $slots: S;
33
+ };
34
+ };
@@ -1,12 +1,12 @@
1
1
  <script>
2
- import theme from "#build/ui/button-group";
2
+ import theme from "#build/ui/field-group";
3
3
  </script>
4
4
 
5
5
  <script setup>
6
6
  import { provide, computed } from "vue";
7
7
  import { Primitive } from "reka-ui";
8
8
  import { useAppConfig } from "#imports";
9
- import { buttonGroupInjectionKey } from "../composables/useButtonGroup";
9
+ import { fieldGroupInjectionKey } from "../composables/useFieldGroup";
10
10
  import { tv } from "../utils/tv";
11
11
  const props = defineProps({
12
12
  as: { type: null, required: false },
@@ -17,8 +17,8 @@ const props = defineProps({
17
17
  });
18
18
  defineSlots();
19
19
  const appConfig = useAppConfig();
20
- const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.buttonGroup || {} }));
21
- provide(buttonGroupInjectionKey, computed(() => ({
20
+ const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.fieldGroup || {} }));
21
+ provide(fieldGroupInjectionKey, computed(() => ({
22
22
  orientation: props.orientation,
23
23
  size: props.size
24
24
  })));