1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/app/scripts/lib/get-first-preferred-lang-code.js

61 lines
2.1 KiB
JavaScript
Raw Normal View History

import extension from 'extensionizer';
import promisify from 'pify';
import allLocales from '../../_locales/index.json';
2020-11-03 00:41:28 +01:00
const getPreferredLocales = extension.i18n
? promisify(extension.i18n.getAcceptLanguages, { errorFirst: false })
: async () => [];
// mapping some browsers return hyphen instead underscore in locale codes (e.g. zh_TW -> zh-tw)
const existingLocaleCodes = {};
2020-02-15 21:34:12 +01:00
allLocales.forEach((locale) => {
if (locale && locale.code) {
2020-11-03 00:41:28 +01:00
existingLocaleCodes[locale.code.toLowerCase().replace('_', '-')] =
locale.code;
}
});
/**
* Returns a preferred language code, based on settings within the user's browser. If we have no translations for the
* users preferred locales, 'en' is returned.
*
* @returns {Promise<string>} Promises a locale code, either one from the user's preferred list that we have a translation for, or 'en'
*
*/
2020-11-03 00:41:28 +01:00
export default async function getFirstPreferredLangCode() {
let userPreferredLocaleCodes;
2018-06-14 19:09:45 +02:00
try {
userPreferredLocaleCodes = await getPreferredLocales();
2018-06-14 19:09:45 +02:00
} catch (e) {
// Brave currently throws when calling getAcceptLanguages, so this handles that.
userPreferredLocaleCodes = [];
2018-06-14 19:09:45 +02:00
}
// safeguard for Brave Browser until they implement chrome.i18n.getAcceptLanguages
// https://github.com/MetaMask/metamask-extension/issues/4270
2018-07-03 00:49:33 +02:00
if (!userPreferredLocaleCodes) {
userPreferredLocaleCodes = [];
}
2018-06-07 03:35:41 +02:00
let firstPreferredLangCode = userPreferredLocaleCodes
2020-02-15 21:34:12 +01:00
.map((code) => code.toLowerCase().replace('_', '-'))
.find(
(code) =>
existingLocaleCodes[code] !== undefined ||
existingLocaleCodes[code.split('-')[0]] !== undefined,
);
// if we have matched against a code with a '-' present, meaning its a regional
// code for which we have a non-regioned locale, we need to set firstPreferredLangCode
// to the correct non-regional code.
if (
firstPreferredLangCode !== undefined &&
existingLocaleCodes[firstPreferredLangCode] === undefined
) {
firstPreferredLangCode = firstPreferredLangCode.split('-')[0];
}
return existingLocaleCodes[firstPreferredLangCode] || 'en';
}