Added VaultActive and LoadoutIgnore

This commit is contained in:
WBHarry 2026-01-11 11:03:06 +01:00
parent 0b343c9f52
commit 7429369212
19 changed files with 62 additions and 39 deletions

View file

@ -2294,6 +2294,8 @@
"DomainCard": {
"type": "Type",
"recallCost": "Recall Cost",
"vaultActive": "Active In Vault",
"loadoutIgnore": "Doesn't Count For Loadout",
"foundationTitle": "Foundation",
"specializationTitle": "Specialization",
"masteryTitle": "Mastery"

View file

@ -33,7 +33,7 @@ export default class CharacterSheet extends DHBaseActorSheet {
advanceResourceDie: CharacterSheet.#advanceResourceDie,
cancelBeastform: CharacterSheet.#cancelBeastform,
useDowntime: this.useDowntime,
viewParty: CharacterSheet.#viewParty,
viewParty: CharacterSheet.#viewParty
},
window: {
resizable: true,
@ -338,15 +338,20 @@ export default class CharacterSheet extends DHBaseActorSheet {
}
const type = 'effect';
const cls = game.system.api.models.actions.actionsTypes[type];
const action = new cls({
...cls.getSourceConfig(doc.system),
type: type,
chatDisplay: false,
cost: [{
key: 'stress',
value: doc.system.recallCost
}]
}, { parent: doc.system });
const action = new cls(
{
...cls.getSourceConfig(doc.system),
type: type,
chatDisplay: false,
cost: [
{
key: 'stress',
value: doc.system.recallCost
}
]
},
{ parent: doc.system }
);
const config = await action.use(event);
if (config) {
return doc.update({ 'system.inVault': false });
@ -822,7 +827,7 @@ export default class CharacterSheet extends DHBaseActorSheet {
static async #toggleVault(_event, button) {
const doc = await getDocFromElement(button);
const { available } = this.document.system.loadoutSlot;
if (doc.system.inVault && !available) {
if (doc.system.inVault && !available && !doc.system.loadoutIgnore) {
return ui.notifications.warn(game.i18n.localize('DAGGERHEART.UI.Notifications.loadoutMaxReached'));
}
@ -900,32 +905,32 @@ export default class CharacterSheet extends DHBaseActorSheet {
return;
}
const buttons = parties.map((p) => {
const button = document.createElement("button");
button.type = "button";
button.classList.add("plain");
const img = document.createElement("img");
const buttons = parties.map(p => {
const button = document.createElement('button');
button.type = 'button';
button.classList.add('plain');
const img = document.createElement('img');
img.src = p.img;
button.append(img);
const name = document.createElement("span");
const name = document.createElement('span');
name.textContent = p.name;
button.append(name);
button.addEventListener("click", () => {
button.addEventListener('click', () => {
p.sheet?.render({ force: true });
game.tooltip.dismissLockedTooltips();
});
return button;
});
const html = document.createElement("div");
html.classList.add("party-list");
const html = document.createElement('div');
html.classList.add('party-list');
html.append(...buttons);
game.tooltip.dismissLockedTooltips();
game.tooltip.activate(target, {
html,
locked: true,
})
locked: true
});
}
/**

View file

@ -29,7 +29,17 @@ export default class DHDomainCard extends BaseDataItem {
required: true,
initial: CONFIG.DH.DOMAIN.cardTypes.ability.id
}),
inVault: new fields.BooleanField({ initial: false })
inVault: new fields.BooleanField({ initial: false }),
vaultActive: new fields.BooleanField({
required: true,
nullable: false,
initial: false
}),
loadoutIgnore: new fields.BooleanField({
required: true,
nullable: false,
initial: false
})
};
}

View file

@ -20,7 +20,7 @@ export default class DhActiveEffect extends foundry.documents.ActiveEffect {
}
if (this.parent?.type === 'domainCard') {
return this.parent.system.inVault;
return this.parent.system.inVault && !this.parent.system.vaultActive;
}
return super.isSuppressed;

View file

@ -18,7 +18,7 @@
},
"flags": {},
"_id": "BFWN2cObMdlk9uVz",
"sort": 3400000,
"sort": 3500000,
"effects": [
{
"name": "Get Back Up",

View file

@ -44,7 +44,8 @@
"source": "Daggerheart SRD",
"page": 127,
"artist": ""
}
},
"loadoutIgnore": true
},
"flags": {},
"_id": "IqxzvvjZiYbgx21A",

View file

@ -95,7 +95,7 @@
},
"flags": {},
"_id": "4uAFGp3LxiC07woC",
"sort": 3400000,
"sort": 3500000,
"effects": [],
"ownership": {
"default": 0

View file

@ -51,7 +51,8 @@
"source": "Daggerheart SRD",
"page": 121,
"artist": ""
}
},
"vaultActive": true
},
"flags": {},
"_id": "sWUlSPOJEaXyQLCj",

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "7pKKYgRQAKlQAksV",
"description": "",
"sort": 1000000,
"sort": 950000,
"flags": {},
"_key": "!folders!7pKKYgRQAKlQAksV"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "9Xc6KzNyjDtTGZkp",
"description": "",
"sort": 100000,
"sort": 700000,
"flags": {},
"_key": "!folders!9Xc6KzNyjDtTGZkp"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "o7t2fsAmRxKLoHrO",
"description": "",
"sort": 200000,
"sort": 800000,
"flags": {},
"_key": "!folders!o7t2fsAmRxKLoHrO"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "wWL9mV6i2EGX5xHS",
"description": "",
"sort": 300000,
"sort": 850000,
"flags": {},
"_key": "!folders!wWL9mV6i2EGX5xHS"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "yalAnCU3SndrYImF",
"description": "",
"sort": 400000,
"sort": 900000,
"flags": {},
"_key": "!folders!yalAnCU3SndrYImF"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "Emnx4o1DWGTVKoAg",
"description": "",
"sort": 500000,
"sort": 901563,
"flags": {},
"_key": "!folders!Emnx4o1DWGTVKoAg"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "EiP5dLozOFZKIeWN",
"description": "",
"sort": 600000,
"sort": 903125,
"flags": {},
"_key": "!folders!EiP5dLozOFZKIeWN"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "HAGbPLHwm0UozDeG",
"description": "",
"sort": 700000,
"sort": 906250,
"flags": {},
"_key": "!folders!HAGbPLHwm0UozDeG"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "me7ywrVh38j6T8Sm",
"description": "",
"sort": 800000,
"sort": 912500,
"flags": {},
"_key": "!folders!me7ywrVh38j6T8Sm"
}

View file

@ -6,7 +6,7 @@
"sorting": "a",
"_id": "QYdeGsmVYIF34kZR",
"description": "",
"sort": 900000,
"sort": 925000,
"flags": {},
"_key": "!folders!QYdeGsmVYIF34kZR"
}

View file

@ -14,6 +14,10 @@
{{formField systemFields.level value=source.system.level data-dtype="Number"}}
<span>{{localize "DAGGERHEART.ITEMS.DomainCard.recallCost"}}</span>
{{formField systemFields.recallCost value=source.system.recallCost data-dtype="Number"}}
<span>{{localize "DAGGERHEART.ITEMS.DomainCard.vaultActive"}}</span>
{{formField systemFields.vaultActive value=source.system.vaultActive}}
<span>{{localize "DAGGERHEART.ITEMS.DomainCard.loadoutIgnore"}}</span>
{{formField systemFields.loadoutIgnore value=source.system.loadoutIgnore}}
</fieldset>
{{> "systems/daggerheart/templates/sheets/global/partials/resource-section/resource-section.hbs" }}