mirror of
https://github.com/trwnh/hugo-theme-paradox.git
synced 2024-11-24 10:21:21 +00:00
finish fixing color switcher
This commit is contained in:
parent
cf9dc13bda
commit
ddadf97337
|
@ -1,25 +1,25 @@
|
||||||
<div class="color-switcher">
|
<div class="color-switcher">
|
||||||
<div class="js-toggle-wrapper">
|
<div class="js-toggle-wrapper">
|
||||||
<div class="js-toggle" style="display: none">
|
<div class="js-toggle" style="display: none">
|
||||||
<div class="js-toggle-track">
|
<div class="js-toggle-track">
|
||||||
<div class="js-toggle-track-check">
|
<div class="js-toggle-track-check">
|
||||||
<img
|
<img
|
||||||
src=""
|
src=""
|
||||||
role="presentation" style="pointer-events: none;" width="16" height="16">
|
role="presentation" style="pointer-events: none;" width="16" height="16">
|
||||||
</div>
|
</div>
|
||||||
<div class="js-toggle-track-x">
|
<div class="js-toggle-track-x">
|
||||||
<img
|
<img
|
||||||
src=""
|
src=""
|
||||||
role="presentation" style="pointer-events: none;" width="16" height="16">
|
role="presentation" style="pointer-events: none;" width="16" height="16">
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="js-toggle-thumb"></div>
|
||||||
|
<input class="js-toggle-screenreader-only" type="checkbox" aria-label="Switch between Dark and Light mode">
|
||||||
</div>
|
</div>
|
||||||
<div class="js-toggle-thumb"></div>
|
|
||||||
<input class="js-toggle-screenreader-only" type="checkbox" aria-label="Switch between Dark and Light mode">
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
<style>
|
<style>
|
||||||
/*
|
/*
|
||||||
* Dark Mode Toggle
|
* Dark Mode Toggle
|
||||||
* Copyright (c) 2015 instructure-react
|
* Copyright (c) 2015 instructure-react
|
||||||
* Forked from Dan Abramov's personal blog
|
* Forked from Dan Abramov's personal blog
|
||||||
|
@ -27,162 +27,161 @@
|
||||||
* MIT License
|
* MIT License
|
||||||
**/
|
**/
|
||||||
|
|
||||||
.js-toggle-wrapper {
|
.js-toggle-wrapper {
|
||||||
display: table;
|
display: table;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle {
|
.js-toggle {
|
||||||
touch-action: pan-x;
|
touch-action: pan-x;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
position: relative;
|
position: relative;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
border: 0;
|
border: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
-webkit-touch-callout: none;
|
-webkit-touch-callout: none;
|
||||||
user-select: none;
|
user-select: none;
|
||||||
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
|
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
|
||||||
-webkit-tap-highlight-color: transparent;
|
-webkit-tap-highlight-color: transparent;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle-screenreader-only {
|
.js-toggle-screenreader-only {
|
||||||
border: 0;
|
border: 0;
|
||||||
clip: rect(0 0 0 0);
|
clip: rect(0 0 0 0);
|
||||||
height: 1px;
|
height: 1px;
|
||||||
margin: -1px;
|
margin: -1px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 1px;
|
width: 1px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle-track {
|
.js-toggle-track {
|
||||||
width: 50px;
|
width: 50px;
|
||||||
height: 24px;
|
height: 24px;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
border-radius: 30px;
|
border-radius: 30px;
|
||||||
background-color: #808080;
|
background-color: #808080;
|
||||||
transition: all 0.2s ease;
|
transition: all 0.2s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle-track-check {
|
.js-toggle-track-check {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 17px;
|
width: 17px;
|
||||||
height: 17px;
|
height: 17px;
|
||||||
left: 5px;
|
left: 5px;
|
||||||
top: 0px;
|
top: 0px;
|
||||||
bottom: 0px;
|
bottom: 0px;
|
||||||
margin-top: auto;
|
margin-top: auto;
|
||||||
margin-bottom: auto;
|
margin-bottom: auto;
|
||||||
line-height: 0;
|
line-height: 0;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
transition: opacity 0.25s ease;
|
transition: opacity 0.25s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle--checked .js-toggle-track-check {
|
.js-toggle--checked .js-toggle-track-check {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
transition: opacity 0.25s ease;
|
transition: opacity 0.25s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle-track-x {
|
.js-toggle-track-x {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
width: 17px;
|
width: 17px;
|
||||||
height: 17px;
|
height: 17px;
|
||||||
right: 5px;
|
right: 5px;
|
||||||
top: 0px;
|
top: 0px;
|
||||||
bottom: 0px;
|
bottom: 0px;
|
||||||
margin-top: auto;
|
margin-top: auto;
|
||||||
margin-bottom: auto;
|
margin-bottom: auto;
|
||||||
line-height: 0;
|
line-height: 0;
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
transition: opacity 0.25s ease;
|
transition: opacity 0.25s ease;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle--checked .js-toggle-track-x {
|
.js-toggle--checked .js-toggle-track-x {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle-thumb {
|
.js-toggle-thumb {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 1px;
|
top: 1px;
|
||||||
left: 1px;
|
left: 1px;
|
||||||
width: 22px;
|
width: 22px;
|
||||||
height: 22px;
|
height: 22px;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
background-color: #fafafa;
|
background-color: #fafafa;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1) 0ms;
|
transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1) 0ms;
|
||||||
transform: translateX(0);
|
transform: translateX(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle--checked .js-toggle-thumb {
|
.js-toggle--checked .js-toggle-thumb {
|
||||||
transform: translateX(26px);
|
transform: translateX(26px);
|
||||||
border-color: #19ab27;
|
border-color: #19ab27;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle--focus {
|
.js-toggle--focus {
|
||||||
filter: drop-shadow(0px 0px 3px var(--primary-accent));
|
filter: drop-shadow(0px 0px 3px var(--primary-accent));
|
||||||
outline: 1px solid var(--ui-text);
|
outline: 1px solid var(--ui-text);
|
||||||
outline-offset: 6px;
|
outline-offset: 6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.js-toggle:active .js-toggle-thumb {
|
.js-toggle:active .js-toggle-thumb {
|
||||||
box-shadow: 0px 0px 5px 5px var(--primary-accent);
|
box-shadow: 0px 0px 5px 5px var(--primary-accent);
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<script>
|
<script>
|
||||||
var body = document.body;
|
var body = document.body;
|
||||||
var switcher = document.getElementsByClassName('js-toggle');
|
var switchers = document.getElementsByClassName('js-toggle');
|
||||||
var input = document.getElementsByClassName('js-toggle-screenreader-only');
|
|
||||||
|
|
||||||
console.log(switcher);
|
for (switcher of switchers) {
|
||||||
|
switcher.removeAttribute("style");
|
||||||
|
var input = switcher.querySelector('.js-toggle-screenreader-only')
|
||||||
|
|
||||||
for (s of switcher) {
|
input.addEventListener('focus', (event) => {
|
||||||
s.removeAttribute("style");
|
switcher.classList.add('js-toggle--focus');
|
||||||
};
|
});
|
||||||
|
|
||||||
input.addEventListener('focus', (event) => {
|
input.addEventListener('focusout', (event) => {
|
||||||
switcher.classList.add('js-toggle--focus');
|
switcher.classList.remove('js-toggle--focus');
|
||||||
});
|
});
|
||||||
|
|
||||||
input.addEventListener('focusout', (event) => {
|
//Click on dark mode icon. Add dark mode classes and wrappers. Store user preference through sessions
|
||||||
switcher.classList.remove('js-toggle--focus');
|
switcher.addEventListener("click", function () {
|
||||||
});
|
for (switcher of switchers) {
|
||||||
|
this.classList.toggle('js-toggle--checked');
|
||||||
|
}
|
||||||
|
//this.classList.add('js-toggle--focus');
|
||||||
|
//If dark mode is selected
|
||||||
|
if (this.classList.contains('js-toggle--checked')) {
|
||||||
|
body.classList.remove('light-mode');
|
||||||
|
body.classList.add('dark-mode');
|
||||||
|
//Save user preference in storage
|
||||||
|
localStorage.setItem('colorMode', 'dark');
|
||||||
|
} else {
|
||||||
|
body.classList.remove('dark-mode');
|
||||||
|
body.classList.add('light-mode');
|
||||||
|
setTimeout(function () {
|
||||||
|
localStorage.setItem('colorMode', 'light');
|
||||||
|
}, 100);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
//Click on dark mode icon. Add dark mode classes and wrappers. Store user preference through sessions
|
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||||
switcher.addEventListener("click", function() {
|
localStorage.setItem('colorMode', 'dark');
|
||||||
this.classList.toggle('js-toggle--checked');
|
}
|
||||||
//this.classList.add('js-toggle--focus');
|
|
||||||
//If dark mode is selected
|
|
||||||
if (this.classList.contains('js-toggle--checked')) {
|
|
||||||
body.classList.remove('light-mode');
|
|
||||||
body.classList.add('dark-mode');
|
|
||||||
//Save user preference in storage
|
|
||||||
localStorage.setItem('colorMode', 'dark');
|
|
||||||
} else {
|
|
||||||
body.classList.remove('dark-mode');
|
|
||||||
body.classList.add('light-mode');
|
|
||||||
setTimeout(function() {
|
|
||||||
localStorage.setItem('colorMode', 'light');
|
|
||||||
}, 100);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
//Check Storage. Keep user preference on page reload
|
||||||
localStorage.setItem('colorMode', 'dark');
|
if (localStorage.getItem('colorMode') == 'dark') {
|
||||||
}
|
for (switcher of switchers) {
|
||||||
|
switcher.classList.add('js-toggle--checked');
|
||||||
//Check Storage. Keep user preference on page reload
|
}
|
||||||
if (localStorage.getItem('colorMode') == 'dark') {
|
body.classList.add('dark-mode');
|
||||||
//body.classList.add('dark-mode');
|
};
|
||||||
switcher.classList.add('js-toggle--checked');
|
if (localStorage.getItem('colorMode') == 'light') {
|
||||||
body.classList.add('dark-mode');
|
body.classList.add('light-mode');
|
||||||
}
|
};
|
||||||
if (localStorage.getItem('colorMode') == 'light') {
|
|
||||||
//body.classList.add('dark-mode');
|
|
||||||
|
|
||||||
body.classList.add('light-mode');
|
|
||||||
}
|
|
||||||
|
|
||||||
</script>
|
</script>
|
Loading…
Reference in a new issue