import { ReactNode, useState } from "react"; import { Button, ButtonProps, Modal, ModalProps } from "@patternfly/react-core"; export type ContinueCancelModalProps = Omit & { modalTitle: string; modalMessage?: string; buttonTitle: string | ReactNode; buttonVariant?: ButtonProps["variant"]; isDisabled?: boolean; onContinue: () => void; continueLabel?: string; cancelLabel?: string; component?: React.ElementType | React.ComponentType; children?: ReactNode; }; export const ContinueCancelModal = ({ modalTitle, modalMessage, buttonTitle, isDisabled, buttonVariant, onContinue, continueLabel = "continue", cancelLabel = "doCancel", component = Button, children, ...rest }: ContinueCancelModalProps) => { const [open, setOpen] = useState(false); const Component = component; return ( <> setOpen(true)} isDisabled={isDisabled} > {buttonTitle} setOpen(false)} actions={[ , , ]} > {modalMessage ? modalMessage : children} ); };