From b309b44c8bd2c532e439a910f06b5e983f00e0c7 Mon Sep 17 00:00:00 2001 From: Meefish <117977321+Meefish@users.noreply.github.com> Date: Thu, 12 Dec 2024 23:14:11 +0100 Subject: [PATCH] Fixes #55 and solves a bug where radio button was turned on while that shouldn't always be the case --- src/pages/QuestionCreation.tsx | 64 ++++++-- src/pages/QuestionEdit.tsx | 265 ++++++++++++++++++--------------- 2 files changed, 191 insertions(+), 138 deletions(-) diff --git a/src/pages/QuestionCreation.tsx b/src/pages/QuestionCreation.tsx index e36766d..10e4cb2 100644 --- a/src/pages/QuestionCreation.tsx +++ b/src/pages/QuestionCreation.tsx @@ -41,7 +41,7 @@ const QuestionCreation: React.FC = () => { const [questions, setQuestions] = useState([]); // NEW: A state to store full question details from Question components - const [fullQuestions, setFullQuestions] = useState>({}); // ADDED + const [fullQuestions, setFullQuestions] = useState>({}); const truncateText = (text: string, maxLength: number): string => { if (!text) return ''; @@ -96,10 +96,10 @@ const QuestionCreation: React.FC = () => { }); }; - // NEW: Handle full question data from the Question component + // Handle full question data from the Question component const handleQuestionDataChange = (localId: string, data: FullQuestionData) => { setFullQuestions(prev => ({ ...prev, [localId]: data })); - }; // ADDED + }; const questionData = questions.map(q => ({ localId: q.localId, @@ -108,12 +108,42 @@ const QuestionCreation: React.FC = () => { questionText: q.questionText })); - // NEW: Implementing saveQuestionsAndAnswers + const validateData = (finalQuestions: FullQuestionData[]): boolean => { + for (const fq of finalQuestions) { + // Check question-level validation + if (!fq.text || fq.text.trim() === '') { + alert(`Question at index ${fq.indexValue} has no title.`); + return false; + } + if (!fq.description || fq.description.trim() === '') { + alert(`Question "${fq.text}" (index ${fq.indexValue}) has no description.`); + return false; + } + if (!fq.indexValue || fq.indexValue <= 0) { + alert(`Question "${fq.text}" has an invalid index value (${fq.indexValue}).`); + return false; + } + + // If multiple-choice, validate answers + if (fq.allowMultipleResponse || fq.answers.length > 0) { + for (const ans of fq.answers) { + if (!ans.text || ans.text.trim() === '') { + alert(`Question "${fq.text}" has an answer with empty text.`); + return false; + } + if (!ans.index || ans.index <= 0) { + alert(`Question "${fq.text}" has an answer with an invalid index (${ans.index}).`); + return false; + } + } + } + } + return true; + }; + const saveQuestionsAndAnswers = async () => { try { const sortedQuestions = [...questions].sort((a, b) => a.indexValue - b.indexValue); - - // Gather full details for each question const finalQuestions = sortedQuestions.map(q => fullQuestions[q.localId]).filter(Boolean); if (finalQuestions.length !== sortedQuestions.length) { @@ -121,9 +151,14 @@ const QuestionCreation: React.FC = () => { return; } + // Validate data before saving + if (!validateData(finalQuestions)) { + return; // If validation fails, do not proceed + } + const localIdToRealId: Record = {}; - // First add all questions + // Add all questions for (const fq of finalQuestions) { const questionPayload = { allowMultipleResponse: fq.allowMultipleResponse, @@ -132,20 +167,19 @@ const QuestionCreation: React.FC = () => { index: fq.indexValue, openResponseFormat: fq.openResponseFormat, text: fq.text, - questionnaireID: questionnaire?.ID // Make sure to use questionnaireID exactly as API specifies + questionnaireID: questionnaire?.ID }; - const createdQuestion = await addQuestion(questionPayload); localIdToRealId[fq.localId] = createdQuestion.ID; } - // Then add answers + // Add answers for (const fq of finalQuestions) { for (const ans of fq.answers) { const answerPayload = { index: ans.index, - questionID: localIdToRealId[fq.localId], // Use questionID instead of questionId + questionID: localIdToRealId[fq.localId], nextQuestionID: ans.nextQuestionID ? localIdToRealId[ans.nextQuestionID] : null, text: ans.text }; @@ -159,7 +193,7 @@ const QuestionCreation: React.FC = () => { console.error('Error saving questions and answers:', error); alert('Failed to save. Please try again.'); } - }; // ADDED + }; return (
@@ -189,9 +223,7 @@ const QuestionCreation: React.FC = () => { onQuestionTextChange={handleQuestionTextChange} allQuestions={questionData} currentQuestionText={q.questionText} - - // Pass the new callback for full data - onQuestionDataChange={handleQuestionDataChange} // ADDED + onQuestionDataChange={handleQuestionDataChange} /> ))}
@@ -208,7 +240,7 @@ const QuestionCreation: React.FC = () => {