import { useEffect } from "react"; import { observer } from "mobx-react-lite"; // hooks import { useApplication, useDashboard, useProject, useUser } from "hooks/store"; // components import { TourRoot } from "components/onboarding"; import { UserGreetingsView } from "components/user"; import { IssuePeekOverview } from "components/issues"; import { DashboardProjectEmptyState, DashboardWidgets } from "components/dashboard"; // ui import { Spinner } from "@plane/ui"; export const WorkspaceDashboardView = observer(() => { // store hooks const { eventTracker: { postHogEventTracker }, router: { workspaceSlug }, } = useApplication(); const { currentUser, updateTourCompleted } = useUser(); const { homeDashboardId, fetchHomeDashboardWidgets } = useDashboard(); const { joinedProjectIds } = useProject(); const handleTourCompleted = () => { updateTourCompleted() .then(() => { postHogEventTracker("USER_TOUR_COMPLETE", { user_id: currentUser?.id, email: currentUser?.email, state: "SUCCESS", }); }) .catch((error) => { console.error(error); }); }; // fetch home dashboard widgets on workspace change useEffect(() => { if (!workspaceSlug) return; fetchHomeDashboardWidgets(workspaceSlug); }, [fetchHomeDashboardWidgets, workspaceSlug]); return ( <> {currentUser && !currentUser.is_tour_completed && (
)} {homeDashboardId && joinedProjectIds ? (
{currentUser && } {joinedProjectIds.length > 0 ? : }
) : (
)} ); });