import { useEffect } from "react"; import { observer } from "mobx-react-lite"; import Link from "next/link"; // hooks import { useDashboard } from "hooks/store"; // components import { WidgetLoader } from "components/dashboard/widgets"; // helpers import { renderFormattedPayloadDate } from "helpers/date-time.helper"; import { cn } from "helpers/common.helper"; // types import { TOverviewStatsWidgetResponse } from "@plane/types"; export type WidgetProps = { dashboardId: string; workspaceSlug: string; }; const WIDGET_KEY = "overview_stats"; export const OverviewStatsWidget: React.FC = observer((props) => { const { dashboardId, workspaceSlug } = props; // store hooks const { fetchWidgetStats, widgetStats: allWidgetStats } = useDashboard(); // derived values const widgetStats = allWidgetStats?.[workspaceSlug]?.[dashboardId]?.[WIDGET_KEY] as TOverviewStatsWidgetResponse; const today = renderFormattedPayloadDate(new Date()); const STATS_LIST = [ { key: "assigned", title: "Issues assigned", count: widgetStats?.assigned_issues_count, link: `/${workspaceSlug}/workspace-views/assigned`, }, { key: "overdue", title: "Issues overdue", count: widgetStats?.pending_issues_count, link: `/${workspaceSlug}/workspace-views/assigned/?target_date=${today};before`, }, { key: "created", title: "Issues created", count: widgetStats?.created_issues_count, link: `/${workspaceSlug}/workspace-views/created`, }, { key: "completed", title: "Issues completed", count: widgetStats?.completed_issues_count, link: `/${workspaceSlug}/workspace-views/assigned?state_group=completed`, }, ]; useEffect(() => { if (!widgetStats) fetchWidgetStats(workspaceSlug, dashboardId, { widget_key: WIDGET_KEY, }); }, [dashboardId, fetchWidgetStats, widgetStats, workspaceSlug]); if (!widgetStats) return ; return (
{STATS_LIST.map((stat, index) => { const isFirst = index === 0; const isLast = index === STATS_LIST.length - 1; const isMiddle = !isFirst && !isLast; return (
{!isLast && (
)}
{stat.count}

{stat.title}

); })}
); });