foundryvtt-reve-de-dragon/module/actor/entite.js

121 lines
3.4 KiB
JavaScript
Raw Normal View History

2023-11-04 03:42:39 +01:00
import { ENTITE_INCARNE, ENTITE_NONINCARNE } from "../constants.js";
import { ITEM_TYPES } from "../item.js";
2023-11-04 03:42:39 +01:00
import { Misc } from "../misc.js";
import { RdDCarac } from "../rdd-carac.js";
2023-11-04 03:42:39 +01:00
import { RdDEncaisser } from "../rdd-roll-encaisser.js";
import { STATUSES } from "../settings/status-effects.js";
import { RdDBaseActorReve } from "./base-actor-reve.js";
export class RdDEntite extends RdDBaseActorReve {
static get defaultIcon() {
return "systems/foundryvtt-reve-de-dragon/icons/entites/darquoine.webp";
}
canReceive(item) {
return item.type == ITEM_TYPES.competencecreature
2023-11-04 03:42:39 +01:00
}
isEntite(typeentite = []) {
return (typeentite.length == 0 || typeentite.includes(this.system.definition.typeentite));
}
2023-11-04 03:42:39 +01:00
isNonIncarnee() { return this.isEntite([ENTITE_NONINCARNE]) }
getReveActuel() {
return Misc.toInt(this.system.carac.reve?.value)
}
getCarac() {
const carac = super.getCarac()
delete carac.niveau
return carac
}
getNiveau() {
const reve = this.getReve()
return RdDCarac.getCaracDerivee(reve).niveau
}
2023-11-04 03:42:39 +01:00
getForce() { return this.getReve() }
getAgilite() { return this.getReve() }
getChance() { return this.getReve() }
getEnduranceMax() { return Math.max(1, this.getTaille() + this.getReve()) }
2023-11-04 03:42:39 +01:00
getDraconicOuPossession() {
return this.itemTypes[ITEM_TYPES.competencecreature]
2023-11-04 03:42:39 +01:00
.filter(it => it.system.categorie == 'possession')
.sort(Misc.descending(it => it.system.niveau))
.find(it => true);
}
async remiseANeuf() {
await this.removeEffects(e => true);
if (!this.isNonIncarnee()) {
await this.update({
'system.sante.endurance.value': this.system.sante.endurance.max
});
}
}
isDead() {
return this.isNonIncarnee() ? false : this.system.sante.endurance.value <= 0
}
async santeIncDec(name, inc, isCritique = false) {
if (name == 'endurance' && !this.isNonIncarnee()) {
const oldValue = this.system.sante.endurance.value;
const endurance = Math.max(0,
Math.min(oldValue + inc,
this.system.sante.endurance.max));
await this.update({ "system.sante.endurance.value": endurance })
await this.setEffect(STATUSES.StatusComma, endurance <= 0);
return {
perte: oldValue - endurance,
newValue: endurance
}
}
return {}
}
2023-11-04 03:42:39 +01:00
async encaisser() {
if (this.isNonIncarnee()) {
return
}
await RdDEncaisser.encaisser(this)
2023-11-04 03:42:39 +01:00
}
isEffectAllowed(effectId) {
return [STATUSES.StatusComma].includes(effectId);
2023-11-04 03:42:39 +01:00
}
async onAppliquerJetEncaissement(encaissement, attackerToken) {
2023-11-04 03:42:39 +01:00
const perteEndurance = await this.santeIncDec("endurance", -encaissement.endurance);
2024-05-01 09:13:21 +02:00
foundry.utils.mergeObject(encaissement, {
2023-11-04 03:42:39 +01:00
resteEndurance: perteEndurance.newValue,
endurance: perteEndurance.perte
});
}
isEntiteAccordee(attacker) {
if (this.isEntite([ENTITE_INCARNE])) {
let resonnance = this.system.sante.resonnance
return (resonnance.actors.find(it => it == attacker.id))
}
return true
}
/* -------------------------------------------- */
async setEntiteReveAccordee(actor) {
2023-11-04 03:42:39 +01:00
if (this.isEntite([ENTITE_INCARNE])) {
if (this.system.sante.resonnance.actors.find(it => it == actor.id)) {
2023-11-04 03:42:39 +01:00
// déjà accordé
return
2023-11-04 03:42:39 +01:00
}
await this.update({ "system.sante.resonnance.actors": [...this.system.sante.resonnance.actors, actor.id] })
2023-11-04 03:42:39 +01:00
}
else {
super.setEntiteReveAccordee(actor)
2023-11-04 03:42:39 +01:00
}
}
}