mirror of
https://github.com/gitpitch/gitpitch.git
synced 2024-04-18 07:30:55 +08:00
9c870227ac
GitPitch default reveal.js dependency is now 3.4.1. Also added support for new PITCHME.yaml property, called revealjs-version. This property allows a presentation owner to specify a specific version of reveal.js to use with their presentation. Currently supported versions are 3.4.1 or 3.3.1.
68 lines
1.6 KiB
JavaScript
Executable File
68 lines
1.6 KiB
JavaScript
Executable File
/**
|
|
* A plugin which enables rendering of math equations inside
|
|
* of reveal.js slides. Essentially a thin wrapper for MathJax.
|
|
*
|
|
* @author Hakim El Hattab
|
|
*/
|
|
var RevealMath = window.RevealMath || (function(){
|
|
|
|
var options = Reveal.getConfig().math || {};
|
|
options.mathjax = options.mathjax || 'https://cdn.mathjax.org/mathjax/latest/MathJax.js';
|
|
options.config = options.config || 'TeX-AMS_HTML-full';
|
|
|
|
loadScript( options.mathjax + '?config=' + options.config, function() {
|
|
|
|
MathJax.Hub.Config({
|
|
messageStyle: 'none',
|
|
tex2jax: {
|
|
inlineMath: [['$','$'],['\\(','\\)']] ,
|
|
skipTags: ['script','noscript','style','textarea','pre']
|
|
},
|
|
skipStartupTypeset: true
|
|
});
|
|
|
|
// Typeset followed by an immediate reveal.js layout since
|
|
// the typesetting process could affect slide height
|
|
MathJax.Hub.Queue( [ 'Typeset', MathJax.Hub ] );
|
|
MathJax.Hub.Queue( Reveal.layout );
|
|
|
|
// Reprocess equations in slides when they turn visible
|
|
Reveal.addEventListener( 'slidechanged', function( event ) {
|
|
|
|
MathJax.Hub.Queue( [ 'Typeset', MathJax.Hub, event.currentSlide ] );
|
|
|
|
} );
|
|
|
|
} );
|
|
|
|
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();
|
|
}
|
|
}
|
|
|
|
// Normal browsers
|
|
head.appendChild( script );
|
|
|
|
}
|
|
|
|
})();
|