2022-03-18 20:07:05 +01:00
|
|
|
import browser from 'webextension-polyfill';
|
2021-02-04 19:15:23 +01:00
|
|
|
import allLocales from '../../_locales/index.json';
|
2018-03-22 16:09:16 +01:00
|
|
|
|
2019-02-08 20:36:37 +01:00
|
|
|
// mapping some browsers return hyphen instead underscore in locale codes (e.g. zh_TW -> zh-tw)
|
2021-02-04 19:15:23 +01:00
|
|
|
const existingLocaleCodes = {};
|
2020-02-15 21:34:12 +01:00
|
|
|
allLocales.forEach((locale) => {
|
2019-02-08 20:36:37 +01:00
|
|
|
if (locale && locale.code) {
|
2020-11-03 00:41:28 +01:00
|
|
|
existingLocaleCodes[locale.code.toLowerCase().replace('_', '-')] =
|
2021-02-04 19:15:23 +01:00
|
|
|
locale.code;
|
2019-02-08 20:36:37 +01:00
|
|
|
}
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2018-03-22 16:09:16 +01:00
|
|
|
|
2018-04-16 19:08:04 +02:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*
|
2020-11-10 18:30:41 +01:00
|
|
|
* @returns {Promise<string>} Promises a locale code, either one from the user's preferred list that we have a translation for, or 'en'
|
2018-04-16 19:08:04 +02:00
|
|
|
*/
|
2020-11-03 00:41:28 +01:00
|
|
|
export default async function getFirstPreferredLangCode() {
|
2021-02-04 19:15:23 +01:00
|
|
|
let userPreferredLocaleCodes;
|
2018-06-14 19:09:45 +02:00
|
|
|
|
|
|
|
try {
|
2022-03-18 20:07:05 +01:00
|
|
|
userPreferredLocaleCodes = await browser.i18n.getAcceptLanguages();
|
2018-06-14 19:09:45 +02:00
|
|
|
} catch (e) {
|
|
|
|
// Brave currently throws when calling getAcceptLanguages, so this handles that.
|
2021-02-04 19:15:23 +01:00
|
|
|
userPreferredLocaleCodes = [];
|
2018-06-14 19:09:45 +02:00
|
|
|
}
|
|
|
|
|
2018-06-07 03:24: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) {
|
2021-02-04 19:15:23 +01:00
|
|
|
userPreferredLocaleCodes = [];
|
2018-06-07 03:10:05 +02:00
|
|
|
}
|
2018-06-07 03:35:41 +02:00
|
|
|
|
2021-10-19 21:32:13 +02:00
|
|
|
let firstPreferredLangCode = userPreferredLocaleCodes
|
2020-02-15 21:34:12 +01:00
|
|
|
.map((code) => code.toLowerCase().replace('_', '-'))
|
2021-10-19 21:32:13 +02:00
|
|
|
.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];
|
|
|
|
}
|
2019-02-08 20:36:37 +01:00
|
|
|
|
2021-02-04 19:15:23 +01:00
|
|
|
return existingLocaleCodes[firstPreferredLangCode] || 'en';
|
2018-03-22 16:09:16 +01:00
|
|
|
}
|