safetwitch/src/views/SettingsView.vue

85 lines
2.8 KiB
Vue
Raw Normal View History

2023-08-16 13:04:24 -04:00
<script lang="ts">
2023-08-19 20:37:11 -04:00
import { getDefaultSettings, syncUserSettings, setLanguage } from '@/settingsManager'
2023-08-18 13:12:06 -04:00
2023-08-16 13:04:24 -04:00
export default {
2023-08-18 13:39:26 -04:00
setup() {
let settings
syncUserSettings()
2023-08-16 13:04:24 -04:00
2023-08-18 13:39:26 -04:00
let storedSettings = localStorage.getItem('settings')
if (storedSettings === null) {
settings = getDefaultSettings()
} else {
settings = JSON.parse(storedSettings)
}
2023-08-16 13:04:24 -04:00
2023-08-18 13:39:26 -04:00
return {
settings
}
},
methods: {
save() {
const settings = JSON.stringify(this.settings)
localStorage.setItem('settings', settings)
2023-08-19 20:37:11 -04:00
setLanguage(this.settings.language.selected, this.$i18n)
window.location.reload()
2023-08-18 13:39:26 -04:00
}
2023-08-16 13:04:24 -04:00
// download() {
// var hiddenElement = document.createElement('a');
// hiddenElement.href = 'data:attachment/text,' + encodeURI(JSON.stringify(this.settings));
// hiddenElement.target = '_blank';
// hiddenElement.download = 'safetwitch_prefs.json';
// hiddenElement.click();
// },
// async handleImport(event: any) {
// const file = await event.target.files[0].text()
// const parsed = JSON.parse(file)
// if (parsed.audioOnly == undefined) {
// return
// }
// this.settings = file
// this.save()
// },
2023-08-18 13:39:26 -04:00
}
}
2023-08-16 13:04:24 -04:00
</script>
<template>
2023-08-18 13:39:26 -04:00
<div class="mx-auto w-[35rem] p-5 py-3 bg-ctp-crust rounded-md text-white">
2023-08-19 20:37:11 -04:00
<h1 class="font-bold text-3xl">{{ $t("nav.settings") }}</h1>
2023-08-18 13:39:26 -04:00
<hr class="my-2" />
<ul class="w-full space-y-1">
<li v-for="setting in settings" :key="setting.type">
<div v-if="setting.type == 'checkbox'" class="justify-between items-center flex">
2023-08-19 20:37:11 -04:00
<label :for="setting.name">{{ $t(`settings.${setting.name}`) }}</label>
2023-08-18 13:39:26 -04:00
<input :name="setting.name" type="checkbox" v-model="setting.selected" />
</div>
2023-08-16 13:04:24 -04:00
2023-08-18 13:39:26 -04:00
<div v-else-if="setting.type == 'option'" class="justify-between items-center flex">
2023-08-19 20:37:11 -04:00
<label :for="setting.name">{{ $t(`settings.${setting.name}`) }}</label>
2023-08-18 13:39:26 -04:00
<select
:name="setting.name"
type="checkbox"
v-model="setting.selected"
class="text-black rounded-md h-8 p-0 pr-8 pl-2"
>
<option v-for="option of setting.options" :key="option" :value="option">
{{ option }}
</option>
</select>
</div>
</li>
</ul>
2023-08-16 13:04:24 -04:00
2023-08-18 13:39:26 -04:00
<div class="space-x-2 mt-3">
2023-08-19 20:37:11 -04:00
<button @click="save" class="bg-ctp-surface0 p-4 py-2 rounded-md">{{ $t('settings.saveButton') }}</button>
2023-08-18 13:39:26 -04:00
<!-- <button @click="download" class="bg-ctp-surface0 p-4 py-2 rounded-md">Export</button>
2023-08-16 13:04:24 -04:00
<input type="file" @change="handleImport" name="fileinput" ref="fileinput"
class="bg-ctp-surface0 p-4 py-2 rounded-md"> -->
2023-08-18 13:39:26 -04:00
</div>
</div>
</template>