2024-08-16 23:10:19 +07:00
|
|
|
import { useEffect, useRef, useState } from "react";
|
|
|
|
|
|
2025-07-31 18:10:39 -04:00
|
|
|
export const useDisclosure = <T = unknown>() => {
|
2024-08-16 23:10:19 +07:00
|
|
|
const dialogRef = useRef<HTMLDialogElement>(null);
|
|
|
|
|
const [isOpen, setIsOpen] = useState(false);
|
|
|
|
|
const [data, setData] = useState<T | null | undefined>(null);
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
const dlg = dialogRef.current;
|
|
|
|
|
if (!dlg || !isOpen) return;
|
|
|
|
|
|
|
|
|
|
const onDialogClose = () => {
|
|
|
|
|
setIsOpen(false);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
dlg.addEventListener("close", onDialogClose);
|
|
|
|
|
return () => dlg.removeEventListener("close", onDialogClose);
|
|
|
|
|
}, [dialogRef, isOpen]);
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
dialogRef,
|
|
|
|
|
isOpen,
|
|
|
|
|
data,
|
|
|
|
|
onOpen: (data?: T | null) => {
|
|
|
|
|
setIsOpen(true);
|
|
|
|
|
setData(data);
|
|
|
|
|
},
|
|
|
|
|
onClose: () => {
|
|
|
|
|
setIsOpen(false);
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
};
|