@justia/eslint-config-ts
Version:
Justia's ESLint configuration for TypeScript projects
94 lines (67 loc) • 2.79 kB
Markdown
<!-- UPDATE-PACKAGES:START - Do not remove or modify this section -->
# `/eslint-config-ts`  <!-- omit from toc -->
> Justia's ESLint configuration for TypeScript projects
<!-- UPDATE-PACKAGES:END -->
This package uses [`/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 /eslint-config-ts
```
If using npm < 5, Linux/OSX users can run
```shell
(
export PKG=/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 /eslint-config-ts eslint@^#.#.# prettier@^#.#.# eslint-config-prettier@^#.#.# eslint-plugin-import@^#.#.# eslint-plugin-prettier@^#.#.# eslint-plugin-promise@^#.#.# @typescript-eslint/parser@^#.#.# -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`
- `-eslint/parser`
- `-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 -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`.