mirror of
https://github.com/khairul169/garage-webui.git
synced 2025-12-18 13:31:04 +07:00
33 lines
758 B
TypeScript
33 lines
758 B
TypeScript
|
|
import { useEffect, useRef, useState } from "react";
|
||
|
|
|
||
|
|
export const useDisclosure = <T = any>() => {
|
||
|
|
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);
|
||
|
|
},
|
||
|
|
};
|
||
|
|
};
|