anvil/striker-ui/components/FormDialog.tsx
2023-09-21 03:41:15 -04:00

86 lines
2.0 KiB
TypeScript

import { BoxProps as MuiBoxProps } from '@mui/material';
import {
ForwardRefExoticComponent,
PropsWithChildren,
RefAttributes,
forwardRef,
useMemo,
} from 'react';
import ConfirmDialog from './ConfirmDialog';
import { FlexBoxProps } from './FlexBox';
const FormDialog: ForwardRefExoticComponent<
PropsWithChildren<ConfirmDialogProps> &
RefAttributes<ConfirmDialogForwardedRefContent>
> = forwardRef<ConfirmDialogForwardedRefContent, ConfirmDialogProps>(
(props, ref) => {
const {
children,
contentContainerProps,
dialogProps,
onSubmitAppend,
proceedButtonProps,
scrollBoxProps,
scrollContent,
...restProps
} = props;
const formBodyProps = useMemo<FlexBoxProps>(
() => ({
...contentContainerProps,
component: 'form',
onSubmit: (...args) => {
const [event] = args;
event.preventDefault();
onSubmitAppend?.call(null, ...args);
},
}),
[contentContainerProps, onSubmitAppend],
);
const formScrollBoxProps = useMemo<MuiBoxProps>(
() => ({
...scrollBoxProps,
sx: scrollContent
? {
overflowX: 'hidden',
paddingTop: '.6em',
...scrollBoxProps?.sx,
}
: scrollBoxProps?.sx,
}),
[scrollBoxProps, scrollContent],
);
return (
<ConfirmDialog
dialogProps={{
...dialogProps,
PaperProps: {
...dialogProps?.PaperProps,
sx: {
minWidth: { xs: '90%', md: '50em' },
...dialogProps?.PaperProps?.sx,
},
},
}}
contentContainerProps={formBodyProps}
proceedButtonProps={{ ...proceedButtonProps, type: 'submit' }}
scrollContent={scrollContent}
scrollBoxProps={formScrollBoxProps}
{...restProps}
ref={ref}
>
{children}
</ConfirmDialog>
);
},
);
FormDialog.displayName = 'FormDialog';
export default FormDialog;