From e455e345cfa5c9bb79ac51dada25b662c39d644b Mon Sep 17 00:00:00 2001 From: ibolton336 Date: Wed, 4 Oct 2023 11:06:52 -0400 Subject: [PATCH] :bug: Add unique keys for answers and questions Signed-off-by: ibolton336 --- .../multi-input-selection.tsx | 91 ++++++++++--------- .../questionnaire-form/questionnaire-form.tsx | 63 +++++++------ .../app/pages/assessment/form-utils.test.ts | 4 +- client/src/app/pages/assessment/form-utils.ts | 2 +- 4 files changed, 84 insertions(+), 76 deletions(-) diff --git a/client/src/app/pages/assessment/components/questionnaire-form/multi-input-selection/multi-input-selection.tsx b/client/src/app/pages/assessment/components/questionnaire-form/multi-input-selection/multi-input-selection.tsx index d2b08203d3..aea19eeb74 100644 --- a/client/src/app/pages/assessment/components/questionnaire-form/multi-input-selection/multi-input-selection.tsx +++ b/client/src/app/pages/assessment/components/questionnaire-form/multi-input-selection/multi-input-selection.tsx @@ -29,50 +29,53 @@ export const MultiInputSelection: React.FC = ({ const { t } = useTranslation(); return ( - {sortedOptions.map((option, i) => ( - - ( - { - onChange(option.text); - }} - aria-label={option.text} - label={ - <> - {option.autoAnswered && option.autoAnswerFor?.length ? ( - `"${t.tag}"`) - .join(", "), - } - )} - > - - - - - ) : null}{" "} - {option.text} - - } - value={option.text} - /> - )} - /> - - ))} + {sortedOptions.map((option, i) => { + const answerUniqueId = `${questionFieldName}-${option.text}-${i}}`; + return ( + + ( + { + onChange(option.text); + }} + aria-label={option.text} + label={ + <> + {option.autoAnswered && option.autoAnswerFor?.length ? ( + `"${t.tag}"`) + .join(", "), + } + )} + > + + + + + ) : null}{" "} + {option.text} + + } + value={option.text} + /> + )} + /> + + ); + })} ); }; diff --git a/client/src/app/pages/assessment/components/questionnaire-form/questionnaire-form.tsx b/client/src/app/pages/assessment/components/questionnaire-form/questionnaire-form.tsx index 4604f4ddf1..8bc3ddbb01 100644 --- a/client/src/app/pages/assessment/components/questionnaire-form/questionnaire-form.tsx +++ b/client/src/app/pages/assessment/components/questionnaire-form/questionnaire-form.tsx @@ -53,35 +53,40 @@ export const QuestionnaireForm: React.FC = ({ {section.name} - {sortedQuestions.map((question) => ( - - - - - {question.text} - - {question.explanation}}> - - - - - - - - - - - ))} + {sortedQuestions.map((question) => { + const questionUniqueKey = `${section.name}-${ + question.order || "no-order" + }-${question.text || "no-text"}`; + return ( + + + + + {question.text} + + {question.explanation}}> + + + + + + + + + + + ); + })} diff --git a/client/src/app/pages/assessment/form-utils.test.ts b/client/src/app/pages/assessment/form-utils.test.ts index 2e6d74a649..0cd0f574f0 100644 --- a/client/src/app/pages/assessment/form-utils.test.ts +++ b/client/src/app/pages/assessment/form-utils.test.ts @@ -26,11 +26,11 @@ describe("Application assessment - form utils", () => { it("getQuestionFieldName: fullName", () => { const fieldName = getQuestionFieldName(question, true); - expect(fieldName).toBe("questions.question-1"); + expect(fieldName).toBe("questions.question-1-Question 321"); }); it("getQuestionFieldName: singleName", () => { const fieldName = getQuestionFieldName(question, false); - expect(fieldName).toBe("question-1"); + expect(fieldName).toBe("question-1-Question 321"); }); }); diff --git a/client/src/app/pages/assessment/form-utils.ts b/client/src/app/pages/assessment/form-utils.ts index 43fcb26f5d..c75600bbc0 100644 --- a/client/src/app/pages/assessment/form-utils.ts +++ b/client/src/app/pages/assessment/form-utils.ts @@ -15,6 +15,6 @@ export const getCommentFieldName = (section: Section, fullName: boolean) => { }; export const getQuestionFieldName = (question: Question, fullName: boolean) => { - const fieldName = `question-${question.order}`; + const fieldName = `question-${question.order}-${question.text}`; return fullName ? `${QUESTIONS_KEY}.${fieldName}` : fieldName; };