forked from public/foundryvtt-reve-de-dragon
		
	Jet V2 pour les créatures
This commit is contained in:
		| @@ -1,4 +1,9 @@ | |||||||
| # 13.0 | # 13.0 | ||||||
|  | ## 13.0.14 - Le familier d'Illysis | ||||||
|  |  | ||||||
|  | - Nouvelle fenêtre de jets de dés | ||||||
|  |   - Attaque/défense des créatures | ||||||
|  |  | ||||||
| ## 13.0.13 - L'épanouissement d'Illysis | ## 13.0.13 - L'épanouissement d'Illysis | ||||||
|  |  | ||||||
| - Fix d'erreur au chargement de templates RollDialog | - Fix d'erreur au chargement de templates RollDialog | ||||||
|   | |||||||
| @@ -186,12 +186,12 @@ export class RdDActor extends RdDBaseActorSang { | |||||||
|     const uniques = [] |     const uniques = [] | ||||||
|  |  | ||||||
|     const addAttaque = (arme, main = undefined, action = 'attaque') => { |     const addAttaque = (arme, main = undefined, action = 'attaque') => { | ||||||
|       const dommagesArme = RdDItemArme.valeurMain(arme.system.dommages, main) |       const dommages = RdDItemArme.valeurMain(arme.system.dommages, main) | ||||||
|       const forceRequise = RdDItemArme.valeurMain(arme.system.force ?? 0, main) |       const forceRequise = RdDItemArme.valeurMain(arme.system.force ?? 0, main) | ||||||
|       const ecaillesEfficacite = arme.system.magique ? arme.system.ecaille_efficacite : 0; |       const ecaillesEfficacite = arme.system.magique ? arme.system.ecaille_efficacite : 0; | ||||||
|  |  | ||||||
|       const comp = this.getCompetence(RdDActor.$getCompetenceAction(arme, main)) |       const comp = this.getCompetence(RdDActor.$getCompetenceAction(arme, main)) | ||||||
|       const unique = [comp.id, arme.name, dommagesArme, forceRequise, ecaillesEfficacite].join('|'); |       const unique = [comp.id, arme.name, dommages, forceRequise, ecaillesEfficacite].join('|'); | ||||||
|       if (uniques.includes(unique)) { |       if (uniques.includes(unique)) { | ||||||
|         return |         return | ||||||
|       } |       } | ||||||
| @@ -212,7 +212,7 @@ export class RdDActor extends RdDBaseActorSang { | |||||||
|         main: main, |         main: main, | ||||||
|         carac: { key: caracCode, value: caracValue }, |         carac: { key: caracCode, value: caracValue }, | ||||||
|         equipe: arme.system.equipe, |         equipe: arme.system.equipe, | ||||||
|         dommagesArme: dommagesArme, |         dommages: dommages, | ||||||
|         forceRequise: forceRequise, |         forceRequise: forceRequise, | ||||||
|         initiative: RdDInitiative.getRollInitiative(caracValue, niveau, ajustement) |         initiative: RdDInitiative.getRollInitiative(caracValue, niveau, ajustement) | ||||||
|       }) |       }) | ||||||
|   | |||||||
| @@ -176,10 +176,11 @@ export class RdDBaseActorReve extends RdDBaseActor { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   getCompetences(name = undefined, options = { onMessage: message => { } }) { |   getCompetences(name = undefined, options = { onMessage: message => { } }) { | ||||||
|  |     const all = [...this.itemTypes[ITEM_TYPES.competence], ...this.itemTypes[ITEM_TYPES.competencecreature]] | ||||||
|     if (name == undefined) { |     if (name == undefined) { | ||||||
|       return this.itemTypes[ITEM_TYPES.competence] |       return all | ||||||
|     } |     } | ||||||
|     return RdDItemCompetence.findCompetences(this.itemTypes[ITEM_TYPES.competence], name, options) |     return RdDItemCompetence.findCompetences(all, name, options) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   getCompetenceCorpsACorps(options = { onMessage: message => { } }) { |   getCompetenceCorpsACorps(options = { onMessage: message => { } }) { | ||||||
| @@ -246,10 +247,10 @@ export class RdDBaseActorReve extends RdDBaseActor { | |||||||
|     if (this.isEffectAllowed(statusId)) { |     if (this.isEffectAllowed(statusId)) { | ||||||
|       const effect = this.getEffectByStatus(statusId); |       const effect = this.getEffectByStatus(statusId); | ||||||
|       if (!status && effect) { |       if (!status && effect) { | ||||||
|         await this.deleteEmbeddedDocuments('ActiveEffect', [effect.id], { render: true}) |         await this.deleteEmbeddedDocuments('ActiveEffect', [effect.id], { render: true }) | ||||||
|       } |       } | ||||||
|       if (status && !effect) { |       if (status && !effect) { | ||||||
|         await this.createEmbeddedDocuments("ActiveEffect", [StatusEffects.prepareActiveEffect(statusId)], { render: true}) |         await this.createEmbeddedDocuments("ActiveEffect", [StatusEffects.prepareActiveEffect(statusId)], { render: true }) | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -309,6 +310,22 @@ export class RdDBaseActorReve extends RdDBaseActor { | |||||||
|  |  | ||||||
|   async rollCaracCompetence(caracName, compName, diff, options = { title: "" }) { |   async rollCaracCompetence(caracName, compName, diff, options = { title: "" }) { | ||||||
|     RdDEmpoignade.checkEmpoignadeEnCours(this) |     RdDEmpoignade.checkEmpoignadeEnCours(this) | ||||||
|  |  | ||||||
|  |     if (OptionsAvancees.isUsing(ROLL_DIALOG_V2)) { | ||||||
|  |       const competence = this.getCompetence(compName); | ||||||
|  |       const rollData = { | ||||||
|  |         ids: { actorId: this.id }, | ||||||
|  |         type: { allowed: DEFAULT_ROLL_TYPES, current: PART_COMP }, | ||||||
|  |         selected: { | ||||||
|  |           carac: { key: caracName }, | ||||||
|  |           comp: { key: competence.name }, | ||||||
|  |           diff: { value: diff } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |       RollDialog.create(rollData, options) | ||||||
|  |       return | ||||||
|  |     } | ||||||
|  |  | ||||||
|     const competence = this.getCompetence(compName); |     const competence = this.getCompetence(compName); | ||||||
|     await this.openRollDialog({ |     await this.openRollDialog({ | ||||||
|       name: 'jet-competence', |       name: 'jet-competence', | ||||||
| @@ -423,32 +440,22 @@ export class RdDBaseActorReve extends RdDBaseActor { | |||||||
|     await RdDRollResult.displayRollData(rollData, this, 'chat-resultat-general.hbs'); |     await RdDRollResult.displayRollData(rollData, this, 'chat-resultat-general.hbs'); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |  | ||||||
|   async rollCompetenceV2(rollData) { |  | ||||||
|     rollData.ids = rollData?.ids ?? {} |  | ||||||
|     rollData.type = rollData.type ?? { allowed: DEFAULT_ROLL_TYPES } |  | ||||||
|     rollData.ids.actorId = this.id |  | ||||||
|     await RollDialog.create(rollData) |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   async rollCompetence(idOrName, options = { tryTarget: true, arme: undefined }) { |   async rollCompetence(idOrName, options = { tryTarget: true, arme: undefined }) { | ||||||
|     RdDEmpoignade.checkEmpoignadeEnCours(this) |     RdDEmpoignade.checkEmpoignadeEnCours(this) | ||||||
|  |  | ||||||
|     const competence = this.getCompetence(idOrName); |     const competence = this.getCompetence(idOrName); | ||||||
|     if (competence.type != ITEM_TYPES.competencecreature && OptionsAvancees.isUsing(ROLL_DIALOG_V2)) { |     if (OptionsAvancees.isUsing(ROLL_DIALOG_V2)) { | ||||||
|       const rollData = { |       const rollData = { | ||||||
|  |         ids: { actorId: this.id }, | ||||||
|  |         type: { allowed: options.arme ? ATTAQUE_ROLL_TYPES : DEFAULT_ROLL_TYPES }, | ||||||
|         selected: { |         selected: { | ||||||
|  |           carac: competence.type == ITEM_TYPES.competencecreature ? { key: competence.name } : undefined, | ||||||
|           comp: { key: competence.name }, |           comp: { key: competence.name }, | ||||||
|           diff: { type: DIFF.LIBRE, value: competence.system.default_diffLibre ?? 0 } |           diff: { type: options.arme ? DIFF.ATTAQUE : DIFF.LIBRE, value: competence.system.default_diffLibre ?? 0 }, | ||||||
|  |           attaque: options.arme ? { arme: { key: options.arme.id } } : undefined | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|       if (options.arme) { |       return await RollDialog.create(rollData) | ||||||
|         rollData.selected.attaque = { arme: { id: options.arme.id }, comp: { id: competence.id } } |  | ||||||
|         rollData.type = { allowed: ATTAQUE_ROLL_TYPES } |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       await this.rollCompetenceV2(rollData) |  | ||||||
|       return |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     let rollData = { |     let rollData = { | ||||||
| @@ -512,19 +519,13 @@ export class RdDBaseActorReve extends RdDBaseActor { | |||||||
|         title: 'Ne pas utiliser les automatisation de combat', |         title: 'Ne pas utiliser les automatisation de combat', | ||||||
|         buttonLabel: "Pas d'automatisation", |         buttonLabel: "Pas d'automatisation", | ||||||
|         onAction: async () => { |         onAction: async () => { | ||||||
|           this.rollCompetenceV2({ |           const rollData = { | ||||||
|             ids: { |             ids: { actorId: this.id, actorTokenId: token?.id, }, | ||||||
|               actorId: this.id, |  | ||||||
|               actorTokenId: token?.id, |  | ||||||
|             }, |  | ||||||
|             selected: { |  | ||||||
|               conditions: { value: 0 } |  | ||||||
|             }, |  | ||||||
|             type: { |             type: { | ||||||
|               allowed: [ROLL_TYPE_COMP, ROLL_TYPE_ATTAQUE, ROLL_TYPE_OEUVRE, ROLL_TYPE_TACHE, ROLL_TYPE_JEU], |               allowed: [ROLL_TYPE_ATTAQUE], current: ROLL_TYPE_ATTAQUE | ||||||
|               current: ROLL_TYPE_COMP |  | ||||||
|             } |             } | ||||||
|           }) |           }; | ||||||
|  |           return await RollDialog.create(rollData) | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -56,8 +56,7 @@ export class RdDBaseActorSheet extends foundry.appv1.sheets.ActorSheet { | |||||||
|     this._appliquerRechercheObjets(formData.conteneurs, formData.inventaires); |     this._appliquerRechercheObjets(formData.conteneurs, formData.inventaires); | ||||||
|     formData.conteneurs = RdDUtility.conteneursRacine(formData.conteneurs); |     formData.conteneurs = RdDUtility.conteneursRacine(formData.conteneurs); | ||||||
|     formData.competences.filter(it => it.type == ITEM_TYPES.competencecreature) |     formData.competences.filter(it => it.type == ITEM_TYPES.competencecreature) | ||||||
|       .forEach(it => it.isdommages = it.isDommages() |       .forEach(it => it.isdommages = it.isDommages()) | ||||||
|       ) |  | ||||||
|  |  | ||||||
|     return formData; |     return formData; | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -160,7 +160,7 @@ export class Mapping { | |||||||
|       return undefined |       return undefined | ||||||
|     } |     } | ||||||
|     const categorie = Mapping.complementCategorie(arme, maniement) |     const categorie = Mapping.complementCategorie(arme, maniement) | ||||||
|     const dommages = Mapping.dommagesArme(actor, arme, maniement) |     const dommages = Mapping.dommages(actor, arme, maniement) | ||||||
|     return { |     return { | ||||||
|       name: arme.name + categorie, |       name: arme.name + categorie, | ||||||
|       niveau: Misc.toSignedString(competence.system.niveau), |       niveau: Misc.toSignedString(competence.system.niveau), | ||||||
| @@ -170,7 +170,8 @@ export class Mapping { | |||||||
|       arme: arme |       arme: arme | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   static dommagesArme(actor, arme, maniement) { |  | ||||||
|  |   static dommages(actor, arme, maniement) { | ||||||
|     const dmgArme = RdDItemArme.dommagesReels(arme, maniement) |     const dmgArme = RdDItemArme.dommagesReels(arme, maniement) | ||||||
|     const dommages = Misc.toSignedString(dmgArme + RdDBonus.bonusDmg(actor, maniement, dmgArme)) |     const dommages = Misc.toSignedString(dmgArme + RdDBonus.bonusDmg(actor, maniement, dmgArme)) | ||||||
|     switch (arme.system.mortalite) { |     switch (arme.system.mortalite) { | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ export class RdDItemCompetenceCreature extends RdDItem { | |||||||
|             initiative: initative, |             initiative: initative, | ||||||
|             mortalite: this.system.mortalite, |             mortalite: this.system.mortalite, | ||||||
|             dommages: this.system.dommages, |             dommages: this.system.dommages, | ||||||
|  |             forceRequise: 0, | ||||||
|             equipe: true, |             equipe: true, | ||||||
|             resistance: 100, |             resistance: 100, | ||||||
|             penetration: 0, |             penetration: 0, | ||||||
| @@ -43,7 +44,8 @@ export class RdDItemCompetenceCreature extends RdDItem { | |||||||
|         carac: { key: this.name, value: this.system.carac_value }, |         carac: { key: this.name, value: this.system.carac_value }, | ||||||
|         equipe: true, |         equipe: true, | ||||||
|         mortalite: this.system.mortalite, |         mortalite: this.system.mortalite, | ||||||
|         dmg: this.system.dommages, |         dommages: this.system.dommages, | ||||||
|  |         //dmg: this.system.dommages, | ||||||
|         initiative: initative |         initiative: initative | ||||||
|       }; |       }; | ||||||
|       return attaque |       return attaque | ||||||
|   | |||||||
| @@ -727,8 +727,6 @@ export class RdDCombat { | |||||||
|     RollBasicParts.loadSurprises(attackerRoll) |     RollBasicParts.loadSurprises(attackerRoll) | ||||||
|     attackerRoll.passeArme = attackerRoll.passeArme ?? foundry.utils.randomID(16) |     attackerRoll.passeArme = attackerRoll.passeArme ?? foundry.utils.randomID(16) | ||||||
|     attackerRoll.dmg = RdDBonus.dmgRollV2(attackerRoll, attackerRoll.current.attaque) |     attackerRoll.dmg = RdDBonus.dmgRollV2(attackerRoll, attackerRoll.current.attaque) | ||||||
|     // attackerRoll.current.attaque.dmg = attackerRoll.dmg |  | ||||||
|     // attaque.dmg = attackerRoll.current.attaque.dmg |  | ||||||
|     const attaque = RollDialog.saveParts(attackerRoll) |     const attaque = RollDialog.saveParts(attackerRoll) | ||||||
|     const defense = { |     const defense = { | ||||||
|       attackerRoll: attaque, |       attackerRoll: attaque, | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ export const ROLL_TYPE_TACHE = 'tache' | |||||||
| export const ATTAQUE_ROLL_TYPES = [ROLL_TYPE_ATTAQUE] | export const ATTAQUE_ROLL_TYPES = [ROLL_TYPE_ATTAQUE] | ||||||
| export const COMBAT_ROLL_TYPES = [ROLL_TYPE_ATTAQUE, ROLL_TYPE_DEFENSE] | export const COMBAT_ROLL_TYPES = [ROLL_TYPE_ATTAQUE, ROLL_TYPE_DEFENSE] | ||||||
| export const DEMIREVE_ROLL_TYPES = [ROLL_TYPE_SORT] | export const DEMIREVE_ROLL_TYPES = [ROLL_TYPE_SORT] | ||||||
| export const DEFAULT_ROLL_TYPES = [ROLL_TYPE_COMP, ROLL_TYPE_TACHE, ROLL_TYPE_MEDITATION, ROLL_TYPE_CUISINE, ROLL_TYPE_OEUVRE, ROLL_TYPE_JEU] | export const DEFAULT_ROLL_TYPES = [ROLL_TYPE_COMP, ROLL_TYPE_ATTAQUE, ROLL_TYPE_TACHE, ROLL_TYPE_MEDITATION, ROLL_TYPE_CUISINE, ROLL_TYPE_OEUVRE, ROLL_TYPE_JEU] | ||||||
|  |  | ||||||
|  |  | ||||||
| export const DIFF = { | export const DIFF = { | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ export class RollPartAttaque extends RollPartSelect { | |||||||
|   restore(rollData) { |   restore(rollData) { | ||||||
|     const saved = this.getSaved(rollData) |     const saved = this.getSaved(rollData) | ||||||
|     super.restore(rollData) |     super.restore(rollData) | ||||||
|     if (saved.dmg) { |     if (saved.dmg != undefined) { | ||||||
|       this.getCurrent(rollData).dmg = this.getSaved(rollData).dmg |       this.getCurrent(rollData).dmg = this.getSaved(rollData).dmg | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -12,22 +12,30 @@ export class RollPartCarac extends RollPartSelect { | |||||||
|  |  | ||||||
|   loadRefs(rollData) { |   loadRefs(rollData) { | ||||||
|     const refs = this.getRefs(rollData) |     const refs = this.getRefs(rollData) | ||||||
|     refs.all = this.$getActorCaracs(rollData) |     const actor = rollData.active.actor | ||||||
|  |     refs.all = [...this.$getActorCaracs(actor), ...this.$getCaracCompetenceCreature(actor)] | ||||||
|     refs.caracs = refs.all |     refs.caracs = refs.all | ||||||
|     this.$selectCarac(rollData) |     this.$selectCarac(rollData) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   choices(refs) { return refs.caracs } |   choices(refs) { return refs.caracs } | ||||||
|  |  | ||||||
|   $getActorCaracs(rollData) { |   $getActorCaracs(actor) { | ||||||
|     return Object.entries(rollData.active.actor.getCarac()) |     return Object.entries(actor.getCarac()) | ||||||
|       .filter(([key, c]) => key != 'taille') |       .filter(([key, c]) => key != 'taille') | ||||||
|       /* TODO: filter by context */ |  | ||||||
|       .map(([key, carac]) => { |       .map(([key, carac]) => { | ||||||
|         return RollPartCarac.$extractCarac(key, carac) |         return RollPartCarac.$extractCarac(key, carac) | ||||||
|       }) |       }) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   $getCaracCompetenceCreature(actor) { | ||||||
|  |     if (actor.isPersonnage()) { | ||||||
|  |       return [] | ||||||
|  |     } | ||||||
|  |     return actor.getCompetences() | ||||||
|  |       .map(it => { return { key: it.name, label: it.name, value: parseInt(it.system.carac_value) } }) | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static $extractCarac(key, carac) { |   static $extractCarac(key, carac) { | ||||||
|     return { |     return { | ||||||
|       key: key, |       key: key, | ||||||
| @@ -40,7 +48,6 @@ export class RollPartCarac extends RollPartSelect { | |||||||
|     allowed = allowed.filter(it => it != undefined) |     allowed = allowed.filter(it => it != undefined) | ||||||
|     const refs = this.getRefs(rollData) |     const refs = this.getRefs(rollData) | ||||||
|     refs.caracs = allowed.length > 0 |     refs.caracs = allowed.length > 0 | ||||||
|       // ? refs.all.filter(it => allowed.includes(Grammar.toLowerCaseNoAccent(it.key))) |  | ||||||
|       ? refs.all.filter(it => allowed.includes(it.key)) |       ? refs.all.filter(it => allowed.includes(it.key)) | ||||||
|       : refs.all |       : refs.all | ||||||
|     this.$selectCarac(rollData) |     this.$selectCarac(rollData) | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| import { ITEM_TYPES } from "../constants.js" | import { ITEM_TYPES } from "../constants.js" | ||||||
| import { Grammar } from "../grammar.js" | import { Grammar } from "../grammar.js" | ||||||
| import { CARACS, RdDCarac } from "../rdd-carac.js" | import { CARACS } from "../rdd-carac.js" | ||||||
| import { RdDTimestamp } from "../time/rdd-timestamp.js" | import { RdDTimestamp } from "../time/rdd-timestamp.js" | ||||||
| import { TMRUtility } from "../tmr-utility.js" | import { TMRUtility } from "../tmr-utility.js" | ||||||
| import { ROLL_TYPE_MEDITATION } from "./roll-constants.mjs" | import { ROLL_TYPE_MEDITATION } from "./roll-constants.mjs" | ||||||
| import { PART_CARAC } from "./roll-part-carac.mjs" | import { PART_CARAC, RollPartCarac } from "./roll-part-carac.mjs" | ||||||
| import { PART_COMP } from "./roll-part-comp.mjs" | import { PART_COMP } from "./roll-part-comp.mjs" | ||||||
| import { RollPartSelect } from "./roll-part-select.mjs" | import { RollPartSelect } from "./roll-part-select.mjs" | ||||||
| import { ROLLDIALOG_SECTION } from "./roll-part.mjs" | import { ROLLDIALOG_SECTION } from "./roll-part.mjs" | ||||||
| @@ -34,8 +34,9 @@ export class RollPartMeditation extends RollPartSelect { | |||||||
|  |  | ||||||
|   loadRefs(rollData) { |   loadRefs(rollData) { | ||||||
|     const refs = this.getRefs(rollData) |     const refs = this.getRefs(rollData) | ||||||
|     refs.meditations = rollData.active.actor.itemTypes[ITEM_TYPES.meditation] |     const actor = rollData.active.actor | ||||||
|       .map(it => RollPartMeditation.$extractMeditation(it, rollData.active.actor)) |     refs.meditations = actor.itemTypes[ITEM_TYPES.meditation] | ||||||
|  |       .map(it => RollPartMeditation.$extractMeditation(it, actor)) | ||||||
|  |  | ||||||
|     if (refs.meditations.length > 0) { |     if (refs.meditations.length > 0) { | ||||||
|       this.$selectMeditation(rollData) |       this.$selectMeditation(rollData) | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ | |||||||
|       {{>"systems/foundryvtt-reve-de-dragon/templates/item/icon-arme-broken.hbs" action.arme}} |       {{>"systems/foundryvtt-reve-de-dragon/templates/item/icon-arme-broken.hbs" action.arme}} | ||||||
|     </span> |     </span> | ||||||
|     <span class="competence-value">{{plusMoins action.comp.system.niveau}}</span> |     <span class="competence-value">{{plusMoins action.comp.system.niveau}}</span> | ||||||
|     <span class="competence-value">{{plusMoins action.dommagesArme}}</span> |     <span class="competence-value">{{plusMoins action.dommages}}</span> | ||||||
|     <span class="competence-value"></span> |     <span class="competence-value"></span> | ||||||
|     <span class="initiative-value"> |     <span class="initiative-value"> | ||||||
|       <a class="roll-init-arme" data-tooltip="{{action.name}}: initiative {{action.initiative}}"> |       <a class="roll-init-arme" data-tooltip="{{action.name}}: initiative {{action.initiative}}"> | ||||||
|   | |||||||
| @@ -10,8 +10,7 @@ | |||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}}{{#unless (eq current.comp.key '')}} / {{current.comp.label}}{{/unless}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -13,8 +13,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> "partial-infojet"}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -10,8 +10,7 @@ | |||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -15,8 +15,7 @@ | |||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <hr> |   <hr> | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|   </div> |   </div> | ||||||
|    |    | ||||||
|   <div class="chat-resume"> |   <div class="chat-resume"> | ||||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} |     {{> 'partial-infojet'}} | ||||||
|     <br>{{> 'partial-infojet'}} |  | ||||||
|   </div> |   </div> | ||||||
|  |  | ||||||
|   <div class="chat-details"> |   <div class="chat-details"> | ||||||
|   | |||||||
| @@ -1,3 +1,9 @@ | |||||||
|  | {{current.carac.label}} | ||||||
|  | {{#if (and (ne current.comp.key '') (ne current.carac.label current.comp.label))}} | ||||||
|  |  / {{current.comp.label}} | ||||||
|  | {{/if}} | ||||||
|  |  à {{current.diff.value}} | ||||||
|  | <br> | ||||||
| {{#if ajustements}} | {{#if ajustements}} | ||||||
| <div> | <div> | ||||||
|   <span class="tooltip-overflow tooltip-dotted" > |   <span class="tooltip-overflow tooltip-dotted" > | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user