From ca918a2f53907b3b06ff05a6aeb6984c6b992899 Mon Sep 17 00:00:00 2001 From: zGadli <96724117+zGadli@users.noreply.github.com> Date: Mon, 8 Jul 2024 03:10:39 +0530 Subject: [PATCH] Fix navigation. (#2409) When left or right arrow key is held down the you will quickly navigate to next or previous chapters. --- lncrawl/assets/web/script.js | 49 +++++++++++++++++++++++------------- 1 file changed, 32 insertions(+), 17 deletions(-) diff --git a/lncrawl/assets/web/script.js b/lncrawl/assets/web/script.js index bf4f16a1d..aa74d52e8 100644 --- a/lncrawl/assets/web/script.js +++ b/lncrawl/assets/web/script.js @@ -8,44 +8,59 @@ function goToHref(el) { window.location.href = href; } -window.addEventListener("keyup", function (evt) { - clearInterval(keyPressTimer); +function startNavigation(direction) { + if (direction === "left") { + keyPressTimer = setTimeout(() => { + navigationInterval = setInterval(() => { + goToHref(document.querySelector("a.prev-button")); + }, 50); + }, 100); + } else if (direction === "right") { + keyPressTimer = setTimeout(() => { + navigationInterval = setInterval(() => { + goToHref(document.querySelector("a.next-button")); + }, 50); + }, 100); + } +} + +function stopNavigation() { + clearTimeout(keyPressTimer); clearInterval(navigationInterval); +} + +window.addEventListener("keydown", function (evt) { switch (evt.key) { case "ArrowLeft": - goToHref(document.querySelector("a.prev-button")); + if (!keyPressTimer && !navigationInterval) { + startNavigation("left"); + } break; case "ArrowRight": - goToHref(document.querySelector("a.next-button")); + if (!keyPressTimer && !navigationInterval) { + startNavigation("right"); + } break; default: break; } }); -window.addEventListener("keydown", function (evt) { - clearInterval(keyPressTimer); - clearInterval(navigationInterval); +window.addEventListener("keyup", function (evt) { + stopNavigation(); switch (evt.key) { case "ArrowLeft": - keyPressTimer = setTimeout(() => { - navigationInterval = setInterval(() => { - goToHref(document.querySelector("a.prev-button")); - }, 50); - }, 450); + goToHref(document.querySelector("a.prev-button")); break; case "ArrowRight": - keyPressTimer = setTimeout(() => { - navigationInterval = setInterval(() => { - goToHref(document.querySelector("a.next-button")); - }, 50); - }, 450); + goToHref(document.querySelector("a.next-button")); break; default: break; } }); + // Handle next TOC select function addTocSelectListener() { document.querySelectorAll("select.toc").forEach((select) => {