💼 This rule is enabled in the ✅ recommended
config.
🔧 This rule is automatically fixable by the --fix
CLI option.
Whenever npm changes package dependencies through npm install
, it lexically sorts (that is, alphabetizes by package name) all dependencies in package.json
.
However, developers will manually update package.json
and accidentally leave dependencies out of order.
Doing so leads to "noise" in commits when a later change re-sorts the packages.
Furthermore, the "scripts"
collections in package.json
files are generally easiest to work with when in alphabetical order.
To keep related scripts close together in the file, consider using the common npm script convention of colon-separated namespaces, such as watch:all
or watch:dist
.
This rule aims to keep the dependency collections sorted in every commit.
The following patterns are considered errors:
{
"scripts": {
"lint": "eslint .",
"test": "jest",
"start": "node server.js"
}
}
In the above scripts
collection, test
should be moved to the last line, after lint
and start
.
{
"devDependencies": {
"eslint": "^5.8.0",
"lodash": "^4.17.11",
"lodash.debounce": "4.17.11",
"mocha": "^5.2.0",
"nyc": "^13.1.0",
"prettier": "^1.14.3"
}
}
In the above devDependencies
collection, manual editing has put the dependencies out of lexical order.
The following patterns are not considered errors:
{
"scripts": {
"lint": "eslint .",
"start": "node server.js",
"test": "jest"
}
}
{
"devDependencies": {
"eslint": "^5.8.0",
"lodash": "^4.17.11",
"lodash.debounce": "4.17.11",
"mocha": "^5.2.0",
"nyc": "^13.1.0",
"prettier": "^1.14.3"
}
}
Note that in lexical ordering, lodash
comes before lodash.debounce
.
Pass an array of top-level package properties to lint sorting on those collections. All of their values must be objects.
Example:
{
"package-json/sort-collections": [
"error",
[
"devDependencies", // Only sort devDependencies
],
],
}
Defaults:
[
"scripts",
"devDependencies",
"dependencies",
"peerDependencies",
"overrides",
"config",
"exports"
]
This rule is autofixable; run eslint
with the --fix
option to sort any incorrect collections in place.