@vuetify/nightly 3.0.0-beta.10 → 3.0.0-beta.13

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 (224) hide show
  1. package/CHANGELOG.md +13 -2
  2. package/dist/json/attributes.json +37 -29
  3. package/dist/json/importMap.json +46 -46
  4. package/dist/json/tags.json +10 -8
  5. package/dist/json/web-types.json +101 -87
  6. package/dist/vuetify.css +545 -441
  7. package/dist/vuetify.d.ts +12095 -10059
  8. package/dist/vuetify.esm.js +401 -266
  9. package/dist/vuetify.esm.js.map +1 -1
  10. package/dist/vuetify.js +371 -236
  11. package/dist/vuetify.js.map +1 -1
  12. package/dist/vuetify.min.css +3 -3
  13. package/dist/vuetify.min.js +496 -490
  14. package/dist/vuetify.min.js.map +1 -1
  15. package/lib/blueprints/index.d.ts +171 -0
  16. package/lib/blueprints/md1.d.ts +167 -0
  17. package/lib/blueprints/md2.d.ts +167 -0
  18. package/lib/blueprints/md3.d.ts +167 -0
  19. package/lib/components/VAlert/index.d.ts +185 -0
  20. package/lib/components/VApp/index.d.ts +83 -0
  21. package/lib/components/VAppBar/VAppBar.css +3 -0
  22. package/lib/components/VAppBar/VAppBar.sass +3 -0
  23. package/lib/components/VAppBar/index.d.ts +156 -0
  24. package/lib/components/VAutocomplete/VAutocomplete.mjs +1 -1
  25. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  26. package/lib/components/VAutocomplete/index.d.ts +1569 -0
  27. package/lib/components/VAvatar/VAvatar.css +44 -2
  28. package/lib/components/VAvatar/VAvatar.mjs +16 -12
  29. package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
  30. package/lib/components/VAvatar/VAvatar.sass +5 -1
  31. package/lib/components/VAvatar/_variables.scss +9 -4
  32. package/lib/components/VAvatar/index.d.ts +80 -0
  33. package/lib/components/VBadge/index.d.ts +123 -0
  34. package/lib/components/VBanner/index.d.ts +122 -0
  35. package/lib/components/VBottomNavigation/index.d.ts +143 -0
  36. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +2 -2
  37. package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
  38. package/lib/components/VBreadcrumbs/index.d.ts +301 -0
  39. package/lib/components/VBtn/VBtn.css +8 -3
  40. package/lib/components/VBtn/VBtn.mjs +16 -6
  41. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  42. package/lib/components/VBtn/index.d.ts +210 -0
  43. package/lib/components/VBtnGroup/index.d.ts +65 -0
  44. package/lib/components/VBtnToggle/VBtnToggle.mjs +1 -3
  45. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  46. package/lib/components/VBtnToggle/index.d.ts +175 -0
  47. package/lib/components/VCard/VCard.css +8 -3
  48. package/lib/components/VCard/index.d.ts +230 -0
  49. package/lib/components/VCarousel/VCarousel.mjs +3 -3
  50. package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
  51. package/lib/components/VCarousel/index.d.ts +80 -0
  52. package/lib/components/VCheckbox/index.d.ts +291 -0
  53. package/lib/components/VChip/index.d.ts +195 -0
  54. package/lib/components/VChipGroup/index.d.ts +89 -0
  55. package/lib/components/VCode/index.d.ts +19 -0
  56. package/lib/components/VColorPicker/index.d.ts +116 -0
  57. package/lib/components/VCombobox/VCombobox.mjs +1 -1
  58. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  59. package/lib/components/VCombobox/index.d.ts +1590 -0
  60. package/lib/components/VCounter/index.d.ts +223 -0
  61. package/lib/components/VDefaultsProvider/index.d.ts +26 -0
  62. package/lib/components/VDialog/VDialog.css +2 -0
  63. package/lib/components/VDialog/VDialog.mjs +17 -12
  64. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  65. package/lib/components/VDialog/VDialog.sass +2 -0
  66. package/lib/components/VDialog/index.d.ts +859 -0
  67. package/lib/components/VDivider/index.d.ts +22 -0
  68. package/lib/components/VExpansionPanel/VExpansionPanel.css +8 -3
  69. package/lib/components/VExpansionPanel/index.d.ts +206 -0
  70. package/lib/components/VField/VField.css +27 -24
  71. package/lib/components/VField/VField.mjs +1 -1
  72. package/lib/components/VField/VField.mjs.map +1 -1
  73. package/lib/components/VField/VField.sass +23 -21
  74. package/lib/components/VField/index.d.ts +332 -0
  75. package/lib/components/VFileInput/VFileInput.mjs +3 -3
  76. package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
  77. package/lib/components/VFileInput/index.d.ts +236 -0
  78. package/lib/components/VFooter/VFooter.css +7 -0
  79. package/lib/components/VFooter/VFooter.sass +1 -1
  80. package/lib/components/VFooter/_variables.scss +11 -0
  81. package/lib/components/VFooter/index.d.ts +76 -0
  82. package/lib/components/VForm/index.d.ts +72 -0
  83. package/lib/components/VGrid/index.d.ts +154 -0
  84. package/lib/components/VHover/index.d.ts +30 -0
  85. package/lib/components/VIcon/index.d.ts +124 -0
  86. package/lib/components/VImg/VImg.mjs +29 -27
  87. package/lib/components/VImg/VImg.mjs.map +1 -1
  88. package/lib/components/VImg/index.d.ts +89 -0
  89. package/lib/components/VInput/VInput.mjs +4 -4
  90. package/lib/components/VInput/VInput.mjs.map +1 -1
  91. package/lib/components/VInput/index.d.ts +325 -0
  92. package/lib/components/VItemGroup/index.d.ts +210 -0
  93. package/lib/components/VKbd/index.d.ts +19 -0
  94. package/lib/components/VLabel/VLabel.css +4 -1
  95. package/lib/components/VLabel/VLabel.mjs +4 -1
  96. package/lib/components/VLabel/VLabel.mjs.map +1 -1
  97. package/lib/components/VLabel/VLabel.sass +3 -1
  98. package/lib/components/VLabel/index.d.ts +16 -0
  99. package/lib/components/VLayout/index.d.ts +75 -0
  100. package/lib/components/VLazy/index.d.ts +85 -0
  101. package/lib/components/VList/VListItem.css +8 -3
  102. package/lib/components/VList/VListItem.mjs +4 -4
  103. package/lib/components/VList/VListItem.mjs.map +1 -1
  104. package/lib/components/VList/index.d.ts +1250 -0
  105. package/lib/components/VLocaleProvider/index.d.ts +23 -0
  106. package/lib/components/VMain/index.d.ts +26 -0
  107. package/lib/components/VMenu/VMenu.mjs +16 -3
  108. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  109. package/lib/components/VMenu/index.d.ts +817 -0
  110. package/lib/components/VMessages/index.d.ts +234 -0
  111. package/lib/components/VNavigationDrawer/index.d.ts +148 -0
  112. package/lib/components/VNoSsr/index.d.ts +7 -0
  113. package/lib/components/VOverlay/VOverlay.mjs +4 -3
  114. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  115. package/lib/components/VOverlay/index.d.ts +579 -0
  116. package/lib/components/VOverlay/useActivator.mjs +27 -1
  117. package/lib/components/VOverlay/useActivator.mjs.map +1 -1
  118. package/lib/components/VPagination/VPagination.mjs +6 -3
  119. package/lib/components/VPagination/VPagination.mjs.map +1 -1
  120. package/lib/components/VPagination/index.d.ts +247 -0
  121. package/lib/components/VParallax/VParallax.mjs +24 -10
  122. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  123. package/lib/components/VParallax/index.d.ts +18 -0
  124. package/lib/components/VProgressCircular/index.d.ts +68 -0
  125. package/lib/components/VProgressLinear/index.d.ts +101 -0
  126. package/lib/components/VRadio/index.d.ts +103 -0
  127. package/lib/components/VRadioGroup/VRadioGroup.css +2 -3
  128. package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -1
  129. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  130. package/lib/components/VRadioGroup/VRadioGroup.sass +2 -2
  131. package/lib/components/VRadioGroup/_variables.scss +0 -1
  132. package/lib/components/VRadioGroup/index.d.ts +186 -0
  133. package/lib/components/VRangeSlider/VRangeSlider.mjs +12 -2
  134. package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
  135. package/lib/components/VRangeSlider/index.d.ts +242 -0
  136. package/lib/components/VRating/index.d.ts +356 -0
  137. package/lib/components/VResponsive/index.d.ts +23 -0
  138. package/lib/components/VSelect/VSelect.mjs +1 -1
  139. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  140. package/lib/components/VSelect/index.d.ts +1521 -0
  141. package/lib/components/VSelectionControl/VSelectionControl.mjs +2 -1
  142. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  143. package/lib/components/VSelectionControl/index.d.ts +275 -0
  144. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.css +5 -0
  145. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +3 -1
  146. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
  147. package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +5 -0
  148. package/lib/components/VSelectionControlGroup/index.d.ts +47 -0
  149. package/lib/components/VSheet/index.d.ts +68 -0
  150. package/lib/components/VSlideGroup/index.d.ts +151 -0
  151. package/lib/components/VSlider/VSlider.css +7 -2
  152. package/lib/components/VSlider/VSlider.mjs +14 -4
  153. package/lib/components/VSlider/VSlider.mjs.map +1 -1
  154. package/lib/components/VSlider/VSlider.sass +6 -2
  155. package/lib/components/VSlider/VSliderTrack.css +20 -20
  156. package/lib/components/VSlider/VSliderTrack.mjs +7 -3
  157. package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
  158. package/lib/components/VSlider/VSliderTrack.sass +14 -14
  159. package/lib/components/VSlider/_variables.scss +2 -2
  160. package/lib/components/VSlider/index.d.ts +239 -0
  161. package/lib/components/VSlider/slider.mjs +2 -2
  162. package/lib/components/VSlider/slider.mjs.map +1 -1
  163. package/lib/components/VSnackbar/VSnackbar.mjs +3 -2
  164. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  165. package/lib/components/VSnackbar/index.d.ts +892 -0
  166. package/lib/components/VSwitch/index.d.ts +175 -0
  167. package/lib/components/VSystemBar/index.d.ts +61 -0
  168. package/lib/components/VTable/index.d.ts +39 -0
  169. package/lib/components/VTabs/VTab.mjs +1 -0
  170. package/lib/components/VTabs/VTab.mjs.map +1 -1
  171. package/lib/components/VTabs/index.d.ts +178 -0
  172. package/lib/components/VTextField/VTextField.css +2 -3
  173. package/lib/components/VTextField/VTextField.sass +2 -4
  174. package/lib/components/VTextField/index.d.ts +582 -0
  175. package/lib/components/VTextarea/VTextarea.css +5 -3
  176. package/lib/components/VTextarea/VTextarea.mjs +2 -1
  177. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  178. package/lib/components/VTextarea/VTextarea.sass +5 -4
  179. package/lib/components/VTextarea/index.d.ts +218 -0
  180. package/lib/components/VThemeProvider/index.d.ts +24 -0
  181. package/lib/components/VTimeline/VTimeline.css +21 -6
  182. package/lib/components/VTimeline/VTimeline.mjs +6 -1
  183. package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
  184. package/lib/components/VTimeline/VTimeline.sass +16 -2
  185. package/lib/components/VTimeline/_variables.scss +4 -3
  186. package/lib/components/VTimeline/index.d.ts +154 -0
  187. package/lib/components/VToolbar/VToolbar.css +0 -1
  188. package/lib/components/VToolbar/VToolbar.sass +0 -1
  189. package/lib/components/VToolbar/index.d.ts +414 -0
  190. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  191. package/lib/components/VTooltip/index.d.ts +799 -0
  192. package/lib/components/VValidation/index.d.ts +61 -0
  193. package/lib/components/VWindow/index.d.ts +428 -0
  194. package/lib/components/index.d.ts +12037 -10009
  195. package/lib/components/transitions/index.d.ts +454 -0
  196. package/lib/composables/display.mjs +3 -3
  197. package/lib/composables/display.mjs.map +1 -1
  198. package/lib/composables/items.mjs.map +1 -1
  199. package/lib/composables/locale.mjs +10 -3
  200. package/lib/composables/locale.mjs.map +1 -1
  201. package/lib/composables/proxiedModel.mjs +28 -10
  202. package/lib/composables/proxiedModel.mjs.map +1 -1
  203. package/lib/composables/router.mjs +10 -2
  204. package/lib/composables/router.mjs.map +1 -1
  205. package/lib/composables/selectLink.mjs +4 -4
  206. package/lib/composables/selectLink.mjs.map +1 -1
  207. package/lib/composables/theme.mjs +37 -33
  208. package/lib/composables/theme.mjs.map +1 -1
  209. package/lib/composables/validation.mjs +1 -1
  210. package/lib/composables/validation.mjs.map +1 -1
  211. package/lib/entry-bundler.mjs +1 -1
  212. package/lib/framework.mjs +46 -51
  213. package/lib/framework.mjs.map +1 -1
  214. package/lib/index.d.ts +31 -22
  215. package/lib/locale/adapters/vue-i18n.d.ts +35 -0
  216. package/lib/locale/adapters/vue-intl.d.ts +42 -0
  217. package/lib/styles/main.css +73 -73
  218. package/lib/styles/settings/_colors.scss +84 -84
  219. package/lib/styles/tools/_states.sass +8 -3
  220. package/lib/util/getCurrentInstance.mjs +2 -3
  221. package/lib/util/getCurrentInstance.mjs.map +1 -1
  222. package/lib/util/helpers.mjs +6 -11
  223. package/lib/util/helpers.mjs.map +1 -1
  224. package/package.json +4 -2
