diff options
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/gui-common/log.js | 38 | ||||
| -rw-r--r-- | scripts/gui-common/widgets.js | 10 |
2 files changed, 43 insertions, 5 deletions
diff --git a/scripts/gui-common/log.js b/scripts/gui-common/log.js new file mode 100644 index 0000000..dcf5ac2 --- /dev/null +++ b/scripts/gui-common/log.js @@ -0,0 +1,38 @@ +'use strict'; + + +const LOG_EL = document.getElementsByTagName("log")[0]; +let LAST_LOG_TYPE = ""; + +function at_bot(el) { + return el.scrollTop >= (el.scrollHeight - el.clientHeight) +} + +function addLogEntry(object) { + + let do_scroll = at_bot(LOG_EL); + + let out = { + type: object.type, + target: object.target.classList.toString() + }; + + if (LAST_LOG_TYPE == "mousemove" || LAST_LOG_TYPE == "touchmove") { + if (LAST_LOG_TYPE == out.type) + return; + } + + LAST_LOG_TYPE = out.type; + + let entry = document.createElement("entry"); + entry.innerText = JSON.stringify(out); + + LOG_EL.appendChild(entry); + + if (do_scroll) { + LOG_EL.scroll({ + top: LOG_EL.scrollHeight, + behavior: "instant", + }); + } +}
\ No newline at end of file diff --git a/scripts/gui-common/widgets.js b/scripts/gui-common/widgets.js index 86bc5b1..c99c3b1 100644 --- a/scripts/gui-common/widgets.js +++ b/scripts/gui-common/widgets.js @@ -109,7 +109,7 @@ class Widget extends EventTarget{ #emitMouseEvent(event) { if (WIDGETS_DEBUG) { - console.log(event); + addLogEntry(event); } if (this.#inactive) @@ -122,7 +122,7 @@ class Widget extends EventTarget{ #emitTouchEvent(event) { if (WIDGETS_DEBUG) { - console.log(event); + addLogEntry(event); } if (event.type == "touchstart") @@ -141,7 +141,7 @@ class Widget extends EventTarget{ /** @param {KeyboardEvent} event */ #emitKeyboardEvent(event) { if (WIDGETS_DEBUG) { - console.log(event); + addLogEntry(event); } if (this.#inactive) @@ -156,7 +156,7 @@ class Widget extends EventTarget{ /** @param {FocusEvent} event */ #emitFocusEvent(event) { if (WIDGETS_DEBUG) { - console.log(event); + addLogEntry(event); } if (this.#inactive) @@ -172,7 +172,7 @@ class Widget extends EventTarget{ #emitContextEvent(event) { if (WIDGETS_DEBUG) { - console.log(event); + addLogEntry(event); } if (this.#inactive) |