eslint-plugin-feature-sliced-design
v1.11.2
Published
Plugin for feature-sliced designed projects
Downloads
518
Maintainers
Readme
eslint-plugin-feature-sliced-design
An ESLint plugin for enforcing best practices of the Feature-Sliced Design methodology in your project.
Installation
npm install --save-dev eslint-plugin-feature-sliced-design
Usage
Add feature-sliced-design
to the plugins section of your ESLint configuration:
{
"plugins": ["feature-sliced-design"],
"rules": {
"feature-sliced-design/layers-hierarchy": [
"error",
{
"alias": "@",
"projectDir": "src"
}
],
"feature-sliced-design/public-api-slice-import": [
"error",
{
"alias": "@",
"projectDir": "src",
"ignoreLayers": ["shared", "app"],
"insideProjectOnly": false
}
],
"feature-sliced-design/relative-path-within-slice": [
"error",
{
"alias": "@",
"projectDir": "src"
}
]
}
}
Rules
feature-sliced-design/layers-hierarchy
Enforces the correct import hierarchy based on Feature-Sliced Design principles.
feature-sliced-design/public-api-slice-import
Enforces that slices can only be imported via their public API.
feature-sliced-design/relative-path-within-slice
Ensures that all imports within a slice use relative paths instead of absolute aliases.
Configuration Options
alias
: The alias used for imports (e.g.,@
). No alias by default.projectDir
: The root directory of your frontend project.src
by default.ignoreLayers
(forpublic-api-slice-import
): Layers that should be ignored in rule enforcement.insideProjectOnly
(forpublic-api-slice-import
): Iftrue
, it's allowed to import from non-public API in files outside project directory.
License
ISC