vert/src/lib/sections/settings/Appearance.svelte

138 lines
3.9 KiB
Svelte

<script lang="ts">
import Panel from "$lib/components/visual/Panel.svelte";
import {
theme,
effects,
setEffects,
setTheme,
} from "$lib/store/index.svelte";
import {
MoonIcon,
PaletteIcon,
PauseIcon,
PlayIcon,
SunIcon,
} from "lucide-svelte";
import { onMount, onDestroy } from "svelte";
let lightElement: HTMLButtonElement;
let darkElement: HTMLButtonElement;
let enableEffectsElement: HTMLButtonElement;
let disableEffectsElement: HTMLButtonElement;
let effectsUnsubscribe: () => void;
let themeUnsubscribe: () => void;
const updateEffectsClasses = (value: boolean) => {
if (value) {
enableEffectsElement.classList.add("selected");
disableEffectsElement.classList.remove("selected");
} else {
disableEffectsElement.classList.add("selected");
enableEffectsElement.classList.remove("selected");
}
};
const updateThemeClasses = (value: string) => {
document.documentElement.classList.remove("light", "dark");
document.documentElement.classList.add(value);
if (value === "dark") {
darkElement.classList.add("selected");
lightElement.classList.remove("selected");
} else {
lightElement.classList.add("selected");
darkElement.classList.remove("selected");
}
};
onMount(() => {
effectsUnsubscribe = effects.subscribe(updateEffectsClasses);
themeUnsubscribe = theme.subscribe(updateThemeClasses);
});
onDestroy(() => {
if (effectsUnsubscribe) effectsUnsubscribe();
if (themeUnsubscribe) themeUnsubscribe();
});
$effect(() => {
updateEffectsClasses($effects);
updateThemeClasses($theme);
});
</script>
<Panel class="flex flex-col gap-8 p-6">
<div class="flex flex-col gap-3">
<h2 class="text-2xl font-bold">
<PaletteIcon
size="40"
class="inline-block -mt-1 mr-2 bg-accent-purple p-2 rounded-full"
color="black"
/>
Appearance
</h2>
<div class="flex flex-col gap-8">
<div class="flex flex-col gap-4">
<div class="flex flex-col gap-2">
<p class="text-base font-bold">Brightness theme</p>
<p class="text-sm text-muted font-normal italic">
Want a sunny flash-bang, or a quiet lonely night?
</p>
</div>
<div class="flex flex-col gap-3 w-full">
<div class="flex gap-3 w-full">
<button
bind:this={lightElement}
onclick={() => setTheme("light")}
class="btn {$effects ? "" : "!scale-100"} flex-1 p-4 rounded-lg text-black dynadark:text-white flex items-center justify-center"
>
<SunIcon size="24" class="inline-block mr-2" />
Light
</button>
<button
bind:this={darkElement}
onclick={() => setTheme("dark")}
class="btn {$effects ? "" : "!scale-100"} flex-1 p-4 rounded-lg text-black flex items-center justify-center"
>
<MoonIcon size="24" class="inline-block mr-2" />
Dark
</button>
</div>
</div>
</div>
<div class="flex flex-col gap-4">
<div class="flex flex-col gap-2">
<p class="text-base font-bold">Effect settings</p>
<p class="text-sm text-muted font-normal italic">
Would you like fancy effects, or a more static
experience?
</p>
</div>
<div class="flex flex-col gap-3 w-full">
<div class="flex gap-3 w-full">
<button
bind:this={enableEffectsElement}
onclick={() => setEffects(true)}
class="btn {$effects ? "" : "!scale-100"} flex-1 p-4 rounded-lg text-black dynadark:text-white flex items-center justify-center"
>
<PlayIcon size="24" class="inline-block mr-2" />
Enable
</button>
<button
bind:this={disableEffectsElement}
onclick={() => setEffects(false)}
class="btn {$effects ? "" : "!scale-100"} flex-1 p-4 rounded-lg text-black dynadark:text-white flex items-center justify-center"
>
<PauseIcon size="24" class="inline-block mr-2" />
Disable
</button>
</div>
</div>
</div>
</div>
</div>
</Panel>