Combat tracker fixes
This commit is contained in:
		| @@ -40,23 +40,26 @@ export class Hero6Combat extends Combat { | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   static async holdAction(combatantId) { | ||||
|     const combatant = game.combat.combatants.get(combatantId) | ||||
|   holdAction(combatantId) { | ||||
|     this.rebuildInitiative() | ||||
|     console.log("Rebuilding.....") | ||||
|     /*const combatant = game.combat.combatants.get(combatantId) | ||||
|     if (combatant.actor.holdAction()) { | ||||
|       let id = combatant._id || combatant.id | ||||
|       let name = combatant.actor.name + " (H)" | ||||
|       await game.combat.updateEmbeddedDocuments("Combatant", [{ _id: id, name: name, holdAction: true }]); | ||||
|     } | ||||
|     }*/ | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   static async abortAction(actorId, abortState) { | ||||
|     const combatant = game.combat.combatants.find(c => c.actor.id == actorId) | ||||
|   abortAction(actorId, abortState) { | ||||
|     this.rebuildInitiative() | ||||
|     /*const combatant = game.combat.combatants.find(c => c.actor.id == actorId) | ||||
|     if (abortState) { | ||||
|       let id = combatant._id || combatant.id | ||||
|       let name = combatant.actor.name + " (A)" | ||||
|       await game.combat.updateEmbeddedDocuments("Combatant", [{ _id: id, name: name }]); | ||||
|     } | ||||
|     }*/ | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
| @@ -82,15 +85,32 @@ export class Hero6Combat extends Combat { | ||||
|  | ||||
|     super.startCombat(); | ||||
|   } | ||||
|   /* -------------------------------------------- */ | ||||
|   forceHold(actor, isHold) { | ||||
|     let updList = [] | ||||
|     let c = this.combatants.find(c => c.actor._id == actor.id) | ||||
|     let name = actor.name + ((isHold) ? " (H)" : "") | ||||
|     updList.push({ _id: c.id || c._id, name: name, initiative: actor.getBaseInit(this.segmentNumber) }) | ||||
|     this.updateEmbeddedDocuments("Combatant", updList) | ||||
|   } | ||||
|   /* -------------------------------------------- */ | ||||
|   forceAbort(actor, isAbort) { | ||||
|     let updList = [] | ||||
|     let c = this.combatants.find(c => c.actor._id == actor.id) | ||||
|     let name = actor.name + ((isAbort) ? " (A)" : "") | ||||
|     updList.push({ _id: c.id || c._id, name: name, initiative: actor.getBaseInit(this.segmentNumber) }) | ||||
|     this.updateEmbeddedDocuments("Combatant", updList) | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   computeInitiative(c, updList) { | ||||
|     let id = c._id || c.id | ||||
|     let hasSegment = c.actor.hasPhase(this.segmentNumber) | ||||
|     let isOnHold = c.actor.getHoldAction() | ||||
|     if (hasSegment || isOnHold) { | ||||
|       let baseInit = c.actor ? c.actor.getBaseInit() : 0; | ||||
|       let name = c.actor.name | ||||
|     let isOnAbort = c.actor.getAbortAction() | ||||
|     let name = c.actor.name | ||||
|     if (hasSegment || isOnHold || isOnAbort) { | ||||
|       let baseInit = c.actor ? c.actor.getBaseInit(this.segmentNumber) : 0; | ||||
|       if (isOnHold) { | ||||
|         if (hasSegment) { // On hold + current segment -> auto-disable on hold | ||||
|           c.actor.disableHoldAction() | ||||
| @@ -98,9 +118,11 @@ export class Hero6Combat extends Combat { | ||||
|           name = c.actor.name + " (H)" | ||||
|         } | ||||
|       } | ||||
|       if (c.actor.getAbortAction()) { | ||||
|       if (isOnAbort) { | ||||
|         name = c.actor.name + " (A)" | ||||
|         c.actor.disableAbortAction() | ||||
|         if ( hasSegment) { | ||||
|           c.actor.disableAbortAction() | ||||
|         } | ||||
|       } | ||||
|       updList.push({ _id: id, name: name, initiative: baseInit, holdAction: c.holdAction }) | ||||
|     } else { | ||||
| @@ -112,7 +134,6 @@ export class Hero6Combat extends Combat { | ||||
|   async rollInitiative(ids, formula = undefined, messageOptions = {}) { | ||||
|     ids = typeof ids === "string" ? [ids] : ids; | ||||
|  | ||||
|     console.log("Roll INIT") | ||||
|     let updList = [] | ||||
|     for (let cId = 0; cId < ids.length; cId++) { | ||||
|       const c = this.combatants.get(ids[cId]) | ||||
| @@ -197,12 +218,14 @@ export class Hero6Combat extends Combat { | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   async _onCreateEmbeddedDocuments(type, documents, result, options, userId) { | ||||
|     super._onCreateEmbeddedDocuments(type, documents, result, options, userId) | ||||
|     //console.log("Added...") | ||||
|     await super._onCreateEmbeddedDocuments(type, documents, result, options, userId) | ||||
|     await this.rebuildInitiative() | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   /* --------------------------------------------  | ||||
|   _onUpdate(changed, options, userId) { | ||||
|   } | ||||
|   }*/ | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   static async checkTurnPosition() { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user