From 7a16e16199e131e62243db91101580f9795bfa3f Mon Sep 17 00:00:00 2001
From: Joe Fong <127404525+joefong-nhs@users.noreply.github.com>
Date: Thu, 13 Jun 2024 10:13:35 +0100
Subject: [PATCH] PRMP-310 - LG "Remove all files" show Spinner button (#380)
* [PRMP-310] add unit test for spinner button, make spinner button appear when deletion taken place
* [PRMP-310] remove unused prop setIsDeletingDocuments
* remove unused mock function
---
.../DeleteSubmitStage.test.tsx | 23 +++++++++++++++----
.../deleteSubmitStage/DeleteSubmitStage.tsx | 17 +++++++-------
.../DocumentSearchResultsPage.tsx | 1 -
3 files changed, 27 insertions(+), 14 deletions(-)
diff --git a/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.test.tsx b/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.test.tsx
index a9e39ed2e..782ebcb3a 100644
--- a/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.test.tsx
+++ b/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.test.tsx
@@ -13,6 +13,7 @@ import usePatient from '../../../../helpers/hooks/usePatient';
import { runAxeTest } from '../../../../helpers/test/axeTestHelper';
import { MemoryHistory, createMemoryHistory } from 'history';
import * as ReactRouter from 'react-router';
+import waitForSeconds from '../../../../helpers/utils/waitForSeconds';
jest.mock('../../../../helpers/hooks/useConfig');
jest.mock('../deleteResultStage/DeleteResultStage', () => () =>
Deletion complete
);
@@ -44,8 +45,6 @@ const mockPatientDetails = buildPatientDetails();
const mockLgSearchResult = buildLgSearchResult();
const mockSetStage = jest.fn();
-const mockSetIsDeletingDocuments = jest.fn();
-const mockSetDownloadStage = jest.fn();
describe('DeleteSubmitStage', () => {
beforeEach(() => {
@@ -261,6 +260,22 @@ describe('DeleteSubmitStage', () => {
),
).toBeInTheDocument();
});
+
+ it('change the button to spinner button when deletion is taken place in background', async () => {
+ mockedUseRole.mockReturnValue(REPOSITORY_ROLE.GP_ADMIN);
+ mockedAxios.delete.mockReturnValue(waitForSeconds(1));
+
+ renderComponent(DOCUMENT_TYPE.LLOYD_GEORGE, history);
+
+ act(() => {
+ userEvent.click(screen.getByRole('radio', { name: 'Yes' }));
+ userEvent.click(screen.getByRole('button', { name: 'Continue' }));
+ });
+
+ await waitFor(() => {
+ expect(screen.getByTestId('delete-submit-spinner-btn')).toBeInTheDocument();
+ });
+ });
});
describe('Accessibility', () => {
@@ -325,7 +340,7 @@ describe('Navigation', () => {
});
const renderComponent = (docType: DOCUMENT_TYPE, history: MemoryHistory) => {
- const props: Omit = {
+ const props: Omit = {
numberOfFiles: mockLgSearchResult.number_of_files,
docType,
recordType: docType.toString(),
@@ -333,7 +348,7 @@ const renderComponent = (docType: DOCUMENT_TYPE, history: MemoryHistory) => {
return render(
- ,
+ ,
,
);
};
diff --git a/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.tsx b/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.tsx
index 02b42a07c..6722b62ee 100644
--- a/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.tsx
+++ b/app/src/components/blocks/_delete/deleteSubmitStage/DeleteSubmitStage.tsx
@@ -30,7 +30,6 @@ import DeleteResultStage from '../deleteResultStage/DeleteResultStage';
export type Props = {
docType: DOCUMENT_TYPE;
numberOfFiles: number;
- setIsDeletingDocuments?: Dispatch;
setDownloadStage?: Dispatch>;
recordType: string;
};
@@ -40,13 +39,7 @@ enum DELETE_DOCUMENTS_OPTION {
NO = 'no',
}
-function DeleteSubmitStage({
- docType,
- numberOfFiles,
- setIsDeletingDocuments,
- setDownloadStage,
- recordType,
-}: Props) {
+function DeleteSubmitStage({ docType, numberOfFiles, setDownloadStage, recordType }: Props) {
const patientDetails = usePatient();
const role = useRole();
const { register, handleSubmit } = useForm();
@@ -73,6 +66,7 @@ function DeleteSubmitStage({
}
};
try {
+ setDeletionStage(SUBMISSION_STATE.PENDING);
const response: DeleteResponse = await deleteAllDocuments({
docType: docType,
nhsNumber: nhsNumber,
@@ -177,7 +171,12 @@ function DeleteSubmitStage({
{deletionStage === SUBMISSION_STATE.PENDING ? (
-
+
) : (