An opinionated but flexible set of ESLint configurations.
This configuration:
- Is mostly composed out of other plugins' recommended configuration sets. It further enables some (hopefully uncontroversial) rules that catch common gotchas and improve consistency.
- Aggressively enables rules that produce consistent style. It assumes you're using Prettier to style your code, and further enables rules that free developers up from style (sorting import declarations and members, etc.).
- Centralizes installation and maintenance of ESLint plugins as much as possible. Rather than installing, configuring, and maintaining a ton of ESLint plugins, install one package.
- Reduces boilerplate by smoothing out common conflicts between plugins.
Install via your package manager of choice:
npm install -D @ndhoule/eslint-config
yarn add -D @ndhoule/eslint-config
You'll also need to install eslint
and prettier
, which are peer dependencies.
You will also need to install react
and typescript
if you're using those configurations; these are also represented as peer dependencies.
@ndhoule/eslint-config/recommended
: A base configuration that enforces best practices. You probably want this rule set enabled at the root of your configuration.@ndhoule/eslint-config/recommended-typescript
: A base configuration for TypeScript files.@ndhoule/eslint-config/jest
: A configuration for Jest tests.@ndhoule/eslint-config/lodash
: A configuration for Lodash. You may need to configure theeslint-plugin-lodash
plugin; consult its documentation for more information.@ndhoule/eslint-config/node
: A configuration for files run in a Node runtime.@ndhoule/eslint-config/node/babel
: A configuration for files run in a Node runtime that are first transpiled via Babel (or a similar transpiler like TSC).@ndhoule/eslint-config/node/typescript
: A configuration for TypeScript files run in a Node runtime.@ndhoule/eslint-config/react
: A configuration for React components/applications. You may need to configure theeslint-plugin-react
plugin; consult its documentation for more information.@ndhoule/eslint-config/react/typescript
: A configuration for React components/applications with TypeScript-specific rules enabled.@ndhoule/eslint-config/react/jsx-runtime
: A configuration for React applications that use the JSX transform.@ndhoule/eslint-config/testing-library
: A configuration for Testing Library tests.@ndhoule/eslint-config/testing-library/react
: A configuration for Testing Library React tests.
The most effective way to use this configuration is in conjunction with overrides. For example:
// .eslintrc.js
module.exports = {
root: true,
extends: "@ndhoule/eslint-config/recommended",
overrides: [
// TypeScript files
{
files: ["src/**/*.ts", "src/**/*.tsx"],
parserOptions: {
tsconfigRootDir: __dirname,
project: "./tsconfig.json",
},
extends: "@ndhoule/eslint-config/typescript",
},
// Tests
{
files: ["src/**/*.test.js", "src/**/*.test.ts"],
extends: ["@ndhoule/eslint-config/jest"],
},
// React tests
{
files: ["src/**/*.test.jsx", "src/**/*.test.tsx"],
extends: [
"@ndhoule/eslint-config/jest",
"@ndhoule/eslint-config/testing-library/react",
],
},
],
};