Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: upgrade react-redux from 5.1.2 to 7.2.6 #2022

Closed

Conversation

snyk-bot
Copy link
Contributor

Snyk has created this PR to upgrade react-redux from 5.1.2 to 7.2.6.

merge advice
ℹ️ 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.


Warning: This is a major version upgrade, and may be a breaking change.

  • The recommended version is 33 versions ahead of your current version.
  • The recommended version was released 3 months ago, on 2021-10-25.
Release notes
Package name: react-redux
  • 7.2.6 - 2021-10-25

    Shameless plug: I'm working on a new company called Spaceship 🚀 It's a tool to launch your code anywhere in one click. Check it out!

    Just a quick fix for a Yarn install warning. Sorry about the noise!

    Changes

    • Remove workspaces from our package.json to silence a Yarn warning (@ timdorr)
  • 7.2.5 - 2021-09-04

    This release shrinks the size of our internal Subscription class, and updates useSelector to avoid an unnecessary selector call on mount.

    Changes

    Subscription Size Refactor

    Our internal Subscription implementation has been written as a class ever since it was added in v5. By rewriting it as a closure factory, we were able to shave a few bytes off the final bundle size.

    useSelector Mount Optimization

    A user noticed that useSelector had never been given an early "bail out if the root state is the same" check to match how connect works. This resulted in a usually-unnecessary second call to the provided selector on mount. We've added that check.

    Entry Point Consolidation

    We've consolidated the list of exported public APIs into a single file, and both the index.js and alternate-renderers.js entry points now re-export everything from that file. No meaningful change here, just shuffling lines of code around for consistency.

    Other Updates

    React-Redux v8 and React 18 Development

    With the announcement of React 18, we've been working with the React team to plan our migration path to keep React-Redux fully compatible with React's upcoming features.

    We've already migrated the React-Redux main development branch to TypeScript, and are prototyping compatibility implementation updates. We'd appreciate any assistance from the community in testing out these changes so that we can ensure React-Redux works great for everyone when React 18 is ready!

    Internal Tooling Updates

    Our master branch now uses Yarn v2 for package management, is built with TypeScript, and we've made CI updates to test against multiple TS versions.

    The 7.x branch has also been updated to use Yarn v2 for consistency.

    These only affect contributors to the React-Redux package itself.

    Changelog

    v7.2.4...v7.2.5

  • 7.2.4 - 2021-04-24

    This release drops our dependency on the core redux package by inlining bindActionCreators, and tweaks useSelector to ensure that selectors aren't run an extra time while re-rendering.

    Changelog

    Redux Dependency Removal

    React-Redux has always imported the bindActionCreators utility from the core redux package for use in connect. However, that meant that we had to have a peer dependency on redux, and this was the only reason we actually required that redux be installed. This became more annoying with the arrival of Redux Toolkit, which has its own dependency on redux internally, and thus users typically saw peer dependency warnings saying that "redux isn't listed as a dependency in your app".

    Code reuse across separate packages is a great thing, but sometimes the right thing to do is duplicate code. So, we've inlined bindActionCreators directly into React-Redux, and we've completely dropped the dependency on Redux. This means that React-Redux will no longer produce a peerDep warning when used with Redux Toolkit, and <Provider> and connect really only need a Redux-store-compatible value to work right.

    useSelector Fixes

    Users reported that useSelector was re-running selector functions again unnecessarily while rendering after a dispatch. We've tweaked the logic to ensure that doesn't happen.

    useSelector also now has checks in development to ensure that selector and equalityFn are functions.

    Changes

    v7.2.3...v7.2.4

  • 7.2.3 - 2021-03-23

    This release improves behavior in useSelector by returning the existing reference if the newly returned selector result passes the equality check, and adds a hard dependency on the @ types/react-redux package to ensure TS users always have the typedefs installed.

    Changes

    useSelector Results Reuse

    Issue #1654 reported that useSelector was returning new references from a selector even if the equality comparison function returned true. This is because the equality check was only ever being performed during the action dispatch process.

    We now run the equality comparison against the value calculated by the selector while rendering, and return the existing reference for consistency if the old and new values are considered equal. This should improve some cases where further derived values where being recalculated unnecessarily.

    TS Types Now Included

    React-Redux has always been written in plain JS, and the typedefs maintained by the community in DefinitelyTyped. We plan on eventually rewriting the library in TypeScript in a future React-Redux v8 release, but until then the types can stay in DT.

    However, having to always manually install @ types/react-redux is annoying, and some users have gotten confused by that. This release adds a hard dependency on @ types/react-redux, so that if you install react-redux, you automatically get the types as well. This should simplify the process for TS users.

    Docs Updates

    We've made several docs updates recently:

    • Renamed "Quick Start" to "Getting Started" and "Static Typing" to "Usage with TypeScript"
    • Dropped the docs API versioning setup, as the legacy API version docs pages were rarely viewed and the versioning setup confused docs contributors
    • Moved the old "Intro > Basic Tutorial" to "Tutorials > Connect" and marked it as semi-obsolete

    We are currently working on a new React-Redux tutorial that will teach the React-Redux hooks as the primary approach, based on the "UI and React" page in the Redux docs "Fundamentals" tutorial.

    Changelog

    v7.2.2...v7.2.3

  • 7.2.2 - 2020-10-26

    This release allows you to use React Redux with React 17 without a warning when installing. That's about it.

    Changes

  • 7.2.1 - 2020-07-25

    This release improves useSelector value display in the React DevTools, fixes a potential race condition, and fixes a couple additional minor issues.

    useSelector DevTools Display

    The React DevTools normally show custom hooks with their inspected name (such as "Selector" for useSelector), and any calls to core hooks inside. This is not always informative, so React has the useDebugValue hook to allow custom hooks to specify what value should be shown instead.

    useSelector now calls useDebugValue to specifically show the current selected value instead of its internal hooks usage.

    Bug Fixes

    This release has a few different bug fixes:

    • A potential race condition when dispatching actions from child components in the commit phase vs selecting data in a parent
    • Removed an excess new object creation when forcing a re-render
    • Our internal prop name for a forwarded ref is now reactReduxForwardedRef to avoid a rare situation where someone else might be passing down a field named forwardedRef
    • Fixed a typo in a useSelector error message

    Changes

    • Fix error message typo in useSelector ('You must pass a selector...). (@ Pixelwelder - #1581)
    • fix useSelector race condition with memoized selector when dispatching in child components useLayoutEffect as well as cDM/cDU (@ dai-shi - #1536)
    • removed a redundant object creation when using forceUpdate (@ vzaidman - #1567)
    • Rename internal forwardedRef usage (@ dtschust - #1553)
    • Show useSelector result in React DevTools (@ Finesse - #1530)
  • 7.2.0 - 2020-02-18
    Read more
  • 7.1.3 - 2019-11-06

    Forgot to remove a console statement before I published 7.1.2. Oops!

    Lint your source code before publishing, folks.

    Changes

  • 7.1.2 - 2019-11-06
    Read more
  • 7.1.2-alpha.0 - 2019-11-05
  • 7.1.1 - 2019-08-26
  • 7.1.0 - 2019-06-11
  • 7.1.0-rc.1 - 2019-05-30
  • 7.1.0-alpha.5 - 2019-05-20
  • 7.1.0-alpha.4 - 2019-05-01
  • 7.1.0-alpha.3 - 2019-04-28
  • 7.1.0-alpha.2 - 2019-04-28
  • 7.1.0-alpha.1 - 2019-04-22
  • 7.1.0-alpha.0 - 2019-04-22
  • 7.0.3 - 2019-04-28
  • 7.0.2 - 2019-04-12
  • 7.0.1 - 2019-04-09
  • 7.0.0 - 2019-04-09
  • 7.0.0-beta.1 - 2019-04-04
  • 7.0.0-beta.0 - 2019-03-22
  • 6.0.1 - 2019-02-20
  • 6.0.0 - 2018-12-05
  • 6.0.0-beta.3 - 2018-11-23
  • 6.0.0-beta.2 - 2018-11-06
  • 6.0.0-beta.1 - 2018-11-06
  • 6.0.0-alpha.ede6245 - 2018-09-20
  • 6.0.0-alpha.2a2f108 - 2018-09-20
  • 6.0.0-alpha.9210282 - 2018-09-20
  • 5.1.2 - 2019-10-08
from react-redux GitHub release notes
Commit messages
Package name: react-redux

Compare


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:

🧐 View latest project report

🛠 Adjust upgrade PR settings

🔕 Ignore this dependency or unsubscribe from future upgrade PRs

@parse-github-assistant
Copy link

I will reformat the title to use the proper commit message syntax.

@parse-github-assistant parse-github-assistant bot changed the title [Snyk] Upgrade react-redux from 5.1.2 to 7.2.6 refactor: upgrade react-redux from 5.1.2 to 7.2.6 Jan 29, 2022
@mtrezza
Copy link
Member

mtrezza commented Mar 23, 2022

Closing, outdated

@mtrezza mtrezza closed this Mar 23, 2022
@mtrezza mtrezza deleted the snyk-upgrade-20770fff3b73df3c6521bd3b3a7680fd branch April 4, 2022 00:50
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.

2 participants