@shigen/eslint-plugin
v0.12.1
Published
General purpose plugin for ESLint
Downloads
12
Maintainers
Readme
@shigen/eslint-plugin
General purpose ESLint plugin
Configurable ESLint rules for issues not -- or not sufficiently -- covered by ESLint core rules.
Install
npm install --save-dev @shigen/eslint-plugin
Usage
In your .eslintrc
:
{
"plugins": ["@shigen"],
"rules": {
"@shigen/group-imports": "error"
}
}
Rules
@shigen/group-imports
Requires imports to be grouped and groups to be separated by a new line. This rule is partially auto-fixable. It is currently not capable to move an import that is preceded by non-import statements, including comments.
The following configuration options can be set:
interface ModuleClassConfiguration {
class: 'node' | 'external' | 'relative' | 'absolute';
types?: 'include' | 'exclude' | 'only';
}
interface ModulePathConfiguration {
path: string;
types?: 'include' | 'exclude' | 'only';
}
type ModuleConfiguration = string | ModulePathConfiguration | ModuleClassConfiguration;
type Configuration = Array<ModuleConfiguration | ModuleConfiguration[]>;
where ModuleConfiguration
can be a path pattern or an object.
If it's an object, path
can be a path pattern and class
can be one of the following:
node
: All node builtin packages likefs
andpath
, with or without thenode:
protocol prefix.external
: All other declared dependencies, e.g.lodash
,react
, etc.relative
: All relative imports.absolute
: All absolute imports, never seen a project use these, but it's possible.
Path patterns are matched with the minimatch
library with the matchBase
option set.
The property types
is only relevant for TypeScript's type imports and defaults to 'include'
.
If you want type and value imports to be in separate groups you need to explicitly declare them with 'only'
and 'exclude'
.
Nested arrays allow packages to be treated as a single group, e.g.
[
[{ "class": "node" }, { "class": "external" }],
["@my-scope", "my-package"],
{ "class": "relative" }
]
Explicitly declared packages and scopes have precedence over the predefined class
tokens. Unused tokens are in an implicit additional group.
The default configuration is:
[
{ "class": "node" },
{ "class": "external" },
{ "class": "absolute" },
{ "class": "relative" }
]
@shigen/sort-imports
Requires import groups to be sorted by module first and then by specifier. Auto-fixable!
The following configuration options can be set:
interface Configuration {
specifier?: 'source' | 'rename';
locales?: string[];
sensitivity?: 'base' | 'accent' | 'case' | 'variant';
ignorePunctuation?: boolean;
numeric?: boolean;
caseFirst?: 'upper' | 'lower' | 'false';
caseGroups?: boolean;
sortExports?: boolean;
typesInGroup?: 'ignore' | 'top' | 'bottom' | 'above-value' | 'below-value';
inlineTypes?: 'ignore' | 'start' | 'end';
}
specifier
: Determines specifier priority, e.g. inimport { foo as bar } from 'baz'
foo
is'source'
andbar
is'rename'
.caseGroups
: Whentrue
, import names need to be grouped by case before sorting.sortExports
: Whether to sort deferred export groups, i.e. all statements that export from another module.typesInGroup
: Where to place type imports/exports in groups with mixed type and value imports/exports. TypeScript only!inlineTypes
: Where to place inline type imports/exports with mixed type and value imports/exports. TypeScript only!
For all other possible settings, see String#localeCompare.
The default configuration is:
{
"specifier": "source",
"locales": ["en-US"],
"sensitivity": "variant",
"ignorePunctuation": false,
"numeric": true,
"caseFirst": "lower",
"caseGroups": false,
"sortExports": true,
"typesInGroup": "ignore",
"inlineTypes": "ignore"
}