development #3
							
								
								
									
										45
									
								
								src/app.html
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								src/app.html
									
									
									
									
									
								
							@@ -10,56 +10,17 @@
 | 
				
			|||||||
		%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';
 | 
				
			||||||
 | 
									
 | 
				
			||||||
				background: var(--bg);
 | 
									background: var(--bg);
 | 
				
			||||||
				color: var(--fg);
 | 
									color: var(--fg);
 | 
				
			||||||
				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 {
 | 
				
			||||||
				color: var(--header);
 | 
									color: var(--header);
 | 
				
			||||||
				border: 0;
 | 
									border: 0;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										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>
 | 
				
			||||||
@@ -25,4 +25,4 @@ export const addToast = (toast: Toast) => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
export const dismissToast = (id: number) => {
 | 
					export const dismissToast = (id: number) => {
 | 
				
			||||||
  toasts.update((all) => all.filter((t) => t.id !== id));
 | 
					  toasts.update((all) => all.filter((t) => t.id !== id));
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@@ -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;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user