Path: blob/1.0-develop/resources/scripts/components/elements/ConfirmationModal.tsx
7461 views
import React, { useContext } from 'react';1import tw from 'twin.macro';2import Button from '@/components/elements/Button';3import asModal from '@/hoc/asModal';4import ModalContext from '@/context/ModalContext';56type Props = {7title: string;8buttonText: string;9onConfirmed: () => void;10showSpinnerOverlay?: boolean;11};1213const ConfirmationModal: React.FC<Props> = ({ title, children, buttonText, onConfirmed }) => {14const { dismiss } = useContext(ModalContext);1516return (17<>18<h2 css={tw`text-2xl mb-6`}>{title}</h2>19<div css={tw`text-neutral-300`}>{children}</div>20<div css={tw`flex flex-wrap items-center justify-end mt-8`}>21<Button isSecondary onClick={() => dismiss()} css={tw`w-full sm:w-auto border-transparent`}>22Cancel23</Button>24<Button color={'red'} css={tw`w-full sm:w-auto mt-4 sm:mt-0 sm:ml-4`} onClick={() => onConfirmed()}>25{buttonText}26</Button>27</div>28</>29);30};3132ConfirmationModal.displayName = 'ConfirmationModal';3334export default asModal<Props>((props) => ({35showSpinnerOverlay: props.showSpinnerOverlay,36}))(ConfirmationModal);373839