Bump db version, use displayName properly
This commit is contained in:
parent
21ef3d59ff
commit
e3ff007cc2
3 changed files with 39 additions and 13 deletions
9
build.js
9
build.js
|
@ -1,7 +1,8 @@
|
||||||
/*Class that represents a wynn player's build.
|
/*Class that represents a wynn player's build.
|
||||||
*/
|
*/
|
||||||
class Build{
|
class Build{
|
||||||
item_fields = [ "name", "displayName", "tier", "set", "slots", "type", "armorType", "color", "lore", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "fDef", "wDef", "aDef", "tDef", "eDef", "lvl", "classReq", "strReq", "dexReq", "intReq", "agiReq", "defReq", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "expoding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "accessoryType", "fixID", "skin", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd" ];
|
item_fields = [ "name", "displayName", "tier", "set", "slots", "type", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "fDef", "wDef", "aDef", "tDef", "eDef", "lvl", "classReq", "strReq", "dexReq", "intReq", "agiReq", "defReq", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "expoding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "type", "fixID", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd" ];
|
||||||
|
|
||||||
/*Turns the input amount of skill points into a float precision percentage.
|
/*Turns the input amount of skill points into a float precision percentage.
|
||||||
* @param skp - the integer skillpoint count to be converted
|
* @param skp - the integer skillpoint count to be converted
|
||||||
*/
|
*/
|
||||||
|
@ -93,9 +94,9 @@ class Build{
|
||||||
return this.helmet.name + ", " + this.chestplate.name + ", " + this.leggings.name + ", " + this.boots.name + ", " + this.ring1.name + ", " + this.ring2.name + ", " + this.bracelet.name + ", " + this.necklace.name + ", " + this.weapon.name;
|
return this.helmet.name + ", " + this.chestplate.name + ", " + this.leggings.name + ", " + this.boots.name + ", " + this.ring1.name + ", " + this.ring2.name + ", " + this.bracelet.name + ", " + this.necklace.name + ", " + this.weapon.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Getters */ TODO
|
/* Getters */
|
||||||
getHealth()
|
//getHealth()
|
||||||
/* Setters */ TODO
|
/* Setters */
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ translate_mappings = {
|
||||||
#"set": "set",
|
#"set": "set",
|
||||||
"sockets": "slots",
|
"sockets": "slots",
|
||||||
#"type": "type",
|
#"type": "type",
|
||||||
# UNUSED? "armorType": "armorType",
|
#"armorType": "armorType",
|
||||||
"armorColor": "color",
|
"armorColor": "color",
|
||||||
"addedLore": "lore",
|
"addedLore": "lore",
|
||||||
#"material": "material",
|
#"material": "material",
|
||||||
|
|
37
test.js
37
test.js
|
@ -1,12 +1,11 @@
|
||||||
import {Build} from "./build.js"
|
import {Build} from "./build.js"
|
||||||
const DB_VERSION = 1;
|
const DB_VERSION = 2;
|
||||||
// @See https://github.com/mdn/learning-area/blob/master/javascript/apis/client-side-storage/indexeddb/video-store/index.js
|
// @See https://github.com/mdn/learning-area/blob/master/javascript/apis/client-side-storage/indexeddb/video-store/index.js
|
||||||
|
|
||||||
//const item_fields = [ "name", "displayName", "tier", "set", "slots", "type", "armorType", "color", "lore", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "fDef", "wDef", "aDef", "tDef", "eDef", "lvl", "classReq", "strReq", "dexReq", "intReq", "agiReq", "defReq", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "expoding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "accessoryType", "fixID", "skin", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd" ]
|
|
||||||
|
|
||||||
let db;
|
let db;
|
||||||
let items;
|
let items;
|
||||||
let reload = false;
|
let reload = false;
|
||||||
|
// Set up item lists for quick access later.
|
||||||
let armorTypes = [ "helmet", "chestplate", "leggings", "boots" ];
|
let armorTypes = [ "helmet", "chestplate", "leggings", "boots" ];
|
||||||
let accessoryTypes = [ "ring", "bracelet", "necklace" ];
|
let accessoryTypes = [ "ring", "bracelet", "necklace" ];
|
||||||
let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ];
|
let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ];
|
||||||
|
@ -17,6 +16,10 @@ for (const it of itemTypes) {
|
||||||
}
|
}
|
||||||
let itemMap = new Map();
|
let itemMap = new Map();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function that takes an item list and populates its corresponding dropdown.
|
||||||
|
* Used for armors and bracelet/necklace.
|
||||||
|
*/
|
||||||
function populateItemList(type) {
|
function populateItemList(type) {
|
||||||
let item_list = document.getElementById(type+"-items");
|
let item_list = document.getElementById(type+"-items");
|
||||||
for (const item of itemLists.get(type)) {
|
for (const item of itemLists.get(type)) {
|
||||||
|
@ -26,15 +29,19 @@ function populateItemList(type) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Populate dropdowns, add listeners, etc.
|
||||||
|
*/
|
||||||
function init() {
|
function init() {
|
||||||
console.log(items);
|
console.log(items);
|
||||||
for (const item of items) {
|
for (const item of items) {
|
||||||
itemLists.get(item.type).push(item.name);
|
itemLists.get(item.type).push(item.displayName);
|
||||||
itemMap.set(item.name, item);
|
itemMap.set(item.displayName, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const armorType of armorTypes) {
|
for (const armorType of armorTypes) {
|
||||||
populateItemList(armorType);
|
populateItemList(armorType);
|
||||||
|
// Add change listener to update armor slots.
|
||||||
document.getElementById(armorType+"-choice").addEventListener("change", (event) => {
|
document.getElementById(armorType+"-choice").addEventListener("change", (event) => {
|
||||||
let item = itemMap.get(event.target.value);
|
let item = itemMap.get(event.target.value);
|
||||||
if (item !== undefined) {
|
if (item !== undefined) {
|
||||||
|
@ -68,6 +75,8 @@ function init() {
|
||||||
weapon_list.appendChild(el);
|
weapon_list.appendChild(el);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add change listener to update weapon slots.
|
||||||
document.getElementById("weapon-choice").addEventListener("change", (event) => {
|
document.getElementById("weapon-choice").addEventListener("change", (event) => {
|
||||||
let item = itemMap.get(event.target.value);
|
let item = itemMap.get(event.target.value);
|
||||||
if (item !== undefined) {
|
if (item !== undefined) {
|
||||||
|
@ -79,6 +88,9 @@ function init() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Load item set from local DB. Calls init() on success.
|
||||||
|
*/
|
||||||
async function load_local() {
|
async function load_local() {
|
||||||
let get_tx = db.transaction('item_db', 'readonly');
|
let get_tx = db.transaction('item_db', 'readonly');
|
||||||
let get_store = get_tx.objectStore('item_db');
|
let get_store = get_tx.objectStore('item_db');
|
||||||
|
@ -95,12 +107,18 @@ async function load_local() {
|
||||||
db.close();
|
db.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Clean bad item data. For now just assigns display name if it isn't already assigned.
|
||||||
|
*/
|
||||||
function clean_item(item) {
|
function clean_item(item) {
|
||||||
if (item.displayName === null) {
|
if (item.displayName === undefined) {
|
||||||
item.displayName = item.name;
|
item.displayName = item.name;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Load item set from remote DB (aka a big json file). Calls init() on success.
|
||||||
|
*/
|
||||||
async function load() {
|
async function load() {
|
||||||
let url = "https://hppeng-wynn.github.io/compress.json";
|
let url = "https://hppeng-wynn.github.io/compress.json";
|
||||||
let result = await (await fetch(url)).json();
|
let result = await (await fetch(url)).json();
|
||||||
|
@ -117,6 +135,7 @@ async function load() {
|
||||||
let add_store = add_tx.objectStore('item_db');
|
let add_store = add_tx.objectStore('item_db');
|
||||||
let add_promises = [];
|
let add_promises = [];
|
||||||
for (const item of items) {
|
for (const item of items) {
|
||||||
|
clean_item(item);
|
||||||
add_promises.push(add_store.add(item, item.name));
|
add_promises.push(add_store.add(item, item.name));
|
||||||
}
|
}
|
||||||
add_promises.push(add_tx.complete);
|
add_promises.push(add_tx.complete);
|
||||||
|
@ -149,6 +168,12 @@ request.onupgradeneeded = function(e) {
|
||||||
|
|
||||||
let db = e.target.result;
|
let db = e.target.result;
|
||||||
|
|
||||||
|
try {
|
||||||
|
db.deleteObjectStore('item_db');
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
console.log("Could not delete DB. This is probably fine");
|
||||||
|
}
|
||||||
let objectStore = db.createObjectStore('item_db');
|
let objectStore = db.createObjectStore('item_db');
|
||||||
|
|
||||||
objectStore.createIndex('item', 'item', {unique: false});
|
objectStore.createIndex('item', 'item', {unique: false});
|
||||||
|
|
Loading…
Reference in a new issue