import clsx from 'clsx' import { ReactNode, useState } from 'react' import { Col } from './layout/col' import { Modal } from './layout/modal' import { Row } from './layout/row' export function ConfirmationButton(props: { openModalBtn: { label: string icon?: JSX.Element className?: string } cancelBtn?: { label?: string className?: string } submitBtn?: { label?: string className?: string } children: ReactNode onSubmit?: () => void onOpenChanged?: (isOpen: boolean) => void onSubmitWithSuccess?: () => Promise<boolean> }) { const { openModalBtn, cancelBtn, submitBtn, onSubmit, children, onOpenChanged, onSubmitWithSuccess, } = props const [open, setOpen] = useState(false) function updateOpen(newOpen: boolean) { onOpenChanged?.(newOpen) setOpen(newOpen) } return ( <> <Modal open={open} setOpen={updateOpen}> <Col className="gap-4 rounded-md bg-white px-8 py-6"> {children} <Row className="gap-4"> <div className={clsx('btn normal-case', cancelBtn?.className)} onClick={() => updateOpen(false)} > {cancelBtn?.label ?? 'Cancel'} </div> <div className={clsx('btn normal-case', submitBtn?.className)} onClick={ onSubmitWithSuccess ? () => onSubmitWithSuccess().then((success) => updateOpen(!success) ) : onSubmit } > {submitBtn?.label ?? 'Submit'} </div> </Row> </Col> </Modal> <div className={clsx('btn normal-case', openModalBtn.className)} onClick={() => updateOpen(true)} > {openModalBtn.icon} {openModalBtn.label} </div> </> ) } export function ResolveConfirmationButton(props: { onResolve: () => void isSubmitting: boolean openModalButtonClass?: string submitButtonClass?: string }) { const { onResolve, isSubmitting, openModalButtonClass, submitButtonClass } = props return ( <ConfirmationButton openModalBtn={{ className: clsx( 'border-none self-start', openModalButtonClass, isSubmitting && 'btn-disabled loading' ), label: 'Resolve', }} cancelBtn={{ label: 'Back', }} submitBtn={{ label: 'Resolve', className: clsx('border-none', submitButtonClass), }} onSubmit={onResolve} > <p>Are you sure you want to resolve this market?</p> </ConfirmationButton> ) }