UNPKG

@justia/eslint-config-ts

Version:
94 lines (67 loc) 2.79 kB
<!-- UPDATE-PACKAGES:START - Do not remove or modify this section --> # `@justia/eslint-config-ts` ![version 3.0.2](https://img.shields.io/badge/version-3.0.2-blue?style=flat-square) <!-- omit from toc --> > Justia's ESLint configuration for TypeScript projects <!-- UPDATE-PACKAGES:END --> This package uses [`@justia/eslint-config`](https://github.com/justia/front-end-projects/tree/develop/packages/eslint-config) as a base configuration and modifies **import** and **prettier** rules to support TypeScript. ## Install Install the correct versions of the peer dependencies, which are listed by the command: ```shell npm info "@justia/eslint-config-ts@latest" peerDependencies ``` If using **npm 5+**, use this shortcut ```shell npx install-peerdeps --dev @justia/eslint-config-ts ``` If using npm < 5, Linux/OSX users can run ```shell ( export PKG=@justia/eslint-config-ts; npm info "$PKG@latest" peerDependencies --json | command sed 's/[\{\},]//g ; s/: /@/g' | xargs npm install --save-dev "$PKG@latest" ) ``` Which produces and runs a command like: ```shell npm install --save-dev @justia/eslint-config-ts eslint@^#.#.# prettier@^#.#.# eslint-config-prettier@^#.#.# eslint-plugin-import@^#.#.# eslint-plugin-prettier@^#.#.# eslint-plugin-promise@^#.#.# @typescript-eslint/parser@^#.#.# @typescript-eslint/eslint-plugin@^#.#.# ``` ## Usage This configuration contains all of our ESLint rules, including ECMAScript 6+, TypeScript and formatting styles. It requires the following external packages: - `eslint` - `prettier` - `eslint-config-prettier` - `eslint-plugin-import` - `eslint-plugin-prettier` - `eslint-plugin-promise` - `@typescript-eslint/parser` - `@typescript-eslint/eslint-plugin` After installation of packages and its peer dependencies, add the following configuration to your ESLint configuration file: ```json { "extends": ["@justia/eslint-config-ts"], "parserOptions": { "project": "./tsconfig.json" } } ``` Alter your `eslint` command to include `ts` files: ```shell eslint --ext .js,.ts ./ ``` ### VS Code Issue For those how use VS Code, it is possible you are getting the following error message: > Parsing error: "parserOptions.project" has been set for @typescript-eslint/parser. > The file does not match your project config: .eslintrc.js. > The file must be included in at least one of the projects provided. To fix it you will need to add a ESLint-specific TypeScript configuration file (`tsconfig.eslint.json`): ```json { "extends": "./tsconfig.json", "compilerOptions": { "noEmit": true }, "include": [ ".eslintrc.js", // Also re-add the patterns you define in the original `include` key. ] } ``` Then change the `parserOptions.project` to `tsconfig.eslint.json`.