link-workspace-packages

nrwl/nx-ai-agents-config · updated Apr 8, 2026

$npx skills add https://github.com/nrwl/nx-ai-agents-config --skill link-workspace-packages
0 commentsdiscussion
summary

Link workspace packages in monorepos across npm, yarn, pnpm, and bun.

  • Detects package manager via packageManager field or lockfile presence, then uses the appropriate workspace linking command for each manager
  • pnpm and yarn use workspace: protocol; npm auto-symlinks workspace packages; bun supports workspace: protocol
  • Resolves \"cannot find module\" and import resolution errors by adding dependencies between sibling packages with proper symlink creation
  • Each manager has different
skill.md

Link Workspace Packages

Add dependencies between packages in a monorepo. All package managers support workspaces but with different syntax.

Detect Package Manager

Check whether there's a packageManager field in the root-level package.json.

Alternatively check lockfile in repo root:

  • pnpm-lock.yaml → pnpm
  • yarn.lock → yarn
  • bun.lock / bun.lockb → bun
  • package-lock.json → npm

Workflow

  1. Identify consumer package (the one importing)
  2. Identify provider package(s) (being imported)
  3. Add dependency using package manager's workspace syntax
  4. Verify symlinks created in consumer's node_modules/

pnpm

Uses workspace: protocol - symlinks only created when explicitly declared.

# From consumer directory
pnpm add @org/ui --workspace

# Or with --filter from anywhere
pnpm add @org/ui --filter @org/app --workspace

Result in package.json:

{ "dependencies": { "@org/ui": "workspace:*" } }

yarn (v2+/berry)

Also uses workspace: protocol.

yarn workspace @org/app add @org/ui

Result in package.json:

{ "dependencies": { "@org/ui": "workspace:^" } }

npm

No workspace: protocol. npm auto-symlinks workspace packages.

npm install @org/ui --workspace @org/app

Result in package.json:

{ "dependencies": { "@org/ui": "*" } }

npm resolves to local workspace automatically during install.


bun

Supports workspace: protocol (pnpm-compatible).

cd packages/app && bun add @org/ui

Result in package.json:

{ "dependencies": { "@org/ui": "workspace:*" } }

Examples

Example 1: pnpm - link ui lib to app

pnpm add @org/ui --filter @org/app --workspace

Example 2: npm - link multiple packages

npm install @org/data-access @org/ui --workspace @org/dashboard

Example 3: Debug "Cannot find module"

  1. Check if dependency is declared in consumer's package.json
  2. If not, add it using appropriate command above
  3. Run install (pnpm install, npm install, etc.)

Notes

  • Symlinks appear in <consumer>/node_modules/@org/<package>
  • Hoisting differs by manager:
    • npm/bun: hoist shared deps to root node_modules
    • pnpm: no hoisting (strict isolation, prevents phantom deps)
    • yarn berry: uses Plug'n'Play by default (no node_modules)
  • Root package.json should have "private": true to prevent accidental publish

Discussion

Product Hunt–style comments (not star reviews)
  • No comments yet — start the thread.
general reviews

Ratings

4.725 reviews
  • Dhruvi Jain· Dec 16, 2024

    link-workspace-packages is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.

  • James Kapoor· Dec 8, 2024

    Solid pick for teams standardizing on skills: link-workspace-packages is focused, and the summary matches what you get after install.

  • Oshnikdeep· Nov 7, 2024

    Useful defaults in link-workspace-packages — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.

  • Ganesh Mohane· Oct 26, 2024

    Registry listing for link-workspace-packages matched our evaluation — installs cleanly and behaves as described in the markdown.

  • Sakshi Patil· Sep 5, 2024

    link-workspace-packages fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.

  • Aditi Verma· Sep 1, 2024

    Registry listing for link-workspace-packages matched our evaluation — installs cleanly and behaves as described in the markdown.

  • Chaitanya Patil· Aug 24, 2024

    link-workspace-packages has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Aditi Robinson· Aug 20, 2024

    Useful defaults in link-workspace-packages — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.

  • Rahul Santra· Jul 23, 2024

    Solid pick for teams standardizing on skills: link-workspace-packages is focused, and the summary matches what you get after install.

  • Piyush G· Jul 15, 2024

    Keeps context tight: link-workspace-packages is the kind of skill you can hand to a new teammate without a long onboarding doc.

showing 1-10 of 25

1 / 3