vuetify 3.1.9 → 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 (208) hide show
  1. package/dist/json/attributes.json +203 -27
  2. package/dist/json/importMap.json +92 -92
  3. package/dist/json/tags.json +46 -2
  4. package/dist/json/web-types.json +481 -49
  5. package/dist/vuetify-labs.css +167 -147
  6. package/dist/vuetify-labs.d.ts +56923 -14294
  7. package/dist/vuetify-labs.esm.js +136 -152
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +136 -152
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +76 -68
  12. package/dist/vuetify.d.ts +54804 -15357
  13. package/dist/vuetify.esm.js +133 -152
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +133 -152
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +667 -669
  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/VListItem.mjs +1 -1
  104. package/lib/components/VList/VListItem.mjs.map +1 -1
  105. package/lib/components/VList/index.d.ts +1461 -223
  106. package/lib/components/VLocaleProvider/index.d.ts +121 -20
  107. package/lib/components/VMain/index.d.ts +118 -17
  108. package/lib/components/VMenu/VMenu.css +4 -4
  109. package/lib/components/VMenu/VMenu.mjs +2 -2
  110. package/lib/components/VMenu/VMenu.mjs.map +1 -1
  111. package/lib/components/VMenu/VMenu.sass +1 -1
  112. package/lib/components/VMenu/index.d.ts +2368 -142
  113. package/lib/components/VMessages/index.d.ts +1921 -98
  114. package/lib/components/VNavigationDrawer/index.d.ts +379 -56
  115. package/lib/components/VOverlay/VOverlay.css +2 -2
  116. package/lib/components/VOverlay/VOverlay.mjs +1 -4
  117. package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
  118. package/lib/components/VOverlay/VOverlay.sass +1 -1
  119. package/lib/components/VOverlay/_variables.scss +1 -1
  120. package/lib/components/VOverlay/index.d.ts +519 -85
  121. package/lib/components/VPagination/index.d.ts +502 -68
  122. package/lib/components/VParallax/VParallax.mjs +3 -3
  123. package/lib/components/VParallax/VParallax.mjs.map +1 -1
  124. package/lib/components/VParallax/index.d.ts +141 -28
  125. package/lib/components/VProgressCircular/index.d.ts +186 -25
  126. package/lib/components/VProgressLinear/index.d.ts +319 -48
  127. package/lib/components/VRadio/index.d.ts +313 -57
  128. package/lib/components/VRadioGroup/VRadioGroup.mjs +4 -6
  129. package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
  130. package/lib/components/VRadioGroup/index.d.ts +463 -83
  131. package/lib/components/VRangeSlider/index.d.ts +528 -80
  132. package/lib/components/VRating/index.d.ts +305 -43
  133. package/lib/components/VResponsive/index.d.ts +142 -27
  134. package/lib/components/VSelect/VSelect.mjs +2 -2
  135. package/lib/components/VSelect/VSelect.mjs.map +1 -1
  136. package/lib/components/VSelect/index.d.ts +3060 -328
  137. package/lib/components/VSelectionControl/VSelectionControl.mjs +1 -4
  138. package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
  139. package/lib/components/VSelectionControl/index.d.ts +76 -4
  140. package/lib/components/VSelectionControlGroup/index.d.ts +242 -38
  141. package/lib/components/VSheet/VSheet.mjs +1 -7
  142. package/lib/components/VSheet/VSheet.mjs.map +1 -1
  143. package/lib/components/VSheet/index.d.ts +194 -31
  144. package/lib/components/VSlideGroup/index.d.ts +475 -83
  145. package/lib/components/VSlider/index.d.ts +521 -79
  146. package/lib/components/VSlider/slider.mjs +2 -5
  147. package/lib/components/VSlider/slider.mjs.map +1 -1
  148. package/lib/components/VSnackbar/VSnackbar.mjs +2 -2
  149. package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
  150. package/lib/components/VSnackbar/index.d.ts +1219 -81
  151. package/lib/components/VSwitch/VSwitch.mjs +2 -2
  152. package/lib/components/VSwitch/VSwitch.mjs.map +1 -1
  153. package/lib/components/VSwitch/index.d.ts +498 -92
  154. package/lib/components/VSystemBar/index.d.ts +184 -27
  155. package/lib/components/VTable/index.d.ts +190 -35
  156. package/lib/components/VTabs/VTab.mjs +7 -23
  157. package/lib/components/VTabs/VTab.mjs.map +1 -1
  158. package/lib/components/VTabs/VTabs.mjs +15 -23
  159. package/lib/components/VTabs/VTabs.mjs.map +1 -1
  160. package/lib/components/VTabs/index.d.ts +623 -71
  161. package/lib/components/VTextField/VTextField.mjs +8 -5
  162. package/lib/components/VTextField/VTextField.mjs.map +1 -1
  163. package/lib/components/VTextField/index.d.ts +1404 -106
  164. package/lib/components/VTextarea/VTextarea.mjs +7 -1
  165. package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
  166. package/lib/components/VTextarea/index.d.ts +1014 -102
  167. package/lib/components/VThemeProvider/index.d.ts +124 -19
  168. package/lib/components/VTimeline/index.d.ts +441 -71
  169. package/lib/components/VToolbar/VToolbar.mjs +1 -4
  170. package/lib/components/VToolbar/VToolbar.mjs.map +1 -1
  171. package/lib/components/VToolbar/index.d.ts +542 -93
  172. package/lib/components/VTooltip/VTooltip.css +3 -3
  173. package/lib/components/VTooltip/VTooltip.mjs +2 -2
  174. package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
  175. package/lib/components/VTooltip/VTooltip.sass +1 -1
  176. package/lib/components/VTooltip/index.d.ts +1263 -81
  177. package/lib/components/VValidation/index.d.ts +201 -30
  178. package/lib/components/VWindow/index.d.ts +527 -95
  179. package/lib/components/index.d.ts +55131 -15681
  180. package/lib/components/transitions/index.d.ts +2097 -308
  181. package/lib/composables/defaults.mjs +1 -1
  182. package/lib/composables/defaults.mjs.map +1 -1
  183. package/lib/composables/display.mjs +2 -0
  184. package/lib/composables/display.mjs.map +1 -1
  185. package/lib/composables/form.mjs.map +1 -1
  186. package/lib/entry-bundler.mjs +1 -1
  187. package/lib/entry-bundler.mjs.map +1 -1
  188. package/lib/framework.mjs +1 -1
  189. package/lib/framework.mjs.map +1 -1
  190. package/lib/index.d.ts +31 -34
  191. package/lib/labs/VDataTable/VDataTable.css +12 -0
  192. package/lib/labs/VDataTable/VDataTable.sass +6 -0
  193. package/lib/labs/VDataTable/VDataTableRow.mjs +2 -0
  194. package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
  195. package/lib/labs/VDataTable/VDataTableRows.mjs +1 -0
  196. package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
  197. package/lib/labs/VDataTable/index.d.ts +4176 -1016
  198. package/lib/labs/VVirtualScroll/index.d.ts +32 -1
  199. package/lib/labs/components.d.ts +4212 -1026
  200. package/lib/styles/main.css +4 -0
  201. package/lib/styles/settings/_utilities.scss +7 -0
  202. package/lib/util/animation.mjs +8 -1
  203. package/lib/util/animation.mjs.map +1 -1
  204. package/lib/util/defineComponent.mjs +12 -5
  205. package/lib/util/defineComponent.mjs.map +1 -1
  206. package/lib/util/helpers.mjs +4 -0
  207. package/lib/util/helpers.mjs.map +1 -1
  208. package/package.json +3 -2
