Récupération de rêve optionnelle
This commit is contained in:
parent
5a50917730
commit
6c9d03be92
@ -4,6 +4,7 @@
|
|||||||
- La transformation de stress à Château Dormant
|
- La transformation de stress à Château Dormant
|
||||||
- La récuperation de chance à Château Dormant
|
- La récuperation de chance à Château Dormant
|
||||||
- La récupération d'éthylisme
|
- La récupération d'éthylisme
|
||||||
|
- La récupération de rêve (y compris fleurs de rêve et Rêves de Dragon: la rencontre a lieu, mais ne donne pas de rêve)
|
||||||
- Séparation des véhicules dans leur propre acteur
|
- Séparation des véhicules dans leur propre acteur
|
||||||
|
|
||||||
## v11.0.28 - les fractures de Khrachtchoum
|
## v11.0.28 - les fractures de Khrachtchoum
|
||||||
|
@ -700,11 +700,20 @@ export class RdDActor extends RdDBaseActor {
|
|||||||
jetsReve.push(-1);
|
jetsReve.push(-1);
|
||||||
return 'eveil';
|
return 'eveil';
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
if (!ReglesOptionnelles.isUsing("recuperation-reve")) {
|
||||||
|
ChatMessage.create({
|
||||||
|
whisper: ChatUtility.getWhisperRecipientsAndGMs(this.name),
|
||||||
|
content: `Pas de récupération de rêve (${reve} points ignorés)`
|
||||||
|
});
|
||||||
|
jetsReve.push(0);
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
await this.reveActuelIncDec(reve);
|
await this.reveActuelIncDec(reve);
|
||||||
jetsReve.push(reve);
|
jetsReve.push(reve);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return 'dort';
|
return 'dort';
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1353,7 +1362,7 @@ export class RdDActor extends RdDBaseActor {
|
|||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
async reveActuelIncDec(value) {
|
async reveActuelIncDec(value) {
|
||||||
let reve = Math.max(this.system.reve.reve.value + value, 0);
|
const reve = Math.max(this.system.reve.reve.value + value, 0);
|
||||||
await this.update({ "system.reve.reve.value": reve });
|
await this.update({ "system.reve.reve.value": reve });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@ const listeReglesOptionnelles = [
|
|||||||
{ group: 'Récupération', name: 'transformation-stress', descr: "Transformer le stress durant Château Dormant"},
|
{ group: 'Récupération', name: 'transformation-stress', descr: "Transformer le stress durant Château Dormant"},
|
||||||
{ group: 'Récupération', name: 'recuperation-chance', descr: "Récupérer la chance durant Château Dormant"},
|
{ group: 'Récupération', name: 'recuperation-chance', descr: "Récupérer la chance durant Château Dormant"},
|
||||||
{ group: 'Récupération', name: 'recuperation-ethylisme', descr: "Récupérer l'éthylisme"},
|
{ group: 'Récupération', name: 'recuperation-ethylisme', descr: "Récupérer l'éthylisme"},
|
||||||
|
{ group: 'Récupération', name: 'recuperation-reve', descr: "Récupérer le rêve pendant la nuit (les jets sont toujours faits pour les Rêves de Dragons)"},
|
||||||
|
|
||||||
{ group: 'Règles de combat', name: 'recul', descr: "Appliquer le recul en cas de particulière en force ou de charge" },
|
{ group: 'Règles de combat', name: 'recul', descr: "Appliquer le recul en cas de particulière en force ou de charge" },
|
||||||
{ group: 'Règles de combat', name: 'resistanceArmeParade', descr: "Faire le jet de résistance des armes lors de parades pouvant les endommager" },
|
{ group: 'Règles de combat', name: 'resistanceArmeParade', descr: "Faire le jet de résistance des armes lors de parades pouvant les endommager" },
|
||||||
|
@ -2,6 +2,7 @@ import { ExperienceLog, XP_TOPIC } from "../actor/experience-log.js";
|
|||||||
import { ChatUtility } from "../chat-utility.js";
|
import { ChatUtility } from "../chat-utility.js";
|
||||||
import { Poetique } from "../poetique.js";
|
import { Poetique } from "../poetique.js";
|
||||||
import { RdDDice } from "../rdd-dice.js";
|
import { RdDDice } from "../rdd-dice.js";
|
||||||
|
import { ReglesOptionnelles } from "../settings/regles-optionnelles.js";
|
||||||
import { TMRUtility } from "../tmr-utility.js";
|
import { TMRUtility } from "../tmr-utility.js";
|
||||||
|
|
||||||
export class EffetsRencontre {
|
export class EffetsRencontre {
|
||||||
@ -9,7 +10,7 @@ export class EffetsRencontre {
|
|||||||
static messager = async (dialog, context) => {
|
static messager = async (dialog, context) => {
|
||||||
dialog.setRencontreState('messager', TMRUtility.getTMRPortee(context.tmr.coord, context.rencontre.system.force));
|
dialog.setRencontreState('messager', TMRUtility.getTMRPortee(context.tmr.coord, context.rencontre.system.force));
|
||||||
}
|
}
|
||||||
|
|
||||||
static passeur = async (dialog, context) => {
|
static passeur = async (dialog, context) => {
|
||||||
dialog.setRencontreState('passeur', TMRUtility.getTMRPortee(context.tmr.coord, context.rencontre.system.force));
|
dialog.setRencontreState('passeur', TMRUtility.getTMRPortee(context.tmr.coord, context.rencontre.system.force));
|
||||||
}
|
}
|
||||||
@ -26,16 +27,25 @@ export class EffetsRencontre {
|
|||||||
static reve_plus_1 = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, 1) }
|
static reve_plus_1 = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, 1) }
|
||||||
static reve_moins_force = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, -context.rencontre.system.force) }
|
static reve_moins_force = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, -context.rencontre.system.force) }
|
||||||
static reve_moins_1 = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, -1) }
|
static reve_moins_1 = async (dialog, context) => { await EffetsRencontre.$reve_plus(context.actor, -1) }
|
||||||
static $reve_plus = async (actor, valeur) => { await actor.reveActuelIncDec(valeur) }
|
static $reve_plus = async (actor, reve) => {
|
||||||
|
if (!ReglesOptionnelles.isUsing("recuperation-reve") && reve < 0) {
|
||||||
|
ChatMessage.create({
|
||||||
|
whisper: ChatUtility.getWhisperRecipientsAndGMs(actor.name),
|
||||||
|
content: `Pas de récupération de rêve (${reve} points ignorés)`
|
||||||
|
});
|
||||||
|
return
|
||||||
|
}
|
||||||
|
await actor.reveActuelIncDec(reve)
|
||||||
|
}
|
||||||
|
|
||||||
static vie_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
static vie_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
||||||
static vie_moins_force = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -context.rencontre.system.force) }
|
static vie_moins_force = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -context.rencontre.system.force) }
|
||||||
static $vie_plus = async (actor, valeur) => { await actor.santeIncDec("vie", valeur) }
|
static $vie_plus = async (actor, valeur) => { await actor.santeIncDec("vie", valeur) }
|
||||||
|
|
||||||
static moral_plus_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, 1) }
|
static moral_plus_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, 1) }
|
||||||
static moral_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
static moral_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
||||||
static $moral_plus = async (actor, valeur) => { await actor.moralIncDec(valeur) }
|
static $moral_plus = async (actor, valeur) => { await actor.moralIncDec(valeur) }
|
||||||
|
|
||||||
static end_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
static end_moins_1 = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -1) }
|
||||||
static end_moins_force = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -context.rencontre.system.force) }
|
static end_moins_force = async (dialog, context) => { await EffetsRencontre.$vie_plus(context.actor, -context.rencontre.system.force) }
|
||||||
static $end_plus = async (actor, valeur) => { await actor.santeIncDec("endurance", valeur) }
|
static $end_plus = async (actor, valeur) => { await actor.santeIncDec("endurance", valeur) }
|
||||||
@ -50,8 +60,8 @@ export class EffetsRencontre {
|
|||||||
const perte = context.rolled.isETotal ? context.rencontre.system.force : 1;
|
const perte = context.rolled.isETotal ? context.rencontre.system.force : 1;
|
||||||
await context.actor.chanceActuelleIncDec("fatigue", -perte);
|
await context.actor.chanceActuelleIncDec("fatigue", -perte);
|
||||||
}
|
}
|
||||||
|
|
||||||
static xp_sort_force = async (dialog, context) => {
|
static xp_sort_force = async (dialog, context) => {
|
||||||
let competence = context.competence;
|
let competence = context.competence;
|
||||||
if (competence) {
|
if (competence) {
|
||||||
const fromXpSort = Number(competence.system.xp_sort);
|
const fromXpSort = Number(competence.system.xp_sort);
|
||||||
@ -60,7 +70,7 @@ export class EffetsRencontre {
|
|||||||
await ExperienceLog.add(this, XP_TOPIC.XPSORT, fromXpSort, toXpSort, `${competence.name} - ${context.rencontre.name} en TMR`);
|
await ExperienceLog.add(this, XP_TOPIC.XPSORT, fromXpSort, toXpSort, `${competence.name} - ${context.rencontre.name} en TMR`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static stress_plus_1 = async (dialog, context) => {
|
static stress_plus_1 = async (dialog, context) => {
|
||||||
await context.actor.addCompteurValue('stress', 1, `Rencontre d'un ${context.rencontre.name} en TMR`);
|
await context.actor.addCompteurValue('stress', 1, `Rencontre d'un ${context.rencontre.name} en TMR`);
|
||||||
}
|
}
|
||||||
@ -75,7 +85,7 @@ export class EffetsRencontre {
|
|||||||
|
|
||||||
static demireve_rompu = async (dialog, context) => {
|
static demireve_rompu = async (dialog, context) => {
|
||||||
dialog.close()
|
dialog.close()
|
||||||
}
|
}
|
||||||
|
|
||||||
static sort_aleatoire = async (dialog, context) => {
|
static sort_aleatoire = async (dialog, context) => {
|
||||||
context.sortReserve = await RdDDice.rollOneOf(context.actor.itemTypes['sortreserve']);
|
context.sortReserve = await RdDDice.rollOneOf(context.actor.itemTypes['sortreserve']);
|
||||||
@ -128,7 +138,7 @@ export class EffetsRencontre {
|
|||||||
|
|
||||||
static regain_seuil = async (dialog, context) => {
|
static regain_seuil = async (dialog, context) => {
|
||||||
await context.actor.regainPointDeSeuil()
|
await context.actor.regainPointDeSeuil()
|
||||||
}
|
}
|
||||||
|
|
||||||
static async $reinsertion(dialog, actor, filter) {
|
static async $reinsertion(dialog, actor, filter) {
|
||||||
const newTMR = await TMRUtility.getTMRAleatoire(filter);
|
const newTMR = await TMRUtility.getTMRAleatoire(filter);
|
||||||
|
Loading…
Reference in New Issue
Block a user