From bf8a4a6607ba27be7066677c0739da713c9d0b05 Mon Sep 17 00:00:00 2001 From: KIM HYOJUNG Date: Sat, 23 Nov 2024 10:40:57 +0900 Subject: [PATCH] fix(fe): add submission detail modal on participant (#2228) --- .../_components/SubmissionTable.tsx | 2 +- .../contest/[contestId]/(overall)/layout.tsx | 6 +-- .../_components/ContestOverallTabs.tsx | 13 +++++-- .../_components/SubmissionDetailAdmin.tsx | 0 .../[userId]/_components/SubmissionTable.tsx | 38 ++++++++++++++----- 5 files changed, 42 insertions(+), 17 deletions(-) rename apps/frontend/app/admin/contest/[contestId]/{(overall)/@tabs/submission => }/_components/SubmissionDetailAdmin.tsx (100%) diff --git a/apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionTable.tsx b/apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionTable.tsx index a76aabfc6f..5187ff9a3b 100644 --- a/apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionTable.tsx +++ b/apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionTable.tsx @@ -6,12 +6,12 @@ import DataTablePagination from '@/app/admin/_components/table/DataTablePaginati import DataTableProblemFilter from '@/app/admin/_components/table/DataTableProblemFilter' import DataTableRoot from '@/app/admin/_components/table/DataTableRoot' import DataTableSearchBar from '@/app/admin/_components/table/DataTableSearchBar' +import SubmissionDetailAdmin from '@/app/admin/contest/[contestId]/_components/SubmissionDetailAdmin' import { Dialog, DialogContent } from '@/components/shadcn/dialog' import { GET_CONTEST_SUBMISSIONS } from '@/graphql/submission/queries' import { useSuspenseQuery } from '@apollo/client' import { useState } from 'react' import { columns } from './Columns' -import SubmissionDetailAdmin from './SubmissionDetailAdmin' export function SubmissionTable({ contestId }: { contestId: number }) { const { data } = useSuspenseQuery(GET_CONTEST_SUBMISSIONS, { diff --git a/apps/frontend/app/admin/contest/[contestId]/(overall)/layout.tsx b/apps/frontend/app/admin/contest/[contestId]/(overall)/layout.tsx index 7d3e281a82..c6c425af70 100644 --- a/apps/frontend/app/admin/contest/[contestId]/(overall)/layout.tsx +++ b/apps/frontend/app/admin/contest/[contestId]/(overall)/layout.tsx @@ -13,12 +13,10 @@ import ContestOverallTabs from '../_components/ContestOverallTabs' export default function Layout({ params, - tabs, - userId + tabs }: { params: { contestId: string } tabs: React.ReactNode - userId: number }) { const { contestId } = params @@ -60,7 +58,7 @@ export default function Layout({ content={contestData?.description} classname="prose mb-4 w-full max-w-full border-y-2 border-y-gray-300 p-5 py-12" /> - + {tabs} ) diff --git a/apps/frontend/app/admin/contest/[contestId]/_components/ContestOverallTabs.tsx b/apps/frontend/app/admin/contest/[contestId]/_components/ContestOverallTabs.tsx index 484e697d19..b705044b44 100644 --- a/apps/frontend/app/admin/contest/[contestId]/_components/ContestOverallTabs.tsx +++ b/apps/frontend/app/admin/contest/[contestId]/_components/ContestOverallTabs.tsx @@ -30,15 +30,22 @@ interface SubmissionSummary { } export default function ContestOverallTabs({ - contestId, - userId + contestId }: { contestId: string - userId: number }) { const id = parseInt(contestId, 10) const pathname = usePathname() + const { data: userData } = useQuery<{ + getUserIdByContest: { userId: number } + }>(GET_CONTEST_SCORE_SUMMARIES, { + variables: { contestId: id }, + skip: !contestId + }) + + const userId = userData?.getUserIdByContest?.userId + const { data: scoreData } = useQuery<{ getContestScoreSummaries: ScoreSummary[] }>(GET_CONTEST_SCORE_SUMMARIES, { diff --git a/apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionDetailAdmin.tsx b/apps/frontend/app/admin/contest/[contestId]/_components/SubmissionDetailAdmin.tsx similarity index 100% rename from apps/frontend/app/admin/contest/[contestId]/(overall)/@tabs/submission/_components/SubmissionDetailAdmin.tsx rename to apps/frontend/app/admin/contest/[contestId]/_components/SubmissionDetailAdmin.tsx diff --git a/apps/frontend/app/admin/contest/[contestId]/participant/[userId]/_components/SubmissionTable.tsx b/apps/frontend/app/admin/contest/[contestId]/participant/[userId]/_components/SubmissionTable.tsx index 8414716c6e..2f9aa00d82 100644 --- a/apps/frontend/app/admin/contest/[contestId]/participant/[userId]/_components/SubmissionTable.tsx +++ b/apps/frontend/app/admin/contest/[contestId]/participant/[userId]/_components/SubmissionTable.tsx @@ -5,8 +5,11 @@ import DataTableFallback from '@/app/admin/_components/table/DataTableFallback' import DataTablePagination from '@/app/admin/_components/table/DataTablePagination' import DataTableProblemFilter from '@/app/admin/_components/table/DataTableProblemFilter' import DataTableRoot from '@/app/admin/_components/table/DataTableRoot' +import SubmissionDetailAdmin from '@/app/admin/contest/[contestId]/_components/SubmissionDetailAdmin' +import { Dialog, DialogContent } from '@/components/shadcn/dialog' import { GET_CONTEST_SUBMISSION_SUMMARIES_OF_USER } from '@/graphql/contest/queries' import { useSuspenseQuery } from '@apollo/client' +import { useState } from 'react' import { submissionColumns } from './SubmissionColumns' export function SubmissionTable({ @@ -22,20 +25,37 @@ export function SubmissionTable({ variables: { contestId, userId, take: 1000 } } ) + const [isSubmissionDialogOpen, setIsSubmissionDialogOpen] = useState(false) + const [submissionId, setSubmissionId] = useState(0) const submissionsData = submissions.data.getContestSubmissionSummaryByUserId.submissions return ( - - - - - + <> + + + { + setSubmissionId(row.original.id) + setIsSubmissionDialogOpen(true) + }} + /> + + + + + + + + ) }