aboutsummaryrefslogtreecommitdiffstats
path: root/web_src/js
diff options
context:
space:
mode:
Diffstat (limited to 'web_src/js')
-rw-r--r--web_src/js/markup/math.ts20
1 files changed, 11 insertions, 9 deletions
diff --git a/web_src/js/markup/math.ts b/web_src/js/markup/math.ts
index 22a4de38e9..4777805e3c 100644
--- a/web_src/js/markup/math.ts
+++ b/web_src/js/markup/math.ts
@@ -1,8 +1,14 @@
import {displayError} from './common.ts';
-function targetElement(el: Element) {
+function targetElement(el: Element): {target: Element, displayAsBlock: boolean} {
// The target element is either the parent "code block with loading indicator", or itself
- return el.closest('.code-block.is-loading') ?? el;
+ // It is designed to work for 2 cases (guaranteed by backend code):
+ // * <pre class="code-block is-loading"><code class="language-math display">...</code></pre>
+ // * <code class="language-math">...</code>
+ return {
+ target: el.closest('.code-block.is-loading') ?? el,
+ displayAsBlock: el.classList.contains('display'),
+ };
}
export async function renderMath(): Promise<void> {
@@ -19,7 +25,7 @@ export async function renderMath(): Promise<void> {
const MAX_EXPAND = 1000;
for (const el of els) {
- const target = targetElement(el);
+ const {target, displayAsBlock} = targetElement(el);
if (target.hasAttribute('data-render-done')) continue;
const source = el.textContent;
@@ -27,16 +33,12 @@ export async function renderMath(): Promise<void> {
displayError(target, new Error(`Math source of ${source.length} characters exceeds the maximum allowed length of ${MAX_CHARS}.`));
continue;
}
-
- const displayMode = el.classList.contains('display');
- const nodeName = displayMode ? 'p' : 'span';
-
try {
- const tempEl = document.createElement(nodeName);
+ const tempEl = document.createElement(displayAsBlock ? 'p' : 'span');
katex.render(source, tempEl, {
maxSize: MAX_SIZE,
maxExpand: MAX_EXPAND,
- displayMode,
+ displayMode: displayAsBlock, // katex: true for display (block) mode, false for inline mode
});
target.replaceWith(tempEl);
} catch (error) {