Add check: don't interpret keys if an input element is selected

This commit is contained in:
Pieter Vander Vennet 2022-12-24 16:08:08 +01:00
parent 63708a65f5
commit 7b50e13ba9

View file

@ -5,6 +5,7 @@ import Title from "./Title"
import Table from "./Table" import Table from "./Table"
import { UIEventSource } from "../../Logic/UIEventSource" import { UIEventSource } from "../../Logic/UIEventSource"
import { VariableUiElement } from "./VariableUIElement" import { VariableUiElement } from "./VariableUIElement"
import doc = Mocha.reporters.doc
export default class Hotkeys { export default class Hotkeys {
private static readonly _docs: UIEventSource< private static readonly _docs: UIEventSource<
@ -18,6 +19,11 @@ export default class Hotkeys {
documentation: string documentation: string
}[] }[]
>([]) >([])
private static textElementSelected(): boolean {
console.log(document.activeElement)
return document?.activeElement?.tagName?.toLowerCase() === "input"
}
public static RegisterHotkey( public static RegisterHotkey(
key: ( key: (
| { | {
@ -61,6 +67,10 @@ export default class Hotkeys {
}) })
} else if (key["shift"] !== undefined) { } else if (key["shift"] !== undefined) {
document.addEventListener(type, function (event) { document.addEventListener(type, function (event) {
if (Hotkeys.textElementSelected()) {
// A text element is selected, we don't do anything special
return
}
if (event.shiftKey && event.key === keycode) { if (event.shiftKey && event.key === keycode) {
action() action()
event.preventDefault() event.preventDefault()
@ -75,6 +85,10 @@ export default class Hotkeys {
}) })
} else if (key["nomod"] !== undefined) { } else if (key["nomod"] !== undefined) {
document.addEventListener(type, function (event) { document.addEventListener(type, function (event) {
if (Hotkeys.textElementSelected()) {
// A text element is selected, we don't do anything special
return
}
if (event.key === keycode) { if (event.key === keycode) {
action() action()
event.preventDefault() event.preventDefault()