From 38421e81061be3b753b3e1348d6ad132aad89a6d Mon Sep 17 00:00:00 2001 From: Aaryan Khandelwal <65252264+aaryan610@users.noreply.github.com> Date: Mon, 23 Oct 2023 15:06:28 +0530 Subject: [PATCH] refactor: layout roots (#2517) --- .../headers/project-view-issues.tsx | 101 +++++++++++++----- web/components/headers/project-views.tsx | 40 ++++--- .../issue-layouts/roots/cycle-layout-root.tsx | 77 ++++++------- .../roots/global-view-layout-root.tsx | 7 +- .../roots/module-layout-root.tsx | 27 +++-- .../roots/project-layout-root.tsx | 23 ++-- .../roots/project-view-layout-root.tsx | 37 +++---- web/layouts/auth-layout/project-wrapper.tsx | 1 + .../projects/[projectId]/cycles/[cycleId].tsx | 20 +--- .../projects/[projectId]/issues/index.tsx | 33 ++---- .../projects/[projectId]/views/[viewId].tsx | 90 +++------------- .../projects/[projectId]/views/index.tsx | 18 +--- 12 files changed, 205 insertions(+), 269 deletions(-) diff --git a/web/components/headers/project-view-issues.tsx b/web/components/headers/project-view-issues.tsx index 71026ce74..31326e826 100644 --- a/web/components/headers/project-view-issues.tsx +++ b/web/components/headers/project-view-issues.tsx @@ -1,11 +1,15 @@ import { useCallback } from "react"; +import Link from "next/link"; import { useRouter } from "next/router"; import { observer } from "mobx-react-lite"; - // mobx store import { useMobxStore } from "lib/mobx/store-provider"; // components import { DisplayFiltersSelection, FiltersDropdown, FilterSelection, LayoutSelection } from "components/issues"; +// ui +import { BreadcrumbItem, Breadcrumbs, CustomMenu, PhotoFilterIcon } from "@plane/ui"; +// helpers +import { truncateText } from "helpers/string.helper"; // types import { IIssueDisplayFilterOptions, IIssueDisplayProperties, IIssueFilterOptions, TIssueLayouts } from "types"; // constants @@ -19,6 +23,7 @@ export const ProjectViewIssuesHeader: React.FC = observer(() => { issueFilter: issueFilterStore, projectViewFilters: projectViewFiltersStore, project: projectStore, + projectViews: projectViewsStore, } = useMobxStore(); const storedFilters = viewId ? projectViewFiltersStore.storedFilters[viewId.toString()] : undefined; @@ -82,32 +87,78 @@ export const ProjectViewIssuesHeader: React.FC = observer(() => { [issueFilterStore, projectId, workspaceSlug] ); + const projectDetails = + workspaceSlug && projectId + ? projectStore.getProjectById(workspaceSlug.toString(), projectId.toString()) + : undefined; + + const viewsList = projectId ? projectViewsStore.viewsList[projectId.toString()] : undefined; + const viewDetails = viewId ? projectViewsStore.viewDetails[viewId.toString()] : undefined; + return ( -
- handleLayoutChange(layout)} - selectedLayout={activeLayout} - /> - - m.member)} - states={projectStore.states?.[projectId?.toString() ?? ""] ?? undefined} +
+
+ router.back()}> + + +

{`${projectDetails?.name ?? "Project"} Views`}

