UNPKG

@ledgerhq/live-common

Version:
54 lines 3.35 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.useLocalizedUrl = exports.getLocalizedUrl = exports.SALESFORCE_SUPPORT = exports.SHOP = exports.LEDGER = exports.BASE_LEDGER_SUPPORT = void 0; exports.BASE_LEDGER_SUPPORT = "https://support.ledger.com"; exports.LEDGER = "https://www.ledger.com"; exports.SHOP = "https://shop.ledger.com"; exports.SALESFORCE_SUPPORT = `${exports.BASE_LEDGER_SUPPORT}/article`; /** * Constructs a localized URL based on the provided base URL, language, default language, and optional suffix. * If the language is the default language, the language part is omitted from the URL. * * @param {string} baseUrl - The base URL (e.g., "https://www.ledger.com"). * @param {LanguageMap} langMap - A mapping of language codes to their respective language identifiers (e.g., { en: "en", fr: "fr", ... }). * @param {keyof LanguageMap} lang - The selected language code (e.g., "en", "fr"). * @param {string} DEFAULT_LANGUAGE - The default language configuration(e.g., "en"). * @param {string} [suffix=""] - An optional suffix to append to the URL (e.g., "article/123"). * * @returns {string} - The localized URL, including the language part (if applicable) and any suffix. */ const getLocalizedUrl = (baseUrl, langMap, lang, defaultLanguage, suffix = "") => { // Determine the language part based on the selected language. If the language is the default, // we don't include it in the URL. If the language isn't in the langMap, fallback to an empty string. const languagePart = lang === defaultLanguage ? "" : langMap[lang] || ""; // If a suffix is provided, prepend it with a "/" for proper URL formatting. const suffixPart = suffix ? `/${suffix}` : ""; // Return the final URL by concatenating the base URL, language part (if any), and the suffix (if any). return `${baseUrl}${languagePart && `/${languagePart}`}${suffixPart}`; }; exports.getLocalizedUrl = getLocalizedUrl; const useLocalizedUrl = (url, { languages, defaultLanguage, currentLanguage }) => { const LEDGER_LANG = { ...languages }; const SHOP_LANG = { ...languages }; const SALESFORCE_LANG = { ...languages, zh: "zh-cn", }; // Define the language patterns in the URL, using the helper function const languagePatterns = { [exports.LEDGER]: (0, exports.getLocalizedUrl)(exports.LEDGER, LEDGER_LANG, currentLanguage, defaultLanguage), [exports.SHOP]: (0, exports.getLocalizedUrl)(exports.SHOP, SHOP_LANG, currentLanguage, defaultLanguage), [exports.BASE_LEDGER_SUPPORT]: (0, exports.getLocalizedUrl)(exports.BASE_LEDGER_SUPPORT, SALESFORCE_LANG, currentLanguage, defaultLanguage), [exports.SALESFORCE_SUPPORT]: (0, exports.getLocalizedUrl)(exports.BASE_LEDGER_SUPPORT, SALESFORCE_LANG, currentLanguage, defaultLanguage, "article"), }; const matchingPattern = Object.keys(languagePatterns).find(pattern => url.startsWith(pattern)); // If no matching pattern, return the original URL if (!matchingPattern) { return url; } // Replace the matching part with the corresponding localized URL const transformedUrl = url.replace(matchingPattern, languagePatterns[matchingPattern]); return transformedUrl; }; exports.useLocalizedUrl = useLocalizedUrl; //# sourceMappingURL=useLocalizedUrl.js.map