mirror of
https://github.com/Foundryborne/daggerheart.git
synced 2026-01-11 19:25:21 +01:00
* Updated the background image for the system * Fixed so Weapon/Armor features are added again * Fixed so fear is available as a resource to be deducted by actions (#757) * Changed to use the config labels and src * Updated Weapons * Fixed so the decrease button of simple fear tracker is not visible when not hovered * Fixed so armor preUpdate doesn't fail if no system changes are made * Updated .gitignore and author details (#777) * Add author details and name mapping for chrisryan10 (#773) Co-authored-by: Chris Ryan <chrisr@blackhole> * Add build to ignore for my linux dev (#775) Co-authored-by: Chris Ryan <chrisr@blackhole> --------- Co-authored-by: Chris Ryan <chrisr@blackhole> * Corrected sneak attack active effect (#780) * Fixed a spelling error (#779) * Fix bardic rally showing in damage dialog when it should not (#783) * update spelling (#786) * Translating inventory descriptions (#782) * updated credits for 1.0.1 release (#797) * updated credits for 1.0.1 release * further updated artwork credits * Chagned handlebarhelper rollparsed to be more defensive (#794) * Added missing scene refreshType (#790) * Remove ability use buttons for not owned abilities (#795) * [Fix] PrayerDice Fixed (#799) * Fixed prayer dice, and wheelchair images * Fixed -settings data sources * Dragging features from one adversary to another (#788) * [Fix] Levelup Fixes (#787) * Fixed crash on experience selection. Fixed subclass error on multiclassing * Fixed so multiclasses do not gain the hope feature for the class * Fixed so Class/Subclass features are properly deleted on delevel * Removed automatic deletion of features on delevel when not using levelup auto * Fixed so custom domains can be selected in levelup when multiclassing * Changed so encounter countdowns is a button (#804) * Fixed so that dropping on class/subclass...creates the item on the character (#803) * [BUG] - Importing All Adversaries/Environments (#814) Fixes #774 Co-authored-by: Joaquin Pereyra <joaquinpereyra98@users.noreply.github.com> * Bug/671 reaction roll chat title (#809) * Update Reaction Roll Chat Message Title * Removed console log --------- Co-authored-by: WBHarry <williambjrklund@gmail.com> * Improve Trait tooltip display (#817) Fixes #806 Co-authored-by: Joaquin Pereyra <joaquinpereyra98@users.noreply.github.com> * [BUG] - Combat Tracker d12 logo not found (#812) Fixes #764 Co-authored-by: Joaquin Pereyra <joaquinpereyra98@users.noreply.github.com> * Compendium Browser (#821) * Corrected timbending description localization (#816) * [Fix] Compendium Item (#810) * Corrected Emberwoven Armor * Fixed subclass regression * Fixed so character's with wildcard images don't break beastform (#815) * Fix roll result based duality damage (#822) --------- Co-authored-by: Chris Ryan <73275196+chrisryan10@users.noreply.github.com> Co-authored-by: Chris Ryan <chrisr@blackhole> Co-authored-by: Dapoulp <74197441+Dapoulp@users.noreply.github.com> Co-authored-by: IrkTheImp <41175833+IrkTheImp@users.noreply.github.com> Co-authored-by: CPTN_Cosmo <cptncosmo@gmail.com> Co-authored-by: Josh Q. <jshqntnr13@gmail.com> Co-authored-by: joaquinpereyra98 <24190917+joaquinpereyra98@users.noreply.github.com> Co-authored-by: Joaquin Pereyra <joaquinpereyra98@users.noreply.github.com>
75 lines
2.5 KiB
JavaScript
75 lines
2.5 KiB
JavaScript
import { itemAbleRollParse } from './utils.mjs';
|
|
|
|
export default class RegisterHandlebarsHelpers {
|
|
static registerHelpers() {
|
|
Handlebars.registerHelper({
|
|
add: this.add,
|
|
includes: this.includes,
|
|
times: this.times,
|
|
damageFormula: this.damageFormula,
|
|
formulaValue: this.formulaValue,
|
|
damageSymbols: this.damageSymbols,
|
|
rollParsed: this.rollParsed,
|
|
hasProperty: foundry.utils.hasProperty,
|
|
getProperty: foundry.utils.getProperty,
|
|
setVar: this.setVar,
|
|
empty: this.empty
|
|
});
|
|
}
|
|
static add(a, b) {
|
|
const aNum = Number.parseInt(a);
|
|
const bNum = Number.parseInt(b);
|
|
return (Number.isNaN(aNum) ? 0 : aNum) + (Number.isNaN(bNum) ? 0 : bNum);
|
|
}
|
|
|
|
static includes(list, item) {
|
|
return list.includes(item);
|
|
}
|
|
|
|
static times(nr, block) {
|
|
var accum = '';
|
|
for (var i = 0; i < nr; ++i) accum += block.fn(i);
|
|
return accum;
|
|
}
|
|
|
|
static damageFormula(attack, actor) {
|
|
const traitTotal = actor.system.traits?.[attack.roll.trait]?.value;
|
|
const instances = [
|
|
attack.damage.parts.map(x => Roll.replaceFormulaData(x.value.getFormula(), actor)).join(' + '),
|
|
traitTotal
|
|
].filter(x => x);
|
|
|
|
return instances.join(traitTotal > 0 ? ' + ' : ' - ');
|
|
}
|
|
|
|
static formulaValue(formula, item) {
|
|
if (isNaN(formula)) {
|
|
const data = item.getRollData.bind(item)(),
|
|
roll = new Roll(Roll.replaceFormulaData(formula, data)).evaluateSync();
|
|
formula = roll.total;
|
|
}
|
|
return formula;
|
|
}
|
|
|
|
static damageSymbols(damageParts) {
|
|
const symbols = [...new Set(damageParts.reduce((a, c) => a.concat([...c.type]), []))].map(
|
|
p => CONFIG.DH.GENERAL.damageTypes[p].icon
|
|
);
|
|
return new Handlebars.SafeString(Array.from(symbols).map(symbol => `<i class="fa-solid ${symbol}"></i>`));
|
|
}
|
|
|
|
static rollParsed(value, actor, item, numerical) {
|
|
const isNumerical = typeof numerical === 'boolean' ? numerical : false;
|
|
const result = itemAbleRollParse(value, actor?.getRollData() ?? {}, item);
|
|
return isNumerical ? (!result ? 0 : Number(result)) : result;
|
|
}
|
|
|
|
static setVar(name, value, context) {
|
|
this[name] = value;
|
|
}
|
|
|
|
static empty(object) {
|
|
if (!(typeof object === 'object')) return true;
|
|
return Object.keys(object).length === 0;
|
|
}
|
|
}
|