ReactHookify
React Hookify is a command line tool that converts React class components into functional components with Hooks!
Documentation (with testing playground): https://react-hookify.herokuapp.com/
It will not alter your current file; instead, a new 'hookified' file is created next to your original.
Setup
npm install -g react-hookify
Usage
hookify <filepath(s) of class component>
- Examples:
hookify client/app.js
hookify app.js
hookify app1.js app2.js
- Look for your new 'hookified' file in the same directory as your class component file!
Limitations
- React Hooks cannot always map 1 to 1 with lifecycle components. Less complex lifecycle components should work fine with React Hookify. In more complex cases, code my have to be rewritten
- Currently, the only supported lifecycle methods are componentDidMount, componentDidUpdate, and componentWillUnmount
- React Hookify does not support replacing the whole state with a new object or using the whole state at once. There is not an exact hook equivalent. For example, replacing the whole state using
this.setState(newObject)
will not be able to be translated - React Hookify will not be able to translate instances where variable names come from other files. The package is built with parsing logic that looks for variable patterns. This may come up when using controlled forms.
- If you try to implement a controlled form, but the actual form component is in a different file, React Hookify would not be able to identify the needed form names and values.
- Any comments in the original file will be removed in the 'hookified file'
- React Hookify does not currently support 'get', 'set', and 'static' keywords
- React Hookify cannot currently translate any JSX with unclosed parentheses. So no smiley/frowney faces
:) or :(
sorry!