@eslamdevui/ui 4.0.0 → 4.1.1-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (514) hide show
  1. package/.nuxt/ui/auth-form.ts +2 -2
  2. package/.nuxt/ui/calendar.ts +221 -9
  3. package/.nuxt/ui/chat-message.ts +10 -3
  4. package/.nuxt/ui/command-palette.ts +12 -2
  5. package/.nuxt/ui/content/content-search.ts +8 -1
  6. package/.nuxt/ui/context-menu.ts +3 -1
  7. package/.nuxt/ui/dashboard-panel.ts +1 -1
  8. package/.nuxt/ui/dashboard-search.ts +8 -1
  9. package/.nuxt/ui/dashboard-sidebar.ts +1 -1
  10. package/.nuxt/ui/drawer.ts +23 -0
  11. package/.nuxt/ui/dropdown-menu.ts +3 -1
  12. package/.nuxt/ui/empty.ts +83 -0
  13. package/.nuxt/ui/index.ts +1 -0
  14. package/.nuxt/ui/input-menu.ts +12 -2
  15. package/.nuxt/ui/input-number.ts +25 -14
  16. package/.nuxt/ui/kbd.ts +1 -1
  17. package/.nuxt/ui/prose/code-tree.ts +1 -1
  18. package/.nuxt/ui/prose/img.ts +2 -1
  19. package/.nuxt/ui/select-menu.ts +12 -2
  20. package/.nuxt/ui/select.ts +4 -2
  21. package/.nuxt/ui/table.ts +8 -2
  22. package/.nuxt/ui/tree.ts +25 -11
  23. package/cli/templates.mjs +14 -2
  24. package/dist/module.d.mts +15 -0
  25. package/dist/module.json +2 -2
  26. package/dist/module.mjs +5 -2
  27. package/dist/runtime/components/Accordion.d.vue.ts +11 -6
  28. package/dist/runtime/components/Accordion.vue +4 -4
  29. package/dist/runtime/components/Accordion.vue.d.ts +11 -6
  30. package/dist/runtime/components/Alert.d.vue.ts +6 -5
  31. package/dist/runtime/components/Alert.vue +1 -1
  32. package/dist/runtime/components/Alert.vue.d.ts +6 -5
  33. package/dist/runtime/components/App.d.vue.ts +5 -4
  34. package/dist/runtime/components/App.vue +1 -1
  35. package/dist/runtime/components/App.vue.d.ts +5 -4
  36. package/dist/runtime/components/AuthForm.d.vue.ts +33 -51
  37. package/dist/runtime/components/AuthForm.vue +35 -23
  38. package/dist/runtime/components/AuthForm.vue.d.ts +33 -51
  39. package/dist/runtime/components/Avatar.d.vue.ts +6 -4
  40. package/dist/runtime/components/Avatar.vue +10 -4
  41. package/dist/runtime/components/Avatar.vue.d.ts +6 -4
  42. package/dist/runtime/components/AvatarGroup.d.vue.ts +2 -1
  43. package/dist/runtime/components/AvatarGroup.vue.d.ts +2 -1
  44. package/dist/runtime/components/Badge.d.vue.ts +11 -4
  45. package/dist/runtime/components/Badge.vue +3 -3
  46. package/dist/runtime/components/Badge.vue.d.ts +11 -4
  47. package/dist/runtime/components/Banner.d.vue.ts +6 -3
  48. package/dist/runtime/components/Banner.vue +1 -1
  49. package/dist/runtime/components/Banner.vue.d.ts +6 -3
  50. package/dist/runtime/components/BlogPost.d.vue.ts +11 -4
  51. package/dist/runtime/components/BlogPost.vue +2 -2
  52. package/dist/runtime/components/BlogPost.vue.d.ts +11 -4
  53. package/dist/runtime/components/BlogPosts.d.vue.ts +23 -13
  54. package/dist/runtime/components/BlogPosts.vue +8 -2
  55. package/dist/runtime/components/BlogPosts.vue.d.ts +23 -13
  56. package/dist/runtime/components/Breadcrumb.d.vue.ts +23 -7
  57. package/dist/runtime/components/Breadcrumb.vue +8 -8
  58. package/dist/runtime/components/Breadcrumb.vue.d.ts +23 -7
  59. package/dist/runtime/components/Button.d.vue.ts +11 -4
  60. package/dist/runtime/components/Button.vue +3 -3
  61. package/dist/runtime/components/Button.vue.d.ts +11 -4
  62. package/dist/runtime/components/Calendar.d.vue.ts +8 -8
  63. package/dist/runtime/components/Calendar.vue +3 -1
  64. package/dist/runtime/components/Calendar.vue.d.ts +8 -8
  65. package/dist/runtime/components/Card.d.vue.ts +2 -1
  66. package/dist/runtime/components/Card.vue.d.ts +2 -1
  67. package/dist/runtime/components/Carousel.d.vue.ts +5 -6
  68. package/dist/runtime/components/Carousel.vue +33 -12
  69. package/dist/runtime/components/Carousel.vue.d.ts +5 -6
  70. package/dist/runtime/components/ChangelogVersion.d.vue.ts +14 -5
  71. package/dist/runtime/components/ChangelogVersion.vue +3 -3
  72. package/dist/runtime/components/ChangelogVersion.vue.d.ts +14 -5
  73. package/dist/runtime/components/ChangelogVersions.d.vue.ts +12 -39
  74. package/dist/runtime/components/ChangelogVersions.vue +2 -2
  75. package/dist/runtime/components/ChangelogVersions.vue.d.ts +12 -39
  76. package/dist/runtime/components/ChatMessage.d.vue.ts +3 -1
  77. package/dist/runtime/components/ChatMessage.vue +1 -1
  78. package/dist/runtime/components/ChatMessage.vue.d.ts +3 -1
  79. package/dist/runtime/components/ChatMessages.d.vue.ts +16 -16
  80. package/dist/runtime/components/ChatMessages.vue +31 -13
  81. package/dist/runtime/components/ChatMessages.vue.d.ts +16 -16
  82. package/dist/runtime/components/ChatPalette.d.vue.ts +2 -1
  83. package/dist/runtime/components/ChatPalette.vue.d.ts +2 -1
  84. package/dist/runtime/components/ChatPrompt.d.vue.ts +4 -3
  85. package/dist/runtime/components/ChatPrompt.vue.d.ts +4 -3
  86. package/dist/runtime/components/ChatPromptSubmit.d.vue.ts +2 -1
  87. package/dist/runtime/components/ChatPromptSubmit.vue.d.ts +2 -1
  88. package/dist/runtime/components/Checkbox.d.vue.ts +2 -1
  89. package/dist/runtime/components/Checkbox.vue.d.ts +2 -1
  90. package/dist/runtime/components/CheckboxGroup.d.vue.ts +4 -6
  91. package/dist/runtime/components/CheckboxGroup.vue.d.ts +4 -6
  92. package/dist/runtime/components/Chip.d.vue.ts +2 -1
  93. package/dist/runtime/components/Chip.vue.d.ts +2 -1
  94. package/dist/runtime/components/Collapsible.d.vue.ts +2 -1
  95. package/dist/runtime/components/Collapsible.vue.d.ts +2 -1
  96. package/dist/runtime/components/ColorPicker.d.vue.ts +3 -2
  97. package/dist/runtime/components/ColorPicker.vue.d.ts +3 -2
  98. package/dist/runtime/components/CommandPalette.d.vue.ts +51 -26
  99. package/dist/runtime/components/CommandPalette.vue +134 -68
  100. package/dist/runtime/components/CommandPalette.vue.d.ts +51 -26
  101. package/dist/runtime/components/Container.d.vue.ts +2 -1
  102. package/dist/runtime/components/Container.vue.d.ts +2 -1
  103. package/dist/runtime/components/ContextMenu.d.vue.ts +32 -11
  104. package/dist/runtime/components/ContextMenu.vue +2 -0
  105. package/dist/runtime/components/ContextMenu.vue.d.ts +32 -11
  106. package/dist/runtime/components/ContextMenuContent.d.vue.ts +6 -12
  107. package/dist/runtime/components/ContextMenuContent.vue +21 -11
  108. package/dist/runtime/components/ContextMenuContent.vue.d.ts +6 -12
  109. package/dist/runtime/components/DashboardGroup.d.vue.ts +2 -1
  110. package/dist/runtime/components/DashboardGroup.vue.d.ts +2 -1
  111. package/dist/runtime/components/DashboardNavbar.d.vue.ts +11 -4
  112. package/dist/runtime/components/DashboardNavbar.vue +3 -3
  113. package/dist/runtime/components/DashboardNavbar.vue.d.ts +11 -4
  114. package/dist/runtime/components/DashboardPanel.d.vue.ts +2 -1
  115. package/dist/runtime/components/DashboardPanel.vue.d.ts +2 -1
  116. package/dist/runtime/components/DashboardResizeHandle.d.vue.ts +2 -1
  117. package/dist/runtime/components/DashboardResizeHandle.vue.d.ts +2 -1
  118. package/dist/runtime/components/DashboardSearch.d.vue.ts +8 -4
  119. package/dist/runtime/components/DashboardSearch.vue +19 -6
  120. package/dist/runtime/components/DashboardSearch.vue.d.ts +8 -4
  121. package/dist/runtime/components/DashboardSearchButton.d.vue.ts +2 -1
  122. package/dist/runtime/components/DashboardSearchButton.vue +2 -2
  123. package/dist/runtime/components/DashboardSearchButton.vue.d.ts +2 -1
  124. package/dist/runtime/components/DashboardSidebar.d.vue.ts +10 -8
  125. package/dist/runtime/components/DashboardSidebar.vue +4 -4
  126. package/dist/runtime/components/DashboardSidebar.vue.d.ts +10 -8
  127. package/dist/runtime/components/DashboardSidebarCollapse.d.vue.ts +2 -1
  128. package/dist/runtime/components/DashboardSidebarCollapse.vue.d.ts +2 -1
  129. package/dist/runtime/components/DashboardSidebarToggle.d.vue.ts +2 -1
  130. package/dist/runtime/components/DashboardSidebarToggle.vue.d.ts +2 -1
  131. package/dist/runtime/components/DashboardToolbar.d.vue.ts +2 -1
  132. package/dist/runtime/components/DashboardToolbar.vue.d.ts +2 -1
  133. package/dist/runtime/components/Drawer.d.vue.ts +5 -1
  134. package/dist/runtime/components/Drawer.vue +16 -5
  135. package/dist/runtime/components/Drawer.vue.d.ts +5 -1
  136. package/dist/runtime/components/DropdownMenu.d.vue.ts +32 -11
  137. package/dist/runtime/components/DropdownMenu.vue +2 -0
  138. package/dist/runtime/components/DropdownMenu.vue.d.ts +32 -11
  139. package/dist/runtime/components/DropdownMenuContent.d.vue.ts +12 -14
  140. package/dist/runtime/components/DropdownMenuContent.vue +21 -11
  141. package/dist/runtime/components/DropdownMenuContent.vue.d.ts +12 -14
  142. package/dist/runtime/components/Empty.d.vue.ts +53 -0
  143. package/dist/runtime/components/Empty.vue +68 -0
  144. package/dist/runtime/components/Empty.vue.d.ts +53 -0
  145. package/dist/runtime/components/Error.d.vue.ts +2 -2
  146. package/dist/runtime/components/Error.vue +1 -1
  147. package/dist/runtime/components/Error.vue.d.ts +2 -2
  148. package/dist/runtime/components/FieldGroup.d.vue.ts +2 -1
  149. package/dist/runtime/components/FieldGroup.vue +1 -1
  150. package/dist/runtime/components/FieldGroup.vue.d.ts +2 -1
  151. package/dist/runtime/components/FileUpload.d.vue.ts +12 -9
  152. package/dist/runtime/components/FileUpload.vue +8 -7
  153. package/dist/runtime/components/FileUpload.vue.d.ts +12 -9
  154. package/dist/runtime/components/Footer.d.vue.ts +2 -1
  155. package/dist/runtime/components/Footer.vue.d.ts +2 -1
  156. package/dist/runtime/components/FooterColumns.d.vue.ts +13 -5
  157. package/dist/runtime/components/FooterColumns.vue +2 -2
  158. package/dist/runtime/components/FooterColumns.vue.d.ts +13 -5
  159. package/dist/runtime/components/Form.d.vue.ts +5 -7
  160. package/dist/runtime/components/Form.vue.d.ts +5 -7
  161. package/dist/runtime/components/FormField.d.vue.ts +2 -1
  162. package/dist/runtime/components/FormField.vue.d.ts +2 -1
  163. package/dist/runtime/components/Header.d.vue.ts +9 -7
  164. package/dist/runtime/components/Header.vue +3 -3
  165. package/dist/runtime/components/Header.vue.d.ts +9 -7
  166. package/dist/runtime/components/Icon.d.vue.ts +2 -1
  167. package/dist/runtime/components/Icon.vue.d.ts +2 -1
  168. package/dist/runtime/components/Input.d.vue.ts +14 -11
  169. package/dist/runtime/components/Input.vue +3 -3
  170. package/dist/runtime/components/Input.vue.d.ts +14 -11
  171. package/dist/runtime/components/InputMenu.d.vue.ts +49 -28
  172. package/dist/runtime/components/InputMenu.vue +117 -65
  173. package/dist/runtime/components/InputMenu.vue.d.ts +49 -28
  174. package/dist/runtime/components/InputNumber.d.vue.ts +6 -3
  175. package/dist/runtime/components/InputNumber.vue +7 -5
  176. package/dist/runtime/components/InputNumber.vue.d.ts +6 -3
  177. package/dist/runtime/components/InputTags.d.vue.ts +16 -16
  178. package/dist/runtime/components/InputTags.vue +5 -5
  179. package/dist/runtime/components/InputTags.vue.d.ts +16 -16
  180. package/dist/runtime/components/Kbd.d.vue.ts +2 -1
  181. package/dist/runtime/components/Kbd.vue.d.ts +2 -1
  182. package/dist/runtime/components/Link.d.vue.ts +3 -2
  183. package/dist/runtime/components/Link.vue.d.ts +3 -2
  184. package/dist/runtime/components/LinkBase.d.vue.ts +3 -2
  185. package/dist/runtime/components/LinkBase.vue.d.ts +3 -2
  186. package/dist/runtime/components/Main.d.vue.ts +3 -4
  187. package/dist/runtime/components/Main.vue +1 -1
  188. package/dist/runtime/components/Main.vue.d.ts +3 -4
  189. package/dist/runtime/components/Marquee.d.vue.ts +22 -1
  190. package/dist/runtime/components/Marquee.vue +1 -1
  191. package/dist/runtime/components/Marquee.vue.d.ts +22 -1
  192. package/dist/runtime/components/Modal.d.vue.ts +4 -6
  193. package/dist/runtime/components/Modal.vue +3 -6
  194. package/dist/runtime/components/Modal.vue.d.ts +4 -6
  195. package/dist/runtime/components/NavigationMenu.d.vue.ts +20 -9
  196. package/dist/runtime/components/NavigationMenu.vue +101 -76
  197. package/dist/runtime/components/NavigationMenu.vue.d.ts +20 -9
  198. package/dist/runtime/components/OverlayProvider.d.vue.ts +2 -1
  199. package/dist/runtime/components/OverlayProvider.vue.d.ts +2 -1
  200. package/dist/runtime/components/Page.d.vue.ts +2 -1
  201. package/dist/runtime/components/Page.vue.d.ts +2 -1
  202. package/dist/runtime/components/PageAnchors.d.vue.ts +13 -5
  203. package/dist/runtime/components/PageAnchors.vue +2 -2
  204. package/dist/runtime/components/PageAnchors.vue.d.ts +13 -5
  205. package/dist/runtime/components/PageAside.d.vue.ts +2 -1
  206. package/dist/runtime/components/PageAside.vue.d.ts +2 -1
  207. package/dist/runtime/components/PageBody.d.vue.ts +2 -1
  208. package/dist/runtime/components/PageBody.vue.d.ts +2 -1
  209. package/dist/runtime/components/PageCTA.d.vue.ts +2 -1
  210. package/dist/runtime/components/PageCTA.vue.d.ts +2 -1
  211. package/dist/runtime/components/PageCard.d.vue.ts +5 -2
  212. package/dist/runtime/components/PageCard.vue +1 -1
  213. package/dist/runtime/components/PageCard.vue.d.ts +5 -2
  214. package/dist/runtime/components/PageColumns.d.vue.ts +2 -1
  215. package/dist/runtime/components/PageColumns.vue.d.ts +2 -1
  216. package/dist/runtime/components/PageFeature.d.vue.ts +5 -2
  217. package/dist/runtime/components/PageFeature.vue +1 -1
  218. package/dist/runtime/components/PageFeature.vue.d.ts +5 -2
  219. package/dist/runtime/components/PageGrid.d.vue.ts +2 -1
  220. package/dist/runtime/components/PageGrid.vue.d.ts +2 -1
  221. package/dist/runtime/components/PageHeader.d.vue.ts +2 -1
  222. package/dist/runtime/components/PageHeader.vue.d.ts +2 -1
  223. package/dist/runtime/components/PageHero.d.vue.ts +2 -1
  224. package/dist/runtime/components/PageHero.vue.d.ts +2 -1
  225. package/dist/runtime/components/PageLinks.d.vue.ts +13 -5
  226. package/dist/runtime/components/PageLinks.vue +2 -2
  227. package/dist/runtime/components/PageLinks.vue.d.ts +13 -5
  228. package/dist/runtime/components/PageList.d.vue.ts +2 -1
  229. package/dist/runtime/components/PageList.vue.d.ts +2 -1
  230. package/dist/runtime/components/PageLogos.d.vue.ts +2 -1
  231. package/dist/runtime/components/PageLogos.vue.d.ts +2 -1
  232. package/dist/runtime/components/PageSection.d.vue.ts +5 -2
  233. package/dist/runtime/components/PageSection.vue +1 -1
  234. package/dist/runtime/components/PageSection.vue.d.ts +5 -2
  235. package/dist/runtime/components/Pagination.d.vue.ts +5 -2
  236. package/dist/runtime/components/Pagination.vue +5 -5
  237. package/dist/runtime/components/Pagination.vue.d.ts +5 -2
  238. package/dist/runtime/components/PinInput.d.vue.ts +5 -9
  239. package/dist/runtime/components/PinInput.vue.d.ts +5 -9
  240. package/dist/runtime/components/Popover.d.vue.ts +22 -23
  241. package/dist/runtime/components/Popover.vue +4 -4
  242. package/dist/runtime/components/Popover.vue.d.ts +22 -23
  243. package/dist/runtime/components/PricingPlan.d.vue.ts +11 -4
  244. package/dist/runtime/components/PricingPlan.vue +3 -3
  245. package/dist/runtime/components/PricingPlan.vue.d.ts +11 -4
  246. package/dist/runtime/components/PricingPlans.d.vue.ts +21 -13
  247. package/dist/runtime/components/PricingPlans.vue +7 -1
  248. package/dist/runtime/components/PricingPlans.vue.d.ts +21 -13
  249. package/dist/runtime/components/PricingTable.d.vue.ts +4 -3
  250. package/dist/runtime/components/PricingTable.vue.d.ts +4 -3
  251. package/dist/runtime/components/Progress.d.vue.ts +2 -1
  252. package/dist/runtime/components/Progress.vue +1 -1
  253. package/dist/runtime/components/Progress.vue.d.ts +2 -1
  254. package/dist/runtime/components/RadioGroup.d.vue.ts +4 -6
  255. package/dist/runtime/components/RadioGroup.vue.d.ts +4 -6
  256. package/dist/runtime/components/Select.d.vue.ts +25 -19
  257. package/dist/runtime/components/Select.vue +18 -9
  258. package/dist/runtime/components/Select.vue.d.ts +25 -19
  259. package/dist/runtime/components/SelectMenu.d.vue.ts +46 -26
  260. package/dist/runtime/components/SelectMenu.vue +114 -61
  261. package/dist/runtime/components/SelectMenu.vue.d.ts +46 -26
  262. package/dist/runtime/components/Separator.d.vue.ts +5 -2
  263. package/dist/runtime/components/Separator.vue +1 -1
  264. package/dist/runtime/components/Separator.vue.d.ts +5 -2
  265. package/dist/runtime/components/Skeleton.d.vue.ts +2 -1
  266. package/dist/runtime/components/Skeleton.vue.d.ts +2 -1
  267. package/dist/runtime/components/Slideover.d.vue.ts +4 -6
  268. package/dist/runtime/components/Slideover.vue +3 -6
  269. package/dist/runtime/components/Slideover.vue.d.ts +4 -6
  270. package/dist/runtime/components/Slider.d.vue.ts +5 -7
  271. package/dist/runtime/components/Slider.vue.d.ts +5 -7
  272. package/dist/runtime/components/Stepper.d.vue.ts +10 -10
  273. package/dist/runtime/components/Stepper.vue +1 -1
  274. package/dist/runtime/components/Stepper.vue.d.ts +10 -10
  275. package/dist/runtime/components/Switch.d.vue.ts +2 -1
  276. package/dist/runtime/components/Switch.vue.d.ts +2 -1
  277. package/dist/runtime/components/Table.d.vue.ts +27 -20
  278. package/dist/runtime/components/Table.vue +145 -61
  279. package/dist/runtime/components/Table.vue.d.ts +27 -20
  280. package/dist/runtime/components/Tabs.d.vue.ts +13 -9
  281. package/dist/runtime/components/Tabs.vue +3 -3
  282. package/dist/runtime/components/Tabs.vue.d.ts +13 -9
  283. package/dist/runtime/components/Textarea.d.vue.ts +14 -11
  284. package/dist/runtime/components/Textarea.vue +3 -3
  285. package/dist/runtime/components/Textarea.vue.d.ts +14 -11
  286. package/dist/runtime/components/Timeline.d.vue.ts +5 -6
  287. package/dist/runtime/components/Timeline.vue.d.ts +5 -6
  288. package/dist/runtime/components/Toast.d.vue.ts +6 -5
  289. package/dist/runtime/components/Toast.vue +1 -1
  290. package/dist/runtime/components/Toast.vue.d.ts +6 -5
  291. package/dist/runtime/components/Toaster.d.vue.ts +8 -1
  292. package/dist/runtime/components/Toaster.vue +6 -3
  293. package/dist/runtime/components/Toaster.vue.d.ts +8 -1
  294. package/dist/runtime/components/Tooltip.d.vue.ts +5 -2
  295. package/dist/runtime/components/Tooltip.vue +1 -1
  296. package/dist/runtime/components/Tooltip.vue.d.ts +5 -2
  297. package/dist/runtime/components/Tree.d.vue.ts +46 -10
  298. package/dist/runtime/components/Tree.vue +169 -81
  299. package/dist/runtime/components/Tree.vue.d.ts +46 -10
  300. package/dist/runtime/components/User.d.vue.ts +5 -2
  301. package/dist/runtime/components/User.vue +1 -1
  302. package/dist/runtime/components/User.vue.d.ts +5 -2
  303. package/dist/runtime/components/color-mode/ColorModeAvatar.d.vue.ts +2 -1
  304. package/dist/runtime/components/color-mode/ColorModeAvatar.vue.d.ts +2 -1
  305. package/dist/runtime/components/color-mode/ColorModeButton.d.vue.ts +2 -1
  306. package/dist/runtime/components/color-mode/ColorModeButton.vue.d.ts +2 -1
  307. package/dist/runtime/components/color-mode/ColorModeImage.d.vue.ts +2 -1
  308. package/dist/runtime/components/color-mode/ColorModeImage.vue.d.ts +2 -1
  309. package/dist/runtime/components/color-mode/ColorModeSelect.d.vue.ts +2 -1
  310. package/dist/runtime/components/color-mode/ColorModeSelect.vue.d.ts +2 -1
  311. package/dist/runtime/components/color-mode/ColorModeSwitch.d.vue.ts +2 -1
  312. package/dist/runtime/components/color-mode/ColorModeSwitch.vue.d.ts +2 -1
  313. package/dist/runtime/components/content/ContentNavigation.d.vue.ts +5 -5
  314. package/dist/runtime/components/content/ContentNavigation.vue +19 -9
  315. package/dist/runtime/components/content/ContentNavigation.vue.d.ts +5 -5
  316. package/dist/runtime/components/content/ContentSearch.d.vue.ts +11 -10
  317. package/dist/runtime/components/content/ContentSearch.vue +21 -6
  318. package/dist/runtime/components/content/ContentSearch.vue.d.ts +11 -10
  319. package/dist/runtime/components/content/ContentSearchButton.d.vue.ts +2 -1
  320. package/dist/runtime/components/content/ContentSearchButton.vue +2 -2
  321. package/dist/runtime/components/content/ContentSearchButton.vue.d.ts +2 -1
  322. package/dist/runtime/components/content/ContentSurround.d.vue.ts +5 -3
  323. package/dist/runtime/components/content/ContentSurround.vue +4 -4
  324. package/dist/runtime/components/content/ContentSurround.vue.d.ts +5 -3
  325. package/dist/runtime/components/content/ContentToc.d.vue.ts +6 -6
  326. package/dist/runtime/components/content/ContentToc.vue +2 -2
  327. package/dist/runtime/components/content/ContentToc.vue.d.ts +6 -6
  328. package/dist/runtime/components/locale/LocaleSelect.d.vue.ts +2 -1
  329. package/dist/runtime/components/locale/LocaleSelect.vue.d.ts +2 -1
  330. package/dist/runtime/components/prose/A.d.vue.ts +2 -1
  331. package/dist/runtime/components/prose/A.vue.d.ts +2 -1
  332. package/dist/runtime/components/prose/Accordion.d.vue.ts +8 -1
  333. package/dist/runtime/components/prose/Accordion.vue +3 -2
  334. package/dist/runtime/components/prose/Accordion.vue.d.ts +8 -1
  335. package/dist/runtime/components/prose/AccordionItem.d.vue.ts +2 -1
  336. package/dist/runtime/components/prose/AccordionItem.vue.d.ts +2 -1
  337. package/dist/runtime/components/prose/Badge.d.vue.ts +2 -1
  338. package/dist/runtime/components/prose/Badge.vue.d.ts +2 -1
  339. package/dist/runtime/components/prose/Blockquote.d.vue.ts +2 -1
  340. package/dist/runtime/components/prose/Blockquote.vue.d.ts +2 -1
  341. package/dist/runtime/components/prose/Callout.d.vue.ts +2 -1
  342. package/dist/runtime/components/prose/Callout.vue.d.ts +2 -1
  343. package/dist/runtime/components/prose/Card.d.vue.ts +2 -1
  344. package/dist/runtime/components/prose/Card.vue.d.ts +2 -1
  345. package/dist/runtime/components/prose/CardGroup.d.vue.ts +2 -1
  346. package/dist/runtime/components/prose/CardGroup.vue.d.ts +2 -1
  347. package/dist/runtime/components/prose/Code.d.vue.ts +2 -1
  348. package/dist/runtime/components/prose/Code.vue.d.ts +2 -1
  349. package/dist/runtime/components/prose/CodeCollapse.d.vue.ts +2 -1
  350. package/dist/runtime/components/prose/CodeCollapse.vue.d.ts +2 -1
  351. package/dist/runtime/components/prose/CodeGroup.d.vue.ts +2 -1
  352. package/dist/runtime/components/prose/CodeGroup.vue.d.ts +2 -1
  353. package/dist/runtime/components/prose/CodeIcon.d.vue.ts +2 -1
  354. package/dist/runtime/components/prose/CodeIcon.vue.d.ts +2 -1
  355. package/dist/runtime/components/prose/CodePreview.d.vue.ts +2 -1
  356. package/dist/runtime/components/prose/CodePreview.vue.d.ts +2 -1
  357. package/dist/runtime/components/prose/CodeTree.d.vue.ts +2 -1
  358. package/dist/runtime/components/prose/CodeTree.vue +40 -36
  359. package/dist/runtime/components/prose/CodeTree.vue.d.ts +2 -1
  360. package/dist/runtime/components/prose/Collapsible.d.vue.ts +4 -3
  361. package/dist/runtime/components/prose/Collapsible.vue +2 -2
  362. package/dist/runtime/components/prose/Collapsible.vue.d.ts +4 -3
  363. package/dist/runtime/components/prose/Em.d.vue.ts +2 -1
  364. package/dist/runtime/components/prose/Em.vue.d.ts +2 -1
  365. package/dist/runtime/components/prose/Field.d.vue.ts +3 -2
  366. package/dist/runtime/components/prose/Field.vue.d.ts +3 -2
  367. package/dist/runtime/components/prose/FieldGroup.d.vue.ts +2 -1
  368. package/dist/runtime/components/prose/FieldGroup.vue.d.ts +2 -1
  369. package/dist/runtime/components/prose/H1.d.vue.ts +2 -1
  370. package/dist/runtime/components/prose/H1.vue.d.ts +2 -1
  371. package/dist/runtime/components/prose/H2.d.vue.ts +2 -1
  372. package/dist/runtime/components/prose/H2.vue.d.ts +2 -1
  373. package/dist/runtime/components/prose/H3.d.vue.ts +2 -1
  374. package/dist/runtime/components/prose/H3.vue.d.ts +2 -1
  375. package/dist/runtime/components/prose/H4.d.vue.ts +2 -1
  376. package/dist/runtime/components/prose/H4.vue.d.ts +2 -1
  377. package/dist/runtime/components/prose/Hr.d.vue.ts +2 -1
  378. package/dist/runtime/components/prose/Hr.vue.d.ts +2 -1
  379. package/dist/runtime/components/prose/Icon.d.vue.ts +2 -1
  380. package/dist/runtime/components/prose/Icon.vue.d.ts +2 -1
  381. package/dist/runtime/components/prose/Img.d.vue.ts +2 -1
  382. package/dist/runtime/components/prose/Img.vue +14 -3
  383. package/dist/runtime/components/prose/Img.vue.d.ts +2 -1
  384. package/dist/runtime/components/prose/Kbd.d.vue.ts +2 -1
  385. package/dist/runtime/components/prose/Kbd.vue.d.ts +2 -1
  386. package/dist/runtime/components/prose/Li.d.vue.ts +2 -1
  387. package/dist/runtime/components/prose/Li.vue.d.ts +2 -1
  388. package/dist/runtime/components/prose/Ol.d.vue.ts +2 -1
  389. package/dist/runtime/components/prose/Ol.vue.d.ts +2 -1
  390. package/dist/runtime/components/prose/P.d.vue.ts +2 -1
  391. package/dist/runtime/components/prose/P.vue.d.ts +2 -1
  392. package/dist/runtime/components/prose/Pre.d.vue.ts +2 -1
  393. package/dist/runtime/components/prose/Pre.vue.d.ts +2 -1
  394. package/dist/runtime/components/prose/Script.d.vue.ts +2 -1
  395. package/dist/runtime/components/prose/Script.vue.d.ts +2 -1
  396. package/dist/runtime/components/prose/Steps.d.vue.ts +2 -1
  397. package/dist/runtime/components/prose/Steps.vue.d.ts +2 -1
  398. package/dist/runtime/components/prose/Strong.d.vue.ts +2 -1
  399. package/dist/runtime/components/prose/Strong.vue.d.ts +2 -1
  400. package/dist/runtime/components/prose/Table.d.vue.ts +2 -1
  401. package/dist/runtime/components/prose/Table.vue.d.ts +2 -1
  402. package/dist/runtime/components/prose/Tabs.d.vue.ts +8 -1
  403. package/dist/runtime/components/prose/Tabs.vue +3 -2
  404. package/dist/runtime/components/prose/Tabs.vue.d.ts +8 -1
  405. package/dist/runtime/components/prose/TabsItem.d.vue.ts +2 -1
  406. package/dist/runtime/components/prose/TabsItem.vue.d.ts +2 -1
  407. package/dist/runtime/components/prose/Tbody.d.vue.ts +2 -1
  408. package/dist/runtime/components/prose/Tbody.vue.d.ts +2 -1
  409. package/dist/runtime/components/prose/Td.d.vue.ts +2 -1
  410. package/dist/runtime/components/prose/Td.vue.d.ts +2 -1
  411. package/dist/runtime/components/prose/Th.d.vue.ts +2 -1
  412. package/dist/runtime/components/prose/Th.vue.d.ts +2 -1
  413. package/dist/runtime/components/prose/Thead.d.vue.ts +2 -1
  414. package/dist/runtime/components/prose/Thead.vue.d.ts +2 -1
  415. package/dist/runtime/components/prose/Tr.d.vue.ts +2 -1
  416. package/dist/runtime/components/prose/Tr.vue.d.ts +2 -1
  417. package/dist/runtime/components/prose/Ul.d.vue.ts +2 -1
  418. package/dist/runtime/components/prose/Ul.vue.d.ts +2 -1
  419. package/dist/runtime/components/prose/callout/Caution.d.vue.ts +3 -2
  420. package/dist/runtime/components/prose/callout/Caution.vue.d.ts +3 -2
  421. package/dist/runtime/components/prose/callout/Note.d.vue.ts +3 -2
  422. package/dist/runtime/components/prose/callout/Note.vue.d.ts +3 -2
  423. package/dist/runtime/components/prose/callout/Tip.d.vue.ts +3 -2
  424. package/dist/runtime/components/prose/callout/Tip.vue.d.ts +3 -2
  425. package/dist/runtime/components/prose/callout/Warning.d.vue.ts +3 -2
  426. package/dist/runtime/components/prose/callout/Warning.vue.d.ts +3 -2
  427. package/dist/runtime/composables/useKbd.js +2 -2
  428. package/dist/runtime/composables/usePortal.d.ts +3 -3
  429. package/dist/runtime/composables/usePortal.js +5 -10
  430. package/dist/runtime/composables/useToast.d.ts +3 -1
  431. package/dist/runtime/composables/useToast.js +4 -3
  432. package/dist/runtime/inertia/components/Link.d.vue.ts +3 -2
  433. package/dist/runtime/inertia/components/Link.vue +12 -6
  434. package/dist/runtime/inertia/components/Link.vue.d.ts +3 -2
  435. package/dist/runtime/inertia/components/LinkBase.d.vue.ts +3 -2
  436. package/dist/runtime/inertia/components/LinkBase.vue.d.ts +3 -2
  437. package/dist/runtime/inertia/stubs.d.ts +1 -1
  438. package/dist/runtime/inertia/stubs.js +2 -2
  439. package/dist/runtime/locale/ar.js +5 -5
  440. package/dist/runtime/locale/az.js +5 -5
  441. package/dist/runtime/locale/bg.js +3 -3
  442. package/dist/runtime/locale/bn.js +5 -5
  443. package/dist/runtime/locale/ca.js +5 -5
  444. package/dist/runtime/locale/ckb.js +15 -15
  445. package/dist/runtime/locale/cs.js +5 -5
  446. package/dist/runtime/locale/da.js +5 -5
  447. package/dist/runtime/locale/de.js +5 -5
  448. package/dist/runtime/locale/de_ch.js +5 -5
  449. package/dist/runtime/locale/el.js +5 -5
  450. package/dist/runtime/locale/en.js +5 -5
  451. package/dist/runtime/locale/es.js +5 -5
  452. package/dist/runtime/locale/et.js +5 -5
  453. package/dist/runtime/locale/fa_ir.js +5 -5
  454. package/dist/runtime/locale/fi.js +5 -5
  455. package/dist/runtime/locale/fr.js +5 -5
  456. package/dist/runtime/locale/he.js +5 -5
  457. package/dist/runtime/locale/hi.js +5 -5
  458. package/dist/runtime/locale/hr.d.ts +3 -0
  459. package/dist/runtime/locale/hr.js +129 -0
  460. package/dist/runtime/locale/hu.js +5 -5
  461. package/dist/runtime/locale/hy.js +4 -4
  462. package/dist/runtime/locale/id.js +5 -5
  463. package/dist/runtime/locale/index.d.ts +1 -0
  464. package/dist/runtime/locale/index.js +1 -0
  465. package/dist/runtime/locale/it.js +5 -5
  466. package/dist/runtime/locale/ja.js +5 -5
  467. package/dist/runtime/locale/ka.js +5 -5
  468. package/dist/runtime/locale/kk.js +3 -3
  469. package/dist/runtime/locale/km.js +5 -5
  470. package/dist/runtime/locale/ko.js +5 -5
  471. package/dist/runtime/locale/ky.js +4 -4
  472. package/dist/runtime/locale/lb.js +4 -4
  473. package/dist/runtime/locale/lt.js +5 -5
  474. package/dist/runtime/locale/mn.js +5 -5
  475. package/dist/runtime/locale/ms.js +5 -5
  476. package/dist/runtime/locale/nb_no.js +5 -5
  477. package/dist/runtime/locale/nl.js +5 -5
  478. package/dist/runtime/locale/pl.js +5 -5
  479. package/dist/runtime/locale/pt.js +5 -5
  480. package/dist/runtime/locale/pt_br.js +5 -5
  481. package/dist/runtime/locale/ro.js +5 -5
  482. package/dist/runtime/locale/ru.js +5 -5
  483. package/dist/runtime/locale/sk.js +5 -5
  484. package/dist/runtime/locale/sl.js +5 -5
  485. package/dist/runtime/locale/sv.js +5 -5
  486. package/dist/runtime/locale/th.js +5 -5
  487. package/dist/runtime/locale/tj.js +3 -3
  488. package/dist/runtime/locale/tr.js +5 -5
  489. package/dist/runtime/locale/ug_cn.js +3 -3
  490. package/dist/runtime/locale/uk.js +5 -5
  491. package/dist/runtime/locale/ur.js +4 -4
  492. package/dist/runtime/locale/uz.js +5 -5
  493. package/dist/runtime/locale/vi.js +5 -5
  494. package/dist/runtime/locale/zh_cn.js +5 -5
  495. package/dist/runtime/locale/zh_tw.js +5 -5
  496. package/dist/runtime/types/index.d.ts +2 -1
  497. package/dist/runtime/types/index.js +2 -1
  498. package/dist/runtime/types/tv.d.ts +6 -0
  499. package/dist/runtime/vue/components/Icon.d.vue.ts +2 -1
  500. package/dist/runtime/vue/components/Icon.vue.d.ts +2 -1
  501. package/dist/runtime/vue/components/Link.d.vue.ts +3 -2
  502. package/dist/runtime/vue/components/Link.vue.d.ts +3 -2
  503. package/dist/runtime/vue/components/color-mode/ColorModeButton.d.vue.ts +2 -1
  504. package/dist/runtime/vue/components/color-mode/ColorModeButton.vue.d.ts +2 -1
  505. package/dist/runtime/vue/components/color-mode/ColorModeSelect.d.vue.ts +2 -1
  506. package/dist/runtime/vue/components/color-mode/ColorModeSelect.vue.d.ts +2 -1
  507. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.d.vue.ts +2 -1
  508. package/dist/runtime/vue/components/color-mode/ColorModeSwitch.vue.d.ts +2 -1
  509. package/dist/runtime/vue/stubs.d.ts +1 -1
  510. package/dist/runtime/vue/stubs.js +2 -2
  511. package/dist/shared/{ui.BBlr3wu_.mjs → ui.Dy8dMbVj.mjs} +489 -114
  512. package/dist/unplugin.mjs +11 -3
  513. package/dist/vite.mjs +3 -2
  514. package/package.json +23 -21
@@ -3,20 +3,24 @@ import theme from "#build/ui/table";
3
3
  </script>
4
4
 
5
5
  <script setup>
6
- import { computed, ref, watch } from "vue";
6
+ import { computed, ref, watch, toRef } from "vue";
7
7
  import { Primitive } from "reka-ui";
8
8
  import { upperFirst } from "scule";
9
+ import { defu } from "defu";
9
10
  import { FlexRender, getCoreRowModel, getFilteredRowModel, getSortedRowModel, getExpandedRowModel, useVueTable } from "@tanstack/vue-table";
10
- import { reactiveOmit } from "@vueuse/core";
11
+ import { useVirtualizer } from "@tanstack/vue-virtual";
12
+ import { reactiveOmit, createReusableTemplate } from "@vueuse/core";
11
13
  import { useAppConfig } from "#imports";
12
14
  import { useLocale } from "../composables/useLocale";
13
15
  import { tv } from "../utils/tv";
16
+ defineOptions({ inheritAttrs: false });
14
17
  const props = defineProps({
15
18
  as: { type: null, required: false },
16
19
  data: { type: Array, required: false },
17
20
  columns: { type: Array, required: false },
18
21
  caption: { type: String, required: false },
19
22
  meta: { type: Object, required: false },
23
+ virtualize: { type: [Boolean, Object], required: false, default: false },
20
24
  empty: { type: String, required: false },
21
25
  sticky: { type: [Boolean, String], required: false },
22
26
  loading: { type: Boolean, required: false },
@@ -63,14 +67,46 @@ const slots = defineSlots();
63
67
  const { t } = useLocale();
64
68
  const appConfig = useAppConfig();
65
69
  const data = ref(props.data ?? []);
66
- const columns = computed(() => props.columns ?? Object.keys(data.value[0] ?? {}).map((accessorKey) => ({ accessorKey, header: upperFirst(accessorKey) })));
67
70
  const meta = computed(() => props.meta ?? {});
71
+ const columns = computed(() => processColumns(props.columns ?? Object.keys(data.value[0] ?? {}).map((accessorKey) => ({ accessorKey, header: upperFirst(accessorKey) }))));
72
+ function processColumns(columns2) {
73
+ return columns2.map((column) => {
74
+ const col = { ...column };
75
+ if ("columns" in col && col.columns) {
76
+ col.columns = processColumns(col.columns);
77
+ }
78
+ if (!col.cell) {
79
+ col.cell = ({ getValue }) => {
80
+ const value = getValue();
81
+ if (value === "" || value === null || value === void 0) {
82
+ return "\xA0";
83
+ }
84
+ return String(value);
85
+ };
86
+ }
87
+ return col;
88
+ });
89
+ }
68
90
  const ui = computed(() => tv({ extend: tv(theme), ...appConfig.ui?.table || {} })({
69
- sticky: props.sticky,
91
+ sticky: props.virtualize ? false : props.sticky,
70
92
  loading: props.loading,
71
93
  loadingColor: props.loadingColor,
72
- loadingAnimation: props.loadingAnimation
94
+ loadingAnimation: props.loadingAnimation,
95
+ virtualize: !!props.virtualize
73
96
  }));
97
+ const [DefineTableTemplate, ReuseTableTemplate] = createReusableTemplate();
98
+ const [DefineRowTemplate, ReuseRowTemplate] = createReusableTemplate({
99
+ props: {
100
+ row: {
101
+ type: Object,
102
+ required: true
103
+ },
104
+ style: {
105
+ type: Object,
106
+ required: false
107
+ }
108
+ }
109
+ });
74
110
  const hasFooter = computed(() => {
75
111
  function hasFooterRecursive(columns2) {
76
112
  for (const column of columns2) {
@@ -98,9 +134,10 @@ const sortingState = defineModel("sorting", { type: Array, ...{ default: [] } })
98
134
  const groupingState = defineModel("grouping", { type: Array, ...{ default: [] } });
99
135
  const expandedState = defineModel("expanded", { type: [Boolean, Object], ...{ default: {} } });
100
136
  const paginationState = defineModel("pagination", { type: Object, ...{ default: {} } });
137
+ const rootRef = ref();
101
138
  const tableRef = ref(null);
102
139
  const tableApi = useVueTable({
103
- ...reactiveOmit(props, "as", "data", "columns", "caption", "sticky", "loading", "loadingColor", "loadingAnimation", "class", "ui"),
140
+ ...reactiveOmit(props, "as", "data", "columns", "virtualize", "caption", "sticky", "loading", "loadingColor", "loadingAnimation", "class", "ui"),
104
141
  data,
105
142
  get columns() {
106
143
  return columns.value;
@@ -177,6 +214,19 @@ const tableApi = useVueTable({
177
214
  }
178
215
  }
179
216
  });
217
+ const rows = computed(() => tableApi.getRowModel().rows);
218
+ const virtualizerProps = toRef(() => defu(typeof props.virtualize === "boolean" ? {} : props.virtualize, {
219
+ estimateSize: 65,
220
+ overscan: 12
221
+ }));
222
+ const virtualizer = !!props.virtualize && useVirtualizer({
223
+ ...virtualizerProps.value,
224
+ get count() {
225
+ return rows.value.length;
226
+ },
227
+ getScrollElement: () => rootRef.value?.$el,
228
+ estimateSize: () => virtualizerProps.value.estimateSize
229
+ });
180
230
  function valueUpdater(updaterOrValue, ref2) {
181
231
  ref2.value = typeof updaterOrValue === "function" ? updaterOrValue(ref2.value) : updaterOrValue;
182
232
  }
@@ -191,7 +241,7 @@ function onRowSelect(e, row) {
191
241
  }
192
242
  e.preventDefault();
193
243
  e.stopPropagation();
194
- props.onSelect(row, e);
244
+ props.onSelect(e, row);
195
245
  }
196
246
  function onRowHover(e, row) {
197
247
  if (!props.onHover) {
@@ -215,21 +265,67 @@ function resolveValue(prop, arg) {
215
265
  }
216
266
  return prop;
217
267
  }
218
- watch(
219
- () => props.data,
220
- () => {
221
- data.value = props.data ? [...props.data] : [];
222
- },
223
- props.watchOptions
224
- );
268
+ watch(() => props.data, () => {
269
+ data.value = props.data ? [...props.data] : [];
270
+ }, props.watchOptions);
225
271
  defineExpose({
272
+ get $el() {
273
+ return rootRef.value?.$el;
274
+ },
226
275
  tableRef,
227
276
  tableApi
228
277
  });
229
278
  </script>
230
279
 
231
280
  <template>
232
- <Primitive :as="as" :class="ui.root({ class: [props.ui?.root, props.class] })">
281
+ <DefineRowTemplate v-slot="{ row, style }">
282
+ <tr
283
+ :data-selected="row.getIsSelected()"
284
+ :data-selectable="!!props.onSelect || !!props.onHover || !!props.onContextmenu"
285
+ :data-expanded="row.getIsExpanded()"
286
+ :role="props.onSelect ? 'button' : void 0"
287
+ :tabindex="props.onSelect ? 0 : void 0"
288
+ :class="ui.tr({
289
+ class: [
290
+ props.ui?.tr,
291
+ resolveValue(tableApi.options.meta?.class?.tr, row)
292
+ ]
293
+ })"
294
+ :style="[resolveValue(tableApi.options.meta?.style?.tr, row), style]"
295
+ @click="onRowSelect($event, row)"
296
+ @pointerenter="onRowHover($event, row)"
297
+ @pointerleave="onRowHover($event, null)"
298
+ @contextmenu="onRowContextmenu($event, row)"
299
+ >
300
+ <td
301
+ v-for="cell in row.getVisibleCells()"
302
+ :key="cell.id"
303
+ :data-pinned="cell.column.getIsPinned()"
304
+ :colspan="resolveValue(cell.column.columnDef.meta?.colspan?.td, cell)"
305
+ :rowspan="resolveValue(cell.column.columnDef.meta?.rowspan?.td, cell)"
306
+ :class="ui.td({
307
+ class: [
308
+ props.ui?.td,
309
+ resolveValue(cell.column.columnDef.meta?.class?.td, cell)
310
+ ],
311
+ pinned: !!cell.column.getIsPinned()
312
+ })"
313
+ :style="resolveValue(cell.column.columnDef.meta?.style?.td, cell)"
314
+ >
315
+ <slot :name="`${cell.column.id}-cell`" v-bind="cell.getContext()">
316
+ <FlexRender :render="cell.column.columnDef.cell" :props="cell.getContext()" />
317
+ </slot>
318
+ </td>
319
+ </tr>
320
+
321
+ <tr v-if="row.getIsExpanded()" :class="ui.tr({ class: [props.ui?.tr] })">
322
+ <td :colspan="row.getAllCells().length" :class="ui.td({ class: [props.ui?.td] })">
323
+ <slot name="expanded" :row="row" />
324
+ </td>
325
+ </tr>
326
+ </DefineRowTemplate>
327
+
328
+ <DefineTableTemplate>
233
329
  <table ref="tableRef" :class="ui.base({ class: [props.ui?.base] })">
234
330
  <caption v-if="caption || !!slots.caption" :class="ui.caption({ class: [props.ui?.caption] })">
235
331
  <slot name="caption">
@@ -266,51 +362,21 @@ defineExpose({
266
362
  <tbody :class="ui.tbody({ class: [props.ui?.tbody] })">
267
363
  <slot name="body-top" />
268
364
 
269
- <template v-if="tableApi.getRowModel().rows?.length">
270
- <template v-for="row in tableApi.getRowModel().rows" :key="row.id">
271
- <tr
272
- :data-selected="row.getIsSelected()"
273
- :data-selectable="!!props.onSelect || !!props.onHover || !!props.onContextmenu"
274
- :data-expanded="row.getIsExpanded()"
275
- :role="props.onSelect ? 'button' : void 0"
276
- :tabindex="props.onSelect ? 0 : void 0"
277
- :class="ui.tr({
278
- class: [
279
- props.ui?.tr,
280
- resolveValue(tableApi.options.meta?.class?.tr, row)
281
- ]
282
- })"
283
- :style="resolveValue(tableApi.options.meta?.style?.tr, row)"
284
- @click="onRowSelect($event, row)"
285
- @pointerenter="onRowHover($event, row)"
286
- @pointerleave="onRowHover($event, null)"
287
- @contextmenu="onRowContextmenu($event, row)"
288
- >
289
- <td
290
- v-for="cell in row.getVisibleCells()"
291
- :key="cell.id"
292
- :data-pinned="cell.column.getIsPinned()"
293
- :colspan="resolveValue(cell.column.columnDef.meta?.colspan?.td, cell)"
294
- :rowspan="resolveValue(cell.column.columnDef.meta?.rowspan?.td, cell)"
295
- :class="ui.td({
296
- class: [
297
- props.ui?.td,
298
- resolveValue(cell.column.columnDef.meta?.class?.td, cell)
299
- ],
300
- pinned: !!cell.column.getIsPinned()
301
- })"
302
- :style="resolveValue(cell.column.columnDef.meta?.style?.td, cell)"
303
- >
304
- <slot :name="`${cell.column.id}-cell`" v-bind="cell.getContext()">
305
- <FlexRender :render="cell.column.columnDef.cell" :props="cell.getContext()" />
306
- </slot>
307
- </td>
308
- </tr>
309
- <tr v-if="row.getIsExpanded()" :class="ui.tr({ class: [props.ui?.tr] })">
310
- <td :colspan="row.getAllCells().length" :class="ui.td({ class: [props.ui?.td] })">
311
- <slot name="expanded" :row="row" />
312
- </td>
313
- </tr>
365
+ <template v-if="rows.length">
366
+ <template v-if="virtualizer">
367
+ <template v-for="(virtualRow, index) in virtualizer.getVirtualItems()" :key="rows[virtualRow.index]?.id">
368
+ <ReuseRowTemplate
369
+ :row="rows[virtualRow.index]"
370
+ :style="{
371
+ height: `${virtualRow.size}px`,
372
+ transform: `translateY(${virtualRow.start - index * virtualRow.size}px)`
373
+ }"
374
+ />
375
+ </template>
376
+ </template>
377
+
378
+ <template v-else>
379
+ <ReuseRowTemplate v-for="row in rows" :key="row.id" :row="row" />
314
380
  </template>
315
381
  </template>
316
382
 
@@ -331,7 +397,13 @@ defineExpose({
331
397
  <slot name="body-bottom" />
332
398
  </tbody>
333
399
 
334
- <tfoot v-if="hasFooter" :class="ui.tfoot({ class: [props.ui?.tfoot] })">
400
+ <tfoot
401
+ v-if="hasFooter"
402
+ :class="ui.tfoot({ class: [props.ui?.tfoot] })"
403
+ :style="virtualizer ? {
404
+ transform: `translateY(${virtualizer.getTotalSize() - virtualizer.getVirtualItems().length * virtualizerProps.estimateSize}px)`
405
+ } : void 0"
406
+ >
335
407
  <tr :class="ui.separator({ class: [props.ui?.separator] })" />
336
408
 
337
409
  <tr v-for="footerGroup in tableApi.getFooterGroups()" :key="footerGroup.id" :class="ui.tr({ class: [props.ui?.tr] })">
@@ -357,5 +429,17 @@ defineExpose({
357
429
  </tr>
358
430
  </tfoot>
359
431
  </table>
432
+ </DefineTableTemplate>
433
+
434
+ <Primitive ref="rootRef" :as="as" v-bind="$attrs" :class="ui.root({ class: [props.ui?.root, props.class] })">
435
+ <div
436
+ v-if="virtualizer"
437
+ :style="{
438
+ height: `${virtualizer.getTotalSize()}px`
439
+ }"
440
+ >
441
+ <ReuseTableTemplate />
442
+ </div>
443
+ <ReuseTableTemplate v-else />
360
444
  </Primitive>
361
445
  </template>
@@ -2,6 +2,7 @@ import type { Ref, WatchOptions } from 'vue';
2
2
  import type { AppConfig } from '@nuxt/schema';
3
3
  import type { Cell, Header, RowData, TableMeta } from '@tanstack/table-core';
4
4
  import type { CellContext, ColumnDef, ColumnFiltersOptions, ColumnFiltersState, ColumnOrderState, ColumnPinningOptions, ColumnPinningState, ColumnSizingInfoState, ColumnSizingOptions, ColumnSizingState, CoreOptions, ExpandedOptions, ExpandedState, FacetedOptions, GlobalFilterOptions, GroupingOptions, GroupingState, HeaderContext, PaginationOptions, PaginationState, Row, RowPinningOptions, RowPinningState, RowSelectionOptions, RowSelectionState, SortingOptions, SortingState, VisibilityOptions, VisibilityState } from '@tanstack/vue-table';
5
+ import type { VirtualizerOptions } from '@tanstack/vue-virtual';
5
6
  import theme from '#build/ui/table';
6
7
  import type { ComponentConfig } from '../types/tv';
7
8
  declare module '@tanstack/table-core' {
@@ -49,6 +50,23 @@ export interface TableProps<T extends TableData = TableData> extends TableOption
49
50
  columns?: TableColumn<T>[];
50
51
  caption?: string;
51
52
  meta?: TableMeta<T>;
53
+ /**
54
+ * Enable virtualization for large datasets.
55
+ * Note: when enabled, the divider between rows and sticky properties are not supported.
56
+ * @defaultValue false
57
+ */
58
+ virtualize?: boolean | (Partial<Omit<VirtualizerOptions<Element, Element>, 'getScrollElement' | 'count' | 'estimateSize' | 'overscan'>> & {
59
+ /**
60
+ * Number of items rendered outside the visible area
61
+ * @defaultValue 12
62
+ */
63
+ overscan?: number;
64
+ /**
65
+ * Estimated size (in px) of each item
66
+ * @defaultValue 65
67
+ */
68
+ estimateSize?: number;
69
+ });
52
70
  /**
53
71
  * The text to display when the table is empty.
54
72
  * @defaultValue t('table.noData')
@@ -56,6 +74,7 @@ export interface TableProps<T extends TableData = TableData> extends TableOption
56
74
  empty?: string;
57
75
  /**
58
76
  * Whether the table should have a sticky header or footer. True for both, 'header' for header only, 'footer' for footer only.
77
+ * Note: this prop is not supported when `virtualize` is true.
59
78
  * @defaultValue false
60
79
  */
61
80
  sticky?: boolean | 'header' | 'footer';
@@ -136,7 +155,7 @@ export interface TableProps<T extends TableData = TableData> extends TableOption
136
155
  * @see [Guide](https://tanstack.com/table/v8/docs/guide/column-faceting)
137
156
  */
138
157
  facetedOptions?: FacetedOptions<T>;
139
- onSelect?: (row: TableRow<T>, e?: Event) => void;
158
+ onSelect?: (e: Event, row: TableRow<T>) => void;
140
159
  onHover?: (e: Event, row: TableRow<T> | null) => void;
141
160
  onContextmenu?: ((e: Event, row: TableRow<T>) => void) | Array<((e: Event, row: TableRow<T>) => void)>;
142
161
  class?: any;
@@ -155,22 +174,8 @@ export type TableSlots<T extends TableData = TableData> = {
155
174
  'body-top': (props?: {}) => any;
156
175
  'body-bottom': (props?: {}) => any;
157
176
  } & DynamicHeaderSlots<T> & DynamicFooterSlots<T> & DynamicCellSlots<T>;
158
- declare const _default: <T extends TableData>(__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<{
159
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
160
- readonly "onUpdate:globalFilter"?: ((value: string) => any) | undefined;
161
- readonly "onUpdate:columnFilters"?: ((value: ColumnFiltersState) => any) | undefined;
162
- readonly "onUpdate:columnOrder"?: ((value: ColumnOrderState) => any) | undefined;
163
- readonly "onUpdate:columnVisibility"?: ((value: VisibilityState) => any) | undefined;
164
- readonly "onUpdate:columnPinning"?: ((value: ColumnPinningState) => any) | undefined;
165
- readonly "onUpdate:columnSizing"?: ((value: ColumnSizingState) => any) | undefined;
166
- readonly "onUpdate:columnSizingInfo"?: ((value: ColumnSizingInfoState) => any) | undefined;
167
- readonly "onUpdate:rowSelection"?: ((value: RowSelectionState) => any) | undefined;
168
- readonly "onUpdate:rowPinning"?: ((value: RowPinningState) => any) | undefined;
169
- readonly "onUpdate:sorting"?: ((value: SortingState) => any) | undefined;
170
- readonly "onUpdate:grouping"?: ((value: GroupingState) => any) | undefined;
171
- readonly "onUpdate:expanded"?: ((value: ExpandedState) => any) | undefined;
172
- readonly "onUpdate:pagination"?: ((value: PaginationState) => any) | undefined;
173
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:globalFilter" | "onUpdate:columnFilters" | "onUpdate:columnOrder" | "onUpdate:columnVisibility" | "onUpdate:columnPinning" | "onUpdate:columnSizing" | "onUpdate:columnSizingInfo" | "onUpdate:rowSelection" | "onUpdate:rowPinning" | "onUpdate:sorting" | "onUpdate:grouping" | "onUpdate:expanded" | "onUpdate:pagination"> & (TableProps<T> & {
177
+ declare const __VLS_export: <T extends TableData>(__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<{
178
+ props: __VLS_PrettifyLocal<(TableProps<T> & {
174
179
  globalFilter?: string;
175
180
  columnFilters?: ColumnFiltersState;
176
181
  columnOrder?: ColumnOrderState;
@@ -184,17 +189,19 @@ declare const _default: <T extends TableData>(__VLS_props: NonNullable<Awaited<t
184
189
  grouping?: GroupingState;
185
190
  expanded?: ExpandedState;
186
191
  pagination?: PaginationState;
187
- }) & {}> & import("vue").PublicProps;
188
- expose(exposed: import("vue").ShallowUnwrapRef<{
192
+ }) & __VLS_EmitsToProps<__VLS_NormalizeEmits<((evt: "update:globalFilter", value: string) => void) & ((evt: "update:columnFilters", value: ColumnFiltersState) => void) & ((evt: "update:columnOrder", value: ColumnOrderState) => void) & ((evt: "update:columnVisibility", value: VisibilityState) => void) & ((evt: "update:columnPinning", value: ColumnPinningState) => void) & ((evt: "update:columnSizing", value: ColumnSizingState) => void) & ((evt: "update:columnSizingInfo", value: ColumnSizingInfoState) => void) & ((evt: "update:rowSelection", value: RowSelectionState) => void) & ((evt: "update:rowPinning", value: RowPinningState) => void) & ((evt: "update:sorting", value: SortingState) => void) & ((evt: "update:grouping", value: GroupingState) => void) & ((evt: "update:expanded", value: ExpandedState) => void) & ((evt: "update:pagination", value: PaginationState) => void)>>> & import("vue").PublicProps;
193
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
194
+ readonly $el: any;
189
195
  tableRef: Ref<HTMLTableElement | null, HTMLTableElement | null>;
190
196
  tableApi: import("@tanstack/table-core").Table<T>;
191
- }>): void;
197
+ }>) => void;
192
198
  attrs: any;
193
199
  slots: TableSlots<T>;
194
200
  emit: ((evt: "update:globalFilter", value: string) => void) & ((evt: "update:columnFilters", value: ColumnFiltersState) => void) & ((evt: "update:columnOrder", value: ColumnOrderState) => void) & ((evt: "update:columnVisibility", value: VisibilityState) => void) & ((evt: "update:columnPinning", value: ColumnPinningState) => void) & ((evt: "update:columnSizing", value: ColumnSizingState) => void) & ((evt: "update:columnSizingInfo", value: ColumnSizingInfoState) => void) & ((evt: "update:rowSelection", value: RowSelectionState) => void) & ((evt: "update:rowPinning", value: RowPinningState) => void) & ((evt: "update:sorting", value: SortingState) => void) & ((evt: "update:grouping", value: GroupingState) => void) & ((evt: "update:expanded", value: ExpandedState) => void) & ((evt: "update:pagination", value: PaginationState) => void);
195
201
  }>) => import("vue").VNode & {
196
202
  __ctx?: Awaited<typeof __VLS_setup>;
197
203
  };
204
+ declare const _default: typeof __VLS_export;
198
205
  export default _default;
199
206
  type __VLS_PrettifyLocal<T> = {
200
207
  [K in keyof T as K]: T[K];
@@ -69,30 +69,34 @@ export interface TabsEmits extends TabsRootEmits<string | number> {
69
69
  type SlotProps<T extends TabsItem> = (props: {
70
70
  item: T;
71
71
  index: number;
72
+ ui: Tabs['ui'];
72
73
  }) => any;
73
74
  export type TabsSlots<T extends TabsItem = TabsItem> = {
74
75
  'leading': SlotProps<T>;
75
- 'default': SlotProps<T>;
76
+ 'default'(props: {
77
+ item: T;
78
+ index: number;
79
+ }): any;
76
80
  'trailing': SlotProps<T>;
77
81
  'content': SlotProps<T>;
78
- 'list-leading': (props?: {}) => any;
79
- 'list-trailing': (props?: {}) => any;
82
+ 'list-leading'(props?: {}): any;
83
+ 'list-trailing'(props?: {}): any;
80
84
  } & DynamicSlots<T, undefined, {
81
85
  index: number;
86
+ ui: Tabs['ui'];
82
87
  }>;
83
- declare const _default: <T extends TabsItem>(__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
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
85
- readonly "onUpdate:modelValue"?: ((payload: string | number) => any) | undefined;
86
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:modelValue"> & TabsProps<T> & {}> & import("vue").PublicProps;
87
- expose(exposed: import("vue").ShallowUnwrapRef<{
88
+ declare const __VLS_export: <T extends TabsItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
89
+ props: __VLS_PrettifyLocal<TabsProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<(evt: "update:modelValue", payload: string | number) => void>>> & import("vue").PublicProps;
90
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
88
91
  triggersRef: import("vue").Ref<ComponentPublicInstance[], ComponentPublicInstance[]>;
89
- }>): void;
92
+ }>) => void;
90
93
  attrs: any;
91
94
  slots: TabsSlots<T>;
92
95
  emit: (evt: "update:modelValue", payload: string | number) => void;
93
96
  }>) => import("vue").VNode & {
94
97
  __ctx?: Awaited<typeof __VLS_setup>;
95
98
  };
99
+ declare const _default: typeof __VLS_export;
96
100
  export default _default;
97
101
  type __VLS_PrettifyLocal<T> = {
98
102
  [K in keyof T as K]: T[K];
@@ -66,7 +66,7 @@ defineExpose({
66
66
  :disabled="item.disabled"
67
67
  :class="ui.trigger({ class: [props.ui?.trigger, item.ui?.trigger] })"
68
68
  >
69
- <slot name="leading" :item="item" :index="index">
69
+ <slot name="leading" :item="item" :index="index" :ui="ui">
70
70
  <UIcon v-if="item.icon" :name="item.icon" :class="ui.leadingIcon({ class: [props.ui?.leadingIcon, item.ui?.leadingIcon] })" />
71
71
  <UAvatar v-else-if="item.avatar" :size="item.ui?.leadingAvatarSize || props.ui?.leadingAvatarSize || ui.leadingAvatarSize()" v-bind="item.avatar" :class="ui.leadingAvatar({ class: [props.ui?.leadingAvatar, item.ui?.leadingAvatar] })" />
72
72
  </slot>
@@ -75,7 +75,7 @@ defineExpose({
75
75
  <slot :item="item" :index="index">{{ get(item, props.labelKey) }}</slot>
76
76
  </span>
77
77
 
78
- <slot name="trailing" :item="item" :index="index">
78
+ <slot name="trailing" :item="item" :index="index" :ui="ui">
79
79
  <UBadge
80
80
  v-if="item.badge !== void 0"
81
81
  color="neutral"
@@ -92,7 +92,7 @@ defineExpose({
92
92
 
93
93
  <template v-if="!!content">
94
94
  <TabsContent v-for="(item, index) of items" :key="index" :value="item.value ?? String(index)" :class="ui.content({ class: [props.ui?.content, item.ui?.content, item.class] })">
95
- <slot :name="item.slot || 'content'" :item="item" :index="index">
95
+ <slot :name="item.slot || 'content'" :item="item" :index="index" :ui="ui">
96
96
  {{ item.content }}
97
97
  </slot>
98
98
  </TabsContent>
@@ -69,30 +69,34 @@ export interface TabsEmits extends TabsRootEmits<string | number> {
69
69
  type SlotProps<T extends TabsItem> = (props: {
70
70
  item: T;
71
71
  index: number;
72
+ ui: Tabs['ui'];
72
73
  }) => any;
73
74
  export type TabsSlots<T extends TabsItem = TabsItem> = {
74
75
  'leading': SlotProps<T>;
75
- 'default': SlotProps<T>;
76
+ 'default'(props: {
77
+ item: T;
78
+ index: number;
79
+ }): any;
76
80
  'trailing': SlotProps<T>;
77
81
  'content': SlotProps<T>;
78
- 'list-leading': (props?: {}) => any;
79
- 'list-trailing': (props?: {}) => any;
82
+ 'list-leading'(props?: {}): any;
83
+ 'list-trailing'(props?: {}): any;
80
84
  } & DynamicSlots<T, undefined, {
81
85
  index: number;
86
+ ui: Tabs['ui'];
82
87
  }>;
83
- declare const _default: <T extends TabsItem>(__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
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
85
- readonly "onUpdate:modelValue"?: ((payload: string | number) => any) | undefined;
86
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:modelValue"> & TabsProps<T> & {}> & import("vue").PublicProps;
87
- expose(exposed: import("vue").ShallowUnwrapRef<{
88
+ declare const __VLS_export: <T extends TabsItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
89
+ props: __VLS_PrettifyLocal<TabsProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<(evt: "update:modelValue", payload: string | number) => void>>> & import("vue").PublicProps;
90
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
88
91
  triggersRef: import("vue").Ref<ComponentPublicInstance[], ComponentPublicInstance[]>;
89
- }>): void;
92
+ }>) => void;
90
93
  attrs: any;
91
94
  slots: TabsSlots<T>;
92
95
  emit: (evt: "update:modelValue", payload: string | number) => void;
93
96
  }>) => import("vue").VNode & {
94
97
  __ctx?: Awaited<typeof __VLS_setup>;
95
98
  };
99
+ declare const _default: typeof __VLS_export;
96
100
  export default _default;
97
101
  type __VLS_PrettifyLocal<T> = {
98
102
  [K in keyof T as K]: T[K];
@@ -49,25 +49,28 @@ export interface TextareaEmits<T extends TextareaValue = TextareaValue> {
49
49
  'change': [event: Event];
50
50
  }
51
51
  export interface TextareaSlots {
52
- leading(props?: {}): any;
53
- default(props?: {}): any;
54
- trailing(props?: {}): any;
52
+ leading(props: {
53
+ ui: Textarea['ui'];
54
+ }): any;
55
+ default(props: {
56
+ ui: Textarea['ui'];
57
+ }): any;
58
+ trailing(props: {
59
+ ui: Textarea['ui'];
60
+ }): any;
55
61
  }
56
- declare const _default: <T extends TextareaValue>(__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<{
57
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
58
- readonly onBlur?: ((event: FocusEvent) => any) | undefined;
59
- readonly onChange?: ((event: Event) => any) | undefined;
60
- readonly "onUpdate:modelValue"?: ((value: T) => any) | undefined;
61
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onBlur" | "onChange" | "onUpdate:modelValue"> & TextareaProps<T> & {}> & import("vue").PublicProps;
62
- expose(exposed: import("vue").ShallowUnwrapRef<{
62
+ declare const __VLS_export: <T extends TextareaValue>(__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<{
63
+ props: __VLS_PrettifyLocal<TextareaProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<((evt: "blur", event: FocusEvent) => void) & ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", value: T) => void)>>> & import("vue").PublicProps;
64
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
63
65
  textareaRef: import("vue").Ref<HTMLTextAreaElement | null, HTMLTextAreaElement | null>;
64
- }>): void;
66
+ }>) => void;
65
67
  attrs: any;
66
68
  slots: TextareaSlots;
67
69
  emit: ((evt: "blur", event: FocusEvent) => void) & ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", value: T) => void);
68
70
  }>) => import("vue").VNode & {
69
71
  __ctx?: Awaited<typeof __VLS_setup>;
70
72
  };
73
+ declare const _default: typeof __VLS_export;
71
74
  export default _default;
72
75
  type __VLS_PrettifyLocal<T> = {
73
76
  [K in keyof T as K]: T[K];
@@ -157,17 +157,17 @@ defineExpose({
157
157
  @focus="emitFormFocus"
158
158
  />
159
159
 
160
- <slot />
160
+ <slot :ui="ui" />
161
161
 
162
162
  <span v-if="isLeading || !!avatar || !!slots.leading" :class="ui.leading({ class: props.ui?.leading })">
163
- <slot name="leading">
163
+ <slot name="leading" :ui="ui">
164
164
  <UIcon v-if="isLeading && leadingIconName" :name="leadingIconName" :class="ui.leadingIcon({ class: props.ui?.leadingIcon })" />
165
165
  <UAvatar v-else-if="!!avatar" :size="props.ui?.leadingAvatarSize || ui.leadingAvatarSize()" v-bind="avatar" :class="ui.leadingAvatar({ class: props.ui?.leadingAvatar })" />
166
166
  </slot>
167
167
  </span>
168
168
 
169
169
  <span v-if="isTrailing || !!slots.trailing" :class="ui.trailing({ class: props.ui?.trailing })">
170
- <slot name="trailing">
170
+ <slot name="trailing" :ui="ui">
171
171
  <UIcon v-if="trailingIconName" :name="trailingIconName" :class="ui.trailingIcon({ class: props.ui?.trailingIcon })" />
172
172
  </slot>
173
173
  </span>
@@ -49,25 +49,28 @@ export interface TextareaEmits<T extends TextareaValue = TextareaValue> {
49
49
  'change': [event: Event];
50
50
  }
51
51
  export interface TextareaSlots {
52
- leading(props?: {}): any;
53
- default(props?: {}): any;
54
- trailing(props?: {}): any;
52
+ leading(props: {
53
+ ui: Textarea['ui'];
54
+ }): any;
55
+ default(props: {
56
+ ui: Textarea['ui'];
57
+ }): any;
58
+ trailing(props: {
59
+ ui: Textarea['ui'];
60
+ }): any;
55
61
  }
56
- declare const _default: <T extends TextareaValue>(__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<{
57
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
58
- readonly onBlur?: ((event: FocusEvent) => any) | undefined;
59
- readonly onChange?: ((event: Event) => any) | undefined;
60
- readonly "onUpdate:modelValue"?: ((value: T) => any) | undefined;
61
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onBlur" | "onChange" | "onUpdate:modelValue"> & TextareaProps<T> & {}> & import("vue").PublicProps;
62
- expose(exposed: import("vue").ShallowUnwrapRef<{
62
+ declare const __VLS_export: <T extends TextareaValue>(__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<{
63
+ props: __VLS_PrettifyLocal<TextareaProps<T> & __VLS_EmitsToProps<__VLS_NormalizeEmits<((evt: "blur", event: FocusEvent) => void) & ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", value: T) => void)>>> & import("vue").PublicProps;
64
+ expose: (exposed: import("vue").ShallowUnwrapRef<{
63
65
  textareaRef: import("vue").Ref<HTMLTextAreaElement | null, HTMLTextAreaElement | null>;
64
- }>): void;
66
+ }>) => void;
65
67
  attrs: any;
66
68
  slots: TextareaSlots;
67
69
  emit: ((evt: "blur", event: FocusEvent) => void) & ((evt: "change", event: Event) => void) & ((evt: "update:modelValue", value: T) => void);
68
70
  }>) => import("vue").VNode & {
69
71
  __ctx?: Awaited<typeof __VLS_setup>;
70
72
  };
73
+ declare const _default: typeof __VLS_export;
71
74
  export default _default;
72
75
  type __VLS_PrettifyLocal<T> = {
73
76
  [K in keyof T as K]: T[K];
@@ -52,19 +52,18 @@ export type TimelineSlots<T extends TimelineItem = TimelineItem> = {
52
52
  } & DynamicSlots<T, 'indicator' | 'date' | 'title' | 'description', {
53
53
  item: T;
54
54
  }>;
55
- declare const _default: <T extends TimelineItem>(__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<{
56
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
57
- readonly "onUpdate:modelValue"?: ((value: string | number | undefined) => any) | undefined;
58
- } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>, "onUpdate:modelValue"> & (TimelineProps<T> & {
55
+ declare const __VLS_export: <T extends TimelineItem>(__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<{
56
+ props: __VLS_PrettifyLocal<(TimelineProps<T> & {
59
57
  modelValue?: string | number;
60
- }) & {}> & import("vue").PublicProps;
61
- expose(exposed: import("vue").ShallowUnwrapRef<{}>): void;
58
+ }) & __VLS_EmitsToProps<__VLS_NormalizeEmits<(evt: "update:modelValue", value: string | number | undefined) => void>>> & import("vue").PublicProps;
59
+ expose: (exposed: {}) => void;
62
60
  attrs: any;
63
61
  slots: TimelineSlots<T>;
64
62
  emit: (evt: "update:modelValue", value: string | number | undefined) => void;
65
63
  }>) => import("vue").VNode & {
66
64
  __ctx?: Awaited<typeof __VLS_setup>;
67
65
  };
66
+ declare const _default: typeof __VLS_export;
68
67
  export default _default;
69
68
  type __VLS_PrettifyLocal<T> = {
70
69
  [K in keyof T as K]: T[K];