mirror of
https://github.com/Foundryborne/daggerheart.git
synced 2026-06-05 20:34:15 +02:00
Fixed d20 modifiers
This commit is contained in:
parent
126a8e4660
commit
505cc634d3
2 changed files with 23 additions and 20 deletions
|
|
@ -78,24 +78,6 @@ export class DHActionRollData extends foundry.abstract.DataModel {
|
||||||
return formula;
|
return formula;
|
||||||
}
|
}
|
||||||
|
|
||||||
getModifier() {
|
|
||||||
const modifiers = [];
|
|
||||||
if (!this.parent?.actor) return modifiers;
|
|
||||||
switch (this.parent.actor.type) {
|
|
||||||
case 'companion':
|
|
||||||
case 'adversary':
|
|
||||||
if (this.type === CONFIG.DH.GENERAL.rollTypes.attack.id)
|
|
||||||
modifiers.push({
|
|
||||||
label: 'Bonus to Hit',
|
|
||||||
value: this.bonus ?? this.parent.actor.system.attack.roll.bonus ?? 0
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return modifiers;
|
|
||||||
}
|
|
||||||
|
|
||||||
get rollTrait() {
|
get rollTrait() {
|
||||||
if (this.parent?.actor?.type !== 'character') return null;
|
if (this.parent?.actor?.type !== 'character') return null;
|
||||||
switch (this.type) {
|
switch (this.type) {
|
||||||
|
|
@ -145,7 +127,6 @@ export default class RollField extends fields.EmbeddedDataField {
|
||||||
config.dialog.configure = RollField.getAutomation() ? !config.dialog.configure : config.dialog.configure;
|
config.dialog.configure = RollField.getAutomation() ? !config.dialog.configure : config.dialog.configure;
|
||||||
|
|
||||||
const roll = {
|
const roll = {
|
||||||
baseModifiers: this.roll.getModifier(),
|
|
||||||
label: 'Attack',
|
label: 'Attack',
|
||||||
type: this.roll?.type,
|
type: this.roll?.type,
|
||||||
trait: this.roll?.rollTrait,
|
trait: this.roll?.rollTrait,
|
||||||
|
|
|
||||||
|
|
@ -128,8 +128,30 @@ export default class D20Roll extends DHRoll {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getBaseModifiers() {
|
||||||
|
const modifiers = [];
|
||||||
|
const actor = foundry.utils.fromUuidSync(this.options.source.actor);
|
||||||
|
if (!actor) return modifiers;
|
||||||
|
switch (actor.type) {
|
||||||
|
case 'companion':
|
||||||
|
case 'adversary':
|
||||||
|
if (
|
||||||
|
this.options.roll.type === CONFIG.DH.GENERAL.rollTypes.attack.id ||
|
||||||
|
this.options.source.action === actor.system.attack.id
|
||||||
|
)
|
||||||
|
modifiers.push({
|
||||||
|
label: 'Bonus to Hit',
|
||||||
|
value: this.data.attack.roll.bonus ?? 0
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return modifiers;
|
||||||
|
}
|
||||||
|
|
||||||
applyBaseBonus() {
|
applyBaseBonus() {
|
||||||
const modifiers = foundry.utils.deepClone(this.options.roll.baseModifiers) ?? [];
|
const modifiers = this.getBaseModifiers();
|
||||||
|
|
||||||
modifiers.push(
|
modifiers.push(
|
||||||
...this.getBonus(
|
...this.getBonus(
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue