2021-10-17 17:56:54 -07:00
|
|
|
const DB_VERSION = 80;
|
2021-03-01 13:57:39 -08:00
|
|
|
// @See https://github.com/mdn/learning-area/blob/master/javascript/apis/client-side-storage/indexeddb/video-store/index.jsA
|
2021-01-06 18:08:19 -06:00
|
|
|
|
|
|
|
let db;
|
|
|
|
let reload = false;
|
2021-04-02 15:19:22 -07:00
|
|
|
let load_complete = false;
|
2021-06-19 00:02:53 -07:00
|
|
|
let load_in_progress = false;
|
2021-01-06 18:08:19 -06:00
|
|
|
let items;
|
2021-01-09 19:33:42 -06:00
|
|
|
let sets;
|
2021-03-13 23:55:08 -08:00
|
|
|
let itemMap;
|
|
|
|
let idMap;
|
|
|
|
let redirectMap;
|
|
|
|
let itemLists = new Map();
|
2021-01-06 18:08:19 -06:00
|
|
|
/*
|
|
|
|
* Load item set from local DB. Calls init() on success.
|
|
|
|
*/
|
|
|
|
async function load_local(init_func) {
|
2021-04-02 14:53:18 -07:00
|
|
|
let get_tx = db.transaction(['item_db', 'set_db'], 'readonly');
|
|
|
|
let sets_store = get_tx.objectStore('set_db');
|
|
|
|
let get_store = get_tx.objectStore('item_db');
|
|
|
|
let request = get_store.getAll();
|
|
|
|
request.onerror = function(event) {
|
|
|
|
console.log("Could not read local item db...");
|
|
|
|
}
|
|
|
|
request.onsuccess = function(event) {
|
|
|
|
console.log("Successfully read local item db.");
|
|
|
|
items = request.result;
|
|
|
|
//console.log(items);
|
|
|
|
let request2 = sets_store.openCursor();
|
|
|
|
|
|
|
|
sets = {};
|
|
|
|
request2.onerror = function(event) {
|
|
|
|
console.log("Could not read local set db...");
|
2021-01-09 20:16:19 -06:00
|
|
|
}
|
2021-04-02 14:53:18 -07:00
|
|
|
|
|
|
|
request2.onsuccess = function(event) {
|
|
|
|
let cursor = event.target.result;
|
|
|
|
if (cursor) {
|
|
|
|
sets[cursor.primaryKey] = cursor.value;
|
|
|
|
cursor.continue();
|
2021-01-09 20:16:19 -06:00
|
|
|
}
|
2021-04-02 14:53:18 -07:00
|
|
|
else {
|
|
|
|
console.log("Successfully read local set db.");
|
|
|
|
//console.log(sets);
|
|
|
|
init_maps();
|
2021-04-02 15:07:15 -07:00
|
|
|
init_func();
|
2021-04-02 15:19:22 -07:00
|
|
|
load_complete = true;
|
2021-01-09 20:16:19 -06:00
|
|
|
}
|
|
|
|
}
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
2021-04-02 14:53:18 -07:00
|
|
|
await get_tx.complete;
|
2021-04-02 15:19:22 -07:00
|
|
|
db.close();
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Clean bad item data. For now just assigns display name if it isn't already assigned.
|
|
|
|
*/
|
|
|
|
function clean_item(item) {
|
2021-01-23 04:53:24 -06:00
|
|
|
if (item.remapID === undefined) {
|
|
|
|
if (item.displayName === undefined) {
|
|
|
|
item.displayName = item.name;
|
|
|
|
}
|
|
|
|
item.skillpoints = [item.str, item.dex, item.int, item.def, item.agi];
|
|
|
|
item.reqs = [item.strReq, item.dexReq, item.intReq, item.defReq, item.agiReq];
|
2021-06-19 00:44:20 -07:00
|
|
|
item.has_negstat = false;
|
2021-06-19 00:02:53 -07:00
|
|
|
for (let i = 0; i < 5; ++i) {
|
2021-06-19 00:44:20 -07:00
|
|
|
if (item.reqs[i] === undefined) { item.reqs[i] = 0; }
|
|
|
|
if (item.skillpoints[i] === undefined) { item.skillpoints[i] = 0; }
|
|
|
|
if (item.skillpoints[i] < 0) { item.has_negstat = true; }
|
2021-06-19 00:02:53 -07:00
|
|
|
}
|
2021-01-29 17:15:00 -06:00
|
|
|
if (item.slots === undefined) {
|
|
|
|
item.slots = 0
|
|
|
|
}
|
2021-07-19 14:04:56 -07:00
|
|
|
for (let key of item_fields) {
|
|
|
|
if (item[key] === undefined) {
|
|
|
|
if (key in str_item_fields) {
|
|
|
|
item[key] = "";
|
|
|
|
}
|
|
|
|
else if (key == "majorIds") {
|
|
|
|
item[key] = [];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
item[key] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Load item set from remote DB (aka a big json file). Calls init() on success.
|
|
|
|
*/
|
|
|
|
async function load(init_func) {
|
2021-01-10 16:48:37 -06:00
|
|
|
|
|
|
|
let getUrl = window.location;
|
2021-01-23 21:58:53 -06:00
|
|
|
let baseUrl = getUrl.protocol + "//" + getUrl.host + "/";// + getUrl.pathname.split('/')[1];
|
2021-02-04 04:55:15 -06:00
|
|
|
// "Random" string to prevent caching!
|
|
|
|
let url = baseUrl + "/compress.json?"+new Date();
|
2021-01-06 18:08:19 -06:00
|
|
|
let result = await (await fetch(url)).json();
|
|
|
|
items = result.items;
|
2021-01-09 19:33:42 -06:00
|
|
|
sets = result.sets;
|
2021-03-13 23:55:08 -08:00
|
|
|
|
|
|
|
|
2021-01-06 18:08:19 -06:00
|
|
|
|
2021-03-08 21:33:45 -08: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');
|
|
|
|
//
|
|
|
|
// await clear_items.clear();
|
|
|
|
// await clear_sets.clear();
|
|
|
|
// await clear_tx.complete;
|
2021-01-19 15:07:10 -06:00
|
|
|
|
2021-01-09 20:16:19 -06:00
|
|
|
let add_tx = db.transaction(['item_db', 'set_db'], 'readwrite');
|
2021-01-23 05:36:38 -06:00
|
|
|
add_tx.onabort = function(e) {
|
|
|
|
console.log(e);
|
2021-01-19 15:07:10 -06:00
|
|
|
console.log("Not enough space...");
|
|
|
|
};
|
2021-01-09 20:16:19 -06:00
|
|
|
let items_store = add_tx.objectStore('item_db');
|
2021-01-06 18:08:19 -06:00
|
|
|
let add_promises = [];
|
|
|
|
for (const item of items) {
|
|
|
|
clean_item(item);
|
2021-01-19 15:07:10 -06:00
|
|
|
let req = items_store.add(item, item.name);
|
|
|
|
req.onerror = function() {
|
|
|
|
console.log("ADD ITEM ERROR? " + item.name);
|
|
|
|
};
|
|
|
|
add_promises.push(req);
|
2021-01-09 20:16:19 -06:00
|
|
|
}
|
|
|
|
let sets_store = add_tx.objectStore('set_db');
|
|
|
|
for (const set in sets) {
|
|
|
|
add_promises.push(sets_store.add(sets[set], set));
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
|
|
|
add_promises.push(add_tx.complete);
|
|
|
|
Promise.all(add_promises).then((values) => {
|
2021-03-13 23:55:08 -08:00
|
|
|
init_maps();
|
2021-01-06 18:08:19 -06:00
|
|
|
init_func();
|
2021-04-02 15:19:22 -07:00
|
|
|
load_complete = true;
|
2021-01-06 18:08:19 -06:00
|
|
|
});
|
2021-03-31 23:52:43 -07:00
|
|
|
// DB not closed? idfk man
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
|
|
|
|
2021-06-19 00:33:39 -07:00
|
|
|
function load_init(init_func) {
|
2021-04-02 15:19:22 -07:00
|
|
|
if (load_complete) {
|
2021-03-31 23:52:43 -07:00
|
|
|
console.log("Item db already loaded, skipping load sequence");
|
2021-04-02 15:09:29 -07:00
|
|
|
init_func();
|
2021-03-31 23:52:43 -07:00
|
|
|
return;
|
|
|
|
}
|
2021-01-18 06:10:28 -06:00
|
|
|
let request = window.indexedDB.open('item_db', DB_VERSION);
|
|
|
|
|
2021-01-06 18:08:19 -06:00
|
|
|
request.onerror = function() {
|
|
|
|
console.log("DB failed to open...");
|
2021-01-18 06:10:28 -06:00
|
|
|
};
|
2021-01-06 18:08:19 -06:00
|
|
|
|
2021-06-19 00:51:07 -07:00
|
|
|
request.onsuccess = function() {
|
|
|
|
(async function() {
|
|
|
|
db = request.result;
|
|
|
|
if (!reload) {
|
|
|
|
console.log("Using stored data...")
|
|
|
|
load_local(init_func);
|
2021-06-19 00:02:53 -07:00
|
|
|
}
|
|
|
|
else {
|
2021-06-19 00:51:07 -07:00
|
|
|
if (load_in_progress) {
|
|
|
|
while (!load_complete) {
|
|
|
|
await sleep(100);
|
|
|
|
}
|
|
|
|
console.log("Skipping load...")
|
|
|
|
init_func();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// Not 100% safe... whatever!
|
|
|
|
load_in_progress = true
|
|
|
|
console.log("Using new data...")
|
|
|
|
load(init_func);
|
|
|
|
}
|
2021-06-19 00:02:53 -07:00
|
|
|
}
|
2021-06-19 00:51:07 -07:00
|
|
|
})()
|
2021-01-06 18:08:19 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
request.onupgradeneeded = function(e) {
|
|
|
|
reload = true;
|
|
|
|
|
|
|
|
let db = e.target.result;
|
|
|
|
|
|
|
|
try {
|
|
|
|
db.deleteObjectStore('item_db');
|
|
|
|
}
|
|
|
|
catch (error) {
|
2021-01-09 20:16:19 -06: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-06 18:08:19 -06:00
|
|
|
}
|
2021-01-18 06:10:28 -06:00
|
|
|
|
2021-01-09 20:16:19 -06:00
|
|
|
db.createObjectStore('item_db');
|
|
|
|
db.createObjectStore('set_db');
|
2021-01-06 18:08:19 -06:00
|
|
|
|
|
|
|
console.log("DB setup complete...");
|
|
|
|
}
|
|
|
|
}
|
2021-03-13 23:55:08 -08:00
|
|
|
|
|
|
|
function init_maps() {
|
|
|
|
//warp
|
|
|
|
itemMap = new Map();
|
|
|
|
/* Mapping from item names to set names. */
|
|
|
|
idMap = new Map();
|
|
|
|
redirectMap = new Map();
|
|
|
|
for (const it of itemTypes) {
|
|
|
|
itemLists.set(it, []);
|
|
|
|
}
|
|
|
|
|
|
|
|
let noneItems = [
|
|
|
|
["armor", "helmet", "No Helmet"],
|
|
|
|
["armor", "chestplate", "No Chestplate"],
|
|
|
|
["armor", "leggings", "No Leggings"],
|
|
|
|
["armor", "boots", "No Boots"],
|
|
|
|
["accessory", "ring", "No Ring 1"],
|
|
|
|
["accessory", "ring", "No Ring 2"],
|
|
|
|
["accessory", "bracelet", "No Bracelet"],
|
|
|
|
["accessory", "necklace", "No Necklace"],
|
|
|
|
["weapon", "dagger", "No Weapon"],
|
|
|
|
];
|
|
|
|
for (let i = 0; i < 9; i++) {
|
|
|
|
let item = Object();
|
|
|
|
item.slots = 0;
|
|
|
|
item.category = noneItems[i][0];
|
|
|
|
item.type = noneItems[i][1];
|
|
|
|
item.name = noneItems[i][2];
|
|
|
|
item.displayName = item.name;
|
|
|
|
item.set = null;
|
|
|
|
item.quest = null;
|
|
|
|
item.skillpoints = [0, 0, 0, 0, 0];
|
|
|
|
item.has_negstat = false;
|
|
|
|
item.reqs = [0, 0, 0, 0, 0];
|
|
|
|
item.fixID = true;
|
|
|
|
item.tier = "Normal";//do not get rid of this @hpp
|
|
|
|
item.id = 10000 + i;
|
|
|
|
item.nDam = "0-0";
|
|
|
|
item.eDam = "0-0";
|
|
|
|
item.tDam = "0-0";
|
|
|
|
item.wDam = "0-0";
|
|
|
|
item.fDam = "0-0";
|
|
|
|
item.aDam = "0-0";
|
2021-07-19 14:31:02 -07:00
|
|
|
clean_item(item);
|
2021-03-13 23:55:08 -08:00
|
|
|
|
|
|
|
noneItems[i] = item;
|
|
|
|
}
|
|
|
|
items = items.concat(noneItems);
|
|
|
|
//console.log(items);
|
|
|
|
for (const item of items) {
|
|
|
|
if (item.remapID === undefined) {
|
|
|
|
itemLists.get(item.type).push(item.displayName);
|
|
|
|
itemMap.set(item.displayName, item);
|
|
|
|
if (noneItems.includes(item)) {
|
|
|
|
idMap.set(item.id, "");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
idMap.set(item.id, item.displayName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
redirectMap.set(item.id, item.remapID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
console.log(itemMap);
|
2021-03-31 23:52:43 -07:00
|
|
|
}
|