discourse/plugins/discourse-math/assets/javascripts/initializers/discourse-math-katex.js
dependabot[bot] e7d3c344d1
Build(deps-dev): Bump the lint group across 1 directory with 4 updates (#33881)
Bumps the lint group with 4 updates in the / directory:
[@discourse/lint-configs](https://github.com/discourse/lint-configs),
[ember-template-lint](https://github.com/ember-template-lint/ember-template-lint),
[eslint](https://github.com/eslint/eslint) and
[stylelint](https://github.com/stylelint/stylelint).


Updates `@discourse/lint-configs` from 2.22.0 to 2.28.0
- [Commits](https://github.com/discourse/lint-configs/commits)

Updates `ember-template-lint` from 7.7.0 to 7.9.1
- [Release
notes](https://github.com/ember-template-lint/ember-template-lint/releases)
-
[Changelog](https://github.com/ember-template-lint/ember-template-lint/blob/master/CHANGELOG.md)
-
[Commits](https://github.com/ember-template-lint/ember-template-lint/commits)

Updates `eslint` from 9.27.0 to 9.32.0
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v9.27.0...v9.32.0)

Updates `stylelint` from 16.19.1 to 16.22.0
- [Release notes](https://github.com/stylelint/stylelint/releases)
-
[Changelog](https://github.com/stylelint/stylelint/blob/main/CHANGELOG.md)
-
[Commits](https://github.com/stylelint/stylelint/compare/16.19.1...16.22.0)

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Discourse CI <ci@ci.invalid>
Co-authored-by: Jarek Radosz <jarek@cvx.dev>
2025-07-28 18:02:41 +02:00

97 lines
2.5 KiB
JavaScript
Vendored

import loadScript from "discourse/lib/load-script";
import { withPluginApi } from "discourse/lib/plugin-api";
async function ensureKaTeX() {
try {
await loadScript("/plugins/discourse-math/katex/katex.min.js");
await loadScript("/plugins/discourse-math/katex/katex.min.css", {
css: true,
});
await loadScript("/plugins/discourse-math/katex/mhchem.min.js");
await loadScript("/plugins/discourse-math/katex/copy-tex.min.js");
} catch (e) {
// eslint-disable-next-line no-console
console.error("Failed to load KaTeX dependencies.", e);
}
}
function decorate(elem, katexOpts) {
katexOpts["displayMode"] = elem.tagName === "DIV";
if (elem.dataset.appliedKatex) {
return;
}
elem.dataset.appliedKatex = true;
if (!elem.classList.contains("math")) {
return;
}
const tag = elem.tagName === "DIV" ? "div" : "span";
const displayClass = tag === "div" ? "block-math" : "inline-math";
const text = elem.textContent;
elem.classList.add("math-container", displayClass, "katex-math");
elem.textContent = "";
window.katex.render(text, elem, katexOpts);
}
async function katex(elem) {
if (!elem) {
return;
}
const mathElems = elem.querySelectorAll(".math");
if (!mathElems.length > 0) {
return;
}
await ensureKaTeX();
// enable persistent macros with are disabled by default: https://katex.org/docs/api.html#persistent-macros
// also enable equation labelling and referencing which are disabled by default
// both of these are enabled in mathjax by default, so now the katex implementation is (more) mathjax compatible
const katexOpts = {
trust: (context) => ["\\htmlId", "\\href"].includes(context.command),
macros: {
"\\eqref": "\\href{###1}{(\\text{#1})}",
"\\ref": "\\href{###1}{\\text{#1}}",
"\\label": "\\htmlId{#1}{}",
},
displayMode: false,
};
mathElems.forEach((mathElem) => decorate(mathElem, katexOpts));
}
function initializeMath(api) {
api.decorateCookedElement(
function (elem) {
katex(elem);
},
{ id: "katex" }
);
if (api.decorateChatMessage) {
api.decorateChatMessage(
(element) => {
katex(element);
},
{ id: "katex-chat" }
);
}
}
export default {
name: "apply-math-katex",
initialize(container) {
const siteSettings = container.lookup("service:site-settings");
if (
siteSettings.discourse_math_enabled &&
siteSettings.discourse_math_provider === "katex"
) {
withPluginApi(function (api) {
initializeMath(api);
});
}
},
};