@wordpress/compose
Version:
WordPress higher-order components (HOCs).
62 lines (57 loc) • 1.57 kB
text/typescript
export type ObservableMap< K, V > = {
get: ( name: K ) => V | undefined;
set: ( name: K, value: V ) => void;
delete: ( name: K ) => void;
subscribe: ( name: K, listener: () => void ) => () => void;
};
/**
* A constructor (factory) for `ObservableMap`, a map-like key/value data structure
* where the individual entries are observable: using the `subscribe` method, you can
* subscribe to updates for a particular keys. Each subscriber always observes one
* specific key and is not notified about any unrelated changes (for different keys)
* in the `ObservableMap`.
*
* @template K The type of the keys in the map.
* @template V The type of the values in the map.
* @return A new instance of the `ObservableMap` type.
*/
export function observableMap< K, V >(): ObservableMap< K, V > {
const map = new Map< K, V >();
const listeners = new Map< K, Set< () => void > >();
function callListeners( name: K ) {
const list = listeners.get( name );
if ( ! list ) {
return;
}
for ( const listener of list ) {
listener();
}
}
return {
get( name ) {
return map.get( name );
},
set( name, value ) {
map.set( name, value );
callListeners( name );
},
delete( name ) {
map.delete( name );
callListeners( name );
},
subscribe( name, listener ) {
let list = listeners.get( name );
if ( ! list ) {
list = new Set();
listeners.set( name, list );
}
list.add( listener );
return () => {
list.delete( listener );
if ( list.size === 0 ) {
listeners.delete( name );
}
};
},
};
}