@@ -1,5 +1,9 @@
1
1
  import * as vue from 'vue';
2
- import { JSXComponent, PropType } from 'vue';
2
+ import { ComponentPropsOptions, ExtractPropTypes, Prop, JSXComponent, PropType } 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
+ }
3
7
 
4
8
  type Density = null | 'default' | 'comfortable' | 'compact';
5
9
 
@@ -7,7 +11,136 @@ type TimelineDirection = 'vertical' | 'horizontal';
7
11
  type TimelineSide = 'start' | 'end' | undefined;
8
12
  type TimelineAlign = 'center' | 'start';
9
13
  type TimelineTruncateLine = 'start' | 'end' | 'both' | undefined;
10
- declare const VTimeline: vue.DefineComponent<{
14
+ declare const VTimeline: {
15
+ new (...args: any[]): {
16
+ $: vue.ComponentInternalInstance;
17
+ $data: {};
18
+ $props: Partial<{
19
+ tag: string;
20
+ justify: string;
21
+ density: Density;
22
+ lineInset: string | number;
23
+ lineThickness: string | number;
24
+ }> & Omit<{
25
+ tag: string;
26
+ justify: string;
27
+ density: Density;
28
+ lineInset: string | number;
29
+ lineThickness: string | number;
30
+ } & {
31
+ direction?: TimelineDirection | undefined;
32
+ align?: TimelineAlign | undefined;
33
+ side?: TimelineSide;
34
+ theme?: string | undefined;
35
+ lineColor?: string | undefined;
36
+ truncateLine?: TimelineTruncateLine;
37
+ } & {
38
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
39
+ default?: (() => vue.VNodeChild) | undefined;
40
+ };
41
+ $slots?: {
42
+ default?: (() => vue.VNodeChild) | undefined;
43
+ } | undefined;
44
+ 'v-slots'?: {
45
+ default?: false | (() => vue.VNodeChild) | undefined;
46
+ } | undefined;
47
+ } & {
48
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
49
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "tag" | "justify" | "density" | "lineInset" | "lineThickness">;
50
+ $attrs: {
51
+ [x: string]: unknown;
52
+ };
53
+ $refs: {
54
+ [x: string]: unknown;
55
+ };
56
+ $slots: Readonly<{
57
+ [name: string]: vue.Slot | undefined;
58
+ }>;
59
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
60
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
61
+ $emit: (event: string, ...args: any[]) => void;
62
+ $el: any;
63
+ $options: vue.ComponentOptionsBase<{
64
+ tag: string;
65
+ justify: string;
66
+ density: Density;
67
+ lineInset: string | number;
68
+ lineThickness: string | number;
69
+ } & {
70
+ direction?: TimelineDirection | undefined;
71
+ align?: TimelineAlign | undefined;
72
+ side?: TimelineSide;
73
+ theme?: string | undefined;
74
+ lineColor?: string | undefined;
75
+ truncateLine?: TimelineTruncateLine;
76
+ } & {
77
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
78
+ default?: (() => vue.VNodeChild) | undefined;
79
+ };
80
+ $slots?: {
81
+ default?: (() => vue.VNodeChild) | undefined;
82
+ } | undefined;
83
+ 'v-slots'?: {
84
+ default?: false | (() => vue.VNodeChild) | undefined;
85
+ } | undefined;
86
+ } & {
87
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
88
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
89
+ tag: string;
90
+ justify: string;
91
+ density: Density;
92
+ lineInset: string | number;
93
+ lineThickness: string | number;
94
+ }, {}, string> & {
95
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
96
+ created?: ((() => void) | (() => void)[]) | undefined;
97
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
98
+ mounted?: ((() => void) | (() => void)[]) | undefined;
99
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
100
+ updated?: ((() => void) | (() => void)[]) | undefined;
101
+ activated?: ((() => void) | (() => void)[]) | undefined;
102
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
103
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
104
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
105
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
106
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
107
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
108
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
109
+ 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;
110
+ };
111
+ $forceUpdate: () => void;
112
+ $nextTick: typeof vue.nextTick;
113
+ $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;
114
+ } & {
115
+ tag: string;
116
+ justify: string;
117
+ density: Density;
118
+ lineInset: string | number;
119
+ lineThickness: string | number;
120
+ } & {
121
+ direction?: TimelineDirection | undefined;
122
+ align?: TimelineAlign | undefined;
123
+ side?: TimelineSide;
124
+ theme?: string | undefined;
125
+ lineColor?: string | undefined;
126
+ truncateLine?: TimelineTruncateLine;
127
+ } & {
128
+ $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
129
+ default?: (() => vue.VNodeChild) | undefined;
130
+ };
131
+ $slots?: {
132
+ default?: (() => vue.VNodeChild) | undefined;
133
+ } | undefined;
134
+ 'v-slots'?: {
135
+ default?: false | (() => vue.VNodeChild) | undefined;
136
+ } | undefined;
137
+ } & {
138
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
139
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
140
+ __isFragment?: undefined;
141
+ __isTeleport?: undefined;
142
+ __isSuspense?: undefined;
143
+ } & vue.ComponentOptionsBase<{
11
144
  tag: string;
12
145
  justify: string;
13
146
  density: Density;
@@ -32,84 +165,253 @@ declare const VTimeline: vue.DefineComponent<{
32
165
  } | undefined;
33
166
  } & {
34
167
  "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
35
- }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
168
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
36
169
  tag: string;
