akkoma-fe/src/components/interface_language_switcher/interface_language_switcher.vue

70 lines
1.6 KiB
Vue
Raw Normal View History

<template>
<div>
<label for="interface-language-switcher">
{{ $t('settings.interfaceLanguage') }}
</label>
2019-07-05 07:17:44 +00:00
<label
for="interface-language-switcher"
class="select"
>
<select
id="interface-language-switcher"
v-model="language"
>
<option
v-for="(langCode, i) in languageCodes"
2019-07-06 21:54:17 +00:00
:key="langCode"
2019-07-05 07:17:44 +00:00
:value="langCode"
>
{{ languageNames[i] }}
</option>
</select>
2020-10-20 19:54:43 +00:00
<FAIcon class="select-down-icon" icon="chevron-down" />
</label>
</div>
</template>
<script>
2019-07-05 07:17:44 +00:00
import languagesObject from '../../i18n/messages'
import ISO6391 from 'iso-639-1'
import _ from 'lodash'
2020-10-20 18:03:46 +00:00
import { library } from '@fortawesome/fontawesome-svg-core'
import {
faChevronDown
} from '@fortawesome/free-solid-svg-icons'
library.add(
faChevronDown
)
2019-07-05 07:17:44 +00:00
export default {
computed: {
languageCodes () {
return languagesObject.languages
2019-07-05 07:17:44 +00:00
},
2019-07-05 07:17:44 +00:00
languageNames () {
return _.map(this.languageCodes, this.getLanguageName)
},
2019-07-05 07:17:44 +00:00
language: {
get: function () { return this.$store.getters.mergedConfig.interfaceLanguage },
2019-07-05 07:17:44 +00:00
set: function (val) {
this.$store.dispatch('setOption', { name: 'interfaceLanguage', value: val })
}
2019-07-05 07:17:44 +00:00
}
},
2019-05-29 05:31:03 +00:00
2019-07-05 07:17:44 +00:00
methods: {
getLanguageName (code) {
const specialLanguageNames = {
'ja': 'Japanese (日本語)',
'ja_easy': 'Japanese (やさしいにほんご)',
2019-07-05 07:17:44 +00:00
'zh': 'Chinese (简体中文)'
2019-05-29 05:31:03 +00:00
}
2019-07-05 07:17:44 +00:00
return specialLanguageNames[code] || ISO6391.getName(code)
}
}
2019-07-05 07:17:44 +00:00
}
</script>