feat: theme component
This commit is contained in:
		
							parent
							
								
									2e7009fef2
								
							
						
					
					
						commit
						a6462d8bd3
					
				
					 1 changed files with 41 additions and 0 deletions
				
			
		
							
								
								
									
										41
									
								
								src/routes/theme.svelte
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								src/routes/theme.svelte
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,41 @@
 | 
				
			||||||
 | 
					<script lang="ts">
 | 
				
			||||||
 | 
						import { onMount } from 'svelte';
 | 
				
			||||||
 | 
						import { writable } from 'svelte/store';
 | 
				
			||||||
 | 
						import { Sun, Moon } from 'lucide-svelte';
 | 
				
			||||||
 | 
						const theme = writable<'light' | 'dark'>('light');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						onMount(() => {
 | 
				
			||||||
 | 
							// Load from localStorage if exists
 | 
				
			||||||
 | 
							const stored = localStorage.getItem('theme');
 | 
				
			||||||
 | 
							if (stored === 'dark') {
 | 
				
			||||||
 | 
								document.documentElement.classList.add('dark');
 | 
				
			||||||
 | 
								theme.set('dark');
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						function toggleTheme() {
 | 
				
			||||||
 | 
							theme.update((current) => {
 | 
				
			||||||
 | 
								const next = current === 'light' ? 'dark' : 'light';
 | 
				
			||||||
 | 
								if (next === 'dark') {
 | 
				
			||||||
 | 
									document.documentElement.classList.add('dark');
 | 
				
			||||||
 | 
								} else {
 | 
				
			||||||
 | 
									document.documentElement.classList.remove('dark');
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								localStorage.setItem('theme', next);
 | 
				
			||||||
 | 
								return next;
 | 
				
			||||||
 | 
							});
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<button
 | 
				
			||||||
 | 
						on:click={toggleTheme}
 | 
				
			||||||
 | 
						class="text-gruvboxLight-fg dark:text-gruvboxDark-fg rounded-md px-4 py-2 transition-all duration-300 ease-out hover:scale-[1.05] hover:drop-shadow-[2px_2px_1px_#000000]"
 | 
				
			||||||
 | 
					>
 | 
				
			||||||
 | 
						{#if $theme === 'light'}
 | 
				
			||||||
 | 
							<Moon class="size-8" />
 | 
				
			||||||
 | 
						{/if}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						{#if $theme === 'dark'}
 | 
				
			||||||
 | 
							<Sun class="size-8" />
 | 
				
			||||||
 | 
						{/if}
 | 
				
			||||||
 | 
					</button>
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue