1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2024-12-20 14:37:43 +01:00

Add better scrape error dialog

This commit is contained in:
Cooper Ransom 2024-03-26 19:43:53 -04:00
parent 1ba72fe768
commit b7be016377
2 changed files with 39 additions and 28 deletions

View file

@ -423,11 +423,17 @@
"notFound": { "notFound": {
"badge": "Not found", "badge": "Not found",
"detailsButton": "Show details", "detailsButton": "Show details",
"reloadButton": "Try again",
"homeButton": "Go home", "homeButton": "Go home",
"text": "We can not find the media you are looking for or no one provides it... <bold>Did you enable the extension for this site?</bold>", "text": "We have searched through our providers and cannot find the media you are looking for! We do not host the media and have no control over what is available. Please click 'Show details' below for more details.",
"text2": "We can not find the media you are looking for or no one provides it...",
"title": "We couldn't find that" "title": "We couldn't find that"
},
"extensionFailure": {
"badge": "Not found",
"homeButton": "Go home",
"enableExtension": "Enable extension",
"disabledTitle": "Extension disabled",
"text": "You've installed the movie-web extension. To start using it, complete a few preliminary steps. Have you enabled the extension for this site?",
"title": "Extension Disabled"
} }
}, },
"time": { "time": {

View file

@ -3,7 +3,7 @@ import { Trans, useTranslation } from "react-i18next";
import { useLocation } from "react-router-dom"; import { useLocation } from "react-router-dom";
import { isAllowedExtensionVersion } from "@/backend/extension/compatibility"; import { isAllowedExtensionVersion } from "@/backend/extension/compatibility";
import { extensionInfo } from "@/backend/extension/messaging"; import { extensionInfo, sendPage } from "@/backend/extension/messaging";
import { Button } from "@/components/buttons/Button"; import { Button } from "@/components/buttons/Button";
import { Icons } from "@/components/Icon"; import { Icons } from "@/components/Icon";
import { IconPill } from "@/components/layout/IconPill"; import { IconPill } from "@/components/layout/IconPill";
@ -47,6 +47,8 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) {
const location = useLocation(); const location = useLocation();
const [extensionState, setExtensionState] = const [extensionState, setExtensionState] =
useState<ExtensionStatus>("unknown"); useState<ExtensionStatus>("unknown");
const [title, setTitle] = useState(t("player.scraping.notFound.title"));
const [icon, setIcon] = useState(Icons.WAND);
const error = useMemo(() => { const error = useMemo(() => {
const data = props.data; const data = props.data;
@ -65,20 +67,24 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) {
}, [props, location]); }, [props, location]);
useEffect(() => { useEffect(() => {
getExtensionState().then(setExtensionState); getExtensionState().then((state) => {
}, []); setExtensionState(state);
if (state === "disallowed") {
setTitle(t("player.scraping.extensionFailure.disabledTitle"));
setIcon(Icons.LOCK);
}
});
}, [t]);
return ( return (
<ErrorLayout> <ErrorLayout>
<ErrorContainer> <ErrorContainer>
<IconPill icon={Icons.WAND}> <IconPill icon={icon}>{t("player.scraping.notFound.badge")}</IconPill>
{t("player.scraping.notFound.badge")} <Title>{title}</Title>
</IconPill>
<Title>{t("player.scraping.notFound.title")}</Title>
<Paragraph> <Paragraph>
{extensionState === "disallowed" ? ( {extensionState === "disallowed" ? (
<Trans <Trans
i18nKey="player.scraping.notFound.text" i18nKey="player.scraping.extensionFailure.text"
components={{ components={{
bold: ( bold: (
<span className="font-bold" style={{ color: "#cfcfcf" }} /> <span className="font-bold" style={{ color: "#cfcfcf" }} />
@ -87,7 +93,7 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) {
/> />
) : ( ) : (
<Trans <Trans
i18nKey="player.scraping.notFound.text2" i18nKey="player.scraping.notFound.text"
components={{ components={{
bold: ( bold: (
<span className="font-bold" style={{ color: "#cfcfcf" }} /> <span className="font-bold" style={{ color: "#cfcfcf" }} />
@ -97,14 +103,6 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) {
)} )}
</Paragraph> </Paragraph>
<div className="flex gap-3"> <div className="flex gap-3">
<Button
onClick={() => window.location.reload()}
theme="secondary"
padding="md:px-12 p-2.5"
className="mt-6"
>
{t("player.scraping.notFound.reloadButton")}
</Button>
<Button <Button
href="/" href="/"
theme="secondary" theme="secondary"
@ -113,15 +111,22 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) {
> >
{t("player.scraping.notFound.homeButton")} {t("player.scraping.notFound.homeButton")}
</Button> </Button>
</div>
<Button <Button
onClick={() => modal.show()} onClick={() => {
sendPage({
page: "PermissionGrant",
redirectUrl: window.location.href,
});
}}
theme="purple" theme="purple"
padding="md:px-12 p-2.5" padding="md:px-12 p-2.5"
className="mt-6" className="mt-6"
> >
{t("player.scraping.notFound.detailsButton")} {extensionState === "unknown"
? t("player.scraping.notFound.detailsButton")
: t("player.scraping.extensionFailure.enableExtension")}
</Button> </Button>
</div>
</ErrorContainer> </ErrorContainer>
{error ? ( {error ? (
<ErrorCardInModal <ErrorCardInModal