@polymorphism-tech/morph-spec 2.3.0 → 3.0.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 (166) hide show
  1. package/CLAUDE.md +446 -1730
  2. package/README.md +515 -516
  3. package/bin/morph-spec.js +366 -294
  4. package/bin/task-manager.js +429 -368
  5. package/bin/validate.js +369 -268
  6. package/content/.claude/commands/morph-apply.md +221 -158
  7. package/content/.claude/commands/morph-deploy.md +529 -0
  8. package/content/.claude/commands/morph-preflight.md +227 -0
  9. package/content/.claude/commands/morph-proposal.md +122 -101
  10. package/content/.claude/commands/morph-status.md +86 -86
  11. package/content/.claude/commands/morph-troubleshoot.md +122 -0
  12. package/content/.claude/skills/infra/azure-deploy-specialist.md +699 -0
  13. package/content/.claude/skills/level-0-meta/README.md +7 -0
  14. package/content/.claude/skills/level-0-meta/code-review.md +226 -0
  15. package/content/.claude/skills/level-0-meta/morph-checklist.md +117 -0
  16. package/content/.claude/skills/level-0-meta/simulation-checklist.md +77 -0
  17. package/content/.claude/skills/level-1-workflows/README.md +7 -0
  18. package/content/.claude/skills/level-1-workflows/morph-replicate.md +213 -0
  19. package/content/.claude/{commands/morph-clarify.md → skills/level-1-workflows/phase-clarify.md} +131 -184
  20. package/content/.claude/{commands/morph-design.md → skills/level-1-workflows/phase-design.md} +213 -275
  21. package/content/.claude/skills/level-1-workflows/phase-setup.md +106 -0
  22. package/content/.claude/skills/level-1-workflows/phase-tasks.md +164 -0
  23. package/content/.claude/{commands/morph-uiux.md → skills/level-1-workflows/phase-uiux.md} +169 -211
  24. package/content/.claude/skills/level-2-domains/README.md +14 -0
  25. package/content/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +192 -0
  26. package/content/.claude/skills/{specialists → level-2-domains/architecture}/po-pm-advisor.md +197 -197
  27. package/content/.claude/skills/level-2-domains/architecture/standards-architect.md +156 -0
  28. package/content/.claude/skills/level-2-domains/backend/dotnet-senior.md +287 -0
  29. package/content/.claude/skills/level-2-domains/backend/ef-modeler.md +113 -0
  30. package/content/.claude/skills/level-2-domains/backend/hangfire-orchestrator.md +126 -0
  31. package/content/.claude/skills/level-2-domains/backend/ms-agent-expert.md +109 -0
  32. package/content/.claude/skills/level-2-domains/frontend/blazor-builder.md +210 -0
  33. package/content/.claude/skills/level-2-domains/frontend/nextjs-expert.md +154 -0
  34. package/content/.claude/skills/level-2-domains/frontend/ui-ux-designer.md +191 -0
  35. package/content/.claude/skills/{specialists → level-2-domains/infrastructure}/azure-architect.md +142 -142
  36. package/content/.claude/skills/level-2-domains/infrastructure/bicep-architect.md +126 -0
  37. package/content/.claude/skills/level-2-domains/infrastructure/container-specialist.md +131 -0
  38. package/content/.claude/skills/level-2-domains/infrastructure/devops-engineer.md +119 -0
  39. package/content/.claude/skills/level-2-domains/integrations/asaas-financial.md +130 -0
  40. package/content/.claude/skills/level-2-domains/integrations/azure-identity.md +142 -0
  41. package/content/.claude/skills/level-2-domains/integrations/clerk-auth.md +108 -0
  42. package/content/.claude/skills/level-2-domains/integrations/resend-email.md +119 -0
  43. package/content/.claude/skills/level-2-domains/quality/code-analyzer.md +235 -0
  44. package/content/.claude/skills/level-2-domains/quality/testing-specialist.md +126 -0
  45. package/content/.claude/skills/level-3-technologies/README.md +7 -0
  46. package/content/.claude/skills/level-4-patterns/README.md +7 -0
  47. package/content/.claude/skills/specialists/prompt-engineer.md +189 -0
  48. package/content/.claude/skills/specialists/seo-growth-hacker.md +320 -0
  49. package/content/.morph/config/agents.json +762 -242
  50. package/content/.morph/config/config.template.json +122 -108
  51. package/content/.morph/docs/workflows/design-impl.md +37 -0
  52. package/content/.morph/docs/workflows/enforcement-pipeline.md +668 -0
  53. package/content/.morph/docs/workflows/fast-track.md +29 -0
  54. package/content/.morph/docs/workflows/full-morph.md +76 -0
  55. package/content/.morph/docs/workflows/standard.md +44 -0
  56. package/content/.morph/docs/workflows/ui-refresh.md +39 -0
  57. package/content/.morph/examples/scheduled-reports/decisions.md +158 -0
  58. package/content/.morph/examples/scheduled-reports/proposal.md +95 -0
  59. package/content/.morph/examples/scheduled-reports/spec.md +267 -0
  60. package/content/.morph/hooks/README.md +348 -239
  61. package/content/.morph/hooks/pre-commit-agents.sh +24 -24
  62. package/content/.morph/hooks/task-completed.js +73 -0
  63. package/content/.morph/hooks/teammate-idle.js +68 -0
  64. package/content/.morph/schemas/tasks.schema.json +220 -0
  65. package/content/.morph/standards/agent-framework-blazor-ui.md +359 -0
  66. package/content/.morph/standards/agent-framework-production.md +410 -0
  67. package/content/.morph/standards/agent-framework-setup.md +413 -453
  68. package/content/.morph/standards/agent-framework-workflows.md +349 -0
  69. package/content/.morph/standards/agent-teams-workflow.md +474 -0
  70. package/content/.morph/standards/architecture.md +325 -325
  71. package/content/.morph/standards/azure.md +605 -379
  72. package/content/.morph/standards/dotnet10-migration.md +520 -494
  73. package/content/.morph/templates/CONTEXT-FEATURE.md +276 -0
  74. package/content/.morph/templates/CONTEXT.md +170 -0
  75. package/content/.morph/templates/agent.cs +163 -172
  76. package/content/.morph/templates/clarify-questions.md +159 -0
  77. package/content/.morph/templates/contracts/Commands.cs +74 -0
  78. package/content/.morph/templates/contracts/Entities.cs +25 -0
  79. package/content/.morph/templates/contracts/Queries.cs +74 -0
  80. package/content/.morph/templates/contracts/README.md +74 -0
  81. package/content/.morph/templates/decisions.md +123 -106
  82. package/content/.morph/templates/infra/azure-pipelines-deploy.yml +480 -0
  83. package/content/.morph/templates/infra/deploy-checklist.md +426 -0
  84. package/content/.morph/templates/proposal.md +141 -155
  85. package/content/.morph/templates/recap.md +94 -105
  86. package/content/.morph/templates/simulation.md +353 -0
  87. package/content/.morph/templates/spec.md +149 -148
  88. package/content/.morph/templates/state.template.json +222 -222
  89. package/content/.morph/templates/tasks.md +257 -235
  90. package/content/.morph/templates/ui-components.md +362 -276
  91. package/content/CLAUDE.md +150 -442
  92. package/detectors/structure-detector.js +245 -250
  93. package/docs/README.md +144 -149
  94. package/docs/getting-started.md +301 -302
  95. package/docs/installation.md +361 -361
  96. package/docs/validation-checklist.md +265 -266
  97. package/package.json +80 -80
  98. package/src/commands/advance-phase.js +266 -0
  99. package/src/commands/analyze-blazor-concurrency.js +193 -0
  100. package/src/commands/deploy.js +780 -0
  101. package/src/commands/detect-agents.js +167 -0
  102. package/src/commands/doctor.js +356 -280
  103. package/src/commands/generate-context.js +40 -0
  104. package/src/commands/init.js +258 -245
  105. package/src/commands/lint-fluent.js +352 -0
  106. package/src/commands/rollback-phase.js +185 -0
  107. package/src/commands/session-summary.js +291 -0
  108. package/src/commands/task.js +78 -75
  109. package/src/commands/troubleshoot.js +222 -0
  110. package/src/commands/update.js +192 -159
  111. package/src/commands/validate-blazor-state.js +210 -0
  112. package/src/commands/validate-blazor.js +156 -0
  113. package/src/commands/validate-css.js +84 -0
  114. package/src/commands/validate-phase.js +221 -0
  115. package/src/lib/blazor-concurrency-analyzer.js +288 -0
  116. package/src/lib/blazor-state-validator.js +291 -0
  117. package/src/lib/blazor-validator.js +374 -0
  118. package/src/lib/complexity-analyzer.js +441 -292
  119. package/src/lib/context-generator.js +513 -0
  120. package/src/lib/continuous-validator.js +421 -440
  121. package/src/lib/css-validator.js +352 -0
  122. package/src/lib/decision-constraint-loader.js +109 -0
  123. package/src/lib/design-system-detector.js +187 -0
  124. package/src/lib/design-system-scaffolder.js +299 -0
  125. package/src/lib/hook-executor.js +256 -0
  126. package/src/lib/recap-generator.js +205 -0
  127. package/src/lib/spec-validator.js +258 -0
  128. package/src/lib/standards-context-injector.js +287 -0
  129. package/src/lib/state-manager.js +397 -340
  130. package/src/lib/team-orchestrator.js +322 -0
  131. package/src/lib/troubleshoot-grep.js +194 -0
  132. package/src/lib/troubleshoot-index.js +144 -0
  133. package/src/lib/validation-runner.js +283 -0
  134. package/src/lib/validators/contract-compliance-validator.js +273 -0
  135. package/src/lib/validators/design-system-validator.js +231 -0
  136. package/src/utils/file-copier.js +187 -139
  137. package/content/.claude/commands/morph-costs.md +0 -206
  138. package/content/.claude/commands/morph-setup.md +0 -100
  139. package/content/.claude/commands/morph-tasks.md +0 -319
  140. package/content/.claude/skills/infra/bicep-architect.md +0 -419
  141. package/content/.claude/skills/infra/container-specialist.md +0 -437
  142. package/content/.claude/skills/infra/devops-engineer.md +0 -405
  143. package/content/.claude/skills/integrations/asaas-financial.md +0 -333
  144. package/content/.claude/skills/integrations/azure-identity.md +0 -309
  145. package/content/.claude/skills/integrations/clerk-auth.md +0 -290
  146. package/content/.claude/skills/specialists/ai-system-architect.md +0 -604
  147. package/content/.claude/skills/specialists/cost-guardian.md +0 -110
  148. package/content/.claude/skills/specialists/ef-modeler.md +0 -211
  149. package/content/.claude/skills/specialists/hangfire-orchestrator.md +0 -255
  150. package/content/.claude/skills/specialists/ms-agent-expert.md +0 -263
  151. package/content/.claude/skills/specialists/standards-architect.md +0 -78
  152. package/content/.claude/skills/specialists/ui-ux-designer.md +0 -1100
  153. package/content/.claude/skills/stacks/dotnet-blazor.md +0 -606
  154. package/content/.claude/skills/stacks/dotnet-nextjs.md +0 -402
  155. package/content/.claude/skills/stacks/shopify.md +0 -445
  156. package/content/.morph/config/azure-pricing.json +0 -70
  157. package/content/.morph/config/azure-pricing.schema.json +0 -50
  158. package/content/.morph/hooks/pre-commit-costs.sh +0 -91
  159. package/docs/api/cost-calculator.js.html +0 -513
  160. package/docs/api/design-system-generator.js.html +0 -382
  161. package/docs/api/global.html +0 -5263
  162. package/docs/api/index.html +0 -96
  163. package/docs/api/state-manager.js.html +0 -423
  164. package/src/commands/cost.js +0 -181
  165. package/src/commands/update-pricing.js +0 -206
  166. package/src/lib/cost-calculator.js +0 -429
