0
Fork 0
mirror of https://codeberg.org/SafeTwitch/safetwitch.git synced 2025-01-08 13:50:04 -05:00

Move languages to settings menu

This commit is contained in:
dragongoose 2023-08-19 20:37:11 -04:00
parent cabdc3321c
commit a062eacb30
No known key found for this signature in database
GPG key ID: 01397EEC371CDAA5
3 changed files with 38 additions and 15 deletions

View file

@ -16,6 +16,12 @@ export default {
toggle() { toggle() {
this.open = !this.open this.open = !this.open
} }
},
mounted() {
const savedLocale = localStorage.getItem('language')
if(savedLocale) {
this.$i18n.locale = savedLocale
}
} }
} }
</script> </script>
@ -29,7 +35,6 @@ export default {
</div> </div>
<search-bar class="mt-4 mr-4 hidden sm:inline-block sm:mt-0"></search-bar> <search-bar class="mt-4 mr-4 hidden sm:inline-block sm:mt-0"></search-bar>
<div class="text-white hidden sm:block"> <div class="text-white hidden sm:block">
<a <a
href="https://codeberg.org/dragongoose/safetwitch" href="https://codeberg.org/dragongoose/safetwitch"
@ -39,7 +44,7 @@ export default {
<router-link to="/privacy" class="mt-4 mr-4 sm:inline-block sm:mt-0">{{ <router-link to="/privacy" class="mt-4 mr-4 sm:inline-block sm:mt-0">{{
$t('nav.privacy') $t('nav.privacy')
}}</router-link> }}</router-link>
<language-switcher class="mt-4 sm:inline-block sm:mt-0"></language-switcher> <router-link to="/settings">{{ $t("nav.settings") }}</router-link>
</div> </div>
<div class="block sm:hidden"> <div class="block sm:hidden">
@ -57,7 +62,7 @@ export default {
<ul class="inline-flex space-x-3 md:space-x-6 font-medium"> <ul class="inline-flex space-x-3 md:space-x-6 font-medium">
<a href="https://codeberg.org/dragongoose/safetwitch">{{ $t('nav.code') }}</a> <a href="https://codeberg.org/dragongoose/safetwitch">{{ $t('nav.code') }}</a>
<router-link to="/privacy">{{ $t('nav.privacy') }}</router-link> <router-link to="/privacy">{{ $t('nav.privacy') }}</router-link>
<language-switcher></language-switcher> <router-link to="/settings">{{ $t("nav.settings") }}</router-link>
</ul> </ul>
</div> </div>
</div> </div>

View file

@ -1,19 +1,35 @@
export const setLanguage = (selectedLanguage: string, i18n: any) => {
// Locales and languages in arrays to match them
const locales = ['en-US', 'es-ES', 'nl-NL', 'pt-PT', 'fa-IR', 'he-IL', 'ru-RU', 'ko-KR']
const languages = ['English', 'Español', 'Nederlands', 'Português', 'فارسی', 'עִבְרִית', 'Русский', '한국어']
const locale = locales[languages.indexOf(selectedLanguage)]
localStorage.setItem("language", locale)
i18n.locale = locale
}
export function getDefaultSettings() { export function getDefaultSettings() {
return { return {
version: import.meta.env.SAFETWITCH_TAG, version: import.meta.env.SAFETWITCH_TAG,
audioOnly: { // audioOnly: {
name: 'Audio Only', // name: 'Audio Only',
selected: false, // selected: false,
type: 'checkbox' // type: 'checkbox'
}, // },
defaultQuality: { defaultQuality: {
name: 'Default Quality', name: 'defaultQuality',
options: ['160p', '360p', '480p', '720p', '1080p'], options: ['160p', '360p', '480p', '720p', '1080p'],
selected: '480p', selected: '480p',
type: 'option' type: 'option'
}, },
language: {
name: 'language',
options: ['English', 'Español', 'Nederlands', 'Português', 'فارسی', 'עִבְרִית', 'Русский', '한국어'],
selected: 'English',
type: 'option'
},
chatVisible: { chatVisible: {
name: 'Hide Chat', name: 'chatVisible',
selected: false, selected: false,
type: 'checkbox' type: 'checkbox'
} }

View file

@ -1,5 +1,5 @@
<script lang="ts"> <script lang="ts">
import { getDefaultSettings, syncUserSettings } from '@/settingsManager' import { getDefaultSettings, syncUserSettings, setLanguage } from '@/settingsManager'
export default { export default {
setup() { setup() {
@ -21,6 +21,8 @@ export default {
save() { save() {
const settings = JSON.stringify(this.settings) const settings = JSON.stringify(this.settings)
localStorage.setItem('settings', settings) localStorage.setItem('settings', settings)
setLanguage(this.settings.language.selected, this.$i18n)
window.location.reload()
} }
// download() { // download() {
// var hiddenElement = document.createElement('a'); // var hiddenElement = document.createElement('a');
@ -47,17 +49,17 @@ export default {
<template> <template>
<div class="mx-auto w-[35rem] p-5 py-3 bg-ctp-crust rounded-md text-white"> <div class="mx-auto w-[35rem] p-5 py-3 bg-ctp-crust rounded-md text-white">
<h1 class="font-bold text-3xl">Settings</h1> <h1 class="font-bold text-3xl">{{ $t("nav.settings") }}</h1>
<hr class="my-2" /> <hr class="my-2" />
<ul class="w-full space-y-1"> <ul class="w-full space-y-1">
<li v-for="setting in settings" :key="setting.type"> <li v-for="setting in settings" :key="setting.type">
<div v-if="setting.type == 'checkbox'" class="justify-between items-center flex"> <div v-if="setting.type == 'checkbox'" class="justify-between items-center flex">
<label :for="setting.name">{{ setting.name }}</label> <label :for="setting.name">{{ $t(`settings.${setting.name}`) }}</label>
<input :name="setting.name" type="checkbox" v-model="setting.selected" /> <input :name="setting.name" type="checkbox" v-model="setting.selected" />
</div> </div>
<div v-else-if="setting.type == 'option'" class="justify-between items-center flex"> <div v-else-if="setting.type == 'option'" class="justify-between items-center flex">
<label :for="setting.name">{{ setting.name }}</label> <label :for="setting.name">{{ $t(`settings.${setting.name}`) }}</label>
<select <select
:name="setting.name" :name="setting.name"
type="checkbox" type="checkbox"
@ -73,7 +75,7 @@ export default {
</ul> </ul>
<div class="space-x-2 mt-3"> <div class="space-x-2 mt-3">
<button @click="save" class="bg-ctp-surface0 p-4 py-2 rounded-md">Save</button> <button @click="save" class="bg-ctp-surface0 p-4 py-2 rounded-md">{{ $t('settings.saveButton') }}</button>
<!-- <button @click="download" class="bg-ctp-surface0 p-4 py-2 rounded-md">Export</button> <!-- <button @click="download" class="bg-ctp-surface0 p-4 py-2 rounded-md">Export</button>
<input type="file" @change="handleImport" name="fileinput" ref="fileinput" <input type="file" @change="handleImport" name="fileinput" ref="fileinput"
class="bg-ctp-surface0 p-4 py-2 rounded-md"> --> class="bg-ctp-surface0 p-4 py-2 rounded-md"> -->