@vuetify/nightly 3.0.0-beta.3 → 3.0.0-beta.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 (441) hide show
  1. package/CHANGELOG.md +43 -2
  2. package/dist/_component-variables.sass +61 -0
  3. package/dist/json/attributes.json +261 -205
  4. package/dist/json/importMap.json +175 -219
  5. package/dist/json/tags.json +74 -104
  6. package/dist/json/web-types.json +880 -835
  7. package/dist/vuetify.css +597 -407
  8. package/dist/vuetify.d.ts +6770 -2144
  9. package/dist/vuetify.esm.js +9075 -8454
  10. package/dist/vuetify.esm.js.map +1 -1
  11. package/dist/vuetify.js +9074 -8453
  12. package/dist/vuetify.js.map +1 -1
  13. package/dist/vuetify.min.css +2 -2
  14. package/dist/vuetify.min.js +1078 -1040
  15. package/dist/vuetify.min.js.map +1 -1
  16. package/lib/blueprints/index.mjs +4 -0
  17. package/lib/blueprints/index.mjs.map +1 -0
  18. package/lib/blueprints/md1.mjs +63 -0
  19. package/lib/blueprints/md1.mjs.map +1 -0
  20. package/lib/blueprints/md2.mjs +60 -0
  21. package/lib/blueprints/md2.mjs.map +1 -0
  22. package/lib/blueprints/md3.mjs +74 -0
  23. package/lib/blueprints/md3.mjs.map +1 -0
  24. package/lib/components/VAlert/VAlert.css +5 -5
  25. package/lib/components/VAlert/VAlert.mjs +8 -2
  26. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  27. package/lib/components/VAlert/VAlert.sass +0 -2
  28. package/lib/components/VApp/VApp.css +2 -5
  29. package/lib/components/VApp/VApp.mjs +3 -4
  30. package/lib/components/VApp/VApp.mjs.map +1 -1
  31. package/lib/components/VApp/VApp.sass +11 -12
  32. package/lib/components/VApp/variables.scss +6 -0
  33. package/lib/components/VAppBar/VAppBar.mjs +4 -3
  34. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  35. package/lib/components/VAppBar/VAppBar.sass +0 -1
  36. package/lib/components/VAppBar/VAppBarNavIcon.mjs +7 -12
  37. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  38. package/lib/components/VAppBar/VAppBarTitle.mjs +4 -3
  39. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  40. package/lib/components/VAppBar/_variables.scss +2 -0
  41. package/lib/components/VAutocomplete/VAutocomplete.mjs +54 -21
  42. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  43. package/lib/components/VAutocomplete/VAutocomplete.sass +0 -2
  44. package/lib/components/VAvatar/VAvatar.css +1 -1
  45. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  46. package/lib/components/VAvatar/VAvatar.sass +1 -2
  47. package/lib/components/VAvatar/_mixins.scss +0 -1
  48. package/lib/components/VBadge/VBadge.mjs +8 -7
  49. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  50. package/lib/components/VBadge/VBadge.sass +0 -1
  51. package/lib/components/VBadge/_variables.scss +2 -2
  52. package/lib/components/VBanner/VBanner.css +7 -7
  53. package/lib/components/VBanner/VBanner.mjs +24 -17
  54. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  55. package/lib/components/VBanner/VBanner.sass +6 -8
  56. package/lib/components/VBanner/VBannerActions.mjs +1 -1
  57. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  58. package/lib/components/VBanner/index.mjs +0 -2
  59. package/lib/components/VBanner/index.mjs.map +1 -1
  60. package/lib/components/VBottomNavigation/VBottomNavigation.css +4 -11
  61. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +4 -3
  62. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  63. package/lib/components/VBottomNavigation/VBottomNavigation.sass +5 -13
  64. package/lib/components/VBottomNavigation/_variables.scss +7 -8
  65. package/lib/components/VBreadcrumbs/VBreadcrumbs.css +13 -6
  66. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +30 -19
  67. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  68. package/lib/components/VBreadcrumbs/VBreadcrumbs.sass +8 -4
  69. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +5 -8
  70. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  71. package/lib/components/VBreadcrumbs/_variables.scss +2 -1
  72. package/lib/components/VBtn/VBtn.css +72 -15
  73. package/lib/components/VBtn/VBtn.mjs +70 -27
  74. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  75. package/lib/components/VBtn/VBtn.sass +70 -13
  76. package/lib/components/VBtn/_variables.scss +4 -1
  77. package/lib/components/VBtnGroup/VBtnGroup.sass +0 -1
  78. package/lib/components/VBtnGroup/_variables.scss +2 -0
  79. package/lib/components/VBtnToggle/VBtnToggle.sass +0 -1
  80. package/lib/components/VBtnToggle/_variables.scss +1 -0
  81. package/lib/components/VCard/VCard.css +86 -69
  82. package/lib/components/VCard/VCard.mjs +52 -66
  83. package/lib/components/VCard/VCard.mjs.map +1 -1
  84. package/lib/components/VCard/VCard.sass +74 -62
  85. package/lib/components/VCard/VCardActions.mjs +1 -1
  86. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  87. package/lib/components/VCard/VCardItem.mjs +88 -0
  88. package/lib/components/VCard/VCardItem.mjs.map +1 -0
  89. package/lib/components/VCard/_variables.scss +40 -24
  90. package/lib/components/VCard/index.mjs +1 -5
  91. package/lib/components/VCard/index.mjs.map +1 -1
  92. package/lib/components/VCarousel/VCarousel.mjs +5 -4
  93. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  94. package/lib/components/VCarousel/VCarousel.sass +0 -1
  95. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  96. package/lib/components/VCarousel/_variables.scss +1 -0
  97. package/lib/components/VCheckbox/VCheckbox.mjs +13 -46
  98. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  99. package/lib/components/VCheckbox/VCheckbox.sass +0 -1
  100. package/lib/components/VCheckbox/VCheckboxBtn.mjs +67 -0
  101. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -0
  102. package/lib/components/VCheckbox/index.mjs +1 -0
  103. package/lib/components/VCheckbox/index.mjs.map +1 -1
  104. package/lib/components/VChip/VChip.css +142 -65
  105. package/lib/components/VChip/VChip.mjs +77 -38
  106. package/lib/components/VChip/VChip.mjs.map +1 -1
  107. package/lib/components/VChip/VChip.sass +6 -1
  108. package/lib/components/VChip/_mixins.scss +26 -6
  109. package/lib/components/VChip/_variables.scss +1 -5
  110. package/lib/components/VChipGroup/VChipGroup.mjs +5 -4
  111. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  112. package/lib/components/VChipGroup/VChipGroup.sass +1 -1
  113. package/lib/components/VChipGroup/_variables.scss +1 -1
  114. package/lib/components/VCode/VCode.sass +1 -2
  115. package/lib/components/VCode/_variables.scss +1 -1
  116. package/lib/components/VColorPicker/VColorPicker.mjs +16 -10
  117. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  118. package/lib/components/VColorPicker/VColorPicker.sass +0 -1
  119. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +5 -4
  120. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  121. package/lib/components/VColorPicker/VColorPickerCanvas.sass +0 -1
  122. package/lib/components/VColorPicker/VColorPickerEdit.mjs +4 -3
  123. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  124. package/lib/components/VColorPicker/VColorPickerEdit.sass +0 -1
  125. package/lib/components/VColorPicker/VColorPickerPreview.mjs +4 -3
  126. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  127. package/lib/components/VColorPicker/VColorPickerPreview.sass +0 -1
  128. package/lib/components/VColorPicker/VColorPickerSwatches.mjs +6 -5
  129. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  130. package/lib/components/VColorPicker/VColorPickerSwatches.sass +0 -1
  131. package/lib/components/VColorPicker/_variables.scss +17 -10
  132. package/lib/components/VCombobox/VCombobox.mjs +52 -36
  133. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  134. package/lib/components/VCombobox/VCombobox.sass +0 -2
  135. package/lib/components/VCounter/VCounter.mjs +16 -16
  136. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  137. package/lib/components/VCounter/VCounter.sass +1 -2
  138. package/lib/components/VCounter/_variables.scss +2 -1
  139. package/lib/components/VDialog/VDialog.css +2 -5
  140. package/lib/components/VDialog/VDialog.mjs +25 -25
  141. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  142. package/lib/components/VDialog/VDialog.sass +1 -5
  143. package/lib/components/VDialog/_variables.scss +0 -1
  144. package/lib/components/VDivider/VDivider.mjs +16 -17
  145. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  146. package/lib/components/VDivider/VDivider.sass +0 -1
  147. package/lib/components/VDivider/_variables.scss +3 -1
  148. package/lib/components/VExpansionPanel/VExpansionPanel.css +1 -0
  149. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +9 -4
  150. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  151. package/lib/components/VExpansionPanel/VExpansionPanel.sass +1 -1
  152. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +7 -7
  153. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  154. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  155. package/lib/components/VExpansionPanel/_variables.scss +15 -10
  156. package/lib/components/VField/VField.css +11 -11
  157. package/lib/components/VField/VField.mjs +19 -12
  158. package/lib/components/VField/VField.mjs.map +1 -1
  159. package/lib/components/VField/VField.sass +8 -10
  160. package/lib/components/VField/VFieldLabel.mjs +8 -9
  161. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  162. package/lib/components/VField/_variables.scss +3 -3
  163. package/lib/components/VFileInput/VFileInput.css +3 -3
  164. package/lib/components/VFileInput/VFileInput.mjs +12 -7
  165. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  166. package/lib/components/VFileInput/VFileInput.sass +3 -4
  167. package/lib/components/VFooter/VFooter.mjs +4 -3
  168. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  169. package/lib/components/VFooter/VFooter.sass +0 -1
  170. package/lib/components/VFooter/_variables.scss +2 -1
  171. package/lib/components/VForm/VForm.mjs +3 -3
  172. package/lib/components/VForm/VForm.mjs.map +1 -1
  173. package/lib/components/VGrid/VCol.mjs.map +1 -1
  174. package/lib/components/VGrid/VContainer.mjs +4 -3
  175. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  176. package/lib/components/VGrid/VRow.mjs.map +1 -1
  177. package/lib/components/VIcon/VIcon.css +0 -8
  178. package/lib/components/VIcon/VIcon.mjs +20 -21
  179. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  180. package/lib/components/VIcon/VIcon.sass +0 -9
  181. package/lib/components/VIcon/_variables.scss +2 -5
  182. package/lib/components/VIcon/index.mjs.map +1 -1
  183. package/lib/components/VImg/VImg.sass +0 -1
  184. package/lib/components/VInput/VInput.mjs +13 -9
  185. package/lib/components/VInput/VInput.mjs.map +1 -1
  186. package/lib/components/VInput/VInput.sass +0 -1
  187. package/lib/components/VItemGroup/VItem.mjs +3 -0
  188. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  189. package/lib/components/VItemGroup/VItemGroup.sass +0 -1
  190. package/lib/components/VKbd/VKbd.sass +0 -1
  191. package/lib/components/VKbd/_variables.scss +1 -1
  192. package/lib/components/VLabel/VLabel.mjs +4 -3
  193. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  194. package/lib/components/VLabel/VLabel.sass +0 -1
  195. package/lib/components/VLabel/_variables.scss +1 -0
  196. package/lib/components/VLazy/VLazy.mjs +5 -3
  197. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  198. package/lib/components/VList/VList.css +2 -2
  199. package/lib/components/VList/VList.mjs +16 -18
  200. package/lib/components/VList/VList.mjs.map +1 -1
  201. package/lib/components/VList/VList.sass +1 -2
  202. package/lib/components/VList/VListChildren.mjs +7 -6
  203. package/lib/components/VList/VListChildren.mjs.map +1 -1
  204. package/lib/components/VList/VListGroup.mjs +45 -31
  205. package/lib/components/VList/VListGroup.mjs.map +1 -1
  206. package/lib/components/VList/VListItem.css +84 -58
  207. package/lib/components/VList/VListItem.mjs +78 -45
  208. package/lib/components/VList/VListItem.mjs.map +1 -1
  209. package/lib/components/VList/VListItem.sass +68 -40
  210. package/lib/components/VList/VListItemAction.mjs +8 -9
  211. package/lib/components/VList/VListItemAction.mjs.map +1 -1
  212. package/lib/components/VList/VListItemMedia.mjs +4 -3
  213. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  214. package/lib/components/VList/VListSubheader.mjs +4 -3
  215. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  216. package/lib/components/VList/_variables.scss +11 -5
  217. package/lib/components/VList/index.mjs +2 -5
  218. package/lib/components/VList/index.mjs.map +1 -1
  219. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +5 -3
  220. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  221. package/lib/components/VMain/VMain.mjs +4 -3
  222. package/lib/components/VMain/VMain.mjs.map +1 -1
  223. package/lib/components/VMain/VMain.sass +0 -1
  224. package/lib/components/VMain/_variables.scss +1 -1
  225. package/lib/components/VMenu/VMenu.mjs +5 -5
  226. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  227. package/lib/components/VMenu/VMenu.sass +0 -1
  228. package/lib/components/VMessages/VMessages.mjs +5 -3
  229. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  230. package/lib/components/VMessages/VMessages.sass +0 -1
  231. package/lib/components/VMessages/_variables.scss +1 -1
  232. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +10 -4
  233. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  234. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +0 -1
  235. package/lib/components/VNavigationDrawer/_variables.scss +2 -1
  236. package/lib/components/VNavigationDrawer/touch.mjs +5 -2
  237. package/lib/components/VNavigationDrawer/touch.mjs.map +1 -1
  238. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  239. package/lib/components/VOverlay/VOverlay.mjs +10 -8
  240. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  241. package/lib/components/VOverlay/VOverlay.sass +0 -1
  242. package/lib/components/VOverlay/locationStrategies.mjs +267 -78
  243. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -1
  244. package/lib/components/VOverlay/useActivator.mjs +4 -3
  245. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  246. package/lib/components/VOverlay/util/point.mjs +3 -3
  247. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  248. package/lib/components/VPagination/VPagination.mjs +41 -23
  249. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  250. package/lib/components/VPagination/VPagination.sass +0 -1
  251. package/lib/components/VParallax/VParallax.mjs +5 -5
  252. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  253. package/lib/components/VProgressCircular/VProgressCircular.mjs +6 -5
  254. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  255. package/lib/components/VProgressCircular/VProgressCircular.sass +0 -1
  256. package/lib/components/VProgressCircular/_variables.scss +2 -0
  257. package/lib/components/VProgressLinear/VProgressLinear.mjs +5 -3
  258. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  259. package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
  260. package/lib/components/VProgressLinear/_variables.scss +1 -0
  261. package/lib/components/VRadioGroup/VRadioGroup.mjs +6 -3
  262. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  263. package/lib/components/VRadioGroup/VRadioGroup.sass +5 -3
  264. package/lib/components/VRadioGroup/_variables.scss +3 -4
  265. package/lib/components/VRangeSlider/VRangeSlider.mjs +12 -13
  266. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  267. package/lib/components/VRating/VRating.mjs +6 -5
  268. package/lib/components/VRating/VRating.mjs.map +1 -1
  269. package/lib/components/VRating/VRating.sass +2 -1
  270. package/lib/components/VResponsive/VResponsive.mjs +7 -6
  271. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  272. package/lib/components/VSelect/VSelect.mjs +61 -22
  273. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  274. package/lib/components/VSelect/VSelect.sass +0 -2
  275. package/lib/components/VSelectionControl/VSelectionControl.css +1 -0
  276. package/lib/components/VSelectionControl/VSelectionControl.mjs +12 -10
  277. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  278. package/lib/components/VSelectionControl/VSelectionControl.sass +1 -1
  279. package/lib/components/VSelectionControl/_variables.scss +1 -0
  280. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +3 -3
  281. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  282. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +1 -6
  283. package/lib/components/VSelectionControlGroup/_variables.scss +1 -4
  284. package/lib/components/VSheet/VSheet.mjs +3 -3
  285. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  286. package/lib/components/VSheet/VSheet.sass +0 -1
  287. package/lib/components/VSheet/_variables.scss +3 -2
  288. package/lib/components/VSlideGroup/VSlideGroup.mjs +47 -49
  289. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  290. package/lib/components/VSlideGroup/VSlideGroup.sass +0 -1
  291. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +7 -3
  292. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  293. package/lib/components/VSlideGroup/_variables.scss +0 -5
  294. package/lib/components/VSlideGroup/index.mjs +2 -2
  295. package/lib/components/VSlideGroup/index.mjs.map +1 -1
  296. package/lib/components/VSlider/VSlider.mjs +7 -9
  297. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  298. package/lib/components/VSlider/VSlider.sass +0 -2
  299. package/lib/components/VSlider/VSliderThumb.mjs +6 -5
  300. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  301. package/lib/components/VSlider/VSliderThumb.sass +0 -2
  302. package/lib/components/VSlider/VSliderTrack.mjs +11 -10
  303. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  304. package/lib/components/VSlider/VSliderTrack.sass +0 -2
  305. package/lib/components/VSlider/slider.mjs +4 -4
  306. package/lib/components/VSlider/slider.mjs.map +1 -1
  307. package/lib/components/VSnackbar/VSnackbar.css +5 -5
  308. package/lib/components/VSnackbar/VSnackbar.mjs +49 -49
  309. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  310. package/lib/components/VSnackbar/VSnackbar.sass +0 -1
  311. package/lib/components/VSnackbar/_variables.scss +2 -0
  312. package/lib/components/VSwitch/VSwitch.css +7 -0
  313. package/lib/components/VSwitch/VSwitch.mjs +8 -2
  314. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  315. package/lib/components/VSwitch/VSwitch.sass +6 -1
  316. package/lib/components/VSwitch/_variables.scss +1 -0
  317. package/lib/components/VSystemBar/VSystemBar.mjs +5 -13
  318. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  319. package/lib/components/VSystemBar/VSystemBar.sass +0 -1
  320. package/lib/components/VSystemBar/_variables.scss +2 -1
  321. package/lib/components/VTable/VTable.css +1 -0
  322. package/lib/components/VTable/VTable.mjs +9 -8
  323. package/lib/components/VTable/VTable.mjs.map +1 -1
  324. package/lib/components/VTable/VTable.sass +1 -1
  325. package/lib/components/VTable/_variables.scss +2 -0
  326. package/lib/components/VTabs/VTab.css +3 -1
  327. package/lib/components/VTabs/VTab.mjs +4 -4
  328. package/lib/components/VTabs/VTab.mjs.map +1 -1
  329. package/lib/components/VTabs/VTab.sass +4 -2
  330. package/lib/components/VTabs/VTabs.mjs +15 -12
  331. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  332. package/lib/components/VTabs/VTabs.sass +0 -1
  333. package/lib/components/VTabs/_variables.scss +2 -0
  334. package/lib/components/VTextField/VTextField.mjs +25 -13
  335. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  336. package/lib/components/VTextField/VTextField.sass +0 -1
  337. package/lib/components/VTextField/_variables.scss +1 -1
  338. package/lib/components/VTextarea/VTextarea.mjs +22 -12
  339. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  340. package/lib/components/VTextarea/VTextarea.sass +0 -2
  341. package/lib/components/VTextarea/_variables.scss +1 -0
  342. package/lib/components/VTimeline/VTimeline.mjs +24 -25
  343. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  344. package/lib/components/VTimeline/VTimeline.sass +3 -3
  345. package/lib/components/VTimeline/VTimelineDivider.mjs +41 -38
  346. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  347. package/lib/components/VTimeline/VTimelineItem.mjs +10 -11
  348. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  349. package/lib/components/VTimeline/_variables.scss +11 -6
  350. package/lib/components/VToolbar/VToolbar.css +15 -6
  351. package/lib/components/VToolbar/VToolbar.mjs +9 -9
  352. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  353. package/lib/components/VToolbar/VToolbar.sass +15 -7
  354. package/lib/components/VToolbar/VToolbarItems.mjs +12 -8
  355. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  356. package/lib/components/VToolbar/_variables.scss +6 -2
  357. package/lib/components/VTooltip/VTooltip.mjs +41 -39
  358. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  359. package/lib/components/VTooltip/VTooltip.sass +0 -1
  360. package/lib/components/VTooltip/_variables.scss +1 -0
  361. package/lib/components/VWindow/VWindow.mjs +4 -4
  362. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  363. package/lib/components/VWindow/VWindow.sass +0 -2
  364. package/lib/components/VWindow/VWindowItem.mjs +21 -11
  365. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  366. package/lib/components/VWindow/_variables.scss +1 -0
  367. package/lib/components/index.d.ts +7316 -2666
  368. package/lib/components/transitions/dialog-transition.mjs +3 -0
  369. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  370. package/lib/components/transitions/index.mjs +0 -5
  371. package/lib/components/transitions/index.mjs.map +1 -1
  372. package/lib/composables/border.mjs +5 -6
  373. package/lib/composables/border.mjs.map +1 -1
  374. package/lib/composables/display.mjs +13 -11
  375. package/lib/composables/display.mjs.map +1 -1
  376. package/lib/composables/form.mjs +6 -6
  377. package/lib/composables/form.mjs.map +1 -1
  378. package/lib/composables/group.mjs.map +1 -1
  379. package/lib/composables/items.mjs +2 -2
  380. package/lib/composables/items.mjs.map +1 -1
  381. package/lib/composables/location.mjs +4 -8
  382. package/lib/composables/location.mjs.map +1 -1
  383. package/lib/composables/proxiedModel.mjs +2 -1
  384. package/lib/composables/proxiedModel.mjs.map +1 -1
  385. package/lib/composables/size.mjs +2 -2
  386. package/lib/composables/size.mjs.map +1 -1
  387. package/lib/composables/ssrBoot.mjs +3 -2
  388. package/lib/composables/ssrBoot.mjs.map +1 -1
  389. package/lib/composables/stack.mjs +7 -7
  390. package/lib/composables/stack.mjs.map +1 -1
  391. package/lib/composables/theme.mjs +15 -6
  392. package/lib/composables/theme.mjs.map +1 -1
  393. package/lib/composables/validation.mjs +15 -8
  394. package/lib/composables/validation.mjs.map +1 -1
  395. package/lib/composables/variant.mjs +7 -5
  396. package/lib/composables/variant.mjs.map +1 -1
  397. package/lib/directives/ripple/VRipple.sass +0 -1
  398. package/lib/entry-bundler.mjs +1 -1
  399. package/lib/framework.mjs +29 -7
  400. package/lib/framework.mjs.map +1 -1
  401. package/lib/index.d.ts +68 -70
  402. package/lib/styles/generic/_transitions.scss +13 -77
  403. package/lib/styles/main.css +44 -58
  404. package/lib/styles/tools/_variant.sass +6 -6
  405. package/lib/util/anchor.mjs +34 -28
  406. package/lib/util/anchor.mjs.map +1 -1
  407. package/lib/util/animation.mjs +2 -2
  408. package/lib/util/animation.mjs.map +1 -1
  409. package/lib/util/box.mjs +12 -0
  410. package/lib/util/box.mjs.map +1 -1
  411. package/lib/util/getCurrentInstance.mjs +19 -0
  412. package/lib/util/getCurrentInstance.mjs.map +1 -1
  413. package/lib/util/helpers.mjs +21 -5
  414. package/lib/util/helpers.mjs.map +1 -1
  415. package/package.json +16 -10
  416. package/lib/components/VBanner/VBannerAvatar.mjs +0 -20
  417. package/lib/components/VBanner/VBannerAvatar.mjs.map +0 -1
  418. package/lib/components/VBanner/VBannerIcon.mjs +0 -20
  419. package/lib/components/VBanner/VBannerIcon.mjs.map +0 -1
  420. package/lib/components/VBreadcrumbs/shared.mjs +0 -2
  421. package/lib/components/VBreadcrumbs/shared.mjs.map +0 -1
  422. package/lib/components/VCard/VCardAvatar.mjs +0 -3
  423. package/lib/components/VCard/VCardAvatar.mjs.map +0 -1
  424. package/lib/components/VCard/VCardContent.mjs +0 -3
  425. package/lib/components/VCard/VCardContent.mjs.map +0 -1
  426. package/lib/components/VCard/VCardHeader.mjs +0 -3
  427. package/lib/components/VCard/VCardHeader.mjs.map +0 -1
  428. package/lib/components/VCard/VCardHeaderText.mjs +0 -3
  429. package/lib/components/VCard/VCardHeaderText.mjs.map +0 -1
  430. package/lib/components/VCard/VCardImg.mjs +0 -3
  431. package/lib/components/VCard/VCardImg.mjs.map +0 -1
  432. package/lib/components/VList/VListItemAvatar.mjs +0 -23
  433. package/lib/components/VList/VListItemAvatar.mjs.map +0 -1
  434. package/lib/components/VList/VListItemHeader.mjs +0 -3
  435. package/lib/components/VList/VListItemHeader.mjs.map +0 -1
  436. package/lib/components/VList/VListItemIcon.mjs +0 -23
  437. package/lib/components/VList/VListItemIcon.mjs.map +0 -1
  438. package/lib/components/VTimeline/shared.mjs +0 -2
  439. package/lib/components/VTimeline/shared.mjs.map +0 -1
  440. package/lib/presets/default/index.mjs +0 -71
  441. package/lib/presets/default/index.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPickerPreview.mjs","names":["VSlider","defineComponent","HSVAtoCSS","nullColor","VColorPickerPreview","name","props","color","type","Object","disabled","Boolean","hideAlpha","emits","setup","emit","background","h","a"],"sources":["../../../src/components/VColorPicker/VColorPickerPreview.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerPreview.sass'\n\n// Components\nimport { VSlider } from '@/components/VSlider'\n\n// Utilities\nimport { defineComponent, HSVAtoCSS } from '@/util'\nimport { nullColor } from './util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSVA } from '@/util'\n\nexport const VColorPickerPreview = defineComponent({\n name: 'VColorPickerPreview',\n\n props: {\n color: {\n type: Object as PropType<HSVA | null>,\n },\n disabled: Boolean,\n hideAlpha: Boolean,\n },\n\n emits: {\n 'update:color': (color: HSVA) => true,\n },\n\n setup (props, { emit }) {\n return () => (\n <div\n class={[\n 'v-color-picker-preview',\n {\n 'v-color-picker-preview--hide-alpha': props.hideAlpha,\n },\n ]}\n >\n <div class=\"v-color-picker-preview__dot\">\n <div style={{ background: HSVAtoCSS(props.color ?? nullColor) }} />\n </div>\n <div class=\"v-color-picker-preview__sliders\">\n <VSlider\n class=\"v-color-picker-preview__track v-color-picker-preview__hue\"\n modelValue={ props.color?.h }\n onUpdate:modelValue={ h => emit('update:color', { ...(props.color ?? nullColor), h }) }\n step={ 0 }\n min={ 0 }\n max={ 360 }\n disabled={ props.disabled }\n thumbSize={ 14 }\n trackSize={ 8 }\n trackFillColor=\"white\"\n hideDetails\n />\n { !props.hideAlpha && (\n <VSlider\n class=\"v-color-picker-preview__track v-color-picker-preview__alpha\"\n modelValue={ props.color?.a }\n onUpdate:modelValue={ a => emit('update:color', { ...(props.color ?? nullColor), a }) }\n step={ 0 }\n min={ 0 }\n max={ 1 }\n disabled={ props.disabled }\n thumbSize={ 14 }\n trackSize={ 8 }\n trackFillColor=\"white\"\n hideDetails\n />\n ) }\n </div>\n </div>\n )\n },\n})\n"],"mappings":";AAAA;AACA,mC,CAEA;;SACSA,O,gCAET;;SACSC,e,EAAiBC,S;SACjBC,S,4BAET;;AAIA,OAAO,MAAMC,mBAAmB,GAAGH,eAAe,CAAC;EACjDI,IAAI,EAAE,qBAD2C;EAGjDC,KAAK,EAAE;IACLC,KAAK,EAAE;MACLC,IAAI,EAAEC;IADD,CADF;IAILC,QAAQ,EAAEC,OAJL;IAKLC,SAAS,EAAED;EALN,CAH0C;EAWjDE,KAAK,EAAE;IACL,gBAAiBN,KAAD,IAAiB;EAD5B,CAX0C;;EAejDO,KAAK,CAAER,KAAF,QAAmB;IAAA,IAAV;MAAES;IAAF,CAAU;IACtB,OAAO;MAAA;;MAAA;QAAA,SAEI,CACL,wBADK,EAEL;UACE,sCAAsCT,KAAK,CAACM;QAD9C,CAFK;MAFJ;QAAA,SASQ;MATR;QAAA,SAUW;UAAEI,UAAU,EAAEd,SAAS,iBAACI,KAAK,CAACC,KAAP,2BAAgBJ,SAAhB;QAAvB;MAVX;QAAA,SAYQ;MAZR;QAAA,SAcO,2DAdP;QAAA,+BAecG,KAAK,CAACC,KAfpB,qBAec,cAAaU,CAf3B;QAAA,uBAgBuBA,CAAC;UAAA;;UAAA,OAAIF,IAAI,CAAC,cAAD,EAAiB,EAAE,qBAAIT,KAAK,CAACC,KAAV,4BAAmBJ,SAAnB,CAAF;YAAiCc;UAAjC,CAAjB,CAAR;QAAA,CAhBxB;QAAA,QAiBQ,CAjBR;QAAA,OAkBO,CAlBP;QAAA,OAmBO,GAnBP;QAAA,YAoBYX,KAAK,CAACI,QApBlB;QAAA,aAqBa,EArBb;QAAA,aAsBa,CAtBb;QAAA,kBAuBgB,OAvBhB;QAAA;MAAA,UA0BC,CAACJ,KAAK,CAACM,SAAP;QAAA,SAEQ,6DAFR;QAAA,+BAGeN,KAAK,CAACC,KAHrB,qBAGe,cAAaW,CAH5B;QAAA,uBAIwBA,CAAC;UAAA;;UAAA,OAAIH,IAAI,CAAC,cAAD,EAAiB,EAAE,qBAAIT,KAAK,CAACC,KAAV,4BAAmBJ,SAAnB,CAAF;YAAiCe;UAAjC,CAAjB,CAAR;QAAA,CAJzB;QAAA,QAKS,CALT;QAAA,OAMQ,CANR;QAAA,OAOQ,CAPR;QAAA,YAQaZ,KAAK,CAACI,QARnB;QAAA,aASc,EATd;QAAA,aAUc,CAVd;QAAA,kBAWiB,OAXjB;QAAA;MAAA,QA1BD;IAAA,CAAP;EA4CD;;AA5DgD,CAAD,CAA3C"}
1
+ {"version":3,"file":"VColorPickerPreview.mjs","names":["VSlider","defineComponent","HSVAtoCSS","useRender","nullColor","VColorPickerPreview","name","props","color","type","Object","disabled","Boolean","hideAlpha","emits","setup","emit","background","h","a"],"sources":["../../../src/components/VColorPicker/VColorPickerPreview.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerPreview.sass'\n\n// Components\nimport { VSlider } from '@/components/VSlider'\n\n// Utilities\nimport { defineComponent, HSVAtoCSS, useRender } from '@/util'\nimport { nullColor } from './util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSVA } from '@/util'\n\nexport const VColorPickerPreview = defineComponent({\n name: 'VColorPickerPreview',\n\n props: {\n color: {\n type: Object as PropType<HSVA | null>,\n },\n disabled: Boolean,\n hideAlpha: Boolean,\n },\n\n emits: {\n 'update:color': (color: HSVA) => true,\n },\n\n setup (props, { emit }) {\n useRender(() => (\n <div\n class={[\n 'v-color-picker-preview',\n {\n 'v-color-picker-preview--hide-alpha': props.hideAlpha,\n },\n ]}\n >\n <div class=\"v-color-picker-preview__dot\">\n <div style={{ background: HSVAtoCSS(props.color ?? nullColor) }} />\n </div>\n\n <div class=\"v-color-picker-preview__sliders\">\n <VSlider\n class=\"v-color-picker-preview__track v-color-picker-preview__hue\"\n modelValue={ props.color?.h }\n onUpdate:modelValue={ h => emit('update:color', { ...(props.color ?? nullColor), h }) }\n step={ 0 }\n min={ 0 }\n max={ 360 }\n disabled={ props.disabled }\n thumbSize={ 14 }\n trackSize={ 8 }\n trackFillColor=\"white\"\n hideDetails\n />\n\n { !props.hideAlpha && (\n <VSlider\n class=\"v-color-picker-preview__track v-color-picker-preview__alpha\"\n modelValue={ props.color?.a }\n onUpdate:modelValue={ a => emit('update:color', { ...(props.color ?? nullColor), a }) }\n step={ 0 }\n min={ 0 }\n max={ 1 }\n disabled={ props.disabled }\n thumbSize={ 14 }\n trackSize={ 8 }\n trackFillColor=\"white\"\n hideDetails\n />\n ) }\n </div>\n </div>\n ))\n\n return {}\n },\n})\n"],"mappings":";AAAA;AACA,mC,CAEA;;SACSA,O,gCAET;;SACSC,e,EAAiBC,S,EAAWC,S;SAC5BC,S,4BAET;;AAIA,OAAO,MAAMC,mBAAmB,GAAGJ,eAAe,CAAC;EACjDK,IAAI,EAAE,qBAD2C;EAGjDC,KAAK,EAAE;IACLC,KAAK,EAAE;MACLC,IAAI,EAAEC;IADD,CADF;IAILC,QAAQ,EAAEC,OAJL;IAKLC,SAAS,EAAED;EALN,CAH0C;EAWjDE,KAAK,EAAE;IACL,gBAAiBN,KAAD,IAAiB;EAD5B,CAX0C;;EAejDO,KAAK,CAAER,KAAF,QAAmB;IAAA,IAAV;MAAES;IAAF,CAAU;IACtBb,SAAS,CAAC;MAAA;;MAAA;QAAA,SAEC,CACL,wBADK,EAEL;UACE,sCAAsCI,KAAK,CAACM;QAD9C,CAFK;MAFD;QAAA,SASK;MATL;QAAA,SAUQ;UAAEI,UAAU,EAAEf,SAAS,iBAACK,KAAK,CAACC,KAAP,2BAAgBJ,SAAhB;QAAvB;MAVR;QAAA,SAaK;MAbL;QAAA,SAeI,2DAfJ;QAAA,+BAgBWG,KAAK,CAACC,KAhBjB,qBAgBW,cAAaU,CAhBxB;QAAA,uBAiBoBA,CAAC;UAAA;;UAAA,OAAIF,IAAI,CAAC,cAAD,EAAiB,EAAE,qBAAIT,KAAK,CAACC,KAAV,4BAAmBJ,SAAnB,CAAF;YAAiCc;UAAjC,CAAjB,CAAR;QAAA,CAjBrB;QAAA,QAkBK,CAlBL;QAAA,OAmBI,CAnBJ;QAAA,OAoBI,GApBJ;QAAA,YAqBSX,KAAK,CAACI,QArBf;QAAA,aAsBU,EAtBV;QAAA,aAuBU,CAvBV;QAAA,kBAwBa,OAxBb;QAAA;MAAA,UA4BF,CAACJ,KAAK,CAACM,SAAP;QAAA,SAEQ,6DAFR;QAAA,+BAGeN,KAAK,CAACC,KAHrB,qBAGe,cAAaW,CAH5B;QAAA,uBAIwBA,CAAC;UAAA;;UAAA,OAAIH,IAAI,CAAC,cAAD,EAAiB,EAAE,qBAAIT,KAAK,CAACC,KAAV,4BAAmBJ,SAAnB,CAAF;YAAiCe;UAAjC,CAAjB,CAAR;QAAA,CAJzB;QAAA,QAKS,CALT;QAAA,OAMQ,CANR;QAAA,OAOQ,CAPR;QAAA,YAQaZ,KAAK,CAACI,QARnB;QAAA,aASc,EATd;QAAA,aAUc,CAVd;QAAA,kBAWiB,OAXjB;QAAA;MAAA,QA5BE;IAAA,CAAD,CAAT;IA+CA,OAAO,EAAP;EACD;;AAhEgD,CAAD,CAA3C"}
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -4,9 +4,9 @@ import "./VColorPickerSwatches.css"; // Components
4
4
 
5
5
  import { VIcon } from "../VIcon/index.mjs"; // Utilities
6
6
 
7
- import { convertToUnit, deepEqual, defineComponent, getContrast } from "../../util/index.mjs";
8
- import colors from "../../util/colors.mjs";
9
- import { parseColor } from "./util/index.mjs"; // Types
7
+ import { convertToUnit, deepEqual, defineComponent, getContrast, useRender } from "../../util/index.mjs";
8
+ import { parseColor } from "./util/index.mjs";
9
+ import colors from "../../util/colors.mjs"; // Types
10
10
 
11
11
  function parseDefaultColors(colors) {
12
12
  return Object.keys(colors).map(key => {
@@ -34,7 +34,7 @@ export const VColorPickerSwatches = defineComponent({
34
34
  let {
35
35
  emit
36
36
  } = _ref;
37
- return () => _createVNode("div", {
37
+ useRender(() => _createVNode("div", {
38
38
  "class": "v-color-picker-swatches",
39
39
  "style": {
40
40
  maxHeight: convertToUnit(props.maxHeight)
@@ -55,7 +55,8 @@ export const VColorPickerSwatches = defineComponent({
55
55
  "icon": "$success",
56
56
  "color": getContrast(color, '#FFFFFF') > 2 ? 'white' : 'black'
57
57
  }, null) : undefined])]);
58
- })]))])]);
58
+ })]))])]));
59
+ return {};
59
60
  }