37
170
  justify: string;
38
171
  density: Density;
39
172
  lineInset: string | number;
40
173
  lineThickness: string | number;
41
- } & {
42
- direction?: TimelineDirection | undefined;
43
- align?: TimelineAlign | undefined;
44
- side?: TimelineSide;
45
- theme?: string | undefined;
46
- lineColor?: string | undefined;
47
- truncateLine?: TimelineTruncateLine;
48
- } & {
49
- $children?: vue.VNodeChild | (() => vue.VNodeChild) | {
50
- default?: (() => vue.VNodeChild) | undefined;
174
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
175
+ theme: StringConstructor;
176
+ tag: {
177
+ type: StringConstructor;
178
+ default: string;
51
179
  };
52
- $slots?: {
53
- default?: (() => vue.VNodeChild) | undefined;
54
- } | undefined;
55
- 'v-slots'?: {
56
- default?: false | (() => vue.VNodeChild) | undefined;
57
- } | undefined;
58
- } & {
59
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
60
- }, {
61
- tag: string;
62
- justify: string;
63
- density: Density;
64
- lineInset: string | number;
65
- lineThickness: string | number;
66
- }>;
180
+ density: {
181
+ type: vue.PropType<Density>;
182
+ default: string;
183
+ validator: (v: any) => boolean;
184
+ };
185
+ align: Prop<TimelineAlign, TimelineAlign>;
186
+ direction: Prop<TimelineDirection, TimelineDirection>;
187
+ justify: {
188
+ type: StringConstructor;
189
+ default: string;
190
+ validator: (v: any) => boolean;
191
+ };
192
+ side: Prop<TimelineSide, TimelineSide>;
193
+ lineInset: {
194
+ type: (StringConstructor | NumberConstructor)[];
195
+ default: number;
196
+ };
197
+ lineThickness: {
198
+ type: (StringConstructor | NumberConstructor)[];
199
+ default: number;
200
+ };
201
+ lineColor: StringConstructor;
202
+ truncateLine: Prop<TimelineTruncateLine, TimelineTruncateLine>;
203
+ }, vue.ExtractPropTypes<{
204
+ theme: StringConstructor;
205
+ tag: {
206
+ type: StringConstructor;
207
+ default: string;
208
+ };
209
+ density: {
210
+ type: vue.PropType<Density>;
211
+ default: string;
212
+ validator: (v: any) => boolean;
213
+ };
214
+ align: Prop<TimelineAlign, TimelineAlign>;
215
+ direction: Prop<TimelineDirection, TimelineDirection>;
216
+ justify: {
217
+ type: StringConstructor;
218
+ default: string;
219
+ validator: (v: any) => boolean;
220
+ };
221
+ side: Prop<TimelineSide, TimelineSide>;
222
+ lineInset: {
223
+ type: (StringConstructor | NumberConstructor)[];
224
+ default: number;
225
+ };
226
+ lineThickness: {
227
+ type: (StringConstructor | NumberConstructor)[];
228
+ default: number;
229
+ };
230
+ lineColor: StringConstructor;
231
+ truncateLine: Prop<TimelineTruncateLine, TimelineTruncateLine>;
232
+ }>>;
67
233
  type VTimeline = InstanceType<typeof VTimeline>;
