๐Ÿ“ฆ retyui / react-native-stylex

๐Ÿ“„ createEventEmitter.ts ยท 27 lines
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27type Handler = () => void;
type UnSubscribe = () => void;

interface EventsRegistry {
  [eventName: string]: Array<Handler>;
}

interface Result {
  on: (callback: Handler) => UnSubscribe;
  emit: () => void;
}

const events: EventsRegistry = {};

export function createEventEmitter(event: string): Result {
  const emit = (): void => (events[event] || []).forEach((fn) => fn());
  const on = (cb: Handler): UnSubscribe => {
    (events[event] = events[event] || []).push(cb);

    return () => {
      events[event] = events[event]!.filter((fn) => fn !== cb);
    };
  };

  return { on, emit };
}