GymStats — писал для себя, открыт для всех, кто ходит в спортзал

от автора

Был я как-то очередной раз в спортзале: делал упражнения, поглядывая на предыдущие значения из заметок и записывая новые туда же. Придя домой, я обновил файл новыми данными и решил, что больше не хочу заниматься этой фигнёй, и что мне нужен сервис, который мне с этим всем поможет.

Я даже не пытался искать готовое решение — яжпрограммист. Мне хотелось сделать что-то под себя, чтобы идеально подходило под мои потребности.

Главная страница

Главная страница

А мне нужно было:
— быстро записать результаты;
— видеть список упражнений с изображением;
— иметь возможность фильтра упражнений по группам мышц, которые я задаю для тренировки;
— указывать вес;
— иметь возможность посмотреть результаты предыдущей тренировки;
— видеть статистику на графике.

И вскоре я взялся за написание этого сервиса. Решил попробовать написать на чистом Blazor — это была ошибка. Проблема в том, что для работы необходимо постоянно держать страницу с сайтом открытой. Стоит свернуть браузер или заблокировать телефон дольше, чем на минуту — и сайт терял соединение и требовал перезагрузки страницы.

Тем не менее, я сделал свой сервис, которым успешно пользовался. И по ходу использования исправлял кучу багов и придумал множество способов упростить работу с сервисом, делая каждый поход в спортзал всё более комфортным.

Несмотря на то что сайт был опубликован и имеет собственный домен, он был закрыт для других пользователей, но я оставил для них поле ввода электронной почты на случай, если решу открыть. Даже получил несколько писем.

Для того, чтобы пользователи понимали, для чего регистрируются, я сделал специальный аккаунт только для чтения с небольшим количеством данных.

В момент поиска новой работы освободилось много времени и я решил, что переписывание сайта на Go + React + MongoDB — это отличный способ решить проблему потери связи и вспомнить, как с этим всем работать. К тому моменту уже появились LLM-ки и переписывание на другой язык превратилось в сказку. Мне особенно понравилось, как фактически в один клик можно перевести запрос к MongoDB в код на Go.

В итоге я это так и не зарелизил. Я получил нужный опыт, а переезжать на другой хостинг не хотелось.

Шли месяцы — и я решил, что можно уже и открыть сайт для всех, а также заодно изменить подход.

На этот раз я использовал связку Blazor + API. Переезд прошёл довольно легко. Оставались изображения. Они были скриншотами из книги, но релизить такое я не хотел. Незадолго до этого как раз вышла NanoBanana, чем я и воспользовался, успешно изменив более сотни изображений и добавив новые, для упражнений на кардио.

Страница тренировки

Страница тренировки

Новую версию я сделал мультиязычной, добавив к английскому языку русский и испанский. Также добавил тёмную версию. Пользоваться им стало ещё приятнее. Он стал первым сервисом, который я использую на испанском (всё-таки в испаноязычном окружении живу).

По ссылке непосредственно сам сервис: https://gymstats.info/
Просто посмотреть: https://gymstats.info/watch

Он бесплатный, без СМС, но с регистрацией. А если хотите поблагодарить, то там есть ссылка.


Немного о том, как работает внутри

Как я уже написал выше, это Blazor с API на C# (очевидно). Фронт максимально простой, на Bootstrap.

Из особенностей лишь то, что считаю очень важным для любого проекта: любые ошибки не только логируются, но и прилетают в Телеграм через персонального бота. Там указано название сервиса (не только этот шлёт сообщения), окружение, подробный текст исключения и запрос, который к этому привёл.

Подобный подход я уже внедрял в одном сервисе на работе, где сообщения прилетали не только с ошибками, но и при условии изменения некоторых метрик. На текущем месте соответствующей pull request уже ждёт своего часа. Очень рекомендую! При этом для команды эти сообщения должны быть в приоритете — только так это будет работать. С таким подходом вы избавитесь от всех багов за считанные недели, а у новых не будет шансов потеряться в логах или быть исправленными с большим опозданием.


Пользуйтесь, сообщайте о найденных проблемах или предложения через обратную связь и будьте здоровы.

ссылка на оригинал статьи https://habr.com/ru/articles/1036640/