mirror of
https://github.com/olehomelchenko/astrolabe-nvc.git
synced 2025-12-21 21:22:23 +00:00
41 lines
1.9 KiB
Markdown
41 lines
1.9 KiB
Markdown
# CLAUDE.md
|
|
|
|
Instructions for Claude Code when working on this project.
|
|
|
|
## Project Overview
|
|
|
|
**Astrolabe** is a lightweight, browser-based snippet manager for Vega-Lite visualizations. Pure vanilla JavaScript, no build tools, retro Windows 2000 aesthetic.
|
|
|
|
## Architecture
|
|
|
|
- **Frontend-only**: HTML/CSS/JavaScript with CDN dependencies (Monaco Editor, Vega-Embed)
|
|
- **Storage**:
|
|
- **Snippets**: localStorage with Phase 0 schema (id, name, created, modified, spec, draftSpec, comment, tags, datasetRefs, meta)
|
|
- **Datasets**: IndexedDB (unlimited size, multi-format: JSON/CSV/TSV/TopoJSON, inline & URL sources)
|
|
- **Structure**: Three resizable panels (snippet library, Monaco editor, live preview) + Dataset Manager modal
|
|
- **No build tools**: Open `index.html` directly in browser (needs local server for IndexedDB)
|
|
|
|
## Current Status
|
|
|
|
**Completed**: Phases 0-12 (Core functionality + Dataset Management + Advanced Dataset Features)
|
|
**Next**: Phase 13 - Polish & UX Refinements or Phase 14 - Advanced Snippet Features
|
|
|
|
### Key Features Implemented
|
|
- ✅ Snippet management with draft/published workflow
|
|
- ✅ Multi-field sorting and real-time search
|
|
- ✅ Storage monitoring and import/export
|
|
- ✅ **Dataset management with IndexedDB**
|
|
- Multi-format support (JSON, CSV, TSV, TopoJSON)
|
|
- Multi-source support (inline data, URL references)
|
|
- Automatic metadata calculation and URL fetching
|
|
- Dataset reference resolution in Vega-Lite specs
|
|
- Modal UI with button-group selectors
|
|
- ✅ **Advanced Dataset Features (Phase 12)**
|
|
- Bidirectional snippet ↔ dataset linking with usage tracking
|
|
- Extract inline data to datasets
|
|
- Import/Export datasets with auto-format detection
|
|
- Table preview with type detection (🔢📅🔤✓)
|
|
- On-demand URL preview loading with caching
|
|
|
|
See `docs/dev-plan.md` for complete roadmap and technical details.
|
|
- when updating documentation, do not record intermediate changes - write them always as a matter-of-fact information |