vuetify 3.1.4 → 3.1.6

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 (474) hide show
  1. package/dist/json/attributes.json +2734 -2738
  2. package/dist/json/importMap.json +32 -32
  3. package/dist/json/tags.json +0 -1
  4. package/dist/json/web-types.json +9073 -6416
  5. package/dist/vuetify-labs.css +3119 -6004
  6. package/dist/vuetify-labs.d.ts +12865 -20825
  7. package/dist/vuetify-labs.esm.js +1674 -1914
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +1673 -1913
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +54 -2948
  12. package/dist/vuetify.d.ts +12215 -20183
  13. package/dist/vuetify.esm.js +1495 -1736
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +1494 -1735
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +1134 -1353
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.ts +9 -9
  21. package/lib/blueprints/md1.d.ts +9 -9
  22. package/lib/blueprints/md2.d.ts +9 -9
  23. package/lib/blueprints/md3.d.ts +9 -9
  24. package/lib/blueprints/md3.mjs.map +1 -1
  25. package/lib/components/VAlert/VAlert.mjs +5 -6
  26. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  27. package/lib/components/VAlert/index.d.ts +135 -157
  28. package/lib/components/VApp/VApp.mjs +9 -12
  29. package/lib/components/VApp/VApp.mjs.map +1 -1
  30. package/lib/components/VApp/index.d.ts +27 -13
  31. package/lib/components/VAppBar/VAppBar.mjs +9 -5
  32. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  33. package/lib/components/VAppBar/VAppBarNavIcon.mjs +2 -2
  34. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  35. package/lib/components/VAppBar/VAppBarTitle.mjs +2 -2
  36. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  37. package/lib/components/VAppBar/index.d.ts +169 -350
  38. package/lib/components/VAutocomplete/VAutocomplete.mjs +100 -104
  39. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  40. package/lib/components/VAutocomplete/index.d.ts +494 -636
  41. package/lib/components/VAvatar/VAvatar.mjs +19 -22
  42. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  43. package/lib/components/VAvatar/index.d.ts +46 -66
  44. package/lib/components/VBadge/VBadge.mjs +7 -5
  45. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  46. package/lib/components/VBadge/index.d.ts +74 -100
  47. package/lib/components/VBanner/VBanner.mjs +3 -4
  48. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  49. package/lib/components/VBanner/VBannerActions.mjs +5 -8
  50. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  51. package/lib/components/VBanner/index.d.ts +134 -98
  52. package/lib/components/VBottomNavigation/VBottomNavigation.css +2 -1
  53. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +8 -4
  54. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  55. package/lib/components/VBottomNavigation/VBottomNavigation.sass +2 -1
  56. package/lib/components/VBottomNavigation/_variables.scss +1 -1
  57. package/lib/components/VBottomNavigation/index.d.ts +67 -131
  58. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +9 -16
  59. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  60. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +5 -8
  61. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  62. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +4 -8
  63. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  64. package/lib/components/VBreadcrumbs/index.d.ts +87 -61
  65. package/lib/components/VBtn/VBtn.mjs +14 -17
  66. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  67. package/lib/components/VBtn/index.d.ts +118 -179
  68. package/lib/components/VBtnGroup/VBtnGroup.mjs +5 -2
  69. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  70. package/lib/components/VBtnGroup/index.d.ts +42 -57
  71. package/lib/components/VBtnToggle/VBtnToggle.mjs +1 -2
  72. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  73. package/lib/components/VBtnToggle/index.d.ts +60 -247
  74. package/lib/components/VCalendar/mixins/mouse.mjs +2 -3
  75. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  76. package/lib/components/VCard/VCard.mjs +5 -6
  77. package/lib/components/VCard/VCard.mjs.map +1 -1
  78. package/lib/components/VCard/VCardActions.mjs +5 -8
  79. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  80. package/lib/components/VCard/VCardItem.mjs +7 -8
  81. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  82. package/lib/components/VCard/index.d.ts +286 -186
  83. package/lib/components/VCarousel/VCarousel.mjs +2 -2
  84. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  85. package/lib/components/VCarousel/VCarouselItem.mjs +2 -2
  86. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  87. package/lib/components/VCarousel/index.d.ts +238 -61
  88. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  89. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  90. package/lib/components/VCheckbox/VCheckboxBtn.mjs +2 -2
  91. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  92. package/lib/components/VCheckbox/index.d.ts +277 -254
  93. package/lib/components/VChip/VChip.mjs +15 -14
  94. package/lib/components/VChip/VChip.mjs.map +1 -1
  95. package/lib/components/VChip/index.d.ts +118 -168
  96. package/lib/components/VChipGroup/VChipGroup.css +1 -0
  97. package/lib/components/VChipGroup/VChipGroup.mjs +15 -18
  98. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  99. package/lib/components/VChipGroup/VChipGroup.sass +1 -0
  100. package/lib/components/VChipGroup/index.d.ts +49 -68
  101. package/lib/components/VCode/index.d.ts +21 -9
  102. package/lib/components/VColorPicker/VColorPicker.mjs +9 -1
  103. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  104. package/lib/components/VColorPicker/VColorPickerCanvas.css +2 -1
  105. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +40 -27
  106. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  107. package/lib/components/VColorPicker/VColorPickerCanvas.sass +2 -1
  108. package/lib/components/VColorPicker/VColorPickerEdit.mjs +16 -20
  109. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  110. package/lib/components/VColorPicker/VColorPickerPreview.mjs +43 -46
  111. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  112. package/lib/components/VColorPicker/index.d.ts +1 -1
  113. package/lib/components/VColorPicker/util/index.mjs +3 -7
  114. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  115. package/lib/components/VCombobox/VCombobox.mjs +104 -113
  116. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  117. package/lib/components/VCombobox/index.d.ts +496 -638
  118. package/lib/components/VCounter/VCounter.mjs +2 -2
  119. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  120. package/lib/components/VCounter/index.d.ts +139 -197
  121. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -9
  122. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  123. package/lib/components/VDefaultsProvider/index.d.ts +33 -14
  124. package/lib/components/VDialog/VDialog.mjs +6 -9
  125. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  126. package/lib/components/VDialog/index.d.ts +430 -1610
  127. package/lib/components/VDivider/VDivider.mjs +2 -2
  128. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  129. package/lib/components/VDivider/index.d.ts +35 -15
  130. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +4 -5
  131. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  132. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +11 -14
  133. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  134. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +19 -22
  135. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  136. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +2 -2
  137. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  138. package/lib/components/VExpansionPanel/index.d.ts +180 -158
  139. package/lib/components/VField/VField.mjs +3 -6
  140. package/lib/components/VField/VField.mjs.map +1 -1
  141. package/lib/components/VField/VFieldLabel.mjs +2 -2
  142. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  143. package/lib/components/VField/index.d.ts +46 -34
  144. package/lib/components/VFileInput/VFileInput.mjs +16 -18
  145. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  146. package/lib/components/VFileInput/index.d.ts +330 -355
  147. package/lib/components/VFooter/VFooter.mjs +2 -2
  148. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  149. package/lib/components/VFooter/index.d.ts +46 -66
  150. package/lib/components/VForm/VForm.mjs +10 -14
  151. package/lib/components/VForm/VForm.mjs.map +1 -1
  152. package/lib/components/VForm/index.d.ts +29 -23
  153. package/lib/components/VGrid/VCol.mjs +5 -8
  154. package/lib/components/VGrid/VCol.mjs.map +1 -1
  155. package/lib/components/VGrid/VContainer.mjs +2 -2
  156. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  157. package/lib/components/VGrid/VGrid.css +0 -125
  158. package/lib/components/VGrid/VRow.mjs +5 -8
  159. package/lib/components/VGrid/VRow.mjs.map +1 -1
  160. package/lib/components/VGrid/index.d.ts +112 -121
  161. package/lib/components/VHover/VHover.mjs +9 -12
  162. package/lib/components/VHover/VHover.mjs.map +1 -1
  163. package/lib/components/VHover/index.d.ts +53 -15
  164. package/lib/components/VIcon/VIcon.mjs +22 -26
  165. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  166. package/lib/components/VIcon/index.d.ts +68 -56
  167. package/lib/components/VImg/VImg.mjs +7 -11
  168. package/lib/components/VImg/VImg.mjs.map +1 -1
  169. package/lib/components/VImg/index.d.ts +67 -58
  170. package/lib/components/VInput/VInput.mjs +5 -6
  171. package/lib/components/VInput/VInput.mjs.map +1 -1
  172. package/lib/components/VInput/index.d.ts +94 -283
  173. package/lib/components/VItemGroup/VItem.mjs +8 -11
  174. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  175. package/lib/components/VItemGroup/VItemGroup.mjs +13 -16
  176. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  177. package/lib/components/VItemGroup/index.d.ts +76 -149
  178. package/lib/components/VKbd/index.d.ts +21 -9
  179. package/lib/components/VLabel/VLabel.mjs +7 -10
  180. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  181. package/lib/components/VLabel/index.d.ts +29 -9
  182. package/lib/components/VLayout/VLayout.mjs +9 -12
  183. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  184. package/lib/components/VLayout/VLayoutItem.mjs +6 -9
  185. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  186. package/lib/components/VLayout/index.d.ts +60 -43
  187. package/lib/components/VLazy/VLazy.mjs +12 -15
  188. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  189. package/lib/components/VLazy/index.d.ts +48 -71
  190. package/lib/components/VList/VList.mjs +4 -8
  191. package/lib/components/VList/VList.mjs.map +1 -1
  192. package/lib/components/VList/VListChildren.mjs +59 -77
  193. package/lib/components/VList/VListChildren.mjs.map +1 -1
  194. package/lib/components/VList/VListGroup.mjs +33 -39
  195. package/lib/components/VList/VListGroup.mjs.map +1 -1
  196. package/lib/components/VList/VListItem.css +2 -2
  197. package/lib/components/VList/VListItem.mjs +10 -18
  198. package/lib/components/VList/VListItem.mjs.map +1 -1
  199. package/lib/components/VList/VListItem.sass +0 -2
  200. package/lib/components/VList/VListItemAction.mjs +2 -2
  201. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  202. package/lib/components/VList/VListItemMedia.mjs +2 -2
  203. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  204. package/lib/components/VList/VListSubheader.mjs +3 -4
  205. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  206. package/lib/components/VList/index.d.ts +418 -686
  207. package/lib/components/VList/list.mjs +1 -1
  208. package/lib/components/VList/list.mjs.map +1 -1
  209. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -8
  210. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  211. package/lib/components/VLocaleProvider/index.d.ts +28 -16
  212. package/lib/components/VMain/VMain.mjs +12 -15
  213. package/lib/components/VMain/VMain.mjs.map +1 -1
  214. package/lib/components/VMain/index.d.ts +23 -17
  215. package/lib/components/VMenu/VMenu.mjs +10 -10
  216. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  217. package/lib/components/VMenu/index.d.ts +428 -1641
  218. package/lib/components/VMessages/VMessages.mjs +2 -2
  219. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  220. package/lib/components/VMessages/index.d.ts +144 -204
  221. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +6 -7
  222. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  223. package/lib/components/VNavigationDrawer/index.d.ts +92 -124
  224. package/lib/components/VNoSsr/VNoSsr.mjs +1 -4
  225. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  226. package/lib/components/VNoSsr/index.d.ts +20 -4
  227. package/lib/components/VOtpInput/VOtpInput.mjs +5 -6
  228. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -1
  229. package/lib/components/VOverlay/VOverlay.mjs +44 -47
  230. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  231. package/lib/components/VOverlay/index.d.ts +150 -468
  232. package/lib/components/VOverlay/locationStrategies.mjs +3 -6
  233. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  234. package/lib/components/VOverlay/scrollStrategies.mjs +8 -13
  235. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  236. package/lib/components/VOverlay/useActivator.mjs +4 -7
  237. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  238. package/lib/components/VPagination/VPagination.mjs +4 -5
  239. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  240. package/lib/components/VPagination/index.d.ts +107 -207
  241. package/lib/components/VParallax/VParallax.mjs +12 -15
  242. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  243. package/lib/components/VParallax/index.d.ts +39 -9
  244. package/lib/components/VProgressCircular/VProgressCircular.mjs +2 -2
  245. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  246. package/lib/components/VProgressCircular/index.d.ts +41 -58
  247. package/lib/components/VProgressLinear/VProgressLinear.mjs +2 -2
  248. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  249. package/lib/components/VProgressLinear/index.d.ts +91 -95
  250. package/lib/components/VRadio/VRadio.mjs +2 -2
  251. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  252. package/lib/components/VRadio/index.d.ts +108 -85
  253. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -2
  254. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  255. package/lib/components/VRadioGroup/index.d.ts +164 -147
  256. package/lib/components/VRangeSlider/VRangeSlider.mjs +21 -31
  257. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  258. package/lib/components/VRangeSlider/index.d.ts +154 -210
  259. package/lib/components/VRating/VRating.mjs +28 -34
  260. package/lib/components/VRating/VRating.mjs.map +1 -1
  261. package/lib/components/VRating/index.d.ts +77 -311
  262. package/lib/components/VResponsive/VResponsive.mjs +11 -14
  263. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  264. package/lib/components/VResponsive/index.d.ts +44 -20
  265. package/lib/components/VSelect/VSelect.mjs +100 -102
  266. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  267. package/lib/components/VSelect/index.d.ts +729 -673
  268. package/lib/components/VSelectionControl/VSelectionControl.mjs +3 -4
  269. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  270. package/lib/components/VSelectionControl/index.d.ts +31 -19
  271. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +8 -11
  272. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  273. package/lib/components/VSelectionControlGroup/index.d.ts +58 -70
  274. package/lib/components/VSheet/VSheet.mjs +23 -13
  275. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  276. package/lib/components/VSheet/index.d.ts +52 -56
  277. package/lib/components/VSlideGroup/VSlideGroup.mjs +51 -60
  278. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  279. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +6 -9
  280. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  281. package/lib/components/VSlideGroup/index.d.ts +144 -366
  282. package/lib/components/VSlider/VSlider.mjs +8 -14
  283. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  284. package/lib/components/VSlider/VSliderThumb.css +0 -1
  285. package/lib/components/VSlider/VSliderThumb.mjs +4 -5
  286. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  287. package/lib/components/VSlider/VSliderTrack.mjs +4 -5
  288. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  289. package/lib/components/VSlider/index.d.ts +151 -207
  290. package/lib/components/VSlider/slider.mjs +3 -6
  291. package/lib/components/VSlider/slider.mjs.map +1 -1
  292. package/lib/components/VSnackbar/VSnackbar.mjs +1 -1
  293. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  294. package/lib/components/VSnackbar/index.d.ts +358 -1519
  295. package/lib/components/VSwitch/VSwitch.mjs +3 -4
  296. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  297. package/lib/components/VSwitch/index.d.ts +180 -151
  298. package/lib/components/VSystemBar/VSystemBar.css +5 -1
  299. package/lib/components/VSystemBar/VSystemBar.mjs +8 -4
  300. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  301. package/lib/components/VSystemBar/VSystemBar.sass +5 -1
  302. package/lib/components/VSystemBar/_variables.scss +4 -1
  303. package/lib/components/VSystemBar/index.d.ts +43 -51
  304. package/lib/components/VTable/VTable.mjs +19 -22
  305. package/lib/components/VTable/VTable.mjs.map +1 -1
  306. package/lib/components/VTable/index.d.ts +54 -30
  307. package/lib/components/VTabs/VTab.mjs +3 -4
  308. package/lib/components/VTabs/VTab.mjs.map +1 -1
  309. package/lib/components/VTabs/VTabs.mjs +2 -2
  310. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  311. package/lib/components/VTabs/index.d.ts +122 -150
  312. package/lib/components/VTextField/VTextField.mjs +16 -19
  313. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  314. package/lib/components/VTextField/index.d.ts +331 -1489
  315. package/lib/components/VTextarea/VTextarea.mjs +17 -19
  316. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  317. package/lib/components/VTextarea/index.d.ts +320 -334
  318. package/lib/components/VThemeProvider/VThemeProvider.mjs +4 -5
  319. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  320. package/lib/components/VThemeProvider/index.d.ts +27 -13
  321. package/lib/components/VTimeline/VTimeline.mjs +2 -2
  322. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  323. package/lib/components/VTimeline/VTimelineDivider.mjs +20 -23
  324. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  325. package/lib/components/VTimeline/VTimelineItem.mjs +33 -34
  326. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  327. package/lib/components/VTimeline/index.d.ts +123 -135
  328. package/lib/components/VToolbar/VToolbar.css +1 -0
  329. package/lib/components/VToolbar/VToolbar.mjs +7 -9
  330. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  331. package/lib/components/VToolbar/VToolbar.sass +1 -0
  332. package/lib/components/VToolbar/VToolbarItems.mjs +5 -8
  333. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  334. package/lib/components/VToolbar/VToolbarTitle.mjs +1 -2
  335. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  336. package/lib/components/VToolbar/index.d.ts +146 -351
  337. package/lib/components/VTooltip/VTooltip.mjs +1 -2
  338. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  339. package/lib/components/VTooltip/index.d.ts +361 -1619
  340. package/lib/components/VValidation/VValidation.mjs +3 -6
  341. package/lib/components/VValidation/VValidation.mjs.map +1 -1
  342. package/lib/components/VValidation/index.d.ts +48 -46
  343. package/lib/components/VWindow/VWindow.mjs +19 -22
  344. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  345. package/lib/components/VWindow/VWindowItem.mjs +10 -14
  346. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  347. package/lib/components/VWindow/index.d.ts +152 -284
  348. package/lib/components/index.d.ts +13684 -21652
  349. package/lib/components/transitions/createTransition.mjs +4 -4
  350. package/lib/components/transitions/createTransition.mjs.map +1 -1
  351. package/lib/components/transitions/dialog-transition.mjs +8 -8
  352. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  353. package/lib/components/transitions/index.d.ts +477 -342
  354. package/lib/composables/defaults.mjs +6 -4
  355. package/lib/composables/defaults.mjs.map +1 -1
  356. package/lib/composables/delay.mjs +1 -1
  357. package/lib/composables/delay.mjs.map +1 -1
  358. package/lib/composables/filter.mjs +11 -12
  359. package/lib/composables/filter.mjs.map +1 -1
  360. package/lib/composables/group.mjs +2 -2
  361. package/lib/composables/group.mjs.map +1 -1
  362. package/lib/composables/icons.mjs +4 -6
  363. package/lib/composables/icons.mjs.map +1 -1
  364. package/lib/composables/intersectionObserver.mjs +1 -1
  365. package/lib/composables/intersectionObserver.mjs.map +1 -1
  366. package/lib/composables/layout.mjs +2 -5
  367. package/lib/composables/layout.mjs.map +1 -1
  368. package/lib/composables/loader.mjs +2 -3
  369. package/lib/composables/loader.mjs.map +1 -1
  370. package/lib/composables/locale.mjs +2 -2
  371. package/lib/composables/locale.mjs.map +1 -1
  372. package/lib/composables/mutationObserver.mjs +8 -8
  373. package/lib/composables/mutationObserver.mjs.map +1 -1
  374. package/lib/composables/nested/nested.mjs +2 -2
  375. package/lib/composables/nested/nested.mjs.map +1 -1
  376. package/lib/composables/nested/selectStrategies.mjs +8 -2
  377. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  378. package/lib/composables/proxiedModel.mjs +8 -9
  379. package/lib/composables/proxiedModel.mjs.map +1 -1
  380. package/lib/composables/resizeObserver.mjs +1 -1
  381. package/lib/composables/resizeObserver.mjs.map +1 -1
  382. package/lib/composables/router.mjs +12 -21
  383. package/lib/composables/router.mjs.map +1 -1
  384. package/lib/composables/scroll.mjs +2 -4
  385. package/lib/composables/scroll.mjs.map +1 -1
  386. package/lib/composables/selectLink.mjs +1 -4
  387. package/lib/composables/selectLink.mjs.map +1 -1
  388. package/lib/composables/stack.mjs +6 -8
  389. package/lib/composables/stack.mjs.map +1 -1
  390. package/lib/composables/teleport.mjs +1 -1
  391. package/lib/composables/teleport.mjs.map +1 -1
  392. package/lib/composables/theme.mjs +23 -16
  393. package/lib/composables/theme.mjs.map +1 -1
  394. package/lib/composables/toggleScope.mjs +3 -6
  395. package/lib/composables/toggleScope.mjs.map +1 -1
  396. package/lib/composables/touch.mjs +1 -2
  397. package/lib/composables/touch.mjs.map +1 -1
  398. package/lib/composables/validation.mjs +7 -7
  399. package/lib/composables/validation.mjs.map +1 -1
  400. package/lib/directives/click-outside/index.mjs +2 -3
  401. package/lib/directives/click-outside/index.mjs.map +1 -1
  402. package/lib/directives/index.d.ts +1 -1
  403. package/lib/directives/intersect/index.mjs +2 -4
  404. package/lib/directives/intersect/index.mjs.map +1 -1
  405. package/lib/directives/mutate/index.mjs +7 -8
  406. package/lib/directives/mutate/index.mjs.map +1 -1
  407. package/lib/directives/resize/index.mjs +3 -5
  408. package/lib/directives/resize/index.mjs.map +1 -1
  409. package/lib/directives/ripple/index.mjs +8 -13
  410. package/lib/directives/ripple/index.mjs.map +1 -1
  411. package/lib/directives/scroll/index.mjs +1 -2
  412. package/lib/directives/scroll/index.mjs.map +1 -1
  413. package/lib/directives/touch/index.mjs +9 -14
  414. package/lib/directives/touch/index.mjs.map +1 -1
  415. package/lib/entry-bundler.mjs +1 -1
  416. package/lib/framework.mjs +2 -3
  417. package/lib/framework.mjs.map +1 -1
  418. package/lib/iconsets/fa-svg.d.ts +2 -2
  419. package/lib/iconsets/fa.d.ts +2 -2
  420. package/lib/iconsets/fa4.d.ts +2 -2
  421. package/lib/iconsets/md.d.ts +2 -2
  422. package/lib/iconsets/mdi-svg.d.ts +2 -2
  423. package/lib/iconsets/mdi.d.ts +2 -2
  424. package/lib/index.d.ts +18 -18
  425. package/lib/labs/VDataTable/VDataTable.mjs +11 -14
  426. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  427. package/lib/labs/VDataTable/VDataTableColumn.mjs +1 -2
  428. package/lib/labs/VDataTable/VDataTableColumn.mjs.map +1 -1
  429. package/lib/labs/VDataTable/VDataTableFooter.css +9 -0
  430. package/lib/labs/VDataTable/VDataTableFooter.mjs +80 -45
  431. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  432. package/lib/labs/VDataTable/VDataTableFooter.sass +7 -0
  433. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +6 -8
  434. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
  435. package/lib/labs/VDataTable/VDataTableHeaders.mjs +3 -4
  436. package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
  437. package/lib/labs/VDataTable/VDataTableRow.mjs +2 -4
  438. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  439. package/lib/labs/VDataTable/VDataTableRows.mjs +45 -49
  440. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  441. package/lib/labs/VDataTable/VDataTableServer.mjs +17 -20
  442. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  443. package/lib/labs/VDataTable/VDataTableVirtual.mjs +2 -2
  444. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  445. package/lib/labs/VDataTable/composables/headers.mjs +3 -4
  446. package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
  447. package/lib/labs/VDataTable/composables/paginate.mjs +1 -6
  448. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  449. package/lib/labs/VDataTable/composables/sort.mjs +1 -1
  450. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  451. package/lib/labs/VDataTable/index.d.ts +583 -575
  452. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs +14 -18
  453. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  454. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs +7 -13
  455. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs.map +1 -1
  456. package/lib/labs/VVirtualScroll/index.d.ts +18 -18
  457. package/lib/labs/components.d.ts +601 -593
  458. package/lib/locale/adapters/vue-i18n.d.ts +1 -1
  459. package/lib/locale/adapters/vuetify.mjs +3 -3
  460. package/lib/locale/adapters/vuetify.mjs.map +1 -1
  461. package/lib/styles/main.css +40 -2816
  462. package/lib/util/colorUtils.mjs +4 -5
  463. package/lib/util/colorUtils.mjs.map +1 -1
  464. package/lib/util/console.mjs +1 -1
  465. package/lib/util/console.mjs.map +1 -1
  466. package/lib/util/createSimpleFunctional.mjs +5 -8
  467. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  468. package/lib/util/defineComponent.mjs +6 -8
  469. package/lib/util/defineComponent.mjs.map +1 -1
  470. package/lib/util/getCurrentInstance.mjs +1 -1
  471. package/lib/util/getCurrentInstance.mjs.map +1 -1
  472. package/lib/util/helpers.mjs +2 -3
  473. package/lib/util/helpers.mjs.map +1 -1
  474. package/package.json +19 -20
