diff --git a/public/locale/en.json b/public/locale/en.json index 5008b13f928..7236e25c9aa 100644 --- a/public/locale/en.json +++ b/public/locale/en.json @@ -1502,6 +1502,8 @@ "questionnaire": "Questionnaire", "questionnaire_error_loading": "Error loading questionnaire", "questionnaire_not_exist": "The questionnaire you tried to access does not exist.", + "questionnaire_submission_failed": "Failed to submit questionnaire", + "questionnaire_submitted_successfully": "Questionnaire submitted successfully", "raise_consent_request": "Raise a consent request to fetch patient records over ABDM", "ration_card__APL": "APL", "ration_card__BPL": "BPL", diff --git a/src/Utils/request/useMutation.ts b/src/Utils/request/useMutation.ts deleted file mode 100644 index cff4919a6bd..00000000000 --- a/src/Utils/request/useMutation.ts +++ /dev/null @@ -1,50 +0,0 @@ -import React from "react"; - -import request from "@/Utils/request/request"; -import { - MutationRoute, - RequestOptions, - RequestResult, -} from "@/Utils/request/types"; -import { mergeRequestOptions } from "@/Utils/request/utils"; - -/** - * @deprecated use `useMutation` from `@tanstack/react-query` instead. - */ -export default function useDeprecatedMutation( - route: MutationRoute, - options: RequestOptions, -) { - const [response, setResponse] = React.useState>(); - const [isProcessing, setIsProcessing] = React.useState(false); - - const controllerRef = React.useRef(); - - const runQuery = React.useCallback( - async (overrides?: RequestOptions) => { - controllerRef.current?.abort(); - - const controller = new AbortController(); - controllerRef.current = controller; - - const resolvedOptions = - options && overrides - ? mergeRequestOptions(options, overrides) - : (overrides ?? options); - - setIsProcessing(true); - const response = await request(route, { - ...resolvedOptions, - signal: controller.signal, - }); - if (response.error?.name !== "AbortError") { - setResponse(response); - setIsProcessing(false); - } - return response; - }, - [route, JSON.stringify(options)], - ); - - return { ...response, isProcessing, mutate: runQuery }; -} diff --git a/src/components/Questionnaire/QuestionnaireForm.tsx b/src/components/Questionnaire/QuestionnaireForm.tsx index 8c7c02b5613..e58617b281e 100644 --- a/src/components/Questionnaire/QuestionnaireForm.tsx +++ b/src/components/Questionnaire/QuestionnaireForm.tsx @@ -1,3 +1,4 @@ +import { useMutation } from "@tanstack/react-query"; import { t } from "i18next"; import { useEffect, useState } from "react"; import { toast } from "sonner"; @@ -12,7 +13,7 @@ import { Button } from "@/components/ui/button"; import Loading from "@/components/Common/Loading"; import routes from "@/Utils/request/api"; -import useMutation from "@/Utils/request/useMutation"; +import mutate from "@/Utils/request/mutate"; import useQuery from "@/Utils/request/useQuery"; import { DetailedValidationError, @@ -77,10 +78,20 @@ export function QuestionnaireForm({ prefetch: !!questionnaireSlug && !FIXED_QUESTIONNAIRES[questionnaireSlug], }); - const { mutate: submitBatch, isProcessing } = useMutation( - routes.batchRequest, - { silent: true }, - ); + const { mutate: submitBatch, isPending } = useMutation({ + mutationFn: mutate(routes.batchRequest, { silent: true }), + onSuccess: () => { + toast.success(t("questionnaire_submitted_successfully")); + onSubmit?.(); + }, + onError: (error) => { + const errorData = error.cause; + if (errorData?.results) { + handleSubmissionError(errorData.results as ValidationErrorResponse[]); + } + toast.error(t("questionnaire_submission_failed")); + }, + }); useEffect(() => { if (!isInitialized && questionnaireSlug) { @@ -199,9 +210,9 @@ export function QuestionnaireForm({ // Then, add questionnaire submission requests questionnaireForms.forEach((form) => { - const nonStructuredResponses = form.responses.filter((response) => { - return !response.structured_type; - }); + const nonStructuredResponses = form.responses.filter( + (response) => !response.structured_type, + ); if (nonStructuredResponses.length > 0) { requests.push({ @@ -233,22 +244,7 @@ export function QuestionnaireForm({ } }); - const response = await submitBatch({ - body: { requests }, - }); - - if (!response.data) { - if (response.error) { - handleSubmissionError( - response.error.results as ValidationErrorResponse[], - ); - toast.error("Failed to submit questionnaire"); - } - return; - } - - toast.success("Questionnaire submitted successfully"); - onSubmit?.(); + submitBatch({ requests }); }; return ( @@ -264,7 +260,7 @@ export function QuestionnaireForm({ "bg-gray-100 text-green-600", )} onClick={() => setActiveQuestionnaireId(form.questionnaire.id)} - disabled={isProcessing} + disabled={isPending} > {form.questionnaire.title} @@ -283,7 +279,7 @@ export function QuestionnaireForm({ setActiveQuestionnaireId(form.questionnaire.id); setActiveGroupId(group.id); }} - disabled={isProcessing} + disabled={isPending} > {group.text} @@ -325,7 +321,7 @@ export function QuestionnaireForm({ ), ); }} - disabled={isProcessing} + disabled={isPending} > Remove @@ -347,7 +343,7 @@ export function QuestionnaireForm({ ), ); }} - disabled={isProcessing} + disabled={isPending} activeGroupId={activeGroupId} errors={form.errors} patientId={patientId} @@ -392,7 +388,7 @@ export function QuestionnaireForm({ }, ]); }} - disabled={isProcessing} + disabled={isPending} /> @@ -403,17 +399,17 @@ export function QuestionnaireForm({ type="button" variant="outline" onClick={onCancel} - disabled={isProcessing} + disabled={isPending} > {t("cancel")}