feat: calvana application microsite + ship-log extension

- Static site: /manifesto, /live, /hire pages
- Ship-log Pi extension: calvana_ship, calvana_oops, calvana_deploy tools
- Docker + nginx deploy to calvana.quikcue.com
- Terminal-ish dark aesthetic, mobile responsive
- Auto-updating /live page from extension state
This commit is contained in:
2026-03-02 18:03:22 +08:00
commit 2fb612b1df
73 changed files with 10938 additions and 0 deletions

138
specs/pi-pi.md Normal file
View File

@@ -0,0 +1,138 @@
# Pi Pi — Meta Agent Spec
## Purpose
A Pi extension that builds Pi agents. The "Pi Pi" agent is a meta-agent — it knows how to create extensions, themes, skills, settings, prompt templates, and TUI components by querying a team of domain-specific research agents in parallel.
## Architecture
```
User Request: "Build me a Pi agent that does X"
┌──────────────────────────────────┐
│ Primary Agent ("Pi Pi") │
│ Tools: read,write,edit,bash, │
│ grep,find,ls, │
│ query_expert │
│ Role: WRITER — gathers info │
│ from experts, then builds │
└──────┬───────────────────────────┘
│ query_expert (parallel)
├──────────────────────────┐──────────────────────┐──────────────────────┐──────────────────────┐
▼ ▼ ▼ ▼ ▼
┌─────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐
│ ext-expert │ │ theme-expert │ │ skill-expert │ │ config-expert│ │ tui-expert │
│ Extensions │ │ Themes │ │ Skills │ │ Settings │ │ TUI/UI │
│ Tools, cmds │ │ JSON format │ │ SKILL.md │ │ Providers │ │ Components │
│ Events, API │ │ Color tokens │ │ Frontmatter │ │ Models │ │ Rendering │
│ │ │ Hot reload │ │ Directories │ │ Packages │ │ Keyboard │
│ read-only │ │ read-only │ │ read-only │ │ read-only │ │ read-only │
└─────────────┘ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────┘
```
## Flow
1. User asks the primary Pi Pi agent to build something
2. Primary agent identifies which domains are relevant
3. Primary dispatches `query_expert` calls in PARALLEL to all relevant experts
4. Each expert:
a. Uses `/skill:firecrawl` to scrape fresh Pi documentation for their domain
b. Searches the local codebase for existing patterns and examples
c. Returns structured research findings
5. Primary agent receives ALL expert responses
6. Primary agent synthesizes the information and WRITES the actual files
## Expert Agents
### ext-expert (Extensions)
- **Domain**: Pi extensions — custom tools, events, commands, shortcuts, flags, state management, custom rendering, overriding tools
- **Doc URL**: `https://raw.githubusercontent.com/badlogic/pi-mono/refs/heads/main/packages/coding-agent/docs/extensions.md`
- **Tools**: read,grep,find,ls,bash
- **First action**: Fetch fresh extensions.md via firecrawl
### theme-expert (Themes)
- **Domain**: Pi themes — JSON format, 51 color tokens, vars, hex/256-color values, hot reload
- **Doc URL**: `https://raw.githubusercontent.com/badlogic/pi-mono/refs/heads/main/packages/coding-agent/docs/themes.md`
- **Tools**: read,grep,find,ls,bash
- **First action**: Fetch fresh themes.md via firecrawl
### skill-expert (Skills)
- **Domain**: Pi skills — SKILL.md format, frontmatter, directories, validation, /skill:name commands
- **Doc URL**: `https://raw.githubusercontent.com/badlogic/pi-mono/refs/heads/main/packages/coding-agent/docs/skills.md`
- **Tools**: read,grep,find,ls,bash
- **First action**: Fetch fresh skills.md via firecrawl
### config-expert (Settings & Providers)
- **Domain**: Pi settings, providers, models, packages, keybindings — settings.json, models.json, packages, enabledModels
- **Doc URLs**: settings.md, providers.md, models.md, packages.md, keybindings.md
- **Tools**: read,grep,find,ls,bash
- **First action**: Fetch fresh settings.md + providers.md via firecrawl
### tui-expert (TUI Components)
- **Domain**: Pi TUI — Component interface, Text, Box, Container, Markdown, Image, keyboard input, custom components, overlays, theming, SelectList, SettingsList, BorderedLoader, widgets, footers, editors
- **Doc URL**: `https://raw.githubusercontent.com/badlogic/pi-mono/refs/heads/main/packages/coding-agent/docs/tui.md`
- **Tools**: read,grep,find,ls,bash
- **First action**: Fetch fresh tui.md via firecrawl
## Extension Structure
File: `extensions/pi-pi.ts`
### Differences from agent-team.ts
| Feature | agent-team | pi-pi |
|---------|-----------|-------|
| Primary tools | dispatch_agent ONLY | read,write,edit,bash,grep,find,ls + query_expert |
| Subagent tools | varies per agent | read,grep,find,ls,bash (read-only + bash for firecrawl) |
| Dispatch model | Sequential | Parallel (LLM calls query_expert N times) |
| Subagent sessions | Persistent | Ephemeral (--no-session) |
| System prompt | Generic dispatcher | Specialized meta-agent builder |
| First prompt | None | Each expert fetches fresh docs on first query |
### Tool: query_expert
```typescript
pi.registerTool({
name: "query_expert",
label: "Query Expert",
description: "Query a domain expert for Pi documentation and patterns. Experts research in parallel. Use multiple query_expert calls in one response for parallel research.",
parameters: Type.Object({
expert: Type.String({ description: "Expert name: ext-expert, theme-expert, skill-expert, config-expert, tui-expert" }),
question: Type.String({ description: "What to research — be specific about what you need to build" }),
}),
})
```
### Widget
Grid of expert cards showing:
- Expert name and status (idle/researching/done/error)
- Current question being researched
- Elapsed time
### Justfile Entry
```just
ext-pi-pi:
pi -e extensions/pi-pi.ts
```
## Agent Definition Files
Located in `.pi/agents/`:
- `ext-expert.md`
- `theme-expert.md`
- `skill-expert.md`
- `config-expert.md`
- `tui-expert.md`
Teams entry in `.pi/agents/teams.yaml`:
```yaml
pi-pi:
- ext-expert
- theme-expert
- skill-expert
- config-expert
- tui-expert
```