@@ -1,6 +1,6 @@
1
1
  import { JSXComponent, PropType } from 'vue';
2
2
 
3
- declare type IconValue = string | JSXComponent;
3
+ type IconValue = string | JSXComponent;
4
4
  declare const IconValue: PropType<IconValue>;
5
5
  interface IconAliases {
6
6
  [name: string]: IconValue;
@@ -44,7 +44,7 @@ interface IconProps {
44
44
  icon?: IconValue;
45
45
  disabled?: Boolean;
46
46
  }
47
- declare type IconComponent = JSXComponent<IconProps>;
47
+ type IconComponent = JSXComponent<IconProps>;
48
48
  interface IconSet {
49
49
  component: IconComponent;
50
50
  }
@@ -1,6 +1,6 @@
1
1
  import { JSXComponent, PropType } from 'vue';
2
2
 
3
- declare type IconValue = string | JSXComponent;
3
+ type IconValue = string | JSXComponent;
4
4
  declare const IconValue: PropType<IconValue>;
5
5
  interface IconAliases {
6
6
  [name: string]: IconValue;
@@ -44,7 +44,7 @@ interface IconProps {
44
44
  icon?: IconValue;
45
45
  disabled?: Boolean;
46
46
  }
47
- declare type IconComponent = JSXComponent<IconProps>;
47
+ type IconComponent = JSXComponent<IconProps>;
48
48
  interface IconSet {
49
49
  component: IconComponent;
50
50
  }
package/lib/index.d.ts CHANGED
@@ -33,16 +33,16 @@ declare function useRtl(): {
33
33
  rtlClasses: Ref<string>;
34
34
  };
35
35
 
36
- declare type DeepPartial<T> = T extends object ? {
36
+ type DeepPartial<T> = T extends object ? {
37
37
  [P in keyof T]?: DeepPartial<T[P]>;
38
38
  } : T;
39
- declare type ThemeOptions = false | {
39
+ type ThemeOptions = false | {
40
40
  cspNonce?: string;
41
41
  defaultTheme?: string;
42
42
  variations?: false | VariationsOptions;
43
43
  themes?: Record<string, ThemeDefinition>;
44
44
  };
45
- declare type ThemeDefinition = DeepPartial<InternalThemeDefinition>;
45
+ type ThemeDefinition = DeepPartial<InternalThemeDefinition>;
46
46
  interface VariationsOptions {
47
47
  colors: string[];
48
48
  lighten: number;
@@ -91,7 +91,7 @@ interface ThemeInstance {
91
91
  }
92
92
  declare function useTheme(): ThemeInstance;
93
93
 
94
- declare type DisplayBreakpoint = keyof DisplayThresholds;
94
+ type DisplayBreakpoint = keyof DisplayThresholds;
95
95
  interface DisplayThresholds {
96
96
  xs: number;
97
97
  sm: number;
@@ -145,13 +145,13 @@ interface DisplayInstance {
145
145
  }
146
146
  declare function useDisplay(): DisplayInstance;
147
147
 
148
- declare type DefaultsInstance = undefined | {
148
+ type DefaultsInstance = undefined | {
149
149
  [key: string]: undefined | Record<string, unknown>;
150
150
  global?: Record<string, unknown>;
151
151
  };
152
- declare type DefaultsOptions = Partial<DefaultsInstance>;
152
+ type DefaultsOptions = Partial<DefaultsInstance>;
153
153
 
154
- declare type IconValue = string | JSXComponent;
154
+ type IconValue = string | JSXComponent;
155
155
  declare const IconValue: PropType<IconValue>;
156
156
  interface IconAliases {
157
157
  [name: string]: IconValue;
@@ -195,17 +195,17 @@ interface IconProps {
195
195
  icon?: IconValue;
196
196
  disabled?: Boolean;
197
197
  }
198
- declare type IconComponent = JSXComponent<IconProps>;
198
+ type IconComponent = JSXComponent<IconProps>;
199
199
  interface IconSet {
200
200
  component: IconComponent;
201
201
  }
202
- declare type IconOptions = {
202
+ type IconOptions = {
203
203
  defaultSet: string;
204
204
  aliases?: Partial<IconAliases>;
205
205
  sets: Record<string, IconSet>;
206
206
  };
207
207
 
208
- declare type Position = 'top' | 'left' | 'right' | 'bottom';
208
+ type Position = 'top' | 'left' | 'right' | 'bottom';
209
209
  interface Layer {
210
210
  top: number;
211
211
  bottom: number;
@@ -361,6 +361,9 @@ declare module '@vue/runtime-core' {
361
361
  VBannerActions: typeof import('vuetify/components')['VBannerActions']
362
362
  VBannerText: typeof import('vuetify/components')['VBannerText']
363
363
  VBottomNavigation: typeof import('vuetify/components')['VBottomNavigation']
364
+ VBreadcrumbs: typeof import('vuetify/components')['VBreadcrumbs']
365
+ VBreadcrumbsItem: typeof import('vuetify/components')['VBreadcrumbsItem']
366
+ VBreadcrumbsDivider: typeof import('vuetify/components')['VBreadcrumbsDivider']
364
367
  VBtn: typeof import('vuetify/components')['VBtn']
365
368
  VBtnGroup: typeof import('vuetify/components')['VBtnGroup']
366
369
  VBtnToggle: typeof import('vuetify/components')['VBtnToggle']
@@ -390,17 +393,17 @@ declare module '@vue/runtime-core' {
390
393
  VFieldLabel: typeof import('vuetify/components')['VFieldLabel']
391
394
  VFileInput: typeof import('vuetify/components')['VFileInput']
392
395
  VFooter: typeof import('vuetify/components')['VFooter']
396
+ VIcon: typeof import('vuetify/components')['VIcon']
397
+ VComponentIcon: typeof import('vuetify/components')['VComponentIcon']
398
+ VSvgIcon: typeof import('vuetify/components')['VSvgIcon']
399
+ VLigatureIcon: typeof import('vuetify/components')['VLigatureIcon']
400
+ VClassIcon: typeof import('vuetify/components')['VClassIcon']
393
401
  VImg: typeof import('vuetify/components')['VImg']
394
402
  VInput: typeof import('vuetify/components')['VInput']
395
403
  VItemGroup: typeof import('vuetify/components')['VItemGroup']
396
404
  VItem: typeof import('vuetify/components')['VItem']
397
405
  VKbd: typeof import('vuetify/components')['VKbd']
398
406
  VLabel: typeof import('vuetify/components')['VLabel']
399
- VIcon: typeof import('vuetify/components')['VIcon']
400
- VComponentIcon: typeof import('vuetify/components')['VComponentIcon']
401
- VSvgIcon: typeof import('vuetify/components')['VSvgIcon']
402
- VLigatureIcon: typeof import('vuetify/components')['VLigatureIcon']
403
- VClassIcon: typeof import('vuetify/components')['VClassIcon']
404
407
  VList: typeof import('vuetify/components')['VList']
405
408
  VListGroup: typeof import('vuetify/components')['VListGroup']
406
409
  VListImg: typeof import('vuetify/components')['VListImg']
@@ -443,8 +446,5 @@ declare module '@vue/runtime-core' {
443
446
  VTooltip: typeof import('vuetify/components')['VTooltip']
444
447
  VWindow: typeof import('vuetify/components')['VWindow']
445
448
  VWindowItem: typeof import('vuetify/components')['VWindowItem']
446
- VBreadcrumbs: typeof import('vuetify/components')['VBreadcrumbs']
447
- VBreadcrumbsItem: typeof import('vuetify/components')['VBreadcrumbsItem']
448
- VBreadcrumbsDivider: typeof import('vuetify/components')['VBreadcrumbsDivider']
449
449
  }
450
450
  }
@@ -18,7 +18,7 @@ import { createExpanded, makeDataTableExpandProps } from "./composables/expand.m
18
18
  import { useOptions } from "./composables/options.mjs";
19
19
  import { provideDefaults } from "../../composables/defaults.mjs"; // Utilities
20
20
  import { computed, toRef } from 'vue';
21
- import { defineComponent, propsFactory, useRender } from "../../util/index.mjs";
21
+ import { genericComponent, propsFactory, useRender } from "../../util/index.mjs";
22
22
  import { makeFilterProps, useFilter } from "../../composables/filter.mjs"; // Types
23
23
  export const makeVDataTableProps = propsFactory({
24
24
  ...makeDataTableItemProps(),
@@ -33,7 +33,7 @@ export const makeVDataTableProps = propsFactory({
33
33
  fixedHeader: Boolean,
34
34
  fixedFooter: Boolean
35
35
  }, 'v-data-table');
36
- export const VDataTable = defineComponent({
36
+ export const VDataTable = genericComponent()({
37
37
  name: 'VDataTable',
38
38
  props: {
39
39
  search: String,
@@ -124,18 +124,15 @@ export const VDataTable = defineComponent({
124
124
  "height": props.height
125
125
  }, {
126
126
  top: slots.top,
127
- default: slots.default ?? (() => {
128
- var _slots$colgroup, _slots$thead, _slots$tbody, _slots$tfoot;
129
- return _createVNode(_Fragment, null, [(_slots$colgroup = slots.colgroup) == null ? void 0 : _slots$colgroup.call(slots, {
130
- columns
131
- }), _createVNode("thead", null, [slots.headers ? slots.headers() : _createVNode(VDataTableHeaders, {
132
- "sticky": props.fixedHeader,
133
- "multiSort": props.multiSort
134
- }, slots)]), (_slots$thead = slots.thead) == null ? void 0 : _slots$thead.call(slots), _createVNode("tbody", null, [slots.body ? slots.body() : _createVNode(VDataTableRows, {
135
- "items": paginatedItems.value,
136
- "onClick:row": (event, value) => emit('click:row', event, value)
137
- }, slots)]), (_slots$tbody = slots.tbody) == null ? void 0 : _slots$tbody.call(slots), (_slots$tfoot = slots.tfoot) == null ? void 0 : _slots$tfoot.call(slots)]);
138
- }),
127
+ default: slots.default ?? (() => _createVNode(_Fragment, null, [slots.colgroup?.({
128
+ columns
129
+ }), _createVNode("thead", null, [slots.headers ? slots.headers() : _createVNode(VDataTableHeaders, {
130
+ "sticky": props.fixedHeader,
131
+ "multiSort": props.multiSort
132
+ }, slots)]), slots.thead?.(), _createVNode("tbody", null, [slots.body ? slots.body() : _createVNode(VDataTableRows, {
133
+ "items": paginatedItems.value,
134
+ "onClick:row": (event, value) => emit('click:row', event, value)
135
+ }, slots)]), slots.tbody?.(), slots.tfoot?.()])),
139
136
  bottom: slots.bottom ?? (() => _createVNode(VDataTableFooter, null, {
140
137
  prepend: slots['footer.prepend']
141
138
  }))
@@ -1 +1 @@
1
- {"version":3,"file":"VDataTable.mjs","names":["VTable","VDataTableHeaders","VDataTableRows","VDataTableFooter","useProxiedModel","makeDataTableItemProps","useDataTableItems","createHeaders","makeDataTableHeaderProps","createSort","makeDataTableSortProps","useSortedItems","createGroupBy","makeDataTableGroupProps","useGroupedItems","createPagination","makeDataTablePaginateProps","usePaginatedItems","createSelection","makeDataTableSelectProps","createExpanded","makeDataTableExpandProps","useOptions","provideDefaults","computed","toRef","defineComponent","propsFactory","useRender","makeFilterProps","useFilter","makeVDataTableProps","hideNoData","Boolean","noDataText","type","String","default","height","Number","width","fixedHeader","fixedFooter","VDataTable","name","props","search","emits","value","event","setup","emit","slots","groupBy","columns","showSelect","showExpand","items","filterKeys","map","c","key","filteredItems","sortBy","sortByWithGroups","opened","extractRows","sortedItems","flatItems","page","itemsPerPage","startIndex","stopIndex","paginatedItems","paginatedItemsWithoutGroups","top","colgroup","headers","multiSort","thead","body","tbody","tfoot","bottom","prepend"],"sources":["../../../src/labs/VDataTable/VDataTable.tsx"],"sourcesContent":["// Styles\nimport './VDataTable.sass'\n\n// Components\nimport { VTable } from '@/components/VTable'\nimport { VDataTableHeaders } from './VDataTableHeaders'\nimport { VDataTableRows } from './VDataTableRows'\nimport { VDataTableFooter } from './VDataTableFooter'\n\n// Composables\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeDataTableItemProps, useDataTableItems } from './composables/items'\nimport { createHeaders, makeDataTableHeaderProps } from './composables/headers'\nimport { createSort, makeDataTableSortProps, useSortedItems } from './composables/sort'\nimport { createGroupBy, makeDataTableGroupProps, useGroupedItems } from './composables/group'\nimport { createPagination, makeDataTablePaginateProps, usePaginatedItems } from './composables/paginate'\nimport { createSelection, makeDataTableSelectProps } from './composables/select'\nimport { createExpanded, makeDataTableExpandProps } from './composables/expand'\nimport { useOptions } from './composables/options'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { defineComponent, propsFactory, useRender } from '@/util'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\n\n// Types\nimport type { DataTableItem } from './types'\n\nexport const makeVDataTableProps = propsFactory({\n ...makeDataTableItemProps(),\n ...makeDataTableHeaderProps(),\n hideNoData: Boolean,\n noDataText: {\n type: String,\n default: '$vuetify.noDataText',\n },\n height: [String, Number],\n width: [String, Number],\n fixedHeader: Boolean,\n fixedFooter: Boolean,\n}, 'v-data-table')\n\nexport const VDataTable = defineComponent({\n name: 'VDataTable',\n\n props: {\n search: String,\n\n ...makeVDataTableProps(),\n ...makeDataTableExpandProps(),\n ...makeDataTableGroupProps(),\n ...makeDataTableSelectProps(),\n ...makeDataTableSortProps(),\n ...makeDataTablePaginateProps(),\n ...makeFilterProps(),\n },\n\n emits: {\n 'update:modelValue': (value: any[]) => true,\n 'update:page': (value: number) => true,\n 'update:itemsPerPage': (value: number) => true,\n 'update:sortBy': (value: any) => true,\n 'update:options': (value: any) => true,\n 'update:groupBy': (value: any) => true,\n 'update:expanded': (value: any) => true,\n 'click:row': (event: Event, value: { item: DataTableItem }) => true,\n },\n\n setup (props, { emit, slots }) {\n const groupBy = useProxiedModel(props, 'groupBy')\n\n const { columns } = createHeaders(props, {\n groupBy,\n showSelect: toRef(props, 'showSelect'),\n showExpand: toRef(props, 'showExpand'),\n })\n\n const { items } = useDataTableItems(props, columns)\n\n const filterKeys = computed(() => columns.value.map(c => 'columns.' + c.key))\n const { filteredItems } = useFilter<DataTableItem>(props, items, toRef(props, 'search'), { filterKeys })\n\n const { sortBy } = createSort(props)\n const { sortByWithGroups, opened, extractRows } = createGroupBy(props, groupBy, sortBy)\n\n const { sortedItems } = useSortedItems(filteredItems, sortByWithGroups, columns)\n const { flatItems } = useGroupedItems(sortedItems, groupBy, opened)\n\n const { page, itemsPerPage, startIndex, stopIndex } = createPagination(props, flatItems)\n const { paginatedItems } = usePaginatedItems(flatItems, startIndex, stopIndex, itemsPerPage)\n\n const paginatedItemsWithoutGroups = computed(() => extractRows(paginatedItems.value))\n\n createSelection(props, paginatedItemsWithoutGroups)\n\n createExpanded(props)\n\n useOptions({\n page,\n itemsPerPage,\n sortBy,\n groupBy,\n })\n\n provideDefaults({\n VDataTableRows: {\n hideNoData: toRef(props, 'hideNoData'),\n noDataText: toRef(props, 'noDataText'),\n },\n })\n\n useRender(() => (\n <VTable\n class={[\n 'v-data-table',\n {\n 'v-data-table--show-select': props.showSelect,\n },\n ]}\n fixedHeader={ props.fixedHeader }\n fixedFooter={ props.fixedFooter }\n height={ props.height }\n >\n {{\n top: slots.top,\n default: slots.default ?? (() => (\n <>\n { slots.colgroup?.({ columns }) }\n <thead>\n { slots.headers ? slots.headers() : (\n <VDataTableHeaders\n sticky={ props.fixedHeader }\n multiSort={ props.multiSort }\n v-slots={ slots }\n />\n ) }\n </thead>\n { slots.thead?.() }\n <tbody>\n { slots.body ? slots.body() : (\n <VDataTableRows\n items={ paginatedItems.value }\n onClick:row={ (event, value) => emit('click:row', event, value) }\n v-slots={ slots }\n />\n ) }\n </tbody>\n { slots.tbody?.() }\n { slots.tfoot?.() }\n </>\n )),\n bottom: slots.bottom ?? (() => (\n <VDataTableFooter\n v-slots={{\n prepend: slots['footer.prepend'],\n }}\n />\n )),\n }}\n </VTable>\n ))\n\n return {}\n },\n})\n\nexport type VDataTable = InstanceType<typeof VDataTable>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VDataTable.mjs","names":["VTable","VDataTableHeaders","VDataTableRows","VDataTableFooter","useProxiedModel","makeDataTableItemProps","useDataTableItems","createHeaders","makeDataTableHeaderProps","createSort","makeDataTableSortProps","useSortedItems","createGroupBy","makeDataTableGroupProps","useGroupedItems","createPagination","makeDataTablePaginateProps","usePaginatedItems","createSelection","makeDataTableSelectProps","createExpanded","makeDataTableExpandProps","useOptions","provideDefaults","computed","toRef","genericComponent","propsFactory","useRender","makeFilterProps","useFilter","makeVDataTableProps","hideNoData","Boolean","noDataText","type","String","default","height","Number","width","fixedHeader","fixedFooter","VDataTable","name","props","search","emits","value","event","setup","emit","slots","groupBy","columns","showSelect","showExpand","items","filterKeys","map","c","key","filteredItems","sortBy","sortByWithGroups","opened","extractRows","sortedItems","flatItems","page","itemsPerPage","startIndex","stopIndex","paginatedItems","paginatedItemsWithoutGroups","top","colgroup","headers","multiSort","thead","body","tbody","tfoot","bottom","prepend"],"sources":["../../../src/labs/VDataTable/VDataTable.tsx"],"sourcesContent":["// Styles\nimport './VDataTable.sass'\n\n// Components\nimport { VTable } from '@/components/VTable'\nimport { VDataTableHeaders } from './VDataTableHeaders'\nimport type { VDataTableRowsSlots } from './VDataTableRows'\nimport { VDataTableRows } from './VDataTableRows'\nimport { VDataTableFooter } from './VDataTableFooter'\n\n// Composables\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeDataTableItemProps, useDataTableItems } from './composables/items'\nimport { createHeaders, makeDataTableHeaderProps } from './composables/headers'\nimport { createSort, makeDataTableSortProps, useSortedItems } from './composables/sort'\nimport { createGroupBy, makeDataTableGroupProps, useGroupedItems } from './composables/group'\nimport { createPagination, makeDataTablePaginateProps, usePaginatedItems } from './composables/paginate'\nimport { createSelection, makeDataTableSelectProps } from './composables/select'\nimport { createExpanded, makeDataTableExpandProps } from './composables/expand'\nimport { useOptions } from './composables/options'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { genericComponent, propsFactory, useRender } from '@/util'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\n\n// Types\nimport type { DataTableItem } from './types'\n\nexport type VDataTableSlots = VDataTableRowsSlots & {\n default: []\n top: []\n headers: []\n body: []\n tbody: []\n thead: []\n tfoot: []\n bottom: []\n 'footer.prepend': []\n}\n\nexport const makeVDataTableProps = propsFactory({\n ...makeDataTableItemProps(),\n ...makeDataTableHeaderProps(),\n hideNoData: Boolean,\n noDataText: {\n type: String,\n default: '$vuetify.noDataText',\n },\n height: [String, Number],\n width: [String, Number],\n fixedHeader: Boolean,\n fixedFooter: Boolean,\n}, 'v-data-table')\n\nexport const VDataTable = genericComponent<VDataTableSlots & { colgroup: [] }>()({\n name: 'VDataTable',\n\n props: {\n search: String,\n\n ...makeVDataTableProps(),\n ...makeDataTableExpandProps(),\n ...makeDataTableGroupProps(),\n ...makeDataTableSelectProps(),\n ...makeDataTableSortProps(),\n ...makeDataTablePaginateProps(),\n ...makeFilterProps(),\n },\n\n emits: {\n 'update:modelValue': (value: any[]) => true,\n 'update:page': (value: number) => true,\n 'update:itemsPerPage': (value: number) => true,\n 'update:sortBy': (value: any) => true,\n 'update:options': (value: any) => true,\n 'update:groupBy': (value: any) => true,\n 'update:expanded': (value: any) => true,\n 'click:row': (event: Event, value: { item: DataTableItem }) => true,\n },\n\n setup (props, { emit, slots }) {\n const groupBy = useProxiedModel(props, 'groupBy')\n\n const { columns } = createHeaders(props, {\n groupBy,\n showSelect: toRef(props, 'showSelect'),\n showExpand: toRef(props, 'showExpand'),\n })\n\n const { items } = useDataTableItems(props, columns)\n\n const filterKeys = computed(() => columns.value.map(c => 'columns.' + c.key))\n const { filteredItems } = useFilter<DataTableItem>(props, items, toRef(props, 'search'), { filterKeys })\n\n const { sortBy } = createSort(props)\n const { sortByWithGroups, opened, extractRows } = createGroupBy(props, groupBy, sortBy)\n\n const { sortedItems } = useSortedItems(filteredItems, sortByWithGroups, columns)\n const { flatItems } = useGroupedItems(sortedItems, groupBy, opened)\n\n const { page, itemsPerPage, startIndex, stopIndex } = createPagination(props, flatItems)\n const { paginatedItems } = usePaginatedItems(flatItems, startIndex, stopIndex, itemsPerPage)\n\n const paginatedItemsWithoutGroups = computed(() => extractRows(paginatedItems.value))\n\n createSelection(props, paginatedItemsWithoutGroups)\n\n createExpanded(props)\n\n useOptions({\n page,\n itemsPerPage,\n sortBy,\n groupBy,\n })\n\n provideDefaults({\n VDataTableRows: {\n hideNoData: toRef(props, 'hideNoData'),\n noDataText: toRef(props, 'noDataText'),\n },\n })\n\n useRender(() => (\n <VTable\n class={[\n 'v-data-table',\n {\n 'v-data-table--show-select': props.showSelect,\n },\n ]}\n fixedHeader={ props.fixedHeader }\n fixedFooter={ props.fixedFooter }\n height={ props.height }\n >\n {{\n top: slots.top,\n default: slots.default ?? (() => (\n <>\n { slots.colgroup?.({ columns }) }\n <thead>\n { slots.headers ? slots.headers() : (\n <VDataTableHeaders\n sticky={ props.fixedHeader }\n multiSort={ props.multiSort }\n v-slots={ slots }\n />\n ) }\n </thead>\n { slots.thead?.() }\n <tbody>\n { slots.body ? slots.body() : (\n <VDataTableRows\n items={ paginatedItems.value }\n onClick:row={ (event, value) => emit('click:row', event, value) }\n v-slots={ slots }\n />\n ) }\n </tbody>\n { slots.tbody?.() }\n { slots.tfoot?.() }\n </>\n )),\n bottom: slots.bottom ?? (() => (\n <VDataTableFooter\n v-slots={{\n prepend: slots['footer.prepend'],\n }}\n />\n )),\n }}\n </VTable>\n ))\n\n return {}\n },\n})\n\nexport type VDataTable = InstanceType<typeof VDataTable>\n"],"mappings":"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"}
@@ -13,7 +13,6 @@ export const VDataTableColumn = defineFunctionalComponent({
13
13
  tag: String,
14
14
  width: [Number, String]
15
15
  }, (props, _ref) => {
16
- var _slots$default;
17
16
  let {
18
17
  slots,
19
18
  attrs
@@ -31,7 +30,7 @@ export const VDataTableColumn = defineFunctionalComponent({
31
30
  left: convertToUnit(props.fixedOffset || null)
32
31
  }
33
32
  }, attrs), {
34
- default: () => [(_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots)]
33
+ default: () => [slots.default?.()]
35
34
  });
36
35
  });
37
36
  //# sourceMappingURL=VDataTableColumn.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VDataTableColumn.mjs","names":["convertToUnit","defineFunctionalComponent","VDataTableColumn","align","type","String","default","fixed","Boolean","fixedOffset","Number","height","lastFixed","noPadding","tag","width","props","slots","attrs","Tag","left"],"sources":["../../../src/labs/VDataTable/VDataTableColumn.tsx"],"sourcesContent":["import { convertToUnit, defineFunctionalComponent } from '@/util'\nimport type { PropType } from 'vue'\n\nexport const VDataTableColumn = defineFunctionalComponent({\n align: {\n type: String as PropType<'start' | 'center' | 'end'>,\n default: 'start',\n },\n fixed: Boolean,\n fixedOffset: [Number, String],\n height: [Number, String],\n lastFixed: Boolean,\n noPadding: Boolean,\n tag: String,\n width: [Number, String],\n}, (props, { slots, attrs }) => {\n const Tag = props.tag ?? 'td'\n return (\n <Tag\n class={[\n 'v-data-table__td',\n {\n 'v-data-table-column--fixed': props.fixed,\n 'v-data-table-column--last-fixed': props.lastFixed,\n 'v-data-table-column--no-padding': props.noPadding,\n },\n `v-data-table-column--align-${props.align}`,\n ]}\n style={{\n height: convertToUnit(props.height),\n width: convertToUnit(props.width),\n left: convertToUnit(props.fixedOffset || null),\n }}\n { ...attrs }\n >\n { slots.default?.() }\n </Tag>\n )\n})\n"],"mappings":";SAASA,aAAa,EAAEC,yBAAyB;AAGjD,OAAO,MAAMC,gBAAgB,GAAGD,yBAAyB,CAAC;EACxDE,KAAK,EAAE;IACLC,IAAI,EAAEC,MAA8C;IACpDC,OAAO,EAAE;EACX,CAAC;EACDC,KAAK,EAAEC,OAAO;EACdC,WAAW,EAAE,CAACC,MAAM,EAAEL,MAAM,CAAC;EAC7BM,MAAM,EAAE,CAACD,MAAM,EAAEL,MAAM,CAAC;EACxBO,SAAS,EAAEJ,OAAO;EAClBK,SAAS,EAAEL,OAAO;EAClBM,GAAG,EAAET,MAAM;EACXU,KAAK,EAAE,CAACL,MAAM,EAAEL,MAAM;AACxB,CAAC,EAAE,CAACW,KAAK,WAAuB;EAAA;EAAA,IAArB;IAAEC,KAAK;IAAEC;EAAM,CAAC;EACzB,MAAMC,GAAG,GAAGH,KAAK,CAACF,GAAG,IAAI,IAAI;EAC7B;IAAA,SAEW,CACL,kBAAkB,EAClB;MACE,4BAA4B,EAAEE,KAAK,CAACT,KAAK;MACzC,iCAAiC,EAAES,KAAK,CAACJ,SAAS;MAClD,iCAAiC,EAAEI,KAAK,CAACH;IAC3C,CAAC,EACA,8BAA6BG,KAAK,CAACb,KAAM,EAAC,CAC5C;IAAA,SACM;MACLQ,MAAM,EAAEX,aAAa,CAACgB,KAAK,CAACL,MAAM,CAAC;MACnCI,KAAK,EAAEf,aAAa,CAACgB,KAAK,CAACD,KAAK,CAAC;MACjCK,IAAI,EAAEpB,aAAa,CAACgB,KAAK,CAACP,WAAW,IAAI,IAAI;IAC/C;EAAC,GACIS,KAAK;IAAA,kCAERD,KAAK,CAACX,OAAO,qBAAb,oBAAAW,KAAK,CAAY;EAAA;AAGzB,CAAC,CAAC"}
1
+ {"version":3,"file":"VDataTableColumn.mjs","names":["convertToUnit","defineFunctionalComponent","VDataTableColumn","align","type","String","default","fixed","Boolean","fixedOffset","Number","height","lastFixed","noPadding","tag","width","props","slots","attrs","Tag","left"],"sources":["../../../src/labs/VDataTable/VDataTableColumn.tsx"],"sourcesContent":["import { convertToUnit, defineFunctionalComponent } from '@/util'\nimport type { PropType } from 'vue'\n\nexport const VDataTableColumn = defineFunctionalComponent({\n align: {\n type: String as PropType<'start' | 'center' | 'end'>,\n default: 'start',\n },\n fixed: Boolean,\n fixedOffset: [Number, String],\n height: [Number, String],\n lastFixed: Boolean,\n noPadding: Boolean,\n tag: String,\n width: [Number, String],\n}, (props, { slots, attrs }) => {\n const Tag = props.tag ?? 'td'\n return (\n <Tag\n class={[\n 'v-data-table__td',\n {\n 'v-data-table-column--fixed': props.fixed,\n 'v-data-table-column--last-fixed': props.lastFixed,\n 'v-data-table-column--no-padding': props.noPadding,\n },\n `v-data-table-column--align-${props.align}`,\n ]}\n style={{\n height: convertToUnit(props.height),\n width: convertToUnit(props.width),\n left: convertToUnit(props.fixedOffset || null),\n }}\n { ...attrs }\n >\n { slots.default?.() }\n </Tag>\n )\n})\n"],"mappings":";SAASA,aAAa,EAAEC,yBAAyB;AAGjD,OAAO,MAAMC,gBAAgB,GAAGD,yBAAyB,CAAC;EACxDE,KAAK,EAAE;IACLC,IAAI,EAAEC,MAA8C;IACpDC,OAAO,EAAE;EACX,CAAC;EACDC,KAAK,EAAEC,OAAO;EACdC,WAAW,EAAE,CAACC,MAAM,EAAEL,MAAM,CAAC;EAC7BM,MAAM,EAAE,CAACD,MAAM,EAAEL,MAAM,CAAC;EACxBO,SAAS,EAAEJ,OAAO;EAClBK,SAAS,EAAEL,OAAO;EAClBM,GAAG,EAAET,MAAM;EACXU,KAAK,EAAE,CAACL,MAAM,EAAEL,MAAM;AACxB,CAAC,EAAE,CAACW,KAAK,WAAuB;EAAA,IAArB;IAAEC,KAAK;IAAEC;EAAM,CAAC;EACzB,MAAMC,GAAG,GAAGH,KAAK,CAACF,GAAG,IAAI,IAAI;EAC7B;IAAA,SAEW,CACL,kBAAkB,EAClB;MACE,4BAA4B,EAAEE,KAAK,CAACT,KAAK;MACzC,iCAAiC,EAAES,KAAK,CAACJ,SAAS;MAClD,iCAAiC,EAAEI,KAAK,CAACH;IAC3C,CAAC,EACA,8BAA6BG,KAAK,CAACb,KAAM,EAAC,CAC5C;IAAA,SACM;MACLQ,MAAM,EAAEX,aAAa,CAACgB,KAAK,CAACL,MAAM,CAAC;MACnCI,KAAK,EAAEf,aAAa,CAACgB,KAAK,CAACD,KAAK,CAAC;MACjCK,IAAI,EAAEpB,aAAa,CAACgB,KAAK,CAACP,WAAW,IAAI,IAAI;IAC/C;EAAC,GACIS,KAAK;IAAA,gBAERD,KAAK,CAACX,OAAO,IAAI;EAAA;AAGzB,CAAC,CAAC"}
@@ -19,4 +19,13 @@
19
19
  .v-data-table-footer__info {
20
20
  display: flex;
21
21
  padding-inline-end: 24px;
22
+ }
23
+
24
+ .v-data-table-footer__pagination {
25
+ display: flex;
26
+ align-items: center;
27
+ }
28
+
29
+ .v-data-table-footer__page {
30
+ padding: 0 8px;
22
31
  }
@@ -1,13 +1,15 @@
1
- import { createVNode as _createVNode, createTextVNode as _createTextVNode } from "vue";
1
+ import { createVNode as _createVNode } from "vue";
2
2
  // Styles
3
3
  import "./VDataTableFooter.css";
4
4
 
5
5
  // Components
6
6
  import { VBtn } from "../../components/VBtn/index.mjs";
7
7
  import { VSelect } from "../../components/VSelect/index.mjs"; // Composables
8
+ import { useLocale } from "../../composables/locale.mjs";
8
9
  import { usePagination } from "./composables/paginate.mjs"; // Utilities
9
- import { defineComponent } from "../../util/index.mjs"; // Types
10
- export const VDataTableFooter = defineComponent({
10
+ import { computed } from 'vue';
11
+ import { genericComponent } from "../../util/index.mjs"; // Types
12
+ export const VDataTableFooter = genericComponent()({
11
13
  name: 'VDataTableFooter',
12
14
  props: {
13
15
  prevIcon: {
@@ -26,6 +28,30 @@ export const VDataTableFooter = defineComponent({
26
28
  type: String,
27
29
  default: '$last'
28
30
  },
31
+ itemsPerPageText: {
32
+ type: String,
33
+ default: '$vuetify.dataFooter.itemsPerPageText'
34
+ },
35
+ pageText: {
36
+ type: String,
37
+ default: '$vuetify.dataFooter.pageText'
38
+ },
39
+ firstPageLabel: {
40
+ type: String,
41
+ default: '$vuetify.dataFooter.firstPage'
42
+ },
43
+ prevPageLabel: {
44
+ type: String,
45
+ default: '$vuetify.dataFooter.prevPage'
46
+ },
47
+ nextPageLabel: {
48
+ type: String,
49
+ default: '$vuetify.dataFooter.nextPage'
50
+ },
51
+ lastPageLabel: {
52
+ type: String,
53
+ default: '$vuetify.dataFooter.lastPage'
54
+ },
29
55
  itemsPerPageOptions: {
30
56
  type: Array,
31
57
  default: () => [{
@@ -42,7 +68,7 @@ export const VDataTableFooter = defineComponent({
42
68
  title: '100'
43
69
  }, {
44
70
  value: -1,
45
- title: 'All'
71
+ title: '$vuetify.dataFooter.itemsPerPageAll'
46
72
  }]
47
73
  },
48
74
  showCurrentPage: Boolean
@@ -51,6 +77,9 @@ export const VDataTableFooter = defineComponent({
51
77
  let {
52
78
  slots
53
79
  } = _ref;
80
+ const {
81
+ t
82
+ } = useLocale();
54
83
  const {
55
84
  page,
56
85
  pageCount,
@@ -59,47 +88,53 @@ export const VDataTableFooter = defineComponent({
59
88
  itemsLength,
60
89
  itemsPerPage
61
90
  } = usePagination();
62
- return () => {
63
- var _slots$prepend;
64
- return _createVNode("div", {
65
- "class": "v-data-table-footer"
66
- }, [(_slots$prepend = slots.prepend) == null ? void 0 : _slots$prepend.call(slots), _createVNode("div", {
67
- "class": "v-data-table-footer__items-per-page"
68
- }, [_createVNode("span", null, [_createTextVNode("Items per page:")]), _createVNode(VSelect, {
69
- "items": props.itemsPerPageOptions,
70
- "modelValue": itemsPerPage.value,
71
- "onUpdate:modelValue": v => itemsPerPage.value = Number(v),
72
- "density": "compact",
73
- "variant": "outlined",
74
- "hide-details": true
75
- }, null)]), _createVNode("div", {
76
- "class": "v-data-table-footer__info"
77
- }, [_createVNode("div", null, [!itemsLength.value ? 0 : startIndex.value + 1, _createTextVNode(" - "), stopIndex.value, _createTextVNode(" of "), itemsLength.value])]), _createVNode("div", {
78
- "class": "v-data-table-footer__pagination"
79
- }, [_createVNode(VBtn, {
80
- "icon": props.firstIcon,
81
- "variant": "plain",
82
- "onClick": () => page.value = 1,
83
- "disabled": page.value === 1
84
- }, null), _createVNode(VBtn, {
85
- "icon": props.prevIcon,
86
- "variant": "plain",
87
- "onClick": () => page.value = Math.max(1, page.value - 1),
88
- "disabled": page.value === 1
89
- }, null), props.showCurrentPage && _createVNode("div", {
90
- "key": "page"
91
- }, [_createTextVNode("page.value")]), _createVNode(VBtn, {
92
- "icon": props.nextIcon,
93
- "variant": "plain",
94
- "onClick": () => page.value = Math.min(pageCount.value, page.value + 1),
95
- "disabled": page.value === pageCount.value
96
- }, null), _createVNode(VBtn, {
97
- "icon": props.lastIcon,
98
- "variant": "plain",
99
- "onClick": () => page.value = pageCount.value,
100
- "disabled": page.value === pageCount.value
101
- }, null)])]);
102
- };
91
+ const itemsPerPageOptions = computed(() => props.itemsPerPageOptions.map(option => ({
92
+ ...option,
93
+ title: t(option.title)
94
+ })));
95
+ return () => _createVNode("div", {
96
+ "class": "v-data-table-footer"
97
+ }, [slots.prepend?.(), _createVNode("div", {
98
+ "class": "v-data-table-footer__items-per-page"
99
+ }, [_createVNode("span", null, [t(props.itemsPerPageText)]), _createVNode(VSelect, {
100
+ "items": itemsPerPageOptions.value,
101
+ "modelValue": itemsPerPage.value,
102
+ "onUpdate:modelValue": v => itemsPerPage.value = Number(v),
103
+ "density": "compact",
104
+ "variant": "outlined",
105
+ "hide-details": true
106
+ }, null)]), _createVNode("div", {
107
+ "class": "v-data-table-footer__info"
108
+ }, [_createVNode("div", null, [t(props.pageText, !itemsLength.value ? 0 : startIndex.value + 1, stopIndex.value, itemsLength.value)])]), _createVNode("div", {
109
+ "class": "v-data-table-footer__pagination"
110
+ }, [_createVNode(VBtn, {
111
+ "icon": props.firstIcon,
112
+ "variant": "plain",
113
+ "onClick": () => page.value = 1,
114
+ "disabled": page.value === 1,
115
+ "aria-label": t(props.firstPageLabel)
116
+ }, null), _createVNode(VBtn, {
117
+ "icon": props.prevIcon,
118
+ "variant": "plain",
119
+ "onClick": () => page.value = Math.max(1, page.value - 1),
120
+ "disabled": page.value === 1,
121
+ "aria-label": t(props.prevPageLabel)
122
+ }, null), props.showCurrentPage && _createVNode("span", {
123
+ "key": "page",
124
+ "class": "v-data-table-footer__page"
125
+ }, [page.value]), _createVNode(VBtn, {
126
+ "icon": props.nextIcon,
127
+ "variant": "plain",
128
+ "onClick": () => page.value = Math.min(pageCount.value, page.value + 1),
129
+ "disabled": page.value === pageCount.value,
130
+ "aria-label": t(props.nextPageLabel)
131
+ }, null), _createVNode(VBtn, {
132
+ "icon": props.lastIcon,
133
+ "variant": "plain",
134
+ "onClick": () => page.value = pageCount.value,
135
+ "disabled": page.value === pageCount.value,
136
+ "aria-label": t(props.lastPageLabel)
137
+ }, null)])]);
103
138
  }
104
139
  });
105
140
  //# sourceMappingURL=VDataTableFooter.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VDataTableFooter.mjs","names":["VBtn","VSelect","usePagination","defineComponent","VDataTableFooter","name","props","prevIcon","type","String","default","nextIcon","firstIcon","lastIcon","itemsPerPageOptions","Array","value","title","showCurrentPage","Boolean","setup","slots","page","pageCount","startIndex","stopIndex","itemsLength","itemsPerPage","prepend","v","Number","Math","max","min"],"sources":["../../../src/labs/VDataTable/VDataTableFooter.tsx"],"sourcesContent":["// Styles\nimport './VDataTableFooter.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VSelect } from '@/components/VSelect'\n\n// Composables\nimport { usePagination } from './composables/paginate'\n\n// Utilities\nimport { defineComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { InternalItem } from '@/composables/items'\n\nexport const VDataTableFooter = defineComponent({\n name: 'VDataTableFooter',\n\n props: {\n prevIcon: {\n type: String,\n default: '$prev',\n },\n nextIcon: {\n type: String,\n default: '$next',\n },\n firstIcon: {\n type: String,\n default: '$first',\n },\n lastIcon: {\n type: String,\n default: '$last',\n },\n itemsPerPageOptions: {\n type: Array as PropType<InternalItem[]>,\n default: () => ([\n { value: 10, title: '10' },\n { value: 25, title: '25' },\n { value: 50, title: '50' },\n { value: 100, title: '100' },\n { value: -1, title: 'All' },\n ]),\n },\n showCurrentPage: Boolean,\n },\n\n setup (props, { slots }) {\n const { page, pageCount, startIndex, stopIndex, itemsLength, itemsPerPage } = usePagination()\n\n return () => (\n <div\n class=\"v-data-table-footer\"\n >\n { slots.prepend?.() }\n <div class=\"v-data-table-footer__items-per-page\">\n <span>Items per page:</span>\n <VSelect\n items={ props.itemsPerPageOptions }\n modelValue={ itemsPerPage.value }\n onUpdate:modelValue={ v => itemsPerPage.value = Number(v) }\n density=\"compact\"\n variant=\"outlined\"\n hide-details\n />\n </div>\n <div class=\"v-data-table-footer__info\">\n <div>{ !itemsLength.value ? 0 : startIndex.value + 1 } - { stopIndex.value } of { itemsLength.value }</div>\n </div>\n <div class=\"v-data-table-footer__pagination\">\n <VBtn\n icon={ props.firstIcon }\n variant=\"plain\"\n onClick={ () => page.value = 1 }\n disabled={ page.value === 1 }\n />\n <VBtn\n icon={ props.prevIcon }\n variant=\"plain\"\n onClick={ () => page.value = Math.max(1, page.value - 1) }\n disabled={ page.value === 1 }\n />\n { props.showCurrentPage && (\n <div key=\"page\">page.value</div>\n ) }\n <VBtn\n icon={ props.nextIcon }\n variant=\"plain\"\n onClick={ () => page.value = Math.min(pageCount.value, page.value + 1) }\n disabled={ page.value === pageCount.value }\n />\n <VBtn\n icon={ props.lastIcon }\n variant=\"plain\"\n onClick={ () => page.value = pageCount.value }\n disabled={ page.value === pageCount.value }\n />\n </div>\n </div>\n )\n },\n})\n"],"mappings":"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"}
1
+ {"version":3,"file":"VDataTableFooter.mjs","names":["VBtn","VSelect","useLocale","usePagination","computed","genericComponent","VDataTableFooter","name","props","prevIcon","type","String","default","nextIcon","firstIcon","lastIcon","itemsPerPageText","pageText","firstPageLabel","prevPageLabel","nextPageLabel","lastPageLabel","itemsPerPageOptions","Array","value","title","showCurrentPage","Boolean","setup","slots","t","page","pageCount","startIndex","stopIndex","itemsLength","itemsPerPage","map","option","prepend","v","Number","Math","max","min"],"sources":["../../../src/labs/VDataTable/VDataTableFooter.tsx"],"sourcesContent":["// Styles\nimport './VDataTableFooter.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VSelect } from '@/components/VSelect'\n\n// Composables\nimport { useLocale } from '@/composables/locale'\nimport { usePagination } from './composables/paginate'\n\n// Utilities\nimport { computed } from 'vue'\nimport { genericComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { InternalItem } from '@/composables/items'\n\nexport const VDataTableFooter = genericComponent<{ prepend: [] }>()({\n name: 'VDataTableFooter',\n\n props: {\n prevIcon: {\n type: String,\n default: '$prev',\n },\n nextIcon: {\n type: String,\n default: '$next',\n },\n firstIcon: {\n type: String,\n default: '$first',\n },\n lastIcon: {\n type: String,\n default: '$last',\n },\n itemsPerPageText: {\n type: String,\n default: '$vuetify.dataFooter.itemsPerPageText',\n },\n pageText: {\n type: String,\n default: '$vuetify.dataFooter.pageText',\n },\n firstPageLabel: {\n type: String,\n default: '$vuetify.dataFooter.firstPage',\n },\n prevPageLabel: {\n type: String,\n default: '$vuetify.dataFooter.prevPage',\n },\n nextPageLabel: {\n type: String,\n default: '$vuetify.dataFooter.nextPage',\n },\n lastPageLabel: {\n type: String,\n default: '$vuetify.dataFooter.lastPage',\n },\n itemsPerPageOptions: {\n type: Array as PropType<InternalItem[]>,\n default: () => ([\n { value: 10, title: '10' },\n { value: 25, title: '25' },\n { value: 50, title: '50' },\n { value: 100, title: '100' },\n { value: -1, title: '$vuetify.dataFooter.itemsPerPageAll' },\n ]),\n },\n showCurrentPage: Boolean,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const { page, pageCount, startIndex, stopIndex, itemsLength, itemsPerPage } = usePagination()\n\n const itemsPerPageOptions = computed(() => (\n props.itemsPerPageOptions.map(option => ({\n ...option,\n title: t(option.title),\n }))\n ))\n\n return () => (\n <div\n class=\"v-data-table-footer\"\n >\n { slots.prepend?.() }\n <div class=\"v-data-table-footer__items-per-page\">\n <span>{ t(props.itemsPerPageText) }</span>\n <VSelect\n items={ itemsPerPageOptions.value }\n modelValue={ itemsPerPage.value }\n onUpdate:modelValue={ v => itemsPerPage.value = Number(v) }\n density=\"compact\"\n variant=\"outlined\"\n hide-details\n />\n </div>\n <div class=\"v-data-table-footer__info\">\n <div>\n { t(props.pageText, !itemsLength.value ? 0 : startIndex.value + 1, stopIndex.value, itemsLength.value) }\n </div>\n </div>\n <div class=\"v-data-table-footer__pagination\">\n <VBtn\n icon={ props.firstIcon }\n variant=\"plain\"\n onClick={ () => page.value = 1 }\n disabled={ page.value === 1 }\n aria-label={ t(props.firstPageLabel) }\n />\n <VBtn\n icon={ props.prevIcon }\n variant=\"plain\"\n onClick={ () => page.value = Math.max(1, page.value - 1) }\n disabled={ page.value === 1 }\n aria-label={ t(props.prevPageLabel) }\n />\n { props.showCurrentPage && (\n <span key=\"page\" class=\"v-data-table-footer__page\">{ page.value }</span>\n ) }\n <VBtn\n icon={ props.nextIcon }\n variant=\"plain\"\n onClick={ () => page.value = Math.min(pageCount.value, page.value + 1) }\n disabled={ page.value === pageCount.value }\n aria-label={ t(props.nextPageLabel) }\n />\n <VBtn\n icon={ props.lastIcon }\n variant=\"plain\"\n onClick={ () => page.value = pageCount.value }\n disabled={ page.value === pageCount.value }\n aria-label={ t(props.lastPageLabel) }\n />\n </div>\n </div>\n )\n },\n})\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,IAAI;AAAA,SACJC,OAAO,8CAEhB;AAAA,SACSC,SAAS;AAAA,SACTC,aAAa,sCAEtB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,gBAAgB,gCAEzB;AAIA,OAAO,MAAMC,gBAAgB,GAAGD,gBAAgB,EAAmB,CAAC;EAClEE,IAAI,EAAE,kBAAkB;EAExBC,KAAK,EAAE;IACLC,QAAQ,EAAE;MACRC,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDC,QAAQ,EAAE;MACRH,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDE,SAAS,EAAE;MACTJ,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDG,QAAQ,EAAE;MACRL,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDI,gBAAgB,EAAE;MAChBN,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDK,QAAQ,EAAE;MACRP,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDM,cAAc,EAAE;MACdR,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDO,aAAa,EAAE;MACbT,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDQ,aAAa,EAAE;MACbV,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDS,aAAa,EAAE;MACbX,IAAI,EAAEC,MAAM;MACZC,OAAO,EAAE;IACX,CAAC;IACDU,mBAAmB,EAAE;MACnBZ,IAAI,EAAEa,KAAiC;MACvCX,OAAO,EAAE,MAAO,CACd;QAAEY,KAAK,EAAE,EAAE;QAAEC,KAAK,EAAE;MAAK,CAAC,EAC1B;QAAED,KAAK,EAAE,EAAE;QAAEC,KAAK,EAAE;MAAK,CAAC,EAC1B;QAAED,KAAK,EAAE,EAAE;QAAEC,KAAK,EAAE;MAAK,CAAC,EAC1B;QAAED,KAAK,EAAE,GAAG;QAAEC,KAAK,EAAE;MAAM,CAAC,EAC5B;QAAED,KAAK,EAAE,CAAC,CAAC;QAAEC,KAAK,EAAE;MAAsC,CAAC;IAE/D,CAAC;IACDC,eAAe,EAAEC;EACnB,CAAC;EAEDC,KAAK,CAAEpB,KAAK,QAAa;IAAA,IAAX;MAAEqB;IAAM,CAAC;IACrB,MAAM;MAAEC;IAAE,CAAC,GAAG5B,SAAS,EAAE;IACzB,MAAM;MAAE6B,IAAI;MAAEC,SAAS;MAAEC,UAAU;MAAEC,SAAS;MAAEC,WAAW;MAAEC;IAAa,CAAC,GAAGjC,aAAa,EAAE;IAE7F,MAAMmB,mBAAmB,GAAGlB,QAAQ,CAAC,MACnCI,KAAK,CAACc,mBAAmB,CAACe,GAAG,CAACC,MAAM,KAAK;MACvC,GAAGA,MAAM;MACTb,KAAK,EAAEK,CAAC,CAACQ,MAAM,CAACb,KAAK;IACvB,CAAC,CAAC,CACH,CAAC;IAEF,OAAO;MAAA,SAEG;IAAqB,IAEzBI,KAAK,CAACU,OAAO,IAAI;MAAA,SACR;IAAqC,gCACtCT,CAAC,CAACtB,KAAK,CAACQ,gBAAgB,CAAC;MAAA,SAEvBM,mBAAmB,CAACE,KAAK;MAAA,cACpBY,YAAY,CAACZ,KAAK;MAAA,uBACTgB,CAAC,IAAIJ,YAAY,CAACZ,KAAK,GAAGiB,MAAM,CAACD,CAAC,CAAC;MAAA,WACjD,SAAS;MAAA,WACT,UAAU;MAAA;IAAA;MAAA,SAIX;IAA2B,+BAEhCV,CAAC,CAACtB,KAAK,CAACS,QAAQ,EAAE,CAACkB,WAAW,CAACX,KAAK,GAAG,CAAC,GAAGS,UAAU,CAACT,KAAK,GAAG,CAAC,EAAEU,SAAS,CAACV,KAAK,EAAEW,WAAW,CAACX,KAAK,CAAC;MAAA,SAG/F;IAAiC;MAAA,QAEjChB,KAAK,CAACM,SAAS;MAAA,WACd,OAAO;MAAA,WACL,MAAMiB,IAAI,CAACP,KAAK,GAAG,CAAC;MAAA,YACnBO,IAAI,CAACP,KAAK,KAAK,CAAC;MAAA,cACdM,CAAC,CAACtB,KAAK,CAACU,cAAc;IAAC;MAAA,QAG7BV,KAAK,CAACC,QAAQ;MAAA,WACb,OAAO;MAAA,WACL,MAAMsB,IAAI,CAACP,KAAK,GAAGkB,IAAI,CAACC,GAAG,CAAC,CAAC,EAAEZ,IAAI,CAACP,KAAK,GAAG,CAAC,CAAC;MAAA,YAC7CO,IAAI,CAACP,KAAK,KAAK,CAAC;MAAA,cACdM,CAAC,CAACtB,KAAK,CAACW,aAAa;IAAC,UAEnCX,KAAK,CAACkB,eAAe;MAAA,OACX,MAAM;MAAA,SAAO;IAA2B,IAAGK,IAAI,CAACP,KAAK,EAChE;MAAA,QAEQhB,KAAK,CAACK,QAAQ;MAAA,WACb,OAAO;MAAA,WACL,MAAMkB,IAAI,CAACP,KAAK,GAAGkB,IAAI,CAACE,GAAG,CAACZ,SAAS,CAACR,KAAK,EAAEO,IAAI,CAACP,KAAK,GAAG,CAAC,CAAC;MAAA,YAC3DO,IAAI,CAACP,KAAK,KAAKQ,SAAS,CAACR,KAAK;MAAA,cAC5BM,CAAC,CAACtB,KAAK,CAACY,aAAa;IAAC;MAAA,QAG5BZ,KAAK,CAACO,QAAQ;MAAA,WACb,OAAO;MAAA,WACL,MAAMgB,IAAI,CAACP,KAAK,GAAGQ,SAAS,CAACR,KAAK;MAAA,YACjCO,IAAI,CAACP,KAAK,KAAKQ,SAAS,CAACR,KAAK;MAAA,cAC5BM,CAAC,CAACtB,KAAK,CAACa,aAAa;IAAC,YAI1C;EACH;AACF,CAAC,CAAC"}
@@ -21,3 +21,10 @@
21
21
  .v-data-table-footer__info
22
22
  display: flex
23
23
  padding-inline-end: 24px
24
+
25
+ .v-data-table-footer__pagination
26
+ display: flex
27
+ align-items: center
28
+
29
+ .v-data-table-footer__page
30
+ padding: 0 8px
@@ -7,8 +7,8 @@ import { useHeaders } from "./composables/headers.mjs";
7
7
  import { useSelection } from "./composables/select.mjs";
8
8
  import { useGroupBy } from "./composables/group.mjs"; // Utilities
9
9
  import { computed } from 'vue';
10
- import { defineComponent } from "../../util/index.mjs"; // Types
11
- export const VDataTableGroupHeaderRow = defineComponent({
10
+ import { genericComponent } from "../../util/index.mjs"; // Types
11
+ export const VDataTableGroupHeaderRow = genericComponent()({
12
12
  name: 'VDataTableGroupHeaderRow',
13
13
  props: {
14
14
  item: {
@@ -43,17 +43,16 @@ export const VDataTableGroupHeaderRow = defineComponent({
43
43
  }
44
44
  }, [columns.value.map(column => {
45
45
  if (column.key === 'data-table-group') {
46
- var _slots$dataTableGro;
47
46
  const icon = isGroupOpen(props.item) ? '$expand' : '$next';
48
47
  const onClick = () => toggleGroup(props.item);
49
- return ((_slots$dataTableGro = slots['data-table-group']) == null ? void 0 : _slots$dataTableGro.call(slots, {
48
+ return slots['data-table-group']?.({
50
49
  item: props.item,
51
50
  count: rows.value.length,
52
51
  props: {
53
52
  icon,
54
53
  onClick
55
54
  }
56
- })) ?? _createVNode(VDataTableColumn, {
55
+ }) ?? _createVNode(VDataTableColumn, {
57
56
  "class": "v-data-table-group-header-row__column"
58
57
  }, {
59
58
  default: () => [_createVNode(VBtn, {
@@ -65,17 +64,16 @@ export const VDataTableGroupHeaderRow = defineComponent({
65
64
  });
66
65
  }
67
66
  if (column.key === 'data-table-select') {
68
- var _slots$dataTableSel;
69
67
  const modelValue = isSelected(rows.value);
70
68
  const indeterminate = isSomeSelected(rows.value) && !modelValue;
71
69
  const selectGroup = v => select(rows.value, v);
72
- return ((_slots$dataTableSel = slots['data-table-select']) == null ? void 0 : _slots$dataTableSel.call(slots, {
70
+ return slots['data-table-select']?.({
73
71
  props: {
74
72
  modelValue,
75
73
  indeterminate,
76
74
  'onUpdate:modelValue': selectGroup
77
75
  }
78
- })) ?? _createVNode("td", null, [_createVNode(VCheckboxBtn, {
76
+ }) ?? _createVNode("td", null, [_createVNode(VCheckboxBtn, {
79
77
  "modelValue": modelValue,
80
78
  "indeterminate": indeterminate,
81
79
  "onUpdate:modelValue": selectGroup
@@ -1 +1 @@
1
- {"version":3,"file":"VDataTableGroupHeaderRow.mjs","names":["VBtn","VCheckboxBtn","VDataTableColumn","useHeaders","useSelection","useGroupBy","computed","defineComponent","VDataTableGroupHeaderRow","name","props","item","type","Object","required","setup","slots","isGroupOpen","toggleGroup","extractRows","isSelected","isSomeSelected","select","columns","rows","depth","value","map","column","key","icon","onClick","count","length","modelValue","indeterminate","selectGroup","v"],"sources":["../../../src/labs/VDataTable/VDataTableGroupHeaderRow.tsx"],"sourcesContent":["// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VDataTableColumn } from './VDataTableColumn'\n\n// Composables\nimport { useHeaders } from './composables/headers'\nimport { useSelection } from './composables/select'\nimport { useGroupBy } from './composables/group'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { GroupHeaderItem } from './types'\n\nexport const VDataTableGroupHeaderRow = defineComponent({\n name: 'VDataTableGroupHeaderRow',\n\n props: {\n item: {\n type: Object as PropType<GroupHeaderItem>,\n required: true,\n },\n },\n\n setup (props, { slots }) {\n const { isGroupOpen, toggleGroup, extractRows } = useGroupBy()\n const { isSelected, isSomeSelected, select } = useSelection()\n const { columns } = useHeaders()\n\n const rows = computed(() => {\n return extractRows([props.item])\n })\n\n return () => (\n <tr\n class=\"v-data-table-group-header-row\"\n style={{\n '--v-data-table-group-header-row-depth': props.item.depth,\n }}\n >\n { columns.value.map(column => {\n if (column.key === 'data-table-group') {\n const icon = isGroupOpen(props.item) ? '$expand' : '$next'\n const onClick = () => toggleGroup(props.item)\n\n return slots['data-table-group']?.({ item: props.item, count: rows.value.length, props: { icon, onClick } }) ?? (\n <VDataTableColumn class=\"v-data-table-group-header-row__column\">\n <VBtn\n size=\"small\"\n variant=\"text\"\n icon={ icon }\n onClick={ onClick }\n />\n <span>{ props.item.value }</span>\n <span>({ rows.value.length })</span>\n </VDataTableColumn>\n )\n }\n\n if (column.key === 'data-table-select') {\n const modelValue = isSelected(rows.value)\n const indeterminate = isSomeSelected(rows.value) && !modelValue\n const selectGroup = (v: boolean) => select(rows.value, v)\n return slots['data-table-select']?.({ props: { modelValue, indeterminate, 'onUpdate:modelValue': selectGroup } }) ?? (\n <td>\n <VCheckboxBtn\n modelValue={ modelValue }\n indeterminate={ indeterminate }\n onUpdate:modelValue={ selectGroup }\n />\n </td>\n )\n }\n\n return <td />\n })}\n </tr>\n )\n },\n})\n"],"mappings":";AAAA;AAAA,SACSA,IAAI;AAAA,SACJC,YAAY;AAAA,SACZC,gBAAgB,kCAEzB;AAAA,SACSC,UAAU;AAAA,SACVC,YAAY;AAAA,SACZC,UAAU,mCAEnB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,eAAe,gCAExB;AAIA,OAAO,MAAMC,wBAAwB,GAAGD,eAAe,CAAC;EACtDE,IAAI,EAAE,0BAA0B;EAEhCC,KAAK,EAAE;IACLC,IAAI,EAAE;MACJC,IAAI,EAAEC,MAAmC;MACzCC,QAAQ,EAAE;IACZ;EACF,CAAC;EAEDC,KAAK,CAAEL,KAAK,QAAa;IAAA,IAAX;MAAEM;IAAM,CAAC;IACrB,MAAM;MAAEC,WAAW;MAAEC,WAAW;MAAEC;IAAY,CAAC,GAAGd,UAAU,EAAE;IAC9D,MAAM;MAAEe,UAAU;MAAEC,cAAc;MAAEC;IAAO,CAAC,GAAGlB,YAAY,EAAE;IAC7D,MAAM;MAAEmB;IAAQ,CAAC,GAAGpB,UAAU,EAAE;IAEhC,MAAMqB,IAAI,GAAGlB,QAAQ,CAAC,MAAM;MAC1B,OAAOa,WAAW,CAAC,CAACT,KAAK,CAACC,IAAI,CAAC,CAAC;IAClC,CAAC,CAAC;IAEF,OAAO;MAAA,SAEG,+BAA+B;MAAA,SAC9B;QACL,uCAAuC,EAAED,KAAK,CAACC,IAAI,CAACc;MACtD;IAAC,IAECF,OAAO,CAACG,KAAK,CAACC,GAAG,CAACC,MAAM,IAAI;MAC5B,IAAIA,MAAM,CAACC,GAAG,KAAK,kBAAkB,EAAE;QAAA;QACrC,MAAMC,IAAI,GAAGb,WAAW,CAACP,KAAK,CAACC,IAAI,CAAC,GAAG,SAAS,GAAG,OAAO;QAC1D,MAAMoB,OAAO,GAAG,MAAMb,WAAW,CAACR,KAAK,CAACC,IAAI,CAAC;QAE7C,OAAO,wBAAAK,KAAK,CAAC,kBAAkB,CAAC,qBAAzB,yBAAAA,KAAK,EAAuB;UAAEL,IAAI,EAAED,KAAK,CAACC,IAAI;UAAEqB,KAAK,EAAER,IAAI,CAACE,KAAK,CAACO,MAAM;UAAEvB,KAAK,EAAE;YAAEoB,IAAI;YAAEC;UAAQ;QAAE,CAAC,CAAC;UAAA,SAClF;QAAuC;UAAA;YAAA,QAEtD,OAAO;YAAA,WACJ,MAAM;YAAA,QACPD,IAAI;YAAA,WACDC;UAAO,sCAEXrB,KAAK,CAACC,IAAI,CAACe,KAAK,uDACfF,IAAI,CAACE,KAAK,CAACO,MAAM;QAAA,EAE7B;MACH;MAEA,IAAIL,MAAM,CAACC,GAAG,KAAK,mBAAmB,EAAE;QAAA;QACtC,MAAMK,UAAU,GAAGd,UAAU,CAACI,IAAI,CAACE,KAAK,CAAC;QACzC,MAAMS,aAAa,GAAGd,cAAc,CAACG,IAAI,CAACE,KAAK,CAAC,IAAI,CAACQ,UAAU;QAC/D,MAAME,WAAW,GAAIC,CAAU,IAAKf,MAAM,CAACE,IAAI,CAACE,KAAK,EAAEW,CAAC,CAAC;QACzD,OAAO,wBAAArB,KAAK,CAAC,mBAAmB,CAAC,qBAA1B,yBAAAA,KAAK,EAAwB;UAAEN,KAAK,EAAE;YAAEwB,UAAU;YAAEC,aAAa;YAAE,qBAAqB,EAAEC;UAAY;QAAE,CAAC,CAAC;UAAA,cAG9FF,UAAU;UAAA,iBACPC,aAAa;UAAA,uBACPC;QAAW,UAGtC;MACH;MAEA;IACF,CAAC,CAAC,EAEL;EACH;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"VDataTableGroupHeaderRow.mjs","names":["VBtn","VCheckboxBtn","VDataTableColumn","useHeaders","useSelection","useGroupBy","computed","genericComponent","VDataTableGroupHeaderRow","name","props","item","type","Object","required","setup","slots","isGroupOpen","toggleGroup","extractRows","isSelected","isSomeSelected","select","columns","rows","depth","value","map","column","key","icon","onClick","count","length","modelValue","indeterminate","selectGroup","v"],"sources":["../../../src/labs/VDataTable/VDataTableGroupHeaderRow.tsx"],"sourcesContent":["// Components\nimport { VBtn } from '@/components/VBtn'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VDataTableColumn } from './VDataTableColumn'\n\n// Composables\nimport { useHeaders } from './composables/headers'\nimport { useSelection } from './composables/select'\nimport { useGroupBy } from './composables/group'\n\n// Utilities\nimport { computed } from 'vue'\nimport { genericComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { GroupHeaderItem } from './types'\n\ntype VDataTableGroupHeaderRowSlots = {\n 'data-table-group': [{ item: GroupHeaderItem, count: number, props: Record<string, unknown> }]\n 'data-table-select': [{ props: Record<string, unknown> }]\n}\n\nexport const VDataTableGroupHeaderRow = genericComponent<VDataTableGroupHeaderRowSlots>()({\n name: 'VDataTableGroupHeaderRow',\n\n props: {\n item: {\n type: Object as PropType<GroupHeaderItem>,\n required: true,\n },\n },\n\n setup (props, { slots }) {\n const { isGroupOpen, toggleGroup, extractRows } = useGroupBy()\n const { isSelected, isSomeSelected, select } = useSelection()\n const { columns } = useHeaders()\n\n const rows = computed(() => {\n return extractRows([props.item])\n })\n\n return () => (\n <tr\n class=\"v-data-table-group-header-row\"\n style={{\n '--v-data-table-group-header-row-depth': props.item.depth,\n }}\n >\n { columns.value.map(column => {\n if (column.key === 'data-table-group') {\n const icon = isGroupOpen(props.item) ? '$expand' : '$next'\n const onClick = () => toggleGroup(props.item)\n\n return slots['data-table-group']?.({ item: props.item, count: rows.value.length, props: { icon, onClick } }) ?? (\n <VDataTableColumn class=\"v-data-table-group-header-row__column\">\n <VBtn\n size=\"small\"\n variant=\"text\"\n icon={ icon }\n onClick={ onClick }\n />\n <span>{ props.item.value }</span>\n <span>({ rows.value.length })</span>\n </VDataTableColumn>\n )\n }\n\n if (column.key === 'data-table-select') {\n const modelValue = isSelected(rows.value)\n const indeterminate = isSomeSelected(rows.value) && !modelValue\n const selectGroup = (v: boolean) => select(rows.value, v)\n return slots['data-table-select']?.({ props: { modelValue, indeterminate, 'onUpdate:modelValue': selectGroup } }) ?? (\n <td>\n <VCheckboxBtn\n modelValue={ modelValue }\n indeterminate={ indeterminate }\n onUpdate:modelValue={ selectGroup }\n />\n </td>\n )\n }\n\n return <td />\n })}\n </tr>\n )\n },\n})\n"],"mappings":";AAAA;AAAA,SACSA,IAAI;AAAA,SACJC,YAAY;AAAA,SACZC,gBAAgB,kCAEzB;AAAA,SACSC,UAAU;AAAA,SACVC,YAAY;AAAA,SACZC,UAAU,mCAEnB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,gBAAgB,gCAEzB;AASA,OAAO,MAAMC,wBAAwB,GAAGD,gBAAgB,EAAiC,CAAC;EACxFE,IAAI,EAAE,0BAA0B;EAEhCC,KAAK,EAAE;IACLC,IAAI,EAAE;MACJC,IAAI,EAAEC,MAAmC;MACzCC,QAAQ,EAAE;IACZ;EACF,CAAC;EAEDC,KAAK,CAAEL,KAAK,QAAa;IAAA,IAAX;MAAEM;IAAM,CAAC;IACrB,MAAM;MAAEC,WAAW;MAAEC,WAAW;MAAEC;IAAY,CAAC,GAAGd,UAAU,EAAE;IAC9D,MAAM;MAAEe,UAAU;MAAEC,cAAc;MAAEC;IAAO,CAAC,GAAGlB,YAAY,EAAE;IAC7D,MAAM;MAAEmB;IAAQ,CAAC,GAAGpB,UAAU,EAAE;IAEhC,MAAMqB,IAAI,GAAGlB,QAAQ,CAAC,MAAM;MAC1B,OAAOa,WAAW,CAAC,CAACT,KAAK,CAACC,IAAI,CAAC,CAAC;IAClC,CAAC,CAAC;IAEF,OAAO;MAAA,SAEG,+BAA+B;MAAA,SAC9B;QACL,uCAAuC,EAAED,KAAK,CAACC,IAAI,CAACc;MACtD;IAAC,IAECF,OAAO,CAACG,KAAK,CAACC,GAAG,CAACC,MAAM,IAAI;MAC5B,IAAIA,MAAM,CAACC,GAAG,KAAK,kBAAkB,EAAE;QACrC,MAAMC,IAAI,GAAGb,WAAW,CAACP,KAAK,CAACC,IAAI,CAAC,GAAG,SAAS,GAAG,OAAO;QAC1D,MAAMoB,OAAO,GAAG,MAAMb,WAAW,CAACR,KAAK,CAACC,IAAI,CAAC;QAE7C,OAAOK,KAAK,CAAC,kBAAkB,CAAC,GAAG;UAAEL,IAAI,EAAED,KAAK,CAACC,IAAI;UAAEqB,KAAK,EAAER,IAAI,CAACE,KAAK,CAACO,MAAM;UAAEvB,KAAK,EAAE;YAAEoB,IAAI;YAAEC;UAAQ;QAAE,CAAC,CAAC;UAAA,SAClF;QAAuC;UAAA;YAAA,QAEtD,OAAO;YAAA,WACJ,MAAM;YAAA,QACPD,IAAI;YAAA,WACDC;UAAO,sCAEXrB,KAAK,CAACC,IAAI,CAACe,KAAK,uDACfF,IAAI,CAACE,KAAK,CAACO,MAAM;QAAA,EAE7B;MACH;MAEA,IAAIL,MAAM,CAACC,GAAG,KAAK,mBAAmB,EAAE;QACtC,MAAMK,UAAU,GAAGd,UAAU,CAACI,IAAI,CAACE,KAAK,CAAC;QACzC,MAAMS,aAAa,GAAGd,cAAc,CAACG,IAAI,CAACE,KAAK,CAAC,IAAI,CAACQ,UAAU;QAC/D,MAAME,WAAW,GAAIC,CAAU,IAAKf,MAAM,CAACE,IAAI,CAACE,KAAK,EAAEW,CAAC,CAAC;QACzD,OAAOrB,KAAK,CAAC,mBAAmB,CAAC,GAAG;UAAEN,KAAK,EAAE;YAAEwB,UAAU;YAAEC,aAAa;YAAE,qBAAqB,EAAEC;UAAY;QAAE,CAAC,CAAC;UAAA,cAG9FF,UAAU;UAAA,iBACPC,aAAa;UAAA,uBACPC;QAAW,UAGtC;MACH;MAEA;IACF,CAAC,CAAC,EAEL;EACH;AACF,CAAC,CAAC"}
@@ -9,8 +9,8 @@ import { useBackgroundColor } from "../../composables/color.mjs";
9
9
  import { useHeaders } from "./composables/headers.mjs";
10
10
  import { useSelection } from "./composables/select.mjs";
11
11
  import { useSort } from "./composables/sort.mjs"; // Utilities
12
- import { convertToUnit, defineComponent, useRender } from "../../util/index.mjs"; // Types
13
- export const VDataTableHeaders = defineComponent({
12
+ import { convertToUnit, genericComponent, useRender } from "../../util/index.mjs"; // Types
13
+ export const VDataTableHeaders = genericComponent()({
14
14
  name: 'VDataTableHeaders',
15
15
  props: {
16
16
  color: String,
@@ -101,8 +101,7 @@ export const VDataTableHeaders = defineComponent({
101
101
  };
102
102
  if (slots[slotName]) return slots[slotName](slotProps);
103
103
  if (column.key === 'data-table-select') {
104
- var _slots$columnDataTa;
105
- return ((_slots$columnDataTa = slots['column.data-table-select']) == null ? void 0 : _slots$columnDataTa.call(slots, slotProps)) ?? _createVNode(VCheckboxBtn, {
104
+ return slots['column.data-table-select']?.(slotProps) ?? _createVNode(VCheckboxBtn, {
106
105
  "modelValue": allSelected.value,
107
106
  "indeterminate": someSelected.value && !allSelected.value,
108
107
  "onUpdate:modelValue": selectAll