Fix admin languages selection
Closes #515 Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
fba9ff4a62
commit
8cbc1e016d
@ -71,7 +71,7 @@
|
|||||||
{{ $t("Main languages you/your moderators speak") }}
|
{{ $t("Main languages you/your moderators speak") }}
|
||||||
</small>
|
</small>
|
||||||
<b-taginput
|
<b-taginput
|
||||||
v-model="adminSettings.instanceLanguages"
|
v-model="instanceLanguages"
|
||||||
:data="filteredLanguages"
|
:data="filteredLanguages"
|
||||||
autocomplete
|
autocomplete
|
||||||
:open-on-focus="true"
|
:open-on-focus="true"
|
||||||
@ -361,24 +361,23 @@ export default class Settings extends Vue {
|
|||||||
|
|
||||||
RouteName = RouteName;
|
RouteName = RouteName;
|
||||||
|
|
||||||
@Watch("languages")
|
get instanceLanguages(): string[] {
|
||||||
setCorrectLanguagesNames(): void {
|
const languageCodes = this.adminSettings.instanceLanguages || [];
|
||||||
if (this.languages && this.adminSettings) {
|
return languageCodes
|
||||||
this.adminSettings.instanceLanguages = this.adminSettings.instanceLanguages
|
|
||||||
.map((code) => this.languageForCode(code))
|
.map((code) => this.languageForCode(code))
|
||||||
.filter((language) => language) as string[];
|
.filter((language) => language) as string[];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set instanceLanguages(instanceLanguages: string[]) {
|
||||||
|
this.adminSettings.instanceLanguages = instanceLanguages
|
||||||
|
.map((language) => {
|
||||||
|
return this.codeForLanguage(language);
|
||||||
|
})
|
||||||
|
.filter((code) => code !== undefined) as string[];
|
||||||
}
|
}
|
||||||
|
|
||||||
async updateSettings(): Promise<void> {
|
async updateSettings(): Promise<void> {
|
||||||
const variables = { ...this.adminSettings };
|
const variables = { ...this.adminSettings };
|
||||||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
||||||
// @ts-ignore
|
|
||||||
variables.instanceLanguages = variables.instanceLanguages.map(
|
|
||||||
(language) => {
|
|
||||||
return this.codeForLanguage(language);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
try {
|
try {
|
||||||
await this.$apollo.mutate({
|
await this.$apollo.mutate({
|
||||||
mutation: SAVE_ADMIN_SETTINGS,
|
mutation: SAVE_ADMIN_SETTINGS,
|
||||||
@ -408,7 +407,7 @@ export default class Settings extends Vue {
|
|||||||
: [];
|
: [];
|
||||||
}
|
}
|
||||||
|
|
||||||
codeForLanguage(language: string): string | undefined {
|
private codeForLanguage(language: string): string | undefined {
|
||||||
if (this.languages) {
|
if (this.languages) {
|
||||||
const lang = this.languages.find(({ name }) => name === language);
|
const lang = this.languages.find(({ name }) => name === language);
|
||||||
if (lang) return lang.code;
|
if (lang) return lang.code;
|
||||||
@ -416,7 +415,7 @@ export default class Settings extends Vue {
|
|||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
languageForCode(codeGiven: string): string | undefined {
|
private languageForCode(codeGiven: string): string | undefined {
|
||||||
if (this.languages) {
|
if (this.languages) {
|
||||||
const lang = this.languages.find(({ code }) => code === codeGiven);
|
const lang = this.languages.find(({ code }) => code === codeGiven);
|
||||||
if (lang) return lang.name;
|
if (lang) return lang.name;
|
||||||
|
Loading…
Reference in New Issue
Block a user