2021-10-21 21:11:04 +07:00
function displaysq2BuildStats ( parent _id , build , command _group ) {
2021-10-17 22:53:48 +07: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.
let display _commands = command _group ;
2022-01-07 00:12:00 -08:00
//console.log(display_commands);
2021-10-17 22:53:48 +07:00
let parent _div = document . getElementById ( parent _id ) ;
2022-01-07 00:12:00 -08:00
// Clear the parent div.
if ( parent _div != null ) {
setHTML ( parent _id , "" ) ;
}
2021-10-17 22:53:48 +07:00
let stats = build . statMap ;
2022-01-07 00:12:00 -08:00
//console.log(build.statMap);
2021-10-17 22:53:48 +07:00
let active _elem ;
let elemental _format = false ;
//TODO this is put here for readability, consolidate with definition in build.js
let staticIDs = [ "hp" , "eDef" , "tDef" , "wDef" , "fDef" , "aDef" ] ;
for ( const command of display _commands ) {
// style instructions
2021-10-21 21:11:04 +07:00
2021-10-17 22:53:48 +07:00
if ( command . charAt ( 0 ) === "#" ) {
2021-10-21 21:11:04 +07:00
if ( command === "#defense-stats" ) {
displaysq2DefenseStats ( parent _div , build , true ) ;
2021-10-17 22:53:48 +07:00
}
}
2021-10-21 21:11:04 +07:00
if ( command . charAt ( 0 ) === "!" ) {
2021-10-17 22:53:48 +07:00
// TODO: This is sooo incredibly janky.....
if ( command === "!elemental" ) {
elemental _format = ! elemental _format ;
}
}
// id instruction
else {
let id = command ;
2022-05-13 21:23:54 -07:00
if ( stats . get ( id ) || build . externalStats . get ( id ) ) {
2021-10-17 22:53:48 +07:00
let style = null ;
// TODO: add pos and neg style
if ( ! staticIDs . includes ( id ) ) {
style = "positive" ;
if ( stats . get ( id ) < 0 ) {
style = "negative" ;
}
}
// ignore
let id _val = stats . get ( id ) ;
2022-05-13 21:23:54 -07:00
if ( build . externalStats . has ( id ) ) {
id _val += build . externalStats . get ( id ) ;
}
2021-10-17 22:53:48 +07:00
if ( reversedIDs . includes ( id ) ) {
style === "positive" ? style = "negative" : style = "positive" ;
}
if ( id === "poison" && id _val > 0 ) {
id _val = Math . ceil ( id _val * build . statMap . get ( "poisonPct" ) / 100 ) ;
}
2021-10-21 21:11:04 +07:00
displaysq2FixedID ( parent _div , id , id _val , elemental _format , style ) ;
2021-10-17 22:53:48 +07:00
if ( id === "poison" && id _val > 0 ) {
2021-10-21 21:11:04 +07:00
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' ) ;
2021-10-17 22:53:48 +07:00
let prefix _elem = document . createElement ( 'b' ) ;
prefix _elem . textContent = "\u279C With Strength: " ;
let number _elem = document . createElement ( 'b' ) ;
number _elem . classList . add ( style ) ;
number _elem . textContent = ( id _val * ( 1 + skillPointsToPercentage ( build . total _skillpoints [ 0 ] ) ) ) . toFixed ( 0 ) + idSuffixes [ id ] ;
value _elem . append ( prefix _elem ) ;
value _elem . append ( number _elem ) ;
row . appendChild ( value _elem ) ;
2021-10-21 21:11:04 +07:00
parent _div . appendChild ( row ) ;
2021-10-17 22:53:48 +07:00
}
// sp thingy
} else if ( skp _order . includes ( id ) ) {
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 ) {
2021-10-21 21:11:04 +07:00
displaysq2FixedID ( parent _div , id , diff , false , style ) ;
2021-10-17 22:53:48 +07:00
}
}
}
}
}
2021-10-29 15:08:36 +07:00
function displaysq2ExpandedItem ( item , parent _id ) {
2021-10-17 22:53:48 +07: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.
if ( item . get ( "category" ) === "weapon" ) {
let stats = new Map ( ) ;
stats . set ( "atkSpd" , item . get ( "atkSpd" ) ) ;
stats . set ( "damageBonus" , [ 0 , 0 , 0 , 0 , 0 ] ) ;
//SUPER JANK @HPP PLS FIX
let damage _keys = [ "nDam_" , "eDam_" , "tDam_" , "wDam_" , "fDam_" , "aDam_" ] ;
if ( item . get ( "tier" ) !== "Crafted" ) {
stats . set ( "damageRaw" , [ item . get ( "nDam" ) , item . get ( "eDam" ) , item . get ( "tDam" ) , item . get ( "wDam" ) , item . get ( "fDam" ) , item . get ( "aDam" ) ] ) ;
let results = calculateSpellDamage ( stats , [ 100 , 0 , 0 , 0 , 0 , 0 ] , 0 , 0 , 0 , item , [ 0 , 0 , 0 , 0 , 0 ] , 1 , undefined ) ;
let damages = results [ 2 ] ;
let total _damage = 0 ;
for ( const i in damage _keys ) {
total _damage += damages [ i ] [ 0 ] + damages [ i ] [ 1 ] ;
item . set ( damage _keys [ i ] , damages [ i ] [ 0 ] + "-" + damages [ i ] [ 1 ] ) ;
}
total _damage = total _damage / 2 ;
item . set ( "basedps" , total _damage ) ;
} else {
stats . set ( "damageRaw" , [ item . get ( "nDamLow" ) , item . get ( "eDamLow" ) , item . get ( "tDamLow" ) , item . get ( "wDamLow" ) , item . get ( "fDamLow" ) , item . get ( "aDamLow" ) ] ) ;
stats . set ( "damageBases" , [ item . get ( "nDamBaseLow" ) , item . get ( "eDamBaseLow" ) , item . get ( "tDamBaseLow" ) , item . get ( "wDamBaseLow" ) , item . get ( "fDamBaseLow" ) , item . get ( "aDamBaseLow" ) ] ) ;
let resultsLow = calculateSpellDamage ( stats , [ 100 , 0 , 0 , 0 , 0 , 0 ] , 0 , 0 , 0 , item , [ 0 , 0 , 0 , 0 , 0 ] , 1 , undefined ) ;
let damagesLow = resultsLow [ 2 ] ;
stats . set ( "damageRaw" , [ item . get ( "nDam" ) , item . get ( "eDam" ) , item . get ( "tDam" ) , item . get ( "wDam" ) , item . get ( "fDam" ) , item . get ( "aDam" ) ] ) ;
stats . set ( "damageBases" , [ item . get ( "nDamBaseHigh" ) , item . get ( "eDamBaseHigh" ) , item . get ( "tDamBaseHigh" ) , item . get ( "wDamBaseHigh" ) , item . get ( "fDamBaseHigh" ) , item . get ( "aDamBaseHigh" ) ] ) ;
let results = calculateSpellDamage ( stats , [ 100 , 0 , 0 , 0 , 0 , 0 ] , 0 , 0 , 0 , item , [ 0 , 0 , 0 , 0 , 0 ] , 1 , undefined ) ;
let damages = results [ 2 ] ;
console . log ( damages ) ;
let total _damage _min = 0 ;
let total _damage _max = 0 ;
for ( const i in damage _keys ) {
total _damage _min += damagesLow [ i ] [ 0 ] + damagesLow [ i ] [ 1 ] ;
total _damage _max += damages [ i ] [ 0 ] + damages [ i ] [ 1 ] ;
item . set ( damage _keys [ i ] , damagesLow [ i ] [ 0 ] + "-" + damagesLow [ i ] [ 1 ] + "\u279c" + damages [ i ] [ 0 ] + "-" + damages [ i ] [ 1 ] ) ;
}
total _damage _min = total _damage _min / 2 ;
total _damage _max = total _damage _max / 2 ;
item . set ( "basedps" , [ total _damage _min , total _damage _max ] ) ;
}
} else if ( item . get ( "category" ) === "armor" ) {
}
2021-10-26 18:43:51 +07:00
let display _commands = sq2 _item _display _commands ;
2021-10-17 22:53:48 +07:00
// Clear the parent div.
setHTML ( parent _id , "" ) ;
let parent _div = document . getElementById ( parent _id ) ;
2022-05-13 16:39:00 -07:00
parent _div . classList . add ( "border" , "border-2" , "border-dark" ) ;
2021-10-17 22:53:48 +07:00
let fix _id = item . has ( "fixID" ) && item . get ( "fixID" ) ;
let elemental _format = false ;
for ( let i = 0 ; i < display _commands . length ; i ++ ) {
const command = display _commands [ i ] ;
2021-10-26 18:43:51 +07:00
if ( command . charAt ( 0 ) === "!" ) {
2021-10-17 22:53:48 +07:00
// TODO: This is sooo incredibly janky.....
if ( command === "!elemental" ) {
elemental _format = ! elemental _format ;
2021-10-26 18:43:51 +07:00
}
else if ( command === "!spacer" ) {
let spacer = document . createElement ( 'div' ) ;
spacer . classList . add ( "row" , "my-2" ) ;
parent _div . appendChild ( spacer ) ;
continue ;
}
2021-10-17 22:53:48 +07:00
}
else {
let id = command ;
if ( nonRolledIDs . includes ( id ) ) { //nonRolledID & non-0/non-null/non-und ID
if ( ! item . get ( id ) ) {
if ( ! ( item . get ( "crafted" ) && skp _order . includes ( id ) &&
( item . get ( "maxRolls" ) . get ( id ) || item . get ( "minRolls" ) . get ( id ) ) ) ) {
continue ;
}
}
if ( id === "slots" ) {
2021-10-26 18:43:51 +07:00
let p _elem = document . createElement ( "div" ) ;
p _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
// PROPER POWDER DISPLAYING
let numerals = new Map ( [ [ 1 , "I" ] , [ 2 , "II" ] , [ 3 , "III" ] , [ 4 , "IV" ] , [ 5 , "V" ] , [ 6 , "VI" ] ] ) ;
let powderPrefix = document . createElement ( "b" ) ;
powderPrefix . textContent = "Powder Slots: " + item . get ( id ) + " [" ;
p _elem . appendChild ( powderPrefix ) ;
let powders = item . get ( "powders" ) ;
for ( let i = 0 ; i < powders . length ; i ++ ) {
let powder = document . createElement ( "b" ) ;
powder . textContent = numerals . get ( ( powders [ i ] % 6 ) + 1 ) + " " ;
powder . classList . add ( damageClasses [ Math . floor ( powders [ i ] / 6 ) + 1 ] + "_powder" ) ;
p _elem . appendChild ( powder ) ;
}
let powderSuffix = document . createElement ( "b" ) ;
powderSuffix . textContent = "]" ;
p _elem . appendChild ( powderSuffix ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( p _elem ) ;
2021-10-17 22:53:48 +07:00
} else if ( id === "set" ) {
if ( item . get ( "hideSet" ) ) { continue ; }
2021-10-26 18:43:51 +07:00
let p _elem = document . createElement ( "div" ) ;
p _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
p _elem . textContent = "Set: " + item . get ( id ) . toString ( ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( p _elem ) ;
2021-10-17 22:53:48 +07:00
} else if ( id === "majorIds" ) {
2022-01-07 00:12:00 -08:00
//console.log(item.get(id));
2021-10-17 22:53:48 +07:00
for ( let majorID of item . get ( id ) ) {
2021-10-26 18:43:51 +07:00
let p _elem = document . createElement ( "div" ) ;
p _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
let title _elem = document . createElement ( "b" ) ;
let b _elem = document . createElement ( "b" ) ;
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 ) ;
}
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( p _elem ) ;
2021-10-17 22:53:48 +07:00
}
} else if ( id === "lvl" && item . get ( "tier" ) === "Crafted" ) {
2021-10-26 18:43:51 +07:00
let p _elem = document . createElement ( "div" ) ;
2022-05-12 01:48:59 -07:00
p _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
p _elem . textContent = "Combat Level Min: " + item . get ( "lvlLow" ) + "-" + item . get ( id ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( p _elem ) ;
2021-10-17 22:53:48 +07:00
} else if ( id === "displayName" ) {
2022-01-07 00:12:00 -08:00
let row = document . createElement ( "div" ) ;
2022-05-19 01:54:26 -07:00
let a _elem = document . createElement ( "a" ) ;
row . classList . add ( "row" , "justify-content-center" ) ;
a _elem . classList . add ( "col-auto" , "text-center" , "item-title" , "p-0" ) ;
a _elem . classList . add ( item . has ( "tier" ) ? item . get ( "tier" ) . replace ( " " , "" ) : "Normal" ) ;
// a_elem.style.textGrow = 1;
2022-05-12 16:41:45 -07:00
2022-05-19 01:54:26 -07:00
row . appendChild ( a _elem ) ;
2022-05-12 16:41:45 -07: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
* /
2022-01-07 00:12:00 -08:00
//allow the plus minus element to toggle upon click: ➕ ➖
2022-05-12 16:41:45 -07: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-01-07 00:12:00 -08:00
2021-10-17 22:53:48 +07:00
if ( item . get ( "custom" ) ) {
2022-05-19 01:54:26 -07:00
a _elem . href = "../custom/#" + item . get ( "hash" ) ;
a _elem . textContent = item . get ( "displayName" ) ;
} else if ( item . get ( "crafted" ) ) {
a _elem . href = "../crafter/#" + item . get ( "hash" ) ;
a _elem . textContent = item . get ( id ) ;
} else {
a _elem . href = "../item/#" + item . get ( "displayName" ) ;
a _elem . textContent = item . get ( "displayName" ) ;
}
parent _div . appendChild ( row ) ;
let nolink _row = document . createElement ( "div" ) ;
let p _elem = document . createElement ( "p" ) ;
nolink _row . classList . add ( "row" , "justify-content-center" ) ;
nolink _row . style . display = "none" ;
p _elem . classList . add ( "col-auto" , "text-center" , "item-title" , "p-0" ) ;
p _elem . classList . add ( item . has ( "tier" ) ? item . get ( "tier" ) . replace ( " " , "" ) : "Normal" ) ;
if ( item . get ( "custom" ) ) {
2021-10-17 22:53:48 +07:00
p _elem . textContent = item . get ( "displayName" ) ;
} else if ( item . get ( "crafted" ) ) {
p _elem . textContent = item . get ( id ) ;
} else {
p _elem . textContent = item . get ( "displayName" ) ;
}
2022-05-19 01:54:26 -07:00
nolink _row . appendChild ( p _elem ) ;
parent _div . appendChild ( nolink _row ) ;
2022-01-07 00:12:00 -08:00
2021-10-17 22:53:48 +07:00
let img = document . createElement ( "img" ) ;
if ( item && item . has ( "type" ) ) {
2022-05-12 01:48:59 -07:00
img . src = "../media/items/" + ( newIcons ? "new/" : "old/" ) + "generic-" + item . get ( "type" ) + ".png" ;
2021-10-17 22:53:48 +07:00
img . alt = item . get ( "type" ) ;
2021-10-29 15:08:36 +07:00
img . style = " z=index: 1; position: relative;" ;
2022-01-07 00:12:00 -08:00
let container = document . createElement ( "div" ) ;
2021-10-26 18:43:51 +07:00
let bckgrd = document . createElement ( "div" ) ;
2022-01-07 00:12:00 -08:00
bckgrd . classList . add ( "col" , "px-0" , "d-flex" , "align-items-center" , "justify-content-center" ) ; // , "no-collapse");
2021-10-29 15:08:36 +07:00
bckgrd . 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;"
bckgrd . classList . add ( "scaled-bckgrd" ) ;
2022-01-07 00:12:00 -08:00
parent _div . appendChild ( container ) ;
container . appendChild ( bckgrd ) ;
2021-10-17 22:53:48 +07:00
bckgrd . appendChild ( img ) ;
}
} else {
let p _elem ;
2021-10-26 18:43:51 +07: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 = displaysq2FixedID ( parent _div , id , item . get ( id ) , elemental _format ) ;
2021-10-17 22:53:48 +07:00
} else if ( item . get ( "tier" ) === "Crafted" && item . get ( "category" ) === "armor" && id === "hp" ) {
2021-10-26 18:43:51 +07:00
p _elem = displaysq2FixedID ( parent _div , id , item . get ( id + "Low" ) + "-" + item . get ( id ) , elemental _format ) ;
2021-10-17 22:53:48 +07:00
}
if ( id === "lore" ) {
p _elem . style = "font-style: italic" ;
} else if ( skp _order . includes ( id ) ) { //id = str, dex, int, def, or agi
2022-05-16 13:02:09 -07:00
if ( item . get ( "tier" ) !== "Crafted" ) {
2021-10-26 18:43:51 +07:00
row = document . createElement ( "div" ) ;
row . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07: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 ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( row ) ;
2022-05-16 13:02:09 -07:00
} else if ( item . get ( "tier" ) === "Crafted" ) {
2021-10-18 07:25:02 +07:00
let row = displaysq2RolledID ( item , id , elemental _format ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( row ) ;
2021-10-17 22:53:48 +07:00
}
} else if ( id === "restrict" ) {
p _elem . classList . add ( "restrict" ) ;
}
}
}
else if ( rolledIDs . includes ( id ) &&
( ( item . get ( "maxRolls" ) && item . get ( "maxRolls" ) . get ( id ) )
|| ( item . get ( "minRolls" ) && item . get ( "minRolls" ) . get ( id ) ) ) ) {
let style = "positive" ;
if ( item . get ( "minRolls" ) . get ( id ) < 0 ) {
style = "negative" ;
}
if ( reversedIDs . includes ( id ) ) {
style === "positive" ? style = "negative" : style = "positive" ;
}
if ( fix _id ) {
2021-10-26 18:43:51 +07:00
p _elem = document . createElement ( "div" ) ;
p _elem . classList . add ( "col" , "text-nowrap" ) ;
if ( id == "dex" ) {
console . log ( "dex activated at fix_id" )
}
displaysq2FixedID ( p _elem , id , item . get ( "minRolls" ) . get ( id ) , elemental _format , style ) ;
parent _div . appendChild ( p _elem ) ;
2021-10-17 22:53:48 +07:00
}
else {
2021-10-18 07:25:02 +07:00
let row = displaysq2RolledID ( item , id , elemental _format ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( row ) ;
2021-10-17 22:53:48 +07:00
}
} else {
// :/
}
}
}
//Show powder specials ;-;
let nonConsumables = [ "relik" , "wand" , "bow" , "spear" , "dagger" , "chestplate" , "helmet" , "leggings" , "boots" , "ring" , "bracelet" , "necklace" ] ;
if ( nonConsumables . includes ( item . get ( "type" ) ) ) {
2021-10-26 18:43:51 +07:00
let powder _special = document . createElement ( "div" ) ;
powder _special . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
let powders = item . get ( "powders" ) ;
let element = "" ;
let power = 0 ;
for ( let i = 0 ; i < powders . length ; i ++ ) {
let firstPowderType = skp _elements [ Math . floor ( powders [ i ] / 6 ) ] ;
if ( element !== "" ) break ;
else if ( powders [ i ] % 6 > 2 ) { //t4+
for ( let j = i + 1 ; j < powders . length ; j ++ ) {
let currentPowderType = skp _elements [ Math . floor ( powders [ j ] / 6 ) ]
if ( powders [ j ] % 6 > 2 && firstPowderType === currentPowderType ) {
element = currentPowderType ;
power = Math . round ( ( ( powders [ i ] % 6 + powders [ j ] % 6 + 2 ) / 2 - 4 ) * 2 ) ;
break ;
}
}
}
}
if ( element !== "" ) { //powder special is "[e,t,w,f,a]+[0,1,2,3,4]"
let powderSpecial = powderSpecialStats [ skp _elements . indexOf ( element ) ] ;
let specialSuffixes = new Map ( [ [ "Duration" , " sec" ] , [ "Radius" , " blocks" ] , [ "Chains" , "" ] , [ "Damage" , "%" ] , [ "Damage Boost" , "%" ] , [ "Knockback" , " blocks" ] ] ) ;
2021-10-26 18:43:51 +07:00
let specialTitle = document . createElement ( "span" ) ;
let specialEffects = document . createElement ( "span" ) ;
addClasses ( specialTitle , [ damageClasses [ skp _elements . indexOf ( element ) + 1 ] ] ) ;
2021-10-17 22:53:48 +07:00
let effects ;
if ( item . get ( "category" ) === "weapon" ) { //weapon
effects = powderSpecial [ "weaponSpecialEffects" ] ;
specialTitle . textContent = powderSpecial [ "weaponSpecialName" ] ;
} else if ( item . get ( "category" ) === "armor" ) { //armor
effects = powderSpecial [ "armorSpecialEffects" ] ;
specialTitle . textContent += powderSpecial [ "armorSpecialName" ] + ": " ;
}
for ( const [ key , value ] of effects . entries ( ) ) {
if ( key !== "Description" ) {
let effect = document . createElement ( "p" ) ;
2021-10-26 18:43:51 +07:00
effect . classList . add ( "m-0" ) ;
2021-10-17 22:53:48 +07:00
effect . textContent = key + ": " + value [ power ] + specialSuffixes . get ( key ) ;
if ( key === "Damage" ) {
effect . textContent += elementIcons [ skp _elements . indexOf ( element ) ] ;
}
if ( element === "w" && item . get ( "category" ) === "armor" ) {
effect . textContent += " / Mana Used" ;
}
specialEffects . appendChild ( effect ) ;
} else {
specialTitle . textContent += "[ " + effects . get ( "Description" ) + " ]" ;
}
}
powder _special . appendChild ( specialTitle ) ;
powder _special . appendChild ( specialEffects ) ;
parent _div . appendChild ( powder _special ) ;
}
}
if ( item . get ( "tier" ) && item . get ( "tier" ) === "Crafted" ) {
2021-10-26 18:43:51 +07:00
let dura _elem = document . createElement ( "div" ) ;
dura _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
let dura = [ ] ;
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."
let charges = document . createElement ( "b" ) ;
charges . textContent = "Charges: " + item . get ( "charges" ) ;
2021-10-26 18:43:51 +07:00
parent _div . appendChild ( charges ) ;
2021-10-17 22:53:48 +07:00
}
if ( typeof ( dura ) === "string" ) {
dura _elem . textContent += dura + suffix ;
} else {
dura _elem . textContent += dura [ 0 ] + "-" + dura [ 1 ] + suffix ;
}
2021-10-26 18:43:51 +07:00
parent _div . append ( dura _elem ) ;
2021-10-17 22:53:48 +07:00
}
//Show item tier
if ( item . get ( "tier" ) && item . get ( "tier" ) !== " " ) {
2021-10-26 18:43:51 +07:00
let item _desc _elem = document . createElement ( "div" ) ;
item _desc _elem . classList . add ( "col" ) ;
2021-10-17 22:53:48 +07:00
item _desc _elem . classList . add ( item . get ( "tier" ) ) ;
2022-05-20 02:03:46 -07: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" ) ;
}
2021-10-26 18:43:51 +07:00
parent _div . append ( item _desc _elem ) ;
2021-10-17 22:53:48 +07:00
}
//Show item hash if applicable
if ( item . get ( "crafted" ) || item . get ( "custom" ) ) {
let item _desc _elem = document . createElement ( "p" ) ;
item _desc _elem . classList . add ( 'itemp' ) ;
item _desc _elem . style . maxWidth = "100%" ;
item _desc _elem . style . wordWrap = "break-word" ;
item _desc _elem . style . wordBreak = "break-word" ;
item _desc _elem . textContent = item . get ( "hash" ) ;
2021-10-26 18:43:51 +07:00
parent _div . append ( item _desc _elem ) ;
2021-10-17 22:53:48 +07:00
}
if ( item . get ( "category" ) === "weapon" ) {
let damage _mult = baseDamageMultiplier [ attackSpeeds . indexOf ( item . get ( "atkSpd" ) ) ] ;
let total _damages = item . get ( "basedps" ) ;
let base _dps _elem = document . createElement ( "p" ) ;
base _dps _elem . classList . add ( "left" ) ;
base _dps _elem . classList . add ( "itemp" ) ;
if ( item . get ( "tier" ) === "Crafted" ) {
let base _dps _min = total _damages [ 0 ] * damage _mult ;
let base _dps _max = total _damages [ 1 ] * damage _mult ;
base _dps _elem . textContent = "Base DPS: " + base _dps _min . toFixed ( 3 ) + "\u279c" + base _dps _max . toFixed ( 3 ) ;
}
else {
2022-05-21 22:58:04 -07:00
let bdps = total _damages * damage _mult ;
base _dps _elem . textContent = "Base DPS: " + ( bdps ? bdps : 0 ) ;
2021-10-17 22:53:48 +07:00
}
parent _div . appendChild ( document . createElement ( "p" ) ) ;
parent _div . appendChild ( base _dps _elem ) ;
}
}
2021-10-18 07:25:02 +07:00
function displaysq2RolledID ( item , id , elemental _format ) {
2021-10-26 18:43:51 +07: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' ) ;
2022-01-06 11:18:44 -08:00
min _elem . style . cssText += "flex-grow: 0" ;
2021-10-17 22:53:48 +07: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 ] ;
2021-10-26 18:43:51 +07:00
item _div . appendChild ( min _elem ) ;
2021-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
let desc _elem = document . createElement ( 'div' ) ;
2022-01-06 11:18:44 -08:00
desc _elem . classList . add ( 'col' , 'text-center' ) ; //, 'text-nowrap');
desc _elem . style . cssText += "flex-grow: 1" ;
2021-10-17 22:53:48 +07:00
//TODO elemental format jank
if ( elemental _format ) {
2021-10-27 20:51:37 +07:00
apply _sq2 _elemental _format ( desc _elem , id ) ;
2021-10-17 22:53:48 +07:00
}
else {
desc _elem . textContent = idPrefixes [ id ] ;
}
2021-10-26 18:43:51 +07:00
item _div . appendChild ( desc _elem ) ;
2021-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
let max _elem = document . createElement ( 'div' ) ;
2021-10-17 22:53:48 +07:00
let id _max = item . get ( "maxRolls" ) . get ( id )
2021-10-26 18:43:51 +07:00
max _elem . classList . add ( 'col' , 'text-end' ) ;
2022-01-06 11:18:44 -08:00
max _elem . style . cssText += "flex-grow: 0" ;
2021-10-17 22:53:48 +07:00
style = id _max < 0 ? "negative" : "positive" ;
2022-01-06 11:18:44 -08:00
if ( reversedIDs . includes ( id ) ) {
2021-10-17 22:53:48 +07:00
style === "positive" ? style = "negative" : style = "positive" ;
}
max _elem . classList . add ( style ) ;
max _elem . textContent = id _max + idSuffixes [ id ] ;
2021-10-26 18:43:51 +07:00
item _div . appendChild ( max _elem ) ;
row . appendChild ( item _div ) ;
2021-10-17 22:53:48 +07:00
return row ;
}
2022-01-07 00:12:00 -08:00
function displaysq2WeaponStats ( build ) {
2021-10-17 22:53:48 +07:00
// let base_damage = build.get('damageRaw');
let damage _keys = [ "nDam" , "eDam" , "tDam" , "wDam" , "fDam" , "aDam" ] ;
// pP base calc (why do i still use pP)
let item = build . weapon ;
let stats = new Map ( ) ;
stats . set ( "atkSpd" , item . get ( "atkSpd" ) ) ;
stats . set ( "damageBonus" , [ 0 , 0 , 0 , 0 , 0 ] ) ;
stats . set ( "damageRaw" , [ item . get ( "nDam" ) , item . get ( "eDam" ) , item . get ( "tDam" ) , item . get ( "wDam" ) , item . get ( "fDam" ) , item . get ( "aDam" ) ] ) ;
let results = calculateSpellDamage ( stats , [ 100 , 0 , 0 , 0 , 0 , 0 ] , 0 , 0 , 0 , build . weapon , [ 0 , 0 , 0 , 0 , 0 ] , 1 , undefined ) ;
let powdered _base = results [ 2 ] ;
const powdered _map = new Map ( ) ;
powdered _map . set ( 'nDam' , powdered _base [ 0 ] [ 0 ] + '-' + powdered _base [ 0 ] [ 1 ] ) ;
powdered _map . set ( 'eDam' , powdered _base [ 1 ] [ 0 ] + '-' + powdered _base [ 1 ] [ 1 ] ) ;
powdered _map . set ( 'tDam' , powdered _base [ 2 ] [ 0 ] + '-' + powdered _base [ 2 ] [ 1 ] ) ;
powdered _map . set ( 'wDam' , powdered _base [ 3 ] [ 0 ] + '-' + powdered _base [ 3 ] [ 1 ] ) ;
powdered _map . set ( 'fDam' , powdered _base [ 4 ] [ 0 ] + '-' + powdered _base [ 4 ] [ 1 ] ) ;
powdered _map . set ( 'aDam' , powdered _base [ 5 ] [ 0 ] + '-' + powdered _base [ 5 ] [ 1 ] ) ;
// display
2022-01-07 00:12:00 -08:00
//I think this is res's code? in any case it doesn't work - ferri
/ * f o r ( c o n s t i i n d a m a g e _ k e y s ) {
2021-10-17 22:53:48 +07:00
document . getElementById ( damage _keys [ i ] + "-base" ) . textContent = powdered _map . get ( damage _keys [ i ] ) ;
2022-01-07 00:12:00 -08:00
} * /
let tot = 0 ;
//sum up elemental damages to get sum of base dps's
for ( let i = 0 ; i < 6 ; i ++ ) {
tot += powdered _base [ i ] [ 0 ] + powdered _base [ i ] [ 1 ] ;
}
tot /= 2 ;
let dps = Math . max ( 0 , Math . round ( tot * baseDamageMultiplier [ attackSpeeds . indexOf ( item . get ( "atkSpd" ) ) ] ) ) ; //atkspeeds
2022-05-21 22:58:04 -07:00
document . getElementById ( "weapon-dps" ) . textContent = "base dps: " + ( isNaN ( dps ) ? 0 : dps ) ;
2022-01-07 00:12:00 -08:00
document . getElementById ( "weapon-lv" ) . textContent = item . get ( "lvl" ) ;
if ( item . get ( "type" ) ) {
2022-05-12 01:48:59 -07:00
document . getElementById ( "weapon-img" ) . src = "../media/items/" + ( newIcons ? "new/" : "old/" ) + "generic-" + item . get ( "type" ) + ".png" ;
2021-10-17 22:53:48 +07:00
}
}
2021-10-18 07:25:02 +07:00
function displaysq2FixedID ( active , id , value , elemental _format , style ) {
2021-10-17 22:53:48 +07:00
if ( style ) {
2021-10-21 21:11:04 +07: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-10-17 22:53:48 +07:00
if ( elemental _format ) {
2021-10-27 20:51:37 +07:00
apply _sq2 _elemental _format ( desc _elem , id ) ;
2021-10-17 22:53:48 +07:00
}
else {
desc _elem . textContent = idPrefixes [ id ] ;
}
row . appendChild ( desc _elem ) ;
2021-10-21 21:11:04 +07:00
let value _elem = document . createElement ( 'div' ) ;
value _elem . classList . add ( 'col' ) ;
value _elem . classList . add ( 'text-end' ) ;
2021-10-17 22:53:48 +07: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
if ( value === "0-0" || value === "0-0\u279c0-0" ) {
return ;
}
2021-10-26 18:43:51 +07:00
let p _elem = document . createElement ( 'div' ) ;
p _elem . classList . add ( 'col' ) ;
2021-10-17 22:53:48 +07:00
if ( elemental _format ) {
2021-10-27 20:51:37 +07:00
apply _sq2 _elemental _format ( p _elem , id , value ) ;
2021-10-17 22:53:48 +07:00
}
else {
p _elem . textContent = idPrefixes [ id ] . concat ( value , idSuffixes [ id ] ) ;
}
active . appendChild ( p _elem ) ;
return p _elem ;
}
}
2021-10-18 07:25:02 +07:00
function displaysq2PoisonDamage ( overallparent _elem , build ) {
2021-10-17 22:53:48 +07:00
overallparent _elem . textContent = "" ;
//Title
2021-10-21 21:11:04 +07:00
let title _elemavg = document . createElement ( "b" ) ;
2021-10-17 22:53:48 +07:00
title _elemavg . textContent = "Poison Stats" ;
overallparent _elem . append ( title _elemavg ) ;
let overallpoisonDamage = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let overallpoisonDamageFirst = document . createElement ( "span" ) ;
let overallpoisonDamageSecond = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
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 ) ;
overallpoisonDamageSecond . classList . add ( "Damage" ) ;
overallpoisonDamage . appendChild ( overallpoisonDamageFirst ) ;
overallpoisonDamage . appendChild ( overallpoisonDamageSecond ) ;
overallparent _elem . append ( overallpoisonDamage ) ;
}
2021-10-18 07:25:02 +07:00
function displaysq2MeleeDamage ( parent _elem , overallparent _elem , meleeStats ) {
2021-10-21 21:11:04 +07:00
// console.log("Melee Stats");
// console.log(meleeStats);
2021-10-17 22:53:48 +07:00
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: "];
parent _elem . textContent = "" ;
overallparent _elem . textContent = "" ;
const stats = meleeStats . slice ( ) ;
for ( let i = 0 ; i < 6 ; ++ i ) {
for ( let j in stats [ i ] ) {
stats [ i ] [ j ] = stats [ i ] [ j ] . toFixed ( 2 ) ;
}
}
for ( let i = 6 ; i < 8 ; ++ i ) {
for ( let j = 0 ; j < 2 ; j ++ ) {
stats [ i ] [ j ] = stats [ i ] [ j ] . toFixed ( 2 ) ;
}
}
for ( let i = 8 ; i < 11 ; ++ i ) {
stats [ i ] = stats [ i ] . toFixed ( 2 ) ;
}
//tooltipelem, tooltiptext
let tooltip ; let tooltiptext ;
//title
let title _elem = document . createElement ( "p" ) ;
title _elem . classList . add ( "title" ) ;
title _elem . textContent = "Melee Stats" ;
parent _elem . append ( title _elem ) ;
parent _elem . append ( document . createElement ( "br" ) ) ;
//overall title
2021-10-21 21:11:04 +07:00
let title _elemavg = document . createElement ( "b" ) ;
2021-10-17 22:53:48 +07:00
title _elemavg . textContent = "Melee Stats" ;
overallparent _elem . append ( title _elemavg ) ;
//average DPS
let averageDamage = document . createElement ( "p" ) ;
averageDamage . classList . add ( "left" ) ;
averageDamage . textContent = "Average DPS: " + stats [ 10 ] ;
tooltiptext = ` = (( ${ stats [ 8 ] } * ${ ( stats [ 6 ] [ 2 ] ) . toFixed ( 2 ) } ) + ( ${ stats [ 9 ] } * ${ ( stats [ 7 ] [ 2 ] ) . toFixed ( 2 ) } )) `
tooltip = createTooltip ( tooltip , "p" , tooltiptext , averageDamage , [ "melee-tooltip" ] ) ;
averageDamage . appendChild ( tooltip ) ;
parent _elem . append ( averageDamage ) ;
//overall average DPS
let overallaverageDamage = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let overallaverageDamageFirst = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
overallaverageDamageFirst . textContent = "Average DPS: "
2021-10-21 21:11:04 +07:00
let overallaverageDamageSecond = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
overallaverageDamageSecond . classList . add ( "Damage" ) ;
overallaverageDamageSecond . textContent = stats [ 10 ] ;
overallaverageDamage . appendChild ( overallaverageDamageFirst ) ;
overallaverageDamage . appendChild ( overallaverageDamageSecond ) ;
overallparent _elem . append ( overallaverageDamage ) ;
//overallparent_elem.append(document.createElement("br"));
//attack speed
let atkSpd = document . createElement ( "p" ) ;
atkSpd . classList . add ( "left" ) ;
atkSpd . textContent = "Attack Speed: " + attackSpeeds [ stats [ 11 ] ] ;
parent _elem . append ( atkSpd ) ;
parent _elem . append ( document . createElement ( "br" ) ) ;
//overall attack speed
let overallatkSpd = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let overallatkSpdFirst = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
overallatkSpdFirst . textContent = "Attack Speed: " ;
2021-10-21 21:11:04 +07:00
let overallatkSpdSecond = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
overallatkSpdSecond . classList . add ( "Damage" ) ;
overallatkSpdSecond . textContent = attackSpeeds [ stats [ 11 ] ] ;
overallatkSpd . appendChild ( overallatkSpdFirst ) ;
overallatkSpd . appendChild ( overallatkSpdSecond ) ;
overallparent _elem . append ( overallatkSpd ) ;
//Non-Crit: n->elem, total dmg, DPS
let nonCritStats = document . createElement ( "p" ) ;
nonCritStats . classList . add ( "left" ) ;
nonCritStats . textContent = "Non-Crit Stats: " ;
nonCritStats . append ( document . createElement ( "br" ) ) ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( stats [ i ] [ 1 ] != 0 ) {
let dmg = document . createElement ( "p" ) ;
dmg . textContent = stats [ i ] [ 0 ] + " \u2013 " + stats [ i ] [ 1 ] ;
dmg . classList . add ( damageClasses [ i ] ) ;
dmg . classList . add ( "itemp" ) ;
tooltiptext = tooltipinfo . get ( "damageformulas" ) [ i ] . slice ( 0 , 2 ) . join ( "\n" ) ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , dmg , [ "melee-tooltip" ] ) ;
nonCritStats . append ( dmg ) ;
}
}
let normalDamage = document . createElement ( "p" ) ;
normalDamage . textContent = "Total: " + stats [ 6 ] [ 0 ] + " \u2013 " + stats [ 6 ] [ 1 ] ;
let tooltiparr = [ "Min: = " , "Max: = " ]
let arr = [ ] ; let arr2 = [ ] ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( stats [ i ] [ 0 ] != 0 ) {
arr . push ( stats [ i ] [ 0 ] ) ;
arr2 . push ( stats [ i ] [ 1 ] ) ;
}
}
tooltiptext = tooltiparr [ 0 ] + arr . join ( " + " ) + "\n" + tooltiparr [ 1 ] + arr2 . join ( " + " ) ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , normalDamage , [ "melee-tooltip" ] ) ;
nonCritStats . append ( normalDamage ) ;
let normalDPS = document . createElement ( "p" ) ;
normalDPS . textContent = "Normal DPS: " + stats [ 8 ] ;
normalDPS . classList . add ( "tooltip" ) ;
tooltiptext = ` = (( ${ stats [ 6 ] [ 0 ] } + ${ stats [ 6 ] [ 1 ] } ) / 2) * ${ baseDamageMultiplier [ stats [ 11 ] ] } ` ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , normalDPS , [ "melee-tooltip" ] ) ;
nonCritStats . append ( normalDPS ) ;
//overall average DPS
let singleHitDamage = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let singleHitDamageFirst = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
singleHitDamageFirst . textContent = "Single Hit Average: " ;
2021-10-21 21:11:04 +07:00
let singleHitDamageSecond = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
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 ) } ` ;
// tooltip = createTooltip(tooltip, "p", tooltiptext, singleHitDamage, ["melee-tooltip", "summary-tooltip"]);
singleHitDamage . appendChild ( singleHitDamageFirst ) ;
singleHitDamage . appendChild ( singleHitDamageSecond ) ;
overallparent _elem . append ( singleHitDamage ) ;
let normalChance = document . createElement ( "p" ) ;
normalChance . textContent = "Non-Crit Chance: " + ( stats [ 6 ] [ 2 ] * 100 ) . toFixed ( 2 ) + "%" ;
normalChance . append ( document . createElement ( "br" ) ) ;
normalChance . append ( document . createElement ( "br" ) ) ;
nonCritStats . append ( normalChance ) ;
parent _elem . append ( nonCritStats ) ;
parent _elem . append ( document . createElement ( "br" ) ) ;
//Crit: n->elem, total dmg, DPS
let critStats = document . createElement ( "p" ) ;
critStats . classList . add ( "left" ) ;
critStats . textContent = "Crit Stats: " ;
critStats . append ( document . createElement ( "br" ) ) ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( stats [ i ] [ 3 ] != 0 ) {
dmg = document . createElement ( "p" ) ;
dmg . textContent = stats [ i ] [ 2 ] + " \u2013 " + stats [ i ] [ 3 ] ;
dmg . classList . add ( damageClasses [ i ] ) ;
dmg . classList . add ( "itemp" ) ;
tooltiptext = tooltipinfo . get ( "damageformulas" ) [ i ] . slice ( 2 , 4 ) . join ( "\n" ) ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , dmg , [ "melee-tooltip" ] ) ;
critStats . append ( dmg ) ;
}
}
let critDamage = document . createElement ( "p" ) ;
critDamage . textContent = "Total: " + stats [ 7 ] [ 0 ] + " \u2013 " + stats [ 7 ] [ 1 ] ;
tooltiparr = [ "Min: = " , "Max: = " ]
arr = [ ] ; arr2 = [ ] ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( stats [ i ] [ 0 ] != 0 ) {
arr . push ( stats [ i ] [ 2 ] ) ;
arr2 . push ( stats [ i ] [ 3 ] ) ;
}
}
tooltiptext = tooltiparr [ 0 ] + arr . join ( " + " ) + "\n" + tooltiparr [ 1 ] + arr2 . join ( " + " ) ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , critDamage , [ "melee-tooltip" ] ) ;
critStats . append ( critDamage ) ;
let critDPS = document . createElement ( "p" ) ;
critDPS . textContent = "Crit DPS: " + stats [ 9 ] ;
tooltiptext = ` = (( ${ stats [ 7 ] [ 0 ] } + ${ stats [ 7 ] [ 1 ] } ) / 2) * ${ baseDamageMultiplier [ stats [ 11 ] ] } ` ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , critDPS , [ "melee-tooltip" ] ) ;
critStats . append ( critDPS ) ;
let critChance = document . createElement ( "p" ) ;
critChance . textContent = "Crit Chance: " + ( stats [ 7 ] [ 2 ] * 100 ) . toFixed ( 2 ) + "%" ;
critChance . append ( document . createElement ( "br" ) ) ;
critChance . append ( document . createElement ( "br" ) ) ;
critStats . append ( critChance ) ;
parent _elem . append ( critStats ) ;
}
2021-10-18 07:25:02 +07:00
function displaysq2ArmorStats ( build ) {
2021-10-17 22:53:48 +07:00
let armor _keys = [ 'helmet' , 'chestplate' , 'leggings' , 'boots' , 'ring1' , 'ring2' , 'bracelet' , 'necklace' ] ;
for ( const i in armor _keys ) {
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' ) ;
}
}
2021-10-18 07:25:02 +07:00
function displaysq2DefenseStats ( parent _elem , build , insertSummary ) {
2021-10-17 22:53:48 +07:00
let defenseStats = build . getDefenseStats ( ) ;
insertSummary = ( typeof insertSummary !== 'undefined' ) ? insertSummary : false ;
if ( ! insertSummary ) {
parent _elem . textContent = "" ;
}
const stats = defenseStats . slice ( ) ;
// parent_elem.append(document.createElement("br"));
2021-10-21 21:11:04 +07:00
let statsTable = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07: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 ) ;
}
}
}
//total HP
2021-10-21 21:11:04 +07:00
let hpRow = document . createElement ( "div" ) ;
hpRow . classList . add ( 'row' ) ;
let hp = document . createElement ( "div" ) ;
hp . classList . add ( 'col' ) ;
2021-10-17 22:53:48 +07:00
hp . classList . add ( "Health" ) ;
2021-10-21 21:11:04 +07:00
hp . classList . add ( "text-start" ) ;
2021-10-17 22:53:48 +07:00
hp . textContent = "Total HP:" ;
2021-10-21 21:11:04 +07:00
let boost = document . createElement ( "div" ) ;
boost . classList . add ( 'col' ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 0 ] ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
hpRow . appendChild ( hp ) ;
hpRow . append ( boost ) ;
if ( insertSummary ) {
parent _elem . appendChild ( hpRow ) ;
} else {
statsTable . appendChild ( hpRow ) ;
}
let tooltip ; let tooltiptext ;
let defMult = build . statMap . get ( "defMult" ) ;
if ( ! defMult ) { defMult = 1 }
//EHP
2021-10-21 21:11:04 +07: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-10-17 22:53:48 +07:00
ehp . textContent = "Effective HP:" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 1 ] [ 0 ] ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
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"]);
ehpRow . appendChild ( ehp ) ;
ehpRow . append ( boost ) ;
if ( insertSummary ) {
parent _elem . appendChild ( ehpRow )
} else {
statsTable . append ( ehpRow ) ;
}
2021-10-21 21:11:04 +07:00
ehpRow = document . createElement ( "div" ) ;
ehpRow . classList . add ( "row" ) ;
ehp = document . createElement ( "div" ) ;
ehp . classList . add ( "col" ) ;
ehp . classList . add ( "text-start" ) ;
2021-10-17 22:53:48 +07:00
ehp . textContent = "Effective HP (no agi):" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 1 ] [ 1 ] ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
tooltiptext = ` = ${ stats [ 0 ] } / ((1 - ${ skillPointsToPercentage ( build . total _skillpoints [ 3 ] ) . toFixed ( 3 ) } ) * (2 - ${ defMult } ) * (2 - ${ build . defenseMultiplier } )) `
// tooltip = createTooltip(tooltip, "p", tooltiptext, boost, ["def-tooltip"]);
ehpRow . appendChild ( ehp ) ;
ehpRow . append ( boost ) ;
statsTable . append ( ehpRow ) ;
//total HPR
2021-10-21 21:11:04 +07:00
let hprRow = document . createElement ( "div" ) ;
hprRow . classList . add ( "row" )
let hpr = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
hpr . classList . add ( "Health" ) ;
2021-10-21 21:11:04 +07:00
hpr . classList . add ( "col" ) ;
hpr . classList . add ( "text-start" ) ;
2021-10-17 22:53:48 +07:00
hpr . textContent = "HP Regen (Total):" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 2 ] ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
hprRow . appendChild ( hpr ) ;
hprRow . appendChild ( boost ) ;
if ( insertSummary ) {
parent _elem . appendChild ( hprRow ) ;
} else {
statsTable . appendChild ( hprRow ) ;
}
//EHPR
2021-10-21 21:11:04 +07: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-10-17 22:53:48 +07:00
ehpr . textContent = "Effective HP Regen:" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 3 ] [ 0 ] ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
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"]);
ehprRow . appendChild ( ehpr ) ;
ehprRow . append ( boost ) ;
statsTable . append ( ehprRow ) ;
/ *
ehprRow = document . createElement ( "tr" ) ;
ehpr = document . createElement ( "td" ) ;
ehpr . classList . add ( "left" ) ;
ehpr . textContent = "Effective HP Regen (no agi):" ;
boost = document . createElement ( "td" ) ;
boost . textContent = stats [ 3 ] [ 1 ] ;
boost . classList . add ( "right" ) ;
ehprRow . appendChild ( ehpr ) ;
ehprRow . append ( boost ) ;
statsTable . append ( ehprRow ) ; * /
//eledefs
let eledefs = stats [ 5 ] ;
for ( let i = 0 ; i < eledefs . length ; i ++ ) {
2021-10-21 21:11:04 +07:00
let eledefElemRow = document . createElement ( "div" ) ;
eledefElemRow . classList . add ( "row" )
2021-10-17 22:53:48 +07:00
2021-10-21 21:11:04 +07:00
let eledef = document . createElement ( "div" ) ;
eledef . classList . add ( "col" ) ;
eledef . classList . add ( "text-start" ) ;
let eledefTitle = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
eledefTitle . textContent = damageClasses [ i + 1 ] ;
eledefTitle . classList . add ( damageClasses [ i + 1 ] ) ;
2021-10-21 21:11:04 +07:00
let defense = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
defense . textContent = " Def (Total): " ;
eledef . appendChild ( eledefTitle ) ;
eledef . appendChild ( defense ) ;
eledefElemRow . appendChild ( eledef ) ;
2021-10-21 21:11:04 +07:00
let boost = document . createElement ( "div" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = eledefs [ i ] ;
boost . classList . add ( eledefs [ i ] >= 0 ? "positive" : "negative" ) ;
2021-10-21 21:11:04 +07:00
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
let defRaw = build . statMap . get ( "defRaw" ) [ i ] ;
let defPct = build . statMap . get ( "defBonus" ) [ i ] / 100 ;
if ( defRaw < 0 ) {
defPct >= 0 ? defPct = "- " + defPct : defPct = "+ " + defPct ;
tooltiptext = ` = min(0, ${ defRaw } * (1 ${ defPct } )) `
} else {
defPct >= 0 ? defPct = "+ " + defPct : defPct = "- " + defPct ;
tooltiptext = ` = ${ defRaw } * (1 ${ defPct } ) `
}
// tooltip = createTooltip(tooltip, "p", tooltiptext, boost, ["def-tooltip"]);
eledefElemRow . appendChild ( boost ) ;
if ( insertSummary ) {
parent _elem . appendChild ( eledefElemRow ) ;
} else {
statsTable . appendChild ( eledefElemRow ) ;
}
}
if ( ! insertSummary ) {
//skp
2021-10-21 21:11:04 +07: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-10-17 22:53:48 +07:00
defElem . textContent = "Damage Absorbed %:" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 4 ] [ 0 ] + "%" ;
defRow . appendChild ( defElem ) ;
defRow . appendChild ( boost ) ;
statsTable . append ( defRow ) ;
2021-10-21 21:11:04 +07: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-10-17 22:53:48 +07:00
agiElem . textContent = "Dodge Chance %:" ;
2021-10-21 21:11:04 +07:00
boost = document . createElement ( "div" ) ;
boost . classList . add ( "col" ) ;
boost . classList . add ( "text-end" ) ;
2021-10-17 22:53:48 +07:00
boost . textContent = stats [ 4 ] [ 1 ] + "%" ;
agiRow . appendChild ( agiElem ) ;
agiRow . appendChild ( boost ) ;
statsTable . append ( agiRow ) ;
}
if ( ! insertSummary ) {
parent _elem . append ( statsTable ) ;
}
}
2021-10-26 18:43:51 +07:00
function displaysq2PowderSpecials ( parent _elem , powderSpecials , build , overall = false ) {
parent _elem . textContent = ""
let title = document . createElement ( "b" ) ;
title . textContent = "Powder Specials" ;
parent _elem . appendChild ( title ) ;
2021-10-17 22:53:48 +07:00
let specials = powderSpecials . slice ( ) ;
let stats = build . statMap ;
let expandedStats = new Map ( ) ;
//each entry of powderSpecials is [ps, power]
for ( special of specials ) {
//iterate through the special and display its effects.
let powder _special = document . createElement ( "p" ) ;
let specialSuffixes = new Map ( [ [ "Duration" , " sec" ] , [ "Radius" , " blocks" ] , [ "Chains" , "" ] , [ "Damage" , "%" ] , [ "Damage Boost" , "%" ] , [ "Knockback" , " blocks" ] ] ) ;
let specialTitle = document . createElement ( "p" ) ;
let specialEffects = document . createElement ( "p" ) ;
specialTitle . classList . add ( damageClasses [ powderSpecialStats . indexOf ( special [ 0 ] ) + 1 ] ) ;
let effects = special [ 0 ] [ "weaponSpecialEffects" ] ;
let power = special [ 1 ] ;
specialTitle . textContent = special [ 0 ] [ "weaponSpecialName" ] + " " + Math . floor ( ( power - 1 ) * 0.5 + 4 ) + ( power % 2 == 0 ? ".5" : "" ) ;
2021-10-26 18:43:51 +07:00
if ( ! overall || powderSpecialStats . indexOf ( special [ 0 ] ) == 2 || powderSpecialStats . indexOf ( special [ 0 ] ) == 3 || powderSpecialStats . indexOf ( special [ 0 ] ) == 4 ) {
for ( const [ key , value ] of effects ) {
let effect = document . createElement ( "p" ) ;
effect . textContent += key + ": " + value [ power - 1 ] + specialSuffixes . get ( key ) ;
if ( key === "Damage" ) {
effect . textContent += elementIcons [ powderSpecialStats . indexOf ( special [ 0 ] ) ] ;
}
if ( special [ 0 ] [ "weaponSpecialName" ] === "Wind Prison" && key === "Damage Boost" ) {
effect . textContent += " (only 1st hit)" ;
}
specialEffects . appendChild ( effect ) ;
2021-10-17 22:53:48 +07:00
}
}
powder _special . appendChild ( specialTitle ) ;
powder _special . appendChild ( specialEffects ) ;
//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 spells = spell _table [ "powder" ] ;
if ( powderSpecialStats . indexOf ( special [ 0 ] ) == 0 || powderSpecialStats . indexOf ( special [ 0 ] ) == 1 || powderSpecialStats . indexOf ( special [ 0 ] ) == 3 ) { //Quake, Chain Lightning, or Courage
let spell = ( powderSpecialStats . indexOf ( special [ 0 ] ) == 3 ? spells [ 2 ] : spells [ powderSpecialStats . indexOf ( special [ 0 ] ) ] ) ;
let part = spell [ "parts" ] [ 0 ] ;
let _results = calculateSpellDamage ( stats , part . conversion ,
stats . get ( "mdRaw" ) , stats . get ( "mdPct" ) + build . externalStats . get ( "mdPct" ) ,
0 , build . weapon , build . total _skillpoints , build . damageMultiplier * ( ( part . multiplier [ power - 1 ] / 100 ) ) , build . externalStats ) ; //part.multiplier[power] / 100
let critChance = skillPointsToPercentage ( build . total _skillpoints [ 1 ] ) ;
let save _damages = [ ] ;
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 ) ;
}
}
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-10-26 18:43:51 +07: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-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
averageWrap . appendChild ( averageLabel ) ;
averageWrap . appendChild ( averageLabelDmg ) ;
specialDamage . appendChild ( averageWrap ) ;
2021-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
if ( ! overall ) {
let nonCritLabel = document . createElement ( "p" ) ;
nonCritLabel . textContent = "Non-Crit Average: " + nonCritAverage . toFixed ( 2 ) ;
nonCritLabel . classList . add ( "damageSubtitle" ) ;
nonCritLabel . classList . add ( "item-margin" ) ;
specialDamage . append ( nonCritLabel ) ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( results [ i ] [ 1 ] > 0 ) {
let p = document . createElement ( "p" ) ;
p . classList . add ( "damagep" ) ;
p . classList . add ( damageClasses [ i ] ) ;
p . textContent = results [ i ] [ 0 ] + "-" + results [ i ] [ 1 ] ;
specialDamage . append ( p ) ;
}
2021-10-17 22:53:48 +07:00
}
2021-10-26 18:43:51 +07:00
let normalDamage = document . createElement ( "p" ) ;
normalDamage . textContent = "Total: " + totalDamNormal [ 0 ] . toFixed ( 2 ) + "-" + totalDamNormal [ 1 ] . toFixed ( 2 ) ;
normalDamage . classList . add ( "itemp" ) ;
specialDamage . append ( normalDamage ) ;
let nonCritChanceLabel = document . createElement ( "p" ) ;
nonCritChanceLabel . textContent = "Non-Crit Chance: " + ( ( 1 - critChance ) * 100 ) . toFixed ( 2 ) + "%" ;
specialDamage . append ( nonCritChanceLabel ) ;
let critLabel = document . createElement ( "p" ) ;
critLabel . textContent = "Crit Average: " + critAverage . toFixed ( 2 ) ;
critLabel . classList . add ( "damageSubtitle" ) ;
critLabel . classList . add ( "item-margin" ) ;
specialDamage . append ( critLabel ) ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( results [ i ] [ 1 ] > 0 ) {
let p = document . createElement ( "p" ) ;
p . classList . add ( "damagep" ) ;
p . classList . add ( damageClasses [ i ] ) ;
p . textContent = results [ i ] [ 2 ] + "-" + results [ i ] [ 3 ] ;
specialDamage . append ( p ) ;
}
2021-10-17 22:53:48 +07:00
}
2021-10-26 18:43:51 +07:00
let critDamage = document . createElement ( "p" ) ;
critDamage . textContent = "Total: " + totalDamCrit [ 0 ] . toFixed ( 2 ) + "-" + totalDamCrit [ 1 ] . toFixed ( 2 ) ;
critDamage . classList . add ( "itemp" ) ;
specialDamage . append ( critDamage ) ;
2021-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
let critChanceLabel = document . createElement ( "p" ) ;
critChanceLabel . textContent = "Crit Chance: " + ( critChance * 100 ) . toFixed ( 2 ) + "%" ;
specialDamage . append ( critChanceLabel ) ;
2021-10-17 22:53:48 +07:00
2021-10-26 18:43:51 +07:00
save _damages . push ( averageDamage ) ;
}
2021-10-17 22:53:48 +07:00
powder _special . append ( specialDamage ) ;
}
parent _elem . appendChild ( powder _special ) ;
}
}
2021-10-18 07:25:02 +07:00
function displaysq2SpellDamage ( parent _elem , overallparent _elem , build , spell , spellIdx ) {
2021-10-17 22:53:48 +07:00
parent _elem . textContent = "" ;
let tooltip ; let tooltiptext ;
const stats = build . statMap ;
let title _elem = document . createElement ( "p" ) ;
overallparent _elem . textContent = "" ;
2021-10-21 21:11:04 +07:00
let title _elemavg = document . createElement ( "b" ) ;
2021-10-17 22:53:48 +07:00
if ( spellIdx != 0 ) {
2021-10-21 21:11:04 +07:00
let first = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
first . textContent = spell . title + " (" ;
title _elem . appendChild ( first . cloneNode ( true ) ) ; //cloneNode is needed here.
title _elemavg . appendChild ( first ) ;
2021-10-21 21:11:04 +07:00
let second = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
second . textContent = build . getSpellCost ( spellIdx , spell . cost ) ;
second . classList . add ( "Mana" ) ;
let int _redux = skillPointsToPercentage ( build . total _skillpoints [ 2 ] ) . toFixed ( 2 ) ;
let spPct _redux = ( build . statMap . get ( "spPct" + spellIdx ) / 100 ) . toFixed ( 2 ) ;
let spRaw _redux = ( build . statMap . get ( "spRaw" + spellIdx ) ) . toFixed ( 2 ) ;
spPct _redux >= 0 ? spPct _redux = "+ " + spPct _redux : spPct _redux = "- " + Math . abs ( spPct _redux ) ;
spRaw _redux >= 0 ? spRaw _redux = "+ " + spRaw _redux : spRaw _redux = "- " + Math . abs ( spRaw _redux ) ;
// tooltiptext = `= max(1, floor((ceil(${spell.cost} * (1 - ${int_redux})) ${spRaw_redux}) * (1 ${spPct_redux})))`;
// tooltip = createTooltip(tooltip, "p", tooltiptext, second, ["spellcostcalc"]);
// second.appendChild(tooltip);
title _elem . appendChild ( second . cloneNode ( true ) ) ;
title _elemavg . appendChild ( second ) ;
2021-10-26 20:21:06 +07:00
let third = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
third . textContent = ") [Base: " + build . getBaseSpellCost ( spellIdx , spell . cost ) + " ]" ;
title _elem . appendChild ( third ) ;
2021-10-21 21:11:04 +07:00
let third _summary = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
third _summary . textContent = ")" ;
title _elemavg . appendChild ( third _summary ) ;
}
else {
title _elem . textContent = spell . title ;
title _elemavg . textContent = spell . title ;
}
parent _elem . append ( title _elem ) ;
overallparent _elem . append ( title _elemavg ) ;
2021-10-27 20:51:37 +07:00
overallparent _elem . append ( displaysq2NextCosts ( spell , build ) ) ;
2021-10-17 22:53:48 +07:00
let critChance = skillPointsToPercentage ( build . total _skillpoints [ 1 ] ) ;
let save _damages = [ ] ;
let part _divavg = document . createElement ( "p" ) ;
overallparent _elem . append ( part _divavg ) ;
let spell _parts ;
if ( spell . parts ) {
spell _parts = spell . parts ;
}
else {
spell _parts = spell . variants . DEFAULT ;
for ( const majorID of stats . get ( "activeMajorIDs" ) ) {
if ( majorID in spell . variants ) {
spell _parts = spell . variants [ majorID ] ;
break ;
}
}
}
//console.log(spell_parts);
for ( const part of spell _parts ) {
let part _div = document . createElement ( "p" ) ;
parent _elem . append ( part _div ) ;
let subtitle _elem = document . createElement ( "p" ) ;
subtitle _elem . textContent = part . subtitle ;
part _div . append ( subtitle _elem ) ;
if ( part . type === "damage" ) {
//console.log(build.expandedStats);
let _results = calculateSpellDamage ( stats , part . conversion ,
stats . get ( "sdRaw" ) + stats . get ( "rainbowRaw" ) , stats . get ( "sdPct" ) + build . externalStats . get ( "sdPct" ) ,
part . multiplier / 100 , build . weapon , build . total _skillpoints , build . damageMultiplier , build . externalStats ) ;
let totalDamNormal = _results [ 0 ] ;
let totalDamCrit = _results [ 1 ] ;
let results = _results [ 2 ] ;
let tooltipinfo = _results [ 3 ] ;
for ( let i = 0 ; i < 6 ; ++ i ) {
for ( let j in results [ i ] ) {
results [ i ] [ j ] = results [ i ] [ j ] . toFixed ( 2 ) ;
}
}
let nonCritAverage = ( totalDamNormal [ 0 ] + totalDamNormal [ 1 ] ) / 2 || 0 ;
let critAverage = ( totalDamCrit [ 0 ] + totalDamCrit [ 1 ] ) / 2 || 0 ;
let averageDamage = ( 1 - critChance ) * nonCritAverage + critChance * critAverage || 0 ;
let averageLabel = document . createElement ( "p" ) ;
averageLabel . textContent = "Average: " + averageDamage . toFixed ( 2 ) ;
tooltiptext = ` = ((1 - ${ critChance } ) * ${ nonCritAverage . toFixed ( 2 ) } ) + ( ${ critChance } * ${ critAverage . toFixed ( 2 ) } ) `
// averageLabel.classList.add("damageSubtitle");
// tooltip = createTooltip(tooltip, "p", tooltiptext, averageLabel, ["spell-tooltip"]);
part _div . append ( averageLabel ) ;
if ( part . summary == true ) {
let overallaverageLabel = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let first = document . createElement ( "span" ) ;
let second = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
first . textContent = part . subtitle + " Average: " ;
second . textContent = averageDamage . toFixed ( 2 ) ;
overallaverageLabel . appendChild ( first ) ;
overallaverageLabel . appendChild ( second ) ;
// tooltip = createTooltip(tooltip, "p", tooltiptext, overallaverageLabel, ["spell-tooltip", "summary-tooltip"]);
second . classList . add ( "Damage" ) ;
part _divavg . append ( overallaverageLabel ) ;
}
function _damage _display ( label _text , average , result _idx ) {
let label = document . createElement ( "p" ) ;
label . textContent = label _text + average . toFixed ( 2 ) ;
part _div . append ( label ) ;
let arrmin = [ ] ;
let arrmax = [ ] ;
for ( let i = 0 ; i < 6 ; i ++ ) {
if ( results [ i ] [ 1 ] != 0 ) {
let p = document . createElement ( "p" ) ;
p . classList . add ( damageClasses [ i ] ) ;
p . textContent = results [ i ] [ result _idx ] + " \u2013 " + results [ i ] [ result _idx + 1 ] ;
arrmin . push ( results [ i ] [ result _idx ] ) ;
arrmax . push ( results [ i ] [ result _idx + 1 ] ) ;
part _div . append ( p ) ;
}
}
tooltiptext = ` = (( ${ arrmin . join ( " + " ) } ) + ( ${ arrmax . join ( " + " ) } )) / 2 ` ;
// tooltip = createTooltip(tooltip, "p", tooltiptext, label, ["spell-tooltip"]);
}
_damage _display ( "Non-Crit Average: " , nonCritAverage , 0 ) ;
_damage _display ( "Crit Average: " , critAverage , 2 ) ;
save _damages . push ( averageDamage ) ;
} else if ( part . type === "heal" ) {
let heal _amount = ( part . strength * build . getDefenseStats ( ) [ 0 ] * Math . max ( 0.5 , Math . min ( 1.75 , 1 + 0.5 * stats . get ( "wDamPct" ) / 100 ) ) ) . toFixed ( 2 ) ;
tooltiptext = ` = ${ part . strength } * ${ build . getDefenseStats ( ) [ 0 ] } * max(0.5, min(1.75, 1 + 0.5 * ${ stats . get ( "wDamPct" ) / 100 } )) ` ;
let healLabel = document . createElement ( "p" ) ;
healLabel . textContent = heal _amount ;
// healLabel.classList.add("damagep");
// tooltip = createTooltip(tooltip, "p", tooltiptext, healLabel, ["spell-tooltip"]);
part _div . append ( healLabel ) ;
if ( part . summary == true ) {
let overallhealLabel = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let first = document . createElement ( "span" ) ;
let second = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
first . textContent = part . subtitle + ": " ;
second . textContent = heal _amount ;
overallhealLabel . appendChild ( first ) ;
second . classList . add ( "Set" ) ;
overallhealLabel . appendChild ( second ) ;
part _divavg . append ( overallhealLabel ) ;
}
} else if ( part . type === "total" ) {
let total _damage = 0 ;
tooltiptext = "" ;
for ( let i in part . factors ) {
total _damage += save _damages [ i ] * part . factors [ i ] ;
}
let dmgarr = part . factors . slice ( ) ;
dmgarr = dmgarr . map ( x => "(" + x + " * " + save _damages [ dmgarr . indexOf ( x ) ] . toFixed ( 2 ) + ")" ) ;
tooltiptext = " = " + dmgarr . join ( " + " ) ;
let averageLabel = document . createElement ( "p" ) ;
averageLabel . textContent = "Average: " + total _damage . toFixed ( 2 ) ;
averageLabel . classList . add ( "damageSubtitle" ) ;
tooltip = createTooltip ( tooltip , "p" , tooltiptext , averageLabel , [ "spell-tooltip" ] ) ;
part _div . append ( averageLabel ) ;
let overallaverageLabel = document . createElement ( "p" ) ;
2021-10-21 21:11:04 +07:00
let overallaverageLabelFirst = document . createElement ( "span" ) ;
let overallaverageLabelSecond = document . createElement ( "span" ) ;
2021-10-17 22:53:48 +07:00
overallaverageLabelFirst . textContent = "Average: " ;
overallaverageLabelSecond . textContent = total _damage . toFixed ( 2 ) ;
overallaverageLabelSecond . classList . add ( "Damage" ) ;
overallaverageLabel . appendChild ( overallaverageLabelFirst ) ;
overallaverageLabel . appendChild ( overallaverageLabelSecond ) ;
part _divavg . append ( overallaverageLabel ) ;
}
}
2022-05-22 00:50:53 -07:00
//up and down arrow - done ugly
2022-05-22 01:10:55 -07:00
let arrow = document . createElement ( "img" ) ;
arrow . id = "arrow_" + overallparent _elem . id ;
arrow . style . maxWidth = document . body . clientWidth > 900 ? "3rem" : "10rem" ;
arrow . src = "../media/icons/" + ( newIcons ? "new" : "old" ) + "/toggle_down.png" ;
overallparent _elem . appendChild ( arrow ) ;
2021-10-17 22:53:48 +07:00
}
2021-10-27 20:51:37 +07:00
function displaysq2EquipOrder ( parent _elem , buildOrder ) {
parent _elem . textContent = "" ;
const order = buildOrder . slice ( ) ;
let title _elem = document . createElement ( "b" ) ;
title _elem . textContent = "Equip order " ;
title _elem . classList . add ( "Normal" , "text-center" ) ;
parent _elem . append ( title _elem ) ;
for ( const item of order ) {
let p _elem = document . createElement ( "b" ) ;
p _elem . textContent = item . get ( "displayName" ) ;
parent _elem . append ( p _elem ) ;
}
}
function displaysq2NextCosts ( spell , build ) {
let int = build . total _skillpoints [ 2 ] ;
let spells = spell _table [ build . weapon . get ( "type" ) ] ;
let row = document . createElement ( "div" ) ;
row . classList . add ( "spellcost-tooltip" ) ;
let init _cost = document . createElement ( "b" ) ;
init _cost . textContent = build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) ;
init _cost . classList . add ( "Mana" ) ;
let arrow = document . createElement ( "b" ) ;
arrow . textContent = "\u279C" ;
let next _cost = document . createElement ( "b" ) ;
next _cost . textContent = ( init _cost . textContent === "1" ? 1 : build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) - 1 ) ;
next _cost . classList . add ( "Mana" ) ;
let int _needed = document . createElement ( "b" ) ;
if ( init _cost . textContent === "1" ) {
int _needed . textContent = ": n/a (+0)" ;
} else { //do math
let target = build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) - 1 ;
let needed = int ;
let noUpdate = false ;
//forgive me... I couldn't inverse ceil, floor, and max.
while ( build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) > target ) {
if ( needed > 150 ) {
noUpdate = true ;
break ;
}
needed ++ ;
build . total _skillpoints [ 2 ] = needed ;
}
let missing = needed - int ;
//in rare circumstances, the next spell cost can jump.
if ( noUpdate ) {
next _cost . textContent = ( init _cost . textContent === "1" ? 1 : build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) - 1 ) ;
} else {
next _cost . textContent = ( init _cost . textContent === "1" ? 1 : build . getSpellCost ( spells . indexOf ( spell ) + 1 , spell . cost ) ) ;
}
build . total _skillpoints [ 2 ] = int ; //forgive me pt 2
int _needed . textContent = ": " + ( needed > 150 ? ">150" : needed ) + " int (+" + ( needed > 150 ? "n/a" : missing ) + ")" ;
}
// row.appendChild(init_cost);
row . appendChild ( arrow ) ;
row . appendChild ( next _cost ) ;
row . appendChild ( int _needed ) ;
return row ;
}
function apply _sq2 _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 ] ;
let i _elem = document . createElement ( 'span' ) ;
i _elem . classList . add ( element _prefix ) ;
i _elem . textContent = element _prefix ;
p _elem . appendChild ( i _elem ) ;
let i _elem2 = document . createElement ( 'span' ) ;
i _elem2 . textContent = " " + desc + suffix ;
p _elem . appendChild ( i _elem2 ) ;
2021-10-29 15:08:36 +07:00
}
function displaysq2SetBonuses ( parent _id , build ) {
setHTML ( parent _id , "" ) ;
let parent _div = document . getElementById ( parent _id ) ;
let set _summary _elem = document . createElement ( 'p' ) ;
set _summary _elem . classList . add ( 'text-center' ) ;
set _summary _elem . textContent = "Set Bonuses" ;
parent _div . append ( set _summary _elem ) ;
for ( const [ setName , count ] of build . activeSetCounts ) {
const active _set = sets [ setName ] ;
if ( active _set [ "hidden" ] ) { continue ; }
let set _elem = document . createElement ( 'p' ) ;
set _elem . id = "set-" + setName ;
set _summary _elem . append ( set _elem ) ;
const bonus = active _set . bonuses [ count - 1 ] ;
let mock _item = new Map ( ) ;
mock _item . set ( "fixID" , true ) ;
mock _item . set ( "displayName" , setName + " Set: " + count + "/" + sets [ setName ] . items . length ) ;
let mock _minRolls = new Map ( ) ;
let mock _maxRolls = new Map ( ) ;
mock _item . set ( "minRolls" , mock _minRolls ) ;
mock _item . set ( "maxRolls" , mock _maxRolls ) ;
for ( const id in bonus ) {
if ( rolledIDs . includes ( id ) ) {
mock _minRolls . set ( id , bonus [ id ] ) ;
mock _maxRolls . set ( id , bonus [ id ] ) ;
}
else {
mock _item . set ( id , bonus [ id ] ) ;
}
}
mock _item . set ( "powders" , [ ] ) ;
displaysq2ExpandedItem ( mock _item , set _elem . id ) ;
console . log ( mock _item ) ;
}
2022-01-06 11:18:44 -08:00
}
2022-01-07 00:12:00 -08:00
function toggle _plus _minus ( elem _id ) {
let elem = document . getElementById ( elem _id ) ;
if ( elem . classList . contains ( "plus_minus" ) ) {
if ( elem . textContent == "\u2795" ) {
elem . textContent = "\u2796" ;
} else if ( elem . textContent == "\u2796" ) {
elem . textContent = "\u2795" ;
} else {
// ????
}
}
}
2022-01-08 22:36:24 -05:00
// updates the powders within this element.
2022-01-07 00:12:00 -08:00
function updatePowders ( elem _id ) {
2022-01-08 22:36:24 -05:00
// let elem = document.getElementById(elem_id);
// for (let i = 0; i < elem.value.length - 1; i++) {
// if ('etwfa'.includes(elem.value.charAt(i)) && elem.value.charAt(i + 1) >= '1' && elem.value.charAt(i + 1) <= '6') {
// elem.value = elem.value.substring(0, i) + powder_chars['etwfa'.indexOf(elem.value.charAt(i))] + elem.value.substring(i + 2);
// }
// }
2022-05-12 01:48:59 -07: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
* /
function displaysq2RecipeStats ( craft , parent _id ) {
let elem = document . getElementById ( parent _id ) ;
if ( ! elem . classList . contains ( "col" ) ) {
elem . classList . add ( "col" ) ;
}
//local vars
elem . textContent = "" ;
recipe = craft [ "recipe" ] ;
mat _tiers = craft [ "mat_tiers" ] ;
ingreds = [ ] ;
for ( const n of craft [ "ingreds" ] ) {
ingreds . push ( n . get ( "name" ) ) ;
}
let effectiveness = craft [ "statMap" ] . get ( "ingredEffectiveness" ) ;
let title = document . createElement ( "div" ) ;
title . classList . add ( "row" , "box-title" , "fw-bold" , "justify-content-center" ) ;
title . textContent = "Recipe Stats" ;
elem . appendChild ( title ) ;
let mats = document . createElement ( "div" ) ;
mats . classList . add ( "row" ) ;
mats . textContent = "Crafting Materials: " ;
elem . appendChild ( mats ) ;
for ( let i = 0 ; i < 2 ; i ++ ) {
let tier = mat _tiers [ i ] ;
let row = document . createElement ( "div" ) ;
row . classList . add ( "row" , "px-0" , "mx-0" ) ;
let b = document . createElement ( "div" ) ;
let mat = recipe . get ( "materials" ) [ i ] ;
b . textContent = "- " + mat . get ( "amount" ) + "x " + mat . get ( "item" ) . split ( " " ) . slice ( 1 ) . join ( " " ) ;
b . classList . add ( "col" ) ;
row . appendChild ( b ) ;
let starsB = document . createElement ( "div" ) ;
starsB . classList . add ( "T1-bracket" , "col-auto" , "px-0" ) ;
starsB . textContent = "[" ;
row . appendChild ( starsB ) ;
for ( let j = 0 ; j < 3 ; j ++ ) {
let star = document . createElement ( "div" ) ;
star . classList . add ( "col-auto" , "px-0" ) ;
star . textContent = "\u272B" ;
if ( j < tier ) {
star . classList . add ( "T1" ) ;
} else {
star . classList . add ( "T0" ) ;
}
row . append ( star ) ;
}
let starsE = document . createElement ( "div" ) ;
starsE . classList . add ( "T1-bracket" , "col-auto" , "px-0" ) ;
starsE . textContent = "]" ;
row . appendChild ( starsE ) ;
elem . appendChild ( row ) ;
}
let ingredTable = document . createElement ( "div" ) ;
ingredTable . classList . add ( "row" ) ;
for ( let i = 0 ; i < 3 ; i ++ ) {
let row = document . createElement ( "div" ) ;
row . classList . add ( "row" , "g-1" , "justify-content-center" ) ;
for ( let j = 0 ; j < 2 ; j ++ ) {
if ( j == 1 ) {
let spacer = document . createElement ( "div" ) ;
spacer . classList . add ( "col-1" ) ;
row . appendChild ( spacer ) ;
}
let ingredName = ingreds [ 2 * i + j ] ;
let col = document . createElement ( "div" ) ;
col . classList . add ( "col-5" , "rounded" , "dark-6" , "border" , "border-3" , "dark-shadow" ) ;
let temp _row = document . createElement ( "div" ) ;
temp _row . classList . add ( "row" ) ;
col . appendChild ( temp _row ) ;
let ingred _div = document . createElement ( "div" ) ;
ingred _div . classList . add ( "col" ) ;
ingred _div . textContent = ingredName ;
temp _row . appendChild ( ingred _div ) ;
let eff _div = document . createElement ( "div" ) ;
eff _div . classList . add ( "col-auto" ) ;
let e = effectiveness [ 2 * i + j ] ;
if ( e > 0 ) {
eff _div . classList . add ( "positive" ) ;
} else if ( e < 0 ) {
eff _div . classList . add ( "negative" ) ;
}
eff _div . textContent = "[" + e + "%]" ;
temp _row . appendChild ( eff _div ) ;
row . appendChild ( col ) ;
}
ingredTable . appendChild ( row ) ;
}
elem . appendChild ( ingredTable ) ;
}
/ *
* Displays an ingredient in item format .
* However , an ingredient is too far from a normal item to display as one .
* /
function displaysq2ExpandedIngredient ( ingred , parent _id ) {
let parent _elem = document . getElementById ( parent _id ) ;
parent _elem . textContent = "" ;
2022-01-07 00:12:00 -08:00
2022-05-12 01:48:59 -07:00
let item _order = [
"dura" ,
"strReq" ,
"dexReq" ,
"intReq" ,
"defReq" ,
"agiReq"
]
let consumable _order = [
"dura" ,
"charges"
]
let posMods _order = [
"above" ,
"under" ,
"left" ,
"right" ,
"touching" ,
"notTouching"
] ;
let id _display _order = [
"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" ,
] ;
let active _elem ;
let elemental _format = false ;
let style ;
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 ;
}
else if ( command === "!spacer" ) {
let spacer = document . createElement ( 'div' ) ;
spacer . classList . add ( "row" , "my-2" ) ;
parent _elem . appendChild ( spacer ) ;
continue ;
}
} else {
let div = document . createElement ( "div" ) ;
div . classList . add ( "row" ) ;
if ( command === "displayName" ) {
div . classList . add ( "box-title" ) ;
let title _elem = document . createElement ( "div" ) ;
title _elem . classList . add ( "col-auto" , "justify-content-center" , "pr-1" ) ;
title _elem . textContent = ingred . get ( "displayName" ) ;
div . appendChild ( title _elem ) ;
let tier = ingred . get ( "tier" ) ; //tier in [0,3]
let begin = document . createElement ( "b" ) ;
begin . classList . add ( "T" + tier + "-bracket" , "col-auto" , "px-0" ) ;
begin . textContent = "[" ;
div . appendChild ( begin ) ;
for ( let i = 0 ; i < 3 ; i ++ ) {
let tier _elem = document . createElement ( "b" ) ;
if ( i < tier ) {
tier _elem . classList . add ( "T" + tier ) ;
} else {
tier _elem . classList . add ( "T0" ) ;
}
tier _elem . classList . add ( "px-0" , "col-auto" ) ;
tier _elem . textContent = "\u272B" ;
div . appendChild ( tier _elem ) ;
}
let end = document . createElement ( "b" ) ;
end . classList . add ( "T" + tier + "-bracket" , "px-0" , "col-auto" ) ;
end . textContent = "]" ;
div . appendChild ( end ) ;
} else if ( command === "lvl" ) {
div . textContent = "Crafting Lvl Min: " + ingred . get ( "lvl" ) ;
} else if ( command === "posMods" ) {
for ( const [ key , value ] of ingred . get ( "posMods" ) ) {
let posModRow = document . createElement ( "div" ) ;
posModRow . classList . add ( "row" ) ;
if ( value != 0 ) {
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" ) ;
val . textContent = value + posModSuffixes [ key ] ;
if ( value > 0 ) {
val . classList . add ( "positive" ) ;
} else {
val . classList . add ( "negative" ) ;
}
posModRow . appendChild ( val ) ;
div . appendChild ( posModRow ) ;
}
}
} else if ( command === "itemIDs" ) { //dura, reqs
for ( const [ key , value ] of ingred . get ( "itemIDs" ) ) {
let idRow = document . createElement ( "div" ) ;
idRow . classList . add ( "row" ) ;
if ( value != 0 ) {
let title = document . createElement ( "div" ) ;
title . classList . add ( "col-auto" ) ;
title . textContent = itemIDPrefixes [ key ] ;
idRow . appendChild ( title ) ;
}
let desc = document . createElement ( "div" ) ;
desc . classList . add ( "col-auto" ) ;
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 ) {
idRow . appendChild ( desc ) ;
}
div . appendChild ( idRow ) ;
}
} else if ( command === "consumableIDs" ) { //dura, charges
for ( const [ key , value ] of ingred . get ( "consumableIDs" ) ) {
let idRow = document . createElement ( "div" ) ;
idRow . classList . add ( "row" ) ;
if ( value != 0 ) {
let title = document . createElement ( "div" ) ;
title . classList . add ( "col-auto" ) ;
title . textContent = consumableIDPrefixes [ key ] ;
idRow . appendChild ( title ) ;
}
let desc = document . createElement ( "div" ) ;
desc . classList . add ( "col-auto" ) ;
if ( value > 0 ) {
desc . classList . add ( "positive" ) ;
desc . textContent = "+" + value ;
} else if ( value < 0 ) {
desc . classList . add ( "negative" ) ;
desc . textContent = value ;
}
if ( value != 0 ) {
idRow . appendChild ( desc ) ;
let suffix = document . createElement ( "div" ) ;
suffix . classList . add ( "col-auto" ) ;
suffix . textContent = consumableIDSuffixes [ key ] ;
idRow . appendChild ( suffix ) ;
}
div . appendChild ( idRow ) ;
}
} else if ( command === "skills" ) {
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 ) ;
for ( const skill of ingred . get ( "skills" ) ) {
let skill _div = document . createElement ( "div" ) ;
skill _div . classList . add ( "row" ) ;
skill _div . textContent = skill . charAt ( 0 ) + skill . substring ( 1 ) . toLowerCase ( ) ;
row . appendChild ( skill _div ) ;
}
div . appendChild ( row ) ;
} else if ( command === "ids" ) { //warp
for ( let [ key , value ] of ingred . get ( "ids" ) . get ( "maxRolls" ) ) {
if ( value !== undefined && value != 0 ) {
let row = displaysq2RolledID ( ingred . get ( "ids" ) , key , elemental _format ) ;
row . classList . remove ( "col" ) ;
row . classList . remove ( "col-12" ) ;
div . appendChild ( row ) ;
}
}
} else { //this shouldn't be happening
}
parent _elem . appendChild ( div ) ;
}
}
2022-05-16 19:44:40 -07:00
}
//TODO: translate the below to BS
/ * * D i s p l a y s A d d i t i o n a l I n f o f o r
*
* @ param { String } elemID - the parent element ' s id
* @ param { Map } item - the statMap of the item
* @ returns
* /
function displaysq2AdditionalInfo ( elemID , item ) {
let parent _elem = document . getElementById ( elemID ) ;
let title = document . createElement ( "div" ) ;
title . classList . add ( "big-title" , "justify-content-center" ) ;
title . textContent = "Additional Info" ;
parent _elem . appendChild ( title ) ;
let droptype _elem = document . createElement ( "div" ) ;
droptype _elem . classList . add ( "row" ) ;
droptype _elem . textContent = "Drop type: " + ( item . has ( "drop" ) ? item . get ( "drop" ) : "NEVER" ) ;
parent _elem . appendChild ( droptype _elem ) ;
let warning _elem = document . createElement ( "div" ) ;
warning _elem . classList . add ( "row" ) ;
warning _elem . textContent = "This page is incomplete. Will work on it later." ;
parent _elem . appendChild ( warning _elem ) ;
return ;
}
/ * * D i s p l a y s t h e I D c o s t s o f a n i t e m
*
* @ param { String } elemID - the id of the parent element .
* @ param { Map } item - the statMap of an item .
* /
function displaysq2IDCosts ( elemID , item ) {
let parent _elem = document . getElementById ( elemID ) ;
let tier = item . get ( "tier" ) ;
if ( ( item . has ( "fixID" ) && item . get ( "fixID" ) ) || [ "Normal" , "Crafted" , "Custom" , "none" , " " , ] . includes ( item . get ( "tier" ) ) ) {
return ;
} else {
/ * * R e t u r n s t h e n u m b e r o f i n v e n t o r y s l o t s m i n i m u m a n a m o u n t o f e m e r a l d s w o u l d t a k e u p + t h e c o n f i g u r a t i o n o f d o i n g s o .
* Returns an array of [ invSpace , E , EB , LE , Stx LE ]
*
* @ param { number } ems - the total numerical value of emeralds to compact .
* /
function emsToInvSpace ( ems ) {
let stx = Math . floor ( ems / 262144 ) ;
ems -= stx * 4096 * 64 ;
let LE = Math . floor ( ems / 4096 ) ;
ems -= LE * 4096 ;
let EB = Math . floor ( ems / 64 ) ;
ems -= EB * 64 ;
let e = ems ;
return [ stx + Math . ceil ( LE / 64 ) + Math . ceil ( EB / 64 ) + Math . ceil ( e / 64 ) , e , EB , LE , stx ] ;
}
/ * *
*
* @ param { String } tier - item tier
* @ param { Number } lvl - item level
* /
function getIDCost ( tier , lvl ) {
switch ( tier ) {
case "Unique" :
return Math . round ( 0.5 * lvl + 3 ) ;
case "Rare" :
return Math . round ( 1.2 * lvl + 8 ) ;
case "Legendary" :
return Math . round ( 4.5 * lvl + 12 ) ;
case "Fabled" :
return Math . round ( 12 * lvl + 26 ) ;
case "Mythic" :
return Math . round ( 18 * lvl + 90 ) ;
case "Set" :
return Math . round ( 1.5 * lvl + 8 )
default :
return - 1 ;
}
}
parent _elem . style = "display: visible" ;
let lvl = item . get ( "lvl" ) ;
if ( typeof ( lvl ) === "string" ) { lvl = parseFloat ( lvl ) ; }
let title _elem = document . createElement ( "div" ) ;
title _elem . classList . add ( "big-title" , "justify-content-center" , "Set" ) ;
title _elem . textContent = "Identification Costs" ;
parent _elem . appendChild ( title _elem ) ;
let grid _item = document . createElement ( "div" ) ;
grid _item . classList . add ( "row" , "g-3" ) ;
parent _elem . appendChild ( grid _item ) ;
let IDcost = getIDCost ( tier , lvl ) ;
let initIDcost = IDcost ;
let invSpace = emsToInvSpace ( IDcost ) ;
let rerolls = 0 ;
while ( invSpace [ 0 ] <= 28 && IDcost > 0 ) {
let container _container = document . createElement ( "div" ) ;
container _container . classList . add ( "col-lg-3" , "col-sm-12" ) ;
let container = document . createElement ( "div" ) ;
container . classList . add ( "col" , "rounded" , "border" , "border-dark" , "border-2" ) ;
container _container . appendChild ( container ) ;
let container _title = document . createElement ( "div" ) ;
container _title . classList . add ( "row" , "box-title" , "justify-content-center" ) ;
if ( rerolls == 0 ) {
container _title . textContent = "Initial ID Cost: " ;
} else {
container _title . textContent = "Reroll to [" + ( rerolls + 1 ) + "] Cost:" ;
}
container . appendChild ( container _title ) ;
let total _cost _container = document . createElement ( "div" ) ;
total _cost _container . classList . add ( "row" ) ;
let total _cost _number = document . createElement ( "b" ) ;
total _cost _number . classList . add ( "Set" , "fw-bold" , "col-6" , "text-end" ) ;
total _cost _number . textContent = IDcost + " " ;
let total _cost _suffix = document . createElement ( "div" ) ;
total _cost _suffix . classList . add ( "col-6" , "text-start" ) ;
total _cost _suffix . textContent = "emeralds."
total _cost _container . appendChild ( total _cost _number ) ;
total _cost _container . appendChild ( total _cost _suffix ) ;
container . appendChild ( total _cost _container ) ;
let OR = document . createElement ( "div" ) ;
OR . classList . add ( "row" ) ;
container . appendChild ( OR ) ;
let OR _text = document . createElement ( "div" ) ;
OR _text . classList . add ( "col" , "text-center" ) ;
OR _text . textContent = "OR" ;
OR . appendChild ( OR _text ) ;
let esuffixes = [ "" , "emeralds." , "EB." , "LE." , "stacks of LE." ] ;
for ( let i = 4 ; i > 0 ; i -- ) {
let n _container = document . createElement ( "div" ) ;
n _container . classList . add ( "row" ) ;
let n _number = document . createElement ( "b" ) ;
n _number . classList . add ( "Set" , "fw-bold" , "col-6" , "text-end" ) ;
n _number . textContent = invSpace [ i ] + " " ;
let n _suffix = document . createElement ( "div" ) ;
n _suffix . classList . add ( "col-6" , "text-start" ) ;
n _suffix . textContent = esuffixes [ i ] ;
n _container . appendChild ( n _number ) ;
n _container . appendChild ( n _suffix ) ;
container . appendChild ( n _container ) ;
}
grid _item . appendChild ( container _container ) ;
rerolls += 1 ;
IDcost = Math . round ( initIDcost * ( 5 * * rerolls ) ) ;
invSpace = emsToInvSpace ( IDcost ) ;
}
}
}
/ * * D i s p l a y s a l l s e t b o n u s e s ( 0 / n , 1 / n , . . . n / n ) f o r a g i v e n s e t
*
* @ param { String } parent _id - id of the parent element
* @ param { String } setName - the name of the set
* /
function displaysq2AllSetBonuses ( parent _id , setName ) {
let parent _elem = document . getElementById ( parent _id ) ;
parent _elem . style . display = "" ;
let set = sets [ setName ] ;
let title _elem = document . createElement ( "div" ) ;
title _elem . textContent = setName + " Set Bonuses" ;
title _elem . classList . add ( "Set" , "big-title" , "justify-content-center" ) ;
parent _elem . appendChild ( title _elem ) ;
let grid _elem = document . createElement ( "div" ) ;
grid _elem . classList . add ( "row" ) ;
parent _elem . appendChild ( grid _elem ) ;
for ( let i = 0 ; i < set . items . length ; i ++ ) {
let set _elem = document . createElement ( 'div' ) ;
set _elem . classList . add ( "col-lg-3" , "col-sm-12" , "py-2" , "my-1" ) ;
grid _elem . appendChild ( set _elem ) ;
const bonus = set . bonuses [ i ] ;
let set _elem _display = document . createElement ( "div" ) ;
set _elem _display . classList . add ( "rounded" , "col" , "g-0" , "scaled-font" , "border" , "border-3" , "border-dark" , "dark-shadow" , "dark-7" , "p-3" ) ;
set _elem _display . id = "set-" + setName + "-" + i ;
set _elem . appendChild ( set _elem _display ) ;
let mock _item = new Map ( ) ;
mock _item . set ( "fixID" , true ) ;
mock _item . set ( "tier" , "Set" ) ;
mock _item . set ( "displayName" , setName + " Set: " + ( i + 1 ) + "/" + sets [ setName ] . items . length ) ;
// set_elem.textContent = mock_item.get("displayName");
let mock _minRolls = new Map ( ) ;
let mock _maxRolls = new Map ( ) ;
mock _item . set ( "minRolls" , mock _minRolls ) ;
mock _item . set ( "maxRolls" , mock _maxRolls ) ;
for ( const id in bonus ) {
if ( rolledIDs . includes ( id ) ) {
mock _minRolls . set ( id , bonus [ id ] ) ;
mock _maxRolls . set ( id , bonus [ id ] ) ;
}
else {
mock _item . set ( id , bonus [ id ] ) ;
}
}
mock _item . set ( "powders" , [ ] ) ;
displaysq2ExpandedItem ( mock _item , set _elem _display . id ) ;
}
}
/ * * D i s p l a y s t h e i n d i v i d u a l p r o b a b i l i t i e s o f e a c h p o s s i b l e v a l u e o f e a c h r o l l a b l e I D f o r t h i s i t e m .
*
* @ param { String } parent _id the document id of the parent element
* @ param { String } item expandedItem object
* @ param { String } amp the level of corkian amplifier used . 0 means no amp , 1 means Corkian Amplifier I , etc . [ 0 , 3 ]
* /
function displaysq2IDProbabilities ( parent _id , item , amp ) {
if ( item . has ( "fixID" ) && item . get ( "fixID" ) ) { return }
let parent _elem = document . getElementById ( parent _id ) ;
parent _elem . style . display = "" ;
parent _elem . innerHTML = "" ;
let title _elem = document . createElement ( "div" ) ;
title _elem . textContent = "Identification Probabilities" ;
title _elem . classList . add ( "row" , "Legendary" , "big-title" , "justify-content-center" ) ;
parent _elem . appendChild ( title _elem ) ;
let disclaimer _elem = document . createElement ( "div" ) ;
disclaimer _elem . classList . add ( "row" , "justify-content-center" ) ;
disclaimer _elem . textContent = "IDs are rolled on a uniform distribution. A chance of 0% means that either the minimum or maximum possible multiplier must be rolled to get this value."
parent _elem . appendChild ( disclaimer _elem ) ;
let amp _row = document . createElement ( "div" ) ;
amp _row . classList . add ( "row" , "justify-content-center" ) ;
amp _row . id = "amp_row" ;
let amp _text = document . createElement ( "div" ) ;
amp _text . classList . add ( "col-lg-2" , "col-sm-3" ) ;
amp _text . textContent = "Corkian Amplifier Used: "
amp _row . appendChild ( amp _text ) ;
let amp _1 = document . createElement ( "button" ) ;
amp _1 . classList . add ( "col-lg-1" , "col-sm-3" , "border-dark" , "text-light" , "dark-5" , "rounded" , "scaled-font" ) ;
amp _1 . id = "cork_amp_1" ;
amp _1 . textContent = "I" ;
amp _row . appendChild ( amp _1 ) ;
let amp _2 = document . createElement ( "button" ) ;
amp _2 . classList . add ( "col-lg-1" , "col-sm-3" , "border-dark" , "text-light" , "dark-5" , "rounded" , "scaled-font" ) ;
amp _2 . id = "cork_amp_2" ;
amp _2 . textContent = "II" ;
amp _row . appendChild ( amp _2 ) ;
let amp _3 = document . createElement ( "button" ) ;
amp _3 . classList . add ( "col-lg-1" , "col-sm-3" , "border-dark" , "text-light" , "dark-5" , "rounded" , "scaled-font" ) ;
amp _3 . id = "cork_amp_3" ;
amp _3 . textContent = "III" ;
amp _row . appendChild ( amp _3 ) ;
amp _1 . addEventListener ( "click" , ( event ) => { toggleAmps ( 1 ) } ) ;
amp _2 . addEventListener ( "click" , ( event ) => { toggleAmps ( 2 ) } ) ;
amp _3 . addEventListener ( "click" , ( event ) => { toggleAmps ( 3 ) } ) ;
parent _elem . appendChild ( amp _row ) ;
if ( amp != 0 ) { toggleButton ( "cork_amp_" + amp ) }
item _name = item . get ( "displayName" ) ;
for ( const [ id , val ] of Object . entries ( itemMap . get ( item _name ) ) ) {
if ( rolledIDs . includes ( id ) ) {
let min = item . get ( "minRolls" ) . get ( id ) ;
let max = item . get ( "maxRolls" ) . get ( id ) ;
if ( min != 0 || max != 0 ) {
//Apply corkian amps
if ( val > 0 ) {
let base = itemMap . get ( item _name ) [ id ] ;
if ( reversedIDs . includes ( id ) ) { max = Math . max ( Math . round ( ( 0.3 + 0.05 * amp ) * base ) , 1 ) }
else { min = Math . max ( Math . round ( ( 0.3 + 0.05 * amp ) * base ) , 1 ) }
}
let row _elem = document . createElement ( "div" ) ;
row _elem . classList . add ( "row" ) ;
parent _elem . appendChild ( row _elem ) ;
let base _and _range = document . createElement ( "div" ) ;
base _and _range . classList . add ( "col-lg-4" , "col-sm-12" ) ;
let base _elem = document . createElement ( "div" ) ;
let base _val = document . createElement ( "div" ) ;
base _elem . classList . add ( "row" ) ;
base _prefix = document . createElement ( "div" ) ;
base _prefix . classList . add ( "col-auto" ) ;
base _val . classList . add ( "col-auto" ) ;
base _prefix . textContent = idPrefixes [ id ] + "Base " ;
base _val . textContent = val + idSuffixes [ id ] ;
if ( val > 0 == ! reversedIDs . includes ( id ) ) {
base _val . classList . add ( "positive" ) ;
} else if ( val > 0 == reversedIDs . includes ( id ) ) {
base _val . classList . add ( "negative" ) ;
}
base _elem . appendChild ( base _prefix ) ;
base _elem . appendChild ( base _val ) ;
let range _elem = document . createElement ( "div" ) ;
range _elem . classList . add ( "row" , "justify-content-center" ) ;
range _elem . textContent = "[ " + min + idSuffixes [ id ] + ", " + max + idSuffixes [ id ] + " ]" ;
if ( ( min > 0 && max > 0 && ! reversedIDs . includes ( id ) ) || ( min < 0 && max < 0 && reversedIDs . includes ( id ) ) ) {
range _elem . classList . add ( "positive" ) ;
} else if ( ( min < 0 && max < 0 && ! reversedIDs . includes ( id ) ) || ( min > 0 && max > 0 && reversedIDs . includes ( id ) ) ) {
range _elem . classList . add ( "negative" ) ;
}
base _and _range . appendChild ( base _elem ) ;
base _and _range . appendChild ( range _elem ) ;
row _elem . appendChild ( base _and _range ) ;
let pdf _and _cdf = document . createElement ( "div" ) ;
pdf _and _cdf . classList . add ( "col-lg-4" , "col-sm-12" ) ;
let pdf _elem = document . createElement ( "div" ) ;
pdf _elem . id = id + "-pdf" ;
let cdf _elem = document . createElement ( "div" ) ;
cdf _elem . id = id + "-cdf" ;
pdf _elem . classList . add ( "row" ) ;
cdf _elem . classList . add ( "row" ) ;
pdf _and _cdf . appendChild ( pdf _elem ) ;
pdf _and _cdf . appendChild ( cdf _elem ) ;
row _elem . appendChild ( pdf _and _cdf ) ;
let input _sec = document . createElement ( "div" ) ;
input _sec . classList . add ( "col-lg-4" , "col-sm-12" ) ;
let title _input _slider = document . createElement ( "input" ) ;
title _input _slider . classList . add ( "row" ) ;
title _input _slider . type = "range" ;
title _input _slider . id = id + "-slider" ;
if ( ! reversedIDs . includes ( id ) ) {
title _input _slider . step = 1 ;
title _input _slider . min = ` ${ min } ` ;
title _input _slider . max = ` ${ max } ` ;
title _input _slider . value = ` ${ max } ` ;
} else {
title _input _slider . step = 1 ;
title _input _slider . min = ` ${ - 1 * min } ` ;
title _input _slider . max = ` ${ - 1 * max } ` ;
title _input _slider . value = ` ${ - 1 * max } ` ;
}
let title _input _textbox = document . createElement ( "input" ) ;
title _input _textbox . classList . add ( "row" ) ;
title _input _textbox . type = "text" ;
title _input _textbox . value = ` ${ max } ` ;
title _input _textbox . id = id + "-textbox" ;
title _input _textbox . classList . add ( "rounded" , "border" , "border-dark" , "border-2" , "dark-5" , "text-light" ) ;
input _sec . appendChild ( title _input _slider ) ;
input _sec . appendChild ( title _input _textbox ) ;
row _elem . appendChild ( input _sec ) ;
sq2StringPDF ( id , max , val , amp ) ; //val is base roll
sq2StringCDF ( id , max , val , amp ) ; //val is base roll
title _input _slider . addEventListener ( "change" , ( event ) => {
let id _name = event . target . id . split ( "-" ) [ 0 ] ;
let textbox _elem = document . getElementById ( id _name + "-textbox" ) ;
if ( reversedIDs . includes ( id _name ) ) {
if ( event . target . value < - 1 * min ) { event . target . value = - 1 * min }
if ( event . target . value > - 1 * max ) { event . target . value = - 1 * max }
sq2StringPDF ( id _name , - 1 * event . target . value , val , amp ) ; //val is base roll
sq2StringCDF ( id _name , - 1 * event . target . value , val , amp ) ; //val is base roll
} else {
if ( event . target . value < min ) { event . target . value = min }
if ( event . target . value > max ) { event . target . value = max }
sq2StringPDF ( id _name , 1 * event . target . value , val , amp ) ; //val is base roll
sq2StringCDF ( id _name , 1 * event . target . value , val , amp ) ; //val is base roll
}
if ( textbox _elem && textbox _elem . value !== event . target . value ) {
if ( reversedIDs . includes ( id _name ) ) {
textbox _elem . value = - event . target . value ;
} else {
textbox _elem . value = event . target . value ;
}
}
} ) ;
title _input _textbox . addEventListener ( "change" , ( event ) => {
let id _name = event . target . id . split ( "-" ) [ 0 ] ;
if ( reversedIDs . includes ( id _name ) ) {
if ( event . target . value > min ) { event . target . value = min }
if ( event . target . value < max ) { event . target . value = max }
} else {
if ( event . target . value < min ) { event . target . value = min }
if ( event . target . value > max ) { event . target . value = max }
}
let slider _elem = document . getElementById ( id _name + "-slider" ) ;
if ( slider _elem . value !== event . target . value ) {
slider _elem . value = - event . target . value ;
}
sq2StringPDF ( id _name , 1 * event . target . value , val , amp ) ;
sq2StringCDF ( id _name , 1 * event . target . value , val , amp ) ;
} ) ;
}
}
}
}
//helper functions. id - the string of the id's name, val - the value of the id, base - the base value of the item for this id
function sq2StringPDF ( id , val , base , amp ) {
/ * * [ 0 . 3 b , 1 . 3 b ] p o s i t i v e n o r m a l
* [ 1.3 b , 0.3 b ] positive reversed
* [ 1.3 b , 0.7 b ] negative normal
* [ 0.7 b , 1.3 b ] negative reversed
*
* [ 0.3 , 1.3 ] minr , maxr [ 0.3 b , 1.3 b ] min , max
* the minr / maxr decimal roll that corresponds to val - > minround , maxround
* /
let p ; let min ; let max ; let minr ; let maxr ; let minround ; let maxround ;
if ( base > 0 ) {
minr = 0.3 + 0.05 * amp ; maxr = 1.3 ;
min = Math . max ( 1 , Math . round ( minr * base ) ) ; max = Math . max ( 1 , Math . round ( maxr * base ) ) ;
minround = ( min == max ) ? ( minr ) : ( Math . max ( minr , ( val - 0.5 ) / base ) ) ;
maxround = ( min == max ) ? ( maxr ) : ( Math . min ( maxr , ( val + 0.5 ) / base ) ) ;
} else {
minr = 1.3 ; maxr = 0.7 ;
min = Math . min ( - 1 , Math . round ( minr * base ) ) ; max = Math . min ( - 1 , Math . round ( maxr * base ) ) ;
minround = ( min == max ) ? ( minr ) : ( Math . min ( minr , ( val - 0.5 ) / base ) ) ;
maxround = ( min == max ) ? ( maxr ) : ( Math . max ( maxr , ( val + 0.5 ) / base ) ) ;
}
p = Math . abs ( maxround - minround ) / Math . abs ( maxr - minr ) * 100 ;
p = p . toFixed ( 3 ) ;
let div1 = document . createElement ( "div" ) ;
div1 . textContent = "Roll exactly " ;
div1 . classList . add ( "col-auto" , "px-0" ) ;
let div2 = document . createElement ( "div" ) ;
div2 . textContent = val + idSuffixes [ id ] ;
div2 . classList . add ( "col-auto" , "px-1" ) ;
if ( val > 0 == ! reversedIDs . includes ( id ) ) { div2 . classList . add ( "positive" ) }
if ( val > 0 == reversedIDs . includes ( id ) ) { div2 . classList . add ( "negative" ) }
let div3 = document . createElement ( "div" ) ;
div3 . textContent = ": " + p + "%" ;
div3 . classList . add ( "col-auto" , "px-0" ) ;
document . getElementById ( id + "-pdf" ) . innerHTML = "" ;
document . getElementById ( id + "-pdf" ) . appendChild ( div1 ) ;
document . getElementById ( id + "-pdf" ) . appendChild ( div2 ) ;
document . getElementById ( id + "-pdf" ) . appendChild ( div3 ) ;
}
function sq2StringCDF ( id , val , base , amp ) {
let p ; let min ; let max ; let minr ; let maxr ; let minround ; let maxround ;
if ( base > 0 ) {
minr = 0.3 + 0.05 * amp ; maxr = 1.3 ;
min = Math . max ( 1 , Math . round ( minr * base ) ) ; max = Math . max ( 1 , Math . round ( maxr * base ) ) ;
minround = ( min == max ) ? ( minr ) : ( Math . max ( minr , ( val - 0.5 ) / base ) ) ;
maxround = ( min == max ) ? ( maxr ) : ( Math . min ( maxr , ( val + 0.5 ) / base ) ) ;
} else {
minr = 1.3 ; maxr = 0.7 ;
min = Math . min ( - 1 , Math . round ( minr * base ) ) ; max = Math . min ( - 1 , Math . round ( maxr * base ) ) ;
minround = ( min == max ) ? ( minr ) : ( Math . min ( minr , ( val - 0.5 ) / base ) ) ;
maxround = ( min == max ) ? ( maxr ) : ( Math . max ( maxr , ( val + 0.5 ) / base ) ) ;
}
if ( reversedIDs . includes ( id ) ) {
p = Math . abs ( minr - maxround ) / Math . abs ( maxr - minr ) * 100 ;
} else {
p = Math . abs ( maxr - minround ) / Math . abs ( maxr - minr ) * 100 ;
}
p = p . toFixed ( 3 ) ;
let div1 = document . createElement ( "div" ) ;
div1 . textContent = "Roll " ;
div1 . classList . add ( "col-auto" , "px-0" ) ;
let div2 = document . createElement ( "div" ) ;
div2 . textContent = val + idSuffixes [ id ] ;
div2 . classList . add ( "col-auto" , "px-1" ) ;
if ( val > 0 == ! reversedIDs . includes ( id ) ) { div2 . classList . add ( "positive" ) }
if ( val > 0 == reversedIDs . includes ( id ) ) { div2 . classList . add ( "negative" ) }
let div3 = document . createElement ( "div" ) ;
div3 . textContent = " or better: " + p + "%" ;
div3 . classList . add ( "col-auto" , "px-0" ) ;
document . getElementById ( id + "-cdf" ) . innerHTML = "" ;
document . getElementById ( id + "-cdf" ) . appendChild ( div1 ) ;
document . getElementById ( id + "-cdf" ) . appendChild ( div2 ) ;
document . getElementById ( id + "-cdf" ) . appendChild ( div3 ) ;
}