Ehance UI and weapon damages
This commit is contained in:
		| @@ -38,7 +38,7 @@ export class VadentisActorSheet extends ActorSheet { | |||||||
|     data.equipements = this.actor.getEquipements(); |     data.equipements = this.actor.getEquipements(); | ||||||
|  |  | ||||||
|     data.optionsBase  = VadentisUtility.createDirectOptionList(0, 50); |     data.optionsBase  = VadentisUtility.createDirectOptionList(0, 50); | ||||||
|     data.optionsMalus = VadentisUtility.createDirectOptionList(-50, 0); |     data.optionsMalus = VadentisUtility.createDirectReverseOptionList(-50, 0); | ||||||
|     data.optionsBonus = VadentisUtility.createDirectOptionList(0, 50); |     data.optionsBonus = VadentisUtility.createDirectOptionList(0, 50); | ||||||
|     data.optionsPV    = VadentisUtility.createOptionList(-50, 200); |     data.optionsPV    = VadentisUtility.createOptionList(-50, 200); | ||||||
|     data.optionsPE    = VadentisUtility.createOptionList(-50, 200); |     data.optionsPE    = VadentisUtility.createOptionList(-50, 200); | ||||||
| @@ -103,6 +103,17 @@ export class VadentisActorSheet extends ActorSheet { | |||||||
|       const weapon = this.actor.getOwnedItem(li.data("item-id")); |       const weapon = this.actor.getOwnedItem(li.data("item-id")); | ||||||
|       this.actor.rollWeapon(weapon); |       this.actor.rollWeapon(weapon); | ||||||
|     }); |     }); | ||||||
|  |     html.find('.weapon-damage').click((event) => { | ||||||
|  |       const li = $(event.currentTarget).parents(".item"); | ||||||
|  |       const weapon = this.actor.getOwnedItem(li.data("item-id")); | ||||||
|  |       this.actor.rollDamage(weapon, 'damage'); | ||||||
|  |     }); | ||||||
|  |     html.find('.weapon-damage-critical').click((event) => { | ||||||
|  |       const li = $(event.currentTarget).parents(".item"); | ||||||
|  |       const weapon = this.actor.getOwnedItem(li.data("item-id")); | ||||||
|  |       this.actor.rollDamage(weapon, 'criticaldamage'); | ||||||
|  |     }); | ||||||
|  |      | ||||||
|     html.find('.competence-base').change((event) => { |     html.find('.competence-base').change((event) => { | ||||||
|       let skillName = event.currentTarget.attributes.skillname.value; |       let skillName = event.currentTarget.attributes.skillname.value; | ||||||
|       this.actor.updateCompetence(skillName, "base", parseInt(event.target.value)); |       this.actor.updateCompetence(skillName, "base", parseInt(event.target.value)); | ||||||
|   | |||||||
| @@ -1,5 +1,9 @@ | |||||||
|  | /* -------------------------------------------- */ | ||||||
| import { VadentisUtility } from "./vadentis-utility.js"; | import { VadentisUtility } from "./vadentis-utility.js"; | ||||||
|  |  | ||||||
|  | /* -------------------------------------------- */ | ||||||
|  | const MIN_PV = -50; | ||||||
|  | const MIN_PE = -50; | ||||||
|  |  | ||||||
| /* -------------------------------------------- */ | /* -------------------------------------------- */ | ||||||
| /** | /** | ||||||
| @@ -114,36 +118,84 @@ export class VadentisActor extends Actor { | |||||||
|     myRoll.evaluate(); |     myRoll.evaluate(); | ||||||
|     myRoll.toMessage( { flavor: `Lancer de ${name} : ${devotionSort.name} (${formulaFull})` } ); |     myRoll.toMessage( { flavor: `Lancer de ${name} : ${devotionSort.name} (${formulaFull})` } ); | ||||||
|      |      | ||||||
|     if (myRoll.total >= devotionSort.data.difficulty) { |     if (myRoll.results[0] > 1 && myRoll.total >= devotionSort.data.difficulty) { | ||||||
|       let content =  `${this.name} a réussi son ${name} et perd ${devotionSort.data.pe} Points d'Energie. L'effet suivant se produit: <br>${devotionSort.data.effect}`; |       let content =  `${this.name} a réussi son ${name} et perd ${devotionSort.data.pe} Points d'Energie. L'effet suivant se produit: <br>${devotionSort.data.effect}`; | ||||||
|       let newEnergie = this.data.data.stats.pointsenergie.value - devotionSort.data.pe; |       let newEnergie = this.data.data.stats.pointsenergie.value - devotionSort.data.pe; | ||||||
|       await this.update( {'data.stats.pointsenergie.value': newEnergie }); |       await this.update( {'data.stats.pointsenergie.value': newEnergie }); | ||||||
|  |  | ||||||
|       if ( devotionSort.data.damage != "") { |       if ( devotionSort.data.damage != "") { | ||||||
|  |         let degatsText = `<br>Et provoque les dégats suivants : `; | ||||||
|  |         let formula = devotionSort.data.damage; | ||||||
|         if (myRoll.results[0] == 20 ) { // Critique ? |         if (myRoll.results[0] == 20 ) { // Critique ? | ||||||
|           content += `<br>Et provoque les dégats critiques suivants : ${devotionSort.data.damagecritical}`; |           degatsText += `<br>Et provoque les dégats critiques suivants : `; | ||||||
|         } else { |           formula = devotionSort.data.damagecritical; | ||||||
|           content += `<br>Et provoque les dégats suivants : ${devotionSort.data.damage}`; |         }  | ||||||
|  |         content += degatsText; | ||||||
|  |         /*let myRoll = new Roll(formula); | ||||||
|  |         myRoll.evaluate(); | ||||||
|  |         if (game.modules.get("dice-so-nice") && game.modules.get("dice-so-nice").active) { | ||||||
|  |           await game.dice3d.showForRoll(degatsRoll, game.user, true); | ||||||
|         } |         } | ||||||
|  |         content += myRoll.total + `(${devotionSort.data.damagecritical})`; */ | ||||||
|  |         content += `${devotionSort.data.damagecritical}`; | ||||||
|       } |       } | ||||||
|       if ( newEnergie < 0) { |       if ( newEnergie < 0) { | ||||||
|         content += `<br>Les Points d'Energie de ${this.name} sont négatifs ! Il convient d'éditer ses Points de Vie en conséquence.`; |         content += `<br><strong>Attention</strong> : Les Points d'Energie de ${this.name} sont négatifs ! Il convient d'éditer ses Points de Vie en conséquence.`; | ||||||
|       } |       } | ||||||
|       ChatMessage.create( { content: content} );       |       ChatMessage.create( { content: content} );       | ||||||
|     } else { |     } else { | ||||||
|       ChatMessage.create( { content: `${this.name} a échoué son lancer de ${name}` } ); |       if (myRoll.results[0] == 1 ) { // Critique ? | ||||||
|  |         ChatMessage.create( { content: `${this.name} a fait un <strong>échec critique</strong> à son lancer de ${name}` } ); | ||||||
|  |       } else { | ||||||
|  |         ChatMessage.create( { content: `${this.name} a échoué son lancer de ${name}` } ); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   async rollDamage( weapon, damageType ) { | ||||||
|  |     let formula = VadentisUtility.processDamageString( weapon.data.data[damageType], this ); | ||||||
|  |     let degatsRoll = await VadentisUtility.processRoll( formula ); | ||||||
|  |  | ||||||
|  |     ChatMessage.create( { content: `${this.name} frappe avec ${weapon.name} et produit ${degatsRoll.total} Points de Dégâts (${formula}).` } ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   async applyDamage( damageValue ) { | ||||||
|  |     let pvData = this.data.data.stats.pointsvie; | ||||||
|  |     let newValue = Math.max( pvData.value - damageValue, MIN_PV); | ||||||
|  |     await this.update( {'data.stats.pointsvie.value': newValue }); | ||||||
|  |     ChatMessage.create( { content: `${this.name} vient de perdre ${damageValue} Points de Vie. Ses Points de Vie actuels sont désormais de ${newValue}.` } ); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   _getCombatValue(mydata) { | ||||||
|  |     if ( Number(mydata.base)) { | ||||||
|  |       return mydata.base + mydata.malus + mydata.bonus; | ||||||
|  |     }else { | ||||||
|  |       return Number(mydata.base[0]) + Number(mydata.malus[0]) + Number(mydata.bonus[0]); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   getInitiativeScore(  ) { | ||||||
|  |     let initData = this.data.data.combat.initiative; | ||||||
|  |     return this._getCombatValue( initData); | ||||||
|  |   } | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   getDefenseScore(  ) { |   getDefenseScore(  ) { | ||||||
|     let defenseData = this.data.data.combat.defense; |     let defenseData = this.data.data.combat.defense; | ||||||
|     return defenseData.base + defenseData.malus + defenseData.bonus; |     return this._getCombatValue( defenseData); | ||||||
|  |   } | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   getForceScore(  ) { | ||||||
|  |     let forceData = this.data.data.combat.force; | ||||||
|  |     return this._getCombatValue( forceData); | ||||||
|   } |   } | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   getAttaqueScore(  ) { |   getAttaqueScore(  ) { | ||||||
|     let attaqueData = this.data.data.combat.attaque; |     let attaqueData = this.data.data.combat.attaque; | ||||||
|     return attaqueData.base + attaqueData.malus + attaqueData.bonus; |     return this._getCombatValue( attaqueData); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
| @@ -193,7 +245,7 @@ export class VadentisActor extends Actor { | |||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   rollCombat( combatName ) { |   rollCombat( combatName ) { | ||||||
|     let stat = this.data.data.combat[combatName]; |     let stat = this.data.data.combat[combatName]; | ||||||
|     let statValue = stat.base + stat.malus + stat.bonus; |     let statValue = this._getCombatValue( stat ); | ||||||
|     let formulaFull = `1d20+${stat.base}+${stat.malus}+${stat.bonus}`; |     let formulaFull = `1d20+${stat.base}+${stat.malus}+${stat.bonus}`; | ||||||
|     let myRoll = new Roll("1d20+"+statValue); |     let myRoll = new Roll("1d20+"+statValue); | ||||||
|     myRoll.evaluate(); |     myRoll.evaluate(); | ||||||
|   | |||||||
| @@ -3,5 +3,43 @@ import { VadentisUtility } from "./vadentis-utility.js"; | |||||||
| /* -------------------------------------------- */ | /* -------------------------------------------- */ | ||||||
| export class VadentisCombat extends Combat { | export class VadentisCombat extends Combat { | ||||||
|    |    | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   async rollInitiative(ids, formula = undefined, messageOptions = {} ) { | ||||||
|  |     console.log("Initiative is requested !!!"); | ||||||
|  |  | ||||||
|  |     ids = typeof ids === "string" ? [ids] : ids; | ||||||
|  |     const currentId = this.combatant._id; | ||||||
|  |     for (let cId = 0; cId < ids.length; cId++) { | ||||||
|  |       const c = this.getCombatant(ids[cId]); | ||||||
|  |       let initBonus = c.actor ? c.actor.getInitiativeScore() : 0; | ||||||
|  |       console.log("Init for ", initBonus); | ||||||
|  |       const roll = super._getInitiativeRoll(c, "1d20+"+initBonus); | ||||||
|  |  | ||||||
|  |       if (roll.total <= 0) roll.total = 0; | ||||||
|  |       console.log("Compute init for", roll.total); | ||||||
|  |       await this.updateEmbeddedEntity("Combatant", { _id: c._id, initiative: roll.total }); | ||||||
|  |  | ||||||
|  |       // Send a chat message | ||||||
|  |       let rollMode = messageOptions.rollMode || game.settings.get("core", "rollMode"); | ||||||
|  |       let messageData = mergeObject( | ||||||
|  |         { | ||||||
|  |           speaker: { | ||||||
|  |             scene: canvas.scene._id, | ||||||
|  |             actor: c.actor ? c.actor._id : null, | ||||||
|  |             token: c.token._id, | ||||||
|  |             alias: c.token.name, | ||||||
|  |             sound: CONFIG.sounds.dice, | ||||||
|  |           }, | ||||||
|  |           flavor: `${c.token.name} a fait son jet d'Initiative (1d20+${initBonus}) | ||||||
|  |           <br> | ||||||
|  |           `, | ||||||
|  |         }, | ||||||
|  |         messageOptions | ||||||
|  |       ); | ||||||
|  |       roll.toMessage(messageData, { rollMode, create: true }); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return this; | ||||||
|  |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -18,11 +18,22 @@ export class VadentisUtility extends Entity { | |||||||
|     return loadTemplates(templatePaths);     |     return loadTemplates(templatePaths);     | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static updateCombat( combat, round, diff, id ) { | ||||||
|  |     if (game.user.isGM && combat.data.round != 0 && combat.turns && combat.data.active) { | ||||||
|  |       let turn = combat.turns.find(t => t.tokenId == combat.current.tokenId); | ||||||
|  |       ChatMessage.create( { content: `Round ${combat.data.round} : C'est au tour de ${turn.actor.name}<br>` } ); | ||||||
|  |  | ||||||
|  |       canvas.tokens.get(turn.token._id).control(); | ||||||
|  |       canvas.tokens.cycleTokens(1, true); | ||||||
|  |     }     | ||||||
|  |   } | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   static createOptionList( min, max) { |   static createOptionList( min, max) { | ||||||
|     let options = "" |     let options = "" | ||||||
|     for(let i=min; i<=max; i++) { |     for(let i=min; i<=max; i++) { | ||||||
|       options+= `<option value="${i}">${i}</option>\n`; |       options += `<option value="${i}">${i}</option>\n`; | ||||||
|     } |     } | ||||||
|     return options; |     return options; | ||||||
|   } |   } | ||||||
| @@ -31,10 +42,18 @@ export class VadentisUtility extends Entity { | |||||||
|   static createDirectOptionList( min, max) { |   static createDirectOptionList( min, max) { | ||||||
|     let options = {}; |     let options = {}; | ||||||
|     for(let i=min; i<=max; i++) { |     for(let i=min; i<=max; i++) { | ||||||
|       options[i] = i; |       options[`${i}`] = `${i}`; | ||||||
|     } |     } | ||||||
|     return options; |     return options; | ||||||
|  |   } | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static createDirectReverseOptionList( min, max) { | ||||||
|  |     let options = {}; | ||||||
|  |     for(let i=max; i>=min; i--) { | ||||||
|  |       options[`${i}`] = `${i}`; | ||||||
|     } |     } | ||||||
|  |     return options; | ||||||
|  |   } | ||||||
|    |    | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   static getTarget() { |   static getTarget() { | ||||||
| @@ -46,6 +65,25 @@ export class VadentisUtility extends Entity { | |||||||
|     return undefined; |     return undefined; | ||||||
|   } |   } | ||||||
|    |    | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static processDamageString( formula, actor ) { | ||||||
|  |     let workFormula = formula.toLowerCase(); | ||||||
|  |     if ( workFormula.includes('bonus de force')) { | ||||||
|  |       workFormula = workFormula.replace('bonus de force', actor.getForceScore()); | ||||||
|  |     } | ||||||
|  |     return workFormula; | ||||||
|  |   }  | ||||||
|  |  | ||||||
|  |   /* -------------------------------------------- */ | ||||||
|  |   static async processRoll( formula ) { | ||||||
|  |     let myRoll = new Roll(formula); | ||||||
|  |     myRoll.evaluate(); | ||||||
|  |     if (game.modules.get("dice-so-nice") && game.modules.get("dice-so-nice").active) { | ||||||
|  |       await game.dice3d.showForRoll(myRoll, game.user, true); | ||||||
|  |     } | ||||||
|  |     return myRoll; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   /* -------------------------------------------- */ |   /* -------------------------------------------- */ | ||||||
|   static async performAttack( combatData) { |   static async performAttack( combatData) { | ||||||
|     let attacker = game.actors.get(combatData.attackerActorId); |     let attacker = game.actors.get(combatData.attackerActorId); | ||||||
| @@ -53,16 +91,27 @@ export class VadentisUtility extends Entity { | |||||||
|     if( attacker && defender) { |     if( attacker && defender) { | ||||||
|       let defense = defender.getDefenseScore(); |       let defense = defender.getDefenseScore(); | ||||||
|       let attaque = attacker.getAttaqueScore(); |       let attaque = attacker.getAttaqueScore(); | ||||||
|       console.log("Attaque : ", attaque); |  | ||||||
|       let myRoll = new Roll("1d20"+attaque); |       let myRoll = await this.processRoll("1d20+"+attaque); | ||||||
|       myRoll.evaluate() |       if (myRoll.results[0] > 1 && myRoll.total >= defense) { // Success ! | ||||||
|       if (game.modules.get("dice-so-nice") && game.modules.get("dice-so-nice").active) { |         let degats = `normaux : ${combatData.arme.data.damage}`; | ||||||
|         await game.dice3d.showForRoll(myRoll, game.user, true); |         let formula = combatData.arme.data.damage.toLowerCase(); | ||||||
|       } |         if ( myRoll.results[0] == 20) { | ||||||
|       if (myRoll.total >= defense) { // Success ! |           degats = `critiques : ${combatData.arme.data.criticaldamage}`; | ||||||
|         ChatMessage.create( { content: `${attacker.name} a réussi son attaque sur ${defender.name} (${myRoll.total} / ${defense}) !<br> Les dégâts sont de : ${combatData.arme.data.damage}`}); |           formula = combatData.arme.data.criticaldamage.toLowerCase(); | ||||||
|  |         } | ||||||
|  |         ChatMessage.create( { content: `${attacker.name} a réussi son attaque sur ${defender.name} (${myRoll.total} / ${defense}) !<br> Les dégâts sont ${degats}`}); | ||||||
|  |          | ||||||
|  |         formula = this.processDamageString( formula, attacker );         | ||||||
|  |         let degatsRoll = await this.processRoll(formula); | ||||||
|  |         ChatMessage.create( { content: `Et les dégats infligés sont de ${degatsRoll.total} (${formula}) à appliquer à ${defender.name}`}); | ||||||
|  |         defender.applyDamage( degatsRoll.total ); | ||||||
|       } else { //Echec |       } else { //Echec | ||||||
|         ChatMessage.create( { content: `${attacker.name} a raté son attaque sur ${defender.name} (${myRoll.total} / ${defense}) !` }); |         if ( myRoll.results[0] == 1) { | ||||||
|  |           ChatMessage.create( { content: `${attacker.name} a fait un <strong>échec critique</strong> et a raté son attaque sur ${defender.name} (${myRoll.total} / ${defense}) !` }); | ||||||
|  |         } else { | ||||||
|  |           ChatMessage.create( { content: `${attacker.name} a raté son attaque sur ${defender.name} (${myRoll.total} / ${defense}) !` }); | ||||||
|  |         } | ||||||
|       } |       } | ||||||
|     } else { |     } else { | ||||||
|       ui.notifications.warn("Impossible de trouver l'attaquant et le défenseur.") |       ui.notifications.warn("Impossible de trouver l'attaquant et le défenseur.") | ||||||
|   | |||||||
| @@ -6,3 +6,14 @@ | |||||||
| {"name":"Donnée de la Foudre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"gypftiVXTACPuTg2"} | {"name":"Donnée de la Foudre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"gypftiVXTACPuTg2"} | ||||||
| {"name":"Donnée de la Terre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"huZaByOsJ4OgOQM0"} | {"name":"Donnée de la Terre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"huZaByOsJ4OgOQM0"} | ||||||
| {"name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"xhNHMkKLL4kW0Sts"} | {"name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"xhNHMkKLL4kW0Sts"} | ||||||
|  | {"_id":"xhNHMkKLL4kW0Sts","name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_eau.webp","effects":[]} | ||||||
|  | {"_id":"xhNHMkKLL4kW0Sts","name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[]} | ||||||
|  | {"_id":"xhNHMkKLL4kW0Sts","name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[]} | ||||||
|  | {"_id":"xhNHMkKLL4kW0Sts","name":"Donnée de l'Eau","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_eau.webp","effects":[]} | ||||||
|  | {"_id":"5rTJDLgO7HjQsPbr","name":"Donnée de l'Ombre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_ombre.webp","effects":[]} | ||||||
|  | {"_id":"gypftiVXTACPuTg2","name":"Donnée de la Foudre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_foudre.webp","effects":[]} | ||||||
|  | {"_id":"grt6xY5BY1kPGsmV","name":"Donnée de la Lumière","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_lumi%C3%A8re.webp","effects":[]} | ||||||
|  | {"_id":"huZaByOsJ4OgOQM0","name":"Donnée de la Terre","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_terre.webp","effects":[]} | ||||||
|  | {"_id":"aIpYtzCM1yWCDAU6","name":"Donnée des Sentiments","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_sentiments.webp","effects":[]} | ||||||
|  | {"_id":"RrwN3NGZQZmlE1xn","name":"Donnée du Feu","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_feu.webp","effects":[]} | ||||||
|  | {"_id":"3Rm5NhRowtPPXDGY","name":"Donnée du Vent","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"donnee","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/donn%C3%A9e_vent.webp","effects":[]} | ||||||
|   | |||||||
| @@ -5,3 +5,10 @@ | |||||||
| {"name":"Adorateurs de Yeshua","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"TV6QiHWXprN8PBjm"} | {"name":"Adorateurs de Yeshua","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"TV6QiHWXprN8PBjm"} | ||||||
| {"name":"Eglise du Soleil","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"muPAkVllu9D6cE7Q"} | {"name":"Eglise du Soleil","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"muPAkVllu9D6cE7Q"} | ||||||
| {"name":"Eglise du Temps","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"nEAicuYriaP3hmc2"} | {"name":"Eglise du Temps","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[],"_id":"nEAicuYriaP3hmc2"} | ||||||
|  | {"_id":"TV6QiHWXprN8PBjm","name":"Adorateurs de Yeshua","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[]} | ||||||
|  | {"_id":"1gQX3Uq6tVXAtQcX","name":"Eglise des 26","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/eglise_26.webp","effects":[]} | ||||||
|  | {"_id":"KWX1EDBkp1yPhoa0","name":"Eglise des Ombres","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/eglise_ombres.webp","effects":[]} | ||||||
|  | {"_id":"muPAkVllu9D6cE7Q","name":"Eglise du Soleil","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/eglise_soleil.webp","effects":[]} | ||||||
|  | {"_id":"nEAicuYriaP3hmc2","name":"Eglise du Temps","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/eglise_temps.webp","effects":[]} | ||||||
|  | {"_id":"5T2uht7mCGI9rzyo","name":"Eglise Estuanienne","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"systems/foundryvtt-vadentis/images/icons/eglise_estuanienne.webp","effects":[]} | ||||||
|  | {"_id":"9bBe6gQLAnM5dpFq","name":"Les Elus d'Estuans","permission":{"default":0,"sCecJLVlaPEcY7nF":3},"type":"eglise","data":{"description":""},"flags":{},"img":"icons/svg/mystery-man.svg","effects":[]} | ||||||
|   | |||||||
| @@ -95,7 +95,12 @@ | |||||||
|   text-shadow: 0 0 10px red; |   text-shadow: 0 0 10px red; | ||||||
|   cursor: pointer; |   cursor: pointer; | ||||||
| } | } | ||||||
|  | input:disabled { | ||||||
|  |   color:#1c2058; | ||||||
|  | } | ||||||
|  | select:disabled { | ||||||
|  |   color:#1c2058; | ||||||
|  | } | ||||||
| table {border: 1px solid #7a7971;} | table {border: 1px solid #7a7971;} | ||||||
|  |  | ||||||
| .grid, .grid-2col { | .grid, .grid-2col { | ||||||
| @@ -383,7 +388,7 @@ table {border: 1px solid #7a7971;} | |||||||
|   text-align: right; |   text-align: right; | ||||||
| } | } | ||||||
|  |  | ||||||
| .rdddialog .dialog-roll-sort s{ | .rdddialog .dialog-roll-sort { | ||||||
|   width: 600px; |   width: 600px; | ||||||
|   height: 430px; |   height: 430px; | ||||||
|   z-index: 9999; |   z-index: 9999; | ||||||
| @@ -444,7 +449,7 @@ table {border: 1px solid #7a7971;} | |||||||
| /* ======================================== */ | /* ======================================== */ | ||||||
| /* Sheet  */ | /* Sheet  */ | ||||||
| .window-app.sheet .window-content .sheet-header{ | .window-app.sheet .window-content .sheet-header{ | ||||||
|   background: #011d33 url("img/bg_header.webp") no-repeat left top; |   background: #011d33 url("../images/ui/texture_feuille_perso_principale.webp") no-repeat left top; | ||||||
|   color: rgba(255, 255, 255, 1); |   color: rgba(255, 255, 255, 1); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -456,7 +461,7 @@ table {border: 1px solid #7a7971;} | |||||||
| } | } | ||||||
|  |  | ||||||
| .window-app .window-content, .window-app.sheet .window-content .sheet-body{ | .window-app .window-content, .window-app.sheet .window-content .sheet-body{ | ||||||
|   background: rgb(245,245,240) url("img/bg_left.jpg") no-repeat left top; |   background: rgb(245,245,240) url("../images/ui/texture_feuille_perso_onglets.webp") no-repeat left top; | ||||||
| } | } | ||||||
|  |  | ||||||
| section.sheet-body{padding: 0.25rem 0.5rem;} | section.sheet-body{padding: 0.25rem 0.5rem;} | ||||||
| @@ -481,7 +486,7 @@ section.sheet-body{padding: 0.25rem 0.5rem;} | |||||||
|   border-top: 0 none; |   border-top: 0 none; | ||||||
|   border-bottom: 0 none; |   border-bottom: 0 none; | ||||||
|   color: rgba(52, 52, 52, 0.95); |   color: rgba(52, 52, 52, 0.95); | ||||||
|   background: rgb(245,245,240) url("img/bg_menu.jpg") no-repeat left top; |   background: rgb(245,245,240) url("../images/ui/texture_feuille_perso_onglets.webp") no-repeat left top; | ||||||
| } | } | ||||||
|  |  | ||||||
| nav.sheet-tabs .item { | nav.sheet-tabs .item { | ||||||
| @@ -890,7 +895,7 @@ ul, li { | |||||||
| /* Sidebar CSS */ | /* Sidebar CSS */ | ||||||
| #sidebar { | #sidebar { | ||||||
|   font-size: 1rem; |   font-size: 1rem; | ||||||
|   background: rgb(105,85,65) url("img/bg_sid_dark.jpg") no-repeat right bottom; |   background: rgb(105,85,65) url("../images/ui/texture_feuille_perso_principale.webp") no-repeat right bottom; | ||||||
|   background-position: 100%; |   background-position: 100%; | ||||||
|   color: rgba(220,220,220,0.75); |   color: rgba(220,220,220,0.75); | ||||||
| } | } | ||||||
| @@ -1373,7 +1378,7 @@ display: inline-flex; | |||||||
|   color: #CCC |   color: #CCC | ||||||
| } | } | ||||||
| #pause > img { | #pause > img { | ||||||
|   content: url(img/rdd_pause.png); |   content: url(../images/ui/logo_transparent.webp); | ||||||
|   height: 256px; |   height: 256px; | ||||||
|   width: 256px; |   width: 256px; | ||||||
|   top: -75px; |   top: -75px; | ||||||
| @@ -1381,7 +1386,7 @@ display: inline-flex; | |||||||
| } | } | ||||||
|  |  | ||||||
| #logo { | #logo { | ||||||
|   content : url(img/logo.png); |   content : url(../images/ui/logo_complet.webp); | ||||||
|   width: 80px; |   width: 80px; | ||||||
|   height: 68px; |   height: 68px; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,11 +2,11 @@ | |||||||
|   "name": "foundryvtt-vadentis", |   "name": "foundryvtt-vadentis", | ||||||
|   "title": "Vadentis", |   "title": "Vadentis", | ||||||
|   "description": "Système Vadentis pour FoundryVTT", |   "description": "Système Vadentis pour FoundryVTT", | ||||||
|   "version": "0.0.11", |   "version": "0.0.13", | ||||||
|   "manifestPlusVersion": "1.0.0", |   "manifestPlusVersion": "1.0.0", | ||||||
|   "minimumCoreVersion": "0.7.5", |   "minimumCoreVersion": "0.7.5", | ||||||
|   "compatibleCoreVersion": "0.7.9", |   "compatibleCoreVersion": "0.7.9", | ||||||
|   "templateVersion": 9, |   "templateVersion": 11, | ||||||
|   "author": "Uberwald", |   "author": "Uberwald", | ||||||
|   "esmodules": [ "modules/vadentis-main.js" ], |   "esmodules": [ "modules/vadentis-main.js" ], | ||||||
|   "styles": ["styles/simple.css"], |   "styles": ["styles/simple.css"], | ||||||
|   | |||||||
| @@ -102,6 +102,7 @@ | |||||||
|       "effect": "", |       "effect": "", | ||||||
|       "notes": "", |       "notes": "", | ||||||
|       "damage": "", |       "damage": "", | ||||||
|  |       "ismaintain": false, | ||||||
|       "damagecritical": "" |       "damagecritical": "" | ||||||
|     }, |     }, | ||||||
|     "equipcommun": { |     "equipcommun": { | ||||||
|   | |||||||
| @@ -26,8 +26,8 @@ | |||||||
|         {{!-- Carac Tab --}} |         {{!-- Carac Tab --}} | ||||||
|         <div class="tab items" data-group="primary" data-tab="principal"> |         <div class="tab items" data-group="primary" data-tab="principal"> | ||||||
|           <span><a class="lock-unlock-sheet"><img class="small-button-container"  |           <span><a class="lock-unlock-sheet"><img class="small-button-container"  | ||||||
|             src="systems/foundryvtt-vadentis/images/icons/{{#if editScore}}unlocked.svg{{else}}locked.svg{{/if}}" alt="Editable/Vérouillé"> |             src="systems/foundryvtt-vadentis/images/icons/{{#if editScore}}unlocked.svg{{else}}locked.svg{{/if}}" alt="Editable/Vérouillé" | ||||||
|             {{#if editScore}}Editable{{else}}Vérouillé{{/if}}</a> |             >{{#if editScore}}Editable{{else}}Vérouillé{{/if}}</a> | ||||||
|           </span> |           </span> | ||||||
|           <div class="grid grid-2col"> |           <div class="grid grid-2col"> | ||||||
|             <div class=""> |             <div class=""> | ||||||
| @@ -126,8 +126,8 @@ | |||||||
|                   <li class="stat flexrow list-item" data-attribute="{{key}}"> |                   <li class="stat flexrow list-item" data-attribute="{{key}}"> | ||||||
|                     <span class="stat-label combat-label flexrow tooltip tooltip-nobottom" name="data.combat.{{key}}.label"><a name="{{key}}">{{mycombat.label}}</a></span> |                     <span class="stat-label combat-label flexrow tooltip tooltip-nobottom" name="data.combat.{{key}}.label"><a name="{{key}}">{{mycombat.label}}</a></span> | ||||||
|                     <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.base" value="{{mycombat.base}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> |                     <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.base" value="{{mycombat.base}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> | ||||||
|                       {{selectOptions @root.optionsBase selected=mycombat.base localize=false}} |                       {{selectOptions @root.optionsBase selected=mycombat.base  localize=false}} | ||||||
|                     </select>  |                     </select> | ||||||
|                     <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.malus" value="{{mycombat.malus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> |                     <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.malus" value="{{mycombat.malus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> | ||||||
|                       {{selectOptions @root.optionsMalus selected=mycombat.malus localize=false}} |                       {{selectOptions @root.optionsMalus selected=mycombat.malus localize=false}} | ||||||
|                     </select>  |                     </select>  | ||||||
| @@ -218,23 +218,17 @@ | |||||||
|               <span class="flexrow tooltip tooltip-nobottom" name="statlabel">Bonus</span> |               <span class="flexrow tooltip tooltip-nobottom" name="statlabel">Bonus</span> | ||||||
|               <span class="flexrow tooltip tooltip-nobottom" name="statlabel">Malus</span> |               <span class="flexrow tooltip tooltip-nobottom" name="statlabel">Malus</span> | ||||||
|             </li> |             </li> | ||||||
|             {{#each data.combat as |combat key|}} |             {{#each data.combat as |mycombat key|}} | ||||||
|               <li class="stat flexrow list-item" data-attribute="{{key}}"> |               <li class="stat flexrow list-item" data-attribute="{{key}}"> | ||||||
|                 <span class="stat-label combat-label flexrow tooltip tooltip-nobottom" name="data.combat.{{key}}.label"><a name="{{key}}">{{combat.label}}</a></span> |                 <span class="stat-label combat-label flexrow tooltip tooltip-nobottom" name="data.combat.{{key}}.label"><a name="{{key}}">{{mycombat.label}}</a></span> | ||||||
|                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.base" value="{{combat.base}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> |                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.base" value="{{mycombat.base}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> | ||||||
|                   {{#select data.combat.base}} |                   {{selectOptions @root.optionsBase selected=mycombat.base  localize=false}} | ||||||
|                   {{{@root.optionsBase}}} |  | ||||||
|                   {{/select}} |  | ||||||
|                 </select>  |                 </select>  | ||||||
|                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.malus" value="{{combat.malus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> |                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.malus" value="{{mycombat.malus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> | ||||||
|                   {{#select data.combat.malus}} |                   {{selectOptions @root.optionsMalus selected=mycombat.malus  localize=false}} | ||||||
|                   {{{@root.optionsMalus}}} |  | ||||||
|                   {{/select}} |  | ||||||
|                 </select>  |                 </select>  | ||||||
|                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.bonus" value="{{combat.bonus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> |                 <select class="stat-value flexrow" type="text" name="data.combat.{{key}}.bonus" value="{{mycombat.bonus}}" data-dtype="Number" {{#unless @root.editScore}}disabled{{/unless}}> | ||||||
|                   {{#select data.combat.bonus}} |                   {{selectOptions @root.optionsBonus selected=mycombat.bonus  localize=false}} | ||||||
|                   {{{@root.optionsBonus}}} |  | ||||||
|                   {{/select}} |  | ||||||
|                 </select>  |                 </select>  | ||||||
|               </li> |               </li> | ||||||
|             {{/each}} |             {{/each}} | ||||||
| @@ -246,7 +240,7 @@ | |||||||
|             <li class="item flexrow list-item" data-item-id="{{arme._id}}"> |             <li class="item flexrow list-item" data-item-id="{{arme._id}}"> | ||||||
|               <img class="sheet-competence-img" src="{{arme.img}}"/> |               <img class="sheet-competence-img" src="{{arme.img}}"/> | ||||||
|               <span class="arme-label"><a>{{arme.name}}</a></span> |               <span class="arme-label"><a>{{arme.name}}</a></span> | ||||||
|               <span class="generic-label">{{arme.data.damage}} / {{arme.data.criticaldamage}}</a></span> |               <span class="generic-label"><a class="weapon-damage">{{arme.data.damage}}</a> / <a class="weapon-damage-critical">{{arme.data.criticaldamage}}</a></span> | ||||||
|             </li>                   |             </li>                   | ||||||
|             {{/if}} |             {{/if}} | ||||||
|             {{/each}} |             {{/each}} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user