Skip to content

Conversation

@alhabib5565
Copy link
Owner

snyk-top-banner

Snyk has created this PR to upgrade react-hook-form from 7.52.2 to 7.66.1.

ℹ️ Keep your dependencies up-to-date. This makes it easier to fix existing vulnerabilities and to more quickly identify and fix newly disclosed vulnerabilities when they affect your project.


  • The recommended version is 38 versions ahead of your current version.

  • The recommended version was released 24 days ago.

Release notes
Package name: react-hook-form
  • 7.66.1 - 2025-11-17

    ⚡ perf: reduce redundant property access in getDirtyFields (#13146)
    🐞 fix(createFormControl): skip setValid() during batch array updates (#13140)
    🐞 fix(useForm): recompute isValid after reset when values update asynchronously (#13126)
    🐞 fix(deepEqual): handle NaN comparison correctly using Object.is (#13120)

    thanks to @ kimtaejin3, @ a28689604 & @ WuMingDao

  • 7.66.0 - 2025-10-31

    🎥 feat: make useWatch and useController to react to name change (#13070)
    🐛 fix: watch() returning undefined immediately after reset() - Issue #13088 (#13091)
    🐞 fix <Watch />: correct render function parameter typing (#13108)

    thanks to @ aspirisen, @ scato3, @ dusan233 & @ zoldyzdk

  • 7.65.0 - 2025-10-10

    🧿 feat: <Watch /> component (#12986)

    import { useForm, Watch } from 'react-hook-form';

    const App = () => {
    const { register, control } = useForm();

    return (
    <div>
    <form>
    <input {...register('foo')} />
    <input {...register('bar')} />
    </form>
    {/* re-render only when value of foo changes */}
    <Watch
    control={control}
    names={['foo']}
    render={([foo]) => <span>{foo}</span>}
    />
    </div>
    );
    };

    🐞 fix: respect parent-provided useFieldArray rules (#13082) (#13083
    🐞 fix: getDirtyFields submit fields with null values when using useForm (#13079)

    thanks to @ tesseractjh, @ Han5991 & @ jonathanarnault

  • 7.64.0 - 2025-10-04

    🚏 Support optional array fields in PathValueImpl type (#13057)
    🐞 fix: preserve Controller's defaultValue with shouldUnregister prop (#13063)
    ✂ chore: remove unused field ids ref in useFieldArray (#13066)

    thanks to @ MPrieur-chaps, @ gynekolog & @ uk960214

  • 7.63.0 - 2025-09-19

    🥢 feat: extract form values by form state (#12936)

    getValues(undefined, { dirtyFields: true }); // return only dirty fields 
    getValues(undefined, { touchedFields: true });  // return only touched fields 

    🦍 feat: improve get dirty fields logic (#13049)
    🐿️ chore: remove duplicated function isMessage (#13050)
    🐞 fix: use field name to update isValidating fields (#13000)
    🐞 fix: unregister previous field when switching conditional Controllers (#13041)
    🐞 fix: only excuse trigger function when deps has a valid array (#13056)

    thanks to @ candymask0712, @ GorkemKir, @ kimtaejin3, @ m2na7 & @ abnud11

  • 7.62.0 - 2025-08-01

    👨‍🔧 prevent onBlur for readOnly fields (#12971)
    🐞 fix #12988 sync two defaultValues after reset with new defaultValues (#12990)
    🐞 fix: do not override prototype of data in cloneObject (#12985)
    🐞 fix field name type conflict in nested FieldErrors (#12972)

    thanks to @ candymask0712, @ Adityapradh, @ Ty3uK & @ kichikawa57

  • 7.61.1 - 2025-07-24

    Revert "⌨️ fix: watch return type based on defaultValue (#12896)"

  • 7.61.0 - 2025-07-23

    🧮 feat: compute prop for useWatch subscription (#12503)

    • subscribe to the entire form but only return updated value with certain condition
    type FormValue = {
    test: string;
    }

    const watchedValue = useWatch({
    control: methods.control,
    compute: (data: FormValue) => {
    if (data.test?.length) {
    return data.test;
    }

    <span class="pl-k">return</span> <span class="pl-s">''</span><span class="pl-kos">;</span>
    

    },
    });

    • subscribe to a specific form value state
    type FormValue = {
    test: string;
    }

    const watchedValue = useWatch({
    control: methods.control,
    name: 'test',
    compute: (data: string) => {
    return data.length > 3 ? data : '';
    },
    });

    👨‍🔧 trigger watch callbacks in response to value changes only (#12945)
    🙏 track name with setValue subscription callbacks (#12946)
    ⌨️ fix: watch return type based on defaultValue (#12896)
    🐞 fix #12959 subscribe with latest defaultValues #12961
    🐞 fix: handle explicit "multipart/form-data" encType in Form Component (#12948)
    🐞 fix(build): Remove React wildcard import to resolve ESM build issues (#12942)
    🦭 chore: improve exclude patterns (#12935)
    🐿️ chore: remove unused omit function (#12958)

    Big thanks to @ joshkel for helping with some of the subscription bugs! and also @ kamja44, @ mrazauskas, @ codepunkt, @ afontcu and @ rururux

  • 7.60.0 - 2025-07-04

    🦘 feat: reset new keepFieldsRef options keep fields reference (#12923)

    // This option will skip input reference gets reset and avoid re-register input reference after reset
    reset(data, { keepFieldsRef: true })
  • 7.60.0-next.0 - 2025-07-01
  • 7.59.0 - 2025-06-28
  • 7.58.1 - 2025-06-17
  • 7.58.0 - 2025-06-15
  • 7.57.0 - 2025-06-01
  • 7.57.0-next.0 - 2025-04-27
  • 7.56.4 - 2025-05-17
  • 7.56.3 - 2025-05-07
  • 7.56.2 - 2025-05-03
  • 7.56.1 - 2025-04-22
  • 7.56.0 - 2025-04-20
  • 7.56.0-next.0 - 2025-04-13
  • 7.55.0 - 2025-03-28
  • 7.55.0-next.9 - 2025-03-17
  • 7.55.0-next.8 - 2025-03-13
  • 7.55.0-next.7 - 2025-03-07
  • 7.55.0-next.6 - 2025-03-05
  • 7.55.0-next.5 - 2025-02-22
  • 7.55.0-next.4 - 2025-02-08
  • 7.55.0-next.3 - 2025-01-25
  • 7.55.0-next.2 - 2025-01-18
  • 7.55.0-next.1 - 2024-12-27
  • 7.55.0-next.0 - 2024-12-24
  • 7.54.2 - 2024-12-20
  • 7.54.1 - 2024-12-12
  • 7.54.0 - 2024-12-06
  • 7.53.2 - 2024-11-08
  • 7.53.1 - 2024-10-19
  • 7.53.0 - 2024-08-24
  • 7.52.2 - 2024-08-03
from react-hook-form GitHub release notes

Important

  • Check the changes in this PR to ensure they won't cause issues with your project.
  • This PR was automatically created by Snyk using the credentials of a real user.

Note: You are seeing this because you or someone else with access to this repository has authorized Snyk to open upgrade PRs.

For more information:

Snyk has created this PR to upgrade react-hook-form from 7.52.2 to 7.66.1.

See this package in npm:
react-hook-form

See this project in Snyk:
https://app.snyk.io/org/alhabib5565/project/3dd92d27-19c2-411e-beb4-689609b8f4d0?utm_source=github&utm_medium=referral&page=upgrade-pr
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants