@vuetify/nightly 3.2.0-dev-20230214.0 → 3.2.0-dev-20230322.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (336) hide show
  1. package/CHANGELOG.md +5 -17
  2. package/dist/json/attributes.json +243 -59
  3. package/dist/json/tags.json +48 -2
  4. package/dist/json/web-types.json +1648 -279
  5. package/dist/vuetify-labs.css +666 -482
  6. package/dist/vuetify-labs.d.ts +59419 -13475
  7. package/dist/vuetify-labs.esm.js +797 -531
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +797 -531
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +524 -355
  12. package/dist/vuetify.d.ts +55670 -14368
  13. package/dist/vuetify.esm.js +607 -462
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +607 -462
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +793 -793
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.ts +6 -9
  21. package/lib/blueprints/md1.d.ts +6 -9
  22. package/lib/blueprints/md2.d.ts +6 -9
  23. package/lib/blueprints/md3.d.ts +6 -9
  24. package/lib/blueprints/md3.mjs +6 -0
  25. package/lib/blueprints/md3.mjs.map +1 -1
  26. package/lib/components/VAlert/VAlert.css +1 -1
  27. package/lib/components/VAlert/VAlert.mjs +29 -15
  28. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  29. package/lib/components/VAlert/_variables.scss +1 -1
  30. package/lib/components/VAlert/index.d.ts +515 -65
  31. package/lib/components/VApp/VApp.css +1 -0
  32. package/lib/components/VApp/VApp.sass +1 -0
  33. package/lib/components/VApp/index.d.ts +161 -17
  34. package/lib/components/VAppBar/VAppBar.mjs +9 -4
  35. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  36. package/lib/components/VAppBar/index.d.ts +624 -82
  37. package/lib/components/VAutocomplete/VAutocomplete.mjs +23 -8
  38. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  39. package/lib/components/VAutocomplete/index.d.ts +1744 -113
  40. package/lib/components/VAvatar/index.d.ts +207 -25
  41. package/lib/components/VBadge/index.d.ts +286 -36
  42. package/lib/components/VBanner/VBanner.mjs +19 -12
  43. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  44. package/lib/components/VBanner/index.d.ts +485 -67
  45. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +6 -2
  46. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  47. package/lib/components/VBottomNavigation/index.d.ts +323 -36
  48. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +11 -7
  49. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  50. package/lib/components/VBreadcrumbs/index.d.ts +346 -42
  51. package/lib/components/VBtn/VBtn.css +0 -5
  52. package/lib/components/VBtn/VBtn.mjs +65 -58
  53. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  54. package/lib/components/VBtn/VBtn.sass +0 -7
  55. package/lib/components/VBtn/_variables.scss +0 -2
  56. package/lib/components/VBtn/index.d.ts +454 -59
  57. package/lib/components/VBtnGroup/VBtnGroup.mjs +1 -7
  58. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  59. package/lib/components/VBtnGroup/index.d.ts +187 -22
  60. package/lib/components/VBtnToggle/VBtnToggle.mjs +2 -2
  61. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  62. package/lib/components/VBtnToggle/index.d.ts +248 -32
  63. package/lib/components/VCard/VCard.mjs +10 -6
  64. package/lib/components/VCard/VCard.mjs.map +1 -1
  65. package/lib/components/VCard/VCardItem.mjs +27 -23
  66. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  67. package/lib/components/VCard/index.d.ts +958 -132
  68. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  69. package/lib/components/VCarousel/index.d.ts +585 -87
  70. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  71. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  72. package/lib/components/VCheckbox/VCheckboxBtn.mjs +1 -4
  73. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  74. package/lib/components/VCheckbox/index.d.ts +841 -119
  75. package/lib/components/VChip/VChip.css +110 -90
  76. package/lib/components/VChip/VChip.mjs +70 -48
  77. package/lib/components/VChip/VChip.mjs.map +1 -1
  78. package/lib/components/VChip/_mixins.scss +27 -23
  79. package/lib/components/VChip/index.d.ts +476 -66
  80. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  81. package/lib/components/VChipGroup/index.d.ts +229 -28
  82. package/lib/components/VCode/index.d.ts +112 -13
  83. package/lib/components/VColorPicker/VColorPicker.mjs +9 -1
  84. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  85. package/lib/components/VColorPicker/VColorPickerCanvas.css +2 -1
  86. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +36 -18
  87. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  88. package/lib/components/VColorPicker/VColorPickerCanvas.sass +2 -1
  89. package/lib/components/VColorPicker/VColorPickerEdit.mjs +4 -4
  90. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  91. package/lib/components/VColorPicker/VColorPickerPreview.mjs +2 -2
  92. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  93. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  94. package/lib/components/VColorPicker/index.d.ts +284 -20
  95. package/lib/components/VColorPicker/util/index.mjs +2 -5
  96. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  97. package/lib/components/VCombobox/VCombobox.mjs +23 -8
  98. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  99. package/lib/components/VCombobox/index.d.ts +1756 -113
  100. package/lib/components/VCounter/index.d.ts +1909 -78
  101. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -1
  102. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  103. package/lib/components/VDefaultsProvider/index.d.ts +136 -18
  104. package/lib/components/VDialog/VDialog.css +31 -24
  105. package/lib/components/VDialog/VDialog.mjs +2 -2
  106. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  107. package/lib/components/VDialog/VDialog.sass +19 -12
  108. package/lib/components/VDialog/index.d.ts +2403 -124
  109. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  110. package/lib/components/VDivider/index.d.ts +132 -19
  111. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  112. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  113. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  114. package/lib/components/VExpansionPanel/index.d.ts +741 -104
  115. package/lib/components/VField/VField.mjs.map +1 -1
  116. package/lib/components/VField/index.d.ts +179 -23
  117. package/lib/components/VFileInput/VFileInput.mjs +1 -0
  118. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  119. package/lib/components/VFileInput/index.d.ts +1069 -93
  120. package/lib/components/VFooter/VFooter.css +2 -0
  121. package/lib/components/VFooter/VFooter.sass +2 -0
  122. package/lib/components/VFooter/_variables.scss +2 -0
  123. package/lib/components/VFooter/index.d.ts +206 -25
  124. package/lib/components/VForm/index.d.ts +207 -20
  125. package/lib/components/VGrid/VCol.mjs +6 -5
  126. package/lib/components/VGrid/VCol.mjs.map +1 -1
  127. package/lib/components/VGrid/VRow.mjs +4 -4
  128. package/lib/components/VGrid/VRow.mjs.map +1 -1
  129. package/lib/components/VGrid/index.d.ts +745 -64
  130. package/lib/components/VHover/index.d.ts +188 -29
  131. package/lib/components/VIcon/index.d.ts +500 -44
  132. package/lib/components/VImg/VImg.mjs +2 -2
  133. package/lib/components/VImg/VImg.mjs.map +1 -1
  134. package/lib/components/VImg/index.d.ts +281 -40
  135. package/lib/components/VInput/VInput.mjs.map +1 -1
  136. package/lib/components/VInput/index.d.ts +321 -47
  137. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  138. package/lib/components/VItemGroup/index.d.ts +313 -45
  139. package/lib/components/VKbd/VKbd.css +1 -0
  140. package/lib/components/VKbd/VKbd.sass +1 -0
  141. package/lib/components/VKbd/_variables.scss +1 -0
  142. package/lib/components/VKbd/index.d.ts +112 -13
  143. package/lib/components/VLabel/index.d.ts +115 -16
  144. package/lib/components/VLayout/index.d.ts +302 -35
  145. package/lib/components/VLazy/VLazy.mjs +4 -1
  146. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  147. package/lib/components/VLazy/index.d.ts +222 -27
  148. package/lib/components/VList/VListChildren.mjs +2 -2
  149. package/lib/components/VList/VListChildren.mjs.map +1 -1
  150. package/lib/components/VList/VListGroup.mjs +1 -4
  151. package/lib/components/VList/VListGroup.mjs.map +1 -1
  152. package/lib/components/VList/VListItem.mjs +23 -19
  153. package/lib/components/VList/VListItem.mjs.map +1 -1
  154. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  155. package/lib/components/VList/index.d.ts +1500 -191
  156. package/lib/components/VLocaleProvider/index.d.ts +123 -16
  157. package/lib/components/VMain/index.d.ts +121 -14
  158. package/lib/components/VMenu/VMenu.css +4 -4
  159. package/lib/components/VMenu/VMenu.mjs +8 -7
  160. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  161. package/lib/components/VMenu/VMenu.sass +1 -1
  162. package/lib/components/VMenu/index.d.ts +2411 -121
  163. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  164. package/lib/components/VMessages/index.d.ts +1934 -87
  165. package/lib/components/VNavigationDrawer/index.d.ts +382 -47
  166. package/lib/components/VNoSsr/index.d.ts +6 -0
  167. package/lib/components/VOverlay/VOverlay.css +2 -2
  168. package/lib/components/VOverlay/VOverlay.mjs +1 -4
  169. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  170. package/lib/components/VOverlay/VOverlay.sass +1 -1
  171. package/lib/components/VOverlay/_variables.scss +1 -1
  172. package/lib/components/VOverlay/index.d.ts +527 -75
  173. package/lib/components/VOverlay/scrollStrategies.mjs +2 -2
  174. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  175. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  176. package/lib/components/VPagination/index.d.ts +504 -56
  177. package/lib/components/VParallax/VParallax.mjs +3 -3
  178. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  179. package/lib/components/VParallax/index.d.ts +144 -19
  180. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  181. package/lib/components/VProgressCircular/index.d.ts +189 -22
  182. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  183. package/lib/components/VProgressLinear/index.d.ts +325 -42
  184. package/lib/components/VRadio/index.d.ts +318 -46
  185. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -6
  186. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  187. package/lib/components/VRadioGroup/index.d.ts +468 -66
  188. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  189. package/lib/components/VRangeSlider/index.d.ts +530 -66
  190. package/lib/components/VRating/VRating.css +0 -4
  191. package/lib/components/VRating/VRating.mjs +6 -35
  192. package/lib/components/VRating/VRating.mjs.map +1 -1
  193. package/lib/components/VRating/VRating.sass +0 -5
  194. package/lib/components/VRating/index.d.ts +309 -38
  195. package/lib/components/VResponsive/index.d.ts +144 -21
  196. package/lib/components/VSelect/VSelect.mjs +23 -8
  197. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  198. package/lib/components/VSelect/index.d.ts +3150 -247
  199. package/lib/components/VSelectionControl/VSelectionControl.mjs +1 -4
  200. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  201. package/lib/components/VSelectionControl/index.d.ts +90 -10
  202. package/lib/components/VSelectionControlGroup/index.d.ts +245 -35
  203. package/lib/components/VSheet/VSheet.mjs +16 -12
  204. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  205. package/lib/components/VSheet/index.d.ts +196 -27
  206. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  207. package/lib/components/VSlideGroup/index.d.ts +488 -70
  208. package/lib/components/VSlider/VSliderTrack.mjs +1 -0
  209. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  210. package/lib/components/VSlider/index.d.ts +523 -65
  211. package/lib/components/VSlider/slider.mjs +5 -6
  212. package/lib/components/VSlider/slider.mjs.map +1 -1
  213. package/lib/components/VSnackbar/VSnackbar.css +2 -9
  214. package/lib/components/VSnackbar/VSnackbar.mjs +10 -11
  215. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  216. package/lib/components/VSnackbar/VSnackbar.sass +3 -10
  217. package/lib/components/VSnackbar/index.d.ts +1255 -74
  218. package/lib/components/VSwitch/VSwitch.mjs +2 -2
  219. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  220. package/lib/components/VSwitch/index.d.ts +503 -75
  221. package/lib/components/VSystemBar/VSystemBar.css +5 -1
  222. package/lib/components/VSystemBar/VSystemBar.mjs +6 -2
  223. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  224. package/lib/components/VSystemBar/VSystemBar.sass +5 -1
  225. package/lib/components/VSystemBar/_variables.scss +4 -1
  226. package/lib/components/VSystemBar/index.d.ts +186 -23
  227. package/lib/components/VTable/VTable.mjs.map +1 -1
  228. package/lib/components/VTable/index.d.ts +193 -26
  229. package/lib/components/VTabs/VTab.mjs +7 -23
  230. package/lib/components/VTabs/VTab.mjs.map +1 -1
  231. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  232. package/lib/components/VTabs/index.d.ts +628 -64
  233. package/lib/components/VTextField/VTextField.mjs +9 -5
  234. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  235. package/lib/components/VTextField/index.d.ts +1447 -101
  236. package/lib/components/VTextarea/VTextarea.mjs +8 -1
  237. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  238. package/lib/components/VTextarea/index.d.ts +1043 -93
  239. package/lib/components/VThemeProvider/index.d.ts +127 -16
  240. package/lib/components/VTimeline/VTimelineDivider.mjs +18 -10
  241. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  242. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  243. package/lib/components/VTimeline/index.d.ts +446 -60
  244. package/lib/components/VToolbar/VToolbar.mjs +10 -9
  245. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  246. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  247. package/lib/components/VToolbar/index.d.ts +552 -73
  248. package/lib/components/VTooltip/VTooltip.css +3 -3
  249. package/lib/components/VTooltip/VTooltip.mjs +4 -4
  250. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  251. package/lib/components/VTooltip/VTooltip.sass +1 -1
  252. package/lib/components/VTooltip/index.d.ts +1315 -73
  253. package/lib/components/VValidation/index.d.ts +204 -27
  254. package/lib/components/VWindow/index.d.ts +541 -75
  255. package/lib/components/index.d.ts +55694 -14389
  256. package/lib/components/transitions/createTransition.mjs +1 -1
  257. package/lib/components/transitions/createTransition.mjs.map +1 -1
  258. package/lib/components/transitions/index.d.ts +2144 -259
  259. package/lib/composables/defaults.mjs +5 -1
  260. package/lib/composables/defaults.mjs.map +1 -1
  261. package/lib/composables/display.mjs +15 -10
  262. package/lib/composables/display.mjs.map +1 -1
  263. package/lib/composables/form.mjs.map +1 -1
  264. package/lib/composables/loader.mjs.map +1 -1
  265. package/lib/composables/nested/nested.mjs +2 -2
  266. package/lib/composables/nested/nested.mjs.map +1 -1
  267. package/lib/composables/nested/selectStrategies.mjs +7 -1
  268. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  269. package/lib/composables/proxiedModel.mjs +1 -1
  270. package/lib/composables/proxiedModel.mjs.map +1 -1
  271. package/lib/composables/resizeObserver.mjs.map +1 -1
  272. package/lib/composables/stack.mjs +2 -2
  273. package/lib/composables/stack.mjs.map +1 -1
  274. package/lib/composables/theme.mjs +28 -23
  275. package/lib/composables/theme.mjs.map +1 -1
  276. package/lib/composables/variant.mjs.map +1 -1
  277. package/lib/entry-bundler.mjs +1 -1
  278. package/lib/framework.mjs +1 -1
  279. package/lib/index.d.ts +6 -9
  280. package/lib/labs/VDataTable/VDataTable.css +15 -0
  281. package/lib/labs/VDataTable/VDataTable.mjs +45 -19
  282. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  283. package/lib/labs/VDataTable/VDataTable.sass +9 -0
  284. package/lib/labs/VDataTable/VDataTableFooter.mjs +3 -2
  285. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  286. package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
  287. package/lib/labs/VDataTable/VDataTableRow.mjs +8 -2
  288. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  289. package/lib/labs/VDataTable/VDataTableRows.mjs +6 -7
  290. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  291. package/lib/labs/VDataTable/VDataTableServer.mjs +41 -19
  292. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  293. package/lib/labs/VDataTable/VDataTableVirtual.mjs +27 -14
  294. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  295. package/lib/labs/VDataTable/composables/expand.mjs +1 -1
  296. package/lib/labs/VDataTable/composables/expand.mjs.map +1 -1
  297. package/lib/labs/VDataTable/composables/group.mjs +12 -1
  298. package/lib/labs/VDataTable/composables/group.mjs.map +1 -1
  299. package/lib/labs/VDataTable/composables/options.mjs +4 -10
  300. package/lib/labs/VDataTable/composables/options.mjs.map +1 -1
  301. package/lib/labs/VDataTable/composables/paginate.mjs +25 -4
  302. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  303. package/lib/labs/VDataTable/composables/select.mjs +1 -1
  304. package/lib/labs/VDataTable/composables/select.mjs.map +1 -1
  305. package/lib/labs/VDataTable/composables/sort.mjs +19 -3
  306. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  307. package/lib/labs/VDataTable/index.d.ts +4934 -317
  308. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs +18 -5
  309. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  310. package/lib/labs/VVirtualScroll/index.d.ts +41 -7
  311. package/lib/labs/components.d.ts +4970 -324
  312. package/lib/locale/adapters/vue-i18n.d.ts +1 -1
  313. package/lib/locale/adapters/vue-i18n.mjs +1 -1
  314. package/lib/locale/adapters/vue-i18n.mjs.map +1 -1
  315. package/lib/locale/index.mjs +1 -1
  316. package/lib/locale/index.mjs.map +1 -1
  317. package/lib/styles/elements/_global.sass +0 -4
  318. package/lib/styles/generic/_index.scss +0 -1
  319. package/lib/styles/generic/_transitions.scss +111 -9
  320. package/lib/styles/main.css +316 -167
  321. package/lib/styles/settings/_utilities.scss +7 -0
  322. package/lib/styles/tools/_sheet.sass +3 -6
  323. package/lib/styles/utilities/_display.sass +6 -5
  324. package/lib/styles/utilities/_elevation.scss +13 -0
  325. package/lib/styles/utilities/_index.sass +3 -2
  326. package/lib/styles/utilities/_screenreaders.sass +13 -11
  327. package/lib/util/animation.mjs +8 -1
  328. package/lib/util/animation.mjs.map +1 -1
  329. package/lib/util/colorUtils.mjs +4 -5
  330. package/lib/util/colorUtils.mjs.map +1 -1
  331. package/lib/util/defineComponent.mjs +15 -7
  332. package/lib/util/defineComponent.mjs.map +1 -1
  333. package/lib/util/helpers.mjs +4 -0
  334. package/lib/util/helpers.mjs.map +1 -1
  335. package/package.json +15 -7
  336. package/lib/styles/generic/_elevation.scss +0 -10
