forked from public/foundryvtt-reve-de-dragon
		
	Utilise RdDRoll pour les caracs
ajout d'un callback dédié à l'expérience limite de la table de résolution à 60 (rêve actuel jusqu'à 3x limite)
This commit is contained in:
		| @@ -268,7 +268,7 @@ export class RdDActorSheet extends ActorSheet { | ||||
|     }); | ||||
|  | ||||
|     html.find('#chance-appel').click((event) => { | ||||
|       this.actor.appelChance(); | ||||
|       this.actor.rollAppelChance(); | ||||
|     }); | ||||
|  | ||||
|     // Roll Skill | ||||
|   | ||||
| @@ -1355,61 +1355,90 @@ export class RdDActor extends Actor { | ||||
|   } | ||||
|    | ||||
|   /* -------------------------------------------- */   | ||||
|   async rollCarac( caracName ) | ||||
|   { | ||||
|     let carac = this.getCaracByName(caracName); | ||||
|     let rollData = {  | ||||
|       selectedCarac: carac, | ||||
|       ajustementsConditions: CONFIG.RDD.ajustementsConditions, | ||||
|       difficultesLibres: CONFIG.RDD.difficultesLibres, | ||||
|       etat: this.data.data.compteurs.etat.value,        | ||||
|       finalLevel: 0, | ||||
|       diffConditions: 0, | ||||
|       diffLibre: 0, | ||||
|       malusArmureValue: (this.data.data.attributs) ? this.data.data.attributs.malusarmure.value : 0, | ||||
|       surencMalusFlag: (this.data.data.compteurs.surenc.value < 0), | ||||
|       surencMalusValue: this.data.data.compteurs.surenc.value, | ||||
|       surencMalusApply: false, | ||||
|       isNatation: false, | ||||
|       useEncForNatation: false | ||||
|   _createCallbackExperience() { | ||||
|     return { | ||||
|       condition: r => r.rolled.isPart && r.finalLevel < 0 && game.settings.get("core", "rollMode") != 'selfroll', | ||||
|       action: r => this._appliquerAjoutExperience(r) | ||||
|     }; | ||||
|   } | ||||
|     console.log(caracName, rollData); | ||||
|     let html = await renderTemplate('systems/foundryvtt-reve-de-dragon/templates/dialog-roll-carac.html', rollData); | ||||
|     new RdDRollDialog("carac", html, rollData, this ).render(true); | ||||
|  | ||||
|   async _appliquerAjoutExperience(rollData) { | ||||
|     // TODO: si pas de compétence, minimum 1 pour carac | ||||
|     // TODO: appliquer l'expérience automatiquement | ||||
|     let xpmsg = RdDResolutionTable.buildXpMessage(rollData.rolled, rollData.finalLevel); | ||||
|     let message = ChatUtility.prepareChatMessage('gmroll', this.name); | ||||
|     message.content = "<strong>" + rollData.selectedCarac.label + "</strong>" | ||||
|           + xpmsg; | ||||
|     ChatMessage.create(message); | ||||
|   } | ||||
|  | ||||
|   /* -------------------------------------------- */   | ||||
|   async appelChance( ) | ||||
|   async rollCarac( caracName ) | ||||
|   { | ||||
|     let rollData = {  | ||||
|       selectedCarac: this.getCaracByName('chance-actuelle'), | ||||
|       diffConditions: this.ajustementAstrologique() | ||||
|     } | ||||
|     let rollData = { selectedCarac: this.getCaracByName(caracName) }; | ||||
|  | ||||
|     const dialog = await RdDRoll.create( | ||||
|       'systems/foundryvtt-reve-de-dragon/templates/dialog-roll-carac.html', | ||||
|       this, | ||||
|       rollData, | ||||
|     const dialog = await RdDRoll.create(this, rollData, | ||||
|       {html: 'systems/foundryvtt-reve-de-dragon/templates/dialog-roll-carac.html'}, | ||||
|       { | ||||
|         name: 'appelChance', | ||||
|         label: 'Appel à la chance', | ||||
|         name: 'jet-'+caracName, | ||||
|         label: 'Lancer : '+rollData.selectedCarac.label, | ||||
|         callbacks: [ | ||||
|           { action: rollData => this._appelChanceResultat(rollData) } | ||||
|           this._createCallbackExperience(), | ||||
|           { action: this._rollCaracResult } | ||||
|         ] | ||||
|       } | ||||
|     ); | ||||
|     dialog.render(true); | ||||
|   } | ||||
|  | ||||
|   async _rollCaracResult(rollData) { | ||||
|     let rolled = rollData.rolled; | ||||
|  | ||||
|     let resumeCompetence = (rollData.diffLibre + rollData.diffConditions); | ||||
|     let explications = "<br>Points de taches : " + rolled.ptTache; | ||||
|  | ||||
|     // Final chat message | ||||
|     let chatOptions = { | ||||
|       content: "<strong>Test : " + rollData.selectedCarac.label + " / " + resumeCompetence + "</strong>" | ||||
|           + "<br>Difficultés <strong>libre : " + rollData.diffLibre + "</strong> / conditions : " + Misc.toSignedString(rollData.diffConditions) +" / état : " + rollData.etat | ||||
|           + RdDResolutionTable.explain(rolled) | ||||
|           + explications | ||||
|     } | ||||
|      | ||||
|     ChatUtility.chatWithRollMode(chatOptions, this.name) | ||||
|   } | ||||
|  | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   _appelChanceResultat(rollData) { | ||||
|   async rollAppelChance( ) | ||||
|   { | ||||
|     let rollData = {  | ||||
|       selectedCarac: this.getCaracByName('chance-actuelle'), | ||||
|       diffConditions: this.ajustementAstrologique() | ||||
|     } | ||||
|  | ||||
|     const dialog = await RdDRoll.create(this, rollData, | ||||
|       { html: 'systems/foundryvtt-reve-de-dragon/templates/dialog-roll-carac.html'}, | ||||
|       { | ||||
|         name: 'appelChance', | ||||
|         label: 'Appel à la chance', | ||||
|         callbacks: [ | ||||
|           this._createCallbackExperience(), | ||||
|           { action: this._appelChanceResult } | ||||
|         ] | ||||
|       } | ||||
|     ); | ||||
|     dialog.render(true); | ||||
|   } | ||||
|  | ||||
|   _appelChanceResult(rollData) { | ||||
|     const message = { | ||||
|       user: game.user._id, | ||||
|       alias: this.name, | ||||
|       content: this.name + " fait appel à la chance" + RdDResolutionTable.explain(rollData.rolled) | ||||
|     }; | ||||
|     if (rollData.rolled.isSuccess) { | ||||
|       message.content += "<br>Dépense d'un point de chance, l'action peut être retentée" | ||||
|       message.content += "<br>Un point de chance est dépensée, l'action peut être retentée" | ||||
|       this.chanceActuelleIncDec(-1) | ||||
|     } | ||||
|     ChatMessage.create(message); | ||||
|   | ||||
| @@ -6,7 +6,10 @@ export class ChatUtility { | ||||
|  | ||||
|   static chatWithRollMode(chatOptions, name) { | ||||
|     let rollMode = game.settings.get("core", "rollMode"); | ||||
|     chatOptions.user = game.user._id; | ||||
|     ChatUtility.createChatMessage(chatOptions, rollMode, name); | ||||
|   } | ||||
|  | ||||
|   static createChatMessage( chatOptions, rollMode, name) { | ||||
|     switch (rollMode) { | ||||
|       case "blindroll": // GM only | ||||
|         if (!game.user.isGM) { | ||||
| @@ -19,24 +22,29 @@ export class ChatUtility { | ||||
|           chatOptions.whisper = ChatUtility.getUsers(user => user.isGM); | ||||
|         } | ||||
|         break; | ||||
|       case "gmroll": // GM + rolling player | ||||
|         chatOptions.user = game.user._id; | ||||
|         chatOptions.whisper = ChatUtility.getWhisperRecipientsAndGMs(name); | ||||
|         break; | ||||
|       case "selfroll": // only the user | ||||
|         chatOptions.user = game.user._id; | ||||
|         chatOptions.whisper = [game.user._id]; | ||||
|         break; | ||||
|       default: | ||||
|       case "roll": // everybody | ||||
|         chatOptions.whisper = undefined; | ||||
|         chatOptions.whisper = ChatUtility.getWhisperRecipients(rollMode, name); | ||||
|         break; | ||||
|     } | ||||
|  | ||||
|     console.log("roll message", chatOptions); | ||||
|     ChatMessage.create(chatOptions); | ||||
|   } | ||||
|  | ||||
|   static prepareChatMessage( rollMode, name) { | ||||
|     return { | ||||
|       user: game.user._id, | ||||
|       whisper: ChatUtility.getWhisperRecipients(rollMode, name) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   static getWhisperRecipients( rollMode, name) { | ||||
|     switch (rollMode) { | ||||
|       case "blindroll": return ChatUtility.getUsers(user => user.isGM); | ||||
|       case "gmroll": return ChatUtility.getWhisperRecipientsAndGMs(name); | ||||
|       case "selfroll": return [game.user._id]; | ||||
|     } | ||||
|     return undefined; | ||||
|   } | ||||
|  | ||||
|   static getWhisperRecipientsAndGMs(name) { | ||||
|     return ChatMessage.getWhisperRecipients(name) | ||||
|       .concat(this.getUsers(user => user.isGM)); | ||||
|   | ||||
| @@ -55,7 +55,7 @@ const reussites = [ | ||||
| const reussiteSignificative = reussites.find(r => r.code == "sign"); | ||||
| const reussiteNormale = reussites.find(r => r.code == "norm"); | ||||
| const echecNormal = reussites.find(r => r.code == "echec"); | ||||
|  | ||||
| const caracMaximumResolution = 60; | ||||
| /* -------------------------------------------- */ | ||||
| export class RdDResolutionTable { | ||||
|   static resolutionTable = this.build() | ||||
| @@ -63,7 +63,7 @@ export class RdDResolutionTable { | ||||
|   /* -------------------------------------------- */ | ||||
|   static build() { | ||||
|     let table = [] | ||||
|     for (var caracValue = 0; caracValue <= 60; caracValue++) { | ||||
|     for (var caracValue = 0; caracValue <= caracMaximumResolution; caracValue++) { | ||||
|       table[caracValue] = this._computeRow(caracValue); | ||||
|     } | ||||
|     return table; | ||||
| @@ -84,7 +84,7 @@ export class RdDResolutionTable { | ||||
|     if (rolled.caracValue != null && rolled.finalLevel!= null) { | ||||
|       message += "(" + rolled.caracValue + " à " + Misc.toSignedString(rolled.finalLevel) + ") "; | ||||
|     } | ||||
|     message += rolled.quality | ||||
|     message += '<strong>' + rolled.quality + '</strong>' | ||||
|     return message; | ||||
|  | ||||
|   } | ||||
| @@ -147,7 +147,6 @@ export class RdDResolutionTable { | ||||
|     return ""; | ||||
|   } | ||||
|  | ||||
|  | ||||
|   /* -------------------------------------------- */ | ||||
|   static _computeReussite(chances, roll) { | ||||
|     const reussite = reussites.find(x => x.condition(chances, roll)); | ||||
| @@ -219,7 +218,7 @@ export class RdDResolutionTable { | ||||
|   static _buildHTMLTable(caracValue, levelValue, minCarac, maxCarac, minLevel, maxLevel) { | ||||
|     let countColonnes = maxLevel - minLevel; | ||||
|     minCarac = Math.max(minCarac, 1); | ||||
|     maxCarac = Math.min(maxCarac, 30); | ||||
|     maxCarac = Math.min(maxCarac, caracMaximumResolution); | ||||
|     minLevel = Math.max(minLevel, -10); | ||||
|     maxLevel = Math.max(Math.min(maxLevel, 22), minLevel + countColonnes); | ||||
|  | ||||
|   | ||||
| @@ -10,17 +10,18 @@ import { RdDResolutionTable } from "./rdd-resolution-table.js"; | ||||
|  | ||||
| export class RdDRoll extends Dialog { | ||||
|  | ||||
|   static async create(htmlTemplate, actor, rollData, ...actions) { | ||||
|     RdDRoll._ensureCorrectActions(actions); | ||||
|   static async create(actor, rollData, dialogConfig, ...actions) { | ||||
|  | ||||
|     RdDRoll._ensureCorrectActions(actions); | ||||
|     RdDRoll._setDefaultOptions(actor, rollData); | ||||
|  | ||||
|     const html = await renderTemplate(htmlTemplate, rollData); | ||||
|     const html = await renderTemplate(dialogConfig.html, rollData); | ||||
|  | ||||
|     return new RdDRoll(actor, rollData, html, { | ||||
|       classes: ["rdddialog"], | ||||
|       width: 600, height: 500, 'z-index': 99999 | ||||
|     }, actions); | ||||
|     let options = { classes: ["rdddialog"], width: 600, height: 500, 'z-index': 99999 }; | ||||
|     if (dialogConfig.options) { | ||||
|       mergeObject(options, dialogConfig.options, { overwrite: true }) | ||||
|     } | ||||
|     return new RdDRoll(actor, rollData, html, options, actions); | ||||
|   } | ||||
|  | ||||
|   static _setDefaultOptions(actor, rollData) { | ||||
| @@ -44,12 +45,12 @@ export class RdDRoll extends Dialog { | ||||
|   } | ||||
|  | ||||
|   static _ensureCorrectActions(actions) { | ||||
|     if (actions.length==0) { | ||||
|     if (actions.length == 0) { | ||||
|       throw 'No action defined'; | ||||
|     } | ||||
|     actions.forEach(action => { | ||||
|       if (action.callbacks == undefined) { | ||||
|         action.callbacks = [{action: r => console.log(action.name, r)}]; | ||||
|         action.callbacks = [{ action: r => console.log(action.name, r) }]; | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| @@ -75,7 +76,7 @@ export class RdDRoll extends Dialog { | ||||
|     await RdDResolutionTable.rollData(this.rollData); | ||||
|     if (action.callbacks) | ||||
|       for (let callback of action.callbacks) { | ||||
|       if (callback.condition == undefined || callback.condition(this.rollData.rolled)) { | ||||
|         if (callback.condition == undefined || callback.condition(this.rollData)) { | ||||
|           callback.action(this.rollData); | ||||
|         } | ||||
|       } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user