anvil/striker-ui/components/ConfirmDialog.tsx

118 lines
2.9 KiB
TypeScript
Raw Normal View History

import { Box as MuiBox } from '@mui/material';
import {
ForwardRefExoticComponent,
PropsWithChildren,
RefAttributes,
createElement,
forwardRef,
useImperativeHandle,
useMemo,
useRef,
} from 'react';
import { DialogActionArea, DialogScrollBox, DialogWithHeader } from './Dialog';
import FlexBox from './FlexBox';
import sxstring from '../lib/sxstring';
import { BodyText } from './Text';
const ConfirmDialog: ForwardRefExoticComponent<
PropsWithChildren<ConfirmDialogProps> &
RefAttributes<ConfirmDialogForwardedRefContent>
> = forwardRef<ConfirmDialogForwardedRefContent, ConfirmDialogProps>(
(
{
actionCancelText = 'Cancel',
actionProceedText,
children,
closeOnProceed = false,
contentContainerProps,
dialogProps,
disableProceed,
loading,
loadingAction = false,
onActionAppend,
onCancelAppend,
onProceedAppend,
openInitially,
preActionArea,
proceedButtonProps,
proceedColour = 'blue',
scrollContent = false,
scrollBoxProps,
showClose,
titleText,
wide,
// Dependents
content = children,
},
ref,
) => {
const dialogRef = useRef<DialogForwardedRefContent>(null);
const contentElement = useMemo(
() => sxstring(content, BodyText),
[content],
);
const bodyElement = useMemo(
() =>
createElement(
scrollContent ? DialogScrollBox : MuiBox,
scrollBoxProps,
contentElement,
),
[contentElement, scrollBoxProps, scrollContent],
);
useImperativeHandle(
ref,
() => ({
setOpen: (open) => dialogRef.current?.setOpen(open),
}),
[],
);
return (
<DialogWithHeader
dialogProps={dialogProps}
header={titleText}
loading={loading}
openInitially={openInitially}
ref={dialogRef}
showClose={showClose}
wide={wide}
>
<FlexBox {...contentContainerProps}>
{bodyElement}
{preActionArea}
<DialogActionArea
cancelProps={{
children: actionCancelText,
onClick: (...args) => {
onActionAppend?.call(null, ...args);
onCancelAppend?.call(null, ...args);
},
}}
closeOnProceed={closeOnProceed}
loading={loadingAction}
proceedProps={{
background: proceedColour,
children: actionProceedText,
disabled: disableProceed,
onClick: (...args) => {
onActionAppend?.call(null, ...args);
onProceedAppend?.call(null, ...args);
},
...proceedButtonProps,
}}
/>
</FlexBox>
</DialogWithHeader>
);
},
);
ConfirmDialog.displayName = 'ConfirmDialog';
export default ConfirmDialog;