diff --git a/module/actor.js b/module/actor.js index de93a0ae..b5528565 100644 --- a/module/actor.js +++ b/module/actor.js @@ -2274,6 +2274,9 @@ export class RdDActor extends Actor { rollData.show = {} rollData.depenseReve = Number(selectedSort.data.ptreve_reel); + if (rollData.competence.name.includes('Thanatos')) { // Si Thanatos + await this.update({ "data.reve.reve.thanatosused": true }); + } let reveActuel = Misc.templateData(this).reve.reve.value; if (rolled.isSuccess) { // Réussite du sort ! if (rolled.isPart) { @@ -2282,9 +2285,6 @@ export class RdDActor extends Actor { if (rollData.isSortReserve) { rollData.depenseReve++; } - if (rollData.competence.name.includes('Thanatos')) { // Si Thanatos - await this.update({ "data.reve.reve.thanatosused": true }); - } if (reveActuel > rollData.depenseReve) { // Incrémenter/gére le bonus de case RdDItemSort.incrementBonusCase(this, selectedSort, rollData.tmr.coord); diff --git a/module/chat-utility.js b/module/chat-utility.js index 06eb5fac..8379e146 100644 --- a/module/chat-utility.js +++ b/module/chat-utility.js @@ -40,7 +40,9 @@ export class ChatUtility { } static removeChatMessageId(messageId) { - ChatUtility.removeMessages({ messageId: messageId }); + if (messageId){ + ChatUtility.removeMessages({ messageId: messageId }); + } } /* -------------------------------------------- */ diff --git a/module/dialog-item-achat.js b/module/dialog-item-achat.js index a6948347..ae1f0e5e 100644 --- a/module/dialog-item-achat.js +++ b/module/dialog-item-achat.js @@ -76,10 +76,10 @@ export class DialogItemAchat extends Dialog { activateListeners(html) { super.activateListeners(html); - html.find(".nombreLots").change(event => this.setnombreLots(Number(event.currentTarget.value))); + html.find(".nombreLots").change(event => this.setNombreLots(Number(event.currentTarget.value))); } - setnombreLots(nombreLots) { + setNombreLots(nombreLots) { this.venteData.nombreLots = nombreLots; this.venteData.prixTotal = (nombreLots * this.venteData.prixLot).toFixed(2); $(".prixTotal").text(this.venteData.prixTotal); diff --git a/module/rdd-combat.js b/module/rdd-combat.js index 0fb909b4..cacc3dd1 100644 --- a/module/rdd-combat.js +++ b/module/rdd-combat.js @@ -357,6 +357,8 @@ export class RdDCombat { return RdDCombat.onMsgEncaisser(sockmsg.data); case "msg_defense": return RdDCombat.onMsgDefense(sockmsg.data); + case "msg_combat_passearme": + return RdDCombat.onMsgPasseArme(sockmsg.data); } } @@ -391,9 +393,11 @@ export class RdDCombat { /* -------------------------------------------- */ static combatNouveauTour(combat) { if (Misc.isElectedUser()) { - let turn = combat.turns.find(t => t.tokenId == combat.current.tokenId); - this.displayActorCombatStatus(combat, turn.actor); - // TODO Playaudio for player?? + let turn = combat.turns.find(t => t.token?.id == combat.current.tokenId); + if (turn?.actor) { + RdDCombat.displayActorCombatStatus(combat, turn.actor); + // TODO Playaudio for player?? + } } } @@ -427,9 +431,31 @@ export class RdDCombat { return undefined; } + static messagePasseArme(data) { + game.socket.emit("system.foundryvtt-reve-de-dragon", { msg: "msg_combat_passearme", data: data }); + RdDCombat.onMsgPasseArme(data); + } + + static onMsgPasseArme(data) { + switch (data.actionPasseArme) { + case "store-attaque": + game.system.rdd.combatStore.attaques[data.id] = data.rollData; + break; + case "store-defense": + game.system.rdd.combatStore.defenses[data.id] = data.rollData; + break; + case "delete-attaque": + delete game.system.rdd.combatStore.attaques[data.id]; + break; + case "delete-defense": + delete game.system.rdd.combatStore.defenses[data.id]; + break; + } + } + /* -------------------------------------------- */ static _storeAttaque(attackerId, attackerRoll) { - game.system.rdd.combatStore.attaques[attackerId] = duplicate(attackerRoll); + RdDCombat.messagePasseArme({ actionPasseArme: "store-attaque", id: attackerId, rollData: attackerRoll }); } /* -------------------------------------------- */ @@ -439,12 +465,12 @@ export class RdDCombat { /* -------------------------------------------- */ static _deleteAttaque(attackerId) { - delete game.system.rdd.combatStore.attaques[attackerId]; + RdDCombat.messagePasseArme({ actionPasseArme: "delete-attaque", id: attackerId }); } /* -------------------------------------------- */ - static _storeDefense(defenderRoll) { - game.system.rdd.combatStore.defenses[defenderRoll.passeArme] = duplicate(defenderRoll); + static _storeDefense(passeArme, defenderRoll) { + RdDCombat.messagePasseArme({ actionPasseArme: "store-defense", id: passeArme, rollData: defenderRoll }); } /* -------------------------------------------- */ @@ -454,7 +480,7 @@ export class RdDCombat { /* -------------------------------------------- */ static _deleteDefense(passeArme) { - delete game.system.rdd.combatStore.defenses[passeArme]; + RdDCombat.messagePasseArme({ actionPasseArme: "delete-defense", id: passeArme }); } /* -------------------------------------------- */ @@ -496,7 +522,7 @@ export class RdDCombat { if (rddCombat) { const defenderRoll = msg.defenderRoll; RdDCombat._storeAttaque(msg.attackerId, defenderRoll.attackerRoll); - RdDCombat._storeDefense(defenderRoll); + RdDCombat._storeDefense(defenderRoll.passeArme, defenderRoll); rddCombat.removeChatMessageActionsPasseArme(defenderRoll.passeArme); rddCombat._chatMessageDefense(msg.paramChatDefense); } @@ -761,7 +787,7 @@ export class RdDCombat { let defenderRoll = { attackerRoll: attackerRoll, passeArme: attackerRoll.passeArme, show: {} } // Save rollData for defender RdDCombat._storeAttaque(this.attackerId, attackerRoll); - RdDCombat._storeDefense(defenderRoll) + RdDCombat._storeDefense(defenderRoll.passeArme, defenderRoll); attackerRoll.show = { cible: this.target ? this.defender.data.name : 'la cible', @@ -996,7 +1022,7 @@ export class RdDCombat { this.removeChatMessageActionsPasseArme(defenderRoll.passeArme); this._sendMessageDefense(defenderRoll.attackerRoll, defenderRoll, { defense: true }); - RdDCombat._storeDefense(defenderRoll); + RdDCombat._storeDefense(defenderRoll.passeArme, defenderRoll); } /* -------------------------------------------- */ @@ -1068,7 +1094,7 @@ export class RdDCombat { this.removeChatMessageActionsPasseArme(defenderRoll.passeArme); this._sendMessageDefense(defenderRoll.attackerRoll, defenderRoll, { defense: true }) - RdDCombat._storeDefense(defenderRoll); + RdDCombat._storeDefense(defenderRoll.passeArme, defenderRoll); } /* -------------------------------------------- */ diff --git a/module/rdd-token-hud.js b/module/rdd-token-hud.js index 8d46bd3d..d748964f 100644 --- a/module/rdd-token-hud.js +++ b/module/rdd-token-hud.js @@ -2,7 +2,6 @@ import { HtmlUtility } from "./html-utility.js"; import { Misc } from "./misc.js"; import { RdDCombatManager } from "./rdd-combat.js"; -import { RdDUtility } from "./rdd-utility.js"; /* -------------------------------------------- */ export class RdDTokenHud { diff --git a/module/rdd-utility.js b/module/rdd-utility.js index f3c36f7c..68a4a7c0 100644 --- a/module/rdd-utility.js +++ b/module/rdd-utility.js @@ -614,10 +614,7 @@ export class RdDUtility { let actor = RdDUtility.getSelectedActor("Pour effectuer le paiement:"); if (actor) { actor.depenserDeniers(sumdenier, objData, quantite, fromActorId); - let chatMessageId = RdDUtility.findChatMessageId(event.currentTarget); - if (chatMessageId) { - ChatUtility.removeChatMessageId(chatMessageId); - } + ChatUtility.removeChatMessageId(RdDUtility.findChatMessageId(event.currentTarget)); } }); } diff --git a/system.json b/system.json index 9c14a6fc..ff795879 100644 --- a/system.json +++ b/system.json @@ -2,7 +2,7 @@ "name": "foundryvtt-reve-de-dragon", "title": "Rêve de Dragon", "description": "Rêve de Dragon RPG for FoundryVTT", - "version": "1.4.13", + "version": "1.4.14", "manifestPlusVersion": "1.0.0", "minimumCoreVersion": "0.8.0", "compatibleCoreVersion": "0.8.5",