@vuetify/nightly 3.0.0-beta.0 → 3.0.0-beta.4

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 (715) hide show
  1. package/CHANGELOG.md +32 -2
  2. package/dist/_component-variables.sass +61 -0
  3. package/dist/json/attributes.json +662 -430
  4. package/dist/json/importMap.json +222 -198
  5. package/dist/json/tags.json +184 -96
  6. package/dist/json/web-types.json +2021 -1152
  7. package/dist/vuetify.css +1869 -1468
  8. package/dist/vuetify.d.ts +12840 -9217
  9. package/dist/vuetify.esm.js +6121 -5104
  10. package/dist/vuetify.esm.js.map +1 -1
  11. package/dist/vuetify.js +6120 -5103
  12. package/dist/vuetify.js.map +1 -1
  13. package/dist/vuetify.min.css +3 -3
  14. package/dist/vuetify.min.js +1085 -964
  15. package/dist/vuetify.min.js.map +1 -1
  16. package/lib/components/VAlert/VAlert.css +34 -13
  17. package/lib/components/VAlert/VAlert.mjs +43 -24
  18. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  19. package/lib/components/VAlert/VAlert.sass +26 -8
  20. package/lib/components/VAlert/VAlertTitle.mjs +1 -0
  21. package/lib/components/VAlert/VAlertTitle.mjs.map +1 -1
  22. package/lib/components/VAlert/_variables.scss +14 -7
  23. package/lib/components/VAlert/index.mjs.map +1 -1
  24. package/lib/components/VApp/VApp.css +1 -0
  25. package/lib/components/VApp/VApp.mjs.map +1 -1
  26. package/lib/components/VApp/VApp.sass +1 -0
  27. package/lib/components/VApp/index.mjs.map +1 -1
  28. package/lib/components/VAppBar/VAppBar.mjs +11 -7
  29. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  30. package/lib/components/VAppBar/VAppBar.sass +0 -1
  31. package/lib/components/VAppBar/VAppBarNavIcon.mjs +4 -2
  32. package/lib/components/VAppBar/VAppBarNavIcon.mjs.map +1 -1
  33. package/lib/components/VAppBar/VAppBarTitle.mjs +3 -1
  34. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  35. package/lib/components/VAppBar/index.mjs.map +1 -1
  36. package/lib/components/VAutocomplete/VAutocomplete.mjs +133 -101
  37. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  38. package/lib/components/VAutocomplete/VAutocomplete.sass +0 -2
  39. package/lib/components/VAutocomplete/index.mjs.map +1 -1
  40. package/lib/components/VAvatar/VAvatar.css +1 -1
  41. package/lib/components/VAvatar/VAvatar.mjs +17 -15
  42. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  43. package/lib/components/VAvatar/VAvatar.sass +1 -2
  44. package/lib/components/VAvatar/_mixins.scss +0 -1
  45. package/lib/components/VAvatar/index.mjs.map +1 -1
  46. package/lib/components/VBadge/VBadge.css +3 -6
  47. package/lib/components/VBadge/VBadge.mjs +16 -44
  48. package/lib/components/VBadge/VBadge.mjs.map +1 -1
  49. package/lib/components/VBadge/VBadge.sass +2 -5
  50. package/lib/components/VBadge/_variables.scss +1 -2
  51. package/lib/components/VBadge/index.mjs.map +1 -1
  52. package/lib/components/VBanner/VBanner.css +82 -58
  53. package/lib/components/VBanner/VBanner.mjs +49 -48
  54. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  55. package/lib/components/VBanner/VBanner.sass +61 -55
  56. package/lib/components/VBanner/VBannerActions.mjs +34 -2
  57. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  58. package/lib/components/VBanner/VBannerAvatar.mjs +20 -0
  59. package/lib/components/VBanner/VBannerAvatar.mjs.map +1 -0
  60. package/lib/components/VBanner/VBannerIcon.mjs +20 -0
  61. package/lib/components/VBanner/VBannerIcon.mjs.map +1 -0
  62. package/lib/components/VBanner/VBannerText.mjs.map +1 -1
  63. package/lib/components/VBanner/_variables.scss +10 -14
  64. package/lib/components/VBanner/index.mjs +2 -0
  65. package/lib/components/VBanner/index.mjs.map +1 -1
  66. package/lib/components/VBottomNavigation/VBottomNavigation.css +1 -1
  67. package/lib/components/VBottomNavigation/VBottomNavigation.mjs +1 -1
  68. package/lib/components/VBottomNavigation/VBottomNavigation.mjs.map +1 -1
  69. package/lib/components/VBottomNavigation/VBottomNavigation.sass +1 -2
  70. package/lib/components/VBottomNavigation/index.mjs.map +1 -1
  71. package/lib/components/VBottomSheet/VBottomSheet.mjs.map +1 -1
  72. package/lib/components/VBottomSheet/index.mjs.map +1 -1
  73. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +5 -2
  74. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  75. package/lib/components/VBreadcrumbs/VBreadcrumbs.sass +0 -1
  76. package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
  77. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +10 -9
  78. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  79. package/lib/components/VBreadcrumbs/index.mjs.map +1 -1
  80. package/lib/components/VBreadcrumbs/shared.mjs.map +1 -1
  81. package/lib/components/VBtn/VBtn.css +56 -11
  82. package/lib/components/VBtn/VBtn.mjs +51 -20
  83. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  84. package/lib/components/VBtn/VBtn.sass +35 -4
  85. package/lib/components/VBtn/_variables.scss +2 -0
  86. package/lib/components/VBtn/index.mjs.map +1 -1
  87. package/lib/components/VBtnGroup/VBtnGroup.css +14 -6
  88. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  89. package/lib/components/VBtnGroup/VBtnGroup.sass +14 -7
  90. package/lib/components/VBtnGroup/index.mjs.map +1 -1
  91. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  92. package/lib/components/VBtnToggle/VBtnToggle.sass +0 -1
  93. package/lib/components/VBtnToggle/index.mjs.map +1 -1
  94. package/lib/components/VCalendar/VCalendar.mjs.map +1 -1
  95. package/lib/components/VCalendar/VCalendarCategory.mjs.map +1 -1
  96. package/lib/components/VCalendar/VCalendarDaily.mjs.map +1 -1
  97. package/lib/components/VCalendar/VCalendarMonthly.mjs.map +1 -1
  98. package/lib/components/VCalendar/VCalendarWeekly.mjs.map +1 -1
  99. package/lib/components/VCalendar/index.mjs.map +1 -1
  100. package/lib/components/VCalendar/mixins/calendar-base.mjs.map +1 -1
  101. package/lib/components/VCalendar/mixins/calendar-with-events.mjs.map +1 -1
  102. package/lib/components/VCalendar/mixins/calendar-with-intervals.mjs.map +1 -1
  103. package/lib/components/VCalendar/mixins/mouse.mjs.map +1 -1
  104. package/lib/components/VCalendar/mixins/times.mjs.map +1 -1
  105. package/lib/components/VCalendar/modes/column.mjs.map +1 -1
  106. package/lib/components/VCalendar/modes/common.mjs.map +1 -1
  107. package/lib/components/VCalendar/modes/index.mjs.map +1 -1
  108. package/lib/components/VCalendar/modes/stack.mjs.map +1 -1
  109. package/lib/components/VCalendar/util/events.mjs.map +1 -1
  110. package/lib/components/VCalendar/util/parser.mjs.map +1 -1
  111. package/lib/components/VCalendar/util/props.mjs.map +1 -1
  112. package/lib/components/VCalendar/util/timestamp.mjs.map +1 -1
  113. package/lib/components/VCard/VCard.css +23 -20
  114. package/lib/components/VCard/VCard.mjs +17 -9
  115. package/lib/components/VCard/VCard.mjs.map +1 -1
  116. package/lib/components/VCard/VCard.sass +12 -10
  117. package/lib/components/VCard/VCardActions.mjs +1 -2
  118. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  119. package/lib/components/VCard/VCardAvatar.mjs.map +1 -1
  120. package/lib/components/VCard/VCardContent.mjs +3 -0
  121. package/lib/components/VCard/VCardContent.mjs.map +1 -0
  122. package/lib/components/VCard/VCardHeader.mjs.map +1 -1
  123. package/lib/components/VCard/VCardHeaderText.mjs.map +1 -1
  124. package/lib/components/VCard/VCardImg.mjs.map +1 -1
  125. package/lib/components/VCard/VCardSubtitle.mjs.map +1 -1
  126. package/lib/components/VCard/VCardText.mjs.map +1 -1
  127. package/lib/components/VCard/VCardTitle.mjs.map +1 -1
  128. package/lib/components/VCard/_variables.scss +11 -5
  129. package/lib/components/VCard/index.mjs +1 -0
  130. package/lib/components/VCard/index.mjs.map +1 -1
  131. package/lib/components/VCarousel/VCarousel.mjs +4 -3
  132. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  133. package/lib/components/VCarousel/VCarousel.sass +0 -1
  134. package/lib/components/VCarousel/VCarouselItem.mjs.map +1 -1
  135. package/lib/components/VCarousel/index.mjs.map +1 -1
  136. package/lib/components/VCheckbox/VCheckbox.mjs +15 -47
  137. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  138. package/lib/components/VCheckbox/VCheckbox.sass +0 -1
  139. package/lib/components/VCheckbox/VCheckboxBtn.mjs +67 -0
  140. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -0
  141. package/lib/components/VCheckbox/index.mjs +1 -0
  142. package/lib/components/VCheckbox/index.mjs.map +1 -1
  143. package/lib/components/VChip/VChip.css +8 -5
  144. package/lib/components/VChip/VChip.mjs +6 -5
  145. package/lib/components/VChip/VChip.mjs.map +1 -1
  146. package/lib/components/VChip/VChip.sass +3 -1
  147. package/lib/components/VChip/_variables.scss +3 -0
  148. package/lib/components/VChip/index.mjs.map +1 -1
  149. package/lib/components/VChipGroup/VChipGroup.mjs +1 -1
  150. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  151. package/lib/components/VChipGroup/index.mjs.map +1 -1
  152. package/lib/components/VCode/VCode.sass +1 -2
  153. package/lib/components/VCode/_variables.scss +1 -1
  154. package/lib/components/VCode/index.mjs.map +1 -1
  155. package/lib/components/VColorPicker/VColorPicker.mjs.map +1 -1
  156. package/lib/components/VColorPicker/VColorPicker.sass +0 -1
  157. package/lib/components/VColorPicker/VColorPickerCanvas.css +1 -1
  158. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  159. package/lib/components/VColorPicker/VColorPickerCanvas.sass +0 -1
  160. package/lib/components/VColorPicker/VColorPickerEdit.mjs.map +1 -1
  161. package/lib/components/VColorPicker/VColorPickerEdit.sass +0 -1
  162. package/lib/components/VColorPicker/VColorPickerPreview.mjs.map +1 -1
  163. package/lib/components/VColorPicker/VColorPickerPreview.sass +0 -1
  164. package/lib/components/VColorPicker/VColorPickerSwatches.mjs.map +1 -1
  165. package/lib/components/VColorPicker/VColorPickerSwatches.sass +0 -1
  166. package/lib/components/VColorPicker/index.mjs.map +1 -1
  167. package/lib/components/VColorPicker/util/index.mjs.map +1 -1
  168. package/lib/components/VCombobox/VCombobox.mjs +140 -110
  169. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  170. package/lib/components/VCombobox/VCombobox.sass +0 -2
  171. package/lib/components/VCombobox/index.mjs.map +1 -1
  172. package/lib/components/VCounter/VCounter.mjs.map +1 -1
  173. package/lib/components/VCounter/VCounter.sass +0 -1
  174. package/lib/components/VCounter/index.mjs.map +1 -1
  175. package/lib/components/VData/VData.mjs.map +1 -1
  176. package/lib/components/VData/index.mjs.map +1 -1
  177. package/lib/components/VDataIterator/VDataFooter.mjs.map +1 -1
  178. package/lib/components/VDataIterator/VDataIterator.mjs.map +1 -1
  179. package/lib/components/VDataIterator/index.mjs.map +1 -1
  180. package/lib/components/VDataTable/MobileRow.mjs.map +1 -1
  181. package/lib/components/VDataTable/Row.mjs.map +1 -1
  182. package/lib/components/VDataTable/RowGroup.mjs.map +1 -1
  183. package/lib/components/VDataTable/VDataTable.mjs.map +1 -1
  184. package/lib/components/VDataTable/VDataTableHeader.mjs.map +1 -1
  185. package/lib/components/VDataTable/VDataTableHeaderDesktop.mjs.map +1 -1
  186. package/lib/components/VDataTable/VDataTableHeaderMobile.mjs.map +1 -1
  187. package/lib/components/VDataTable/VEditDialog.mjs.map +1 -1
  188. package/lib/components/VDataTable/VVirtualTable.mjs.map +1 -1
  189. package/lib/components/VDataTable/index.mjs.map +1 -1
  190. package/lib/components/VDataTable/mixins/header.mjs.map +1 -1
  191. package/lib/components/VDatePicker/VDatePicker.mjs.map +1 -1
  192. package/lib/components/VDatePicker/VDatePickerDateTable.mjs.map +1 -1
  193. package/lib/components/VDatePicker/VDatePickerHeader.mjs.map +1 -1
  194. package/lib/components/VDatePicker/VDatePickerMonthTable.mjs.map +1 -1
  195. package/lib/components/VDatePicker/VDatePickerTitle.mjs.map +1 -1
  196. package/lib/components/VDatePicker/VDatePickerYears.mjs.map +1 -1
  197. package/lib/components/VDatePicker/index.mjs.map +1 -1
  198. package/lib/components/VDatePicker/mixins/date-picker-table.mjs.map +1 -1
  199. package/lib/components/VDatePicker/util/createNativeLocaleFormatter.mjs.map +1 -1
  200. package/lib/components/VDatePicker/util/eventHelpers.mjs.map +1 -1
  201. package/lib/components/VDatePicker/util/index.mjs.map +1 -1
  202. package/lib/components/VDatePicker/util/isDateAllowed.mjs.map +1 -1
  203. package/lib/components/VDatePicker/util/monthChange.mjs.map +1 -1
  204. package/lib/components/VDatePicker/util/pad.mjs.map +1 -1
  205. package/lib/components/VDatePicker/util/sanitizeDateString.mjs.map +1 -1
  206. package/lib/components/VDefaultsProvider/VDefaultsProvider.mjs.map +1 -1
  207. package/lib/components/VDefaultsProvider/index.mjs.map +1 -1
  208. package/lib/components/VDialog/VDialog.css +31 -12
  209. package/lib/components/VDialog/VDialog.mjs +14 -12
  210. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  211. package/lib/components/VDialog/VDialog.sass +27 -12
  212. package/lib/components/VDialog/_variables.scss +3 -7
  213. package/lib/components/VDialog/index.mjs.map +1 -1
  214. package/lib/components/VDivider/VDivider.mjs.map +1 -1
  215. package/lib/components/VDivider/VDivider.sass +0 -1
  216. package/lib/components/VDivider/index.mjs.map +1 -1
  217. package/lib/components/VExpansionPanel/VExpansionPanel.css +8 -6
  218. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +6 -2
  219. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  220. package/lib/components/VExpansionPanel/VExpansionPanel.sass +0 -1
  221. package/lib/components/VExpansionPanel/VExpansionPanelText.mjs.map +1 -1
  222. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +9 -6
  223. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  224. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +4 -0
  225. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  226. package/lib/components/VExpansionPanel/index.mjs.map +1 -1
  227. package/lib/components/VField/VField.css +10 -10
  228. package/lib/components/VField/VField.mjs +12 -11
  229. package/lib/components/VField/VField.mjs.map +1 -1
  230. package/lib/components/VField/VField.sass +7 -9
  231. package/lib/components/VField/VFieldLabel.mjs.map +1 -1
  232. package/lib/components/VField/_variables.scss +3 -3
  233. package/lib/components/VField/index.mjs.map +1 -1
  234. package/lib/components/VFileInput/VFileInput.mjs +5 -3
  235. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  236. package/lib/components/VFileInput/VFileInput.sass +0 -1
  237. package/lib/components/VFileInput/index.mjs.map +1 -1
  238. package/lib/components/VFooter/VFooter.mjs +32 -15
  239. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  240. package/lib/components/VFooter/VFooter.sass +0 -1
  241. package/lib/components/VFooter/index.mjs.map +1 -1
  242. package/lib/components/VForm/VForm.mjs +25 -11
  243. package/lib/components/VForm/VForm.mjs.map +1 -1
  244. package/lib/components/VForm/index.mjs.map +1 -1
  245. package/lib/components/VGrid/VCol.mjs.map +1 -1
  246. package/lib/components/VGrid/VContainer.mjs.map +1 -1
  247. package/lib/components/VGrid/VRow.mjs.map +1 -1
  248. package/lib/components/VGrid/VSpacer.mjs.map +1 -1
  249. package/lib/components/VGrid/index.mjs.map +1 -1
  250. package/lib/components/VHover/VHover.mjs.map +1 -1
  251. package/lib/components/VHover/index.mjs.map +1 -1
  252. package/lib/components/VIcon/VIcon.css +27 -12
  253. package/lib/components/VIcon/VIcon.mjs +18 -17
  254. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  255. package/lib/components/VIcon/VIcon.sass +27 -17
  256. package/lib/components/VIcon/_variables.scss +1 -0
  257. package/lib/components/VIcon/index.mjs.map +1 -1
  258. package/lib/components/VImg/VImg.mjs.map +1 -1
  259. package/lib/components/VImg/VImg.sass +0 -1
  260. package/lib/components/VImg/index.mjs.map +1 -1
  261. package/lib/components/VInput/VInput.css +3 -1
  262. package/lib/components/VInput/VInput.mjs +10 -10
  263. package/lib/components/VInput/VInput.mjs.map +1 -1
  264. package/lib/components/VInput/VInput.sass +3 -2
  265. package/lib/components/VInput/_variables.scss +4 -0
  266. package/lib/components/VInput/index.mjs.map +1 -1
  267. package/lib/components/VItemGroup/VItem.mjs.map +1 -1
  268. package/lib/components/VItemGroup/VItemGroup.mjs.map +1 -1
  269. package/lib/components/VItemGroup/VItemGroup.sass +0 -1
  270. package/lib/components/VItemGroup/index.mjs.map +1 -1
  271. package/lib/components/VKbd/VKbd.sass +0 -1
  272. package/lib/components/VKbd/_variables.scss +1 -1
  273. package/lib/components/VKbd/index.mjs.map +1 -1
  274. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  275. package/lib/components/VLabel/VLabel.sass +0 -1
  276. package/lib/components/VLabel/index.mjs.map +1 -1
  277. package/lib/components/VLayout/VLayout.mjs.map +1 -1
  278. package/lib/components/VLayout/VLayoutItem.mjs +1 -1
  279. package/lib/components/VLayout/VLayoutItem.mjs.map +1 -1
  280. package/lib/components/VLayout/index.mjs.map +1 -1
  281. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  282. package/lib/components/VLazy/index.mjs.map +1 -1
  283. package/lib/components/VList/VList.css +7 -12
  284. package/lib/components/VList/VList.mjs +83 -48
  285. package/lib/components/VList/VList.mjs.map +1 -1
  286. package/lib/components/VList/VList.sass +3 -4
  287. package/lib/components/VList/VListChildren.mjs +41 -3
  288. package/lib/components/VList/VListChildren.mjs.map +1 -1
  289. package/lib/components/VList/VListGroup.mjs +43 -15
  290. package/lib/components/VList/VListGroup.mjs.map +1 -1
  291. package/lib/components/VList/VListImg.mjs.map +1 -1
  292. package/lib/components/VList/VListItem.css +129 -51
  293. package/lib/components/VList/VListItem.mjs +49 -44
  294. package/lib/components/VList/VListItem.mjs.map +1 -1
  295. package/lib/components/VList/VListItem.sass +77 -30
  296. package/lib/components/VList/VListItemAction.mjs +29 -0
  297. package/lib/components/VList/VListItemAction.mjs.map +1 -0
  298. package/lib/components/VList/VListItemAvatar.mjs +10 -16
  299. package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
  300. package/lib/components/VList/VListItemHeader.mjs.map +1 -1
  301. package/lib/components/VList/VListItemIcon.mjs +23 -0
  302. package/lib/components/VList/VListItemIcon.mjs.map +1 -0
  303. package/lib/components/VList/VListItemMedia.mjs +4 -4
  304. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  305. package/lib/components/VList/VListItemSubtitle.mjs.map +1 -1
  306. package/lib/components/VList/VListItemTitle.mjs.map +1 -1
  307. package/lib/components/VList/VListSubheader.mjs +3 -3
  308. package/lib/components/VList/VListSubheader.mjs.map +1 -1
  309. package/lib/components/VList/_variables.scss +12 -4
  310. package/lib/components/VList/index.mjs +2 -0
  311. package/lib/components/VList/index.mjs.map +1 -1
  312. package/lib/components/VList/list.mjs.map +1 -1
  313. package/lib/components/VLocaleProvider/VLocaleProvider.mjs.map +1 -1
  314. package/lib/components/VLocaleProvider/index.mjs.map +1 -1
  315. package/lib/components/VMain/VMain.mjs.map +1 -1
  316. package/lib/components/VMain/VMain.sass +0 -1
  317. package/lib/components/VMain/index.mjs.map +1 -1
  318. package/lib/components/VMenu/VMenu.css +2 -12
  319. package/lib/components/VMenu/VMenu.mjs +65 -31
  320. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  321. package/lib/components/VMenu/VMenu.sass +3 -7
  322. package/lib/components/VMenu/_variables.scss +0 -1
  323. package/lib/components/VMenu/index.mjs.map +1 -1
  324. package/lib/components/VMenu/shared.mjs +2 -0
  325. package/lib/components/VMenu/shared.mjs.map +1 -0
  326. package/lib/components/VMessages/VMessages.mjs.map +1 -1
  327. package/lib/components/VMessages/VMessages.sass +0 -1
  328. package/lib/components/VMessages/index.mjs.map +1 -1
  329. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +13 -9
  330. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  331. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +0 -1
  332. package/lib/components/VNavigationDrawer/index.mjs.map +1 -1
  333. package/lib/components/VNavigationDrawer/touch.mjs.map +1 -1
  334. package/lib/components/VNoSsr/VNoSsr.mjs.map +1 -1
  335. package/lib/components/VNoSsr/index.mjs.map +1 -1
  336. package/lib/components/VOtpInput/VOtpInput.mjs.map +1 -1
  337. package/lib/components/VOtpInput/index.mjs.map +1 -1
  338. package/lib/components/VOverflowBtn/VOverflowBtn.mjs.map +1 -1
  339. package/lib/components/VOverflowBtn/index.mjs.map +1 -1
  340. package/lib/components/VOverlay/VOverlay.css +7 -0
  341. package/lib/components/VOverlay/VOverlay.mjs +57 -32
  342. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  343. package/lib/components/VOverlay/VOverlay.sass +8 -1
  344. package/lib/components/VOverlay/index.mjs.map +1 -1
  345. package/lib/components/VOverlay/{positionStrategies.mjs → locationStrategies.mjs} +39 -36
  346. package/lib/components/VOverlay/locationStrategies.mjs.map +1 -0
  347. package/lib/components/VOverlay/requestNewFrame.mjs.map +1 -1
  348. package/lib/components/VOverlay/scrollStrategies.mjs +11 -2
  349. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  350. package/lib/components/VOverlay/useActivator.mjs +57 -15
  351. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  352. package/lib/components/VOverlay/util/point.mjs.map +1 -1
  353. package/lib/components/VPagination/VPagination.mjs +16 -17
  354. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  355. package/lib/components/VPagination/VPagination.sass +0 -1
  356. package/lib/components/VPagination/index.mjs.map +1 -1
  357. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  358. package/lib/components/VParallax/index.mjs.map +1 -1
  359. package/lib/components/VPicker/VPicker.mjs.map +1 -1
  360. package/lib/components/VPicker/index.mjs.map +1 -1
  361. package/lib/components/VProgressCircular/VProgressCircular.mjs.map +1 -1
  362. package/lib/components/VProgressCircular/VProgressCircular.sass +0 -1
  363. package/lib/components/VProgressCircular/index.mjs.map +1 -1
  364. package/lib/components/VProgressLinear/VProgressLinear.css +1 -1
  365. package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
  366. package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
  367. package/lib/components/VProgressLinear/index.mjs.map +1 -1
  368. package/lib/components/VRadio/VRadio.mjs +6 -5
  369. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  370. package/lib/components/VRadio/index.mjs.map +1 -1
  371. package/lib/components/VRadioGroup/VRadioGroup.mjs +11 -6
  372. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  373. package/lib/components/VRadioGroup/index.mjs.map +1 -1
  374. package/lib/components/VRangeSlider/VRangeSlider.mjs +5 -2
  375. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  376. package/lib/components/VRangeSlider/index.mjs.map +1 -1
  377. package/lib/components/VRating/VRating.css +2 -2
  378. package/lib/components/VRating/VRating.mjs +17 -6
  379. package/lib/components/VRating/VRating.mjs.map +1 -1
  380. package/lib/components/VRating/VRating.sass +2 -3
  381. package/lib/components/VRating/index.mjs.map +1 -1
  382. package/lib/components/VResponsive/VResponsive.mjs.map +1 -1
  383. package/lib/components/VResponsive/index.mjs.map +1 -1
  384. package/lib/components/VSelect/VSelect.mjs +134 -107
  385. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  386. package/lib/components/VSelect/VSelect.sass +0 -2
  387. package/lib/components/VSelect/index.mjs.map +1 -1
  388. package/lib/components/VSelectionControl/VSelectionControl.css +1 -0
  389. package/lib/components/VSelectionControl/VSelectionControl.mjs +15 -12
  390. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  391. package/lib/components/VSelectionControl/VSelectionControl.sass +1 -1
  392. package/lib/components/VSelectionControl/index.mjs.map +1 -1
  393. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +6 -5
  394. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  395. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +0 -1
  396. package/lib/components/VSelectionControlGroup/index.mjs.map +1 -1
  397. package/lib/components/VSheet/VSheet.mjs +7 -3
  398. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  399. package/lib/components/VSheet/VSheet.sass +0 -1
  400. package/lib/components/VSheet/index.mjs.map +1 -1
  401. package/lib/components/VSkeletonLoader/VSkeletonLoader.mjs.map +1 -1
  402. package/lib/components/VSkeletonLoader/index.mjs.map +1 -1
  403. package/lib/components/VSlideGroup/VSlideGroup.css +0 -5
  404. package/lib/components/VSlideGroup/VSlideGroup.mjs +40 -17
  405. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  406. package/lib/components/VSlideGroup/VSlideGroup.sass +0 -5
  407. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +3 -1
  408. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  409. package/lib/components/VSlideGroup/helpers.mjs.map +1 -1
  410. package/lib/components/VSlideGroup/index.mjs.map +1 -1
  411. package/lib/components/VSlider/VSlider.css +7 -2
  412. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  413. package/lib/components/VSlider/VSlider.sass +11 -7
  414. package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
  415. package/lib/components/VSlider/VSliderThumb.sass +0 -2
  416. package/lib/components/VSlider/VSliderTrack.css +6 -6
  417. package/lib/components/VSlider/VSliderTrack.mjs +3 -2
  418. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  419. package/lib/components/VSlider/VSliderTrack.sass +7 -9
  420. package/lib/components/VSlider/_variables.scss +5 -2
  421. package/lib/components/VSlider/index.mjs.map +1 -1
  422. package/lib/components/VSlider/slider.mjs.map +1 -1
  423. package/lib/components/VSnackbar/VSnackbar.css +19 -36
  424. package/lib/components/VSnackbar/VSnackbar.mjs +38 -19
  425. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  426. package/lib/components/VSnackbar/VSnackbar.sass +15 -35
  427. package/lib/components/VSnackbar/_variables.scss +0 -4
  428. package/lib/components/VSnackbar/index.mjs.map +1 -1
  429. package/lib/components/VSparkline/VSparkline.mjs.map +1 -1
  430. package/lib/components/VSparkline/helpers/core.mjs.map +1 -1
  431. package/lib/components/VSparkline/helpers/math.mjs.map +1 -1
  432. package/lib/components/VSparkline/helpers/path.mjs.map +1 -1
  433. package/lib/components/VSparkline/index.mjs.map +1 -1
  434. package/lib/components/VSpeedDial/VSpeedDial.mjs.map +1 -1
  435. package/lib/components/VSpeedDial/index.mjs.map +1 -1
  436. package/lib/components/VStepper/VStepper.mjs.map +1 -1
  437. package/lib/components/VStepper/VStepperContent.mjs.map +1 -1
  438. package/lib/components/VStepper/VStepperStep.mjs.map +1 -1
  439. package/lib/components/VStepper/index.mjs.map +1 -1
  440. package/lib/components/VSwitch/VSwitch.mjs +15 -6
  441. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  442. package/lib/components/VSwitch/VSwitch.sass +0 -1
  443. package/lib/components/VSwitch/index.mjs.map +1 -1
  444. package/lib/components/VSystemBar/VSystemBar.css +0 -5
  445. package/lib/components/VSystemBar/VSystemBar.mjs +31 -14
  446. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  447. package/lib/components/VSystemBar/VSystemBar.sass +0 -6
  448. package/lib/components/VSystemBar/_variables.scss +0 -3
  449. package/lib/components/VSystemBar/index.mjs.map +1 -1
  450. package/lib/components/VTable/VTable.mjs.map +1 -1
  451. package/lib/components/VTable/VTable.sass +0 -1
  452. package/lib/components/VTable/index.mjs.map +1 -1
  453. package/lib/components/VTabs/VTab.css +1 -1
  454. package/lib/components/VTabs/VTab.mjs +33 -36
  455. package/lib/components/VTabs/VTab.mjs.map +1 -1
  456. package/lib/components/VTabs/VTab.sass +1 -2
  457. package/lib/components/VTabs/VTabs.css +14 -11
  458. package/lib/components/VTabs/VTabs.mjs +7 -8
  459. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  460. package/lib/components/VTabs/VTabs.sass +10 -7
  461. package/lib/components/VTabs/_variables.scss +1 -1
  462. package/lib/components/VTabs/index.mjs.map +1 -1
  463. package/lib/components/VTabs/shared.mjs +2 -0
  464. package/lib/components/VTabs/shared.mjs.map +1 -0
  465. package/lib/components/VTextField/VTextField.css +4 -4
  466. package/lib/components/VTextField/VTextField.mjs +9 -10
  467. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  468. package/lib/components/VTextField/VTextField.sass +5 -6
  469. package/lib/components/VTextField/index.mjs.map +1 -1
  470. package/lib/components/VTextarea/VTextarea.css +7 -4
  471. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  472. package/lib/components/VTextarea/VTextarea.sass +9 -7
  473. package/lib/components/VTextarea/index.mjs.map +1 -1
  474. package/lib/components/VThemeProvider/VThemeProvider.mjs.map +1 -1
  475. package/lib/components/VThemeProvider/index.mjs.map +1 -1
  476. package/lib/components/VTimePicker/SelectingTimes.mjs.map +1 -1
  477. package/lib/components/VTimePicker/VTimePicker.mjs.map +1 -1
  478. package/lib/components/VTimePicker/VTimePickerClock.mjs.map +1 -1
  479. package/lib/components/VTimePicker/VTimePickerTitle.mjs.map +1 -1
  480. package/lib/components/VTimePicker/index.mjs.map +1 -1
  481. package/lib/components/VTimeline/VTimeline.css +187 -48
  482. package/lib/components/VTimeline/VTimeline.mjs +27 -11
  483. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  484. package/lib/components/VTimeline/VTimeline.sass +196 -52
  485. package/lib/components/VTimeline/VTimelineDivider.mjs +5 -3
  486. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  487. package/lib/components/VTimeline/VTimelineItem.mjs +3 -2
  488. package/lib/components/VTimeline/VTimelineItem.mjs.map +1 -1
  489. package/lib/components/VTimeline/_variables.scss +2 -1
  490. package/lib/components/VTimeline/index.mjs.map +1 -1
  491. package/lib/components/VTimeline/shared.mjs.map +1 -1
  492. package/lib/components/VToolbar/VToolbar.css +8 -1
  493. package/lib/components/VToolbar/VToolbar.mjs +21 -17
  494. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  495. package/lib/components/VToolbar/VToolbar.sass +2 -2
  496. package/lib/components/VToolbar/VToolbarItems.mjs +1 -2
  497. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  498. package/lib/components/VToolbar/VToolbarTitle.mjs.map +1 -1
  499. package/lib/components/VToolbar/_variables.scss +13 -1
  500. package/lib/components/VToolbar/index.mjs.map +1 -1
  501. package/lib/components/VTooltip/VTooltip.mjs +12 -7
  502. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  503. package/lib/components/VTooltip/VTooltip.sass +0 -1
  504. package/lib/components/VTooltip/index.mjs.map +1 -1
  505. package/lib/components/VTreeview/VTreeview.mjs.map +1 -1
  506. package/lib/components/VTreeview/VTreeviewNode.mjs.map +1 -1
  507. package/lib/components/VTreeview/index.mjs.map +1 -1
  508. package/lib/components/VTreeview/util/filterTreeItems.mjs.map +1 -1
  509. package/lib/components/VValidation/VValidation.mjs.map +1 -1
  510. package/lib/components/VValidation/index.mjs.map +1 -1
  511. package/lib/components/VVirtualScroll/VVirtualScroll.mjs.map +1 -1
  512. package/lib/components/VVirtualScroll/index.mjs.map +1 -1
  513. package/lib/components/VWindow/VWindow.mjs +2 -10
  514. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  515. package/lib/components/VWindow/VWindow.sass +0 -2
  516. package/lib/components/VWindow/VWindowItem.mjs +9 -3
  517. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  518. package/lib/components/VWindow/index.mjs.map +1 -1
  519. package/lib/components/index.d.ts +13464 -9854
  520. package/lib/components/index.mjs.map +1 -1
  521. package/lib/components/transitions/createTransition.mjs.map +1 -1
  522. package/lib/components/transitions/dialog-transition.mjs +61 -8
  523. package/lib/components/transitions/dialog-transition.mjs.map +1 -1
  524. package/lib/components/transitions/expand-transition.mjs.map +1 -1
  525. package/lib/components/transitions/index.mjs.map +1 -1
  526. package/lib/composables/border.mjs.map +1 -1
  527. package/lib/composables/color.mjs.map +1 -1
  528. package/lib/composables/defaults.mjs +2 -2
  529. package/lib/composables/defaults.mjs.map +1 -1
  530. package/lib/composables/delay.mjs.map +1 -1
  531. package/lib/composables/density.mjs.map +1 -1
  532. package/lib/composables/dimensions.mjs.map +1 -1
  533. package/lib/composables/display.mjs +13 -11
  534. package/lib/composables/display.mjs.map +1 -1
  535. package/lib/composables/elevation.mjs.map +1 -1
  536. package/lib/composables/filter.mjs +33 -13
  537. package/lib/composables/filter.mjs.map +1 -1
  538. package/lib/composables/focus.mjs.map +1 -1
  539. package/lib/composables/form.mjs +24 -11
  540. package/lib/composables/form.mjs.map +1 -1
  541. package/lib/composables/forwardRef.mjs +10 -6
  542. package/lib/composables/forwardRef.mjs.map +1 -1
  543. package/lib/composables/group.mjs +14 -6
  544. package/lib/composables/group.mjs.map +1 -1
  545. package/lib/composables/hydration.mjs.map +1 -1
  546. package/lib/composables/icons.mjs +15 -3
  547. package/lib/composables/icons.mjs.map +1 -1
  548. package/lib/composables/index.mjs.map +1 -1
  549. package/lib/composables/intersectionObserver.mjs.map +1 -1
  550. package/lib/composables/items.mjs +84 -0
  551. package/lib/composables/items.mjs.map +1 -0
  552. package/lib/composables/layout.mjs +10 -6
  553. package/lib/composables/layout.mjs.map +1 -1
  554. package/lib/composables/lazy.mjs.map +1 -1
  555. package/lib/composables/loader.mjs.map +1 -1
  556. package/lib/composables/locale.mjs +11 -8
  557. package/lib/composables/locale.mjs.map +1 -1
  558. package/lib/composables/location.mjs +70 -0
  559. package/lib/composables/location.mjs.map +1 -0
  560. package/lib/composables/mutationObserver.mjs.map +1 -1
  561. package/lib/composables/nested/nested.mjs +27 -14
  562. package/lib/composables/nested/nested.mjs.map +1 -1
  563. package/lib/composables/nested/openStrategies.mjs +63 -36
  564. package/lib/composables/nested/openStrategies.mjs.map +1 -1
  565. package/lib/composables/nested/selectStrategies.mjs +163 -122
  566. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  567. package/lib/composables/position.mjs +4 -25
  568. package/lib/composables/position.mjs.map +1 -1
  569. package/lib/composables/proxiedModel.mjs.map +1 -1
  570. package/lib/composables/refs.mjs.map +1 -1
  571. package/lib/composables/resizeObserver.mjs +1 -9
  572. package/lib/composables/resizeObserver.mjs.map +1 -1
  573. package/lib/composables/rounded.mjs.map +1 -1
  574. package/lib/composables/router.mjs +29 -15
  575. package/lib/composables/router.mjs.map +1 -1
  576. package/lib/composables/rtl.mjs.map +1 -1
  577. package/lib/composables/scopeId.mjs +11 -0
  578. package/lib/composables/scopeId.mjs.map +1 -0
  579. package/lib/composables/scroll.mjs.map +1 -1
  580. package/lib/composables/selectLink.mjs +19 -0
  581. package/lib/composables/selectLink.mjs.map +1 -0
  582. package/lib/composables/size.mjs.map +1 -1
  583. package/lib/composables/ssrBoot.mjs +3 -2
  584. package/lib/composables/ssrBoot.mjs.map +1 -1
  585. package/lib/composables/stack.mjs +27 -23
  586. package/lib/composables/stack.mjs.map +1 -1
  587. package/lib/composables/tag.mjs.map +1 -1
  588. package/lib/composables/teleport.mjs.map +1 -1
  589. package/lib/composables/theme.mjs +94 -93
  590. package/lib/composables/theme.mjs.map +1 -1
  591. package/lib/composables/toggleScope.mjs +18 -0
  592. package/lib/composables/toggleScope.mjs.map +1 -0
  593. package/lib/composables/touch.mjs.map +1 -1
  594. package/lib/composables/transition.mjs.map +1 -1
  595. package/lib/composables/validation.mjs +17 -6
  596. package/lib/composables/validation.mjs.map +1 -1
  597. package/lib/composables/variant.mjs +3 -6
  598. package/lib/composables/variant.mjs.map +1 -1
  599. package/lib/directives/click-outside/index.mjs.map +1 -1
  600. package/lib/directives/color/index.mjs.map +1 -1
  601. package/lib/directives/index.mjs.map +1 -1
  602. package/lib/directives/intersect/index.mjs.map +1 -1
  603. package/lib/directives/mutate/index.mjs.map +1 -1
  604. package/lib/directives/resize/index.mjs.map +1 -1
  605. package/lib/directives/ripple/VRipple.sass +0 -1
  606. package/lib/directives/ripple/index.mjs +15 -3
  607. package/lib/directives/ripple/index.mjs.map +1 -1
  608. package/lib/directives/scroll/index.mjs.map +1 -1
  609. package/lib/directives/touch/index.mjs.map +1 -1
  610. package/lib/entry-bundler.mjs +1 -1
  611. package/lib/entry-bundler.mjs.map +1 -1
  612. package/lib/framework.mjs +39 -29
  613. package/lib/framework.mjs.map +1 -1
  614. package/lib/iconsets/fa-svg.d.ts +2 -1
  615. package/lib/iconsets/fa-svg.mjs.map +1 -1
  616. package/lib/iconsets/fa.d.ts +2 -1
  617. package/lib/iconsets/fa.mjs.map +1 -1
  618. package/lib/iconsets/fa4.d.ts +2 -1
  619. package/lib/iconsets/fa4.mjs.map +1 -1
  620. package/lib/iconsets/md.d.ts +2 -1
  621. package/lib/iconsets/md.mjs.map +1 -1
  622. package/lib/iconsets/mdi-svg.d.ts +2 -1
  623. package/lib/iconsets/mdi-svg.mjs.map +1 -1
  624. package/lib/iconsets/mdi.d.ts +2 -1
  625. package/lib/iconsets/mdi.mjs.map +1 -1
  626. package/lib/index.d.ts +161 -138
  627. package/lib/locale/adapters/vue-i18n.mjs.map +1 -1
  628. package/lib/locale/adapters/vue-intl.mjs.map +1 -1
  629. package/lib/locale/af.mjs.map +1 -1
  630. package/lib/locale/ar.mjs.map +1 -1
  631. package/lib/locale/az.mjs.map +1 -1
  632. package/lib/locale/bg.mjs.map +1 -1
  633. package/lib/locale/ca.mjs +9 -9
  634. package/lib/locale/ca.mjs.map +1 -1
  635. package/lib/locale/ckb.mjs.map +1 -1
  636. package/lib/locale/cs.mjs.map +1 -1
  637. package/lib/locale/da.mjs.map +1 -1
  638. package/lib/locale/de.mjs.map +1 -1
  639. package/lib/locale/el.mjs.map +1 -1
  640. package/lib/locale/en.mjs.map +1 -1
  641. package/lib/locale/es.mjs.map +1 -1
  642. package/lib/locale/et.mjs.map +1 -1
  643. package/lib/locale/fa.mjs.map +1 -1
  644. package/lib/locale/fi.mjs.map +1 -1
  645. package/lib/locale/fr.mjs.map +1 -1
  646. package/lib/locale/he.mjs.map +1 -1
  647. package/lib/locale/hr.mjs.map +1 -1
  648. package/lib/locale/hu.mjs.map +1 -1
  649. package/lib/locale/id.mjs.map +1 -1
  650. package/lib/locale/index.mjs.map +1 -1
  651. package/lib/locale/it.mjs.map +1 -1
  652. package/lib/locale/ja.mjs.map +1 -1
  653. package/lib/locale/ko.mjs.map +1 -1
  654. package/lib/locale/lt.mjs.map +1 -1
  655. package/lib/locale/lv.mjs.map +1 -1
  656. package/lib/locale/nl.mjs.map +1 -1
  657. package/lib/locale/no.mjs.map +1 -1
  658. package/lib/locale/pl.mjs.map +1 -1
  659. package/lib/locale/pt.mjs.map +1 -1
  660. package/lib/locale/ro.mjs.map +1 -1
  661. package/lib/locale/ru.mjs.map +1 -1
  662. package/lib/locale/sk.mjs.map +1 -1
  663. package/lib/locale/sl.mjs.map +1 -1
  664. package/lib/locale/sr-Cyrl.mjs.map +1 -1
  665. package/lib/locale/sr-Latn.mjs.map +1 -1
  666. package/lib/locale/sv.mjs.map +1 -1
  667. package/lib/locale/th.mjs.map +1 -1
  668. package/lib/locale/tr.mjs.map +1 -1
  669. package/lib/locale/uk.mjs.map +1 -1
  670. package/lib/locale/vi.mjs.map +1 -1
  671. package/lib/locale/zh-Hans.mjs.map +1 -1
  672. package/lib/locale/zh-Hant.mjs.map +1 -1
  673. package/lib/presets/default/index.mjs.map +1 -1
  674. package/lib/services/goto/easing-patterns.mjs.map +1 -1
  675. package/lib/services/goto/index.mjs.map +1 -1
  676. package/lib/services/goto/util.mjs.map +1 -1
  677. package/lib/styles/generic/_colors.scss +0 -1
  678. package/lib/styles/main.css +400 -392
  679. package/lib/styles/settings/_utilities.scss +54 -26
  680. package/lib/styles/tools/_states.sass +11 -3
  681. package/lib/styles/tools/_utilities.sass +1 -1
  682. package/lib/styles/tools/_variant.sass +6 -6
  683. package/lib/{components/VOverlay/util → util}/anchor.mjs +0 -0
  684. package/lib/util/anchor.mjs.map +1 -0
  685. package/lib/util/animation.mjs.map +1 -1
  686. package/lib/util/box.mjs.map +1 -1
  687. package/lib/util/color/APCA.mjs.map +1 -1
  688. package/lib/util/color/transformCIELAB.mjs.map +1 -1
  689. package/lib/util/color/transformSRGB.mjs.map +1 -1
  690. package/lib/util/colorUtils.mjs.map +1 -1
  691. package/lib/util/colors.mjs.map +1 -1
  692. package/lib/util/console.mjs.map +1 -1
  693. package/lib/util/createSimpleFunctional.mjs.map +1 -1
  694. package/lib/util/dateTimeUtils.mjs.map +1 -1
  695. package/lib/util/defineComponent.mjs +37 -6
  696. package/lib/util/defineComponent.mjs.map +1 -1
  697. package/lib/util/dom.mjs.map +1 -1
  698. package/lib/util/easing.mjs.map +1 -1
  699. package/lib/util/getCurrentInstance.mjs +20 -1
  700. package/lib/util/getCurrentInstance.mjs.map +1 -1
  701. package/lib/util/getScrollParent.mjs.map +1 -1
  702. package/lib/util/globals.mjs +0 -3
  703. package/lib/util/globals.mjs.map +1 -1
  704. package/lib/util/helpers.mjs +1 -5
  705. package/lib/util/helpers.mjs.map +1 -1
  706. package/lib/util/index.mjs +1 -0
  707. package/lib/util/index.mjs.map +1 -1
  708. package/lib/util/isFixedPosition.mjs.map +1 -1
  709. package/lib/util/propsFactory.mjs.map +1 -1
  710. package/lib/util/useRender.mjs.map +1 -1
  711. package/package.json +41 -31
  712. package/lib/components/VOverlay/positionStrategies.mjs.map +0 -1
  713. package/lib/components/VOverlay/util/anchor.mjs.map +0 -1
  714. package/lib/composables/overlay.mjs +0 -30
  715. package/lib/composables/overlay.mjs.map +0 -1
