22 lines
442 B
TypeScript
22 lines
442 B
TypeScript
11 months ago
|
import { useEffect, useState } from "react";
|
||
|
import { Emitter } from "../emitter";
|
||
|
|
||
|
export const useEmitter = <TEvent extends unknown>(
|
||
|
emitter: Emitter<[TEvent]>,
|
||
|
initialState: TEvent,
|
||
|
) => {
|
||
|
const [event, setEvent] = useState<TEvent>(initialState);
|
||
|
|
||
|
useEffect(() => {
|
||
|
const unsubscribe = emitter.on((event) => {
|
||
|
setEvent(event);
|
||
|
});
|
||
|
|
||
|
return () => {
|
||
|
unsubscribe();
|
||
|
};
|
||
|
}, [emitter]);
|
||
|
|
||
|
return event;
|
||
|
};
|