/eslint-prettier-typescript-config

Documentation on how to get started with linting and formatting in a TypeScript project

Apache License 2.0Apache-2.0

Getting Started with TypeScript, ESLint and Prettier

This project was once a collection of shared MOIA TypeScript, eslint and prettier configurations. It's now just a README.

There will be no further releases of @moia-oss/eslint-prettier-typescript-config. The last published version is 3.0.9.

This document is intended to be a starting point for setting up your TypeScript project with ESLint and Prettier.

The following steps presume you have an existing repository with a package.json (you can do this with npm init) that is of type "module".

  1. Install TypeScript

    npm install --save-dev typescript
  2. Configure TypeScript

    Create a tsconfig.json in your project root:

    {
      "compilerOptions": {
        "target": "es6",
        "module": "esnext",
        "strict": true,
        "esModuleInterop": true,
        "outDir": "./dist"
      },
      "include": ["src/**/*"]
    }
  3. Install Prettier

    npm install --save-dev prettier
  4. Configure Prettier

    Create a .prettierrc file in your project root:

    {
      "semi": false,
      "singleQuote": true
    }
  5. Install ESLint and ESLint plugins

    npm install --save-dev eslint @eslint/js eslint-config-prettier typescript-eslint
  6. Configure ESLint

    Create an eslint.config.js file in your project root:

    import eslint from "@eslint/js";
    import prettier from "eslint-config-prettier";
    import typescript from "typescript-eslint";
    
    export default [
      {
        ignores: ["node_modules/*", "dist/*"],
      },
      {
        languageOptions: {
          parserOptions: {
            projectService: true,
          },
        },
      },
      eslint.configs.recommended,
      ...typescript.configs.recommended,
      // prettier should be the last config because it disables all formatting rules
      prettier,
    ];
  7. Add Scripts

    Edit your package.json to include build, lint, and format scripts:

    "scripts": {
      "build": "tsc",
      "lint": "eslint ./src",
      "format": "prettier ./src --check"
    }

VSCode

  • To enable auto-formatting (prettier) and auto-fixing (ESLint) in VSCode, you can add this to your .vscode/settings.json:

    {
      "editor.formatOnSave": true,
      "editor.defaultFormatter": "esbenp.prettier-vscode",
      "editor.codeActionsOnSave": {
        "source.fixAll.eslint": true
      }
    }
  • To recommend the ESLint and Prettier plugins for VSCode, you can add this to your .vscode/extensions.json:

    {
      "recommendations": ["esbenp.prettier-vscode", "dbaeumer.vscode-eslint"]
    }