From f6d31f0cd11aa31b940f12f4f871817c4bbd8d58 Mon Sep 17 00:00:00 2001 From: Ashesh <3626859+Ashesh3@users.noreply.github.com> Date: Wed, 25 Oct 2023 21:10:00 +0530 Subject: [PATCH] Add medico-legal case toggle and filter (#6440) * Add medico-legal case toggle and filter * Redesign patient info card actions * Update design * lint fix * fix design * Add badge --- .../Assets/AssetType/ONVIFCamera.tsx | 1 - src/Components/Common/components/Menu.tsx | 5 +- .../Common/components/SwitchTabs.tsx | 16 +- src/Components/Facility/models.tsx | 1 + src/Components/Patient/ManagePatients.tsx | 13 +- src/Components/Patient/PatientFilter.tsx | 23 ++ src/Components/Patient/PatientInfoCard.tsx | 365 ++++++++++++------ src/Components/Resource/ResourceBoardView.tsx | 6 +- src/Components/Shifting/BoardView.tsx | 6 +- src/Redux/api.tsx | 2 + 10 files changed, 300 insertions(+), 138 deletions(-) diff --git a/src/Components/Assets/AssetType/ONVIFCamera.tsx b/src/Components/Assets/AssetType/ONVIFCamera.tsx index 4a3a003d0a1..4a3e475419e 100644 --- a/src/Components/Assets/AssetType/ONVIFCamera.tsx +++ b/src/Components/Assets/AssetType/ONVIFCamera.tsx @@ -134,7 +134,6 @@ const ONVIFCamera = ({ assetId, facilityId, asset, onUpdated }: Props) => { } setLoadingAddPreset(false); }; - if (isLoading || loading || !facility) return ; const fallbackMiddleware = diff --git a/src/Components/Common/components/Menu.tsx b/src/Components/Common/components/Menu.tsx index 4b52a293f9e..49ee02b393e 100644 --- a/src/Components/Common/components/Menu.tsx +++ b/src/Components/Common/components/Menu.tsx @@ -16,6 +16,7 @@ interface DropdownMenuProps { children: JSX.Element | JSX.Element[]; disabled?: boolean | undefined; className?: string | undefined; + itemClassName?: string | undefined; } export default function DropdownMenu({ @@ -36,7 +37,9 @@ export default function DropdownMenu({ - + <>{props.children} diff --git a/src/Components/Common/components/SwitchTabs.tsx b/src/Components/Common/components/SwitchTabs.tsx index 0592f0272dd..047dba53b4b 100644 --- a/src/Components/Common/components/SwitchTabs.tsx +++ b/src/Components/Common/components/SwitchTabs.tsx @@ -1,36 +1,36 @@ export default function SwitchTabs(props: { - activeTab: boolean; + isTab2Active: boolean; onClickTab1: () => void; onClickTab2: () => void; - Tab1: string; - Tab2: string; + tab1: string; + tab2: string; }) { return (
- {props.Tab1} + {props.tab1}
- {props.Tab2} + {props.tab2}
); diff --git a/src/Components/Facility/models.tsx b/src/Components/Facility/models.tsx index a9861a4869c..f5ddde19d2d 100644 --- a/src/Components/Facility/models.tsx +++ b/src/Components/Facility/models.tsx @@ -146,6 +146,7 @@ export interface ConsultationModel { death_datetime?: string; death_confirmed_doctor?: string; is_readmission?: boolean; + medico_legal_case?: boolean; } export interface PatientStatsModel { id?: number; diff --git a/src/Components/Patient/ManagePatients.tsx b/src/Components/Patient/ManagePatients.tsx index aa3a837647d..61b18faa367 100644 --- a/src/Components/Patient/ManagePatients.tsx +++ b/src/Components/Patient/ManagePatients.tsx @@ -185,6 +185,8 @@ export const PatientManager = () => { qParams.date_declared_positive_after || undefined, date_of_result_before: qParams.date_of_result_before || undefined, date_of_result_after: qParams.date_of_result_after || undefined, + last_consultation_medico_legal_case: + qParams.last_consultation_medico_legal_case || undefined, last_consultation_admission_date_before: qParams.last_consultation_admission_date_before || undefined, last_consultation_admission_date_after: @@ -333,6 +335,7 @@ export const PatientManager = () => { }); }, [ dispatch, + qParams.last_consultation_medico_legal_case, qParams.last_consultation_admission_date_before, qParams.last_consultation_admission_date_after, qParams.last_consultation_discharge_date_before, @@ -768,11 +771,11 @@ export const PatientManager = () => {
updateQuery({ is_active: "True" })} onClickTab2={() => updateQuery({ is_active: "False" })} - activeTab={tabValue ? true : false} + isTab2Active={tabValue ? true : false} /> {showDoctorConnect && ( { kasp(), badge("COWIN ID", "covin_id"), badge("Is Antenatal", "is_antenatal"), + badge( + "Is Medico-Legal Case", + "last_consultation_medico_legal_case" + ), value("Facility", "facility", facilityBadgeName), badge("Facility Type", "facility_type"), value("District", "district", districtName), diff --git a/src/Components/Patient/PatientFilter.tsx b/src/Components/Patient/PatientFilter.tsx index 205ac39ac9c..97f5a6c6b9c 100644 --- a/src/Components/Patient/PatientFilter.tsx +++ b/src/Components/Patient/PatientFilter.tsx @@ -65,6 +65,8 @@ export default function PatientFilter(props: any) { age_max: filter.age_max || null, date_of_result: filter.date_of_result || null, date_declared_positive: filter.date_declared_positive || null, + last_consultation_medico_legal_case: + filter.last_consultation_medico_legal_case || null, last_consultation_admission_date_before: filter.last_consultation_admission_date_before || null, last_consultation_admission_date_after: @@ -120,6 +122,7 @@ export default function PatientFilter(props: any) { age_max: "", date_of_result: null, date_declared_positive: null, + last_consultation_medico_legal_case: null, last_consultation_admission_date_before: "", last_consultation_admission_date_after: "", last_consultation_discharge_date_before: "", @@ -229,6 +232,7 @@ export default function PatientFilter(props: any) { age_min, age_max, date_of_result, + last_consultation_medico_legal_case, last_consultation_admission_date_before, last_consultation_admission_date_after, last_consultation_discharge_date_before, @@ -266,6 +270,8 @@ export default function PatientFilter(props: any) { modified_date_before: dateQueryString(modified_date_before), modified_date_after: dateQueryString(modified_date_after), date_of_result: dateQueryString(date_of_result), + last_consultation_medico_legal_case: + last_consultation_medico_legal_case || "", last_consultation_admission_date_before: dateQueryString( last_consultation_admission_date_before ), @@ -473,6 +479,23 @@ export default function PatientFilter(props: any) { } />
+
+ Is Medico-Legal Case + + o === "true" ? "Medico-Legal" : "Non-Medico-Legal" + } + value={filterState.last_consultation_medico_legal_case} + onChange={(v) => + setFilterState({ + ...filterState, + last_consultation_medico_legal_case: v, + }) + } + /> +
{ + if (!consultation?.id || value === medicoLegalCase) return; + const { res, data } = await request(routes.partialUpdateConsultation, { + pathParams: { id: consultation?.id }, + body: { medico_legal_case: value }, + }); + + if (res?.status !== 200 || !data) { + Notification.Error({ + msg: "Failed to update Medico Legal Case", + }); + setMedicoLegalCase(!value); + } else { + Notification.Success({ + msg: "Medico Legal Case updated successfully", + }); + } + }; + return ( <> 0 && (
)} + {medicoLegalCase && ( + + MLC + + )}
{!!consultation?.discharge_date && (

@@ -326,131 +359,225 @@ export default function PatientInfoCard(props: { , ], ], - [ - `/patient/${patient.id}/investigation_reports`, - "Investigation Summary", - "align-alt", - true, - ], - [ - `/facility/${patient.facility}/patient/${patient.id}/consultation/${consultation?.id}/treatment-summary`, - "Treatment Summary", - "file-medical", - consultation?.id, - ], - ] - .concat( - enable_hcx - ? [ - [ - `/facility/${patient.facility}/patient/${patient.id}/consultation/${consultation?.id}/claims`, - "Claims", - "copy-landscape", - consultation?.id, - ], - ] - : [] - ) - .map( - (action: any, i) => - action[3] && ( -

- + action[3] && ( +
+ { + if ( consultation?.admitted && !consultation?.current_bed && i === 1 - ? undefined - : `${action[0]}` + ) { + Notification.Error({ + msg: "Please assign a bed to the patient", + }); + setOpen(true); } - onClick={() => { - if ( - consultation?.admitted && - !consultation?.current_bed && - i === 1 - ) { - Notification.Error({ - msg: "Please assign a bed to the patient", - }); - setOpen(true); - } - }} - className="w-full" - > - - -

{action[1]}

-
-
- {action[4] && action[4][0] && ( - <> -

- {action[4][1]} -

- - )} -
+ }} + className="w-full" + > + + +

{action[1]}

+
+
+ {action?.[4]?.[0] && ( + <> +

+ {action[4][1]} +

+ + )} +
+ ) + )} + } + > +
+ {[ + [ + `/patient/${patient.id}/investigation_reports`, + "Investigation Summary", + "align-alt", + true, + ], + [ + `/facility/${patient.facility}/patient/${patient.id}/consultation/${consultation?.id}/treatment-summary`, + "Treatment Summary", + "file-medical", + consultation?.id, + ], + ] + .concat( + enable_hcx + ? [ + [ + `/facility/${patient.facility}/patient/${patient.id}/consultation/${consultation?.id}/claims`, + "Claims", + "copy-landscape", + consultation?.id, + ], + ] + : [] ) - )} - {enable_abdm && - (patient.abha_number ? ( - <> - setShowABHAProfile(true)} - > - - -

Show ABHA Profile

-
-
- setShowLinkCareContext(true)} - > - - -

Link Care Context

-
-
- setShowABHAProfile(false)} - /> - setShowLinkCareContext(false)} - /> - - ) : ( - <> - setShowLinkABHANumber(true)} - > - - -

Link ABHA Number

-
-
- setShowLinkABHANumber(false)} - patientId={patient.id as any} - onSuccess={(_) => { - window.location.href += "?show-abha-profile=true"; + .map( + (action: any, i) => + action[3] && ( + + ) + )} +
+
+ {enable_abdm && + (patient.abha_number ? ( + <> + + {({ close }) => ( + <> +
{ + close(); + setShowABHAProfile(true); + }} + > + + Show ABHA Profile +
+
{ + close(); + setShowLinkCareContext(true); + }} + > + + Link Care Context +
+ + )} +
+ + ) : ( + + {({ close }) => ( +
{ + close(); + setShowLinkABHANumber(true); + }} + > + + +

Link ABHA Number

+
+
+ )} +
+ ))} +
+
+ + { + setMedicoLegalCase(checked); + switchMedicoLegalCase(checked); }} - /> - - ))} + className={classNames( + medicoLegalCase ? "bg-primary" : "bg-gray-200", + "relative inline-flex h-4 w-8 flex-shrink-0 cursor-pointer rounded-full border-2 border-transparent transition-colors duration-200 ease-in-out focus:outline-none " + )} + > + + + + Medico-Legal Case + {" "} + + +
+
+ setShowLinkABHANumber(false)} + patientId={patient.id as any} + onSuccess={(_) => { + window.location.href += "?show-abha-profile=true"; + }} + /> + setShowABHAProfile(false)} + /> + setShowLinkCareContext(false)} + /> ); } diff --git a/src/Components/Resource/ResourceBoardView.tsx b/src/Components/Resource/ResourceBoardView.tsx index d3b2b202649..17fb70c662f 100644 --- a/src/Components/Resource/ResourceBoardView.tsx +++ b/src/Components/Resource/ResourceBoardView.tsx @@ -59,11 +59,11 @@ export default function BoardView() {
setBoardFilter(ACTIVE)} onClickTab2={() => setBoardFilter(COMPLETED)} - activeTab={boardFilter !== ACTIVE} + isTab2Active={boardFilter !== ACTIVE} />
diff --git a/src/Components/Shifting/BoardView.tsx b/src/Components/Shifting/BoardView.tsx index 85815770acf..9c96daa0e59 100644 --- a/src/Components/Shifting/BoardView.tsx +++ b/src/Components/Shifting/BoardView.tsx @@ -85,11 +85,11 @@ export default function BoardView() { /> setBoardFilter(activeBoards)} onClickTab2={() => setBoardFilter(completedBoards)} - activeTab={boardFilter[0].text !== activeBoards[0].text} + isTab2Active={boardFilter[0].text !== activeBoards[0].text} />
diff --git a/src/Redux/api.tsx b/src/Redux/api.tsx index fe678f2be3e..104fa0c0c75 100644 --- a/src/Redux/api.tsx +++ b/src/Redux/api.tsx @@ -410,6 +410,8 @@ const routes = { partialUpdateConsultation: { path: "/api/v1/consultation/{id}/", method: "PATCH", + TRes: Type>(), + TBody: Type(), }, deleteConsultation: { path: "/api/v1/consultation/{id}/",