2022-11-25 20:25:03 +00:00
|
|
|
import type { ReactNode } from 'react';
|
|
|
|
import { useContext } from 'react';
|
2020-07-04 23:05:44 +01:00
|
|
|
import tw from 'twin.macro';
|
2022-11-25 20:25:03 +00:00
|
|
|
|
2020-07-04 23:05:44 +01:00
|
|
|
import Button from '@/components/elements/Button';
|
2020-08-18 05:35:11 +01:00
|
|
|
import ModalContext from '@/context/ModalContext';
|
2022-11-25 20:25:03 +00:00
|
|
|
import asModal from '@/hoc/asModal';
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
children: ReactNode;
|
2020-03-23 02:10:49 +00:00
|
|
|
|
|
|
|
title: string;
|
|
|
|
buttonText: string;
|
|
|
|
onConfirmed: () => void;
|
2020-03-27 22:32:33 +00:00
|
|
|
showSpinnerOverlay?: boolean;
|
2022-11-25 20:25:03 +00:00
|
|
|
}
|
2020-03-23 02:10:49 +00:00
|
|
|
|
2022-11-25 20:25:03 +00:00
|
|
|
function ConfirmationModal({ title, children, buttonText, onConfirmed }: Props) {
|
2020-08-18 06:04:24 +01:00
|
|
|
const { dismiss } = useContext(ModalContext);
|
2020-08-18 05:35:11 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<h2 css={tw`text-2xl mb-6`}>{title}</h2>
|
2022-06-26 20:13:52 +01:00
|
|
|
<div css={tw`text-neutral-300`}>{children}</div>
|
2022-11-25 20:25:03 +00:00
|
|
|
|
2020-09-13 18:33:12 +01:00
|
|
|
<div css={tw`flex flex-wrap items-center justify-end mt-8`}>
|
2020-11-01 04:22:44 +00:00
|
|
|
<Button isSecondary onClick={() => dismiss()} css={tw`w-full sm:w-auto border-transparent`}>
|
2020-08-18 05:35:11 +01:00
|
|
|
Cancel
|
|
|
|
</Button>
|
2020-09-13 18:33:12 +01:00
|
|
|
<Button color={'red'} css={tw`w-full sm:w-auto mt-4 sm:mt-0 sm:ml-4`} onClick={() => onConfirmed()}>
|
2020-08-18 05:35:11 +01:00
|
|
|
{buttonText}
|
|
|
|
</Button>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
);
|
2022-11-25 20:25:03 +00:00
|
|
|
}
|
2020-08-18 05:35:11 +01:00
|
|
|
|
2022-11-25 20:25:03 +00:00
|
|
|
export default asModal<Props>(props => ({
|
2020-08-18 06:04:24 +01:00
|
|
|
showSpinnerOverlay: props.showSpinnerOverlay,
|
|
|
|
}))(ConfirmationModal);
|