Ahmed's Prefered Strict ESLint Configuration
Default eslint rules
eslint-plugin-import
eslint-plugin-react
eslint-plugin-react-hooks
eslint-plugin-jest
Note: you need to install those plugins by yourself.
To installed it as dependency into your project, run:
$ npm install --save-dev eslint-config-ahmed
To use this config,
- Create a
.eslintrc.js
file in the root of your project's directory. (make sure to usejs
with your your .eslintrc file) - Then merge in the
baseConfig()
rules in your.eslintrc.js
file, for example:
// your eslintrc.js file
const baseConfig = require("eslint-config-ahmed");
module.exports = {
rules: Object.assign({}, baseConfig(), {
// Here you can add your own rules to overide intial rules.
}),
};
- You can add scripts to your
package.json
to lint and/or fix:
"scripts": {
"test:lint": "eslint .",
"test:lint-fix": "eslint --fix .",
"test": "npm run test:lint"
}
You can easily enable any rules for the plugins you use like react
, import
, and jest
, do it like so:
// your eslintrc.js file
const baseConfig = require("eslint-config-ahmed");
module.exports = {
rules: Object.assign({}, baseConfig({ import: true, react: true }), {
// Here you can add your own rules to overide intial rules.
}),
};
Note: you need to install plugins that mentioned above by yourself.
Here is a full example:
const baseConfig = require("eslint-config-ahmed");
module.exports = {
root: true,
plugins: [
"import",
"react",
"react-hooks",
"prettier", // Recommended Prettier plugin
"css-modules", // if you are using css modules in your project
],
// For parser options, you can use the default like below, or use `parser: "babel-eslint"`
parserOptions: {
sourceType: "module",
ecmaFeatures: {
jsx: true,
},
},
env: {
es6: true,
// node: true, // If you use it with Node then enable this.
},
rules: Object.assign(
{},
baseConfig({ flow: true, import: true, jest: true, react: true }),
// Here you can add your own rules to overide intial rules:
{
"prettier/prettier": "error",
"css-modules/no-undef-class": "error",
}
),
// Override Configure for Specific files
overrides: [
{
// Jest.
files: ["*.test.js"],
env: { jest: true },
// As you seen here we can enable Jest rules only for test
// using `jest: true` and turn off `builtin` rules
rules: baseConfig({ builtin: false, jest: true }),
},
{
// If you are working with Storybook
files: ["stories.js"],
globals: {
module: false,
},
},
{
// Node.js code.
files: ["server/**/*.js"],
env: { node: true },
rules: {
"import/order": ["error", { "newlines-between": "always" }],
},
},
],
// Here you can add Shared Settings, for example
settings: {
react: {
version: "detect",
},
},
};