34 lines
776 B
JavaScript
34 lines
776 B
JavaScript
import { registerDestructor } from "@ember/destroyable";
|
|
import { service } from "@ember/service";
|
|
import Modifier from "ember-modifier";
|
|
import { bind } from "discourse-common/utils/decorators";
|
|
|
|
export default class FloatKitCloseOnEscape extends Modifier {
|
|
@service menu;
|
|
|
|
constructor(owner, args) {
|
|
super(owner, args);
|
|
registerDestructor(this, (instance) => instance.cleanup());
|
|
}
|
|
|
|
modify(element, [closeFn]) {
|
|
this.closeFn = closeFn;
|
|
this.element = element;
|
|
|
|
document.addEventListener("keydown", this.check);
|
|
}
|
|
|
|
@bind
|
|
check(event) {
|
|
if (event.key === "Escape") {
|
|
event.stopPropagation();
|
|
event.preventDefault();
|
|
this.closeFn();
|
|
}
|
|
}
|
|
|
|
cleanup() {
|
|
document.removeEventListener("keydown", this.check);
|
|
}
|
|
}
|