react-hook-form 8.0.0-beta.0 → 8.0.0-beta.2

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.
Files changed (55) hide show
  1. package/README.md +16 -29
  2. package/dist/constants.d.ts +5 -0
  3. package/dist/constants.d.ts.map +1 -1
  4. package/dist/form.d.ts.map +1 -1
  5. package/dist/index.cjs.js +1 -1
  6. package/dist/index.cjs.js.map +1 -1
  7. package/dist/index.esm.mjs +541 -217
  8. package/dist/index.esm.mjs.map +1 -1
  9. package/dist/index.umd.js +1 -1
  10. package/dist/index.umd.js.map +1 -1
  11. package/dist/logic/createFormControl.d.ts +13 -0
  12. package/dist/logic/createFormControl.d.ts.map +1 -1
  13. package/dist/logic/getDirtyFields.d.ts.map +1 -1
  14. package/dist/logic/{isNameInFieldArray.d.ts → getFieldArrayParentNames.d.ts} +2 -2
  15. package/dist/logic/getFieldArrayParentNames.d.ts.map +1 -0
  16. package/dist/logic/getProxyFormState.d.ts.map +1 -1
  17. package/dist/logic/getResolverOptions.d.ts +2 -2
  18. package/dist/logic/hasValidation.d.ts +1 -1
  19. package/dist/logic/shouldRenderFormState.d.ts.map +1 -1
  20. package/dist/logic/updateFieldArrayRootError.d.ts.map +1 -1
  21. package/dist/logic/validateField.d.ts.map +1 -1
  22. package/dist/react-server.esm.mjs +362 -92
  23. package/dist/react-server.esm.mjs.map +1 -1
  24. package/dist/types/errors.d.ts +1 -0
  25. package/dist/types/errors.d.ts.map +1 -1
  26. package/dist/types/fieldArray.d.ts +1 -2
  27. package/dist/types/fieldArray.d.ts.map +1 -1
  28. package/dist/types/form.d.ts +14 -41
  29. package/dist/types/form.d.ts.map +1 -1
  30. package/dist/types/index.d.ts +1 -0
  31. package/dist/types/index.d.ts.map +1 -1
  32. package/dist/types/path/eager.d.ts +1 -1
  33. package/dist/types/path/eager.d.ts.map +1 -1
  34. package/dist/types/utils.d.ts +5 -4
  35. package/dist/types/utils.d.ts.map +1 -1
  36. package/dist/types/validator.d.ts +13 -1
  37. package/dist/types/validator.d.ts.map +1 -1
  38. package/dist/types/watch.d.ts +32 -0
  39. package/dist/types/watch.d.ts.map +1 -0
  40. package/dist/useController.d.ts.map +1 -1
  41. package/dist/useFieldArray.d.ts +2 -2
  42. package/dist/useFieldArray.d.ts.map +1 -1
  43. package/dist/useForm.d.ts.map +1 -1
  44. package/dist/useFormContext.d.ts.map +1 -1
  45. package/dist/useFormControlContext.d.ts +12 -0
  46. package/dist/useFormControlContext.d.ts.map +1 -0
  47. package/dist/useFormState.d.ts.map +1 -1
  48. package/dist/useWatch.d.ts.map +1 -1
  49. package/dist/utils/deepEqual.d.ts +1 -1
  50. package/dist/utils/deepEqual.d.ts.map +1 -1
  51. package/dist/utils/unset.d.ts.map +1 -1
  52. package/dist/watch.d.ts +7 -17
  53. package/dist/watch.d.ts.map +1 -1
  54. package/package.json +29 -29
  55. package/dist/logic/isNameInFieldArray.d.ts.map +0 -1
