From b072e2579f28a18970199a9be354de43e4fd47e7 Mon Sep 17 00:00:00 2001 From: Mike Brown Date: Mon, 25 Nov 2024 10:39:51 -0500 Subject: [PATCH 1/3] Add gonorrhea support to test card --- ...kSupportedDiseaseTestPerformedGonorrhea.ts | 15 + .../app/testQueue/TestCard/TestCard.test.tsx | 136 ++ .../TestCardForm/TestCardForm.test.tsx | 20 + .../testQueue/TestCardForm/TestCardForm.tsx | 25 +- .../TestCardForm/TestCardForm.utils.tsx | 23 +- .../__snapshots__/TestCardForm.test.tsx.snap | 1403 +++++++++++++++++ ...itisCAoeForm.tsx => STIGenericAOEForm.tsx} | 21 +- .../aoeUtils.test.ts | 13 + .../diseaseSpecificComponents/aoeUtils.ts | 10 + .../app/testQueue/testCardTestConstants.ts | 20 + frontend/src/app/testResults/constants.ts | 1 + frontend/src/app/utils/disease.ts | 4 + .../src/patientApp/timeOfTest/constants.ts | 31 +- 13 files changed, 1710 insertions(+), 12 deletions(-) create mode 100644 frontend/src/app/supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedGonorrhea.ts rename frontend/src/app/testQueue/TestCardForm/diseaseSpecificComponents/{HepatitisCAoeForm.tsx => STIGenericAOEForm.tsx} (89%) diff --git a/frontend/src/app/supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedGonorrhea.ts b/frontend/src/app/supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedGonorrhea.ts new file mode 100644 index 0000000000..e41815fafe --- /dev/null +++ b/frontend/src/app/supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedGonorrhea.ts @@ -0,0 +1,15 @@ +const mockSupportedDiseaseTestPerformedGonorrhea = [ + { + supportedDisease: { + internalId: "18948648-1780-4303-b5fe-05c1d3f34ab7", + loinc: "LP14316-1", + name: "Gonorrhea", + }, + testPerformedLoincCode: "80123-6", + equipmentUid: "GonorrheaEquipmentUid123", + testkitNameId: "GonorrheaTestkitNameId123", + testOrderedLoincCode: "80123-6", + }, +]; + +export default mockSupportedDiseaseTestPerformedGonorrhea; diff --git a/frontend/src/app/testQueue/TestCard/TestCard.test.tsx b/frontend/src/app/testQueue/TestCard/TestCard.test.tsx index 92c87bd575..50a053a838 100644 --- a/frontend/src/app/testQueue/TestCard/TestCard.test.tsx +++ b/frontend/src/app/testQueue/TestCard/TestCard.test.tsx @@ -69,6 +69,8 @@ import { mutationResponse, updateHepCAoeMocks, baseStiAoeUpdateMock, + device10Id, + device10Name, } from "../testCardTestConstants"; import { QueriedFacility } from "../TestCardForm/types"; import mockSupportedDiseaseMultiplex, { @@ -78,6 +80,7 @@ import mockSupportedDiseaseTestPerformedHIV from "../../supportAdmin/DeviceType/ import mockSupportedDiseaseTestPerformedSyphilis from "../../supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedSyphilis"; import { UpdateTestOrderTimerStartedAtDocument } from "../../../generated/graphql"; import mockSupportedDiseaseTestPerformedHepatitisC from "../../supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedHepatitisC"; +import mockSupportedDiseaseTestPerformedGonorrhea from "../../supportAdmin/DeviceType/mocks/mockSupportedDiseaseTestPerformedGonorrhea"; import { TestCard, TestCardProps } from "./TestCard"; @@ -277,6 +280,21 @@ const facilityInfo: QueriedFacility = { }, ], }, + { + internalId: device10Id, + name: device10Name, + testLength: 15, + supportedDiseaseTestPerformed: [ + ...mockSupportedDiseaseTestPerformedGonorrhea, + ], + swabTypes: [ + { + name: specimen3Name, + internalId: specimen3Id, + typeCode: "122555007", + }, + ], + }, ], }; export const devicesMap = new Map(); @@ -1486,6 +1504,124 @@ describe("TestCard", () => { expect(screen.queryByText(AOE_ERROR_TEXT)).not.toBeInTheDocument(); }); + it("shows radio buttons for Gonorrhea when a Gonorrhea device is chosen", async function () { + mockDiseaseEnabledFlag("gonorrhea"); + + const mocks = [ + generateEditQueueMock( + MULTIPLEX_DISEASES.GONORRHEA, + TEST_RESULTS.POSITIVE + ), + blankUpdateAoeEventMock, + ]; + + const { user } = await renderQueueItem({ mocks }); + expect(screen.queryByText("Gonorrhea result")).not.toBeInTheDocument(); + + const deviceDropdown = await getDeviceTypeDropdown(); + + await user.selectOptions(deviceDropdown, device10Name); + expect(screen.getByText("Gonorrhea result")).toBeInTheDocument(); + }); + + it("shows required Gonorrhea AOE questions when a positive Gonorrhea result is present", async function () { + mockDiseaseEnabledFlag("gonorrhea"); + + const mocks = [ + generateEditQueueMock( + MULTIPLEX_DISEASES.GONORRHEA, + TEST_RESULTS.POSITIVE + ), + blankUpdateAoeEventMock, + { + ...baseStiAoeUpdateMock({ + ...NO_SYMPTOMS_FALSE_OVERRIDE, + }), + ...mutationResponse, + }, + ]; + + const { user } = await renderQueueItem({ mocks }); + const deviceDropdown = await getDeviceTypeDropdown(); + expect(deviceDropdown.options.length).toEqual( + DEFAULT_DEVICE_OPTIONS_LENGTH + 1 + ); + + await user.selectOptions(deviceDropdown, device10Name); + expect(screen.getByText("Gonorrhea result")).toBeInTheDocument(); + + await user.click( + screen.getByLabelText("Positive", { + exact: false, + }) + ); + + expect(screen.getByText("Is the patient pregnant?")).toBeInTheDocument(); + expect( + screen.getByText( + "Is the patient currently experiencing or showing signs of symptoms?" + ) + ).toBeInTheDocument(); + expect( + screen.getByText("What is the gender of their sexual partners?") + ).toBeInTheDocument(); + + const symptomFieldSet = screen.getByTestId( + `has-any-symptoms-${sharedTestOrderInfo.internalId}` + ); + await user.click(within(symptomFieldSet).getByLabelText("Yes")); + + expect( + screen.getByText("Select any symptoms the patient is experiencing") + ).toBeInTheDocument(); + }); + + it("hides AOE questions when there is no positive Gonorrhea result", async function () { + mockDiseaseEnabledFlag("gonorrhea"); + + const mocks = [ + generateEditQueueMock( + MULTIPLEX_DISEASES.GONORRHEA, + TEST_RESULTS.POSITIVE + ), + blankUpdateAoeEventMock, + ]; + + const { user } = await renderQueueItem({ mocks }); + const deviceDropdown = await getDeviceTypeDropdown(); + + await user.selectOptions(deviceDropdown, device10Name); + expect(screen.getByText("Gonorrhea result")).toBeInTheDocument(); + expect( + screen.queryByText("Is the patient pregnant?") + ).not.toBeInTheDocument(); + expect( + screen.queryByText( + "Is the patient currently experiencing or showing signs of symptoms?" + ) + ).not.toBeInTheDocument(); + expect( + screen.queryByText("What is the gender of their sexual partners?") + ).not.toBeInTheDocument(); + + await user.click( + screen.getByLabelText("Inconclusive", { + exact: false, + }) + ); + expect( + screen.queryByText("Is the patient pregnant?") + ).not.toBeInTheDocument(); + expect( + screen.queryByText( + "Is the patient currently experiencing or showing signs of symptoms?" + ) + ).not.toBeInTheDocument(); + expect( + screen.queryByText("What is the gender of their sexual partners?") + ).not.toBeInTheDocument(); + }); + it("checks that submission only works if AOE questions are valid", async function () { mockDiseaseEnabledFlag("syphilis"); diff --git a/frontend/src/app/testQueue/TestCardForm/TestCardForm.test.tsx b/frontend/src/app/testQueue/TestCardForm/TestCardForm.test.tsx index ec5aa6b5bd..0952cb6071 100644 --- a/frontend/src/app/testQueue/TestCardForm/TestCardForm.test.tsx +++ b/frontend/src/app/testQueue/TestCardForm/TestCardForm.test.tsx @@ -12,6 +12,8 @@ import { fluDeviceId, fluDeviceName, generateSubmitQueueMock, + gonorrheaDeviceId, + gonorrheaDeviceName, hepatitisCDeviceId, hepatitisCDeviceName, hivDeviceId, @@ -205,6 +207,24 @@ describe("TestCardForm", () => { expect(await renderTestCardForm({ props })).toMatchSnapshot(); }); + + it("matches snapshot for gonorrhea device", async () => { + const props = { + ...testProps, + testOrder: { + ...testProps.testOrder, + results: [{ testResult: "POSITIVE", disease: { name: "GONORRHEA" } }], + deviceType: { + internalId: gonorrheaDeviceId, + name: gonorrheaDeviceName, + model: gonorrheaDeviceName, + testLength: 15, + }, + }, + }; + + expect(await renderTestCardForm({ props })).toMatchSnapshot(); + }); }); describe("error handling", () => { diff --git a/frontend/src/app/testQueue/TestCardForm/TestCardForm.tsx b/frontend/src/app/testQueue/TestCardForm/TestCardForm.tsx index 7c305cfe25..fa7c10a166 100644 --- a/frontend/src/app/testQueue/TestCardForm/TestCardForm.tsx +++ b/frontend/src/app/testQueue/TestCardForm/TestCardForm.tsx @@ -27,6 +27,8 @@ import { TestCorrectionReasons, } from "../../testResults/viewResults/actionMenuModals/TestResultCorrectionModal"; import { + gonorrheaSymptomDefinitions, + hepatitisCSymptomDefinitions, PregnancyCode, SyphilisHistoryCode, } from "../../../patientApp/timeOfTest/constants"; @@ -58,7 +60,7 @@ import { HIVAoEForm } from "./diseaseSpecificComponents/HIVAoEForm"; import { stringifySymptomJsonForAoeUpdate } from "./diseaseSpecificComponents/aoeUtils"; import { SyphilisAoEForm } from "./diseaseSpecificComponents/SyphilisAoEForm"; import { WhereResultsAreSentModal } from "./WhereResultsAreSentModal"; -import { HepatitisCAoeForm } from "./diseaseSpecificComponents/HepatitisCAoeForm"; +import { STIGenericAOEForm } from "./diseaseSpecificComponents/STIGenericAOEForm"; const DEBOUNCE_TIME = 300; @@ -606,7 +608,7 @@ const TestCardForm = ({ )} {whichAoeFormOption === AOEFormOption.HEPATITIS_C && (
- +
+ )} + {whichAoeFormOption === AOEFormOption.GONORRHEA && ( +
+ { + dispatch({ + type: TestFormActionCase.UPDATE_AOE_RESPONSES, + payload: responses, + }); + }} + diseaseSymptomDefinitions={gonorrheaSymptomDefinitions} + diseaseNameForFormIds={"gonorrhea"} />
)} diff --git a/frontend/src/app/testQueue/TestCardForm/TestCardForm.utils.tsx b/frontend/src/app/testQueue/TestCardForm/TestCardForm.utils.tsx index 9d692985ed..2bd7da9314 100644 --- a/frontend/src/app/testQueue/TestCardForm/TestCardForm.utils.tsx +++ b/frontend/src/app/testQueue/TestCardForm/TestCardForm.utils.tsx @@ -27,6 +27,7 @@ export enum AOEFormOption { HIV = "HIV", SYPHILIS = "SYPHILIS", HEPATITIS_C = "HEPATITIS_C", + GONORRHEA = "GONORRHEA", NONE = "NONE", } @@ -65,6 +66,7 @@ export function useFilteredDeviceTypes(facility: QueriedFacility) { const hivEnabled = useFeature("hivEnabled"); const syphilisEnabled = useFeature("syphilisEnabled"); const hepatitisCEnabled = useFeature("hepatitisCEnabled"); + const gonorrheaEnabled = useFeature("gonorrheaEnabled"); let deviceTypes = [...facility!.deviceTypes]; @@ -74,7 +76,6 @@ export function useFilteredDeviceTypes(facility: QueriedFacility) { MULTIPLEX_DISEASES.HIV ); } - if (!syphilisEnabled) { deviceTypes = filterDiseaseFromAllDevices( deviceTypes, @@ -87,6 +88,12 @@ export function useFilteredDeviceTypes(facility: QueriedFacility) { MULTIPLEX_DISEASES.HEPATITIS_C ); } + if (!gonorrheaEnabled) { + deviceTypes = filterDiseaseFromAllDevices( + deviceTypes, + MULTIPLEX_DISEASES.GONORRHEA + ); + } return deviceTypes; } @@ -204,6 +211,15 @@ export const useAOEFormOption = ( if (!hasAnySupportedDiseaseTests(testFormState.deviceId, devicesMap)) { return AOEFormOption.COVID; } + if ( + devicesMap + .get(testFormState.deviceId) + ?.supportedDiseaseTestPerformed.filter( + (x) => x.supportedDisease.name === MULTIPLEX_DISEASES.GONORRHEA + ).length === 1 + ) { + return resultHasPositive ? AOEFormOption.GONORRHEA : AOEFormOption.NONE; + } if ( devicesMap .get(testFormState.deviceId) @@ -288,6 +304,11 @@ export const REQUIRED_AOE_QUESTIONS_BY_DISEASE: { AoeQuestionName.GENDER_OF_SEXUAL_PARTNERS, AoeQuestionName.NO_SYMPTOMS, ], + [AOEFormOption.GONORRHEA]: [ + AoeQuestionName.PREGNANCY, + AoeQuestionName.GENDER_OF_SEXUAL_PARTNERS, + AoeQuestionName.NO_SYMPTOMS, + ], [AOEFormOption.NONE]: [], }; diff --git a/frontend/src/app/testQueue/TestCardForm/__snapshots__/TestCardForm.test.tsx.snap b/frontend/src/app/testQueue/TestCardForm/__snapshots__/TestCardForm.test.tsx.snap index 325c0521f0..499774bf53 100644 --- a/frontend/src/app/testQueue/TestCardForm/__snapshots__/TestCardForm.test.tsx.snap +++ b/frontend/src/app/testQueue/TestCardForm/__snapshots__/TestCardForm.test.tsx.snap @@ -1535,6 +1535,1409 @@ exports[`TestCardForm initial state matches snapshot for flu device 1`] = ` `; +exports[`TestCardForm initial state matches snapshot for gonorrhea device 1`] = ` +Object { + "asFragment": [Function], + "baseElement": +
+ +
+
+
+ +
+ + +
+
+
+
+
+
+ + +
+
+
+
+ + +
+
+
+
+
+
+
+

+ This device doesn't have any supported disease tests configured. Please ask your organization admin to add the correct test. +

+
+
+
+
+
+
+
+
+
+ + + + +
+ + +   + + + + + +
+
+
+ + Selected [object Object] + +
+
+
+
+
+
+
+
+ + Is the patient pregnant? + + + * + + +
+
+ + +
+
+ + +
+
+ + +
+
+
+
+
+
+
+
+
+
+ + Is the patient currently experiencing or showing signs of symptoms? + + + * + + +
+
+ + +
+
+ + +
+
+
+
+
+
+
+
+
+
+ +
+
+
+ +
+
+
+