+
+ + } + /> +
+ + + {viewDetails?.name && truncateText(viewDetails.name, 40)} + + } + className="ml-1.5" + placement="bottom-start" + > + {viewsList?.map((view) => ( + router.push(`/${workspaceSlug}/projects/${projectId}/views/${view.id}`)} + > + {truncateText(view.name, 40)} + + ))} + +
+
+ handleLayoutChange(layout)} + selectedLayout={activeLayout} /> - - - - + + m.member)} + states={projectStore.states?.[projectId?.toString() ?? ""] ?? undefined} + /> + + + + +
); }); diff --git a/web/components/headers/project-views.tsx b/web/components/headers/project-views.tsx index e72b97c47..41d22d1b2 100644 --- a/web/components/headers/project-views.tsx +++ b/web/components/headers/project-views.tsx @@ -1,7 +1,10 @@ -import { FC, useState } from "react"; +import { useState } from "react"; import { useRouter } from "next/router"; -// icons -import { ArrowLeft, Link, Plus } from "lucide-react"; +import Link from "next/link"; +import { observer } from "mobx-react-lite"; +import { ArrowLeft, Plus } from "lucide-react"; +// mobx store +import { useMobxStore } from "lib/mobx/store-provider"; // components import { CreateUpdateProjectViewModal } from "components/views"; // components @@ -11,18 +14,20 @@ import { PrimaryButton } from "components/ui"; // helpers import { truncateText } from "helpers/string.helper"; -interface IProjectViewsHeader { - title: string | undefined; -} - -export const ProjectViewsHeader: FC = (props) => { - const { title } = props; +export const ProjectViewsHeader: React.FC = observer(() => { // router const router = useRouter(); const { workspaceSlug, projectId } = router.query; // states const [createViewModal, setCreateViewModal] = useState(false); + const { project: projectStore } = useMobxStore(); + + const projectDetails = + workspaceSlug && projectId + ? projectStore.getProjectById(workspaceSlug.toString(), projectId.toString()) + : undefined; + return ( <> {workspaceSlug && projectId && ( @@ -43,7 +48,7 @@ export const ProjectViewsHeader: FC = (props) => { className="grid h-8 w-8 place-items-center rounded border border-custom-border-200" onClick={() => router.back()} > - +
@@ -57,20 +62,13 @@ export const ProjectViewsHeader: FC = (props) => { } /> - +
-
+
- { - const e = new KeyboardEvent("keydown", { key: "v" }); - document.dispatchEvent(e); - }} - > + setCreateViewModal(true)}> Create View @@ -79,4 +77,4 @@ export const ProjectViewsHeader: FC = (props) => {
); -}; +}); diff --git a/web/components/issues/issue-layouts/roots/cycle-layout-root.tsx b/web/components/issues/issue-layouts/roots/cycle-layout-root.tsx index 2be3abc56..20cd972f7 100644 --- a/web/components/issues/issue-layouts/roots/cycle-layout-root.tsx +++ b/web/components/issues/issue-layouts/roots/cycle-layout-root.tsx @@ -1,10 +1,9 @@ -import React from "react"; -// next imports +import React, { useState } from "react"; import { useRouter } from "next/router"; -// swr -import useSWR from "swr"; -// mobx react lite import { observer } from "mobx-react-lite"; +import useSWR from "swr"; +// mobx store +import { useMobxStore } from "lib/mobx/store-provider"; // components import { CycleAppliedFiltersRoot, @@ -14,59 +13,63 @@ import { CycleListLayout, CycleSpreadsheetLayout, } from "components/issues"; -// mobx store -import { useMobxStore } from "lib/mobx/store-provider"; +import { TransferIssues, TransferIssuesModal } from "components/cycles"; +// helpers +import { getDateRangeStatus } from "helpers/date-time.helper"; export const CycleLayoutRoot: React.FC = observer(() => { + const [transferIssuesModal, setTransferIssuesModal] = useState(false); + const router = useRouter(); - const { workspaceSlug, projectId, cycleId } = router.query as { - workspaceSlug: string; - projectId: string; - cycleId: string; - }; + const { workspaceSlug, projectId, cycleId } = router.query; const { - project: projectStore, issueFilter: issueFilterStore, + cycle: cycleStore, cycleIssue: cycleIssueStore, cycleIssueFilter: cycleIssueFilterStore, } = useMobxStore(); - useSWR(workspaceSlug && projectId && cycleId ? `CYCLE_ISSUES` : null, async () => { + useSWR(workspaceSlug && projectId && cycleId ? `CYCLE_FILTERS_AND_ISSUES_${cycleId.toString()}` : null, async () => { if (workspaceSlug && projectId && cycleId) { // fetching the project display filters and display properties - await issueFilterStore.fetchUserProjectFilters(workspaceSlug, projectId); + await issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()); // fetching the cycle filters - await cycleIssueFilterStore.fetchCycleFilters(workspaceSlug, projectId, cycleId); - - // fetching the project state, labels and members - await projectStore.fetchProjectStates(workspaceSlug, projectId); - await projectStore.fetchProjectLabels(workspaceSlug, projectId); - await projectStore.fetchProjectMembers(workspaceSlug, projectId); + await cycleIssueFilterStore.fetchCycleFilters(workspaceSlug.toString(), projectId.toString(), cycleId.toString()); // fetching the cycle issues - await cycleIssueStore.fetchIssues(workspaceSlug, projectId, cycleId); + await cycleIssueStore.fetchIssues(workspaceSlug.toString(), projectId.toString(), cycleId.toString()); } }); const activeLayout = issueFilterStore.userDisplayFilters.layout; + const cycleDetails = cycleId ? cycleStore.cycle_details[cycleId.toString()] : undefined; + const cycleStatus = + cycleDetails?.start_date && cycleDetails?.end_date + ? getDateRangeStatus(cycleDetails?.start_date, cycleDetails?.end_date) + : "draft"; + return ( -
- -
- {activeLayout === "list" ? ( - - ) : activeLayout === "kanban" ? ( - - ) : activeLayout === "calendar" ? ( - - ) : activeLayout === "gantt_chart" ? ( - - ) : activeLayout === "spreadsheet" ? ( - - ) : null} + <> + setTransferIssuesModal(false)} isOpen={transferIssuesModal} /> +
+ {cycleStatus === "completed" && setTransferIssuesModal(true)} />} + +
+ {activeLayout === "list" ? ( + + ) : activeLayout === "kanban" ? ( + + ) : activeLayout === "calendar" ? ( + + ) : activeLayout === "gantt_chart" ? ( + + ) : activeLayout === "spreadsheet" ? ( + + ) : null} +
-
+ ); }); diff --git a/web/components/issues/issue-layouts/roots/global-view-layout-root.tsx b/web/components/issues/issue-layouts/roots/global-view-layout-root.tsx index 4886339aa..c88c821f4 100644 --- a/web/components/issues/issue-layouts/roots/global-view-layout-root.tsx +++ b/web/components/issues/issue-layouts/roots/global-view-layout-root.tsx @@ -2,15 +2,12 @@ import React, { useCallback } from "react"; import { useRouter } from "next/router"; import { observer } from "mobx-react-lite"; import useSWR from "swr"; - // mobx store import { useMobxStore } from "lib/mobx/store-provider"; // components import { GlobalViewsAppliedFiltersRoot, SpreadsheetView } from "components/issues"; // types import { IIssue, IIssueDisplayFilterOptions, TStaticViewTypes } from "types"; -// fetch-keys -import { GLOBAL_VIEW_ISSUES } from "constants/fetch-keys"; type Props = { type?: TStaticViewTypes; @@ -35,7 +32,7 @@ export const GlobalViewLayoutRoot: React.FC = observer((props) => { const storedFilters = globalViewId ? globalViewFiltersStore.storedFilters[globalViewId.toString()] : undefined; useSWR( - workspaceSlug && globalViewId && viewDetails ? GLOBAL_VIEW_ISSUES(globalViewId.toString()) : null, + workspaceSlug && globalViewId && viewDetails ? `GLOBAL_VIEW_ISSUES_${globalViewId.toString()}` : null, workspaceSlug && globalViewId && viewDetails ? () => { globalViewIssuesStore.fetchViewIssues(workspaceSlug.toString(), globalViewId.toString(), storedFilters ?? {}); @@ -44,7 +41,7 @@ export const GlobalViewLayoutRoot: React.FC = observer((props) => { ); useSWR( - workspaceSlug && type ? GLOBAL_VIEW_ISSUES(type) : null, + workspaceSlug && type ? `GLOBAL_VIEW_ISSUES_${type.toString()}` : null, workspaceSlug && type ? () => { globalViewIssuesStore.fetchStaticIssues(workspaceSlug.toString(), type); diff --git a/web/components/issues/issue-layouts/roots/module-layout-root.tsx b/web/components/issues/issue-layouts/roots/module-layout-root.tsx index 74410a952..f01fd1fc2 100644 --- a/web/components/issues/issue-layouts/roots/module-layout-root.tsx +++ b/web/components/issues/issue-layouts/roots/module-layout-root.tsx @@ -24,28 +24,25 @@ export const ModuleLayoutRoot: React.FC = observer(() => { }; const { - project: projectStore, issueFilter: issueFilterStore, moduleIssue: moduleIssueStore, moduleFilter: moduleIssueFilterStore, } = useMobxStore(); - useSWR(workspaceSlug && projectId && moduleId ? `MODULE_INFORMATION_${moduleId.toString()}` : null, async () => { - if (workspaceSlug && projectId && moduleId) { - // fetching the project display filters and display properties - await issueFilterStore.fetchUserProjectFilters(workspaceSlug, projectId); - // fetching the module filters - await moduleIssueFilterStore.fetchModuleFilters(workspaceSlug, projectId, moduleId); + useSWR( + workspaceSlug && projectId && moduleId ? `MODULE_FILTERS_AND_ISSUES_${moduleId.toString()}` : null, + async () => { + if (workspaceSlug && projectId && moduleId) { + // fetching the project display filters and display properties + await issueFilterStore.fetchUserProjectFilters(workspaceSlug, projectId); + // fetching the module filters + await moduleIssueFilterStore.fetchModuleFilters(workspaceSlug, projectId, moduleId); - // fetching the project state, labels and members - await projectStore.fetchProjectStates(workspaceSlug, projectId); - await projectStore.fetchProjectLabels(workspaceSlug, projectId); - await projectStore.fetchProjectMembers(workspaceSlug, projectId); - - // fetching the module issues - await moduleIssueStore.fetchIssues(workspaceSlug, projectId, moduleId); + // fetching the module issues + await moduleIssueStore.fetchIssues(workspaceSlug, projectId, moduleId); + } } - }); + ); const activeLayout = issueFilterStore.userDisplayFilters.layout; diff --git a/web/components/issues/issue-layouts/roots/project-layout-root.tsx b/web/components/issues/issue-layouts/roots/project-layout-root.tsx index 288bf7289..f76d2a3e3 100644 --- a/web/components/issues/issue-layouts/roots/project-layout-root.tsx +++ b/web/components/issues/issue-layouts/roots/project-layout-root.tsx @@ -18,24 +18,15 @@ export const ProjectLayoutRoot: React.FC = observer(() => { const router = useRouter(); const { workspaceSlug, projectId } = router.query; - const { issue: issueStore, project: projectStore, issueFilter: issueFilterStore } = useMobxStore(); + const { issue: issueStore, issueFilter: issueFilterStore } = useMobxStore(); - useSWR( - workspaceSlug && projectId ? `REVALIDATE_PROJECT_ISSUES_${projectId.toString()}` : null, - async () => { - if (workspaceSlug && projectId) { - await issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()); + useSWR(workspaceSlug && projectId ? `PROJECT_FILTERS_AND_ISSUES_${projectId.toString()}` : null, async () => { + if (workspaceSlug && projectId) { + await issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectStates(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectLabels(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectMembers(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectEstimates(workspaceSlug.toString(), projectId.toString()); - - await issueStore.fetchIssues(workspaceSlug.toString(), projectId.toString()); - } - }, - { revalidateOnFocus: false } - ); + await issueStore.fetchIssues(workspaceSlug.toString(), projectId.toString()); + } + }); const activeLayout = issueFilterStore.userDisplayFilters.layout; diff --git a/web/components/issues/issue-layouts/roots/project-view-layout-root.tsx b/web/components/issues/issue-layouts/roots/project-view-layout-root.tsx index 8ad7428a2..7d5dad9e2 100644 --- a/web/components/issues/issue-layouts/roots/project-view-layout-root.tsx +++ b/web/components/issues/issue-layouts/roots/project-view-layout-root.tsx @@ -20,34 +20,31 @@ export const ProjectViewLayoutRoot: React.FC = observer(() => { const { workspaceSlug, projectId, viewId } = router.query; const { - project: projectStore, issueFilter: issueFilterStore, projectViews: projectViewsStore, projectViewIssues: projectViewIssuesStore, projectViewFilters: projectViewFiltersStore, } = useMobxStore(); - useSWR(workspaceSlug && projectId && viewId ? `PROJECT_VIEW_INFORMATION_${viewId.toString()}` : null, async () => { - if (workspaceSlug && projectId && viewId) { - // fetching the project display filters and display properties - await issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()); + useSWR( + workspaceSlug && projectId && viewId ? `PROJECT_VIEW_FILTERS_AND_ISSUES_${viewId.toString()}` : null, + async () => { + if (workspaceSlug && projectId && viewId) { + // fetching the project display filters and display properties + await issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()); - // fetching the project state, labels and members - await projectStore.fetchProjectStates(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectLabels(workspaceSlug.toString(), projectId.toString()); - await projectStore.fetchProjectMembers(workspaceSlug.toString(), projectId.toString()); - - // fetching the view details - await projectViewsStore.fetchViewDetails(workspaceSlug.toString(), projectId.toString(), viewId.toString()); - // fetching the view issues - await projectViewIssuesStore.fetchViewIssues( - workspaceSlug.toString(), - projectId.toString(), - viewId.toString(), - projectViewFiltersStore.storedFilters[viewId.toString()] ?? {} - ); + // fetching the view details + await projectViewsStore.fetchViewDetails(workspaceSlug.toString(), projectId.toString(), viewId.toString()); + // fetching the view issues + await projectViewIssuesStore.fetchViewIssues( + workspaceSlug.toString(), + projectId.toString(), + viewId.toString(), + projectViewFiltersStore.storedFilters[viewId.toString()] ?? {} + ); + } } - }); + ); const activeLayout = issueFilterStore.userDisplayFilters.layout; diff --git a/web/layouts/auth-layout/project-wrapper.tsx b/web/layouts/auth-layout/project-wrapper.tsx index e5a9bd4cd..c065c1412 100644 --- a/web/layouts/auth-layout/project-wrapper.tsx +++ b/web/layouts/auth-layout/project-wrapper.tsx @@ -65,6 +65,7 @@ export const ProjectAuthWrapper: FC = observer((props) => { ? () => projectStore.fetchProjectStates(workspaceSlug.toString(), projectId.toString()) : null ); + // TODO: fetch project estimates // fetching project cycles useSWR( workspaceSlug && projectId ? `PROJECT_ALL_CYCLES_${workspaceSlug}_${projectId}` : null, diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx index a558f8a37..6f8384297 100644 --- a/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx +++ b/web/pages/[workspaceSlug]/projects/[projectId]/cycles/[cycleId].tsx @@ -10,18 +10,15 @@ import { AppLayout } from "layouts/app-layout"; // components import { CycleIssuesHeader } from "components/headers"; import { ExistingIssuesListModal } from "components/core"; -import { CycleDetailsSidebar, TransferIssues, TransferIssuesModal } from "components/cycles"; +import { CycleDetailsSidebar } from "components/cycles"; import { CycleLayoutRoot } from "components/issues/issue-layouts"; // ui import { EmptyState } from "components/common"; // assets import emptyCycle from "public/empty-state/cycle.svg"; -// helpers -import { getDateRangeStatus } from "helpers/date-time.helper"; const SingleCycle: React.FC = () => { const [cycleIssuesListModal, setCycleIssuesListModal] = useState(false); - const [transferIssuesModal, setTransferIssuesModal] = useState(false); const router = useRouter(); const { workspaceSlug, projectId, cycleId } = router.query; @@ -31,18 +28,13 @@ const SingleCycle: React.FC = () => { const { storedValue } = useLocalStorage("cycle_sidebar_collapsed", "false"); const isSidebarCollapsed = storedValue ? (storedValue === "true" ? true : false) : false; - const { data: cycleDetails, error } = useSWR( + const { error } = useSWR( workspaceSlug && projectId && cycleId ? `CURRENT_CYCLE_DETAILS_${cycleId.toString()}` : null, workspaceSlug && projectId && cycleId ? () => cycleStore.fetchCycleWithId(workspaceSlug.toString(), projectId.toString(), cycleId.toString()) : null ); - const cycleStatus = - cycleDetails?.start_date && cycleDetails?.end_date - ? getDateRangeStatus(cycleDetails?.start_date, cycleDetails?.end_date) - : "draft"; - // TODO: add this function to bulk add issues to cycle // const handleAddIssuesToCycle = async (data: ISearchIssueResponse[]) => { // if (!workspaceSlug || !projectId) return; @@ -83,13 +75,9 @@ const SingleCycle: React.FC = () => { /> ) : ( <> - setTransferIssuesModal(false)} isOpen={transferIssuesModal} />
-
- {cycleStatus === "completed" && setTransferIssuesModal(true)} />} -
- -
+
+
{cycleId && }
diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/issues/index.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/issues/index.tsx index 80e85a74e..0e1f673ad 100644 --- a/web/pages/[workspaceSlug]/projects/[projectId]/issues/index.tsx +++ b/web/pages/[workspaceSlug]/projects/[projectId]/issues/index.tsx @@ -1,7 +1,3 @@ -import { useRouter } from "next/router"; -import useSWR from "swr"; -// mobx -import { useMobxStore } from "lib/mobx/store-provider"; // components import { ProjectLayoutRoot } from "components/issues"; import { ProjectIssuesHeader } from "components/headers"; @@ -10,27 +6,12 @@ import type { NextPage } from "next"; // layouts import { AppLayout } from "layouts/app-layout"; -const ProjectIssues: NextPage = () => { - const router = useRouter(); - const { workspaceSlug, projectId } = router.query; - - const { issueFilter: issueFilterStore } = useMobxStore(); - - // TODO: update the fetch keys - useSWR( - workspaceSlug && projectId ? "REVALIDATE_USER_PROJECT_FILTERS" : null, - workspaceSlug && projectId - ? () => issueFilterStore.fetchUserProjectFilters(workspaceSlug.toString(), projectId.toString()) - : null - ); - - return ( - } withProjectWrapper> -
- -
-
- ); -}; +const ProjectIssues: NextPage = () => ( + } withProjectWrapper> +
+ +
+
+); export default ProjectIssues; diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx b/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx index 87b230e35..e5b2d6045 100644 --- a/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx +++ b/web/pages/[workspaceSlug]/projects/[projectId]/views/[viewId].tsx @@ -1,90 +1,34 @@ import { useRouter } from "next/router"; -import Link from "next/link"; - import useSWR from "swr"; - -// services -import { ProjectService } from "services/project"; -import { ViewService } from "services/view.service"; +// mobx store +import { useMobxStore } from "lib/mobx/store-provider"; // layouts -import { ProjectAuthorizationWrapper } from "layouts/auth-layout-legacy"; +import { AppLayout } from "layouts/app-layout"; // components import { ProjectViewLayoutRoot } from "components/issues"; -// ui -import { BreadcrumbItem, Breadcrumbs, CustomMenu, PhotoFilterIcon } from "@plane/ui"; -import { EmptyState } from "components/common"; -// icons -// images -import emptyView from "public/empty-state/view.svg"; -// helpers -import { truncateText } from "helpers/string.helper"; -// fetch-keys -import { PROJECT_DETAILS, VIEWS_LIST, VIEW_DETAILS } from "constants/fetch-keys"; import { ProjectViewIssuesHeader } from "components/headers"; +// ui +import { EmptyState } from "components/common"; +// assets +import emptyView from "public/empty-state/view.svg"; +// types +import { NextPage } from "next"; -// services -const projectService = new ProjectService(); -const viewService = new ViewService(); - -const SingleView: React.FC = () => { +const ProjectViewIssues: NextPage = () => { const router = useRouter(); const { workspaceSlug, projectId, viewId } = router.query; - const { data: activeProject } = useSWR( - workspaceSlug && projectId ? PROJECT_DETAILS(projectId as string) : null, - workspaceSlug && projectId ? () => projectService.getProject(workspaceSlug as string, projectId as string) : null - ); + const { projectViews: projectViewsStore } = useMobxStore(); - const { data: views } = useSWR( - workspaceSlug && projectId ? VIEWS_LIST(projectId as string) : null, - workspaceSlug && projectId ? () => viewService.getViews(workspaceSlug as string, projectId as string) : null - ); - - const { data: viewDetails, error } = useSWR( - workspaceSlug && projectId && viewId ? VIEW_DETAILS(viewId as string) : null, + const { error } = useSWR( + workspaceSlug && projectId && viewId ? `VIEW_DETAILS_${viewId.toString()}` : null, workspaceSlug && projectId && viewId - ? () => viewService.getViewDetails(workspaceSlug as string, projectId as string, viewId as string) + ? () => projectViewsStore.fetchViewDetails(workspaceSlug.toString(), projectId.toString(), viewId.toString()) : null ); return ( - router.back()}> - - -

