import { VueNode } from '../_util/type'; export type InternalNamePath = (string | number)[]; export type NamePath = string | number | InternalNamePath; export type StoreValue = any; export interface Store { [name: string]: StoreValue; } export interface Meta { touched: boolean; validating: boolean; errors: string[]; name: InternalNamePath; } export interface InternalFieldData extends Meta { value: StoreValue; } /** * Used by `setFields` config */ export interface FieldData extends Partial> { name: NamePath; } export type RuleType = | 'string' | 'number' | 'boolean' | 'method' | 'regexp' | 'integer' | 'float' | 'object' | 'enum' | 'date' | 'url' | 'hex' | 'email'; type Validator = ( rule: RuleObject, value: StoreValue, callback: (error?: string) => void, ) => Promise | void; export interface ValidatorRule { message?: string | VueNode; validator: Validator; } interface BaseRule { enum?: StoreValue[]; len?: number; max?: number; message?: string | VueNode; min?: number; pattern?: RegExp; required?: boolean; transform?: (value: StoreValue) => StoreValue; type?: RuleType; whitespace?: boolean; /** Customize rule level `validateTrigger`. Must be subset of Field `validateTrigger` */ validateTrigger?: string | string[]; } type AggregationRule = BaseRule & Partial; interface ArrayRule extends Omit { type: 'array'; defaultField?: RuleObject; } export type RuleObject = AggregationRule | ArrayRule; export type Rule = RuleObject; export interface ValidateErrorEntity { values: Values; errorFields: { name: InternalNamePath; errors: string[] }[]; outOfDate: boolean; } export interface FieldError { name: InternalNamePath; errors: string[]; } export interface ValidateOptions { triggerName?: string; validateMessages?: ValidateMessages; } export type InternalValidateFields = ( nameList?: NamePath[], options?: ValidateOptions, ) => Promise; export type ValidateFields = (nameList?: NamePath[]) => Promise; // >>>>>> Info interface ValueUpdateInfo { type: 'valueUpdate'; source: 'internal' | 'external'; } interface ValidateFinishInfo { type: 'validateFinish'; } interface ResetInfo { type: 'reset'; } interface SetFieldInfo { type: 'setField'; data: FieldData; } interface DependenciesUpdateInfo { type: 'dependenciesUpdate'; /** * Contains all the related `InternalNamePath[]`. * a <- b <- c : change `a` * relatedFields=[a, b, c] */ relatedFields: InternalNamePath[]; } export type NotifyInfo = | ValueUpdateInfo | ValidateFinishInfo | ResetInfo | SetFieldInfo | DependenciesUpdateInfo; export type ValuedNotifyInfo = NotifyInfo & { store: Store; }; export interface Callbacks { onValuesChange?: (changedValues: any, values: Values) => void; onFieldsChange?: (changedFields: FieldData[], allFields: FieldData[]) => void; onFinish?: (values: Values) => void; onFinishFailed?: (errorInfo: ValidateErrorEntity) => void; } // eslint-disable-next-line @typescript-eslint/no-explicit-any export type EventArgs = any[]; type ValidateMessage = string | (() => string); export interface ValidateMessages { default?: ValidateMessage; required?: ValidateMessage; enum?: ValidateMessage; whitespace?: ValidateMessage; date?: { format?: ValidateMessage; parse?: ValidateMessage; invalid?: ValidateMessage; }; types?: { string?: ValidateMessage; method?: ValidateMessage; array?: ValidateMessage; object?: ValidateMessage; number?: ValidateMessage; date?: ValidateMessage; boolean?: ValidateMessage; integer?: ValidateMessage; float?: ValidateMessage; regexp?: ValidateMessage; email?: ValidateMessage; url?: ValidateMessage; hex?: ValidateMessage; }; string?: { len?: ValidateMessage; min?: ValidateMessage; max?: ValidateMessage; range?: ValidateMessage; }; number?: { len?: ValidateMessage; min?: ValidateMessage; max?: ValidateMessage; range?: ValidateMessage; }; array?: { len?: ValidateMessage; min?: ValidateMessage; max?: ValidateMessage; range?: ValidateMessage; }; pattern?: { mismatch?: ValidateMessage; }; }