2020-06-19 12:30:05 +02:00
|
|
|
class InteractionElement {
|
|
|
|
constructor(htmlId="",
|
2020-06-19 15:49:11 +02:00
|
|
|
checkStatus=true,
|
2020-06-19 12:30:05 +02:00
|
|
|
disabledBefore=true,
|
|
|
|
disabledAfter=false,
|
|
|
|
hideBefore=true,
|
|
|
|
hideAfter=false) {
|
2020-06-25 17:44:55 +02:00
|
|
|
this.htmlId = htmlId;
|
|
|
|
this.element = (htmlId) => {this.element = document.getElementById(htmlId);}
|
|
|
|
this.checkStatus = checkStatus;
|
|
|
|
this.callbacks = {};
|
|
|
|
this.disabledBefore = disabledBefore;
|
|
|
|
this.disabledAfter = disabledAfter;
|
|
|
|
this.hideBefore = hideBefore;
|
|
|
|
this.hideAfter = hideAfter;
|
|
|
|
this.element(this.htmlId);
|
2020-06-19 12:30:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
setCallback(trigger, callback, bindThis, args=[]) {
|
|
|
|
this.callbacks[trigger] = {
|
2020-06-25 17:44:55 +02:00
|
|
|
"function": callback,
|
|
|
|
"bindThis": bindThis,
|
|
|
|
"args": args
|
2020-06-19 12:30:05 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
bindThisToCallback(trigger) {
|
|
|
|
let callback = this.callbacks[trigger];
|
|
|
|
let boundedCallback = callback["function"].bind(callback.bindThis);
|
|
|
|
return boundedCallback;
|
|
|
|
}
|
|
|
|
}
|