b7a8b0c08d
Les objets d'inventaire ont maintenant tous: coût, encombrement, qualité, quantité Le coût est toujours exprimé en sols, y compris pour les monnaies. Les paiements et achat-ventes sont fait en sols.
94 lines
3.4 KiB
JavaScript
94 lines
3.4 KiB
JavaScript
import { Misc } from "./misc.js";
|
|
import { LOG_HEAD } from "./constants.js";
|
|
|
|
const MONNAIE_ETAIN = {
|
|
name: "Etain (1 denier)", type: 'monnaie',
|
|
img: "systems/foundryvtt-reve-de-dragon/icons/objets/piece_etain_poisson.webp",
|
|
system: { quantite: 0, cout: 0.01, encombrement: 0.001, description: "" }
|
|
};
|
|
const MONNAIE_BRONZE = {
|
|
name: "Bronze (10 deniers)", type: 'monnaie',
|
|
img: "systems/foundryvtt-reve-de-dragon/icons/objets/piece_bronze_epees.webp",
|
|
system: { quantite: 0, cout: 0.10, encombrement: 0.002, description: "" }
|
|
};
|
|
const MONNAIE_ARGENT = {
|
|
name: "Argent (1 sol)", type: 'monnaie',
|
|
img: "systems/foundryvtt-reve-de-dragon/icons/objets/piece_argent_sol.webp",
|
|
system: { quantite: 0, cout: 1, encombrement: 0.003, description: "" }
|
|
};
|
|
const MONNAIE_OR = {
|
|
name: "Or (10 sols)", type: 'monnaie',
|
|
img: "systems/foundryvtt-reve-de-dragon/icons/objets/piece_or_sol.webp",
|
|
system: { quantite: 0, cout: 10, encombrement: 0.004, description: "" }
|
|
};
|
|
|
|
const MONNAIES_STANDARD = [MONNAIE_ETAIN, MONNAIE_BRONZE, MONNAIE_ARGENT, MONNAIE_OR];
|
|
|
|
export class Monnaie {
|
|
|
|
static monnaiesStandard() {
|
|
return MONNAIES_STANDARD;
|
|
}
|
|
|
|
static monnaiesManquantes(actor) {
|
|
const disponibles = actor.itemTypes['monnaie'];
|
|
const manquantes = MONNAIES_STANDARD.filter(standard => !disponibles.find(disponible => Monnaie.deValeur(disponible, standard.system?.cout)));
|
|
if (manquantes.length > 0) {
|
|
console.error(`${LOG_HEAD} monnaiesManquantes pour ${actor.name}`, manquantes, ' avec monnaies', disponibles, MONNAIES_STANDARD);
|
|
}
|
|
return manquantes;
|
|
}
|
|
|
|
static deValeur(monnaie, valeur) {
|
|
return Monnaie.valEntiere(valeur) == Monnaie.valEntiere(monnaie.system.cout)
|
|
}
|
|
|
|
static valEntiere(sols) {
|
|
return Math.max(Math.floor((sols??0)*100), 0);
|
|
}
|
|
|
|
static triValeurEntiere() {
|
|
return Misc.ascending(item => Monnaie.valEntiere(item.system.cout))
|
|
}
|
|
|
|
static async creerMonnaiesStandard(actor) {
|
|
await actor.createEmbeddedDocuments('Item', MONNAIES_STANDARD, { renderSheet: false });
|
|
}
|
|
|
|
static async creerMonnaiesDeniers(actor, fortune) {
|
|
await actor.createEmbeddedDocuments('Item', [Monnaie.creerDeniers(fortune)], { renderSheet: false });
|
|
}
|
|
|
|
static creerDeniers(fortune) {
|
|
const deniers = duplicate(MONNAIE_ETAIN);
|
|
deniers.system.quantite = fortune;
|
|
return deniers;
|
|
}
|
|
|
|
static async optimiserFortune(actor, fortune) {
|
|
let resteEnDeniers = Math.round(fortune*100);
|
|
let monnaies = actor.itemTypes['monnaie'];
|
|
let updates = [];
|
|
let parValeur = Misc.classifyFirst(monnaies, it => Monnaie.valEntiere(it.system.cout));
|
|
for (let valeurDeniers of [1000, 100, 10, 1]) {
|
|
const itemPiece = parValeur[valeurDeniers];
|
|
if (itemPiece) {
|
|
const quantite = Math.floor(resteEnDeniers / valeurDeniers);
|
|
if (quantite != itemPiece.system.quantite) {
|
|
updates.push({ _id: parValeur[valeurDeniers].id, 'system.quantite': quantite });
|
|
}
|
|
resteEnDeniers -= quantite*valeurDeniers;
|
|
}
|
|
}
|
|
console.log('Monnaie.optimiserFortune', actor.name, 'total', fortune, 'parValeur', parValeur, 'updates', updates, 'reste', resteEnDeniers);
|
|
if (updates.length > 0) {
|
|
await actor.updateEmbeddedDocuments('Item', updates);
|
|
}
|
|
if (resteEnDeniers > 0){
|
|
// créer le reste en deniers fortune en deniers
|
|
await Monnaie.creerMonnaiesDeniers(actor, resteEnDeniers);
|
|
}
|
|
}
|
|
|
|
}
|