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,222 +1,222 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-motion-design
|
|
3
|
-
description: Unified team skill for motion design. Animation token systems, scroll choreography, GPU-accelerated transforms, reduced-motion fallback. Uses team-worker agent architecture. Triggers on "team motion design", "animation system".
|
|
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(*), mcp__ccw-tools__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*), mcp__chrome-devtools__evaluate_script(*), mcp__chrome-devtools__take_screenshot(*), mcp__chrome-devtools__performance_start_trace(*), mcp__chrome-devtools__performance_stop_trace(*), mcp__chrome-devtools__performance_analyze_insight(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team Motion Design
|
|
8
|
-
|
|
9
|
-
Systematic motion design pipeline: research -> choreography -> animation -> performance testing. Built on **team-worker agent architecture** -- all worker roles share a single agent definition with role-specific Phase 2-4 loaded from `roles/<role>/role.md`.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-motion-design", 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
|
-
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
-
motion-researcher choreographer animator motion-tester
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Role Registry
|
|
34
|
-
|
|
35
|
-
| Role | Path | Prefix | Inner Loop |
|
|
36
|
-
|------|------|--------|------------|
|
|
37
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | -- | -- |
|
|
38
|
-
| motion-researcher | [roles/motion-researcher/role.md](roles/motion-researcher/role.md) | MRESEARCH-* | false |
|
|
39
|
-
| choreographer | [roles/choreographer/role.md](roles/choreographer/role.md) | CHOREO-* | false |
|
|
40
|
-
| animator | [roles/animator/role.md](roles/animator/role.md) | ANIM-* | true |
|
|
41
|
-
| motion-tester | [roles/motion-tester/role.md](roles/motion-tester/role.md) | MTEST-* | 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**: `MD`
|
|
77
|
-
- **Session path**: `.workflow/.team/MD-<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
|
-
- **Max GC rounds**: 2
|
|
81
|
-
|
|
82
|
-
## Worker Spawn Template
|
|
83
|
-
|
|
84
|
-
Coordinator spawns workers using this template:
|
|
85
|
-
|
|
86
|
-
```
|
|
87
|
-
spawn_agent({
|
|
88
|
-
agent_type: "team_worker",
|
|
89
|
-
task_name: "<task-id>",
|
|
90
|
-
fork_context: false,
|
|
91
|
-
items: [
|
|
92
|
-
{ type: "text", text: `## Role Assignment
|
|
93
|
-
role: <role>
|
|
94
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
95
|
-
session: <session-folder>
|
|
96
|
-
session_id: <session-id>
|
|
97
|
-
requirement: <task-description>
|
|
98
|
-
inner_loop: <true|false>
|
|
99
|
-
|
|
100
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
101
|
-
|
|
102
|
-
{ type: "text", text: `## Task Context
|
|
103
|
-
task_id: <task-id>
|
|
104
|
-
title: <task-title>
|
|
105
|
-
description: <task-description>
|
|
106
|
-
pipeline_phase: <pipeline-phase>` },
|
|
107
|
-
|
|
108
|
-
{ type: "text", text: `## Upstream Context
|
|
109
|
-
<prev_context>` }
|
|
110
|
-
]
|
|
111
|
-
})
|
|
112
|
-
```
|
|
113
|
-
|
|
114
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
### Model Selection Guide
|
|
118
|
-
|
|
119
|
-
Motion design is a performance-critical pipeline where research informs choreography decisions and animations must pass strict GPU performance gates. Researcher needs thorough profiling, animator needs creative implementation with inner loop capability.
|
|
120
|
-
|
|
121
|
-
| Role | reasoning_effort | Rationale |
|
|
122
|
-
|------|-------------------|-----------|
|
|
123
|
-
| motion-researcher | high | Deep performance profiling and animation audit across codebase |
|
|
124
|
-
| choreographer | high | Creative token system design and scroll choreography sequencing |
|
|
125
|
-
| animator | high | Complex CSS/JS animation implementation with compositor constraints |
|
|
126
|
-
| motion-tester | medium | Performance validation follows defined test criteria and scoring |
|
|
127
|
-
|
|
128
|
-
### Research-to-Choreography Context Flow
|
|
129
|
-
|
|
130
|
-
Researcher findings must reach choreographer via coordinator's upstream context:
|
|
131
|
-
```
|
|
132
|
-
// After MRESEARCH-001 completes, coordinator sends findings to choreographer
|
|
133
|
-
spawn_agent({
|
|
134
|
-
agent_type: "team_worker",
|
|
135
|
-
task_name: "CHOREO-001",
|
|
136
|
-
fork_context: false,
|
|
137
|
-
items: [
|
|
138
|
-
...,
|
|
139
|
-
{ type: "text", text: `## Upstream Context
|
|
140
|
-
Research findings: <session>/research/animation-inventory.json
|
|
141
|
-
Performance baseline: <session>/research/performance-baseline.json
|
|
142
|
-
Easing catalog: <session>/research/easing-catalog.json` }
|
|
143
|
-
]
|
|
144
|
-
})
|
|
145
|
-
```
|
|
146
|
-
|
|
147
|
-
## User Commands
|
|
148
|
-
|
|
149
|
-
| Command | Action |
|
|
150
|
-
|---------|--------|
|
|
151
|
-
| `check` / `status` | View execution status graph |
|
|
152
|
-
| `resume` / `continue` | Advance to next step |
|
|
153
|
-
|
|
154
|
-
## Specs Reference
|
|
155
|
-
|
|
156
|
-
- [specs/pipelines.md](specs/pipelines.md) -- Pipeline definitions and task registry
|
|
157
|
-
- [specs/motion-tokens.md](specs/motion-tokens.md) -- Animation token schema
|
|
158
|
-
- [specs/gpu-constraints.md](specs/gpu-constraints.md) -- Compositor-only animation rules
|
|
159
|
-
- [specs/reduced-motion.md](specs/reduced-motion.md) -- Accessibility motion preferences
|
|
160
|
-
|
|
161
|
-
## Session Directory
|
|
162
|
-
|
|
163
|
-
```
|
|
164
|
-
.workflow/.team/MD-<slug>-<date>/
|
|
165
|
-
+-- .msg/
|
|
166
|
-
| +-- messages.jsonl # Team message bus
|
|
167
|
-
| +-- meta.json # Pipeline config + GC state
|
|
168
|
-
+-- research/ # Motion researcher output
|
|
169
|
-
| +-- perf-traces/ # Chrome DevTools performance traces
|
|
170
|
-
| +-- animation-inventory.json
|
|
171
|
-
| +-- performance-baseline.json
|
|
172
|
-
| +-- easing-catalog.json
|
|
173
|
-
+-- choreography/ # Choreographer output
|
|
174
|
-
| +-- motion-tokens.json
|
|
175
|
-
| +-- sequences/ # Scroll choreography sequences
|
|
176
|
-
+-- animations/ # Animator output
|
|
177
|
-
| +-- keyframes/ # CSS @keyframes files
|
|
178
|
-
| +-- orchestrators/ # JS animation orchestrators
|
|
179
|
-
+-- testing/ # Motion tester output
|
|
180
|
-
| +-- traces/ # Performance trace data
|
|
181
|
-
| +-- reports/ # Performance reports
|
|
182
|
-
+-- wisdom/ # Cross-task knowledge
|
|
183
|
-
```
|
|
184
|
-
|
|
185
|
-
## v4 Agent Coordination
|
|
186
|
-
|
|
187
|
-
### Message Semantics
|
|
188
|
-
|
|
189
|
-
| Intent | API | Example |
|
|
190
|
-
|--------|-----|---------|
|
|
191
|
-
| Queue supplementary info (don't interrupt) | `send_message` | Send research findings to running choreographer |
|
|
192
|
-
| Assign implementation from reviewed specs | `assign_task` | Assign ANIM task after choreography passes |
|
|
193
|
-
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
194
|
-
|
|
195
|
-
### Agent Health Check
|
|
196
|
-
|
|
197
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
198
|
-
|
|
199
|
-
```
|
|
200
|
-
// Reconcile session state with actual running agents
|
|
201
|
-
const running = list_agents({})
|
|
202
|
-
// Compare with tasks.json active_agents
|
|
203
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
204
|
-
```
|
|
205
|
-
|
|
206
|
-
### Named Agent Targeting
|
|
207
|
-
|
|
208
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
209
|
-
- `send_message({ target: "CHOREO-001", items: [...] })` -- send additional research findings to choreographer
|
|
210
|
-
- `assign_task({ target: "ANIM-001", items: [...] })` -- assign animation from reviewed choreography specs
|
|
211
|
-
- `close_agent({ target: "MTEST-001" })` -- cleanup after performance test
|
|
212
|
-
|
|
213
|
-
## Error Handling
|
|
214
|
-
|
|
215
|
-
| Scenario | Resolution |
|
|
216
|
-
|----------|------------|
|
|
217
|
-
| Unknown command | Error with available command list |
|
|
218
|
-
| Role not found | Error with role registry |
|
|
219
|
-
| Session corruption | Attempt recovery, fallback to manual |
|
|
220
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
221
|
-
| Completion action fails | Default to Keep Active |
|
|
222
|
-
| GC loop stuck > 2 rounds | Escalate to user: accept / retry / terminate |
|
|
1
|
+
---
|
|
2
|
+
name: team-motion-design
|
|
3
|
+
description: Unified team skill for motion design. Animation token systems, scroll choreography, GPU-accelerated transforms, reduced-motion fallback. Uses team-worker agent architecture. Triggers on "team motion design", "animation system".
|
|
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(*), mcp__ccw-tools__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*), mcp__chrome-devtools__evaluate_script(*), mcp__chrome-devtools__take_screenshot(*), mcp__chrome-devtools__performance_start_trace(*), mcp__chrome-devtools__performance_stop_trace(*), mcp__chrome-devtools__performance_analyze_insight(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team Motion Design
|
|
8
|
+
|
|
9
|
+
Systematic motion design pipeline: research -> choreography -> animation -> performance testing. Built on **team-worker agent architecture** -- all worker roles share a single agent definition with role-specific Phase 2-4 loaded from `roles/<role>/role.md`.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-motion-design", 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
|
+
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
+
motion-researcher choreographer animator motion-tester
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Role Registry
|
|
34
|
+
|
|
35
|
+
| Role | Path | Prefix | Inner Loop |
|
|
36
|
+
|------|------|--------|------------|
|
|
37
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | -- | -- |
|
|
38
|
+
| motion-researcher | [roles/motion-researcher/role.md](roles/motion-researcher/role.md) | MRESEARCH-* | false |
|
|
39
|
+
| choreographer | [roles/choreographer/role.md](roles/choreographer/role.md) | CHOREO-* | false |
|
|
40
|
+
| animator | [roles/animator/role.md](roles/animator/role.md) | ANIM-* | true |
|
|
41
|
+
| motion-tester | [roles/motion-tester/role.md](roles/motion-tester/role.md) | MTEST-* | 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**: `MD`
|
|
77
|
+
- **Session path**: `.workflow/.team/MD-<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
|
+
- **Max GC rounds**: 2
|
|
81
|
+
|
|
82
|
+
## Worker Spawn Template
|
|
83
|
+
|
|
84
|
+
Coordinator spawns workers using this template:
|
|
85
|
+
|
|
86
|
+
```
|
|
87
|
+
spawn_agent({
|
|
88
|
+
agent_type: "team_worker",
|
|
89
|
+
task_name: "<task-id>",
|
|
90
|
+
fork_context: false,
|
|
91
|
+
items: [
|
|
92
|
+
{ type: "text", text: `## Role Assignment
|
|
93
|
+
role: <role>
|
|
94
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
95
|
+
session: <session-folder>
|
|
96
|
+
session_id: <session-id>
|
|
97
|
+
requirement: <task-description>
|
|
98
|
+
inner_loop: <true|false>
|
|
99
|
+
|
|
100
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
101
|
+
|
|
102
|
+
{ type: "text", text: `## Task Context
|
|
103
|
+
task_id: <task-id>
|
|
104
|
+
title: <task-title>
|
|
105
|
+
description: <task-description>
|
|
106
|
+
pipeline_phase: <pipeline-phase>` },
|
|
107
|
+
|
|
108
|
+
{ type: "text", text: `## Upstream Context
|
|
109
|
+
<prev_context>` }
|
|
110
|
+
]
|
|
111
|
+
})
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
### Model Selection Guide
|
|
118
|
+
|
|
119
|
+
Motion design is a performance-critical pipeline where research informs choreography decisions and animations must pass strict GPU performance gates. Researcher needs thorough profiling, animator needs creative implementation with inner loop capability.
|
|
120
|
+
|
|
121
|
+
| Role | reasoning_effort | Rationale |
|
|
122
|
+
|------|-------------------|-----------|
|
|
123
|
+
| motion-researcher | high | Deep performance profiling and animation audit across codebase |
|
|
124
|
+
| choreographer | high | Creative token system design and scroll choreography sequencing |
|
|
125
|
+
| animator | high | Complex CSS/JS animation implementation with compositor constraints |
|
|
126
|
+
| motion-tester | medium | Performance validation follows defined test criteria and scoring |
|
|
127
|
+
|
|
128
|
+
### Research-to-Choreography Context Flow
|
|
129
|
+
|
|
130
|
+
Researcher findings must reach choreographer via coordinator's upstream context:
|
|
131
|
+
```
|
|
132
|
+
// After MRESEARCH-001 completes, coordinator sends findings to choreographer
|
|
133
|
+
spawn_agent({
|
|
134
|
+
agent_type: "team_worker",
|
|
135
|
+
task_name: "CHOREO-001",
|
|
136
|
+
fork_context: false,
|
|
137
|
+
items: [
|
|
138
|
+
...,
|
|
139
|
+
{ type: "text", text: `## Upstream Context
|
|
140
|
+
Research findings: <session>/research/animation-inventory.json
|
|
141
|
+
Performance baseline: <session>/research/performance-baseline.json
|
|
142
|
+
Easing catalog: <session>/research/easing-catalog.json` }
|
|
143
|
+
]
|
|
144
|
+
})
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
## User Commands
|
|
148
|
+
|
|
149
|
+
| Command | Action |
|
|
150
|
+
|---------|--------|
|
|
151
|
+
| `check` / `status` | View execution status graph |
|
|
152
|
+
| `resume` / `continue` | Advance to next step |
|
|
153
|
+
|
|
154
|
+
## Specs Reference
|
|
155
|
+
|
|
156
|
+
- [specs/pipelines.md](specs/pipelines.md) -- Pipeline definitions and task registry
|
|
157
|
+
- [specs/motion-tokens.md](specs/motion-tokens.md) -- Animation token schema
|
|
158
|
+
- [specs/gpu-constraints.md](specs/gpu-constraints.md) -- Compositor-only animation rules
|
|
159
|
+
- [specs/reduced-motion.md](specs/reduced-motion.md) -- Accessibility motion preferences
|
|
160
|
+
|
|
161
|
+
## Session Directory
|
|
162
|
+
|
|
163
|
+
```
|
|
164
|
+
.workflow/.team/MD-<slug>-<date>/
|
|
165
|
+
+-- .msg/
|
|
166
|
+
| +-- messages.jsonl # Team message bus
|
|
167
|
+
| +-- meta.json # Pipeline config + GC state
|
|
168
|
+
+-- research/ # Motion researcher output
|
|
169
|
+
| +-- perf-traces/ # Chrome DevTools performance traces
|
|
170
|
+
| +-- animation-inventory.json
|
|
171
|
+
| +-- performance-baseline.json
|
|
172
|
+
| +-- easing-catalog.json
|
|
173
|
+
+-- choreography/ # Choreographer output
|
|
174
|
+
| +-- motion-tokens.json
|
|
175
|
+
| +-- sequences/ # Scroll choreography sequences
|
|
176
|
+
+-- animations/ # Animator output
|
|
177
|
+
| +-- keyframes/ # CSS @keyframes files
|
|
178
|
+
| +-- orchestrators/ # JS animation orchestrators
|
|
179
|
+
+-- testing/ # Motion tester output
|
|
180
|
+
| +-- traces/ # Performance trace data
|
|
181
|
+
| +-- reports/ # Performance reports
|
|
182
|
+
+-- wisdom/ # Cross-task knowledge
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
## v4 Agent Coordination
|
|
186
|
+
|
|
187
|
+
### Message Semantics
|
|
188
|
+
|
|
189
|
+
| Intent | API | Example |
|
|
190
|
+
|--------|-----|---------|
|
|
191
|
+
| Queue supplementary info (don't interrupt) | `send_message` | Send research findings to running choreographer |
|
|
192
|
+
| Assign implementation from reviewed specs | `assign_task` | Assign ANIM task after choreography passes |
|
|
193
|
+
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
194
|
+
|
|
195
|
+
### Agent Health Check
|
|
196
|
+
|
|
197
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
198
|
+
|
|
199
|
+
```
|
|
200
|
+
// Reconcile session state with actual running agents
|
|
201
|
+
const running = list_agents({})
|
|
202
|
+
// Compare with tasks.json active_agents
|
|
203
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
### Named Agent Targeting
|
|
207
|
+
|
|
208
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
209
|
+
- `send_message({ target: "CHOREO-001", items: [...] })` -- send additional research findings to choreographer
|
|
210
|
+
- `assign_task({ target: "ANIM-001", items: [...] })` -- assign animation from reviewed choreography specs
|
|
211
|
+
- `close_agent({ target: "MTEST-001" })` -- cleanup after performance test
|
|
212
|
+
|
|
213
|
+
## Error Handling
|
|
214
|
+
|
|
215
|
+
| Scenario | Resolution |
|
|
216
|
+
|----------|------------|
|
|
217
|
+
| Unknown command | Error with available command list |
|
|
218
|
+
| Role not found | Error with role registry |
|
|
219
|
+
| Session corruption | Attempt recovery, fallback to manual |
|
|
220
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
221
|
+
| Completion action fails | Default to Keep Active |
|
|
222
|
+
| GC loop stuck > 2 rounds | Escalate to user: accept / retry / terminate |
|