AgentSkillsCN

tabz-development

用于构建与调试 TabzChrome 本身的模式。适用于在 Terminal.tsx、xterm.js 集成、WebSocket I/O、尺寸调整处理,或任何 TabzChrome 扩展程序/后端代码中使用。

SKILL.md
--- frontmatter
name: tabz-development
description: "Patterns for building and debugging TabzChrome itself. Use when working on Terminal.tsx, xterm.js integration, WebSocket I/O, resize handling, or any TabzChrome extension/backend code."

TabzChrome Development

Reference patterns for building TabzChrome's terminal implementation.

Core Architecture

code
extension/components/Terminal.tsx  →  WebSocket  →  backend/modules/pty-handler.js
         ↓                                                    ↓
    xterm.js render                                      tmux session

Key Files

FilePurpose
extension/components/Terminal.tsxxterm.js terminal + resize
extension/hooks/useTerminalSessions.tsSession lifecycle
extension/background/websocket.tsWebSocket management
backend/modules/pty-handler.jsPTY spawning, tmux

Quick Patterns

Terminal Initialization

typescript
const term = new Terminal({ /* options */ });
const fitAddon = new FitAddon();
term.loadAddon(fitAddon);
term.open(containerRef.current);
fitAddon.fit();

Resize Handling

typescript
// Debounce resize, sync xterm → PTY
fitAddon.fit();
ws.send(JSON.stringify({ type: 'resize', cols: term.cols, rows: term.rows }));

WebSocket I/O

typescript
// Terminal → Backend
term.onData(data => ws.send(JSON.stringify({ type: 'input', data })));
// Backend → Terminal
ws.onmessage = (e) => term.write(JSON.parse(e.data).data);

References

See references/ for detailed patterns:

  • xterm-patterns.md - Terminal setup, addons, options
  • resize-handling.md - Debouncing, PTY sync
  • websocket-io.md - Message protocol, reconnection
  • testing-checklist.md - Manual test scenarios