Added HitPoints on class for use on character

This commit is contained in:
WBHarry 2025-06-28 02:50:38 +02:00
parent c6cede40b2
commit ebdb330932
4 changed files with 17 additions and 8 deletions

View file

@ -1295,6 +1295,7 @@
"Severe": "Severe" "Severe": "Severe"
}, },
"Evasion": "Evasion", "Evasion": "Evasion",
"HitPoints": "Hit Points",
"ClassFeatures": "Class Features", "ClassFeatures": "Class Features",
"Subclasses": "Subclasses", "Subclasses": "Subclasses",
"Guide": { "Guide": {

View file

@ -30,7 +30,10 @@ export default class DhCharacter extends BaseDataActor {
return { return {
resources: new fields.SchemaField({ resources: new fields.SchemaField({
hitPoints: resourceField(6), hitPoints: new fields.SchemaField({
value: new foundry.data.fields.NumberField({ initial: 0, integer: true }),
bonus: new foundry.data.fields.NumberField({ initial: 0, integer: true })
}),
stress: resourceField(6), stress: resourceField(6),
hope: resourceField(6) hope: resourceField(6)
}), }),
@ -243,7 +246,7 @@ export default class DhCharacter extends BaseDataActor {
experience.total = experience.value + experience.bonus; experience.total = experience.value + experience.bonus;
} }
this.resources.hitPoints.maxTotal = this.resources.hitPoints.max + this.resources.hitPoints.bonus; this.resources.hitPoints.maxTotal = (this.class.value?.system?.hitPoints ?? 0) + this.resources.hitPoints.bonus;
this.resources.stress.maxTotal = this.resources.stress.max + this.resources.stress.bonus; this.resources.stress.maxTotal = this.resources.stress.max + this.resources.stress.bonus;
this.evasion.total = (this.class?.evasion ?? 0) + this.evasion.bonus; this.evasion.total = (this.class?.evasion ?? 0) + this.evasion.bonus;
this.proficiency.total = this.proficiency.value + this.proficiency.bonus; this.proficiency.total = this.proficiency.value + this.proficiency.bonus;

View file

@ -20,8 +20,14 @@ export default class DHClass extends BaseDataItem {
...super.defineSchema(), ...super.defineSchema(),
domains: new fields.ArrayField(new fields.StringField(), { max: 2 }), domains: new fields.ArrayField(new fields.StringField(), { max: 2 }),
classItems: new ForeignDocumentUUIDArrayField({ type: 'Item', required: false }), classItems: new ForeignDocumentUUIDArrayField({ type: 'Item', required: false }),
hitPoints: new fields.NumberField({
evasion: new fields.NumberField({ initial: 0, integer: true }), required: true,
integer: true,
min: 1,
initial: 5,
label: 'DAGGERHEART.Sheets.Class.HitPoints'
}),
evasion: new fields.NumberField({ initial: 0, integer: true, label: 'DAGGERHEART.Sheets.Class.Evasion' }),
hopeFeatures: new foundry.data.fields.ArrayField(new ActionField()), hopeFeatures: new foundry.data.fields.ArrayField(new ActionField()),
classFeatures: new foundry.data.fields.ArrayField(new ActionField()), classFeatures: new foundry.data.fields.ArrayField(new ActionField()),
subclasses: new ForeignDocumentUUIDArrayField({ type: 'Item', required: false }), subclasses: new ForeignDocumentUUIDArrayField({ type: 'Item', required: false }),

View file

@ -3,11 +3,10 @@
data-tab='{{tabs.settings.id}}' data-tab='{{tabs.settings.id}}'
data-group='{{tabs.settings.group}}' data-group='{{tabs.settings.group}}'
> >
<fieldset class="two-columns even">
<fieldset class="two-columns">
<legend>{{localize tabs.settings.label}}</legend> <legend>{{localize tabs.settings.label}}</legend>
<span>{{localize "DAGGERHEART.Sheets.Class.Evasion"}}</span> {{formGroup systemFields.hitPoints value=source.system.hitPoints localize=true}}
{{formField systemFields.evasion value=source.system.evasion}} {{formGroup systemFields.evasion value=source.system.evasion localize=true}}
</fieldset> </fieldset>
<div class="fieldsets-section"> <div class="fieldsets-section">