diff --git a/module/actor.js b/module/actor.js index f6cade15..acf82344 100644 --- a/module/actor.js +++ b/module/actor.js @@ -457,7 +457,20 @@ export class RdDActor extends RdDBaseActor { async _jetDeMoralChateauDormant(message) { const jetMoral = await this._jetDeMoral('neutre'); - message.content += jetMoral.ajustement == 0 ? ' -- le moral reste stable' : ' -- le moral retourne vers 0'; + message.content += ' -- le moral ' + this._messageAjustementMoral(jetMoral.ajustement); + } + _messageAjustementMoral(ajustement) { + switch (Math.sign(ajustement)) { + case 1: + return `remonte de ${ajustement}`; + case -1: + return `diminue de ${-ajustement}`; + case 0: + return 'reste stable'; + default: + console.error(`Le signe de l'ajustement de moral ${ajustement} est ${Math.sign(ajustement)}, ce qui est innatendu`) + return `est ajusté de ${ajustement} (bizarre)`; + } } /* -------------------------------------------- */ diff --git a/module/actor/base-actor-sheet.js b/module/actor/base-actor-sheet.js index c4d09424..ea512b1c 100644 --- a/module/actor/base-actor-sheet.js +++ b/module/actor/base-actor-sheet.js @@ -52,28 +52,28 @@ export class RdDBaseActorSheet extends ActorSheet { this.objetVersConteneur = RdDUtility.buildArbreDeConteneurs(formData.conteneurs, formData.objets); formData.conteneurs = RdDUtility.conteneursRacine(formData.conteneurs); - this._appliquerRechercheObjets(formData.objets, formData.conteneurs, this.options.recherche); + this._appliquerRechercheObjets(formData.objets, formData.conteneurs); return formData; } - _appliquerRechercheObjets(objets, conteneurs, recherche) { - if (recherche) { - this._setConteneursVisibles(objets, conteneurs); + _appliquerRechercheObjets(objets, conteneurs) { + if (this.options.recherche?.text) { + const recherche = this.options.recherche; + const allVisible = objets.filter(it => it.isNomTypeLike(recherche.text)).map(it => it.id); + let addVisible = conteneurs.filter(it => it.isNomTypeLike(recherche.text)).map(it => it.id) + do { + allVisible.push(...addVisible) + const parentsIds = conteneurs.filter(it => it.system.contenu.find(id => allVisible.includes(id))).map(it => it.id) + addVisible = parentsIds.filter(id => !allVisible.includes(id)) + } + while (addVisible.length > 0) + objets.forEach(it => it.system.isHidden = !allVisible.includes(it.id)) + conteneurs.forEach(it => it.system.isHidden = !allVisible.includes(it.id)) } - } - - _setConteneursVisibles(objets, conteneurs) { - const recherche = this.options.recherche; - const allVisible = objets.filter(it => it.isNomTypeLike(recherche.text)).map(it => it.id); - let addVisible = conteneurs.filter(it => it.isNomTypeLike(recherche.text)).map(it => it.id) - do { - allVisible.push(...addVisible) - const parentsIds = conteneurs.filter(it => it.system.contenu.find(id => allVisible.includes(id))).map(it => it.id) - addVisible = parentsIds.filter(id => !allVisible.includes(id)) + else { + objets.forEach(it => it.system.isHidden = false) + conteneurs.forEach(it => it.system.isHidden = false) } - while (addVisible.length > 0) - objets.forEach(it => it.system.isHidden = !allVisible.includes(it.id)) - conteneurs.forEach(it => it.system.isHidden = !allVisible.includes(it.id)) } /* -------------------------------------------- */ @@ -164,12 +164,8 @@ export class RdDBaseActorSheet extends ActorSheet { .each((index, field) => { this._rechercheSelectArea(field); }) - .keyup(async event => { - this._rechercherKeyup(event); - }) - .change(async event => - this.options.recherche = this._optionRecherche(event.currentTarget) - ); + .keyup(async event => this._rechercherKeyup(event)) + .change(async event => this._rechercherKeyup(event)); } _rechercherKeyup(event) { diff --git a/system.json b/system.json index 18d4a7c5..1b2908d1 100644 --- a/system.json +++ b/system.json @@ -1,8 +1,8 @@ { "id": "foundryvtt-reve-de-dragon", "title": "Rêve de Dragon", - "version": "10.6.12", - "download": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/archive/foundryvtt-reve-de-dragon-10.6.12.zip", + "version": "10.6.13", + "download": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/archive/foundryvtt-reve-de-dragon-10.6.13.zip", "manifest": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/raw/v10/system.json", "compatibility": { "minimum": "10", diff --git a/templates/actor/commerce-inventaire-item.html b/templates/actor/commerce-inventaire-item.html index e057f84c..5a8683ce 100644 --- a/templates/actor/commerce-inventaire-item.html +++ b/templates/actor/commerce-inventaire-item.html @@ -1,3 +1,4 @@ +{{#unless item.system.isHidden}} {{#if (ne item.type 'monnaie')}}
  • @@ -57,3 +58,4 @@
  • {{/if}} +{{/unless}} \ No newline at end of file diff --git a/templates/actor/commerce-inventaire.html b/templates/actor/commerce-inventaire.html index f4fc2b81..16f95c72 100644 --- a/templates/actor/commerce-inventaire.html +++ b/templates/actor/commerce-inventaire.html @@ -4,6 +4,9 @@ Nouvel objet Tout vider {{/if}} + + + {{#unless system.illimite}} {{#if calc.surEncombrementMessage}}{{calc.surEncombrementMessage}} ‐{{/if}}