@tilde-nlp/ngx-common 4.0.20 → 4.0.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -9,19 +9,31 @@ export class LanguageTranslatePipe {
|
|
|
9
9
|
constructor(translate) {
|
|
10
10
|
this.translate = translate;
|
|
11
11
|
this.languagesLocalizationKey = 'LANGUAGES';
|
|
12
|
+
this.translationCache = new Map();
|
|
13
|
+
this.translate.onLangChange.subscribe(() => {
|
|
14
|
+
this.translationCache.clear();
|
|
15
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
16
|
+
});
|
|
17
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
12
18
|
}
|
|
13
19
|
transform(fullLangCode, hideRegion = false) {
|
|
14
20
|
if (!fullLangCode) {
|
|
15
21
|
return '';
|
|
16
22
|
}
|
|
17
|
-
|
|
23
|
+
if (this.lastUiLanguage !== this.translate.currentLang) {
|
|
24
|
+
this.translationCache.clear();
|
|
25
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
26
|
+
}
|
|
27
|
+
const cacheKey = `${fullLangCode}:${hideRegion}`;
|
|
28
|
+
if (this.translationCache.has(cacheKey)) {
|
|
29
|
+
return this.translationCache.get(cacheKey);
|
|
30
|
+
}
|
|
31
|
+
const langCodeWithoutRegion = this.getLanguageFromLanguageCode(fullLangCode);
|
|
18
32
|
const isCodeAndRegionSame = this.isLanguageCodeSameAsRegion(fullLangCode);
|
|
19
33
|
const langCodeForTranslation = isCodeAndRegionSame ? langCodeWithoutRegion : fullLangCode;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
const [code, region, extra] = fullLangCode.split('-');
|
|
24
|
-
return code === region?.toLowerCase() && !extra;
|
|
34
|
+
const translation = this.getTranslation(langCodeForTranslation, hideRegion);
|
|
35
|
+
this.translationCache.set(cacheKey, translation);
|
|
36
|
+
return translation;
|
|
25
37
|
}
|
|
26
38
|
getTranslation(langCode, hideRegion) {
|
|
27
39
|
const languageTranslations = this.translate.instant(this.languagesLocalizationKey);
|
|
@@ -39,7 +51,32 @@ export class LanguageTranslatePipe {
|
|
|
39
51
|
}
|
|
40
52
|
getLanguageTranslationFromLanguageCode(currentLang, code) {
|
|
41
53
|
const languageNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'language' });
|
|
42
|
-
|
|
54
|
+
const regionNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'region' });
|
|
55
|
+
let translation;
|
|
56
|
+
try {
|
|
57
|
+
const language = this.getLanguageFromLanguageCode(code);
|
|
58
|
+
const region = this.getRegionFromLanguageCode(code);
|
|
59
|
+
const languagetranslation = languageNamesInCurrentLang.of(language);
|
|
60
|
+
const regionTranslation = regionNamesInCurrentLang.of(region);
|
|
61
|
+
translation = `${languagetranslation} (${regionTranslation})`;
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
translation = languageNamesInCurrentLang.of(code);
|
|
65
|
+
}
|
|
66
|
+
return this.capitalizeFirstLetter(translation);
|
|
67
|
+
}
|
|
68
|
+
isLanguageCodeSameAsRegion(fullLangCode) {
|
|
69
|
+
const [code, region, extra] = fullLangCode.split('-');
|
|
70
|
+
return code === region?.toLowerCase() && !extra;
|
|
71
|
+
}
|
|
72
|
+
getRegionFromLanguageCode(fullLangCode) {
|
|
73
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
74
|
+
const [_code, region, extra] = fullLangCode.split('-');
|
|
75
|
+
const regionCode = extra ? `${region}-${extra}` : `${region}`;
|
|
76
|
+
return regionCode.toUpperCase();
|
|
77
|
+
}
|
|
78
|
+
getLanguageFromLanguageCode(fullLangCode) {
|
|
79
|
+
return fullLangCode.split('-')[0].toLowerCase();
|
|
43
80
|
}
|
|
44
81
|
capitalizeFirstLetter(text) {
|
|
45
82
|
return text.charAt(0).toUpperCase() + text.slice(1);
|
|
@@ -54,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
54
91
|
pure: false,
|
|
55
92
|
}]
|
|
56
93
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }]; } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtdHJhbnNsYXRlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvcGlwZXMvbGFuZ3VhZ2UtdHJhbnNsYXRlL2xhbmd1YWdlLXRyYW5zbGF0ZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7QUFPcEQ7OztFQUdFO0FBQ0YsTUFBTSxPQUFPLHFCQUFxQjtJQUdoQyxZQUE2QixTQUEyQjtRQUEzQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQUZ2Qyw2QkFBd0IsR0FBRyxXQUFXLENBQUM7SUFFRyxDQUFDO0lBRTVELFNBQVMsQ0FBQyxZQUFvQixFQUFFLFVBQVUsR0FBRyxLQUFLO1FBQ2hELElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDakIsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUVELE1BQU0scUJBQXFCLEdBQUcsWUFBWSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6RCxNQUFNLG1CQUFtQixHQUFHLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUMxRSxNQUFNLHNCQUFzQixHQUFHLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDO1FBRTFGLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxzQkFBc0IsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRU8sMEJBQTBCLENBQUMsWUFBb0I7UUFDckQsTUFBTSxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLEdBQUcsWUFBWSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN0RCxPQUFPLElBQUksS0FBSyxNQUFNLEVBQUUsV0FBVyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDbEQsQ0FBQztJQUVPLGNBQWMsQ0FBQyxRQUFnQixFQUFFLFVBQW9CO1FBQzNELE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDbkYsSUFBSSxXQUFXO1FBQ2I7OztVQUdFO1FBQ0Ysb0JBQW9CLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7WUFDOUQsSUFBSSxDQUFDLHNDQUFzQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXBGLElBQUksVUFBVSxFQUFFO1lBQ2QsV0FBVyxHQUFHLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDaEQ7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRU8sc0NBQXNDLENBQUMsV0FBbUIsRUFBRSxJQUFZO1FBQzlFLE1BQU0sMEJBQTBCLEdBQUcsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztRQUM5RixPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQywwQkFBMEIsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFXLENBQUMsQ0FBQztJQUNuRixDQUFDO0lBRU8scUJBQXFCLENBQUMsSUFBWTtRQUN4QyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDOytHQTlDVSxxQkFBcUI7NkdBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFSakMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsbUJBQW1CO29CQUN6QixJQUFJLEVBQUUsS0FBSztpQkFDWiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5cclxuQFBpcGUoe1xyXG4gIG5hbWU6ICdsYW5ndWFnZVRyYW5zbGF0ZScsXHJcbiAgcHVyZTogZmFsc2UsXHJcbn0pXHJcbi8qKlxyXG4gIFRoaXMgcGlwZSBzZWFyY2hlcyBmb3IgYSBsYW5ndWFnZSBjb2RlIHRyYW5zbGF0aW9uIHdpdGhpbiBvdXIgSlNPTiBmaWxlcy4gXHJcbiAgSWYgdGhlIHRyYW5zbGF0aW9uIGZvciBhIGdpdmVuIGxhbmd1YWdlIGNvZGUgaXMgbm90IGZvdW5kIHRoZXJlLCBpdCByZXRyaWV2ZXMgaXQgZnJvbSB0aGUgYnJvd3NlcidzIEludGwgb2JqZWN0LlxyXG4qL1xyXG5leHBvcnQgY2xhc3MgTGFuZ3VhZ2VUcmFuc2xhdGVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBsYW5ndWFnZXNMb2NhbGl6YXRpb25LZXkgPSAnTEFOR1VBR0VTJztcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSB0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XHJcblxyXG4gIHRyYW5zZm9ybShmdWxsTGFuZ0NvZGU6IHN0cmluZywgaGlkZVJlZ2lvbiA9IGZhbHNlKTogc3RyaW5nIHtcclxuICAgIGlmICghZnVsbExhbmdDb2RlKSB7XHJcbiAgICAgIHJldHVybiAnJztcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBsYW5nQ29kZVdpdGhvdXRSZWdpb24gPSBmdWxsTGFuZ0NvZGUuc3BsaXQoJy0nKVswXTtcclxuICAgIGNvbnN0IGlzQ29kZUFuZFJlZ2lvblNhbWUgPSB0aGlzLmlzTGFuZ3VhZ2VDb2RlU2FtZUFzUmVnaW9uKGZ1bGxMYW5nQ29kZSk7XHJcbiAgICBjb25zdCBsYW5nQ29kZUZvclRyYW5zbGF0aW9uID0gaXNDb2RlQW5kUmVnaW9uU2FtZSA/IGxhbmdDb2RlV2l0aG91dFJlZ2lvbiA6IGZ1bGxMYW5nQ29kZTtcclxuXHJcbiAgICByZXR1cm4gdGhpcy5nZXRUcmFuc2xhdGlvbihsYW5nQ29kZUZvclRyYW5zbGF0aW9uLCBoaWRlUmVnaW9uKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgaXNMYW5ndWFnZUNvZGVTYW1lQXNSZWdpb24oZnVsbExhbmdDb2RlOiBzdHJpbmcpOiBib29sZWFuIHtcclxuICAgIGNvbnN0IFtjb2RlLCByZWdpb24sIGV4dHJhXSA9IGZ1bGxMYW5nQ29kZS5zcGxpdCgnLScpO1xyXG4gICAgcmV0dXJuIGNvZGUgPT09IHJlZ2lvbj8udG9Mb3dlckNhc2UoKSAmJiAhZXh0cmE7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGdldFRyYW5zbGF0aW9uKGxhbmdDb2RlOiBzdHJpbmcsIGhpZGVSZWdpb24/OiBib29sZWFuKTogc3RyaW5nIHtcclxuICAgIGNvbnN0IGxhbmd1YWdlVHJhbnNsYXRpb25zID0gdGhpcy50cmFuc2xhdGUuaW5zdGFudCh0aGlzLmxhbmd1YWdlc0xvY2FsaXphdGlvbktleSk7XHJcbiAgICBsZXQgdHJhbnNsYXRpb24gPVxyXG4gICAgICAvKipcclxuICAgICAgICAgIGUuZy4gSW4gY2FzZSB3ZSBuZWVkIHRvIGRpc3BsYXkgXCJlbi1HQlwiIGxhbmd1YWdlIGNvZGUgYXMgXCJCcml0aXNoXCIgd2UgY2FuIGRvIHRoaXNcclxuICAgICAgICBieSBhZGRpbmcgXCJFTl9HQlwiOiBcIkJyaXRpc2hcIiBpbiBsb2NhbGl6YXRpb24gZmlsZXMgdW5kZXIgXCJMQU5HVUFHRVNcIiBrZXkuIFxyXG4gICAgICAqL1xyXG4gICAgICBsYW5ndWFnZVRyYW5zbGF0aW9uc1tsYW5nQ29kZS50b1VwcGVyQ2FzZSgpLnJlcGxhY2UoJy0nLCAnXycpXSA/P1xyXG4gICAgICB0aGlzLmdldExhbmd1YWdlVHJhbnNsYXRpb25Gcm9tTGFuZ3VhZ2VDb2RlKHRoaXMudHJhbnNsYXRlLmN1cnJlbnRMYW5nLCBsYW5nQ29kZSk7XHJcblxyXG4gICAgaWYgKGhpZGVSZWdpb24pIHtcclxuICAgICAgdHJhbnNsYXRpb24gPSB0cmFuc2xhdGlvbi5zcGxpdCgnKCcpWzBdLnRyaW0oKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdHJhbnNsYXRpb247XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGdldExhbmd1YWdlVHJhbnNsYXRpb25Gcm9tTGFuZ3VhZ2VDb2RlKGN1cnJlbnRMYW5nOiBzdHJpbmcsIGNvZGU6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICBjb25zdCBsYW5ndWFnZU5hbWVzSW5DdXJyZW50TGFuZyA9IG5ldyBJbnRsLkRpc3BsYXlOYW1lcyhbY3VycmVudExhbmddLCB7IHR5cGU6ICdsYW5ndWFnZScgfSk7XHJcbiAgICByZXR1cm4gdGhpcy5jYXBpdGFsaXplRmlyc3RMZXR0ZXIobGFuZ3VhZ2VOYW1lc0luQ3VycmVudExhbmcub2YoY29kZSkgYXMgc3RyaW5nKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgY2FwaXRhbGl6ZUZpcnN0TGV0dGVyKHRleHQ6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGV4dC5jaGFyQXQoMCkudG9VcHBlckNhc2UoKSArIHRleHQuc2xpY2UoMSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-translate.pipe.js","sourceRoot":"","sources":["../../../../../../projects/ngx-common/src/lib/pipes/language-translate/language-translate.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Pipe({\r\n  name: 'languageTranslate',\r\n  pure: false,\r\n})\r\n/**\r\n  This pipe searches for a language code translation within our JSON files. \r\n  If the translation for a given language code is not found there, it retrieves it from the browser's Intl object.\r\n*/\r\nexport class LanguageTranslatePipe implements PipeTransform {\r\n  private readonly languagesLocalizationKey = 'LANGUAGES';\r\n\r\n  private lastUiLanguage: string;\r\n\r\n  private translationCache = new Map<string, string>();\r\n\r\n  constructor(private readonly translate: TranslateService) {\r\n    this.translate.onLangChange.subscribe(() => {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    });\r\n    this.lastUiLanguage = this.translate.currentLang;\r\n  }\r\n\r\n  transform(fullLangCode: string, hideRegion = false): string {\r\n    if (!fullLangCode) {\r\n      return '';\r\n    }\r\n\r\n    if (this.lastUiLanguage !== this.translate.currentLang) {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    }\r\n\r\n    const cacheKey = `${fullLangCode}:${hideRegion}`;\r\n\r\n    if (this.translationCache.has(cacheKey)) {\r\n      return this.translationCache.get(cacheKey)!;\r\n    }\r\n\r\n    const langCodeWithoutRegion = this.getLanguageFromLanguageCode(fullLangCode);\r\n    const isCodeAndRegionSame = this.isLanguageCodeSameAsRegion(fullLangCode);\r\n    const langCodeForTranslation = isCodeAndRegionSame ? langCodeWithoutRegion : fullLangCode;\r\n\r\n    const translation = this.getTranslation(langCodeForTranslation, hideRegion);\r\n\r\n    this.translationCache.set(cacheKey, translation);\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getTranslation(langCode: string, hideRegion?: boolean): string {\r\n    const languageTranslations = this.translate.instant(this.languagesLocalizationKey);\r\n    let translation =\r\n      /**\r\n          e.g. In case we need to display \"en-GB\" language code as \"British\" we can do this\r\n        by adding \"EN_GB\": \"British\" in localization files under \"LANGUAGES\" key. \r\n      */\r\n      languageTranslations[langCode.toUpperCase().replace('-', '_')] ??\r\n      this.getLanguageTranslationFromLanguageCode(this.translate.currentLang, langCode);\r\n\r\n    if (hideRegion) {\r\n      translation = translation.split('(')[0].trim();\r\n    }\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getLanguageTranslationFromLanguageCode(currentLang: string, code: string): string {\r\n    const languageNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'language' });\r\n    const regionNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'region' });\r\n\r\n    let translation: string;\r\n\r\n    try {\r\n      const language = this.getLanguageFromLanguageCode(code);\r\n      const region = this.getRegionFromLanguageCode(code);\r\n\r\n      const languagetranslation = languageNamesInCurrentLang.of(language);\r\n      const regionTranslation = regionNamesInCurrentLang.of(region);\r\n\r\n      translation = `${languagetranslation} (${regionTranslation})`;\r\n    } catch {\r\n      translation = languageNamesInCurrentLang.of(code) as string;\r\n    }\r\n\r\n    return this.capitalizeFirstLetter(translation);\r\n  }\r\n\r\n  private isLanguageCodeSameAsRegion(fullLangCode: string): boolean {\r\n    const [code, region, extra] = fullLangCode.split('-');\r\n    return code === region?.toLowerCase() && !extra;\r\n  }\r\n\r\n  private getRegionFromLanguageCode(fullLangCode: string): string {\r\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n    const [_code, region, extra] = fullLangCode.split('-');\r\n    const regionCode = extra ? `${region}-${extra}` : `${region}`;\r\n    return regionCode.toUpperCase();\r\n  }\r\n\r\n  private getLanguageFromLanguageCode(fullLangCode: string): string {\r\n    return fullLangCode.split('-')[0].toLowerCase();\r\n  }\r\n\r\n  private capitalizeFirstLetter(text: string): string {\r\n    return text.charAt(0).toUpperCase() + text.slice(1);\r\n  }\r\n}\r\n"]}
|
|
@@ -618,19 +618,31 @@ class LanguageTranslatePipe {
|
|
|
618
618
|
constructor(translate) {
|
|
619
619
|
this.translate = translate;
|
|
620
620
|
this.languagesLocalizationKey = 'LANGUAGES';
|
|
621
|
+
this.translationCache = new Map();
|
|
622
|
+
this.translate.onLangChange.subscribe(() => {
|
|
623
|
+
this.translationCache.clear();
|
|
624
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
625
|
+
});
|
|
626
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
621
627
|
}
|
|
622
628
|
transform(fullLangCode, hideRegion = false) {
|
|
623
629
|
if (!fullLangCode) {
|
|
624
630
|
return '';
|
|
625
631
|
}
|
|
626
|
-
|
|
632
|
+
if (this.lastUiLanguage !== this.translate.currentLang) {
|
|
633
|
+
this.translationCache.clear();
|
|
634
|
+
this.lastUiLanguage = this.translate.currentLang;
|
|
635
|
+
}
|
|
636
|
+
const cacheKey = `${fullLangCode}:${hideRegion}`;
|
|
637
|
+
if (this.translationCache.has(cacheKey)) {
|
|
638
|
+
return this.translationCache.get(cacheKey);
|
|
639
|
+
}
|
|
640
|
+
const langCodeWithoutRegion = this.getLanguageFromLanguageCode(fullLangCode);
|
|
627
641
|
const isCodeAndRegionSame = this.isLanguageCodeSameAsRegion(fullLangCode);
|
|
628
642
|
const langCodeForTranslation = isCodeAndRegionSame ? langCodeWithoutRegion : fullLangCode;
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
const [code, region, extra] = fullLangCode.split('-');
|
|
633
|
-
return code === region?.toLowerCase() && !extra;
|
|
643
|
+
const translation = this.getTranslation(langCodeForTranslation, hideRegion);
|
|
644
|
+
this.translationCache.set(cacheKey, translation);
|
|
645
|
+
return translation;
|
|
634
646
|
}
|
|
635
647
|
getTranslation(langCode, hideRegion) {
|
|
636
648
|
const languageTranslations = this.translate.instant(this.languagesLocalizationKey);
|
|
@@ -648,7 +660,32 @@ class LanguageTranslatePipe {
|
|
|
648
660
|
}
|
|
649
661
|
getLanguageTranslationFromLanguageCode(currentLang, code) {
|
|
650
662
|
const languageNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'language' });
|
|
651
|
-
|
|
663
|
+
const regionNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'region' });
|
|
664
|
+
let translation;
|
|
665
|
+
try {
|
|
666
|
+
const language = this.getLanguageFromLanguageCode(code);
|
|
667
|
+
const region = this.getRegionFromLanguageCode(code);
|
|
668
|
+
const languagetranslation = languageNamesInCurrentLang.of(language);
|
|
669
|
+
const regionTranslation = regionNamesInCurrentLang.of(region);
|
|
670
|
+
translation = `${languagetranslation} (${regionTranslation})`;
|
|
671
|
+
}
|
|
672
|
+
catch {
|
|
673
|
+
translation = languageNamesInCurrentLang.of(code);
|
|
674
|
+
}
|
|
675
|
+
return this.capitalizeFirstLetter(translation);
|
|
676
|
+
}
|
|
677
|
+
isLanguageCodeSameAsRegion(fullLangCode) {
|
|
678
|
+
const [code, region, extra] = fullLangCode.split('-');
|
|
679
|
+
return code === region?.toLowerCase() && !extra;
|
|
680
|
+
}
|
|
681
|
+
getRegionFromLanguageCode(fullLangCode) {
|
|
682
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
683
|
+
const [_code, region, extra] = fullLangCode.split('-');
|
|
684
|
+
const regionCode = extra ? `${region}-${extra}` : `${region}`;
|
|
685
|
+
return regionCode.toUpperCase();
|
|
686
|
+
}
|
|
687
|
+
getLanguageFromLanguageCode(fullLangCode) {
|
|
688
|
+
return fullLangCode.split('-')[0].toLowerCase();
|
|
652
689
|
}
|
|
653
690
|
capitalizeFirstLetter(text) {
|
|
654
691
|
return text.charAt(0).toUpperCase() + text.slice(1);
|