react-hook-form 7.18.0-next.0 → 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.
- package/CHANGELOG.md +1185 -0
- package/README.md +6 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +151 -91
- package/dist/index.esm.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/dist/logic/schemaErrorLookup.d.ts +5 -0
- package/dist/logic/shouldSubscribeByName.d.ts +2 -0
- package/dist/types/fieldArray.d.ts +1 -1
- package/dist/types/form.d.ts +11 -8
- package/dist/types/utils.d.ts +5 -0
- package/dist/useSubscribe.d.ts +2 -2
- package/dist/useWatch.d.ts +4 -4
- package/dist/utils/cloneObject.d.ts +1 -1
- package/dist/utils/convertToArrayPayload.d.ts +1 -1
- package/dist/utils/createSubject.d.ts +18 -0
- package/dist/utils/get.d.ts +1 -1
- package/package.json +21 -23
- package/dist/utils/Subject.d.ts +0 -24
@@ -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;
|
package/dist/types/form.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
import * as React from 'react';
|
2
|
-
import {
|
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> =
|
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:
|
129
|
+
watch: Subject<{
|
130
130
|
name?: InternalFieldName;
|
131
131
|
type?: EventType;
|
132
132
|
values?: FieldValues;
|
133
133
|
}>;
|
134
|
-
control:
|
134
|
+
control: Subject<{
|
135
135
|
name?: InternalFieldName;
|
136
136
|
values?: FieldValues;
|
137
137
|
}>;
|
138
|
-
array:
|
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
|
182
|
+
export declare type WatchObserver<TFieldValues> = (value: UnpackNestedValue<DeepPartial<TFieldValues>>, info: {
|
180
183
|
name?: FieldPath<TFieldValues>;
|
181
184
|
type?: EventType;
|
182
185
|
value?: unknown;
|
package/dist/types/utils.d.ts
CHANGED
@@ -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>;
|
package/dist/useSubscribe.d.ts
CHANGED
@@ -1,7 +1,7 @@
|
|
1
|
-
import {
|
1
|
+
import { Subject } from './utils/createSubject';
|
2
2
|
declare type Props<T> = {
|
3
3
|
disabled?: boolean;
|
4
|
-
subject:
|
4
|
+
subject: Subject<T>;
|
5
5
|
callback: (value: T) => void;
|
6
6
|
skipEarlySubscription?: boolean;
|
7
7
|
};
|
package/dist/useWatch.d.ts
CHANGED
@@ -1,9 +1,9 @@
|
|
1
|
-
import { Control,
|
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<
|
3
|
+
defaultValue?: UnpackNestedValue<DeepPartialSkipArrayKey<TFieldValues>>;
|
4
4
|
control?: Control<TFieldValues>;
|
5
5
|
disabled?: boolean;
|
6
|
-
}): UnpackNestedValue<
|
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<
|
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
|
1
|
+
export default function cloneObject<T>(data: T): T;
|
@@ -1,2 +1,2 @@
|
|
1
|
-
declare const _default: <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>;
|
package/dist/utils/get.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
declare const _default: <T
|
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.18.0
|
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
|
-
"
|
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",
|
@@ -42,9 +42,8 @@
|
|
42
42
|
"test:native": "TEST_ENV=native yarn test",
|
43
43
|
"cypress": "cypress run",
|
44
44
|
"cypress:open": "cypress open",
|
45
|
-
"cypress:parallel": "cypress-parallel -s cypress -t 4 -d -a",
|
46
45
|
"postversion": "git push && git push origin v$npm_package_version",
|
47
|
-
"prepublishOnly": "yarn && yarn lint:fix && yarn
|
46
|
+
"prepublishOnly": "yarn && yarn lint:fix && yarn type && yarn test && yarn build",
|
48
47
|
"bundlesize": "yarn build:modern && bundlesize",
|
49
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"
|
50
49
|
},
|
@@ -66,45 +65,44 @@
|
|
66
65
|
"author": "<bluebill1049@hotmail.com>",
|
67
66
|
"license": "MIT",
|
68
67
|
"devDependencies": {
|
69
|
-
"@rollup/plugin-commonjs": "^
|
70
|
-
"@rollup/plugin-node-resolve": "^13.0.
|
68
|
+
"@rollup/plugin-commonjs": "^21.0.1",
|
69
|
+
"@rollup/plugin-node-resolve": "^13.0.6",
|
71
70
|
"@testing-library/jest-dom": "^5.14.1",
|
72
|
-
"@testing-library/react": "^12.1.
|
71
|
+
"@testing-library/react": "^12.1.2",
|
73
72
|
"@testing-library/react-hooks": "^7.0.2",
|
74
|
-
"@testing-library/react-native": "^
|
73
|
+
"@testing-library/react-native": "^8.0.0",
|
75
74
|
"@types/jest": "^27.0.2",
|
76
|
-
"@types/react": "^17.0.
|
77
|
-
"@types/react-native": "^0.65.
|
78
|
-
"@typescript-eslint/eslint-plugin": "^
|
79
|
-
"@typescript-eslint/parser": "^
|
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",
|
80
79
|
"@vitejs/plugin-react-refresh": "^1.3.6",
|
81
|
-
"babel-jest": "^27.
|
80
|
+
"babel-jest": "^27.3.1",
|
82
81
|
"bundlesize": "^0.18.0",
|
83
|
-
"cypress": "8.
|
84
|
-
"
|
85
|
-
"eslint": "^7.32.0",
|
82
|
+
"cypress": "8.6.0",
|
83
|
+
"eslint": "^8.0.1",
|
86
84
|
"eslint-config-prettier": "^8.3.0",
|
87
85
|
"eslint-plugin-cypress": "^2.12.1",
|
88
86
|
"eslint-plugin-prettier": "^4.0.0",
|
89
87
|
"eslint-plugin-react": "^7.26.1",
|
90
88
|
"eslint-plugin-react-hooks": "^4.2.0",
|
91
89
|
"eslint-plugin-simple-import-sort": "^7.0.0",
|
92
|
-
"husky": "^7.0.
|
93
|
-
"jest": "^27.
|
94
|
-
"lint-staged": "^11.
|
90
|
+
"husky": "^7.0.4",
|
91
|
+
"jest": "^27.3.1",
|
92
|
+
"lint-staged": "^11.2.3",
|
95
93
|
"prettier": "^2.4.1",
|
96
94
|
"react": "^17.0.1",
|
97
95
|
"react-dom": "^17.0.1",
|
98
|
-
"react-native": "^0.
|
96
|
+
"react-native": "^0.66.1",
|
99
97
|
"react-test-renderer": "^17.0.1",
|
100
98
|
"rimraf": "^3.0.2",
|
101
|
-
"rollup": "^2.
|
99
|
+
"rollup": "^2.58.0",
|
102
100
|
"rollup-plugin-peer-deps-external": "^2.2.4",
|
103
101
|
"rollup-plugin-sourcemaps": "^0.6.2",
|
104
102
|
"rollup-plugin-terser": "^7.0.2",
|
105
103
|
"rollup-plugin-typescript2": "^0.30.0",
|
106
|
-
"ts-jest": "^27.0.
|
107
|
-
"typescript": "^4.4.
|
104
|
+
"ts-jest": "^27.0.7",
|
105
|
+
"typescript": "^4.4.4"
|
108
106
|
},
|
109
107
|
"resolutions": {
|
110
108
|
"react-native/@jest/create-cache-key-function": "^27.0.2"
|
package/dist/utils/Subject.d.ts
DELETED
@@ -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
|
-
}
|