dummy commit
This commit is contained in:
parent
ce3904d0ab
commit
126bcf875c
3 changed files with 1457 additions and 7 deletions
59
build.js
59
build.js
|
@ -101,7 +101,7 @@ class Build{
|
|||
}
|
||||
this.availableSkillpoints = levelToSkillPoints(this.level);
|
||||
this.equipment = [ helmet, chestplate, leggings, boots, ring1, ring2, bracelet, necklace ];
|
||||
|
||||
this.items = [helmet, chestplate, leggings, boots, ring1, ring2, bracelet, necklace, weapon];
|
||||
// return [equip_order, best_skillpoints, final_skillpoints, best_total];
|
||||
let result = calculate_skillpoints(this.equipment, weapon);
|
||||
console.log(result);
|
||||
|
@ -118,6 +118,9 @@ class Build{
|
|||
}
|
||||
|
||||
/* Getters */
|
||||
|
||||
/* Get total health for build.
|
||||
*/
|
||||
getHealth(){
|
||||
health = parseInt(this.helmet.hp,10) + parseInt(this.helmet.hpBonus,10) + parseInt(this.chestplate.hp,10) + parseInt(this.chestplate.hpBonus,10) + parseInt(this.leggings.hp,10) + parseInt(this.leggings.hpBonus,10) + parseInt(this.boots.hp,10) + parseInt(this.boots.hpBonus,10) + parseInt(this.ring1.hp,10) + parseInt(this.ring1.hpBonus,10) + parseInt(this.ring2.hp,10) + parseInt(this.ring2.hpBonus,10) + parseInt(this.bracelet.hp,10) + parseInt(this.bracelet.hpBonus,10) + parseInt(this.necklace.hp,10) + parseInt(this.necklace.hpBonus,10) + parseInt(this.weapon.hp,10) + parseInt(this.weapon.hpBonus,10) + levelToHPBase(this.level);
|
||||
if(health<5){
|
||||
|
@ -126,6 +129,60 @@ class Build{
|
|||
return health;
|
||||
}
|
||||
}
|
||||
/* Get total melee dps for build.
|
||||
*/
|
||||
getMeleeDPS(){
|
||||
let meleeMult = {
|
||||
"SUPER_SLOW":"0.51",
|
||||
"VERY_SLOW":"0.83",
|
||||
"SLOW":"1.5",
|
||||
"NORMAL":"2.05",
|
||||
"FAST":"2.5",
|
||||
"VERY_FAST":"3.1",
|
||||
"SUPER_FAST":"4.3",
|
||||
}
|
||||
let stats = this.getBuildStats();
|
||||
let nDam = stats.get("nDam");
|
||||
|
||||
return [];
|
||||
}
|
||||
|
||||
/* Get all stats for this build. Returns a map w/ sums of all IDs.
|
||||
@dep test.js.item_fields
|
||||
@dep test.js.rolledIDs
|
||||
@dep test.js.nonRolledIDs
|
||||
@dep test.js.expandItem()
|
||||
@pre The build itself should be valid. No checking of validity of pieces is done here.
|
||||
@post The map returned will contain non-stacking IDs w/ a value null.
|
||||
*/
|
||||
getBuildStats(){
|
||||
//Create a map of this build's stats
|
||||
//This is universal for every possible build, so it's possible to move this elsewhere.
|
||||
let statMap = new Map();
|
||||
for (const i in item_fields){
|
||||
let id = item_fields[i];
|
||||
if(stackingIDs.includes(id)){ //IDs stack - make it number
|
||||
statMap.set(id,0);
|
||||
}else if(standaloneIDs.includes(id)){ //IDs do not stack - string
|
||||
statMap.set(id,"");
|
||||
}
|
||||
}
|
||||
for (const i in this.items){
|
||||
let item = expandItem(this.items[i]);
|
||||
console.log(item,type(item));
|
||||
if(item.has("fixID") && item.get("fixID")){//item has fixed IDs
|
||||
for(const [key,value] in item.entries()){
|
||||
console.log(key,value);
|
||||
}
|
||||
}else{//item does not have fixed IDs
|
||||
for (const i in item) {
|
||||
console.log(entry,": ",item.get(entry));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return statMap;
|
||||
}
|
||||
|
||||
/* Setters */
|
||||
|
||||
|
|
14
test.js
14
test.js
|
@ -23,6 +23,8 @@ let weaponTypes = [ "wand", "spear", "bow", "dagger", "relik" ];
|
|||
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", "agiReq", "defReq", "hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "str", "dex", "int", "agi", "def", "thorns", "exploding", "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 nonRolledIDs = ["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","str", "dex", "int", "agi", "def", "fixID", "category", "id"];
|
||||
let rolledIDs = ["hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd"];
|
||||
let stackingIDs = ["hprPct", "mr", "sdPct", "mdPct", "ls", "ms", "xpb", "lb", "ref", "thorns", "exploding", "spd", "atkTier", "poison", "hpBonus", "spRegen", "eSteal", "hprRaw", "sdRaw", "mdRaw", "fDamPct", "wDamPct", "aDamPct", "tDamPct", "eDamPct", "fDefPct", "wDefPct", "aDefPct", "tDefPct", "eDefPct", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "lq", "gXp", "gSpd", "fDef", "wDef", "aDef", "tDef", "eDef", "str", "dex", "int", "agi", "def"];
|
||||
let standaloneIDs = ["name", "displayName", "tier", "set", "slots", "type", "material", "drop", "quest", "restrict", "nDam", "fDam", "wDam", "aDam", "tDam", "eDam", "atkSpd", "hp", "lvl", "classReq", "strReq", "dexReq", "intReq", "agiReq", "defReq", "fixID", "category", "id"];
|
||||
let itemTypes = armorTypes.concat(accessoryTypes).concat(weaponTypes);
|
||||
let itemLists = new Map();
|
||||
for (const it of itemTypes) {
|
||||
|
@ -72,6 +74,8 @@ function init() {
|
|||
item.skillpoints = [0, 0, 0, 0, 0];
|
||||
item.has_negstat = false;
|
||||
item.reqs = [0, 0, 0, 0, 0];
|
||||
item.fixID = true;
|
||||
item.tier = " ";//do not get rid of this @hpp
|
||||
item.id = 10000 + i;
|
||||
|
||||
noneItems[i] = item;
|
||||
|
@ -289,7 +293,7 @@ function calculateBuild(){
|
|||
setHTML("build-bracelet", expandedItemToString(expandItem(player_build.bracelet)));
|
||||
setHTML("build-necklace", expandedItemToString(expandItem(player_build.necklace)));
|
||||
setHTML("build-weapon", expandedItemToString(expandItem(player_build.weapon)));
|
||||
|
||||
setHTML("build-cumulative-stats", player_build.getMeleeDPS()); //Incomplete function
|
||||
location.hash = encodeBuild();
|
||||
}
|
||||
/* Helper function that gets stats ranges for wearable items.
|
||||
|
@ -314,7 +318,6 @@ function expandItem(item){
|
|||
}
|
||||
}else{ //The item does not have fixed IDs.
|
||||
for (const id in rolledIDs){
|
||||
console.log(id);
|
||||
if(item[rolledIDs[id]]){
|
||||
if(item[rolledIDs[id]] > 0){ // positive rolled IDs
|
||||
minRolls.set(rolledIDs[id],idRound(item[rolledIDs[id]]*0.3));
|
||||
|
@ -336,7 +339,6 @@ function expandItem(item){
|
|||
}
|
||||
expandedItem.set("minRolls",minRolls);
|
||||
expandedItem.set("maxRolls",maxRolls);
|
||||
console.log(expandedItem)
|
||||
return expandedItem;
|
||||
}
|
||||
/* A second helper function that takes items from expandItem() and stringifies them.
|
||||
|
@ -344,7 +346,6 @@ function expandItem(item){
|
|||
TODO: write the function
|
||||
*/
|
||||
function expandedItemToString(item){
|
||||
console.log(item);
|
||||
let ids = ["lvl", "classReq","strReq", "dexReq", "intReq", "defReq","agiReq", "nDam", "eDam", "tDam", "wDam", "tDam", "aDam", "atkSpd", "hp", "eDef", "tDef", "wDef", "fDef", "aDef", "str", "dex", "int", "agi", "def", "hpBonus", "hprRaw", "hprPct", "sdRaw", "sdPct", "mdRaw", "mdPct", "mr", "ms", "ref", "ls", "poison", "thorns", "exploding", "spd", "atkTier", "eDamPct", "tDamPct", "wDamPct", "fDamPct", "aDamPct", "eDefPct", "tDefPct", "wDefPct", "fDefPct", "aDefPct", "spPct1", "spRaw1", "spPct2", "spRaw2", "spPct3", "spRaw3", "spPct4", "spRaw4", "rainbowRaw", "sprint", "sprintReg", "jh", "xpb", "lb", "lq", "spRegen", "eSteal", "gXp", "gSpd", "slots", "set", "quest", "restrict"];
|
||||
let idPrefixes = {"lvl":"Combat Level Min: ", "classReq":"Class Req: ","strReq":"Strength Min: ","dexReq":"Dexterity Min: ","intReq":"Intelligence Min: ","defReq":"Defense Min: ","agiReq":"Agility Min: ", "nDam":"Neutral Damage: ", "eDam":"Earth Damage: ", "tDam":"Thunder Damage: ", "wDam":"Water Damage: ", "fDam":"Fire Damage: ", "aDam":"Air Damage: ", "atkSpd":"Attack Speed: ", "hp":"Health: ", "eDef":"Earth Defense: ", "tDef":"Thunder Defense: ", "wDef":"Water Defense: ", "fDef":"Fire Defense: ", "aDef":"Air Defense: ", "str":"Strength: ", "dex":"Dexterity: ", "int":"Intelligence: ", "def":"Defense: ","agi":"Agility: ", "hpBonus":"Health Bonus: ", "hprRaw":"Health Regen Raw: ", "hprPct":"Health Regen %: ", "sdRaw":"Raw Spell Damage: ", "sdPct":"Spell Damage %: ", "mdRaw":"Main Attack Neutral Damage: ", "mdPct":"Main Attack Damage %: ", "mr":"Mana Regen: ", "ms":"Mana Steal: ", "ref":"Reflection: ", "ls":"Life Steal: ", "poison":"Poison: ", "thorns":"Thorns: ", "exploding":"Expoding: ", "spd":"Walk Speed Bonus: ", "atkTier":"Attack Speed Bonus: ", "eDamPct":"Earth Damage %: ", "tDamPct":"Thunder Damage %: ", "wDamPct":"Water Damage %: ", "fDamPct":"Fire Damage %: ", "aDamPct":"Air Damage %: ", "eDefPct":"Earth Defense %: ", "tDefPct":"Thunder Defense %: ", "wDefPct":"Water Defense %: ", "fDefPct":"Fire Defense %: ", "aDefPct":"Air Defense %: ", "spPct1":"1st Spell Cost %: ", "spRaw1":"1st Spell Cost Raw: ", "spPct2":"2nd Spell Cost %: ", "spRaw2":"2nd Spell Cost Raw: ", "spPct3":"3rd Spell Cost %: ", "spRaw3":"3rd Spell Cost Raw: ", "spPct4":"4th Spell Cost %: ", "spRaw4":"4th Spell Cost Raw: ", "rainbowRaw":"Rainbow Spell Damage Raw: ", "sprint":"Sprint Bonus: ", "sprintReg":"Sprint Regen Bonus: ", "jh":"Jump Height: ", "xpb":"Combat XP Bonus: ", "lb":"Loot Bonus: ", "lq":"Loot Quality: ", "spRegen":"Soul Point Regen: ", "eSteal":"Stealing: ", "gXp":"Gathering XP Bonus: ", "gSpd":"Gathering Speed Bonus: ", "slots":"Powder Slots: ", "set":"This item belongs to the ", "quest":"This item is from the quest<br>", "restrict":""};
|
||||
let idSuffixes = {"lvl":"", "classReq":"","strReq":"","dexReq":"","intReq":"","defReq":"","agiReq":"", "nDam":"", "eDam":"", "tDam":"", "wDam":"", "fDam":"", "aDam":"", "atkSpd":"", "hp":"", "eDef":"", "tDef":"", "wDef":"", "fDef":"", "aDef":"", "str":"", "dex":"", "int":"", "def":"","agi":"", "hpBonus":"", "hprRaw":"", "hprPct":"%", "sdRaw":"", "sdPct":"%", "mdRaw":"", "mdPct":"%", "mr":"/4s", "ms":"/4s", "ref":"%", "ls":"/4s", "poison":"/3s", "thorns":"%", "exploding":"%", "spd":"%", "atkTier":" tier", "eDamPct":"%", "tDamPct":"%", "wDamPct":"%", "fDamPct":"%", "aDamPct":"%", "eDefPct":"%", "tDefPct":"%", "wDefPct":"%", "fDefPct":"%", "aDefPct":"%", "spPct1":"%", "spRaw1":"", "spPct2":"%", "spRaw2":"", "spPct3":"%", "spRaw3":"", "spPct4":"%", "spRaw4":"", "rainbowRaw":"", "sprint":"%", "sprintReg":"%", "jh":"", "xpb":"%", "lb":"%", "lq":"%", "spRegen":"%", "eSteal":"%", "gXp":"%", "gSpd":"%", "slots":"", "set":" set.", "quest":".", "restrict":""};
|
||||
|
@ -357,7 +358,6 @@ function expandedItemToString(item){
|
|||
itemString = itemString.concat(item.get(ids[i]), idSuffixes[ids[i]],"<br>");
|
||||
}
|
||||
if(rolledIDs.includes(ids[i])&& item.get("minRolls").get(ids[i]) && item.get("maxRolls").get(ids[i]) ){//rolled ID & non-0/non-null/non-und ID
|
||||
console.log("hi");
|
||||
itemString = itemString.concat(idPrefixes[ids[i]]);
|
||||
itemString = itemString.concat(item.get("minRolls").get(ids[i]), idSuffixes[ids[i]],"<br>");
|
||||
}//Just don't do anything if else
|
||||
|
@ -369,7 +369,6 @@ function expandedItemToString(item){
|
|||
itemString = itemString.concat(item.get(ids[i]), idSuffixes[ids[i]],"<br>");
|
||||
}
|
||||
if(rolledIDs.includes(ids[i])&& item.get("minRolls").get(ids[i]) && item.get("maxRolls").get(ids[i]) ){//rolled ID & non-0/non-null/non-und ID
|
||||
console.log("hi");
|
||||
itemString = itemString.concat(idPrefixes[ids[i]]);
|
||||
itemString = itemString.concat(item.get("minRolls").get(ids[i]), idSuffixes[ids[i]], " -> ", idRound(item.get("maxRolls").get(ids[i])),idSuffixes[ids[i]],"<br>");
|
||||
}//Just don't do anything if else
|
||||
|
@ -390,6 +389,8 @@ function idRound(id){
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
function resetFields(){
|
||||
setValue("helmet-choice", "");
|
||||
setValue("helmet-powder", "");
|
||||
|
@ -413,3 +414,4 @@ function resetFields(){
|
|||
}
|
||||
|
||||
load_init(init);
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue