mirror of
https://github.com/barsdeveloper/ueblueprint.git
synced 2026-02-13 16:44:49 +08:00
39 lines
999 B
JavaScript
Executable File
39 lines
999 B
JavaScript
Executable File
// @ts-check
|
|
|
|
import IContext from "../IContext"
|
|
|
|
export default class Unfocus extends IContext {
|
|
|
|
/** @type {(e: MouseEvent) => void} */
|
|
#clickHandler
|
|
|
|
constructor(target, blueprint, options = {}) {
|
|
options.listenOnFocus = true
|
|
super(target, blueprint, options)
|
|
|
|
let self = this
|
|
this.#clickHandler = e => self.clickedSomewhere(/** @type {HTMLElement} */(e.target))
|
|
if (this.blueprint.focus) {
|
|
document.addEventListener("click", this.#clickHandler)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param {HTMLElement} target
|
|
*/
|
|
clickedSomewhere(target) {
|
|
// If target is outside the blueprint grid
|
|
if (!target.closest("ueb-blueprint")) {
|
|
this.blueprint.setFocused(false)
|
|
}
|
|
}
|
|
|
|
listenEvents() {
|
|
document.addEventListener("click", this.#clickHandler)
|
|
}
|
|
|
|
unlistenEvents() {
|
|
document.removeEventListener("click", this.#clickHandler)
|
|
}
|
|
}
|