Extremely strict ESLint config for demanding projects 🔥
ESLint is a great linter. It's reliable, high-performance, but also very configurable. And that's why some of its users might struggle a little bit. Which configuration is best for my project? How strict my config should be? Are there any rules that I could guide me?
Because I've stumbled upon these questions myself a while ago, I decided to somehow answer them on my own. I didn't know how strict my config should be and how should it look like. I searched through the NPM to find some reference point, but with no success.
That's why (and for some other reasons you can read about in my blog post), I went on a quest to go through the whole list of official ESLint rules and the most popular plugins to create my own ESLint config from scratch. This config is the result of my work, and I hope you'll enjoy it!
This config is available on NPM, so the installation process is really straight-forward.
npm install --save-dev eslint-config-xtrict
Or if you're using Yarn
yarn add --dev eslint-config-xtrict
The config is very much tailored towards the use of TypeScript (as its recommended for anyone wanting this level of strictness). The most basic use-case is just tsconfig.json
and ESLint config file (example for .eslintrc.js
).
{
"extends": "./node_modules/eslint-config-xtrict/tsconfig.json"
}
module.exports = {
extends: ["xtrict"],
parserOptions: {
tsconfigRootDir: __dirname
}
};
The config is designed to work with ESLint v7, but if you're using v6, it's important to include the special patching script at top of your config file, which allows ESLint v6 to properly resolve plugins used by the config (see this issue for more details).
require("eslint-config-xtrict/patch-eslint6");
module.exports = {
// ...
};
Apart from that if you're using TypeScript, you'll also have to supply tsconfigRootDir
option, equal to global variable __dirname
.
If you use Prettier (also recommended), there's a reference config included, if you want.
If you don't use TypeScript or want to ease the rules, you can extend only upon certain groups of rules. For this, you need to access the /config
folder and all the sub-configs within in.
module.exports = {
extends: ["xtrict/configs/style"]
// ...
};
There are as many as 8 different sub-configs, so feel free to use them however you want!
So, again, as the config is really strict, you'll most likely end up disabling some of the rules, to better suit your needs. It's meant to serve as a better foundation for your edits, rather than eslint:all
.