@polymorphism-tech/morph-spec 3.0.1 → 3.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 (316) hide show
  1. package/CLAUDE.md +561 -63
  2. package/LICENSE +72 -72
  3. package/README.md +275 -79
  4. package/bin/detect-agents.js +3 -1
  5. package/bin/morph-spec.js +60 -1
  6. package/bin/render-template.js +61 -14
  7. package/bin/semantic-detect-agents.js +2 -1
  8. package/bin/{task-manager.js → task-manager.cjs} +113 -8
  9. package/bin/validate-agents-skills.js +10 -4
  10. package/bin/validate-agents.js +4 -3
  11. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-light-webfont.svg +977 -977
  12. package/docs/api/fonts/Source-Sans-Pro/sourcesanspro-regular-webfont.svg +1048 -1048
  13. package/docs/api/scripts/collapse.js +38 -38
  14. package/docs/api/scripts/commonNav.js +28 -28
  15. package/docs/api/scripts/linenumber.js +25 -25
  16. package/docs/api/scripts/nav.js +12 -12
  17. package/docs/api/scripts/polyfill.js +3 -3
  18. package/docs/api/scripts/prettify/Apache-License-2.0.txt +202 -202
  19. package/docs/api/scripts/prettify/lang-css.js +2 -2
  20. package/docs/api/scripts/prettify/prettify.js +28 -28
  21. package/docs/api/scripts/search.js +98 -98
  22. package/docs/api/styles/jsdoc.css +776 -776
  23. package/docs/api/styles/prettify.css +80 -80
  24. package/docs/cli-auto-detection.md +219 -0
  25. package/docs/examples.md +328 -328
  26. package/docs/getting-started.md +3 -3
  27. package/docs/llm-interaction-config.md +735 -0
  28. package/docs/templates.md +418 -418
  29. package/docs/troubleshooting.md +269 -0
  30. package/package.json +7 -3
  31. package/scripts/postinstall.js +132 -132
  32. package/scripts/reorganize-skills.cjs +1 -1
  33. package/scripts/validate-agents-structure.cjs +1 -1
  34. package/scripts/validate-skills.cjs +2 -2
  35. package/src/commands/advance-phase.js +93 -2
  36. package/src/commands/analyze-blazor-concurrency.js +193 -193
  37. package/src/commands/approve.js +221 -0
  38. package/src/commands/capture-pattern.js +121 -0
  39. package/src/commands/create-story.js +5 -2
  40. package/src/commands/deploy.js +780 -780
  41. package/src/commands/detect-agents.js +4 -2
  42. package/src/commands/generate.js +276 -149
  43. package/src/commands/init.js +37 -0
  44. package/src/commands/lint-fluent.js +352 -352
  45. package/src/commands/migrate-state.js +158 -0
  46. package/src/commands/rollback-phase.js +185 -185
  47. package/src/commands/search-patterns.js +126 -0
  48. package/src/commands/session-summary.js +291 -291
  49. package/src/commands/shard-spec.js +224 -224
  50. package/src/commands/spawn-team.js +172 -0
  51. package/src/commands/sprint-status.js +250 -250
  52. package/src/commands/task.js +3 -3
  53. package/src/commands/troubleshoot.js +222 -222
  54. package/src/commands/update.js +36 -0
  55. package/src/commands/upgrade.js +346 -0
  56. package/src/commands/validate-blazor-state.js +210 -210
  57. package/src/commands/validate-blazor.js +156 -156
  58. package/src/commands/validate-css.js +84 -84
  59. package/src/commands/validate-phase.js +221 -221
  60. package/src/generator/.gitkeep +0 -0
  61. package/src/generator/config-generator.js +206 -0
  62. package/src/generator/templates/config.json.template +40 -0
  63. package/src/generator/templates/project.md.template +67 -0
  64. package/src/lib/blazor-concurrency-analyzer.js +288 -288
  65. package/src/lib/blazor-state-validator.js +291 -291
  66. package/src/lib/blazor-validator.js +374 -374
  67. package/src/lib/checkpoint-hooks.js +258 -0
  68. package/src/lib/context-generator.js +7 -4
  69. package/src/lib/css-validator.js +352 -352
  70. package/src/lib/design-system-generator.js +298 -298
  71. package/src/lib/hook-executor.js +2 -1
  72. package/src/lib/learning-system.js +520 -520
  73. package/src/lib/metadata-extractor.js +380 -0
  74. package/src/lib/mockup-generator.js +366 -366
  75. package/src/lib/phase-state-machine.js +214 -0
  76. package/src/lib/stack-resolver.js +148 -0
  77. package/src/lib/standards-context-injector.js +4 -3
  78. package/src/lib/state-manager.js +120 -0
  79. package/src/lib/team-orchestrator.js +2 -1
  80. package/src/lib/template-data-sources.js +325 -0
  81. package/src/lib/troubleshoot-grep.js +204 -194
  82. package/src/lib/troubleshoot-index.js +144 -144
  83. package/src/lib/ui-detector.js +350 -350
  84. package/src/lib/validation-runner.js +2 -1
  85. package/src/lib/validators/architecture-validator.js +387 -387
  86. package/src/lib/validators/content-validator.js +351 -0
  87. package/src/lib/validators/package-validator.js +360 -360
  88. package/src/lib/validators/ui-contrast-validator.js +422 -422
  89. package/src/llm/.gitkeep +0 -0
  90. package/src/llm/analyzer.js +215 -0
  91. package/src/llm/environment-detector.js +43 -0
  92. package/src/llm/few-shot-examples.js +216 -0
  93. package/src/llm/project-config-schema.json +188 -0
  94. package/src/llm/prompt-builder.js +96 -0
  95. package/src/llm/schema-validator.js +121 -0
  96. package/src/orchestrator.js +206 -0
  97. package/src/sanitizer/.gitkeep +0 -0
  98. package/src/sanitizer/context-sanitizer.js +221 -0
  99. package/src/sanitizer/patterns.js +163 -0
  100. package/src/scanner/.gitkeep +0 -0
  101. package/src/scanner/project-scanner.js +242 -0
  102. package/src/types/index.js +477 -0
  103. package/src/ui/.gitkeep +0 -0
  104. package/src/ui/diff-display.js +91 -0
  105. package/src/ui/interactive-wizard.js +96 -0
  106. package/src/ui/user-review.js +211 -0
  107. package/src/ui/wizard-questions.js +190 -0
  108. package/src/utils/file-copier.js +3 -1
  109. package/src/utils/logger.js +32 -32
  110. package/src/utils/version-checker.js +175 -175
  111. package/src/writer/.gitkeep +0 -0
  112. package/src/writer/file-writer.js +86 -0
  113. package/{content → stacks/blazor-azure}/.azure/README.md +2 -2
  114. package/{content → stacks/blazor-azure}/.azure/pipelines/pipeline-variables.yml +1 -1
  115. package/{content → stacks/blazor-azure}/.azure/pipelines/prod-pipeline.yml +1 -1
  116. package/{content → stacks/blazor-azure}/.azure/pipelines/staging-pipeline.yml +1 -1
  117. package/{content → stacks/blazor-azure}/.claude/commands/morph-preflight.md +227 -227
  118. package/{content → stacks/blazor-azure}/.claude/commands/morph-troubleshoot.md +122 -122
  119. package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-setup.md +1 -1
  120. package/{content → stacks/blazor-azure}/.morph/docs/workflows/enforcement-pipeline.md +3 -3
  121. package/{content → stacks/blazor-azure}/.morph/hooks/README.md +12 -12
  122. package/{content → stacks/blazor-azure}/.morph/standards/agent-teams-workflow.md +2 -2
  123. package/{content → stacks/blazor-azure}/.morph/standards/migration-guide.md +2 -2
  124. package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy-checklist.md +426 -426
  125. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/backend/dotnet-supabase.md +244 -0
  126. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/frontend/nextjs-supabase.md +335 -0
  127. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/infrastructure/easypanel-deployer.md +189 -0
  128. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +170 -0
  129. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -0
  130. package/stacks/nextjs-supabase/.morph/config/config.template.json +92 -0
  131. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +169 -0
  132. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +247 -0
  133. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +697 -0
  134. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +85 -0
  135. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +86 -0
  136. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +498 -0
  137. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +121 -0
  138. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +138 -0
  139. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +162 -0
  140. package/stacks/nextjs-supabase/.morph/project.md +168 -0
  141. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +191 -0
  142. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +193 -0
  143. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +171 -0
  144. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +164 -0
  145. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +179 -0
  146. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +148 -0
  147. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +173 -0
  148. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +168 -0
  149. package/stacks/nextjs-supabase/.morph/templates/decisions.md +115 -0
  150. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +38 -0
  151. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +48 -0
  152. package/stacks/nextjs-supabase/.morph/templates/proposal.md +145 -0
  153. package/stacks/nextjs-supabase/.morph/templates/recap.md +134 -0
  154. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +57 -0
  155. package/stacks/nextjs-supabase/.morph/templates/spec.md +231 -0
  156. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +100 -0
  157. package/stacks/nextjs-supabase/.morph/templates/tasks.md +257 -0
  158. package/stacks/nextjs-supabase/CLAUDE.md +149 -0
  159. package/stacks/nextjs-supabase/README.md +112 -0
  160. /package/{content → stacks/blazor-azure}/.azure/docs/azure-devops-setup.md +0 -0
  161. /package/{content → stacks/blazor-azure}/.azure/docs/branch-strategy.md +0 -0
  162. /package/{content → stacks/blazor-azure}/.azure/docs/local-development.md +0 -0
  163. /package/{content → stacks/blazor-azure}/.azure/pipelines/templates/build-dotnet.yml +0 -0
  164. /package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-app-service.yml +0 -0
  165. /package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-container-app.yml +0 -0
  166. /package/{content → stacks/blazor-azure}/.azure/pipelines/templates/infra-deploy.yml +0 -0
  167. /package/{content → stacks/blazor-azure}/.claude/commands/morph-apply.md +0 -0
  168. /package/{content → stacks/blazor-azure}/.claude/commands/morph-archive.md +0 -0
  169. /package/{content → stacks/blazor-azure}/.claude/commands/morph-deploy.md +0 -0
  170. /package/{content → stacks/blazor-azure}/.claude/commands/morph-infra.md +0 -0
  171. /package/{content → stacks/blazor-azure}/.claude/commands/morph-proposal.md +0 -0
  172. /package/{content → stacks/blazor-azure}/.claude/commands/morph-status.md +0 -0
  173. /package/{content → stacks/blazor-azure}/.claude/settings.local.json +0 -0
  174. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/README.md +0 -0
  175. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/code-review.md +0 -0
  176. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/morph-checklist.md +0 -0
  177. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/simulation-checklist.md +0 -0
  178. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/README.md +0 -0
  179. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/morph-replicate.md +0 -0
  180. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-clarify.md +0 -0
  181. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-design.md +0 -0
  182. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-tasks.md +0 -0
  183. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-uiux.md +0 -0
  184. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/README.md +0 -0
  185. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +0 -0
  186. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/po-pm-advisor.md +0 -0
  187. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/prompt-engineer.md +0 -0
  188. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/seo-growth-hacker.md +0 -0
  189. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/standards-architect.md +0 -0
  190. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/dotnet-senior.md +0 -0
  191. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ef-modeler.md +0 -0
  192. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/hangfire-orchestrator.md +0 -0
  193. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ms-agent-expert.md +0 -0
  194. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/blazor-builder.md +0 -0
  195. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/nextjs-expert.md +0 -0
  196. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/ui-ux-designer.md +0 -0
  197. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/azure-architect.md +0 -0
  198. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/azure-deploy-specialist.md +0 -0
  199. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/bicep-architect.md +0 -0
  200. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/container-specialist.md +0 -0
  201. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/devops-engineer.md +0 -0
  202. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/asaas-financial.md +0 -0
  203. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/azure-identity.md +0 -0
  204. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/clerk-auth.md +0 -0
  205. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/resend-email.md +0 -0
  206. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/code-analyzer.md +0 -0
  207. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/testing-specialist.md +0 -0
  208. /package/{content → stacks/blazor-azure}/.claude/skills/level-3-technologies/README.md +0 -0
  209. /package/{content → stacks/blazor-azure}/.claude/skills/level-4-patterns/README.md +0 -0
  210. /package/{content → stacks/blazor-azure}/.morph/.morphversion +0 -0
  211. /package/{content → stacks/blazor-azure}/.morph/archive/.gitkeep +0 -0
  212. /package/{content → stacks/blazor-azure}/.morph/config/agents.json +0 -0
  213. /package/{content → stacks/blazor-azure}/.morph/config/config.template.json +0 -0
  214. /package/{content → stacks/blazor-azure}/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +0 -0
  215. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/design-impl.md +0 -0
  216. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/fast-track.md +0 -0
  217. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/full-morph.md +0 -0
  218. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/standard.md +0 -0
  219. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/ui-refresh.md +0 -0
  220. /package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/README.md +0 -0
  221. /package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/contracts.ts +0 -0
  222. /package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/spec.md +0 -0
  223. /package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/tasks.md +0 -0
  224. /package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/README.md +0 -0
  225. /package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/contracts.cs +0 -0
  226. /package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/decisions.md +0 -0
  227. /package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/spec.md +0 -0
  228. /package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/tasks.md +0 -0
  229. /package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/README.md +0 -0
  230. /package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/contracts.cs +0 -0
  231. /package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/spec.md +0 -0
  232. /package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/tasks.md +0 -0
  233. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/decisions.md +0 -0
  234. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/proposal.md +0 -0
  235. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/spec.md +0 -0
  236. /package/{content → stacks/blazor-azure}/.morph/examples/state-v3.json +0 -0
  237. /package/{content → stacks/blazor-azure}/.morph/features/.gitkeep +0 -0
  238. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-agents.sh +0 -0
  239. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-all.sh +0 -0
  240. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-specs.sh +0 -0
  241. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-tests.sh +0 -0
  242. /package/{content → stacks/blazor-azure}/.morph/hooks/task-completed.js +0 -0
  243. /package/{content → stacks/blazor-azure}/.morph/hooks/teammate-idle.js +0 -0
  244. /package/{content → stacks/blazor-azure}/.morph/project.md +0 -0
  245. /package/{content → stacks/blazor-azure}/.morph/schemas/agent.schema.json +0 -0
  246. /package/{content → stacks/blazor-azure}/.morph/schemas/tasks.schema.json +0 -0
  247. /package/{content → stacks/blazor-azure}/.morph/specs/.gitkeep +0 -0
  248. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-blazor-ui.md +0 -0
  249. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-production.md +0 -0
  250. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-setup.md +0 -0
  251. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-workflows.md +0 -0
  252. /package/{content → stacks/blazor-azure}/.morph/standards/architecture.md +0 -0
  253. /package/{content → stacks/blazor-azure}/.morph/standards/azure.md +0 -0
  254. /package/{content → stacks/blazor-azure}/.morph/standards/coding.md +0 -0
  255. /package/{content → stacks/blazor-azure}/.morph/standards/dotnet10-migration.md +0 -0
  256. /package/{content → stacks/blazor-azure}/.morph/standards/fluent-ui-setup.md +0 -0
  257. /package/{content → stacks/blazor-azure}/.morph/standards/passkeys-auth.md +0 -0
  258. /package/{content → stacks/blazor-azure}/.morph/standards/vector-search-rag.md +0 -0
  259. /package/{content → stacks/blazor-azure}/.morph/state.json +0 -0
  260. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT-FEATURE.md +0 -0
  261. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT.md +0 -0
  262. /package/{content → stacks/blazor-azure}/.morph/templates/FluentDesignTheme.cs +0 -0
  263. /package/{content → stacks/blazor-azure}/.morph/templates/MudTheme.cs +0 -0
  264. /package/{content → stacks/blazor-azure}/.morph/templates/agent.cs +0 -0
  265. /package/{content → stacks/blazor-azure}/.morph/templates/clarify-questions.md +0 -0
  266. /package/{content → stacks/blazor-azure}/.morph/templates/component.razor +0 -0
  267. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Commands.cs +0 -0
  268. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Entities.cs +0 -0
  269. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Queries.cs +0 -0
  270. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/README.md +0 -0
  271. /package/{content → stacks/blazor-azure}/.morph/templates/contracts.cs +0 -0
  272. /package/{content → stacks/blazor-azure}/.morph/templates/decisions.md +0 -0
  273. /package/{content → stacks/blazor-azure}/.morph/templates/design-system.css +0 -0
  274. /package/{content → stacks/blazor-azure}/.morph/templates/infra/.dockerignore.example +0 -0
  275. /package/{content → stacks/blazor-azure}/.morph/templates/infra/Dockerfile.example +0 -0
  276. /package/{content → stacks/blazor-azure}/.morph/templates/infra/README.md +0 -0
  277. /package/{content → stacks/blazor-azure}/.morph/templates/infra/app-insights.bicep +0 -0
  278. /package/{content → stacks/blazor-azure}/.morph/templates/infra/app-service.bicep +0 -0
  279. /package/{content → stacks/blazor-azure}/.morph/templates/infra/azure-pipelines-deploy.yml +0 -0
  280. /package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app-env.bicep +0 -0
  281. /package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app.bicep +0 -0
  282. /package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.ps1 +0 -0
  283. /package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.sh +0 -0
  284. /package/{content → stacks/blazor-azure}/.morph/templates/infra/key-vault.bicep +0 -0
  285. /package/{content → stacks/blazor-azure}/.morph/templates/infra/main.bicep +0 -0
  286. /package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.dev.json +0 -0
  287. /package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.prod.json +0 -0
  288. /package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.staging.json +0 -0
  289. /package/{content → stacks/blazor-azure}/.morph/templates/infra/sql-database.bicep +0 -0
  290. /package/{content → stacks/blazor-azure}/.morph/templates/infra/storage.bicep +0 -0
  291. /package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-client.cs +0 -0
  292. /package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-webhook.cs +0 -0
  293. /package/{content → stacks/blazor-azure}/.morph/templates/integrations/azure-identity-config.cs +0 -0
  294. /package/{content → stacks/blazor-azure}/.morph/templates/integrations/clerk-config.cs +0 -0
  295. /package/{content → stacks/blazor-azure}/.morph/templates/job.cs +0 -0
  296. /package/{content → stacks/blazor-azure}/.morph/templates/migration.cs +0 -0
  297. /package/{content → stacks/blazor-azure}/.morph/templates/proposal.md +0 -0
  298. /package/{content → stacks/blazor-azure}/.morph/templates/recap.md +0 -0
  299. /package/{content → stacks/blazor-azure}/.morph/templates/repository.cs +0 -0
  300. /package/{content → stacks/blazor-azure}/.morph/templates/saas/subscription.cs +0 -0
  301. /package/{content → stacks/blazor-azure}/.morph/templates/saas/tenant.cs +0 -0
  302. /package/{content → stacks/blazor-azure}/.morph/templates/service.cs +0 -0
  303. /package/{content → stacks/blazor-azure}/.morph/templates/simulation.md +0 -0
  304. /package/{content → stacks/blazor-azure}/.morph/templates/spec.md +0 -0
  305. /package/{content → stacks/blazor-azure}/.morph/templates/sprint-status.yaml +0 -0
  306. /package/{content → stacks/blazor-azure}/.morph/templates/state.template.json +0 -0
  307. /package/{content → stacks/blazor-azure}/.morph/templates/story.md +0 -0
  308. /package/{content → stacks/blazor-azure}/.morph/templates/tasks.md +0 -0
  309. /package/{content → stacks/blazor-azure}/.morph/templates/test.cs +0 -0
  310. /package/{content → stacks/blazor-azure}/.morph/templates/ui-components.md +0 -0
  311. /package/{content → stacks/blazor-azure}/.morph/templates/ui-design-system.md +0 -0
  312. /package/{content → stacks/blazor-azure}/.morph/templates/ui-flows.md +0 -0
  313. /package/{content → stacks/blazor-azure}/.morph/templates/ui-mockups.md +0 -0
  314. /package/{content → stacks/blazor-azure}/.morph/test-infra/example.bicep +0 -0
  315. /package/{content → stacks/blazor-azure}/CLAUDE.md +0 -0
  316. /package/{content → stacks/blazor-azure}/README.md +0 -0
