Flat ESLint config for JavaScript, TypeScript, Vue 2, Vue 3, Prettier.
- Opinionable: single quotes, no semi, trailing comma, etc
- Designed to work alongside with Prettier
- Respect
.gitignore
via eslint-config-flat-gitignore - Out-of-box support for TypeScript, Vue, JSON, Markdown, YAML, TOML, SVG and etc
- Strict but provides useful rules to guard your codebase
- Custom ESLint commands for eslint-plugin-command
- ESLint flat config for ESLint v9.5.0+
pnpm add eslint prettier typescript @ntnyq/eslint-config @ntnyq/prettier-config -D
Highly recommended using eslint.config.mjs
as the config file :
// @ts-check
import { defineESLintConfig } from '@ntnyq/eslint-config'
export default defineESLintConfig()
Add scripts lint
in package.json
:
{
"scripts": {
"lint": "eslint .",
"lint:fix": "eslint . --fix"
}
}
💼 Intergrated with Prettier, VSCode, husky and nano-staged
// @ts-check
import { config, defineConfig } from '@ntnyq/prettier-config'
export default defineConfig({
...config,
// overrides if needed
overrides: [
{
files: ['**/*.html'],
options: {
singleAttributePerLine: false,
},
},
{
files: ['**/*.{css,scss,less}'],
options: {
singleQuote: false,
},
},
],
})
{
"eslint.enable": true,
"prettier.enable": true,
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.fixAll.eslint": "explicit",
"source.organizeImports": "never"
},
"editor.defaultFormatter": "esbenp.prettier-vscode",
"eslint.validate": [
"vue",
"html",
"yaml",
"toml",
"json",
"jsonc",
"json5",
"markdown",
"javascript",
"typescript",
"javascriptreact",
"typescriptreact"
]
}
pnpm add husky nano-staged -D
{
"scripts": {
"prepare": "husky"
},
"nano-staged": {
"*.{js,ts,cjs,mjs,jsx,tsx,vue,md,html,json,toml,yml,yaml}": "eslint --fix"
}
}
echo "nano-staged" > .husky/pre-commit
Check for detail in:
export interface ConfigOptions extends ConfigOptionsInternal, OptionsExtensions {
command?: ConfigCommandOptions
comments?: ConfigCommentsOptions
ignores?: ConfigIgnoresOptions
importX?: ConfigImportXOptions
javascript?: ConfigJavaScriptOptions
jsdoc?: ConfigJsdocOptions
node?: ConfigNodeOptions
specials?: ConfigSpecialsOptions
/**
* bellow can be disabled
*/
antfu?: boolean | ConfigAntfuOptions
depend?: boolean | ConfigDependOptions
githubAction?: boolean | ConfigGitHubActionOptions
gitignore?: boolean | ConfigGitIgnoreOptions
jsonc?: boolean | ConfigJsoncOptions
markdown?: boolean | ConfigMarkdownOptions
ntnyq?: boolean | ConfigNtnyqOptions
perfectionist?: boolean | ConfigPerfectionistOptions
pinia?: boolean | ConfigPiniaOptions
prettier?: boolean | ConfigPrettierOptions
regexp?: boolean | ConfigRegexpOptions
sort?: boolean | ConfigSortOptions
test?: boolean | ConfigTestOptions
toml?: boolean | ConfigTomlOptions
typescript?: boolean | ConfigTypeScriptOptions
unicorn?: boolean | ConfigUnicornOptions
unocss?: boolean | ConfigUnoCSSOptions
vue?: boolean | ConfigVueOptions
yml?: boolean | ConfigYmlOptions
/**
* disabled by default
*/
svgo?: boolean | ConfigSVGOOptions
/**
* disabled by default
*
* require `eslint-plugin-eslint-plugin` installed mannally
*/
eslintPlugin?: boolean | ConfigESLintPluginOptions
/**
* disabled by default
*
* require `@stylistic/eslint-plugin` installed mannally
*/
stylistic?: boolean | ConfigStylisticOptions
}
This project follows Semantic Versioning for releases.
- Node.js version requirement changes
- Huge refactors that might break the config
- Plugins made major changes that might break the config
- Changes that might affect most of the codebases
- Enable/disable rules and plugins (that might become stricter)
- Rules options changes
- Version bumps of dependencies