MDL-45780 mod_quiz: Autosave should listen for textarea:change events too
[moodle.git] / filter / mathjaxloader / yui / src / loader / js / loader.js
1 // This file is part of Moodle - http://moodle.org/
2 //
3 // Moodle is free software: you can redistribute it and/or modify
4 // it under the terms of the GNU General Public License as published by
5 // the Free Software Foundation, either version 3 of the License, or
6 // (at your option) any later version.
7 //
8 // Moodle is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 // GNU General Public License for more details.
12 //
13 // You should have received a copy of the GNU General Public License
14 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16 /**
17  * Mathjax JS Loader.
18  *
19  * @package    filter_mathjaxloader
20  * @copyright  2014 Damyon Wiese  <damyon@moodle.com>
21  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
22  */
23 M.filter_mathjaxloader = M.filter_mathjaxloader || {
25     /**
26      * The users current language - this can't be set until MathJax is loaded - so we need to store it.
27      * @property _lang
28      * @type String
29      * @default ''
30      * @private
31      */
32     _lang: '',
34     /**
35      * Boolean used to prevent configuring MathJax twice.
36      * @property _configured
37      * @type Boolean
38      * @default ''
39      * @private
40      */
41     _configured: false,
43     /**
44      * Called by the filter when it is active on any page.
45      * This does not load MathJAX yet - it addes the configuration to the head incase it gets loaded later.
46      * It also subscribes to the filter-content-updated event so MathJax can respond to content loaded by Ajax.
47      *
48      * @method typeset
49      * @param {Object} params List of configuration params containing mathjaxconfig (text) and lang
50      */
51     configure: function(params) {
53         // Add a js configuration object to the head.
54         // See "http://docs.mathjax.org/en/latest/dynamic.html#ajax-mathjax"
55         var script = document.createElement("script");
56         script.type = "text/x-mathjax-config";
57         script[(window.opera ? "innerHTML" : "text")] = params.mathjaxconfig;
58         document.getElementsByTagName("head")[0].appendChild(script);
60         // Save the lang config until MathJax is actually loaded.
61         this._lang = params.lang;
63         // Listen for events triggered when new text is added to a page that needs
64         // processing by a filter.
65         Y.on(M.core.event.FILTER_CONTENT_UPDATED, this.contentUpdated, this);
66     },
68     /**
69      * Set the correct language for the MathJax menus. Only do this once.
70      *
71      * @method setLocale
72      * @private
73      */
74     _setLocale: function() {
75         if (!this._configured) {
76             var lang = this._lang;
77             MathJax.Hub.Queue(function () {
78                 MathJax.Localization.setLocale(lang);
79             });
80             MathJax.Hub.Configured();
81             this._configured = true;
82         }
83     },
85     /**
86      * Called by the filter when an equation is found while rendering the page.
87      *
88      * @method typeset
89      */
90     typeset: function() {
91         if (!this._configured) {
92             var self = this;
93             Y.use('mathjax', function() {
94                 self._setLocale();
95                 Y.all('.filter_mathjaxloader_equation').each(function(node) {
96                     MathJax.Hub.Queue(["Typeset", MathJax.Hub, node.getDOMNode()]);
97                 });
98             });
99         }
100     },
102     /**
103      * Handle content updated events - typeset the new content.
104      * @method contentUpdated
105      * @param Y.Event - Custom event with "nodes" indicating the root of the updated nodes.
106      */
107     contentUpdated: function(event) {
108         var self = this;
109         Y.use('mathjax', function() {
110             self._setLocale();
111             event.nodes.each(function (node) {
112                 node.all('.filter_mathjaxloader_equation').each(function(node) {
113                     MathJax.Hub.Queue(["Typeset", MathJax.Hub, node.getDOMNode()]);
114                 });
115             });
116         });
117     }
118 };