@polymorphism-tech/morph-spec 3.1.0 → 4.2.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.
Files changed (333) hide show
  1. package/CLAUDE.md +882 -3
  2. package/README.md +79 -18
  3. package/bin/detect-agents.js +1 -1
  4. package/bin/morph-spec.js +163 -26
  5. package/bin/task-manager.cjs +101 -7
  6. package/bin/validate.js +1 -1
  7. package/docs/cli-auto-detection.md +219 -0
  8. package/docs/getting-started.md +0 -5
  9. package/docs/llm-interaction-config.md +735 -0
  10. package/docs/troubleshooting.md +269 -0
  11. package/docs/v3.0/AGENTS.md +521 -0
  12. package/docs/v3.0/ANALYSIS.md +555 -0
  13. package/docs/v3.0/ARCHITECTURE.md +436 -0
  14. package/docs/v3.0/EXECUTION-FLOW.md +1304 -0
  15. package/docs/v3.0/FEATURES.md +688 -0
  16. package/docs/v3.0/README.md +231 -0
  17. package/docs/v3.0/ROADMAP.md +801 -0
  18. package/docs/validation-checklist.md +0 -1
  19. package/package.json +5 -1
  20. package/src/commands/agents/index.js +4 -0
  21. package/src/commands/agents/spawn-team.js +172 -0
  22. package/src/commands/{create-story.js → feature/create-story.js} +357 -354
  23. package/src/commands/feature/index.js +6 -0
  24. package/src/commands/{shard-spec.js → feature/shard-spec.js} +2 -2
  25. package/src/commands/{sprint-status.js → feature/sprint-status.js} +1 -1
  26. package/src/commands/{generate-context.js → generation/generate-context.js} +40 -40
  27. package/src/commands/{generate.js → generation/generate.js} +130 -3
  28. package/src/commands/generation/index.js +5 -0
  29. package/src/commands/index.js +16 -0
  30. package/src/commands/learning/capture-pattern.js +121 -0
  31. package/src/commands/learning/index.js +5 -0
  32. package/src/commands/learning/search-patterns.js +126 -0
  33. package/src/commands/{detect-agents.js → project/detect-agents.js} +178 -178
  34. package/src/commands/project/detect-workflow.js +174 -0
  35. package/src/commands/{detect.js → project/detect.js} +104 -104
  36. package/src/commands/{doctor.js → project/doctor.js} +356 -356
  37. package/src/commands/project/index.js +10 -0
  38. package/src/commands/{init.js → project/init.js} +305 -258
  39. package/src/commands/{sync.js → project/sync.js} +167 -167
  40. package/src/commands/{update.js → project/update.js} +240 -204
  41. package/src/commands/{advance-phase.js → state/advance-phase.js} +416 -266
  42. package/src/commands/state/approve.js +221 -0
  43. package/src/commands/state/index.js +8 -0
  44. package/src/commands/{rollback-phase.js → state/rollback-phase.js} +185 -185
  45. package/src/commands/{state.js → state/state.js} +334 -334
  46. package/src/commands/{validate-phase.js → state/validate-phase.js} +221 -221
  47. package/src/commands/tasks/index.js +4 -0
  48. package/src/commands/{task.js → tasks/task.js} +78 -78
  49. package/src/commands/templates/index.js +8 -0
  50. package/src/commands/templates/template-customize.js +101 -0
  51. package/src/commands/templates/template-list.js +128 -0
  52. package/src/commands/templates/template-render.js +95 -0
  53. package/src/commands/templates/template-show.js +131 -0
  54. package/src/commands/templates/template-validate.js +91 -0
  55. package/src/commands/utils/index.js +7 -0
  56. package/src/commands/utils/migrate-state.js +158 -0
  57. package/src/commands/{session-summary.js → utils/session-summary.js} +291 -291
  58. package/src/commands/{troubleshoot.js → utils/troubleshoot.js} +222 -222
  59. package/src/commands/utils/upgrade.js +346 -0
  60. package/src/commands/{analyze-blazor-concurrency.js → validation/analyze-blazor-concurrency.js} +193 -193
  61. package/src/commands/validation/index.js +8 -0
  62. package/src/commands/{lint-fluent.js → validation/lint-fluent.js} +352 -352
  63. package/src/commands/{validate-blazor-state.js → validation/validate-blazor-state.js} +210 -210
  64. package/src/commands/{validate-blazor.js → validation/validate-blazor.js} +156 -156
  65. package/src/commands/{validate-css.js → validation/validate-css.js} +84 -84
  66. package/src/core/index.js +10 -0
  67. package/src/core/registry/command-registry.js +302 -0
  68. package/src/core/registry/index.js +8 -0
  69. package/src/core/registry/validator-registry.js +204 -0
  70. package/src/core/state/index.js +8 -0
  71. package/src/core/state/phase-state-machine.js +214 -0
  72. package/src/{lib → core/state}/state-manager.js +572 -414
  73. package/src/core/templates/index.js +9 -0
  74. package/src/core/templates/template-data-sources.js +325 -0
  75. package/src/core/templates/template-registry.js +335 -0
  76. package/src/core/templates/template-renderer.js +477 -0
  77. package/src/core/templates/template-validator.js +296 -0
  78. package/src/core/workflows/index.js +7 -0
  79. package/src/core/workflows/workflow-detector.js +354 -0
  80. package/src/generator/config-generator.js +206 -0
  81. package/src/generator/templates/config.json.template +40 -0
  82. package/src/generator/templates/project.md.template +67 -0
  83. package/src/lib/{complexity-analyzer.js → analysis/complexity-analyzer.js} +441 -441
  84. package/src/lib/analysis/index.js +7 -0
  85. package/src/lib/checkpoints/checkpoint-hooks.js +258 -0
  86. package/src/lib/checkpoints/index.js +7 -0
  87. package/src/lib/detectors/config-detector.js +223 -223
  88. package/src/lib/detectors/conversation-analyzer.js +163 -163
  89. package/src/lib/{design-system-detector.js → detectors/design-system-detector.js} +187 -187
  90. package/src/lib/detectors/index.js +87 -84
  91. package/src/lib/detectors/standards-generator.js +275 -275
  92. package/src/lib/detectors/structure-detector.js +245 -245
  93. package/src/lib/{context-generator.js → generators/context-generator.js} +526 -516
  94. package/src/lib/generators/index.js +10 -0
  95. package/src/lib/generators/metadata-extractor.js +387 -0
  96. package/src/lib/{recap-generator.js → generators/recap-generator.js} +205 -205
  97. package/src/lib/learning/index.js +7 -0
  98. package/src/lib/orchestration/index.js +7 -0
  99. package/src/lib/{team-orchestrator.js → orchestration/team-orchestrator.js} +323 -323
  100. package/src/lib/stacks/index.js +7 -0
  101. package/src/lib/{stack-resolver.js → stacks/stack-resolver.js} +180 -148
  102. package/src/lib/standards/index.js +7 -0
  103. package/src/lib/{standards-context-injector.js → standards/standards-context-injector.js} +298 -288
  104. package/src/lib/troubleshooting/index.js +8 -0
  105. package/src/lib/{troubleshoot-grep.js → troubleshooting/troubleshoot-grep.js} +204 -204
  106. package/src/lib/{troubleshoot-index.js → troubleshooting/troubleshoot-index.js} +144 -144
  107. package/src/lib/validators/architecture/architecture-validator.js +387 -0
  108. package/src/lib/validators/architecture/index.js +7 -0
  109. package/src/lib/validators/architecture-validator.js +40 -367
  110. package/src/lib/{blazor-concurrency-analyzer.js → validators/blazor/blazor-concurrency-analyzer.js} +277 -288
  111. package/src/lib/{blazor-state-validator.js → validators/blazor/blazor-state-validator.js} +279 -291
  112. package/src/lib/{blazor-validator.js → validators/blazor/blazor-validator.js} +369 -374
  113. package/src/lib/validators/blazor/index.js +9 -0
  114. package/src/lib/validators/content/content-validator.js +351 -0
  115. package/src/lib/validators/content/index.js +7 -0
  116. package/src/lib/validators/content-validator.js +164 -0
  117. package/src/lib/validators/{contract-compliance-validator.js → contracts/contract-compliance-validator.js} +273 -273
  118. package/src/lib/validators/contracts/index.js +7 -0
  119. package/src/lib/{css-validator.js → validators/css/css-validator.js} +352 -352
  120. package/src/lib/validators/css/index.js +7 -0
  121. package/src/lib/validators/{design-system-validator.js → design-system/design-system-validator.js} +231 -231
  122. package/src/lib/validators/design-system/index.js +7 -0
  123. package/src/lib/validators/package-validator.js +41 -340
  124. package/src/lib/validators/packages/index.js +7 -0
  125. package/src/lib/validators/packages/package-validator.js +360 -0
  126. package/src/lib/validators/shared/index.js +12 -0
  127. package/src/lib/validators/shared/issue-counter.js +18 -0
  128. package/src/lib/validators/shared/result-formatter.js +124 -0
  129. package/src/lib/{spec-validator.js → validators/spec-validator.js} +258 -258
  130. package/src/lib/validators/ui/index.js +7 -0
  131. package/src/lib/validators/ui/ui-contrast-validator.js +422 -0
  132. package/src/lib/validators/ui-contrast-validator.js +31 -409
  133. package/src/lib/{validation-runner.js → validators/validation-runner.js} +286 -284
  134. package/src/llm/analyzer.js +215 -0
  135. package/src/llm/environment-detector.js +43 -0
  136. package/src/llm/few-shot-examples.js +216 -0
  137. package/src/llm/project-config-schema.json +188 -0
  138. package/src/llm/prompt-builder.js +96 -0
  139. package/src/orchestrator.js +206 -0
  140. package/src/sanitizer/context-sanitizer.js +221 -0
  141. package/src/sanitizer/patterns.js +163 -0
  142. package/src/scanner/project-scanner.js +242 -0
  143. package/src/ui/diff-display.js +91 -0
  144. package/src/ui/interactive-wizard.js +96 -0
  145. package/src/ui/user-review.js +211 -0
  146. package/src/ui/wizard-questions.js +188 -0
  147. package/src/utils/color-utils.js +70 -0
  148. package/src/utils/file-copier.js +188 -189
  149. package/src/utils/process-handler.js +97 -0
  150. package/src/writer/file-writer.js +86 -0
  151. package/stacks/blazor-azure/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +3 -3
  152. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/api-designer.md +59 -0
  153. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/dotnet-senior.md +45 -255
  154. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ef-modeler.md +33 -88
  155. package/stacks/blazor-azure/.claude/skills/level-2-domains/backend/ms-agent-expert.md +25 -89
  156. package/stacks/blazor-azure/.claude/skills/level-2-domains/integrations/hangfire-orchestrator.md +64 -0
  157. package/stacks/blazor-azure/.morph/config/agents.json +879 -764
  158. package/stacks/blazor-azure/.morph/hooks/{pre-commit-tests.sh → pre-commit/tests-csharp.sh} +3 -2
  159. package/stacks/blazor-azure/.morph/templates/.gitkeep +0 -0
  160. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +41 -0
  161. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +24 -0
  162. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +23 -0
  163. package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
  164. package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
  165. package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
  166. package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
  167. package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
  168. package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
  169. package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
  170. package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
  171. package/stacks/nextjs-supabase/.claude/settings.local.json +6 -0
  172. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +30 -150
  173. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
  174. package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +61 -0
  175. package/stacks/nextjs-supabase/.morph/templates/.gitkeep +0 -0
  176. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +22 -0
  177. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +22 -0
  178. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +35 -0
  179. package/stacks/nextjs-supabase/README.md +6 -15
  180. package/bin/render-template.js +0 -303
  181. package/bin/semantic-detect-agents.js +0 -247
  182. package/bin/validate-agents-skills.js +0 -257
  183. package/bin/validate-agents.js +0 -70
  184. package/bin/validate-phase.js +0 -263
  185. package/docs/examples.md +0 -328
  186. package/scripts/reorganize-skills.cjs +0 -175
  187. package/scripts/validate-agents-structure.cjs +0 -52
  188. package/scripts/validate-skills.cjs +0 -180
  189. package/src/commands/deploy.js +0 -780
  190. package/src/lib/continuous-validator.js +0 -421
  191. package/src/lib/decision-constraint-loader.js +0 -109
  192. package/src/lib/design-system-scaffolder.js +0 -299
  193. package/src/lib/hook-executor.js +0 -257
  194. package/src/lib/mockup-generator.js +0 -366
  195. package/src/lib/ui-detector.js +0 -350
  196. package/stacks/blazor-azure/.azure/README.md +0 -293
  197. package/stacks/blazor-azure/.azure/docs/azure-devops-setup.md +0 -454
  198. package/stacks/blazor-azure/.azure/docs/branch-strategy.md +0 -398
  199. package/stacks/blazor-azure/.azure/docs/local-development.md +0 -515
  200. package/stacks/blazor-azure/.azure/pipelines/pipeline-variables.yml +0 -34
  201. package/stacks/blazor-azure/.azure/pipelines/prod-pipeline.yml +0 -319
  202. package/stacks/blazor-azure/.azure/pipelines/staging-pipeline.yml +0 -234
  203. package/stacks/blazor-azure/.azure/pipelines/templates/build-dotnet.yml +0 -75
  204. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-app-service.yml +0 -94
  205. package/stacks/blazor-azure/.azure/pipelines/templates/deploy-container-app.yml +0 -120
  206. package/stacks/blazor-azure/.azure/pipelines/templates/infra-deploy.yml +0 -90
  207. package/stacks/blazor-azure/.claude/settings.local.json +0 -15
  208. package/stacks/blazor-azure/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +0 -392
  209. package/stacks/blazor-azure/.morph/docs/workflows/design-impl.md +0 -37
  210. package/stacks/blazor-azure/.morph/docs/workflows/enforcement-pipeline.md +0 -668
  211. package/stacks/blazor-azure/.morph/docs/workflows/fast-track.md +0 -29
  212. package/stacks/blazor-azure/.morph/docs/workflows/full-morph.md +0 -76
  213. package/stacks/blazor-azure/.morph/docs/workflows/standard.md +0 -44
  214. package/stacks/blazor-azure/.morph/docs/workflows/ui-refresh.md +0 -39
  215. package/stacks/blazor-azure/.morph/examples/api-nextjs/README.md +0 -241
  216. package/stacks/blazor-azure/.morph/examples/api-nextjs/contracts.ts +0 -307
  217. package/stacks/blazor-azure/.morph/examples/api-nextjs/spec.md +0 -399
  218. package/stacks/blazor-azure/.morph/examples/api-nextjs/tasks.md +0 -168
  219. package/stacks/blazor-azure/.morph/examples/micro-saas/README.md +0 -125
  220. package/stacks/blazor-azure/.morph/examples/micro-saas/contracts.cs +0 -358
  221. package/stacks/blazor-azure/.morph/examples/micro-saas/decisions.md +0 -246
  222. package/stacks/blazor-azure/.morph/examples/micro-saas/spec.md +0 -236
  223. package/stacks/blazor-azure/.morph/examples/micro-saas/tasks.md +0 -150
  224. package/stacks/blazor-azure/.morph/examples/multi-agent/README.md +0 -309
  225. package/stacks/blazor-azure/.morph/examples/multi-agent/contracts.cs +0 -433
  226. package/stacks/blazor-azure/.morph/examples/multi-agent/spec.md +0 -479
  227. package/stacks/blazor-azure/.morph/examples/multi-agent/tasks.md +0 -185
  228. package/stacks/blazor-azure/.morph/examples/scheduled-reports/decisions.md +0 -158
  229. package/stacks/blazor-azure/.morph/examples/scheduled-reports/proposal.md +0 -95
  230. package/stacks/blazor-azure/.morph/examples/scheduled-reports/spec.md +0 -267
  231. package/stacks/blazor-azure/.morph/examples/state-v3.json +0 -188
  232. package/stacks/blazor-azure/.morph/hooks/README.md +0 -348
  233. package/stacks/blazor-azure/.morph/hooks/pre-commit-agents.sh +0 -24
  234. package/stacks/blazor-azure/.morph/hooks/pre-commit-all.sh +0 -48
  235. package/stacks/blazor-azure/.morph/hooks/pre-commit-specs.sh +0 -49
  236. package/stacks/blazor-azure/.morph/hooks/task-completed.js +0 -73
  237. package/stacks/blazor-azure/.morph/hooks/teammate-idle.js +0 -68
  238. package/stacks/blazor-azure/.morph/standards/agent-framework-blazor-ui.md +0 -359
  239. package/stacks/blazor-azure/.morph/standards/agent-framework-production.md +0 -410
  240. package/stacks/blazor-azure/.morph/standards/agent-framework-setup.md +0 -413
  241. package/stacks/blazor-azure/.morph/standards/agent-framework-workflows.md +0 -349
  242. package/stacks/blazor-azure/.morph/standards/agent-teams-workflow.md +0 -474
  243. package/stacks/blazor-azure/.morph/standards/architecture.md +0 -325
  244. package/stacks/blazor-azure/.morph/standards/azure.md +0 -605
  245. package/stacks/blazor-azure/.morph/standards/coding.md +0 -377
  246. package/stacks/blazor-azure/.morph/standards/dotnet10-migration.md +0 -520
  247. package/stacks/blazor-azure/.morph/standards/fluent-ui-setup.md +0 -590
  248. package/stacks/blazor-azure/.morph/standards/migration-guide.md +0 -514
  249. package/stacks/blazor-azure/.morph/standards/passkeys-auth.md +0 -423
  250. package/stacks/blazor-azure/.morph/standards/vector-search-rag.md +0 -536
  251. package/stacks/blazor-azure/.morph/templates/CONTEXT-FEATURE.md +0 -276
  252. package/stacks/blazor-azure/.morph/templates/CONTEXT.md +0 -170
  253. package/stacks/blazor-azure/.morph/templates/FluentDesignTheme.cs +0 -149
  254. package/stacks/blazor-azure/.morph/templates/MudTheme.cs +0 -281
  255. package/stacks/blazor-azure/.morph/templates/agent.cs +0 -163
  256. package/stacks/blazor-azure/.morph/templates/clarify-questions.md +0 -159
  257. package/stacks/blazor-azure/.morph/templates/component.razor +0 -239
  258. package/stacks/blazor-azure/.morph/templates/contracts/Commands.cs +0 -74
  259. package/stacks/blazor-azure/.morph/templates/contracts/Entities.cs +0 -25
  260. package/stacks/blazor-azure/.morph/templates/contracts/Queries.cs +0 -74
  261. package/stacks/blazor-azure/.morph/templates/contracts/README.md +0 -74
  262. package/stacks/blazor-azure/.morph/templates/contracts.cs +0 -217
  263. package/stacks/blazor-azure/.morph/templates/decisions.md +0 -123
  264. package/stacks/blazor-azure/.morph/templates/design-system.css +0 -226
  265. package/stacks/blazor-azure/.morph/templates/infra/.dockerignore.example +0 -89
  266. package/stacks/blazor-azure/.morph/templates/infra/Dockerfile.example +0 -82
  267. package/stacks/blazor-azure/.morph/templates/infra/README.md +0 -286
  268. package/stacks/blazor-azure/.morph/templates/infra/app-insights.bicep +0 -63
  269. package/stacks/blazor-azure/.morph/templates/infra/app-service.bicep +0 -164
  270. package/stacks/blazor-azure/.morph/templates/infra/azure-pipelines-deploy.yml +0 -480
  271. package/stacks/blazor-azure/.morph/templates/infra/container-app-env.bicep +0 -49
  272. package/stacks/blazor-azure/.morph/templates/infra/container-app.bicep +0 -156
  273. package/stacks/blazor-azure/.morph/templates/infra/deploy-checklist.md +0 -426
  274. package/stacks/blazor-azure/.morph/templates/infra/deploy.ps1 +0 -229
  275. package/stacks/blazor-azure/.morph/templates/infra/deploy.sh +0 -208
  276. package/stacks/blazor-azure/.morph/templates/infra/key-vault.bicep +0 -91
  277. package/stacks/blazor-azure/.morph/templates/infra/main.bicep +0 -189
  278. package/stacks/blazor-azure/.morph/templates/infra/parameters.dev.json +0 -29
  279. package/stacks/blazor-azure/.morph/templates/infra/parameters.prod.json +0 -29
  280. package/stacks/blazor-azure/.morph/templates/infra/parameters.staging.json +0 -29
  281. package/stacks/blazor-azure/.morph/templates/infra/sql-database.bicep +0 -103
  282. package/stacks/blazor-azure/.morph/templates/infra/storage.bicep +0 -106
  283. package/stacks/blazor-azure/.morph/templates/integrations/asaas-client.cs +0 -387
  284. package/stacks/blazor-azure/.morph/templates/integrations/asaas-webhook.cs +0 -351
  285. package/stacks/blazor-azure/.morph/templates/integrations/azure-identity-config.cs +0 -288
  286. package/stacks/blazor-azure/.morph/templates/integrations/clerk-config.cs +0 -258
  287. package/stacks/blazor-azure/.morph/templates/job.cs +0 -171
  288. package/stacks/blazor-azure/.morph/templates/migration.cs +0 -83
  289. package/stacks/blazor-azure/.morph/templates/proposal.md +0 -141
  290. package/stacks/blazor-azure/.morph/templates/recap.md +0 -94
  291. package/stacks/blazor-azure/.morph/templates/repository.cs +0 -141
  292. package/stacks/blazor-azure/.morph/templates/saas/subscription.cs +0 -347
  293. package/stacks/blazor-azure/.morph/templates/saas/tenant.cs +0 -338
  294. package/stacks/blazor-azure/.morph/templates/service.cs +0 -139
  295. package/stacks/blazor-azure/.morph/templates/simulation.md +0 -353
  296. package/stacks/blazor-azure/.morph/templates/spec.md +0 -149
  297. package/stacks/blazor-azure/.morph/templates/sprint-status.yaml +0 -68
  298. package/stacks/blazor-azure/.morph/templates/state.template.json +0 -222
  299. package/stacks/blazor-azure/.morph/templates/story.md +0 -143
  300. package/stacks/blazor-azure/.morph/templates/tasks.md +0 -257
  301. package/stacks/blazor-azure/.morph/templates/test.cs +0 -239
  302. package/stacks/blazor-azure/.morph/templates/ui-components.md +0 -362
  303. package/stacks/blazor-azure/.morph/templates/ui-design-system.md +0 -286
  304. package/stacks/blazor-azure/.morph/templates/ui-flows.md +0 -336
  305. package/stacks/blazor-azure/.morph/templates/ui-mockups.md +0 -133
  306. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +0 -169
  307. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +0 -247
  308. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +0 -697
  309. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +0 -85
  310. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +0 -86
  311. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +0 -498
  312. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +0 -121
  313. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +0 -138
  314. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +0 -162
  315. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +0 -191
  316. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +0 -193
  317. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +0 -171
  318. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +0 -164
  319. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +0 -179
  320. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +0 -148
  321. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +0 -173
  322. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +0 -168
  323. package/stacks/nextjs-supabase/.morph/templates/decisions.md +0 -115
  324. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +0 -38
  325. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +0 -48
  326. package/stacks/nextjs-supabase/.morph/templates/proposal.md +0 -145
  327. package/stacks/nextjs-supabase/.morph/templates/recap.md +0 -134
  328. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +0 -57
  329. package/stacks/nextjs-supabase/.morph/templates/spec.md +0 -231
  330. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +0 -100
  331. package/stacks/nextjs-supabase/.morph/templates/tasks.md +0 -257
  332. /package/src/lib/{design-system-generator.js → generators/design-system-generator.js} +0 -0
  333. /package/src/lib/{learning-system.js → learning/learning-system.js} +0 -0
@@ -1,474 +0,0 @@
1
- # Agent Teams Workflow - Claude Code Integration
2
-
3
- **Status:** EXPERIMENTAL - Enable via `CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS=1`
4
-
5
- > Orchestrate multiple Claude Code instances as a coordinated team for parallel development workflows
6
-
7
- ---
8
-
9
- ## Overview
10
-
11
- **Agent Teams** are a Claude Code feature that coordinates multiple independent Claude instances working together on complex tasks. Unlike subagents (which run within a single context and only report back), Agent Teams members can communicate directly with each other, share findings, challenge each other's approaches, and coordinate through a shared task list.
12
-
13
- ### Core Architecture
14
-
15
- | Component | Role |
16
- |-----------|------|
17
- | **Team Lead** | Main Claude session that creates the team, spawns teammates, coordinates work |
18
- | **Teammates** | Independent Claude Code instances, each with own context window |
19
- | **Shared Task List** | Coordinated work items with dependencies and state (pending/in-progress/completed) |
20
- | **Mailbox** | Direct messaging system between agents |
21
-
22
- **Storage:**
23
- - Team config: `~/.claude/teams/{team-name}/config.json`
24
- - Task list: `~/.claude/tasks/{team-name}/`
25
-
26
- ---
27
-
28
- ## Agent Teams vs Subagents
29
-
30
- | Aspect | Subagents | Agent Teams |
31
- |--------|-----------|-------------|
32
- | **Context** | Own context, results return to caller | Fully independent contexts |
33
- | **Communication** | Report back to main agent only | Direct inter-teammate messaging + broadcast |
34
- | **Coordination** | Main agent manages all work | Shared task list with self-claiming |
35
- | **Best for** | Focused research, verification, isolated tasks | Complex work requiring discussion & collaboration |
36
- | **Token cost** | Lower (results summarized) | Higher (each teammate = separate Claude instance) |
37
- | **Use in MORPH** | Quick analysis, validation, isolated research | Parallel feature implementation, multi-module refactoring |
38
-
39
- ---
40
-
41
- ## When to Use Agent Teams in MORPH-SPEC
42
-
43
- ### ✅ **Strong Use Cases**
44
-
45
- 1. **Parallel Feature Implementation (FASE 5)**
46
- - Multiple independent features in the same release
47
- - Each teammate owns 1-2 modules (e.g., Auth, Payments, Reporting)
48
- - No file conflicts (each module has distinct files)
49
-
50
- 2. **Architecture Review & Debugging**
51
- - Multiple teammates investigate competing hypotheses
52
- - Each applies different lens (security, performance, maintainability)
53
- - Teams debate and converge on best solution
54
-
55
- 3. **Cross-Stack Coordination**
56
- - Frontend teammate (Blazor/Next.js)
57
- - Backend teammate (API + EF Core)
58
- - Infrastructure teammate (Bicep + Azure)
59
- - Testing teammate (unit + integration)
60
-
61
- 4. **Research & Standards Validation (FASE 0-2)**
62
- - Investigate multiple integration options (Clerk vs Azure AD vs custom)
63
- - Compare UI libraries (Fluent UI vs MudBlazor vs Radzen)
64
- - Validate architecture patterns (CQRS vs simple Repository)
65
-
66
- ### ❌ **Not Recommended**
67
-
68
- - Single-file edits or small bug fixes
69
- - Sequential tasks with many dependencies
70
- - Same-file modifications by multiple teammates (causes conflicts)
71
- - Routine tasks where coordination overhead > benefit
72
-
73
- ---
74
-
75
- ## Setup & Configuration
76
-
77
- ### 1. Enable Agent Teams
78
-
79
- Add to `.claude/settings.local.json` (or env variable):
80
-
81
- ```json
82
- {
83
- "env": {
84
- "CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS": "1"
85
- },
86
- "teammateMode": "auto" // or "in-process" / "tmux"
87
- }
88
- ```
89
-
90
- **Display Modes:**
91
- - `"auto"`: Split panes if in tmux, otherwise in-process
92
- - `"in-process"`: All teammates in main terminal (Shift+Up/Down to switch)
93
- - `"tmux"`: Each teammate in separate pane (requires tmux or iTerm2)
94
-
95
- ### 2. Start a Team
96
-
97
- **Natural Language Request:**
98
- ```
99
- Create an agent team to implement the scheduled-reports feature.
100
- Spawn 3 teammates:
101
- - Backend engineer: EF Core models + Hangfire jobs (uses ef-modeler, hangfire-orchestrator skills)
102
- - Frontend engineer: Blazor dashboard + report viewer (uses blazor-builder, ui-ux-designer skills)
103
- - Testing specialist: Unit + integration tests (uses testing-specialist skill)
104
-
105
- Require plan approval for each teammate before implementation.
106
- ```
107
-
108
- **What Claude Does:**
109
- 1. Creates team config in `~/.claude/teams/scheduled-reports/`
110
- 2. Spawns 3 independent Claude instances
111
- 3. Each teammate loads project context (CLAUDE.md, MCP servers, skills)
112
- 4. Lead assigns initial tasks from shared task list
113
- 5. Teammates work in plan mode until lead approves
114
- 6. After approval, teammates implement independently
115
-
116
- ### 3. Control the Team
117
-
118
- **Delegate Mode** (Lead focuses on coordination only):
119
- ```
120
- Press Shift+Tab to cycle into delegate mode
121
- ```
122
- - Lead can't use code tools (Edit/Write/Bash)
123
- - Only coordination tools: spawn, message, task management
124
-
125
- **Direct Teammate Communication:**
126
- - In-process mode: Shift+Up/Down to select, type to message
127
- - Split-pane mode: Click teammate pane to interact directly
128
-
129
- **Task Management:**
130
- ```
131
- # Lead assigns task
132
- Assign task T003 (implement report scheduler) to the backend engineer
133
-
134
- # Teammate self-claims next available task
135
- After completing T001, backend engineer claims T004 (add report repository)
136
- ```
137
-
138
- **Shutdown:**
139
- ```
140
- Ask the backend teammate to shut down gracefully
141
- ```
142
-
143
- ---
144
-
145
- ## MORPH-SPEC Integration Patterns
146
-
147
- ### Pattern 1: Parallel Feature Implementation (FASE 5)
148
-
149
- **Scenario:** Multi-module feature with independent components
150
-
151
- ```bash
152
- # 1. Complete FASES 0-4 normally (proposal → design → tasks)
153
- morph-spec state set scheduled-reports phase implement
154
-
155
- # 2. Claude creates agent team based on tasks.json structure
156
- # Example tasks.json with module grouping:
157
- {
158
- "tasks": [
159
- { "id": "T001", "module": "backend", "title": "Create ReportDefinition entity" },
160
- { "id": "T002", "module": "backend", "title": "Implement Hangfire scheduler" },
161
- { "id": "T003", "module": "frontend", "title": "Create report dashboard UI" },
162
- { "id": "T004", "module": "frontend", "title": "Add report preview component" },
163
- { "id": "T005", "module": "infra", "title": "Provision Blob Storage for reports" },
164
- { "id": "T006", "module": "tests", "title": "Unit tests for scheduler", "dependsOn": ["T002"] }
165
- ]
166
- }
167
- ```
168
-
169
- **Team Structure:**
170
- - **Lead:** Standards Architect (coordinates, validates contracts, syncs decisions.md)
171
- - **Backend Teammate:** .NET Senior + Hangfire Orchestrator + EF Modeler
172
- - **Frontend Teammate:** Blazor Builder + UI/UX Designer
173
- - **Infra Teammate:** Azure Architect + Bicep Architect
174
- - **Testing Teammate:** Testing Specialist
175
-
176
- **Workflow:**
177
- 1. Lead assigns tasks by module
178
- 2. Each teammate implements their tasks independently
179
- 3. Teammates run `morph-spec task done {feature} {task-id}` after each task
180
- 4. Validation pipeline runs automatically (contract compliance, decisions constraints)
181
- 5. Lead synthesizes recap.md after all tasks complete
182
-
183
- ### Pattern 2: Architecture Decision Debate (FASE 2)
184
-
185
- **Scenario:** Multiple valid approaches for complex problem
186
-
187
- ```
188
- Create an agent team to decide on the authentication architecture.
189
- Spawn 3 debate teammates:
190
- - Pro-Clerk: Argue for Clerk.com (ease of use, modern UI, MFA built-in)
191
- - Pro-Azure AD: Argue for Azure AD B2C (enterprise compliance, existing infra)
192
- - Pro-Custom: Argue for custom JWT + Passkeys (full control, no vendor lock-in)
193
-
194
- Have them debate, challenge each other's assumptions, and document pros/cons.
195
- Update decisions.md with consensus.
196
- ```
197
-
198
- **Output:** Structured ADR in `decisions.md` with all perspectives considered
199
-
200
- ### Pattern 3: Code Review by Concern (Post-FASE 5)
201
-
202
- **Scenario:** Thorough review before production deployment
203
-
204
- ```
205
- Create an agent team to review the scheduled-reports implementation.
206
- Spawn 4 reviewers:
207
- - Security reviewer: Auth, SQL injection, XSS, secrets management
208
- - Performance reviewer: Query efficiency, caching, background job overhead
209
- - Standards reviewer: Blazor patterns, EF Core best practices, contract compliance
210
- - UX reviewer: Accessibility, responsive design, error handling
211
-
212
- Each reviewer reports findings to the lead, then synthesize into review.md
213
- ```
214
-
215
- ---
216
-
217
- ## Best Practices for MORPH-SPEC
218
-
219
- ### 1. Size Tasks Appropriately
220
-
221
- **Good task granularity (5-6 tasks per teammate):**
222
- ```json
223
- {
224
- "id": "T003",
225
- "title": "Implement report scheduling service",
226
- "module": "backend",
227
- "files": ["Services/ReportScheduler.cs", "Jobs/GenerateReportJob.cs"],
228
- "estimatedHours": 2
229
- }
230
- ```
231
-
232
- **Too small (coordination overhead > benefit):**
233
- ```json
234
- { "id": "T001", "title": "Add using statement" }
235
- ```
236
-
237
- **Too large (teammate works too long without check-ins):**
238
- ```json
239
- { "id": "T099", "title": "Implement entire authentication system" }
240
- ```
241
-
242
- ### 2. Prevent File Conflicts
243
-
244
- **Design task ownership to avoid overlapping edits:**
245
-
246
- ❌ **Bad (conflict risk):**
247
- - Backend teammate modifies `Program.cs` for DI
248
- - Frontend teammate modifies `Program.cs` for middleware
249
-
250
- ✅ **Good (isolated ownership):**
251
- - Backend teammate: `Services/`, `Data/`, `Jobs/`
252
- - Frontend teammate: `Pages/`, `Components/`, `wwwroot/`
253
- - Lead handles shared files (`Program.cs`, `appsettings.json`) after review
254
-
255
- ### 3. Leverage Shared Context
256
-
257
- **All teammates automatically load:**
258
- - `CLAUDE.md` (MORPH-SPEC instructions)
259
- - `.claude/skills/` (all available skills)
260
- - `.morph/config.json` (project configuration)
261
- - `framework/standards/` + `.morph/standards/`
262
-
263
- **Pass task-specific context in spawn prompt:**
264
- ```
265
- Spawn backend teammate with prompt: "Implement scheduled reports feature.
266
- Active agents: ef-modeler, hangfire-orchestrator, dotnet-senior.
267
- Read .morph/project/outputs/scheduled-reports/spec.md and contracts.cs.
268
- Follow Blazor concurrency patterns from framework/standards/blazor-state.md.
269
- All background jobs MUST use IDbContextFactory (scoped repository pattern)."
270
- ```
271
-
272
- ### 4. Use Hooks for Quality Gates
273
-
274
- **Enforce validation before task completion:**
275
-
276
- ```json
277
- // .claude/hooks.json
278
- {
279
- "TaskCompleted": {
280
- "command": "morph-spec validate-task ${MORPH_FEATURE} ${TASK_ID}",
281
- "exitCode2Feedback": "Task validation failed. Fix violations before marking complete."
282
- },
283
- "TeammateIdle": {
284
- "command": "morph-spec check-teammate-progress ${TEAMMATE_ID}",
285
- "exitCode2Feedback": "Teammate has incomplete work. Continue implementation."
286
- }
287
- }
288
- ```
289
-
290
- ### 5. Monitor Token Usage
291
-
292
- **Agent Teams = High Token Cost:**
293
- - Each teammate = separate Claude instance with full context
294
- - 4 teammates on a 2-hour task ≈ 4x token usage vs single session
295
-
296
- **When worth it:**
297
- - Parallel implementation of 3+ independent modules
298
- - Complex architecture decisions requiring debate
299
- - Time-sensitive features where parallel work reduces calendar time
300
-
301
- **When NOT worth it:**
302
- - Single-module features
303
- - Sequential refactoring
304
- - Simple bug fixes
305
-
306
- ---
307
-
308
- ## Troubleshooting
309
-
310
- ### Issue: Lead Implements Instead of Delegating
311
-
312
- **Symptom:** Lead starts coding tasks instead of waiting for teammates
313
-
314
- **Solution:**
315
- ```
316
- Wait for your teammates to complete their tasks before proceeding.
317
- Use delegate mode to restrict yourself to coordination only.
318
- ```
319
- Then press `Shift+Tab` to cycle into delegate mode.
320
-
321
- ### Issue: Task Not Marked Complete
322
-
323
- **Symptom:** Teammate finished work but task still shows "in_progress"
324
-
325
- **Solution:**
326
- ```
327
- # Check if validation passed
328
- morph-spec state get {feature}
329
-
330
- # If validation failed, teammate must fix violations
331
- Tell the frontend teammate to check validation output and fix contract violations
332
-
333
- # If validation passed but task stuck, manually mark complete
334
- morph-spec task done {feature} {task-id}
335
- ```
336
-
337
- ### Issue: Orphaned tmux Sessions
338
-
339
- **Symptom:** `tmux ls` shows team sessions after cleanup
340
-
341
- **Solution:**
342
- ```bash
343
- tmux kill-session -t scheduled-reports-team
344
- rm -rf ~/.claude/teams/scheduled-reports
345
- ```
346
-
347
- ### Issue: Permission Prompts Spam
348
-
349
- **Symptom:** Too many permission requests for teammates
350
-
351
- **Solution:** Pre-approve common operations in `settings.local.json`:
352
- ```json
353
- {
354
- "dangerouslySkipPermissions": {
355
- "allowedPaths": [".morph/project/outputs/**"],
356
- "allowedCommands": ["morph-spec task done", "morph-spec validate-*"]
357
- }
358
- }
359
- ```
360
-
361
- ---
362
-
363
- ## Integration with MORPH Workflows
364
-
365
- ### Full MORPH (9 phases) + Agent Teams
366
-
367
- | Phase | Team Usage |
368
- |-------|------------|
369
- | **0 PROPOSAL** | Single session (detect-agents) |
370
- | **1 SETUP** | Single session |
371
- | **1.5 UI/UX** | Optional: Spawn UI/UX designer teammate for mockup generation |
372
- | **2 DESIGN** | Optional: Spawn debate team for DECISION POINTS |
373
- | **3 CLARIFY** | Single session |
374
- | **4 TASKS** | Single session (generate tasks.json) |
375
- | **5 IMPLEMENT** | **Primary use case:** Spawn implementation team by module |
376
- | **6 SYNC** | Single session (lead synthesizes decisions.md → standards/) |
377
-
378
- ### Fast Track + Agent Teams
379
-
380
- **Not recommended:** Coordination overhead defeats purpose of fast workflow.
381
-
382
- **Exception:** If fast-track task expands during implementation:
383
- ```
384
- morph-spec state set {feature} workflow full-morph
385
- # Then create agent team for expanded scope
386
- ```
387
-
388
- ---
389
-
390
- ## Limitations (as of 2026-02-12)
391
-
392
- - **No session resumption:** `/resume` doesn't restore in-process teammates
393
- - **Task status can lag:** Manual nudge may be needed
394
- - **One team per session:** Clean up before starting new team
395
- - **No nested teams:** Teammates can't spawn their own teams
396
- - **Split panes require tmux/iTerm2:** Not available in VS Code terminal, Windows Terminal, Ghostty
397
-
398
- ---
399
-
400
- ## Example: Full MORPH Workflow with Agent Team
401
-
402
- ```bash
403
- # FASES 0-4: Single Claude session
404
- /morph-proposal scheduled-reports
405
- # ... proposal approved, design approved, tasks generated ...
406
-
407
- # FASE 5: Create agent team
408
- morph-spec state set scheduled-reports phase implement
409
- ```
410
-
411
- ```
412
- Create an agent team to implement scheduled-reports.
413
-
414
- Team structure based on tasks.json modules:
415
- - Backend teammate (T001-T005): EF models, Hangfire jobs, repositories
416
- - Frontend teammate (T006-T010): Blazor pages, components, CSS
417
- - Infra teammate (T011-T012): Bicep modules for Blob Storage + Service Bus
418
-
419
- Require plan approval for each teammate.
420
- Use delegate mode so I only coordinate.
421
- ```
422
-
423
- **Claude creates team, spawns 3 teammates, each works independently:**
424
-
425
- ```bash
426
- # Backend teammate
427
- morph-spec task start scheduled-reports T001
428
- # ... implements ReportDefinition.cs ...
429
- morph-spec task done scheduled-reports T001
430
- # Validation runs: contract-compliance, blazor-concurrency (IDbContextFactory check)
431
- # ✅ Task T001 completed
432
-
433
- # Frontend teammate (parallel)
434
- morph-spec task start scheduled-reports T006
435
- # ... implements ReportDashboard.razor ...
436
- morph-spec task done scheduled-reports T006
437
- # Validation runs: blazor-validator, css-validator, contrast-checker
438
- # ✅ Task T006 completed
439
- ```
440
-
441
- **After all tasks complete, lead synthesizes:**
442
- ```bash
443
- morph-spec generate recap scheduled-reports
444
- # Pulls data from state.json, validation results, contracts.cs
445
- # Generates comprehensive recap.md
446
-
447
- morph-spec phase advance scheduled-reports
448
- # Validates FASE 5 → advances to FASE 6 → shows next steps
449
- ```
450
-
451
- ---
452
-
453
- ## Summary
454
-
455
- **Agent Teams enable MORPH-SPEC to:**
456
- - Implement multi-module features in parallel (reduces calendar time)
457
- - Debate architecture decisions with multiple perspectives
458
- - Conduct thorough reviews across security/performance/standards
459
-
460
- **Use when:**
461
- - 3+ independent modules/components
462
- - Complex architecture decisions
463
- - Cross-stack coordination (backend + frontend + infra)
464
-
465
- **Avoid when:**
466
- - Single-module features
467
- - Sequential workflows
468
- - Same-file modifications needed
469
-
470
- **Key insight:** Agent Teams amplify MORPH-SPEC's strengths (structured workflows, spec-driven development, validation pipeline) by parallelizing implementation while maintaining quality gates and coordination.
471
-
472
- ---
473
-
474
- *MORPH-SPEC by Polymorphism Tech - Integrated with Claude Code Agent Teams*