Files
ueblueprint/js/element/IElement.js
barsdeveloper fdd86ce5de Refactor jsdoc types (#16)
* WIP

* Fix type 1

* Missing types info

* Some fixes

* Several types refactoring and fixes

* WIP

* Fix grammar
2023-09-22 22:56:33 +02:00

125 lines
2.9 KiB
JavaScript

import { LitElement } from "lit"
import Configuration from "../Configuration.js"
/**
* @template {IEntity} EntityT
* @template {ITemplate} TemplateT
*/
export default class IElement extends LitElement {
/** @type {Blueprint} */
#blueprint
get blueprint() {
return this.#blueprint
}
set blueprint(v) {
this.#blueprint = v
}
/** @type {EntityT} */
#entity
get entity() {
return this.#entity
}
set entity(entity) {
this.#entity = entity
}
/** @type {TemplateT} */
#template
get template() {
return this.#template
}
isInitialized = false
isSetup = false
/** @type {IInput[]} */
inputObjects = []
/**
* @param {EntityT} entity
* @param {TemplateT} template
*/
initialize(entity, template) {
this.requestUpdate()
this.#entity = entity
this.#template = template
this.#template.initialize(this)
if (this.isConnected) {
this.updateComplete.then(() => this.setup())
}
this.isInitialized = true
}
connectedCallback() {
super.connectedCallback()
this.blueprint = /** @type {Blueprint} */(this.closest("ueb-blueprint"))
if (this.isInitialized) {
this.requestUpdate()
this.updateComplete.then(() => this.setup())
}
}
disconnectedCallback() {
super.disconnectedCallback()
if (this.isSetup) {
this.updateComplete.then(() => this.cleanup())
}
this.acknowledgeDelete()
}
createRenderRoot() {
return this
}
setup() {
this.template.setup()
this.isSetup = true
}
cleanup() {
this.template.cleanup()
this.isSetup = false
}
/** @param {PropertyValues} changedProperties */
willUpdate(changedProperties) {
super.willUpdate(changedProperties)
this.template.willUpdate(changedProperties)
}
/** @param {PropertyValues} changedProperties */
update(changedProperties) {
super.update(changedProperties)
this.template.update(changedProperties)
}
render() {
return this.template.render()
}
/** @param {PropertyValues} changedProperties */
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties)
this.template.firstUpdated(changedProperties)
this.template.inputSetup()
}
/** @param {PropertyValues} changedProperties */
updated(changedProperties) {
super.updated(changedProperties)
this.template.updated(changedProperties)
}
acknowledgeDelete() {
let deleteEvent = new CustomEvent(Configuration.removeEventName)
this.dispatchEvent(deleteEvent)
}
/** @param {IElement} element */
isSameGraph(element) {
return this.blueprint && this.blueprint == element?.blueprint
}
}