Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
f84822dd5d | |||
21d6e19a22 | |||
8947738dc1 | |||
14bc5dcd25 |
2
package-lock.json
generated
2
package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/lik",
|
"name": "@pushrocks/lik",
|
||||||
"version": "4.0.19",
|
"version": "4.0.21",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/lik",
|
"name": "@pushrocks/lik",
|
||||||
"version": "4.0.19",
|
"version": "4.0.21",
|
||||||
"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",
|
||||||
|
@ -29,7 +29,7 @@ export class FastMap<T> {
|
|||||||
return this.mapObject[keyArg];
|
return this.mapObject[keyArg];
|
||||||
}
|
}
|
||||||
|
|
||||||
public removeFromMap(keyArg): T {
|
public removeFromMap(keyArg: string): T {
|
||||||
const removedItem = this.getByKey(keyArg);
|
const removedItem = this.getByKey(keyArg);
|
||||||
delete this.mapObject[keyArg];
|
delete this.mapObject[keyArg];
|
||||||
return removedItem;
|
return removedItem;
|
||||||
@ -50,7 +50,7 @@ export class FastMap<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* returns a new Objectmap that includes
|
* returns a new Fastmap that includes all values from this and all from the fastmap in the argument
|
||||||
*/
|
*/
|
||||||
public concat(fastMapArg: FastMap<T>) {
|
public concat(fastMapArg: FastMap<T>) {
|
||||||
const concatedFastmap = new FastMap<T>();
|
const concatedFastmap = new FastMap<T>();
|
||||||
@ -68,9 +68,9 @@ export class FastMap<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* tries to merge another Objectmap
|
* tries to merge another Fastmap
|
||||||
* Note: uniqueKeyCollisions will cause overwrite
|
* Note: uniqueKeyCollisions will cause overwrite
|
||||||
* @param objectMapArg
|
* @param fastMapArg
|
||||||
*/
|
*/
|
||||||
public addAllFromOther(fastMapArg: FastMap<T>) {
|
public addAllFromOther(fastMapArg: FastMap<T>) {
|
||||||
for (const key of fastMapArg.getKeys()) {
|
for (const key of fastMapArg.getKeys()) {
|
||||||
@ -79,4 +79,10 @@ export class FastMap<T> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async find(findFunction: (mapItemArg: T) => Promise<boolean>) {
|
||||||
|
for (const key of this.getKeys()) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
Reference in New Issue
Block a user