vuetify 3.1.4 → 3.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (474) hide show
  1. package/dist/json/attributes.json +2734 -2738
  2. package/dist/json/importMap.json +32 -32
  3. package/dist/json/tags.json +0 -1
  4. package/dist/json/web-types.json +9073 -6416
  5. package/dist/vuetify-labs.css +3119 -6004
  6. package/dist/vuetify-labs.d.ts +12865 -20825
  7. package/dist/vuetify-labs.esm.js +1674 -1914
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +1673 -1913
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +54 -2948
  12. package/dist/vuetify.d.ts +12215 -20183
  13. package/dist/vuetify.esm.js +1495 -1736
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +1494 -1735
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +1134 -1353
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.ts +9 -9
  21. package/lib/blueprints/md1.d.ts +9 -9
  22. package/lib/blueprints/md2.d.ts +9 -9
  23. package/lib/blueprints/md3.d.ts +9 -9
  24. package/lib/blueprints/md3.mjs.map +1 -1
  25. package/lib/components/VAlert/VAlert.mjs +5 -6
  26. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  27. package/lib/components/VAlert/index.d.ts +135 -157
  28. package/lib/components/VApp/VApp.mjs +9 -12
  29. package/lib/components/VApp/VApp.mjs.map +1 -1
  30. package/lib/components/VApp/index.d.ts +27 -13
  31. package/lib/components/VAppBar/VAppBar.mjs +9 -5
  32. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  33. package/lib/components/VAppBar/VAppBarNavIcon.mjs +2 -2
  34. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  35. package/lib/components/VAppBar/VAppBarTitle.mjs +2 -2
  36. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  37. package/lib/components/VAppBar/index.d.ts +169 -350
  38. package/lib/components/VAutocomplete/VAutocomplete.mjs +100 -104
  39. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  40. package/lib/components/VAutocomplete/index.d.ts +494 -636
  41. package/lib/components/VAvatar/VAvatar.mjs +19 -22
  42. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  43. package/lib/components/VAvatar/index.d.ts +46 -66
  44. package/lib/components/VBadge/VBadge.mjs +7 -5
  45. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  46. package/lib/components/VBadge/index.d.ts +74 -100
  47. package/lib/components/VBanner/VBanner.mjs +3 -4
  48. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  49. package/lib/components/VBanner/VBannerActions.mjs +5 -8
  50. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  51. package/lib/components/VBanner/index.d.ts +134 -98
  52. package/lib/components/VBottomNavigation/VBottomNavigation.css +2 -1
  53. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +8 -4
  54. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  55. package/lib/components/VBottomNavigation/VBottomNavigation.sass +2 -1
  56. package/lib/components/VBottomNavigation/_variables.scss +1 -1
  57. package/lib/components/VBottomNavigation/index.d.ts +67 -131
  58. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +9 -16
  59. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  60. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +5 -8
  61. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  62. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +4 -8
  63. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  64. package/lib/components/VBreadcrumbs/index.d.ts +87 -61
  65. package/lib/components/VBtn/VBtn.mjs +14 -17
  66. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  67. package/lib/components/VBtn/index.d.ts +118 -179
  68. package/lib/components/VBtnGroup/VBtnGroup.mjs +5 -2
  69. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  70. package/lib/components/VBtnGroup/index.d.ts +42 -57
  71. package/lib/components/VBtnToggle/VBtnToggle.mjs +1 -2
  72. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  73. package/lib/components/VBtnToggle/index.d.ts +60 -247
  74. package/lib/components/VCalendar/mixins/mouse.mjs +2 -3
  75. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  76. package/lib/components/VCard/VCard.mjs +5 -6
  77. package/lib/components/VCard/VCard.mjs.map +1 -1
  78. package/lib/components/VCard/VCardActions.mjs +5 -8
  79. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  80. package/lib/components/VCard/VCardItem.mjs +7 -8
  81. package/lib/components/VCard/VCardItem.mjs.map +1 -1
  82. package/lib/components/VCard/index.d.ts +286 -186
  83. package/lib/components/VCarousel/VCarousel.mjs +2 -2
  84. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  85. package/lib/components/VCarousel/VCarouselItem.mjs +2 -2
  86. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  87. package/lib/components/VCarousel/index.d.ts +238 -61
  88. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  89. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  90. package/lib/components/VCheckbox/VCheckboxBtn.mjs +2 -2
  91. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  92. package/lib/components/VCheckbox/index.d.ts +277 -254
  93. package/lib/components/VChip/VChip.mjs +15 -14
  94. package/lib/components/VChip/VChip.mjs.map +1 -1
  95. package/lib/components/VChip/index.d.ts +118 -168
  96. package/lib/components/VChipGroup/VChipGroup.css +1 -0
  97. package/lib/components/VChipGroup/VChipGroup.mjs +15 -18
  98. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  99. package/lib/components/VChipGroup/VChipGroup.sass +1 -0
  100. package/lib/components/VChipGroup/index.d.ts +49 -68
  101. package/lib/components/VCode/index.d.ts +21 -9
  102. package/lib/components/VColorPicker/VColorPicker.mjs +9 -1
  103. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  104. package/lib/components/VColorPicker/VColorPickerCanvas.css +2 -1
  105. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +40 -27
  106. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  107. package/lib/components/VColorPicker/VColorPickerCanvas.sass +2 -1
  108. package/lib/components/VColorPicker/VColorPickerEdit.mjs +16 -20
  109. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  110. package/lib/components/VColorPicker/VColorPickerPreview.mjs +43 -46
  111. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  112. package/lib/components/VColorPicker/index.d.ts +1 -1
  113. package/lib/components/VColorPicker/util/index.mjs +3 -7
  114. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  115. package/lib/components/VCombobox/VCombobox.mjs +104 -113
  116. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  117. package/lib/components/VCombobox/index.d.ts +496 -638
  118. package/lib/components/VCounter/VCounter.mjs +2 -2
  119. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  120. package/lib/components/VCounter/index.d.ts +139 -197
  121. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +4 -9
  122. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  123. package/lib/components/VDefaultsProvider/index.d.ts +33 -14
  124. package/lib/components/VDialog/VDialog.mjs +6 -9
  125. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  126. package/lib/components/VDialog/index.d.ts +430 -1610
  127. package/lib/components/VDivider/VDivider.mjs +2 -2
  128. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  129. package/lib/components/VDivider/index.d.ts +35 -15
  130. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +4 -5
  131. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  132. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +11 -14
  133. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  134. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +19 -22
  135. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  136. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +2 -2
  137. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  138. package/lib/components/VExpansionPanel/index.d.ts +180 -158
  139. package/lib/components/VField/VField.mjs +3 -6
  140. package/lib/components/VField/VField.mjs.map +1 -1
  141. package/lib/components/VField/VFieldLabel.mjs +2 -2
  142. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  143. package/lib/components/VField/index.d.ts +46 -34
  144. package/lib/components/VFileInput/VFileInput.mjs +16 -18
  145. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  146. package/lib/components/VFileInput/index.d.ts +330 -355
  147. package/lib/components/VFooter/VFooter.mjs +2 -2
  148. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  149. package/lib/components/VFooter/index.d.ts +46 -66
  150. package/lib/components/VForm/VForm.mjs +10 -14
  151. package/lib/components/VForm/VForm.mjs.map +1 -1
  152. package/lib/components/VForm/index.d.ts +29 -23
  153. package/lib/components/VGrid/VCol.mjs +5 -8
  154. package/lib/components/VGrid/VCol.mjs.map +1 -1
  155. package/lib/components/VGrid/VContainer.mjs +2 -2
  156. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  157. package/lib/components/VGrid/VGrid.css +0 -125
  158. package/lib/components/VGrid/VRow.mjs +5 -8
  159. package/lib/components/VGrid/VRow.mjs.map +1 -1
  160. package/lib/components/VGrid/index.d.ts +112 -121
  161. package/lib/components/VHover/VHover.mjs +9 -12
  162. package/lib/components/VHover/VHover.mjs.map +1 -1
  163. package/lib/components/VHover/index.d.ts +53 -15
  164. package/lib/components/VIcon/VIcon.mjs +22 -26
  165. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  166. package/lib/components/VIcon/index.d.ts +68 -56
  167. package/lib/components/VImg/VImg.mjs +7 -11
  168. package/lib/components/VImg/VImg.mjs.map +1 -1
  169. package/lib/components/VImg/index.d.ts +67 -58
  170. package/lib/components/VInput/VInput.mjs +5 -6
  171. package/lib/components/VInput/VInput.mjs.map +1 -1
  172. package/lib/components/VInput/index.d.ts +94 -283
  173. package/lib/components/VItemGroup/VItem.mjs +8 -11
  174. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  175. package/lib/components/VItemGroup/VItemGroup.mjs +13 -16
  176. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  177. package/lib/components/VItemGroup/index.d.ts +76 -149
  178. package/lib/components/VKbd/index.d.ts +21 -9
  179. package/lib/components/VLabel/VLabel.mjs +7 -10
  180. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  181. package/lib/components/VLabel/index.d.ts +29 -9
  182. package/lib/components/VLayout/VLayout.mjs +9 -12
  183. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  184. package/lib/components/VLayout/VLayoutItem.mjs +6 -9
  185. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  186. package/lib/components/VLayout/index.d.ts +60 -43
  187. package/lib/components/VLazy/VLazy.mjs +12 -15
  188. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  189. package/lib/components/VLazy/index.d.ts +48 -71
  190. package/lib/components/VList/VList.mjs +4 -8
  191. package/lib/components/VList/VList.mjs.map +1 -1
  192. package/lib/components/VList/VListChildren.mjs +59 -77
  193. package/lib/components/VList/VListChildren.mjs.map +1 -1
  194. package/lib/components/VList/VListGroup.mjs +33 -39
  195. package/lib/components/VList/VListGroup.mjs.map +1 -1
  196. package/lib/components/VList/VListItem.css +2 -2
  197. package/lib/components/VList/VListItem.mjs +10 -18
  198. package/lib/components/VList/VListItem.mjs.map +1 -1
  199. package/lib/components/VList/VListItem.sass +0 -2
  200. package/lib/components/VList/VListItemAction.mjs +2 -2
  201. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  202. package/lib/components/VList/VListItemMedia.mjs +2 -2
  203. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  204. package/lib/components/VList/VListSubheader.mjs +3 -4
  205. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  206. package/lib/components/VList/index.d.ts +418 -686
  207. package/lib/components/VList/list.mjs +1 -1
  208. package/lib/components/VList/list.mjs.map +1 -1
  209. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -8
  210. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  211. package/lib/components/VLocaleProvider/index.d.ts +28 -16
  212. package/lib/components/VMain/VMain.mjs +12 -15
  213. package/lib/components/VMain/VMain.mjs.map +1 -1
  214. package/lib/components/VMain/index.d.ts +23 -17
  215. package/lib/components/VMenu/VMenu.mjs +10 -10
  216. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  217. package/lib/components/VMenu/index.d.ts +428 -1641
  218. package/lib/components/VMessages/VMessages.mjs +2 -2
  219. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  220. package/lib/components/VMessages/index.d.ts +144 -204
  221. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +6 -7
  222. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  223. package/lib/components/VNavigationDrawer/index.d.ts +92 -124
  224. package/lib/components/VNoSsr/VNoSsr.mjs +1 -4
  225. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  226. package/lib/components/VNoSsr/index.d.ts +20 -4
  227. package/lib/components/VOtpInput/VOtpInput.mjs +5 -6
  228. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -1
  229. package/lib/components/VOverlay/VOverlay.mjs +44 -47
  230. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  231. package/lib/components/VOverlay/index.d.ts +150 -468
  232. package/lib/components/VOverlay/locationStrategies.mjs +3 -6
  233. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  234. package/lib/components/VOverlay/scrollStrategies.mjs +8 -13
  235. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  236. package/lib/components/VOverlay/useActivator.mjs +4 -7
  237. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  238. package/lib/components/VPagination/VPagination.mjs +4 -5
  239. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  240. package/lib/components/VPagination/index.d.ts +107 -207
  241. package/lib/components/VParallax/VParallax.mjs +12 -15
  242. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  243. package/lib/components/VParallax/index.d.ts +39 -9
  244. package/lib/components/VProgressCircular/VProgressCircular.mjs +2 -2
  245. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  246. package/lib/components/VProgressCircular/index.d.ts +41 -58
  247. package/lib/components/VProgressLinear/VProgressLinear.mjs +2 -2
  248. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  249. package/lib/components/VProgressLinear/index.d.ts +91 -95
  250. package/lib/components/VRadio/VRadio.mjs +2 -2
  251. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  252. package/lib/components/VRadio/index.d.ts +108 -85
  253. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -2
  254. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  255. package/lib/components/VRadioGroup/index.d.ts +164 -147
  256. package/lib/components/VRangeSlider/VRangeSlider.mjs +21 -31
  257. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  258. package/lib/components/VRangeSlider/index.d.ts +154 -210
  259. package/lib/components/VRating/VRating.mjs +28 -34
  260. package/lib/components/VRating/VRating.mjs.map +1 -1
  261. package/lib/components/VRating/index.d.ts +77 -311
  262. package/lib/components/VResponsive/VResponsive.mjs +11 -14
  263. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  264. package/lib/components/VResponsive/index.d.ts +44 -20
  265. package/lib/components/VSelect/VSelect.mjs +100 -102
  266. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  267. package/lib/components/VSelect/index.d.ts +729 -673
  268. package/lib/components/VSelectionControl/VSelectionControl.mjs +3 -4
  269. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  270. package/lib/components/VSelectionControl/index.d.ts +31 -19
  271. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +8 -11
  272. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  273. package/lib/components/VSelectionControlGroup/index.d.ts +58 -70
  274. package/lib/components/VSheet/VSheet.mjs +23 -13
  275. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  276. package/lib/components/VSheet/index.d.ts +52 -56
  277. package/lib/components/VSlideGroup/VSlideGroup.mjs +51 -60
  278. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  279. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +6 -9
  280. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  281. package/lib/components/VSlideGroup/index.d.ts +144 -366
  282. package/lib/components/VSlider/VSlider.mjs +8 -14
  283. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  284. package/lib/components/VSlider/VSliderThumb.css +0 -1
  285. package/lib/components/VSlider/VSliderThumb.mjs +4 -5
  286. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  287. package/lib/components/VSlider/VSliderTrack.mjs +4 -5
  288. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  289. package/lib/components/VSlider/index.d.ts +151 -207
  290. package/lib/components/VSlider/slider.mjs +3 -6
  291. package/lib/components/VSlider/slider.mjs.map +1 -1
  292. package/lib/components/VSnackbar/VSnackbar.mjs +1 -1
  293. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  294. package/lib/components/VSnackbar/index.d.ts +358 -1519
  295. package/lib/components/VSwitch/VSwitch.mjs +3 -4
  296. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  297. package/lib/components/VSwitch/index.d.ts +180 -151
  298. package/lib/components/VSystemBar/VSystemBar.css +5 -1
  299. package/lib/components/VSystemBar/VSystemBar.mjs +8 -4
  300. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  301. package/lib/components/VSystemBar/VSystemBar.sass +5 -1
  302. package/lib/components/VSystemBar/_variables.scss +4 -1
  303. package/lib/components/VSystemBar/index.d.ts +43 -51
  304. package/lib/components/VTable/VTable.mjs +19 -22
  305. package/lib/components/VTable/VTable.mjs.map +1 -1
  306. package/lib/components/VTable/index.d.ts +54 -30
  307. package/lib/components/VTabs/VTab.mjs +3 -4
  308. package/lib/components/VTabs/VTab.mjs.map +1 -1
  309. package/lib/components/VTabs/VTabs.mjs +2 -2
  310. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  311. package/lib/components/VTabs/index.d.ts +122 -150
  312. package/lib/components/VTextField/VTextField.mjs +16 -19
  313. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  314. package/lib/components/VTextField/index.d.ts +331 -1489
  315. package/lib/components/VTextarea/VTextarea.mjs +17 -19
  316. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  317. package/lib/components/VTextarea/index.d.ts +320 -334
  318. package/lib/components/VThemeProvider/VThemeProvider.mjs +4 -5
  319. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  320. package/lib/components/VThemeProvider/index.d.ts +27 -13
  321. package/lib/components/VTimeline/VTimeline.mjs +2 -2
  322. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  323. package/lib/components/VTimeline/VTimelineDivider.mjs +20 -23
  324. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  325. package/lib/components/VTimeline/VTimelineItem.mjs +33 -34
  326. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  327. package/lib/components/VTimeline/index.d.ts +123 -135
  328. package/lib/components/VToolbar/VToolbar.css +1 -0
  329. package/lib/components/VToolbar/VToolbar.mjs +7 -9
  330. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  331. package/lib/components/VToolbar/VToolbar.sass +1 -0
  332. package/lib/components/VToolbar/VToolbarItems.mjs +5 -8
  333. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  334. package/lib/components/VToolbar/VToolbarTitle.mjs +1 -2
  335. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  336. package/lib/components/VToolbar/index.d.ts +146 -351
  337. package/lib/components/VTooltip/VTooltip.mjs +1 -2
  338. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  339. package/lib/components/VTooltip/index.d.ts +361 -1619
  340. package/lib/components/VValidation/VValidation.mjs +3 -6
  341. package/lib/components/VValidation/VValidation.mjs.map +1 -1
  342. package/lib/components/VValidation/index.d.ts +48 -46
  343. package/lib/components/VWindow/VWindow.mjs +19 -22
  344. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  345. package/lib/components/VWindow/VWindowItem.mjs +10 -14
  346. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  347. package/lib/components/VWindow/index.d.ts +152 -284
  348. package/lib/components/index.d.ts +13684 -21652
  349. package/lib/components/transitions/createTransition.mjs +4 -4
  350. package/lib/components/transitions/createTransition.mjs.map +1 -1
  351. package/lib/components/transitions/dialog-transition.mjs +8 -8
  352. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  353. package/lib/components/transitions/index.d.ts +477 -342
  354. package/lib/composables/defaults.mjs +6 -4
  355. package/lib/composables/defaults.mjs.map +1 -1
  356. package/lib/composables/delay.mjs +1 -1
  357. package/lib/composables/delay.mjs.map +1 -1
  358. package/lib/composables/filter.mjs +11 -12
  359. package/lib/composables/filter.mjs.map +1 -1
  360. package/lib/composables/group.mjs +2 -2
  361. package/lib/composables/group.mjs.map +1 -1
  362. package/lib/composables/icons.mjs +4 -6
  363. package/lib/composables/icons.mjs.map +1 -1
  364. package/lib/composables/intersectionObserver.mjs +1 -1
  365. package/lib/composables/intersectionObserver.mjs.map +1 -1
  366. package/lib/composables/layout.mjs +2 -5
  367. package/lib/composables/layout.mjs.map +1 -1
  368. package/lib/composables/loader.mjs +2 -3
  369. package/lib/composables/loader.mjs.map +1 -1
  370. package/lib/composables/locale.mjs +2 -2
  371. package/lib/composables/locale.mjs.map +1 -1
  372. package/lib/composables/mutationObserver.mjs +8 -8
  373. package/lib/composables/mutationObserver.mjs.map +1 -1
  374. package/lib/composables/nested/nested.mjs +2 -2
  375. package/lib/composables/nested/nested.mjs.map +1 -1
  376. package/lib/composables/nested/selectStrategies.mjs +8 -2
  377. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  378. package/lib/composables/proxiedModel.mjs +8 -9
  379. package/lib/composables/proxiedModel.mjs.map +1 -1
  380. package/lib/composables/resizeObserver.mjs +1 -1
  381. package/lib/composables/resizeObserver.mjs.map +1 -1
  382. package/lib/composables/router.mjs +12 -21
  383. package/lib/composables/router.mjs.map +1 -1
  384. package/lib/composables/scroll.mjs +2 -4
  385. package/lib/composables/scroll.mjs.map +1 -1
  386. package/lib/composables/selectLink.mjs +1 -4
  387. package/lib/composables/selectLink.mjs.map +1 -1
  388. package/lib/composables/stack.mjs +6 -8
  389. package/lib/composables/stack.mjs.map +1 -1
  390. package/lib/composables/teleport.mjs +1 -1
  391. package/lib/composables/teleport.mjs.map +1 -1
  392. package/lib/composables/theme.mjs +23 -16
  393. package/lib/composables/theme.mjs.map +1 -1
  394. package/lib/composables/toggleScope.mjs +3 -6
  395. package/lib/composables/toggleScope.mjs.map +1 -1
  396. package/lib/composables/touch.mjs +1 -2
  397. package/lib/composables/touch.mjs.map +1 -1
  398. package/lib/composables/validation.mjs +7 -7
  399. package/lib/composables/validation.mjs.map +1 -1
  400. package/lib/directives/click-outside/index.mjs +2 -3
  401. package/lib/directives/click-outside/index.mjs.map +1 -1
  402. package/lib/directives/index.d.ts +1 -1
  403. package/lib/directives/intersect/index.mjs +2 -4
  404. package/lib/directives/intersect/index.mjs.map +1 -1
  405. package/lib/directives/mutate/index.mjs +7 -8
  406. package/lib/directives/mutate/index.mjs.map +1 -1
  407. package/lib/directives/resize/index.mjs +3 -5
  408. package/lib/directives/resize/index.mjs.map +1 -1
  409. package/lib/directives/ripple/index.mjs +8 -13
  410. package/lib/directives/ripple/index.mjs.map +1 -1
  411. package/lib/directives/scroll/index.mjs +1 -2
  412. package/lib/directives/scroll/index.mjs.map +1 -1
  413. package/lib/directives/touch/index.mjs +9 -14
  414. package/lib/directives/touch/index.mjs.map +1 -1
  415. package/lib/entry-bundler.mjs +1 -1
  416. package/lib/framework.mjs +2 -3
  417. package/lib/framework.mjs.map +1 -1
  418. package/lib/iconsets/fa-svg.d.ts +2 -2
  419. package/lib/iconsets/fa.d.ts +2 -2
  420. package/lib/iconsets/fa4.d.ts +2 -2
  421. package/lib/iconsets/md.d.ts +2 -2
  422. package/lib/iconsets/mdi-svg.d.ts +2 -2
  423. package/lib/iconsets/mdi.d.ts +2 -2
  424. package/lib/index.d.ts +18 -18
  425. package/lib/labs/VDataTable/VDataTable.mjs +11 -14
  426. package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
  427. package/lib/labs/VDataTable/VDataTableColumn.mjs +1 -2
  428. package/lib/labs/VDataTable/VDataTableColumn.mjs.map +1 -1
  429. package/lib/labs/VDataTable/VDataTableFooter.css +9 -0
  430. package/lib/labs/VDataTable/VDataTableFooter.mjs +80 -45
  431. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  432. package/lib/labs/VDataTable/VDataTableFooter.sass +7 -0
  433. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +6 -8
  434. package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
  435. package/lib/labs/VDataTable/VDataTableHeaders.mjs +3 -4
  436. package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -1
  437. package/lib/labs/VDataTable/VDataTableRow.mjs +2 -4
  438. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  439. package/lib/labs/VDataTable/VDataTableRows.mjs +45 -49
  440. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  441. package/lib/labs/VDataTable/VDataTableServer.mjs +17 -20
  442. package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
  443. package/lib/labs/VDataTable/VDataTableVirtual.mjs +2 -2
  444. package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
  445. package/lib/labs/VDataTable/composables/headers.mjs +3 -4
  446. package/lib/labs/VDataTable/composables/headers.mjs.map +1 -1
  447. package/lib/labs/VDataTable/composables/paginate.mjs +1 -6
  448. package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -1
  449. package/lib/labs/VDataTable/composables/sort.mjs +1 -1
  450. package/lib/labs/VDataTable/composables/sort.mjs.map +1 -1
  451. package/lib/labs/VDataTable/index.d.ts +583 -575
  452. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs +14 -18
  453. package/lib/labs/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  454. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs +7 -13
  455. package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs.map +1 -1
  456. package/lib/labs/VVirtualScroll/index.d.ts +18 -18
  457. package/lib/labs/components.d.ts +601 -593
  458. package/lib/locale/adapters/vue-i18n.d.ts +1 -1
  459. package/lib/locale/adapters/vuetify.mjs +3 -3
  460. package/lib/locale/adapters/vuetify.mjs.map +1 -1
  461. package/lib/styles/main.css +40 -2816
  462. package/lib/util/colorUtils.mjs +4 -5
  463. package/lib/util/colorUtils.mjs.map +1 -1
  464. package/lib/util/console.mjs +1 -1
  465. package/lib/util/console.mjs.map +1 -1
  466. package/lib/util/createSimpleFunctional.mjs +5 -8
  467. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  468. package/lib/util/defineComponent.mjs +6 -8
  469. package/lib/util/defineComponent.mjs.map +1 -1
  470. package/lib/util/getCurrentInstance.mjs +1 -1
  471. package/lib/util/getCurrentInstance.mjs.map +1 -1
  472. package/lib/util/helpers.mjs +2 -3
  473. package/lib/util/helpers.mjs.map +1 -1
  474. package/package.json +19 -20
