Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Build and manage monorepos with Turborepo, Nx, and pnpm workspaces — covering workspace structure, dependency management, task orchestration, caching, CI/CD, and publishing. Use when setting up monorepos, optimizing builds, or managing shared packages.
Build and manage monorepos with Turborepo, Nx, and pnpm workspaces — covering workspace structure, dependency management, task orchestration, caching, CI/CD, and publishing. Use when setting up monorepos, optimizing builds, or managing shared packages.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Then review README.md for any prerequisites, environment setup, or post-install checks. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run.
Build efficient, scalable monorepos that enable code sharing, consistent tooling, and atomic changes across multiple packages and applications.
Setting up a new monorepo or migrating from multi-repo Optimizing build and test performance Managing shared dependencies across packages Configuring CI/CD for monorepos Versioning and publishing packages
Advantages: Shared code and dependencies, atomic commits across projects, consistent tooling, easier refactoring, better code visibility. Challenges: Build performance at scale, CI/CD complexity, access control, large Git history.
ManagerRecommendationNotespnpmRecommendedFast, strict, excellent workspace supportnpmAcceptableBuilt-in workspaces, slower installsYarnAcceptableMature, but pnpm surpasses in most areas
ToolBest ForTrade-offTurborepoMost projectsSimple config, fast caching, Vercel integrationNxLarge orgs, complex graphsFeature-rich but steeper learning curveLernaLegacy projectsMaintenance mode — migrate away Guidance: Start with Turborepo unless you need Nx's code generation, dependency graph visualization, or plugin ecosystem.
my-monorepo/ ├── apps/ │ ├── web/ # Next.js app │ ├── api/ # Backend service │ └── docs/ # Documentation site ├── packages/ │ ├── ui/ # Shared UI components │ ├── utils/ # Shared utilities │ ├── types/ # Shared TypeScript types │ ├── config-eslint/ # Shared ESLint config │ └── config-ts/ # Shared TypeScript configs ├── turbo.json # Turborepo pipeline config ├── pnpm-workspace.yaml # Workspace definition └── package.json # Root package.json Convention: apps/ for deployable applications, packages/ for shared libraries.
# pnpm-workspace.yaml packages: - "apps/*" - "packages/*" // package.json (root) { "name": "my-monorepo", "private": true, "scripts": { "build": "turbo run build", "dev": "turbo run dev", "test": "turbo run test", "lint": "turbo run lint", "type-check": "turbo run type-check", "clean": "turbo run clean && rm -rf node_modules" }, "devDependencies": { "turbo": "^2.0.0", "prettier": "^3.0.0" }, "packageManager": "pnpm@9.0.0" }
// turbo.json { "$schema": "https://turbo.build/schema.json", "globalDependencies": ["**/.env.*local"], "tasks": { "build": { "dependsOn": ["^build"], "outputs": ["dist/**", ".next/**", "!.next/cache/**"], "inputs": ["src/**", "package.json", "tsconfig.json"] }, "test": { "dependsOn": ["build"], "outputs": ["coverage/**"] }, "lint": { "outputs": [] }, "type-check": { "dependsOn": ["^build"], "outputs": [] }, "dev": { "cache": false, "persistent": true } } } Key concepts: dependsOn: ["^build"] — build dependencies first (topological) outputs — what to cache (omit for side-effect-only tasks) inputs — what invalidates cache (default: all files) persistent: true — for long-running dev servers cache: false — disable caching for dev tasks
// packages/ui/package.json { "name": "@repo/ui", "version": "0.0.0", "private": true, "exports": { ".": { "import": "./dist/index.js", "types": "./dist/index.d.ts" }, "./button": { "import": "./dist/button.js", "types": "./dist/button.d.ts" } }, "scripts": { "build": "tsup src/index.ts --format esm,cjs --dts", "dev": "tsup src/index.ts --format esm,cjs --dts --watch" }, "devDependencies": { "@repo/config-ts": "workspace:*", "tsup": "^8.0.0" } }
npx create-nx-workspace@latest my-org # Generate projects nx generate @nx/react:app my-app nx generate @nx/js:lib utils // nx.json { "targetDefaults": { "build": { "dependsOn": ["^build"], "inputs": ["production", "^production"], "cache": true }, "test": { "inputs": ["default", "^production"], "cache": true } }, "namedInputs": { "default": ["{projectRoot}/**/*"], "production": ["default", "!{projectRoot}/**/*.spec.*"] } } # Nx-specific commands nx build my-app nx affected:build --base=main # Only build what changed nx graph # Visualize dependency graph nx run-many --target=build --all --parallel=3 Nx advantage: nx affected computes exactly which projects changed, skipping unaffected ones entirely.
# Install in specific package pnpm add react --filter @repo/ui pnpm add -D typescript --filter @repo/ui # Install workspace dependency pnpm add @repo/ui --filter web # Install in root (shared dev tools) pnpm add -D eslint -w # Run script in specific package pnpm --filter web dev pnpm --filter @repo/ui build # Run in all packages pnpm -r build # Filter patterns pnpm --filter "@repo/*" build pnpm --filter "...web" build # web + all its dependencies # Update all dependencies pnpm update -r
# Hoist shared dependencies for compatibility shamefully-hoist=true # Strict peer dependency management auto-install-peers=true strict-peer-dependencies=true
// packages/config-ts/base.json { "compilerOptions": { "strict": true, "esModuleInterop": true, "skipLibCheck": true, "module": "ESNext", "moduleResolution": "bundler", "resolveJsonModule": true, "isolatedModules": true, "declaration": true } } // apps/web/tsconfig.json { "extends": "@repo/config-ts/base.json", "compilerOptions": { "outDir": "dist", "rootDir": "src" }, "include": ["src"] }
# Turborepo + Vercel remote cache npx turbo login npx turbo link # Now builds share cache across CI and all developers # First build: 2 minutes. Cache hit: 0 seconds.
{ "tasks": { "build": { "dependsOn": ["^build"], "outputs": ["dist/**", ".next/**"], "inputs": ["src/**/*.tsx", "src/**/*.ts", "package.json"] } } } Critical: Define inputs precisely. If a build only depends on src/, don't let changes to README.md invalidate the cache.
name: CI on: push: branches: [main] pull_request: branches: [main] jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 with: fetch-depth: 0 # Required for affected commands - uses: pnpm/action-setup@v4 with: version: 9 - uses: actions/setup-node@v4 with: node-version: 20 cache: "pnpm" - run: pnpm install --frozen-lockfile - run: pnpm turbo run build test lint type-check
Lock dependency versions — Use exact versions or lock files across the workspace Centralize configs — ESLint, TypeScript, Prettier in shared packages Keep the graph acyclic — No circular dependencies between packages Define cache inputs/outputs precisely — Incorrect cache config wastes time or serves stale builds Share types between frontend/backend — Single source of truth for contracts Unit tests in packages, E2E in apps — Match test scope to package scope README in each package — What it does, how to develop, how to use Use changesets for versioning — Automated, reviewable release process
PitfallFixCircular dependenciesRefactor shared code into a third packagePhantom dependencies (using deps not in package.json)Use pnpm strict modeIncorrect cache inputsAdd missing files to inputs arrayOver-sharing codeOnly share genuinely reusable codeMissing fetch-depth: 0 in CIRequired for affected commands to compare historyCaching dev tasksSet cache: false and persistent: true
NEVER use * for workspace dependency versions — Use workspace:* with pnpm NEVER skip --frozen-lockfile in CI — Ensures reproducible builds NEVER cache dev server tasks — They're long-running, not cacheable NEVER create circular package dependencies — Breaks build ordering NEVER hoist without understanding — shamefully-hoist is a compatibility escape hatch, not a default
Related: service-layer-architecture — API patterns within monorepo apps Related: postgres-job-queue — Background jobs for monorepo services
Workflow acceleration for inboxes, docs, calendars, planning, and execution loops.
Largest current source with strong distribution and engagement signals.