create-xani-agentic-app 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +237 -0
- package/index.js +219 -0
- package/package.json +46 -0
- package/template/.agents/skills/ai-sdk/SKILL.md +78 -0
- package/template/.agents/skills/ai-sdk/references/ai-gateway.md +66 -0
- package/template/.agents/skills/ai-sdk/references/common-errors.md +443 -0
- package/template/.agents/skills/ai-sdk/references/devtools.md +52 -0
- package/template/.agents/skills/ai-sdk/references/type-safe-agents.md +204 -0
- package/template/.agents/skills/better-auth-best-practices/SKILL.md +175 -0
- package/template/.agents/skills/checkpoint/SKILL.md +82 -0
- package/template/.agents/skills/create-spec/SKILL.md +132 -0
- package/template/.agents/skills/create-spec/references/action-required-template.md +53 -0
- package/template/.agents/skills/create-spec/references/readme-template.md +53 -0
- package/template/.agents/skills/create-spec/references/requirements-template.md +54 -0
- package/template/.agents/skills/create-spec/references/task-template.md +79 -0
- package/template/.agents/skills/find-skills/SKILL.md +142 -0
- package/template/.agents/skills/frontend-design/LICENSE.txt +177 -0
- package/template/.agents/skills/frontend-design/SKILL.md +42 -0
- package/template/.agents/skills/implement-feature/SKILL.md +189 -0
- package/template/.agents/skills/implement-feature/references/coder-prompt-template.md +46 -0
- package/template/.agents/skills/implement-feature/references/fix-prompt-template.md +38 -0
- package/template/.agents/skills/implement-feature/references/review-prompt-template.md +50 -0
- package/template/.agents/skills/mcp-builder/LICENSE.txt +202 -0
- package/template/.agents/skills/mcp-builder/SKILL.md +236 -0
- package/template/.agents/skills/mcp-builder/reference/evaluation.md +602 -0
- package/template/.agents/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
- package/template/.agents/skills/mcp-builder/reference/node_mcp_server.md +970 -0
- package/template/.agents/skills/mcp-builder/reference/python_mcp_server.md +719 -0
- package/template/.agents/skills/mcp-builder/scripts/connections.py +151 -0
- package/template/.agents/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/template/.agents/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/template/.agents/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/template/.agents/skills/nextjs/SKILL.md +434 -0
- package/template/.agents/skills/nextjs/overlay.yaml +284 -0
- package/template/.agents/skills/nextjs/references/app-router-files.md +94 -0
- package/template/.agents/skills/nextjs/references/async-patterns.md +87 -0
- package/template/.agents/skills/nextjs/references/bundling.md +180 -0
- package/template/.agents/skills/nextjs/references/data-patterns.md +297 -0
- package/template/.agents/skills/nextjs/references/debug-tricks.md +105 -0
- package/template/.agents/skills/nextjs/references/directives.md +73 -0
- package/template/.agents/skills/nextjs/references/error-handling.md +227 -0
- package/template/.agents/skills/nextjs/references/file-conventions.md +140 -0
- package/template/.agents/skills/nextjs/references/font.md +245 -0
- package/template/.agents/skills/nextjs/references/functions.md +108 -0
- package/template/.agents/skills/nextjs/references/hydration-error.md +91 -0
- package/template/.agents/skills/nextjs/references/image.md +173 -0
- package/template/.agents/skills/nextjs/references/metadata.md +301 -0
- package/template/.agents/skills/nextjs/references/parallel-routes.md +287 -0
- package/template/.agents/skills/nextjs/references/route-handlers.md +146 -0
- package/template/.agents/skills/nextjs/references/rsc-boundaries.md +159 -0
- package/template/.agents/skills/nextjs/references/runtime-selection.md +39 -0
- package/template/.agents/skills/nextjs/references/scripts.md +141 -0
- package/template/.agents/skills/nextjs/references/self-hosting.md +371 -0
- package/template/.agents/skills/nextjs/references/suspense-boundaries.md +67 -0
- package/template/.agents/skills/nextjs/upstream/SKILL.md +153 -0
- package/template/.agents/skills/nextjs/upstream/references/app-router-files.md +94 -0
- package/template/.agents/skills/nextjs/upstream/references/async-patterns.md +87 -0
- package/template/.agents/skills/nextjs/upstream/references/bundling.md +180 -0
- package/template/.agents/skills/nextjs/upstream/references/data-patterns.md +297 -0
- package/template/.agents/skills/nextjs/upstream/references/debug-tricks.md +105 -0
- package/template/.agents/skills/nextjs/upstream/references/directives.md +73 -0
- package/template/.agents/skills/nextjs/upstream/references/error-handling.md +227 -0
- package/template/.agents/skills/nextjs/upstream/references/file-conventions.md +140 -0
- package/template/.agents/skills/nextjs/upstream/references/font.md +245 -0
- package/template/.agents/skills/nextjs/upstream/references/functions.md +108 -0
- package/template/.agents/skills/nextjs/upstream/references/hydration-error.md +91 -0
- package/template/.agents/skills/nextjs/upstream/references/image.md +173 -0
- package/template/.agents/skills/nextjs/upstream/references/metadata.md +301 -0
- package/template/.agents/skills/nextjs/upstream/references/parallel-routes.md +287 -0
- package/template/.agents/skills/nextjs/upstream/references/route-handlers.md +146 -0
- package/template/.agents/skills/nextjs/upstream/references/rsc-boundaries.md +159 -0
- package/template/.agents/skills/nextjs/upstream/references/runtime-selection.md +39 -0
- package/template/.agents/skills/nextjs/upstream/references/scripts.md +141 -0
- package/template/.agents/skills/nextjs/upstream/references/self-hosting.md +371 -0
- package/template/.agents/skills/nextjs/upstream/references/suspense-boundaries.md +67 -0
- package/template/.agents/skills/playwright-cli/SKILL.md +344 -0
- package/template/.agents/skills/playwright-cli/references/element-attributes.md +23 -0
- package/template/.agents/skills/playwright-cli/references/playwright-tests.md +39 -0
- package/template/.agents/skills/playwright-cli/references/request-mocking.md +87 -0
- package/template/.agents/skills/playwright-cli/references/running-code.md +231 -0
- package/template/.agents/skills/playwright-cli/references/session-management.md +169 -0
- package/template/.agents/skills/playwright-cli/references/storage-state.md +275 -0
- package/template/.agents/skills/playwright-cli/references/test-generation.md +88 -0
- package/template/.agents/skills/playwright-cli/references/tracing.md +139 -0
- package/template/.agents/skills/playwright-cli/references/video-recording.md +143 -0
- package/template/.agents/skills/review-pr/SKILL.md +97 -0
- package/template/.agents/skills/security-scanner/SKILL.md +157 -0
- package/template/.agents/skills/security-scanner/references/A01-broken-access-control.md +136 -0
- package/template/.agents/skills/security-scanner/references/A02-security-misconfiguration.md +130 -0
- package/template/.agents/skills/security-scanner/references/A03-software-supply-chain-failures.md +117 -0
- package/template/.agents/skills/security-scanner/references/A04-cryptographic-failures.md +141 -0
- package/template/.agents/skills/security-scanner/references/A05-injection.md +155 -0
- package/template/.agents/skills/security-scanner/references/A06-insecure-design.md +145 -0
- package/template/.agents/skills/security-scanner/references/A07-authentication-failures.md +150 -0
- package/template/.agents/skills/security-scanner/references/A08-software-data-integrity-failures.md +132 -0
- package/template/.agents/skills/security-scanner/references/A09-security-logging-alerting-failures.md +130 -0
- package/template/.agents/skills/security-scanner/references/A10-mishandling-exceptional-conditions.md +154 -0
- package/template/.agents/skills/security-scanner/references/report-template.md +148 -0
- package/template/.agents/skills/shadcn/SKILL.md +246 -0
- package/template/.agents/skills/shadcn/agents/openai.yml +5 -0
- package/template/.agents/skills/shadcn/assets/shadcn-small.png +0 -0
- package/template/.agents/skills/shadcn/assets/shadcn.png +0 -0
- package/template/.agents/skills/shadcn/cli.md +276 -0
- package/template/.agents/skills/shadcn/customization.md +209 -0
- package/template/.agents/skills/shadcn/evals/evals.json +47 -0
- package/template/.agents/skills/shadcn/mcp.md +94 -0
- package/template/.agents/skills/shadcn/rules/base-vs-radix.md +306 -0
- package/template/.agents/skills/shadcn/rules/composition.md +195 -0
- package/template/.agents/skills/shadcn/rules/forms.md +192 -0
- package/template/.agents/skills/shadcn/rules/icons.md +101 -0
- package/template/.agents/skills/shadcn/rules/styling.md +162 -0
- package/template/.agents/skills/ship-it/SKILL.md +174 -0
- package/template/.agents/skills/skill-creator/LICENSE.txt +202 -0
- package/template/.agents/skills/skill-creator/SKILL.md +485 -0
- package/template/.agents/skills/skill-creator/agents/analyzer.md +274 -0
- package/template/.agents/skills/skill-creator/agents/comparator.md +202 -0
- package/template/.agents/skills/skill-creator/agents/grader.md +223 -0
- package/template/.agents/skills/skill-creator/assets/eval_review.html +146 -0
- package/template/.agents/skills/skill-creator/eval-viewer/generate_review.py +471 -0
- package/template/.agents/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/template/.agents/skills/skill-creator/references/schemas.md +430 -0
- package/template/.agents/skills/skill-creator/scripts/__init__.py +0 -0
- package/template/.agents/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
- package/template/.agents/skills/skill-creator/scripts/generate_report.py +326 -0
- package/template/.agents/skills/skill-creator/scripts/improve_description.py +247 -0
- package/template/.agents/skills/skill-creator/scripts/package_skill.py +136 -0
- package/template/.agents/skills/skill-creator/scripts/quick_validate.py +103 -0
- package/template/.agents/skills/skill-creator/scripts/run_eval.py +310 -0
- package/template/.agents/skills/skill-creator/scripts/run_loop.py +328 -0
- package/template/.agents/skills/skill-creator/scripts/utils.py +47 -0
- package/template/.agents/skills/vercel-react-best-practices/AGENTS.md +3750 -0
- package/template/.agents/skills/vercel-react-best-practices/README.md +123 -0
- package/template/.agents/skills/vercel-react-best-practices/SKILL.md +148 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/_sections.md +46 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/_template.md +28 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/advanced-effect-event-deps.md +56 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +82 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +60 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-flatmap-filter.md +60 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-request-idle-callback.md +105 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-resource-hints.md +85 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-script-defer-async.md +68 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-no-inline-components.md +82 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-use-deferred-value.md +59 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-hoist-static-io.md +149 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-no-shared-module-state.md +50 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
- package/template/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/template/.agents/skills/web-design-guidelines/SKILL.md +39 -0
- package/template/.claude/agents/better-auth-expert.md +189 -0
- package/template/.claude/agents/code-review.md +147 -0
- package/template/.claude/agents/coder.md +139 -0
- package/template/.claude/agents/deep-dive.md +133 -0
- package/template/.claude/agents/polar-payments-expert.md +140 -0
- package/template/.claude/agents/security-scanner.md +214 -0
- package/template/.claude/settings.local.json +15 -0
- package/template/.claude/skills/ai-sdk/SKILL.md +78 -0
- package/template/.claude/skills/ai-sdk/references/ai-gateway.md +66 -0
- package/template/.claude/skills/ai-sdk/references/common-errors.md +443 -0
- package/template/.claude/skills/ai-sdk/references/devtools.md +52 -0
- package/template/.claude/skills/ai-sdk/references/type-safe-agents.md +204 -0
- package/template/.claude/skills/better-auth-best-practices/SKILL.md +175 -0
- package/template/.claude/skills/caveman/SKILL.md +49 -0
- package/template/.claude/skills/checkpoint/SKILL.md +82 -0
- package/template/.claude/skills/create-spec/SKILL.md +132 -0
- package/template/.claude/skills/create-spec/references/action-required-template.md +53 -0
- package/template/.claude/skills/create-spec/references/readme-template.md +53 -0
- package/template/.claude/skills/create-spec/references/requirements-template.md +54 -0
- package/template/.claude/skills/create-spec/references/task-template.md +79 -0
- package/template/.claude/skills/d3-visualization/SKILL.md +62 -0
- package/template/.claude/skills/find-skills/SKILL.md +142 -0
- package/template/.claude/skills/frontend-design/LICENSE.txt +177 -0
- package/template/.claude/skills/frontend-design/SKILL.md +42 -0
- package/template/.claude/skills/grill-me/SKILL.md +10 -0
- package/template/.claude/skills/grill-with-docs/ADR-FORMAT.md +47 -0
- package/template/.claude/skills/grill-with-docs/CONTEXT-FORMAT.md +63 -0
- package/template/.claude/skills/grill-with-docs/SKILL.md +88 -0
- package/template/.claude/skills/gsap-core/SKILL.md +267 -0
- package/template/.claude/skills/implement-feature/SKILL.md +189 -0
- package/template/.claude/skills/implement-feature/references/coder-prompt-template.md +46 -0
- package/template/.claude/skills/implement-feature/references/fix-prompt-template.md +38 -0
- package/template/.claude/skills/implement-feature/references/review-prompt-template.md +50 -0
- package/template/.claude/skills/mcp-builder/LICENSE.txt +202 -0
- package/template/.claude/skills/mcp-builder/SKILL.md +236 -0
- package/template/.claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/template/.claude/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
- package/template/.claude/skills/mcp-builder/reference/node_mcp_server.md +970 -0
- package/template/.claude/skills/mcp-builder/reference/python_mcp_server.md +719 -0
- package/template/.claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/template/.claude/skills/mcp-builder/scripts/evaluation.py +373 -0
- package/template/.claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/template/.claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/template/.claude/skills/nextjs/SKILL.md +434 -0
- package/template/.claude/skills/nextjs/overlay.yaml +284 -0
- package/template/.claude/skills/nextjs/references/app-router-files.md +94 -0
- package/template/.claude/skills/nextjs/references/async-patterns.md +87 -0
- package/template/.claude/skills/nextjs/references/bundling.md +180 -0
- package/template/.claude/skills/nextjs/references/data-patterns.md +297 -0
- package/template/.claude/skills/nextjs/references/debug-tricks.md +105 -0
- package/template/.claude/skills/nextjs/references/directives.md +73 -0
- package/template/.claude/skills/nextjs/references/error-handling.md +227 -0
- package/template/.claude/skills/nextjs/references/file-conventions.md +140 -0
- package/template/.claude/skills/nextjs/references/font.md +245 -0
- package/template/.claude/skills/nextjs/references/functions.md +108 -0
- package/template/.claude/skills/nextjs/references/hydration-error.md +91 -0
- package/template/.claude/skills/nextjs/references/image.md +173 -0
- package/template/.claude/skills/nextjs/references/metadata.md +301 -0
- package/template/.claude/skills/nextjs/references/parallel-routes.md +287 -0
- package/template/.claude/skills/nextjs/references/route-handlers.md +146 -0
- package/template/.claude/skills/nextjs/references/rsc-boundaries.md +159 -0
- package/template/.claude/skills/nextjs/references/runtime-selection.md +39 -0
- package/template/.claude/skills/nextjs/references/scripts.md +141 -0
- package/template/.claude/skills/nextjs/references/self-hosting.md +371 -0
- package/template/.claude/skills/nextjs/references/suspense-boundaries.md +67 -0
- package/template/.claude/skills/nextjs/upstream/SKILL.md +153 -0
- package/template/.claude/skills/nextjs/upstream/references/app-router-files.md +94 -0
- package/template/.claude/skills/nextjs/upstream/references/async-patterns.md +87 -0
- package/template/.claude/skills/nextjs/upstream/references/bundling.md +180 -0
- package/template/.claude/skills/nextjs/upstream/references/data-patterns.md +297 -0
- package/template/.claude/skills/nextjs/upstream/references/debug-tricks.md +105 -0
- package/template/.claude/skills/nextjs/upstream/references/directives.md +73 -0
- package/template/.claude/skills/nextjs/upstream/references/error-handling.md +227 -0
- package/template/.claude/skills/nextjs/upstream/references/file-conventions.md +140 -0
- package/template/.claude/skills/nextjs/upstream/references/font.md +245 -0
- package/template/.claude/skills/nextjs/upstream/references/functions.md +108 -0
- package/template/.claude/skills/nextjs/upstream/references/hydration-error.md +91 -0
- package/template/.claude/skills/nextjs/upstream/references/image.md +173 -0
- package/template/.claude/skills/nextjs/upstream/references/metadata.md +301 -0
- package/template/.claude/skills/nextjs/upstream/references/parallel-routes.md +287 -0
- package/template/.claude/skills/nextjs/upstream/references/route-handlers.md +146 -0
- package/template/.claude/skills/nextjs/upstream/references/rsc-boundaries.md +159 -0
- package/template/.claude/skills/nextjs/upstream/references/runtime-selection.md +39 -0
- package/template/.claude/skills/nextjs/upstream/references/scripts.md +141 -0
- package/template/.claude/skills/nextjs/upstream/references/self-hosting.md +371 -0
- package/template/.claude/skills/nextjs/upstream/references/suspense-boundaries.md +67 -0
- package/template/.claude/skills/playwright-cli/SKILL.md +344 -0
- package/template/.claude/skills/playwright-cli/references/element-attributes.md +23 -0
- package/template/.claude/skills/playwright-cli/references/playwright-tests.md +39 -0
- package/template/.claude/skills/playwright-cli/references/request-mocking.md +87 -0
- package/template/.claude/skills/playwright-cli/references/running-code.md +231 -0
- package/template/.claude/skills/playwright-cli/references/session-management.md +169 -0
- package/template/.claude/skills/playwright-cli/references/storage-state.md +275 -0
- package/template/.claude/skills/playwright-cli/references/test-generation.md +88 -0
- package/template/.claude/skills/playwright-cli/references/tracing.md +139 -0
- package/template/.claude/skills/playwright-cli/references/video-recording.md +143 -0
- package/template/.claude/skills/react-three-fiber/SKILL.md +180 -0
- package/template/.claude/skills/remotion/SKILL.md +43 -0
- package/template/.claude/skills/review-pr/SKILL.md +97 -0
- package/template/.claude/skills/security-scanner/SKILL.md +157 -0
- package/template/.claude/skills/security-scanner/references/A01-broken-access-control.md +136 -0
- package/template/.claude/skills/security-scanner/references/A02-security-misconfiguration.md +130 -0
- package/template/.claude/skills/security-scanner/references/A03-software-supply-chain-failures.md +117 -0
- package/template/.claude/skills/security-scanner/references/A04-cryptographic-failures.md +141 -0
- package/template/.claude/skills/security-scanner/references/A05-injection.md +155 -0
- package/template/.claude/skills/security-scanner/references/A06-insecure-design.md +145 -0
- package/template/.claude/skills/security-scanner/references/A07-authentication-failures.md +150 -0
- package/template/.claude/skills/security-scanner/references/A08-software-data-integrity-failures.md +132 -0
- package/template/.claude/skills/security-scanner/references/A09-security-logging-alerting-failures.md +130 -0
- package/template/.claude/skills/security-scanner/references/A10-mishandling-exceptional-conditions.md +154 -0
- package/template/.claude/skills/security-scanner/references/report-template.md +148 -0
- package/template/.claude/skills/shadcn/SKILL.md +246 -0
- package/template/.claude/skills/shadcn/agents/openai.yml +5 -0
- package/template/.claude/skills/shadcn/assets/shadcn-small.png +0 -0
- package/template/.claude/skills/shadcn/assets/shadcn.png +0 -0
- package/template/.claude/skills/shadcn/cli.md +276 -0
- package/template/.claude/skills/shadcn/customization.md +209 -0
- package/template/.claude/skills/shadcn/evals/evals.json +47 -0
- package/template/.claude/skills/shadcn/mcp.md +94 -0
- package/template/.claude/skills/shadcn/rules/base-vs-radix.md +306 -0
- package/template/.claude/skills/shadcn/rules/composition.md +195 -0
- package/template/.claude/skills/shadcn/rules/forms.md +192 -0
- package/template/.claude/skills/shadcn/rules/icons.md +101 -0
- package/template/.claude/skills/shadcn/rules/styling.md +162 -0
- package/template/.claude/skills/ship-it/SKILL.md +174 -0
- package/template/.claude/skills/skill-creator/LICENSE.txt +202 -0
- package/template/.claude/skills/skill-creator/SKILL.md +485 -0
- package/template/.claude/skills/skill-creator/agents/analyzer.md +274 -0
- package/template/.claude/skills/skill-creator/agents/comparator.md +202 -0
- package/template/.claude/skills/skill-creator/agents/grader.md +223 -0
- package/template/.claude/skills/skill-creator/assets/eval_review.html +146 -0
- package/template/.claude/skills/skill-creator/eval-viewer/generate_review.py +471 -0
- package/template/.claude/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/template/.claude/skills/skill-creator/references/schemas.md +430 -0
- package/template/.claude/skills/skill-creator/scripts/__init__.py +0 -0
- package/template/.claude/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
- package/template/.claude/skills/skill-creator/scripts/generate_report.py +326 -0
- package/template/.claude/skills/skill-creator/scripts/improve_description.py +247 -0
- package/template/.claude/skills/skill-creator/scripts/package_skill.py +136 -0
- package/template/.claude/skills/skill-creator/scripts/quick_validate.py +103 -0
- package/template/.claude/skills/skill-creator/scripts/run_eval.py +310 -0
- package/template/.claude/skills/skill-creator/scripts/run_loop.py +328 -0
- package/template/.claude/skills/skill-creator/scripts/utils.py +47 -0
- package/template/.claude/skills/svelte/SKILL.md +284 -0
- package/template/.claude/skills/tdd/SKILL.md +109 -0
- package/template/.claude/skills/tdd/deep-modules.md +33 -0
- package/template/.claude/skills/tdd/interface-design.md +31 -0
- package/template/.claude/skills/tdd/mocking.md +59 -0
- package/template/.claude/skills/tdd/refactoring.md +10 -0
- package/template/.claude/skills/tdd/tests.md +61 -0
- package/template/.claude/skills/threejs/SKILL.md +43 -0
- package/template/.claude/skills/to-issues/SKILL.md +83 -0
- package/template/.claude/skills/to-prd/SKILL.md +76 -0
- package/template/.claude/skills/vercel-react-best-practices/AGENTS.md +3750 -0
- package/template/.claude/skills/vercel-react-best-practices/README.md +123 -0
- package/template/.claude/skills/vercel-react-best-practices/SKILL.md +148 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/_sections.md +46 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/_template.md +28 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/advanced-effect-event-deps.md +56 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-defer-await.md +82 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +60 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-flatmap-filter.md +60 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-request-idle-callback.md +105 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-resource-hints.md +85 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-script-defer-async.md +68 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-no-inline-components.md +82 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-use-deferred-value.md +59 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-hoist-static-io.md +149 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-no-shared-module-state.md +50 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
- package/template/.claude/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/template/.claude/skills/video-downloader/SKILL.md +42 -0
- package/template/.claude/skills/web-design-guidelines/SKILL.md +39 -0
- package/template/.claude/skills/webgpu-threejs-tsl/REFERENCE.md +371 -0
- package/template/.claude/skills/webgpu-threejs-tsl/SKILL.md +93 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/compute-shaders.md +578 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/core-concepts.md +497 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/device-loss.md +359 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/limits-and-features.md +133 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/materials.md +353 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/post-processing.md +515 -0
- package/template/.claude/skills/webgpu-threejs-tsl/docs/wgsl-integration.md +324 -0
- package/template/.claude/skills/webgpu-threejs-tsl/examples/basic-setup.js +87 -0
- package/template/.claude/skills/webgpu-threejs-tsl/examples/custom-material.js +170 -0
- package/template/.claude/skills/webgpu-threejs-tsl/examples/earth-shader.js +292 -0
- package/template/.claude/skills/webgpu-threejs-tsl/examples/particle-system.js +259 -0
- package/template/.claude/skills/webgpu-threejs-tsl/examples/post-processing.js +199 -0
- package/template/.claude/skills/webgpu-threejs-tsl/templates/compute-shader.js +343 -0
- package/template/.claude/skills/webgpu-threejs-tsl/templates/webgpu-project.js +276 -0
- package/template/.claude/skills/zoom-out/SKILL.md +7 -0
- package/template/.mcp.json +5 -0
- package/template/.nvmrc +1 -0
- package/template/.prettierignore +25 -0
- package/template/.prettierrc +11 -0
- package/template/.vscode/settings.json +1 -0
- package/template/.vscode/tasks.json.example +85 -0
- package/template/AGENTS.md +37 -0
- package/template/CLAUDE.md +75 -0
- package/template/CONTEXT.md +29 -0
- package/template/DESIGN.md +451 -0
- package/template/README.md +394 -0
- package/template/_gitignore +48 -0
- package/template/components.json +21 -0
- package/template/docker-compose.yml +9 -0
- package/template/docs/business/starter-prompt.md +94 -0
- package/template/docs/technical/ai/streaming.md +520 -0
- package/template/docs/technical/ai/structured-data.md +409 -0
- package/template/docs/technical/betterauth/polar.md +476 -0
- package/template/docs/technical/react-markdown.md +123 -0
- package/template/drizzle/0000_chilly_the_phantom.sql +50 -0
- package/template/drizzle/0001_last_warpath.sql +5 -0
- package/template/drizzle/meta/0000_snapshot.json +326 -0
- package/template/drizzle/meta/0001_snapshot.json +410 -0
- package/template/drizzle/meta/_journal.json +20 -0
- package/template/drizzle.config.ts +10 -0
- package/template/env.example +26 -0
- package/template/eslint.config.mjs +75 -0
- package/template/next-env.d.ts +6 -0
- package/template/next.config.ts +57 -0
- package/template/package.json +79 -0
- package/template/postcss.config.mjs +5 -0
- package/template/public/file.svg +1 -0
- package/template/public/globe.svg +1 -0
- package/template/public/next.svg +1 -0
- package/template/public/vercel.svg +1 -0
- package/template/public/window.svg +1 -0
- package/template/scripts/setup.ts +277 -0
- package/template/skills-lock.json +61 -0
- package/template/specs/ui-polish-responsive/README.md +59 -0
- package/template/specs/ui-polish-responsive/action-required.md +3 -0
- package/template/specs/ui-polish-responsive/requirements.md +53 -0
- package/template/specs/ui-polish-responsive/tasks/task-01-globals-css.md +144 -0
- package/template/specs/ui-polish-responsive/tasks/task-02-layout.md +66 -0
- package/template/specs/ui-polish-responsive/tasks/task-03-site-header.md +79 -0
- package/template/specs/ui-polish-responsive/tasks/task-04-site-footer.md +63 -0
- package/template/specs/ui-polish-responsive/tasks/task-05-home-page.md +215 -0
- package/template/specs/ui-polish-responsive/tasks/task-06-dashboard.md +222 -0
- package/template/specs/ui-polish-responsive/tasks/task-07-chat-page.md +225 -0
- package/template/specs/ui-polish-responsive/tasks/task-08-profile-page.md +192 -0
- package/template/specs/ui-polish-responsive/tasks/task-09-auth-pages.md +97 -0
- package/template/specs/ui-polish-responsive/tasks/task-10-setup-checklist.md +120 -0
- package/template/specs/ui-polish-responsive/tasks/task-11-starter-prompt-modal.md +87 -0
- package/template/src/app/(auth)/forgot-password/page.tsx +35 -0
- package/template/src/app/(auth)/layout.tsx +7 -0
- package/template/src/app/(auth)/login/page.tsx +44 -0
- package/template/src/app/(auth)/register/page.tsx +33 -0
- package/template/src/app/(auth)/reset-password/page.tsx +36 -0
- package/template/src/app/api/auth/[...all]/route.ts +4 -0
- package/template/src/app/api/chat/route.ts +80 -0
- package/template/src/app/api/diagnostics/route.ts +162 -0
- package/template/src/app/chat/error.tsx +46 -0
- package/template/src/app/chat/loading.tsx +42 -0
- package/template/src/app/chat/page.tsx +348 -0
- package/template/src/app/dashboard/loading.tsx +63 -0
- package/template/src/app/dashboard/page.tsx +79 -0
- package/template/src/app/error.tsx +44 -0
- package/template/src/app/favicon.ico +0 -0
- package/template/src/app/globals.css +175 -0
- package/template/src/app/layout.tsx +108 -0
- package/template/src/app/manifest.ts +21 -0
- package/template/src/app/not-found.tsx +28 -0
- package/template/src/app/page.tsx +152 -0
- package/template/src/app/profile/page.tsx +416 -0
- package/template/src/app/robots.ts +16 -0
- package/template/src/app/sitemap.ts +26 -0
- package/template/src/components/auth/forgot-password-form.tsx +83 -0
- package/template/src/components/auth/reset-password-form.tsx +107 -0
- package/template/src/components/auth/sign-in-button.tsx +97 -0
- package/template/src/components/auth/sign-out-button.tsx +31 -0
- package/template/src/components/auth/sign-up-form.tsx +121 -0
- package/template/src/components/auth/user-profile.tsx +91 -0
- package/template/src/components/setup-checklist.tsx +180 -0
- package/template/src/components/site-footer.tsx +24 -0
- package/template/src/components/site-header.tsx +46 -0
- package/template/src/components/starter-prompt-modal.tsx +202 -0
- package/template/src/components/theme-provider.tsx +11 -0
- package/template/src/components/ui/avatar.tsx +52 -0
- package/template/src/components/ui/badge.tsx +35 -0
- package/template/src/components/ui/button.tsx +58 -0
- package/template/src/components/ui/card.tsx +78 -0
- package/template/src/components/ui/dialog.tsx +142 -0
- package/template/src/components/ui/dropdown-menu.tsx +256 -0
- package/template/src/components/ui/github-stars.tsx +53 -0
- package/template/src/components/ui/input.tsx +20 -0
- package/template/src/components/ui/label.tsx +23 -0
- package/template/src/components/ui/mode-toggle.tsx +38 -0
- package/template/src/components/ui/separator.tsx +23 -0
- package/template/src/components/ui/skeleton.tsx +13 -0
- package/template/src/components/ui/sonner.tsx +42 -0
- package/template/src/components/ui/spinner.tsx +21 -0
- package/template/src/components/ui/textarea.tsx +17 -0
- package/template/src/hooks/use-diagnostics.ts +86 -0
- package/template/src/lib/auth-client.ts +16 -0
- package/template/src/lib/auth.ts +25 -0
- package/template/src/lib/db.ts +12 -0
- package/template/src/lib/env.ts +117 -0
- package/template/src/lib/schema.ts +82 -0
- package/template/src/lib/session.ts +48 -0
- package/template/src/lib/storage.ts +225 -0
- package/template/src/lib/utils.ts +6 -0
- package/template/src/proxy.ts +25 -0
- package/template/tsconfig.json +48 -0
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
name: nextjs
|
|
2
|
+
description: Next.js App Router expert guidance. Use when building, debugging, or architecting Next.js applications — routing, Server Components, Server Actions, Cache Components, layouts, middleware/proxy, data fetching, rendering strategies, and deployment on Vercel.
|
|
3
|
+
metadata:
|
|
4
|
+
priority: 5
|
|
5
|
+
docs:
|
|
6
|
+
- "https://nextjs.org/docs"
|
|
7
|
+
- "https://nextjs.org/docs/app"
|
|
8
|
+
sitemap: "https://nextjs.org/sitemap.xml"
|
|
9
|
+
pathPatterns:
|
|
10
|
+
- 'next.config.*'
|
|
11
|
+
- 'next-env.d.ts'
|
|
12
|
+
- 'app/**'
|
|
13
|
+
- 'pages/**'
|
|
14
|
+
- 'src/app/**'
|
|
15
|
+
- 'src/pages/**'
|
|
16
|
+
- 'tailwind.config.*'
|
|
17
|
+
- 'postcss.config.*'
|
|
18
|
+
- 'tsconfig.json'
|
|
19
|
+
- 'tsconfig.*.json'
|
|
20
|
+
- 'apps/*/app/**'
|
|
21
|
+
- 'apps/*/pages/**'
|
|
22
|
+
- 'apps/*/src/app/**'
|
|
23
|
+
- 'apps/*/src/pages/**'
|
|
24
|
+
- 'apps/*/next.config.*'
|
|
25
|
+
bashPatterns:
|
|
26
|
+
- '\bnext\s+(dev|build|start|lint)\b'
|
|
27
|
+
- '\bnext\s+experimental-analyze\b'
|
|
28
|
+
- '\bnpx\s+create-next-app\b'
|
|
29
|
+
- '\bbunx\s+create-next-app\b'
|
|
30
|
+
- '\bnpm\s+run\s+(dev|build|start)\b'
|
|
31
|
+
- '\bpnpm\s+(dev|build)\b'
|
|
32
|
+
- '\bbun\s+run\s+(dev|build)\b'
|
|
33
|
+
promptSignals:
|
|
34
|
+
phrases:
|
|
35
|
+
- "next.js"
|
|
36
|
+
- "nextjs"
|
|
37
|
+
- "app router"
|
|
38
|
+
- "server component"
|
|
39
|
+
- "server action"
|
|
40
|
+
allOf:
|
|
41
|
+
- [middleware, next]
|
|
42
|
+
- [layout, route]
|
|
43
|
+
anyOf:
|
|
44
|
+
- "pages router"
|
|
45
|
+
- "getserversideprops"
|
|
46
|
+
- "use server"
|
|
47
|
+
noneOf: []
|
|
48
|
+
minScore: 6
|
|
49
|
+
validate:
|
|
50
|
+
-
|
|
51
|
+
pattern: export.*getServerSideProps
|
|
52
|
+
message: 'getServerSideProps is removed in App Router — use server components or route handlers'
|
|
53
|
+
severity: error
|
|
54
|
+
upgradeToSkill: nextjs
|
|
55
|
+
upgradeWhy: 'Guides migration from Pages Router getServerSideProps to App Router server components with async data fetching.'
|
|
56
|
+
-
|
|
57
|
+
pattern: getServerSideProps
|
|
58
|
+
message: 'getServerSideProps is a Pages Router pattern — migrate to App Router server components'
|
|
59
|
+
severity: warn
|
|
60
|
+
-
|
|
61
|
+
pattern: export.*getStaticProps
|
|
62
|
+
message: 'getStaticProps is removed in App Router — use generateStaticParams + server components instead'
|
|
63
|
+
severity: error
|
|
64
|
+
upgradeToSkill: nextjs
|
|
65
|
+
upgradeWhy: 'Guides migration from Pages Router getStaticProps to App Router generateStaticParams with server components.'
|
|
66
|
+
-
|
|
67
|
+
pattern: getStaticProps
|
|
68
|
+
message: 'getStaticProps is a Pages Router pattern — migrate to App Router generateStaticParams + server components'
|
|
69
|
+
severity: warn
|
|
70
|
+
-
|
|
71
|
+
pattern: from\s+['"]next/router['"]
|
|
72
|
+
message: 'next/router is Pages Router only — use next/navigation for App Router'
|
|
73
|
+
severity: error
|
|
74
|
+
upgradeToSkill: nextjs
|
|
75
|
+
upgradeWhy: 'Guides migration from next/router to next/navigation with useRouter, usePathname, useSearchParams hooks.'
|
|
76
|
+
-
|
|
77
|
+
pattern: (useState|useEffect)
|
|
78
|
+
message: 'React hooks require "use client" directive — add it at the top of client components'
|
|
79
|
+
severity: warn
|
|
80
|
+
skipIfFileContains: "^['\"]use client['\"]"
|
|
81
|
+
-
|
|
82
|
+
pattern: from\s+['"]next/head['"]
|
|
83
|
+
message: 'next/head is Pages Router — use export const metadata or generateMetadata() in App Router. Run Skill(nextjs) for metadata API guidance.'
|
|
84
|
+
severity: error
|
|
85
|
+
upgradeToSkill: nextjs
|
|
86
|
+
upgradeWhy: 'Guides migration from next/head to the App Router metadata API (export const metadata / generateMetadata()).'
|
|
87
|
+
skipIfFileContains: export\s+(const\s+)?metadata|generateMetadata
|
|
88
|
+
-
|
|
89
|
+
pattern: export\s+(default\s+)?function\s+middleware
|
|
90
|
+
message: 'middleware() is renamed to proxy() in Next.js 16 — rename the function and the file to proxy.ts. Run Skill(routing-middleware) for proxy.ts migration guidance.'
|
|
91
|
+
severity: recommended
|
|
92
|
+
upgradeToSkill: routing-middleware
|
|
93
|
+
upgradeWhy: 'Guides migration from middleware.ts to proxy.ts with correct file placement, runtime config, and request interception patterns.'
|
|
94
|
+
-
|
|
95
|
+
pattern: revalidateTag\(\s*['"][^'"]+['"]\s*\)
|
|
96
|
+
message: 'Single-arg revalidateTag(tag) is deprecated in Next.js 16 — pass a cacheLife profile: revalidateTag(tag, "max")'
|
|
97
|
+
severity: recommended
|
|
98
|
+
upgradeToSkill: nextjs
|
|
99
|
+
upgradeWhy: 'Guides migration from single-arg revalidateTag to the Next.js 16 two-arg API with cacheLife profiles.'
|
|
100
|
+
-
|
|
101
|
+
pattern: '\bcacheHandler\s*:'
|
|
102
|
+
message: 'Singular cacheHandler is deprecated in Next.js 16 — use cacheHandlers (plural) with per-type handlers'
|
|
103
|
+
severity: recommended
|
|
104
|
+
upgradeToSkill: nextjs
|
|
105
|
+
upgradeWhy: 'Guides migration from singular cacheHandler to Next.js 16 cacheHandlers (plural) with per-type handler config.'
|
|
106
|
+
-
|
|
107
|
+
pattern: useRef\(\s*\)
|
|
108
|
+
message: 'useRef() requires an initial value in React 19 — use useRef(null) or useRef(0)'
|
|
109
|
+
severity: error
|
|
110
|
+
-
|
|
111
|
+
pattern: next\s+export
|
|
112
|
+
message: 'next export was removed — use output: "export" in next.config.js for static export'
|
|
113
|
+
severity: error
|
|
114
|
+
upgradeToSkill: nextjs
|
|
115
|
+
upgradeWhy: 'Guides migration from next export CLI command to output: "export" in next.config for static site generation.'
|
|
116
|
+
-
|
|
117
|
+
pattern: (?<!await )\bcookies\(\s*\)
|
|
118
|
+
message: 'cookies() is async in Next.js 16 — add await: const cookieStore = await cookies()'
|
|
119
|
+
severity: error
|
|
120
|
+
skipIfFileContains: "^['\"]use client['\"]"
|
|
121
|
+
-
|
|
122
|
+
pattern: (?<!await )\bheaders\(\s*\)
|
|
123
|
+
message: 'headers() is async in Next.js 16 — add await: const headersList = await headers()'
|
|
124
|
+
severity: error
|
|
125
|
+
skipIfFileContains: "^['\"]use client['\"]"
|
|
126
|
+
-
|
|
127
|
+
pattern: =\s*(?!await\b)params\b
|
|
128
|
+
message: 'params is async in Next.js 16 — add await: const { slug } = await params'
|
|
129
|
+
severity: recommended
|
|
130
|
+
skipIfFileContains: "^['\"]use client['\"]"
|
|
131
|
+
-
|
|
132
|
+
pattern: =\s*(?!await\b)searchParams\b
|
|
133
|
+
message: 'searchParams is async in Next.js 16 — add await: const { query } = await searchParams'
|
|
134
|
+
severity: recommended
|
|
135
|
+
skipIfFileContains: "^['\"]use client['\"]"
|
|
136
|
+
-
|
|
137
|
+
pattern: 'from\s+[''""](next-auth|@auth/core)[''""]|NextAuth\(|getServerSession\('
|
|
138
|
+
message: 'Legacy auth pattern detected. Modern Vercel apps should use Clerk, Descope, or Auth0 for managed authentication.'
|
|
139
|
+
severity: recommended
|
|
140
|
+
upgradeToSkill: auth
|
|
141
|
+
upgradeWhy: 'Migrate from next-auth/manual JWT to a managed auth provider (Clerk, Descope, Auth0) for better Vercel integration.'
|
|
142
|
+
skipIfFileContains: '@clerk/|@descope/|@auth0/'
|
|
143
|
+
-
|
|
144
|
+
pattern: 'NextApiRequest|NextApiResponse|export\s+default\s+function\s+handler'
|
|
145
|
+
message: 'Pages Router API handler detected. Use App Router route handlers with named HTTP exports instead.'
|
|
146
|
+
severity: recommended
|
|
147
|
+
upgradeToSkill: vercel-functions
|
|
148
|
+
upgradeWhy: 'Migrate from Pages Router API routes to App Router route handlers with Web Request/Response API.'
|
|
149
|
+
skipIfFileContains: 'export\s+(async\s+)?function\s+(GET|POST|PUT|PATCH|DELETE)'
|
|
150
|
+
-
|
|
151
|
+
pattern: 'from\s+[''""](lru-cache|node-cache|memory-cache)[''""]|new\s+(LRUCache|NodeCache)\('
|
|
152
|
+
message: 'In-process cache detected. Serverless deployments lose process memory between invocations.'
|
|
153
|
+
severity: recommended
|
|
154
|
+
upgradeToSkill: runtime-cache
|
|
155
|
+
upgradeWhy: 'Replace process-memory caches with Vercel Runtime Cache for shared, region-aware caching.'
|
|
156
|
+
-
|
|
157
|
+
pattern: 'from\s+[''""](express|fastify|koa|hapi)[''""]|require\s*\(\s*[''""](express|fastify|koa|hapi)[''""]'
|
|
158
|
+
message: 'Express/Fastify/Koa/Hapi server framework detected in a Next.js project. Use Next.js route handlers or proxy.ts for request handling instead.'
|
|
159
|
+
severity: recommended
|
|
160
|
+
upgradeToSkill: routing-middleware
|
|
161
|
+
upgradeWhy: 'Replace custom server frameworks with Next.js proxy.ts for request interception and route handlers for API endpoints.'
|
|
162
|
+
skipIfFileContains: 'proxy\.ts|from\s+[''""](next/server)[''""]|@vercel/functions'
|
|
163
|
+
-
|
|
164
|
+
pattern: 'from\s+[''""](typeorm|sequelize|mikro-orm|objection|bookshelf|knex)[''""]|require\s*\(\s*[''""](typeorm|sequelize|mikro-orm|objection|bookshelf|knex)[''""]'
|
|
165
|
+
message: 'Heavy ORM detected. Consider using lightweight serverless-native alternatives like Drizzle, Prisma, or direct Neon for better cold start performance.'
|
|
166
|
+
severity: recommended
|
|
167
|
+
upgradeToSkill: vercel-storage
|
|
168
|
+
upgradeWhy: 'Migrate from heavy ORMs to serverless-native database clients (Drizzle + Neon, Prisma, or @neondatabase/serverless) for faster cold starts.'
|
|
169
|
+
skipIfFileContains: 'from\s+[''""](drizzle-orm|@neondatabase|@prisma/client|prisma)[''""]'
|
|
170
|
+
-
|
|
171
|
+
pattern: 'fonts\.googleapis\.com|from\s+[''""](fontsource|@fontsource)[''""]|<link[^>]*fonts\.googleapis'
|
|
172
|
+
message: 'External font loader detected. Use next/font for zero-CLS, self-hosted font loading with automatic optimization.'
|
|
173
|
+
severity: recommended
|
|
174
|
+
upgradeToSkill: nextjs
|
|
175
|
+
upgradeWhy: 'Guides migration from external font loaders to next/font with Geist Sans/Mono for zero-CLS font optimization.'
|
|
176
|
+
skipIfFileContains: 'next/font'
|
|
177
|
+
chainTo:
|
|
178
|
+
-
|
|
179
|
+
pattern: 'export\s+(default\s+)?function\s+middleware'
|
|
180
|
+
targetSkill: routing-middleware
|
|
181
|
+
message: 'middleware() is renamed to proxy() in Next.js 16 — loading Routing Middleware guidance for proxy.ts migration.'
|
|
182
|
+
-
|
|
183
|
+
pattern: "from\\s+['\"]@vercel/(postgres|kv)['\"]"
|
|
184
|
+
targetSkill: vercel-storage
|
|
185
|
+
message: 'Sunset storage package detected — loading Vercel Storage guidance for Neon/Upstash migration.'
|
|
186
|
+
-
|
|
187
|
+
pattern: "from\\s+['\"]@ai-sdk/(anthropic|openai)['\"]"
|
|
188
|
+
targetSkill: ai-gateway
|
|
189
|
+
message: 'Direct AI provider SDK import — loading AI Gateway guidance for unified model routing with failover and cost tracking.'
|
|
190
|
+
-
|
|
191
|
+
pattern: 'from\s+[''""](next-auth|@auth/core)[''""]|NextAuth\(|getServerSession\('
|
|
192
|
+
targetSkill: auth
|
|
193
|
+
message: 'Legacy auth pattern detected — loading managed authentication guidance (Clerk, Descope, Auth0).'
|
|
194
|
+
-
|
|
195
|
+
pattern: 'NextApiRequest|NextApiResponse|export\s+default\s+function\s+handler'
|
|
196
|
+
targetSkill: vercel-functions
|
|
197
|
+
message: 'Pages Router API handler detected — loading Vercel Functions guidance for App Router migration.'
|
|
198
|
+
-
|
|
199
|
+
pattern: 'from\s+[''""](lru-cache|node-cache|memory-cache)[''""]|new\s+(LRUCache|NodeCache)\('
|
|
200
|
+
targetSkill: runtime-cache
|
|
201
|
+
message: 'In-process cache detected — loading Runtime Cache guidance for serverless-compatible caching.'
|
|
202
|
+
-
|
|
203
|
+
pattern: 'fetch\s*\(\s*[''""](https?://)?(api\.openai\.com|api\.anthropic\.com|api\.cohere\.ai)'
|
|
204
|
+
targetSkill: ai-gateway
|
|
205
|
+
message: 'Raw AI provider fetch URL detected — loading AI Gateway guidance for unified routing, failover, and OIDC auth.'
|
|
206
|
+
skipIfFileContains: '@ai-sdk/|from\s+[''""](ai)[''""]|ai-gateway|gateway\('
|
|
207
|
+
-
|
|
208
|
+
pattern: 'jwt\.(sign|verify|decode)\(|from\s+[''""](jsonwebtoken)[''""]|new\s+SignJWT\(|jwtVerify\('
|
|
209
|
+
targetSkill: auth
|
|
210
|
+
message: 'Manual JWT token handling detected — loading Auth guidance for managed authentication (Clerk, Descope, Auth0).'
|
|
211
|
+
skipIfFileContains: 'clerkMiddleware|@clerk/|@auth0/|@descope/|from\s+[''""](next-auth)[''""]'
|
|
212
|
+
-
|
|
213
|
+
pattern: 'from\s+[''"]@/components/ui/|from\s+[''"]@/components/ui[''""]'
|
|
214
|
+
targetSkill: shadcn
|
|
215
|
+
message: 'shadcn/ui component imports detected — loading shadcn guidance for component composition, theming, and registry patterns.'
|
|
216
|
+
skipIfFileContains: 'shadcn|components\.json'
|
|
217
|
+
-
|
|
218
|
+
pattern: 'from\s+[''""](styled-components|@emotion/(react|styled)|@mui/material)[''""]'
|
|
219
|
+
targetSkill: shadcn
|
|
220
|
+
message: 'CSS-in-JS library detected — loading shadcn/ui guidance for Tailwind CSS + Radix UI component patterns (Vercel recommended).'
|
|
221
|
+
skipIfFileContains: '@/components/ui|shadcn'
|
|
222
|
+
-
|
|
223
|
+
pattern: 'getInitialProps'
|
|
224
|
+
targetSkill: nextjs
|
|
225
|
+
message: 'getInitialProps is a legacy Pages Router pattern — loading Next.js guidance for App Router migration with server components and async data fetching.'
|
|
226
|
+
skipIfFileContains: 'app/.*page\.|generateStaticParams|use cache'
|
|
227
|
+
-
|
|
228
|
+
pattern: 'export.*getServerSideProps|getServerSideProps\s*\('
|
|
229
|
+
targetSkill: nextjs
|
|
230
|
+
message: 'getServerSideProps is a Pages Router pattern — loading Next.js guidance for App Router migration with server components and async data fetching.'
|
|
231
|
+
skipIfFileContains: 'generateStaticParams|use cache|app/.*page\.'
|
|
232
|
+
-
|
|
233
|
+
pattern: 'export.*getStaticProps|getStaticProps\s*\('
|
|
234
|
+
targetSkill: nextjs
|
|
235
|
+
message: 'getStaticProps is a Pages Router pattern — loading Next.js guidance for App Router migration with generateStaticParams and server components.'
|
|
236
|
+
skipIfFileContains: 'generateStaticParams|use cache|app/.*page\.'
|
|
237
|
+
-
|
|
238
|
+
pattern: '_app\.(tsx?|jsx?)'
|
|
239
|
+
targetSkill: nextjs
|
|
240
|
+
message: '_app.tsx is a Pages Router pattern — loading Next.js guidance for App Router layout.tsx migration.'
|
|
241
|
+
skipIfFileContains: 'app/layout\.|app/.*layout\.'
|
|
242
|
+
-
|
|
243
|
+
pattern: '_document\.(tsx?|jsx?)'
|
|
244
|
+
targetSkill: nextjs
|
|
245
|
+
message: '_document.tsx is a Pages Router pattern — loading Next.js guidance for App Router layout.tsx with metadata API migration.'
|
|
246
|
+
skipIfFileContains: 'app/layout\.|app/.*layout\.'
|
|
247
|
+
-
|
|
248
|
+
pattern: "from\\s+['\"]next/document['\"]"
|
|
249
|
+
targetSkill: nextjs
|
|
250
|
+
message: 'next/document is Pages Router only — loading Next.js guidance for App Router layout.tsx with html/body structure.'
|
|
251
|
+
skipIfFileContains: 'app/layout\.|app/.*layout\.'
|
|
252
|
+
-
|
|
253
|
+
pattern: 'pages/api/'
|
|
254
|
+
targetSkill: vercel-functions
|
|
255
|
+
message: 'Pages Router API route (pages/api/) detected — loading Vercel Functions guidance for App Router route handlers with named HTTP exports.'
|
|
256
|
+
skipIfFileContains: 'export\s+(async\s+)?function\s+(GET|POST|PUT|PATCH|DELETE)'
|
|
257
|
+
retrieval:
|
|
258
|
+
aliases:
|
|
259
|
+
- next.js
|
|
260
|
+
- nextjs app
|
|
261
|
+
- react framework
|
|
262
|
+
- app router
|
|
263
|
+
intents:
|
|
264
|
+
- set up routing and layouts in a Next.js app
|
|
265
|
+
- choose between server and client components for a feature
|
|
266
|
+
- configure data fetching or caching in App Router
|
|
267
|
+
- add middleware or proxy logic to handle requests
|
|
268
|
+
- set up server rendering for React pages
|
|
269
|
+
- add a new page with dynamic route segments
|
|
270
|
+
entities:
|
|
271
|
+
- App Router
|
|
272
|
+
- Server Components
|
|
273
|
+
- Server Actions
|
|
274
|
+
- generateMetadata
|
|
275
|
+
- layout
|
|
276
|
+
- proxy
|
|
277
|
+
- next.config
|
|
278
|
+
examples:
|
|
279
|
+
- add a new page with dynamic routing
|
|
280
|
+
- should this be a server or client component
|
|
281
|
+
- set up middleware for auth redirects
|
|
282
|
+
- configure caching for this data fetch
|
|
283
|
+
- set up server rendering for my pages
|
|
284
|
+
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
# Next.js App Router — File Convention Reference
|
|
2
|
+
|
|
3
|
+
## Special Files
|
|
4
|
+
|
|
5
|
+
| File | Purpose | Server/Client |
|
|
6
|
+
|------|---------|---------------|
|
|
7
|
+
| `layout.tsx` | Shared UI wrapper, preserves state | Server (default) |
|
|
8
|
+
| `page.tsx` | Unique route UI | Server (default) |
|
|
9
|
+
| `loading.tsx` | Suspense fallback | Server (default) |
|
|
10
|
+
| `error.tsx` | Error boundary | Client (required) |
|
|
11
|
+
| `not-found.tsx` | 404 UI | Server (default) |
|
|
12
|
+
| `route.ts` | API endpoint (Route Handler) | Server only |
|
|
13
|
+
| `template.tsx` | Layout that remounts on navigation | Server (default) |
|
|
14
|
+
| `default.tsx` | Parallel route fallback | Server (default) |
|
|
15
|
+
| `proxy.ts` | Network proxy (replaces middleware) | Server (Node.js) |
|
|
16
|
+
| `opengraph-image.tsx` | Auto-generated OG image for route | Server (Edge) |
|
|
17
|
+
| `twitter-image.tsx` | Auto-generated Twitter card image | Server (Edge) |
|
|
18
|
+
|
|
19
|
+
## Route Segments
|
|
20
|
+
|
|
21
|
+
| Pattern | Example | Matches |
|
|
22
|
+
|---------|---------|---------|
|
|
23
|
+
| `[id]` | `app/users/[id]/page.tsx` | `/users/123` |
|
|
24
|
+
| `[...slug]` | `app/docs/[...slug]/page.tsx` | `/docs/a/b/c` |
|
|
25
|
+
| `[[...slug]]` | `app/shop/[[...slug]]/page.tsx` | `/shop` or `/shop/a/b` |
|
|
26
|
+
| `(group)` | `app/(marketing)/page.tsx` | `/` (group ignored in URL) |
|
|
27
|
+
| `@slot` | `app/@sidebar/page.tsx` | Parallel route slot |
|
|
28
|
+
|
|
29
|
+
## Data Fetching Patterns
|
|
30
|
+
|
|
31
|
+
### Server Component (Default)
|
|
32
|
+
```tsx
|
|
33
|
+
export default async function Page() {
|
|
34
|
+
const data = await fetch('https://api.example.com/data')
|
|
35
|
+
return <div>{data}</div>
|
|
36
|
+
}
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### With Params (Async in Next.js 16)
|
|
40
|
+
```tsx
|
|
41
|
+
export default async function Page({
|
|
42
|
+
params,
|
|
43
|
+
}: {
|
|
44
|
+
params: Promise<{ id: string }>
|
|
45
|
+
}) {
|
|
46
|
+
const { id } = await params
|
|
47
|
+
const user = await getUser(id)
|
|
48
|
+
return <UserProfile user={user} />
|
|
49
|
+
}
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### With Search Params (Async in Next.js 16)
|
|
53
|
+
```tsx
|
|
54
|
+
export default async function Page({
|
|
55
|
+
searchParams,
|
|
56
|
+
}: {
|
|
57
|
+
searchParams: Promise<{ q?: string }>
|
|
58
|
+
}) {
|
|
59
|
+
const { q } = await searchParams
|
|
60
|
+
const results = await search(q)
|
|
61
|
+
return <SearchResults results={results} />
|
|
62
|
+
}
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
### generateStaticParams (SSG)
|
|
66
|
+
```tsx
|
|
67
|
+
export async function generateStaticParams() {
|
|
68
|
+
const posts = await getPosts()
|
|
69
|
+
return posts.map((post) => ({ slug: post.slug }))
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
export default async function Page({
|
|
73
|
+
params,
|
|
74
|
+
}: {
|
|
75
|
+
params: Promise<{ slug: string }>
|
|
76
|
+
}) {
|
|
77
|
+
const { slug } = await params
|
|
78
|
+
const post = await getPost(slug)
|
|
79
|
+
return <Post post={post} />
|
|
80
|
+
}
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### generateMetadata
|
|
84
|
+
```tsx
|
|
85
|
+
export async function generateMetadata({
|
|
86
|
+
params,
|
|
87
|
+
}: {
|
|
88
|
+
params: Promise<{ id: string }>
|
|
89
|
+
}) {
|
|
90
|
+
const { id } = await params
|
|
91
|
+
const product = await getProduct(id)
|
|
92
|
+
return { title: product.name, description: product.description }
|
|
93
|
+
}
|
|
94
|
+
```
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
# Async Patterns
|
|
2
|
+
|
|
3
|
+
In Next.js 15+, `params`, `searchParams`, `cookies()`, and `headers()` are asynchronous.
|
|
4
|
+
|
|
5
|
+
## Async Params and SearchParams
|
|
6
|
+
|
|
7
|
+
Always type them as `Promise<...>` and await them.
|
|
8
|
+
|
|
9
|
+
### Pages and Layouts
|
|
10
|
+
|
|
11
|
+
```tsx
|
|
12
|
+
type Props = { params: Promise<{ slug: string }> }
|
|
13
|
+
|
|
14
|
+
export default async function Page({ params }: Props) {
|
|
15
|
+
const { slug } = await params
|
|
16
|
+
}
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
### Route Handlers
|
|
20
|
+
|
|
21
|
+
```tsx
|
|
22
|
+
export async function GET(
|
|
23
|
+
request: Request,
|
|
24
|
+
{ params }: { params: Promise<{ id: string }> }
|
|
25
|
+
) {
|
|
26
|
+
const { id } = await params
|
|
27
|
+
}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
### SearchParams
|
|
31
|
+
|
|
32
|
+
```tsx
|
|
33
|
+
type Props = {
|
|
34
|
+
params: Promise<{ slug: string }>
|
|
35
|
+
searchParams: Promise<{ query?: string }>
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export default async function Page({ params, searchParams }: Props) {
|
|
39
|
+
const { slug } = await params
|
|
40
|
+
const { query } = await searchParams
|
|
41
|
+
}
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
### Synchronous Components
|
|
45
|
+
|
|
46
|
+
Use `React.use()` for non-async components:
|
|
47
|
+
|
|
48
|
+
```tsx
|
|
49
|
+
import { use } from 'react'
|
|
50
|
+
|
|
51
|
+
type Props = { params: Promise<{ slug: string }> }
|
|
52
|
+
|
|
53
|
+
export default function Page({ params }: Props) {
|
|
54
|
+
const { slug } = use(params)
|
|
55
|
+
}
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### generateMetadata
|
|
59
|
+
|
|
60
|
+
```tsx
|
|
61
|
+
type Props = { params: Promise<{ slug: string }> }
|
|
62
|
+
|
|
63
|
+
export async function generateMetadata({ params }: Props): Promise<Metadata> {
|
|
64
|
+
const { slug } = await params
|
|
65
|
+
return { title: slug }
|
|
66
|
+
}
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## Async Cookies and Headers
|
|
70
|
+
|
|
71
|
+
```tsx
|
|
72
|
+
import { cookies, headers } from 'next/headers'
|
|
73
|
+
|
|
74
|
+
export default async function Page() {
|
|
75
|
+
const cookieStore = await cookies()
|
|
76
|
+
const headersList = await headers()
|
|
77
|
+
|
|
78
|
+
const theme = cookieStore.get('theme')
|
|
79
|
+
const userAgent = headersList.get('user-agent')
|
|
80
|
+
}
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
## Migration Codemod
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
npx @next/codemod@latest next-async-request-api .
|
|
87
|
+
```
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
# Bundling
|
|
2
|
+
|
|
3
|
+
Fix common bundling issues with third-party packages.
|
|
4
|
+
|
|
5
|
+
## Server-Incompatible Packages
|
|
6
|
+
|
|
7
|
+
Some packages use browser APIs (`window`, `document`, `localStorage`) and fail in Server Components.
|
|
8
|
+
|
|
9
|
+
### Error Signs
|
|
10
|
+
|
|
11
|
+
```
|
|
12
|
+
ReferenceError: window is not defined
|
|
13
|
+
ReferenceError: document is not defined
|
|
14
|
+
ReferenceError: localStorage is not defined
|
|
15
|
+
Module not found: Can't resolve 'fs'
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
### Solution 1: Mark as Client-Only
|
|
19
|
+
|
|
20
|
+
If the package is only needed on client:
|
|
21
|
+
|
|
22
|
+
```tsx
|
|
23
|
+
// Bad: Fails - package uses window
|
|
24
|
+
import SomeChart from 'some-chart-library'
|
|
25
|
+
|
|
26
|
+
export default function Page() {
|
|
27
|
+
return <SomeChart />
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// Good: Use dynamic import with ssr: false
|
|
31
|
+
import dynamic from 'next/dynamic'
|
|
32
|
+
|
|
33
|
+
const SomeChart = dynamic(() => import('some-chart-library'), {
|
|
34
|
+
ssr: false,
|
|
35
|
+
})
|
|
36
|
+
|
|
37
|
+
export default function Page() {
|
|
38
|
+
return <SomeChart />
|
|
39
|
+
}
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
### Solution 2: Externalize from Server Bundle
|
|
43
|
+
|
|
44
|
+
For packages that should run on server but have bundling issues:
|
|
45
|
+
|
|
46
|
+
```js
|
|
47
|
+
// next.config.js
|
|
48
|
+
module.exports = {
|
|
49
|
+
serverExternalPackages: ['problematic-package'],
|
|
50
|
+
}
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
Use this for:
|
|
54
|
+
- Packages with native bindings (sharp, bcrypt)
|
|
55
|
+
- Packages that don't bundle well (some ORMs)
|
|
56
|
+
- Packages with circular dependencies
|
|
57
|
+
|
|
58
|
+
### Solution 3: Client Component Wrapper
|
|
59
|
+
|
|
60
|
+
Wrap the entire usage in a client component:
|
|
61
|
+
|
|
62
|
+
```tsx
|
|
63
|
+
// components/ChartWrapper.tsx
|
|
64
|
+
'use client'
|
|
65
|
+
|
|
66
|
+
import { Chart } from 'chart-library'
|
|
67
|
+
|
|
68
|
+
export function ChartWrapper(props) {
|
|
69
|
+
return <Chart {...props} />
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// app/page.tsx (server component)
|
|
73
|
+
import { ChartWrapper } from '@/components/ChartWrapper'
|
|
74
|
+
|
|
75
|
+
export default function Page() {
|
|
76
|
+
return <ChartWrapper data={data} />
|
|
77
|
+
}
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
## CSS Imports
|
|
81
|
+
|
|
82
|
+
Import CSS files instead of using `<link>` tags. Next.js handles bundling and optimization.
|
|
83
|
+
|
|
84
|
+
```tsx
|
|
85
|
+
// Bad: Manual link tag
|
|
86
|
+
<link rel="stylesheet" href="/styles.css" />
|
|
87
|
+
|
|
88
|
+
// Good: Import CSS
|
|
89
|
+
import './styles.css'
|
|
90
|
+
|
|
91
|
+
// Good: CSS Modules
|
|
92
|
+
import styles from './Button.module.css'
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
## Polyfills
|
|
96
|
+
|
|
97
|
+
Next.js includes common polyfills automatically. Don't load redundant ones from polyfill.io or similar CDNs.
|
|
98
|
+
|
|
99
|
+
Already included: `Array.from`, `Object.assign`, `Promise`, `fetch`, `Map`, `Set`, `Symbol`, `URLSearchParams`, and 50+ others.
|
|
100
|
+
|
|
101
|
+
```tsx
|
|
102
|
+
// Bad: Redundant polyfills
|
|
103
|
+
<script src="https://polyfill.io/v3/polyfill.min.js?features=fetch,Promise,Array.from" />
|
|
104
|
+
|
|
105
|
+
// Good: Next.js includes these automatically
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
## ESM/CommonJS Issues
|
|
109
|
+
|
|
110
|
+
### Error Signs
|
|
111
|
+
|
|
112
|
+
```
|
|
113
|
+
SyntaxError: Cannot use import statement outside a module
|
|
114
|
+
Error: require() of ES Module
|
|
115
|
+
Module not found: ESM packages need to be imported
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
### Solution: Transpile Package
|
|
119
|
+
|
|
120
|
+
```js
|
|
121
|
+
// next.config.js
|
|
122
|
+
module.exports = {
|
|
123
|
+
transpilePackages: ['some-esm-package', 'another-package'],
|
|
124
|
+
}
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
## Common Problematic Packages
|
|
128
|
+
|
|
129
|
+
| Package | Issue | Solution |
|
|
130
|
+
|---------|-------|----------|
|
|
131
|
+
| `sharp` | Native bindings | `serverExternalPackages: ['sharp']` |
|
|
132
|
+
| `bcrypt` | Native bindings | `serverExternalPackages: ['bcrypt']` or use `bcryptjs` |
|
|
133
|
+
| `canvas` | Native bindings | `serverExternalPackages: ['canvas']` |
|
|
134
|
+
| `recharts` | Uses window | `dynamic(() => import('recharts'), { ssr: false })` |
|
|
135
|
+
| `react-quill` | Uses document | `dynamic(() => import('react-quill'), { ssr: false })` |
|
|
136
|
+
| `mapbox-gl` | Uses window | `dynamic(() => import('mapbox-gl'), { ssr: false })` |
|
|
137
|
+
| `monaco-editor` | Uses window | `dynamic(() => import('@monaco-editor/react'), { ssr: false })` |
|
|
138
|
+
| `lottie-web` | Uses document | `dynamic(() => import('lottie-react'), { ssr: false })` |
|
|
139
|
+
|
|
140
|
+
## Bundle Analysis
|
|
141
|
+
|
|
142
|
+
Analyze bundle size with the built-in analyzer (Next.js 16.1+):
|
|
143
|
+
|
|
144
|
+
```bash
|
|
145
|
+
next experimental-analyze
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
This opens an interactive UI to:
|
|
149
|
+
- Filter by route, environment (client/server), and type
|
|
150
|
+
- Inspect module sizes and import chains
|
|
151
|
+
- View treemap visualization
|
|
152
|
+
|
|
153
|
+
Save output for comparison:
|
|
154
|
+
|
|
155
|
+
```bash
|
|
156
|
+
next experimental-analyze --output
|
|
157
|
+
# Output saved to .next/diagnostics/analyze
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
Reference: https://nextjs.org/docs/app/guides/package-bundling
|
|
161
|
+
|
|
162
|
+
## Migrating from Webpack to Turbopack
|
|
163
|
+
|
|
164
|
+
Turbopack is the default bundler in Next.js 15+. If you have custom webpack config, migrate to Turbopack-compatible alternatives:
|
|
165
|
+
|
|
166
|
+
```js
|
|
167
|
+
// next.config.js
|
|
168
|
+
module.exports = {
|
|
169
|
+
// Good: Works with Turbopack
|
|
170
|
+
serverExternalPackages: ['package'],
|
|
171
|
+
transpilePackages: ['package'],
|
|
172
|
+
|
|
173
|
+
// Bad: Webpack-only - migrate away from this
|
|
174
|
+
webpack: (config) => {
|
|
175
|
+
// custom webpack config
|
|
176
|
+
},
|
|
177
|
+
}
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
Reference: https://nextjs.org/docs/app/building-your-application/upgrading/from-webpack-to-turbopack
|