feat: stuffs
This commit is contained in:
parent
afb02b33dc
commit
c651816392
6 changed files with 1185 additions and 260 deletions
117
sq2bs.css
117
sq2bs.css
|
@ -1,4 +1,6 @@
|
|||
|
||||
* {
|
||||
font-family: 'Nunito', sans-serif;
|
||||
}
|
||||
|
||||
/* sidebar stuff */
|
||||
.sidebar {
|
||||
|
@ -44,6 +46,14 @@
|
|||
/* builder containers */
|
||||
|
||||
/* wynn-related css(es) */
|
||||
.positive {
|
||||
color: #5f5;
|
||||
}
|
||||
|
||||
.negative {
|
||||
color: #f55;
|
||||
}
|
||||
|
||||
.Health {
|
||||
color: #AA0000
|
||||
}
|
||||
|
@ -52,6 +62,14 @@
|
|||
content: "\2764" ' ';
|
||||
}
|
||||
|
||||
.lvl:before {
|
||||
content: 'Lv. '
|
||||
}
|
||||
|
||||
.Damage {
|
||||
color: rgb(255, 198, 85)
|
||||
}
|
||||
|
||||
.Normal {
|
||||
color: #FFFFFF;
|
||||
}
|
||||
|
@ -73,7 +91,12 @@
|
|||
}
|
||||
|
||||
.Mythic {
|
||||
color: #AA00AA
|
||||
color: #AA00AA;
|
||||
}
|
||||
|
||||
.Set {
|
||||
display: inline;
|
||||
color: #5f5;
|
||||
}
|
||||
|
||||
.eDam, .Earth, .Earth_powder {
|
||||
|
@ -110,9 +133,37 @@
|
|||
color: #FFAA00;
|
||||
}
|
||||
|
||||
.nDam:before, .Neutral:before { content: "\2724" ' '; }
|
||||
.nDam:before, .Neutral:before {
|
||||
content: "\2724" ' ';
|
||||
}
|
||||
|
||||
.Mana {
|
||||
color: #5ff;
|
||||
}
|
||||
|
||||
.Mana:after {
|
||||
content: "\273A"
|
||||
}
|
||||
|
||||
/* equipment field specifics */
|
||||
|
||||
.text-right {
|
||||
float: right;
|
||||
}
|
||||
|
||||
.text-left {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.spell-display p {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
|
||||
.spell-display b {
|
||||
font-size: 3rem;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
input {
|
||||
min-width: 0;
|
||||
width: 100%;
|
||||
|
@ -131,35 +182,73 @@ input.equipment-input {
|
|||
font-weight: bold;
|
||||
}
|
||||
|
||||
.warning {
|
||||
color: #ff8180;
|
||||
font-size: 1.875rem;
|
||||
margin-bottom: 0;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.scaled-item-icon {
|
||||
width: 128px;
|
||||
width: 8rem;
|
||||
}
|
||||
|
||||
.scaled-item-icon img {
|
||||
width: 104px;
|
||||
width: 6.5rem;
|
||||
}
|
||||
|
||||
@media screen and (min-width: 992px) {
|
||||
@media screen and (min-width: 1200px) and (max-width: 1400px) {
|
||||
.scaled-font {
|
||||
font-size: .8rem;
|
||||
}
|
||||
|
||||
.skp-tooltip {
|
||||
font-size: .625rem;
|
||||
}
|
||||
|
||||
.scaled-item-icon {
|
||||
width: 3.2rem;
|
||||
}
|
||||
|
||||
.scaled-item-icon img {
|
||||
width: 2.8rem;
|
||||
}
|
||||
|
||||
.warning {
|
||||
font-size: .7rem;
|
||||
}
|
||||
|
||||
.spell-display b {
|
||||
font-size: 1rem;
|
||||
}
|
||||
}
|
||||
|
||||
@media screen and (min-width: 1400px) {
|
||||
.scaled-font {
|
||||
font-size: 1rem;
|
||||
}
|
||||
|
||||
.skp-tooltip {
|
||||
font-size: .875rem;
|
||||
font-weight: bold;
|
||||
font-size: .78rem;
|
||||
}
|
||||
|
||||
.scaled-item-icon {
|
||||
width: 64px;
|
||||
width: 4rem;
|
||||
}
|
||||
|
||||
.scaled-item-icon img {
|
||||
width: 56px;
|
||||
width: 3.5rem;
|
||||
}
|
||||
|
||||
.warning {
|
||||
font-size: .8rem;
|
||||
}
|
||||
|
||||
.spell-display b {
|
||||
font-size: 1.2rem;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* Fake button for build stats */
|
||||
.fake-button {
|
||||
cursor: pointer;
|
||||
|
@ -208,8 +297,8 @@ input.equipment-input {
|
|||
|
||||
.dark-shadow {
|
||||
box-shadow: 0rem 0rem 1.25rem 0.1875rem black;
|
||||
}
|
||||
}
|
||||
|
||||
.dark-shadow-sm {
|
||||
box-shadow: 0rem 0rem 0.625rem 0.125rem black;
|
||||
}
|
||||
}
|
855
sq2bs.html
855
sq2bs.html
File diff suppressed because it is too large
Load diff
150
sq2bs.js
150
sq2bs.js
|
@ -1,3 +1,153 @@
|
|||
$().ready(function(){
|
||||
// sp fields
|
||||
jQuery(document).on("input", '.skp-update', function(){
|
||||
updateStatSchedule();
|
||||
});
|
||||
|
||||
// equipment fields
|
||||
$("#weapon-choice").on('input', function(e){
|
||||
update_fields('weapon');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#weapon-powder").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#helmet-choice").on('input', function(e){
|
||||
update_fields('helmet', '|example: t6t6');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#helmet-powder").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#chestplate-choice").on('input', function(e){
|
||||
update_fields('chestplate');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#chestplate-powder").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#leggings-choice").on('input', function(e){
|
||||
update_fields('leggings');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#leggings-powder").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#boots-choice").on('input', function(e){
|
||||
update_fields('boots');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#boots-powder").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#ring1-choice").on('input', function(e){
|
||||
update_fields('ring1');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#ring2-choice").on('input', function(e){
|
||||
update_fields('ring2');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#bracelet-choice").on('input', function(e){
|
||||
update_fields('bracelet');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#necklace-choice").on('input', function(e){
|
||||
update_fields('necklace');
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
$("#level-choice").on('input', function(e){
|
||||
calcBuildSchedule();
|
||||
});
|
||||
|
||||
// tabular stats view
|
||||
let tabs = ['minimal-stats', 'minimal-offensive-stats', 'minimal-defensive-stats'];
|
||||
let btns = ['tab-basic-btn', 'tab-offense-btn', 'tab-defense-btn'];
|
||||
|
||||
$(".fake-button").on('click' ,function(e){
|
||||
let target_tab;
|
||||
|
||||
if (e.target.id == 'tab-basic-btn') {
|
||||
target_tab = 'minimal-stats';
|
||||
}
|
||||
else if (e.target.id == 'tab-offense-btn') {
|
||||
target_tab = 'minimal-offensive-stats';
|
||||
}
|
||||
else if (e.target.id == 'tab-defense-btn') {
|
||||
target_tab = 'minimal-defensive-stats';
|
||||
}
|
||||
for (const i in tabs) {
|
||||
$("#"+tabs[i]).hide();
|
||||
$("#"+btns[i]).removeClass("dark-6").addClass("dark-4");
|
||||
}
|
||||
$("#"+e.target.id).addClass("dark-6");
|
||||
$("#"+target_tab).show();
|
||||
});
|
||||
});
|
||||
let calcBuildTask = null;
|
||||
let updateStatTask = null;
|
||||
let doSearchTask = null;
|
||||
|
||||
function calcBuildSchedule(){
|
||||
if (calcBuildTask !== null) {
|
||||
clearTimeout(calcBuildTask);
|
||||
}
|
||||
calcBuildTask = setTimeout(function(){
|
||||
calcBuildTask = null;
|
||||
calculateBuild();
|
||||
}, 500);
|
||||
}
|
||||
|
||||
function updateStatSchedule(){
|
||||
if (updateStatTask !== null) {
|
||||
clearTimeout(updateStatTask);
|
||||
}
|
||||
updateStatTask = setTimeout(function(){
|
||||
updateStatTask = null;
|
||||
updateStats();
|
||||
}, 500);
|
||||
}
|
||||
|
||||
function doSearchSchedule(){
|
||||
if (doSearchTask !== null) {
|
||||
clearTimeout(doSearchTask);
|
||||
}
|
||||
doSearchTask = setTimeout(function(){
|
||||
doSearchTask = null;
|
||||
doItemSearch();
|
||||
}, 500);
|
||||
}
|
||||
|
||||
function update_fields(type, alt="") {
|
||||
let item = itemMap.get($("#"+type+"-choice").val());
|
||||
if (item) {
|
||||
$("#"+type+"-powder").attr("placeholder", item["slots"]+" slots"+alt);
|
||||
$("#"+type+"-choice").removeClass("text-light").addClass(item.tier);
|
||||
if (type == 'weapon') {
|
||||
$("#"+type+"-img").attr('src', 'media/items/new/generic-'+item.type+'.png');
|
||||
}
|
||||
} else {
|
||||
$("#"+type+"-choice").removeClass('Normal Unique Rare Legendary Fabled Mythic Set').addClass("text-light");
|
||||
}
|
||||
}
|
||||
|
||||
function init_field_styles() {
|
||||
let equipment_keys = ['weapon', 'helmet', 'chestplate', 'leggings', 'boots', 'ring1', 'ring2', 'bracelet', 'necklace'];
|
||||
for (const i in equipment_keys) {
|
||||
update_fields(equipment_keys[i]);
|
||||
}
|
||||
}
|
|
@ -165,7 +165,7 @@ function init() {
|
|||
});*/
|
||||
|
||||
decodeBuild(url_tag);
|
||||
init_equipUI();
|
||||
init_field_styles();
|
||||
}
|
||||
|
||||
function getItemNameFromID(id) {
|
||||
|
@ -469,7 +469,7 @@ function calculateBuild(save_skp, skp){
|
|||
const assigned = player_build.base_skillpoints;
|
||||
const skillpoints = player_build.total_skillpoints;
|
||||
for (let i in skp_order){ //big bren
|
||||
setText(skp_order[i] + "-skp-base", "Original Value: " + skillpoints[i]);
|
||||
setText(skp_order[i] + "-skp-base", "Original: " + skillpoints[i]);
|
||||
}
|
||||
|
||||
for (let id of editable_item_fields) {
|
||||
|
@ -761,10 +761,10 @@ function calculateBuildStats() {
|
|||
let summarybox = document.getElementById("summary-box");
|
||||
summarybox.textContent = "";
|
||||
let skpRow = document.createElement("p");
|
||||
let td = document.createElement("p");
|
||||
// let td = document.createElement("p");
|
||||
|
||||
let remainingSkp = document.createElement("p");
|
||||
remainingSkp.classList.add("center");
|
||||
remainingSkp.classList.add("scaled-font");
|
||||
let remainingSkpTitle = document.createElement("b");
|
||||
remainingSkpTitle.textContent = "Assigned " + player_build.assigned_skillpoints + " skillpoints. Remaining skillpoints: ";
|
||||
let remainingSkpContent = document.createElement("b");
|
||||
|
@ -778,13 +778,14 @@ function calculateBuildStats() {
|
|||
summarybox.append(skpRow);
|
||||
summarybox.append(remainingSkp);
|
||||
if(player_build.assigned_skillpoints > levelToSkillPoints(player_build.level)){
|
||||
let skpWarning = document.createElement("p");
|
||||
let skpWarning = document.createElement("span");
|
||||
//skpWarning.classList.add("itemp");
|
||||
skpWarning.classList.add("warning");
|
||||
skpWarning.classList.add("small-text");
|
||||
// skpWarning.classList.add("skp-tooltip");
|
||||
skpWarning.textContent = "WARNING: Too many skillpoints need to be assigned!";
|
||||
let skpCount = document.createElement("p");
|
||||
skpCount.classList.add("small-text");
|
||||
skpCount.classList.add("warning");
|
||||
// skpCount.classList.add("skp-tooltip");
|
||||
skpCount.textContent = "For level " + (player_build.level>101 ? "101+" : player_build.level) + ", there are only " + levelToSkillPoints(player_build.level) + " skill points available.";
|
||||
summarybox.append(skpWarning);
|
||||
summarybox.append(skpCount);
|
||||
|
@ -830,14 +831,13 @@ function calculateBuildStats() {
|
|||
}
|
||||
|
||||
for (let i in player_build.items) {
|
||||
displaysq2ExpandedItem(player_build.items[i], buildFields[i], true);
|
||||
// displaysq2ExpandedItem(player_build.items[i], buildFields[i], true);
|
||||
}
|
||||
|
||||
displaysq2WeaponBase(player_build);
|
||||
displaysq2ArmorStats(player_build);
|
||||
displayMinimalBuildStats("all-stats", player_build, build_all_display_commands);
|
||||
displayMinimalBuildStats("minimal-stats", player_build, build_basic_display_commands);
|
||||
displayMinimalBuildStats("minimal-offensive-stats",player_build, build_offensive_display_commands);
|
||||
displaysq2BuildStats("all-stats", player_build, build_all_display_commands);
|
||||
displaysq2BuildStats("minimal-stats", player_build, build_basic_display_commands);
|
||||
displaysq2BuildStats("minimal-offensive-stats",player_build, build_offensive_display_commands);
|
||||
displaySetBonuses("set-info",player_build);
|
||||
displayNextCosts("int-info",player_build);
|
||||
|
||||
|
|
291
sq2display.js
291
sq2display.js
|
@ -1,4 +1,4 @@
|
|||
function displayMinimalBuildStats(parent_id,build,command_group){
|
||||
function displaysq2BuildStats(parent_id,build,command_group){
|
||||
// Commands to "script" the creation of nice formatting.
|
||||
// #commands create a new element.
|
||||
// !elemental is some janky hack for elemental damage.
|
||||
|
@ -22,35 +22,13 @@ function displayMinimalBuildStats(parent_id,build,command_group){
|
|||
|
||||
for (const command of display_commands) {
|
||||
// style instructions
|
||||
|
||||
if (command.charAt(0) === "#") {
|
||||
if (command === "#cdiv") {
|
||||
active_elem = document.createElement('div');
|
||||
active_elem.classList.add('itemcenter');
|
||||
if (command === "#defense-stats") {
|
||||
displaysq2DefenseStats(parent_div, build, true);
|
||||
}
|
||||
else if (command === "#ldiv") {
|
||||
active_elem = document.createElement('div');
|
||||
active_elem.classList.add('itemleft');
|
||||
}
|
||||
else if (command === "#table") {
|
||||
active_elem = document.createElement('table');
|
||||
active_elem.classList.add('full-border')
|
||||
}
|
||||
else if (command === "#defense-stats") {
|
||||
displaysq2DefenseStats(active_elem, build, true);
|
||||
}
|
||||
else if(command === "#spacer") {
|
||||
let row = document.createElement('tr');
|
||||
let filler = document.createElement('td');
|
||||
filler.colSpan = 2
|
||||
filler.classList.add('center')
|
||||
filler.classList.add('shaded-table')
|
||||
filler.classList.add('spacer-table')
|
||||
row.appendChild(filler);
|
||||
active_elem.appendChild(row);
|
||||
}
|
||||
parent_div.appendChild(active_elem);
|
||||
}
|
||||
else if (command.charAt(0) === "!") {
|
||||
if (command.charAt(0) === "!") {
|
||||
// TODO: This is sooo incredibly janky.....
|
||||
if (command === "!elemental") {
|
||||
elemental_format = !elemental_format;
|
||||
|
@ -79,12 +57,14 @@ function displayMinimalBuildStats(parent_id,build,command_group){
|
|||
if (id === "poison" && id_val > 0) {
|
||||
id_val = Math.ceil(id_val*build.statMap.get("poisonPct")/100);
|
||||
}
|
||||
displaysq2FixedID(active_elem, id, id_val, elemental_format, style);
|
||||
displaysq2FixedID(parent_div, id, id_val, elemental_format, style);
|
||||
if (id === "poison" && id_val > 0) {
|
||||
let row = document.createElement('tr');
|
||||
let value_elem = document.createElement('td');
|
||||
value_elem.classList.add('right');
|
||||
value_elem.setAttribute("colspan", "2");
|
||||
let row = document.createElement('div');
|
||||
row.classList.add("row")
|
||||
let value_elem = document.createElement('div');
|
||||
value_elem.classList.add('col');
|
||||
value_elem.classList.add('text-end');
|
||||
|
||||
let prefix_elem = document.createElement('b');
|
||||
prefix_elem.textContent = "\u279C With Strength: ";
|
||||
let number_elem = document.createElement('b');
|
||||
|
@ -94,7 +74,7 @@ function displayMinimalBuildStats(parent_id,build,command_group){
|
|||
value_elem.append(number_elem);
|
||||
row.appendChild(value_elem);
|
||||
|
||||
active_elem.appendChild(row);
|
||||
parent_div.appendChild(row);
|
||||
}
|
||||
|
||||
// sp thingy
|
||||
|
@ -109,7 +89,7 @@ function displayMinimalBuildStats(parent_id,build,command_group){
|
|||
style = "negative";
|
||||
}
|
||||
if (diff != 0) {
|
||||
displaysq2FixedID(active_elem, id, diff, false, style);
|
||||
displaysq2FixedID(parent_div, id, diff, false, style);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -565,11 +545,12 @@ function displaysq2WeaponBase(build) {
|
|||
|
||||
function displaysq2FixedID(active, id, value, elemental_format, style) {
|
||||
if (style) {
|
||||
let row = document.createElement('tr');
|
||||
let desc_elem = document.createElement('td');
|
||||
desc_elem.classList.add('shaded-table');
|
||||
desc_elem.classList.add('left');
|
||||
desc_elem.classList.add('se-padded');
|
||||
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');
|
||||
|
||||
if (elemental_format) {
|
||||
apply_elemental_format(desc_elem, id);
|
||||
}
|
||||
|
@ -578,10 +559,9 @@ function displaysq2FixedID(active, id, value, elemental_format, style) {
|
|||
}
|
||||
row.appendChild(desc_elem);
|
||||
|
||||
let value_elem = document.createElement('td');
|
||||
value_elem.classList.add('right');
|
||||
value_elem.classList.add('shaded-table');
|
||||
value_elem.classList.add('se-padded');
|
||||
let value_elem = document.createElement('div');
|
||||
value_elem.classList.add('col');
|
||||
value_elem.classList.add('text-end');
|
||||
value_elem.classList.add(style);
|
||||
value_elem.textContent = value + idSuffixes[id];
|
||||
row.appendChild(value_elem);
|
||||
|
@ -610,19 +590,13 @@ function displaysq2PoisonDamage(overallparent_elem, build) {
|
|||
overallparent_elem.textContent = "";
|
||||
|
||||
//Title
|
||||
let title_elemavg = document.createElement("p");
|
||||
title_elemavg.classList.add('no-newline');
|
||||
// title_elemavg.classList.add("smalltitle");
|
||||
// title_elemavg.classList.add("Normal");
|
||||
let title_elemavg = document.createElement("b");
|
||||
title_elemavg.textContent = "Poison Stats";
|
||||
overallparent_elem.append(title_elemavg);
|
||||
|
||||
let overallpoisonDamage = document.createElement("p");
|
||||
// overallpoisonDamage.classList.add("lessbottom");
|
||||
let overallpoisonDamageFirst = document.createElement("p");
|
||||
let overallpoisonDamageSecond = document.createElement("p");
|
||||
overallpoisonDamageFirst.classList.add('no-newline');
|
||||
overallpoisonDamageSecond.classList.add('no-newline');
|
||||
let overallpoisonDamageFirst = document.createElement("span");
|
||||
let overallpoisonDamageSecond = document.createElement("span");
|
||||
let poison_tick = Math.ceil(build.statMap.get("poison") * (1+skillPointsToPercentage(build.total_skillpoints[0])) * (build.statMap.get("poisonPct") + build.externalStats.get("poisonPct"))/100 /3);
|
||||
overallpoisonDamageFirst.textContent = "Poison Tick: ";
|
||||
overallpoisonDamageSecond.textContent = Math.max(poison_tick,0);
|
||||
|
@ -634,8 +608,8 @@ function displaysq2PoisonDamage(overallparent_elem, build) {
|
|||
}
|
||||
|
||||
function displaysq2MeleeDamage(parent_elem, overallparent_elem, meleeStats){
|
||||
console.log("Melee Stats");
|
||||
console.log(meleeStats);
|
||||
// console.log("Melee Stats");
|
||||
// console.log(meleeStats);
|
||||
let tooltipinfo = meleeStats[13];
|
||||
let attackSpeeds = ["Super Slow", "Very Slow", "Slow", "Normal", "Fast", "Very Fast", "Super Fast"];
|
||||
//let damagePrefixes = ["Neutral Damage: ","Earth Damage: ","Thunder Damage: ","Water Damage: ","Fire Damage: ","Air Damage: "];
|
||||
|
@ -667,9 +641,7 @@ function displaysq2MeleeDamage(parent_elem, overallparent_elem, meleeStats){
|
|||
parent_elem.append(document.createElement("br"));
|
||||
|
||||
//overall title
|
||||
let title_elemavg = document.createElement("p");
|
||||
title_elemavg.classList.add('no-newline');
|
||||
title_elemavg.classList.add("box-title");
|
||||
let title_elemavg = document.createElement("b");
|
||||
title_elemavg.textContent = "Melee Stats";
|
||||
overallparent_elem.append(title_elemavg);
|
||||
|
||||
|
@ -684,12 +656,10 @@ function displaysq2MeleeDamage(parent_elem, overallparent_elem, meleeStats){
|
|||
|
||||
//overall average DPS
|
||||
let overallaverageDamage = document.createElement("p");
|
||||
let overallaverageDamageFirst = document.createElement("p");
|
||||
overallaverageDamageFirst.classList.add('no-newline');
|
||||
let overallaverageDamageFirst = document.createElement("span");
|
||||
overallaverageDamageFirst.textContent = "Average DPS: "
|
||||
|
||||
let overallaverageDamageSecond = document.createElement("p");
|
||||
overallaverageDamageSecond.classList.add('no-newline');
|
||||
let overallaverageDamageSecond = document.createElement("span");
|
||||
overallaverageDamageSecond.classList.add("Damage");
|
||||
overallaverageDamageSecond.textContent = stats[10];
|
||||
overallaverageDamage.appendChild(overallaverageDamageFirst);
|
||||
|
@ -707,11 +677,9 @@ function displaysq2MeleeDamage(parent_elem, overallparent_elem, meleeStats){
|
|||
|
||||
//overall attack speed
|
||||
let overallatkSpd = document.createElement("p");
|
||||
let overallatkSpdFirst = document.createElement("p");
|
||||
overallatkSpdFirst.classList.add('no-newline');
|
||||
let overallatkSpdFirst = document.createElement("span");
|
||||
overallatkSpdFirst.textContent = "Attack Speed: ";
|
||||
let overallatkSpdSecond = document.createElement("p");
|
||||
overallatkSpdSecond.classList.add('no-newline');
|
||||
let overallatkSpdSecond = document.createElement("span");
|
||||
overallatkSpdSecond.classList.add("Damage");
|
||||
overallatkSpdSecond.textContent = attackSpeeds[stats[11]];
|
||||
overallatkSpd.appendChild(overallatkSpdFirst);
|
||||
|
@ -758,11 +726,9 @@ function displaysq2MeleeDamage(parent_elem, overallparent_elem, meleeStats){
|
|||
|
||||
//overall average DPS
|
||||
let singleHitDamage = document.createElement("p");
|
||||
let singleHitDamageFirst = document.createElement("p");
|
||||
singleHitDamageFirst.classList.add('no-newline');
|
||||
let singleHitDamageFirst = document.createElement("span");
|
||||
singleHitDamageFirst.textContent = "Single Hit Average: ";
|
||||
let singleHitDamageSecond = document.createElement("p");
|
||||
singleHitDamageSecond.classList.add('no-newline');
|
||||
let singleHitDamageSecond = document.createElement("span");
|
||||
singleHitDamageSecond.classList.add("Damage");
|
||||
singleHitDamageSecond.textContent = stats[12].toFixed(2);
|
||||
tooltiptext = ` = ((${stats[6][0]} + ${stats[6][1]}) / 2) * ${stats[6][2].toFixed(2)} + ((${stats[7][0]} + ${stats[7][1]}) / 2) * ${stats[7][2].toFixed(2)}`;
|
||||
|
@ -834,7 +800,6 @@ function displaysq2ArmorStats(build) {
|
|||
document.getElementById(armor_keys[i]+'-health').textContent = build[armor_keys[i]].get('hp');
|
||||
document.getElementById(armor_keys[i]+'-lv').textContent = build[armor_keys[i]].get('lvl');
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
||||
|
@ -846,8 +811,7 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
const stats = defenseStats.slice();
|
||||
|
||||
// parent_elem.append(document.createElement("br"));
|
||||
let statsTable = document.createElement("table");
|
||||
statsTable.classList.add("full-border");
|
||||
let statsTable = document.createElement("div");
|
||||
|
||||
//[total hp, ehp, total hpr, ehpr, [def%, agi%], [edef,tdef,wdef,fdef,adef]]
|
||||
for(const i in stats){
|
||||
|
@ -861,16 +825,17 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
}
|
||||
|
||||
//total HP
|
||||
let hpRow = document.createElement("tr");
|
||||
let hp = document.createElement("td");
|
||||
let hpRow = document.createElement("div");
|
||||
hpRow.classList.add('row');
|
||||
let hp = document.createElement("div");
|
||||
hp.classList.add('col');
|
||||
hp.classList.add("Health");
|
||||
hp.classList.add("shaded-table");
|
||||
hp.classList.add("left");
|
||||
hp.classList.add("text-start");
|
||||
hp.textContent = "Total HP:";
|
||||
let boost = document.createElement("td");
|
||||
let boost = document.createElement("div");
|
||||
boost.classList.add('col');
|
||||
boost.textContent = stats[0];
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table")
|
||||
boost.classList.add("text-end");
|
||||
|
||||
hpRow.appendChild(hp);
|
||||
hpRow.append(boost);
|
||||
|
@ -887,16 +852,17 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
if (!defMult) {defMult = 1}
|
||||
|
||||
//EHP
|
||||
let ehpRow = document.createElement("tr");
|
||||
let ehp = document.createElement("td");
|
||||
ehp.classList.add("left");
|
||||
ehp.classList.add("shaded-table");
|
||||
let ehpRow = document.createElement("div");
|
||||
ehpRow.classList.add("row");
|
||||
let ehp = document.createElement("div");
|
||||
ehp.classList.add("col");
|
||||
ehp.classList.add("text-start");
|
||||
ehp.textContent = "Effective HP:";
|
||||
|
||||
boost = document.createElement("td");
|
||||
boost = document.createElement("div");
|
||||
boost.textContent = stats[1][0];
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
tooltiptext = `= ${stats[0]} / ((1 - ${skillPointsToPercentage(build.total_skillpoints[3]).toFixed(3)}) * (1 - ${skillPointsToPercentage(build.total_skillpoints[4]).toFixed(3)}) * (2 - ${defMult}) * (2 - ${build.defenseMultiplier}))`
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, boost, ["def-tooltip"]);
|
||||
|
||||
|
@ -909,16 +875,17 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
statsTable.append(ehpRow);
|
||||
}
|
||||
|
||||
ehpRow = document.createElement("tr");
|
||||
ehp = document.createElement("td");
|
||||
ehp.classList.add("left");
|
||||
ehp.classList.add("shaded-table");
|
||||
ehpRow = document.createElement("div");
|
||||
ehpRow.classList.add("row");
|
||||
ehp = document.createElement("div");
|
||||
ehp.classList.add("col");
|
||||
ehp.classList.add("text-start");
|
||||
ehp.textContent = "Effective HP (no agi):";
|
||||
|
||||
boost = document.createElement("td");
|
||||
boost = document.createElement("div");
|
||||
boost.textContent = stats[1][1];
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
tooltiptext = `= ${stats[0]} / ((1 - ${skillPointsToPercentage(build.total_skillpoints[3]).toFixed(3)}) * (2 - ${defMult}) * (2 - ${build.defenseMultiplier}))`
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, boost, ["def-tooltip"]);
|
||||
|
||||
|
@ -927,16 +894,17 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
statsTable.append(ehpRow);
|
||||
|
||||
//total HPR
|
||||
let hprRow = document.createElement("tr");
|
||||
let hpr = document.createElement("td");
|
||||
let hprRow = document.createElement("div");
|
||||
hprRow.classList.add("row")
|
||||
let hpr = document.createElement("div");
|
||||
hpr.classList.add("Health");
|
||||
hpr.classList.add("shaded-table");
|
||||
hpr.classList.add("left");
|
||||
hpr.classList.add("col");
|
||||
hpr.classList.add("text-start");
|
||||
hpr.textContent = "HP Regen (Total):";
|
||||
boost = document.createElement("td");
|
||||
boost = document.createElement("div");
|
||||
boost.textContent = stats[2];
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table")
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
|
||||
hprRow.appendChild(hpr);
|
||||
hprRow.appendChild(boost);
|
||||
|
@ -948,16 +916,17 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
}
|
||||
|
||||
//EHPR
|
||||
let ehprRow = document.createElement("tr");
|
||||
let ehpr = document.createElement("td");
|
||||
ehpr.classList.add("left");
|
||||
ehpr.classList.add("shaded-table");
|
||||
let ehprRow = document.createElement("div");
|
||||
ehprRow.classList.add("row")
|
||||
let ehpr = document.createElement("div");
|
||||
ehpr.classList.add("col");
|
||||
ehpr.classList.add("text-start");
|
||||
ehpr.textContent = "Effective HP Regen:";
|
||||
|
||||
boost = document.createElement("td");
|
||||
boost = document.createElement("div");
|
||||
boost.textContent = stats[3][0];
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
tooltiptext = `= ${stats[2]} / ((1 - ${skillPointsToPercentage(build.total_skillpoints[3]).toFixed(3)}) * (1 - ${skillPointsToPercentage(build.total_skillpoints[4]).toFixed(3)}) * (2 - ${defMult}) * (2 - ${build.defenseMultiplier}))`
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, boost, ["def-tooltip"]);
|
||||
|
||||
|
@ -981,29 +950,28 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
//eledefs
|
||||
let eledefs = stats[5];
|
||||
for (let i = 0; i < eledefs.length; i++){
|
||||
let eledefElemRow = document.createElement("tr");
|
||||
let eledefElemRow = document.createElement("div");
|
||||
eledefElemRow.classList.add("row")
|
||||
|
||||
let eledef = document.createElement("td");
|
||||
eledef.classList.add("left");
|
||||
eledef.classList.add("shaded-table");
|
||||
let eledefTitle = document.createElement("p");
|
||||
eledefTitle.classList.add('no-newline');
|
||||
let eledef = document.createElement("div");
|
||||
eledef.classList.add("col");
|
||||
eledef.classList.add("text-start");
|
||||
let eledefTitle = document.createElement("span");
|
||||
eledefTitle.textContent = damageClasses[i+1];
|
||||
eledefTitle.classList.add(damageClasses[i+1]);
|
||||
|
||||
let defense = document.createElement("p");
|
||||
defense.classList.add('no-newline');
|
||||
let defense = document.createElement("span");
|
||||
defense.textContent = " Def (Total): ";
|
||||
|
||||
eledef.appendChild(eledefTitle);
|
||||
eledef.appendChild(defense);
|
||||
eledefElemRow.appendChild(eledef);
|
||||
|
||||
let boost = document.createElement("td");
|
||||
let boost = document.createElement("div");
|
||||
boost.textContent = eledefs[i];
|
||||
boost.classList.add(eledefs[i] >= 0 ? "positive" : "negative");
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
|
||||
let defRaw = build.statMap.get("defRaw")[i];
|
||||
let defPct = build.statMap.get("defBonus")[i]/100;
|
||||
|
@ -1027,27 +995,29 @@ function displaysq2DefenseStats(parent_elem, build, insertSummary){
|
|||
|
||||
if (!insertSummary) {
|
||||
//skp
|
||||
let defRow = document.createElement("tr");
|
||||
let defElem = document.createElement("td");
|
||||
defElem.classList.add("left");
|
||||
defElem.classList.add("shaded-table");
|
||||
let defRow = document.createElement("div");
|
||||
defRow.classList.add("row");
|
||||
let defElem = document.createElement("div");
|
||||
defElem.classList.add("col");
|
||||
defElem.classList.add("text-start");
|
||||
defElem.textContent = "Damage Absorbed %:";
|
||||
boost = document.createElement("td");
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table");
|
||||
boost = document.createElement("div");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
boost.textContent = stats[4][0] + "%";
|
||||
defRow.appendChild(defElem);
|
||||
defRow.appendChild(boost);
|
||||
statsTable.append(defRow);
|
||||
|
||||
let agiRow = document.createElement("tr");
|
||||
let agiElem = document.createElement("td");
|
||||
agiElem.classList.add("left");
|
||||
agiElem.classList.add("shaded-table");
|
||||
let agiRow = document.createElement("div");
|
||||
agiRow.classList.add("row");
|
||||
let agiElem = document.createElement("div");
|
||||
agiElem.classList.add("col");
|
||||
agiElem.classList.add("text-start");
|
||||
agiElem.textContent = "Dodge Chance %:";
|
||||
boost = document.createElement("td");
|
||||
boost.classList.add("right");
|
||||
boost.classList.add("shaded-table")
|
||||
boost = document.createElement("div");
|
||||
boost.classList.add("col");
|
||||
boost.classList.add("text-end");
|
||||
boost.textContent = stats[4][1] + "%";
|
||||
agiRow.appendChild(agiElem);
|
||||
agiRow.appendChild(boost);
|
||||
|
@ -1191,26 +1161,19 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
let tooltip; let tooltiptext;
|
||||
const stats = build.statMap;
|
||||
let title_elem = document.createElement("p");
|
||||
// title_elem.classList.add("smalltitle");
|
||||
// title_elem.classList.add("Normal");
|
||||
|
||||
overallparent_elem.textContent = "";
|
||||
let title_elemavg = document.createElement("p");
|
||||
// title_elemavg.classList.add('smalltitle');
|
||||
// title_elemavg.classList.add('Normal');
|
||||
let title_elemavg = document.createElement("b");
|
||||
|
||||
if (spellIdx != 0) {
|
||||
let first = document.createElement("p");
|
||||
first.classList.add('no-newline');
|
||||
let first = document.createElement("span");
|
||||
first.textContent = spell.title + " (";
|
||||
title_elem.appendChild(first.cloneNode(true)); //cloneNode is needed here.
|
||||
title_elemavg.appendChild(first);
|
||||
|
||||
let second = document.createElement("p");
|
||||
second.classList.add('no-newline');
|
||||
let second = document.createElement("span");
|
||||
second.textContent = build.getSpellCost(spellIdx, spell.cost);
|
||||
second.classList.add("Mana");
|
||||
// second.classList.add("tooltip");
|
||||
|
||||
let int_redux = skillPointsToPercentage(build.total_skillpoints[2]).toFixed(2);
|
||||
let spPct_redux = (build.statMap.get("spPct" + spellIdx)/100).toFixed(2);
|
||||
|
@ -1229,8 +1192,7 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
third.classList.add('no-newline');
|
||||
third.textContent = ") [Base: " + build.getBaseSpellCost(spellIdx, spell.cost) + " ]";
|
||||
title_elem.appendChild(third);
|
||||
let third_summary = document.createElement("p");
|
||||
third_summary.classList.add('no-newline');
|
||||
let third_summary = document.createElement("span");
|
||||
third_summary.textContent = ")";
|
||||
title_elemavg.appendChild(third_summary);
|
||||
}
|
||||
|
@ -1247,7 +1209,6 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
let save_damages = [];
|
||||
|
||||
let part_divavg = document.createElement("p");
|
||||
// part_divavg.classList.add("lessbottom");
|
||||
overallparent_elem.append(part_divavg);
|
||||
|
||||
let spell_parts;
|
||||
|
@ -1266,13 +1227,12 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
//console.log(spell_parts);
|
||||
|
||||
for (const part of spell_parts) {
|
||||
parent_elem.append(document.createElement("br"));
|
||||
// parent_elem.append(document.createElement("br"));
|
||||
let part_div = document.createElement("p");
|
||||
parent_elem.append(part_div);
|
||||
|
||||
let subtitle_elem = document.createElement("p");
|
||||
subtitle_elem.textContent = part.subtitle;
|
||||
// subtitle_elem.classList.add("nomargin");
|
||||
part_div.append(subtitle_elem);
|
||||
|
||||
if (part.type === "damage") {
|
||||
|
@ -1304,10 +1264,8 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
|
||||
if (part.summary == true) {
|
||||
let overallaverageLabel = document.createElement("p");
|
||||
let first = document.createElement("p");
|
||||
let second = document.createElement("p");
|
||||
first.classList.add('no-newline');
|
||||
second.classList.add('no-newline');
|
||||
let first = document.createElement("span");
|
||||
let second = document.createElement("span");
|
||||
first.textContent = part.subtitle + " Average: ";
|
||||
second.textContent = averageDamage.toFixed(2);
|
||||
overallaverageLabel.appendChild(first);
|
||||
|
@ -1356,33 +1314,14 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
part_div.append(healLabel);
|
||||
if (part.summary == true) {
|
||||
let overallhealLabel = document.createElement("p");
|
||||
let first = document.createElement("p");
|
||||
let second = document.createElement("p");
|
||||
first.classList.add('no-newline');
|
||||
second.classList.add('no-newline');
|
||||
let first = document.createElement("span");
|
||||
let second = document.createElement("span");
|
||||
first.textContent = part.subtitle + ": ";
|
||||
second.textContent = heal_amount;
|
||||
overallhealLabel.appendChild(first);
|
||||
second.classList.add("Set");
|
||||
overallhealLabel.appendChild(second);
|
||||
// overallhealLabel.classList.add("itemp");
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, second, ["spell-tooltip"]);
|
||||
part_divavg.append(overallhealLabel);
|
||||
|
||||
/*
|
||||
let effectiveHealLabel = document.createElement("p");
|
||||
first = document.createElement("b");
|
||||
second = document.createElement("b");
|
||||
let defStats = build.getDefenseStats();
|
||||
tooltiptext = ` = ${heal_amount} * ${defStats[1][0].toFixed(2)} / ${defStats[0]}`;
|
||||
first.textContent = "Effective Heal: ";
|
||||
second.textContent = (defStats[1][0]*heal_amount/defStats[0]).toFixed(2);
|
||||
effectiveHealLabel.appendChild(first);
|
||||
second.classList.add("Set");
|
||||
effectiveHealLabel.appendChild(second);
|
||||
// effectiveHealLabel.classList.add("itemp");
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, second, ["spell-tooltip"]);
|
||||
part_divavg.append(effectiveHealLabel);*/
|
||||
}
|
||||
} else if (part.type === "total") {
|
||||
let total_damage = 0;
|
||||
|
@ -1403,15 +1342,11 @@ function displaysq2SpellDamage(parent_elem, overallparent_elem, build, spell, sp
|
|||
part_div.append(averageLabel);
|
||||
|
||||
let overallaverageLabel = document.createElement("p");
|
||||
overallaverageLabel.classList.add("damageSubtitle");
|
||||
let overallaverageLabelFirst = document.createElement("p");
|
||||
let overallaverageLabelSecond = document.createElement("p");
|
||||
overallaverageLabelFirst.classList.add('no-newline');
|
||||
overallaverageLabelSecond.classList.add('no-newline');
|
||||
let overallaverageLabelFirst = document.createElement("span");
|
||||
let overallaverageLabelSecond = document.createElement("span");
|
||||
overallaverageLabelFirst.textContent = "Average: ";
|
||||
overallaverageLabelSecond.textContent = total_damage.toFixed(2);
|
||||
overallaverageLabelSecond.classList.add("Damage");
|
||||
// tooltip = createTooltip(tooltip, "p", tooltiptext, overallaverageLabel, ["spell-tooltip", "summary-tooltip"]);
|
||||
|
||||
|
||||
overallaverageLabel.appendChild(overallaverageLabelFirst);
|
||||
|
|
|
@ -48,9 +48,7 @@ let build_offensive_display_commands = [
|
|||
];
|
||||
|
||||
let build_basic_display_commands = [
|
||||
'#table',
|
||||
'#defense-stats',
|
||||
'#spacer',
|
||||
// defense stats [hp, ehp, hpr, ]
|
||||
// "sPot", // base * atkspd + spell raws
|
||||
// melee potential
|
||||
|
|
Loading…
Add table
Reference in a new issue