2022-07-29 17:37:09 +00:00
|
|
|
|
/**
|
|
|
|
|
* File containing generic display code, ex. for displaying items and spell damage.
|
|
|
|
|
* TODO: split this file into separate parts for each "component".
|
|
|
|
|
*/
|
|
|
|
|
|
2022-07-24 21:31:23 +00:00
|
|
|
|
const itemBGPositions = {"bow": "0 0", "spear": "9.090909090909088% 0", "wand": "18.181818181818183% 0", "dagger": "27.27272727272727% 0", "relik": "36.36363636363637% 0",
|
|
|
|
|
"helmet": "45.45454545454546% 0", "chestplate": "54.54545454545454% 0", "leggings": "63.63636363636363% 0", "boots": "72.72727272727272% 0",
|
|
|
|
|
"ring": "81.81818181818181% 0", "bracelet": "90.90909090909092% 0", "necklace": "100% 0",
|
|
|
|
|
"potion": "25% 0", "scroll": "50% 0", "food": "75% 0"};
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2021-01-09 12:47:25 +00:00
|
|
|
|
function apply_elemental_format(p_elem, id, suffix) {
|
|
|
|
|
suffix = (typeof suffix !== 'undefined') ? suffix : "";
|
|
|
|
|
// THIS IS SO JANK BUT IM TOO LAZY TO FIX IT TODO
|
|
|
|
|
let parts = idPrefixes[id].split(/ (.*)/);
|
|
|
|
|
let element_prefix = parts[0];
|
|
|
|
|
let desc = parts[1];
|
2022-07-17 02:43:13 +00:00
|
|
|
|
let i_elem = make_elem('span', [element_prefix], {textContent: element_prefix});
|
2021-01-09 12:47:25 +00:00
|
|
|
|
p_elem.appendChild(i_elem);
|
|
|
|
|
|
2022-07-17 03:06:01 +00:00
|
|
|
|
let i_elem2 = make_elem('span', [], {textContent: " "+desc+suffix});
|
2021-01-09 12:47:25 +00:00
|
|
|
|
p_elem.appendChild(i_elem2);
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-15 18:20:17 +00:00
|
|
|
|
function displaySetBonuses(parent_id,build) {
|
2021-01-10 21:01:59 +00:00
|
|
|
|
setHTML(parent_id, "");
|
|
|
|
|
let parent_div = document.getElementById(parent_id);
|
|
|
|
|
|
2022-07-17 02:43:13 +00:00
|
|
|
|
let set_summary_elem = make_elem('p', ['text-center'], {textContent: "Set Bonuses"});
|
2021-01-10 21:01:59 +00:00
|
|
|
|
parent_div.append(set_summary_elem);
|
|
|
|
|
|
|
|
|
|
for (const [setName, count] of build.activeSetCounts) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
const active_set = sets.get(setName);
|
2021-02-04 10:55:15 +00:00
|
|
|
|
if (active_set["hidden"]) { continue; }
|
|
|
|
|
|
2022-07-17 02:43:13 +00:00
|
|
|
|
let set_elem = make_elem('p', [], {id: "set-"+setName});
|
2021-01-10 21:01:59 +00:00
|
|
|
|
set_summary_elem.append(set_elem);
|
|
|
|
|
|
2021-02-04 10:55:15 +00:00
|
|
|
|
const bonus = active_set.bonuses[count-1];
|
2022-06-29 06:23:27 +00:00
|
|
|
|
let mock_item = new Map([["fixID", true],
|
|
|
|
|
["displayName", setName+" Set: "+count+"/"+sets.get(setName).items.length]]);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
let mock_minRolls = new Map();
|
2021-03-16 22:43:44 +00:00
|
|
|
|
let mock_maxRolls = new Map();
|
2021-01-10 21:01:59 +00:00
|
|
|
|
mock_item.set("minRolls", mock_minRolls);
|
2021-03-16 22:43:44 +00:00
|
|
|
|
mock_item.set("maxRolls", mock_maxRolls);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
for (const id in bonus) {
|
|
|
|
|
if (rolledIDs.includes(id)) {
|
|
|
|
|
mock_minRolls.set(id, bonus[id]);
|
2021-03-16 22:43:44 +00:00
|
|
|
|
mock_maxRolls.set(id, bonus[id]);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
mock_item.set(id, bonus[id]);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-11 12:19:15 +00:00
|
|
|
|
mock_item.set("powders", []);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
displayExpandedItem(mock_item, set_elem.id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-20 13:12:22 +00:00
|
|
|
|
function displayBuildStats(parent_id,build,command_group,stats){
|
2021-01-09 12:47:25 +00:00
|
|
|
|
// Commands to "script" the creation of nice formatting.
|
|
|
|
|
// #commands create a new element.
|
|
|
|
|
// !elemental is some janky hack for elemental damage.
|
|
|
|
|
// normals just display a thing.
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let display_commands = command_group;
|
2021-01-09 12:47:25 +00:00
|
|
|
|
let parent_div = document.getElementById(parent_id);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
// Clear the parent div.
|
|
|
|
|
if (parent_div != null) {
|
|
|
|
|
setHTML(parent_id, "");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
}
|
2021-01-09 12:47:25 +00:00
|
|
|
|
|
|
|
|
|
let active_elem;
|
|
|
|
|
let elemental_format = false;
|
|
|
|
|
|
2022-08-16 05:32:49 +00:00
|
|
|
|
//TODO this is put here for readability, consolidate with definition in `builder/build.js`
|
|
|
|
|
// TODO amend: uuhhhhh these two constants have diverged too far...
|
2021-01-09 12:47:25 +00:00
|
|
|
|
let staticIDs = ["hp", "eDef", "tDef", "wDef", "fDef", "aDef"];
|
|
|
|
|
|
|
|
|
|
for (const command of display_commands) {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
// style instructions
|
|
|
|
|
|
2021-01-09 12:47:25 +00:00
|
|
|
|
if (command.charAt(0) === "#") {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (command === "#defense-stats") {
|
2022-06-20 13:12:22 +00:00
|
|
|
|
displayDefenseStats(parent_div, stats, true);
|
2021-01-09 12:47:25 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (command.charAt(0) === "!") {
|
2021-01-09 12:47:25 +00:00
|
|
|
|
// TODO: This is sooo incredibly janky.....
|
|
|
|
|
if (command === "!elemental") {
|
|
|
|
|
elemental_format = !elemental_format;
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
// id instruction
|
2021-01-09 12:47:25 +00:00
|
|
|
|
else {
|
|
|
|
|
let id = command;
|
|
|
|
|
if (stats.get(id)) {
|
|
|
|
|
let style = null;
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
// TODO: add pos and neg style
|
2021-01-09 12:47:25 +00:00
|
|
|
|
if (!staticIDs.includes(id)) {
|
|
|
|
|
style = "positive";
|
|
|
|
|
if (stats.get(id) < 0) {
|
|
|
|
|
style = "negative";
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
// ignore
|
2021-01-11 07:05:23 +00:00
|
|
|
|
let id_val = stats.get(id);
|
2021-03-16 06:11:59 +00:00
|
|
|
|
if (reversedIDs.includes(id)) {
|
2021-01-11 17:52:21 +00:00
|
|
|
|
style === "positive" ? style = "negative" : style = "positive";
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
displayFixedID(parent_div, id, id_val, elemental_format, style);
|
2022-09-18 23:14:38 +00:00
|
|
|
|
if (id === "ls" && id_val != 0) {
|
2022-07-17 02:43:13 +00:00
|
|
|
|
let row = make_elem('div', ['row']);
|
|
|
|
|
let value_elem = make_elem('div', ['col', 'text-end']);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-07-17 03:06:01 +00:00
|
|
|
|
let prefix_elem = make_elem('b', [], {textContent: "\u279C Effective LS: "});
|
2021-01-11 07:05:23 +00:00
|
|
|
|
|
2022-06-20 13:12:22 +00:00
|
|
|
|
let defStats = getDefenseStats(stats);
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let number_elem = make_elem('b', [style], {
|
2022-07-17 02:43:13 +00:00
|
|
|
|
textContent: Math.round(defStats[1][0]*id_val/defStats[0]) + "/3s"
|
|
|
|
|
});
|
2022-06-19 18:30:10 +00:00
|
|
|
|
value_elem.append(prefix_elem);
|
|
|
|
|
value_elem.append(number_elem);
|
|
|
|
|
row.appendChild(value_elem);
|
|
|
|
|
parent_div.appendChild(row);
|
2021-01-11 07:05:23 +00:00
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
}
|
|
|
|
|
// sp thingy (WHY IS THIS HANDLED SEPARATELY TODO
|
|
|
|
|
else if (skp_order.includes(id)) {
|
2021-01-20 05:59:17 +00:00
|
|
|
|
let total_assigned = build.total_skillpoints[skp_order.indexOf(id)];
|
|
|
|
|
let base_assigned = build.base_skillpoints[skp_order.indexOf(id)];
|
|
|
|
|
let diff = total_assigned - base_assigned;
|
|
|
|
|
let style;
|
|
|
|
|
if (diff > 0) {
|
|
|
|
|
style = "positive";
|
|
|
|
|
} else if (diff < 0) {
|
|
|
|
|
style = "negative";
|
|
|
|
|
}
|
|
|
|
|
if (diff != 0) {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
displayFixedID(parent_div, id, diff, false, style);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
}
|
2021-01-09 12:47:25 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-18 01:26:39 +00:00
|
|
|
|
|
2021-01-07 22:44:52 +00:00
|
|
|
|
function displayExpandedItem(item, parent_id){
|
|
|
|
|
// Commands to "script" the creation of nice formatting.
|
|
|
|
|
// #commands create a new element.
|
2021-01-08 01:02:12 +00:00
|
|
|
|
// !elemental is some janky hack for elemental damage.
|
2021-01-07 22:44:52 +00:00
|
|
|
|
// normals just display a thing.
|
2022-06-26 07:08:02 +00:00
|
|
|
|
item = new Map(item); // shallow copy
|
2021-01-09 00:56:07 +00:00
|
|
|
|
if (item.get("category") === "weapon") {
|
2022-06-24 10:35:03 +00:00
|
|
|
|
item.set('basedps', get_base_dps(item));
|
2021-01-30 08:50:25 +00:00
|
|
|
|
} else if (item.get("category") === "armor") {
|
2021-01-09 00:56:07 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let display_commands = sq2_item_display_commands;
|
2021-01-07 22:44:52 +00:00
|
|
|
|
|
|
|
|
|
// Clear the parent div.
|
|
|
|
|
setHTML(parent_id, "");
|
|
|
|
|
let parent_div = document.getElementById(parent_id);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.classList.add("border", "border-2", "border-dark");
|
2021-01-07 22:44:52 +00:00
|
|
|
|
|
2021-01-08 01:02:12 +00:00
|
|
|
|
let fix_id = item.has("fixID") && item.get("fixID");
|
|
|
|
|
let elemental_format = false;
|
2021-01-25 22:06:41 +00:00
|
|
|
|
for (let i = 0; i < display_commands.length; i++) {
|
|
|
|
|
const command = display_commands[i];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (command.charAt(0) === "!") {
|
2021-01-08 01:02:12 +00:00
|
|
|
|
// TODO: This is sooo incredibly janky.....
|
|
|
|
|
if (command === "!elemental") {
|
|
|
|
|
elemental_format = !elemental_format;
|
2022-06-19 18:30:10 +00:00
|
|
|
|
}
|
|
|
|
|
else if (command === "!spacer") {
|
2022-07-18 06:46:23 +00:00
|
|
|
|
let spacer = make_elem('div', ["row", "my-2"], {});
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(spacer);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2021-01-08 01:02:12 +00:00
|
|
|
|
}
|
2021-01-07 22:44:52 +00:00
|
|
|
|
else {
|
2021-03-14 07:55:08 +00:00
|
|
|
|
let id = command;
|
2021-09-06 05:45:01 +00:00
|
|
|
|
if(nonRolledIDs.includes(id)){//nonRolledID & non-0/non-null/non-und ID
|
|
|
|
|
if (!item.get(id)) {
|
2022-07-18 06:46:23 +00:00
|
|
|
|
if (!(item.get("crafted") && skp_order.includes(id) &&
|
2021-09-06 05:45:01 +00:00
|
|
|
|
(item.get("maxRolls").get(id) || item.get("minRolls").get(id)))) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-09 23:31:14 +00:00
|
|
|
|
if (id === "slots") {
|
2022-07-18 06:46:23 +00:00
|
|
|
|
let p_elem = make_elem("div", ["col"]);
|
|
|
|
|
|
2021-01-28 00:52:34 +00:00
|
|
|
|
// PROPER POWDER DISPLAYING
|
2021-01-11 07:22:06 +00:00
|
|
|
|
let numerals = new Map([[1, "I"], [2, "II"], [3, "III"], [4, "IV"], [5, "V"], [6, "VI"]]);
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
p_elem.appendChild(make_elem("b", [], {
|
2022-07-18 06:46:23 +00:00
|
|
|
|
textContent: "Powder Slots: " + item.get(id) + " ["
|
2022-07-18 07:34:29 +00:00
|
|
|
|
}));
|
2021-01-11 01:47:13 +00:00
|
|
|
|
|
2021-01-11 07:22:06 +00:00
|
|
|
|
let powders = item.get("powders");
|
|
|
|
|
for (let i = 0; i < powders.length; i++) {
|
2022-07-18 07:34:29 +00:00
|
|
|
|
p_elem.appendChild(make_elem("b", [damageClasses[Math.floor(powders[i]/6)+1]+"_powder"], {
|
|
|
|
|
textContent: numerals.get((powders[i]%6)+1)+" "
|
|
|
|
|
}));
|
2021-01-10 21:31:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
p_elem.appendChild(make_elem("b", [], { textContent: "]" }));
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(p_elem);
|
2021-02-04 10:55:15 +00:00
|
|
|
|
} else if (id === "set") {
|
|
|
|
|
if (item.get("hideSet")) { continue; }
|
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
parent_div.appendChild(make_elem("div", ["col"], { textContent: "Set: " + item.get(id).toString() }));
|
2021-01-30 12:09:32 +00:00
|
|
|
|
} else if (id === "majorIds") {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
//console.log(item.get(id));
|
2021-07-19 21:31:02 +00:00
|
|
|
|
for (let majorID of item.get(id)) {
|
2022-07-18 06:46:23 +00:00
|
|
|
|
let p_elem = make_elem("div", ['col']);
|
2021-07-19 21:31:02 +00:00
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let title_elem = make_elem("b");
|
|
|
|
|
let b_elem = make_elem("b");
|
2021-07-19 21:31:02 +00:00
|
|
|
|
if (majorID.includes(":")) {
|
|
|
|
|
let name = majorID.substring(0, majorID.indexOf(":")+1);
|
|
|
|
|
let mid = majorID.substring(majorID.indexOf(":")+1);
|
|
|
|
|
if (name.charAt(0) !== "+") {name = "+" + name}
|
|
|
|
|
title_elem.classList.add("Legendary");
|
|
|
|
|
title_elem.textContent = name;
|
|
|
|
|
b_elem.classList.add("Crafted");
|
|
|
|
|
b_elem.textContent = mid;
|
|
|
|
|
p_elem.appendChild(title_elem);
|
|
|
|
|
p_elem.appendChild(b_elem);
|
|
|
|
|
} else {
|
|
|
|
|
let name = item.get(id).toString()
|
|
|
|
|
if (name.charAt(0) !== "+") {name = "+" + name}
|
|
|
|
|
b_elem.classList.add("Legendary");
|
|
|
|
|
b_elem.textContent = name;
|
|
|
|
|
p_elem.appendChild(b_elem);
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(p_elem);
|
2021-03-27 18:17:58 +00:00
|
|
|
|
}
|
2021-03-14 07:55:08 +00:00
|
|
|
|
} else if (id === "lvl" && item.get("tier") === "Crafted") {
|
2022-07-18 07:34:29 +00:00
|
|
|
|
parent_div.appendChild(make_elem("div", ["col"], {
|
|
|
|
|
textContent: "Combat Level Min: " + item.get("lvlLow") + "-" + item.get(id)
|
|
|
|
|
}));
|
2021-09-25 18:57:57 +00:00
|
|
|
|
} else if (id === "displayName") {
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let row = make_elem("div", ["row", "justify-content-center"]);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let nolink_row = make_elem("div", ["row", "justify-content-center"]);
|
|
|
|
|
nolink_row.style.display = "none";
|
|
|
|
|
|
|
|
|
|
const tier_class = item.has("tier") ? item.get("tier").replace(" ","") : "Normal";
|
|
|
|
|
let item_link;
|
|
|
|
|
if (item.get("custom")) {
|
|
|
|
|
item_link = "../custom/#" + item.get("hash");
|
|
|
|
|
} else if (item.get("crafted")) {
|
2022-08-20 05:48:37 +00:00
|
|
|
|
item_link = "../crafter/#" + item.get("hash");
|
2022-07-18 07:34:29 +00:00
|
|
|
|
} else {
|
|
|
|
|
item_link = "../item/#" + item.get("displayName");
|
|
|
|
|
}
|
|
|
|
|
const item_name_elem = make_elem("a", ["col-auto", "text-center", "item-title", "p-0", tier_class], {
|
|
|
|
|
textContent: item.get('displayName')
|
|
|
|
|
});
|
|
|
|
|
nolink_row.appendChild(item_name_elem.cloneNode(true));
|
|
|
|
|
item_name_elem.href = item_link;
|
2022-07-19 03:43:25 +00:00
|
|
|
|
row.appendChild(item_name_elem);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
FUNCTIONALITY FOR THIS FEATURE HAS SINCE BEEN REMOVED (WITH SQ2).
|
|
|
|
|
IF WE WANT TO USE IT IN THE FUTURE, I'VE LEFT THE CODE TO ADD IT IN HERE
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
//allow the plus minus element to toggle upon click: ➕➖
|
2022-06-19 20:44:02 +00:00
|
|
|
|
//let plusminus = document.createElement("div");
|
|
|
|
|
//plusminus.id = parent_div.id.split("-")[0] + "-pm";
|
|
|
|
|
//plusminus.classList.add("col", "plus_minus", "text_end");
|
|
|
|
|
//plusminus.style.flexGrow = 0;
|
|
|
|
|
//plusminus.textContent = "\u2795";
|
|
|
|
|
//row.appendChild(plusminus);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(row);
|
|
|
|
|
parent_div.appendChild(nolink_row);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
if (item.has("type")) {
|
2022-07-24 21:31:23 +00:00
|
|
|
|
let img = make_elem("div", [], {
|
2022-07-18 07:34:29 +00:00
|
|
|
|
alt: item.get("type"),
|
2022-07-24 21:31:23 +00:00
|
|
|
|
style: "z-index: 1; position: relative; image-rendering: pixelated; width: 50%; height: 50%; background-position: " + itemBGPositions[item.get("type")] + ";"
|
2022-07-18 07:34:29 +00:00
|
|
|
|
});
|
2022-07-24 21:31:23 +00:00
|
|
|
|
if (["potion", "scroll", "food"].includes(item.get("type"))) {
|
|
|
|
|
img.style.backgroundImage = "url('../media/items/common.png')";
|
|
|
|
|
img.style.backgroundSize = "500% 100%";
|
|
|
|
|
} else {
|
|
|
|
|
img.style.backgroundImage = "url('../media/items/" + (newIcons ? "new.png')" : "old.png')");
|
|
|
|
|
img.style.backgroundSize = "1200% 100%";
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let container = make_elem("div");
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-07-18 07:34:29 +00:00
|
|
|
|
let bckgrd = make_elem("div", ["col", "px-0", "d-flex", "align-items-center", "justify-content-center", 'scaled-bckgrd'], { // , "no-collapse"
|
|
|
|
|
style: "border-radius: 50%;background-image: radial-gradient(closest-side, " + colorMap.get(item.get("tier")) + " 20%," + "hsl(0, 0%, 16%) 80%); margin-left: auto; margin-right: auto;"
|
|
|
|
|
});
|
2021-09-25 18:57:57 +00:00
|
|
|
|
bckgrd.appendChild(img);
|
2022-07-18 07:34:29 +00:00
|
|
|
|
container.appendChild(bckgrd);
|
|
|
|
|
parent_div.appendChild(container);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
}
|
2021-01-19 17:32:27 +00:00
|
|
|
|
} else {
|
2022-06-26 07:08:02 +00:00
|
|
|
|
if (id.endsWith('Dam_')) {
|
|
|
|
|
// TODO: kinda jank but replacing lists with txt at this step
|
|
|
|
|
let damages = item.get(id);
|
|
|
|
|
if (item.get("tier") !== "Crafted") {
|
|
|
|
|
damages = damages.map(x => Math.round(x));
|
|
|
|
|
item.set(id, damages[0]+"-"+damages[1]);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
damages = damages.map(x => x.map(y => Math.round(y)));
|
|
|
|
|
item.set(id, damages[0][0]+"-"+damages[0][1]+"\u279c"+damages[1][0]+"-"+damages[1][1]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-19 17:32:27 +00:00
|
|
|
|
let p_elem;
|
2022-06-26 07:08:02 +00:00
|
|
|
|
// TODO: wtf is this if statement
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if ( !(item.get("tier") === "Crafted" && item.get("category") === "armor" && id === "hp") && (!skp_order.includes(id)) || (skp_order.includes(id) && item.get("tier") !== "Crafted" && parent_div.nodeName === "table") ) { //skp warp
|
|
|
|
|
p_elem = displayFixedID(parent_div, id, item.get(id), elemental_format);
|
2021-01-30 08:50:25 +00:00
|
|
|
|
} else if (item.get("tier") === "Crafted" && item.get("category") === "armor" && id === "hp") {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
p_elem = displayFixedID(parent_div, id, item.get(id+"Low")+"-"+item.get(id), elemental_format);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
}
|
|
|
|
|
if (id === "lore") {
|
2021-03-05 16:28:00 +00:00
|
|
|
|
p_elem.style = "font-style: italic";
|
2021-01-11 07:05:23 +00:00
|
|
|
|
} else if (skp_order.includes(id)) { //id = str, dex, int, def, or agi
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if ( item.get("tier") !== "Crafted") {
|
2022-07-18 07:34:29 +00:00
|
|
|
|
row = make_elem("div", ["col"]);
|
2021-01-19 17:32:27 +00:00
|
|
|
|
|
|
|
|
|
let title = document.createElement("b");
|
|
|
|
|
title.textContent = idPrefixes[id] + " ";
|
|
|
|
|
let boost = document.createElement("b");
|
|
|
|
|
if (item.get(id) < 0) {
|
|
|
|
|
boost.classList.add("negative");
|
|
|
|
|
} else { //boost = 0 SHOULD not come up
|
|
|
|
|
boost.classList.add("positive");
|
|
|
|
|
}
|
|
|
|
|
boost.textContent = item.get(id);
|
|
|
|
|
row.appendChild(title);
|
|
|
|
|
row.appendChild(boost);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(row);
|
|
|
|
|
} else if ( item.get("tier") === "Crafted") {
|
2021-09-25 18:57:57 +00:00
|
|
|
|
let row = displayRolledID(item, id, elemental_format);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(row);
|
2021-01-11 07:05:23 +00:00
|
|
|
|
}
|
2021-03-14 07:55:08 +00:00
|
|
|
|
} else if (id === "restrict") {
|
2021-01-11 07:05:23 +00:00
|
|
|
|
p_elem.classList.add("restrict");
|
2021-03-14 07:55:08 +00:00
|
|
|
|
}
|
2021-01-09 23:31:14 +00:00
|
|
|
|
}
|
2021-01-07 22:44:52 +00:00
|
|
|
|
}
|
2021-09-06 05:45:01 +00:00
|
|
|
|
else if ( rolledIDs.includes(id) &&
|
|
|
|
|
((item.get("maxRolls") && item.get("maxRolls").get(id))
|
|
|
|
|
|| (item.get("minRolls") && item.get("minRolls").get(id)))) {
|
2021-01-08 01:02:12 +00:00
|
|
|
|
let style = "positive";
|
|
|
|
|
if (item.get("minRolls").get(id) < 0) {
|
|
|
|
|
style = "negative";
|
|
|
|
|
}
|
2021-03-16 06:09:28 +00:00
|
|
|
|
if(reversedIDs.includes(id)){
|
2021-01-10 21:31:29 +00:00
|
|
|
|
style === "positive" ? style = "negative" : style = "positive";
|
|
|
|
|
}
|
2021-01-08 01:02:12 +00:00
|
|
|
|
if (fix_id) {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
p_elem = document.createElement("div");
|
|
|
|
|
p_elem.classList.add("col", "text-nowrap");
|
|
|
|
|
if (id == "dex") {
|
|
|
|
|
console.log("dex activated at fix_id")
|
|
|
|
|
}
|
|
|
|
|
displayFixedID(p_elem, id, item.get("minRolls").get(id), elemental_format, style);
|
|
|
|
|
parent_div.appendChild(p_elem);
|
2021-01-08 01:02:12 +00:00
|
|
|
|
}
|
|
|
|
|
else {
|
2021-09-25 18:57:57 +00:00
|
|
|
|
let row = displayRolledID(item, id, elemental_format);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.appendChild(row);
|
2021-01-08 01:02:12 +00:00
|
|
|
|
}
|
2021-01-19 17:32:27 +00:00
|
|
|
|
}else{
|
|
|
|
|
// :/
|
|
|
|
|
}
|
2021-01-07 22:44:52 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-11 06:49:52 +00:00
|
|
|
|
//Show powder specials ;-;
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let powder_specials_check = ["relik", "wand", "bow", "spear", "dagger", "chestplate", "helmet", "leggings", "boots"];
|
|
|
|
|
if(powder_specials_check.includes(item.get("type"))) {
|
|
|
|
|
let powder_special = make_elem("div", ['col']);
|
2021-01-19 17:32:27 +00:00
|
|
|
|
let powders = item.get("powders");
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let element;
|
|
|
|
|
let power_index;
|
2021-01-19 17:32:27 +00:00
|
|
|
|
for (let i = 0; i < powders.length; i++) {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
const firstPowderType = skp_elements[Math.floor(powders[i]/6)];
|
|
|
|
|
const powder1_power = powders[i] % 6;
|
|
|
|
|
if (powder1_power > 2) { //t4+
|
2021-01-19 17:32:27 +00:00
|
|
|
|
for (let j = i+1; j < powders.length; j++) {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
const currentPowderType = skp_elements[Math.floor(powders[j]/6)]
|
|
|
|
|
const powder2_power = powders[j] % 6;
|
|
|
|
|
if (powder2_power > 2 && firstPowderType === currentPowderType) {
|
2021-01-19 17:32:27 +00:00
|
|
|
|
element = currentPowderType;
|
2022-08-02 04:11:53 +00:00
|
|
|
|
power_index = powder1_power + powder2_power - 6;
|
2021-01-19 17:32:27 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
2021-01-11 06:49:52 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-09-16 06:00:44 +00:00
|
|
|
|
if (element) { break; } // terminate early if already found.
|
2021-01-11 06:49:52 +00:00
|
|
|
|
}
|
2022-08-02 04:11:53 +00:00
|
|
|
|
if (element) {//powder special is "[e,t,w,f,a]+[0,1,2,3,4]"
|
|
|
|
|
const powderSpecial = powderSpecialStats[skp_elements.indexOf(element)];
|
|
|
|
|
const specialSuffixes = new Map([ ["Duration", " sec"], ["Radius", " blocks"], ["Chains", ""], ["Damage", "%"], ["Damage Boost", "%"], ["Knockback", " blocks"] ]);
|
|
|
|
|
const specialTitle = make_elem("span", [damageClasses[skp_elements.indexOf(element) + 1]]);
|
|
|
|
|
const specialEffects = document.createElement("span");
|
2021-01-19 17:32:27 +00:00
|
|
|
|
let effects;
|
|
|
|
|
if (item.get("category") === "weapon") {//weapon
|
|
|
|
|
effects = powderSpecial["weaponSpecialEffects"];
|
|
|
|
|
specialTitle.textContent = powderSpecial["weaponSpecialName"];
|
2022-08-02 04:11:53 +00:00
|
|
|
|
} else if (item.get("category") === "armor") {//armor
|
2021-01-19 17:32:27 +00:00
|
|
|
|
effects = powderSpecial["armorSpecialEffects"];
|
|
|
|
|
specialTitle.textContent += powderSpecial["armorSpecialName"] + ": ";
|
|
|
|
|
}
|
2021-02-03 17:47:48 +00:00
|
|
|
|
for (const [key,value] of effects.entries()) {
|
|
|
|
|
if (key !== "Description") {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let effect = make_elem("p", ["m-0"], {
|
|
|
|
|
textContent: key + ": " + value[power_index] + specialSuffixes.get(key)
|
|
|
|
|
});
|
2021-02-03 17:47:48 +00:00
|
|
|
|
if(key === "Damage"){
|
2021-01-19 17:32:27 +00:00
|
|
|
|
effect.textContent += elementIcons[skp_elements.indexOf(element)];
|
|
|
|
|
}
|
2021-02-05 18:09:36 +00:00
|
|
|
|
if (element === "w" && item.get("category") === "armor") {
|
2021-01-19 17:32:27 +00:00
|
|
|
|
effect.textContent += " / Mana Used";
|
|
|
|
|
}
|
|
|
|
|
specialEffects.appendChild(effect);
|
2022-08-02 04:11:53 +00:00
|
|
|
|
} else {
|
2021-01-19 17:32:27 +00:00
|
|
|
|
specialTitle.textContent += "[ " + effects.get("Description") + " ]";
|
2021-01-11 07:40:49 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-08-02 04:11:53 +00:00
|
|
|
|
powder_special.append(specialTitle, specialEffects);
|
2021-02-03 17:47:48 +00:00
|
|
|
|
parent_div.appendChild(powder_special);
|
2021-01-11 07:40:49 +00:00
|
|
|
|
}
|
2021-01-11 06:49:52 +00:00
|
|
|
|
}
|
2021-01-19 17:32:27 +00:00
|
|
|
|
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let nonConsumables = ["relik", "wand", "bow", "spear", "dagger", "chestplate", "helmet", "leggings", "boots", "ring", "bracelet", "necklace"];
|
2021-01-19 17:32:27 +00:00
|
|
|
|
if(item.get("tier") && item.get("tier") === "Crafted") {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let dura_elem = make_elem("div", ["col"]);
|
|
|
|
|
let dura;
|
2021-01-19 17:32:27 +00:00
|
|
|
|
let suffix = "";
|
|
|
|
|
if(nonConsumables.includes(item.get("type"))) {
|
|
|
|
|
dura = item.get("durability");
|
|
|
|
|
dura_elem.textContent = "Durability: "
|
|
|
|
|
} else {
|
|
|
|
|
dura = item.get("duration");
|
|
|
|
|
dura_elem.textContent = "Duration: "
|
|
|
|
|
suffix = " sec."
|
2022-08-02 04:11:53 +00:00
|
|
|
|
parent_div.appendChild(make_elem('b', [], {
|
|
|
|
|
textContent: "Charges: " + item.get("charges")
|
|
|
|
|
}));
|
2021-01-19 17:32:27 +00:00
|
|
|
|
}
|
2021-03-14 07:55:08 +00:00
|
|
|
|
|
|
|
|
|
if (typeof(dura) === "string") {
|
|
|
|
|
dura_elem.textContent += dura + suffix;
|
|
|
|
|
} else {
|
|
|
|
|
dura_elem.textContent += dura[0]+"-"+dura[1] + suffix;
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
parent_div.append(dura_elem);
|
2021-01-28 00:52:34 +00:00
|
|
|
|
|
2021-01-19 17:32:27 +00:00
|
|
|
|
}
|
2021-01-11 06:49:52 +00:00
|
|
|
|
//Show item tier
|
2021-01-11 17:52:21 +00:00
|
|
|
|
if (item.get("tier") && item.get("tier") !== " ") {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let item_desc_elem = make_elem("div", ["col", item.get("tier")]);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (tome_types.includes(item.get("type"))) {
|
|
|
|
|
tome_type_map = new Map([["weaponTome", "Weapon Tome"],["armorTome", "Armor Tome"],["guildTome", "Guild Tome"]]);
|
|
|
|
|
item_desc_elem.textContent = item.get("tier")+" "+tome_type_map.get(item.get("type"));
|
|
|
|
|
} else {
|
|
|
|
|
item_desc_elem.textContent = item.get("tier")+" "+item.get("type");
|
|
|
|
|
}
|
|
|
|
|
parent_div.append(item_desc_elem);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
}
|
2021-03-14 07:55:08 +00:00
|
|
|
|
|
|
|
|
|
//Show item hash if applicable
|
|
|
|
|
if (item.get("crafted") || item.get("custom")) {
|
2022-08-02 04:11:53 +00:00
|
|
|
|
parent_div.append(make_elem('p', ['itemp'], {
|
|
|
|
|
style: {
|
|
|
|
|
maxWidth: '100%',
|
|
|
|
|
wordWrap: 'break-word',
|
|
|
|
|
wordBreak: 'break-word'
|
|
|
|
|
},
|
|
|
|
|
textContent: item.get('hash')
|
|
|
|
|
}));
|
2021-04-17 09:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (item.get("category") === "weapon") {
|
|
|
|
|
let total_damages = item.get("basedps");
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let base_dps_elem = make_elem("p", ["left", "itemp"]);
|
2021-04-17 09:54:44 +00:00
|
|
|
|
if (item.get("tier") === "Crafted") {
|
2022-06-24 10:35:03 +00:00
|
|
|
|
let base_dps_min = total_damages[0];
|
|
|
|
|
let base_dps_max = total_damages[1];
|
2021-04-17 09:54:44 +00:00
|
|
|
|
|
2021-04-30 03:10:29 +00:00
|
|
|
|
base_dps_elem.textContent = "Base DPS: "+base_dps_min.toFixed(3)+"\u279c"+base_dps_max.toFixed(3);
|
2021-04-17 09:54:44 +00:00
|
|
|
|
}
|
|
|
|
|
else {
|
2022-06-24 10:35:03 +00:00
|
|
|
|
base_dps_elem.textContent = "Base DPS: "+(total_damages);
|
2021-04-17 09:54:44 +00:00
|
|
|
|
}
|
2022-08-02 04:11:53 +00:00
|
|
|
|
parent_div.append(make_elem("p"), base_dps_elem);
|
2021-03-14 07:55:08 +00:00
|
|
|
|
}
|
2021-01-07 22:44:52 +00:00
|
|
|
|
}
|
2021-01-20 05:59:17 +00:00
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
/*
|
|
|
|
|
* Displays stats about a recipe that are NOT displayed in the craft stats.
|
|
|
|
|
* Includes: mat name and amounts, ingred names in an "array" with ingred effectiveness
|
2021-01-20 05:59:17 +00:00
|
|
|
|
*/
|
|
|
|
|
function displayRecipeStats(craft, parent_id) {
|
|
|
|
|
let elem = document.getElementById(parent_id);
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
|
|
|
|
//local vars
|
2021-01-20 05:59:17 +00:00
|
|
|
|
elem.textContent = "";
|
|
|
|
|
recipe = craft["recipe"];
|
2021-03-14 07:55:08 +00:00
|
|
|
|
mat_tiers = craft["mat_tiers"];
|
2021-01-20 05:59:17 +00:00
|
|
|
|
ingreds = [];
|
|
|
|
|
for (const n of craft["ingreds"]) {
|
|
|
|
|
ingreds.push(n.get("name"));
|
|
|
|
|
}
|
|
|
|
|
let effectiveness = craft["statMap"].get("ingredEffectiveness");
|
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let title = document.createElement("div");
|
2022-07-12 05:10:55 +00:00
|
|
|
|
title.classList.add("col", "box-title", "fw-bold", "justify-content-center", "scaled-font");
|
2021-01-20 05:59:17 +00:00
|
|
|
|
title.textContent = "Recipe Stats";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
elem.appendChild(title);
|
|
|
|
|
|
|
|
|
|
let mats = document.createElement("div");
|
2022-07-12 05:10:55 +00:00
|
|
|
|
mats.classList.add("col");
|
2021-01-20 05:59:17 +00:00
|
|
|
|
mats.textContent = "Crafting Materials: ";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
elem.appendChild(mats);
|
|
|
|
|
|
2021-01-20 05:59:17 +00:00
|
|
|
|
for (let i = 0; i < 2; i++) {
|
2021-03-14 07:55:08 +00:00
|
|
|
|
let tier = mat_tiers[i];
|
2022-07-12 05:10:55 +00:00
|
|
|
|
let col = document.createElement("div");
|
|
|
|
|
col.classList.add("col", "ps-4");
|
|
|
|
|
let b = document.createElement("span");
|
2021-01-20 05:59:17 +00:00
|
|
|
|
let mat = recipe.get("materials")[i];
|
|
|
|
|
b.textContent = "- " + mat.get("amount") + "x " + mat.get("item").split(" ").slice(1).join(" ");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
b.classList.add("col");
|
2022-07-12 05:10:55 +00:00
|
|
|
|
col.appendChild(b);
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
2022-07-12 05:10:55 +00:00
|
|
|
|
let starsContainer = document.createElement("span");
|
|
|
|
|
let starsB = document.createElement("span");
|
|
|
|
|
starsB.classList.add("T1-bracket", "px-0");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
starsB.textContent = "[";
|
2022-07-12 05:10:55 +00:00
|
|
|
|
starsContainer.appendChild(starsB);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
for(let j = 0; j < 3; j ++) {
|
2022-07-12 05:10:55 +00:00
|
|
|
|
let star = document.createElement("span");
|
|
|
|
|
star.classList.add("px-0");
|
2021-01-20 05:59:17 +00:00
|
|
|
|
star.textContent = "\u272B";
|
|
|
|
|
if(j < tier) {
|
|
|
|
|
star.classList.add("T1");
|
|
|
|
|
} else {
|
|
|
|
|
star.classList.add("T0");
|
|
|
|
|
}
|
2022-07-12 05:10:55 +00:00
|
|
|
|
starsContainer.append(star);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
}
|
2022-07-12 05:10:55 +00:00
|
|
|
|
let starsE = document.createElement("span");
|
|
|
|
|
starsE.classList.add("T1-bracket", "px-0");
|
2021-01-20 05:59:17 +00:00
|
|
|
|
starsE.textContent = "]";
|
2022-07-12 05:10:55 +00:00
|
|
|
|
starsContainer.appendChild(starsE);
|
|
|
|
|
|
|
|
|
|
col.appendChild(starsContainer);
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
2022-07-12 05:10:55 +00:00
|
|
|
|
elem.appendChild(col);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let ingredTable = document.createElement("div");
|
2022-07-12 05:10:55 +00:00
|
|
|
|
ingredTable.classList.add("col", "mt-2");
|
|
|
|
|
|
|
|
|
|
let ingredContainer = document.createElement("div");
|
|
|
|
|
ingredContainer.classList.add("row", "row-cols-2", "g-3");
|
|
|
|
|
for (let i = 0; i < 6; i++) {
|
|
|
|
|
let ingredCell = document.createElement("div");
|
|
|
|
|
ingredCell.classList.add("col");
|
|
|
|
|
|
|
|
|
|
let ingredTextContainer = document.createElement("div");
|
|
|
|
|
ingredTextContainer.classList.add("border", "border-3", "rounded")
|
|
|
|
|
|
|
|
|
|
let ingredName = ingreds[i];
|
|
|
|
|
let ingred_text = document.createElement("p");
|
|
|
|
|
ingred_text.classList.add("mb-2", "ps-2");
|
|
|
|
|
ingred_text.textContent = ingredName;
|
|
|
|
|
ingredTextContainer.appendChild(ingred_text);
|
|
|
|
|
|
|
|
|
|
let eff_div = document.createElement("p");
|
|
|
|
|
eff_div.classList.add("mb-2", "ps-2");
|
|
|
|
|
let e = effectiveness[i];
|
|
|
|
|
if (e > 0) {
|
|
|
|
|
eff_div.classList.add("positive");
|
|
|
|
|
} else if (e < 0) {
|
|
|
|
|
eff_div.classList.add("negative");
|
|
|
|
|
}
|
|
|
|
|
eff_div.textContent = "[" + e + "%]";
|
|
|
|
|
ingredTextContainer.appendChild(eff_div);
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
2022-07-12 05:10:55 +00:00
|
|
|
|
ingredCell.appendChild(ingredTextContainer);
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
2022-07-12 05:10:55 +00:00
|
|
|
|
ingredContainer.appendChild(ingredCell);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
}
|
2022-07-12 05:10:55 +00:00
|
|
|
|
ingredTable.appendChild(ingredContainer);
|
2021-01-20 05:59:17 +00:00
|
|
|
|
elem.appendChild(ingredTable);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Displays a craft. If things change, this function should be modified.
|
2021-01-18 01:26:39 +00:00
|
|
|
|
function displayCraftStats(craft, parent_id) {
|
2021-01-19 17:32:27 +00:00
|
|
|
|
let mock_item = craft.statMap;
|
|
|
|
|
displayExpandedItem(mock_item,parent_id);
|
2021-01-18 01:26:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
/*
|
|
|
|
|
* Displays an ingredient in item format.
|
|
|
|
|
* However, an ingredient is too far from a normal item to display as one.
|
|
|
|
|
*/
|
2021-01-18 01:26:39 +00:00
|
|
|
|
function displayExpandedIngredient(ingred, parent_id) {
|
2021-01-18 20:23:37 +00:00
|
|
|
|
let parent_elem = document.getElementById(parent_id);
|
|
|
|
|
parent_elem.textContent = "";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
|
2021-01-18 20:23:37 +00:00
|
|
|
|
let item_order = [
|
|
|
|
|
"dura",
|
|
|
|
|
"strReq",
|
|
|
|
|
"dexReq",
|
|
|
|
|
"intReq",
|
|
|
|
|
"defReq",
|
|
|
|
|
"agiReq"
|
|
|
|
|
]
|
|
|
|
|
let consumable_order = [
|
|
|
|
|
"dura",
|
|
|
|
|
"charges"
|
|
|
|
|
]
|
|
|
|
|
let posMods_order = [
|
|
|
|
|
"above",
|
2021-01-19 17:32:27 +00:00
|
|
|
|
"under",
|
2021-01-18 20:23:37 +00:00
|
|
|
|
"left",
|
|
|
|
|
"right",
|
|
|
|
|
"touching",
|
|
|
|
|
"notTouching"
|
|
|
|
|
];
|
|
|
|
|
let id_display_order = [
|
2021-01-18 01:26:39 +00:00
|
|
|
|
"eDefPct",
|
|
|
|
|
"tDefPct",
|
|
|
|
|
"wDefPct",
|
|
|
|
|
"fDefPct",
|
|
|
|
|
"aDefPct",
|
|
|
|
|
"eDamPct",
|
|
|
|
|
"tDamPct",
|
|
|
|
|
"wDamPct",
|
|
|
|
|
"fDamPct",
|
|
|
|
|
"aDamPct",
|
|
|
|
|
"str",
|
|
|
|
|
"dex",
|
|
|
|
|
"int",
|
|
|
|
|
"agi",
|
|
|
|
|
"def",
|
|
|
|
|
"hpBonus",
|
|
|
|
|
"mr",
|
|
|
|
|
"ms",
|
|
|
|
|
"ls",
|
|
|
|
|
"hprRaw",
|
|
|
|
|
"hprPct",
|
|
|
|
|
"sdRaw",
|
|
|
|
|
"sdPct",
|
|
|
|
|
"mdRaw",
|
|
|
|
|
"mdPct",
|
|
|
|
|
"xpb",
|
|
|
|
|
"lb",
|
|
|
|
|
"lq",
|
|
|
|
|
"ref",
|
|
|
|
|
"thorns",
|
|
|
|
|
"expd",
|
|
|
|
|
"spd",
|
|
|
|
|
"atkTier",
|
|
|
|
|
"poison",
|
|
|
|
|
"spRegen",
|
|
|
|
|
"eSteal",
|
|
|
|
|
"spRaw1",
|
|
|
|
|
"spRaw2",
|
|
|
|
|
"spRaw3",
|
|
|
|
|
"spRaw4",
|
|
|
|
|
"spPct1",
|
|
|
|
|
"spPct2",
|
|
|
|
|
"spPct3",
|
|
|
|
|
"spPct4",
|
|
|
|
|
"jh",
|
|
|
|
|
"sprint",
|
|
|
|
|
"sprintReg",
|
|
|
|
|
"gXp",
|
|
|
|
|
"gSpd",
|
|
|
|
|
];
|
2021-01-18 20:23:37 +00:00
|
|
|
|
let active_elem;
|
|
|
|
|
let elemental_format = false;
|
|
|
|
|
let style;
|
2022-06-19 20:44:02 +00:00
|
|
|
|
for (const command of sq2_ing_display_order) {
|
|
|
|
|
if (command.charAt(0) === "!") {
|
|
|
|
|
// TODO: This is sooo incredibly janky.....
|
|
|
|
|
if (command === "!elemental") {
|
|
|
|
|
elemental_format = !elemental_format;
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
else if (command === "!spacer") {
|
|
|
|
|
let spacer = document.createElement('div');
|
|
|
|
|
spacer.classList.add("row", "my-2");
|
|
|
|
|
parent_elem.appendChild(spacer);
|
|
|
|
|
continue;
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
} else {
|
|
|
|
|
let div = document.createElement("div");
|
|
|
|
|
div.classList.add("row");
|
2021-03-04 13:48:10 +00:00
|
|
|
|
if (command === "displayName") {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.classList.add("box-title");
|
|
|
|
|
let title_elem = document.createElement("div");
|
|
|
|
|
title_elem.classList.add("col-auto", "justify-content-center", "pr-1");
|
2021-03-04 13:48:10 +00:00
|
|
|
|
title_elem.textContent = ingred.get("displayName");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(title_elem);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
|
|
|
|
|
let tier = ingred.get("tier"); //tier in [0,3]
|
|
|
|
|
let begin = document.createElement("b");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
begin.classList.add("T"+tier+"-bracket", "col-auto", "px-0");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
begin.textContent = "[";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(begin);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
|
|
|
|
|
for (let i = 0; i < 3; i++) {
|
|
|
|
|
let tier_elem = document.createElement("b");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
if (i < tier) {
|
|
|
|
|
tier_elem.classList.add("T"+tier);
|
|
|
|
|
} else {
|
|
|
|
|
tier_elem.classList.add("T0");
|
|
|
|
|
}
|
|
|
|
|
tier_elem.classList.add("px-0", "col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
tier_elem.textContent = "\u272B";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(tier_elem);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
let end = document.createElement("b");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
end.classList.add("T"+tier+"-bracket", "px-0", "col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
end.textContent = "]";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(end);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}else if (command === "lvl") {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.textContent = "Crafting Lvl Min: " + ingred.get("lvl");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}else if (command === "posMods") {
|
|
|
|
|
for (const [key,value] of ingred.get("posMods")) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let posModRow = document.createElement("div");
|
|
|
|
|
posModRow.classList.add("row");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
if (value != 0) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let posMod = document.createElement("div");
|
|
|
|
|
posMod.classList.add("col-auto");
|
|
|
|
|
posMod.textContent = posModPrefixes[key];
|
|
|
|
|
posModRow.appendChild(posMod);
|
|
|
|
|
|
|
|
|
|
let val = document.createElement("div");
|
|
|
|
|
val.classList.add("col-auto", "px-0");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
val.textContent = value + posModSuffixes[key];
|
|
|
|
|
if(value > 0) {
|
|
|
|
|
val.classList.add("positive");
|
|
|
|
|
} else {
|
|
|
|
|
val.classList.add("negative");
|
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
posModRow.appendChild(val);
|
|
|
|
|
div.appendChild(posModRow);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else if (command === "itemIDs") { //dura, reqs
|
|
|
|
|
for (const [key,value] of ingred.get("itemIDs")) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let idRow = document.createElement("div");
|
|
|
|
|
idRow.classList.add("row");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
if (value != 0) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let title = document.createElement("div");
|
|
|
|
|
title.classList.add("col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
title.textContent = itemIDPrefixes[key];
|
2022-06-19 20:44:02 +00:00
|
|
|
|
idRow.appendChild(title);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let desc = document.createElement("div");
|
|
|
|
|
desc.classList.add("col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
if(value > 0) {
|
|
|
|
|
if(key !== "dura") {
|
|
|
|
|
desc.classList.add("negative");
|
|
|
|
|
} else{
|
|
|
|
|
desc.classList.add("positive");
|
|
|
|
|
}
|
|
|
|
|
desc.textContent = "+"+value;
|
|
|
|
|
} else if (value < 0){
|
|
|
|
|
if(key !== "dura") {
|
|
|
|
|
desc.classList.add("positive");
|
|
|
|
|
} else{
|
|
|
|
|
desc.classList.add("negative");
|
|
|
|
|
}
|
|
|
|
|
desc.textContent = value;
|
|
|
|
|
}
|
|
|
|
|
if(value != 0){
|
2022-06-19 20:44:02 +00:00
|
|
|
|
idRow.appendChild(desc);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(idRow);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
} else if (command === "consumableIDs") { //dura, charges
|
|
|
|
|
for (const [key,value] of ingred.get("consumableIDs")) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let idRow = document.createElement("div");
|
|
|
|
|
idRow.classList.add("row");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
if (value != 0) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let title = document.createElement("div");
|
|
|
|
|
title.classList.add("col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
title.textContent = consumableIDPrefixes[key];
|
2022-06-19 20:44:02 +00:00
|
|
|
|
idRow.appendChild(title);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let desc = document.createElement("div");
|
|
|
|
|
desc.classList.add("col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
if(value > 0) {
|
|
|
|
|
desc.classList.add("positive");
|
|
|
|
|
desc.textContent = "+"+value;
|
|
|
|
|
} else if (value < 0){
|
|
|
|
|
desc.classList.add("negative");
|
|
|
|
|
desc.textContent = value;
|
|
|
|
|
}
|
|
|
|
|
if(value != 0){
|
2022-06-19 20:44:02 +00:00
|
|
|
|
idRow.appendChild(desc);
|
|
|
|
|
let suffix = document.createElement("div");
|
|
|
|
|
suffix.classList.add("col-auto");
|
2021-01-18 20:23:37 +00:00
|
|
|
|
suffix.textContent = consumableIDSuffixes[key];
|
2022-06-19 20:44:02 +00:00
|
|
|
|
idRow.appendChild(suffix);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(idRow);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
}else if (command === "skills") {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let row = document.createElement("div");
|
|
|
|
|
row.classList.add("row");
|
|
|
|
|
let title = document.createElement("div");
|
|
|
|
|
title.classList.add("row");
|
|
|
|
|
title.textContent = "Used in:";
|
|
|
|
|
row.appendChild(title);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
for(const skill of ingred.get("skills")) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let skill_div = document.createElement("div");
|
2022-07-12 05:10:55 +00:00
|
|
|
|
skill_div.classList.add("row", "ps-4");
|
2022-06-19 20:44:02 +00:00
|
|
|
|
skill_div.textContent = skill.charAt(0) + skill.substring(1).toLowerCase();
|
|
|
|
|
row.appendChild(skill_div);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
2022-06-19 20:44:02 +00:00
|
|
|
|
div.appendChild(row);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
} else if (command === "ids") { //warp
|
2021-02-25 06:03:44 +00:00
|
|
|
|
for (let [key,value] of ingred.get("ids").get("maxRolls")) {
|
|
|
|
|
if (value !== undefined && value != 0) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let row = displayRolledID(ingred.get("ids"), key, elemental_format);
|
|
|
|
|
row.classList.remove("col");
|
|
|
|
|
row.classList.remove("col-12");
|
|
|
|
|
div.appendChild(row);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {//this shouldn't be happening
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
parent_elem.appendChild(div);
|
2021-01-18 20:23:37 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
|
}
|
2021-01-09 08:52:58 +00:00
|
|
|
|
|
2022-06-20 14:37:14 +00:00
|
|
|
|
function displayNextCosts(_stats, spell, spellIdx) {
|
|
|
|
|
let stats = new Map(_stats);
|
|
|
|
|
let intel = stats.get('int');
|
2022-06-19 18:02:28 +00:00
|
|
|
|
|
|
|
|
|
let row = document.createElement("div");
|
|
|
|
|
row.classList.add("spellcost-tooltip");
|
|
|
|
|
let init_cost = document.createElement("b");
|
2022-06-20 14:37:14 +00:00
|
|
|
|
init_cost.textContent = getSpellCost(stats, spellIdx, spell.cost);
|
2022-06-19 18:02:28 +00:00
|
|
|
|
init_cost.classList.add("Mana");
|
|
|
|
|
let arrow = document.createElement("b");
|
|
|
|
|
arrow.textContent = "\u279C";
|
|
|
|
|
let next_cost = document.createElement("b");
|
2022-06-20 14:37:14 +00:00
|
|
|
|
next_cost.textContent = (init_cost.textContent === "1" ? 1 : getSpellCost(stats, spellIdx, spell.cost) - 1);
|
2022-06-19 18:02:28 +00:00
|
|
|
|
next_cost.classList.add("Mana");
|
|
|
|
|
let int_needed = document.createElement("b");
|
|
|
|
|
if (init_cost.textContent === "1") {
|
|
|
|
|
int_needed.textContent = ": n/a (+0)";
|
2022-07-22 17:27:59 +00:00
|
|
|
|
} else { //do math
|
2022-06-20 14:37:14 +00:00
|
|
|
|
let target = getSpellCost(stats, spellIdx, spell.cost) - 1;
|
|
|
|
|
let needed = intel;
|
2022-06-19 18:02:28 +00:00
|
|
|
|
let noUpdate = false;
|
|
|
|
|
//forgive me... I couldn't inverse ceil, floor, and max.
|
2022-06-20 14:37:14 +00:00
|
|
|
|
while (getSpellCost(stats, spellIdx, spell.cost) > target) {
|
2022-06-19 18:02:28 +00:00
|
|
|
|
if(needed > 150) {
|
|
|
|
|
noUpdate = true;
|
|
|
|
|
break;
|
2021-01-15 20:36:12 +00:00
|
|
|
|
}
|
2022-06-19 18:02:28 +00:00
|
|
|
|
needed++;
|
2022-06-20 14:37:14 +00:00
|
|
|
|
stats.set('int', stats.get('int') + 1);
|
2022-06-19 18:02:28 +00:00
|
|
|
|
}
|
2022-06-20 14:37:14 +00:00
|
|
|
|
let missing = needed - intel;
|
2022-06-19 18:02:28 +00:00
|
|
|
|
//in rare circumstances, the next spell cost can jump.
|
|
|
|
|
if (noUpdate) {
|
2022-06-20 14:37:14 +00:00
|
|
|
|
next_cost.textContent = (init_cost.textContent === "1" ? 1 : getSpellCost(stats, spellIdx, spell.cost)-1);
|
2022-06-19 18:02:28 +00:00
|
|
|
|
}else {
|
2022-06-20 14:37:14 +00:00
|
|
|
|
next_cost.textContent = (init_cost.textContent === "1" ? 1 : getSpellCost(stats, spellIdx, spell.cost));
|
2021-01-15 18:49:24 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 18:02:28 +00:00
|
|
|
|
|
|
|
|
|
int_needed.textContent = ": " + (needed > 150 ? ">150" : needed) + " int (+" + (needed > 150 ? "n/a" : missing) + ")";
|
2021-01-15 18:20:17 +00:00
|
|
|
|
}
|
2022-06-19 18:02:28 +00:00
|
|
|
|
|
|
|
|
|
// row.appendChild(init_cost);
|
|
|
|
|
row.appendChild(arrow);
|
|
|
|
|
row.appendChild(next_cost);
|
|
|
|
|
row.appendChild(int_needed);
|
|
|
|
|
return row;
|
2021-01-15 18:20:17 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-09-25 18:57:57 +00:00
|
|
|
|
function displayRolledID(item, id, elemental_format) {
|
2022-06-20 17:51:17 +00:00
|
|
|
|
let row = document.createElement('div');
|
|
|
|
|
row.classList.add('col');
|
|
|
|
|
|
|
|
|
|
let item_div = document.createElement('div');
|
|
|
|
|
item_div.classList.add('row');
|
|
|
|
|
|
|
|
|
|
let min_elem = document.createElement('div');
|
|
|
|
|
min_elem.classList.add('col', 'text-start');
|
|
|
|
|
min_elem.style.cssText += "flex-grow: 0";
|
2021-09-25 18:57:57 +00:00
|
|
|
|
let id_min = item.get("minRolls").get(id)
|
|
|
|
|
let style = id_min < 0 ? "negative" : "positive";
|
|
|
|
|
if(reversedIDs.includes(id)){
|
|
|
|
|
style === "positive" ? style = "negative" : style = "positive";
|
|
|
|
|
}
|
|
|
|
|
min_elem.classList.add(style);
|
|
|
|
|
min_elem.textContent = id_min + idSuffixes[id];
|
2022-06-20 17:51:17 +00:00
|
|
|
|
item_div.appendChild(min_elem);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
|
2022-06-20 17:51:17 +00:00
|
|
|
|
let desc_elem = document.createElement('div');
|
|
|
|
|
desc_elem.classList.add('col', 'text-center');//, 'text-nowrap');
|
|
|
|
|
desc_elem.style.cssText += "flex-grow: 1";
|
2021-09-25 18:57:57 +00:00
|
|
|
|
//TODO elemental format jank
|
|
|
|
|
if (elemental_format) {
|
|
|
|
|
apply_elemental_format(desc_elem, id);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
desc_elem.textContent = idPrefixes[id];
|
|
|
|
|
}
|
2022-06-20 17:51:17 +00:00
|
|
|
|
item_div.appendChild(desc_elem);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
|
2022-06-20 17:51:17 +00:00
|
|
|
|
let max_elem = document.createElement('div');
|
2021-09-25 18:57:57 +00:00
|
|
|
|
let id_max = item.get("maxRolls").get(id)
|
2022-06-20 17:51:17 +00:00
|
|
|
|
max_elem.classList.add('col', 'text-end');
|
|
|
|
|
max_elem.style.cssText += "flex-grow: 0";
|
2021-09-25 18:57:57 +00:00
|
|
|
|
style = id_max < 0 ? "negative" : "positive";
|
2022-06-20 17:51:17 +00:00
|
|
|
|
if (reversedIDs.includes(id)) {
|
2021-09-25 18:57:57 +00:00
|
|
|
|
style === "positive" ? style = "negative" : style = "positive";
|
|
|
|
|
}
|
|
|
|
|
max_elem.classList.add(style);
|
|
|
|
|
max_elem.textContent = id_max + idSuffixes[id];
|
2022-06-20 17:51:17 +00:00
|
|
|
|
item_div.appendChild(max_elem);
|
|
|
|
|
row.appendChild(item_div);
|
2021-09-25 18:57:57 +00:00
|
|
|
|
return row;
|
|
|
|
|
}
|
2021-01-18 01:26:39 +00:00
|
|
|
|
|
2021-01-09 12:47:25 +00:00
|
|
|
|
function displayFixedID(active, id, value, elemental_format, style) {
|
|
|
|
|
if (style) {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let row = document.createElement('div');
|
|
|
|
|
row.classList.add("row");
|
|
|
|
|
let desc_elem = document.createElement('div');
|
|
|
|
|
desc_elem.classList.add('col');
|
|
|
|
|
desc_elem.classList.add('text-start');
|
|
|
|
|
|
2021-01-09 12:47:25 +00:00
|
|
|
|
if (elemental_format) {
|
|
|
|
|
apply_elemental_format(desc_elem, id);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
desc_elem.textContent = idPrefixes[id];
|
|
|
|
|
}
|
|
|
|
|
row.appendChild(desc_elem);
|
2021-01-09 11:56:10 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let value_elem = document.createElement('div');
|
|
|
|
|
value_elem.classList.add('col');
|
|
|
|
|
value_elem.classList.add('text-end');
|
2021-01-09 12:47:25 +00:00
|
|
|
|
value_elem.classList.add(style);
|
|
|
|
|
value_elem.textContent = value + idSuffixes[id];
|
|
|
|
|
row.appendChild(value_elem);
|
|
|
|
|
active.appendChild(row);
|
|
|
|
|
return row;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
// HACK TO AVOID DISPLAYING ZERO DAMAGE! TODO
|
2021-01-28 00:52:34 +00:00
|
|
|
|
if (value === "0-0" || value === "0-0\u279c0-0") {
|
2021-01-09 12:47:25 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let p_elem = document.createElement('div');
|
|
|
|
|
p_elem.classList.add('col');
|
2021-01-09 12:47:25 +00:00
|
|
|
|
if (elemental_format) {
|
|
|
|
|
apply_elemental_format(p_elem, id, value);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
p_elem.textContent = idPrefixes[id].concat(value, idSuffixes[id]);
|
|
|
|
|
}
|
|
|
|
|
active.appendChild(p_elem);
|
|
|
|
|
return p_elem;
|
|
|
|
|
}
|
2021-01-09 11:56:10 +00:00
|
|
|
|
}
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-08-15 02:55:31 +00:00
|
|
|
|
function displayPoisonDamage(overallparent_elem, statMap) {
|
2022-06-19 18:30:10 +00:00
|
|
|
|
overallparent_elem.textContent = "";
|
2022-08-15 02:55:31 +00:00
|
|
|
|
if (statMap.get('poison') <= 0) {
|
2022-07-19 08:09:21 +00:00
|
|
|
|
overallparent_elem.style = "display: none";
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
overallparent_elem.style = "";
|
|
|
|
|
|
|
|
|
|
let container = make_elem('div', ['col', 'pe-0']);
|
|
|
|
|
let spell_summary = make_elem('div', ["col", "spell-display", "dark-5", "rounded", "dark-shadow", "py-2", "border", "border-dark"]);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
//Title
|
2022-07-19 08:09:21 +00:00
|
|
|
|
let title_elemavg = make_elem("b");
|
|
|
|
|
title_elemavg.append(make_elem('span', [], { textContent: "Poison Stats" }));
|
|
|
|
|
spell_summary.append(title_elemavg);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-09-04 19:17:01 +00:00
|
|
|
|
let poison_tick = Math.floor(statMap.get("poison")/3);
|
|
|
|
|
//let poison_tick = Math.ceil(statMap.get("poison") * (1+skillPointsToPercentage(statMap.get('str'))) * (statMap.get("poisonPct"))/100 /3);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
2022-07-19 08:09:21 +00:00
|
|
|
|
let overallpoisonDamage = make_elem("p");
|
|
|
|
|
overallpoisonDamage.append(
|
|
|
|
|
make_elem("span", [], { textContent: "Poison Tick: " }),
|
|
|
|
|
make_elem("span", ["Damage"], { textContent: Math.max(poison_tick,0) })
|
|
|
|
|
);
|
|
|
|
|
spell_summary.append(overallpoisonDamage);
|
|
|
|
|
container.append(spell_summary);
|
|
|
|
|
overallparent_elem.append(container);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-19 20:44:02 +00:00
|
|
|
|
function displayEquipOrder(parent_elem, buildOrder){
|
2021-01-10 21:01:59 +00:00
|
|
|
|
parent_elem.textContent = "";
|
|
|
|
|
const order = buildOrder.slice();
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let title_elem = document.createElement("b");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
title_elem.textContent = "Equip order ";
|
2022-06-19 20:44:02 +00:00
|
|
|
|
title_elem.classList.add("Normal", "text-center");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
parent_elem.append(title_elem);
|
|
|
|
|
for (const item of order) {
|
2022-06-19 20:44:02 +00:00
|
|
|
|
let p_elem = document.createElement("b");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
p_elem.textContent = item.get("displayName");
|
|
|
|
|
parent_elem.append(p_elem);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-10 22:38:17 +00:00
|
|
|
|
|
2022-06-20 13:12:22 +00:00
|
|
|
|
function displayDefenseStats(parent_elem, statMap, insertSummary){
|
|
|
|
|
let defenseStats = getDefenseStats(statMap);
|
2021-01-11 22:25:55 +00:00
|
|
|
|
insertSummary = (typeof insertSummary !== 'undefined') ? insertSummary : false;
|
|
|
|
|
if (!insertSummary) {
|
|
|
|
|
parent_elem.textContent = "";
|
|
|
|
|
}
|
2021-01-10 21:01:59 +00:00
|
|
|
|
const stats = defenseStats.slice();
|
2021-01-11 22:25:55 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
// parent_elem.append(document.createElement("br"));
|
|
|
|
|
let statsTable = document.createElement("div");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
|
|
|
|
|
//[total hp, ehp, total hpr, ehpr, [def%, agi%], [edef,tdef,wdef,fdef,adef]]
|
|
|
|
|
for(const i in stats){
|
|
|
|
|
if(typeof stats[i] === "number"){
|
|
|
|
|
stats[i] = stats[i].toFixed(2);
|
|
|
|
|
}else{
|
|
|
|
|
for(const j in stats[i]){
|
|
|
|
|
stats[i][j] = stats[i][j].toFixed(2);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-11 22:25:55 +00:00
|
|
|
|
|
2021-01-10 21:01:59 +00:00
|
|
|
|
//total HP
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let hpRow = document.createElement("div");
|
|
|
|
|
hpRow.classList.add('row');
|
|
|
|
|
let hp = document.createElement("div");
|
|
|
|
|
hp.classList.add('col');
|
2021-01-10 21:31:29 +00:00
|
|
|
|
hp.classList.add("Health");
|
2022-06-19 18:30:10 +00:00
|
|
|
|
hp.classList.add("text-start");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
hp.textContent = "Total HP:";
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let boost = document.createElement("div");
|
|
|
|
|
boost.classList.add('col');
|
2021-01-10 21:31:29 +00:00
|
|
|
|
boost.textContent = stats[0];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("text-end");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
|
|
|
|
hpRow.appendChild(hp);
|
|
|
|
|
hpRow.append(boost);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(hpRow);
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.appendChild(hpRow);
|
|
|
|
|
}
|
2021-01-11 22:25:55 +00:00
|
|
|
|
|
2021-01-10 21:01:59 +00:00
|
|
|
|
//EHP
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let ehpRow = document.createElement("div");
|
|
|
|
|
ehpRow.classList.add("row");
|
|
|
|
|
let ehp = document.createElement("div");
|
|
|
|
|
ehp.classList.add("col");
|
|
|
|
|
ehp.classList.add("text-start");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
ehp.textContent = "Effective HP:";
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
boost.textContent = stats[1][0];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
ehpRow.appendChild(ehp);
|
|
|
|
|
ehpRow.append(boost);
|
2021-01-11 00:46:30 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(ehpRow)
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.append(ehpRow);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ehpRow = document.createElement("div");
|
|
|
|
|
ehpRow.classList.add("row");
|
|
|
|
|
ehp = document.createElement("div");
|
|
|
|
|
ehp.classList.add("col");
|
|
|
|
|
ehp.classList.add("text-start");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
ehp.textContent = "Effective HP (no agi):";
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
boost.textContent = stats[1][1];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
ehpRow.appendChild(ehp);
|
|
|
|
|
ehpRow.append(boost);
|
2022-06-19 20:59:16 +00:00
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(ehpRow)
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.append(ehpRow);
|
|
|
|
|
}
|
2021-01-11 00:46:30 +00:00
|
|
|
|
|
2021-01-10 21:01:59 +00:00
|
|
|
|
//total HPR
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let hprRow = document.createElement("div");
|
|
|
|
|
hprRow.classList.add("row")
|
|
|
|
|
let hpr = document.createElement("div");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
hpr.classList.add("Health");
|
2022-06-19 18:30:10 +00:00
|
|
|
|
hpr.classList.add("col");
|
|
|
|
|
hpr.classList.add("text-start");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
hpr.textContent = "HP Regen (Total):";
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
2021-01-10 22:38:17 +00:00
|
|
|
|
boost.textContent = stats[2];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-10 22:38:17 +00:00
|
|
|
|
|
2021-01-10 21:31:29 +00:00
|
|
|
|
hprRow.appendChild(hpr);
|
|
|
|
|
hprRow.appendChild(boost);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(hprRow);
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.appendChild(hprRow);
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-19 10:12:36 +00:00
|
|
|
|
//EHPR
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let ehprRow = document.createElement("div");
|
|
|
|
|
ehprRow.classList.add("row")
|
|
|
|
|
let ehpr = document.createElement("div");
|
|
|
|
|
ehpr.classList.add("col");
|
|
|
|
|
ehpr.classList.add("text-start");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
ehpr.textContent = "Effective HP Regen:";
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
boost.textContent = stats[3][0];
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-11 00:46:30 +00:00
|
|
|
|
ehprRow.appendChild(ehpr);
|
|
|
|
|
ehprRow.append(boost);
|
2022-06-19 20:59:16 +00:00
|
|
|
|
|
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(ehprRow);
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.appendChild(ehprRow);
|
|
|
|
|
}
|
2021-01-11 22:25:55 +00:00
|
|
|
|
|
2021-01-10 21:01:59 +00:00
|
|
|
|
//eledefs
|
|
|
|
|
let eledefs = stats[5];
|
|
|
|
|
for (let i = 0; i < eledefs.length; i++){
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let eledefElemRow = document.createElement("div");
|
|
|
|
|
eledefElemRow.classList.add("row")
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let eledef = document.createElement("div");
|
|
|
|
|
eledef.classList.add("col");
|
|
|
|
|
eledef.classList.add("text-start");
|
|
|
|
|
let eledefTitle = document.createElement("span");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
eledefTitle.textContent = damageClasses[i+1];
|
|
|
|
|
eledefTitle.classList.add(damageClasses[i+1]);
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let defense = document.createElement("span");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
defense.textContent = " Def (Total): ";
|
2021-01-11 01:42:09 +00:00
|
|
|
|
|
|
|
|
|
eledef.appendChild(eledefTitle);
|
|
|
|
|
eledef.appendChild(defense);
|
|
|
|
|
eledefElemRow.appendChild(eledef);
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let boost = document.createElement("div");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
boost.textContent = eledefs[i];
|
2021-03-10 18:58:24 +00:00
|
|
|
|
boost.classList.add(eledefs[i] >= 0 ? "positive" : "negative");
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-03-27 18:17:58 +00:00
|
|
|
|
|
2022-06-22 05:39:10 +00:00
|
|
|
|
let defRaw = statMap.get(skp_elements[i]+"Def");
|
|
|
|
|
let defPct = statMap.get(skp_elements[i]+"DefPct")/100;
|
2021-03-27 18:17:58 +00:00
|
|
|
|
if (defRaw < 0) {
|
|
|
|
|
defPct >= 0 ? defPct = "- " + defPct: defPct = "+ " + defPct;
|
|
|
|
|
} else {
|
|
|
|
|
defPct >= 0 ? defPct = "+ " + defPct: defPct = "- " + defPct;
|
|
|
|
|
}
|
2021-01-11 01:42:09 +00:00
|
|
|
|
eledefElemRow.appendChild(boost);
|
2022-06-19 18:30:10 +00:00
|
|
|
|
|
|
|
|
|
if (insertSummary) {
|
|
|
|
|
parent_elem.appendChild(eledefElemRow);
|
|
|
|
|
} else {
|
|
|
|
|
statsTable.appendChild(eledefElemRow);
|
|
|
|
|
}
|
2021-01-10 21:01:59 +00:00
|
|
|
|
}
|
2021-01-11 22:25:55 +00:00
|
|
|
|
|
|
|
|
|
if (!insertSummary) {
|
|
|
|
|
//skp
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let defRow = document.createElement("div");
|
|
|
|
|
defRow.classList.add("row");
|
|
|
|
|
let defElem = document.createElement("div");
|
|
|
|
|
defElem.classList.add("col");
|
|
|
|
|
defElem.classList.add("text-start");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
defElem.textContent = "Damage Absorbed %:";
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
boost.textContent = stats[4][0] + "%";
|
|
|
|
|
defRow.appendChild(defElem);
|
|
|
|
|
defRow.appendChild(boost);
|
|
|
|
|
statsTable.append(defRow);
|
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
let agiRow = document.createElement("div");
|
|
|
|
|
agiRow.classList.add("row");
|
|
|
|
|
let agiElem = document.createElement("div");
|
|
|
|
|
agiElem.classList.add("col");
|
|
|
|
|
agiElem.classList.add("text-start");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
agiElem.textContent = "Dodge Chance %:";
|
2022-06-19 18:30:10 +00:00
|
|
|
|
boost = document.createElement("div");
|
|
|
|
|
boost.classList.add("col");
|
|
|
|
|
boost.classList.add("text-end");
|
2021-01-11 22:25:55 +00:00
|
|
|
|
boost.textContent = stats[4][1] + "%";
|
|
|
|
|
agiRow.appendChild(agiElem);
|
|
|
|
|
agiRow.appendChild(boost);
|
|
|
|
|
statsTable.append(agiRow);
|
|
|
|
|
}
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-06-19 18:30:10 +00:00
|
|
|
|
if (!insertSummary) {
|
|
|
|
|
parent_elem.append(statsTable);
|
|
|
|
|
}
|
2021-01-09 23:30:05 +00:00
|
|
|
|
}
|
2021-03-27 18:17:58 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
function displayPowderSpecials(parent_elem, powderSpecials, stats, weapon) {
|
2022-07-19 08:09:21 +00:00
|
|
|
|
parent_elem.textContent = "";
|
|
|
|
|
if (powderSpecials.length === 0) {
|
|
|
|
|
parent_elem.style = "display: none";
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
parent_elem.style = "";
|
|
|
|
|
|
2022-06-20 17:51:17 +00:00
|
|
|
|
const skillpoints = [
|
|
|
|
|
stats.get('str'),
|
|
|
|
|
stats.get('dex'),
|
|
|
|
|
stats.get('int'),
|
|
|
|
|
stats.get('def'),
|
|
|
|
|
stats.get('agi')
|
|
|
|
|
];
|
2022-07-19 08:09:21 +00:00
|
|
|
|
parent_elem.append(make_elem("b", [], { textContent: "Powder Specials" }));
|
2021-01-12 21:07:03 +00:00
|
|
|
|
let specials = powderSpecials.slice();
|
2021-01-14 03:17:01 +00:00
|
|
|
|
let expandedStats = new Map();
|
2021-01-12 21:07:03 +00:00
|
|
|
|
//each entry of powderSpecials is [ps, power]
|
|
|
|
|
for (special of specials) {
|
2021-01-13 06:57:07 +00:00
|
|
|
|
//iterate through the special and display its effects.
|
2023-04-04 23:30:20 +00:00
|
|
|
|
let powder_special_elem = make_elem("p", ["pt-3"]);
|
2021-01-12 21:07:03 +00:00
|
|
|
|
let specialSuffixes = new Map([ ["Duration", " sec"], ["Radius", " blocks"], ["Chains", ""], ["Damage", "%"], ["Damage Boost", "%"], ["Knockback", " blocks"] ]);
|
2022-08-02 04:11:53 +00:00
|
|
|
|
let specialTitle = make_elem("p");
|
|
|
|
|
let specialEffects = make_elem("p");
|
2023-04-04 23:30:20 +00:00
|
|
|
|
// TODO janky and depends on the order of powder specials being ETWFA. This should be encoded in the powder special object.
|
|
|
|
|
let element_num = powderSpecialStats.indexOf(special[0]) + 1;
|
|
|
|
|
specialTitle.classList.add(damageClasses[element_num]);
|
|
|
|
|
let powder_special = special[0];
|
2021-01-12 22:49:02 +00:00
|
|
|
|
let power = special[1];
|
2023-04-04 23:30:20 +00:00
|
|
|
|
specialTitle.textContent = powder_special.weaponSpecialName + " " + Math.floor((power-1)*0.5 + 4) + (power % 2 == 0 ? ".5" : "");
|
|
|
|
|
|
|
|
|
|
for (const [key,value] of powder_special.weaponSpecialEffects) {
|
|
|
|
|
if(key === "Damage"){
|
|
|
|
|
//if this special is an instant-damage special (Quake, Chain Lightning, Courage Burst), display the damage.
|
|
|
|
|
let specialDamage = document.createElement("p");
|
|
|
|
|
// specialDamage.classList.add("item-margin");
|
|
|
|
|
let conversions = [0, 0, 0, 0, 0, 0];
|
|
|
|
|
conversions[element_num] = powder_special.weaponSpecialEffects.get("Damage")[power-1];
|
|
|
|
|
let _results = calculateSpellDamage(stats, weapon, conversions, false, true, "0.Powder Special");
|
|
|
|
|
|
|
|
|
|
let critChance = skillPointsToPercentage(skillpoints[1]);
|
|
|
|
|
let save_damages = [];
|
2022-06-20 17:51:17 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
let totalDamNormal = _results[0];
|
|
|
|
|
let totalDamCrit = _results[1];
|
|
|
|
|
let results = _results[2];
|
|
|
|
|
for (let i = 0; i < 6; ++i) {
|
|
|
|
|
for (let j in results[i]) {
|
|
|
|
|
results[i][j] = results[i][j].toFixed(2);
|
2022-06-20 17:51:17 +00:00
|
|
|
|
}
|
2021-01-13 08:30:55 +00:00
|
|
|
|
}
|
2023-04-04 23:30:20 +00:00
|
|
|
|
let nonCritAverage = (totalDamNormal[0]+totalDamNormal[1])/2 || 0;
|
|
|
|
|
let critAverage = (totalDamCrit[0]+totalDamCrit[1])/2 || 0;
|
|
|
|
|
let averageDamage = (1-critChance)*nonCritAverage+critChance*critAverage || 0;
|
2021-01-12 21:07:03 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
let averageWrap = document.createElement("p");
|
|
|
|
|
let averageLabel = document.createElement("span");
|
|
|
|
|
averageLabel.textContent = "Average: ";
|
|
|
|
|
|
|
|
|
|
let averageLabelDmg = document.createElement("span");
|
|
|
|
|
averageLabelDmg.classList.add("Damage");
|
|
|
|
|
averageLabelDmg.textContent = averageDamage.toFixed(2);
|
2021-01-13 08:30:55 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
averageWrap.appendChild(averageLabel);
|
|
|
|
|
averageWrap.appendChild(averageLabelDmg);
|
|
|
|
|
specialDamage.appendChild(averageWrap);
|
|
|
|
|
|
|
|
|
|
specialEffects.append(specialDamage);
|
2022-06-20 17:51:17 +00:00
|
|
|
|
}
|
2023-04-04 23:30:20 +00:00
|
|
|
|
else {
|
|
|
|
|
let effect = document.createElement("p");
|
|
|
|
|
effect.textContent += key + ": " + value[power-1] + specialSuffixes.get(key);
|
|
|
|
|
specialEffects.appendChild(effect);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-01-13 08:30:55 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
powder_special_elem.appendChild(specialTitle);
|
|
|
|
|
powder_special_elem.appendChild(specialEffects);
|
2021-01-12 21:07:03 +00:00
|
|
|
|
|
2023-04-04 23:30:20 +00:00
|
|
|
|
parent_elem.appendChild(powder_special_elem);
|
2021-01-13 06:57:07 +00:00
|
|
|
|
}
|
2021-01-12 21:07:03 +00:00
|
|
|
|
}
|
2021-03-27 18:17:58 +00:00
|
|
|
|
|
2022-06-29 06:23:27 +00:00
|
|
|
|
function getSpellCost(stats, spell) {
|
2022-08-13 04:39:24 +00:00
|
|
|
|
return Math.max(1, getBaseSpellCost(stats, spell) * (1 + stats.get('spPct'+spell.base_spell+'Final')/100));
|
2022-06-20 14:37:14 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-29 06:23:27 +00:00
|
|
|
|
function getBaseSpellCost(stats, spell) {
|
2022-07-22 17:27:59 +00:00
|
|
|
|
let cost = spell.cost * (1 - skillPointsToPercentage(stats.get('int')) * skillpoint_final_mult[2]);
|
2022-06-29 06:23:27 +00:00
|
|
|
|
cost += stats.get("spRaw"+spell.base_spell);
|
2022-07-22 17:27:59 +00:00
|
|
|
|
return cost * (1 + stats.get("spPct"+spell.base_spell) / 100);
|
2022-06-20 14:37:14 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2022-07-23 12:19:32 +00:00
|
|
|
|
function displaySpellDamage(parent_elem, _overallparent_elem, stats, spell, spellIdx, spell_results) {
|
2022-06-19 18:02:28 +00:00
|
|
|
|
// TODO: remove spellIdx (just used to flag melee and cost)
|
|
|
|
|
// TODO: move cost calc out
|
2021-01-09 08:52:58 +00:00
|
|
|
|
parent_elem.textContent = "";
|
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let title_elem = make_elem("p");
|
2021-01-10 21:01:59 +00:00
|
|
|
|
|
2022-07-23 12:19:32 +00:00
|
|
|
|
_overallparent_elem.textContent = "";
|
|
|
|
|
const overallparent_elem = make_elem("div", ['col'])
|
2022-06-19 18:02:28 +00:00
|
|
|
|
let title_elemavg = document.createElement("b");
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-06-27 06:42:00 +00:00
|
|
|
|
if ('cost' in spell) {
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let first = make_elem("span", [], { textContent: spell.name + " (" });
|
2021-01-16 07:30:19 +00:00
|
|
|
|
title_elem.appendChild(first.cloneNode(true)); //cloneNode is needed here.
|
2021-01-15 08:23:55 +00:00
|
|
|
|
title_elemavg.appendChild(first);
|
2021-03-27 18:17:58 +00:00
|
|
|
|
|
2022-07-22 17:27:59 +00:00
|
|
|
|
let second = make_elem("span", ["Mana"], { textContent: getSpellCost(stats, spell).toFixed(2) });
|
2021-01-16 07:30:19 +00:00
|
|
|
|
title_elem.appendChild(second.cloneNode(true));
|
2021-01-15 08:23:55 +00:00
|
|
|
|
title_elemavg.appendChild(second);
|
2021-03-27 18:17:58 +00:00
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let third = make_elem("span", [], { textContent: ")" });// " + getBaseSpellCost(stats, spellIdx, spell.cost) + " ]";
|
|
|
|
|
title_elem.appendChild(third.cloneNode(true));
|
|
|
|
|
title_elemavg.appendChild(third);
|
2021-01-09 08:52:58 +00:00
|
|
|
|
}
|
|
|
|
|
else {
|
2022-06-27 06:42:00 +00:00
|
|
|
|
title_elem.textContent = spell.name;
|
|
|
|
|
title_elemavg.textContent = spell.name;
|
2021-01-09 08:52:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
parent_elem.append(title_elem);
|
2021-01-10 21:01:59 +00:00
|
|
|
|
overallparent_elem.append(title_elemavg);
|
|
|
|
|
|
2022-06-29 06:23:27 +00:00
|
|
|
|
// if ('cost' in spell) {
|
2022-07-22 17:27:59 +00:00
|
|
|
|
// overallparent_elem.append(displayNextCosts(stats, spell, spellIdx));
|
2022-06-29 06:23:27 +00:00
|
|
|
|
// }
|
2022-06-19 18:02:28 +00:00
|
|
|
|
|
2022-06-20 14:37:14 +00:00
|
|
|
|
let critChance = skillPointsToPercentage(stats.get('dex'));
|
2021-01-09 08:52:58 +00:00
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let part_divavg = make_elem("p");
|
2021-01-19 01:57:26 +00:00
|
|
|
|
overallparent_elem.append(part_divavg);
|
|
|
|
|
|
2022-07-20 07:35:20 +00:00
|
|
|
|
function add_summary(text, val, fmt) {
|
2022-07-19 07:33:05 +00:00
|
|
|
|
if (typeof(val) === 'number') { val = val.toFixed(2); }
|
2022-07-20 07:35:20 +00:00
|
|
|
|
let summary_elem = make_elem("p");
|
|
|
|
|
summary_elem.append(
|
|
|
|
|
make_elem("span", [], { textContent: text }),
|
|
|
|
|
make_elem("span", [fmt], { textContent: val })
|
|
|
|
|
);
|
|
|
|
|
part_divavg.append(summary_elem);
|
2022-06-27 06:54:05 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-06-27 06:42:00 +00:00
|
|
|
|
for (let i = 0; i < spell_results.length; ++i) {
|
2022-06-28 05:16:23 +00:00
|
|
|
|
const spell_info = spell_results[i];
|
2022-09-04 19:17:01 +00:00
|
|
|
|
if (!spell_info.display) { continue; }
|
2021-01-30 12:03:40 +00:00
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let part_div = make_elem("p", ["pt-3"]);
|
2021-01-09 08:52:58 +00:00
|
|
|
|
parent_elem.append(part_div);
|
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
part_div.append(make_elem("p", [], { textContent: spell_info.name }));
|
2021-01-10 21:01:59 +00:00
|
|
|
|
|
2022-06-28 05:16:23 +00:00
|
|
|
|
if (spell_info.type === "damage") {
|
|
|
|
|
let totalDamNormal = spell_info.normal_total;
|
|
|
|
|
let totalDamCrit = spell_info.crit_total;
|
2022-06-27 06:42:00 +00:00
|
|
|
|
|
2021-01-13 02:48:00 +00:00
|
|
|
|
let nonCritAverage = (totalDamNormal[0]+totalDamNormal[1])/2 || 0;
|
|
|
|
|
let critAverage = (totalDamCrit[0]+totalDamCrit[1])/2 || 0;
|
|
|
|
|
let averageDamage = (1-critChance)*nonCritAverage+critChance*critAverage || 0;
|
2021-01-09 08:52:58 +00:00
|
|
|
|
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let averageLabel = make_elem("p", [], { textContent: "Average: "+averageDamage.toFixed(2) });
|
2022-06-19 18:02:28 +00:00
|
|
|
|
// averageLabel.classList.add("damageSubtitle");
|
2021-01-09 09:35:18 +00:00
|
|
|
|
part_div.append(averageLabel);
|
2021-01-09 08:52:58 +00:00
|
|
|
|
|
2022-06-28 05:16:23 +00:00
|
|
|
|
if (spell_info.name === spell.display) {
|
2022-07-19 07:33:05 +00:00
|
|
|
|
if (spellIdx === 0) {
|
2022-07-20 18:59:29 +00:00
|
|
|
|
let display_attack_speeds = ["Super Slow", "Very Slow", "Slow", "Normal", "Fast", "Very Fast", "Super Fast"];
|
2022-07-19 07:33:05 +00:00
|
|
|
|
let adjAtkSpd = attackSpeeds.indexOf(stats.get("atkSpd")) + stats.get("atkTier");
|
|
|
|
|
if(adjAtkSpd > 6) {
|
|
|
|
|
adjAtkSpd = 6;
|
|
|
|
|
} else if(adjAtkSpd < 0) {
|
|
|
|
|
adjAtkSpd = 0;
|
|
|
|
|
}
|
2022-07-20 07:35:20 +00:00
|
|
|
|
add_summary("Average DPS: ", averageDamage * baseDamageMultiplier[adjAtkSpd], "Damage");
|
2022-07-20 18:59:29 +00:00
|
|
|
|
add_summary("Attack Speed: ", display_attack_speeds[adjAtkSpd], "Damage");
|
2022-07-20 07:35:20 +00:00
|
|
|
|
add_summary("Per Attack: ", averageDamage, "Damage");
|
2022-07-19 07:33:05 +00:00
|
|
|
|
}
|
|
|
|
|
else {
|
2022-07-20 07:35:20 +00:00
|
|
|
|
add_summary(spell_info.name+ ": ", averageDamage, "Damage");
|
2022-07-19 07:33:05 +00:00
|
|
|
|
}
|
2021-01-10 22:16:22 +00:00
|
|
|
|
}
|
2021-01-10 21:31:29 +00:00
|
|
|
|
|
2022-06-27 06:42:00 +00:00
|
|
|
|
function _damage_display(label_text, average, dmg_min, dmg_max) {
|
2021-07-27 10:04:12 +00:00
|
|
|
|
let label = document.createElement("p");
|
|
|
|
|
label.textContent = label_text+average.toFixed(2);
|
|
|
|
|
part_div.append(label);
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < 6; i++){
|
2022-06-27 06:42:00 +00:00
|
|
|
|
if (dmg_max[i] != 0){
|
2021-07-27 10:04:12 +00:00
|
|
|
|
let p = document.createElement("p");
|
|
|
|
|
p.classList.add(damageClasses[i]);
|
2022-06-27 06:42:00 +00:00
|
|
|
|
p.textContent = dmg_min[i].toFixed(2)+" \u2013 "+dmg_max[i].toFixed(2);
|
2021-07-27 10:04:12 +00:00
|
|
|
|
part_div.append(p);
|
|
|
|
|
}
|
2021-01-09 08:52:58 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-28 05:16:23 +00:00
|
|
|
|
_damage_display("Non-Crit Average: ", nonCritAverage, spell_info.normal_min, spell_info.normal_max);
|
|
|
|
|
_damage_display("Crit Average: ", critAverage, spell_info.crit_min, spell_info.crit_max);
|
|
|
|
|
} else if (spell_info.type === "heal") {
|
|
|
|
|
let heal_amount = spell_info.heal_amount;
|
2022-07-29 05:53:04 +00:00
|
|
|
|
let healLabel = make_elem("p", ["Set"], {textContent: heal_amount.toFixed(2)});
|
2021-01-09 11:56:10 +00:00
|
|
|
|
part_div.append(healLabel);
|
2022-06-28 05:16:23 +00:00
|
|
|
|
if (spell_info.name === spell.display) {
|
2022-07-20 07:35:20 +00:00
|
|
|
|
add_summary(spell_info.name+ ": ", heal_amount, "Set");
|
2021-01-10 22:16:22 +00:00
|
|
|
|
}
|
2021-01-09 08:52:58 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-06-19 18:43:02 +00:00
|
|
|
|
|
2022-06-29 06:23:27 +00:00
|
|
|
|
addClickableArrow(overallparent_elem, parent_elem);
|
2022-07-23 12:19:32 +00:00
|
|
|
|
_overallparent_elem.append(overallparent_elem);
|
2021-01-09 08:52:58 +00:00
|
|
|
|
}
|
2021-03-14 07:55:08 +00:00
|
|
|
|
|
2022-06-29 06:23:27 +00:00
|
|
|
|
function addClickableArrow(elem, target) {
|
2022-06-23 09:51:51 +00:00
|
|
|
|
//up and down arrow - done ugly
|
2022-07-19 07:39:01 +00:00
|
|
|
|
let arrow = make_elem("img", [], { id: "arrow_" + elem.id, src: "../media/icons/" + (newIcons ? "new" : "old") + "/toggle_down.png" });
|
2022-06-23 09:51:51 +00:00
|
|
|
|
arrow.style.maxWidth = document.body.clientWidth > 900 ? "3rem" : "10rem";
|
2022-07-20 17:25:32 +00:00
|
|
|
|
elem.appendChild(arrow);
|
|
|
|
|
elem.addEventListener("click", () => toggle_spell_tab(arrow, target));
|
2022-06-29 06:23:27 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// toggle arrow thinger
|
|
|
|
|
function toggle_spell_tab(arrow_img, target) {
|
|
|
|
|
if (target.style.display == "none") {
|
|
|
|
|
target.style.display = "";
|
|
|
|
|
arrow_img.src = arrow_img.src.replace("down", "up");
|
|
|
|
|
} else {
|
|
|
|
|
target.style.display = "none";
|
|
|
|
|
arrow_img.src = arrow_img.src.replace("up", "down");
|
|
|
|
|
}
|
2022-06-23 09:51:51 +00:00
|
|
|
|
}
|