docs: reflect Phase 2 completion across all project documentation
Update progress log with Phase 2 deliverables, mark Phase 2 complete in TODO/CHANGELOG/README, fix stale Solid.js reference in findings, update task_plan status to BUILDING, add v2 key paths to CLAUDE.md.
This commit is contained in:
parent
05ad0db092
commit
54b0d44bc1
7 changed files with 47 additions and 19 deletions
|
|
@ -132,17 +132,17 @@ Zellij uses WASM plugins for extensibility:
|
|||
|
||||
## 6. Frontend Framework Choice
|
||||
|
||||
### Why Solid.js
|
||||
- **Fine-grained reactivity** — updates only the DOM nodes that changed, not the component tree
|
||||
### Why Svelte 5 (revised from initial Solid.js choice)
|
||||
- **Fine-grained reactivity** — $state/$derived runes match Solid's signals model
|
||||
- **No VDOM** — critical when we have 4-8 panes each streaming data
|
||||
- **Small bundle** — ~7KB vs React's ~40KB
|
||||
- **JSX familiar** — easy for anyone who knows React
|
||||
- **Signals** — perfect for streaming agent state
|
||||
- **Small bundle** — ~5KB runtime vs React's ~40KB
|
||||
- **Larger ecosystem** — more component libraries, xterm.js wrappers, better tooling
|
||||
- **Better TypeScript support** — improved in Svelte 5
|
||||
|
||||
### Alternative: Svelte
|
||||
- Also no VDOM, also reactive, slightly larger community
|
||||
- Slightly more ceremony for stores/state management
|
||||
- Would also work, personal preference
|
||||
### Why NOT Solid.js (initial choice, revised)
|
||||
- Ecosystem too small for production use
|
||||
- Fewer component libraries and integrations
|
||||
- Svelte 5 runes eliminated the ceremony gap
|
||||
|
||||
### NOT React
|
||||
- VDOM reconciliation across 4-8 simultaneously updating panes = CPU waste
|
||||
|
|
|
|||
|
|
@ -43,5 +43,22 @@
|
|||
- [x] Project meta files: CLAUDE.md, .claude/CLAUDE.md, TODO.md, CHANGELOG.md
|
||||
- [x] Documentation structure: docs/README.md, task_plan.md, phases.md, findings.md, progress.md
|
||||
|
||||
### Phase 2: Terminal Pane + Layout (complete)
|
||||
- [x] Rust PTY backend with portable-pty (PtyManager: spawn, write, resize, kill)
|
||||
- [x] PTY reader thread emitting Tauri events (pty-data-{id}, pty-exit-{id})
|
||||
- [x] Tauri commands: pty_spawn, pty_write, pty_resize, pty_kill
|
||||
- [x] xterm.js terminal pane with Canvas addon (explicit, no WebGL)
|
||||
- [x] Catppuccin Mocha theme for xterm.js (16 ANSI colors)
|
||||
- [x] FitAddon with ResizeObserver + 100ms debounce
|
||||
- [x] PTY bridge adapter (spawnPty, writePty, resizePty, killPty, onPtyData, onPtyExit)
|
||||
- [x] CSS Grid tiling layout with 5 presets (1-col, 2-col, 3-col, 2x2, master-stack)
|
||||
- [x] Layout store with Svelte 5 $state runes and auto-preset selection
|
||||
- [x] Sidebar with session list, layout preset selector, new terminal button
|
||||
- [x] Keyboard shortcuts: Ctrl+N new terminal, Ctrl+1-4 focus pane
|
||||
- [x] PaneContainer with header bar (title, status, close)
|
||||
- [x] Empty state welcome screen with Ctrl+N hint
|
||||
- [x] npm dependencies: @xterm/xterm, @xterm/addon-canvas, @xterm/addon-fit
|
||||
- [x] Cargo dependencies: portable-pty, uuid
|
||||
|
||||
### Next Steps
|
||||
- [ ] Begin Phase 2: Terminal Pane + Layout (CSS Grid, xterm.js, PTY)
|
||||
- [ ] Begin Phase 3: Agent SDK Integration (Node.js sidecar, SDK message adapter)
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
## Goal
|
||||
Redesign BTerminal from a GTK3 terminal emulator into a **multi-session Claude agent dashboard** optimized for 32:9 ultrawide (5120x1440). Simultaneous visibility of all active sessions, agent tree visualization, inline markdown rendering, maximum information density.
|
||||
|
||||
## Status: PLANNING (Rev 2 — post-adversarial review)
|
||||
## Status: BUILDING (Phase 2 complete — Rev 2)
|
||||
|
||||
---
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue