2013-08-12 13:21:38 +00:00
|
|
|
/**
|
|
|
|
* A plugin which enables rendering of math equations inside
|
|
|
|
* of reveal.js slides. Essentially a thin wrapper for MathJax.
|
|
|
|
*
|
|
|
|
* @author Hakim El Hattab
|
|
|
|
*/
|
2013-08-13 03:01:35 +00:00
|
|
|
var RevealMath = window.RevealMath || (function(){
|
|
|
|
|
|
|
|
var loaded = false;
|
2013-08-12 13:21:38 +00:00
|
|
|
|
2013-08-13 02:42:14 +00:00
|
|
|
var config = Reveal.getConfig().math || {};
|
2013-08-13 03:15:19 +00:00
|
|
|
config.host = config.host || 'http://cdn.mathjax.org/mathjax/latest/MathJax.js';
|
2013-08-13 02:42:14 +00:00
|
|
|
config.mode = config.mode || 'TeX-AMS_HTML-full';
|
|
|
|
|
2013-08-13 03:15:19 +00:00
|
|
|
loadScript( config.host + '?config=' + config.mode, function() {
|
2013-08-12 13:21:38 +00:00
|
|
|
|
2013-08-13 03:01:35 +00:00
|
|
|
// Conditioned just in case both onload and readystate fire
|
|
|
|
if( loaded === false ) {
|
|
|
|
loaded = true;
|
2013-08-12 13:21:38 +00:00
|
|
|
|
2013-08-13 03:01:35 +00:00
|
|
|
MathJax.Hub.Config({
|
|
|
|
messageStyle: 'none',
|
|
|
|
tex2jax: { inlineMath: [['$','$'],['\\(','\\)']] }
|
|
|
|
});
|
2013-08-13 02:42:14 +00:00
|
|
|
|
2013-08-13 03:01:35 +00:00
|
|
|
// Process any math inside of the current slide when navigating,
|
|
|
|
// this is needed since it's not possible to typeset equations
|
|
|
|
// within invisible elements (far future or past).
|
|
|
|
Reveal.addEventListener( 'slidechanged', function( event ) {
|
2013-08-13 02:42:14 +00:00
|
|
|
|
2013-08-13 03:01:35 +00:00
|
|
|
// This will only typeset equations that have not yet been
|
|
|
|
// processed, as well as equations that have change since
|
|
|
|
// last being processed.
|
2013-08-13 03:15:19 +00:00
|
|
|
MathJax.Hub.Update( event.currentSlide, function() {
|
|
|
|
Reveal.layout();
|
|
|
|
} );
|
2013-08-13 03:01:35 +00:00
|
|
|
|
|
|
|
} );
|
|
|
|
}
|
2013-08-12 13:21:38 +00:00
|
|
|
|
2013-08-13 03:15:19 +00:00
|
|
|
} );
|
|
|
|
|
|
|
|
function loadScript( url, callback ) {
|
|
|
|
|
|
|
|
var head = document.querySelector( 'head' );
|
|
|
|
var script = document.createElement( 'script' );
|
|
|
|
script.type = 'text/javascript';
|
|
|
|
script.src = url;
|
|
|
|
|
|
|
|
// Wrapper for callback to make sure it only fires once
|
|
|
|
var finish = function() {
|
|
|
|
if( typeof callback === 'function' ) {
|
|
|
|
callback.call();
|
|
|
|
callback = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
script.onload = finish;
|
|
|
|
|
|
|
|
// IE
|
|
|
|
script.onreadystatechange = function() {
|
|
|
|
if ( this.readyState === 'loaded' ) {
|
|
|
|
finish.call();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Normal browsers
|
|
|
|
head.appendChild( script );
|
|
|
|
|
2013-08-12 13:21:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
})();
|