react-hook-form 7.17.3 → 7.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,5 @@
1
+ import { FieldError, FieldErrors, FieldValues } from '../types';
2
+ export default function schemaErrorLookup(errors: FieldErrors, _fields: FieldValues, name: string): {
3
+ error?: FieldError;
4
+ name: string;
5
+ };
@@ -1,35 +1,35 @@
1
1
  import * as React from 'react';
2
2
  import { RegisterOptions } from './validator';
3
- import { Control, FieldError, FieldPath, FieldPathValue, FieldValues, Noop, RefCallBack, UnpackNestedValue, UseFormStateReturn } from './';
3
+ import { Control, FieldError, FieldPathValue, FieldPathWithValue, FieldValues, IsAny, Noop, RefCallBack, UnpackNestedValue, UseFormStateReturn } from './';
4
4
  export declare type ControllerFieldState = {
5
5
  invalid: boolean;
6
6
  isTouched: boolean;
7
7
  isDirty: boolean;
8
8
  error?: FieldError;
9
9
  };
10
- export declare type ControllerRenderProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
10
+ export declare type ControllerRenderProps<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>> = {
11
11
  onChange: (...event: any[]) => void;
12
12
  onBlur: Noop;
13
- value: UnpackNestedValue<FieldPathValue<TFieldValues, TName>>;
13
+ value: IsAny<TResult> extends true ? UnpackNestedValue<FieldPathValue<TFieldValues, TName>> : UnpackNestedValue<TResult>;
14
14
  name: TName;
15
15
  ref: RefCallBack;
16
16
  };
17
- export declare type UseControllerProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
17
+ export declare type UseControllerProps<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>> = {
18
18
  name: TName;
19
19
  rules?: Omit<RegisterOptions<TFieldValues, TName>, 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'>;
20
20
  shouldUnregister?: boolean;
21
- defaultValue?: UnpackNestedValue<FieldPathValue<TFieldValues, TName>>;
21
+ defaultValue?: IsAny<TResult> extends true ? UnpackNestedValue<FieldPathValue<TFieldValues, TName>> : UnpackNestedValue<TResult>;
22
22
  control?: Control<TFieldValues>;
23
23
  };
24
- export declare type UseControllerReturn<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
25
- field: ControllerRenderProps<TFieldValues, TName>;
24
+ export declare type UseControllerReturn<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>> = {
25
+ field: ControllerRenderProps<TFieldValues, TResult, TName>;
26
26
  formState: UseFormStateReturn<TFieldValues>;
27
27
  fieldState: ControllerFieldState;
28
28
  };
29
- export declare type ControllerProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
29
+ export declare type ControllerProps<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>> = {
30
30
  render: ({ field, fieldState, formState, }: {
31
- field: ControllerRenderProps<TFieldValues, TName>;
31
+ field: ControllerRenderProps<TFieldValues, TResult, TName>;
32
32
  fieldState: ControllerFieldState;
33
33
  formState: UseFormStateReturn<TFieldValues>;
34
34
  }) => React.ReactElement;
35
- } & UseControllerProps<TFieldValues, TName>;
35
+ } & UseControllerProps<TFieldValues, TResult, TName>;
@@ -9,7 +9,7 @@ export declare type UseFieldArrayProps<TFieldValues extends FieldValues = FieldV
9
9
  shouldUnregister?: boolean;
10
10
  };
11
11
  export declare type FieldArrayWithId<TFieldValues extends FieldValues = FieldValues, TFieldArrayName extends FieldArrayPath<TFieldValues> = FieldArrayPath<TFieldValues>, TKeyName extends string = 'id'> = FieldArray<TFieldValues, TFieldArrayName> & Record<TKeyName, string>;
12
- export declare type FieldArray<TFieldValues extends FieldValues = FieldValues, TFieldArrayName extends FieldArrayPath<TFieldValues> = FieldArrayPath<TFieldValues>> = FieldArrayPathValue<TFieldValues, TFieldArrayName> extends ReadonlyArray<infer U> ? U : never;
12
+ export declare type FieldArray<TFieldValues extends FieldValues = FieldValues, TFieldArrayName extends FieldArrayPath<TFieldValues> = FieldArrayPath<TFieldValues>> = FieldArrayPathValue<TFieldValues, TFieldArrayName> extends ReadonlyArray<infer U> | null | undefined ? U : never;
13
13
  export declare type FieldArrayMethodProps = {
14
14
  shouldFocus?: boolean;
15
15
  focusIndex?: number;
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import { SubjectType, Subscription } from '../utils/Subject';
2
+ import { Subject, Subscription } from '../utils/createSubject';
3
3
  import { ErrorOption, FieldError, FieldErrors } from './errors';
4
4
  import { EventType } from './events';
5
5
  import { FieldArrayWithId } from './fieldArray';
@@ -122,20 +122,20 @@ export declare type UseFormHandleSubmit<TFieldValues extends FieldValues> = <TSu
122
122
  export declare type UseFormReset<TFieldValues extends FieldValues> = (values?: DefaultValues<TFieldValues>, keepStateOptions?: KeepStateOptions) => void;
123
123
  export declare type WatchInternal<TFieldValues> = (fieldNames?: InternalFieldName | InternalFieldName[], defaultValue?: UnpackNestedValue<DeepPartial<TFieldValues>>, isMounted?: boolean, isGlobal?: boolean) => FieldPathValue<FieldValues, InternalFieldName> | FieldPathValues<FieldValues, InternalFieldName[]>;
124
124
  export declare type GetIsDirty = <TName extends InternalFieldName, TData>(name?: TName, data?: TData) => boolean;
125
- export declare type FormStateSubjectRef<TFieldValues> = SubjectType<Partial<FormState<TFieldValues>> & {
125
+ export declare type FormStateSubjectRef<TFieldValues> = Subject<Partial<FormState<TFieldValues>> & {
126
126
  name?: InternalFieldName;
127
127
  }>;
128
128
  export declare type Subjects<TFieldValues extends FieldValues = FieldValues> = {
129
- watch: SubjectType<{
129
+ watch: Subject<{
130
130
  name?: InternalFieldName;
131
131
  type?: EventType;
132
132
  values?: FieldValues;
133
133
  }>;
134
- control: SubjectType<{
134
+ control: Subject<{
135
135
  name?: InternalFieldName;
136
136
  values?: FieldValues;
137
137
  }>;
138
- array: SubjectType<{
138
+ array: Subject<{
139
139
  name?: InternalFieldName;
140
140
  values?: FieldValues;
141
141
  }>;
@@ -162,7 +162,7 @@ export declare type Control<TFieldValues extends FieldValues = FieldValues, TCon
162
162
  action: boolean;
163
163
  watch: boolean;
164
164
  };
165
- _options: UseFormProps<TFieldValues, TContext>;
165
+ _options: Pick<UseFormProps<TFieldValues, TContext>, 'shouldUnregister'>;
166
166
  _getDirty: GetIsDirty;
167
167
  _formState: FormState<TFieldValues>;
168
168
  _updateValid: Noop;
@@ -171,12 +171,15 @@ export declare type Control<TFieldValues extends FieldValues = FieldValues, TCon
171
171
  _proxyFormState: ReadFormState;
172
172
  _defaultValues: Partial<DefaultValues<TFieldValues>>;
173
173
  _getWatch: WatchInternal<TFieldValues>;
174
- register: UseFormRegister<TFieldValues>;
175
174
  _updateFieldArray: BatchFieldArrayUpdate;
176
175
  _getFieldArray: <TFieldArrayValues>(name: InternalFieldName) => Partial<TFieldArrayValues>[];
176
+ _executeSchema: (names: InternalFieldName[]) => Promise<{
177
+ errors: FieldErrors;
178
+ }>;
179
+ register: UseFormRegister<TFieldValues>;
177
180
  unregister: UseFormUnregister<TFieldValues>;
178
181
  };
179
- export declare type WatchObserver<TFieldValues> = (value: UnpackNestedValue<TFieldValues>, info: {
182
+ export declare type WatchObserver<TFieldValues> = (value: UnpackNestedValue<DeepPartial<TFieldValues>>, info: {
180
183
  name?: FieldPath<TFieldValues>;
181
184
  type?: EventType;
182
185
  value?: unknown;
@@ -21,6 +21,11 @@ export declare type LiteralUnion<T extends U, U extends Primitive> = T | (U & {
21
21
  export declare type DeepPartial<T> = T extends Date | FileList | File | NestedValue ? T : {
22
22
  [K in keyof T]?: DeepPartial<T[K]>;
23
23
  };
24
+ export declare type DeepPartialSkipArrayKey<T> = T extends Date | FileList | File | NestedValue ? T : T extends ReadonlyArray<any> ? {
25
+ [K in keyof T]: DeepPartialSkipArrayKey<T[K]>;
26
+ } : {
27
+ [K in keyof T]?: DeepPartialSkipArrayKey<T[K]>;
28
+ };
24
29
  export declare type IsAny<T> = boolean extends (T extends never ? true : false) ? true : false;
25
30
  export declare type DeepMap<T, TValue> = IsAny<T> extends true ? any : T extends Date | FileList | File | NestedValue ? TValue : T extends object ? {
26
31
  [K in keyof T]: DeepMap<NonUndefined<T[K]>, TValue>;
@@ -30,12 +35,10 @@ declare type IsTuple<T extends ReadonlyArray<any>> = number extends T['length']
30
35
  declare type TupleKey<T extends ReadonlyArray<any>> = Exclude<keyof T, keyof any[]>;
31
36
  declare type ArrayKey = number;
32
37
  declare type PathImpl<K extends string | number, V> = V extends Primitive ? `${K}` : `${K}` | `${K}.${Path<V>}`;
33
- export declare type Path<T> = (T extends ReadonlyArray<infer V> ? IsTuple<T> extends true ? {
38
+ export declare type Path<T> = T extends ReadonlyArray<infer V> ? IsTuple<T> extends true ? {
34
39
  [K in TupleKey<T>]-?: PathImpl<K & string, T[K]>;
35
40
  }[TupleKey<T>] : PathImpl<ArrayKey, V> : {
36
41
  [K in keyof T]-?: PathImpl<K & string, T[K]>;
37
- }[keyof T]) | {
38
- [K in keyof T]-?: K & string;
39
42
  }[keyof T];
40
43
  export declare type FieldPath<TFieldValues extends FieldValues> = Path<TFieldValues>;
41
44
  declare type ArrayPathImpl<K extends string | number, V> = V extends Primitive ? never : V extends ReadonlyArray<infer U> ? U extends Primitive ? never : `${K}` | `${K}.${ArrayPath<V>}` : `${K}.${ArrayPath<V>}`;
@@ -62,4 +65,7 @@ export declare type UnionLike<T> = [T] extends [Date | FileList | File | NestedV
62
65
  } : [T] extends [object] ? PartialBy<{
63
66
  [K in UnionKeys<T>]: UnionLike<UnionValues<T, K>>;
64
67
  }, Exclude<UnionKeys<T>, keyof T> | OptionalKeys<T>> : T;
68
+ export declare type FieldPathWithValue<TFieldValues extends FieldValues, TResult = unknown, FieldPaths extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
69
+ [key in FieldPaths]: FieldPathValue<TFieldValues, key> extends TResult ? key : never;
70
+ }[FieldPaths];
65
71
  export {};
@@ -1,2 +1,2 @@
1
- import { FieldPath, FieldValues, UseControllerProps, UseControllerReturn } from './types';
2
- export declare function useController<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>>(props: UseControllerProps<TFieldValues, TName>): UseControllerReturn<TFieldValues, TName>;
1
+ import { FieldPathWithValue, FieldValues, UseControllerProps, UseControllerReturn } from './types';
2
+ export declare function useController<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>>(props: UseControllerProps<TFieldValues, TResult, TName>): UseControllerReturn<TFieldValues, TResult, TName>;
@@ -1,7 +1,7 @@
1
- import { SubjectType } from './utils/Subject';
1
+ import { Subject } from './utils/createSubject';
2
2
  declare type Props<T> = {
3
3
  disabled?: boolean;
4
- subject: SubjectType<T>;
4
+ subject: Subject<T>;
5
5
  callback: (value: T) => void;
6
6
  skipEarlySubscription?: boolean;
7
7
  };
@@ -1,9 +1,9 @@
1
- import { Control, DeepPartial, FieldPath, FieldPathValue, FieldPathValues, FieldValues, UnpackNestedValue } from './types';
1
+ import { Control, DeepPartialSkipArrayKey, FieldPath, FieldPathValue, FieldPathValues, FieldValues, UnpackNestedValue } from './types';
2
2
  export declare function useWatch<TFieldValues extends FieldValues = FieldValues>(props: {
3
- defaultValue?: UnpackNestedValue<DeepPartial<TFieldValues>>;
3
+ defaultValue?: UnpackNestedValue<DeepPartialSkipArrayKey<TFieldValues>>;
4
4
  control?: Control<TFieldValues>;
5
5
  disabled?: boolean;
6
- }): UnpackNestedValue<DeepPartial<TFieldValues>>;
6
+ }): UnpackNestedValue<DeepPartialSkipArrayKey<TFieldValues>>;
7
7
  export declare function useWatch<TFieldValues extends FieldValues = FieldValues, TFieldName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>>(props: {
8
8
  name: TFieldName;
9
9
  defaultValue?: FieldPathValue<TFieldValues, TFieldName>;
@@ -12,7 +12,7 @@ export declare function useWatch<TFieldValues extends FieldValues = FieldValues,
12
12
  }): FieldPathValue<TFieldValues, TFieldName>;
13
13
  export declare function useWatch<TFieldValues extends FieldValues = FieldValues, TFieldNames extends FieldPath<TFieldValues>[] = FieldPath<TFieldValues>[]>(props: {
14
14
  name: readonly [...TFieldNames];
15
- defaultValue?: UnpackNestedValue<DeepPartial<TFieldValues>>;
15
+ defaultValue?: UnpackNestedValue<DeepPartialSkipArrayKey<TFieldValues>>;
16
16
  control?: Control<TFieldValues>;
17
17
  disabled?: boolean;
18
18
  }): FieldPathValues<TFieldValues, TFieldNames>;
@@ -1 +1 @@
1
- export default function cloneObject<T extends unknown>(data: T): T;
1
+ export default function cloneObject<T>(data: T): T;
@@ -1,2 +1,2 @@
1
- declare const _default: <T extends unknown>(value: T) => (T & any[]) | T[];
1
+ declare const _default: <T>(value: T) => (T & any[]) | T[];
2
2
  export default _default;
@@ -0,0 +1,18 @@
1
+ import { Noop } from '../types';
2
+ export declare type Observer<T> = {
3
+ next: (value: T) => void;
4
+ };
5
+ export declare type TearDown = Noop;
6
+ export declare type Subscription = {
7
+ add: (tearDown: TearDown) => void;
8
+ unsubscribe: () => void;
9
+ };
10
+ export declare type Subject<T> = {
11
+ readonly observers: Observer<T>[];
12
+ next: (value: T) => void;
13
+ subscribe: (value: Observer<T>) => {
14
+ unsubscribe: TearDown;
15
+ };
16
+ unsubscribe: Noop;
17
+ };
18
+ export default function createSubject<T>(): Subject<T>;
@@ -1,2 +1,2 @@
1
- declare const _default: <T extends unknown>(obj: T, path: string, defaultValue?: unknown) => any;
1
+ declare const _default: <T>(obj: T, path: string, defaultValue?: unknown) => any;
2
2
  export default _default;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "react-hook-form",
3
3
  "description": "Performant, flexible and extensible forms library for React Hooks",
4
- "version": "7.17.3",
4
+ "version": "7.18.0",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.esm.js",
7
7
  "umd:main": "dist/index.umd.js",
@@ -32,7 +32,7 @@
32
32
  "prettier:fix": "prettier --config .prettierrc --write \"**/*.{ts,tsx}\"",
33
33
  "lint": "eslint '**/*.{js,ts,tsx}'",
34
34
  "lint:fix": "yarn lint -- --fix",
35
- "lint:types": "tsc --noEmit",
35
+ "type": "tsc --noEmit",
36
36
  "coverage": "jest --coverage --coverageReporters=text-lcov",
37
37
  "test": "jest --config ./scripts/jest/jest.config.js",
38
38
  "test:coverage": "yarn test -- --coverage",
@@ -43,7 +43,7 @@
43
43
  "cypress": "cypress run",
44
44
  "cypress:open": "cypress open",
45
45
  "postversion": "git push && git push origin v$npm_package_version",
46
- "prepublishOnly": "yarn && yarn lint:fix && yarn lint:types && yarn test && yarn build",
46
+ "prepublishOnly": "yarn && yarn lint:fix && yarn type && yarn test && yarn build",
47
47
  "bundlesize": "yarn build:modern && bundlesize",
48
48
  "start:app": "yarn build:esm && yarn link && yarn --cwd node_modules/react link && yarn --cwd ./app link react react-hook-form && yarn --cwd ./app && yarn --cwd ./app run dev"
49
49
  },
@@ -65,44 +65,44 @@
65
65
  "author": "<bluebill1049@hotmail.com>",
66
66
  "license": "MIT",
67
67
  "devDependencies": {
68
- "@rollup/plugin-commonjs": "^20.0.0",
69
- "@rollup/plugin-node-resolve": "^13.0.5",
68
+ "@rollup/plugin-commonjs": "^21.0.1",
69
+ "@rollup/plugin-node-resolve": "^13.0.6",
70
70
  "@testing-library/jest-dom": "^5.14.1",
71
- "@testing-library/react": "^12.1.1",
71
+ "@testing-library/react": "^12.1.2",
72
72
  "@testing-library/react-hooks": "^7.0.2",
73
- "@testing-library/react-native": "^7.2.0",
73
+ "@testing-library/react-native": "^8.0.0",
74
74
  "@types/jest": "^27.0.2",
75
- "@types/react": "^17.0.26",
76
- "@types/react-native": "^0.65.2",
77
- "@typescript-eslint/eslint-plugin": "^4.32.0",
78
- "@typescript-eslint/parser": "^4.32.0",
75
+ "@types/react": "^17.0.31",
76
+ "@types/react-native": "^0.65.10",
77
+ "@typescript-eslint/eslint-plugin": "^5.1.0",
78
+ "@typescript-eslint/parser": "^5.1.0",
79
79
  "@vitejs/plugin-react-refresh": "^1.3.6",
80
- "babel-jest": "^27.2.4",
80
+ "babel-jest": "^27.3.1",
81
81
  "bundlesize": "^0.18.0",
82
- "cypress": "8.5.0",
83
- "eslint": "^7.32.0",
82
+ "cypress": "8.6.0",
83
+ "eslint": "^8.0.1",
84
84
  "eslint-config-prettier": "^8.3.0",
85
85
  "eslint-plugin-cypress": "^2.12.1",
86
86
  "eslint-plugin-prettier": "^4.0.0",
87
87
  "eslint-plugin-react": "^7.26.1",
88
88
  "eslint-plugin-react-hooks": "^4.2.0",
89
89
  "eslint-plugin-simple-import-sort": "^7.0.0",
90
- "husky": "^7.0.2",
91
- "jest": "^27.2.4",
92
- "lint-staged": "^11.1.2",
90
+ "husky": "^7.0.4",
91
+ "jest": "^27.3.1",
92
+ "lint-staged": "^11.2.3",
93
93
  "prettier": "^2.4.1",
94
94
  "react": "^17.0.1",
95
95
  "react-dom": "^17.0.1",
96
- "react-native": "^0.65.1",
96
+ "react-native": "^0.66.1",
97
97
  "react-test-renderer": "^17.0.1",
98
98
  "rimraf": "^3.0.2",
99
- "rollup": "^2.57.0",
99
+ "rollup": "^2.58.0",
100
100
  "rollup-plugin-peer-deps-external": "^2.2.4",
101
101
  "rollup-plugin-sourcemaps": "^0.6.2",
102
102
  "rollup-plugin-terser": "^7.0.2",
103
103
  "rollup-plugin-typescript2": "^0.30.0",
104
- "ts-jest": "^27.0.5",
105
- "typescript": "^4.4.3"
104
+ "ts-jest": "^27.0.7",
105
+ "typescript": "^4.4.4"
106
106
  },
107
107
  "resolutions": {
108
108
  "react-native/@jest/create-cache-key-function": "^27.0.2"
@@ -1,24 +0,0 @@
1
- import { Noop } from '../types';
2
- export declare type Observer<T> = {
3
- next: (value: T) => void;
4
- };
5
- export declare type TearDown = Noop;
6
- export declare type SubjectType<T> = {
7
- next: (value: T) => void;
8
- subscribe: (value: Observer<T>) => {
9
- unsubscribe: TearDown;
10
- };
11
- unsubscribe: Noop;
12
- };
13
- export declare class Subscription {
14
- private tearDowns;
15
- add(tearDown: TearDown): void;
16
- unsubscribe(): void;
17
- }
18
- export default class Subject<T> {
19
- observers: Observer<T>[];
20
- constructor();
21
- next(value: T): void;
22
- subscribe(observer: Observer<T>): Subscription;
23
- unsubscribe(): void;
24
- }