@@ -11,11 +11,8 @@ import { makeTagProps } from "../../composables/tag.mjs";
11
11
  import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
12
12
  import { makeVariantProps } from "../../composables/variant.mjs";
13
13
  import { provideDefaults } from "../../composables/defaults.mjs"; // Utility
14
- import { genericComponent, pick, propsFactory, useRender } from "../../util/index.mjs";
14
+ import { genericComponent, propsFactory, useRender } from "../../util/index.mjs";
15
15
  import { toRef } from 'vue';
16
-
17
- // Types
18
-
19
16
  export const makeVBtnGroupProps = propsFactory({
20
17
  divided: Boolean,
21
18
  ...makeBorderProps(),
@@ -66,7 +63,4 @@ export const VBtnGroup = genericComponent()({
66
63
  });
67
64
  }
68
65
  });
69
- export function filterVBtnGroupProps(props) {
70
- return pick(props, Object.keys(VBtnGroup.props));
71
- }
72
66
  //# sourceMappingURL=VBtnGroup.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VBtnGroup.mjs","names":["makeBorderProps","useBorder","makeDensityProps","useDensity","makeElevationProps","useElevation","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","provideDefaults","genericComponent","pick","propsFactory","useRender","toRef","makeVBtnGroupProps","divided","Boolean","VBtnGroup","name","props","setup","slots","themeClasses","densityClasses","borderClasses","elevationClasses","roundedClasses","VBtn","height","color","density","flat","variant","value","filterVBtnGroupProps","Object","keys"],"sources":["../../../src/components/VBtnGroup/VBtnGroup.tsx"],"sourcesContent":["// Styles\nimport './VBtnGroup.sass'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utility\nimport { genericComponent, pick, propsFactory, useRender } from '@/util'\nimport { toRef } from 'vue'\n\n// Types\nimport type { ExtractPropTypes } from 'vue'\n\nexport const makeVBtnGroupProps = propsFactory({\n divided: Boolean,\n\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps(),\n}, 'v-btn-group')\n\nexport const VBtnGroup = genericComponent()({\n name: 'VBtnGroup',\n\n props: makeVBtnGroupProps(),\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { densityClasses } = useDensity(props)\n const { borderClasses } = useBorder(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n\n provideDefaults({\n VBtn: {\n height: 'auto',\n color: toRef(props, 'color'),\n density: toRef(props, 'density'),\n flat: true,\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => {\n return (\n <props.tag\n class={[\n 'v-btn-group',\n {\n 'v-btn-group--divided': props.divided,\n },\n themeClasses.value,\n borderClasses.value,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n ]}\n v-slots={ slots }\n />\n )\n })\n },\n})\n\nexport type VBtnGroup = InstanceType<typeof VBtnGroup>\n\nexport function filterVBtnGroupProps (props: Partial<ExtractPropTypes<ReturnType<typeof makeVBtnGroupProps>>>) {\n return pick(props, Object.keys(VBtnGroup.props) as any)\n}\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,eAAe,EAAEC,SAAS;AAAA,SAC1BC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,kBAAkB,EAAEC,YAAY;AAAA,SAChCC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB;AAAA,SAChBC,eAAe,0CAExB;AAAA,SACSC,gBAAgB,EAAEC,IAAI,EAAEC,YAAY,EAAEC,SAAS;AACxD,SAASC,KAAK,QAAQ,KAAK;;AAE3B;;AAGA,OAAO,MAAMC,kBAAkB,GAAGH,YAAY,CAAC;EAC7CI,OAAO,EAAEC,OAAO;EAEhB,GAAGpB,eAAe,EAAE;EACpB,GAAGE,gBAAgB,EAAE;EACrB,GAAGE,kBAAkB,EAAE;EACvB,GAAGE,gBAAgB,EAAE;EACrB,GAAGE,YAAY,EAAE;EACjB,GAAGC,cAAc,EAAE;EACnB,GAAGE,gBAAgB;AACrB,CAAC,EAAE,aAAa,CAAC;AAEjB,OAAO,MAAMU,SAAS,GAAGR,gBAAgB,EAAE,CAAC;EAC1CS,IAAI,EAAE,WAAW;EAEjBC,KAAK,EAAEL,kBAAkB,EAAE;EAE3BM,KAAK,CAAED,KAAK,QAAa;IAAA,IAAX;MAAEE;IAAM,CAAC;IACrB,MAAM;MAAEC;IAAa,CAAC,GAAGhB,YAAY,CAACa,KAAK,CAAC;IAC5C,MAAM;MAAEI;IAAe,CAAC,GAAGxB,UAAU,CAACoB,KAAK,CAAC;IAC5C,MAAM;MAAEK;IAAc,CAAC,GAAG3B,SAAS,CAACsB,KAAK,CAAC;IAC1C,MAAM;MAAEM;IAAiB,CAAC,GAAGxB,YAAY,CAACkB,KAAK,CAAC;IAChD,MAAM;MAAEO;IAAe,CAAC,GAAGvB,UAAU,CAACgB,KAAK,CAAC;IAE5CX,eAAe,CAAC;MACdmB,IAAI,EAAE;QACJC,MAAM,EAAE,MAAM;QACdC,KAAK,EAAEhB,KAAK,CAACM,KAAK,EAAE,OAAO,CAAC;QAC5BW,OAAO,EAAEjB,KAAK,CAACM,KAAK,EAAE,SAAS,CAAC;QAChCY,IAAI,EAAE,IAAI;QACVC,OAAO,EAAEnB,KAAK,CAACM,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFP,SAAS,CAAC,MAAM;MACd;QAAA,SAEW,CACL,aAAa,EACb;UACE,sBAAsB,EAAEO,KAAK,CAACJ;QAChC,CAAC,EACDO,YAAY,CAACW,KAAK,EAClBT,aAAa,CAACS,KAAK,EACnBV,cAAc,CAACU,KAAK,EACpBR,gBAAgB,CAACQ,KAAK,EACtBP,cAAc,CAACO,KAAK;MACrB,GACSZ,KAAK;IAGrB,CAAC,CAAC;EACJ;AACF,CAAC,CAAC;AAIF,OAAO,SAASa,oBAAoB,CAAEf,KAAuE,EAAE;EAC7G,OAAOT,IAAI,CAACS,KAAK,EAAEgB,MAAM,CAACC,IAAI,CAACnB,SAAS,CAACE,KAAK,CAAC,CAAQ;AACzD"}
1
+ {"version":3,"file":"VBtnGroup.mjs","names":["makeBorderProps","useBorder","makeDensityProps","useDensity","makeElevationProps","useElevation","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","provideDefaults","genericComponent","propsFactory","useRender","toRef","makeVBtnGroupProps","divided","Boolean","VBtnGroup","name","props","setup","slots","themeClasses","densityClasses","borderClasses","elevationClasses","roundedClasses","VBtn","height","color","density","flat","variant","value"],"sources":["../../../src/components/VBtnGroup/VBtnGroup.tsx"],"sourcesContent":["// Styles\nimport './VBtnGroup.sass'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utility\nimport { genericComponent, propsFactory, useRender } from '@/util'\nimport { toRef } from 'vue'\n\nexport const makeVBtnGroupProps = propsFactory({\n divided: Boolean,\n\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps(),\n}, 'v-btn-group')\n\nexport const VBtnGroup = genericComponent()({\n name: 'VBtnGroup',\n\n props: makeVBtnGroupProps(),\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { densityClasses } = useDensity(props)\n const { borderClasses } = useBorder(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n\n provideDefaults({\n VBtn: {\n height: 'auto',\n color: toRef(props, 'color'),\n density: toRef(props, 'density'),\n flat: true,\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => {\n return (\n <props.tag\n class={[\n 'v-btn-group',\n {\n 'v-btn-group--divided': props.divided,\n },\n themeClasses.value,\n borderClasses.value,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n ]}\n v-slots={ slots }\n />\n )\n })\n },\n})\n\nexport type VBtnGroup = InstanceType<typeof VBtnGroup>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,eAAe,EAAEC,SAAS;AAAA,SAC1BC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,kBAAkB,EAAEC,YAAY;AAAA,SAChCC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB;AAAA,SAChBC,eAAe,0CAExB;AAAA,SACSC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS;AAClD,SAASC,KAAK,QAAQ,KAAK;AAE3B,OAAO,MAAMC,kBAAkB,GAAGH,YAAY,CAAC;EAC7CI,OAAO,EAAEC,OAAO;EAEhB,GAAGnB,eAAe,EAAE;EACpB,GAAGE,gBAAgB,EAAE;EACrB,GAAGE,kBAAkB,EAAE;EACvB,GAAGE,gBAAgB,EAAE;EACrB,GAAGE,YAAY,EAAE;EACjB,GAAGC,cAAc,EAAE;EACnB,GAAGE,gBAAgB;AACrB,CAAC,EAAE,aAAa,CAAC;AAEjB,OAAO,MAAMS,SAAS,GAAGP,gBAAgB,EAAE,CAAC;EAC1CQ,IAAI,EAAE,WAAW;EAEjBC,KAAK,EAAEL,kBAAkB,EAAE;EAE3BM,KAAK,CAAED,KAAK,QAAa;IAAA,IAAX;MAAEE;IAAM,CAAC;IACrB,MAAM;MAAEC;IAAa,CAAC,GAAGf,YAAY,CAACY,KAAK,CAAC;IAC5C,MAAM;MAAEI;IAAe,CAAC,GAAGvB,UAAU,CAACmB,KAAK,CAAC;IAC5C,MAAM;MAAEK;IAAc,CAAC,GAAG1B,SAAS,CAACqB,KAAK,CAAC;IAC1C,MAAM;MAAEM;IAAiB,CAAC,GAAGvB,YAAY,CAACiB,KAAK,CAAC;IAChD,MAAM;MAAEO;IAAe,CAAC,GAAGtB,UAAU,CAACe,KAAK,CAAC;IAE5CV,eAAe,CAAC;MACdkB,IAAI,EAAE;QACJC,MAAM,EAAE,MAAM;QACdC,KAAK,EAAEhB,KAAK,CAACM,KAAK,EAAE,OAAO,CAAC;QAC5BW,OAAO,EAAEjB,KAAK,CAACM,KAAK,EAAE,SAAS,CAAC;QAChCY,IAAI,EAAE,IAAI;QACVC,OAAO,EAAEnB,KAAK,CAACM,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFP,SAAS,CAAC,MAAM;MACd;QAAA,SAEW,CACL,aAAa,EACb;UACE,sBAAsB,EAAEO,KAAK,CAACJ;QAChC,CAAC,EACDO,YAAY,CAACW,KAAK,EAClBT,aAAa,CAACS,KAAK,EACnBV,cAAc,CAACU,KAAK,EACpBR,gBAAgB,CAACQ,KAAK,EACtBP,cAAc,CAACO,KAAK;MACrB,GACSZ,KAAK;IAGrB,CAAC,CAAC;EACJ;AACF,CAAC,CAAC"}
@@ -1,8 +1,136 @@
1
1
  import * as vue from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes } from 'vue';
