Skip to main content

Manual setup

Follow these steps:

  1. Install the package from npm.

    npm install -D eslint eslint-define-config eslint-config-sheriff
  2. Create a eslint.config.mjs file at the root of your project and copy/paste the contents of the following snippet of code:

    eslint.config.mjs
    import { sheriff } from "eslint-config-sheriff";
    import { defineFlatConfig } from "eslint-define-config";

    const sheriffOptions = {
    react: false,
    next: false,
    astro: false,
    lodash: false,
    remeda: false,
    playwright: false,
    jest: false,
    vitest: false,
    };

    export default defineFlatConfig([...sheriff(sheriffOptions)]);

    or, if you already have a eslint.config.mjs in your project, just append Sheriff to the configs array, like this:

    eslint.config.mjs
    import { sheriff } from "eslint-config-sheriff"; // add this
    import { defineFlatConfig } from "eslint-define-config"; // add this
    // my other imports...

    // add this
    const sheriffOptions = {
    react: false,
    next: false,
    astro: false,
    lodash: false,
    remeda: false,
    playwright: false,
    jest: false,
    vitest: false,
    };

    export default [
    ...sheriff(sheriffOptions), // add this
    // my other configurations...
    ];
  3. Adopt eslint.config.ts (optional).

    If you want to have a .ts configuration file instead of the default .js file, follow these steps:

    • make sure your installed ESLint version is >=9.9.0

    • install jiti

      npm install -D jiti
    • change the extension of eslint.config.mjs from .mjs to .ts

    • define the types of the sheriffOptions object:

      eslint.config.ts
      import { sheriff, type SheriffSettings } from "eslint-config-sheriff";
      import { defineFlatConfig } from "eslint-define-config";

      const sheriffOptions: SheriffSettings = {
      react: false,
      next: false,
      astro: false,
      lodash: false,
      remeda: false,
      playwright: false,
      jest: false,
      vitest: false,
      };

      export default defineFlatConfig([...sheriff(sheriffOptions)]);
  4. Configure Sheriff (optional)

  5. Setup Prettier (optional)

  6. Setup VSCode support (optional)

warning

Sheriff is based on the new format of ESLint configs. You cannot extend Sheriff from an old config format, it wouldn't work.