@feature-sliced/eslint-config
Version:
🍰 Lint feature-sliced concepts by existing eslint plugins
63 lines (46 loc) • 2.41 kB
Markdown
# @feature-sliced/import-order
#### Reference: [Layers](https://feature-sliced.design/docs/reference/layers)
## Usage
Add `"@feature-sliced/eslint-config/rules/import-order"` to your `extends` section in ESLint config.
```js
// 👎 Fail
import { getSmth } from "./lib";
import axios from "axios";
import { data } from "../fixtures";
import { authModel } from "entities/auth";
import { Button } from "shared/ui";
import { LoginForm } from "features/login-form";
import { Header } from "widgets/header";
import { debounce } from "shared/lib/fp";
// 👍 Pass
import axios from "axios"; // 1) external libs
import { Header } from "widgets/header"; // 2.1) Layers: widgets
import { LoginForm } from "features/login-form"; // 2.2) Layers: features
import { authModel } from "entities/auth"; // 2.3) Layers: entities
import { Button } from "shared/ui"; // 2.4) Layers: shared
import { debounce } from "shared/lib/fp"; // 2.4) Layers: shared
import { data } from "../fixtures"; // 3) parent
import { getSmth } from "./lib"; // 4) sibling
```
> `WARN:` Rule supports layer-based imports, but [its recommended](../public-api) to prefer more specified imports
>
> ```js
> import { ... } from "shared"; // Non-critical
> import { ... } from "shared/ui"; // Better
> import { ... } from "shared/ui/button"; // Perfect
> ```
## Experimental
**With reversed order ("from abstract to specific") and spaces between layers groups**
[(why experimental?)](https://github.com/feature-sliced/eslint-config/issues/85)
Add `"@feature-sliced/eslint-config/rules/import-order/experimental"` to your `extends` section in ESLint config.
<sup>*Only for @^0.1.0-beta.4*</sup>
```js
import axios from "axios"; // 1) external libs
import { debounce } from "shared/lib/fp"; // 2.1) Layers: shared
import { Button } from "shared/ui"; // 2.1) Layers: shared
import { authModel } from "entities/auth"; // 2.2) Layers: entities
import { LoginForm } from "features/login-form"; // 2.3) Layers: features
import { Header } from "widgets/header"; // 2.4) Layers: widgets
import { data } from "../fixtures"; // 3) parent
import { getSmth } from "./lib"; // 4) sibling
```