From 7278b5727ff341a407706f0c143d3ecbce06de9d Mon Sep 17 00:00:00 2001 From: Aaryan Khandelwal <65252264+aaryan610@users.noreply.github.com> Date: Tue, 31 Jan 2023 19:23:51 +0530 Subject: [PATCH] refactor: issue details page (#211) --- .../projects/[projectId]/issues/[issueId].tsx | 80 +++++-------------- apps/app/types/issues.d.ts | 12 ++- 2 files changed, 30 insertions(+), 62 deletions(-) diff --git a/apps/app/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx b/apps/app/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx index a97c94ca7..dd291c8df 100644 --- a/apps/app/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx +++ b/apps/app/pages/[workspaceSlug]/projects/[projectId]/issues/[issueId].tsx @@ -18,27 +18,17 @@ import AddAsSubIssue from "components/project/issues/issue-detail/add-as-sub-iss import IssueDetailSidebar from "components/project/issues/issue-detail/issue-detail-sidebar"; import AddIssueComment from "components/project/issues/issue-detail/comment/issue-comment-section"; import IssueActivitySection from "components/project/issues/issue-detail/activity"; -import { - IssueDescriptionForm, - IssueDescriptionFormValues, - SubIssueList, - CreateUpdateIssueModal, -} from "components/issues"; +import { IssueDescriptionForm, SubIssueList, CreateUpdateIssueModal } from "components/issues"; // ui -import { Loader, HeaderButton, CustomMenu } from "components/ui"; +import { Loader, CustomMenu } from "components/ui"; import { Breadcrumbs } from "components/breadcrumbs"; // icons -import { ChevronLeftIcon, ChevronRightIcon, PlusIcon } from "@heroicons/react/24/outline"; +import { PlusIcon } from "@heroicons/react/24/outline"; // types import { IIssue } from "types"; import type { NextPage, NextPageContext } from "next"; // fetch-keys -import { - PROJECT_ISSUES_LIST, - PROJECT_ISSUES_ACTIVITY, - ISSUE_DETAILS, - SUB_ISSUES, -} from "constants/fetch-keys"; +import { PROJECT_ISSUES_ACTIVITY, ISSUE_DETAILS, SUB_ISSUES } from "constants/fetch-keys"; const defaultValues = { name: "", @@ -81,15 +71,6 @@ const IssueDetailsPage: NextPage = () => { : null ); - const { data: issues } = useSWR( - workspaceSlug && projectId - ? PROJECT_ISSUES_LIST(workspaceSlug as string, projectId as string) - : null, - workspaceSlug && projectId - ? () => issuesService.getIssues(workspaceSlug as string, projectId as string) - : null - ); - const { data: issueActivities, mutate: mutateIssueActivities } = useSWR( workspaceSlug && projectId && issueId ? PROJECT_ISSUES_ACTIVITY(issueId as string) : null, workspaceSlug && projectId && issueId @@ -102,17 +83,22 @@ const IssueDetailsPage: NextPage = () => { : null ); + const { data: siblingIssues } = useSWR( + workspaceSlug && projectId && issueDetails?.parent ? SUB_ISSUES(issueDetails.parent) : null, + workspaceSlug && projectId && issueDetails?.parent + ? () => + issuesService.subIssues( + workspaceSlug as string, + projectId as string, + issueDetails.parent ?? "" + ) + : null + ); + const { reset, control, watch } = useForm({ defaultValues, }); - const prevIssue = issues?.results[issues?.results.findIndex((issue) => issue.id === issueId) - 1]; - const nextIssue = issues?.results[issues?.results.findIndex((issue) => issue.id === issueId) + 1]; - - const siblingIssues = - issueDetails && - issues?.results.filter((i) => i.parent === issueDetails.parent && i.id !== issueId); - useEffect(() => { if (issueDetails) { mutateIssueActivities(); @@ -191,32 +177,6 @@ const IssueDetailsPage: NextPage = () => { /> } - right={ -
- { - if (!prevIssue) return; - router.push(`/${workspaceSlug}/projects/${prevIssue.project}/issues/${prevIssue.id}`); - }} - /> - { - if (!nextIssue) return; - router.push( - `/${workspaceSlug}/projects/${nextIssue.project}/issues/${nextIssue?.id}` - ); - }} - position="reverse" - /> -
- } > {isOpen && ( { /> {issueDetails.project_detail.identifier}- - {issues?.results.find((i) => i.id === issueDetails.parent)?.sequence_id} + {issueDetails.parent_detail?.sequence_id} - {issues?.results - .find((i) => i.id === issueDetails.parent) - ?.name.substring(0, 50)} + {issueDetails.parent_detail?.name.substring(0, 50)} {siblingIssues && siblingIssues.length > 0 ? ( - siblingIssues.map((issue) => ( + siblingIssues.map((issue: IIssue) => (