@vuetify/nightly 3.0.0-beta.3 → 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 (169) hide show
  1. package/CHANGELOG.md +32 -2
  2. package/dist/_component-variables.sass +61 -0
  3. package/dist/json/attributes.json +176 -20
  4. package/dist/json/importMap.json +208 -204
  5. package/dist/json/tags.json +48 -4
  6. package/dist/json/web-types.json +492 -46
  7. package/dist/vuetify.css +950 -932
  8. package/dist/vuetify.d.ts +2521 -341
  9. package/dist/vuetify.esm.js +2318 -2130
  10. package/dist/vuetify.esm.js.map +1 -1
  11. package/dist/vuetify.js +2317 -2129
  12. package/dist/vuetify.js.map +1 -1
  13. package/dist/vuetify.min.css +2 -2
  14. package/dist/vuetify.min.js +764 -740
  15. package/dist/vuetify.min.js.map +1 -1
  16. package/lib/components/VAlert/VAlert.css +5 -5
  17. package/lib/components/VAlert/VAlert.mjs +1 -1
  18. package/lib/components/VAlert/VAlert.mjs.map +1 -1
  19. package/lib/components/VAlert/VAlert.sass +0 -2
  20. package/lib/components/VAppBar/VAppBar.sass +0 -1
  21. package/lib/components/VAutocomplete/VAutocomplete.mjs +46 -17
  22. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  23. package/lib/components/VAutocomplete/VAutocomplete.sass +0 -2
  24. package/lib/components/VAvatar/VAvatar.css +1 -1
  25. package/lib/components/VAvatar/VAvatar.sass +1 -2
  26. package/lib/components/VAvatar/_mixins.scss +0 -1
  27. package/lib/components/VBadge/VBadge.sass +0 -1
  28. package/lib/components/VBanner/VBanner.sass +0 -1
  29. package/lib/components/VBottomNavigation/VBottomNavigation.sass +0 -1
  30. package/lib/components/VBreadcrumbs/VBreadcrumbs.sass +0 -1
  31. package/lib/components/VBtn/VBtn.css +24 -7
  32. package/lib/components/VBtn/VBtn.mjs +20 -11
  33. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  34. package/lib/components/VBtn/VBtn.sass +17 -2
  35. package/lib/components/VBtnGroup/VBtnGroup.sass +0 -1
  36. package/lib/components/VBtnToggle/VBtnToggle.sass +0 -1
  37. package/lib/components/VCard/VCard.css +5 -5
  38. package/lib/components/VCard/VCard.mjs +1 -1
  39. package/lib/components/VCard/VCard.mjs.map +1 -1
  40. package/lib/components/VCard/VCard.sass +0 -1
  41. package/lib/components/VCarousel/VCarousel.sass +0 -1
  42. package/lib/components/VCheckbox/VCheckbox.mjs +13 -46
  43. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  44. package/lib/components/VCheckbox/VCheckbox.sass +0 -1
  45. package/lib/components/VCheckbox/VCheckboxBtn.mjs +67 -0
  46. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -0
  47. package/lib/components/VCheckbox/index.mjs +1 -0
  48. package/lib/components/VCheckbox/index.mjs.map +1 -1
  49. package/lib/components/VChip/VChip.css +5 -5
  50. package/lib/components/VChip/VChip.mjs +1 -1
  51. package/lib/components/VChip/VChip.mjs.map +1 -1
  52. package/lib/components/VChip/VChip.sass +0 -1
  53. package/lib/components/VChipGroup/VChipGroup.mjs +1 -1
  54. package/lib/components/VChipGroup/VChipGroup.mjs.map +1 -1
  55. package/lib/components/VCode/VCode.sass +1 -2
  56. package/lib/components/VCode/_variables.scss +1 -1
  57. package/lib/components/VColorPicker/VColorPicker.sass +0 -1
  58. package/lib/components/VColorPicker/VColorPickerCanvas.sass +0 -1
  59. package/lib/components/VColorPicker/VColorPickerEdit.sass +0 -1
  60. package/lib/components/VColorPicker/VColorPickerPreview.sass +0 -1
  61. package/lib/components/VColorPicker/VColorPickerSwatches.sass +0 -1
  62. package/lib/components/VCombobox/VCombobox.mjs +47 -29
  63. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  64. package/lib/components/VCombobox/VCombobox.sass +0 -2
  65. package/lib/components/VCounter/VCounter.sass +0 -1
  66. package/lib/components/VDialog/VDialog.sass +0 -1
  67. package/lib/components/VDivider/VDivider.sass +0 -1
  68. package/lib/components/VExpansionPanel/VExpansionPanel.sass +0 -1
  69. package/lib/components/VField/VField.css +9 -9
  70. package/lib/components/VField/VField.mjs +2 -2
  71. package/lib/components/VField/VField.mjs.map +1 -1
  72. package/lib/components/VField/VField.sass +6 -8
  73. package/lib/components/VField/_variables.scss +3 -3
  74. package/lib/components/VFileInput/VFileInput.sass +0 -1
  75. package/lib/components/VFooter/VFooter.sass +0 -1
  76. package/lib/components/VIcon/VIcon.sass +0 -1
  77. package/lib/components/VImg/VImg.sass +0 -1
  78. package/lib/components/VInput/VInput.mjs +3 -3
  79. package/lib/components/VInput/VInput.mjs.map +1 -1
  80. package/lib/components/VInput/VInput.sass +0 -1
  81. package/lib/components/VItemGroup/VItemGroup.sass +0 -1
  82. package/lib/components/VKbd/VKbd.sass +0 -1
  83. package/lib/components/VKbd/_variables.scss +1 -1
  84. package/lib/components/VLabel/VLabel.sass +0 -1
  85. package/lib/components/VList/VList.mjs +1 -1
  86. package/lib/components/VList/VList.mjs.map +1 -1
  87. package/lib/components/VList/VList.sass +0 -1
  88. package/lib/components/VList/VListChildren.mjs +1 -1
  89. package/lib/components/VList/VListChildren.mjs.map +1 -1
  90. package/lib/components/VList/VListGroup.mjs +11 -2
  91. package/lib/components/VList/VListGroup.mjs.map +1 -1
  92. package/lib/components/VList/VListItem.css +6 -6
  93. package/lib/components/VList/VListItem.mjs +7 -7
  94. package/lib/components/VList/VListItem.mjs.map +1 -1
  95. package/lib/components/VList/VListItem.sass +1 -2
  96. package/lib/components/VMain/VMain.sass +0 -1
  97. package/lib/components/VMenu/VMenu.sass +0 -1
  98. package/lib/components/VMessages/VMessages.sass +0 -1
  99. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +5 -1
  100. package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
  101. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +0 -1
  102. package/lib/components/VOverlay/VOverlay.sass +0 -1
  103. package/lib/components/VPagination/VPagination.sass +0 -1
  104. package/lib/components/VProgressCircular/VProgressCircular.sass +0 -1
  105. package/lib/components/VProgressLinear/VProgressLinear.sass +0 -1
  106. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -1
  107. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  108. package/lib/components/VRating/VRating.sass +0 -1
  109. package/lib/components/VSelect/VSelect.mjs +54 -19
  110. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  111. package/lib/components/VSelect/VSelect.sass +0 -2
  112. package/lib/components/VSelectionControl/VSelectionControl.css +1 -0
  113. package/lib/components/VSelectionControl/VSelectionControl.mjs +6 -5
  114. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  115. package/lib/components/VSelectionControl/VSelectionControl.sass +1 -1
  116. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +0 -1
  117. package/lib/components/VSheet/VSheet.sass +0 -1
  118. package/lib/components/VSlideGroup/VSlideGroup.sass +0 -1
  119. package/lib/components/VSlider/VSlider.sass +0 -2
  120. package/lib/components/VSlider/VSliderThumb.sass +0 -2
  121. package/lib/components/VSlider/VSliderTrack.sass +0 -2
  122. package/lib/components/VSnackbar/VSnackbar.css +5 -5
  123. package/lib/components/VSnackbar/VSnackbar.sass +0 -1
  124. package/lib/components/VSwitch/VSwitch.mjs +8 -2
  125. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  126. package/lib/components/VSwitch/VSwitch.sass +0 -1
  127. package/lib/components/VSystemBar/VSystemBar.sass +0 -1
  128. package/lib/components/VTable/VTable.sass +0 -1
  129. package/lib/components/VTabs/VTab.sass +0 -1
  130. package/lib/components/VTabs/VTabs.sass +0 -1
  131. package/lib/components/VTabs/_variables.scss +1 -1
  132. package/lib/components/VTextField/VTextField.mjs +2 -0
  133. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  134. package/lib/components/VTextField/VTextField.sass +0 -1
  135. package/lib/components/VTextarea/VTextarea.sass +0 -2
  136. package/lib/components/VTimeline/VTimeline.sass +0 -1
  137. package/lib/components/VToolbar/VToolbar.sass +0 -1
  138. package/lib/components/VToolbar/VToolbarItems.mjs +1 -1
  139. package/lib/components/VToolbar/VToolbarItems.mjs.map +1 -1
  140. package/lib/components/VTooltip/VTooltip.sass +0 -1
  141. package/lib/components/VWindow/VWindow.sass +0 -2
  142. package/lib/components/VWindow/VWindowItem.mjs +9 -3
  143. package/lib/components/VWindow/VWindowItem.mjs.map +1 -1
  144. package/lib/components/index.d.ts +2520 -342
  145. package/lib/composables/display.mjs +13 -11
  146. package/lib/composables/display.mjs.map +1 -1
  147. package/lib/composables/form.mjs +6 -6
  148. package/lib/composables/form.mjs.map +1 -1
  149. package/lib/composables/items.mjs +2 -2
  150. package/lib/composables/items.mjs.map +1 -1
  151. package/lib/composables/ssrBoot.mjs +3 -2
  152. package/lib/composables/ssrBoot.mjs.map +1 -1
  153. package/lib/composables/theme.mjs +6 -2
  154. package/lib/composables/theme.mjs.map +1 -1
  155. package/lib/composables/validation.mjs +14 -7
  156. package/lib/composables/validation.mjs.map +1 -1
  157. package/lib/composables/variant.mjs +3 -3
  158. package/lib/composables/variant.mjs.map +1 -1
  159. package/lib/directives/ripple/VRipple.sass +0 -1
  160. package/lib/entry-bundler.mjs +1 -1
  161. package/lib/framework.mjs +23 -6
  162. package/lib/framework.mjs.map +1 -1
  163. package/lib/index.d.ts +73 -67
  164. package/lib/styles/tools/_variant.sass +6 -6
  165. package/lib/util/getCurrentInstance.mjs +19 -0
  166. package/lib/util/getCurrentInstance.mjs.map +1 -1
  167. package/lib/util/helpers.mjs +0 -4
  168. package/lib/util/helpers.mjs.map +1 -1
  169. package/package.json +11 -3