3
+
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
2
7
 
3
8
  type Density = null | 'default' | 'comfortable' | 'compact';
4
9
 
5
- declare const VBtnGroup: vue.DefineComponent<{
10
+ declare const VBtnGroup: {
11
+ new (...args: any[]): {
12
+ $: vue.ComponentInternalInstance;
13
+ $data: {};
14
+ $props: Partial<{
15
+ tag: string;
16
+ rounded: string | number | boolean;
17
+ density: Density;
18
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
19
+ divided: boolean;
20
+ }> & Omit<{
21
+ tag: string;
22
+ density: Density;
23
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
24
+ divided: boolean;
25
+ } & {
26
+ border?: string | number | boolean | undefined;
27
+ color?: string | undefined;
28
+ elevation?: string | number | undefined;
29
+ theme?: string | undefined;
30
+ rounded?: string | number | boolean | undefined;
31
+ } & {
32
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
33
+ default?: (() => vue.VNodeChild) | undefined;
34
+ };
35
+ $slots?: {
36
+ default?: (() => vue.VNodeChild) | undefined;
37
+ } | undefined;
38
+ 'v-slots'?: {
39
+ default?: false | (() => vue.VNodeChild) | undefined;
40
+ } | undefined;
41
+ } & {
42
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
43
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "tag" | "rounded" | "density" | "variant" | "divided">;
44
+ $attrs: {
45
+ [x: string]: unknown;
46
+ };
47
+ $refs: {
48
+ [x: string]: unknown;
49
+ };
50
+ $slots: Readonly<{
51
+ [name: string]: vue.Slot | undefined;
52
+ }>;
53
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
54
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
55
+ $emit: (event: string, ...args: any[]) => void;
56
+ $el: any;
57
+ $options: vue.ComponentOptionsBase<{
58
+ tag: string;
59
+ density: Density;
60
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
61
+ divided: boolean;
62
+ } & {
63
+ border?: string | number | boolean | undefined;
64
+ color?: string | undefined;
65
+ elevation?: string | number | undefined;
66
+ theme?: string | undefined;
67
+ rounded?: string | number | boolean | undefined;
68
+ } & {
69
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
70
+ default?: (() => vue.VNodeChild) | undefined;
71
+ };
72
+ $slots?: {
73
+ default?: (() => vue.VNodeChild) | undefined;
74
+ } | undefined;
75
+ 'v-slots'?: {
76
+ default?: false | (() => vue.VNodeChild) | undefined;
77
+ } | undefined;
78
+ } & {
79
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
80
+ }, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
81
+ tag: string;
82
+ rounded: string | number | boolean;
83
+ density: Density;
84
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
85
+ divided: boolean;
86
+ }, {}, string> & {
87
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
88
+ created?: ((() => void) | (() => void)[]) | undefined;
89
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
90
+ mounted?: ((() => void) | (() => void)[]) | undefined;
91
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
92
+ updated?: ((() => void) | (() => void)[]) | undefined;
93
+ activated?: ((() => void) | (() => void)[]) | undefined;
94
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
95
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
96
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
97
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
98
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
99
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
100
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
101
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
102
+ };
103
+ $forceUpdate: () => void;
104
+ $nextTick: typeof vue.nextTick;
105
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
106
+ } & {
107
+ tag: string;
108
+ density: Density;
109
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
110
+ divided: boolean;
111
+ } & {
112
+ border?: string | number | boolean | undefined;
113
+ color?: string | undefined;
114
+ elevation?: string | number | undefined;
115
+ theme?: string | undefined;
116
+ rounded?: string | number | boolean | undefined;
117
+ } & {
118
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
119
+ default?: (() => vue.VNodeChild) | undefined;
120
+ };
121
+ $slots?: {
122
+ default?: (() => vue.VNodeChild) | undefined;
123
+ } | undefined;
124
+ 'v-slots'?: {
125
+ default?: false | (() => vue.VNodeChild) | undefined;
126
+ } | undefined;
127
+ } & {
128
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
129
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
130
+ __isFragment?: undefined;
131
+ __isTeleport?: undefined;
132
+ __isSuspense?: undefined;
133
+ } & vue.ComponentOptionsBase<{
6
134
  tag: string;
7
135
  density: Density;
8
136
  variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
@@ -17,38 +145,75 @@ declare const VBtnGroup: vue.DefineComponent<{
17
145
  $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
18
146
  default?: (() => vue.VNodeChild) | undefined;
19
147
  };
20
- 'v-slots'?: {
21
- default?: false | (() => vue.VNodeChild) | undefined;
22
- } | undefined;
23
- } & {
24
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
25
- }, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
26
- tag: string;
27
- density: Density;
28
- variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
29
- divided: boolean;
30
- } & {
31
- border?: string | number | boolean | undefined;
32
- color?: string | undefined;
33
- elevation?: string | number | undefined;
34
- theme?: string | undefined;
35
- rounded?: string | number | boolean | undefined;
36
- } & {
37
- $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
148
+ $slots?: {
38
149
  default?: (() => vue.VNodeChild) | undefined;
39
- };
150
+ } | undefined;
40
151
  'v-slots'?: {
41
152
  default?: false | (() => vue.VNodeChild) | undefined;
42
153
  } | undefined;
