Skip to content

Commit

Permalink
Address broken export questionnaire
Browse files Browse the repository at this point in the history
Signed-off-by: ibolton336 <[email protected]>
  • Loading branch information
ibolton336 committed Oct 4, 2023
1 parent c0186be commit 220af4a
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 45 deletions.
19 changes: 2 additions & 17 deletions client/src/app/api/rest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -721,23 +721,8 @@ export const updateProxy = (obj: Proxy): Promise<Proxy> =>
export const getQuestionnaires = (): Promise<Questionnaire[]> =>
axios.get(QUESTIONNAIRES).then((response) => response.data);

export const getQuestionnaireById = <T>(
id: number | string,
isBlob: boolean = false
): Promise<T> =>
axios
.get(
`${QUESTIONNAIRES}/${id}`,
isBlob
? {
responseType: "blob",
headers: {
Accept: "application/x-yaml",
},
}
: {}
)
.then((response) => response.data);
export const getQuestionnaireById = <T>(id: number | string): Promise<T> =>
axios.get(`${QUESTIONNAIRES}/${id}`).then((response) => response.data);

export const createQuestionnaire = (
obj: Questionnaire
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,7 @@
import * as React from "react";
import { saveAs } from "file-saver";
import { DropdownItem } from "@patternfly/react-core";
import { useTranslation } from "react-i18next";

import { useFetchQuestionnaireBlob } from "@app/queries/questionnaires";
import { AxiosError } from "axios";
import { getAxiosErrorMessage } from "@app/utils/utils";
import { NotificationsContext } from "@app/components/NotificationsContext";
import { useDownloadQuestionnaire } from "@app/queries/questionnaires";

export interface IExportQuestionnaireDropdownItemProps {
id: number;
Expand All @@ -15,30 +10,18 @@ export const ExportQuestionnaireDropdownItem: React.FC<
IExportQuestionnaireDropdownItemProps
> = ({ id }) => {
const { t } = useTranslation();
const { pushNotification } = React.useContext(NotificationsContext);

const onExportQuestionnaireError = (error: AxiosError) => {
pushNotification({
title: getAxiosErrorMessage(error),
variant: "danger",
});
};

const { data: questionnaire, refetch } = useFetchQuestionnaireBlob(
id,
onExportQuestionnaireError
);
const {
mutate: downloadFile,
isLoading,
isError,
} = useDownloadQuestionnaire();

const exportQuestionnaire = () => {
refetch().then(() => {
if (questionnaire) {
saveAs(new Blob([questionnaire]), `questionnaire-${id}.yaml`);
}
});
const handleDownload = () => {
downloadFile(id);
};

return (
<DropdownItem key="export" component="button" onClick={exportQuestionnaire}>
<DropdownItem key="export" component="button" onClick={handleDownload}>
{t("actions.export")}
</DropdownItem>
);
Expand Down
34 changes: 32 additions & 2 deletions client/src/app/queries/questionnaires.ts
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query";
import { AxiosError } from "axios";
import axios, { AxiosError } from "axios";

import {
QUESTIONNAIRES,
createQuestionnaire,
deleteQuestionnaire,
getQuestionnaireById,
getQuestionnaires,
updateQuestionnaire,
} from "@app/api/rest";
import { Questionnaire } from "@app/api/models";
import saveAs from "file-saver";

export const QuestionnairesQueryKey = "questionnaires";
export const QuestionnaireByIdQueryKey = "questionnaireById";
Expand Down Expand Up @@ -84,7 +86,7 @@ export const useFetchQuestionnaireBlob = (
) =>
useQuery({
queryKey: [QuestionnaireByIdQueryKey, id],
queryFn: () => getQuestionnaireById<Blob>(id, true),
queryFn: () => getQuestionnaireById<Blob>(id),
onError: onError,
enabled: false,
});
Expand Down Expand Up @@ -113,3 +115,31 @@ export const useCreateQuestionnaireMutation = (
error,
};
};

export const downloadQuestionnaire = async (
id: number | string
): Promise<void> => {
const url = `${QUESTIONNAIRES}/${id}`;

try {
const response = await axios.get(url, {
responseType: "blob",
headers: {
Accept: "application/x-yaml",
},
});

if (response.status !== 200) {
throw new Error("Network response was not ok when downloading file.");
}

const blob = new Blob([response.data]);
saveAs(blob, `questionnaire-${id}.yaml`);
} catch (error) {
console.error("There was an error downloading the file:", error);
throw error;
}
};
export const useDownloadQuestionnaire = () => {
return useMutation(downloadQuestionnaire);
};

0 comments on commit 220af4a

Please sign in to comment.