diff --git a/build.js b/build.js index 983fcdd..751fc2b 100644 --- a/build.js +++ b/build.js @@ -409,14 +409,10 @@ class Build{ } } } + statMap.set("poisonPct", 100); // The stuff relevant for damage calculation!!! @ferricles statMap.set("atkSpd", this.weapon.get("atkSpd")); - statMap.set("damageRaw", [this.weapon.get("nDam"), this.weapon.get("eDam"), this.weapon.get("tDam"), this.weapon.get("wDam"), this.weapon.get("fDam"), this.weapon.get("aDam")]); - statMap.set("damageBonus", [statMap.get("eDamPct"), statMap.get("tDamPct"), statMap.get("wDamPct"), statMap.get("fDamPct"), statMap.get("aDamPct")]); - statMap.set("defRaw", [statMap.get("eDam"), statMap.get("tDef"), statMap.get("wDef"), statMap.get("fDef"), statMap.get("aDef")]); - statMap.set("defBonus", [statMap.get("eDamPct"), statMap.get("tDefPct"), statMap.get("wDefPct"), statMap.get("fDefPct"), statMap.get("aDefPct")]); - statMap.set("poisonPct", 100); for (const x of skp_elements) { this.externalStats.set(x + "DamPct", 0); @@ -427,6 +423,15 @@ class Build{ this.externalStats.set("defBonus",[0, 0, 0, 0, 0]); this.externalStats.set("poisonPct", 0); this.statMap = statMap; + + this.aggregateStats(); } + aggregateStats() { + let statMap = this.statMap; + statMap.set("damageRaw", [this.weapon.get("nDam"), this.weapon.get("eDam"), this.weapon.get("tDam"), this.weapon.get("wDam"), this.weapon.get("fDam"), this.weapon.get("aDam")]); + statMap.set("damageBonus", [statMap.get("eDamPct"), statMap.get("tDamPct"), statMap.get("wDamPct"), statMap.get("fDamPct"), statMap.get("aDamPct")]); + statMap.set("defRaw", [statMap.get("eDef"), statMap.get("tDef"), statMap.get("wDef"), statMap.get("fDef"), statMap.get("aDef")]); + statMap.set("defBonus", [statMap.get("eDefPct"), statMap.get("tDefPct"), statMap.get("wDefPct"), statMap.get("fDefPct"), statMap.get("aDefPct")]); + } } diff --git a/builder.js b/builder.js index 8c7684f..a3b9b47 100644 --- a/builder.js +++ b/builder.js @@ -1,16 +1,9 @@ -/* - * TESTING SECTION - */ - const url_base = location.href.split("#")[0]; const url_tag = location.hash.slice(1); console.log(url_base); console.log(url_tag); -/* - * END testing section - */ - +const BUILD_VERSION = "6.9.4"; function setTitle() { document.getElementById("header").textContent = "WynnBuilder version "+BUILD_VERSION+" (db version "+DB_VERSION+")"; @@ -26,6 +19,7 @@ let accessoryTypes = [ "ring", "bracelet", "necklace" ]; let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ]; // THIS IS SUPER DANGEROUS, WE SHOULD NOT BE KEEPING THIS IN SO MANY PLACES let 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", "defReq", "agiReq", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "expd", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "fixID", "category", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd", "id" ]; +let editable_item_fields = [ "sdPct", "sdRaw", "mdPct", "mdRaw", "poison", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "hprRaw", "hprPct", "hpBonus", "atkTier", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4" ]; let skp_order = ["str","dex","int","def","agi"]; let skp_elements = ["e","t","w","f","a"]; @@ -475,6 +469,11 @@ function calculateBuild(save_skp, skp){ for (let i in skp_order){ //big bren setText(skp_order[i] + "-skp-base", "Original Value: " + skillpoints[i]); } + + for (let id of editable_item_fields) { + setValue(id, player_build.statMap.get(id)); + setText(id+"-base", "Original Value: " + player_build.statMap.get(id)); + } if (save_skp) { // TODO: reduce duplicated code, @updateStats @@ -588,28 +587,33 @@ function updateStats() { delta_total += delta; } player_build.assigned_skillpoints += delta_total; - calculateBuildStats(); if(player_build){ - updatePowderSpecials("skip"); - updateBoosts("skip"); + updatePowderSpecials("skip", false); + updateBoosts("skip", false); } + for (let id of editable_item_fields) { + player_build.statMap.set(id, parseInt(getValue(id))); + } + player_build.aggregateStats(); + console.log(player_build.statMap); + calculateBuildStats(); } /* Updates all spell boosts */ -function updateBoosts(buttonId) { +function updateBoosts(buttonId, recalcStats) { let elem = document.getElementById(buttonId); let name = buttonId.split("-")[0]; if(buttonId !== "skip") { if (elem.classList.contains("toggleOn")) { player_build.damageMultiplier -= damageMultipliers.get(name); if (name === "warscream") { - player_build.defenseMultiplier -= .10; + player_build.defenseMultiplier -= .20; } elem.classList.remove("toggleOn"); }else{ player_build.damageMultiplier += damageMultipliers.get(name); if (name === "warscream") { - player_build.defenseMultiplier += .10; + player_build.defenseMultiplier += .20; } elem.classList.add("toggleOn"); } @@ -620,16 +624,18 @@ function updateBoosts(buttonId) { if (elem.classList.contains("toggleOn")) { elem.classList.remove("toggleOn"); player_build.damageMultiplier -= value; - if (key === "warscream") { player_build.defenseMultiplier -= .10 } + if (key === "warscream") { player_build.defenseMultiplier -= .20 } } } } - calculateBuildStats(); + if (recalcStats) { + calculateBuildStats(); + } } /* Updates all powder special boosts */ -function updatePowderSpecials(buttonId){ +function updatePowderSpecials(buttonId, recalcStats) { //console.log(player_build.statMap); let name = (buttonId).split("-")[0]; @@ -709,8 +715,10 @@ function updatePowderSpecials(buttonId){ } } + if (recalcStats) { + calculateBuildStats(); + } displayPowderSpecials(document.getElementById("powder-special-stats"), powderSpecials, player_build); - calculateBuildStats(); //also make damage boosts apply ;-; } /* Calculates all build statistics and updates the entire display. */ @@ -874,5 +882,18 @@ function resetFields(){ calculateBuild(); } +function toggleID() { + let button = document.getElementById("show-id-button"); + let targetDiv = document.getElementById("id-edit"); + if (button.classList.contains("toggleOn")) { //toggle the pressed button off + targetDiv.style.display = "none"; + button.classList.remove("toggleOn"); + } + else { + targetDiv.style.display = "block"; + button.classList.add("toggleOn"); + } +} + load_init(init); diff --git a/clean.json b/clean.json index 68bd2e4..0bc0b5a 100644 --- a/clean.json +++ b/clean.json @@ -270652,7 +270652,7 @@ "restrict": "1.20 item", "fixID": false, "strReq": 0, - "dexReq": 105, + "dexReq": 120, "intReq": 0, "defReq": 0, "agiReq": 0, diff --git a/credits.txt b/credits.txt index 6145cc2..29ba52c 100644 --- a/credits.txt +++ b/credits.txt @@ -6,5 +6,5 @@ The game, of course Additional Contributors: - QuantumNep (Layout code/layout ideas) - - dr_carlos (Hiding UI elements, misc. fixes) + - dr_carlos (Hiding UI elements properly, fade animations, proper error handling) - Atlas Inc discord (feedback, ideas, etc) diff --git a/index.html b/index.html index 71167c6..623258e 100644 --- a/index.html +++ b/index.html @@ -16,6 +16,9 @@ +
+ Forum thread (instructions/help) +
@@ -439,7 +442,7 @@

- +
Manually Assigned: 0 @@ -453,7 +456,7 @@

- +
Manually Assigned: 0 @@ -467,7 +470,7 @@

- +
Manually Assigned: 0 @@ -481,7 +484,7 @@

- +
Manually Assigned: 0 @@ -495,7 +498,7 @@

- +
Manually Assigned: 0 @@ -507,10 +510,317 @@
+ +
+