@graphcommerce/react-hook-form 3.2.1 → 3.3.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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,23 @@
1
1
  # Change Log
2
2
 
3
+ ## 3.3.1
4
+
5
+ ### Patch Changes
6
+
7
+ - [#1553](https://github.com/graphcommerce-org/graphcommerce/pull/1553) [`4a4579bb2`](https://github.com/graphcommerce-org/graphcommerce/commit/4a4579bb2f7da378f3fcc504405caf2560dc10f6) Thanks [@NickdeK](https://github.com/NickdeK)! - When using a useFormGqlMutation or useFormGqlQuery and defaultValues change, the form values will update for fields that aren't dirty.
8
+
9
+ ## 3.3.0
10
+
11
+ ### Minor Changes
12
+
13
+ - [#1544](https://github.com/graphcommerce-org/graphcommerce/pull/1544) [`5f927ebdc`](https://github.com/graphcommerce-org/graphcommerce/commit/5f927ebdc6f0331833e02b96e4f169bfe475ac6b) Thanks [@mikekeehnen](https://github.com/mikekeehnen)! - Fixed hydration errors on account, cart and wishlist
14
+
15
+ ## 3.2.2
16
+
17
+ ### Patch Changes
18
+
19
+ - [#1490](https://github.com/graphcommerce-org/graphcommerce/pull/1490) [`d311ef48b`](https://github.com/graphcommerce-org/graphcommerce/commit/d311ef48bb3e97806d992af5516d6b7f183ec9cb) Thanks [@paales](https://github.com/paales)! - upgraded packages
20
+
3
21
  ## 3.2.1
4
22
 
5
23
  ### Patch Changes
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@graphcommerce/react-hook-form",
3
3
  "homepage": "https://www.graphcommerce.org/",
4
4
  "repository": "github:graphcommerce-org/graphcommerce",
5
- "version": "3.2.1",
5
+ "version": "3.3.1",
6
6
  "sideEffects": false,
7
7
  "prettier": "@graphcommerce/prettier-config-pwa",
8
8
  "eslintConfig": {
@@ -12,19 +12,19 @@
12
12
  }
13
13
  },
14
14
  "devDependencies": {
15
- "@graphcommerce/eslint-config-pwa": "^4.1.7",
15
+ "@graphcommerce/eslint-config-pwa": "^4.1.8",
16
16
  "@graphcommerce/prettier-config-pwa": "^4.0.6",
17
17
  "@graphcommerce/typescript-config-pwa": "^4.0.3",
18
18
  "@playwright/test": "^1.21.1",
19
19
  "type-fest": "^2.12.2"
20
20
  },
21
21
  "dependencies": {
22
- "@apollo/client": "^3.6.0",
23
- "graphql": "16.4.0",
24
- "react-hook-form": "7.30.0"
22
+ "@apollo/client": "^3.6.9",
23
+ "graphql": "16.5.0",
24
+ "react-hook-form": "7.32.0"
25
25
  },
26
26
  "peerDependencies": {
27
- "react": "^17.0.2",
28
- "react-dom": "^17.0.2"
27
+ "react": "^18.0.0",
28
+ "react-dom": "^18.0.0"
29
29
  }
30
30
  }
@@ -7,6 +7,7 @@ import {
7
7
  ApolloError,
8
8
  LazyQueryResultTuple,
9
9
  } from '@apollo/client'
10
+ import { useEffect, useRef } from 'react'
10
11
  import { UseFormProps, UseFormReturn, UnpackNestedValue, DeepPartial } from 'react-hook-form'
11
12
  import diff from './diff'
12
13
  import { useGqlDocumentHandler, UseGqlDocumentHandler } from './useGqlDocumentHandler'
@@ -51,6 +52,18 @@ export function useFormGql<Q, V>(
51
52
  const [execute, { data, error }] = tuple
52
53
  const client = useApolloClient()
53
54
 
55
+ // automatically updates the default values
56
+ const initital = useRef(true)
57
+ const valuesString = JSON.stringify(defaultValues)
58
+ useEffect(() => {
59
+ if (initital.current) {
60
+ initital.current = false
61
+ return
62
+ }
63
+ form.reset(defaultValues, { keepDirtyValues: true })
64
+ // eslint-disable-next-line react-hooks/exhaustive-deps
65
+ }, [valuesString, form])
66
+
54
67
  const handleSubmit: UseFormReturn<V>['handleSubmit'] = (onValid, onInvalid) =>
55
68
  form.handleSubmit(async (formValues, event) => {
56
69
  // Combine defaults with the formValues and encode