@vuetify/nightly 3.0.0-alpha.11 → 3.0.0-beta.0

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 (921) hide show
  1. package/CHANGELOG.md +2 -28
  2. package/dist/json/attributes.json +2472 -520
  3. package/dist/json/importMap.json +134 -14
  4. package/dist/json/tags.json +753 -112
  5. package/dist/json/web-types.json +11494 -5089
  6. package/dist/vuetify.css +4937 -2974
  7. package/dist/vuetify.d.ts +11788 -3139
  8. package/dist/vuetify.esm.js +12489 -5014
  9. package/dist/vuetify.esm.js.map +1 -1
  10. package/dist/vuetify.js +12486 -5010
  11. package/dist/vuetify.js.map +1 -1
  12. package/dist/vuetify.min.css +3 -3
  13. package/dist/vuetify.min.js +1393 -2
  14. package/dist/vuetify.min.js.map +1 -1
  15. package/lib/components/VAlert/VAlert.css +80 -92
  16. package/lib/components/VAlert/VAlert.mjs +55 -65
  17. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  18. package/lib/components/VAlert/VAlert.sass +56 -76
  19. package/lib/components/VAlert/VAlertTitle.mjs +3 -0
  20. package/lib/components/VAlert/VAlertTitle.mjs.map +1 -0
  21. package/lib/components/VAlert/_variables.scss +18 -30
  22. package/lib/components/VAlert/index.mjs +2 -1
  23. package/lib/components/VAlert/index.mjs.map +1 -1
  24. package/lib/components/VApp/VApp.css +1 -2
  25. package/lib/components/VApp/VApp.mjs +23 -13
  26. package/lib/components/VApp/VApp.mjs.map +1 -1
  27. package/lib/components/VApp/VApp.sass +1 -2
  28. package/lib/components/VApp/index.mjs +1 -1
  29. package/lib/components/VApp/index.mjs.map +1 -1
  30. package/lib/components/VAppBar/VAppBar.css +4 -94
  31. package/lib/components/VAppBar/VAppBar.mjs +39 -100
  32. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  33. package/lib/components/VAppBar/VAppBar.sass +4 -87
  34. package/lib/components/VAppBar/VAppBarNavIcon.mjs +6 -5
  35. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  36. package/lib/components/VAppBar/VAppBarTitle.mjs +10 -19
  37. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  38. package/lib/components/VAppBar/_variables.scss +1 -1
  39. package/lib/components/VAppBar/index.mjs +3 -3
  40. package/lib/components/VAppBar/index.mjs.map +1 -1
  41. package/lib/components/VAutocomplete/VAutocomplete.css +57 -0
  42. package/lib/components/VAutocomplete/VAutocomplete.mjs +229 -359
  43. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  44. package/lib/components/VAutocomplete/VAutocomplete.sass +69 -33
  45. package/lib/components/VAutocomplete/_variables.scss +7 -4
  46. package/lib/components/VAutocomplete/index.mjs +1 -3
  47. package/lib/components/VAutocomplete/index.mjs.map +1 -1
  48. package/lib/components/VAvatar/VAvatar.css +3 -16
  49. package/lib/components/VAvatar/VAvatar.mjs +16 -15
  50. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  51. package/lib/components/VAvatar/VAvatar.sass +2 -17
  52. package/lib/components/VAvatar/_variables.scss +9 -2
  53. package/lib/components/VAvatar/index.mjs +1 -1
  54. package/lib/components/VAvatar/index.mjs.map +1 -1
  55. package/lib/components/VBadge/VBadge.css +2 -2
  56. package/lib/components/VBadge/VBadge.mjs +29 -19
  57. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  58. package/lib/components/VBadge/VBadge.sass +2 -2
  59. package/lib/components/VBadge/_variables.scss +3 -2
  60. package/lib/components/VBadge/index.mjs +1 -1
  61. package/lib/components/VBadge/index.mjs.map +1 -1
  62. package/lib/components/VBanner/VBanner.css +16 -28
  63. package/lib/components/VBanner/VBanner.mjs +53 -46
  64. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  65. package/lib/components/VBanner/VBanner.sass +8 -20
  66. package/lib/components/VBanner/VBannerActions.mjs +1 -1
  67. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  68. package/lib/components/VBanner/VBannerText.mjs +1 -1
  69. package/lib/components/VBanner/VBannerText.mjs.map +1 -1
  70. package/lib/components/VBanner/_variables.scss +2 -6
  71. package/lib/components/VBanner/index.mjs +3 -5
  72. package/lib/components/VBanner/index.mjs.map +1 -1
  73. package/lib/components/VBottomNavigation/VBottomNavigation.css +38 -7
  74. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +50 -30
  75. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  76. package/lib/components/VBottomNavigation/VBottomNavigation.sass +43 -7
  77. package/lib/components/VBottomNavigation/_variables.scss +19 -2
  78. package/lib/components/VBottomNavigation/index.mjs +1 -1
  79. package/lib/components/VBottomNavigation/index.mjs.map +1 -1
  80. package/lib/components/VBreadcrumbs/VBreadcrumbs.css +7 -7
  81. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +52 -47
  82. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  83. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +1 -1
  84. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  85. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +30 -34
  86. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  87. package/lib/components/VBreadcrumbs/_variables.scss +1 -1
  88. package/lib/components/VBreadcrumbs/index.mjs +3 -3
  89. package/lib/components/VBreadcrumbs/index.mjs.map +1 -1
  90. package/lib/components/VBtn/VBtn.css +25 -91
  91. package/lib/components/VBtn/VBtn.mjs +31 -25
  92. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  93. package/lib/components/VBtn/VBtn.sass +17 -68
  94. package/lib/components/VBtn/_variables.scss +6 -22
  95. package/lib/components/VBtn/index.mjs +1 -1
  96. package/lib/components/VBtn/index.mjs.map +1 -1
  97. package/lib/components/VBtnGroup/VBtnGroup.css +49 -0
  98. package/lib/components/VBtnGroup/VBtnGroup.mjs +67 -0
  99. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -0
  100. package/lib/components/VBtnGroup/VBtnGroup.sass +44 -0
  101. package/lib/components/VBtnGroup/_variables.scss +25 -0
  102. package/lib/components/VBtnGroup/index.mjs +2 -0
  103. package/lib/components/VBtnGroup/index.mjs.map +1 -0
  104. package/lib/components/VBtnToggle/VBtnToggle.css +3 -0
  105. package/lib/components/VBtnToggle/VBtnToggle.mjs +45 -39
  106. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  107. package/lib/components/VBtnToggle/VBtnToggle.sass +5 -97
  108. package/lib/components/VBtnToggle/_variables.scss +3 -10
  109. package/lib/components/VBtnToggle/index.mjs +1 -3
  110. package/lib/components/VBtnToggle/index.mjs.map +1 -1
  111. package/lib/components/VCalendar/VCalendar.mjs +8 -4
  112. package/lib/components/VCalendar/VCalendar.mjs.map +1 -1
  113. package/lib/components/VCalendar/VCalendarCategory.sass +67 -0
  114. package/lib/components/VCalendar/_variables.scss +4 -0
  115. package/lib/components/VCalendar/mixins/calendar-base.mjs +5 -4
  116. package/lib/components/VCalendar/mixins/calendar-base.mjs.map +1 -1
  117. package/lib/components/VCalendar/mixins/calendar-with-events.mjs +17 -11
  118. package/lib/components/VCalendar/mixins/calendar-with-events.mjs.map +1 -1
  119. package/lib/components/VCalendar/mixins/calendar-with-events.sass +7 -1
  120. package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs +2 -1
  121. package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs.map +1 -1
  122. package/lib/components/VCalendar/mixins/mouse.mjs +19 -0
  123. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  124. package/lib/components/VCalendar/modes/common.mjs +7 -3
  125. package/lib/components/VCalendar/modes/common.mjs.map +1 -1
  126. package/lib/components/VCalendar/modes/stack.mjs +2 -1
  127. package/lib/components/VCalendar/modes/stack.mjs.map +1 -1
  128. package/lib/components/VCalendar/util/events.mjs +3 -1
  129. package/lib/components/VCalendar/util/events.mjs.map +1 -1
  130. package/lib/components/VCalendar/util/timestamp.mjs +19 -7
  131. package/lib/components/VCalendar/util/timestamp.mjs.map +1 -1
  132. package/lib/components/VCard/VCard.css +18 -17
  133. package/lib/components/VCard/VCard.mjs +67 -49
  134. package/lib/components/VCard/VCard.mjs.map +1 -1
  135. package/lib/components/VCard/VCard.sass +9 -2
  136. package/lib/components/VCard/VCardActions.mjs +29 -2
  137. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  138. package/lib/components/VCard/VCardAvatar.mjs +1 -1
  139. package/lib/components/VCard/VCardAvatar.mjs.map +1 -1
  140. package/lib/components/VCard/VCardHeader.mjs +1 -1
  141. package/lib/components/VCard/VCardHeader.mjs.map +1 -1
  142. package/lib/components/VCard/VCardHeaderText.mjs +1 -1
  143. package/lib/components/VCard/VCardHeaderText.mjs.map +1 -1
  144. package/lib/components/VCard/VCardImg.mjs +1 -1
  145. package/lib/components/VCard/VCardImg.mjs.map +1 -1
  146. package/lib/components/VCard/VCardSubtitle.mjs +1 -1
  147. package/lib/components/VCard/VCardSubtitle.mjs.map +1 -1
  148. package/lib/components/VCard/VCardText.mjs +1 -1
  149. package/lib/components/VCard/VCardText.mjs.map +1 -1
  150. package/lib/components/VCard/VCardTitle.mjs +1 -1
  151. package/lib/components/VCard/VCardTitle.mjs.map +1 -1
  152. package/lib/components/VCard/_variables.scss +5 -5
  153. package/lib/components/VCard/index.mjs +9 -10
  154. package/lib/components/VCard/index.mjs.map +1 -1
  155. package/lib/components/VCarousel/VCarousel.css +63 -0
  156. package/lib/components/VCarousel/VCarousel.mjs +100 -179
  157. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  158. package/lib/components/VCarousel/VCarousel.sass +7 -2
  159. package/lib/components/VCarousel/VCarouselItem.mjs +23 -58
  160. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  161. package/lib/components/VCarousel/_variables.scss +1 -3
  162. package/lib/components/VCarousel/index.mjs +2 -9
  163. package/lib/components/VCarousel/index.mjs.map +1 -1
  164. package/lib/components/VCheckbox/VCheckbox.css +3 -0
  165. package/lib/components/VCheckbox/VCheckbox.mjs +56 -83
  166. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  167. package/lib/components/VCheckbox/VCheckbox.sass +8 -8
  168. package/lib/components/VCheckbox/_variables.scss +2 -4
  169. package/lib/components/VCheckbox/index.mjs +1 -9
  170. package/lib/components/VCheckbox/index.mjs.map +1 -1
  171. package/lib/components/VChip/VChip.css +101 -81
  172. package/lib/components/VChip/VChip.mjs +48 -27
  173. package/lib/components/VChip/VChip.mjs.map +1 -1
  174. package/lib/components/VChip/VChip.sass +16 -15
  175. package/lib/components/VChip/_mixins.scss +5 -3
  176. package/lib/components/VChip/_variables.scss +6 -15
  177. package/lib/components/VChip/index.mjs +1 -1
  178. package/lib/components/VChip/index.mjs.map +1 -1
  179. package/lib/components/VChipGroup/VChipGroup.css +18 -0
  180. package/lib/components/VChipGroup/VChipGroup.mjs +66 -38
  181. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  182. package/lib/components/VChipGroup/VChipGroup.sass +11 -17
  183. package/lib/components/VChipGroup/_variables.scss +3 -5
  184. package/lib/components/VChipGroup/index.mjs +1 -3
  185. package/lib/components/VChipGroup/index.mjs.map +1 -1
  186. package/lib/components/VColorPicker/VColorPicker.css +21 -0
  187. package/lib/components/VColorPicker/VColorPicker.mjs +98 -128
  188. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  189. package/lib/components/VColorPicker/VColorPicker.sass +10 -17
  190. package/lib/components/VColorPicker/VColorPickerCanvas.css +21 -0
  191. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +139 -121
  192. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  193. package/lib/components/VColorPicker/VColorPickerCanvas.sass +5 -3
  194. package/lib/components/VColorPicker/VColorPickerEdit.css +31 -0
  195. package/lib/components/VColorPicker/VColorPickerEdit.mjs +70 -130
  196. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  197. package/lib/components/VColorPicker/VColorPickerEdit.sass +9 -6
  198. package/lib/components/VColorPicker/VColorPickerPreview.css +67 -0
  199. package/lib/components/VColorPicker/VColorPickerPreview.mjs +64 -82
  200. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  201. package/lib/components/VColorPicker/VColorPickerPreview.sass +42 -39
  202. package/lib/components/VColorPicker/VColorPickerSwatches.css +35 -0
  203. package/lib/components/VColorPicker/VColorPickerSwatches.mjs +33 -53
  204. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  205. package/lib/components/VColorPicker/VColorPickerSwatches.sass +6 -4
  206. package/lib/components/VColorPicker/_variables.scss +5 -9
  207. package/lib/components/VColorPicker/index.mjs +1 -5
  208. package/lib/components/VColorPicker/index.mjs.map +1 -1
  209. package/lib/components/VColorPicker/util/index.mjs +141 -97
  210. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  211. package/lib/components/VCombobox/VCombobox.css +66 -0
  212. package/lib/components/VCombobox/VCombobox.mjs +317 -213
  213. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  214. package/lib/components/VCombobox/VCombobox.sass +91 -0
  215. package/lib/components/VCombobox/_variables.scss +8 -0
  216. package/lib/components/VCombobox/index.mjs +1 -3
  217. package/lib/components/VCombobox/index.mjs.map +1 -1
  218. package/lib/components/VCounter/VCounter.css +2 -0
  219. package/lib/components/VCounter/VCounter.mjs +29 -14
  220. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  221. package/lib/components/VCounter/VCounter.sass +3 -0
  222. package/lib/components/VCounter/_variables.scss +2 -0
  223. package/lib/components/VDataIterator/VDataIterator.mjs +14 -6
  224. package/lib/components/VDataIterator/VDataIterator.mjs.map +1 -1
  225. package/lib/components/VDataTable/MobileRow.mjs +6 -5
  226. package/lib/components/VDataTable/MobileRow.mjs.map +1 -1
  227. package/lib/components/VDataTable/Row.mjs +19 -11
  228. package/lib/components/VDataTable/Row.mjs.map +1 -1
  229. package/lib/components/VDataTable/RowGroup.mjs +5 -4
  230. package/lib/components/VDataTable/RowGroup.mjs.map +1 -1
  231. package/lib/components/VDataTable/VDataTable.mjs +5 -3
  232. package/lib/components/VDataTable/VDataTable.mjs.map +1 -1
  233. package/lib/components/VDataTable/VDataTableHeader.mjs +6 -5
  234. package/lib/components/VDataTable/VDataTableHeader.mjs.map +1 -1
  235. package/lib/components/VDataTable/VDataTableHeaderMobile.mjs +2 -2
  236. package/lib/components/VDataTable/VDataTableHeaderMobile.mjs.map +1 -1
  237. package/lib/components/VDataTable/VEditDialog.mjs +6 -5
  238. package/lib/components/VDataTable/VEditDialog.mjs.map +1 -1
  239. package/lib/components/VDatePicker/VDatePicker.mjs +2 -2
  240. package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
  241. package/lib/components/VDatePicker/VDatePickerHeader.mjs +3 -3
  242. package/lib/components/VDatePicker/VDatePickerHeader.mjs.map +1 -1
  243. package/lib/components/VDatePicker/VDatePickerTitle.mjs +1 -1
  244. package/lib/components/VDatePicker/VDatePickerTitle.mjs.map +1 -1
  245. package/lib/components/VDatePicker/VDatePickerYears.mjs +2 -2
  246. package/lib/components/VDatePicker/VDatePickerYears.mjs.map +1 -1
  247. package/lib/components/VDatePicker/mixins/date-picker-table.mjs +5 -4
  248. package/lib/components/VDatePicker/mixins/date-picker-table.mjs.map +1 -1
  249. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs +6 -4
  250. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs.map +1 -1
  251. package/lib/components/VDatePicker/util/pad.mjs +4 -1
  252. package/lib/components/VDatePicker/util/pad.mjs.map +1 -1
  253. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs +26 -8
  254. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  255. package/lib/components/VDefaultsProvider/index.mjs +1 -1
  256. package/lib/components/VDefaultsProvider/index.mjs.map +1 -1
  257. package/lib/components/VDialog/VDialog.css +8 -1
  258. package/lib/components/VDialog/VDialog.mjs +9 -7
  259. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  260. package/lib/components/VDialog/VDialog.sass +7 -0
  261. package/lib/components/VDialog/index.mjs +1 -2
  262. package/lib/components/VDialog/index.mjs.map +1 -1
  263. package/lib/components/VDivider/VDivider.mjs +17 -10
  264. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  265. package/lib/components/VDivider/index.mjs +1 -1
  266. package/lib/components/VDivider/index.mjs.map +1 -1
  267. package/lib/components/VExpansionPanel/VExpansionPanel.css +5 -3
  268. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +32 -28
  269. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  270. package/lib/components/VExpansionPanel/VExpansionPanel.sass +5 -1
  271. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs +12 -10
  272. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  273. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +17 -15
  274. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  275. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +26 -20
  276. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  277. package/lib/components/VExpansionPanel/_variables.scss +1 -1
  278. package/lib/components/VExpansionPanel/index.mjs +4 -4
  279. package/lib/components/VExpansionPanel/index.mjs.map +1 -1
  280. package/lib/components/VField/VField.css +182 -160
  281. package/lib/components/VField/VField.mjs +124 -158
  282. package/lib/components/VField/VField.mjs.map +1 -1
  283. package/lib/components/VField/VField.sass +173 -151
  284. package/lib/components/VField/VFieldLabel.mjs +12 -14
  285. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  286. package/lib/components/VField/_variables.scss +14 -6
  287. package/lib/components/VField/index.mjs +1 -1
  288. package/lib/components/VField/index.mjs.map +1 -1
  289. package/lib/components/VFileInput/VFileInput.css +0 -33
  290. package/lib/components/VFileInput/VFileInput.mjs +144 -99
  291. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  292. package/lib/components/VFileInput/VFileInput.sass +0 -37
  293. package/lib/components/VFileInput/index.mjs +1 -1
  294. package/lib/components/VFileInput/index.mjs.map +1 -1
  295. package/lib/components/VFooter/VFooter.css +2 -2
  296. package/lib/components/VFooter/VFooter.mjs +22 -14
  297. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  298. package/lib/components/VFooter/_variables.scss +2 -2
  299. package/lib/components/VFooter/index.mjs +1 -1
  300. package/lib/components/VFooter/index.mjs.map +1 -1
  301. package/lib/components/VForm/VForm.mjs +46 -127
  302. package/lib/components/VForm/VForm.mjs.map +1 -1
  303. package/lib/components/VForm/index.mjs +1 -3
  304. package/lib/components/VForm/index.mjs.map +1 -1
  305. package/lib/components/VGrid/VCol.mjs +5 -4
  306. package/lib/components/VGrid/VCol.mjs.map +1 -1
  307. package/lib/components/VGrid/VContainer.mjs +6 -5
  308. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  309. package/lib/components/VGrid/VGrid.css +1 -1
  310. package/lib/components/VGrid/VRow.mjs +5 -4
  311. package/lib/components/VGrid/VRow.mjs.map +1 -1
  312. package/lib/components/VGrid/VSpacer.mjs +1 -1
  313. package/lib/components/VGrid/VSpacer.mjs.map +1 -1
  314. package/lib/components/VGrid/index.mjs +4 -4
  315. package/lib/components/VGrid/index.mjs.map +1 -1
  316. package/lib/components/VHover/VHover.mjs +8 -7
  317. package/lib/components/VHover/VHover.mjs.map +1 -1
  318. package/lib/components/VHover/index.mjs +1 -1
  319. package/lib/components/VHover/index.mjs.map +1 -1
  320. package/lib/components/VIcon/VIcon.css +2 -6
  321. package/lib/components/VIcon/VIcon.mjs +15 -9
  322. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  323. package/lib/components/VIcon/VIcon.sass +2 -8
  324. package/lib/components/VIcon/_variables.scss +0 -1
  325. package/lib/components/VIcon/index.mjs +1 -1
  326. package/lib/components/VIcon/index.mjs.map +1 -1
  327. package/lib/components/VImg/VImg.css +8 -0
  328. package/lib/components/VImg/VImg.mjs +58 -27
  329. package/lib/components/VImg/VImg.mjs.map +1 -1
  330. package/lib/components/VImg/VImg.sass +10 -5
  331. package/lib/components/VImg/index.mjs +1 -1
  332. package/lib/components/VImg/index.mjs.map +1 -1
  333. package/lib/components/VInput/VInput.css +68 -11
  334. package/lib/components/VInput/VInput.mjs +95 -29
  335. package/lib/components/VInput/VInput.mjs.map +1 -1
  336. package/lib/components/VInput/VInput.sass +51 -12
  337. package/lib/components/VInput/_variables.scss +1 -1
  338. package/lib/components/VItemGroup/VItem.mjs +7 -5
  339. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  340. package/lib/components/VItemGroup/VItemGroup.mjs +8 -7
  341. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  342. package/lib/components/VItemGroup/index.mjs +2 -2
  343. package/lib/components/VItemGroup/index.mjs.map +1 -1
  344. package/lib/components/VLabel/VLabel.css +12 -0
  345. package/lib/components/VLabel/VLabel.mjs +18 -56
  346. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  347. package/lib/components/VLabel/VLabel.sass +13 -11
  348. package/lib/components/VLabel/_variables.scss +7 -4
  349. package/lib/components/VLabel/index.mjs +1 -3
  350. package/lib/components/VLabel/index.mjs.map +1 -1
  351. package/lib/components/VLayout/VLayout.css +1 -0
  352. package/lib/components/VLayout/VLayout.mjs +12 -7
  353. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  354. package/lib/components/VLayout/VLayout.sass +1 -0
  355. package/lib/components/VLayout/VLayoutItem.css +1 -1
  356. package/lib/components/VLayout/VLayoutItem.mjs +20 -11
  357. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  358. package/lib/components/VLayout/VLayoutItem.sass +1 -1
  359. package/lib/components/VLayout/index.mjs +2 -2
  360. package/lib/components/VLayout/index.mjs.map +1 -1
  361. package/lib/components/VLazy/VLazy.mjs +7 -6
  362. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  363. package/lib/components/VLazy/index.mjs +1 -1
  364. package/lib/components/VLazy/index.mjs.map +1 -1
  365. package/lib/components/VList/VList.css +6 -2
  366. package/lib/components/VList/VList.mjs +77 -28
  367. package/lib/components/VList/VList.mjs.map +1 -1
  368. package/lib/components/VList/VList.sass +6 -2
  369. package/lib/components/VList/VListChildren.mjs +53 -0
  370. package/lib/components/VList/VListChildren.mjs.map +1 -0
  371. package/lib/components/VList/VListGroup.mjs +84 -0
  372. package/lib/components/VList/VListGroup.mjs.map +1 -0
  373. package/lib/components/VList/VListImg.mjs +1 -1
  374. package/lib/components/VList/VListImg.mjs.map +1 -1
  375. package/lib/components/VList/VListItem.css +37 -18
  376. package/lib/components/VList/VListItem.mjs +95 -46
  377. package/lib/components/VList/VListItem.mjs.map +1 -1
  378. package/lib/components/VList/VListItem.sass +26 -6
  379. package/lib/components/VList/VListItemAvatar.mjs +6 -5
  380. package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
  381. package/lib/components/VList/VListItemHeader.mjs +1 -1
  382. package/lib/components/VList/VListItemHeader.mjs.map +1 -1
  383. package/lib/components/VList/VListItemMedia.mjs +6 -5
  384. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  385. package/lib/components/VList/VListItemSubtitle.mjs +1 -1
  386. package/lib/components/VList/VListItemSubtitle.mjs.map +1 -1
  387. package/lib/components/VList/VListItemTitle.mjs +1 -1
  388. package/lib/components/VList/VListItemTitle.mjs.map +1 -1
  389. package/lib/components/VList/VListSubheader.mjs +25 -16
  390. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  391. package/lib/components/VList/_variables.scss +4 -4
  392. package/lib/components/VList/index.mjs +10 -9
  393. package/lib/components/VList/index.mjs.map +1 -1
  394. package/lib/components/VList/list.mjs +31 -0
  395. package/lib/components/VList/list.mjs.map +1 -0
  396. package/lib/components/VLocaleProvider/VLocaleProvider.mjs +6 -5
  397. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  398. package/lib/components/VLocaleProvider/index.mjs +1 -1
  399. package/lib/components/VLocaleProvider/index.mjs.map +1 -1
  400. package/lib/components/VMain/VMain.mjs +8 -7
  401. package/lib/components/VMain/VMain.mjs.map +1 -1
  402. package/lib/components/VMain/index.mjs +1 -1
  403. package/lib/components/VMain/index.mjs.map +1 -1
  404. package/lib/components/VMenu/VMenu.css +0 -3
  405. package/lib/components/VMenu/VMenu.mjs +9 -7
  406. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  407. package/lib/components/VMenu/VMenu.sass +1 -3
  408. package/lib/components/VMenu/_variables.scss +0 -1
  409. package/lib/components/VMenu/index.mjs +1 -2
  410. package/lib/components/VMenu/index.mjs.map +1 -1
  411. package/lib/components/VMessages/VMessages.css +16 -0
  412. package/lib/components/VMessages/VMessages.mjs +42 -41
  413. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  414. package/lib/components/VMessages/VMessages.sass +5 -10
  415. package/lib/components/VMessages/_variables.scss +3 -2
  416. package/lib/components/VMessages/index.mjs +1 -3
  417. package/lib/components/VMessages/index.mjs.map +1 -1
  418. package/lib/components/VNavigationDrawer/VNavigationDrawer.css +21 -9
  419. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +89 -26
  420. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  421. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +19 -8
  422. package/lib/components/VNavigationDrawer/_variables.scss +1 -1
  423. package/lib/components/VNavigationDrawer/index.mjs +1 -1
  424. package/lib/components/VNavigationDrawer/index.mjs.map +1 -1
  425. package/lib/components/VNavigationDrawer/touch.mjs +139 -0
  426. package/lib/components/VNavigationDrawer/touch.mjs.map +1 -0
  427. package/lib/components/VNoSsr/VNoSsr.mjs +10 -18
  428. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  429. package/lib/components/VNoSsr/index.mjs +1 -1
  430. package/lib/components/VNoSsr/index.mjs.map +1 -1
  431. package/lib/components/VOtpInput/VOtpInput.mjs +345 -0
  432. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -0
  433. package/lib/components/VOtpInput/VOtpInput.sass +37 -0
  434. package/lib/components/VOtpInput/_variables.scss +4 -0
  435. package/lib/components/VOtpInput/index.mjs +4 -0
  436. package/lib/components/VOtpInput/index.mjs.map +1 -0
  437. package/lib/components/VOverlay/VOverlay.css +8 -2
  438. package/lib/components/VOverlay/VOverlay.mjs +69 -40
  439. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  440. package/lib/components/VOverlay/VOverlay.sass +6 -2
  441. package/lib/components/VOverlay/_variables.scss +0 -1
  442. package/lib/components/VOverlay/index.mjs +1 -2
  443. package/lib/components/VOverlay/index.mjs.map +1 -1
  444. package/lib/components/VOverlay/positionStrategies.mjs +18 -11
  445. package/lib/components/VOverlay/positionStrategies.mjs.map +1 -1
  446. package/lib/components/VOverlay/scrollStrategies.mjs +14 -1
  447. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  448. package/lib/components/VOverlay/useActivator.mjs +38 -22
  449. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  450. package/lib/components/VOverlay/util/anchor.mjs.map +1 -1
  451. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  452. package/lib/components/VPagination/VPagination.mjs +44 -47
  453. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  454. package/lib/components/VPagination/index.mjs +1 -2
  455. package/lib/components/VPagination/index.mjs.map +1 -1
  456. package/lib/components/VParallax/VParallax.css +7 -0
  457. package/lib/components/VParallax/VParallax.mjs +71 -77
  458. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  459. package/lib/components/VParallax/VParallax.sass +1 -32
  460. package/lib/components/VParallax/index.mjs +1 -3
  461. package/lib/components/VParallax/index.mjs.map +1 -1
  462. package/lib/components/VPicker/VPicker.mjs +3 -3
  463. package/lib/components/VPicker/VPicker.mjs.map +1 -1
  464. package/lib/components/VProgressCircular/VProgressCircular.css +1 -1
  465. package/lib/components/VProgressCircular/VProgressCircular.mjs +26 -16
  466. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  467. package/lib/components/VProgressCircular/_variables.scss +1 -1
  468. package/lib/components/VProgressCircular/index.mjs +1 -1
  469. package/lib/components/VProgressCircular/index.mjs.map +1 -1
  470. package/lib/components/VProgressLinear/VProgressLinear.css +0 -1
  471. package/lib/components/VProgressLinear/VProgressLinear.mjs +17 -19
  472. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  473. package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
  474. package/lib/components/VProgressLinear/index.mjs +1 -1
  475. package/lib/components/VProgressLinear/index.mjs.map +1 -1
  476. package/lib/components/VRadio/VRadio.mjs +34 -0
  477. package/lib/components/VRadio/VRadio.mjs.map +1 -0
  478. package/lib/components/VRadio/index.mjs +2 -0
  479. package/lib/components/VRadio/index.mjs.map +1 -0
  480. package/lib/components/VRadioGroup/VRadioGroup.css +10 -0
  481. package/lib/components/VRadioGroup/VRadioGroup.mjs +66 -69
  482. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  483. package/lib/components/VRadioGroup/VRadioGroup.sass +7 -37
  484. package/lib/components/VRadioGroup/_variables.scss +3 -3
  485. package/lib/components/VRadioGroup/index.mjs +1 -9
  486. package/lib/components/VRadioGroup/index.mjs.map +1 -1
  487. package/lib/components/VRangeSlider/VRangeSlider.mjs +192 -211
  488. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  489. package/lib/components/VRangeSlider/index.mjs +1 -3
  490. package/lib/components/VRangeSlider/index.mjs.map +1 -1
  491. package/lib/components/VRating/VRating.css +1 -1
  492. package/lib/components/VRating/VRating.mjs +30 -24
  493. package/lib/components/VRating/VRating.mjs.map +1 -1
  494. package/lib/components/VRating/VRating.sass +3 -2
  495. package/lib/components/VRating/index.mjs +1 -1
  496. package/lib/components/VRating/index.mjs.map +1 -1
  497. package/lib/components/VResponsive/VResponsive.css +1 -0
  498. package/lib/components/VResponsive/VResponsive.mjs +7 -6
  499. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  500. package/lib/components/VResponsive/VResponsive.sass +1 -0
  501. package/lib/components/VResponsive/index.mjs +1 -1
  502. package/lib/components/VResponsive/index.mjs.map +1 -1
  503. package/lib/components/VSelect/VSelect.css +34 -0
  504. package/lib/components/VSelect/VSelect.mjs +185 -772
  505. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  506. package/lib/components/VSelect/VSelect.sass +44 -153
  507. package/lib/components/VSelect/_variables.scss +7 -21
  508. package/lib/components/VSelect/index.mjs +1 -3
  509. package/lib/components/VSelect/index.mjs.map +1 -1
  510. package/lib/components/VSelectionControl/VSelectionControl.css +97 -0
  511. package/lib/components/VSelectionControl/VSelectionControl.mjs +209 -0
  512. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -0
  513. package/lib/components/VSelectionControl/VSelectionControl.sass +96 -0
  514. package/lib/components/VSelectionControl/_variables.scss +9 -0
  515. package/lib/components/VSelectionControl/index.mjs +2 -0
  516. package/lib/components/VSelectionControl/index.mjs.map +1 -0
  517. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.css +3 -0
  518. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +64 -0
  519. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -0
  520. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +9 -0
  521. package/lib/components/VSelectionControlGroup/_variables.scss +4 -0
  522. package/lib/components/VSelectionControlGroup/index.mjs +2 -0
  523. package/lib/components/VSelectionControlGroup/index.mjs.map +1 -0
  524. package/lib/components/VSheet/VSheet.css +2 -1
  525. package/lib/components/VSheet/VSheet.mjs +12 -14
  526. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  527. package/lib/components/VSheet/VSheet.sass +2 -0
  528. package/lib/components/VSheet/_variables.scss +1 -1
  529. package/lib/components/VSheet/index.mjs +1 -1
  530. package/lib/components/VSheet/index.mjs.map +1 -1
  531. package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs +2 -2
  532. package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
  533. package/lib/components/VSlideGroup/VSlideGroup.css +47 -0
  534. package/lib/components/VSlideGroup/VSlideGroup.mjs +275 -357
  535. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  536. package/lib/components/VSlideGroup/VSlideGroup.sass +21 -21
  537. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +27 -0
  538. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -0
  539. package/lib/components/VSlideGroup/_variables.scss +4 -1
  540. package/lib/components/VSlideGroup/helpers.mjs +54 -0
  541. package/lib/components/VSlideGroup/helpers.mjs.map +1 -0
  542. package/lib/components/VSlideGroup/index.mjs +2 -9
  543. package/lib/components/VSlideGroup/index.mjs.map +1 -1
  544. package/lib/components/VSlider/VSlider.css +48 -0
  545. package/lib/components/VSlider/VSlider.mjs +108 -537
  546. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  547. package/lib/components/VSlider/VSlider.sass +29 -280
  548. package/lib/components/VSlider/VSliderThumb.css +142 -0
  549. package/lib/components/VSlider/VSliderThumb.mjs +165 -0
  550. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -0
  551. package/lib/components/VSlider/VSliderThumb.sass +147 -0
  552. package/lib/components/VSlider/VSliderTrack.css +150 -0
  553. package/lib/components/VSlider/VSliderTrack.mjs +121 -0
  554. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -0
  555. package/lib/components/VSlider/VSliderTrack.sass +159 -0
  556. package/lib/components/VSlider/_variables.scss +18 -13
  557. package/lib/components/VSlider/index.mjs +1 -3
  558. package/lib/components/VSlider/index.mjs.map +1 -1
  559. package/lib/components/VSlider/slider.mjs +300 -0
  560. package/lib/components/VSlider/slider.mjs.map +1 -0
  561. package/lib/components/VSnackbar/VSnackbar.css +136 -0
  562. package/lib/components/VSnackbar/VSnackbar.mjs +88 -167
  563. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  564. package/lib/components/VSnackbar/VSnackbar.sass +34 -69
  565. package/lib/components/VSnackbar/_variables.scss +20 -21
  566. package/lib/components/VSnackbar/index.mjs +1 -3
  567. package/lib/components/VSnackbar/index.mjs.map +1 -1
  568. package/lib/components/VSparkline/VSparkline.mjs +1 -1
  569. package/lib/components/VSparkline/VSparkline.mjs.map +1 -1
  570. package/lib/components/VSparkline/helpers/path.mjs +3 -1
  571. package/lib/components/VSparkline/helpers/path.mjs.map +1 -1
  572. package/lib/components/VSpeedDial/VSpeedDial.mjs +1 -1
  573. package/lib/components/VStepper/VStepper.mjs +1 -1
  574. package/lib/components/VStepper/VStepper.mjs.map +1 -1
  575. package/lib/components/VStepper/VStepper.sass +5 -1
  576. package/lib/components/VStepper/VStepperStep.mjs +1 -1
  577. package/lib/components/VStepper/_variables.scss +2 -1
  578. package/lib/components/VSwitch/VSwitch.css +69 -0
  579. package/lib/components/VSwitch/VSwitch.mjs +100 -111
  580. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  581. package/lib/components/VSwitch/VSwitch.sass +71 -129
  582. package/lib/components/VSwitch/_variables.scss +10 -23
  583. package/lib/components/VSwitch/index.mjs +1 -3
  584. package/lib/components/VSwitch/index.mjs.map +1 -1
  585. package/lib/components/VSystemBar/VSystemBar.css +16 -13
  586. package/lib/components/VSystemBar/VSystemBar.mjs +19 -19
  587. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  588. package/lib/components/VSystemBar/VSystemBar.sass +11 -15
  589. package/lib/components/VSystemBar/_variables.scss +25 -16
  590. package/lib/components/VSystemBar/index.mjs +1 -1
  591. package/lib/components/VSystemBar/index.mjs.map +1 -1
  592. package/lib/components/VTable/VTable.css +143 -0
  593. package/lib/components/VTable/VTable.mjs +54 -0
  594. package/lib/components/VTable/VTable.mjs.map +1 -0
  595. package/lib/components/VTable/VTable.sass +156 -0
  596. package/lib/components/VTable/_mixins.scss +25 -0
  597. package/lib/components/VTable/_variables.scss +21 -0
  598. package/lib/components/VTable/index.mjs +2 -0
  599. package/lib/components/VTable/index.mjs.map +1 -0
  600. package/lib/components/VTabs/VTab.css +29 -0
  601. package/lib/components/VTabs/VTab.mjs +114 -70
  602. package/lib/components/VTabs/VTab.mjs.map +1 -1
  603. package/lib/components/VTabs/VTab.sass +30 -0
  604. package/lib/components/VTabs/VTabs.css +67 -0
  605. package/lib/components/VTabs/VTabs.mjs +81 -277
  606. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  607. package/lib/components/VTabs/VTabs.sass +37 -207
  608. package/lib/components/VTabs/_variables.scss +10 -16
  609. package/lib/components/VTabs/index.mjs +2 -15
  610. package/lib/components/VTabs/index.mjs.map +1 -1
  611. package/lib/components/VTextField/VTextField.css +55 -33
  612. package/lib/components/VTextField/VTextField.mjs +138 -82
  613. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  614. package/lib/components/VTextField/VTextField.sass +62 -38
  615. package/lib/components/VTextField/_variables.scss +7 -48
  616. package/lib/components/VTextarea/VTextarea.css +34 -0
  617. package/lib/components/VTextarea/VTextarea.mjs +210 -74
  618. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  619. package/lib/components/VTextarea/VTextarea.sass +32 -76
  620. package/lib/components/VTextarea/_variables.scss +2 -4
  621. package/lib/components/VTextarea/index.mjs +1 -3
  622. package/lib/components/VTextarea/index.mjs.map +1 -1
  623. package/lib/components/VThemeProvider/VThemeProvider.mjs +8 -7
  624. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  625. package/lib/components/VThemeProvider/index.mjs +1 -1
  626. package/lib/components/VThemeProvider/index.mjs.map +1 -1
  627. package/lib/components/VTimePicker/VTimePicker.mjs +2 -2
  628. package/lib/components/VTimePicker/VTimePicker.mjs.map +1 -1
  629. package/lib/components/VTimePicker/VTimePickerClock.mjs +2 -2
  630. package/lib/components/VTimePicker/VTimePickerClock.mjs.map +1 -1
  631. package/lib/components/VTimePicker/VTimePickerTitle.mjs +1 -1
  632. package/lib/components/VTimePicker/VTimePickerTitle.mjs.map +1 -1
  633. package/lib/components/VTimeline/VTimeline.css +3 -3
  634. package/lib/components/VTimeline/VTimeline.mjs +12 -12
  635. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  636. package/lib/components/VTimeline/VTimelineDivider.mjs +7 -6
  637. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  638. package/lib/components/VTimeline/VTimelineItem.mjs +9 -10
  639. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  640. package/lib/components/VTimeline/index.mjs +2 -2
  641. package/lib/components/VTimeline/index.mjs.map +1 -1
  642. package/lib/components/VToolbar/VToolbar.css +138 -0
  643. package/lib/components/VToolbar/VToolbar.mjs +138 -141
  644. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  645. package/lib/components/VToolbar/VToolbar.sass +74 -123
  646. package/lib/components/VToolbar/VToolbarItems.mjs +33 -0
  647. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -0
  648. package/lib/components/VToolbar/VToolbarTitle.mjs +34 -0
  649. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -0
  650. package/lib/components/VToolbar/_variables.scss +53 -15
  651. package/lib/components/VToolbar/index.mjs +3 -14
  652. package/lib/components/VToolbar/index.mjs.map +1 -1
  653. package/lib/components/VTooltip/VTooltip.css +3 -2
  654. package/lib/components/VTooltip/VTooltip.mjs +18 -12
  655. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  656. package/lib/components/VTooltip/VTooltip.sass +1 -0
  657. package/lib/components/VTooltip/_variables.scss +2 -2
  658. package/lib/components/VTooltip/index.mjs +1 -1
  659. package/lib/components/VTooltip/index.mjs.map +1 -1
  660. package/lib/components/VTreeview/VTreeview.mjs +14 -7
  661. package/lib/components/VTreeview/VTreeview.mjs.map +1 -1
  662. package/lib/components/VTreeview/VTreeviewNode.mjs +4 -2
  663. package/lib/components/VTreeview/VTreeviewNode.mjs.map +1 -1
  664. package/lib/components/VValidation/VValidation.mjs +26 -0
  665. package/lib/components/VValidation/VValidation.mjs.map +1 -0
  666. package/lib/components/VValidation/index.mjs +2 -0
  667. package/lib/components/VValidation/index.mjs.map +1 -0
  668. package/lib/components/VWindow/VWindow.css +70 -0
  669. package/lib/components/VWindow/VWindow.mjs +166 -233
  670. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  671. package/lib/components/VWindow/VWindow.sass +26 -50
  672. package/lib/components/VWindow/VWindowItem.mjs +72 -98
  673. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  674. package/lib/components/VWindow/_variables.scss +2 -3
  675. package/lib/components/VWindow/index.mjs +2 -9
  676. package/lib/components/VWindow/index.mjs.map +1 -1
  677. package/lib/components/index.d.ts +11597 -3077
  678. package/lib/components/index.mjs +46 -39
  679. package/lib/components/index.mjs.map +1 -1
  680. package/lib/components/transitions/createTransition.mjs +14 -14
  681. package/lib/components/transitions/createTransition.mjs.map +1 -1
  682. package/lib/components/transitions/dialog-transition.mjs +6 -5
  683. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  684. package/lib/components/transitions/expand-transition.mjs +3 -1
  685. package/lib/components/transitions/expand-transition.mjs.map +1 -1
  686. package/lib/components/transitions/index.mjs +1 -1
  687. package/lib/components/transitions/index.mjs.map +1 -1
  688. package/lib/composables/border.mjs +3 -2
  689. package/lib/composables/border.mjs.map +1 -1
  690. package/lib/composables/defaults.mjs +29 -5
  691. package/lib/composables/defaults.mjs.map +1 -1
  692. package/lib/composables/density.mjs +3 -2
  693. package/lib/composables/density.mjs.map +1 -1
  694. package/lib/composables/display.mjs +2 -1
  695. package/lib/composables/display.mjs.map +1 -1
  696. package/lib/composables/elevation.mjs +4 -3
  697. package/lib/composables/elevation.mjs.map +1 -1
  698. package/lib/composables/filter.mjs +87 -0
  699. package/lib/composables/filter.mjs.map +1 -0
  700. package/lib/composables/focus.mjs +35 -0
  701. package/lib/composables/focus.mjs.map +1 -0
  702. package/lib/composables/form.mjs +103 -0
  703. package/lib/composables/form.mjs.map +1 -0
  704. package/lib/composables/forwardRef.mjs +42 -0
  705. package/lib/composables/forwardRef.mjs.map +1 -0
  706. package/lib/composables/group.mjs +51 -37
  707. package/lib/composables/group.mjs.map +1 -1
  708. package/lib/composables/hydration.mjs +12 -0
  709. package/lib/composables/hydration.mjs.map +1 -0
  710. package/lib/composables/icons.mjs +7 -6
  711. package/lib/composables/icons.mjs.map +1 -1
  712. package/lib/composables/index.mjs +1 -0
  713. package/lib/composables/index.mjs.map +1 -1
  714. package/lib/composables/intersectionObserver.mjs +21 -16
  715. package/lib/composables/intersectionObserver.mjs.map +1 -1
  716. package/lib/composables/layout.mjs +126 -41
  717. package/lib/composables/layout.mjs.map +1 -1
  718. package/lib/composables/loader.mjs +39 -0
  719. package/lib/composables/loader.mjs.map +1 -0
  720. package/lib/composables/locale.mjs +10 -6
  721. package/lib/composables/locale.mjs.map +1 -1
  722. package/lib/composables/nested/nested.mjs +194 -0
  723. package/lib/composables/nested/nested.mjs.map +1 -0
  724. package/lib/composables/nested/openStrategies.mjs +49 -0
  725. package/lib/composables/nested/openStrategies.mjs.map +1 -0
  726. package/lib/composables/nested/selectStrategies.mjs +157 -0
  727. package/lib/composables/nested/selectStrategies.mjs.map +1 -0
  728. package/lib/composables/overlay.mjs +30 -0
  729. package/lib/composables/overlay.mjs.map +1 -0
  730. package/lib/composables/position.mjs +3 -2
  731. package/lib/composables/position.mjs.map +1 -1
  732. package/lib/composables/proxiedModel.mjs +10 -5
  733. package/lib/composables/proxiedModel.mjs.map +1 -1
  734. package/lib/composables/refs.mjs.map +1 -1
  735. package/lib/composables/resizeObserver.mjs +27 -21
  736. package/lib/composables/resizeObserver.mjs.map +1 -1
  737. package/lib/composables/rounded.mjs +9 -10
  738. package/lib/composables/rounded.mjs.map +1 -1
  739. package/lib/composables/router.mjs +7 -5
  740. package/lib/composables/router.mjs.map +1 -1
  741. package/lib/composables/scroll.mjs +2 -1
  742. package/lib/composables/scroll.mjs.map +1 -1
  743. package/lib/composables/size.mjs +3 -2
  744. package/lib/composables/size.mjs.map +1 -1
  745. package/lib/composables/stack.mjs +33 -0
  746. package/lib/composables/stack.mjs.map +1 -0
  747. package/lib/composables/theme.mjs +100 -64
  748. package/lib/composables/theme.mjs.map +1 -1
  749. package/lib/composables/touch.mjs +129 -0
  750. package/lib/composables/touch.mjs.map +1 -0
  751. package/lib/composables/transition.mjs +4 -3
  752. package/lib/composables/transition.mjs.map +1 -1
  753. package/lib/composables/validation.mjs +116 -0
  754. package/lib/composables/validation.mjs.map +1 -0
  755. package/lib/composables/variant.mjs +5 -4
  756. package/lib/composables/variant.mjs.map +1 -1
  757. package/lib/directives/click-outside/index.mjs +23 -11
  758. package/lib/directives/click-outside/index.mjs.map +1 -1
  759. package/lib/directives/index.d.ts +3 -3
  760. package/lib/directives/intersect/index.mjs +19 -12
  761. package/lib/directives/intersect/index.mjs.map +1 -1
  762. package/lib/directives/mutate/index.mjs +13 -7
  763. package/lib/directives/mutate/index.mjs.map +1 -1
  764. package/lib/directives/resize/index.mjs +8 -5
  765. package/lib/directives/resize/index.mjs.map +1 -1
  766. package/lib/directives/ripple/index.mjs +5 -2
  767. package/lib/directives/ripple/index.mjs.map +1 -1
  768. package/lib/directives/scroll/index.mjs +9 -6
  769. package/lib/directives/scroll/index.mjs.map +1 -1
  770. package/lib/directives/touch/index.mjs +8 -4
  771. package/lib/directives/touch/index.mjs.map +1 -1
  772. package/lib/entry-bundler.mjs +3 -2
  773. package/lib/entry-bundler.mjs.map +1 -1
  774. package/lib/framework.mjs +5 -2
  775. package/lib/framework.mjs.map +1 -1
  776. package/lib/index.d.ts +282 -6
  777. package/lib/locale/adapters/vue-i18n.mjs +64 -0
  778. package/lib/locale/adapters/vue-i18n.mjs.map +1 -0
  779. package/lib/locale/adapters/vue-intl.mjs +67 -0
  780. package/lib/locale/adapters/vue-intl.mjs.map +1 -0
  781. package/lib/locale/cs.mjs +3 -3
  782. package/lib/locale/cs.mjs.map +1 -1
  783. package/lib/locale/es.mjs +2 -2
  784. package/lib/locale/es.mjs.map +1 -1
  785. package/lib/locale/fr.mjs +1 -1
  786. package/lib/locale/fr.mjs.map +1 -1
  787. package/lib/services/goto/easing-patterns.mjs +0 -3
  788. package/lib/services/goto/easing-patterns.mjs.map +1 -1
  789. package/lib/services/goto/index.mjs +16 -18
  790. package/lib/services/goto/index.mjs.map +1 -1
  791. package/lib/styles/generic/_colors.scss +19 -0
  792. package/lib/styles/main.css +297 -10
  793. package/lib/styles/settings/_colors.scss +430 -6
  794. package/lib/styles/settings/_utilities.scss +8 -0
  795. package/lib/styles/settings/_variables.scss +15 -13
  796. package/lib/styles/tools/_absolute.sass +3 -2
  797. package/lib/styles/tools/_variant.sass +9 -9
  798. package/lib/util/animation.mjs +7 -9
  799. package/lib/util/animation.mjs.map +1 -1
  800. package/lib/util/box.mjs +32 -0
  801. package/lib/util/box.mjs.map +1 -0
  802. package/lib/util/colorUtils.mjs +3 -0
  803. package/lib/util/colorUtils.mjs.map +1 -1
  804. package/lib/util/console.mjs +2 -1
  805. package/lib/util/console.mjs.map +1 -1
  806. package/lib/util/createSimpleFunctional.mjs +7 -4
  807. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  808. package/lib/util/dateTimeUtils.mjs +3 -1
  809. package/lib/util/dateTimeUtils.mjs.map +1 -1
  810. package/lib/util/defineComponent.mjs +5 -1
  811. package/lib/util/defineComponent.mjs.map +1 -1
  812. package/lib/util/getCurrentInstance.mjs +19 -0
  813. package/lib/util/getCurrentInstance.mjs.map +1 -0
  814. package/lib/util/getScrollParent.mjs +1 -2
  815. package/lib/util/getScrollParent.mjs.map +1 -1
  816. package/lib/util/globals.mjs +1 -0
  817. package/lib/util/globals.mjs.map +1 -1
  818. package/lib/util/helpers.mjs +124 -17
  819. package/lib/util/helpers.mjs.map +1 -1
  820. package/lib/util/index.mjs +1 -0
  821. package/lib/util/propsFactory.mjs.map +1 -1
  822. package/lib/util/useRender.mjs +4 -2
  823. package/lib/util/useRender.mjs.map +1 -1
  824. package/package.json +57 -53
  825. package/lib/components/VAppBar/VAppBarTitle.css +0 -10
  826. package/lib/components/VAppBar/VAppBarTitle.sass +0 -10
  827. package/lib/components/VBanner/VBannerAvatar.mjs +0 -28
  828. package/lib/components/VBanner/VBannerAvatar.mjs.map +0 -1
  829. package/lib/components/VBanner/VBannerContent.mjs +0 -3
  830. package/lib/components/VBanner/VBannerContent.mjs.map +0 -1
  831. package/lib/components/VCheckbox/VSimpleCheckbox.mjs +0 -92
  832. package/lib/components/VCheckbox/VSimpleCheckbox.mjs.map +0 -1
  833. package/lib/components/VCheckbox/VSimpleCheckbox.sass +0 -16
  834. package/lib/components/VDataTable/VSimpleTable.mjs +0 -48
  835. package/lib/components/VDataTable/VSimpleTable.mjs.map +0 -1
  836. package/lib/components/VDataTable/VSimpleTable.sass +0 -179
  837. package/lib/components/VPagination/VPaginationBtn.mjs +0 -8
  838. package/lib/components/VPagination/VPaginationBtn.mjs.map +0 -1
  839. package/lib/components/VParallax/_variables.scss +0 -4
  840. package/lib/components/VRadioGroup/VRadio.mjs +0 -179
  841. package/lib/components/VRadioGroup/VRadio.mjs.map +0 -1
  842. package/lib/components/VRadioGroup/VRadio.sass +0 -25
  843. package/lib/components/VRangeSlider/VRangeSlider.sass +0 -19
  844. package/lib/components/VSelect/VSelectList.mjs +0 -251
  845. package/lib/components/VSelect/VSelectList.mjs.map +0 -1
  846. package/lib/components/VSlideGroup/VSlideItem.mjs +0 -14
  847. package/lib/components/VSlideGroup/VSlideItem.mjs.map +0 -1
  848. package/lib/components/VTabs/VTabItem.mjs +0 -23
  849. package/lib/components/VTabs/VTabItem.mjs.map +0 -1
  850. package/lib/components/VTabs/VTabsBar.mjs +0 -86
  851. package/lib/components/VTabs/VTabsBar.mjs.map +0 -1
  852. package/lib/components/VTabs/VTabsItems.mjs +0 -37
  853. package/lib/components/VTabs/VTabsItems.mjs.map +0 -1
  854. package/lib/components/VTabs/VTabsSlider.mjs +0 -20
  855. package/lib/components/VTabs/VTabsSlider.mjs.map +0 -1
  856. package/lib/components/VToolbar/_index.scss +0 -2
  857. package/lib/composables/index.d.ts +0 -173
  858. package/lib/globals.d.mjs +0 -2
  859. package/lib/globals.d.mjs.map +0 -1
  860. package/lib/mixins/activatable/index.mjs +0 -199
  861. package/lib/mixins/activatable/index.mjs.map +0 -1
  862. package/lib/mixins/applicationable/index.mjs +0 -72
  863. package/lib/mixins/applicationable/index.mjs.map +0 -1
  864. package/lib/mixins/binds-attrs/index.mjs +0 -42
  865. package/lib/mixins/binds-attrs/index.mjs.map +0 -1
  866. package/lib/mixins/button-group/index.mjs +0 -28
  867. package/lib/mixins/button-group/index.mjs.map +0 -1
  868. package/lib/mixins/colorable/index.mjs +0 -78
  869. package/lib/mixins/colorable/index.mjs.map +0 -1
  870. package/lib/mixins/comparable/index.mjs +0 -15
  871. package/lib/mixins/comparable/index.mjs.map +0 -1
  872. package/lib/mixins/dependent/index.mjs +0 -73
  873. package/lib/mixins/dependent/index.mjs.map +0 -1
  874. package/lib/mixins/elevatable/index.mjs +0 -26
  875. package/lib/mixins/elevatable/index.mjs.map +0 -1
  876. package/lib/mixins/filterable/index.mjs +0 -16
  877. package/lib/mixins/filterable/index.mjs.map +0 -1
  878. package/lib/mixins/loadable/index.mjs +0 -45
  879. package/lib/mixins/loadable/index.mjs.map +0 -1
  880. package/lib/mixins/localable/index.mjs +0 -17
  881. package/lib/mixins/localable/index.mjs.map +0 -1
  882. package/lib/mixins/mobile/index.mjs +0 -50
  883. package/lib/mixins/mobile/index.mjs.map +0 -1
  884. package/lib/mixins/overlayable/index.mjs +0 -212
  885. package/lib/mixins/overlayable/index.mjs.map +0 -1
  886. package/lib/mixins/picker/index.mjs +0 -75
  887. package/lib/mixins/picker/index.mjs.map +0 -1
  888. package/lib/mixins/picker-button/index.mjs +0 -35
  889. package/lib/mixins/picker-button/index.mjs.map +0 -1
  890. package/lib/mixins/proxyable/index.mjs +0 -50
  891. package/lib/mixins/proxyable/index.mjs.map +0 -1
  892. package/lib/mixins/returnable/index.mjs +0 -36
  893. package/lib/mixins/returnable/index.mjs.map +0 -1
  894. package/lib/mixins/rippleable/index.mjs +0 -35
  895. package/lib/mixins/rippleable/index.mjs.map +0 -1
  896. package/lib/mixins/roundable/index.mjs +0 -37
  897. package/lib/mixins/roundable/index.mjs.map +0 -1
  898. package/lib/mixins/routable/index.mjs +0 -148
  899. package/lib/mixins/routable/index.mjs.map +0 -1
  900. package/lib/mixins/selectable/index.mjs +0 -167
  901. package/lib/mixins/selectable/index.mjs.map +0 -1
  902. package/lib/mixins/stackable/index.mjs +0 -55
  903. package/lib/mixins/stackable/index.mjs.map +0 -1
  904. package/lib/mixins/themeable/index.mjs +0 -111
  905. package/lib/mixins/themeable/index.mjs.map +0 -1
  906. package/lib/mixins/toggleable/index.mjs +0 -40
  907. package/lib/mixins/toggleable/index.mjs.map +0 -1
  908. package/lib/mixins/translatable/index.mjs +0 -59
  909. package/lib/mixins/translatable/index.mjs.map +0 -1
  910. package/lib/mixins/validatable/index.mjs +0 -263
  911. package/lib/mixins/validatable/index.mjs.map +0 -1
  912. package/lib/services/application/index.mjs +0 -58
  913. package/lib/services/application/index.mjs.map +0 -1
  914. package/lib/services/breakpoint/index.mjs +0 -175
  915. package/lib/services/breakpoint/index.mjs.map +0 -1
  916. package/lib/services/index.mjs +0 -10
  917. package/lib/services/index.mjs.map +0 -1
  918. package/lib/services/lang/index.mjs +0 -73
  919. package/lib/services/lang/index.mjs.map +0 -1
  920. package/lib/services/service/index.mjs +0 -13
  921. package/lib/services/service/index.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VIcon/VIcon.tsx"],"names":["makeSizeProps","useSize","makeTagProps","useIcon","useTextColor","computed","toRef","convertToUnit","defineComponent","flattenFragments","name","props","color","String","left","Boolean","right","icon","type","Object","tag","setup","slots","slotIcon","default","slot","filter","node","children","iconData","sizeClasses","textColorClasses","textColorStyles","value","fontSize","size","width","height","undefined"],"mappings":";AAAA;AACA,qB,CAEA;;SACSA,a,EAAeC,O;SACfC,Y;SACAC,O;SACAC,Y,uCAET;;AACA,SAASC,QAAT,EAAmBC,KAAnB,QAAgC,KAAhC;SACSC,a,EAAeC,e,EAAiBC,gB,gCAEzC;;AAIA,eAAeD,eAAe,CAAC;AAC7BE,EAAAA,IAAI,EAAE,OADuB;AAG7BC,EAAAA,KAAK,EAAE;AACLC,IAAAA,KAAK,EAAEC,MADF;AAELC,IAAAA,IAAI,EAAEC,OAFD;AAGLC,IAAAA,KAAK,EAAED,OAHF;AAILE,IAAAA,IAAI,EAAE;AACJC,MAAAA,IAAI,EAAE,CAACL,MAAD,EAASM,MAAT;AADF,KAJD;AAOL,OAAGnB,aAAa,EAPX;AAQL,OAAGE,YAAY,CAAC;AAAEkB,MAAAA,GAAG,EAAE;AAAP,KAAD;AARV,GAHsB;;AAc7BC,EAAAA,KAAK,CAAEV,KAAF,EAAS;AAAEW,IAAAA;AAAF,GAAT,EAAoB;AACvB,QAAIC,QAAJ;;AACA,QAAID,KAAK,CAACE,OAAV,EAAmB;AACjBD,MAAAA,QAAQ,GAAGlB,QAAQ,CAAC,MAAM;AAAA;;AACxB,cAAMoB,IAAI,qBAAGH,KAAK,CAACE,OAAT,qBAAG,oBAAAF,KAAK,CAAlB;AACA,YAAI,CAACG,IAAL,EAAW;AAEX,wCAAOhB,gBAAgB,CAACgB,IAAD,CAAhB,CAAuBC,MAAvB,CAA8BC,IAAI,IACvCA,IAAI,CAACC,QAAL,IAAiB,OAAOD,IAAI,CAACC,QAAZ,KAAyB,QADrC,EAEL,CAFK,CAAP,qBAAO,sBAEDA,QAFN;AAGD,OAPkB,CAAnB;AAQD;;AAED,UAAM;AAAEC,MAAAA;AAAF,QAAe1B,OAAO,CAACoB,QAAQ,IAAIZ,KAAb,CAA5B;AACA,UAAM;AAAEmB,MAAAA;AAAF,QAAkB7B,OAAO,CAACU,KAAD,EAAQ,QAAR,CAA/B;AACA,UAAM;AAAEoB,MAAAA,gBAAF;AAAoBC,MAAAA;AAApB,QAAwC5B,YAAY,CAACE,KAAK,CAACK,KAAD,EAAQ,OAAR,CAAN,CAA1D;AAEA,WAAO,MAAM;AACX;AAAA,eAEUA,KAAK,CAACS,GAFhB;AAAA,gBAGWS,QAAQ,CAACI,KAAT,CAAehB,IAH1B;AAAA,iBAIW,CACL,QADK,EAEL,aAFK,EAGLa,WAAW,CAACG,KAHP,EAILF,gBAAgB,CAACE,KAJZ,EAKL;AACE,0BAAgBtB,KAAK,CAACG,IADxB;AAEE,2BAAiBH,KAAK,CAACK;AAFzB,SALK,CAJX;AAAA,iBAcW,CACL,CAACc,WAAW,CAACG,KAAb,GAAsB;AACpBC,UAAAA,QAAQ,EAAE3B,aAAa,CAACI,KAAK,CAACwB,IAAP,CADH;AAEpBC,UAAAA,KAAK,EAAE7B,aAAa,CAACI,KAAK,CAACwB,IAAP,CAFA;AAGpBE,UAAAA,MAAM,EAAE9B,aAAa,CAACI,KAAK,CAACwB,IAAP;AAHD,SAAtB,GAIKG,SALA,EAMLN,eAAe,CAACC,KANX,CAdX;AAAA,uBAsBgB;AAtBhB;AAyBD,KA1BD;AA2BD;;AA1D4B,CAAD,CAA9B","sourcesContent":["// Styles\nimport './VIcon.sass'\n\n// Composables\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { useIcon } from '@/composables/icons'\nimport { useTextColor } from '@/composables/color'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { convertToUnit, defineComponent, flattenFragments } from '@/util'\n\n// Types\nimport type { IconValue } from '@/composables/icons'\nimport type { ComputedRef, PropType } from 'vue'\n\nexport default defineComponent({\n name: 'VIcon',\n\n props: {\n color: String,\n left: Boolean,\n right: Boolean,\n icon: {\n type: [String, Object] as PropType<IconValue>,\n },\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'i' }),\n },\n\n setup (props, { slots }) {\n let slotIcon: ComputedRef<string | undefined> | undefined\n if (slots.default) {\n slotIcon = computed(() => {\n const slot = slots.default?.()\n if (!slot) return\n\n return flattenFragments(slot).filter(node =>\n node.children && typeof node.children === 'string'\n )[0]?.children as string\n })\n }\n\n const { iconData } = useIcon(slotIcon || props)\n const { sizeClasses } = useSize(props, 'v-icon')\n const { textColorClasses, textColorStyles } = useTextColor(toRef(props, 'color'))\n\n return () => {\n return (\n <iconData.value.component\n tag={ props.tag }\n icon={ iconData.value.icon }\n class={[\n 'v-icon',\n 'notranslate',\n sizeClasses.value,\n textColorClasses.value,\n {\n 'v-icon--left': props.left,\n 'v-icon--right': props.right,\n },\n ]}\n style={[\n !sizeClasses.value ? ({\n fontSize: convertToUnit(props.size),\n width: convertToUnit(props.size),\n height: convertToUnit(props.size),\n }) : undefined,\n textColorStyles.value,\n ]}\n aria-hidden=\"true\"\n />\n )\n }\n },\n})\n"],"file":"VIcon.mjs"}
