mirror of
https://github.com/Foundryborne/daggerheart.git
synced 2026-04-21 23:13:39 +02:00
.
This commit is contained in:
parent
60e38e5705
commit
59481d0d77
9 changed files with 52 additions and 21 deletions
|
|
@ -2487,6 +2487,7 @@
|
||||||
"step": "Step",
|
"step": "Step",
|
||||||
"stress": "Stress",
|
"stress": "Stress",
|
||||||
"subclasses": "Subclasses",
|
"subclasses": "Subclasses",
|
||||||
|
"subType": "Subtype",
|
||||||
"success": "Success",
|
"success": "Success",
|
||||||
"summon": {
|
"summon": {
|
||||||
"single": "Summon",
|
"single": "Summon",
|
||||||
|
|
|
||||||
|
|
@ -53,8 +53,23 @@ export default class LevelupOptionsDialog extends HandlebarsApplicationMixin(App
|
||||||
|
|
||||||
async _prepareContext(_options) {
|
async _prepareContext(_options) {
|
||||||
const context = await super._prepareContext(_options);
|
const context = await super._prepareContext(_options);
|
||||||
context.item = this.item;
|
|
||||||
context.fields = this.item.system.schema.fields.levelupOptionTiers.element.element.fields;
|
context.fields = this.item.system.schema.fields.levelupOptionTiers.element.element.fields;
|
||||||
|
context.item = this.item;
|
||||||
|
context.levelupOptionTiers = Object.keys(this.item.system.levelupOptionTiers).reduce((acc, key) => {
|
||||||
|
const tier = this.item.system.levelupOptionTiers[key];
|
||||||
|
acc[key] = Object.keys(tier).reduce((acc, key) => {
|
||||||
|
const option = tier[key];
|
||||||
|
acc[key] = {
|
||||||
|
...option,
|
||||||
|
typeData: option.type ? LevelOptionType[option.type] : null
|
||||||
|
};
|
||||||
|
|
||||||
|
return acc;
|
||||||
|
}, {});
|
||||||
|
|
||||||
|
return acc;
|
||||||
|
}, {})
|
||||||
|
|
||||||
context.optionTypes = LevelOptionType;
|
context.optionTypes = LevelOptionType;
|
||||||
context.selectedOption = this.selectedOption;
|
context.selectedOption = this.selectedOption;
|
||||||
|
|
||||||
|
|
@ -63,6 +78,7 @@ export default class LevelupOptionsDialog extends HandlebarsApplicationMixin(App
|
||||||
|
|
||||||
static async updateData(_event, _element, formData) {
|
static async updateData(_event, _element, formData) {
|
||||||
const data = foundry.utils.expandObject(formData.object);
|
const data = foundry.utils.expandObject(formData.object);
|
||||||
|
await this.item.update(data)
|
||||||
|
|
||||||
this.render();
|
this.render();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -527,7 +527,8 @@ export default class DhlevelUp extends HandlebarsApplicationMixin(ApplicationV2)
|
||||||
minCost: Number(button.dataset.cost),
|
minCost: Number(button.dataset.cost),
|
||||||
amount: button.dataset.amount ? Number(button.dataset.amount) : null,
|
amount: button.dataset.amount ? Number(button.dataset.amount) : null,
|
||||||
value: button.dataset.value,
|
value: button.dataset.value,
|
||||||
type: button.dataset.type
|
type: button.dataset.type,
|
||||||
|
subType: button.dataset.subType
|
||||||
};
|
};
|
||||||
|
|
||||||
if (button.dataset.type === 'domainCard') {
|
if (button.dataset.type === 'domainCard') {
|
||||||
|
|
|
||||||
|
|
@ -766,8 +766,8 @@ export default class DhCharacter extends DhCreature {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case 'comboStrikes':
|
case 'dice':
|
||||||
this.rules.roll.comboDieIndex += 1;
|
this.rules.roll[selection.subType] += 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -41,6 +41,7 @@ export default class DhLevelData extends foundry.abstract.DataModel {
|
||||||
level: new fields.NumberField({ required: true, integer: true }),
|
level: new fields.NumberField({ required: true, integer: true }),
|
||||||
optionKey: new fields.StringField({ required: true }),
|
optionKey: new fields.StringField({ required: true }),
|
||||||
type: new fields.StringField({ required: true, choices: LevelOptionType }),
|
type: new fields.StringField({ required: true, choices: LevelOptionType }),
|
||||||
|
subType: new fields.StringField({ nullable: true }),
|
||||||
checkboxNr: new fields.NumberField({ required: true, integer: true }),
|
checkboxNr: new fields.NumberField({ required: true, integer: true }),
|
||||||
value: new fields.NumberField({ integer: true }),
|
value: new fields.NumberField({ integer: true }),
|
||||||
minCost: new fields.NumberField({ integer: true }),
|
minCost: new fields.NumberField({ integer: true }),
|
||||||
|
|
|
||||||
|
|
@ -69,6 +69,10 @@ export class DhLevelOption extends foundry.abstract.DataModel {
|
||||||
choices: LevelOptionType,
|
choices: LevelOptionType,
|
||||||
label: 'DAGGERHEART.GENERAL.type'
|
label: 'DAGGERHEART.GENERAL.type'
|
||||||
}),
|
}),
|
||||||
|
subType: new fields.StringField({
|
||||||
|
nullable: true,
|
||||||
|
label: 'DAGGERHEART.GENERAL.subType',
|
||||||
|
}),
|
||||||
value: new fields.NumberField({
|
value: new fields.NumberField({
|
||||||
integer: true,
|
integer: true,
|
||||||
label: 'DAGGERHEART.GENERAL.value'
|
label: 'DAGGERHEART.GENERAL.value'
|
||||||
|
|
@ -136,13 +140,6 @@ export const CompanionLevelOptionType = {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
export const ClassLevelOptionTypes = {
|
|
||||||
comboStrikes: {
|
|
||||||
id: 'comboStrikes',
|
|
||||||
label: 'Increase your Combo Die size',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
export const LevelOptionType = {
|
export const LevelOptionType = {
|
||||||
trait: {
|
trait: {
|
||||||
id: 'trait',
|
id: 'trait',
|
||||||
|
|
@ -192,7 +189,16 @@ export const LevelOptionType = {
|
||||||
id: 'multiclass',
|
id: 'multiclass',
|
||||||
label: 'Multiclass'
|
label: 'Multiclass'
|
||||||
},
|
},
|
||||||
...ClassLevelOptionTypes,
|
dice: {
|
||||||
|
id: 'dice',
|
||||||
|
label: 'Increase Dice Size',
|
||||||
|
subTypes: {
|
||||||
|
hopeIndex: { key: 'hopeIndex', label: 'DAGGERHEART.GENERAL.hope' },
|
||||||
|
fearIndex: { key: 'fearIndex', label: 'DAGGERHEART.GENERAL.fear' },
|
||||||
|
advantageIndex: { key: 'advantageIndex', label: 'DAGGERHEART.GENERAL.Advantage.full' },
|
||||||
|
comboDieIndex:{ key: 'comboDieIndex', label: 'Combo Die' } // Translation pending actual useage
|
||||||
|
},
|
||||||
|
},
|
||||||
...CompanionLevelOptionType
|
...CompanionLevelOptionType
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -90,6 +90,7 @@ export class DhLevelup extends foundry.abstract.DataModel {
|
||||||
checkboxSelections: new fields.NumberField({ required: true, integer: true }),
|
checkboxSelections: new fields.NumberField({ required: true, integer: true }),
|
||||||
minCost: new fields.NumberField({ required: true, integer: true }),
|
minCost: new fields.NumberField({ required: true, integer: true }),
|
||||||
type: new fields.StringField({ required: true, choices: LevelOptionType }),
|
type: new fields.StringField({ required: true, choices: LevelOptionType }),
|
||||||
|
subType: new fields.StringField({ nullable: true }),
|
||||||
value: new fields.NumberField({ integer: true }),
|
value: new fields.NumberField({ integer: true }),
|
||||||
amount: new fields.NumberField({ integer: true })
|
amount: new fields.NumberField({ integer: true })
|
||||||
})
|
})
|
||||||
|
|
@ -242,7 +243,7 @@ export class DhLevelup extends foundry.abstract.DataModel {
|
||||||
const checkboxes = [...Array(option.checkboxSelections).keys()].flatMap(index => {
|
const checkboxes = [...Array(option.checkboxSelections).keys()].flatMap(index => {
|
||||||
const checkboxNr = index + 1;
|
const checkboxNr = index + 1;
|
||||||
const checkboxData = selections[tierKey]?.[optionKey]?.[checkboxNr];
|
const checkboxData = selections[tierKey]?.[optionKey]?.[checkboxNr];
|
||||||
const checkbox = { ...option, checkboxNr, tier: tierKey };
|
const checkbox = { ...option, checkboxNr, tier: tierKey, option: optionKey };
|
||||||
|
|
||||||
if (checkboxData) {
|
if (checkboxData) {
|
||||||
checkbox.level = checkboxData.level;
|
checkbox.level = checkboxData.level;
|
||||||
|
|
@ -343,7 +344,8 @@ export class DhLevelupLevel extends foundry.abstract.DataModel {
|
||||||
value: new fields.StringField(),
|
value: new fields.StringField(),
|
||||||
data: new fields.ArrayField(new fields.StringField()),
|
data: new fields.ArrayField(new fields.StringField()),
|
||||||
secondaryData: new fields.TypedObjectField(new fields.StringField()),
|
secondaryData: new fields.TypedObjectField(new fields.StringField()),
|
||||||
type: new fields.StringField({ required: true })
|
type: new fields.StringField({ required: true }),
|
||||||
|
subType: new fields.StringField({ nullable: true }),
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -5,18 +5,21 @@
|
||||||
</select>
|
</select>
|
||||||
<button data-action="addTierOption" data-tier="{{tab.tier}}" {{#unless selectedOption}}disabled{{/unless}}>{{localize "Add Levelup Option"}}</button>
|
<button data-action="addTierOption" data-tier="{{tab.tier}}" {{#unless selectedOption}}disabled{{/unless}}>{{localize "Add Levelup Option"}}</button>
|
||||||
</div>
|
</div>
|
||||||
{{#with (lookup item.system.levelupOptionTiers tab.tier)}}
|
{{#with (lookup levelupOptionTiers tab.tier)}}
|
||||||
{{#unless (empty this)}}
|
{{#unless (empty this)}}
|
||||||
{{#each this as |option key|}}
|
{{#each this as |option key|}}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend><a data-action="removeTierOption" data-tier="{{../../tab.tier}}" data-key="{{key}}"><i class="fa-solid fa-trash"></i></a></legend>
|
<legend><a data-action="removeTierOption" data-tier="{{../../tab.tier}}" data-key="{{key}}"><i class="fa-solid fa-trash"></i></a></legend>
|
||||||
|
|
||||||
<div class="tier-container">
|
<div class="tier-container">
|
||||||
{{formGroup @root.fields.label value=option.label name=(concat "system.levelOptionTiers." ../../tab.tier "." key ".label") localize=true }}
|
{{formGroup @root.fields.label value=option.label name=(concat "system.levelupOptionTiers." ../../tab.tier "." key ".label") localize=true }}
|
||||||
{{formGroup @root.fields.type value=option.type name=(concat "system.levelOptionTiers." ../../tab.tier "." key ".type") localize=true }}
|
{{formGroup @root.fields.type value=option.type name=(concat "system.levelupOptionTiers." ../../tab.tier "." key ".type") localize=true }}
|
||||||
<div class="two-columns even">
|
<div class="nest-inputs">
|
||||||
{{formGroup @root.fields.checkboxSelections value=option.checkboxSelections name=(concat "system.levelOptionTiers." ../../tab.tier "." key ".checkboxSelections") localize=true }}
|
{{formGroup @root.fields.checkboxSelections value=option.checkboxSelections name=(concat "system.levelupOptionTiers." ../../tab.tier "." key ".checkboxSelections") localize=true }}
|
||||||
{{formGroup @root.fields.minCost value=option.minCost name=(concat "system.levelOptionTiers." ../../tab.tier "." key ".minCost") localize=true }}
|
{{formGroup @root.fields.minCost value=option.minCost name=(concat "system.levelupOptionTiers." ../../tab.tier "." key ".minCost") localize=true }}
|
||||||
|
{{#if option.typeData}}
|
||||||
|
{{formGroup @root.fields.subType value=option.subType name=(concat "system.levelupOptionTiers." ../../tab.tier "." key ".subType") choices=option.typeData.subTypes localize=true }}
|
||||||
|
{{/if}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
|
|
|
||||||
|
|
@ -19,12 +19,13 @@
|
||||||
type="checkbox" class="selection-checkbox{{#if (gt this.cost 1)}} multi{{/if}}" {{checked this.selected}} {{#if this.disabled}}disabled{{/if}}
|
type="checkbox" class="selection-checkbox{{#if (gt this.cost 1)}} multi{{/if}}" {{checked this.selected}} {{#if this.disabled}}disabled{{/if}}
|
||||||
data-tier="{{this.tier}}"
|
data-tier="{{this.tier}}"
|
||||||
data-level="{{this.level}}"
|
data-level="{{this.level}}"
|
||||||
data-option="{{this.type}}"
|
data-option="{{this.option}}"
|
||||||
data-checkbox-nr="{{this.checkboxNr}}"
|
data-checkbox-nr="{{this.checkboxNr}}"
|
||||||
data-cost="{{this.minCost}}"
|
data-cost="{{this.minCost}}"
|
||||||
data-amount="{{this.amount}}"
|
data-amount="{{this.amount}}"
|
||||||
data-value="{{this.value}}"
|
data-value="{{this.value}}"
|
||||||
data-type="{{this.type}}"
|
data-type="{{this.type}}"
|
||||||
|
data-sub-type="{{this.subType}}"
|
||||||
/>
|
/>
|
||||||
{{/each}}
|
{{/each}}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue