Полная глава 2 «Строение вещества» в одном файле (1195 строк, 7 экспортов). §8 Дискретное строение: - 3 карточки (молекулы и атомы / шкала размеров от 1 м до ядра / доказательства) - IV-1 СИМ: визуальная шкала размеров (8 объектов с цветными барами) - IV-2 СИМ: конструктор молекул H₂O/CO₂/O₂/N₂/CH4/NaCl с SVG-схемами и описаниями - IV-3 DnD: 8 объектов по 3 корзинам (атом/молекула/тело) - IV-4 ТРН: 5 вопросов §9 Тепловое движение. Диффузия: - 3 карточки (хаотическое движение / диффузия и её скорость / примеры) - IV-1 СИМ: анимированная диффузия 60 частиц (20 чернил + 40 воды), slider T → ускорение броуновского движения, кнопка «Сброс», requestAnimationFrame - IV-2 КВИЗ: 3 вопроса о диффузии и броун. движении - IV-3 DnD: 6 примеров → 3 скорости (быстро газ / средне жидк / медленно тверд) - IV-4 ТРН: 5 вопросов §10 Взаимодействие частиц: - 3 карточки (отталкивание/равновесие/притяжение / зачем знать / опыт со свинцом) - IV-1 СИМ: интерактивный график F(r) (Леннард-Джонс-подобная кривая), slider положения → автоматическое определение «отталкивание / равновесие / притяжение / силы малы» - IV-2 КВИЗ: 4 вопроса - IV-3 DnD: 6 ситуаций по 4 корзинам - IV-4 ТРН: 4 вопроса §11 Три состояния — ГЛАВНЫЙ ВИЗУАЛ ГЛАВЫ 2: - 3 карточки (таблица состояний / поведение молекул / вода во всех 3 состояниях) - IV-1 СИМ: переключатель solid/liquid/gas с 3 разными режимами анимации 50 частиц: solid — крист. решётка 10×5 + дрожание; liquid — отскоки + гравитация к дну + плоский уровень; gas — свободное хаотическое движение по всему объёму - IV-2 КВИЗ: 4 вопроса о свойствах - IV-3 DnD: 9 веществ → 3 состояния - IV-4 ТРН: 5 вопросов §12 Тепловое расширение: - 3 карточки (почему / где важно / аномалия воды) - IV-1 СИМ: стержень со slider ΔT (0..200°C), цвет по температуре (HSL 240→0), пунктир базовой длины, индикатор Δl - IV-2 СИМ: биметаллическая пластина с slider ΔT (-50..100°C), изгиб ±30° - IV-3 DnD: 6 веществ → 3 уровня расширения - IV-4 ТРН: 5 вопросов §13 Температура. Термометры: - 3 карточки (T и тепловое движение / шкала Цельсия / 4 вида термометров) - IV-1 СИМ: виртуальный термометр SVG (-50..150 °C), столбик меняет цвет по температуре, шкала с делениями, указатель-стрелка, контекстная подсказка (мороз/комфорт/жарко/кипяток...) + конвертер в Кельвины - IV-2 КАЛЬК: slider t°C → T(K) = t + 273.15, упоминание абс. нуля - IV-3 DnD: 6 температур → 3 диапазона - IV-4 ТРН: 5 вопросов (включая °C↔K) ФИНАЛ ГЛАВЫ 2 (5 боссов + ачивка «Знаток вещества» +50 XP): 1. Молекула vs волос: во сколько раз меньше (10⁶) 2. Диффузия в горячей воде (/T_2$ через Кельвины) 3. Сжатие газа в шприце (20/50 = 40%) 4. Удлинение рельса при ΔT=60°C (18 мм) 5. 27 °C → 300.2 K Все интерактивы wireDnd/wireQuiz/слайдеры/симы привязаны. parse-check, smoke-test (7 экспортов) пройдены.
LearnSpace
Образовательная платформа с интерактивной онлайн-доской, системой тестирования, управлением классами и элементами геймификации.
Стек: Node.js · Express · SQLite · Vanilla JS · Canvas API · SSE · WebRTC
Содержание
Возможности
Онлайн-урок (Classroom)
Полнофункциональная интерактивная доска с синхронизацией в реальном времени через SSE.
Инструменты рисования
- Карандаш со сглаживанием Catmull-Rom
- Маркер (highlighter) с настраиваемой прозрачностью
- Лазерная указка (без сохранения)
- Ластик
- 11 фигур: прямоугольник, скруглённый прямоугольник, эллипс, линия, стрелка, треугольник, ромб, шестиугольник, звезда, облако, коннектор
- Стикеры с редактированием
- Текстовые блоки
- Вставка изображений
- Таблицы
- LaTeX-формулы (KaTeX) с визуальным редактором и категориями символов
- Система координат с построением графиков функций (встроенный парсер)
- Числовая ось для неравенств (точки, интервалы)
- Циркуль с анимацией
Инструмент выделения
- Перемещение и изменение размера всех объектов
- Вращение объектов (handle над объектом)
- Lasso multi-select (резиновая рамка)
- Shift+click для добавления к выделению
- Copy / Paste с автосмещением
- Snap-гайды при выравнивании объектов
Навигация по холсту
- Zoom: колесо мыши к курсору, Ctrl+
+/-/0, кнопки в тулбаре - Pan: зажатый пробел + перетаскивание
- Minimap (192×108) в правом нижнем углу при zoom > 1 — клик/drag для прыжка по холсту
Инструменты измерения
- Линейка: поворот (drag ↺), изменение длины (drag ↔), панель свойств (угол, длина)
- Транспортир: поворот, изменение радиуса, панель свойств
- Авто-измерения геометрических фигур (длины, углы, площадь)
Страницы и шаблоны
- Неограниченное количество страниц на сессию
- Боковая панель с миниатюрами страниц
- Шаблоны: чистая страница, сетка, линейки, точки, координатные оси
- Экспорт страницы в PNG
Коммуникация
- Чат с реакциями и закреплёнными сообщениями
- Загрузка файлов в чат
- Поднятие руки учеником
- WebRTC аудио/видео
- Трансляция экрана учителя
- Курсор учителя виден ученикам в реальном времени
- Выдача прав рисования отдельным ученикам
- Личные заметки по уроку (per user)
Учебные материалы
- Банк вопросов с уровнями сложности и тематиками
- Конструктор тестов с перемешиванием вопросов
- Многошаговые уроки с блоками: текст, медиа, формулы, код, викторина
- Курсы с прогрессом прохождения
- Карточки (flashcards) со spaced repetition
- Граф знаний — визуализация связей между темами
- Интерактивные лабораторные работы (30+ симуляций): физика, химия, биология, математика
Управление классом
- Создание классов, добавление учеников
- Задания с дедлайнами, отслеживание сдачи
- Журнал оценок
- Объявления и лента активности (Google Classroom-стиль)
- Шаблоны заданий для переиспользования
- Live-викторины в реальном времени
- Аналитика успеваемости
Специализированный контент
- Биохимия: интерактивные молекулы, реакции, метаболические пути, электрофорез
- Красная книга: виды, биомы, экосистемы, пищевые сети, популяционные данные, квесты
Геймификация
- Опыт (XP) и уровни
- Система достижений
- Стрики (серии дней)
- Ежедневные цели и задачи
- Виртуальный питомец
- Магазин с внутренней валютой
- Коллекционирование предметов
Администрирование
- Управление пользователями и ролями
- Гранулярные разрешения (RBAC)
- Feature flags (глобальные и per-class)
- Журнал аудита
- Кабинет родителя
Быстрый старт
Требования: Docker, Docker Compose
git clone https://git.dolgolyov-family.by/maxim.dolgolyov/Learn_System.git
cd Learn_System
cp backend/.env.example .env
# Отредактировать .env — задать JWT_SECRET и CLIENT_ORIGIN
docker compose up -d
Платформа будет доступна на http://localhost:3000.
Первый пользователь с ролью admin создаётся через seed:
docker compose exec app npm run seed
Ручная установка
Требования: Node.js 18+
# 1. Клонировать и установить зависимости
git clone https://git.dolgolyov-family.by/maxim.dolgolyov/Learn_System.git
cd Learn_System/backend
npm install
# 2. Конфигурация
cp .env.example .env
# Отредактировать .env
# 3. Миграции и начальные данные
npm run migrate
npm run seed # опционально — тестовые вопросы и пользователи
# 4. Запуск
npm start # production
npm run dev # development (nodemon)
Сервер запустится на http://localhost:3000.
Фронтенд раздаётся Express-ом из папки frontend/.
Переменные окружения
Файл: backend/.env (шаблон: backend/.env.example)
| Переменная | Описание | По умолчанию |
|---|---|---|
PORT |
Порт сервера | 3000 |
JWT_SECRET |
Секрет для подписи токенов | обязательно |
JWT_EXPIRES_IN |
Срок жизни токена | 7d |
CLIENT_ORIGIN |
CORS — адрес фронтенда | http://localhost:3000 |
DB_PATH |
Путь к файлу БД | ./backend/data/learnspace.db |
UPLOADS_DIR |
Папка для загруженных файлов | ./backend/uploads |
NODE_ENV |
Окружение (production/development) |
development |
Архитектура
Learn_System/
├── backend/
│ ├── src/
│ │ ├── server.js # Express app, 28 route groups
│ │ ├── config.js
│ │ ├── sse.js # Server-Sent Events broadcast
│ │ ├── controllers/ # 30 контроллеров
│ │ ├── routes/ # 28 файлов маршрутов
│ │ ├── middleware/ # auth, RBAC, rate limit, validate
│ │ ├── db/
│ │ │ ├── migrate.js # Auto-migration при старте (76 таблиц)
│ │ │ ├── db.js # better-sqlite3 singleton
│ │ │ └── migrations/ # SQL-файлы схемы
│ │ └── utils/
│ └── package.json
├── frontend/
│ ├── *.html # 43 страницы
│ ├── css/ls.css # Общая дизайн-система
│ └── js/
│ ├── whiteboard.js # Движок доски (~3200 строк)
│ ├── classroom-rtc.js # WebRTC модуль
│ └── labs/ # 30+ физических симуляций
├── js/
│ ├── api.js # window.LS.* — клиентское API
│ └── mobile.js # Мобильная адаптация
├── docker-compose.yml
└── Dockerfile
Ключевые технические решения
Синхронизация доски
- Штрихи сохраняются батчами через
POST /api/classroom/:id/strokes - Загрузка с
?since_seq=N— клиент получает только новые штрихи - Live-превью через
POST /stroke-preview→ SSEstroke_previewсобытие - Двухслойный canvas: статический слой (_strokes) + динамический (_selection/guides/laser)
Real-time (SSE)
- Один SSE-поток на пользователя:
GET /api/classroom/:id/events - События:
stroke_batch,stroke_preview,stroke_deleted,page_changed,chat_message,cursor_move,hand_raised,screen_share, и др. - Compression отключён для SSE-потоков
База данных
- SQLite через
better-sqlite3(синхронный API) - Автоматические миграции при каждом старте сервера
- 76 таблиц, транзакционная запись батчей штрихов
Аутентификация
- JWT Bearer token
- Роли:
admin,teacher,student,free_student - RBAC middleware с кешированием разрешений
- Rate limiting: 6000 req/min для classroom, 600 req/min для остальных
API
Базовый URL: http://localhost:3000/api
Аутентификация: Authorization: Bearer <token>
| Группа | Базовый путь | Назначение |
|---|---|---|
| Auth | /auth |
Регистрация, вход, профиль |
| Classroom | /classroom |
Онлайн-урок, доска, чат, WebRTC |
| Classes | /classes |
Управление классами |
| Assignments | /assignments |
Задания и сдача работ |
| Questions | /questions |
Банк вопросов |
| Sessions | /sessions |
Тестовые сессии |
| Courses | /courses |
Теоретические курсы |
| Lessons | /lessons |
Уроки с блоками контента |
| Gamification | /gamification |
XP, ачивки, стрики |
| Files | /files |
Загрузка и хранение файлов |
| Live | /live |
Live-викторины |
| Analytics | /analytics |
Статистика |
| Admin | /admin |
Управление платформой |
Полная документация по endpoint'ам — в backend/src/routes/.
Роли пользователей
| Роль | Доступ |
|---|---|
admin |
Полный доступ ко всему, включая панель администратора |
teacher |
Создание классов, уроков, заданий, проведение онлайн-уроков |
student |
Прохождение тестов, участие в уроках, доступ к материалам |
free_student |
Ограниченный доступ (настраивается feature flags) |
Разрешения настраиваются гранулярно через /api/permissions.
Лицензия
Частный проект. Все права защищены.