1
+ {"version":3,"sources":["../../../src/components/VIcon/VIcon.tsx"],"names":["makeSizeProps","useSize","makeTagProps","useIcon","useTextColor","makeThemeProps","provideTheme","computed","toRef","convertToUnit","defineComponent","flattenFragments","VIcon","name","props","color","String","left","Boolean","right","icon","type","Object","tag","setup","slots","slotIcon","default","slot","filter","node","children","themeClasses","iconData","sizeClasses","textColorClasses","textColorStyles","value","fontSize","size","width","height","undefined"],"mappings":";AAAA;AACA,qB,CAEA;;SACSA,a,EAAeC,O;SACfC,Y;SACAC,O;SACAC,Y;SACAC,c,EAAgBC,Y,uCAEzB;;AACA,SAASC,QAAT,EAAmBC,KAAnB,QAAgC,KAAhC;SACSC,a,EAAeC,e,EAAiBC,gB,gCAEzC;;AAIA,OAAO,MAAMC,KAAK,GAAGF,eAAe,CAAC;AACnCG,EAAAA,IAAI,EAAE,OAD6B;AAGnCC,EAAAA,KAAK,EAAE;AACLC,IAAAA,KAAK,EAAEC,MADF;AAELC,IAAAA,IAAI,EAAEC,OAFD;AAGLC,IAAAA,KAAK,EAAED,OAHF;AAILE,IAAAA,IAAI,EAAE;AACJC,MAAAA,IAAI,EAAE,CAACL,MAAD,EAASM,MAAT;AADF,KAJD;AAOL,OAAGtB,aAAa,EAPX;AAQL,OAAGE,YAAY,CAAC;AAAEqB,MAAAA,GAAG,EAAE;AAAP,KAAD,CARV;AASL,OAAGlB,cAAc;AATZ,GAH4B;;AAenCmB,EAAAA,KAAK,CAAEV,KAAF,QAAoB;AAAA,QAAX;AAAEW,MAAAA;AAAF,KAAW;AACvB,QAAIC,QAAJ;;AACA,QAAID,KAAK,CAACE,OAAV,EAAmB;AACjBD,MAAAA,QAAQ,GAAGnB,QAAQ,CAAC,MAAM;AAAA;;AACxB,cAAMqB,IAAI,qBAAGH,KAAK,CAACE,OAAT,qBAAG,oBAAAF,KAAK,CAAlB;AACA,YAAI,CAACG,IAAL,EAAW;AAEX,wCAAOjB,gBAAgB,CAACiB,IAAD,CAAhB,CAAuBC,MAAvB,CAA8BC,IAAI,IACvCA,IAAI,CAACC,QAAL,IAAiB,OAAOD,IAAI,CAACC,QAAZ,KAAyB,QADrC,EAEL,CAFK,CAAP,qBAAO,sBAEDA,QAFN;AAGD,OAPkB,CAAnB;AAQD;;AAED,UAAM;AAAEC,MAAAA;AAAF,QAAmB1B,YAAY,CAACQ,KAAD,CAArC;AACA,UAAM;AAAEmB,MAAAA;AAAF,QAAe9B,OAAO,CAACuB,QAAQ,IAAIZ,KAAb,CAA5B;AACA,UAAM;AAAEoB,MAAAA;AAAF,QAAkBjC,OAAO,CAACa,KAAD,CAA/B;AACA,UAAM;AAAEqB,MAAAA,gBAAF;AAAoBC,MAAAA;AAApB,QAAwChC,YAAY,CAACI,KAAK,CAACM,KAAD,EAAQ,OAAR,CAAN,CAA1D;AAEA,WAAO,MAAM;AACX;AAAA,eAEUA,KAAK,CAACS,GAFhB;AAAA,gBAGWU,QAAQ,CAACI,KAAT,CAAejB,IAH1B;AAAA,iBAIW,CACL,QADK,EAEL,aAFK,EAGLc,WAAW,CAACG,KAHP,EAILF,gBAAgB,CAACE,KAJZ,EAKLL,YAAY,CAACK,KALR,EAML;AACE,0BAAgBvB,KAAK,CAACG,IADxB;AAEE,2BAAiBH,KAAK,CAACK;AAFzB,SANK,CAJX;AAAA,iBAeW,CACL,CAACe,WAAW,CAACG,KAAb,GAAsB;AACpBC,UAAAA,QAAQ,EAAE7B,aAAa,CAACK,KAAK,CAACyB,IAAP,CADH;AAEpBC,UAAAA,KAAK,EAAE/B,aAAa,CAACK,KAAK,CAACyB,IAAP,CAFA;AAGpBE,UAAAA,MAAM,EAAEhC,aAAa,CAACK,KAAK,CAACyB,IAAP;AAHD,SAAtB,GAIKG,SALA,EAMLN,eAAe,CAACC,KANX,CAfX;AAAA,uBAuBgB;AAvBhB;AA0BD,KA3BD;AA4BD;;AA7DkC,CAAD,CAA7B","sourcesContent":["// Styles\nimport './VIcon.sass'\n\n// Composables\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { useIcon } from '@/composables/icons'\nimport { useTextColor } from '@/composables/color'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { convertToUnit, defineComponent, flattenFragments } from '@/util'\n\n// Types\nimport type { IconValue } from '@/composables/icons'\nimport type { ComputedRef, PropType } from 'vue'\n\nexport const VIcon = defineComponent({\n name: 'VIcon',\n\n props: {\n color: String,\n left: Boolean,\n right: Boolean,\n icon: {\n type: [String, Object] as PropType<IconValue>,\n },\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'i' }),\n ...makeThemeProps(),\n },\n\n setup (props, { slots }) {\n let slotIcon: ComputedRef<string | undefined> | undefined\n if (slots.default) {\n slotIcon = computed(() => {\n const slot = slots.default?.()\n if (!slot) return\n\n return flattenFragments(slot).filter(node =>\n node.children && typeof node.children === 'string'\n )[0]?.children as string\n })\n }\n\n const { themeClasses } = provideTheme(props)\n const { iconData } = useIcon(slotIcon || props)\n const { sizeClasses } = useSize(props)\n const { textColorClasses, textColorStyles } = useTextColor(toRef(props, 'color'))\n\n return () => {\n return (\n <iconData.value.component\n tag={ props.tag }\n icon={ iconData.value.icon }\n class={[\n 'v-icon',\n 'notranslate',\n sizeClasses.value,\n textColorClasses.value,\n themeClasses.value,\n {\n 'v-icon--left': props.left,\n 'v-icon--right': props.right,\n },\n ]}\n style={[\n !sizeClasses.value ? ({\n fontSize: convertToUnit(props.size),\n width: convertToUnit(props.size),\n height: convertToUnit(props.size),\n }) : undefined,\n textColorStyles.value,\n ]}\n aria-hidden=\"true\"\n />\n )\n }\n },\n})\n"],"file":"VIcon.mjs"}
@@ -29,16 +29,10 @@
29
29
 
