2023-11-09 14:29:01 +01:00
|
|
|
nopaque.resource_lists.ResourceList = class ResourceList {
|
2023-01-04 20:00:37 +01:00
|
|
|
/* A wrapper class for the list.js list.
|
|
|
|
* This class is not meant to be used directly, instead it should be used as
|
|
|
|
* a base class for concrete resource list implementations.
|
|
|
|
*/
|
|
|
|
|
2023-10-10 11:06:44 +02:00
|
|
|
static htmlClass;
|
2023-01-04 20:00:37 +01:00
|
|
|
|
2023-10-11 16:20:17 +02:00
|
|
|
static defaultOptions = {
|
|
|
|
page: 5,
|
|
|
|
pagination: {
|
|
|
|
innerWindow: 2,
|
|
|
|
outerWindow: 2
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-01-09 08:45:47 +01:00
|
|
|
constructor(listContainerElement, options = {}) {
|
|
|
|
if ('items' in options) {
|
|
|
|
throw '"items" is not supported as an option, define it as a getter in the list class';
|
|
|
|
}
|
|
|
|
if ('valueNames' in options) {
|
|
|
|
throw '"valueNames" is not supported as an option, define it as a getter in the list class';
|
|
|
|
}
|
2023-11-09 14:29:01 +01:00
|
|
|
let _options = nopaque.Utils.mergeObjectsDeep(
|
2023-01-09 08:45:47 +01:00
|
|
|
{item: this.item, valueNames: this.valueNames},
|
2023-11-09 14:29:01 +01:00
|
|
|
nopaque.resource_lists.ResourceList.defaultOptions,
|
2023-01-09 08:45:47 +01:00
|
|
|
options
|
|
|
|
);
|
2023-01-04 20:00:37 +01:00
|
|
|
this.listContainerElement = listContainerElement;
|
|
|
|
this.initListContainerElement();
|
|
|
|
this.listjs = new List(listContainerElement, _options);
|
|
|
|
}
|
|
|
|
|
|
|
|
add(resources, callback) {
|
2023-02-21 16:23:10 +01:00
|
|
|
let tmp = Array.isArray(resources) ? resources : [resources];
|
|
|
|
let values = tmp.map((resource) => {
|
2023-01-04 20:00:37 +01:00
|
|
|
return this.mapResourceToValue(resource);
|
|
|
|
});
|
|
|
|
this.listjs.add(values, (items) => {
|
|
|
|
this.sort();
|
|
|
|
if (typeof callback === 'function') {
|
|
|
|
callback(items);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
remove(id) {
|
|
|
|
this.listjs.remove('id', id);
|
|
|
|
}
|
|
|
|
|
|
|
|
replace(id, key, value) {
|
|
|
|
let item = this.listjs.get('id', id)[0];
|
|
|
|
item.values({[key]: value});
|
|
|
|
}
|
|
|
|
|
|
|
|
// #region Mandatory getters and methods to implement
|
|
|
|
get item() {throw 'Not implemented';}
|
|
|
|
|
|
|
|
get valueNames() {throw 'Not implemented';}
|
|
|
|
|
|
|
|
initListContainerElement() {throw 'Not implemented';}
|
|
|
|
// #endregion
|
|
|
|
|
|
|
|
// #region Optional methods to implement
|
|
|
|
mapResourceToValue(resource) {return resource;}
|
|
|
|
|
|
|
|
sort() {return;}
|
|
|
|
// #endregion
|
|
|
|
}
|