@helpwave/hightide
Version:
helpwave's component and theming library
35 lines (32 loc) • 1.43 kB
text/typescript
import * as react_jsx_runtime from 'react/jsx-runtime';
import { PropsWithChildren } from 'react';
import { SolidButtonColor } from '../user-action/Button.mjs';
import { PropsForTranslation } from '../../localization/useTranslation.mjs';
import { DialogProps } from '../layout-and-navigation/Overlay.mjs';
import { FormTranslationType } from '../../localization/defaults/form.mjs';
import '../../localization/util.mjs';
type ConfirmDialogTranslation = FormTranslationType;
type ConfirmDialogType = 'positive' | 'negative' | 'neutral' | 'primary';
type ButtonOverwriteType = {
text?: string;
color?: SolidButtonColor;
disabled?: boolean;
};
type ConfirmDialogProps = DialogProps & {
isShowingDecline?: boolean;
requireAnswer?: boolean;
onConfirm: () => void;
onDecline?: () => void;
confirmType?: ConfirmDialogType;
/**
* Order: Decline, Confirm
*/
buttonOverwrites?: [ButtonOverwriteType, ButtonOverwriteType];
};
/**
* A Dialog for demanding the user for confirmation
*
* To allow for background closing, prefer using a ConfirmModal
*/
declare const ConfirmDialog: ({ overwriteTranslation, children, onConfirm, onDecline, confirmType, buttonOverwrites, className, ...restProps }: PropsForTranslation<ConfirmDialogTranslation, PropsWithChildren<ConfirmDialogProps>>) => react_jsx_runtime.JSX.Element;
export { ConfirmDialog, type ConfirmDialogProps, type ConfirmDialogType };