Convert to using a module instead of a "static" class
This commit is contained in:
parent
e71d2133f2
commit
82108bfe5f
2 changed files with 72 additions and 66 deletions
|
|
@ -1,4 +1,4 @@
|
||||||
import { PlayerActor } from "./Player.mjs";
|
import PlayerActor from "./Player.mjs";
|
||||||
|
|
||||||
export class ActorHandler extends Actor {
|
export class ActorHandler extends Actor {
|
||||||
actorTypes = {
|
actorTypes = {
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,13 @@
|
||||||
export class PlayerActor {
|
/** @this {Actor} */
|
||||||
/** @this {Actor} */
|
async function genericEmbeddedUpdate($event) {
|
||||||
static async genericEmbeddedUpdate($event) {
|
|
||||||
let data = $event.delegateTarget.dataset;
|
let data = $event.delegateTarget.dataset;
|
||||||
let item = await fromUuid(data.embeddedId);
|
let item = await fromUuid(data.embeddedId);
|
||||||
item?.update({ [data.embeddedUpdate]: $event.target.value });
|
item?.update({ [data.embeddedUpdate]: $event.target.value });
|
||||||
this.sheet.render();
|
this.sheet.render();
|
||||||
};
|
};
|
||||||
|
|
||||||
/** @this {Actor} */
|
/** @this {Actor} */
|
||||||
static async genericEmbeddedDelete($event) {
|
async function genericEmbeddedDelete($event) {
|
||||||
let data = $event.currentTarget.dataset;
|
let data = $event.currentTarget.dataset;
|
||||||
let item = await fromUuid(data.embeddedId);
|
let item = await fromUuid(data.embeddedId);
|
||||||
|
|
||||||
|
|
@ -34,10 +33,10 @@ export class PlayerActor {
|
||||||
},
|
},
|
||||||
defaultYes: false,
|
defaultYes: false,
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
/** @this {Actor} */
|
/** @this {Actor} */
|
||||||
static async createCustomItem(defaults, opts = {}) {
|
async function createCustomItem(defaults, opts = {}) {
|
||||||
let items = await this.createEmbeddedDocuments(`Item`, defaults);
|
let items = await this.createEmbeddedDocuments(`Item`, defaults);
|
||||||
if (items.length == 0) {
|
if (items.length == 0) {
|
||||||
throw new Error();
|
throw new Error();
|
||||||
|
|
@ -51,21 +50,28 @@ export class PlayerActor {
|
||||||
item.sheet.render(true);
|
item.sheet.render(true);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
/** @this {Actor} */
|
/** @this {Actor} */
|
||||||
static async createCustomAspect() {
|
async function createCustomAspect() {
|
||||||
await PlayerActor.createCustomItem.bind(this)([{
|
await createCustomItem.bind(this)([{
|
||||||
type: `aspect`,
|
type: `aspect`,
|
||||||
name: game.i18n.format(`dotdungeon.defaults.aspect.name`),
|
name: game.i18n.format(`dotdungeon.defaults.aspect.name`),
|
||||||
}]);
|
}]);
|
||||||
};
|
};
|
||||||
|
|
||||||
/** @this {Actor} */
|
/** @this {Actor} */
|
||||||
static async createCustomSpell() {
|
async function createCustomSpell() {
|
||||||
await PlayerActor.createCustomItem.bind(this)([{
|
await createCustomItem.bind(this)([{
|
||||||
type: `spell`,
|
type: `spell`,
|
||||||
name: game.i18n.format(`dotdungeon.defaults.spell.name`),
|
name: game.i18n.format(`dotdungeon.defaults.spell.name`),
|
||||||
}]);
|
}]);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export default {
|
||||||
|
genericEmbeddedDelete,
|
||||||
|
genericEmbeddedUpdate,
|
||||||
|
createCustomItem,
|
||||||
|
createCustomAspect,
|
||||||
|
createCustomSpell
|
||||||
};
|
};
|
||||||
Loading…
Add table
Add a link
Reference in a new issue