8.7 KiB
Разомнись — Exercise Reminder
Windows desktop приложение, которое помогает делать короткие перерывы без потери фокуса: держит план дня, напоминает размяться, ведёт недельные челленджи и превращает Dota 2 статистику после матча в игровые долги.
Что внутри
- Гибкие напоминания — любое количество упражнений, интервал от минуты до часов, разные иконки.
- Питание — отдельная вкладка с приёмами пищи по времени суток (завтрак/обед/ужин/перекусы), выбор дней недели, пресеты быстрого добавления. Напоминания по настенным часам, а не по интервалу.
- История и стрики — heatmap-календарь активности, ежедневный счётчик, серия дней подряд.
- Обзор — главный экран с ближайшим действием, планом дня, уровнем, недельными мини-челленджами и игровым долгом.
- Помощник дня — советы по пропускам, питанию, вечерним провалам, короткие разминка-сессии и недельная аналитика.
- Пресеты — готовые наборы упражнений для офиса, спины/шеи, минимального дня и нагрузки после катки.
- Тихие часы — окно времени когда напоминания подавляются (например
22:00 → 08:00), с выбором дней недели. - Сделал частично — степпер
−/+в окне напоминания: если ты сделал 5 из 10, в историю запишется честное число. - Игровая интеграция (Dota 2) — Game State Integration читает статистику матча, после Победа/Поражение показывает экран с «причитающимися» повторениями и помогает разбить большой долг на подходы.
- Фирменный desktop-интерфейс — Plus Jakarta Sans + Bricolage Grotesque, мягкая палитра, sidebar, spring-анимации, светлая/тёмная/системная тема.
- Два языка — русский и английский, переключение мгновенное.
- Auto-update — приложение само скачивает новые версии из фиксированного
update-channel(проверка каждый час, силент-ретрай при сетевых сбоях).
Скриншоты
TODO: вставить screenshots Dashboard / Reminder / Match summary (light + dark).
Установка
Скачай последний Exercise-Reminder-Setup-X.Y.Z.exe со страницы релизов и запусти. Установщик:
- Создаёт ярлык на рабочем столе и в Пуске
- Сохраняет настройки в
%APPDATA%\Exercise Reminder\ - При запуске поверх существующей инсталляции — обновляет, настройки сохраняются
Windows SmartScreen может предупредить «не доверено» — приложение не подписано code-signing сертификатом. Нажми Подробнее → Выполнить в любом случае.
Разработка
git clone https://git.xn--90adajar8af4h.xn--p1ai/AnRil/laude.git
cd laude
npm install
npm run dev
Полезные команды:
npm run typecheck # tsc по main + renderer
npm run verify # typecheck + tests + lint + build + audit summary
npm run test # vitest в watch-режиме
npm run test:run # vitest один раз (для CI)
npm run dev:renderer # renderer-стенд с демо-данными для UI-проверки
npm run build # сборка без NSIS
npm run dist # сборка + NSIS-инсталлятор → release/
npm run release -- -Bump patch # bump версии + tag + push + upload в Gitea
Документ RELEASING.md описывает процесс выпуска новых версий.
Архитектура
- Electron 42 — multi-process: main (Node/scheduler/GSI) + preload (contextBridge) + renderer (React)
- Renderer — React 18, TypeScript 5, Vite 7, Tailwind 3, framer-motion, react-router, zustand
- Persistence — единственный JSON-файл
%APPDATA%\Exercise Reminder\app-state.json(debounced writes) - IPC — типизированные каналы через
src/shared/ipc.ts, обёрнуто preload-ом - i18n — самописная микро-система:
src/renderer/src/i18n/dict.ts(плоский словарь ~200 ключей × 2 языка) + хукuseT() - Auto-update —
electron-updaterсgenericprovider, манифестlatest.ymlлежит в Gitea release attachments - GSI Dota 2 — локальный HTTP-сервер слушает GameStateIntegration коллбэки от Steam, парсит match-end events
Тесты
src/main/validate.test.ts (78)
src/renderer/src/lib/history.test.ts (31)
src/renderer/src/i18n/i18n.test.ts (15)
src/renderer/src/lib/format.test.ts (14)
src/main/scheduler.test.ts (14)
src/main/games/vdf.test.ts (11)
src/main/store.test.ts (12)
src/renderer/src/lib/achievements.test.ts (10)
src/shared/release-notes.test.ts (9)
src/shared/meals.test.ts (8)
src/main/meeting-detect.test.ts (8)
src/shared/quiet-hours.test.ts (7)
src/main/adaptive.test.ts (6)
src/renderer/src/lib/day-plan.test.ts (6)
src/shared/types.test.ts (4)
src/renderer/src/lib/icon-choices.test.ts (4)
src/renderer/src/lib/momentum.test.ts (3)
src/main/autostart.test.ts (3)
──────────────────────────────────────────
245 ✓
Покрытие: IPC-валидация (упражнения/челленджи/приёмы пищи), persistence (миграции, карантин битого JSON, history cap), scheduler-гейтинг (тихие часы, ВКС-пауза, daily-goal), планирование приёмов пищи по времени суток (DST-safe), детект ВКС, история/стрики (DST), тихие часы (wrap), парсер VDF для Steam-конфигов, достижения, i18n с плюрализацией RU/EN, дефолты shared-типов.
Лицензия
Проприетарная — все права защищены. Личное некоммерческое использование разрешено; копирование, распространение, модификация и реверс-инжиниринг — без письменного разрешения автора. Полный текст — в файле LICENSE. По вопросам использования за рамками лицензии открой issue в репозитории.
Stack
- Electron · runtime
- electron-vite · build
- React + TypeScript
- Tailwind CSS · стили
- framer-motion · анимации
- lucide-react · иконки
- electron-updater · auto-update
- Vitest · тесты
- Шрифты: Plus Jakarta Sans, Bricolage Grotesque, JetBrains Mono