import { useEffect } from "react"; import { observer } from "mobx-react-lite"; // components import { Spinner } from "@plane/ui"; // components import { DashboardWidgets } from "@/components/dashboard"; import { EmptyState } from "@/components/empty-state"; import { IssuePeekOverview } from "@/components/issues"; import { TourRoot } from "@/components/onboarding"; import { UserGreetingsView } from "@/components/user"; // constants import { EmptyStateType } from "@/constants/empty-state"; import { E_DASHBOARD_EMPTY_STATE, PRODUCT_TOUR_COMPLETED } from "@/constants/event-tracker"; // helpers import { cn } from "@/helpers/common.helper"; // hooks import { useCommandPalette, useAppRouter, useUserProfile, useEventTracker, useDashboard, useProject, useUser } from "@/hooks/store"; import useSize from "@/hooks/use-window-size"; export const WorkspaceDashboardView = observer(() => { // store hooks const { // captureEvent, setTrackElement, } = useEventTracker(); const { toggleCreateProjectModal } = useCommandPalette(); const { workspaceSlug } = useAppRouter(); const { data: currentUser } = useUser(); const { data: currentUserProfile, updateTourCompleted } = useUserProfile(); const { captureEvent } = useEventTracker(); const { homeDashboardId, fetchHomeDashboardWidgets } = useDashboard(); const { joinedProjectIds } = useProject(); const [windowWidth] = useSize(); const handleTourCompleted = () => { updateTourCompleted() .then(() => { captureEvent(PRODUCT_TOUR_COMPLETED, { user_id: currentUser?.id, state: "SUCCESS", }); }) .catch((error) => { console.error(error); }); }; // fetch home dashboard widgets on workspace change useEffect(() => { if (!workspaceSlug) return; fetchHomeDashboardWidgets(workspaceSlug); }, [fetchHomeDashboardWidgets, workspaceSlug]); return ( <> {currentUserProfile && !currentUserProfile.is_tour_completed && (
)} {homeDashboardId && joinedProjectIds ? ( <> {joinedProjectIds.length > 0 ? ( <>
= 768, } )} > {currentUser && }
) : ( { setTrackElement(E_DASHBOARD_EMPTY_STATE); toggleCreateProjectModal(true); }} /> )} ) : (
)} ); });