react-hook-form 7.17.0 → 7.17.4
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 +24 -0
- package/dist/controller.d.ts +2 -2
- package/dist/index.cjs.js +1 -1
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +447 -446
- 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/shouldSubscribeByName.d.ts +2 -0
- package/dist/types/controller.d.ts +15 -18
- package/dist/types/fields.d.ts +2 -2
- package/dist/types/form.d.ts +9 -10
- package/dist/types/utils.d.ts +21 -11
- package/dist/useController.d.ts +2 -2
- package/dist/useSubscribe.d.ts +4 -3
- 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/get.d.ts +1 -1
- package/dist/utils/{Subject.d.ts → subject.d.ts} +3 -2
- package/package.json +17 -19
@@ -1,38 +1,35 @@
|
|
1
1
|
import * as React from 'react';
|
2
|
-
import { FieldErrors } from '..';
|
3
2
|
import { RegisterOptions } from './validator';
|
4
|
-
import { Control, FieldError,
|
5
|
-
declare type
|
6
|
-
export declare type ControllerFieldState<TFieldValues extends FieldValues = FieldValues, TResult = any, TName extends FieldPathWithValue<TFieldValues, TResult> = FieldPathWithValue<TFieldValues, TResult>> = {
|
3
|
+
import { Control, FieldError, FieldPath, FieldPathValue, FieldValues, Noop, RefCallBack, UnpackNestedValue, UseFormStateReturn } from './';
|
4
|
+
export declare type ControllerFieldState = {
|
7
5
|
invalid: boolean;
|
8
6
|
isTouched: boolean;
|
9
7
|
isDirty: boolean;
|
10
|
-
error?:
|
8
|
+
error?: FieldError;
|
11
9
|
};
|
12
|
-
export declare type ControllerRenderProps<TFieldValues extends FieldValues = FieldValues,
|
10
|
+
export declare type ControllerRenderProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
|
13
11
|
onChange: (...event: any[]) => void;
|
14
|
-
onBlur:
|
15
|
-
value:
|
12
|
+
onBlur: Noop;
|
13
|
+
value: UnpackNestedValue<FieldPathValue<TFieldValues, TName>>;
|
16
14
|
name: TName;
|
17
15
|
ref: RefCallBack;
|
18
16
|
};
|
19
|
-
export declare type UseControllerProps<TFieldValues extends FieldValues = FieldValues,
|
17
|
+
export declare type UseControllerProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
|
20
18
|
name: TName;
|
21
19
|
rules?: Omit<RegisterOptions<TFieldValues, TName>, 'valueAsNumber' | 'valueAsDate' | 'setValueAs' | 'disabled'>;
|
22
20
|
shouldUnregister?: boolean;
|
23
|
-
defaultValue?:
|
21
|
+
defaultValue?: UnpackNestedValue<FieldPathValue<TFieldValues, TName>>;
|
24
22
|
control?: Control<TFieldValues>;
|
25
23
|
};
|
26
|
-
export declare type UseControllerReturn<TFieldValues extends FieldValues = FieldValues,
|
27
|
-
field: ControllerRenderProps<TFieldValues,
|
24
|
+
export declare type UseControllerReturn<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
|
25
|
+
field: ControllerRenderProps<TFieldValues, TName>;
|
28
26
|
formState: UseFormStateReturn<TFieldValues>;
|
29
|
-
fieldState: ControllerFieldState
|
27
|
+
fieldState: ControllerFieldState;
|
30
28
|
};
|
31
|
-
export declare type ControllerProps<TFieldValues extends FieldValues = FieldValues,
|
29
|
+
export declare type ControllerProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
|
32
30
|
render: ({ field, fieldState, formState, }: {
|
33
|
-
field: ControllerRenderProps<TFieldValues,
|
34
|
-
fieldState: ControllerFieldState
|
31
|
+
field: ControllerRenderProps<TFieldValues, TName>;
|
32
|
+
fieldState: ControllerFieldState;
|
35
33
|
formState: UseFormStateReturn<TFieldValues>;
|
36
34
|
}) => React.ReactElement;
|
37
|
-
} & UseControllerProps<TFieldValues,
|
38
|
-
export {};
|
35
|
+
} & UseControllerProps<TFieldValues, TName>;
|
package/dist/types/fields.d.ts
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import { IsFlatObject } from './utils';
|
1
|
+
import { IsFlatObject, Noop } from './utils';
|
2
2
|
import { RegisterOptions } from './validator';
|
3
3
|
export declare type InternalFieldName = string;
|
4
4
|
export declare type FieldName<TFieldValues extends FieldValues> = IsFlatObject<TFieldValues> extends true ? Extract<keyof TFieldValues, string> : string;
|
@@ -10,7 +10,7 @@ export declare type CustomElement<TFieldValues extends FieldValues> = {
|
|
10
10
|
checked?: boolean;
|
11
11
|
options?: HTMLOptionsCollection;
|
12
12
|
files?: FileList | null;
|
13
|
-
focus?:
|
13
|
+
focus?: Noop;
|
14
14
|
};
|
15
15
|
export declare type FieldValue<TFieldValues extends FieldValues> = TFieldValues[InternalFieldName];
|
16
16
|
export declare type FieldValues = Record<string, any>;
|
package/dist/types/form.d.ts
CHANGED
@@ -1,17 +1,17 @@
|
|
1
1
|
import * as React from 'react';
|
2
|
-
import { SubjectType, Subscription } from '../utils/
|
2
|
+
import { SubjectType, Subscription } from '../utils/subject';
|
3
3
|
import { ErrorOption, FieldError, FieldErrors } from './errors';
|
4
4
|
import { EventType } from './events';
|
5
5
|
import { FieldArrayWithId } from './fieldArray';
|
6
6
|
import { FieldRefs, FieldValue, FieldValues, InternalFieldName } from './fields';
|
7
7
|
import { Resolver } from './resolvers';
|
8
|
-
import { DeepMap, DeepPartial, FieldArrayPath, FieldPath, FieldPathValue, FieldPathValues, UnionLike } from './utils';
|
8
|
+
import { DeepMap, DeepPartial, FieldArrayPath, FieldPath, FieldPathValue, FieldPathValues, Noop, UnionLike } from './utils';
|
9
9
|
import { RegisterOptions } from './validator';
|
10
10
|
declare const $NestedValue: unique symbol;
|
11
11
|
export declare type NestedValue<TValue extends object = object> = {
|
12
12
|
[$NestedValue]: never;
|
13
13
|
} & TValue;
|
14
|
-
export declare type UnpackNestedValue<T> = T extends NestedValue<infer U> ? U : T extends
|
14
|
+
export declare type UnpackNestedValue<T> = T extends NestedValue<infer U> ? U : T extends Date | FileList | File ? T : T extends object ? {
|
15
15
|
[K in keyof T]: UnpackNestedValue<T[K]>;
|
16
16
|
} : T;
|
17
17
|
export declare type DefaultValues<TFieldValues> = UnpackNestedValue<DeepPartial<TFieldValues>>;
|
@@ -149,24 +149,23 @@ export declare type Names = {
|
|
149
149
|
focus: InternalFieldName;
|
150
150
|
watchAll: boolean;
|
151
151
|
};
|
152
|
-
export declare type BatchFieldArrayUpdate = <T extends Function, TFieldValues, TFieldArrayName extends FieldArrayPath<TFieldValues> = FieldArrayPath<TFieldValues>, TKeyName extends string = 'id'>(
|
152
|
+
export declare type BatchFieldArrayUpdate = <T extends Function, TFieldValues, TFieldArrayName extends FieldArrayPath<TFieldValues> = FieldArrayPath<TFieldValues>, TKeyName extends string = 'id'>(name: InternalFieldName, method: T, args: {
|
153
153
|
argA?: unknown;
|
154
154
|
argB?: unknown;
|
155
155
|
}, updatedFieldArrayValues?: Partial<FieldArrayWithId<TFieldValues, TFieldArrayName, TKeyName>>[], shouldSetValue?: boolean, shouldSetFields?: boolean) => void;
|
156
156
|
export declare type Control<TFieldValues extends FieldValues = FieldValues, TContext extends object = object> = {
|
157
|
-
_shouldUnregister?: boolean;
|
158
157
|
_subjects: Subjects<TFieldValues>;
|
159
|
-
|
158
|
+
_removeUnmounted: Noop;
|
160
159
|
_names: Names;
|
161
160
|
_stateFlags: {
|
162
161
|
mount: boolean;
|
163
162
|
action: boolean;
|
164
163
|
watch: boolean;
|
165
164
|
};
|
166
|
-
|
167
|
-
|
165
|
+
_options: UseFormProps<TFieldValues, TContext>;
|
166
|
+
_getDirty: GetIsDirty;
|
168
167
|
_formState: FormState<TFieldValues>;
|
169
|
-
_updateValid:
|
168
|
+
_updateValid: Noop;
|
170
169
|
_fields: FieldRefs;
|
171
170
|
_formValues: FieldValues;
|
172
171
|
_proxyFormState: ReadFormState;
|
@@ -174,7 +173,7 @@ export declare type Control<TFieldValues extends FieldValues = FieldValues, TCon
|
|
174
173
|
_getWatch: WatchInternal<TFieldValues>;
|
175
174
|
register: UseFormRegister<TFieldValues>;
|
176
175
|
_updateFieldArray: BatchFieldArrayUpdate;
|
177
|
-
|
176
|
+
_getFieldArray: <TFieldArrayValues>(name: InternalFieldName) => Partial<TFieldArrayValues>[];
|
178
177
|
unregister: UseFormUnregister<TFieldValues>;
|
179
178
|
};
|
180
179
|
export declare type WatchObserver<TFieldValues> = (value: UnpackNestedValue<TFieldValues>, info: {
|
package/dist/types/utils.d.ts
CHANGED
@@ -1,5 +1,15 @@
|
|
1
1
|
import { FieldValues } from './fields';
|
2
2
|
import { NestedValue } from './form';
|
3
|
+
export declare type Noop = () => void;
|
4
|
+
interface File extends Blob {
|
5
|
+
readonly lastModified: number;
|
6
|
+
readonly name: string;
|
7
|
+
}
|
8
|
+
interface FileList {
|
9
|
+
readonly length: number;
|
10
|
+
item(index: number): File | null;
|
11
|
+
[index: number]: File;
|
12
|
+
}
|
3
13
|
export declare type Primitive = null | undefined | string | number | boolean | symbol | bigint;
|
4
14
|
export declare type EmptyObject = {
|
5
15
|
[K in string | number]: never;
|
@@ -8,15 +18,18 @@ export declare type NonUndefined<T> = T extends undefined ? never : T;
|
|
8
18
|
export declare type LiteralUnion<T extends U, U extends Primitive> = T | (U & {
|
9
19
|
_?: never;
|
10
20
|
});
|
11
|
-
export declare type
|
12
|
-
|
13
|
-
[K in keyof T]?: DeepPartialImpl<T[K]>;
|
21
|
+
export declare type DeepPartial<T> = T extends Date | FileList | File | NestedValue ? T : {
|
22
|
+
[K in keyof T]?: DeepPartial<T[K]>;
|
14
23
|
};
|
15
|
-
export declare type
|
16
|
-
|
17
|
-
|
18
|
-
[K in keyof T]
|
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]>;
|
19
28
|
};
|
29
|
+
export declare type IsAny<T> = boolean extends (T extends never ? true : false) ? true : false;
|
30
|
+
export declare type DeepMap<T, TValue> = IsAny<T> extends true ? any : T extends Date | FileList | File | NestedValue ? TValue : T extends object ? {
|
31
|
+
[K in keyof T]: DeepMap<NonUndefined<T[K]>, TValue>;
|
32
|
+
} : TValue;
|
20
33
|
export declare type IsFlatObject<T extends object> = Extract<Exclude<T[keyof T], NestedValue | Date | FileList>, any[] | object> extends never ? true : false;
|
21
34
|
declare type IsTuple<T extends ReadonlyArray<any>> = number extends T['length'] ? false : true;
|
22
35
|
declare type TupleKey<T extends ReadonlyArray<any>> = Exclude<keyof T, keyof any[]>;
|
@@ -49,10 +62,7 @@ declare type OptionalKeys<T> = T extends any ? {
|
|
49
62
|
declare type PartialBy<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
50
63
|
export declare type UnionLike<T> = [T] extends [Date | FileList | File | NestedValue] ? T : [T] extends [ReadonlyArray<any>] ? {
|
51
64
|
[K in keyof T]: UnionLike<T[K]>;
|
52
|
-
} : [T] extends [
|
65
|
+
} : [T] extends [object] ? PartialBy<{
|
53
66
|
[K in UnionKeys<T>]: UnionLike<UnionValues<T, K>>;
|
54
67
|
}, Exclude<UnionKeys<T>, keyof T> | OptionalKeys<T>> : T;
|
55
|
-
export declare type FieldPathWithValue<TFieldValues extends FieldValues, TResult = unknown, FieldPaths extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
|
56
|
-
[key in FieldPaths]: FieldPathValue<TFieldValues, key> extends TResult ? key : never;
|
57
|
-
}[FieldPaths];
|
58
68
|
export {};
|
package/dist/useController.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
import {
|
2
|
-
export declare function useController<TFieldValues extends FieldValues = FieldValues,
|
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>;
|
package/dist/useSubscribe.d.ts
CHANGED
@@ -1,8 +1,9 @@
|
|
1
|
-
import { SubjectType } from './utils/
|
1
|
+
import { SubjectType } from './utils/subject';
|
2
2
|
declare type Props<T> = {
|
3
3
|
disabled?: boolean;
|
4
|
-
subject
|
4
|
+
subject: SubjectType<T>;
|
5
5
|
callback: (value: T) => void;
|
6
|
+
skipEarlySubscription?: boolean;
|
6
7
|
};
|
7
|
-
export declare function useSubscribe<T>(
|
8
|
+
export declare function useSubscribe<T>(props: Props<T>): void;
|
8
9
|
export {};
|
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;
|
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;
|
@@ -1,13 +1,14 @@
|
|
1
|
+
import { Noop } from '../types';
|
1
2
|
export declare type Observer<T> = {
|
2
3
|
next: (value: T) => void;
|
3
4
|
};
|
4
|
-
export declare type TearDown =
|
5
|
+
export declare type TearDown = Noop;
|
5
6
|
export declare type SubjectType<T> = {
|
6
7
|
next: (value: T) => void;
|
7
8
|
subscribe: (value: Observer<T>) => {
|
8
9
|
unsubscribe: TearDown;
|
9
10
|
};
|
10
|
-
unsubscribe:
|
11
|
+
unsubscribe: Noop;
|
11
12
|
};
|
12
13
|
export declare class Subscription {
|
13
14
|
private tearDowns;
|
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.
|
4
|
+
"version": "7.17.4",
|
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,23 +65,22 @@
|
|
66
65
|
"author": "<bluebill1049@hotmail.com>",
|
67
66
|
"license": "MIT",
|
68
67
|
"devDependencies": {
|
69
|
-
"@rollup/plugin-commonjs": "^
|
68
|
+
"@rollup/plugin-commonjs": "^21.0.0",
|
70
69
|
"@rollup/plugin-node-resolve": "^13.0.5",
|
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
73
|
"@testing-library/react-native": "^7.2.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.29",
|
76
|
+
"@types/react-native": "^0.65.5",
|
77
|
+
"@typescript-eslint/eslint-plugin": "^5.0.0",
|
78
|
+
"@typescript-eslint/parser": "^5.0.0",
|
80
79
|
"@vitejs/plugin-react-refresh": "^1.3.6",
|
81
|
-
"babel-jest": "^27.2.
|
80
|
+
"babel-jest": "^27.2.5",
|
82
81
|
"bundlesize": "^0.18.0",
|
83
|
-
"cypress": "8.
|
84
|
-
"
|
85
|
-
"eslint": "^7.32.0",
|
82
|
+
"cypress": "8.6.0",
|
83
|
+
"eslint": "^8.0.0",
|
86
84
|
"eslint-config-prettier": "^8.3.0",
|
87
85
|
"eslint-plugin-cypress": "^2.12.1",
|
88
86
|
"eslint-plugin-prettier": "^4.0.0",
|
@@ -90,21 +88,21 @@
|
|
90
88
|
"eslint-plugin-react-hooks": "^4.2.0",
|
91
89
|
"eslint-plugin-simple-import-sort": "^7.0.0",
|
92
90
|
"husky": "^7.0.2",
|
93
|
-
"jest": "^27.2.
|
94
|
-
"lint-staged": "^11.
|
91
|
+
"jest": "^27.2.5",
|
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.0",
|
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
104
|
"ts-jest": "^27.0.5",
|
107
|
-
"typescript": "^4.4.
|
105
|
+
"typescript": "^4.4.4"
|
108
106
|
},
|
109
107
|
"resolutions": {
|
110
108
|
"react-native/@jest/create-cache-key-function": "^27.0.2"
|