summaryrefslogtreecommitdiff
path: root/pyssg.xyz/live/static/scripts/theme.js
blob: a10710107efae8d3771f56f3f90b5348ef52a318 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// refactored code for a better solution found in:
//  https://medium.com/@haxzie/dark-and-light-theme-switcher-using-css-variables-and-pure-javascript-zocada-dd0059d72fa2
var local_storage = window.localStorage;

// changed window.onload to document.addEventListener, as suggested here:
//  https://stackoverflow.com/a/800010
document.addEventListener("DOMContentLoaded", function(event) {
  let theme = local_storage.getItem('theme');

  if(theme == null){
    local_storage.setItem('theme', 'theme-dark');
  }
  else{
    if(theme == 'theme-dark'){
      setTheme('theme-dark');
    }
    else{
      setTheme('theme-light');
    }
  }
})

function setTheme(themeName){
  local_storage.setItem('theme', themeName)
  document.documentElement.className = themeName;
}

function toggleTheme(){
  if (local_storage.getItem('theme') == 'theme-dark') {
    setTheme('theme-light');
  }
  else{
    setTheme('theme-dark');
  }
}