mirror of
https://github.com/Foundryborne/daggerheart.git
synced 2026-01-11 19:25:21 +01:00
* Restructured all the files * Moved build/daggerheart.js to ./daggerheart.js. Changed rollup to use the css file instead of the less * Restored build/ folder * Mvoed config out form under application * Moved roll.mjs to module/dice and renamed to dhRolls.mjs * Update module/canvas/placeables/_module.mjs Co-authored-by: joaquinpereyra98 <24190917+joaquinpereyra98@users.noreply.github.com> * Le massive export update * Removed unncessary import --------- Co-authored-by: joaquinpereyra98 <24190917+joaquinpereyra98@users.noreply.github.com>
67 lines
1.9 KiB
JavaScript
67 lines
1.9 KiB
JavaScript
const { ApplicationV2, HandlebarsApplicationMixin } = foundry.applications.api;
|
|
|
|
export default class DamageDialog extends HandlebarsApplicationMixin(ApplicationV2) {
|
|
constructor(roll, config = {}, options = {}) {
|
|
super(options);
|
|
|
|
this.roll = roll;
|
|
this.config = config;
|
|
}
|
|
|
|
static DEFAULT_OPTIONS = {
|
|
tag: 'form',
|
|
id: 'roll-selection',
|
|
classes: ['daggerheart', 'views', 'damage-selection'],
|
|
position: {
|
|
width: 400,
|
|
height: 'auto'
|
|
},
|
|
actions: {
|
|
submitRoll: this.submitRoll
|
|
},
|
|
form: {
|
|
handler: this.updateRollConfiguration,
|
|
submitOnChange: true,
|
|
submitOnClose: false
|
|
}
|
|
};
|
|
|
|
/** @override */
|
|
static PARTS = {
|
|
damageSelection: {
|
|
id: 'damageSelection',
|
|
template: 'systems/daggerheart/templates/dialogs/damageSelection.hbs'
|
|
}
|
|
};
|
|
|
|
async _prepareContext(_options) {
|
|
const context = await super._prepareContext(_options);
|
|
context.title = this.config.title;
|
|
context.extraFormula = this.config.extraFormula;
|
|
context.formula = this.roll.constructFormula(this.config);
|
|
return context;
|
|
}
|
|
|
|
static updateRollConfiguration(event, _, formData) {
|
|
const { ...rest } = foundry.utils.expandObject(formData.object);
|
|
this.config.extraFormula = rest.extraFormula;
|
|
this.render();
|
|
}
|
|
|
|
static async submitRoll() {
|
|
await this.close({ submitted: true });
|
|
}
|
|
|
|
/** @override */
|
|
_onClose(options = {}) {
|
|
if (!options.submitted) this.config = false;
|
|
}
|
|
|
|
static async configure(roll, config = {}) {
|
|
return new Promise(resolve => {
|
|
const app = new this(roll, config);
|
|
app.addEventListener('close', () => resolve(app.config), { once: true });
|
|
app.render({ force: true });
|
|
});
|
|
}
|
|
}
|