anvil/striker-ui/components/Dialog/DialogActionGroup.tsx

100 lines
2.2 KiB
TypeScript
Raw Normal View History

import { FC, useCallback, useContext, useMemo } from 'react';
import ActionGroup from '../ActionGroup';
import { DialogContext } from './Dialog';
const handleAction: ExtendableEventHandler<ButtonClickEventHandler> = (
{ handlers: { base, origin } },
...args
) => {
base?.call(null, ...args);
origin?.call(null, ...args);
};
const DialogActionGroup: FC<DialogActionGroupProps> = (props) => {
const {
cancelProps,
closeOnProceed,
loading = false,
onCancel = handleAction,
onProceed = handleAction,
proceedColour,
proceedProps,
showCancel = true,
// Dependents
cancelChildren = cancelProps?.children,
proceedChildren = proceedProps?.children,
} = props;
const dialogContext = useContext(DialogContext);
const cancelHandler = useCallback<ButtonClickEventHandler>(
(...args) =>
onCancel(
{
handlers: {
base: () => {
dialogContext?.setOpen(false);
},
origin: cancelProps?.onClick,
},
},
...args,
),
[cancelProps?.onClick, dialogContext, onCancel],
);
const proceedHandler = useCallback<ButtonClickEventHandler>(
(...args) =>
onProceed(
{
handlers: {
base: () => {
if (closeOnProceed) {
dialogContext?.setOpen(false);
}
},
origin: proceedProps?.onClick,
},
},
...args,
),
[closeOnProceed, dialogContext, onProceed, proceedProps?.onClick],
);
const actions = useMemo(() => {
const acts: ContainedButtonProps[] = [
{
background: proceedColour,
...proceedProps,
children: proceedChildren,
onClick: proceedHandler,
},
];
if (showCancel) {
acts.unshift({
...cancelProps,
children: cancelChildren,
onClick: cancelHandler,
});
}
return <ActionGroup actions={acts} loading={loading} />;
}, [
cancelChildren,
cancelHandler,
cancelProps,
loading,
proceedChildren,
proceedColour,
proceedHandler,
proceedProps,
showCancel,
]);
return actions;
};
export default DialogActionGroup;