Skip to content

Commit

Permalink
Use abort controller for submit requests for patient and consultation…
Browse files Browse the repository at this point in the history
… creates (#8354)
  • Loading branch information
rithviknishad authored Aug 19, 2024
1 parent d5805fa commit e7608d5
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 6 deletions.
10 changes: 9 additions & 1 deletion src/Components/Facility/ConsultationForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import { FieldErrorText, FieldLabel } from "../Form/FormFields/FormField";
import InvestigationBuilder, {
InvestigationType,
} from "../Common/prescription-builder/InvestigationBuilder";
import { LegacyRef, createRef, lazy, useEffect, useState } from "react";
import { LegacyRef, createRef, lazy, useEffect, useRef, useState } from "react";
import ProcedureBuilder, {
ProcedureType,
} from "../Common/prescription-builder/ProcedureBuilder";
Expand Down Expand Up @@ -230,6 +230,7 @@ type Props = {
export const ConsultationForm = ({ facilityId, patientId, id }: Props) => {
const { goBack } = useAppHistory();
const { kasp_enabled, kasp_string } = useConfig();
const submitController = useRef<AbortController>();
const [state, dispatch] = useAutoSaveReducer<FormDetails>(
consultationFormReducer,
initialState,
Expand Down Expand Up @@ -739,11 +740,18 @@ export const ConsultationForm = ({ facilityId, patientId, id }: Props) => {
patient_no: state.form.patient_no || null,
};

request(id ? routes.updateConsultation : routes.createConsultation, {
pathParams: id ? { id } : undefined,
body: data,
controllerRef: submitController,
});

const { data: obj } = await request(
id ? routes.updateConsultation : routes.createConsultation,
{
pathParams: id ? { id } : undefined,
body: data,
controllerRef: submitController,
},
);

Expand Down
12 changes: 11 additions & 1 deletion src/Components/Patient/PatientRegister.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,14 @@ import {
} from "../../Utils/utils";
import { navigate, useQueryParams } from "raviger";
import { statusType, useAbortableEffect } from "../../Common/utils";
import { lazy, useCallback, useEffect, useReducer, useState } from "react";
import {
lazy,
useCallback,
useEffect,
useReducer,
useRef,
useState,
} from "react";

import AccordionV2 from "../Common/components/AccordionV2";
import ButtonV2 from "../Common/components/ButtonV2";
Expand Down Expand Up @@ -170,6 +177,7 @@ export const parseOccupationFromExt = (occupation: Occupation) => {
};

export const PatientRegister = (props: PatientRegisterProps) => {
const submitController = useRef<AbortController>();
const authUser = useAuthUser();
const { t } = useTranslation();
const { goBack } = useAppHistory();
Expand Down Expand Up @@ -760,9 +768,11 @@ export const PatientRegister = (props: PatientRegisterProps) => {
? await request(routes.updatePatient, {
pathParams: { id },
body: data,
controllerRef: submitController,
})
: await request(routes.addPatient, {
body: { ...data, facility: facilityId },
controllerRef: submitController,
});
if (res?.ok && requestData) {
await Promise.all(
Expand Down
23 changes: 19 additions & 4 deletions src/Utils/request/request.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,18 @@ import handleResponse from "./handleResponse";
import { RequestOptions, RequestResult, Route } from "./types";
import { makeHeaders, makeUrl } from "./utils";

interface Options<TData, TBody> extends RequestOptions<TData, TBody> {
controller?: AbortController;
}
type ControllerXORControllerRef =
| {
controller?: AbortController;
controllerRef?: undefined;
}
| {
controller?: undefined;
controllerRef: React.MutableRefObject<AbortController | undefined>;
};

type Options<TData, TBody> = RequestOptions<TData, TBody> &
ControllerXORControllerRef;

export default async function request<TData, TBody>(
{ path, method, noAuth }: Route<TData, TBody>,
Expand All @@ -13,12 +22,18 @@ export default async function request<TData, TBody>(
body,
pathParams,
controller,
controllerRef,
onResponse,
silent,
reattempts = 3,
}: Options<TData, TBody> = {},
): Promise<RequestResult<TData>> {
const signal = controller?.signal;
if (controllerRef) {
controllerRef.current?.abort();
controllerRef.current = new AbortController();
}

const signal = controller?.signal ?? controllerRef?.current?.signal;
const url = makeUrl(path, query, pathParams);

const options: RequestInit = { method, signal };
Expand Down

0 comments on commit e7608d5

Please sign in to comment.