feat(lab-graph): KaTeX-формулы + панель ввода как редактор формул
«График функции»: - примеры (чипы) и живой предпросмотр каждой функции рендерятся в KaTeX (data-tex на чипах, _initGraphPanel рендерит при открытии) - предпросмотр теперь всегда виден, крупный и в цвет функции; пустое поле показывает плейсхолдер-формулу приглушённо - НОВОЕ: keypad вставки структур (x², xⁿ, √, a/b, |x|, π, sin/cos/tg/ln/eˣ, ()) — клик вставляет в активное поле по каретке (как редактор формул в PowerPoint) - graphInsert(token) с маркером каретки |; активное поле отслеживается по focus Только фронт. Проверено: node --check, логика вставки 5/5. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
+19
-5
@@ -188,15 +188,29 @@
|
||||
}
|
||||
.fn-input::placeholder { color: var(--text-3); font-weight: 500; }
|
||||
|
||||
/* KaTeX live preview */
|
||||
/* KaTeX live preview — крупная «отрисованная» формула под вводом */
|
||||
.fn-preview {
|
||||
min-height: 20px; padding: 3px 4px 3px 36px;
|
||||
min-height: 22px; padding: 5px 8px 5px 36px; margin-top: 3px;
|
||||
font-size: 0.82rem; line-height: 1.5;
|
||||
color: rgba(255,255,255,.65);
|
||||
overflow: hidden; display: none;
|
||||
overflow-x: auto; overflow-y: hidden; display: none;
|
||||
}
|
||||
.fn-preview.has-content { display: block; }
|
||||
.fn-preview .katex { color: rgba(255,255,255,.8); font-size: 1em; }
|
||||
.fn-preview .katex { color: var(--fn-color, rgba(255,255,255,.85)); font-size: 1.18em; }
|
||||
.fn-preview.is-ph { opacity: .4; } /* плейсхолдер-формула, пока поле пустое */
|
||||
|
||||
/* keypad вставки структур (как редактор формул) */
|
||||
.gp-keypad { display: grid; grid-template-columns: repeat(6, 1fr); gap: 5px; margin-bottom: 6px; }
|
||||
.kp-btn {
|
||||
display: flex; align-items: center; justify-content: center; min-height: 32px;
|
||||
padding: 5px 2px; border-radius: 9px; border: 1.5px solid var(--border-h);
|
||||
background: rgba(255,255,255,.02); color: var(--text-2);
|
||||
font-family: 'Manrope', monospace; font-size: 0.78rem; font-weight: 700;
|
||||
cursor: pointer; transition: all .14s;
|
||||
}
|
||||
.kp-btn:hover { border-color: var(--violet); color: var(--violet); background: rgba(155,93,229,.08); transform: translateY(-1px); }
|
||||
.kp-btn:active { transform: translateY(0); }
|
||||
.kp-btn .katex { font-size: 1em; }
|
||||
.preset-btn .katex { font-size: 0.96em; }
|
||||
.fn-err {
|
||||
font-size: 0.68rem; color: var(--pink); font-weight: 600;
|
||||
padding: 2px 0 0 22px; display: none;
|
||||
|
||||
Reference in New Issue
Block a user