clean up js, start adding hamburger

This commit is contained in:
zoe 2022-04-15 23:49:55 +02:00
parent b8901b68d7
commit 137f5a2b05
11 changed files with 120 additions and 41 deletions

View file

@ -1,9 +1,9 @@
$light-bg: #ffffff; $light-bg: #ffffff;
$light-bg-alt: #413c74; $light-bg-alt: #413c74;
$light-fg: #413c74; $light-fg: #413c74;
$light-ln: #9b5bb4 ; $light-ln: #9b5bb4;
$light-accent1: #9b5bb4; $light-accent1: #9b5bb4;
$light-accent2: #5183b9 ; $light-accent2: #5183b9;
$light-accent3: #413c74; $light-accent3: #413c74;
$dark-bg: #413c74; $dark-bg: #413c74;
@ -131,7 +131,7 @@ h2 {
h2 a { h2 a {
color: $dark-bg; color: $dark-bg;
&.light{ &.light {
color: $light-bg; color: $light-bg;
} }
} }
@ -251,3 +251,32 @@ header {
background-color: transparent; background-color: transparent;
} }
} }
button {
color: $dark-bg;
background-color: $dark-bg-alt;
border-color: $dark-bg;
&:hover {
transition: $trans-short;
background-color: $dark-bg;
color: $dark-bg-alt;
}
&.light {
color: $light-bg;
background-color: $light-bg-alt;
border-color: $light-bg;
&:hover {
transition: $trans-short;
background-color: $light-bg;
color: $light-bg-alt;
}
}
}
#pageindicator {
&.light {
color: $light-bg;
}
&:hover {background-color: transparent;}
background-color: transparent;
}

View file

@ -17,6 +17,7 @@ $small: 12pt;
* { * {
font-family: CaskaydiaCove; font-family: CaskaydiaCove;
font-size: $small; font-size: $small;
text-overflow: clip;
} }
p, p,

View file

@ -50,6 +50,7 @@ p code{
justify-self: left; justify-self: left;
margin-right: auto; margin-right: auto;
display: inline-flex; display: inline-flex;
align-items: center;
} }
#footer-right { #footer-right {
@ -133,3 +134,14 @@ header{
padding-top: 42pt; padding-top: 42pt;
} }
#hamburger-bg{
position: fixed;
background-color: red;
opacity: 40%;
width: 100%;
height: calc(100% - 42pt);
left: 0pt;
top: 0pt;
right: 0;
transition: 0s;
}

View file

@ -2,3 +2,4 @@
@import "./layout"; @import "./layout";
@import "./font"; @import "./font";
@import "./style"; @import "./style";
@import "./responsive"

View file

@ -0,0 +1,16 @@
#hamburger-button {
display: none;
}
@media screen and (max-width: 640pt) {
#footer-center,
#darkmode-toggle,
#darkmode-toggle-label
{
display: none;
}
#hamburger-button {
display: flex;
}
}

View file

@ -52,13 +52,15 @@ input:checked + label::after {
content: ""; content: "";
} }
.footer-nav-item { .footer-nav-item,
button{
border-radius: 100%; border-radius: 100%;
height: 1em; height: 1em;
width: 1em; width: 1em;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
border-style: solid; border-style: solid;
cursor: pointer;
} }
.togglelabel { .togglelabel {

View file

@ -5,6 +5,6 @@
{{- partial "header.html" . -}} {{- partial "header.html" . -}}
<div id="content">{{- block "main" . }}{{- end }}</div> <div id="content">{{- block "main" . }}{{- end }}</div>
{{- partial "footer.html" . -}} {{- partial "footer.html" . -}}
<script src="/js/main.js"></script> <script type="module" src="/js/main.js"></script>
</body> </body>
</html> </html>

View file

@ -1,5 +1,5 @@
<footer class="colorswitch"> <footer class="colorswitch">
<span id="footer-left"></span> <span id="footer-left"><a href="/" id="pageindicator" class="colorswitch" title="{{.Title}}"> {{.Site.Title | truncate 14}}</a></span>
<span id="footer-center"> <span id="footer-center">
<nav id="footer-nav" aria-label="navigation"> <nav id="footer-nav" aria-label="navigation">
{{ $currentPage := . }} {{ $currentPage := . }}
@ -10,6 +10,16 @@
</span> </span>
<span id="footer-right"> <span id="footer-right">
<input type="checkbox" id="darkmode-toggle" aria-label="darkmode toggle" class="toggleinput"> <input type="checkbox" id="darkmode-toggle" aria-label="darkmode toggle" class="toggleinput">
<label class="togglelabel colorswitch" for="darkmode-toggle" aria-label="darkmode toggle" role="checkbox"></label> <label class="togglelabel colorswitch" for="darkmode-toggle" aria-label="darkmode toggle" role="checkbox" id="darkmode-toggle-label"></label>
<button type="button" id="hamburger-button" class="colorswitch hamburger"></button>
<div class="hamburger colorswitch" id="hamburger-bg">
<nav id="footer-nav" aria-label="navigation">
{{ $currentPage := . }}
{{ range .Site.Menus.nav }}
<a class="footer-nav-item{{if or ($currentPage.IsMenuCurrent "nav" .) ($currentPage.HasMenuCurrent "nav" .) }} active{{end}} colorswitch" href="{{ .URL }}" title="{{ .Title }}">{{ .Name }}</a>
{{ end }}
</nav>
</div>
</span> </span>
</footer> </footer>

1
static/js/hamburger.js Normal file
View file

@ -0,0 +1 @@
function activateHamburger() {}

36
static/js/lightmode.js Normal file
View file

@ -0,0 +1,36 @@
const checkbox = document.getElementById("darkmode-toggle");
const colorswitchers = document.getElementsByClassName("colorswitch");
function switchToLight() {
for (let item of colorswitchers) {
item.classList.add("light");
}
}
function switchToDark() {
for (let item of colorswitchers) {
console.log(item);
item.classList.remove("light");
}
}
export function updateMode() {
if (localStorage.getItem("light")) {
switchToLight();
} else {
switchToDark();
}
checkbox.checked = localStorage.getItem("dark");
checkbox.addEventListener("change", function () {
localStorage.setItem("light", this.checked);
if (this.checked) {
switchToLight();
} else {
localStorage.removeItem("light");
switchToDark();
}
});
if (localStorage.getItem("light")) {
checkbox.checked = true;
}
}

View file

@ -1,36 +1,7 @@
const checkbox = document.getElementById("darkmode-toggle"); import { updateMode } from "./lightmode.js";
const colorswitchers = document.getElementsByClassName("colorswitch"); import { activateHamburger } from "./hamburger.js";
function switchToLight() {
for (let item of colorswitchers) {
item.classList.add("light");
}
}
function switchToDark() {
for (let item of colorswitchers) {
console.log(item);
item.classList.remove("light");
}
}
document.addEventListener("DOMContentLoaded", () => { document.addEventListener("DOMContentLoaded", () => {
if (localStorage.getItem("light")) { updateMode();
switchToLight(); activateHamburger();
} else {
switchToDark();
}
checkbox.checked = localStorage.getItem("dark");
checkbox.addEventListener("change", function () {
localStorage.setItem("light", this.checked);
if (this.checked) {
switchToLight();
} else {
localStorage.removeItem("light");
switchToDark();
}
});
if (localStorage.getItem("light")) {
checkbox.checked = true;
}
}); });