mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-06 00:07:44 +01:00
28 lines
745 B
TypeScript
28 lines
745 B
TypeScript
|
import { useEffect } from 'react';
|
||
|
|
||
|
/**
|
||
|
* 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,
|
||
|
) => {
|
||
|
const emitEvent = () => {
|
||
|
const event = new CustomEvent(eventName);
|
||
|
document.dispatchEvent(event);
|
||
|
};
|
||
|
|
||
|
useEffect(() => {
|
||
|
const eventListener = (event: Event) => handler(event as CustomEvent);
|
||
|
|
||
|
document.addEventListener(eventName, eventListener);
|
||
|
|
||
|
return () => {
|
||
|
document.removeEventListener(eventName, eventListener);
|
||
|
};
|
||
|
}, [eventName, handler]);
|
||
|
|
||
|
return { emitEvent };
|
||
|
};
|