Created
September 6, 2019 14:57
-
-
Save jacwright/db25827137f9d3b3a16cf0914093662d to your computer and use it in GitHub Desktop.
TypeScript Signals, A simple typed alternative to events.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* Tiny. Compiled code for signals results in 15 lines of JS, < 500 bytes of uncompressed code. | |
* | |
* Usage: | |
* | |
* const clickedSave = createSignal<Doc>(); | |
* | |
* clickedSave(doc => { | |
* // do something to save the doc, or when the doc is saved | |
* }) | |
* | |
* clickedSave(doc); | |
*/ | |
export interface SignalListener<T> { | |
(event: T): void; | |
} | |
export interface SignalUnsubscriber { | |
(): void; | |
} | |
export interface SignalSubscriber<T> { | |
(listener: SignalListener<T>): SignalUnsubscriber; | |
} | |
export interface SignalDispatcher<T> { | |
(event: T): void; | |
} | |
export type Signal<T> = SignalSubscriber<T> & SignalDispatcher<T>; | |
export type SignalReturn = SignalUnsubscriber & void; | |
export function createSignal<T = void>(): Signal<T> { | |
const subscribers = new Set<SignalListener<T>>(); | |
return (eventOrListener: any): any => { | |
if (typeof eventOrListener === 'function') { | |
subscribers.add(eventOrListener); | |
return () => { subscribers.delete(eventOrListener) }; | |
} else { | |
subscribers.forEach(listener => listener(eventOrListener)); | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment