fix selector so maths support doesn't mangle divs (#12433)
							parent
							
								
									193237f204
								
							
						
					
					
						commit
						04a2191cad
					
				|  | @ -348,7 +348,7 @@ export function bodyToHtml(content: IContent, highlights: Optional<string[]>, op | |||
|             isHtmlMessage = !isPlainText; | ||||
| 
 | ||||
|             if (isHtmlMessage && SettingsStore.getValue("feature_latex_maths")) { | ||||
|                 [...phtml.querySelectorAll<HTMLElement>("div, span[data-mx-maths]")].forEach((e) => { | ||||
|                 [...phtml.querySelectorAll<HTMLElement>("div[data-mx-maths], span[data-mx-maths]")].forEach((e) => { | ||||
|                     e.outerHTML = katex.renderToString(decode(e.getAttribute("data-mx-maths")), { | ||||
|                         throwOnError: false, | ||||
|                         displayMode: e.tagName == "DIV", | ||||
|  |  | |||
|  | @ -166,6 +166,16 @@ describe("bodyToHtml", () => { | |||
|             }); | ||||
|             expect(html).toMatchSnapshot(); | ||||
|         }); | ||||
| 
 | ||||
|         it("should not mangle divs", () => { | ||||
|             const html = getHtml({ | ||||
|                 body: "hello world", | ||||
|                 msgtype: "m.text", | ||||
|                 formatted_body: "<p>hello</p><div>world</div>", | ||||
|                 format: "org.matrix.custom.html", | ||||
|             }); | ||||
|             expect(html).toMatchSnapshot(); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,6 +2,8 @@ | |||
| 
 | ||||
| exports[`bodyToHtml feature_latex_maths should not mangle code blocks 1`] = `"<p>hello</p><pre><code>$\\xi$</code></pre><p>world</p>"`; | ||||
| 
 | ||||
| exports[`bodyToHtml feature_latex_maths should not mangle divs 1`] = `"<p>hello</p><div>world</div>"`; | ||||
| 
 | ||||
| exports[`bodyToHtml feature_latex_maths should render block katex 1`] = `"<p>hello</p><span class="katex-display"><span class="katex"><span class="katex-mathml"><math xmlns="http://www.w3.org/1998/Math/MathML" display="block"><semantics><mrow><mi>ξ</mi></mrow><annotation encoding="application/x-tex">\\xi</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.8889em;vertical-align:-0.1944em;"></span><span class="mord mathnormal" style="margin-right:0.04601em;">ξ</span></span></span></span></span><p>world</p>"`; | ||||
| 
 | ||||
| exports[`bodyToHtml feature_latex_maths should render inline katex 1`] = `"hello <span class="katex"><span class="katex-mathml"><math xmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mi>ξ</mi></mrow><annotation encoding="application/x-tex">\\xi</annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.8889em;vertical-align:-0.1944em;"></span><span class="mord mathnormal" style="margin-right:0.04601em;">ξ</span></span></span></span> world"`; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Hubert Chathi
						Hubert Chathi