68
234
 
69
235
  type IconValue = string | JSXComponent;
70
236
  declare const IconValue: PropType<IconValue>;
71
237
 
72
- declare const VTimelineItem: vue.DefineComponent<{
73
- size: string | number;
74
- tag: string;
75
- fillDot: boolean;
76
- hideDot: boolean;
77
- } & {
78
- height?: string | number | undefined;
79
- width?: string | number | undefined;
80
- maxHeight?: string | number | undefined;
81
- maxWidth?: string | number | undefined;
82
- minHeight?: string | number | undefined;
83
- minWidth?: string | number | undefined;
84
- icon?: IconValue | undefined;
85
- elevation?: string | number | undefined;
86
- rounded?: string | number | boolean | undefined;
87
- density?: "default" | "compact" | undefined;
88
- lineInset?: string | number | undefined;
89
- dotColor?: string | undefined;
90
- iconColor?: string | undefined;
91
- hideOpposite?: boolean | undefined;
92
- } & {
93
- $children?: {} | vue.VNodeChild | {
94
- default?: (() => vue.VNodeChild) | undefined;
95
- icon?: (() => vue.VNodeChild) | undefined;
96
- opposite?: (() => vue.VNodeChild) | undefined;
97
- };
98
- $slots?: {
99
- default?: (() => vue.VNodeChild) | undefined;
100
- icon?: (() => vue.VNodeChild) | undefined;
101
- opposite?: (() => vue.VNodeChild) | undefined;
102
- } | undefined;
103
- 'v-slots'?: {
104
- default?: false | (() => vue.VNodeChild) | undefined;
105
- icon?: false | (() => vue.VNodeChild) | undefined;
106
- opposite?: false | (() => vue.VNodeChild) | undefined;
107
- } | undefined;
108
- } & {
109
- "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
110
- "v-slot:icon"?: false | (() => vue.VNodeChild) | undefined;
111
- "v-slot:opposite"?: false | (() => vue.VNodeChild) | undefined;
112
- }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, {
238
+ declare const VTimelineItem: {
239
+ new (...args: any[]): {
240
+ $: vue.ComponentInternalInstance;
241
+ $data: {};
242
+ $props: Partial<{
243
+ size: string | number;
244
+ tag: string;
245
+ rounded: string | number | boolean;
246
+ fillDot: boolean;
247
+ hideDot: boolean;
248
+ hideOpposite: boolean;
249
+ }> & Omit<{
250
+ size: string | number;
251
+ tag: string;
252
+ fillDot: boolean;
253
+ hideDot: boolean;
254
+ } & {
255
+ height?: string | number | undefined;
256
+ width?: string | number | undefined;
257
+ maxHeight?: string | number | undefined;
258
+ maxWidth?: string | number | undefined;
259
+ minHeight?: string | number | undefined;
260
+ minWidth?: string | number | undefined;
261
+ icon?: IconValue | undefined;
262
+ elevation?: string | number | undefined;
263
+ rounded?: string | number | boolean | undefined;
264
+ density?: "default" | "compact" | undefined;
265
+ lineInset?: string | number | undefined;
266
+ dotColor?: string | undefined;
267
+ iconColor?: string | undefined;
268
+ hideOpposite?: boolean | undefined;
269
+ } & {
270
+ $children?: {} | vue.VNodeChild | {
271
+ default?: (() => vue.VNodeChild) | undefined;
272
+ icon?: (() => vue.VNodeChild) | undefined;
273
+ opposite?: (() => vue.VNodeChild) | undefined;
274
+ };
275
+ $slots?: {
276
+ default?: (() => vue.VNodeChild) | undefined;
277
+ icon?: (() => vue.VNodeChild) | undefined;
278
+ opposite?: (() => vue.VNodeChild) | undefined;
279
+ } | undefined;
280
+ 'v-slots'?: {
281
+ default?: false | (() => vue.VNodeChild) | undefined;
282
+ icon?: false | (() => vue.VNodeChild) | undefined;
283
+ opposite?: false | (() => vue.VNodeChild) | undefined;
284
+ } | undefined;
285
+ } & {
286
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
287
+ "v-slot:icon"?: false | (() => vue.VNodeChild) | undefined;
288
+ "v-slot:opposite"?: false | (() => vue.VNodeChild) | undefined;
289
+ } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "size" | "tag" | "rounded" | "fillDot" | "hideDot" | "hideOpposite">;
290
+ $attrs: {
291
+ [x: string]: unknown;
292
+ };
293
+ $refs: {
294
+ [x: string]: unknown;
295
+ };
296
+ $slots: Readonly<{
297
+ [name: string]: vue.Slot | undefined;
298
+ }>;
299
+ $root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
300
+ $parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
301
+ $emit: (event: string, ...args: any[]) => void;
302
+ $el: any;
303
+ $options: vue.ComponentOptionsBase<{
304
+ size: string | number;
305
+ tag: string;
306
+ fillDot: boolean;
307
+ hideDot: boolean;
308
+ } & {
309
+ height?: string | number | undefined;
310
+ width?: string | number | undefined;
311
+ maxHeight?: string | number | undefined;
312
+ maxWidth?: string | number | undefined;
313
+ minHeight?: string | number | undefined;
314
+ minWidth?: string | number | undefined;
315
+ icon?: IconValue | undefined;
316
+ elevation?: string | number | undefined;
317
+ rounded?: string | number | boolean | undefined;
318
+ density?: "default" | "compact" | undefined;
319
+ lineInset?: string | number | undefined;
320
+ dotColor?: string | undefined;
321
+ iconColor?: string | undefined;
322
+ hideOpposite?: boolean | undefined;
323
+ } & {
324
+ $children?: {} | vue.VNodeChild | {
325
+ default?: (() => vue.VNodeChild) | undefined;
326
+ icon?: (() => vue.VNodeChild) | undefined;
327
+ opposite?: (() => vue.VNodeChild) | undefined;
328
+ };
329
+ $slots?: {
330
+ default?: (() => vue.VNodeChild) | undefined;
331
+ icon?: (() => vue.VNodeChild) | undefined;
332
+ opposite?: (() => vue.VNodeChild) | undefined;
333
+ } | undefined;
334
+ 'v-slots'?: {
335
+ default?: false | (() => vue.VNodeChild) | undefined;
336
+ icon?: false | (() => vue.VNodeChild) | undefined;
337
+ opposite?: false | (() => vue.VNodeChild) | undefined;
338
+ } | undefined;
339
+ } & {
340
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
341
+ "v-slot:icon"?: false | (() => vue.VNodeChild) | undefined;
342
+ "v-slot:opposite"?: false | (() => vue.VNodeChild) | undefined;
343
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
344
+ size: string | number;
345
+ tag: string;
346
+ rounded: string | number | boolean;
347
+ fillDot: boolean;
348
+ hideDot: boolean;
349
+ hideOpposite: boolean;
350
+ }, {}, string> & {
351
+ beforeCreate?: ((() => void) | (() => void)[]) | undefined;
352
+ created?: ((() => void) | (() => void)[]) | undefined;
353
+ beforeMount?: ((() => void) | (() => void)[]) | undefined;
354
+ mounted?: ((() => void) | (() => void)[]) | undefined;
355
+ beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
356
+ updated?: ((() => void) | (() => void)[]) | undefined;
357
+ activated?: ((() => void) | (() => void)[]) | undefined;
358
+ deactivated?: ((() => void) | (() => void)[]) | undefined;
359
+ beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
360
+ beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
361
+ destroyed?: ((() => void) | (() => void)[]) | undefined;
362
+ unmounted?: ((() => void) | (() => void)[]) | undefined;
363
+ renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
364
+ renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
365
+ 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;
366
+ };
367
+ $forceUpdate: () => void;
368
+ $nextTick: typeof vue.nextTick;
369
+ $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;
370
+ } & {
371
+ size: string | number;
372
+ tag: string;
373
+ fillDot: boolean;
374
+ hideDot: boolean;
375
+ } & {
376
+ height?: string | number | undefined;
377
+ width?: string | number | undefined;
378
+ maxHeight?: string | number | undefined;
379
+ maxWidth?: string | number | undefined;
380
+ minHeight?: string | number | undefined;
381
+ minWidth?: string | number | undefined;
382
+ icon?: IconValue | undefined;
383
+ elevation?: string | number | undefined;
384
+ rounded?: string | number | boolean | undefined;
385
+ density?: "default" | "compact" | undefined;
386
+ lineInset?: string | number | undefined;
387
+ dotColor?: string | undefined;
388
+ iconColor?: string | undefined;
389
+ hideOpposite?: boolean | undefined;
390
+ } & {
391
+ $children?: {} | vue.VNodeChild | {
392
+ default?: (() => vue.VNodeChild) | undefined;
393
+ icon?: (() => vue.VNodeChild) | undefined;
394
+ opposite?: (() => vue.VNodeChild) | undefined;
395
+ };
396
+ $slots?: {
397
+ default?: (() => vue.VNodeChild) | undefined;
398
+ icon?: (() => vue.VNodeChild) | undefined;
399
+ opposite?: (() => vue.VNodeChild) | undefined;
400
+ } | undefined;
401
+ 'v-slots'?: {
402
+ default?: false | (() => vue.VNodeChild) | undefined;
403
+ icon?: false | (() => vue.VNodeChild) | undefined;
404
+ opposite?: false | (() => vue.VNodeChild) | undefined;
405
+ } | undefined;
406
+ } & {
407
+ "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
408
+ "v-slot:icon"?: false | (() => vue.VNodeChild) | undefined;
409
+ "v-slot:opposite"?: false | (() => vue.VNodeChild) | undefined;
410
+ } & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties & {};
411
+ __isFragment?: undefined;
412
+ __isTeleport?: undefined;
413
+ __isSuspense?: undefined;
414
+ } & vue.ComponentOptionsBase<{
113
415
  size: string | number;
114
416
  tag: string;
115
417
  fillDot: boolean;
@@ -149,14 +451,82 @@ declare const VTimelineItem: vue.DefineComponent<{
149
451
  "v-slot:default"?: false | (() => vue.VNodeChild) | undefined;
150
452
  "v-slot:icon"?: false | (() => vue.VNodeChild) | undefined;
151
453
  "v-slot:opposite"?: false | (() => vue.VNodeChild) | undefined;
152
- }, {
454
+ }, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Record<string, any>, string, {
153
455
  size: string | number;
154
456
  tag: string;
155
457
  rounded: string | number | boolean;
156
458
  fillDot: boolean;
157
459
  hideDot: boolean;
158
460
  hideOpposite: boolean;
159
- }>;
461
+ }, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
462
+ height: (StringConstructor | NumberConstructor)[];
463
+ maxHeight: (StringConstructor | NumberConstructor)[];
464
+ maxWidth: (StringConstructor | NumberConstructor)[];
465
+ minHeight: (StringConstructor | NumberConstructor)[];
466
+ minWidth: (StringConstructor | NumberConstructor)[];
467
+ width: (StringConstructor | NumberConstructor)[];
468
+ tag: {
469
+ type: StringConstructor;
470
+ default: string;
471
+ };
472
+ size: {
473
+ type: (StringConstructor | NumberConstructor)[];
474
+ default: string;
475
+ };
476
+ elevation: {
477
+ type: (StringConstructor | NumberConstructor)[];
478
+ validator(v: any): boolean;
479
+ };
480
+ rounded: {
481
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
482
+ default: undefined;
483
+ };
484
+ density: PropType<"default" | "compact">;
485
+ dotColor: StringConstructor;
486
+ fillDot: BooleanConstructor;
487
+ hideDot: BooleanConstructor;
488
+ hideOpposite: {
489
+ type: BooleanConstructor;
490
+ default: undefined;
491
+ };
492
+ icon: PropType<IconValue>;
493
+ iconColor: StringConstructor;
494
+ lineInset: (StringConstructor | NumberConstructor)[];
495
+ }, vue.ExtractPropTypes<{
496
+ height: (StringConstructor | NumberConstructor)[];
497
+ maxHeight: (StringConstructor | NumberConstructor)[];
498
+ maxWidth: (StringConstructor | NumberConstructor)[];
499
+ minHeight: (StringConstructor | NumberConstructor)[];
500
+ minWidth: (StringConstructor | NumberConstructor)[];
501
+ width: (StringConstructor | NumberConstructor)[];
502
+ tag: {
503
+ type: StringConstructor;
504
+ default: string;
505
+ };
506
+ size: {
507
+ type: (StringConstructor | NumberConstructor)[];
508
+ default: string;
509
+ };
510
+ elevation: {
511
+ type: (StringConstructor | NumberConstructor)[];
512
+ validator(v: any): boolean;
513
+ };
514
+ rounded: {
515
+ type: (StringConstructor | BooleanConstructor | NumberConstructor)[];
516
+ default: undefined;
517
+ };
518
+ density: PropType<"default" | "compact">;
519
+ dotColor: StringConstructor;
520
+ fillDot: BooleanConstructor;
521
+ hideDot: BooleanConstructor;
522
+ hideOpposite: {
523
+ type: BooleanConstructor;
524
+ default: undefined;
525
+ };
526
+ icon: PropType<IconValue>;
527
+ iconColor: StringConstructor;
528
+ lineInset: (StringConstructor | NumberConstructor)[];
529
+ }>>;
160
530
  type VTimelineItem = InstanceType<typeof VTimelineItem>;
