2016-09-21 13:44:11 +02:00
|
|
|
import * as plugins from './lik.plugins'
|
2016-07-22 00:16:45 +02:00
|
|
|
|
|
|
|
/**
|
2016-09-21 13:44:11 +02:00
|
|
|
* allows you to easily keep track of a bunch of strings
|
2016-07-22 00:16:45 +02:00
|
|
|
*/
|
2016-07-23 04:39:42 +02:00
|
|
|
|
2016-09-21 13:44:11 +02:00
|
|
|
export interface ITriggerFunction {
|
|
|
|
(): boolean
|
2016-07-23 04:39:42 +02:00
|
|
|
}
|
|
|
|
|
2016-07-22 00:16:45 +02:00
|
|
|
export class Stringmap {
|
2016-09-21 13:44:11 +02:00
|
|
|
private _stringArray: string[] = []
|
|
|
|
private _triggerUntilTrueFunctionArray: ITriggerFunction[] = []
|
|
|
|
constructor() {}
|
2016-07-22 00:16:45 +02:00
|
|
|
/**
|
|
|
|
* add a string to the Stringmap
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
addString(stringArg: string) {
|
|
|
|
this._stringArray.push(stringArg)
|
|
|
|
this.notifyTrigger()
|
|
|
|
}
|
2016-07-22 00:16:45 +02:00
|
|
|
|
2016-09-21 13:51:37 +02:00
|
|
|
/**
|
|
|
|
* like addString, but accepts an array of strings
|
|
|
|
*/
|
|
|
|
addStringArray(stringArrayArg: string[]) {
|
|
|
|
for (let stringItem of stringArrayArg){
|
|
|
|
this.addString(stringItem)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-22 00:16:45 +02:00
|
|
|
/**
|
|
|
|
* removes a string from Stringmap
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
removeString(stringArg: string) {
|
|
|
|
for (let keyArg in this._stringArray) {
|
|
|
|
if (this._stringArray[keyArg] === stringArg) {
|
|
|
|
this._stringArray.splice(parseInt(keyArg),1)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.notifyTrigger()
|
2016-07-23 04:39:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* wipes the Stringmap
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
wipe() {
|
|
|
|
this._stringArray = []
|
|
|
|
this.notifyTrigger()
|
2016-07-22 00:16:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* check if string is in Stringmap
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
checkString(stringArg: string): boolean {
|
|
|
|
return this._stringArray.indexOf(stringArg) !== -1
|
2016-07-22 00:16:45 +02:00
|
|
|
}
|
2016-07-22 14:59:09 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* checks stringPresence with minimatch
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
checkMinimatch(miniMatchStringArg: string): boolean {
|
|
|
|
let foundMatch: boolean = false
|
|
|
|
for (let stringItem of this._stringArray){
|
|
|
|
if (plugins.minimatch(stringItem,miniMatchStringArg)) {
|
|
|
|
foundMatch = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return foundMatch
|
|
|
|
}
|
2016-07-22 14:59:09 +02:00
|
|
|
|
2016-07-23 04:39:42 +02:00
|
|
|
/**
|
|
|
|
* checks if the Stringmap is empty
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
checkIsEmpty() {
|
|
|
|
return (this._stringArray.length === 0)
|
2016-07-23 04:39:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-09-21 13:44:11 +02:00
|
|
|
* gets a cloned copy of the current string Array
|
2016-07-23 04:39:42 +02:00
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
getStringArray() {
|
|
|
|
return plugins.lodash.cloneDeep(this._stringArray)
|
|
|
|
}
|
|
|
|
|
|
|
|
// trigger registering
|
2016-07-23 04:39:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* register a new trigger
|
|
|
|
*/
|
2016-09-21 13:44:11 +02:00
|
|
|
registerUntilTrue(functionArg: ITriggerFunction,doFunctionArg) {
|
2016-07-23 04:39:42 +02:00
|
|
|
this._triggerUntilTrueFunctionArray.push(
|
|
|
|
() => {
|
2016-09-21 13:44:11 +02:00
|
|
|
let result = functionArg()
|
|
|
|
if (result === true) {
|
|
|
|
doFunctionArg()
|
2016-07-23 04:39:42 +02:00
|
|
|
}
|
2016-09-21 13:44:11 +02:00
|
|
|
return result
|
2016-07-23 04:39:42 +02:00
|
|
|
}
|
2016-09-21 13:44:11 +02:00
|
|
|
)
|
|
|
|
this.notifyTrigger()
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* notifies triggers
|
|
|
|
*/
|
|
|
|
private notifyTrigger() {
|
|
|
|
let filteredArray = this._triggerUntilTrueFunctionArray.filter((functionArg) => {
|
|
|
|
return !functionArg()
|
|
|
|
})
|
|
|
|
this._triggerUntilTrueFunctionArray = filteredArray
|
2016-07-22 14:59:09 +02:00
|
|
|
}
|
2016-09-21 13:44:11 +02:00
|
|
|
|
|
|
|
}
|