Draft: Fix calcul encTotal #473

Closed
vincent.vandeme wants to merge 1 commits from v1.4-fix-enc into v1.4
3 changed files with 34 additions and 26 deletions

View File

@ -1143,6 +1143,7 @@ export class RdDActor extends Actor {
/* -------------------------------------------- */ /* -------------------------------------------- */
computeEncombrement() { computeEncombrement() {
this.encTotal = this.filterItemsData(it => it.data.encombrement != undefined) this.encTotal = this.filterItemsData(it => it.data.encombrement != undefined)
.filter(it => !it.estContenu)
.map(it => it.data.encTotal) .map(it => it.data.encTotal)
.reduce(Misc.sum(), 0); .reduce(Misc.sum(), 0);
return this.encTotal; return this.encTotal;

View File

@ -94,7 +94,7 @@ export class RdDItem extends Item {
case 'herbe': case 'herbe':
return encBrin; return encBrin;
} }
return itemData.data.encombrement return itemData.data.encombrement ?? 0;
} }
prepareDerivedData() { prepareDerivedData() {

View File

@ -177,7 +177,7 @@ export class RdDUtility {
'systems/foundryvtt-reve-de-dragon/templates/partial-roll-surenc.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-roll-surenc.html',
'systems/foundryvtt-reve-de-dragon/templates/partial-roll-enctotal.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-roll-enctotal.html',
'systems/foundryvtt-reve-de-dragon/templates/partial-roll-moral.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-roll-moral.html',
'systems/foundryvtt-reve-de-dragon/templates/partial-select-carac.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-select-carac.html',
// Calendrier // Calendrier
'systems/foundryvtt-reve-de-dragon/templates/calendar-template.html', 'systems/foundryvtt-reve-de-dragon/templates/calendar-template.html',
'systems/foundryvtt-reve-de-dragon/templates/calendar-editor-template.html', 'systems/foundryvtt-reve-de-dragon/templates/calendar-editor-template.html',
@ -339,28 +339,35 @@ export class RdDUtility {
// Attribution des objets aux conteneurs // Attribution des objets aux conteneurs
for (let conteneur of conteneurs) { for (let conteneur of conteneurs) {
conteneur.subItems = []; conteneur.subItems = [];
conteneur.data.encTotal = conteneur.data.encombrement; for (let id of conteneur.data.contenu ?? []) {
//conteneur.data.encTotal = ; Deja calculé let objet = objets.find(objet => (id == objet._id));
if (conteneur.data.contenu) { if (objet) {
for (let id of conteneur.data.contenu) { objet.estContenu = true; // Permet de filtrer ce qui est porté dans le template
let objet = objets.find(objet => (id == objet._id)); objetVersConteneur[id] = conteneur._id;
if (objet) { conteneur.subItems.push(objet);
if (!objet.data.encombrement)
objet.data.encombrement = 0; // Auto-fix
objet.estContenu = true; // Permet de filtrer ce qifui est porté dans le template
objetVersConteneur[id] = conteneur._id;
conteneur.data.encTotal += Number(objet.data.encombrement) * Number(((objet.data.quantite) ? objet.data.quantite : 1));
conteneur.subItems.push(objet);
}
} }
} }
} }
RdDUtility.calculEncObjets(objets);
return objetVersConteneur; return objetVersConteneur;
} }
static calculEncObjets(objets) {
for (let objet of objets) {
objet.data.encTotal = RdDUtility.calculEnc(objet, objets);
}
}
static calculEnc(objet, objets) {
const contenu = objet.data.contenu ?? [];
return contenu.map(id => objets.find(objet => (id == objet._id)))
.map(inside => RdDUtility.calculEnc(inside, objets))
.reduce(Misc.sum(), Number(objet.data.encombrement ?? 0) * Number(objet.data.quantite ?? 1));
}
// Construit la liste des conteneurs de niveau 1 (c'est à dire non contenu eux-même dans un conteneur) // Construit la liste des conteneurs de niveau 1 (c'est à dire non contenu eux-même dans un conteneur)
static conteneursRacine(conteneurs) { static conteneursRacine(conteneurs) {
return conteneurs.filter( (conteneur, index, arr) => !conteneur.estContenu); return conteneurs.filter((conteneur, index, arr) => !conteneur.estContenu);
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
@ -429,7 +436,7 @@ export class RdDUtility {
return ReglesOptionelles.isUsing("appliquer-fatigue") ? { return ReglesOptionelles.isUsing("appliquer-fatigue") ? {
malus: RdDUtility.calculMalusFatigue(fatigue, endurance), malus: RdDUtility.calculMalusFatigue(fatigue, endurance),
html: "<table class='table-fatigue'>" + RdDUtility.makeHTMLfatigueMatrix(fatigue, endurance).html() + "</table>" html: "<table class='table-fatigue'>" + RdDUtility.makeHTMLfatigueMatrix(fatigue, endurance).html() + "</table>"
} : { malus:0, html:''}; } : { malus: 0, html: '' };
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
@ -513,7 +520,7 @@ export class RdDUtility {
if (ReglesOptionelles.isUsing("appliquer-fatigue")) { if (ReglesOptionelles.isUsing("appliquer-fatigue")) {
max = Math.max(1, Math.min(max, 60)); max = Math.max(1, Math.min(max, 60));
value = Math.min(max * 2, Math.max(0, value)); value = Math.min(max * 2, Math.max(0, value));
let fatigueTab = fatigueMatrix[max]; let fatigueTab = fatigueMatrix[max];
let fatigueRem = value; let fatigueRem = value;
for (let idx = 0; idx < fatigueTab.length; idx++) { for (let idx = 0; idx < fatigueTab.length; idx++) {
@ -558,7 +565,7 @@ export class RdDUtility {
return RdDUtility.responseNombreAstral(sockmsg.data); return RdDUtility.responseNombreAstral(sockmsg.data);
case "msg_tmr_move": case "msg_tmr_move":
let actor = game.actors.get(sockmsg.data.actorId); let actor = game.actors.get(sockmsg.data.actorId);
if (actor.isOwner || game.user.isGM ) { if (actor.isOwner || game.user.isGM) {
actor.refreshTMRView(sockmsg.data.tmrPos); actor.refreshTMRView(sockmsg.data.tmrPos);
} }
break; break;
@ -587,7 +594,7 @@ export class RdDUtility {
// gestion bouton tchat Acheter // gestion bouton tchat Acheter
html.on("click", '.button-acheter', event => DialogItemAchat.onButtonAcheter(event)); html.on("click", '.button-acheter', event => DialogItemAchat.onButtonAcheter(event));
// Gestion du bouton payer // Gestion du bouton payer
html.on("click", '.payer-button', event => { html.on("click", '.payer-button', event => {
let sumdenier = event.currentTarget.attributes['data-somme-denier']?.value ?? 0; let sumdenier = event.currentTarget.attributes['data-somme-denier']?.value ?? 0;
@ -637,14 +644,14 @@ export class RdDUtility {
if (token.actor && token.data.actorLink) { if (token.actor && token.data.actorLink) {
return token.actor; return token.actor;
} }
if (msgPlayer != undefined){ if (msgPlayer != undefined) {
msgPlayer += "<br>le token sélectionné doit être lié à un personnage"; msgPlayer += "<br>le token sélectionné doit être lié à un personnage";
} }
} }
if (game.user.character) { if (game.user.character) {
return game.user.character; return game.user.character;
} }
if (msgPlayer != undefined){ if (msgPlayer != undefined) {
msgPlayer += "<br>vous pouvez sélectionner un seul token lié à un personnage"; msgPlayer += "<br>vous pouvez sélectionner un seul token lié à un personnage";
msgPlayer += "<br>vous devez être connecté comme joueur avec un personnage sélectionné"; msgPlayer += "<br>vous devez être connecté comme joueur avec un personnage sélectionné";
ui.notifications.warn(msgPlayer); ui.notifications.warn(msgPlayer);
@ -805,9 +812,9 @@ export class RdDUtility {
} }
/*-------------------------------------------- */ /*-------------------------------------------- */
static distribuerStress( stressValue, raison = 'Inconnu', nomJoueur = undefined) { static distribuerStress(stressValue, raison = 'Inconnu', nomJoueur = undefined) {
if (game.user.isGM) { if (game.user.isGM) {
if( nomJoueur == undefined) { if (nomJoueur == undefined) {
for (let actor of game.actors) { for (let actor of game.actors) {
if (actor.hasPlayerOwner) { if (actor.hasPlayerOwner) {
actor.addCompteurValue('stress', stressValue, raison); actor.addCompteurValue('stress', stressValue, raison);
@ -816,7 +823,7 @@ export class RdDUtility {
} }
} else { } else {
//console.log(stressValue, nomJoueur); //console.log(stressValue, nomJoueur);
let joueur = game.users.find( user => user.name.toLowerCase() == nomJoueur.toLowerCase() ); let joueur = game.users.find(user => user.name.toLowerCase() == nomJoueur.toLowerCase());
//console.log("Player", joueur, joueur.character ); //console.log("Player", joueur, joueur.character );
joueur.character.addCompteurValue('stress', stressValue, raison); joueur.character.addCompteurValue('stress', stressValue, raison);
ui.notifications.info(`${joueur.character.name} a reçu ${stressValue} points de Stress (raison : ${raison})`); ui.notifications.info(`${joueur.character.name} a reçu ${stressValue} points de Stress (raison : ${raison})`);