forked from public/foundryvtt-reve-de-dragon
		
	Fix: deprecation effects flags.core.statusId
Remplacement de la logique basée sur les flags par le set de "statuses"
This commit is contained in:
		| @@ -1,13 +1,13 @@ | ||||
| import { SYSTEM_RDD } from "../constants.js"; | ||||
|  | ||||
| export const STATUSES = { | ||||
|   StatusStunned : 'stun', | ||||
|   StatusStunned: 'stun', | ||||
|   StatusBleeding: 'bleeding', | ||||
|   StatusProne: 'prone', | ||||
|   StatusGrappling: 'grappling', | ||||
|   StatusGrappled: 'grappled', | ||||
|   StatusRestrained: 'restrain', | ||||
|   StatusUnconscious: 'unconscious',  | ||||
|   StatusUnconscious: 'unconscious', | ||||
|   StatusBlind: 'blind', | ||||
|   StatusComma: 'comma', | ||||
|   StatusDead: 'dead', | ||||
| @@ -29,13 +29,16 @@ const rddStatusEffects = [ | ||||
| ]; | ||||
| const demiReveStatusEffect = rddStatusEffects.find(it => it.id == STATUSES.StatusDemiReve); | ||||
|  | ||||
| const statusDemiSurprise = [STATUSES.StatusStunned, STATUSES.StatusProne, STATUSES.StatusRestrained]; | ||||
| const statusSurpriseTotale = [STATUSES.StatusUnconscious, STATUSES.StatusBlind, STATUSES.StatusComma]; | ||||
| const statusDemiSurprise = new Set([STATUSES.StatusStunned, STATUSES.StatusProne, STATUSES.StatusRestrained]) | ||||
| const statusSurpriseTotale = new Set([STATUSES.StatusUnconscious, STATUSES.StatusBlind, STATUSES.StatusComma]) | ||||
|  | ||||
| export class StatusEffects extends FormApplication { | ||||
|   static onReady() { | ||||
|     const rddStatusIds = rddStatusEffects.map(it => it.id); | ||||
|     rddStatusEffects.forEach(it => it.flags = { core: { statusId: it.id } }); | ||||
|     const rddEffectIds = rddStatusEffects.map(it => it.id); | ||||
|     rddStatusEffects.forEach(it => { | ||||
|       it.statuses = new Set() | ||||
|       it.statuses.add(it.id) | ||||
|     }) | ||||
|     const defaultStatusEffectIds = CONFIG.statusEffects.map(it => it.id); | ||||
|     game.settings.register(SYSTEM_RDD, "use-status-effects", { | ||||
|       name: "use-status-effects", | ||||
| @@ -54,37 +57,47 @@ export class StatusEffects extends FormApplication { | ||||
|       restricted: true | ||||
|     }); | ||||
|  | ||||
|     CONFIG.RDD.allEffects = rddStatusEffects.concat(CONFIG.statusEffects.filter(it => !rddStatusIds.includes(it.id))); | ||||
|     CONFIG.RDD.allEffects = rddStatusEffects.concat(CONFIG.statusEffects.filter(it => !rddEffectIds.includes(it.id))); | ||||
|  | ||||
|     StatusEffects._setUseStatusEffects(StatusEffects._getUseStatusEffects()); | ||||
|     console.log('statusEffects', CONFIG.statusEffects); | ||||
|   } | ||||
|  | ||||
|   static valeurSurprise(effect, isCombat) { | ||||
|     // const id = StatusEffects.statusId(effect); | ||||
|     if (statusSurpriseTotale.includes(effect.flags?.core?.statusId)) { | ||||
|     if (statusSurpriseTotale.intersects(effect.statuses)) { | ||||
|       return 2; | ||||
|     } | ||||
|     return statusDemiSurprise.includes(effect.flags?.core?.statusId) || (isCombat && effect.flags?.core?.statusId == STATUSES.StatusDemiReve) ? 1 : 0; | ||||
|     if (statusDemiSurprise.intersects(effect.statuses)) { | ||||
|       return 1 | ||||
|     } | ||||
|     if (isCombat && effect.statuses.includes(STATUSES.StatusDemiReve)) { | ||||
|       return 1 | ||||
|     } | ||||
|     return 0 | ||||
|   } | ||||
|  | ||||
|   static _getUseStatusEffects() { | ||||
|      return game.settings.get(SYSTEM_RDD, "use-status-effects")?.split(',') ?? []; | ||||
|     return game.settings.get(SYSTEM_RDD, "use-status-effects")?.split(',') ?? []; | ||||
|   } | ||||
|  | ||||
|   static _setUseStatusEffects(statusIds) { | ||||
|   static _setUseStatusEffects(effectIds) { | ||||
|     if (game.user.isGM) { | ||||
|       game.settings.set(SYSTEM_RDD, "use-status-effects", statusIds.join()); | ||||
|       game.settings.set(SYSTEM_RDD, "use-status-effects", effectIds.join()); | ||||
|     } | ||||
|  | ||||
|     for (let effect of CONFIG.RDD.allEffects) { | ||||
|       effect.active = effect.rdd || statusIds.includes(effect.flags?.core?.statusId); | ||||
|       effect.active = effect.rdd || effectIds.includes(effect.id); | ||||
|     } | ||||
|     CONFIG.statusEffects = CONFIG.RDD.allEffects.filter(it => it.active); | ||||
|   } | ||||
|  | ||||
|   static status(statusId) { | ||||
|     return rddStatusEffects.find(it => it.flags?.core?.statusId == statusId); | ||||
|   static prepareActiveEffect(effectId) { | ||||
|     let status = rddStatusEffects.find(it => it.id == effectId) | ||||
|     if (status) { | ||||
|       status = duplicate(status) | ||||
|       status.statuses = [effectId] | ||||
|     } | ||||
|     return status; | ||||
|   } | ||||
|  | ||||
|   static demiReve() { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user