mapcomplete/UI/i18n/Locale.ts

74 lines
3.3 KiB
TypeScript
Raw Normal View History

import {UIEventSource} from "../../Logic/UIEventSource"
import {LocalStorageSource} from "../../Logic/Web/LocalStorageSource"
import {Utils} from "../../Utils"
import {QueryParameters} from "../../Logic/Web/QueryParameters"
2020-07-20 12:39:43 +02:00
export default class Locale {
2022-09-08 21:40:48 +02:00
public static showLinkToWeblate: UIEventSource<boolean> = new UIEventSource<boolean>(false)
/**
* Indicates that -if showLinkToWeblate is true- a link on mobile mode is shown as well
*/
public static showLinkOnMobile: UIEventSource<boolean> = new UIEventSource<boolean>(false)
2022-09-08 21:40:48 +02:00
public static language: UIEventSource<string> = Locale.setup()
2020-07-25 18:00:08 +02:00
/**
* Creates the UIEventSource containing the identifier of the current language
*
* If the QueryParameter 'language' is set, this query parameter will be used as backing source value
* If not set, a localStorageSource will be used. This will use the navigator language by default
*
* Note that other parts of the code (most notably the UserRelatedState) might sync language selection with OSM.
*
*
* @private
*/
2020-07-31 04:58:58 +02:00
private static setup() {
let source: UIEventSource<string>
if (QueryParameters.wasInitialized("language") || Utils.runningFromConsole) {
2023-07-16 19:37:11 +02:00
if(!Utils.runningFromConsole){
console.debug("Language was initialized via URL-parameter - using the URL parameter as store instead of local storage", QueryParameters.wasInitialized("language"))
}
source = QueryParameters.GetQueryParameter(
"language",
undefined,
["The language to display MapComplete in.",
"The user display language is determined in the following order:",
"- If the user did log in and did set their language before with MapComplete, use this language",
"- If the user visited MapComplete before and did change their language, use the language as set by this URL-parameter. This will _disable_ saving the language to localStorage in case a non-logged-in user changes their language",
"- Use the navigator-language (if available)",
"- Use English",
"",
2023-07-16 02:50:02 +02:00
"Note that this URL-parameter is not added to the URL-bar by default.",
"",
"Translations are never complete. If a translation in a certain language is missing, English is used as fallback."].join("\n"),
)
} else {
let browserLanguage = "en"
if (typeof navigator !== "undefined") {
browserLanguage = navigator.languages?.[0] ?? navigator.language ?? "en"
console.log("Browser language is", browserLanguage)
}
source = LocalStorageSource.Get("language", browserLanguage)
}
2021-01-06 02:21:50 +01:00
if (!Utils.runningFromConsole) {
2020-07-31 17:11:44 +02:00
// @ts-ignore
window.setLanguage = function (language: string) {
source.setData(language)
}
2022-04-03 03:49:09 +02:00
}
2022-09-08 21:40:48 +02:00
QueryParameters.GetBooleanQueryParameter(
"fs-translation-mode",
false,
"If set, will show a translation button next to every string."
).addCallbackAndRunD((tr) => {
Locale.showLinkToWeblate.setData(Locale.showLinkToWeblate.data || tr)
2022-04-03 03:49:09 +02:00
})
2022-09-08 21:40:48 +02:00
return source
2020-07-25 18:00:08 +02:00
}
2020-07-20 12:39:43 +02:00
}