diff options
author | wxiaoguang <wxiaoguang@gmail.com> | 2024-12-14 13:43:05 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-14 13:43:05 +0800 |
commit | cc5ff98e0d510c1923ad7cabc3e339f9cf0b570f (patch) | |
tree | 36e6c850a686beda2ae7cca8ed38d6234fbc6968 /web_src/js | |
parent | 82c59d52ea650ce42bbca2c6740d9449d06e77be (diff) | |
download | gitea-cc5ff98e0d510c1923ad7cabc3e339f9cf0b570f.tar.gz gitea-cc5ff98e0d510c1923ad7cabc3e339f9cf0b570f.zip |
Refactor markdown math render (#32831)
Add more tests
Diffstat (limited to 'web_src/js')
-rw-r--r-- | web_src/js/markup/math.ts | 20 |
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) { |