1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-06 17:07:41 +01:00

localize setupPart

This commit is contained in:
mrjvs 2024-01-20 13:47:21 +01:00
parent 8cc6faff09
commit 88b788d831
2 changed files with 45 additions and 16 deletions
src
assets/locales
pages/parts/settings

View file

@ -393,6 +393,28 @@
"colorLabel": "Color"
},
"connections": {
"setup": {
"errorStatus": {
"title": "Something needs your attention",
"description": "It seems that one or more items in this setup need your attention."
},
"unsetStatus": {
"title": "You haven't gone through setup",
"description": "Please click the button to the right to start the setup process."
},
"successStatus": {
"title": "Everything is set up!",
"description": "All things are in place for you to start watching your favourite media."
},
"redoSetup": "Redo setup",
"doSetup": "Do setup",
"itemError": "There is something wrong with this setting. Go through setup again to fix it.",
"items": {
"extension": "Extension",
"proxy": "Custom proxy",
"default": "Default setup"
}
},
"server": {
"description": "If you would like to connect to a custom backend to store your data, enable this and provide the URL.",
"label": "Custom server",

View file

@ -1,6 +1,6 @@
import classNames from "classnames";
import { t } from "i18next";
import { ReactNode } from "react";
import { useTranslation } from "react-i18next";
import { useNavigate } from "react-router-dom";
import { useAsync } from "react-use";
@ -78,6 +78,7 @@ function SetupCheckList(props: {
grey?: boolean;
children?: ReactNode;
}) {
const { t } = useTranslation();
const statusMap: Record<Status, StatusCircleProps["type"]> = {
error: "error",
success: "success",
@ -97,17 +98,16 @@ function SetupCheckList(props: {
<div>
<p
className={classNames({
"!text-type-dimmed opacity-75": props.grey,
"text-type-dimmed opacity-75": props.grey,
"text-type-danger": props.status === "error",
"text-white": props.status === "success",
"text-white !opacity-100": props.status === "success",
})}
>
{props.children}
</p>
{props.status === "error" ? (
<p className="max-w-96">
There is something wrong with this setting. Go through setup again
to fix it.
{t("settings.connections.setup.itemError")}
</p>
) : null}
</div>
@ -116,22 +116,29 @@ function SetupCheckList(props: {
}
export function SetupPart() {
const { t } = useTranslation();
const navigate = useNavigate();
const { loading, setupStates, globalState } = useIsSetup();
if (loading || !setupStates) return <p>Loading states...</p>;
const textLookupMap: Record<Status, { title: string; desc: string }> = {
const textLookupMap: Record<
Status,
{ title: string; desc: string; button: string }
> = {
error: {
title: "err1",
desc: "err2",
title: "settings.connections.setup.errorStatus.title",
desc: "settings.connections.setup.errorStatus.description",
button: "settings.connections.setup.redoSetup",
},
success: {
title: "success1",
desc: "success2",
title: "settings.connections.setup.successStatus.title",
desc: "settings.connections.setup.successStatus.description",
button: "settings.connections.setup.redoSetup",
},
unset: {
title: "unset1",
desc: "unset2",
title: "settings.connections.setup.unsetStatus.title",
desc: "settings.connections.setup.unsetStatus.description",
button: "settings.connections.setup.doSetup",
},
};
@ -162,18 +169,18 @@ export function SetupPart() {
{t(textLookupMap[globalState].desc)}
</p>
<SetupCheckList status={setupStates.extension}>
Extension
{t("settings.connections.setup.items.extension")}
</SetupCheckList>
<SetupCheckList status={setupStates.proxy}>
Custom proxy
{t("settings.connections.setup.items.proxy")}
</SetupCheckList>
<SetupCheckList grey status={setupStates.defaultProxy}>
Default setup
{t("settings.connections.setup.items.default")}
</SetupCheckList>
</div>
<div className="mt-5">
<Button theme="purple" onClick={() => navigate("/onboarding")}>
Do setup
{t(textLookupMap[globalState].button)}
</Button>
</div>
</div>