ESLint + Prettier
Seamlessness
Why Prettier?
data:image/s3,"s3://crabby-images/c8afc/c8afcbf39e964c5679eb191d296bc33f2e262226" alt=""
data:image/s3,"s3://crabby-images/14b03/14b033430dfca188da760a98b1aa6ef2b22ad3b4" alt=""
Lettere å skrive
Raskere å lese
Mer meningsfulle reviews
data:image/s3,"s3://crabby-images/dbef7/dbef7b5d7d0c160a48de931bda98a121fc8ebf62" alt=""
When Prettier is usually run
Real diff: 0
Pre commit hook
// package.json
{
...
"devDependencies": {
...
"husky": "^4.2.5",
"lint-staged": "^10.2.2",
"prettier": "^2.1.1"
},
"husky": {
"hooks": {
"pre-commit": "lint-staged"
}
},
"lint-staged": {
"*.{js,jsx,ts,tsx,json,css,md}": [
"prettier --write"
]
}
}
Using husky and lint-staged
husky-hook kan re-addes med npm rebuild
Pre commit hook #2
# .pre-commit-config.yaml
- repo: local
hooks:
- id: eslint
name: eslint
entry: yarn eslint --quiet --fix
language: system
files: \.[jt]sx?$
types: [file]
- id: prettier
name: prettier
entry: yarn prettier --write
language: system
files: \.[jt]sx?$
types: [file]
Using pre-commit.com
IDE automatic Prettier
Using VSCode Prettier
data:image/s3,"s3://crabby-images/148f9/148f91af997e908603a168becce60dc7b6a3449a" alt=""
Why ESLint?
Lettere å skrive konsekvent og bugfritt
Raskere å lese
Mer meningsfulle reviews
data:image/s3,"s3://crabby-images/71f92/71f92fb3e9a0fd1c2ed3550fb0b3dae671fb5c08" alt=""
data:image/s3,"s3://crabby-images/ab8a3/ab8a3d7252f6d0e486ffd809cecd5f08a4f84e77" alt=""
ESLint: Rar regel?
Google it!
data:image/s3,"s3://crabby-images/9002b/9002b23cb227e02a637c86abb53c34b38dd71758" alt=""
data:image/s3,"s3://crabby-images/c7c33/c7c3342c56c5159a0e9f6d343452a523527447a1" alt=""
data:image/s3,"s3://crabby-images/8434c/8434c9165a75a772ee965e5cb7d1e81edaf6bef8" alt=""
ESLint: Dum regel?
Skru den av i .eslintrc eller i @askeladden/eslint-config
// .eslintrc
{
...
"rules": {
// TODO: Fix this, we got e.g. components
// accepting style without using it.
"@typescript-eslint/no-unused-vars": 0
}
}
// .eslintrc
{
...
"rules": {
// We try to avoid using classes, but when we
// do, it's often to be compatible with a third-party
// library who might require methods in a certain way.
"class-methods-use-this": 0
}
}
// .eslintrc
{
...
"rules": {
// Avoid unnecessary imports
"unused-imports/no-unused-imports-ts": 2,
}
}
IDE automatic Eslint
Using VSCode ESLint
data:image/s3,"s3://crabby-images/f14a8/f14a8fdf492a7413046087a93a5826ed3d51be8a" alt=""
IDE auto fix
Fixes Prettier and some ESLint errors
// VSCode settings.json
{
...
// Formats Prettier on save
"[javascript]": {
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[css]": {
"editor.formatOnSave": true
},
"[html]": {
"editor.formatOnSave": true
},
"[json]": {
"editor.formatOnSave": true
},
// Fixes some ESLint errors (e.g. import)
"editor.codeActionsOnSave": {
"source.fixAll": true
},
}
Kun Wercker CI feiler
Med ESLint / Prettier
Funker pre-commit hooken?
Kan re-addes med npm rebuild
data:image/s3,"s3://crabby-images/c1c95/c1c95a8ea0430e4be4bc87ab99abd7b1f41e3339" alt=""
// package.json
{
...
"scripts": {
"lint:ignore-warnings": "eslint . --quiet",
"lint:prettier-check": "prettier --check \"**/*.{js,jsx,ts,tsx,json}\"",
"lint:prettier": "prettier --write \"**/*.{js,jsx,ts,tsx,json}\""
}
}
ESLint + Prettier
By Tomas Fagerbekk
ESLint + Prettier
- 667