vuetify 3.3.1 → 3.3.2

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 (470) hide show
  1. package/dist/json/attributes.json +40 -44
  2. package/dist/json/importMap.json +4 -4
  3. package/dist/json/tags.json +0 -1
  4. package/dist/json/web-types.json +605 -748
  5. package/dist/vuetify-labs.css +53 -32
  6. package/dist/vuetify-labs.d.ts +1591 -1494
  7. package/dist/vuetify-labs.esm.js +8140 -8073
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +8139 -8072
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +21 -1
  12. package/dist/vuetify.d.ts +1187 -1187
  13. package/dist/vuetify.esm.js +6685 -6547
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +6684 -6546
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +979 -975
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.mts +31 -31
  21. package/lib/blueprints/md1.d.mts +31 -31
  22. package/lib/blueprints/md2.d.mts +31 -31
  23. package/lib/blueprints/md3.d.mts +31 -31
  24. package/lib/components/VAlert/VAlert.mjs +6 -6
  25. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  26. package/lib/components/VAlert/index.d.mts +1 -1
  27. package/lib/components/VApp/VApp.mjs +4 -4
  28. package/lib/components/VApp/VApp.mjs.map +1 -1
  29. package/lib/components/VAppBar/VAppBar.mjs +9 -6
  30. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  31. package/lib/components/VAppBar/VAppBarNavIcon.mjs +1 -1
  32. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  33. package/lib/components/VAppBar/index.d.mts +1 -1
  34. package/lib/components/VAutocomplete/VAutocomplete.mjs +11 -11
  35. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  36. package/lib/components/VAutocomplete/index.d.mts +88 -88
  37. package/lib/components/VAvatar/VAvatar.mjs +4 -4
  38. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  39. package/lib/components/VBadge/VBadge.mjs +6 -6
  40. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  41. package/lib/components/VBanner/VBanner.mjs +7 -10
  42. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  43. package/lib/components/VBanner/VBannerActions.mjs +2 -2
  44. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  45. package/lib/components/VBanner/VBannerText.mjs +1 -0
  46. package/lib/components/VBanner/VBannerText.mjs.map +1 -1
  47. package/lib/components/VBanner/index.d.mts +1 -1
  48. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +8 -8
  49. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  50. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +6 -9
  51. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  52. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +2 -2
  53. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  54. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +3 -3
  55. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  56. package/lib/components/VBtn/VBtn.mjs +6 -6
  57. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  58. package/lib/components/VBtnGroup/VBtnGroup.mjs +4 -4
  59. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  60. package/lib/components/VBtnToggle/VBtnToggle.mjs +2 -2
  61. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  62. package/lib/components/VCard/VCard.mjs +7 -7
  63. package/lib/components/VCard/VCard.mjs.map +1 -1
  64. package/lib/components/VCard/VCardItem.mjs +4 -4
  65. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  66. package/lib/components/VCard/VCardSubtitle.mjs +1 -0
  67. package/lib/components/VCard/VCardSubtitle.mjs.map +1 -1
  68. package/lib/components/VCard/VCardText.mjs +1 -0
  69. package/lib/components/VCard/VCardText.mjs.map +1 -1
  70. package/lib/components/VCard/VCardTitle.mjs +1 -0
  71. package/lib/components/VCard/VCardTitle.mjs.map +1 -1
  72. package/lib/components/VCard/index.d.mts +1 -1
  73. package/lib/components/VCarousel/VCarousel.mjs +4 -7
  74. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  75. package/lib/components/VCarousel/VCarouselItem.mjs +1 -1
  76. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  77. package/lib/components/VCheckbox/VCheckbox.mjs +3 -3
  78. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  79. package/lib/components/VCheckbox/VCheckboxBtn.mjs +4 -4
  80. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  81. package/lib/components/VCheckbox/index.d.mts +50 -50
  82. package/lib/components/VChip/VChip.mjs +7 -7
  83. package/lib/components/VChip/VChip.mjs.map +1 -1
  84. package/lib/components/VChipGroup/VChipGroup.mjs +4 -7
  85. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  86. package/lib/components/VCode/index.mjs +3 -0
  87. package/lib/components/VCode/index.mjs.map +1 -1
  88. package/lib/components/VColorPicker/VColorPicker.mjs +10 -12
  89. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  90. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +2 -5
  91. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  92. package/lib/components/VColorPicker/VColorPickerEdit.mjs +3 -3
  93. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  94. package/lib/components/VColorPicker/VColorPickerPreview.mjs +3 -3
  95. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  96. package/lib/components/VColorPicker/VColorPickerSwatches.mjs +1 -1
  97. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  98. package/lib/components/VCombobox/VCombobox.mjs +13 -12
  99. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  100. package/lib/components/VCombobox/index.d.mts +88 -88
  101. package/lib/components/VCounter/VCounter.mjs +2 -2
  102. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  103. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -4
  104. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  105. package/lib/components/VDefaultsProvider/index.d.mts +7 -9
  106. package/lib/components/VDialog/VDialog.mjs +7 -7
  107. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  108. package/lib/components/VDialog/index.d.mts +66 -66
  109. package/lib/components/VDivider/VDivider.mjs +3 -3
  110. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  111. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +5 -5
  112. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  113. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +3 -3
  114. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  115. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +5 -5
  116. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  117. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +3 -3
  118. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  119. package/lib/components/VExpansionPanel/index.d.mts +1 -1
  120. package/lib/components/VField/VField.mjs +8 -8
  121. package/lib/components/VField/VField.mjs.map +1 -1
  122. package/lib/components/VField/VFieldLabel.mjs +1 -1
  123. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  124. package/lib/components/VField/index.d.mts +5 -5
  125. package/lib/components/VFileInput/VFileInput.mjs +5 -5
  126. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  127. package/lib/components/VFileInput/index.d.mts +60 -60
  128. package/lib/components/VFooter/VFooter.mjs +4 -4
  129. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  130. package/lib/components/VForm/VForm.mjs +3 -3
  131. package/lib/components/VForm/VForm.mjs.map +1 -1
  132. package/lib/components/VGrid/VCol.mjs +2 -2
  133. package/lib/components/VGrid/VCol.mjs.map +1 -1
  134. package/lib/components/VGrid/VContainer.mjs +3 -3
  135. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  136. package/lib/components/VGrid/VRow.mjs +2 -2
  137. package/lib/components/VGrid/VRow.mjs.map +1 -1
  138. package/lib/components/VGrid/VSpacer.mjs +1 -0
  139. package/lib/components/VGrid/VSpacer.mjs.map +1 -1
  140. package/lib/components/VHover/VHover.mjs +1 -1
  141. package/lib/components/VHover/VHover.mjs.map +1 -1
  142. package/lib/components/VIcon/VIcon.mjs +4 -4
  143. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  144. package/lib/components/VImg/VImg.mjs +5 -4
  145. package/lib/components/VImg/VImg.mjs.map +1 -1
  146. package/lib/components/VInput/InputIcon.mjs +3 -2
  147. package/lib/components/VInput/InputIcon.mjs.map +1 -1
  148. package/lib/components/VInput/VInput.mjs +8 -4
  149. package/lib/components/VInput/VInput.mjs.map +1 -1
  150. package/lib/components/VInput/index.d.mts +10 -10
  151. package/lib/components/VItemGroup/VItem.mjs +2 -2
  152. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  153. package/lib/components/VItemGroup/VItemGroup.mjs +1 -1
  154. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  155. package/lib/components/VKbd/index.mjs +3 -0
  156. package/lib/components/VKbd/index.mjs.map +1 -1
  157. package/lib/components/VLabel/VLabel.mjs +1 -1
  158. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  159. package/lib/components/VLayout/VLayout.mjs +3 -3
  160. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  161. package/lib/components/VLayout/VLayoutItem.mjs +1 -1
  162. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  163. package/lib/components/VLazy/VLazy.mjs +3 -3
  164. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  165. package/lib/components/VList/VList.css +1 -0
  166. package/lib/components/VList/VList.mjs +5 -4
  167. package/lib/components/VList/VList.mjs.map +1 -1
  168. package/lib/components/VList/VList.sass +1 -0
  169. package/lib/components/VList/VListChildren.mjs +3 -3
  170. package/lib/components/VList/VListChildren.mjs.map +1 -1
  171. package/lib/components/VList/VListGroup.mjs +8 -8
  172. package/lib/components/VList/VListGroup.mjs.map +1 -1
  173. package/lib/components/VList/VListImg.mjs +1 -0
  174. package/lib/components/VList/VListImg.mjs.map +1 -1
  175. package/lib/components/VList/VListItem.css +18 -0
  176. package/lib/components/VList/VListItem.mjs +9 -9
  177. package/lib/components/VList/VListItem.mjs.map +1 -1
  178. package/lib/components/VList/VListItem.sass +12 -0
  179. package/lib/components/VList/VListItemAction.mjs +1 -1
  180. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  181. package/lib/components/VList/VListItemMedia.mjs +1 -1
  182. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  183. package/lib/components/VList/VListItemSubtitle.mjs +1 -0
  184. package/lib/components/VList/VListItemSubtitle.mjs.map +1 -1
  185. package/lib/components/VList/VListItemTitle.mjs +1 -0
  186. package/lib/components/VList/VListItemTitle.mjs.map +1 -1
  187. package/lib/components/VList/VListSubheader.mjs +3 -3
  188. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  189. package/lib/components/VList/index.d.mts +24 -24
  190. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +1 -1
  191. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  192. package/lib/components/VMain/VMain.mjs +3 -3
  193. package/lib/components/VMain/VMain.mjs.map +1 -1
  194. package/lib/components/VMenu/VMenu.mjs +7 -7
  195. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  196. package/lib/components/VMenu/index.d.mts +113 -113
  197. package/lib/components/VMenu/shared.mjs +2 -0
  198. package/lib/components/VMenu/shared.mjs.map +1 -1
  199. package/lib/components/VMessages/VMessages.mjs +3 -3
  200. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  201. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +17 -13
  202. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  203. package/lib/components/VOverlay/VOverlay.mjs +11 -14
  204. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  205. package/lib/components/VOverlay/index.d.mts +21 -21
  206. package/lib/components/VOverlay/locationStrategies.mjs +5 -5
  207. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  208. package/lib/components/VOverlay/scrollStrategies.mjs +3 -3
  209. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  210. package/lib/components/VOverlay/useActivator.mjs +6 -10
  211. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  212. package/lib/components/VOverlay/util/point.mjs +2 -0
  213. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  214. package/lib/components/VPagination/VPagination.mjs +9 -9
  215. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  216. package/lib/components/VParallax/VParallax.mjs +3 -6
  217. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  218. package/lib/components/VProgressCircular/VProgressCircular.mjs +5 -5
  219. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  220. package/lib/components/VProgressLinear/VProgressLinear.mjs +6 -6
  221. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  222. package/lib/components/VRadio/VRadio.mjs +3 -3
  223. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  224. package/lib/components/VRadio/index.d.mts +4 -4
  225. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -4
  226. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  227. package/lib/components/VRadioGroup/index.d.mts +32 -32
  228. package/lib/components/VRangeSlider/VRangeSlider.mjs +4 -4
  229. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  230. package/lib/components/VRangeSlider/index.d.mts +8 -8
  231. package/lib/components/VRating/VRating.mjs +6 -9
  232. package/lib/components/VRating/VRating.mjs.map +1 -1
  233. package/lib/components/VResponsive/VResponsive.css +1 -0
  234. package/lib/components/VResponsive/VResponsive.mjs +1 -1
  235. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  236. package/lib/components/VResponsive/VResponsive.sass +1 -0
  237. package/lib/components/VSelect/VSelect.mjs +9 -9
  238. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  239. package/lib/components/VSelect/index.d.mts +88 -88
  240. package/lib/components/VSelectionControl/VSelectionControl.mjs +7 -7
  241. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  242. package/lib/components/VSelectionControl/index.d.mts +2 -2
  243. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +6 -6
  244. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  245. package/lib/components/VSheet/VSheet.mjs +4 -4
  246. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  247. package/lib/components/VSlideGroup/VSlideGroup.mjs +7 -7
  248. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  249. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +2 -2
  250. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  251. package/lib/components/VSlider/VSlider.mjs +6 -6
  252. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  253. package/lib/components/VSlider/VSliderThumb.mjs +6 -6
  254. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  255. package/lib/components/VSlider/VSliderTrack.mjs +3 -3
  256. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  257. package/lib/components/VSlider/index.d.mts +8 -8
  258. package/lib/components/VSlider/slider.mjs +4 -7
  259. package/lib/components/VSlider/slider.mjs.map +1 -1
  260. package/lib/components/VSnackbar/VSnackbar.mjs +7 -7
  261. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  262. package/lib/components/VSnackbar/index.d.mts +77 -77
  263. package/lib/components/VStepper/index.mjs +3 -2
  264. package/lib/components/VStepper/index.mjs.map +1 -1
  265. package/lib/components/VSwitch/VSwitch.mjs +6 -6
  266. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  267. package/lib/components/VSwitch/index.d.mts +41 -41
  268. package/lib/components/VSystemBar/VSystemBar.mjs +4 -4
  269. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  270. package/lib/components/VTable/VTable.mjs +1 -1
  271. package/lib/components/VTable/VTable.mjs.map +1 -1
  272. package/lib/components/VTabs/VTab.mjs +3 -3
  273. package/lib/components/VTabs/VTab.mjs.map +1 -1
  274. package/lib/components/VTabs/VTabs.mjs +7 -7
  275. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  276. package/lib/components/VTabs/shared.mjs +2 -0
  277. package/lib/components/VTabs/shared.mjs.map +1 -1
  278. package/lib/components/VTextField/VTextField.mjs +6 -6
  279. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  280. package/lib/components/VTextField/index.d.mts +72 -72
  281. package/lib/components/VTextarea/VTextarea.mjs +8 -11
  282. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  283. package/lib/components/VTextarea/index.d.mts +60 -60
  284. package/lib/components/VThemeProvider/VThemeProvider.mjs +1 -1
  285. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  286. package/lib/components/VTimeline/VTimeline.mjs +4 -4
  287. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  288. package/lib/components/VTimeline/VTimelineDivider.mjs +5 -5
  289. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  290. package/lib/components/VTimeline/VTimelineItem.mjs +4 -7
  291. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  292. package/lib/components/VToolbar/VToolbar.mjs +8 -8
  293. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  294. package/lib/components/VToolbar/VToolbarItems.mjs +4 -4
  295. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  296. package/lib/components/VToolbar/VToolbarTitle.mjs +1 -1
  297. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  298. package/lib/components/VToolbar/index.d.mts +1 -1
  299. package/lib/components/VTooltip/VTooltip.mjs +6 -6
  300. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  301. package/lib/components/VTooltip/index.d.mts +113 -113
  302. package/lib/components/VVirtualScroll/VVirtualScroll.mjs +15 -93
  303. package/lib/components/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  304. package/lib/components/VVirtualScroll/VVirtualScrollItem.mjs +9 -4
  305. package/lib/components/VVirtualScroll/VVirtualScrollItem.mjs.map +1 -1
  306. package/lib/components/VVirtualScroll/index.d.mts +9 -9
  307. package/lib/components/VWindow/VWindow.mjs +6 -6
  308. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  309. package/lib/components/VWindow/VWindowItem.mjs +5 -5
  310. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  311. package/lib/components/index.d.mts +1481 -1483
  312. package/lib/components/transitions/createTransition.mjs +5 -8
  313. package/lib/components/transitions/createTransition.mjs.map +1 -1
  314. package/lib/components/transitions/dialog-transition.mjs +1 -3
  315. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  316. package/lib/components/transitions/index.d.mts +117 -117
  317. package/lib/composables/defaults.mjs +5 -0
  318. package/lib/composables/defaults.mjs.map +1 -1
  319. package/lib/composables/display.mjs +1 -1
  320. package/lib/composables/display.mjs.map +1 -1
  321. package/lib/composables/filter.mjs +2 -4
  322. package/lib/composables/filter.mjs.map +1 -1
  323. package/lib/composables/focus.mjs +1 -1
  324. package/lib/composables/focus.mjs.map +1 -1
  325. package/lib/composables/forwardRefs.mjs +2 -0
  326. package/lib/composables/forwardRefs.mjs.map +1 -1
  327. package/lib/composables/hydration.mjs +1 -1
  328. package/lib/composables/hydration.mjs.map +1 -1
  329. package/lib/composables/icons.mjs +7 -1
  330. package/lib/composables/icons.mjs.map +1 -1
  331. package/lib/composables/lazy.mjs +1 -3
  332. package/lib/composables/lazy.mjs.map +1 -1
  333. package/lib/composables/locale.mjs +2 -1
  334. package/lib/composables/locale.mjs.map +1 -1
  335. package/lib/composables/mutationObserver.mjs +2 -5
  336. package/lib/composables/mutationObserver.mjs.map +1 -1
  337. package/lib/composables/nested/nested.mjs +2 -2
  338. package/lib/composables/nested/nested.mjs.map +1 -1
  339. package/lib/composables/nested/selectStrategies.mjs +1 -0
  340. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  341. package/lib/composables/proxiedModel.mjs +3 -3
  342. package/lib/composables/proxiedModel.mjs.map +1 -1
  343. package/lib/composables/refs.mjs +4 -1
  344. package/lib/composables/refs.mjs.map +1 -1
  345. package/lib/composables/resizeObserver.mjs +4 -4
  346. package/lib/composables/resizeObserver.mjs.map +1 -1
  347. package/lib/composables/router.mjs +1 -4
  348. package/lib/composables/router.mjs.map +1 -1
  349. package/lib/composables/scopeId.mjs +1 -0
  350. package/lib/composables/scopeId.mjs.map +1 -1
  351. package/lib/composables/theme.mjs.map +1 -1
  352. package/lib/composables/toggleScope.mjs +4 -0
  353. package/lib/composables/toggleScope.mjs.map +1 -1
  354. package/lib/composables/touch.mjs +1 -0
  355. package/lib/composables/touch.mjs.map +1 -1
  356. package/lib/composables/validation.mjs +2 -2
  357. package/lib/composables/validation.mjs.map +1 -1
  358. package/lib/composables/virtual.mjs +108 -0
  359. package/lib/composables/virtual.mjs.map +1 -0
  360. package/lib/directives/click-outside/index.mjs +2 -1
  361. package/lib/directives/click-outside/index.mjs.map +1 -1
  362. package/lib/directives/intersect/index.mjs +1 -1
  363. package/lib/directives/intersect/index.mjs.map +1 -1
  364. package/lib/directives/resize/index.mjs +2 -0
  365. package/lib/directives/resize/index.mjs.map +1 -1
  366. package/lib/directives/scroll/index.mjs +2 -0
  367. package/lib/directives/scroll/index.mjs.map +1 -1
  368. package/lib/directives/touch/index.mjs +1 -2
  369. package/lib/directives/touch/index.mjs.map +1 -1
  370. package/lib/entry-bundler.mjs +7 -2
  371. package/lib/entry-bundler.mjs.map +1 -1
  372. package/lib/framework.mjs +4 -6
  373. package/lib/framework.mjs.map +1 -1
  374. package/lib/iconsets/fa.mjs +1 -1
  375. package/lib/iconsets/fa.mjs.map +1 -1
  376. package/lib/iconsets/fa4.mjs +4 -3
  377. package/lib/iconsets/fa4.mjs.map +1 -1
  378. package/lib/iconsets/md.mjs +4 -3
  379. package/lib/iconsets/md.mjs.map +1 -1
  380. package/lib/iconsets/mdi-svg.mjs +1 -1
  381. package/lib/iconsets/mdi-svg.mjs.map +1 -1
  382. package/lib/iconsets/mdi.mjs +4 -3
  383. package/lib/iconsets/mdi.mjs.map +1 -1
  384. package/lib/index.d.mts +34 -32
  385. package/lib/labs/VBottomSheet/VBottomSheet.mjs +1 -1
  386. package/lib/labs/VBottomSheet/VBottomSheet.mjs.map +1 -1
  387. package/lib/labs/VBottomSheet/index.d.mts +21 -21
  388. package/lib/labs/VDataIterator/VDataIterator.mjs +7 -7
  389. package/lib/labs/VDataIterator/VDataIterator.mjs.map +1 -1
  390. package/lib/labs/VDataIterator/composables/items.mjs +2 -2
  391. package/lib/labs/VDataIterator/composables/items.mjs.map +1 -1
  392. package/lib/labs/VDataIterator/index.d.mts +28 -27
  393. package/lib/labs/VDataTable/VDataTable.css +1 -0
  394. package/lib/labs/VDataTable/VDataTable.mjs +8 -8
  395. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  396. package/lib/labs/VDataTable/VDataTable.sass +1 -0
  397. package/lib/labs/VDataTable/VDataTableColumn.mjs +2 -1
  398. package/lib/labs/VDataTable/VDataTableColumn.mjs.map +1 -1
  399. package/lib/labs/VDataTable/VDataTableFooter.mjs +3 -3
  400. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  401. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +5 -5
  402. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
  403. package/lib/labs/VDataTable/VDataTableHeaders.mjs +6 -6
  404. package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
  405. package/lib/labs/VDataTable/VDataTableRow.mjs +1 -1
  406. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  407. package/lib/labs/VDataTable/VDataTableRows.mjs +20 -16
  408. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  409. package/lib/labs/VDataTable/VDataTableServer.mjs +7 -7
  410. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  411. package/lib/labs/VDataTable/VDataTableVirtual.mjs +34 -22
  412. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  413. package/lib/labs/VDataTable/composables/expand.mjs +4 -4
  414. package/lib/labs/VDataTable/composables/expand.mjs.map +1 -1
  415. package/lib/labs/VDataTable/composables/group.mjs +1 -1
  416. package/lib/labs/VDataTable/composables/group.mjs.map +1 -1
  417. package/lib/labs/VDataTable/composables/headers.mjs +2 -2
  418. package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
  419. package/lib/labs/VDataTable/composables/items.mjs +5 -8
  420. package/lib/labs/VDataTable/composables/items.mjs.map +1 -1
  421. package/lib/labs/VDataTable/composables/paginate.mjs +1 -1
  422. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  423. package/lib/labs/VDataTable/composables/select.mjs +1 -1
  424. package/lib/labs/VDataTable/composables/select.mjs.map +1 -1
  425. package/lib/labs/VDataTable/composables/sort.mjs +4 -9
  426. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  427. package/lib/labs/VDataTable/index.d.mts +182 -83
  428. package/lib/labs/VDataTable/types.mjs.map +1 -1
  429. package/lib/labs/VInfiniteScroll/VInfiniteScroll.mjs +1 -1
  430. package/lib/labs/VInfiniteScroll/VInfiniteScroll.mjs.map +1 -1
  431. package/lib/labs/VSkeletonLoader/VSkeletonLoader.mjs +4 -4
  432. package/lib/labs/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
  433. package/lib/labs/components.d.mts +213 -114
  434. package/lib/labs/date/date.mjs.map +1 -1
  435. package/lib/labs/entry-bundler.mjs +3 -1
  436. package/lib/labs/entry-bundler.mjs.map +1 -1
  437. package/lib/locale/adapters/vue-i18n.d.mts +1 -1
  438. package/lib/locale/adapters/vue-i18n.mjs +5 -1
  439. package/lib/locale/adapters/vue-i18n.mjs.map +1 -1
  440. package/lib/locale/adapters/vuetify.mjs +1 -3
  441. package/lib/locale/adapters/vuetify.mjs.map +1 -1
  442. package/lib/util/anchor.mjs +1 -0
  443. package/lib/util/anchor.mjs.map +1 -1
  444. package/lib/util/animation.mjs +1 -0
  445. package/lib/util/animation.mjs.map +1 -1
  446. package/lib/util/color/APCA.mjs +1 -0
  447. package/lib/util/color/APCA.mjs.map +1 -1
  448. package/lib/util/color/transformCIELAB.mjs +2 -0
  449. package/lib/util/color/transformCIELAB.mjs.map +1 -1
  450. package/lib/util/color/transformSRGB.mjs +3 -1
  451. package/lib/util/color/transformSRGB.mjs.map +1 -1
  452. package/lib/util/colorUtils.mjs +2 -2
  453. package/lib/util/colorUtils.mjs.map +1 -1
  454. package/lib/util/console.mjs +1 -0
  455. package/lib/util/console.mjs.map +1 -1
  456. package/lib/util/createSimpleFunctional.mjs +2 -1
  457. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  458. package/lib/util/defineComponent.mjs +5 -5
  459. package/lib/util/defineComponent.mjs.map +1 -1
  460. package/lib/util/getCurrentInstance.mjs +1 -2
  461. package/lib/util/getCurrentInstance.mjs.map +1 -1
  462. package/lib/util/helpers.mjs +3 -3
  463. package/lib/util/helpers.mjs.map +1 -1
  464. package/lib/util/injectSelf.mjs +2 -1
  465. package/lib/util/injectSelf.mjs.map +1 -1
  466. package/lib/util/propsFactory.mjs +1 -0
  467. package/lib/util/propsFactory.mjs.map +1 -1
  468. package/package.json +4 -4
  469. package/lib/labs/VDataTable/composables/virtual.mjs +0 -77
  470. package/lib/labs/VDataTable/composables/virtual.mjs.map +0 -1
