import type { FieldValidationResult, FormField, FormValidationResult, SubmitEventPromise } from '../../composables/form.js'; export declare const makeVFormProps: (defaults?: Defaults | undefined) => { class: unknown extends Defaults["class"] ? import("vue").PropType : { type: import("vue").PropType; default: unknown extends Defaults["class"] ? any : any; }; style: unknown extends Defaults["style"] ? { type: import("vue").PropType; default: null; } : Omit<{ type: import("vue").PropType; default: null; }, "default" | "type"> & { type: import("vue").PropType; default: unknown extends Defaults["style"] ? import("vue").StyleValue : Defaults["style"] | NonNullable; }; disabled: unknown extends Defaults["disabled"] ? BooleanConstructor : { type: import("vue").PropType; default: unknown extends Defaults["disabled"] ? boolean : boolean | Defaults["disabled"]; }; fastFail: unknown extends Defaults["fastFail"] ? BooleanConstructor : { type: import("vue").PropType; default: unknown extends Defaults["fastFail"] ? boolean : boolean | Defaults["fastFail"]; }; readonly: unknown extends Defaults["readonly"] ? BooleanConstructor : { type: import("vue").PropType; default: unknown extends Defaults["readonly"] ? boolean : boolean | Defaults["readonly"]; }; modelValue: unknown extends Defaults["modelValue"] ? { type: import("vue").PropType; default: null; } : Omit<{ type: import("vue").PropType; default: null; }, "default" | "type"> & { type: import("vue").PropType; default: unknown extends Defaults["modelValue"] ? boolean | null : Defaults["modelValue"] | NonNullable; }; validateOn: unknown extends Defaults["validateOn"] ? { type: import("vue").PropType<("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined>; default: string; } : Omit<{ type: import("vue").PropType<("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined>; default: string; }, "default" | "type"> & { type: import("vue").PropType; default: unknown extends Defaults["validateOn"] ? ("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined : Defaults["validateOn"] | NonNullable<("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined>; }; }; export declare const VForm: { new (...args: any[]): import("vue").CreateComponentPublicInstanceWithMixins<{ style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: "blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit"); } & { class?: any; } & { $children?: { default?: ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | { $stable?: boolean; } | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | import("vue").VNodeChild; 'v-slots'?: { default?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | undefined; } & { "v-slot:default"?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } & { onSubmit?: ((e: SubmitEventPromise) => any) | undefined; "onUpdate:modelValue"?: ((val: boolean | null) => any) | undefined; }, { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; } & HTMLFormElement & { _allExposed: { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; }; }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, { 'update:modelValue': (val: boolean | null) => true; submit: (e: SubmitEventPromise) => true; }, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, { style: import("vue").StyleValue; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: ("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined; }, true, {}, import("vue").SlotsType Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNode[]; }>>, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, {}, any, import("vue").ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, { style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: "blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit"); } & { class?: any; } & { $children?: { default?: ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | { $stable?: boolean; } | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | import("vue").VNodeChild; 'v-slots'?: { default?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | undefined; } & { "v-slot:default"?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } & { onSubmit?: ((e: SubmitEventPromise) => any) | undefined; "onUpdate:modelValue"?: ((val: boolean | null) => any) | undefined; }, { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; } & HTMLFormElement & { _allExposed: { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; }; }, {}, {}, {}, { style: import("vue").StyleValue; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: ("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined; }>; __isFragment?: never; __isTeleport?: never; __isSuspense?: never; } & import("vue").ComponentOptionsBase<{ style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: "blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit"); } & { class?: any; } & { $children?: { default?: ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | { $stable?: boolean; } | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | import("vue").VNodeChild; 'v-slots'?: { default?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } | undefined; } & { "v-slot:default"?: false | ((arg: { errors: FieldValidationResult[]; isDisabled: boolean; isReadonly: boolean; isValidating: boolean; isValid: boolean | null; items: FormField[]; validate: () => Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNodeChild) | undefined; } & { onSubmit?: ((e: SubmitEventPromise) => any) | undefined; "onUpdate:modelValue"?: ((val: boolean | null) => any) | undefined; }, { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; } & HTMLFormElement & { _allExposed: { errors: import("vue").Ref<{ id: number | string; errorMessages: string[]; }[], FieldValidationResult[] | { id: number | string; errorMessages: string[]; }[]>; isDisabled: Readonly>; isReadonly: Readonly>; isValidating: import("vue").ShallowRef; isValid: import("vue").Ref & { readonly externalValue: boolean | null; }; items: import("vue").Ref<{ id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[], FormField[] | { id: number | string; validate: () => Promise; reset: () => Promise; resetValidation: () => Promise; vm: import("vue").Raw; isValid: boolean | null; errorMessages: string[]; }[]>; validate: () => Promise<{ valid: boolean; errors: { id: number | string; errorMessages: string[]; }[]; }>; reset: () => void; resetValidation: () => void; }; }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, { 'update:modelValue': (val: boolean | null) => true; submit: (e: SubmitEventPromise) => true; }, string, { style: import("vue").StyleValue; disabled: boolean; fastFail: boolean; readonly: boolean; modelValue: boolean | null; validateOn: ("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined; }, {}, string, import("vue").SlotsType Promise; reset: () => void; resetValidation: () => void; }) => import("vue").VNode[]; }>>, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps & import("../../util/index.js").FilterPropsOptions<{ class: import("vue").PropType; style: { type: import("vue").PropType; default: null; }; disabled: BooleanConstructor; fastFail: BooleanConstructor; readonly: BooleanConstructor; modelValue: { type: import("vue").PropType; default: null; }; validateOn: { type: import("vue").PropType<("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined>; default: string; }; }, import("vue").ExtractPropTypes<{ class: import("vue").PropType; style: { type: import("vue").PropType; default: null; }; disabled: BooleanConstructor; fastFail: BooleanConstructor; readonly: BooleanConstructor; modelValue: { type: import("vue").PropType; default: null; }; validateOn: { type: import("vue").PropType<("blur eager" | "blur lazy" | "eager" | "eager blur" | "eager input" | "eager invalid-input" | "eager submit" | "input eager" | "input lazy" | "invalid-input eager" | "invalid-input lazy" | "lazy" | "lazy blur" | "lazy input" | "lazy invalid-input" | "lazy submit" | "submit eager" | "submit lazy" | ("blur" | "input" | "invalid-input" | "submit")) | undefined>; default: string; }; }>>; export type VForm = InstanceType;