From ad65cfc94e51fdf63e8845c4a2e76481668a94c5 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Mon, 25 Mar 2024 19:55:13 +0530 Subject: [PATCH 01/19] Fail build if typescript errors present --- package.json | 1 + vite.config.mts | 2 ++ 2 files changed, 3 insertions(+) diff --git a/package.json b/package.json index 244b6c125b0..1b263b97e9e 100644 --- a/package.json +++ b/package.json @@ -159,6 +159,7 @@ "tailwindcss": "^3.3.3", "typescript": "^5.1.6", "vite": "^5.1.3", + "vite-plugin-checker": "^0.6.4", "vite-plugin-pwa": "^0.18.2" }, "browserslist": { diff --git a/vite.config.mts b/vite.config.mts index c8eb11c53cf..6ac3df464cf 100644 --- a/vite.config.mts +++ b/vite.config.mts @@ -1,6 +1,7 @@ import { VitePWA } from "vite-plugin-pwa"; import { defineConfig } from "vite"; import react from "@vitejs/plugin-react-swc"; +import checker from "vite-plugin-checker"; const cdnUrls = process.env.CARE_CDN_URL ?? @@ -14,6 +15,7 @@ export default defineConfig({ envPrefix: "REACT_", plugins: [ react(), + checker({ typescript: true }), VitePWA({ strategies: "injectManifest", srcDir: "src", From e8f09f96be8aa2dad05b7265a1e7f5482363c884 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 15:41:06 +0530 Subject: [PATCH 02/19] error fixes part 1 --- package.json | 1 + src/Components/Assets/AssetConfigure.tsx | 6 +++--- src/Components/Assets/AssetManage.tsx | 8 ++++---- src/Components/Assets/AssetsList.tsx | 4 ++-- src/Components/CameraFeed/NoFeedAvailable.tsx | 2 +- src/Components/Facility/AddBedForm.tsx | 2 +- src/Components/Facility/ConsultationCard.tsx | 2 +- src/Components/Facility/ConsultationDetails/index.tsx | 3 +-- src/Components/Facility/Consultations/Beds.tsx | 6 +++--- .../DailyRounds/DefaultLogUpdateCard.tsx | 4 ++-- src/Components/Facility/models.tsx | 4 ++-- src/Components/Form/MultiSelectMenuV2.tsx | 6 +++--- src/Components/Shifting/ShiftDetailsUpdate.tsx | 11 +++++++---- src/Components/Users/UserAdd.tsx | 4 ++-- src/Components/Users/UserProfile.tsx | 2 +- 15 files changed, 34 insertions(+), 31 deletions(-) diff --git a/package.json b/package.json index 1b263b97e9e..7a0467f0618 100644 --- a/package.json +++ b/package.json @@ -114,6 +114,7 @@ "@tailwindcss/typography": "^0.5.9", "@types/cypress": "^1.1.3", "@types/echarts": "^4.9.18", + "@types/google.maps": "^3.55.5", "@types/lodash-es": "^4.17.9", "@types/qrcode.react": "^1.0.2", "@types/react": "18.2.14", diff --git a/src/Components/Assets/AssetConfigure.tsx b/src/Components/Assets/AssetConfigure.tsx index fd431ae35ea..aa6b7c9221e 100644 --- a/src/Components/Assets/AssetConfigure.tsx +++ b/src/Components/Assets/AssetConfigure.tsx @@ -26,7 +26,7 @@ const AssetConfigure = ({ assetId, facilityId }: AssetConfigureProps) => { { { { {
{[ { - label: asset?.location_object.facility.name, + label: asset?.location_object.facility?.name, icon: "location-pin-alt", content: asset?.location_object.name, }, @@ -418,7 +418,7 @@ const AssetManage = (props: AssetManageProps) => { className="flex gap-2" onClick={() => navigate( - `/facility/${asset?.location_object.facility.id}/assets/${asset?.id}/update` + `/facility/${asset?.location_object.facility?.id}/assets/${asset?.id}/update` ) } id="update-asset" @@ -436,7 +436,7 @@ const AssetManage = (props: AssetManageProps) => { navigate( - `/facility/${asset?.location_object.facility.id}/assets/${asset?.id}/configure` + `/facility/${asset?.location_object.facility?.id}/assets/${asset?.id}/configure` ) } id="configure-asset" diff --git a/src/Components/Assets/AssetsList.tsx b/src/Components/Assets/AssetsList.tsx index 228e940de29..732d6924688 100644 --- a/src/Components/Assets/AssetsList.tsx +++ b/src/Components/Assets/AssetsList.tsx @@ -130,7 +130,7 @@ const AssetsList = () => { try { if (assetData) { navigate( - `/facility/${assetData.location_object.facility.id}/assets/${assetId}` + `/facility/${assetData.location_object.facility?.id}/assets/${assetId}` ); } } catch (err) { @@ -188,7 +188,7 @@ const AssetsList = () => { {assets.map((asset: AssetData) => ( diff --git a/src/Components/CameraFeed/NoFeedAvailable.tsx b/src/Components/CameraFeed/NoFeedAvailable.tsx index aaf74dadec6..20eb7a41106 100644 --- a/src/Components/CameraFeed/NoFeedAvailable.tsx +++ b/src/Components/CameraFeed/NoFeedAvailable.tsx @@ -47,7 +47,7 @@ export default function NoFeedAvailable(props: Props) { className="bg-black text-white hover:bg-white/30" border size="small" - href={`/facility/${props.asset.location_object.facility.id}/assets/${props.asset.id}/configure`} + href={`/facility/${props.asset.location_object.facility?.id}/assets/${props.asset.id}/configure`} > Configure diff --git a/src/Components/Facility/AddBedForm.tsx b/src/Components/Facility/AddBedForm.tsx index 379a9a532b8..0a612fa776b 100644 --- a/src/Components/Facility/AddBedForm.tsx +++ b/src/Components/Facility/AddBedForm.tsx @@ -143,7 +143,7 @@ export const AddBedForm = ({ facilityId, locationId, bedId }: Props) => { title={action} backUrl={`/facility/${facilityId}/location/${locationId}/beds`} crumbsReplacements={{ - [facilityId]: { name: location?.facility.name }, + [facilityId]: { name: location?.facility?.name }, [locationId]: { name: location?.name, uri: `/facility/${facilityId}/location`, diff --git a/src/Components/Facility/ConsultationCard.tsx b/src/Components/Facility/ConsultationCard.tsx index 96728c6a2e3..debc59e45df 100644 --- a/src/Components/Facility/ConsultationCard.tsx +++ b/src/Components/Facility/ConsultationCard.tsx @@ -203,7 +203,7 @@ export const ConsultationCard = (props: ConsultationProps) => { ); } }} - disabled={itemData.discharge_date} + disabled={!!itemData.discharge_date} authorizeFor={NonReadOnlyUsers} > Add Consultation Updates diff --git a/src/Components/Facility/ConsultationDetails/index.tsx b/src/Components/Facility/ConsultationDetails/index.tsx index b422fc8867d..dbfdedd6408 100644 --- a/src/Components/Facility/ConsultationDetails/index.tsx +++ b/src/Components/Facility/ConsultationDetails/index.tsx @@ -1,7 +1,6 @@ import { CONSULTATION_TABS, GENDER_TYPES, - OptionsType, SYMPTOM_CHOICES, } from "../../../Common/constants"; import { ConsultationModel } from "../models"; @@ -420,7 +419,7 @@ export const ConsultationDetails = (props: any) => { className="flex space-x-6 overflow-x-auto pb-2 pl-2 " id="consultation_tab_nav" > - {CONSULTATION_TABS.map((p: OptionsType) => { + {CONSULTATION_TABS.map((p) => { if (p.text === "FEED") { if ( isCameraAttached === false || // No camera attached diff --git a/src/Components/Facility/Consultations/Beds.tsx b/src/Components/Facility/Consultations/Beds.tsx index 32023bc9f5f..f9a0c251313 100644 --- a/src/Components/Facility/Consultations/Beds.tsx +++ b/src/Components/Facility/Consultations/Beds.tsx @@ -115,7 +115,7 @@ const Beds = (props: BedsProps) => { {showBedDetails?.assets_objects?.map((asset: AssetData) => ( @@ -237,7 +237,7 @@ const Beds = (props: BedsProps) => {

Previous beds:

-
+
Bed
@@ -253,7 +253,7 @@ const Beds = (props: BedsProps) => {
{consultationBeds.length > 0 ? ( consultationBeds.map((bed) => ( -
+
{bed?.bed_object?.name} {bed?.assets_objects && bed.assets_objects.length > 0 && ( diff --git a/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx b/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx index 1be3419ca2a..1023b353018 100644 --- a/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx +++ b/src/Components/Facility/Consultations/DailyRounds/DefaultLogUpdateCard.tsx @@ -20,8 +20,8 @@ const DefaultLogUpdateCard = ({ round, ...props }: Props) => { id="dailyround-entry" > (props: Props) => { return props.renderSelectedOptions(selectedOptions.map((o) => o.option)); }; - const buttonRef = useRef(null); + const buttonRef = useRef(null); const handleSingleSelect = (o: any) => { if ( @@ -104,9 +104,9 @@ const MultiSelectMenuV2 = (props: Props) => { {selectedOptions.length !== 0 && (
- {selectedOptions.map((option) => ( + {selectedOptions.map((option, index) => ( { const updatedOptions = selectedOptions.filter( diff --git a/src/Components/Shifting/ShiftDetailsUpdate.tsx b/src/Components/Shifting/ShiftDetailsUpdate.tsx index a726150c9e1..4c736ed2244 100644 --- a/src/Components/Shifting/ShiftDetailsUpdate.tsx +++ b/src/Components/Shifting/ShiftDetailsUpdate.tsx @@ -38,6 +38,7 @@ import useQuery from "../../Utils/request/useQuery.js"; import routes from "../../Redux/api.js"; import { IShift } from "./models.js"; import request from "../../Utils/request/request.js"; +import { PatientModel } from "../Patient/models.js"; const Loading = lazy(() => import("../Common/Loading")); @@ -251,17 +252,19 @@ export const ShiftDetailsUpdate = (props: patientShiftProps) => { onResponse: ({ res, data }) => { if (res?.ok && data) { const d = data; - setConsultationData(d.patient.last_consultation as ConsultationModel); + setConsultationData( + (d.patient as PatientModel).last_consultation as ConsultationModel + ); if (d.assigned_facility_external) d["assigned_facility_object"] = { - id: -1, name: String(data.assigned_facility_external), }; d["initial_status"] = data.status; d["status"] = qParams.status || data.status; const patient_category = - d.patient.last_consultation?.last_daily_round?.patient_category ?? - d.patient.last_consultation?.category; + (d.patient as PatientModel).last_consultation?.last_daily_round + ?.patient_category ?? + (d.patient as PatientModel).last_consultation?.category; d["patient_category"] = PATIENT_CATEGORIES.find((c) => c.text === patient_category)?.id ?? ""; dispatch({ type: "set_form", form: d }); diff --git a/src/Components/Users/UserAdd.tsx b/src/Components/Users/UserAdd.tsx index b4d9e9fbca6..57c52323601 100644 --- a/src/Components/Users/UserAdd.tsx +++ b/src/Components/Users/UserAdd.tsx @@ -58,7 +58,7 @@ type UserForm = { gender: string; password: string; c_password: string; - facilities: Array; + facilities: Array; home_facility: FacilityModel | null; username: string; first_name: string; @@ -328,7 +328,7 @@ export const UserAdd = (props: UserProps) => { setSelectedFacility(selected as FacilityModel[]); const form = { ...state.form }; form.facilities = selected - ? (selected as FacilityModel[]).map((i) => i.id ?? -1) + ? (selected as FacilityModel[]).map((i) => i.id!) : []; dispatch({ type: "set_form", form }); }; diff --git a/src/Components/Users/UserProfile.tsx b/src/Components/Users/UserProfile.tsx index d1c23a9db64..921fd2b7211 100644 --- a/src/Components/Users/UserProfile.tsx +++ b/src/Components/Users/UserProfile.tsx @@ -34,7 +34,7 @@ type EditForm = { doctor_qualification: string | undefined; doctor_experience_commenced_on: number | string | undefined; doctor_medical_council_registration: string | undefined; - weekly_working_hours: string | null; + weekly_working_hours?: string | null; }; type ErrorForm = { firstName: string; From e0e56e0479c2893a19b65a177e0219d77f0d1543 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 16:12:54 +0530 Subject: [PATCH 03/19] fixes part 2 --- src/Components/Patient/PatientRegister.tsx | 7 ++++--- src/Components/Patient/models.tsx | 5 +++++ src/Redux/api.tsx | 4 ++-- 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/src/Components/Patient/PatientRegister.tsx b/src/Components/Patient/PatientRegister.tsx index eb6c7104c04..742a1e65f53 100644 --- a/src/Components/Patient/PatientRegister.tsx +++ b/src/Components/Patient/PatientRegister.tsx @@ -414,7 +414,7 @@ export const PatientRegister = (props: PatientRegisterProps) => { local_body: data.local_body ? data.local_body : "", ward: data.ward_object ? data.ward_object.id : undefined, village: data.village ? data.village : "", - medical_history: [], + medical_history: [] as number[], is_antenatal: String(!!data.is_antenatal), allergies: data.allergies ? data.allergies : "", pincode: data.pincode ? data.pincode : "", @@ -469,8 +469,9 @@ export const PatientRegister = (props: PatientRegisterProps) => { ); if (medicalHistory) { formData.medical_history.push(Number(medicalHistory.id)); - formData[`medical_history_${String(medicalHistory.id)}`] = - i.details; + (formData as any)[ + `medical_history_${String(medicalHistory.id)}` + ] = i.details; } } ); diff --git a/src/Components/Patient/models.tsx b/src/Components/Patient/models.tsx index 7648ea18c5e..f1d854c53b5 100644 --- a/src/Components/Patient/models.tsx +++ b/src/Components/Patient/models.tsx @@ -284,6 +284,11 @@ export const DailyRoundTypes = [ export interface DailyRoundsModel { ventilator_spo2?: number; + ventilator_interface?: + | "UNKNOWN" + | "OXYGEN_SUPPORT" + | "NON_INVASIVE" + | "INVASIVE"; spo2?: string; rhythm?: string; rhythm_detail?: string; diff --git a/src/Redux/api.tsx b/src/Redux/api.tsx index 33b6a69e057..856abb11173 100644 --- a/src/Redux/api.tsx +++ b/src/Redux/api.tsx @@ -540,8 +540,8 @@ const routes = { partialUpdateConsultation: { path: "/api/v1/consultation/{id}/", method: "PATCH", - TRes: Type>(), - TBody: Type(), + TBody: Type>(), + TRes: Type(), }, deleteConsultation: { path: "/api/v1/consultation/{id}/", From 4a030bc33c938c1bff2518e6f233d674412488c1 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 16:16:30 +0530 Subject: [PATCH 04/19] fix merge conflict --- plugins/{treeShakeCareIcons.mts => treeShakeCareIcons.ts} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename plugins/{treeShakeCareIcons.mts => treeShakeCareIcons.ts} (100%) diff --git a/plugins/treeShakeCareIcons.mts b/plugins/treeShakeCareIcons.ts similarity index 100% rename from plugins/treeShakeCareIcons.mts rename to plugins/treeShakeCareIcons.ts From 5f9434fc6c86f5306386ce9d59d3062737ff2330 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 16:59:30 +0530 Subject: [PATCH 05/19] fixes part 3 --- src/Components/Common/Export.tsx | 2 +- .../Facility/DoctorVideoSlideover.tsx | 11 ++++- src/Components/Facility/FacilityUsers.tsx | 14 ++---- .../Facility/PatientConsultationNotesList.tsx | 44 ++++++++++--------- .../Form/FormFields/DosageFormField.tsx | 6 +-- .../Form/FormFields/OtpFormField.tsx | 2 +- src/Components/HCX/validators.ts | 2 +- .../Medicine/AdministerMedicine.tsx | 4 +- src/Components/Medicine/models.ts | 2 +- 9 files changed, 45 insertions(+), 42 deletions(-) diff --git a/src/Components/Common/Export.tsx b/src/Components/Common/Export.tsx index e94a2826398..72d5f447e57 100644 --- a/src/Components/Common/Export.tsx +++ b/src/Components/Common/Export.tsx @@ -52,7 +52,7 @@ export const ExportMenu = ({ ghost className="py-2.5" > - + {isExporting ? "Exporting..." : label} ); diff --git a/src/Components/Facility/DoctorVideoSlideover.tsx b/src/Components/Facility/DoctorVideoSlideover.tsx index 998528217f2..edce8f67aeb 100644 --- a/src/Components/Facility/DoctorVideoSlideover.tsx +++ b/src/Components/Facility/DoctorVideoSlideover.tsx @@ -107,6 +107,12 @@ export default function DoctorVideoSlideover(props: { ); } +type MSLaunchURI = ( + uri: string, + successCB?: null | (() => void), + noHandlerCB?: null | (() => void) +) => void; + function UserListItem(props: { user: UserAssignedModel }) { const user = props.user; const icon: IconName = @@ -141,8 +147,9 @@ function UserListItem(props: { user: UserAssignedModel }) { }; if (isEdge) { - if (navigator.msLaunchUri) { - navigator.msLaunchUri(whatsappAppURL, null, openWhatsAppWebFallback); + if ("msLaunchUri" in navigator) { + const launch = navigator.msLaunchUri as MSLaunchURI; + launch(whatsappAppURL, null, openWhatsAppWebFallback); } else { openWhatsAppWebFallback(); } diff --git a/src/Components/Facility/FacilityUsers.tsx b/src/Components/Facility/FacilityUsers.tsx index 781dbad9e40..c60b7cd5268 100644 --- a/src/Components/Facility/FacilityUsers.tsx +++ b/src/Components/Facility/FacilityUsers.tsx @@ -21,7 +21,6 @@ import useAuthUser from "../../Common/hooks/useAuthUser"; import request from "../../Utils/request/request"; import routes from "../../Redux/api"; import useQuery from "../../Utils/request/useQuery"; -import { UserModel } from "../Users/models"; const Loading = lazy(() => import("../Common/Loading")); @@ -262,7 +261,7 @@ export default function FacilityUsers(props: any) { facilityUserData && facilityUserData.results && facilityUserData.results.length && - (userList = facilityUserData.results.map((user: UserModel) => { + (userList = facilityUserData.results.map((user) => { return (
)}
- {user.created_by && ( - -
{user.created_by}
-
- )} {user.phone_number && (
@@ -359,9 +353,9 @@ export default function FacilityUsers(props: any) { {user.username && ( - {user.facilities && - showFacilities(user.username, user.facilities)} - {!user.facilities && ( + {(user as any).facilities && + showFacilities(user.username, (user as any).facilities)} + {!(user as any).facilities && ( loadFacilities(user.username)} className={`inline-block ${facilityClassname}`} diff --git a/src/Components/Facility/PatientConsultationNotesList.tsx b/src/Components/Facility/PatientConsultationNotesList.tsx index 2b9df8c3902..35822508d4b 100644 --- a/src/Components/Facility/PatientConsultationNotesList.tsx +++ b/src/Components/Facility/PatientConsultationNotesList.tsx @@ -1,4 +1,4 @@ -import { useEffect, useState } from "react"; +import { Dispatch, SetStateAction, useEffect, useState } from "react"; import { RESULTS_PER_PAGE_LIMIT } from "../../Common/constants"; import CircularProgress from "../Common/components/CircularProgress"; import routes from "../../Redux/api"; @@ -9,9 +9,9 @@ import request from "../../Utils/request/request"; interface PatientNotesProps { state: PatientNoteStateType; - setState: any; + setState: Dispatch>; reload?: boolean; - setReload?: any; + setReload?: (value: boolean) => void; disableEdit?: boolean; } @@ -25,9 +25,9 @@ const PatientConsultationNotesList = (props: PatientNotesProps) => { const fetchNotes = async () => { setIsLoading(true); - const { data }: any = await request(routes.getPatientNotes, { + const { data } = await request(routes.getPatientNotes, { pathParams: { - patientId: props.state.patientId, + patientId: props.state.patientId || "", }, query: { consultation: consultationId, @@ -35,21 +35,23 @@ const PatientConsultationNotesList = (props: PatientNotesProps) => { }, }); - if (state.cPage === 1) { - setState((prevState: any) => ({ - ...prevState, - notes: data.results, - totalPages: Math.ceil(data.count / pageSize), - })); - } else { - setState((prevState: any) => ({ - ...prevState, - notes: [...prevState.notes, ...data.results], - totalPages: Math.ceil(data.count / pageSize), - })); + if (data) { + if (state.cPage === 1) { + setState((prevState) => ({ + ...prevState, + notes: data.results, + totalPages: Math.ceil(data.count / pageSize), + })); + } else { + setState((prevState) => ({ + ...prevState, + notes: [...prevState.notes, ...data.results], + totalPages: Math.ceil(data.count / pageSize), + })); + } } setIsLoading(false); - setReload(false); + setReload?.(false); }; useEffect(() => { @@ -59,16 +61,16 @@ const PatientConsultationNotesList = (props: PatientNotesProps) => { }, [reload]); useEffect(() => { - setReload(true); + setReload?.(true); }, []); const handleNext = () => { if (state.cPage < state.totalPages) { - setState((prevState: any) => ({ + setState((prevState) => ({ ...prevState, cPage: prevState.cPage + 1, })); - setReload(true); + setReload?.(true); } }; diff --git a/src/Components/Form/FormFields/DosageFormField.tsx b/src/Components/Form/FormFields/DosageFormField.tsx index 5f669701913..14afc18806b 100644 --- a/src/Components/Form/FormFields/DosageFormField.tsx +++ b/src/Components/Form/FormFields/DosageFormField.tsx @@ -1,8 +1,8 @@ -import { DOSAGE_UNITS } from "../../Medicine/models"; +import { DOSAGE_UNITS, DosageValue } from "../../Medicine/models"; import NumericWithUnitsFormField from "./NumericWithUnitsFormField"; import { FormFieldBaseProps } from "./Utils"; -type Props = FormFieldBaseProps & { +type Props = FormFieldBaseProps & { placeholder?: string; autoComplete?: string; min?: string | number; @@ -10,5 +10,5 @@ type Props = FormFieldBaseProps & { }; export default function DosageFormField(props: Props) { - return ; + return ; } diff --git a/src/Components/Form/FormFields/OtpFormField.tsx b/src/Components/Form/FormFields/OtpFormField.tsx index 904675db833..ad2a0817f58 100644 --- a/src/Components/Form/FormFields/OtpFormField.tsx +++ b/src/Components/Form/FormFields/OtpFormField.tsx @@ -13,7 +13,7 @@ const OtpFormField = ({ length = 6, ...props }: TextAreaFormFieldProps) => { const inputs = useRef>({}); return ( - +
{new Array(length).fill(null).map((_, i) => ( = ( if ( !value.policy_id.trim() || !value.subscriber_id.trim() || - (enable_hcx && (!value.insurer_id.trim() || !value.insurer_name.trim())) + (enable_hcx && (!value.insurer_id?.trim() || !value.insurer_name?.trim())) ) return "All fields are mandatory"; }; diff --git a/src/Components/Medicine/AdministerMedicine.tsx b/src/Components/Medicine/AdministerMedicine.tsx index f7353051ea7..6f5822e8604 100644 --- a/src/Components/Medicine/AdministerMedicine.tsx +++ b/src/Components/Medicine/AdministerMedicine.tsx @@ -1,6 +1,6 @@ import { useState } from "react"; import ConfirmDialog from "../Common/ConfirmDialog"; -import { Prescription } from "./models"; +import { DosageValue, Prescription } from "./models"; import TextAreaFormField from "../Form/FormFields/TextAreaFormField"; import { Success } from "../../Utils/Notifications"; import PrescriptionDetailCard from "./PrescriptionDetailCard"; @@ -26,7 +26,7 @@ export default function AdministerMedicine({ prescription, ...props }: Props) { const consultation = useSlug("consultation"); const [isLoading, setIsLoading] = useState(false); const [notes, setNotes] = useState(""); - const [dosage, setDosage] = useState(); + const [dosage, setDosage] = useState(); const [error, setError] = useState(); const [isCustomTime, setIsCustomTime] = useState(false); const [customTime, setCustomTime] = useState( diff --git a/src/Components/Medicine/models.ts b/src/Components/Medicine/models.ts index 1a5f6fe8a13..53fd39d90f8 100644 --- a/src/Components/Medicine/models.ts +++ b/src/Components/Medicine/models.ts @@ -68,7 +68,7 @@ export type MedicineAdministrationRecord = { readonly id: string; readonly prescription: Prescription; notes: string; - dosage?: string; + dosage?: DosageValue; administered_date?: string; readonly administered_by: PerformedByModel; readonly archived_by: PerformedByModel | undefined; From 781d750756216025adc1f3123fa49022f886cb01 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 17:47:51 +0530 Subject: [PATCH 06/19] fixes part 4 --- .../Facility/Consultations/DailyRoundsList.tsx | 16 +++++----------- src/Components/HCX/InsuranceDetailsBuilder.tsx | 2 +- src/Components/Patient/models.tsx | 12 ++---------- 3 files changed, 8 insertions(+), 22 deletions(-) diff --git a/src/Components/Facility/Consultations/DailyRoundsList.tsx b/src/Components/Facility/Consultations/DailyRoundsList.tsx index 76d48ec86ba..dc329d580b2 100644 --- a/src/Components/Facility/Consultations/DailyRoundsList.tsx +++ b/src/Components/Facility/Consultations/DailyRoundsList.tsx @@ -13,6 +13,7 @@ import { useSlugs } from "../../../Common/hooks/useSlug"; import Timeline, { TimelineNode } from "../../../CAREUI/display/Timeline"; import { useState } from "react"; import { QueryParams } from "../../../Utils/request/types"; +import { UserRole } from "../../../Common/constants"; interface Props { consultation: ConsultationModel; @@ -61,11 +62,12 @@ export default function DailyRoundsList({ consultation }: Props) { type: "created", timestamp: item.taken_at?.toString() ?? "", by: { - user_type: "", + user_type: + "Virtual Nursing Assistant" as UserRole, first_name: "Virtual", last_name: "Assistant", username: "", - id: "", + id: -1, email: "", last_login: "", }, @@ -92,15 +94,7 @@ export default function DailyRoundsList({ consultation }: Props) { event={{ type: "created", timestamp: item.taken_at?.toString() ?? "", - by: { - user_type: item.created_by?.user_type ?? "", - first_name: item.created_by?.first_name ?? "", - last_name: item.created_by?.last_name ?? "", - username: "", - id: "", - email: "", - last_login: "", - }, + by: item.created_by, icon: "l-user-nurse", }} isLast={items.indexOf(item) == items.length - 1} diff --git a/src/Components/HCX/InsuranceDetailsBuilder.tsx b/src/Components/HCX/InsuranceDetailsBuilder.tsx index c507566a259..9c2e1190f99 100644 --- a/src/Components/HCX/InsuranceDetailsBuilder.tsx +++ b/src/Components/HCX/InsuranceDetailsBuilder.tsx @@ -95,7 +95,7 @@ const InsuranceDetailEditCard = ({ }) => { const { enable_hcx } = useConfig(); const seletedInsurer = - policy.insurer_id || policy.insurer_name + policy.insurer_id && policy.insurer_name ? { code: policy.insurer_id, name: policy.insurer_name } : undefined; diff --git a/src/Components/Patient/models.tsx b/src/Components/Patient/models.tsx index f1d854c53b5..20e651a703f 100644 --- a/src/Components/Patient/models.tsx +++ b/src/Components/Patient/models.tsx @@ -328,16 +328,8 @@ export interface DailyRoundsModel { rounds_type?: (typeof DailyRoundTypes)[number]; last_updated_by_telemedicine?: boolean; created_by_telemedicine?: boolean; - created_by?: { - first_name?: string; - last_name?: string; - user_type?: string; - }; - last_edited_by?: { - first_name?: string; - last_name?: string; - user_type?: string; - }; + created_by?: PerformedByModel; + last_edited_by?: PerformedByModel; bed?: string; } From af1753fae37bba60a00da47b497a63c80c270a33 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 17:56:28 +0530 Subject: [PATCH 07/19] fixes facility select using -1 for id --- src/Components/Common/FacilitySelect.tsx | 1 - src/Components/Facility/ConsultationForm.tsx | 14 ++++++-------- .../Facility/Consultations/DailyRoundsList.tsx | 2 +- src/Components/Facility/DischargeModal.tsx | 8 +++----- src/Components/Patient/ShiftCreate.tsx | 16 +++++----------- src/Components/Shifting/ShiftDetailsUpdate.tsx | 12 ++++-------- 6 files changed, 19 insertions(+), 34 deletions(-) diff --git a/src/Components/Common/FacilitySelect.tsx b/src/Components/Common/FacilitySelect.tsx index b207189d27d..cac9958db4f 100644 --- a/src/Components/Common/FacilitySelect.tsx +++ b/src/Components/Common/FacilitySelect.tsx @@ -56,7 +56,6 @@ export const FacilitySelect = (props: FacilitySelectProps) => { if (freeText) data?.results?.push({ - id: -1, name: text, }); return data?.results; diff --git a/src/Components/Facility/ConsultationForm.tsx b/src/Components/Facility/ConsultationForm.tsx index ea49f24871b..8c5fcd872e4 100644 --- a/src/Components/Facility/ConsultationForm.tsx +++ b/src/Components/Facility/ConsultationForm.tsx @@ -373,7 +373,6 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { if (res.data.suggestion === "R") { if (res.data.referred_to_external) setReferredToFacility({ - id: -1, name: res.data.referred_to_external, }); else setReferredToFacility(res.data.referred_to_object); @@ -381,7 +380,6 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { if (res.data.route_to_facility === 20) { if (res.data.referred_from_facility_external) setReferredFromFacility({ - id: -1, name: res.data.referred_from_facility_external, }); else setReferredFromFacility(res.data.referred_from_facility_object); @@ -854,12 +852,12 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { const selectedFacility = selected as FacilityModel; setReferredToFacility(selectedFacility); const form: FormDetails = { ...state.form }; - if (selectedFacility?.id) { - if (selectedFacility.id === -1) { + if (selectedFacility) { + if (!selectedFacility.id) { form.referred_to_external = selectedFacility.name ?? ""; delete form.referred_to; } else { - form.referred_to = selectedFacility.id.toString() || ""; + form.referred_to = selectedFacility.id; delete form.referred_to_external; } } @@ -872,12 +870,12 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { const selectedFacility = selected as FacilityModel; setReferredFromFacility(selectedFacility); const form: FormDetails = { ...state.form }; - if (selectedFacility?.id) { - if (selectedFacility.id === -1) { + if (selectedFacility) { + if (!selectedFacility.id) { form.referred_from_facility_external = selectedFacility.name ?? ""; delete form.referred_from_facility; } else { - form.referred_from_facility = selectedFacility.id.toString() || ""; + form.referred_from_facility = selectedFacility.id; delete form.referred_from_facility_external; } } diff --git a/src/Components/Facility/Consultations/DailyRoundsList.tsx b/src/Components/Facility/Consultations/DailyRoundsList.tsx index dc329d580b2..dca876c08d5 100644 --- a/src/Components/Facility/Consultations/DailyRoundsList.tsx +++ b/src/Components/Facility/Consultations/DailyRoundsList.tsx @@ -69,7 +69,7 @@ export default function DailyRoundsList({ consultation }: Props) { username: "", id: -1, email: "", - last_login: "", + last_login: new Date().toISOString(), }, icon: "l-robot", }} diff --git a/src/Components/Facility/DischargeModal.tsx b/src/Components/Facility/DischargeModal.tsx index e3952ed0825..50108329f9d 100644 --- a/src/Components/Facility/DischargeModal.tsx +++ b/src/Components/Facility/DischargeModal.tsx @@ -31,7 +31,7 @@ interface PreDischargeFormInterface { discharge_date?: string; death_datetime?: string; death_confirmed_doctor?: string; - referred_to?: number | null | undefined; + referred_to?: string | null | undefined; referred_to_external?: string | null | undefined; } @@ -167,12 +167,10 @@ const DischargeModal = ({ const handleFacilitySelect = (selected: FacilityModel) => { setFacility(selected); - const { id, name } = selected || {}; - const isExternal = id === -1; setPreDischargeForm((prev) => ({ ...prev, - referred_to: isExternal ? null : id, - referred_to_external: isExternal ? name : null, + referred_to: selected.id ?? null, + referred_to_external: !selected.id ? selected.name : null, })); }; diff --git a/src/Components/Patient/ShiftCreate.tsx b/src/Components/Patient/ShiftCreate.tsx index 0323ddb7c4b..6cb3cd90692 100644 --- a/src/Components/Patient/ShiftCreate.tsx +++ b/src/Components/Patient/ShiftCreate.tsx @@ -202,17 +202,11 @@ export const ShiftCreate = (props: patientShiftProps) => { const data = { status: wartime_shifting ? "PENDING" : "APPROVED", origin_facility: props.facilityId, - shifting_approving_facility: ( - state.form.shifting_approving_facility || {} - ).id, - assigned_facility: - state.form?.assigned_facility?.id != -1 - ? state.form?.assigned_facility?.id - : null, - assigned_facility_external: - state.form?.assigned_facility?.id === -1 - ? state.form?.assigned_facility?.name - : null, + shifting_approving_facility: state.form.shifting_approving_facility?.id, + assigned_facility: state.form?.assigned_facility?.id, + assigned_facility_external: !state.form?.assigned_facility?.id + ? state.form?.assigned_facility?.name + : null, patient: props.patientId, emergency: state.form.emergency === "true", is_up_shift: state.form.is_up_shift === "true", diff --git a/src/Components/Shifting/ShiftDetailsUpdate.tsx b/src/Components/Shifting/ShiftDetailsUpdate.tsx index 4c736ed2244..a3df51fa289 100644 --- a/src/Components/Shifting/ShiftDetailsUpdate.tsx +++ b/src/Components/Shifting/ShiftDetailsUpdate.tsx @@ -197,14 +197,10 @@ export const ShiftDetailsUpdate = (props: patientShiftProps) => { origin_facility: state.form.origin_facility_object?.id, shifting_approving_facility: state.form?.shifting_approving_facility_object?.id, - assigned_facility: - state.form?.assigned_facility_object?.id != -1 - ? state.form?.assigned_facility_object?.id - : null, - assigned_facility_external: - state.form?.assigned_facility_object?.id === -1 - ? state.form?.assigned_facility_object?.name - : null, + assigned_facility: state.form?.assigned_facility_object?.id, + assigned_facility_external: !state.form?.assigned_facility_object?.id + ? state.form?.assigned_facility_object?.name + : null, patient: state.form.patient_object?.id, emergency: [true, "true"].includes(state.form.emergency), is_kasp: [true, "true"].includes(state.form.is_kasp), From 4920f9614a9d51a4153e489054ba32cc599a8b53 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 18:03:03 +0530 Subject: [PATCH 08/19] fixes type errors in daily rounds --- src/Components/Common/BloodPressureFormField.tsx | 4 +--- .../DailyRounds/LogUpdateCardAttribute.tsx | 14 ++++++++++---- src/Components/Patient/models.tsx | 14 ++++++++------ 3 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/Components/Common/BloodPressureFormField.tsx b/src/Components/Common/BloodPressureFormField.tsx index e64b2a15ff6..3f7ecacce46 100644 --- a/src/Components/Common/BloodPressureFormField.tsx +++ b/src/Components/Common/BloodPressureFormField.tsx @@ -6,9 +6,7 @@ import { FormFieldBaseProps, useFormFieldPropsResolver, } from "../Form/FormFields/Utils"; -import { DailyRoundsModel } from "../Patient/models"; - -type BloodPressure = NonNullable; +import { BloodPressure } from "../Patient/models"; type Props = FormFieldBaseProps; diff --git a/src/Components/Facility/Consultations/DailyRounds/LogUpdateCardAttribute.tsx b/src/Components/Facility/Consultations/DailyRounds/LogUpdateCardAttribute.tsx index a5bdd26c09c..3afed28dda8 100644 --- a/src/Components/Facility/Consultations/DailyRounds/LogUpdateCardAttribute.tsx +++ b/src/Components/Facility/Consultations/DailyRounds/LogUpdateCardAttribute.tsx @@ -1,5 +1,10 @@ import PatientCategoryBadge from "../../../Common/PatientCategoryBadge"; -import { DailyRoundsModel } from "../../../Patient/models"; +import { + BloodPressure, + DailyRoundsModel, + DailyRoundsOutput, +} from "../../../Patient/models"; +import { PatientCategory } from "../../models"; interface Props { attributeKey: T; @@ -28,7 +33,7 @@ const LogUpdateCardAttribute = ({ return (
- +
); @@ -37,7 +42,8 @@ const LogUpdateCardAttribute = ({
- {attributeValue.systolic}/{attributeValue.diastolic} mmHg + {(attributeValue as BloodPressure).systolic}/ + {(attributeValue as BloodPressure).diastolic} mmHg
); @@ -47,7 +53,7 @@ const LogUpdateCardAttribute = ({
- {attributeValue.map((output: any) => ( + {(attributeValue as DailyRoundsOutput[]).map((output) => ( {output.name}: {output.quantity} diff --git a/src/Components/Patient/models.tsx b/src/Components/Patient/models.tsx index 20e651a703f..d62a66dbfca 100644 --- a/src/Components/Patient/models.tsx +++ b/src/Components/Patient/models.tsx @@ -282,6 +282,12 @@ export const DailyRoundTypes = [ "TELEMEDICINE", ] as const; +export interface BloodPressure { + diastolic?: number; + mean?: number; + systolic?: number; +} + export interface DailyRoundsModel { ventilator_spo2?: number; ventilator_interface?: @@ -292,11 +298,7 @@ export interface DailyRoundsModel { spo2?: string; rhythm?: string; rhythm_detail?: string; - bp?: { - diastolic?: number; - mean?: number; - systolic?: number; - }; + bp?: BloodPressure; pulse?: number; resp?: number; temperature?: string; @@ -312,7 +314,7 @@ export interface DailyRoundsModel { other_symptoms?: string; admitted_to?: string; patient_category?: PatientCategory; - output?: DailyRoundsOutput; + output?: DailyRoundsOutput[]; recommend_discharge?: boolean; created_date?: string; modified_date?: string; From c168dadea9e8851e422d957082edbbf457a42b79 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 18:28:16 +0530 Subject: [PATCH 09/19] fixes #7482 --- src/Common/constants.tsx | 2 +- src/Components/Facility/models.tsx | 8 ++++++-- src/Components/Patient/PatientInfoCard.tsx | 2 +- 3 files changed, 8 insertions(+), 4 deletions(-) diff --git a/src/Common/constants.tsx b/src/Common/constants.tsx index 8ad2e72032c..e0565a0083e 100644 --- a/src/Common/constants.tsx +++ b/src/Common/constants.tsx @@ -315,7 +315,7 @@ export const DISCHARGE_REASONS = [ { id: 2, text: "Referred" }, { id: 3, text: "Expired" }, { id: 4, text: "LAMA" }, -]; +] as const; export const CONSCIOUSNESS_LEVEL = [ { id: "UNRESPONSIVE", text: "Unresponsive" }, diff --git a/src/Components/Facility/models.tsx b/src/Components/Facility/models.tsx index a04a16f7863..9d8309ae660 100644 --- a/src/Components/Facility/models.tsx +++ b/src/Components/Facility/models.tsx @@ -1,4 +1,8 @@ -import { ConsultationSuggestionValue, UserRole } from "../../Common/constants"; +import { + ConsultationSuggestionValue, + DISCHARGE_REASONS, + UserRole, +} from "../../Common/constants"; import { AssetData, AssetLocationType } from "../Assets/AssetTypes"; import { RouteToFacility } from "../Common/RouteToFacilitySelect"; import { InvestigationType } from "../Common/prescription-builder/InvestigationBuilder"; @@ -104,7 +108,7 @@ export interface ConsultationModel { category?: PatientCategory; created_date?: string; discharge_date?: string; - new_discharge_reason?: number; + new_discharge_reason?: (typeof DISCHARGE_REASONS)[number]["id"]; discharge_prescription?: NormalPrescription; discharge_prn_prescription?: PRNPrescription; discharge_notes?: string; diff --git a/src/Components/Patient/PatientInfoCard.tsx b/src/Components/Patient/PatientInfoCard.tsx index 99d786cd57f..284341b746c 100644 --- a/src/Components/Patient/PatientInfoCard.tsx +++ b/src/Components/Patient/PatientInfoCard.tsx @@ -375,7 +375,7 @@ export default function PatientInfoCard(props: { } {" "} on {formatDateTime(consultation.encounter_date)}, - {consultation?.new_discharge_reason === "EXP" ? ( + {consultation?.new_discharge_reason === 3 ? ( {" "} Expired on{" "} From 6a78786e026516d1953b9f13fd1ac06925b11a7a Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 18:30:54 +0530 Subject: [PATCH 10/19] some minor fixes.. --- src/Common/utils.tsx | 2 +- src/Components/Patient/PatientRegister.tsx | 12 ++++-------- 2 files changed, 5 insertions(+), 9 deletions(-) diff --git a/src/Common/utils.tsx b/src/Common/utils.tsx index 3596469a6d5..b1e98a9e196 100644 --- a/src/Common/utils.tsx +++ b/src/Common/utils.tsx @@ -31,7 +31,7 @@ export const useAbortableEffect = ( }; export const parseOptionId: ( - options: OptionsType[], + options: readonly OptionsType[], id: string | string[] ) => string = (options, id) => { const textArray = options diff --git a/src/Components/Patient/PatientRegister.tsx b/src/Components/Patient/PatientRegister.tsx index 188b974fe25..4d022b85af2 100644 --- a/src/Components/Patient/PatientRegister.tsx +++ b/src/Components/Patient/PatientRegister.tsx @@ -222,7 +222,7 @@ export const PatientRegister = (props: PatientRegisterProps) => { useEffect(() => { if (extId && formField) { setCareExtId(extId); - fetchExtResultData(null, formField); + fetchExtResultData(formField); } }, [careExtId, formField]); @@ -284,8 +284,7 @@ export const PatientRegister = (props: PatientRegisterProps) => { } }; - const fetchExtResultData = async (e: any, field: any) => { - if (e) e.preventDefault(); + const fetchExtResultData = async (field: any) => { if (!careExtId) return; const { res, data } = await request(routes.externalResult, { pathParams: { id: careExtId }, @@ -312,10 +311,6 @@ export const PatientRegister = (props: PatientRegisterProps) => { ? parseGenderFromExt(data.gender, state.form.gender) : state.form.gender, }); - field.onChange({ - name: "occupation", - value: data.meta_info?.occupation ?? state.form.occupation, - }); field.onChange({ name: "test_id", value: data.test_id ? data.test_id : state.form.test_id, @@ -1120,7 +1115,8 @@ export const PatientRegister = (props: PatientRegisterProps) => { id="submit-importexternalresult-button" className="btn btn-primary mr-4" onClick={(e) => { - fetchExtResultData(e, showImport?.field?.("name")); + e.preventDefault(); + fetchExtResultData(showImport?.field?.("name")); }} disabled={!careExtId} > From eab02535a9bf50d93dc6e1fe2660bd3da35a9083 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 18:40:32 +0530 Subject: [PATCH 11/19] fixes #7473 --- src/Components/Facility/DoctorNote.tsx | 1 - src/Components/Facility/PatientNoteCard.tsx | 14 +++++--------- 2 files changed, 5 insertions(+), 10 deletions(-) diff --git a/src/Components/Facility/DoctorNote.tsx b/src/Components/Facility/DoctorNote.tsx index 1fe28ba38d0..13e490cbd05 100644 --- a/src/Components/Facility/DoctorNote.tsx +++ b/src/Components/Facility/DoctorNote.tsx @@ -33,7 +33,6 @@ const DoctorNote = (props: DoctorNoteProps) => { > {state.notes.map((note: any) => ( { + const patientId = useSlug("patient"); const [isEditing, setIsEditing] = useState(false); const [noteField, setNoteField] = useState(note.note); const [showEditHistory, setShowEditHistory] = useState(false); @@ -36,7 +32,7 @@ const PatientNoteCard = ({ const fetchEditHistory = async () => { const { res, data } = await request(routes.getPatientNoteEditHistory, { - pathParams: { patientId: state.patientId, noteId: note.id }, + pathParams: { patientId, noteId: note.id }, }); if (res?.status === 200) { setEditHistory(data?.results ?? []); @@ -59,7 +55,7 @@ const PatientNoteCard = ({ } const { res } = await request(routes.updatePatientNote, { - pathParams: { patientId: state.patientId, noteId: note.id }, + pathParams: { patientId, noteId: note.id }, body: payload, }); if (res?.status === 200) { From 817eef96e504973587e1327db6c1552211e7e6a5 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 18:49:08 +0530 Subject: [PATCH 12/19] update lockfile --- package-lock.json | 209 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 209 insertions(+) diff --git a/package-lock.json b/package-lock.json index 95740c96295..cbf4af46757 100644 --- a/package-lock.json +++ b/package-lock.json @@ -74,6 +74,7 @@ "@tailwindcss/typography": "^0.5.9", "@types/cypress": "^1.1.3", "@types/echarts": "^4.9.18", + "@types/google.maps": "^3.55.5", "@types/lodash-es": "^4.17.9", "@types/qrcode.react": "^1.0.2", "@types/react": "18.2.14", @@ -119,6 +120,7 @@ "tailwindcss": "^3.3.3", "typescript": "^5.1.6", "vite": "^5.1.3", + "vite-plugin-checker": "^0.6.4", "vite-plugin-pwa": "^0.18.2" }, "engines": { @@ -6360,6 +6362,12 @@ "@types/node": "*" } }, + "node_modules/@types/google.maps": { + "version": "3.55.5", + "resolved": "https://registry.npmjs.org/@types/google.maps/-/google.maps-3.55.5.tgz", + "integrity": "sha512-U1QwCo1GeeLm0YI/GoHvfd1VfwgnoUSBcKCMXXFAM+2izSSuqqwZUJ9XNO6NxZxmYKjBNI+NF5eGF6uUSb1aSg==", + "dev": true + }, "node_modules/@types/graceful-fs": { "version": "4.1.9", "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.9.tgz", @@ -24727,6 +24735,111 @@ } } }, + "node_modules/vite-plugin-checker": { + "version": "0.6.4", + "resolved": "https://registry.npmjs.org/vite-plugin-checker/-/vite-plugin-checker-0.6.4.tgz", + "integrity": "sha512-2zKHH5oxr+ye43nReRbC2fny1nyARwhxdm0uNYp/ERy4YvU9iZpNOsueoi/luXw5gnpqRSvjcEPxXbS153O2wA==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.12.13", + "ansi-escapes": "^4.3.0", + "chalk": "^4.1.1", + "chokidar": "^3.5.1", + "commander": "^8.0.0", + "fast-glob": "^3.2.7", + "fs-extra": "^11.1.0", + "npm-run-path": "^4.0.1", + "semver": "^7.5.0", + "strip-ansi": "^6.0.0", + "tiny-invariant": "^1.1.0", + "vscode-languageclient": "^7.0.0", + "vscode-languageserver": "^7.0.0", + "vscode-languageserver-textdocument": "^1.0.1", + "vscode-uri": "^3.0.2" + }, + "engines": { + "node": ">=14.16" + }, + "peerDependencies": { + "eslint": ">=7", + "meow": "^9.0.0", + "optionator": "^0.9.1", + "stylelint": ">=13", + "typescript": "*", + "vite": ">=2.0.0", + "vls": "*", + "vti": "*", + "vue-tsc": ">=1.3.9" + }, + "peerDependenciesMeta": { + "eslint": { + "optional": true + }, + "meow": { + "optional": true + }, + "optionator": { + "optional": true + }, + "stylelint": { + "optional": true + }, + "typescript": { + "optional": true + }, + "vls": { + "optional": true + }, + "vti": { + "optional": true + }, + "vue-tsc": { + "optional": true + } + } + }, + "node_modules/vite-plugin-checker/node_modules/commander": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", + "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", + "dev": true, + "engines": { + "node": ">= 12" + } + }, + "node_modules/vite-plugin-checker/node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/vite-plugin-checker/node_modules/semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/vite-plugin-checker/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, "node_modules/vite-plugin-pwa": { "version": "0.18.2", "resolved": "https://registry.npmjs.org/vite-plugin-pwa/-/vite-plugin-pwa-0.18.2.tgz", @@ -25199,6 +25312,102 @@ "node": ">=0.10.0" } }, + "node_modules/vscode-jsonrpc": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-6.0.0.tgz", + "integrity": "sha512-wnJA4BnEjOSyFMvjZdpiOwhSq9uDoK8e/kpRJDTaMYzwlkrhG1fwDIZI94CLsLzlCK5cIbMMtFlJlfR57Lavmg==", + "dev": true, + "engines": { + "node": ">=8.0.0 || >=10.0.0" + } + }, + "node_modules/vscode-languageclient": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/vscode-languageclient/-/vscode-languageclient-7.0.0.tgz", + "integrity": "sha512-P9AXdAPlsCgslpP9pRxYPqkNYV7Xq8300/aZDpO35j1fJm/ncize8iGswzYlcvFw5DQUx4eVk+KvfXdL0rehNg==", + "dev": true, + "dependencies": { + "minimatch": "^3.0.4", + "semver": "^7.3.4", + "vscode-languageserver-protocol": "3.16.0" + }, + "engines": { + "vscode": "^1.52.0" + } + }, + "node_modules/vscode-languageclient/node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/vscode-languageclient/node_modules/semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/vscode-languageclient/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/vscode-languageserver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-7.0.0.tgz", + "integrity": "sha512-60HTx5ID+fLRcgdHfmz0LDZAXYEV68fzwG0JWwEPBode9NuMYTIxuYXPg4ngO8i8+Ou0lM7y6GzaYWbiDL0drw==", + "dev": true, + "dependencies": { + "vscode-languageserver-protocol": "3.16.0" + }, + "bin": { + "installServerIntoExtension": "bin/installServerIntoExtension" + } + }, + "node_modules/vscode-languageserver-protocol": { + "version": "3.16.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.16.0.tgz", + "integrity": "sha512-sdeUoAawceQdgIfTI+sdcwkiK2KU+2cbEYA0agzM2uqaUy2UpnnGHtWTHVEtS0ES4zHU0eMFRGN+oQgDxlD66A==", + "dev": true, + "dependencies": { + "vscode-jsonrpc": "6.0.0", + "vscode-languageserver-types": "3.16.0" + } + }, + "node_modules/vscode-languageserver-textdocument": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.11.tgz", + "integrity": "sha512-X+8T3GoiwTVlJbicx/sIAF+yuJAqz8VvwJyoMVhwEMoEKE/fkDmrqUgDMyBECcM2A2frVZIUj5HI/ErRXCfOeA==", + "dev": true + }, + "node_modules/vscode-languageserver-types": { + "version": "3.16.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.16.0.tgz", + "integrity": "sha512-k8luDIWJWyenLc5ToFQQMaSrqCHiLwyKPHKPQZ5zz21vM+vIVUSvsRpcbiECH4WR88K2XZqc4ScRcZ7nk/jbeA==", + "dev": true + }, + "node_modules/vscode-uri": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.8.tgz", + "integrity": "sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==", + "dev": true + }, "node_modules/walk-up-path": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/walk-up-path/-/walk-up-path-3.0.1.tgz", From 485762b0316a7054a1785bb4d92a1e91b69b91d3 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 19:07:49 +0530 Subject: [PATCH 13/19] ignore generated files --- .prettierrc.json | 9 +++++++-- tsconfig.json | 5 ++++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/.prettierrc.json b/.prettierrc.json index 48552107a8d..96ff50bd324 100644 --- a/.prettierrc.json +++ b/.prettierrc.json @@ -5,5 +5,10 @@ "semi": true, "jsxSingleQuote": false, "arrowParens": "always", - "tailwindFunctions": ["classNames"] -} + "tailwindFunctions": [ + "classNames" + ], + "plugins": [ + "prettier-plugin-tailwindcss" + ] +} \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index ab2b142d3a4..23f7ab14d4a 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -17,5 +17,8 @@ "jsx": "react-jsx", "types": ["vite/client", "vite-plugin-pwa/client"] }, - "include": ["src"] + "include": ["src"], + "exclude": [ + "src/**/*.gen.tsx" + ] } From c9b176a9ee048a2c4fea41f53e2b2d16b15825aa Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Wed, 27 Mar 2024 19:58:25 +0530 Subject: [PATCH 14/19] fix node 20 code present in codebase --- .../ConsultationDiagnosisBuilder.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Components/Diagnosis/ConsultationDiagnosisBuilder/ConsultationDiagnosisBuilder.tsx b/src/Components/Diagnosis/ConsultationDiagnosisBuilder/ConsultationDiagnosisBuilder.tsx index 43dc7810ee7..f2360109b78 100644 --- a/src/Components/Diagnosis/ConsultationDiagnosisBuilder/ConsultationDiagnosisBuilder.tsx +++ b/src/Components/Diagnosis/ConsultationDiagnosisBuilder/ConsultationDiagnosisBuilder.tsx @@ -29,7 +29,7 @@ export const CreateDiagnosesBuilder = (props: CreateDiagnosesProps) => { value={diagnosis} onChange={(action) => { if (action.type === "remove") { - props.onChange(props.value.toSpliced(index, 1)); + props.onChange([...props.value].splice(index, 1)); } if (action.type === "edit") { From fc9737b090e85116925264ad90d2639c68a844e5 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Mon, 1 Apr 2024 10:14:20 +0530 Subject: [PATCH 15/19] remove more errors --- src/Components/Facility/ConsultationForm.tsx | 16 +++++--- src/Components/Facility/FacilityUsers.tsx | 39 +------------------- 2 files changed, 11 insertions(+), 44 deletions(-) diff --git a/src/Components/Facility/ConsultationForm.tsx b/src/Components/Facility/ConsultationForm.tsx index 022e6671373..09d843c502e 100644 --- a/src/Components/Facility/ConsultationForm.tsx +++ b/src/Components/Facility/ConsultationForm.tsx @@ -304,7 +304,7 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { ref: treatmentPlanRef, }, "Consent Records": { - iconClass: "care-l-file-alt", + iconClass: "l-file-alt", visible: consentRecordsVisible, ref: consentRecordsRef, }, @@ -1614,13 +1614,14 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { } > { CONSENT_TYPE_CHOICES.find( @@ -1635,7 +1636,10 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => { setShowDeleteConsent(record.id); }} > - +
{ - setUserData({ - show: true, - username: user.username, - name: `${user.first_name} ${user.last_name}`, - }); - }; - const facilityClassname = classNames( "align-baseline text-sm font-bold", isAddFacilityLoading || isUnlinkFacilityLoading || isLoadFacilityLoading @@ -300,14 +285,6 @@ export default function FacilityUsers(props: any) { className="mt-2 flex gap-3 text-2xl font-bold capitalize" > {`${user.first_name} ${user.last_name}`} - {showUserDelete(authUser, user) && ( -
handleDelete(user)} - > - -
- )}
@@ -316,21 +293,7 @@ export default function FacilityUsers(props: any) {
{user.user_type}
)} - {user.district_object && ( - -
- {user.district_object.name} -
-
- )}
- {user.local_body_object && ( - -
- {user.local_body_object.name} -
-
- )}
{user.phone_number && (
From 670434c685b5f8815a49bfe55675d7dc3c01aebc Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Mon, 1 Apr 2024 10:18:30 +0530 Subject: [PATCH 16/19] run `lint-fix` --- .../ConsultationUpdatesTab.tsx | 2 +- .../Facility/DoctorVideoSlideover.tsx | 1 - src/Components/Facility/TreatmentSummary.tsx | 22 +++++++++---------- .../Form/FormFields/CheckBoxFormField.tsx | 2 +- 4 files changed, 13 insertions(+), 14 deletions(-) diff --git a/src/Components/Facility/ConsultationDetails/ConsultationUpdatesTab.tsx b/src/Components/Facility/ConsultationDetails/ConsultationUpdatesTab.tsx index b3aca51c615..f0885d75d5e 100644 --- a/src/Components/Facility/ConsultationDetails/ConsultationUpdatesTab.tsx +++ b/src/Components/Facility/ConsultationDetails/ConsultationUpdatesTab.tsx @@ -723,7 +723,7 @@ export const ConsultationUpdatesTab = (props: ConsultationTabProps) => { tab2={
Events - + beta
diff --git a/src/Components/Facility/DoctorVideoSlideover.tsx b/src/Components/Facility/DoctorVideoSlideover.tsx index 2d63a754c9e..7d41971545f 100644 --- a/src/Components/Facility/DoctorVideoSlideover.tsx +++ b/src/Components/Facility/DoctorVideoSlideover.tsx @@ -112,7 +112,6 @@ export default function DoctorVideoSlideover(props: { ); } - type MSLaunchURI = ( uri: string, successCB?: null | (() => void), diff --git a/src/Components/Facility/TreatmentSummary.tsx b/src/Components/Facility/TreatmentSummary.tsx index b55c86216a7..f3c59791d63 100644 --- a/src/Components/Facility/TreatmentSummary.tsx +++ b/src/Components/Facility/TreatmentSummary.tsx @@ -53,8 +53,8 @@ const TreatmentSummary = (props: any) => {
{formatDate(date)}
-
-
+
+
Name : {patientData?.name ?? ""}
@@ -62,9 +62,9 @@ const TreatmentSummary = (props: any) => {
-
-
-
+
+
+
Age :{" "} {formatAge( patientData?.age ?? 0, @@ -72,7 +72,7 @@ const TreatmentSummary = (props: any) => { true )}
-
+
OP : {consultationData?.patient_no ?? ""}
@@ -87,8 +87,8 @@ const TreatmentSummary = (props: any) => {
-
-
+
+
Gender : {GENDER_TYPES.find((i) => i.id === patientData?.gender)?.text}
@@ -106,7 +106,7 @@ const TreatmentSummary = (props: any) => {
Comorbidities : -
+
@@ -187,7 +187,7 @@ const TreatmentSummary = (props: any) => {
Relevant investigations : -
+
@@ -282,7 +282,7 @@ const TreatmentSummary = (props: any) => { )} Treatment summary/Treament Plan : -
+
diff --git a/src/Components/Form/FormFields/CheckBoxFormField.tsx b/src/Components/Form/FormFields/CheckBoxFormField.tsx index f3382d522de..c9ff52c23aa 100644 --- a/src/Components/Form/FormFields/CheckBoxFormField.tsx +++ b/src/Components/Form/FormFields/CheckBoxFormField.tsx @@ -8,7 +8,7 @@ export default function CheckBoxFormField(props: FormFieldBaseProps) {
Date: Mon, 1 Apr 2024 11:13:59 +0530 Subject: [PATCH 17/19] Switch off classnames order in eslint --- .eslintrc.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.eslintrc.json b/.eslintrc.json index b444a07c3c8..a2f7b667856 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -85,7 +85,7 @@ ], "tailwindcss/no-custom-classname": "off", "tailwindcss/migration-from-tailwind-2": "error", - "tailwindcss/classnames-order": "error", + "tailwindcss/classnames-order": "off", "tailwindcss/enforces-shorthand": "off", "tailwindcss/no-contradicting-classname": "error" }, From b58c673e59a7d1c18d1591c1ea90a3cce21d3a52 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Mon, 1 Apr 2024 13:06:40 +0530 Subject: [PATCH 18/19] fix lint from linux --- .../Common/Sidebar/SidebarUserCard.tsx | 4 ++-- .../Facility/CoverImageEditModal.tsx | 4 ++-- src/Components/Facility/TreatmentSummary.tsx | 22 +++++++++---------- src/Components/Patient/ManagePatients.tsx | 4 ++-- src/Components/Patient/PatientInfoCard.tsx | 2 +- src/Components/Patient/SampleViewAdmin.tsx | 2 +- 6 files changed, 19 insertions(+), 19 deletions(-) diff --git a/src/Components/Common/Sidebar/SidebarUserCard.tsx b/src/Components/Common/Sidebar/SidebarUserCard.tsx index 02170f453d7..d083867738c 100644 --- a/src/Components/Common/Sidebar/SidebarUserCard.tsx +++ b/src/Components/Common/Sidebar/SidebarUserCard.tsx @@ -31,7 +31,7 @@ const SidebarUserCard = ({ shrinked }: { shrinked: boolean }) => { shrinked ? "hidden" : "grow" } flex min-w-0 flex-col pb-2 pl-3`} > -
+
{
{!isCameraOpen ? ( -
+ {hasImage ? ( <>
@@ -305,7 +305,7 @@ const CoverImageEditModal = ({
) : ( -
+
{t("capture_cover_photo")} diff --git a/src/Components/Facility/TreatmentSummary.tsx b/src/Components/Facility/TreatmentSummary.tsx index f3c59791d63..b55c86216a7 100644 --- a/src/Components/Facility/TreatmentSummary.tsx +++ b/src/Components/Facility/TreatmentSummary.tsx @@ -53,8 +53,8 @@ const TreatmentSummary = (props: any) => {
{formatDate(date)}
-
-
+
+
Name : {patientData?.name ?? ""}
@@ -62,9 +62,9 @@ const TreatmentSummary = (props: any) => {
-
-
-
+
+
+
Age :{" "} {formatAge( patientData?.age ?? 0, @@ -72,7 +72,7 @@ const TreatmentSummary = (props: any) => { true )}
-
+
OP : {consultationData?.patient_no ?? ""}
@@ -87,8 +87,8 @@ const TreatmentSummary = (props: any) => {
-
-
+
+
Gender : {GENDER_TYPES.find((i) => i.id === patientData?.gender)?.text}
@@ -106,7 +106,7 @@ const TreatmentSummary = (props: any) => {
Comorbidities : -
+
@@ -187,7 +187,7 @@ const TreatmentSummary = (props: any) => {
Relevant investigations : -
+
@@ -282,7 +282,7 @@ const TreatmentSummary = (props: any) => { )} Treatment summary/Treament Plan : -
+
diff --git a/src/Components/Patient/ManagePatients.tsx b/src/Components/Patient/ManagePatients.tsx index aacad50dc19..0c5dba7ca27 100644 --- a/src/Components/Patient/ManagePatients.tsx +++ b/src/Components/Patient/ManagePatients.tsx @@ -480,7 +480,7 @@ export const PatientManager = () => {
-
+
{patient?.last_consultation?.current_bed && patient?.last_consultation?.discharge_date === null ? (
@@ -515,7 +515,7 @@ export const PatientManager = () => {
) : ( -
+
{consultation?.current_bed && consultation?.discharge_date === null ? ( diff --git a/src/Components/Patient/SampleViewAdmin.tsx b/src/Components/Patient/SampleViewAdmin.tsx index d11d4ad23b2..431fc09a317 100644 --- a/src/Components/Patient/SampleViewAdmin.tsx +++ b/src/Components/Patient/SampleViewAdmin.tsx @@ -157,7 +157,7 @@ export default function SampleViewAdmin() {
{item.sample_type && ( - + Type: {item.sample_type} )} From 249f27f04c43537f37c48525db2bcc6d58c5e325 Mon Sep 17 00:00:00 2001 From: rithviknishad Date: Tue, 2 Apr 2024 16:01:57 +0530 Subject: [PATCH 19/19] fix lint --- .../Common/Sidebar/SidebarUserCard.tsx | 4 ++-- .../Facility/CoverImageEditModal.tsx | 4 ++-- src/Components/Facility/TreatmentSummary.tsx | 22 +++++++++---------- src/Components/Patient/ManagePatients.tsx | 4 ++-- src/Components/Patient/PatientInfoCard.tsx | 2 +- src/Components/Patient/SampleViewAdmin.tsx | 2 +- 6 files changed, 19 insertions(+), 19 deletions(-) diff --git a/src/Components/Common/Sidebar/SidebarUserCard.tsx b/src/Components/Common/Sidebar/SidebarUserCard.tsx index d083867738c..02170f453d7 100644 --- a/src/Components/Common/Sidebar/SidebarUserCard.tsx +++ b/src/Components/Common/Sidebar/SidebarUserCard.tsx @@ -31,7 +31,7 @@ const SidebarUserCard = ({ shrinked }: { shrinked: boolean }) => { shrinked ? "hidden" : "grow" } flex min-w-0 flex-col pb-2 pl-3`} > -
+
{
{!isCameraOpen ? ( -
+ {hasImage ? ( <>
@@ -305,7 +305,7 @@ const CoverImageEditModal = ({
) : ( -
+
{t("capture_cover_photo")} diff --git a/src/Components/Facility/TreatmentSummary.tsx b/src/Components/Facility/TreatmentSummary.tsx index b55c86216a7..f3c59791d63 100644 --- a/src/Components/Facility/TreatmentSummary.tsx +++ b/src/Components/Facility/TreatmentSummary.tsx @@ -53,8 +53,8 @@ const TreatmentSummary = (props: any) => {
{formatDate(date)}
-
-
+
+
Name : {patientData?.name ?? ""}
@@ -62,9 +62,9 @@ const TreatmentSummary = (props: any) => {
-
-
-
+
+
+
Age :{" "} {formatAge( patientData?.age ?? 0, @@ -72,7 +72,7 @@ const TreatmentSummary = (props: any) => { true )}
-
+
OP : {consultationData?.patient_no ?? ""}
@@ -87,8 +87,8 @@ const TreatmentSummary = (props: any) => {
-
-
+
+
Gender : {GENDER_TYPES.find((i) => i.id === patientData?.gender)?.text}
@@ -106,7 +106,7 @@ const TreatmentSummary = (props: any) => {
Comorbidities : -
+
@@ -187,7 +187,7 @@ const TreatmentSummary = (props: any) => {
Relevant investigations : -
+
@@ -282,7 +282,7 @@ const TreatmentSummary = (props: any) => { )} Treatment summary/Treament Plan : -
+
diff --git a/src/Components/Patient/ManagePatients.tsx b/src/Components/Patient/ManagePatients.tsx index 0c5dba7ca27..aacad50dc19 100644 --- a/src/Components/Patient/ManagePatients.tsx +++ b/src/Components/Patient/ManagePatients.tsx @@ -480,7 +480,7 @@ export const PatientManager = () => {
-
+
{patient?.last_consultation?.current_bed && patient?.last_consultation?.discharge_date === null ? (
@@ -515,7 +515,7 @@ export const PatientManager = () => {
) : ( -
+
{consultation?.current_bed && consultation?.discharge_date === null ? ( diff --git a/src/Components/Patient/SampleViewAdmin.tsx b/src/Components/Patient/SampleViewAdmin.tsx index 431fc09a317..d11d4ad23b2 100644 --- a/src/Components/Patient/SampleViewAdmin.tsx +++ b/src/Components/Patient/SampleViewAdmin.tsx @@ -157,7 +157,7 @@ export default function SampleViewAdmin() {
{item.sample_type && ( - + Type: {item.sample_type} )}