create-inox-app 0.1.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 +110 -0
- package/dist/cli.js +22196 -0
- package/dist/prompt-Bp8saGVV.js +852 -0
- package/dist/templates/base/.gitignore.hbs +9 -0
- package/dist/templates/base/package.json.hbs +29 -0
- package/dist/templates/base/packages/typescript-config/base.json +17 -0
- package/dist/templates/base/packages/typescript-config/nextjs.json +8 -0
- package/dist/templates/base/packages/typescript-config/package.json +10 -0
- package/dist/templates/base/packages/typescript-config/react-library.json +7 -0
- package/dist/templates/base/turbo.json.hbs +32 -0
- package/dist/templates/ci/.gitlab-ci.yml.hbs +70 -0
- package/dist/templates/ci/scripts/build.sh.hbs +94 -0
- package/dist/templates/ci/scripts/prebuild.sh.hbs +11 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/SKILL.md +325 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/authentication.md +202 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/commands.md +259 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/proxy-support.md +188 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/session-management.md +193 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/snapshot-refs.md +194 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/references/video-recording.md +173 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/templates/authenticated-session.sh +100 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/templates/capture-workflow.sh +69 -0
- package/dist/templates/claude-config/app/.agents/skills/agent-browser/templates/form-automation.sh +62 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/SKILL.md +150 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/agent.md +131 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/artifact.md +84 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/attachments.md +190 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/audio-player.md +134 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/canvas.md +32 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/chain-of-thought.md +81 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/checkpoint.md +163 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/code-block.md +170 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/commit.md +177 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/confirmation.md +252 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/connection.md +32 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/context.md +126 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/controls.md +30 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/conversation.md +210 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/edge.md +50 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/environment-variables.md +102 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/file-tree.md +72 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/image.md +143 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/inline-citation.md +293 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/jsx-preview.md +101 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/message.md +256 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/mic-selector.md +186 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/model-selector.md +112 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/node.md +71 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/open-in-chat.md +67 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/package-info.md +95 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/panel.md +31 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/persona.md +158 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/plan.md +79 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/prompt-input.md +555 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/queue.md +172 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/reasoning.md +219 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/sandbox.md +126 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/schema-display.md +102 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/shimmer.md +48 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/snippet.md +64 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/sources.md +193 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/speech-input.md +160 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/stack-trace.md +218 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/suggestion.md +121 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/task.md +215 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/terminal.md +103 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/test-results.md +157 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/tool.md +275 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/toolbar.md +30 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/transcription.md +120 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/voice-selector.md +241 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/references/web-preview.md +197 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/agent.tsx +61 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/artifact.tsx +111 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/attachments-inline.tsx +117 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/attachments-list.tsx +88 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/attachments.tsx +78 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/audio-player-remote.tsx +35 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/audio-player.tsx +69 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/chain-of-thought.tsx +74 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/checkpoint.tsx +90 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/code-block-dark.tsx +46 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/code-block.tsx +115 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/commit.tsx +94 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/confirmation-accepted.tsx +35 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/confirmation-rejected.tsx +35 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/confirmation-request.tsx +54 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/confirmation.tsx +53 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/context.tsx +45 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/conversation.tsx +176 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/environment-variables.tsx +55 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/file-tree-basic.tsx +14 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/file-tree-expanded.tsx +17 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/file-tree-selection.tsx +20 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/file-tree.tsx +38 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/image.tsx +20 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/inline-citation.tsx +95 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/jsx-preview.tsx +99 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/message.tsx +324 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/mic-selector.tsx +46 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/model-selector.tsx +362 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/open-in-chat.tsx +33 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/package-info.tsx +46 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-command.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-glint.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-halo.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-mana.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-obsidian.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/persona-opal.tsx +96 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/plan.tsx +63 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/prompt-input-cursor.tsx +459 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/prompt-input-tooltip.tsx +40 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/prompt-input.tsx +247 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/queue-prompt-input.tsx +367 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/queue.tsx +276 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/reasoning.tsx +67 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/sandbox.tsx +166 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/schema-display-basic.tsx +7 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/schema-display-body.tsx +20 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/schema-display-nested.tsx +23 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/schema-display-params.tsx +16 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/schema-display.tsx +110 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/shimmer-duration.tsx +29 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/shimmer-elements.tsx +39 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/shimmer.tsx +17 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/snippet-plain.tsx +19 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/snippet.tsx +25 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/sources-custom.tsx +34 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/sources.tsx +27 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/speech-input.tsx +79 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/stack-trace-collapsed.tsx +39 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/stack-trace-no-internal.tsx +41 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/stack-trace.tsx +54 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/suggestion-input.tsx +137 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/suggestion.tsx +28 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/task.tsx +60 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/terminal-basic.tsx +7 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/terminal-clear.tsx +19 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/terminal-streaming.tsx +38 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/terminal.tsx +77 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/test-results-basic.tsx +27 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/test-results-errors.tsx +51 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/test-results-suites.tsx +40 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/test-results.tsx +78 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/tool-input-available.tsx +31 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/tool-input-streaming.tsx +30 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/tool-output-available.tsx +76 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/tool-output-error.tsx +45 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/tool.tsx +205 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/transcription.tsx +284 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/voice-selector.tsx +228 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-elements/scripts/web-preview.tsx +99 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-sdk/SKILL.md +78 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-sdk/references/ai-gateway.md +66 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-sdk/references/common-errors.md +439 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-sdk/references/devtools.md +52 -0
- package/dist/templates/claude-config/app/.agents/skills/ai-sdk/references/type-safe-agents.md +200 -0
- package/dist/templates/claude-config/app/.agents/skills/better-auth-best-practices/SKILL.md +166 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/SKILL.md +37 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/accessibility.mdx +819 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/as-child.mdx +324 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/composition.mdx +239 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/data-attributes.mdx +413 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/definitions.mdx +258 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/design-tokens.mdx +57 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/docs.mdx +155 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/marketplaces.mdx +144 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/npm.mdx +166 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/polymorphism.mdx +583 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/principles.mdx +61 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/registry.mdx +169 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/state.mdx +99 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/styling.mdx +286 -0
- package/dist/templates/claude-config/app/.agents/skills/building-components/references/types.mdx +191 -0
- package/dist/templates/claude-config/app/.agents/skills/docker-expert/SKILL.md +409 -0
- package/dist/templates/claude-config/app/.agents/skills/email-and-password-best-practices/SKILL.md +224 -0
- package/dist/templates/claude-config/app/.agents/skills/find-skills/SKILL.md +133 -0
- package/dist/templates/claude-config/app/.agents/skills/frontend-design/LICENSE.txt +177 -0
- package/dist/templates/claude-config/app/.agents/skills/frontend-design/SKILL.md +42 -0
- package/dist/templates/claude-config/app/.agents/skills/git-commit/SKILL.md +124 -0
- package/dist/templates/claude-config/app/.agents/skills/gitlab-ci-patterns/SKILL.md +271 -0
- package/dist/templates/claude-config/app/.agents/skills/hono/SKILL.md +90 -0
- package/dist/templates/claude-config/app/.agents/skills/langfuse-observability/SKILL.md +139 -0
- package/dist/templates/claude-config/app/.agents/skills/logging-best-practices/SKILL.md +127 -0
- package/dist/templates/claude-config/app/.agents/skills/logging-best-practices/rules/context.md +157 -0
- package/dist/templates/claude-config/app/.agents/skills/logging-best-practices/rules/pitfalls.md +118 -0
- package/dist/templates/claude-config/app/.agents/skills/logging-best-practices/rules/structure.md +193 -0
- package/dist/templates/claude-config/app/.agents/skills/logging-best-practices/rules/wide-events.md +113 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/SKILL.md +153 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/async-patterns.md +87 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/bundling.md +180 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/data-patterns.md +297 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/debug-tricks.md +105 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/directives.md +73 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/error-handling.md +227 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/file-conventions.md +140 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/font.md +245 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/functions.md +108 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/hydration-error.md +91 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/image.md +173 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/metadata.md +301 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/parallel-routes.md +287 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/route-handlers.md +146 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/rsc-boundaries.md +159 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/runtime-selection.md +39 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/scripts.md +141 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/self-hosting.md +371 -0
- package/dist/templates/claude-config/app/.agents/skills/next-best-practices/suspense-boundaries.md +67 -0
- package/dist/templates/claude-config/app/.agents/skills/next-cache-components/SKILL.md +411 -0
- package/dist/templates/claude-config/app/.agents/skills/next-upgrade/SKILL.md +50 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/SKILL.md +179 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/CHEATSHEET.md +418 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/MIGRATIONS.md +536 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/PERFORMANCE.md +559 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/POSTGRES.md +588 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/QUERIES.md +764 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/RELATIONS.md +624 -0
- package/dist/templates/claude-config/app/.agents/skills/postgres-drizzle/references/SCHEMA.md +554 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/LICENSE.txt +202 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/SKILL.md +356 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/references/output-patterns.md +82 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/references/workflows.md +28 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/scripts/init_skill.py +303 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/scripts/package_skill.py +113 -0
- package/dist/templates/claude-config/app/.agents/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/SKILL.md +164 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/assets/examples/basic-streaming.tsx +34 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/assets/examples/custom-security.tsx +38 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/assets/examples/full-featured.tsx +60 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/assets/examples/static-mode.tsx +17 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/assets/examples/with-caret.tsx +39 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/references/api.md +278 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/references/features.md +201 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/references/plugins.md +239 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/references/security.md +192 -0
- package/dist/templates/claude-config/app/.agents/skills/streamdown/references/styling.md +166 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/SKILL.md +107 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/deep-modules.md +33 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/interface-design.md +31 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/mocking.md +60 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/refactoring.md +10 -0
- package/dist/templates/claude-config/app/.agents/skills/tdd/tests.md +61 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/SKILL.md +914 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/command/turborepo.md +70 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/best-practices/RULE.md +241 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/best-practices/dependencies.md +246 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/best-practices/packages.md +335 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/best-practices/structure.md +270 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/boundaries/RULE.md +126 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/caching/RULE.md +107 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/caching/gotchas.md +169 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/caching/remote-cache.md +127 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/ci/RULE.md +79 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/ci/github-actions.md +162 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/ci/patterns.md +145 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/ci/vercel.md +103 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/cli/RULE.md +100 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/cli/commands.md +297 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/configuration/RULE.md +211 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/configuration/global-options.md +191 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/configuration/gotchas.md +348 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/configuration/tasks.md +281 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/environment/RULE.md +96 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/environment/gotchas.md +141 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/environment/modes.md +101 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/filtering/RULE.md +148 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/filtering/patterns.md +152 -0
- package/dist/templates/claude-config/app/.agents/skills/turborepo/references/watch/RULE.md +99 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/AGENTS.md +917 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/SKILL.md +88 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/architecture-avoid-boolean-props.md +94 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/architecture-compound-components.md +108 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/patterns-children-over-render-props.md +84 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/patterns-explicit-variants.md +94 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/state-context-interface.md +191 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/state-decouple-implementation.md +103 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-composition-patterns/rules/state-lift-state.md +125 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/AGENTS.md +2883 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/SKILL.md +138 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +35 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +48 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +24 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +37 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +48 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +34 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +44 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +78 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +74 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +110 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +68 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +50 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +38 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +32 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +36 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +72 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +26 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +77 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +56 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +36 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/dist/templates/claude-config/app/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/dist/templates/claude-config/app/.agents/skills/web-design-guidelines/SKILL.md +40 -0
- package/dist/templates/claude-config/app/.agents/skills/workflow/SKILL.md +181 -0
- package/dist/templates/claude-config/app/.claude/commands/council.md +7 -0
- package/dist/templates/claude-config/app/.claude/commands/deslop.md +25 -0
- package/dist/templates/claude-config/app/.claude/commands/diagram.md +101 -0
- package/dist/templates/claude-config/app/.claude/commands/fix-merge.md +47 -0
- package/dist/templates/claude-config/app/.claude/commands/you-might-not-need-an-effect.md +10 -0
- package/dist/templates/claude-config/app/.claude/hooks/post-tool-use-tracker.sh +187 -0
- package/dist/templates/claude-config/app/.claude/hooks/skill-activation-prompt.sh +5 -0
- package/dist/templates/claude-config/app/.claude/hooks/skill-activation-prompt.ts +134 -0
- package/dist/templates/claude-config/app/.claude/rules/comments.md +12 -0
- package/dist/templates/claude-config/app/.claude/rules/typescript.md +31 -0
- package/dist/templates/claude-config/app/.claude/settings.json.hbs +74 -0
- package/dist/templates/claude-config/app/.claude/skills/skill-rules.json.hbs +309 -0
- package/dist/templates/claude-config/app/AGENTS.md.hbs +185 -0
- package/dist/templates/claude-config/app/CLAUDE.md.hbs +5 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/git-commit/SKILL.md +124 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/SKILL.md +534 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/references/deployment-spec.md +780 -0
- package/dist/templates/claude-config/kustomize/.agents/skills/k8s-manifest-generator/references/service-spec.md +748 -0
- package/dist/templates/claude-config/kustomize/.claude/settings.json +42 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/git-commit/SKILL.md +124 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/SKILL.md +534 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/references/deployment-spec.md +780 -0
- package/dist/templates/claude-config/kustomize/.claude/skills/k8s-manifest-generator/references/service-spec.md +748 -0
- package/dist/templates/docker/.dockerignore.hbs +8 -0
- package/dist/templates/docker/Dockerfile.hbs +81 -0
- package/dist/templates/docker/docker-compose.yml.hbs +55 -0
- package/dist/templates/kustomize/base/deployments/app.yaml.hbs +44 -0
- package/dist/templates/kustomize/base/ingress/app.yaml.hbs +20 -0
- package/dist/templates/kustomize/base/jobs/app-jobs.yaml.hbs +43 -0
- package/dist/templates/kustomize/base/kustomization.yaml.hbs +13 -0
- package/dist/templates/kustomize/base/secrets/regcred.yaml.hbs +7 -0
- package/dist/templates/kustomize/base/services/app.yaml.hbs +12 -0
- package/dist/templates/kustomize/overlays/{{env}}/configs/app.config.env.hbs +21 -0
- package/dist/templates/kustomize/overlays/{{env}}/configs/paradedb.config.env.hbs +3 -0
- package/dist/templates/kustomize/overlays/{{env}}/deployments/paradedb.yaml.hbs +28 -0
- package/dist/templates/kustomize/overlays/{{env}}/deployments/redis.yaml.hbs +18 -0
- package/dist/templates/kustomize/overlays/{{env}}/kustomization.yaml.hbs +36 -0
- package/dist/templates/kustomize/overlays/{{env}}/patch-operation/ingress-host.yaml.hbs +15 -0
- package/dist/templates/kustomize/overlays/{{env}}/services/paradedb.yaml.hbs +11 -0
- package/dist/templates/kustomize/overlays/{{env}}/services/redis.yaml.hbs +11 -0
- package/dist/templates/kustomize/overlays/{{env}}/storage/paradedb-pvc.yaml.hbs +10 -0
- package/dist/templates/presets/ai-chat-app/apps/web/.env.example +11 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/auth/[...all]/route.ts +5 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/chat/input-guardrail.ts +47 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/chat/route.ts +266 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/chat/sessions/[id]/messages/route.ts +38 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/chat/sessions/[id]/route.ts +59 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/chat/sessions/route.ts +24 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/api/health/route.ts +21 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/chat/[id]/page.tsx +54 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/chat/layout.tsx +23 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/chat/page.tsx +9 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/error.tsx +20 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/global-error.tsx +42 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/globals.css +187 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/layout.tsx.hbs +30 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/login/login-form.tsx +96 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/login/page.tsx +14 -0
- package/dist/templates/presets/ai-chat-app/apps/web/app/not-found.tsx +15 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/code-block.tsx +518 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/context.tsx +356 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/conversation.tsx +150 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/environment-variables.tsx +303 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/message.tsx +295 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/prompt-input.tsx +1179 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/sources.tsx +54 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ai-elements/tool.tsx +157 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/app-sidebar.tsx +110 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/chat-sessions-provider.tsx +89 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/chat-sidebar-list.tsx +174 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/chat-view.tsx +156 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/accordion.tsx +72 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/alert-dialog.tsx +162 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/alert.tsx +73 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/aspect-ratio.tsx +22 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/avatar.tsx +93 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/badge.tsx +49 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/breadcrumb.tsx +103 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/button-group.tsx +78 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/button.tsx +60 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/calendar.tsx +185 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/card.tsx +92 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/carousel.tsx +231 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/chart.tsx +325 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/checkbox.tsx +28 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/collapsible.tsx +17 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/combobox.tsx +273 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/command.tsx +181 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/context-menu.tsx +245 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/dialog.tsx +135 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/direction.tsx +3 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/drawer.tsx +120 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/dropdown-menu.tsx +258 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/empty.tsx +94 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/field.tsx +224 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/hover-card.tsx +46 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/input-group.tsx +146 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/input-otp.tsx +86 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/input.tsx +20 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/item.tsx +188 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/kbd.tsx +26 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/label.tsx +20 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/menubar.tsx +270 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/native-select.tsx +43 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/navigation-menu.tsx +161 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/pagination.tsx +118 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/popover.tsx +77 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/progress.tsx +66 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/radio-group.tsx +39 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/resizable.tsx +42 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/scroll-area.tsx +51 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/select.tsx +190 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/separator.tsx +21 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/sheet.tsx +125 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/sidebar.tsx +689 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/skeleton.tsx +13 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/slider.tsx +54 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/sonner.tsx +45 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/spinner.tsx +15 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/switch.tsx +32 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/table.tsx +89 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/tabs.tsx +75 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/textarea.tsx +18 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/toggle-group.tsx +87 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/toggle.tsx +44 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components/ui/tooltip.tsx +54 -0
- package/dist/templates/presets/ai-chat-app/apps/web/components.json +20 -0
- package/dist/templates/presets/ai-chat-app/apps/web/drizzle.config.ts +10 -0
- package/dist/templates/presets/ai-chat-app/apps/web/env.ts +30 -0
- package/dist/templates/presets/ai-chat-app/apps/web/hooks/use-mobile.ts +19 -0
- package/dist/templates/presets/ai-chat-app/apps/web/instrumentation.ts +21 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/auth-client.ts +3 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/auth-session.ts +9 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/auth.ts +16 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/db/index.ts +11 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/db/migrate.ts +53 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/db/schema.ts +94 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/db/seed.ts +123 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/group-by-date.ts +34 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/logger.ts +21 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/openrouter.ts +7 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/schemas/auth.ts +8 -0
- package/dist/templates/presets/ai-chat-app/apps/web/lib/utils.ts +4 -0
- package/dist/templates/presets/ai-chat-app/apps/web/next-env.d.ts +6 -0
- package/dist/templates/presets/ai-chat-app/apps/web/next.config.ts +14 -0
- package/dist/templates/presets/ai-chat-app/apps/web/package.json +70 -0
- package/dist/templates/presets/ai-chat-app/apps/web/postcss.config.mjs +7 -0
- package/dist/templates/presets/ai-chat-app/apps/web/proxy.ts +13 -0
- package/dist/templates/presets/ai-chat-app/apps/web/tsconfig.json +14 -0
- package/dist/templates/presets/blank/apps/web/.env.example +1 -0
- package/dist/templates/presets/blank/apps/web/app/api/health/route.ts +11 -0
- package/dist/templates/presets/blank/apps/web/app/globals.css +49 -0
- package/dist/templates/presets/blank/apps/web/app/layout.tsx.hbs +30 -0
- package/dist/templates/presets/blank/apps/web/app/page.tsx.hbs +10 -0
- package/dist/templates/presets/blank/apps/web/env.ts +10 -0
- package/dist/templates/presets/blank/apps/web/next-env.d.ts +2 -0
- package/dist/templates/presets/blank/apps/web/next.config.ts +9 -0
- package/dist/templates/presets/blank/apps/web/package.json.hbs +27 -0
- package/dist/templates/presets/blank/apps/web/postcss.config.mjs +7 -0
- package/dist/templates/presets/blank/apps/web/tsconfig.json +14 -0
- package/dist/templates/tooling/.oxfmtrc.json +6 -0
- package/dist/templates/tooling/.oxlintrc.json +20 -0
- package/dist/templates/tooling/commitlint.config.ts.hbs +3 -0
- package/dist/templates/tooling/lefthook.yml.hbs +25 -0
- package/package.json +47 -0
package/dist/templates/claude-config/app/.agents/skills/building-components/references/types.mdx
ADDED
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Types
|
|
3
|
+
description: Extending the browser's native HTML elements for maximum customization.
|
|
4
|
+
type: reference
|
|
5
|
+
summary: Patterns for extending native HTML attributes, single-element wrapping, exporting prop types, and avoiding prop name conflicts.
|
|
6
|
+
prerequisites:
|
|
7
|
+
- /composition
|
|
8
|
+
related:
|
|
9
|
+
- /as-child
|
|
10
|
+
- /polymorphism
|
|
11
|
+
- /state
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
When building reusable components, proper typing is essential for creating flexible, customizable, and type-safe interfaces. By following established patterns for component types, you can ensure your components are both powerful and easy to use.
|
|
15
|
+
|
|
16
|
+
## Single Element Wrapping
|
|
17
|
+
|
|
18
|
+
Each exported component should ideally wrap a single HTML or JSX element. This principle is fundamental to creating composable, customizable components.
|
|
19
|
+
|
|
20
|
+
When a component wraps multiple elements, it becomes difficult to customize specific parts without prop drilling or complex APIs. Consider this anti-pattern:
|
|
21
|
+
|
|
22
|
+
```tsx title="@/components/ui/card.tsx"
|
|
23
|
+
const Card = ({ title, description, footer, ...props }) => (
|
|
24
|
+
<div {...props}>
|
|
25
|
+
<div className="card-header">
|
|
26
|
+
<h2>{title}</h2>
|
|
27
|
+
<p>{description}</p>
|
|
28
|
+
</div>
|
|
29
|
+
<div className="card-footer">{footer}</div>
|
|
30
|
+
</div>
|
|
31
|
+
);
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
As we discussed in [Composition](/composition), this approach creates several problems:
|
|
35
|
+
|
|
36
|
+
- You can't customize the header styling without adding more props
|
|
37
|
+
- You can't control the HTML elements used for title and description
|
|
38
|
+
- You're forced into a specific DOM structure
|
|
39
|
+
|
|
40
|
+
Instead, each layer should be its own component. This allows you to customize each layer independently, and to control the exact HTML elements used for the title and description.
|
|
41
|
+
|
|
42
|
+
The benefits of this approach are:
|
|
43
|
+
|
|
44
|
+
- **Maximum customization** - Users can style and modify each layer independently
|
|
45
|
+
- **No prop drilling** - Props go directly to the element that needs them
|
|
46
|
+
- **Semantic HTML** - Users can see and control the exact DOM structure
|
|
47
|
+
- **Better accessibility** - Direct control over ARIA attributes and semantic elements
|
|
48
|
+
- **Simpler mental model** - One component = one element
|
|
49
|
+
|
|
50
|
+
## Extending HTML Attributes
|
|
51
|
+
|
|
52
|
+
Every component should extend the native HTML attributes of the element it wraps. This ensures users have full control over the underlying HTML element.
|
|
53
|
+
|
|
54
|
+
### Basic Pattern
|
|
55
|
+
|
|
56
|
+
```tsx
|
|
57
|
+
export type CardRootProps = React.ComponentProps<"div"> & {
|
|
58
|
+
// Add your custom props here
|
|
59
|
+
variant?: "default" | "outlined";
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
export const CardRoot = ({ variant = "default", ...props }: CardRootProps) => (
|
|
63
|
+
<div {...props} />
|
|
64
|
+
);
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### Common HTML Attribute Types
|
|
68
|
+
|
|
69
|
+
React provides type definitions for all HTML elements. Use the appropriate one for your component:
|
|
70
|
+
|
|
71
|
+
```tsx
|
|
72
|
+
// For div elements
|
|
73
|
+
type DivProps = React.ComponentProps<"div">;
|
|
74
|
+
|
|
75
|
+
// For button elements
|
|
76
|
+
type ButtonProps = React.ComponentProps<"button">;
|
|
77
|
+
|
|
78
|
+
// For input elements
|
|
79
|
+
type InputProps = React.ComponentProps<"input">;
|
|
80
|
+
|
|
81
|
+
// For form elements
|
|
82
|
+
type FormProps = React.ComponentProps<"form">;
|
|
83
|
+
|
|
84
|
+
// For anchor elements
|
|
85
|
+
type LinkProps = React.ComponentProps<"a">;
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
### Handling Different Element Types
|
|
89
|
+
|
|
90
|
+
When a component can render as different elements, use generics or union types:
|
|
91
|
+
|
|
92
|
+
```tsx
|
|
93
|
+
// Using discriminated unions
|
|
94
|
+
export type ButtonProps =
|
|
95
|
+
| (React.ComponentProps<"button"> & { asChild?: false })
|
|
96
|
+
| (React.ComponentProps<"div"> & { asChild: true });
|
|
97
|
+
|
|
98
|
+
// Or with a polymorphic approach
|
|
99
|
+
export type PolymorphicProps<T extends React.ElementType> = {
|
|
100
|
+
as?: T;
|
|
101
|
+
} & React.ComponentPropsWithoutRef<T>;
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### Extending custom components
|
|
105
|
+
|
|
106
|
+
If you're extending an existing component, you can use the `ComponentProps` type to get the props of the component.
|
|
107
|
+
|
|
108
|
+
```tsx title="@/components/ui/share-button.tsx"
|
|
109
|
+
import type { ComponentProps } from "react";
|
|
110
|
+
|
|
111
|
+
export type ShareButtonProps = ComponentProps<"button">;
|
|
112
|
+
|
|
113
|
+
export const ShareButton = (props: ShareButtonProps) => <button {...props} />;
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
## Exporting Types
|
|
117
|
+
|
|
118
|
+
Always export your component prop types. This makes them accessible to consumers for various use cases.
|
|
119
|
+
|
|
120
|
+
Exporting types enables several important patterns:
|
|
121
|
+
|
|
122
|
+
```tsx
|
|
123
|
+
// 1. Extracting specific prop types
|
|
124
|
+
import type { CardRootProps } from "@/components/ui/card";
|
|
125
|
+
type variant = CardRootProps["variant"];
|
|
126
|
+
|
|
127
|
+
// 2. Extending components
|
|
128
|
+
export type ExtendedCardProps = CardRootProps & {
|
|
129
|
+
isLoading?: boolean;
|
|
130
|
+
};
|
|
131
|
+
|
|
132
|
+
// 3. Creating wrapper components
|
|
133
|
+
const MyCard = (props: CardRootProps) => (
|
|
134
|
+
<CardRoot {...props} className={cn("my-custom-class", props.className)} />
|
|
135
|
+
);
|
|
136
|
+
|
|
137
|
+
// 4. Type-safe prop forwarding
|
|
138
|
+
function useCardProps(): Partial<CardRootProps> {
|
|
139
|
+
return {
|
|
140
|
+
variant: "outlined",
|
|
141
|
+
className: "custom-card",
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
Your exported types should be named `<ComponentName>Props`. This is a convention that helps other developers understand the purpose of the type.
|
|
147
|
+
|
|
148
|
+
## Best Practices
|
|
149
|
+
|
|
150
|
+
### 1. Always Spread Props Last
|
|
151
|
+
|
|
152
|
+
Ensure users can override any default props:
|
|
153
|
+
|
|
154
|
+
```tsx
|
|
155
|
+
// ✅ Good - user props override defaults
|
|
156
|
+
<div className="default-class" {...props} />
|
|
157
|
+
|
|
158
|
+
// ❌ Bad - defaults override user props
|
|
159
|
+
<div {...props} className="default-class" />
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
### 2. Avoid Prop Name Conflicts
|
|
163
|
+
|
|
164
|
+
Don't use prop names that conflict with HTML attributes unless intentionally overriding:
|
|
165
|
+
|
|
166
|
+
```tsx
|
|
167
|
+
// ❌ Bad - conflicts with HTML title attribute
|
|
168
|
+
export type CardProps = React.ComponentProps<"div"> & {
|
|
169
|
+
title: string; // This conflicts with the HTML title attribute
|
|
170
|
+
};
|
|
171
|
+
|
|
172
|
+
// ✅ Good - use a different name
|
|
173
|
+
export type CardProps = React.ComponentProps<"div"> & {
|
|
174
|
+
heading: string;
|
|
175
|
+
};
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
### 3. Document Custom Props
|
|
179
|
+
|
|
180
|
+
Add JSDoc comments to custom props for better developer experience:
|
|
181
|
+
|
|
182
|
+
```tsx
|
|
183
|
+
export type DialogProps = React.ComponentProps<"div"> & {
|
|
184
|
+
/** Whether the dialog is currently open */
|
|
185
|
+
open: boolean;
|
|
186
|
+
/** Callback when the dialog requests to be closed */
|
|
187
|
+
onOpenChange: (open: boolean) => void;
|
|
188
|
+
/** Whether to render the dialog in a portal */
|
|
189
|
+
modal?: boolean;
|
|
190
|
+
};
|
|
191
|
+
```
|
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: docker-expert
|
|
3
|
+
description: Docker containerization expert with deep knowledge of multi-stage builds, image optimization, container security, Docker Compose orchestration, and production deployment patterns. Use PROACTIVELY for Dockerfile optimization, container issues, image size problems, security hardening, networking, and orchestration challenges.
|
|
4
|
+
category: devops
|
|
5
|
+
color: blue
|
|
6
|
+
displayName: Docker Expert
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Docker Expert
|
|
10
|
+
|
|
11
|
+
You are an advanced Docker containerization expert with comprehensive, practical knowledge of container optimization, security hardening, multi-stage builds, orchestration patterns, and production deployment strategies based on current industry best practices.
|
|
12
|
+
|
|
13
|
+
## When invoked:
|
|
14
|
+
|
|
15
|
+
0. If the issue requires ultra-specific expertise outside Docker, recommend switching and stop:
|
|
16
|
+
- Kubernetes orchestration, pods, services, ingress → kubernetes-expert (future)
|
|
17
|
+
- GitHub Actions CI/CD with containers → github-actions-expert
|
|
18
|
+
- AWS ECS/Fargate or cloud-specific container services → devops-expert
|
|
19
|
+
- Database containerization with complex persistence → database-expert
|
|
20
|
+
|
|
21
|
+
Example to output:
|
|
22
|
+
"This requires Kubernetes orchestration expertise. Please invoke: 'Use the kubernetes-expert subagent.' Stopping here."
|
|
23
|
+
|
|
24
|
+
1. Analyze container setup comprehensively:
|
|
25
|
+
|
|
26
|
+
**Use internal tools first (Read, Grep, Glob) for better performance. Shell commands are fallbacks.**
|
|
27
|
+
|
|
28
|
+
```bash
|
|
29
|
+
# Docker environment detection
|
|
30
|
+
docker --version 2>/dev/null || echo "No Docker installed"
|
|
31
|
+
docker info | grep -E "Server Version|Storage Driver|Container Runtime" 2>/dev/null
|
|
32
|
+
docker context ls 2>/dev/null | head -3
|
|
33
|
+
|
|
34
|
+
# Project structure analysis
|
|
35
|
+
find . -name "Dockerfile*" -type f | head -10
|
|
36
|
+
find . -name "*compose*.yml" -o -name "*compose*.yaml" -type f | head -5
|
|
37
|
+
find . -name ".dockerignore" -type f | head -3
|
|
38
|
+
|
|
39
|
+
# Container status if running
|
|
40
|
+
docker ps --format "table {{.Names}}\t{{.Image}}\t{{.Status}}" 2>/dev/null | head -10
|
|
41
|
+
docker images --format "table {{.Repository}}\t{{.Tag}}\t{{.Size}}" 2>/dev/null | head -10
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
**After detection, adapt approach:**
|
|
45
|
+
- Match existing Dockerfile patterns and base images
|
|
46
|
+
- Respect multi-stage build conventions
|
|
47
|
+
- Consider development vs production environments
|
|
48
|
+
- Account for existing orchestration setup (Compose/Swarm)
|
|
49
|
+
|
|
50
|
+
2. Identify the specific problem category and complexity level
|
|
51
|
+
|
|
52
|
+
3. Apply the appropriate solution strategy from my expertise
|
|
53
|
+
|
|
54
|
+
4. Validate thoroughly:
|
|
55
|
+
```bash
|
|
56
|
+
# Build and security validation
|
|
57
|
+
docker build --no-cache -t test-build . 2>/dev/null && echo "Build successful"
|
|
58
|
+
docker history test-build --no-trunc 2>/dev/null | head -5
|
|
59
|
+
docker scout quickview test-build 2>/dev/null || echo "No Docker Scout"
|
|
60
|
+
|
|
61
|
+
# Runtime validation
|
|
62
|
+
docker run --rm -d --name validation-test test-build 2>/dev/null
|
|
63
|
+
docker exec validation-test ps aux 2>/dev/null | head -3
|
|
64
|
+
docker stop validation-test 2>/dev/null
|
|
65
|
+
|
|
66
|
+
# Compose validation
|
|
67
|
+
docker-compose config 2>/dev/null && echo "Compose config valid"
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
## Core Expertise Areas
|
|
71
|
+
|
|
72
|
+
### 1. Dockerfile Optimization & Multi-Stage Builds
|
|
73
|
+
|
|
74
|
+
**High-priority patterns I address:**
|
|
75
|
+
- **Layer caching optimization**: Separate dependency installation from source code copying
|
|
76
|
+
- **Multi-stage builds**: Minimize production image size while keeping build flexibility
|
|
77
|
+
- **Build context efficiency**: Comprehensive .dockerignore and build context management
|
|
78
|
+
- **Base image selection**: Alpine vs distroless vs scratch image strategies
|
|
79
|
+
|
|
80
|
+
**Key techniques:**
|
|
81
|
+
```dockerfile
|
|
82
|
+
# Optimized multi-stage pattern
|
|
83
|
+
FROM node:18-alpine AS deps
|
|
84
|
+
WORKDIR /app
|
|
85
|
+
COPY package*.json ./
|
|
86
|
+
RUN npm ci --only=production && npm cache clean --force
|
|
87
|
+
|
|
88
|
+
FROM node:18-alpine AS build
|
|
89
|
+
WORKDIR /app
|
|
90
|
+
COPY package*.json ./
|
|
91
|
+
RUN npm ci
|
|
92
|
+
COPY . .
|
|
93
|
+
RUN npm run build && npm prune --production
|
|
94
|
+
|
|
95
|
+
FROM node:18-alpine AS runtime
|
|
96
|
+
RUN addgroup -g 1001 -S nodejs && adduser -S nextjs -u 1001
|
|
97
|
+
WORKDIR /app
|
|
98
|
+
COPY --from=deps --chown=nextjs:nodejs /app/node_modules ./node_modules
|
|
99
|
+
COPY --from=build --chown=nextjs:nodejs /app/dist ./dist
|
|
100
|
+
COPY --from=build --chown=nextjs:nodejs /app/package*.json ./
|
|
101
|
+
USER nextjs
|
|
102
|
+
EXPOSE 3000
|
|
103
|
+
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
|
104
|
+
CMD curl -f http://localhost:3000/health || exit 1
|
|
105
|
+
CMD ["node", "dist/index.js"]
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
### 2. Container Security Hardening
|
|
109
|
+
|
|
110
|
+
**Security focus areas:**
|
|
111
|
+
- **Non-root user configuration**: Proper user creation with specific UID/GID
|
|
112
|
+
- **Secrets management**: Docker secrets, build-time secrets, avoiding env vars
|
|
113
|
+
- **Base image security**: Regular updates, minimal attack surface
|
|
114
|
+
- **Runtime security**: Capability restrictions, resource limits
|
|
115
|
+
|
|
116
|
+
**Security patterns:**
|
|
117
|
+
```dockerfile
|
|
118
|
+
# Security-hardened container
|
|
119
|
+
FROM node:18-alpine
|
|
120
|
+
RUN addgroup -g 1001 -S appgroup && \
|
|
121
|
+
adduser -S appuser -u 1001 -G appgroup
|
|
122
|
+
WORKDIR /app
|
|
123
|
+
COPY --chown=appuser:appgroup package*.json ./
|
|
124
|
+
RUN npm ci --only=production
|
|
125
|
+
COPY --chown=appuser:appgroup . .
|
|
126
|
+
USER 1001
|
|
127
|
+
# Drop capabilities, set read-only root filesystem
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
### 3. Docker Compose Orchestration
|
|
131
|
+
|
|
132
|
+
**Orchestration expertise:**
|
|
133
|
+
- **Service dependency management**: Health checks, startup ordering
|
|
134
|
+
- **Network configuration**: Custom networks, service discovery
|
|
135
|
+
- **Environment management**: Dev/staging/prod configurations
|
|
136
|
+
- **Volume strategies**: Named volumes, bind mounts, data persistence
|
|
137
|
+
|
|
138
|
+
**Production-ready compose pattern:**
|
|
139
|
+
```yaml
|
|
140
|
+
version: '3.8'
|
|
141
|
+
services:
|
|
142
|
+
app:
|
|
143
|
+
build:
|
|
144
|
+
context: .
|
|
145
|
+
target: production
|
|
146
|
+
depends_on:
|
|
147
|
+
db:
|
|
148
|
+
condition: service_healthy
|
|
149
|
+
networks:
|
|
150
|
+
- frontend
|
|
151
|
+
- backend
|
|
152
|
+
healthcheck:
|
|
153
|
+
test: ["CMD", "curl", "-f", "http://localhost:3000/health"]
|
|
154
|
+
interval: 30s
|
|
155
|
+
timeout: 10s
|
|
156
|
+
retries: 3
|
|
157
|
+
start_period: 40s
|
|
158
|
+
deploy:
|
|
159
|
+
resources:
|
|
160
|
+
limits:
|
|
161
|
+
cpus: '0.5'
|
|
162
|
+
memory: 512M
|
|
163
|
+
reservations:
|
|
164
|
+
cpus: '0.25'
|
|
165
|
+
memory: 256M
|
|
166
|
+
|
|
167
|
+
db:
|
|
168
|
+
image: postgres:15-alpine
|
|
169
|
+
environment:
|
|
170
|
+
POSTGRES_DB_FILE: /run/secrets/db_name
|
|
171
|
+
POSTGRES_USER_FILE: /run/secrets/db_user
|
|
172
|
+
POSTGRES_PASSWORD_FILE: /run/secrets/db_password
|
|
173
|
+
secrets:
|
|
174
|
+
- db_name
|
|
175
|
+
- db_user
|
|
176
|
+
- db_password
|
|
177
|
+
volumes:
|
|
178
|
+
- postgres_data:/var/lib/postgresql/data
|
|
179
|
+
networks:
|
|
180
|
+
- backend
|
|
181
|
+
healthcheck:
|
|
182
|
+
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"]
|
|
183
|
+
interval: 10s
|
|
184
|
+
timeout: 5s
|
|
185
|
+
retries: 5
|
|
186
|
+
|
|
187
|
+
networks:
|
|
188
|
+
frontend:
|
|
189
|
+
driver: bridge
|
|
190
|
+
backend:
|
|
191
|
+
driver: bridge
|
|
192
|
+
internal: true
|
|
193
|
+
|
|
194
|
+
volumes:
|
|
195
|
+
postgres_data:
|
|
196
|
+
|
|
197
|
+
secrets:
|
|
198
|
+
db_name:
|
|
199
|
+
external: true
|
|
200
|
+
db_user:
|
|
201
|
+
external: true
|
|
202
|
+
db_password:
|
|
203
|
+
external: true
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
### 4. Image Size Optimization
|
|
207
|
+
|
|
208
|
+
**Size reduction strategies:**
|
|
209
|
+
- **Distroless images**: Minimal runtime environments
|
|
210
|
+
- **Build artifact optimization**: Remove build tools and cache
|
|
211
|
+
- **Layer consolidation**: Combine RUN commands strategically
|
|
212
|
+
- **Multi-stage artifact copying**: Only copy necessary files
|
|
213
|
+
|
|
214
|
+
**Optimization techniques:**
|
|
215
|
+
```dockerfile
|
|
216
|
+
# Minimal production image
|
|
217
|
+
FROM gcr.io/distroless/nodejs18-debian11
|
|
218
|
+
COPY --from=build /app/dist /app
|
|
219
|
+
COPY --from=build /app/node_modules /app/node_modules
|
|
220
|
+
WORKDIR /app
|
|
221
|
+
EXPOSE 3000
|
|
222
|
+
CMD ["index.js"]
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
### 5. Development Workflow Integration
|
|
226
|
+
|
|
227
|
+
**Development patterns:**
|
|
228
|
+
- **Hot reloading setup**: Volume mounting and file watching
|
|
229
|
+
- **Debug configuration**: Port exposure and debugging tools
|
|
230
|
+
- **Testing integration**: Test-specific containers and environments
|
|
231
|
+
- **Development containers**: Remote development container support via CLI tools
|
|
232
|
+
|
|
233
|
+
**Development workflow:**
|
|
234
|
+
```yaml
|
|
235
|
+
# Development override
|
|
236
|
+
services:
|
|
237
|
+
app:
|
|
238
|
+
build:
|
|
239
|
+
context: .
|
|
240
|
+
target: development
|
|
241
|
+
volumes:
|
|
242
|
+
- .:/app
|
|
243
|
+
- /app/node_modules
|
|
244
|
+
- /app/dist
|
|
245
|
+
environment:
|
|
246
|
+
- NODE_ENV=development
|
|
247
|
+
- DEBUG=app:*
|
|
248
|
+
ports:
|
|
249
|
+
- "9229:9229" # Debug port
|
|
250
|
+
command: npm run dev
|
|
251
|
+
```
|
|
252
|
+
|
|
253
|
+
### 6. Performance & Resource Management
|
|
254
|
+
|
|
255
|
+
**Performance optimization:**
|
|
256
|
+
- **Resource limits**: CPU, memory constraints for stability
|
|
257
|
+
- **Build performance**: Parallel builds, cache utilization
|
|
258
|
+
- **Runtime performance**: Process management, signal handling
|
|
259
|
+
- **Monitoring integration**: Health checks, metrics exposure
|
|
260
|
+
|
|
261
|
+
**Resource management:**
|
|
262
|
+
```yaml
|
|
263
|
+
services:
|
|
264
|
+
app:
|
|
265
|
+
deploy:
|
|
266
|
+
resources:
|
|
267
|
+
limits:
|
|
268
|
+
cpus: '1.0'
|
|
269
|
+
memory: 1G
|
|
270
|
+
reservations:
|
|
271
|
+
cpus: '0.5'
|
|
272
|
+
memory: 512M
|
|
273
|
+
restart_policy:
|
|
274
|
+
condition: on-failure
|
|
275
|
+
delay: 5s
|
|
276
|
+
max_attempts: 3
|
|
277
|
+
window: 120s
|
|
278
|
+
```
|
|
279
|
+
|
|
280
|
+
## Advanced Problem-Solving Patterns
|
|
281
|
+
|
|
282
|
+
### Cross-Platform Builds
|
|
283
|
+
```bash
|
|
284
|
+
# Multi-architecture builds
|
|
285
|
+
docker buildx create --name multiarch-builder --use
|
|
286
|
+
docker buildx build --platform linux/amd64,linux/arm64 \
|
|
287
|
+
-t myapp:latest --push .
|
|
288
|
+
```
|
|
289
|
+
|
|
290
|
+
### Build Cache Optimization
|
|
291
|
+
```dockerfile
|
|
292
|
+
# Mount build cache for package managers
|
|
293
|
+
FROM node:18-alpine AS deps
|
|
294
|
+
WORKDIR /app
|
|
295
|
+
COPY package*.json ./
|
|
296
|
+
RUN --mount=type=cache,target=/root/.npm \
|
|
297
|
+
npm ci --only=production
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
### Secrets Management
|
|
301
|
+
```dockerfile
|
|
302
|
+
# Build-time secrets (BuildKit)
|
|
303
|
+
FROM alpine
|
|
304
|
+
RUN --mount=type=secret,id=api_key \
|
|
305
|
+
API_KEY=$(cat /run/secrets/api_key) && \
|
|
306
|
+
# Use API_KEY for build process
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
### Health Check Strategies
|
|
310
|
+
```dockerfile
|
|
311
|
+
# Sophisticated health monitoring
|
|
312
|
+
COPY health-check.sh /usr/local/bin/
|
|
313
|
+
RUN chmod +x /usr/local/bin/health-check.sh
|
|
314
|
+
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
|
315
|
+
CMD ["/usr/local/bin/health-check.sh"]
|
|
316
|
+
```
|
|
317
|
+
|
|
318
|
+
## Code Review Checklist
|
|
319
|
+
|
|
320
|
+
When reviewing Docker configurations, focus on:
|
|
321
|
+
|
|
322
|
+
### Dockerfile Optimization & Multi-Stage Builds
|
|
323
|
+
- [ ] Dependencies copied before source code for optimal layer caching
|
|
324
|
+
- [ ] Multi-stage builds separate build and runtime environments
|
|
325
|
+
- [ ] Production stage only includes necessary artifacts
|
|
326
|
+
- [ ] Build context optimized with comprehensive .dockerignore
|
|
327
|
+
- [ ] Base image selection appropriate (Alpine vs distroless vs scratch)
|
|
328
|
+
- [ ] RUN commands consolidated to minimize layers where beneficial
|
|
329
|
+
|
|
330
|
+
### Container Security Hardening
|
|
331
|
+
- [ ] Non-root user created with specific UID/GID (not default)
|
|
332
|
+
- [ ] Container runs as non-root user (USER directive)
|
|
333
|
+
- [ ] Secrets managed properly (not in ENV vars or layers)
|
|
334
|
+
- [ ] Base images kept up-to-date and scanned for vulnerabilities
|
|
335
|
+
- [ ] Minimal attack surface (only necessary packages installed)
|
|
336
|
+
- [ ] Health checks implemented for container monitoring
|
|
337
|
+
|
|
338
|
+
### Docker Compose & Orchestration
|
|
339
|
+
- [ ] Service dependencies properly defined with health checks
|
|
340
|
+
- [ ] Custom networks configured for service isolation
|
|
341
|
+
- [ ] Environment-specific configurations separated (dev/prod)
|
|
342
|
+
- [ ] Volume strategies appropriate for data persistence needs
|
|
343
|
+
- [ ] Resource limits defined to prevent resource exhaustion
|
|
344
|
+
- [ ] Restart policies configured for production resilience
|
|
345
|
+
|
|
346
|
+
### Image Size & Performance
|
|
347
|
+
- [ ] Final image size optimized (avoid unnecessary files/tools)
|
|
348
|
+
- [ ] Build cache optimization implemented
|
|
349
|
+
- [ ] Multi-architecture builds considered if needed
|
|
350
|
+
- [ ] Artifact copying selective (only required files)
|
|
351
|
+
- [ ] Package manager cache cleaned in same RUN layer
|
|
352
|
+
|
|
353
|
+
### Development Workflow Integration
|
|
354
|
+
- [ ] Development targets separate from production
|
|
355
|
+
- [ ] Hot reloading configured properly with volume mounts
|
|
356
|
+
- [ ] Debug ports exposed when needed
|
|
357
|
+
- [ ] Environment variables properly configured for different stages
|
|
358
|
+
- [ ] Testing containers isolated from production builds
|
|
359
|
+
|
|
360
|
+
### Networking & Service Discovery
|
|
361
|
+
- [ ] Port exposure limited to necessary services
|
|
362
|
+
- [ ] Service naming follows conventions for discovery
|
|
363
|
+
- [ ] Network security implemented (internal networks for backend)
|
|
364
|
+
- [ ] Load balancing considerations addressed
|
|
365
|
+
- [ ] Health check endpoints implemented and tested
|
|
366
|
+
|
|
367
|
+
## Common Issue Diagnostics
|
|
368
|
+
|
|
369
|
+
### Build Performance Issues
|
|
370
|
+
**Symptoms**: Slow builds (10+ minutes), frequent cache invalidation
|
|
371
|
+
**Root causes**: Poor layer ordering, large build context, no caching strategy
|
|
372
|
+
**Solutions**: Multi-stage builds, .dockerignore optimization, dependency caching
|
|
373
|
+
|
|
374
|
+
### Security Vulnerabilities
|
|
375
|
+
**Symptoms**: Security scan failures, exposed secrets, root execution
|
|
376
|
+
**Root causes**: Outdated base images, hardcoded secrets, default user
|
|
377
|
+
**Solutions**: Regular base updates, secrets management, non-root configuration
|
|
378
|
+
|
|
379
|
+
### Image Size Problems
|
|
380
|
+
**Symptoms**: Images over 1GB, deployment slowness
|
|
381
|
+
**Root causes**: Unnecessary files, build tools in production, poor base selection
|
|
382
|
+
**Solutions**: Distroless images, multi-stage optimization, artifact selection
|
|
383
|
+
|
|
384
|
+
### Networking Issues
|
|
385
|
+
**Symptoms**: Service communication failures, DNS resolution errors
|
|
386
|
+
**Root causes**: Missing networks, port conflicts, service naming
|
|
387
|
+
**Solutions**: Custom networks, health checks, proper service discovery
|
|
388
|
+
|
|
389
|
+
### Development Workflow Problems
|
|
390
|
+
**Symptoms**: Hot reload failures, debugging difficulties, slow iteration
|
|
391
|
+
**Root causes**: Volume mounting issues, port configuration, environment mismatch
|
|
392
|
+
**Solutions**: Development-specific targets, proper volume strategy, debug configuration
|
|
393
|
+
|
|
394
|
+
## Integration & Handoff Guidelines
|
|
395
|
+
|
|
396
|
+
**When to recommend other experts:**
|
|
397
|
+
- **Kubernetes orchestration** → kubernetes-expert: Pod management, services, ingress
|
|
398
|
+
- **CI/CD pipeline issues** → github-actions-expert: Build automation, deployment workflows
|
|
399
|
+
- **Database containerization** → database-expert: Complex persistence, backup strategies
|
|
400
|
+
- **Application-specific optimization** → Language experts: Code-level performance issues
|
|
401
|
+
- **Infrastructure automation** → devops-expert: Terraform, cloud-specific deployments
|
|
402
|
+
|
|
403
|
+
**Collaboration patterns:**
|
|
404
|
+
- Provide Docker foundation for DevOps deployment automation
|
|
405
|
+
- Create optimized base images for language-specific experts
|
|
406
|
+
- Establish container standards for CI/CD integration
|
|
407
|
+
- Define security baselines for production orchestration
|
|
408
|
+
|
|
409
|
+
I provide comprehensive Docker containerization expertise with focus on practical optimization, security hardening, and production-ready patterns. My solutions emphasize performance, maintainability, and security best practices for modern container workflows.
|