@polymorphism-tech/morph-spec 4.5.0 → 4.7.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 (292) hide show
  1. package/CLAUDE.md +77 -56
  2. package/README.md +394 -700
  3. package/docs/ARCHITECTURE.md +331 -0
  4. package/docs/CHEATSHEET.md +221 -0
  5. package/docs/COMMAND-FLOWS.md +368 -0
  6. package/docs/QUICKSTART.md +212 -0
  7. package/docs/examples/order-management/contracts.cs +84 -0
  8. package/docs/examples/order-management/proposal.md +24 -0
  9. package/docs/examples/order-management/spec.md +162 -0
  10. package/docs/plans/2026-02-23-ddd-architecture-refactor.md +1153 -0
  11. package/docs/plans/2026-02-23-ddd-nextsteps.md +682 -0
  12. package/docs/plans/2026-02-23-infra-architect-refactor.md +437 -0
  13. package/docs/plans/2026-02-23-nextjs-code-review-design.md +156 -0
  14. package/docs/plans/2026-02-23-nextjs-code-review-impl.md +1254 -0
  15. package/docs/plans/2026-02-23-nextjs-standards-design.md +149 -0
  16. package/docs/plans/2026-02-23-nextjs-standards-impl.md +1846 -0
  17. package/framework/{skills/level-2-domains → agents}/README.md +14 -14
  18. package/framework/{skills/level-2-domains → agents}/ai-agents/ai-system-architect.md +1 -4
  19. package/framework/{skills/level-2-domains → agents}/architecture/po-pm-advisor.md +1 -2
  20. package/framework/{skills/level-2-domains → agents}/architecture/prompt-engineer.md +1 -2
  21. package/framework/{skills/level-2-domains → agents}/architecture/seo-growth-hacker.md +1 -2
  22. package/framework/{skills/level-2-domains → agents}/architecture/standards-architect.md +159 -162
  23. package/framework/agents/backend/api-designer.md +103 -0
  24. package/framework/{skills/level-2-domains → agents}/backend/dotnet-senior.md +1 -2
  25. package/framework/agents/backend/ef-modeler.md +119 -0
  26. package/framework/{skills/level-2-domains → agents}/backend/hangfire-orchestrator.md +1 -4
  27. package/framework/{skills/level-2-domains → agents}/backend/ms-agent-expert.md +1 -4
  28. package/framework/{skills/level-2-domains → agents}/frontend/blazor-builder.md +1 -4
  29. package/framework/agents/frontend/nextjs-expert.md +118 -0
  30. package/framework/{skills/level-2-domains → agents}/frontend/ui-ux-designer.md +1 -2
  31. package/framework/{skills/level-2-domains → agents}/infrastructure/azure-architect.md +147 -148
  32. package/framework/{skills/level-2-domains → agents}/infrastructure/azure-deploy-specialist.md +1 -2
  33. package/framework/{skills/level-2-domains → agents}/infrastructure/bicep-architect.md +1 -4
  34. package/framework/{skills/level-2-domains → agents}/infrastructure/container-specialist.md +1 -4
  35. package/framework/{skills/level-2-domains → agents}/infrastructure/devops-engineer.md +1 -4
  36. package/framework/agents/infrastructure/infra-architect.md +45 -0
  37. package/framework/{skills/level-2-domains → agents}/integrations/asaas-financial.md +1 -4
  38. package/framework/{skills/level-2-domains → agents}/integrations/azure-identity.md +1 -4
  39. package/framework/{skills/level-2-domains → agents}/integrations/clerk-auth.md +1 -4
  40. package/framework/{skills/level-2-domains → agents}/integrations/hangfire-integration.md +1 -2
  41. package/framework/{skills/level-2-domains → agents}/integrations/resend-email.md +1 -4
  42. package/framework/{skills/level-2-domains → agents}/quality/code-analyzer.md +1 -4
  43. package/framework/{skills/level-2-domains → agents}/quality/testing-specialist.md +1 -4
  44. package/framework/agents.json +1145 -278
  45. package/framework/hooks/claude-code/statusline.py +384 -85
  46. package/framework/hooks/shared/phase-utils.js +129 -129
  47. package/framework/rules/frontend-standards.md +0 -3
  48. package/framework/rules/nextjs-standards.md +17 -0
  49. package/framework/skills/README.md +66 -0
  50. package/framework/skills/level-0-meta/{brainstorming.md → brainstorming/SKILL.md} +3 -1
  51. package/framework/skills/level-0-meta/brainstorming/references/proposal-example.md +138 -0
  52. package/framework/skills/level-0-meta/{code-review.md → code-review/SKILL.md} +3 -2
  53. package/framework/skills/level-0-meta/code-review/references/review-example.md +164 -0
  54. package/framework/skills/level-0-meta/code-review/scripts/scan-csharp.mjs +121 -0
  55. package/framework/skills/level-0-meta/code-review-nextjs/SKILL.md +147 -0
  56. package/framework/skills/level-0-meta/code-review-nextjs/references/review-example-nextjs.md +254 -0
  57. package/framework/skills/level-0-meta/{morph-checklist.md → morph-checklist/SKILL.md} +2 -5
  58. package/framework/skills/{level-1-workflows/morph-replicate.md → level-0-meta/morph-replicate/SKILL.md} +6 -7
  59. package/framework/skills/level-0-meta/{simulation-checklist.md → simulation-checklist/SKILL.md} +3 -6
  60. package/framework/skills/level-0-meta/{tool-usage-guide.md → tool-usage-guide/SKILL.md} +4 -5
  61. package/framework/skills/level-0-meta/{verification-before-completion.md → verification-before-completion/SKILL.md} +3 -1
  62. package/framework/skills/level-0-meta/verification-before-completion/scripts/check-phase-outputs.mjs +110 -0
  63. package/framework/skills/level-1-workflows/{phase-clarify.md → phase-clarify/SKILL.md} +3 -3
  64. package/framework/skills/level-1-workflows/phase-clarify/references/clarifications-example.md +117 -0
  65. package/framework/skills/level-1-workflows/{phase-codebase-analysis.md → phase-codebase-analysis/SKILL.md} +2 -3
  66. package/framework/skills/level-1-workflows/{phase-design.md → phase-design/SKILL.md} +46 -182
  67. package/framework/skills/level-1-workflows/phase-design/references/spec-example.md +253 -0
  68. package/framework/skills/level-1-workflows/{phase-implement.md → phase-implement/SKILL.md} +3 -3
  69. package/framework/skills/level-1-workflows/phase-implement/references/recap-example.md +132 -0
  70. package/framework/skills/level-1-workflows/{phase-setup.md → phase-setup/SKILL.md} +2 -3
  71. package/framework/skills/level-1-workflows/{phase-tasks.md → phase-tasks/SKILL.md} +42 -3
  72. package/framework/skills/level-1-workflows/phase-tasks/references/tasks-example.md +231 -0
  73. package/framework/skills/level-1-workflows/phase-tasks/scripts/validate-tasks.mjs +112 -0
  74. package/framework/skills/level-1-workflows/{phase-uiux.md → phase-uiux/SKILL.md} +2 -3
  75. package/framework/standards/STANDARDS.json +121 -0
  76. package/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
  77. package/framework/standards/architecture/ddd/complexity-levels.md +108 -0
  78. package/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
  79. package/framework/standards/frontend/nextjs/app-router.md +123 -0
  80. package/framework/standards/frontend/nextjs/components.md +132 -0
  81. package/framework/standards/frontend/nextjs/data-fetching.md +126 -0
  82. package/framework/standards/frontend/nextjs/forms.md +128 -0
  83. package/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
  84. package/framework/standards/frontend/nextjs/project-structure.md +102 -0
  85. package/framework/standards/frontend/nextjs/state-management.md +72 -0
  86. package/framework/standards/frontend/nextjs/testing.md +111 -0
  87. package/framework/templates/REGISTRY.json +538 -142
  88. package/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
  89. package/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
  90. package/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
  91. package/framework/templates/docs/spec.md +49 -0
  92. package/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
  93. package/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
  94. package/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
  95. package/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
  96. package/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
  97. package/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
  98. package/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
  99. package/framework/templates/project-structure/dotnet-ddd.md +70 -0
  100. package/framework/workflows/docs/enforcement-pipeline.md +2 -1
  101. package/package.json +1 -1
  102. package/scripts/scan-nextjs.mjs +169 -0
  103. package/src/commands/project/doctor.js +52 -1
  104. package/src/commands/project/init.js +19 -65
  105. package/src/commands/project/update.js +7 -63
  106. package/src/lib/detectors/claude-config-detector.js +1 -3
  107. package/src/lib/standards/standards-context-injector.js +5 -0
  108. package/src/lib/validators/nextjs/index.js +6 -0
  109. package/src/lib/validators/nextjs/next-component-validator.js +181 -0
  110. package/src/lib/validators/validation-runner.js +5 -0
  111. package/src/utils/agents-installer.js +16 -4
  112. package/src/utils/skills-installer.js +59 -15
  113. package/.morph/.morphversion +0 -5
  114. package/.morph/analytics/threads-log.jsonl +0 -44
  115. package/.morph/config/config.json +0 -8
  116. package/.morph/context/README.md +0 -17
  117. package/.morph/framework/agents.json +0 -948
  118. package/.morph/framework/standards/STANDARDS.json +0 -812
  119. package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
  120. package/.morph/framework/standards/ai-agents/production.md +0 -415
  121. package/.morph/framework/standards/ai-agents/setup.md +0 -418
  122. package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
  123. package/.morph/framework/standards/ai-agents/workflows.md +0 -354
  124. package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
  125. package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
  126. package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
  127. package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
  128. package/.morph/framework/standards/backend/api/rest.md +0 -492
  129. package/.morph/framework/standards/backend/api/validation.md +0 -88
  130. package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
  131. package/.morph/framework/standards/backend/database/ef-core.md +0 -199
  132. package/.morph/framework/standards/backend/database/migrations.md +0 -393
  133. package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
  134. package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
  135. package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
  136. package/.morph/framework/standards/backend/dotnet/async.md +0 -366
  137. package/.morph/framework/standards/backend/dotnet/core.md +0 -117
  138. package/.morph/framework/standards/backend/dotnet/di.md +0 -439
  139. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
  140. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
  141. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
  142. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
  143. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
  144. package/.morph/framework/standards/context/analytics.md +0 -96
  145. package/.morph/framework/standards/context/bundles.md +0 -110
  146. package/.morph/framework/standards/context/priming.md +0 -78
  147. package/.morph/framework/standards/core/architecture.md +0 -185
  148. package/.morph/framework/standards/core/coding.md +0 -214
  149. package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
  150. package/.morph/framework/standards/core/git.md +0 -185
  151. package/.morph/framework/standards/core/testing.md +0 -295
  152. package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
  153. package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
  154. package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
  155. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
  156. package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
  157. package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
  158. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
  159. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
  160. package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
  161. package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
  162. package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
  163. package/.morph/framework/standards/frontend/blazor/state.md +0 -191
  164. package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
  165. package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
  166. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -198
  167. package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
  168. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
  169. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
  170. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
  171. package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
  172. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
  173. package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
  174. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
  175. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
  176. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
  177. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
  178. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
  179. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
  180. package/.morph/framework/standards/integration/api/graphql.md +0 -91
  181. package/.morph/framework/standards/integration/api/grpc.md +0 -114
  182. package/.morph/framework/standards/integration/api/rest-design.md +0 -95
  183. package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
  184. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
  185. package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
  186. package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
  187. package/.morph/framework/standards/observability/logging.md +0 -131
  188. package/.morph/framework/standards/observability/metrics.md +0 -121
  189. package/.morph/framework/standards/observability/monitoring.md +0 -114
  190. package/.morph/framework/standards/observability/tracing.md +0 -132
  191. package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
  192. package/.morph/framework/standards/workflows/thread-management.md +0 -113
  193. package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
  194. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
  195. package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
  196. package/.morph/framework/templates/README.md +0 -814
  197. package/.morph/framework/templates/REGISTRY.json +0 -1492
  198. package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
  199. package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
  200. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
  201. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
  202. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
  203. package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
  204. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
  205. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  206. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
  207. package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
  208. package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
  209. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
  210. package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
  211. package/.morph/framework/templates/code/dotnet/test.cs +0 -239
  212. package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
  213. package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
  214. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
  215. package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
  216. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
  217. package/.morph/framework/templates/context/CONTEXT.md +0 -181
  218. package/.morph/framework/templates/docs/clarifications.md +0 -253
  219. package/.morph/framework/templates/docs/onboarding.md +0 -123
  220. package/.morph/framework/templates/docs/proposal.md +0 -182
  221. package/.morph/framework/templates/docs/schema-analysis.md +0 -119
  222. package/.morph/framework/templates/docs/spec.md +0 -149
  223. package/.morph/framework/templates/docs/ui-components.md +0 -124
  224. package/.morph/framework/templates/docs/ui-design-system.md +0 -76
  225. package/.morph/framework/templates/docs/ui-flows.md +0 -167
  226. package/.morph/framework/templates/docs/ui-mockups.md +0 -98
  227. package/.morph/framework/templates/examples/design-system-examples.md +0 -357
  228. package/.morph/framework/templates/examples/spec-examples.md +0 -90
  229. package/.morph/framework/templates/feature/decisions.md +0 -187
  230. package/.morph/framework/templates/feature/recap.md +0 -146
  231. package/.morph/framework/templates/feature/tasks.md +0 -199
  232. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
  233. package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
  234. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
  235. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
  236. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
  237. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
  238. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
  239. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
  240. package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
  241. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
  242. package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
  243. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
  244. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
  245. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
  246. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
  247. package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
  248. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
  249. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
  250. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
  251. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
  252. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
  253. package/.morph/framework/templates/infrastructure/github/README.md +0 -593
  254. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
  255. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
  256. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
  257. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
  258. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
  259. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
  260. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
  261. package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
  262. package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
  263. package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
  264. package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
  265. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
  266. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
  267. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
  268. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
  269. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
  270. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
  271. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
  272. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
  273. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
  274. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
  275. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
  276. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
  277. package/.morph/framework/templates/saas/subscription.cs +0 -347
  278. package/.morph/framework/templates/saas/tenant.cs +0 -338
  279. package/.morph/framework/templates/state.template.json +0 -17
  280. package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
  281. package/.morph/framework/templates/ui/MudTheme.cs +0 -281
  282. package/.morph/framework/templates/ui/design-system.css +0 -226
  283. package/.morph/logs/tool-failures.log +0 -51
  284. package/.morph/memory/pre-compact-2026-02-22T17-01-01-658Z.json +0 -16
  285. package/.morph/state.json +0 -48
  286. package/framework/skills/level-2-domains/backend/api-designer.md +0 -66
  287. package/framework/skills/level-2-domains/backend/ef-modeler.md +0 -65
  288. package/framework/skills/level-2-domains/frontend/nextjs-expert.md +0 -161
  289. package/framework/skills/level-3-technologies/README.md +0 -7
  290. package/framework/skills/level-4-patterns/README.md +0 -7
  291. package/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  292. package/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
