Compare commits
4 Commits
af3de8f98b
...
f21a5ebf06
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f21a5ebf06 | ||
|
|
ae0ca2018f | ||
|
|
1cb0f89dff | ||
|
|
d6983cf9c7 |
@ -22,6 +22,7 @@
|
|||||||
<a class="fas fa-list {{#if (eq tabGroups.primary 'talente') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="talente" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.talente"}}"></a>
|
<a class="fas fa-list {{#if (eq tabGroups.primary 'talente') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="talente" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.talente"}}"></a>
|
||||||
<a class="fas fa-sack {{#if (eq tabGroups.primary 'inventar') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="inventar" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.inventar"}}"></a>
|
<a class="fas fa-sack {{#if (eq tabGroups.primary 'inventar') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="inventar" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.inventar"}}"></a>
|
||||||
<a class="fas fa-swords {{#if (eq tabGroups.primary 'kampf') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="kampf" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.kampf"}}"></a>
|
<a class="fas fa-swords {{#if (eq tabGroups.primary 'kampf') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="kampf" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.kampf"}}"></a>
|
||||||
|
<a class="fas fa-bolt {{#if (eq tabGroups.primary 'zauber') }}active{{/if}}" data-action="tab" data-group="primary" data-tab="zauber" data-tooltip-direction="RIGHT" data-tooltip="{{localize "DSA41.character.zauber"}}"></a>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
<div class="scroll-container">
|
<div class="scroll-container">
|
||||||
@ -474,29 +475,6 @@
|
|||||||
{{/each}}
|
{{/each}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="list Zauber">
|
|
||||||
<div class="list-header ">
|
|
||||||
<div>{{localize "DSA41.kampf.zauber"}}</div>
|
|
||||||
<div class="center"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{{#unless (ne actor.itemTypes.Zauber.length 0)}}
|
|
||||||
<div class="list-item">{{localize "DSA41.list_empty"}}</div>
|
|
||||||
{{/unless}}
|
|
||||||
|
|
||||||
{{#each actor.itemTypes.Zauber}}
|
|
||||||
<div class="list-item" data-item-id="{{_id}}">
|
|
||||||
<div class="row" data-action="item-open" data-tooltip="{{system.beschreibung}}">
|
|
||||||
<img class="item-image" src="{{img}}" title="{{name}}">
|
|
||||||
<div class="col">
|
|
||||||
<span>{{name}}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<button class="right" data-action="post-zauber">Post to Chat</button>
|
|
||||||
</div>
|
|
||||||
{{/each}}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="list Ruestung">
|
<div class="list Ruestung">
|
||||||
<div class="list-header rowspan2">
|
<div class="list-header rowspan2">
|
||||||
<div class="rowspan2">{{localize "DSA41.kampf.ruestungen"}}</div>
|
<div class="rowspan2">{{localize "DSA41.kampf.ruestungen"}}</div>
|
||||||
@ -577,6 +555,43 @@
|
|||||||
{{/each}}
|
{{/each}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="tab Zauber {{#if (eq tabGroups.primary 'zauber')}}active{{/if}}" data-group="primary" data-tab="zauber">
|
||||||
|
<div class="list Zauber subgrid-columns">
|
||||||
|
<div class="list-header ">
|
||||||
|
<div>{{localize "DSA41.kampf.zauber"}}</div>
|
||||||
|
<div></div>
|
||||||
|
<div class="center">Eigenschaften</div>
|
||||||
|
<div></div>
|
||||||
|
<div class="center">{{localize "DSA41.zauber.label_zauberfertigkeitswert"}}</div>
|
||||||
|
<div></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{{#unless (ne actor.itemTypes.Zauber.length 0)}}
|
||||||
|
<div class="list-item">{{localize "DSA41.list_empty"}}</div>
|
||||||
|
{{/unless}}
|
||||||
|
|
||||||
|
{{#each actor.itemTypes.Zauber}}
|
||||||
|
<div class="list-item" data-item-id="{{_id}}">
|
||||||
|
<div class="row" data-action="item-open" data-tooltip-direction="LEFT" data-tooltip="{{system.beschreibung}}">
|
||||||
|
<img class="item-image" src="{{img}}" title="{{name}}">
|
||||||
|
<div class="col">
|
||||||
|
<span>{{name}}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div></div>
|
||||||
|
<div class="center" data-action="roll" data-roll-type="zauber">
|
||||||
|
{{>die-type type=system.attribute1}}
|
||||||
|
{{>die-type type=system.attribute2}}
|
||||||
|
{{>die-type type=system.attribute3}}
|
||||||
|
</div>
|
||||||
|
<div></div>
|
||||||
|
<div>{{>editable-input type="number" data-name="system.zauberfertigkeitswert" value=system.zauberfertigkeitswert}}</div>
|
||||||
|
<div class="center fas fa-trash" data-action="item-delete"></div>
|
||||||
|
</div>
|
||||||
|
{{/each}}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
39
src/Chat/Zauber.hbs
Normal file
39
src/Chat/Zauber.hbs
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<div class="zauber_chat_message">
|
||||||
|
<h3>{{zauber.name}} ({{localize (concat "DSA41.chat.zauberfertigkeitswert_short")}}: {{zauber.system.zauberfertigkeitswert}}{{#if (ne modifikator 0)}} + {{modifikator}}{{/if}}{{#if (ne magieresistenz 0)}} + {{magieresistenz}}{{/if}})</h3>
|
||||||
|
<div class="info">
|
||||||
|
<div>
|
||||||
|
<div>{{localize (concat "DSA41.chat.attribute")}}</div>
|
||||||
|
<div>{{localize (concat "DSA41.chat.value")}}</div>
|
||||||
|
<div>{{localize (concat "DSA41.chat.roll")}}</div>
|
||||||
|
<div>{{localize (concat "DSA41.chat.zauberfertigkeitswert_short")}}</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div>{{localize (concat "DSA41.attributes.long." attribute1.type)}}</div>
|
||||||
|
<div>{{attribute1.value}}</div>
|
||||||
|
<div>{{roll1}}</div>
|
||||||
|
<div>{{needed_zfw_roll1}}</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div>{{localize (concat "DSA41.attributes.long." attribute2.type)}}</div>
|
||||||
|
<div>{{attribute2.value}}</div>
|
||||||
|
<div>{{roll2}}</div>
|
||||||
|
<div>{{needed_zfw_roll2}}</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<div>{{localize (concat "DSA41.attributes.long." attribute3.type)}}</div>
|
||||||
|
<div>{{attribute3.value}}</div>
|
||||||
|
<div>{{roll3}}</div>
|
||||||
|
<div>{{needed_zfw_roll3}}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
{{localize (concat "DSA41.chat.result")}}:
|
||||||
|
{{#if (lt leftover_zfw 0)}}
|
||||||
|
<b>{{localize (concat "DSA41.chat.failure")}}</b>
|
||||||
|
{{else}}
|
||||||
|
<b>{{localize (concat "DSA41.chat.success")}}</b>
|
||||||
|
{{/if}}
|
||||||
|
({{localize (concat "DSA41.chat.zauberfertigkeitswert_short")}}: {{leftover_zfw}})
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
9
src/Dialogs/Zauber.hbs
Normal file
9
src/Dialogs/Zauber.hbs
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<div>
|
||||||
|
<span class="colspan2">{{localize "DSA41.kampf.modifikator"}}</span>
|
||||||
|
<input class="colspan2" type="number" name="modifikator" value="{{lookup formData "modifikator"}}">
|
||||||
|
|
||||||
|
{{#if options.item.system.magieresistenz}}
|
||||||
|
<span class="colspan2">{{localize "DSA41.zauber.label_magieresistenz"}}</span>
|
||||||
|
<input class="colspan2" type="number" name="magieresistenz" value="{{lookup formData "magieresistenz"}}">
|
||||||
|
{{/if}}
|
||||||
|
</div>
|
||||||
@ -24,6 +24,9 @@
|
|||||||
|
|
||||||
<span>{{localize "DSA41.zauber.merkmale.label"}}</span>
|
<span>{{localize "DSA41.zauber.merkmale.label"}}</span>
|
||||||
{{DSA41_input "system.merkmale"}}
|
{{DSA41_input "system.merkmale"}}
|
||||||
|
|
||||||
|
<span>{{localize "DSA41.zauber.label_magieresistenz"}}</span>
|
||||||
|
{{DSA41_input "system.magieresistenz"}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
|
|||||||
@ -80,6 +80,7 @@
|
|||||||
"roll": "Wurf",
|
"roll": "Wurf",
|
||||||
|
|
||||||
"talentwert_short": "TaW",
|
"talentwert_short": "TaW",
|
||||||
|
"zauberfertigkeitswert_short": "ZfW",
|
||||||
|
|
||||||
"targets": "Ziele",
|
"targets": "Ziele",
|
||||||
"trefferpunkte_apply": "Zuweisen"
|
"trefferpunkte_apply": "Zuweisen"
|
||||||
@ -147,6 +148,7 @@
|
|||||||
"strength": "Körperkraft",
|
"strength": "Körperkraft",
|
||||||
|
|
||||||
"talent": "Talent",
|
"talent": "Talent",
|
||||||
|
"zauber": "Zauber",
|
||||||
|
|
||||||
"attacke": "Attacke",
|
"attacke": "Attacke",
|
||||||
"parade": "Parade",
|
"parade": "Parade",
|
||||||
@ -161,7 +163,8 @@
|
|||||||
"talente": "Talente",
|
"talente": "Talente",
|
||||||
"inventar": "Inventar",
|
"inventar": "Inventar",
|
||||||
"kampf": "Kampf",
|
"kampf": "Kampf",
|
||||||
"allgemein": "Allgemein"
|
"allgemein": "Allgemein",
|
||||||
|
"zauber": "Zauber"
|
||||||
},
|
},
|
||||||
|
|
||||||
"allgemein": {
|
"allgemein": {
|
||||||
@ -541,6 +544,8 @@
|
|||||||
"label_komplexitaet": "Komplexität",
|
"label_komplexitaet": "Komplexität",
|
||||||
"label_zauberdauer": "Zauberdauer",
|
"label_zauberdauer": "Zauberdauer",
|
||||||
"label_wirkungsdauer": "Wirkungsdauer",
|
"label_wirkungsdauer": "Wirkungsdauer",
|
||||||
|
"label_zauberfertigkeitswert": "Zauberfertigkeitswert",
|
||||||
|
"label_magieresistenz": "Magieresistenz",
|
||||||
|
|
||||||
"merkmale": {
|
"merkmale": {
|
||||||
"label": "Merkmale",
|
"label": "Merkmale",
|
||||||
|
|||||||
32
src/main.css
32
src/main.css
@ -236,6 +236,8 @@ html {
|
|||||||
width: 3.5em;
|
width: 3.5em;
|
||||||
height: 3.5em;
|
height: 3.5em;
|
||||||
|
|
||||||
|
text-shadow: 1px 1px 1px black;
|
||||||
|
|
||||||
& > * {
|
& > * {
|
||||||
grid-row: 1;
|
grid-row: 1;
|
||||||
grid-column: 1;
|
grid-column: 1;
|
||||||
@ -598,10 +600,6 @@ html {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
& .Zauber {
|
|
||||||
grid-template-columns: minmax(0, max-content) minmax(0, auto);
|
|
||||||
}
|
|
||||||
|
|
||||||
& .Ruestung {
|
& .Ruestung {
|
||||||
grid-template-columns: 2fr repeat(8, 1fr) repeat(2, 1.5fr);
|
grid-template-columns: 2fr repeat(8, 1fr) repeat(2, 1.5fr);
|
||||||
text-align: center;
|
text-align: center;
|
||||||
@ -611,6 +609,14 @@ html {
|
|||||||
grid-template-columns: minmax(min-content, max-content) auto min-content;
|
grid-template-columns: minmax(min-content, max-content) auto min-content;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&[data-tab="zauber"] {
|
||||||
|
grid-template-columns: minmax(0, max-content) auto minmax(0, max-content) auto minmax(0, max-content) min-content;
|
||||||
|
|
||||||
|
& > * {
|
||||||
|
grid-column: 1 / -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -638,6 +644,24 @@ html {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.zauber_chat_message {
|
||||||
|
& .info {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: repeat(4, minmax(min-content, 1fr));
|
||||||
|
text-wrap: nowrap;
|
||||||
|
|
||||||
|
& > * {
|
||||||
|
display: grid;
|
||||||
|
grid-column: 1 / -1;
|
||||||
|
grid-template-columns: subgrid;
|
||||||
|
|
||||||
|
& > *:not(:first-child) {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#tooltip.DSA41 {
|
#tooltip.DSA41 {
|
||||||
max-width: 650px;
|
max-width: 650px;
|
||||||
|
|||||||
59
src/main.mjs
59
src/main.mjs
@ -147,6 +147,7 @@ Hooks.once("init", async function() {
|
|||||||
"CHAT_HEADER": "systems/dsa-4th-edition/src/Chat/Header.hbs",
|
"CHAT_HEADER": "systems/dsa-4th-edition/src/Chat/Header.hbs",
|
||||||
"TrefferpunkteTargets": "systems/dsa-4th-edition/src/Chat/TrefferpunkteTargets.hbs",
|
"TrefferpunkteTargets": "systems/dsa-4th-edition/src/Chat/TrefferpunkteTargets.hbs",
|
||||||
"talent_chat": "systems/dsa-4th-edition/src/Chat/Talent.hbs",
|
"talent_chat": "systems/dsa-4th-edition/src/Chat/Talent.hbs",
|
||||||
|
"zauber_chat": "systems/dsa-4th-edition/src/Chat/Zauber.hbs",
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -1114,6 +1115,8 @@ class DSA41_ZauberData extends TypeDataModel {
|
|||||||
},
|
},
|
||||||
})),
|
})),
|
||||||
|
|
||||||
|
magieresistenz: new BooleanField({ initial: false }),
|
||||||
|
|
||||||
haus: new BooleanField({ initial: false }),
|
haus: new BooleanField({ initial: false }),
|
||||||
zauberfertigkeitswert: new NumberField({ integer: true, initial: 0 }),
|
zauberfertigkeitswert: new NumberField({ integer: true, initial: 0 }),
|
||||||
|
|
||||||
@ -1142,6 +1145,7 @@ class DSA41_Dialog extends DSA41_ApplicationMixin(ApplicationV2) {
|
|||||||
static PARTS = {
|
static PARTS = {
|
||||||
Eigenschaft: { template: "systems/dsa-4th-edition/src/Dialogs/Attribute.hbs" },
|
Eigenschaft: { template: "systems/dsa-4th-edition/src/Dialogs/Attribute.hbs" },
|
||||||
Talent: { template: "systems/dsa-4th-edition/src/Dialogs/Talent.hbs" },
|
Talent: { template: "systems/dsa-4th-edition/src/Dialogs/Talent.hbs" },
|
||||||
|
Zauber: { template: "systems/dsa-4th-edition/src/Dialogs/Zauber.hbs" },
|
||||||
|
|
||||||
Attacke: { template: "systems/dsa-4th-edition/src/Dialogs/Attacke.hbs" },
|
Attacke: { template: "systems/dsa-4th-edition/src/Dialogs/Attacke.hbs" },
|
||||||
Parade: { template: "systems/dsa-4th-edition/src/Dialogs/Parade.hbs" },
|
Parade: { template: "systems/dsa-4th-edition/src/Dialogs/Parade.hbs" },
|
||||||
@ -1291,7 +1295,7 @@ class DSA41_ActorSheet extends DSA41_ApplicationMixin(ActorSheetV2) {
|
|||||||
modifikator: -data.modifikator,
|
modifikator: -data.modifikator,
|
||||||
|
|
||||||
attribute1: { type: item.system.attribute1, value: attribute1 },
|
attribute1: { type: item.system.attribute1, value: attribute1 },
|
||||||
attribute2: { type: item.system.attribute2, value: attribute3 },
|
attribute2: { type: item.system.attribute2, value: attribute2 },
|
||||||
attribute3: { type: item.system.attribute3, value: attribute3 },
|
attribute3: { type: item.system.attribute3, value: attribute3 },
|
||||||
|
|
||||||
roll1: roll1,
|
roll1: roll1,
|
||||||
@ -1436,6 +1440,59 @@ class DSA41_ActorSheet extends DSA41_ApplicationMixin(ActorSheetV2) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (roll_type == "zauber") {
|
||||||
|
const title = game.i18n.localize("DSA41.roll_types." + roll_type) + ": " + item.name;
|
||||||
|
const data = await DSA41_Dialog.wait("Zauber", { window: {title: title}, item: item });
|
||||||
|
|
||||||
|
const zauberfertigkeitswert = item.system.zauberfertigkeitswert - data.modifikator - data.magieresistenz;
|
||||||
|
const roll_modifier = zauberfertigkeitswert < 0 ? -zauberfertigkeitswert: 0;
|
||||||
|
|
||||||
|
const roll1 = (await new Roll("1d20").evaluate()).total + roll_modifier;
|
||||||
|
const roll2 = (await new Roll("1d20").evaluate()).total + roll_modifier;
|
||||||
|
const roll3 = (await new Roll("1d20").evaluate()).total + roll_modifier;
|
||||||
|
|
||||||
|
const attribute1 = this.document.system.computed.attributes[item.system.attribute1];
|
||||||
|
const attribute2 = this.document.system.computed.attributes[item.system.attribute2];
|
||||||
|
const attribute3 = this.document.system.computed.attributes[item.system.attribute3];
|
||||||
|
|
||||||
|
const needed_zfw_roll1 = Math.max(roll1 - attribute1, 0);
|
||||||
|
const needed_zfw_roll2 = Math.max(roll2 - attribute2, 0);
|
||||||
|
const needed_zfw_roll3 = Math.max(roll3 - attribute3, 0);
|
||||||
|
|
||||||
|
const leftover_zfw = Math.max(zauberfertigkeitswert, 0) - needed_zfw_roll1 - needed_zfw_roll2 - needed_zfw_roll3;
|
||||||
|
|
||||||
|
const context = {
|
||||||
|
zauber: item,
|
||||||
|
|
||||||
|
modifikator: -data.modifikator,
|
||||||
|
magieresistenz: -data.magieresistenz,
|
||||||
|
|
||||||
|
attribute1: { type: item.system.attribute1, value: attribute1 },
|
||||||
|
attribute2: { type: item.system.attribute2, value: attribute2 },
|
||||||
|
attribute3: { type: item.system.attribute3, value: attribute3 },
|
||||||
|
|
||||||
|
roll1: roll1,
|
||||||
|
roll2: roll2,
|
||||||
|
roll3: roll3,
|
||||||
|
|
||||||
|
needed_zfw_roll1: -needed_zfw_roll1,
|
||||||
|
needed_zfw_roll2: -needed_zfw_roll2,
|
||||||
|
needed_zfw_roll3: -needed_zfw_roll3,
|
||||||
|
|
||||||
|
leftover_zfw: Math.min(leftover_zfw, item.system.zauberfertigkeitswert),
|
||||||
|
};
|
||||||
|
|
||||||
|
const message = await ChatMessage.create(
|
||||||
|
{
|
||||||
|
content: await renderTemplate("zauber_chat", context),
|
||||||
|
speaker: { actor: this.actor },
|
||||||
|
sound: CONFIG.sounds.dice,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let roll = new Roll(roll_formula, this.document.system);
|
let roll = new Roll(roll_formula, this.document.system);
|
||||||
roll.toMessage({
|
roll.toMessage({
|
||||||
speaker: ChatMessage.getSpeaker({ actor: this.document }),
|
speaker: ChatMessage.getSpeaker({ actor: this.document }),
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user