create-team
Acerca de
La habilidad `create-team` genera un nuevo archivo de composición de equipos multiagente, adhiriéndose a la plantilla agent-almanac y a las convenciones del registro. Maneja la definición de propósito, selección de miembros, patrones de coordinación y la creación automatizada de README para definir flujos de trabajo coordinados. Úsala al componer agentes para tareas colaborativas complejas y recurrentes o procesos de revisión.
Instalación rápida
Claude Code
Recomendadonpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-teamCopia y pega este comando en Claude Code para instalar esta habilidad
Documentación
Create a New Team
Define multi-agent team composition. Coordinate two or more agents for tasks needing multiple perspectives, specialties, or phases. Resulting team file integrates with teams registry. Can be activated in Claude Code by name.
When Use
- Task needs many perspectives one agent cannot give (e.g., code review plus security audit plus architecture review)
- Need recurring collaborative workflow with consistent role assignments and handoff patterns
- Existing agent composition used often, should be formalized
- Complex process naturally breaks into phases or specialties handled by different agents
- Want to define coordinated group for sprint-based, pipeline-based, or parallel work
Inputs
- Required: Team name (lowercase kebab-case, e.g.,
data-pipeline-review) - Required: Team purpose (one paragraph describing what problem needs many agents)
- Required: Lead agent (must exist in
agents/_registry.yml) - Optional: Coordination pattern (default: hub-and-spoke). One of:
hub-and-spoke,sequential,parallel,timeboxed,adaptive - Optional: Number of members (default: 3-4; recommended range: 2-5)
- Optional: Source material (existing workflow, runbook, or ad-hoc team composition to formalize)
Steps
Step 1: Define Team Purpose
Spell out what problem needs many agents working together. Valid team purpose must answer:
- What outcome does this team deliver? (e.g., comprehensive review report, deployed application, sprint increment)
- Why can't single agent do this? Identify at least two distinct specialties or perspectives needed.
- When should this team activate? Define trigger conditions.
Write purpose as one paragraph human or agent can read to decide whether to activate this team.
Got: Clear paragraph explaining team's value. At least two distinct specialties identified.
If fail: Cannot identify two distinct specialties? Task likely does not need team. Use single agent with multiple skills instead.
Step 2: Select Lead Agent
Lead agent orchestrates team. Pick agent from agents/_registry.yml that:
- Has domain expertise relevant to team's primary output
- Can decompose incoming requests into subtasks for other members
- Can synthesize results from many reviewers into coherent deliverable
# List all available agents
grep "^ - id:" agents/_registry.yml
Lead must also show as member in team composition (lead always a member).
Got: One agent picked as lead. Confirmed to exist in agents registry.
If fail: No existing agent fits lead role? Create one first using create-agent skill (or agents/_template.md by hand). Do not create team with lead that does not exist as agent definition.
Step 3: Select Member Agents
Pick 2-5 members (including lead) with clear, non-overlapping responsibilities. For each member, define:
- id: Agent name from agents registry
- role: Short title (e.g., "Quality Reviewer", "Security Auditor", "Architecture Reviewer")
- responsibilities: One sentence describing what this member does that no other member does
# Verify each candidate agent exists
grep "id: agent-name-here" agents/_registry.yml
Validate non-overlap: no two members should have same primary responsibility. Responsibilities overlap? Merge roles or sharpen boundaries.
Got: 2-5 members picked, each with unique role and clear responsibilities. All confirmed in agents registry.
If fail: Needed agent does not exist? Create first. Responsibilities overlap between two members? Rewrite to clarify boundaries or drop one member.
Step 4: Choose Coordination Pattern
Pick pattern fitting team's workflow. Five patterns and use cases:
| Pattern | When to Use | Example Teams |
|---|---|---|
| hub-and-spoke | Lead distributes tasks, collects results, synthesizes. Best for review and audit workflows. | r-package-review, gxp-compliance-validation, ml-data-science-review |
| sequential | Each agent builds on prior agent's output. Best for pipelines and staged workflows. | fullstack-web-dev, tending |
| parallel | All agents work at once on independent subtasks. Best when subtasks have no dependencies. | devops-platform-engineering |
| timeboxed | Work organized into fixed-length iterations. Best for ongoing project work with backlog. | scrum-team |
| adaptive | Team self-organizes based on task. Best for unknown or highly variable tasks. | opaque-team |
Decision guide:
- Lead must see all results before producing output → hub-and-spoke
- Agent B needs agent A's output to start → sequential
- All agents can work without seeing each other's output → parallel
- Work spans many iterations with planning ceremonies → timeboxed
- Cannot predict task structure in advance → adaptive
Got: One coordination pattern picked with clear rationale.
If fail: Unsure? Default to hub-and-spoke. Most common pattern, works for most review and analysis workflows.
Step 5: Design Task Decomposition
Define how typical incoming request splits across team members. Structure as phases:
- Setup phase: What lead does to analyze request and create tasks
- Execution phase: What each member works on (in parallel, in sequence, or per-sprint depending on coordination pattern)
- Synthesis phase: How results collected and final deliverable produced
For each member, list 3-5 concrete tasks they would do on typical request. These tasks show in both "Task Decomposition" prose section and CONFIG block's tasks list.
Got: Phase-structured decomposition with concrete tasks per member, matching picked coordination pattern.
If fail: Tasks too vague (e.g., "reviews things")? Make specific (e.g., "reviews code style against tidyverse style guide, checks test coverage, evaluates error message quality").
Step 6: Write the Team File
Copy template. Fill in all sections:
cp teams/_template.md teams/<team-name>.md
Fill in these sections in order:
- YAML frontmatter:
name,description,lead,version("1.0.0"),author,created,updated,tags,coordination,members[](each with id, role, responsibilities) - Title:
# Team Name(human-readable, title case) - Introduction: One paragraph summary
- Purpose: Why this team exists, what specialties it combines
- Team Composition: Table with Member, Agent, Role, Focus Areas columns
- Coordination Pattern: Prose description plus ASCII diagram of flow
- Task Decomposition: Phased breakdown with concrete tasks per member
- Configuration: Machine-readable CONFIG block (see Step 7)
- Usage Scenarios: 2-3 concrete scenarios with example user prompts
- Limitations: 3-5 known constraints
- See Also: Links to member agent files and related skills/teams
Got: Complete team file with all sections filled in. No placeholder text left from template.
If fail: Compare against existing team file (e.g., teams/r-package-review.md) to verify structure. Search for template placeholder strings like "your-team-name" or "another-agent" to find unfilled sections.
Step 7: Write the CONFIG Block
CONFIG block between <!-- CONFIG:START --> and <!-- CONFIG:END --> markers gives machine-readable YAML for tooling. Structure as follows:
<!-- CONFIG:START -->
```yaml
team:
name: <team-name>
lead: <lead-agent-id>
coordination: <pattern>
members:
- agent: <agent-id>
role: <role-title>
subagent_type: <agent-id> # Claude Code subagent type for spawning
# ... repeat for each member
tasks:
- name: <task-name>
assignee: <agent-id>
description: <one-line description>
# ... repeat for each task
- name: synthesize-report # final task if hub-and-spoke
assignee: <lead-agent-id>
description: <synthesis description>
blocked_by: [<prior-task-names>] # for dependency ordering
```
<!-- CONFIG:END -->
subagent_type field maps to Claude Code agent types. For agents defined in .claude/agents/, use agent id as subagent_type. Use blocked_by for task dependencies (e.g., synthesis blocked by all review tasks).
Got: CONFIG block is valid YAML. All agents match those in frontmatter members list. Task dependencies form valid DAG (no cycles).
If fail: Validate YAML syntax. Verify every assignee in tasks list matches agent in members list. Check blocked_by references only task names defined earlier in list.
Step 8: Add to Registry
Edit teams/_registry.yml. Add new team:
- id: <team-name>
path: <team-name>.md
lead: <lead-agent-id>
members: [<agent-id-1>, <agent-id-2>, ...]
coordination: <pattern>
description: <one-line description matching frontmatter>
Bump total_teams count at top of registry (currently 8; becomes 9 after adding one team).
# Verify the entry was added
grep "id: <team-name>" teams/_registry.yml
Got: New entry shows in registry. total_teams count incremented by one.
If fail: Team name already in registry? Pick different name or update existing entry. Verify YAML indentation matches existing entries.
Step 9: Run README Automation
Regenerate README files from updated registry:
npm run update-readmes
Updates dynamic sections in teams/README.md and other files with <!-- AUTO:START --> / <!-- AUTO:END --> markers referencing team data.
Got: Command exits 0. teams/README.md now lists new team.
If fail: Run npm run check-readmes to see which files out of sync. Script fails? Verify package.json exists in repo root and js-yaml installed (npm install).
Step 10: Verify Team Activation
Test team can be activated in Claude Code:
User: Use the <team-name> team to <typical task description>
Claude reads teams/<team-name>.md, extracts CONFIG block, orchestrates activation:
- Calls
TeamCreatewith team name and description - Spawns teammates via
Agenttool using each member'ssubagent_typefrom CONFIG block - Creates tasks via
TaskCreatewithblocked_bydependencies from CONFIG block - Lead agent coordinates work following coordination pattern
Note: Teams not auto-discovered from .claude/teams/. Claude reads definition directly from teams/ when asked.
Got: Claude reads team file, creates team via TeamCreate, spawns right agents, follows coordination pattern.
If fail: Verify team file at teams/<team-name>.md (not in subdirectory). Check all member agents exist in agents/. Confirm CONFIG block has valid YAML with subagent_type for each member. Confirm team listed in teams/_registry.yml.
Step 11: Scaffold Translations
Required for all teams. This step applies to both human authors and AI agents following this procedure. Do not skip — missing translations pile into stale backlog.
Scaffold translation files for all 4 supported locales right after committing new team:
for locale in de zh-CN ja es; do
npm run translate:scaffold -- teams <team-name> "$locale"
done
Then translate scaffolded prose in each file (code blocks and IDs stay English). Finally regenerate status files:
npm run translation:status
Got: 4 files created at i18n/{de,zh-CN,ja,es}/teams/<team-name>.md, all with source_commit matching current HEAD. npm run validate:translations shows 0 stale warnings for new team.
If fail: Scaffold fails? Verify team exists in teams/_registry.yml. Status files don't update? Run npm run translation:status explicitly.
Checks
- Team file exists at
teams/<team-name>.md - YAML frontmatter parses without errors
- All required frontmatter fields present:
name,description,lead,version,author,coordination,members[] - Each member in frontmatter has
id,role,responsibilities - All sections present: Purpose, Team Composition, Coordination Pattern, Task Decomposition, Configuration, Usage Scenarios, Limitations, See Also
- CONFIG block exists between
<!-- CONFIG:START -->and<!-- CONFIG:END -->markers - CONFIG block YAML valid and parseable
- All member agent ids exist in
agents/_registry.yml - Lead agent shows in members list
- No two members share same primary responsibility
- Team listed in
teams/_registry.ymlwith right path, lead, members, coordination -
total_teamscount in registry incremented -
npm run update-readmesfinishes without errors
Pitfalls
- Too many members: Teams with more than 5 members → hard to coordinate. Overhead of distributing tasks and synthesizing results outweighs benefit of extra perspectives. Split into two teams or cut to essential specialties.
- Overlapping responsibilities: Two members both "review code quality"? Findings will conflict, lead wastes time deduplicating. Each member must have clearly distinct focus area.
- Wrong coordination pattern: Using hub-and-spoke when agents need each other's output (should be sequential), or using sequential when agents can work independently (should be parallel). Review decision guide in Step 4.
- Missing CONFIG block: CONFIG block not optional prose decoration. Machine-readable spec Claude uses to orchestrate
TeamCreate, agent spawning, task creation. Without it, team only activatable through ad-hoc prose interpretation, less reliable. - Lead agent not in members list: Lead must also show as member with own role and responsibilities. Lead who only "coordinates" without substantive work wastes slot. Give lead concrete review or synthesis responsibility.
See Also
create-skill- follows same meta-pattern for creating SKILL.md filescreate-agent- create agent definitions serving as team memberscommit-changes- commit new team file and registry updates
Repositorio GitHub
Habilidades relacionadas
content-collections
MetaEsta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.
polymarket
MetaEsta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.
creating-opencode-plugins
MetaEsta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.
sglang
MetaSGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.
