Opposed tests, ongoing process
This commit is contained in:
parent
42af291a7c
commit
de104fb386
@ -98,6 +98,11 @@ export class SoSActorSheet extends ActorSheet {
|
|||||||
const skill = this.actor.getOwnedItem(li.data("item-id"));
|
const skill = this.actor.getOwnedItem(li.data("item-id"));
|
||||||
this.actor.rollSkill(skill);
|
this.actor.rollSkill(skill);
|
||||||
});
|
});
|
||||||
|
html.find('.weapon-label a').click((event) => {
|
||||||
|
const li = $(event.currentTarget).parents(".item");
|
||||||
|
const weapon = this.actor.getOwnedItem(li.data("item-id"));
|
||||||
|
this.actor.rollWeapon(weapon);
|
||||||
|
});
|
||||||
html.find('.skill-value').change((event) => {
|
html.find('.skill-value').change((event) => {
|
||||||
let skillName = event.currentTarget.attributes.skillname.value;
|
let skillName = event.currentTarget.attributes.skillname.value;
|
||||||
//console.log("Competence changed :", skillName);
|
//console.log("Competence changed :", skillName);
|
||||||
|
@ -78,11 +78,13 @@ export class SoSActor extends Actor {
|
|||||||
this.cardDeck.drawEdge( 1 );
|
this.cardDeck.drawEdge( 1 );
|
||||||
this.saveDeck();
|
this.saveDeck();
|
||||||
}
|
}
|
||||||
/* -------------------------------------------- */
|
|
||||||
resetDeck() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
resetDeck( ) {
|
||||||
|
this.cardDeck.resetDeck();
|
||||||
|
this.saveDeck();
|
||||||
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
saveDeck( ) {
|
saveDeck( ) {
|
||||||
let deck = { deck: duplicate(this.cardDeck.data.deck),
|
let deck = { deck: duplicate(this.cardDeck.data.deck),
|
||||||
@ -210,7 +212,6 @@ export class SoSActor extends Actor {
|
|||||||
}
|
}
|
||||||
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/dialog-flip.html', flipData);
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/dialog-flip.html', flipData);
|
||||||
new SoSFlipDialog(flipData, html).render(true);
|
new SoSFlipDialog(flipData, html).render(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
@ -218,6 +219,7 @@ export class SoSActor extends Actor {
|
|||||||
let flipData = {
|
let flipData = {
|
||||||
mode: 'skill',
|
mode: 'skill',
|
||||||
statList: duplicate(this.data.data.stats),
|
statList: duplicate(this.data.data.stats),
|
||||||
|
selectedStat: 'strength',
|
||||||
consequencesList: duplicate( this.getApplicableConsequences() ),
|
consequencesList: duplicate( this.getApplicableConsequences() ),
|
||||||
skill: duplicate(skill),
|
skill: duplicate(skill),
|
||||||
actor: this,
|
actor: this,
|
||||||
@ -229,4 +231,40 @@ export class SoSActor extends Actor {
|
|||||||
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/dialog-flip.html', flipData);
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/dialog-flip.html', flipData);
|
||||||
new SoSFlipDialog(flipData, html).render(true);
|
new SoSFlipDialog(flipData, html).render(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
async rollWeapon( weapon ) {
|
||||||
|
let target = SoSUtility.getTarget();
|
||||||
|
let skill, selectedStatName;
|
||||||
|
if ( weapon.data.data.category == 'ballistic' || weapon.data.data.category == 'laser' ) {
|
||||||
|
skill = this.data.items.find( item => item.name == 'Guns');
|
||||||
|
selectedStatName = 'dexterity';
|
||||||
|
} else if ( weapon.data.data.category == 'melee' ) {
|
||||||
|
skill = this.data.items.find( item => item.name == 'Melee');
|
||||||
|
selectedStatName = 'dexterity';
|
||||||
|
} else if ( weapon.data.data.category == 'grenade' ) {
|
||||||
|
skill = this.data.items.find( item => item.name == 'Athletics');
|
||||||
|
selectedStatName = 'dexterity';
|
||||||
|
}
|
||||||
|
|
||||||
|
let flipData = {
|
||||||
|
mode: 'weapon',
|
||||||
|
weapon: duplicate(weapon.data),
|
||||||
|
statList: duplicate(this.data.data.stats),
|
||||||
|
target: target,
|
||||||
|
selectedStat: selectedStatName,
|
||||||
|
consequencesList: duplicate( this.getApplicableConsequences() ),
|
||||||
|
skill: duplicate(skill),
|
||||||
|
actor: this,
|
||||||
|
modifierList: SoSUtility.fillRange(-10, +10),
|
||||||
|
tnList: SoSUtility.fillRange(6, 20),
|
||||||
|
malusConsequence: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(flipData);
|
||||||
|
|
||||||
|
flipData.statList['nostat'] = { label: "No stat (ie defaulting skills)", value: 0, cardsuit: "none" }
|
||||||
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/dialog-flip.html', flipData);
|
||||||
|
new SoSFlipDialog(flipData, html).render(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import { SoSUtility } from "./sos-utility.js";
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
const NB_POKER_CARD = 54;
|
const NB_POKER_CARD = 54;
|
||||||
@ -165,7 +166,7 @@ export class SoSCardDeck {
|
|||||||
this.setJoker( flipData );
|
this.setJoker( flipData );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
console.log("First card : ", flipData.cardSlot[0].card1);
|
//console.log("First card : ", flipData.cardSlot[0].card1);
|
||||||
// Face check for first card
|
// Face check for first card
|
||||||
flipData.cardSlot[0].value1 = this.getCardValue(flipData.cardSlot[0].card1.cardName);
|
flipData.cardSlot[0].value1 = this.getCardValue(flipData.cardSlot[0].card1.cardName);
|
||||||
flipData.cardSlot[0].isFace1 = this.isCardFace(flipData.cardSlot[0].card1.cardName);
|
flipData.cardSlot[0].isFace1 = this.isCardFace(flipData.cardSlot[0].card1.cardName);
|
||||||
@ -212,14 +213,21 @@ export class SoSCardDeck {
|
|||||||
|
|
||||||
// Card Total
|
// Card Total
|
||||||
flipData.cardTotal = flipData.cardSlot[0].total;
|
flipData.cardTotal = flipData.cardSlot[0].total;
|
||||||
|
flipData.cardSlotIndex = 0;
|
||||||
if ( flipData.fullTrump ) {
|
if ( flipData.fullTrump ) {
|
||||||
flipData.cardTotal = flipData.cardSlot[0].total + flipData.cardSlot[1].total;
|
flipData.cardTotal = flipData.cardSlot[0].total + flipData.cardSlot[1].total;
|
||||||
} else if (flipData.isTrump) {
|
} else if (flipData.isTrump) {
|
||||||
flipData.cardTotal = (flipData.cardSlot[0].total > flipData.cardSlot[1].total) ? flipData.cardSlot[0].total : flipData.cardSlot[1].total;
|
if (flipData.cardSlot[0].total > flipData.cardSlot[1].total ) {
|
||||||
|
flipData.cardSlotIndex = 0;
|
||||||
|
flipData.cardTotal = flipData.cardSlot[0].total;
|
||||||
|
} else {
|
||||||
|
flipData.cardSlotIndex = 0;
|
||||||
|
flipData.cardTotal = flipData.cardSlot[1].total;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compute final result and compare
|
// Compute final result and compare
|
||||||
if ( flipData.mode == 'stat' ) {
|
if ( flipData.mode == 'stat' || flipData.mode == 'weapon' ) {
|
||||||
flipData.baseScore = flipData.stat.value + flipData.malusConsequence;
|
flipData.baseScore = flipData.stat.value + flipData.malusConsequence;
|
||||||
} else if (flipData.mode == 'skill') {
|
} else if (flipData.mode == 'skill') {
|
||||||
flipData.baseScore = Math.floor(flipData.stat.value/2) + flipData.skill.data.value + flipData.malusConsequence
|
flipData.baseScore = Math.floor(flipData.stat.value/2) + flipData.skill.data.value + flipData.malusConsequence
|
||||||
@ -228,13 +236,43 @@ export class SoSCardDeck {
|
|||||||
flipData.magnitude = flipData.finalScore - flipData.tn;
|
flipData.magnitude = flipData.finalScore - flipData.tn;
|
||||||
flipData.result = (flipData.magnitude >= 0) ? "Success": "Failure";
|
flipData.result = (flipData.magnitude >= 0) ? "Success": "Failure";
|
||||||
|
|
||||||
console.log(flipData);
|
//console.log(flipData);
|
||||||
this.data.actor.saveDeck();
|
this.data.actor.saveDeck();
|
||||||
flipData.alias = this.data.actor.name;
|
flipData.alias = this.data.actor.name;
|
||||||
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/chat-flip.html', flipData);
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/chat-flip.html', flipData);
|
||||||
ChatMessage.create( { content: html });
|
ChatMessage.create( { content: html });
|
||||||
|
|
||||||
|
if ( flipData.mode == 'weapon' && flipData.magnitude >= 0 && !flipData.isJoker) { // Success
|
||||||
|
this.processWeapon( flipData );
|
||||||
|
}
|
||||||
|
|
||||||
|
if (flipData.isJoker) { // Critical mismatch !
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
async processWeapon( flipData ) {
|
||||||
|
flipData.damageCardsuit = flipData.cardSlot[flipData.cardSlotIndex].cardsuit;
|
||||||
|
let damageKey = 'damage_'+ flipData.damageCardsuit;
|
||||||
|
flipData.damageString = flipData.weapon.data[damageKey];
|
||||||
|
let damageRegexp = flipData.damageString.match( /(\d*)([LMSC])/i );
|
||||||
|
flipData.damageValue = damageRegexp[1];
|
||||||
|
flipData.damageSeverity = damageRegexp[2];
|
||||||
|
|
||||||
|
// Now process damage
|
||||||
|
if ( flipData.target) {
|
||||||
|
if ( game.user.isGM ) { // Direct access
|
||||||
|
SoSUtility.applyDamage( flipData );
|
||||||
|
} else {
|
||||||
|
game.socket.emit("system.foundryvtt-shadows-over-sol", {
|
||||||
|
msg: "msg_defense", data: flipData } );
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/chat-damage-only.html', flipData );
|
||||||
|
ChatMessage.create( { content: html });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
getDeckHTML( ) {
|
getDeckHTML( ) {
|
||||||
|
@ -116,6 +116,18 @@ export class SoSCombat extends Combat {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
getAPFromActor( actorId ) {
|
||||||
|
for( let combatant of this.combatants) {
|
||||||
|
//console.log(combatant);
|
||||||
|
if ( combatant.actor.data._id == actorId ) {
|
||||||
|
let phase = this.phaseSetup[combatant._id];
|
||||||
|
return phase.remainingAP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
async setupActorActions(actionConf) {
|
async setupActorActions(actionConf) {
|
||||||
console.log("Setting combat for phase : ", actionConf);
|
console.log("Setting combat for phase : ", actionConf);
|
||||||
@ -124,7 +136,7 @@ export class SoSCombat extends Combat {
|
|||||||
|
|
||||||
// Keep track
|
// Keep track
|
||||||
this.phaseSetup[actionConf.combatantId] = actionConf;
|
this.phaseSetup[actionConf.combatantId] = actionConf;
|
||||||
console.log( this.combatants);
|
console.log( this.combatants );
|
||||||
//let combatant = this.combatants.find( comb => comb._id == actionConf.combatantId);
|
//let combatant = this.combatants.find( comb => comb._id == actionConf.combatantId);
|
||||||
await this.setInitiative( actionConf.combatantId, this.getPhaseRank( actionConf ) );
|
await this.setInitiative( actionConf.combatantId, this.getPhaseRank( actionConf ) );
|
||||||
|
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
|
/* -------------------------------------------- */
|
||||||
import { SoSUtility } from "./sos-utility.js";
|
import { SoSUtility } from "./sos-utility.js";
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
export class SoSFlipDialog extends Dialog {
|
export class SoSFlipDialog extends Dialog {
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
@ -25,7 +27,7 @@ export class SoSFlipDialog extends Dialog {
|
|||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
updateScoreBase( ) {
|
updateScoreBase( ) {
|
||||||
let scoreBase = 0;
|
let scoreBase = 0;
|
||||||
if ( this.flipData.mode == 'skill') {
|
if ( this.flipData.mode == 'skill' || this.flipData.mode == 'weapon' ) {
|
||||||
let statKey = $('#statSelect').val();
|
let statKey = $('#statSelect').val();
|
||||||
this.flipData.stat = duplicate( this.flipData.statList[ statKey ] );
|
this.flipData.stat = duplicate( this.flipData.statList[ statKey ] );
|
||||||
scoreBase = Math.floor(this.flipData.statList[ statKey ].value / 2) + this.flipData.skill.data.value;
|
scoreBase = Math.floor(this.flipData.statList[ statKey ].value / 2) + this.flipData.skill.data.value;
|
||||||
@ -49,14 +51,15 @@ export class SoSFlipDialog extends Dialog {
|
|||||||
this.updateScoreBase();
|
this.updateScoreBase();
|
||||||
|
|
||||||
$('.edge-card').click((event) => {
|
$('.edge-card').click((event) => {
|
||||||
let flipData = duplicate(this.flipData);
|
let flipData = this.flipData;
|
||||||
flipData.modifier = $('#modifier').val();
|
flipData.modifier = $('#modifier').val();
|
||||||
flipData.tn = $('#tn').val();
|
flipData.tn = (flipData.target) ? flipData.target.actor.data.data.scores.defense.value : $('#tn').val();
|
||||||
flipData.edgeName = event.currentTarget.attributes['data-edge-card'].value;
|
flipData.edgeName = event.currentTarget.attributes['data-edge-card'].value;
|
||||||
flipData.cardOrigin = "Edge";
|
flipData.cardOrigin = "Edge";
|
||||||
if ( flipData.mode == 'skill') {
|
if ( flipData.mode == 'skill' || flipData.mode == 'weapon') {
|
||||||
flipData.stat = duplicate( flipData.statList[ $('#statSelect').val() ] );
|
flipData.stat = duplicate( flipData.statList[ $('#statSelect').val() ] );
|
||||||
}
|
}
|
||||||
|
console.log("CLICK:", flipData);
|
||||||
this.flipData.actor.cardDeck.doFlipFromDeckOrEdge(flipData);
|
this.flipData.actor.cardDeck.doFlipFromDeckOrEdge(flipData);
|
||||||
this.onFlipClose();
|
this.onFlipClose();
|
||||||
});
|
});
|
||||||
@ -105,15 +108,14 @@ export class SoSFlipDialog extends Dialog {
|
|||||||
} );
|
} );
|
||||||
|
|
||||||
html.find('.class-view-deck').click((event) => {
|
html.find('.class-view-deck').click((event) => {
|
||||||
let flipData = duplicate(this.flipData);
|
let flipData = this.flipData;
|
||||||
flipData.modifier = html.find('#modifier').val();
|
flipData.modifier = html.find('#modifier').val();
|
||||||
flipData.tn = html.find('#tn').val();
|
if ( flipData.mode == 'skill' || flipData.mode == 'weapon') {
|
||||||
if ( flipData.mode == 'skill') {
|
|
||||||
let statKey = $('#statSelect').val();
|
let statKey = $('#statSelect').val();
|
||||||
flipData.stat = duplicate( flipData.statList[ statKey ] );
|
flipData.stat = duplicate( flipData.statList[ statKey ] );
|
||||||
}
|
}
|
||||||
flipData.cardOrigin = "Deck";
|
flipData.cardOrigin = "Deck";
|
||||||
flipData.tn = html.find('#tn').val();
|
flipData.tn = (flipData.target) ? flipData.target.actor.data.data.scores.defense.value : $('#tn').val();
|
||||||
dialog.flipData.actor.cardDeck.doFlipFromDeckOrEdge(flipData);
|
dialog.flipData.actor.cardDeck.doFlipFromDeckOrEdge(flipData);
|
||||||
dialog.onFlipClose();
|
dialog.onFlipClose();
|
||||||
});
|
});
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
|
import { SoSCombat } from "./sos-combat.js";
|
||||||
import { SoSDialogCombatActions } from "./sos-dialog-combat-actions.js";
|
import { SoSDialogCombatActions } from "./sos-dialog-combat-actions.js";
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
@ -129,4 +130,102 @@ export class SoSUtility {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
static getTarget() {
|
||||||
|
if (game.user.targets && game.user.targets.size == 1) {
|
||||||
|
for (let target of game.user.targets) {
|
||||||
|
return target;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
static increaseSeverity( severity ) {
|
||||||
|
if ( severity == 'L') return 'M';
|
||||||
|
if ( severity == 'M') return 'S';
|
||||||
|
if ( severity == 'S') return 'C';
|
||||||
|
if ( severity == 'C') return 'F';
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
static decreaseSeverity( severity ) {
|
||||||
|
if ( severity == 'C') return 'S';
|
||||||
|
if ( severity == 'S') return 'M';
|
||||||
|
if ( severity == 'M') return 'L';
|
||||||
|
if ( severity == 'L') return 'N';
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
static getSeverityLevel( severity) {
|
||||||
|
if ( severity == 'C') return 4;
|
||||||
|
if ( severity == 'S') return 3;
|
||||||
|
if ( severity == 'M') return 2;
|
||||||
|
if ( severity == 'L') return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* -------------------------------------------- */
|
||||||
|
static async applyDamage( flipData ) {
|
||||||
|
let dr = flipData.target.actor.data.data.scores.dr.value;
|
||||||
|
let shock = flipData.target.actor.data.data.scores.shock.value;
|
||||||
|
let defenseCritical = flipData.target.actor.data.data.scores.defense.critical;
|
||||||
|
flipData.damageStatus = 'apply_damage';
|
||||||
|
|
||||||
|
flipData.targetShock = shock;
|
||||||
|
flipData.targetDR = dr;
|
||||||
|
flipData.targetCritical = defenseCritical;
|
||||||
|
// DR management
|
||||||
|
if ( flipData.damageValue < dr) {
|
||||||
|
if (flipData.damageValue < dr / 2) {
|
||||||
|
flipData.damageStatus = "no_damage";
|
||||||
|
// TODO : No damage !
|
||||||
|
} else {
|
||||||
|
flipData.damageSeverity = this.decreaseSeverity(flipData.damageSeverity );
|
||||||
|
if ( flipData.damageSeverity == 'N') {
|
||||||
|
flipData.damageStatus = "no_damage";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Shock management
|
||||||
|
flipData.woundsList = [];
|
||||||
|
if ( flipData.damageValue >= shock) {
|
||||||
|
let incSeverity = Math.floor(flipData.damageValue / shock);
|
||||||
|
for (let i=0; i<incSeverity; i++) {
|
||||||
|
if ( flipData.damageSeverity == 'C') {
|
||||||
|
flipData.woundsList.push( flipData.damageSeverity );
|
||||||
|
flipData.damageSeverity = 'L';
|
||||||
|
} else {
|
||||||
|
flipData.damageSeverity = this.increaseSeverity( flipData.damageSeverity );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
flipData.woundsList.push( flipData.damageSeverity );
|
||||||
|
flipData.nbWounds = flipData.woundsList.length;
|
||||||
|
|
||||||
|
// Critical management
|
||||||
|
flipData.isCritical = ( flipData.cardTotal >= defenseCritical);
|
||||||
|
|
||||||
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/chat-damage-target.html', flipData );
|
||||||
|
ChatMessage.create( { content: html });
|
||||||
|
|
||||||
|
// Is target able to dodge ??
|
||||||
|
let defender = game.actors.get( flipData.target.actor._id);
|
||||||
|
flipData.coverConsequence = defender.data.items.find( item => item.type == 'consequence' && item.name == 'Cover');
|
||||||
|
flipData.APavailable = game.combat.getAPFromActor( defender.data._id );
|
||||||
|
console.log("FLIPDATE : ", flipData);
|
||||||
|
if ( flipData.APavailable > 0) {
|
||||||
|
if ( (flipData.weapon.data.category == 'melee' ) || ( (flipData.weapon.data.category == 'laser' || flipData.weapon.data.category == 'ballistic') &&
|
||||||
|
flipData.coverConsequence.data.severity != 'none') ) {
|
||||||
|
flipData.coverSeverityLevel = this.getSeverityLevel( flipData.coverConsequence.data.severity ) * 2;
|
||||||
|
flipData.coverSeverityFlag = (flipData.coverSeverityLevel > 0);
|
||||||
|
flipData.isMelee = (flipData.weapon.data.category == 'melee' );
|
||||||
|
let melee = defender.data.items.find( item => item.type == 'skill' && item.name == 'Melee');
|
||||||
|
flipData.defenderMelee = melee.data.value;
|
||||||
|
let html = await renderTemplate('systems/foundryvtt-shadows-over-sol/templates/chat-damage-request-dodge.html', flipData );
|
||||||
|
ChatMessage.create( { content: html, whisper: [ChatMessage.getWhisperRecipients(flipData.target.actor.name), ChatMessage.getWhisperRecipients("GM") ] } );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -2,7 +2,7 @@
|
|||||||
"name": "foundryvtt-shadows-over-sol",
|
"name": "foundryvtt-shadows-over-sol",
|
||||||
"title": "Shadows over Sol",
|
"title": "Shadows over Sol",
|
||||||
"description": "Shadows over Sol for FoundryVTT",
|
"description": "Shadows over Sol for FoundryVTT",
|
||||||
"version": "0.0.20",
|
"version": "0.0.21",
|
||||||
"manifestPlusVersion": "1.0.0",
|
"manifestPlusVersion": "1.0.0",
|
||||||
"minimumCoreVersion": "0.7.5",
|
"minimumCoreVersion": "0.7.5",
|
||||||
"compatibleCoreVersion": "0.7.9",
|
"compatibleCoreVersion": "0.7.9",
|
||||||
|
@ -192,7 +192,7 @@
|
|||||||
{{#each data.weapons as |weapon key|}}
|
{{#each data.weapons as |weapon key|}}
|
||||||
<li class="item flexrow list-item" data-item-id="{{weapon._id}}">
|
<li class="item flexrow list-item" data-item-id="{{weapon._id}}">
|
||||||
<img class="sheet-skill-img" src="{{weapon.img}}"/>
|
<img class="sheet-skill-img" src="{{weapon.img}}"/>
|
||||||
<span class="conseq-label"><a>{{weapon.name}}</a></span>
|
<span class="weapon-label"><a>{{weapon.name}}</a></span>
|
||||||
<div class="item-controls">
|
<div class="item-controls">
|
||||||
<a class="item-control item-equip" title="Equipped">{{#if weapon.data.equiped}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
<a class="item-control item-equip" title="Equipped">{{#if weapon.data.equiped}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
||||||
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
||||||
@ -206,7 +206,7 @@
|
|||||||
{{#each data.armors as |armor key|}}
|
{{#each data.armors as |armor key|}}
|
||||||
<li class="item flexrow list-item" data-item-id="{{armor._id}}">
|
<li class="item flexrow list-item" data-item-id="{{armor._id}}">
|
||||||
<img class="sheet-skill-img" src="{{armor.img}}"/>
|
<img class="sheet-skill-img" src="{{armor.img}}"/>
|
||||||
<span class="conseq-label"><a>{{armor.name}}</a></span>
|
<span class="armor-label">{{armor.name}}</span>
|
||||||
<div class="item-controls">
|
<div class="item-controls">
|
||||||
<a class="item-control item-worn" title="Worn">{{#if armor.data.worn}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
<a class="item-control item-worn" title="Worn">{{#if armor.data.worn}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
||||||
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
||||||
@ -220,7 +220,7 @@
|
|||||||
{{#each data.gears as |gear key|}}
|
{{#each data.gears as |gear key|}}
|
||||||
<li class="item flexrow list-item" data-item-id="{{gear._id}}">
|
<li class="item flexrow list-item" data-item-id="{{gear._id}}">
|
||||||
<img class="sheet-skill-img" src="{{gear.img}}"/>
|
<img class="sheet-skill-img" src="{{gear.img}}"/>
|
||||||
<span class="conseq-label"><a>{{gear.name}}</a></span>
|
<span class="conseq-label">{{gear.name}}</span>
|
||||||
<div class="item-controls">
|
<div class="item-controls">
|
||||||
<a class="item-control item-equip" title="Worn">{{#if armor.data.worn}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
<a class="item-control item-equip" title="Worn">{{#if armor.data.worn}}<i class="fas fa-circle"></i>{{else}}<i class="fas fa-genderless"></i>{{/if}}</a>
|
||||||
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
<a class="item-control item-edit" title="Edit Item"><i class="fas fa-edit"></i></a>
|
||||||
|
8
templates/chat-damage-only.html
Normal file
8
templates/chat-damage-only.html
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<h4>{{alias}} has made damages with its weapon {{weapon.name}} !</h4>
|
||||||
|
<div class="flexcol">
|
||||||
|
<label>Card color : {{damageCardsuit}}</label>
|
||||||
|
<label>Damage value: {{damageValue}}</label>
|
||||||
|
<label>Damage Severity : {{damageSeverity}} </label>
|
||||||
|
<label>No target has been selected, you must apply damages manually, by comparing the value above with the DR and the Shock of the target,
|
||||||
|
as per rules p.117.</label>
|
||||||
|
</div>
|
10
templates/chat-damage-request-dodge.html
Normal file
10
templates/chat-damage-request-dodge.html
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<h4>{{target.actor.name}} has {{remainingAP}} AP and can react to the attack from {{actor.name}} !</h4>
|
||||||
|
<div class="flexcol">
|
||||||
|
{{#if coverSeverityFlag}}
|
||||||
|
<label>Add cover consequence bonus * 2 to your defense : {{coverSeverityLevel}}</label>
|
||||||
|
{{/if}}
|
||||||
|
{{#if isMelee}}
|
||||||
|
<label>Add Melee level to your defense : {{defenderMelee}}</label>
|
||||||
|
{{/if}}
|
||||||
|
<label>Do not dodge and get the hit ! </label>
|
||||||
|
</div>
|
17
templates/chat-damage-target.html
Normal file
17
templates/chat-damage-target.html
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<h4>{{alias}} has made damages with its weapon {{weapon.name}} against
|
||||||
|
{{target.actor.name}} !</h4>
|
||||||
|
<div class="flexcol">
|
||||||
|
<label>Score : {{finalScore}} - Target defense : {{tn}} / {{targetCritical}}</label>
|
||||||
|
<label>Target DR : {{targetDR}} - Target Shock : {{targetShock}} </label>
|
||||||
|
<label>Card color : {{damageCardsuit}}</label>
|
||||||
|
<label>Damage value: {{damageValue}}</label>
|
||||||
|
{{#if isCritical}}
|
||||||
|
<label><strong>This is a critical hit !</strong></label>
|
||||||
|
{{/if}}
|
||||||
|
<label>Number of Wounds : {{nbWounds}}</label>
|
||||||
|
<ul>
|
||||||
|
{{#each woundsList as |severity key|}}
|
||||||
|
<li> 1 Wound of severity {{severity}}</li>
|
||||||
|
{{/each}}
|
||||||
|
</ul>
|
||||||
|
</div>
|
@ -18,7 +18,7 @@
|
|||||||
<select name="stat" id="statSelect" data-dtype="String">
|
<select name="stat" id="statSelect" data-dtype="String">
|
||||||
{{#select statList}}
|
{{#select statList}}
|
||||||
{{#each statList as |stat key|}}
|
{{#each statList as |stat key|}}
|
||||||
<option value={{key}}>{{localize stat.label}} : {{stat.value}} - {{stat.cardsuit}} </option>
|
<option value={{key}} {{#if (eq key ../selectedStat)}}selected{{/if}}>{{localize stat.label}} : {{stat.value}} - {{stat.cardsuit}} </option>
|
||||||
{{/each}}
|
{{/each}}
|
||||||
{{/select}}
|
{{/select}}
|
||||||
</select>
|
</select>
|
||||||
@ -43,10 +43,19 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{{#if target}}
|
||||||
|
<div>
|
||||||
|
<h4>Target : {{target.actor.name}} - Defense : {{target.actor.data.data.scores.defense.value}}/{{target.actor.data.data.scores.defense.critical}}</h4>
|
||||||
|
</div>
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
<section class="sheet-body">
|
<section class="sheet-body">
|
||||||
<div class="tab" data-group="primary">
|
<div class="tab" data-group="primary">
|
||||||
<div class="flexrow">
|
<div class="flexrow">
|
||||||
<label for="categorie generic-label">Target Number (TN) : </label>
|
<label for="categorie" class="generic-label">Target Number (TN) : </label>
|
||||||
|
{{#if target}}
|
||||||
|
<label for="categorie" class="generic-label"> {{target.actor.data.data.scores.defense.value}} </label>
|
||||||
|
{{else}}
|
||||||
<select name="tn" id="tn" data-dtype="number">
|
<select name="tn" id="tn" data-dtype="number">
|
||||||
{{#select tn}}
|
{{#select tn}}
|
||||||
{{#each tnList as |key|}}
|
{{#each tnList as |key|}}
|
||||||
@ -54,9 +63,10 @@
|
|||||||
{{/each}}
|
{{/each}}
|
||||||
{{/select}}
|
{{/select}}
|
||||||
</select>
|
</select>
|
||||||
|
{{/if}}
|
||||||
</div>
|
</div>
|
||||||
<div class="flexrow">
|
<div class="flexrow">
|
||||||
<label for="categorie generic-label">Flip Modifier</label>
|
<label for="categorie" class="generic-label">Flip Modifier</label>
|
||||||
<select name="modifier" id="modifier" data-dtype="number">
|
<select name="modifier" id="modifier" data-dtype="number">
|
||||||
{{#select modifier}}
|
{{#select modifier}}
|
||||||
{{#each modifierList as |key|}}
|
{{#each modifierList as |key|}}
|
||||||
|
Loading…
Reference in New Issue
Block a user