v0.1.9
This commit is contained in:
@@ -4,6 +4,8 @@
|
|||||||
- versions condensées des méthodes (@kristov)
|
- versions condensées des méthodes (@kristov)
|
||||||
- renommage des templates
|
- renommage des templates
|
||||||
- image actors par défaut
|
- image actors par défaut
|
||||||
|
- image des créatures
|
||||||
|
- ajout du totem et de l'apprentissage dans les capacités
|
||||||
|
|
||||||
## 0.1.8
|
## 0.1.8
|
||||||
- refactoring sheet vers actor
|
- refactoring sheet vers actor
|
||||||
|
|||||||
+3
-1
@@ -164,6 +164,7 @@
|
|||||||
"type_character": "Personnage",
|
"type_character": "Personnage",
|
||||||
"type_npc": "PNJ",
|
"type_npc": "PNJ",
|
||||||
"type_creature": "Créature",
|
"type_creature": "Créature",
|
||||||
|
"type": "Type",
|
||||||
"group_members": "Membres",
|
"group_members": "Membres",
|
||||||
"encounters": "Rencontres",
|
"encounters": "Rencontres",
|
||||||
"road": "La Route",
|
"road": "La Route",
|
||||||
@@ -209,7 +210,8 @@
|
|||||||
"evolutions": "Adaptations",
|
"evolutions": "Adaptations",
|
||||||
"new_vehicle": "Nouveau véhicule",
|
"new_vehicle": "Nouveau véhicule",
|
||||||
"vehicles": "Véhicules",
|
"vehicles": "Véhicules",
|
||||||
"new_objective": "Nouvel objectif"
|
"new_objective": "Nouvel objectif",
|
||||||
|
"learning": "Apprentissage"
|
||||||
},
|
},
|
||||||
"ABILITIES": {
|
"ABILITIES": {
|
||||||
"vigor": { "name": "Vigueur"},
|
"vigor": { "name": "Vigueur"},
|
||||||
|
|||||||
@@ -11,6 +11,24 @@ export class VermineItem extends Item {
|
|||||||
// preparation methods overridden (such as prepareBaseData()).
|
// preparation methods overridden (such as prepareBaseData()).
|
||||||
super.prepareData();
|
super.prepareData();
|
||||||
}
|
}
|
||||||
|
prepareBaseData(){
|
||||||
|
const actorType = (this.actor !== null) ? this.actor.type : 'character';
|
||||||
|
|
||||||
|
switch (this.type){
|
||||||
|
case 'ability':
|
||||||
|
if (this.system.type == "") {
|
||||||
|
// console.log('je suis une capacité, avec pour sous-type', this.system.type, actorType);
|
||||||
|
this.system.type = actorType;
|
||||||
|
}
|
||||||
|
if (this.system.totem == "" && this.actor !== null && this.actor.system.identity.totem != "") {
|
||||||
|
// console.log('je suis une capacité, avec pour sous-type', this.system.type, actorType);
|
||||||
|
this.system.totem = this.actor.system.identity.totem;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Prepare a data object which is passed to any Roll formulas which are created related to this Item
|
* Prepare a data object which is passed to any Roll formulas which are created related to this Item
|
||||||
|
|||||||
@@ -9,12 +9,12 @@ export class VermineActorSheet extends ActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
static get defaultOptions() {
|
static get defaultOptions() {
|
||||||
return mergeObject(super.defaultOptions, {
|
return mergeObject(super.defaultOptions, {
|
||||||
classes: ["vermine2047", "sheet", "actor"],
|
/*classes: ["vermine2047", "sheet", "actor"],
|
||||||
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
||||||
height: 800,
|
height: 800,
|
||||||
width: 690,
|
width: 690,
|
||||||
resizable: false,
|
resizable: false,
|
||||||
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]*/
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ export class VermineCharacterSheet extends VermineActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
static get defaultOptions() {
|
static get defaultOptions() {
|
||||||
return mergeObject(super.defaultOptions, {
|
return mergeObject(super.defaultOptions, {
|
||||||
classes: ["vermine2047", "sheet", "actor"],
|
classes: ["vermine2047", "sheet", "character", "actor"],
|
||||||
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
||||||
width: 600,
|
width: 600,
|
||||||
height: 600,
|
height: 600,
|
||||||
|
|||||||
@@ -10,10 +10,10 @@ export class VermineCreatureSheet extends ActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
static get defaultOptions() {
|
static get defaultOptions() {
|
||||||
return mergeObject(super.defaultOptions, {
|
return mergeObject(super.defaultOptions, {
|
||||||
classes: ["vermine2047", "sheet", "actor"],
|
classes: ["vermine2047", "sheet", "actor", "creature"],
|
||||||
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
||||||
width: 600,
|
width: 300,
|
||||||
height: 600,
|
height: 300,
|
||||||
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -92,6 +92,33 @@ export class VermineCreatureSheet extends ActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
activateListeners(html) {
|
activateListeners(html) {
|
||||||
super.activateListeners(html);
|
super.activateListeners(html);
|
||||||
|
|
||||||
|
html.find('.item-create').click(this._onItemCreate.bind(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async _onItemCreate(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
const header = event.currentTarget;
|
||||||
|
// Get the type of item to create.
|
||||||
|
const type = header.dataset.type;
|
||||||
|
// Grab any data associated with this control.
|
||||||
|
const data = duplicate(header.dataset);
|
||||||
|
// Initialize a default name.
|
||||||
|
// const name = `New ${type.capitalize()}`;
|
||||||
|
const name = game.i18n.localize('ITEMS.new_' + type);
|
||||||
|
|
||||||
|
console.log('onItemCreate child', data.type, this.actor.type);
|
||||||
|
// Prepare the item object.
|
||||||
|
const itemData = {
|
||||||
|
name: name,
|
||||||
|
type: type,
|
||||||
|
system: data
|
||||||
|
};
|
||||||
|
// Remove the type from the dataset since it's in the itemData.type prop.
|
||||||
|
delete itemData.system["type"];
|
||||||
|
|
||||||
|
// Finally, create the item!
|
||||||
|
return await Item.create(itemData, {parent: this.actor});
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,6 +45,7 @@ export class VermineItemSheet extends ItemSheet {
|
|||||||
// Add the actor's data to context.data for easier access, as well as flags.
|
// Add the actor's data to context.data for easier access, as well as flags.
|
||||||
context.system = itemData.system;
|
context.system = itemData.system;
|
||||||
context.flags = itemData.flags;
|
context.flags = itemData.flags;
|
||||||
|
context.config = CONFIG.VERMINE;
|
||||||
|
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
|
|||||||
+14
-43
@@ -11,10 +11,10 @@ export class VermineGroupSheet extends VermineActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
static get defaultOptions() {
|
static get defaultOptions() {
|
||||||
return mergeObject(super.defaultOptions, {
|
return mergeObject(super.defaultOptions, {
|
||||||
classes: ["vermine2047", "sheet", "actor"],
|
classes: ["vermine2047", "sheet", "actor", "group"],
|
||||||
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
||||||
width: 600,
|
width: 500,
|
||||||
height: 600,
|
height: 500,
|
||||||
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -88,41 +88,19 @@ export class VermineGroupSheet extends VermineActorSheet {
|
|||||||
* @return {undefined}
|
* @return {undefined}
|
||||||
*/
|
*/
|
||||||
_prepareItems(context) {
|
_prepareItems(context) {
|
||||||
// Initialize containers.
|
context.specialties = this.actor.itemTypes['specialty'];
|
||||||
const abilities = [];
|
context.backgrounds = this.actor.itemTypes['background'];
|
||||||
const specialties = [];
|
context.evolutions = this.actor.itemTypes['evolution'];
|
||||||
const backgrounds = [];
|
context.traumas = this.actor.itemTypes['trauma'];
|
||||||
const evolutions = [];
|
|
||||||
const traumas = [];
|
context.gear = this.actor.itemTypes['item'];
|
||||||
|
context.weapons = this.actor.itemTypes['weapon'];
|
||||||
|
context.defenses = this.actor.itemTypes['defense'];
|
||||||
|
context.vehicles = this.actor.itemTypes['vehicle'];
|
||||||
|
|
||||||
|
context.totem_abilities = this.actor.itemTypes['ability'].filter(i=>i.system.type === 'totem');
|
||||||
|
context.abilities = this.actor.itemTypes['ability'].filter(i=>i.system.type !== 'totem');
|
||||||
|
|
||||||
// Iterate through items, allocating to containers
|
|
||||||
for (let i of context.items) {
|
|
||||||
i.img = i.img || DEFAULT_TOKEN;
|
|
||||||
if (i.type === 'ability') {
|
|
||||||
abilities.push(i);
|
|
||||||
}
|
|
||||||
else if (i.type === 'specialty') {
|
|
||||||
specialties.push(i);
|
|
||||||
}
|
|
||||||
else if (i.type === 'background') {
|
|
||||||
backgrounds.push(i);
|
|
||||||
}
|
|
||||||
else if (i.type === 'evolution') {
|
|
||||||
evolutions.push(i);
|
|
||||||
}
|
|
||||||
else if (i.type === 'trauma') {
|
|
||||||
traumas.push(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Assign and return
|
|
||||||
context.abilities = abilities;
|
|
||||||
context.specialties = specialties;
|
|
||||||
context.backgrounds = backgrounds;
|
|
||||||
context.evolutions = evolutions;
|
|
||||||
context.traumas = traumas;
|
|
||||||
context.members = [];
|
context.members = [];
|
||||||
context.encounters = [];
|
context.encounters = [];
|
||||||
|
|
||||||
@@ -134,13 +112,6 @@ export class VermineGroupSheet extends VermineActorSheet {
|
|||||||
context.encounters.push(game.actors.get(encounterId));
|
context.encounters.push(game.actors.get(encounterId));
|
||||||
}
|
}
|
||||||
|
|
||||||
context.gear = this.actor.itemTypes['item'];
|
|
||||||
context.weapons = this.actor.itemTypes['weapon'];
|
|
||||||
context.defenses = this.actor.itemTypes['defense'];
|
|
||||||
context.vehicles = this.actor.itemTypes['vehicle'];
|
|
||||||
|
|
||||||
context.totem_abilities = this.actor.itemTypes['ability'].filter(i=>i.type !== 'totem');
|
|
||||||
context.abilities = this.actor.itemTypes['ability'].filter(i=>i.type === 'totem');
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -10,10 +10,10 @@ export class VermineNpcSheet extends VermineActorSheet {
|
|||||||
/** @override */
|
/** @override */
|
||||||
static get defaultOptions() {
|
static get defaultOptions() {
|
||||||
return mergeObject(super.defaultOptions, {
|
return mergeObject(super.defaultOptions, {
|
||||||
classes: ["vermine2047", "sheet", "actor"],
|
classes: ["vermine2047", "sheet", "actor", "npc"],
|
||||||
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
template: "systems/vermine2047/templates/actor/actor-sheet.hbs",
|
||||||
width: 600,
|
width: 400,
|
||||||
height: 600,
|
height: 400,
|
||||||
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "features" }]
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,15 +8,10 @@
|
|||||||
|
|
||||||
|
|
||||||
// Actor partials.
|
// Actor partials.
|
||||||
"systems/vermine2047/templates/actor/parts/actor-id.hbs",
|
"systems/vermine2047/templates/actor/parts/actor-features.hbs",
|
||||||
"systems/vermine2047/templates/actor/parts/actor-totem.hbs",
|
|
||||||
"systems/vermine2047/templates/actor/parts/character-features.hbs",
|
|
||||||
"systems/vermine2047/templates/actor/parts/character-header.hbs",
|
|
||||||
"systems/vermine2047/templates/actor/parts/actor-items.hbs",
|
"systems/vermine2047/templates/actor/parts/actor-items.hbs",
|
||||||
"systems/vermine2047/templates/actor/parts/actor-weapons.hbs",
|
"systems/vermine2047/templates/actor/parts/actor-weapons.hbs",
|
||||||
"systems/vermine2047/templates/actor/parts/actor-defenses.hbs",
|
"systems/vermine2047/templates/actor/parts/actor-defenses.hbs",
|
||||||
"systems/vermine2047/templates/actor/parts/actor-stories.hbs",
|
|
||||||
"systems/vermine2047/templates/actor/parts/actor-combat.hbs",
|
|
||||||
|
|
||||||
// Character partials.
|
// Character partials.
|
||||||
"systems/vermine2047/templates/actor/character/character-id.hbs",
|
"systems/vermine2047/templates/actor/character/character-id.hbs",
|
||||||
|
|||||||
+1
-1
@@ -2,7 +2,7 @@
|
|||||||
"id": "vermine2047",
|
"id": "vermine2047",
|
||||||
"title": "Vermine 2047",
|
"title": "Vermine 2047",
|
||||||
"description": "The Vermine 2047 system for FoundryVTT!",
|
"description": "The Vermine 2047 system for FoundryVTT!",
|
||||||
"version": "0.1.8",
|
"version": "0.1.9",
|
||||||
"compatibility": {
|
"compatibility": {
|
||||||
"minimum": "10",
|
"minimum": "10",
|
||||||
"verified": "10.287",
|
"verified": "10.287",
|
||||||
|
|||||||
+11
-1
@@ -383,6 +383,11 @@
|
|||||||
"creature": {
|
"creature": {
|
||||||
"templates": ["base"],
|
"templates": ["base"],
|
||||||
"skills": "",
|
"skills": "",
|
||||||
|
"modes": {
|
||||||
|
"survival": true,
|
||||||
|
"nightmare": true,
|
||||||
|
"apocalypse": false
|
||||||
|
},
|
||||||
"pattern": {
|
"pattern": {
|
||||||
"value": 1,
|
"value": 1,
|
||||||
"min": 1,
|
"min": 1,
|
||||||
@@ -437,7 +442,12 @@
|
|||||||
},
|
},
|
||||||
"ability": {
|
"ability": {
|
||||||
"templates": ["list"],
|
"templates": ["list"],
|
||||||
"type": "character",
|
"type": "",
|
||||||
|
"totem": "",
|
||||||
|
"learn": {
|
||||||
|
"threshold":5,
|
||||||
|
"hindrance":0
|
||||||
|
},
|
||||||
"level": {
|
"level": {
|
||||||
"value": 1,
|
"value": 1,
|
||||||
"min": 1,
|
"min": 1,
|
||||||
|
|||||||
@@ -7,7 +7,6 @@
|
|||||||
<ol class="list-item">
|
<ol class="list-item">
|
||||||
{{#each members as |actor id|}}
|
{{#each members as |actor id|}}
|
||||||
<li class="actor flexrow" data-actor-id="{{actor._id}}">
|
<li class="actor flexrow" data-actor-id="{{actor._id}}">
|
||||||
{{ log actor }}
|
|
||||||
<div class="actor-name" style="flex:4;">
|
<div class="actor-name" style="flex:4;">
|
||||||
<a class="item-control">{{actor.name}}</a>
|
<a class="item-control">{{actor.name}}</a>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -14,16 +14,34 @@
|
|||||||
<aside style="flex:1">
|
<aside style="flex:1">
|
||||||
<div class="resource">
|
<div class="resource">
|
||||||
<label class="resource-label">{{ localize "VERMINE.level"}}</label>
|
<label class="resource-label">{{ localize "VERMINE.level"}}</label>
|
||||||
<input type="number" name="system.level" value="{{system.level}}" data-dtype="Number"/>
|
<input type="number" name="system.level.value" value="{{system.level.value }}" data-dtype="Number" min="{{system.level.min }}" max="{{system.level.max }}" />
|
||||||
</div>
|
</div>
|
||||||
|
{{#if (eq system.type "group")}}
|
||||||
|
<div class="resource row mdb">
|
||||||
|
<label class="resource-label">{{ localize "ITEMS.learning"}}</label>
|
||||||
|
<div class=" flexrow row">
|
||||||
|
<input type="number" name="system.learning.threshold" value="{{system.learning.threshold }}" data-dtype="Number" min="3" max="10" /> /
|
||||||
|
<input type="number" name="system.learning.hindrance" value="{{system.learning.hindrance }}" data-dtype="Number" min="0" max="3" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{{/if}}
|
||||||
<div class="resource">
|
<div class="resource">
|
||||||
<label class="resource-label">{{ localize "VERMINE.type"}}</label>
|
<label class="resource-label">{{ localize "VERMINE.type"}}</label>
|
||||||
<select name="system.type" value="{{system.type}}" data-dtype="String">
|
<select name="system.type" data-dtype="String">
|
||||||
<option value="character" {{#if (eq system.type "character")}}selected{{/if}}>Personnage</option>
|
<option value="character" {{#if (eq system.type "character")}}selected{{/if}}>Personnage</option>
|
||||||
<option value="group" {{#if (eq system.type "group")}}selected{{/if}}>Groupe</option>
|
<option value="group" {{#if (eq system.type "group")}}selected{{/if}}>Groupe</option>
|
||||||
|
<option value="group" {{#if (eq system.type "creature")}}selected{{/if}}>Créature</option>
|
||||||
<option value="totem" {{#if (eq system.type "totem")}}selected{{/if}}>Totem</option>
|
<option value="totem" {{#if (eq system.type "totem")}}selected{{/if}}>Totem</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="resource">
|
||||||
|
<label class="resource-label">{{ localize "VERMINE.totem"}}</label>
|
||||||
|
<select name="system.totem" data-dtype="String">
|
||||||
|
{{#each config.totems as | totem tk|}}
|
||||||
|
<option value="{{tk}}" {{#if (eq tk @root.system.totem)}}selected="selected"{{/if}}>{{ localize totem }}</option>
|
||||||
|
{{/each}}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
</aside>
|
</aside>
|
||||||
<main class="editor-wrapper" style="flex:10">
|
<main class="editor-wrapper" style="flex:10">
|
||||||
{{editor system.description target="system.description" rollData=rollData button=true owner=owner editable=editable}}
|
{{editor system.description target="system.description" rollData=rollData button=true owner=owner editable=editable}}
|
||||||
|
|||||||
Reference in New Issue
Block a user