/react-router-codemod

upgrade react-router v5 to v6

Primary LanguageTypeScript

React-Router v6 Codemod

A collection of codemod scripts that help upgrade react-router v6 using jscodeshift.(Inspired by react-codemod)

NPM version NPM downloads

Usage

Before run codemod scripts, you'd better make sure to commit your local git changes firstly.

# global installation
npm i -g react-router-codemod
# or for yarn user
#  yarn global add react-router-codemod
react-router-codemod

# use npx
npx react-router-codemod

Codemod scripts introduction

useHistory_to_useNavigate

Replace deprecated useHistory:

- import { useHistory } from "react-router-dom";
+ import { useNavigate } from "react-router-dom";
  import React from "react";

  function App() {
- const history = useHistory();
+ const navigate = useNavigate();

  return (
    <>
-     <button onClick={() => history.replace("/name", { id: 123 })}>replace</button>
+     <button onClick={() => navigate("/name", {
+         replace: true,
+         state: { id: 123 }
+      })}>replace</button>
-     <button onClick={() => history.goForward()}>Go forward</button>
+     <button onClick={() => navigate(1)}>Go forward</button>
-     <button onClick={() => history.push("/user")}>push</button>
+     <button onClick={() => navigate("/user")}>push</button>
-     <button onClick={() => history.push("/user", { id: 13 })}>push state</button>
+     <button onClick={() => navigate("/user", {
+        state: { id: 13 }
+     })}>push state</button>
    </>
  );
}

It don't resolve the second reference,it will add some comments fixme for helping user to fix

License

MIT