Added ability to switch between light and dark mode
This commit is contained in:
parent
278fc640ce
commit
6f0f5f1cf7
41
src/app.html
41
src/app.html
@ -10,46 +10,6 @@
|
|||||||
%sveltekit.head%
|
%sveltekit.head%
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
@media (prefers-color-scheme: dark) {
|
|
||||||
:root {
|
|
||||||
--bg: #282c34;
|
|
||||||
--bg-secondary: #474d57;
|
|
||||||
--bg-grad-1: #484e58;
|
|
||||||
--bg-grad-2: #4e5560;
|
|
||||||
--bg-grad-3: #59616d;
|
|
||||||
--bg-grad-4: #606a7b;
|
|
||||||
--bg-grad-5: #606978;
|
|
||||||
--input: #4e5560;
|
|
||||||
--fg: #ABB2BF;
|
|
||||||
--header: #E06C75;
|
|
||||||
--link: #98C379;
|
|
||||||
--hover: #56B6C2;
|
|
||||||
--glow: #C678DD;
|
|
||||||
|
|
||||||
--green: #98C379;
|
|
||||||
--red: #E06C75;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media (prefers-color-scheme: light) {
|
|
||||||
:root {
|
|
||||||
--bg: #fff;
|
|
||||||
--bg-secondary: #ebebeb;
|
|
||||||
--bg-grad-1: #c1c1c1;
|
|
||||||
--bg-grad-2: #a1a1a1;
|
|
||||||
--bg-grad-3: #858585;
|
|
||||||
--bg-grad-4: #616161;
|
|
||||||
--bg-grad-5: #484848;
|
|
||||||
--input: #a9a9a9;
|
|
||||||
--fg: #2f2f2f;
|
|
||||||
--header: #514a4a;
|
|
||||||
--link: #df0000;
|
|
||||||
--hover: #4f4b489b;
|
|
||||||
--glow: #545454;
|
|
||||||
|
|
||||||
--green: #98C379;
|
|
||||||
--red: #E06C75;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
:root {
|
:root {
|
||||||
--font: Consolas, 'Cascadia Code', Monaco, 'SF Mono', 'DejaVu Sans Mono', 'Roboto Mono';
|
--font: Consolas, 'Cascadia Code', Monaco, 'SF Mono', 'DejaVu Sans Mono', 'Roboto Mono';
|
||||||
|
|
||||||
@ -58,6 +18,7 @@
|
|||||||
font-family: var(--font);
|
font-family: var(--font);
|
||||||
font-size: 110%;
|
font-size: 110%;
|
||||||
margin: 2rem;
|
margin: 2rem;
|
||||||
|
transition: all 0.2s;
|
||||||
}
|
}
|
||||||
|
|
||||||
h1, h2, h3 {
|
h1, h2, h3 {
|
||||||
|
102
src/lib/components/ThemeSwitcher.svelte
Normal file
102
src/lib/components/ThemeSwitcher.svelte
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
<script lang="ts">
|
||||||
|
import { browser } from '$app/environment';
|
||||||
|
|
||||||
|
export let darkMode: boolean = true;
|
||||||
|
|
||||||
|
function onThemeSwitch() {
|
||||||
|
darkMode = !darkMode;
|
||||||
|
|
||||||
|
localStorage.setItem('theme', darkMode ? 'dark' : 'light');
|
||||||
|
|
||||||
|
darkMode
|
||||||
|
? document.documentElement.classList.add('dark')
|
||||||
|
: document.documentElement.classList.remove('dark');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (browser) {
|
||||||
|
if (
|
||||||
|
localStorage.theme === 'dark' ||
|
||||||
|
(!('theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)
|
||||||
|
) {
|
||||||
|
document.documentElement.classList.add('dark');
|
||||||
|
darkMode = true;
|
||||||
|
} else {
|
||||||
|
document.documentElement.classList.remove('dark');
|
||||||
|
darkMode = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
input {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.switch {
|
||||||
|
position: absolute;
|
||||||
|
top: 0em;
|
||||||
|
right: 0em;
|
||||||
|
display: inline-block;
|
||||||
|
width: 3.75em;
|
||||||
|
height: 2.125em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.slider {
|
||||||
|
position: absolute;
|
||||||
|
cursor: pointer;
|
||||||
|
background-color: var(--bg-grad-4);
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
background-color: #ccc;
|
||||||
|
-webkit-transition: .4s;
|
||||||
|
transition: .4s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.slider:before {
|
||||||
|
position: absolute;
|
||||||
|
content: "";
|
||||||
|
height: 80%;
|
||||||
|
width: 45%;
|
||||||
|
left: 4px;
|
||||||
|
bottom: 4px;
|
||||||
|
background-color: white;
|
||||||
|
-webkit-transition: .4s;
|
||||||
|
transition: .4s;
|
||||||
|
}
|
||||||
|
input:checked + .slider {
|
||||||
|
background-color: var(--bg-grad-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
input:checked + .slider:before {
|
||||||
|
background: var(--bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
input:checked + .slider:before {
|
||||||
|
-webkit-transform: translateX(1.625em);
|
||||||
|
-ms-transform: translateX(1.625em);
|
||||||
|
transform: translateX(1.625em);
|
||||||
|
}
|
||||||
|
|
||||||
|
.slider.round {
|
||||||
|
border-radius: 2.125em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.slider.round:before {
|
||||||
|
border-radius: 50%;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<svelte:head>
|
||||||
|
<link rel="stylesheet" href={`/themes/${darkMode ? 'dark' : 'light'}.css`} />
|
||||||
|
</svelte:head>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="toggle-wrapper not-required">
|
||||||
|
<label class="switch">
|
||||||
|
<input type="checkbox" checked={darkMode} on:click={onThemeSwitch}>
|
||||||
|
<span class="slider round"></span>
|
||||||
|
</label>
|
||||||
|
</div>
|
@ -1,5 +1,6 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import Toasts from "$lib/components/Toasts/Toasts.svelte";
|
import Toasts from "$lib/components/Toasts/Toasts.svelte";
|
||||||
|
import ThemeSwitcher from "$lib/components/ThemeSwitcher.svelte";
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
@ -18,7 +19,7 @@
|
|||||||
|
|
||||||
nav {
|
nav {
|
||||||
position: relative;
|
position: relative;
|
||||||
overflow:visible;
|
overflow: visible;
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
gap: 1.5em;
|
gap: 1.5em;
|
||||||
@ -48,9 +49,10 @@
|
|||||||
<a href = "/">//Profile</a>
|
<a href = "/">//Profile</a>
|
||||||
<a href = "/repos">//Repos</a>
|
<a href = "/repos">//Repos</a>
|
||||||
<a href = "/contact">//Contact</a>
|
<a href = "/contact">//Contact</a>
|
||||||
|
<ThemeSwitcher />
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<div class="main-container fade">
|
<div class="main-container fade">
|
||||||
<Toasts></Toasts>
|
<Toasts />
|
||||||
<slot />
|
<slot />
|
||||||
</div>
|
</div>
|
||||||
|
@ -26,10 +26,10 @@
|
|||||||
<TimelineSeparator>
|
<TimelineSeparator>
|
||||||
{#if item.duration.includes('Present') || !item.duration.includes('-')}
|
{#if item.duration.includes('Present') || !item.duration.includes('-')}
|
||||||
<div class="elementToFadeInAndOut">
|
<div class="elementToFadeInAndOut">
|
||||||
<TimelineDot style={`background-color: var(--link); border-color: var(--bg-grad);`} />
|
<TimelineDot style={`background-color: var(--link); border-color: var(--bg-grad-2);`} />
|
||||||
</div>
|
</div>
|
||||||
{:else}
|
{:else}
|
||||||
<TimelineDot style={`background-color: var(--link); border-color: var(--bg-grad);`} />
|
<TimelineDot style={`background-color: var(--link); border-color: var(--bg-grad-2);`} />
|
||||||
{/if}
|
{/if}
|
||||||
<TimelineConnector />
|
<TimelineConnector />
|
||||||
</TimelineSeparator>
|
</TimelineSeparator>
|
||||||
|
18
static/themes/dark.css
Normal file
18
static/themes/dark.css
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
:root {
|
||||||
|
--bg: #282c34;
|
||||||
|
--bg-secondary: #474d57;
|
||||||
|
--bg-grad-1: #484e58;
|
||||||
|
--bg-grad-2: #4e5560;
|
||||||
|
--bg-grad-3: #59616d;
|
||||||
|
--bg-grad-4: #606a7b;
|
||||||
|
--bg-grad-5: #606978;
|
||||||
|
--input: #4e5560;
|
||||||
|
--fg: #ABB2BF;
|
||||||
|
--header: #E06C75;
|
||||||
|
--link: #98C379;
|
||||||
|
--hover: #56B6C2;
|
||||||
|
--glow: #C678DD;
|
||||||
|
|
||||||
|
--green: #98C379;
|
||||||
|
--red: #E06C75;
|
||||||
|
}
|
18
static/themes/light.css
Normal file
18
static/themes/light.css
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
:root {
|
||||||
|
--bg: #fff;
|
||||||
|
--bg-secondary: #ebebeb;
|
||||||
|
--bg-grad-1: #c1c1c1;
|
||||||
|
--bg-grad-2: #a1a1a1;
|
||||||
|
--bg-grad-3: #858585;
|
||||||
|
--bg-grad-4: #616161;
|
||||||
|
--bg-grad-5: #484848;
|
||||||
|
--input: #a9a9a9;
|
||||||
|
--fg: #2f2f2f;
|
||||||
|
--header: #514a4a;
|
||||||
|
--link: #df0000;
|
||||||
|
--hover: #4f4b489b;
|
||||||
|
--glow: #545454;
|
||||||
|
|
||||||
|
--green: #98C379;
|
||||||
|
--red: #E06C75;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user