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-ux-improve
|
|
3
|
-
description: Unified team skill for UX improvement. Systematically discovers and fixes UI/UX interaction issues including unresponsive buttons, missing feedback, and state refresh problems. Uses team-worker agent architecture with roles/ for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team ux improve".
|
|
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__ace-tool__search_context(*), mcp__ccw-tools__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team UX Improve
|
|
8
|
-
|
|
9
|
-
Systematic UX improvement pipeline: scan -> diagnose -> design -> implement -> test. 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-ux-improve", args="<project-path> [--framework react|vue]")
|
|
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 v
|
|
29
|
-
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
-
scanner diagnoser designer implementer 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
|
-
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | SCAN-* | false |
|
|
39
|
-
| diagnoser | [roles/diagnoser/role.md](roles/diagnoser/role.md) | DIAG-* | false |
|
|
40
|
-
| designer | [roles/designer/role.md](roles/designer/role.md) | DESIGN-* | false |
|
|
41
|
-
| implementer | [roles/implementer/role.md](roles/implementer/role.md) | IMPL-* | true |
|
|
42
|
-
| tester | [roles/tester/role.md](roles/tester/role.md) | TEST-* | false |
|
|
43
|
-
|
|
44
|
-
## Utility Member Registry
|
|
45
|
-
|
|
46
|
-
**Coordinator-only**: Utility members can only be spawned by Coordinator. Workers CANNOT call spawn_agent() to spawn utility members.
|
|
47
|
-
|
|
48
|
-
| Utility Member | Path | Callable By | Purpose |
|
|
49
|
-
|----------------|------|-------------|---------|
|
|
50
|
-
| explorer | [roles/explorer/role.md](roles/explorer/role.md) | Coordinator only | Explore codebase for UI component patterns and framework-specific patterns |
|
|
51
|
-
|
|
52
|
-
## Role Router
|
|
53
|
-
|
|
54
|
-
Parse `$ARGUMENTS`:
|
|
55
|
-
- Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
|
|
56
|
-
- No `--role` → `roles/coordinator/role.md`, execute entry router
|
|
57
|
-
|
|
58
|
-
## Delegation Lock
|
|
59
|
-
|
|
60
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
61
|
-
|
|
62
|
-
Before calling ANY tool, apply this check:
|
|
63
|
-
|
|
64
|
-
| Tool Call | Verdict | Reason |
|
|
65
|
-
|-----------|---------|--------|
|
|
66
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
67
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
68
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
69
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
70
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
71
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
72
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
73
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
74
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
75
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
76
|
-
|
|
77
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
78
|
-
|
|
79
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
80
|
-
|
|
81
|
-
---
|
|
82
|
-
|
|
83
|
-
## Shared Constants
|
|
84
|
-
|
|
85
|
-
- **Session prefix**: `ux-improve`
|
|
86
|
-
- **Session path**: `.workflow/.team/ux-improve-<timestamp>/`
|
|
87
|
-
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
88
|
-
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
89
|
-
- **Max test iterations**: 5
|
|
90
|
-
|
|
91
|
-
## Worker Spawn Template
|
|
92
|
-
|
|
93
|
-
Coordinator spawns workers using this template:
|
|
94
|
-
|
|
95
|
-
```
|
|
96
|
-
spawn_agent({
|
|
97
|
-
agent_type: "team_worker",
|
|
98
|
-
task_name: "<task-id>",
|
|
99
|
-
fork_context: false,
|
|
100
|
-
items: [
|
|
101
|
-
{ type: "text", text: `## Role Assignment
|
|
102
|
-
role: <role>
|
|
103
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
104
|
-
session: <session-folder>
|
|
105
|
-
session_id: <session-id>
|
|
106
|
-
requirement: <task-description>
|
|
107
|
-
inner_loop: <true|false>
|
|
108
|
-
|
|
109
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
110
|
-
|
|
111
|
-
{ type: "text", text: `## Task Context
|
|
112
|
-
task_id: <task-id>
|
|
113
|
-
title: <task-title>
|
|
114
|
-
description: <task-description>
|
|
115
|
-
pipeline_phase: <pipeline-phase>` },
|
|
116
|
-
|
|
117
|
-
{ type: "text", text: `## Upstream Context
|
|
118
|
-
<prev_context>` }
|
|
119
|
-
]
|
|
120
|
-
})
|
|
121
|
-
```
|
|
122
|
-
|
|
123
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
### Model Selection Guide
|
|
127
|
-
|
|
128
|
-
UX improvement has an explorer utility member and a scan-diagnose-design-implement-test pipeline.
|
|
129
|
-
|
|
130
|
-
| Role | reasoning_effort | Rationale |
|
|
131
|
-
|------|-------------------|-----------|
|
|
132
|
-
| explorer | low | File reading and pattern summarization only (utility member) |
|
|
133
|
-
| scanner | medium | Broad UI/UX issue scanning, pattern-based detection |
|
|
134
|
-
| diagnoser | high | Root cause diagnosis of UX issues requires deep analysis |
|
|
135
|
-
| designer | high | UX improvement design needs careful user experience reasoning |
|
|
136
|
-
| implementer | high | UI code changes must preserve existing behavior |
|
|
137
|
-
| tester | medium | Test execution follows defined UX verification criteria |
|
|
138
|
-
|
|
139
|
-
## User Commands
|
|
140
|
-
|
|
141
|
-
| Command | Action |
|
|
142
|
-
|---------|--------|
|
|
143
|
-
| `check` / `status` | View execution status graph |
|
|
144
|
-
| `resume` / `continue` | Advance to next step |
|
|
145
|
-
|
|
146
|
-
## Specs Reference
|
|
147
|
-
|
|
148
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
149
|
-
|
|
150
|
-
## Session Directory
|
|
151
|
-
|
|
152
|
-
```
|
|
153
|
-
.workflow/.team/ux-improve-<timestamp>/
|
|
154
|
-
├── .msg/
|
|
155
|
-
│ ├── messages.jsonl # Team message bus
|
|
156
|
-
│ └── meta.json # Pipeline config + role state snapshot
|
|
157
|
-
├── artifacts/ # Role deliverables
|
|
158
|
-
│ ├── scan-report.md # Scanner output
|
|
159
|
-
│ ├── diagnosis.md # Diagnoser output
|
|
160
|
-
│ ├── design-guide.md # Designer output
|
|
161
|
-
│ ├── fixes/ # Implementer output
|
|
162
|
-
│ └── test-report.md # Tester output
|
|
163
|
-
├── explorations/ # Explorer cache
|
|
164
|
-
│ └── cache-index.json
|
|
165
|
-
└── wisdom/ # Session knowledge base
|
|
166
|
-
├── contributions/ # Worker contributions (write-only for workers)
|
|
167
|
-
├── principles/
|
|
168
|
-
├── patterns/
|
|
169
|
-
└── anti-patterns/
|
|
170
|
-
```
|
|
171
|
-
|
|
172
|
-
## v4 Agent Coordination
|
|
173
|
-
|
|
174
|
-
### Message Semantics
|
|
175
|
-
|
|
176
|
-
| Intent | API | Example |
|
|
177
|
-
|--------|-----|---------|
|
|
178
|
-
| Queue supplementary info (don't interrupt) | `send_message` | Send explorer findings to running scanner |
|
|
179
|
-
| Assign implementation from design | `assign_task` | Assign IMPL task from designer output |
|
|
180
|
-
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
181
|
-
|
|
182
|
-
### Agent Health Check
|
|
183
|
-
|
|
184
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
185
|
-
|
|
186
|
-
```
|
|
187
|
-
// Reconcile session state with actual running agents
|
|
188
|
-
const running = list_agents({})
|
|
189
|
-
// Compare with meta.json active tasks
|
|
190
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
191
|
-
```
|
|
192
|
-
|
|
193
|
-
### Named Agent Targeting
|
|
194
|
-
|
|
195
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
196
|
-
- `send_message({ target: "SCAN-001", items: [...] })` -- send explorer findings to scanner
|
|
197
|
-
- `assign_task({ target: "IMPL-001", items: [...] })` -- assign UX fix from designer output
|
|
198
|
-
- `close_agent({ target: "TEST-001" })` -- cleanup after UX testing
|
|
199
|
-
|
|
200
|
-
### Explorer-Assisted Scanning
|
|
201
|
-
|
|
202
|
-
Coordinator spawns explorer (utility member) early to gather codebase context, then sends findings to scanner via upstream context:
|
|
203
|
-
```
|
|
204
|
-
// Explorer results inform scanner's scope
|
|
205
|
-
send_message({
|
|
206
|
-
target: "SCAN-001",
|
|
207
|
-
items: [
|
|
208
|
-
{ type: "text", text: `## Explorer Findings
|
|
209
|
-
component_patterns: <explorer's component inventory>
|
|
210
|
-
framework: <detected framework>
|
|
211
|
-
ui_library: <detected UI library>` }
|
|
212
|
-
]
|
|
213
|
-
})
|
|
214
|
-
```
|
|
215
|
-
|
|
216
|
-
## Error Handling
|
|
217
|
-
|
|
218
|
-
| Scenario | Resolution |
|
|
219
|
-
|----------|------------|
|
|
220
|
-
| Unknown command | Error with available command list |
|
|
221
|
-
| Role not found | Error with role registry |
|
|
222
|
-
| Project path invalid | Re-prompt user for valid path |
|
|
223
|
-
| Framework detection fails | request_user_input for framework selection |
|
|
224
|
-
| Session corruption | Attempt recovery, fallback to manual |
|
|
225
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
226
|
-
| No UI issues found | Complete with empty fix list, generate clean bill report |
|
|
227
|
-
| Test iterations exceeded | Accept current state, continue to completion |
|
|
1
|
+
---
|
|
2
|
+
name: team-ux-improve
|
|
3
|
+
description: Unified team skill for UX improvement. Systematically discovers and fixes UI/UX interaction issues including unresponsive buttons, missing feedback, and state refresh problems. Uses team-worker agent architecture with roles/ for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team ux improve".
|
|
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__ace-tool__search_context(*), mcp__ccw-tools__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team UX Improve
|
|
8
|
+
|
|
9
|
+
Systematic UX improvement pipeline: scan -> diagnose -> design -> implement -> test. 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-ux-improve", args="<project-path> [--framework react|vue]")
|
|
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 v
|
|
29
|
+
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
+
scanner diagnoser designer implementer 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
|
+
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | SCAN-* | false |
|
|
39
|
+
| diagnoser | [roles/diagnoser/role.md](roles/diagnoser/role.md) | DIAG-* | false |
|
|
40
|
+
| designer | [roles/designer/role.md](roles/designer/role.md) | DESIGN-* | false |
|
|
41
|
+
| implementer | [roles/implementer/role.md](roles/implementer/role.md) | IMPL-* | true |
|
|
42
|
+
| tester | [roles/tester/role.md](roles/tester/role.md) | TEST-* | false |
|
|
43
|
+
|
|
44
|
+
## Utility Member Registry
|
|
45
|
+
|
|
46
|
+
**Coordinator-only**: Utility members can only be spawned by Coordinator. Workers CANNOT call spawn_agent() to spawn utility members.
|
|
47
|
+
|
|
48
|
+
| Utility Member | Path | Callable By | Purpose |
|
|
49
|
+
|----------------|------|-------------|---------|
|
|
50
|
+
| explorer | [roles/explorer/role.md](roles/explorer/role.md) | Coordinator only | Explore codebase for UI component patterns and framework-specific patterns |
|
|
51
|
+
|
|
52
|
+
## Role Router
|
|
53
|
+
|
|
54
|
+
Parse `$ARGUMENTS`:
|
|
55
|
+
- Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
|
|
56
|
+
- No `--role` → `roles/coordinator/role.md`, execute entry router
|
|
57
|
+
|
|
58
|
+
## Delegation Lock
|
|
59
|
+
|
|
60
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
61
|
+
|
|
62
|
+
Before calling ANY tool, apply this check:
|
|
63
|
+
|
|
64
|
+
| Tool Call | Verdict | Reason |
|
|
65
|
+
|-----------|---------|--------|
|
|
66
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
67
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
68
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
69
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
70
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
71
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
72
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
73
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
74
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
75
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
76
|
+
|
|
77
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
78
|
+
|
|
79
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
80
|
+
|
|
81
|
+
---
|
|
82
|
+
|
|
83
|
+
## Shared Constants
|
|
84
|
+
|
|
85
|
+
- **Session prefix**: `ux-improve`
|
|
86
|
+
- **Session path**: `.workflow/.team/ux-improve-<timestamp>/`
|
|
87
|
+
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
88
|
+
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
89
|
+
- **Max test iterations**: 5
|
|
90
|
+
|
|
91
|
+
## Worker Spawn Template
|
|
92
|
+
|
|
93
|
+
Coordinator spawns workers using this template:
|
|
94
|
+
|
|
95
|
+
```
|
|
96
|
+
spawn_agent({
|
|
97
|
+
agent_type: "team_worker",
|
|
98
|
+
task_name: "<task-id>",
|
|
99
|
+
fork_context: false,
|
|
100
|
+
items: [
|
|
101
|
+
{ type: "text", text: `## Role Assignment
|
|
102
|
+
role: <role>
|
|
103
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
104
|
+
session: <session-folder>
|
|
105
|
+
session_id: <session-id>
|
|
106
|
+
requirement: <task-description>
|
|
107
|
+
inner_loop: <true|false>
|
|
108
|
+
|
|
109
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
110
|
+
|
|
111
|
+
{ type: "text", text: `## Task Context
|
|
112
|
+
task_id: <task-id>
|
|
113
|
+
title: <task-title>
|
|
114
|
+
description: <task-description>
|
|
115
|
+
pipeline_phase: <pipeline-phase>` },
|
|
116
|
+
|
|
117
|
+
{ type: "text", text: `## Upstream Context
|
|
118
|
+
<prev_context>` }
|
|
119
|
+
]
|
|
120
|
+
})
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
### Model Selection Guide
|
|
127
|
+
|
|
128
|
+
UX improvement has an explorer utility member and a scan-diagnose-design-implement-test pipeline.
|
|
129
|
+
|
|
130
|
+
| Role | reasoning_effort | Rationale |
|
|
131
|
+
|------|-------------------|-----------|
|
|
132
|
+
| explorer | low | File reading and pattern summarization only (utility member) |
|
|
133
|
+
| scanner | medium | Broad UI/UX issue scanning, pattern-based detection |
|
|
134
|
+
| diagnoser | high | Root cause diagnosis of UX issues requires deep analysis |
|
|
135
|
+
| designer | high | UX improvement design needs careful user experience reasoning |
|
|
136
|
+
| implementer | high | UI code changes must preserve existing behavior |
|
|
137
|
+
| tester | medium | Test execution follows defined UX verification criteria |
|
|
138
|
+
|
|
139
|
+
## User Commands
|
|
140
|
+
|
|
141
|
+
| Command | Action |
|
|
142
|
+
|---------|--------|
|
|
143
|
+
| `check` / `status` | View execution status graph |
|
|
144
|
+
| `resume` / `continue` | Advance to next step |
|
|
145
|
+
|
|
146
|
+
## Specs Reference
|
|
147
|
+
|
|
148
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
149
|
+
|
|
150
|
+
## Session Directory
|
|
151
|
+
|
|
152
|
+
```
|
|
153
|
+
.workflow/.team/ux-improve-<timestamp>/
|
|
154
|
+
├── .msg/
|
|
155
|
+
│ ├── messages.jsonl # Team message bus
|
|
156
|
+
│ └── meta.json # Pipeline config + role state snapshot
|
|
157
|
+
├── artifacts/ # Role deliverables
|
|
158
|
+
│ ├── scan-report.md # Scanner output
|
|
159
|
+
│ ├── diagnosis.md # Diagnoser output
|
|
160
|
+
│ ├── design-guide.md # Designer output
|
|
161
|
+
│ ├── fixes/ # Implementer output
|
|
162
|
+
│ └── test-report.md # Tester output
|
|
163
|
+
├── explorations/ # Explorer cache
|
|
164
|
+
│ └── cache-index.json
|
|
165
|
+
└── wisdom/ # Session knowledge base
|
|
166
|
+
├── contributions/ # Worker contributions (write-only for workers)
|
|
167
|
+
├── principles/
|
|
168
|
+
├── patterns/
|
|
169
|
+
└── anti-patterns/
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
## v4 Agent Coordination
|
|
173
|
+
|
|
174
|
+
### Message Semantics
|
|
175
|
+
|
|
176
|
+
| Intent | API | Example |
|
|
177
|
+
|--------|-----|---------|
|
|
178
|
+
| Queue supplementary info (don't interrupt) | `send_message` | Send explorer findings to running scanner |
|
|
179
|
+
| Assign implementation from design | `assign_task` | Assign IMPL task from designer output |
|
|
180
|
+
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
181
|
+
|
|
182
|
+
### Agent Health Check
|
|
183
|
+
|
|
184
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
185
|
+
|
|
186
|
+
```
|
|
187
|
+
// Reconcile session state with actual running agents
|
|
188
|
+
const running = list_agents({})
|
|
189
|
+
// Compare with meta.json active tasks
|
|
190
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
### Named Agent Targeting
|
|
194
|
+
|
|
195
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
196
|
+
- `send_message({ target: "SCAN-001", items: [...] })` -- send explorer findings to scanner
|
|
197
|
+
- `assign_task({ target: "IMPL-001", items: [...] })` -- assign UX fix from designer output
|
|
198
|
+
- `close_agent({ target: "TEST-001" })` -- cleanup after UX testing
|
|
199
|
+
|
|
200
|
+
### Explorer-Assisted Scanning
|
|
201
|
+
|
|
202
|
+
Coordinator spawns explorer (utility member) early to gather codebase context, then sends findings to scanner via upstream context:
|
|
203
|
+
```
|
|
204
|
+
// Explorer results inform scanner's scope
|
|
205
|
+
send_message({
|
|
206
|
+
target: "SCAN-001",
|
|
207
|
+
items: [
|
|
208
|
+
{ type: "text", text: `## Explorer Findings
|
|
209
|
+
component_patterns: <explorer's component inventory>
|
|
210
|
+
framework: <detected framework>
|
|
211
|
+
ui_library: <detected UI library>` }
|
|
212
|
+
]
|
|
213
|
+
})
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
## Error Handling
|
|
217
|
+
|
|
218
|
+
| Scenario | Resolution |
|
|
219
|
+
|----------|------------|
|
|
220
|
+
| Unknown command | Error with available command list |
|
|
221
|
+
| Role not found | Error with role registry |
|
|
222
|
+
| Project path invalid | Re-prompt user for valid path |
|
|
223
|
+
| Framework detection fails | request_user_input for framework selection |
|
|
224
|
+
| Session corruption | Attempt recovery, fallback to manual |
|
|
225
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
226
|
+
| No UI issues found | Complete with empty fix list, generate clean bill report |
|
|
227
|
+
| Test iterations exceeded | Accept current state, continue to completion |
|
|
@@ -141,7 +141,7 @@ Delegate to `@commands/monitor.md#handleSpawnNext`:
|
|
|
141
141
|
5. Output pipeline summary with [coordinator] prefix
|
|
142
142
|
6. Execute completion action:
|
|
143
143
|
```
|
|
144
|
-
request_user_input({
|
|
144
|
+
functions.request_user_input({
|
|
145
145
|
prompt: "Pipeline complete. What next?\n\nOptions:\n1. Archive & Clean - Archive session and clean up team resources\n2. Keep Active - Keep session for follow-up work\n3. Export Results - Export deliverables to specified location"
|
|
146
146
|
})
|
|
147
147
|
```
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
"role_spec": "roles/coordinator/role.md",
|
|
20
20
|
"task_prefix": null,
|
|
21
21
|
"inner_loop": false,
|
|
22
|
-
"allowed_tools": ["Agent", "
|
|
22
|
+
"allowed_tools": ["Agent", "request_user_input", "Read", "Write", "Bash", "Glob", "Grep", "TaskList", "TaskGet", "TaskUpdate", "TaskCreate", "TeamCreate", "TeamDelete", "SendMessage", "mcp__ccw-tools__team_msg"],
|
|
23
23
|
"description": "Orchestrates the UX improvement pipeline, spawns workers, monitors progress"
|
|
24
24
|
},
|
|
25
25
|
{
|