43
154
  } & {
44
155
  "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
45
- }, {
156
+ }, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
46
157
  tag: string;
47
158
  rounded: string | number | boolean;
48
159
  density: Density;
49
160
  variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
50
161
  divided: boolean;
51
- }>;
162
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
163
+ color: StringConstructor;
164
+ variant: {
165
+ type: vue.PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
166
+ default: string;
167
+ validator: (v: any) => boolean;
168
+ };
169
+ theme: StringConstructor;
170
+ tag: {
171
+ type: StringConstructor;
172
+ default: string;
173
+ };
174
+ rounded: {
175
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
176
+ default: undefined;
177
+ };
178
+ elevation: {
179
+ type: (StringConstructor | NumberConstructor)[];
180
+ validator(v: any): boolean;
181
+ };
182
+ density: {
183
+ type: vue.PropType<Density>;
184
+ default: string;
185
+ validator: (v: any) => boolean;
186
+ };
187
+ border: (StringConstructor | BooleanConstructor | NumberConstructor)[];
188
+ divided: BooleanConstructor;
189
+ }, vue.ExtractPropTypes<{
190
+ color: StringConstructor;
191
+ variant: {
192
+ type: vue.PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
193
+ default: string;
194
+ validator: (v: any) => boolean;
195
+ };
196
+ theme: StringConstructor;
197
+ tag: {
198
+ type: StringConstructor;
199
+ default: string;
200
+ };
201
+ rounded: {
202
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
203
+ default: undefined;
204
+ };
205
+ elevation: {
206
+ type: (StringConstructor | NumberConstructor)[];
207
+ validator(v: any): boolean;
208
+ };
209
+ density: {
210
+ type: vue.PropType<Density>;
211
+ default: string;
212
+ validator: (v: any) => boolean;
213
+ };
214
+ border: (StringConstructor | BooleanConstructor | NumberConstructor)[];
215
+ divided: BooleanConstructor;
216
+ }>>;
52
217
  type VBtnGroup = InstanceType<typeof VBtnGroup>;