@@ -1,366 +1,366 @@
1
- /**
2
- * Mockup Generator
3
- *
4
- * Generates high-quality ASCII wireframes for UI components.
5
- * Used in FASE 1.5: UI/UX Design (conception phase).
6
- *
7
- * MORPH-SPEC 3.0
8
- */
9
-
10
- /**
11
- * Generate wireframe based on component spec
12
- * @param {Object} componentSpec - Component specification
13
- * @returns {string} ASCII wireframe
14
- */
15
- export function generateWireframe(componentSpec) {
16
- switch (componentSpec.type) {
17
- case 'form':
18
- return generateFormWireframe(componentSpec);
19
- case 'list':
20
- case 'data-grid':
21
- return generateListWireframe(componentSpec);
22
- case 'dashboard':
23
- return generateDashboardWireframe(componentSpec);
24
- case 'wizard':
25
- return generateWizardWireframe(componentSpec);
26
- case 'file-upload':
27
- return generateFileUploadWireframe(componentSpec);
28
- case 'confirm-dialog':
29
- return generateConfirmDialogWireframe(componentSpec);
30
- case 'detail-view':
31
- return generateDetailViewWireframe(componentSpec);
32
- default:
33
- return generateGenericWireframe(componentSpec);
34
- }
35
- }
36
-
37
- /**
38
- * Generate form wireframe
39
- */
40
- function generateFormWireframe(spec) {
41
- const { entity, operation = 'create', fields = [] } = spec;
42
- const title = operation === 'create' ? `Create ${entity}` : `Edit ${entity}`;
43
-
44
- const maxLabelLength = Math.max(...fields.map(f => (f.label || f.name).length), 15);
45
- const fieldWidth = 40;
46
- const totalWidth = maxLabelLength + fieldWidth + 10;
47
-
48
- const fieldLines = fields.map(field => {
49
- const label = (field.label || field.name).padEnd(maxLabelLength);
50
- const inputType = getInputType(field.type);
51
- const required = field.isRequired ? '*' : ' ';
52
-
53
- return `│ ${required} ${label} ${inputType.padEnd(fieldWidth)} │`;
54
- }).join('\n');
55
-
56
- return `
57
- ┌${'─'.repeat(totalWidth)}┐
58
- │ ${title.padEnd(totalWidth - 4)} │
59
- ├${'─'.repeat(totalWidth)}┤
60
- │${' '.repeat(totalWidth)}│
61
- ${fieldLines}
62
- │${' '.repeat(totalWidth)}│
63
- │ ┌──────────┐ ┌────────┐${' '.repeat(totalWidth - 34)}│
64
- │ │ ${operation === 'create' ? 'Create' : 'Save'} │ │ Cancel │${' '.repeat(totalWidth - 34)}│
65
- │ └──────────┘ └────────┘${' '.repeat(totalWidth - 34)}│
66
- └${'─'.repeat(totalWidth)}┘
67
-
68
- Legend: * = Required field
69
- `.trim();
70
- }
71
-
72
- /**
73
- * Get input type representation
74
- */
75
- function getInputType(type) {
76
- if (!type) return '[_________________]';
77
-
78
- const lower = type.toLowerCase();
79
-
80
- if (lower.includes('string') || lower.includes('text')) {
81
- return '[_________________]';
82
- } else if (lower.includes('int') || lower.includes('decimal') || lower.includes('number')) {
83
- return '[______] (number)';
84
- } else if (lower.includes('date') || lower.includes('datetime')) {
85
- return '[____/____/____] 📅';
86
- } else if (lower.includes('bool')) {
87
- return '☐ Yes ☐ No';
88
- } else if (lower.includes('enum') || lower.includes('status') || lower.includes('type')) {
89
- return '[Select option ▼]';
90
- } else if (lower.includes('email')) {
91
- return '[___@___.___]';
92
- } else if (lower.includes('url')) {
93
- return '[https://____]';
94
- } else {
95
- return '[_________________]';
96
- }
97
- }
98
-
99
- /**
100
- * Generate list/grid wireframe
101
- */
102
- function generateListWireframe(spec) {
103
- const { entity, fields = [], features = {} } = spec;
104
- const title = `${entity} List`;
105
-
106
- const headers = fields.slice(0, 5).map(f => (f.label || f.name).substring(0, 15).padEnd(15));
107
- const headerLine = headers.join(' │ ');
108
-
109
- const sampleRow = fields.slice(0, 5).map(f => {
110
- const sample = getSampleValue(f.type);
111
- return sample.substring(0, 15).padEnd(15);
112
- }).join(' │ ');
113
-
114
- const totalWidth = headers.length * 16 + headers.length - 1 + 12; // +12 for actions
115
-
116
- return `
117
- ┌${'─'.repeat(totalWidth + 4)}┐
118
- │ ${title.padEnd(totalWidth - 20)} [+ New] [⚙ Filters] │
119
- ├${'─'.repeat(totalWidth + 4)}┤
120
- │ ${headerLine} │ Actions │
121
- ├${'─'.repeat(totalWidth + 4)}┤
122
- │ ${sampleRow} │ ✏️ 🗑️ │
123
- │ ${sampleRow} │ ✏️ 🗑️ │
124
- │ ${sampleRow} │ ✏️ 🗑️ │
125
- ${features.pagination !== false ? `├${'─'.repeat(totalWidth + 4)}┤
126
- │ ◀ 1 2 3 ... 10 ▶${' '.repeat(totalWidth - 40)}Showing 1-10 of 47 │` : ''}
127
- └${'─'.repeat(totalWidth + 4)}┘
128
-
129
- ${features.filtering !== false ? '\nFeatures: Search, Filter, Sort' : ''}
130
- ${features.selection !== false ? 'Selection: Multi-select with checkboxes' : ''}
131
- `.trim();
132
- }
133
-
134
- /**
135
- * Get sample value for field type
136
- */
137
- function getSampleValue(type) {
138
- if (!type) return 'Sample Value';
139
-
140
- const lower = type.toLowerCase();
141
-
142
- if (lower.includes('name')) return 'John Doe';
143
- if (lower.includes('email')) return 'user@example.com';
144
- if (lower.includes('phone')) return '(555) 123-4567';
145
- if (lower.includes('date')) return '2025-01-17';
146
- if (lower.includes('status')) return 'Active';
147
- if (lower.includes('amount') || lower.includes('price')) return '$99.99';
148
- if (lower.includes('quantity') || lower.includes('count')) return '42';
149
- if (lower.includes('bool')) return 'Yes';
150
-
151
- return 'Sample';
152
- }
153
-
154
- /**
155
- * Generate dashboard wireframe
156
- */
157
- function generateDashboardWireframe(spec) {
158
- const { widgets = [] } = spec;
159
-
160
- const hasStats = widgets.some(w => w.type === 'stat-card');
161
- const hasChart = widgets.some(w => w.type === 'chart');
162
- const hasTable = widgets.some(w => w.type === 'data-table');
163
-
164
- return `
165
- ┌────────────────────────────────────────────────────────────────────────────┐
166
- │ Dashboard Overview [User Icon] ▼ │
167
- ├────────────────────────────────────────────────────────────────────────────┤
168
- │ │
169
- ${hasStats ? `│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
170
- │ │ Total Sales │ │ New Orders │ │ Revenue │ │
171
- │ │ $125,430 │ │ 47 │ │ +12.5% │ │
172
- │ │ +8.2% ↑ │ │ +5 today │ │ This month │ │
173
- │ └──────────────┘ └──────────────┘ └──────────────┘ │
174
- │ │` : ''}
175
- ${hasChart ? `│ ┌────────────────────────────────────────────────────────────────┐ │
176
- │ │ Sales Trend (Last 30 Days) │ │
177
- │ │ │ │
178
- │ │ $ ╭─╮ │ │
179
- │ │ │ │ ╭─╮ │ │
180
- │ │ │ │ ╭─╯ ╰─╮ ╭─╮ │ │
181
- │ │ ────┴─┴───┴─────┴───┴─┴───────────────────────────────────── │ │
182
- │ │ Week 1 Week 2 Week 3 Week 4 │ │
183
- │ └────────────────────────────────────────────────────────────────┘ │
184
- │ │` : ''}
185
- ${hasTable ? `│ ┌────────────────────────────────────────────────────────────────┐ │
186
- │ │ Recent Orders [View All →] │ │
187
- │ ├────────────────────────────────────────────────────────────────┤ │
188
- │ │ Order # Customer Amount Status Actions │ │
189
- │ ├────────────────────────────────────────────────────────────────┤ │
190
- │ │ #1234 John Doe $99.99 Pending 👁️ ✏️ │ │
191
- │ │ #1233 Jane Smith $149.99 Completed 👁️ ✏️ │ │
192
- │ │ #1232 Bob Johnson $79.99 Shipped 👁️ ✏️ │ │
193
- │ └────────────────────────────────────────────────────────────────┘ │` : ''}
194
- │ │
195
- └────────────────────────────────────────────────────────────────────────────┘
196
- `.trim();
197
- }
198
-
199
- /**
200
- * Generate wizard wireframe
201
- */
202
- function generateWizardWireframe(spec) {
203
- const { steps = [] } = spec;
204
- const currentStep = steps[0] || { number: 1, title: 'Step 1' };
205
-
206
- const stepIndicators = steps.map((step, i) => {
207
- const isCurrent = i === 0;
208
- return isCurrent ? `● ${step.number}` : `○ ${step.number}`;
209
- }).join(' ── ');
210
-
211
- return `
212
- ┌────────────────────────────────────────────────────────────────────────────┐
213
- │ ${currentStep.title.padEnd(70)} │
214
- ├────────────────────────────────────────────────────────────────────────────┤
215
- │ │
216
- │ Progress: ${stepIndicators.padEnd(60)} │
217
- │ │
218
- │ ┌──────────────────────────────────────────────────────────────────────┐ │
219
- │ │ │ │
220
- │ │ {Step ${currentStep.number} Content} │ │
221
- │ │ - Input fields │ │
222
- │ │ - Instructions │ │
223
- │ │ - Validation messages │ │
224
- │ │ │ │
225
- │ └──────────────────────────────────────────────────────────────────────┘ │
226
- │ │
227
- │ ┌────────┐ ┌────────────┐ │
228
- │ │ Back │ │ Next → │ │
229
- │ └────────┘ └────────────┘ │
230
- └────────────────────────────────────────────────────────────────────────────┘
231
- `.trim();
232
- }
233
-
234
- /**
235
- * Generate file upload wireframe
236
- */
237
- function generateFileUploadWireframe(spec) {
238
- const { maxSize = '10MB', allowedTypes = ['.jpg', '.png'] } = spec;
239
-
240
- return `
241
- ┌────────────────────────────────────────────────────────────────────────────┐
242
- │ Upload File │
243
- ├────────────────────────────────────────────────────────────────────────────┤
244
- │ │
245
- │ ┌──────────────────────────────────────────────────────────────────────┐ │
246
- │ │ │ │
247
- │ │ 📷 Drag & Drop │ │
248
- │ │ │ │
249
- │ │ Drag your file here or click to browse │ │
250
- │ │ │ │
251
- │ │ Accepted: ${allowedTypes.join(', ').padEnd(30)} │ │
252
- │ │ Max size: ${maxSize.padEnd(30)} │ │
253
- │ │ │ │
254
- │ └──────────────────────────────────────────────────────────────────────┘ │
255
- │ │
256
- │ [Preview will appear here after file selection] │
257
- │ │
258
- │ ┌────────────┐ ┌────────┐ │
259
- │ │ Upload │ │ Cancel │ │
260
- │ └────────────┘ └────────┘ │
261
- └────────────────────────────────────────────────────────────────────────────┘
262
- `.trim();
263
- }
264
-
265
- /**
266
- * Generate confirm dialog wireframe
267
- */
268
- function generateConfirmDialogWireframe(spec) {
269
- const { entity, operation = 'delete' } = spec;
270
-
271
- return `
272
- ┌────────────────────────────────────────┐
273
- │ Confirm ${operation} │
274
- ├────────────────────────────────────────┤
275
- │ │
276
- │ Are you sure you want to ${operation} │
277
- │ this ${entity}? │
278
- │ │
279
- │ This action cannot be undone. │
280
- │ │
281
- │ ┌────────────┐ ┌────────┐ │
282
- │ │ ${operation} │ │ Cancel │ │
283
- │ └────────────┘ └────────┘ │
284
- └────────────────────────────────────────┘
285
- `.trim();
286
- }
287
-
288
- /**
289
- * Generate detail view wireframe
290
- */
291
- function generateDetailViewWireframe(spec) {
292
- const { entity, fields = [] } = spec;
293
-
294
- const fieldLines = fields.slice(0, 8).map(field => {
295
- const label = (field.label || field.name).padEnd(20);
296
- const value = getSampleValue(field.type).padEnd(30);
297
- return `│ ${label}: ${value} │`;
298
- }).join('\n');
299
-
300
- return `
301
- ┌────────────────────────────────────────────────────────────────────────────┐
302
- │ ${entity} Details [✏️ Edit] [🗑️ Delete]│
303
- ├────────────────────────────────────────────────────────────────────────────┤
304
- │ │
305
- ${fieldLines}
306
- │ │
307
- │ ┌────────┐ │
308
- │ │ Back │ │
309
- │ └────────┘ │
310
- └────────────────────────────────────────────────────────────────────────────┘
311
- `.trim();
312
- }
313
-
314
- /**
315
- * Generate generic wireframe
316
- */
317
- function generateGenericWireframe(spec) {
318
- const { entity = 'Component', type = 'generic' } = spec;
319
-
320
- return `
321
- ┌────────────────────────────────────────────────────────────────────────────┐
322
- │ ${entity} (${type}) │
323
- ├────────────────────────────────────────────────────────────────────────────┤
324
- │ │
325
- │ [Component content will be defined based on requirements] │
326
- │ │
327
- │ - Feature 1 │
328
- │ - Feature 2 │
329
- │ - Feature 3 │
330
- │ │
331
- └────────────────────────────────────────────────────────────────────────────┘
332
- `.trim();
333
- }
334
-
335
- /**
336
- * Generate complete UI mockup set
337
- */
338
- export function generateCompleteMockupSet(uiNeeds) {
339
- const mockups = {};
340
-
341
- for (const need of uiNeeds) {
342
- const key = `${need.type}-${need.entity || need.operation || 'generic'}`;
343
- mockups[key] = generateWireframe(need);
344
- }
345
-
346
- return mockups;
347
- }
348
-
349
- /**
350
- * Format mockups for markdown output
351
- */
352
- export function formatMockupsForMarkdown(mockups) {
353
- const sections = [];
354
-
355
- for (const [key, wireframe] of Object.entries(mockups)) {
356
- const [type, entity] = key.split('-');
357
- sections.push(`### ${entity} - ${type.toUpperCase()}`);
358
- sections.push('');
359
- sections.push('```');
360
- sections.push(wireframe);
361
- sections.push('```');
362
- sections.push('');
363
- }
364
-
365
- return sections.join('\n');
366
- }
1
+ /**
2
+ * Mockup Generator
3
+ *
4
+ * Generates high-quality ASCII wireframes for UI components.
5
+ * Used in FASE 1.5: UI/UX Design (conception phase).
6
+ *
7
+ * MORPH-SPEC 3.0
8
+ */
9
+
10
+ /**
11
+ * Generate wireframe based on component spec
12
+ * @param {Object} componentSpec - Component specification
13
+ * @returns {string} ASCII wireframe
14
+ */
15
+ export function generateWireframe(componentSpec) {
16
+ switch (componentSpec.type) {
17
+ case 'form':
18
+ return generateFormWireframe(componentSpec);
19
+ case 'list':
20
+ case 'data-grid':
21
+ return generateListWireframe(componentSpec);
22
+ case 'dashboard':
23
+ return generateDashboardWireframe(componentSpec);
24
+ case 'wizard':
25
+ return generateWizardWireframe(componentSpec);
26
+ case 'file-upload':
27
+ return generateFileUploadWireframe(componentSpec);
28
+ case 'confirm-dialog':
29
+ return generateConfirmDialogWireframe(componentSpec);
30
+ case 'detail-view':
31
+ return generateDetailViewWireframe(componentSpec);
32
+ default:
33
+ return generateGenericWireframe(componentSpec);
34
+ }
35
+ }
36
+
37
+ /**
38
+ * Generate form wireframe
39
+ */
40
+ function generateFormWireframe(spec) {
41
+ const { entity, operation = 'create', fields = [] } = spec;
42
+ const title = operation === 'create' ? `Create ${entity}` : `Edit ${entity}`;
43
+
44
+ const maxLabelLength = Math.max(...fields.map(f => (f.label || f.name).length), 15);
45
+ const fieldWidth = 40;
46
+ const totalWidth = maxLabelLength + fieldWidth + 10;
47
+
48
+ const fieldLines = fields.map(field => {
49
+ const label = (field.label || field.name).padEnd(maxLabelLength);
50
+ const inputType = getInputType(field.type);
51
+ const required = field.isRequired ? '*' : ' ';
52
+
53
+ return `│ ${required} ${label} ${inputType.padEnd(fieldWidth)} │`;
54
+ }).join('\n');
55
+
56
+ return `
57
+ ┌${'─'.repeat(totalWidth)}┐
58
+ │ ${title.padEnd(totalWidth - 4)} │
59
+ ├${'─'.repeat(totalWidth)}┤
60
+ │${' '.repeat(totalWidth)}│
61
+ ${fieldLines}
62
+ │${' '.repeat(totalWidth)}│
63
+ │ ┌──────────┐ ┌────────┐${' '.repeat(totalWidth - 34)}│
64
+ │ │ ${operation === 'create' ? 'Create' : 'Save'} │ │ Cancel │${' '.repeat(totalWidth - 34)}│
65
+ │ └──────────┘ └────────┘${' '.repeat(totalWidth - 34)}│
66
+ └${'─'.repeat(totalWidth)}┘
67
+
68
+ Legend: * = Required field
69
+ `.trim();
70
+ }
71
+
72
+ /**
73
+ * Get input type representation
74
+ */
75
+ function getInputType(type) {
76
+ if (!type) return '[_________________]';
77
+
78
+ const lower = type.toLowerCase();
79
+
80
+ if (lower.includes('string') || lower.includes('text')) {
81
+ return '[_________________]';
82
+ } else if (lower.includes('int') || lower.includes('decimal') || lower.includes('number')) {
83
+ return '[______] (number)';
84
+ } else if (lower.includes('date') || lower.includes('datetime')) {
85
+ return '[____/____/____] 📅';
86
+ } else if (lower.includes('bool')) {
87
+ return '☐ Yes ☐ No';
88
+ } else if (lower.includes('enum') || lower.includes('status') || lower.includes('type')) {
89
+ return '[Select option ▼]';
90
+ } else if (lower.includes('email')) {
91
+ return '[___@___.___]';
92
+ } else if (lower.includes('url')) {
93
+ return '[https://____]';
94
+ } else {
95
+ return '[_________________]';
96
+ }
97
+ }
98
+
99
+ /**
100
+ * Generate list/grid wireframe
101
+ */
102
+ function generateListWireframe(spec) {
103
+ const { entity, fields = [], features = {} } = spec;
104
+ const title = `${entity} List`;
105
+
106
+ const headers = fields.slice(0, 5).map(f => (f.label || f.name).substring(0, 15).padEnd(15));
107
+ const headerLine = headers.join(' │ ');
108
+
109
+ const sampleRow = fields.slice(0, 5).map(f => {
110
+ const sample = getSampleValue(f.type);
111
+ return sample.substring(0, 15).padEnd(15);
112
+ }).join(' │ ');
113
+
114
+ const totalWidth = headers.length * 16 + headers.length - 1 + 12; // +12 for actions
115
+
116
+ return `
117
+ ┌${'─'.repeat(totalWidth + 4)}┐
118
+ │ ${title.padEnd(totalWidth - 20)} [+ New] [⚙ Filters] │
119
+ ├${'─'.repeat(totalWidth + 4)}┤
120
+ │ ${headerLine} │ Actions │
121
+ ├${'─'.repeat(totalWidth + 4)}┤
122
+ │ ${sampleRow} │ ✏️ 🗑️ │
123
+ │ ${sampleRow} │ ✏️ 🗑️ │
124
+ │ ${sampleRow} │ ✏️ 🗑️ │
125
+ ${features.pagination !== false ? `├${'─'.repeat(totalWidth + 4)}┤
126
+ │ ◀ 1 2 3 ... 10 ▶${' '.repeat(totalWidth - 40)}Showing 1-10 of 47 │` : ''}
127
+ └${'─'.repeat(totalWidth + 4)}┘
128
+
129
+ ${features.filtering !== false ? '\nFeatures: Search, Filter, Sort' : ''}
130
+ ${features.selection !== false ? 'Selection: Multi-select with checkboxes' : ''}
131
+ `.trim();
132
+ }
133
+
134
+ /**
135
+ * Get sample value for field type
136
+ */
137
+ function getSampleValue(type) {
138
+ if (!type) return 'Sample Value';
139
+
140
+ const lower = type.toLowerCase();
141
+
142
+ if (lower.includes('name')) return 'John Doe';
143
+ if (lower.includes('email')) return 'user@example.com';
144
+ if (lower.includes('phone')) return '(555) 123-4567';
145
+ if (lower.includes('date')) return '2025-01-17';
146
+ if (lower.includes('status')) return 'Active';
147
+ if (lower.includes('amount') || lower.includes('price')) return '$99.99';
148
+ if (lower.includes('quantity') || lower.includes('count')) return '42';
149
+ if (lower.includes('bool')) return 'Yes';
150
+
151
+ return 'Sample';
152
+ }
153
+
154
+ /**
155
+ * Generate dashboard wireframe
156
+ */
157
+ function generateDashboardWireframe(spec) {
158
+ const { widgets = [] } = spec;
159
+
160
+ const hasStats = widgets.some(w => w.type === 'stat-card');
161
+ const hasChart = widgets.some(w => w.type === 'chart');
162
+ const hasTable = widgets.some(w => w.type === 'data-table');
163
+
164
+ return `
165
+ ┌────────────────────────────────────────────────────────────────────────────┐
166
+ │ Dashboard Overview [User Icon] ▼ │
167
+ ├────────────────────────────────────────────────────────────────────────────┤
168
+ │ │
169
+ ${hasStats ? `│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
170
+ │ │ Total Sales │ │ New Orders │ │ Revenue │ │
171
+ │ │ $125,430 │ │ 47 │ │ +12.5% │ │
172
+ │ │ +8.2% ↑ │ │ +5 today │ │ This month │ │
173
+ │ └──────────────┘ └──────────────┘ └──────────────┘ │
174
+ │ │` : ''}
175
+ ${hasChart ? `│ ┌────────────────────────────────────────────────────────────────┐ │
176
+ │ │ Sales Trend (Last 30 Days) │ │
177
+ │ │ │ │
178
+ │ │ $ ╭─╮ │ │
179
+ │ │ │ │ ╭─╮ │ │
180
+ │ │ │ │ ╭─╯ ╰─╮ ╭─╮ │ │
181
+ │ │ ────┴─┴───┴─────┴───┴─┴───────────────────────────────────── │ │
182
+ │ │ Week 1 Week 2 Week 3 Week 4 │ │
183
+ │ └────────────────────────────────────────────────────────────────┘ │
184
+ │ │` : ''}
185
+ ${hasTable ? `│ ┌────────────────────────────────────────────────────────────────┐ │
186
+ │ │ Recent Orders [View All →] │ │
187
+ │ ├────────────────────────────────────────────────────────────────┤ │
188
+ │ │ Order # Customer Amount Status Actions │ │
189
+ │ ├────────────────────────────────────────────────────────────────┤ │
190
+ │ │ #1234 John Doe $99.99 Pending 👁️ ✏️ │ │
191
+ │ │ #1233 Jane Smith $149.99 Completed 👁️ ✏️ │ │
192
+ │ │ #1232 Bob Johnson $79.99 Shipped 👁️ ✏️ │ │
193
+ │ └────────────────────────────────────────────────────────────────┘ │` : ''}
194
+ │ │
195
+ └────────────────────────────────────────────────────────────────────────────┘
196
+ `.trim();
197
+ }
198
+
199
+ /**
200
+ * Generate wizard wireframe
201
+ */
202
+ function generateWizardWireframe(spec) {
203
+ const { steps = [] } = spec;
204
+ const currentStep = steps[0] || { number: 1, title: 'Step 1' };
205
+
206
+ const stepIndicators = steps.map((step, i) => {
207
+ const isCurrent = i === 0;
208
+ return isCurrent ? `● ${step.number}` : `○ ${step.number}`;
209
+ }).join(' ── ');
210
+
211
+ return `
212
+ ┌────────────────────────────────────────────────────────────────────────────┐
213
+ │ ${currentStep.title.padEnd(70)} │
214
+ ├────────────────────────────────────────────────────────────────────────────┤
215
+ │ │
216
+ │ Progress: ${stepIndicators.padEnd(60)} │
217
+ │ │
218
+ │ ┌──────────────────────────────────────────────────────────────────────┐ │
219
+ │ │ │ │
220
+ │ │ {Step ${currentStep.number} Content} │ │
221
+ │ │ - Input fields │ │
222
+ │ │ - Instructions │ │
223
+ │ │ - Validation messages │ │
224
+ │ │ │ │
225
+ │ └──────────────────────────────────────────────────────────────────────┘ │
226
+ │ │
227
+ │ ┌────────┐ ┌────────────┐ │
228
+ │ │ Back │ │ Next → │ │
229
+ │ └────────┘ └────────────┘ │
230
+ └────────────────────────────────────────────────────────────────────────────┘
231
+ `.trim();
232
+ }
233
+
234
+ /**
235
+ * Generate file upload wireframe
236
+ */
237
+ function generateFileUploadWireframe(spec) {
238
+ const { maxSize = '10MB', allowedTypes = ['.jpg', '.png'] } = spec;
239
+
240
+ return `
241
+ ┌────────────────────────────────────────────────────────────────────────────┐
242
+ │ Upload File │
243
+ ├────────────────────────────────────────────────────────────────────────────┤
244
+ │ │
245
+ │ ┌──────────────────────────────────────────────────────────────────────┐ │
246
+ │ │ │ │
247
+ │ │ 📷 Drag & Drop │ │
248
+ │ │ │ │
249
+ │ │ Drag your file here or click to browse │ │
250
+ │ │ │ │
251
+ │ │ Accepted: ${allowedTypes.join(', ').padEnd(30)} │ │
252
+ │ │ Max size: ${maxSize.padEnd(30)} │ │
253
+ │ │ │ │
254
+ │ └──────────────────────────────────────────────────────────────────────┘ │
255
+ │ │
256
+ │ [Preview will appear here after file selection] │
257
+ │ │
258
+ │ ┌────────────┐ ┌────────┐ │
259
+ │ │ Upload │ │ Cancel │ │
260
+ │ └────────────┘ └────────┘ │
261
+ └────────────────────────────────────────────────────────────────────────────┘
262
+ `.trim();
263
+ }
264
+
265
+ /**
266
+ * Generate confirm dialog wireframe
267
+ */
268
+ function generateConfirmDialogWireframe(spec) {
269
+ const { entity, operation = 'delete' } = spec;
270
+
271
+ return `
272
+ ┌────────────────────────────────────────┐
273
+ │ Confirm ${operation} │
274
+ ├────────────────────────────────────────┤
275
+ │ │
276
+ │ Are you sure you want to ${operation} │
277
+ │ this ${entity}? │
278
+ │ │
279
+ │ This action cannot be undone. │
280
+ │ │
281
+ │ ┌────────────┐ ┌────────┐ │
282
+ │ │ ${operation} │ │ Cancel │ │
283
+ │ └────────────┘ └────────┘ │
284
+ └────────────────────────────────────────┘
285
+ `.trim();
286
+ }
287
+
288
+ /**
289
+ * Generate detail view wireframe
290
+ */
291
+ function generateDetailViewWireframe(spec) {
292
+ const { entity, fields = [] } = spec;
293
+
294
+ const fieldLines = fields.slice(0, 8).map(field => {
295
+ const label = (field.label || field.name).padEnd(20);
296
+ const value = getSampleValue(field.type).padEnd(30);
297
+ return `│ ${label}: ${value} │`;
298
+ }).join('\n');
299
+
300
+ return `
301
+ ┌────────────────────────────────────────────────────────────────────────────┐
302
+ │ ${entity} Details [✏️ Edit] [🗑️ Delete]│
303
+ ├────────────────────────────────────────────────────────────────────────────┤
304
+ │ │
305
+ ${fieldLines}
306
+ │ │
307
+ │ ┌────────┐ │
308
+ │ │ Back │ │
309
+ │ └────────┘ │
310
+ └────────────────────────────────────────────────────────────────────────────┘
311
+ `.trim();
312
+ }
313
+
314
+ /**
315
+ * Generate generic wireframe
316
+ */
317
+ function generateGenericWireframe(spec) {
318
+ const { entity = 'Component', type = 'generic' } = spec;
319
+
320
+ return `
321
+ ┌────────────────────────────────────────────────────────────────────────────┐
322
+ │ ${entity} (${type}) │
323
+ ├────────────────────────────────────────────────────────────────────────────┤
324
+ │ │
325
+ │ [Component content will be defined based on requirements] │
326
+ │ │
327
+ │ - Feature 1 │
328
+ │ - Feature 2 │
329
+ │ - Feature 3 │
330
+ │ │
331
+ └────────────────────────────────────────────────────────────────────────────┘
332
+ `.trim();
333
+ }
334
+
335
+ /**
336
+ * Generate complete UI mockup set
337
+ */
338
+ export function generateCompleteMockupSet(uiNeeds) {
339
+ const mockups = {};
340
+
341
+ for (const need of uiNeeds) {
342
+ const key = `${need.type}-${need.entity || need.operation || 'generic'}`;
343
+ mockups[key] = generateWireframe(need);
344
+ }
345
+
346
+ return mockups;
347
+ }
348
+
349
+ /**
350
+ * Format mockups for markdown output
351
+ */
352
+ export function formatMockupsForMarkdown(mockups) {
353
+ const sections = [];
354
+
355
+ for (const [key, wireframe] of Object.entries(mockups)) {
356
+ const [type, entity] = key.split('-');
357
+ sections.push(`### ${entity} - ${type.toUpperCase()}`);
358
+ sections.push('');
359
+ sections.push('```');
360
+ sections.push(wireframe);
361
+ sections.push('```');
362
+ sections.push('');
363
+ }
364
+
365
+ return sections.join('\n');
366
+ }