This commit is contained in:
WBHarry 2026-01-07 19:14:17 +01:00
parent e22928b59e
commit f5e00dedb2
2 changed files with 47 additions and 66 deletions

View file

@ -1,50 +1,41 @@
import DHSummonField from '../fields/action/summonField.mjs';
import DHBaseAction from './baseAction.mjs'; import DHBaseAction from './baseAction.mjs';
import DHSummonDialog from '../../applications/dialogs/summonDialog.mjs';
export default class DHSummonAction extends DHBaseAction { export default class DHSummonAction extends DHBaseAction {
static defineSchema() {
return {
...super.defineSchema(),
summon: new DHSummonField({ required: false, initial: [] })
};
}
static extraSchemas = [...super.extraSchemas, 'summon']; static extraSchemas = [...super.extraSchemas, 'summon'];
get defaultValues() { // get defaultValues() {
return { // return {
summon: [] // summon: []
}; // };
} // }
async trigger(event, ...args) { // async trigger(event, ...args) {
if (!this.canSummon || !canvas.scene){ // if (!this.canSummon || !canvas.scene){
ui.notifications.warn(game.i18n.localize("DAGGERHEART.ACTIONS.TYPES.summon.error")); // ui.notifications.warn(game.i18n.localize("DAGGERHEART.ACTIONS.TYPES.summon.error"));
return; // return;
} // }
await this._performAction(); // await this._performAction();
} // }
get canSummon() { // get canSummon() {
return game.user.can('TOKEN_CREATE'); // return game.user.can('TOKEN_CREATE');
} // }
async _performAction(event, ...args) { // async _performAction(event, ...args) {
const validSummons = this.summon.filter(entry => entry.actorUUID); // const validSummons = this.summon.filter(entry => entry.actorUUID);
if (validSummons.length === 0) { // if (validSummons.length === 0) {
ui.notifications.warn("No actors configured for this Summon action."); // ui.notifications.warn("No actors configured for this Summon action.");
return; // return;
} // }
// FOR NOW: Just log the data to prove the schema working or not // // FOR NOW: Just log the data to prove the schema working or not
console.group("Summon Action Triggered"); // console.group("Summon Action Triggered");
for (const entry of validSummons) { // for (const entry of validSummons) {
const actor = await fromUuid(entry.actorUUID); // const actor = await fromUuid(entry.actorUUID);
console.log(`- Ready to summon ${entry.count}x [${actor?.name || "Unknown Actor"}]`); // console.log(`- Ready to summon ${entry.count}x [${actor?.name || "Unknown Actor"}]`);
} // }
console.groupEnd(); // console.groupEnd();
//Todo: Open Summon Dialog // //Todo: Open Summon Dialog
} // }
} }

View file

@ -18,21 +18,11 @@ export default class DHSummonField extends fields.ArrayField {
min: 1, min: 1,
integer: true integer: true
}) })
}) });
super(summonFields, options, context); super(summonFields, options, context);
// summon: new fields.ArrayField(new fields.SchemaField({
// actorUUID: new fields.DocumentUUIDField({
// type: 'Actor',
// required: true }),
// count: new fields.NumberField({
// required: true,
// default: 1,
// min: 1,
// integer: true })
// }), { required: false, initial: [] })
// };
// super(summonFields, options, context);
} }
static async execute(config) {
console.log('something');
}
} }