package/dist/watch.d.ts CHANGED
@@ -1,22 +1,13 @@
1
- import { type ReactNode } from 'react';
2
- import type { Control, FieldPath, FieldPathValue, FieldValues } from './types';
3
- type GetValues<TFieldValues extends FieldValues, TFieldNames extends readonly FieldPath<TFieldValues>[] = readonly []> = TFieldNames extends readonly [
4
- infer Name extends FieldPath<TFieldValues>,
5
- ...infer RestFieldNames
6
- ] ? RestFieldNames extends readonly FieldPath<TFieldValues>[] ? readonly [
7
- FieldPathValue<TFieldValues, Name>,
8
- ...GetValues<TFieldValues, RestFieldNames>
9
- ] : never : TFieldNames extends readonly [infer Name extends FieldPath<TFieldValues>] ? readonly [FieldPathValue<TFieldValues, Name>] : TFieldNames extends readonly [] ? readonly [] : never;
10
- export type WatchProps<TFieldNames extends readonly FieldPath<TFieldValues>[], TFieldValues extends FieldValues = FieldValues, TContext = any, TTransformedValues = TFieldValues> = {
11
- control: Control<TFieldValues, TContext, TTransformedValues>;
12
- names: TFieldNames;
13
- render: (values: GetValues<TFieldValues, TFieldNames>) => ReactNode;
14
- };
1
+ import type { FieldPath, FieldValues, WatchProps } from './types';
15
2
  /**
16
3
  * Watch component that subscribes to form field changes and re-renders when watched fields update.
17
4
  *
18
5
  * @param control - The form control object from useForm
19
- * @param names - Array of field names to watch for changes
6
+ * @param name - Can be field name, array of field names, or undefined to watch the entire form
7
+ * @param disabled - Disable subscription
8
+ * @param exact - Whether to watch exact field names or not
9
+ * @param defaultValue - The default value to use if the field is not yet set
10
+ * @param compute - Function to compute derived values from watched fields
20
11
  * @param render - The function that receives watched values and returns ReactNode
21
12
  * @returns The result of calling render function with watched values
22
13
  *
@@ -34,6 +25,5 @@ export type WatchProps<TFieldNames extends readonly FieldPath<TFieldValues>[], T
34
25
  * />
35
26
  * ```
36
27
  */
37
- export declare const Watch: <const TFieldNames extends readonly FieldPath<TFieldValues>[], TFieldValues extends FieldValues = FieldValues, TContext = any, TTransformedValues = TFieldValues>({ control, names, render, }: WatchProps<TFieldNames, TFieldValues, TContext, TTransformedValues>) => ReactNode;
38
- export {};
28
+ export declare const Watch: <TFieldValues extends FieldValues = FieldValues, TFieldName extends FieldPath<TFieldValues> | readonly [FieldPath<TFieldValues>, ...FieldPath<TFieldValues>[]] | FieldPath<TFieldValues>[] | readonly FieldPath<TFieldValues>[] | undefined = undefined, TContext = any, TTransformedValues = TFieldValues, TComputeValue = undefined>(props: WatchProps<TFieldName, TFieldValues, TContext, TTransformedValues, TComputeValue>) => import("react").ReactNode | import("react").ReactNode[];
39
29
  //# sourceMappingURL=watch.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"watch.d.ts","sourceRoot":"","sources":["../src/watch.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG/E,KAAK,SAAS,CACZ,YAAY,SAAS,WAAW,EAChC,WAAW,SAAS,SAAS,SAAS,CAAC,YAAY,CAAC,EAAE,GAAG,SAAS,EAAE,IAClE,WAAW,SAAS,SAAS;IAC/B,MAAM,IAAI,SAAS,SAAS,CAAC,YAAY,CAAC;IAC1C,GAAG,MAAM,cAAc;CACxB,GACG,cAAc,SAAS,SAAS,SAAS,CAAC,YAAY,CAAC,EAAE,GACvD,SAAS;IACP,cAAc,CAAC,YAAY,EAAE,IAAI,CAAC;IAClC,GAAG,SAAS,CAAC,YAAY,EAAE,cAAc,CAAC;CAC3C,GACD,KAAK,GACP,WAAW,SAAS,SAAS,CAAC,MAAM,IAAI,SAAS,SAAS,CAAC,YAAY,CAAC,CAAC,GACvE,SAAS,CAAC,cAAc,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,GAC7C,WAAW,SAAS,SAAS,EAAE,GAC7B,SAAS,EAAE,GACX,KAAK,CAAC;AAEd,MAAM,MAAM,UAAU,CACpB,WAAW,SAAS,SAAS,SAAS,CAAC,YAAY,CAAC,EAAE,EACtD,YAAY,SAAS,WAAW,GAAG,WAAW,EAC9C,QAAQ,GAAG,GAAG,EACd,kBAAkB,GAAG,YAAY,IAC/B;IACF,OAAO,EAAE,OAAO,CAAC,YAAY,EAAE,QAAQ,EAAE,kBAAkB,CAAC,CAAC;IAC7D,KAAK,EAAE,WAAW,CAAC;IACnB,MAAM,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC,KAAK,SAAS,CAAC;CACrE,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,eAAO,MAAM,KAAK,GAChB,KAAK,CAAC,WAAW,SAAS,SAAS,SAAS,CAAC,YAAY,CAAC,EAAE,EAC5D,YAAY,SAAS,WAAW,GAAG,WAAW,EAC9C,QAAQ,GAAG,GAAG,EACd,kBAAkB,GAAG,YAAY,EACjC,6BAIC,UAAU,CAAC,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,kBAAkB,CAAC,cAGnE,CAAC"}
