vuetify 3.1.10 → 3.1.11

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 (200) hide show
  1. package/dist/json/attributes.json +203 -27
  2. package/dist/json/importMap.json +98 -98
  3. package/dist/json/tags.json +46 -2
  4. package/dist/json/web-types.json +481 -49
  5. package/dist/vuetify-labs.css +224 -204
  6. package/dist/vuetify-labs.d.ts +56923 -14294
  7. package/dist/vuetify-labs.esm.js +121 -129
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +121 -129
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +47 -39
  12. package/dist/vuetify.d.ts +55374 -15927
  13. package/dist/vuetify.esm.js +118 -129
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +118 -129
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +640 -642
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.ts +6 -9
  21. package/lib/blueprints/md1.d.ts +6 -9
  22. package/lib/blueprints/md2.d.ts +6 -9
  23. package/lib/blueprints/md3.d.ts +6 -9
  24. package/lib/blueprints/md3.mjs +6 -0
  25. package/lib/blueprints/md3.mjs.map +1 -1
  26. package/lib/components/VAlert/index.d.ts +509 -83
  27. package/lib/components/VApp/VApp.css +1 -0
  28. package/lib/components/VApp/VApp.sass +1 -0
  29. package/lib/components/VApp/index.d.ts +158 -20
  30. package/lib/components/VAppBar/VAppBar.mjs +2 -2
  31. package/lib/components/VAppBar/VAppBar.mjs.map +1 -1
  32. package/lib/components/VAppBar/index.d.ts +616 -110
  33. package/lib/components/VAutocomplete/VAutocomplete.mjs +2 -2
  34. package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
  35. package/lib/components/VAutocomplete/index.d.ts +1656 -130
  36. package/lib/components/VAvatar/index.d.ts +205 -29
  37. package/lib/components/VBadge/index.d.ts +284 -42
  38. package/lib/components/VBanner/index.d.ts +478 -84
  39. package/lib/components/VBottomNavigation/index.d.ts +321 -40
  40. package/lib/components/VBreadcrumbs/index.d.ts +325 -45
  41. package/lib/components/VBtn/VBtn.css +0 -5
  42. package/lib/components/VBtn/VBtn.mjs +40 -39
  43. package/lib/components/VBtn/VBtn.mjs.map +1 -1
  44. package/lib/components/VBtn/VBtn.sass +0 -7
  45. package/lib/components/VBtn/_variables.scss +0 -2
  46. package/lib/components/VBtn/index.d.ts +452 -69
  47. package/lib/components/VBtnGroup/VBtnGroup.mjs +1 -7
  48. package/lib/components/VBtnGroup/VBtnGroup.mjs.map +1 -1
  49. package/lib/components/VBtnGroup/index.d.ts +185 -26
  50. package/lib/components/VBtnToggle/VBtnToggle.mjs +2 -2
  51. package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
  52. package/lib/components/VBtnToggle/index.d.ts +245 -35
  53. package/lib/components/VCard/index.d.ts +938 -172
  54. package/lib/components/VCarousel/index.d.ts +561 -123
  55. package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
  56. package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
  57. package/lib/components/VCheckbox/VCheckboxBtn.mjs +1 -4
  58. package/lib/components/VCheckbox/VCheckboxBtn.mjs.map +1 -1
  59. package/lib/components/VCheckbox/index.d.ts +831 -147
  60. package/lib/components/VChip/index.d.ts +473 -75
  61. package/lib/components/VChipGroup/index.d.ts +227 -32
  62. package/lib/components/VCode/index.d.ts +109 -16
  63. package/lib/components/VColorPicker/index.d.ts +284 -20
  64. package/lib/components/VCombobox/VCombobox.mjs +2 -2
  65. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  66. package/lib/components/VCombobox/index.d.ts +1668 -130
  67. package/lib/components/VCounter/index.d.ts +1894 -87
  68. package/lib/components/VDefaultsProvider/index.d.ts +131 -22
  69. package/lib/components/VDialog/VDialog.css +31 -24
  70. package/lib/components/VDialog/VDialog.mjs +2 -2
  71. package/lib/components/VDialog/VDialog.mjs.map +1 -1
  72. package/lib/components/VDialog/VDialog.sass +19 -12
  73. package/lib/components/VDialog/index.d.ts +2362 -146
  74. package/lib/components/VDivider/index.d.ts +130 -23
  75. package/lib/components/VExpansionPanel/index.d.ts +719 -119
  76. package/lib/components/VField/index.d.ts +163 -21
  77. package/lib/components/VFileInput/index.d.ts +1038 -104
  78. package/lib/components/VFooter/index.d.ts +203 -28
  79. package/lib/components/VForm/index.d.ts +204 -23
  80. package/lib/components/VGrid/VCol.mjs +6 -5
  81. package/lib/components/VGrid/VCol.mjs.map +1 -1
  82. package/lib/components/VGrid/VRow.mjs +4 -4
  83. package/lib/components/VGrid/VRow.mjs.map +1 -1
  84. package/lib/components/VGrid/index.d.ts +733 -76
  85. package/lib/components/VHover/index.d.ts +182 -35
  86. package/lib/components/VIcon/index.d.ts +494 -50
  87. package/lib/components/VImg/index.d.ts +275 -46
  88. package/lib/components/VInput/index.d.ts +315 -53
  89. package/lib/components/VItemGroup/index.d.ts +308 -52
  90. package/lib/components/VKbd/VKbd.css +1 -0
  91. package/lib/components/VKbd/VKbd.sass +1 -0
  92. package/lib/components/VKbd/_variables.scss +1 -0
  93. package/lib/components/VKbd/index.d.ts +109 -16
  94. package/lib/components/VLabel/index.d.ts +113 -20
  95. package/lib/components/VLayout/index.d.ts +296 -41
  96. package/lib/components/VLazy/VLazy.mjs +4 -1
  97. package/lib/components/VLazy/VLazy.mjs.map +1 -1
  98. package/lib/components/VLazy/index.d.ts +219 -30
  99. package/lib/components/VList/VListChildren.mjs +2 -2
  100. package/lib/components/VList/VListChildren.mjs.map +1 -1
  101. package/lib/components/VList/VListGroup.mjs +1 -4
  102. package/lib/components/VList/VListGroup.mjs.map +1 -1
  103. package/lib/components/VList/index.d.ts +1461 -223
  104. package/lib/components/VLocaleProvider/index.d.ts +121 -20
  105. package/lib/components/VMain/index.d.ts +118 -17
  106. package/lib/components/VMenu/VMenu.css +4 -4
  107. package/lib/components/VMenu/VMenu.mjs +2 -2
  108. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  109. package/lib/components/VMenu/VMenu.sass +1 -1
  110. package/lib/components/VMenu/index.d.ts +2368 -142
  111. package/lib/components/VMessages/index.d.ts +1921 -98
  112. package/lib/components/VNavigationDrawer/index.d.ts +379 -56
  113. package/lib/components/VOverlay/VOverlay.css +2 -2
  114. package/lib/components/VOverlay/VOverlay.mjs +1 -4
  115. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  116. package/lib/components/VOverlay/VOverlay.sass +1 -1
  117. package/lib/components/VOverlay/_variables.scss +1 -1
  118. package/lib/components/VOverlay/index.d.ts +519 -85
  119. package/lib/components/VPagination/index.d.ts +502 -68
  120. package/lib/components/VParallax/VParallax.mjs +3 -3
  121. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  122. package/lib/components/VParallax/index.d.ts +141 -28
  123. package/lib/components/VProgressCircular/index.d.ts +186 -25
  124. package/lib/components/VProgressLinear/index.d.ts +319 -48
  125. package/lib/components/VRadio/index.d.ts +313 -57
  126. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -6
  127. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  128. package/lib/components/VRadioGroup/index.d.ts +463 -83
  129. package/lib/components/VRangeSlider/index.d.ts +528 -80
  130. package/lib/components/VRating/index.d.ts +305 -43
  131. package/lib/components/VResponsive/index.d.ts +142 -27
  132. package/lib/components/VSelect/VSelect.mjs +2 -2
  133. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  134. package/lib/components/VSelect/index.d.ts +3060 -328
  135. package/lib/components/VSelectionControl/VSelectionControl.mjs +1 -4
  136. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  137. package/lib/components/VSelectionControl/index.d.ts +76 -4
  138. package/lib/components/VSelectionControlGroup/index.d.ts +242 -38
  139. package/lib/components/VSheet/VSheet.mjs +1 -7
  140. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  141. package/lib/components/VSheet/index.d.ts +194 -31
  142. package/lib/components/VSlideGroup/index.d.ts +475 -83
  143. package/lib/components/VSlider/index.d.ts +521 -79
  144. package/lib/components/VSlider/slider.mjs +2 -5
  145. package/lib/components/VSlider/slider.mjs.map +1 -1
  146. package/lib/components/VSnackbar/VSnackbar.mjs +2 -2
  147. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  148. package/lib/components/VSnackbar/index.d.ts +1219 -81
  149. package/lib/components/VSwitch/VSwitch.mjs +2 -2
  150. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  151. package/lib/components/VSwitch/index.d.ts +498 -92
  152. package/lib/components/VSystemBar/index.d.ts +184 -27
  153. package/lib/components/VTable/index.d.ts +190 -35
  154. package/lib/components/VTabs/VTab.mjs +7 -23
  155. package/lib/components/VTabs/VTab.mjs.map +1 -1
  156. package/lib/components/VTabs/index.d.ts +623 -71
  157. package/lib/components/VTextField/VTextField.mjs +8 -5
  158. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  159. package/lib/components/VTextField/index.d.ts +1404 -106
  160. package/lib/components/VTextarea/VTextarea.mjs +7 -1
  161. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  162. package/lib/components/VTextarea/index.d.ts +1014 -102
  163. package/lib/components/VThemeProvider/index.d.ts +124 -19
  164. package/lib/components/VTimeline/index.d.ts +441 -71
  165. package/lib/components/VToolbar/VToolbar.mjs +1 -4
  166. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  167. package/lib/components/VToolbar/index.d.ts +542 -93
  168. package/lib/components/VTooltip/VTooltip.css +3 -3
  169. package/lib/components/VTooltip/VTooltip.mjs +2 -2
  170. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  171. package/lib/components/VTooltip/VTooltip.sass +1 -1
  172. package/lib/components/VTooltip/index.d.ts +1263 -81
  173. package/lib/components/VValidation/index.d.ts +201 -30
  174. package/lib/components/VWindow/index.d.ts +527 -95
  175. package/lib/components/index.d.ts +55131 -15681
  176. package/lib/components/transitions/index.d.ts +2097 -308
  177. package/lib/composables/display.mjs +2 -0
  178. package/lib/composables/display.mjs.map +1 -1
  179. package/lib/composables/form.mjs.map +1 -1
  180. package/lib/entry-bundler.mjs +1 -1
  181. package/lib/framework.mjs +1 -1
  182. package/lib/index.d.ts +32 -35
  183. package/lib/labs/VDataTable/VDataTable.css +12 -0
  184. package/lib/labs/VDataTable/VDataTable.sass +6 -0
  185. package/lib/labs/VDataTable/VDataTableRow.mjs +2 -0
  186. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  187. package/lib/labs/VDataTable/VDataTableRows.mjs +1 -0
  188. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  189. package/lib/labs/VDataTable/index.d.ts +4176 -1016
  190. package/lib/labs/VVirtualScroll/index.d.ts +32 -1
  191. package/lib/labs/components.d.ts +4212 -1026
  192. package/lib/styles/main.css +4 -0
  193. package/lib/styles/settings/_utilities.scss +7 -0
  194. package/lib/util/animation.mjs +8 -1
  195. package/lib/util/animation.mjs.map +1 -1
  196. package/lib/util/defineComponent.mjs +12 -5
  197. package/lib/util/defineComponent.mjs.map +1 -1
  198. package/lib/util/helpers.mjs +4 -0
  199. package/lib/util/helpers.mjs.map +1 -1
  200. package/package.json +3 -2