{`${activeProject?.name ?? "Project"} Views`}

-
- - } - /> - - } - left={ - - - {viewDetails?.name && truncateText(viewDetails.name, 40)} - - } - className="ml-1.5" - width="auto" - > - {views?.map((view) => ( - router.push(`/${workspaceSlug}/projects/${projectId}/views/${view.id}`)} - > - {truncateText(view.name, 40)} - - ))} - - } - right={} - > + } withProjectWrapper> {error ? ( { ) : ( )} -
+ ); }; -export default SingleView; +export default ProjectViewIssues; diff --git a/web/pages/[workspaceSlug]/projects/[projectId]/views/index.tsx b/web/pages/[workspaceSlug]/projects/[projectId]/views/index.tsx index aad472e75..072dcebb9 100644 --- a/web/pages/[workspaceSlug]/projects/[projectId]/views/index.tsx +++ b/web/pages/[workspaceSlug]/projects/[projectId]/views/index.tsx @@ -2,7 +2,7 @@ import React from "react"; import type { NextPage } from "next"; import { useRouter } from "next/router"; import useSWR from "swr"; -// hooks +// mobx store import { useMobxStore } from "lib/mobx/store-provider"; // components import { ProjectViewsHeader } from "components/headers"; @@ -14,14 +14,7 @@ const ProjectViews: NextPage = () => { const router = useRouter(); const { workspaceSlug, projectId } = router.query; - const { project: projectStore, projectViews: projectViewsStore } = useMobxStore(); - - useSWR( - workspaceSlug && projectId ? `PROJECT_DETAILS_${projectId.toString()}` : null, - workspaceSlug && projectId - ? () => projectStore.fetchProjectDetails(workspaceSlug.toString(), projectId.toString()) - : null - ); + const { projectViews: projectViewsStore } = useMobxStore(); useSWR( workspaceSlug && projectId ? `PROJECT_VIEWS_LIST_${workspaceSlug.toString()}_${projectId.toString()}` : null, @@ -30,13 +23,8 @@ const ProjectViews: NextPage = () => { : null ); - const projectDetails = - workspaceSlug && projectId - ? projectStore.getProjectById(workspaceSlug.toString(), projectId.toString()) - : undefined; - return ( - }> + }> );