Awesome-omni-skill canvas
Spawn interactive terminal TUI components (calendars, documents, flight bookings) with real-time IPC communication. Display rich content and collect user selections in tmux split panes.
git clone https://github.com/diegosouzapw/awesome-omni-skill
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/design/canvas" ~/.claude/skills/diegosouzapw-awesome-omni-skill-canvas && rm -rf "$T"
skills/design/canvas/SKILL.mdCanvas TUI Toolkit
Interactive terminal displays (TUIs) that spawn in tmux split panes and communicate via IPC. Use for calendars, documents, flight bookings, and other rich interactive scenarios.
When to Use
- Displaying calendars and picking meeting times
- Showing markdown documents with text selection
- Comparing flights and selecting seats
- Any scenario requiring visual display + user interaction
- When you need to show rich content without blocking the conversation
Quick Start
cd ${SKILL_DIR} # Display calendar in current terminal bun run src/cli.ts show calendar # Spawn interactive meeting picker in tmux split bun run src/cli.ts spawn calendar --scenario meeting-picker --config '{ "calendars": [ {"name": "Alice", "color": "blue", "events": [...]}, {"name": "Bob", "color": "green", "events": [...]} ] }'
Available Canvas Types
| Canvas | Purpose | Scenarios |
|---|---|---|
| Display calendars, pick meeting times | , |
| View/edit markdown documents | , , |
| Flight comparison and seat selection | |
Spawning Canvases
Always use
for interactive scenarios - opens canvas in tmux split pane.spawn
bun run src/cli.ts spawn [kind] --scenario [name] --config '[json]'
Parameters:
: Canvas type (calendar, document, flight)kind
: Interaction mode--scenario
: JSON configuration for the canvas--config
: Optional canvas instance ID for IPC--id
Calendar Canvas
Display Scenario
View-only calendar display.
bun run src/cli.ts show calendar --config '{ "title": "My Week", "events": [ { "id": "1", "title": "Meeting", "startTime": "2026-01-07T09:00:00", "endTime": "2026-01-07T10:00:00" } ] }'
Meeting Picker Scenario
Interactive time slot selection across multiple calendars.
bun run src/cli.ts spawn calendar --scenario meeting-picker --config '{ "calendars": [ { "name": "Alice", "color": "blue", "events": [ {"id": "1", "title": "Standup", "startTime": "2026-01-07T09:00:00", "endTime": "2026-01-07T09:30:00"} ] } ], "slotGranularity": 30, "minDuration": 30, "maxDuration": 120 }'
Controls:
- Mouse click: Select a free time slot
: Navigate weeks←/→
: Jump to todayt
orq
: CancelEsc
Returns:
{ "startTime": "2026-01-07T14:00:00", "endTime": "2026-01-07T15:00:00", "duration": 60 }
Document Canvas
Display Scenario
Read-only markdown document.
# Spawn in new tmux pane (recommended) bun run src/cli.ts spawn document --config '{ "content": "# Hello World\n\nThis is **markdown**.", "title": "My Document" }' # Or show inline in current terminal bun run src/cli.ts show document --config '{ "content": "# Hello World\n\nThis is **markdown**.", "title": "My Document" }'
Edit Scenario
Interactive document with text selection and diff highlighting.
bun run src/cli.ts spawn document --scenario edit --config '{ "content": "# Blog Post\n\nSelect some text here.", "title": "Edit Mode", "diffs": [ {"startOffset": 20, "endOffset": 30, "type": "add"} ] }'
Controls:
- Mouse click and drag: Select text
: Navigate document↑/↓
: Closeq
Returns:
{ "selectedText": "some text", "startOffset": 12, "endOffset": 21, "startLine": 3, "endLine": 3 }
Flight Canvas
Booking Scenario
Flight comparison and seat selection with cyberpunk theme.
bun run src/cli.ts spawn flight --scenario booking --config '{ "flights": [ { "id": "ua123", "airline": "United Airlines", "flightNumber": "UA 123", "origin": { "code": "SFO", "name": "San Francisco International", "city": "San Francisco", "timezone": "PST" }, "destination": { "code": "DEN", "name": "Denver International", "city": "Denver", "timezone": "MST" }, "departureTime": "2026-01-08T12:55:00-08:00", "arrivalTime": "2026-01-08T16:37:00-07:00", "duration": 162, "price": 34500, "currency": "USD", "cabinClass": "economy", "aircraft": "Boeing 737-800", "stops": 0, "seatmap": { "rows": 30, "seatsPerRow": ["A", "B", "C", "D", "E", "F"], "aisleAfter": ["C"], "unavailable": ["1A", "1B", "1C"], "premium": ["2A", "2B"], "occupied": ["3A", "4B"] } } ] }'
Controls:
: Navigate between flights↑/↓
: Switch to seatmapTab
(in seatmap): Move cursor←/→/↑/↓
: Select seatSpace
: ConfirmEnter
: Cancelq
Returns:
{ "selectedFlight": { ... }, "selectedSeat": "12A" }
IPC Communication
Canvases communicate via Unix domain sockets.
Canvas → Controller:
{ type: "ready", scenario } // Canvas ready { type: "selected", data } // User made selection { type: "cancelled", reason? } // User cancelled { type: "error", message } // Error occurred
Controller → Canvas:
{ type: "update", config } // Update canvas config { type: "close" } // Close canvas { type: "ping" } // Health check
Programmatic API
import { pickMeetingTime, editDocument, bookFlight } from "${SKILL_DIR}/src/api"; // Meeting picker const meeting = await pickMeetingTime({ calendars: [...], slotGranularity: 30, }); // Document editor const doc = await editDocument({ content: "# My Document", title: "Edit Mode", }); // Flight booking const flight = await bookFlight({ flights: [...] });
Requirements
- tmux: Canvas spawning requires active tmux session
- Bun: Runtime for executing canvas commands
- Terminal with mouse support: For interactive scenarios
File Structure
canvas/ ├── SKILL.md # This file ├── README.md # Additional documentation ├── package.json # Dependencies ├── run-canvas.sh # Wrapper script ├── src/ │ ├── cli.ts # CLI entry point │ ├── canvases/ # React/Ink canvas components │ ├── scenarios/ # Scenario definitions │ ├── ipc/ # IPC server/client │ └── api/ # High-level API └── scripts/ # Helper scripts
Tips
- Always check for tmux session before spawning:
tmux list-sessions - Use
for quick displays,show
for interactive scenariosspawn - Canvas IDs are optional but useful for managing multiple canvases
- IPC sockets are created in
/tmp/canvas-*.sock - Canvases auto-cleanup on exit or error
Examples
Example 1: Pick Meeting Time
# User: "Find a time for Alice and Bob to meet tomorrow" # You: Spawn meeting picker bun run src/cli.ts spawn calendar --scenario meeting-picker --config '{ "calendars": [ {"name": "Alice", "color": "blue", "events": [...]}, {"name": "Bob", "color": "green", "events": [...]} ], "slotGranularity": 30 }' # Wait for selection, then confirm with user
Example 2: Review Document
# User: "Show me the email draft" # You: Display email in document canvas bun run src/cli.ts spawn document --config '{ "content": "Dear Team,\n\nPlease review...", "title": "Email Draft" }'
Example 3: Book Flight
# User: "Compare these flights and pick a seat" # You: Spawn flight booking canvas bun run src/cli.ts spawn flight --scenario booking --config '{ "flights": [...] }' # Wait for user to select flight + seat