claude-code-workflow 7.2.29 → 7.3.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 (169) hide show
  1. package/.ccw/workflows/cli-templates/schemas/plan-overview-base-schema.json +2 -2
  2. package/.ccw/workflows/cli-templates/schemas/task-schema.json +14 -7
  3. package/.claude/agents/action-planning-agent.md +7 -4
  4. package/.claude/agents/cli-explore-agent.md +77 -63
  5. package/.claude/agents/cli-lite-planning-agent.md +11 -10
  6. package/.claude/agents/issue-plan-agent.md +421 -426
  7. package/.claude/commands/workflow/spec/setup.md +1 -1
  8. package/.claude/commands/workflow-skill.md +130 -0
  9. package/.claude/skills/ccw-chain/SKILL.md +92 -0
  10. package/.claude/skills/ccw-chain/chains/ccw-cycle.json +31 -0
  11. package/.claude/skills/ccw-chain/chains/ccw-exploration.json +58 -0
  12. package/.claude/skills/ccw-chain/chains/ccw-issue.json +44 -0
  13. package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +71 -0
  14. package/.claude/skills/ccw-chain/chains/ccw-main.json +65 -0
  15. package/.claude/skills/ccw-chain/chains/ccw-standard.json +51 -0
  16. package/.claude/skills/ccw-chain/chains/ccw-team.json +15 -0
  17. package/.claude/skills/ccw-chain/chains/ccw-with-file.json +47 -0
  18. package/.claude/skills/ccw-chain/specs/auto-mode.md +47 -0
  19. package/.claude/skills/chain-loader/SKILL.md +78 -0
  20. package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -0
  21. package/.claude/skills/chain-loader/phases/02-design-graph.md +73 -0
  22. package/.claude/skills/chain-loader/phases/03-generate-validate.md +75 -0
  23. package/.claude/skills/chain-loader/specs/chain-schema.md +126 -0
  24. package/.claude/skills/chain-loader/specs/design-patterns.md +99 -0
  25. package/.claude/skills/chain-loader/templates/chain-json.md +63 -0
  26. package/.claude/skills/review-cycle/phases/review-module.md +764 -764
  27. package/.claude/skills/review-cycle/phases/review-session.md +775 -775
  28. package/.claude/skills/workflow-multi-cli-plan/SKILL.md +2 -2
  29. package/.claude/skills/workflow-plan/SKILL.md +1 -0
  30. package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
  31. package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
  32. package/.claude/skills/workflow-plan/phases/03-conflict-resolution.md +422 -422
  33. package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
  34. package/.claude/skills/workflow-plan/phases/05-plan-verify.md +395 -395
  35. package/.claude/skills/workflow-tdd-plan/phases/02-context-gathering.md +407 -407
  36. package/.claude/skills/workflow-tdd-plan/phases/04-conflict-resolution.md +426 -426
  37. package/.claude/skills/workflow-test-fix/phases/02-test-context-gather.md +493 -493
  38. package/.codex/skills/analyze-with-file/SKILL.md +383 -134
  39. package/.codex/skills/brainstorm/SKILL.md +3 -3
  40. package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
  41. package/.codex/skills/clean/SKILL.md +1 -1
  42. package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
  43. package/.codex/skills/investigate/orchestrator.md +24 -0
  44. package/.codex/skills/issue-discover/SKILL.md +374 -361
  45. package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
  46. package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
  47. package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
  48. package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
  49. package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
  50. package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
  51. package/.codex/skills/review-cycle/SKILL.md +31 -12
  52. package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
  53. package/.codex/skills/security-audit/orchestrator.md +29 -0
  54. package/.codex/skills/session-sync/SKILL.md +1 -1
  55. package/.codex/skills/ship/orchestrator.md +24 -0
  56. package/.codex/skills/spec-add/SKILL.md +5 -5
  57. package/.codex/skills/spec-generator/SKILL.md +33 -2
  58. package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
  59. package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
  60. package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
  61. package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
  62. package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
  63. package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
  64. package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
  65. package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
  66. package/.codex/skills/spec-setup/SKILL.md +669 -669
  67. package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
  68. package/.codex/skills/team-brainstorm/SKILL.md +259 -259
  69. package/.codex/skills/team-coordinate/SKILL.md +359 -359
  70. package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
  71. package/.codex/skills/team-designer/SKILL.md +27 -1
  72. package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
  73. package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
  74. package/.codex/skills/team-designer/phases/04-validation.md +1 -1
  75. package/.codex/skills/team-executor/SKILL.md +218 -218
  76. package/.codex/skills/team-frontend/SKILL.md +227 -227
  77. package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
  78. package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
  79. package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
  80. package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
  81. package/.codex/skills/team-issue/SKILL.md +269 -269
  82. package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
  83. package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
  84. package/.codex/skills/team-motion-design/SKILL.md +222 -222
  85. package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
  86. package/.codex/skills/team-perf-opt/SKILL.md +258 -258
  87. package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
  88. package/.codex/skills/team-planex/SKILL.md +216 -216
  89. package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
  90. package/.codex/skills/team-review/SKILL.md +227 -227
  91. package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
  92. package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
  93. package/.codex/skills/team-tech-debt/SKILL.md +206 -206
  94. package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
  95. package/.codex/skills/team-testing/SKILL.md +237 -237
  96. package/.codex/skills/team-ui-polish/SKILL.md +218 -218
  97. package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
  98. package/.codex/skills/team-uidesign/SKILL.md +219 -219
  99. package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
  100. package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
  101. package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
  102. package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
  103. package/.codex/skills/team-ux-improve/SKILL.md +227 -227
  104. package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
  105. package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
  106. package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
  107. package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
  108. package/.codex/skills/workflow-execute/SKILL.md +5 -5
  109. package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
  110. package/.codex/skills/workflow-plan/SKILL.md +3 -3
  111. package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
  112. package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
  113. package/README.md +14 -0
  114. package/ccw/dist/cli.d.ts.map +1 -1
  115. package/ccw/dist/cli.js +16 -0
  116. package/ccw/dist/cli.js.map +1 -1
  117. package/ccw/dist/commands/chain-loader.d.ts +2 -0
  118. package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
  119. package/ccw/dist/commands/chain-loader.js +11 -0
  120. package/ccw/dist/commands/chain-loader.js.map +1 -0
  121. package/ccw/dist/commands/install.d.ts.map +1 -1
  122. package/ccw/dist/commands/install.js +52 -1
  123. package/ccw/dist/commands/install.js.map +1 -1
  124. package/ccw/dist/commands/launcher.d.ts +2 -0
  125. package/ccw/dist/commands/launcher.d.ts.map +1 -0
  126. package/ccw/dist/commands/launcher.js +434 -0
  127. package/ccw/dist/commands/launcher.js.map +1 -0
  128. package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
  129. package/ccw/dist/core/routes/litellm-api-routes.js +0 -23
  130. package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
  131. package/ccw/dist/tools/chain-loader.d.ts +10 -0
  132. package/ccw/dist/tools/chain-loader.d.ts.map +1 -0
  133. package/ccw/dist/tools/chain-loader.js +1054 -0
  134. package/ccw/dist/tools/chain-loader.js.map +1 -0
  135. package/ccw/dist/tools/index.d.ts.map +1 -1
  136. package/ccw/dist/tools/index.js +2 -0
  137. package/ccw/dist/tools/index.js.map +1 -1
  138. package/ccw/dist/tools/json-builder.js +20 -0
  139. package/ccw/dist/tools/json-builder.js.map +1 -1
  140. package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
  141. package/ccw/dist/tools/skill-context-loader.js +12 -26
  142. package/ccw/dist/tools/skill-context-loader.js.map +1 -1
  143. package/ccw/dist/types/chain-types.d.ts +112 -0
  144. package/ccw/dist/types/chain-types.d.ts.map +1 -0
  145. package/ccw/dist/types/chain-types.js +5 -0
  146. package/ccw/dist/types/chain-types.js.map +1 -0
  147. package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
  148. package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
  149. package/ccw/dist/utils/chain-visualizer.js +164 -0
  150. package/ccw/dist/utils/chain-visualizer.js.map +1 -0
  151. package/ccw/scripts/prepublish-clean.mjs +0 -1
  152. package/package.json +1 -3
  153. package/.claude/commands/cli/cli-init.md +0 -441
  154. package/.claude/commands/cli/codex-review.md +0 -361
  155. package/.claude/commands/flow-create.md +0 -663
  156. package/.claude/skills/team-edict.zip +0 -0
  157. package/ccw-litellm/README.md +0 -180
  158. package/ccw-litellm/pyproject.toml +0 -35
  159. package/ccw-litellm/src/ccw_litellm/__init__.py +0 -47
  160. package/ccw-litellm/src/ccw_litellm/cli.py +0 -108
  161. package/ccw-litellm/src/ccw_litellm/clients/__init__.py +0 -12
  162. package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +0 -270
  163. package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +0 -198
  164. package/ccw-litellm/src/ccw_litellm/config/__init__.py +0 -22
  165. package/ccw-litellm/src/ccw_litellm/config/loader.py +0 -343
  166. package/ccw-litellm/src/ccw_litellm/config/models.py +0 -162
  167. package/ccw-litellm/src/ccw_litellm/interfaces/__init__.py +0 -14
  168. package/ccw-litellm/src/ccw_litellm/interfaces/embedder.py +0 -52
  169. package/ccw-litellm/src/ccw_litellm/interfaces/llm.py +0 -45