@@ -1,30 +1,137 @@
1
1
  import * as vue from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes } from 'vue';
2
3
 
3
- declare const VSystemBar: vue.DefineComponent<{
4
- window: boolean;
5
- absolute: boolean;
6
- order: string | number;
7
- tag: string;
8
- } & {
9
- height?: string | number | undefined;
10
- name?: string | undefined;
11
- color?: string | undefined;
12
- elevation?: string | number | undefined;
13
- theme?: string | undefined;
14
- rounded?: string | number | boolean | undefined;
15
- } & {
16
- $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
17
- default?: (() => vue.VNodeChild) | undefined;
18
- };
19
- $slots?: {
20
- default?: (() => vue.VNodeChild) | undefined;
21
- } | undefined;
22
- 'v-slots'?: {
23
- default?: false | (() => vue.VNodeChild) | undefined;
24
- } | undefined;
25
- } & {
26
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
27
- }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
7
+
8
+ declare const VSystemBar: {
9
+ new (...args: any[]): {
10
+ $: vue.ComponentInternalInstance;
11
+ $data: {};
12
+ $props: Partial<{
13
+ window: boolean;
14
+ absolute: boolean;
15
+ order: string | number;
16
+ tag: string;
17
+ rounded: string | number | boolean;
18
+ }> & Omit<{
19
+ window: boolean;
20
+ absolute: boolean;
21
+ order: string | number;
22
+ tag: string;
23
+ } & {
24
+ height?: string | number | undefined;
25
+ name?: string | undefined;
26
+ color?: string | undefined;
27
+ elevation?: string | number | undefined;
28
+ theme?: string | undefined;
29
+ rounded?: string | number | boolean | undefined;
30
+ } & {
31
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
32
+ default?: (() => vue.VNodeChild) | undefined;
33
+ };
34
+ $slots?: {
35
+ default?: (() => vue.VNodeChild) | undefined;
36
+ } | undefined;
37
+ 'v-slots'?: {
38
+ default?: false | (() => vue.VNodeChild) | undefined;
39
+ } | undefined;
40
+ } & {
41
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
42
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "window" | "absolute" | "order" | "tag" | "rounded">;
43
+ $attrs: {
44
+ [x: string]: unknown;
45
+ };
46
+ $refs: {
47
+ [x: string]: unknown;
48
+ };
49
+ $slots: Readonly<{
50
+ [name: string]: vue.Slot | undefined;
51
+ }>;
52
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
53
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
54
+ $emit: (event: string, ...args: any[]) => void;
55
+ $el: any;
56
+ $options: vue.ComponentOptionsBase<{
57
+ window: boolean;
58
+ absolute: boolean;
59
+ order: string | number;
60
+ tag: string;
61
+ } & {
62
+ height?: string | number | undefined;
63
+ name?: string | undefined;
64
+ color?: string | undefined;
65
+ elevation?: string | number | undefined;
66
+ theme?: string | undefined;
67
+ rounded?: string | number | boolean | undefined;
68
+ } & {
69
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
70
+ default?: (() => vue.VNodeChild) | undefined;
71
+ };
72
+ $slots?: {
73
+ default?: (() => vue.VNodeChild) | undefined;
74
+ } | undefined;
75
+ 'v-slots'?: {
76
+ default?: false | (() => vue.VNodeChild) | undefined;
77
+ } | undefined;
78
+ } & {
79
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
80
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
81
+ window: boolean;
82
+ absolute: boolean;
83
+ order: string | number;
84
+ tag: string;
85
+ rounded: string | number | boolean;
86
+ }, {}, string> & {
87
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
88
+ created?: ((() => void) | (() => void)[]) | undefined;
89
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
90
+ mounted?: ((() => void) | (() => void)[]) | undefined;
91
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
92
+ updated?: ((() => void) | (() => void)[]) | undefined;
93
+ activated?: ((() => void) | (() => void)[]) | undefined;
94
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
95
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
96
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
97
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
98
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
99
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
100
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
101
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
102
+ };
103
+ $forceUpdate: () => void;
104
+ $nextTick: typeof vue.nextTick;
105
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
106
+ } & {
107
+ window: boolean;
108
+ absolute: boolean;
109
+ order: string | number;
110
+ tag: string;
111
+ } & {
112
+ height?: string | number | undefined;
113
+ name?: string | undefined;
114
+ color?: string | undefined;
115
+ elevation?: string | number | undefined;
116
+ theme?: string | undefined;
117
+ rounded?: string | number | boolean | undefined;
118
+ } & {
119
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
120
+ default?: (() => vue.VNodeChild) | undefined;
121
+ };
122
+ $slots?: {
123
+ default?: (() => vue.VNodeChild) | undefined;
124
+ } | undefined;
125
+ 'v-slots'?: {
126
+ default?: false | (() => vue.VNodeChild) | undefined;
127
+ } | undefined;
128
+ } & {
129
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
130
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
131
+ __isFragment?: undefined;
132
+ __isTeleport?: undefined;
133
+ __isSuspense?: undefined;
134
+ } & vue.ComponentOptionsBase<{
28
135
  window: boolean;
29
136
  absolute: boolean;
30
137
  order: string | number;
@@ -48,13 +155,63 @@ declare const VSystemBar: vue.DefineComponent<{
48
155
  } | undefined;
49
156
  } & {
50
157
  "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
51
- }, {
158
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
52
159
  window: boolean;
53
160
  absolute: boolean;
54
161
  order: string | number;
55
162
  tag: string;
56
163
  rounded: string | number | boolean;
57
- }>;
164
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
165
+ theme: StringConstructor;
166
+ tag: {
167
+ type: StringConstructor;
168
+ default: string;
169
+ };
170
+ rounded: {
171
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
172
+ default: undefined;
173
+ };
174
+ name: {
175
+ type: StringConstructor;
176
+ };
177
+ order: {
178
+ type: (StringConstructor | NumberConstructor)[];
179
+ default: number;
180
+ };
181
+ absolute: BooleanConstructor;
182
+ elevation: {
183
+ type: (StringConstructor | NumberConstructor)[];
184
+ validator(v: any): boolean;
185
+ };
186
+ color: StringConstructor;
187
+ height: (StringConstructor | NumberConstructor)[];
188
+ window: BooleanConstructor;
189
+ }, vue.ExtractPropTypes<{
190
+ theme: StringConstructor;
191
+ tag: {
192
+ type: StringConstructor;
193
+ default: string;
194
+ };
195
+ rounded: {
196
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
197
+ default: undefined;
198
+ };
199
+ name: {
200
+ type: StringConstructor;
201
+ };
202
+ order: {
203
+ type: (StringConstructor | NumberConstructor)[];
204
+ default: number;
205
+ };
206
+ absolute: BooleanConstructor;
207
+ elevation: {
208
+ type: (StringConstructor | NumberConstructor)[];
209
+ validator(v: any): boolean;
210
+ };
211
+ color: StringConstructor;
212
+ height: (StringConstructor | NumberConstructor)[];
213
+ window: BooleanConstructor;
214
+ }>>;
58
215
  type VSystemBar = InstanceType<typeof VSystemBar>;
59
216
 
60
217
  export { VSystemBar };
@@ -1,8 +1,166 @@
1
1
  import * as vue from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes } from 'vue';
3
+
4
+ interface FilterPropsOptions<PropsOptions extends Readonly<ComponentPropsOptions>, Props = ExtractPropTypes<PropsOptions>> {
5
+ filterProps<T extends Partial<Props>, U extends Exclude<keyof Props, Exclude<keyof Props, keyof T>>>(props: T): [yes: Partial<Pick<T, U>>, no: Omit<T, U>];
6
+ }
2
7
 
3
8
  type Density = null | 'default' | 'comfortable' | 'compact';
4
9
 
5
- declare const VTable: vue.DefineComponent<{
10
+ declare const VTable: {
11
+ new (...args: any[]): {
12
+ $: vue.ComponentInternalInstance;
13
+ $data: {};
14
+ $props: Partial<{
15
+ tag: string;
16
+ density: Density;
17
+ hover: boolean;
18
+ fixedHeader: boolean;
19
+ fixedFooter: boolean;
20
+ }> & Omit<{
21
+ tag: string;
22
+ density: Density;
23
+ hover: boolean;
24
+ fixedHeader: boolean;
25
+ fixedFooter: boolean;
26
+ } & {
27
+ height?: string | number | undefined;
28
+ theme?: string | undefined;
29
+ } & {
30
+ $children?: {} | vue.VNodeChild | {
31
+ default?: (() => vue.VNodeChild) | undefined;
32
+ top?: (() => vue.VNodeChild) | undefined;
33
+ bottom?: (() => vue.VNodeChild) | undefined;
34
+ wrapper?: (() => vue.VNodeChild) | undefined;
35
+ };
36
+ $slots?: {
37
+ default?: (() => vue.VNodeChild) | undefined;
38
+ top?: (() => vue.VNodeChild) | undefined;
39
+ bottom?: (() => vue.VNodeChild) | undefined;
40
+ wrapper?: (() => vue.VNodeChild) | undefined;
41
+ } | undefined;
42
+ 'v-slots'?: {
43
+ default?: false | (() => vue.VNodeChild) | undefined;
44
+ top?: false | (() => vue.VNodeChild) | undefined;
45
+ bottom?: false | (() => vue.VNodeChild) | undefined;
46
+ wrapper?: false | (() => vue.VNodeChild) | undefined;
47
+ } | undefined;
48
+ } & {
49
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
50
+ "v-slot:top"?: false | (() => vue.VNodeChild) | undefined;
51
+ "v-slot:bottom"?: false | (() => vue.VNodeChild) | undefined;
52
+ "v-slot:wrapper"?: false | (() => vue.VNodeChild) | undefined;
53
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "tag" | "density" | "hover" | "fixedHeader" | "fixedFooter">;
54
+ $attrs: {
55
+ [x: string]: unknown;
56
+ };
57
+ $refs: {
58
+ [x: string]: unknown;
59
+ };
60
+ $slots: Readonly<{
61
+ [name: string]: vue.Slot | undefined;
62
+ }>;
63
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
64
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
65
+ $emit: (event: string, ...args: any[]) => void;
66
+ $el: any;
67
+ $options: vue.ComponentOptionsBase<{
68
+ tag: string;
69
+ density: Density;
70
+ hover: boolean;
71
+ fixedHeader: boolean;
72
+ fixedFooter: boolean;
73
+ } & {
74
+ height?: string | number | undefined;
75
+ theme?: string | undefined;
76
+ } & {
77
+ $children?: {} | vue.VNodeChild | {
78
+ default?: (() => vue.VNodeChild) | undefined;
79
+ top?: (() => vue.VNodeChild) | undefined;
80
+ bottom?: (() => vue.VNodeChild) | undefined;
81
+ wrapper?: (() => vue.VNodeChild) | undefined;
82
+ };
83
+ $slots?: {
84
+ default?: (() => vue.VNodeChild) | undefined;
85
+ top?: (() => vue.VNodeChild) | undefined;
86
+ bottom?: (() => vue.VNodeChild) | undefined;
87
+ wrapper?: (() => vue.VNodeChild) | undefined;
88
+ } | undefined;
89
+ 'v-slots'?: {
90
+ default?: false | (() => vue.VNodeChild) | undefined;
91
+ top?: false | (() => vue.VNodeChild) | undefined;
92
+ bottom?: false | (() => vue.VNodeChild) | undefined;
93
+ wrapper?: false | (() => vue.VNodeChild) | undefined;
94
+ } | undefined;
95
+ } & {
96
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
97
+ "v-slot:top"?: false | (() => vue.VNodeChild) | undefined;
98
+ "v-slot:bottom"?: false | (() => vue.VNodeChild) | undefined;
99
+ "v-slot:wrapper"?: false | (() => vue.VNodeChild) | undefined;
100
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
101
+ tag: string;
102
+ density: Density;
103
+ hover: boolean;
104
+ fixedHeader: boolean;
105
+ fixedFooter: boolean;
106
+ }, {}, string> & {
107
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
108
+ created?: ((() => void) | (() => void)[]) | undefined;
109
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
110
+ mounted?: ((() => void) | (() => void)[]) | undefined;
111
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
112
+ updated?: ((() => void) | (() => void)[]) | undefined;
113
+ activated?: ((() => void) | (() => void)[]) | undefined;
114
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
115
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
116
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
117
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
118
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
119
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
120
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
121
+ errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
122
+ };
123
+ $forceUpdate: () => void;
124
+ $nextTick: typeof vue.nextTick;
125
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
126
+ } & {
127
+ tag: string;
128
+ density: Density;
129
+ hover: boolean;
130
+ fixedHeader: boolean;
131
+ fixedFooter: boolean;
132
+ } & {
133
+ height?: string | number | undefined;
134
+ theme?: string | undefined;
135
+ } & {
136
+ $children?: {} | vue.VNodeChild | {
137
+ default?: (() => vue.VNodeChild) | undefined;
138
+ top?: (() => vue.VNodeChild) | undefined;
139
+ bottom?: (() => vue.VNodeChild) | undefined;
140
+ wrapper?: (() => vue.VNodeChild) | undefined;
141
+ };
142
+ $slots?: {
143
+ default?: (() => vue.VNodeChild) | undefined;
144
+ top?: (() => vue.VNodeChild) | undefined;
145
+ bottom?: (() => vue.VNodeChild) | undefined;
146
+ wrapper?: (() => vue.VNodeChild) | undefined;
147
+ } | undefined;
148
+ 'v-slots'?: {
149
+ default?: false | (() => vue.VNodeChild) | undefined;
150
+ top?: false | (() => vue.VNodeChild) | undefined;
151
+ bottom?: false | (() => vue.VNodeChild) | undefined;
152
+ wrapper?: false | (() => vue.VNodeChild) | undefined;
153
+ } | undefined;
154
+ } & {
155
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
156
+ "v-slot:top"?: false | (() => vue.VNodeChild) | undefined;
157
+ "v-slot:bottom"?: false | (() => vue.VNodeChild) | undefined;
158
+ "v-slot:wrapper"?: false | (() => vue.VNodeChild) | undefined;
159
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
160
+ __isFragment?: undefined;
161
+ __isTeleport?: undefined;
162
+ __isSuspense?: undefined;
163
+ } & vue.ComponentOptionsBase<{
6
164
  tag: string;
7
165
  density: Density;
8
166
  hover: boolean;
@@ -35,46 +193,43 @@ declare const VTable: vue.DefineComponent<{
35
193
  "v-slot:top"?: false | (() => vue.VNodeChild) | undefined;
36
194
  "v-slot:bottom"?: false | (() => vue.VNodeChild) | undefined;
37
195
  "v-slot:wrapper"?: false | (() => vue.VNodeChild) | undefined;
38
- }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
196
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
39
197
  tag: string;
40
198
  density: Density;
41
199
  hover: boolean;
42
200
  fixedHeader: boolean;
43
201
  fixedFooter: boolean;
44
- } & {
45
- height?: string | number | undefined;
46
- theme?: string | undefined;
47
- } & {
48
- $children?: {} | vue.VNodeChild | {
49
- default?: (() => vue.VNodeChild) | undefined;
50
- top?: (() => vue.VNodeChild) | undefined;
51
- bottom?: (() => vue.VNodeChild) | undefined;
52
- wrapper?: (() => vue.VNodeChild) | undefined;
202
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
203
+ theme: StringConstructor;
204
+ tag: {
205
+ type: StringConstructor;
206
+ default: string;
53
207
  };
54
- $slots?: {
55
- default?: (() => vue.VNodeChild) | undefined;
56
- top?: (() => vue.VNodeChild) | undefined;
57
- bottom?: (() => vue.VNodeChild) | undefined;
58
- wrapper?: (() => vue.VNodeChild) | undefined;
59
- } | undefined;
60
- 'v-slots'?: {
61
- default?: false | (() => vue.VNodeChild) | undefined;
62
- top?: false | (() => vue.VNodeChild) | undefined;
63
- bottom?: false | (() => vue.VNodeChild) | undefined;
64
- wrapper?: false | (() => vue.VNodeChild) | undefined;
65
- } | undefined;
66
- } & {
67
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
68
- "v-slot:top"?: false | (() => vue.VNodeChild) | undefined;
69
- "v-slot:bottom"?: false | (() => vue.VNodeChild) | undefined;
70
- "v-slot:wrapper"?: false | (() => vue.VNodeChild) | undefined;
71
- }, {
72
- tag: string;
73
- density: Density;
74
- hover: boolean;
75
- fixedHeader: boolean;
76
- fixedFooter: boolean;
77
- }>;
208
+ density: {
209
+ type: vue.PropType<Density>;
210
+ default: string;
211
+ validator: (v: any) => boolean;
212
+ };
213
+ fixedHeader: BooleanConstructor;
214
+ fixedFooter: BooleanConstructor;
215
+ height: (StringConstructor | NumberConstructor)[];
216
+ hover: BooleanConstructor;
217
+ }, vue.ExtractPropTypes<{
218
+ theme: StringConstructor;
219
+ tag: {
220
+ type: StringConstructor;
221
+ default: string;
222
+ };
223
+ density: {
224
+ type: vue.PropType<Density>;
225
+ default: string;
226
+ validator: (v: any) => boolean;
227
+ };
228
+ fixedHeader: BooleanConstructor;
229
+ fixedFooter: BooleanConstructor;
230
+ height: (StringConstructor | NumberConstructor)[];
231
+ hover: BooleanConstructor;
232
+ }>>;
78
233
  type VTable = InstanceType<typeof VTable>;
79
234
 
80
235
  export { VTable };
@@ -4,41 +4,26 @@ import "./VTab.css";
4
4
 
5
5
  // Components
6
6
  import { VBtn } from "../VBtn/index.mjs"; // Composables
7
- import { IconValue } from "../../composables/icons.mjs";
8
- import { makeGroupItemProps } from "../../composables/group.mjs";
9
- import { makeRouterProps } from "../../composables/router.mjs";
10
- import { makeTagProps } from "../../composables/tag.mjs";
11
- import { makeThemeProps } from "../../composables/theme.mjs";
12
7
  import { useTextColor } from "../../composables/color.mjs"; // Utilities
13
8
  import { computed, ref } from 'vue';
14
- import { animate, genericComponent, pick, standardEasing, useRender } from "../../util/index.mjs"; // Types
9
+ import { animate, genericComponent, omit, standardEasing, useRender } from "../../util/index.mjs";
10
+ import { makeVBtnProps } from "../VBtn/VBtn.mjs"; // Types
15
11
  import { VTabsSymbol } from "./shared.mjs";
16
12
  export const VTab = genericComponent()({
17
13
  name: 'VTab',
18
14
  props: {
19
15
  fixed: Boolean,
20
- icon: [Boolean, String, Function, Object],
21
- prependIcon: IconValue,
22
- appendIcon: IconValue,
23
- stacked: Boolean,
24
16
  title: String,
25
- ripple: {
26
- type: Boolean,
27
- default: true
28
- },
29
- color: String,
30
17
  sliderColor: String,
31
18
  hideSlider: Boolean,
32
19
  direction: {
33
20
  type: String,
34
21
  default: 'horizontal'
35
22
  },
36
- ...makeTagProps(),
37
- ...makeRouterProps(),
38
- ...makeGroupItemProps({
39
- selectedClass: 'v-tab--selected'
40
- }),
41
- ...makeThemeProps()
23
+ ...omit(makeVBtnProps({
24
+ selectedClass: 'v-tab--selected',
25
+ variant: 'text'
26
+ }), ['active', 'block', 'flat', 'location', 'position', 'symbol'])
42
27
  },
43
28
  setup(props, _ref) {
44
29
  let {
@@ -88,7 +73,7 @@ export const VTab = genericComponent()({
88
73
  }
89
74
  }
90
75
  useRender(() => {
91
- const [btnProps] = pick(props, ['href', 'to', 'replace', 'icon', 'stacked', 'prependIcon', 'appendIcon', 'ripple', 'theme', 'disabled', 'selectedClass', 'value', 'color']);
76
+ const [btnProps] = VBtn.filterProps(props);
92
77
  return _createVNode(VBtn, _mergeProps({
93
78
  "_as": "VTab",
94
79
  "symbol": VTabsSymbol,
@@ -100,7 +85,6 @@ export const VTab = genericComponent()({
100
85
  "active": false,
101
86
  "block": props.fixed,
102
87
  "maxWidth": props.fixed ? 300 : undefined,
103
- "variant": "text",
104
88
  "rounded": 0
105
89
  }, btnProps, attrs, {
106
90
  "onGroup:selected": updateSlider
@@ -1 +1 @@
1
- {"version":3,"file":"VTab.mjs","names":["VBtn","IconValue","makeGroupItemProps","makeRouterProps","makeTagProps","makeThemeProps","useTextColor","computed","ref","animate","genericComponent","pick","standardEasing","useRender","VTabsSymbol","VTab","name","props","fixed","Boolean","icon","String","Function","Object","prependIcon","appendIcon","stacked","title","ripple","type","default","color","sliderColor","hideSlider","direction","selectedClass","setup","slots","attrs","textColorClasses","sliderColorClasses","textColorStyles","sliderColorStyles","isHorizontal","isSelected","rootEl","sliderEl","updateSlider","value","prevEl","$el","parentElement","querySelector","nextEl","getComputedStyle","prevBox","getBoundingClientRect","nextBox","xy","XY","rightBottom","widthHeight","prevPos","nextPos","delta","origin","Math","sign","size","abs","scale","max","initialScale","sigma","backgroundColor","transform","transformOrigin","Array","fill","duration","easing","btnProps","undefined"],"sources":["../../../src/components/VTabs/VTab.tsx"],"sourcesContent":["// Styles\nimport './VTab.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Composables\nimport { IconValue } from '@/composables/icons'\nimport { makeGroupItemProps } from '@/composables/group'\nimport { makeRouterProps } from '@/composables/router'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps } from '@/composables/theme'\nimport { useTextColor } from '@/composables/color'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { animate, genericComponent, pick, standardEasing, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport { VTabsSymbol } from './shared'\n\nexport const VTab = genericComponent()({\n name: 'VTab',\n\n props: {\n fixed: Boolean,\n icon: [Boolean, String, Function, Object] as PropType<boolean | IconValue>,\n prependIcon: IconValue,\n appendIcon: IconValue,\n\n stacked: Boolean,\n title: String,\n\n ripple: {\n type: Boolean,\n default: true,\n },\n color: String,\n sliderColor: String,\n hideSlider: Boolean,\n\n direction: {\n type: String as PropType<'horizontal' | 'vertical'>,\n default: 'horizontal',\n },\n\n ...makeTagProps(),\n ...makeRouterProps(),\n ...makeGroupItemProps({\n selectedClass: 'v-tab--selected',\n }),\n ...makeThemeProps(),\n },\n\n setup (props, { slots, attrs }) {\n const { textColorClasses: sliderColorClasses, textColorStyles: sliderColorStyles } = useTextColor(props, 'sliderColor')\n const isHorizontal = computed(() => props.direction === 'horizontal')\n const isSelected = ref(false)\n\n const rootEl = ref<VBtn>()\n const sliderEl = ref<HTMLElement>()\n\n function updateSlider ({ value }: { value: boolean }) {\n isSelected.value = value\n\n if (value) {\n const prevEl: HTMLElement | undefined = rootEl.value?.$el.parentElement?.querySelector('.v-tab--selected .v-tab__slider')\n const nextEl = sliderEl.value\n\n if (!prevEl || !nextEl) return\n\n const color = getComputedStyle(prevEl).color\n\n const prevBox = prevEl.getBoundingClientRect()\n const nextBox = nextEl.getBoundingClientRect()\n\n const xy = isHorizontal.value ? 'x' : 'y'\n const XY = isHorizontal.value ? 'X' : 'Y'\n const rightBottom = isHorizontal.value ? 'right' : 'bottom'\n const widthHeight = isHorizontal.value ? 'width' : 'height'\n\n const prevPos = prevBox[xy]\n const nextPos = nextBox[xy]\n const delta = prevPos > nextPos\n ? prevBox[rightBottom] - nextBox[rightBottom]\n : prevBox[xy] - nextBox[xy]\n const origin =\n Math.sign(delta) > 0 ? (isHorizontal.value ? 'right' : 'bottom')\n : Math.sign(delta) < 0 ? (isHorizontal.value ? 'left' : 'top')\n : 'center'\n const size = Math.abs(delta) + (Math.sign(delta) < 0 ? prevBox[widthHeight] : nextBox[widthHeight])\n const scale = size / Math.max(prevBox[widthHeight], nextBox[widthHeight])\n const initialScale = prevBox[widthHeight] / nextBox[widthHeight]\n\n const sigma = 1.5\n animate(nextEl, {\n backgroundColor: [color, ''],\n transform: [\n `translate${XY}(${delta}px) scale${XY}(${initialScale})`,\n `translate${XY}(${delta / sigma}px) scale${XY}(${(scale - 1) / sigma + 1})`,\n '',\n ],\n transformOrigin: Array(3).fill(origin),\n }, {\n duration: 225,\n easing: standardEasing,\n })\n }\n }\n\n useRender(() => {\n const [btnProps] = pick(props, [\n 'href',\n 'to',\n 'replace',\n 'icon',\n 'stacked',\n 'prependIcon',\n 'appendIcon',\n 'ripple',\n 'theme',\n 'disabled',\n 'selectedClass',\n 'value',\n 'color',\n ])\n\n return (\n <VBtn\n _as=\"VTab\"\n symbol={ VTabsSymbol }\n ref={ rootEl }\n class={[\n 'v-tab',\n ]}\n tabindex={ isSelected.value ? 0 : -1 }\n role=\"tab\"\n aria-selected={ String(isSelected.value) }\n active={ false }\n block={ props.fixed }\n maxWidth={ props.fixed ? 300 : undefined }\n variant=\"text\"\n rounded={ 0 }\n { ...btnProps }\n { ...attrs }\n onGroup:selected={ updateSlider }\n >\n { slots.default ? slots.default() : props.title }\n { !props.hideSlider && (\n <div\n ref={ sliderEl }\n class={[\n 'v-tab__slider',\n sliderColorClasses.value,\n ]}\n style={ sliderColorStyles.value }\n />\n )}\n </VBtn>\n )\n })\n\n return {}\n },\n})\n\nexport type VTab = InstanceType<typeof VTab>\n"],"mappings":"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"}
1
+ {"version":3,"file":"VTab.mjs","names":["VBtn","useTextColor","computed","ref","animate","genericComponent","omit","standardEasing","useRender","makeVBtnProps","VTabsSymbol","VTab","name","props","fixed","Boolean","title","String","sliderColor","hideSlider","direction","type","default","selectedClass","variant","setup","slots","attrs","textColorClasses","sliderColorClasses","textColorStyles","sliderColorStyles","isHorizontal","isSelected","rootEl","sliderEl","updateSlider","value","prevEl","$el","parentElement","querySelector","nextEl","color","getComputedStyle","prevBox","getBoundingClientRect","nextBox","xy","XY","rightBottom","widthHeight","prevPos","nextPos","delta","origin","Math","sign","size","abs","scale","max","initialScale","sigma","backgroundColor","transform","transformOrigin","Array","fill","duration","easing","btnProps","filterProps","undefined"],"sources":["../../../src/components/VTabs/VTab.tsx"],"sourcesContent":["// Styles\nimport './VTab.sass'\n\n// Components\nimport { VBtn } from '@/components/VBtn'\n\n// Composables\nimport { useTextColor } from '@/composables/color'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport { animate, genericComponent, omit, standardEasing, useRender } from '@/util'\nimport { makeVBtnProps } from '@/components/VBtn/VBtn'\n\n// Types\nimport type { PropType } from 'vue'\nimport { VTabsSymbol } from './shared'\n\nexport const VTab = genericComponent()({\n name: 'VTab',\n\n props: {\n fixed: Boolean,\n title: String,\n\n sliderColor: String,\n hideSlider: Boolean,\n\n direction: {\n type: String as PropType<'horizontal' | 'vertical'>,\n default: 'horizontal',\n },\n\n ...omit(makeVBtnProps({\n selectedClass: 'v-tab--selected',\n variant: 'text' as const,\n }), [\n 'active',\n 'block',\n 'flat',\n 'location',\n 'position',\n 'symbol',\n ]),\n },\n\n setup (props, { slots, attrs }) {\n const { textColorClasses: sliderColorClasses, textColorStyles: sliderColorStyles } = useTextColor(props, 'sliderColor')\n const isHorizontal = computed(() => props.direction === 'horizontal')\n const isSelected = ref(false)\n\n const rootEl = ref<VBtn>()\n const sliderEl = ref<HTMLElement>()\n\n function updateSlider ({ value }: { value: boolean }) {\n isSelected.value = value\n\n if (value) {\n const prevEl: HTMLElement | undefined = rootEl.value?.$el.parentElement?.querySelector('.v-tab--selected .v-tab__slider')\n const nextEl = sliderEl.value\n\n if (!prevEl || !nextEl) return\n\n const color = getComputedStyle(prevEl).color\n\n const prevBox = prevEl.getBoundingClientRect()\n const nextBox = nextEl.getBoundingClientRect()\n\n const xy = isHorizontal.value ? 'x' : 'y'\n const XY = isHorizontal.value ? 'X' : 'Y'\n const rightBottom = isHorizontal.value ? 'right' : 'bottom'\n const widthHeight = isHorizontal.value ? 'width' : 'height'\n\n const prevPos = prevBox[xy]\n const nextPos = nextBox[xy]\n const delta = prevPos > nextPos\n ? prevBox[rightBottom] - nextBox[rightBottom]\n : prevBox[xy] - nextBox[xy]\n const origin =\n Math.sign(delta) > 0 ? (isHorizontal.value ? 'right' : 'bottom')\n : Math.sign(delta) < 0 ? (isHorizontal.value ? 'left' : 'top')\n : 'center'\n const size = Math.abs(delta) + (Math.sign(delta) < 0 ? prevBox[widthHeight] : nextBox[widthHeight])\n const scale = size / Math.max(prevBox[widthHeight], nextBox[widthHeight])\n const initialScale = prevBox[widthHeight] / nextBox[widthHeight]\n\n const sigma = 1.5\n animate(nextEl, {\n backgroundColor: [color, ''],\n transform: [\n `translate${XY}(${delta}px) scale${XY}(${initialScale})`,\n `translate${XY}(${delta / sigma}px) scale${XY}(${(scale - 1) / sigma + 1})`,\n '',\n ],\n transformOrigin: Array(3).fill(origin),\n }, {\n duration: 225,\n easing: standardEasing,\n })\n }\n }\n\n useRender(() => {\n const [btnProps] = VBtn.filterProps(props)\n\n return (\n <VBtn\n _as=\"VTab\"\n symbol={ VTabsSymbol }\n ref={ rootEl }\n class={[\n 'v-tab',\n ]}\n tabindex={ isSelected.value ? 0 : -1 }\n role=\"tab\"\n aria-selected={ String(isSelected.value) }\n active={ false }\n block={ props.fixed }\n maxWidth={ props.fixed ? 300 : undefined }\n rounded={ 0 }\n { ...btnProps }\n { ...attrs }\n onGroup:selected={ updateSlider }\n >\n { slots.default ? slots.default() : props.title }\n { !props.hideSlider && (\n <div\n ref={ sliderEl }\n class={[\n 'v-tab__slider',\n sliderColorClasses.value,\n ]}\n style={ sliderColorStyles.value }\n />\n )}\n </VBtn>\n )\n })\n\n return {}\n },\n})\n\nexport type VTab = InstanceType<typeof VTab>\n"],"mappings":"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"}