2022-05-25 16:43:59 +01:00
|
|
|
import { Check } from "@styled-icons/boxicons-regular";
|
2021-12-11 11:56:33 +00:00
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
|
2021-06-19 22:37:12 +01:00
|
|
|
import styles from "./Panes.module.scss";
|
2021-07-05 11:23:23 +01:00
|
|
|
import { Text } from "preact-i18n";
|
2021-12-11 11:56:33 +00:00
|
|
|
import { useMemo } from "preact/hooks";
|
|
|
|
|
|
|
|
import { useApplicationState } from "../../../mobx/State";
|
2021-07-05 11:23:23 +01:00
|
|
|
|
2022-05-25 16:43:59 +01:00
|
|
|
import britannyFlagSVG from "../assets/flags/brittany.svg";
|
|
|
|
import enchantingTableWEBP from "../assets/flags/enchanting_table.webp";
|
|
|
|
import esperantoFlagSVG from "../assets/flags/esperanto.svg";
|
|
|
|
import kurdistanFlagSVG from "../assets/flags/kurdistan.svg";
|
|
|
|
import tamilFlagPNG from "../assets/flags/tamil_nadu.png";
|
|
|
|
import tokiponaSVG from "../assets/flags/toki_pona.svg";
|
|
|
|
import venetoFlagSVG from "../assets/flags/veneto.svg";
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2022-03-25 11:17:04 +00:00
|
|
|
import {
|
|
|
|
Language,
|
|
|
|
LanguageEntry,
|
|
|
|
Languages as Langs,
|
|
|
|
} from "../../../../external/lang/Languages";
|
2022-05-25 16:43:59 +01:00
|
|
|
import Emoji from "../../../components/common/Emoji";
|
|
|
|
import Checkbox from "../../../components/ui/Checkbox";
|
|
|
|
import Tip from "../../../components/ui/Tip";
|
2022-03-25 11:17:04 +00:00
|
|
|
|
2021-12-11 11:56:33 +00:00
|
|
|
type Key = [Language, LanguageEntry];
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-12-11 11:56:33 +00:00
|
|
|
interface Props {
|
|
|
|
entry: Key;
|
|
|
|
selected: boolean;
|
|
|
|
onSelect: () => void;
|
|
|
|
}
|
2021-06-22 16:37:06 +01:00
|
|
|
|
2021-12-11 11:56:33 +00:00
|
|
|
/**
|
|
|
|
* Component providing individual language entries.
|
|
|
|
* @param param0 Entry data
|
|
|
|
*/
|
|
|
|
function Entry({ entry: [x, lang], selected, onSelect }: Props) {
|
2021-07-05 11:25:20 +01:00
|
|
|
return (
|
|
|
|
<Checkbox
|
|
|
|
key={x}
|
|
|
|
className={styles.entry}
|
2021-12-11 11:56:33 +00:00
|
|
|
checked={selected}
|
|
|
|
onChange={onSelect}>
|
2021-07-05 11:25:20 +01:00
|
|
|
<div className={styles.flag}>
|
2022-05-25 16:43:59 +01:00
|
|
|
{lang.i18n === "vec" ? (
|
|
|
|
<img
|
|
|
|
src={venetoFlagSVG}
|
|
|
|
width={42}
|
|
|
|
loading="lazy"
|
|
|
|
style={{ objectFit: "cover", borderRadius: "6px" }}
|
|
|
|
/>
|
|
|
|
) : lang.i18n === "br" ? (
|
|
|
|
<img
|
|
|
|
src={britannyFlagSVG}
|
|
|
|
width={42}
|
|
|
|
loading="lazy"
|
|
|
|
style={{ objectFit: "cover", borderRadius: "6px" }}
|
|
|
|
/>
|
|
|
|
) : lang.i18n === "ckb" ? (
|
|
|
|
<img
|
|
|
|
src={kurdistanFlagSVG}
|
|
|
|
width={42}
|
|
|
|
loading="lazy"
|
|
|
|
style={{ objectFit: "cover", borderRadius: "6px" }}
|
|
|
|
/>
|
|
|
|
) : lang.i18n === "eo" ? (
|
2022-01-15 15:23:03 +00:00
|
|
|
<img
|
|
|
|
src={esperantoFlagSVG}
|
|
|
|
width={42}
|
|
|
|
loading="lazy"
|
2022-05-25 16:43:59 +01:00
|
|
|
style={{ objectFit: "cover", borderRadius: "6px" }}
|
2022-01-15 15:23:03 +00:00
|
|
|
/>
|
|
|
|
) : lang.i18n === "ta" ? (
|
2021-10-31 17:36:26 +00:00
|
|
|
<img
|
|
|
|
src={tamilFlagPNG}
|
|
|
|
width={42}
|
2022-01-15 15:23:03 +00:00
|
|
|
loading="lazy"
|
2022-05-25 16:43:59 +01:00
|
|
|
style={{ objectFit: "cover" }}
|
2021-10-31 17:36:26 +00:00
|
|
|
/>
|
|
|
|
) : lang.emoji === "🙂" ? (
|
2022-05-25 16:43:59 +01:00
|
|
|
<img
|
|
|
|
src={tokiponaSVG}
|
|
|
|
width={42}
|
|
|
|
loading="lazy"
|
|
|
|
style={{ borderRadius: "6px" }}
|
|
|
|
/>
|
2021-09-04 15:50:58 +01:00
|
|
|
) : lang.emoji === "🪄" ? (
|
|
|
|
<img
|
|
|
|
src={enchantingTableWEBP}
|
|
|
|
width={42}
|
2022-01-15 15:23:03 +00:00
|
|
|
loading="lazy"
|
2021-09-04 15:50:58 +01:00
|
|
|
style={{ objectFit: "contain" }}
|
|
|
|
/>
|
2021-08-04 19:22:13 +01:00
|
|
|
) : (
|
|
|
|
<Emoji size={42} emoji={lang.emoji} />
|
|
|
|
)}
|
2021-07-05 11:25:20 +01:00
|
|
|
</div>
|
2022-05-25 16:43:59 +01:00
|
|
|
<span className={styles.description}>
|
|
|
|
{lang.display} {lang.verified && <Check size={16} />}
|
|
|
|
</span>
|
2021-07-05 11:25:20 +01:00
|
|
|
</Checkbox>
|
|
|
|
);
|
2021-06-22 16:37:06 +01:00
|
|
|
}
|
|
|
|
|
2021-12-11 11:56:33 +00:00
|
|
|
/**
|
|
|
|
* Component providing the language selection menu.
|
|
|
|
*/
|
|
|
|
export const Languages = observer(() => {
|
|
|
|
const locale = useApplicationState().locale;
|
|
|
|
const language = locale.getLanguage();
|
|
|
|
|
|
|
|
// Generate languages array.
|
|
|
|
const languages = useMemo(() => {
|
|
|
|
const languages = Object.keys(Langs).map((x) => [
|
|
|
|
x,
|
|
|
|
Langs[x as keyof typeof Langs],
|
|
|
|
]) as Key[];
|
|
|
|
|
|
|
|
// Get the user's system language. Check for exact
|
|
|
|
// matches first, otherwise check for partial matches
|
|
|
|
const preferredLanguage =
|
|
|
|
navigator.languages.filter((lang) =>
|
|
|
|
languages.find((l) => l[0].replace(/_/g, "-") == lang),
|
|
|
|
)?.[0] ||
|
|
|
|
navigator.languages
|
|
|
|
?.map((x) => x.split("-")[0])
|
|
|
|
?.filter((lang) => languages.find((l) => l[0] == lang))?.[0]
|
|
|
|
?.split("-")[0];
|
|
|
|
|
|
|
|
if (preferredLanguage) {
|
|
|
|
// This moves the user's system language to the top of the language list
|
|
|
|
const prefLangKey = languages.find(
|
|
|
|
(lang) => lang[0].replace(/_/g, "-") == preferredLanguage,
|
2021-08-06 22:12:10 +02:00
|
|
|
);
|
2021-12-11 11:56:33 +00:00
|
|
|
|
|
|
|
if (prefLangKey) {
|
|
|
|
languages.splice(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
languages.splice(languages.indexOf(prefLangKey), 1)[0],
|
|
|
|
);
|
|
|
|
}
|
2021-08-06 22:12:10 +02:00
|
|
|
}
|
2021-12-11 11:56:33 +00:00
|
|
|
|
|
|
|
return languages;
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
// Creates entries with given key.
|
|
|
|
const EntryFactory = ([x, lang]: Key) => (
|
|
|
|
<Entry
|
|
|
|
key={x}
|
|
|
|
entry={[x, lang]}
|
|
|
|
selected={language === x}
|
|
|
|
onSelect={() => locale.setLanguage(x)}
|
|
|
|
/>
|
|
|
|
);
|
2021-08-06 20:48:10 +02:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
return (
|
|
|
|
<div className={styles.languages}>
|
|
|
|
<h3>
|
|
|
|
<Text id="app.settings.pages.language.select" />
|
|
|
|
</h3>
|
|
|
|
<div className={styles.list}>
|
2021-12-11 11:56:33 +00:00
|
|
|
{languages.filter(([, lang]) => !lang.cat).map(EntryFactory)}
|
2021-07-05 11:25:20 +01:00
|
|
|
</div>
|
2021-08-04 13:29:12 +02:00
|
|
|
<h3>
|
|
|
|
<Text id="app.settings.pages.language.const" />
|
|
|
|
</h3>
|
2021-08-04 12:31:51 +01:00
|
|
|
<div className={styles.list}>
|
|
|
|
{languages
|
|
|
|
.filter(([, lang]) => lang.cat === "const")
|
2021-12-11 11:56:33 +00:00
|
|
|
.map(EntryFactory)}
|
2021-08-04 12:31:51 +01:00
|
|
|
</div>
|
2021-07-05 11:25:20 +01:00
|
|
|
<h3>
|
|
|
|
<Text id="app.settings.pages.language.other" />
|
|
|
|
</h3>
|
|
|
|
<div className={styles.list}>
|
|
|
|
{languages
|
2021-08-04 12:31:51 +01:00
|
|
|
.filter(([, lang]) => lang.cat === "alt")
|
2021-12-11 11:56:33 +00:00
|
|
|
.map(EntryFactory)}
|
2021-07-05 11:25:20 +01:00
|
|
|
</div>
|
|
|
|
<Tip>
|
|
|
|
<span>
|
|
|
|
<Text id="app.settings.tips.languages.a" />
|
|
|
|
</span>{" "}
|
|
|
|
<a
|
|
|
|
href="https://weblate.insrt.uk/engage/revolt/?utm_source=widget"
|
2021-07-10 15:57:29 +01:00
|
|
|
target="_blank"
|
|
|
|
rel="noreferrer">
|
2021-07-05 11:25:20 +01:00
|
|
|
<Text id="app.settings.tips.languages.b" />
|
|
|
|
</a>
|
|
|
|
</Tip>
|
|
|
|
</div>
|
|
|
|
);
|
2021-07-05 11:23:23 +01:00
|
|
|
});
|