@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
- const langCodeWithoutRegion = fullLangCode.split('-')[0];
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
- return this.getTranslation(langCodeForTranslation, hideRegion);
21
- }
22
- isLanguageCodeSameAsRegion(fullLangCode) {
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
- return this.capitalizeFirstLetter(languageNamesInCurrentLang.of(code));
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
- const langCodeWithoutRegion = fullLangCode.split('-')[0];
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
- return this.getTranslation(langCodeForTranslation, hideRegion);
630
- }
631
- isLanguageCodeSameAsRegion(fullLangCode) {
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
- return this.capitalizeFirstLetter(languageNamesInCurrentLang.of(code));
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);