Eslint and Prettier Setup
These are my settings for ESLint and Prettier
What it does
- Lints Typescript based on the latest standards
- Fixes issues and formatting errors with Prettier
- Lints + Fixes React via eslint-config-airbnb
- You can see all the rules here.
Installing
- Use the following command to install all the necessary deps (remove the -Y if you don't use Yarn):
npx install-peerdeps --dev @lukemorales/eslint-config -Y
-
You can see in your package.json there are now a big list of devDependencies.
-
Add the following code to your package.json
:
"eslintConfig": {
"extends": [
"@lukemorales"
],
"parserOptions": {
"project": "./tsconfig.json"
},
},
You can alternatively create a .eslintrc
file in the root of your project's directory (it should live where package.json does). Your .eslintrc
file should look like this:
{
"extends": [
"@lukemorales"
],
"parserOptions": {
"project": "./tsconfig.json"
},
}
- You can add two scripts to your package.json to lint and/or fix:
"scripts": {
"lint": "eslint .",
"lint:fix": "eslint . --fix"
},
- Now you can manually lint your code by running
npm run lint
and fix all fixable issues with npm run lint:fix
. You probably want your editor to do this though.
Settings
If you'd like to overwrite eslint or prettier settings, you can add the rules in your .eslintrc
file. The ESLint rules go directly under "rules"
while prettier options go under "prettier/prettier"
. Note that prettier rules overwrite anything in my config (trailing comma, and single quote), so you'll need to include those as well.
{
"extends": [
"@lukemorales"
],
"rules": {
"no-console": "off"
}
}
With Create React App
- Run
npx install-peerdeps --dev @lukemorales/eslint-config
- Crack open your
package.json
and replace "extends": "react-app"
with "extends": "@lukemorales"