Display the system language first. Fixes #4
parent
cae3b68c7f
commit
735e9b7f5e
|
|
@ -53,6 +53,24 @@ export function Component(props: Props) {
|
||||||
Langs[x as keyof typeof Langs],
|
Langs[x as keyof typeof Langs],
|
||||||
]) as Key[];
|
]) as Key[];
|
||||||
|
|
||||||
|
// Get the user's system language
|
||||||
|
const preferredLanguage =
|
||||||
|
navigator.languages
|
||||||
|
?.filter((lang) =>
|
||||||
|
languages.find((l) => l[0] == lang.split("-")[0]),
|
||||||
|
)?.[0]
|
||||||
|
?.split("-")[0] ?? "en";
|
||||||
|
|
||||||
|
// This moves the user's system language to the top of the language list
|
||||||
|
const prefLangKey = languages.find((lang) => lang[0] == preferredLanguage);
|
||||||
|
if (prefLangKey) {
|
||||||
|
languages.splice(
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
languages.splice(languages.indexOf(prefLangKey), 1)[0],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={styles.languages}>
|
<div className={styles.languages}>
|
||||||
<h3>
|
<h3>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue