From 63702c48ab77ee73b7e304c92fc74ce02748107e Mon Sep 17 00:00:00 2001 From: Krishna Gopal Date: Tue, 17 May 2022 19:58:53 -0500 Subject: [PATCH] fix: add primary button loading state to modals (#20018) --- superset-frontend/src/components/Modal/Modal.tsx | 3 +++ .../src/views/CRUD/data/dataset/AddDatasetModal.tsx | 6 +++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/superset-frontend/src/components/Modal/Modal.tsx b/superset-frontend/src/components/Modal/Modal.tsx index 9e53589d8..389982cc2 100644 --- a/superset-frontend/src/components/Modal/Modal.tsx +++ b/superset-frontend/src/components/Modal/Modal.tsx @@ -34,6 +34,7 @@ export interface ModalProps { className?: string; children: React.ReactNode; disablePrimaryButton?: boolean; + primaryButtonLoading?: boolean; onHide: () => void; onHandledPrimaryAction?: () => void; primaryButtonName?: string; @@ -190,6 +191,7 @@ export const StyledModal = styled(BaseModal)` const CustomModal = ({ children, disablePrimaryButton = false, + primaryButtonLoading = false, onHide, onHandledPrimaryAction, primaryButtonName = t('OK'), @@ -240,6 +242,7 @@ const CustomModal = ({ key="submit" buttonStyle={primaryButtonType} disabled={disablePrimaryButton} + loading={primaryButtonLoading} onClick={onHandledPrimaryAction} cta data-test="modal-confirm-button" diff --git a/superset-frontend/src/views/CRUD/data/dataset/AddDatasetModal.tsx b/superset-frontend/src/views/CRUD/data/dataset/AddDatasetModal.tsx index 7e7e7429b..10a3b7bb7 100644 --- a/superset-frontend/src/views/CRUD/data/dataset/AddDatasetModal.tsx +++ b/superset-frontend/src/views/CRUD/data/dataset/AddDatasetModal.tsx @@ -56,7 +56,10 @@ const DatasetModal: FunctionComponent = ({ const [currentSchema, setSchema] = useState(''); const [currentTableName, setTableName] = useState(''); const [disableSave, setDisableSave] = useState(true); - const { createResource } = useSingleViewResource>( + const { + createResource, + state: { loading }, + } = useSingleViewResource>( 'dataset', t('dataset'), addDangerToast, @@ -114,6 +117,7 @@ const DatasetModal: FunctionComponent = ({ return (