1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- import { t } from "../i18n";
- import { Dialog, DialogProps } from "./Dialog";
- import "./ConfirmDialog.scss";
- import DialogActionButton from "./DialogActionButton";
- import { useSetAtom } from "jotai";
- import { isLibraryMenuOpenAtom } from "./LibraryMenuHeaderContent";
- import { useExcalidrawSetAppState } from "./App";
- interface Props extends Omit<DialogProps, "onCloseRequest"> {
- onConfirm: () => void;
- onCancel: () => void;
- confirmText?: string;
- cancelText?: string;
- }
- const ConfirmDialog = (props: Props) => {
- const {
- onConfirm,
- onCancel,
- children,
- confirmText = t("buttons.confirm"),
- cancelText = t("buttons.cancel"),
- className = "",
- ...rest
- } = props;
- const setAppState = useExcalidrawSetAppState();
- const setIsLibraryMenuOpen = useSetAtom(isLibraryMenuOpenAtom);
- return (
- <Dialog
- onCloseRequest={onCancel}
- small={true}
- {...rest}
- className={`confirm-dialog ${className}`}
- >
- {children}
- <div className="confirm-dialog-buttons">
- <DialogActionButton
- label={cancelText}
- onClick={() => {
- setAppState({ openMenu: null });
- setIsLibraryMenuOpen(false);
- onCancel();
- }}
- />
- <DialogActionButton
- label={confirmText}
- onClick={() => {
- setAppState({ openMenu: null });
- setIsLibraryMenuOpen(false);
- onConfirm();
- }}
- actionType="danger"
- />
- </div>
- </Dialog>
- );
- };
- export default ConfirmDialog;
|