/* -------------------------------------------- */ export class RdDTMRRencontreDialog extends Dialog { /* -------------------------------------------- */ constructor(html, tmrApp, rencontre, postRencontre) { const dialogConf = { title: "Rencontre en TMR!", content: "Vous recontrez un " + rencontre.name + " de force " + rencontre.force + "<br>", buttons: { derober: { icon: '<i class="fas fa-check"></i>', label: "Se dérober", callback: () => { this.onButtonFuir(() => tmrApp.derober()); } }, refouler: { icon: '<i class="fas fa-check"></i>', label: "Refouler", callback: () => this.onButtonAction(() => tmrApp.refouler()) }, maitiser: { icon: '<i class="fas fa-check"></i>', label: "Maîtriser", callback: () => this.onButtonAction(() => tmrApp.maitriserRencontre()) } }, default: "derober" }; if (rencontre.ignorer) { dialogConf.buttons.ignorer = { icon: '<i class="fas fa-check"></i>', label: "Ignorer", callback: () => this.onButtonAction(() => tmrApp.ignorerRencontre()) } }; const dialogOptions = { classes: ["tmrrencdialog"], width: 320, height: 240, 'z-index': 50 } super(dialogConf, dialogOptions); this.toClose = false; this.rencontreData = duplicate(rencontre); this.postRencontre = postRencontre; this.tmrApp = tmrApp; this.tmrApp.minimize(); } async onButtonAction(action) { this.toClose = true; await action(); this.postRencontre(); } async onButtonFuir(action) { this.toClose = true; await action(); } /* -------------------------------------------- */ close() { if (this.toClose) { this.tmrApp.maximize(); return super.close(); } ui.notifications.info("Vous devez résoudre la rencontre."); } }