@polymorphism-tech/morph-spec 4.3.3 → 4.3.5
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/.morph/.morphversion +5 -0
- package/.morph/analytics/threads-log.jsonl +9 -0
- package/{stacks/blazor-azure/.morph → .morph}/config/agents.json +948 -948
- package/.morph/config/config.json +9 -0
- package/{stacks/blazor-azure/.morph → .morph}/project/context/README.md +1 -1
- package/.morph/project/context/detection-log.md +16 -0
- package/.morph/project/standards/inferred.md +59 -0
- package/.morph/state.json +48 -0
- package/.morph/templates/.idea/morph-templates.xml +92 -0
- package/.morph/templates/.vscode/morph-templates.code-snippets +186 -0
- package/.morph/templates/IDE-SNIPPETS.md +266 -0
- package/.morph/templates/README.md +814 -0
- package/.morph/templates/REGISTRY.json +1677 -0
- package/.morph/templates/code/dotnet/backend/repository.cs +141 -0
- package/.morph/templates/code/dotnet/backend/service.cs +139 -0
- package/.morph/templates/code/dotnet/contracts/Commands.cs +74 -0
- package/.morph/templates/code/dotnet/contracts/Entities.cs +25 -0
- package/.morph/templates/code/dotnet/contracts/Queries.cs +74 -0
- package/.morph/templates/code/dotnet/contracts/README.md +74 -0
- package/.morph/templates/code/dotnet/contracts/api-contracts.cs +173 -0
- package/.morph/templates/code/dotnet/contracts/contracts.cs +217 -0
- package/.morph/templates/code/dotnet/database/migration.cs +83 -0
- package/.morph/templates/code/dotnet/frontend/component.razor +239 -0
- package/.morph/templates/code/dotnet/jobs/agent.cs +163 -0
- package/.morph/templates/code/dotnet/jobs/job.cs +171 -0
- package/.morph/templates/code/dotnet/test.cs +239 -0
- package/.morph/templates/code/sql/rls-policy.sql +57 -0
- package/.morph/templates/code/sql/supabase-migration.sql +100 -0
- package/.morph/templates/code/sql/supabase-migration.template.sql +113 -0
- package/.morph/templates/code/typescript/contracts.ts +168 -0
- package/.morph/templates/context/CONTEXT-FEATURE.md +276 -0
- package/.morph/templates/context/CONTEXT.md +181 -0
- package/.morph/templates/docs/proposal.md +182 -0
- package/.morph/templates/docs/spec.md +149 -0
- package/.morph/templates/examples/design-system-examples.md +357 -0
- package/.morph/templates/examples/spec-examples.md +90 -0
- package/.morph/templates/feature/decisions.md +187 -0
- package/.morph/templates/feature/recap.md +146 -0
- package/.morph/templates/feature/tasks.md +199 -0
- package/.morph/templates/infrastructure/azure/Dockerfile.example +82 -0
- package/.morph/templates/infrastructure/azure/README.md +286 -0
- package/.morph/templates/infrastructure/azure/app-insights.bicep +63 -0
- package/.morph/templates/infrastructure/azure/app-service.bicep +164 -0
- package/.morph/templates/infrastructure/azure/container-app-env.bicep +49 -0
- package/.morph/templates/infrastructure/azure/container-app.bicep +156 -0
- package/.morph/templates/infrastructure/azure/deploy-checklist.md +426 -0
- package/.morph/templates/infrastructure/azure/deploy.ps1 +229 -0
- package/.morph/templates/infrastructure/azure/deploy.sh +208 -0
- package/.morph/templates/infrastructure/azure/key-vault.bicep +91 -0
- package/.morph/templates/infrastructure/azure/main.bicep +189 -0
- package/.morph/templates/infrastructure/azure/parameters.dev.json +29 -0
- package/.morph/templates/infrastructure/azure/parameters.prod.json +29 -0
- package/.morph/templates/infrastructure/azure/parameters.staging.json +29 -0
- package/.morph/templates/infrastructure/azure/sql-database.bicep +103 -0
- package/.morph/templates/infrastructure/azure/storage.bicep +106 -0
- package/.morph/templates/infrastructure/docker/Dockerfile.template +58 -0
- package/.morph/templates/infrastructure/docker/docker-compose.template.yml +67 -0
- package/.morph/templates/infrastructure/docker/dockerfile-api.dockerfile +38 -0
- package/.morph/templates/infrastructure/docker/dockerfile-web.dockerfile +48 -0
- package/.morph/templates/infrastructure/docker/easypanel.template.json +54 -0
- package/.morph/templates/infrastructure/github/README.md +593 -0
- package/.morph/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +22 -0
- package/.morph/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +45 -0
- package/.morph/templates/infrastructure/github/actions/health-check/action.yml.hbs +27 -0
- package/.morph/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +61 -0
- package/.morph/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +31 -0
- package/.morph/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +59 -0
- package/.morph/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +39 -0
- package/.morph/templates/integrations/asaas-client.cs +387 -0
- package/.morph/templates/integrations/asaas-webhook.cs +351 -0
- package/.morph/templates/integrations/azure-identity-config.cs +288 -0
- package/.morph/templates/integrations/clerk-config.cs +258 -0
- package/.morph/templates/meta-prompts/fusion/fusion-agent.md +76 -0
- package/.morph/templates/meta-prompts/fusion/fusion-aggregator.md +100 -0
- package/.morph/templates/meta-prompts/hops/hop-retry.md +78 -0
- package/.morph/templates/meta-prompts/hops/hop-validation.md +97 -0
- package/.morph/templates/meta-prompts/hops/hop-wrapper.md +36 -0
- package/.morph/templates/meta-prompts/parallel-workers/parallel-coordinator.md +113 -0
- package/.morph/templates/meta-prompts/parallel-workers/parallel-worker.md +80 -0
- package/.morph/templates/meta-prompts/squad-leaders/backend-squad.md +90 -0
- package/.morph/templates/meta-prompts/squad-leaders/frontend-squad.md +126 -0
- package/.morph/templates/meta-prompts/squad-leaders/squad-leader.md +43 -0
- package/.morph/templates/meta-prompts/validators/checkpoint-validator.md +107 -0
- package/.morph/templates/meta-prompts/validators/pre-commit-validator.md +95 -0
- package/.morph/templates/saas/subscription.cs +347 -0
- package/.morph/templates/saas/tenant.cs +338 -0
- package/.morph/templates/state.template.json +17 -0
- package/.morph/templates/ui/FluentDesignTheme.cs +149 -0
- package/.morph/templates/ui/MudTheme.cs +281 -0
- package/.morph/templates/ui/design-system.css +226 -0
- package/bin/detect-agents.js +1 -2
- package/bin/morph-spec.js +1 -14
- package/framework/agents.json +948 -0
- package/{stacks/nextjs-supabase/.claude → framework}/commands/morph-infra.md +1 -1
- package/framework/hooks/README.md +282 -0
- package/framework/hooks/agent-stop/validate-and-continue.js +96 -0
- package/framework/hooks/agent-stop/validate-checkpoints.js +101 -0
- package/framework/hooks/agent-stop/validate-tests.js +109 -0
- package/framework/hooks/agent-teams/dispatch.js +67 -0
- package/framework/hooks/agent-teams/phase-advanced.js +80 -0
- package/framework/hooks/agent-teams/task-completed.js +76 -0
- package/framework/hooks/agent-teams/teammate-idle.js +70 -0
- package/framework/hooks/commit-msg/conventional-commits.sh +33 -0
- package/framework/hooks/pre-commit/agents.sh +25 -0
- package/framework/hooks/pre-commit/orchestrator.sh +64 -0
- package/framework/hooks/pre-commit/specs.sh +50 -0
- package/framework/hooks/pre-push/run-tests.sh +44 -0
- package/framework/index/troubleshooting-index.json +184 -0
- package/framework/memory/patterns-learned.md +766 -0
- package/framework/skills/level-0-meta/README.md +7 -0
- package/framework/skills/level-0-meta/code-review.md +226 -0
- package/framework/skills/level-0-meta/morph-checklist.md +117 -0
- package/framework/skills/level-0-meta/simulation-checklist.md +77 -0
- package/framework/skills/level-1-workflows/README.md +7 -0
- package/framework/skills/level-1-workflows/morph-replicate.md +213 -0
- package/framework/skills/level-1-workflows/phase-clarify.md +131 -0
- package/framework/skills/level-1-workflows/phase-design.md +213 -0
- package/framework/skills/level-1-workflows/phase-setup.md +106 -0
- package/framework/skills/level-1-workflows/phase-tasks.md +164 -0
- package/framework/skills/level-1-workflows/phase-uiux.md +169 -0
- package/framework/skills/level-2-domains/README.md +14 -0
- package/framework/skills/level-2-domains/ai-agents/ai-system-architect.md +192 -0
- package/framework/skills/level-2-domains/architecture/po-pm-advisor.md +197 -0
- package/framework/skills/level-2-domains/architecture/prompt-engineer.md +189 -0
- package/framework/skills/level-2-domains/architecture/seo-growth-hacker.md +320 -0
- package/framework/skills/level-2-domains/architecture/standards-architect.md +156 -0
- package/framework/skills/level-2-domains/backend/api-designer.md +59 -0
- package/framework/skills/level-2-domains/backend/dotnet-senior.md +77 -0
- package/framework/skills/level-2-domains/backend/ef-modeler.md +58 -0
- package/framework/skills/level-2-domains/backend/hangfire-orchestrator.md +126 -0
- package/framework/skills/level-2-domains/backend/ms-agent-expert.md +45 -0
- package/framework/skills/level-2-domains/frontend/blazor-builder.md +210 -0
- package/framework/skills/level-2-domains/frontend/nextjs-expert.md +154 -0
- package/framework/skills/level-2-domains/frontend/ui-ux-designer.md +191 -0
- package/framework/skills/level-2-domains/infrastructure/azure-architect.md +142 -0
- package/framework/skills/level-2-domains/infrastructure/azure-deploy-specialist.md +699 -0
- package/framework/skills/level-2-domains/infrastructure/bicep-architect.md +126 -0
- package/framework/skills/level-2-domains/infrastructure/container-specialist.md +131 -0
- package/framework/skills/level-2-domains/infrastructure/devops-engineer.md +119 -0
- package/framework/skills/level-2-domains/integrations/asaas-financial.md +130 -0
- package/framework/skills/level-2-domains/integrations/azure-identity.md +142 -0
- package/framework/skills/level-2-domains/integrations/clerk-auth.md +108 -0
- package/framework/skills/level-2-domains/integrations/hangfire-orchestrator.md +64 -0
- package/framework/skills/level-2-domains/integrations/resend-email.md +119 -0
- package/framework/skills/level-2-domains/quality/code-analyzer.md +235 -0
- package/framework/skills/level-2-domains/quality/testing-specialist.md +126 -0
- package/framework/skills/level-3-technologies/README.md +7 -0
- package/framework/skills/level-4-patterns/README.md +7 -0
- package/framework/squad-templates/backend-only.json +34 -0
- package/framework/squad-templates/frontend-only.json +34 -0
- package/framework/squad-templates/full-stack.json +52 -0
- package/framework/templates/.idea/morph-templates.xml +92 -0
- package/framework/templates/.vscode/morph-templates.code-snippets +186 -0
- package/framework/templates/IDE-SNIPPETS.md +266 -0
- package/framework/templates/README.md +814 -0
- package/framework/templates/REGISTRY.json +1677 -0
- package/framework/templates/code/dotnet/backend/repository.cs +141 -0
- package/framework/templates/code/dotnet/backend/service.cs +139 -0
- package/framework/templates/code/dotnet/contracts/Commands.cs +74 -0
- package/framework/templates/code/dotnet/contracts/Entities.cs +25 -0
- package/framework/templates/code/dotnet/contracts/Queries.cs +74 -0
- package/framework/templates/code/dotnet/contracts/README.md +74 -0
- package/framework/templates/code/dotnet/contracts/api-contracts.cs +173 -0
- package/framework/templates/code/dotnet/contracts/contracts.cs +217 -0
- package/framework/templates/code/dotnet/database/migration.cs +83 -0
- package/framework/templates/code/dotnet/frontend/component.razor +239 -0
- package/framework/templates/code/dotnet/jobs/agent.cs +163 -0
- package/framework/templates/code/dotnet/jobs/job.cs +171 -0
- package/framework/templates/code/dotnet/test.cs +239 -0
- package/framework/templates/code/sql/rls-policy.sql +57 -0
- package/framework/templates/code/sql/supabase-migration.sql +100 -0
- package/framework/templates/code/sql/supabase-migration.template.sql +113 -0
- package/framework/templates/code/typescript/contracts.ts +168 -0
- package/framework/templates/context/CONTEXT-FEATURE.md +276 -0
- package/framework/templates/context/CONTEXT.md +181 -0
- package/framework/templates/docs/proposal.md +182 -0
- package/framework/templates/docs/spec.md +149 -0
- package/framework/templates/examples/design-system-examples.md +357 -0
- package/framework/templates/examples/spec-examples.md +90 -0
- package/framework/templates/feature/decisions.md +187 -0
- package/framework/templates/feature/recap.md +146 -0
- package/framework/templates/feature/tasks.md +199 -0
- package/framework/templates/infrastructure/azure/Dockerfile.example +82 -0
- package/framework/templates/infrastructure/azure/README.md +286 -0
- package/framework/templates/infrastructure/azure/app-insights.bicep +63 -0
- package/framework/templates/infrastructure/azure/app-service.bicep +164 -0
- package/framework/templates/infrastructure/azure/container-app-env.bicep +49 -0
- package/framework/templates/infrastructure/azure/container-app.bicep +156 -0
- package/framework/templates/infrastructure/azure/deploy-checklist.md +426 -0
- package/framework/templates/infrastructure/azure/deploy.ps1 +229 -0
- package/framework/templates/infrastructure/azure/deploy.sh +208 -0
- package/framework/templates/infrastructure/azure/key-vault.bicep +91 -0
- package/framework/templates/infrastructure/azure/main.bicep +189 -0
- package/framework/templates/infrastructure/azure/parameters.dev.json +29 -0
- package/framework/templates/infrastructure/azure/parameters.prod.json +29 -0
- package/framework/templates/infrastructure/azure/parameters.staging.json +29 -0
- package/framework/templates/infrastructure/azure/sql-database.bicep +103 -0
- package/framework/templates/infrastructure/azure/storage.bicep +106 -0
- package/framework/templates/infrastructure/docker/Dockerfile.template +58 -0
- package/framework/templates/infrastructure/docker/docker-compose.template.yml +67 -0
- package/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +38 -0
- package/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +48 -0
- package/framework/templates/infrastructure/docker/easypanel.template.json +54 -0
- package/framework/templates/infrastructure/github/README.md +593 -0
- package/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +22 -0
- package/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +45 -0
- package/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +27 -0
- package/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +61 -0
- package/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +31 -0
- package/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +59 -0
- package/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +39 -0
- package/framework/templates/integrations/asaas-client.cs +387 -0
- package/framework/templates/integrations/asaas-webhook.cs +351 -0
- package/framework/templates/integrations/azure-identity-config.cs +288 -0
- package/framework/templates/integrations/clerk-config.cs +258 -0
- package/framework/templates/meta-prompts/fusion/fusion-agent.md +76 -0
- package/framework/templates/meta-prompts/fusion/fusion-aggregator.md +100 -0
- package/framework/templates/meta-prompts/hops/hop-retry.md +78 -0
- package/framework/templates/meta-prompts/hops/hop-validation.md +97 -0
- package/framework/templates/meta-prompts/hops/hop-wrapper.md +36 -0
- package/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +113 -0
- package/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +80 -0
- package/framework/templates/meta-prompts/squad-leaders/backend-squad.md +90 -0
- package/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +126 -0
- package/framework/templates/meta-prompts/squad-leaders/squad-leader.md +43 -0
- package/framework/templates/meta-prompts/validators/checkpoint-validator.md +107 -0
- package/framework/templates/meta-prompts/validators/pre-commit-validator.md +95 -0
- package/framework/templates/saas/subscription.cs +347 -0
- package/framework/templates/saas/tenant.cs +338 -0
- package/framework/templates/state.template.json +17 -0
- package/framework/templates/ui/FluentDesignTheme.cs +149 -0
- package/framework/templates/ui/MudTheme.cs +281 -0
- package/framework/templates/ui/design-system.css +226 -0
- package/framework/workflows/README.md +1041 -0
- package/framework/workflows/configs/design-impl.json +49 -0
- package/framework/workflows/configs/fast-track.json +42 -0
- package/framework/workflows/configs/full-morph.json +79 -0
- package/framework/workflows/configs/fusion.json +39 -0
- package/framework/workflows/configs/long-running.json +33 -0
- package/framework/workflows/configs/standard.json +60 -0
- package/framework/workflows/configs/ui-refresh.json +49 -0
- package/framework/workflows/configs/zero-touch.json +75 -0
- package/framework/workflows/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -0
- package/framework/workflows/docs/design-impl.md +37 -0
- package/framework/workflows/docs/enforcement-pipeline.md +668 -0
- package/framework/workflows/docs/fast-track.md +29 -0
- package/framework/workflows/docs/full-morph.md +76 -0
- package/framework/workflows/docs/standard.md +44 -0
- package/framework/workflows/docs/ui-refresh.md +39 -0
- package/package.json +3 -3
- package/src/commands/feature/create-story.js +11 -7
- package/src/commands/project/detect-agents.js +1 -2
- package/src/commands/project/init.js +69 -32
- package/src/commands/project/update.js +102 -15
- package/src/commands/templates/template-customize.js +3 -17
- package/src/commands/templates/template-list.js +1 -15
- package/src/commands/templates/template-render.js +2 -3
- package/src/commands/templates/template-show.js +3 -5
- package/src/core/templates/template-registry.js +9 -23
- package/src/lib/detectors/structure-detector.js +3 -3
- package/src/lib/generators/context-generator.js +18 -6
- package/src/lib/hooks/hook-executor.js +0 -2
- package/src/lib/orchestration/team-orchestrator.js +1 -2
- package/src/lib/standards/standards-context-injector.js +3 -4
- package/src/lib/troubleshooting/troubleshoot-grep.js +3 -9
- package/src/lib/validators/validation-runner.js +1 -2
- package/src/utils/file-copier.js +1 -2
- package/docs/README.md +0 -144
- package/docs/api/fonts/Montserrat/Montserrat-Bold.eot +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Bold.ttf +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Bold.woff +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Bold.woff2 +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Regular.eot +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Regular.ttf +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Regular.woff +0 -0
- package/docs/api/fonts/Montserrat/Montserrat-Regular.woff2 +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.eot +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.svg +0 -978
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.ttf +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.woff +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.woff2 +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.eot +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.svg +0 -1049
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.ttf +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.woff +0 -0
- package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.woff2 +0 -0
- package/docs/api/scripts/collapse.js +0 -39
- package/docs/api/scripts/commonNav.js +0 -28
- package/docs/api/scripts/linenumber.js +0 -25
- package/docs/api/scripts/nav.js +0 -12
- package/docs/api/scripts/polyfill.js +0 -4
- package/docs/api/scripts/prettify/Apache-License-2.0.txt +0 -202
- package/docs/api/scripts/prettify/lang-css.js +0 -2
- package/docs/api/scripts/prettify/prettify.js +0 -28
- package/docs/api/scripts/search.js +0 -99
- package/docs/api/styles/jsdoc.css +0 -776
- package/docs/api/styles/prettify.css +0 -80
- package/docs/cli-auto-detection.md +0 -219
- package/docs/getting-started.md +0 -296
- package/docs/installation.md +0 -361
- package/docs/next-generation/AGENTS.md +0 -521
- package/docs/next-generation/ANALYSIS.md +0 -555
- package/docs/next-generation/ARCHITECTURE.md +0 -436
- package/docs/next-generation/CONTEXT-OPTIMIZATION.md +0 -267
- package/docs/next-generation/EXECUTION-FLOW.md +0 -274
- package/docs/next-generation/FEATURES.md +0 -688
- package/docs/next-generation/META-PROMPTS.md +0 -235
- package/docs/next-generation/MIGRATION-GUIDE.md +0 -253
- package/docs/next-generation/README.md +0 -231
- package/docs/next-generation/ROADMAP.md +0 -801
- package/docs/next-generation/THREAD-MANAGEMENT.md +0 -240
- package/docs/templates.md +0 -418
- package/docs/troubleshooting.md +0 -269
- package/docs/validation-checklist.md +0 -264
- package/scripts/postinstall.js +0 -132
- package/src/lib/stacks/index.js +0 -7
- package/src/lib/stacks/stack-resolver.js +0 -180
- package/stacks/blazor-azure/.claude/commands/morph-deploy.md +0 -529
- package/stacks/blazor-azure/.claude/commands/morph-infra.md +0 -209
- package/stacks/blazor-azure/.morph/.morphversion +0 -5
- package/stacks/blazor-azure/.morph/config/config.json +0 -9
- package/stacks/blazor-azure/CLAUDE.md +0 -155
- package/stacks/blazor-azure/README.md +0 -79
- package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +0 -221
- package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +0 -79
- package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +0 -529
- package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +0 -227
- package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +0 -122
- package/stacks/nextjs-supabase/.claude/commands/morph-status.md +0 -86
- package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +0 -122
- package/stacks/nextjs-supabase/.morph/.morphversion +0 -5
- package/stacks/nextjs-supabase/.morph/config/agents.json +0 -345
- package/stacks/nextjs-supabase/.morph/config/config.json +0 -9
- package/stacks/nextjs-supabase/.morph/project/context/README.md +0 -17
- package/stacks/nextjs-supabase/CLAUDE.md +0 -155
- package/stacks/nextjs-supabase/README.md +0 -103
- /package/{stacks/blazor-azure/.morph → .morph}/standards/ai-agents/blazor-ui.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/ai-agents/production.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/ai-agents/setup.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/ai-agents/team-orchestration.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/ai-agents/workflows.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/architecture/ddd/aggregates.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/architecture/ddd/entities.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/architecture/ddd/value-objects.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/api/minimal-api.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/api/rest.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/api/validation.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/authentication/passkeys.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/database/ef-core.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/database/migrations.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/database/postgresql/database.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/database/repository-patterns.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/database/vector-search-rag.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/dotnet/async.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/dotnet/core.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/dotnet/di.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/dotnet/program-cs-checklist.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/integrations/asaas/asaas-api.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/integrations/clerk/clerk-auth.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/backend/integrations/resend/resend-email.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/context/analytics.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/context/bundles.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/context/priming.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/core/architecture.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/core/coding.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/core/git-branching-strategy.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/core/git.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/core/testing.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/data/nosql/blob-storage.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/data/nosql/cache/redis.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/data/nosql/cosmos-db.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/data/vector-search/azure-ai-search.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/data/vector-search/rag-chunking.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/design-checklist.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/fluent-ui-setup.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/fluent-ui.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/html-conversion.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/lifecycle.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/pitfalls.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/blazor/state.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/design-system/animations.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/design-system/naming.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/frontend/nextjs/nextjs-patterns.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/azure.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/devops/local-development.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/services/functions.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/services/service-bus.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/azure/services/storage.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/docker/easypanel-deploy.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/supabase/mcp-setup.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/supabase/supabase-auth.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/supabase/supabase-pgvector.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/supabase/supabase-rls.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/infrastructure/supabase/supabase-storage.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/api/graphql.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/api/grpc.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/api/rest-design.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/event-driven/cqrs.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/event-driven/event-sourcing.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/integration/event-driven/service-bus.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/observability/logging.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/observability/metrics.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/observability/monitoring.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/observability/tracing.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/workflows/parallel-execution.md +0 -0
- /package/{stacks/blazor-azure/.morph → .morph}/standards/workflows/thread-management.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-apply.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-archive.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-preflight.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-proposal.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-status.md +0 -0
- /package/{stacks/blazor-azure/.claude → framework}/commands/morph-troubleshoot.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/ai-agents/blazor-ui.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/ai-agents/production.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/ai-agents/setup.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/ai-agents/team-orchestration.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/ai-agents/workflows.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/architecture/ddd/aggregates.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/architecture/ddd/entities.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/architecture/ddd/value-objects.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/api/minimal-api.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/api/rest.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/api/validation.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/authentication/passkeys.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/database/ef-core.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/database/migrations.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/database/postgresql/database.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/database/repository-patterns.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/database/vector-search-rag.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/dotnet/async.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/dotnet/core.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/dotnet/di.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/dotnet/program-cs-checklist.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/integrations/asaas/asaas-api.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/integrations/clerk/clerk-auth.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/backend/integrations/resend/resend-email.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/context/analytics.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/context/bundles.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/context/priming.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/core/architecture.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/core/coding.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/core/git-branching-strategy.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/core/git.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/core/testing.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/data/nosql/blob-storage.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/data/nosql/cache/redis.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/data/nosql/cosmos-db.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/data/vector-search/azure-ai-search.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/data/vector-search/rag-chunking.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/design-checklist.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/fluent-ui-setup.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/fluent-ui.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/html-conversion.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/lifecycle.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/pitfalls.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/blazor/state.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/design-system/animations.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/design-system/naming.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/frontend/nextjs/nextjs-patterns.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/azure.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/devops/local-development.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/services/functions.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/services/service-bus.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/azure/services/storage.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/docker/easypanel-deploy.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/supabase/mcp-setup.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/supabase/supabase-auth.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/supabase/supabase-pgvector.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/supabase/supabase-rls.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/infrastructure/supabase/supabase-storage.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/api/graphql.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/api/grpc.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/api/rest-design.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/event-driven/cqrs.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/event-driven/event-sourcing.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/integration/event-driven/service-bus.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/observability/logging.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/observability/metrics.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/observability/monitoring.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/observability/tracing.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/workflows/parallel-execution.md +0 -0
- /package/{stacks/nextjs-supabase/.morph → framework}/standards/workflows/thread-management.md +0 -0
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// TEST TEMPLATE
|
|
3
|
+
// Generated by MORPH Framework
|
|
4
|
+
// ============================================================
|
|
5
|
+
|
|
6
|
+
using FluentAssertions;
|
|
7
|
+
using Microsoft.Extensions.Logging;
|
|
8
|
+
using NSubstitute;
|
|
9
|
+
using Xunit;
|
|
10
|
+
|
|
11
|
+
namespace {{NAMESPACE}}.Tests.Unit.Features.{{pascalCase FEATURE_NAME}};
|
|
12
|
+
|
|
13
|
+
/// <summary>
|
|
14
|
+
/// Unit tests for {{pascalCase FEATURE_NAME}}Service.
|
|
15
|
+
/// </summary>
|
|
16
|
+
public class {{pascalCase FEATURE_NAME}}ServiceTests
|
|
17
|
+
{
|
|
18
|
+
private readonly I{{pascalCase FEATURE_NAME}}Repository _repository;
|
|
19
|
+
private readonly ILogger<{{pascalCase FEATURE_NAME}}Service> _logger;
|
|
20
|
+
private readonly {{pascalCase FEATURE_NAME}}Service _sut;
|
|
21
|
+
|
|
22
|
+
public {{pascalCase FEATURE_NAME}}ServiceTests()
|
|
23
|
+
{
|
|
24
|
+
_repository = Substitute.For<I{{pascalCase FEATURE_NAME}}Repository>();
|
|
25
|
+
_logger = Substitute.For<ILogger<{{pascalCase FEATURE_NAME}}Service>>();
|
|
26
|
+
_sut = new {{pascalCase FEATURE_NAME}}Service(_repository, _logger);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
#region GetByIdAsync Tests
|
|
30
|
+
|
|
31
|
+
[Fact]
|
|
32
|
+
public async Task GetByIdAsync_WithValidId_ReturnsDto()
|
|
33
|
+
{
|
|
34
|
+
// Arrange
|
|
35
|
+
var id = 1;
|
|
36
|
+
var entity = CreateTestEntity(id, "Test {{pascalCase FEATURE_NAME}}");
|
|
37
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
38
|
+
.Returns(entity);
|
|
39
|
+
|
|
40
|
+
// Act
|
|
41
|
+
var result = await _sut.GetByIdAsync(id);
|
|
42
|
+
|
|
43
|
+
// Assert
|
|
44
|
+
result.Should().NotBeNull();
|
|
45
|
+
result!.Id.Should().Be(id);
|
|
46
|
+
result.Name.Should().Be("Test {{pascalCase FEATURE_NAME}}");
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
[Fact]
|
|
50
|
+
public async Task GetByIdAsync_WithInvalidId_ReturnsNull()
|
|
51
|
+
{
|
|
52
|
+
// Arrange
|
|
53
|
+
var id = 999;
|
|
54
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
55
|
+
.Returns((Domain.Entities.{{pascalCase FEATURE_NAME}}?)null);
|
|
56
|
+
|
|
57
|
+
// Act
|
|
58
|
+
var result = await _sut.GetByIdAsync(id);
|
|
59
|
+
|
|
60
|
+
// Assert
|
|
61
|
+
result.Should().BeNull();
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
#endregion
|
|
65
|
+
|
|
66
|
+
#region GetAllAsync Tests
|
|
67
|
+
|
|
68
|
+
[Fact]
|
|
69
|
+
public async Task GetAllAsync_ReturnsAllItems()
|
|
70
|
+
{
|
|
71
|
+
// Arrange
|
|
72
|
+
var entities = new List<Domain.Entities.{{pascalCase FEATURE_NAME}}>
|
|
73
|
+
{
|
|
74
|
+
CreateTestEntity(1, "First"),
|
|
75
|
+
CreateTestEntity(2, "Second"),
|
|
76
|
+
CreateTestEntity(3, "Third")
|
|
77
|
+
};
|
|
78
|
+
_repository.GetAllAsync(Arg.Any<CancellationToken>())
|
|
79
|
+
.Returns(entities);
|
|
80
|
+
|
|
81
|
+
// Act
|
|
82
|
+
var result = await _sut.GetAllAsync();
|
|
83
|
+
|
|
84
|
+
// Assert
|
|
85
|
+
result.Should().HaveCount(3);
|
|
86
|
+
result[0].Name.Should().Be("First");
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
[Fact]
|
|
90
|
+
public async Task GetAllAsync_WithNoItems_ReturnsEmptyList()
|
|
91
|
+
{
|
|
92
|
+
// Arrange
|
|
93
|
+
_repository.GetAllAsync(Arg.Any<CancellationToken>())
|
|
94
|
+
.Returns(new List<Domain.Entities.{{pascalCase FEATURE_NAME}}>());
|
|
95
|
+
|
|
96
|
+
// Act
|
|
97
|
+
var result = await _sut.GetAllAsync();
|
|
98
|
+
|
|
99
|
+
// Assert
|
|
100
|
+
result.Should().BeEmpty();
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
#endregion
|
|
104
|
+
|
|
105
|
+
#region CreateAsync Tests
|
|
106
|
+
|
|
107
|
+
[Fact]
|
|
108
|
+
public async Task CreateAsync_WithValidRequest_CreatesAndReturnsDto()
|
|
109
|
+
{
|
|
110
|
+
// Arrange
|
|
111
|
+
var request = new Create{{pascalCase FEATURE_NAME}}Request("New {{pascalCase FEATURE_NAME}}");
|
|
112
|
+
|
|
113
|
+
_repository
|
|
114
|
+
.When(x => x.AddAsync(Arg.Any<Domain.Entities.{{pascalCase FEATURE_NAME}}>(), Arg.Any<CancellationToken>()))
|
|
115
|
+
.Do(x =>
|
|
116
|
+
{
|
|
117
|
+
// Simulate ID assignment
|
|
118
|
+
var entity = x.Arg<Domain.Entities.{{pascalCase FEATURE_NAME}}>();
|
|
119
|
+
// entity.Id would be set by EF Core
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
// Act
|
|
123
|
+
var result = await _sut.CreateAsync(request);
|
|
124
|
+
|
|
125
|
+
// Assert
|
|
126
|
+
result.Should().NotBeNull();
|
|
127
|
+
result.Name.Should().Be("New {{pascalCase FEATURE_NAME}}");
|
|
128
|
+
|
|
129
|
+
await _repository.Received(1).AddAsync(Arg.Any<Domain.Entities.{{pascalCase FEATURE_NAME}}>(), Arg.Any<CancellationToken>());
|
|
130
|
+
await _repository.Received(1).SaveChangesAsync(Arg.Any<CancellationToken>());
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
[Theory]
|
|
134
|
+
[InlineData("")]
|
|
135
|
+
[InlineData(" ")]
|
|
136
|
+
[InlineData(null)]
|
|
137
|
+
public async Task CreateAsync_WithInvalidName_ThrowsValidationException(string? name)
|
|
138
|
+
{
|
|
139
|
+
// Arrange
|
|
140
|
+
var request = new Create{{pascalCase FEATURE_NAME}}Request(name!);
|
|
141
|
+
|
|
142
|
+
// Act
|
|
143
|
+
var act = async () => await _sut.CreateAsync(request);
|
|
144
|
+
|
|
145
|
+
// Assert
|
|
146
|
+
await act.Should().ThrowAsync<ValidationException>();
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
#endregion
|
|
150
|
+
|
|
151
|
+
#region UpdateAsync Tests
|
|
152
|
+
|
|
153
|
+
[Fact]
|
|
154
|
+
public async Task UpdateAsync_WithValidRequest_UpdatesEntity()
|
|
155
|
+
{
|
|
156
|
+
// Arrange
|
|
157
|
+
var id = 1;
|
|
158
|
+
var entity = CreateTestEntity(id, "Original");
|
|
159
|
+
var request = new Update{{pascalCase FEATURE_NAME}}Request("Updated");
|
|
160
|
+
|
|
161
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
162
|
+
.Returns(entity);
|
|
163
|
+
|
|
164
|
+
// Act
|
|
165
|
+
await _sut.UpdateAsync(id, request);
|
|
166
|
+
|
|
167
|
+
// Assert
|
|
168
|
+
_repository.Received(1).Update(Arg.Any<Domain.Entities.{{pascalCase FEATURE_NAME}}>());
|
|
169
|
+
await _repository.Received(1).SaveChangesAsync(Arg.Any<CancellationToken>());
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
[Fact]
|
|
173
|
+
public async Task UpdateAsync_WithNonExistentId_ThrowsNotFoundException()
|
|
174
|
+
{
|
|
175
|
+
// Arrange
|
|
176
|
+
var id = 999;
|
|
177
|
+
var request = new Update{{pascalCase FEATURE_NAME}}Request("Updated");
|
|
178
|
+
|
|
179
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
180
|
+
.Returns((Domain.Entities.{{pascalCase FEATURE_NAME}}?)null);
|
|
181
|
+
|
|
182
|
+
// Act
|
|
183
|
+
var act = async () => await _sut.UpdateAsync(id, request);
|
|
184
|
+
|
|
185
|
+
// Assert
|
|
186
|
+
await act.Should().ThrowAsync<{{pascalCase FEATURE_NAME}}NotFoundException>();
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
#endregion
|
|
190
|
+
|
|
191
|
+
#region DeleteAsync Tests
|
|
192
|
+
|
|
193
|
+
[Fact]
|
|
194
|
+
public async Task DeleteAsync_WithValidId_DeletesEntity()
|
|
195
|
+
{
|
|
196
|
+
// Arrange
|
|
197
|
+
var id = 1;
|
|
198
|
+
var entity = CreateTestEntity(id, "To Delete");
|
|
199
|
+
|
|
200
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
201
|
+
.Returns(entity);
|
|
202
|
+
|
|
203
|
+
// Act
|
|
204
|
+
await _sut.DeleteAsync(id);
|
|
205
|
+
|
|
206
|
+
// Assert
|
|
207
|
+
_repository.Received(1).Remove(entity);
|
|
208
|
+
await _repository.Received(1).SaveChangesAsync(Arg.Any<CancellationToken>());
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
[Fact]
|
|
212
|
+
public async Task DeleteAsync_WithNonExistentId_ThrowsNotFoundException()
|
|
213
|
+
{
|
|
214
|
+
// Arrange
|
|
215
|
+
var id = 999;
|
|
216
|
+
|
|
217
|
+
_repository.GetByIdAsync(id, Arg.Any<CancellationToken>())
|
|
218
|
+
.Returns((Domain.Entities.{{pascalCase FEATURE_NAME}}?)null);
|
|
219
|
+
|
|
220
|
+
// Act
|
|
221
|
+
var act = async () => await _sut.DeleteAsync(id);
|
|
222
|
+
|
|
223
|
+
// Assert
|
|
224
|
+
await act.Should().ThrowAsync<{{pascalCase FEATURE_NAME}}NotFoundException>();
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
#endregion
|
|
228
|
+
|
|
229
|
+
#region Helper Methods
|
|
230
|
+
|
|
231
|
+
private static Domain.Entities.{{pascalCase FEATURE_NAME}} CreateTestEntity(int id, string name)
|
|
232
|
+
{
|
|
233
|
+
return Domain.Entities.{{pascalCase FEATURE_NAME}}.Create(name);
|
|
234
|
+
// Note: In real tests, you might need reflection to set the Id
|
|
235
|
+
// or use a factory method that accepts an id for testing
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
#endregion
|
|
239
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
-- ============================================================
|
|
2
|
+
-- RLS Policy: {{titleCase FEATURE_NAME}}
|
|
3
|
+
-- Stack: Next.js + Supabase
|
|
4
|
+
-- Generated by MORPH Framework
|
|
5
|
+
-- Date: {{DATE}}
|
|
6
|
+
-- ============================================================
|
|
7
|
+
|
|
8
|
+
-- Enable RLS on table
|
|
9
|
+
alter table public.{{TABLE_NAME}} enable row level security;
|
|
10
|
+
|
|
11
|
+
-- Force RLS for table owner (prevents bypassing)
|
|
12
|
+
alter table public.{{TABLE_NAME}} force row level security;
|
|
13
|
+
|
|
14
|
+
-- Policy: {{POLICY_NAME}}
|
|
15
|
+
-- Operation: {{OPERATION}} (SELECT | INSERT | UPDATE | DELETE | ALL)
|
|
16
|
+
|
|
17
|
+
-- SELECT policy: users can read their own rows
|
|
18
|
+
create policy "{{POLICY_NAME}}_select"
|
|
19
|
+
on public.{{TABLE_NAME}}
|
|
20
|
+
for select
|
|
21
|
+
using ({{USING_EXPRESSION}});
|
|
22
|
+
|
|
23
|
+
-- INSERT policy: users can insert rows for themselves
|
|
24
|
+
create policy "{{POLICY_NAME}}_insert"
|
|
25
|
+
on public.{{TABLE_NAME}}
|
|
26
|
+
for insert
|
|
27
|
+
with check ({{WITH_CHECK_EXPRESSION}});
|
|
28
|
+
|
|
29
|
+
-- UPDATE policy: users can update their own rows
|
|
30
|
+
create policy "{{POLICY_NAME}}_update"
|
|
31
|
+
on public.{{TABLE_NAME}}
|
|
32
|
+
for update
|
|
33
|
+
using ({{USING_EXPRESSION}})
|
|
34
|
+
with check ({{WITH_CHECK_EXPRESSION}});
|
|
35
|
+
|
|
36
|
+
-- DELETE policy: users can delete their own rows
|
|
37
|
+
create policy "{{POLICY_NAME}}_delete"
|
|
38
|
+
on public.{{TABLE_NAME}}
|
|
39
|
+
for delete
|
|
40
|
+
using ({{USING_EXPRESSION}});
|
|
41
|
+
|
|
42
|
+
-- ============================================================
|
|
43
|
+
-- Common USING / WITH CHECK expressions:
|
|
44
|
+
--
|
|
45
|
+
-- Owner-based:
|
|
46
|
+
-- auth.uid() = user_id
|
|
47
|
+
--
|
|
48
|
+
-- Role-based:
|
|
49
|
+
-- auth.jwt() ->> 'role' = 'admin'
|
|
50
|
+
--
|
|
51
|
+
-- Organization-based:
|
|
52
|
+
-- org_id in (select org_id from public.org_members where user_id = auth.uid())
|
|
53
|
+
--
|
|
54
|
+
-- Public read, owner write:
|
|
55
|
+
-- SELECT using (true)
|
|
56
|
+
-- INSERT/UPDATE/DELETE using (auth.uid() = user_id)
|
|
57
|
+
-- ============================================================
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
-- ============================================================
|
|
2
|
+
-- Migration: {{titleCase FEATURE_NAME}}
|
|
3
|
+
-- Stack: Next.js + Supabase
|
|
4
|
+
-- Generated by MORPH Framework
|
|
5
|
+
-- Date: {{DATE}}
|
|
6
|
+
-- Run: supabase db push
|
|
7
|
+
-- ============================================================
|
|
8
|
+
|
|
9
|
+
-- ============================================================
|
|
10
|
+
-- 1. TABLE CREATION
|
|
11
|
+
-- ============================================================
|
|
12
|
+
|
|
13
|
+
create table if not exists public.{{TABLE_NAME}} (
|
|
14
|
+
id uuid primary key default gen_random_uuid(),
|
|
15
|
+
user_id uuid not null references auth.users(id) on delete cascade,
|
|
16
|
+
name text not null,
|
|
17
|
+
status text not null default 'draft'
|
|
18
|
+
check (status in ('draft', 'active', 'completed', 'archived', 'failed', 'cancelled')),
|
|
19
|
+
-- Add feature-specific columns here
|
|
20
|
+
metadata jsonb default '{}'::jsonb,
|
|
21
|
+
created_at timestamptz not null default now(),
|
|
22
|
+
updated_at timestamptz
|
|
23
|
+
);
|
|
24
|
+
|
|
25
|
+
-- Comment on table
|
|
26
|
+
comment on table public.{{TABLE_NAME}} is '{{titleCase FEATURE_NAME}} - managed by MORPH Framework';
|
|
27
|
+
|
|
28
|
+
-- ============================================================
|
|
29
|
+
-- 2. INDEXES
|
|
30
|
+
-- ============================================================
|
|
31
|
+
|
|
32
|
+
-- Index for filtering by owner
|
|
33
|
+
create index if not exists idx_{{TABLE_NAME}}_user_id
|
|
34
|
+
on public.{{TABLE_NAME}} (user_id);
|
|
35
|
+
|
|
36
|
+
-- Index for filtering by status
|
|
37
|
+
create index if not exists idx_{{TABLE_NAME}}_status
|
|
38
|
+
on public.{{TABLE_NAME}} (status);
|
|
39
|
+
|
|
40
|
+
-- Index for sorting by creation date
|
|
41
|
+
create index if not exists idx_{{TABLE_NAME}}_created_at
|
|
42
|
+
on public.{{TABLE_NAME}} (created_at desc);
|
|
43
|
+
|
|
44
|
+
-- ============================================================
|
|
45
|
+
-- 3. UPDATED_AT TRIGGER
|
|
46
|
+
-- ============================================================
|
|
47
|
+
|
|
48
|
+
-- Function to auto-update updated_at
|
|
49
|
+
create or replace function public.update_updated_at_column()
|
|
50
|
+
returns trigger as $$
|
|
51
|
+
begin
|
|
52
|
+
new.updated_at = now();
|
|
53
|
+
return new;
|
|
54
|
+
end;
|
|
55
|
+
$$ language plpgsql;
|
|
56
|
+
|
|
57
|
+
-- Trigger for auto-updating updated_at
|
|
58
|
+
create trigger set_{{TABLE_NAME}}_updated_at
|
|
59
|
+
before update on public.{{TABLE_NAME}}
|
|
60
|
+
for each row execute function public.update_updated_at_column();
|
|
61
|
+
|
|
62
|
+
-- ============================================================
|
|
63
|
+
-- 4. ROW LEVEL SECURITY
|
|
64
|
+
-- ============================================================
|
|
65
|
+
|
|
66
|
+
-- Enable RLS
|
|
67
|
+
alter table public.{{TABLE_NAME}} enable row level security;
|
|
68
|
+
|
|
69
|
+
-- Users can read their own rows
|
|
70
|
+
create policy "Users can read own {{TABLE_NAME}}"
|
|
71
|
+
on public.{{TABLE_NAME}}
|
|
72
|
+
for select
|
|
73
|
+
using (auth.uid() = user_id);
|
|
74
|
+
|
|
75
|
+
-- Users can insert rows for themselves
|
|
76
|
+
create policy "Users can insert own {{TABLE_NAME}}"
|
|
77
|
+
on public.{{TABLE_NAME}}
|
|
78
|
+
for insert
|
|
79
|
+
with check (auth.uid() = user_id);
|
|
80
|
+
|
|
81
|
+
-- Users can update their own rows
|
|
82
|
+
create policy "Users can update own {{TABLE_NAME}}"
|
|
83
|
+
on public.{{TABLE_NAME}}
|
|
84
|
+
for update
|
|
85
|
+
using (auth.uid() = user_id)
|
|
86
|
+
with check (auth.uid() = user_id);
|
|
87
|
+
|
|
88
|
+
-- Users can delete their own rows
|
|
89
|
+
create policy "Users can delete own {{TABLE_NAME}}"
|
|
90
|
+
on public.{{TABLE_NAME}}
|
|
91
|
+
for delete
|
|
92
|
+
using (auth.uid() = user_id);
|
|
93
|
+
|
|
94
|
+
-- ============================================================
|
|
95
|
+
-- 5. GRANTS
|
|
96
|
+
-- ============================================================
|
|
97
|
+
|
|
98
|
+
-- Grant access to authenticated users (via Supabase API)
|
|
99
|
+
grant select, insert, update, delete on public.{{TABLE_NAME}} to authenticated;
|
|
100
|
+
grant usage on schema public to authenticated;
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
-- Migration: {{FEATURE_NAME_HUMAN}}
|
|
2
|
+
-- Created: {{DATE}}
|
|
3
|
+
-- Description: {{DESCRIPTION}}
|
|
4
|
+
|
|
5
|
+
-- Enable necessary extensions
|
|
6
|
+
create extension if not exists "uuid-ossp";
|
|
7
|
+
|
|
8
|
+
-- ========================================
|
|
9
|
+
-- Create Tables
|
|
10
|
+
-- ========================================
|
|
11
|
+
|
|
12
|
+
create table if not exists public.{{TABLE_NAME}} (
|
|
13
|
+
-- Primary key
|
|
14
|
+
id uuid primary key default gen_random_uuid(),
|
|
15
|
+
|
|
16
|
+
-- Columns
|
|
17
|
+
name text not null,
|
|
18
|
+
description text,
|
|
19
|
+
is_active boolean default true not null,
|
|
20
|
+
|
|
21
|
+
-- Foreign keys (example)
|
|
22
|
+
-- user_id uuid references auth.users(id) on delete cascade,
|
|
23
|
+
|
|
24
|
+
-- Timestamps
|
|
25
|
+
created_at timestamptz default now() not null,
|
|
26
|
+
updated_at timestamptz default now() not null
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
-- ========================================
|
|
30
|
+
-- Create Indexes
|
|
31
|
+
-- ========================================
|
|
32
|
+
|
|
33
|
+
-- Index on frequently queried columns
|
|
34
|
+
create index if not exists idx_{{TABLE_NAME}}_name
|
|
35
|
+
on public.{{TABLE_NAME}} (name);
|
|
36
|
+
|
|
37
|
+
-- Index on foreign keys (if any)
|
|
38
|
+
-- create index if not exists idx_{{TABLE_NAME}}_user_id
|
|
39
|
+
-- on public.{{TABLE_NAME}} (user_id);
|
|
40
|
+
|
|
41
|
+
-- Composite index for common queries
|
|
42
|
+
-- create index if not exists idx_{{TABLE_NAME}}_user_created
|
|
43
|
+
-- on public.{{TABLE_NAME}} (user_id, created_at desc);
|
|
44
|
+
|
|
45
|
+
-- ========================================
|
|
46
|
+
-- Create Triggers
|
|
47
|
+
-- ========================================
|
|
48
|
+
|
|
49
|
+
-- Auto-update timestamp trigger
|
|
50
|
+
create or replace function public.handle_updated_at()
|
|
51
|
+
returns trigger as $$
|
|
52
|
+
begin
|
|
53
|
+
new.updated_at = now();
|
|
54
|
+
return new;
|
|
55
|
+
end;
|
|
56
|
+
$$ language plpgsql;
|
|
57
|
+
|
|
58
|
+
create trigger {{TABLE_NAME}}_updated_at
|
|
59
|
+
before update on public.{{TABLE_NAME}}
|
|
60
|
+
for each row execute function public.handle_updated_at();
|
|
61
|
+
|
|
62
|
+
-- ========================================
|
|
63
|
+
-- Enable Row Level Security (RLS)
|
|
64
|
+
-- ========================================
|
|
65
|
+
|
|
66
|
+
alter table public.{{TABLE_NAME}} enable row level security;
|
|
67
|
+
|
|
68
|
+
-- Policy: Users can view all records (example)
|
|
69
|
+
create policy "{{TABLE_NAME}}_select_policy"
|
|
70
|
+
on public.{{TABLE_NAME}} for select
|
|
71
|
+
using (true);
|
|
72
|
+
|
|
73
|
+
-- Policy: Users can only insert their own records (example)
|
|
74
|
+
-- create policy "{{TABLE_NAME}}_insert_policy"
|
|
75
|
+
-- on public.{{TABLE_NAME}} for insert
|
|
76
|
+
-- with check (auth.uid() = user_id);
|
|
77
|
+
|
|
78
|
+
-- Policy: Users can only update their own records (example)
|
|
79
|
+
-- create policy "{{TABLE_NAME}}_update_policy"
|
|
80
|
+
-- on public.{{TABLE_NAME}} for update
|
|
81
|
+
-- using (auth.uid() = user_id)
|
|
82
|
+
-- with check (auth.uid() = user_id);
|
|
83
|
+
|
|
84
|
+
-- Policy: Users can only delete their own records (example)
|
|
85
|
+
-- create policy "{{TABLE_NAME}}_delete_policy"
|
|
86
|
+
-- on public.{{TABLE_NAME}} for delete
|
|
87
|
+
-- using (auth.uid() = user_id);
|
|
88
|
+
|
|
89
|
+
-- Policy: Admins have full access (example)
|
|
90
|
+
-- create policy "{{TABLE_NAME}}_admin_policy"
|
|
91
|
+
-- on public.{{TABLE_NAME}} for all
|
|
92
|
+
-- using (
|
|
93
|
+
-- exists (
|
|
94
|
+
-- select 1 from public.user_roles
|
|
95
|
+
-- where user_id = auth.uid() and role = 'admin'
|
|
96
|
+
-- )
|
|
97
|
+
-- );
|
|
98
|
+
|
|
99
|
+
-- ========================================
|
|
100
|
+
-- Seed Data (Optional)
|
|
101
|
+
-- ========================================
|
|
102
|
+
|
|
103
|
+
-- insert into public.{{TABLE_NAME}} (name, description) values
|
|
104
|
+
-- ('Example 1', 'First example record'),
|
|
105
|
+
-- ('Example 2', 'Second example record');
|
|
106
|
+
|
|
107
|
+
-- ========================================
|
|
108
|
+
-- Rollback Instructions
|
|
109
|
+
-- ========================================
|
|
110
|
+
|
|
111
|
+
-- Uncomment to rollback this migration:
|
|
112
|
+
-- drop table if exists public.{{TABLE_NAME}} cascade;
|
|
113
|
+
-- drop function if exists public.handle_updated_at() cascade;
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// CONTRACTS: {{titleCase FEATURE_NAME}}
|
|
3
|
+
// Stack: Next.js + Supabase
|
|
4
|
+
// Generated by MORPH Framework
|
|
5
|
+
// Date: {{DATE}}
|
|
6
|
+
// ============================================================
|
|
7
|
+
|
|
8
|
+
// ----- Supabase Config -----
|
|
9
|
+
|
|
10
|
+
export interface SupabaseConfig {
|
|
11
|
+
url: string;
|
|
12
|
+
anonKey: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// ----- API Client Types -----
|
|
16
|
+
|
|
17
|
+
export interface ApiClientConfig {
|
|
18
|
+
baseUrl: string;
|
|
19
|
+
getAccessToken: () => Promise<string | null>;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export interface ApiError {
|
|
23
|
+
message: string;
|
|
24
|
+
code: string;
|
|
25
|
+
statusCode: number;
|
|
26
|
+
details?: Record<string, string[]>;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export type ApiResult<T> =
|
|
30
|
+
| { success: true; data: T }
|
|
31
|
+
| { success: false; error: ApiError };
|
|
32
|
+
|
|
33
|
+
// ----- Pagination -----
|
|
34
|
+
|
|
35
|
+
export interface PaginationQuery {
|
|
36
|
+
page?: number;
|
|
37
|
+
pageSize?: number;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export interface PagedResult<T> {
|
|
41
|
+
items: T[];
|
|
42
|
+
totalCount: number;
|
|
43
|
+
page: number;
|
|
44
|
+
pageSize: number;
|
|
45
|
+
totalPages: number;
|
|
46
|
+
hasNext: boolean;
|
|
47
|
+
hasPrevious: boolean;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// ----- Supabase Client Type Aliases -----
|
|
51
|
+
// Generated by: supabase gen types typescript --project-id <id> > types/database.ts
|
|
52
|
+
|
|
53
|
+
export type Tables<T extends keyof Database["public"]["Tables"]> =
|
|
54
|
+
Database["public"]["Tables"][T]["Row"];
|
|
55
|
+
|
|
56
|
+
export type Insertable<T extends keyof Database["public"]["Tables"]> =
|
|
57
|
+
Database["public"]["Tables"][T]["Insert"];
|
|
58
|
+
|
|
59
|
+
export type Updatable<T extends keyof Database["public"]["Tables"]> =
|
|
60
|
+
Database["public"]["Tables"][T]["Update"];
|
|
61
|
+
|
|
62
|
+
// ----- Database Schema (placeholder - replace with generated types) -----
|
|
63
|
+
|
|
64
|
+
export interface Database {
|
|
65
|
+
public: {
|
|
66
|
+
Tables: {
|
|
67
|
+
{{FEATURE_NAME}}: {
|
|
68
|
+
Row: {
|
|
69
|
+
id: string;
|
|
70
|
+
name: string;
|
|
71
|
+
user_id: string;
|
|
72
|
+
status: {{pascalCase FEATURE_NAME}}Status;
|
|
73
|
+
created_at: string;
|
|
74
|
+
updated_at: string | null;
|
|
75
|
+
};
|
|
76
|
+
Insert: {
|
|
77
|
+
id?: string;
|
|
78
|
+
name: string;
|
|
79
|
+
user_id?: string;
|
|
80
|
+
status?: {{pascalCase FEATURE_NAME}}Status;
|
|
81
|
+
created_at?: string;
|
|
82
|
+
updated_at?: string | null;
|
|
83
|
+
};
|
|
84
|
+
Update: {
|
|
85
|
+
id?: string;
|
|
86
|
+
name?: string;
|
|
87
|
+
user_id?: string;
|
|
88
|
+
status?: {{pascalCase FEATURE_NAME}}Status;
|
|
89
|
+
created_at?: string;
|
|
90
|
+
updated_at?: string | null;
|
|
91
|
+
};
|
|
92
|
+
};
|
|
93
|
+
};
|
|
94
|
+
Views: Record<string, never>;
|
|
95
|
+
Functions: Record<string, never>;
|
|
96
|
+
Enums: {
|
|
97
|
+
{{FEATURE_NAME}}_status: {{pascalCase FEATURE_NAME}}Status;
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// ----- Feature Types -----
|
|
103
|
+
|
|
104
|
+
export type {{pascalCase FEATURE_NAME}}Status =
|
|
105
|
+
| "draft"
|
|
106
|
+
| "active"
|
|
107
|
+
| "completed"
|
|
108
|
+
| "archived"
|
|
109
|
+
| "failed"
|
|
110
|
+
| "cancelled";
|
|
111
|
+
|
|
112
|
+
export interface {{pascalCase FEATURE_NAME}} {
|
|
113
|
+
id: string;
|
|
114
|
+
name: string;
|
|
115
|
+
userId: string;
|
|
116
|
+
status: {{pascalCase FEATURE_NAME}}Status;
|
|
117
|
+
createdAt: string;
|
|
118
|
+
updatedAt: string | null;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
export interface Create{{pascalCase FEATURE_NAME}}Input {
|
|
122
|
+
name: string;
|
|
123
|
+
// Add other required fields
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
export interface Update{{pascalCase FEATURE_NAME}}Input {
|
|
127
|
+
name?: string;
|
|
128
|
+
// Add other updatable fields
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// ----- Storage Types -----
|
|
132
|
+
|
|
133
|
+
export interface StorageUpload {
|
|
134
|
+
bucket: string;
|
|
135
|
+
path: string;
|
|
136
|
+
file: File;
|
|
137
|
+
contentType?: string;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
export interface StorageFile {
|
|
141
|
+
id: string;
|
|
142
|
+
name: string;
|
|
143
|
+
bucket: string;
|
|
144
|
+
path: string;
|
|
145
|
+
publicUrl: string;
|
|
146
|
+
size: number;
|
|
147
|
+
contentType: string;
|
|
148
|
+
createdAt: string;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// ----- Auth Types -----
|
|
152
|
+
|
|
153
|
+
export interface AuthUser {
|
|
154
|
+
id: string;
|
|
155
|
+
email: string;
|
|
156
|
+
displayName: string | null;
|
|
157
|
+
avatarUrl: string | null;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
export interface AuthSession {
|
|
161
|
+
user: AuthUser;
|
|
162
|
+
accessToken: string;
|
|
163
|
+
expiresAt: number;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
// ----- Form Schemas (use with zod) -----
|
|
167
|
+
// Define zod schemas in component files, not here.
|
|
168
|
+
// This file is for type definitions only.
|