Compare commits

..

2 Commits

Author SHA1 Message Date
8947738dc1 4.0.20 2020-11-24 19:11:43 +00:00
14bc5dcd25 fix(core): update 2020-11-24 19:11:42 +00:00
3 changed files with 20 additions and 8 deletions

2
package-lock.json generated
View File

@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/lik", "name": "@pushrocks/lik",
"version": "4.0.19", "version": "4.0.20",
"lockfileVersion": 1, "lockfileVersion": 1,
"requires": true, "requires": true,
"dependencies": { "dependencies": {

View File

@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/lik", "name": "@pushrocks/lik",
"version": "4.0.19", "version": "4.0.20",
"private": false, "private": false,
"description": "light little helpers for node", "description": "light little helpers for node",
"main": "dist_ts/index.js", "main": "dist_ts/index.js",

View File

@ -17,6 +17,11 @@ export interface IObjectmapFindFunction<T> {
(itemArg: T): boolean; (itemArg: T): boolean;
} }
export interface IObjectMapEventData<T> {
operation: 'add' | 'remove';
payload: T;
}
/** /**
* allows keeping track of objects * allows keeping track of objects
*/ */
@ -24,7 +29,7 @@ export class ObjectMap<T> {
private fastMap = new FastMap<T>(); private fastMap = new FastMap<T>();
// events // events
public eventSubject = new plugins.smartrx.rxjs.Subject<any>(); public eventSubject = new plugins.smartrx.rxjs.Subject<IObjectMapEventData<T>>();
/** /**
* returns a new instance * returns a new instance
@ -57,8 +62,6 @@ export class ObjectMap<T> {
const object = this.getMappedUnique(uniqueKey); const object = this.getMappedUnique(uniqueKey);
} }
public addSubject = new plugins.smartrx.rxjs.Subject<T>();
/** /**
* add object to Objectmap * add object to Objectmap
* returns false if the object is already in the map * returns false if the object is already in the map
@ -76,7 +79,10 @@ export class ObjectMap<T> {
// otherwise lets create it // otherwise lets create it
const uniqueKey = uni('key'); const uniqueKey = uni('key');
this.addMappedUnique(uniqueKey, objectArg); this.addMappedUnique(uniqueKey, objectArg);
this.addSubject.next(objectArg); this.eventSubject.next({
operation: 'add',
payload: objectArg
});
return uniqueKey; return uniqueKey;
} }
@ -153,7 +159,10 @@ export class ObjectMap<T> {
} else { } else {
const keyToUse = keys[0]; const keyToUse = keys[0];
const removedItem = this.fastMap.removeFromMap(keyToUse); const removedItem = this.fastMap.removeFromMap(keyToUse);
this.eventSubject.next('remove'); this.eventSubject.next({
operation: 'remove',
payload: removedItem
});
return removedItem; return removedItem;
} }
} }
@ -183,7 +192,10 @@ export class ObjectMap<T> {
if (this.checkForObject(objectArg)) { if (this.checkForObject(objectArg)) {
const keyArg = this.getKeyForObject(objectArg); const keyArg = this.getKeyForObject(objectArg);
const removedObject = this.fastMap.removeFromMap(keyArg); const removedObject = this.fastMap.removeFromMap(keyArg);
this.eventSubject.next('remove'); this.eventSubject.next({
operation: 'remove',
payload: removedObject
});
return removedObject; return removedObject;
} }
return null; return null;