@@ -18,7 +18,7 @@
18
18
  .v-alert--sticky {
19
19
  position: sticky;
20
20
  }
21
- .v-alert--variant-plain, .v-alert--variant-outlined, .v-alert--variant-text, .v-alert--variant-contained-text {
21
+ .v-alert--variant-plain, .v-alert--variant-outlined, .v-alert--variant-text, .v-alert--variant-tonal {
22
22
  background: transparent;
23
23
  color: inherit;
24
24
  }
@@ -31,14 +31,14 @@
31
31
  .v-alert--variant-plain .v-alert__overlay {
32
32
  display: none;
33
33
  }
34
- .v-alert--variant-contained, .v-alert--variant-contained-flat {
34
+ .v-alert--variant-elevated, .v-alert--variant-flat {
35
35
  background: rgb(var(--v-theme-on-surface-variant));
36
36
  color: rgba(var(--v-theme-on-surface), var(--v-high-emphasis-opacity));
37
37
  }
38
- .v-alert--variant-contained {
38
+ .v-alert--variant-elevated {
39
39
  box-shadow: 0px 2px 1px -1px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 1px 3px 0px rgba(0, 0, 0, 0.12);
40
40
  }
41
- .v-alert--variant-contained-flat {
41
+ .v-alert--variant-flat {
42
42
  box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12);
43
43
  }
44
44
  .v-alert--variant-outlined {
@@ -47,7 +47,7 @@
47
47
  .v-alert--variant-text .v-alert__overlay {
48
48
  background: currentColor;
49
49
  }
50
- .v-alert--variant-contained-text .v-alert__underlay {
50
+ .v-alert--variant-tonal .v-alert__underlay {
51
51
  background: currentColor;
52
52
  opacity: var(--v-activated-opacity);
53
53
  border-radius: inherit;
@@ -66,7 +66,7 @@ export const VAlert = defineComponent({
66
66
  ...makeTagProps(),
67
67
  ...makeThemeProps(),
68
68
  ...makeVariantProps({
69
- variant: 'contained-flat'
69
+ variant: 'flat'
70
70
  })
71
71
  },
72
72
  emits: {
@@ -1 +1 @@
1
- {"version":3,"file":"VAlert.mjs","names":["VAlertTitle","VDefaultsProvider","VIcon","genOverlays","makeVariantProps","useVariant","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","useProxiedModel","useTextColor","IconValue","computed","toRef","defineComponent","allowedTypes","VAlert","name","props","border","type","Boolean","String","validator","val","includes","borderColor","closable","closeIcon","default","closeLabel","icon","Function","Object","modelValue","prominent","title","text","variant","emits","value","setup","slots","isActive","undefined","variantProps","color","themeClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","locationStyles","positionClasses","roundedClasses","textColorClasses","textColorStyles","onCloseClick","e","hasPrepend","prepend","hasTitle","hasText","hasClose","close","density","size","append"],"sources":["../../../src/components/VAlert/VAlert.tsx"],"sourcesContent":["// Styles\nimport './VAlert.sass'\n\n// Components\nimport { VAlertTitle } from './VAlertTitle'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\nimport { IconValue } from '@/composables/icons'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { defineComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nconst allowedTypes = ['success', 'info', 'warning', 'error'] as const\n\ntype ContextualType = typeof allowedTypes[number]\n\nexport const VAlert = defineComponent({\n name: 'VAlert',\n\n props: {\n border: {\n type: [Boolean, String],\n validator: (val: boolean | string) => {\n return typeof val === 'boolean' || [\n 'top',\n 'end',\n 'bottom',\n 'start',\n ].includes(val)\n },\n },\n borderColor: String,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$close',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n icon: {\n type: [Boolean, String, Function, Object] as PropType<false | IconValue>,\n default: null,\n },\n modelValue: {\n type: Boolean,\n default: true,\n },\n prominent: Boolean,\n title: String,\n text: String,\n type: {\n type: String as PropType<ContextualType>,\n validator: (val: ContextualType) => allowedTypes.includes(val),\n },\n\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'contained-flat' } as const),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const icon = computed(() => {\n if (props.icon === false) return undefined\n if (!props.type) return props.icon\n\n return props.icon ?? `$${props.type}`\n })\n const variantProps = computed(() => ({\n color: props.color ?? props.type,\n variant: props.variant,\n }))\n\n const { themeClasses } = provideTheme(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(variantProps)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const { textColorClasses, textColorStyles } = useTextColor(toRef(props, 'borderColor'))\n\n function onCloseClick (e: MouseEvent) {\n isActive.value = false\n }\n\n return () => {\n const hasPrepend = !!(slots.prepend || icon.value)\n const hasTitle = !!(slots.title || props.title)\n const hasText = !!(props.text || slots.text)\n const hasClose = !!(slots.close || props.closable)\n\n return isActive.value && (\n <props.tag\n class={[\n 'v-alert',\n props.border && {\n 'v-alert--border': !!props.border,\n [`v-alert--border-${props.border === true ? 'start' : props.border}`]: true,\n },\n {\n 'v-alert--prominent': props.prominent,\n },\n themeClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n role=\"alert\"\n >\n { genOverlays(false, 'v-alert') }\n\n { props.border && (\n <div\n class={[\n 'v-alert__border',\n textColorClasses.value,\n ]}\n style={ textColorStyles.value }\n />\n ) }\n\n { hasPrepend && (\n <VDefaultsProvider\n defaults={{\n VIcon: {\n density: props.density,\n icon: icon.value,\n size: props.prominent ? 44 : 'default',\n },\n }}\n >\n <div class=\"v-alert__prepend\">\n { slots.prepend\n ? slots.prepend()\n : icon.value && (<VIcon />)\n }\n </div>\n </VDefaultsProvider>\n ) }\n\n <div class=\"v-alert__content\">\n { hasTitle && (\n <VAlertTitle>\n { slots.title ? slots.title() : props.title }\n </VAlertTitle>\n ) }\n\n { hasText && (\n slots.text ? slots.text() : props.text\n ) }\n\n { slots.default?.() }\n </div>\n\n { slots.append && (\n <div class=\"v-alert__append\">\n { slots.append() }\n </div>\n ) }\n\n { hasClose && (\n <VDefaultsProvider\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'small',\n },\n }}\n >\n <div\n class=\"v-alert__close\"\n onClick={ onCloseClick }\n >\n { slots.close\n ? slots.close()\n : (<VIcon />)\n }\n </div>\n </VDefaultsProvider>\n ) }\n </props.tag>\n )\n }\n },\n})\n\nexport type VAlert = InstanceType<typeof VAlert>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VAlert.mjs","names":["VAlertTitle","VDefaultsProvider","VIcon","genOverlays","makeVariantProps","useVariant","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","useProxiedModel","useTextColor","IconValue","computed","toRef","defineComponent","allowedTypes","VAlert","name","props","border","type","Boolean","String","validator","val","includes","borderColor","closable","closeIcon","default","closeLabel","icon","Function","Object","modelValue","prominent","title","text","variant","emits","value","setup","slots","isActive","undefined","variantProps","color","themeClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","locationStyles","positionClasses","roundedClasses","textColorClasses","textColorStyles","onCloseClick","e","hasPrepend","prepend","hasTitle","hasText","hasClose","close","density","size","append"],"sources":["../../../src/components/VAlert/VAlert.tsx"],"sourcesContent":["// Styles\nimport './VAlert.sass'\n\n// Components\nimport { VAlertTitle } from './VAlertTitle'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\nimport { IconValue } from '@/composables/icons'\n\n// Utilities\nimport { computed, toRef } from 'vue'\nimport { defineComponent } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nconst allowedTypes = ['success', 'info', 'warning', 'error'] as const\n\ntype ContextualType = typeof allowedTypes[number]\n\nexport const VAlert = defineComponent({\n name: 'VAlert',\n\n props: {\n border: {\n type: [Boolean, String],\n validator: (val: boolean | string) => {\n return typeof val === 'boolean' || [\n 'top',\n 'end',\n 'bottom',\n 'start',\n ].includes(val)\n },\n },\n borderColor: String,\n closable: Boolean,\n closeIcon: {\n type: IconValue,\n default: '$close',\n },\n closeLabel: {\n type: String,\n default: '$vuetify.close',\n },\n icon: {\n type: [Boolean, String, Function, Object] as PropType<false | IconValue>,\n default: null,\n },\n modelValue: {\n type: Boolean,\n default: true,\n },\n prominent: Boolean,\n title: String,\n text: String,\n type: {\n type: String as PropType<ContextualType>,\n validator: (val: ContextualType) => allowedTypes.includes(val),\n },\n\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeTagProps(),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'flat' } as const),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const icon = computed(() => {\n if (props.icon === false) return undefined\n if (!props.type) return props.icon\n\n return props.icon ?? `$${props.type}`\n })\n const variantProps = computed(() => ({\n color: props.color ?? props.type,\n variant: props.variant,\n }))\n\n const { themeClasses } = provideTheme(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(variantProps)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const { textColorClasses, textColorStyles } = useTextColor(toRef(props, 'borderColor'))\n\n function onCloseClick (e: MouseEvent) {\n isActive.value = false\n }\n\n return () => {\n const hasPrepend = !!(slots.prepend || icon.value)\n const hasTitle = !!(slots.title || props.title)\n const hasText = !!(props.text || slots.text)\n const hasClose = !!(slots.close || props.closable)\n\n return isActive.value && (\n <props.tag\n class={[\n 'v-alert',\n props.border && {\n 'v-alert--border': !!props.border,\n [`v-alert--border-${props.border === true ? 'start' : props.border}`]: true,\n },\n {\n 'v-alert--prominent': props.prominent,\n },\n themeClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n role=\"alert\"\n >\n { genOverlays(false, 'v-alert') }\n\n { props.border && (\n <div\n class={[\n 'v-alert__border',\n textColorClasses.value,\n ]}\n style={ textColorStyles.value }\n />\n ) }\n\n { hasPrepend && (\n <VDefaultsProvider\n defaults={{\n VIcon: {\n density: props.density,\n icon: icon.value,\n size: props.prominent ? 44 : 'default',\n },\n }}\n >\n <div class=\"v-alert__prepend\">\n { slots.prepend\n ? slots.prepend()\n : icon.value && (<VIcon />)\n }\n </div>\n </VDefaultsProvider>\n ) }\n\n <div class=\"v-alert__content\">\n { hasTitle && (\n <VAlertTitle>\n { slots.title ? slots.title() : props.title }\n </VAlertTitle>\n ) }\n\n { hasText && (\n slots.text ? slots.text() : props.text\n ) }\n\n { slots.default?.() }\n </div>\n\n { slots.append && (\n <div class=\"v-alert__append\">\n { slots.append() }\n </div>\n ) }\n\n { hasClose && (\n <VDefaultsProvider\n defaults={{\n VIcon: {\n icon: props.closeIcon,\n size: 'small',\n },\n }}\n >\n <div\n class=\"v-alert__close\"\n onClick={ onCloseClick }\n >\n { slots.close\n ? slots.close()\n : (<VIcon />)\n }\n </div>\n </VDefaultsProvider>\n ) }\n </props.tag>\n )\n }\n },\n})\n\nexport type VAlert = InstanceType<typeof VAlert>\n"],"mappings":"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"}
@@ -1,5 +1,3 @@
1
- @forward './variables'
2
-
3
1
  @use '../../styles/tools'
4
2
  @use './variables' as *
5
3
 
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -3,6 +3,7 @@ import { createTextVNode as _createTextVNode, mergeProps as _mergeProps, createV
3
3
  import "./VAutocomplete.css"; // Components
4
4
 
5
5
  import { makeSelectProps } from "../VSelect/VSelect.mjs";
6
+ import { VCheckboxBtn } from "../VCheckbox/index.mjs";
6
7
  import { VChip } from "../VChip/index.mjs";
7
8
  import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
8
9
  import { VList, VListItem } from "../VList/index.mjs";
@@ -16,7 +17,7 @@ import { useForwardRef } from "../../composables/forwardRef.mjs";
16
17
  import { useLocale } from "../../composables/locale.mjs";
17
18
  import { useProxiedModel } from "../../composables/proxiedModel.mjs"; // Utility
18
19
 
19
- import { computed, nextTick, ref, watch } from 'vue';
20
+ import { computed, mergeProps, nextTick, ref, watch } from 'vue';
20
21
  import { genericComponent, useRender, wrapInArray } from "../../util/index.mjs"; // Types
21
22
 
22
23
  function highlightResult(text, matches, length) {
@@ -47,7 +48,8 @@ export const VAutocomplete = genericComponent()({
47
48
  emits: {
48
49
  'click:clear': e => true,
49
50
  'update:search': val => true,
50
- 'update:modelValue': val => true
51
+ 'update:modelValue': val => true,
52
+ 'update:menu': val => true
51
53
  },
52
54
 
53
55
  setup(props, _ref) {
@@ -60,7 +62,7 @@ export const VAutocomplete = genericComponent()({
60
62
  const vTextFieldRef = ref();
61
63
  const isFocused = ref(false);
62
64
  const isPristine = ref(true);
63
- const menu = ref(false);
65
+ const menu = useProxiedModel(props, 'menu');
64
66
  const {
65
67
  items,
66
68
  transformIn,
@@ -68,8 +70,10 @@ export const VAutocomplete = genericComponent()({
68
70
  } = useItems(props);
69
71
  const search = useProxiedModel(props, 'search', '');
70
72
  const model = useProxiedModel(props, 'modelValue', [], v => transformIn(wrapInArray(v)), v => {
73
+ var _transformed$;
74
+
71
75
  const transformed = transformOut(v);
72
- return props.multiple ? transformed : transformed[0];
76
+ return props.multiple ? transformed : (_transformed$ = transformed[0]) != null ? _transformed$ : null;
73
77
  });
74
78
  const {
75
79
  filteredItems
@@ -165,6 +169,10 @@ export const VAutocomplete = genericComponent()({
165
169
  return _createVNode(VTextField, {
166
170
  "ref": vTextFieldRef,
167
171
  "modelValue": search.value,
172
+ "onUpdate:modelValue": v => {
173
+ if (v == null) model.value = [];
174
+ },
175
+ "validationValue": props.modelValue,
168
176
  "onInput": onInput,
169
177
  "class": ['v-autocomplete', {
170
178
  'v-autocomplete--active-menu': menu.value,
@@ -172,7 +180,6 @@ export const VAutocomplete = genericComponent()({
172
180
  [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true
173
181
  }],
174
182
  "appendInnerIcon": props.menuIcon,
175
- "dirty": selected.value.length > 0,
176
183
  "onClick:clear": onClear,
177
184
  "onClick:control": onClickControl,
178
185
  "onClick:input": onClickControl,
@@ -183,31 +190,48 @@ export const VAutocomplete = genericComponent()({
183
190
  default: () => {
184
191
  var _slots$noData, _slots$noData2;
185
192
 
186
- return _createVNode(_Fragment, null, [_createVNode(VMenu, {
193
+ return _createVNode(_Fragment, null, [_createVNode(VMenu, _mergeProps({
187
194
  "modelValue": menu.value,
188
195
  "onUpdate:modelValue": $event => menu.value = $event,
189
196
  "activator": "parent",
190
197
  "contentClass": "v-autocomplete__content",
191
198
  "eager": props.eager,
192
199
  "openOnClick": false,
200
+ "closeOnContentClick": false,
193
201
  "transition": props.transition,
194
202
  "onAfterLeave": onAfterLeave
195
- }, {
203
+ }, props.menuProps), {
196
204
  default: () => [_createVNode(VList, {
197
205
  "selected": selected.value,
198
- "selectStrategy": props.multiple ? 'independent' : 'single-independent'
206
+ "selectStrategy": props.multiple ? 'independent' : 'single-independent',
207
+ "onMousedown": e => e.preventDefault()
199
208
  }, {
200
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, {
201
210
  "title": t(props.noDataText)
202
211
  }, null)), filteredItems.value.map(_ref2 => {
212
+ var _slots$item, _slots$item2;
213
+
203
214
  let {
204
215
  item,
205
216
  matches
206
217
  } = _ref2;
207
- return _createVNode(VListItem, _mergeProps(item.props, {
208
- "onMousedown": e => e.preventDefault(),
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, {
209
224
  "onClick": () => select(item)
210
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
+ },
211
235
  title: () => {
212
236
  var _search$value$length, _search$value;
213
237
 
@@ -216,11 +240,11 @@ export const VAutocomplete = genericComponent()({
216
240
  });
217
241
  })]
218
242
  })]
219
- }), selections.value.map((selection, index) => {
243
+ }), selections.value.map((item, index) => {
220
244
  function onChipClose(e) {
221
245
  e.stopPropagation();
222
246
  e.preventDefault();
223
- select(selection);
247
+ select(item);
224
248
  }
225
249
 
226
250
  const slotProps = {
@@ -234,21 +258,21 @@ export const VAutocomplete = genericComponent()({
234
258
  VChip: {
235
259
  closable: props.closableChips,
236
260
  size: 'small',
237
- text: selection.props.title
261
+ text: item.title
238
262
  }
239
263
  }
240
264
  }, {
241
265
  default: () => [slots.chip ? slots.chip({
242
266
  props: slotProps,
243
- item: selection.originalItem,
267
+ item,
244
268
  index
245
269
  }) : _createVNode(VChip, slotProps, null)]
246
270
  }) : slots.selection ? slots.selection({
247
- item: selection.originalItem,
271
+ item,
248
272
  index
249
273
  }) : _createVNode("span", {
250
274
  "class": "v-autocomplete__selection-text"
251
- }, [selection.props.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
275
+ }, [item.title, props.multiple && index < selections.value.length - 1 && _createVNode("span", {
252
276
  "class": "v-autocomplete__selection-comma"
253
277
  }, [_createTextVNode(",")])])]);
254
278
  })]);
@@ -256,7 +280,12 @@ export const VAutocomplete = genericComponent()({
256
280
  });
257
281
  });
258
282
  return useForwardRef({
259
- filteredItems
283
+ isFocused,
284
+ isPristine,
285
+ menu,
286
+ search,
287
+ filteredItems,
288
+ select
260
289
  }, vTextFieldRef);
261
290
  }
262
291
 
@@ -1 +1 @@
1
- {"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","makeFilterProps","useFilter","makeTransitionProps","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","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","menuIcon","default","eager","noDataText","preventDefault","onChipClose","stopPropagation","slotProps","modelValue","closable","closableChips","size","originalItem"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"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 { 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 { 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 },\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 = ref(false)\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]\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 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]\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 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 <VMenu\n v-model={ menu.value }\n activator=\"parent\"\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 { ...item.props }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onClick={ () => select(item) }\n >\n {{\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, matches.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n </VList>\n </VMenu>\n\n { selections.value.map((selection, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(selection)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n }\n\n return (\n <div class=\"v-autocomplete__selection\">\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: selection.props.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ props: slotProps, item: selection.originalItem, index })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item: selection.originalItem, index })\n : (\n <span class=\"v-autocomplete__selection-text\">\n { selection.props.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"],"mappings":"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"}
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":"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"}
@@ -1,10 +1,8 @@
1
- @forward './variables'
2
1
  @use 'sass:selector'
3
2
  @use 'sass:math'
4
3
  @use '../../styles/settings'
5
4
  @use '../../styles/tools'
6
5
  @use './variables' as *
7
- @use '../VInput/variables' as *
8
6
 
9
7
  .v-autocomplete
10
8
  .v-field
@@ -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
  }
@@ -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,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use 'sass:math'
3
2
  @use '../../styles/tools'
4
3
  @use './variables' as *
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -1,4 +1,3 @@
1
- @forward './variables'
2
1
  @use '../../styles/tools'
3
2
  @use './variables' as *
4
3
 
@@ -104,7 +104,7 @@
104
104
  .v-btn--active:focus > .v-btn__overlay, .v-btn[aria-haspopup=menu][aria-expanded=true]:focus > .v-btn__overlay {
105
105
  opacity: calc(0.16 * var(--v-theme-overlay-multiplier));
106
106
  }
107
- .v-btn--variant-plain, .v-btn--variant-outlined, .v-btn--variant-text, .v-btn--variant-contained-text {
107
+ .v-btn--variant-plain, .v-btn--variant-outlined, .v-btn--variant-text, .v-btn--variant-tonal {
108
108
  background: transparent;
109
109
  color: inherit;
110
110
  }
@@ -117,14 +117,14 @@
117
117
  .v-btn--variant-plain .v-btn__overlay {
118
118
  display: none;
119
119
  }
120
- .v-btn--variant-contained, .v-btn--variant-contained-flat {
120
+ .v-btn--variant-elevated, .v-btn--variant-flat {
121
121
  background: rgb(var(--v-theme-surface));
122
122
  color: rgba(var(--v-theme-on-surface), var(--v-high-emphasis-opacity));
123
123
  }
124
- .v-btn--variant-contained {
124
+ .v-btn--variant-elevated {
125
125
  box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
126
126
  }
127
- .v-btn--variant-contained-flat {
127
+ .v-btn--variant-flat {
128
128
  box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12);
129
129
  }
130
130
  .v-btn--variant-outlined {
@@ -133,7 +133,7 @@
133
133
  .v-btn--variant-text .v-btn__overlay {
134
134
  background: currentColor;
135
135
  }
136
- .v-btn--variant-contained-text .v-btn__underlay {
136
+ .v-btn--variant-tonal .v-btn__underlay {
137
137
  background: currentColor;
138
138
  opacity: var(--v-activated-opacity);
139
139
  border-radius: inherit;
@@ -203,13 +203,19 @@
203
203
  color: rgba(var(--v-theme-on-surface), 0.26);
204
204
  opacity: 1;
205
205
  }
206
- .v-btn--disabled.v-btn--variant-contained {
206
+ .v-btn--disabled.v-btn--variant-elevated {
207
207
  background: rgb(var(--v-theme-surface));
208
208
  box-shadow: none;
209
209
  }
210
- .v-btn--disabled.v-btn--variant-contained .v-btn__overlay {
210
+ .v-btn--disabled.v-btn--variant-elevated .v-btn__overlay {
211
211
  opacity: 0.4615384615;
212
212
  }
213
+ .v-btn--loading {
214
+ pointer-events: none;
215
+ }
216
+ .v-btn--loading .v-btn__content {
217
+ opacity: 0;
218
+ }
213
219
  .v-btn--stacked {
214
220
  flex-direction: column;
215
221
  line-height: 1.25;
@@ -279,6 +285,17 @@
279
285
  --v-icon-size-multiplier: 1.1428571429;
280
286
  }
281
287
 
288
+ .v-btn__loader {
289
+ align-items: center;
290
+ display: flex;
291
+ height: 100%;
292
+ justify-content: center;
293
+ left: 0;
294
+ position: absolute;
295
+ top: 0;
296
+ width: 100%;
297
+ }
298
+
282
299
  .v-btn__content {
283
300
  transition: transform, opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1);
284
301
  white-space: nowrap;
@@ -3,7 +3,8 @@ import { withDirectives as _withDirectives, resolveDirective as _resolveDirectiv
3
3
  import "./VBtn.css"; // Components
4
4
 
5
5
  import { VBtnToggleSymbol } from "../VBtnToggle/VBtnToggle.mjs";
6
- import { VIcon } from "../VIcon/index.mjs"; // Composables
6
+ import { VIcon } from "../VIcon/index.mjs";
7
+ import { VProgressCircular } from "../VProgressCircular/index.mjs"; // Composables
7
8
 
8
9
  import { makeBorderProps, useBorder } from "../../composables/border.mjs";
9
10
  import { makeDensityProps, useDensity } from "../../composables/density.mjs";
@@ -43,6 +44,7 @@ export const VBtn = defineComponent({
43
44
  appendIcon: IconValue,
44
45
  block: Boolean,
45
46
  stacked: Boolean,
47
+ loading: Boolean,
46
48
  ripple: {
47
49
  type: Boolean,
48
50
  default: true
@@ -62,7 +64,7 @@ export const VBtn = defineComponent({
62
64
  }),
63
65
  ...makeThemeProps(),
64
66
  ...makeVariantProps({
65
- variant: 'contained'
67
+ variant: 'elevated'
66
68
  })
67
69
  },
68
70
 
@@ -107,7 +109,7 @@ export const VBtn = defineComponent({
107
109
  const link = useLink(props, attrs);
108
110
  const isDisabled = computed(() => (group == null ? void 0 : group.disabled.value) || props.disabled);
109
111
  const isElevated = computed(() => {
110
- return props.variant === 'contained' && !(props.disabled || props.flat || props.border);
112
+ return props.variant === 'elevated' && !(props.disabled || props.flat || props.border);
111
113
  });
112
114
  useSelectLink(link, group == null ? void 0 : group.select);
113
115
  return () => {
@@ -124,7 +126,8 @@ export const VBtn = defineComponent({
124
126
  'v-btn--elevated': isElevated.value,
125
127
  'v-btn--flat': props.flat,
126
128
  'v-btn--icon': !!props.icon,
127
- 'v-btn--stacked': props.stacked
129
+ 'v-btn--stacked': props.stacked,
130
+ 'v-btn--loading': props.loading
128
131
  }, themeClasses.value, borderClasses.value, hasColor ? colorClasses.value : undefined, densityClasses.value, elevationClasses.value, positionClasses.value, roundedClasses.value, sizeClasses.value, variantClasses.value],
129
132
  "style": [hasColor ? colorStyles.value : undefined, dimensionStyles.value, locationStyles.value],
130
133
  "disabled": isDisabled.value || undefined,
@@ -137,22 +140,28 @@ export const VBtn = defineComponent({
137
140
  group == null ? void 0 : group.toggle();
138
141
  }
139
142
  }, {
140
- default: () => [genOverlays(true, 'v-btn'), !props.icon && props.prependIcon && _createVNode(VIcon, {
143
+ default: () => [genOverlays(true, 'v-btn'), _createVNode("span", {
144
+ "class": "v-btn__content",
145
+ "data-no-activator": ""
146
+ }, [!props.icon && props.prependIcon && _createVNode(VIcon, {
141
147
  "class": "v-btn__icon",
142
148
  "icon": props.prependIcon,
143
149
  "start": true
144
- }, null), _createVNode("div", {
145
- "class": "v-btn__content",
146
- "data-no-activator": ""
147
- }, [typeof props.icon === 'boolean' ? (_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots) : _createVNode(VIcon, {
150
+ }, null), typeof props.icon === 'boolean' ? (_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots) : _createVNode(VIcon, {
148
151
  "class": "v-btn__icon",
149
152
  "icon": props.icon,
150
153
  "size": props.size
151
- }, null)]), !props.icon && props.appendIcon && _createVNode(VIcon, {
154
+ }, null), !props.icon && props.appendIcon && _createVNode(VIcon, {
152
155
  "class": "v-btn__icon",
153
156
  "icon": props.appendIcon,
154
157
  "end": true
155
- }, null)]
158
+ }, null)]), props.loading && _createVNode("span", {
159
+ "class": "v-btn__loader"
160
+ }, [slots.loader ? slots.loader() : _createVNode(VProgressCircular, {
161
+ "indeterminate": true,
162
+ "size": "23",
163
+ "width": "2"
164
+ }, null)])]
156
165
  }), [[_resolveDirective("ripple"), !isDisabled.value && props.ripple, null]]);
157
166
  };
158
167
  }