53
218
 
54
219
  export { VBtnGroup };
@@ -3,7 +3,7 @@ import { createVNode as _createVNode, mergeProps as _mergeProps } from "vue";
3
3
  import "./VBtnToggle.css";
4
4
 
5
5
  // Components
6
- import { filterVBtnGroupProps, makeVBtnGroupProps, VBtnGroup } from "../VBtnGroup/VBtnGroup.mjs"; // Composables
6
+ import { makeVBtnGroupProps, VBtnGroup } from "../VBtnGroup/VBtnGroup.mjs"; // Composables
7
7
  import { makeGroupProps, useGroup } from "../../composables/group.mjs"; // Utility
8
8
  import { genericComponent, useRender } from "../../util/index.mjs"; // Types
9
9
  export const VBtnToggleSymbol = Symbol.for('vuetify:v-btn-toggle');
@@ -28,7 +28,7 @@ export const VBtnToggle = genericComponent()({
28
28
  selected
29
29
  } = useGroup(props, VBtnToggleSymbol);
30
30
  useRender(() => {
31
- const [btnGroupProps] = filterVBtnGroupProps(props);
31
+ const [btnGroupProps] = VBtnGroup.filterProps(props);
32
32
  return _createVNode(VBtnGroup, _mergeProps({
33
33
  "class": "v-btn-toggle"
34
34
  }, btnGroupProps), {
@@ -1 +1 @@
1
- {"version":3,"file":"VBtnToggle.mjs","names":["filterVBtnGroupProps","makeVBtnGroupProps","VBtnGroup","makeGroupProps","useGroup","genericComponent","useRender","VBtnToggleSymbol","Symbol","for","VBtnToggle","name","props","emits","value","setup","slots","isSelected","next","prev","select","selected","btnGroupProps","default"],"sources":["../../../src/components/VBtnToggle/VBtnToggle.tsx"],"sourcesContent":["// Styles\nimport './VBtnToggle.sass'\n\n// Components\nimport { filterVBtnGroupProps, makeVBtnGroupProps, VBtnGroup } from '@/components/VBtnGroup/VBtnGroup'\n\n// Composables\nimport { makeGroupProps, useGroup } from '@/composables/group'\n\n// Utility\nimport { genericComponent, useRender } from '@/util'\n\n// Types\nimport type { InjectionKey } from 'vue'\nimport type { GroupProvide } from '@/composables/group'\n\nexport type BtnToggleSlotProps = 'isSelected' | 'select' | 'selected' | 'next' | 'prev'\nexport interface DefaultBtnToggleSlot extends Pick<GroupProvide, BtnToggleSlotProps> {}\n\nexport const VBtnToggleSymbol: InjectionKey<GroupProvide> = Symbol.for('vuetify:v-btn-toggle')\n\ntype VBtnToggleSlots = {\n default: [DefaultBtnToggleSlot]\n}\n\nexport const VBtnToggle = genericComponent<VBtnToggleSlots>()({\n name: 'VBtnToggle',\n\n props: {\n ...makeVBtnGroupProps(),\n ...makeGroupProps(),\n },\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { isSelected, next, prev, select, selected } = useGroup(props, VBtnToggleSymbol)\n\n useRender(() => {\n const [btnGroupProps] = filterVBtnGroupProps(props)\n\n return (\n <VBtnGroup\n class=\"v-btn-toggle\"\n { ...btnGroupProps }\n >\n { slots.default?.({\n isSelected,\n next,\n prev,\n select,\n selected,\n } as DefaultBtnToggleSlot) }\n </VBtnGroup>\n )\n })\n\n return {\n next,\n prev,\n select,\n }\n },\n})\n\nexport type VBtnToggle = InstanceType<typeof VBtnToggle>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,oBAAoB,EAAEC,kBAAkB,EAAEC,SAAS,sCAE5D;AAAA,SACSC,cAAc,EAAEC,QAAQ,uCAEjC;AAAA,SACSC,gBAAgB,EAAEC,SAAS,gCAEpC;AAOA,OAAO,MAAMC,gBAA4C,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAM9F,OAAO,MAAMC,UAAU,GAAGL,gBAAgB,EAAmB,CAAC;EAC5DM,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAE;IACL,GAAGX,kBAAkB,EAAE;IACvB,GAAGE,cAAc;EACnB,CAAC;EAEDU,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAK,CAAEH,KAAK,QAAa;IAAA,IAAX;MAAEI;IAAM,CAAC;IACrB,MAAM;MAAEC,UAAU;MAAEC,IAAI;MAAEC,IAAI;MAAEC,MAAM;MAAEC;IAAS,CAAC,GAAGjB,QAAQ,CAACQ,KAAK,EAAEL,gBAAgB,CAAC;IAEtFD,SAAS,CAAC,MAAM;MACd,MAAM,CAACgB,aAAa,CAAC,GAAGtB,oBAAoB,CAACY,KAAK,CAAC;MAEnD;QAAA,SAEU;MAAc,GACfU,aAAa;QAAA,gBAEhBN,KAAK,CAACO,OAAO,GAAG;UAChBN,UAAU;UACVC,IAAI;UACJC,IAAI;UACJC,MAAM;UACNC;QACF,CAAC,CAAyB;MAAA;IAGhC,CAAC,CAAC;IAEF,OAAO;MACLH,IAAI;MACJC,IAAI;MACJC;IACF,CAAC;EACH;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"VBtnToggle.mjs","names":["makeVBtnGroupProps","VBtnGroup","makeGroupProps","useGroup","genericComponent","useRender","VBtnToggleSymbol","Symbol","for","VBtnToggle","name","props","emits","value","setup","slots","isSelected","next","prev","select","selected","btnGroupProps","filterProps","default"],"sources":["../../../src/components/VBtnToggle/VBtnToggle.tsx"],"sourcesContent":["// Styles\nimport './VBtnToggle.sass'\n\n// Components\nimport { makeVBtnGroupProps, VBtnGroup } from '@/components/VBtnGroup/VBtnGroup'\n\n// Composables\nimport { makeGroupProps, useGroup } from '@/composables/group'\n\n// Utility\nimport { genericComponent, useRender } from '@/util'\n\n// Types\nimport type { InjectionKey } from 'vue'\nimport type { GroupProvide } from '@/composables/group'\n\nexport type BtnToggleSlotProps = 'isSelected' | 'select' | 'selected' | 'next' | 'prev'\nexport interface DefaultBtnToggleSlot extends Pick<GroupProvide, BtnToggleSlotProps> {}\n\nexport const VBtnToggleSymbol: InjectionKey<GroupProvide> = Symbol.for('vuetify:v-btn-toggle')\n\ntype VBtnToggleSlots = {\n default: [DefaultBtnToggleSlot]\n}\n\nexport const VBtnToggle = genericComponent<VBtnToggleSlots>()({\n name: 'VBtnToggle',\n\n props: {\n ...makeVBtnGroupProps(),\n ...makeGroupProps(),\n },\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { isSelected, next, prev, select, selected } = useGroup(props, VBtnToggleSymbol)\n\n useRender(() => {\n const [btnGroupProps] = VBtnGroup.filterProps(props)\n\n return (\n <VBtnGroup\n class=\"v-btn-toggle\"\n { ...btnGroupProps }\n >\n { slots.default?.({\n isSelected,\n next,\n prev,\n select,\n selected,\n } as DefaultBtnToggleSlot)}\n </VBtnGroup>\n )\n })\n\n return {\n next,\n prev,\n select,\n }\n },\n})\n\nexport type VBtnToggle = InstanceType<typeof VBtnToggle>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,kBAAkB,EAAEC,SAAS,sCAEtC;AAAA,SACSC,cAAc,EAAEC,QAAQ,uCAEjC;AAAA,SACSC,gBAAgB,EAAEC,SAAS,gCAEpC;AAOA,OAAO,MAAMC,gBAA4C,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAM9F,OAAO,MAAMC,UAAU,GAAGL,gBAAgB,EAAmB,CAAC;EAC5DM,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAE;IACL,GAAGX,kBAAkB,EAAE;IACvB,GAAGE,cAAc;EACnB,CAAC;EAEDU,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAK,CAAEH,KAAK,QAAa;IAAA,IAAX;MAAEI;IAAM,CAAC;IACrB,MAAM;MAAEC,UAAU;MAAEC,IAAI;MAAEC,IAAI;MAAEC,MAAM;MAAEC;IAAS,CAAC,GAAGjB,QAAQ,CAACQ,KAAK,EAAEL,gBAAgB,CAAC;IAEtFD,SAAS,CAAC,MAAM;MACd,MAAM,CAACgB,aAAa,CAAC,GAAGpB,SAAS,CAACqB,WAAW,CAACX,KAAK,CAAC;MAEpD;QAAA,SAEU;MAAc,GACfU,aAAa;QAAA,gBAEhBN,KAAK,CAACQ,OAAO,GAAG;UAChBP,UAAU;UACVC,IAAI;UACJC,IAAI;UACJC,MAAM;UACNC;QACF,CAAC,CAAyB;MAAA;IAGhC,CAAC,CAAC;IAEF,OAAO;MACLH,IAAI;MACJC,IAAI;MACJC;IACF,CAAC;EACH;AACF,CAAC,CAAC"}
@@ -1,5 +1,9 @@
1
1
  import * as vue from 'vue';
2
- import { ComponentInternalInstance, Ref, ComputedRef } from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes, ComponentInternalInstance, Ref, ComputedRef } from 'vue';
3
+
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
3
7
 
4
8
  type Density = null | 'default' | 'comfortable' | 'compact';
5
9
 
@@ -29,7 +33,170 @@ interface GroupProvide {
29
33
  type BtnToggleSlotProps = 'isSelected' | 'select' | 'selected' | 'next' | 'prev';
30
34
  interface DefaultBtnToggleSlot extends Pick<GroupProvide, BtnToggleSlotProps> {
31
35
  }
32
- declare const VBtnToggle: vue.DefineComponent<{
36
+ declare const VBtnToggle: {
37
+ new (...args: any[]): {
38
+ $: vue.ComponentInternalInstance;
39
+ $data: {};
40
+ $props: Partial<{
41
+ disabled: boolean;
42
+ multiple: boolean;
43
+ tag: string;
44
+ rounded: string | number | boolean;
45
+ density: Density;
46
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
47
+ modelValue: any;
48
+ divided: boolean;
49
+ }> & Omit<{
50
+ disabled: boolean;
51
+ multiple: boolean;
52
+ tag: string;
53
+ density: Density;
54
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
55
+ divided: boolean;
56
+ } & {
57
+ max?: number | undefined;
58
+ border?: string | number | boolean | undefined;
59
+ color?: string | undefined;
60
+ mandatory?: boolean | "force" | undefined;
61
+ elevation?: string | number | undefined;
62
+ theme?: string | undefined;
63
+ rounded?: string | number | boolean | undefined;
64
+ modelValue?: any;
65
+ selectedClass?: string | undefined;
66
+ } & {
67
+ $children?: vue.VNodeChild | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | {
68
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
69
+ };
70
+ $slots?: {
71
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
72
+ } | undefined;
73
+ 'v-slots'?: {
74
+ default?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
75
+ } | undefined;
76
+ } & {
77
+ "v-slot:default"?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
78
+ } & {
79
+ "onUpdate:modelValue"?: ((value: any) => any) | undefined;
80
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "disabled" | "multiple" | "tag" | "rounded" | "density" | "variant" | "modelValue" | "divided">;
81
+ $attrs: {
82
+ [x: string]: unknown;
83
+ };
84
+ $refs: {
85
+ [x: string]: unknown;
86
+ };
87
+ $slots: Readonly<{
88
+ [name: string]: vue.Slot | undefined;
89
+ }>;
90
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
91
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
92
+ $emit: (event: "update:modelValue", value: any) => void;
93
+ $el: any;
94
+ $options: vue.ComponentOptionsBase<{
95
+ disabled: boolean;
96
+ multiple: boolean;
97
+ tag: string;
98
+ density: Density;
99
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
100
+ divided: boolean;
101
+ } & {
102
+ max?: number | undefined;
103
+ border?: string | number | boolean | undefined;
104
+ color?: string | undefined;
105
+ mandatory?: boolean | "force" | undefined;
106
+ elevation?: string | number | undefined;
107
+ theme?: string | undefined;
108
+ rounded?: string | number | boolean | undefined;
109
+ modelValue?: any;
110
+ selectedClass?: string | undefined;
111
+ } & {
112
+ $children?: vue.VNodeChild | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | {
113
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
114
+ };
115
+ $slots?: {
116
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
117
+ } | undefined;
118
+ 'v-slots'?: {
119
+ default?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
120
+ } | undefined;
121
+ } & {
122
+ "v-slot:default"?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
123
+ } & {
124
+ "onUpdate:modelValue"?: ((value: any) => any) | undefined;
125
+ }, {
126
+ next: () => void;
127
+ prev: () => void;
128
+ select: (id: number, value: boolean) => void;
129
+ }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
130
+ 'update:modelValue': (value: any) => boolean;
131
+ }, string, {
132
+ disabled: boolean;
133
+ multiple: boolean;
134
+ tag: string;
135
+ rounded: string | number | boolean;
136
+ density: Density;
137
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
138
+ modelValue: any;
139
+ divided: boolean;
140
+ }, {}, string> & {
141
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
142
+ created?: ((() => void) | (() => void)[]) | undefined;
143
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
144
+ mounted?: ((() => void) | (() => void)[]) | undefined;
145
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
146
+ updated?: ((() => void) | (() => void)[]) | undefined;
147
+ activated?: ((() => void) | (() => void)[]) | undefined;
148
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
149
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
150
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
151
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
152
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
153
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
154
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
155
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
156
+ };
157
+ $forceUpdate: () => void;
158
+ $nextTick: typeof vue.nextTick;
159
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
160
+ } & {
161
+ disabled: boolean;
162
+ multiple: boolean;
163
+ tag: string;
164
+ density: Density;
165
+ variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
166
+ divided: boolean;
167
+ } & {
168
+ max?: number | undefined;
169
+ border?: string | number | boolean | undefined;
170
+ color?: string | undefined;
171
+ mandatory?: boolean | "force" | undefined;
172
+ elevation?: string | number | undefined;
173
+ theme?: string | undefined;
174
+ rounded?: string | number | boolean | undefined;
175
+ modelValue?: any;
176
+ selectedClass?: string | undefined;
177
+ } & {
178
+ $children?: vue.VNodeChild | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | {
179
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
180
+ };
181
+ $slots?: {
182
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
183
+ } | undefined;
184
+ 'v-slots'?: {
185
+ default?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
186
+ } | undefined;
187
+ } & {
188
+ "v-slot:default"?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
189
+ } & {
190
+ "onUpdate:modelValue"?: ((value: any) => any) | undefined;
191
+ } & vue.ShallowUnwrapRef<{
192
+ next: () => void;
193
+ prev: () => void;
194
+ select: (id: number, value: boolean) => void;
195
+ }> & {} & vue.ComponentCustomProperties & {};
196
+ __isFragment?: undefined;
197
+ __isTeleport?: undefined;
198
+ __isSuspense?: undefined;
199
+ } & vue.ComponentOptionsBase<{
33
200
  disabled: boolean;
34
201
  multiple: boolean;
35
202
  tag: string;
@@ -50,46 +217,23 @@ declare const VBtnToggle: vue.DefineComponent<{
50
217
  $children?: vue.VNodeChild | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | {
51
218
  default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
52
219
  };
220
+ $slots?: {
221
+ default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
222
+ } | undefined;
53
223
  'v-slots'?: {
54
224
  default?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
55
225
  } | undefined;
56
226
  } & {
57
227
  "v-slot:default"?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
228
+ } & {
229
+ "onUpdate:modelValue"?: ((value: any) => any) | undefined;
58
230
  }, {
59
231
  next: () => void;
60
232
  prev: () => void;
61
233
  select: (id: number, value: boolean) => void;
62
234
  }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
63
235
  'update:modelValue': (value: any) => boolean;
64
- }, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
65
- disabled: boolean;
66
- multiple: boolean;
67
- tag: string;
68
- density: Density;
69
- variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
70
- divided: boolean;
71
- } & {
72
- max?: number | undefined;
73
- border?: string | number | boolean | undefined;
74
- color?: string | undefined;
75
- mandatory?: boolean | "force" | undefined;
76
- elevation?: string | number | undefined;
77
- theme?: string | undefined;
78
- rounded?: string | number | boolean | undefined;
79
- modelValue?: any;
80
- selectedClass?: string | undefined;
81
- } & {
82
- $children?: vue.VNodeChild | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | {
83
- default?: ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
84
- };
85
- 'v-slots'?: {
86
- default?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
87
- } | undefined;
88
- } & {
89
- "v-slot:default"?: false | ((args_0: DefaultBtnToggleSlot) => vue.VNodeChild) | undefined;
90
- } & {
91
- "onUpdate:modelValue"?: ((value: any) => any) | undefined;
92
- }, {
236
+ }, string, {
93
237
  disabled: boolean;
94
238
  multiple: boolean;
95
239
  tag: string;
@@ -98,7 +242,79 @@ declare const VBtnToggle: vue.DefineComponent<{
98
242
  variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
99
243
  modelValue: any;
100
244
  divided: boolean;
101
- }>;
245
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
246
+ modelValue: {
247
+ type: null;
248
+ default: undefined;
249
+ };
250
+ multiple: BooleanConstructor;
251
+ mandatory: vue.PropType<boolean | "force">;
252
+ max: NumberConstructor;
253
+ selectedClass: StringConstructor;
254
+ disabled: BooleanConstructor;
255
+ color: StringConstructor;
256
+ variant: {
257
+ type: vue.PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
258
+ default: string;
259
+ validator: (v: any) => boolean;
260
+ };
261
+ theme: StringConstructor;
262
+ tag: {
263
+ type: StringConstructor;
264
+ default: string;
265
+ };
266
+ rounded: {
267
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
268
+ default: undefined;
269
+ };
270
+ elevation: {
271
+ type: (StringConstructor | NumberConstructor)[];
272
+ validator(v: any): boolean;
273
+ };
274
+ density: {
275
+ type: vue.PropType<Density>;
276
+ default: string;
277
+ validator: (v: any) => boolean;
278
+ };
279
+ border: (StringConstructor | BooleanConstructor | NumberConstructor)[];
280
+ divided: BooleanConstructor;
281
+ }, vue.ExtractPropTypes<{
282
+ modelValue: {
283
+ type: null;
284
+ default: undefined;
285
+ };
286
+ multiple: BooleanConstructor;
287
+ mandatory: vue.PropType<boolean | "force">;
288
+ max: NumberConstructor;
289
+ selectedClass: StringConstructor;
290
+ disabled: BooleanConstructor;
291
+ color: StringConstructor;
292
+ variant: {
293
+ type: vue.PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
294
+ default: string;
295
+ validator: (v: any) => boolean;
296
+ };
297
+ theme: StringConstructor;
298
+ tag: {
299
+ type: StringConstructor;
300
+ default: string;
301
+ };
302
+ rounded: {
303
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
304
+ default: undefined;
305
+ };
306
+ elevation: {
307
+ type: (StringConstructor | NumberConstructor)[];
308
+ validator(v: any): boolean;
309
+ };
310
+ density: {
311
+ type: vue.PropType<Density>;
312
+ default: string;
313
+ validator: (v: any) => boolean;
314
+ };
315
+ border: (StringConstructor | BooleanConstructor | NumberConstructor)[];
316
+ divided: BooleanConstructor;
317
+ }>>;
102
318
  type VBtnToggle = InstanceType<typeof VBtnToggle>;
103
319
 
104
320
  export { VBtnToggle };
@@ -128,19 +128,23 @@ export const VCard = genericComponent()({
128
128
  "onClick": isClickable.value && link.navigate,
129
129
  "tabindex": props.disabled ? -1 : undefined
130
130
  }, {
131
- default: () => [hasImage && _createVNode(VDefaultsProvider, {
131
+ default: () => [hasImage && _createVNode("div", {
132
132
  "key": "image",
133
+ "class": "v-card__image"
134
+ }, [!slots.image ? _createVNode(VImg, {
135
+ "key": "image-img",
136
+ "cover": true,
137
+ "src": props.image
138
+ }, null) : _createVNode(VDefaultsProvider, {
139
+ "key": "image-defaults",
140
+ "disabled": !props.image,
133
141
  "defaults": {
134
142
  VImg: {
135
143
  cover: true,
136
144
  src: props.image
137
145
  }
138
146
  }
139
- }, {
140
- default: () => [_createVNode("div", {
141
- "class": "v-card__image"
142
- }, [slots.image?.() ?? _createVNode(VImg, null, null)])]
143
- }), _createVNode(LoaderSlot, {
147
+ }, slots.image)]), _createVNode(LoaderSlot, {
144
148
  "name": "v-card",
145
149
  "active": !!props.loading,
146
150
  "color": typeof props.loading === 'boolean' ? undefined : props.loading