import { useNavigate, useParams } from "react-router-dom"; import { Helmet } from "react-helmet-async"; import { useTranslation } from "react-i18next"; import { useSharePageQuery } from "@/features/share/queries/share-query.ts"; import { Container } from "@mantine/core"; import React, { useEffect } from "react"; import ReadonlyPageEditor from "@/features/editor/readonly-page-editor.tsx"; import { extractPageSlugId } from "@/lib"; import { Error404 } from "@/components/ui/error-404.tsx"; import ShareBranding from "@/features/share/components/share-branding.tsx"; export default function SharedPage() { const { t } = useTranslation(); const { pageSlug } = useParams(); const { shareId } = useParams(); const navigate = useNavigate(); const { data, isLoading, isError, error } = useSharePageQuery({ pageId: extractPageSlugId(pageSlug), }); useEffect(() => { if (shareId && data) { if (data.share.key !== shareId) { navigate(`/share/${data.share.key}/p/${pageSlug}`, { replace: true }); } } }, [shareId, data]); if (isLoading) { return <>; } if (isError || !data) { if ([401, 403, 404].includes(error?.["status"])) { return ; } return
{t("Error fetching page data.")}
; } return (
{`${data?.page?.title || t("untitled")}`} {!data?.share.searchIndexing && ( )} {data && !shareId && !data.hasLicenseKey && }
); }