Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/reactjs/react-codemod
React codemod scripts
https://github.com/reactjs/react-codemod
Last synced: 4 days ago
JSON representation
React codemod scripts
- Host: GitHub
- URL: https://github.com/reactjs/react-codemod
- Owner: reactjs
- License: mit
- Created: 2015-10-19T20:47:22.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-05-20T21:07:35.000Z (8 months ago)
- Last Synced: 2024-12-31T10:09:52.834Z (11 days ago)
- Language: JavaScript
- Size: 1.04 MB
- Stars: 4,245
- Watchers: 61
- Forks: 290
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-modernization - https://github.com/reactjs/react-codemod
- awesome-codemods - react-codemod - React codemod scripts to update React APIs. (Frameworks / React.js)
- awesome-github-star - react-codemod
- awesome-list - react-codemod
- awesome-jscodeshift - react-codemod - React codemod scripts to update React APIs. (Table of Contents / Codemods)
README
## React Codemods [![Build Status](https://travis-ci.org/reactjs/react-codemod.svg)](https://travis-ci.org/reactjs/react-codemod)
This repository contains a collection of codemods to help update React apps.
All codemods, whether you use the `codemod` CLI command or `react-codemod`, are free and open source, with the source code available in this repository.
### Usage
We recommend using the [`codemod`](https://go.codemod.com/github) command for an enhanced experience and better support.
`npx codemod // --target [...options]`
* `transform` - name of transform, see available transforms below.
* `path` - directory to transformCheck [codemod docs](https://go.codemod.com/cli-docs) for the full list of available commands.
For the legacy `react-codemod` command, see [LEGACY.md](https://github.com/reactjs/react-codemod/blob/master/LEGACY.md).
## Available Codemods
All React codemods are also available in the [Codemod Registry](https://go.codemod.com/react-codemods).
#### `remove-context-provider`
Converts `Context.Provider` JSX opening and closing elements into `Context`.
```sh
npx codemod react/19/remove-context-provider --target
```#### `remove-forward-ref`
Removes usages of `forwardRef`.
```sh
npx codemod react/19/remove-forward-ref --target
```#### `use-context-hook`
Replaces usages of `React.useContext(...)` with `React.use(...)`.
```sh
npx codemod react/19/use-context-hook --target
```#### `replace-act-import`
Updates `act` import path from `react-dom/test-utils` to `react`.
```sh
npx codemod react/19/replace-act-import --target
```#### `replace-string-ref`
Replaces deprecated string refs with callback refs.
```sh
npx codemod react/19/replace-string-ref --target
```#### `replace-use-form-state`
Replaces usages of useFormState() to use useActionState().
```sh
npx codemod react/19/replace-use-form-state --target
```#### `replace-reactdom-render`
Replaces usages of ReactDom.render() with createRoot(node).render().
```sh
npx codemod react/19/replace-reactdom-render --target
```#### `create-element-to-jsx`
Converts calls to `React.createElement` into JSX elements.
```sh
npx codemod react/create-element-to-jsx --target
```#### `error-boundaries`
Renames the experimental `unstable_handleError` lifecycle hook to `componentDidCatch`.
```sh
npx codemod react/error-boundaries --target
```#### `findDOMNode`
Updates `this.getDOMNode()` or `this.refs.foo.getDOMNode()` calls inside of
`React.createClass` components to `React.findDOMNode(foo)`. Note that it will
only look at code inside of `React.createClass` calls and only update calls on
the component instance or its refs. You can use this script to update most calls
to `getDOMNode` and then manually go through the remaining calls.```sh
npx codemod react/findDOMNode --target
```#### `manual-bind-to-arrow`
Converts manual function bindings in a class (e.g., `this.f = this.f.bind(this)`) to arrow property initializer functions (e.g., `f = () => {}`).
```sh
npx codemod react/manual-bind-to-arrow --target
```#### `pure-component`
Converts ES6 classes that only have a render method, only have safe properties
(statics and props), and do not have refs to Functional Components.The wizard will ask for 2 options -
* **Use arrow functions?**: converts to arrow function. Converts to `function` by default.
* **Destructure props?**: will destructure props in the argument where it is safe to do so.```sh
npx codemod react/pure-component --target
```#### `pure-render-mixin`
Removes `PureRenderMixin` and inlines `shouldComponentUpdate` so that the ES2015
class transform can pick up the React component and turn it into an ES2015
class. NOTE: This currently only works if you are using the master version
(>0.13.1) of React as it is using `React.addons.shallowCompare````sh
npx codemod react/pure-render-mixin --target
```* The wizard will ask to optionally override `mixin-name`, and look for it
instead of `PureRenderMixin`. Note that it is not possible to use a
namespaced name for the mixin. `mixins: [React.addons.PureRenderMixin]` will
not currently work.#### `React-PropTypes-to-prop-types`
Replaces `React.PropTypes` references with `prop-types` and adds the appropriate `import` or `require` statement. This codemod is intended for React 15.5+.
```sh
npx codemod react/React-PropTypes-to-prop-types --target
```* In addition to running the above codemod you will also need to install the `prop-types` NPM package.
#### `rename-unsafe-lifecycles`
Adds `UNSAFE_` prefix for deprecated lifecycle hooks. (For more information about this codemod, see [React RFC #6](https://github.com/reactjs/rfcs/pull/6))
```sh
npx codemod react/rename-unsafe-lifecycles --target
```#### `react-to-react-dom`
Updates code for the split of the `react` and `react-dom` packages (e.g.,
`React.render` to `ReactDOM.render`). It looks for `require('react')` and
replaces the appropriate property accesses using `require('react-dom')`. It does
not support ES6 modules or other non-CommonJS systems. We recommend performing
the `findDOMNode` conversion first.```sh
npx codemod react/react-to-react-dom --target
```* After running the automated codemod, you may want to run a regex-based
find-and-replace to remove extra whitespace between the added requires, such
as `codemod.py -m -d src --extensions js '(var
React\s*=\s*require\(.react.\);)\n\n(\s*var ReactDOM)' '\1\n\2'` using
https://github.com/facebook/codemod.#### `React-DOM-to-react-dom-factories`
Converts calls like `React.DOM.div(...)` to `React.createElement('div', ...)`.
```sh
npx codemod react/React-DOM-to-react-dom-factories --target
```#### `ReactNative-View-propTypes`
Replaces `View.propTypes` references with `ViewPropTypes` and adds the appropriate `import` or `require` statement. This codemod is intended for ReactNative 44+.
```sh
npx codemod react/ReactNative-View-propTypes --target
```#### `update-react-imports`
[As of Babel 7.9.0](https://babeljs.io/blog/2020/03/16/7.9.0#a-new-jsx-transform-11154-https-githubcom-babel-babel-pull-11154), when using `runtime: automatic` in `@babel/preset-react` or `@babel/plugin-transform-react-jsx`, you will not need to explicitly import React for compiling jsx. This codemod removes the redundant import statements. It also converts default imports (`import React from 'react'`) to named imports (e.g. `import { useState } from 'react'`).
The wizard will ask for 1 option -
* **Destructure namespace imports as well?**: If chosen, *namespace* imports like `import * as React` will *also* be converted. By default, it's false, so only default imports (`import React`) are converted.
```sh
npx codemod react/update-react-imports --target
```## Support and Contributing
The scripts in this repository are maintained by the React team in collaboration with the [Codemod.com](https://codemod.com) team.
If you want to contribute, you're welcome to submit a pull request.
## License
react-codemod is [MIT licensed](./LICENSE).