@@ -1,77 +1,58 @@
1
1
  import * as vue from 'vue';
2
- import { PropType } from 'vue';
3
2
 
4
3
  declare function deepEqual(a: any, b: any): boolean;
5
4
 
6
5
  declare const VChipGroup: vue.DefineComponent<{
7
- color: StringConstructor;
8
- variant: Omit<{
9
- type: PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
10
- default: string;
11
- validator: (v: any) => boolean;
12
- }, "type" | "default"> & {
13
- type: PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
14
- default: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
15
- };
16
- theme: StringConstructor;
17
- tag: {
18
- type: StringConstructor;
19
- default: string;
20
- };
21
- modelValue: {
22
- type: null;
23
- default: undefined;
24
- };
25
- multiple: BooleanConstructor;
26
- mandatory: PropType<boolean | "force">;
27
- max: NumberConstructor;
28
- selectedClass: {
29
- type: PropType<string>;
30
- default: string;
31
- };
32
- disabled: BooleanConstructor;
33
- column: BooleanConstructor;
34
- filter: BooleanConstructor;
35
- valueComparator: {
36
- type: PropType<typeof deepEqual>;
37
- default: typeof deepEqual;
6
+ filter: boolean;
7
+ disabled: boolean;
8
+ multiple: boolean;
9
+ tag: string;
10
+ column: boolean;
11
+ variant: NonNullable<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
12
+ selectedClass: string;
13
+ valueComparator: typeof deepEqual;
14
+ } & {
15
+ max?: number | undefined;
16
+ color?: string | undefined;
17
+ mandatory?: boolean | "force" | undefined;
18
+ theme?: string | undefined;
19
+ modelValue?: any;
20
+ } & {
21
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
22
+ default?: (() => vue.VNodeChild) | undefined;
38
23
  };
24
+ 'v-slots'?: {
25
+ default?: false | (() => vue.VNodeChild) | undefined;
26
+ } | undefined;
27
+ } & {
28
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
39
29
  }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
40
- 'update:modelValue': (value: any) => true;
41
- }, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, Readonly<vue.ExtractPropTypes<{
42
- color: StringConstructor;
43
- variant: Omit<{
44
- type: PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
45
- default: string;
46
- validator: (v: any) => boolean;
47
- }, "type" | "default"> & {
48
- type: PropType<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
49
- default: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
50
- };
51
- theme: StringConstructor;
52
- tag: {
53
- type: StringConstructor;
54
- default: string;
55
- };
56
- modelValue: {
57
- type: null;
58
- default: undefined;
59
- };
60
- multiple: BooleanConstructor;
61
- mandatory: PropType<boolean | "force">;
62
- max: NumberConstructor;
63
- selectedClass: {
64
- type: PropType<string>;
65
- default: string;
66
- };
67
- disabled: BooleanConstructor;
68
- column: BooleanConstructor;
69
- filter: BooleanConstructor;
70
- valueComparator: {
71
- type: PropType<typeof deepEqual>;
72
- default: typeof deepEqual;
30
+ 'update:modelValue': (value: any) => boolean;
31
+ }, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
32
+ filter: boolean;
33
+ disabled: boolean;
34
+ multiple: boolean;
35
+ tag: string;
36
+ column: boolean;
37
+ variant: NonNullable<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
38
+ selectedClass: string;
39
+ valueComparator: typeof deepEqual;
40
+ } & {
41
+ max?: number | undefined;
42
+ color?: string | undefined;
43
+ mandatory?: boolean | "force" | undefined;
44
+ theme?: string | undefined;
45
+ modelValue?: any;
46
+ } & {
47
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
48
+ default?: (() => vue.VNodeChild) | undefined;
73
49
  };
74
- }>> & {
50
+ 'v-slots'?: {
51
+ default?: false | (() => vue.VNodeChild) | undefined;
52
+ } | undefined;
53
+ } & {
54
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
55
+ } & {
75
56
  "onUpdate:modelValue"?: ((value: any) => any) | undefined;
76
57
  }, {
77
58
  filter: boolean;
@@ -79,11 +60,11 @@ declare const VChipGroup: vue.DefineComponent<{
79
60
  multiple: boolean;
80
61
  tag: string;
81
62
  column: boolean;
82
- variant: "flat" | "text" | "elevated" | "tonal" | "outlined" | "plain";
63
+ variant: NonNullable<"flat" | "text" | "elevated" | "tonal" | "outlined" | "plain">;
83
64
  modelValue: any;
84
65
  selectedClass: string;
85
66
  valueComparator: typeof deepEqual;
86
67
  }>;
87
- declare type VChipGroup = InstanceType<typeof VChipGroup>;
68
+ type VChipGroup = InstanceType<typeof VChipGroup>;
88
69
 
89
70
  export { VChipGroup };
@@ -1,20 +1,32 @@
1
1
  import * as vue from 'vue';
2
2
 
3
3
  declare const VCode: vue.DefineComponent<{
4
- tag: {
5
- type: StringConstructor;
6
- default: string;
4
+ tag: string;
5
+ } & {} & {
6
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
7
+ default?: (() => vue.VNodeChild) | undefined;
7
8
  };
9
+ 'v-slots'?: {
10
+ default?: false | (() => vue.VNodeChild) | undefined;
11
+ } | undefined;
12
+ } & {
13
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
8
14
  }, () => vue.VNode<vue.RendererNode, vue.RendererElement, {
9
15
  [key: string]: any;
10
- }>, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, Readonly<vue.ExtractPropTypes<{
11
- tag: {
12
- type: StringConstructor;
13
- default: string;
16
+ }>, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
17
+ tag: string;
18
+ } & {} & {
19
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
20
+ default?: (() => vue.VNodeChild) | undefined;
14
21
  };
15
- }>>, {
22
+ 'v-slots'?: {
23
+ default?: false | (() => vue.VNodeChild) | undefined;
24
+ } | undefined;
25
+ } & {
26
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
27
+ }, {
16
28
  tag: string;
17
29
  }>;
18
- declare type VCode = InstanceType<typeof VCode>;
30
+ type VCode = InstanceType<typeof VCode>;
19
31
 
20
32
  export { VCode };
@@ -11,7 +11,8 @@ import { VSheet } from "../VSheet/index.mjs"; // Composables
11
11
  import { makeElevationProps } from "../../composables/elevation.mjs";
12
12
  import { makeRoundedProps } from "../../composables/rounded.mjs";
13
13
  import { makeThemeProps } from "../../composables/theme.mjs";
14
- import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utilities
14
+ import { useProxiedModel } from "../../composables/proxiedModel.mjs";
15
+ import { provideDefaults } from "../../composables/defaults.mjs"; // Utilities
15
16
  import { defineComponent, HSVtoCSS, useRender } from "../../util/index.mjs";
16
17
  import { extractColor, modes, nullColor, parseColor } from "./util/index.mjs";
17
18
  import { onMounted, ref } from 'vue';
