From 1883a9bc632f3ab22ce75ef630e61783646c6f2a Mon Sep 17 00:00:00 2001
From: Patrick Jentsch <p.jentsch@uni-bielefeld.de>
Date: Fri, 4 Dec 2020 14:16:11 +0100
Subject: [PATCH] Start redesign of RessourceLists

---
 web/app/static/js/nopaque.lists.new.js | 68 ++++++++++++++++++++++++++
 1 file changed, 68 insertions(+)
 create mode 100644 web/app/static/js/nopaque.lists.new.js

diff --git a/web/app/static/js/nopaque.lists.new.js b/web/app/static/js/nopaque.lists.new.js
new file mode 100644
index 00000000..564bae45
--- /dev/null
+++ b/web/app/static/js/nopaque.lists.new.js
@@ -0,0 +1,68 @@
+class RessourceList extends List {
+  constructor(idOrElement, options) {
+    super(idOrElement, {...RessourceList.options['default'], ...(options ? options : {})});
+  }
+
+  _init(ressources) {
+    this.clear();
+    this._add(Object.values(ressources));
+    this.sort("id", {order: "desc"});
+  }
+
+
+  _update(patch) {
+    let item, pathArray;
+
+    for (let operation of patch) {
+      /*
+       * '/{ressourceName}/{ressourceId}/...' -> ['{ressourceId}', ...]
+       * Example: '/jobs/1/status' -> ['1', 'status']
+      */
+      pathArray = operation.path.split("/").slice(2);
+      switch(operation.op) {
+        case "add":
+          this.add_handler([operation.value]);
+          break;
+        case "remove":
+          this.remove_handler(pathArray[0]);
+          break;
+        case "replace":
+          this.replace_handler(pathArray[0], pathArray[1], operation.value);
+          break;
+        default:
+          break;
+      }
+    }
+  }
+
+  add_handler(values, callback) {
+    if (this.hasOwnProperty('add_')) {
+      this.add_(values, callback);
+    } else {
+      this.add(values, callback);
+    }
+  }
+
+  remove_handler(id) {
+    if (this.hasOwnProperty('remove_')) {
+      this.remove_(id);
+    } else {
+      this.remove(id);
+    }
+  }
+
+  replace_handler(id, valueName, newValue) {
+    let item = this.get('id', id);
+    if (this.hasOwnProperty('add_'))
+    item.values({valueName: operation.value});
+  }
+}
+
+
+RessourceList.options = {
+  // default RessourceList options
+  default: {page: 5, pagination: [{innerWindow: 4, outerWindow: 1}]},
+};
+
+
+export { RessourceList, };
-- 
GitLab