* feat: noindex/nofollow - On login: nofollow - On app pages: noindex, nofollow https://app.plane.so/plane/browse/WEB-4098/ - https://nextjs.org/docs/app/api-reference/file-conventions/layout - https://nextjs.org/docs/app/building-your-application/routing/route-groups#creating-multiple-root-layouts - https://nextjs.org/docs/app/api-reference/functions/generate-metadata#link-relpreload * chore: address PR feedback
30 lines
877 B
TypeScript
30 lines
877 B
TypeScript
"use client";
|
|
|
|
import { observer } from "mobx-react";
|
|
// components
|
|
import { useTranslation } from "@plane/i18n";
|
|
import { PageHead, AppHeader, ContentWrapper } from "@/components/core";
|
|
import { WorkspaceHomeView } from "@/components/home";
|
|
// hooks
|
|
import { useWorkspace } from "@/hooks/store";
|
|
// local components
|
|
import { WorkspaceDashboardHeader } from "./header";
|
|
|
|
const WorkspaceDashboardPage = observer(() => {
|
|
const { currentWorkspace } = useWorkspace();
|
|
const { t } = useTranslation();
|
|
// derived values
|
|
const pageTitle = currentWorkspace?.name ? `${currentWorkspace?.name} - ${t("home.title")}` : undefined;
|
|
|
|
return (
|
|
<>
|
|
<AppHeader header={<WorkspaceDashboardHeader />} />
|
|
<ContentWrapper>
|
|
<PageHead title={pageTitle} />
|
|
<WorkspaceHomeView />
|
|
</ContentWrapper>
|
|
</>
|
|
);
|
|
});
|
|
|
|
export default WorkspaceDashboardPage;
|