@@ -0,0 +1,579 @@
1
+ import * as vue from 'vue';
2
+ import { Ref, VNodeChild, PropType } from 'vue';
3
+
4
+ interface ScrollStrategyData {
5
+ root: Ref<HTMLElement | undefined>;
6
+ contentEl: Ref<HTMLElement | undefined>;
7
+ activatorEl: Ref<HTMLElement | undefined>;
8
+ isActive: Ref<boolean>;
9
+ updateLocation: Ref<((e: Event) => void) | undefined>;
10
+ }
11
+ declare const scrollStrategies: {
12
+ none: null;
13
+ close: typeof closeScrollStrategy;
14
+ block: typeof blockScrollStrategy;
15
+ reposition: typeof repositionScrollStrategy;
16
+ };
17
+ interface StrategyProps$1 {
18
+ scrollStrategy: keyof typeof scrollStrategies | ((data: ScrollStrategyData, props?: StrategyProps$1) => void);
19
+ contained: boolean | undefined;
20
+ }
21
+ declare function closeScrollStrategy(data: ScrollStrategyData): void;
22
+ declare function blockScrollStrategy(data: ScrollStrategyData, props: StrategyProps$1): void;
23
+ declare function repositionScrollStrategy(data: ScrollStrategyData): void;
24
+
25
+ declare const block: readonly ["top", "bottom"];
26
+ declare const inline: readonly ["start", "end", "left", "right"];
27
+ declare type Tblock = typeof block[number];
28
+ declare type Tinline = typeof inline[number];
29
+ declare type Anchor = Tblock | Tinline | 'center' | 'center center' | `${Tblock} ${Tinline | 'center'}` | `${Tinline} ${Tblock | 'center'}`;
30
+
31
+ declare type SlotsToProps<T extends Record<string, Slot>> = {
32
+ $children: () => (T['default'] | VNodeChild | {
33
+ [K in keyof T]?: T[K];
34
+ });
35
+ 'v-slots': new () => {
36
+ [K in keyof T]?: T[K] | false;
37
+ };
38
+ };
39
+ declare type Slot<T extends any[] = any[]> = (...args: T) => VNodeChild;
40
+ declare type MakeSlots<T extends Record<string, any[]>> = {
41
+ [K in keyof T]?: Slot<T[K]>;
42
+ };
43
+
44
+ interface LocationStrategyData {
45
+ contentEl: Ref<HTMLElement | undefined>;
46
+ activatorEl: Ref<HTMLElement | undefined>;
47
+ isActive: Ref<boolean>;
48
+ isRtl: Ref<boolean>;
49
+ }
50
+ declare const locationStrategies: {
51
+ static: typeof staticLocationStrategy;
52
+ connected: typeof connectedLocationStrategy;
53
+ };
54
+ interface StrategyProps {
55
+ locationStrategy: keyof typeof locationStrategies | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => undefined | {
56
+ updateLocation: (e: Event) => void;
57
+ });
58
+ location: Anchor;
59
+ origin: Anchor | 'auto' | 'overlap';
60
+ offset?: number | string | number[];
61
+ maxHeight?: number | string;
62
+ maxWidth?: number | string;
63
+ minHeight?: number | string;
64
+ minWidth?: number | string;
65
+ }
66
+ declare function staticLocationStrategy(): void;
67
+ declare function connectedLocationStrategy(data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>): {
68
+ updateLocation: () => void;
69
+ };
70
+
71
+ declare type OverlaySlots = MakeSlots<{
72
+ default: [{
73
+ isActive: Ref<boolean>;
74
+ }];
75
+ activator: [{
76
+ isActive: boolean;
77
+ props: Record<string, any>;
78
+ }];
79
+ }>;
80
+ declare const VOverlay: {
81
+ new (...args: any[]): {
82
+ $: vue.ComponentInternalInstance;
83
+ $data: {};
84
+ $props: Partial<{
85
+ absolute: boolean;
86
+ location: Anchor;
87
+ origin: "auto" | Anchor | "overlap";
88
+ transition: string | boolean | (vue.TransitionProps & {
89
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
90
+ });
91
+ zIndex: string | number;
92
+ eager: boolean;
93
+ disabled: boolean;
94
+ modelValue: boolean;
95
+ activatorProps: Record<string, any>;
96
+ openOnClick: boolean;
97
+ openOnHover: boolean;
98
+ openOnFocus: boolean;
99
+ closeOnContentClick: boolean;
100
+ locationStrategy: "connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
101
+ updateLocation: (e: Event) => void;
102
+ } | undefined);
103
+ scrollStrategy: "none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void);
104
+ contained: boolean;
105
+ noClickAnimation: boolean;
106
+ persistent: boolean;
107
+ closeOnBack: boolean;
108
+ scrim: string | boolean;
109
+ }> & Omit<Readonly<vue.ExtractPropTypes<{
110
+ transition: {
111
+ type: PropType<string | boolean | (vue.TransitionProps & {
112
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
113
+ })>;
114
+ default: string;
115
+ validator: (val: unknown) => boolean;
116
+ };
117
+ theme: StringConstructor;
118
+ scrollStrategy: {
119
+ type: PropType<"none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void)>;
120
+ default: string;
121
+ validator: (val: any) => boolean;
122
+ };
123
+ locationStrategy: {
124
+ type: PropType<"connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
125
+ updateLocation: (e: Event) => void;
126
+ } | undefined)>;
127
+ default: string;
128
+ validator: (val: any) => boolean;
129
+ };
130
+ location: {
131
+ type: PropType<Anchor>;
132
+ default: string;
133
+ };
134
+ origin: {
135
+ type: PropType<"auto" | Anchor | "overlap">;
136
+ default: string;
137
+ };
138
+ offset: PropType<string | number | number[] | undefined>;
139
+ eager: BooleanConstructor;
140
+ height: (StringConstructor | NumberConstructor)[];
141
+ maxHeight: (StringConstructor | NumberConstructor)[];
142
+ maxWidth: (StringConstructor | NumberConstructor)[];
143
+ minHeight: (StringConstructor | NumberConstructor)[];
144
+ minWidth: (StringConstructor | NumberConstructor)[];
145
+ width: (StringConstructor | NumberConstructor)[];
146
+ closeDelay: (StringConstructor | NumberConstructor)[];
147
+ openDelay: (StringConstructor | NumberConstructor)[];
148
+ activator: PropType<string | Element | vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | undefined>;
149
+ activatorProps: {
150
+ type: PropType<Record<string, any>>;
151
+ default: () => {};
152
+ };
153
+ openOnClick: {
154
+ type: BooleanConstructor;
155
+ default: undefined;
156
+ };
157
+ openOnHover: BooleanConstructor;
158
+ openOnFocus: {
159
+ type: BooleanConstructor;
160
+ default: undefined;
161
+ };
162
+ closeOnContentClick: BooleanConstructor;
163
+ absolute: BooleanConstructor;
164
+ attach: PropType<string | boolean | Element>;
165
+ closeOnBack: {
166
+ type: BooleanConstructor;
167
+ default: boolean;
168
+ };
169
+ contained: BooleanConstructor;
170
+ contentClass: null;
171
+ contentProps: null;
172
+ disabled: BooleanConstructor;
173
+ noClickAnimation: BooleanConstructor;
174
+ modelValue: BooleanConstructor;
175
+ persistent: BooleanConstructor;
176
+ scrim: {
177
+ type: (StringConstructor | BooleanConstructor)[];
178
+ default: boolean;
179
+ };
180
+ zIndex: {
181
+ type: (StringConstructor | NumberConstructor)[];
182
+ default: number;
183
+ };
184
+ } & SlotsToProps<MakeSlots<{
185
+ default: [{
186
+ isActive: Ref<boolean>;
187
+ }];
188
+ activator: [{
189
+ isActive: boolean;
190
+ props: Record<string, any>;
191
+ }];
192
+ }>>>> & {
193
+ onAfterLeave?: (() => any) | undefined;
194
+ "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
195
+ "onClick:outside"?: ((e: MouseEvent) => any) | undefined;
196
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "absolute" | "location" | "origin" | "transition" | "zIndex" | "eager" | "disabled" | "modelValue" | "activatorProps" | "openOnClick" | "openOnHover" | "openOnFocus" | "closeOnContentClick" | "locationStrategy" | "scrollStrategy" | "contained" | "noClickAnimation" | "persistent" | "closeOnBack" | "scrim">;
197
+ $attrs: {
198
+ [x: string]: unknown;
199
+ };
200
+ $refs: {
201
+ [x: string]: unknown;
202
+ };
203
+ $slots: Readonly<{
204
+ [name: string]: vue.Slot | undefined;
205
+ }>;
206
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
207
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
208
+ $emit: ((event: "update:modelValue", value: boolean) => void) & ((event: "click:outside", e: MouseEvent) => void) & ((event: "afterLeave") => void);
209
+ $el: any;
210
+ $options: vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<{
211
+ transition: {
212
+ type: PropType<string | boolean | (vue.TransitionProps & {
213
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
214
+ })>;
215
+ default: string;
216
+ validator: (val: unknown) => boolean;
217
+ };
218
+ theme: StringConstructor;
219
+ scrollStrategy: {
220
+ type: PropType<"none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void)>;
221
+ default: string;
222
+ validator: (val: any) => boolean;
223
+ };
224
+ locationStrategy: {
225
+ type: PropType<"connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
226
+ updateLocation: (e: Event) => void;
227
+ } | undefined)>;
228
+ default: string;
229
+ validator: (val: any) => boolean;
230
+ };
231
+ location: {
232
+ type: PropType<Anchor>;
233
+ default: string;
234
+ };
235
+ origin: {
236
+ type: PropType<"auto" | Anchor | "overlap">;
237
+ default: string;
238
+ };
239
+ offset: PropType<string | number | number[] | undefined>;
240
+ eager: BooleanConstructor;
241
+ height: (StringConstructor | NumberConstructor)[];
242
+ maxHeight: (StringConstructor | NumberConstructor)[];
243
+ maxWidth: (StringConstructor | NumberConstructor)[];
244
+ minHeight: (StringConstructor | NumberConstructor)[];
245
+ minWidth: (StringConstructor | NumberConstructor)[];
246
+ width: (StringConstructor | NumberConstructor)[];
247
+ closeDelay: (StringConstructor | NumberConstructor)[];
248
+ openDelay: (StringConstructor | NumberConstructor)[];
249
+ activator: PropType<string | Element | vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | undefined>;
250
+ activatorProps: {
251
+ type: PropType<Record<string, any>>;
252
+ default: () => {};
253
+ };
254
+ openOnClick: {
255
+ type: BooleanConstructor;
256
+ default: undefined;
257
+ };
258
+ openOnHover: BooleanConstructor;
259
+ openOnFocus: {
260
+ type: BooleanConstructor;
261
+ default: undefined;
262
+ };
263
+ closeOnContentClick: BooleanConstructor;
264
+ absolute: BooleanConstructor;
265
+ attach: PropType<string | boolean | Element>;
266
+ closeOnBack: {
267
+ type: BooleanConstructor;
268
+ default: boolean;
269
+ };
270
+ contained: BooleanConstructor;
271
+ contentClass: null;
272
+ contentProps: null;
273
+ disabled: BooleanConstructor;
274
+ noClickAnimation: BooleanConstructor;
275
+ modelValue: BooleanConstructor;
276
+ persistent: BooleanConstructor;
277
+ scrim: {
278
+ type: (StringConstructor | BooleanConstructor)[];
279
+ default: boolean;
280
+ };
281
+ zIndex: {
282
+ type: (StringConstructor | NumberConstructor)[];
283
+ default: number;
284
+ };
285
+ } & SlotsToProps<MakeSlots<{
286
+ default: [{
287
+ isActive: Ref<boolean>;
288
+ }];
289
+ activator: [{
290
+ isActive: boolean;
291
+ props: Record<string, any>;
292
+ }];
293
+ }>>>> & {
294
+ onAfterLeave?: (() => any) | undefined;
295
+ "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
296
+ "onClick:outside"?: ((e: MouseEvent) => any) | undefined;
297
+ }, {
298
+ activatorEl: Ref<HTMLElement | undefined>;
299
+ animateClick: () => void;
300
+ contentEl: Ref<HTMLElement | undefined>;
301
+ globalTop: Readonly<Ref<boolean>>;
302
+ localTop: vue.ComputedRef<boolean>;
303
+ updateLocation: Ref<((e: Event) => void) | undefined>;
304
+ }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
305
+ 'click:outside': (e: MouseEvent) => boolean;
306
+ 'update:modelValue': (value: boolean) => boolean;
307
+ afterLeave: () => boolean;
308
+ }, string, {
309
+ absolute: boolean;
310
+ location: Anchor;
311
+ origin: "auto" | Anchor | "overlap";
312
+ transition: string | boolean | (vue.TransitionProps & {
313
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
314
+ });
315
+ zIndex: string | number;
316
+ eager: boolean;
317
+ disabled: boolean;
318
+ modelValue: boolean;
319
+ activatorProps: Record<string, any>;
320
+ openOnClick: boolean;
321
+ openOnHover: boolean;
322
+ openOnFocus: boolean;
323
+ closeOnContentClick: boolean;
324
+ locationStrategy: "connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
325
+ updateLocation: (e: Event) => void;
326
+ } | undefined);
327
+ scrollStrategy: "none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void);
328
+ contained: boolean;
329
+ noClickAnimation: boolean;
330
+ persistent: boolean;
331
+ closeOnBack: boolean;
332
+ scrim: string | boolean;
333
+ }> & {
334
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
335
+ created?: ((() => void) | (() => void)[]) | undefined;
336
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
337
+ mounted?: ((() => void) | (() => void)[]) | undefined;
338
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
339
+ updated?: ((() => void) | (() => void)[]) | undefined;
340
+ activated?: ((() => void) | (() => void)[]) | undefined;
341
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
342
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
343
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
344
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
345
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
346
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
347
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
348
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void)[]) | undefined;
349
+ };
350
+ $forceUpdate: () => void;
351
+ $nextTick: typeof vue.nextTick;
352
+ $watch(source: string | Function, cb: Function, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
353
+ } & Readonly<vue.ExtractPropTypes<{
354
+ transition: {
355
+ type: PropType<string | boolean | (vue.TransitionProps & {
356
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
357
+ })>;
358
+ default: string;
359
+ validator: (val: unknown) => boolean;
360
+ };
361
+ theme: StringConstructor;
362
+ scrollStrategy: {
363
+ type: PropType<"none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void)>;
364
+ default: string;
365
+ validator: (val: any) => boolean;
366
+ };
367
+ locationStrategy: {
368
+ type: PropType<"connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
369
+ updateLocation: (e: Event) => void;
370
+ } | undefined)>;
371
+ default: string;
372
+ validator: (val: any) => boolean;
373
+ };
374
+ location: {
375
+ type: PropType<Anchor>;
376
+ default: string;
377
+ };
378
+ origin: {
379
+ type: PropType<"auto" | Anchor | "overlap">;
380
+ default: string;
381
+ };
382
+ offset: PropType<string | number | number[] | undefined>;
383
+ eager: BooleanConstructor;
384
+ height: (StringConstructor | NumberConstructor)[];
385
+ maxHeight: (StringConstructor | NumberConstructor)[];
386
+ maxWidth: (StringConstructor | NumberConstructor)[];
387
+ minHeight: (StringConstructor | NumberConstructor)[];
388
+ minWidth: (StringConstructor | NumberConstructor)[];
389
+ width: (StringConstructor | NumberConstructor)[];
390
+ closeDelay: (StringConstructor | NumberConstructor)[];
391
+ openDelay: (StringConstructor | NumberConstructor)[];
392
+ activator: PropType<string | Element | vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | undefined>;
393
+ activatorProps: {
394
+ type: PropType<Record<string, any>>;
395
+ default: () => {};
396
+ };
397
+ openOnClick: {
398
+ type: BooleanConstructor;
399
+ default: undefined;
400
+ };
401
+ openOnHover: BooleanConstructor;
402
+ openOnFocus: {
403
+ type: BooleanConstructor;
404
+ default: undefined;
405
+ };
406
+ closeOnContentClick: BooleanConstructor;
407
+ absolute: BooleanConstructor;
408
+ attach: PropType<string | boolean | Element>;
409
+ closeOnBack: {
410
+ type: BooleanConstructor;
411
+ default: boolean;
412
+ };
413
+ contained: BooleanConstructor;
414
+ contentClass: null;
415
+ contentProps: null;
416
+ disabled: BooleanConstructor;
417
+ noClickAnimation: BooleanConstructor;
418
+ modelValue: BooleanConstructor;
419
+ persistent: BooleanConstructor;
420
+ scrim: {
421
+ type: (StringConstructor | BooleanConstructor)[];
422
+ default: boolean;
423
+ };
424
+ zIndex: {
425
+ type: (StringConstructor | NumberConstructor)[];
426
+ default: number;
427
+ };
428
+ } & SlotsToProps<MakeSlots<{
429
+ default: [{
430
+ isActive: Ref<boolean>;
431
+ }];
432
+ activator: [{
433
+ isActive: boolean;
434
+ props: Record<string, any>;
435
+ }];
436
+ }>>>> & {
437
+ onAfterLeave?: (() => any) | undefined;
438
+ "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
439
+ "onClick:outside"?: ((e: MouseEvent) => any) | undefined;
440
+ } & vue.ShallowUnwrapRef<{
441
+ activatorEl: Ref<HTMLElement | undefined>;
442
+ animateClick: () => void;
443
+ contentEl: Ref<HTMLElement | undefined>;
444
+ globalTop: Readonly<Ref<boolean>>;
445
+ localTop: vue.ComputedRef<boolean>;
446
+ updateLocation: Ref<((e: Event) => void) | undefined>;
447
+ }> & {} & vue.ComponentCustomProperties;
448
+ __isFragment?: undefined;
449
+ __isTeleport?: undefined;
450
+ __isSuspense?: undefined;
451
+ } & vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<{
452
+ transition: {
453
+ type: PropType<string | boolean | (vue.TransitionProps & {
454
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
455
+ })>;
456
+ default: string;
457
+ validator: (val: unknown) => boolean;
458
+ };
459
+ theme: StringConstructor;
460
+ scrollStrategy: {
461
+ type: PropType<"none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void)>;
462
+ default: string;
463
+ validator: (val: any) => boolean;
464
+ };
465
+ locationStrategy: {
466
+ type: PropType<"connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
467
+ updateLocation: (e: Event) => void;
468
+ } | undefined)>;
469
+ default: string;
470
+ validator: (val: any) => boolean;
471
+ };
472
+ location: {
473
+ type: PropType<Anchor>;
474
+ default: string;
475
+ };
476
+ origin: {
477
+ type: PropType<"auto" | Anchor | "overlap">;
478
+ default: string;
479
+ };
480
+ offset: PropType<string | number | number[] | undefined>;
481
+ eager: BooleanConstructor;
482
+ height: (StringConstructor | NumberConstructor)[];
483
+ maxHeight: (StringConstructor | NumberConstructor)[];
484
+ maxWidth: (StringConstructor | NumberConstructor)[];
485
+ minHeight: (StringConstructor | NumberConstructor)[];
486
+ minWidth: (StringConstructor | NumberConstructor)[];
487
+ width: (StringConstructor | NumberConstructor)[];
488
+ closeDelay: (StringConstructor | NumberConstructor)[];
489
+ openDelay: (StringConstructor | NumberConstructor)[];
490
+ activator: PropType<string | Element | vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | undefined>;
491
+ activatorProps: {
492
+ type: PropType<Record<string, any>>;
493
+ default: () => {};
494
+ };
495
+ openOnClick: {
496
+ type: BooleanConstructor;
497
+ default: undefined;
498
+ };
499
+ openOnHover: BooleanConstructor;
500
+ openOnFocus: {
501
+ type: BooleanConstructor;
502
+ default: undefined;
503
+ };
504
+ closeOnContentClick: BooleanConstructor;
505
+ absolute: BooleanConstructor;
506
+ attach: PropType<string | boolean | Element>;
507
+ closeOnBack: {
508
+ type: BooleanConstructor;
509
+ default: boolean;
510
+ };
511
+ contained: BooleanConstructor;
512
+ contentClass: null;
513
+ contentProps: null;
514
+ disabled: BooleanConstructor;
515
+ noClickAnimation: BooleanConstructor;
516
+ modelValue: BooleanConstructor;
517
+ persistent: BooleanConstructor;
518
+ scrim: {
519
+ type: (StringConstructor | BooleanConstructor)[];
520
+ default: boolean;
521
+ };
522
+ zIndex: {
523
+ type: (StringConstructor | NumberConstructor)[];
524
+ default: number;
525
+ };
526
+ } & SlotsToProps<MakeSlots<{
527
+ default: [{
528
+ isActive: Ref<boolean>;
529
+ }];
530
+ activator: [{
531
+ isActive: boolean;
532
+ props: Record<string, any>;
533
+ }];
534
+ }>>>> & {
535
+ onAfterLeave?: (() => any) | undefined;
536
+ "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
537
+ "onClick:outside"?: ((e: MouseEvent) => any) | undefined;
538
+ }, {
539
+ activatorEl: Ref<HTMLElement | undefined>;
540
+ animateClick: () => void;
541
+ contentEl: Ref<HTMLElement | undefined>;
542
+ globalTop: Readonly<Ref<boolean>>;
543
+ localTop: vue.ComputedRef<boolean>;
544
+ updateLocation: Ref<((e: Event) => void) | undefined>;
545
+ }, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
546
+ 'click:outside': (e: MouseEvent) => boolean;
547
+ 'update:modelValue': (value: boolean) => boolean;
548
+ afterLeave: () => boolean;
549
+ }, string, {
550
+ absolute: boolean;
551
+ location: Anchor;
552
+ origin: "auto" | Anchor | "overlap";
553
+ transition: string | boolean | (vue.TransitionProps & {
554
+ component?: vue.Component<any, any, any, vue.ComputedOptions, vue.MethodOptions> | undefined;
555
+ });
556
+ zIndex: string | number;
557
+ eager: boolean;
558
+ disabled: boolean;
559
+ modelValue: boolean;
560
+ activatorProps: Record<string, any>;
561
+ openOnClick: boolean;
562
+ openOnHover: boolean;
563
+ openOnFocus: boolean;
564
+ closeOnContentClick: boolean;
565
+ locationStrategy: "connected" | "static" | ((data: LocationStrategyData, props: StrategyProps, contentStyles: Ref<Record<string, string>>) => {
566
+ updateLocation: (e: Event) => void;
567
+ } | undefined);
568
+ scrollStrategy: "none" | "block" | "close" | "reposition" | ((data: ScrollStrategyData, props?: StrategyProps$1 | undefined) => void);
569
+ contained: boolean;
570
+ noClickAnimation: boolean;
571
+ persistent: boolean;
572
+ closeOnBack: boolean;
573
+ scrim: string | boolean;
574
+ }> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new () => {
575
+ $slots: OverlaySlots;
576
+ });
577
+ declare type VOverlay = InstanceType<typeof VOverlay>;
578
+
579
+ export { VOverlay };
@@ -31,6 +31,7 @@ export function useActivator(props, _ref) {
31
31
  const activatorEl = ref();
32
32
  let isHovered = false;
33
33
  let isFocused = false;
34
+ let firstEnter = true;
34
35
  const openOnFocus = computed(() => props.openOnFocus || props.openOnFocus == null && props.openOnHover);
35
36
  const openOnClick = computed(() => props.openOnClick || props.openOnClick == null && !props.openOnHover && !openOnFocus.value);
36
37
  const {
@@ -38,6 +39,10 @@ export function useActivator(props, _ref) {
38
39
  runCloseDelay
39
40
  } = useDelay(props, value => {
40
41
  if (value === (props.openOnHover && isHovered || openOnFocus.value && isFocused) && !(props.openOnHover && isActive.value && !isTop.value)) {
42
+ if (isActive.value !== value) {
43
+ firstEnter = true;
44
+ }
45
+
41
46
  isActive.value = value;
42
47
  }
43
48
  });
@@ -114,6 +119,26 @@ export function useActivator(props, _ref) {
114
119
 
115
120
  return events;
116
121
  });
122
+ const scrimEvents = computed(() => {
123
+ const events = {};
124
+
125
+ if (props.openOnHover) {
126
+ events.mouseenter = () => {
127
+ if (firstEnter) {
128
+ isHovered = true;
129
+ firstEnter = false;
130
+ runOpenDelay();
131
+ }
132
+ };
133
+
134
+ events.mouseleave = () => {
135
+ isHovered = false;
136
+ runCloseDelay();
137
+ };
138
+ }
139
+
140
+ return events;
141
+ });
117
142
  watch(isTop, val => {
118
143
  if (val && (props.openOnHover && !isHovered && (!openOnFocus.value || !isFocused) || openOnFocus.value && !isFocused && (!props.openOnHover || !isHovered))) {
119
144
  isActive.value = false;
@@ -149,7 +174,8 @@ export function useActivator(props, _ref) {
149
174
  activatorEl,
150
175
  activatorRef,
151
176
  activatorEvents,
152
- contentEvents
177
+ contentEvents,
178
+ scrimEvents
153
179
  };
154
180
  }
155
181