Skip to content

Latest commit

 

History

History
275 lines (201 loc) · 7.47 KB

README.md

File metadata and controls

275 lines (201 loc) · 7.47 KB

ESLint config

Shared configuration for ESLint for consistent rules across Maykin projects.

NPM Version

This package exposes a set of standard/recommended rules for ESLint code checks. You can still decide to override certain rules/configurations on a per-project basis - a nice feature of ESLint's flat config format. See below for example configurations.

Installation

The recommended installation includes all optional plugins. These should not get in the way if you're not using all features (e.g. a project without React or Typescript).

npm install \
    --save-dev \
    @maykinmedia/eslint-config \
    eslint-plugin-import \
    eslint-plugin-jsx-a11y \
    eslint-plugin-prettier \
    eslint-config-prettier \
    eslint-plugin-react \
    eslint-plugin-react-hooks \
    eslint-plugin-storybook \
    typescript-eslint \
    eslint-import-resolver-typescript

Optional plugins are specified as peer dependencies, required plugins will be pulled in automatically.

Usage

Create a file eslint.config.js and compose the configuration:

// eslint.config.mjs
import {ignoreBuildArtifacts} from '@maykinmedia/eslint-config';
import recommended from '@maykinmedia/eslint-config/recommended';

export default [
  // dist, build and storybook-static are the defaults
  ignoreBuildArtifacts(['dist', 'build', 'storybook-static']),
  ...recommended,
];

See Overrides for how to add overrides.

You can use the config-inspector to inspect what the final composed config is for your project.

Recommended

The recommended configuration assumes modern setups with Typescript, React and Storybook. Even if you don't use all of these components of the stack, you can still use the recommended configuration.

For company-wide consistency, we really encourage you to use the recommended config.

Required plugins

  • React plugins
  • Typescript plugins
  • eslint-plugin-import
  • eslint-config-prettier
  • eslint-plugin-prettier
  • eslint-plugin-storybook

Usage

See Usage above.

Configuration parts

The (recommended) and available configuration is broken up around various (optional) plugins. The recommended config is composed from these parts. Each part is documented below.

Base

Tip

Included in the recommended config.

The base configuration is the absolute minimum. It sets up the environment and enables the recommended rules from ESLint itself. Additionally, it provides a helper to prevent linting build artifacts, as that hurts performance.

import {base, ignoreBuildArtifacts} from '@maykinmedia/eslint-config/base';

export default [
  ignoreBuildArtifacts(['dist']),
  ...base,
]

Typescript

Tip

Included in the recommended config.

The typescript configuration enables parsing of TS source code with type annotations.

We essentially re-export the typescript-eslint recommended configuration without additional tweaks.

Required plugins

  • typescript-eslint
import typescript from '@maykinmedia/eslint-config/typescript';

export default [
  ...,
  ...typescript,
  ...,
]

React

Tip

Included in the recommended config.

The React config enables:

  • JSX accessibility checks that can be done statically
  • the recommended react plugin configuration
  • the JSX automatic runtime
  • react hooks checking

Required plugins

  • eslint-plugin-jsx-a11y
  • eslint-plugin-react
  • eslint-plugin-react-hooks

react-intl support

If you use react-intl for internationalization, you'll want to use the relevant override if you're not using the recommended config.

import {react, reactIntl} from '@maykinmedia/eslint-config/react';

export default [
  ...,
  ...react,
  reactIntl,
  ...,
]

Disabling exhaustive deps checking

The default React configuration enables hook dependency array checking, which may be very frustrating when adopting ESLint into an existing project. You can disable the relevant rule in your Project specific overrides:

{
  name: 'project:react-hooks:disable-exhaustive-deps',
  rules: {
    'react-hooks/exhaustive-deps': 'off',
  },
}

Storybook

Tip

Included in the recommended config.

Storybook itself provides a plugin to lint your story files. Additionally, we enable checking of the .storybook configuration folder.

Required plugins

  • eslint-plugin-storybook
import storybookConfig from '@maykinmedia/eslint-config/storybook';

export default [
  ...,
  ...storybookConfig,
  ...,
]

Import/export

Tip

Included in the recommended config.

Import/export linting protects against broken imports and can help enforce consistent import/export styles. Additionally, our rules block using "legacy" require and define import systems in favour of the import/export module system. We also prevent bundler-specific import syntax (e.g. webpack-specific import directives) to avoid tight coupling with a particular bundler.

The recommended configuration assumes you're either using Typescript, or jsconfig.json with base URLs/path aliases and for that reason, the src directory is automatically added to the module resolution.

Required plugins

  • eslint-plugin-import
  • eslint-import-resolver-typescript when integrating with Typescript
import importConfig from "@maykinmedia/eslint-config/imports";
import typescriptImports from "@maykinmedia/eslint-config/import-with-typescript";

export default [
  importConfig,
  ...typescriptImports,
]

Project specific overrides

Finally, and especially when adapting existing projects, you may want to apply certain project-specific overrides. This can be because you're using something else, or there are known linting violations that are just too much work to address right now.

You can easily apply overrides on top of the recommend config by including your own configuration objects - ESLint applies them all and on conflict, the last one wins.

For example, a recommend config with project specific overrides:

import {ignoreBuildArtifacts} from '@maykinmedia/eslint-config';
import recommended from '@maykinmedia/eslint-config/recommended';

export default [
  // dist, build and storybook-static are the defaults
  ignoreBuildArtifacts(['dist', 'build', 'storybook-static']),
  ...recommended,
  // Project-specific overrides.
  {
    name: 'project/ignore-tests',
    ignores: ['**/*.{spec,test}.{js,jsx,ts,tsx}'],
  },
  {
    name: 'project/allow-webpack-imports',
    rules: {
      'import/no-webpack-loader-syntax': 'off',
    },
  }
];

We recommend always providing a name for a rule as that makes it easier to identify when using the config inspector.

Contributing

Note

It's likely that only contributions from Maykin employees will be accepted, as this package is aimed at Maykin projects. However, we won't stop you from making bugfixes and suggestions, we just can't promise that we'll agree with them.

The various configuration snippets are in the src/ folder. They are organized based on the optional dependencies, i.e. you should be able to use the base config without having eslint-plugin-react installed, or typescript support should be available without the eslint-plugin-import being present.

The recommended configuration assumes that all optional dependencies are available, as that is what we recommend.