2023-12-04 06:41:36 +00:00
|
|
|
import { FC } from "react";
|
|
|
|
import useSWR from "swr";
|
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
// store
|
|
|
|
import { useMobxStore } from "lib/mobx/store-provider";
|
2023-05-17 07:28:01 +00:00
|
|
|
// components
|
2023-12-04 06:41:36 +00:00
|
|
|
import { CyclesBoard, CyclesList, CyclesListGanttChartView } from "components/cycles";
|
|
|
|
// ui components
|
|
|
|
import { Loader } from "@plane/ui";
|
2023-05-17 07:28:01 +00:00
|
|
|
// types
|
2023-12-04 06:41:36 +00:00
|
|
|
import { TCycleLayout } from "types";
|
|
|
|
|
|
|
|
export interface ICyclesView {
|
|
|
|
filter: "all" | "current" | "upcoming" | "draft" | "completed" | "incomplete";
|
|
|
|
layout: TCycleLayout;
|
|
|
|
workspaceSlug: string;
|
|
|
|
projectId: string;
|
|
|
|
peekCycle: string | undefined;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const CyclesView: FC<ICyclesView> = observer((props) => {
|
|
|
|
const { filter, layout, workspaceSlug, projectId, peekCycle } = props;
|
|
|
|
|
|
|
|
// store
|
|
|
|
const { cycle: cycleStore } = useMobxStore();
|
|
|
|
|
|
|
|
// api call to fetch cycles list
|
|
|
|
useSWR(
|
|
|
|
workspaceSlug && projectId && filter ? `CYCLES_LIST_${projectId}_${filter}` : null,
|
|
|
|
workspaceSlug && projectId && filter ? () => cycleStore.fetchCycles(workspaceSlug, projectId, filter) : null
|
|
|
|
);
|
2023-05-28 20:44:40 +00:00
|
|
|
|
2023-12-04 06:41:36 +00:00
|
|
|
const cyclesList =
|
|
|
|
filter === "completed"
|
|
|
|
? cycleStore.projectCompletedCycles
|
|
|
|
: filter === "draft"
|
|
|
|
? cycleStore.projectDraftCycles
|
|
|
|
: filter === "upcoming"
|
|
|
|
? cycleStore.projectUpcomingCycles
|
|
|
|
: cycleStore.projectCycles;
|
2023-05-17 07:28:01 +00:00
|
|
|
|
|
|
|
return (
|
2023-05-20 12:00:15 +00:00
|
|
|
<>
|
2023-12-04 06:41:36 +00:00
|
|
|
{layout === "list" && (
|
|
|
|
<>
|
|
|
|
{cyclesList ? (
|
|
|
|
<CyclesList cycles={cyclesList} filter={filter} workspaceSlug={workspaceSlug} projectId={projectId} />
|
|
|
|
) : (
|
|
|
|
<Loader className="space-y-4 p-8">
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
</Loader>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
|
|
|
|
{layout === "board" && (
|
|
|
|
<>
|
|
|
|
{cyclesList ? (
|
|
|
|
<CyclesBoard
|
|
|
|
cycles={cyclesList}
|
|
|
|
filter={filter}
|
|
|
|
workspaceSlug={workspaceSlug}
|
|
|
|
projectId={projectId}
|
|
|
|
peekCycle={peekCycle}
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<Loader className="grid grid-cols-1 gap-9 md:grid-cols-2 lg:grid-cols-3 p-8">
|
|
|
|
<Loader.Item height="200px" />
|
|
|
|
<Loader.Item height="200px" />
|
|
|
|
<Loader.Item height="200px" />
|
|
|
|
</Loader>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
|
|
|
|
{layout === "gantt" && (
|
|
|
|
<>
|
|
|
|
{cyclesList ? (
|
|
|
|
<CyclesListGanttChartView cycles={cyclesList} workspaceSlug={workspaceSlug} />
|
2023-05-28 20:44:40 +00:00
|
|
|
) : (
|
2023-12-04 06:41:36 +00:00
|
|
|
<Loader className="space-y-4">
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
<Loader.Item height="50px" />
|
|
|
|
</Loader>
|
|
|
|
)}
|
|
|
|
</>
|
2023-05-28 20:44:40 +00:00
|
|
|
)}
|
2023-05-20 12:00:15 +00:00
|
|
|
</>
|
2023-05-17 07:28:01 +00:00
|
|
|
);
|
2023-12-04 06:41:36 +00:00
|
|
|
});
|