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.
- package/.ccw/workflows/cli-templates/schemas/plan-overview-base-schema.json +2 -2
- package/.ccw/workflows/cli-templates/schemas/task-schema.json +14 -7
- package/.claude/agents/action-planning-agent.md +7 -4
- package/.claude/agents/cli-explore-agent.md +77 -63
- package/.claude/agents/cli-lite-planning-agent.md +11 -10
- package/.claude/agents/issue-plan-agent.md +421 -426
- package/.claude/commands/workflow/spec/setup.md +1 -1
- package/.claude/commands/workflow-skill.md +130 -0
- package/.claude/skills/ccw-chain/SKILL.md +92 -0
- package/.claude/skills/ccw-chain/chains/ccw-cycle.json +31 -0
- package/.claude/skills/ccw-chain/chains/ccw-exploration.json +58 -0
- package/.claude/skills/ccw-chain/chains/ccw-issue.json +44 -0
- package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +71 -0
- package/.claude/skills/ccw-chain/chains/ccw-main.json +65 -0
- package/.claude/skills/ccw-chain/chains/ccw-standard.json +51 -0
- package/.claude/skills/ccw-chain/chains/ccw-team.json +15 -0
- package/.claude/skills/ccw-chain/chains/ccw-with-file.json +47 -0
- package/.claude/skills/ccw-chain/specs/auto-mode.md +47 -0
- package/.claude/skills/chain-loader/SKILL.md +78 -0
- package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -0
- package/.claude/skills/chain-loader/phases/02-design-graph.md +73 -0
- package/.claude/skills/chain-loader/phases/03-generate-validate.md +75 -0
- package/.claude/skills/chain-loader/specs/chain-schema.md +126 -0
- package/.claude/skills/chain-loader/specs/design-patterns.md +99 -0
- package/.claude/skills/chain-loader/templates/chain-json.md +63 -0
- package/.claude/skills/review-cycle/phases/review-module.md +764 -764
- package/.claude/skills/review-cycle/phases/review-session.md +775 -775
- package/.claude/skills/workflow-multi-cli-plan/SKILL.md +2 -2
- package/.claude/skills/workflow-plan/SKILL.md +1 -0
- package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
- package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
- package/.claude/skills/workflow-plan/phases/03-conflict-resolution.md +422 -422
- package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
- package/.claude/skills/workflow-plan/phases/05-plan-verify.md +395 -395
- package/.claude/skills/workflow-tdd-plan/phases/02-context-gathering.md +407 -407
- package/.claude/skills/workflow-tdd-plan/phases/04-conflict-resolution.md +426 -426
- package/.claude/skills/workflow-test-fix/phases/02-test-context-gather.md +493 -493
- package/.codex/skills/analyze-with-file/SKILL.md +383 -134
- package/.codex/skills/brainstorm/SKILL.md +3 -3
- package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
- package/.codex/skills/clean/SKILL.md +1 -1
- package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
- package/.codex/skills/investigate/orchestrator.md +24 -0
- package/.codex/skills/issue-discover/SKILL.md +374 -361
- package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
- package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
- package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
- package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
- package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
- package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
- package/.codex/skills/review-cycle/SKILL.md +31 -12
- package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
- package/.codex/skills/security-audit/orchestrator.md +29 -0
- package/.codex/skills/session-sync/SKILL.md +1 -1
- package/.codex/skills/ship/orchestrator.md +24 -0
- package/.codex/skills/spec-add/SKILL.md +5 -5
- package/.codex/skills/spec-generator/SKILL.md +33 -2
- package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
- package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
- package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
- package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
- package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
- package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
- package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
- package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
- package/.codex/skills/spec-setup/SKILL.md +669 -669
- package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-brainstorm/SKILL.md +259 -259
- package/.codex/skills/team-coordinate/SKILL.md +359 -359
- package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-designer/SKILL.md +27 -1
- package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
- package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
- package/.codex/skills/team-designer/phases/04-validation.md +1 -1
- package/.codex/skills/team-executor/SKILL.md +218 -218
- package/.codex/skills/team-frontend/SKILL.md +227 -227
- package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
- package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
- package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
- package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
- package/.codex/skills/team-issue/SKILL.md +269 -269
- package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
- package/.codex/skills/team-motion-design/SKILL.md +222 -222
- package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
- package/.codex/skills/team-perf-opt/SKILL.md +258 -258
- package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-planex/SKILL.md +216 -216
- package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
- package/.codex/skills/team-review/SKILL.md +227 -227
- package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
- package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
- package/.codex/skills/team-tech-debt/SKILL.md +206 -206
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-testing/SKILL.md +237 -237
- package/.codex/skills/team-ui-polish/SKILL.md +218 -218
- package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
- package/.codex/skills/team-uidesign/SKILL.md +219 -219
- package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
- package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
- package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/SKILL.md +227 -227
- package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
- package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
- package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
- package/.codex/skills/workflow-execute/SKILL.md +5 -5
- package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
- package/.codex/skills/workflow-plan/SKILL.md +3 -3
- package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
- package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
- package/README.md +14 -0
- package/ccw/dist/cli.d.ts.map +1 -1
- package/ccw/dist/cli.js +16 -0
- package/ccw/dist/cli.js.map +1 -1
- package/ccw/dist/commands/chain-loader.d.ts +2 -0
- package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
- package/ccw/dist/commands/chain-loader.js +11 -0
- package/ccw/dist/commands/chain-loader.js.map +1 -0
- package/ccw/dist/commands/install.d.ts.map +1 -1
- package/ccw/dist/commands/install.js +52 -1
- package/ccw/dist/commands/install.js.map +1 -1
- package/ccw/dist/commands/launcher.d.ts +2 -0
- package/ccw/dist/commands/launcher.d.ts.map +1 -0
- package/ccw/dist/commands/launcher.js +434 -0
- package/ccw/dist/commands/launcher.js.map +1 -0
- package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/litellm-api-routes.js +0 -23
- package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
- package/ccw/dist/tools/chain-loader.d.ts +10 -0
- package/ccw/dist/tools/chain-loader.d.ts.map +1 -0
- package/ccw/dist/tools/chain-loader.js +1054 -0
- package/ccw/dist/tools/chain-loader.js.map +1 -0
- package/ccw/dist/tools/index.d.ts.map +1 -1
- package/ccw/dist/tools/index.js +2 -0
- package/ccw/dist/tools/index.js.map +1 -1
- package/ccw/dist/tools/json-builder.js +20 -0
- package/ccw/dist/tools/json-builder.js.map +1 -1
- package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
- package/ccw/dist/tools/skill-context-loader.js +12 -26
- package/ccw/dist/tools/skill-context-loader.js.map +1 -1
- package/ccw/dist/types/chain-types.d.ts +112 -0
- package/ccw/dist/types/chain-types.d.ts.map +1 -0
- package/ccw/dist/types/chain-types.js +5 -0
- package/ccw/dist/types/chain-types.js.map +1 -0
- package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
- package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
- package/ccw/dist/utils/chain-visualizer.js +164 -0
- package/ccw/dist/utils/chain-visualizer.js.map +1 -0
- package/ccw/scripts/prepublish-clean.mjs +0 -1
- package/package.json +1 -3
- package/.claude/commands/cli/cli-init.md +0 -441
- package/.claude/commands/cli/codex-review.md +0 -361
- package/.claude/commands/flow-create.md +0 -663
- package/.claude/skills/team-edict.zip +0 -0
- package/ccw-litellm/README.md +0 -180
- package/ccw-litellm/pyproject.toml +0 -35
- package/ccw-litellm/src/ccw_litellm/__init__.py +0 -47
- package/ccw-litellm/src/ccw_litellm/cli.py +0 -108
- package/ccw-litellm/src/ccw_litellm/clients/__init__.py +0 -12
- package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +0 -270
- package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +0 -198
- package/ccw-litellm/src/ccw_litellm/config/__init__.py +0 -22
- package/ccw-litellm/src/ccw_litellm/config/loader.py +0 -343
- package/ccw-litellm/src/ccw_litellm/config/models.py +0 -162
- package/ccw-litellm/src/ccw_litellm/interfaces/__init__.py +0 -14
- package/ccw-litellm/src/ccw_litellm/interfaces/embedder.py +0 -52
- 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 |
|