Talljack's ESLint config
When ESLint upgrades to flat config(ESLint 9), my all projects need to update the ESLint config file, so I want to write my config to be reused in all projects.
pnpm i -D eslint talljack-eslint-config
And create eslint.config.js
(you need to set package.json's type
to module
) like this:
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig()
{
"scripts": {
"lint": "eslint .",
"fix": "eslint . --fix"
}
}
Install VS Code ESLint extension
Add the following settings to your .vscode/settings.json
{
"eslint.experimental.useFlatConfig": true,
"editor.codeActionsOnSave": {
"source.fixAll.eslint": "explicit",
"source.organizeImports": "never"
},
"editor.formatOnSave": false,
"eslint.validate": [
"javascript",
"typescript",
"javascriptreact",
"typescriptreact",
"vue",
"html",
"markdown",
"json",
"jsonc",
"json5",
"astro"
]
}
Use all of the options in the config file.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
formatter: true,
jsonc: true,
markdown: true,
typescript: true,
vue: true,
yaml: true,
})
To use the React ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
react: true,
})
To use the Vue3 ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
vue: true,
})
To use the Markdown ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
markdown: true,
})
To use the Jsonc ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
jsonc: true,
})
To use the Yaml ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
yaml: true,
})
To use the Astro ESLint config, you can turn it on(you need to install eslint-plugin-astro
).
pnpm add -D eslint-plugin-astro
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
astro: true,
})
To use the Solid ESLint config, you can turn it on(you need to install eslint-plugin-solid
).
pnpm add -D eslint-plugin-solid
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
solid: true,
})
To use the Test ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
test: true,
})
To use the Formatters ESLint config, you can turn it on.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
formatters: true,
})
To use the Stylistic ESLint config, you can turn it on.
It's default true
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
stylistic: true,
})
you can read more type-aware here.
// eslint.config.js
import createEslintConfig from 'talljack-eslint-config'
export default createEslintConfig({
typescript: {
tsconfigPath: 'tsconfig.json',
},
})
If you want to apply lint and auto-fix before every commit, you can add the following to your package.json
you need to install lint-staged
and simple-git-hooks
pnpm i -D lint-staged simple-git-hooks
npx simple-git-hooks
then
// package.json
{
"simple-git-hooks": {
"pre-commit": "pnpm lint-staged"
},
"lint-staged": {
"*": "eslint --fix"
}
}