2025-02-05 15:18:02 +05:30
|
|
|
"use client";
|
|
|
|
|
|
|
|
|
|
import { observer } from "mobx-react";
|
|
|
|
|
import { useParams } from "next/navigation";
|
|
|
|
|
import useSWR from "swr";
|
|
|
|
|
// components
|
2024-08-12 18:24:42 +05:30
|
|
|
import Root from "@/components/project/root";
|
2025-02-05 15:18:02 +05:30
|
|
|
// hooks
|
|
|
|
|
import { useProject, useWorkspace } from "@/hooks/store";
|
|
|
|
|
|
|
|
|
|
export const ProjectPageRoot = observer(() => {
|
|
|
|
|
// router
|
|
|
|
|
const { workspaceSlug } = useParams();
|
|
|
|
|
// store
|
|
|
|
|
const { currentWorkspace } = useWorkspace();
|
|
|
|
|
const { fetchProjects } = useProject();
|
|
|
|
|
// fetching workspace projects
|
|
|
|
|
useSWR(
|
|
|
|
|
workspaceSlug && currentWorkspace ? `WORKSPACE_PROJECTS_${workspaceSlug}` : null,
|
|
|
|
|
workspaceSlug && currentWorkspace ? () => fetchProjects(workspaceSlug.toString()) : null,
|
|
|
|
|
{ revalidateIfStale: false, revalidateOnFocus: false }
|
|
|
|
|
);
|
2024-08-12 18:24:42 +05:30
|
|
|
|
2025-02-05 15:18:02 +05:30
|
|
|
return <Root />;
|
|
|
|
|
});
|