import { useState } from "react"; import Image from "next/image"; import { useRouter } from "next/router"; import useSWR from "swr"; import { observer } from "mobx-react-lite"; // hooks import { useMobxStore } from "lib/mobx/store-provider"; // components import { TourRoot } from "components/onboarding"; import { UserGreetingsView } from "components/user"; import { CompletedIssuesGraph, IssuesList, IssuesPieChart, IssuesStats } from "components/workspace"; import { Button } from "@plane/ui"; // images import emptyDashboard from "public/empty-state/dashboard.svg"; import { NewEmptyState } from "components/common/new-empty-state"; import emptyProject from "public/empty-state/dashboard_empty_project.webp"; export const WorkspaceDashboardView = observer(() => { // router const router = useRouter(); const { workspaceSlug } = router.query; // store const { user: userStore, project: projectStore, commandPalette: commandPaletteStore, trackEvent: { setTrackElement }, } = useMobxStore(); const user = userStore.currentUser; const projects = workspaceSlug ? projectStore.projects[workspaceSlug.toString()] : null; const workspaceDashboardInfo = userStore.dashboardInfo; // states const [month, setMonth] = useState(new Date().getMonth() + 1); // fetch user dashboard info useSWR( workspaceSlug ? `USER_WORKSPACE_DASHBOARD_${workspaceSlug}_${month}` : null, workspaceSlug ? () => userStore.fetchUserDashboardInfo(workspaceSlug.toString(), month) : null ); const handleTourCompleted = () => { userStore.updateTourCompleted(); }; return ( <> {/* {isProductUpdatesModalOpen && ( <ProductUpdatesModal isOpen={isProductUpdatesModalOpen} setIsOpen={setIsProductUpdatesModalOpen} /> )} */} {user && !user.is_tour_completed && ( <div className="fixed top-0 left-0 h-full w-full bg-custom-backdrop bg-opacity-50 transition-opacity z-20 grid place-items-center"> <TourRoot onComplete={handleTourCompleted} /> </div> )} <div className="p-8 space-y-8"> {user && <UserGreetingsView user={user} />} {projects ? ( projects.length > 0 ? ( <div className="flex flex-col gap-8"> <IssuesStats data={workspaceDashboardInfo} /> <div className="grid grid-cols-1 gap-8 lg:grid-cols-2"> <IssuesList issues={workspaceDashboardInfo?.overdue_issues} type="overdue" /> <IssuesList issues={workspaceDashboardInfo?.upcoming_issues} type="upcoming" /> <IssuesPieChart groupedIssues={workspaceDashboardInfo?.state_distribution} /> <CompletedIssuesGraph issues={workspaceDashboardInfo?.completed_issues} month={month} setMonth={setMonth} /> </div> </div> ) : ( <NewEmptyState image={emptyProject} title="Overview of your projects, activity, and metrics" description="When you have created a project and have issues assigned, you will see metrics, activity, and things you care about here. This is personalized to your role in projects, so project admins will see more than members." comicBox={{ title: "Everything starts with a project in Plane", direction: "right", description: "A project could be a product’s roadmap, a marketing campaign, or launching a new car.", }} primaryButton={{ text: "Build your first project", onClick: () => { setTrackElement("DASHBOARD_PAGE"); commandPaletteStore.toggleCreateProjectModal(true); }, }} /> ) ) : null} </div> </> ); });