2017-11-20 15:06:24 +11:00

99 lines
2.5 KiB
JavaScript

import { withPluginApi } from 'discourse/lib/plugin-api';
import loadScript from 'discourse/lib/load-script';
let initializedMathJax = false;
let zoom_on_hover, enable_accessibility;
function initMathJax() {
if (initializedMathJax) { return; }
var extensions = ["toMathML.js", "Safe.js"];
if (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(zoom_on_hover) {
settings.menuSettings = {zoom: "Hover"};
settings.MathEvents = {hover: 750};
}
window.MathJax = settings;
initializedMathJax = true;
}
function ensureMathJax(){
initMathJax();
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);
const tag = elem.tagName === "DIV" ? "div" : "span";
const display = tag === "div" ? "; mode=display" : "";
const $mathWrapper = $(`<${tag} style="display: none;"><script type="math/tex${display}"></script></${tag}>`);
const $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) {
if (!$elem || !$elem.find) {
return;
}
const mathElems = $elem.find('.math');
if (mathElems.length > 0) {
const isPreview = $elem.hasClass('d-editor-preview');
ensureMathJax().then(()=>{
mathElems.each((idx,elem) => decorate(elem, isPreview));
});
}
}
function initializeMath(api) {
api.decorateCooked(mathjax);
}
export default {
name: "apply-math",
initialize(container) {
const siteSettings = container.lookup('site-settings:main');
zoom_on_hover = siteSettings.discourse_math_zoom_on_hover;
enable_accessibility = siteSettings.discourse_math_enable_accessibility;
if (siteSettings.discourse_math_enabled) {
withPluginApi('0.5', initializeMath);
}
}
};