13.0.7 - Sous le signe d'Illysis #768
@@ -17,23 +17,23 @@ import { RdDRollResult } from "./rdd-roll-result.js";
|
||||
|
||||
/* -------------------------------------------- */
|
||||
const premierRoundInit = [
|
||||
{ pattern: 'hast', init: 5.90 },
|
||||
{ pattern: 'lance', init: 5.85 },
|
||||
{ pattern: 'baton', init: 5.80 },
|
||||
{ pattern: 'doubledragonne', init: 5.75 },
|
||||
{ pattern: 'esparlongue', init: 5.70 },
|
||||
{ pattern: 'epeedragonne', init: 5.65 },
|
||||
{ pattern: 'epeebatarde', init: 5.60 },
|
||||
{ pattern: 'epeecyane', init: 5.55 },
|
||||
{ pattern: 'epeesorde', init: 5.50 },
|
||||
{ pattern: 'grandehache', init: 5.45 },
|
||||
{ pattern: 'bataille', init: 5.40 },
|
||||
{ pattern: 'epeegnome', init: 5.35 },
|
||||
{ pattern: 'masse', init: 5.30 },
|
||||
{ pattern: 'gourdin', init: 5.25 },
|
||||
{ pattern: 'fleau', init: 5.20 },
|
||||
{ pattern: 'dague', init: 5.15 },
|
||||
{ pattern: 'autre', init: 5.10 },
|
||||
{ pattern: 'hast' },
|
||||
{ pattern: 'lance' },
|
||||
{ pattern: 'baton' },
|
||||
{ pattern: 'doubledragonne' },
|
||||
{ pattern: 'esparlongue' },
|
||||
{ pattern: 'epeedragonne' },
|
||||
{ pattern: 'epeebatarde' },
|
||||
{ pattern: 'epeecyane' },
|
||||
{ pattern: 'epeesorde' },
|
||||
{ pattern: 'grandehache' },
|
||||
{ pattern: 'bataille' },
|
||||
{ pattern: 'epeegnome' },
|
||||
{ pattern: 'masse' },
|
||||
{ pattern: 'gourdin' },
|
||||
{ pattern: 'fleau' },
|
||||
{ pattern: 'dague' },
|
||||
{ pattern: 'autre' },
|
||||
];
|
||||
|
||||
/* -------------------------------------------- */
|
||||
@@ -45,6 +45,10 @@ export class RdDCombatManager extends Combat {
|
||||
Hooks.on("updateCombat", (combat, change, options, userId) => { RdDCombat.onUpdateCombat(combat, change, options, userId) });
|
||||
Hooks.on("preDeleteCombat", (combat, html, id) => { combat.onPreDeleteCombat() })
|
||||
Hooks.on("deleteCombat", (combat, html, id) => { combat.onDeleteCombat() })
|
||||
|
||||
for (let i = 0.0; i < premierRoundInit.length; i++) {
|
||||
premierRoundInit[i].init = 5.99 - i / 100
|
||||
}
|
||||
}
|
||||
|
||||
/* -------------------------------------------- */
|
||||
@@ -108,9 +112,7 @@ export class RdDCombatManager extends Combat {
|
||||
async rollInitiative(ids, messageOptions = {}) {
|
||||
console.log(`${game.system.title} | Combat.rollInitiative()`, ids, messageOptions)
|
||||
ids = typeof ids === "string" ? [ids] : ids
|
||||
ids.forEach(async id =>
|
||||
await this.rollInitRdD(id, undefined, messageOptions)
|
||||
)
|
||||
Promise.all(ids.map(id => this.rollInitRdD(id, undefined, messageOptions)))
|
||||
return this
|
||||
}
|
||||
|
||||
@@ -251,11 +253,13 @@ export class RdDCombatManager extends Combat {
|
||||
let initMissing = game.combat.combatants.find(it => !it.initiative);
|
||||
if (!initMissing) { // Premier round !
|
||||
for (let combatant of game.combat.combatants) {
|
||||
let action = combatant.initiativeData?.arme;
|
||||
//console.log("Parsed !!!", combatant, initDone, game.combat.current, arme);
|
||||
if (action && action.type == "arme") {
|
||||
for (let initData of premierRoundInit) {
|
||||
if (Grammar.toLowerCaseNoAccentNoSpace(action.system.initpremierround).includes(initData.pattern)) {
|
||||
if (combatant.initiativeData?.arme?.type == "arme") {
|
||||
// TODO: get init data premier round
|
||||
const initiativeData = combatant.initiativeData;
|
||||
const action = combatant.initiativeData.arme;
|
||||
const fromArme = Grammar.toLowerCaseNoAccentNoSpace(action.system.initpremierround)
|
||||
const initData = premierRoundInit.find(it => fromArme.includes(initData.pattern))
|
||||
if (initData) {
|
||||
let msg = `<h4>L'initiative de ${combatant.actor.getAlias()} a été modifiée !</h4>
|
||||
<hr>
|
||||
<div>
|
||||
@@ -269,7 +273,6 @@ export class RdDCombatManager extends Combat {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* -------------------------------------------- */
|
||||
static incDecInit(combatantId, incDecValue) {
|
||||
@@ -297,7 +300,7 @@ export class RdDCombatManager extends Combat {
|
||||
].concat(options);
|
||||
}
|
||||
/* -------------------------------------------- */
|
||||
static rollInitiativeAction(combatantId, action) {
|
||||
static async rollInitiativeAction(combatantId, action) {
|
||||
const combatant = game.combat.combatants.get(combatantId)
|
||||
const actor = RdDCombatManager.getActorCombatant(combatant)
|
||||
if (actor == undefined) { return [] }
|
||||
@@ -308,7 +311,8 @@ export class RdDCombatManager extends Combat {
|
||||
const ajustement = RdDCombatManager.calculAjustementInit(actor, action)
|
||||
const rollFormula = RdDCombatManager.formuleInitiative(init.offset, init.carac, init.niveau, ajustement);
|
||||
|
||||
game.combat.rollInitRdD(combatantId, rollFormula, init);
|
||||
await game.combat.rollInitRdD(combatantId, rollFormula, init);
|
||||
combatant.initiativeData
|
||||
}
|
||||
|
||||
static getInitData(actor, action) {
|
||||
|
@@ -1,6 +1,5 @@
|
||||
/* -------------------------------------------- */
|
||||
import { HtmlUtility } from "./html-utility.js";
|
||||
import { Misc } from "./misc.js";
|
||||
import { RdDCombatManager } from "./rdd-combat.js";
|
||||
import { Targets } from "./targets.js";
|
||||
|
||||
|
Reference in New Issue
Block a user