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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (277) hide show
  1. package/CHANGELOG.md +53 -2
  2. package/dist/json/attributes.json +343 -195
  3. package/dist/json/importMap.json +20 -0
  4. package/dist/json/tags.json +106 -44
  5. package/dist/json/web-types.json +946 -549
  6. package/dist/vuetify.css +1486 -1085
  7. package/dist/vuetify.d.ts +9036 -8077
  8. package/dist/vuetify.esm.js +1511 -944
  9. package/dist/vuetify.esm.js.map +1 -1
  10. package/dist/vuetify.js +1510 -943
  11. package/dist/vuetify.js.map +1 -1
  12. package/dist/vuetify.min.css +3 -3
  13. package/dist/vuetify.min.js +825 -754
  14. package/dist/vuetify.min.js.map +1 -1
  15. package/lib/components/VAlert/VAlert.css +29 -8
  16. package/lib/components/VAlert/VAlert.mjs +31 -17
  17. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  18. package/lib/components/VAlert/VAlert.sass +27 -7
  19. package/lib/components/VAlert/VAlertTitle.mjs +1 -0
  20. package/lib/components/VAlert/VAlertTitle.mjs.map +1 -1
  21. package/lib/components/VAlert/_variables.scss +14 -7
  22. package/lib/components/VApp/VApp.css +1 -0
  23. package/lib/components/VApp/VApp.sass +1 -0
  24. package/lib/components/VAppBar/VAppBar.mjs +7 -3
  25. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  26. package/lib/components/VAppBar/VAppBarTitle.mjs.map +1 -1
  27. package/lib/components/VAutocomplete/VAutocomplete.mjs +82 -69
  28. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  29. package/lib/components/VAvatar/VAvatar.mjs +15 -14
  30. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  31. package/lib/components/VBanner/VBanner.css +82 -58
  32. package/lib/components/VBanner/VBanner.mjs +39 -43
  33. package/lib/components/VBanner/VBanner.mjs.map +1 -1
  34. package/lib/components/VBanner/VBanner.sass +61 -54
  35. package/lib/components/VBanner/VBannerActions.mjs +34 -2
  36. package/lib/components/VBanner/VBannerActions.mjs.map +1 -1
  37. package/lib/components/VBanner/VBannerAvatar.mjs +20 -0
  38. package/lib/components/VBanner/VBannerAvatar.mjs.map +1 -0
  39. package/lib/components/VBanner/VBannerIcon.mjs +20 -0
  40. package/lib/components/VBanner/VBannerIcon.mjs.map +1 -0
  41. package/lib/components/VBanner/_variables.scss +10 -14
  42. package/lib/components/VBanner/index.mjs +2 -0
  43. package/lib/components/VBanner/index.mjs.map +1 -1
  44. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +2 -0
  45. package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
  46. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +10 -9
  47. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  48. package/lib/components/VBtn/VBtn.css +20 -1
  49. package/lib/components/VBtn/VBtn.mjs +20 -7
  50. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  51. package/lib/components/VBtn/VBtn.sass +15 -2
  52. package/lib/components/VBtn/_variables.scss +3 -0
  53. package/lib/components/VBtnGroup/VBtnGroup.css +14 -6
  54. package/lib/components/VBtnGroup/VBtnGroup.sass +14 -6
  55. package/lib/components/VCard/VCard.css +13 -11
  56. package/lib/components/VCard/VCard.mjs +5 -2
  57. package/lib/components/VCard/VCard.mjs.map +1 -1
  58. package/lib/components/VCard/VCard.sass +12 -9
  59. package/lib/components/VCard/VCardActions.mjs +1 -2
  60. package/lib/components/VCard/VCardActions.mjs.map +1 -1
  61. package/lib/components/VCard/VCardContent.mjs +3 -0
  62. package/lib/components/VCard/VCardContent.mjs.map +1 -0
  63. package/lib/components/VCard/_variables.scss +11 -5
  64. package/lib/components/VCard/index.mjs +1 -0
  65. package/lib/components/VCard/index.mjs.map +1 -1
  66. package/lib/components/VCarousel/VCarousel.mjs +1 -1
  67. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  68. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  69. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  70. package/lib/components/VChip/VChip.css +3 -0
  71. package/lib/components/VChip/VChip.sass +3 -0
  72. package/lib/components/VChip/_variables.scss +3 -0
  73. package/lib/components/VColorPicker/VColorPickerCanvas.css +1 -1
  74. package/lib/components/VCombobox/VCombobox.mjs +92 -74
  75. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  76. package/lib/components/VDialog/VDialog.css +31 -11
  77. package/lib/components/VDialog/VDialog.mjs +6 -9
  78. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  79. package/lib/components/VDialog/VDialog.sass +27 -10
  80. package/lib/components/VDialog/_variables.scss +3 -6
  81. package/lib/components/VExpansionPanel/VExpansionPanel.css +3 -2
  82. package/lib/components/VExpansionPanel/VExpansionPanel.mjs +6 -2
  83. package/lib/components/VExpansionPanel/VExpansionPanel.mjs.map +1 -1
  84. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs +5 -3
  85. package/lib/components/VExpansionPanel/VExpansionPanelTitle.mjs.map +1 -1
  86. package/lib/components/VExpansionPanel/VExpansionPanels.mjs +4 -0
  87. package/lib/components/VExpansionPanel/VExpansionPanels.mjs.map +1 -1
  88. package/lib/components/VField/VField.css +1 -1
  89. package/lib/components/VField/VField.mjs +3 -4
  90. package/lib/components/VField/VField.mjs.map +1 -1
  91. package/lib/components/VField/VField.sass +1 -1
  92. package/lib/components/VFileInput/VFileInput.mjs +2 -1
  93. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  94. package/lib/components/VFooter/VFooter.mjs +32 -15
  95. package/lib/components/VFooter/VFooter.mjs.map +1 -1
  96. package/lib/components/VForm/VForm.mjs +25 -11
  97. package/lib/components/VForm/VForm.mjs.map +1 -1
  98. package/lib/components/VIcon/VIcon.css +27 -12
  99. package/lib/components/VIcon/VIcon.mjs +19 -16
  100. package/lib/components/VIcon/VIcon.mjs.map +1 -1
  101. package/lib/components/VIcon/VIcon.sass +27 -16
  102. package/lib/components/VIcon/_variables.scss +1 -0
  103. package/lib/components/VInput/VInput.css +3 -1
  104. package/lib/components/VInput/VInput.mjs +3 -4
  105. package/lib/components/VInput/VInput.mjs.map +1 -1
  106. package/lib/components/VInput/VInput.sass +3 -1
  107. package/lib/components/VInput/_variables.scss +4 -0
  108. package/lib/components/VList/VList.css +7 -6
  109. package/lib/components/VList/VList.mjs +36 -17
  110. package/lib/components/VList/VList.mjs.map +1 -1
  111. package/lib/components/VList/VList.sass +3 -2
  112. package/lib/components/VList/VListChildren.mjs +1 -1
  113. package/lib/components/VList/VListChildren.mjs.map +1 -1
  114. package/lib/components/VList/VListGroup.mjs +28 -10
  115. package/lib/components/VList/VListGroup.mjs.map +1 -1
  116. package/lib/components/VList/VListItem.css +119 -42
  117. package/lib/components/VList/VListItem.mjs +36 -32
  118. package/lib/components/VList/VListItem.mjs.map +1 -1
  119. package/lib/components/VList/VListItem.sass +76 -28
  120. package/lib/components/VList/VListItemAction.mjs +29 -0
  121. package/lib/components/VList/VListItemAction.mjs.map +1 -0
  122. package/lib/components/VList/VListItemAvatar.mjs +10 -16
  123. package/lib/components/VList/VListItemAvatar.mjs.map +1 -1
  124. package/lib/components/VList/VListItemIcon.mjs +23 -0
  125. package/lib/components/VList/VListItemIcon.mjs.map +1 -0
  126. package/lib/components/VList/VListItemMedia.mjs +4 -4
  127. package/lib/components/VList/VListItemMedia.mjs.map +1 -1
  128. package/lib/components/VList/_variables.scss +12 -3
  129. package/lib/components/VList/index.mjs +2 -0
  130. package/lib/components/VList/index.mjs.map +1 -1
  131. package/lib/components/VMenu/VMenu.css +2 -12
  132. package/lib/components/VMenu/VMenu.mjs +61 -31
  133. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  134. package/lib/components/VMenu/VMenu.sass +3 -6
  135. package/lib/components/VMenu/shared.mjs +2 -0
  136. package/lib/components/VMenu/shared.mjs.map +1 -0
  137. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +1 -1
  138. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  139. package/lib/components/VOverlay/VOverlay.css +8 -0
  140. package/lib/components/VOverlay/VOverlay.mjs +16 -15
  141. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  142. package/lib/components/VOverlay/VOverlay.sass +9 -0
  143. package/lib/components/VOverlay/_variables.scss +1 -0
  144. package/lib/components/VOverlay/positionStrategies.mjs +7 -3
  145. package/lib/components/VOverlay/positionStrategies.mjs.map +1 -1
  146. package/lib/components/VOverlay/scrollStrategies.mjs +9 -0
  147. package/lib/components/VOverlay/scrollStrategies.mjs.map +1 -1
  148. package/lib/components/VOverlay/useActivator.mjs +50 -14
  149. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  150. package/lib/components/VPagination/VPagination.mjs +10 -12
  151. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  152. package/lib/components/VProgressLinear/VProgressLinear.css +1 -1
  153. package/lib/components/VRadio/VRadio.mjs +1 -2
  154. package/lib/components/VRadio/VRadio.mjs.map +1 -1
  155. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -2
  156. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  157. package/lib/components/VRangeSlider/VRangeSlider.mjs +5 -2
  158. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  159. package/lib/components/VRating/VRating.css +2 -2
  160. package/lib/components/VRating/VRating.mjs +13 -3
  161. package/lib/components/VRating/VRating.mjs.map +1 -1
  162. package/lib/components/VRating/VRating.sass +2 -2
  163. package/lib/components/VSelect/VSelect.mjs +70 -91
  164. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  165. package/lib/components/VSelectionControl/VSelectionControl.mjs +2 -1
  166. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  167. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +2 -2
  168. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  169. package/lib/components/VSlideGroup/VSlideGroup.css +0 -5
  170. package/lib/components/VSlideGroup/VSlideGroup.mjs +36 -14
  171. package/lib/components/VSlideGroup/VSlideGroup.mjs.map +1 -1
  172. package/lib/components/VSlideGroup/VSlideGroup.sass +0 -4
  173. package/lib/components/VSlideGroup/VSlideGroupItem.mjs +3 -1
  174. package/lib/components/VSlideGroup/VSlideGroupItem.mjs.map +1 -1
  175. package/lib/components/VSlider/VSlider.css +7 -2
  176. package/lib/components/VSlider/VSlider.sass +11 -5
  177. package/lib/components/VSlider/VSliderTrack.css +6 -6
  178. package/lib/components/VSlider/VSliderTrack.mjs +1 -1
  179. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  180. package/lib/components/VSlider/VSliderTrack.sass +7 -7
  181. package/lib/components/VSlider/_variables.scss +5 -2
  182. package/lib/components/VSnackbar/VSnackbar.css +14 -13
  183. package/lib/components/VSnackbar/VSnackbar.mjs +22 -10
  184. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  185. package/lib/components/VSnackbar/VSnackbar.sass +15 -16
  186. package/lib/components/VSnackbar/_variables.scss +0 -4
  187. package/lib/components/VSwitch/VSwitch.mjs +8 -5
  188. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  189. package/lib/components/VSystemBar/VSystemBar.css +0 -5
  190. package/lib/components/VSystemBar/VSystemBar.mjs +31 -14
  191. package/lib/components/VSystemBar/VSystemBar.mjs.map +1 -1
  192. package/lib/components/VSystemBar/VSystemBar.sass +0 -5
  193. package/lib/components/VSystemBar/_variables.scss +0 -3
  194. package/lib/components/VTabs/VTab.mjs +28 -32
  195. package/lib/components/VTabs/VTab.mjs.map +1 -1
  196. package/lib/components/VTabs/VTabs.css +6 -2
  197. package/lib/components/VTabs/VTabs.mjs +7 -8
  198. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  199. package/lib/components/VTabs/VTabs.sass +6 -1
  200. package/lib/components/VTabs/shared.mjs +2 -0
  201. package/lib/components/VTabs/shared.mjs.map +1 -0
  202. package/lib/components/VTextField/VTextField.css +4 -4
  203. package/lib/components/VTextField/VTextField.mjs +5 -9
  204. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  205. package/lib/components/VTextField/VTextField.sass +5 -5
  206. package/lib/components/VTextarea/VTextarea.css +7 -4
  207. package/lib/components/VTextarea/VTextarea.sass +9 -5
  208. package/lib/components/VTimeline/VTimeline.css +187 -48
  209. package/lib/components/VTimeline/VTimeline.mjs +27 -11
  210. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  211. package/lib/components/VTimeline/VTimeline.sass +196 -51
  212. package/lib/components/VTimeline/VTimelineDivider.mjs +2 -1
  213. package/lib/components/VTimeline/VTimelineDivider.mjs.map +1 -1
  214. package/lib/components/VTimeline/_variables.scss +2 -1
  215. package/lib/components/VToolbar/VToolbar.css +8 -1
  216. package/lib/components/VToolbar/VToolbar.mjs +8 -11
  217. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  218. package/lib/components/VToolbar/VToolbar.sass +2 -1
  219. package/lib/components/VToolbar/VToolbarItems.mjs +0 -1
  220. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  221. package/lib/components/VToolbar/_variables.scss +13 -1
  222. package/lib/components/VWindow/VWindow.mjs +0 -8
  223. package/lib/components/VWindow/VWindow.mjs.map +1 -1
  224. package/lib/components/index.d.ts +9025 -8077
  225. package/lib/composables/defaults.mjs +2 -2
  226. package/lib/composables/defaults.mjs.map +1 -1
  227. package/lib/composables/form.mjs +18 -5
  228. package/lib/composables/form.mjs.map +1 -1
  229. package/lib/composables/forwardRef.mjs +10 -6
  230. package/lib/composables/forwardRef.mjs.map +1 -1
  231. package/lib/composables/group.mjs +14 -6
  232. package/lib/composables/group.mjs.map +1 -1
  233. package/lib/composables/index.mjs.map +1 -1
  234. package/lib/composables/items.mjs +56 -0
  235. package/lib/composables/items.mjs.map +1 -0
  236. package/lib/composables/layout.mjs +7 -3
  237. package/lib/composables/layout.mjs.map +1 -1
  238. package/lib/composables/loader.mjs.map +1 -1
  239. package/lib/composables/nested/nested.mjs +27 -14
  240. package/lib/composables/nested/nested.mjs.map +1 -1
  241. package/lib/composables/nested/openStrategies.mjs +63 -36
  242. package/lib/composables/nested/openStrategies.mjs.map +1 -1
  243. package/lib/composables/nested/selectStrategies.mjs +163 -122
  244. package/lib/composables/nested/selectStrategies.mjs.map +1 -1
  245. package/lib/composables/overlay.mjs +5 -1
  246. package/lib/composables/overlay.mjs.map +1 -1
  247. package/lib/composables/proxiedModel.mjs.map +1 -1
  248. package/lib/composables/resizeObserver.mjs +1 -9
  249. package/lib/composables/resizeObserver.mjs.map +1 -1
  250. package/lib/composables/router.mjs +17 -5
  251. package/lib/composables/router.mjs.map +1 -1
  252. package/lib/composables/selectLink.mjs +19 -0
  253. package/lib/composables/selectLink.mjs.map +1 -0
  254. package/lib/composables/stack.mjs +7 -4
  255. package/lib/composables/stack.mjs.map +1 -1
  256. package/lib/composables/validation.mjs +6 -3
  257. package/lib/composables/validation.mjs.map +1 -1
  258. package/lib/composables/variant.mjs +0 -3
  259. package/lib/composables/variant.mjs.map +1 -1
  260. package/lib/directives/ripple/index.mjs +15 -3
  261. package/lib/directives/ripple/index.mjs.map +1 -1
  262. package/lib/entry-bundler.mjs +1 -1
  263. package/lib/framework.mjs +12 -7
  264. package/lib/framework.mjs.map +1 -1
  265. package/lib/index.d.ts +18 -2
  266. package/lib/locale/ca.mjs +9 -9
  267. package/lib/locale/ca.mjs.map +1 -1
  268. package/lib/styles/generic/_colors.scss +0 -1
  269. package/lib/styles/main.css +400 -392
  270. package/lib/styles/settings/_utilities.scss +54 -26
  271. package/lib/styles/tools/_states.sass +2 -1
  272. package/lib/util/defineComponent.mjs +37 -6
  273. package/lib/util/defineComponent.mjs.map +1 -1
  274. package/lib/util/getCurrentInstance.mjs +1 -1
  275. package/lib/util/getCurrentInstance.mjs.map +1 -1
  276. package/lib/util/helpers.mjs.map +1 -1
  277. package/package.json +31 -29
