@polymorphism-tech/morph-spec 4.6.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 (239) hide show
  1. package/README.md +394 -700
  2. package/docs/ARCHITECTURE.md +331 -0
  3. package/docs/CHEATSHEET.md +221 -0
  4. package/docs/COMMAND-FLOWS.md +368 -0
  5. package/docs/QUICKSTART.md +212 -0
  6. package/docs/examples/order-management/contracts.cs +84 -0
  7. package/docs/examples/order-management/proposal.md +24 -0
  8. package/docs/examples/order-management/spec.md +162 -0
  9. package/docs/plans/2026-02-23-ddd-architecture-refactor.md +1153 -0
  10. package/docs/plans/2026-02-23-ddd-nextsteps.md +682 -0
  11. package/docs/plans/2026-02-23-infra-architect-refactor.md +437 -0
  12. package/docs/plans/2026-02-23-nextjs-code-review-design.md +156 -0
  13. package/docs/plans/2026-02-23-nextjs-code-review-impl.md +1254 -0
  14. package/docs/plans/2026-02-23-nextjs-standards-design.md +149 -0
  15. package/docs/plans/2026-02-23-nextjs-standards-impl.md +1846 -0
  16. package/framework/agents/README.md +14 -14
  17. package/framework/agents/architecture/standards-architect.md +159 -159
  18. package/framework/agents/frontend/nextjs-expert.md +87 -127
  19. package/framework/agents/infrastructure/azure-architect.md +147 -147
  20. package/framework/agents/infrastructure/infra-architect.md +45 -0
  21. package/framework/agents.json +1145 -278
  22. package/framework/rules/frontend-standards.md +0 -3
  23. package/framework/rules/nextjs-standards.md +17 -0
  24. package/framework/skills/level-0-meta/code-review-nextjs/SKILL.md +147 -0
  25. package/framework/skills/level-0-meta/code-review-nextjs/references/review-example-nextjs.md +254 -0
  26. package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +3 -3
  27. package/framework/skills/level-1-workflows/phase-design/SKILL.md +45 -9
  28. package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +38 -0
  29. package/framework/standards/STANDARDS.json +121 -0
  30. package/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
  31. package/framework/standards/architecture/ddd/complexity-levels.md +108 -0
  32. package/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
  33. package/framework/standards/frontend/nextjs/app-router.md +123 -0
  34. package/framework/standards/frontend/nextjs/components.md +132 -0
  35. package/framework/standards/frontend/nextjs/data-fetching.md +126 -0
  36. package/framework/standards/frontend/nextjs/forms.md +128 -0
  37. package/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
  38. package/framework/standards/frontend/nextjs/project-structure.md +102 -0
  39. package/framework/standards/frontend/nextjs/state-management.md +72 -0
  40. package/framework/standards/frontend/nextjs/testing.md +111 -0
  41. package/framework/templates/REGISTRY.json +538 -142
  42. package/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
  43. package/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
  44. package/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
  45. package/framework/templates/docs/spec.md +49 -0
  46. package/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
  47. package/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
  48. package/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
  49. package/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
  50. package/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
  51. package/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
  52. package/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
  53. package/framework/templates/project-structure/dotnet-ddd.md +70 -0
  54. package/framework/workflows/docs/enforcement-pipeline.md +2 -1
  55. package/package.json +1 -1
  56. package/scripts/scan-nextjs.mjs +169 -0
  57. package/src/commands/project/doctor.js +52 -1
  58. package/src/commands/project/init.js +15 -1
  59. package/src/commands/project/update.js +6 -1
  60. package/src/lib/standards/standards-context-injector.js +5 -0
  61. package/src/lib/validators/nextjs/index.js +6 -0
  62. package/src/lib/validators/nextjs/next-component-validator.js +181 -0
  63. package/src/lib/validators/validation-runner.js +5 -0
  64. package/src/utils/agents-installer.js +14 -2
  65. package/.morph/.morphversion +0 -5
  66. package/.morph/analytics/threads-log.jsonl +0 -6
  67. package/.morph/config/config.json +0 -8
  68. package/.morph/framework/agents.json +0 -948
  69. package/.morph/framework/standards/STANDARDS.json +0 -812
  70. package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
  71. package/.morph/framework/standards/ai-agents/production.md +0 -415
  72. package/.morph/framework/standards/ai-agents/setup.md +0 -418
  73. package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
  74. package/.morph/framework/standards/ai-agents/workflows.md +0 -354
  75. package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
  76. package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
  77. package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
  78. package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
  79. package/.morph/framework/standards/backend/api/rest.md +0 -492
  80. package/.morph/framework/standards/backend/api/validation.md +0 -88
  81. package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
  82. package/.morph/framework/standards/backend/database/ef-core.md +0 -199
  83. package/.morph/framework/standards/backend/database/migrations.md +0 -393
  84. package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
  85. package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
  86. package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
  87. package/.morph/framework/standards/backend/dotnet/async.md +0 -366
  88. package/.morph/framework/standards/backend/dotnet/core.md +0 -117
  89. package/.morph/framework/standards/backend/dotnet/di.md +0 -439
  90. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
  91. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
  92. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
  93. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
  94. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
  95. package/.morph/framework/standards/context/analytics.md +0 -96
  96. package/.morph/framework/standards/context/bundles.md +0 -110
  97. package/.morph/framework/standards/context/priming.md +0 -78
  98. package/.morph/framework/standards/core/architecture.md +0 -185
  99. package/.morph/framework/standards/core/coding.md +0 -214
  100. package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
  101. package/.morph/framework/standards/core/git.md +0 -185
  102. package/.morph/framework/standards/core/testing.md +0 -295
  103. package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
  104. package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
  105. package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
  106. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
  107. package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
  108. package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
  109. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
  110. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
  111. package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
  112. package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
  113. package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
  114. package/.morph/framework/standards/frontend/blazor/state.md +0 -191
  115. package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
  116. package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
  117. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -215
  118. package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
  119. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
  120. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
  121. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
  122. package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
  123. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
  124. package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
  125. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
  126. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
  127. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
  128. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
  129. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
  130. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
  131. package/.morph/framework/standards/integration/api/graphql.md +0 -91
  132. package/.morph/framework/standards/integration/api/grpc.md +0 -114
  133. package/.morph/framework/standards/integration/api/rest-design.md +0 -95
  134. package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
  135. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
  136. package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
  137. package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
  138. package/.morph/framework/standards/observability/logging.md +0 -131
  139. package/.morph/framework/standards/observability/metrics.md +0 -121
  140. package/.morph/framework/standards/observability/monitoring.md +0 -114
  141. package/.morph/framework/standards/observability/tracing.md +0 -132
  142. package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
  143. package/.morph/framework/standards/workflows/thread-management.md +0 -113
  144. package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
  145. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
  146. package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
  147. package/.morph/framework/templates/README.md +0 -814
  148. package/.morph/framework/templates/REGISTRY.json +0 -1492
  149. package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
  150. package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
  151. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
  152. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
  153. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
  154. package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
  155. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
  156. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  157. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
  158. package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
  159. package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
  160. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
  161. package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
  162. package/.morph/framework/templates/code/dotnet/test.cs +0 -239
  163. package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
  164. package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
  165. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
  166. package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
  167. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
  168. package/.morph/framework/templates/context/CONTEXT.md +0 -181
  169. package/.morph/framework/templates/docs/clarifications.md +0 -253
  170. package/.morph/framework/templates/docs/onboarding.md +0 -123
  171. package/.morph/framework/templates/docs/proposal.md +0 -182
  172. package/.morph/framework/templates/docs/schema-analysis.md +0 -119
  173. package/.morph/framework/templates/docs/spec.md +0 -149
  174. package/.morph/framework/templates/docs/ui-components.md +0 -124
  175. package/.morph/framework/templates/docs/ui-design-system.md +0 -76
  176. package/.morph/framework/templates/docs/ui-flows.md +0 -167
  177. package/.morph/framework/templates/docs/ui-mockups.md +0 -98
  178. package/.morph/framework/templates/docs/user-stories.md +0 -34
  179. package/.morph/framework/templates/examples/design-system-examples.md +0 -357
  180. package/.morph/framework/templates/examples/spec-examples.md +0 -90
  181. package/.morph/framework/templates/feature/decisions.md +0 -187
  182. package/.morph/framework/templates/feature/recap.md +0 -146
  183. package/.morph/framework/templates/feature/tasks.md +0 -199
  184. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
  185. package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
  186. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
  187. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
  188. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
  189. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
  190. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
  191. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
  192. package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
  193. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
  194. package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
  195. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
  196. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
  197. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
  198. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
  199. package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
  200. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
  201. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
  202. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
  203. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
  204. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
  205. package/.morph/framework/templates/infrastructure/github/README.md +0 -593
  206. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
  207. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
  208. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
  209. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
  210. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
  211. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
  212. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
  213. package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
  214. package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
  215. package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
  216. package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
  217. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
  218. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
  219. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
  220. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
  221. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
  222. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
  223. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
  224. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
  225. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
  226. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
  227. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
  228. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
  229. package/.morph/framework/templates/saas/subscription.cs +0 -347
  230. package/.morph/framework/templates/saas/tenant.cs +0 -338
  231. package/.morph/framework/templates/state.template.json +0 -17
  232. package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
  233. package/.morph/framework/templates/ui/MudTheme.cs +0 -281
  234. package/.morph/framework/templates/ui/design-system.css +0 -226
  235. package/.morph/logs/tool-failures.log +0 -7
  236. package/.morph/memory/pre-compact-2026-02-23T15-43-03-521Z.json +0 -16
  237. package/.morph/state.json +0 -48
  238. package/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  239. 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*