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 - 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 | ||||
|  | ||||
| - Fix d'erreur au chargement de templates RollDialog | ||||
|   | ||||
| @@ -186,12 +186,12 @@ export class RdDActor extends RdDBaseActorSang { | ||||
|     const uniques = [] | ||||
|  | ||||
|     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 ecaillesEfficacite = arme.system.magique ? arme.system.ecaille_efficacite : 0; | ||||
|  | ||||
|       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)) { | ||||
|         return | ||||
|       } | ||||
| @@ -212,7 +212,7 @@ export class RdDActor extends RdDBaseActorSang { | ||||
|         main: main, | ||||
|         carac: { key: caracCode, value: caracValue }, | ||||
|         equipe: arme.system.equipe, | ||||
|         dommagesArme: dommagesArme, | ||||
|         dommages: dommages, | ||||
|         forceRequise: forceRequise, | ||||
|         initiative: RdDInitiative.getRollInitiative(caracValue, niveau, ajustement) | ||||
|       }) | ||||
|   | ||||
| @@ -176,10 +176,11 @@ export class RdDBaseActorReve extends RdDBaseActor { | ||||
|   } | ||||
|  | ||||
|   getCompetences(name = undefined, options = { onMessage: message => { } }) { | ||||
|     const all = [...this.itemTypes[ITEM_TYPES.competence], ...this.itemTypes[ITEM_TYPES.competencecreature]] | ||||
|     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 => { } }) { | ||||
| @@ -246,10 +247,10 @@ export class RdDBaseActorReve extends RdDBaseActor { | ||||
|     if (this.isEffectAllowed(statusId)) { | ||||
|       const effect = this.getEffectByStatus(statusId); | ||||
|       if (!status && effect) { | ||||
|         await this.deleteEmbeddedDocuments('ActiveEffect', [effect.id], { render: true}) | ||||
|         await this.deleteEmbeddedDocuments('ActiveEffect', [effect.id], { render: true }) | ||||
|       } | ||||
|       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: "" }) { | ||||
|     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); | ||||
|     await this.openRollDialog({ | ||||
|       name: 'jet-competence', | ||||
| @@ -423,32 +440,22 @@ export class RdDBaseActorReve extends RdDBaseActor { | ||||
|     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 }) { | ||||
|     RdDEmpoignade.checkEmpoignadeEnCours(this) | ||||
|  | ||||
|     const competence = this.getCompetence(idOrName); | ||||
|     if (competence.type != ITEM_TYPES.competencecreature && OptionsAvancees.isUsing(ROLL_DIALOG_V2)) { | ||||
|     if (OptionsAvancees.isUsing(ROLL_DIALOG_V2)) { | ||||
|       const rollData = { | ||||
|         ids: { actorId: this.id }, | ||||
|         type: { allowed: options.arme ? ATTAQUE_ROLL_TYPES : DEFAULT_ROLL_TYPES }, | ||||
|         selected: { | ||||
|           carac: competence.type == ITEM_TYPES.competencecreature ? { key: competence.name } : undefined, | ||||
|           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) { | ||||
|         rollData.selected.attaque = { arme: { id: options.arme.id }, comp: { id: competence.id } } | ||||
|         rollData.type = { allowed: ATTAQUE_ROLL_TYPES } | ||||
|       } | ||||
|  | ||||
|       await this.rollCompetenceV2(rollData) | ||||
|       return | ||||
|       return await RollDialog.create(rollData) | ||||
|     } | ||||
|  | ||||
|     let rollData = { | ||||
| @@ -512,19 +519,13 @@ export class RdDBaseActorReve extends RdDBaseActor { | ||||
|         title: 'Ne pas utiliser les automatisation de combat', | ||||
|         buttonLabel: "Pas d'automatisation", | ||||
|         onAction: async () => { | ||||
|           this.rollCompetenceV2({ | ||||
|             ids: { | ||||
|               actorId: this.id, | ||||
|               actorTokenId: token?.id, | ||||
|             }, | ||||
|             selected: { | ||||
|               conditions: { value: 0 } | ||||
|             }, | ||||
|           const rollData = { | ||||
|             ids: { actorId: this.id, actorTokenId: token?.id, }, | ||||
|             type: { | ||||
|               allowed: [ROLL_TYPE_COMP, ROLL_TYPE_ATTAQUE, ROLL_TYPE_OEUVRE, ROLL_TYPE_TACHE, ROLL_TYPE_JEU], | ||||
|               current: ROLL_TYPE_COMP | ||||
|               allowed: [ROLL_TYPE_ATTAQUE], current: ROLL_TYPE_ATTAQUE | ||||
|             } | ||||
|           }) | ||||
|           }; | ||||
|           return await RollDialog.create(rollData) | ||||
|         } | ||||
|       }) | ||||
|     } | ||||
|   | ||||
| @@ -56,8 +56,7 @@ export class RdDBaseActorSheet extends foundry.appv1.sheets.ActorSheet { | ||||
|     this._appliquerRechercheObjets(formData.conteneurs, formData.inventaires); | ||||
|     formData.conteneurs = RdDUtility.conteneursRacine(formData.conteneurs); | ||||
|     formData.competences.filter(it => it.type == ITEM_TYPES.competencecreature) | ||||
|       .forEach(it => it.isdommages = it.isDommages() | ||||
|       ) | ||||
|       .forEach(it => it.isdommages = it.isDommages()) | ||||
|  | ||||
|     return formData; | ||||
|   } | ||||
|   | ||||
| @@ -160,7 +160,7 @@ export class Mapping { | ||||
|       return undefined | ||||
|     } | ||||
|     const categorie = Mapping.complementCategorie(arme, maniement) | ||||
|     const dommages = Mapping.dommagesArme(actor, arme, maniement) | ||||
|     const dommages = Mapping.dommages(actor, arme, maniement) | ||||
|     return { | ||||
|       name: arme.name + categorie, | ||||
|       niveau: Misc.toSignedString(competence.system.niveau), | ||||
| @@ -170,7 +170,8 @@ export class Mapping { | ||||
|       arme: arme | ||||
|     } | ||||
|   } | ||||
|   static dommagesArme(actor, arme, maniement) { | ||||
|  | ||||
|   static dommages(actor, arme, maniement) { | ||||
|     const dmgArme = RdDItemArme.dommagesReels(arme, maniement) | ||||
|     const dommages = Misc.toSignedString(dmgArme + RdDBonus.bonusDmg(actor, maniement, dmgArme)) | ||||
|     switch (arme.system.mortalite) { | ||||
|   | ||||
| @@ -32,6 +32,7 @@ export class RdDItemCompetenceCreature extends RdDItem { | ||||
|             initiative: initative, | ||||
|             mortalite: this.system.mortalite, | ||||
|             dommages: this.system.dommages, | ||||
|             forceRequise: 0, | ||||
|             equipe: true, | ||||
|             resistance: 100, | ||||
|             penetration: 0, | ||||
| @@ -43,7 +44,8 @@ export class RdDItemCompetenceCreature extends RdDItem { | ||||
|         carac: { key: this.name, value: this.system.carac_value }, | ||||
|         equipe: true, | ||||
|         mortalite: this.system.mortalite, | ||||
|         dmg: this.system.dommages, | ||||
|         dommages: this.system.dommages, | ||||
|         //dmg: this.system.dommages, | ||||
|         initiative: initative | ||||
|       }; | ||||
|       return attaque | ||||
|   | ||||
| @@ -727,8 +727,6 @@ export class RdDCombat { | ||||
|     RollBasicParts.loadSurprises(attackerRoll) | ||||
|     attackerRoll.passeArme = attackerRoll.passeArme ?? foundry.utils.randomID(16) | ||||
|     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 defense = { | ||||
|       attackerRoll: attaque, | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export const ROLL_TYPE_TACHE = 'tache' | ||||
| export const ATTAQUE_ROLL_TYPES = [ROLL_TYPE_ATTAQUE] | ||||
| export const COMBAT_ROLL_TYPES = [ROLL_TYPE_ATTAQUE, ROLL_TYPE_DEFENSE] | ||||
| 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 = { | ||||
|   | ||||
| @@ -36,7 +36,7 @@ export class RollPartAttaque extends RollPartSelect { | ||||
|   restore(rollData) { | ||||
|     const saved = this.getSaved(rollData) | ||||
|     super.restore(rollData) | ||||
|     if (saved.dmg) { | ||||
|     if (saved.dmg != undefined) { | ||||
|       this.getCurrent(rollData).dmg = this.getSaved(rollData).dmg | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -12,22 +12,30 @@ export class RollPartCarac extends RollPartSelect { | ||||
|  | ||||
|   loadRefs(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 | ||||
|     this.$selectCarac(rollData) | ||||
|   } | ||||
|  | ||||
|   choices(refs) { return refs.caracs } | ||||
|  | ||||
|   $getActorCaracs(rollData) { | ||||
|     return Object.entries(rollData.active.actor.getCarac()) | ||||
|   $getActorCaracs(actor) { | ||||
|     return Object.entries(actor.getCarac()) | ||||
|       .filter(([key, c]) => key != 'taille') | ||||
|       /* TODO: filter by context */ | ||||
|       .map(([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) { | ||||
|     return { | ||||
|       key: key, | ||||
| @@ -40,7 +48,6 @@ export class RollPartCarac extends RollPartSelect { | ||||
|     allowed = allowed.filter(it => it != undefined) | ||||
|     const refs = this.getRefs(rollData) | ||||
|     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 | ||||
|     this.$selectCarac(rollData) | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { ITEM_TYPES } from "../constants.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 { TMRUtility } from "../tmr-utility.js" | ||||
| 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 { RollPartSelect } from "./roll-part-select.mjs" | ||||
| import { ROLLDIALOG_SECTION } from "./roll-part.mjs" | ||||
| @@ -34,6 +34,7 @@ export class RollPartMeditation extends RollPartSelect { | ||||
|  | ||||
|   loadRefs(rollData) { | ||||
|     const refs = this.getRefs(rollData) | ||||
|     refs.intellect = RollPartCarac.getActorCaracs(actor).find(it => it.key = CARACS.INTELLECT) | ||||
|     refs.meditations = rollData.active.actor.itemTypes[ITEM_TYPES.meditation] | ||||
|       .map(it => RollPartMeditation.$extractMeditation(it, rollData.active.actor)) | ||||
|  | ||||
| @@ -120,7 +121,7 @@ export class RollPartMeditation extends RollPartSelect { | ||||
|     if (this.visible(rollData)) { | ||||
|       const current = this.getCurrent(rollData) | ||||
|       switch (part.code) { | ||||
|         case PART_CARAC: return part.filterCaracs(rollData, [CARACS.INTELLECT]) | ||||
|         case PART_CARAC: return part.filterCaracs(rollData, [this.getRefs(rollData).intellect]) | ||||
|         case PART_COMP: return part.filterComps(rollData, [current.comp?.name]) | ||||
|       } | ||||
|     } | ||||
|   | ||||
| @@ -20,7 +20,7 @@ | ||||
|       {{>"systems/foundryvtt-reve-de-dragon/templates/item/icon-arme-broken.hbs" action.arme}} | ||||
|     </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="initiative-value"> | ||||
|       <a class="roll-init-arme" data-tooltip="{{action.name}}: initiative {{action.initiative}}"> | ||||
|   | ||||
| @@ -10,8 +10,7 @@ | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}}{{#unless (eq current.comp.key '')}} / {{current.comp.label}}{{/unless}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -13,8 +13,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> "partial-infojet"}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -10,8 +10,7 @@ | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-details"> | ||||
|   | ||||
| @@ -15,8 +15,7 @@ | ||||
|   </div> | ||||
|  | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <hr> | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|   </div> | ||||
|    | ||||
|   <div class="chat-resume"> | ||||
|     {{current.carac.label}} / {{current.comp.label}} à {{current.diff.value}} | ||||
|     <br>{{> 'partial-infojet'}} | ||||
|     {{> 'partial-infojet'}} | ||||
|   </div> | ||||
|  | ||||
|   <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}} | ||||
| <div> | ||||
|   <span class="tooltip-overflow tooltip-dotted" > | ||||
|   | ||||
		Reference in New Issue
	
	Block a user