- As simple as flat config can be, without re-inventing the classic config,
- Helps to code with less stress,
- Helps to find bugs using only necessary rules,
- Adds minimum of what you need and allows to configure,
- Supports Typescript, React.js, Playwright, Storybook, Vitest and others out-of-box,
- DOES NOT sort imports and does not include formatting/stylistic rules,
- Works with eslint v9+
This package aims to help you develop confidently without pressure from tools and too strict rules. At the same time, it tries to ensure that tools help you avoid shooting yourself in the foot.
Some key points behind this package include:
- A developer should not be blocked by the tool and should be able to use language features,
- No or minimum warnings, just errors that don't mess up output
- warnings can still exist since exported recommended configs from other packages can include them,
- No formatting rules, this should be handled by formatter without blocking your flow and fighting in semicolon wars,
- Simple configuration, use native js arrays for configuring without additional abstractions,
- Batteries included. Enable when needed: typescript, react, nextjs, tailwind, vitest, playwright, storybook etc.
- Rules should not force you to use a specific programming style but help you catch bugs
npm install --save-dev eslint @zemd/eslint-flat-config
bun add --dev eslint @zemd/eslint-flat-config
// eslint.config.js
import { createConfig } from "@zemd/eslint-flat-config";
// If you prefer importing the factory method as default:
// import createConfig from "@zemd/eslint-flat-config";
// Or if you want to import only default configuration:
// import { config } from "@zemd/eslint-flat-config";
// export default config;
export default createConfig();
All optional features are disabled by default. You can enable features as you need them.
// eslint.config.js
import { createConfig } from "@zemd/eslint-flat-config";
export default createConfig({
storybook: true,
nextjs: true,
playwright: true,
vitest: true,
turbo: true,
tailwind: true,
graphql: true,
});
Sometimes you might want to override some internal behavior of the rules provided by the package. It can be achieved by filtering out the array you get from createConfig
factory method. Each feature rule set is named, so you can identify it easily:
// eslint.config.js
import { createConfig } from "@zemd/eslint-flat-config";
const config = createConfig().filter((feature) => {
return feature.name !== "zemd/react/rules";
});
export default [...config];
Or you can import exactly what you need from the package:
// eslint.config.js
import { javascript, typescript, vitest } from "@zemd/eslint-flat-config";
export default [...javascript(), ...typescript(), ...vitest()];
npm pkg set scripts.lint="eslint ."
npm pkg set scripts.lint:fix="eslint . --fix"
or
{
"scripts": {
"lint": "eslint .",
"lint:fix": "eslint . --fix"
}
}
Debug your rules locally using @eslint/config-inspector
package.
npx @eslint/config-inspector@latest
# or bunx @eslint/config-inspector@latest
Since eslint
is a tool for javascript project the core set of rules is javascript
. I recommend to include at minimum javascript
rules in your configuration.
These set of rules are enabled by default when you call createConfig()
function without additional parameters. The rules are constructed by composing javascript()
, typescript()
and react()
configs.
Javascript config:
eslint-config-flat-gitignore
- ignores all files from your .gitignore file@eslint/js
- recommended rules plus the ones that were not includedeslint-plugin-unicorn
- carefully hand-picked rules avoiding some style relating ruleseslint-plugin-sonarjs
- all recommended rules@eslint-community/eslint-plugin-eslint-comments
- additional ESLint rules for ESLint directive comments (e.g. //eslint-disable-line)@eslint/markdown
(disabled by default) - helpful rules for linting code blocks in markdown files
Typescript config:
@typescript-eslint/eslint-plugin
- carefully hand-picked rules in conjunction withstrict-type-checked
config.
React config:
eslint-plugin-react
- recommended rules and some additional ruleseslint-plugin-react-hooks
- recommended ruleseslint-plugin-jsx-a11y
- recommended ruleseslint-plugin-react-hooks-extra
- additional set of rules for react hooks.- I am considering also switching from
eslint-plugin-react
to@eslint-react/eslint-plugin
in the future, but till then can use some of the rules from underlying package.
- I am considering also switching from
eslint-plugin-react-refresh
eslint-plugin-react-compiler
eslint-plugin-react-web-api
- recommended rules from the package
Each feature can be used separately and available in the exports of the package.
graphql
- rules from@graphql-eslint/eslint-plugin
for schema and operationsnextjs
- compoud rules fromrecommended
andcore-web-vitals
configs from the@next/eslint-plugin-next
package.playwright
- recommended rules fromeslint-plugin-playwright
storybook
- recommended and csf-strict rules fromeslint-plugin-storybook
tailwind
- recommended rules fromeslint-plugin-tailwindcss
excepttailwindcss/classnames-order
, since the official prettier plugin sorts classes differently.turbo
- recommended rules fromeslint-config-turbo
vitest
- recommended rules from@vitest/eslint-plugin
- Sheriff -- Great set of rules, but with some style restrictions
- Antfu config -- Another great set of rules
- XO -- Flat version of popular set
xo
, still in beta, includes some restrictive rules that I don't always agree with
The @zemd/eslint-flat-config
is licensed under the Apache-2.0 license.