foundry-vtt-system-midgard5/source/module/sheets/M5CharacterSheet.ts

123 lines
4.1 KiB
TypeScript

import Logger from "../../utils/Logger"
import { M5Character } from "../actors/M5Character"
import { M5Item } from "../items/M5Item"
import { M5SkillLearned, M5SkillUnlearned } from "../M5Base"
export default class M5CharacterSheet extends ActorSheet {
static get defaultOptions() {
return mergeObject(super.defaultOptions, {
template: "systems/midgard5/templates/sheets/character/main.hbs",
width: 600,
height: 400,
classes: ["midgard5", "sheet", "character"],
tabs: [{ navSelector: ".sheet-navigation", contentSelector: ".sheet-content", initial: "base_values" }]
})
}
// get template() {
// return "systems/midgard5/templates/character_sheet/main.hbs"
// }Options extends ActorSheet.Options = ActorSheet.Options, Data extends object = ActorSheet.Data<Options>
override getData(options?: Partial<ActorSheet.Options>): ActorSheet.Data<ActorSheet.Options> | Promise<ActorSheet.Data<ActorSheet.Options>> {
const actor = this.actor as M5Character
//console.log("Sheet getData", (actor as any).data)
return Promise.resolve(super.getData(options)).then(context => {
actor.prepareDerivedData()
const actorData = (actor as any).data.toObject(false)
context.actor = actorData;
context.data = actorData.data;
//console.log("Sheet Promise", context.actor, context.data)
return context
})
}
override activateListeners(html: JQuery) {
super.activateListeners(html)
html.find(".edit-skill").on("click", async (event) => {
const row = event.target.parentElement
let skillId = row.dataset["skill"]
const context = this.actor.data
const item = context.items.get(skillId)
item.sheet.render(true)
})
html.find(".roll-learned-button").on("click", async (event) => {
const row = event.target.parentElement.parentElement
let skillId = row.dataset["skill"]
const actor = this.actor as any
const context = this.actor.data
const data = context.data
const item = context.items.get(skillId) as M5Item
await item.roll()
})
html.find(".roll-general-button").on("click", async (event) => {
const row = event.target.parentElement.parentElement
let skillName = row.dataset["skill"]
const actor = this.actor as M5Character
const context = this.actor.data
const data = context.data
const skill = data.skills.general[skillName]
const attribute = data.attributes[skill.attribute]
//console.log(skill, attribute)
const r = new Roll("1d20 + @fw + @bonus", {
fw: skill.fw,
bonus: M5Character.attributeBonus(attribute)
})
await r.evaluate().then(value => {
const skillLocalized = (game as Game).i18n.localize("midgard5." + skillName)
const chatString = skillLocalized + ": " + value.result + " = " + value.total
//console.log(chatString)
const speaker = ChatMessage.getSpeaker({actor: actor})
let chatData = { content: (game as Game).i18n.format(chatString, {name: (actor as any).name}), speaker }
ChatMessage.applyRollMode(chatData, (r.options as any).rollMode)
return ChatMessage.create(chatData)
})
})
html.find(".learn-button").on("click", async (event) => {
const row = event.target.parentElement.parentElement
let skillName = row.dataset["skill"]
const data = this.actor.data.data
const unlearnedSkill = data.skills.general[skillName] as M5SkillUnlearned
const itemData = {
name: (game as Game).i18n.localize("midgard5." + skillName),
type: "skill",
data: {
fw: unlearnedSkill.initial,
attribute: unlearnedSkill.attribute,
skill: skillName,
type: "general"
} as M5SkillLearned
}
this.actor.createEmbeddedDocuments("Item", [itemData]).then(docs => {
const item = docs[0]
//console.log("createEmbeddedDocuments", item.data)
})
})
// Drag & Drop
// const dragDropSkill = new DragDrop({
// dragSelector: ".items-list .item",
// dropSelector: ".sheet-body",
// permissions: { dragstart: this._canDragStart.bind(this), drop: this._canDragDrop.bind(this) },
// callbacks: { dragstart: this._onTransferItemDragStart.bind(this), drop: this._onTransferItemDrop.bind(this) },
// })
// dragDrop.bind(html[0])
}
}