react-hook-form 7.16.0 → 7.17.1

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.
@@ -1,3 +1,3 @@
1
1
  import { FieldArrayMethodProps, InternalFieldName } from '../types';
2
- declare const _default: (name: InternalFieldName, index: number, options?: FieldArrayMethodProps | undefined) => string;
2
+ declare const _default: (name: InternalFieldName, index: number, options?: FieldArrayMethodProps) => string;
3
3
  export default _default;
@@ -1,11 +1,12 @@
1
1
  import * as React from 'react';
2
2
  import { RegisterOptions } from './validator';
3
- import { Control, FieldErrors, FieldPath, FieldPathValue, FieldValues, RefCallBack, UnpackNestedValue, UseFormStateReturn } from './';
3
+ import { Control, DeepMapImpl, DeepPartialImpl, FieldError, FieldPath, FieldPathValue, FieldValues, RefCallBack, UnionLike, UnpackNestedValue, UseFormStateReturn } from './';
4
+ declare type ControllerFieldError<T> = DeepMapImpl<DeepPartialImpl<UnionLike<T>>, FieldError>;
4
5
  export declare type ControllerFieldState<TFieldValues extends FieldValues = FieldValues, TFieldName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
5
6
  invalid: boolean;
6
7
  isTouched: boolean;
7
8
  isDirty: boolean;
8
- error?: FieldErrors<FieldPathValue<TFieldValues, TFieldName>>;
9
+ error?: ControllerFieldError<FieldPathValue<TFieldValues, TFieldName>>;
9
10
  };
10
11
  export declare type ControllerRenderProps<TFieldValues extends FieldValues = FieldValues, TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>> = {
11
12
  onChange: (...event: any[]) => void;
@@ -33,3 +34,4 @@ export declare type ControllerProps<TFieldValues extends FieldValues = FieldValu
33
34
  formState: UseFormStateReturn<TFieldValues>;
34
35
  }) => React.ReactElement;
35
36
  } & UseControllerProps<TFieldValues, TName>;
37
+ export {};
@@ -149,22 +149,21 @@ 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'>(keyName: TKeyName, name: InternalFieldName, method: T, args: {
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
- _removeFields: () => void;
158
+ _removeUnmounted: () => void;
160
159
  _names: Names;
161
160
  _stateFlags: {
162
161
  mount: boolean;
163
162
  action: boolean;
164
163
  watch: boolean;
165
164
  };
166
- _updateProps: (props: UseFormProps<TFieldValues, TContext>) => void;
167
- _getIsDirty: GetIsDirty;
165
+ _options: UseFormProps<TFieldValues, TContext>;
166
+ _getDirty: GetIsDirty;
168
167
  _formState: FormState<TFieldValues>;
169
168
  _updateValid: () => void;
170
169
  _fields: FieldRefs;
@@ -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
- _getFieldArrayValue: <TFieldArrayValues>(name: InternalFieldName) => Partial<TFieldArrayValues>[];
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: {
@@ -8,12 +8,12 @@ export declare type NonUndefined<T> = T extends undefined ? never : T;
8
8
  export declare type LiteralUnion<T extends U, U extends Primitive> = T | (U & {
9
9
  _?: never;
10
10
  });
11
- declare type DeepPartialImpl<T> = T extends NestedValue ? T : T extends ReadonlyArray<any> | Record<any, unknown> ? DeepPartial<T> : T;
11
+ export declare type DeepPartialImpl<T> = T extends NestedValue ? T : T extends ReadonlyArray<any> | Record<any, unknown> ? DeepPartial<T> : T;
12
12
  export declare type DeepPartial<T> = {
13
13
  [K in keyof T]?: DeepPartialImpl<T[K]>;
14
14
  };
15
15
  export declare type IsAny<T> = boolean extends (T extends never ? true : false) ? true : false;
16
- declare type DeepMapImpl<T, TValue> = IsAny<T> extends true ? any : T extends NestedValue ? TValue : T extends ReadonlyArray<any> | Record<any, unknown> ? DeepMap<T, TValue> : TValue;
16
+ export declare type DeepMapImpl<T, TValue> = IsAny<T> extends true ? any : T extends NestedValue ? TValue : T extends ReadonlyArray<any> | Record<any, unknown> ? DeepMap<T, TValue> : TValue;
17
17
  export declare type DeepMap<T, TValue> = {
18
18
  [K in keyof T]: DeepMapImpl<NonUndefined<T[K]>, TValue>;
19
19
  };
@@ -21,14 +21,14 @@ export declare type IsFlatObject<T extends object> = Extract<Exclude<T[keyof T],
21
21
  declare type IsTuple<T extends ReadonlyArray<any>> = number extends T['length'] ? false : true;
22
22
  declare type TupleKey<T extends ReadonlyArray<any>> = Exclude<keyof T, keyof any[]>;
23
23
  declare type ArrayKey = number;
24
- declare type PathImpl<K extends string | number, V> = V extends Primitive ? `${K}` : `${K}` | `${K}.${Path<V>}`;
24
+ declare type PathImpl<K extends string | number, V> = V extends ReadonlyArray<any> | Record<any, unknown> ? `${K}` | `${K}.${Path<V>}` : `${K}`;
25
25
  export declare type Path<T> = T extends ReadonlyArray<infer V> ? IsTuple<T> extends true ? {
26
26
  [K in TupleKey<T>]-?: PathImpl<K & string, T[K]>;
27
27
  }[TupleKey<T>] : PathImpl<ArrayKey, V> : {
28
28
  [K in keyof T]-?: PathImpl<K & string, T[K]>;
29
29
  }[keyof T];
30
30
  export declare type FieldPath<TFieldValues extends FieldValues> = Path<TFieldValues>;
31
- 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>}`;
31
+ declare type ArrayPathImpl<K extends string | number, V> = IsAny<V> extends true ? `${K}` | `${K}.${ArrayPath<V>}` : V extends ReadonlyArray<infer U> ? U extends ReadonlyArray<any> | Record<any, unknown> ? `${K}` | `${K}.${ArrayPath<V>}` : never : V extends Record<any, unknown> ? `${K}.${ArrayPath<V>}` : never;
32
32
  export declare type ArrayPath<T> = T extends ReadonlyArray<infer V> ? IsTuple<T> extends true ? {
33
33
  [K in TupleKey<T>]-?: ArrayPathImpl<K & string, T[K]>;
34
34
  }[TupleKey<T>] : ArrayPathImpl<ArrayKey, V> : {
@@ -0,0 +1,8 @@
1
+ import { SubjectType } from './utils/Subject';
2
+ declare type Props<T> = {
3
+ disabled?: boolean;
4
+ subject?: SubjectType<T>;
5
+ callback: (value: T) => void;
6
+ };
7
+ export declare function useSubscribe<T>({ disabled, subject, callback }: Props<T>): void;
8
+ export {};
@@ -1,12 +1,13 @@
1
1
  export declare type Observer<T> = {
2
2
  next: (value: T) => void;
3
3
  };
4
- declare type TearDown = () => void;
4
+ export declare type TearDown = () => void;
5
5
  export declare type SubjectType<T> = {
6
6
  next: (value: T) => void;
7
7
  subscribe: (value: Observer<T>) => {
8
8
  unsubscribe: TearDown;
9
9
  };
10
+ unsubscribe: () => void;
10
11
  };
11
12
  export declare class Subscription {
12
13
  private tearDowns;
@@ -20,4 +21,3 @@ export default class Subject<T> {
20
21
  subscribe(observer: Observer<T>): Subscription;
21
22
  unsubscribe(): void;
22
23
  }
23
- export {};
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.16.0",
4
+ "version": "7.17.1",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.esm.js",
7
7
  "umd:main": "dist/index.umd.js",
@@ -67,44 +67,44 @@
67
67
  "license": "MIT",
68
68
  "devDependencies": {
69
69
  "@rollup/plugin-commonjs": "^20.0.0",
70
- "@rollup/plugin-node-resolve": "^13.0.2",
70
+ "@rollup/plugin-node-resolve": "^13.0.5",
71
71
  "@testing-library/jest-dom": "^5.14.1",
72
- "@testing-library/react": "^12.0.0",
72
+ "@testing-library/react": "^12.1.1",
73
73
  "@testing-library/react-hooks": "^7.0.2",
74
74
  "@testing-library/react-native": "^7.2.0",
75
- "@types/jest": "^27.0.1",
76
- "@types/react": "^17.0.20",
77
- "@types/react-native": "^0.65.0",
78
- "@typescript-eslint/eslint-plugin": "^4.31.0",
79
- "@typescript-eslint/parser": "^4.31.0",
75
+ "@types/jest": "^27.0.2",
76
+ "@types/react": "^17.0.26",
77
+ "@types/react-native": "^0.65.2",
78
+ "@typescript-eslint/eslint-plugin": "^4.32.0",
79
+ "@typescript-eslint/parser": "^4.32.0",
80
80
  "@vitejs/plugin-react-refresh": "^1.3.6",
81
- "babel-jest": "^27.1.1",
81
+ "babel-jest": "^27.2.4",
82
82
  "bundlesize": "^0.18.0",
83
- "cypress": "8.3.1",
84
- "cypress-parallel": "^0.3.0",
83
+ "cypress": "8.5.0",
84
+ "cypress-parallel": "^0.5.0",
85
85
  "eslint": "^7.32.0",
86
86
  "eslint-config-prettier": "^8.3.0",
87
- "eslint-plugin-cypress": "^2.11.3",
87
+ "eslint-plugin-cypress": "^2.12.1",
88
88
  "eslint-plugin-prettier": "^4.0.0",
89
- "eslint-plugin-react": "^7.25.1",
89
+ "eslint-plugin-react": "^7.26.1",
90
90
  "eslint-plugin-react-hooks": "^4.2.0",
91
91
  "eslint-plugin-simple-import-sort": "^7.0.0",
92
92
  "husky": "^7.0.2",
93
- "jest": "^27.1.1",
93
+ "jest": "^27.2.4",
94
94
  "lint-staged": "^11.1.2",
95
- "prettier": "^2.4.0",
95
+ "prettier": "^2.4.1",
96
96
  "react": "^17.0.1",
97
97
  "react-dom": "^17.0.1",
98
98
  "react-native": "^0.65.1",
99
99
  "react-test-renderer": "^17.0.1",
100
100
  "rimraf": "^3.0.2",
101
- "rollup": "^2.56.3",
101
+ "rollup": "^2.57.0",
102
102
  "rollup-plugin-peer-deps-external": "^2.2.4",
103
103
  "rollup-plugin-sourcemaps": "^0.6.2",
104
104
  "rollup-plugin-terser": "^7.0.2",
105
105
  "rollup-plugin-typescript2": "^0.30.0",
106
106
  "ts-jest": "^27.0.5",
107
- "typescript": "^4.4.2"
107
+ "typescript": "^4.4.3"
108
108
  },
109
109
  "resolutions": {
110
110
  "react-native/@jest/create-cache-key-function": "^27.0.2"