import type { InjectionKey } from 'vue' import type { FieldErrorList } from 'async-validator' import type { Emitter } from 'mitt' import type { ComponentSize } from '@element-plus/utils/types' export interface ElFormContext { registerLabelWidth(width: number, oldWidth: number): void deregisterLabelWidth(width: number): void autoLabelWidth: string | undefined formMitt: Emitter emit: (evt: string, ...args: any[]) => void labelSuffix: string inline?: boolean inlineMessage?: boolean model?: Record size?: string showMessage?: boolean labelPosition?: string labelWidth?: string | number rules?: Record statusIcon?: boolean hideRequiredAsterisk?: boolean disabled?: boolean } export interface ValidateFieldCallback { (isValid?: string, invalidFields?: FieldErrorList): void } export interface ElFormItemContext { prop?: string formItemMitt: Emitter size?: ComponentSize validateState: string $el: HTMLDivElement validate(trigger: string, callback?: ValidateFieldCallback): void updateComputedLabelWidth(width: number): void addValidateEvents(): void removeValidateEvents(): void resetField(): void clearValidate(): void } // TODO: change it to symbol export const elFormKey: InjectionKey = 'elForm' as any export const elFormItemKey: InjectionKey = 'elFormItem' as any export const elFormEvents = { addField: 'el.form.addField', removeField: 'el.form.removeField', } as const