@@ -1,227 +1,227 @@
1
- ---
2
- name: team-frontend
3
- description: Unified team skill for frontend development. Pure router — all roles read this file. Beat model is coordinator-only in monitor.md. Built-in ui-ux-pro-max design intelligence. Triggers on "team frontend".
4
- allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), WebFetch(*), WebSearch(*), mcp__ace-tool__search_context(*)
5
- ---
6
-
7
- # Team Frontend Development
8
-
9
- Unified team skill: frontend development with built-in ui-ux-pro-max design intelligence. Covers requirement analysis, design system generation, frontend implementation, and quality assurance. Built on **team-worker agent architecture** — all worker roles share a single agent definition with role-specific Phase 2-4 loaded from role.md specs.
10
-
11
- ## Architecture
12
-
13
- ```
14
- Skill(skill="team-frontend", args="task description")
15
- |
16
- SKILL.md (this file) = Router
17
- |
18
- +--------------+--------------+
19
- | |
20
- no --role flag --role <name>
21
- | |
22
- Coordinator Worker
23
- roles/coordinator/role.md roles/<name>/role.md
24
- |
25
- +-- analyze -> dispatch -> spawn workers -> STOP
26
- |
27
- +-------+-------+-------+
28
- v v v v
29
- [analyst] [architect] [developer] [qa]
30
- (team-worker agents, each loads roles/<role>/role.md)
31
- ```
32
-
33
- ## Role Registry
34
-
35
- | Role | Path | Prefix | Inner Loop |
36
- |------|------|--------|------------|
37
- | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
38
- | analyst | [roles/analyst/role.md](roles/analyst/role.md) | ANALYZE-* | false |
39
- | architect | [roles/architect/role.md](roles/architect/role.md) | ARCH-* | false |
40
- | developer | [roles/developer/role.md](roles/developer/role.md) | DEV-* | true |
41
- | qa | [roles/qa/role.md](roles/qa/role.md) | QA-* | false |
42
-
43
- ## Role Router
44
-
45
- Parse `$ARGUMENTS`:
46
- - Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
47
- - No `--role` → `roles/coordinator/role.md`, execute entry router
48
-
49
- ## Delegation Lock
50
-
51
- **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
52
-
53
- Before calling ANY tool, apply this check:
54
-
55
- | Tool Call | Verdict | Reason |
56
- |-----------|---------|--------|
57
- | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
58
- | `list_agents` | ALLOWED | Agent health check |
59
- | `request_user_input` | ALLOWED | User interaction |
60
- | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
61
- | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
62
- | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
63
- | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
64
- | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
65
- | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
66
- | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
67
-
68
- **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
69
-
70
- **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
71
-
72
- ---
73
-
74
- ## Shared Constants
75
-
76
- - **Session prefix**: `FE`
77
- - **Session path**: `.workflow/.team/FE-<slug>-<date>/`
78
- - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
79
- - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
80
-
81
- ## Worker Spawn Template
82
-
83
- Coordinator spawns workers using this template:
84
-
85
- ```
86
- spawn_agent({
87
- agent_type: "team_worker",
88
- task_name: "<task-id>",
89
- fork_context: false,
90
- items: [
91
- { type: "text", text: `## Role Assignment
92
- role: <role>
93
- role_spec: <skill_root>/roles/<role>/role.md
94
- session: <session-folder>
95
- session_id: <session-id>
96
- requirement: <task-description>
97
- inner_loop: <true|false>
98
-
99
- Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
100
-
101
- { type: "text", text: `## Task Context
102
- task_id: <task-id>
103
- title: <task-title>
104
- description: <task-description>
105
- pipeline_phase: <pipeline-phase>` },
106
-
107
- { type: "text", text: `## Upstream Context
108
- <prev_context>` }
109
- ]
110
- })
111
- ```
112
-
113
- After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
114
-
115
-
116
- ### Model Selection Guide
117
-
118
- | Role | model | reasoning_effort | Rationale |
119
- |------|-------|-------------------|-----------|
120
- | Analyst (ANALYZE-*) | (default) | high | Design intelligence requires deep UI/UX reasoning |
121
- | Architect (ARCH-*) | (default) | high | Component spec and design token generation needs precision |
122
- | Developer (DEV-*) | (default) | high | Frontend code generation needs full reasoning |
123
- | QA (QA-*) | (default) | high | 5-dimension audit requires thorough analysis |
124
-
125
- Override model/reasoning_effort in spawn_agent when cost optimization is needed:
126
- ```
127
- spawn_agent({
128
- agent_type: "team_worker",
129
- task_name: "<task-id>",
130
- fork_context: false,
131
- model: "<model-override>",
132
- reasoning_effort: "<effort-level>",
133
- items: [...]
134
- })
135
- ```
136
-
137
- ## User Commands
138
-
139
- | Command | Action |
140
- |---------|--------|
141
- | `check` / `status` | View execution status graph |
142
- | `resume` / `continue` | Advance to next step |
143
-
144
- ## Session Directory
145
-
146
- ```
147
- .workflow/.team/FE-<slug>-<YYYY-MM-DD>/
148
- ├── .msg/
149
- │ ├── messages.jsonl # Message bus log
150
- │ └── meta.json # Session state + cross-role state
151
- ├── task-analysis.json # Coordinator analyze output
152
- ├── wisdom/ # Cross-task knowledge
153
- ├── analysis/ # Analyst output
154
- │ ├── design-intelligence.json
155
- │ └── requirements.md
156
- ├── architecture/ # Architect output
157
- │ ├── design-tokens.json
158
- │ ├── component-specs/
159
- │ └── project-structure.md
160
- ├── qa/ # QA output
161
- │ └── audit-<NNN>.md
162
- └── build/ # Developer output
163
- ```
164
-
165
- ## Specs Reference
166
-
167
- - [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
168
-
169
- ## v4 Agent Coordination
170
-
171
- ### Message Semantics
172
-
173
- | Intent | API | Example |
174
- |--------|-----|---------|
175
- | Send architecture specs to running developer | `send_message` | Queue design tokens and component specs to DEV-* |
176
- | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
177
- | Check running agents | `list_agents` | Verify agent health during resume |
178
-
179
- ### Pipeline Pattern
180
-
181
- Sequential pipeline with GC loops: analyst -> architect -> developer -> QA. In **system mode**, architect revision (ARCH-002) and developer (DEV-001) may run in parallel after QA-001 arch review.
182
-
183
- ### fork_context Consideration
184
-
185
- Developer workers (DEV-*) benefit from `fork_context: true` when the coordinator has accumulated significant design context (analysis results, architecture specs, design tokens). This avoids the developer needing to re-read all upstream artifacts:
186
-
187
- ```
188
- // Consider fork_context: true for developer in feature/system modes
189
- spawn_agent({
190
- agent_type: "team_worker",
191
- task_name: "DEV-001",
192
- fork_context: true, // Developer gets full coordinator context including design decisions
193
- items: [...]
194
- })
195
- ```
196
-
197
- ### GC Loop (QA Fix Cycle)
198
-
199
- QA may flag FIX_REQUIRED, creating DEV-fix + QA-recheck tasks (max 2 rounds). If QA score remains < 6 after 2 rounds, escalate to user.
200
-
201
- ### Agent Health Check
202
-
203
- Use `list_agents({})` in handleResume and handleComplete:
204
-
205
- ```
206
- // Reconcile session state with actual running agents
207
- const running = list_agents({})
208
- // Compare with tasks.json active_agents
209
- // Reset orphaned tasks (in_progress but agent gone) to pending
210
- ```
211
-
212
- ### Named Agent Targeting
213
-
214
- Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
215
- - `send_message({ target: "DEV-001", items: [...] })` -- queue architecture specs to running developer
216
- - `close_agent({ target: "ARCH-001" })` -- cleanup by name after completion
217
-
218
- ## Error Handling
219
-
220
- | Scenario | Resolution |
221
- |----------|------------|
222
- | Unknown command | Error with available command list |
223
- | Role not found | Error with role registry |
224
- | QA score < 6 over 2 GC rounds | Escalate to user |
225
- | ui-ux-pro-max unavailable | Degrade to LLM general design knowledge |
226
- | Worker no response | Report waiting task, suggest user `resume` |
227
- | Pipeline deadlock | Check blockedBy chain, report blocking point |
1
+ ---
2
+ name: team-frontend
3
+ description: Unified team skill for frontend development. Pure router — all roles read this file. Beat model is coordinator-only in monitor.md. Built-in ui-ux-pro-max design intelligence. Triggers on "team frontend".
4
+ allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), WebFetch(*), WebSearch(*), mcp__ace-tool__search_context(*)
5
+ ---
6
+
7
+ # Team Frontend Development
8
+
9
+ Unified team skill: frontend development with built-in ui-ux-pro-max design intelligence. Covers requirement analysis, design system generation, frontend implementation, and quality assurance. Built on **team-worker agent architecture** — all worker roles share a single agent definition with role-specific Phase 2-4 loaded from role.md specs.
10
+
11
+ ## Architecture
12
+
13
+ ```
14
+ Skill(skill="team-frontend", args="task description")
15
+ |
16
+ SKILL.md (this file) = Router
17
+ |
18
+ +--------------+--------------+
19
+ | |
20
+ no --role flag --role <name>
21
+ | |
22
+ Coordinator Worker
23
+ roles/coordinator/role.md roles/<name>/role.md
24
+ |
25
+ +-- analyze -> dispatch -> spawn workers -> STOP
26
+ |
27
+ +-------+-------+-------+
28
+ v v v v
29
+ [analyst] [architect] [developer] [qa]
30
+ (team-worker agents, each loads roles/<role>/role.md)
31
+ ```
32
+
33
+ ## Role Registry
34
+
35
+ | Role | Path | Prefix | Inner Loop |
36
+ |------|------|--------|------------|
37
+ | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
38
+ | analyst | [roles/analyst/role.md](roles/analyst/role.md) | ANALYZE-* | false |
39
+ | architect | [roles/architect/role.md](roles/architect/role.md) | ARCH-* | false |
40
+ | developer | [roles/developer/role.md](roles/developer/role.md) | DEV-* | true |
41
+ | qa | [roles/qa/role.md](roles/qa/role.md) | QA-* | false |
42
+
43
+ ## Role Router
44
+
45
+ Parse `$ARGUMENTS`:
46
+ - Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
47
+ - No `--role` → `roles/coordinator/role.md`, execute entry router
48
+
49
+ ## Delegation Lock
50
+
51
+ **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
52
+
53
+ Before calling ANY tool, apply this check:
54
+
55
+ | Tool Call | Verdict | Reason |
56
+ |-----------|---------|--------|
57
+ | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
58
+ | `list_agents` | ALLOWED | Agent health check |
59
+ | `request_user_input` | ALLOWED | User interaction |
60
+ | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
61
+ | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
62
+ | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
63
+ | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
64
+ | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
65
+ | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
66
+ | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
67
+
68
+ **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
69
+
70
+ **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
71
+
72
+ ---
73
+
74
+ ## Shared Constants
75
+
76
+ - **Session prefix**: `FE`
77
+ - **Session path**: `.workflow/.team/FE-<slug>-<date>/`
78
+ - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
79
+ - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
80
+
81
+ ## Worker Spawn Template
82
+
83
+ Coordinator spawns workers using this template:
84
+
85
+ ```
86
+ spawn_agent({
87
+ agent_type: "team_worker",
88
+ task_name: "<task-id>",
89
+ fork_context: false,
90
+ items: [
91
+ { type: "text", text: `## Role Assignment
92
+ role: <role>
93
+ role_spec: <skill_root>/roles/<role>/role.md
94
+ session: <session-folder>
95
+ session_id: <session-id>
96
+ requirement: <task-description>
97
+ inner_loop: <true|false>
98
+
99
+ Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
100
+
101
+ { type: "text", text: `## Task Context
102
+ task_id: <task-id>
103
+ title: <task-title>
104
+ description: <task-description>
105
+ pipeline_phase: <pipeline-phase>` },
106
+
107
+ { type: "text", text: `## Upstream Context
108
+ <prev_context>` }
109
+ ]
110
+ })
111
+ ```
112
+
113
+ After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
114
+
115
+
116
+ ### Model Selection Guide
117
+
118
+ | Role | model | reasoning_effort | Rationale |
119
+ |------|-------|-------------------|-----------|
120
+ | Analyst (ANALYZE-*) | (default) | high | Design intelligence requires deep UI/UX reasoning |
121
+ | Architect (ARCH-*) | (default) | high | Component spec and design token generation needs precision |
122
+ | Developer (DEV-*) | (default) | high | Frontend code generation needs full reasoning |
123
+ | QA (QA-*) | (default) | high | 5-dimension audit requires thorough analysis |
124
+
125
+ Override model/reasoning_effort in spawn_agent when cost optimization is needed:
126
+ ```
127
+ spawn_agent({
128
+ agent_type: "team_worker",
129
+ task_name: "<task-id>",
130
+ fork_context: false,
131
+ model: "<model-override>",
132
+ reasoning_effort: "<effort-level>",
133
+ items: [...]
134
+ })
135
+ ```
136
+
137
+ ## User Commands
138
+
139
+ | Command | Action |
140
+ |---------|--------|
141
+ | `check` / `status` | View execution status graph |
142
+ | `resume` / `continue` | Advance to next step |
143
+
144
+ ## Session Directory
145
+
146
+ ```
147
+ .workflow/.team/FE-<slug>-<YYYY-MM-DD>/
148
+ ├── .msg/
149
+ │ ├── messages.jsonl # Message bus log
150
+ │ └── meta.json # Session state + cross-role state
151
+ ├── task-analysis.json # Coordinator analyze output
152
+ ├── wisdom/ # Cross-task knowledge
153
+ ├── analysis/ # Analyst output
154
+ │ ├── design-intelligence.json
155
+ │ └── requirements.md
156
+ ├── architecture/ # Architect output
157
+ │ ├── design-tokens.json
158
+ │ ├── component-specs/
159
+ │ └── project-structure.md
160
+ ├── qa/ # QA output
161
+ │ └── audit-<NNN>.md
162
+ └── build/ # Developer output
163
+ ```
164
+
165
+ ## Specs Reference
166
+
167
+ - [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
168
+
169
+ ## v4 Agent Coordination
170
+
171
+ ### Message Semantics
172
+
173
+ | Intent | API | Example |
174
+ |--------|-----|---------|
175
+ | Send architecture specs to running developer | `send_message` | Queue design tokens and component specs to DEV-* |
176
+ | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
177
+ | Check running agents | `list_agents` | Verify agent health during resume |
178
+
179
+ ### Pipeline Pattern
180
+
181
+ Sequential pipeline with GC loops: analyst -> architect -> developer -> QA. In **system mode**, architect revision (ARCH-002) and developer (DEV-001) may run in parallel after QA-001 arch review.
182
+
183
+ ### fork_context Consideration
184
+
185
+ Developer workers (DEV-*) benefit from `fork_context: true` when the coordinator has accumulated significant design context (analysis results, architecture specs, design tokens). This avoids the developer needing to re-read all upstream artifacts:
186
+
187
+ ```
188
+ // Consider fork_context: true for developer in feature/system modes
189
+ spawn_agent({
190
+ agent_type: "team_worker",
191
+ task_name: "DEV-001",
192
+ fork_context: true, // Developer gets full coordinator context including design decisions
193
+ items: [...]
194
+ })
195
+ ```
196
+
197
+ ### GC Loop (QA Fix Cycle)
198
+
199
+ QA may flag FIX_REQUIRED, creating DEV-fix + QA-recheck tasks (max 2 rounds). If QA score remains < 6 after 2 rounds, escalate to user.
200
+
201
+ ### Agent Health Check
202
+
203
+ Use `list_agents({})` in handleResume and handleComplete:
204
+
205
+ ```
206
+ // Reconcile session state with actual running agents
207
+ const running = list_agents({})
208
+ // Compare with tasks.json active_agents
209
+ // Reset orphaned tasks (in_progress but agent gone) to pending
210
+ ```
211
+
212
+ ### Named Agent Targeting
213
+
214
+ Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
215
+ - `send_message({ target: "DEV-001", items: [...] })` -- queue architecture specs to running developer
216
+ - `close_agent({ target: "ARCH-001" })` -- cleanup by name after completion
217
+
218
+ ## Error Handling
219
+
220
+ | Scenario | Resolution |
221
+ |----------|------------|
222
+ | Unknown command | Error with available command list |
223
+ | Role not found | Error with role registry |
224
+ | QA score < 6 over 2 GC rounds | Escalate to user |
225
+ | ui-ux-pro-max unavailable | Degrade to LLM general design knowledge |
226
+ | Worker no response | Report waiting task, suggest user `resume` |
227
+ | Pipeline deadlock | Check blockedBy chain, report blocking point |