Fix DBOpenRequest.onupgradeneeded
authorBenjamin Auder <benjamin.auder@somewhere>
Thu, 19 Mar 2020 15:47:28 +0000 (16:47 +0100)
committerBenjamin Auder <benjamin.auder@somewhere>
Thu, 19 Mar 2020 15:47:28 +0000 (16:47 +0100)
client/src/utils/compgameStorage.js
client/src/utils/gameStorage.js

index a5c58af..a8bcaa2 100644 (file)
@@ -27,7 +27,11 @@ function dbOperation(callback) {
 
   DBOpenRequest.onupgradeneeded = function(event) {
     let db = event.target.result;
-    db.createObjectStore("compgames", { keyPath: "vname" });
+    let upgradeTransaction = event.target.transaction;
+    if (!db.objectStoreNames.contains("compgames"))
+      db.createObjectStore("compgames", { keyPath: "vname" });
+    else
+      upgradeTransaction.objectStore("compgames");
   };
 }
 
index fc179f1..514448b 100644 (file)
@@ -34,11 +34,18 @@ function dbOperation(callback) {
 
   DBOpenRequest.onupgradeneeded = function(event) {
     let db = event.target.result;
-    let objectStore = db.createObjectStore("games", { keyPath: "id" });
-    // To sarch games by score (useful for running games)
-    objectStore.createIndex("score", "score", { unique: false });
-    // To search by date intervals. Two games cannot start at the same time
-    objectStore.createIndex("created", "created", { unique: true });
+    let upgradeTransaction = event.target.transaction;
+    let objectStore = undefined;
+    if (!db.objectStoreNames.contains("games"))
+      objectStore = db.createObjectStore("games", { keyPath: "id" });
+    else
+      objectStore = upgradeTransaction.objectStore("games");
+    if (!objectStore.indexNames.contains("score"))
+      // To sarch games by score (useful for running games)
+      objectStore.createIndex("score", "score", { unique: false });
+    if (!objectStore.indexNames.contains("created"))
+      // To search by date intervals. Two games cannot start at the same time
+      objectStore.createIndex("created", "created", { unique: true });
   };
 }