diff --git a/apps/frontend/src/app/collaboration/[id]/page.tsx b/apps/frontend/src/app/collaboration/[id]/page.tsx index 739eac08a6..91fa315edb 100644 --- a/apps/frontend/src/app/collaboration/[id]/page.tsx +++ b/apps/frontend/src/app/collaboration/[id]/page.tsx @@ -209,15 +209,19 @@ export default function CollaborationPage(props: CollaborationProps) { }; const updateSubmissionResults = (data: SubmissionResults) => { - setSubmissionHiddenTestResultsAndStatus({ + const submissionHiddenTestResultsAndStatus: SubmissionHiddenTestResultsAndStatus = { hiddenTestResults: data.hiddenTestResults, status: data.status, - }); + } + setSubmissionHiddenTestResultsAndStatus(submissionHiddenTestResultsAndStatus); + localStorage.setItem("submissionHiddenTestResultsAndStatus", JSON.stringify(submissionHiddenTestResultsAndStatus)); setVisibleTestCases(data.visibleTestResults); + localStorage.setItem("visibleTestResults", JSON.stringify(data.visibleTestResults)); }; const updateExecutionResults = (data: ExecutionResults) => { setVisibleTestCases(data.visibleTestResults); + localStorage.setItem("visibleTestResults", JSON.stringify(data.visibleTestResults)); }; const handleRunTestCases = async () => { @@ -231,7 +235,7 @@ export default function CollaborationPage(props: CollaborationProps) { language: selectedLanguage, customTestCases: "", }); - setVisibleTestCases(data.visibleTestResults); + updateExecutionResults(data); infoMessage("Test cases executed. Review the results below."); sendExecutionResultsToMatchedUser(data); setIsLoadingTestCase(false); @@ -254,11 +258,11 @@ export default function CollaborationPage(props: CollaborationProps) { questionDifficulty: complexity ?? "", questionTopics: categories, }); - setVisibleTestCases(data.visibleTestResults); - setSubmissionHiddenTestResultsAndStatus({ - hiddenTestResults: data.hiddenTestResults, - status: data.status, + updateExecutionResults({ + visibleTestResults: data.visibleTestResults, + customTestResults: [], }); + updateSubmissionResults(data); sendSubmissionResultsToMatchedUser(data); successMessage("Code saved successfully!"); setIsLoadingSubmission(false); @@ -283,6 +287,11 @@ export default function CollaborationPage(props: CollaborationProps) { const currentUser: string = localStorage.getItem("user") ?? ""; const matchedTopics: string[] = localStorage.getItem("matchedTopics")?.split(",") ?? []; + const submissionHiddenTestResultsAndStatus: SubmissionHiddenTestResultsAndStatus | undefined = + localStorage.getItem("submissionHiddenTestResultsAndStatus") + ? JSON.parse(localStorage.getItem("submissionHiddenTestResultsAndStatus") as string) + : undefined; + const visibleTestCases: Test[] = JSON.parse(localStorage.getItem("visibleTestResults") ?? "[]") ?? []; // Set states from localstorage setCollaborationId(collabId); @@ -290,6 +299,8 @@ export default function CollaborationPage(props: CollaborationProps) { setCurrentUser(currentUser); setMatchedTopics(matchedTopics); setQuestionDocRefId(questionDocRefId); + setSubmissionHiddenTestResultsAndStatus(submissionHiddenTestResultsAndStatus); + setVisibleTestCases(visibleTestCases); GetSingleQuestion(questionDocRefId).then((data: Question) => { setQuestionTitle(`${data.id}. ${data.title}`); @@ -298,9 +309,11 @@ export default function CollaborationPage(props: CollaborationProps) { setDescription(data.description); }); - GetVisibleTests(questionDocRefId).then((data: Test[]) => { - setVisibleTestCases(data); - }); + if (visibleTestCases.length == 0) { + GetVisibleTests(questionDocRefId).then((data: Test[]) => { + setVisibleTestCases(data); + }); + } // Start stopwatch startStopwatch(); @@ -384,6 +397,8 @@ export default function CollaborationPage(props: CollaborationProps) { localStorage.removeItem("collabId"); localStorage.removeItem("questionDocRefId"); localStorage.removeItem("matchedTopics"); + localStorage.removeItem("submissionHiddenTestResultsAndStatus"); + localStorage.removeItem("visibleTestResults"); }; return (