web: basic settings page needed for testing

typescript cries about types but i don't care at this point
This commit is contained in:
wukko
2024-06-20 18:05:17 +06:00
parent 09548c89b6
commit e610f3ad67
5 changed files with 89 additions and 11 deletions

View File

@@ -0,0 +1,32 @@
<script
lang="ts"
generics="
Context extends Exclude<keyof CobaltSettings, 'schemaVersion'>,
Id extends keyof CobaltSettings[Context],
Key extends CobaltSettings[Context][Id]
"
>
import settings, { updateSetting } from "$lib/settings";
import type { CobaltSettings } from "$lib/types/settings";
export let settingContext: Context;
export let settingId: Id;
export let settingKey: Key;
$: setting = $settings[settingContext][settingId];
$: isSelected = setting === settingKey;
</script>
<button
id="setting-button-{settingContext}-{String(settingId)}-{settingKey}"
class="button"
class:selected={isSelected}
on:click={() =>
updateSetting({
[settingContext]: {
[settingId]: settingKey,
},
})}
>
<slot></slot>
</button>