Skill

SkillsSoftware Development › Dev workflow & Git

monorepo-navigator

Monorepo Navigator

Freerisk: low
monoreponavigatortypescriptgit

The full skill

— name: "monorepo-navigator" description: "Monorepo Navigator" — # Monorepo Navigator **Tier:** POWERFUL **Category:** Engineering **Domain:** Monorepo Architecture / Build Systems — ## Overview Navigate, manage, and optimize monorepos. Covers Turborepo, Nx, pnpm workspaces, and Lerna. Enables cross-package impact analysis, selective builds/tests on affected packages only, remote caching, dependency graph visualization, and structured migrations from multi-repo to monorepo. Includes Claude Code configuration for workspace-aware development. — ## Core Capabilities – **Cross-package impact analysis** — determine which apps break when a shared package changes – **Selective commands** — run tests/builds only for affected packages (not everything) – **Dependency graph** — visualize package relationships as Mermaid diagrams – **Build optimization** — remote caching, incremental builds, parallel execution – **Migration** — step-by-step multi-repo → monorepo with zero history loss – **Publishing** — changesets for versioning, pre-release channels, npm publish workflows – **Claude Code config** — workspace-aware CLAUDE.md with per-package instructions — ## When to Use Use when: – Multiple packages/apps share code (UI components, utils, types, API clients) – Build times are slow because everything rebuilds when anything changes – Migrating from multiple repos to a single repo – Need to publish packages to npm with coordinated versioning – Teams work across multiple packages and need unified tooling Skip when: – Single-app project with no shared packages – Team/project boundaries are completely isolated (polyrepo is fine) – Shared code is minimal and copy-paste overhead is acceptable — ## Tool Selection | Tool | Best For | Key Feature | |—|—|—| | **Turborepo** | JS/TS monorepos, simple pipeline config | Best-in-class remote caching, minimal config | | **Nx** | Large enterprises, plugin ecosystem | Project graph, code generation, affected commands | | **pnpm workspaces** | Workspace protocol, disk efficiency | `workspace:*` for local package refs | | **Lerna** | npm publishing, versioning | Batch publishing, conventional commits | | **Changesets** | Modern versioning (preferred over Lerna) | Changelog generation, pre-release channels | Most modern setups: **pnpm workspaces + Turborepo + Changesets** — ## Turborepo → See references/monorepo-tooling-reference.md for details ## Workspace Analyzer “`bash python3 scripts/monorepo_analyzer.py /path/to/monorepo python3 scripts/monorepo_analyzer.py /path/to/monorepo –json “` Also see `references/monorepo-patterns.md` for common architecture and CI patterns. ## Common Pitfalls | Pitfall | Fix | |—|—| | Running `turbo run build` without `–filter` on every PR | Always use `–filter=…[origin/main]` in CI | | `workspace:*` refs cause publish failures | Use `pnpm changeset publish` — it replaces `workspace:*` with real versions automatically | | All packages rebuild when unrelated file changes | Tune `inputs` in turbo.json to exclude docs, config files from cache keys | | Shared tsconfig causes one package to break all type-checks | Use `extends` properly — each package extends root but overrides `rootDir` / `outDir` | | git history lost during migration | Use `git filter-repo –to-subdirectory-filter` before merging — never move files manually | | Remote cache not working in CI | Check TURBO_TOKEN and TURBO_TEAM env vars; verify with `turbo run build –summarize` | | CLAUDE.md too generic — Claude modifies wrong package | Add explicit "When working on X, only touch files in apps/X" rules per package CLAUDE.md | — ## Best Practices 1. **Root CLAUDE.md defines the map** — document every package, its purpose, and dependency rules 2. **Per-package CLAUDE.md defines the rules** — what's allowed, what's forbidden, testing commands 3. **Always scope commands with –filter** — running everything on every change defeats the purpose 4. **Remote cache is not optional** — without it, monorepo CI is slower than multi-repo CI 5. **Changesets over manual versioning** — never hand-edit package.json versions in a monorepo 6. **Shared configs in root, extended in packages** — tsconfig.base.json, .eslintrc.base.js, jest.base.config.js 7. **Impact analysis before merging shared package changes** — run affected check, communicate blast radius 8. **Keep packages/types as pure TypeScript** — no runtime code, no dependencies, fast to build and type-check