mirror of
https://github.com/barsdeveloper/ueblueprint.git
synced 2026-02-04 08:50:33 +08:00
70 lines
1.9 KiB
JavaScript
Executable File
70 lines
1.9 KiB
JavaScript
Executable File
import Drag from "../input/Drag"
|
|
import GraphElement from "./GraphElement"
|
|
|
|
export default class SelectableDraggable extends GraphElement {
|
|
|
|
constructor(...args) {
|
|
super(...args)
|
|
this.dragObject = null
|
|
this.location = [0, 0]
|
|
this.selected = false
|
|
|
|
let self = this
|
|
this.dragHandler = (e) => {
|
|
self.addLocation(e.detail.value)
|
|
}
|
|
}
|
|
|
|
connectedCallback() {
|
|
super.connectedCallback()
|
|
this.dragObject = new Drag(this, this.blueprint, {
|
|
looseTarget: true
|
|
})
|
|
}
|
|
|
|
disconnectedCallback() {
|
|
this.dragObject.unlistenDOMElement()
|
|
}
|
|
|
|
setLocation(value = [0, 0]) {
|
|
this.location = value
|
|
this.style.setProperty('--ueb-position-x', this.location[0])
|
|
this.style.setProperty('--ueb-position-y', this.location[1])
|
|
}
|
|
|
|
addLocation(value) {
|
|
this.setLocation([this.location[0] + value[0], this.location[1] + value[1]])
|
|
}
|
|
|
|
dispatchDragEvent(value) {
|
|
if (!this.selected) {
|
|
this.blueprint.unselectAll()
|
|
this.setSelected(true)
|
|
}
|
|
let dragEvent = new CustomEvent('uDragSelected', {
|
|
detail: {
|
|
instigator: this,
|
|
value: value
|
|
},
|
|
bubbles: false,
|
|
cancelable: true,
|
|
composed: false,
|
|
})
|
|
this.blueprint.dispatchEvent(dragEvent)
|
|
}
|
|
|
|
setSelected(value = true) {
|
|
if (this.selected == value) {
|
|
return
|
|
}
|
|
this.selected = value
|
|
if (this.selected) {
|
|
this.classList.add('ueb-selected')
|
|
this.blueprint.addEventListener('uDragSelected', this.dragHandler)
|
|
} else {
|
|
this.classList.remove('ueb-selected')
|
|
this.blueprint.removeEventListener('uDragSelected', this.dragHandler)
|
|
}
|
|
}
|
|
}
|