133 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 
 | |
| const demiReveStatusEffect = { id: 'demi-reve', rdd: true, label: 'Demi-rêve', icon: 'systems/foundryvtt-reve-de-dragon/icons/heures/hd12.svg' };
 | |
| const rddStatusEffects = [
 | |
|   { id: 'sonne', rdd: true, label: 'Sonné', icon: 'icons/svg/stoned.svg' },
 | |
|   demiReveStatusEffect
 | |
| ];
 | |
| const statusDemiSurprise = new Set(['sonne', 'prone', 'restrain']);
 | |
| const statusSurpriseTotale = new Set(['unconscious', 'blind', 'dead']);
 | |
| 
 | |
| export class StatusEffects {
 | |
|   static onReady() {
 | |
|     StatusEffects.setCoreStatusId([demiReveStatusEffect]);
 | |
|     StatusEffects.setCoreStatusId(rddStatusEffects);
 | |
|     StatusEffects.setMandatoryRdd();
 | |
|     const defaultUseStatusEffect = CONFIG.statusEffects.map(it => it.id).join();
 | |
|     game.settings.register("foundryvtt-reve-de-dragon", "use-status-effects", {
 | |
|       name: "use-status-effects",
 | |
|       scope: "world",
 | |
|       config: false,
 | |
|       default: defaultUseStatusEffect,
 | |
|       type: String
 | |
|     });
 | |
| 
 | |
|     game.settings.registerMenu("foundryvtt-reve-de-dragon", "select-status-effect", {
 | |
|       name: "Choisir les effets disponibles",
 | |
|       label: "Choix des effets",
 | |
|       hint: "Ouvre la fenêtre de sélection des effets/status appliqués aux acteurs",
 | |
|       icon: "fas fa-bars",
 | |
|       type: StatusEffectsSettings,
 | |
|       restricted: true
 | |
|     });
 | |
|     CONFIG.RDD.allEffects = rddStatusEffects.concat(CONFIG.statusEffects);
 | |
|     
 | |
|     StatusEffects._setUseStatusEffects(StatusEffects._getUseStatusEffects());
 | |
|     console.log('statusEffects', CONFIG.statusEffects);
 | |
|   }
 | |
| 
 | |
|   static valeurSurprise(effect, isCombat) {
 | |
|     const id = StatusEffects.statusId(effect);
 | |
|     if (statusSurpriseTotale.has(id)) {
 | |
|       return 2;
 | |
|     }
 | |
|     return statusDemiSurprise.has(id) || (isCombat && id == demiReveStatusEffect.id) ? 1 : 0;
 | |
|   }
 | |
| 
 | |
|   static statusId(effectData) {
 | |
|     return effectData.flags?.core?.statusId ?? effectData["flags.core.statusId"];
 | |
|   }
 | |
| 
 | |
|   static setCoreStatusId(list) {
 | |
|     list.forEach(it => {
 | |
|       it.flags = { core: { statusId: it.id } };
 | |
|       it["flags.core.statusId"] = it.id;
 | |
|     });
 | |
|   }
 | |
|   static setMandatoryRdd() {
 | |
|     CONFIG.statusEffects.filter(it => statusDemiSurprise.has(it.id) || statusSurpriseTotale.has(it.id))
 | |
|       .forEach(it => it.rdd = true);
 | |
|   }
 | |
| 
 | |
|   static _getUseStatusEffects() {
 | |
|     const setting = game.settings.get("foundryvtt-reve-de-dragon", "use-status-effects");
 | |
|     return setting ? new Set(setting.split(',')) : new Set();
 | |
|   }
 | |
| 
 | |
|   static _setUseStatusEffects(useStatusEffects) {
 | |
|     if (game.user.isGM) {
 | |
|       game.settings.set("foundryvtt-reve-de-dragon", "use-status-effects", StatusEffects._toSetting(useStatusEffects));
 | |
|     }
 | |
| 
 | |
|     for (let effect of CONFIG.RDD.allEffects) {
 | |
|       effect.active = effect.rdd || useStatusEffects.has(effect.id);
 | |
|     }
 | |
|     CONFIG.statusEffects = CONFIG.RDD.allEffects.filter(it => it.active);
 | |
|   }
 | |
| 
 | |
|   static _toSetting(useStatusEffects) {
 | |
|     return Array.from(useStatusEffects).join();
 | |
|   }
 | |
| 
 | |
|   static demiReve() {
 | |
|     return demiReveStatusEffect;
 | |
|   }
 | |
| }
 | |
| 
 | |
| class StatusEffectsSettings extends FormApplication {
 | |
|   constructor(...args) {
 | |
|     super(...args);
 | |
|   }
 | |
| 
 | |
|   static get defaultOptions() {
 | |
|     const options = super.defaultOptions;
 | |
|     mergeObject(options, {
 | |
|       id: "status-effects-settings",
 | |
|       template: "systems/foundryvtt-reve-de-dragon/templates/status-effects-settings.html",
 | |
|       height: "800",
 | |
|       width: 350,
 | |
|       minimizable: false,
 | |
|       closeOnSubmit: true,
 | |
|       title: "Choix des status/effets"
 | |
|     });
 | |
|     return options;
 | |
|   }
 | |
| 
 | |
|   getData() {
 | |
|     let formData = super.getData();
 | |
|     formData.effects = CONFIG.RDD.allEffects;
 | |
|     return formData;
 | |
|   }
 | |
| 
 | |
|   activateListeners(html) {
 | |
|     html.find(".select-effect").click((event) => {
 | |
|       let id = event.currentTarget.attributes.name?.value;
 | |
|       if (id) {
 | |
|         let selected = StatusEffects._getUseStatusEffects();
 | |
|         let isChecked = event.currentTarget.checked;
 | |
|         if (isChecked) {
 | |
|           selected.add(id);
 | |
|         }
 | |
|         else {
 | |
|           selected.delete(id);
 | |
|         }
 | |
|         StatusEffects._setUseStatusEffects(selected);
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   async _updateObject(event, formData) {
 | |
|     this.close();
 | |
|   }
 | |
| }
 | |
| 
 |