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;
|
|
|
|
}
|
2020-07-20 09:31:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
class InteractionElements {
|
|
|
|
constructor() {
|
|
|
|
this.interactions = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
addInteractions (interactionsArray) {
|
|
|
|
this.interactions.push(...interactionsArray);
|
|
|
|
}
|
2020-07-03 14:41:57 +02:00
|
|
|
|
2020-07-20 09:31:27 +02:00
|
|
|
onChangeExecute() {
|
2020-07-03 14:41:57 +02:00
|
|
|
// checks if a change for every interactionElement happens and executes
|
|
|
|
// the callbacks accordingly
|
2020-07-20 09:31:27 +02:00
|
|
|
for (let interaction of this.interactions) {
|
2020-07-03 14:41:57 +02:00
|
|
|
if (interaction.checkStatus) {
|
|
|
|
interaction.element.addEventListener("change", (event) => {
|
|
|
|
if (event.target.checked) {
|
|
|
|
let f_on = interaction.bindThisToCallback("on");
|
|
|
|
let args_on = interaction.callbacks.on.args;
|
|
|
|
f_on(...args_on);
|
|
|
|
} else if (!event.target.checked){
|
|
|
|
let f_off = interaction.bindThisToCallback("off");
|
|
|
|
let args_off = interaction.callbacks.off.args;
|
|
|
|
f_off(...args_off);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|