New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@quintoandar/farewell-immutablejs

Package Overview
Dependencies
Maintainers
10
Versions
6
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@quintoandar/farewell-immutablejs

Codemods to replace ImmutableJS library with ES6.

  • 1.2.3
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
10
Created
Source

Farewell ImmutableJS

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.

How to use

# 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.

Features

Drop immutable import

- import { fromJS } from 'immutable';

Remove .fromJS()

- const a = fromJS({ value: 1 });
+ const a = { value: 1 };

Remove .toJS()

- const js = state.toJS();
+ const js = state;

Replace .get()

// 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,
}

Replace .getIn()

// 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;

Replace .set()

// with a literal key
- state.set('a', 10);
+ state.a = 10;
// with a variable key
- state.set(key, 10);
+ state[key] = 10;

Replace .setIn()

- state.setIn(['a', 'b', c, 'd'], 10);
+ state.a.b.c.d = 10;

Replace .merge()

- const newState = state.merge({ a: 10 });
+ const newState = { ...state, a: 10 };

Add deprecation comment

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.

Unsupported methods

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

Contributing

The codemod implementation is based on jscodeshift, so check out their API documentation.

Keywords

FAQs

Package last updated on 22 Jun 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc