moodle/theme/splash/yui/colourswitcher/colourswitcher.js
2010-09-17 19:59:16 +00:00

63 lines
2.0 KiB
JavaScript

YUI.add('moodle-theme_splash-colourswitcher', function(Y) {
// Available colours
var COLOURS = ['red','green','blue','orange'];
/**
* Splash theme colour switcher class.
* Initialise this class by calling M.theme_splash.init
*/
var ColourSwitcher = function() {
ColourSwitcher.superclass.constructor.apply(this, arguments);
};
ColourSwitcher.prototype = {
/**
* Constructor for this class
* @param {object} config
*/
initializer : function(config) {
var i, c;
// Attach events to the links to change colours so we can do it with
// JavaScript without refreshing the page
for (i in COLOURS) {
c = COLOURS[i];
// Check if this is the current colour
if (Y.one(document.body).hasClass('splash-'+c)) {
this.set('colour', c);
}
Y.all(config.div+' .colour-'+c).on('click', this.setColour, this, c);
}
},
/**
* Sets the colour being used for the splash theme
* @param {Y.Event} e The event that fired
* @param {string} colour The new colour
*/
setColour : function(e, colour) {
// Prevent the event from refreshing the page
e.preventDefault();
// Switch over the CSS classes on the body
Y.one(document.body).replaceClass('splash-'+this.get('colour'), 'splash-'+colour);
// Update the current colour
this.set('colour', colour);
// Store the users selection (Uses AJAX to save to the database)
M.util.set_user_preference('theme_splash_chosen_colour', colour);
}
};
// Make the colour switcher a fully fledged YUI module
Y.extend(ColourSwitcher, Y.Base, ColourSwitcher.prototype, {
NAME : 'Splash theme colour switcher',
ATTRS : {
colour : {
value : 'red'
}
}
});
// Our splash theme namespace
M.theme_splash = M.theme_splash || {};
// Initialisation function for the colour switcher
M.theme_splash.initColourSwitcher = function(cfg) {
return new ColourSwitcher(cfg);
}
}, '@VERSION@', {requires:['base','node']});