2bf7ff7ef1
Все 6 ЛР физики 7 закрыты. Файл phys7_lab_widgets.js (726 строк, 6 экспортов: lr1..lr6). Палитра cyan. Подключение через обновлённый gen_phys7_lab.js: script-тег + hook в goTo (удаление placeholder + вызов widgets). Каждая ЛР содержит: - Цель (goal card, голубая) - Оборудование (equip card, оранжевая) - Ход работы (steps card, фиолетовая) — пронумерованный список - СИМ-виджет (интерактивная симуляция прибора) - ТБЛ-виджет (таблица измерений) - ВОПР-виджет (3 контрольных вопроса с авто-проверкой) - Вывод (concl card, зелёная) - Кнопка «Сдать ЛР» (+30 XP, localStorage-фиксация) ЛР-1 «Цена деления» (§7): - 4 виртуальных прибора (линейка/термометр/мензурка/динамометр) с SVG-шкалами - Таблица C для всех 4 - 3 контрольных вопроса ЛР-2 «Измерение длины» (§4, §7): - 3 предмета на выбор (карандаш/тетрадь/брусок), SVG с линейкой ниже, риска на длине + запись (l ± 0,5) мм - Таблица 3 измерений ЛР-3 «Объём вытеснением» (§4): - 3 тела (камень/гайка/болт), 2 SVG-мензурки рядом (V1=100 и V2=100+V), стрелка «опускаем» между ними, авто-расчёт V = V2 − V1 - Таблица 3 измерений ЛР-4 «Неравномерное движение» (§18): - Шарик на наклонной плоскости, slider угла 10..60°, кнопка «Запустить», анимация скатывания (квадратичная по времени, эмпирически быстрее на больших углах) - Таблица 3 углов с разной средней скоростью ЛР-5 «Плотность» (§20): - 3 образца на выбор (54г/156г/272г, V=20 см³ каждый), SVG-весы+мензурка, расчёт ρ = m/V и автоопределение материала (алюминий/железо/золото) - Таблица плотностей 9 веществ ЛР-6 «Сила трения» (§27): - SVG: брусок с грузами, динамометр, разные поверхности из <select> (дерево/пластик/резина/лёд: μ от 0.04 до 0.5) - slider массы 100..500 г → авто N и Ftr через динамометр - Таблица 5 измерений с разными грузами → видно Ftr ~ N АЧИВКА «Лаборант 7 класса» +80 XP — автоматически при сдаче всех 6 ЛР (проверка через localStorage в wireSubmit). Парсинг OK, smoke (6 экспортов) OK.
LearnSpace Backend — Фаза 1
Быстрый старт
cd backend
npm install
# 1. Скопировать и заполнить переменные окружения
cp .env.example .env
# 2. Создать базу данных в PostgreSQL
createdb learnspace
# 3. Применить миграции (создать таблицы)
npm run migrate
# 4. Загрузить тестовые вопросы
npm run seed
# 5. Запустить сервер
npm run dev
API
Auth
| Метод | URL | Тело | Описание |
|---|---|---|---|
| POST | /api/auth/register |
{ email, password, name } |
Регистрация |
| POST | /api/auth/login |
{ email, password } |
Вход |
| GET | /api/auth/me |
— | Текущий пользователь |
Предметы
| Метод | URL | Описание |
|---|---|---|
| GET | /api/subjects |
Список предметов |
| GET | /api/subjects/:slug/topics |
Темы предмета |
Сессии тестирования
| Метод | URL | Тело | Описание |
|---|---|---|---|
| POST | /api/sessions |
{ subject_slug, mode, count, topic_id? } |
Начать тест |
| POST | /api/sessions/:id/answer |
{ question_id, option_id, time_spent_sec? } |
Отправить ответ |
| POST | /api/sessions/:id/finish |
— | Завершить тест + разбор |
| GET | /api/sessions/:id/result |
— | Результат завершённого теста |
| GET | /api/sessions/history |
— | История тестов |
Все /api/sessions/* требуют заголовок:
Authorization: Bearer <token>
Добавление вопросов
Создать JSON-файл в data/ по образцу questions-bio.json:
{
"subject": "chem",
"topics": [{ "name": "Органическая химия", "order": 1 }],
"questions": [
{
"topic": "Органическая химия",
"difficulty": 2,
"text": "Текст вопроса",
"options": ["А", "Б", "В", "Г"],
"answer": 0,
"explanation": "Объяснение правильного ответа"
}
]
}
Затем повторно запустить npm run seed.
Структура проекта
backend/
├── data/ ← JSON с вопросами
├── src/
│ ├── server.js ← точка входа
│ ├── middleware/auth.js ← JWT верификация
│ ├── db/
│ │ ├── pool.js ← соединение с PostgreSQL
│ │ ├── migrate.js ← запуск миграций
│ │ ├── seed.js ← загрузка вопросов
│ │ └── migrations/ ← SQL-файлы схемы
│ ├── routes/ ← маршруты
│ └── controllers/ ← бизнес-логика
└── .env.example