2023-10-05 14:11:17 +02:00
|
|
|
var ResourceDisplays = {};
|
|
|
|
|
|
|
|
ResourceDisplays.BaseDisplay = class BaseDisplay {
|
2021-01-11 13:36:45 +01:00
|
|
|
constructor(displayElement) {
|
|
|
|
this.displayElement = displayElement;
|
2021-11-30 16:22:16 +01:00
|
|
|
this.userId = this.displayElement.dataset.userId;
|
2022-07-08 11:46:47 +02:00
|
|
|
this.isInitialized = false;
|
|
|
|
if (this.userId) {
|
2022-09-02 13:07:30 +02:00
|
|
|
app.subscribeUser(this.userId)
|
|
|
|
.then((response) => {
|
|
|
|
app.socket.on('PATCH', (patch) => {
|
|
|
|
if (this.isInitialized) {this.onPatch(patch);}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
app.getUser(this.userId)
|
|
|
|
.then((user) => {
|
|
|
|
this.init(user);
|
|
|
|
this.isInitialized = true;
|
|
|
|
});
|
2022-07-08 11:46:47 +02:00
|
|
|
}
|
2021-01-11 13:36:45 +01:00
|
|
|
}
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
init(user) {throw 'Not implemented';}
|
2021-01-11 13:36:45 +01:00
|
|
|
|
2022-09-02 13:07:30 +02:00
|
|
|
onPatch(patch) {throw 'Not implemented';}
|
2021-01-11 13:36:45 +01:00
|
|
|
|
|
|
|
setElement(element, value) {
|
|
|
|
switch (element.tagName) {
|
2022-09-02 13:07:30 +02:00
|
|
|
case 'INPUT': {
|
2021-01-11 13:36:45 +01:00
|
|
|
element.value = value;
|
|
|
|
M.updateTextFields();
|
|
|
|
break;
|
2022-09-02 13:07:30 +02:00
|
|
|
}
|
|
|
|
default: {
|
2021-01-11 13:36:45 +01:00
|
|
|
element.innerText = value;
|
|
|
|
break;
|
2022-09-02 13:07:30 +02:00
|
|
|
}
|
2021-01-11 13:36:45 +01:00
|
|
|
}
|
|
|
|
}
|
2021-12-01 14:15:20 +01:00
|
|
|
|
|
|
|
setElements(elements, value) {
|
2022-09-02 13:07:30 +02:00
|
|
|
for (let element of elements) {
|
2021-12-01 14:15:20 +01:00
|
|
|
this.setElement(element, value);
|
|
|
|
}
|
|
|
|
}
|
2023-10-05 14:11:17 +02:00
|
|
|
};
|