This configuration is opinionated and it may not fit your needs. You can extend it and override the rules that you don't like.
Note
This configuration is designed to be used with Prettier for code formatting. You can use my personal config @javalce/prettier-config.
- Supports ESLint v9
- ESLint Flat Config file format
- Does not lint
.gitignore
listed files (I think that if you don't want to track a file, you don't want to lint it) - Designed to work with TypeScript, React, Next.js, Node.js, and more smoothly out of the box
- Some rules can be auto-fixed with
eslint --fix
- Stylistic rules that are not covered by Prettier are enabled by
@stylistic/eslint-plugin
Thanks to antfu/eslint-config for the inspiration and reference and vercel/style-guide for the amazing eslint rules and config for JavaScript, TypeScript and React.
Note
For the examples below, I'm using pnpm
as the package manager, but you can use npm
, yarn
or bun
as well.
It is provided CLI tool to help you setup your project with ESLint. It also supports adding new configurations to an existing project.
pnpx @javalce/eslint-config init
pnpx @javalce/eslint-config add react # or the config for the framework you want
pnpm add --save-dev eslint @javalce/eslint-config
Create an eslint.config.mjs
file in the root of your project with the following content:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({});
By default it uses the ecmaVersion 2021
. If you want to use a different version, you can specify it in the configuration:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
ecmaVersion: 2022,
});
To enable TypeScript support, you only need to install the typescript
package:
pnpm add --save-dev typescript
By default, it will automatically load the typescript config and the configuration will look for a tsconfig.json
file in the root of your project.
If you want, you can enable explicitly the TypeScript config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
typescript: true,
});
Also, if you want to use a different file, you can specify it in the configuration:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
typescript: './path/to/tsconfig.custom.json',
});
Or you can use multiple tsconfig files:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
typescript: ['./path/to/tsconfig.json', './path/to/another/tsconfig.json'],
});
Instead of using the passing the path to the tsconfig file(s) in the configuration, you can only pass the filename(s) and let the configuration resolve the absolute path for you.
To enable React support, you need to install the eslint-plugin-react
and eslint-plugin-react-hooks
packages:
pnpm add --save-dev eslint-plugin-react eslint-plugin-react-hooks
Then, update your ESLint configuration file to enable the React config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
react: true,
});
To enable Next.js support, you need to install all the react plugins and the @next/eslint-plugin-next
package:
# If you use npm
pnpm add --save-dev eslint-plugin-react eslint-plugin-react-hooks @next/eslint-plugin-next
Then, update your ESLint configuration file to enable the Next.js config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
react: 'next',
});
The next.js config will only load the @next/eslint-plugin-next
plugin and the recommended rules. To enable the react rules you must enable the react config.
To enable Svelte support, you need to install the eslint-plugin-svelte
and svelte-eslint-parser
package:
pnpm add --save-dev eslint-plugin-svelte svelte-eslint-parser
Then, update your ESLint configuration file to enable the Svelte config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
svelte: true,
});
To enable Solidjs support, you need to install the eslint-plugin-solid
package:
pnpm add --save-dev eslint-plugin-solid
Then, update your ESLint configuration file to enable the Solidjs config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
solidjs: true,
});
To enable Vue support, you need to install the eslint-plugin-vue
and vue-eslint-parser
package:
pnpm add --save-dev eslint-plugin-vue vue-eslint-parser
Then, update your ESLint configuration file to enable the Vue config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
vue: true,
});
Vue 2 has reached EOL and it's not recommended to use it. However, if you still want to use it, you can enable the Vue 2 config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
vue: {
version: 2,
},
});
To enable Astro support, you need to install the astro-eslint-plugin
and astro-eslint-parser
package:
pnpm add --save-dev astro-eslint-plugin astro-eslint-parser
Then, update your ESLint configuration file to enable the Astro config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
astro: true,
});
Astro can be integrated with other frameworks like React, Vue, Svelte, Solidjs, etc. You can enable the respective configs to lint the code of the framework.
To enable testing support, you must enable the testing
option in the configuration. You can choose between jest
or vitest
and it will load the recommended rules for each testing library.
If you are using Jest, install the eslint-plugin-jest
package:
pnpm add --save-dev eslint-plugin-jest
Then, update your ESLint configuration file to enable the Jest config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
testing: 'jest',
});
If you are using Vitest, install the eslint-plugin-vitest
package:
pnpm add --save-dev eslint-plugin-vitest
Then, update your ESLint configuration file to enable the Vitest config:
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
testing: 'vitest',
});
To enable testing with React or Vue, you only need to enable the respective config and the testing config and it will load the recommended rules for the @testing-library
package.
import { defineConfig } from '@javalce/eslint-config';
export default defineConfig({
react: true, // or vue
testing: 'jest', // or vitest
});
Also, you need to install the eslint-plugin-testing-library
package:
pnpm add --save-dev eslint-plugin-testing-library