2023-08-31 13:13:37 +00:00
|
|
|
import useSWR from "swr";
|
2023-08-30 11:21:13 +00:00
|
|
|
import type { GetServerSideProps } from "next";
|
2023-08-30 08:11:25 +00:00
|
|
|
import { useRouter } from "next/router";
|
2023-08-30 11:21:13 +00:00
|
|
|
import Head from "next/head";
|
2023-08-31 13:13:37 +00:00
|
|
|
/// layouts
|
2023-08-30 08:11:25 +00:00
|
|
|
import ProjectLayout from "layouts/project-layout";
|
2023-08-31 13:13:37 +00:00
|
|
|
// components
|
2023-08-30 11:21:13 +00:00
|
|
|
import { ProjectDetailsView } from "components/views/project-details";
|
2023-08-31 13:13:37 +00:00
|
|
|
// lib
|
|
|
|
import { useMobxStore } from "lib/mobx/store-provider";
|
2023-08-11 11:48:33 +00:00
|
|
|
|
2023-08-30 11:21:13 +00:00
|
|
|
const WorkspaceProjectPage = (props: any) => {
|
|
|
|
const SITE_TITLE = props?.project_settings?.project_details?.name || "Plane | Deploy";
|
2023-08-11 11:48:33 +00:00
|
|
|
|
|
|
|
const router = useRouter();
|
2023-08-31 13:13:37 +00:00
|
|
|
const { workspace_slug, project_slug, states, labels, priorities } = router.query;
|
|
|
|
|
|
|
|
const { project: projectStore, issue: issueStore } = useMobxStore();
|
|
|
|
|
|
|
|
useSWR("REVALIDATE_ALL", () => {
|
|
|
|
if (workspace_slug && project_slug) {
|
|
|
|
projectStore.fetchProjectSettings(workspace_slug.toString(), project_slug.toString());
|
|
|
|
const params = {
|
|
|
|
state: states || null,
|
|
|
|
labels: labels || null,
|
|
|
|
priority: priorities || null,
|
|
|
|
};
|
|
|
|
issueStore.fetchPublicIssues(workspace_slug.toString(), project_slug.toString(), params);
|
|
|
|
}
|
|
|
|
});
|
2023-08-11 11:48:33 +00:00
|
|
|
|
|
|
|
return (
|
2023-08-30 08:11:25 +00:00
|
|
|
<ProjectLayout>
|
2023-08-30 11:21:13 +00:00
|
|
|
<Head>
|
|
|
|
<title>{SITE_TITLE}</title>
|
|
|
|
</Head>
|
|
|
|
<ProjectDetailsView />
|
2023-08-30 08:11:25 +00:00
|
|
|
</ProjectLayout>
|
2023-08-11 11:48:33 +00:00
|
|
|
);
|
2023-08-30 07:19:15 +00:00
|
|
|
};
|
2023-08-11 11:48:33 +00:00
|
|
|
|
2023-08-30 12:09:11 +00:00
|
|
|
// export const getServerSideProps: GetServerSideProps<any> = async ({ query: { workspace_slug, project_slug } }) => {
|
|
|
|
// const res = await fetch(
|
|
|
|
// `${process.env.NEXT_PUBLIC_API_BASE_URL}/api/public/workspaces/${workspace_slug}/project-boards/${project_slug}/settings/`
|
|
|
|
// );
|
|
|
|
// const project_settings = await res.json();
|
|
|
|
// return { props: { project_settings } };
|
|
|
|
// };
|
2023-08-30 11:21:13 +00:00
|
|
|
|
|
|
|
export default WorkspaceProjectPage;
|