2023-10-05 14:11:17 +02:00
|
|
|
var ResourceDisplays = {};
|
|
|
|
|
2023-10-09 14:21:31 +02:00
|
|
|
ResourceDisplays.autoInit = () => {
|
|
|
|
for (let propertyName in ResourceDisplays) {
|
|
|
|
let property = ResourceDisplays[propertyName];
|
|
|
|
// Call autoInit of all properties that are subclasses of `ResourceDisplays.BaseDisplay`.
|
|
|
|
// This does not include `ResourceDisplays.BaseDisplay` itself.
|
|
|
|
if (property.prototype instanceof ResourceDisplays.BaseDisplay) {
|
|
|
|
// Check if the static `htmlClass` property is defined.
|
|
|
|
if (property.htmlClass === undefined) {return;}
|
|
|
|
// Gather all HTML elements that have the `this.htmlClass` class
|
|
|
|
// and do not have the `no-autoinit` class.
|
|
|
|
let displayElements = document.querySelectorAll(`.${property.htmlClass}:not(.no-autoinit)`);
|
|
|
|
// Create an instance of this class for each display element.
|
|
|
|
for (let displayElement of displayElements) {new property(displayElement);}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-05 14:11:17 +02:00
|
|
|
ResourceDisplays.BaseDisplay = class BaseDisplay {
|
2023-10-09 14:21:31 +02:00
|
|
|
static htmlClass;
|
|
|
|
|
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
|
|
|
};
|