Files
NomadArch/dev-docs/SUMMARY.md
Gemini AI 157449a9ad restore: recover deleted documentation, CI/CD, and infrastructure files
Restored from origin/main (b4663fb):
- .github/ workflows and issue templates
- .gitignore (proper exclusions)
- .opencode/agent/web_developer.md
- AGENTS.md, BUILD.md, PROGRESS.md
- dev-docs/ (9 architecture/implementation docs)
- docs/screenshots/ (4 UI screenshots)
- images/ (CodeNomad icons)
- package-lock.json (dependency lockfile)
- tasks/ (25+ project task files)

Also restored original source files that were modified:
- packages/ui/src/App.tsx
- packages/ui/src/lib/logger.ts
- packages/ui/src/stores/instances.ts
- packages/server/src/server/routes/workspaces.ts
- packages/server/src/workspaces/manager.ts
- packages/server/src/workspaces/runtime.ts
- packages/server/package.json

Kept new additions:
- Install-*.bat/.sh (enhanced installers)
- Launch-*.bat/.sh (new launchers)
- README.md (SEO optimized with GLM 4.7)
2025-12-23 13:03:48 +04:00

349 lines
8.7 KiB
Markdown

# 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:**
1. **Foundation** (Week 1) - Project setup, process management
2. **Core Chat** (Week 2) - Message display, SSE streaming
3. **Essential Features** (Week 3) - Markdown, agents, errors
4. **Multi-Instance** (Week 4) - Multiple projects support
5. **Advanced Input** (Week 5) - Commands, file attachments
6. **Polish** (Week 6) - UX refinements, settings
7. **System Integration** (Week 7) - Native features
8. **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:
1. Read task file completely
2. Review related documentation
3. Follow steps in order
4. Check off acceptance criteria
5. Test thoroughly
6. Move to done/ when complete
### Code Standards:
- TypeScript for everything
- No `any` types
- 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:
1. **Read all documentation**
- Understand architecture
- Review UI specifications
- Study technical approach
2. **Start with Task 001**
- Set up project structure
- Install dependencies
- Verify build works
3. **Follow sequential order**
- Each task builds on previous
- Don't skip ahead
- Dependencies matter
4. **Track progress**
- Update task checkboxes
- Move completed tasks to done/
- Update roadmap as you go
### When You Hit Issues:
1. Review task prerequisites
2. Check documentation for clarification
3. Look at related specs
4. Ask questions on unclear requirements
5. 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 started
- `docs/architecture.md` - System design
- `docs/user-interface.md` - UI specifications
- `docs/technical-implementation.md` - Implementation details
- `tasks/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:
1. Exact OpenCode CLI syntax for spawning server
2. Expected stdout format for port extraction
3. SDK package location and version
4. Any platform-specific gotchas
5. 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! 🚀