mirror of
https://github.com/Shadowfita/docmost.git
synced 2025-11-13 08:12:32 +10:00
70 lines
1.9 KiB
TypeScript
70 lines
1.9 KiB
TypeScript
import { useParams } from "react-router-dom";
|
|
import { usePageQuery } from "@/features/page/queries/page-query";
|
|
import { FullEditor } from "@/features/editor/full-editor";
|
|
import HistoryModal from "@/features/page-history/components/history-modal";
|
|
import { Helmet } from "react-helmet-async";
|
|
import PageHeader from "@/features/page/components/header/page-header.tsx";
|
|
import { extractPageSlugId } from "@/lib";
|
|
import { useGetSpaceBySlugQuery } from "@/features/space/queries/space-query.ts";
|
|
import { useMemo } from "react";
|
|
import { useSpaceAbility } from "@/features/space/permissions/use-space-ability.ts";
|
|
import {
|
|
SpaceCaslAction,
|
|
SpaceCaslSubject,
|
|
} from "@/features/space/permissions/permissions.type.ts";
|
|
|
|
export default function Page() {
|
|
const { pageSlug } = useParams();
|
|
const {
|
|
data: page,
|
|
isLoading,
|
|
isError,
|
|
} = usePageQuery({ pageId: extractPageSlugId(pageSlug) });
|
|
const { data: space } = useGetSpaceBySlugQuery(page?.space?.slug);
|
|
|
|
const spaceRules = space?.membership?.permissions;
|
|
const spaceAbility = useMemo(() => useSpaceAbility(spaceRules), [spaceRules]);
|
|
|
|
if (isLoading) {
|
|
return <></>;
|
|
}
|
|
|
|
if (isError || !page) {
|
|
// TODO: fix this
|
|
return <div>Error fetching page data.</div>;
|
|
}
|
|
|
|
if (!space) {
|
|
return <></>;
|
|
}
|
|
|
|
return (
|
|
page && (
|
|
<div>
|
|
<Helmet>
|
|
<title>{`${page?.icon || ""} ${page.title || "untitled"}`}</title>
|
|
</Helmet>
|
|
|
|
<PageHeader
|
|
readOnly={spaceAbility.cannot(
|
|
SpaceCaslAction.Manage,
|
|
SpaceCaslSubject.Page,
|
|
)}
|
|
/>
|
|
|
|
<FullEditor
|
|
pageId={page.id}
|
|
title={page.title}
|
|
slugId={page.slugId}
|
|
spaceSlug={page?.space?.slug}
|
|
editable={spaceAbility.can(
|
|
SpaceCaslAction.Manage,
|
|
SpaceCaslSubject.Page,
|
|
)}
|
|
/>
|
|
<HistoryModal pageId={page.id} />
|
|
</div>
|
|
)
|
|
);
|
|
}
|