Shared ESLint config for Scorum projects
Our lint rules are to help us write bug-free, readable and maintainable code. Rules are usually added because the patterns they are checking for have been proven to be problematic and frequently come up in code reviews. The intention is to save both authors and reviewers time by providing the author early feedback at the time of writing.
Required dependencies for ALL configs
# dependencies only for all configs
npm install --save-dev eslint eslint-config-scorum
Additionall dependencies for base
config
# dependencies only for base config
npm install --save-dev eslint babel-eslint eslint-config-scorum eslint-plugin-import
Additionall dependencies for react
config
# dependencies only for react config
npm install --save-dev eslint-plugin-react eslint-plugin-react-hooks eslint-plugin-jsx-a11y
Additionall dependencies for ramda
config
# dependencies only for ramda config
npm install --save-dev eslint-plugin-ramda
Additionall dependencies for jest
config
# dependencies only for jest config
npm install --save-dev eslint-plugin-ramda
Additionall dependencies for prettier
config
# dependencies only for prettier config
npm install --save-dev prettier eslint-plugin-prettier
Create an .eslintrc
file that extends this config. For more configuration options, check out the ESLint docs.
{
"extends": "scorum"
}
{
"extends": "scorum/react"
}
{
"extends": "scorum/node"
}
Server config includes base
and node
configs
{
"extends": "scorum/server"
}
This config for vanilla JS (includes base
config)
{
"extends": "scorum/client"
}
{
"extends": "scorum/jest"
}
{
"extends": "scorum/ramda"
}
{
"extends": [
"scorum/prettier",
"scorum/prettier/react",
]
}
If you need to override or turn off rules:
If you need to override a rule, your .eslintrc.json
file should look like the example below. All shared rules will be used, but eqeqeq
will be turned off.
{
"extends": "scorum",
"rules": {
"eqeqeq": "off"
},
"env": {},
"globals": {},
"rules": {}
}
- Add automatically bumping package version release-it