mirror of
https://github.com/barsdeveloper/ueblueprint.git
synced 2026-02-03 23:55:04 +08:00
* WIP * Fix type 1 * Missing types info * Some fixes * Several types refactoring and fixes * WIP * Fix grammar
55 lines
1.5 KiB
JavaScript
55 lines
1.5 KiB
JavaScript
import IDraggableTemplate from "./IDraggableTemplate.js"
|
|
import MouseMoveDraggable from "../input/mouse/MouseMoveDraggable.js"
|
|
|
|
/**
|
|
* @template {IDraggableElement} T
|
|
* @extends {IDraggableTemplate<T>}
|
|
*/
|
|
export default class IDraggableControlTemplate extends IDraggableTemplate {
|
|
|
|
/** @type {(x: Number, y: Number) => void} */
|
|
#locationChangeCallback
|
|
get locationChangeCallback() {
|
|
return this.#locationChangeCallback
|
|
}
|
|
set locationChangeCallback(callback) {
|
|
this.#locationChangeCallback = callback
|
|
}
|
|
|
|
movementSpace
|
|
movementSpaceSize = [0, 0]
|
|
|
|
/** @param {PropertyValues} changedProperties */
|
|
firstUpdated(changedProperties) {
|
|
super.firstUpdated(changedProperties)
|
|
this.movementSpace = this.element.parentElement
|
|
}
|
|
|
|
setup() {
|
|
super.setup()
|
|
const bounding = this.movementSpace.getBoundingClientRect()
|
|
this.movementSpaceSize = [bounding.width, bounding.height]
|
|
}
|
|
|
|
createDraggableObject() {
|
|
return new MouseMoveDraggable(this.element, this.blueprint, {
|
|
draggableElement: this.movementSpace,
|
|
ignoreTranslateCompensate: true,
|
|
moveEverywhere: true,
|
|
movementSpace: this.movementSpace,
|
|
repositionOnClick: true,
|
|
stepSize: 1,
|
|
})
|
|
}
|
|
|
|
/**
|
|
* @param {Number} x
|
|
* @param {Number} y
|
|
* @returns {[Number, Number]}
|
|
*/
|
|
adjustLocation(x, y) {
|
|
this.locationChangeCallback?.(x, y)
|
|
return [x, y]
|
|
}
|
|
}
|