Files
RWKV-Runner/frontend/src/components/DialogButton.tsx
2023-06-15 22:55:38 +08:00

58 lines
1.7 KiB
TypeScript

import { FC, ReactElement } from 'react';
import {
Button,
Dialog,
DialogActions,
DialogBody,
DialogContent,
DialogSurface,
DialogTitle,
DialogTrigger
} from '@fluentui/react-components';
import { ToolTipButton } from './ToolTipButton';
import { useTranslation } from 'react-i18next';
export const DialogButton: FC<{
text?: string | null
icon?: ReactElement,
tooltip?: string | null,
className?: string,
title: string,
contentText: string,
onConfirm: () => void,
size?: 'small' | 'medium' | 'large',
shape?: 'rounded' | 'circular' | 'square',
appearance?: 'secondary' | 'primary' | 'outline' | 'subtle' | 'transparent',
}> = ({
text, icon, tooltip, className, title, contentText,
onConfirm, size, shape, appearance
}) => {
const { t } = useTranslation();
return <Dialog>
<DialogTrigger disableButtonEnhancement>
{tooltip ?
<ToolTipButton className={className} desc={tooltip} text={text} icon={icon} size={size} shape={shape}
appearance={appearance} /> :
<Button className={className} icon={icon} size={size} shape={shape} appearance={appearance}>{text}</Button>
}
</DialogTrigger>
<DialogSurface>
<DialogBody>
<DialogTitle>{title}</DialogTitle>
<DialogContent>
{contentText}
</DialogContent>
<DialogActions>
<DialogTrigger disableButtonEnhancement>
<Button appearance="secondary">{t('Cancel')}</Button>
</DialogTrigger>
<DialogTrigger disableButtonEnhancement>
<Button appearance="primary" onClick={onConfirm}>{t('Confirm')}
</Button>
</DialogTrigger>
</DialogActions>
</DialogBody>
</DialogSurface>
</Dialog>;
};