wasrusgen
|
76fce9ec58
|
feat(analytics): assembler schedule parser + analytics screen
Backend:
- assembler_parser.py: parse Excel «Таблица занятости сборщиков»
- Handles both row-order variants (2026: dates row1; 2025-: dates row2)
- Extracts amount from end of cell text, supports compound "6030+20100"
- aggregate(): by_assembler×month + by_month totals
- In-memory cache with mtime invalidation
- main.py: /api/assembler_analytics — local file first, Drive fallback
- LOCAL: /app/data/assembler_schedule.xlsx (mounted volume)
- Config: ASSEMBLER_SCHEDULE_PATH env var override
- config.py: assembler_schedule_file_id for Drive fallback
- docker-compose.yml: /opt/zov-tech/data → /app/data:ro volume
Frontend:
- assembler_analytics.js: year filter, monthly table, assembler ranking
with progress bars, per-order average, last-6-months breakdown
- app.js: route #/admin/assembler-analytics + "Аналитика" button
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-05-19 09:44:34 +03:00 |
|