161
531
 
162
532
  export { VTimeline, VTimelineItem };
@@ -15,7 +15,7 @@ import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
15
15
  import { provideDefaults } from "../../composables/defaults.mjs";
16
16
  import { useBackgroundColor } from "../../composables/color.mjs"; // Utilities
17
17
  import { computed, ref, toRef } from 'vue';
18
- import { convertToUnit, genericComponent, pick, propsFactory, useRender } from "../../util/index.mjs"; // Types
18
+ import { convertToUnit, genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
19
19
  const allowedDensities = [null, 'prominent', 'default', 'comfortable', 'compact'];
20
20
  export const makeVToolbarProps = propsFactory({
21
21
  absolute: Boolean,
@@ -155,7 +155,4 @@ export const VToolbar = genericComponent()({
155
155
  };
156
156
  }
157
157
  });
158
- export function filterToolbarProps(props) {
159
- return pick(props, Object.keys(VToolbar?.props ?? {}));
160
- }
161
158
  //# sourceMappingURL=VToolbar.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"VToolbar.mjs","names":["VDefaultsProvider","VExpandTransition","VImg","VToolbarTitle","makeBorderProps","useBorder","makeElevationProps","useElevation","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","provideDefaults","useBackgroundColor","computed","ref","toRef","convertToUnit","genericComponent","pick","propsFactory","useRender","allowedDensities","makeVToolbarProps","absolute","Boolean","collapse","color","String","density","type","default","validator","v","includes","extended","extensionHeight","Number","flat","floating","height","image","title","tag","VToolbar","name","props","setup","slots","backgroundColorClasses","backgroundColorStyles","borderClasses","elevationClasses","roundedClasses","themeClasses","isExtended","extension","contentHeight","parseInt","value","VBtn","variant","hasTitle","hasImage","cover","src","VTabs","prepend","text","append","filterToolbarProps","Object","keys"],"sources":["../../../src/components/VToolbar/VToolbar.tsx"],"sourcesContent":["// Styles\nimport './VToolbar.sass'\n\n// Components\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VExpandTransition } from '@/components/transitions'\nimport { VImg } from '@/components/VImg'\nimport { VToolbarTitle } from './VToolbarTitle'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { provideDefaults } from '@/composables/defaults'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Utilities\nimport { computed, ref, toRef } from 'vue'\nimport { convertToUnit, genericComponent, pick, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { ExtractPropTypes, PropType } from 'vue'\nimport type { MakeSlots } from '@/util'\n\nconst allowedDensities = [null, 'prominent', 'default', 'comfortable', 'compact'] as const\n\nexport type Density = null | 'prominent' | 'default' | 'comfortable' | 'compact'\n\nexport const makeVToolbarProps = propsFactory({\n absolute: Boolean,\n collapse: Boolean,\n color: String,\n density: {\n type: String as PropType<Density>,\n default: 'default',\n validator: (v: any) => allowedDensities.includes(v),\n },\n extended: Boolean,\n extensionHeight: {\n type: [Number, String],\n default: 48,\n },\n flat: Boolean,\n floating: Boolean,\n height: {\n type: [Number, String],\n default: 64,\n },\n image: String,\n title: String,\n\n ...makeBorderProps(),\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeTagProps({ tag: 'header' }),\n ...makeThemeProps(),\n}, 'v-toolbar')\n\nexport type VToolbarSlots = MakeSlots<{\n default: []\n image: []\n prepend: []\n append: []\n title: []\n extension: []\n}>\n\nexport const VToolbar = genericComponent<VToolbarSlots>()({\n name: 'VToolbar',\n\n props: makeVToolbarProps(),\n\n setup (props, { slots }) {\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const { borderClasses } = useBorder(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { themeClasses } = provideTheme(props)\n\n const isExtended = ref(!!(props.extended || slots.extension?.()))\n const contentHeight = computed(() => parseInt((\n Number(props.height) +\n (props.density === 'prominent' ? Number(props.height) : 0) -\n (props.density === 'comfortable' ? 8 : 0) -\n (props.density === 'compact' ? 16 : 0)\n ), 10))\n const extensionHeight = computed(() => isExtended.value\n ? parseInt((\n Number(props.extensionHeight) +\n (props.density === 'prominent' ? Number(props.extensionHeight) : 0) -\n (props.density === 'comfortable' ? 4 : 0) -\n (props.density === 'compact' ? 8 : 0)\n ), 10)\n : 0\n )\n\n provideDefaults({\n VBtn: {\n variant: 'text',\n },\n })\n\n useRender(() => {\n const hasTitle = !!(props.title || slots.title)\n const hasImage = !!(slots.image || props.image)\n\n const extension = slots.extension?.()\n isExtended.value = !!(props.extended || extension)\n\n return (\n <props.tag\n class={[\n 'v-toolbar',\n {\n 'v-toolbar--absolute': props.absolute,\n 'v-toolbar--collapse': props.collapse,\n 'v-toolbar--flat': props.flat,\n 'v-toolbar--floating': props.floating,\n [`v-toolbar--density-${props.density}`]: true,\n },\n backgroundColorClasses.value,\n borderClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n themeClasses.value,\n ]}\n style={[\n backgroundColorStyles.value,\n ]}\n >\n { hasImage && (\n <div key=\"image\" class=\"v-toolbar__image\">\n { !slots.image ? (\n <VImg\n key=\"image-img\"\n cover\n src={ props.image }\n />\n ) : (\n <VDefaultsProvider\n key=\"image-defaults\"\n disabled={ !props.image }\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n v-slots:default={ slots.image }\n />\n )}\n </div>\n )}\n\n <VDefaultsProvider\n defaults={{\n VTabs: {\n height: convertToUnit(contentHeight.value),\n },\n }}\n >\n <div\n class=\"v-toolbar__content\"\n style={{ height: convertToUnit(contentHeight.value) }}\n >\n { slots.prepend && (\n <div class=\"v-toolbar__prepend\">\n { slots.prepend?.() }\n </div>\n )}\n\n { hasTitle && (\n <VToolbarTitle key=\"title\" text={ props.title }>\n {{ text: slots.title }}\n </VToolbarTitle>\n )}\n\n { slots.default?.() }\n\n { slots.append && (\n <div class=\"v-toolbar__append\">\n { slots.append?.() }\n </div>\n )}\n </div>\n </VDefaultsProvider>\n\n <VDefaultsProvider\n defaults={{\n VTabs: {\n height: convertToUnit(extensionHeight.value),\n },\n }}\n >\n <VExpandTransition>\n { isExtended.value && (\n <div\n class=\"v-toolbar__extension\"\n style={{ height: convertToUnit(extensionHeight.value) }}\n >\n { extension }\n </div>\n )}\n </VExpandTransition>\n </VDefaultsProvider>\n </props.tag>\n )\n })\n\n return {\n contentHeight,\n extensionHeight,\n }\n },\n})\n\nexport type VToolbar = InstanceType<typeof VToolbar>\n\nexport function filterToolbarProps (props: ExtractPropTypes<ReturnType<typeof makeVToolbarProps>>) {\n return pick(props, Object.keys(VToolbar?.props ?? {}) as any)\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"VToolbar.mjs","names":["VDefaultsProvider","VExpandTransition","VImg","VToolbarTitle","makeBorderProps","useBorder","makeElevationProps","useElevation","makeRoundedProps","useRounded","makeTagProps","makeThemeProps","provideTheme","provideDefaults","useBackgroundColor","computed","ref","toRef","convertToUnit","genericComponent","propsFactory","useRender","allowedDensities","makeVToolbarProps","absolute","Boolean","collapse","color","String","density","type","default","validator","v","includes","extended","extensionHeight","Number","flat","floating","height","image","title","tag","VToolbar","name","props","setup","slots","backgroundColorClasses","backgroundColorStyles","borderClasses","elevationClasses","roundedClasses","themeClasses","isExtended","extension","contentHeight","parseInt","value","VBtn","variant","hasTitle","hasImage","cover","src","VTabs","prepend","text","append"],"sources":["../../../src/components/VToolbar/VToolbar.tsx"],"sourcesContent":["// Styles\nimport './VToolbar.sass'\n\n// Components\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VExpandTransition } from '@/components/transitions'\nimport { VImg } from '@/components/VImg'\nimport { VToolbarTitle } from './VToolbarTitle'\n\n// Composables\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { provideDefaults } from '@/composables/defaults'\nimport { useBackgroundColor } from '@/composables/color'\n\n// Utilities\nimport { computed, ref, toRef } from 'vue'\nimport { convertToUnit, genericComponent, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { MakeSlots } from '@/util'\n\nconst allowedDensities = [null, 'prominent', 'default', 'comfortable', 'compact'] as const\n\nexport type Density = null | 'prominent' | 'default' | 'comfortable' | 'compact'\n\nexport const makeVToolbarProps = propsFactory({\n absolute: Boolean,\n collapse: Boolean,\n color: String,\n density: {\n type: String as PropType<Density>,\n default: 'default',\n validator: (v: any) => allowedDensities.includes(v),\n },\n extended: Boolean,\n extensionHeight: {\n type: [Number, String],\n default: 48,\n },\n flat: Boolean,\n floating: Boolean,\n height: {\n type: [Number, String],\n default: 64,\n },\n image: String,\n title: String,\n\n ...makeBorderProps(),\n ...makeElevationProps(),\n ...makeRoundedProps(),\n ...makeTagProps({ tag: 'header' }),\n ...makeThemeProps(),\n}, 'v-toolbar')\n\nexport type VToolbarSlots = MakeSlots<{\n default: []\n image: []\n prepend: []\n append: []\n title: []\n extension: []\n}>\n\nexport const VToolbar = genericComponent<VToolbarSlots>()({\n name: 'VToolbar',\n\n props: makeVToolbarProps(),\n\n setup (props, { slots }) {\n const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))\n const { borderClasses } = useBorder(props)\n const { elevationClasses } = useElevation(props)\n const { roundedClasses } = useRounded(props)\n const { themeClasses } = provideTheme(props)\n\n const isExtended = ref(!!(props.extended || slots.extension?.()))\n const contentHeight = computed(() => parseInt((\n Number(props.height) +\n (props.density === 'prominent' ? Number(props.height) : 0) -\n (props.density === 'comfortable' ? 8 : 0) -\n (props.density === 'compact' ? 16 : 0)\n ), 10))\n const extensionHeight = computed(() => isExtended.value\n ? parseInt((\n Number(props.extensionHeight) +\n (props.density === 'prominent' ? Number(props.extensionHeight) : 0) -\n (props.density === 'comfortable' ? 4 : 0) -\n (props.density === 'compact' ? 8 : 0)\n ), 10)\n : 0\n )\n\n provideDefaults({\n VBtn: {\n variant: 'text',\n },\n })\n\n useRender(() => {\n const hasTitle = !!(props.title || slots.title)\n const hasImage = !!(slots.image || props.image)\n\n const extension = slots.extension?.()\n isExtended.value = !!(props.extended || extension)\n\n return (\n <props.tag\n class={[\n 'v-toolbar',\n {\n 'v-toolbar--absolute': props.absolute,\n 'v-toolbar--collapse': props.collapse,\n 'v-toolbar--flat': props.flat,\n 'v-toolbar--floating': props.floating,\n [`v-toolbar--density-${props.density}`]: true,\n },\n backgroundColorClasses.value,\n borderClasses.value,\n elevationClasses.value,\n roundedClasses.value,\n themeClasses.value,\n ]}\n style={[\n backgroundColorStyles.value,\n ]}\n >\n { hasImage && (\n <div key=\"image\" class=\"v-toolbar__image\">\n { !slots.image ? (\n <VImg\n key=\"image-img\"\n cover\n src={ props.image }\n />\n ) : (\n <VDefaultsProvider\n key=\"image-defaults\"\n disabled={ !props.image }\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n v-slots:default={ slots.image }\n />\n )}\n </div>\n )}\n\n <VDefaultsProvider\n defaults={{\n VTabs: {\n height: convertToUnit(contentHeight.value),\n },\n }}\n >\n <div\n class=\"v-toolbar__content\"\n style={{ height: convertToUnit(contentHeight.value) }}\n >\n { slots.prepend && (\n <div class=\"v-toolbar__prepend\">\n { slots.prepend?.() }\n </div>\n )}\n\n { hasTitle && (\n <VToolbarTitle key=\"title\" text={ props.title }>\n {{ text: slots.title }}\n </VToolbarTitle>\n )}\n\n { slots.default?.() }\n\n { slots.append && (\n <div class=\"v-toolbar__append\">\n { slots.append?.() }\n </div>\n )}\n </div>\n </VDefaultsProvider>\n\n <VDefaultsProvider\n defaults={{\n VTabs: {\n height: convertToUnit(extensionHeight.value),\n },\n }}\n >\n <VExpandTransition>\n { isExtended.value && (\n <div\n class=\"v-toolbar__extension\"\n style={{ height: convertToUnit(extensionHeight.value) }}\n >\n { extension }\n </div>\n )}\n </VExpandTransition>\n </VDefaultsProvider>\n </props.tag>\n )\n })\n\n return {\n contentHeight,\n extensionHeight,\n }\n },\n})\n\nexport type VToolbar = InstanceType<typeof VToolbar>\n"],"mappings":"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"}