2024-05-29 16:01:52 +02:00
|
|
|
import { useCallback, useEffect } from 'react';
|
2024-05-29 12:58:14 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A hook that provides methods to emit and listen to custom DOM events.
|
|
|
|
* @param eventName The name of the event to listen for and dispatch.
|
|
|
|
*/
|
|
|
|
export const useCustomEvent = (
|
|
|
|
eventName: string,
|
|
|
|
handler: (event: CustomEvent) => void,
|
|
|
|
) => {
|
2024-05-29 16:01:52 +02:00
|
|
|
const emitEvent = useCallback(() => {
|
2024-05-29 12:58:14 +02:00
|
|
|
const event = new CustomEvent(eventName);
|
|
|
|
document.dispatchEvent(event);
|
2024-05-29 16:01:52 +02:00
|
|
|
}, [eventName]);
|
2024-05-29 12:58:14 +02:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const eventListener = (event: Event) => handler(event as CustomEvent);
|
|
|
|
|
|
|
|
document.addEventListener(eventName, eventListener);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
document.removeEventListener(eventName, eventListener);
|
|
|
|
};
|
|
|
|
}, [eventName, handler]);
|
|
|
|
|
|
|
|
return { emitEvent };
|
|
|
|
};
|