import { NestedValue } from './form'; export type Noop = () => void; interface File extends Blob { readonly lastModified: number; readonly name: string; } interface FileList { readonly length: number; item(index: number): File | null; [index: number]: File; } export type Primitive = null | undefined | string | number | boolean | symbol | bigint; export type BrowserNativeObject = Date | FileList | File; export type EmptyObject = { [K in string | number]: never; }; export type NonUndefined = T extends undefined ? never : T; export type LiteralUnion = T | (U & { _?: never; }); export type ExtractObjects = T extends infer U ? U extends object ? U : never : never; export type DeepPartial = T extends BrowserNativeObject | NestedValue ? T : { [K in keyof T]?: ExtractObjects extends never ? T[K] : DeepPartial; }; export type DeepPartialSkipArrayKey = T extends BrowserNativeObject | NestedValue ? T : T extends ReadonlyArray ? { [K in keyof T]: DeepPartialSkipArrayKey; } : { [K in keyof T]?: DeepPartialSkipArrayKey; }; /** * Checks whether the type is any * See {@link https://stackoverflow.com/a/49928360/3406963} * @typeParam T - type which may be any * ``` * IsAny = true * IsAny = false * ``` */ export type IsAny = 0 extends 1 & T ? true : false; /** * Checks whether the type is never * @typeParam T - type which may be never * ``` * IsAny = true * IsAny = false * ``` */ export type IsNever = [T] extends [never] ? true : false; /** * Checks whether T1 can be exactly (mutually) assigned to T2 * @typeParam T1 - type to check * @typeParam T2 - type to check against * ``` * IsEqual = true * IsEqual<'foo', 'foo'> = true * IsEqual = false * IsEqual = false * IsEqual = false * IsEqual<'foo', string> = false * IsEqual<'foo' | 'bar', 'foo'> = boolean // 'foo' is assignable, but 'bar' is not (true | false) -> boolean * ``` */ export type IsEqual = T1 extends T2 ? (() => G extends T1 ? 1 : 2) extends () => G extends T2 ? 1 : 2 ? true : false : false; export type DeepMap = IsAny extends true ? any : T extends BrowserNativeObject | NestedValue ? TValue : T extends object ? { [K in keyof T]: DeepMap, TValue>; } : TValue; export type IsFlatObject = Extract, any[] | object> extends never ? true : false; export type Merge = { [K in keyof A | keyof B]?: K extends keyof A & keyof B ? [A[K], B[K]] extends [object, object] ? Merge : A[K] | B[K] : K extends keyof A ? A[K] : K extends keyof B ? B[K] : never; }; export {}; //# sourceMappingURL=utils.d.ts.map