Features: - Binary-Free Mode: No OpenCode binary required - NomadArch Native mode with free Zen models - Native session management - Provider routing (Zen, Qwen, Z.AI) - Fixed MCP connection with explicit connectAll() - Updated installers and launchers for all platforms - UI binary selector with Native option Free Models Available: - GPT-5 Nano (400K context) - Grok Code Fast 1 (256K context) - GLM-4.7 (205K context) - Doubao Seed Code (256K context) - Big Pickle (200K context)
8.7 KiB
CodeNomad - Project Summary
Current Status
We have completed the MVP milestones (Phases 1-3) and are now operating in post-MVP mode. Future work prioritizes multi-instance support, advanced input polish, and system integrations outlined in later phases.
What We've Created
A comprehensive specification and task breakdown for building the CodeNomad desktop application.
Directory Structure
packages/opencode-client/
├── docs/ # Comprehensive documentation
│ ├── architecture.md # System architecture & design
│ ├── user-interface.md # UI/UX specifications
│ ├── technical-implementation.md # Technical details & patterns
│ ├── build-roadmap.md # Phased development plan
│ └── SUMMARY.md # This file
├── tasks/
│ ├── README.md # Task management guide
│ ├── todo/ # Tasks to implement
│ │ ├── 001-project-setup.md
│ │ ├── 002-empty-state-ui.md
│ │ ├── 003-process-manager.md
│ │ ├── 004-sdk-integration.md
│ │ └── 005-session-picker-modal.md
│ └── done/ # Completed tasks (empty)
└── README.md # Project overview
Documentation Overview
1. Architecture (architecture.md)
What it covers:
- High-level system design
- Component layers (Main process, Renderer, Communication)
- State management approach
- Tab hierarchy (Instance tabs → Session tabs)
- Data flow for key operations
- Technology stack decisions
- Security considerations
Key sections:
- Component architecture diagram
- Instance/Session state structures
- Communication patterns (HTTP, SSE)
- Error handling strategies
- Performance considerations
2. User Interface (user-interface.md)
What it covers:
- Complete UI layout specifications
- Visual design for every component
- Interaction patterns
- Keyboard shortcuts
- Accessibility requirements
- Empty states and error states
- Modal designs
Key sections:
- Detailed layout wireframes (ASCII art)
- Component-by-component specifications
- Message rendering formats
- Control bar designs
- Modal/overlay specifications
- Color schemes and typography
3. Technical Implementation (technical-implementation.md)
What it covers:
- Technology stack details
- Project file structure
- State management patterns
- Process management implementation
- SDK integration approach
- SSE event handling
- IPC communication
- Error handling strategies
- Performance optimizations
Key sections:
- Complete project structure
- TypeScript interfaces
- Process spawning logic
- SDK client management
- Message rendering implementation
- Build and packaging config
4. Build Roadmap (build-roadmap.md)
What it covers:
- 8 development phases
- Task dependencies
- Timeline estimates
- Success criteria per phase
- Risk mitigation
- Release strategy
Phases:
- Foundation (Week 1) - Project setup, process management
- Core Chat (Week 2) - Message display, SSE streaming
- Essential Features (Week 3) - Markdown, agents, errors
- Multi-Instance (Week 4) - Multiple projects support
- Advanced Input (Week 5) - Commands, file attachments
- Polish (Week 6) - UX refinements, settings
- System Integration (Week 7) - Native features
- Advanced (Week 8+) - Performance, plugins
Task Breakdown
Current Tasks (Phase 1)
001 - Project Setup (2-3 hours)
- Set up Electron + SolidJS + Vite
- Configure TypeScript, TailwindCSS
- Create basic project structure
- Verify build pipeline works
002 - Empty State UI (2-3 hours)
- Create empty state component
- Implement folder selection dialog
- Add keyboard shortcuts
- Style and test responsiveness
003 - Process Manager (4-5 hours)
- Spawn OpenCode server processes
- Parse stdout for port extraction
- Kill processes on command
- Handle errors and timeouts
- Auto-cleanup on app quit
004 - SDK Integration (3-4 hours)
- Create SDK client per instance
- Fetch sessions, agents, models
- Implement session CRUD operations
- Add error handling and retries
005 - Session Picker Modal (3-4 hours)
- Build modal with session list
- Agent selector for new sessions
- Keyboard navigation
- Loading and error states
Total Phase 1 time: ~15-20 hours (2-3 weeks part-time)
Key Design Decisions
1. Two-Level Tabs
- Level 1: Instance tabs (one per project folder)
- Level 2: Session tabs (multiple per instance)
- Allows working on multiple projects with multiple conversations each
2. Process Management in Main Process
- Electron main process spawns servers
- Parses stdout to get port
- IPC sends port to renderer
- Ensures clean shutdown on app quit
3. One SDK Client Per Instance
- Each instance has its own HTTP client
- Connects to different port (different server)
- Isolated state prevents cross-contamination
4. SolidJS for Reactivity
- Fine-grained reactivity for SSE updates
- No re-render cascades
- Better performance for real-time updates
- Smaller bundle size than React
5. No Virtual Scrolling or Performance Optimization in MVP
- Start with simple list rendering
- Don't optimize for large sessions initially
- Focus on functionality, not performance
- Add optimizations in post-MVP phases if needed
- Reduces initial complexity and speeds up development
6. Messages and Tool Calls Inline
- All activity shows in main message stream
- Tool calls expandable/collapsible
- File changes visible inline
- Single timeline view
Implementation Guidelines
For Each Task:
- Read task file completely
- Review related documentation
- Follow steps in order
- Check off acceptance criteria
- Test thoroughly
- Move to done/ when complete
Code Standards:
- TypeScript for everything
- No
anytypes - Descriptive variable names
- Comments for complex logic
- Error handling on all async operations
- Loading states for all network calls
Testing Approach:
- Manual testing at each step
- Test on minimum window size (800x600)
- Test error cases
- Test edge cases (long text, special chars)
- Keyboard navigation verification
Next Steps
To Start Building:
-
Read all documentation
- Understand architecture
- Review UI specifications
- Study technical approach
-
Start with Task 001
- Set up project structure
- Install dependencies
- Verify build works
-
Follow sequential order
- Each task builds on previous
- Don't skip ahead
- Dependencies matter
-
Track progress
- Update task checkboxes
- Move completed tasks to done/
- Update roadmap as you go
When You Hit Issues:
- Review task prerequisites
- Check documentation for clarification
- Look at related specs
- Ask questions on unclear requirements
- Document blockers and solutions
Success Metrics
MVP (After Task 015)
- Can select folder → spawn server → chat
- Messages stream in real-time
- Can switch agents and models
- Tool executions visible
- Basic error handling works
- Performance is NOT a concern - focus on functionality
Beta (After Task 030)
- Multi-instance support
- Advanced input (files, commands)
- Polished UX
- Settings and preferences
- Native menus
v1.0 (After Task 035)
- System tray integration
- Auto-updates
- Crash reporting
- Production-ready stability
Useful References
Within This Project:
README.md- Project overview and getting starteddocs/architecture.md- System designdocs/user-interface.md- UI specificationsdocs/technical-implementation.md- Implementation detailstasks/README.md- Task workflow guide
External:
- OpenCode server API: https://opencode.ai/docs/server/
- Electron docs: https://electronjs.org/docs
- SolidJS docs: https://solidjs.com
- Kobalte UI: https://kobalte.dev
Questions to Resolve
Before starting implementation, clarify:
- Exact OpenCode CLI syntax for spawning server
- Expected stdout format for port extraction
- SDK package location and version
- Any platform-specific gotchas
- Icon and branding assets location
Estimated Timeline
Conservative estimate (part-time, ~15 hours/week):
- Phase 1 (MVP Foundation): 2-3 weeks
- Phase 2 (Core Chat): 2 weeks
- Phase 3 (Essential): 2 weeks
- MVP Complete: 6-7 weeks
Aggressive estimate (full-time, ~40 hours/week):
- Phase 1: 1 week
- Phase 2: 1 week
- Phase 3: 1 week
- MVP Complete: 3 weeks
Add 2-4 weeks for testing, bug fixes, and polish before alpha release.
This is a Living Document
As you build:
- Update estimates based on actual time
- Add new tasks as needed
- Refine specifications
- Document learnings
- Track blockers and solutions
Good luck! 🚀