Generate code using nx generators. INVOKE IMMEDIATELY when user mentions scaffolding, setup, structure, creating apps/libs, or setting up project structure. Trigger words - scaffold, setup, create a ... app, create a ... lib, project structure, generate, add a new project. ALWAYS use this BEFORE calling nx_docs or exploring - this skill handles discovery internally.
68
83%
Does it follow best practices?
Impact
—
No eval scenarios have been run
Advisory
Suggest reviewing before use
Nx generators are powerful tools that scaffold projects, make automated code migrations or automate repetitive tasks in a monorepo. They ensure consistency across the codebase and reduce boilerplate work.
This skill applies when the user wants to:
--no-interactive - Prevents prompts that would hang
executionUse the Nx CLI to discover available generators:
pnpm exec nx list @nx/reactpnpm exec nx listThis includes plugin generators (e.g., @nx/react:library) and local workspace
generators.
Identify which generator(s) could fulfill the user's needs. Consider what artifact type they want, which framework is relevant, and any specific generator names mentioned.
IMPORTANT: When both a local workspace generator and an external plugin generator could satisfy the request, always prefer the local workspace generator. Local generators are customized for the specific repo's patterns.
If no suitable generator exists, you can stop using this skill. However, the burden of proof is high—carefully consider all available generators before deciding none apply.
Use the --help flag to understand available options:
pnpm exec nx g @nx/react:library --helpPay attention to required options, defaults that might need overriding, and options relevant to the user's request.
Default to non-buildable libraries unless there's a specific reason for buildable.
| Type | When to use | Generator flags |
|---|---|---|
| Non-buildable (default) | Internal monorepo libs consumed by apps | No --bundler flag |
| Buildable | Publishing to npm, cross-repo sharing, stable libs for cache hits | --bundler=vite or --bundler=swc |
Non-buildable libs:
.ts/.tsx source directlyBuildable libs:
If unclear, ask the user: "Should this library be buildable (own build step, better caching) or non-buildable (source consumed directly, simpler setup)?"
This step is critical. The schema alone does not tell you everything. Reading the source code helps you:
To find generator source code:
node -e "console.log(require.resolve('@nx/<plugin>/generators.json'));" to
find the generators.json, then locate the source from therenode_modules/<plugin>/generators.jsontools/generators/ or a local plugin
directory. Search the repo for the generator name.After reading the source, reconsider: Is this the right generator? If not, go back to step 2.
⚠️
--directoryflag behavior can be misleading. It should specify the full path of the generated library or component, not the parent path that it will be generated in.# ✅ Correct - directory is the full path for the library nx g @nx/react:library --directory=libs/my-lib # generates libs/my-lib/package.json and more # ❌ Wrong - this will create files at libs and libs/src/... nx g @nx/react:library --name=my-lib --directory=libs # generates libs/package.json and more
Before generating, examine the target area of the codebase:
Always run with --dry-run first to verify files will be created in the
correct location:
pnpm exec nx g @nx/react:library --name=my-lib --dry-run --no-interactiveReview the output carefully. If files would be created in the wrong location, adjust your options based on what you learned from the generator source code.
Note: Some generators don't support dry-run (e.g., if they install npm packages). If dry-run fails for this reason, proceed to running the generator for real.
Execute the generator:
pnpm exec nx generate <generator-name> <options> --no-interactiveTip: New packages often need workspace dependencies wired up (e.g., importing shared types, being consumed by apps). The
link-workspace-packagesskill can help add these correctly.
Generators provide a starting point. Modify the output as needed to:
Important: If you replace or delete generated test files (e.g.,
*.spec.ts), either write meaningful replacement tests or remove the test
target from the project configuration. Empty test suites will cause nx test to
fail.
Format all generated/modified files:
pnpm exec nx format --fixThis example is for built-in nx formatting with prettier. There might be other formatting tools for this workspace, use these when appropriate.
Then verify the generated code works. Keep in mind that the changes you make with a generator or subsequent modifications might impact various projects so it's usually not enough to only run targets for the artifact you just created.
# these targets are just an example!
pnpm exec nx run-many -t build,lint,test,typecheckThese targets are common examples used across many workspaces. You should do research into other targets available for this workspace and its projects. CI configuration is usually a good guide for what the critical targets are that have to pass.
If verification fails with manageable issues (a few lint errors, minor type issues), fix them. If issues are extensive, attempt obvious fixes first, then escalate to the user with details about what was generated, what's failing, and what you've attempted.
e887790
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.