link-workspace-packages
53
总安装量
53
周安装量
#4046
全站排名
安装命令
npx skills add https://github.com/nrwl/nx-ai-agents-config --skill link-workspace-packages
Agent 安装分布
github-copilot
50
gemini-cli
49
codex
49
kimi-cli
46
amp
45
Skill 文档
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â pnpmyarn.lockâ yarnbun.lock/bun.lockbâ bunpackage-lock.jsonâ npm
Workflow
- Identify consumer package (the one importing)
- Identify provider package(s) (being imported)
- Add dependency using package manager’s workspace syntax
- 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”
- Check if dependency is declared in consumer’s
package.json - If not, add it using appropriate command above
- 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)
- npm/bun: hoist shared deps to root
- Root
package.jsonshould have"private": trueto prevent accidental publish