fielder
Version:
A field-first form library for React and React Native
95 lines (94 loc) • 4.36 kB
TypeScript
import { SetFieldValueArgs } from './actions/setFieldValue';
import { ValidateFieldArgs } from './actions/validateField';
import { MountFieldArgs } from './actions/mountField';
import { BlurFieldArgs } from './actions/blurField';
import { UnmountFieldArgs } from './actions/unmountField';
import { SetFieldStateArgs } from './actions/setFieldState';
import { SetFieldValidationArgs } from './actions/setFieldValidation';
export declare type FormValue = string | boolean | number | string[];
export declare type FormSchemaType = Record<string, FormValue>;
export declare type FieldsState<T extends FormSchemaType = FormSchemaType> = {
[K in keyof T]: FieldState<T, K>;
};
export interface FormState<T extends FormSchemaType = FormSchemaType> {
fields: FieldsState<T>;
/** All mounted fields are valid. */
isValid: boolean;
/** Async validation currently active on a mounted fields. */
isValidating: boolean;
/** Set value for a field. */
setFieldValue: <K extends keyof T>(a: SetFieldValueArgs<T, K>) => void;
/** Trigger blur event for a mounted field. */
blurField: (a: BlurFieldArgs<T>) => void;
/** Force trigger validation on a mounted field. */
validateField: (a: ValidateFieldArgs<T>) => void;
/** Internal: Premount field during render */
premountField: <K extends keyof T & string>(a: MountFieldArgs<T, K>) => FieldState<T, K>;
/** Internal: Manually mount field. */
mountField: <K extends keyof T & string>(a: MountFieldArgs<T, K>) => FieldState<T, K>;
/** Internal: Manually unmount field. */
unmountField: (a: UnmountFieldArgs<T>) => void;
/** Internal: Manually set field state. */
setFieldState: <K extends keyof T>(a: SetFieldStateArgs<T, K>) => void;
/** Internal: Set new field validation function */
setFieldValidation: <K extends keyof T>(a: SetFieldValidationArgs<T, K>) => void;
/** Trigger submission validation.
*
* Throws on synchronous validation errors.
* Returns promise if form contains async validation.
*/
validateSubmission: () => MaybePromise<{
state: FieldsState;
errors: Record<string, string>;
}>;
}
export interface FieldState<T extends FormSchemaType | FormValue = FormValue, K extends keyof T = any, V extends FormValue = T extends FormSchemaType ? T[K] : T, S extends FormSchemaType = T extends FormSchemaType ? T : FormSchemaType> {
/** The field is currently mounted. */
readonly _isActive: boolean;
/** Validation function. */
readonly _validate?: ValidationFn<V, S> | ObjectValidation<V, S>;
/** Field name */
readonly name: K;
/** Field value */
readonly value: V;
/** Field error */
readonly error?: string;
/** Field is currently valid. */
readonly isValid: boolean;
/** Field is currently being validated (async). */
readonly isValidating: boolean;
/** Field has been blurred since mount. */
readonly hasBlurred: boolean;
/** Field has been changed since mount. */
readonly hasChanged: boolean;
}
/**
* Events which trigger validation
*
* `mount`: Field has been mounted.
*
* `blur`: Field has had 'onBlur' event.
*
* `change`: Field has had 'onChange' event.
*
* `update`: The value of another field in the form has changed.
*
* `submit`: Submission has begun.
*/
export declare type ValidationTrigger = 'mount' | 'blur' | 'change' | 'update' | 'submit';
/** Arguments passed to a validation function */
export declare type ValidationArgs<T extends FormValue = FormValue, S extends FormSchemaType = FormSchemaType> = {
trigger: ValidationTrigger;
value: T;
form: FieldsState<S>;
};
/** Handler for validation event */
export declare type ValidationFn<T extends FormValue = FormValue, S extends FormSchemaType = FormSchemaType> = (args: ValidationArgs<T, S>) => void | Promise<void>;
/** A map of validation events corresponding to a function. */
export declare type ObjectValidation<T extends FormValue = FormValue, S extends FormSchemaType = FormSchemaType> = {
[k in ValidationTrigger]?: ValidationFn<T, S>;
};
declare type MaybePromise<T> = T | Promise<T>;
export declare type Dispatch<T> = (a: T) => void;
export declare type SetStateAction<T> = T | ((a: T) => T);
export {};