import { RdDActorSheet } from "./actor-sheet.js"; import { RdDSheetUtility } from "./rdd-sheet-utility.js"; import { RdDUtility } from "./rdd-utility.js"; export class RdDActorEntiteSheet extends RdDActorSheet { /** @override */ static get defaultOptions() { return mergeObject(super.defaultOptions, { classes: ["rdd", "sheet", "actor"], template: "systems/foundryvtt-reve-de-dragon/templates/actor-entite-sheet.html", width: 640, height: 720, tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "carac" }], dragDrop: [{ dragSelector: ".item-list .item", dropSelector: undefined }] }); } async getData() { let formData = await super.getData(); formData.resonances = this.actor.system.sante.resonnance.actors.map(actorId => game.actors.get(actorId)) .map(actor => { return { id: actor.id, name: actor.name, img: actor.img } }) return formData } /* -------------------------------------------- */ /** @override */ activateListeners(html) { super.activateListeners(html); // Everything below here is only needed if the sheet is editable if (!this.options.editable) return; // On competence change this.html.find('.creature-carac').change(async event => { let compName = event.currentTarget.attributes.compname.value; this.actor.updateCreatureCompetence(compName, "carac_value", parseInt(event.target.value)); }); this.html.find('.creature-niveau').change(async event => { let compName = event.currentTarget.attributes.compname.value; this.actor.updateCreatureCompetence(compName, "niveau", parseInt(event.target.value)); }); this.html.find('.creature-dommages').change(async event => { let compName = event.currentTarget.attributes.compname.value; this.actor.updateCreatureCompetence(compName, "dommages", parseInt(event.target.value)); }); this.html.find('.resonance-delete').click(async event => { const li = RdDSheetUtility.getEventElement(event); const actorId = li.data("actor-id"); if (actorId) { const actorResonance = game.actors.get(actorId); RdDUtility.confirmerSuppressionSubacteur(this, actorResonance, li, () => { console.log('Delete : ', actorId); this.removeSubacteur(actorId); RdDUtility.slideOnDelete(this, li); }); } }); } async removeSubacteur(actorId) { let newResonances = this.actor.system.sante.resonnance.actors.filter(id => id != actorId); await this.actor.update({ 'system.sante.resonnance.actors': newResonances }, { renderSheet: false }); } }