vuetify 3.1.3 → 3.1.5

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 (520) hide show
  1. package/LICENSE.md +1 -1
  2. package/dist/json/attributes.json +3104 -3068
  3. package/dist/json/importMap-labs.json +4 -0
  4. package/dist/json/importMap.json +38 -38
  5. package/dist/json/tags.json +18 -4
  6. package/dist/json/web-types.json +9059 -6289
  7. package/dist/vuetify-labs.css +374 -3262
  8. package/dist/vuetify-labs.d.ts +14446 -22245
  9. package/dist/vuetify-labs.esm.js +1661 -1922
  10. package/dist/vuetify-labs.esm.js.map +1 -1
  11. package/dist/vuetify-labs.js +1660 -1921
  12. package/dist/vuetify-labs.min.css +2 -2
  13. package/dist/vuetify.css +162 -3058
  14. package/dist/vuetify.d.ts +13666 -21503
  15. package/dist/vuetify.esm.js +1435 -1706
  16. package/dist/vuetify.esm.js.map +1 -1
  17. package/dist/vuetify.js +1434 -1705
  18. package/dist/vuetify.js.map +1 -1
  19. package/dist/vuetify.min.css +2 -2
  20. package/dist/vuetify.min.js +1084 -1305
  21. package/dist/vuetify.min.js.map +1 -1
  22. package/lib/blueprints/index.d.ts +9 -9
  23. package/lib/blueprints/md1.d.ts +9 -9
  24. package/lib/blueprints/md2.d.ts +9 -9
  25. package/lib/blueprints/md3.d.ts +9 -9
  26. package/lib/blueprints/md3.mjs.map +1 -1
  27. package/lib/components/VAlert/VAlert.mjs +5 -6
  28. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  29. package/lib/components/VAlert/index.d.ts +135 -157
  30. package/lib/components/VApp/VApp.mjs +9 -12
  31. package/lib/components/VApp/VApp.mjs.map +1 -1
  32. package/lib/components/VApp/index.d.ts +27 -13
  33. package/lib/components/VAppBar/VAppBar.mjs +9 -5
  34. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  35. package/lib/components/VAppBar/VAppBarNavIcon.mjs +2 -2
  36. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  37. package/lib/components/VAppBar/VAppBarTitle.mjs +5 -6
  38. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  39. package/lib/components/VAppBar/index.d.ts +173 -342
  40. package/lib/components/VAutocomplete/VAutocomplete.mjs +100 -104
  41. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  42. package/lib/components/VAutocomplete/index.d.ts +494 -636
  43. package/lib/components/VAvatar/VAvatar.mjs +19 -22
  44. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  45. package/lib/components/VAvatar/index.d.ts +46 -66
  46. package/lib/components/VBadge/VBadge.mjs +7 -5
  47. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  48. package/lib/components/VBadge/index.d.ts +74 -100
  49. package/lib/components/VBanner/VBanner.mjs +3 -4
  50. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  51. package/lib/components/VBanner/VBannerActions.mjs +5 -8
  52. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  53. package/lib/components/VBanner/index.d.ts +134 -98
  54. package/lib/components/VBottomNavigation/VBottomNavigation.css +2 -1
  55. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +8 -4
  56. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  57. package/lib/components/VBottomNavigation/VBottomNavigation.sass +2 -1
  58. package/lib/components/VBottomNavigation/_variables.scss +1 -1
  59. package/lib/components/VBottomNavigation/index.d.ts +67 -131
  60. package/lib/components/VBottomSheet/VBottomSheet.mjs +1 -4
  61. package/lib/components/VBottomSheet/VBottomSheet.mjs.map +1 -1
  62. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +9 -16
  63. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  64. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +5 -8
  65. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  66. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +4 -8
  67. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  68. package/lib/components/VBreadcrumbs/index.d.ts +87 -61
  69. package/lib/components/VBtn/VBtn.css +7 -7
  70. package/lib/components/VBtn/VBtn.mjs +14 -17
  71. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  72. package/lib/components/VBtn/index.d.ts +118 -179
  73. package/lib/components/VBtnGroup/VBtnGroup.mjs +19 -12
  74. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  75. package/lib/components/VBtnGroup/index.d.ts +42 -56
  76. package/lib/components/VBtnToggle/VBtnToggle.mjs +10 -7
  77. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  78. package/lib/components/VBtnToggle/index.d.ts +65 -131
  79. package/lib/components/VCalendar/VCalendar.mjs +3 -0
  80. package/lib/components/VCalendar/VCalendar.mjs.map +1 -1
  81. package/lib/components/VCalendar/VCalendarCategory.sass +9 -3
  82. package/lib/components/VCalendar/VCalendarDaily.mjs +20 -8
  83. package/lib/components/VCalendar/VCalendarDaily.mjs.map +1 -1
  84. package/lib/components/VCalendar/VCalendarWeekly.mjs +25 -5
  85. package/lib/components/VCalendar/VCalendarWeekly.mjs.map +1 -1
  86. package/lib/components/VCalendar/mixins/calendar-with-events.mjs +20 -16
  87. package/lib/components/VCalendar/mixins/calendar-with-events.mjs.map +1 -1
  88. package/lib/components/VCalendar/mixins/mouse.mjs +15 -30
  89. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  90. package/lib/components/VCard/VCard.css +7 -7
  91. package/lib/components/VCard/VCard.mjs +5 -6
  92. package/lib/components/VCard/VCard.mjs.map +1 -1
  93. package/lib/components/VCard/VCardActions.mjs +5 -8
  94. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  95. package/lib/components/VCard/VCardItem.mjs +7 -8
  96. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  97. package/lib/components/VCard/index.d.ts +286 -186
  98. package/lib/components/VCarousel/VCarousel.mjs +2 -2
  99. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  100. package/lib/components/VCarousel/VCarouselItem.mjs +2 -2
  101. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  102. package/lib/components/VCarousel/index.d.ts +238 -61
  103. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  104. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  105. package/lib/components/VCheckbox/VCheckboxBtn.mjs +2 -2
  106. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  107. package/lib/components/VCheckbox/index.d.ts +277 -254
  108. package/lib/components/VChip/VChip.css +7 -7
  109. package/lib/components/VChip/VChip.mjs +21 -15
  110. package/lib/components/VChip/VChip.mjs.map +1 -1
  111. package/lib/components/VChip/index.d.ts +118 -168
  112. package/lib/components/VChipGroup/VChipGroup.css +1 -0
  113. package/lib/components/VChipGroup/VChipGroup.mjs +15 -18
  114. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  115. package/lib/components/VChipGroup/VChipGroup.sass +1 -0
  116. package/lib/components/VChipGroup/index.d.ts +49 -68
  117. package/lib/components/VCode/index.d.ts +21 -9
  118. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +4 -9
  119. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  120. package/lib/components/VColorPicker/VColorPickerEdit.mjs +12 -16
  121. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  122. package/lib/components/VColorPicker/VColorPickerPreview.mjs +43 -46
  123. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  124. package/lib/components/VColorPicker/index.d.ts +1 -1
  125. package/lib/components/VColorPicker/util/index.mjs +1 -2
  126. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  127. package/lib/components/VCombobox/VCombobox.mjs +104 -113
  128. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  129. package/lib/components/VCombobox/index.d.ts +496 -638
  130. package/lib/components/VCounter/VCounter.mjs +2 -2
  131. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  132. package/lib/components/VCounter/index.d.ts +139 -197
  133. package/lib/components/VData/VData.mjs +2 -4
  134. package/lib/components/VData/VData.mjs.map +1 -1
  135. package/lib/components/VDatePicker/VDatePicker.mjs +7 -5
  136. package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
  137. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -9
  138. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  139. package/lib/components/VDefaultsProvider/index.d.ts +33 -14
  140. package/lib/components/VDialog/VDialog.mjs +6 -9
  141. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  142. package/lib/components/VDialog/index.d.ts +430 -1610
  143. package/lib/components/VDivider/VDivider.mjs +2 -2
  144. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  145. package/lib/components/VDivider/index.d.ts +35 -15
  146. package/lib/components/VExpansionPanel/VExpansionPanel.css +7 -7
  147. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +4 -5
  148. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  149. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +11 -14
  150. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  151. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +19 -22
  152. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  153. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +2 -2
  154. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  155. package/lib/components/VExpansionPanel/index.d.ts +180 -158
  156. package/lib/components/VField/VField.css +2 -2
  157. package/lib/components/VField/VField.mjs +3 -6
  158. package/lib/components/VField/VField.mjs.map +1 -1
  159. package/lib/components/VField/VField.sass +2 -2
  160. package/lib/components/VField/VFieldLabel.mjs +2 -2
  161. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  162. package/lib/components/VField/index.d.ts +46 -34
  163. package/lib/components/VFileInput/VFileInput.mjs +16 -18
  164. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  165. package/lib/components/VFileInput/index.d.ts +330 -355
  166. package/lib/components/VFooter/VFooter.mjs +2 -2
  167. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  168. package/lib/components/VFooter/index.d.ts +45 -65
  169. package/lib/components/VForm/VForm.mjs +10 -14
  170. package/lib/components/VForm/VForm.mjs.map +1 -1
  171. package/lib/components/VForm/index.d.ts +29 -23
  172. package/lib/components/VGrid/VCol.mjs +5 -8
  173. package/lib/components/VGrid/VCol.mjs.map +1 -1
  174. package/lib/components/VGrid/VContainer.mjs +2 -2
  175. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  176. package/lib/components/VGrid/VGrid.css +0 -125
  177. package/lib/components/VGrid/VRow.mjs +5 -8
  178. package/lib/components/VGrid/VRow.mjs.map +1 -1
  179. package/lib/components/VGrid/index.d.ts +112 -121
  180. package/lib/components/VHover/VHover.mjs +9 -12
  181. package/lib/components/VHover/VHover.mjs.map +1 -1
  182. package/lib/components/VHover/index.d.ts +53 -15
  183. package/lib/components/VIcon/VIcon.mjs +22 -26
  184. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  185. package/lib/components/VIcon/index.d.ts +68 -56
  186. package/lib/components/VImg/VImg.mjs +7 -11
  187. package/lib/components/VImg/VImg.mjs.map +1 -1
  188. package/lib/components/VImg/index.d.ts +67 -58
  189. package/lib/components/VInput/VInput.mjs +5 -6
  190. package/lib/components/VInput/VInput.mjs.map +1 -1
  191. package/lib/components/VInput/index.d.ts +94 -283
  192. package/lib/components/VItemGroup/VItem.mjs +8 -11
  193. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  194. package/lib/components/VItemGroup/VItemGroup.mjs +13 -16
  195. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  196. package/lib/components/VItemGroup/index.d.ts +76 -149
  197. package/lib/components/VKbd/index.d.ts +21 -9
  198. package/lib/components/VLabel/VLabel.mjs +7 -10
  199. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  200. package/lib/components/VLabel/index.d.ts +29 -9
  201. package/lib/components/VLayout/VLayout.mjs +9 -12
  202. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  203. package/lib/components/VLayout/VLayoutItem.mjs +6 -9
  204. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  205. package/lib/components/VLayout/index.d.ts +60 -43
  206. package/lib/components/VLazy/VLazy.mjs +12 -15
  207. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  208. package/lib/components/VLazy/index.d.ts +48 -71
  209. package/lib/components/VList/VList.mjs +4 -8
  210. package/lib/components/VList/VList.mjs.map +1 -1
  211. package/lib/components/VList/VListChildren.mjs +59 -77
  212. package/lib/components/VList/VListChildren.mjs.map +1 -1
  213. package/lib/components/VList/VListGroup.mjs +33 -39
  214. package/lib/components/VList/VListGroup.mjs.map +1 -1
  215. package/lib/components/VList/VListItem.css +9 -9
  216. package/lib/components/VList/VListItem.mjs +10 -18
  217. package/lib/components/VList/VListItem.mjs.map +1 -1
  218. package/lib/components/VList/VListItem.sass +0 -2
  219. package/lib/components/VList/VListItemAction.mjs +2 -2
  220. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  221. package/lib/components/VList/VListItemMedia.mjs +2 -2
  222. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  223. package/lib/components/VList/VListSubheader.mjs +3 -4
  224. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  225. package/lib/components/VList/index.d.ts +418 -686
  226. package/lib/components/VList/list.mjs +1 -1
  227. package/lib/components/VList/list.mjs.map +1 -1
  228. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -8
  229. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  230. package/lib/components/VLocaleProvider/index.d.ts +28 -16
  231. package/lib/components/VMain/VMain.mjs +12 -15
  232. package/lib/components/VMain/VMain.mjs.map +1 -1
  233. package/lib/components/VMain/index.d.ts +23 -17
  234. package/lib/components/VMenu/VMenu.mjs +10 -10
  235. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  236. package/lib/components/VMenu/index.d.ts +428 -1641
  237. package/lib/components/VMessages/VMessages.mjs +2 -2
  238. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  239. package/lib/components/VMessages/index.d.ts +144 -204
  240. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +6 -7
  241. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  242. package/lib/components/VNavigationDrawer/index.d.ts +92 -124
  243. package/lib/components/VNoSsr/VNoSsr.mjs +1 -4
  244. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  245. package/lib/components/VNoSsr/index.d.ts +20 -4
  246. package/lib/components/VOtpInput/VOtpInput.mjs +25 -50
  247. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -1
  248. package/lib/components/VOverflowBtn/VOverflowBtn.mjs +3 -0
  249. package/lib/components/VOverflowBtn/VOverflowBtn.mjs.map +1 -1
  250. package/lib/components/VOverlay/VOverlay.mjs +44 -47
  251. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  252. package/lib/components/VOverlay/index.d.ts +150 -468
  253. package/lib/components/VOverlay/locationStrategies.mjs +3 -6
  254. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  255. package/lib/components/VOverlay/scrollStrategies.mjs +7 -12
  256. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  257. package/lib/components/VOverlay/useActivator.mjs +4 -7
  258. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  259. package/lib/components/VPagination/VPagination.mjs +4 -5
  260. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  261. package/lib/components/VPagination/index.d.ts +107 -207
  262. package/lib/components/VParallax/VParallax.mjs +12 -15
  263. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  264. package/lib/components/VParallax/index.d.ts +39 -9
  265. package/lib/components/VProgressCircular/VProgressCircular.mjs +2 -2
  266. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  267. package/lib/components/VProgressCircular/index.d.ts +41 -58
  268. package/lib/components/VProgressLinear/VProgressLinear.mjs +2 -2
  269. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  270. package/lib/components/VProgressLinear/index.d.ts +91 -95
  271. package/lib/components/VRadio/VRadio.mjs +2 -2
  272. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  273. package/lib/components/VRadio/index.d.ts +108 -85
  274. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -2
  275. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  276. package/lib/components/VRadioGroup/index.d.ts +164 -147
  277. package/lib/components/VRangeSlider/VRangeSlider.mjs +21 -31
  278. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  279. package/lib/components/VRangeSlider/index.d.ts +154 -210
  280. package/lib/components/VRating/VRating.mjs +28 -34
  281. package/lib/components/VRating/VRating.mjs.map +1 -1
  282. package/lib/components/VRating/index.d.ts +77 -311
  283. package/lib/components/VResponsive/VResponsive.mjs +11 -14
  284. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  285. package/lib/components/VResponsive/index.d.ts +44 -20
  286. package/lib/components/VSelect/VSelect.mjs +100 -102
  287. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  288. package/lib/components/VSelect/index.d.ts +729 -673
  289. package/lib/components/VSelectionControl/VSelectionControl.css +2 -2
  290. package/lib/components/VSelectionControl/VSelectionControl.mjs +3 -4
  291. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  292. package/lib/components/VSelectionControl/index.d.ts +31 -19
  293. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +8 -11
  294. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  295. package/lib/components/VSelectionControlGroup/index.d.ts +58 -70
  296. package/lib/components/VSheet/VSheet.mjs +2 -2
  297. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  298. package/lib/components/VSheet/index.d.ts +52 -56
  299. package/lib/components/VSkeletonLoader/VSkeletonLoader.sass +1 -1
  300. package/lib/components/VSlideGroup/VSlideGroup.mjs +51 -60
  301. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  302. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +6 -9
  303. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  304. package/lib/components/VSlideGroup/index.d.ts +144 -366
  305. package/lib/components/VSlider/VSlider.mjs +8 -14
  306. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  307. package/lib/components/VSlider/VSliderThumb.css +0 -1
  308. package/lib/components/VSlider/VSliderThumb.mjs +4 -5
  309. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  310. package/lib/components/VSlider/VSliderTrack.mjs +4 -5
  311. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  312. package/lib/components/VSlider/index.d.ts +151 -207
  313. package/lib/components/VSlider/slider.mjs +3 -6
  314. package/lib/components/VSlider/slider.mjs.map +1 -1
  315. package/lib/components/VSnackbar/VSnackbar.mjs +1 -1
  316. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  317. package/lib/components/VSnackbar/index.d.ts +358 -1519
  318. package/lib/components/VStepper/VStepper.sass +6 -6
  319. package/lib/components/VStepper/VStepperStep.mjs +12 -2
  320. package/lib/components/VStepper/VStepperStep.mjs.map +1 -1
  321. package/lib/components/VSwitch/VSwitch.mjs +3 -4
  322. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  323. package/lib/components/VSwitch/index.d.ts +180 -151
  324. package/lib/components/VSystemBar/VSystemBar.mjs +8 -4
  325. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  326. package/lib/components/VSystemBar/index.d.ts +43 -51
  327. package/lib/components/VTable/VTable.mjs +19 -22
  328. package/lib/components/VTable/VTable.mjs.map +1 -1
  329. package/lib/components/VTable/index.d.ts +54 -30
  330. package/lib/components/VTabs/VTab.mjs +3 -4
  331. package/lib/components/VTabs/VTab.mjs.map +1 -1
  332. package/lib/components/VTabs/VTabs.mjs +2 -2
  333. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  334. package/lib/components/VTabs/index.d.ts +122 -150
  335. package/lib/components/VTextField/VTextField.mjs +16 -19
  336. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  337. package/lib/components/VTextField/index.d.ts +331 -1489
  338. package/lib/components/VTextarea/VTextarea.mjs +17 -19
  339. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  340. package/lib/components/VTextarea/index.d.ts +320 -334
  341. package/lib/components/VThemeProvider/VThemeProvider.mjs +4 -5
  342. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  343. package/lib/components/VThemeProvider/index.d.ts +27 -13
  344. package/lib/components/VTimePicker/VTimePicker.mjs.map +1 -1
  345. package/lib/components/VTimeline/VTimeline.mjs +2 -2
  346. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  347. package/lib/components/VTimeline/VTimelineDivider.mjs +20 -23
  348. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  349. package/lib/components/VTimeline/VTimelineItem.mjs +33 -34
  350. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  351. package/lib/components/VTimeline/_mixins.sass +1 -1
  352. package/lib/components/VTimeline/index.d.ts +123 -135
  353. package/lib/components/VToolbar/VToolbar.css +1 -0
  354. package/lib/components/VToolbar/VToolbar.mjs +7 -9
  355. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  356. package/lib/components/VToolbar/VToolbar.sass +1 -0
  357. package/lib/components/VToolbar/VToolbarItems.mjs +5 -8
  358. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  359. package/lib/components/VToolbar/VToolbarTitle.mjs +7 -7
  360. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  361. package/lib/components/VToolbar/index.d.ts +146 -351
  362. package/lib/components/VTooltip/VTooltip.mjs +1 -2
  363. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  364. package/lib/components/VTooltip/index.d.ts +361 -1619
  365. package/lib/components/VTreeview/VTreeview.mjs +1 -1
  366. package/lib/components/VTreeview/VTreeview.mjs.map +1 -1
  367. package/lib/components/VValidation/VValidation.mjs +3 -6
  368. package/lib/components/VValidation/VValidation.mjs.map +1 -1
  369. package/lib/components/VValidation/index.d.ts +48 -46
  370. package/lib/components/VWindow/VWindow.mjs +19 -22
  371. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  372. package/lib/components/VWindow/VWindowItem.mjs +10 -14
  373. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  374. package/lib/components/VWindow/index.d.ts +152 -284
  375. package/lib/components/index.d.ts +13667 -21504
  376. package/lib/components/transitions/createTransition.mjs +4 -4
  377. package/lib/components/transitions/createTransition.mjs.map +1 -1
  378. package/lib/components/transitions/dialog-transition.mjs +8 -8
  379. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  380. package/lib/components/transitions/index.d.ts +477 -342
  381. package/lib/composables/defaults.mjs +6 -4
  382. package/lib/composables/defaults.mjs.map +1 -1
  383. package/lib/composables/delay.mjs +1 -1
  384. package/lib/composables/delay.mjs.map +1 -1
  385. package/lib/composables/filter.mjs +11 -12
  386. package/lib/composables/filter.mjs.map +1 -1
  387. package/lib/composables/group.mjs +2 -2
  388. package/lib/composables/group.mjs.map +1 -1
  389. package/lib/composables/icons.mjs +4 -6
  390. package/lib/composables/icons.mjs.map +1 -1
  391. package/lib/composables/intersectionObserver.mjs +1 -1
  392. package/lib/composables/intersectionObserver.mjs.map +1 -1
  393. package/lib/composables/layout.mjs +2 -5
  394. package/lib/composables/layout.mjs.map +1 -1
  395. package/lib/composables/loader.mjs +2 -3
  396. package/lib/composables/loader.mjs.map +1 -1
  397. package/lib/composables/locale.mjs +2 -2
  398. package/lib/composables/locale.mjs.map +1 -1
  399. package/lib/composables/mutationObserver.mjs +8 -8
  400. package/lib/composables/mutationObserver.mjs.map +1 -1
  401. package/lib/composables/nested/nested.mjs +2 -1
  402. package/lib/composables/nested/nested.mjs.map +1 -1
  403. package/lib/composables/nested/selectStrategies.mjs +1 -1
  404. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  405. package/lib/composables/proxiedModel.mjs +9 -10
  406. package/lib/composables/proxiedModel.mjs.map +1 -1
  407. package/lib/composables/resizeObserver.mjs +1 -1
  408. package/lib/composables/resizeObserver.mjs.map +1 -1
  409. package/lib/composables/router.mjs +12 -21
  410. package/lib/composables/router.mjs.map +1 -1
  411. package/lib/composables/scroll.mjs +2 -4
  412. package/lib/composables/scroll.mjs.map +1 -1
  413. package/lib/composables/selectLink.mjs +1 -4
  414. package/lib/composables/selectLink.mjs.map +1 -1
  415. package/lib/composables/stack.mjs +6 -8
  416. package/lib/composables/stack.mjs.map +1 -1
  417. package/lib/composables/teleport.mjs +1 -1
  418. package/lib/composables/teleport.mjs.map +1 -1
  419. package/lib/composables/theme.mjs +2 -3
  420. package/lib/composables/theme.mjs.map +1 -1
  421. package/lib/composables/toggleScope.mjs +3 -6
  422. package/lib/composables/toggleScope.mjs.map +1 -1
  423. package/lib/composables/touch.mjs +1 -2
  424. package/lib/composables/touch.mjs.map +1 -1
  425. package/lib/composables/validation.mjs +7 -7
  426. package/lib/composables/validation.mjs.map +1 -1
  427. package/lib/directives/click-outside/index.mjs +2 -3
  428. package/lib/directives/click-outside/index.mjs.map +1 -1
  429. package/lib/directives/index.d.ts +1 -1
  430. package/lib/directives/intersect/index.mjs +2 -4
  431. package/lib/directives/intersect/index.mjs.map +1 -1
  432. package/lib/directives/mutate/index.mjs +7 -8
  433. package/lib/directives/mutate/index.mjs.map +1 -1
  434. package/lib/directives/resize/index.mjs +3 -5
  435. package/lib/directives/resize/index.mjs.map +1 -1
  436. package/lib/directives/ripple/VRipple.css +3 -0
  437. package/lib/directives/ripple/VRipple.sass +3 -0
  438. package/lib/directives/ripple/_variables.scss +1 -1
  439. package/lib/directives/ripple/index.mjs +8 -18
  440. package/lib/directives/ripple/index.mjs.map +1 -1
  441. package/lib/directives/scroll/index.mjs +1 -2
  442. package/lib/directives/scroll/index.mjs.map +1 -1
  443. package/lib/directives/touch/index.mjs +9 -14
  444. package/lib/directives/touch/index.mjs.map +1 -1
  445. package/lib/entry-bundler.mjs +1 -1
  446. package/lib/framework.mjs +2 -3
  447. package/lib/framework.mjs.map +1 -1
  448. package/lib/iconsets/fa-svg.d.ts +2 -2
  449. package/lib/iconsets/fa.d.ts +2 -2
  450. package/lib/iconsets/fa4.d.ts +2 -2
  451. package/lib/iconsets/md.d.ts +2 -2
  452. package/lib/iconsets/mdi-svg.d.ts +2 -2
  453. package/lib/iconsets/mdi.d.ts +2 -2
  454. package/lib/index.d.ts +20 -20
  455. package/lib/labs/VDataTable/VDataTable.mjs +12 -19
  456. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  457. package/lib/labs/VDataTable/VDataTableColumn.mjs +1 -2
  458. package/lib/labs/VDataTable/VDataTableColumn.mjs.map +1 -1
  459. package/lib/labs/VDataTable/VDataTableFooter.css +9 -0
  460. package/lib/labs/VDataTable/VDataTableFooter.mjs +80 -45
  461. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  462. package/lib/labs/VDataTable/VDataTableFooter.sass +7 -0
  463. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +6 -8
  464. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
  465. package/lib/labs/VDataTable/VDataTableHeaders.mjs +3 -4
  466. package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
  467. package/lib/labs/VDataTable/VDataTableRow.mjs +2 -4
  468. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  469. package/lib/labs/VDataTable/VDataTableRows.mjs +45 -49
  470. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  471. package/lib/labs/VDataTable/VDataTableServer.mjs +17 -26
  472. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  473. package/lib/labs/VDataTable/VDataTableVirtual.mjs +2 -5
  474. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  475. package/lib/labs/VDataTable/composables/headers.mjs +3 -4
  476. package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
  477. package/lib/labs/VDataTable/composables/options.mjs +0 -6
  478. package/lib/labs/VDataTable/composables/options.mjs.map +1 -1
  479. package/lib/labs/VDataTable/composables/paginate.mjs +2 -7
  480. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  481. package/lib/labs/VDataTable/composables/sort.mjs +1 -1
  482. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  483. package/lib/labs/VDataTable/index.d.ts +593 -526
  484. package/lib/labs/VDataTable/index.mjs +1 -0
  485. package/lib/labs/VDataTable/index.mjs.map +1 -1
  486. package/lib/labs/VVirtualScroll/VVirtualScroll.css +0 -1
  487. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs +48 -34
  488. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  489. package/lib/labs/VVirtualScroll/VVirtualScroll.sass +0 -1
  490. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs +22 -16
  491. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs.map +1 -1
  492. package/lib/labs/VVirtualScroll/index.d.ts +26 -57
  493. package/lib/labs/components.d.ts +619 -583
  494. package/lib/locale/adapters/vue-i18n.d.ts +1 -1
  495. package/lib/locale/adapters/vuetify.mjs +3 -3
  496. package/lib/locale/adapters/vuetify.mjs.map +1 -1
  497. package/lib/locale/ar.mjs +20 -20
  498. package/lib/locale/ar.mjs.map +1 -1
  499. package/lib/locale/es.mjs +3 -3
  500. package/lib/locale/es.mjs.map +1 -1
  501. package/lib/locale/fi.mjs +5 -5
  502. package/lib/locale/fi.mjs.map +1 -1
  503. package/lib/locale/it.mjs +6 -6
  504. package/lib/locale/it.mjs.map +1 -1
  505. package/lib/locale/sv.mjs +7 -7
  506. package/lib/locale/sv.mjs.map +1 -1
  507. package/lib/styles/main.css +40 -2816
  508. package/lib/styles/settings/_variables.scss +6 -6
  509. package/lib/styles/tools/_states.sass +3 -3
  510. package/lib/util/console.mjs +1 -1
  511. package/lib/util/console.mjs.map +1 -1
  512. package/lib/util/createSimpleFunctional.mjs +5 -8
  513. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  514. package/lib/util/defineComponent.mjs +6 -8
  515. package/lib/util/defineComponent.mjs.map +1 -1
  516. package/lib/util/getCurrentInstance.mjs +1 -1
  517. package/lib/util/getCurrentInstance.mjs.map +1 -1
  518. package/lib/util/helpers.mjs +2 -21
  519. package/lib/util/helpers.mjs.map +1 -1
  520. package/package.json +19 -19
@@ -3,4 +3,5 @@ export { VDataTableRows } from "./VDataTableRows.mjs";
3
3
  export { VDataTableRow } from "./VDataTableRow.mjs";
4
4
  export { VDataTableVirtual } from "./VDataTableVirtual.mjs";
5
5
  export { VDataTableServer } from "./VDataTableServer.mjs";
6
+ export { VDataTableFooter } from "./VDataTableFooter.mjs";
6
7
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","names":["VDataTable","VDataTableRows","VDataTableRow","VDataTableVirtual","VDataTableServer"],"sources":["../../../src/labs/VDataTable/index.ts"],"sourcesContent":["export { VDataTable } from './VDataTable'\nexport { VDataTableRows } from './VDataTableRows'\nexport { VDataTableRow } from './VDataTableRow'\nexport { VDataTableVirtual } from './VDataTableVirtual'\nexport { VDataTableServer } from './VDataTableServer'\n"],"mappings":"SAASA,UAAU;AAAA,SACVC,cAAc;AAAA,SACdC,aAAa;AAAA,SACbC,iBAAiB;AAAA,SACjBC,gBAAgB"}
1
+ {"version":3,"file":"index.mjs","names":["VDataTable","VDataTableRows","VDataTableRow","VDataTableVirtual","VDataTableServer","VDataTableFooter"],"sources":["../../../src/labs/VDataTable/index.ts"],"sourcesContent":["export { VDataTable } from './VDataTable'\nexport { VDataTableRows } from './VDataTableRows'\nexport { VDataTableRow } from './VDataTableRow'\nexport { VDataTableVirtual } from './VDataTableVirtual'\nexport { VDataTableServer } from './VDataTableServer'\nexport { VDataTableFooter } from './VDataTableFooter'\n"],"mappings":"SAASA,UAAU;AAAA,SACVC,cAAc;AAAA,SACdC,aAAa;AAAA,SACbC,iBAAiB;AAAA,SACjBC,gBAAgB;AAAA,SAChBC,gBAAgB"}
@@ -1,7 +1,6 @@
1
1
  .v-virtual-scroll {
2
2
  display: block;
3
3
  flex: 1 1 auto;
4
- height: 100%;
5
4
  max-width: 100%;
6
5
  overflow: auto;
7
6
  position: relative;
@@ -4,9 +4,11 @@ import "./VVirtualScroll.css";
4
4
 
5
5
  // Components
6
6
  import { VVirtualScrollItem } from "./VVirtualScrollItem.mjs"; // Composables
7
- import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs"; // Utilities
8
- import { computed, ref } from 'vue';
9
- import { convertToUnit, createRange, genericComponent, getPropertyFromItem, useRender } from "../../util/index.mjs"; // Types
7
+ import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs";
8
+ import { useDisplay } from "../../composables/display.mjs";
9
+ import { useResizeObserver } from "../../composables/resizeObserver.mjs"; // Utilities
10
+ import { computed, onMounted, ref, watchEffect } from 'vue';
11
+ import { convertToUnit, createRange, genericComponent, useRender } from "../../util/index.mjs"; // Types
10
12
  const UP = -1;
11
13
  const DOWN = 1;
12
14
  export const VVirtualScroll = genericComponent()({
@@ -16,15 +18,8 @@ export const VVirtualScroll = genericComponent()({
16
18
  type: Array,
17
19
  default: () => []
18
20
  },
19
- itemKey: {
20
- type: String,
21
- default: 'value'
22
- },
23
21
  itemHeight: [Number, String],
24
- visibleItems: {
25
- type: [Number, String],
26
- default: 30
27
- },
22
+ visibleItems: [Number, String],
28
23
  ...makeDimensionProps()
29
24
  },
30
25
  setup(props, _ref) {
@@ -39,15 +34,22 @@ export const VVirtualScroll = genericComponent()({
39
34
  baseItemHeight.value = val;
40
35
  }
41
36
  });
42
- const visibleItems = computed(() => parseInt(props.visibleItems, 10));
43
37
  const rootEl = ref();
44
- const ids = new Map(props.items.map((item, index) => [getPropertyFromItem(item, props.itemKey, item), index]));
38
+ const {
39
+ resizeRef,
40
+ contentRect
41
+ } = useResizeObserver();
42
+ watchEffect(() => {
43
+ resizeRef.value = rootEl.value;
44
+ });
45
+ const display = useDisplay();
45
46
  const sizes = createRange(props.items.length).map(() => itemHeight.value);
46
- function handleItemResize(item, height) {
47
- const index = ids.get(getPropertyFromItem(item, props.itemKey, item));
48
- if (!index) return;
47
+ const visibleItems = computed(() => {
48
+ return props.visibleItems ? parseInt(props.visibleItems, 10) : Math.max(12, Math.ceil((contentRect.value?.height ?? display.height.value) / itemHeight.value * 1.7 + 1));
49
+ });
50
+ function handleItemResize(index, height) {
51
+ itemHeight.value = Math.max(itemHeight.value, height);
49
52
  sizes[index] = height;
50
- if (!itemHeight.value) itemHeight.value = height;
51
53
  }
52
54
  function calculateOffset(index) {
53
55
  return sizes.slice(0, index).reduce((curr, value) => curr + (value || itemHeight.value), 0);
@@ -70,18 +72,24 @@ export const VVirtualScroll = genericComponent()({
70
72
  }
71
73
  let lastScrollTop = 0;
72
74
  function handleScroll() {
73
- if (!rootEl.value) return;
75
+ if (!rootEl.value || !contentRect.value) return;
76
+ const height = contentRect.value.height;
74
77
  const scrollTop = rootEl.value.scrollTop;
75
78
  const direction = scrollTop < lastScrollTop ? UP : DOWN;
76
- const midPointIndex = calculateMidPointIndex(scrollTop);
79
+ const midPointIndex = calculateMidPointIndex(scrollTop + height / 2);
77
80
  const buffer = Math.round(visibleItems.value / 3);
78
- if (direction === UP && midPointIndex <= first.value) {
81
+ if (direction === UP && midPointIndex <= first.value + buffer * 2 - 1) {
79
82
  first.value = Math.max(midPointIndex - buffer, 0);
80
- } else if (direction === DOWN && midPointIndex >= first.value + buffer * 2) {
83
+ } else if (direction === DOWN && midPointIndex >= first.value + buffer * 2 - 1) {
81
84
  first.value = Math.min(Math.max(0, midPointIndex - buffer), props.items.length - visibleItems.value);
82
85
  }
83
86
  lastScrollTop = rootEl.value.scrollTop;
84
87
  }
88
+ function scrollToIndex(index) {
89
+ if (!rootEl.value) return;
90
+ const offset = calculateOffset(index);
91
+ rootEl.value.scrollTop = offset;
92
+ }
85
93
  const last = computed(() => Math.min(props.items.length, first.value + visibleItems.value));
86
94
  const computedItems = computed(() => props.items.slice(first.value, last.value));
87
95
  const paddingTop = computed(() => calculateOffset(first.value));
@@ -89,6 +97,12 @@ export const VVirtualScroll = genericComponent()({
89
97
  const {
90
98
  dimensionStyles
91
99
  } = useDimension(props);
100
+ onMounted(() => {
101
+ if (!itemHeight.value) {
102
+ // If itemHeight prop is not set, then calculate an estimated height from the average of inital items
103
+ itemHeight.value = sizes.slice(first.value, last.value).reduce((curr, height) => curr + height, 0) / visibleItems.value;
104
+ }
105
+ });
92
106
  useRender(() => _createVNode("div", {
93
107
  "ref": rootEl,
94
108
  "class": "v-virtual-scroll",
@@ -100,19 +114,19 @@ export const VVirtualScroll = genericComponent()({
100
114
  paddingTop: convertToUnit(paddingTop.value),
101
115
  paddingBottom: convertToUnit(paddingBottom.value)
102
116
  }
103
- }, [computedItems.value.map((item, index) => {
104
- var _slots$default;
105
- return _createVNode(VVirtualScrollItem, {
106
- "key": index,
107
- "dynamicHeight": !props.itemHeight,
108
- "onUpdate:height": height => handleItemResize(item, height)
109
- }, {
110
- default: () => [(_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots, {
111
- item,
112
- index: index + first.value
113
- })]
114
- });
115
- })])]));
117
+ }, [computedItems.value.map((item, index) => _createVNode(VVirtualScrollItem, {
118
+ "key": index,
119
+ "dynamicHeight": !props.itemHeight,
120
+ "onUpdate:height": height => handleItemResize(index + first.value, height)
121
+ }, {
122
+ default: () => [slots.default?.({
123
+ item,
124
+ index: index + first.value
125
+ })]
126
+ }))])]));
127
+ return {
128
+ scrollToIndex
129
+ };
116
130
  }
117
131
  });
