2021-01-18 01:24:17 +00:00
|
|
|
const DB_VERSION = 20;
|
2021-01-18 01:26:39 +00:00
|
|
|
const BUILD_VERSION = "6.9.2";
|
|
|
|
|
2021-01-07 00:08:19 +00:00
|
|
|
// @See https://github.com/mdn/learning-area/blob/master/javascript/apis/client-side-storage/indexeddb/video-store/index.js
|
|
|
|
|
|
|
|
let db;
|
|
|
|
let reload = false;
|
|
|
|
let items;
|
2021-01-10 01:33:42 +00:00
|
|
|
let sets;
|
2021-01-18 01:26:39 +00:00
|
|
|
let ings;
|
|
|
|
let recipes;
|
2021-01-07 00:08:19 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Load item set from local DB. Calls init() on success.
|
|
|
|
*/
|
|
|
|
async function load_local(init_func) {
|
2021-01-18 01:26:39 +00:00
|
|
|
let get_tx = db.transaction(['item_db', 'set_db', 'ing_db', 'recipe_db'], 'readonly');
|
2021-01-10 02:16:19 +00:00
|
|
|
let sets_store = get_tx.objectStore('set_db');
|
2021-01-07 00:08:19 +00:00
|
|
|
let get_store = get_tx.objectStore('item_db');
|
2021-01-18 01:26:39 +00:00
|
|
|
let ings_store = get_tx.objectStore('ing_db');
|
|
|
|
let recipes_store = get_tx.objectStore('recipe_db');
|
2021-01-07 00:08:19 +00:00
|
|
|
let request = get_store.getAll();
|
|
|
|
request.onerror = function(event) {
|
2021-01-10 02:16:19 +00:00
|
|
|
console.log("Could not read local item db...");
|
2021-01-07 00:08:19 +00:00
|
|
|
}
|
|
|
|
request.onsuccess = function(event) {
|
2021-01-10 02:16:19 +00:00
|
|
|
console.log("Successfully read local item db.");
|
2021-01-07 00:08:19 +00:00
|
|
|
items = request.result;
|
2021-01-10 02:16:19 +00:00
|
|
|
let request2 = sets_store.openCursor();
|
|
|
|
|
|
|
|
sets = {};
|
|
|
|
request2.onerror = function(event) {
|
|
|
|
console.log("Could not read local set db...");
|
|
|
|
}
|
|
|
|
|
|
|
|
request2.onsuccess = function(event) {
|
|
|
|
let cursor = event.target.result;
|
|
|
|
if (cursor) {
|
|
|
|
sets[cursor.primaryKey] = cursor.value;
|
|
|
|
cursor.continue();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
console.log("Successfully read local set db.");
|
|
|
|
console.log(sets);
|
|
|
|
init_func();
|
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
|
2021-01-10 02:16:19 +00:00
|
|
|
}
|
2021-01-07 00:08:19 +00:00
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
let request3 = ings_store.getAll();
|
|
|
|
request3.onerror = function(event) {
|
|
|
|
console.log("Could not read local ingredient db...");
|
|
|
|
}
|
|
|
|
request3.onsuccess = function(event) {
|
|
|
|
console.log("Successfully read local ingredient db.");
|
|
|
|
ings = request3.result;
|
|
|
|
}
|
|
|
|
let request4 = recipes_store.getAll();
|
|
|
|
request4.onerror = function(event) {
|
|
|
|
console.log("Could not read local recipe db...");
|
|
|
|
}
|
|
|
|
request4.onsuccess = function(event) {
|
|
|
|
console.log("Successfully read local recipe db.");
|
|
|
|
recipes = request4.result;
|
|
|
|
}
|
2021-01-07 00:08:19 +00:00
|
|
|
await get_tx.complete;
|
|
|
|
db.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean bad item data. For now just assigns display name if it isn't already assigned.
|
|
|
|
*/
|
|
|
|
function clean_item(item) {
|
|
|
|
if (item.displayName === undefined) {
|
|
|
|
item.displayName = item.name;
|
|
|
|
}
|
2021-01-07 06:41:41 +00:00
|
|
|
item.skillpoints = [item.str, item.dex, item.int, item.def, item.agi];
|
|
|
|
item.has_negstat = item.str < 0 || item.dex < 0 || item.int < 0 || item.def < 0 || item.agi < 0;
|
|
|
|
item.reqs = [item.strReq, item.dexReq, item.intReq, item.defReq, item.agiReq];
|
2021-01-07 00:08:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Load item set from remote DB (aka a big json file). Calls init() on success.
|
|
|
|
*/
|
|
|
|
async function load(init_func) {
|
2021-01-10 22:48:37 +00:00
|
|
|
|
|
|
|
let getUrl = window.location;
|
|
|
|
let baseUrl = getUrl.protocol + "//" + getUrl.host + "/" + getUrl.pathname.split('/')[1];
|
|
|
|
let url = baseUrl + "/compress.json";
|
2021-01-18 01:26:39 +00:00
|
|
|
url = url.replace("/crafter.html", ""); //JANK
|
2021-01-07 00:08:19 +00:00
|
|
|
let result = await (await fetch(url)).json();
|
|
|
|
items = result.items;
|
2021-01-10 01:33:42 +00:00
|
|
|
sets = result.sets;
|
2021-01-18 01:26:39 +00:00
|
|
|
url = url.replace("/compress.json", "/ingreds_compress.json");
|
|
|
|
result = await (await fetch(url)).json();
|
|
|
|
ings = result.ingredients;
|
|
|
|
url = url.replace("/ingreds_compress.json", "/recipes_compress.json");
|
|
|
|
result = await (await fetch(url)).json();
|
|
|
|
recipes = result.recipes;
|
2021-01-07 00:08:19 +00:00
|
|
|
|
|
|
|
// https://developer.mozilla.org/en-US/docs/Web/API/IDBObjectStore/clear
|
2021-01-10 02:16:19 +00:00
|
|
|
let clear_tx = db.transaction(['item_db', 'set_db'], 'readwrite');
|
|
|
|
let clear_items = clear_tx.objectStore('item_db');
|
|
|
|
let clear_sets = clear_tx.objectStore('item_db');
|
2021-01-18 01:26:39 +00:00
|
|
|
let clear_tx2 = db.transaction(['ing_db'], 'readwrite');
|
|
|
|
let clear_ings = clear_tx2.objectStore('ing_db');
|
|
|
|
let clear_tx3 = db.transaction(['recipe_db'], 'readwrite');
|
|
|
|
let clear_recipes = clear_tx3.objectStore('recipe_db');
|
2021-01-10 02:16:19 +00:00
|
|
|
await clear_items.clear();
|
|
|
|
await clear_sets.clear();
|
2021-01-18 01:26:39 +00:00
|
|
|
await clear_ings.clear();
|
|
|
|
await clear_recipes.clear();
|
2021-01-07 00:08:19 +00:00
|
|
|
await clear_tx.complete;
|
2021-01-18 01:26:39 +00:00
|
|
|
await clear_tx2.complete;
|
|
|
|
await clear_tx3.complete;
|
2021-01-07 00:08:19 +00:00
|
|
|
|
2021-01-10 02:16:19 +00:00
|
|
|
let add_tx = db.transaction(['item_db', 'set_db'], 'readwrite');
|
|
|
|
let items_store = add_tx.objectStore('item_db');
|
2021-01-07 00:08:19 +00:00
|
|
|
let add_promises = [];
|
|
|
|
for (const item of items) {
|
|
|
|
clean_item(item);
|
2021-01-10 02:16:19 +00:00
|
|
|
add_promises.push(items_store.add(item, item.name));
|
|
|
|
}
|
|
|
|
let sets_store = add_tx.objectStore('set_db');
|
|
|
|
for (const set in sets) {
|
|
|
|
add_promises.push(sets_store.add(sets[set], set));
|
2021-01-07 00:08:19 +00:00
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
|
|
|
|
let add_tx2 = db.transaction(['ing_db'], 'readwrite');
|
|
|
|
let ings_store = add_tx2.objectStore('ing_db');
|
|
|
|
for (const ing in ings) {
|
|
|
|
add_promises.push(ings_store.add(ings[ing], ing));
|
|
|
|
}
|
|
|
|
let add_tx3 = db.transaction(['recipe_db'], 'readwrite');
|
|
|
|
let recipes_store = add_tx3.objectStore('recipe_db');
|
|
|
|
for (const recipe in recipes) {
|
|
|
|
add_promises.push(recipes_store.add(recipes[recipe], recipe));
|
|
|
|
}
|
2021-01-07 00:08:19 +00:00
|
|
|
add_promises.push(add_tx.complete);
|
2021-01-18 01:26:39 +00:00
|
|
|
add_promises.push(add_tx2.complete);
|
|
|
|
add_promises.push(add_tx3.complete);
|
2021-01-07 00:08:19 +00:00
|
|
|
Promise.all(add_promises).then((values) => {
|
|
|
|
db.close();
|
|
|
|
init_func();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function load_init(init_func) {
|
2021-01-18 01:26:39 +00:00
|
|
|
|
|
|
|
let request = window.indexedDB.open("ing_db", DB_VERSION)
|
2021-01-07 00:08:19 +00:00
|
|
|
request.onerror = function() {
|
|
|
|
console.log("DB failed to open...");
|
2021-01-18 01:26:39 +00:00
|
|
|
}
|
2021-01-07 00:08:19 +00:00
|
|
|
|
|
|
|
request.onsuccess = function() {
|
|
|
|
db = request.result;
|
|
|
|
if (!reload) {
|
|
|
|
console.log("Using stored data...")
|
|
|
|
load_local(init_func);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
console.log("Using new data...")
|
|
|
|
load(init_func);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
request.onupgradeneeded = function(e) {
|
|
|
|
reload = true;
|
|
|
|
|
|
|
|
let db = e.target.result;
|
|
|
|
|
|
|
|
try {
|
|
|
|
db.deleteObjectStore('item_db');
|
|
|
|
}
|
|
|
|
catch (error) {
|
2021-01-10 02:16:19 +00:00
|
|
|
console.log("Could not delete item DB. This is probably fine");
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
db.deleteObjectStore('set_db');
|
|
|
|
}
|
|
|
|
catch (error) {
|
|
|
|
console.log("Could not delete set DB. This is probably fine");
|
2021-01-07 00:08:19 +00:00
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
try {
|
|
|
|
db.deleteObjectStore('ing_db');
|
|
|
|
}
|
|
|
|
catch (error) {
|
|
|
|
console.log("Could not delete ingredient DB. This is probably fine");
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
db.deleteObjectStore('recipe_db');
|
|
|
|
}
|
|
|
|
catch (error) {
|
|
|
|
console.log("Could not delete recipe DB. This is probably fine");
|
|
|
|
}
|
2021-01-10 02:16:19 +00:00
|
|
|
db.createObjectStore('item_db');
|
|
|
|
db.createObjectStore('set_db');
|
2021-01-18 01:26:39 +00:00
|
|
|
db.createObjectStore('ing_db');
|
|
|
|
db.createObjectStore('recipe_db');
|
2021-01-07 00:08:19 +00:00
|
|
|
|
|
|
|
console.log("DB setup complete...");
|
|
|
|
}
|
|
|
|
}
|