mirror of
https://github.com/romancm/gamebrary
synced 2025-01-01 22:08:44 +00:00
86 lines
2 KiB
Vue
86 lines
2 KiB
Vue
<template lang="html">
|
|
<b-dropdown-item v-b-modal:language>
|
|
<b-icon-chat-left-text class="mr-1" />
|
|
{{ $t('settings.language') }}
|
|
|
|
<b-modal
|
|
id="language"
|
|
title="Language"
|
|
hide-footer
|
|
@show="show"
|
|
>
|
|
<b-form-select v-model="language" class="mb-2">
|
|
<b-form-select-option
|
|
v-for="{ flag, code } in languages"
|
|
:key="code"
|
|
:value="code"
|
|
>
|
|
{{ flag }} {{ $t(`settings.languages.${code}`) }}
|
|
</b-form-select-option>
|
|
</b-form-select>
|
|
|
|
<b-button
|
|
:disabled="saving"
|
|
@click="saveSettings"
|
|
>
|
|
<b-spinner small v-if="saving" />
|
|
<span v-else>Save and reload browser</span>
|
|
</b-button>
|
|
</b-modal>
|
|
</b-dropdown-item>
|
|
</template>
|
|
|
|
<script>
|
|
import { mapState } from 'vuex';
|
|
|
|
export default {
|
|
data() {
|
|
return {
|
|
saving: false,
|
|
languages: [
|
|
{ flag: '🇺🇸', code: 'en' },
|
|
{ flag: '🇪🇸', code: 'es' },
|
|
{ flag: '🇵🇱', code: 'pl' },
|
|
{ flag: '🇩🇪', code: 'de' },
|
|
{ flag: '🇦🇪', code: 'ar' },
|
|
{ flag: '🇫🇷', code: 'fr' },
|
|
{ flag: '🇯🇵', code: 'ja' },
|
|
{ flag: '🇮🇹', code: 'it' },
|
|
{ flag: '🇨🇿', code: 'cs' },
|
|
],
|
|
language: null,
|
|
};
|
|
},
|
|
|
|
computed: {
|
|
...mapState(['settings']),
|
|
},
|
|
|
|
methods: {
|
|
show() {
|
|
const { settings } = this;
|
|
|
|
this.language = settings.language || 'en';
|
|
},
|
|
|
|
saveSettings() {
|
|
const { language, settings } = this;
|
|
|
|
const payload = {
|
|
...settings,
|
|
language,
|
|
};
|
|
|
|
this.$store.dispatch('SAVE_SETTINGS', payload)
|
|
.then(() => {
|
|
this.$bvToast.toast('Settings saved', { title: 'Success', variant: 'success' });
|
|
location.reload();
|
|
})
|
|
.catch(() => {
|
|
this.$bvToast.toast('There was an error saving your settings', { title: 'Error', variant: 'danger' });
|
|
this.saving = false;
|
|
});
|
|
},
|
|
},
|
|
};
|
|
</script>
|