feat(chemistry-8): Phase 2 — Глава 1 «Важнейшие классы неорг. соединений» (§10–23)

Полная глава на движке (14 § + 2 лаб. опыта + 2 практические работы + финал-босс):
- §10–12 оксиды (классификатор, свойства, получение)
- §13–15 кислоты (классификатор, ряд активности, индикаторы, получение)
- §16–18 основания (классификатор, фенолфталеин, Лаб.1 Cu(OH)₂↓, ПР2 нейтрализация)
- §19–21 соли (таблица растворимости, РИО, соль+металл, Лаб.2, способы)
- §22 генетическая связь классов + ПР3; §23 расчётный решатель; финал-босс (6 задач)
- POOLS: ~45 задач (MCQ + числовые), шпаргалки и подсказки по каждому §

chem8_svg.js: реализованы 5 хим-виджетов (были заглушки) — testTube (осадок/газ),
indicatorScale (лакмус/фенолфталеин/метилоранж + pH), classifier (клик-DnD),
solubilityTable (катион×анион), activitySeries (ряд активности металлов).
chem8-textbook.css: стили виджетов. chem8_ch1_widgets.js: монтаж по §.

Тесты: 24/24 (юнит + jsdom-виджеты + полностраничный SPA intro и ch1 — para-selector,
активный §, монтаж флагманов, тренажёр, без ошибок). Ассеты 200.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
@
This commit is contained in:
Maxim Dolgolyov
2026-05-30 15:20:13 +03:00
parent b9d30f5252
commit 787092674a
6 changed files with 740 additions and 163 deletions
+45
View File
@@ -297,6 +297,51 @@ html.dark .el-cell .s{color:var(--pri-l)}
.drop-box h5{font-size:.8rem;font-weight:800;margin-bottom:8px;text-align:center;color:var(--pri-d)}
html.dark .drop-box h5{color:var(--pri-l)}
/* testTube */
.tt-svg{color:var(--pri);vertical-align:bottom}
.tt-row{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-end;margin:10px 0}
.tt-cap{font-size:.84rem;color:var(--muted);text-align:center;max-width:120px}
/* indicatorScale */
.ind-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.ind-row label{font-size:.85rem;font-weight:600;color:var(--muted)}
.ind-strip{height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.92rem;border:1px solid var(--border);transition:background .25s}
.ind-label{margin-top:8px;font-size:.9rem}
.ind-label b{color:var(--pri-d)}html.dark .ind-label b{color:var(--pri-l)}
/* classifier */
.cls-chip.on{border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-soft)}
.cls-chip.cls-ok{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}
.cls-chip.cls-bad{background:var(--fail-bg);border-color:var(--fail);color:var(--fail)}
.cls-items{display:flex;flex-wrap:wrap;gap:6px;min-height:24px}
/* solubilityTable */
.sol-wrap{overflow-x:auto}
.sol-tab{border-collapse:collapse;font-size:.78rem;font-family:var(--mono);min-width:520px}
.sol-tab th,.sol-tab td{border:1px solid var(--border);padding:4px 6px;text-align:center;cursor:pointer}
.sol-tab thead th{background:var(--card-soft);font-weight:800}
.sol-tab th[data-an]{background:var(--card-soft);font-weight:800}
.sol-tab td.sP{background:rgba(37,99,235,.12);color:#1d4ed8}
.sol-tab td.sM{background:rgba(245,158,11,.18);color:#b45309}
.sol-tab td.sH{background:rgba(220,38,38,.14);color:#b91c1c}
.sol-tab td.sX{background:rgba(120,120,120,.12);color:var(--muted)}
.sol-tab td.sol-dim,.sol-tab th.sol-dim{opacity:.3}
.sol-tab td.sol-hot{outline:3px solid var(--pri);outline-offset:-3px;font-weight:900}
.sol-out{margin-top:10px}
/* activitySeries */
.act-row{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.act-cell{font-family:var(--mono);font-weight:800;font-size:.82rem;padding:7px 9px;border:1.5px solid var(--border);border-radius:8px;background:var(--card);color:var(--text);cursor:pointer;transition:.12s}
.act-cell:hover{border-color:var(--pri)}
.act-cell.act-h{background:var(--card-soft);color:var(--muted);cursor:default;font-size:.74rem}
.act-cell.act-on{background:var(--pri);border-color:var(--pri);color:#fff}
.act-cell.act-disp{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}
.act-axis{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin:6px 2px}
.act-out{margin-top:8px}
/* exa-step (разбор примеров) */
.exa-step{font-family:var(--mono);font-size:.9rem;background:var(--card-soft);border-left:3px solid var(--pri);border-radius:0 8px 8px 0;padding:8px 12px;margin:6px 0}
/* FOOTER + popup */
.foot{text-align:center;padding:24px 16px;color:var(--muted);font-size:.78rem;border-top:1px solid var(--border)}
.ach-popup{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(130px);background:var(--card);border:1.5px solid var(--pri);color:var(--text);padding:12px 20px;border-radius:13px;font-weight:700;box-shadow:var(--sh2);z-index:60;transition:transform .35s;display:flex;align-items:center;gap:10px;font-size:.9rem;max-width:90vw}