@@ -3,8 +3,10 @@ import { createVNode as _createVNode, resolveDirective as _resolveDirective } fr
3
3
  import { VToolbarTitle } from "../VToolbar/index.mjs"; // Utilities
4
4
 
5
5
  import { defineComponent } from "../../util/index.mjs";
6
- export const VAppBarTitle = defineComponent({ ...VToolbarTitle,
6
+ export const VAppBarTitle = defineComponent({
7
7
  name: 'VAppBarTitle',
8
+ props: { ...VToolbarTitle.props
9
+ },
8
10
 
9
11
  setup(_, _ref) {
10
12
  let {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAppBar/VAppBarTitle.tsx"],"names":["VToolbarTitle","defineComponent","VAppBarTitle","name","setup","_","slots"],"mappings":";AAAA;SACSA,a,iCAET;;SACSC,e;AAET,OAAO,MAAMC,YAAY,GAAGD,eAAe,CAAC,EAC1C,GAAGD,aADuC;AAG1CG,EAAAA,IAAI,EAAE,cAHoC;;AAK1CC,EAAAA,KAAK,CAAEC,CAAF,QAAgB;AAAA,QAAX;AAAEC,MAAAA;AAAF,KAAW;AACnB,WAAO;AAAA,eAEG;AAFH,OAGOA,KAHP,CAAP;AAMD;;AAZyC,CAAD,CAApC","sourcesContent":["// Composables\nimport { VToolbarTitle } from '@/components/VToolbar'\n\n// Utilities\nimport { defineComponent } from '@/util'\n\nexport const VAppBarTitle = defineComponent({\n ...VToolbarTitle,\n\n name: 'VAppBarTitle',\n\n setup (_, { slots }) {\n return () => (\n <VToolbarTitle\n class=\"v-app-bar-title\"\n v-slots={ slots }\n />\n )\n },\n})\n"],"file":"VAppBarTitle.mjs"}
1
+ {"version":3,"file":"VAppBarTitle.mjs","names":["VToolbarTitle","defineComponent","VAppBarTitle","name","props","setup","_","slots"],"sources":["../../../src/components/VAppBar/VAppBarTitle.tsx"],"sourcesContent":["// Composables\nimport { VToolbarTitle } from '@/components/VToolbar'\n\n// Utilities\nimport { defineComponent } from '@/util'\n\nexport const VAppBarTitle = defineComponent({\n name: 'VAppBarTitle',\n\n props: { ...VToolbarTitle.props },\n\n setup (_, { slots }) {\n return () => (\n <VToolbarTitle\n class=\"v-app-bar-title\"\n v-slots={ slots }\n />\n )\n },\n})\n"],"mappings":";AAAA;SACSA,a,iCAET;;SACSC,e;AAET,OAAO,MAAMC,YAAY,GAAGD,eAAe,CAAC;EAC1CE,IAAI,EAAE,cADoC;EAG1CC,KAAK,EAAE,EAAE,GAAGJ,aAAa,CAACI;EAAnB,CAHmC;;EAK1CC,KAAK,CAAEC,CAAF,QAAgB;IAAA,IAAX;MAAEC;IAAF,CAAW;IACnB,OAAO;MAAA,SAEG;IAFH,GAGOA,KAHP,CAAP;EAMD;;AAZyC,CAAD,CAApC"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAppBar/index.ts"],"names":["VAppBar","VAppBarNavIcon","VAppBarTitle"],"mappings":"SAASA,O;SACAC,c;SACAC,Y","sourcesContent":["export { VAppBar } from './VAppBar'\nexport { VAppBarNavIcon } from './VAppBarNavIcon'\nexport { VAppBarTitle } from './VAppBarTitle'\n"],"file":"index.mjs"}
1
+ {"version":3,"file":"index.mjs","names":["VAppBar","VAppBarNavIcon","VAppBarTitle"],"sources":["../../../src/components/VAppBar/index.ts"],"sourcesContent":["export { VAppBar } from './VAppBar'\nexport { VAppBarNavIcon } from './VAppBarNavIcon'\nexport { VAppBarTitle } from './VAppBarTitle'\n"],"mappings":"SAASA,O;SACAC,c;SACAC,Y"}
@@ -1,8 +1,9 @@
1
- import { createTextVNode as _createTextVNode, createVNode as _createVNode, Fragment as _Fragment } from "vue";
1
+ import { createTextVNode as _createTextVNode, mergeProps as _mergeProps, createVNode as _createVNode, Fragment as _Fragment } from "vue";
2
2
  // Styles
3
3
  import "./VAutocomplete.css"; // Components
4
4
 
5
- import { genItem, makeSelectProps } from "../VSelect/VSelect.mjs";
5
+ import { makeSelectProps } from "../VSelect/VSelect.mjs";
6
+ import { VCheckboxBtn } from "../VCheckbox/index.mjs";
6
7
  import { VChip } from "../VChip/index.mjs";
7
8
  import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
8
9
  import { VList, VListItem } from "../VList/index.mjs";
@@ -11,11 +12,12 @@ import { VTextField } from "../VTextField/index.mjs"; // Composables
11
12
 
12
13
  import { makeFilterProps, useFilter } from "../../composables/filter.mjs";
13
14
  import { makeTransitionProps } from "../../composables/transition.mjs";
15
+ import { useItems } from "../../composables/items.mjs";
14
16
  import { useForwardRef } from "../../composables/forwardRef.mjs";
15
17
  import { useLocale } from "../../composables/locale.mjs";
16
18
  import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utility
17
19
 
18
- import { computed, nextTick, ref, watch } from 'vue';
20
+ import { computed, mergeProps, nextTick, ref, watch } from 'vue';
19
21
  import { genericComponent, useRender, wrapInArray } from "../../util/index.mjs"; // Types
20
22
 
21
23
  function highlightResult(text, matches, length) {
@@ -46,7 +48,8 @@ export const VAutocomplete = genericComponent()({
46
48
  emits: {
47
49
  'click:clear': e => true,
48
50
  'update:search': val => true,
49
- 'update:modelValue': val => true
51
+ 'update:modelValue': val => true,
52
+ 'update:menu': val => true
50
53
  },
51
54
 
52
55
  setup(props, _ref) {
@@ -57,35 +60,30 @@ export const VAutocomplete = genericComponent()({
57
60
  t
58
61
  } = useLocale();
59
62
  const vTextFieldRef = ref();
60
- const activator = ref();
61
63
  const isFocused = ref(false);
62
64
  const isPristine = ref(true);
63
- const menu = ref(false);
64
- const items = computed(() => props.items.map(genItem));
65
+ const menu = useProxiedModel(props, 'menu');
66
+ const {
67
+ items,
68
+ transformIn,
69
+ transformOut
70
+ } = useItems(props);
65
71
  const search = useProxiedModel(props, 'search', '');
66
- const model = useProxiedModel(props, 'modelValue', [], v => wrapInArray(v || []), v => props.multiple ? v : v[0]);
72
+ const model = useProxiedModel(props, 'modelValue', [], v => transformIn(wrapInArray(v)), v => {
73
+ var _transformed$;
74
+
75
+ const transformed = transformOut(v);
76
+ return props.multiple ? transformed : (_transformed$ = transformed[0]) != null ? _transformed$ : null;
77
+ });
67
78
  const {
68
79
  filteredItems
69
80
  } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value));
70
81
  const selections = computed(() => {
71
- const array = [];
72
- let index = 0;
73
-
74
- for (const unwrapped of model.value) {
75
- const item = genItem(unwrapped);
76
- const found = array.find(selection => selection.value === item.value);
77
-
78
- if (found == null) {
79
- array.push({ ...item,
80
- index
81
- });
82
- index++;
83
- }
84
- }
85
-
86
- return array;
82
+ return model.value.map(v => {
83
+ return items.value.find(item => item.value === v.value) || v;
84
+ });
87
85
  });
88
- const selected = computed(() => selections.value.map(selection => selection.value));
86
+ const selected = computed(() => selections.value.map(selection => selection.props.value));
89
87
 
90
88
  function onClear(e) {
91
89
  model.value = [];
@@ -116,6 +114,10 @@ export const VAutocomplete = genericComponent()({
116
114
  }
117
115
  }
118
116
 
117
+ function onInput(e) {
118
+ search.value = e.target.value;
119
+ }
120
+
119
121
  function onAfterLeave() {
120
122
  if (isFocused.value) isPristine.value = true;
121
123
  }
@@ -124,15 +126,18 @@ export const VAutocomplete = genericComponent()({
124
126
 
125
127
  function select(item) {
126
128
  if (props.multiple) {
127
- const index = selections.value.findIndex(selection => selection.value === item.value);
129
+ const index = selected.value.findIndex(selection => selection === item.value);
128
130
 
129
131
  if (index === -1) {
130
- model.value.push(item.value);
132
+ model.value = [...model.value, item];
133
+ search.value = '';
131
134
  } else {
132
- model.value = selected.value.filter(selection => selection !== item.value);
135
+ const value = [...model.value];
136
+ value.splice(index, 1);
137
+ model.value = value;
133
138
  }
134
139
  } else {
135
- model.value = [item.value];
140
+ model.value = [item];
136
141
  isSelecting.value = true;
137
142
  search.value = item.title;
138
143
  menu.value = false;
@@ -141,15 +146,12 @@ export const VAutocomplete = genericComponent()({
141
146
  }
142
147
  }
143
148
 
144
- watch(() => vTextFieldRef.value, val => {
145
- activator.value = val.$el.querySelector('.v-input__control');
146
- });
147
149
  watch(isFocused, val => {
148
150
  if (val) {
149
- var _model$value;
151
+ var _selections$value$at$, _selections$value$at;
150
152
 
151
153
  isSelecting.value = true;
152
- search.value = props.multiple ? '' : String((_model$value = model.value) != null ? _model$value : '');
154
+ search.value = props.multiple ? '' : String((_selections$value$at$ = (_selections$value$at = selections.value.at(-1)) == null ? void 0 : _selections$value$at.props.title) != null ? _selections$value$at$ : '');
153
155
  isPristine.value = true;
154
156
  nextTick(() => isSelecting.value = false);
155
157
  } else {
@@ -167,14 +169,17 @@ export const VAutocomplete = genericComponent()({
167
169
  return _createVNode(VTextField, {
168
170
  "ref": vTextFieldRef,
169
171
  "modelValue": search.value,
170
- "onUpdate:modelValue": $event => search.value = $event,
172
+ "onUpdate:modelValue": v => {
173
+ if (v == null) model.value = [];
174
+ },
175
+ "validationValue": props.modelValue,
176
+ "onInput": onInput,
171
177
  "class": ['v-autocomplete', {
172
178
  'v-autocomplete--active-menu': menu.value,
173
179
  'v-autocomplete--chips': !!props.chips,
174
180
  [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true
175
181
  }],
176
182
  "appendInnerIcon": props.menuIcon,
177
- "dirty": selected.value.length > 0,
178
183
  "onClick:clear": onClear,
179
184
  "onClick:control": onClickControl,
180
185
  "onClick:input": onClickControl,
@@ -182,78 +187,105 @@ export const VAutocomplete = genericComponent()({
182
187
  "onBlur": () => isFocused.value = false,
183
188
  "onKeydown": onKeydown
184
189
  }, { ...slots,
185
- default: () => _createVNode(_Fragment, null, [activator.value && _createVNode(VMenu, {
186
- "modelValue": menu.value,
187
- "onUpdate:modelValue": $event => menu.value = $event,
188
- "activator": activator.value,
189
- "contentClass": "v-autocomplete__content",
190
- "eager": props.eager,
191
- "openOnClick": false,
192
- "transition": props.transition,
193
- "onAfterLeave": onAfterLeave
194
- }, {
195
- default: () => [_createVNode(VList, {
196
- "selected": selected.value,
197
- "selectStrategy": props.multiple ? 'independent' : 'single-independent'
198
- }, {
199
- default: () => [!filteredItems.value.length && !props.hideNoData && _createVNode(VListItem, {
200
- "title": t(props.noDataText)
201
- }, null), filteredItems.value.map(_ref2 => {
202
- let {
203
- item,
204
- matches
205
- } = _ref2;
206
- return _createVNode(VListItem, {
207
- "value": item.value,
208
- "onMousedown": e => e.preventDefault(),
209
- "onClick": () => select(item)
210
- }, {
211
- title: () => {
212
- var _search$value$length, _search$value;
190
+ default: () => {
191
+ var _slots$noData, _slots$noData2;
213
192
 
214
- return isPristine.value ? item.title : highlightResult(item.title, matches.title, (_search$value$length = (_search$value = search.value) == null ? void 0 : _search$value.length) != null ? _search$value$length : 0);
215
- }
216
- });
193
+ return _createVNode(_Fragment, null, [_createVNode(VMenu, _mergeProps({
194
+ "modelValue": menu.value,
195
+ "onUpdate:modelValue": $event => menu.value = $event,
196
+ "activator": "parent",
197
+ "contentClass": "v-autocomplete__content",
198
+ "eager": props.eager,
199
+ "openOnClick": false,
200
+ "closeOnContentClick": false,
201
+ "transition": props.transition,
202
+ "onAfterLeave": onAfterLeave
203
+ }, props.menuProps), {
204
+ default: () => [_createVNode(VList, {
205
+ "selected": selected.value,
206
+ "selectStrategy": props.multiple ? 'independent' : 'single-independent',
207
+ "onMousedown": e => e.preventDefault()
208
+ }, {
209
+ default: () => [!filteredItems.value.length && !props.hideNoData && ((_slots$noData = (_slots$noData2 = slots['no-data']) == null ? void 0 : _slots$noData2.call(slots)) != null ? _slots$noData : _createVNode(VListItem, {
210
+ "title": t(props.noDataText)
211
+ }, null)), filteredItems.value.map(_ref2 => {
212
+ var _slots$item, _slots$item2;
213
+
214
+ let {
215
+ item,
216
+ matches
217
+ } = _ref2;
218
+ return (_slots$item = (_slots$item2 = slots.item) == null ? void 0 : _slots$item2.call(slots, {
219
+ item,
220
+ props: mergeProps(item.props, {
221
+ onClick: () => select(item)
222
+ })
223
+ })) != null ? _slots$item : _createVNode(VListItem, _mergeProps(item.props, {
224
+ "onClick": () => select(item)
225
+ }), {
226
+ prepend: _ref3 => {
227
+ let {
228
+ isSelected
229
+ } = _ref3;
230
+ return props.multiple ? _createVNode(VCheckboxBtn, {
231
+ "modelValue": isSelected,
232
+ "ripple": false
233
+ }, null) : undefined;
234
+ },
235
+ title: () => {
236
+ var _search$value$length, _search$value;
237
+
238
+ return isPristine.value ? item.title : highlightResult(item.title, matches.title, (_search$value$length = (_search$value = search.value) == null ? void 0 : _search$value.length) != null ? _search$value$length : 0);
239
+ }
240
+ });
241
+ })]
217
242
  })]
218
- })]
219
- }), selections.value.map((selection, index) => {
220
- function onChipClose(e) {
221
- e.stopPropagation();
222
- e.preventDefault();
223
- select(selection);
224
- }
243
+ }), selections.value.map((item, index) => {
244
+ function onChipClose(e) {
245
+ e.stopPropagation();
246
+ e.preventDefault();
247
+ select(item);
248
+ }
225
249
 
226
- const slotProps = {
227
- 'onClick:close': onChipClose,
228
- modelValue: true
229
- };
230
- return _createVNode("div", {
231
- "class": "v-autocomplete__selection"
232
- }, [hasChips && _createVNode(VDefaultsProvider, {
233
- "defaults": {
234
- VChip: {
235
- closable: props.closableChips,
236
- size: 'small',
237
- text: selection.title
250
+ const slotProps = {
251
+ 'onClick:close': onChipClose,
252
+ modelValue: true
253
+ };
254
+ return _createVNode("div", {
255
+ "class": "v-autocomplete__selection"
256
+ }, [hasChips ? _createVNode(VDefaultsProvider, {
257
+ "defaults": {
258
+ VChip: {
259
+ closable: props.closableChips,
260
+ size: 'small',
261
+ text: item.title
262
+ }
238
263
  }
239
- }
240
- }, {
241
- default: () => [slots.chip ? slots.chip({
242
- props: slotProps,
243
- selection
244
- }) : _createVNode(VChip, slotProps, null)]
245
- }), !hasChips && (slots.selection ? slots.selection({
246
- selection
247
- }) : _createVNode("span", {
248
- "class": "v-autocomplete__selection-text"
249
- }, [selection.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
250
- "class": "v-autocomplete__selection-comma"
251
- }, [_createTextVNode(",")])]))]);
252
- })])
264
+ }, {
265
+ default: () => [slots.chip ? slots.chip({
266
+ props: slotProps,
267
+ item,
268
+ index
269
+ }) : _createVNode(VChip, slotProps, null)]
270
+ }) : slots.selection ? slots.selection({
271
+ item,
272
+ index
273
+ }) : _createVNode("span", {
274
+ "class": "v-autocomplete__selection-text"
275
+ }, [item.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
276
+ "class": "v-autocomplete__selection-comma"
277
+ }, [_createTextVNode(",")])])]);
278
+ })]);
279
+ }
253
280
  });
254
281
  });
255
282
  return useForwardRef({
256
- filteredItems
283
+ isFocused,
284
+ isPristine,
285
+ menu,
286
+ search,
287
+ filteredItems,
288
+ select
257
289
  }, vTextFieldRef);
258
290
  }
259
291
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"names":["genItem","makeSelectProps","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","useForwardRef","useLocale","useProxiedModel","computed","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VAutocomplete","name","props","search","String","filterKeys","transition","emits","e","val","setup","slots","t","vTextFieldRef","activator","isFocused","isPristine","menu","items","map","model","v","multiple","filteredItems","value","undefined","selections","array","index","unwrapped","item","found","find","selection","push","selected","onClear","openOnClear","onClickControl","hideNoData","onKeydown","includes","key","onAfterLeave","isSelecting","select","findIndex","filter","title","$el","querySelector","hasChips","chips","chip","menuIcon","default","eager","noDataText","preventDefault","onChipClose","stopPropagation","slotProps","modelValue","closable","closableChips","size"],"mappings":"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","sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { genItem, makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utility\nimport { computed, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { DefaultChipSlot, InternalSelectItem } from '@/components/VSelect/VSelect'\nimport type { MakeSlots } from '@/util'\n\nexport interface InternalAutocompleteItem extends InternalSelectItem {\n\n}\n\nexport interface DefaultAutocompleteSlot {\n selection: InternalAutocompleteItem\n}\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\nexport const VAutocomplete = genericComponent<new <T>() => {\n $slots: MakeSlots<{\n chip: [DefaultChipSlot]\n default: []\n selection: [DefaultAutocompleteSlot]\n }>\n}>()({\n name: 'VAutocomplete',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'click:clear': (e: MouseEvent) => true,\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const activator = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = ref(false)\n const items = computed(() => props.items.map(genItem))\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => wrapInArray(v || []),\n (v: any) => props.multiple ? v : v[0]\n )\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n const array: InternalSelectItem[] = []\n let index = 0\n for (const unwrapped of model.value) {\n const item = genItem(unwrapped)\n\n const found = array.find(selection => selection.value === item.value)\n\n if (found == null) {\n array.push({\n ...item,\n index,\n })\n\n index++\n }\n }\n\n return array\n })\n const selected = computed(() => selections.value.map(selection => selection.value))\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n const isSelecting = ref(false)\n function select (item: any) {\n if (props.multiple) {\n const index = selections.value.findIndex(selection => selection.value === item.value)\n\n if (index === -1) {\n model.value.push(item.value)\n } else {\n model.value = selected.value.filter(selection => selection !== item.value)\n }\n } else {\n model.value = [item.value]\n\n isSelecting.value = true\n\n search.value = item.title\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(() => vTextFieldRef.value, val => {\n activator.value = val.$el.querySelector('.v-input__control')\n })\n\n watch(isFocused, val => {\n if (val) {\n isSelecting.value = true\n search.value = props.multiple ? '' : String(model.value ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n menu.value = false\n search.value = ''\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n v-model={ search.value }\n class={[\n 'v-autocomplete',\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.menuIcon }\n dirty={ selected.value.length > 0 }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n { activator.value && (\n <VMenu\n v-model={ menu.value }\n activator={ activator.value }\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n openOnClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n >\n { !filteredItems.value.length && !props.hideNoData && (\n <VListItem title={ t(props.noDataText) } />\n ) }\n\n { filteredItems.value.map(({ item, matches }) => (\n <VListItem\n value={ item.value }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onClick={ () => select(item) }\n >\n {{\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n ) }\n { selections.value.map((selection, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(selection)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div class=\"v-autocomplete__selection\">\n { hasChips && (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: selection.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ props: slotProps, selection })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) }\n\n { !hasChips && (\n slots.selection\n ? slots.selection({ selection })\n : (\n <span class=\"v-autocomplete__selection-text\">\n { selection.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n filteredItems,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"file":"VAutocomplete.mjs"}
1
+ {"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","useItems","useForwardRef","useLocale","useProxiedModel","computed","mergeProps","nextTick","ref","watch","genericComponent","useRender","wrapInArray","highlightResult","text","matches","length","Array","isArray","Error","substr","VAutocomplete","name","props","search","String","filterKeys","transition","emits","e","val","setup","slots","t","vTextFieldRef","isFocused","isPristine","menu","items","transformIn","transformOut","model","v","transformed","multiple","filteredItems","value","undefined","selections","map","find","item","selected","selection","onClear","openOnClear","onClickControl","hideNoData","onKeydown","includes","key","onInput","target","onAfterLeave","isSelecting","select","index","findIndex","splice","title","at","hasChips","chips","chip","modelValue","menuIcon","default","eager","menuProps","preventDefault","noDataText","onClick","prepend","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { MakeSlots } from '@/util'\n\nfunction highlightResult (text: string, matches: FilterMatch, length: number) {\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VAutocomplete = genericComponent<new <\n T,\n ReturnObject extends boolean = false,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: Readonly<V>\n 'onUpdate:modelValue'?: (val: V) => void\n }\n $slots: VInputSlots & VFieldSlots & MakeSlots<{\n chip: [{ item: T, index: number, props: Record<string, unknown> }]\n selection: [{ item: T, index: number }]\n 'no-data': []\n }>\n}>()({\n name: 'VAutocomplete',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'click:clear': (e: MouseEvent) => true,\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const { items, transformIn, transformOut } = useItems(props)\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v)),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const { filteredItems } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => item.value === v.value) || v\n })\n })\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onClickControl () {\n if (props.hideNoData && !filteredItems.value.length) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n }\n\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n\n const isSelecting = ref(false)\n\n function select (item: any) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item]\n search.value = ''\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [item]\n\n isSelecting.value = true\n\n search.value = item.title\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(isFocused, val => {\n if (val) {\n isSelecting.value = true\n search.value = props.multiple ? '' : String(selections.value.at(-1)?.props.title ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n menu.value = false\n search.value = ''\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n modelValue={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ props.modelValue }\n onInput={ onInput }\n class={[\n 'v-autocomplete',\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.menuIcon }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n <VList\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n >\n { !filteredItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { filteredItems.value.map(({ item, matches }) => slots.item?.({\n item,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div class=\"v-autocomplete__selection\">\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ props: slotProps, item, index })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-autocomplete__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n ) }\n </span>\n )\n )}\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return useForwardRef({\n isFocused,\n isPristine,\n menu,\n search,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"mappings":";AAAA;AACA,6B,CAEA;;SACSA,e;SACAC,Y;SACAC,K;SACAC,iB;SACAC,K,EAAOC,S;SACPC,K;SACAC,U,mCAET;;SACSC,e,EAAiBC,S;SACjBC,mB;SACAC,Q;SACAC,a;SACAC,S;SACAC,e,8CAET;;AACA,SAASC,QAAT,EAAmBC,UAAnB,EAA+BC,QAA/B,EAAyCC,GAAzC,EAA8CC,KAA9C,QAA2D,KAA3D;SACSC,gB,EAAkBC,S,EAAWC,W,gCAEtC;;AAMA,SAASC,eAAT,CAA0BC,IAA1B,EAAwCC,OAAxC,EAA8DC,MAA9D,EAA8E;EAC5E,IAAIC,KAAK,CAACC,OAAN,CAAcH,OAAd,CAAJ,EAA4B,MAAM,IAAII,KAAJ,CAAU,qCAAV,CAAN;EAE5B,OAAO,OAAOJ,OAAP,KAAmB,QAAnB,IAA+B,CAACA,OAAhC;IAAA,SAGW;EAHX,IAGsCD,IAAI,CAACM,MAAL,CAAY,CAAZ,EAAeL,OAAf,CAHtC;IAAA,SAIW;EAJX,IAIoCD,IAAI,CAACM,MAAL,CAAYL,OAAZ,EAAqBC,MAArB,CAJpC;IAAA,SAKW;EALX,IAKsCF,IAAI,CAACM,MAAL,CAAYL,OAAO,GAAGC,MAAtB,CALtC,OAQHF,IARJ;AASD;;AAaD,OAAO,MAAMO,aAAa,GAAGX,gBAAgB,GAkBxC;EACHY,IAAI,EAAE,eADH;EAGHC,KAAK,EAAE;IACL;IACA;IACAC,MAAM,EAAEC,MAHH;IAKL,GAAG3B,eAAe,CAAC;MAAE4B,UAAU,EAAE,CAAC,OAAD;IAAd,CAAD,CALb;IAML,GAAGpC,eAAe,EANb;IAOL,GAAGU,mBAAmB,CAAC;MAAE2B,UAAU,EAAE;IAAd,CAAD;EAPjB,CAHJ;EAaHC,KAAK,EAAE;IACL,eAAgBC,CAAD,IAAmB,IAD7B;IAEL,iBAAkBC,GAAD,IAAc,IAF1B;IAGL,qBAAsBA,GAAD,IAAc,IAH9B;IAIL,eAAgBA,GAAD,IAAkB;EAJ5B,CAbJ;;EAoBHC,KAAK,CAAER,KAAF,QAAoB;IAAA,IAAX;MAAES;IAAF,CAAW;IACvB,MAAM;MAAEC;IAAF,IAAQ9B,SAAS,EAAvB;IACA,MAAM+B,aAAa,GAAG1B,GAAG,EAAzB;IACA,MAAM2B,SAAS,GAAG3B,GAAG,CAAC,KAAD,CAArB;IACA,MAAM4B,UAAU,GAAG5B,GAAG,CAAC,IAAD,CAAtB;IACA,MAAM6B,IAAI,GAAGjC,eAAe,CAACmB,KAAD,EAAQ,MAAR,CAA5B;IACA,MAAM;MAAEe,KAAF;MAASC,WAAT;MAAsBC;IAAtB,IAAuCvC,QAAQ,CAACsB,KAAD,CAArD;IACA,MAAMC,MAAM,GAAGpB,eAAe,CAACmB,KAAD,EAAQ,QAAR,EAAkB,EAAlB,CAA9B;IACA,MAAMkB,KAAK,GAAGrC,eAAe,CAC3BmB,KAD2B,EAE3B,YAF2B,EAG3B,EAH2B,EAI3BmB,CAAC,IAAIH,WAAW,CAAC3B,WAAW,CAAC8B,CAAD,CAAZ,CAJW,EAK3BA,CAAC,IAAI;MAAA;;MACH,MAAMC,WAAW,GAAGH,YAAY,CAACE,CAAD,CAAhC;MACA,OAAOnB,KAAK,CAACqB,QAAN,GAAiBD,WAAjB,oBAAgCA,WAAW,CAAC,CAAD,CAA3C,4BAAkD,IAAzD;IACD,CAR0B,CAA7B;IAUA,MAAM;MAAEE;IAAF,IAAoB9C,SAAS,CAACwB,KAAD,EAAQe,KAAR,EAAejC,QAAQ,CAAC,MAAM+B,UAAU,CAACU,KAAX,GAAmBC,SAAnB,GAA+BvB,MAAM,CAACsB,KAA7C,CAAvB,CAAnC;IACA,MAAME,UAAU,GAAG3C,QAAQ,CAAC,MAAM;MAChC,OAAOoC,KAAK,CAACK,KAAN,CAAYG,GAAZ,CAAgBP,CAAC,IAAI;QAC1B,OAAOJ,KAAK,CAACQ,KAAN,CAAYI,IAAZ,CAAiBC,IAAI,IAAIA,IAAI,CAACL,KAAL,KAAeJ,CAAC,CAACI,KAA1C,KAAoDJ,CAA3D;MACD,CAFM,CAAP;IAGD,CAJ0B,CAA3B;IAKA,MAAMU,QAAQ,GAAG/C,QAAQ,CAAC,MAAM2C,UAAU,CAACF,KAAX,CAAiBG,GAAjB,CAAqBI,SAAS,IAAIA,SAAS,CAAC9B,KAAV,CAAgBuB,KAAlD,CAAP,CAAzB;;IAEA,SAASQ,OAAT,CAAkBzB,CAAlB,EAAiC;MAC/BY,KAAK,CAACK,KAAN,GAAc,EAAd;;MAEA,IAAIvB,KAAK,CAACgC,WAAV,EAAuB;QACrBlB,IAAI,CAACS,KAAL,GAAa,IAAb;MACD;;MAEDtB,MAAM,CAACsB,KAAP,GAAe,EAAf;IACD;;IACD,SAASU,cAAT,GAA2B;MACzB,IAAIjC,KAAK,CAACkC,UAAN,IAAoB,CAACZ,aAAa,CAACC,KAAd,CAAoB9B,MAA7C,EAAqD;MAErDqB,IAAI,CAACS,KAAL,GAAa,IAAb;IACD;;IACD,SAASY,SAAT,CAAoB7B,CAApB,EAAsC;MACpC,IAAI,CAAC,OAAD,EAAU,WAAV,EAAuB8B,QAAvB,CAAgC9B,CAAC,CAAC+B,GAAlC,CAAJ,EAA4C;QAC1CvB,IAAI,CAACS,KAAL,GAAa,IAAb;MACD;;MAED,IAAI,CAAC,QAAD,EAAWa,QAAX,CAAoB9B,CAAC,CAAC+B,GAAtB,CAAJ,EAAgC;QAC9BvB,IAAI,CAACS,KAAL,GAAa,KAAb;MACD;;MAED,IAAI,CAAC,OAAD,EAAU,QAAV,EAAoB,KAApB,EAA2Ba,QAA3B,CAAoC9B,CAAC,CAAC+B,GAAtC,CAAJ,EAAgD;QAC9CxB,UAAU,CAACU,KAAX,GAAmB,IAAnB;MACD;IACF;;IAED,SAASe,OAAT,CAAkBhC,CAAlB,EAAiC;MAC/BL,MAAM,CAACsB,KAAP,GAAgBjB,CAAC,CAACiC,MAAH,CAA+BhB,KAA9C;IACD;;IAED,SAASiB,YAAT,GAAyB;MACvB,IAAI5B,SAAS,CAACW,KAAd,EAAqBV,UAAU,CAACU,KAAX,GAAmB,IAAnB;IACtB;;IAED,MAAMkB,WAAW,GAAGxD,GAAG,CAAC,KAAD,CAAvB;;IAEA,SAASyD,MAAT,CAAiBd,IAAjB,EAA4B;MAC1B,IAAI5B,KAAK,CAACqB,QAAV,EAAoB;QAClB,MAAMsB,KAAK,GAAGd,QAAQ,CAACN,KAAT,CAAeqB,SAAf,CAAyBd,SAAS,IAAIA,SAAS,KAAKF,IAAI,CAACL,KAAzD,CAAd;;QAEA,IAAIoB,KAAK,KAAK,CAAC,CAAf,EAAkB;UAChBzB,KAAK,CAACK,KAAN,GAAc,CAAC,GAAGL,KAAK,CAACK,KAAV,EAAiBK,IAAjB,CAAd;UACA3B,MAAM,CAACsB,KAAP,GAAe,EAAf;QACD,CAHD,MAGO;UACL,MAAMA,KAAK,GAAG,CAAC,GAAGL,KAAK,CAACK,KAAV,CAAd;UACAA,KAAK,CAACsB,MAAN,CAAaF,KAAb,EAAoB,CAApB;UACAzB,KAAK,CAACK,KAAN,GAAcA,KAAd;QACD;MACF,CAXD,MAWO;QACLL,KAAK,CAACK,KAAN,GAAc,CAACK,IAAD,CAAd;QAEAa,WAAW,CAAClB,KAAZ,GAAoB,IAApB;QAEAtB,MAAM,CAACsB,KAAP,GAAeK,IAAI,CAACkB,KAApB;QACAhC,IAAI,CAACS,KAAL,GAAa,KAAb;QACAV,UAAU,CAACU,KAAX,GAAmB,IAAnB;QAEAvC,QAAQ,CAAC,MAAOyD,WAAW,CAAClB,KAAZ,GAAoB,KAA5B,CAAR;MACD;IACF;;IAEDrC,KAAK,CAAC0B,SAAD,EAAYL,GAAG,IAAI;MACtB,IAAIA,GAAJ,EAAS;QAAA;;QACPkC,WAAW,CAAClB,KAAZ,GAAoB,IAApB;QACAtB,MAAM,CAACsB,KAAP,GAAevB,KAAK,CAACqB,QAAN,GAAiB,EAAjB,GAAsBnB,MAAM,kDAACuB,UAAU,CAACF,KAAX,CAAiBwB,EAAjB,CAAoB,CAAC,CAArB,CAAD,qBAAC,qBAAyB/C,KAAzB,CAA+B8C,KAAhC,oCAAyC,EAAzC,CAA3C;QACAjC,UAAU,CAACU,KAAX,GAAmB,IAAnB;QAEAvC,QAAQ,CAAC,MAAMyD,WAAW,CAAClB,KAAZ,GAAoB,KAA3B,CAAR;MACD,CAND,MAMO;QACLT,IAAI,CAACS,KAAL,GAAa,KAAb;QACAtB,MAAM,CAACsB,KAAP,GAAe,EAAf;MACD;IACF,CAXI,CAAL;IAaArC,KAAK,CAACe,MAAD,EAASM,GAAG,IAAI;MACnB,IAAI,CAACK,SAAS,CAACW,KAAX,IAAoBkB,WAAW,CAAClB,KAApC,EAA2C;MAE3C,IAAIhB,GAAJ,EAASO,IAAI,CAACS,KAAL,GAAa,IAAb;MAETV,UAAU,CAACU,KAAX,GAAmB,CAAChB,GAApB;IACD,CANI,CAAL;IAQAnB,SAAS,CAAC,MAAM;MACd,MAAM4D,QAAQ,GAAG,CAAC,EAAEhD,KAAK,CAACiD,KAAN,IAAexC,KAAK,CAACyC,IAAvB,CAAlB;MAEA;QAAA,OAEUvC,aAFV;QAAA,cAGiBV,MAAM,CAACsB,KAHxB;QAAA,uBAI0BJ,CAAC,IAAI;UAAE,IAAIA,CAAC,IAAI,IAAT,EAAeD,KAAK,CAACK,KAAN,GAAc,EAAd;QAAkB,CAJlE;QAAA,mBAKsBvB,KAAK,CAACmD,UAL5B;QAAA,WAMcb,OANd;QAAA,SAOW,CACL,gBADK,EAEL;UACE,+BAA+BxB,IAAI,CAACS,KADtC;UAEE,yBAAyB,CAAC,CAACvB,KAAK,CAACiD,KAFnC;UAGE,CAAE,mBAAkBjD,KAAK,CAACqB,QAAN,GAAiB,UAAjB,GAA8B,QAAS,EAA3D,GAA+D;QAHjE,CAFK,CAPX;QAAA,mBAesBrB,KAAK,CAACoD,QAf5B;QAAA,iBAgBoBrB,OAhBpB;QAAA,mBAiBsBE,cAjBtB;QAAA,iBAkBoBA,cAlBpB;QAAA,WAmBc,MAAMrB,SAAS,CAACW,KAAV,GAAkB,IAnBtC;QAAA,UAoBa,MAAMX,SAAS,CAACW,KAAV,GAAkB,KApBrC;QAAA,aAqBgBY;MArBhB,KAwBM,GAAG1B,KAxBT;QAyBM4C,OAAO,EAAE;UAAA;;UAAA;YAAA,cAGOvC,IAAI,CAACS,KAHZ;YAAA,iCAGOT,IAAI,CAACS,KAHZ;YAAA,aAIO,QAJP;YAAA,gBAKU,yBALV;YAAA,SAMKvB,KAAK,CAACsD,KANX;YAAA,eAOW,KAPX;YAAA,uBAQmB,KARnB;YAAA,cASUtD,KAAK,CAACI,UAThB;YAAA,gBAUYoC;UAVZ,GAWExC,KAAK,CAACuD,SAXR;YAAA;cAAA,YAcU1B,QAAQ,CAACN,KAdnB;cAAA,kBAegBvB,KAAK,CAACqB,QAAN,GAAiB,aAAjB,GAAiC,oBAfjD;cAAA,eAgBcf,CAAD,IAAmBA,CAAC,CAACkD,cAAF;YAhBhC;cAAA,gBAkBC,CAAClC,aAAa,CAACC,KAAd,CAAoB9B,MAArB,IAA+B,CAACO,KAAK,CAACkC,UAAtC,wCAAqDzB,KAAK,CAAC,SAAD,CAA1D,qBAAqD,oBAAAA,KAAK,CAA1D;gBAAA,SACmBC,CAAC,CAACV,KAAK,CAACyD,UAAP;cADpB,SAlBD,EAsBCnC,aAAa,CAACC,KAAd,CAAoBG,GAApB,CAAwB;gBAAA;;gBAAA,IAAC;kBAAEE,IAAF;kBAAQpC;gBAAR,CAAD;gBAAA,sCAAuBiB,KAAK,CAACmB,IAA7B,qBAAuB,kBAAAnB,KAAK,EAAQ;kBAC5DmB,IAD4D;kBAE5D5B,KAAK,EAAEjB,UAAU,CAAC6C,IAAI,CAAC5B,KAAN,EAAa;oBAAE0D,OAAO,EAAE,MAAMhB,MAAM,CAACd,IAAD;kBAAvB,CAAb;gBAF2C,CAAR,CAA5B,8DAKjBA,IAAI,CAAC5B,KALY;kBAAA,WAMZ,MAAM0C,MAAM,CAACd,IAAD;gBANA;kBASpB+B,OAAO,EAAE;oBAAA,IAAC;sBAAEC;oBAAF,CAAD;oBAAA,OAAoB5D,KAAK,CAACqB,QAAN;sBAAA,cACAuC,UADA;sBAAA,UACsB;oBADtB,WAEzBpC,SAFK;kBAAA,CATW;kBAYpBsB,KAAK,EAAE,MAAM;oBAAA;;oBACX,OAAOjC,UAAU,CAACU,KAAX,GACHK,IAAI,CAACkB,KADF,GAEHxD,eAAe,CAACsC,IAAI,CAACkB,KAAN,EAAatD,OAAO,CAACsD,KAArB,2CAA4B7C,MAAM,CAACsB,KAAnC,qBAA4B,cAAc9B,MAA1C,mCAAoD,CAApD,CAFnB;kBAGD;gBAhBmB;cAAA,CAAxB,CAtBD;YAAA;UAAA,IA6CHgC,UAAU,CAACF,KAAX,CAAiBG,GAAjB,CAAqB,CAACE,IAAD,EAAOe,KAAP,KAAiB;YACtC,SAASkB,WAAT,CAAsBvD,CAAtB,EAAgC;cAC9BA,CAAC,CAACwD,eAAF;cACAxD,CAAC,CAACkD,cAAF;cAEAd,MAAM,CAACd,IAAD,CAAN;YACD;;YAED,MAAMmC,SAAS,GAAG;cAChB,iBAAiBF,WADD;cAEhBV,UAAU,EAAE;YAFI,CAAlB;YAKA;cAAA,SACa;YADb,IAEMH,QAAQ;cAAA,YAEI;gBACR/E,KAAK,EAAE;kBACL+F,QAAQ,EAAEhE,KAAK,CAACiE,aADX;kBAELC,IAAI,EAAE,OAFD;kBAGL3E,IAAI,EAAEqC,IAAI,CAACkB;gBAHN;cADC;YAFJ;cAAA,gBAUJrC,KAAK,CAACyC,IAAN,GACEzC,KAAK,CAACyC,IAAN,CAAW;gBAAElD,KAAK,EAAE+D,SAAT;gBAAoBnC,IAApB;gBAA0Be;cAA1B,CAAX,CADF,uBAEeoB,SAFf,OAVI;YAAA,KAgBRtD,KAAK,CAACqB,SAAN,GACIrB,KAAK,CAACqB,SAAN,CAAgB;cAAEF,IAAF;cAAQe;YAAR,CAAhB,CADJ;cAAA,SAGgB;YAHhB,IAIQf,IAAI,CAACkB,KAJb,EAKQ9C,KAAK,CAACqB,QAAN,IAAmBsB,KAAK,GAAGlB,UAAU,CAACF,KAAX,CAAiB9B,MAAjB,GAA0B,CAArD;cAAA,SACY;YADZ,2BALR,EAlBN;UA+BD,CA5CC,CA7CG;QAAA;MAzBf;IAwHD,CA3HQ,CAAT;IA6HA,OAAOd,aAAa,CAAC;MACnBiC,SADmB;MAEnBC,UAFmB;MAGnBC,IAHmB;MAInBb,MAJmB;MAKnBqB,aALmB;MAMnBoB;IANmB,CAAD,EAOjB/B,aAPiB,CAApB;EAQD;;AAvQE,CAlBwC,CAAtC"}
@@ -1,10 +1,8 @@
1
- @forward './variables'
2
1
  @use 'sass:selector'
3
2
  @use 'sass:math'
4
3
  @use '../../styles/settings'
5
4
  @use '../../styles/tools'
6
5
  @use './variables' as *
7
- @use '../VInput/variables' as *
8
6
 
9
7
  .v-autocomplete
10
8
  .v-field
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAutocomplete/index.ts"],"names":["VAutocomplete"],"mappings":"SAASA,a","sourcesContent":["export { VAutocomplete } from './VAutocomplete'\n"],"file":"index.mjs"}
1
+ {"version":3,"file":"index.mjs","names":["VAutocomplete"],"sources":["../../../src/components/VAutocomplete/index.ts"],"sourcesContent":["export { VAutocomplete } from './VAutocomplete'\n"],"mappings":"SAASA,a"}
@@ -39,5 +39,5 @@
39
39
  width: calc(var(--v-avatar-height) + -8px);
40
40
  }
41
41
  .v-avatar--rounded {
42
- @includes tools.rounded($avatar-rounded-border-radius);
42
+ border-radius: 4px;
43
43
  }
@@ -9,23 +9,25 @@ import { makeDensityProps, useDensity } from "../../composables/density.mjs";
9
9
  import { makeRoundedProps, useRounded } from "../../composables/rounded.mjs";
10
10
  import { makeSizeProps, useSize } from "../../composables/size.mjs";
11
11
  import { makeTagProps } from "../../composables/tag.mjs";
12
- import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
12
+ import { useBackgroundColor } from "../../composables/color.mjs";
13
+ import { IconValue } from "../../composables/icons.mjs"; // Utilities
13
14
 
14
- import { defineComponent, useRender } from "../../util/index.mjs";
15
+ import { defineComponent, propsFactory, useRender } from "../../util/index.mjs";
15
16
  import { toRef } from 'vue';
17
+ export const makeVAvatarProps = propsFactory({
18
+ color: String,
19
+ start: Boolean,
20
+ end: Boolean,
21
+ icon: IconValue,
22
+ image: String,
23
+ ...makeDensityProps(),
24
+ ...makeRoundedProps(),
25
+ ...makeSizeProps(),
26
+ ...makeTagProps()
27
+ });
16
28
  export const VAvatar = defineComponent({
17
29
  name: 'VAvatar',
18
- props: {
19
- color: String,
20
- left: Boolean,
21
- right: Boolean,
22
- icon: String,
23
- image: String,
24
- ...makeDensityProps(),
25
- ...makeRoundedProps(),
26
- ...makeSizeProps(),
27
- ...makeTagProps()
28
- },
30
+ props: makeVAvatarProps(),
29
31
 
30
32
  setup(props, _ref) {
31
33
  let {
@@ -50,8 +52,8 @@ export const VAvatar = defineComponent({
50
52
 
51
53
  return _createVNode(props.tag, {
52
54
  "class": ['v-avatar', {
53
- 'v-avatar--left': props.left,
54
- 'v-avatar--right': props.right
55
+ 'v-avatar--start': props.start,
56
+ 'v-avatar--end': props.end
55
57
  }, backgroundColorClasses.value, densityClasses.value, roundedClasses.value, sizeClasses.value],
56
58
  "style": [backgroundColorStyles.value, sizeStyles.value]
57
59
  }, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAvatar/VAvatar.tsx"],"names":["VIcon","VImg","makeDensityProps","useDensity","makeRoundedProps","useRounded","makeSizeProps","useSize","makeTagProps","useBackgroundColor","defineComponent","useRender","toRef","VAvatar","name","props","color","String","left","Boolean","right","icon","image","setup","slots","backgroundColorClasses","backgroundColorStyles","densityClasses","roundedClasses","sizeClasses","sizeStyles","value","default"],"mappings":";AAAA;AACA,uB,CAEA;;SACSA,K;SACAC,I,6BAET;;SACSC,gB,EAAkBC,U;SAClBC,gB,EAAkBC,U;SAClBC,a,EAAeC,O;SACfC,Y;SACAC,kB,uCAET;;SACSC,e,EAAiBC,S;AAC1B,SAASC,KAAT,QAAsB,KAAtB;AAEA,OAAO,MAAMC,OAAO,GAAGH,eAAe,CAAC;AACrCI,EAAAA,IAAI,EAAE,SAD+B;AAGrCC,EAAAA,KAAK,EAAE;AACLC,IAAAA,KAAK,EAAEC,MADF;AAELC,IAAAA,IAAI,EAAEC,OAFD;AAGLC,IAAAA,KAAK,EAAED,OAHF;AAILE,IAAAA,IAAI,EAAEJ,MAJD;AAKLK,IAAAA,KAAK,EAAEL,MALF;AAOL,OAAGf,gBAAgB,EAPd;AAQL,OAAGE,gBAAgB,EARd;AASL,OAAGE,aAAa,EATX;AAUL,OAAGE,YAAY;AAVV,GAH8B;;AAgBrCe,EAAAA,KAAK,CAAER,KAAF,QAAoB;AAAA,QAAX;AAAES,MAAAA;AAAF,KAAW;AACvB,UAAM;AAAEC,MAAAA,sBAAF;AAA0BC,MAAAA;AAA1B,QAAoDjB,kBAAkB,CAACG,KAAK,CAACG,KAAD,EAAQ,OAAR,CAAN,CAA5E;AACA,UAAM;AAAEY,MAAAA;AAAF,QAAqBxB,UAAU,CAACY,KAAD,CAArC;AACA,UAAM;AAAEa,MAAAA;AAAF,QAAqBvB,UAAU,CAACU,KAAD,CAArC;AACA,UAAM;AAAEc,MAAAA,WAAF;AAAeC,MAAAA;AAAf,QAA8BvB,OAAO,CAACQ,KAAD,CAA3C;AAEAJ,IAAAA,SAAS,CAAC;AAAA;;AAAA;AAAA,iBAEC,CACL,UADK,EAEL;AACE,4BAAkBI,KAAK,CAACG,IAD1B;AAEE,6BAAmBH,KAAK,CAACK;AAF3B,SAFK,EAMLK,sBAAsB,CAACM,KANlB,EAOLJ,cAAc,CAACI,KAPV,EAQLH,cAAc,CAACG,KARV,EASLF,WAAW,CAACE,KATP,CAFD;AAAA,iBAaC,CACLL,qBAAqB,CAACK,KADjB,EAELD,UAAU,CAACC,KAFN;AAbD;AAAA,wBAmBJhB,KAAK,CAACO,KAAN;AAAA,iBACeP,KAAK,CAACO,KADrB;AAAA,iBACiC;AADjC,mBAEEP,KAAK,CAACM,IAAN;AAAA,kBACiBN,KAAK,CAACM;AADvB,qCAEEG,KAAK,CAACQ,OAFR,qBAEE,oBAAAR,KAAK,CAvBL;AAAA;AAAA,KAAD,CAAT;AA4BA,WAAO,EAAP;AACD;;AAnDoC,CAAD,CAA/B","sourcesContent":["// Styles\nimport './VAvatar.sass'\n\n// Components\nimport { VIcon } from '@/components/VIcon'\nimport { VImg } from '@/components/VImg'\n\n// Composables\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Utilities\nimport { defineComponent, useRender } from '@/util'\nimport { toRef } from 'vue'\n\nexport const VAvatar = defineComponent({\n name: 'VAvatar',\n\n props: {\n color: String,\n left: Boolean,\n right: Boolean,\n icon: String,\n image: String,\n\n ...makeDensityProps(),\n ...makeRoundedProps(),\n ...makeSizeProps(),\n ...makeTagProps(),\n },\n\n setup (props, { slots }) {\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const { densityClasses } = useDensity(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses, sizeStyles } = useSize(props)\n\n useRender(() => (\n <props.tag\n class={[\n 'v-avatar',\n {\n 'v-avatar--left': props.left,\n 'v-avatar--right': props.right,\n },\n backgroundColorClasses.value,\n densityClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n ]}\n style={[\n backgroundColorStyles.value,\n sizeStyles.value,\n ]}\n >\n\n { props.image\n ? (<VImg src={ props.image } alt=\"\" />)\n : props.icon\n ? (<VIcon icon={ props.icon } />)\n : slots.default?.()\n }\n </props.tag>\n ))\n\n return {}\n },\n})\n\nexport type VAvatar = InstanceType<typeof VAvatar>\n"],"file":"VAvatar.mjs"}
1
+ {"version":3,"file":"VAvatar.mjs","names":["VIcon","VImg","makeDensityProps","useDensity","makeRoundedProps","useRounded","makeSizeProps","useSize","makeTagProps","useBackgroundColor","IconValue","defineComponent","propsFactory","useRender","toRef","makeVAvatarProps","color","String","start","Boolean","end","icon","image","VAvatar","name","props","setup","slots","backgroundColorClasses","backgroundColorStyles","densityClasses","roundedClasses","sizeClasses","sizeStyles","value","default"],"sources":["../../../src/components/VAvatar/VAvatar.tsx"],"sourcesContent":["// Styles\nimport './VAvatar.sass'\n\n// Components\nimport { VIcon } from '@/components/VIcon'\nimport { VImg } from '@/components/VImg'\n\n// Composables\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { useBackgroundColor } from '@/composables/color'\nimport { IconValue } from '@/composables/icons'\n\n// Utilities\nimport { defineComponent, propsFactory, useRender } from '@/util'\nimport { toRef } from 'vue'\n\nexport const makeVAvatarProps = propsFactory({\n color: String,\n start: Boolean,\n end: Boolean,\n icon: IconValue,\n image: String,\n\n ...makeDensityProps(),\n ...makeRoundedProps(),\n ...makeSizeProps(),\n ...makeTagProps(),\n})\n\nexport const VAvatar = defineComponent({\n name: 'VAvatar',\n\n props: makeVAvatarProps(),\n\n setup (props, { slots }) {\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const { densityClasses } = useDensity(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses, sizeStyles } = useSize(props)\n\n useRender(() => (\n <props.tag\n class={[\n 'v-avatar',\n {\n 'v-avatar--start': props.start,\n 'v-avatar--end': props.end,\n },\n backgroundColorClasses.value,\n densityClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n ]}\n style={[\n backgroundColorStyles.value,\n sizeStyles.value,\n ]}\n >\n\n { props.image\n ? (<VImg src={ props.image } alt=\"\" />)\n : props.icon\n ? (<VIcon icon={ props.icon } />)\n : slots.default?.()\n }\n </props.tag>\n ))\n\n return {}\n },\n})\n\nexport type VAvatar = InstanceType<typeof VAvatar>\n"],"mappings":";AAAA;AACA,uB,CAEA;;SACSA,K;SACAC,I,6BAET;;SACSC,gB,EAAkBC,U;SAClBC,gB,EAAkBC,U;SAClBC,a,EAAeC,O;SACfC,Y;SACAC,kB;SACAC,S,uCAET;;SACSC,e,EAAiBC,Y,EAAcC,S;AACxC,SAASC,KAAT,QAAsB,KAAtB;AAEA,OAAO,MAAMC,gBAAgB,GAAGH,YAAY,CAAC;EAC3CI,KAAK,EAAEC,MADoC;EAE3CC,KAAK,EAAEC,OAFoC;EAG3CC,GAAG,EAAED,OAHsC;EAI3CE,IAAI,EAAEX,SAJqC;EAK3CY,KAAK,EAAEL,MALoC;EAO3C,GAAGf,gBAAgB,EAPwB;EAQ3C,GAAGE,gBAAgB,EARwB;EAS3C,GAAGE,aAAa,EAT2B;EAU3C,GAAGE,YAAY;AAV4B,CAAD,CAArC;AAaP,OAAO,MAAMe,OAAO,GAAGZ,eAAe,CAAC;EACrCa,IAAI,EAAE,SAD+B;EAGrCC,KAAK,EAAEV,gBAAgB,EAHc;;EAKrCW,KAAK,CAAED,KAAF,QAAoB;IAAA,IAAX;MAAEE;IAAF,CAAW;IACvB,MAAM;MAAEC,sBAAF;MAA0BC;IAA1B,IAAoDpB,kBAAkB,CAACK,KAAK,CAACW,KAAD,EAAQ,OAAR,CAAN,CAA5E;IACA,MAAM;MAAEK;IAAF,IAAqB3B,UAAU,CAACsB,KAAD,CAArC;IACA,MAAM;MAAEM;IAAF,IAAqB1B,UAAU,CAACoB,KAAD,CAArC;IACA,MAAM;MAAEO,WAAF;MAAeC;IAAf,IAA8B1B,OAAO,CAACkB,KAAD,CAA3C;IAEAZ,SAAS,CAAC;MAAA;;MAAA;QAAA,SAEC,CACL,UADK,EAEL;UACE,mBAAmBY,KAAK,CAACP,KAD3B;UAEE,iBAAiBO,KAAK,CAACL;QAFzB,CAFK,EAMLQ,sBAAsB,CAACM,KANlB,EAOLJ,cAAc,CAACI,KAPV,EAQLH,cAAc,CAACG,KARV,EASLF,WAAW,CAACE,KATP,CAFD;QAAA,SAaC,CACLL,qBAAqB,CAACK,KADjB,EAELD,UAAU,CAACC,KAFN;MAbD;QAAA,gBAmBJT,KAAK,CAACH,KAAN;UAAA,OACeG,KAAK,CAACH,KADrB;UAAA,OACiC;QADjC,WAEEG,KAAK,CAACJ,IAAN;UAAA,QACiBI,KAAK,CAACJ;QADvB,6BAEEM,KAAK,CAACQ,OAFR,qBAEE,oBAAAR,KAAK,CAvBL;MAAA;IAAA,CAAD,CAAT;IA4BA,OAAO,EAAP;EACD;;AAxCoC,CAAD,CAA/B"}
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './mixins' as *
4
3
  @use './variables' as *
@@ -19,4 +18,4 @@
19
18
  @include tools.theme($avatar-theme...)
20
19
 
21
20
  &--rounded
22
- @includes tools.rounded($avatar-rounded-border-radius)
21
+ @include tools.rounded($avatar-rounded-border-radius)
@@ -1,4 +1,3 @@
1
- @forward './variables';
2
1
  @use 'sass:map';
3
2
  @use 'sass:meta';
4
3
  @use '../../styles/settings';
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/VAvatar/index.ts"],"names":["VAvatar"],"mappings":"SAASA,O","sourcesContent":["export { VAvatar } from './VAvatar'\n"],"file":"index.mjs"}
1
+ {"version":3,"file":"index.mjs","names":["VAvatar"],"sources":["../../../src/components/VAvatar/index.ts"],"sourcesContent":["export { VAvatar } from './VAvatar'\n"],"mappings":"SAASA,O"}
@@ -6,13 +6,12 @@
6
6
  .v-badge__badge {
7
7
  align-items: center;
8
8
  border-radius: 10px;
9
- display: flex;
10
9
  font-size: 0.75rem;
11
10
  font-weight: 500;
12
11
  height: 1.25rem;
13
12
  justify-content: center;
14
13
  min-width: 20px;
15
- padding: 4px;
14
+ padding: 4px 6px;
16
15
  pointer-events: auto;
17
16
  position: absolute;
18
17
  text-align: center;
@@ -51,6 +50,8 @@
51
50
  }
52
51
  .v-badge__badge .v-icon {
53
52
  color: inherit;
53
+ font-size: 0.75rem;
54
+ margin: 0 -2px;
54
55
  }
55
56
  .v-badge__badge img,
56
57
  .v-badge__badge .v-img {
@@ -58,10 +59,6 @@
58
59
  width: 100%;
59
60
  }
60
61
 
61
- .v-badge__content {
62
- padding: 0 2px;
63
- }
64
-
65
62
  .v-badge__wrapper {
66
63
  display: flex;
67
64
  position: relative;