Compare commits

...

3 Commits

Author SHA1 Message Date
6b22dade9c Foundry v13 migration 2025-05-01 23:27:51 +02:00
965fc02eb3 Foundry v13 migration 2025-05-01 23:23:29 +02:00
0ef689bf1b Fix specialization again 2025-03-11 23:47:08 +01:00
59 changed files with 197 additions and 179 deletions

View File

@ -6,7 +6,7 @@
import { EcrymeUtility } from "../common/ecryme-utility.js"; import { EcrymeUtility } from "../common/ecryme-utility.js";
/* -------------------------------------------- */ /* -------------------------------------------- */
export class EcrymeActorSheet extends ActorSheet { export class EcrymeActorSheet extends foundry.appv1.sheets.ActorSheet {
/** @override */ /** @override */
static get defaultOptions() { static get defaultOptions() {
@ -53,9 +53,9 @@ export class EcrymeActorSheet extends ActorSheet {
cephalySkills: this.actor.getCephalySkills(), cephalySkills: this.actor.getCephalySkills(),
subActors: foundry.utils.duplicate(this.actor.getSubActors()), subActors: foundry.utils.duplicate(this.actor.getSubActors()),
annency: this.actor.getAnnency(), annency: this.actor.getAnnency(),
description: await TextEditor.enrichHTML(this.object.system.biodata.description, { async: true }), description: await foundry.applications.ux.TextEditor.implementation.enrichHTML(this.object.system.biodata.description, { async: true }),
notes: await TextEditor.enrichHTML(this.object.system.biodata.notes, { async: true }), notes: await foundry.applications.ux.TextEditor.implementation.enrichHTML(this.object.system.biodata.notes, { async: true }),
equipementlibre: await TextEditor.enrichHTML(this.object.system.equipmentfree, { async: true }), equipementlibre: await foundry.applications.ux.TextEditor.implementation.enrichHTML(this.object.system.equipmentfree, { async: true }),
options: this.options, options: this.options,
owner: this.document.isOwner, owner: this.document.isOwner,
editScore: this.options.editScore, editScore: this.options.editScore,
@ -75,10 +75,10 @@ export class EcrymeActorSheet extends ActorSheet {
// Everything below here is only needed if the sheet is editable // Everything below here is only needed if the sheet is editable
if (!this.options.editable) return; if (!this.options.editable) return;
html.bind("keydown", function(e) { // Ignore Enter in actores sheet html.bind("keydown", function(e) { // Ignore Enter in actores sheet
if (e.keyCode === 13) return false; if (e.keyCode === 13) return false;
}); });
html.find('.open-annency').click(ev => { html.find('.open-annency').click(ev => {
let actorId = $(ev.currentTarget).data("annency-id") let actorId = $(ev.currentTarget).data("annency-id")
@ -105,14 +105,14 @@ export class EcrymeActorSheet extends ActorSheet {
let dataType = $(ev.currentTarget).data("type") let dataType = $(ev.currentTarget).data("type")
this.actor.createEmbeddedDocuments('Item', [{ name: "NewItem", type: dataType }], { renderSheet: true }) this.actor.createEmbeddedDocuments('Item', [{ name: "NewItem", type: dataType }], { renderSheet: true })
}) })
html.find('.subactor-edit').click(ev => { html.find('.subactor-edit').click(ev => {
const li = $(ev.currentTarget).parents(".item"); const li = $(ev.currentTarget).parents(".item");
let actorId = li.data("actor-id"); let actorId = li.data("actor-id");
let actor = game.actors.get( actorId ); let actor = game.actors.get( actorId );
actor.sheet.render(true); actor.sheet.render(true);
}); });
html.find('.subactor-delete').click(ev => { html.find('.subactor-delete').click(ev => {
const li = $(ev.currentTarget).parents(".item"); const li = $(ev.currentTarget).parents(".item");
let actorId = li.data("actor-id"); let actorId = li.data("actor-id");
@ -131,13 +131,13 @@ export class EcrymeActorSheet extends ActorSheet {
let categKey = $(event.currentTarget).data("category-key") let categKey = $(event.currentTarget).data("category-key")
let skillKey = $(event.currentTarget).data("skill-key") let skillKey = $(event.currentTarget).data("skill-key")
this.actor.rollSkill(categKey, skillKey) this.actor.rollSkill(categKey, skillKey)
}); });
html.find('.roll-spec').click((event) => { html.find('.roll-spec').click((event) => {
let categKey = $(event.currentTarget).data("category-key") let categKey = $(event.currentTarget).data("category-key")
let skillKey = $(event.currentTarget).data("skill-key") let skillKey = $(event.currentTarget).data("skill-key")
let specId = $(event.currentTarget).data("spec-id") let specId = $(event.currentTarget).data("spec-id")
this.actor.rollSpec(categKey, skillKey, specId) this.actor.rollSpec(categKey, skillKey, specId)
}); });
html.find('.roll-skill-confront').click((event) => { html.find('.roll-skill-confront').click((event) => {
let categKey = $(event.currentTarget).data("category-key") let categKey = $(event.currentTarget).data("category-key")
let skillKey = $(event.currentTarget).data("skill-key") let skillKey = $(event.currentTarget).data("skill-key")
@ -151,36 +151,36 @@ export class EcrymeActorSheet extends ActorSheet {
const li = $(event.currentTarget).parents(".item") const li = $(event.currentTarget).parents(".item")
let weaponId = li.data("item-id"); let weaponId = li.data("item-id");
this.actor.rollWeaponConfront(weaponId) this.actor.rollWeaponConfront(weaponId)
}); });
html.find('.impact-modify').click((event) => { html.find('.impact-modify').click((event) => {
let impactType = $(event.currentTarget).data("impact-type") let impactType = $(event.currentTarget).data("impact-type")
let impactLevel = $(event.currentTarget).data("impact-level") let impactLevel = $(event.currentTarget).data("impact-level")
let modifier = Number($(event.currentTarget).data("impact-modifier")) let modifier = Number($(event.currentTarget).data("impact-modifier"))
this.actor.modifyImpact(impactType, impactLevel, modifier) this.actor.modifyImpact(impactType, impactLevel, modifier)
}); });
html.find('.roll-weapon').click((event) => { html.find('.roll-weapon').click((event) => {
const armeId = $(event.currentTarget).data("arme-id") const armeId = $(event.currentTarget).data("arme-id")
this.actor.rollArme(armeId) this.actor.rollArme(armeId)
}); });
html.find('.lock-unlock-sheet').click((event) => { html.find('.lock-unlock-sheet').click((event) => {
this.options.editScore = !this.options.editScore; this.options.editScore = !this.options.editScore;
this.render(true); this.render(true);
}); });
html.find('.item-equip').click(ev => { html.find('.item-equip').click(ev => {
const li = $(ev.currentTarget).parents(".item"); const li = $(ev.currentTarget).parents(".item");
this.actor.equipItem( li.data("item-id") ); this.actor.equipItem( li.data("item-id") );
this.render(true); this.render(true);
}); });
html.find('.update-field').change(ev => { html.find('.update-field').change(ev => {
const fieldName = $(ev.currentTarget).data("field-name"); const fieldName = $(ev.currentTarget).data("field-name");
let value = Number(ev.currentTarget.value); let value = Number(ev.currentTarget.value);
this.actor.update( { [`${fieldName}`]: value } ); this.actor.update( { [`${fieldName}`]: value } );
}); });
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
/** @override */ /** @override */
setPosition(options = {}) { setPosition(options = {}) {

View File

@ -6,7 +6,7 @@
import { EcrymeUtility } from "../common/ecryme-utility.js"; import { EcrymeUtility } from "../common/ecryme-utility.js";
/* -------------------------------------------- */ /* -------------------------------------------- */
export class EcrymeAnnencySheet extends ActorSheet { export class EcrymeAnnencySheet extends foundry.appv1.sheets.ActorSheet {
/** @override */ /** @override */
static get defaultOptions() { static get defaultOptions() {
@ -75,7 +75,7 @@ export class EcrymeAnnencySheet extends ActorSheet {
let actorId = li.data("actor-id") let actorId = li.data("actor-id")
this.actor.removeAnnencyActor(actorId) this.actor.removeAnnencyActor(actorId)
}) })
// Update Inventory Item // Update Inventory Item
html.find('.item-edit').click(ev => { html.find('.item-edit').click(ev => {

View File

@ -36,7 +36,7 @@ export class EcrymeUtility {
/* -------------------------------------------- */ /* -------------------------------------------- */
static async init() { static async init() {
Hooks.on('renderChatLog', (log, html, data) => EcrymeUtility.chatListeners(html)); Hooks.on('renderChatLog', (log, html, data) => EcrymeUtility.chatListeners(html));
Hooks.on("getChatLogEntryContext", (html, options) => EcrymeUtility.chatMenuManager(html, options)); Hooks.on("getChatMessageContextOptions", (html, options) => EcrymeUtility.chatMenuManager(html, options));
this.rollDataStore = {} this.rollDataStore = {}
this.defenderStore = {} this.defenderStore = {}
@ -120,7 +120,7 @@ export class EcrymeUtility {
let level = game.settings.get("fvtt-ecryme", "ecryme-game-level") let level = game.settings.get("fvtt-ecryme", "ecryme-game-level")
return level == "level_a" return level == "level_a"
} }
/*-------------------------------------------- */ /*-------------------------------------------- */
static buildSkillConfig() { static buildSkillConfig() {
game.system.ecryme.config.skills = {} game.system.ecryme.config.skills = {}
@ -273,20 +273,17 @@ export class EcrymeUtility {
let canTranscendRoll = [] let canTranscendRoll = []
for (let i = 1; i <= 10; i++) { for (let i = 1; i <= 10; i++) {
canTranscendRoll[i] = function (li) { canTranscendRoll[i] = function (li) {
let message = game.messages.get(li.attr("data-message-id")) let message = game.messages.get($(li).attr("data-message-id"))
let rollData = message.getFlag("world", "rolldata") let rollData = message.getFlag("world", "rolldata")
//console.log(">>>>>>>>>>>>>>>>>>>>>>>>>> Menu !!!!", rollData) //console.log(">>>>>>>>>>>>>>>>>>>>>>>>>> Menu !!!!", rollData)
if (rollData.skill && rollData.skill.value >= i && !rollData.transcendUsed && rollData.spec) { return (rollData?.skill?.value >= i && !rollData.transcendUsed && rollData.spec)
return true
}
return false
} }
options.push({ options.push({
name: game.i18n.localize("ECRY.chat.spectranscend") + i, name: game.i18n.localize("ECRY.chat.spectranscend") + i,
icon: '<i class="fas fa-plus-square"></i>', icon: '<i class="fas fa-plus-square"></i>',
condition: canTranscendRoll[i], condition: canTranscendRoll[i],
callback: li => { callback: li => {
let message = game.messages.get(li.attr("data-message-id")) let message = game.messages.get($(li).attr("data-message-id"))
let rollData = message.getFlag("world", "rolldata") let rollData = message.getFlag("world", "rolldata")
EcrymeUtility.transcendFromSpec(rollData, i).catch("Error on Transcend") EcrymeUtility.transcendFromSpec(rollData, i).catch("Error on Transcend")
} }
@ -297,27 +294,27 @@ export class EcrymeUtility {
/* -------------------------------------------- */ /* -------------------------------------------- */
static async chatListeners(html) { static async chatListeners(html) {
html.on("click", '.button-select-confront', event => { $(html).on("click", '.button-select-confront', event => {
let messageId = EcrymeUtility.findChatMessageId(event.currentTarget) let messageId = EcrymeUtility.findChatMessageId(event.currentTarget)
let message = game.messages.get(messageId) let message = game.messages.get(messageId)
let rollData = message.getFlag("world", "ecryme-rolldata") let rollData = message.getFlag("world", "ecryme-rolldata")
ui.notifications.info( game.i18n.localize("ECRY.chat.confrontselect")) ui.notifications.info( game.i18n.localize("ECRY.chat.confrontselect"))
EcrymeUtility.manageConfrontation(rollData) EcrymeUtility.manageConfrontation(rollData)
}) })
html.on("click", '.button-apply-cephaly-difficulty', event => { $(html).on("click", '.button-apply-cephaly-difficulty', event => {
let messageId = EcrymeUtility.findChatMessageId(event.currentTarget) let messageId = EcrymeUtility.findChatMessageId(event.currentTarget)
let message = game.messages.get(messageId) let message = game.messages.get(messageId)
let rollData = message.getFlag("world", "ecryme-rolldata") let rollData = message.getFlag("world", "ecryme-rolldata")
let difficulty = $("#" + rollData.rollId + "-cephaly-difficulty").val() let difficulty = $("#" + rollData.rollId + "-cephaly-difficulty").val()
EcrymeUtility.manageCephalyDifficulty(rollData, difficulty) EcrymeUtility.manageCephalyDifficulty(rollData, difficulty)
}) })
html.on("click", '.button-apply-impact', event => { $(html).on("click", '.button-apply-impact', event => {
let messageId = EcrymeUtility.findChatMessageId(event.currentTarget) let messageId = EcrymeUtility.findChatMessageId(event.currentTarget)
let message = game.messages.get(messageId) let message = game.messages.get(messageId)
let actor = game.actors.get($(event.currentTarget).data("actor-id")) let actor = game.actors.get($(event.currentTarget).data("actor-id"))
actor.modifyImpact($(event.currentTarget).data("impact-type"), $(event.currentTarget).data("impact"), 1) actor.modifyImpact($(event.currentTarget).data("impact-type"), $(event.currentTarget).data("impact"), 1)
}) })
html.on("click", '.button-apply-bonus', event => { $(html).on("click", '.button-apply-bonus', event => {
let messageId = EcrymeUtility.findChatMessageId(event.currentTarget) let messageId = EcrymeUtility.findChatMessageId(event.currentTarget)
let message = game.messages.get(messageId) let message = game.messages.get(messageId)
let actor = game.actors.get($(event.currentTarget).data("actor-id")) let actor = game.actors.get($(event.currentTarget).data("actor-id"))
@ -339,7 +336,7 @@ export class EcrymeUtility {
'systems/fvtt-ecryme/templates/dialogs/partial-confront-bonus-area.hbs', 'systems/fvtt-ecryme/templates/dialogs/partial-confront-bonus-area.hbs',
'systems/fvtt-ecryme/templates/actors/partial-impacts.hbs', 'systems/fvtt-ecryme/templates/actors/partial-impacts.hbs',
] ]
return loadTemplates(templatePaths); return foundry.applications.handlebars.loadTemplates(templatePaths);
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
@ -575,7 +572,7 @@ export class EcrymeUtility {
this.computeResults(rollData) this.computeResults(rollData)
let msg = await this.createChatWithRollMode(rollData.alias, { let msg = await this.createChatWithRollMode(rollData.alias, {
content: await renderTemplate(`systems/fvtt-ecryme/templates/chat/chat-generic-result.hbs`, rollData) content: await foundry.applications.handlebars.renderTemplate(`systems/fvtt-ecryme/templates/chat/chat-generic-result.hbs`, rollData)
}) })
await msg.setFlag("world", "ecryme-rolldata", rollData) await msg.setFlag("world", "ecryme-rolldata", rollData)
console.log("Rolldata result", rollData) console.log("Rolldata result", rollData)
@ -661,7 +658,7 @@ export class EcrymeUtility {
} }
return array; return array;
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
static async createChatMessage(name, rollMode, chatOptions) { static async createChatMessage(name, rollMode, chatOptions) {
switch (rollMode) { switch (rollMode) {

View File

@ -12,7 +12,7 @@ export class EcrymeConfrontDialog extends Dialog {
width: 620, height: 'fit-content', 'z-index': 99999 width: 620, height: 'fit-content', 'z-index': 99999
}); });
let html = await renderTemplate('systems/fvtt-ecryme/templates/dialogs/confront-dialog.hbs', rollData); let html = await foundry.applications.handlebars.renderTemplate('systems/fvtt-ecryme/templates/dialogs/confront-dialog.hbs', rollData);
return new EcrymeConfrontDialog(actor, rollData, html, options); return new EcrymeConfrontDialog(actor, rollData, html, options);
} }
@ -72,7 +72,7 @@ export class EcrymeConfrontDialog extends Dialog {
$("#confront-dice-pool").html(content) $("#confront-dice-pool").html(content)
content = await renderTemplate("systems/fvtt-ecryme/templates/dialogs/partial-confront-bonus-area.hbs", this.rollData ) content = await renderTemplate("systems/fvtt-ecryme/templates/dialogs/partial-confront-bonus-area.hbs", this.rollData )
$("#confront-bonus-pool").html(content) $("#confront-bonus-pool").html(content)
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
async refreshDialog() { async refreshDialog() {
@ -83,7 +83,7 @@ export class EcrymeConfrontDialog extends Dialog {
let button = this.buttonDisabled let button = this.buttonDisabled
setTimeout(function () { $(".launchConfront").attr("disabled", button) }, 180) setTimeout(function () { $(".launchConfront").attr("disabled", button) }, 180)
} }
/* ------------------ -------------------------- */ /* ------------------ -------------------------- */
_canDragStart(selector) { _canDragStart(selector) {
console.log("CAN DRAG START", selector, super._canDragStart(selector) ) console.log("CAN DRAG START", selector, super._canDragStart(selector) )
@ -124,23 +124,23 @@ export class EcrymeConfrontDialog extends Dialog {
if ( data.dragType == "dice") { if ( data.dragType == "dice") {
let idx = Number(data.diceIndex) let idx = Number(data.diceIndex)
console.log("DATA", data, event, event.srcElement.className) console.log("DATA", data, event, event.srcElement.className)
if (event.srcElement.className.includes("execution") && if (event.srcElement.className.includes("execution") &&
this.rollData.availableDices.filter(d => d.location == "execution").length < 2) { this.rollData.availableDices.filter(d => d.location == "execution").length < 2) {
this.rollData.availableDices[idx].location = "execution" this.rollData.availableDices[idx].location = "execution"
} }
if (event.srcElement.className.includes("preservation") && if (event.srcElement.className.includes("preservation") &&
this.rollData.availableDices.filter(d => d.location == "preservation").length < 2) { this.rollData.availableDices.filter(d => d.location == "preservation").length < 2) {
this.rollData.availableDices[idx].location = "preservation" this.rollData.availableDices[idx].location = "preservation"
} }
if (event.srcElement.className.includes("dice-list")) { if (event.srcElement.className.includes("dice-list")) {
this.rollData.availableDices[idx].location = "mainpool" this.rollData.availableDices[idx].location = "mainpool"
} }
if (this.rollData.availableDices.filter(d => d.location == "execution").length == 2 && this.rollData.availableDices.filter(d => d.location == "preservation").length == 2) { if (this.rollData.availableDices.filter(d => d.location == "execution").length == 2 && this.rollData.availableDices.filter(d => d.location == "preservation").length == 2) {
this.buttonDisabled = false this.buttonDisabled = false
} else { } else {
this.buttonDisabled = true this.buttonDisabled = true
} }
} else { } else {
let idx = Number(data.bonusIndex) let idx = Number(data.bonusIndex)
if (event.srcElement.className.includes("execution")) { if (event.srcElement.className.includes("execution")) {
@ -192,7 +192,7 @@ export class EcrymeConfrontDialog extends Dialog {
this.processTranscendence() this.processTranscendence()
if (rollData.selectedSpecs && rollData.selectedSpecs.length > 0) { if (rollData.selectedSpecs && rollData.selectedSpecs.length > 0) {
rollData.spec = foundry.utils.duplicate(actor.getSpecialization(rollData.selectedSpecs[0])) rollData.spec = foundry.utils.duplicate(actor.getSpecialization(rollData.selectedSpecs[0]))
rollData.specApplied = true rollData.specApplied = true
rollData.executionTotal += 2 rollData.executionTotal += 2
rollData.preservationTotal += 2 rollData.preservationTotal += 2

View File

@ -7,7 +7,7 @@ export class EcrymeConfrontStartDialog extends Dialog {
static async create(actor, rollData) { static async create(actor, rollData) {
let options = { classes: ["fvtt-ecryme ecryme-confront-dialog"], width: 540, height: 'fit-content', 'z-index': 99999 } let options = { classes: ["fvtt-ecryme ecryme-confront-dialog"], width: 540, height: 'fit-content', 'z-index': 99999 }
let html = await renderTemplate('systems/fvtt-ecryme/templates/dialogs/confront-start-dialog.hbs', rollData); let html = await foundry.applications.handlebars.renderTemplate('systems/fvtt-ecryme/templates/dialogs/confront-start-dialog.hbs', rollData);
return new EcrymeConfrontStartDialog(actor, rollData, html, options); return new EcrymeConfrontStartDialog(actor, rollData, html, options);
} }

View File

@ -6,7 +6,7 @@ export class EcrymeRollDialog extends Dialog {
static async create(actor, rollData) { static async create(actor, rollData) {
let options = { classes: ["ecryme-roll-dialog"], width: 540, height: 'fit-content', 'z-index': 99999 } let options = { classes: ["ecryme-roll-dialog"], width: 540, height: 'fit-content', 'z-index': 99999 }
let html = await renderTemplate('systems/fvtt-ecryme/templates/dialogs/roll-dialog-generic.hbs', rollData); let html = await foundry.applications.handlebars.renderTemplate('systems/fvtt-ecryme/templates/dialogs/roll-dialog-generic.hbs', rollData);
return new EcrymeRollDialog(actor, rollData, html, options); return new EcrymeRollDialog(actor, rollData, html, options);
} }
@ -52,7 +52,6 @@ export class EcrymeRollDialog extends Dialog {
activateListeners(html) { activateListeners(html) {
super.activateListeners(html); super.activateListeners(html);
var dialog = this;
function onLoad() { function onLoad() {
} }
$(function () { onLoad(); }); $(function () { onLoad(); });
@ -75,13 +74,13 @@ export class EcrymeRollDialog extends Dialog {
}) })
html.find('#roll-select-transcendence').change((event) => { html.find('#roll-select-transcendence').change((event) => {
this.rollData.skillTranscendence = Number($('#roll-select-transcendence').val()) this.rollData.skillTranscendence = Number($('#roll-select-transcendence').val())
}) })
html.find('#roll-use-spleen').change((event) => { html.find('#roll-use-spleen').change((event) => {
this.rollData.useSpleen = event.currentTarget.checked this.rollData.useSpleen = event.currentTarget.checked
}) })
html.find('#roll-use-ideal').change((event) => { html.find('#roll-use-ideal').change((event) => {
this.rollData.useIdeal = event.currentTarget.checked this.rollData.useIdeal = event.currentTarget.checked
}) })
} }
} }

View File

@ -38,7 +38,7 @@ Hooks.once("init", async function () {
EcrymeUtility.preloadHandlebarsTemplates(); EcrymeUtility.preloadHandlebarsTemplates();
/* -------------------------------------------- */ /* -------------------------------------------- */
// Set an initiative formula for the system // Set an initiative formula for the system
CONFIG.Combat.initiative = { CONFIG.Combat.initiative = {
formula: "1d6", formula: "1d6",
decimals: 1 decimals: 1
@ -57,18 +57,16 @@ Hooks.once("init", async function () {
/* -------------------------------------------- */ /* -------------------------------------------- */
// Register sheet application classes // Register sheet application classes
Actors.unregisterSheet("core", ActorSheet); foundry.documents.collections.Actors.unregisterSheet("core", foundry.appv1.sheets.ActorSheet);
Actors.registerSheet("fvtt-ecryme", EcrymeActorSheet, { types: ["pc"], makeDefault: true }); foundry.documents.collections.Actors.registerSheet("fvtt-ecryme", EcrymeActorSheet, { types: ["pc"], makeDefault: true });
Actors.registerSheet("fvtt-ecryme", EcrymeActorSheet, { types: ["npc"], makeDefault: true }); foundry.documents.collections.Actors.registerSheet("fvtt-ecryme", EcrymeActorSheet, { types: ["npc"], makeDefault: true });
Actors.registerSheet("fvtt-ecryme", EcrymeAnnencySheet, { types: ["annency"], makeDefault: false }); foundry.documents.collections.Actors.registerSheet("fvtt-ecryme", EcrymeAnnencySheet, { types: ["annency"], makeDefault: false });
Items.unregisterSheet("core", ItemSheet); foundry.documents.collections.Items.unregisterSheet("core", foundry.appv1.sheets.ItemSheet);
Items.registerSheet("fvtt-ecryme", EcrymeItemSheet, { makeDefault: true }); foundry.documents.collections.Items.registerSheet("fvtt-ecryme", EcrymeItemSheet, { makeDefault: true });
EcrymeUtility.init() EcrymeUtility.init()
Babele.get().setSystemTranslationsDir("translated")
}); });
/* -------------------------------------------- */ /* -------------------------------------------- */
@ -91,6 +89,7 @@ async function importDefaultScene() {
await game.scenes.documentClass.create(newDocuments); await game.scenes.documentClass.create(newDocuments);
game.scenes.find(i => i.name == "Landing page 1").activate(); game.scenes.find(i => i.name == "Landing page 1").activate();
} }
} }
/* -------------------------------------------- */ /* -------------------------------------------- */
@ -98,9 +97,6 @@ async function importDefaultScene() {
/* -------------------------------------------- */ /* -------------------------------------------- */
Hooks.once("ready", function () { Hooks.once("ready", function () {
// Load trranslations
Babele.get().setSystemTranslationsDir("translated")
// User warning // User warning
if (!game.user.isGM && game.user.character == undefined) { if (!game.user.isGM && game.user.character == undefined) {
ui.notifications.info("Attention ! Aucun personnage relié au joueur !"); ui.notifications.info("Attention ! Aucun personnage relié au joueur !");
@ -122,6 +118,9 @@ Hooks.once("ready", function () {
EcrymeCharacterSummary.ready(); EcrymeCharacterSummary.ready();
importDefaultScene(); importDefaultScene();
// Load translations
Babele.get().setSystemTranslationsDir("translated")
}) })
@ -138,4 +137,3 @@ Hooks.on("chatMessage", (html, content, msg) => {
} }
return true; return true;
}); });

View File

@ -4,7 +4,7 @@ import { EcrymeUtility } from "../common/ecryme-utility.js";
* Extend the basic ItemSheet with some very simple modifications * Extend the basic ItemSheet with some very simple modifications
* @extends {ItemSheet} * @extends {ItemSheet}
*/ */
export class EcrymeItemSheet extends ItemSheet { export class EcrymeItemSheet extends foundry.appv1.sheets.ItemSheet {
/** @override */ /** @override */
static get defaultOptions() { static get defaultOptions() {
@ -61,15 +61,15 @@ export class EcrymeItemSheet extends ItemSheet {
limited: this.object.limited, limited: this.object.limited,
options: this.options, options: this.options,
owner: this.document.isOwner, owner: this.document.isOwner,
description: await TextEditor.enrichHTML(this.object.system.description, { async: true }), description: await foundry.applications.ux.TextEditor.implementation.enrichHTML(this.object.system.description, { async: true }),
notes: await TextEditor.enrichHTML(this.object.system.notes, { async: true }), notes: await foundry.applications.ux.TextEditor.implementation.enrichHTML(this.object.system.notes, { async: true }),
isGM: game.user.isGM isGM: game.user.isGM
} }
if ( this.object.type == "archetype") { if ( this.object.type == "archetype") {
formData.tarots = EcrymeUtility.getTarots() formData.tarots = EcrymeUtility.getTarots()
} }
this.options.editable = !(this.object.origin == "embeddedItem"); this.options.editable = !(this.object.origin == "embeddedItem");
console.log("ITEM DATA", formData, this); console.log("ITEM DATA", formData, this);
return formData; return formData;
@ -115,7 +115,7 @@ export class EcrymeItemSheet extends ItemSheet {
let levelIndex = Number($(ev.currentTarget).parents(".item").data("level-index")) let levelIndex = Number($(ev.currentTarget).parents(".item").data("level-index"))
let choiceIndex = Number($(ev.currentTarget).parents(".item").data("choice-index")) let choiceIndex = Number($(ev.currentTarget).parents(".item").data("choice-index"))
let featureId = $(ev.currentTarget).parents(".item").data("feature-id") let featureId = $(ev.currentTarget).parents(".item").data("feature-id")
let itemData = this.object.system.levels[levelIndex].choices[choiceIndex].features[featureId] let itemData = this.object.system.levels[levelIndex].choices[choiceIndex].features[featureId]
if (itemData.name != 'None') { if (itemData.name != 'None') {

Binary file not shown.

BIN
packs/equipment/000192.ldb Normal file

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000176 MANIFEST-000205

View File

@ -1,7 +1,7 @@
2025/03/11-22:28:43.689446 7f24c57fa6c0 Recovering log #174 2025/05/01-23:23:34.950257 7f11177fe6c0 Recovering log #203
2025/03/11-22:28:43.742748 7f24c57fa6c0 Delete type=3 #172 2025/05/01-23:23:34.960390 7f11177fe6c0 Delete type=3 #201
2025/03/11-22:28:43.742876 7f24c57fa6c0 Delete type=0 #174 2025/05/01-23:23:34.960497 7f11177fe6c0 Delete type=0 #203
2025/03/11-22:29:05.490854 7f24c4bff6c0 Level-0 table #179: started 2025/05/01-23:27:45.498796 7f11153ff6c0 Level-0 table #208: started
2025/03/11-22:29:05.490876 7f24c4bff6c0 Level-0 table #179: 0 bytes OK 2025/05/01-23:27:45.498850 7f11153ff6c0 Level-0 table #208: 0 bytes OK
2025/03/11-22:29:05.528875 7f24c4bff6c0 Delete type=0 #177 2025/05/01-23:27:45.505411 7f11153ff6c0 Delete type=0 #206
2025/03/11-22:29:05.604302 7f24c4bff6c0 Manual compaction at level-0 from '!folders!1GrTlI1xWvaxdKRI' @ 72057594037927935 : 1 .. '!items!zs7krgXhDRndtqbl' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.518830 7f11153ff6c0 Manual compaction at level-0 from '!folders!1GrTlI1xWvaxdKRI' @ 72057594037927935 : 1 .. '!items!zs7krgXhDRndtqbl' @ 0 : 0; will stop at (end)

View File

@ -1,7 +1,7 @@
2025/03/11-22:17:42.207103 7f24c5ffb6c0 Recovering log #169 2025/05/01-23:18:27.056956 7f1115ffb6c0 Recovering log #199
2025/03/11-22:17:42.229307 7f24c5ffb6c0 Delete type=3 #167 2025/05/01-23:18:27.067437 7f1115ffb6c0 Delete type=3 #197
2025/03/11-22:17:42.229364 7f24c5ffb6c0 Delete type=0 #169 2025/05/01-23:18:27.067539 7f1115ffb6c0 Delete type=0 #199
2025/03/11-22:28:37.828063 7f24c4bff6c0 Level-0 table #175: started 2025/05/01-23:23:12.722068 7f11153ff6c0 Level-0 table #204: started
2025/03/11-22:28:37.828090 7f24c4bff6c0 Level-0 table #175: 0 bytes OK 2025/05/01-23:23:12.722089 7f11153ff6c0 Level-0 table #204: 0 bytes OK
2025/03/11-22:28:37.835412 7f24c4bff6c0 Delete type=0 #173 2025/05/01-23:23:12.728871 7f11153ff6c0 Delete type=0 #202
2025/03/11-22:28:37.855865 7f24c4bff6c0 Manual compaction at level-0 from '!folders!1GrTlI1xWvaxdKRI' @ 72057594037927935 : 1 .. '!items!zs7krgXhDRndtqbl' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.744842 7f11153ff6c0 Manual compaction at level-0 from '!folders!1GrTlI1xWvaxdKRI' @ 72057594037927935 : 1 .. '!items!zs7krgXhDRndtqbl' @ 0 : 0; will stop at (end)

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
packs/help/000129.ldb Normal file

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000113 MANIFEST-000142

View File

@ -1,8 +1,8 @@
2025/03/11-22:28:43.904749 7f24c6ffd6c0 Recovering log #111 2025/05/01-23:23:35.002627 7f1116ffd6c0 Recovering log #140
2025/03/11-22:28:43.971386 7f24c6ffd6c0 Delete type=3 #109 2025/05/01-23:23:35.013325 7f1116ffd6c0 Delete type=3 #138
2025/03/11-22:28:43.971494 7f24c6ffd6c0 Delete type=0 #111 2025/05/01-23:23:35.013430 7f1116ffd6c0 Delete type=0 #140
2025/03/11-22:29:05.641249 7f24c4bff6c0 Level-0 table #116: started 2025/05/01-23:27:45.532648 7f11153ff6c0 Level-0 table #145: started
2025/03/11-22:29:05.641276 7f24c4bff6c0 Level-0 table #116: 0 bytes OK 2025/05/01-23:27:45.532688 7f11153ff6c0 Level-0 table #145: 0 bytes OK
2025/03/11-22:29:05.674923 7f24c4bff6c0 Delete type=0 #114 2025/05/01-23:27:45.540035 7f11153ff6c0 Delete type=0 #143
2025/03/11-22:29:05.723243 7f24c4bff6c0 Manual compaction at level-0 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.546611 7f11153ff6c0 Manual compaction at level-0 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end)
2025/03/11-22:29:05.762798 7f24c4bff6c0 Manual compaction at level-1 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.546647 7f11153ff6c0 Manual compaction at level-1 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end)

View File

@ -1,8 +1,8 @@
2025/03/11-22:17:42.313432 7f24c57fa6c0 Recovering log #106 2025/05/01-23:18:27.111839 7f1116ffd6c0 Recovering log #136
2025/03/11-22:17:42.340002 7f24c57fa6c0 Delete type=3 #104 2025/05/01-23:18:27.122280 7f1116ffd6c0 Delete type=3 #134
2025/03/11-22:17:42.340070 7f24c57fa6c0 Delete type=0 #106 2025/05/01-23:18:27.122337 7f1116ffd6c0 Delete type=0 #136
2025/03/11-22:28:37.842072 7f24c4bff6c0 Level-0 table #112: started 2025/05/01-23:23:12.768196 7f11153ff6c0 Level-0 table #141: started
2025/03/11-22:28:37.842115 7f24c4bff6c0 Level-0 table #112: 0 bytes OK 2025/05/01-23:23:12.768227 7f11153ff6c0 Level-0 table #141: 0 bytes OK
2025/03/11-22:28:37.848681 7f24c4bff6c0 Delete type=0 #110 2025/05/01-23:23:12.774547 7f11153ff6c0 Delete type=0 #139
2025/03/11-22:28:37.855911 7f24c4bff6c0 Manual compaction at level-0 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.774689 7f11153ff6c0 Manual compaction at level-0 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end)
2025/03/11-22:28:37.855943 7f24c4bff6c0 Manual compaction at level-1 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.774707 7f11153ff6c0 Manual compaction at level-1 from '!journal!wooTFYjEwh83FwgT' @ 72057594037927935 : 1 .. '!journal.pages!wooTFYjEwh83FwgT.xhc7hqoL8kdW6lrD' @ 0 : 0; will stop at (end)

Binary file not shown.

BIN
packs/help/MANIFEST-000142 Normal file

Binary file not shown.

Binary file not shown.

BIN
packs/maneuvers/000192.ldb Normal file

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000176 MANIFEST-000205

View File

@ -1,7 +1,7 @@
2025/03/11-22:28:43.852356 7f24c67fc6c0 Recovering log #174 2025/05/01-23:23:34.989243 7f11177fe6c0 Recovering log #203
2025/03/11-22:28:43.902310 7f24c67fc6c0 Delete type=3 #172 2025/05/01-23:23:34.999290 7f11177fe6c0 Delete type=3 #201
2025/03/11-22:28:43.902433 7f24c67fc6c0 Delete type=0 #174 2025/05/01-23:23:34.999338 7f11177fe6c0 Delete type=0 #203
2025/03/11-22:29:05.604411 7f24c4bff6c0 Level-0 table #179: started 2025/05/01-23:27:45.505528 7f11153ff6c0 Level-0 table #208: started
2025/03/11-22:29:05.604444 7f24c4bff6c0 Level-0 table #179: 0 bytes OK 2025/05/01-23:27:45.505551 7f11153ff6c0 Level-0 table #208: 0 bytes OK
2025/03/11-22:29:05.641128 7f24c4bff6c0 Delete type=0 #177 2025/05/01-23:27:45.512071 7f11153ff6c0 Delete type=0 #206
2025/03/11-22:29:05.723220 7f24c4bff6c0 Manual compaction at level-0 from '!items!13IYF6BPUTivFZzB' @ 72057594037927935 : 1 .. '!items!oSutlbe9wyBZccmf' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.518845 7f11153ff6c0 Manual compaction at level-0 from '!items!13IYF6BPUTivFZzB' @ 72057594037927935 : 1 .. '!items!oSutlbe9wyBZccmf' @ 0 : 0; will stop at (end)

View File

@ -1,7 +1,7 @@
2025/03/11-22:17:42.287558 7f24c6ffd6c0 Recovering log #169 2025/05/01-23:18:27.099266 7f1115ffb6c0 Recovering log #199
2025/03/11-22:17:42.309970 7f24c6ffd6c0 Delete type=3 #167 2025/05/01-23:18:27.109501 7f1115ffb6c0 Delete type=3 #197
2025/03/11-22:17:42.310079 7f24c6ffd6c0 Delete type=0 #169 2025/05/01-23:18:27.109566 7f1115ffb6c0 Delete type=0 #199
2025/03/11-22:28:37.821422 7f24c4bff6c0 Level-0 table #175: started 2025/05/01-23:23:12.745080 7f11153ff6c0 Level-0 table #204: started
2025/03/11-22:28:37.821461 7f24c4bff6c0 Level-0 table #175: 0 bytes OK 2025/05/01-23:23:12.745126 7f11153ff6c0 Level-0 table #204: 0 bytes OK
2025/03/11-22:28:37.827638 7f24c4bff6c0 Delete type=0 #173 2025/05/01-23:23:12.751818 7f11153ff6c0 Delete type=0 #202
2025/03/11-22:28:37.827871 7f24c4bff6c0 Manual compaction at level-0 from '!items!13IYF6BPUTivFZzB' @ 72057594037927935 : 1 .. '!items!oSutlbe9wyBZccmf' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.774663 7f11153ff6c0 Manual compaction at level-0 from '!items!13IYF6BPUTivFZzB' @ 72057594037927935 : 1 .. '!items!oSutlbe9wyBZccmf' @ 0 : 0; will stop at (end)

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
packs/scenes/000090.ldb Normal file

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000060 MANIFEST-000091

View File

@ -1,8 +1,8 @@
2025/03/11-22:28:43.794986 7f24c6ffd6c0 Recovering log #58 2025/05/01-23:23:34.977246 7f1116ffd6c0 Recovering log #88
2025/03/11-22:28:43.848806 7f24c6ffd6c0 Delete type=3 #56 2025/05/01-23:23:34.986582 7f1116ffd6c0 Delete type=3 #86
2025/03/11-22:28:43.848927 7f24c6ffd6c0 Delete type=0 #58 2025/05/01-23:23:34.986642 7f1116ffd6c0 Delete type=0 #88
2025/03/11-22:29:05.569282 7f24c4bff6c0 Level-0 table #63: started 2025/05/01-23:27:45.512228 7f11153ff6c0 Level-0 table #94: started
2025/03/11-22:29:05.569313 7f24c4bff6c0 Level-0 table #63: 0 bytes OK 2025/05/01-23:27:45.512262 7f11153ff6c0 Level-0 table #94: 0 bytes OK
2025/03/11-22:29:05.604065 7f24c4bff6c0 Delete type=0 #61 2025/05/01-23:27:45.518665 7f11153ff6c0 Delete type=0 #92
2025/03/11-22:29:05.604324 7f24c4bff6c0 Manual compaction at level-0 from '!scenes!YYBr138LR7ntGFdo' @ 72057594037927935 : 1 .. '!scenes!wJJTdzEVyJpkUXaM' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.518856 7f11153ff6c0 Manual compaction at level-0 from '!scenes!DDibQQLAvyIq9y09' @ 72057594037927935 : 1 .. '!scenes!zvY1RwBhTfwdZIBa' @ 0 : 0; will stop at (end)
2025/03/11-22:29:05.675098 7f24c4bff6c0 Manual compaction at level-1 from '!scenes!YYBr138LR7ntGFdo' @ 72057594037927935 : 1 .. '!scenes!wJJTdzEVyJpkUXaM' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.518892 7f11153ff6c0 Manual compaction at level-1 from '!scenes!DDibQQLAvyIq9y09' @ 72057594037927935 : 1 .. '!scenes!zvY1RwBhTfwdZIBa' @ 0 : 0; will stop at (end)

View File

@ -1,8 +1,15 @@
2025/03/11-22:17:42.261222 7f24c57fa6c0 Recovering log #53 2025/05/01-23:18:27.084819 7f1116ffd6c0 Recovering log #82
2025/03/11-22:17:42.284333 7f24c57fa6c0 Delete type=3 #51 2025/05/01-23:18:27.095491 7f1116ffd6c0 Delete type=3 #80
2025/03/11-22:17:42.284459 7f24c57fa6c0 Delete type=0 #53 2025/05/01-23:18:27.095539 7f1116ffd6c0 Delete type=0 #82
2025/03/11-22:28:37.807470 7f24c4bff6c0 Level-0 table #59: started 2025/05/01-23:23:12.735355 7f11153ff6c0 Level-0 table #89: started
2025/03/11-22:28:37.807537 7f24c4bff6c0 Level-0 table #59: 0 bytes OK 2025/05/01-23:23:12.738432 7f11153ff6c0 Level-0 table #89: 1551 bytes OK
2025/03/11-22:28:37.814273 7f24c4bff6c0 Delete type=0 #57 2025/05/01-23:23:12.744606 7f11153ff6c0 Delete type=0 #87
2025/03/11-22:28:37.827846 7f24c4bff6c0 Manual compaction at level-0 from '!scenes!YYBr138LR7ntGFdo' @ 72057594037927935 : 1 .. '!scenes!wJJTdzEVyJpkUXaM' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.744906 7f11153ff6c0 Manual compaction at level-0 from '!scenes!DDibQQLAvyIq9y09' @ 72057594037927935 : 1 .. '!scenes!zvY1RwBhTfwdZIBa' @ 0 : 0; will stop at (end)
2025/03/11-22:28:37.828046 7f24c4bff6c0 Manual compaction at level-1 from '!scenes!YYBr138LR7ntGFdo' @ 72057594037927935 : 1 .. '!scenes!wJJTdzEVyJpkUXaM' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.751899 7f11153ff6c0 Manual compaction at level-1 from '!scenes!DDibQQLAvyIq9y09' @ 72057594037927935 : 1 .. '!scenes!zvY1RwBhTfwdZIBa' @ 0 : 0; will stop at '!scenes!zvY1RwBhTfwdZIBa' @ 18 : 1
2025/05/01-23:23:12.751905 7f11153ff6c0 Compacting 1@1 + 1@2 files
2025/05/01-23:23:12.755259 7f11153ff6c0 Generated table #90@1: 2 keys, 1586 bytes
2025/05/01-23:23:12.755289 7f11153ff6c0 Compacted 1@1 + 1@2 files => 1586 bytes
2025/05/01-23:23:12.761436 7f11153ff6c0 compacted to: files[ 0 0 1 0 0 0 0 ]
2025/05/01-23:23:12.761603 7f11153ff6c0 Delete type=2 #85
2025/05/01-23:23:12.761813 7f11153ff6c0 Delete type=2 #89
2025/05/01-23:23:12.774673 7f11153ff6c0 Manual compaction at level-1 from '!scenes!zvY1RwBhTfwdZIBa' @ 18 : 1 .. '!scenes!zvY1RwBhTfwdZIBa' @ 0 : 0; will stop at (end)

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000176 MANIFEST-000205

View File

@ -1,7 +1,7 @@
2025/03/11-22:28:43.632057 7f24c5ffb6c0 Recovering log #174 2025/05/01-23:23:34.938221 7f1116ffd6c0 Recovering log #203
2025/03/11-22:28:43.687014 7f24c5ffb6c0 Delete type=3 #172 2025/05/01-23:23:34.947805 7f1116ffd6c0 Delete type=3 #201
2025/03/11-22:28:43.687139 7f24c5ffb6c0 Delete type=0 #174 2025/05/01-23:23:34.947853 7f1116ffd6c0 Delete type=0 #203
2025/03/11-22:29:05.529067 7f24c4bff6c0 Level-0 table #179: started 2025/05/01-23:27:45.491261 7f11153ff6c0 Level-0 table #208: started
2025/03/11-22:29:05.529094 7f24c4bff6c0 Level-0 table #179: 0 bytes OK 2025/05/01-23:27:45.491305 7f11153ff6c0 Level-0 table #208: 0 bytes OK
2025/03/11-22:29:05.569107 7f24c4bff6c0 Delete type=0 #177 2025/05/01-23:27:45.498558 7f11153ff6c0 Delete type=0 #206
2025/03/11-22:29:05.604312 7f24c4bff6c0 Manual compaction at level-0 from '!folders!00Hn2nNarlL7b0DR' @ 72057594037927935 : 1 .. '!items!yozTUjNuc2rEGjFK' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.518813 7f11153ff6c0 Manual compaction at level-0 from '!folders!00Hn2nNarlL7b0DR' @ 72057594037927935 : 1 .. '!items!yozTUjNuc2rEGjFK' @ 0 : 0; will stop at (end)

View File

@ -1,7 +1,7 @@
2025/03/11-22:17:42.183744 7f24c67fc6c0 Recovering log #169 2025/05/01-23:18:27.043700 7f11167fc6c0 Recovering log #199
2025/03/11-22:17:42.204063 7f24c67fc6c0 Delete type=3 #167 2025/05/01-23:18:27.054373 7f11167fc6c0 Delete type=3 #197
2025/03/11-22:17:42.204124 7f24c67fc6c0 Delete type=0 #169 2025/05/01-23:18:27.054431 7f11167fc6c0 Delete type=0 #199
2025/03/11-22:28:37.801121 7f24c4bff6c0 Level-0 table #175: started 2025/05/01-23:23:12.728954 7f11153ff6c0 Level-0 table #204: started
2025/03/11-22:28:37.801173 7f24c4bff6c0 Level-0 table #175: 0 bytes OK 2025/05/01-23:23:12.728976 7f11153ff6c0 Level-0 table #204: 0 bytes OK
2025/03/11-22:28:37.807280 7f24c4bff6c0 Delete type=0 #173 2025/05/01-23:23:12.735241 7f11153ff6c0 Delete type=0 #202
2025/03/11-22:28:37.827819 7f24c4bff6c0 Manual compaction at level-0 from '!folders!00Hn2nNarlL7b0DR' @ 72057594037927935 : 1 .. '!items!yozTUjNuc2rEGjFK' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.744865 7f11153ff6c0 Manual compaction at level-0 from '!folders!00Hn2nNarlL7b0DR' @ 72057594037927935 : 1 .. '!items!yozTUjNuc2rEGjFK' @ 0 : 0; will stop at (end)

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
packs/traits/000192.ldb Normal file

Binary file not shown.

View File

@ -1 +1 @@
MANIFEST-000176 MANIFEST-000205

View File

@ -1,7 +1,7 @@
2025/03/11-22:28:43.745519 7f24c67fc6c0 Recovering log #174 2025/05/01-23:23:34.963229 7f1115ffb6c0 Recovering log #203
2025/03/11-22:28:43.792356 7f24c67fc6c0 Delete type=3 #172 2025/05/01-23:23:34.973922 7f1115ffb6c0 Delete type=3 #201
2025/03/11-22:28:43.792465 7f24c67fc6c0 Delete type=0 #174 2025/05/01-23:23:34.974025 7f1115ffb6c0 Delete type=0 #203
2025/03/11-22:29:05.462231 7f24c4bff6c0 Level-0 table #179: started 2025/05/01-23:27:45.518950 7f11153ff6c0 Level-0 table #208: started
2025/03/11-22:29:05.462271 7f24c4bff6c0 Level-0 table #179: 0 bytes OK 2025/05/01-23:27:45.518982 7f11153ff6c0 Level-0 table #208: 0 bytes OK
2025/03/11-22:29:05.490724 7f24c4bff6c0 Delete type=0 #177 2025/05/01-23:27:45.525989 7f11153ff6c0 Delete type=0 #206
2025/03/11-22:29:05.604286 7f24c4bff6c0 Manual compaction at level-0 from '!folders!DiwHbtGAkTYxtshX' @ 72057594037927935 : 1 .. '!items!zgNI2haxhBxBDBdl' @ 0 : 0; will stop at (end) 2025/05/01-23:27:45.546586 7f11153ff6c0 Manual compaction at level-0 from '!folders!DiwHbtGAkTYxtshX' @ 72057594037927935 : 1 .. '!items!zgNI2haxhBxBDBdl' @ 0 : 0; will stop at (end)

View File

@ -1,7 +1,7 @@
2025/03/11-22:17:42.232923 7f24c6ffd6c0 Recovering log #169 2025/05/01-23:18:27.070994 7f11167fc6c0 Recovering log #199
2025/03/11-22:17:42.257730 7f24c6ffd6c0 Delete type=3 #167 2025/05/01-23:18:27.081264 7f11167fc6c0 Delete type=3 #197
2025/03/11-22:17:42.257832 7f24c6ffd6c0 Delete type=0 #169 2025/05/01-23:18:27.081417 7f11167fc6c0 Delete type=0 #199
2025/03/11-22:28:37.814417 7f24c4bff6c0 Level-0 table #175: started 2025/05/01-23:23:12.715522 7f11153ff6c0 Level-0 table #204: started
2025/03/11-22:28:37.814450 7f24c4bff6c0 Level-0 table #175: 0 bytes OK 2025/05/01-23:23:12.715566 7f11153ff6c0 Level-0 table #204: 0 bytes OK
2025/03/11-22:28:37.821238 7f24c4bff6c0 Delete type=0 #173 2025/05/01-23:23:12.721964 7f11153ff6c0 Delete type=0 #202
2025/03/11-22:28:37.827860 7f24c4bff6c0 Manual compaction at level-0 from '!folders!DiwHbtGAkTYxtshX' @ 72057594037927935 : 1 .. '!items!zgNI2haxhBxBDBdl' @ 0 : 0; will stop at (end) 2025/05/01-23:23:12.744818 7f11153ff6c0 Manual compaction at level-0 from '!folders!DiwHbtGAkTYxtshX' @ 72057594037927935 : 1 .. '!items!zgNI2haxhBxBDBdl' @ 0 : 0; will stop at (end)

Binary file not shown.

Binary file not shown.

View File

@ -3,7 +3,7 @@
font-family: "MailartRubberstamp"; font-family: "MailartRubberstamp";
src: url('../fonts/MailartRubberstamp-Regular.woff') format("woff"); src: url('../fonts/MailartRubberstamp-Regular.woff') format("woff");
} }
:root { :root {
/* =================== 1. ACTOR SHEET FONT STYLES =========== */ /* =================== 1. ACTOR SHEET FONT STYLES =========== */
--window-header-title-font-size: 1.3rem; --window-header-title-font-size: 1.3rem;
@ -27,7 +27,7 @@
--actor-label-font-weight: 700; --actor-label-font-weight: 700;
--actor-label-color: rgba(70,67,49,0.76863); --actor-label-color: rgba(70,67,49,0.76863);
/* =================== 2. DEBUGGING HIGHLIGHTERS ============ */ /* =================== 2. DEBUGGING HIGHLIGHTERS ============ */
--debug-background-color-red: rgba(255,0,0,0.32941); --debug-background-color-red: rgba(255,0,0,0.32941);
--debug-background-color-blue: rgba(29,0,255,0.32941); --debug-background-color-blue: rgba(29,0,255,0.32941);
--debug-background-color-green: rgba(84,255,0,0.32941); --debug-background-color-green: rgba(84,255,0,0.32941);
@ -454,9 +454,11 @@ section.sheet-body{padding: 0.25rem 0.5rem;}
/* background: rgb(245,245,240) url("../images/ui/fond4.webp") repeat left top;*/ /* background: rgb(245,245,240) url("../images/ui/fond4.webp") repeat left top;*/
nav.sheet-tabs a,
nav.sheet-tabs .item { nav.sheet-tabs .item {
position: relative; position: relative;
padding: 0 0.25rem; padding: 0 0.25rem;
color: beige;
} }
nav.sheet-tabs .item:after { nav.sheet-tabs .item:after {
@ -697,7 +699,7 @@ ul, li {
/* ======================================== */ /* ======================================== */
.tokenhudext { .tokenhudext {
display: flex; display: flex;
flex: 0 !important; flex: 0 !important;
font-weight: 600; font-weight: 600;
} }
@ -755,7 +757,7 @@ ul, li {
.skill-label { .skill-label {
font-size: 0.7rem; font-size: 0.7rem;
} }
.skill-good-checkbox { .skill-good-checkbox {
max-height: 10px; max-height: 10px;
max-width: 10px; max-width: 10px;
} }
@ -790,7 +792,7 @@ ul, li {
.sidebar-tab .directory-list .entity { .sidebar-tab .directory-list .entity {
border-top: 1px dashed rgba(0,0,0,0.25); border-top: 1px dashed rgba(0,0,0,0.25);
border-bottom: 0 none; border-bottom: 0 none;
padding: 0.25rem 0; padding: 0.25rem 0;
} }
.sidebar-tab .directory-list .entity:hover { .sidebar-tab .directory-list .entity:hover {
@ -804,10 +806,10 @@ ul, li {
text-align: center; text-align: center;
vertical-align: middle; vertical-align: middle;
display: flex; display: flex;
align-items: center; align-items: center;
} }
.chat-message .message-header .flavor-text, .chat-message .message-header .whisper-to { .chat-message .message-header .flavor-text, .chat-message .message-header .whisper-to {
font-size: 0.9rem; font-size: 0.9rem;
} }
.chat-result-text, .chat-result-text,
@ -978,7 +980,7 @@ ul, li {
border-radius: 0px; border-radius: 0px;
} }
#hotbar .bar-controls { #hotbar .bar-controls {
background: rgba(30, 25, 20, 1); background: rgba(30, 25, 20, 1);
border: 1px solid rgba(72, 46, 28, 1); border: 1px solid rgba(72, 46, 28, 1);
} }
@ -1042,7 +1044,7 @@ ul, li {
top: 1px; top: 1px;
position: absolute; position: absolute;
z-index: 1; z-index: 1;
/* Fade in tooltip */ /* Fade in tooltip */
visibility: hidden; visibility: hidden;
opacity: 0; opacity: 0;
@ -1148,7 +1150,7 @@ ul, li {
height: 60px; height: 60px;
} }
.dice-cell { .dice-cell {
padding-left: 12px; padding-left: 12px;
padding-right: 12px; padding-right: 12px;
width: 60px; width: 60px;
@ -1194,8 +1196,8 @@ ul, li {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
margin-left: auto; margin-left: auto;
margin-right: auto; margin-right: auto;
text-align: center; text-align: center;
} }
@ -1312,7 +1314,7 @@ ul, li {
flex-wrap: nowrap; flex-wrap: nowrap;
} }
.item-filler { .item-filler {
flex-grow: 6; flex-grow: 6;
flex-shrink: 7; flex-shrink: 7;
} }
.item-controls-fixed { .item-controls-fixed {
@ -1327,7 +1329,7 @@ ul, li {
font-weight: bold; font-weight: bold;
} }
.flexrow-no-expand { .flexrow-no-expand {
flex-grow: 0; flex-grow: 0;
} }
.flexrow-start { .flexrow-start {
justify-content: flex-start; justify-content: flex-start;

View File

@ -104,8 +104,8 @@
"license": "LICENSE.txt", "license": "LICENSE.txt",
"manifest": "https://www.uberwald.me/gitea/public/fvtt-ecryme/raw/branch/master/system.json", "manifest": "https://www.uberwald.me/gitea/public/fvtt-ecryme/raw/branch/master/system.json",
"compatibility": { "compatibility": {
"minimum": "12", "minimum": "13",
"verified": "12" "verified": "13"
}, },
"id": "fvtt-ecryme", "id": "fvtt-ecryme",
"primaryTokenAttribute": "secondary.health", "primaryTokenAttribute": "secondary.health",
@ -125,7 +125,7 @@
}, },
"title": "Ecryme, le Jeu de Rôles", "title": "Ecryme, le Jeu de Rôles",
"url": "https://www.uberwald.me/gitea/public/fvtt-ecryme", "url": "https://www.uberwald.me/gitea/public/fvtt-ecryme",
"version": "12.0.2", "version": "13.0.0",
"download": "https://www.uberwald.me/gitea/public/fvtt-ecryme/archive/fvtt-ecryme-v12.0.2.zip", "download": "https://www.uberwald.me/gitea/public/fvtt-ecryme/archive/fvtt-ecryme-v13.0.0.zip",
"background": "systems/fvtt-ecryme/images/assets/ecryme_extract_panel_01.webp" "background": "systems/fvtt-ecryme/images/assets/ecryme_extract_panel_01.webp"
} }

View File

@ -31,26 +31,31 @@
"pnjvalue": 0, "pnjvalue": 0,
"skilllist": { "skilllist": {
"athletics": { "athletics": {
"key": "athletics",
"name": "ECRY.ui.athletics", "name": "ECRY.ui.athletics",
"max": 0, "max": 0,
"value": 0 "value": 0
}, },
"driving": { "driving": {
"key": "driving",
"name": "ECRY.ui.driving", "name": "ECRY.ui.driving",
"max": 0, "max": 0,
"value": 0 "value": 0
}, },
"fencing": { "fencing": {
"key": "fencing",
"name": "ECRY.ui.fencing", "name": "ECRY.ui.fencing",
"max": 0, "max": 0,
"value": 0 "value": 0
}, },
"brawling": { "brawling": {
"key": "brawling",
"name": "ECRY.ui.brawling", "name": "ECRY.ui.brawling",
"max": 0, "max": 0,
"value": 0 "value": 0
}, },
"shooting": { "shooting": {
"key": "shooting",
"name": "ECRY.ui.shooting", "name": "ECRY.ui.shooting",
"max": 0, "max": 0,
"value": 0 "value": 0
@ -62,26 +67,31 @@
"pnjvalue": 0, "pnjvalue": 0,
"skilllist": { "skilllist": {
"anthropomecanology": { "anthropomecanology": {
"key": "anthropomecanology",
"name": "ECRY.ui.anthropomecanology", "name": "ECRY.ui.anthropomecanology",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"ecrymology": { "ecrymology": {
"key": "ecrymology",
"name": "ECRY.ui.ecrymology", "name": "ECRY.ui.ecrymology",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"traumatology": { "traumatology": {
"key": "traumatology",
"name": "ECRY.ui.traumatology", "name": "ECRY.ui.traumatology",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"traversology": { "traversology": {
"key": "traversology",
"name": "ECRY.ui.traversology", "name": "ECRY.ui.traversology",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"urbatechnology": { "urbatechnology": {
"key": "urbatechnology",
"name": "ECRY.ui.urbatechnology", "name": "ECRY.ui.urbatechnology",
"value": 0, "value": 0,
"max": 10 "max": 10
@ -93,26 +103,31 @@
"pnjvalue": 0, "pnjvalue": 0,
"skilllist": { "skilllist": {
"quibbling": { "quibbling": {
"key": "quibbling",
"name": "ECRY.ui.quibbling", "name": "ECRY.ui.quibbling",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"creativity": { "creativity": {
"key": "creativity",
"name": "ECRY.ui.creativity", "name": "ECRY.ui.creativity",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"loquacity": { "loquacity": {
"key": "loquacity",
"name": "ECRY.ui.loquacity", "name": "ECRY.ui.loquacity",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"guile": { "guile": {
"key": "guile",
"name": "ECRY.ui.guile", "name": "ECRY.ui.guile",
"value": 0, "value": 0,
"max": 10 "max": 10
}, },
"performance": { "performance": {
"key": "performance",
"name": "ECRY.ui.performance", "name": "ECRY.ui.performance",
"value": 0, "value": 0,
"max": 10 "max": 10