118
132
  //# sourceMappingURL=VVirtualScroll.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VVirtualScroll.mjs","names":["VVirtualScrollItem","makeDimensionProps","useDimension","computed","ref","convertToUnit","createRange","genericComponent","getPropertyFromItem","useRender","UP","DOWN","VVirtualScroll","name","props","items","type","Array","default","itemKey","String","itemHeight","Number","visibleItems","setup","slots","first","baseItemHeight","get","parseInt","value","set","val","rootEl","ids","Map","map","item","index","sizes","length","handleItemResize","height","calculateOffset","slice","reduce","curr","calculateMidPointIndex","scrollTop","start","end","middle","Math","floor","middleOffset","lastScrollTop","handleScroll","direction","midPointIndex","buffer","round","max","min","last","computedItems","paddingTop","paddingBottom","dimensionStyles"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScroll.tsx"],"sourcesContent":["// Styles\nimport './VVirtualScroll.sass'\n\n// Components\nimport { VVirtualScrollItem } from './VVirtualScrollItem'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport {\n convertToUnit,\n createRange,\n genericComponent,\n getPropertyFromItem,\n useRender,\n} from '@/util'\n\n// Types\nimport type { MakeSlots, SlotsToProps } from '@/util'\n\nconst UP = -1\nconst DOWN = 1\n\nexport interface VVirtualScrollSlot<T> {\n item: T\n index: number\n}\n\nexport const VVirtualScroll = genericComponent<new <T>() => {\n $props: {\n items: readonly T[]\n } & SlotsToProps<\n MakeSlots<{\n default: [VVirtualScrollSlot<T>]\n }>\n >\n}>()({\n name: 'VVirtualScroll',\n\n props: {\n items: {\n type: Array,\n default: () => ([]),\n },\n itemKey: {\n type: String,\n default: 'value',\n },\n itemHeight: [Number, String],\n visibleItems: {\n type: [Number, String],\n default: 30,\n },\n\n ...makeDimensionProps(),\n },\n\n setup (props, { slots }) {\n const first = ref(0)\n const baseItemHeight = ref(props.itemHeight)\n const itemHeight = computed({\n get: () => parseInt(baseItemHeight.value ?? 0, 10),\n set (val) {\n baseItemHeight.value = val\n },\n })\n const visibleItems = computed(() => parseInt(props.visibleItems, 10))\n const rootEl = ref<HTMLDivElement>()\n\n const ids = new Map<unknown, number>(props.items.map((item, index) => [getPropertyFromItem(item, props.itemKey, item), index]))\n const sizes = createRange(props.items.length).map(() => itemHeight.value)\n\n function handleItemResize (item: unknown, height: number) {\n const index = ids.get(getPropertyFromItem(item, props.itemKey, item))\n\n if (!index) return\n\n sizes[index] = height\n\n if (!itemHeight.value) itemHeight.value = height\n }\n\n function calculateOffset (index: number) {\n return sizes.slice(0, index).reduce((curr, value) => curr + (value || itemHeight.value), 0)\n }\n\n function calculateMidPointIndex (scrollTop: number) {\n let start = 0\n let end = props.items.length\n\n while (start <= end) {\n const middle = start + Math.floor((end - start) / 2)\n const middleOffset = calculateOffset(middle)\n\n if (middleOffset === scrollTop) {\n return middle\n } else if (middleOffset < scrollTop) {\n start = middle + 1\n } else if (middleOffset > scrollTop) {\n end = middle - 1\n }\n }\n\n return start\n }\n\n let lastScrollTop = 0\n function handleScroll () {\n if (!rootEl.value) return\n\n const scrollTop = rootEl.value.scrollTop\n const direction = scrollTop < lastScrollTop ? UP : DOWN\n\n const midPointIndex = calculateMidPointIndex(scrollTop)\n\n const buffer = Math.round(visibleItems.value / 3)\n if (direction === UP && midPointIndex <= first.value) {\n first.value = Math.max(midPointIndex - buffer, 0)\n } else if (direction === DOWN && midPointIndex >= first.value + (buffer * 2)) {\n first.value = Math.min(Math.max(0, midPointIndex - buffer), props.items.length - visibleItems.value)\n }\n\n lastScrollTop = rootEl.value.scrollTop\n }\n\n const last = computed(() => Math.min(props.items.length, first.value + visibleItems.value))\n const computedItems = computed(() => props.items.slice(first.value, last.value))\n const paddingTop = computed(() => calculateOffset(first.value))\n const paddingBottom = computed(() => calculateOffset(props.items.length) - calculateOffset(last.value))\n\n const { dimensionStyles } = useDimension(props)\n\n useRender(() => (\n <div\n ref={ rootEl }\n class=\"v-virtual-scroll\"\n onScroll={ handleScroll }\n style={ dimensionStyles.value }\n >\n <div\n class=\"v-virtual-scroll__container\"\n style={{\n paddingTop: convertToUnit(paddingTop.value),\n paddingBottom: convertToUnit(paddingBottom.value),\n }}\n >\n { computedItems.value.map((item, index) => (\n <VVirtualScrollItem\n key={ index }\n dynamicHeight={ !props.itemHeight }\n onUpdate:height={ height => handleItemResize(item, height) }\n >\n { slots.default?.({ item, index: index + first.value }) }\n </VVirtualScrollItem>\n )) }\n </div>\n </div>\n ))\n },\n})\n\nexport type VVirtualScroll = InstanceType<typeof VVirtualScroll>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,kBAAkB,oCAE3B;AAAA,SACSC,kBAAkB,EAAEC,YAAY,4CAEzC;AACA,SAASC,QAAQ,EAAEC,GAAG,QAAQ,KAAK;AAAA,SAEjCC,aAAa,EACbC,WAAW,EACXC,gBAAgB,EAChBC,mBAAmB,EACnBC,SAAS,gCAGX;AAGA,MAAMC,EAAE,GAAG,CAAC,CAAC;AACb,MAAMC,IAAI,GAAG,CAAC;AAOd,OAAO,MAAMC,cAAc,GAAGL,gBAAgB,EAQ1C,CAAC;EACHM,IAAI,EAAE,gBAAgB;EAEtBC,KAAK,EAAE;IACLC,KAAK,EAAE;MACLC,IAAI,EAAEC,KAAK;MACXC,OAAO,EAAE,MAAO;IAClB,CAAC;IACDC,OAAO,EAAE;MACPH,IAAI,EAAEI,MAAM;MACZF,OAAO,EAAE;IACX,CAAC;IACDG,UAAU,EAAE,CAACC,MAAM,EAAEF,MAAM,CAAC;IAC5BG,YAAY,EAAE;MACZP,IAAI,EAAE,CAACM,MAAM,EAAEF,MAAM,CAAC;MACtBF,OAAO,EAAE;IACX,CAAC;IAED,GAAGjB,kBAAkB;EACvB,CAAC;EAEDuB,KAAK,CAAEV,KAAK,QAAa;IAAA,IAAX;MAAEW;IAAM,CAAC;IACrB,MAAMC,KAAK,GAAGtB,GAAG,CAAC,CAAC,CAAC;IACpB,MAAMuB,cAAc,GAAGvB,GAAG,CAACU,KAAK,CAACO,UAAU,CAAC;IAC5C,MAAMA,UAAU,GAAGlB,QAAQ,CAAC;MAC1ByB,GAAG,EAAE,MAAMC,QAAQ,CAACF,cAAc,CAACG,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;MAClDC,GAAG,CAAEC,GAAG,EAAE;QACRL,cAAc,CAACG,KAAK,GAAGE,GAAG;MAC5B;IACF,CAAC,CAAC;IACF,MAAMT,YAAY,GAAGpB,QAAQ,CAAC,MAAM0B,QAAQ,CAACf,KAAK,CAACS,YAAY,EAAE,EAAE,CAAC,CAAC;IACrE,MAAMU,MAAM,GAAG7B,GAAG,EAAkB;IAEpC,MAAM8B,GAAG,GAAG,IAAIC,GAAG,CAAkBrB,KAAK,CAACC,KAAK,CAACqB,GAAG,CAAC,CAACC,IAAI,EAAEC,KAAK,KAAK,CAAC9B,mBAAmB,CAAC6B,IAAI,EAAEvB,KAAK,CAACK,OAAO,EAAEkB,IAAI,CAAC,EAAEC,KAAK,CAAC,CAAC,CAAC;IAC/H,MAAMC,KAAK,GAAGjC,WAAW,CAACQ,KAAK,CAACC,KAAK,CAACyB,MAAM,CAAC,CAACJ,GAAG,CAAC,MAAMf,UAAU,CAACS,KAAK,CAAC;IAEzE,SAASW,gBAAgB,CAAEJ,IAAa,EAAEK,MAAc,EAAE;MACxD,MAAMJ,KAAK,GAAGJ,GAAG,CAACN,GAAG,CAACpB,mBAAmB,CAAC6B,IAAI,EAAEvB,KAAK,CAACK,OAAO,EAAEkB,IAAI,CAAC,CAAC;MAErE,IAAI,CAACC,KAAK,EAAE;MAEZC,KAAK,CAACD,KAAK,CAAC,GAAGI,MAAM;MAErB,IAAI,CAACrB,UAAU,CAACS,KAAK,EAAET,UAAU,CAACS,KAAK,GAAGY,MAAM;IAClD;IAEA,SAASC,eAAe,CAAEL,KAAa,EAAE;MACvC,OAAOC,KAAK,CAACK,KAAK,CAAC,CAAC,EAAEN,KAAK,CAAC,CAACO,MAAM,CAAC,CAACC,IAAI,EAAEhB,KAAK,KAAKgB,IAAI,IAAIhB,KAAK,IAAIT,UAAU,CAACS,KAAK,CAAC,EAAE,CAAC,CAAC;IAC7F;IAEA,SAASiB,sBAAsB,CAAEC,SAAiB,EAAE;MAClD,IAAIC,KAAK,GAAG,CAAC;MACb,IAAIC,GAAG,GAAGpC,KAAK,CAACC,KAAK,CAACyB,MAAM;MAE5B,OAAOS,KAAK,IAAIC,GAAG,EAAE;QACnB,MAAMC,MAAM,GAAGF,KAAK,GAAGG,IAAI,CAACC,KAAK,CAAC,CAACH,GAAG,GAAGD,KAAK,IAAI,CAAC,CAAC;QACpD,MAAMK,YAAY,GAAGX,eAAe,CAACQ,MAAM,CAAC;QAE5C,IAAIG,YAAY,KAAKN,SAAS,EAAE;UAC9B,OAAOG,MAAM;QACf,CAAC,MAAM,IAAIG,YAAY,GAAGN,SAAS,EAAE;UACnCC,KAAK,GAAGE,MAAM,GAAG,CAAC;QACpB,CAAC,MAAM,IAAIG,YAAY,GAAGN,SAAS,EAAE;UACnCE,GAAG,GAAGC,MAAM,GAAG,CAAC;QAClB;MACF;MAEA,OAAOF,KAAK;IACd;IAEA,IAAIM,aAAa,GAAG,CAAC;IACrB,SAASC,YAAY,GAAI;MACvB,IAAI,CAACvB,MAAM,CAACH,KAAK,EAAE;MAEnB,MAAMkB,SAAS,GAAGf,MAAM,CAACH,KAAK,CAACkB,SAAS;MACxC,MAAMS,SAAS,GAAGT,SAAS,GAAGO,aAAa,GAAG7C,EAAE,GAAGC,IAAI;MAEvD,MAAM+C,aAAa,GAAGX,sBAAsB,CAACC,SAAS,CAAC;MAEvD,MAAMW,MAAM,GAAGP,IAAI,CAACQ,KAAK,CAACrC,YAAY,CAACO,KAAK,GAAG,CAAC,CAAC;MACjD,IAAI2B,SAAS,KAAK/C,EAAE,IAAIgD,aAAa,IAAIhC,KAAK,CAACI,KAAK,EAAE;QACpDJ,KAAK,CAACI,KAAK,GAAGsB,IAAI,CAACS,GAAG,CAACH,aAAa,GAAGC,MAAM,EAAE,CAAC,CAAC;MACnD,CAAC,MAAM,IAAIF,SAAS,KAAK9C,IAAI,IAAI+C,aAAa,IAAIhC,KAAK,CAACI,KAAK,GAAI6B,MAAM,GAAG,CAAE,EAAE;QAC5EjC,KAAK,CAACI,KAAK,GAAGsB,IAAI,CAACU,GAAG,CAACV,IAAI,CAACS,GAAG,CAAC,CAAC,EAAEH,aAAa,GAAGC,MAAM,CAAC,EAAE7C,KAAK,CAACC,KAAK,CAACyB,MAAM,GAAGjB,YAAY,CAACO,KAAK,CAAC;MACtG;MAEAyB,aAAa,GAAGtB,MAAM,CAACH,KAAK,CAACkB,SAAS;IACxC;IAEA,MAAMe,IAAI,GAAG5D,QAAQ,CAAC,MAAMiD,IAAI,CAACU,GAAG,CAAChD,KAAK,CAACC,KAAK,CAACyB,MAAM,EAAEd,KAAK,CAACI,KAAK,GAAGP,YAAY,CAACO,KAAK,CAAC,CAAC;IAC3F,MAAMkC,aAAa,GAAG7D,QAAQ,CAAC,MAAMW,KAAK,CAACC,KAAK,CAAC6B,KAAK,CAAClB,KAAK,CAACI,KAAK,EAAEiC,IAAI,CAACjC,KAAK,CAAC,CAAC;IAChF,MAAMmC,UAAU,GAAG9D,QAAQ,CAAC,MAAMwC,eAAe,CAACjB,KAAK,CAACI,KAAK,CAAC,CAAC;IAC/D,MAAMoC,aAAa,GAAG/D,QAAQ,CAAC,MAAMwC,eAAe,CAAC7B,KAAK,CAACC,KAAK,CAACyB,MAAM,CAAC,GAAGG,eAAe,CAACoB,IAAI,CAACjC,KAAK,CAAC,CAAC;IAEvG,MAAM;MAAEqC;IAAgB,CAAC,GAAGjE,YAAY,CAACY,KAAK,CAAC;IAE/CL,SAAS,CAAC;MAAA,OAEAwB,MAAM;MAAA,SACN,kBAAkB;MAAA,YACbuB,YAAY;MAAA,SACfW,eAAe,CAACrC;IAAK;MAAA,SAGrB,6BAA6B;MAAA,SAC5B;QACLmC,UAAU,EAAE5D,aAAa,CAAC4D,UAAU,CAACnC,KAAK,CAAC;QAC3CoC,aAAa,EAAE7D,aAAa,CAAC6D,aAAa,CAACpC,KAAK;MAClD;IAAC,IAECkC,aAAa,CAAClC,KAAK,CAACM,GAAG,CAAC,CAACC,IAAI,EAAEC,KAAK;MAAA;MAAA;QAAA,OAE5BA,KAAK;QAAA,iBACK,CAACxB,KAAK,CAACO,UAAU;QAAA,mBACfqB,MAAM,IAAID,gBAAgB,CAACJ,IAAI,EAAEK,MAAM;MAAC;QAAA,kCAExDjB,KAAK,CAACP,OAAO,qBAAb,oBAAAO,KAAK,EAAW;UAAEY,IAAI;UAAEC,KAAK,EAAEA,KAAK,GAAGZ,KAAK,CAACI;QAAM,CAAC,CAAC;MAAA;IAAA,CAE1D,CAAC,IAGP,CAAC;EACJ;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"VVirtualScroll.mjs","names":["VVirtualScrollItem","makeDimensionProps","useDimension","useDisplay","useResizeObserver","computed","onMounted","ref","watchEffect","convertToUnit","createRange","genericComponent","useRender","UP","DOWN","VVirtualScroll","name","props","items","type","Array","default","itemHeight","Number","String","visibleItems","setup","slots","first","baseItemHeight","get","parseInt","value","set","val","rootEl","resizeRef","contentRect","display","sizes","length","map","Math","max","ceil","height","handleItemResize","index","calculateOffset","slice","reduce","curr","calculateMidPointIndex","scrollTop","start","end","middle","floor","middleOffset","lastScrollTop","handleScroll","direction","midPointIndex","buffer","round","min","scrollToIndex","offset","last","computedItems","paddingTop","paddingBottom","dimensionStyles","item"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScroll.tsx"],"sourcesContent":["// Styles\nimport './VVirtualScroll.sass'\n\n// Components\nimport { VVirtualScrollItem } from './VVirtualScrollItem'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { useDisplay } from '@/composables/display'\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { computed, onMounted, ref, watchEffect } from 'vue'\nimport {\n convertToUnit,\n createRange,\n genericComponent,\n useRender,\n} from '@/util'\n\n// Types\nimport type { SlotsToProps } from '@/util'\n\nconst UP = -1\nconst DOWN = 1\n\nexport interface VVirtualScrollSlot<T> {\n item: T\n index: number\n}\n\nexport const VVirtualScroll = genericComponent<new <T>() => {\n $props: {\n items: readonly T[]\n } & SlotsToProps<{\n default: [VVirtualScrollSlot<T>]\n }>\n}>()({\n name: 'VVirtualScroll',\n\n props: {\n items: {\n type: Array,\n default: () => ([]),\n },\n itemHeight: [Number, String],\n visibleItems: [Number, String],\n\n ...makeDimensionProps(),\n },\n\n setup (props, { slots }) {\n const first = ref(0)\n const baseItemHeight = ref(props.itemHeight)\n const itemHeight = computed({\n get: () => parseInt(baseItemHeight.value ?? 0, 10),\n set (val) {\n baseItemHeight.value = val\n },\n })\n const rootEl = ref<HTMLDivElement>()\n const { resizeRef, contentRect } = useResizeObserver()\n watchEffect(() => {\n resizeRef.value = rootEl.value\n })\n const display = useDisplay()\n\n const sizes = createRange(props.items.length).map(() => itemHeight.value)\n const visibleItems = computed(() => {\n return props.visibleItems\n ? parseInt(props.visibleItems, 10)\n : Math.max(12,\n Math.ceil(((contentRect.value?.height ?? display.height.value) / itemHeight.value) * 1.7 + 1)\n )\n })\n\n function handleItemResize (index: number, height: number) {\n itemHeight.value = Math.max(itemHeight.value, height)\n sizes[index] = height\n }\n\n function calculateOffset (index: number) {\n return sizes.slice(0, index).reduce((curr, value) => curr + (value || itemHeight.value), 0)\n }\n\n function calculateMidPointIndex (scrollTop: number) {\n let start = 0\n let end = props.items.length\n\n while (start <= end) {\n const middle = start + Math.floor((end - start) / 2)\n const middleOffset = calculateOffset(middle)\n\n if (middleOffset === scrollTop) {\n return middle\n } else if (middleOffset < scrollTop) {\n start = middle + 1\n } else if (middleOffset > scrollTop) {\n end = middle - 1\n }\n }\n\n return start\n }\n\n let lastScrollTop = 0\n function handleScroll () {\n if (!rootEl.value || !contentRect.value) return\n\n const height = contentRect.value.height\n const scrollTop = rootEl.value.scrollTop\n const direction = scrollTop < lastScrollTop ? UP : DOWN\n\n const midPointIndex = calculateMidPointIndex(scrollTop + height / 2)\n const buffer = Math.round(visibleItems.value / 3)\n if (direction === UP && midPointIndex <= first.value + (buffer * 2) - 1) {\n first.value = Math.max(midPointIndex - buffer, 0)\n } else if (direction === DOWN && midPointIndex >= first.value + (buffer * 2) - 1) {\n first.value = Math.min(Math.max(0, midPointIndex - buffer), props.items.length - visibleItems.value)\n }\n\n lastScrollTop = rootEl.value.scrollTop\n }\n\n function scrollToIndex (index: number) {\n if (!rootEl.value) return\n\n const offset = calculateOffset(index)\n rootEl.value.scrollTop = offset\n }\n\n const last = computed(() => Math.min(props.items.length, first.value + visibleItems.value))\n const computedItems = computed(() => props.items.slice(first.value, last.value))\n const paddingTop = computed(() => calculateOffset(first.value))\n const paddingBottom = computed(() => calculateOffset(props.items.length) - calculateOffset(last.value))\n\n const { dimensionStyles } = useDimension(props)\n\n onMounted(() => {\n if (!itemHeight.value) {\n // If itemHeight prop is not set, then calculate an estimated height from the average of inital items\n itemHeight.value = sizes.slice(first.value, last.value).reduce((curr, height) => curr + height, 0) / (visibleItems.value)\n }\n })\n\n useRender(() => (\n <div\n ref={ rootEl }\n class=\"v-virtual-scroll\"\n onScroll={ handleScroll }\n style={ dimensionStyles.value }\n >\n <div\n class=\"v-virtual-scroll__container\"\n style={{\n paddingTop: convertToUnit(paddingTop.value),\n paddingBottom: convertToUnit(paddingBottom.value),\n }}\n >\n { computedItems.value.map((item, index) => (\n <VVirtualScrollItem\n key={ index }\n dynamicHeight={ !props.itemHeight }\n onUpdate:height={ height => handleItemResize(index + first.value, height) }\n >\n { slots.default?.({ item, index: index + first.value }) }\n </VVirtualScrollItem>\n )) }\n </div>\n </div>\n ))\n\n return {\n scrollToIndex,\n }\n },\n})\n\nexport type VVirtualScroll = InstanceType<typeof VVirtualScroll>\n"],"mappings":"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"}
@@ -1,7 +1,6 @@
1
1
  .v-virtual-scroll
2
2
  display: block
3
3
  flex: 1 1 auto
4
- height: 100%
5
4
  max-width: 100%
6
5
  overflow: auto
7
6
  position: relative
@@ -1,9 +1,10 @@
1
1
  import { createVNode as _createVNode } from "vue";
2
2
  // Composables
3
- import { useResizeObserver } from "../../composables/resizeObserver.mjs"; // Utilities
4
- import { defineComponent } from "../../util/defineComponent.mjs";
5
- import { useRender } from "../../util/index.mjs";
6
- export const VVirtualScrollItem = defineComponent({
3
+ import { useResizeObserver } from "../../composables/resizeObserver.mjs";
4
+ import { useToggleScope } from "../../composables/toggleScope.mjs"; // Utilities
5
+ import { genericComponent, useRender } from "../../util/index.mjs";
6
+ import { onUpdated, watch } from 'vue';
7
+ export const VVirtualScrollItem = genericComponent()({
7
8
  name: 'VVirtualScrollItem',
8
9
  props: {
9
10
  dynamicHeight: Boolean
@@ -17,19 +18,24 @@ export const VVirtualScrollItem = defineComponent({
17
18
  slots
18
19
  } = _ref;
19
20
  const {
20
- resizeRef
21
- } = useResizeObserver(entries => {
22
- if (!entries.length) return;
23
- const contentRect = entries[0].contentRect;
24
- emit('update:height', contentRect.height);
25
- });
26
- useRender(() => {
27
- var _slots$default;
28
- return _createVNode("div", {
29
- "ref": props.dynamicHeight ? resizeRef : undefined,
30
- "class": "v-virtual-scroll__item"
31
- }, [(_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots)]);
21
+ resizeRef,
22
+ contentRect
23
+ } = useResizeObserver();
24
+ useToggleScope(() => props.dynamicHeight, () => {
25
+ watch(() => contentRect.value?.height, height => {
26
+ if (height != null) emit('update:height', height);
27
+ });
32
28
  });
29
+ function updateHeight() {
30
+ if (props.dynamicHeight && contentRect.value) {
31
+ emit('update:height', contentRect.value.height);
32
+ }
33
+ }
34
+ onUpdated(updateHeight);
35
+ useRender(() => _createVNode("div", {
36
+ "ref": props.dynamicHeight ? resizeRef : undefined,
37
+ "class": "v-virtual-scroll__item"
38
+ }, [slots.default?.()]));
33
39
  }
34
40
  });
35
41
  //# sourceMappingURL=VVirtualScrollItem.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VVirtualScrollItem.mjs","names":["useResizeObserver","defineComponent","useRender","VVirtualScrollItem","name","props","dynamicHeight","Boolean","emits","height","setup","emit","slots","resizeRef","entries","length","contentRect","undefined","default"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScrollItem.tsx"],"sourcesContent":["// Composables\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { defineComponent } from '@/util/defineComponent'\nimport { useRender } from '@/util'\n\nexport const VVirtualScrollItem = defineComponent({\n name: 'VVirtualScrollItem',\n\n props: {\n dynamicHeight: Boolean,\n },\n\n emits: {\n 'update:height': (height: number) => true,\n },\n\n setup (props, { emit, slots }) {\n const { resizeRef } = useResizeObserver(entries => {\n if (!entries.length) return\n\n const contentRect = entries[0].contentRect\n emit('update:height', contentRect.height)\n })\n\n useRender(() => (\n <div\n ref={ props.dynamicHeight ? resizeRef : undefined }\n class=\"v-virtual-scroll__item\"\n >\n { slots.default?.() }\n </div>\n ))\n },\n})\n"],"mappings":";AAAA;AAAA,SACSA,iBAAiB,gDAE1B;AAAA,SACSC,eAAe;AAAA,SACfC,SAAS;AAElB,OAAO,MAAMC,kBAAkB,GAAGF,eAAe,CAAC;EAChDG,IAAI,EAAE,oBAAoB;EAE1BC,KAAK,EAAE;IACLC,aAAa,EAAEC;EACjB,CAAC;EAEDC,KAAK,EAAE;IACL,eAAe,EAAGC,MAAc,IAAK;EACvC,CAAC;EAEDC,KAAK,CAAEL,KAAK,QAAmB;IAAA,IAAjB;MAAEM,IAAI;MAAEC;IAAM,CAAC;IAC3B,MAAM;MAAEC;IAAU,CAAC,GAAGb,iBAAiB,CAACc,OAAO,IAAI;MACjD,IAAI,CAACA,OAAO,CAACC,MAAM,EAAE;MAErB,MAAMC,WAAW,GAAGF,OAAO,CAAC,CAAC,CAAC,CAACE,WAAW;MAC1CL,IAAI,CAAC,eAAe,EAAEK,WAAW,CAACP,MAAM,CAAC;IAC3C,CAAC,CAAC;IAEFP,SAAS,CAAC;MAAA;MAAA;QAAA,OAEAG,KAAK,CAACC,aAAa,GAAGO,SAAS,GAAGI,SAAS;QAAA,SAC3C;MAAwB,sBAE5BL,KAAK,CAACM,OAAO,qBAAb,oBAAAN,KAAK,CAAY;IAAA,CAEtB,CAAC;EACJ;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"VVirtualScrollItem.mjs","names":["useResizeObserver","useToggleScope","genericComponent","useRender","onUpdated","watch","VVirtualScrollItem","name","props","dynamicHeight","Boolean","emits","height","setup","emit","slots","resizeRef","contentRect","value","updateHeight","undefined","default"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScrollItem.tsx"],"sourcesContent":["// Composables\nimport { useResizeObserver } from '@/composables/resizeObserver'\nimport { useToggleScope } from '@/composables/toggleScope'\n\n// Utilities\nimport { genericComponent, useRender } from '@/util'\nimport { onUpdated, watch } from 'vue'\n\nexport const VVirtualScrollItem = genericComponent()({\n name: 'VVirtualScrollItem',\n\n props: {\n dynamicHeight: Boolean,\n },\n\n emits: {\n 'update:height': (height: number) => true,\n },\n\n setup (props, { emit, slots }) {\n const { resizeRef, contentRect } = useResizeObserver()\n\n useToggleScope(() => props.dynamicHeight, () => {\n watch(() => contentRect.value?.height, height => {\n if (height != null) emit('update:height', height)\n })\n })\n\n function updateHeight () {\n if (props.dynamicHeight && contentRect.value) {\n emit('update:height', contentRect.value.height)\n }\n }\n\n onUpdated(updateHeight)\n\n useRender(() => (\n <div\n ref={ props.dynamicHeight ? resizeRef : undefined }\n class=\"v-virtual-scroll__item\"\n >\n { slots.default?.() }\n </div>\n ))\n },\n})\n"],"mappings":";AAAA;AAAA,SACSA,iBAAiB;AAAA,SACjBC,cAAc,6CAEvB;AAAA,SACSC,gBAAgB,EAAEC,SAAS;AACpC,SAASC,SAAS,EAAEC,KAAK,QAAQ,KAAK;AAEtC,OAAO,MAAMC,kBAAkB,GAAGJ,gBAAgB,EAAE,CAAC;EACnDK,IAAI,EAAE,oBAAoB;EAE1BC,KAAK,EAAE;IACLC,aAAa,EAAEC;EACjB,CAAC;EAEDC,KAAK,EAAE;IACL,eAAe,EAAGC,MAAc,IAAK;EACvC,CAAC;EAEDC,KAAK,CAAEL,KAAK,QAAmB;IAAA,IAAjB;MAAEM,IAAI;MAAEC;IAAM,CAAC;IAC3B,MAAM;MAAEC,SAAS;MAAEC;IAAY,CAAC,GAAGjB,iBAAiB,EAAE;IAEtDC,cAAc,CAAC,MAAMO,KAAK,CAACC,aAAa,EAAE,MAAM;MAC9CJ,KAAK,CAAC,MAAMY,WAAW,CAACC,KAAK,EAAEN,MAAM,EAAEA,MAAM,IAAI;QAC/C,IAAIA,MAAM,IAAI,IAAI,EAAEE,IAAI,CAAC,eAAe,EAAEF,MAAM,CAAC;MACnD,CAAC,CAAC;IACJ,CAAC,CAAC;IAEF,SAASO,YAAY,GAAI;MACvB,IAAIX,KAAK,CAACC,aAAa,IAAIQ,WAAW,CAACC,KAAK,EAAE;QAC5CJ,IAAI,CAAC,eAAe,EAAEG,WAAW,CAACC,KAAK,CAACN,MAAM,CAAC;MACjD;IACF;IAEAR,SAAS,CAACe,YAAY,CAAC;IAEvBhB,SAAS,CAAC;MAAA,OAEAK,KAAK,CAACC,aAAa,GAAGO,SAAS,GAAGI,SAAS;MAAA,SAC3C;IAAwB,IAE5BL,KAAK,CAACM,OAAO,IAAI,EAEtB,CAAC;EACJ;AACF,CAAC,CAAC"}
@@ -8,10 +8,7 @@ declare const VVirtualScroll: {
8
8
  new (...args: any[]): {
9
9
  $: vue.ComponentInternalInstance;
10
10
  $data: {};
11
- $props: Partial<{
12
- visibleItems: string | number;
13
- itemKey: string;
14
- }> & Omit<Readonly<vue.ExtractPropTypes<Omit<{
11
+ $props: Partial<{}> & Omit<Readonly<vue.ExtractPropTypes<Omit<{
15
12
  height: (StringConstructor | NumberConstructor)[];
16
13
  maxHeight: (StringConstructor | NumberConstructor)[];
17
14
  maxWidth: (StringConstructor | NumberConstructor)[];
@@ -22,16 +19,9 @@ declare const VVirtualScroll: {
22
19
  type: ArrayConstructor;
23
20
  default: () => never[];
24
21
  };
25
- itemKey: {
26
- type: StringConstructor;
27
- default: string;
28
- };
29
22
  itemHeight: (StringConstructor | NumberConstructor)[];
30
- visibleItems: {
31
- type: (StringConstructor | NumberConstructor)[];
32
- default: number;
33
- };
34
- }, "$children" | "items" | "v-slots" | "v-slot:default">>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "visibleItems" | "itemKey">;
23
+ visibleItems: (StringConstructor | NumberConstructor)[];
24
+ }, "$children" | "v-slot:default" | "items" | "v-slots">>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, never>;
35
25
  $attrs: {
36
26
  [x: string]: unknown;
37
27
  };
@@ -41,8 +31,8 @@ declare const VVirtualScroll: {
41
31
  $slots: Readonly<{
42
32
  [name: string]: vue.Slot | undefined;
43
33
  }>;
44
- $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
45
- $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
34
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
35
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
46
36
  $emit: (event: string, ...args: any[]) => void;
47
37
  $el: any;
48
38
  $options: vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<Omit<{
@@ -56,19 +46,11 @@ declare const VVirtualScroll: {
56
46
  type: ArrayConstructor;
57
47
  default: () => never[];
58
48
  };
59
- itemKey: {
60
- type: StringConstructor;
61
- default: string;
62
- };
63
49
  itemHeight: (StringConstructor | NumberConstructor)[];
64
- visibleItems: {
65
- type: (StringConstructor | NumberConstructor)[];
66
- default: number;
67
- };
68
- }, "$children" | "items" | "v-slots" | "v-slot:default">>>, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "items" | "v-slots" | "v-slot:default">, string, {
69
- visibleItems: string | number;
70
- itemKey: string;
71
- }> & {
50
+ visibleItems: (StringConstructor | NumberConstructor)[];
51
+ }, "$children" | "v-slot:default" | "items" | "v-slots">>>, {
52
+ scrollToIndex: (index: number) => void;
53
+ }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "v-slot:default" | "items" | "v-slots">, string, {}, {}, string> & {
72
54
  beforeCreate?: ((() => void) | (() => void)[]) | undefined;
73
55
  created?: ((() => void) | (() => void)[]) | undefined;
74
56
  beforeMount?: ((() => void) | (() => void)[]) | undefined;
@@ -83,11 +65,11 @@ declare const VVirtualScroll: {
83
65
  unmounted?: ((() => void) | (() => void)[]) | undefined;
84
66
  renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
85
67
  renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
86
- errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void)[]) | undefined;
68
+ 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;
87
69
  };
88
70
  $forceUpdate: () => void;
89
71
  $nextTick: typeof vue.nextTick;
90
- $watch(source: string | Function, cb: Function, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
72
+ $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;
91
73
  } & Readonly<vue.ExtractPropTypes<Omit<{
92
74
  height: (StringConstructor | NumberConstructor)[];
93
75
  maxHeight: (StringConstructor | NumberConstructor)[];
@@ -99,16 +81,11 @@ declare const VVirtualScroll: {
99
81
  type: ArrayConstructor;
100
82
  default: () => never[];
101
83
  };
102
- itemKey: {
103
- type: StringConstructor;
104
- default: string;
105
- };
106
84
  itemHeight: (StringConstructor | NumberConstructor)[];
107
- visibleItems: {
108
- type: (StringConstructor | NumberConstructor)[];
109
- default: number;
110
- };
111
- }, "$children" | "items" | "v-slots" | "v-slot:default">>> & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties;
85
+ visibleItems: (StringConstructor | NumberConstructor)[];
86
+ }, "$children" | "v-slot:default" | "items" | "v-slots">>> & vue.ShallowUnwrapRef<{
87
+ scrollToIndex: (index: number) => void;
88
+ }> & {} & vue.ComponentCustomProperties & {};
112
89
  __isFragment?: undefined;
113
90
  __isTeleport?: undefined;
114
91
  __isSuspense?: undefined;
@@ -123,32 +100,24 @@ declare const VVirtualScroll: {
123
100
  type: ArrayConstructor;
124
101
  default: () => never[];
125
102
  };
126
- itemKey: {
127
- type: StringConstructor;
128
- default: string;
129
- };
130
103
  itemHeight: (StringConstructor | NumberConstructor)[];
131
- visibleItems: {
132
- type: (StringConstructor | NumberConstructor)[];
133
- default: number;
134
- };
135
- }, "$children" | "items" | "v-slots" | "v-slot:default">>>, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "items" | "v-slots" | "v-slot:default">, string, {
136
- visibleItems: string | number;
137
- itemKey: string;
138
- }> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>() => {
104
+ visibleItems: (StringConstructor | NumberConstructor)[];
105
+ }, "$children" | "v-slot:default" | "items" | "v-slots">>>, {
106
+ scrollToIndex: (index: number) => void;
107
+ }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "v-slot:default" | "items" | "v-slots">, string, {}, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T_1>() => {
139
108
  $props: {
140
- items: readonly T[];
109
+ items: readonly T_1[];
141
110
  } & {
142
- $children?: vue.VNodeChild | {
143
- default?: ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
144
- } | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild);
111
+ $children?: vue.VNodeChild | ((args_0: VVirtualScrollSlot<T_1>) => vue.VNodeChild) | {
112
+ default?: ((args_0: VVirtualScrollSlot<T_1>) => vue.VNodeChild) | undefined;
113
+ };
145
114
  'v-slots'?: {
146
- default?: false | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
115
+ default?: false | ((args_0: VVirtualScrollSlot<T_1>) => vue.VNodeChild) | undefined;
147
116
  } | undefined;
148
117
  } & {
149
- "v-slot:default"?: false | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
118
+ "v-slot:default"?: false | ((args_0: VVirtualScrollSlot<T_1>) => vue.VNodeChild) | undefined;
150
119
  };
151
120
  });
152
- declare type VVirtualScroll = InstanceType<typeof VVirtualScroll>;
121
+ type VVirtualScroll = InstanceType<typeof VVirtualScroll>;
153
122
 
154
123
  export { VVirtualScroll };