Codemods to migrate Immutable.js to ES6.
Check out the migration guide for the motivations and step-by-step instructions.
Never heard of codemods? Here is a quick summary from facebook/codemod:
codemod is a tool/library to assist you with large-scale codebase refactors that can be partially automated but still require human oversight and occasional intervention.
# installing globally
npm install -g @quintoandar/farewell-immutablejs
farewell-immutablejs
# or using npx
npx @quintoandar/farewell-immutablejs
Use the --help
flag or refer to the help file.
- import { fromJS } from 'immutable';
- const a = fromJS({ value: 1 });
+ const a = { value: 1 };
- const js = state.toJS();
+ const js = state;
// without default value
- const a = state.get('value');
+ const a = state?.value;
// with default value
- const a = state.get('value', 10);
+ const a = state?.value ?? 10;
// recursive gets are ignored
// for cases like this, run twice
{
- value: state.get('a').get('b'),
+ value: state.get('a')?.b,
}
// without default value
- const a = state.getIn(['b', 'c']);
+ const a = state?.b?.c;
// with default value
- const a = state.getIn(['b', 'c'], 10);
+ const a = state?.b?.c ?? 10;
// with a literal key
- state.set('a', 10);
+ state.a = 10;
// with a variable key
- state.set(key, 10);
+ state[key] = 10;
- state.setIn(['a', 'b', c, 'd'], 10);
+ state.a.b.c.d = 10;
- const newState = state.merge({ a: 10 });
+ const newState = { ...state, a: 10 };
Large codebases might be stuck in a "transitional period" for a considerable amount of time when removing Immutable.
If you have already started to remove it, but are worried about other developers using old code as example and adding the library to new features, consider adding these deprecation messages:
+ // ImmutableJS usage is deprecated
+ // Please, do not copy & paste or use this snippet as reference :)
+ // How to refactor? See https://github.com/quintoandar/farewell-immutablejs/blob/master/MIGRATION.md
import { fromJS } from 'immutable';
Suggestion: skip test files when running this codemod. Most likely, they will be refactored together with the corresponding application code, so it would just generate more clutter.
The methods below have either small cost-benefit to implement a codemod or are too difficult to implement given name collisions.
- contains
- includes
- some
- find
- withMutations
- removeIn
- sortBy
- remove
- first
- last
- add
- mergeIn
- mergeDeep
- update
- updateIn
- map
- filter
- reduce
The codemod implementation is based on jscodeshift, so check out their API documentation.