diff --git a/module/actor-sheet.js b/module/actor-sheet.js
index 4113343e..2659db9d 100644
--- a/module/actor-sheet.js
+++ b/module/actor-sheet.js
@@ -146,6 +146,10 @@ export class RdDActorSheet extends ActorSheet {
montures: this.actor.listeMontures(),
suivants: this.actor.listeSuivants()
}
+ if (this.actor.getBestDraconic().data.niveau > -11 && !this.actor.isHautRevant()) {
+ ui.notifications.error(`${this.actor.name} a des compétences draconiques, mais pas le don de Haut-Rêve!
+
Ajoutez-lui la tête "Don de Haut-Rêve" pour lui permettre d'utiliser ses compétences et d'accéder aux terres médianes du rêve`);
+ }
return formData;
}
diff --git a/module/actor.js b/module/actor.js
index 610b1519..5d272dac 100644
--- a/module/actor.js
+++ b/module/actor.js
@@ -163,6 +163,10 @@ export class RdDActor extends Actor {
return this.data.type == 'personnage';
}
/* -------------------------------------------- */
+ isHautRevant() {
+ return Misc.templateData(this).attributs.hautrevant.value != ""
+ }
+ /* -------------------------------------------- */
getFatigueActuelle() {
if (!this.isPersonnage()) {
return 0;
@@ -1044,7 +1048,6 @@ export class RdDActor extends Actor {
/* -------------------------------------------- */
computeEtatGeneral() {
const actorData = Misc.data(this);
- console.info("computeEtatGeneral", actorData)
// Pas d'état général pour les entités forçage à 0
if (this.data.type == 'entite') {
diff --git a/module/rdd-combat.js b/module/rdd-combat.js
index f4520908..a8ae51e3 100644
--- a/module/rdd-combat.js
+++ b/module/rdd-combat.js
@@ -160,7 +160,7 @@ export class RdDCombatManager extends Combat {
arme2main.data.mainInfo = "(2m)";
arme2main.data.dommages = arme2main.data.dommages.split("/")[1]; // Existence temporaire uniquement dans la liste des armes, donc OK
arme2main.data.competence = arme2main.data.competence.replace(" 1 main", " 2 mains"); // Replace !
- let comp = competences.find(c => c.name == arme2main.data.competence);
+ let comp = Misc.data(competences.find(c => c.name == arme2main.data.competence));
arme2main.data.niveau = comp.data.niveau;
arme2main.data.initiative = RdDCombatManager.calculInitiative(arme2main.data.niveau, carac[comp.data.defaut_carac].value);
armesEquipe.push(arme2main);
@@ -661,7 +661,7 @@ export class RdDCombat {
/* -------------------------------------------- */
static isEchecTotal(rollData) {
if (!rollData.attackerRoll && rollData.ajustements.surprise.used) {
- return rollData.rolled.isEchec;
+ return rollData.rolled.isEchec && rollData.rolled.code != 'notSign';
}
return rollData.rolled.isETotal;
}
@@ -726,7 +726,6 @@ export class RdDCombat {
surpriseDefenseur: this.defender.getSurprise(true),
essais: {}
};
- rollData.diviseurSignificative = this._getDiviseurSignificative(rollData);
if (this.attacker.isCreature()) {
RdDItemCompetenceCreature.setRollDataCreature(rollData);
@@ -969,7 +968,6 @@ export class RdDCombat {
carac: Misc.templateData(this.defender).carac,
show: {}
};
- defenderRoll.diviseurSignificative = this._getDiviseurSignificative(defenderRoll);
if (this.defender.isCreature()) {
RdDItemCompetenceCreature.setRollDataCreature(defenderRoll);
@@ -978,24 +976,6 @@ export class RdDCombat {
return defenderRoll;
}
- /* -------------------------------------------- */
- _getDiviseurSignificative(defenderRoll) {
- let facteurSign = 1;
- if (defenderRoll.surprise == 'demi') {
- facteurSign *= 2;
- }
- if (defenderRoll.needParadeSignificative) {
- facteurSign *= 2;
- }
- if (RdDBonus.isDefenseAttaqueFinesse(defenderRoll)) {
- facteurSign *= 2;
- }
- if (!ReglesOptionelles.isUsing('tripleSignificative')) {
- facteurSign = Math.min(facteurSign, 4);
- }
- return facteurSign;
- }
-
/* -------------------------------------------- */
_onParadeParticuliere(defenderRoll) {
console.log("RdDCombat._onParadeParticuliere >>>", defenderRoll);
@@ -1068,7 +1048,6 @@ export class RdDCombat {
carac: Misc.templateData(this.defender).carac,
show: {}
};
- rollData.diviseurSignificative = this._getDiviseurSignificative(rollData);
if (this.defender.isCreature()) {
RdDItemCompetenceCreature.setRollDataCreature(rollData);
diff --git a/module/rdd-resolution-table.js b/module/rdd-resolution-table.js
index 9d2c392e..23a6e2c8 100644
--- a/module/rdd-resolution-table.js
+++ b/module/rdd-resolution-table.js
@@ -51,10 +51,8 @@ const reussites = [
{ code: "error", isPart: false, isSign: false, isSuccess: false, isEchec: true, isEPart: true, isETotal: true, ptTache: 0, ptQualite: 0, quality: "Jet de dés invalide", condition: (target, roll) => (roll <= 0 || roll > 100) }
];
+const reussiteInsuffisante = { code: "notSign", isPart: false, isSign: false, isSuccess: false, isEchec: true, isEPart: false, isETotal: false, ptTache: 0, ptQualite: -2, quality: "Réussite insuffisante", condition: (target, roll) => false }
/* -------------------------------------------- */
-const reussiteSignificative = reussites.find(r => r.code == "sign");
-const reussiteNormale = reussites.find(r => r.code == "norm");
-const echecNormal = reussites.find(r => r.code == "echec");
const caracMaximumResolution = 60;
/* -------------------------------------------- */
export class RdDResolutionTable {
@@ -115,7 +113,7 @@ export class RdDResolutionTable {
this._updateChancesFactor(chances, diviseur);
chances.showDice = showDice;
- let rolled = await this.rollChances(chances);
+ let rolled = await this.rollChances(chances, diviseur);
rolled.caracValue = caracValue;
rolled.finalLevel = finalLevel;
rolled.bonus = bonus;
@@ -150,12 +148,12 @@ export class RdDResolutionTable {
}
/* -------------------------------------------- */
- static async rollChances(chances) {
+ static async rollChances(chances, diviseur) {
let myRoll = new Roll("1d100").evaluate( {async: false} );
myRoll.showDice = chances.showDice;
await RdDDice.show(myRoll);
chances.roll = myRoll.total;
- mergeObject(chances, this.computeReussite(chances, chances.roll), { overwrite: true });
+ mergeObject(chances, this.computeReussite(chances, chances.roll, diviseur), { overwrite: true });
return chances;
}
@@ -216,8 +214,12 @@ export class RdDResolutionTable {
}
/* -------------------------------------------- */
- static computeReussite(chances, roll) {
- return reussites.find(x => x.condition(chances, roll));
+ static computeReussite(chances, roll, diviseur) {
+ const reussite = reussites.find(x => x.condition(chances, roll));
+ if (diviseur > 1 && reussite.code == 'norm') {
+ return reussiteInsuffisante;
+ }
+ return reussite;
}
/* -------------------------------------------- */
@@ -269,23 +271,23 @@ export class RdDResolutionTable {
/* -------------------------------------------- */
static buildHTMLResults(caracValue, levelValue) {
- if ( caracValue == undefined || isNaN(caracValue )) caracValue = 10;
- if ( levelValue == undefined || isNaN(levelValue )) levelValue = 0;
-
+ if (caracValue == undefined || isNaN(caracValue)) caracValue = 10;
+ if (levelValue == undefined || isNaN(levelValue)) levelValue = 0;
+
let cell = this.computeChances(caracValue, levelValue);
cell.epart = cell.epart > 99 ? 'N/A' : cell.epart;
cell.etotal = cell.etotal > 100 ? 'N/A' : cell.etotal;
cell.score = Math.min(cell.score, 99);
return `
-
-Particulière: ${cell.part}
-- Significative: ${cell.sign}
-- Réussite: ${cell.score}
-- Echec Particulier: ${cell.epart}
-- Echec Total: ${cell.etotal}
-
-`
+
+ Particulière: ${cell.part}
+ - Significative: ${cell.sign}
+ - Réussite: ${cell.score}
+ - Echec Particulier: ${cell.epart}
+ - Echec Total: ${cell.etotal}
+
+ `
}
/* -------------------------------------------- */
diff --git a/module/rdd-roll.js b/module/rdd-roll.js
index 6c06a349..cbdad129 100644
--- a/module/rdd-roll.js
+++ b/module/rdd-roll.js
@@ -7,6 +7,7 @@ import { Misc } from "./misc.js";
import { RdDBonus } from "./rdd-bonus.js";
import { RdDCarac } from "./rdd-carac.js";
import { RdDResolutionTable } from "./rdd-resolution-table.js";
+import { ReglesOptionelles } from "./regles-optionelles.js";
/**
* Extend the base Dialog entity to select roll parameters
@@ -63,14 +64,33 @@ export class RdDRoll extends Dialog {
surprise: actor.getSurprise(false),
canClose: true
};
-
mergeObject(rollData, defaultRollData, { recursive: true, overwrite: false });
if (rollData.forceCarac) {
rollData.carac = rollData.forceCarac;
}
+ rollData.diviseurSignificative = RdDRoll.getDiviseurSignificative(rollData);
+
RollDataAjustements.calcul(rollData, actor);
}
+ /* -------------------------------------------- */
+ static getDiviseurSignificative(rollData) {
+ let facteurSign = 1;
+ if (rollData.surprise == 'demi') {
+ facteurSign *= 2;
+ }
+ if (rollData.needParadeSignificative) {
+ facteurSign *= 2;
+ }
+ if (RdDBonus.isDefenseAttaqueFinesse(rollData)) {
+ facteurSign *= 2;
+ }
+ if (!ReglesOptionelles.isUsing('tripleSignificative')) {
+ facteurSign = Math.min(facteurSign, 4);
+ }
+ return facteurSign;
+ }
+
/* -------------------------------------------- */
static _ensureCorrectActions(actions) {
@@ -122,7 +142,6 @@ export class RdDRoll extends Dialog {
await RdDResolutionTable.rollData(this.rollData);
console.log("RdDRoll -=>", this.rollData, this.rollData.rolled);
this.actor.setRollWindowsOpened(false);
-
if (action.callbacks)
for (let callback of action.callbacks) {
if (callback.condition == undefined || callback.condition(this.rollData)) {
diff --git a/styles/simple.css b/styles/simple.css
index 7b875ce2..c76e8e8a 100644
--- a/styles/simple.css
+++ b/styles/simple.css
@@ -406,7 +406,7 @@ table {border: 1px solid #7a7971;}
border-radius: 6px; padding: 3px;
background:linear-gradient(30deg, rgba(7, 76, 0, 0.3), rgba(66, 163, 65, 0.2), rgba(184, 226, 163, 0.1), rgba(66, 163, 65, 0.2), rgba(184, 226, 163, 0.3));
}
-.rdd-roll-echec{
+.rdd-roll-notSign, .rdd-roll-echec{
border-radius: 6px; padding: 3px;
background-image: linear-gradient(150deg, rgba(255, 0, 0, 0.3), rgba(255, 200, 128, 0.05),rgba(255, 200, 128, 0.1), rgba(255,10,0,0.3));
}
diff --git a/templates/actor-sheet.html b/templates/actor-sheet.html
index 3c3d37b7..886322a3 100644
--- a/templates/actor-sheet.html
+++ b/templates/actor-sheet.html
@@ -557,6 +557,8 @@