mirror of
				https://github.com/discourse/discourse-math.git
				synced 2025-10-25 11:28:42 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			94 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			94 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) {
 | |
|   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);
 | |
|     }
 | |
|   }
 | |
| };
 |