2019-05-24 18:38:25 +03:00
|
|
|
# Ely.by ESLint rules
|
|
|
|
|
|
|
|
Set of ESLint rules used in development of Ely.by JS projects. Contains rules for pure JS, JSX, ReactJS and TS.
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
First of all install Ely.by ESLint plugin and `eslint` peer dependency via NPM:
|
2019-05-24 18:38:25 +03:00
|
|
|
|
|
|
|
```sh
|
|
|
|
npm install @elyby/eslint-plugin eslint --save-dev
|
2019-05-28 23:32:01 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
Or via yarn:
|
|
|
|
|
|
|
|
```sh
|
2019-05-24 18:38:25 +03:00
|
|
|
yarn add -D @elyby/eslint-plugin eslint
|
|
|
|
```
|
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
## Configuration
|
|
|
|
|
|
|
|
The configuration is divided into several parts. The `base` provides only pure js checks. To use it,
|
|
|
|
simply add the `plugin:@elyby/base` configuration to the `extends` block:
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"extends": [
|
2019-06-03 14:16:46 +03:00
|
|
|
"plugin:@elyby/base"
|
2019-05-28 23:32:01 +03:00
|
|
|
]
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### React
|
|
|
|
|
|
|
|
The configuration for React requires additional dependencies. Install them first:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# NPM:
|
|
|
|
npm install eslint-plugin-react eslint-plugin-react-hooks --save-dev
|
|
|
|
# Yarn:
|
|
|
|
yarn add -D eslint-plugin-react eslint-plugin-react-hooks
|
|
|
|
```
|
|
|
|
|
|
|
|
Then add the `plugin:@elyby/react` configuration to the `extends` block:
|
2019-05-24 18:38:25 +03:00
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
```json
|
|
|
|
{
|
|
|
|
"extends": [
|
2019-06-03 14:16:46 +03:00
|
|
|
"plugin:@elyby/base",
|
2019-05-28 23:32:01 +03:00
|
|
|
"plugin:@elyby/react"
|
|
|
|
]
|
2019-05-24 18:38:25 +03:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
### TypeScript
|
|
|
|
|
|
|
|
Configuration for TypeScript also requires additional libraries:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# NPM:
|
|
|
|
npm install @typescript-eslint/parser @typescript-eslint/eslint-plugin --save-dev
|
|
|
|
# Yarn:
|
|
|
|
yarn add -D @typescript-eslint/parser @typescript-eslint/eslint-plugin
|
|
|
|
```
|
|
|
|
|
|
|
|
Then add the `plugin:@elyby/react` configuration to the `extends` block:
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"extends": [
|
2019-06-03 14:16:46 +03:00
|
|
|
"plugin:@elyby/base",
|
2019-05-28 23:32:01 +03:00
|
|
|
"plugin:@elyby/typescript"
|
|
|
|
]
|
|
|
|
}
|
|
|
|
```
|
2019-05-24 18:38:25 +03:00
|
|
|
|
|
|
|
You may still wish to override some of our rules, as well as the rest of our eslint configuration settings.
|
|
|
|
For example, you can specify the preferred `env` for eslint:
|
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
```json
|
|
|
|
{
|
|
|
|
"env": {
|
|
|
|
"browser": true,
|
|
|
|
"es6": true
|
|
|
|
}
|
|
|
|
}
|
2019-05-24 18:38:25 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
## Using our custom fixers
|
|
|
|
|
|
|
|
First of all, you must install Ely.by's ESLint plugin as described in the [installation chapter](#installation).
|
|
|
|
After that you can enable our custom rules with defining our plugin in `plugins` section:
|
|
|
|
|
2019-05-28 23:32:01 +03:00
|
|
|
```json
|
|
|
|
{
|
|
|
|
"plugins": [
|
|
|
|
"@elyby"
|
|
|
|
]
|
|
|
|
}
|
2019-05-24 18:38:25 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
After that all custom rules will be available for use.
|
|
|
|
|
|
|
|
### List of supported rules
|
|
|
|
|
|
|
|
* [@elyby/jsx-closing-bracket-location](docs/rules/jsx-closing-bracket-location.md):
|
|
|
|
Validate closing bracket location in JSX
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Ely.by ESLint plugin is licensed under the [MIT License](LICENSE.md).
|