some cleanup and better notation

This commit is contained in:
Robert Clarke 2019-05-07 14:19:42 +01:00
parent 09c17330d6
commit 34905fb69f
2 changed files with 39 additions and 18 deletions

View file

@ -8,14 +8,21 @@
let theme = localStorage.getItem(THEME_KEY); let theme = localStorage.getItem(THEME_KEY);
//Private Methods //Private Methods
/* Called when the theme is changed */
function changeTheme(themeName, firstLoad) { function changeTheme(themeName, firstLoad) {
//create the css link element
var fileref = document.createElement("link"); var fileref = document.createElement("link");
fileref.rel = "stylesheet"; fileref.rel = "stylesheet";
fileref.type = "text/css"; fileref.type = "text/css";
fileref.href = `/${themeName}.css`; fileref.href = `/${themeName}.css`;
//append it to the head
link = document.getElementsByTagName("head")[0].appendChild(fileref); link = document.getElementsByTagName("head")[0].appendChild(fileref);
//when it's loaded, call onLinkLoad
link.addEventListener('load', onLinkLoad); link.addEventListener('load', onLinkLoad);
//if this is the first load of the page, remove the current stylesheet early to avoid flash of wrongly styled content
if (firstLoad) { if (firstLoad) {
document.querySelectorAll('.stylesheet').forEach((el) => { document.querySelectorAll('.stylesheet').forEach((el) => {
el.remove(); el.remove();
@ -25,42 +32,55 @@
saveTheme(themeName); saveTheme(themeName);
}; };
/* The function called when the css has finished loading */
function onLinkLoad() { function onLinkLoad() {
link.removeEventListener('load', onLinkLoad); link.removeEventListener('load', onLinkLoad);
//remove the previous stylesheet(s)
document.querySelectorAll('.stylesheet').forEach((el) => { document.querySelectorAll('.stylesheet').forEach((el) => {
el.remove(); el.remove();
}); });
//add stylesheet class
link.className += 'stylesheet'; link.className += 'stylesheet';
addcss('body{visibility:visible;}'); //make body visible again if it was hidden
showBody();
}; };
/* Saves the current theme in localstorage */
function saveTheme(themeName) { function saveTheme(themeName) {
localStorage.setItem(THEME_KEY, themeName); localStorage.setItem(THEME_KEY, themeName);
}; };
function addcss(css) { /* Adds the given css to the head. */
let el = document.getElementById(STOP_LINK_CSS_ID); function hideBody() {
if (el) {
el.innerText = css;
} else {
var head = document.getElementsByTagName('head')[0]; var head = document.getElementsByTagName('head')[0];
var style = document.createElement('style'); var style = document.createElement('style');
style.id = STOP_LINK_CSS_ID; style.id = STOP_LINK_CSS_ID;
style.setAttribute('type', 'text/css'); style.setAttribute('type', 'text/css');
if (style.styleSheet) { // IE
if (style.styleSheet) {
style.styleSheet.cssText = css; style.styleSheet.cssText = css;
} else { // the world } else {
style.appendChild(document.createTextNode(css)); style.appendChild(document.createTextNode('body{visibility:hidden;}'));
}
head.insertBefore(style, head.firstChild);
} }
head.appendChild(style);
};
function showBody() {
let css = document.getElementById(STOP_LINK_CSS_ID);
if (css)
css.remove();
}; };
//Public Methods //Public Methods
switch_css.init = function () { switch_css.init = function () {
//if user has selected and theme and it is not the current theme
if (theme && !document.getElementById(theme)) { if (theme && !document.getElementById(theme)) {
addcss('body{visibility:hidden;}') //hide the body to stop FOUC
hideBody();
//change the theme
changeTheme(theme, true); changeTheme(theme, true);
//when the DOM is loaded, change the select to their current choice
window.addEventListener('DOMContentLoaded', () => { window.addEventListener('DOMContentLoaded', () => {
document.querySelectorAll('#theme-select>option').forEach(element => { document.querySelectorAll('#theme-select>option').forEach(element => {
if (element.value === theme) { if (element.value === theme) {
@ -69,6 +89,7 @@
}); });
}); });
} }
//when the DOM is loaded, set the dropdown to trigger the theme change
window.addEventListener('DOMContentLoaded', () => { window.addEventListener('DOMContentLoaded', () => {
document.getElementById('theme-select').onchange = function () { document.getElementById('theme-select').onchange = function () {
changeTheme(this.value); changeTheme(this.value);

View file

@ -16,12 +16,12 @@
{% block title %}{{ config.title }}{% endblock title %} {% block title %}{{ config.title }}{% endblock title %}
</title> </title>
{{ index_macros::css() }} {{ index_macros::css() }}
<!-- This script must follow css -->
{% if config.extra.zulma_allow_theme_selection %} {% if config.extra.zulma_allow_theme_selection %}
<script type="text/javascript" src="{{ get_url(path="js/switchcss.js") }}"></script> <script type="text/javascript" src="{{ get_url(path="js/switchcss.js") }}"></script>
{% endif %} {% endif %}
{% if config.generate_rss %} {% if config.generate_rss %}
<link rel="alternate" type="application/rss+xml" title="RSS" href="{{ get_url(path="rss.xml") | safe }}"> <link rel="alternate" type="application/rss+xml" title="RSS" href="{{ get_url(path="rss.xml") | safe }}">
{% endif %} {% endif %}