@@ -61,16 +61,16 @@ declare const VCheckbox: {
61
61
  messages?: string | readonly string[] | undefined;
62
62
  density?: Density | undefined;
63
63
  ripple?: boolean | undefined;
64
+ falseIcon?: NonNullable<IconValue> | undefined;
65
+ trueIcon?: NonNullable<IconValue> | undefined;
66
+ valueComparator?: typeof deepEqual | undefined;
67
+ indeterminateIcon?: IconValue | undefined;
64
68
  focused?: boolean | undefined;
65
- centerAffix?: boolean | undefined;
66
69
  errorMessages?: string | readonly string[] | undefined;
67
70
  maxErrors?: string | number | undefined;
68
71
  rules?: readonly ValidationRule[] | undefined;
72
+ centerAffix?: boolean | undefined;
69
73
  persistentHint?: boolean | undefined;
70
- falseIcon?: NonNullable<IconValue> | undefined;
71
- trueIcon?: NonNullable<IconValue> | undefined;
72
- valueComparator?: typeof deepEqual | undefined;
73
- indeterminateIcon?: IconValue | undefined;
74
74
  type?: string | undefined;
75
75
  key?: string | number | symbol | undefined;
76
76
  id?: string | undefined;
@@ -151,23 +151,23 @@ declare const VCheckbox: {
151
151
  modelValue?: any;
152
152
  prependIcon?: IconValue | undefined;
153
153
  appendIcon?: IconValue | undefined;
154
- 'onClick:append'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
155
- 'onClick:prepend'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
156
- 'onUpdate:focused'?: (EventProp<[boolean], (args_0: boolean) => any> & ((focused: boolean) => any)) | undefined;
154
+ defaultsTarget?: string | undefined;
155
+ trueValue?: any;
156
+ falseValue?: any;
157
+ "v-slot:input"?: false | ((arg: SelectionControlSlot) => vue.VNodeChild) | undefined;
157
158
  "v-slot:label"?: false | ((arg: {
158
159
  label: string | undefined;
159
160
  props: Record<string, unknown>;
160
161
  }) => vue.VNodeChild) | undefined;
162
+ 'onClick:append'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
163
+ 'onClick:prepend'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
161
164
  "v-slot:message"?: false | ((arg: VMessageSlot) => vue.VNodeChild) | undefined;
165
+ 'onUpdate:focused'?: (EventProp<[boolean], (args_0: boolean) => any> & ((focused: boolean) => any)) | undefined;
162
166
  validateOn?: "lazy" | ("input" | "blur" | "submit") | "input lazy" | "blur lazy" | "submit lazy" | "lazy input" | "lazy blur" | "lazy submit" | undefined;
163
167
  validationValue?: any;
164
168
  hint?: string | undefined;
165
169
  hideDetails?: boolean | "auto" | undefined;
166
170
  "v-slot:details"?: false | ((arg: VInputSlot) => vue.VNodeChild) | undefined;
167
- defaultsTarget?: string | undefined;
168
- trueValue?: any;
169
- falseValue?: any;
170
- "v-slot:input"?: false | ((arg: SelectionControlSlot) => vue.VNodeChild) | undefined;
171
171
  };
172
172
  $attrs: {
173
173
  [x: string]: unknown;
@@ -216,16 +216,16 @@ declare const VCheckbox: {
216
216
  messages: string | readonly string[];
217
217
  density: Density;
218
218
  ripple: boolean;
219
+ falseIcon: NonNullable<IconValue>;
220
+ trueIcon: NonNullable<IconValue>;
221
+ valueComparator: typeof deepEqual;
222
+ indeterminateIcon: IconValue;
219
223
  focused: boolean;
220
- centerAffix: boolean;
221
224
  errorMessages: string | readonly string[];
222
225
  maxErrors: string | number;
223
226
  rules: readonly ValidationRule[];
227
+ centerAffix: boolean;
224
228
  persistentHint: boolean;
225
- falseIcon: NonNullable<IconValue>;
226
- trueIcon: NonNullable<IconValue>;
227
- valueComparator: typeof deepEqual;
228
- indeterminateIcon: IconValue;
229
229
  } & {
230
230
  type?: string | undefined;
231
231
  id?: string | undefined;
@@ -238,6 +238,9 @@ declare const VCheckbox: {
238
238
  modelValue?: any;
239
239
  prependIcon?: IconValue | undefined;
240
240
  appendIcon?: IconValue | undefined;
241
+ defaultsTarget?: string | undefined;
242
+ trueValue?: any;
243
+ falseValue?: any;
241
244
  'onClick:append'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
242
245
  'onClick:prepend'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
243
246
  'onUpdate:focused'?: EventProp<[boolean], (args_0: boolean) => any> | undefined;
@@ -245,9 +248,6 @@ declare const VCheckbox: {
245
248
  validationValue?: any;
246
249
  hint?: string | undefined;
247
250
  hideDetails?: boolean | "auto" | undefined;
248
- defaultsTarget?: string | undefined;
249
- trueValue?: any;
250
- falseValue?: any;
251
251
  } & {
252
252
  $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
253
253
  default?: (() => vue.VNodeChild) | undefined;
@@ -299,16 +299,16 @@ declare const VCheckbox: {
299
299
  messages: string | readonly string[];
300
300
  density: Density;
301
301
  ripple: boolean;
302
+ falseIcon: NonNullable<IconValue>;
303
+ trueIcon: NonNullable<IconValue>;
304
+ valueComparator: typeof deepEqual;
305
+ indeterminateIcon: IconValue;
302
306
  focused: boolean;
303
- centerAffix: boolean;
304
307
  errorMessages: string | readonly string[];
305
308
  maxErrors: string | number;
306
309
  rules: readonly ValidationRule[];
310
+ centerAffix: boolean;
307
311
  persistentHint: boolean;
308
- falseIcon: NonNullable<IconValue>;
309
- trueIcon: NonNullable<IconValue>;
310
- valueComparator: typeof deepEqual;
311
- indeterminateIcon: IconValue;
312
312
  }, {}, string, vue.SlotsType<Partial<{
313
313
  default: () => vue.VNode<vue.RendererNode, vue.RendererElement, {
314
314
  [key: string]: any;
@@ -365,16 +365,16 @@ declare const VCheckbox: {
365
365
  messages: string | readonly string[];
366
366
  density: Density;
367
367
  ripple: boolean;
368
+ falseIcon: NonNullable<IconValue>;
369
+ trueIcon: NonNullable<IconValue>;
370
+ valueComparator: typeof deepEqual;
371
+ indeterminateIcon: IconValue;
368
372
  focused: boolean;
369
- centerAffix: boolean;
370
373
  errorMessages: string | readonly string[];
371
374
  maxErrors: string | number;
372
375
  rules: readonly ValidationRule[];
376
+ centerAffix: boolean;
373
377
  persistentHint: boolean;
374
- falseIcon: NonNullable<IconValue>;
375
- trueIcon: NonNullable<IconValue>;
376
- valueComparator: typeof deepEqual;
377
- indeterminateIcon: IconValue;
378
378
  } & {
379
379
  type?: string | undefined;
380
380
  id?: string | undefined;
@@ -387,6 +387,9 @@ declare const VCheckbox: {
387
387
  modelValue?: any;
388
388
  prependIcon?: IconValue | undefined;
389
389
  appendIcon?: IconValue | undefined;
390
+ defaultsTarget?: string | undefined;
391
+ trueValue?: any;
392
+ falseValue?: any;
390
393
  'onClick:append'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
391
394
  'onClick:prepend'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
392
395
  'onUpdate:focused'?: EventProp<[boolean], (args_0: boolean) => any> | undefined;
@@ -394,9 +397,6 @@ declare const VCheckbox: {
394
397
  validationValue?: any;
395
398
  hint?: string | undefined;
396
399
  hideDetails?: boolean | "auto" | undefined;
397
- defaultsTarget?: string | undefined;
398
- trueValue?: any;
399
- falseValue?: any;
400
400
  } & {
401
401
  $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
402
402
  default?: (() => vue.VNodeChild) | undefined;
@@ -450,16 +450,16 @@ declare const VCheckbox: {
450
450
  messages: string | readonly string[];
451
451
  density: Density;
452
452
  ripple: boolean;
453
+ falseIcon: NonNullable<IconValue>;
454
+ trueIcon: NonNullable<IconValue>;
455
+ valueComparator: typeof deepEqual;
456
+ indeterminateIcon: IconValue;
453
457
  focused: boolean;
454
- centerAffix: boolean;
455
458
  errorMessages: string | readonly string[];
456
459
  maxErrors: string | number;
457
460
  rules: readonly ValidationRule[];
461
+ centerAffix: boolean;
458
462
  persistentHint: boolean;
459
- falseIcon: NonNullable<IconValue>;
460
- trueIcon: NonNullable<IconValue>;
461
- valueComparator: typeof deepEqual;
462
- indeterminateIcon: IconValue;
463
463
  } & {
464
464
  type?: string | undefined;
465
465
  id?: string | undefined;
@@ -472,6 +472,9 @@ declare const VCheckbox: {
472
472
  modelValue?: any;
473
473
  prependIcon?: IconValue | undefined;
474
474
  appendIcon?: IconValue | undefined;
475
+ defaultsTarget?: string | undefined;
476
+ trueValue?: any;
477
+ falseValue?: any;
475
478
  'onClick:append'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
476
479
  'onClick:prepend'?: EventProp<[MouseEvent], (args_0: MouseEvent) => any> | undefined;
477
480
  'onUpdate:focused'?: EventProp<[boolean], (args_0: boolean) => any> | undefined;
@@ -479,9 +482,6 @@ declare const VCheckbox: {
479
482
  validationValue?: any;
480
483
  hint?: string | undefined;
481
484
  hideDetails?: boolean | "auto" | undefined;
482
- defaultsTarget?: string | undefined;
483
- trueValue?: any;
484
- falseValue?: any;
485
485
  } & {
486
486
  $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
487
487
  default?: (() => vue.VNodeChild) | undefined;
@@ -533,16 +533,16 @@ declare const VCheckbox: {
533
533
  messages: string | readonly string[];
534
534
  density: Density;
535
535
  ripple: boolean;
536
+ falseIcon: NonNullable<IconValue>;
537
+ trueIcon: NonNullable<IconValue>;
538
+ valueComparator: typeof deepEqual;
539
+ indeterminateIcon: IconValue;
536
540
  focused: boolean;
537
- centerAffix: boolean;
538
541
  errorMessages: string | readonly string[];
539
542
  maxErrors: string | number;
540
543
  rules: readonly ValidationRule[];
544
+ centerAffix: boolean;
541
545
  persistentHint: boolean;
542
- falseIcon: NonNullable<IconValue>;
543
- trueIcon: NonNullable<IconValue>;
544
- valueComparator: typeof deepEqual;
545
- indeterminateIcon: IconValue;
546
546
  }, {}, string, vue.SlotsType<Partial<{
547
547
  default: () => vue.VNode<vue.RendererNode, vue.RendererElement, {
548
548
  [key: string]: any;
@@ -830,14 +830,14 @@ declare const VCheckboxBtn: {
830
830
  }>) => void)[] | undefined;
831
831
  modelValue?: any;
832
832
  "onUpdate:modelValue"?: ((value: any) => any) | undefined;
833
- "v-slot:label"?: false | ((arg: {
834
- label: string | undefined;
835
- props: Record<string, unknown>;
836
- }) => vue.VNodeChild) | undefined;
837
833
  defaultsTarget?: string | undefined;
838
834
  trueValue?: any;
839
835
  falseValue?: any;
840
836
  "v-slot:input"?: false | ((arg: SelectionControlSlot) => vue.VNodeChild) | undefined;
837
+ "v-slot:label"?: false | ((arg: {
838
+ label: string | undefined;
839
+ props: Record<string, unknown>;
840
+ }) => vue.VNodeChild) | undefined;
841
841
  "onUpdate:indeterminate"?: ((val: boolean) => any) | undefined;
842
842
  };
843
843
  $attrs: {
@@ -4,28 +4,28 @@ import { mergeProps as _mergeProps, Fragment as _Fragment, vShow as _vShow, with
4
4
  import "./VChip.css";
5
5
 
6
6
  // Components
7
+ import { VExpandXTransition } from "../transitions/index.mjs";
7
8
  import { VAvatar } from "../VAvatar/index.mjs";
8
9
  import { VChipGroupSymbol } from "../VChipGroup/VChipGroup.mjs";
9
10
  import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
10
- import { VExpandXTransition } from "../transitions/index.mjs";
11
11
  import { VIcon } from "../VIcon/index.mjs"; // Composables
12
- import { genOverlays, makeVariantProps, useVariant } from "../../composables/variant.mjs";
13
- import { IconValue } from "../../composables/icons.mjs";
14
12
  import { makeBorderProps, useBorder } from "../../composables/border.mjs";
15
13
  import { makeComponentProps } from "../../composables/component.mjs";
16
14
  import { makeDensityProps, useDensity } from "../../composables/density.mjs";
17
15
  import { makeElevationProps, useElevation } from "../../composables/elevation.mjs";
18
16
  import { makeGroupItemProps, useGroupItem } from "../../composables/group.mjs";
17
+ import { IconValue } from "../../composables/icons.mjs";
18
+ import { useLocale } from "../../composables/locale.mjs";
19
+ import { useProxiedModel } from "../../composables/proxiedModel.mjs";
19
20
  import { makeRoundedProps, useRounded } from "../../composables/rounded.mjs";
20
21
  import { makeRouterProps, useLink } from "../../composables/router.mjs";
21
22
  import { makeSizeProps, useSize } from "../../composables/size.mjs";
22
23
  import { makeTagProps } from "../../composables/tag.mjs";
23
24
  import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
24
- import { useLocale } from "../../composables/locale.mjs";
25
- import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Directives
25
+ import { genOverlays, makeVariantProps, useVariant } from "../../composables/variant.mjs"; // Directives
26
26
  import { Ripple } from "../../directives/ripple/index.mjs"; // Utilities
27
- import { EventProp, genericComponent, propsFactory } from "../../util/index.mjs";
28
27
  import { computed } from 'vue';
28
+ import { EventProp, genericComponent, propsFactory } from "../../util/index.mjs";
29
29
  export const makeVChipProps = propsFactory({
30
30
  activeClass: String,
31
31
  appendAvatar: String,
@@ -79,7 +79,7 @@ export const makeVChipProps = propsFactory({
79
79
  ...makeVariantProps({
80
80
  variant: 'tonal'
81
81
  })
82
- }, 'v-chip');
82
+ }, 'VChip');
83
83
  export const VChip = genericComponent()({
84
84
  name: 'VChip',
85
85
  directives: {
@@ -1 +1 @@
1
- {"version":3,"file":"VChip.mjs","names":["VAvatar","VChipGroupSymbol","VDefaultsProvider","VExpandXTransition","VIcon","genOverlays","makeVariantProps","useVariant","IconValue","makeBorderProps","useBorder","makeComponentProps","makeDensityProps","useDensity","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","useLocale","useProxiedModel","Ripple","EventProp","genericComponent","propsFactory","computed","makeVChipProps","activeClass","String","appendAvatar","appendIcon","closable","Boolean","closeIcon","type","default","closeLabel","draggable","filter","filterIcon","label","link","undefined","pill","prependAvatar","prependIcon","ripple","text","modelValue","onClick","onClickOnce","tag","variant","VChip","name","directives","props","emits","e","value","val","click","setup","_ref","attrs","emit","slots","t","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","elevationClasses","roundedClasses","sizeClasses","themeClasses","isActive","group","isLink","isClickable","disabled","closeProps","navigate","toggle","onKeyDown","key","preventDefault","Tag","hasAppendMedia","hasAppend","append","hasClose","close","hasFilter","hasPrependMedia","hasPrepend","prepend","hasColor","isSelected","_withDirectives","_createVNode","selectedClass","class","style","href","icon","_resolveDirective","_vShow","_Fragment","image","start","select","end","_mergeProps","size"],"sources":["../../../src/components/VChip/VChip.tsx"],"sourcesContent":["/* eslint-disable complexity */\n// Styles\nimport './VChip.sass'\n\n// Components\nimport { VAvatar } from '@/components/VAvatar'\nimport { VChipGroupSymbol } from '@/components/VChipGroup/VChipGroup'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VExpandXTransition } from '@/components/transitions'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeComponentProps } from '@/composables/component'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Utilities\nimport { EventProp, genericComponent, propsFactory } from '@/util'\nimport { computed } from 'vue'\n\nexport type VChipSlots = {\n default: {\n isSelected: boolean | undefined\n selectedClass: boolean | (string | undefined)[] | undefined\n select: ((value: boolean) => void) | undefined\n toggle: (() => void) | undefined\n value: unknown\n disabled: boolean\n }\n label: never\n prepend: never\n append: never\n close: never\n filter: never\n}\n\nexport const makeVChipProps = propsFactory({\n activeClass: String,\n appendAvatar: String,\n appendIcon: IconValue,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$delete',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n draggable: Boolean,\n filter: Boolean,\n filterIcon: {\n type: String,\n default: '$complete',\n },\n label: Boolean,\n link: {\n type: Boolean,\n default: undefined,\n },\n pill: Boolean,\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: {\n type: Boolean,\n default: true,\n },\n text: String,\n modelValue: {\n type: Boolean,\n default: true,\n },\n\n onClick: EventProp<[MouseEvent]>(),\n onClickOnce: EventProp<[MouseEvent]>(),\n\n ...makeBorderProps(),\n ...makeComponentProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'span' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'v-chip')\n\nexport const VChip = genericComponent<VChipSlots>()({\n name: 'VChip',\n\n directives: { Ripple },\n\n props: makeVChipProps(),\n\n emits: {\n 'click:close': (e: MouseEvent) => true,\n 'update:modelValue': (value: boolean) => true,\n 'group:selected': (val: { value: boolean }) => true,\n click: (e: MouseEvent | KeyboardEvent) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses } = useSize(props)\n const { themeClasses } = provideTheme(props)\n\n const isActive = useProxiedModel(props, 'modelValue')\n const group = useGroupItem(props, VChipGroupSymbol, false)\n const link = useLink(props, attrs)\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (!!group || props.link || link.isClickable.value)\n )\n const closeProps = computed(() => ({\n 'aria-label': t(props.closeLabel),\n onClick (e: MouseEvent) {\n isActive.value = false\n\n emit('click:close', e)\n },\n }))\n\n function onClick (e: MouseEvent) {\n emit('click', e)\n\n if (!isClickable.value) return\n\n link.navigate?.(e)\n group?.toggle()\n }\n\n function onKeyDown (e: KeyboardEvent) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onClick(e as any as MouseEvent)\n }\n }\n\n return () => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasAppendMedia = !!(props.appendIcon || props.appendAvatar)\n const hasAppend = !!(hasAppendMedia || slots.append)\n const hasClose = !!(slots.close || props.closable)\n const hasFilter = !!(slots.filter || props.filter) && group\n const hasPrependMedia = !!(props.prependIcon || props.prependAvatar)\n const hasPrepend = !!(hasPrependMedia || slots.prepend)\n const hasColor = !group || group.isSelected.value\n\n return isActive.value && (\n <Tag\n class={[\n 'v-chip',\n {\n 'v-chip--disabled': props.disabled,\n 'v-chip--label': props.label,\n 'v-chip--link': isClickable.value,\n 'v-chip--filter': hasFilter,\n 'v-chip--pill': props.pill,\n },\n themeClasses.value,\n borderClasses.value,\n hasColor ? colorClasses.value : undefined,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n group?.selectedClass.value,\n props.class,\n ]}\n style={[\n hasColor ? colorStyles.value : undefined,\n props.style,\n ]}\n disabled={ props.disabled || undefined }\n draggable={ props.draggable }\n href={ link.href.value }\n tabindex={ isClickable.value ? 0 : undefined }\n onClick={ onClick }\n onKeydown={ isClickable.value && !isLink.value && onKeyDown }\n v-ripple={[isClickable.value && props.ripple, null]}\n >\n { genOverlays(isClickable.value, 'v-chip') }\n\n { hasFilter && (\n <VExpandXTransition key=\"filter\">\n <div\n class=\"v-chip__filter\"\n v-show={ group.isSelected.value }\n >\n { !slots.filter ? (\n <VIcon\n key=\"filter-icon\"\n icon={ props.filterIcon }\n />\n ) : (\n <VDefaultsProvider\n key=\"filter-defaults\"\n disabled={ !props.filterIcon }\n defaults={{\n VIcon: { icon: props.filterIcon },\n }}\n v-slot:default={ slots.filter }\n />\n )}\n </div>\n </VExpandXTransition>\n )}\n\n { hasPrepend && (\n <div key=\"prepend\" class=\"v-chip__prepend\">\n { !slots.prepend ? (\n <>\n { props.prependIcon && (\n <VIcon\n key=\"prepend-icon\"\n icon={ props.prependIcon }\n start\n />\n )}\n\n { props.prependAvatar && (\n <VAvatar\n key=\"prepend-avatar\"\n image={ props.prependAvatar }\n start\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"prepend-defaults\"\n disabled={ !hasPrependMedia }\n defaults={{\n VAvatar: {\n image: props.prependAvatar,\n start: true,\n },\n VIcon: {\n icon: props.prependIcon,\n start: true,\n },\n }}\n v-slots:default={ slots.prepend }\n />\n )}\n </div>\n )}\n\n <div class=\"v-chip__content\">\n { slots.default?.({\n isSelected: group?.isSelected.value,\n selectedClass: group?.selectedClass.value,\n select: group?.select,\n toggle: group?.toggle,\n value: group?.value.value,\n disabled: props.disabled,\n }) ?? props.text }\n </div>\n\n { hasAppend && (\n <div key=\"append\" class=\"v-chip__append\">\n { !slots.append ? (\n <>\n { props.appendIcon && (\n <VIcon\n key=\"append-icon\"\n end\n icon={ props.appendIcon }\n />\n )}\n\n { props.appendAvatar && (\n <VAvatar\n key=\"append-avatar\"\n end\n image={ props.appendAvatar }\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"append-defaults\"\n disabled={ !hasAppendMedia }\n defaults={{\n VAvatar: {\n end: true,\n image: props.appendAvatar,\n },\n VIcon: {\n end: true,\n icon: props.appendIcon,\n },\n }}\n v-slots:default={ slots.append }\n />\n )}\n </div>\n )}\n\n { hasClose && (\n <div\n key=\"close\"\n class=\"v-chip__close\"\n { ...closeProps.value }\n >\n { !slots.close ? (\n <VIcon\n key=\"close-icon\"\n icon={ props.closeIcon }\n size=\"x-small\"\n />\n ) : (\n <VDefaultsProvider\n key=\"close-defaults\"\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'x-small',\n },\n }}\n v-slots:default={ slots.close }\n />\n )}\n </div>\n )}\n </Tag>\n )\n }\n },\n})\n\nexport type VChip = InstanceType<typeof VChip>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VChip.mjs","names":["VExpandXTransition","VAvatar","VChipGroupSymbol","VDefaultsProvider","VIcon","makeBorderProps","useBorder","makeComponentProps","makeDensityProps","useDensity","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","IconValue","useLocale","useProxiedModel","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","genOverlays","makeVariantProps","useVariant","Ripple","computed","EventProp","genericComponent","propsFactory","makeVChipProps","activeClass","String","appendAvatar","appendIcon","closable","Boolean","closeIcon","type","default","closeLabel","draggable","filter","filterIcon","label","link","undefined","pill","prependAvatar","prependIcon","ripple","text","modelValue","onClick","onClickOnce","tag","variant","VChip","name","directives","props","emits","e","value","val","click","setup","_ref","attrs","emit","slots","t","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","elevationClasses","roundedClasses","sizeClasses","themeClasses","isActive","group","isLink","isClickable","disabled","closeProps","navigate","toggle","onKeyDown","key","preventDefault","Tag","hasAppendMedia","hasAppend","append","hasClose","close","hasFilter","hasPrependMedia","hasPrepend","prepend","hasColor","isSelected","_withDirectives","_createVNode","selectedClass","class","style","href","icon","_resolveDirective","_vShow","_Fragment","image","start","select","end","_mergeProps","size"],"sources":["../../../src/components/VChip/VChip.tsx"],"sourcesContent":["/* eslint-disable complexity */\n// Styles\nimport './VChip.sass'\n\n// Components\nimport { VExpandXTransition } from '@/components/transitions'\nimport { VAvatar } from '@/components/VAvatar'\nimport { VChipGroupSymbol } from '@/components/VChipGroup/VChipGroup'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeComponentProps } from '@/composables/component'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { IconValue } from '@/composables/icons'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Utilities\nimport { computed } from 'vue'\nimport { EventProp, genericComponent, propsFactory } from '@/util'\n\nexport type VChipSlots = {\n default: {\n isSelected: boolean | undefined\n selectedClass: boolean | (string | undefined)[] | undefined\n select: ((value: boolean) => void) | undefined\n toggle: (() => void) | undefined\n value: unknown\n disabled: boolean\n }\n label: never\n prepend: never\n append: never\n close: never\n filter: never\n}\n\nexport const makeVChipProps = propsFactory({\n activeClass: String,\n appendAvatar: String,\n appendIcon: IconValue,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$delete',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n draggable: Boolean,\n filter: Boolean,\n filterIcon: {\n type: String,\n default: '$complete',\n },\n label: Boolean,\n link: {\n type: Boolean,\n default: undefined,\n },\n pill: Boolean,\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: {\n type: Boolean,\n default: true,\n },\n text: String,\n modelValue: {\n type: Boolean,\n default: true,\n },\n\n onClick: EventProp<[MouseEvent]>(),\n onClickOnce: EventProp<[MouseEvent]>(),\n\n ...makeBorderProps(),\n ...makeComponentProps(),\n ...makeDensityProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'span' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChip')\n\nexport const VChip = genericComponent<VChipSlots>()({\n name: 'VChip',\n\n directives: { Ripple },\n\n props: makeVChipProps(),\n\n emits: {\n 'click:close': (e: MouseEvent) => true,\n 'update:modelValue': (value: boolean) => true,\n 'group:selected': (val: { value: boolean }) => true,\n click: (e: MouseEvent | KeyboardEvent) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses } = useSize(props)\n const { themeClasses } = provideTheme(props)\n\n const isActive = useProxiedModel(props, 'modelValue')\n const group = useGroupItem(props, VChipGroupSymbol, false)\n const link = useLink(props, attrs)\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (!!group || props.link || link.isClickable.value)\n )\n const closeProps = computed(() => ({\n 'aria-label': t(props.closeLabel),\n onClick (e: MouseEvent) {\n isActive.value = false\n\n emit('click:close', e)\n },\n }))\n\n function onClick (e: MouseEvent) {\n emit('click', e)\n\n if (!isClickable.value) return\n\n link.navigate?.(e)\n group?.toggle()\n }\n\n function onKeyDown (e: KeyboardEvent) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onClick(e as any as MouseEvent)\n }\n }\n\n return () => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasAppendMedia = !!(props.appendIcon || props.appendAvatar)\n const hasAppend = !!(hasAppendMedia || slots.append)\n const hasClose = !!(slots.close || props.closable)\n const hasFilter = !!(slots.filter || props.filter) && group\n const hasPrependMedia = !!(props.prependIcon || props.prependAvatar)\n const hasPrepend = !!(hasPrependMedia || slots.prepend)\n const hasColor = !group || group.isSelected.value\n\n return isActive.value && (\n <Tag\n class={[\n 'v-chip',\n {\n 'v-chip--disabled': props.disabled,\n 'v-chip--label': props.label,\n 'v-chip--link': isClickable.value,\n 'v-chip--filter': hasFilter,\n 'v-chip--pill': props.pill,\n },\n themeClasses.value,\n borderClasses.value,\n hasColor ? colorClasses.value : undefined,\n densityClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n group?.selectedClass.value,\n props.class,\n ]}\n style={[\n hasColor ? colorStyles.value : undefined,\n props.style,\n ]}\n disabled={ props.disabled || undefined }\n draggable={ props.draggable }\n href={ link.href.value }\n tabindex={ isClickable.value ? 0 : undefined }\n onClick={ onClick }\n onKeydown={ isClickable.value && !isLink.value && onKeyDown }\n v-ripple={[isClickable.value && props.ripple, null]}\n >\n { genOverlays(isClickable.value, 'v-chip') }\n\n { hasFilter && (\n <VExpandXTransition key=\"filter\">\n <div\n class=\"v-chip__filter\"\n v-show={ group.isSelected.value }\n >\n { !slots.filter ? (\n <VIcon\n key=\"filter-icon\"\n icon={ props.filterIcon }\n />\n ) : (\n <VDefaultsProvider\n key=\"filter-defaults\"\n disabled={ !props.filterIcon }\n defaults={{\n VIcon: { icon: props.filterIcon },\n }}\n v-slot:default={ slots.filter }\n />\n )}\n </div>\n </VExpandXTransition>\n )}\n\n { hasPrepend && (\n <div key=\"prepend\" class=\"v-chip__prepend\">\n { !slots.prepend ? (\n <>\n { props.prependIcon && (\n <VIcon\n key=\"prepend-icon\"\n icon={ props.prependIcon }\n start\n />\n )}\n\n { props.prependAvatar && (\n <VAvatar\n key=\"prepend-avatar\"\n image={ props.prependAvatar }\n start\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"prepend-defaults\"\n disabled={ !hasPrependMedia }\n defaults={{\n VAvatar: {\n image: props.prependAvatar,\n start: true,\n },\n VIcon: {\n icon: props.prependIcon,\n start: true,\n },\n }}\n v-slots:default={ slots.prepend }\n />\n )}\n </div>\n )}\n\n <div class=\"v-chip__content\">\n { slots.default?.({\n isSelected: group?.isSelected.value,\n selectedClass: group?.selectedClass.value,\n select: group?.select,\n toggle: group?.toggle,\n value: group?.value.value,\n disabled: props.disabled,\n }) ?? props.text }\n </div>\n\n { hasAppend && (\n <div key=\"append\" class=\"v-chip__append\">\n { !slots.append ? (\n <>\n { props.appendIcon && (\n <VIcon\n key=\"append-icon\"\n end\n icon={ props.appendIcon }\n />\n )}\n\n { props.appendAvatar && (\n <VAvatar\n key=\"append-avatar\"\n end\n image={ props.appendAvatar }\n />\n )}\n </>\n ) : (\n <VDefaultsProvider\n key=\"append-defaults\"\n disabled={ !hasAppendMedia }\n defaults={{\n VAvatar: {\n end: true,\n image: props.appendAvatar,\n },\n VIcon: {\n end: true,\n icon: props.appendIcon,\n },\n }}\n v-slots:default={ slots.append }\n />\n )}\n </div>\n )}\n\n { hasClose && (\n <div\n key=\"close\"\n class=\"v-chip__close\"\n { ...closeProps.value }\n >\n { !slots.close ? (\n <VIcon\n key=\"close-icon\"\n icon={ props.closeIcon }\n size=\"x-small\"\n />\n ) : (\n <VDefaultsProvider\n key=\"close-defaults\"\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'x-small',\n },\n }}\n v-slots:default={ slots.close }\n />\n )}\n </div>\n )}\n </Tag>\n )\n }\n },\n})\n\nexport type VChip = InstanceType<typeof VChip>\n"],"mappings":"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"}
@@ -4,16 +4,13 @@ import "./VChipGroup.css";
4
4
 
5
5
  // Composables
6
6
  import { makeComponentProps } from "../../composables/component.mjs";
7
+ import { provideDefaults } from "../../composables/defaults.mjs";
7
8
  import { makeGroupProps, useGroup } from "../../composables/group.mjs";
8
9
  import { makeTagProps } from "../../composables/tag.mjs";
9
10
  import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
10
- import { makeVariantProps } from "../../composables/variant.mjs";
11
- import { provideDefaults } from "../../composables/defaults.mjs"; // Utilities
12
- import { deepEqual, genericComponent, propsFactory, useRender } from "../../util/index.mjs";
11
+ import { makeVariantProps } from "../../composables/variant.mjs"; // Utilities
13
12
  import { toRef } from 'vue';
14
-
15
- // Types
16
-
13
+ import { deepEqual, genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
17
14
  export const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group');
18
15
  export const makeVChipGroupProps = propsFactory({
19
16
  column: Boolean,
@@ -31,7 +28,7 @@ export const makeVChipGroupProps = propsFactory({
31
28
  ...makeVariantProps({
32
29
  variant: 'tonal'
33
30
  })
34
- }, 'v-chip-group');
31
+ }, 'VChipGroup');
35
32
  export const VChipGroup = genericComponent()({
36
33
  name: 'VChipGroup',
37
34
  props: makeVChipGroupProps(),
@@ -1 +1 @@
1
- {"version":3,"file":"VChipGroup.mjs","names":["makeComponentProps","makeGroupProps","useGroup","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","provideDefaults","deepEqual","genericComponent","propsFactory","useRender","toRef","VChipGroupSymbol","Symbol","for","makeVChipGroupProps","column","Boolean","filter","valueComparator","type","Function","default","selectedClass","variant","VChipGroup","name","props","emits","value","setup","_ref","slots","themeClasses","isSelected","select","next","prev","selected","VChip","color","disabled","_createVNode","tag","class","style"],"sources":["../../../src/components/VChipGroup/VChipGroup.tsx"],"sourcesContent":["// Styles\nimport './VChipGroup.sass'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { makeGroupProps, useGroup } from '@/composables/group'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utilities\nimport { deepEqual, genericComponent, propsFactory, useRender } from '@/util'\nimport { toRef } from 'vue'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group')\n\nexport const makeVChipGroupProps = propsFactory({\n column: Boolean,\n filter: Boolean,\n valueComparator: {\n type: Function as PropType<typeof deepEqual>,\n default: deepEqual,\n },\n\n ...makeComponentProps(),\n ...makeGroupProps({ selectedClass: 'v-chip--selected' }),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'v-chip-group')\n\ntype VChipGroupSlots = {\n default: {\n isSelected: (id: number) => boolean\n select: (id: number, value: boolean) => void\n next: () => void\n prev: () => void\n selected: readonly number[]\n }\n}\n\nexport const VChipGroup = genericComponent<VChipGroupSlots>()({\n name: 'VChipGroup',\n\n props: makeVChipGroupProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { isSelected, select, next, prev, selected } = useGroup(props, VChipGroupSymbol)\n\n provideDefaults({\n VChip: {\n color: toRef(props, 'color'),\n disabled: toRef(props, 'disabled'),\n filter: toRef(props, 'filter'),\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => (\n <props.tag\n class={[\n 'v-chip-group',\n {\n 'v-chip-group--column': props.column,\n },\n themeClasses.value,\n props.class,\n ]}\n style={ props.style }\n >\n { slots.default?.({\n isSelected,\n select,\n next,\n prev,\n selected: selected.value,\n })}\n </props.tag>\n ))\n\n return {}\n },\n})\n\nexport type VChipGroup = InstanceType<typeof VChipGroup>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,kBAAkB;AAAA,SAClBC,cAAc,EAAEC,QAAQ;AAAA,SACxBC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB;AAAA,SAChBC,eAAe,0CAExB;AAAA,SACSC,SAAS,EAAEC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS;AAC7D,SAASC,KAAK,QAAQ,KAAK;;AAE3B;;AAGA,OAAO,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAElE,OAAO,MAAMC,mBAAmB,GAAGN,YAAY,CAAC;EAC9CO,MAAM,EAAEC,OAAO;EACfC,MAAM,EAAED,OAAO;EACfE,eAAe,EAAE;IACfC,IAAI,EAAEC,QAAsC;IAC5CC,OAAO,EAAEf;EACX,CAAC;EAED,GAAGR,kBAAkB,EAAE;EACvB,GAAGC,cAAc,CAAC;IAAEuB,aAAa,EAAE;EAAmB,CAAC,CAAC;EACxD,GAAGrB,YAAY,EAAE;EACjB,GAAGC,cAAc,EAAE;EACnB,GAAGE,gBAAgB,CAAC;IAAEmB,OAAO,EAAE;EAAQ,CAAC;AAC1C,CAAC,EAAE,cAAc,CAAC;AAYlB,OAAO,MAAMC,UAAU,GAAGjB,gBAAgB,EAAmB,CAAC;EAC5DkB,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAEZ,mBAAmB,EAAE;EAE5Ba,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAKA,CAAEH,KAAK,EAAAI,IAAA,EAAa;IAAA,IAAX;MAAEC;IAAM,CAAC,GAAAD,IAAA;IACrB,MAAM;MAAEE;IAAa,CAAC,GAAG7B,YAAY,CAACuB,KAAK,CAAC;IAC5C,MAAM;MAAEO,UAAU;MAAEC,MAAM;MAAEC,IAAI;MAAEC,IAAI;MAAEC;IAAS,CAAC,GAAGrC,QAAQ,CAAC0B,KAAK,EAAEf,gBAAgB,CAAC;IAEtFN,eAAe,CAAC;MACdiC,KAAK,EAAE;QACLC,KAAK,EAAE7B,KAAK,CAACgB,KAAK,EAAE,OAAO,CAAC;QAC5Bc,QAAQ,EAAE9B,KAAK,CAACgB,KAAK,EAAE,UAAU,CAAC;QAClCT,MAAM,EAAEP,KAAK,CAACgB,KAAK,EAAE,QAAQ,CAAC;QAC9BH,OAAO,EAAEb,KAAK,CAACgB,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFjB,SAAS,CAAC,MAAAgC,YAAA,CAAAf,KAAA,CAAAgB,GAAA;MAAA,SAEC,CACL,cAAc,EACd;QACE,sBAAsB,EAAEhB,KAAK,CAACX;MAChC,CAAC,EACDiB,YAAY,CAACJ,KAAK,EAClBF,KAAK,CAACiB,KAAK,CACZ;MAAA,SACOjB,KAAK,CAACkB;IAAK;MAAAvB,OAAA,EAAAA,CAAA,MAEjBU,KAAK,CAACV,OAAO,GAAG;QAChBY,UAAU;QACVC,MAAM;QACNC,IAAI;QACJC,IAAI;QACJC,QAAQ,EAAEA,QAAQ,CAACT;MACrB,CAAC,CAAC;IAAA,EAEL,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
1
+ {"version":3,"file":"VChipGroup.mjs","names":["makeComponentProps","provideDefaults","makeGroupProps","useGroup","makeTagProps","makeThemeProps","provideTheme","makeVariantProps","toRef","deepEqual","genericComponent","propsFactory","useRender","VChipGroupSymbol","Symbol","for","makeVChipGroupProps","column","Boolean","filter","valueComparator","type","Function","default","selectedClass","variant","VChipGroup","name","props","emits","value","setup","_ref","slots","themeClasses","isSelected","select","next","prev","selected","VChip","color","disabled","_createVNode","tag","class","style"],"sources":["../../../src/components/VChipGroup/VChipGroup.tsx"],"sourcesContent":["// Styles\nimport './VChipGroup.sass'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { provideDefaults } from '@/composables/defaults'\nimport { makeGroupProps, useGroup } from '@/composables/group'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { makeVariantProps } from '@/composables/variant'\n\n// Utilities\nimport { toRef } from 'vue'\nimport { deepEqual, genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VChipGroupSymbol = Symbol.for('vuetify:v-chip-group')\n\nexport const makeVChipGroupProps = propsFactory({\n column: Boolean,\n filter: Boolean,\n valueComparator: {\n type: Function as PropType<typeof deepEqual>,\n default: deepEqual,\n },\n\n ...makeComponentProps(),\n ...makeGroupProps({ selectedClass: 'v-chip--selected' }),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'tonal' } as const),\n}, 'VChipGroup')\n\ntype VChipGroupSlots = {\n default: {\n isSelected: (id: number) => boolean\n select: (id: number, value: boolean) => void\n next: () => void\n prev: () => void\n selected: readonly number[]\n }\n}\n\nexport const VChipGroup = genericComponent<VChipGroupSlots>()({\n name: 'VChipGroup',\n\n props: makeVChipGroupProps(),\n\n emits: {\n 'update:modelValue': (value: any) => true,\n },\n\n setup (props, { slots }) {\n const { themeClasses } = provideTheme(props)\n const { isSelected, select, next, prev, selected } = useGroup(props, VChipGroupSymbol)\n\n provideDefaults({\n VChip: {\n color: toRef(props, 'color'),\n disabled: toRef(props, 'disabled'),\n filter: toRef(props, 'filter'),\n variant: toRef(props, 'variant'),\n },\n })\n\n useRender(() => (\n <props.tag\n class={[\n 'v-chip-group',\n {\n 'v-chip-group--column': props.column,\n },\n themeClasses.value,\n props.class,\n ]}\n style={ props.style }\n >\n { slots.default?.({\n isSelected,\n select,\n next,\n prev,\n selected: selected.value,\n })}\n </props.tag>\n ))\n\n return {}\n },\n})\n\nexport type VChipGroup = InstanceType<typeof VChipGroup>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,kBAAkB;AAAA,SAClBC,eAAe;AAAA,SACfC,cAAc,EAAEC,QAAQ;AAAA,SACxBC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,gBAAgB,yCAEzB;AACA,SAASC,KAAK,QAAQ,KAAK;AAAA,SAClBC,SAAS,EAAEC,gBAAgB,EAAEC,YAAY,EAAEC,SAAS,gCAE7D;AAGA,OAAO,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,GAAG,CAAC,sBAAsB,CAAC;AAElE,OAAO,MAAMC,mBAAmB,GAAGL,YAAY,CAAC;EAC9CM,MAAM,EAAEC,OAAO;EACfC,MAAM,EAAED,OAAO;EACfE,eAAe,EAAE;IACfC,IAAI,EAAEC,QAAsC;IAC5CC,OAAO,EAAEd;EACX,CAAC;EAED,GAAGT,kBAAkB,EAAE;EACvB,GAAGE,cAAc,CAAC;IAAEsB,aAAa,EAAE;EAAmB,CAAC,CAAC;EACxD,GAAGpB,YAAY,EAAE;EACjB,GAAGC,cAAc,EAAE;EACnB,GAAGE,gBAAgB,CAAC;IAAEkB,OAAO,EAAE;EAAQ,CAAC;AAC1C,CAAC,EAAE,YAAY,CAAC;AAYhB,OAAO,MAAMC,UAAU,GAAGhB,gBAAgB,EAAmB,CAAC;EAC5DiB,IAAI,EAAE,YAAY;EAElBC,KAAK,EAAEZ,mBAAmB,EAAE;EAE5Ba,KAAK,EAAE;IACL,mBAAmB,EAAGC,KAAU,IAAK;EACvC,CAAC;EAEDC,KAAKA,CAAEH,KAAK,EAAAI,IAAA,EAAa;IAAA,IAAX;MAAEC;IAAM,CAAC,GAAAD,IAAA;IACrB,MAAM;MAAEE;IAAa,CAAC,GAAG5B,YAAY,CAACsB,KAAK,CAAC;IAC5C,MAAM;MAAEO,UAAU;MAAEC,MAAM;MAAEC,IAAI;MAAEC,IAAI;MAAEC;IAAS,CAAC,GAAGpC,QAAQ,CAACyB,KAAK,EAAEf,gBAAgB,CAAC;IAEtFZ,eAAe,CAAC;MACduC,KAAK,EAAE;QACLC,KAAK,EAAEjC,KAAK,CAACoB,KAAK,EAAE,OAAO,CAAC;QAC5Bc,QAAQ,EAAElC,KAAK,CAACoB,KAAK,EAAE,UAAU,CAAC;QAClCT,MAAM,EAAEX,KAAK,CAACoB,KAAK,EAAE,QAAQ,CAAC;QAC9BH,OAAO,EAAEjB,KAAK,CAACoB,KAAK,EAAE,SAAS;MACjC;IACF,CAAC,CAAC;IAEFhB,SAAS,CAAC,MAAA+B,YAAA,CAAAf,KAAA,CAAAgB,GAAA;MAAA,SAEC,CACL,cAAc,EACd;QACE,sBAAsB,EAAEhB,KAAK,CAACX;MAChC,CAAC,EACDiB,YAAY,CAACJ,KAAK,EAClBF,KAAK,CAACiB,KAAK,CACZ;MAAA,SACOjB,KAAK,CAACkB;IAAK;MAAAvB,OAAA,EAAAA,CAAA,MAEjBU,KAAK,CAACV,OAAO,GAAG;QAChBY,UAAU;QACVC,MAAM;QACNC,IAAI;QACJC,IAAI;QACJC,QAAQ,EAAEA,QAAQ,CAACT;MACrB,CAAC,CAAC;IAAA,EAEL,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
@@ -1,4 +1,7 @@
1
+ // Styles
1
2
  import "./VCode.css";
3
+
4
+ // Utilities
2
5
  import { createSimpleFunctional } from "../../util/index.mjs";
3
6
  export const VCode = createSimpleFunctional('v-code');
4
7
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","names":["createSimpleFunctional","VCode"],"sources":["../../../src/components/VCode/index.ts"],"sourcesContent":["import './VCode.sass'\n\nimport { createSimpleFunctional } from '@/util'\n\nexport const VCode = createSimpleFunctional('v-code')\n\nexport type VCode = InstanceType<typeof VCode>\n"],"mappings":"AAAA;AAAqB,SAEZA,sBAAsB;AAE/B,OAAO,MAAMC,KAAK,GAAGD,sBAAsB,CAAC,QAAQ,CAAC"}
1
+ {"version":3,"file":"index.mjs","names":["createSimpleFunctional","VCode"],"sources":["../../../src/components/VCode/index.ts"],"sourcesContent":["// Styles\nimport './VCode.sass'\n\n// Utilities\nimport { createSimpleFunctional } from '@/util'\n\nexport const VCode = createSimpleFunctional('v-code')\n\nexport type VCode = InstanceType<typeof VCode>\n"],"mappings":"AAAA;AACA;;AAEA;AAAA,SACSA,sBAAsB;AAE/B,OAAO,MAAMC,KAAK,GAAGD,sBAAsB,CAAC,QAAQ,CAAC"}
@@ -3,21 +3,18 @@ import { mergeProps as _mergeProps, createVNode as _createVNode } from "vue";
3
3
  import "./VColorPicker.css";
4
4
 
5
5
  // Components
6
- import { makeVSheetProps, VSheet } from "../VSheet/VSheet.mjs";
7
6
  import { VColorPickerCanvas } from "./VColorPickerCanvas.mjs";
8
7
  import { VColorPickerEdit } from "./VColorPickerEdit.mjs";
9
8
  import { VColorPickerPreview } from "./VColorPickerPreview.mjs";
10
- import { VColorPickerSwatches } from "./VColorPickerSwatches.mjs"; // Composables
11
- import { useProxiedModel } from "../../composables/proxiedModel.mjs";
9
+ import { VColorPickerSwatches } from "./VColorPickerSwatches.mjs";
10
+ import { makeVSheetProps, VSheet } from "../VSheet/VSheet.mjs"; // Composables
12
11
  import { provideDefaults } from "../../composables/defaults.mjs";
13
- import { useRtl } from "../../composables/locale.mjs"; // Utilities
14
- import { consoleWarn, defineComponent, HSVtoCSS, omit, parseColor, propsFactory, RGBtoHSV, useRender } from "../../util/index.mjs";
15
- import { extractColor, modes, nullColor } from "./util/index.mjs";
12
+ import { useRtl } from "../../composables/locale.mjs";
13
+ import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utilities
16
14
  import { onMounted, ref } from 'vue';
17
-
18
- // Types
19
-
20
- export const makeVPickerProps = propsFactory({
15
+ import { extractColor, modes, nullColor } from "./util/index.mjs";
16
+ import { consoleWarn, defineComponent, HSVtoCSS, omit, parseColor, propsFactory, RGBtoHSV, useRender } from "../../util/index.mjs"; // Types
17
+ export const makeVColorPickerProps = propsFactory({
21
18
  canvasHeight: {
22
19
  type: [String, Number],
23
20
  default: 150
@@ -52,10 +49,10 @@ export const makeVPickerProps = propsFactory({
52
49
  ...omit(makeVSheetProps({
53
50
  width: 300
54
51
  }), ['height', 'location', 'minHeight', 'maxHeight', 'minWidth', 'maxWidth'])
55
- }, 'v-color-picker');
52
+ }, 'VColorPicker');
56
53
  export const VColorPicker = defineComponent({
57
54
  name: 'VColorPicker',
58
- props: makeVPickerProps(),
55
+ props: makeVColorPickerProps(),
59
56
  emits: {
60
57
  'update:modelValue': color => true,
61
58
  'update:mode': mode => true
@@ -64,6 +61,7 @@ export const VColorPicker = defineComponent({
64
61
  const mode = useProxiedModel(props, 'mode');
65
62
  const lastPickedColor = ref(null);
66
63
  const currentColor = useProxiedModel(props, 'modelValue', undefined, v => {
64
+ if (v == null || v === '') return null;
67
65
  let c;
68
66
  try {
69
67
  c = RGBtoHSV(parseColor(v));
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPicker.mjs","names":["makeVSheetProps","VSheet","VColorPickerCanvas","VColorPickerEdit","VColorPickerPreview","VColorPickerSwatches","useProxiedModel","provideDefaults","useRtl","consoleWarn","defineComponent","HSVtoCSS","omit","parseColor","propsFactory","RGBtoHSV","useRender","extractColor","modes","nullColor","onMounted","ref","makeVPickerProps","canvasHeight","type","String","Number","default","disabled","Boolean","dotSize","hideCanvas","hideSliders","hideInputs","mode","validator","v","Object","keys","includes","Array","isArray","every","m","showSwatches","swatches","swatchesMaxHeight","modelValue","width","VColorPicker","name","props","emits","color","setup","lastPickedColor","currentColor","undefined","c","err","value","h","rtlClasses","updateColor","hsva","VSlider","trackColor","trackFillColor","sheetProps","filterProps","_createVNode","_mergeProps","rounded","elevation","theme","class","a","style","endsWith"],"sources":["../../../src/components/VColorPicker/VColorPicker.tsx"],"sourcesContent":["// Styles\nimport './VColorPicker.sass'\n\n// Components\nimport { makeVSheetProps, VSheet } from '@/components/VSheet/VSheet'\nimport { VColorPickerCanvas } from './VColorPickerCanvas'\nimport { VColorPickerEdit } from './VColorPickerEdit'\nimport { VColorPickerPreview } from './VColorPickerPreview'\nimport { VColorPickerSwatches } from './VColorPickerSwatches'\n\n// Composables\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { provideDefaults } from '@/composables/defaults'\nimport { useRtl } from '@/composables/locale'\n\n// Utilities\nimport { consoleWarn, defineComponent, HSVtoCSS, omit, parseColor, propsFactory, RGBtoHSV, useRender } from '@/util'\nimport { extractColor, modes, nullColor } from './util'\nimport { onMounted, ref } from 'vue'\n\n// Types\nimport type { DeepReadonly, PropType } from 'vue'\nimport type { Color, HSV } from '@/util'\n\nexport const makeVPickerProps = propsFactory({\n canvasHeight: {\n type: [String, Number],\n default: 150,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n hideCanvas: Boolean,\n hideSliders: Boolean,\n hideInputs: Boolean,\n mode: {\n type: String as PropType<keyof typeof modes>,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<readonly (keyof typeof modes)[]>,\n default: () => Object.keys(modes),\n validator: (v: any) => Array.isArray(v) && v.every(m => Object.keys(modes).includes(m)),\n },\n showSwatches: Boolean,\n swatches: Array as PropType<DeepReadonly<Color[][]>>,\n swatchesMaxHeight: {\n type: [Number, String],\n default: 150,\n },\n modelValue: {\n type: [Object, String] as PropType<Record<string, unknown> | string | undefined | null>,\n },\n\n ...omit(makeVSheetProps({ width: 300 }), [\n 'height',\n 'location',\n 'minHeight',\n 'maxHeight',\n 'minWidth',\n 'maxWidth',\n ]),\n}, 'v-color-picker')\n\nexport const VColorPicker = defineComponent({\n name: 'VColorPicker',\n\n props: makeVPickerProps(),\n\n emits: {\n 'update:modelValue': (color: any) => true,\n 'update:mode': (mode: keyof typeof modes) => true,\n },\n\n setup (props) {\n const mode = useProxiedModel(props, 'mode')\n const lastPickedColor = ref<HSV | null>(null)\n const currentColor = useProxiedModel(\n props,\n 'modelValue',\n undefined,\n v => {\n let c: HSV\n try {\n c = RGBtoHSV(parseColor(v as any))\n } catch (err) {\n consoleWarn(err as any)\n return null\n }\n\n if (lastPickedColor.value) {\n c = { ...c, h: lastPickedColor.value.h }\n lastPickedColor.value = null\n }\n\n return c\n },\n v => {\n if (!v) return null\n\n return extractColor(v, props.modelValue)\n }\n )\n const { rtlClasses } = useRtl()\n\n const updateColor = (hsva: HSV) => {\n currentColor.value = hsva\n lastPickedColor.value = hsva\n }\n\n onMounted(() => {\n if (!props.modes.includes(mode.value)) mode.value = props.modes[0]\n })\n\n provideDefaults({\n VSlider: {\n color: undefined,\n trackColor: undefined,\n trackFillColor: undefined,\n },\n })\n\n useRender(() => {\n const [sheetProps] = VSheet.filterProps(props)\n\n return (\n <VSheet\n rounded={ props.rounded }\n elevation={ props.elevation }\n theme={ props.theme }\n class={[\n 'v-color-picker',\n rtlClasses.value,\n props.class,\n ]}\n style={[\n {\n '--v-color-picker-color-hsv': HSVtoCSS({ ...(currentColor.value ?? nullColor), a: 1 }),\n },\n props.style,\n ]}\n { ...sheetProps }\n maxWidth={ props.width }\n >\n { !props.hideCanvas && (\n <VColorPickerCanvas\n key=\"canvas\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n disabled={ props.disabled }\n dotSize={ props.dotSize }\n width={ props.width }\n height={ props.canvasHeight }\n />\n )}\n\n { (!props.hideSliders || !props.hideInputs) && (\n <div key=\"controls\" class=\"v-color-picker__controls\">\n { !props.hideSliders && (\n <VColorPickerPreview\n key=\"preview\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n hideAlpha={ !mode.value.endsWith('a') }\n disabled={ props.disabled }\n />\n )}\n\n { !props.hideInputs && (\n <VColorPickerEdit\n key=\"edit\"\n modes={ props.modes }\n mode={ mode.value }\n onUpdate:mode={ m => mode.value = m }\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n disabled={ props.disabled }\n />\n )}\n </div>\n )}\n\n { props.showSwatches && (\n <VColorPickerSwatches\n key=\"swatches\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n maxHeight={ props.swatchesMaxHeight }\n swatches={ props.swatches }\n disabled={ props.disabled }\n />\n )}\n </VSheet>\n )\n })\n\n return {}\n },\n})\n\nexport type VColorPicker = InstanceType<typeof VColorPicker>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VColorPicker.mjs","names":["VColorPickerCanvas","VColorPickerEdit","VColorPickerPreview","VColorPickerSwatches","makeVSheetProps","VSheet","provideDefaults","useRtl","useProxiedModel","onMounted","ref","extractColor","modes","nullColor","consoleWarn","defineComponent","HSVtoCSS","omit","parseColor","propsFactory","RGBtoHSV","useRender","makeVColorPickerProps","canvasHeight","type","String","Number","default","disabled","Boolean","dotSize","hideCanvas","hideSliders","hideInputs","mode","validator","v","Object","keys","includes","Array","isArray","every","m","showSwatches","swatches","swatchesMaxHeight","modelValue","width","VColorPicker","name","props","emits","color","setup","lastPickedColor","currentColor","undefined","c","err","value","h","rtlClasses","updateColor","hsva","VSlider","trackColor","trackFillColor","sheetProps","filterProps","_createVNode","_mergeProps","rounded","elevation","theme","class","a","style","endsWith"],"sources":["../../../src/components/VColorPicker/VColorPicker.tsx"],"sourcesContent":["// Styles\nimport './VColorPicker.sass'\n\n// Components\nimport { VColorPickerCanvas } from './VColorPickerCanvas'\nimport { VColorPickerEdit } from './VColorPickerEdit'\nimport { VColorPickerPreview } from './VColorPickerPreview'\nimport { VColorPickerSwatches } from './VColorPickerSwatches'\nimport { makeVSheetProps, VSheet } from '@/components/VSheet/VSheet'\n\n// Composables\nimport { provideDefaults } from '@/composables/defaults'\nimport { useRtl } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { onMounted, ref } from 'vue'\nimport { extractColor, modes, nullColor } from './util'\nimport { consoleWarn, defineComponent, HSVtoCSS, omit, parseColor, propsFactory, RGBtoHSV, useRender } from '@/util'\n\n// Types\nimport type { DeepReadonly, PropType } from 'vue'\nimport type { Color, HSV } from '@/util'\n\nexport const makeVColorPickerProps = propsFactory({\n canvasHeight: {\n type: [String, Number],\n default: 150,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n hideCanvas: Boolean,\n hideSliders: Boolean,\n hideInputs: Boolean,\n mode: {\n type: String as PropType<keyof typeof modes>,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<readonly (keyof typeof modes)[]>,\n default: () => Object.keys(modes),\n validator: (v: any) => Array.isArray(v) && v.every(m => Object.keys(modes).includes(m)),\n },\n showSwatches: Boolean,\n swatches: Array as PropType<DeepReadonly<Color[][]>>,\n swatchesMaxHeight: {\n type: [Number, String],\n default: 150,\n },\n modelValue: {\n type: [Object, String] as PropType<Record<string, unknown> | string | undefined | null>,\n },\n\n ...omit(makeVSheetProps({ width: 300 }), [\n 'height',\n 'location',\n 'minHeight',\n 'maxHeight',\n 'minWidth',\n 'maxWidth',\n ]),\n}, 'VColorPicker')\n\nexport const VColorPicker = defineComponent({\n name: 'VColorPicker',\n\n props: makeVColorPickerProps(),\n\n emits: {\n 'update:modelValue': (color: any) => true,\n 'update:mode': (mode: keyof typeof modes) => true,\n },\n\n setup (props) {\n const mode = useProxiedModel(props, 'mode')\n const lastPickedColor = ref<HSV | null>(null)\n const currentColor = useProxiedModel(\n props,\n 'modelValue',\n undefined,\n v => {\n if (v == null || v === '') return null\n\n let c: HSV\n try {\n c = RGBtoHSV(parseColor(v as any))\n } catch (err) {\n consoleWarn(err as any)\n return null\n }\n\n if (lastPickedColor.value) {\n c = { ...c, h: lastPickedColor.value.h }\n lastPickedColor.value = null\n }\n\n return c\n },\n v => {\n if (!v) return null\n\n return extractColor(v, props.modelValue)\n }\n )\n const { rtlClasses } = useRtl()\n\n const updateColor = (hsva: HSV) => {\n currentColor.value = hsva\n lastPickedColor.value = hsva\n }\n\n onMounted(() => {\n if (!props.modes.includes(mode.value)) mode.value = props.modes[0]\n })\n\n provideDefaults({\n VSlider: {\n color: undefined,\n trackColor: undefined,\n trackFillColor: undefined,\n },\n })\n\n useRender(() => {\n const [sheetProps] = VSheet.filterProps(props)\n\n return (\n <VSheet\n rounded={ props.rounded }\n elevation={ props.elevation }\n theme={ props.theme }\n class={[\n 'v-color-picker',\n rtlClasses.value,\n props.class,\n ]}\n style={[\n {\n '--v-color-picker-color-hsv': HSVtoCSS({ ...(currentColor.value ?? nullColor), a: 1 }),\n },\n props.style,\n ]}\n { ...sheetProps }\n maxWidth={ props.width }\n >\n { !props.hideCanvas && (\n <VColorPickerCanvas\n key=\"canvas\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n disabled={ props.disabled }\n dotSize={ props.dotSize }\n width={ props.width }\n height={ props.canvasHeight }\n />\n )}\n\n { (!props.hideSliders || !props.hideInputs) && (\n <div key=\"controls\" class=\"v-color-picker__controls\">\n { !props.hideSliders && (\n <VColorPickerPreview\n key=\"preview\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n hideAlpha={ !mode.value.endsWith('a') }\n disabled={ props.disabled }\n />\n )}\n\n { !props.hideInputs && (\n <VColorPickerEdit\n key=\"edit\"\n modes={ props.modes }\n mode={ mode.value }\n onUpdate:mode={ m => mode.value = m }\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n disabled={ props.disabled }\n />\n )}\n </div>\n )}\n\n { props.showSwatches && (\n <VColorPickerSwatches\n key=\"swatches\"\n color={ currentColor.value }\n onUpdate:color={ updateColor }\n maxHeight={ props.swatchesMaxHeight }\n swatches={ props.swatches }\n disabled={ props.disabled }\n />\n )}\n </VSheet>\n )\n })\n\n return {}\n },\n})\n\nexport type VColorPicker = InstanceType<typeof VColorPicker>\n"],"mappings":"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"}
@@ -5,11 +5,8 @@ import "./VColorPickerCanvas.css";
5
5
  // Composables
6
6
  import { makeComponentProps } from "../../composables/component.mjs";
7
7
  import { useResizeObserver } from "../../composables/resizeObserver.mjs"; // Utilities
8
- import { clamp, convertToUnit, defineComponent, getEventCoordinates, propsFactory, useRender } from "../../util/index.mjs";
9
8
  import { computed, onMounted, ref, shallowRef, watch } from 'vue';
10
-
11
- // Types
12
-
9
+ import { clamp, convertToUnit, defineComponent, getEventCoordinates, propsFactory, useRender } from "../../util/index.mjs"; // Types
13
10
  export const makeVColorPickerCanvasProps = propsFactory({
14
11
  color: {
15
12
  type: Object
@@ -28,7 +25,7 @@ export const makeVColorPickerCanvasProps = propsFactory({
28
25
  default: 300
29
26
  },
30
27
  ...makeComponentProps()
31
- }, 'v-color-picker-canvas');
28
+ }, 'VColorPickerCanvas');
32
29
  export const VColorPickerCanvas = defineComponent({
33
30
  name: 'VColorPickerCanvas',
34
31
  props: makeVColorPickerCanvasProps(),