function initThemeChooser(settings) { var isInitialized = false; var $currentStylesheet = $(); var $loading = $('#loading'); var $systemSelect = $('#theme-system-selector select') .on('change', function() { setThemeSystem(this.value); }); setThemeSystem($systemSelect.val()); function setThemeSystem(themeSystem) { var $allSelectWraps = $('.selector[data-theme-system]').hide(); var $selectWrap = $allSelectWraps.filter('[data-theme-system="' + themeSystem +'"]').show(); var $select = $selectWrap.find('select') .off('change') // avoid duplicate handlers :( .on('change', function() { setTheme(themeSystem, this.value); }); setTheme(themeSystem, $select.val()); } function setTheme(themeSystem, themeName) { var stylesheetUrl = generateStylesheetUrl(themeSystem, themeName); var $stylesheet; function done() { if (!isInitialized) { isInitialized = true; settings.init(themeSystem); } else { settings.change(themeSystem); } showCredits(themeSystem, themeName); } if (stylesheetUrl) { $stylesheet = $('').appendTo('head'); $loading.show(); whenStylesheetLoaded($stylesheet[0], function() { $currentStylesheet.remove(); $currentStylesheet = $stylesheet; $loading.hide(); done(); }); } else { $currentStylesheet.remove(); $currentStylesheet = $(); done(); } } function generateStylesheetUrl(themeSystem, themeName) { if (themeSystem === 'jquery-ui') { return 'https://code.jquery.com/ui/1.12.1/themes/' + themeName + '/jquery-ui.css'; } else if (themeSystem === 'bootstrap3') { if (themeName) { return 'https://bootswatch.com/' + themeName + '/bootstrap.min.css'; } else { // the default bootstrap theme return 'https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css'; } } } function showCredits(themeSystem, themeName) { var creditId; if (themeSystem === 'jquery-ui') { creditId = 'jquery-ui'; } else if (themeSystem === 'bootstrap3') { if (themeName) { creditId = 'bootstrap-custom'; } else { creditId = 'bootstrap-standard'; } } $('.credits').hide() .filter('[data-credit-id="' + creditId + '"]').show(); } function whenStylesheetLoaded(linkNode, callback) { var isReady = false; function ready() { if (!isReady) { // avoid double-call isReady = true; callback(); } } linkNode.onload = ready; // does not work cross-browser setTimeout(ready, 2000); // max wait. also handles browsers that don't support onload } }