Compare commits
7 Commits
fvtt-pegas
...
fvtt-pegas
Author | SHA1 | Date | |
---|---|---|---|
a68db10676 | |||
6e69e151c5 | |||
c2831e4ccd | |||
5a062cc94e | |||
ef740f4c0d | |||
076945c76f | |||
a763efe873 |
@ -61,6 +61,7 @@ export class PegasusActorSheet extends ActorSheet {
|
|||||||
encCapacity: this.actor.getEncumbranceCapacity(),
|
encCapacity: this.actor.getEncumbranceCapacity(),
|
||||||
levelRemainingList: this.actor.getLevelRemainingList(),
|
levelRemainingList: this.actor.getLevelRemainingList(),
|
||||||
maxLevelRemainingList: this.actor.getMaxLevelRemainingList(),
|
maxLevelRemainingList: this.actor.getMaxLevelRemainingList(),
|
||||||
|
disabledBonus: (this.actor.system.biodata.noautobonus) ? "" : "disabled",
|
||||||
containersTree: this.actor.containersTree,
|
containersTree: this.actor.containersTree,
|
||||||
encCurrent: this.actor.encCurrent,
|
encCurrent: this.actor.encCurrent,
|
||||||
encHindrance: this.actor.encHindrance,
|
encHindrance: this.actor.encHindrance,
|
||||||
@ -249,13 +250,13 @@ export class PegasusActorSheet extends ActorSheet {
|
|||||||
this.actor.rollPool( 'def', true, "defence");
|
this.actor.rollPool( 'def', true, "defence");
|
||||||
});
|
});
|
||||||
html.find('.damage-melee').click((event) => {
|
html.find('.damage-melee').click((event) => {
|
||||||
this.actor.rollPool( 'str', false, "melee-dmg");
|
this.actor.rollPool( 'str', false, "melee-dmg")
|
||||||
});
|
});
|
||||||
html.find('.damage-ranged').click((event) => {
|
html.find('.damage-ranged').click((event) => {
|
||||||
this.actor.rollPool( 'per', false, "ranged-dmg");
|
this.actor.rollPool( 'per', false, "ranged-dmg");
|
||||||
});
|
});
|
||||||
html.find('.damage-resistance').click((event) => {
|
html.find('.damage-resistance').click((event) => {
|
||||||
this.actor.rollPool( 'phy', false, "dmg-res");
|
this.actor.rollPool( 'phy', false, "dmg-res")
|
||||||
});
|
});
|
||||||
|
|
||||||
html.find('.roll-stat').click((event) => {
|
html.find('.roll-stat').click((event) => {
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -90,6 +90,9 @@ export class PegasusRollDialog extends Dialog {
|
|||||||
PegasusUtility.updateDamageDicePool(this.rollData)
|
PegasusUtility.updateDamageDicePool(this.rollData)
|
||||||
PegasusUtility.updateEffectsBonusDice(this.rollData)
|
PegasusUtility.updateEffectsBonusDice(this.rollData)
|
||||||
PegasusUtility.updateHindranceBonusDice(this.rollData)
|
PegasusUtility.updateHindranceBonusDice(this.rollData)
|
||||||
|
if ( effect.specList) {
|
||||||
|
this.rollData.specList = duplicate(effect.specList)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
|
@ -175,12 +175,13 @@ export class PegasusUtility {
|
|||||||
newDicePool = newDicePool.concat(this.buildDicePool("armor-shield", armor.value, 0))
|
newDicePool = newDicePool.concat(this.buildDicePool("armor-shield", armor.value, 0))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
newDicePool = rollData.dicePool.filter(dice => dice.name != "vehicle-shield")
|
newDicePool = newDicePool.filter(dice => dice.name != "vehicle-shield")
|
||||||
for (let shield of rollData.vehicleShieldList) {
|
for (let shield of rollData.vehicleShieldList) {
|
||||||
if (shield.applied) {
|
if (shield.applied) {
|
||||||
newDicePool = newDicePool.concat(this.buildDicePool("vehicle-shield", shield.value, 0))
|
newDicePool = newDicePool.concat(this.buildDicePool("vehicle-shield", shield.value, 0))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
console.log(">>>>Dicepoool", newDicePool)
|
||||||
rollData.dicePool = newDicePool
|
rollData.dicePool = newDicePool
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1026,7 +1027,12 @@ export class PegasusUtility {
|
|||||||
if (target) {
|
if (target) {
|
||||||
let defenderActor = target.actor
|
let defenderActor = target.actor
|
||||||
rollData.defenderTokenId = target.id
|
rollData.defenderTokenId = target.id
|
||||||
rollData.defenderSize = Number(defenderActor.system.biodata.sizenum) + Number(defenderActor.system.biodata.sizebonus)
|
rollData.defenderSize = 0
|
||||||
|
if ( defenderActor.type == "character") {
|
||||||
|
rollData.defenderSize = Number(defenderActor.system.biodata.sizenum) + Number(defenderActor.system.biodata.sizebonus)
|
||||||
|
} else if ( defenderActor.type == "vehicle" ){
|
||||||
|
rollData.defenderSize = Number(defenderActor.system.statistics.hr.size)
|
||||||
|
}
|
||||||
//rollData.attackerId = this.id
|
//rollData.attackerId = this.id
|
||||||
console.log("Target/DEFENDER", defenderActor)
|
console.log("Target/DEFENDER", defenderActor)
|
||||||
defenderActor.addHindrancesList(rollData.effectsList)
|
defenderActor.addHindrancesList(rollData.effectsList)
|
||||||
@ -1067,31 +1073,15 @@ export class PegasusUtility {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
static glowToken(token) {
|
static checkIsVehicleCrew(actorId) {
|
||||||
let params =
|
let vehicles = game.actors.filter( actor=> actor.type == "vehicle") || []
|
||||||
[{
|
for(let vehicle of vehicles) {
|
||||||
filterType: "glow",
|
console.log("Checking", vehicle.name)
|
||||||
filterId: "superSpookyGlow",
|
if ( vehicle.inCrew(actorId) ) {
|
||||||
outerStrength: 15,
|
return vehicle
|
||||||
innerStrength: 0,
|
}
|
||||||
color: 0x6AAB8E,
|
}
|
||||||
quality: 0.5,
|
return false
|
||||||
padding: 40,
|
|
||||||
autoDestroy: true,
|
|
||||||
animated:
|
|
||||||
{
|
|
||||||
color:
|
|
||||||
{
|
|
||||||
active: true,
|
|
||||||
loopDuration: 3000,
|
|
||||||
loops: 2,
|
|
||||||
animType: "colorOscillation",
|
|
||||||
val1: 0x6AAB8E,
|
|
||||||
val2: 0x66FF33
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
TokenMagic.addUpdateFilters(token, params)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------------------------------- */
|
/* -------------------------------------------- */
|
||||||
@ -1117,7 +1107,7 @@ export class PegasusUtility {
|
|||||||
static async processTactician() {
|
static async processTactician() {
|
||||||
// Tactician management
|
// Tactician management
|
||||||
let toApply = {}
|
let toApply = {}
|
||||||
let tacticianTokens = canvas.tokens.placeables.filter(token => token.actor.isTactician() && !newToken.document.hidden)
|
let tacticianTokens = canvas.tokens.placeables.filter(token => token.actor.isTactician() && !token.document.hidden)
|
||||||
for (let token of tacticianTokens) {
|
for (let token of tacticianTokens) {
|
||||||
token.refresh()
|
token.refresh()
|
||||||
let friends = canvas.tokens.placeables.filter(newToken => newToken.actor.type == "character" && !newToken.document.hidden && newToken.document.disposition == token.document.disposition)
|
let friends = canvas.tokens.placeables.filter(newToken => newToken.actor.type == "character" && !newToken.document.hidden && newToken.document.disposition == token.document.disposition)
|
||||||
@ -1165,7 +1155,7 @@ export class PegasusUtility {
|
|||||||
static async processEnhancer() {
|
static async processEnhancer() {
|
||||||
// Enhancer management
|
// Enhancer management
|
||||||
let toApply = {}
|
let toApply = {}
|
||||||
let enhancerTokens = canvas.tokens.placeables.filter(token => token.actor.isEnhancer() && !newToken.document.hidden)
|
let enhancerTokens = canvas.tokens.placeables.filter(token => token.actor.isEnhancer() && !token.document.hidden)
|
||||||
for (let token of enhancerTokens) {
|
for (let token of enhancerTokens) {
|
||||||
token.refresh()
|
token.refresh()
|
||||||
let friends = canvas.tokens.placeables.filter(newToken => newToken.actor.type == "character" && !newToken.document.hidden && newToken.document.disposition == token.document.disposition)
|
let friends = canvas.tokens.placeables.filter(newToken => newToken.actor.type == "character" && !newToken.document.hidden && newToken.document.disposition == token.document.disposition)
|
||||||
@ -1215,7 +1205,7 @@ export class PegasusUtility {
|
|||||||
static async processAgitator() {
|
static async processAgitator() {
|
||||||
// Agitator management
|
// Agitator management
|
||||||
let toApply = {}
|
let toApply = {}
|
||||||
let agitatorTokens = canvas.tokens.placeables.filter(token => token.actor.isAgitator())
|
let agitatorTokens = canvas.tokens.placeables.filter(token => token.actor.isAgitator() && !token.document.hidden)
|
||||||
for (let token of agitatorTokens) {
|
for (let token of agitatorTokens) {
|
||||||
token.refresh()
|
token.refresh()
|
||||||
if (token.document.disposition == 0) {
|
if (token.document.disposition == 0) {
|
||||||
@ -1257,11 +1247,11 @@ export class PegasusUtility {
|
|||||||
applyDef.actor.removeAgitatorHindrance()
|
applyDef.actor.removeAgitatorHindrance()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Delete all effects if no more tacticians (ie deleted case)
|
// Delete all effects if no more agtators (ie deleted case)
|
||||||
if (agitatorTokens.length == 0) {
|
if (agitatorTokens.length == 0) {
|
||||||
let allTokens = canvas.tokens.placeables.filter(token => token.actor.type == "character")
|
let allTokens = canvas.tokens.placeables.filter(token => token.actor.type == "character")
|
||||||
for (let token of allTokens) {
|
for (let token of allTokens) {
|
||||||
if (token.actor.addAgitatorHindrance()) {
|
if (token.actor.hasAgitatorHindrance()) {
|
||||||
token.actor.removeAgitatorHindrance()
|
token.actor.removeAgitatorHindrance()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -253,7 +253,7 @@
|
|||||||
],
|
],
|
||||||
"title": "Pegasus RPG",
|
"title": "Pegasus RPG",
|
||||||
"url": "https://www.uberwald.me/data/files/fvtt-pegasus-rpg",
|
"url": "https://www.uberwald.me/data/files/fvtt-pegasus-rpg",
|
||||||
"version": "10.0.32",
|
"version": "10.1.0",
|
||||||
"download": "https://www.uberwald.me/gitea/uberwald/fvtt-pegasus-rpg/archive/fvtt-pegasus-rpg-v10.0.32.zip",
|
"download": "https://www.uberwald.me/gitea/uberwald/fvtt-pegasus-rpg/archive/fvtt-pegasus-rpg-v10.1.0.zip",
|
||||||
"background": "systems/fvtt-pegasus-rpg/images/ui/pegasus_welcome_page.webp"
|
"background": "systems/fvtt-pegasus-rpg/images/ui/pegasus_welcome_page.webp"
|
||||||
}
|
}
|
@ -37,6 +37,7 @@
|
|||||||
"rolename": "",
|
"rolename": "",
|
||||||
"morality": 5,
|
"morality": 5,
|
||||||
"bonusselection": "",
|
"bonusselection": "",
|
||||||
|
"noautobonus": false,
|
||||||
"moralitythreshold": 0
|
"moralitythreshold": 0
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -869,6 +869,12 @@
|
|||||||
<label class="generic-label">Hair</label>
|
<label class="generic-label">Hair</label>
|
||||||
<input type="text" class="" name="system.biodata.hair" value="{{data.biodata.hair}}" data-dtype="String" />
|
<input type="text" class="" name="system.biodata.hair" value="{{data.biodata.hair}}" data-dtype="String" />
|
||||||
</li>
|
</li>
|
||||||
|
{{#if isGM}}
|
||||||
|
<li class="item flexrow">
|
||||||
|
<label class="generic-label">Manual bonuses only ?</label>
|
||||||
|
<input type="checkbox" class="change-worstfear" name="system.biodata.noautobonus" {{checked data.biodata.noautobonus}} />
|
||||||
|
</li>
|
||||||
|
{{/if}}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
|
@ -34,6 +34,27 @@
|
|||||||
</select>
|
</select>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li class="flexrow"><label class="generic-label">Effect Level is a Stat?</label>
|
||||||
|
<label class="attribute-value checkbox"><input type="checkbox" name="system.effectstatlevel" {{checked data.effectstatlevel}}/></label>
|
||||||
|
</li>
|
||||||
|
{{#if data.effectstatlevel}}
|
||||||
|
<li class="flexrow"><label class="generic-label">Stat to use for Effect Level</label>
|
||||||
|
<select class="competence-base flexrow" type="text" name="system.effectstat" value="{{data.effectstat}}" data-dtype="String">
|
||||||
|
{{#select data.effectstat}}
|
||||||
|
{{> systems/fvtt-pegasus-rpg/templates/partial-options-statistics.html notapplicable=false mr=true all=false}}
|
||||||
|
{{/select}}
|
||||||
|
</select>
|
||||||
|
</li>
|
||||||
|
{{else}}
|
||||||
|
<li class="flexrow"><label class="generic-label">Effect Level</label>
|
||||||
|
<input type="text" class="input-numeric-short padd-right" name="system.effectlevel" value="{{data.effectlevel}}" data-dtype="Number"/>
|
||||||
|
</li>
|
||||||
|
<li class="flexrow"><label class="generic-label">Affect size ?</label>
|
||||||
|
<label class="attribute-value checkbox"><input type="checkbox" name="system.affectsize" {{checked data.affectsize}}/></label>
|
||||||
|
</li>
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
|
|
||||||
<li class="flexrow"><label class="generic-label">One use?</label>
|
<li class="flexrow"><label class="generic-label">One use?</label>
|
||||||
<label class="attribute-value checkbox"><input type="checkbox" name="system.oneuse" {{checked data.oneuse}}/></label>
|
<label class="attribute-value checkbox"><input type="checkbox" name="system.oneuse" {{checked data.oneuse}}/></label>
|
||||||
</li>
|
</li>
|
||||||
@ -65,26 +86,6 @@
|
|||||||
<label class="attribute-value checkbox"><input type="checkbox" name="system.locked" {{checked data.locked}}/></label>
|
<label class="attribute-value checkbox"><input type="checkbox" name="system.locked" {{checked data.locked}}/></label>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
<li class="flexrow"><label class="generic-label">Effect Level is a Stat?</label>
|
|
||||||
<label class="attribute-value checkbox"><input type="checkbox" name="system.effectstatlevel" {{checked data.effectstatlevel}}/></label>
|
|
||||||
</li>
|
|
||||||
{{#if data.effectstatlevel}}
|
|
||||||
<li class="flexrow"><label class="generic-label">Stat to use for Effect Level</label>
|
|
||||||
<select class="competence-base flexrow" type="text" name="system.effectstat" value="{{data.effectstat}}" data-dtype="String">
|
|
||||||
{{#select data.effectstat}}
|
|
||||||
{{> systems/fvtt-pegasus-rpg/templates/partial-options-statistics.html notapplicable=false mr=true all=false}}
|
|
||||||
{{/select}}
|
|
||||||
</select>
|
|
||||||
</li>
|
|
||||||
{{else}}
|
|
||||||
<li class="flexrow"><label class="generic-label">Effect Level</label>
|
|
||||||
<input type="text" class="input-numeric-short padd-right" name="system.effectlevel" value="{{data.effectlevel}}" data-dtype="Number"/>
|
|
||||||
</li>
|
|
||||||
<li class="flexrow"><label class="generic-label">Affect size ?</label>
|
|
||||||
<label class="attribute-value checkbox"><input type="checkbox" name="system.affectsize" {{checked data.affectsize}}/></label>
|
|
||||||
</li>
|
|
||||||
{{/if}}
|
|
||||||
|
|
||||||
<li class="flexrow"><label class="generic-label">Affect Status?</label>
|
<li class="flexrow"><label class="generic-label">Affect Status?</label>
|
||||||
<label class="attribute-value checkbox"><input type="checkbox" name="system.affectstatus" {{checked data.affectstatus}}/></label>
|
<label class="attribute-value checkbox"><input type="checkbox" name="system.affectstatus" {{checked data.affectstatus}}/></label>
|
||||||
</li>
|
</li>
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
</label>
|
</label>
|
||||||
</span>
|
</span>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.value" value="{{stat2.value}}" data-dtype="Number"/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.value" value="{{stat2.value}}" data-dtype="Number"/>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.bonus" value="{{stat2.bonus}}" data-dtype="Number" disabled/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.bonus" value="{{stat2.bonus}}" data-dtype="Number" {{@root.disabledBonus}}/>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.max" value="{{stat2.max}}" data-dtype="Number"/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.secondary.{{key}}.max" value="{{stat2.max}}" data-dtype="Number"/>
|
||||||
</li>
|
</li>
|
||||||
{{/each}}
|
{{/each}}
|
||||||
@ -27,7 +27,7 @@
|
|||||||
<label class="status-small-label"><strong>{{data.nrg.label}}</strong></label>
|
<label class="status-small-label"><strong>{{data.nrg.label}}</strong></label>
|
||||||
</span>
|
</span>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.value" value="{{data.nrg.value}}" data-dtype="Number"/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.value" value="{{data.nrg.value}}" data-dtype="Number"/>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.mod" value="{{data.nrg.mod}}" data-dtype="Number" disabled/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.mod" value="{{data.nrg.mod}}" data-dtype="Number" {{@root.disabledBonus}}/>
|
||||||
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.max" value="{{data.nrg.max}}" data-dtype="Number"/>
|
<input type="text" class="padd-right status-small-label no-grow" name="system.nrg.max" value="{{data.nrg.max}}" data-dtype="Number"/>
|
||||||
<span class="small-label status-small-label"> / {{data.nrg.absolutemax}}</span>
|
<span class="small-label status-small-label"> / {{data.nrg.absolutemax}}</span>
|
||||||
</li>
|
</li>
|
||||||
|
Reference in New Issue
Block a user