Awesome-copilot react18-dep-compatibility

React 18.3.1 and React 19 dependency compatibility matrix.

install
source · Clone the upstream repo
git clone https://github.com/github/awesome-copilot
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/github/awesome-copilot "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/react18-upgrade/skills/react18-dep-compatibility" ~/.claude/skills/github-awesome-copilot-react18-dep-compatibility && rm -rf "$T"
manifest: plugins/react18-upgrade/skills/react18-dep-compatibility/SKILL.md
source content

React Dependency Compatibility Matrix

Minimum versions required for React 18.3.1 and React 19 compatibility.

Use this skill whenever checking whether a dependency supports a target React version, resolving peer dependency conflicts, deciding whether to upgrade or use

legacy-peer-deps
, or assessing the risk of a
react-router
v5 to v6 migration.

Review this matrix before running

npm install
during a React upgrade and before accepting an npm dependency conflict resolution, especially where concurrent mode compatibility may be affected.

Core Upgrade Targets

PackageReact 17 (current)React 18.3.1 (min)React 19 (min)Notes
react
17.x18.3.119.0.0Pin exactly to 18.3.1 for the R18 orchestra
react-dom
17.x18.3.119.0.0Must match react version exactly

Testing Libraries

PackageReact 18 MinReact 19 MinNotes
@testing-library/react
14.0.016.0.0RTL 13 uses ReactDOM.render internally - broken in R18
@testing-library/jest-dom
6.0.06.0.0v5 works but v6 has React 18 matcher updates
@testing-library/user-event
14.0.014.0.0v13 is sync, v14 is async - API change required
jest
27.x27.xjest 27+ with jsdom 16+ for React 18
jest-environment-jsdom
27.x27.xMust match jest version

Apollo Client

PackageReact 18 MinReact 19 MinNotes
@apollo/client
3.8.03.11.03.8 adds
useSyncExternalStore
for concurrent mode
graphql
15.x16.xApollo 3.8+ peer requires graphql 15 or 16

Read

references/apollo-details.md
for concurrent mode issues and MockedProvider changes.

Emotion

PackageReact 18 MinReact 19 MinNotes
@emotion/react
11.10.011.13.011.10 adds React 18 concurrent mode support
@emotion/styled
11.10.011.13.0Must match @emotion/react version
@emotion/cache
11.10.011.13.0If used directly

React Router

PackageReact 18 MinReact 19 MinNotes
react-router-dom
v6.0.0v6.8.0v5 → v6 is a breaking migration - see details below
react-router-dom
v5
5.3.4 (workaround)❌ Not supportedSee legacy peer deps note

react-router v5 → v6 is a SEPARATE migration sprint. Read

references/router-migration.md
.

Redux

PackageReact 18 MinReact 19 MinNotes
react-redux
8.0.09.0.0v7 works on R18 legacy root only - breaks on concurrent mode
redux
4.x5.xRedux itself is framework-agnostic - react-redux version matters
@reduxjs/toolkit
1.9.02.0.0RTK 1.9 tested against React 18

Other Common Packages

PackageReact 18 MinReact 19 MinNotes
react-query
/
@tanstack/react-query
4.0.05.0.0v3 doesn't support concurrent mode
react-hook-form
7.0.07.43.0v6 has concurrent mode issues
formik
2.2.92.4.0v2.2.9 patched for React 18
react-select
5.0.05.8.0v4 has peer dep conflicts with R18
react-datepicker
4.8.06.0.0v4.8+ added React 18 support
react-dnd
16.0.016.0.0v15 and below have R18 concurrent mode issues
prop-types
anyanyStandalone - unaffected by React version

Conflict Resolution Decision Tree

npm ls shows peer conflict for package X
         │
         ▼
Does package X have a version that supports React 18?
  YES → npm install X@[min-compatible-version]
  NO  ↓
         │
Is the package critical to the app?
  YES → check GitHub issues for React 18 branch/fork
      → check if maintainer has a PR open
      → last resort: --legacy-peer-deps (document why)
  NO  → consider removing the package

--legacy-peer-deps Rules

Only use

--legacy-peer-deps
when:

  • The package has no React 18 compatible release
  • The package is actively maintained (not abandoned)
  • The conflict is only a peer dep declaration mismatch (not actual API incompatibility)

Document every

--legacy-peer-deps
usage in a comment at the top of package.json or in a MIGRATION.md file explaining why it was necessary.