30
30
  .v-icon__svg
31
31
  fill: currentColor
32
+ width: 100%
33
+ height: 100%
32
34
 
33
35
  .v-icon
34
- &--size-default
35
- .v-btn:not(.v-btn--icon):not(.v-btn--stacked) &
36
- .v-bottom-navigation &
37
- font-size: $icon-btn-bottom-navigation-font-size
38
-
39
- .v-bottom-navigation:not(.v-bottom-navigation--horizontal) &
40
- margin: 0
41
-
42
36
  &--left
43
37
  .v-btn:not(.v-btn--icon) &
44
38
  margin-inline-start: $icon-btn-margin-start
@@ -3,7 +3,6 @@
3
3
  @use '../../styles/tools';
4
4
 
5
5
  // Defaults
6
- $icon-btn-bottom-navigation-font-size: 24px !default;
7
6
  $icon-btn-margin-start-multiplier: -9 !default;
8
7
  $icon-btn-margin-end-multiplier: 4.5 !default;
9
8
  $icon-btn-margin-start: calc(var(--v-btn-height) / #{$icon-btn-margin-start-multiplier}) !default;
@@ -1,3 +1,3 @@
1
- export { default as VIcon } from "./VIcon.mjs";
1
+ export { VIcon } from "./VIcon.mjs";
2
2
  export { VComponentIcon, VSvgIcon, VLigatureIcon, VClassIcon } from "../../composables/icons.mjs";
3
3
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VIcon/index.ts"],"names":["default","VIcon","VComponentIcon","VSvgIcon","VLigatureIcon","VClassIcon"],"mappings":"SAASA,OAAO,IAAIC,K;SAElBC,c,EACAC,Q,EACAC,a,EACAC,U","sourcesContent":["export { default as VIcon } from './VIcon'\nexport {\n VComponentIcon,\n VSvgIcon,\n VLigatureIcon,\n VClassIcon,\n} from '@/composables/icons'\n"],"file":"index.mjs"}
1
+ {"version":3,"sources":["../../../src/components/VIcon/index.ts"],"names":["VIcon","VComponentIcon","VSvgIcon","VLigatureIcon","VClassIcon"],"mappings":"SAASA,K;SAEPC,c,EACAC,Q,EACAC,a,EACAC,U","sourcesContent":["export { VIcon } from './VIcon'\nexport {\n VComponentIcon,\n VSvgIcon,\n VLigatureIcon,\n VClassIcon,\n} from '@/composables/icons'\n"],"file":"index.mjs"}
@@ -2,9 +2,13 @@
2
2
  --v-theme-overlay-multiplier: 3;
3
3
  z-index: 0;
4
4
  }
5
+ .v-img--booting .v-responsive__sizer {
6
+ transition: none;
7
+ }
5
8
 
6
9
  .v-img__img,
7
10
  .v-img__picture,
11
+ .v-img__gradient,
8
12
  .v-img__placeholder,
9
13
  .v-img__error {
10
14
  z-index: -1;
@@ -23,4 +27,8 @@
23
27
  }
24
28
  .v-img__img--cover {
25
29
  object-fit: cover;
30
+ }
31
+
32
+ .v-img__gradient {
33
+ background-repeat: no-repeat;
26
34
  }
@@ -8,9 +8,9 @@ import intersect from "../../directives/intersect/index.mjs"; // Composables
8
8
  import { makeTransitionProps, MaybeTransition } from "../../composables/transition.mjs"; // Utilities
9
9
 
10
10
  import { computed, h, nextTick, onBeforeMount, ref, vShow, watch, withDirectives } from 'vue';
11
- import { defineComponent, SUPPORTS_INTERSECTION, useRender } from "../../util/index.mjs"; // Types
11
+ import { convertToUnit, defineComponent, SUPPORTS_INTERSECTION, useRender } from "../../util/index.mjs"; // Types
12
12
 
13
- export default defineComponent({
13
+ export const VImg = defineComponent({
14
14
  name: 'VImg',
15
15
  directives: {
16
16
  intersect
@@ -20,6 +20,7 @@ export default defineComponent({
20
20
  alt: String,
21
21
  cover: Boolean,
22
22
  eager: Boolean,
23
+ gradient: String,
23
24
  lazySrc: String,
24
25
  options: {
25
26
  type: Object,
@@ -31,24 +32,22 @@ export default defineComponent({
31
32
  threshold: undefined
32
33
  })
33
34
  },
34
- position: {
35
- type: String,
36
- default: 'center center'
37
- },
38
35
  sizes: String,
39
36
  src: {
40
37
  type: [String, Object],
41
38
  default: ''
42
39
  },
43
40
  srcset: String,
41
+ width: [String, Number],
44
42
  ...makeTransitionProps()
45
43
  },
46
44
  emits: ['loadstart', 'load', 'error'],
47
45
 
48
- setup(props, {
49
- emit,
50
- slots
51
- }) {
46
+ setup(props, _ref) {
47
+ let {
48
+ emit,
49
+ slots
50
+ } = _ref;
52
51
  const currentSrc = ref(''); // Set from srcset
53
52
 
54
53
  const image = ref();
@@ -81,6 +80,14 @@ export default defineComponent({
81
80
  if (props.eager && isIntersecting) return;
82
81
  if (SUPPORTS_INTERSECTION && !isIntersecting && !props.eager) return;
83
82
  state.value = 'loading';
83
+
84
+ if (normalisedSrc.value.lazySrc) {
85
+ const lazyImg = new Image();
86
+ lazyImg.src = normalisedSrc.value.lazySrc;
87
+ pollForSize(lazyImg, null);
88
+ }
89
+
90
+ if (!normalisedSrc.value.src) return;
84
91
  nextTick(() => {
85
92
  var _image$value, _image$value2;
86
93
 
@@ -99,12 +106,6 @@ export default defineComponent({
99
106
  getSrc();
100
107
  }
101
108
  });
102
-
103
- if (normalisedSrc.value.lazySrc) {
104
- const lazyImg = new Image();
105
- lazyImg.src = normalisedSrc.value.lazySrc;
106
- pollForSize(lazyImg, null);
107
- }
108
109
  }
109
110
 
110
111
  function onLoad() {
@@ -127,7 +128,9 @@ export default defineComponent({
127
128
  if (img) currentSrc.value = img.currentSrc || img.src;
128
129
  }
129
130
 
130
- function pollForSize(img, timeout = 100) {
131
+ function pollForSize(img) {
132
+ let timeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100;
133
+
131
134
  const poll = () => {
132
135
  const {
133
136
  naturalHeight: imgHeight,
@@ -173,9 +176,8 @@ export default defineComponent({
173
176
  }, {
174
177
  default: () => [withDirectives(sources ? _createVNode("picture", {
175
178
  "class": "v-img__picture"
176
- }, [sources, img]) : img, [[vShow, state.value === 'loaded']])],
177
- _: 2
178
- }, 8, ["transition", "appear"]);
179
+ }, [sources, img]) : img, [[vShow, state.value === 'loaded']])]
180
+ });
179
181
  });
180
182
 
181
183
  const __preloadImage = computed(() => _createVNode(MaybeTransition, {
@@ -185,8 +187,8 @@ export default defineComponent({
185
187
  "class": ['v-img__img', 'v-img__img--preload', containClasses.value],
186
188
  "src": normalisedSrc.value.lazySrc,
187
189
  "alt": ""
188
- }, null, 10, ["src"])]
189
- }, 8, ["transition"]));
190
+ }, null)]
191
+ }));
190
192
 
191
193
  const __placeholder = computed(() => {
192
194
  if (!slots.placeholder) return;
@@ -197,7 +199,7 @@ export default defineComponent({
197
199
  default: () => [(state.value === 'loading' || state.value === 'error' && !slots.error) && _createVNode("div", {
198
200
  "class": "v-img__placeholder"
199
201
  }, [slots.placeholder()])]
200
- }, 8, ["transition", "appear"]);
202
+ });
201
203
  });
202
204
 
203
205
  const __error = computed(() => {
@@ -209,18 +211,47 @@ export default defineComponent({
209
211
  default: () => [state.value === 'error' && _createVNode("div", {
210
212
  "class": "v-img__error"
211
213
  }, [slots.error()])]
212
- }, 8, ["transition", "appear"]);
214
+ });
213
215
  });
214
216
 
217
+ const __gradient = computed(() => {
218
+ if (!props.gradient) return;
219
+ return _createVNode("div", {
220
+ "class": "v-img__gradient",
221
+ "style": {
222
+ backgroundImage: `linear-gradient(${props.gradient})`
223
+ }
224
+ }, null);
225
+ });
226
+
227
+ const isBooted = ref(false);
228
+ {
229
+ const stop = watch(aspectRatio, val => {
230
+ if (val) {
231
+ // Doesn't work with nextTick, idk why
232
+ requestAnimationFrame(() => {
233
+ requestAnimationFrame(() => {
234
+ isBooted.value = true;
235
+ });
236
+ });
237
+ stop();
238
+ }
239
+ });
240
+ }
215
241
  useRender(() => _withDirectives(_createVNode(VResponsive, {
216
- "class": "v-img",
242
+ "class": ['v-img', {
243
+ 'v-img--booting': !isBooted.value
244
+ }],
245
+ "style": {
246
+ width: convertToUnit(props.width === 'auto' ? naturalWidth.value : props.width)
247
+ },
217
248
  "aspectRatio": aspectRatio.value,
218
249
  "aria-label": props.alt,
219
250
  "role": props.alt ? 'img' : undefined
220
251
  }, {
221
- additional: () => [__image.value, __preloadImage.value, __placeholder.value, __error.value],
252
+ additional: () => [__image.value, __preloadImage.value, __gradient.value, __placeholder.value, __error.value],
222
253
  default: slots.default
223
- }, 8, ["aspectRatio", "aria-label", "role"]), [[_resolveDirective("intersect"), {
254
+ }), [[_resolveDirective("intersect"), {
224
255
  handler: init,
225
256
  options: props.options
226
257
  }, null, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VImg/VImg.tsx"],"names":["VResponsive","intersect","makeTransitionProps","MaybeTransition","computed","h","nextTick","onBeforeMount","ref","vShow","watch","withDirectives","defineComponent","SUPPORTS_INTERSECTION","useRender","name","directives","props","aspectRatio","String","Number","alt","cover","Boolean","eager","lazySrc","options","type","Object","default","root","undefined","rootMargin","threshold","position","sizes","src","srcset","emits","setup","emit","slots","currentSrc","image","state","naturalWidth","naturalHeight","normalisedSrc","aspect","value","init","isIntersecting","complete","onError","pollForSize","onLoad","getSrc","lazyImg","Image","img","timeout","poll","imgHeight","imgWidth","setTimeout","endsWith","startsWith","containClasses","__image","class","sources","transition","__preloadImage","__placeholder","placeholder","error","__error","additional","handler"],"mappings":";AAAA,oB,CAEA;;SACSA,W,oCAET;;OACOC,S,8CAEP;;SACSC,mB,EAAqBC,e,4CAE9B;;AACA,SACEC,QADF,EAEEC,CAFF,EAGEC,QAHF,EAIEC,aAJF,EAKEC,GALF,EAMEC,KANF,EAOEC,KAPF,EAQEC,cARF,QASO,KATP;SAWEC,e,EACAC,qB,EACAC,S,gCAGF;;AAWA,eAAeF,eAAe,CAAC;AAC7BG,EAAAA,IAAI,EAAE,MADuB;AAG7BC,EAAAA,UAAU,EAAE;AAAEf,IAAAA;AAAF,GAHiB;AAK7BgB,EAAAA,KAAK,EAAE;AACLC,IAAAA,WAAW,EAAE,CAACC,MAAD,EAASC,MAAT,CADR;AAELC,IAAAA,GAAG,EAAEF,MAFA;AAGLG,IAAAA,KAAK,EAAEC,OAHF;AAILC,IAAAA,KAAK,EAAED,OAJF;AAKLE,IAAAA,OAAO,EAAEN,MALJ;AAMLO,IAAAA,OAAO,EAAE;AACPC,MAAAA,IAAI,EAAEC,MADC;AAEP;AACA;AACAC,MAAAA,OAAO,EAAE,OAAO;AACdC,QAAAA,IAAI,EAAEC,SADQ;AAEdC,QAAAA,UAAU,EAAED,SAFE;AAGdE,QAAAA,SAAS,EAAEF;AAHG,OAAP;AAJF,KANJ;AAgBLG,IAAAA,QAAQ,EAAE;AACRP,MAAAA,IAAI,EAAER,MADE;AAERU,MAAAA,OAAO,EAAE;AAFD,KAhBL;AAoBLM,IAAAA,KAAK,EAAEhB,MApBF;AAqBLiB,IAAAA,GAAG,EAAE;AACHT,MAAAA,IAAI,EAAE,CAACR,MAAD,EAASS,MAAT,CADH;AAEHC,MAAAA,OAAO,EAAE;AAFN,KArBA;AAyBLQ,IAAAA,MAAM,EAAElB,MAzBH;AA2BL,OAAGjB,mBAAmB;AA3BjB,GALsB;AAmC7BoC,EAAAA,KAAK,EAAE,CAAC,WAAD,EAAc,MAAd,EAAsB,OAAtB,CAnCsB;;AAqC7BC,EAAAA,KAAK,CAAEtB,KAAF,EAAS;AAAEuB,IAAAA,IAAF;AAAQC,IAAAA;AAAR,GAAT,EAA0B;AAC7B,UAAMC,UAAU,GAAGlC,GAAG,CAAC,EAAD,CAAtB,CAD6B,CACF;;AAC3B,UAAMmC,KAAK,GAAGnC,GAAG,EAAjB;AACA,UAAMoC,KAAK,GAAGpC,GAAG,CAA0CS,KAAK,CAACO,KAAN,GAAc,SAAd,GAA0B,MAApE,CAAjB;AACA,UAAMqB,YAAY,GAAGrC,GAAG,EAAxB;AACA,UAAMsC,aAAa,GAAGtC,GAAG,EAAzB;AAEA,UAAMuC,aAAa,GAAG3C,QAAQ,CAAY,MAAM;AAC9C,aAAOa,KAAK,CAACmB,GAAN,IAAa,OAAOnB,KAAK,CAACmB,GAAb,KAAqB,QAAlC,GACH;AACAA,QAAAA,GAAG,EAAEnB,KAAK,CAACmB,GAAN,CAAUA,GADf;AAEAC,QAAAA,MAAM,EAAEpB,KAAK,CAACoB,MAAN,IAAgBpB,KAAK,CAACmB,GAAN,CAAUC,MAFlC;AAGAZ,QAAAA,OAAO,EAAER,KAAK,CAACQ,OAAN,IAAiBR,KAAK,CAACmB,GAAN,CAAUX,OAHpC;AAIAuB,QAAAA,MAAM,EAAE5B,MAAM,CAACH,KAAK,CAACC,WAAN,IAAqBD,KAAK,CAACmB,GAAN,CAAUY,MAAhC;AAJd,OADG,GAMD;AACFZ,QAAAA,GAAG,EAAEnB,KAAK,CAACmB,GADT;AAEFC,QAAAA,MAAM,EAAEpB,KAAK,CAACoB,MAFZ;AAGFZ,QAAAA,OAAO,EAAER,KAAK,CAACQ,OAHb;AAIFuB,QAAAA,MAAM,EAAE5B,MAAM,CAACH,KAAK,CAACC,WAAN,IAAqB,CAAtB;AAJZ,OANN;AAYD,KAb6B,CAA9B;AAcA,UAAMA,WAAW,GAAGd,QAAQ,CAAC,MAAM;AACjC,aAAO2C,aAAa,CAACE,KAAd,CAAoBD,MAApB,IAA8BH,YAAY,CAACI,KAAb,GAAsBH,aAAa,CAACG,KAAlE,IAA4E,CAAnF;AACD,KAF2B,CAA5B;AAIAvC,IAAAA,KAAK,CAAC,MAAMO,KAAK,CAACmB,GAAb,EAAkB,MAAM;AAC3Bc,MAAAA,IAAI,CAACN,KAAK,CAACK,KAAN,KAAgB,MAAjB,CAAJ;AACD,KAFI,CAAL,CAzB6B,CA4B7B;;AAEA1C,IAAAA,aAAa,CAAC,MAAM2C,IAAI,EAAX,CAAb;;AAEA,aAASA,IAAT,CAAeC,cAAf,EAAyC;AACvC,UAAIlC,KAAK,CAACO,KAAN,IAAe2B,cAAnB,EAAmC;AACnC,UACEtC,qBAAqB,IACrB,CAACsC,cADD,IAEA,CAAClC,KAAK,CAACO,KAHT,EAIE;AAEFoB,MAAAA,KAAK,CAACK,KAAN,GAAc,SAAd;AACA3C,MAAAA,QAAQ,CAAC,MAAM;AAAA;;AACbkC,QAAAA,IAAI,CAAC,WAAD,EAAc,iBAAAG,KAAK,CAACM,KAAN,kCAAaP,UAAb,KAA2BK,aAAa,CAACE,KAAd,CAAoBb,GAA7D,CAAJ;;AAEA,6BAAIO,KAAK,CAACM,KAAV,aAAI,cAAaG,QAAjB,EAA2B;AACzB,cAAI,CAACT,KAAK,CAACM,KAAN,CAAYJ,YAAjB,EAA+B;AAC7BQ,YAAAA,OAAO;AACR;;AAED,cAAIT,KAAK,CAACK,KAAN,KAAgB,OAApB,EAA6B;AAE7B,cAAI,CAAC/B,WAAW,CAAC+B,KAAjB,EAAwBK,WAAW,CAACX,KAAK,CAACM,KAAP,EAAc,IAAd,CAAX;AACxBM,UAAAA,MAAM;AACP,SATD,MASO;AACL,cAAI,CAACrC,WAAW,CAAC+B,KAAjB,EAAwBK,WAAW,CAACX,KAAK,CAACM,KAAP,CAAX;AACxBO,UAAAA,MAAM;AACP;AACF,OAhBO,CAAR;;AAkBA,UAAIT,aAAa,CAACE,KAAd,CAAoBxB,OAAxB,EAAiC;AAC/B,cAAMgC,OAAO,GAAG,IAAIC,KAAJ,EAAhB;AACAD,QAAAA,OAAO,CAACrB,GAAR,GAAcW,aAAa,CAACE,KAAd,CAAoBxB,OAAlC;AACA6B,QAAAA,WAAW,CAACG,OAAD,EAAU,IAAV,CAAX;AACD;AACF;;AAED,aAASF,MAAT,GAAmB;AAAA;;AACjBC,MAAAA,MAAM;AACNZ,MAAAA,KAAK,CAACK,KAAN,GAAc,QAAd;AACAT,MAAAA,IAAI,CAAC,MAAD,EAAS,kBAAAG,KAAK,CAACM,KAAN,mCAAaP,UAAb,KAA2BK,aAAa,CAACE,KAAd,CAAoBb,GAAxD,CAAJ;AACD;;AAED,aAASiB,OAAT,GAAoB;AAAA;;AAClBT,MAAAA,KAAK,CAACK,KAAN,GAAc,OAAd;AACAT,MAAAA,IAAI,CAAC,OAAD,EAAU,kBAAAG,KAAK,CAACM,KAAN,mCAAaP,UAAb,KAA2BK,aAAa,CAACE,KAAd,CAAoBb,GAAzD,CAAJ;AACD;;AAED,aAASoB,MAAT,GAAmB;AACjB,YAAMG,GAAG,GAAGhB,KAAK,CAACM,KAAlB;AACA,UAAIU,GAAJ,EAASjB,UAAU,CAACO,KAAX,GAAmBU,GAAG,CAACjB,UAAJ,IAAkBiB,GAAG,CAACvB,GAAzC;AACV;;AAED,aAASkB,WAAT,CAAsBK,GAAtB,EAA6CC,OAAsB,GAAG,GAAtE,EAA2E;AACzE,YAAMC,IAAI,GAAG,MAAM;AACjB,cAAM;AAAEf,UAAAA,aAAa,EAAEgB,SAAjB;AAA4BjB,UAAAA,YAAY,EAAEkB;AAA1C,YAAuDJ,GAA7D;;AAEA,YAAIG,SAAS,IAAIC,QAAjB,EAA2B;AACzBlB,UAAAA,YAAY,CAACI,KAAb,GAAqBc,QAArB;AACAjB,UAAAA,aAAa,CAACG,KAAd,GAAsBa,SAAtB;AACD,SAHD,MAGO,IAAI,CAACH,GAAG,CAACP,QAAL,IAAiBR,KAAK,CAACK,KAAN,KAAgB,SAAjC,IAA8CW,OAAO,IAAI,IAA7D,EAAmE;AACxEI,UAAAA,UAAU,CAACH,IAAD,EAAOD,OAAP,CAAV;AACD,SAFM,MAEA,IAAID,GAAG,CAACjB,UAAJ,CAAeuB,QAAf,CAAwB,MAAxB,KAAmCN,GAAG,CAACjB,UAAJ,CAAewB,UAAf,CAA0B,oBAA1B,CAAvC,EAAwF;AAC7FrB,UAAAA,YAAY,CAACI,KAAb,GAAqB,CAArB;AACAH,UAAAA,aAAa,CAACG,KAAd,GAAsB,CAAtB;AACD;AACF,OAZD;;AAcAY,MAAAA,IAAI;AACL;;AAED,UAAMM,cAAc,GAAG/D,QAAQ,CAAC,OAAO;AACrC,2BAAqBa,KAAK,CAACK,KADU;AAErC,6BAAuB,CAACL,KAAK,CAACK;AAFO,KAAP,CAAD,CAA/B;;AAKA,UAAM8C,OAAO,GAAGhE,QAAQ,CAAC,MAAM;AAAA;;AAC7B,UAAI,CAAC2C,aAAa,CAACE,KAAd,CAAoBb,GAArB,IAA4BQ,KAAK,CAACK,KAAN,KAAgB,MAAhD,EAAwD;AAExD,YAAMU,GAAG,GAAGtD,CAAC,CAAC,KAAD,EAAQ;AACnBgE,QAAAA,KAAK,EAAE,CAAC,YAAD,EAAeF,cAAc,CAAClB,KAA9B,CADY;AAEnBb,QAAAA,GAAG,EAAEW,aAAa,CAACE,KAAd,CAAoBb,GAFN;AAGnBC,QAAAA,MAAM,EAAEU,aAAa,CAACE,KAAd,CAAoBZ,MAHT;AAInBF,QAAAA,KAAK,EAAElB,KAAK,CAACkB,KAJM;AAKnB3B,QAAAA,GAAG,EAAEmC,KALc;AAMnBY,QAAAA,MANmB;AAOnBF,QAAAA;AAPmB,OAAR,CAAb;AAUA,YAAMiB,OAAO,qBAAG7B,KAAK,CAAC6B,OAAT,qBAAG,oBAAA7B,KAAK,CAArB;AAEA;AAAA,sBACgCxB,KAAK,CAACsD,UADtC;AAAA;AAAA;AAAA,wBAGM5D,cAAc,CACZ2D,OAAO;AAAA,mBACY;AADZ,YAC+BA,OAD/B,EAC0CX,GAD1C,KAEHA,GAHQ,EAIZ,CAAC,CAAClD,KAAD,EAAQmC,KAAK,CAACK,KAAN,KAAgB,QAAxB,CAAD,CAJY,CAHpB;AAAA;AAAA;AAYD,KA3BuB,CAAxB;;AA6BA,UAAMuB,cAAc,GAAGpE,QAAQ,CAAC;AAAA,oBACAa,KAAK,CAACsD;AADN;AAAA,sBAE1BxB,aAAa,CAACE,KAAd,CAAoBxB,OAApB,IAA+BmB,KAAK,CAACK,KAAN,KAAgB,QAA/C;AAAA,iBAES,CAAC,YAAD,EAAe,qBAAf,EAAsCkB,cAAc,CAAClB,KAArD,CAFT;AAAA,eAGQF,aAAa,CAACE,KAAd,CAAoBxB,OAH5B;AAAA,eAIM;AAJN,2BAF0B;AAAA,yBAAD,CAA/B;;AAYA,UAAMgD,aAAa,GAAGrE,QAAQ,CAAC,MAAM;AACnC,UAAI,CAACqC,KAAK,CAACiC,WAAX,EAAwB;AAExB;AAAA,sBACgCzD,KAAK,CAACsD,UADtC;AAAA;AAAA;AAAA,wBAEM,CAAC3B,KAAK,CAACK,KAAN,KAAgB,SAAhB,IAA8BL,KAAK,CAACK,KAAN,KAAgB,OAAhB,IAA2B,CAACR,KAAK,CAACkC,KAAjE;AAAA,mBACS;AADT,YACgClC,KAAK,CAACiC,WAAN,EADhC,EAFN;AAAA;AAOD,KAV6B,CAA9B;;AAYA,UAAME,OAAO,GAAGxE,QAAQ,CAAC,MAAM;AAC7B,UAAI,CAACqC,KAAK,CAACkC,KAAX,EAAkB;AAElB;AAAA,sBACgC1D,KAAK,CAACsD,UADtC;AAAA;AAAA;AAAA,wBAEM3B,KAAK,CAACK,KAAN,KAAgB,OAAhB;AAAA,mBACW;AADX,YAC4BR,KAAK,CAACkC,KAAN,EAD5B,EAFN;AAAA;AAOD,KAVuB,CAAxB;;AAYA7D,IAAAA,SAAS,CAAC;AAAA,eAEA,OAFA;AAAA,qBAGQI,WAAW,CAAC+B,KAHpB;AAAA,oBAIOhC,KAAK,CAACI,GAJb;AAAA,cAKCJ,KAAK,CAACI,GAAN,GAAY,KAAZ,GAAoBU;AALrB,OAUG;AACP8C,MAAAA,UAAU,EAAE,MAAM,CAACT,OAAO,CAACnB,KAAT,EAAgBuB,cAAc,CAACvB,KAA/B,EAAsCwB,aAAa,CAACxB,KAApD,EAA2D2B,OAAO,CAAC3B,KAAnE,CADX;AAEPpB,MAAAA,OAAO,EAAEY,KAAK,CAACZ;AAFR,KAVH,+EAMQ;AACZiD,MAAAA,OAAO,EAAE5B,IADG;AAEZxB,MAAAA,OAAO,EAAET,KAAK,CAACS;AAFH,KANR,EASH,IATG;AAAA;AAAA,QAAD,CAAT;AAiBA,WAAO;AACLgB,MAAAA,UADK;AAELC,MAAAA,KAFK;AAGLC,MAAAA,KAHK;AAILC,MAAAA,YAJK;AAKLC,MAAAA;AALK,KAAP;AAOD;;AAvO4B,CAAD,CAA9B","sourcesContent":["import './VImg.sass'\n\n// Components\nimport { VResponsive } from '@/components/VResponsive'\n\n// Directives\nimport intersect from '@/directives/intersect'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport {\n computed,\n h,\n nextTick,\n onBeforeMount,\n ref,\n vShow,\n watch,\n withDirectives,\n} from 'vue'\nimport {\n defineComponent,\n SUPPORTS_INTERSECTION,\n useRender,\n} from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\n// not intended for public use, this is passed in by vuetify-loader\nexport interface srcObject {\n src?: string\n srcset?: string\n lazySrc?: string\n aspect: number\n}\n\nexport default defineComponent({\n name: 'VImg',\n\n directives: { intersect },\n\n props: {\n aspectRatio: [String, Number],\n alt: String,\n cover: Boolean,\n eager: Boolean,\n lazySrc: String,\n options: {\n type: Object as PropType<IntersectionObserverInit>,\n // For more information on types, navigate to:\n // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API\n default: () => ({\n root: undefined,\n rootMargin: undefined,\n threshold: undefined,\n }),\n },\n position: {\n type: String,\n default: 'center center',\n },\n sizes: String,\n src: {\n type: [String, Object] as PropType<string | srcObject>,\n default: '',\n },\n srcset: String,\n\n ...makeTransitionProps(),\n },\n\n emits: ['loadstart', 'load', 'error'],\n\n setup (props, { emit, slots }) {\n const currentSrc = ref('') // Set from srcset\n const image = ref<HTMLImageElement>()\n const state = ref<'idle' | 'loading' | 'loaded' | 'error'>(props.eager ? 'loading' : 'idle')\n const naturalWidth = ref<number>()\n const naturalHeight = ref<number>()\n\n const normalisedSrc = computed<srcObject>(() => {\n return props.src && typeof props.src === 'object'\n ? {\n src: props.src.src,\n srcset: props.srcset || props.src.srcset,\n lazySrc: props.lazySrc || props.src.lazySrc,\n aspect: Number(props.aspectRatio || props.src.aspect),\n } : {\n src: props.src,\n srcset: props.srcset,\n lazySrc: props.lazySrc,\n aspect: Number(props.aspectRatio || 0),\n }\n })\n const aspectRatio = computed(() => {\n return normalisedSrc.value.aspect || naturalWidth.value! / naturalHeight.value! || 0\n })\n\n watch(() => props.src, () => {\n init(state.value !== 'idle')\n })\n // TODO: getSrc when window width changes\n\n onBeforeMount(() => init())\n\n function init (isIntersecting?: boolean) {\n if (props.eager && isIntersecting) return\n if (\n SUPPORTS_INTERSECTION &&\n !isIntersecting &&\n !props.eager\n ) return\n\n state.value = 'loading'\n nextTick(() => {\n emit('loadstart', image.value?.currentSrc || normalisedSrc.value.src)\n\n if (image.value?.complete) {\n if (!image.value.naturalWidth) {\n onError()\n }\n\n if (state.value === 'error') return\n\n if (!aspectRatio.value) pollForSize(image.value, null)\n onLoad()\n } else {\n if (!aspectRatio.value) pollForSize(image.value!)\n getSrc()\n }\n })\n\n if (normalisedSrc.value.lazySrc) {\n const lazyImg = new Image()\n lazyImg.src = normalisedSrc.value.lazySrc\n pollForSize(lazyImg, null)\n }\n }\n\n function onLoad () {\n getSrc()\n state.value = 'loaded'\n emit('load', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function onError () {\n state.value = 'error'\n emit('error', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function getSrc () {\n const img = image.value\n if (img) currentSrc.value = img.currentSrc || img.src\n }\n\n function pollForSize (img: HTMLImageElement, timeout: number | null = 100) {\n const poll = () => {\n const { naturalHeight: imgHeight, naturalWidth: imgWidth } = img\n\n if (imgHeight || imgWidth) {\n naturalWidth.value = imgWidth\n naturalHeight.value = imgHeight\n } else if (!img.complete && state.value === 'loading' && timeout != null) {\n setTimeout(poll, timeout)\n } else if (img.currentSrc.endsWith('.svg') || img.currentSrc.startsWith('data:image/svg+xml')) {\n naturalWidth.value = 1\n naturalHeight.value = 1\n }\n }\n\n poll()\n }\n\n const containClasses = computed(() => ({\n 'v-img__img--cover': props.cover,\n 'v-img__img--contain': !props.cover,\n }))\n\n const __image = computed(() => {\n if (!normalisedSrc.value.src || state.value === 'idle') return\n\n const img = h('img', {\n class: ['v-img__img', containClasses.value],\n src: normalisedSrc.value.src,\n srcset: normalisedSrc.value.srcset,\n sizes: props.sizes,\n ref: image,\n onLoad,\n onError,\n })\n\n const sources = slots.sources?.()\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n {\n withDirectives(\n sources\n ? <picture class=\"v-img__picture\">{ sources }{ img }</picture>\n : img,\n [[vShow, state.value === 'loaded']]\n )\n }\n </MaybeTransition>\n )\n })\n\n const __preloadImage = computed(() => (\n <MaybeTransition transition={ props.transition }>\n { normalisedSrc.value.lazySrc && state.value !== 'loaded' && (\n <img\n class={['v-img__img', 'v-img__img--preload', containClasses.value]}\n src={ normalisedSrc.value.lazySrc }\n alt=\"\"\n />\n )}\n </MaybeTransition>\n ))\n\n const __placeholder = computed(() => {\n if (!slots.placeholder) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { (state.value === 'loading' || (state.value === 'error' && !slots.error)) &&\n <div class=\"v-img__placeholder\">{ slots.placeholder() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __error = computed(() => {\n if (!slots.error) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { state.value === 'error' &&\n <div class=\"v-img__error\">{ slots.error() }</div>\n }\n </MaybeTransition>\n )\n })\n\n useRender(() => (\n <VResponsive\n class=\"v-img\"\n aspectRatio={ aspectRatio.value }\n aria-label={ props.alt }\n role={ props.alt ? 'img' : undefined }\n v-intersect={[{\n handler: init,\n options: props.options,\n }, null, ['once']]}\n v-slots={{\n additional: () => [__image.value, __preloadImage.value, __placeholder.value, __error.value],\n default: slots.default,\n }}\n />\n ))\n\n return {\n currentSrc,\n image,\n state,\n naturalWidth,\n naturalHeight,\n }\n },\n})\n"],"file":"VImg.mjs"}
1
+ {"version":3,"sources":["../../../src/components/VImg/VImg.tsx"],"names":["VResponsive","intersect","makeTransitionProps","MaybeTransition","computed","h","nextTick","onBeforeMount","ref","vShow","watch","withDirectives","convertToUnit","defineComponent","SUPPORTS_INTERSECTION","useRender","VImg","name","directives","props","aspectRatio","String","Number","alt","cover","Boolean","eager","gradient","lazySrc","options","type","Object","default","root","undefined","rootMargin","threshold","sizes","src","srcset","width","emits","setup","emit","slots","currentSrc","image","state","naturalWidth","naturalHeight","normalisedSrc","aspect","value","init","isIntersecting","lazyImg","Image","pollForSize","complete","onError","onLoad","getSrc","img","timeout","poll","imgHeight","imgWidth","setTimeout","endsWith","startsWith","containClasses","__image","class","sources","transition","__preloadImage","__placeholder","placeholder","error","__error","__gradient","backgroundImage","isBooted","stop","val","requestAnimationFrame","additional","handler"],"mappings":"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","sourcesContent":["import './VImg.sass'\n\n// Components\nimport { VResponsive } from '@/components/VResponsive'\n\n// Directives\nimport intersect from '@/directives/intersect'\n\n// Composables\nimport { makeTransitionProps, MaybeTransition } from '@/composables/transition'\n\n// Utilities\nimport {\n computed,\n h,\n nextTick,\n onBeforeMount,\n ref,\n vShow,\n watch,\n withDirectives,\n} from 'vue'\nimport {\n convertToUnit,\n defineComponent,\n SUPPORTS_INTERSECTION,\n useRender,\n} from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\n// not intended for public use, this is passed in by vuetify-loader\nexport interface srcObject {\n src?: string\n srcset?: string\n lazySrc?: string\n aspect: number\n}\n\nexport const VImg = defineComponent({\n name: 'VImg',\n\n directives: { intersect },\n\n props: {\n aspectRatio: [String, Number],\n alt: String,\n cover: Boolean,\n eager: Boolean,\n gradient: String,\n lazySrc: String,\n options: {\n type: Object as PropType<IntersectionObserverInit>,\n // For more information on types, navigate to:\n // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API\n default: () => ({\n root: undefined,\n rootMargin: undefined,\n threshold: undefined,\n }),\n },\n sizes: String,\n src: {\n type: [String, Object] as PropType<string | srcObject>,\n default: '',\n },\n srcset: String,\n width: [String, Number],\n\n ...makeTransitionProps(),\n },\n\n emits: ['loadstart', 'load', 'error'],\n\n setup (props, { emit, slots }) {\n const currentSrc = ref('') // Set from srcset\n const image = ref<HTMLImageElement>()\n const state = ref<'idle' | 'loading' | 'loaded' | 'error'>(props.eager ? 'loading' : 'idle')\n const naturalWidth = ref<number>()\n const naturalHeight = ref<number>()\n\n const normalisedSrc = computed<srcObject>(() => {\n return props.src && typeof props.src === 'object'\n ? {\n src: props.src.src,\n srcset: props.srcset || props.src.srcset,\n lazySrc: props.lazySrc || props.src.lazySrc,\n aspect: Number(props.aspectRatio || props.src.aspect),\n } : {\n src: props.src,\n srcset: props.srcset,\n lazySrc: props.lazySrc,\n aspect: Number(props.aspectRatio || 0),\n }\n })\n const aspectRatio = computed(() => {\n return normalisedSrc.value.aspect || naturalWidth.value! / naturalHeight.value! || 0\n })\n\n watch(() => props.src, () => {\n init(state.value !== 'idle')\n })\n // TODO: getSrc when window width changes\n\n onBeforeMount(() => init())\n\n function init (isIntersecting?: boolean) {\n if (props.eager && isIntersecting) return\n if (\n SUPPORTS_INTERSECTION &&\n !isIntersecting &&\n !props.eager\n ) return\n\n state.value = 'loading'\n\n if (normalisedSrc.value.lazySrc) {\n const lazyImg = new Image()\n lazyImg.src = normalisedSrc.value.lazySrc\n pollForSize(lazyImg, null)\n }\n\n if (!normalisedSrc.value.src) return\n\n nextTick(() => {\n emit('loadstart', image.value?.currentSrc || normalisedSrc.value.src)\n\n if (image.value?.complete) {\n if (!image.value.naturalWidth) {\n onError()\n }\n\n if (state.value === 'error') return\n\n if (!aspectRatio.value) pollForSize(image.value, null)\n onLoad()\n } else {\n if (!aspectRatio.value) pollForSize(image.value!)\n getSrc()\n }\n })\n }\n\n function onLoad () {\n getSrc()\n state.value = 'loaded'\n emit('load', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function onError () {\n state.value = 'error'\n emit('error', image.value?.currentSrc || normalisedSrc.value.src)\n }\n\n function getSrc () {\n const img = image.value\n if (img) currentSrc.value = img.currentSrc || img.src\n }\n\n function pollForSize (img: HTMLImageElement, timeout: number | null = 100) {\n const poll = () => {\n const { naturalHeight: imgHeight, naturalWidth: imgWidth } = img\n\n if (imgHeight || imgWidth) {\n naturalWidth.value = imgWidth\n naturalHeight.value = imgHeight\n } else if (!img.complete && state.value === 'loading' && timeout != null) {\n setTimeout(poll, timeout)\n } else if (img.currentSrc.endsWith('.svg') || img.currentSrc.startsWith('data:image/svg+xml')) {\n naturalWidth.value = 1\n naturalHeight.value = 1\n }\n }\n\n poll()\n }\n\n const containClasses = computed(() => ({\n 'v-img__img--cover': props.cover,\n 'v-img__img--contain': !props.cover,\n }))\n\n const __image = computed(() => {\n if (!normalisedSrc.value.src || state.value === 'idle') return\n\n const img = h('img', {\n class: ['v-img__img', containClasses.value],\n src: normalisedSrc.value.src,\n srcset: normalisedSrc.value.srcset,\n sizes: props.sizes,\n ref: image,\n onLoad,\n onError,\n })\n\n const sources = slots.sources?.()\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n {\n withDirectives(\n sources\n ? <picture class=\"v-img__picture\">{ sources }{ img }</picture>\n : img,\n [[vShow, state.value === 'loaded']]\n )\n }\n </MaybeTransition>\n )\n })\n\n const __preloadImage = computed(() => (\n <MaybeTransition transition={ props.transition }>\n { normalisedSrc.value.lazySrc && state.value !== 'loaded' && (\n <img\n class={['v-img__img', 'v-img__img--preload', containClasses.value]}\n src={ normalisedSrc.value.lazySrc }\n alt=\"\"\n />\n )}\n </MaybeTransition>\n ))\n\n const __placeholder = computed(() => {\n if (!slots.placeholder) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { (state.value === 'loading' || (state.value === 'error' && !slots.error)) &&\n <div class=\"v-img__placeholder\">{ slots.placeholder() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __error = computed(() => {\n if (!slots.error) return\n\n return (\n <MaybeTransition transition={ props.transition } appear>\n { state.value === 'error' &&\n <div class=\"v-img__error\">{ slots.error() }</div>\n }\n </MaybeTransition>\n )\n })\n\n const __gradient = computed(() => {\n if (!props.gradient) return\n\n return <div class=\"v-img__gradient\" style={{ backgroundImage: `linear-gradient(${props.gradient})` }} />\n })\n\n const isBooted = ref(false)\n {\n const stop = watch(aspectRatio, val => {\n if (val) {\n // Doesn't work with nextTick, idk why\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n isBooted.value = true\n })\n })\n stop()\n }\n })\n }\n\n useRender(() => (\n <VResponsive\n class={[\n 'v-img',\n { 'v-img--booting': !isBooted.value },\n ]}\n style={{ width: convertToUnit(props.width === 'auto' ? naturalWidth.value : props.width) }}\n aspectRatio={ aspectRatio.value }\n aria-label={ props.alt }\n role={ props.alt ? 'img' : undefined }\n v-intersect={[{\n handler: init,\n options: props.options,\n }, null, ['once']]}\n v-slots={{\n additional: () => [__image.value, __preloadImage.value, __gradient.value, __placeholder.value, __error.value],\n default: slots.default,\n }}\n />\n ))\n\n return {\n currentSrc,\n image,\n state,\n naturalWidth,\n naturalHeight,\n }\n },\n})\n\nexport type VImg = InstanceType<typeof VImg>\n"],"file":"VImg.mjs"}
@@ -1,20 +1,22 @@
1
1
  @forward './variables'
2
+ @use '../../styles/tools'
2
3
  @use './variables' as *
3
4
 
4
5
  .v-img
5
6
  --v-theme-overlay-multiplier: 3
6
7
  z-index: 0
7
8
 
9
+ &--booting .v-responsive__sizer
10
+ transition: none
11
+
8
12
  .v-img__img,
9
13
  .v-img__picture,
14
+ .v-img__gradient,
10
15
  .v-img__placeholder,
11
16
  .v-img__error
12
17
  z-index: -1
13
- position: absolute
14
- top: 0
15
- left: 0
16
- width: 100%
17
- height: 100%
18
+
19
+ @include tools.absolute()
18
20
 
19
21
  .v-img__img
20
22
  &--preload
@@ -25,3 +27,6 @@
25
27
 
26
28
  &--cover
27
29
  object-fit: cover
30
+
31
+ .v-img__gradient
32
+ background-repeat: no-repeat
@@ -1,2 +1,2 @@
1
- export { default as VImg } from "./VImg.mjs";
1
+ export { VImg } from "./VImg.mjs";
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VImg/index.ts"],"names":["default","VImg"],"mappings":"SAASA,OAAO,IAAIC,I","sourcesContent":["export { default as VImg } from './VImg'\n"],"file":"index.mjs"}
1
+ {"version":3,"sources":["../../../src/components/VImg/index.ts"],"names":["VImg"],"mappings":"SAASA,I","sourcesContent":["export { VImg } from './VImg'\n"],"file":"index.mjs"}
@@ -1,53 +1,110 @@
1
1
  .v-input {
2
2
  display: grid;
3
3
  flex: 1 1 auto;
4
- grid-template-areas: "prepend control append" "a messages b";
5
- grid-template-columns: max-content auto max-content;
6
- grid-template-rows: auto auto;
4
+ }
5
+ .v-input--disabled {
6
+ pointer-events: none;
7
7
  }
8
8
  .v-input--density-default {
9
9
  --v-input-control-height: 56px;
10
+ --v-input-padding-top: 16px;
10
11
  }
11
12
 
12
13
  .v-input--density-comfortable {
13
14
  --v-input-control-height: 48px;
15
+ --v-input-padding-top: 12px;
14
16
  }
15
17
 
16
18
  .v-input--density-compact {
17
19
  --v-input-control-height: 40px;
20
+ --v-input-padding-top: 8px;
21
+ }
22
+
23
+ .v-input--vertical {
24
+ grid-template-areas: "append" "control" "prepend";
25
+ grid-template-rows: max-content auto max-content;
26
+ grid-template-columns: min-content;
27
+ }
28
+ .v-input--vertical .v-input__prepend {
29
+ margin-block-start: 16px;
30
+ }
31
+ .v-input--vertical .v-input__append {
32
+ margin-block-end: 16px;
33
+ }
34
+
35
+ .v-input--horizontal {
36
+ grid-template-areas: "prepend control append" "a messages b";
37
+ grid-template-columns: max-content auto max-content;
38
+ grid-template-rows: auto auto;
39
+ }
40
+ .v-input--horizontal .v-input__prepend {
41
+ margin-inline-end: 16px;
42
+ }
43
+ .v-input--horizontal .v-input__append {
44
+ margin-inline-start: 16px;
18
45
  }
19
46
 
20
47
  .v-input__details {
21
48
  align-items: flex-end;
22
- color: rgba(0, 0, 0, 0.6);
23
49
  display: flex;
24
50
  font-size: 0.75rem;
25
51
  font-weight: 400;
26
52
  grid-area: messages;
27
53
  letter-spacing: 0.0333333333em;
28
54
  line-height: normal;
55
+ margin-bottom: 16px;
29
56
  min-height: 22px;
30
57
  padding-top: 6px;
31
58
  overflow: hidden;
32
- padding-inline-start: 16px;
33
- padding-inline-end: 16px;
34
59
  justify-content: space-between;
35
- transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
60
+ }
61
+
62
+ .v-input__details > .v-icon,
63
+ .v-input__prepend > .v-icon,
64
+ .v-input__append > .v-icon {
65
+ opacity: var(--v-medium-emphasis-opacity);
66
+ }
67
+ .v-input--disabled .v-input__details > .v-icon,
68
+ .v-input--disabled .v-input__details .v-messages, .v-input--error .v-input__details > .v-icon,
69
+ .v-input--error .v-input__details .v-messages,
70
+ .v-input--disabled .v-input__prepend > .v-icon,
71
+ .v-input--disabled .v-input__prepend .v-messages,
72
+ .v-input--error .v-input__prepend > .v-icon,
73
+ .v-input--error .v-input__prepend .v-messages,
74
+ .v-input--disabled .v-input__append > .v-icon,
75
+ .v-input--disabled .v-input__append .v-messages,
76
+ .v-input--error .v-input__append > .v-icon,
77
+ .v-input--error .v-input__append .v-messages {
78
+ opacity: 1;
79
+ }
80
+ .v-input--disabled .v-input__details,
81
+ .v-input--disabled .v-input__prepend,
82
+ .v-input--disabled .v-input__append {
83
+ opacity: var(--v-disabled-opacity);
84
+ }
85
+ .v-input--error:not(.v-input--disabled) .v-input__details > .v-icon,
86
+ .v-input--error:not(.v-input--disabled) .v-input__details .v-messages,
87
+ .v-input--error:not(.v-input--disabled) .v-input__prepend > .v-icon,
88
+ .v-input--error:not(.v-input--disabled) .v-input__prepend .v-messages,
89
+ .v-input--error:not(.v-input--disabled) .v-input__append > .v-icon,
90
+ .v-input--error:not(.v-input--disabled) .v-input__append .v-messages {
91
+ color: rgb(var(--v-theme-error));
36
92
  }
37
93
 
38
94
  .v-input__prepend,
39
95
  .v-input__append {
40
96
  display: flex;
41
- align-items: center;
42
- align-self: center;
97
+ padding-top: var(--v-input-padding-top);
43
98
  }
44
99
 
45
100
  .v-input__prepend {
46
- margin-inline-end: 16px;
47
101
  grid-area: prepend;
48
102
  }
49
103
 
50
104
  .v-input__append {
51
- margin-inline-start: 16px;
52
105
  grid-area: append;
106
+ }
107
+
108
+ .v-input__control {
109
+ grid-area: control;
53
110
  }