import { withPluginApi } from 'discourse/lib/plugin-api'; import loadScript from 'discourse/lib/load-script'; let initializedMathJax = false; function initMathJax(opts) { if (initializedMathJax) { return; } var extensions = ["toMathML.js", "Safe.js"]; if (opts.enable_accessibility) { extensions.push("[a11y]/accessibility-menu.js"); } var settings = { jax: ['input/TeX', 'input/AsciiMath', 'input/MathML', 'output/CommonHTML'], TeX: {extensions: ["AMSmath.js", "AMSsymbols.js", "autoload-all.js"]}, extensions: extensions, showProcessingMessages: false, root: '/plugins/discourse-math/mathjax' }; if(opts.zoom_on_hover) { settings.menuSettings = {zoom: "Hover"}; settings.MathEvents = {hover: 750}; } window.MathJax = settings; initializedMathJax = true; } function ensureMathJax(opts){ initMathJax(opts); return loadScript('/plugins/discourse-math/mathjax/MathJax.1.7.1.js'); } function decorate(elem, isPreview){ const $elem= $(elem); if ($elem.data('applied-mathjax')){ return; } $elem.data('applied-mathjax', true); if($elem.hasClass('math')) { const tag = elem.tagName === "DIV" ? "div" : "span"; const display = tag === "div" ? "; mode=display" : ""; var $mathWrapper = $(`<${tag} style="display: none;">`); var $math = $mathWrapper.children(); $math.html($elem.text()); $elem.after($mathWrapper); } else if($elem.hasClass('asciimath')) { var $mathWrapper = $(``); var $math = $mathWrapper.children(); $math.html($elem.text()); $elem.after($mathWrapper); } Em.run.later(this, ()=> { window.MathJax.Hub.Queue(() => { // don't bother processing previews removed from DOM if (elem.parentElement && elem.parentElement.offsetParent !== null) { window.MathJax.Hub.Typeset($math[0], ()=> { $elem.remove(); $mathWrapper.show(); }); } }); }, isPreview ? 200 : 0); } function mathjax($elem, opts) { if (!$elem || !$elem.find) { return; } let mathElems; if(opts.enable_asciimath) { mathElems = $elem.find('.math, .asciimath'); } else { mathElems = $elem.find('.math'); } if (mathElems.length > 0) { const isPreview = $elem.hasClass('d-editor-preview'); ensureMathJax(opts).then(()=>{ mathElems.each((idx,elem) => decorate(elem, isPreview)); }); } } function initializeMath(api, discourse_math_opts) { api.decorateCooked(function(elem) {mathjax(elem,discourse_math_opts)}); } export default { name: "apply-math", initialize(container) { const siteSettings = container.lookup('site-settings:main'); let discourse_math_opts = { zoom_on_hover: siteSettings.discourse_math_zoom_on_hover, enable_accessibility: siteSettings.discourse_math_enable_accessibility, enable_asciimath: siteSettings.discourse_math_enable_asciimath }; if (siteSettings.discourse_math_enabled) { withPluginApi('0.5', function(api) {initializeMath(api,discourse_math_opts)}); } } };