The purpose of this config is to keep extremely easy to use ESLint, Typescript, and Prettier in any project.
ESLint - this is the best tool in the world that improves your Javascript code. It acts as a guide showing you good practices and helping you to avoid unnecessary issues.
Prettier - allows you to keep your code style consistent between many environments and many projects.
Typescript - is another excellent tool that could be helpful in our daily work - this one is bringing to us static typings.
The only disadvantage of them is that they are not very easy to configure, especially if you want to connect them with React or some other framework. This project tries to solve this problem.
- Install
- Setting up a basic project
- Setting up a React project
- Setting up a Node project
- Setting up a project with Node and React
- What's inside
The first thing you have to do is to remove all eslint dependencies (including plugins, almost everything that contains eslint in the name) from your package.json. Now, you can install this package:
npm i --save-dev eslint-config-turbocharge
This config contains a few presets for different kinds of projects:
- react
- nodejs
- react-native (TODO)
Let's say that you have a project structure like this and already installed eslint-config-turbocharge:
your-project
├── package.json
├── config.js
├── src
│ ├── A.ts
│ └── B.ts
└── node_modules
To enable eslint - you will need proper .eslintrc, for typescript - tsconfig.json and for prettier - .prettierrc
.eslintrc
{ "extends": "turbocharge", "root": true }
.tsconfig.json
{ "extends": "eslint-config-turbocharge/node/tsconfig.json" }
.prettierrc
"eslint-config-turbocharge/prettier"
Our example project should look like this:
your-project
├── package.json
├── .eslintrc <== new
├── .prettierrc <== new
├── .tsconfig.json <== new
├── config.js
├── src
│ ├── A.ts
│ └── B.ts
└── node_modules
Now everything is set up.
We are going to use a project structure the same as for Basic setup. But now src folder will contain React components.
your-project
├── package.json
├── .eslintrc
├── .prettierrc
├── .tsconfig.json
├── config.js
├── src
│ ├── .tsconfig.json <== new
│ ├── .eslintrc <== new
│ ├── App.tsx
│ └── Navbar.tsx
└── node_modules
.eslintrc
{ "extends": "turbocharge/react", "root": true }
.tsconfig.json
{ "extends": "eslint-config-turbocharge/react/tsconfig.json" }
First we are going to put additional .tsconfig.json and .eslintrc files inside src folder, also with "root": true property - this is crucial.
This way we change eslint/typescript behavior only for src files. Top-level files like config.js (i.e. webpack.config.js) will not report any problems related to React rules.
We are going to use a project structure the same as for Basic setup. But now src folder will contain Node files.
your-project
├── package.json
├── .eslintrc
├── .prettierrc
├── .tsconfig.json
├── config.js
├── src
│ ├── .eslintrc <== new
│ ├── service.ts
│ ├── server.ts
│ └── controller.ts
└── node_modules
.eslintrc
{ "extends": "turbocharge/node", "root": true }
We just need to put .eslintrc file inside src folder, with "root": true property - this is crucial.
This way we change eslint behavior only for src files. Top-level files like config.js (i.e. webpack.config.js) will not report any problems related to Node rules.
Looking at React and Node examples, we can try to mix them up in project which contain both React and Node code.
Example project structure based on Basic project:
your-project
├── package.json
├── .eslintrc
├── .prettierrc
├── .tsconfig.json
├── config.js
├── src-backend
│ ├── .eslintrc <==
│ ├── service.ts
│ ├── server.ts
│ └── controller.ts
├── src-frontend
│ ├── .tsconfig.json <==
│ ├── .eslintrc <==
│ ├── service.ts
│ ├── server.ts
│ └── controller.ts
└── node_modules
.eslintrc
{ "extends": "turbocharge/node", "root": true }
.eslintrc
{ "extends": "turbocharge/react", "root": true }
.tsconfig.json
{ "extends": "eslint-config-turbocharge/react/tsconfig.json" }
Simple as that.
- "root": true - makes you sure that the only config you are using is defined in that file.
This project does not contain any new eslint-rules, it is just a set of correctly preconfigured rules of the modules that are listed below:
Common:
- https://www.npmjs.com/package/eslint-config-prettier
- https://www.npmjs.com/package/eslint-plugin-import
- https://www.npmjs.com/package/eslint-plugin-simple-import-sort
- https://www.npmjs.com/package/eslint-plugin-unicorn
- https://www.npmjs.com/package/@typescript-eslint/eslint-plugin
- https://www.npmjs.com/package/@typescript-eslint/parser
React:
- https://www.npmjs.com/package/eslint-plugin-react
- https://www.npmjs.com/package/eslint-plugin-react-hooks
- https://www.npmjs.com/package/eslint-plugin-jsx-a11y
- https://www.npmjs.com/package/eslint-plugin-styled-components-a11y
- https://www.npmjs.com/package/eslint-plugin-testing-library
NodeJS:
@q-nick