Fix misc. shaman bugs (#210)

fluid healing affecting aura heal
crash bug with invigorate puppets

Co-authored-by: hppeng <hppeng>
This commit is contained in:
hppeng-wynn 2022-08-16 09:24:16 -07:00 committed by GitHub
parent 23499b59de
commit 50b981620d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 10 additions and 4 deletions

View file

@ -576,7 +576,9 @@ const atree_scaling = new (class extends ComputeNode {
merge_stat(ret_effects, name, value); merge_stat(ret_effects, name, value);
} else if (type === 'prop') { } else if (type === 'prop') {
const merge_abil = atree_edit.get(abil); const merge_abil = atree_edit.get(abil);
merge_abil.properties[name] += value; if (merge_abil) {
merge_abil.properties[name] += value;
}
} }
} }
for (const [abil_id, abil] of atree_merged.entries()) { for (const [abil_id, abil] of atree_merged.entries()) {

View file

@ -10816,7 +10816,7 @@ const atrees = {
], ],
"output": { "output": {
"type": "stat", "type": "stat",
"name": "healPct.Fluid:3.Heal Amount" "name": "healPct:3.Heal Amount"
}, },
"scaling": [ 0.3 ] "scaling": [ 0.3 ]
} }

File diff suppressed because one or more lines are too long

View file

@ -603,8 +603,9 @@ class SpellDamageCalcNode extends ComputeNode {
// TODO: move preprocessing to separate node/node chain // TODO: move preprocessing to separate node/node chain
for (const part of spell_parts) { for (const part of spell_parts) {
let spell_result; let spell_result;
const part_id = spell.base_spell + '.' + part.name
if ('multipliers' in part) { // damage type spell if ('multipliers' in part) { // damage type spell
let results = calculateSpellDamage(stats, weapon, part.multipliers, use_spell, !use_speed, spell.base_spell + '.' + part.name); let results = calculateSpellDamage(stats, weapon, part.multipliers, use_spell, !use_speed, part_id);
spell_result = { spell_result = {
type: "damage", type: "damage",
normal_min: results[2].map(x => x[0]), normal_min: results[2].map(x => x[0]),
@ -617,6 +618,9 @@ class SpellDamageCalcNode extends ComputeNode {
} else if ('power' in part) { } else if ('power' in part) {
// TODO: wynn2 formula // TODO: wynn2 formula
let _heal_amount = (part.power * getDefenseStats(stats)[0] * (stats.get('healPct')/100)); let _heal_amount = (part.power * getDefenseStats(stats)[0] * (stats.get('healPct')/100));
if (stats.has('healPct:'+part_id)) {
_heal_amount *= 1+(stats.get('healPct:'+part_id)/100);
}
spell_result = { spell_result = {
type: "heal", type: "heal",
heal_amount: _heal_amount heal_amount: _heal_amount