Gestion plus fines des entites et corrections sur initiative #915
This commit is contained in:
parent
f24331865c
commit
2e83cbd366
@ -90,7 +90,7 @@ export class RdDCombatManager extends Combat {
|
|||||||
let armeCombat, competence;
|
let armeCombat, competence;
|
||||||
if (combatant.actor.data.type == 'creature' || combatant.actor.data.type == 'entite') {
|
if (combatant.actor.data.type == 'creature' || combatant.actor.data.type == 'entite') {
|
||||||
for (const competenceItemData of combatant.actor.data.items) {
|
for (const competenceItemData of combatant.actor.data.items) {
|
||||||
if (competenceItemData.data.iscombat) {
|
if (competenceItemData.data.data.iscombat) {
|
||||||
competence = duplicate(competenceItemData);
|
competence = duplicate(competenceItemData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -434,8 +434,11 @@ export class RdDCombat {
|
|||||||
else {
|
else {
|
||||||
const defender = target?.actor;
|
const defender = target?.actor;
|
||||||
const defenderTokenId = target?.data._id;
|
const defenderTokenId = target?.data._id;
|
||||||
|
console.log("Defender: ", defender);
|
||||||
if ( defender.data._id == attacker.data._id) {
|
if ( defender.data._id == attacker.data._id) {
|
||||||
ui.notifications.warn("Vous vous attaquez vous-même !!!!");
|
ui.notifications.warn("Vous vous attaquez vous-même !!!!");
|
||||||
|
} else if ( defender.type == 'entite' && defender.data.data.definition.typeentite == 'nonincarne') {
|
||||||
|
ui.notifications.warn("Vous ne pouvez pas cibler une entité non incarnée !!!!");
|
||||||
} else {
|
} else {
|
||||||
return this.create(attacker, defender, defenderTokenId, target)
|
return this.create(attacker, defender, defenderTokenId, target)
|
||||||
}
|
}
|
||||||
@ -856,6 +859,11 @@ export class RdDCombat {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
isPossession( attackerRoll) {
|
||||||
|
return attackerRoll.selectedCarac.label.toLowerCase() == 'possession';
|
||||||
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
async _sendMessageDefense(attackerRoll, defenderRoll, essaisPrecedents = undefined) {
|
async _sendMessageDefense(attackerRoll, defenderRoll, essaisPrecedents = undefined) {
|
||||||
console.log("RdDCombat._sendMessageDefense", attackerRoll, defenderRoll, essaisPrecedents, " / ", this.attacker, this.target, this.attackerId, attackerRoll.competence.data.categorie);
|
console.log("RdDCombat._sendMessageDefense", attackerRoll, defenderRoll, essaisPrecedents, " / ", this.attacker, this.target, this.attackerId, attackerRoll.competence.data.categorie);
|
||||||
@ -873,6 +881,7 @@ export class RdDCombat {
|
|||||||
const paramChatDefense = {
|
const paramChatDefense = {
|
||||||
passeArme: attackerRoll.passeArme,
|
passeArme: attackerRoll.passeArme,
|
||||||
essais: attackerRoll.essais,
|
essais: attackerRoll.essais,
|
||||||
|
isPossession: this.isPossession( attackerRoll),
|
||||||
defender: Misc.data(this.defender),
|
defender: Misc.data(this.defender),
|
||||||
attacker: Misc.data(this.attacker),
|
attacker: Misc.data(this.attacker),
|
||||||
attackerId: this.attackerId,
|
attackerId: this.attackerId,
|
||||||
@ -927,7 +936,7 @@ export class RdDCombat {
|
|||||||
let items = defender.data.items;
|
let items = defender.data.items;
|
||||||
items = items.filter(it => RdDItemArme.isArmeUtilisable(it) || RdDItemCompetenceCreature.isCompetenceParade(it));
|
items = items.filter(it => RdDItemArme.isArmeUtilisable(it) || RdDItemCompetenceCreature.isCompetenceParade(it));
|
||||||
for (let item of items) {
|
for (let item of items) {
|
||||||
item.data.nbUsage = defender.getItemUse(item._id); // Ajout du # d'utilisation ce round
|
item.data.nbUsage = defender.getItemUse(item.id); // Ajout du # d'utilisation ce round
|
||||||
}
|
}
|
||||||
switch (competence.data.categorie) {
|
switch (competence.data.categorie) {
|
||||||
case 'tir':
|
case 'tir':
|
||||||
|
File diff suppressed because one or more lines are too long
@ -2,11 +2,11 @@
|
|||||||
"name": "foundryvtt-reve-de-dragon",
|
"name": "foundryvtt-reve-de-dragon",
|
||||||
"title": "Rêve de Dragon",
|
"title": "Rêve de Dragon",
|
||||||
"description": "Rêve de Dragon RPG for FoundryVTT",
|
"description": "Rêve de Dragon RPG for FoundryVTT",
|
||||||
"version": "1.5.27",
|
"version": "1.5.33",
|
||||||
"manifestPlusVersion": "1.0.0",
|
"manifestPlusVersion": "1.0.0",
|
||||||
"minimumCoreVersion": "0.8.0",
|
"minimumCoreVersion": "0.8.0",
|
||||||
"compatibleCoreVersion": "0.8.9",
|
"compatibleCoreVersion": "0.8.9",
|
||||||
"templateVersion": 126,
|
"templateVersion": 132,
|
||||||
"author": "LeRatierBretonnien",
|
"author": "LeRatierBretonnien",
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
{
|
||||||
|
@ -40,6 +40,10 @@
|
|||||||
"capacite_encombrement": 0
|
"capacite_encombrement": 0
|
||||||
},
|
},
|
||||||
"entite": {
|
"entite": {
|
||||||
|
"definition": {
|
||||||
|
"categorieentite": "",
|
||||||
|
"typeentite": ""
|
||||||
|
},
|
||||||
"carac": {
|
"carac": {
|
||||||
"taille": {
|
"taille": {
|
||||||
"type": "number",
|
"type": "number",
|
||||||
@ -667,6 +671,7 @@
|
|||||||
"carac_value": 0,
|
"carac_value": 0,
|
||||||
"iscombat": false,
|
"iscombat": false,
|
||||||
"isparade": false,
|
"isparade": false,
|
||||||
|
"ispossession": false,
|
||||||
"dommages": 0,
|
"dommages": 0,
|
||||||
"description": "Compétence : ...",
|
"description": "Compétence : ...",
|
||||||
"descriptionmj": ""
|
"descriptionmj": ""
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
{{!-- Carac Tab --}}
|
{{!-- Carac Tab --}}
|
||||||
<div class="tab items" data-group="primary" data-tab="carac">
|
<div class="tab items" data-group="primary" data-tab="carac">
|
||||||
|
|
||||||
<div class="grid grid-2col">
|
<div class="grid grid-2col">
|
||||||
<div class="flex-group-left flexcol">
|
<div class="flex-group-left flexcol">
|
||||||
<ol class="carac-list alterne-list">
|
<ol class="carac-list alterne-list">
|
||||||
@ -45,8 +46,28 @@
|
|||||||
{{/each}}
|
{{/each}}
|
||||||
</ol>
|
</ol>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="flex-group-left flexcol">
|
<div class="flex-group-left flexcol">
|
||||||
|
|
||||||
<ol class="carac-list alterne-list">
|
<ol class="carac-list alterne-list">
|
||||||
|
<li class="competence flexrow list-item">
|
||||||
|
<span class="carac-label flexrow" name="catEntite">Catégorie : </span>
|
||||||
|
<select name="data.definition.categorieentite" value="{{data.definition.categorieentite}}" data-dtype="String">
|
||||||
|
{{#select data.definition.categorieentite}}
|
||||||
|
<option value="cauchemar">Cauchemar</option>
|
||||||
|
<option value="reve">Rêve</option>
|
||||||
|
{{/select}}
|
||||||
|
</select>
|
||||||
|
</li>
|
||||||
|
<li class="competence flexrow list-item">
|
||||||
|
<span class="carac-label flexrow" name="typeEntite">Type d'entité : </span>
|
||||||
|
<select name="data.definition.typeentite" value="{{data.definition.typeentite}}" data-dtype="String">
|
||||||
|
{{#select data.definition.typeentite}}
|
||||||
|
<option value="incarne">Incarnée</option>
|
||||||
|
<option value="nonincarne">Non Incarnée</option>
|
||||||
|
{{/select}}
|
||||||
|
</select>
|
||||||
|
</li>
|
||||||
{{#each data.attributs as |attr key|}}
|
{{#each data.attributs as |attr key|}}
|
||||||
<li class="competence flexrow list-item" data-attribute="{{key}}">
|
<li class="competence flexrow list-item" data-attribute="{{key}}">
|
||||||
<span class="carac-label flexrow" name="data.attributs.{{key}}.label">{{attr.label}} : </span>
|
<span class="carac-label flexrow" name="data.attributs.{{key}}.label">{{attr.label}} : </span>
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
{{/unless}}
|
{{/unless}}
|
||||||
{{else}}
|
{{else}}
|
||||||
{{#each armes as |arme key|}}
|
{{#each armes as |arme key|}}
|
||||||
<a class='chat-card-button' id='parer-button' data-attackerId='{{../attackerId}}' data-defenderTokenId='{{../defenderTokenId}}' data-armeid='{{arme._id }}'>
|
<a class='chat-card-button' id='parer-button' data-attackerId='{{../attackerId}}' data-defenderTokenId='{{../defenderTokenId}}' data-armeid='{{arme.id }}'>
|
||||||
Parer avec {{arme.name}} à {{../diffLibre }}{{#if arme.data.nbUsage}} (Utilisations : {{arme.data.nbUsage}}){{/if}}
|
Parer avec {{arme.name}} à {{../diffLibre }}{{#if arme.data.nbUsage}} (Utilisations : {{arme.data.nbUsage}}){{/if}}
|
||||||
</a>
|
</a>
|
||||||
<br>
|
<br>
|
||||||
|
@ -28,6 +28,10 @@
|
|||||||
<label for="xp">Parade ? </label>
|
<label for="xp">Parade ? </label>
|
||||||
<input class="attribute-value" type="checkbox" name="data.isparade" {{#if data.isparade}}checked{{/if}}/>
|
<input class="attribute-value" type="checkbox" name="data.isparade" {{#if data.isparade}}checked{{/if}}/>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="xp">Possession ? </label>
|
||||||
|
<input class="attribute-value" type="checkbox" name="data.ispossession" {{#if data.ispossession}}checked{{/if}}/>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label>Catégorie parade </label>
|
<label>Catégorie parade </label>
|
||||||
<select name="data.categorie_parade" id="categorie_parade" data-dtype="String">
|
<select name="data.categorie_parade" id="categorie_parade" data-dtype="String">
|
||||||
|
Loading…
Reference in New Issue
Block a user