diff --git a/module/actor.js b/module/actor.js
index 5ee13feb..31385304 100644
--- a/module/actor.js
+++ b/module/actor.js
@@ -310,18 +310,19 @@ export class RdDActor extends Actor {
}
return duplicate(list[0]);
}
+ getDemiReve() {
+ return this.data.data.reve.tmrpos.coord;
+ }
/* -------------------------------------------- */
async deleteSortReserve(sortReserve) {
let reserve = duplicate(this.data.data.reve.reserve);
- let len = reserve.list.length;
- let i = 0;
- let newTable = [];
- for (i = 0; i < len; i++) {
- if (reserve.list[i].coord != sortReserve.coord && reserve.list[i].sort.name != sortReserve.sort.name)
- newTable.push(reserve.list[i]);
- }
- if (newTable.length != len) {
- reserve.list = newTable;
+ let tmr = TMRUtility.getTMR(sortReserve.coord);
+ let index = reserve.list.findIndex(tmr.type == 'fleuve'
+ ? sort => (TMRUtility.getTMR(sort.coord).type == 'fleuve' && sort.sort.name == sortReserve.sort.name)
+ : sort => (sort.coord == sortReserve.coord && sort.sort.name == sortReserve.sort.name)
+ );
+ if (index >=0 ) {
+ reserve.list.splice(index,1);
await this.update({ "data.reve.reserve": reserve });
}
}
@@ -1156,26 +1157,6 @@ export class RdDActor extends Actor {
return tmrInnaccessibles.map(it => it.data.coord);
}
- /* -------------------------------------------- */
- displayTMRQueueSouffleInformation() {
- let messages = [];
- for (let item of this.data.items) {
- if (EffetsDraconiques.isUrgenceDraconique(item)) {
- messages.push("Vous souffrez d'une Urgence Draconique : " + item.data.description);
- }
- if (EffetsDraconiques.isPeriple(item)) {
- messages.push("Vous souffrez du Souffle Périple. Vous devez gérer manuellement le détail du Périple. " + item.data.description);
- }
- }
-
- if (messages.length > 0) {
- ChatMessage.create({
- whisper: ChatUtility.getWhisperRecipientsAndGMs(game.user.name),
- content: "RAPPEL ! " + messages.join('
')
- });
- }
- }
-
/* -------------------------------------------- */
getTMRRencontres() {
return this.data.data.reve.rencontre;
@@ -1189,7 +1170,7 @@ export class RdDActor extends Actor {
//console.log("List", rencontres, len);
let newTable = [];
for (i = 0; i < len; i++) {
- if (rencontres.list[i].coord != this.data.data.reve.tmrpos.coord)
+ if (rencontres.list[i].coord != this.getDemiReve())
newTable.push(rencontres.list[i]);
}
if (newTable.length != len) {
@@ -1206,7 +1187,7 @@ export class RdDActor extends Actor {
let i = 0;
let already = false;
for (i = 0; i < len; i++) {
- if (rencontres.list[i].coord == this.data.data.reve.tmrpos.coord)
+ if (rencontres.list[i].coord == this.getDemiReve())
already = true;
}
if (!already) {
@@ -1228,9 +1209,7 @@ export class RdDActor extends Actor {
/* -------------------------------------------- */
async updateCoordTMR(coord) {
- let tmrPos = duplicate(this.data.data.reve.tmrpos);
- tmrPos.coord = coord;
- await this.update({ "data.reve.tmrpos": tmrPos });
+ await this.update({ "data.reve.tmrpos.coord": coord });
}
/* -------------------------------------------- */
@@ -3199,6 +3178,9 @@ export class RdDActor extends Actor {
case 'souffle':
await this.onDeleteOwnedDraconique(item, options, id);
break;
+ case 'casetmr':
+ await this.onDeleteOwnedCaseTmr(item, options, id);
+ break;
}
}
@@ -3220,6 +3202,13 @@ export class RdDActor extends Actor {
}
}
+ async onDeleteOwnedCaseTmr(item, options, id) {
+ let draconique = Draconique.all().find(it => it.isCase(item));
+ if (draconique) {
+ draconique.onActorDeleteCaseTmr(this, item)
+ }
+ }
+
notifyGestionTeteSouffleQueue(item, manualMessage=true){
ChatMessage.create({
whisper: ChatUtility.getWhisperRecipientsAndGMs(game.user.name),
diff --git a/module/grammar.js b/module/grammar.js
index e75bdc77..7a35cebc 100644
--- a/module/grammar.js
+++ b/module/grammar.js
@@ -26,7 +26,7 @@ export class Grammar {
/* -------------------------------------------- */
static articleDetermine(genre) {
- switch (toLowerCaseNoAccent(genre)) {
+ switch (Grammar.toLowerCaseNoAccent(genre)) {
case 'f': case 'feminin': return 'la';
case 'p': case 'mp': case 'fp': case 'pluriel': return 'les';
default:
@@ -35,8 +35,8 @@ export class Grammar {
}
/* -------------------------------------------- */
- static articleIndétermine(genre) {
- switch (toLowerCaseNoAccent(genre)) {
+ static articleIndetermine(genre) {
+ switch (Grammar.toLowerCaseNoAccent(genre)) {
case 'f': case 'feminin': return 'une';
case 'p': case 'fp': case 'mp': case 'pluriel': return 'des';
case 'n': case 'neutre': return 'du'
@@ -58,7 +58,7 @@ export class Grammar {
* @param {...any} mots
*/
static accord(genre, ...mots) {
- switch (toLowerCaseNoAccent(genre)) {
+ switch (Grammar.toLowerCaseNoAccent(genre)) {
default:
case 'n': case 'neutre':
case 'm': case 'masculin': return mots[0];
diff --git a/module/poetique.js b/module/poetique.js
index 58127bf8..e448d6e7 100644
--- a/module/poetique.js
+++ b/module/poetique.js
@@ -4,25 +4,25 @@ const poesieHautReve = [
{
reference: 'Le Ratier Bretonien',
extrait: `Le courant du Fleuve
- Te domine et te Porte
- Avant que tu te moeuves
- Combat le, ou il t'emporte`
+ Te domine et te Porte
+ Avant que tu te moeuves
+ Combat le, ou il t'emporte`
},
{
reference: 'Incompatibilité, Charles Beaudelaire',
extrait: `Et lorsque par hasard une nuée errante
- Assombrit dans son vol le lac silencieux,
- On croirait voir la robe ou l'ombre transparente
- D'un esprit qui voyage et passe dans les cieux.`
+ Assombrit dans son vol le lac silencieux,
+ On croirait voir la robe ou l'ombre transparente
+ D'un esprit qui voyage et passe dans les cieux.`
},
{
reference: 'Au fleuve de Loire, Joachim du Bellay',
extrait: `Ô de qui la vive course
- Prend sa bienheureuse source,
- D’une argentine fontaine,
- Qui d’une fuite lointaine,
- Te rends au sein fluctueux
- De l’Océan monstrueux`
+ Prend sa bienheureuse source,
+ D’une argentine fontaine,
+ Qui d’une fuite lointaine,
+ Te rends au sein fluctueux
+ De l’Océan monstrueux`
},
{
reference: 'Denis Gerfaud',
@@ -61,10 +61,188 @@ const poesieHautReve = [
Nul ne sait qui est le créateur des Dragons, ni qui est leur maître.
Mais l'on peut supposer qui est le maître du Rêve des Dragons, c'est Oniros»`
},
+ {
+ reference: "La chevelure, Charles Baudelaire",
+ extrait: `J'irai là-bas où l'arbre et l'homme, pleins de sève,
+ Se pâment longuement sous l'ardeur des climats ;
+ Fortes tresses, soyez la houle qui m'enlève !`
+ },
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `En réalité, tous les éléments du rêve des Dragons expriment
+ le Draconic : chaque pierre, chaque fleur, chaque goutte d'eau,
+ chaque nuage est porteur d'un message dans la langue des Dragons`
+ },
+ {
+ reference: "Femmes damnées (2), Charles Baudelaire",
+ extrait: `Comme je descendais des Fleuves impassibles,
+ Je ne me sentis plus guidé par les haleurs :
+ Des Peaux-Rouges criards les avaient pris pour cibles,
+ Les ayant cloués nus aux poteaux de couleurs.`
+ },
+ {
+ reference: "Le bateau ivre, Arthur Rimbaud",
+ extrait: `Loin des peuples vivants, errantes, condamnées,
+ A travers les déserts courez comme les loups ;
+ Faites votre destin, âmes désordonnées,
+ Et fuyez l'infini que vous portez en vous !`
+ },
+ {
+ reference: "L'Ennemi, Charles Baudelaire",
+ extrait: `Et qui sait si les fleurs nouvelles que je rêve
+ Trouveront dans ce sol lavé comme une grève
+ Le mystique aliment qui ferait leur vigueur ?`
+ },
+ {
+ reference: "Une charogne, Charles Baudelaire",
+ extrait: `Et le ciel regardait la carcasse superbe
+ Comme une fleur s'épanouir.
+ La puanteur était si forte, que sur l'herbe
+ Vous crûtes vous évanouir.`
+ },
+ {
+ reference: "Conseil, Victor Hugo",
+ extrait: `Rois ! la bure est souvent jalouse du velours.
+ Le peuple a froid l'hiver, le peuple a faim toujours.
+ Rendez-lui son sort plus facile.
+ Le peuple souvent porte un bien rude collier.
+ Ouvrez l'école aux fils, aux pères l'atelier,
+ À tous vos bras, auguste asile !`
+ },
+ {
+ reference: "El Desdichado, Gérard de Nerval",
+ extrait: `Suis-je Amour ou Phébus ?... Lusignan ou Biron ?
+ Mon front est rouge encor du baiser de la Reine ;
+ J'ai rêvé dans la Grotte où nage la sirène...`
+ },
+ {
+ reference: "Caligula - IIIème chant, Gérard de Nerval",
+ extrait: `Allez, que le caprice emporte
+ Chaque âme selon son désir,
+ Et que, close après vous, la porte
+ Ne se rouvre plus qu'au plaisir.`
+ },
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `Les sages ont encore coutume de dire :
+ « Mais comment les Dragons peuvent-ils
+ être influencés par une créature qui, tout
+ bien considéré, n'existe pas vraiment pour eux,
+ qui n'est que le fantasme de leur activité nocturne ? »`
+ },
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `La légende affirme que ce sont les Gnomes qui furent
+ les premiers haut-rêvants. En observant les pierres précieuses,
+ les gemmes qui sont les larmes de joie des Dragons, ils parvinrent à
+ en comprendre la langue. Et l'ayant comprise, ils purent s'en servir
+ pour influencer le cours du rêve`,
+ },
+ {
+ reference: "Quand le rêve se brise, Cypora Sebagh",
+ extrait: `Quand le rêve se brise,
+ Dans la plainte du jour,
+ Ma mémoire devient grise
+ Et sombre, tour à tour,
+ Dans le puits du silence
+ Et de la solitude ;
+ Elle reprend son errance
+ Parmi la multitude.`
+ }
+ ,
+ {
+ reference: "Une charogne, Charles Baudelaire",
+ extrait: `Les formes s'effaçaient et n'étaient plus qu'un rêve,
+ Une ébauche lente à venir
+ Sur la toile oubliée, et que l'artiste achève
+ Seulement par le souvenir.`
+ },
+ {
+ reference: "La chevelure, Charles Baudelaire",
+ extrait: `Longtemps ! toujours ! ma main dans ta crinière lourde
+ Sèmera le rubis, la perle et le saphir,
+ Afin qu'à mon désir tu ne sois jamais sourde !
+ N'es-tu pas l'oasis où je rêve, et la gourde
+ Où je hume à longs traits le vin du souvenir`
+ },
+ {
+ reference: "Un Fou et un Sage, Jean de La Fontaine",
+ extrait: `Certain Fou poursuivait à coups de pierre un Sage.
+ Le Sage se retourne et lui dit : Mon ami,
+ C'est fort bien fait à toi ; reçois cet écu-ci :
+ Tu fatigues assez pour gagner davantage.`
+ },
+ {
+ reference: "Guitare, Victor Hugo",
+ extrait: `Je la voyais passer de ma demeure,
+ Et c'était tout.
+ Mais à présent je m'ennuie à toute heure,
+ Plein de dégoût,
+ Rêveur oisif, l'âme dans la campagne,
+ La dague au clou ... –
+ Le vent qui vient à travers la montagne
+ M'a rendu fou !`
+ },
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `Le Premier Âge fut appelé l'Âge des Dragons. Ce fut le commencement
+ des temps, le commencement des rêves. Durant cette période plus mythique
+ que réellement historique, les Dragons aimaient à se rêver eux-mêmes.`
+ },
+ {
+ reference: "Les Djinns, Victor Hugo",
+ extrait: `C'est l'essaim des Djinns qui passe,
+ Et tourbillonne en sifflant !
+ Les ifs, que leur vol fracasse,
+ Craquent comme un pin brûlant.`},
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `Car le Second Âge fut bel et bien celui des Magiciens. Durant cette période, les
+ Gnomes s'enfoncèrent profondément sous les montagnes et la magie passa aux
+ mains des Humains qui en usèrent et abusèrent, se croyant devenus les maîtres du monde`
+ },
+ {
+ reference: "Lily, Pierre Perret",
+ extrait: `Elle aurait pas cru sans le voir
+ Que la couleur du désespoir
+ Là-bas aussi ce fût le noir.`
+ },
+
+ {
+ reference: "Qu'est-ce de votre vie ? une bouteille molle, Jean-Baptiste Chassignet",
+ extrait: `Qu'est-ce de votre vie ? un tourbillon rouant
+ De fumière à flot gris, parmi l'air se jouant,
+ Qui passe plus soudain que foudre meurtrière.`
+ },
+ {
+ reference: "Les Djinns, poème Victor Hugo",
+ extrait: `Cris de l'enfer! voix qui hurle et qui pleure !
+ L'horrible essaim, poussé par l'aquilon,
+ Sans doute, ô ciel ! s'abat sur ma demeure.
+ Le mur fléchit sous le noir bataillon.
+ La maison crie et chancelle penchée,
+ Et l'on dirait que, du sol arrachée,
+ Ainsi qu'il chasse une feuille séchée,
+ Le vent la roule avec leur tourbillon !`
+ },
+ {
+ reference: "Rêve de Dragon, Denis Gerfaud",
+ extrait: `Le monde est Rêve de Dragons, mais nous ne savons
+ ni leur apparence ni qui sont les dragons.
+ En dépit de l'iconographie qui les clame
+ immenses créatures ailées crachant des flammes`
+ },
+ {
+ reference: "El Desdichado, Gérard de Nerval",
+ extrait: `Je suis le Ténébreux, – le Veuf, – l'Inconsolé,
+ Le Prince d'Aquitaine à la Tour abolie :
+ Ma seule Etoile est morte, – et mon luth constellé
+ Porte le Soleil noir de la Mélancolie.`
+ },
]
export class Poetique {
- static getExtrait(){
+ static getExtrait() {
return Misc.rollOneOf(poesieHautReve);
}
diff --git a/module/rdd-commands.js b/module/rdd-commands.js
index b085c758..a10392ff 100644
--- a/module/rdd-commands.js
+++ b/module/rdd-commands.js
@@ -23,6 +23,8 @@ export class RdDCommands {
rddCommands.registerCommand({ path: ["/aide"], func: (content, msg, params) => rddCommands.help(msg), descr: "Affiche l'aide pour toutes les commandes" });
rddCommands.registerCommand({ path: ["/help"], func: (content, msg, params) => rddCommands.help(msg), descr: "Affiche l'aide pour toutes les commandes" });
rddCommands.registerCommand({ path: ["/table", "queues"], func: (content, msg, params) => RdDRollTables.getQueue(true), descr: "Tire une Queue de Dragon" });
+ rddCommands.registerCommand({ path: ["/table", "ideefixe"], func: (content, msg, params) => RdDRollTables.getIdeeFixe(true), descr: "Tire une Idée fixe" });
+ rddCommands.registerCommand({ path: ["/table", "desir"], func: (content, msg, params) => RdDRollTables.getDesirLancinant(true), descr: "Tire un Désir Lancinant" });
rddCommands.registerCommand({ path: ["/table", "ombre"], func: (content, msg, params) => RdDRollTables.getOmbre(true), descr: "Tire une Ombre de Dragon" });
rddCommands.registerCommand({ path: ["/table", "tetehr"], func: (content, msg, params) => RdDRollTables.getTeteHR(true), descr: "Tire une Tête de Dragon pour Hauts Revants" });
rddCommands.registerCommand({ path: ["/table", "tete"], func: (content, msg, params) => RdDRollTables.getTete(true), descr: "Tire une Tête de Dragon" });
diff --git a/module/rdd-rolltables.js b/module/rdd-rolltables.js
index 957c130a..74d06152 100644
--- a/module/rdd-rolltables.js
+++ b/module/rdd-rolltables.js
@@ -48,14 +48,22 @@ export class RdDRollTables {
static async getQueue(toChat = false) {
let queue = await RdDRollTables.drawItemFromRollTable("Queues de dragon", toChat);
if (queue.name.toLowerCase().includes('lancinant') ) {
- queue = await RdDRollTables.drawItemFromRollTable("Désirs lancinants", toChat);
+ return await RdDRollTables.getDesirLancinant(toChat);
}
if (queue.name.toLowerCase().includes('fixe') ) {
- queue = await RdDRollTables.drawItemFromRollTable("Idées fixes", toChat);
+ return await RdDRollTables.getIdeeFixe(toChat);
}
return queue;
}
+ static async getDesirLancinant(toChat = false) {
+ return await RdDRollTables.drawItemFromRollTable("Désirs lancinants", toChat);
+ }
+
+ static async getIdeeFixe(toChat = false) {
+ return await RdDRollTables.drawItemFromRollTable("Idées fixes", toChat);
+ }
+
/* -------------------------------------------- */
static async getTeteHR(toChat = false) {
return await RdDRollTables.drawItemFromRollTable("Têtes de Dragon pour haut-rêvants", toChat);
diff --git a/module/rdd-tmr-dialog.js b/module/rdd-tmr-dialog.js
index a3bcff7e..cbc1aafe 100644
--- a/module/rdd-tmr-dialog.js
+++ b/module/rdd-tmr-dialog.js
@@ -108,6 +108,11 @@ export class RdDTMRDialog extends Dialog {
this._createTokens();
}
+ removeToken(tmr, casetmr) {
+ this._removeTokens(t => t.coordTMR() == tmr.coord && t.caseSpeciale?._id == casetmr._id);
+ this.updateTokens()
+ }
+
/* -------------------------------------------- */
_getTokensCasesTmr() {
return this.casesSpeciales.map(c => this._tokenCaseSpeciale(c)).filter(token => token);
@@ -142,7 +147,7 @@ export class RdDTMRDialog extends Dialog {
async activateListeners(html) {
super.activateListeners(html);
- document.getElementById("tmrrow1").insertCell(1).append(this.pixiApp.view);
+ document.getElementById("tmrrow1").insertCell(0).append(this.pixiApp.view);
if (this.viewOnly) {
html.find('#lancer-sort').remove();
@@ -168,7 +173,6 @@ export class RdDTMRDialog extends Dialog {
let tmr = TMRUtility.getTMR(this.actor.data.data.reve.tmrpos.coord);
await this.manageRencontre(tmr, () => {
this.postRencontre(tmr);
- this.actor.displayTMRQueueSouffleInformation();
});
}
@@ -498,9 +502,7 @@ export class RdDTMRDialog extends Dialog {
}
async _resultatMaitriseCaseHumide(rollData) {
- if (rollData.rolled.isETotal) {
- rollData.souffle = await this.actor.ajouterSouffle({ chat: false });
- }
+ await this.souffleSiEchecTotal(rollData);
this.toclose = rollData.rolled.isEchec;
if (rollData.rolled.isSuccess && rollData.double) {
rollData.previous = { rolled: rollData.rolled, ajustements: rollData.ajustements };
@@ -518,6 +520,12 @@ export class RdDTMRDialog extends Dialog {
}
}
+ async souffleSiEchecTotal(rollData) {
+ if (rollData.rolled.isETotal) {
+ rollData.souffle = await this.actor.ajouterSouffle({ chat: false });
+ }
+ }
+
/* -------------------------------------------- */
isCaseHumide(tmr) {
if (!(TMRUtility.isCaseHumide(tmr) || this.isCaseHumideAdditionelle(tmr))) {
@@ -558,16 +566,29 @@ export class RdDTMRDialog extends Dialog {
await this._conquerir(tmr, {
difficulte: -9,
action: 'Conquérir la cité',
- onConqueteReussie: r => EffetsDraconiques.fermetureCites.onConquete(r.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr)),
- onConqueteEchec: r => this.close(),
+ onConqueteReussie: r => EffetsDraconiques.fermetureCites.onVisiteSupprimer(r.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr)),
+ onConqueteEchec: r => {
+ this.souffleSiEchecTotal(rollData);
+ this.close()
+ },
canClose: false
});
}
}
-
- removeToken(tmr, casetmr) {
- this._removeTokens(t => t.coordTMR() == tmr.coord && t.caseSpeciale?._id == casetmr._id);
- this.updateTokens()
+ /* -------------------------------------------- */
+ async purifierPeriple(tmr) {
+ if (EffetsDraconiques.periple.find(this.casesSpeciales, tmr.coord)) {
+ await this._conquerir(tmr, {
+ difficulte: EffetsDraconiques.periple.getDifficulte(tmr),
+ action: 'Purifier ' + TMRUtility.getTMRDescr(tmr.coord),
+ onConqueteReussie: r => EffetsDraconiques.periple.onVisiteSupprimer(r.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr)),
+ onConqueteEchec: r => {
+ this.souffleSiEchecTotal(rollData);
+ this.close()
+ },
+ canClose: false
+ });
+ }
}
/* -------------------------------------------- */
@@ -576,8 +597,8 @@ export class RdDTMRDialog extends Dialog {
await this._conquerir(tmr, {
difficulte: -7,
action: 'Conquérir',
- onConqueteReussie: r => EffetsDraconiques.conquete.onConquete(r.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr)),
- onConqueteEchec: r => { },
+ onConqueteReussie: r => EffetsDraconiques.conquete.onVisiteSupprimer(r.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr)),
+ onConqueteEchec: r => this.close(),
canClose: false
});
}
@@ -639,8 +660,9 @@ export class RdDTMRDialog extends Dialog {
dialog.render(true);
}
- async validerPelerinage(tmr) {
- await EffetsDraconiques.pelerinage.onFinPelerinage(this.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr));
+ async validerVisite(tmr) {
+ await EffetsDraconiques.pelerinage.onVisiteSupprimer(this.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr));
+ await EffetsDraconiques.urgenceDraconique.onVisiteSupprimer(this.actor, tmr, (casetmr) => this.removeToken(tmr, casetmr));
}
@@ -649,11 +671,12 @@ export class RdDTMRDialog extends Dialog {
let sortReserveList = TMRUtility.getSortReserveList(this.sortsReserves, coord);
if (sortReserveList.length > 0) {
- if (EffetsDraconiques.isSortImpossible(this.actor)) {
+ if (EffetsDraconiques.isSortReserveImpossible(this.actor)) {
ui.notifications.error("Une queue ou un souffle vous empèche de déclencher de sort!");
return;
}
- if (EffetsDraconiques.isReserveEnSecurite(this.actor) || this.isReserveExtensible(coord)) {
+ if (!EffetsDraconiques.isUrgenceDraconique(this.actor) &&
+ (EffetsDraconiques.isReserveEnSecurite(this.actor) || this.isReserveExtensible(coord))) {
let msg = "Vous êtes sur une case avec un Sort en Réserve. Grâce à votre Tête Reserve en Sécurité ou Réserve Exensible, vous pouvez contrôler le déclenchement. Cliquez si vous souhaitez le déclencher :
";
for (let sortReserve of sortReserveList) {
msg += "