1
+ {"version":3,"file":"watch.d.ts","sourceRoot":"","sources":["../src/watch.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EACT,WAAW,EACX,UAAU,EAEX,MAAM,SAAS,CAAC;AAGjB;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,eAAO,MAAM,KAAK,GAChB,YAAY,SAAS,WAAW,GAAG,WAAW,EAC9C,UAAU,SACN,SAAS,CAAC,YAAY,CAAC,GACvB,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,GAAG,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,GAChE,SAAS,CAAC,YAAY,CAAC,EAAE,GACzB,SAAS,SAAS,CAAC,YAAY,CAAC,EAAE,GAClC,SAAS,GAAG,SAAS,EACzB,QAAQ,GAAG,GAAG,EACd,kBAAkB,GAAG,YAAY,EACjC,aAAa,GAAG,SAAS,EAEzB,OAAO,UAAU,CACf,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,kBAAkB,EAClB,aAAa,CACd,4DAQA,CAAC"}
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": "8.0.0-beta.0",
4
+ "version": "8.0.0-beta.2",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.esm.mjs",
7
7
  "umd:main": "dist/index.umd.js",
@@ -33,16 +33,16 @@
33
33
  "build:modern": "rollup --bundleConfigAsCjs -c ./scripts/rollup/rollup.config.js",
34
34
  "build:esm": "rollup --bundleConfigAsCjs -c ./scripts/rollup/rollup.esm.config.js",
35
35
  "prettier:fix": "prettier --config .prettierrc --write .",
36
- "lint": "eslint '**/*.{js,ts,tsx}' --cache",
36
+ "lint": "eslint . --cache",
37
37
  "lint:fix": "pnpm lint --fix",
38
38
  "type": "tsc --noEmit",
39
39
  "jest-preview": "jest-preview",
40
40
  "test": "jest --config ./scripts/jest/jest.config.js",
41
41
  "test:react-compiler": "jest --config ./scripts/jest/jest-react-compiler.config.js --onlyChanged --watch",
42
- "test:coverage": "pnpm test -- --coverage",
43
- "test:watch": "pnpm test -- --onlyChanged --watch",
42
+ "test:coverage": "pnpm test --coverage",
43
+ "test:watch": "pnpm test --onlyChanged --watch",
44
44
  "test:web": "TEST_ENV=web pnpm test",
45
- "test:type": "tsd src/__typetest__",
45
+ "test:type": "tsc -p src/__typetest__/tsconfig.json",
46
46
  "e2e": "cypress run",
47
47
  "e2e:watch": "cypress open",
48
48
  "api-extractor": "api-extractor run --local",
@@ -73,7 +73,7 @@
73
73
  "license": "MIT",
74
74
  "devDependencies": {
75
75
  "@eslint/compat": "^1.4.1",
76
- "@microsoft/api-extractor": "^7.53.3",
76
+ "@microsoft/api-extractor": "^7.57.7",
77
77
  "@rollup/plugin-commonjs": "^28.0.9",
78
78
  "@rollup/plugin-node-resolve": "^16.0.3",
79
79
  "@babel/preset-env": "^7.25.7",
@@ -81,46 +81,46 @@
81
81
  "@babel/preset-typescript": "^7.25.7",
82
82
  "react-compiler-runtime": "^1.0.0",
83
83
  "@rollup/plugin-terser": "^0.4.4",
84
- "@swc/core": "^1.14.0",
84
+ "@swc/core": "^1.15.18",
85
85
  "@swc/jest": "^0.2.39",
86
86
  "@testing-library/jest-dom": "^6.9.1",
87
- "@testing-library/react": "^16.3.0",
87
+ "@testing-library/react": "^16.3.2",
88
88
  "@types/jest": "^30.0.0",
89
- "@types/react": "^19.2.2",
90
- "@types/react-dom": "^19.2.2",
89
+ "@types/node": "^25.5.0",
90
+ "@types/react": "^19.2.14",
91
+ "@types/react-dom": "^19.2.3",
91
92
  "bundlewatch": "^0.4.1",
92
- "cypress": "^15.5.0",
93
- "eslint": "^9.39.0",
93
+ "cypress": "^15.14.1",
94
+ "eslint": "^9.39.4",
94
95
  "eslint-config-prettier": "^10.1.8",
95
- "eslint-plugin-cypress": "^5.2.0",
96
- "eslint-plugin-prettier": "^5.5.4",
97
- "babel-plugin-react-compiler": "^1.0.0",
96
+ "eslint-plugin-cypress": "^5.3.0",
97
+ "eslint-plugin-prettier": "^5.5.5",
98
98
  "eslint-plugin-react": "^7.37.5",
99
99
  "eslint-plugin-react-hooks": "^7.0.1",
100
100
  "eslint-plugin-simple-import-sort": "^12.1.1",
101
101
  "husky": "^9.1.7",
102
- "jest": "^30.2.0",
103
- "jest-environment-jsdom": "^30.2.0",
102
+ "jest": "^30.3.0",
103
+ "jest-environment-jsdom": "^30.3.0",
104
104
  "jest-fixed-jsdom": "^0.0.10",
105
- "jest-preview": "^0.3.2",
106
- "lint-staged": "^16.2.6",
107
- "prettier": "^3.6.2",
108
- "react": "^19.2.1",
109
- "react-dom": "^19.2.1",
110
- "rimraf": "^6.1.0",
111
- "rollup": "^4.52.5",
105
+ "jest-preview": "^0.3.3",
106
+ "lint-staged": "^16.4.0",
107
+ "prettier": "^3.8.1",
108
+ "react": "^19.2.4",
109
+ "react-dom": "^19.2.4",
110
+ "rimraf": "^6.1.3",
111
+ "rollup": "^4.60.0",
112
112
  "rollup-plugin-typescript2": "^0.36.0",
113
- "tsd": "^0.33.0",
114
- "typescript": "^5.9.3",
115
- "typescript-eslint": "^8.46.2",
113
+ "typescript": "^6.0.2",
114
+ "typescript-eslint": "^8.57.1",
116
115
  "whatwg-fetch": "^3.6.20",
117
- "zod": "^3.25.76"
116
+ "zod": "^3.25.76",
117
+ "babel-plugin-react-compiler": "^1.0.0"
118
118
  },
119
119
  "bundlewatch": {
120
120
  "files": [
121
121
  {
122
122
  "path": "./dist/index.cjs.js",
123
- "maxSize": "12.0 kB"
123
+ "maxSize": "12.5 kB"
124
124
  }
125
125
  ]
126
126
  },
@@ -1 +0,0 @@
1
- {"version":3,"file":"isNameInFieldArray.d.ts","sourceRoot":"","sources":["../../src/logic/isNameInFieldArray.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;yBAIlC,OAAO,GAAG,CAAC,iBAAiB,CAAC,EAAE,MAAM,iBAAiB;AAAtE,wBACqC"}