@workyloop/eslint-config

0.4.0 • Public • Published

@workyloop/eslint-config

Workyloop ESLint config for React Native, React and Node.js projects, utilizing Flow, TypeScript, Prettier and Jest with sensible defaults.

Installation

With Yarn:

yarn add --dev eslint @workyloop/eslint-config

Or with npm:

npm install --save-dev eslint @workyloop/eslint-config

Usage

You can choose one of the following environments to work with by extending your ESLint config (.eslintrc, or eslintConfig field in package.json) with @workyloop config tailored to your project.

React Native config

Usage:

{
  "extends": "@workyloop"
}

Plugins used:

Additionally, it sets "react-native/react-native" environment and native platform extensions to resolve.

React config

Usage:

{
  "extends": "@workyloop/eslint-config/react"
}

Plugins used:

Node config

Usage:

{
  "extends": "@workyloop/eslint-config/node"
}

Plugins used:

Additionally, it sets es6 and node environments.

Example of extending the configuration

{
  "extends": "@workyloop",
  "rules": {
    "global-require": 0,
    "prefer-destructuring": 0
  }
}

TypeScript

TypeScript is supported out-of-the-box, including importing JS files from TS files and vice-versa. All you need to do is to make sure you have typescript module installed.

Then when running ESLint add --ext '.js,.ts' (you might need also .jsx, .tsx) option, for example:

yarn eslint --ext '.js,.ts' ./src

parserOptions.project is set to ./tsconfig.json. You may need to adjust that.

To do so, you'll need to override our setup for TS files in your ESLint config:

{
  "overrides": [
    {
      "files": ["*.ts", "*.tsx"],
      "parserOptions": {
        "project": "./packages/**/tsconfig.json"
      }
    }
  ]
}

VSCode

If you're VSCode user, you may find adding this config to your .vscode/settings.json helpful:

{
  "eslint.validate": [
    {
      "language": "javascript",
      "autoFix": true
    },
    {
      "language": "javascriptreact",
      "autoFix": true
    },
    {
      "language": "typescript",
      "autoFix": true
    },
    {
      "language": "typescriptreact",
      "autoFix": true
    }
  ]
}

Package Sidebar

Install

npm i @workyloop/eslint-config

Weekly Downloads

1

Version

0.4.0

License

MIT

Unpacked Size

12 kB

Total Files

8

Last publish

Collaborators

  • rghorbani