@eslamdevui/ui 3.3.4 → 4.0.0-beta

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
@@ -7,8 +7,12 @@ import { computed } from "vue";
7
7
  import { Primitive } from "reka-ui";
8
8
  import { createReusableTemplate } from "@vueuse/core";
9
9
  import { useAppConfig } from "#imports";
10
- import { useLocalePro } from "../composables/useLocalePro";
10
+ import { useLocale } from "../composables/useLocale";
11
11
  import { tv } from "../utils/tv";
12
+ import UBadge from "./Badge.vue";
13
+ import UButton from "./Button.vue";
14
+ import UIcon from "./Icon.vue";
15
+ defineOptions({ inheritAttrs: false });
12
16
  const props = defineProps({
13
17
  as: { type: null, required: false },
14
18
  caption: { type: String, required: false },
@@ -18,7 +22,7 @@ const props = defineProps({
18
22
  ui: { type: null, required: false }
19
23
  });
20
24
  const slots = defineSlots();
21
- const { t } = useLocalePro();
25
+ const { t } = useLocale();
22
26
  const appConfig = useAppConfig();
23
27
  const formatSlotName = (item) => {
24
28
  if (item.id) return item.id;
@@ -64,10 +68,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
64
68
  </slot>
65
69
  </div>
66
70
 
67
- <div
68
- v-if="tier.description || !!slots['tier-description'] || !!slots[`${tier.id}-description`]"
69
- :class="ui.tierDescription({ class: props.ui?.tierDescription })"
70
- >
71
+ <div v-if="tier.description || !!slots['tier-description'] || !!slots[`${tier.id}-description`]" :class="ui.tierDescription({ class: props.ui?.tierDescription })">
71
72
  <slot :name="`${tier.id}-description`" :tier="tier">
72
73
  <slot name="tier-description" :tier="tier">
73
74
  {{ tier.description }}
@@ -75,14 +76,8 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
75
76
  </slot>
76
77
  </div>
77
78
 
78
- <div
79
- v-if="tier.discount || tier.price || !!slots['tier-discount'] || !!slots[`${tier.id}-discount`] || !!slots['tier-price'] || !!slots[`${tier.id}-price`] || tier.billingCycle || tier.billingPeriod || !!slots['tier-billing'] || !!slots[`${tier.id}-billing`]"
80
- :class="ui.tierPriceWrapper({ class: props.ui?.tierPriceWrapper })"
81
- >
82
- <div
83
- v-if="tier.discount && tier.price || !!slots[`${tier.id}-discount`] || !!slots['tier-discount']"
84
- :class="ui.tierDiscount({ class: props.ui?.tierDiscount })"
85
- >
79
+ <div v-if="tier.discount || tier.price || !!slots['tier-discount'] || !!slots[`${tier.id}-discount`] || !!slots['tier-price'] || !!slots[`${tier.id}-price`] || tier.billingCycle || tier.billingPeriod || !!slots['tier-billing'] || !!slots[`${tier.id}-billing`]" :class="ui.tierPriceWrapper({ class: props.ui?.tierPriceWrapper })">
80
+ <div v-if="tier.discount && tier.price || !!slots[`${tier.id}-discount`] || !!slots['tier-discount']" :class="ui.tierDiscount({ class: props.ui?.tierDiscount })">
86
81
  <slot :name="`${tier.id}-discount`" :tier="tier">
87
82
  <slot name="tier-discount" :tier="tier">
88
83
  {{ tier.price }}
@@ -90,10 +85,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
90
85
  </slot>
91
86
  </div>
92
87
 
93
- <div
94
- v-if="tier.discount || tier.price || !!slots[`${tier.id}-price`] || !!slots['tier-price']"
95
- :class="ui.tierPrice({ class: props.ui?.tierPrice })"
96
- >
88
+ <div v-if="tier.discount || tier.price || !!slots[`${tier.id}-price`] || !!slots['tier-price']" :class="ui.tierPrice({ class: props.ui?.tierPrice })">
97
89
  <slot :name="`${tier.id}-price`" :tier="tier">
98
90
  <slot name="tier-price" :tier="tier">
99
91
  {{ tier.discount || tier.price }}
@@ -101,10 +93,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
101
93
  </slot>
102
94
  </div>
103
95
 
104
- <div
105
- v-if="tier.billingCycle || tier.billingPeriod || !!slots[`${tier.id}-billing`] || !!slots['tier-billing']"
106
- :class="ui.tierBilling({ class: props.ui?.tierBilling })"
107
- >
96
+ <div v-if="tier.billingCycle || tier.billingPeriod || !!slots[`${tier.id}-billing`] || !!slots['tier-billing']" :class="ui.tierBilling({ class: props.ui?.tierBilling })">
108
97
  <slot :name="`${tier.id}-billing`" :tier="tier">
109
98
  <slot name="tier-billing" :tier="tier">
110
99
  <span :class="ui.tierBillingPeriod({ class: props.ui?.tierBillingPeriod })">
@@ -119,10 +108,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
119
108
  </div>
120
109
  </div>
121
110
 
122
- <div
123
- v-if="!!slots[`${tier.id}-button`] || !!slots['tier-button'] || tier.button"
124
- :class="ui.tierButton({ class: props.ui?.tierButton })"
125
- >
111
+ <div v-if="!!slots[`${tier.id}-button`] || !!slots['tier-button'] || tier.button" :class="ui.tierButton({ class: props.ui?.tierButton })">
126
112
  <slot :name="`${tier.id}-button`" :tier="tier">
127
113
  <slot name="tier-button" :tier="tier">
128
114
  <UButton v-if="tier.button" block size="lg" v-bind="tier.button" />
@@ -135,11 +121,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
135
121
 
136
122
  <DefineFeatureTemplate v-slot="{ feature, tier }">
137
123
  <template v-if="feature.tiers?.[tier.id]">
138
- <UIcon
139
- v-if="typeof feature.tiers[tier.id] === 'boolean'"
140
- :name="appConfig.ui.icons.success"
141
- :class="ui.tierFeatureIcon({ class: props.ui?.tierFeatureIcon, active: true })"
142
- />
124
+ <UIcon v-if="typeof feature.tiers[tier.id] === 'boolean'" :name="appConfig.ui.icons.success" :class="ui.tierFeatureIcon({ class: props.ui?.tierFeatureIcon, active: true })" />
143
125
  <template v-else>
144
126
  {{ feature.tiers[tier.id] }}
145
127
  </template>
@@ -148,7 +130,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
148
130
  <UIcon v-else :name="appConfig.ui.icons.minus" :class="ui.tierFeatureIcon({ class: props.ui?.tierFeatureIcon })" />
149
131
  </DefineFeatureTemplate>
150
132
 
151
- <Primitive :as="as" :class="ui.root({ class: [props.ui?.root, props.class] })">
133
+ <Primitive :as="as" v-bind="$attrs" :class="ui.root({ class: [props.ui?.root, props.class] })">
152
134
  <table :class="ui.table({ class: props.ui?.table })">
153
135
  <caption v-if="caption || !!slots.caption" :class="ui.caption({ class: [props.ui?.caption] })">
154
136
  <slot name="caption">
@@ -175,10 +157,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
175
157
  <template v-for="(section, sectionIndex) in sections" :key="sectionIndex">
176
158
  <tr :class="ui.tr({ class: props.ui?.tr, section: sectionIndex > 0 })">
177
159
  <th scope="row" :class="ui.th({ class: props.ui?.th })">
178
- <div
179
- v-if="section.title || !!slots['section-title'] || !!slots[`section-${formatSlotName(section)}-title`]"
180
- :class="ui.sectionTitle({ class: props.ui?.sectionTitle })"
181
- >
160
+ <div v-if="section.title || !!slots['section-title'] || !!slots[`section-${formatSlotName(section)}-title`]" :class="ui.sectionTitle({ class: props.ui?.sectionTitle })">
182
161
  <slot :name="`section-${formatSlotName(section)}-title`" :section="section">
183
162
  <slot name="section-title" :section="section">
184
163
  {{ section.title }}
@@ -197,13 +176,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
197
176
  <tr v-for="(feature, featureIndex) in section.features" :key="`${sectionIndex}-feature-${featureIndex}`">
198
177
  <th scope="row" :class="ui.th({ class: props.ui?.th })">
199
178
  <div :class="ui.featureTitle({ class: props.ui?.featureTitle })">
200
- <!-- Fixed: Added tier parameter to match FeatureDynamicSlots type -->
201
- <slot
202
- :name="`feature-${formatSlotName(feature)}-title`"
203
- :feature="feature"
204
- :tier="tiers[0]"
205
- :section="section"
206
- >
179
+ <slot :name="`feature-${formatSlotName(feature)}-title`" :feature="feature" :section="section">
207
180
  <slot name="feature-title" :feature="feature" :section="section">
208
181
  {{ feature.title }}
209
182
  </slot>
@@ -217,12 +190,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
217
190
  :class="ui.td({ class: props.ui?.td, highlight: tier.highlight })"
218
191
  >
219
192
  <div :class="ui.featureValue({ class: props.ui?.featureValue })">
220
- <slot
221
- :name="`feature-${formatSlotName(feature)}-value`"
222
- :feature="feature"
223
- :tier="tier"
224
- :section="section"
225
- >
193
+ <slot :name="`feature-${formatSlotName(feature)}-value`" :feature="feature" :tier="tier" :section="section">
226
194
  <slot name="feature-value" :feature="feature" :tier="tier" :section="section">
227
195
  <ReuseFeatureTemplate :tier="tier" :feature="feature" />
228
196
  </slot>
@@ -235,18 +203,10 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
235
203
  </table>
236
204
 
237
205
  <ul :class="ui.list({ class: props.ui?.list })">
238
- <li
239
- v-for="(tier, index) in tiers"
240
- :key="index"
241
- :class="ui.item({ class: props.ui?.item, highlight: tier.highlight })"
242
- >
206
+ <li v-for="(tier, index) in tiers" :key="index" :class="ui.item({ class: props.ui?.item, highlight: tier.highlight })">
243
207
  <ReuseTierTemplate :tier="tier" />
244
208
 
245
- <div
246
- v-for="(section, sectionIndex) in sections"
247
- :key="`section-${sectionIndex}`"
248
- :class="ui.section({ class: props.ui?.section })"
249
- >
209
+ <div v-for="(section, sectionIndex) in sections" :key="`section-${sectionIndex}`" :class="ui.section({ class: props.ui?.section })">
250
210
  <div v-if="section.title" :class="ui.sectionTitle({ class: props.ui?.sectionTitle })">
251
211
  <slot :name="`section-${formatSlotName(section)}-title`" :section="section">
252
212
  <slot name="section-title" :section="section">
@@ -255,19 +215,9 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
255
215
  </slot>
256
216
  </div>
257
217
 
258
- <div
259
- v-for="(feature, featureIndex) in section.features"
260
- :key="`section-${sectionIndex}-feature-${featureIndex}`"
261
- :class="ui.feature({ class: props.ui?.feature })"
262
- >
218
+ <div v-for="(feature, featureIndex) in section.features" :key="`section-${sectionIndex}-feature-${featureIndex}`" :class="ui.feature({ class: props.ui?.feature })">
263
219
  <div :class="ui.featureTitle({ class: props.ui?.featureTitle })">
264
- <!-- Fixed: Added tier parameter to match FeatureDynamicSlots type -->
265
- <slot
266
- :name="`feature-${formatSlotName(feature)}-title`"
267
- :feature="feature"
268
- :tier="tier"
269
- :section="section"
270
- >
220
+ <slot :name="`feature-${formatSlotName(feature)}-title`" :feature="feature" :section="section">
271
221
  <slot name="feature-title" :feature="feature" :section="section">
272
222
  {{ feature.title }}
273
223
  </slot>
@@ -275,12 +225,7 @@ const [DefineFeatureTemplate, ReuseFeatureTemplate] = createReusableTemplate({
275
225
  </div>
276
226
 
277
227
  <div :class="ui.featureValue({ class: props.ui?.featureValue })">
278
- <slot
279
- :name="`feature-${formatSlotName(feature)}-value`"
280
- :feature="feature"
281
- :tier="tier"
282
- :section="section"
283
- >
228
+ <slot :name="`feature-${formatSlotName(feature)}-value`" :feature="feature" :tier="tier" :section="section">
284
229
  <slot name="feature-value" :feature="feature" :tier="tier" :section="section">
285
230
  <ReuseFeatureTemplate :tier="tier" :feature="feature" />
286
231
  </slot>
@@ -1,6 +1,7 @@
1
- import theme from '#build/ui/pricing-table';
2
1
  import type { AppConfig } from '@nuxt/schema';
3
- import type { ComponentConfig, PricingPlanProps } from '../types';
2
+ import theme from '#build/ui/pricing-table';
3
+ import type { PricingPlanProps } from '../types';
4
+ import type { ComponentConfig } from '../types/tv';
4
5
  type PricingTable = ComponentConfig<typeof theme, AppConfig, 'pricingTable'>;
5
6
  type DynamicSlots<T extends {
6
7
  id: string;
@@ -89,10 +90,16 @@ export type PricingTableSlots<T extends PricingTableTier = PricingTableTier> = {
89
90
  section: PricingTableSection<T>;
90
91
  }) => any;
91
92
  } & DynamicSlots<T, 'title' | 'description' | 'badge' | 'button' | 'billing' | 'discount' | 'price'> & FeatureDynamicSlots<PricingTableSectionFeature<T>, 'title' | 'value'> & SectionDynamicSlots<PricingTableSection<T>, 'title'>;
92
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<PricingTableProps<PricingTableTier>, void, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<PricingTableProps<PricingTableTier>> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, PricingTableSlots<PricingTableTier>>;
93
- export default _default;
94
- type __VLS_WithSlots<T, S> = T & {
95
- new (): {
96
- $slots: S;
97
- };
93
+ declare const _default: <T extends PricingTableTier>(__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<{
94
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{} & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, never> & PricingTableProps<T> & {}> & import("vue").PublicProps;
95
+ expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
96
+ attrs: any;
97
+ slots: PricingTableSlots<T>;
98
+ emit: {};
99
+ }>) => import("vue").VNode & {
100
+ __ctx?: Awaited<typeof __VLS_setup>;
98
101
  };
102
+ export default _default;
103
+ type __VLS_PrettifyLocal<T> = {
104
+ [K in keyof T as K]: T[K];
105
+ } & {};
@@ -0,0 +1,66 @@
1
+ import type { ProgressRootProps, ProgressRootEmits } from 'reka-ui';
2
+ import type { AppConfig } from '@nuxt/schema';
3
+ import theme from '#build/ui/progress';
4
+ import type { ComponentConfig } from '../types/tv';
5
+ type Progress = ComponentConfig<typeof theme, AppConfig, 'progress'>;
6
+ export interface ProgressProps extends Pick<ProgressRootProps, 'getValueLabel' | 'getValueText' | 'modelValue'> {
7
+ /**
8
+ * The element or component this component should render as.
9
+ * @defaultValue 'div'
10
+ */
11
+ as?: any;
12
+ /** The maximum progress value. */
13
+ max?: number | Array<any>;
14
+ /** Display the current progress value. */
15
+ status?: boolean;
16
+ /** Whether the progress is visually inverted. */
17
+ inverted?: boolean;
18
+ /**
19
+ * @defaultValue 'md'
20
+ */
21
+ size?: Progress['variants']['size'];
22
+ /**
23
+ * @defaultValue 'primary'
24
+ */
25
+ color?: Progress['variants']['color'];
26
+ /**
27
+ * The orientation of the progress bar.
28
+ * @defaultValue 'horizontal'
29
+ */
30
+ orientation?: Progress['variants']['orientation'];
31
+ /**
32
+ * The animation of the progress bar.
33
+ * @defaultValue 'carousel'
34
+ */
35
+ animation?: Progress['variants']['animation'];
36
+ class?: any;
37
+ ui?: Progress['slots'];
38
+ }
39
+ export interface ProgressEmits extends ProgressRootEmits {
40
+ }
41
+ export type ProgressSlots = {
42
+ status(props: {
43
+ percent?: number;
44
+ }): any;
45
+ } & {
46
+ [key: string]: (props: {
47
+ step: number;
48
+ }) => any;
49
+ };
50
+ declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ProgressProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
51
+ "update:modelValue": (value: string[] | undefined) => any;
52
+ "update:max": (value: number) => any;
53
+ }, string, import("vue").PublicProps, Readonly<ProgressProps> & Readonly<{
54
+ "onUpdate:modelValue"?: ((value: string[] | undefined) => any) | undefined;
55
+ "onUpdate:max"?: ((value: number) => any) | undefined;
56
+ }>, {
57
+ orientation: Progress["variants"]["orientation"];
58
+ modelValue: number | null;
59
+ inverted: boolean;
60
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, ProgressSlots>;
61
+ export default _default;
62
+ type __VLS_WithSlots<T, S> = T & {
63
+ new (): {
64
+ $slots: S;
65
+ };
66
+ };
@@ -74,9 +74,8 @@ const indicatorStyle = computed(() => {
74
74
  }
75
75
  });
76
76
  const statusStyle = computed(() => {
77
- return {
78
- [props.orientation === "vertical" ? "height" : "width"]: percent.value ? `${percent.value}%` : "fit-content"
79
- };
77
+ const value = `${Math.max(percent.value ?? 0, 0)}%`;
78
+ return props.orientation === "vertical" ? { height: value } : { width: value };
80
79
  });
81
80
  function isActive(index) {
82
81
  return index === Number(props.modelValue);
@@ -1,7 +1,7 @@
1
1
  import type { ProgressRootProps, ProgressRootEmits } from 'reka-ui';
2
2
  import type { AppConfig } from '@nuxt/schema';
3
3
  import theme from '#build/ui/progress';
4
- import type { ComponentConfig } from '../types/utils';
4
+ import type { ComponentConfig } from '../types/tv';
5
5
  type Progress = ComponentConfig<typeof theme, AppConfig, 'progress'>;
6
6
  export interface ProgressProps extends Pick<ProgressRootProps, 'getValueLabel' | 'getValueText' | 'modelValue'> {
7
7
  /**
@@ -47,7 +47,7 @@ export type ProgressSlots = {
47
47
  step: number;
48
48
  }) => any;
49
49
  };
50
- declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ProgressProps, void, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
50
+ declare const _default: __VLS_WithSlots<import("vue").DefineComponent<ProgressProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
51
51
  "update:modelValue": (value: string[] | undefined) => any;
52
52
  "update:max": (value: number) => any;
53
53
  }, string, import("vue").PublicProps, Readonly<ProgressProps> & Readonly<{
@@ -0,0 +1,99 @@
1
+ import type { RadioGroupRootProps, RadioGroupRootEmits } from 'reka-ui';
2
+ import type { AppConfig } from '@nuxt/schema';
3
+ import theme from '#build/ui/radio-group';
4
+ import type { AcceptableValue, GetItemKeys, GetModelValue } from '../types/utils';
5
+ import type { ComponentConfig } from '../types/tv';
6
+ type RadioGroup = ComponentConfig<typeof theme, AppConfig, 'radioGroup'>;
7
+ export type RadioGroupValue = AcceptableValue;
8
+ export type RadioGroupItem = RadioGroupValue | {
9
+ label?: string;
10
+ description?: string;
11
+ disabled?: boolean;
12
+ value?: RadioGroupValue;
13
+ class?: any;
14
+ ui?: Pick<RadioGroup['slots'], 'item' | 'container' | 'base' | 'indicator' | 'wrapper' | 'label' | 'description'>;
15
+ [key: string]: any;
16
+ };
17
+ export interface RadioGroupProps<T extends RadioGroupItem[] = RadioGroupItem[], VK extends GetItemKeys<T> = 'value'> extends Pick<RadioGroupRootProps, 'disabled' | 'loop' | 'name' | 'required'> {
18
+ /**
19
+ * The element or component this component should render as.
20
+ * @defaultValue 'div'
21
+ */
22
+ as?: any;
23
+ legend?: string;
24
+ /**
25
+ * When `items` is an array of objects, select the field to use as the value.
26
+ * @defaultValue 'value'
27
+ */
28
+ valueKey?: VK;
29
+ /**
30
+ * When `items` is an array of objects, select the field to use as the label.
31
+ * @defaultValue 'label'
32
+ */
33
+ labelKey?: GetItemKeys<T>;
34
+ /**
35
+ * When `items` is an array of objects, select the field to use as the description.
36
+ * @defaultValue 'description'
37
+ */
38
+ descriptionKey?: GetItemKeys<T>;
39
+ items?: T;
40
+ /** The controlled value of the RadioGroup. Can be bind as `v-model`. */
41
+ modelValue?: GetModelValue<T, VK, false>;
42
+ /** The value of the RadioGroup when initially rendered. Use when you do not need to control the state of the RadioGroup. */
43
+ defaultValue?: GetModelValue<T, VK, false>;
44
+ /**
45
+ * @defaultValue 'md'
46
+ */
47
+ size?: RadioGroup['variants']['size'];
48
+ /**
49
+ * @defaultValue 'list'
50
+ */
51
+ variant?: RadioGroup['variants']['variant'];
52
+ /**
53
+ * @defaultValue 'primary'
54
+ */
55
+ color?: RadioGroup['variants']['color'];
56
+ /**
57
+ * The orientation the radio buttons are laid out.
58
+ * @defaultValue 'vertical'
59
+ */
60
+ orientation?: RadioGroupRootProps['orientation'];
61
+ /**
62
+ * Position of the indicator.
63
+ * @defaultValue 'start'
64
+ */
65
+ indicator?: RadioGroup['variants']['indicator'];
66
+ class?: any;
67
+ ui?: RadioGroup['slots'];
68
+ }
69
+ export type RadioGroupEmits = RadioGroupRootEmits & {
70
+ change: [event: Event];
71
+ };
72
+ type NormalizeItem<T extends RadioGroupItem> = Exclude<T & {
73
+ id: string;
74
+ }, RadioGroupValue>;
75
+ type SlotProps<T extends RadioGroupItem> = (props: {
76
+ item: NormalizeItem<T>;
77
+ modelValue?: RadioGroupValue;
78
+ }) => any;
79
+ export interface RadioGroupSlots<T extends RadioGroupItem[] = RadioGroupItem[]> {
80
+ legend(props?: {}): any;
81
+ label: SlotProps<T[number]>;
82
+ description: SlotProps<T[number]>;
83
+ }
84
+ declare const _default: <T extends RadioGroupItem[], VK extends GetItemKeys<T> = "value">(__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<{
85
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
86
+ readonly onChange?: ((event: Event) => any) | undefined;
87
+ readonly "onUpdate:modelValue"?: ((payload: string) => any) | undefined;
88
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onChange" | "onUpdate:modelValue"> & RadioGroupProps<T, VK> & {}> & import("vue").PublicProps;
89
+ expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
90
+ attrs: any;
91
+ slots: RadioGroupSlots<T>;
92
+ emit: ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", payload: string) => void);
93
+ }>) => import("vue").VNode & {
94
+ __ctx?: Awaited<typeof __VLS_setup>;
95
+ };
96
+ export default _default;
97
+ type __VLS_PrettifyLocal<T> = {
98
+ [K in keyof T as K]: T[K];
99
+ } & {};
@@ -4,7 +4,7 @@ import theme from "#build/ui/radio-group";
4
4
 
5
5
  <script setup>
6
6
  import { computed, useId } from "vue";
7
- import { RadioGroupRoot, RadioGroupItem, RadioGroupIndicator, Label, useForwardPropsEmits } from "reka-ui";
7
+ import { RadioGroupRoot, RadioGroupItem as RRadioGroupItem, RadioGroupIndicator, Label, useForwardPropsEmits } from "reka-ui";
8
8
  import { reactivePick } from "@vueuse/core";
9
9
  import { useAppConfig } from "#imports";
10
10
  import { useFormField } from "../composables/useFormField";
@@ -13,10 +13,12 @@ import { tv } from "../utils/tv";
13
13
  const props = defineProps({
14
14
  as: { type: null, required: false },
15
15
  legend: { type: String, required: false },
16
- valueKey: { type: String, required: false, default: "value" },
17
- labelKey: { type: String, required: false, default: "label" },
18
- descriptionKey: { type: String, required: false, default: "description" },
19
- items: { type: Array, required: false },
16
+ valueKey: { type: null, required: false, default: "value" },
17
+ labelKey: { type: null, required: false, default: "label" },
18
+ descriptionKey: { type: null, required: false, default: "description" },
19
+ items: { type: null, required: false },
20
+ modelValue: { type: null, required: false },
21
+ defaultValue: { type: null, required: false },
20
22
  size: { type: null, required: false },
21
23
  variant: { type: null, required: false },
22
24
  color: { type: null, required: false },
@@ -24,17 +26,15 @@ const props = defineProps({
24
26
  indicator: { type: null, required: false },
25
27
  class: { type: null, required: false },
26
28
  ui: { type: null, required: false },
27
- defaultValue: { type: null, required: false },
28
29
  disabled: { type: Boolean, required: false },
29
30
  loop: { type: Boolean, required: false },
30
- modelValue: { type: null, required: false },
31
31
  name: { type: String, required: false },
32
32
  required: { type: Boolean, required: false }
33
33
  });
34
34
  const emits = defineEmits(["update:modelValue", "change"]);
35
35
  const slots = defineSlots();
36
36
  const appConfig = useAppConfig();
37
- const rootProps = useForwardPropsEmits(reactivePick(props, "as", "modelValue", "defaultValue", "orientation", "loop", "required"), emits);
37
+ const rootProps = useForwardPropsEmits(reactivePick(props, "as", "loop", "required"), emits);
38
38
  const { emitFormChange, emitFormInput, color, name, size, id: _id, disabled, ariaAttrs } = useFormField(props, { bind: false });
39
39
  const id = _id.value ?? useId();
40
40
  const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.radioGroup || {} })({
@@ -89,8 +89,10 @@ function onUpdate(value) {
89
89
  <template>
90
90
  <RadioGroupRoot
91
91
  :id="id"
92
- v-slot="{ modelValue }"
93
92
  v-bind="rootProps"
93
+ :model-value="modelValue"
94
+ :default-value="defaultValue"
95
+ :orientation="orientation"
94
96
  :name="name"
95
97
  :disabled="disabled"
96
98
  :class="ui.root({ class: [props.ui?.root, props.class] })"
@@ -105,14 +107,14 @@ function onUpdate(value) {
105
107
 
106
108
  <component :is="!variant || variant === 'list' ? 'div' : Label" v-for="item in normalizedItems" :key="item.value" :class="ui.item({ class: [props.ui?.item, item.ui?.item, item.class] })">
107
109
  <div :class="ui.container({ class: [props.ui?.container, item.ui?.container] })">
108
- <RadioGroupItem
110
+ <RRadioGroupItem
109
111
  :id="item.id"
110
112
  :value="item.value"
111
113
  :disabled="item.disabled"
112
114
  :class="ui.base({ class: [props.ui?.base, item.ui?.base], disabled: item.disabled })"
113
115
  >
114
116
  <RadioGroupIndicator :class="ui.indicator({ class: [props.ui?.indicator, item.ui?.indicator] })" />
115
- </RadioGroupItem>
117
+ </RRadioGroupItem>
116
118
  </div>
117
119
 
118
120
  <div v-if="item.label || !!slots.label || (item.description || !!slots.description)" :class="ui.wrapper({ class: [props.ui?.wrapper, item.ui?.wrapper] })">
@@ -1,10 +1,11 @@
1
1
  import type { RadioGroupRootProps, RadioGroupRootEmits } from 'reka-ui';
2
2
  import type { AppConfig } from '@nuxt/schema';
3
3
  import theme from '#build/ui/radio-group';
4
- import type { AcceptableValue, ComponentConfig } from '../types/utils';
4
+ import type { AcceptableValue, GetItemKeys, GetModelValue } from '../types/utils';
5
+ import type { ComponentConfig } from '../types/tv';
5
6
  type RadioGroup = ComponentConfig<typeof theme, AppConfig, 'radioGroup'>;
6
7
  export type RadioGroupValue = AcceptableValue;
7
- export type RadioGroupItem = {
8
+ export type RadioGroupItem = RadioGroupValue | {
8
9
  label?: string;
9
10
  description?: string;
10
11
  disabled?: boolean;
@@ -12,8 +13,8 @@ export type RadioGroupItem = {
12
13
  class?: any;
13
14
  ui?: Pick<RadioGroup['slots'], 'item' | 'container' | 'base' | 'indicator' | 'wrapper' | 'label' | 'description'>;
14
15
  [key: string]: any;
15
- } | RadioGroupValue;
16
- export interface RadioGroupProps<T extends RadioGroupItem = RadioGroupItem> extends Pick<RadioGroupRootProps, 'defaultValue' | 'disabled' | 'loop' | 'modelValue' | 'name' | 'required'> {
16
+ };
17
+ export interface RadioGroupProps<T extends RadioGroupItem[] = RadioGroupItem[], VK extends GetItemKeys<T> = 'value'> extends Pick<RadioGroupRootProps, 'disabled' | 'loop' | 'name' | 'required'> {
17
18
  /**
18
19
  * The element or component this component should render as.
19
20
  * @defaultValue 'div'
@@ -24,18 +25,22 @@ export interface RadioGroupProps<T extends RadioGroupItem = RadioGroupItem> exte
24
25
  * When `items` is an array of objects, select the field to use as the value.
25
26
  * @defaultValue 'value'
26
27
  */
27
- valueKey?: string;
28
+ valueKey?: VK;
28
29
  /**
29
30
  * When `items` is an array of objects, select the field to use as the label.
30
31
  * @defaultValue 'label'
31
32
  */
32
- labelKey?: string;
33
+ labelKey?: GetItemKeys<T>;
33
34
  /**
34
35
  * When `items` is an array of objects, select the field to use as the description.
35
36
  * @defaultValue 'description'
36
37
  */
37
- descriptionKey?: string;
38
- items?: T[];
38
+ descriptionKey?: GetItemKeys<T>;
39
+ items?: T;
40
+ /** The controlled value of the RadioGroup. Can be bind as `v-model`. */
41
+ modelValue?: GetModelValue<T, VK, false>;
42
+ /** The value of the RadioGroup when initially rendered. Use when you do not need to control the state of the RadioGroup. */
43
+ defaultValue?: GetModelValue<T, VK, false>;
39
44
  /**
40
45
  * @defaultValue 'md'
41
46
  */
@@ -62,7 +67,7 @@ export interface RadioGroupProps<T extends RadioGroupItem = RadioGroupItem> exte
62
67
  ui?: RadioGroup['slots'];
63
68
  }
64
69
  export type RadioGroupEmits = RadioGroupRootEmits & {
65
- change: [payload: Event];
70
+ change: [event: Event];
66
71
  };
67
72
  type NormalizeItem<T extends RadioGroupItem> = Exclude<T & {
68
73
  id: string;
@@ -71,20 +76,20 @@ type SlotProps<T extends RadioGroupItem> = (props: {
71
76
  item: NormalizeItem<T>;
72
77
  modelValue?: RadioGroupValue;
73
78
  }) => any;
74
- export interface RadioGroupSlots<T extends RadioGroupItem = RadioGroupItem> {
79
+ export interface RadioGroupSlots<T extends RadioGroupItem[] = RadioGroupItem[]> {
75
80
  legend(props?: {}): any;
76
- label: SlotProps<T>;
77
- description: SlotProps<T>;
81
+ label: SlotProps<T[number]>;
82
+ description: SlotProps<T[number]>;
78
83
  }
79
- declare const _default: <T extends RadioGroupItem>(__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<{
84
+ declare const _default: <T extends RadioGroupItem[], VK extends GetItemKeys<T> = "value">(__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<{
80
85
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
81
- readonly onChange?: ((payload: Event) => any) | undefined;
86
+ readonly onChange?: ((event: Event) => any) | undefined;
82
87
  readonly "onUpdate:modelValue"?: ((payload: string) => any) | undefined;
83
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onChange" | "onUpdate:modelValue"> & RadioGroupProps<T> & Partial<{}>> & import("vue").PublicProps;
88
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onChange" | "onUpdate:modelValue"> & RadioGroupProps<T, VK> & {}> & import("vue").PublicProps;
84
89
  expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
85
90
  attrs: any;
86
91
  slots: RadioGroupSlots<T>;
87
- emit: ((evt: "change", payload: Event) => void) & ((evt: "update:modelValue", payload: string) => void);
92
+ emit: ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", payload: string) => void);
88
93
  }>) => import("vue").VNode & {
89
94
  __ctx?: Awaited<typeof __VLS_setup>;
90
95
  };