PromucFlow_constructor/app/client/src/pages/Applications/ImportApplicationModalOld.tsx
albinAppsmith fbc3bd663b
feat: Migrate design system components import to design-system repo - I (#15562)
* Icon component deleted and changed the imports in refrence places

* design system package version changed

* import changes

* Delete TextInput.tsx

* Change imports

* Change single named import

* Update package

* Update package

* Delete ScrollIndicator.tsx

* Change imports

* Icon import completed

* Event type added

* Changed Button component imports

* import change button

* Button onclick type fix

* Label with Tooltip import changes

* Changed breadcrumbs import

* EmojiPicker and Emoji Reaction import changes

* AppIcon import change

* import bug fix

* Menu Item import chnages

* Icon selector imports changed

* Delete LabelWithTooltip.tsx

* Change imports across the app

* Update package version

* Update version number for design-system

* Delete Checkbox.tsx

* Remove the exports

* Add lock file for ds package update

* Change imports

* default import -> named

* Update release version

* Make arg type explicit

* Updated design-system to latest release

* Missing file mysteriously comes back and is updated accordingly

* changes design-system package version

* Add types to arguments in the onChange for text input

* onBlur type fix

* Search component in property pane

* WDS button changes reverted

* package version bumped

* conflict fix

* Remove Dropdown, change imports

* Category import fix

* fix: table icon size import

* Bump version of design system package

* Yarn lock

Co-authored-by: Tanvi Bhakta <tanvibhakta@gmail.com>
2022-08-22 10:39:39 +05:30

118 lines
3.3 KiB
TypeScript

import React, { useCallback, useState } from "react";
import styled from "styled-components";
import { Button, Size } from "design-system";
import { StyledDialog } from "./ForkModalStyles";
import { useSelector } from "store";
import { SetProgress, FileType } from "components/ads/FilePicker";
import { useDispatch } from "react-redux";
import { importApplication } from "actions/applicationActions";
import { Toaster } from "components/ads/Toast";
import { Variant } from "components/ads/common";
import { IMPORT_APPLICATION_MODAL_TITLE } from "@appsmith/constants/messages";
import FilePickerV2 from "components/ads/FilePickerV2";
import { getIsImportingApplication } from "selectors/applicationSelectors";
const ImportButton = styled(Button)<{ disabled?: boolean }>`
height: 30px;
width: 81px;
pointer-events: ${(props) => (!!props.disabled ? "none" : "auto")};
`;
const ButtonWrapper = styled.div`
display: flex;
justify-content: center;
margin-top: ${(props) => props.theme.spaces[6]}px;
`;
const FilePickerWrapper = styled.div`
width: 100%;
display: flex;
align-items: center;
justify-content: center;
`;
type ImportApplicationModalProps = {
// import?: (file: any) => void;
workspaceId?: string;
isModalOpen?: boolean;
onClose?: () => void;
};
function ImportApplicationModal(props: ImportApplicationModalProps) {
const { isModalOpen, onClose, workspaceId } = props;
const [appFileToBeUploaded, setAppFileToBeUploaded] = useState<{
file: File;
setProgress: SetProgress;
} | null>(null);
const dispatch = useDispatch();
const importingApplication = useSelector(getIsImportingApplication);
const FileUploader = useCallback(
async (file: File, setProgress: SetProgress) => {
if (!!file) {
setAppFileToBeUploaded({
file,
setProgress,
});
} else {
setAppFileToBeUploaded(null);
}
},
[],
);
const onImportApplication = useCallback(() => {
if (!appFileToBeUploaded) {
Toaster.show({
text: "Please choose a valid application file!",
variant: Variant.danger,
});
return;
}
const { file } = appFileToBeUploaded || {};
dispatch(
importApplication({
workspaceId: workspaceId as string,
applicationFile: file,
}),
);
}, [appFileToBeUploaded, workspaceId]);
const onRemoveFile = useCallback(() => setAppFileToBeUploaded(null), []);
return (
<StyledDialog
canOutsideClickClose
className={"t--import-application-modal"}
isOpen={isModalOpen}
maxHeight={"540px"}
setModalClose={onClose}
title={IMPORT_APPLICATION_MODAL_TITLE()}
>
<FilePickerWrapper>
<FilePickerV2
delayedUpload
fileType={FileType.JSON}
fileUploader={FileUploader}
onFileRemoved={onRemoveFile}
/>
</FilePickerWrapper>
<ButtonWrapper>
<ImportButton
// category={ButtonCategory.tertiary}
cypressSelector={"t--workspace-import-app-button"}
disabled={!appFileToBeUploaded}
isLoading={importingApplication}
onClick={onImportApplication}
size={Size.large}
text={"IMPORT"}
/>
</ButtonWrapper>
</StyledDialog>
);
}
export default ImportApplicationModal;