@@ -2,7 +2,7 @@ import { createTextVNode as _createTextVNode, createVNode as _createVNode, Fragm
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
6
  import { VChip } from "../VChip/index.mjs";
7
7
  import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
8
8
  import { VList, VListItem } from "../VList/index.mjs";
@@ -11,6 +11,7 @@ import { VTextField } from "../VTextField/index.mjs"; // Composables
11
11
 
12
12
  import { makeFilterProps, useFilter } from "../../composables/filter.mjs";
13
13
  import { makeTransitionProps } from "../../composables/transition.mjs";
14
+ import { transformItem, useItems } from "../../composables/items.mjs";
14
15
  import { useForwardRef } from "../../composables/forwardRef.mjs";
15
16
  import { useLocale } from "../../composables/locale.mjs";
16
17
  import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utility
@@ -61,7 +62,9 @@ export const VAutocomplete = genericComponent()({
61
62
  const isFocused = ref(false);
62
63
  const isPristine = ref(true);
63
64
  const menu = ref(false);
64
- const items = computed(() => props.items.map(genItem));
65
+ const {
66
+ items
67
+ } = useItems(props);
65
68
  const search = useProxiedModel(props, 'search', '');
66
69
  const model = useProxiedModel(props, 'modelValue', [], v => wrapInArray(v || []), v => props.multiple ? v : v[0]);
67
70
  const {
@@ -72,7 +75,7 @@ export const VAutocomplete = genericComponent()({
72
75
  let index = 0;
73
76
 
74
77
  for (const unwrapped of model.value) {
75
- const item = genItem(unwrapped);
78
+ const item = transformItem(props, unwrapped);
76
79
  const found = array.find(selection => selection.value === item.value);
77
80
 
78
81
  if (found == null) {
@@ -116,6 +119,10 @@ export const VAutocomplete = genericComponent()({
116
119
  }
117
120
  }
118
121
 
122
+ function onInput(e) {
123
+ search.value = e.target.value;
124
+ }
125
+
119
126
  function onAfterLeave() {
120
127
  if (isFocused.value) isPristine.value = true;
121
128
  }
@@ -124,12 +131,14 @@ export const VAutocomplete = genericComponent()({
124
131
 
125
132
  function select(item) {
126
133
  if (props.multiple) {
127
- const index = selections.value.findIndex(selection => selection.value === item.value);
134
+ const index = selected.value.findIndex(selection => selection === item.value);
128
135
 
129
136
  if (index === -1) {
130
- model.value.push(item.value);
137
+ model.value = [...model.value, item.value];
131
138
  } else {
132
- model.value = selected.value.filter(selection => selection !== item.value);
139
+ const value = [...model.value];
140
+ value.splice(index, 1);
141
+ model.value = value;
133
142
  }
134
143
  } else {
135
144
  model.value = [item.value];
@@ -167,7 +176,7 @@ export const VAutocomplete = genericComponent()({
167
176
  return _createVNode(VTextField, {
168
177
  "ref": vTextFieldRef,
169
178
  "modelValue": search.value,
170
- "onUpdate:modelValue": $event => search.value = $event,
179
+ "onInput": onInput,
171
180
  "class": ['v-autocomplete', {
172
181
  'v-autocomplete--active-menu': menu.value,
173
182
  'v-autocomplete--chips': !!props.chips,
@@ -182,74 +191,78 @@ export const VAutocomplete = genericComponent()({
182
191
  "onBlur": () => isFocused.value = false,
183
192
  "onKeydown": onKeydown
184
193
  }, { ...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'
194
+ default: () => {
195
+ var _slots$noData, _slots$noData2;
196
+
197
+ return _createVNode(_Fragment, null, [activator.value && _createVNode(VMenu, {
198
+ "modelValue": menu.value,
199
+ "onUpdate:modelValue": $event => menu.value = $event,
200
+ "activator": activator.value,
201
+ "contentClass": "v-autocomplete__content",
202
+ "eager": props.eager,
203
+ "openOnClick": false,
204
+ "transition": props.transition,
205
+ "onAfterLeave": onAfterLeave
198
206
  }, {
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;
207
+ default: () => [_createVNode(VList, {
208
+ "selected": selected.value,
209
+ "selectStrategy": props.multiple ? 'independent' : 'single-independent'
210
+ }, {
211
+ 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, {
212
+ "title": t(props.noDataText)
213
+ }, null)), filteredItems.value.map(_ref2 => {
214
+ let {
215
+ item,
216
+ matches
217
+ } = _ref2;
218
+ return _createVNode(VListItem, {
219
+ "value": item.value,
220
+ "onMousedown": e => e.preventDefault(),
221
+ "onClick": () => select(item)
222
+ }, {
223
+ title: () => {
224
+ var _search$value$length, _search$value;
213
225
 
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
- });
226
+ 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);
227
+ }
228
+ });
229
+ })]
217
230
  })]
218
- })]
219
- }), selections.value.map((selection, index) => {
220
- function onChipClose(e) {
221
- e.stopPropagation();
222
- e.preventDefault();
223
- select(selection);
224
- }
231
+ }), selections.value.map((selection, index) => {
232
+ function onChipClose(e) {
233
+ e.stopPropagation();
234
+ e.preventDefault();
235
+ select(selection);
236
+ }
225
237
 
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
238
+ const slotProps = {
239
+ 'onClick:close': onChipClose,
240
+ modelValue: true
241
+ };
242
+ return _createVNode("div", {
243
+ "class": "v-autocomplete__selection"
244
+ }, [hasChips && _createVNode(VDefaultsProvider, {
245
+ "defaults": {
246
+ VChip: {
247
+ closable: props.closableChips,
248
+ size: 'small',
249
+ text: selection.title
250
+ }
238
251
  }
239
- }
240
- }, {
241
- default: () => [slots.chip ? slots.chip({
242
- props: slotProps,
252
+ }, {
253
+ default: () => [slots.chip ? slots.chip({
254
+ props: slotProps,
255
+ selection
256
+ }) : _createVNode(VChip, slotProps, null)]
257
+ }), !hasChips && (slots.selection ? slots.selection({
243
258
  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
- })])
259
+ }) : _createVNode("span", {
260
+ "class": "v-autocomplete__selection-text"
261
+ }, [selection.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
262
+ "class": "v-autocomplete__selection-comma"
263
+ }, [_createTextVNode(",")])]))]);
264
+ })]);
265
+ }
253
266
  });
254
267
  });
255
268
  return useForwardRef({
@@ -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,"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"names":["makeSelectProps","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","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","model","v","multiple","filteredItems","value","undefined","selections","array","index","unwrapped","item","found","find","selection","push","selected","map","onClear","openOnClear","onClickControl","hideNoData","onKeydown","includes","key","onInput","target","onAfterLeave","isSelecting","select","findIndex","splice","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 { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForwardRef } from '@/composables/forwardRef'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\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 } = useItems(props)\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 = transformItem(props, 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 onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\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 = selected.value.findIndex(selection => selection === item.value)\n\n if (index === -1) {\n model.value = [...model.value, item.value]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = 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 modelValue={ search.value }\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 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 && (slots['no-data']?.() ?? (\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"}
@@ -11,21 +11,22 @@ import { makeSizeProps, useSize } from "../../composables/size.mjs";
11
11
  import { makeTagProps } from "../../composables/tag.mjs";
12
12
  import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
13
13
 
14
- import { defineComponent, useRender } from "../../util/index.mjs";
14
+ import { defineComponent, propsFactory, useRender } from "../../util/index.mjs";
15
15
  import { toRef } from 'vue';
16
+ export const makeVAvatarProps = propsFactory({
17
+ color: String,
18
+ start: Boolean,
19
+ end: Boolean,
20
+ icon: String,
21
+ image: String,
22
+ ...makeDensityProps(),
23
+ ...makeRoundedProps(),
24
+ ...makeSizeProps(),
25
+ ...makeTagProps()
26
+ });
16
27
  export const VAvatar = defineComponent({
17
28
  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
- },
29
+ props: makeVAvatarProps(),
29
30
 
30
31
  setup(props, _ref) {
31
32
  let {
@@ -50,8 +51,8 @@ export const VAvatar = defineComponent({
50
51
 
51
52
  return _createVNode(props.tag, {
52
53
  "class": ['v-avatar', {
53
- 'v-avatar--left': props.left,
54
- 'v-avatar--right': props.right
54
+ 'v-avatar--start': props.start,
55
+ 'v-avatar--end': props.end
55
56
  }, backgroundColorClasses.value, densityClasses.value, roundedClasses.value, sizeClasses.value],
56
57
  "style": [backgroundColorStyles.value, sizeStyles.value]
57
58
  }, {
@@ -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,"sources":["../../../src/components/VAvatar/VAvatar.tsx"],"names":["VIcon","VImg","makeDensityProps","useDensity","makeRoundedProps","useRounded","makeSizeProps","useSize","makeTagProps","useBackgroundColor","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"],"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,Y,EAAcC,S;AACxC,SAASC,KAAT,QAAsB,KAAtB;AAEA,OAAO,MAAMC,gBAAgB,GAAGH,YAAY,CAAC;AAC3CI,EAAAA,KAAK,EAAEC,MADoC;AAE3CC,EAAAA,KAAK,EAAEC,OAFoC;AAG3CC,EAAAA,GAAG,EAAED,OAHsC;AAI3CE,EAAAA,IAAI,EAAEJ,MAJqC;AAK3CK,EAAAA,KAAK,EAAEL,MALoC;AAO3C,KAAGd,gBAAgB,EAPwB;AAQ3C,KAAGE,gBAAgB,EARwB;AAS3C,KAAGE,aAAa,EAT2B;AAU3C,KAAGE,YAAY;AAV4B,CAAD,CAArC;AAaP,OAAO,MAAMc,OAAO,GAAGZ,eAAe,CAAC;AACrCa,EAAAA,IAAI,EAAE,SAD+B;AAGrCC,EAAAA,KAAK,EAAEV,gBAAgB,EAHc;;AAKrCW,EAAAA,KAAK,CAAED,KAAF,QAAoB;AAAA,QAAX;AAAEE,MAAAA;AAAF,KAAW;AACvB,UAAM;AAAEC,MAAAA,sBAAF;AAA0BC,MAAAA;AAA1B,QAAoDnB,kBAAkB,CAACI,KAAK,CAACW,KAAD,EAAQ,OAAR,CAAN,CAA5E;AACA,UAAM;AAAEK,MAAAA;AAAF,QAAqB1B,UAAU,CAACqB,KAAD,CAArC;AACA,UAAM;AAAEM,MAAAA;AAAF,QAAqBzB,UAAU,CAACmB,KAAD,CAArC;AACA,UAAM;AAAEO,MAAAA,WAAF;AAAeC,MAAAA;AAAf,QAA8BzB,OAAO,CAACiB,KAAD,CAA3C;AAEAZ,IAAAA,SAAS,CAAC;AAAA;;AAAA;AAAA,iBAEC,CACL,UADK,EAEL;AACE,6BAAmBY,KAAK,CAACP,KAD3B;AAEE,2BAAiBO,KAAK,CAACL;AAFzB,SAFK,EAMLQ,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,wBAmBJT,KAAK,CAACH,KAAN;AAAA,iBACeG,KAAK,CAACH,KADrB;AAAA,iBACiC;AADjC,mBAEEG,KAAK,CAACJ,IAAN;AAAA,kBACiBI,KAAK,CAACJ;AADvB,qCAEEM,KAAK,CAACQ,OAFR,qBAEE,oBAAAR,KAAK,CAvBL;AAAA;AAAA,KAAD,CAAT;AA4BA,WAAO,EAAP;AACD;;AAxCoC,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, propsFactory, useRender } from '@/util'\nimport { toRef } from 'vue'\n\nexport const makeVAvatarProps = propsFactory({\n color: String,\n start: Boolean,\n end: Boolean,\n icon: String,\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"],"file":"VAvatar.mjs"}
@@ -1,10 +1,17 @@
1
1
  .v-banner {
2
- display: flex;
3
- flex-wrap: wrap;
2
+ align-items: center;
3
+ display: grid;
4
+ flex: 1 1;
4
5
  font-size: 0.875rem;
5
- padding-bottom: 8px;
6
+ grid-template-areas: "prepend text actions";
7
+ grid-template-columns: max-content auto max-content;
8
+ grid-template-rows: max-content max-content;
9
+ line-height: 1.375rem;
10
+ overflow: hidden;
11
+ padding-inline-start: 16px;
6
12
  padding-inline-end: 8px;
7
- padding-inline-start: 24px;
13
+ padding-top: 16px;
14
+ padding-bottom: 16px;
8
15
  position: relative;
9
16
  width: 100%;
10
17
  border-color: rgba(var(--v-border-color), var(--v-border-opacity));
@@ -28,106 +35,123 @@
28
35
  .v-banner--sticky {
29
36
  position: sticky;
30
37
  }
31
- .v-banner--border {
32
- border-width: thin;
33
- }
34
- .v-banner--mobile {
35
- align-items: center;
36
- padding-inline-end: 8px;
37
- padding-inline-start: 16px;
38
- }
39
38
  .v-banner--rounded {
40
39
  border-radius: 4px;
41
40
  }
42
- .v-banner--density-default {
41
+ .v-banner--stacked:not(.v-banner--one-line) {
42
+ grid-template-areas: "prepend text" ". actions";
43
+ }
44
+ .v-banner--stacked .v-banner-text {
45
+ padding-inline-end: 36px;
46
+ }
47
+ .v-banner--density-default .v-banner-actions {
48
+ margin-bottom: -8px;
49
+ }
50
+ .v-banner--density-default.v-banner--one-line {
51
+ padding-top: 8px;
52
+ padding-bottom: 8px;
53
+ }
54
+ .v-banner--density-default.v-banner--one-line .v-banner-actions {
55
+ margin-bottom: 0;
56
+ }
57
+ .v-banner--density-default.v-banner--one-line {
43
58
  padding-top: 10px;
44
59
  }
45
60
  .v-banner--density-default.v-banner--two-line {
46
- padding-top: 24px;
61
+ padding-top: 16px;
62
+ padding-bottom: 16px;
47
63
  }
48
64
  .v-banner--density-default.v-banner--three-line {
49
65
  padding-top: 24px;
66
+ padding-bottom: 16px;
67
+ }
68
+ .v-banner--density-default:not(.v-banner--one-line) .v-banner-actions, .v-banner--density-default.v-banner--two-line .v-banner-actions, .v-banner--density-default.v-banner--three-line .v-banner-actions {
69
+ margin-top: 20px;
50
70
  }
51
71
 
52
- .v-banner--density-comfortable {
53
- padding-top: 6px;
72
+ .v-banner--density-comfortable .v-banner-actions {
73
+ margin-bottom: -4px;
74
+ }
75
+ .v-banner--density-comfortable.v-banner--one-line {
76
+ padding-top: 4px;
77
+ padding-bottom: 4px;
78
+ }
79
+ .v-banner--density-comfortable.v-banner--one-line .v-banner-actions {
80
+ margin-bottom: 0;
54
81
  }
55
82
  .v-banner--density-comfortable.v-banner--two-line {
56
- padding-top: 20px;
83
+ padding-top: 12px;
84
+ padding-bottom: 12px;
57
85
  }
58
86
  .v-banner--density-comfortable.v-banner--three-line {
59
87
  padding-top: 20px;
88
+ padding-bottom: 12px;
89
+ }
90
+ .v-banner--density-comfortable:not(.v-banner--one-line) .v-banner-actions, .v-banner--density-comfortable.v-banner--two-line .v-banner-actions, .v-banner--density-comfortable.v-banner--three-line .v-banner-actions {
91
+ margin-top: 16px;
60
92
  }
61
93
 
62
- .v-banner--density-compact {
63
- padding-top: 2px;
94
+ .v-banner--density-compact .v-banner-actions {
95
+ margin-bottom: 0px;
96
+ }
97
+ .v-banner--density-compact.v-banner--one-line {
98
+ padding-top: 0px;
99
+ padding-bottom: 0px;
100
+ }
101
+ .v-banner--density-compact.v-banner--one-line .v-banner-actions {
102
+ margin-bottom: 0;
64
103
  }
65
104
  .v-banner--density-compact.v-banner--two-line {
66
- padding-top: 16px;
105
+ padding-top: 8px;
106
+ padding-bottom: 8px;
67
107
  }
68
108
  .v-banner--density-compact.v-banner--three-line {
69
109
  padding-top: 16px;
110
+ padding-bottom: 8px;
111
+ }
112
+ .v-banner--density-compact:not(.v-banner--one-line) .v-banner-actions, .v-banner--density-compact.v-banner--two-line .v-banner-actions, .v-banner--density-compact.v-banner--three-line .v-banner-actions {
113
+ margin-top: 12px;
70
114
  }
71
115
 
72
116
  .v-banner--sticky {
73
117
  top: 0;
74
118
  }
75
119
 
120
+ .v-banner-avatar,
121
+ .v-banner-icon,
122
+ .v-banner__prepend {
123
+ align-self: flex-start;
124
+ grid-area: prepend;
125
+ margin-inline-end: 24px;
126
+ }
127
+
76
128
  .v-banner-actions {
77
- align-items: flex-end;
129
+ align-self: flex-end;
78
130
  display: flex;
79
131
  flex: 0 1;
132
+ grid-area: actions;
80
133
  justify-content: flex-end;
81
134
  }
82
- .v-banner--mobile .v-banner-actions {
83
- flex: 1 0;
84
- }
85
-
86
- .v-banner__content {
87
- display: flex;
88
- flex: 1 1;
89
- min-width: 0;
90
- padding-inline-end: 90px;
91
- }
92
- .v-banner--mobile .v-banner__content {
93
- flex: 1 1 auto;
94
- padding-inline-end: 8px;
95
- }
96
- .v-banner--two-line .v-banner__content {
97
- margin-bottom: 4px;
98
- }
99
- .v-banner--three-line .v-banner__content {
100
- margin-bottom: 8px;
101
- }
102
-
103
- .v-banner__avatar {
104
- align-self: flex-start;
105
- border-radius: 50%;
106
- margin-inline-end: 24px;
107
- margin-inline-start: 0;
108
- position: relative;
109
- }
110
- .v-banner--mobile .v-banner__avatar {
111
- margin-inline-end: 16px;
112
- }
113
- .v-banner--one-line .v-banner__avatar {
114
- align-self: center;
135
+ .v-banner--two-line .v-banner-actions, .v-banner--three-line .v-banner-actions {
136
+ margin-top: 20px;
115
137
  }
116
138
 
117
139
  .v-banner-text {
118
140
  -webkit-box-orient: vertical;
119
- align-self: center;
120
141
  display: -webkit-box;
121
- line-height: 1.375rem;
142
+ grid-area: text;
122
143
  overflow: hidden;
144
+ padding-inline-end: 90px;
123
145
  }
124
146
  .v-banner--one-line .v-banner-text {
125
147
  -webkit-line-clamp: 1;
126
148
  }
127
- .v-banner--two-line .v-banner-text, .v-banner--three-line .v-banner-text {
128
- align-self: flex-start;
149
+ .v-banner--two-line .v-banner-text {
129
150
  -webkit-line-clamp: 2;
130
151
  }
131
152
  .v-banner--three-line .v-banner-text {
132
153
  -webkit-line-clamp: 3;
154
+ }
155
+ .v-banner--two-line .v-banner-text, .v-banner--three-line .v-banner-text {
156
+ align-self: flex-start;
133
157
  }