MOBILE-3320 lang: Fix plugin strings not loaded if child lang
Before this change, the last language used was the parent one. This means the Translate library searched the strings in the parent language instead of the child one.main
parent
997d6185fd
commit
1cd937961f
|
@ -19,7 +19,7 @@ import { LangChangeEvent } from '@ngx-translate/core';
|
||||||
import { CoreAppProvider } from '@services/app';
|
import { CoreAppProvider } from '@services/app';
|
||||||
import { CoreConfig } from '@services/config';
|
import { CoreConfig } from '@services/config';
|
||||||
import { CoreSubscriptions } from '@singletons/subscriptions';
|
import { CoreSubscriptions } from '@singletons/subscriptions';
|
||||||
import { makeSingleton, Translate, Platform } from '@singletons';
|
import { makeSingleton, Translate, Platform, Http } from '@singletons';
|
||||||
|
|
||||||
import * as moment from 'moment';
|
import * as moment from 'moment';
|
||||||
import { CoreSite } from '../classes/site';
|
import { CoreSite } from '../classes/site';
|
||||||
|
@ -142,24 +142,24 @@ export class CoreLangProvider {
|
||||||
|
|
||||||
// Change the language, resolving the promise when we receive the first value.
|
// Change the language, resolving the promise when we receive the first value.
|
||||||
promises.push(new Promise((resolve, reject) => {
|
promises.push(new Promise((resolve, reject) => {
|
||||||
CoreSubscriptions.once(Translate.use(language), data => {
|
CoreSubscriptions.once(Translate.use(language), async data => {
|
||||||
// It's a language override, load the original one first.
|
// Check if it has a parent language.
|
||||||
const fallbackLang = this.getParentLanguage(language);
|
const fallbackLang = this.getParentLanguage(language);
|
||||||
|
|
||||||
if (fallbackLang) {
|
if (fallbackLang) {
|
||||||
CoreSubscriptions.once(
|
try {
|
||||||
Translate.use(fallbackLang),
|
// Merge parent translations with the child ones.
|
||||||
fallbackData => {
|
const parentTranslations = Translate.translations[fallbackLang] ?? await this.readLangFile(fallbackLang);
|
||||||
data = Object.assign(fallbackData, data);
|
|
||||||
|
const mergedData = Object.assign(parentTranslations, data);
|
||||||
|
|
||||||
|
Object.assign(data, mergedData);
|
||||||
|
} catch {
|
||||||
|
// Ignore errors.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
resolve(data);
|
resolve(data);
|
||||||
},
|
|
||||||
// Resolve with the original language.
|
|
||||||
() => resolve(data),
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
resolve(data);
|
|
||||||
}
|
|
||||||
}, reject);
|
}, reject);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
@ -474,6 +474,20 @@ export class CoreLangProvider {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Read a language file.
|
||||||
|
*
|
||||||
|
* @param lang Language code.
|
||||||
|
* @return Promise resolved with the file contents.
|
||||||
|
*/
|
||||||
|
async readLangFile(lang: string): Promise<Record<string, string>> {
|
||||||
|
const observable = Http.get(`assets/lang/${lang}.json`, {
|
||||||
|
responseType: 'json',
|
||||||
|
});
|
||||||
|
|
||||||
|
return <Record<string, string>> await observable.toPromise();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unload custom or site plugin strings, removing them from the translations table.
|
* Unload custom or site plugin strings, removing them from the translations table.
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue