2023-12-12 20:45:33 +00:00
|
|
|
import {
|
|
|
|
Dispatch,
|
|
|
|
MutableRefObject,
|
|
|
|
ReactElement,
|
|
|
|
ReactNode,
|
|
|
|
SetStateAction,
|
|
|
|
useCallback,
|
|
|
|
useMemo,
|
|
|
|
useRef,
|
|
|
|
useState,
|
|
|
|
} from 'react';
|
|
|
|
|
|
|
|
import ConfirmDialog from '../components/ConfirmDialog';
|
|
|
|
import MessageBox from '../components/MessageBox';
|
|
|
|
|
|
|
|
const useConfirmDialog = (
|
|
|
|
args: {
|
|
|
|
initial?: Partial<ConfirmDialogProps>;
|
|
|
|
} = {},
|
|
|
|
): {
|
|
|
|
confirmDialog: ReactElement;
|
|
|
|
confirmDialogRef: MutableRefObject<ConfirmDialogForwardedRefContent | null>;
|
2024-01-19 01:17:17 +00:00
|
|
|
setConfirmDialogLoading: (value: boolean) => void;
|
2023-12-12 20:45:33 +00:00
|
|
|
setConfirmDialogOpen: (value: boolean) => void;
|
|
|
|
setConfirmDialogProps: Dispatch<SetStateAction<ConfirmDialogProps>>;
|
|
|
|
finishConfirm: (title: ReactNode, message: Message) => void;
|
|
|
|
} => {
|
|
|
|
const {
|
2024-01-15 23:37:38 +00:00
|
|
|
initial: {
|
|
|
|
actionProceedText = '',
|
|
|
|
content = '',
|
|
|
|
titleText = '',
|
2024-01-23 22:23:40 +00:00
|
|
|
...restInitialProps
|
2024-01-15 23:37:38 +00:00
|
|
|
} = {},
|
2023-12-12 20:45:33 +00:00
|
|
|
} = args;
|
|
|
|
|
|
|
|
const confirmDialogRef = useRef<ConfirmDialogForwardedRefContent | null>(
|
|
|
|
null,
|
|
|
|
);
|
|
|
|
|
|
|
|
const [confirmDialogProps, setConfirmDialogProps] =
|
|
|
|
useState<ConfirmDialogProps>({
|
|
|
|
actionProceedText,
|
|
|
|
content,
|
|
|
|
titleText,
|
|
|
|
});
|
|
|
|
|
2024-01-19 01:17:17 +00:00
|
|
|
const setConfirmDialogLoading = useCallback(
|
|
|
|
(value: boolean) =>
|
|
|
|
setConfirmDialogProps(({ loading, ...rest }) => ({
|
|
|
|
...rest,
|
|
|
|
loading: value,
|
|
|
|
})),
|
|
|
|
[],
|
|
|
|
);
|
|
|
|
|
2023-12-12 20:45:33 +00:00
|
|
|
const setConfirmDialogOpen = useCallback(
|
|
|
|
(value: boolean) => confirmDialogRef?.current?.setOpen?.call(null, value),
|
|
|
|
[],
|
|
|
|
);
|
|
|
|
|
|
|
|
const finishConfirm = useCallback(
|
|
|
|
(title: ReactNode, message: Message) =>
|
|
|
|
setConfirmDialogProps({
|
|
|
|
actionProceedText: '',
|
|
|
|
content: <MessageBox {...message} />,
|
|
|
|
showActionArea: false,
|
|
|
|
showClose: true,
|
|
|
|
titleText: title,
|
|
|
|
}),
|
|
|
|
[],
|
|
|
|
);
|
|
|
|
|
|
|
|
const confirmDialog = useMemo<ReactElement>(
|
2024-01-15 23:37:38 +00:00
|
|
|
() => (
|
|
|
|
<ConfirmDialog
|
2024-01-23 22:23:40 +00:00
|
|
|
{...restInitialProps}
|
2024-01-15 23:37:38 +00:00
|
|
|
{...confirmDialogProps}
|
|
|
|
ref={confirmDialogRef}
|
|
|
|
/>
|
|
|
|
),
|
2024-01-23 22:23:40 +00:00
|
|
|
[confirmDialogProps, restInitialProps],
|
2023-12-12 20:45:33 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
return {
|
|
|
|
confirmDialog,
|
|
|
|
confirmDialogRef,
|
2024-01-19 01:17:17 +00:00
|
|
|
setConfirmDialogLoading,
|
2023-12-12 20:45:33 +00:00
|
|
|
setConfirmDialogOpen,
|
|
|
|
setConfirmDialogProps,
|
|
|
|
finishConfirm,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default useConfirmDialog;
|