|
@@ -1,6 +1,7 @@
|
|
<script lang="ts">
|
|
<script lang="ts">
|
|
import { createEventDispatcher, tick } from 'svelte';
|
|
import { createEventDispatcher, tick } from 'svelte';
|
|
import { Switch } from 'bits-ui';
|
|
import { Switch } from 'bits-ui';
|
|
|
|
+ import { settings } from '$lib/stores';
|
|
export let state = true;
|
|
export let state = true;
|
|
export let id = '';
|
|
export let id = '';
|
|
|
|
|
|
@@ -12,9 +13,12 @@
|
|
<Switch.Root
|
|
<Switch.Root
|
|
bind:checked={state}
|
|
bind:checked={state}
|
|
{id}
|
|
{id}
|
|
- class="flex h-5 min-h-5 w-9 shrink-0 cursor-pointer items-center rounded-full px-[3px] mx-[1px] transition {state
|
|
|
|
|
|
+ class="flex h-5 min-h-5 w-9 shrink-0 cursor-pointer items-center rounded-full px-[3px] mx-[1px] transition {($settings?.highContrastMode ??
|
|
|
|
+ false)
|
|
|
|
+ ? 'focus:outline focus:outline-2 focus:outline-gray-800 focus:dark:outline-gray-200'
|
|
|
|
+ : 'outline outline-1 outline-gray-100 dark:outline-gray-800'} {state
|
|
? ' bg-emerald-600'
|
|
? ' bg-emerald-600'
|
|
- : 'bg-gray-200 dark:bg-transparent'} outline outline-1 outline-gray-100 dark:outline-gray-800"
|
|
|
|
|
|
+ : 'bg-gray-200 dark:bg-transparent'}"
|
|
>
|
|
>
|
|
<Switch.Thumb
|
|
<Switch.Thumb
|
|
class="pointer-events-none block size-4 shrink-0 rounded-full bg-white transition-transform data-[state=checked]:translate-x-3.5 data-[state=unchecked]:translate-x-0 data-[state=unchecked]:shadow-mini "
|
|
class="pointer-events-none block size-4 shrink-0 rounded-full bg-white transition-transform data-[state=checked]:translate-x-3.5 data-[state=unchecked]:translate-x-0 data-[state=unchecked]:shadow-mini "
|