@@ -1,595 +0,0 @@
1
- # Fluent UI Blazor - Setup e Padrões (.NET 10)
2
-
3
- > **Scope:** blazor-azure
4
- > **Layer:** 2 (on keyword)
5
- > **Keywords:** fluent ui, setup, azure, blazor, components
6
- > **Load When:** fluent ui setup keywords detected
7
-
8
- Biblioteca de UI recomendada para projetos **AI-first** e micro-SaaS no MORPH-SPEC.
9
-
10
- ---
11
-
12
- ## 🎯 Por Que Fluent UI Blazor?
13
-
14
- ### Para Projetos AI-First
15
-
16
- | Vantagem | Descrição |
17
- |----------|-----------|
18
- | **Componentes AI nativos** | Chat containers, streaming, typing indicators |
19
- | **Microsoft Stack** | Integração perfeita com Agent Framework, Aspire, .NET 10 |
20
- | **Design Copilot-like** | UX patterns da Microsoft para AI assistants |
21
- | **Futuro-proof** | Microsoft evolui junto com AI capabilities |
22
- | **Performance** | ~200KB gzipped (vs 500KB MudBlazor) |
23
- | **Aspire Dashboard** | Mesma lib - consistência visual |
24
-
25
- ### Para Micro-SaaS
26
-
27
- - **Design System moderno** - Microsoft 365 style
28
- - **Acessibilidade nativa** - WCAG compliant
29
- - **Dark mode** - Built-in
30
- - **Responsive** - Mobile-first
31
- - **Grátis** - MIT License, sem custos
32
-
33
- ---
34
-
35
- ## 📦 Setup
36
-
37
- ### 1. Instalar Package
38
-
39
- ```bash
40
- dotnet add package Microsoft.FluentUI.AspNetCore.Components --version 4.0.0
41
- ```
42
-
43
- ### 2. Configurar Program.cs
44
-
45
- ```csharp
46
- var builder = WebApplication.CreateBuilder(args);
47
-
48
- // Blazor
49
- builder.Services.AddRazorComponents()
50
- .AddInteractiveServerComponents();
51
-
52
- // Fluent UI
53
- builder.Services.AddFluentUIComponents();
54
-
55
- var app = builder.Build();
56
-
57
- // Pipeline
58
- app.UseStaticFiles();
59
- app.UseAntiforgery();
60
-
61
- app.MapRazorComponents<App>()
62
- .AddInteractiveServerRenderMode()
63
- .AddAdditionalAssemblies(typeof(Microsoft.FluentUI.AspNetCore.Components._Imports).Assembly);
64
-
65
- app.Run();
66
- ```
67
-
68
- ### 3. Configurar _Imports.razor
69
-
70
- ```razor
71
- @* Components/_Imports.razor *@
72
- @using Microsoft.AspNetCore.Components.Web
73
- @using Microsoft.FluentUI.AspNetCore.Components
74
- @using Microsoft.FluentUI.AspNetCore.Components.Icons
75
- ```
76
-
77
- ### 4. Adicionar CSS e JS
78
-
79
- ```html
80
- <!-- Components/App.razor -->
81
- <!DOCTYPE html>
82
- <html lang="pt-BR">
83
- <head>
84
- <meta charset="utf-8" />
85
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
86
- <base href="/" />
87
-
88
- <!-- Fluent UI CSS -->
89
- <link href="_content/Microsoft.FluentUI.AspNetCore.Components/css/reboot.css" rel="stylesheet" />
90
- <link href="_content/Microsoft.FluentUI.AspNetCore.Components/Microsoft.FluentUI.AspNetCore.Components.min.css" rel="stylesheet" />
91
-
92
- <HeadOutlet />
93
- </head>
94
- <body>
95
- <Routes />
96
-
97
- <!-- Fluent UI JS -->
98
- <script src="_content/Microsoft.FluentUI.AspNetCore.Components/Microsoft.FluentUI.AspNetCore.Components.lib.module.js" type="module"></script>
99
- </body>
100
- </html>
101
- ```
102
-
103
- ---
104
-
105
- ## 🎨 Layout SaaS Padrão
106
-
107
- ### Layout Principal
108
-
109
- ```razor
110
- @* Components/Layout/MainLayout.razor *@
111
- @inherits LayoutComponentBase
112
-
113
- <FluentLayout>
114
- <!-- Header -->
115
- <FluentHeader>
116
- <FluentStack Orientation="Orientation.Horizontal" HorizontalAlignment="HorizontalAlignment.SpaceBetween">
117
- <FluentStack Orientation="Orientation.Horizontal">
118
- <FluentIcon Value="@(new Icons.Regular.Size24.AppGeneric())" Color="Color.Accent" />
119
- <FluentLabel Typo="Typography.H5">Meu SaaS</FluentLabel>
120
- </FluentStack>
121
-
122
- <FluentStack Orientation="Orientation.Horizontal">
123
- <FluentButton Appearance="Appearance.Stealth" IconStart="@(new Icons.Regular.Size20.DarkTheme())">
124
- Dark Mode
125
- </FluentButton>
126
- <FluentPersona Name="@_userName" Image="@_userAvatar" />
127
- </FluentStack>
128
- </FluentStack>
129
- </FluentHeader>
130
-
131
- <!-- Sidebar -->
132
- <FluentNavMenu Width="250">
133
- <FluentNavLink Icon="@(new Icons.Regular.Size20.Home())" Href="/" Match="NavLinkMatch.All">
134
- Dashboard
135
- </FluentNavLink>
136
- <FluentNavLink Icon="@(new Icons.Regular.Size20.People())" Href="/customers">
137
- Clientes
138
- </FluentNavLink>
139
- <FluentNavLink Icon="@(new Icons.Regular.Size20.Cart())" Href="/orders">
140
- Pedidos
141
- </FluentNavLink>
142
- <FluentNavLink Icon="@(new Icons.Regular.Size20.Chat())" Href="/ai-assistant">
143
- AI Assistant
144
- </FluentNavLink>
145
-
146
- <FluentDivider />
147
-
148
- <FluentNavLink Icon="@(new Icons.Regular.Size20.Settings())" Href="/settings">
149
- Configurações
150
- </FluentNavLink>
151
- </FluentNavMenu>
152
-
153
- <!-- Main Content -->
154
- <FluentMain>
155
- <FluentBodyContent>
156
- @Body
157
- </FluentBodyContent>
158
- </FluentMain>
159
- </FluentLayout>
160
-
161
- @code {
162
- private string _userName = "Usuário";
163
- private string _userAvatar = "";
164
- }
165
- ```
166
-
167
- ---
168
-
169
- ## 📋 Componentes Essenciais
170
-
171
- ### Data Grid
172
-
173
- ```razor
174
- @page "/customers"
175
-
176
- <FluentStack Orientation="Orientation.Vertical">
177
- <FluentStack Orientation="Orientation.Horizontal" HorizontalAlignment="HorizontalAlignment.SpaceBetween">
178
- <FluentLabel Typo="Typography.H4">Clientes</FluentLabel>
179
- <FluentButton Appearance="Appearance.Accent" IconStart="@(new Icons.Regular.Size20.Add())">
180
- Novo Cliente
181
- </FluentButton>
182
- </FluentStack>
183
-
184
- <FluentDataGrid Items="@_customers" GridTemplateColumns="1fr 2fr 2fr 1fr">
185
- <PropertyColumn Property="@(c => c.Id)" />
186
- <PropertyColumn Property="@(c => c.Name)" Title="Nome" />
187
- <PropertyColumn Property="@(c => c.Email)" />
188
- <TemplateColumn Title="Ações">
189
- <FluentButton Appearance="Appearance.Stealth" IconStart="@(new Icons.Regular.Size16.Edit())">
190
- Editar
191
- </FluentButton>
192
- </TemplateColumn>
193
- </FluentDataGrid>
194
- </FluentStack>
195
-
196
- @code {
197
- private IQueryable<Customer> _customers = new List<Customer>
198
- {
199
- new() { Id = 1, Name = "João Silva", Email = "joao@example.com" },
200
- new() { Id = 2, Name = "Maria Santos", Email = "maria@example.com" }
201
- }.AsQueryable();
202
- }
203
- ```
204
-
205
- ### Formulários
206
-
207
- ```razor
208
- @page "/customers/new"
209
-
210
- <EditForm Model="@_model" OnValidSubmit="HandleSubmit">
211
- <DataAnnotationsValidator />
212
-
213
- <FluentStack Orientation="Orientation.Vertical">
214
- <FluentLabel Typo="Typography.H4">Novo Cliente</FluentLabel>
215
-
216
- <FluentTextField @bind-Value="_model.Name" Label="Nome" Required />
217
- <FluentValidationMessage For="@(() => _model.Name)" />
218
-
219
- <FluentTextField @bind-Value="_model.Email" Label="Email" TextFieldType="TextFieldType.Email" Required />
220
- <FluentValidationMessage For="@(() => _model.Email)" />
221
-
222
- <FluentTextField @bind-Value="_model.Phone" Label="Telefone" />
223
-
224
- <FluentStack Orientation="Orientation.Horizontal">
225
- <FluentButton Type="ButtonType.Submit" Appearance="Appearance.Accent">
226
- Salvar
227
- </FluentButton>
228
- <FluentButton Appearance="Appearance.Neutral" OnClick="Cancel">
229
- Cancelar
230
- </FluentButton>
231
- </FluentStack>
232
- </FluentStack>
233
- </EditForm>
234
-
235
- @code {
236
- private CustomerFormModel _model = new();
237
-
238
- private async Task HandleSubmit()
239
- {
240
- // Salvar cliente
241
- }
242
-
243
- private void Cancel() => NavigationManager.NavigateTo("/customers");
244
- }
245
- ```
246
-
247
- ### Dialogs e Mensagens
248
-
249
- ```razor
250
- @inject IDialogService DialogService
251
- @inject IMessageService MessageService
252
-
253
- <FluentButton OnClick="ShowDialog">Abrir Dialog</FluentButton>
254
- <FluentButton OnClick="ShowMessage">Mostrar Mensagem</FluentButton>
255
-
256
- @code {
257
- private async Task ShowDialog()
258
- {
259
- var dialog = await DialogService.ShowDialogAsync<ConfirmDialog>(new DialogParameters
260
- {
261
- Title = "Confirmar ação",
262
- PrimaryAction = "Confirmar",
263
- SecondaryAction = "Cancelar"
264
- });
265
-
266
- var result = await dialog.Result;
267
- if (!result.Cancelled)
268
- {
269
- // Ação confirmada
270
- }
271
- }
272
-
273
- private void ShowMessage()
274
- {
275
- MessageService.ShowMessageBar(options =>
276
- {
277
- options.Intent = MessageIntent.Success;
278
- options.Title = "Sucesso!";
279
- options.Body = "Operação realizada com sucesso.";
280
- });
281
- }
282
- }
283
- ```
284
-
285
- ---
286
-
287
- ## 🤖 Componentes AI-Specific
288
-
289
- ### Chat Container
290
-
291
- ```razor
292
- @page "/ai-assistant"
293
- @inject IDocumentAssistantAgent Assistant
294
-
295
- <FluentStack Orientation="Orientation.Vertical" Style="height: 100vh;">
296
- <FluentLabel Typo="Typography.H4">AI Assistant</FluentLabel>
297
-
298
- <!-- Messages Area -->
299
- <FluentScrollArea Style="flex: 1; overflow-y: auto;">
300
- <FluentStack Orientation="Orientation.Vertical">
301
- @foreach (var message in _messages)
302
- {
303
- <FluentMessageBar Intent="@(message.IsUser ? MessageIntent.Info : MessageIntent.Success)">
304
- <FluentLabel Weight="FontWeight.Bold">
305
- @(message.IsUser ? "Você" : "AI Assistant")
306
- </FluentLabel>
307
- <FluentLabel>@message.Content</FluentLabel>
308
- </FluentMessageBar>
309
- }
310
-
311
- @if (_isTyping)
312
- {
313
- <FluentProgress />
314
- <FluentLabel Typo="Typography.Caption">AI está digitando...</FluentLabel>
315
- }
316
- </FluentStack>
317
- </FluentScrollArea>
318
-
319
- <!-- Input Area -->
320
- <FluentStack Orientation="Orientation.Horizontal">
321
- <FluentTextField @bind-Value="_userInput"
322
- Placeholder="Digite sua pergunta..."
323
- Style="flex: 1;"
324
- @onkeypress="HandleKeyPress" />
325
- <FluentButton Appearance="Appearance.Accent"
326
- IconStart="@(new Icons.Regular.Size20.Send())"
327
- OnClick="SendMessage"
328
- Disabled="@_isTyping">
329
- Enviar
330
- </FluentButton>
331
- </FluentStack>
332
- </FluentStack>
333
-
334
- @code {
335
- private List<ChatMessage> _messages = new();
336
- private string _userInput = "";
337
- private bool _isTyping;
338
-
339
- private async Task SendMessage()
340
- {
341
- if (string.IsNullOrWhiteSpace(_userInput)) return;
342
-
343
- // Adicionar mensagem do usuário
344
- _messages.Add(new ChatMessage { Content = _userInput, IsUser = true });
345
- var question = _userInput;
346
- _userInput = "";
347
- _isTyping = true;
348
-
349
- // Obter resposta do AI
350
- var response = await Assistant.AskQuestionAsync(question);
351
- _messages.Add(new ChatMessage { Content = response, IsUser = false });
352
-
353
- _isTyping = false;
354
- }
355
-
356
- private async Task HandleKeyPress(KeyboardEventArgs e)
357
- {
358
- if (e.Key == "Enter" && !e.ShiftKey)
359
- {
360
- await SendMessage();
361
- }
362
- }
363
-
364
- public class ChatMessage
365
- {
366
- public string Content { get; set; } = "";
367
- public bool IsUser { get; set; }
368
- }
369
- }
370
- ```
371
-
372
- ### Streaming Response
373
-
374
- ```razor
375
- @page "/ai-stream"
376
-
377
- <FluentStack Orientation="Orientation.Vertical">
378
- <FluentTextField @bind-Value="_prompt" Label="Prompt" />
379
- <FluentButton OnClick="GenerateStream">Gerar (Streaming)</FluentButton>
380
-
381
- <FluentCard>
382
- <FluentLabel>@_streamedContent</FluentLabel>
383
- @if (_isStreaming)
384
- {
385
- <FluentProgressRing />
386
- }
387
- </FluentCard>
388
- </FluentStack>
389
-
390
- @code {
391
- private string _prompt = "";
392
- private string _streamedContent = "";
393
- private bool _isStreaming;
394
-
395
- private async Task GenerateStream()
396
- {
397
- _streamedContent = "";
398
- _isStreaming = true;
399
-
400
- // Simular streaming (substituir com Agent Framework real)
401
- var words = "Esta é uma resposta simulada do AI assistant em streaming.".Split(' ');
402
- foreach (var word in words)
403
- {
404
- _streamedContent += word + " ";
405
- StateHasChanged();
406
- await Task.Delay(200);
407
- }
408
-
409
- _isStreaming = false;
410
- }
411
- }
412
- ```
413
-
414
- ---
415
-
416
- ## 🎨 Temas e Dark Mode
417
-
418
- ### Configurar Theme Provider
419
-
420
- ```razor
421
- <!-- App.razor -->
422
- <FluentDesignTheme @bind-Mode="@_theme"
423
- StorageName="theme-preference"
424
- OfficeColor="OfficeColor.Default" />
425
-
426
- <FluentLayout>
427
- <!-- Conteúdo -->
428
- </FluentLayout>
429
-
430
- @code {
431
- private DesignThemeModes _theme = DesignThemeModes.System;
432
- }
433
- ```
434
-
435
- ### Toggle Dark Mode
436
-
437
- ```razor
438
- <FluentSwitch @bind-Value="_isDarkMode"
439
- @bind-Value:after="ToggleTheme"
440
- Label="@(_isDarkMode ? "Dark Mode" : "Light Mode")" />
441
-
442
- @code {
443
- private bool _isDarkMode;
444
-
445
- private void ToggleTheme()
446
- {
447
- _theme = _isDarkMode ? DesignThemeModes.Dark : DesignThemeModes.Light;
448
- }
449
- }
450
- ```
451
-
452
- ---
453
-
454
- ## 🔄 Abordagem Híbrida (Fluent UI + MudBlazor)
455
-
456
- ### Quando Adicionar MudBlazor
457
-
458
- Use MudBlazor para:
459
- - **DataGrid complexo** - filtros avançados, agrupamento, export
460
- - **Charts** - MudChart para dashboards analytics
461
- - **Calendar/Scheduler** - se precisar de componentes avançados
462
-
463
- ### Setup Híbrido
464
-
465
- ```bash
466
- dotnet add package Microsoft.FluentUI.AspNetCore.Components
467
- dotnet add package MudBlazor
468
- ```
469
-
470
- ```csharp
471
- // Program.cs
472
- builder.Services.AddFluentUIComponents();
473
- builder.Services.AddMudServices();
474
- ```
475
-
476
- ```html
477
- <!-- App.razor -->
478
- <!-- Fluent UI CSS -->
479
- <link href="_content/Microsoft.FluentUI.AspNetCore.Components/Microsoft.FluentUI.AspNetCore.Components.min.css" rel="stylesheet" />
480
-
481
- <!-- MudBlazor CSS -->
482
- <link href="_content/MudBlazor/MudBlazor.min.css" rel="stylesheet" />
483
- ```
484
-
485
- ### Exemplo de Uso Combinado
486
-
487
- ```razor
488
- @* Layout com Fluent UI *@
489
- <FluentLayout>
490
- <FluentHeader>...</FluentHeader>
491
-
492
- <FluentMain>
493
- @* Grid complexo com MudBlazor *@
494
- <MudDataGrid T="Order"
495
- Items="@_orders"
496
- Filterable="true"
497
- Groupable="true"
498
- Dense="true">
499
- <Columns>
500
- <PropertyColumn Property="x => x.OrderNumber" Title="Número" />
501
- <PropertyColumn Property="x => x.Total" Title="Total" Format="C2" />
502
- </Columns>
503
- </MudDataGrid>
504
-
505
- @* Chat com Fluent UI *@
506
- <FluentMessageBar Intent="MessageIntent.Success">
507
- Pedido criado com sucesso!
508
- </FluentMessageBar>
509
- </FluentMain>
510
- </FluentLayout>
511
- ```
512
-
513
- ---
514
-
515
- ## 📊 Performance Tips
516
-
517
- ### Bundle Size
518
-
519
- ```xml
520
- <!-- .csproj -->
521
- <PropertyGroup>
522
- <!-- Trimming para reduzir bundle -->
523
- <PublishTrimmed>true</PublishTrimmed>
524
- <TrimMode>link</TrimMode>
525
- </PropertyGroup>
526
- ```
527
-
528
- ### Lazy Loading de Componentes
529
-
530
- ```razor
531
- @* Carregar MudBlazor só quando necessário *@
532
- @if (_showComplexGrid)
533
- {
534
- <MudDataGrid ... />
535
- }
536
- else
537
- {
538
- <FluentDataGrid ... />
539
- }
540
- ```
541
-
542
- ---
543
-
544
- ## ✅ Checklist de Implementação
545
-
546
- - [ ] Package `Microsoft.FluentUI.AspNetCore.Components` instalado
547
- - [ ] `AddFluentUIComponents()` no Program.cs
548
- - [ ] CSS e JS referenciados no App.razor
549
- - [ ] _Imports.razor atualizado
550
- - [ ] Layout principal criado com FluentLayout
551
- - [ ] Navegação configurada com FluentNavMenu
552
- - [ ] Theme provider configurado
553
- - [ ] Dark mode funcional
554
- - [ ] Componentes AI (chat) implementados se aplicável
555
- - [ ] (Opcional) MudBlazor adicionado para grids/charts complexos
556
-
557
- ---
558
-
559
- ## 🚫 O Que NÃO Fazer
560
-
561
- ❌ Misturar estilos - use Fluent UI OU MudBlazor consistentemente
562
- ❌ Importar todas as libs sem necessidade (bundle size)
563
- ❌ Ignorar acessibilidade (Fluent UI tem nativa)
564
- ❌ Criar componentes customizados sem checar se já existem
565
- ❌ Usar JavaScript customizado (Fluent UI tem tudo em C#)
566
-
567
- ---
568
-
569
- ## 📚 Recursos
570
-
571
- | Recurso | URL |
572
- |---------|-----|
573
- | Documentação Oficial | [fluentui-blazor.net](https://www.fluentui-blazor.net/) |
574
- | GitHub | [github.com/microsoft/fluentui-blazor](https://github.com/microsoft/fluentui-blazor) |
575
- | Exemplos | [fluentui-blazor.net/examples](https://www.fluentui-blazor.net/examples) |
576
- | Icons Explorer | [fluentui-blazor.net/icon-explorer](https://www.fluentui-blazor.net/icon-explorer) |
577
- | MudBlazor (complemento) | [mudblazor.com](https://mudblazor.com/) |
578
-
579
- ---
580
-
581
- ## 🎓 Comparativo Rápido
582
-
583
- | Feature | Fluent UI | MudBlazor | Recomendação |
584
- |---------|-----------|-----------|--------------|
585
- | AI Components | ✅ Nativo | ❌ Não | **Fluent UI** |
586
- | DataGrid | ⚠️ Básico | ✅ Avançado | **MudBlazor** |
587
- | Charts | ❌ Não | ✅ Sim | **MudBlazor** |
588
- | Performance | ✅ Leve | ⚠️ Pesado | **Fluent UI** |
589
- | Microsoft Integration | ✅ Nativo | ❌ Não | **Fluent UI** |
590
- | Templates Prontos | ⚠️ Poucos | ✅ Muitos | **MudBlazor** |
591
- | Futuro AI | ✅ Garantido | ❓ Incerto | **Fluent UI** |
592
-
593
- ---
594
-
595
- *MORPH-SPEC by Polymorphism Tech*