Whalebird-desktop-client-ma.../src/renderer/components/Preferences/Language.vue

92 lines
2.1 KiB
Vue
Raw Normal View History

<template>
<div id="language">
<h2>{{ $t('preferences.language.title') }}</h2>
2018-12-12 01:19:08 +01:00
<el-form class="display-language section" label-position="top" size="small">
<el-form-item for="language" :label="$t('preferences.language.language_description')">
<el-select id="language" v-model="displayLanguage" placeholder="style">
<el-option
v-for="lang in languages"
:key="lang.key"
:label="lang.name"
:value="lang.key">
</el-option>
</el-select>
<p class="notice">{{ $t('preferences.language.notice') }}</p>
</el-form-item>
</el-form>
</div>
</template>
<script>
import Language from '~/src/constants/language'
export default {
name: 'language',
data () {
return {
languages: [
2018-08-16 13:58:17 +02:00
Language.de,
Language.en,
2018-08-14 23:07:08 +02:00
Language.fr,
2018-08-20 07:28:37 +02:00
Language.ja,
2018-08-20 14:21:46 +02:00
Language.ko,
2019-05-07 22:38:46 +02:00
Language.pl,
2019-08-11 11:20:56 +02:00
Language.it,
Language.zh_cn
]
}
},
computed: {
displayLanguage: {
get () {
return this.$store.state.Preferences.Language.language.language
},
set (value) {
this.$store.dispatch('Preferences/Language/changeLanguage', value)
.then(() => {
this.confirm()
})
}
}
},
created () {
this.$store.dispatch('Preferences/Language/loadLanguage')
},
methods: {
confirm () {
this.$confirm(
this.$t('preferences.language.confirm.message'),
this.$t('preferences.language.confirm.title'),
{
confirmButtonText: this.$t('preferences.language.confirm.ok'),
cancelButtonText: this.$t('preferences.language.confirm.cancel'),
type: 'warning'
}
)
.then(() => {
this.$store.dispatch('Preferences/Language/relaunch')
})
.cancel(() => {
})
}
}
}
</script>
<style lang="scss" scoped>
#language {
2018-12-12 01:19:08 +01:00
.section /deep/ {
margin-bottom: 40px;
.el-form-item__label {
color: var(--theme-primary-color);
}
}
.notice {
color: #c0c4cc;
font-size: 12px;
}
}
</style>