import-reorder v1.2.1
import-reorder
Re-orders imports in JavaScript and TypeScript files, in-place. Usable with ES6-style import, as well as Node-style require. Handles multi-line imports, as well as interspersed comments.
Important Notes
- Requires use of semicolons.
- Comments associated with imports must be placed above their associated imports, NOT to the right of their imports on the same line; otherwise, they will be associated with the next statement.
What
Alphabetizes members.
import { fnB , fnC, fnA } from 'some-source';becomes:
import { fnA, fnB , fnC } from 'some-source';Alphabetizes imports.
import { fnD , fnF, fnE } from 'some-module';
import { fnB , fnC, fnA } from 'some-source';becomes:
import { fnA , fnB, fnC } from 'some-source';
import { fnD , fnE, fnF } from 'some-module';Groups related imports.
Example, grouped by /vendor/ and /homegrown/.
import { fnD , fnF, fnE } from 'some-vendor-lib';
import { ComponentX } from 'some-homegrown-module';
import { fnB , fnC, fnA } from 'other-vendor-lib';
import { ModuleY } from 'other-homegrown-module';becomes:
import { fnA , fnB, fnC } from 'other-vendor-lib';
import { fnD , fnE, fnF } from 'some-vendor-lib';
import { ComponentX } from 'some-homegrown-module';
import { ModuleY } from 'other-homegrown-module';Usage (WIP)
Install
npm install import-reorderConfigure
The CLI looks for a file named reorder.config.js in the current working directory. The config should export an object with the following shape (with examples):
module.exports = {
  caseSensitive: false,
  defaultGroup: 'Components',
  fileTypes: /(\.js$|\.jsx$|\.ts$|\.tsx$)/,
  groups: {
    Vendor: /(react|mobx|vendor)/,
    Platform: /platform/,
    Toolkit: /toolkit/,
    'Models/Constants/Types': /(models|constants|types)/,
    Stores: /stores/,
    StdLib: /fs/,
    Config: /config/
  },
  ignoreFiles: /config/,
  importPattern: /(import.*from|const.*require)/,
  indentSpaces: 2,
  maxLineLength: 80,
  membersBegin: /(import \{|const \{)/
};- caseSensitive: Whether to compare case sensitively. Defaults to false if unset (case insensitive).
- defaultGroup: Name of the default group, should you want to label it.
- fileTypes: The filetypes you want to read; regex of the file extensions.
- groups: Defines the groups you want your imports to be in,- groupName: /pattern/.
- ignoreFiles: The files you want to ignore and not modify (for use cases like dynamic imports).
- indentSpaces: Size of your indent.
- maxLineLength: Length of your lines.
CLI
The CLI expects paths separated by \n if there are multiple, relative to the current working directory.
echo 'fileA.js\nfileB.js\nAnotherDir/fileC.ts' | node_modules/import-reorder/reorder.jsWith staged files:
git diff --name-only --cached | node_modules/import-reorder/reorder.jsThe above can be added as a git hook with tools like Husky. Example:
// package.json
{
  ...
  "husky": {
    "hooks": {
      "pre-commit": "git diff --name-only --cached | node_modules/import-reorder/reorder.js",
      ...
    }
  }
}Module
import-reorder exports the CLI as well as the ReOrderer class. The class requires as parameters a config object (see above) and the current working directory.
const ReOrderer = require('./import-reorder');
const config = require(`${process.cwd()}/reorder.config`);
const reOrderer = new ReOrderer(config, process.cwd());
const sortedText = reOrderer.processText(someBlobOfText);With the class, it's possible to make this tool part of more complex workflows.