@vuetify/nightly 3.0.0-beta.10 → 3.0.0-beta.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +13 -2
- package/dist/json/attributes.json +37 -29
- package/dist/json/importMap.json +46 -46
- package/dist/json/tags.json +10 -8
- package/dist/json/web-types.json +101 -87
- package/dist/vuetify.css +545 -441
- package/dist/vuetify.d.ts +12095 -10059
- package/dist/vuetify.esm.js +401 -266
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +371 -236
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +3 -3
- package/dist/vuetify.min.js +496 -490
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/index.d.ts +171 -0
- package/lib/blueprints/md1.d.ts +167 -0
- package/lib/blueprints/md2.d.ts +167 -0
- package/lib/blueprints/md3.d.ts +167 -0
- package/lib/components/VAlert/index.d.ts +185 -0
- package/lib/components/VApp/index.d.ts +83 -0
- package/lib/components/VAppBar/VAppBar.css +3 -0
- package/lib/components/VAppBar/VAppBar.sass +3 -0
- package/lib/components/VAppBar/index.d.ts +156 -0
- package/lib/components/VAutocomplete/VAutocomplete.mjs +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/index.d.ts +1569 -0
- package/lib/components/VAvatar/VAvatar.css +44 -2
- package/lib/components/VAvatar/VAvatar.mjs +16 -12
- package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
- package/lib/components/VAvatar/VAvatar.sass +5 -1
- package/lib/components/VAvatar/_variables.scss +9 -4
- package/lib/components/VAvatar/index.d.ts +80 -0
- package/lib/components/VBadge/index.d.ts +123 -0
- package/lib/components/VBanner/index.d.ts +122 -0
- package/lib/components/VBottomNavigation/index.d.ts +143 -0
- package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs +2 -2
- package/lib/components/VBreadcrumbs/VBreadcrumbsItem.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/index.d.ts +301 -0
- package/lib/components/VBtn/VBtn.css +8 -3
- package/lib/components/VBtn/VBtn.mjs +16 -6
- package/lib/components/VBtn/VBtn.mjs.map +1 -1
- package/lib/components/VBtn/index.d.ts +210 -0
- package/lib/components/VBtnGroup/index.d.ts +65 -0
- package/lib/components/VBtnToggle/VBtnToggle.mjs +1 -3
- package/lib/components/VBtnToggle/VBtnToggle.mjs.map +1 -1
- package/lib/components/VBtnToggle/index.d.ts +175 -0
- package/lib/components/VCard/VCard.css +8 -3
- package/lib/components/VCard/index.d.ts +230 -0
- package/lib/components/VCarousel/VCarousel.mjs +3 -3
- package/lib/components/VCarousel/VCarousel.mjs.map +1 -1
- package/lib/components/VCarousel/index.d.ts +80 -0
- package/lib/components/VCheckbox/index.d.ts +291 -0
- package/lib/components/VChip/index.d.ts +195 -0
- package/lib/components/VChipGroup/index.d.ts +89 -0
- package/lib/components/VCode/index.d.ts +19 -0
- package/lib/components/VColorPicker/index.d.ts +116 -0
- package/lib/components/VCombobox/VCombobox.mjs +1 -1
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/index.d.ts +1590 -0
- package/lib/components/VCounter/index.d.ts +223 -0
- package/lib/components/VDefaultsProvider/index.d.ts +26 -0
- package/lib/components/VDialog/VDialog.css +2 -0
- package/lib/components/VDialog/VDialog.mjs +17 -12
- package/lib/components/VDialog/VDialog.mjs.map +1 -1
- package/lib/components/VDialog/VDialog.sass +2 -0
- package/lib/components/VDialog/index.d.ts +859 -0
- package/lib/components/VDivider/index.d.ts +22 -0
- package/lib/components/VExpansionPanel/VExpansionPanel.css +8 -3
- package/lib/components/VExpansionPanel/index.d.ts +206 -0
- package/lib/components/VField/VField.css +27 -24
- package/lib/components/VField/VField.mjs +1 -1
- package/lib/components/VField/VField.mjs.map +1 -1
- package/lib/components/VField/VField.sass +23 -21
- package/lib/components/VField/index.d.ts +332 -0
- package/lib/components/VFileInput/VFileInput.mjs +3 -3
- package/lib/components/VFileInput/VFileInput.mjs.map +1 -1
- package/lib/components/VFileInput/index.d.ts +236 -0
- package/lib/components/VFooter/VFooter.css +7 -0
- package/lib/components/VFooter/VFooter.sass +1 -1
- package/lib/components/VFooter/_variables.scss +11 -0
- package/lib/components/VFooter/index.d.ts +76 -0
- package/lib/components/VForm/index.d.ts +72 -0
- package/lib/components/VGrid/index.d.ts +154 -0
- package/lib/components/VHover/index.d.ts +30 -0
- package/lib/components/VIcon/index.d.ts +124 -0
- package/lib/components/VImg/VImg.mjs +29 -27
- package/lib/components/VImg/VImg.mjs.map +1 -1
- package/lib/components/VImg/index.d.ts +89 -0
- package/lib/components/VInput/VInput.mjs +4 -4
- package/lib/components/VInput/VInput.mjs.map +1 -1
- package/lib/components/VInput/index.d.ts +325 -0
- package/lib/components/VItemGroup/index.d.ts +210 -0
- package/lib/components/VKbd/index.d.ts +19 -0
- package/lib/components/VLabel/VLabel.css +4 -1
- package/lib/components/VLabel/VLabel.mjs +4 -1
- package/lib/components/VLabel/VLabel.mjs.map +1 -1
- package/lib/components/VLabel/VLabel.sass +3 -1
- package/lib/components/VLabel/index.d.ts +16 -0
- package/lib/components/VLayout/index.d.ts +75 -0
- package/lib/components/VLazy/index.d.ts +85 -0
- package/lib/components/VList/VListItem.css +8 -3
- package/lib/components/VList/VListItem.mjs +4 -4
- package/lib/components/VList/VListItem.mjs.map +1 -1
- package/lib/components/VList/index.d.ts +1250 -0
- package/lib/components/VLocaleProvider/index.d.ts +23 -0
- package/lib/components/VMain/index.d.ts +26 -0
- package/lib/components/VMenu/VMenu.mjs +16 -3
- package/lib/components/VMenu/VMenu.mjs.map +1 -1
- package/lib/components/VMenu/index.d.ts +817 -0
- package/lib/components/VMessages/index.d.ts +234 -0
- package/lib/components/VNavigationDrawer/index.d.ts +148 -0
- package/lib/components/VNoSsr/index.d.ts +7 -0
- package/lib/components/VOverlay/VOverlay.mjs +4 -3
- package/lib/components/VOverlay/VOverlay.mjs.map +1 -1
- package/lib/components/VOverlay/index.d.ts +579 -0
- package/lib/components/VOverlay/useActivator.mjs +27 -1
- package/lib/components/VOverlay/useActivator.mjs.map +1 -1
- package/lib/components/VPagination/VPagination.mjs +6 -3
- package/lib/components/VPagination/VPagination.mjs.map +1 -1
- package/lib/components/VPagination/index.d.ts +247 -0
- package/lib/components/VParallax/VParallax.mjs +24 -10
- package/lib/components/VParallax/VParallax.mjs.map +1 -1
- package/lib/components/VParallax/index.d.ts +18 -0
- package/lib/components/VProgressCircular/index.d.ts +68 -0
- package/lib/components/VProgressLinear/index.d.ts +101 -0
- package/lib/components/VRadio/index.d.ts +103 -0
- package/lib/components/VRadioGroup/VRadioGroup.css +2 -3
- package/lib/components/VRadioGroup/VRadioGroup.mjs +2 -1
- package/lib/components/VRadioGroup/VRadioGroup.mjs.map +1 -1
- package/lib/components/VRadioGroup/VRadioGroup.sass +2 -2
- package/lib/components/VRadioGroup/_variables.scss +0 -1
- package/lib/components/VRadioGroup/index.d.ts +186 -0
- package/lib/components/VRangeSlider/VRangeSlider.mjs +12 -2
- package/lib/components/VRangeSlider/VRangeSlider.mjs.map +1 -1
- package/lib/components/VRangeSlider/index.d.ts +242 -0
- package/lib/components/VRating/index.d.ts +356 -0
- package/lib/components/VResponsive/index.d.ts +23 -0
- package/lib/components/VSelect/VSelect.mjs +1 -1
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSelect/index.d.ts +1521 -0
- package/lib/components/VSelectionControl/VSelectionControl.mjs +2 -1
- package/lib/components/VSelectionControl/VSelectionControl.mjs.map +1 -1
- package/lib/components/VSelectionControl/index.d.ts +275 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.css +5 -0
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs +3 -1
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.mjs.map +1 -1
- package/lib/components/VSelectionControlGroup/VSelectionControlGroup.sass +5 -0
- package/lib/components/VSelectionControlGroup/index.d.ts +47 -0
- package/lib/components/VSheet/index.d.ts +68 -0
- package/lib/components/VSlideGroup/index.d.ts +151 -0
- package/lib/components/VSlider/VSlider.css +7 -2
- package/lib/components/VSlider/VSlider.mjs +14 -4
- package/lib/components/VSlider/VSlider.mjs.map +1 -1
- package/lib/components/VSlider/VSlider.sass +6 -2
- package/lib/components/VSlider/VSliderTrack.css +20 -20
- package/lib/components/VSlider/VSliderTrack.mjs +7 -3
- package/lib/components/VSlider/VSliderTrack.mjs.map +1 -1
- package/lib/components/VSlider/VSliderTrack.sass +14 -14
- package/lib/components/VSlider/_variables.scss +2 -2
- package/lib/components/VSlider/index.d.ts +239 -0
- package/lib/components/VSlider/slider.mjs +2 -2
- package/lib/components/VSlider/slider.mjs.map +1 -1
- package/lib/components/VSnackbar/VSnackbar.mjs +3 -2
- package/lib/components/VSnackbar/VSnackbar.mjs.map +1 -1
- package/lib/components/VSnackbar/index.d.ts +892 -0
- package/lib/components/VSwitch/index.d.ts +175 -0
- package/lib/components/VSystemBar/index.d.ts +61 -0
- package/lib/components/VTable/index.d.ts +39 -0
- package/lib/components/VTabs/VTab.mjs +1 -0
- package/lib/components/VTabs/VTab.mjs.map +1 -1
- package/lib/components/VTabs/index.d.ts +178 -0
- package/lib/components/VTextField/VTextField.css +2 -3
- package/lib/components/VTextField/VTextField.sass +2 -4
- package/lib/components/VTextField/index.d.ts +582 -0
- package/lib/components/VTextarea/VTextarea.css +5 -3
- package/lib/components/VTextarea/VTextarea.mjs +2 -1
- package/lib/components/VTextarea/VTextarea.mjs.map +1 -1
- package/lib/components/VTextarea/VTextarea.sass +5 -4
- package/lib/components/VTextarea/index.d.ts +218 -0
- package/lib/components/VThemeProvider/index.d.ts +24 -0
- package/lib/components/VTimeline/VTimeline.css +21 -6
- package/lib/components/VTimeline/VTimeline.mjs +6 -1
- package/lib/components/VTimeline/VTimeline.mjs.map +1 -1
- package/lib/components/VTimeline/VTimeline.sass +16 -2
- package/lib/components/VTimeline/_variables.scss +4 -3
- package/lib/components/VTimeline/index.d.ts +154 -0
- package/lib/components/VToolbar/VToolbar.css +0 -1
- package/lib/components/VToolbar/VToolbar.sass +0 -1
- package/lib/components/VToolbar/index.d.ts +414 -0
- package/lib/components/VTooltip/VTooltip.mjs.map +1 -1
- package/lib/components/VTooltip/index.d.ts +799 -0
- package/lib/components/VValidation/index.d.ts +61 -0
- package/lib/components/VWindow/index.d.ts +428 -0
- package/lib/components/index.d.ts +12037 -10009
- package/lib/components/transitions/index.d.ts +454 -0
- package/lib/composables/display.mjs +3 -3
- package/lib/composables/display.mjs.map +1 -1
- package/lib/composables/items.mjs.map +1 -1
- package/lib/composables/locale.mjs +10 -3
- package/lib/composables/locale.mjs.map +1 -1
- package/lib/composables/proxiedModel.mjs +28 -10
- package/lib/composables/proxiedModel.mjs.map +1 -1
- package/lib/composables/router.mjs +10 -2
- package/lib/composables/router.mjs.map +1 -1
- package/lib/composables/selectLink.mjs +4 -4
- package/lib/composables/selectLink.mjs.map +1 -1
- package/lib/composables/theme.mjs +37 -33
- package/lib/composables/theme.mjs.map +1 -1
- package/lib/composables/validation.mjs +1 -1
- package/lib/composables/validation.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +46 -51
- package/lib/framework.mjs.map +1 -1
- package/lib/index.d.ts +31 -22
- package/lib/locale/adapters/vue-i18n.d.ts +35 -0
- package/lib/locale/adapters/vue-intl.d.ts +42 -0
- package/lib/styles/main.css +73 -73
- package/lib/styles/settings/_colors.scss +84 -84
- package/lib/styles/tools/_states.sass +8 -3
- package/lib/util/getCurrentInstance.mjs +2 -3
- package/lib/util/getCurrentInstance.mjs.map +1 -1
- package/lib/util/helpers.mjs +6 -11
- package/lib/util/helpers.mjs.map +1 -1
- package/package.json +4 -2
|
@@ -0,0 +1,332 @@
|
|
|
1
|
+
import * as vue from 'vue';
|
|
2
|
+
import { VNodeChild, PropType, JSXComponent, ComputedRef, Ref } from 'vue';
|
|
3
|
+
|
|
4
|
+
declare type SlotsToProps<T extends Record<string, Slot>> = {
|
|
5
|
+
$children: () => (T['default'] | VNodeChild | {
|
|
6
|
+
[K in keyof T]?: T[K];
|
|
7
|
+
});
|
|
8
|
+
'v-slots': new () => {
|
|
9
|
+
[K in keyof T]?: T[K] | false;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
declare type Slot<T extends any[] = any[]> = (...args: T) => VNodeChild;
|
|
13
|
+
declare type MakeSlots<T extends Record<string, any[]>> = {
|
|
14
|
+
[K in keyof T]?: Slot<T[K]>;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
declare type EventProp<T = (...args: any[]) => any> = T | T[];
|
|
18
|
+
declare const EventProp: PropType<EventProp<(...args: any[]) => any>>;
|
|
19
|
+
|
|
20
|
+
declare type IconValue = string | JSXComponent;
|
|
21
|
+
declare const IconValue: PropType<IconValue>;
|
|
22
|
+
|
|
23
|
+
interface LoaderSlotProps {
|
|
24
|
+
color: string | undefined;
|
|
25
|
+
isActive: boolean;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
interface VInputSlot {
|
|
29
|
+
id: ComputedRef<string>;
|
|
30
|
+
isDirty: ComputedRef<boolean>;
|
|
31
|
+
isDisabled: ComputedRef<boolean>;
|
|
32
|
+
isReadonly: ComputedRef<boolean>;
|
|
33
|
+
isPristine: Ref<boolean>;
|
|
34
|
+
isValid: ComputedRef<boolean | null>;
|
|
35
|
+
isValidating: Ref<boolean>;
|
|
36
|
+
reset: () => void;
|
|
37
|
+
resetValidation: () => void;
|
|
38
|
+
validate: () => void;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
interface DefaultInputSlot {
|
|
42
|
+
isActive: Ref<boolean>;
|
|
43
|
+
isFocused: Ref<boolean>;
|
|
44
|
+
controlRef: Ref<HTMLElement | undefined>;
|
|
45
|
+
focus: () => void;
|
|
46
|
+
blur: () => void;
|
|
47
|
+
}
|
|
48
|
+
interface VFieldSlot extends DefaultInputSlot {
|
|
49
|
+
props: Record<string, unknown>;
|
|
50
|
+
}
|
|
51
|
+
declare type VFieldSlots = MakeSlots<{
|
|
52
|
+
clear: [];
|
|
53
|
+
'prepend-inner': [DefaultInputSlot & VInputSlot];
|
|
54
|
+
'append-inner': [DefaultInputSlot & VInputSlot];
|
|
55
|
+
label: [DefaultInputSlot & VInputSlot];
|
|
56
|
+
loader: [LoaderSlotProps];
|
|
57
|
+
default: [VFieldSlot];
|
|
58
|
+
}>;
|
|
59
|
+
declare const VField: {
|
|
60
|
+
new (...args: any[]): {
|
|
61
|
+
$: vue.ComponentInternalInstance;
|
|
62
|
+
$data: {};
|
|
63
|
+
$props: Partial<{
|
|
64
|
+
reverse: boolean;
|
|
65
|
+
error: boolean;
|
|
66
|
+
active: boolean;
|
|
67
|
+
loading: boolean;
|
|
68
|
+
disabled: boolean;
|
|
69
|
+
variant: "filled" | "outlined" | "plain" | "underlined" | "solo";
|
|
70
|
+
clearIcon: IconValue;
|
|
71
|
+
focused: boolean;
|
|
72
|
+
clearable: boolean;
|
|
73
|
+
dirty: boolean;
|
|
74
|
+
persistentClear: boolean;
|
|
75
|
+
singleLine: boolean;
|
|
76
|
+
}> & Omit<Readonly<vue.ExtractPropTypes<Omit<{
|
|
77
|
+
loading: BooleanConstructor;
|
|
78
|
+
theme: StringConstructor;
|
|
79
|
+
appendInnerIcon: PropType<IconValue>;
|
|
80
|
+
bgColor: StringConstructor;
|
|
81
|
+
clearable: BooleanConstructor;
|
|
82
|
+
clearIcon: {
|
|
83
|
+
type: PropType<IconValue>;
|
|
84
|
+
default: string;
|
|
85
|
+
};
|
|
86
|
+
active: BooleanConstructor;
|
|
87
|
+
color: StringConstructor;
|
|
88
|
+
dirty: BooleanConstructor;
|
|
89
|
+
disabled: BooleanConstructor;
|
|
90
|
+
error: BooleanConstructor;
|
|
91
|
+
label: StringConstructor;
|
|
92
|
+
persistentClear: BooleanConstructor;
|
|
93
|
+
prependInnerIcon: PropType<IconValue>;
|
|
94
|
+
reverse: BooleanConstructor;
|
|
95
|
+
singleLine: BooleanConstructor;
|
|
96
|
+
variant: {
|
|
97
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
98
|
+
default: string;
|
|
99
|
+
validator: (v: any) => boolean;
|
|
100
|
+
};
|
|
101
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
102
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
103
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
104
|
+
focused: BooleanConstructor;
|
|
105
|
+
id: StringConstructor;
|
|
106
|
+
}, "onUpdate:modelValue" | "modelValue"> & SlotsToProps<MakeSlots<{
|
|
107
|
+
clear: [];
|
|
108
|
+
'prepend-inner': [DefaultInputSlot & VInputSlot];
|
|
109
|
+
'append-inner': [DefaultInputSlot & VInputSlot];
|
|
110
|
+
label: [DefaultInputSlot & VInputSlot];
|
|
111
|
+
loader: [LoaderSlotProps];
|
|
112
|
+
default: [VFieldSlot];
|
|
113
|
+
}>>>> & {
|
|
114
|
+
"onUpdate:focused"?: ((focused: boolean) => any) | undefined;
|
|
115
|
+
"onClick:control"?: ((e: MouseEvent) => any) | undefined;
|
|
116
|
+
} & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "reverse" | "error" | "active" | "loading" | "disabled" | "variant" | "clearIcon" | "focused" | "clearable" | "dirty" | "persistentClear" | "singleLine">;
|
|
117
|
+
$attrs: {
|
|
118
|
+
[x: string]: unknown;
|
|
119
|
+
};
|
|
120
|
+
$refs: {
|
|
121
|
+
[x: string]: unknown;
|
|
122
|
+
};
|
|
123
|
+
$slots: Readonly<{
|
|
124
|
+
[name: string]: vue.Slot | undefined;
|
|
125
|
+
}>;
|
|
126
|
+
$root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
|
|
127
|
+
$parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
|
|
128
|
+
$emit: ((event: "click:control", e: MouseEvent) => void) & ((event: "update:focused", focused: boolean) => void);
|
|
129
|
+
$el: any;
|
|
130
|
+
$options: vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<Omit<{
|
|
131
|
+
loading: BooleanConstructor;
|
|
132
|
+
theme: StringConstructor;
|
|
133
|
+
appendInnerIcon: PropType<IconValue>;
|
|
134
|
+
bgColor: StringConstructor;
|
|
135
|
+
clearable: BooleanConstructor;
|
|
136
|
+
clearIcon: {
|
|
137
|
+
type: PropType<IconValue>;
|
|
138
|
+
default: string;
|
|
139
|
+
};
|
|
140
|
+
active: BooleanConstructor;
|
|
141
|
+
color: StringConstructor;
|
|
142
|
+
dirty: BooleanConstructor;
|
|
143
|
+
disabled: BooleanConstructor;
|
|
144
|
+
error: BooleanConstructor;
|
|
145
|
+
label: StringConstructor;
|
|
146
|
+
persistentClear: BooleanConstructor;
|
|
147
|
+
prependInnerIcon: PropType<IconValue>;
|
|
148
|
+
reverse: BooleanConstructor;
|
|
149
|
+
singleLine: BooleanConstructor;
|
|
150
|
+
variant: {
|
|
151
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
152
|
+
default: string;
|
|
153
|
+
validator: (v: any) => boolean;
|
|
154
|
+
};
|
|
155
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
156
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
157
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
158
|
+
focused: BooleanConstructor;
|
|
159
|
+
id: StringConstructor;
|
|
160
|
+
}, "onUpdate:modelValue" | "modelValue"> & SlotsToProps<MakeSlots<{
|
|
161
|
+
clear: [];
|
|
162
|
+
'prepend-inner': [DefaultInputSlot & VInputSlot];
|
|
163
|
+
'append-inner': [DefaultInputSlot & VInputSlot];
|
|
164
|
+
label: [DefaultInputSlot & VInputSlot];
|
|
165
|
+
loader: [LoaderSlotProps];
|
|
166
|
+
default: [VFieldSlot];
|
|
167
|
+
}>>>> & {
|
|
168
|
+
"onUpdate:focused"?: ((focused: boolean) => any) | undefined;
|
|
169
|
+
"onClick:control"?: ((e: MouseEvent) => any) | undefined;
|
|
170
|
+
}, {
|
|
171
|
+
controlRef: Ref<HTMLElement | undefined>;
|
|
172
|
+
}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<{
|
|
173
|
+
'click:control': (e: MouseEvent) => boolean;
|
|
174
|
+
'update:focused': (focused: boolean) => boolean;
|
|
175
|
+
'update:modelValue': (val: any) => boolean;
|
|
176
|
+
}, "update:modelValue" | "modelValue">, string, {
|
|
177
|
+
reverse: boolean;
|
|
178
|
+
error: boolean;
|
|
179
|
+
active: boolean;
|
|
180
|
+
loading: boolean;
|
|
181
|
+
disabled: boolean;
|
|
182
|
+
variant: "filled" | "outlined" | "plain" | "underlined" | "solo";
|
|
183
|
+
clearIcon: IconValue;
|
|
184
|
+
focused: boolean;
|
|
185
|
+
clearable: boolean;
|
|
186
|
+
dirty: boolean;
|
|
187
|
+
persistentClear: boolean;
|
|
188
|
+
singleLine: boolean;
|
|
189
|
+
}> & {
|
|
190
|
+
beforeCreate?: ((() => void) | (() => void)[]) | undefined;
|
|
191
|
+
created?: ((() => void) | (() => void)[]) | undefined;
|
|
192
|
+
beforeMount?: ((() => void) | (() => void)[]) | undefined;
|
|
193
|
+
mounted?: ((() => void) | (() => void)[]) | undefined;
|
|
194
|
+
beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
|
|
195
|
+
updated?: ((() => void) | (() => void)[]) | undefined;
|
|
196
|
+
activated?: ((() => void) | (() => void)[]) | undefined;
|
|
197
|
+
deactivated?: ((() => void) | (() => void)[]) | undefined;
|
|
198
|
+
beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
|
|
199
|
+
beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
|
|
200
|
+
destroyed?: ((() => void) | (() => void)[]) | undefined;
|
|
201
|
+
unmounted?: ((() => void) | (() => void)[]) | undefined;
|
|
202
|
+
renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
|
|
203
|
+
renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
|
|
204
|
+
errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void)[]) | undefined;
|
|
205
|
+
};
|
|
206
|
+
$forceUpdate: () => void;
|
|
207
|
+
$nextTick: typeof vue.nextTick;
|
|
208
|
+
$watch(source: string | Function, cb: Function, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
|
|
209
|
+
} & Readonly<vue.ExtractPropTypes<Omit<{
|
|
210
|
+
loading: BooleanConstructor;
|
|
211
|
+
theme: StringConstructor;
|
|
212
|
+
appendInnerIcon: PropType<IconValue>;
|
|
213
|
+
bgColor: StringConstructor;
|
|
214
|
+
clearable: BooleanConstructor;
|
|
215
|
+
clearIcon: {
|
|
216
|
+
type: PropType<IconValue>;
|
|
217
|
+
default: string;
|
|
218
|
+
};
|
|
219
|
+
active: BooleanConstructor;
|
|
220
|
+
color: StringConstructor;
|
|
221
|
+
dirty: BooleanConstructor;
|
|
222
|
+
disabled: BooleanConstructor;
|
|
223
|
+
error: BooleanConstructor;
|
|
224
|
+
label: StringConstructor;
|
|
225
|
+
persistentClear: BooleanConstructor;
|
|
226
|
+
prependInnerIcon: PropType<IconValue>;
|
|
227
|
+
reverse: BooleanConstructor;
|
|
228
|
+
singleLine: BooleanConstructor;
|
|
229
|
+
variant: {
|
|
230
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
231
|
+
default: string;
|
|
232
|
+
validator: (v: any) => boolean;
|
|
233
|
+
};
|
|
234
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
235
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
236
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
237
|
+
focused: BooleanConstructor;
|
|
238
|
+
id: StringConstructor;
|
|
239
|
+
}, "onUpdate:modelValue" | "modelValue"> & SlotsToProps<MakeSlots<{
|
|
240
|
+
clear: [];
|
|
241
|
+
'prepend-inner': [DefaultInputSlot & VInputSlot];
|
|
242
|
+
'append-inner': [DefaultInputSlot & VInputSlot];
|
|
243
|
+
label: [DefaultInputSlot & VInputSlot];
|
|
244
|
+
loader: [LoaderSlotProps];
|
|
245
|
+
default: [VFieldSlot];
|
|
246
|
+
}>>>> & {
|
|
247
|
+
"onUpdate:focused"?: ((focused: boolean) => any) | undefined;
|
|
248
|
+
"onClick:control"?: ((e: MouseEvent) => any) | undefined;
|
|
249
|
+
} & vue.ShallowUnwrapRef<{
|
|
250
|
+
controlRef: Ref<HTMLElement | undefined>;
|
|
251
|
+
}> & {} & vue.ComponentCustomProperties;
|
|
252
|
+
__isFragment?: undefined;
|
|
253
|
+
__isTeleport?: undefined;
|
|
254
|
+
__isSuspense?: undefined;
|
|
255
|
+
} & vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<Omit<{
|
|
256
|
+
loading: BooleanConstructor;
|
|
257
|
+
theme: StringConstructor;
|
|
258
|
+
appendInnerIcon: PropType<IconValue>;
|
|
259
|
+
bgColor: StringConstructor;
|
|
260
|
+
clearable: BooleanConstructor;
|
|
261
|
+
clearIcon: {
|
|
262
|
+
type: PropType<IconValue>;
|
|
263
|
+
default: string;
|
|
264
|
+
};
|
|
265
|
+
active: BooleanConstructor;
|
|
266
|
+
color: StringConstructor;
|
|
267
|
+
dirty: BooleanConstructor;
|
|
268
|
+
disabled: BooleanConstructor;
|
|
269
|
+
error: BooleanConstructor;
|
|
270
|
+
label: StringConstructor;
|
|
271
|
+
persistentClear: BooleanConstructor;
|
|
272
|
+
prependInnerIcon: PropType<IconValue>;
|
|
273
|
+
reverse: BooleanConstructor;
|
|
274
|
+
singleLine: BooleanConstructor;
|
|
275
|
+
variant: {
|
|
276
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
277
|
+
default: string;
|
|
278
|
+
validator: (v: any) => boolean;
|
|
279
|
+
};
|
|
280
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
281
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
282
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
283
|
+
focused: BooleanConstructor;
|
|
284
|
+
id: StringConstructor;
|
|
285
|
+
}, "onUpdate:modelValue" | "modelValue"> & SlotsToProps<MakeSlots<{
|
|
286
|
+
clear: [];
|
|
287
|
+
'prepend-inner': [DefaultInputSlot & VInputSlot];
|
|
288
|
+
'append-inner': [DefaultInputSlot & VInputSlot];
|
|
289
|
+
label: [DefaultInputSlot & VInputSlot];
|
|
290
|
+
loader: [LoaderSlotProps];
|
|
291
|
+
default: [VFieldSlot];
|
|
292
|
+
}>>>> & {
|
|
293
|
+
"onUpdate:focused"?: ((focused: boolean) => any) | undefined;
|
|
294
|
+
"onClick:control"?: ((e: MouseEvent) => any) | undefined;
|
|
295
|
+
}, {
|
|
296
|
+
controlRef: Ref<HTMLElement | undefined>;
|
|
297
|
+
}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<{
|
|
298
|
+
'click:control': (e: MouseEvent) => boolean;
|
|
299
|
+
'update:focused': (focused: boolean) => boolean;
|
|
300
|
+
'update:modelValue': (val: any) => boolean;
|
|
301
|
+
}, "update:modelValue" | "modelValue">, string, {
|
|
302
|
+
reverse: boolean;
|
|
303
|
+
error: boolean;
|
|
304
|
+
active: boolean;
|
|
305
|
+
loading: boolean;
|
|
306
|
+
disabled: boolean;
|
|
307
|
+
variant: "filled" | "outlined" | "plain" | "underlined" | "solo";
|
|
308
|
+
clearIcon: IconValue;
|
|
309
|
+
focused: boolean;
|
|
310
|
+
clearable: boolean;
|
|
311
|
+
dirty: boolean;
|
|
312
|
+
persistentClear: boolean;
|
|
313
|
+
singleLine: boolean;
|
|
314
|
+
}> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>() => {
|
|
315
|
+
$props: {
|
|
316
|
+
modelValue?: T | undefined;
|
|
317
|
+
'onUpdate:modelValue'?: ((val: T) => any) | undefined;
|
|
318
|
+
};
|
|
319
|
+
$slots: VFieldSlots;
|
|
320
|
+
});
|
|
321
|
+
declare type VField = InstanceType<typeof VField>;
|
|
322
|
+
|
|
323
|
+
declare const VFieldLabel: vue.DefineComponent<{
|
|
324
|
+
floating: BooleanConstructor;
|
|
325
|
+
}, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, Readonly<vue.ExtractPropTypes<{
|
|
326
|
+
floating: BooleanConstructor;
|
|
327
|
+
}>>, {
|
|
328
|
+
floating: boolean;
|
|
329
|
+
}>;
|
|
330
|
+
declare type VFieldLabel = InstanceType<typeof VFieldLabel>;
|
|
331
|
+
|
|
332
|
+
export { VField, VFieldLabel };
|
|
@@ -200,9 +200,9 @@ export const VFileInput = defineComponent({
|
|
|
200
200
|
},
|
|
201
201
|
"onFocus": onFocus,
|
|
202
202
|
"onBlur": () => isFocused.value = false
|
|
203
|
-
}, slotProps, inputAttrs), null),
|
|
203
|
+
}, slotProps, inputAttrs), null), _createVNode("div", {
|
|
204
204
|
"class": fieldClass
|
|
205
|
-
}, [slots.selection ? slots.selection({
|
|
205
|
+
}, [model.value.length > 0 && (slots.selection ? slots.selection({
|
|
206
206
|
fileNames: fileNames.value,
|
|
207
207
|
totalBytes: totalBytes.value,
|
|
208
208
|
totalBytesReadable: totalBytesReadable.value
|
|
@@ -212,7 +212,7 @@ export const VFileInput = defineComponent({
|
|
|
212
212
|
"color": props.color
|
|
213
213
|
}, {
|
|
214
214
|
default: () => [text]
|
|
215
|
-
})) : fileNames.value.join(', ')])]);
|
|
215
|
+
})) : fileNames.value.join(', '))])]);
|
|
216
216
|
}
|
|
217
217
|
});
|
|
218
218
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VFileInput.mjs","names":["filterFieldProps","makeVFieldProps","filterInputProps","makeVInputProps","VInput","VChip","VCounter","VField","forwardRefs","useLocale","useProxiedModel","computed","nextTick","ref","callEvent","defineComponent","filterInputAttrs","humanReadableFileSize","useRender","wrapInArray","VFileInput","name","inheritAttrs","props","chips","Boolean","counter","counterSizeString","type","String","default","counterString","multiple","hint","persistentHint","placeholder","showSize","Number","validator","v","includes","prependIcon","modelValue","Array","val","every","clearable","emits","e","files","setup","attrs","emit","slots","t","model","base","undefined","totalBytes","value","reduce","bytes","size","totalBytesReadable","fileNames","map","file","counterValue","fileCount","length","vInputRef","vFieldRef","isFocused","inputRef","messages","onFocus","document","activeElement","focus","onClickPrepend","onControlClick","click","onClear","stopPropagation","hasCounter","hasDetails","details","rootAttrs","inputAttrs","_","inputProps","fieldProps","isDisabled","isDirty","isReadonly","isValid","class","fieldClass","slotProps","target","selection","text","color","join"],"sources":["../../../src/components/VFileInput/VFileInput.tsx"],"sourcesContent":["// Styles\nimport './VFileInput.sass'\n\n// Components\nimport { filterFieldProps, makeVFieldProps } from '@/components/VField/VField'\nimport { filterInputProps, makeVInputProps, VInput } from '@/components/VInput/VInput'\nimport { VChip } from '@/components/VChip'\nimport { VCounter } from '@/components/VCounter'\nimport { VField } from '@/components/VField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, nextTick, ref } from 'vue'\nimport { callEvent, defineComponent, filterInputAttrs, humanReadableFileSize, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VFileInput = defineComponent({\n name: 'VFileInput',\n\n inheritAttrs: false,\n\n props: {\n chips: Boolean,\n counter: Boolean,\n counterSizeString: {\n type: String,\n default: '$vuetify.fileInput.counterSize',\n },\n counterString: {\n type: String,\n default: '$vuetify.fileInput.counter',\n },\n multiple: Boolean,\n hint: String,\n persistentHint: Boolean,\n placeholder: String,\n showSize: {\n type: [Boolean, Number] as PropType<boolean | 1000 | 1024>,\n default: false,\n validator: (v: boolean | number) => {\n return (\n typeof v === 'boolean' ||\n [1000, 1024].includes(v)\n )\n },\n },\n\n ...makeVInputProps({ prependIcon: '$file' }),\n\n modelValue: {\n type: Array as PropType<File[]>,\n default: () => ([]),\n validator: (val: any) => {\n return wrapInArray(val).every(v => v != null && typeof v === 'object')\n },\n },\n\n ...makeVFieldProps({ clearable: true }),\n },\n\n emits: {\n 'click:control': (e: MouseEvent) => true,\n 'update:modelValue': (files: File[]) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const model = useProxiedModel(props, 'modelValue')\n const base = computed(() => typeof props.showSize !== 'boolean' ? props.showSize : undefined)\n const totalBytes = computed(() => (model.value ?? []).reduce((bytes, { size = 0 }) => bytes + size, 0))\n const totalBytesReadable = computed(() => humanReadableFileSize(totalBytes.value, base.value))\n\n const fileNames = computed(() => (model.value ?? []).map(file => {\n const { name = '', size = 0 } = file\n\n return !props.showSize\n ? name\n : `${name} (${humanReadableFileSize(size, base.value)})`\n }))\n\n const counterValue = computed(() => {\n const fileCount = model.value?.length ?? 0\n if (props.showSize) return t(props.counterSizeString, fileCount, totalBytesReadable.value)\n else return t(props.counterString, fileCount)\n })\n const vInputRef = ref<VInput>()\n const vFieldRef = ref<VInput>()\n const isFocused = ref(false)\n const inputRef = ref<HTMLInputElement>()\n const messages = computed(() => {\n return props.messages.length\n ? props.messages\n : (props.persistentHint) ? props.hint : ''\n })\n function onFocus () {\n if (inputRef.value !== document.activeElement) {\n inputRef.value?.focus()\n }\n\n if (!isFocused.value) {\n isFocused.value = true\n }\n }\n function onClickPrepend (e: MouseEvent) {\n callEvent(props['onClick:prepend'], e)\n onControlClick(e)\n }\n function onControlClick (e: MouseEvent) {\n inputRef.value?.click()\n\n emit('click:control', e)\n }\n function onClear (e: MouseEvent) {\n e.stopPropagation()\n\n onFocus()\n\n nextTick(() => {\n model.value = []\n\n if (inputRef?.value) {\n inputRef.value.value = ''\n }\n\n callEvent(props['onClick:clear'], e)\n })\n }\n\n useRender(() => {\n const hasCounter = !!(slots.counter || props.counter)\n const hasDetails = !!(hasCounter || slots.details)\n const [rootAttrs, inputAttrs] = filterInputAttrs(attrs)\n const [{ modelValue: _, ...inputProps }] = filterInputProps(props)\n const [fieldProps] = filterFieldProps(props)\n\n return (\n <VInput\n ref={ vInputRef }\n v-model={ model.value }\n class=\"v-file-input\"\n onClick:prepend={ onClickPrepend }\n onClick:append={ props['onClick:append'] }\n { ...rootAttrs }\n { ...inputProps }\n messages={ messages.value }\n >\n {{\n ...slots,\n default: ({\n isDisabled,\n isDirty,\n isReadonly,\n isValid,\n }) => (\n <VField\n ref={ vFieldRef }\n prepend-icon={ props.prependIcon }\n onClick:control={ onControlClick }\n onClick:clear={ onClear }\n onClick:prependInner={ props['onClick:prependInner'] }\n onClick:appendInner={ props['onClick:appendInner'] }\n { ...fieldProps }\n active={ isDirty.value || isFocused.value }\n dirty={ isDirty.value }\n focused={ isFocused.value }\n error={ isValid.value === false }\n >\n {{\n ...slots,\n default: ({\n props: { class: fieldClass, ...slotProps },\n }) => (\n <>\n <input\n ref={ inputRef }\n type=\"file\"\n readonly={ isReadonly.value }\n disabled={ isDisabled.value }\n multiple={ props.multiple }\n name={ props.name }\n onClick={ e => {\n e.stopPropagation()\n\n onFocus()\n } }\n onChange={ e => {\n if (!e.target) return\n\n const target = e.target as HTMLInputElement\n model.value = [...target.files ?? []]\n } }\n onFocus={ onFocus }\n onBlur={ () => (isFocused.value = false) }\n { ...slotProps }\n { ...inputAttrs }\n />\n\n { model.value.length > 0 && (\n <div class={ fieldClass }>\n { slots.selection ? slots.selection({\n fileNames: fileNames.value,\n totalBytes: totalBytes.value,\n totalBytesReadable: totalBytesReadable.value,\n })\n : props.chips ? fileNames.value.map(text => (\n <VChip\n key={ text }\n size=\"small\"\n color={ props.color }\n >{ text }</VChip>\n ))\n : fileNames.value.join(', ') }\n </div>\n ) }\n </>\n ),\n }}\n </VField>\n ),\n details: hasDetails ? slotProps => (\n <>\n { slots.details?.(slotProps) }\n\n { hasCounter && (\n <>\n <span />\n\n <VCounter\n active={ !!model.value.length }\n value={ counterValue.value }\n v-slots={ slots.counter }\n />\n </>\n ) }\n </>\n ) : undefined,\n }}\n </VInput>\n )\n })\n\n return forwardRefs({}, vInputRef, vFieldRef, inputRef)\n },\n})\n\nexport type VFileInput = InstanceType<typeof VFileInput>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VFileInput.mjs","names":["filterFieldProps","makeVFieldProps","filterInputProps","makeVInputProps","VInput","VChip","VCounter","VField","forwardRefs","useLocale","useProxiedModel","computed","nextTick","ref","callEvent","defineComponent","filterInputAttrs","humanReadableFileSize","useRender","wrapInArray","VFileInput","name","inheritAttrs","props","chips","Boolean","counter","counterSizeString","type","String","default","counterString","multiple","hint","persistentHint","placeholder","showSize","Number","validator","v","includes","prependIcon","modelValue","Array","val","every","clearable","emits","e","files","setup","attrs","emit","slots","t","model","base","undefined","totalBytes","value","reduce","bytes","size","totalBytesReadable","fileNames","map","file","counterValue","fileCount","length","vInputRef","vFieldRef","isFocused","inputRef","messages","onFocus","document","activeElement","focus","onClickPrepend","onControlClick","click","onClear","stopPropagation","hasCounter","hasDetails","details","rootAttrs","inputAttrs","_","inputProps","fieldProps","isDisabled","isDirty","isReadonly","isValid","class","fieldClass","slotProps","target","selection","text","color","join"],"sources":["../../../src/components/VFileInput/VFileInput.tsx"],"sourcesContent":["// Styles\nimport './VFileInput.sass'\n\n// Components\nimport { filterFieldProps, makeVFieldProps } from '@/components/VField/VField'\nimport { filterInputProps, makeVInputProps, VInput } from '@/components/VInput/VInput'\nimport { VChip } from '@/components/VChip'\nimport { VCounter } from '@/components/VCounter'\nimport { VField } from '@/components/VField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utilities\nimport { computed, nextTick, ref } from 'vue'\nimport { callEvent, defineComponent, filterInputAttrs, humanReadableFileSize, useRender, wrapInArray } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VFileInput = defineComponent({\n name: 'VFileInput',\n\n inheritAttrs: false,\n\n props: {\n chips: Boolean,\n counter: Boolean,\n counterSizeString: {\n type: String,\n default: '$vuetify.fileInput.counterSize',\n },\n counterString: {\n type: String,\n default: '$vuetify.fileInput.counter',\n },\n multiple: Boolean,\n hint: String,\n persistentHint: Boolean,\n placeholder: String,\n showSize: {\n type: [Boolean, Number] as PropType<boolean | 1000 | 1024>,\n default: false,\n validator: (v: boolean | number) => {\n return (\n typeof v === 'boolean' ||\n [1000, 1024].includes(v)\n )\n },\n },\n\n ...makeVInputProps({ prependIcon: '$file' }),\n\n modelValue: {\n type: Array as PropType<File[]>,\n default: () => ([]),\n validator: (val: any) => {\n return wrapInArray(val).every(v => v != null && typeof v === 'object')\n },\n },\n\n ...makeVFieldProps({ clearable: true }),\n },\n\n emits: {\n 'click:control': (e: MouseEvent) => true,\n 'update:modelValue': (files: File[]) => true,\n },\n\n setup (props, { attrs, emit, slots }) {\n const { t } = useLocale()\n const model = useProxiedModel(props, 'modelValue')\n const base = computed(() => typeof props.showSize !== 'boolean' ? props.showSize : undefined)\n const totalBytes = computed(() => (model.value ?? []).reduce((bytes, { size = 0 }) => bytes + size, 0))\n const totalBytesReadable = computed(() => humanReadableFileSize(totalBytes.value, base.value))\n\n const fileNames = computed(() => (model.value ?? []).map(file => {\n const { name = '', size = 0 } = file\n\n return !props.showSize\n ? name\n : `${name} (${humanReadableFileSize(size, base.value)})`\n }))\n\n const counterValue = computed(() => {\n const fileCount = model.value?.length ?? 0\n if (props.showSize) return t(props.counterSizeString, fileCount, totalBytesReadable.value)\n else return t(props.counterString, fileCount)\n })\n const vInputRef = ref<VInput>()\n const vFieldRef = ref<VInput>()\n const isFocused = ref(false)\n const inputRef = ref<HTMLInputElement>()\n const messages = computed(() => {\n return props.messages.length\n ? props.messages\n : (props.persistentHint) ? props.hint : ''\n })\n function onFocus () {\n if (inputRef.value !== document.activeElement) {\n inputRef.value?.focus()\n }\n\n if (!isFocused.value) {\n isFocused.value = true\n }\n }\n function onClickPrepend (e: MouseEvent) {\n callEvent(props['onClick:prepend'], e)\n onControlClick(e)\n }\n function onControlClick (e: MouseEvent) {\n inputRef.value?.click()\n\n emit('click:control', e)\n }\n function onClear (e: MouseEvent) {\n e.stopPropagation()\n\n onFocus()\n\n nextTick(() => {\n model.value = []\n\n if (inputRef?.value) {\n inputRef.value.value = ''\n }\n\n callEvent(props['onClick:clear'], e)\n })\n }\n\n useRender(() => {\n const hasCounter = !!(slots.counter || props.counter)\n const hasDetails = !!(hasCounter || slots.details)\n const [rootAttrs, inputAttrs] = filterInputAttrs(attrs)\n const [{ modelValue: _, ...inputProps }] = filterInputProps(props)\n const [fieldProps] = filterFieldProps(props)\n\n return (\n <VInput\n ref={ vInputRef }\n v-model={ model.value }\n class=\"v-file-input\"\n onClick:prepend={ onClickPrepend }\n onClick:append={ props['onClick:append'] }\n { ...rootAttrs }\n { ...inputProps }\n messages={ messages.value }\n >\n {{\n ...slots,\n default: ({\n isDisabled,\n isDirty,\n isReadonly,\n isValid,\n }) => (\n <VField\n ref={ vFieldRef }\n prepend-icon={ props.prependIcon }\n onClick:control={ onControlClick }\n onClick:clear={ onClear }\n onClick:prependInner={ props['onClick:prependInner'] }\n onClick:appendInner={ props['onClick:appendInner'] }\n { ...fieldProps }\n active={ isDirty.value || isFocused.value }\n dirty={ isDirty.value }\n focused={ isFocused.value }\n error={ isValid.value === false }\n >\n {{\n ...slots,\n default: ({\n props: { class: fieldClass, ...slotProps },\n }) => (\n <>\n <input\n ref={ inputRef }\n type=\"file\"\n readonly={ isReadonly.value }\n disabled={ isDisabled.value }\n multiple={ props.multiple }\n name={ props.name }\n onClick={ e => {\n e.stopPropagation()\n\n onFocus()\n } }\n onChange={ e => {\n if (!e.target) return\n\n const target = e.target as HTMLInputElement\n model.value = [...target.files ?? []]\n } }\n onFocus={ onFocus }\n onBlur={ () => (isFocused.value = false) }\n { ...slotProps }\n { ...inputAttrs }\n />\n\n <div class={ fieldClass }>\n { model.value.length > 0 && (\n slots.selection ? slots.selection({\n fileNames: fileNames.value,\n totalBytes: totalBytes.value,\n totalBytesReadable: totalBytesReadable.value,\n })\n : props.chips ? fileNames.value.map(text => (\n <VChip\n key={ text }\n size=\"small\"\n color={ props.color }\n >{ text }</VChip>\n ))\n : fileNames.value.join(', ')\n )}\n </div>\n </>\n ),\n }}\n </VField>\n ),\n details: hasDetails ? slotProps => (\n <>\n { slots.details?.(slotProps) }\n\n { hasCounter && (\n <>\n <span />\n\n <VCounter\n active={ !!model.value.length }\n value={ counterValue.value }\n v-slots={ slots.counter }\n />\n </>\n ) }\n </>\n ) : undefined,\n }}\n </VInput>\n )\n })\n\n return forwardRefs({}, vInputRef, vFieldRef, inputRef)\n },\n})\n\nexport type VFileInput = InstanceType<typeof VFileInput>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import * as vue from 'vue';
|
|
2
|
+
import { PropType, JSXComponent } from 'vue';
|
|
3
|
+
|
|
4
|
+
declare type EventProp<T = (...args: any[]) => any> = T | T[];
|
|
5
|
+
declare const EventProp: PropType<EventProp<(...args: any[]) => any>>;
|
|
6
|
+
|
|
7
|
+
declare type ValidationResult = string | boolean;
|
|
8
|
+
declare type ValidationRule = ValidationResult | PromiseLike<ValidationResult> | ((value: any) => ValidationResult) | ((value: any) => PromiseLike<ValidationResult>);
|
|
9
|
+
|
|
10
|
+
declare type IconValue = string | JSXComponent;
|
|
11
|
+
declare const IconValue: PropType<IconValue>;
|
|
12
|
+
|
|
13
|
+
declare const VFileInput: vue.DefineComponent<{
|
|
14
|
+
loading: BooleanConstructor;
|
|
15
|
+
theme: StringConstructor;
|
|
16
|
+
appendInnerIcon: PropType<IconValue>;
|
|
17
|
+
bgColor: StringConstructor;
|
|
18
|
+
clearable: {
|
|
19
|
+
type: PropType<boolean>;
|
|
20
|
+
default: boolean;
|
|
21
|
+
};
|
|
22
|
+
clearIcon: {
|
|
23
|
+
type: PropType<IconValue>;
|
|
24
|
+
default: string;
|
|
25
|
+
};
|
|
26
|
+
active: BooleanConstructor;
|
|
27
|
+
color: StringConstructor;
|
|
28
|
+
dirty: BooleanConstructor;
|
|
29
|
+
disabled: BooleanConstructor;
|
|
30
|
+
error: BooleanConstructor;
|
|
31
|
+
label: StringConstructor;
|
|
32
|
+
persistentClear: BooleanConstructor;
|
|
33
|
+
prependInnerIcon: PropType<IconValue>;
|
|
34
|
+
reverse: BooleanConstructor;
|
|
35
|
+
singleLine: BooleanConstructor;
|
|
36
|
+
variant: {
|
|
37
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
38
|
+
default: string;
|
|
39
|
+
validator: (v: any) => boolean;
|
|
40
|
+
};
|
|
41
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
42
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
43
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
44
|
+
modelValue: {
|
|
45
|
+
type: PropType<File[]>;
|
|
46
|
+
default: () => never[];
|
|
47
|
+
validator: (val: any) => boolean;
|
|
48
|
+
};
|
|
49
|
+
errorMessages: {
|
|
50
|
+
type: PropType<string | string[]>;
|
|
51
|
+
default: () => never[];
|
|
52
|
+
};
|
|
53
|
+
maxErrors: {
|
|
54
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
55
|
+
default: number;
|
|
56
|
+
};
|
|
57
|
+
name: StringConstructor;
|
|
58
|
+
readonly: BooleanConstructor;
|
|
59
|
+
rules: {
|
|
60
|
+
type: PropType<ValidationRule[]>;
|
|
61
|
+
default: () => never[];
|
|
62
|
+
};
|
|
63
|
+
validationValue: null;
|
|
64
|
+
density: {
|
|
65
|
+
type: PropType<"default" | "compact" | "comfortable" | null>;
|
|
66
|
+
default: string;
|
|
67
|
+
validator: (v: any) => boolean;
|
|
68
|
+
};
|
|
69
|
+
id: StringConstructor;
|
|
70
|
+
appendIcon: PropType<IconValue>;
|
|
71
|
+
prependIcon: {
|
|
72
|
+
type: PropType<(string & {}) | IconValue>;
|
|
73
|
+
default: (string & {}) | IconValue;
|
|
74
|
+
};
|
|
75
|
+
hideDetails: PropType<boolean | "auto">;
|
|
76
|
+
messages: {
|
|
77
|
+
type: PropType<string | string[]>;
|
|
78
|
+
default: () => never[];
|
|
79
|
+
};
|
|
80
|
+
direction: {
|
|
81
|
+
type: PropType<"horizontal" | "vertical">;
|
|
82
|
+
default: string;
|
|
83
|
+
validator: (v: any) => boolean;
|
|
84
|
+
};
|
|
85
|
+
'onClick:prepend': PropType<EventProp<(...args: any[]) => any>>;
|
|
86
|
+
'onClick:append': PropType<EventProp<(...args: any[]) => any>>;
|
|
87
|
+
chips: BooleanConstructor;
|
|
88
|
+
counter: BooleanConstructor;
|
|
89
|
+
counterSizeString: {
|
|
90
|
+
type: StringConstructor;
|
|
91
|
+
default: string;
|
|
92
|
+
};
|
|
93
|
+
counterString: {
|
|
94
|
+
type: StringConstructor;
|
|
95
|
+
default: string;
|
|
96
|
+
};
|
|
97
|
+
multiple: BooleanConstructor;
|
|
98
|
+
hint: StringConstructor;
|
|
99
|
+
persistentHint: BooleanConstructor;
|
|
100
|
+
placeholder: StringConstructor;
|
|
101
|
+
showSize: {
|
|
102
|
+
type: PropType<boolean | 1000 | 1024>;
|
|
103
|
+
default: boolean;
|
|
104
|
+
validator: (v: boolean | number) => boolean;
|
|
105
|
+
};
|
|
106
|
+
}, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
|
|
107
|
+
'click:control': (e: MouseEvent) => true;
|
|
108
|
+
'update:modelValue': (files: File[]) => true;
|
|
109
|
+
}, string, vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, Readonly<vue.ExtractPropTypes<{
|
|
110
|
+
loading: BooleanConstructor;
|
|
111
|
+
theme: StringConstructor;
|
|
112
|
+
appendInnerIcon: PropType<IconValue>;
|
|
113
|
+
bgColor: StringConstructor;
|
|
114
|
+
clearable: {
|
|
115
|
+
type: PropType<boolean>;
|
|
116
|
+
default: boolean;
|
|
117
|
+
};
|
|
118
|
+
clearIcon: {
|
|
119
|
+
type: PropType<IconValue>;
|
|
120
|
+
default: string;
|
|
121
|
+
};
|
|
122
|
+
active: BooleanConstructor;
|
|
123
|
+
color: StringConstructor;
|
|
124
|
+
dirty: BooleanConstructor;
|
|
125
|
+
disabled: BooleanConstructor;
|
|
126
|
+
error: BooleanConstructor;
|
|
127
|
+
label: StringConstructor;
|
|
128
|
+
persistentClear: BooleanConstructor;
|
|
129
|
+
prependInnerIcon: PropType<IconValue>;
|
|
130
|
+
reverse: BooleanConstructor;
|
|
131
|
+
singleLine: BooleanConstructor;
|
|
132
|
+
variant: {
|
|
133
|
+
type: PropType<"filled" | "outlined" | "plain" | "underlined" | "solo">;
|
|
134
|
+
default: string;
|
|
135
|
+
validator: (v: any) => boolean;
|
|
136
|
+
};
|
|
137
|
+
'onClick:clear': PropType<EventProp<(...args: any[]) => any>>;
|
|
138
|
+
'onClick:appendInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
139
|
+
'onClick:prependInner': PropType<EventProp<(...args: any[]) => any>>;
|
|
140
|
+
modelValue: {
|
|
141
|
+
type: PropType<File[]>;
|
|
142
|
+
default: () => never[];
|
|
143
|
+
validator: (val: any) => boolean;
|
|
144
|
+
};
|
|
145
|
+
errorMessages: {
|
|
146
|
+
type: PropType<string | string[]>;
|
|
147
|
+
default: () => never[];
|
|
148
|
+
};
|
|
149
|
+
maxErrors: {
|
|
150
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
151
|
+
default: number;
|
|
152
|
+
};
|
|
153
|
+
name: StringConstructor;
|
|
154
|
+
readonly: BooleanConstructor;
|
|
155
|
+
rules: {
|
|
156
|
+
type: PropType<ValidationRule[]>;
|
|
157
|
+
default: () => never[];
|
|
158
|
+
};
|
|
159
|
+
validationValue: null;
|
|
160
|
+
density: {
|
|
161
|
+
type: PropType<"default" | "compact" | "comfortable" | null>;
|
|
162
|
+
default: string;
|
|
163
|
+
validator: (v: any) => boolean;
|
|
164
|
+
};
|
|
165
|
+
id: StringConstructor;
|
|
166
|
+
appendIcon: PropType<IconValue>;
|
|
167
|
+
prependIcon: {
|
|
168
|
+
type: PropType<(string & {}) | IconValue>;
|
|
169
|
+
default: (string & {}) | IconValue;
|
|
170
|
+
};
|
|
171
|
+
hideDetails: PropType<boolean | "auto">;
|
|
172
|
+
messages: {
|
|
173
|
+
type: PropType<string | string[]>;
|
|
174
|
+
default: () => never[];
|
|
175
|
+
};
|
|
176
|
+
direction: {
|
|
177
|
+
type: PropType<"horizontal" | "vertical">;
|
|
178
|
+
default: string;
|
|
179
|
+
validator: (v: any) => boolean;
|
|
180
|
+
};
|
|
181
|
+
'onClick:prepend': PropType<EventProp<(...args: any[]) => any>>;
|
|
182
|
+
'onClick:append': PropType<EventProp<(...args: any[]) => any>>;
|
|
183
|
+
chips: BooleanConstructor;
|
|
184
|
+
counter: BooleanConstructor;
|
|
185
|
+
counterSizeString: {
|
|
186
|
+
type: StringConstructor;
|
|
187
|
+
default: string;
|
|
188
|
+
};
|
|
189
|
+
counterString: {
|
|
190
|
+
type: StringConstructor;
|
|
191
|
+
default: string;
|
|
192
|
+
};
|
|
193
|
+
multiple: BooleanConstructor;
|
|
194
|
+
hint: StringConstructor;
|
|
195
|
+
persistentHint: BooleanConstructor;
|
|
196
|
+
placeholder: StringConstructor;
|
|
197
|
+
showSize: {
|
|
198
|
+
type: PropType<boolean | 1000 | 1024>;
|
|
199
|
+
default: boolean;
|
|
200
|
+
validator: (v: boolean | number) => boolean;
|
|
201
|
+
};
|
|
202
|
+
}>> & {
|
|
203
|
+
"onUpdate:modelValue"?: ((files: File[]) => any) | undefined;
|
|
204
|
+
"onClick:control"?: ((e: MouseEvent) => any) | undefined;
|
|
205
|
+
}, {
|
|
206
|
+
reverse: boolean;
|
|
207
|
+
error: boolean;
|
|
208
|
+
active: boolean;
|
|
209
|
+
direction: "horizontal" | "vertical";
|
|
210
|
+
loading: boolean;
|
|
211
|
+
disabled: boolean;
|
|
212
|
+
multiple: boolean;
|
|
213
|
+
readonly: boolean;
|
|
214
|
+
messages: string | string[];
|
|
215
|
+
counter: boolean;
|
|
216
|
+
density: "default" | "compact" | "comfortable" | null;
|
|
217
|
+
variant: "filled" | "outlined" | "plain" | "underlined" | "solo";
|
|
218
|
+
modelValue: File[];
|
|
219
|
+
prependIcon: (string & {}) | IconValue;
|
|
220
|
+
errorMessages: string | string[];
|
|
221
|
+
maxErrors: string | number;
|
|
222
|
+
rules: ValidationRule[];
|
|
223
|
+
clearIcon: IconValue;
|
|
224
|
+
clearable: boolean;
|
|
225
|
+
dirty: boolean;
|
|
226
|
+
persistentClear: boolean;
|
|
227
|
+
singleLine: boolean;
|
|
228
|
+
persistentHint: boolean;
|
|
229
|
+
chips: boolean;
|
|
230
|
+
counterSizeString: string;
|
|
231
|
+
counterString: string;
|
|
232
|
+
showSize: boolean | 1000 | 1024;
|
|
233
|
+
}>;
|
|
234
|
+
declare type VFileInput = InstanceType<typeof VFileInput>;
|
|
235
|
+
|
|
236
|
+
export { VFileInput };
|