Merge branch 'main' into feature/death-moves

This commit is contained in:
Chris Ryan 2026-01-16 20:30:05 +10:00
commit 6ea09551fe
19 changed files with 49 additions and 173 deletions

View file

@ -712,7 +712,7 @@ export default class CharacterSheet extends DHBaseActorSheet {
headerTitle: game.i18n.format('DAGGERHEART.UI.Chat.dualityRoll.abilityCheckTitle', { headerTitle: game.i18n.format('DAGGERHEART.UI.Chat.dualityRoll.abilityCheckTitle', {
ability: abilityLabel ability: abilityLabel
}), }),
effects: Array.from(await this.document.allApplicableEffects()), effects: await game.system.api.data.actions.actionsTypes.base.getEffects(this.document),
roll: { roll: {
trait: button.dataset.attribute, trait: button.dataset.attribute,
type: 'trait' type: 'trait'

View file

@ -505,7 +505,10 @@ export default function DHApplicationMixin(Base) {
const doc = await getDocFromElement(target), const doc = await getDocFromElement(target),
action = doc?.system?.attack ?? doc; action = doc?.system?.attack ?? doc;
const config = action.prepareConfig(event); const config = action.prepareConfig(event);
config.effects = Array.from(await this.document.allApplicableEffects()); config.effects = await game.system.api.data.actions.actionsTypes.base.getEffects(
this.document,
doc
);
config.hasRoll = false; config.hasRoll = false;
return action && action.workflow.get('damage').execute(config, null, true); return action && action.workflow.get('damage').execute(config, null, true);
} }

View file

@ -198,7 +198,7 @@ export default class DHBaseAction extends ActionMixin(foundry.abstract.DataModel
let config = this.prepareConfig(event); let config = this.prepareConfig(event);
if (!config) return; if (!config) return;
await this.addEffects(config); config.effects = await game.system.api.data.actions.actionsTypes.base.getEffects(this.actor, this.item);
if (Hooks.call(`${CONFIG.DH.id}.preUseAction`, this, config) === false) return; if (Hooks.call(`${CONFIG.DH.id}.preUseAction`, this, config) === false) return;
@ -266,14 +266,26 @@ export default class DHBaseAction extends ActionMixin(foundry.abstract.DataModel
return config; return config;
} }
/** */ /**
async addEffects(config) { * Get the all potentially applicable effects on the actor
let effects = []; * @param {DHActor} actor The actor performing the action
if (this.actor) { * @param {DHItem|DhActor} effectParent The parent of the effect
effects = Array.from(await this.actor.allApplicableEffects()); * @returns {DhActiveEffect[]}
} */
static async getEffects(actor, effectParent) {
if (!actor) return [];
config.effects = effects; return Array.from(await actor.allApplicableEffects()).filter(effect => {
/* Effects on weapons only ever apply for the weapon itself */
if (effect.parent.type === 'weapon') {
/* Unless they're secondary - then they apply only to other primary weapons */
if (effect.parent.system.secondary) {
if (effectParent?.type !== 'weapon' || effectParent?.system.secondary) return false;
} else if (effectParent?.id !== effect.parent.id) return false;
}
return !effect.isSuppressed;
});
} }
/** /**

View file

@ -167,7 +167,9 @@ export default class DhpChatMessage extends foundry.documents.ChatMessage {
const config = foundry.utils.deepClone(this.system); const config = foundry.utils.deepClone(this.system);
config.event = event; config.event = event;
if (this.system.action) { if (this.system.action) {
await this.system.action.addEffects(config); const actor = await foundry.utils.fromUuid(config.source.actor);
const item = actor?.items.get(config.source.item) ?? null;
config.effects = await game.system.api.data.actions.actionsTypes.base.getEffects(actor, item);
await this.system.action.workflow.get('damage')?.execute(config, this._id, true); await this.system.action.workflow.get('damage')?.execute(config, this._id, true);
} }
@ -201,7 +203,16 @@ export default class DhpChatMessage extends foundry.documents.ChatMessage {
return ui.notifications.info(game.i18n.localize('DAGGERHEART.UI.Notifications.noTargetsSelectedOrPerm')); return ui.notifications.info(game.i18n.localize('DAGGERHEART.UI.Notifications.noTargetsSelectedOrPerm'));
this.consumeOnSuccess(); this.consumeOnSuccess();
this.system.action?.workflow.get('applyDamage')?.execute(config, targets, true); if (this.system.action) this.system.action.workflow.get('applyDamage')?.execute(config, targets, true);
else {
for (const target of targets) {
const actor = await foundry.utils.fromUuid(target.actorId);
if (!actor) continue;
if (this.system.hasHealing) actor.takeHealing(this.system.damage);
else actor.takeDamage(this.system.damage);
}
}
} }
async onRollSave(event) { async onRollSave(event) {

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "sGVVxSM68Fmr1sSM", "_id": "sGVVxSM68Fmr1sSM",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -118,16 +118,6 @@
"key": "system.evasion", "key": "system.evasion",
"mode": 2, "mode": 2,
"value": "-1" "value": "-1"
},
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
} }
], ],
"_id": "E0PjC15OP55vIype", "_id": "E0PjC15OP55vIype",

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "DCie5eR1dZH2Qvln", "_id": "DCie5eR1dZH2Qvln",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "sZ1XotFlGdkPPDG4", "_id": "sZ1XotFlGdkPPDG4",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "T831j6kZiMnpMNmv", "_id": "T831j6kZiMnpMNmv",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "ir4iKLIQ4CH1Qckn", "_id": "ir4iKLIQ4CH1Qckn",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "K4VgrDjVj1U1m9Ie", "_id": "K4VgrDjVj1U1m9Ie",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "904orawScurM9GjG", "_id": "904orawScurM9GjG",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -118,16 +118,6 @@
"key": "system.evasion", "key": "system.evasion",
"mode": 2, "mode": 2,
"value": "-1" "value": "-1"
},
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
} }
], ],
"_id": "cffkpiwGpEGhjiUC", "_id": "cffkpiwGpEGhjiUC",

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "hnayB09P25ZW3gVY", "_id": "hnayB09P25ZW3gVY",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -118,16 +118,6 @@
"key": "system.evasion", "key": "system.evasion",
"mode": 2, "mode": 2,
"value": "-1" "value": "-1"
},
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
} }
], ],
"_id": "2nl35v8sPAudiOIb", "_id": "2nl35v8sPAudiOIb",

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "OV1Ly7vX4owBUgLQ", "_id": "OV1Ly7vX4owBUgLQ",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -118,16 +118,6 @@
"key": "system.evasion", "key": "system.evasion",
"mode": 2, "mode": 2,
"value": "-1" "value": "-1"
},
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
} }
], ],
"_id": "oRCiXSElN5xufUfn", "_id": "oRCiXSElN5xufUfn",

View file

@ -113,18 +113,7 @@
"name": "Powerful", "name": "Powerful",
"description": "On a successful attack, roll an additional damage die and discard the lowest result.", "description": "On a successful attack, roll an additional damage die and discard the lowest result.",
"img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp", "img": "icons/magic/control/buff-flight-wings-runes-red-yellow.webp",
"changes": [ "changes": [],
{
"key": "system.bonuses.damage.primaryWeapon.extraDice",
"mode": 2,
"value": "1"
},
{
"key": "system.rules.weapon.dropLowestDamageDice",
"mode": 5,
"value": "1"
}
],
"_id": "2J6vzNUel78JFypp", "_id": "2J6vzNUel78JFypp",
"type": "base", "type": "base",
"system": {}, "system": {},

View file

@ -2,7 +2,7 @@
"id": "daggerheart", "id": "daggerheart",
"title": "Daggerheart", "title": "Daggerheart",
"description": "An unofficial implementation of the Daggerheart system", "description": "An unofficial implementation of the Daggerheart system",
"version": "1.5.1", "version": "1.5.2",
"compatibility": { "compatibility": {
"minimum": "13.346", "minimum": "13.346",
"verified": "13.351", "verified": "13.351",