All files / app/features/communities PagePage.tsx

0% Statements 0/33
0% Branches 0/20
0% Functions 0/3
0% Lines 0/32

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99                                                                                                                                                                                                     
import Alert from "components/Alert";
import CenteredSpinner from "components/CenteredSpinner/CenteredSpinner";
import CommentBox from "components/Comments/CommentBox";
import HtmlMeta from "components/HtmlMeta";
import Markdown from "components/Markdown";
import PageTitle from "components/PageTitle";
import TextBody from "components/TextBody";
import { useRouter } from "next/router";
import { useTranslation } from "next-i18next";
import { Page, PageType } from "proto/pages_pb";
import React, { useEffect, useState } from "react";
import { routeToGuide, routeToPlace } from "routes";
import { service } from "service";
import isGrpcError from "service/utils/isGrpcError";
 
export default function PagePage({
  pageType,
  pageId,
  pageSlug,
}: {
  pageType: PageType;
  pageId: number;
  pageSlug?: string;
}) {
  const { t } = useTranslation(["communities", "global"]);
  const [loading, setLoading] = useState(false);
  const [error, setError] = useState("");
  const [page, setPage] = useState<Page.AsObject | null>(null);
 
  const router = useRouter();
 
  useEffect(() => {
    Iif (!pageId) return;
    (async () => {
      setLoading(true);
      try {
        const page = await service.pages.getPage(pageId);
        if (
          page.slug !== pageSlug ||
          (page.type !== pageType && typeof window !== "undefined")
        ) {
          // if the address is wrong, redirect to the right place
          router.push(
            pageType === PageType.PAGE_TYPE_PLACE
              ? routeToPlace(page.pageId, page.slug)
              : routeToGuide(page.pageId, page.slug)
          );
        } else {
          setPage(page);
        }
      } catch (e) {
        console.error(e);
        setError(isGrpcError(e) ? e.message : t("global:error.fatal_message"));
      }
      setLoading(false);
    })();
  }, [pageType, pageId, pageSlug, router, t]);
 
  return (
    <>
      {error && <Alert severity="error">{error}</Alert>}
      {loading ? (
        <CenteredSpinner />
      ) : page ? (
        <>
          <HtmlMeta title={page.title} />
          {page.photoUrl && <img src={page.photoUrl} alt="" />}
          <PageTitle>{page.title}</PageTitle>
          <p>
            Owner:{" "}
            {page.ownerUserId !== 0
              ? "user " + page.ownerUserId
              : page.ownerCommunityId !== 0
              ? "community " + page.ownerCommunityId
              : "group " + page.ownerGroupId}
          </p>
          <p>
            Last edited at {page.lastEdited?.seconds} by {page.lastEditorUserId}
          </p>
          <p>
            Created at {page.created?.seconds} by {page.creatorUserId}
          </p>
          <p>
            Address: {page.address} (coords: {page.location!.lat},{" "}
            {page.location!.lng})
          </p>
          <Markdown source={page.content} />
          <p>
            You <b>{page.canEdit ? "can" : "cannot"}</b> edit this page.
          </p>
          <CommentBox threadId={page.thread!.threadId} />
        </>
      ) : (
        <TextBody>Error</TextBody>
      )}
    </>
  );
}