2014-09-21 22:03:07 +00:00
|
|
|
/*\
|
|
|
|
title: $:/plugins/tiddlywiki/katex/wrapper.js
|
|
|
|
type: application/javascript
|
|
|
|
module-type: widget
|
|
|
|
|
|
|
|
Wrapper for `katex.min.js` that provides a `<$latex>` widget. It is also available under the alias `<$katex>`
|
|
|
|
|
|
|
|
\*/
|
|
|
|
(function(){
|
|
|
|
|
|
|
|
/*jslint node: true, browser: true */
|
|
|
|
/*global $tw: false */
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var katex = require("$:/plugins/tiddlywiki/katex/katex.min.js"),
|
2018-12-01 13:59:08 +00:00
|
|
|
chemParse = require("$:/plugins/tiddlywiki/katex/mhchem.min.js"),
|
2014-09-21 22:03:07 +00:00
|
|
|
Widget = require("$:/core/modules/widgets/widget.js").widget;
|
|
|
|
|
2021-09-10 20:28:13 +00:00
|
|
|
katex.macros = {};
|
|
|
|
katex.updateMacros = function() {
|
|
|
|
var tiddlers = $tw.wiki.getTiddlersWithTag("$:/tags/KaTeX/Macro"),
|
|
|
|
regex = /#\d/g, // Remove the arguments like #1#2
|
|
|
|
tid, macro, cmd;
|
2024-08-20 15:33:07 +00:00
|
|
|
for(var i=0; i < tiddlers.length; i++) {
|
2021-09-10 20:28:13 +00:00
|
|
|
tid = $tw.wiki.getTiddler(tiddlers[i]);
|
|
|
|
try {
|
|
|
|
macro = tid.fields["caption"];
|
|
|
|
macro = macro.replace(regex, "");
|
|
|
|
cmd = tid.fields["text"];
|
|
|
|
katex.macros[macro] = cmd;
|
|
|
|
} catch(ex) {// Catch the bad ones
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2014-09-21 22:03:07 +00:00
|
|
|
var KaTeXWidget = function(parseTreeNode,options) {
|
|
|
|
this.initialise(parseTreeNode,options);
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
Inherit from the base widget class
|
|
|
|
*/
|
|
|
|
KaTeXWidget.prototype = new Widget();
|
|
|
|
|
|
|
|
/*
|
|
|
|
Render this widget into the DOM
|
|
|
|
*/
|
|
|
|
KaTeXWidget.prototype.render = function(parent,nextSibling) {
|
|
|
|
// Housekeeping
|
|
|
|
this.parentDomNode = parent;
|
|
|
|
this.computeAttributes();
|
|
|
|
this.execute();
|
|
|
|
// Get the source text
|
|
|
|
var text = this.getAttribute("text",this.parseTreeNode.text || "");
|
2015-12-18 14:41:37 +00:00
|
|
|
var displayMode = this.getAttribute("displayMode",this.parseTreeNode.displayMode || "false") === "true";
|
2021-09-10 20:28:13 +00:00
|
|
|
katex.updateMacros();
|
2014-09-21 22:03:07 +00:00
|
|
|
// Render it into a span
|
2015-09-08 09:37:33 +00:00
|
|
|
var span = this.document.createElement("span"),
|
2021-09-10 20:28:13 +00:00
|
|
|
options = {throwOnError: false, displayMode: displayMode, macros: katex.macros};
|
2015-07-17 07:58:58 +00:00
|
|
|
try {
|
2015-07-14 07:45:14 +00:00
|
|
|
if(!this.document.isTiddlyWikiFakeDom) {
|
2015-09-08 09:37:33 +00:00
|
|
|
katex.render(text,span,options);
|
2014-10-06 20:20:19 +00:00
|
|
|
} else {
|
2015-09-08 09:37:33 +00:00
|
|
|
span.innerHTML = katex.renderToString(text,options);
|
2014-10-06 20:20:19 +00:00
|
|
|
}
|
2015-07-17 07:58:58 +00:00
|
|
|
} catch(ex) {
|
|
|
|
span.className = "tc-error";
|
|
|
|
span.textContent = ex;
|
|
|
|
}
|
2014-09-21 22:03:07 +00:00
|
|
|
// Insert it into the DOM
|
|
|
|
parent.insertBefore(span,nextSibling);
|
|
|
|
this.domNodes.push(span);
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
Compute the internal state of the widget
|
|
|
|
*/
|
|
|
|
KaTeXWidget.prototype.execute = function() {
|
|
|
|
// Nothing to do for a katex widget
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
Selectively refreshes the widget if needed. Returns true if the widget or any of its children needed re-rendering
|
|
|
|
*/
|
|
|
|
KaTeXWidget.prototype.refresh = function(changedTiddlers) {
|
|
|
|
var changedAttributes = this.computeAttributes();
|
|
|
|
if(changedAttributes.text) {
|
|
|
|
this.refreshSelf();
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
exports.latex = KaTeXWidget;
|
|
|
|
exports.katex = KaTeXWidget;
|
|
|
|
|
|
|
|
})();
|
|
|
|
|