- Lints JavaScript/TypeScript based on the current standards
- Fixes formatting issues with Prettier
- Lints + Fixes React and React Hooks based on the eslint config of airbnb with some minor changes to it based on my preferences
- See the applied rules
I use this setup globally to have linting for random JavaScript Files but you can also install this on a per project basis.
- If you have a
package.json
in your project you can skip this step. Otherwise create apackage.json
withnpm init
. - Install this configuration by running
npx install-peerdeps --dev eslint-config-danyo
- You can see all the installed packages in the
devDependencies
section of yourpackage.json
- In the root directory of your project (That's where your
package.json
lives aswell). Create a.eslintrc.js
or.eslintrc
file and fill it with:
{
"extends": ["danyo"]
}
{
"extends": ["danyo", "danyo/ts"]
}
To reduce file clutter in your project you alternatively can put this object in your package.json
under the property "eslintConfig":
.
- Install the configuration and all dependencies globally
npx install-peerdeps --global eslint-config-danyo
- Create a global
.eslintrc
or.eslintrc.js
file. ESLint will look in your home directory
~/.eslintrc
or~/.eslintrc.js
on a macC:\Users\{username}/.eslintrc
orC:\Users\{username}/.eslintrc.js
on windows
The Content of if this file should look like this
{
"extends": ["danyo"]
}
or this if you use TypeScript
{
"extends": ["danyo", "danyo/ts"]
}
After the setup step you can add the following code to your "scripts"
section of your package.json
to run the linter from the commandline.
- run
npm run lint
to lint your errors - run
npm run lint:fix
to lint and automatically fix all fixable issues.
"scripts": {
"lint": "eslint .",
"lint:fix": "eslint . --fix"
},
- Install the ESLint extension
- Setup Vs Code settings via
Code
→Preferences
→Settings
(or hitcmd + ,
on a mac). To get to thejson
view click theOpen Settings (JSON)
icon in the top right corner.
"editor.formatOnSave": true //runs auto formatting for all files
//turns of auto formatting for JS, JSX, TS and TSX because eslint takes care of this
"[javascript, typescript]": {
"editor.formatOnSave": false
},
//tells the eslint plugin to run when we save
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
},
"eslint.run": "onSave", //runs eslint when you save a file
"eslint.validate": [ //sets filetypes eslint watches
"javascript",
"javascriptreact",
"typescript",
"typescriptreact"
],
"eslint.alwaysShowStatus": true, //shows the eslint status in the status bar
/* OPTIONAL SETTING if you have the prettier VS Code Extension installed
* This code tells the exentsion that we already take care of formatting these filetypes
*/
"prettier.disableLanguages": [
"javascript",
"javascriptreact",
"typescript",
"typescriptreact"
]
You can overwrite both eslint
and prettier
settings in your own .eslintrc
or eslintrc.js
file.
- ESLint rules are written under
"rules"
- Prettier Settings are inside the
"rules"
under"prettier/prettier"
. Prettier rules overwrite everything previous defined so you have to write settings that you would like to keep aswell
{
"extends": [
"danyo"
],
"rules": {
"react/prefer-stateless-function": 2,
"prettier/prettier": [
"error",
{
"bracketSpacing": true,
"printWidth": 120,
"singleQuote": true,
"useTabs": true, //don't @ me for this 👾
"tabWidth": 4,
"trailingComma": "es5"
}
]
}
}
There's the possibility that global modules fail on installation. This will remove them from your system to start out fresh.
npm remove --global eslint-config-danyo eslint eslint-config-airbnb eslint-config-prettier eslint-plugin-html eslint-plugin-import eslint-plugin-jsx-a11y eslint-plugin-prettier eslint-plugin-react eslint-plugin-react-hooks prettier babel-eslint eslint-import-resolver-typescript typescript @typescript-eslint/parser @typescript-eslint/eslint-plugin
For a local installation omit the --global
flag. After that follow the setup guide again.