"use client"; import { useEffect, useState } from "react"; // next imports import { useRouter, useParams, useSearchParams } from "next/navigation"; // mobx import { observer } from "mobx-react-lite"; // components import { IssueListView } from "components/issues/board-views/list"; import { IssueKanbanView } from "components/issues/board-views/kanban"; import { IssueCalendarView } from "components/issues/board-views/calendar"; import { IssueSpreadsheetView } from "components/issues/board-views/spreadsheet"; import { IssueGanttView } from "components/issues/board-views/gantt"; import { IssuePeekOverview } from "components/issues/peek-overview"; // mobx store import { RootStore } from "store/root"; import { useMobxStore } from "lib/mobx/store-provider"; // types import { TIssueBoardKeys } from "store/types"; const WorkspaceProjectPage = () => { const store: RootStore = useMobxStore(); const router = useRouter(); const routerParams = useParams(); const routerSearchparams = useSearchParams(); const activeIssueId = store.issue.activePeekOverviewIssueId; const { workspace_slug, project_slug } = routerParams as { workspace_slug: string; project_slug: string }; const board = routerSearchparams && routerSearchparams.get("board") != null && (routerSearchparams.get("board") as TIssueBoardKeys | ""); const states = routerSearchparams && routerSearchparams.get("states") != null && routerSearchparams.get("states"); const labels = routerSearchparams && routerSearchparams.get("labels") != null && routerSearchparams.get("labels"); const priorities = routerSearchparams && routerSearchparams.get("priorities") != null && routerSearchparams.get("priorities"); // updating default board view when we are in the issues page useEffect(() => { if (workspace_slug && project_slug && store?.project?.workspaceProjectSettings) { const workspacePRojectSettingViews = store?.project?.workspaceProjectSettings?.views; const userAccessViews: TIssueBoardKeys[] = []; Object.keys(workspacePRojectSettingViews).filter((_key) => { if (_key === "list" && workspacePRojectSettingViews.list === true) userAccessViews.push(_key); if (_key === "kanban" && workspacePRojectSettingViews.kanban === true) userAccessViews.push(_key); if (_key === "calendar" && workspacePRojectSettingViews.calendar === true) userAccessViews.push(_key); if (_key === "spreadsheet" && workspacePRojectSettingViews.spreadsheet === true) userAccessViews.push(_key); if (_key === "gantt" && workspacePRojectSettingViews.gantt === true) userAccessViews.push(_key); }); let url = `/${workspace_slug}/${project_slug}`; let _board = board; if (userAccessViews && userAccessViews.length > 0) { if (!board) { store.issue.setCurrentIssueBoardView(userAccessViews[0]); _board = userAccessViews[0]; } else { if (userAccessViews.includes(board)) { if (store.issue.currentIssueBoardView === null) store.issue.setCurrentIssueBoardView(board); else { if (board === store.issue.currentIssueBoardView) { _board = board; } else { _board = board; store.issue.setCurrentIssueBoardView(board); } } } else { store.issue.setCurrentIssueBoardView(userAccessViews[0]); _board = userAccessViews[0]; } } } _board = _board || "list"; url = `${url}?board=${_board}`; if (states) url = `${url}&states=${states}`; if (labels) url = `${url}&labels=${labels}`; if (priorities) url = `${url}&priorities=${priorities}`; url = decodeURIComponent(url); router.replace(url); } }, [ workspace_slug, project_slug, board, router, store?.issue, store?.project?.workspaceProjectSettings, states, labels, priorities, ]); useEffect(() => { if (!workspace_slug || !project_slug) return; const params = { state: states || null, labels: labels || null, priority: priorities || null, }; store?.project?.getProjectSettingsAsync(workspace_slug, project_slug); store?.issue?.getIssuesAsync(workspace_slug, project_slug, params); }, [workspace_slug, project_slug, store?.project, store?.issue, states, labels, priorities]); return (