From b1e27a9597bb3475ceb79b6cb5c9f93a9c1fe717 Mon Sep 17 00:00:00 2001 From: Vincent Vandemeulebrouck Date: Sat, 3 Dec 2022 15:33:16 +0100 Subject: [PATCH 1/5] On ne peut pas tout donner MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Limitation des types d'objets pouvant être donnés à différents acteurs --- module/actor-sheet.js | 10 +++-- module/actor.js | 40 ++++++++++++++--- module/item-sheet.js | 30 ++++++------- module/item.js | 60 ++++++++++++++------------ module/misc.js | 3 +- module/rdd-combat.js | 8 ++-- module/rdd-possession.js | 2 +- module/rdd-sheet-utility.js | 24 +++++++---- module/rdd-utility.js | 7 ++- templates/item/partial-inventaire.html | 8 ++-- 10 files changed, 116 insertions(+), 76 deletions(-) diff --git a/module/actor-sheet.js b/module/actor-sheet.js index 075c6d22..8dc97a16 100644 --- a/module/actor-sheet.js +++ b/module/actor-sheet.js @@ -132,10 +132,12 @@ export class RdDActorSheet extends ActorSheet { /* -------------------------------------------- */ async _onDropItem(event, dragData) { const destItemId = $(event.target)?.closest('.item').attr('data-item-id') - const dropParams = RdDSheetUtility.prepareItemDropParameters(destItemId, this.actor.id, dragData, this.objetVersConteneur) - const callSuper = await this.actor.processDropItem(dropParams) - if (callSuper) { - await super._onDropItem(event, dragData) + const dropParams = RdDSheetUtility.prepareItemDropParameters(destItemId, this.actor, dragData, this.objetVersConteneur) + if (dropParams){ + const callSuper = await this.actor.processDropItem(dropParams) + if (callSuper) { + await super._onDropItem(event, dragData) + } } } diff --git a/module/actor.js b/module/actor.js index edf43b10..1e7c51bc 100644 --- a/module/actor.js +++ b/module/actor.js @@ -145,7 +145,7 @@ export class RdDActor extends Actor { // Make separate methods for each Actor type (character, npc, etc.) to keep // things organized. if (this.isPersonnage()) this._prepareCharacterData(this) - if (this.isCreature()) this._prepareCreatureData(this) + if (this.isCreatureEntite()) this._prepareCreatureData(this) if (this.isVehicule()) this._prepareVehiculeData(this) this.computeEtatGeneral(); } @@ -193,10 +193,36 @@ export class RdDActor extends Actor { } } + canReceive(item) { + if (this.isCreature()) { + return item.type == 'competencecreature' || RdDItem.isItemInventaire(item); + } + if (this.isEntite()) { + return item.type == 'competencecreature'; + } + if (this.isVehicule()) { + return RdDItem.isItemInventaire(item); + } + if (this.isPersonnage()) { + switch (item.type) { + case 'competencecreature': case 'tarot': + return false; + } + return true; + } + return false; + } + /* -------------------------------------------- */ - isCreature() { + isCreatureEntite() { return this.type == 'creature' || this.type == 'entite'; } + isCreature() { + return this.type == 'creature'; + } + isEntite() { + return this.type == 'entite'; + } /* -------------------------------------------- */ isPersonnage() { return this.type == 'personnage'; @@ -1175,13 +1201,13 @@ export class RdDActor extends Actor { } let result = true; const item = this.getObjet(itemId); - if (item?.isEquipement() && sourceActorId == targetActorId) { + if (item?.isInventaire() && sourceActorId == targetActorId) { // rangement if (srcId != destId && itemId != destId) { // déplacement de l'objet const src = this.getObjet(srcId); const dest = this.getObjet(destId); const cible = this.getContenantOrParent(dest); - const [empilable, message] = item.isEquipementEmpilable(dest); + const [empilable, message] = item.isInventaireEmpilable(dest); if (empilable) { await this.regrouperEquipementsSimilaires(item, dest); result = false; @@ -1359,7 +1385,7 @@ export class RdDActor extends Actor { /* -------------------------------------------- */ computePrixTotalEquipement() { - const valeur = this.items.filter(it => it.isEquipement()) + const valeur = this.items.filter(it => it.isInventaire()) .map(it => it.valeurTotale()) .reduce(Misc.sum(), 0); return valeur; @@ -2995,7 +3021,7 @@ export class RdDActor extends Actor { /* -------------------------------------------- */ getHeureNaissance() { - if (this.isCreature()) { + if (this.isCreatureEntite()) { return 0; } return this.system.heure; @@ -3003,7 +3029,7 @@ export class RdDActor extends Actor { /* -------------------------------------------- */ ajustementAstrologique() { - if (this.isCreature()) { + if (this.isCreatureEntite()) { return 0; } // selon l'heure de naissance... diff --git a/module/item-sheet.js b/module/item-sheet.js index 3ce65a19..802ac9c9 100644 --- a/module/item-sheet.js +++ b/module/item-sheet.js @@ -30,9 +30,7 @@ export class RdDItemSheet extends ItemSheet { /* -------------------------------------------- */ _getHeaderButtons() { let buttons = super._getHeaderButtons(); - // Add "Post to chat" button - // We previously restricted this to GM and editable items only. If you ever find this comment because it broke something: eh, sorry! - if ("cout" in this.item.system && this.item.isVideOuNonConteneur()) { + if (this.item.isInventaire() && this.item.isVideOuNonConteneur()) { buttons.unshift({ class: "vendre", icon: "fas fa-comments-dollar", @@ -73,8 +71,8 @@ export class RdDItemSheet extends ItemSheet { editable: this.isEditable, cssClass: this.isEditable ? "editable" : "locked", isSoins: false, - description: await TextEditor.enrichHTML(this.item.system.description, {async: true}), - descriptionmj: await TextEditor.enrichHTML(this.item.system.descriptionmj, {async: true}) + description: await TextEditor.enrichHTML(this.item.system.description, { async: true }), + descriptionmj: await TextEditor.enrichHTML(this.item.system.descriptionmj, { async: true }) } if (this.actor) { formData.isOwned = true; @@ -97,18 +95,18 @@ export class RdDItemSheet extends ItemSheet { formData.competences = competences.filter(it => RdDItemCompetence.isDraconic(it)); } if (this.item.type == 'recettecuisine') { - formData.ingredients = await TextEditor.enrichHTML(this.object.system.ingredients, {async: true}) + formData.ingredients = await TextEditor.enrichHTML(this.object.system.ingredients, { async: true }) } if (this.item.type == 'extraitpoetique') { - formData.extrait = await TextEditor.enrichHTML(this.object.system.extrait, {async: true}) - formData.texte = await TextEditor.enrichHTML(this.object.system.texte, {async: true}) + formData.extrait = await TextEditor.enrichHTML(this.object.system.extrait, { async: true }) + formData.texte = await TextEditor.enrichHTML(this.object.system.texte, { async: true }) } if (this.item.type == 'recettealchimique') { RdDAlchimie.processManipulation(this.item, this.actor && this.actor.id); - formData.manipulation_update = await TextEditor.enrichHTML(this.object.system.manipulation_update, {async: true}) - formData.utilisation = await TextEditor.enrichHTML(this.object.system.utilisation, {async: true}) - formData.enchantement = await TextEditor.enrichHTML(this.object.system.enchantement, {async: true}) - formData.sureffet = await TextEditor.enrichHTML(this.object.system.sureffet, {async: true}) + formData.manipulation_update = await TextEditor.enrichHTML(this.object.system.manipulation_update, { async: true }) + formData.utilisation = await TextEditor.enrichHTML(this.object.system.utilisation, { async: true }) + formData.enchantement = await TextEditor.enrichHTML(this.object.system.enchantement, { async: true }) + formData.sureffet = await TextEditor.enrichHTML(this.object.system.sureffet, { async: true }) } if (this.item.type == 'gemme') { formData.gemmeTypeList = RdDGemme.getGemmeTypeOptionList(); @@ -256,8 +254,10 @@ export class RdDItemSheet extends ItemSheet { /** @override */ _updateObject(event, formData) { - // Données de bonus de cases ? - formData['system.bonuscase'] = RdDItemSort.buildBonusCaseStringFromFormData(formData.bonusValue, formData.caseValue); + if (this.item.type == 'sort') { + // Données de bonus de cases ? + formData['system.bonuscase'] = RdDItemSort.buildBonusCaseStringFromFormData(formData.bonusValue, formData.caseValue); + } return this.item.update(formData); } @@ -301,7 +301,7 @@ export class RdDItemSheet extends ItemSheet { /* -------------------------------------------- */ async _onDropItem(event, dragData) { if (this.actor) { - const dropParams = RdDSheetUtility.prepareItemDropParameters(this.item.id, this.actor.id, dragData, this.objetVersConteneur); + const dropParams = RdDSheetUtility.prepareItemDropParameters(this.item.id, this.actor, dragData, this.objetVersConteneur); await this.actor.processDropItem(dropParams); await this.render(true); } diff --git a/module/item.js b/module/item.js index fd41209b..7a19f3be 100644 --- a/module/item.js +++ b/module/item.js @@ -1,10 +1,9 @@ import { DialogItemVente } from "./dialog-item-vente.js"; import { Grammar } from "./grammar.js"; -import { Monnaie } from "./item-monnaie.js"; import { RdDHerbes } from "./rdd-herbes.js"; import { RdDUtility } from "./rdd-utility.js"; -const typesObjetsEquipement = [ +const typesObjetsInventaire = [ "arme", "armure", "conteneur", @@ -70,7 +69,11 @@ export class RdDItem extends Item { return defaultItemImg[itemType]; } - static isEquipementFieldEditable(type, field) { + static isItemInventaire(newLocal) { + return typesObjetsInventaire.includes(newLocal.type); + } + + static isFieldInventaireModifiable(type, field) { switch (field) { case 'quantite': if (['conteneur'].includes(type)) { @@ -78,8 +81,8 @@ export class RdDItem extends Item { } break; case 'cout': - if(['monnaie'].includes(type)){ - return game.user.isGM; + if (['monnaie'].includes(type)) { + return game.user.isGM; } break; } @@ -98,12 +101,12 @@ export class RdDItem extends Item { constructor(itemData, context) { if (!itemData.img) { itemData.img = RdDItem.getDefaultImg(itemData.type); - } + } super(itemData, context); - } + } - static getTypesObjetsEquipement() { - return typesObjetsEquipement + static getItemTypesInventaire() { + return typesObjetsInventaire } static getTypesOeuvres() { @@ -113,11 +116,14 @@ export class RdDItem extends Item { isCompetencePersonnage() { return this.type == 'competence' } + isCompetenceCreature() { + return this.type == 'competencecreature' + } isCompetence() { return typesObjetsCompetence.includes(this.type) } - isEquipement() { - return typesObjetsEquipement.includes(this.type) + isInventaire() { + return RdDItem.isItemInventaire(this) } isOeuvre() { return typesObjetsOeuvres.includes(this.type) @@ -136,7 +142,7 @@ export class RdDItem extends Item { } getItemGroup() { - if (this.isEquipement()) return "equipement"; + if (this.isInventaire()) return "equipement"; if (this.isOeuvre()) return "oeuvre"; if (this.isDraconique()) return "draconique"; if (this.isConnaissance()) return "connaissance"; @@ -180,7 +186,7 @@ export class RdDItem extends Item { getEncTotal() { return this.getEnc() * this.getQuantite(); - } + } getEnc() { switch (this.type) { @@ -202,7 +208,7 @@ export class RdDItem extends Item { prepareDerivedData() { super.prepareDerivedData(); - if (this.isEquipement()) { + if (this.isInventaire()) { this.system.encTotal = this.getEncTotal(); if (this.isPotion()) { this.prepareDataPotion() @@ -229,13 +235,13 @@ export class RdDItem extends Item { case 'potion': return this._actionOrWarnQuantiteZero('Boire', warn); case 'livre': return this._actionOrWarnQuantiteZero('Lire', warn); case 'conteneur': return 'Ouvrir'; - case 'herbe': return this.isHerbeAPotion() ? this._actionOrWarnQuantiteZero('Décoction', warn) : undefined; - case 'queue': case 'ombre': return this.system.refoulement>0 ? 'Refouler' : undefined; + case 'herbe': return this.isHerbeAPotion() ? this._actionOrWarnQuantiteZero('Décoction', warn) : undefined; + case 'queue': case 'ombre': return this.system.refoulement > 0 ? 'Refouler' : undefined; } return undefined; } - _actionOrWarnQuantiteZero(actionName, warn){ + _actionOrWarnQuantiteZero(actionName, warn) { if ((this.system.quantite ?? 0) <= 0) { if (warn) { ui.notifications.warn(`Vous n'avez plus de ${this.name}.`); @@ -275,14 +281,14 @@ export class RdDItem extends Item { /* -------------------------------------------- */ // détermine si deux équipements sont similaires: de même type, et avec les même champs hormis la quantité - isEquipementEmpilable(other) { - if (!other || !this.isEquipement()) { + isInventaireEmpilable(other) { + if (!other || !this.isInventaire()) { return [false, undefined]; } if (this.system.quantite == undefined) { return [false, `Impossible de regrouper des ${this.type}, ils ne sont pas empilables`]; - } + } else if (this.type != other.type) { return [false, `Impossible de regrouper des ${this.type} avec des ${other.type}`]; } @@ -309,7 +315,7 @@ export class RdDItem extends Item { ui.notifications.warn(`Votre ${this.name} n'est pas vide, pas possible de le proposer`); return; } - await DialogItemVente.display(this, async (vente) => { + await DialogItemVente.display(this, async (vente) => { vente["properties"] = this.getProprietes(); if (vente.isOwned) { if (vente.quantiteNbLots * vente.tailleLot > vente.quantiteMax) { @@ -318,7 +324,7 @@ export class RdDItem extends Item { } } vente.jsondata = JSON.stringify(vente.item); - + console.log(vente); let html = await renderTemplate('systems/foundryvtt-reve-de-dragon/templates/chat-vente-item.html', vente); ChatMessage.create(RdDUtility.chatDataSetup(html)); @@ -459,7 +465,7 @@ export class RdDItem extends Item { `Fatigue: ${this.system.fatigue}`, `Difficulté: ${this.system.difficulte}` ].concat([ - this.system.cacher_points_de_tache ? [] :`Points de Tâche: ${this.system.points_de_tache}` + this.system.cacher_points_de_tache ? [] : `Points de Tâche: ${this.system.points_de_tache}` ]).concat([ `Points de Tâche atteints: ${this.system.points_de_tache_courant}`] ); @@ -563,10 +569,10 @@ export class RdDItem extends Item { return [`Inconnue`] } let properties = [ - `Malignité: ${this.system.malignite}`, - `Périodicité: ${this.system.periodicite}`, - `Dommages: ${this.system.dommages}` - ] + `Malignité: ${this.system.malignite}`, + `Périodicité: ${this.system.periodicite}`, + `Dommages: ${this.system.dommages}` + ] if (this.system.remedesconnus) { properties.push(`Remedes: ${this.system.remedes}`) } diff --git a/module/misc.js b/module/misc.js index 849c0d52..2aa30278 100644 --- a/module/misc.js +++ b/module/misc.js @@ -42,7 +42,8 @@ export class Misc { } static typeName(type, subType) { - return game.i18n.localize(`${type.toUpperCase()}.Type${Misc.upperFirst(subType)}`); + return subType ? game.i18n.localize(`${type.toUpperCase()}.Type${Misc.upperFirst(subType)}`) + : ''; } /** diff --git a/module/rdd-combat.js b/module/rdd-combat.js index 74dbfb0e..c5579338 100644 --- a/module/rdd-combat.js +++ b/module/rdd-combat.js @@ -246,7 +246,7 @@ export class RdDCombatManager extends Combat { if (actions.length > 0) { return actions; } - if (actor.isCreature()) { + if (actor.isCreatureEntite()) { actions = actions.concat(RdDCombatManager.listActionsCreature(actor.itemTypes['competencecreature'])); } else { // Recupération des items 'arme' @@ -821,7 +821,7 @@ export class RdDCombat { essais: {} }; - if (this.attacker.isCreature()) { + if (this.attacker.isCreatureEntite()) { RdDItemCompetenceCreature.setRollDataCreature(rollData); } else if (arme) { @@ -1079,7 +1079,7 @@ export class RdDCombat { show: {} }; - if (this.defender.isCreature()) { + if (this.defender.isCreatureEntite()) { RdDItemCompetenceCreature.setRollDataCreature(defenderRoll); } @@ -1158,7 +1158,7 @@ export class RdDCombat { show: {} }; - if (this.defender.isCreature()) { + if (this.defender.isCreatureEntite()) { RdDItemCompetenceCreature.setRollDataCreature(rollData); } return rollData; diff --git a/module/rdd-possession.js b/module/rdd-possession.js index 0de88bf0..a0e73204 100644 --- a/module/rdd-possession.js +++ b/module/rdd-possession.js @@ -45,7 +45,7 @@ export class RdDPossession { defender: defender, targetToken: Targets.extractTokenData(target) }; - if (attacker.isCreature()) { + if (attacker.isCreatureEntite()) { RdDItemCompetenceCreature.setRollDataCreature(rollData) } diff --git a/module/rdd-sheet-utility.js b/module/rdd-sheet-utility.js index 15dc98e0..faa6856d 100644 --- a/module/rdd-sheet-utility.js +++ b/module/rdd-sheet-utility.js @@ -19,17 +19,23 @@ export class RdDSheetUtility { return $(event.currentTarget)?.parents(".item"); } - static prepareItemDropParameters(destItemId, actorId, dragData, objetVersConteneur) { + static prepareItemDropParameters(destItemId, actor, dragData, objetVersConteneur) { const item = fromUuidSync(dragData.uuid) - return { - destId: destItemId, - targetActorId: actorId, - itemId: item.id, - sourceActorId: item.actor?.id, - srcId: objetVersConteneur[item.id], - onEnleverConteneur: () => { delete objetVersConteneur[item.id]; }, - onAjouterDansConteneur: (itemId, conteneurId) => { objetVersConteneur[itemId] = conteneurId; } + if (actor.canReceive(item)) { + return { + destId: destItemId, + targetActorId: actor.id, + itemId: item.id, + sourceActorId: item.actor?.id, + srcId: objetVersConteneur[item.id], + onEnleverConteneur: () => { delete objetVersConteneur[item.id]; }, + onAjouterDansConteneur: (itemId, conteneurId) => { objetVersConteneur[itemId] = conteneurId; } + } } + else { + ui.notifications.warn(`Impossible de donner ${item.name} à ${actor.name}: ${item.type} / ${actor.type}`); + } + return undefined; } static async splitItem(item, actor, onSplit = () => { }) { diff --git a/module/rdd-utility.js b/module/rdd-utility.js index c747e221..dbb0e9fe 100644 --- a/module/rdd-utility.js +++ b/module/rdd-utility.js @@ -330,7 +330,7 @@ export class RdDUtility { ); Handlebars.registerHelper('linkCompendium', (compendium, id, name) => `@Compendium[${compendium}.${id}]{${name}}`); Handlebars.registerHelper('uniteQuantite', (type) => RdDItem.getUniteQuantite(type)); - Handlebars.registerHelper('isEquipementFieldEditable', (type, field) => RdDItem.isEquipementFieldEditable(type, field)); + Handlebars.registerHelper('isFieldInventaireModifiable', (type, field) => RdDItem.isFieldInventaireModifiable(type, field)); Handlebars.registerHelper('getFrequenceRarete', (rarete, field) => Environnement.getFrequenceRarete(rarete, field)); Handlebars.registerHelper('either', (a, b) => a ?? b); return loadTemplates(templatePaths); @@ -344,7 +344,7 @@ export class RdDUtility { /* -------------------------------------------- */ static async selectObjetType(actorSheet) { - let typeObjets = RdDItem.getTypesObjetsEquipement(); + let typeObjets = RdDItem.getItemTypesInventaire(); let options = `Selectionnez le type d'équipement + {{#unless (isFieldInventaireModifiable type 'qualite')}}disabled{{/unless}}/>
+ {{#unless (isFieldInventaireModifiable type 'encombrement')}}disabled{{/unless}}/>
+ {{#unless (isFieldInventaireModifiable type 'quantite')}}disabled{{/unless}}/>
+ {{#unless (isFieldInventaireModifiable type 'cout')}}disabled{{/unless}}/>
From d998a4cb082705cee4f3655fd64609361cc35a8c Mon Sep 17 00:00:00 2001 From: Vincent Vandemeulebrouck Date: Sat, 3 Dec 2022 18:29:29 +0100 Subject: [PATCH 2/5] =?UTF-8?q?Am=C3=A9lioration=20Classes=20ItemSheet=20s?= =?UTF-8?q?=C3=A9par=C3=A9es?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Meilleur support des feuilles ItemSheet séparés Séparation de la feuille Conteneurs Mise en commun de la logique drag&drop --- module/environnement.js | 28 +------ module/item-conteneur-sheet.js | 58 ++++++++++++++ module/item-herbe-sheet.js | 26 +----- module/item-ingredient-sheet.js | 25 +----- module/item-rencontre-sheet.js | 31 +------- module/item-sheet.js | 115 ++++++++++++--------------- module/item-signedraconique-sheet.js | 36 ++------- module/rdd-main.js | 38 ++++----- module/rdd-utility.js | 2 - styles/simple.css | 5 +- templates/item-herbe-sheet.html | 2 +- 11 files changed, 148 insertions(+), 218 deletions(-) create mode 100644 module/item-conteneur-sheet.js diff --git a/module/environnement.js b/module/environnement.js index 508f4da7..8f14e477 100644 --- a/module/environnement.js +++ b/module/environnement.js @@ -126,12 +126,8 @@ export class Environnement { export class EnvironmentSheetHelper { - static defaultOptions(defaultOptions, type) { + static defaultOptions(defaultOptions) { return mergeObject(defaultOptions, { - classes: ["rdd", "sheet", "item"], - template: `systems/foundryvtt-reve-de-dragon/templates/item-${type}-sheet.html`, - width: 500, - height: 600, tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "informations" }] }); } @@ -152,18 +148,9 @@ export class EnvironmentSheetHelper { /* -------------------------------------------- */ static async getData(sheet, formData) { - const autresMilieux = await game.system.rdd.environnement.autresMilieux(sheet.item); - mergeObject(formData, { - title: formData.name, - isGM: game.user.isGM, - owner: sheet.actor?.isOwner, - isOwned: sheet.actor ? true : false, - actorId: sheet.actor?.id, - editable: sheet.isEditable, - cssClass: sheet.isEditable ? "editable" : "locked", - milieux: autresMilieux + return mergeObject(formData, { + milieux: await game.system.rdd.environnement.autresMilieux(sheet.item) }); - return formData; } static activateListeners(sheet, html) { @@ -238,13 +225,4 @@ export class EnvironmentSheetHelper { return $(event.currentTarget)?.parents("div.environnement-milieu").data("milieu"); } - static template(itemType) { - /* -------------------------------------------- */ - return `systems/foundryvtt-reve-de-dragon/templates/item-${itemType}-sheet.html`; - } - - static title(item) { - return Misc.typeName('Item', item.type) + ': ' + item.name; - } - } \ No newline at end of file diff --git a/module/item-conteneur-sheet.js b/module/item-conteneur-sheet.js new file mode 100644 index 00000000..6ab5205d --- /dev/null +++ b/module/item-conteneur-sheet.js @@ -0,0 +1,58 @@ +import { RdDItemSheet } from "./item-sheet.js"; +import { RdDSheetUtility } from "./rdd-sheet-utility.js"; +import { RdDUtility } from "./rdd-utility.js"; + +export class RdDConteneurItemSheet extends RdDItemSheet { + + static get ITEM_TYPE() { return "conteneur" }; + + async getData() { + const formData = await super.getData(); + if (this.actor) { + this.prepareConteneurData(formData); + } + } + + activateListeners(html) { + super.activateListeners(html); + if (!this.options.editable) return; + + html.find('.conteneur-name a').click(async event => { + RdDUtility.toggleAfficheContenu(RdDSheetUtility.getItemId(event)); + this.render(true); + }); + } + + /* -------------------------------------------- */ + prepareConteneurData(formData) { + RdDUtility.filterEquipementParType(formData, this.actor.itemTypes); + + this.objetVersConteneur = RdDUtility.buildArbreDeConteneurs(formData.conteneurs, formData.objets); + formData.subItems = formData.conteneurs.find(it => it._id == this.item.id)?.subItems; + } + + async _onDragStart(event) { + console.log("_onDragStart", event); + if (event.target.classList.contains("entity-link")) return; + + const itemId = event.srcElement?.attributes["data-item-id"].value; + const item = this.actor.items.get(itemId); + // Create drag data + const dragData = { + actorId: this.actor.id, + type: "Item", + data: item.system + }; + + event.dataTransfer.setData("text/plain", JSON.stringify(dragData)); + } + + async _onDropItem(event, dragData) { + if (this.actor) { + const dropParams = RdDSheetUtility.prepareItemDropParameters(this.item.id, this.actor, dragData, this.objetVersConteneur); + await this.actor.processDropItem(dropParams); + await this.render(true); + } + } + +} diff --git a/module/item-herbe-sheet.js b/module/item-herbe-sheet.js index 616025a9..940eec58 100644 --- a/module/item-herbe-sheet.js +++ b/module/item-herbe-sheet.js @@ -1,26 +1,12 @@ -import { SYSTEM_RDD } from "./constants.js"; import { EnvironmentSheetHelper } from "./environnement.js"; import { RdDItemSheet } from "./item-sheet.js"; -import { Misc } from "./misc.js"; - -const ITEM_TYPE = 'herbe'; export class RdDHerbeItemSheet extends RdDItemSheet { - static register() { - Items.registerSheet(SYSTEM_RDD, RdDHerbeItemSheet, { - label: Misc.typeName('Item', ITEM_TYPE), - types: [ITEM_TYPE], - makeDefault: true - }); - } + static get ITEM_TYPE() { return "herbe" }; static get defaultOptions() { - return EnvironmentSheetHelper.defaultOptions(super.defaultOptions, ITEM_TYPE); - } - - _getHeaderButtons() { - return EnvironmentSheetHelper.getHeaderButtons(this, super._getHeaderButtons()); + return EnvironmentSheetHelper.defaultOptions(super.defaultOptions); } setPosition(options = {}) { @@ -36,12 +22,4 @@ export class RdDHerbeItemSheet extends RdDItemSheet { super.activateListeners(html); EnvironmentSheetHelper.activateListeners(this, html); } - - get template() { - return EnvironmentSheetHelper.template(this.item.type); - } - - get title() { - return EnvironmentSheetHelper.title(this.item); - } } diff --git a/module/item-ingredient-sheet.js b/module/item-ingredient-sheet.js index 6f5cd5f6..fe78bc68 100644 --- a/module/item-ingredient-sheet.js +++ b/module/item-ingredient-sheet.js @@ -1,25 +1,12 @@ -import { SYSTEM_RDD } from "./constants.js"; import { EnvironmentSheetHelper } from "./environnement.js"; import { RdDItemSheet } from "./item-sheet.js"; -import { Misc } from "./misc.js"; -const ITEM_TYPE = 'ingredient'; export class RdDIngredientItemSheet extends RdDItemSheet { - static register() { - Items.registerSheet(SYSTEM_RDD, RdDIngredientItemSheet, { - label: Misc.typeName('Item', ITEM_TYPE), - types: [ITEM_TYPE], - makeDefault: true - }); - } + static get ITEM_TYPE() { return "ingredient" }; static get defaultOptions() { - return EnvironmentSheetHelper.defaultOptions(super.defaultOptions, ITEM_TYPE); - } - - _getHeaderButtons() { - return EnvironmentSheetHelper.getHeaderButtons(this, super._getHeaderButtons()); + return EnvironmentSheetHelper.defaultOptions(super.defaultOptions); } setPosition(options = {}) { @@ -35,12 +22,4 @@ export class RdDIngredientItemSheet extends RdDItemSheet { super.activateListeners(html); EnvironmentSheetHelper.activateListeners(this, html); } - - get template() { - return EnvironmentSheetHelper.template(this.item.type); - } - - get title() { - return EnvironmentSheetHelper.title(this.item); - } } diff --git a/module/item-rencontre-sheet.js b/module/item-rencontre-sheet.js index baaf5d8d..d4b74a98 100644 --- a/module/item-rencontre-sheet.js +++ b/module/item-rencontre-sheet.js @@ -1,29 +1,16 @@ import { RdDRencontre } from "./item-rencontre.js"; +import { RdDItemSheet } from "./item-sheet.js"; -/** - * Item sheet pour configurer les rencontres - * @extends {ItemSheet} - */ -export class RdDRencontreItemSheet extends ItemSheet { +export class RdDRencontreItemSheet extends RdDItemSheet { + + static get ITEM_TYPE() { return "rencontre" }; - /** @override */ static get defaultOptions() { return mergeObject(super.defaultOptions, { - classes: ["rdd", "sheet", "item"], - template: "systems/foundryvtt-reve-de-dragon/templates/item-rencontre-sheet.html", - width: 500, - height: 500, tabs: [{ navSelector: ".sheet-tabs", contentSelector: ".sheet-body", initial: "carac" }] }); } - /* -------------------------------------------- */ - _getHeaderButtons() { - let buttons = super._getHeaderButtons(); - buttons.unshift({ class: "post", icon: "fas fa-comment", onclick: ev => this.item.postItem() }); - return buttons; - } - /* -------------------------------------------- */ /** @override */ setPosition(options = {}) { @@ -34,7 +21,6 @@ export class RdDRencontreItemSheet extends ItemSheet { return position; } - /* -------------------------------------------- */ async getData() { const formData = duplicate(this.item); @@ -96,13 +82,4 @@ export class RdDRencontreItemSheet extends ItemSheet { updates[key] = liste; this.item.update(updates); } - - get template() { - /* -------------------------------------------- */ - return `systems/foundryvtt-reve-de-dragon/templates/item-rencontre-sheet.html`; - } - - get title() { - return `Rencontre: ${this.object.name}`; - } } diff --git a/module/item-sheet.js b/module/item-sheet.js index 802ac9c9..2e6c91c2 100644 --- a/module/item-sheet.js +++ b/module/item-sheet.js @@ -9,23 +9,49 @@ import { ReglesOptionelles } from "./settings/regles-optionelles.js"; import { SYSTEM_RDD } from "./constants.js"; import { RdDSheetUtility } from "./rdd-sheet-utility.js"; import { SystemCompendiums } from "./settings/system-compendiums.js"; +import { Misc } from "./misc.js"; /** - * Extend the basic ItemSheet with some very simple modifications - * @extends {ItemSheet} + * Extend the basic ItemSheet for RdD specific items */ export class RdDItemSheet extends ItemSheet { + static get ITEM_TYPE() { + return undefined + } + + static defaultTemplate(type) { + return type ? + `systems/foundryvtt-reve-de-dragon/templates/item-${type}-sheet.html` : + "systems/foundryvtt-reve-de-dragon/templates/item-sheet.html"; + } + + static register(sheetClass) { + Items.registerSheet(SYSTEM_RDD, sheetClass, { + label: Misc.typeName('Item', sheetClass.ITEM_TYPE), + types: [sheetClass.ITEM_TYPE], + makeDefault: true + }) + } + /** @override */ static get defaultOptions() { return mergeObject(super.defaultOptions, { classes: [SYSTEM_RDD, "sheet", "item"], - template: "systems/foundryvtt-reve-de-dragon/templates/item-sheet.html", + template: RdDItemSheet.defaultTemplate(RdDItemSheet.ITEM_TYPE), width: 550, height: 550 }); } + /* -------------------------------------------- */ + get template() { + return RdDItemSheet.defaultTemplate(this.item.type); + } + + get title() { + return `${Misc.typeName('Item', this.item.type)}: ${this.item.name}`; + } /* -------------------------------------------- */ _getHeaderButtons() { @@ -67,6 +93,7 @@ export class RdDItemSheet extends ItemSheet { system: this.item.system, isGM: game.user.isGM, actorId: this.actor?.id, + isOwned: this.actor ? true : false, owner: this.item.isOwner, editable: this.isEditable, cssClass: this.isEditable ? "editable" : "locked", @@ -74,12 +101,6 @@ export class RdDItemSheet extends ItemSheet { description: await TextEditor.enrichHTML(this.item.system.description, { async: true }), descriptionmj: await TextEditor.enrichHTML(this.item.system.descriptionmj, { async: true }) } - if (this.actor) { - formData.isOwned = true; - if (this.item.type == 'conteneur') { - this.prepareConteneurData(formData); - } - } const competences = await SystemCompendiums.getCompetences(this.actor?.type); formData.categorieCompetences = RdDItemCompetence.getCategorieCompetences() @@ -131,25 +152,10 @@ export class RdDItemSheet extends ItemSheet { return formData; } - /* -------------------------------------------- */ - prepareConteneurData(formData) { - RdDUtility.filterEquipementParType(formData, this.actor.itemTypes); - - this.objetVersConteneur = RdDUtility.buildArbreDeConteneurs(formData.conteneurs, formData.objets); - formData.subItems = formData.conteneurs.find(it => it._id == this.item.id)?.subItems; - - } - /* -------------------------------------------- */ /** @override */ activateListeners(html) { super.activateListeners(html); - - if (this.item.type == 'conteneur') { - this.form.ondragstart = (event) => this._onDragStart(event); - this.form.ondrop = (event) => this._onDrop(event); - } - let itemSheetDialog = this; HtmlUtility._showControlWhen($(".item-cout"), ReglesOptionelles.isUsing('afficher-prix-joueurs') || game.user.isGM || !this.item.isOwned); @@ -157,6 +163,9 @@ export class RdDItemSheet extends ItemSheet { // Everything below here is only needed if the sheet is editable if (!this.options.editable) return; + this.form.ondragstart = (event) => this._onDragStart(event); + this.form.ondrop = (event) => this._onDrop(event); + // Select competence categorie html.find(".categorie").change(event => this._onSelectCategorie(event)); @@ -227,10 +236,6 @@ export class RdDItemSheet extends ItemSheet { const item = RdDSheetUtility.getItem(event, this.actor); this.actor.actionItem(item, async () => itemSheetDialog.render(true)); }); - html.find('.conteneur-name a').click(async event => { - RdDUtility.toggleAfficheContenu(RdDSheetUtility.getItemId(event)); - this.render(true); - }); } /* -------------------------------------------- */ @@ -245,13 +250,6 @@ export class RdDItemSheet extends ItemSheet { } /* -------------------------------------------- */ - get template() { - let type = this.item.type - return `systems/foundryvtt-reve-de-dragon/templates/item-${type}-sheet.html`; - } - - /* -------------------------------------------- */ - /** @override */ _updateObject(event, formData) { if (this.item.type == 'sort') { @@ -262,50 +260,41 @@ export class RdDItemSheet extends ItemSheet { return this.item.update(formData); } + /* -------------------------------------------- */ async _onDragStart(event) { - console.log("_onDragStart", event); - if (event.target.classList.contains("entity-link")) return; - - const itemId = event.srcElement?.attributes["data-item-id"].value; - const item = this.actor.items.get(itemId); - // Create drag data - const dragData = { - actorId: this.actor.id, - type: "Item", - data: item.system - }; - - event.dataTransfer.setData("text/plain", JSON.stringify(dragData)); } async _onDrop(event) { // Try to extract the dragData - let dragData; - try { - dragData = JSON.parse(event.dataTransfer.getData('text/plain')); - } catch (err) { - return false; - } - + let dragData = RdDItemSheet.$extractDragData(event); + if (!dragData) return false; const allowed = Hooks.call("dropActorSheetData", this.actor, this, dragData); - if (allowed === false) return; + if (allowed === false) return false; // Handle different dragData types switch (dragData.type) { case "Item": return this._onDropItem(event, dragData); + case "Actor": + return this._onDropActor(event, dragData); } return super._onDrop(event); } - /* -------------------------------------------- */ - async _onDropItem(event, dragData) { - if (this.actor) { - const dropParams = RdDSheetUtility.prepareItemDropParameters(this.item.id, this.actor, dragData, this.objetVersConteneur); - await this.actor.processDropItem(dropParams); - await this.render(true); - } + static $extractDragData(event) { + try { + const eventData = event?.dataTransfer?.getData('text/plain'); + if (eventData) { + return JSON.parse(eventData); + } + } catch (err) { } + return undefined; } + async _onDropItem(event, dragData) { + } + + async _onDropActor(event, dragData) { + } } diff --git a/module/item-signedraconique-sheet.js b/module/item-signedraconique-sheet.js index f3c33fdd..823d459c 100644 --- a/module/item-signedraconique-sheet.js +++ b/module/item-signedraconique-sheet.js @@ -1,29 +1,14 @@ -import { SYSTEM_RDD } from "./constants.js"; +import { RdDItemSheet } from "./item-sheet.js"; import { RdDItemSigneDraconique } from "./item-signedraconique.js"; import { TMRUtility } from "./tmr-utility.js"; /** * Item sheet pour signes draconiques - * @extends {ItemSheet} + * @extends {RdDItemSheet} */ -export class RdDSigneDraconiqueItemSheet extends ItemSheet { +export class RdDSigneDraconiqueItemSheet extends RdDItemSheet { - /** @override */ - static get defaultOptions() { - return mergeObject(super.defaultOptions, { - classes: [SYSTEM_RDD, "sheet", "item"], - template: "systems/foundryvtt-reve-de-dragon/templates/item-signedraconique-sheet.html", - width: 550, - height: 550 - }); - } - - /* -------------------------------------------- */ - _getHeaderButtons() { - let buttons = super._getHeaderButtons(); - buttons.unshift({ class: "post", icon: "fas fa-comment", onclick: ev => this.item.postItem() }); - return buttons; - } + static get ITEM_TYPE() { return "signedraconique" } /* -------------------------------------------- */ /** @override */ @@ -61,12 +46,13 @@ export class RdDSigneDraconiqueItemSheet extends ItemSheet { if (!this.options.editable) return; html.find(".signe-aleatoire").click(event => this.setSigneAleatoire()); - html.find("input.select-tmr").change((event) => this.onSelectTmr(event)); - html.find(".signe-xp-sort").change((event) => this.onValeurXpSort(event.currentTarget.attributes['data-typereussite']?.value, Number(event.currentTarget.value))); + html.find("input.select-tmr").change(event => this.onSelectTmr(event)); + html.find(".signe-xp-sort").change(event => this.onValeurXpSort(event.currentTarget.attributes['data-typereussite']?.value, Number(event.currentTarget.value))); } async setSigneAleatoire() { const newSigne = await RdDItemSigneDraconique.randomSigneDraconique(); + newSigne.name = this.item.name; this.item.update(newSigne); } @@ -88,12 +74,4 @@ export class RdDSigneDraconiqueItemSheet extends ItemSheet { await this.item.update({ 'system.valeur': newValeur }); } - /* -------------------------------------------- */ - get template() { - return `systems/foundryvtt-reve-de-dragon/templates/item-signedraconique-sheet.html`; - } - - get title() { - return `Signe draconique: ${this.object.name}`; - } } diff --git a/module/rdd-main.js b/module/rdd-main.js index f4d5c361..23acc016 100644 --- a/module/rdd-main.js +++ b/module/rdd-main.js @@ -42,6 +42,7 @@ import { TMRRencontres } from "./tmr-rencontres.js"; import { RdDHerbeItemSheet } from "./item-herbe-sheet.js"; import { Environnement } from "./environnement.js"; import { RdDIngredientItemSheet } from "./item-ingredient-sheet.js"; +import { RdDConteneurItemSheet } from "./item-conteneur-sheet.js"; /* -------------------------------------------- */ /* Foundry VTT Initialization */ @@ -163,8 +164,8 @@ Hooks.once("init", async function () { RdDCombat.onSocketMessage(sockmsg); ChatUtility.onSocketMessage(sockmsg); RdDActor.onSocketMessage(sockmsg); - } catch(e) { - console.error('game.socket.on(SYSTEM_SOCKET_ID) Exception: ', sockmsg,' => ', e) + } catch (e) { + console.error('game.socket.on(SYSTEM_SOCKET_ID) Exception: ', sockmsg, ' => ', e) } }); @@ -187,28 +188,23 @@ Hooks.once("init", async function () { Actors.registerSheet(SYSTEM_RDD, RdDActorVehiculeSheet, { types: ["vehicule"], makeDefault: true }); Actors.registerSheet(SYSTEM_RDD, RdDActorEntiteSheet, { types: ["entite"], makeDefault: true }); Items.unregisterSheet("core", ItemSheet); - Items.registerSheet(SYSTEM_RDD, RdDSigneDraconiqueItemSheet, { - label: "Signe draconique", - types: ["signedraconique"], - makeDefault: true - }); - Items.registerSheet(SYSTEM_RDD, RdDRencontreItemSheet, { - label: "Rencontre", - types: ["rencontre"], - makeDefault: true - }); - RdDHerbeItemSheet.register(); - RdDIngredientItemSheet.register(); + + RdDItemSheet.register(RdDSigneDraconiqueItemSheet); + RdDItemSheet.register(RdDRencontreItemSheet); + RdDItemSheet.register(RdDConteneurItemSheet); + RdDItemSheet.register(RdDHerbeItemSheet); + RdDItemSheet.register(RdDIngredientItemSheet); + Items.registerSheet(SYSTEM_RDD, RdDItemSheet, { types: [ "competence", "competencecreature", "recettealchimique", "musique", "chant", "danse", "jeu", "recettecuisine", "oeuvre", - "objet", "arme", "armure", "conteneur", "livre", "potion", "munition", + "objet", "arme", "armure", "livre", "potion", "munition", "monnaie", "nourritureboisson", "gemme", "meditation", "queue", "ombre", "souffle", "tete", "casetmr", "sort", "sortreserve", "nombreastral", "tache", "maladie", "poison", "possession", "tarot", "extraitpoetique" - ], makeDefault: true + ], makeDefault: true }); CONFIG.Combat.documentClass = RdDCombatManager; @@ -247,8 +243,8 @@ function messageDeBienvenue() { /* -------------------------------------------- */ // Register world usage statistics -function registerUsageCount( registerKey ) { - if ( game.user.isGM ) { +function registerUsageCount(registerKey) { + if (game.user.isGM) { game.settings.register("world", "world-key", { name: "Unique world key", scope: "world", @@ -258,9 +254,9 @@ function registerUsageCount( registerKey ) { }); let worldKey = game.settings.get("world", "world-key") - if ( worldKey == undefined || worldKey == "" ) { + if (worldKey == undefined || worldKey == "") { worldKey = randomID(32) - game.settings.set("world", "world-key", worldKey ) + game.settings.set("world", "world-key", worldKey) } let regURL = `https://www.uberwald.me/fvtt_appcount/count.php?name="${registerKey}"&worldKey="${worldKey}"&version="${game.release.generation}.${game.release.build}"&system="${game.system.id}"&systemversion="${game.system.version}"` $.ajax(regURL) @@ -300,7 +296,7 @@ Hooks.once("ready", async function () { } if (Misc.isUniqueConnectedGM()) { messageDeBienvenue(); - registerUsageCount( SYSTEM_RDD ); + registerUsageCount(SYSTEM_RDD); } }); diff --git a/module/rdd-utility.js b/module/rdd-utility.js index dbb0e9fe..fe173ac9 100644 --- a/module/rdd-utility.js +++ b/module/rdd-utility.js @@ -1,5 +1,4 @@ /* Common useful functions shared between objects */ - import { ChatUtility } from "./chat-utility.js"; import { RdDCombat } from "./rdd-combat.js"; import { Misc } from "./misc.js"; @@ -14,7 +13,6 @@ import { RdDPossession } from "./rdd-possession.js"; import { RdDNameGen } from "./rdd-namegen.js"; import { RdDConfirm } from "./rdd-confirm.js"; import { RdDCalendrier } from "./rdd-calendrier.js"; -import { RdDCarac } from "./rdd-carac.js"; import { Environnement } from "./environnement.js"; /* -------------------------------------------- */ diff --git a/styles/simple.css b/styles/simple.css index d20c17f8..052a4257 100644 --- a/styles/simple.css +++ b/styles/simple.css @@ -497,8 +497,7 @@ input:is(.blessure-premiers_soins, .blessure-soins_complets) { } .foundryvtt-reve-de-dragon .sheet-body, -.foundryvtt-reve-de-dragon .sheet-body .tab, -.foundryvtt-reve-de-dragon .sheet-body .tab .editor { +.foundryvtt-reve-de-dragon .sheet-body .tab { height: 100%; } @@ -543,7 +542,7 @@ input:is(.blessure-premiers_soins, .blessure-soins_complets) { .editor { border: 2; - height: 300px; + height: 10rem; padding: 0 3px; } diff --git a/templates/item-herbe-sheet.html b/templates/item-herbe-sheet.html index da561fee..8221be6a 100644 --- a/templates/item-herbe-sheet.html +++ b/templates/item-herbe-sheet.html @@ -5,7 +5,7 @@

{{#if isIngredientPotionBase}} {{/if}} From db8fd6dbf868525309bd26cf32f3cf569151bfb9 Mon Sep 17 00:00:00 2001 From: Vincent Vandemeulebrouck Date: Sat, 3 Dec 2022 22:01:06 +0100 Subject: [PATCH 3/5] Meilleur post to tchat --- module/environnement.js | 7 +-- module/item.js | 97 +++++++++++++++++++++-------------------- 2 files changed, 51 insertions(+), 53 deletions(-) diff --git a/module/environnement.js b/module/environnement.js index 8f14e477..3b5e3221 100644 --- a/module/environnement.js +++ b/module/environnement.js @@ -132,12 +132,6 @@ export class EnvironmentSheetHelper { }); } - /* -------------------------------------------- */ - static getHeaderButtons(sheet, buttons) { - buttons.unshift({ class: "post", icon: "fas fa-comment", onclick: ev => sheet.item.postItem() }); - return buttons; - } - static setPosition(sheet, superPosition) { const position = superPosition; const sheetHeader = sheet.element.find(".sheet-header"); @@ -155,6 +149,7 @@ export class EnvironmentSheetHelper { static activateListeners(sheet, html) { if (!sheet.options.editable) return; + html.find("input.input-selection-milieu").keypress(event => { if (event.keyCode == '13') { EnvironmentSheetHelper.onAddMilieu(html, sheet, event); diff --git a/module/item.js b/module/item.js index 7a19f3be..060151bc 100644 --- a/module/item.js +++ b/module/item.js @@ -333,7 +333,7 @@ export class RdDItem extends Item { /* -------------------------------------------- */ getProprietes() { - return this[`_${this.type}ChatData`](); + return this[`_${this.type}ChatData`]().filter(it => it != undefined); } /* -------------------------------------------- */ @@ -357,29 +357,31 @@ export class RdDItem extends Item { }); } - static propertyIfDefined(name, val, condition = (it) => true) { - return condition ? [`${name}: ${val}`] : []; + static propertyIfDefined(name, val, condition = true) { + return condition ? `${name}: ${val}` : undefined; } + _inventaireTemplateChatData() { + return [ + RdDItem.propertyIfDefined('Qualité', this.system.qualite, this.system.qualite != 0), + RdDItem.propertyIfDefined('Encombrement', this.system.encombrement) + // cout et quantité masqués + ] + } /* -------------------------------------------- */ _objetChatData() { - return [].concat( - RdDItem.propertyIfDefined('Résistance', this.system.resistance, this.system.resistance), - RdDItem.propertyIfDefined('Qualité', this.system.qualite, this.system.qualite), - RdDItem.propertyIfDefined('Encombrement', this.system.encombrement), - ); + return this._inventaireTemplateChatData() } /* -------------------------------------------- */ _nourritureboissonChatData() { - return [].concat( + return [ RdDItem.propertyIfDefined('Sustentation', this.system.sust, this.system.sust > 0), RdDItem.propertyIfDefined('Désaltère', this.system.desaltere, this.system.boisson), RdDItem.propertyIfDefined('Force alcool', this.system.force, this.system.boisson && this.system.alcoolise), RdDItem.propertyIfDefined('Exotisme', this.system.exotisme, this.system.exotisme < 0), - RdDItem.propertyIfDefined('Qualité', this.system.qualite, this.system.qualite), - RdDItem.propertyIfDefined('Encombrement', this.system.encombrement), - ); + ...this._inventaireTemplateChatData() + ] } /* -------------------------------------------- */ _armeChatData() { @@ -388,21 +390,19 @@ export class RdDItem extends Item { `Dommages: ${this.system.dommages}`, `Force minimum: ${this.system.force}`, `Resistance: ${this.system.resistance}`, - `Encombrement: ${this.system.encombrement}` + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ _conteneurChatData() { return [ `Capacité: ${this.system.capacite} Enc.`, - `Encombrement: ${this.system.encombrement}` + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ _munitionChatData() { - return [ - `Encombrement: ${this.system.encombrement}` - ] + return this._inventaireTemplateChatData() } /* -------------------------------------------- */ _armureChatData() { @@ -410,7 +410,7 @@ export class RdDItem extends Item { `Protection: ${this.system.protection}`, `Détérioration: ${this.system.deterioration}`, `Malus armure: ${this.system.malus}`, - `Encombrement: ${this.system.encombrement}` + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ @@ -444,16 +444,16 @@ export class RdDItem extends Item { _herbeChatData() { return [ `Milieu: ${this.system.milieu}`, - `Rareté: ${this.system.rarete}`, `Catégorie: ${this.system.categorie}`, + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ _ingredientChatData() { return [ `Milieu: ${this.system.milieu}`, - `Rareté: ${this.system.rarete}`, `Catégorie: ${this.system.categorie}`, + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ @@ -463,12 +463,9 @@ export class RdDItem extends Item { `Compétence: ${this.system.competence}`, `Périodicité: ${this.system.periodicite}`, `Fatigue: ${this.system.fatigue}`, - `Difficulté: ${this.system.difficulte}` - ].concat([ - this.system.cacher_points_de_tache ? [] : `Points de Tâche: ${this.system.points_de_tache}` - ]).concat([ + `Difficulté: ${this.system.difficulte}`, + RdDItem.propertyIfDefined('Points de Tâche', this.system.points_de_tache, this.system.cacher_points_de_tache), `Points de Tâche atteints: ${this.system.points_de_tache_courant}`] - ); } /* -------------------------------------------- */ _livreChatData() { @@ -476,8 +473,8 @@ export class RdDItem extends Item { `Compétence: ${this.system.competence}`, `Auteur: ${this.system.auteur}`, `Difficulté: ${this.system.difficulte}`, - `Points de Tâche: ${this.system.points_de_tache}`, - `Encombrement: ${this.system.encombrement}` + RdDItem.propertyIfDefined('Points de Tâche', this.system.points_de_tache, this.system.cacher_points_de_tache), + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ @@ -485,32 +482,44 @@ export class RdDItem extends Item { return [ `Rareté: ${this.system.rarete}`, `Catégorie: ${this.system.categorie}`, - `Encombrement: ${this.system.encombrement}`, + ...this._inventaireTemplateChatData() ] } /* -------------------------------------------- */ _queueChatData() { + function label(categorie) { + switch (categorie) { + case 'ideefixe': return 'Idée fixe'; + case 'lancinant': return 'Désir lancinant'; + } + return '' + } return [ - `Refoulement: ${this.system.refoulement}` + `Refoulement: ${this.system.refoulement}`, + `Catégorie: ${label(this.system.categorie)}`, + `Affecte: ${this.system.hautrevant ? 'les haut-rêvants' : 'tout le monde'}`, ] } /* -------------------------------------------- */ _ombreChatData() { - return [ - `Refoulement: ${this.system.refoulement}` - ] + return this._queueChatData() } /* -------------------------------------------- */ _souffleChatData() { - return []; + return [ + `Affecte: ${this.system.hautrevant ? 'les haut-rêvants' : 'tout le monde'}`, + ]; } /* -------------------------------------------- */ _teteChatData() { - return []; + return [ + `Affecte: ${this.system.hautrevant ? 'les haut-rêvants' : 'tout le monde'}`, + ]; } /* -------------------------------------------- */ _tarotChatData() { return [ + RdDItem.propertyIfDefined('Carte', RdDUtility.linkCompendium(this.pack, this.id, this.name), this.pack), `Concept: ${this.system.concept}`, `Aspect: ${this.system.aspect}`, ] @@ -524,10 +533,7 @@ export class RdDItem extends Item { } /* -------------------------------------------- */ _monnaieChatData() { - return [ - `Valeur en Sols: ${this.system.cout}`, - `Encombrement: ${this.system.encombrement}` - ] + return this._inventaireTemplateChatData() } /* -------------------------------------------- */ _meditationChatData() { @@ -551,9 +557,9 @@ export class RdDItem extends Item { ] } return [ - `Force: ${this.system.force}`, + `Force: ${this.system.formule}`, `Refoulement: ${this.system.refoulement}`, - `Présent de cités: ${this.system.presentCite}`, + RdDItem.propertyIfDefined('Présent de cités', '', this.system.presentCite), ] } /* -------------------------------------------- */ @@ -568,15 +574,12 @@ export class RdDItem extends Item { if (!this.system.identifie) { return [`Inconnue`] } - let properties = [ + return [ `Malignité: ${this.system.malignite}`, `Périodicité: ${this.system.periodicite}`, - `Dommages: ${this.system.dommages}` + `Dommages: ${this.system.dommages}`, + RdDItem.propertyIfDefined('Remedes', this.system.remedes, this.system.remedesconnus), ] - if (this.system.remedesconnus) { - properties.push(`Remedes: ${this.system.remedes}`) - } - return properties; } /* -------------------------------------------- */ @@ -591,7 +594,7 @@ export class RdDItem extends Item { `Taille: ${this.system.taille}`, `Inertie: ${this.system.inertie}`, `Enchantabilité: ${this.system.enchantabilite}`, - `Prix: ${this.system.cout}`, + ...this._inventaireTemplateChatData() ] } From ab704c46d25a7d21a978ab5d135f992e90cb844c Mon Sep 17 00:00:00 2001 From: Vincent Vandemeulebrouck Date: Sat, 3 Dec 2022 18:31:05 +0100 Subject: [PATCH 4/5] Ajout de l'Item "faune" pour tables environnement --- icons/faune/cerf.webp | Bin 0 -> 7130 bytes icons/faune/chevre.webp | Bin 0 -> 6796 bytes icons/faune/crabe.webp | Bin 0 -> 7232 bytes icons/faune/lapin.webp | Bin 0 -> 8260 bytes icons/faune/oie.webp | Bin 0 -> 5360 bytes icons/faune/oiseau.webp | Bin 0 -> 8154 bytes icons/faune/poisson.webp | Bin 0 -> 6420 bytes icons/faune/raton-laveur.webp | Bin 0 -> 6492 bytes icons/faune/rongeur.webp | Bin 0 -> 7952 bytes icons/faune/saumon.webp | Bin 0 -> 8150 bytes icons/faune/singe-vert.webp | Bin 0 -> 6068 bytes lang/fr.json | 1 + module/environnement.js | 2 +- module/item-faune-sheet.js | 54 +++++++++++++++++++++++++++ module/item.js | 10 +++++ module/rdd-main.js | 2 + module/rdd-utility.js | 10 ++++- template.json | 16 +++++++- templates/common/compendium-link.hbs | 1 + templates/item-faune-sheet.html | 47 +++++++++++++++++++++++ 20 files changed, 139 insertions(+), 4 deletions(-) create mode 100644 icons/faune/cerf.webp create mode 100644 icons/faune/chevre.webp create mode 100644 icons/faune/crabe.webp create mode 100644 icons/faune/lapin.webp create mode 100644 icons/faune/oie.webp create mode 100644 icons/faune/oiseau.webp create mode 100644 icons/faune/poisson.webp create mode 100644 icons/faune/raton-laveur.webp create mode 100644 icons/faune/rongeur.webp create mode 100644 icons/faune/saumon.webp create mode 100644 icons/faune/singe-vert.webp create mode 100644 module/item-faune-sheet.js create mode 100644 templates/common/compendium-link.hbs create mode 100644 templates/item-faune-sheet.html diff --git a/icons/faune/cerf.webp b/icons/faune/cerf.webp new file mode 100644 index 0000000000000000000000000000000000000000..c18c85051e55a3671ad44be58756c3290cfc54b0 GIT binary patch literal 7130 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 MR;!mK;eTEJ3lO>x7XSbN literal 0 HcmV?d00001 diff --git a/icons/faune/chevre.webp b/icons/faune/chevre.webp new file mode 100644 index 0000000000000000000000000000000000000000..f604aa6c832741b9c5494c0cb806c95f2c41b74d GIT binary patch literal 6796 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 literal 0 HcmV?d00001 diff --git a/icons/faune/crabe.webp b/icons/faune/crabe.webp new file mode 100644 index 0000000000000000000000000000000000000000..6e797ec4cbe49dc0fd16ec6bbe49b7dddd35e397 GIT binary patch literal 7232 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 literal 0 HcmV?d00001 diff --git a/icons/faune/raton-laveur.webp b/icons/faune/raton-laveur.webp new file mode 100644 index 0000000000000000000000000000000000000000..9022c695e11ef504f57ea9f962a036a6fd5b3ffd GIT binary patch literal 6492 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 AKL7v# literal 0 HcmV?d00001 diff --git a/icons/faune/saumon.webp b/icons/faune/saumon.webp new file mode 100644 index 0000000000000000000000000000000000000000..5b8faf39014ed3b7cb604de28e74da50da1fdd80 GIT binary patch literal 8150 zcmZ{pRahNClZNNu?i!pxaCdh|u;A_vIk-!34-(wn-7UCV@L++!!8K@rpl8YM#lIK3 zHPhX1e_hqnUHv?BF{AcDR(6^K0JLQ!RkT$2bx;5RV1F%8(7*eGl$44F%xf2b(Eyv< zyTZK=**mzosL4rE>geiGBJKld04#tC&;uBz=B`dk>arUDy#H^zT>?P=MiyB9&Gmo# z{J$!yg{7-G0DzEQJw(l&T-;vy{VOYax;g#hf%c6nXkEC2YXoBaqM;`Bx;Ly>rnLTFZ1%s{+{VTJ)#qPQXzao6uWR^k`?nJ`O9xH$*OvOV zkOHoN8XyNq0+hf9Kn9QkcmWPT;I-xjSO89d^|c55Kk@(OCIyrM$Jbc%*V+m223!DJ zz#6at+yLfR)%|sL%h%TGRkwV-z<~F^{J+M%+JExuYQ@F*-x3H-5&+;gpwMet06SFre&w+idVXUkG;HnG&&~*U-cNPFp^#3PkuVeqlfudyq(C~ddswn`-$OM3Qul|?@ z5{fGC_du^Fgvk!Y#+LMG`E9@URFA^8h5nVphy6`@Rdv`O9t{Mf`2_RO0KtH*w|%KN zb5P`biQZtr3rE4Iq3`RB&)v_MQ2`nvy8&~JkZ}6ltw`!G``a1AnVkGH)x~b2S*Syb zZ&1vTC$WYVxw8`*r5SJ)u)nK*b{P%D5`0fHDb|9D5iw79!7q{nS2 zyyFUyXmUDJ!C)Jr`r?$p=ajeQ0BLmNQq^~EeWA`oZYle+tN~N7s>_zDJOlsB&3uAT z7G}^LH(si7(8M}l!_nb#c(Ru-#Dpn)vr9w&mh%QyU} zqh6H{yw@KMe7H|S*oME9xDL;CgUdxiJn3_4dqyx9KecPSnA-4~#c$>AEy&v=O#V?b zL#eBx#VOKIqH*2X1yj)7OsghyW@K;W_KQr6$}=c{PE9Y*j47>L^ryqg!^?3C*4%*3 z@FLJ#l-`mLoX@WV0y!W?00w{&owKS`DHrRl zEO9yda`6V)++jv-V69TQuy>GG5qJ4J=DF{tf@kW!@0mgA1MF&U0J-@yVNTv%Pnnq1 zBaCbQ^VSXef$EXMGsXk-ukl0fxLD0b<4ZmCXQRQ3>ξ-s-8<0CdSA@HAH!q_$i0 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 literal 0 HcmV?d00001 diff --git a/lang/fr.json b/lang/fr.json index 76a10929..3cc1bf86 100644 --- a/lang/fr.json +++ b/lang/fr.json @@ -20,6 +20,7 @@ "TypeMonnaie": "Monnaie", "TypeHerbe": "Herbe ou plante", "TypeIngredient": "Ingrédient", + "TypeFaune": "Faune", "TypeLivre": "Livre", "TypePotion": "Potion", "TypeArme": "Arme", diff --git a/module/environnement.js b/module/environnement.js index 3b5e3221..eebc6834 100644 --- a/module/environnement.js +++ b/module/environnement.js @@ -23,7 +23,7 @@ const MILIEUX = [ "Sous-sols" ] const ITEM_ENVIRONNEMENT_TYPES = [ - 'herbe', 'ingredient' + 'herbe', 'ingredient', 'faune' ] export class Environnement { diff --git a/module/item-faune-sheet.js b/module/item-faune-sheet.js new file mode 100644 index 00000000..274142b2 --- /dev/null +++ b/module/item-faune-sheet.js @@ -0,0 +1,54 @@ +import { EnvironmentSheetHelper } from "./environnement.js"; +import { RdDItemSheet } from "./item-sheet.js"; +import { RdDUtility } from "./rdd-utility.js"; + +export class RdDFauneItemSheet extends RdDItemSheet { + + static get ITEM_TYPE() { return "faune" }; + + static get defaultOptions() { + return EnvironmentSheetHelper.defaultOptions(super.defaultOptions); + } + + setPosition(options = {}) { + return EnvironmentSheetHelper.setPosition(this, super.setPosition(options)); + } + + async getData() { + const formData = await super.getData(); + return await EnvironmentSheetHelper.getData(this, formData); + } + + activateListeners(html) { + super.activateListeners(html); + if (!this.options.editable) return; + + EnvironmentSheetHelper.activateListeners(this, html); + + html.find("a.linked-actor-delete").click(event => this.onDeleteLinkedActor()); + + } + + async _onDropActor(event, dragData) { + console.log('faune:dropActor', event, dragData) + const actor = fromUuidSync(dragData.uuid); + if (actor?.pack) { + this.item.update({ + 'system.actor.pack': actor.pack, + 'system.actor.id': actor._id, + 'system.actor.name': actor.name + }); + } + else { + ui.notifications.warn(`${actor.name} ne provient pas d'eun compendium. +
Choisissez une créature du compendium pour représenter un élément de faune générique`) + } + } + async onDeleteLinkedActor() { + this.item.update({ + 'system.actor.pack': '', + 'system.actor.id': '', + 'system.actor.name': '' + }); + } +} diff --git a/module/item.js b/module/item.js index 060151bc..6182bd0f 100644 --- a/module/item.js +++ b/module/item.js @@ -10,6 +10,7 @@ const typesObjetsInventaire = [ "gemme", "herbe", "ingredient", + "faune", "livre", "monnaie", "munition", @@ -35,6 +36,7 @@ export const defaultItemImg = { conteneur: "systems/foundryvtt-reve-de-dragon/icons/objets/sac_a_dos.webp", sort: "systems/foundryvtt-reve-de-dragon/icons/competence_oniros.webp", herbe: "systems/foundryvtt-reve-de-dragon/icons/botanique/Endorlotte.webp", + faune: "systems/foundryvtt-reve-de-dragon/icons/faune/rongeur.webp", ingredient: "systems/foundryvtt-reve-de-dragon/icons/objets/sable_poudre.webp", livre: "systems/foundryvtt-reve-de-dragon/icons/objets/livre.webp", potion: "systems/foundryvtt-reve-de-dragon/icons/objets/liqueur_de_bagdol.webp", @@ -457,6 +459,14 @@ export class RdDItem extends Item { ] } /* -------------------------------------------- */ + _fauneChatData() { + return [ + `Sustentation: ${this.system.sust}`, + `Milieu: ${this.system.milieu}`, + ...this._inventaireTemplateChatData() + ] + } + /* -------------------------------------------- */ _tacheChatData() { return [ `Caractéristique: ${this.system.carac}`, diff --git a/module/rdd-main.js b/module/rdd-main.js index 23acc016..912d6209 100644 --- a/module/rdd-main.js +++ b/module/rdd-main.js @@ -42,6 +42,7 @@ import { TMRRencontres } from "./tmr-rencontres.js"; import { RdDHerbeItemSheet } from "./item-herbe-sheet.js"; import { Environnement } from "./environnement.js"; import { RdDIngredientItemSheet } from "./item-ingredient-sheet.js"; +import { RdDFauneItemSheet } from "./item-faune-sheet.js"; import { RdDConteneurItemSheet } from "./item-conteneur-sheet.js"; /* -------------------------------------------- */ @@ -193,6 +194,7 @@ Hooks.once("init", async function () { RdDItemSheet.register(RdDRencontreItemSheet); RdDItemSheet.register(RdDConteneurItemSheet); RdDItemSheet.register(RdDHerbeItemSheet); + RdDItemSheet.register(RdDFauneItemSheet); RdDItemSheet.register(RdDIngredientItemSheet); Items.registerSheet(SYSTEM_RDD, RdDItemSheet, { diff --git a/module/rdd-utility.js b/module/rdd-utility.js index fe173ac9..0b7f21d3 100644 --- a/module/rdd-utility.js +++ b/module/rdd-utility.js @@ -183,6 +183,7 @@ export class RdDUtility { 'systems/foundryvtt-reve-de-dragon/templates/item-sort-sheet.html', 'systems/foundryvtt-reve-de-dragon/templates/item-herbe-sheet.html', 'systems/foundryvtt-reve-de-dragon/templates/item-ingredient-sheet.html', + 'systems/foundryvtt-reve-de-dragon/templates/item-faune-sheet.html', 'systems/foundryvtt-reve-de-dragon/templates/item-livre-sheet.html', 'systems/foundryvtt-reve-de-dragon/templates/item-tache-sheet.html', 'systems/foundryvtt-reve-de-dragon/templates/item-potion-sheet.html', @@ -218,6 +219,7 @@ export class RdDUtility { 'systems/foundryvtt-reve-de-dragon/templates/enum-tmr-type.html', 'systems/foundryvtt-reve-de-dragon/templates/enum-tmr-effet.html', // Partials + 'systems/foundryvtt-reve-de-dragon/templates/common/compendium-link.hbs', 'systems/foundryvtt-reve-de-dragon/templates/partial-description-overflow.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-description-sort.html', 'systems/foundryvtt-reve-de-dragon/templates/partial-roll-ajustements.html', @@ -326,7 +328,7 @@ export class RdDUtility { return a.name.localeCompare(b.name); }) ); - Handlebars.registerHelper('linkCompendium', (compendium, id, name) => `@Compendium[${compendium}.${id}]{${name}}`); + Handlebars.registerHelper('linkCompendium', (pack, id, name)=> RdDUtility.linkCompendium(pack, id, name)); Handlebars.registerHelper('uniteQuantite', (type) => RdDItem.getUniteQuantite(type)); Handlebars.registerHelper('isFieldInventaireModifiable', (type, field) => RdDItem.isFieldInventaireModifiable(type, field)); Handlebars.registerHelper('getFrequenceRarete', (rarete, field) => Environnement.getFrequenceRarete(rarete, field)); @@ -334,6 +336,10 @@ export class RdDUtility { return loadTemplates(templatePaths); } + static linkCompendium(pack, id, name) { + return `@Compendium[${pack}.${id}]{${name}}`; + } + /* -------------------------------------------- */ static async creerObjet(actorSheet) { let itemType = $(".item-type").val(); @@ -464,6 +470,7 @@ export class RdDUtility { formData.livres = this.arrayOrEmpty(itemTypes['livre']); formData.potions = this.arrayOrEmpty(itemTypes['potion']); formData.ingredients = this.arrayOrEmpty(itemTypes['ingredient']); + formData.faunes = this.arrayOrEmpty(itemTypes['faune']); formData.herbes = this.arrayOrEmpty(itemTypes['herbe']); formData.monnaie = this.arrayOrEmpty(itemTypes['monnaie']).sort(Monnaie.triValeurEntiere()); formData.nourritureboissons = this.arrayOrEmpty(itemTypes['nourritureboisson']); @@ -478,6 +485,7 @@ export class RdDUtility { .concat(formData.potions) .concat(formData.ingredients) .concat(formData.herbes) + .concat(formData.faunes) .concat(formData.monnaie) .concat(formData.nourritureboissons) .concat(formData.gemmes); diff --git a/template.json b/template.json index 27c37132..c9950acf 100644 --- a/template.json +++ b/template.json @@ -572,7 +572,7 @@ "types": [ "competence", "competencecreature", "recettealchimique", "musique", "chant", "danse", "jeu", "recettecuisine", "oeuvre", - "objet", "arme", "armure", "conteneur", "herbe", "ingredient", "livre", "potion", "munition", + "objet", "arme", "armure", "conteneur", "herbe", "ingredient", "faune", "livre", "potion", "munition", "monnaie", "nourritureboisson", "gemme", "meditation", "rencontre", "queue", "ombre", "souffle", "tete", "casetmr", "signedraconique", "sort", "sortreserve", "nombreastral", "tache", "maladie", "poison", "possession", @@ -700,11 +700,11 @@ }, "nourritureboisson": { "templates": [ "description", "inventaire" ], - "sust": 0, "boisson": false, "desaltere": 0, "alcoolise": false, "force": 0, + "sust": 0, "exotisme": 0 }, "herbe": { @@ -717,8 +717,20 @@ "templates": [ "description", "inventaire", "environnement" ], "niveau": 0, "base": 0, + "sust": 0, + "exotisme": 0, "categorie": "" }, + "faune": { + "templates": [ "description", "inventaire", "environnement"], + "sust": 0, + "exotisme": 0, + "actor": { + "id": "", + "pack": "", + "name": "" + } + }, "livre": { "templates": [ "description", "inventaire" ], "competence": "", diff --git a/templates/common/compendium-link.hbs b/templates/common/compendium-link.hbs new file mode 100644 index 00000000..3efebb63 --- /dev/null +++ b/templates/common/compendium-link.hbs @@ -0,0 +1 @@ +{{name}} \ No newline at end of file diff --git a/templates/item-faune-sheet.html b/templates/item-faune-sheet.html new file mode 100644 index 00000000..145b7a0c --- /dev/null +++ b/templates/item-faune-sheet.html @@ -0,0 +1,47 @@ +
+
+ +
+

+
+
+ + + +
+
+
+
+ + +
+ {{#if (gt system.sust 0)}} +
+ + +
+ {{/if}} +
+ +
+ {{#if system.actor.id}} + + + {{else}} + + {{/if}} +
+
+ {{>"systems/foundryvtt-reve-de-dragon/templates/item/partial-inventaire.html"}} + {{>"systems/foundryvtt-reve-de-dragon/templates/partial-item-description.html"}} +
+
+ {{>"systems/foundryvtt-reve-de-dragon/templates/item/partial-environnement.html"}} +
+
\ No newline at end of file From b8f3a9af273711f12ab98a6a3819d976b87f3f7f Mon Sep 17 00:00:00 2001 From: Vincent Vandemeulebrouck Date: Sat, 3 Dec 2022 22:31:56 +0100 Subject: [PATCH 5/5] Version 10.3.5 --- system.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/system.json b/system.json index bbe0dc91..6f40a556 100644 --- a/system.json +++ b/system.json @@ -1,8 +1,8 @@ { "id": "foundryvtt-reve-de-dragon", "title": "Rêve de Dragon", - "version": "10.3.4", - "download": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/archive/foundryvtt-reve-de-dragon-10.3.4.zip", + "version": "10.3.5", + "download": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/archive/foundryvtt-reve-de-dragon-10.3.5.zip", "manifest": "https://www.uberwald.me/gitea/public/foundryvtt-reve-de-dragon/raw/v10/system.json", "compatibility": { "minimum": "10",