๐ Monorepo support
General guidelinesโ
While Sheriff can technically be used at the root of monorepos, it's not recommended.
It works best when applied to individual packages within a monorepo.
Examplesโ
โ
โโโ apps
โ โโโ website
โ โ โโโ eslint.config.js
โ โโโ docs
โ โ โโโ eslint.config.js
โโโ packages
โ โโโ ui
โ โ โโโ eslint.config.js
โ โโโ utils
โ โ โโโ eslint.config.js
โ โโโ types
โ โ โโโ eslint.config.js
โโโ node_modules
โโโ README
โโโ package.json
โโโ pnpm-lock.yaml
โโโ .gitignore
โ
โโโ apps
โ โโโ website
โ โโโ docs
โโโ packages
โ โโโ ui
โ โโโ utils
โ โโโ types
โโโ node_modules
โโโ eslint.config.js
โโโ README
โโโ package.json
โโโ pnpm-lock.yaml
โโโ .gitignore
Usage in VSCodeโ
To make use of the ESLint VScode extension in monorepos, use the eslint.workingDirectories setting.
Setup with create-sheriff-config
โ
If you want to use create-sheriff-config
to bootstrap Sheriff in one of your workspaces, you can actually do so by following the general usage rules of workspaces, meaning that you should run the command from the root of your monorepo, and then filter by the workspace you want to apply Sheriff to. A chain of prompts will start to guide you through the correct process of installation.
Examples:
- npm
- Yarn
- pnpm
npx create-sheriff-config --filter=packages/my-package
npx create-sheriff-config --filter=packages/my-package
pnpm dlx create-sheriff-config --filter=packages/my-package