@@ -0,0 +1,164 @@
1
+ # MORPH Tasks - FASE 4
2
+
3
+ > INTERNAL: Workflow skill used by /morph-proposal during automated phase orchestration. Not a user command.
4
+
5
+ Quebre a especificação em tasks executáveis, defina ordem de execução e estabeleça checkpoints.
6
+
7
+ ## Pré-requisitos
8
+
9
+ - [ ] FASE 3 (Clarify) concluída
10
+ - [ ] `spec.md` atualizado com clarificações
11
+ - [ ] Todos os edge cases documentados
12
+
13
+ ## Workflow
14
+
15
+ ### Passo 1: Analisar Spec
16
+
17
+ Leia `.morph/project/outputs/{feature}/spec.md` e identifique:
18
+
19
+ 1. **Requisitos funcionais** (FR001, FR002, ...)
20
+ 2. **Componentes técnicos** (Entities, Services, Controllers, Pages)
21
+ 3. **Infraestrutura** (Bicep, migrations, configs)
22
+ 4. **Testes** (Unit tests, integration tests)
23
+
24
+ ### Passo 2: Quebrar em Tasks
25
+
26
+ Crie tasks no formato **T{NNN}** seguindo ordem lógica de implementação.
27
+
28
+ #### 2.1. Estrutura de Task
29
+
30
+ ```json
31
+ {
32
+ "id": "T001",
33
+ "title": "Criar Entity {Nome}",
34
+ "description": "Implementar entity {Nome} com propriedades X, Y, Z seguindo padrões EF Core",
35
+ "category": "domain",
36
+ "dependencies": [],
37
+ "estimatedMinutes": 30,
38
+ "status": "pending",
39
+ "specSections": ["## Domain Model", "## Business Rules"],
40
+ "contractInterfaces": ["I{Nome}Repository"],
41
+ "files": [
42
+ "Domain/Entities/{Nome}.cs",
43
+ "Infrastructure/Data/Configurations/{Nome}Configuration.cs"
44
+ ]
45
+ }
46
+ ```
47
+
48
+ #### 2.2. Categorias de Tasks
49
+
50
+ | Categoria | Descrição | Exemplos |
51
+ |-----------|-----------|----------|
52
+ | **domain** | Entities, Value Objects, Enums | Entity, DomainException |
53
+ | **application** | Services, DTOs, Interfaces | Service, Validator, Mapper |
54
+ | **infrastructure** | DbContext, Repositories, External APIs | EF Config, Repository impl |
55
+ | **presentation** | Controllers, Pages, Components | API endpoint, Blazor page |
56
+ | **tests** | Unit tests, Integration tests | Service tests, API tests |
57
+ | **infra** | Bicep, Migrations, Scripts | Azure resources, DB migration |
58
+ | **docs** | README, API docs, Swagger | OpenAPI spec, README update |
59
+
60
+ #### 2.3. Ordem de Implementação
61
+
62
+ **Bottom-up approach:**
63
+ ```
64
+ 1. Domain (Entities, Enums, Value Objects)
65
+
66
+ 2. Infrastructure (Repositories, DbContext configs)
67
+
68
+ 3. Application (Services, DTOs, Business logic)
69
+
70
+ 4. Presentation (Controllers, Pages, Components)
71
+
72
+ 5. Tests (Unit → Integration)
73
+
74
+ 6. Infra (Bicep, Migrations, Deploy scripts)
75
+
76
+ 7. Docs (README, Swagger, Comments)
77
+ ```
78
+
79
+ ### Passo 3: Definir Dependências
80
+
81
+ Para cada task, especifique dependências:
82
+
83
+ ```json
84
+ {
85
+ "id": "T005",
86
+ "title": "Criar {Nome}Service",
87
+ "dependencies": ["T001", "T002"],
88
+ "status": "pending"
89
+ }
90
+ ```
91
+
92
+ **Regra:** Task só pode ser executada quando todas as dependências estão `completed`.
93
+
94
+ ### Passo 4: Estabelecer Checkpoints
95
+
96
+ Defina checkpoints a cada **3 tasks** ou **marcos significativos**:
97
+
98
+ ```json
99
+ {
100
+ "id": "CHECKPOINT_001",
101
+ "title": "Domain Layer Completo",
102
+ "afterTasks": ["T001", "T002", "T003"],
103
+ "validations": [
104
+ "Todas as entities criadas",
105
+ "Migrations aplicadas",
106
+ "Testes de domain passando"
107
+ ]
108
+ }
109
+ ```
110
+
111
+ ### Passo 5: Estimar Esforço
112
+
113
+ Para cada task, estime tempo em minutos:
114
+
115
+ | Complexidade | Tempo Estimado |
116
+ |--------------|----------------|
117
+ | Trivial (CRUD básico) | 15-30 min |
118
+ | Simples (Service, Controller) | 30-60 min |
119
+ | Média (Business logic, validações) | 60-120 min |
120
+ | Complexa (Integrações, AI) | 120-240 min |
121
+
122
+ ### Passo 6: Gerar `tasks.json`
123
+
124
+ Crie `.morph/project/outputs/{feature}/tasks.json` com a estrutura completa de tasks, checkpoints e estimativas.
125
+
126
+ ### Passo 7: Incluir Tasks de IaC (se necessário)
127
+
128
+ Se houver recursos Azure, adicionar tasks de Bicep e migrations.
129
+
130
+ ### Passo 8: Atualizar State
131
+
132
+ ```bash
133
+ npx morph-spec state set {feature-name} phase tasks
134
+ npx morph-spec state set {feature-name} tasks.total {N}
135
+ npx morph-spec state mark-output {feature-name} tasks
136
+ ```
137
+
138
+ ## Outputs Gerados
139
+
140
+ - `.morph/project/outputs/{feature}/tasks.json` - Breakdown completo de tasks
141
+
142
+ ## PAUSA OBRIGATÓRIA
143
+
144
+ Apresente ao usuário 3 ações sugeridas:
145
+
146
+ 1. **Aprovar breakdown e iniciar implementação**
147
+ 2. **Repriorizar tasks** - Mudar ordem de execução
148
+ 3. **Adicionar/remover tasks** - Ajustar escopo
149
+
150
+ ## Critérios de Avanço
151
+
152
+ - [x] `tasks.json` criado com todas as tasks
153
+ - [x] Tasks categorizadas corretamente
154
+ - [x] Dependências mapeadas
155
+ - [x] Checkpoints definidos (a cada 3 tasks)
156
+ - [x] Esforço estimado por task
157
+ - [x] Ordem de execução clara
158
+ - [x] Tasks de IaC incluídas (se aplicável)
159
+ - [x] State atualizado com total de tasks
160
+ - [x] Usuário aprovou breakdown
161
+
162
+ ---
163
+
164
+ Após aprovação: "Planejamento completo! Execute `/morph-apply {feature}` para iniciar implementação."
@@ -1,211 +1,169 @@
1
- # MORPH UI/UX Design - FASE 1.5
2
-
3
- Fase obrigatória para features com front-end. Coleta requisitos de UI/UX, gera wireframes, specs de componentes e fluxos de usuário.
4
-
5
- ## Uso
6
-
7
- ```
8
- /morph-uiux {feature-name}
9
- ```
10
-
11
- ## Pré-requisitos
12
-
13
- - [ ] FASE 1 (Setup) concluída
14
- - [ ] Feature tem keywords de UI detectadas (blazor, ui, component, page, dashboard, wizard, form, chart)
15
- - [ ] `uiux-designer` agent ativado
16
-
17
- ## Workflow
18
-
19
- ### Passo 1: Detectar Se Fase É Necessária
20
-
21
- Verifique se agentes ativos incluem `uiux-designer`:
22
-
23
- ```bash
24
- node bin/state-manager.js get {feature-name}
25
- ```
26
-
27
- Se `uiux-designer` NÃO estiver nos `activeAgents`, pule esta fase e vá para `/morph-design`.
28
-
29
- ### Passo 2: Coletar Input do Usuário
30
-
31
- **SEMPRE perguntar ao usuário PRIMEIRO:**
32
-
33
- 1. **Layout e estilo**:
34
- - Você tem alguma ideia de layout em mente?
35
- - Tem alguma referência visual? (sites, apps, screenshots)
36
- - Como imagina o fluxo do usuário?
37
-
38
- 2. **Componentes e interações**:
39
- - Quais os principais componentes desta tela/página?
40
- - Quais estados precisam ser considerados? (loading, error, empty, success)
41
-
42
- 3. **Imagens de referência**:
43
- - Tem imagens de exemplo que eu possa analisar?
44
- - Se SIM: use Read tool para ler screenshots e extrair padrões
45
-
46
- ### Passo 3: Decidir Biblioteca UI
47
-
48
- Escolha entre **Fluent UI Blazor** (recomendado para AI-first) ou **MudBlazor** (componentes complexos):
49
-
50
- **Critérios:**
51
- - Fluent UI: Para dashboards, forms simples, AI components, Microsoft design language
52
- - MudBlazor: Para data grids avançadas, charts complexos, material design
53
-
54
- **Documente a decisão:**
55
- ```bash
56
- # Adicionar ADR em decisions.md
57
- echo "## ADR: UI Library Choice
58
-
59
- Decision: [Fluent UI / MudBlazor]
60
-
61
- Rationale:
62
- - {Justificativa baseada nos requisitos}
63
-
64
- Date: $(date +%Y-%m-%d)" >> .morph/project/outputs/{feature}/decisions.md
65
- ```
66
-
67
- ### Passo 4: Gerar Deliverables
68
-
69
- Crie os seguintes arquivos em `.morph/project/outputs/{feature}/`:
70
-
71
- #### 4.1. `ui-design-system.md`
72
-
73
- Design system com:
74
- - Paleta de cores (primary, secondary, accent, semantic)
75
- - Tipografia (heading scales, body text, code)
76
- - Spacing e layout (grid, margins, paddings)
77
- - Componentes base (buttons, inputs, cards)
78
-
79
- #### 4.2. `ui-mockups.md`
80
-
81
- Wireframes ASCII + descrições:
82
- - Layout geral de cada tela/página
83
- - Posicionamento de componentes
84
- - Responsividade (desktop, tablet, mobile)
85
- - Estados (loading, error, empty, success)
86
-
87
- Exemplo:
88
- ```
89
- ┌─────────────────────────────────────────┐
90
- Header [🔔] [👤] │
91
- ├─────────────────────────────────────────┤
92
- ┌─────────┐ │
93
- Sidebar │ Main Content Area │
94
- │ │ Menu │ ┌─────────────────────┐ │
95
- │ │ │ Dashboard Card │ │
96
- │ │ • Home │ │ - Chart │ │
97
- Data │ │ - Metrics │ │
98
- └─────────┘ └─────────────────────┘ │
99
- └─────────────────────────────────────────┘
100
- ```
101
-
102
- #### 4.3. `ui-components.md`
103
-
104
- Specs técnicas de componentes Fluent UI/MudBlazor:
105
- - Componente a usar (FluentButton, MudDataGrid, etc.)
106
- - Props e configurações
107
- - Eventos e bindings
108
- - Validações e estados
109
-
110
- Exemplo:
111
- ```markdown
112
- ### DashboardCard Component
113
-
114
- **Library:** FluentCard
115
- **Props:**
116
- - Title: string
117
- - Subtitle: string (optional)
118
- - Loading: bool
119
-
120
- **Events:**
121
- - OnRefresh: EventCallback
122
-
123
- **Variants:**
124
- - Default (outline)
125
- - Filled (accent color)
126
- - Error (danger color)
127
- ```
128
-
129
- #### 4.4. `ui-flows.md`
130
-
131
- Fluxos de usuário completos:
132
- - User stories
133
- - Diagramas de fluxo (texto/ASCII)
134
- - Edge cases (o que acontece se...?)
135
- - Validações e feedback
136
-
137
- Exemplo:
138
- ```
139
- ## Fluxo: Adicionar Item
140
-
141
- 1. User clica "Adicionar Item"
142
- 2. Modal abre com form
143
- - Loading: Skeleton placeholders
144
- - Error: Toast notification
145
- 3. User preenche campos
146
- - Validação em tempo real
147
- - Campos required marcados com *
148
- 4. User clica "Salvar"
149
- - Success: Modal fecha + toast "Item adicionado"
150
- - Error: Modal permanece + mensagem de erro destacada
151
- ```
152
-
153
- ### Passo 5: Validar Acessibilidade e Responsividade
154
-
155
- Documente nos arquivos UI:
156
- - **WCAG 2.1 Level AA** compliance
157
- - Contraste de cores adequado
158
- - Labels acessíveis para screen readers
159
- - Navegação por teclado
160
- - **Responsive breakpoints**
161
- - Desktop (>1200px)
162
- - Tablet (768px - 1199px)
163
- - Mobile (<768px)
164
-
165
- ### Passo 6: Atualizar State
166
-
167
- ```bash
168
- # Marcar fase como uiux-design
169
- node bin/state-manager.js set {feature-name} phase uiux-design
170
-
171
- # Marcar outputs criados
172
- node bin/state-manager.js mark-output {feature-name} ui-design-system
173
- node bin/state-manager.js mark-output {feature-name} ui-mockups
174
- node bin/state-manager.js mark-output {feature-name} ui-components
175
- node bin/state-manager.js mark-output {feature-name} ui-flows
176
- ```
177
-
178
- ## Outputs Gerados
179
-
180
- - `.morph/project/outputs/{feature}/ui-design-system.md`
181
- - `.morph/project/outputs/{feature}/ui-mockups.md`
182
- - `.morph/project/outputs/{feature}/ui-components.md`
183
- - `.morph/project/outputs/{feature}/ui-flows.md`
184
- - `.morph/project/outputs/{feature}/decisions.md` (atualizado com ADR UI library)
185
-
186
- ## ⛔ PAUSA OBRIGATÓRIA
187
-
188
- Apresente ao usuário 3 ações sugeridas:
189
-
190
- 1. ✅ **Aprovar UI/UX e prosseguir para design técnico**
191
- Continuar para `/morph-design` (FASE 2)
192
-
193
- 2. 🎨 **Ajustar wireframes/componentes de telas específicas**
194
- Revisar mockups ou adicionar mais detalhes
195
-
196
- 3. 🔄 **Revisar biblioteca UI escolhida (Fluent UI ↔ MudBlazor)**
197
- Mudar decisão se justificado
198
-
199
- ## Critérios de Avanço
200
-
201
- - [x] Input do usuário coletado (layout, referências)
202
- - [x] Biblioteca UI escolhida e justificada (ADR)
203
- - [x] 4 deliverables criados (design-system, mockups, components, flows)
204
- - [x] Acessibilidade WCAG 2.1 documentada
205
- - [x] Responsividade especificada
206
- - [x] State atualizado
207
- - [x] Usuário aprovou UI/UX
208
-
209
- ---
210
-
211
- **Feature:** $ARGUMENTS
1
+ # MORPH UI/UX Design - FASE 1.5
2
+
3
+ > INTERNAL: Workflow skill used by /morph-proposal during automated phase orchestration. Not a user command.
4
+
5
+ Fase condicional para features com front-end. Coleta requisitos de UI/UX, gera wireframes, specs de componentes e fluxos de usuário.
6
+
7
+ ## Pré-requisitos
8
+
9
+ - [ ] FASE 1 (Setup) concluída
10
+ - [ ] Feature tem keywords de UI detectadas (blazor, ui, component, page, dashboard, wizard, form, chart)
11
+ - [ ] `uiux-designer` agent ativado
12
+
13
+ ## Workflow
14
+
15
+ ### Passo 0: Verificar Design System Existe
16
+
17
+ **CRITICAL:** Antes de iniciar a FASE UI/UX, verifique se um design system existe:
18
+
19
+ ```bash
20
+ npx morph-spec detect-agents "{feature description}"
21
+ ```
22
+
23
+ Se nenhum design system for detectado (verificar output):
24
+
25
+ 1. **Opção A - Scaffold automático:**
26
+ - O sistema criará automaticamente um design system ao avançar para implementação
27
+ - Você pode gerar manualmente agora: `npx morph-spec generate design-system`
28
+
29
+ 2. **Opção B - Criar manualmente:**
30
+ - Crie `.morph/project/design-system.md` (project-level, compartilhado)
31
+ - Ou `.morph/project/outputs/{feature}/ui-design-system.md` (feature-specific)
32
+
33
+ 3. **Opção C - Scan existing CSS:**
34
+ - Se o projeto já tem CSS com variáveis: `npx morph-spec generate design-system --scan`
35
+
36
+ **⚠️ IMPORTANTE:**
37
+ - Design system é **obrigatório** para features UI
38
+ - Gate automático bloqueará implementação (FASE 5) se design system não existir
39
+ - Melhor criar agora para garantir consistência visual
40
+
41
+ ### Passo 1: Detectar Se Fase É Necessária
42
+
43
+ Verifique se agentes ativos incluem `uiux-designer`:
44
+
45
+ ```bash
46
+ npx morph-spec state get {feature-name}
47
+ ```
48
+
49
+ Se `uiux-designer` NÃO estiver nos `activeAgents`, pule esta fase e continue para FASE 2 (Design).
50
+
51
+ ### Passo 2: Coletar Input do Usuário
52
+
53
+ **SEMPRE perguntar ao usuário PRIMEIRO:**
54
+
55
+ 1. **Layout e estilo**:
56
+ - Você tem alguma ideia de layout em mente?
57
+ - Tem alguma referência visual? (sites, apps, screenshots)
58
+ - Como imagina o fluxo do usuário?
59
+
60
+ 2. **Componentes e interações**:
61
+ - Quais os principais componentes desta tela/página?
62
+ - Quais estados precisam ser considerados? (loading, error, empty, success)
63
+
64
+ 3. **Imagens de referência**:
65
+ - Tem imagens de exemplo que eu possa analisar?
66
+ - Se SIM: use Read tool para ler screenshots e extrair padrões
67
+
68
+ ### Passo 3: Decidir Biblioteca UI
69
+
70
+ Escolha entre **Fluent UI Blazor** (recomendado para AI-first) ou **MudBlazor** (componentes complexos):
71
+
72
+ **Critérios:**
73
+ - Fluent UI: Para dashboards, forms simples, AI components, Microsoft design language
74
+ - MudBlazor: Para data grids avançadas, charts complexos, material design
75
+
76
+ **Documente a decisão em `decisions.md`.**
77
+
78
+ ### Passo 4: Gerar Deliverables
79
+
80
+ Crie os seguintes arquivos em `.morph/project/outputs/{feature}/`:
81
+
82
+ #### 4.1. `ui-design-system.md`
83
+
84
+ **Se design system project-level existe (`.morph/project/design-system.md`):**
85
+ - Referencie-o nos specs: "Uses project design system at .morph/project/design-system.md"
86
+ - Crie `ui-design-system.md` apenas se houver cores/componentes **específicos** da feature
87
+
88
+ **Se não existe:**
89
+ - Crie design system feature-level completo com:
90
+ - Paleta de cores (primary, secondary, accent, semantic)
91
+ - Tipografia (heading scales, body text, code)
92
+ - Spacing e layout (grid, margins, paddings)
93
+ - Componentes base (buttons, inputs, cards)
94
+
95
+ #### 4.2. `ui-mockups.md`
96
+
97
+ Wireframes ASCII + descrições:
98
+ - Layout geral de cada tela/página
99
+ - Posicionamento de componentes
100
+ - Responsividade (desktop, tablet, mobile)
101
+ - Estados (loading, error, empty, success)
102
+
103
+ #### 4.3. `ui-components.md`
104
+
105
+ Specs técnicas de componentes Fluent UI/MudBlazor:
106
+ - Componente a usar (FluentButton, MudDataGrid, etc.)
107
+ - Props e configurações
108
+ - Eventos e bindings
109
+ - Validações e estados
110
+
111
+ #### 4.4. `ui-flows.md`
112
+
113
+ Fluxos de usuário completos:
114
+ - User stories
115
+ - Diagramas de fluxo (texto/ASCII)
116
+ - Edge cases (o que acontece se...?)
117
+ - Validações e feedback
118
+
119
+ ### Passo 5: Validar Acessibilidade e Responsividade
120
+
121
+ Documente nos arquivos UI:
122
+ - **WCAG 2.1 Level AA** compliance
123
+ - Contraste de cores adequado
124
+ - Labels acessíveis para screen readers
125
+ - Navegação por teclado
126
+ - **Responsive breakpoints**
127
+ - Desktop (>1200px)
128
+ - Tablet (768px - 1199px)
129
+ - Mobile (<768px)
130
+
131
+ ### Passo 6: Atualizar State
132
+
133
+ ```bash
134
+ npx morph-spec state set {feature-name} phase uiux-design
135
+ npx morph-spec state mark-output {feature-name} ui-design-system
136
+ npx morph-spec state mark-output {feature-name} ui-mockups
137
+ npx morph-spec state mark-output {feature-name} ui-components
138
+ npx morph-spec state mark-output {feature-name} ui-flows
139
+ ```
140
+
141
+ ## Outputs Gerados
142
+
143
+ - `.morph/project/outputs/{feature}/ui-design-system.md`
144
+ - `.morph/project/outputs/{feature}/ui-mockups.md`
145
+ - `.morph/project/outputs/{feature}/ui-components.md`
146
+ - `.morph/project/outputs/{feature}/ui-flows.md`
147
+ - `.morph/project/outputs/{feature}/decisions.md` (atualizado com ADR UI library)
148
+
149
+ ## PAUSA OBRIGATÓRIA
150
+
151
+ Apresente ao usuário 3 ações sugeridas:
152
+
153
+ 1. **Aprovar UI/UX e prosseguir para design técnico**
154
+ 2. **Ajustar wireframes/componentes de telas específicas**
155
+ 3. **Revisar biblioteca UI escolhida (Fluent UI / MudBlazor)**
156
+
157
+ ## Critérios de Avanço
158
+
159
+ - [x] Input do usuário coletado (layout, referências)
160
+ - [x] Biblioteca UI escolhida e justificada (ADR)
161
+ - [x] 4 deliverables criados (design-system, mockups, components, flows)
162
+ - [x] Acessibilidade WCAG 2.1 documentada
163
+ - [x] Responsividade especificada
164
+ - [x] State atualizado
165
+ - [x] Usuário aprovou UI/UX
166
+
167
+ ---
168
+
169
+ Continuar automaticamente para FASE 2 (Design) após aprovação.
@@ -0,0 +1,14 @@
1
+ # Level 2: Domains
2
+
3
+ Domain expertise skills organized by squad.
4
+
5
+ **Purpose:** Skills that provide deep domain knowledge (backend, frontend, infra, quality, ai-agents, integrations).
6
+
7
+ **Squads:**
8
+ - backend/ - Backend Squad (led by dotnet-senior)
9
+ - frontend/ - Frontend Squad (led by ui-designer)
10
+ - infrastructure/ - Infrastructure Squad (led by azure-architect)
11
+ - quality/ - Quality Squad (coordinated by standards-architect)
12
+ - ai-agents/ - AI/Agent specialists
13
+ - integrations/ - External integration specialists
14
+ - architecture/ - Architecture and planning