60
61
 
61
62
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VColorPickerSwatches.mjs","names":["VIcon","convertToUnit","deepEqual","defineComponent","getContrast","colors","parseColor","parseDefaultColors","Object","keys","map","key","color","base","darken4","darken3","darken2","darken1","lighten1","lighten2","lighten3","lighten4","lighten5","black","white","transparent","VColorPickerSwatches","name","props","swatches","type","Array","default","disabled","Boolean","maxHeight","Number","String","emits","setup","emit","swatch","hsva","background","undefined"],"sources":["../../../src/components/VColorPicker/VColorPickerSwatches.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerSwatches.sass'\n\n// Components\nimport { VIcon } from '@/components/VIcon'\n\n// Utilities\nimport { convertToUnit, deepEqual, defineComponent, getContrast } from '@/util'\nimport colors from '@/util/colors'\nimport { parseColor } from './util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSVA } from '@/util'\n\nfunction parseDefaultColors (colors: Record<string, Record<string, string>>) {\n return Object.keys(colors).map(key => {\n const color = colors[key]\n return color.base ? [\n color.base,\n color.darken4,\n color.darken3,\n color.darken2,\n color.darken1,\n color.lighten1,\n color.lighten2,\n color.lighten3,\n color.lighten4,\n color.lighten5,\n ] : [\n color.black,\n color.white,\n color.transparent,\n ]\n })\n}\n\nexport const VColorPickerSwatches = defineComponent({\n name: 'VColorPickerSwatches',\n\n props: {\n swatches: {\n type: Array as PropType<string[][]>,\n default: () => parseDefaultColors(colors),\n },\n disabled: Boolean,\n color: Object as PropType<HSVA | null>,\n maxHeight: [Number, String],\n },\n\n emits: {\n 'update:color': (color: HSVA) => true,\n },\n\n setup (props, { emit }) {\n return () => (\n <div\n class=\"v-color-picker-swatches\"\n style={{\n maxHeight: convertToUnit(props.maxHeight),\n }}\n >\n <div>\n { props.swatches.map(swatch => (\n <div class=\"v-color-picker-swatches__swatch\">\n { swatch.map(color => {\n const hsva = parseColor(color)\n\n return (\n <div\n class=\"v-color-picker-swatches__color\"\n onClick={() => hsva && emit('update:color', hsva)}\n >\n <div style={{ background: color }}>\n { props.color && deepEqual(props.color, hsva)\n ? <VIcon size=\"x-small\" icon=\"$success\" color={getContrast(color, '#FFFFFF') > 2 ? 'white' : 'black' } />\n : undefined\n }\n </div>\n </div>\n )\n }) }\n </div>\n ))}\n </div>\n </div>\n )\n },\n})\n"],"mappings":";AAAA;AACA,oC,CAEA;;SACSA,K,8BAET;;SACSC,a,EAAeC,S,EAAWC,e,EAAiBC,W;OAC7CC,M;SACEC,U,4BAET;;AAIA,SAASC,kBAAT,CAA6BF,MAA7B,EAA6E;EAC3E,OAAOG,MAAM,CAACC,IAAP,CAAYJ,MAAZ,EAAoBK,GAApB,CAAwBC,GAAG,IAAI;IACpC,MAAMC,KAAK,GAAGP,MAAM,CAACM,GAAD,CAApB;IACA,OAAOC,KAAK,CAACC,IAAN,GAAa,CAClBD,KAAK,CAACC,IADY,EAElBD,KAAK,CAACE,OAFY,EAGlBF,KAAK,CAACG,OAHY,EAIlBH,KAAK,CAACI,OAJY,EAKlBJ,KAAK,CAACK,OALY,EAMlBL,KAAK,CAACM,QANY,EAOlBN,KAAK,CAACO,QAPY,EAQlBP,KAAK,CAACQ,QARY,EASlBR,KAAK,CAACS,QATY,EAUlBT,KAAK,CAACU,QAVY,CAAb,GAWH,CACFV,KAAK,CAACW,KADJ,EAEFX,KAAK,CAACY,KAFJ,EAGFZ,KAAK,CAACa,WAHJ,CAXJ;EAgBD,CAlBM,CAAP;AAmBD;;AAED,OAAO,MAAMC,oBAAoB,GAAGvB,eAAe,CAAC;EAClDwB,IAAI,EAAE,sBAD4C;EAGlDC,KAAK,EAAE;IACLC,QAAQ,EAAE;MACRC,IAAI,EAAEC,KADE;MAERC,OAAO,EAAE,MAAMzB,kBAAkB,CAACF,MAAD;IAFzB,CADL;IAKL4B,QAAQ,EAAEC,OALL;IAMLtB,KAAK,EAAEJ,MANF;IAOL2B,SAAS,EAAE,CAACC,MAAD,EAASC,MAAT;EAPN,CAH2C;EAalDC,KAAK,EAAE;IACL,gBAAiB1B,KAAD,IAAiB;EAD5B,CAb2C;;EAiBlD2B,KAAK,CAAEX,KAAF,QAAmB;IAAA,IAAV;MAAEY;IAAF,CAAU;IACtB,OAAO;MAAA,SAEG,yBAFH;MAAA,SAGI;QACLL,SAAS,EAAElC,aAAa,CAAC2B,KAAK,CAACO,SAAP;MADnB;IAHJ,+BAQCP,KAAK,CAACC,QAAN,CAAenB,GAAf,CAAmB+B,MAAM;MAAA,SACd;IADc,IAErBA,MAAM,CAAC/B,GAAP,CAAWE,KAAK,IAAI;MACpB,MAAM8B,IAAI,GAAGpC,UAAU,CAACM,KAAD,CAAvB;MAEA;QAAA,SAEU,gCAFV;QAAA,WAGa,MAAM8B,IAAI,IAAIF,IAAI,CAAC,cAAD,EAAiBE,IAAjB;MAH/B;QAAA,SAKgB;UAAEC,UAAU,EAAE/B;QAAd;MALhB,IAMQgB,KAAK,CAAChB,KAAN,IAAeV,SAAS,CAAC0B,KAAK,CAAChB,KAAP,EAAc8B,IAAd,CAAxB;QAAA,QACc,SADd;QAAA,QAC6B,UAD7B;QAAA,SAC+CtC,WAAW,CAACQ,KAAD,EAAQ,SAAR,CAAX,GAAgC,CAAhC,GAAoC,OAApC,GAA8C;MAD7F,WAEEgC,SARV;IAaD,CAhBC,CAFqB,EAAzB,CARD,IAAP;EAgCD;;AAlDiD,CAAD,CAA5C"}
1
+ {"version":3,"file":"VColorPickerSwatches.mjs","names":["VIcon","convertToUnit","deepEqual","defineComponent","getContrast","useRender","parseColor","colors","parseDefaultColors","Object","keys","map","key","color","base","darken4","darken3","darken2","darken1","lighten1","lighten2","lighten3","lighten4","lighten5","black","white","transparent","VColorPickerSwatches","name","props","swatches","type","Array","default","disabled","Boolean","maxHeight","Number","String","emits","setup","emit","swatch","hsva","background","undefined"],"sources":["../../../src/components/VColorPicker/VColorPickerSwatches.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerSwatches.sass'\n\n// Components\nimport { VIcon } from '@/components/VIcon'\n\n// Utilities\nimport { convertToUnit, deepEqual, defineComponent, getContrast, useRender } from '@/util'\nimport { parseColor } from './util'\nimport colors from '@/util/colors'\n\n// Types\nimport type { HSVA } from '@/util'\nimport type { PropType } from 'vue'\n\nfunction parseDefaultColors (colors: Record<string, Record<string, string>>) {\n return Object.keys(colors).map(key => {\n const color = colors[key]\n return color.base ? [\n color.base,\n color.darken4,\n color.darken3,\n color.darken2,\n color.darken1,\n color.lighten1,\n color.lighten2,\n color.lighten3,\n color.lighten4,\n color.lighten5,\n ] : [\n color.black,\n color.white,\n color.transparent,\n ]\n })\n}\n\nexport const VColorPickerSwatches = defineComponent({\n name: 'VColorPickerSwatches',\n\n props: {\n swatches: {\n type: Array as PropType<string[][]>,\n default: () => parseDefaultColors(colors),\n },\n disabled: Boolean,\n color: Object as PropType<HSVA | null>,\n maxHeight: [Number, String],\n },\n\n emits: {\n 'update:color': (color: HSVA) => true,\n },\n\n setup (props, { emit }) {\n useRender(() => (\n <div\n class=\"v-color-picker-swatches\"\n style={{\n maxHeight: convertToUnit(props.maxHeight),\n }}\n >\n <div>\n { props.swatches.map(swatch => (\n <div class=\"v-color-picker-swatches__swatch\">\n { swatch.map(color => {\n const hsva = parseColor(color)\n\n return (\n <div\n class=\"v-color-picker-swatches__color\"\n onClick={() => hsva && emit('update:color', hsva)}\n >\n <div style={{ background: color }}>\n { props.color && deepEqual(props.color, hsva)\n ? <VIcon size=\"x-small\" icon=\"$success\" color={getContrast(color, '#FFFFFF') > 2 ? 'white' : 'black' } />\n : undefined\n }\n </div>\n </div>\n )\n }) }\n </div>\n ))}\n </div>\n </div>\n ))\n\n return {}\n },\n})\n"],"mappings":";AAAA;AACA,oC,CAEA;;SACSA,K,8BAET;;SACSC,a,EAAeC,S,EAAWC,e,EAAiBC,W,EAAaC,S;SACxDC,U;OACFC,M,+BAEP;;AAIA,SAASC,kBAAT,CAA6BD,MAA7B,EAA6E;EAC3E,OAAOE,MAAM,CAACC,IAAP,CAAYH,MAAZ,EAAoBI,GAApB,CAAwBC,GAAG,IAAI;IACpC,MAAMC,KAAK,GAAGN,MAAM,CAACK,GAAD,CAApB;IACA,OAAOC,KAAK,CAACC,IAAN,GAAa,CAClBD,KAAK,CAACC,IADY,EAElBD,KAAK,CAACE,OAFY,EAGlBF,KAAK,CAACG,OAHY,EAIlBH,KAAK,CAACI,OAJY,EAKlBJ,KAAK,CAACK,OALY,EAMlBL,KAAK,CAACM,QANY,EAOlBN,KAAK,CAACO,QAPY,EAQlBP,KAAK,CAACQ,QARY,EASlBR,KAAK,CAACS,QATY,EAUlBT,KAAK,CAACU,QAVY,CAAb,GAWH,CACFV,KAAK,CAACW,KADJ,EAEFX,KAAK,CAACY,KAFJ,EAGFZ,KAAK,CAACa,WAHJ,CAXJ;EAgBD,CAlBM,CAAP;AAmBD;;AAED,OAAO,MAAMC,oBAAoB,GAAGxB,eAAe,CAAC;EAClDyB,IAAI,EAAE,sBAD4C;EAGlDC,KAAK,EAAE;IACLC,QAAQ,EAAE;MACRC,IAAI,EAAEC,KADE;MAERC,OAAO,EAAE,MAAMzB,kBAAkB,CAACD,MAAD;IAFzB,CADL;IAKL2B,QAAQ,EAAEC,OALL;IAMLtB,KAAK,EAAEJ,MANF;IAOL2B,SAAS,EAAE,CAACC,MAAD,EAASC,MAAT;EAPN,CAH2C;EAalDC,KAAK,EAAE;IACL,gBAAiB1B,KAAD,IAAiB;EAD5B,CAb2C;;EAiBlD2B,KAAK,CAAEX,KAAF,QAAmB;IAAA,IAAV;MAAEY;IAAF,CAAU;IACtBpC,SAAS,CAAC;MAAA,SAEA,yBAFA;MAAA,SAGC;QACL+B,SAAS,EAAEnC,aAAa,CAAC4B,KAAK,CAACO,SAAP;MADnB;IAHD,+BAQFP,KAAK,CAACC,QAAN,CAAenB,GAAf,CAAmB+B,MAAM;MAAA,SACd;IADc,IAErBA,MAAM,CAAC/B,GAAP,CAAWE,KAAK,IAAI;MACpB,MAAM8B,IAAI,GAAGrC,UAAU,CAACO,KAAD,CAAvB;MAEA;QAAA,SAEU,gCAFV;QAAA,WAGa,MAAM8B,IAAI,IAAIF,IAAI,CAAC,cAAD,EAAiBE,IAAjB;MAH/B;QAAA,SAKgB;UAAEC,UAAU,EAAE/B;QAAd;MALhB,IAMQgB,KAAK,CAAChB,KAAN,IAAeX,SAAS,CAAC2B,KAAK,CAAChB,KAAP,EAAc8B,IAAd,CAAxB;QAAA,QACc,SADd;QAAA,QAC6B,UAD7B;QAAA,SAC+CvC,WAAW,CAACS,KAAD,EAAQ,SAAR,CAAX,GAAgC,CAAhC,GAAoC,OAApC,GAA8C;MAD7F,WAEEgC,SARV;IAaD,CAhBC,CAFqB,EAAzB,CARE,IAAD,CAAT;IAiCA,OAAO,EAAP;EACD;;AApDiD,CAAD,CAA5C"}
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -1,20 +1,27 @@
1
+ // VColorPicker
1
2
  $color-picker-border-radius: 4px !default;
2
- $color-picker-elevation: 2 !default;
3
3
  $color-picker-checkerboard: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAAAAXNSR0IArs4c6QAAACRJREFUKFNjPHTo0H8GJGBnZ8eIzGekgwJk+0BsdCtRHEQbBQBbbh0dIGKknQAAAABJRU5ErkJggg==) repeat !default;
4
- $color-picker-swatch-color-width: 45px !default;
4
+ $color-picker-controls-padding: 16px !default;
5
+ $color-picker-elevation: 2 !default;
6
+ $color-picker-input-font-size: 0.75rem !default;
7
+ $color-picker-input-height: 32px !default;
8
+ $color-picker-input-margin: 8px !default;
9
+ $color-picker-preview-margin-bottom: 24px !default;
10
+ $color-picker-input-margin-bottom: 8px !default;
11
+
12
+ // VColorPickerSwatch
13
+ $color-picker-swatch-color-border-radius: 2px !default;
5
14
  $color-picker-swatch-color-height: 18px !default;
6
15
  $color-picker-swatch-color-margin: 2px 4px !default;
7
- $color-picker-swatch-color-border-radius: 2px !default;
16
+ $color-picker-swatch-color-width: 45px !default;
8
17
  $color-picker-swatch-margin-bottom: 10px !default;
9
18
  $color-picker-swatches-border-radius: 8px !default;
10
- $color-picker-canvas-dot-size: 15px !default;
19
+
20
+ // VColorCanvas
11
21
  $color-picker-canvas-dot-box-shadow: 0px 0px 0px 1.5px rgba(255, 255, 255, 1), inset 0px 0px 1px 1.5px rgba(0, 0, 0, 0.3) !default;
12
22
  $color-picker-canvas-dot-disabled-box-shadow: 0px 0px 0px 1.5px rgba(255, 255, 255, 0.7), inset 0px 0px 1px 1.5px rgba(0, 0, 0, 0.3) !default;
13
- $color-picker-controls-padding: 16px !default;
14
- $color-picker-preview-margin-bottom: 24px !default;
15
- $color-picker-input-height: 32px !default;
16
- $color-picker-input-font-size: 0.75rem !default;
17
- $color-picker-input-margin: 8px !default;
18
- $color-picker-input-margin-bottom: 8px !default;
23
+ $color-picker-canvas-dot-size: 15px !default;
24
+
25
+ // VColorPickerPreview
19
26
  $color-picker-preview-dot-size: 30px !default;
20
27
  $color-picker-preview-dot-margin: 24px !default;
@@ -3,6 +3,7 @@ import { createTextVNode as _createTextVNode, mergeProps as _mergeProps, createV
3
3
  import "./VCombobox.css"; // Components
4
4
 
5
5
  import { makeSelectProps } from "../VSelect/VSelect.mjs";
6
+ import { VCheckboxBtn } from "../VCheckbox/index.mjs";
6
7
  import { VChip } from "../VChip/index.mjs";
7
8
  import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
8
9
  import { VList, VListItem } from "../VList/index.mjs";
@@ -17,7 +18,7 @@ import { useLocale } from "../../composables/locale.mjs";
17
18
  import { useProxiedModel } from "../../composables/proxiedModel.mjs";
18
19
  import { useTextColor } from "../../composables/color.mjs"; // Utility
19
20
 
20
- import { computed, nextTick, ref, watch } from 'vue';
21
+ import { computed, mergeProps, nextTick, ref, watch } from 'vue';
21
22
  import { genericComponent, useRender, wrapInArray } from "../../util/index.mjs"; // Types
22
23
 
23
24
  function highlightResult(text, matches, length) {
@@ -50,7 +51,8 @@ export const VCombobox = genericComponent()({
50
51
  },
51
52
  emits: {
52
53
  'update:modelValue': val => true,
53
- 'update:searchInput': val => true
54
+ 'update:searchInput': val => true,
55
+ 'update:menu': val => true
54
56
  },
55
57
 
56
58
  setup(props, _ref) {
@@ -64,7 +66,7 @@ export const VCombobox = genericComponent()({
64
66
  const vTextFieldRef = ref();
65
67
  const isFocused = ref(false);
66
68
  const isPristine = ref(true);
67
- const menu = ref(false);
69
+ const menu = useProxiedModel(props, 'menu');
68
70
  const selectionIndex = ref(-1);
69
71
  const color = computed(() => {
70
72
  var _vTextFieldRef$value;
@@ -81,29 +83,24 @@ export const VCombobox = genericComponent()({
81
83
  textColorStyles
82
84
  } = useTextColor(color);
83
85
  const model = useProxiedModel(props, 'modelValue', [], v => transformIn(wrapInArray(v || [])), v => {
86
+ var _transformed$;
87
+
84
88
  const transformed = transformOut(v);
85
- return props.multiple ? transformed : transformed[0];
89
+ return props.multiple ? transformed : (_transformed$ = transformed[0]) != null ? _transformed$ : null;
86
90
  });
87
91
 
88
92
  const _search = ref('');
89
93
 
90
94
  const search = computed({
91
95
  get: () => {
92
- if (props.multiple) return _search.value;
93
- const item = items.value.find(_ref2 => {
94
- let {
95
- props
96
- } = _ref2;
97
- return props.value === model.value[0];
98
- });
99
- return item == null ? void 0 : item.props.value;
96
+ return _search.value;
100
97
  },
101
98
  set: val => {
102
99
  var _props$delimiters;
103
100
 
104
- if (props.multiple) {
105
- _search.value = val;
106
- } else {
101
+ _search.value = val;
102
+
103
+ if (!props.multiple) {
107
104
  model.value = [transformItem(props, val)];
108
105
  }
109
106
 
@@ -213,10 +210,6 @@ export const VCombobox = genericComponent()({
213
210
  }
214
211
  }
215
212
 
216
- function onInput(e) {
217
- search.value = e.target.value;
218
- }
219
-
220
213
  function onAfterLeave() {
221
214
  if (isFocused.value) isPristine.value = true;
222
215
  }
@@ -262,7 +255,10 @@ export const VCombobox = genericComponent()({
262
255
  return _createVNode(VTextField, {
263
256
  "ref": vTextFieldRef,
264
257
  "modelValue": search.value,
265
- "onInput": onInput,
258
+ "onUpdate:modelValue": [$event => search.value = $event, v => {
259
+ if (v == null) model.value = [];
260
+ }],
261
+ "validationValue": props.modelValue,
266
262
  "class": ['v-combobox', {
267
263
  'v-combobox--active-menu': menu.value,
268
264
  'v-combobox--chips': !!props.chips,
@@ -270,7 +266,6 @@ export const VCombobox = genericComponent()({
270
266
  [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true
271
267
  }],
272
268
  "appendInnerIcon": props.items.length ? props.menuIcon : undefined,
273
- "dirty": selected.value.length > 0,
274
269
  "onClick:clear": onClear,
275
270
  "onClick:control": onClickControl,
276
271
  "onClick:input": onClickControl,
@@ -281,31 +276,51 @@ export const VCombobox = genericComponent()({
281
276
  default: () => {
282
277
  var _slots$noData, _slots$noData2;
283
278
 
284
- return _createVNode(_Fragment, null, [_createVNode(VMenu, {
279
+ return _createVNode(_Fragment, null, [_createVNode(VMenu, _mergeProps({
285
280
  "modelValue": menu.value,
286
281
  "onUpdate:modelValue": $event => menu.value = $event,
287
282
  "activator": "parent",
288
283
  "contentClass": "v-combobox__content",
289
284
  "eager": props.eager,
290
285
  "openOnClick": false,
286
+ "closeOnContentClick": false,
291
287
  "transition": props.transition,
292
288
  "onAfterLeave": onAfterLeave
293
- }, {
289
+ }, props.menuProps), {
294
290
  default: () => [_createVNode(VList, {
295
291
  "selected": selected.value,
296
- "selectStrategy": props.multiple ? 'independent' : 'single-independent'
292
+ "selectStrategy": props.multiple ? 'independent' : 'single-independent',
293
+ "onMousedown": e => e.preventDefault()
297
294
  }, {
298
295
  default: () => [!filteredItems.value.length && !props.hideNoData && ((_slots$noData = (_slots$noData2 = slots['no-data']) == null ? void 0 : _slots$noData2.call(slots)) != null ? _slots$noData : _createVNode(VListItem, {
299
296
  "title": t(props.noDataText)
300
- }, null)), filteredItems.value.map(_ref3 => {
297
+ }, null)), filteredItems.value.map((_ref2, index) => {
298
+ var _slots$item, _slots$item2;
299
+
301
300
  let {
302
301
  item,
303
302
  matches
304
- } = _ref3;
305
- return _createVNode(VListItem, _mergeProps(item.props, {
306
- "onMousedown": e => e.preventDefault(),
303
+ } = _ref2;
304
+ return (_slots$item = (_slots$item2 = slots.item) == null ? void 0 : _slots$item2.call(slots, {
305
+ item,
306
+ index,
307
+ props: mergeProps(item.props, {
308
+ onClick: () => select(item)
309
+ })
310
+ })) != null ? _slots$item : _createVNode(VListItem, _mergeProps({
311
+ "key": index
312
+ }, item.props, {
307
313
  "onClick": () => select(item)
308
314
  }), {
315
+ prepend: _ref3 => {
316
+ let {
317
+ isSelected
318
+ } = _ref3;
319
+ return props.multiple && !props.hideSelected ? _createVNode(VCheckboxBtn, {
320
+ "modelValue": isSelected,
321
+ "ripple": false
322
+ }, null) : undefined;
323
+ },
309
324
  title: () => {
310
325
  var _search$value$length, _search$value;
311
326
 
@@ -314,11 +329,11 @@ export const VCombobox = genericComponent()({
314
329
  });
315
330
  })]
316
331
  })]
317
- }), selections.value.map((selection, index) => {
332
+ }), selections.value.map((item, index) => {
318
333
  function onChipClose(e) {
319
334
  e.stopPropagation();
320
335
  e.preventDefault();
321
- select(selection);
336
+ select(item);
322
337
  }
323
338
 
324
339
  const slotProps = {
@@ -326,6 +341,7 @@ export const VCombobox = genericComponent()({
326
341
  modelValue: true
327
342
  };
328
343
  return _createVNode("div", {
344
+ "key": index,
329
345
  "class": ['v-combobox__selection', index === selectionIndex.value && ['v-combobox__selection--selected', textColorClasses.value]],
330
346
  "style": index === selectionIndex.value ? textColorStyles.value : {}
331
347
  }, [hasChips ? _createVNode(VDefaultsProvider, {
@@ -333,21 +349,21 @@ export const VCombobox = genericComponent()({
333
349
  VChip: {
334
350
  closable: props.closableChips,
335
351
  size: 'small',
336
- text: selection.props.title
352
+ text: item.title
337
353
  }
338
354
  }
339
355
  }, {
340
356
  default: () => [slots.chip ? slots.chip({
341
- props: slotProps,
342
- item: selection.originalItem,
343
- index
357
+ item,
358
+ index,
359
+ props: slotProps
344
360
  }) : _createVNode(VChip, slotProps, null)]
345
361
  }) : slots.selection ? slots.selection({
346
- item: selection.originalItem,
362
+ item,
347
363
  index
348
364
  }) : _createVNode("span", {
349
365
  "class": "v-combobox__selection-text"
350
- }, [selection.props.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
366
+ }, [item.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
351
367
  "class": "v-combobox__selection-comma"
352
368
  }, [_createTextVNode(",")])])]);
353
369
  })]);
@@ -1 +1 @@
1
- {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForwardRef","useLocale","useProxiedModel","useTextColor","computed","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","item","find","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onInput","target","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","menuIcon","default","eager","noDataText","onChipClose","stopPropagation","slotProps","modelValue","closable","closableChips","size","originalItem"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { PropType } from 'vue'\nimport type { MakeSlots } from '@/util'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = ref(false)\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : transformed[0]\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n if (props.multiple) return _search.value\n\n const item = items.value.find(({ props }) => props.value === model.value[0])\n\n return item?.props.value\n },\n set: val => {\n if (props.multiple) {\n _search.value = val\n } else {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n modelValue={ search.value }\n onInput={ onInput }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n dirty={ selected.value.length > 0 }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }) => (\n <VListItem\n { ...item.props }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onClick={ () => select(item) }\n >\n {{\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((selection, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(selection)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: selection.props.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ props: slotProps, item: selection.originalItem, index })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item: selection.originalItem, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { selection.props.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForwardRef","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","_search","search","get","set","values","split","RegExp","join","forEach","trim","select","filteredItems","undefined","selections","map","find","item","selected","selection","onClear","e","openOnClear","onClickControl","onKeydown","selectionStart","preventDefault","includes","key","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","title","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","noDataText","onClick","prepend","isSelected","hideSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots } from '@/util'\nimport type { PropType } from 'vue'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n item: [{ item: T, index: number, props: Record<string, unknown> }]\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:searchInput': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const _search = ref('')\n const search = computed<string>({\n get: () => {\n return _search.value\n },\n set: val => {\n _search.value = val\n if (!props.multiple) {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:searchInput', value)\n })\n\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div\n key={ index }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
@@ -1,10 +1,8 @@
1
- @forward './variables'
2
1
  @use 'sass:selector'
3
2
  @use 'sass:math'
4
3
  @use '../../styles/settings'
5
4
  @use '../../styles/tools'
6
5
  @use './variables' as *
7
- @use '../VInput/variables' as *
8
6
 
9
7
  .v-combobox
10
8
  .v-field
@@ -2,11 +2,12 @@ import { withDirectives as _withDirectives, createVNode as _createVNode, vShow a
2
2
  // Styles
3
3
  import "./VCounter.css"; // Components
4
4
 
5
- import { VSlideYTransition } from "../transitions/index.mjs"; // Utilities
5
+ import { VSlideYTransition } from "../transitions/index.mjs"; // Composables
6
+
7
+ import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs"; // Utilities
6
8
 
7
- import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs";
8
9
  import { computed } from 'vue';
9
- import { defineComponent } from "../../util/index.mjs";
10
+ import { defineComponent, useRender } from "../../util/index.mjs";
10
11
  export const VCounter = defineComponent({
11
12
  name: 'VCounter',
12
13
  functional: true,
@@ -31,19 +32,18 @@ export const VCounter = defineComponent({
31
32
  const counter = computed(() => {
32
33
  return props.max ? `${props.value} / ${props.max}` : String(props.value);
33
34
  });
34
- return () => {
35
- return _createVNode(MaybeTransition, {
36
- "transition": props.transition
37
- }, {
38
- default: () => [_withDirectives(_createVNode("div", {
39
- "class": "v-counter"
40
- }, [slots.default ? slots.default({
41
- counter: counter.value,
42
- max: props.max,
43
- value: props.value
44
- }) : counter.value]), [[_vShow, props.active]])]
45
- });
46
- };
35
+ useRender(() => _createVNode(MaybeTransition, {
36
+ "transition": props.transition
37
+ }, {
38
+ default: () => [_withDirectives(_createVNode("div", {
39
+ "class": "v-counter"
40
+ }, [slots.default ? slots.default({
41
+ counter: counter.value,
42
+ max: props.max,
43
+ value: props.value
44
+ }) : counter.value]), [[_vShow, props.active]])]
45
+ }));
46
+ return {};
47
47
  }
48
48
 
49
49
  });
@@ -1 +1 @@
1
- {"version":3,"file":"VCounter.mjs","names":["VSlideYTransition","makeTransitionProps","MaybeTransition","computed","defineComponent","VCounter","name","functional","props","active","Boolean","max","Number","String","value","type","default","transition","component","setup","slots","counter"],"sources":["../../../src/components/VCounter/VCounter.tsx"],"sourcesContent":["// Styles\nimport './VCounter.sass'\n\n// Components\nimport { VSlideYTransition } from '@/components/transitions'\n\n// Utilities\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\nimport { computed } from 'vue'\nimport { defineComponent } from '@/util'\n\nexport const VCounter = defineComponent({\n name: 'VCounter',\n\n functional: true,\n\n props: {\n active: Boolean,\n max: [Number, String],\n value: {\n type: [Number, String],\n default: 0,\n },\n\n ...makeTransitionProps({\n transition: { component: VSlideYTransition },\n }),\n },\n\n setup (props, { slots }) {\n const counter = computed(() => {\n return props.max ? `${props.value} / ${props.max}` : String(props.value)\n })\n\n return () => {\n return (\n <MaybeTransition transition={ props.transition }>\n <div\n v-show={ props.active }\n class=\"v-counter\"\n >\n { slots.default\n ? slots.default({\n counter: counter.value,\n max: props.max,\n value: props.value,\n })\n : counter.value\n }\n </div>\n </MaybeTransition>\n )\n }\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;SACSA,iB,oCAET;;SACSC,mB,EAAqBC,e;AAC9B,SAASC,QAAT,QAAyB,KAAzB;SACSC,e;AAET,OAAO,MAAMC,QAAQ,GAAGD,eAAe,CAAC;EACtCE,IAAI,EAAE,UADgC;EAGtCC,UAAU,EAAE,IAH0B;EAKtCC,KAAK,EAAE;IACLC,MAAM,EAAEC,OADH;IAELC,GAAG,EAAE,CAACC,MAAD,EAASC,MAAT,CAFA;IAGLC,KAAK,EAAE;MACLC,IAAI,EAAE,CAACH,MAAD,EAASC,MAAT,CADD;MAELG,OAAO,EAAE;IAFJ,CAHF;IAQL,GAAGf,mBAAmB,CAAC;MACrBgB,UAAU,EAAE;QAAEC,SAAS,EAAElB;MAAb;IADS,CAAD;EARjB,CAL+B;;EAkBtCmB,KAAK,CAAEX,KAAF,QAAoB;IAAA,IAAX;MAAEY;IAAF,CAAW;IACvB,MAAMC,OAAO,GAAGlB,QAAQ,CAAC,MAAM;MAC7B,OAAOK,KAAK,CAACG,GAAN,GAAa,GAAEH,KAAK,CAACM,KAAM,MAAKN,KAAK,CAACG,GAAI,EAA1C,GAA8CE,MAAM,CAACL,KAAK,CAACM,KAAP,CAA3D;IACD,CAFuB,CAAxB;IAIA,OAAO,MAAM;MACX;QAAA,cACgCN,KAAK,CAACS;MADtC;QAAA;UAAA,SAIY;QAJZ,IAMQG,KAAK,CAACJ,OAAN,GACEI,KAAK,CAACJ,OAAN,CAAc;UACdK,OAAO,EAAEA,OAAO,CAACP,KADH;UAEdH,GAAG,EAAEH,KAAK,CAACG,GAFG;UAGdG,KAAK,EAAEN,KAAK,CAACM;QAHC,CAAd,CADF,GAMEO,OAAO,CAACP,KAZlB,cAGeN,KAAK,CAACC,MAHrB;MAAA;IAiBD,CAlBD;EAmBD;;AA1CqC,CAAD,CAAhC"}
1
+ {"version":3,"file":"VCounter.mjs","names":["VSlideYTransition","makeTransitionProps","MaybeTransition","computed","defineComponent","useRender","VCounter","name","functional","props","active","Boolean","max","Number","String","value","type","default","transition","component","setup","slots","counter"],"sources":["../../../src/components/VCounter/VCounter.tsx"],"sourcesContent":["// Styles\nimport './VCounter.sass'\n\n// Components\nimport { VSlideYTransition } from '@/components/transitions'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\nexport const VCounter = defineComponent({\n name: 'VCounter',\n\n functional: true,\n\n props: {\n active: Boolean,\n max: [Number, String],\n value: {\n type: [Number, String],\n default: 0,\n },\n\n ...makeTransitionProps({\n transition: { component: VSlideYTransition },\n }),\n },\n\n setup (props, { slots }) {\n const counter = computed(() => {\n return props.max ? `${props.value} / ${props.max}` : String(props.value)\n })\n\n useRender(() => (\n <MaybeTransition transition={ props.transition }>\n <div\n v-show={ props.active }\n class=\"v-counter\"\n >\n { slots.default\n ? slots.default({\n counter: counter.value,\n max: props.max,\n value: props.value,\n })\n : counter.value\n }\n </div>\n </MaybeTransition>\n ))\n\n return {}\n },\n})\n"],"mappings":";AAAA;AACA,wB,CAEA;;SACSA,iB,oCAET;;SACSC,mB,EAAqBC,e,4CAE9B;;AACA,SAASC,QAAT,QAAyB,KAAzB;SACSC,e,EAAiBC,S;AAE1B,OAAO,MAAMC,QAAQ,GAAGF,eAAe,CAAC;EACtCG,IAAI,EAAE,UADgC;EAGtCC,UAAU,EAAE,IAH0B;EAKtCC,KAAK,EAAE;IACLC,MAAM,EAAEC,OADH;IAELC,GAAG,EAAE,CAACC,MAAD,EAASC,MAAT,CAFA;IAGLC,KAAK,EAAE;MACLC,IAAI,EAAE,CAACH,MAAD,EAASC,MAAT,CADD;MAELG,OAAO,EAAE;IAFJ,CAHF;IAQL,GAAGhB,mBAAmB,CAAC;MACrBiB,UAAU,EAAE;QAAEC,SAAS,EAAEnB;MAAb;IADS,CAAD;EARjB,CAL+B;;EAkBtCoB,KAAK,CAAEX,KAAF,QAAoB;IAAA,IAAX;MAAEY;IAAF,CAAW;IACvB,MAAMC,OAAO,GAAGnB,QAAQ,CAAC,MAAM;MAC7B,OAAOM,KAAK,CAACG,GAAN,GAAa,GAAEH,KAAK,CAACM,KAAM,MAAKN,KAAK,CAACG,GAAI,EAA1C,GAA8CE,MAAM,CAACL,KAAK,CAACM,KAAP,CAA3D;IACD,CAFuB,CAAxB;IAIAV,SAAS,CAAC;MAAA,cACsBI,KAAK,CAACS;IAD5B;MAAA;QAAA,SAIE;MAJF,IAMFG,KAAK,CAACJ,OAAN,GACEI,KAAK,CAACJ,OAAN,CAAc;QACdK,OAAO,EAAEA,OAAO,CAACP,KADH;QAEdH,GAAG,EAAEH,KAAK,CAACG,GAFG;QAGdG,KAAK,EAAEN,KAAK,CAACM;MAHC,CAAd,CADF,GAMEO,OAAO,CAACP,KAZR,cAGKN,KAAK,CAACC,MAHX;IAAA,EAAD,CAAT;IAkBA,OAAO,EAAP;EACD;;AA1CqC,CAAD,CAAhC"}
@@ -1,9 +1,8 @@
1
- @forward './variables'
2
1
  @use '../../styles/settings'
3
2
  @use './variables' as *
4
3
 
5
4
  .v-counter
6
5
  color: $counter-color
7
- flex: 0 1 auto
6
+ flex: $counter-flex
8
7
  font-size: $counter-font-size
9
8
  transition-duration: $counter-transition-duration
@@ -1,5 +1,6 @@
1
- // Defaults
1
+ // VCounter
2
2
  $counter-color: rgba(var(--v-theme-on-surface), var(--v-medium-emphasis-opacity)) !default;
3
+ $counter-flex: 0 1 auto !default;
3
4
  $counter-font-size: 12px !default;
4
5
  $counter-line-height: $counter-font-size !default;
5
6
  $counter-min-height: 12px !default;
@@ -19,13 +19,10 @@
19
19
  display: flex;
20
20
  flex-direction: column;
21
21
  }
22
- .v-dialog .v-overlay__content > .v-card > .v-card-avatar {
23
- padding: 0;
24
- }
25
- .v-dialog .v-overlay__content > .v-card > .v-card-header {
22
+ .v-dialog .v-overlay__content > .v-card > .v-card-item {
26
23
  padding: 14px 24px 0;
27
24
  }
28
- .v-dialog .v-overlay__content > .v-card > .v-card-header + .v-card-text {
25
+ .v-dialog .v-overlay__content > .v-card > .v-card-item + .v-card-text {
29
26
  padding-top: 10px;
30
27
  }
31
28
  .v-dialog .v-overlay__content > .v-card > .v-card-text {