dc201f28ff
Глава 3 «Неравенства с одной переменной» по программе Арефьевой/Пирютко. Палитра: индиго → фиолетовый → бирюза. 6 параграфов + финал. Скелет (общая инфраструктура, копия паттернов из ch2): - 7 параграфов: §13–§18 + final3 - LocalStorage 'algebra8_ch3_*', shared XP 'algebra8_xp' - DnD-хелпер setupSorter, glossary с 12 терминами, поиск Ctrl+K - XP-карта + бейдж + 7 контекстных подсказок + ачивки - Server sync прогресса (markLastPara/markParaRead, debounce 600мс) § 13 «Числовые неравенства и их свойства»: - Теория, 5 главных свойств, примеры - INTERACT 1: Drag-сортировка 5 чисел по возрастанию (5 наборов) - INTERACT 2: «Знак меняется или нет» (8 операций) - INTERACT 3: Конструктор a, b, k + операция → live-сравнение - INTERACT 4: Цепочка свойств (5 шагов выбора) - INTERACT 5: Drag-классификация (8 переходов по 4 свойствам) - INTERACT 6: Тренажёр «Что больше?» (10 случайных задач) § 14 «Сложение, умножение, оценка»: - Теория, таблица 4 операций для оценки, пример - INTERACT 1: Калькулятор оценок (live x+y, x-y, xy, x/y) - INTERACT 2: Тренажёр границ (8 задач) - INTERACT 3: Drag «Можно сложить / перемножить / нельзя» - INTERACT 4: Пошаговое сложение (5 шагов) - INTERACT 5: Сложи неравенства (6 multiple-choice) DB: миграция 013 — slug 'algebra-8-ch3', sort_order=5, бамп physics-8 на 6. Главы 1 и 2 теперь имеют кнопку «Глава 3 →» в шапке.
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