@@ -89,6 +90,13 @@ export const VColorPicker = defineComponent({
89
90
  onMounted(() => {
90
91
  if (!props.modes.includes(mode.value)) mode.value = props.modes[0];
91
92
  });
93
+ provideDefaults({
94
+ VSlider: {
95
+ color: undefined,
96
+ trackColor: undefined,
97
+ trackFillColor: undefined
98
+ }
99
+ });
92
100
  useRender(() => _createVNode(VSheet, {
93
101
  "rounded": props.rounded,
94
102
  "elevation": props.elevation,
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPicker.mjs","names":["VColorPickerCanvas","VColorPickerEdit","VColorPickerPreview","VColorPickerSwatches","VSheet","makeElevationProps","makeRoundedProps","makeThemeProps","useProxiedModel","defineComponent","HSVtoCSS","useRender","extractColor","modes","nullColor","parseColor","onMounted","ref","VColorPicker","name","props","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","emits","color","setup","lastPickedColor","currentColor","undefined","c","value","h","updateColor","hsva","rounded","elevation","theme","a","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 { VSheet } from '@/components/VSheet'\n\n// Composables\nimport { makeElevationProps } from '@/composables/elevation'\nimport { makeRoundedProps } from '@/composables/rounded'\nimport { makeThemeProps } from '@/composables/theme'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { defineComponent, HSVtoCSS, useRender } from '@/util'\nimport { extractColor, modes, nullColor, parseColor } from './util'\nimport { onMounted, ref } from 'vue'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util'\n\nexport const VColorPicker = defineComponent({\n name: 'VColorPicker',\n\n props: {\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,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<string[]>,\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<string[][]>,\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 width: {\n type: [Number, String],\n default: 300,\n },\n\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeThemeProps(),\n },\n\n emits: {\n 'update:modelValue': (color: any) => true,\n 'update:mode': (mode: string) => 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 = parseColor(v)\n\n if (!c) return null\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\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 useRender(() => (\n <VSheet\n rounded={ props.rounded }\n elevation={ props.elevation }\n theme={ props.theme }\n class={[\n 'v-color-picker',\n ]}\n style={{\n '--v-color-picker-color-hsv': HSVtoCSS({ ...(currentColor.value ?? nullColor), a: 1 }),\n }}\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 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","VSheet","makeElevationProps","makeRoundedProps","makeThemeProps","useProxiedModel","provideDefaults","defineComponent","HSVtoCSS","useRender","extractColor","modes","nullColor","parseColor","onMounted","ref","VColorPicker","name","props","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","emits","color","setup","lastPickedColor","currentColor","undefined","c","value","h","updateColor","hsva","VSlider","trackColor","trackFillColor","rounded","elevation","theme","a","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 { VSheet } from '@/components/VSheet'\n\n// Composables\nimport { makeElevationProps } from '@/composables/elevation'\nimport { makeRoundedProps } from '@/composables/rounded'\nimport { makeThemeProps } from '@/composables/theme'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { provideDefaults } from '@/composables/defaults'\n\n// Utilities\nimport { defineComponent, HSVtoCSS, useRender } from '@/util'\nimport { extractColor, modes, nullColor, parseColor } from './util'\nimport { onMounted, ref } from 'vue'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util'\n\nexport const VColorPicker = defineComponent({\n name: 'VColorPicker',\n\n props: {\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,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<string[]>,\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<string[][]>,\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 width: {\n type: [Number, String],\n default: 300,\n },\n\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeThemeProps(),\n },\n\n emits: {\n 'update:modelValue': (color: any) => true,\n 'update:mode': (mode: string) => 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 = parseColor(v)\n\n if (!c) return null\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\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 <VSheet\n rounded={ props.rounded }\n elevation={ props.elevation }\n theme={ props.theme }\n class={[\n 'v-color-picker',\n ]}\n style={{\n '--v-color-picker-color-hsv': HSVtoCSS({ ...(currentColor.value ?? nullColor), a: 1 }),\n }}\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 return {}\n },\n})\n\nexport type VColorPicker = InstanceType<typeof VColorPicker>\n"],"mappings":"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"}
@@ -1,7 +1,8 @@
1
1
  .v-color-picker-canvas {
2
+ display: flex;
2
3
  position: relative;
3
4
  overflow: hidden;
4
- contain: strict;
5
+ contain: content;
5
6
  }
6
7
  .v-color-picker-canvas__dot {
7
8
  position: absolute;
@@ -2,7 +2,8 @@ import { createVNode as _createVNode } from "vue";
2
2
  // Styles
3
3
  import "./VColorPickerCanvas.css";
4
4
 
5
- // Utilities
5
+ // Composables
6
+ import { useResizeObserver } from "../../composables/resizeObserver.mjs"; // Utilities
6
7
  import { clamp, convertToUnit, defineComponent, getEventCoordinates, useRender } from "../../util/index.mjs";
7
8
  import { computed, onMounted, ref, watch } from 'vue';
8
9
 
@@ -55,6 +56,19 @@ export const VColorPickerCanvas = defineComponent({
55
56
  };
56
57
  });
57
58
  const canvasRef = ref();
59
+ const canvasWidth = ref(parseFloat(props.width));
60
+ const canvasHeight = ref(parseFloat(props.height));
61
+ const {
62
+ resizeRef
63
+ } = useResizeObserver(entries => {
64
+ if (!resizeRef.value?.offsetParent) return;
65
+ const {
66
+ width,
67
+ height
68
+ } = entries[0].contentRect;
69
+ canvasWidth.value = width;
70
+ canvasHeight.value = height;
71
+ });
58
72
  function updateDotPosition(x, y, rect) {
59
73
  const {
60
74
  left,
@@ -94,36 +108,30 @@ export const VColorPickerCanvas = defineComponent({
94
108
  window.removeEventListener('touchend', handleMouseUp);
95
109
  }
96
110
  watch(dotPosition, () => {
97
- var _props$color, _props$color2;
98
111
  if (isOutsideUpdate.value) {
99
112
  isOutsideUpdate.value = false;
100
113
  return;
101
114
  }
102
115
  if (!canvasRef.value) return;
103
- const {
104
- width,
105
- height
106
- } = canvasRef.value.getBoundingClientRect();
107
116
  const {
108
117
  x,
109
118
  y
110
119
  } = dotPosition.value;
111
120
  emit('update:color', {
112
- h: ((_props$color = props.color) == null ? void 0 : _props$color.h) ?? 0,
113
- s: clamp(x, 0, width) / width,
114
- v: 1 - clamp(y, 0, height) / height,
115
- a: ((_props$color2 = props.color) == null ? void 0 : _props$color2.a) ?? 1
121
+ h: props.color?.h ?? 0,
122
+ s: clamp(x, 0, canvasWidth.value) / canvasWidth.value,
123
+ v: 1 - clamp(y, 0, canvasHeight.value) / canvasHeight.value,
124
+ a: props.color?.a ?? 1
116
125
  });
117
126
  });
118
127
  function updateCanvas() {
119
- var _props$color3;
120
128
  if (!canvasRef.value) return;
121
129
  const canvas = canvasRef.value;
122
130
  const ctx = canvas.getContext('2d');
123
131
  if (!ctx) return;
124
132
  const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0);
125
133
  saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)'); // white
126
- saturationGradient.addColorStop(1, `hsla(${((_props$color3 = props.color) == null ? void 0 : _props$color3.h) ?? 0}, 100%, 50%, 1)`);
134
+ saturationGradient.addColorStop(1, `hsla(${props.color?.h ?? 0}, 100%, 50%, 1)`);
127
135
  ctx.fillStyle = saturationGradient;
128
136
  ctx.fillRect(0, 0, canvas.width, canvas.height);
129
137
  const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height);
@@ -132,22 +140,30 @@ export const VColorPickerCanvas = defineComponent({
132
140
  ctx.fillStyle = valueGradient;
133
141
  ctx.fillRect(0, 0, canvas.width, canvas.height);
134
142
  }
135
- watch(() => {
136
- var _props$color4;
137
- return (_props$color4 = props.color) == null ? void 0 : _props$color4.h;
138
- }, updateCanvas, {
143
+ watch(() => props.color?.h, updateCanvas, {
139
144
  immediate: true
140
145
  });
146
+ watch(() => [canvasWidth.value, canvasHeight.value], (newVal, oldVal) => {
147
+ updateCanvas();
148
+ dotPosition.value = {
149
+ x: dotPosition.value.x * newVal[0] / oldVal[0],
150
+ y: dotPosition.value.y * newVal[1] / oldVal[1]
151
+ };
152
+ }, {
153
+ flush: 'post'
154
+ });
141
155
  watch(() => props.color, () => {
142
156
  if (isInteracting.value) {
143
157
  isInteracting.value = false;
144
158
  return;
145
159
  }
146
- if (!props.color) return;
147
160
  isOutsideUpdate.value = true;
148
- dotPosition.value = {
149
- x: props.color.s * parseInt(props.width, 10),
150
- y: (1 - props.color.v) * parseInt(props.height, 10)
161
+ dotPosition.value = props.color ? {
162
+ x: props.color.s * canvasWidth.value,
163
+ y: (1 - props.color.v) * canvasHeight.value
164
+ } : {
165
+ x: 0,
166
+ y: 0
151
167
  };
152
168
  }, {
153
169
  deep: true,
@@ -155,19 +171,16 @@ export const VColorPickerCanvas = defineComponent({
155
171
  });
156
172
  onMounted(() => updateCanvas());
157
173
  useRender(() => _createVNode("div", {
174
+ "ref": resizeRef,
158
175
  "class": "v-color-picker-canvas",
159
- "style": {
160
- width: convertToUnit(props.width),
161
- height: convertToUnit(props.height)
162
- },
163
176
  "onClick": handleClick,
164
177
  "onMousedown": handleMouseDown,
165
178
  "onTouchstart": handleMouseDown
166
179
  }, [_createVNode("canvas", {
167
180
  "ref": canvasRef,
168
- "width": props.width,
169
- "height": props.height
170
- }, null), _createVNode("div", {
181
+ "width": canvasWidth.value,
182
+ "height": canvasHeight.value
183
+ }, null), props.color && _createVNode("div", {
171
184
  "class": ['v-color-picker-canvas__dot', {
172
185
  'v-color-picker-canvas__dot--disabled': props.disabled
173
186
  }],
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPickerCanvas.mjs","names":["clamp","convertToUnit","defineComponent","getEventCoordinates","useRender","computed","onMounted","ref","watch","VColorPickerCanvas","name","props","color","type","Object","disabled","Boolean","dotSize","Number","String","default","height","width","emits","hue","setup","emit","isInteracting","isOutsideUpdate","dotPosition","x","y","dotStyles","value","radius","parseInt","transform","canvasRef","updateDotPosition","rect","left","top","handleClick","e","clientX","clientY","getBoundingClientRect","handleMouseDown","preventDefault","window","addEventListener","handleMouseMove","handleMouseUp","coords","removeEventListener","h","s","v","a","updateCanvas","canvas","ctx","getContext","saturationGradient","createLinearGradient","addColorStop","fillStyle","fillRect","valueGradient","immediate","deep"],"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerCanvas.sass'\n\n// Utilities\nimport { clamp, convertToUnit, defineComponent, getEventCoordinates, useRender } from '@/util'\nimport { computed, onMounted, ref, watch } from 'vue'\n\n// Types\nimport type { HSV } from '@/util'\nimport type { PropType } from 'vue'\n\nexport const VColorPickerCanvas = defineComponent({\n name: 'VColorPickerCanvas',\n\n props: {\n color: {\n type: Object as PropType<HSV | null>,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:position': (hue: any) => true,\n },\n\n setup (props, { emit }) {\n const isInteracting = ref(false)\n const isOutsideUpdate = ref(false)\n const dotPosition = ref({ x: 0, y: 0 })\n\n const dotStyles = computed(() => {\n const { x, y } = dotPosition.value\n const radius = parseInt(props.dotSize, 10) / 2\n\n return {\n width: convertToUnit(props.dotSize),\n height: convertToUnit(props.dotSize),\n transform: `translate(${convertToUnit(x - radius)}, ${convertToUnit(y - radius)})`,\n }\n })\n\n const canvasRef = ref<HTMLCanvasElement | null>()\n\n function updateDotPosition (x: number, y: number, rect: DOMRect) {\n const { left, top, width, height } = rect\n dotPosition.value = {\n x: clamp(x - left, 0, width),\n y: clamp(y - top, 0, height),\n }\n }\n\n function handleClick (e: MouseEvent) {\n if (props.disabled || !canvasRef.value) return\n\n updateDotPosition(e.clientX, e.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseDown (e: MouseEvent | TouchEvent) {\n // To prevent selection while moving cursor\n e.preventDefault()\n\n if (props.disabled) return\n\n isInteracting.value = true\n\n window.addEventListener('mousemove', handleMouseMove)\n window.addEventListener('mouseup', handleMouseUp)\n window.addEventListener('touchmove', handleMouseMove)\n window.addEventListener('touchend', handleMouseUp)\n }\n\n function handleMouseMove (e: MouseEvent | TouchEvent) {\n if (props.disabled || !canvasRef.value) return\n\n isInteracting.value = true\n\n const coords = getEventCoordinates(e)\n\n updateDotPosition(coords.clientX, coords.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseUp () {\n window.removeEventListener('mousemove', handleMouseMove)\n window.removeEventListener('mouseup', handleMouseUp)\n window.removeEventListener('touchmove', handleMouseMove)\n window.removeEventListener('touchend', handleMouseUp)\n }\n\n watch(dotPosition, () => {\n if (isOutsideUpdate.value) {\n isOutsideUpdate.value = false\n return\n }\n\n if (!canvasRef.value) return\n\n const { width, height } = canvasRef.value.getBoundingClientRect()\n const { x, y } = dotPosition.value\n\n emit('update:color', {\n h: props.color?.h ?? 0,\n s: clamp(x, 0, width) / width,\n v: 1 - clamp(y, 0, height) / height,\n a: props.color?.a ?? 1,\n })\n })\n\n function updateCanvas () {\n if (!canvasRef.value) return\n\n const canvas = canvasRef.value\n const ctx = canvas.getContext('2d')\n\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${props.color?.h ?? 0}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n }\n\n watch(() => props.color?.h, updateCanvas, { immediate: true })\n\n watch(() => props.color, () => {\n if (isInteracting.value) {\n isInteracting.value = false\n return\n }\n\n if (!props.color) return\n\n isOutsideUpdate.value = true\n\n dotPosition.value = {\n x: props.color.s * parseInt(props.width, 10),\n y: (1 - props.color.v) * parseInt(props.height, 10),\n }\n }, { deep: true, immediate: true })\n\n onMounted(() => updateCanvas())\n\n useRender(() => (\n <div\n class=\"v-color-picker-canvas\"\n style={{\n width: convertToUnit(props.width),\n height: convertToUnit(props.height),\n }}\n onClick={ handleClick }\n onMousedown={ handleMouseDown }\n onTouchstart={ handleMouseDown }\n >\n <canvas\n ref={ canvasRef }\n width={ props.width }\n height={ props.height }\n />\n <div\n class={[\n 'v-color-picker-canvas__dot',\n {\n 'v-color-picker-canvas__dot--disabled': props.disabled,\n },\n ]}\n style={ dotStyles.value }\n />\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerCanvas = InstanceType<typeof VColorPickerCanvas>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VColorPickerCanvas.mjs","names":["useResizeObserver","clamp","convertToUnit","defineComponent","getEventCoordinates","useRender","computed","onMounted","ref","watch","VColorPickerCanvas","name","props","color","type","Object","disabled","Boolean","dotSize","Number","String","default","height","width","emits","hue","setup","emit","isInteracting","isOutsideUpdate","dotPosition","x","y","dotStyles","value","radius","parseInt","transform","canvasRef","canvasWidth","parseFloat","canvasHeight","resizeRef","entries","offsetParent","contentRect","updateDotPosition","rect","left","top","handleClick","e","clientX","clientY","getBoundingClientRect","handleMouseDown","preventDefault","window","addEventListener","handleMouseMove","handleMouseUp","coords","removeEventListener","h","s","v","a","updateCanvas","canvas","ctx","getContext","saturationGradient","createLinearGradient","addColorStop","fillStyle","fillRect","valueGradient","immediate","newVal","oldVal","flush","deep"],"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerCanvas.sass'\n\n// Composables\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { clamp, convertToUnit, defineComponent, getEventCoordinates, useRender } from '@/util'\nimport { computed, onMounted, ref, watch } from 'vue'\n\n// Types\nimport type { HSV } from '@/util'\nimport type { PropType } from 'vue'\n\nexport const VColorPickerCanvas = defineComponent({\n name: 'VColorPickerCanvas',\n\n props: {\n color: {\n type: Object as PropType<HSV | null>,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:position': (hue: any) => true,\n },\n\n setup (props, { emit }) {\n const isInteracting = ref(false)\n const isOutsideUpdate = ref(false)\n const dotPosition = ref({ x: 0, y: 0 })\n\n const dotStyles = computed(() => {\n const { x, y } = dotPosition.value\n const radius = parseInt(props.dotSize, 10) / 2\n\n return {\n width: convertToUnit(props.dotSize),\n height: convertToUnit(props.dotSize),\n transform: `translate(${convertToUnit(x - radius)}, ${convertToUnit(y - radius)})`,\n }\n })\n\n const canvasRef = ref<HTMLCanvasElement | null>()\n const canvasWidth = ref(parseFloat(props.width))\n const canvasHeight = ref(parseFloat(props.height))\n const { resizeRef } = useResizeObserver(entries => {\n if (!resizeRef.value?.offsetParent) return\n\n const { width, height } = entries[0].contentRect\n\n canvasWidth.value = width\n canvasHeight.value = height\n })\n\n function updateDotPosition (x: number, y: number, rect: DOMRect) {\n const { left, top, width, height } = rect\n dotPosition.value = {\n x: clamp(x - left, 0, width),\n y: clamp(y - top, 0, height),\n }\n }\n\n function handleClick (e: MouseEvent) {\n if (props.disabled || !canvasRef.value) return\n\n updateDotPosition(e.clientX, e.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseDown (e: MouseEvent | TouchEvent) {\n // To prevent selection while moving cursor\n e.preventDefault()\n\n if (props.disabled) return\n\n isInteracting.value = true\n\n window.addEventListener('mousemove', handleMouseMove)\n window.addEventListener('mouseup', handleMouseUp)\n window.addEventListener('touchmove', handleMouseMove)\n window.addEventListener('touchend', handleMouseUp)\n }\n\n function handleMouseMove (e: MouseEvent | TouchEvent) {\n if (props.disabled || !canvasRef.value) return\n\n isInteracting.value = true\n\n const coords = getEventCoordinates(e)\n\n updateDotPosition(coords.clientX, coords.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseUp () {\n window.removeEventListener('mousemove', handleMouseMove)\n window.removeEventListener('mouseup', handleMouseUp)\n window.removeEventListener('touchmove', handleMouseMove)\n window.removeEventListener('touchend', handleMouseUp)\n }\n\n watch(dotPosition, () => {\n if (isOutsideUpdate.value) {\n isOutsideUpdate.value = false\n return\n }\n\n if (!canvasRef.value) return\n\n const { x, y } = dotPosition.value\n\n emit('update:color', {\n h: props.color?.h ?? 0,\n s: clamp(x, 0, canvasWidth.value) / canvasWidth.value,\n v: 1 - clamp(y, 0, canvasHeight.value) / canvasHeight.value,\n a: props.color?.a ?? 1,\n })\n })\n\n function updateCanvas () {\n if (!canvasRef.value) return\n\n const canvas = canvasRef.value\n const ctx = canvas.getContext('2d')\n\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${props.color?.h ?? 0}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n }\n\n watch(() => props.color?.h, updateCanvas, { immediate: true })\n watch(() => [canvasWidth.value, canvasHeight.value], (newVal, oldVal) => {\n updateCanvas()\n dotPosition.value = {\n x: dotPosition.value.x * newVal[0] / oldVal[0],\n y: dotPosition.value.y * newVal[1] / oldVal[1],\n }\n }, { flush: 'post' })\n\n watch(() => props.color, () => {\n if (isInteracting.value) {\n isInteracting.value = false\n return\n }\n\n isOutsideUpdate.value = true\n\n dotPosition.value = props.color ? {\n x: props.color.s * canvasWidth.value,\n y: (1 - props.color.v) * canvasHeight.value,\n } : { x: 0, y: 0 }\n }, { deep: true, immediate: true })\n\n onMounted(() => updateCanvas())\n\n useRender(() => (\n <div\n ref={ resizeRef }\n class=\"v-color-picker-canvas\"\n onClick={ handleClick }\n onMousedown={ handleMouseDown }\n onTouchstart={ handleMouseDown }\n >\n <canvas\n ref={ canvasRef }\n width={ canvasWidth.value }\n height={ canvasHeight.value }\n />\n { props.color && (\n <div\n class={[\n 'v-color-picker-canvas__dot',\n {\n 'v-color-picker-canvas__dot--disabled': props.disabled,\n },\n ]}\n style={ dotStyles.value }\n />\n )}\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerCanvas = InstanceType<typeof VColorPickerCanvas>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,iBAAiB,gDAE1B;AAAA,SACSC,KAAK,EAAEC,aAAa,EAAEC,eAAe,EAAEC,mBAAmB,EAAEC,SAAS;AAC9E,SAASC,QAAQ,EAAEC,SAAS,EAAEC,GAAG,EAAEC,KAAK,QAAQ,KAAK;;AAErD;;AAIA,OAAO,MAAMC,kBAAkB,GAAGP,eAAe,CAAC;EAChDQ,IAAI,EAAE,oBAAoB;EAE1BC,KAAK,EAAE;IACLC,KAAK,EAAE;MACLC,IAAI,EAAEC;IACR,CAAC;IACDC,QAAQ,EAAEC,OAAO;IACjBC,OAAO,EAAE;MACPJ,IAAI,EAAE,CAACK,MAAM,EAAEC,MAAM,CAAC;MACtBC,OAAO,EAAE;IACX,CAAC;IACDC,MAAM,EAAE;MACNR,IAAI,EAAE,CAACK,MAAM,EAAEC,MAAM,CAAC;MACtBC,OAAO,EAAE;IACX,CAAC;IACDE,KAAK,EAAE;MACLT,IAAI,EAAE,CAACK,MAAM,EAAEC,MAAM,CAAC;MACtBC,OAAO,EAAE;IACX;EACF,CAAC;EAEDG,KAAK,EAAE;IACL,cAAc,EAAGX,KAAU,IAAK,IAAI;IACpC,iBAAiB,EAAGY,GAAQ,IAAK;EACnC,CAAC;EAEDC,KAAK,CAAEd,KAAK,QAAY;IAAA,IAAV;MAAEe;IAAK,CAAC;IACpB,MAAMC,aAAa,GAAGpB,GAAG,CAAC,KAAK,CAAC;IAChC,MAAMqB,eAAe,GAAGrB,GAAG,CAAC,KAAK,CAAC;IAClC,MAAMsB,WAAW,GAAGtB,GAAG,CAAC;MAAEuB,CAAC,EAAE,CAAC;MAAEC,CAAC,EAAE;IAAE,CAAC,CAAC;IAEvC,MAAMC,SAAS,GAAG3B,QAAQ,CAAC,MAAM;MAC/B,MAAM;QAAEyB,CAAC;QAAEC;MAAE,CAAC,GAAGF,WAAW,CAACI,KAAK;MAClC,MAAMC,MAAM,GAAGC,QAAQ,CAACxB,KAAK,CAACM,OAAO,EAAE,EAAE,CAAC,GAAG,CAAC;MAE9C,OAAO;QACLK,KAAK,EAAErB,aAAa,CAACU,KAAK,CAACM,OAAO,CAAC;QACnCI,MAAM,EAAEpB,aAAa,CAACU,KAAK,CAACM,OAAO,CAAC;QACpCmB,SAAS,EAAG,aAAYnC,aAAa,CAAC6B,CAAC,GAAGI,MAAM,CAAE,KAAIjC,aAAa,CAAC8B,CAAC,GAAGG,MAAM,CAAE;MAClF,CAAC;IACH,CAAC,CAAC;IAEF,MAAMG,SAAS,GAAG9B,GAAG,EAA4B;IACjD,MAAM+B,WAAW,GAAG/B,GAAG,CAACgC,UAAU,CAAC5B,KAAK,CAACW,KAAK,CAAC,CAAC;IAChD,MAAMkB,YAAY,GAAGjC,GAAG,CAACgC,UAAU,CAAC5B,KAAK,CAACU,MAAM,CAAC,CAAC;IAClD,MAAM;MAAEoB;IAAU,CAAC,GAAG1C,iBAAiB,CAAC2C,OAAO,IAAI;MACjD,IAAI,CAACD,SAAS,CAACR,KAAK,EAAEU,YAAY,EAAE;MAEpC,MAAM;QAAErB,KAAK;QAAED;MAAO,CAAC,GAAGqB,OAAO,CAAC,CAAC,CAAC,CAACE,WAAW;MAEhDN,WAAW,CAACL,KAAK,GAAGX,KAAK;MACzBkB,YAAY,CAACP,KAAK,GAAGZ,MAAM;IAC7B,CAAC,CAAC;IAEF,SAASwB,iBAAiB,CAAEf,CAAS,EAAEC,CAAS,EAAEe,IAAa,EAAE;MAC/D,MAAM;QAAEC,IAAI;QAAEC,GAAG;QAAE1B,KAAK;QAAED;MAAO,CAAC,GAAGyB,IAAI;MACzCjB,WAAW,CAACI,KAAK,GAAG;QAClBH,CAAC,EAAE9B,KAAK,CAAC8B,CAAC,GAAGiB,IAAI,EAAE,CAAC,EAAEzB,KAAK,CAAC;QAC5BS,CAAC,EAAE/B,KAAK,CAAC+B,CAAC,GAAGiB,GAAG,EAAE,CAAC,EAAE3B,MAAM;MAC7B,CAAC;IACH;IAEA,SAAS4B,WAAW,CAAEC,CAAa,EAAE;MACnC,IAAIvC,KAAK,CAACI,QAAQ,IAAI,CAACsB,SAAS,CAACJ,KAAK,EAAE;MAExCY,iBAAiB,CAACK,CAAC,CAACC,OAAO,EAAED,CAAC,CAACE,OAAO,EAAEf,SAAS,CAACJ,KAAK,CAACoB,qBAAqB,EAAE,CAAC;IAClF;IAEA,SAASC,eAAe,CAAEJ,CAA0B,EAAE;MACpD;MACAA,CAAC,CAACK,cAAc,EAAE;MAElB,IAAI5C,KAAK,CAACI,QAAQ,EAAE;MAEpBY,aAAa,CAACM,KAAK,GAAG,IAAI;MAE1BuB,MAAM,CAACC,gBAAgB,CAAC,WAAW,EAAEC,eAAe,CAAC;MACrDF,MAAM,CAACC,gBAAgB,CAAC,SAAS,EAAEE,aAAa,CAAC;MACjDH,MAAM,CAACC,gBAAgB,CAAC,WAAW,EAAEC,eAAe,CAAC;MACrDF,MAAM,CAACC,gBAAgB,CAAC,UAAU,EAAEE,aAAa,CAAC;IACpD;IAEA,SAASD,eAAe,CAAER,CAA0B,EAAE;MACpD,IAAIvC,KAAK,CAACI,QAAQ,IAAI,CAACsB,SAAS,CAACJ,KAAK,EAAE;MAExCN,aAAa,CAACM,KAAK,GAAG,IAAI;MAE1B,MAAM2B,MAAM,GAAGzD,mBAAmB,CAAC+C,CAAC,CAAC;MAErCL,iBAAiB,CAACe,MAAM,CAACT,OAAO,EAAES,MAAM,CAACR,OAAO,EAAEf,SAAS,CAACJ,KAAK,CAACoB,qBAAqB,EAAE,CAAC;IAC5F;IAEA,SAASM,aAAa,GAAI;MACxBH,MAAM,CAACK,mBAAmB,CAAC,WAAW,EAAEH,eAAe,CAAC;MACxDF,MAAM,CAACK,mBAAmB,CAAC,SAAS,EAAEF,aAAa,CAAC;MACpDH,MAAM,CAACK,mBAAmB,CAAC,WAAW,EAAEH,eAAe,CAAC;MACxDF,MAAM,CAACK,mBAAmB,CAAC,UAAU,EAAEF,aAAa,CAAC;IACvD;IAEAnD,KAAK,CAACqB,WAAW,EAAE,MAAM;MACvB,IAAID,eAAe,CAACK,KAAK,EAAE;QACzBL,eAAe,CAACK,KAAK,GAAG,KAAK;QAC7B;MACF;MAEA,IAAI,CAACI,SAAS,CAACJ,KAAK,EAAE;MAEtB,MAAM;QAAEH,CAAC;QAAEC;MAAE,CAAC,GAAGF,WAAW,CAACI,KAAK;MAElCP,IAAI,CAAC,cAAc,EAAE;QACnBoC,CAAC,EAAEnD,KAAK,CAACC,KAAK,EAAEkD,CAAC,IAAI,CAAC;QACtBC,CAAC,EAAE/D,KAAK,CAAC8B,CAAC,EAAE,CAAC,EAAEQ,WAAW,CAACL,KAAK,CAAC,GAAGK,WAAW,CAACL,KAAK;QACrD+B,CAAC,EAAE,CAAC,GAAGhE,KAAK,CAAC+B,CAAC,EAAE,CAAC,EAAES,YAAY,CAACP,KAAK,CAAC,GAAGO,YAAY,CAACP,KAAK;QAC3DgC,CAAC,EAAEtD,KAAK,CAACC,KAAK,EAAEqD,CAAC,IAAI;MACvB,CAAC,CAAC;IACJ,CAAC,CAAC;IAEF,SAASC,YAAY,GAAI;MACvB,IAAI,CAAC7B,SAAS,CAACJ,KAAK,EAAE;MAEtB,MAAMkC,MAAM,GAAG9B,SAAS,CAACJ,KAAK;MAC9B,MAAMmC,GAAG,GAAGD,MAAM,CAACE,UAAU,CAAC,IAAI,CAAC;MAEnC,IAAI,CAACD,GAAG,EAAE;MAEV,MAAME,kBAAkB,GAAGF,GAAG,CAACG,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAEJ,MAAM,CAAC7C,KAAK,EAAE,CAAC,CAAC;MAC1EgD,kBAAkB,CAACE,YAAY,CAAC,CAAC,EAAE,sBAAsB,CAAC,EAAC;MAC3DF,kBAAkB,CAACE,YAAY,CAAC,CAAC,EAAG,QAAO7D,KAAK,CAACC,KAAK,EAAEkD,CAAC,IAAI,CAAE,iBAAgB,CAAC;MAChFM,GAAG,CAACK,SAAS,GAAGH,kBAAkB;MAClCF,GAAG,CAACM,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAEP,MAAM,CAAC7C,KAAK,EAAE6C,MAAM,CAAC9C,MAAM,CAAC;MAE/C,MAAMsD,aAAa,GAAGP,GAAG,CAACG,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAEJ,MAAM,CAAC9C,MAAM,CAAC;MACtEsD,aAAa,CAACH,YAAY,CAAC,CAAC,EAAE,sBAAsB,CAAC,EAAC;MACtDG,aAAa,CAACH,YAAY,CAAC,CAAC,EAAE,oBAAoB,CAAC,EAAC;MACpDJ,GAAG,CAACK,SAAS,GAAGE,aAAa;MAC7BP,GAAG,CAACM,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAEP,MAAM,CAAC7C,KAAK,EAAE6C,MAAM,CAAC9C,MAAM,CAAC;IACjD;IAEAb,KAAK,CAAC,MAAMG,KAAK,CAACC,KAAK,EAAEkD,CAAC,EAAEI,YAAY,EAAE;MAAEU,SAAS,EAAE;IAAK,CAAC,CAAC;IAC9DpE,KAAK,CAAC,MAAM,CAAC8B,WAAW,CAACL,KAAK,EAAEO,YAAY,CAACP,KAAK,CAAC,EAAE,CAAC4C,MAAM,EAAEC,MAAM,KAAK;MACvEZ,YAAY,EAAE;MACdrC,WAAW,CAACI,KAAK,GAAG;QAClBH,CAAC,EAAED,WAAW,CAACI,KAAK,CAACH,CAAC,GAAG+C,MAAM,CAAC,CAAC,CAAC,GAAGC,MAAM,CAAC,CAAC,CAAC;QAC9C/C,CAAC,EAAEF,WAAW,CAACI,KAAK,CAACF,CAAC,GAAG8C,MAAM,CAAC,CAAC,CAAC,GAAGC,MAAM,CAAC,CAAC;MAC/C,CAAC;IACH,CAAC,EAAE;MAAEC,KAAK,EAAE;IAAO,CAAC,CAAC;IAErBvE,KAAK,CAAC,MAAMG,KAAK,CAACC,KAAK,EAAE,MAAM;MAC7B,IAAIe,aAAa,CAACM,KAAK,EAAE;QACvBN,aAAa,CAACM,KAAK,GAAG,KAAK;QAC3B;MACF;MAEAL,eAAe,CAACK,KAAK,GAAG,IAAI;MAE5BJ,WAAW,CAACI,KAAK,GAAGtB,KAAK,CAACC,KAAK,GAAG;QAChCkB,CAAC,EAAEnB,KAAK,CAACC,KAAK,CAACmD,CAAC,GAAGzB,WAAW,CAACL,KAAK;QACpCF,CAAC,EAAE,CAAC,CAAC,GAAGpB,KAAK,CAACC,KAAK,CAACoD,CAAC,IAAIxB,YAAY,CAACP;MACxC,CAAC,GAAG;QAAEH,CAAC,EAAE,CAAC;QAAEC,CAAC,EAAE;MAAE,CAAC;IACpB,CAAC,EAAE;MAAEiD,IAAI,EAAE,IAAI;MAAEJ,SAAS,EAAE;IAAK,CAAC,CAAC;IAEnCtE,SAAS,CAAC,MAAM4D,YAAY,EAAE,CAAC;IAE/B9D,SAAS,CAAC;MAAA,OAEAqC,SAAS;MAAA,SACT,uBAAuB;MAAA,WACnBQ,WAAW;MAAA,eACPK,eAAe;MAAA,gBACdA;IAAe;MAAA,OAGtBjB,SAAS;MAAA,SACPC,WAAW,CAACL,KAAK;MAAA,UAChBO,YAAY,CAACP;IAAK,UAE3BtB,KAAK,CAACC,KAAK;MAAA,SAEF,CACL,4BAA4B,EAC5B;QACE,sCAAsC,EAAED,KAAK,CAACI;MAChD,CAAC,CACF;MAAA,SACOiB,SAAS,CAACC;IAAK,QAE1B,EAEJ,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
@@ -3,9 +3,10 @@
3
3
 
4
4
  .v-color-picker-canvas
5
5
  $root: &
6
+ display: flex
6
7
  position: relative
7
8
  overflow: hidden
8
- contain: strict
9
+ contain: content
9
10
 
10
11
  &__dot
11
12
  position: absolute
@@ -6,7 +6,7 @@ import "./VColorPickerEdit.css";
6
6
  import { VBtn } from "../VBtn/index.mjs"; // Utilities
7
7
  import { computed } from 'vue';
8
8
  import { defineComponent, useRender } from "../../util/index.mjs";
9
- import { modes } from "./util/index.mjs"; // Types
9
+ import { modes, nullColor } from "./util/index.mjs"; // Types
10
10
  const VColorPickerInput = _ref => {
11
11
  let {
12
12
  label,
@@ -47,11 +47,10 @@ export const VColorPickerEdit = defineComponent({
47
47
  }));
48
48
  });
49
49
  const inputs = computed(() => {
50
- var _mode$inputs;
51
50
  const mode = enabledModes.value.find(m => m.name === props.mode);
52
51
  if (!mode) return [];
53
- const color = props.color ? mode.to(props.color) : {};
54
- return (_mode$inputs = mode.inputs) == null ? void 0 : _mode$inputs.map(_ref3 => {
52
+ const color = props.color ? mode.to(props.color) : null;
53
+ return mode.inputs?.map(_ref3 => {
55
54
  let {
56
55
  getValue,
57
56
  getColor,
@@ -61,29 +60,26 @@ export const VColorPickerEdit = defineComponent({
61
60
  ...mode.inputProps,
62
61
  ...inputProps,
63
62
  disabled: props.disabled,
64
- value: getValue(color),
63
+ value: color && getValue(color),
65
64
  onChange: e => {
66
65
  const target = e.target;
67
66
  if (!target) return;
68
- emit('update:color', mode.from(getColor(color, target.value)));
67
+ emit('update:color', mode.from(getColor(color ?? nullColor, target.value)));
69
68
  }
70
69
  };
71
70
  });
72
71
  });
73
- useRender(() => {
74
- var _inputs$value;
75
- return _createVNode("div", {
76
- "class": "v-color-picker-edit"
77
- }, [(_inputs$value = inputs.value) == null ? void 0 : _inputs$value.map(props => _createVNode(VColorPickerInput, props, null)), enabledModes.value.length > 1 && _createVNode(VBtn, {
78
- "icon": "$unfold",
79
- "size": "x-small",
80
- "variant": "plain",
81
- "onClick": () => {
82
- const mi = enabledModes.value.findIndex(m => m.name === props.mode);
83
- emit('update:mode', enabledModes.value[(mi + 1) % enabledModes.value.length].name);
84
- }
85
- }, null)]);
86
- });
72
+ useRender(() => _createVNode("div", {
73
+ "class": "v-color-picker-edit"
74
+ }, [inputs.value?.map(props => _createVNode(VColorPickerInput, props, null)), enabledModes.value.length > 1 && _createVNode(VBtn, {
75
+ "icon": "$unfold",
76
+ "size": "x-small",
77
+ "variant": "plain",
78
+ "onClick": () => {
79
+ const mi = enabledModes.value.findIndex(m => m.name === props.mode);
80
+ emit('update:mode', enabledModes.value[(mi + 1) % enabledModes.value.length].name);
81
+ }
82
+ }, null)]));
87
83
  return {};
88
84
  }
89
85
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPickerEdit.mjs","names":["VBtn","computed","defineComponent","useRender","modes","VColorPickerInput","label","rest","VColorPickerEdit","name","props","color","Object","disabled","Boolean","mode","type","String","default","validator","v","keys","includes","Array","isArray","every","m","emits","setup","emit","enabledModes","map","key","inputs","value","find","to","getValue","getColor","inputProps","onChange","e","target","from","length","mi","findIndex"],"sources":["../../../src/components/VColorPicker/VColorPickerEdit.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerEdit.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\nimport { modes } from './util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util/colorUtils'\n\nconst VColorPickerInput = ({ label, ...rest }: any) => {\n return (\n <div\n class=\"v-color-picker-edit__input\"\n >\n <input {...rest} />\n <span>{ label }</span>\n </div>\n )\n}\n\nexport const VColorPickerEdit = defineComponent({\n name: 'VColorPickerEdit',\n\n props: {\n color: Object as PropType<HSV | null>,\n disabled: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<string[]>,\n default: () => Object.keys(modes),\n validator: (v: any) => Array.isArray(v) && v.every(m => Object.keys(modes).includes(m)),\n },\n },\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:mode': (mode: string) => true,\n },\n\n setup (props, { emit }) {\n const enabledModes = computed(() => {\n return props.modes.map(key => ({ ...modes[key], name: key }))\n })\n\n const inputs = computed(() => {\n const mode = enabledModes.value.find(m => m.name === props.mode)\n\n if (!mode) return []\n\n const color = props.color ? mode.to(props.color) : {}\n\n return mode.inputs?.map(({ getValue, getColor, ...inputProps }) => {\n return {\n ...mode.inputProps,\n ...inputProps,\n disabled: props.disabled,\n value: getValue(color),\n onChange: (e: InputEvent) => {\n const target = e.target as HTMLInputElement | null\n\n if (!target) return\n\n emit('update:color', mode.from(getColor(color, target.value)))\n },\n }\n })\n })\n\n useRender(() => (\n <div\n class=\"v-color-picker-edit\"\n >\n { inputs.value?.map(props => (\n <VColorPickerInput {...props} />\n )) }\n { enabledModes.value.length > 1 && (\n <VBtn\n icon=\"$unfold\"\n size=\"x-small\"\n variant=\"plain\"\n onClick={ () => {\n const mi = enabledModes.value.findIndex(m => m.name === props.mode)\n\n emit('update:mode', enabledModes.value[(mi + 1) % enabledModes.value.length].name)\n } }\n />\n ) }\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerEdit = InstanceType<typeof VColorPickerEdit>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VColorPickerEdit.mjs","names":["VBtn","computed","defineComponent","useRender","modes","nullColor","VColorPickerInput","label","rest","VColorPickerEdit","name","props","color","Object","disabled","Boolean","mode","type","String","default","validator","v","keys","includes","Array","isArray","every","m","emits","setup","emit","enabledModes","map","key","inputs","value","find","to","getValue","getColor","inputProps","onChange","e","target","from","length","mi","findIndex"],"sources":["../../../src/components/VColorPicker/VColorPickerEdit.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerEdit.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\nimport { modes, nullColor } from './util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util/colorUtils'\n\nconst VColorPickerInput = ({ label, ...rest }: any) => {\n return (\n <div\n class=\"v-color-picker-edit__input\"\n >\n <input {...rest} />\n <span>{ label }</span>\n </div>\n )\n}\n\nexport const VColorPickerEdit = defineComponent({\n name: 'VColorPickerEdit',\n\n props: {\n color: Object as PropType<HSV | null>,\n disabled: Boolean,\n mode: {\n type: String,\n default: 'rgba',\n validator: (v: string) => Object.keys(modes).includes(v),\n },\n modes: {\n type: Array as PropType<string[]>,\n default: () => Object.keys(modes),\n validator: (v: any) => Array.isArray(v) && v.every(m => Object.keys(modes).includes(m)),\n },\n },\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:mode': (mode: string) => true,\n },\n\n setup (props, { emit }) {\n const enabledModes = computed(() => {\n return props.modes.map(key => ({ ...modes[key], name: key }))\n })\n\n const inputs = computed(() => {\n const mode = enabledModes.value.find(m => m.name === props.mode)\n\n if (!mode) return []\n\n const color = props.color ? mode.to(props.color) : null\n\n return mode.inputs?.map(({ getValue, getColor, ...inputProps }) => {\n return {\n ...mode.inputProps,\n ...inputProps,\n disabled: props.disabled,\n value: color && getValue(color),\n onChange: (e: InputEvent) => {\n const target = e.target as HTMLInputElement | null\n\n if (!target) return\n\n emit('update:color', mode.from(getColor(color ?? nullColor, target.value)))\n },\n }\n })\n })\n\n useRender(() => (\n <div\n class=\"v-color-picker-edit\"\n >\n { inputs.value?.map(props => (\n <VColorPickerInput {...props} />\n )) }\n { enabledModes.value.length > 1 && (\n <VBtn\n icon=\"$unfold\"\n size=\"x-small\"\n variant=\"plain\"\n onClick={ () => {\n const mi = enabledModes.value.findIndex(m => m.name === props.mode)\n\n emit('update:mode', enabledModes.value[(mi + 1) % enabledModes.value.length].name)\n } }\n />\n ) }\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerEdit = InstanceType<typeof VColorPickerEdit>\n"],"mappings":"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"}