From task-orchestrator
Generates hierarchical project dashboard of work items organized by container, showing IDs, tags, status, priority. Use for project status, summaries, overviews.
npx claudepluginhub jpicklyk/task-orchestrator --plugin task-orchestratorThis skill uses the workspace's default tool permissions.
Generate a PM-ready project dashboard. The goal is to show the full project state in one view — every container, every item, with enough detail (IDs, tags, priority, status) to make decisions and take action. Supplement the data with brief observations only when there is a genuine anomaly or actionable insight.
Guides MCP work item role transitions: identifies by UUID/title, checks gate status/missing notes/guidance, suggests advance triggers like start/complete/block/cancel.
Mandates invoking relevant skills via tools before any response in coding sessions. Covers access, priorities, and adaptations for Claude Code, Copilot CLI, Gemini CLI.
Share bugs, ideas, or general feedback.
Generate a PM-ready project dashboard. The goal is to show the full project state in one view — every container, every item, with enough detail (IDs, tags, priority, status) to make decisions and take action. Supplement the data with brief observations only when there is a genuine anomaly or actionable insight.
If $ARGUMENTS is provided:
parentId for all queries belowquery_items(operation="search", query="<text>") — pick the best-matching root or container item and use its UUID as parentIdAskUserQuestion to clarifyWhen scoped to a parentId, modify the data collection calls:
query_items(operation="overview", itemId="<parentId>") — scoped overview of that subtreequery_items(operation="search", parentId="<parentId>", limit=200) — scoped item detailsget_context(includeAncestors=true) — still global (filter to scope in analysis phase)get_next_item(limit=5, includeAncestors=true, parentId="<parentId>") — scoped recommendationsIf no $ARGUMENTS, proceed with the global (unscoped) data collection as written below.
query_items(operation="overview", includeChildren=true) — all root items with childCounts per role and direct childrenquery_items(operation="search", limit=200) — all items with full fields: id, parentId, title, role, priority, depth, tagsget_context(includeAncestors=true) — active (work/review), blocked, and stalled itemsget_next_item(limit=5, includeAncestors=true) — dependency-aware ranked recommendationsWhy 4 calls: Overview gives hierarchy structure and child counts. Search gives tags and priority for every item (overview children lack these fields). get_context gives active/blocked/stalled signals. get_next_item gives dependency-aware recommendations that search cannot provide.
Before rendering, cross-reference the data sources:
searchMap[id] = { priority, tags, role } from the search resultsparentId. For each parent, count children by role: childRoleCounts[parentId] = { queue: N, work: N, review: N, blocked: N, terminal: N }. This powers the Children column in tables.priority, tags, and child role counts from the mapstags value (first tag if multiple). Items with no tag go into an "Uncategorized" group.| Pattern | Classification | Rendering |
|---|---|---|
| Has non-terminal children | Active container | Full section with children table |
| All children terminal | Completed container | Done footer |
| No children, non-terminal role | Standalone item | Standalone Items table |
| No children, terminal role | Completed standalone | Done footer |
Note: Overview
childCountsreflects direct children only. Active grandchildren can exist under a terminal root. Cross-reference withget_contextresults.
Render the dashboard in this exact section order. Omit any section that has no data.
## ◆ Work Summary
[One sentence assessing project health and momentum.]
**X active · Y blocked · Z stalled · W queued · V done**
Counts come from the search results grouped by role. "active" = work + review roles. "done" = terminal role.
Omit this entire section if there are no blocked or stalled items.
### ⊘ Attention Required
| ID | Item | Container | Issue |
|----|------|-----------|-------|
| `short-id` | <title> | <parent title or —> | Blocked by: `<blocker-id>` <blocker-title> |
| `short-id` | <title> | <parent title or —> | Stalled: missing `<note-key>`, `<note-key>` |
For blocked items, show what is blocking them. For stalled items, show which required notes are missing.
If there is actionable context (e.g., blocker is not in active work, or a stalled item has a guidancePointer), add a brief observation line below the table — one sentence max.
Include the short ID so the user can reference items in follow-up commands.
This is the core of the dashboard. Show every active container with its children.
For each active container (has non-terminal children), render:
#### <Container Title> `<8-char-id>`
<role-symbol> <role> · <N open> · <N done>
| ID | Title | Status | Pri | Tags | Children |
|----|-------|--------|-----|------|----------|
| `xxxxxxxx` | <child title> | ◉ work | high | feature-task | — |
| `yyyyyyyy` | <child title> | ○ queue | med | — | 2○ 1◉ |
| `zzzzzzzz` | <child title> | ⊘ blocked | high | bug | — |
✓ N completed: <comma-separated titles of terminal children>
Rendering rules for container sections:
✓ N completed line below the table. If 0 completed, omit the line. If more than 5 completed, show first 3 titles then (+N more).<N open> = queue + work + review + blocked children countparentId), show a compact role summary using the format N○ N◉ N⊘ N✓ (omit roles with zero count). If the item has no children, show —.— if nonehigh, med, low, or — if default/unsetIf a container itself is in work/review role, prefix its header with the role symbol: #### ◉ Tech Debt \89d02e32``
Root items (depth 0) that have no children and are non-terminal. Omit section if none.
Grouping strategy — adaptive, hierarchy-first:
Items with a parentId are always shown under their container in Section 3 — hierarchy wins over tags. Standalone items (no parent) are grouped by tag in this section. This adapts to how the user organizes work:
Rendering rules:
Multi-group format:
### Standalone Items
#### feature-implementation
| ID | Title | Status | Pri | Children |
|----|-------|--------|-----|----------|
| `xxxxxxxx` | <title> | ○ queue | med | — |
#### bug-fix
| ID | Title | Status | Pri | Children |
|----|-------|--------|-----|----------|
| `yyyyyyyy` | <title> | ○ queue | high | — |
#### Uncategorized
| ID | Title | Status | Pri | Children |
|----|-------|--------|-----|----------|
| `zzzzzzzz` | <title> | ○ queue | med | — |
Single-group format (all same tag or all uncategorized):
### Standalone Items
| ID | Title | Status | Pri | Tags | Children |
|----|-------|--------|-----|------|----------|
| `xxxxxxxx` | <title> | ○ queue | med | — | — |
Note: when items are grouped by tag, the Tags column is omitted from the table (the tag subheading already conveys it). When rendered as a flat table, include the Tags column.
From get_next_item results. Omit if no recommendations.
### ▸ Recommended Next
| ID | Title | Container | Pri |
|----|-------|-----------|-----|
| `xxxxxxxx` | <title> | <parent title or —> | high |
These items are queue-role, not blocked by dependencies, ranked by priority then complexity. Brief observation (one sentence) only if there's a parallelization opportunity or if all recommendations come from the same container.
Compact footer for completed work. Omit if nothing is terminal.
### ✓ Done (N total)
**Completed containers:** <title> (N children) · <title> (N children)
**Completed standalone:** <title> · <title> · (+N more if >5)
N total = count of all terminal root items (containers + standalone).
Do NOT render a UUID reference table in the dashboard output. The user references items by short ID only.
Instead, retain the short→full UUID mapping as internal agent context. When the user references a short ID in a follow-up command (e.g., "start 0499a6aa"), resolve it to the full UUID silently for the MCP tool call. The search results from data collection provide all the full UUIDs needed.
Status symbols: ✓ terminal · ◉ work/review · ⊘ blocked/stalled · ○ queue
Short IDs: First 8 characters of the UUID, rendered in backticks: `af21ed9a`
Use — for empty/null values, not 0 or blank.
Priority abbreviations: high, med, low in tables.
Observations: Write them sparingly — only when there is a genuine anomaly, bottleneck, or actionable insight. A healthy project needs zero observations. Do not fill space with "work is progressing normally" — the data speaks for itself.
Empty containers: Root items where ALL childCounts are zero and role is non-terminal. If any exist, note them at the end of the inventory section: **Empty (no items):** <title>, <title>