- README: add GPX upload feature to fiche list and intro section - CLAUDE.md: clarify ADR convention (per-work-item vs global) - ET-005: add YAML frontmatter to business request - PH-7: document F-07/F-08 done, F-10 pending in phase BRD - docs/architecture: add client modules table (app.js, units.js, gpx.js)
1.6 KiB
1.6 KiB
Архитектура Enduro Trails
Обзор
Веб-приложение для планирования эндуро-маршрутов с визуализацией рельефа.
Компоненты
- Frontend — MapLibre GL JS, vanilla JS (ES modules)
- Backend API — FastAPI (Python 3.12), uvicorn
- Tile Server — статические raster tiles (PNG), раздаются через FastAPI/nginx
- Routing Engine — OSRM с кастомным эндуро-профилем
- Database — SQLite + Spatialite (точки интереса, маршруты)
Слои карты
- Base map (OpenStreetMap)
- Hillshade (рельеф с тенями)
- TRI (Terrain Ruggedness Index — сложность рельефа)
- Hypsometric (высотная раскраска)
- Trails (маршруты из OSM)
Деплой
Один Docker Compose на mva154. Nginx проксирует /enduro/ на контейнер.
Клиентские модули (src/web/)
| Модуль | Описание | Work Item |
|---|---|---|
app.js |
Главный модуль: MapLibre, роутинг, UI, тёмная тема | PH-1..PH-6 |
units.js |
Централизованный форматтер расстояний (км/мили), localStorage, событие unitchange |
ET-005 |
gpx.js |
GPX 1.1 парсер (DOMParser), рендеринг треков/waypoints, canvas-профиль высот, rebuildMapOverlays() |
ET-006 |
style.json |
MapLibre стиль (светлая тема) | PH-1/PH-5 |
style-dark.json |
MapLibre стиль (тёмная тема) | PH-5 |