From 04653e2e29df634c566153b1da2a757538f60a94 Mon Sep 17 00:00:00 2001 From: Alexander Ebert Date: Mon, 10 May 2021 16:11:34 +0200 Subject: [PATCH] Explicitly declare a non-passive event listener --- ts/WoltLabSuite/Core/Ui/Mobile.ts | 82 ++++++++++--------- .../files/js/WoltLabSuite/Core/Ui/Mobile.js | 4 +- 2 files changed, 45 insertions(+), 41 deletions(-) diff --git a/ts/WoltLabSuite/Core/Ui/Mobile.ts b/ts/WoltLabSuite/Core/Ui/Mobile.ts index eff98789ea..4f5f3ef769 100644 --- a/ts/WoltLabSuite/Core/Ui/Mobile.ts +++ b/ts/WoltLabSuite/Core/Ui/Mobile.ts @@ -238,45 +238,49 @@ function toggleMobileNavigation(message: HTMLElement, quickOptions: HTMLElement, function setupLGTouchNavigation(): void { _enabledLGTouchNavigation = true; document.querySelectorAll(".boxMenuHasChildren > a").forEach((element: HTMLElement) => { - element.addEventListener("touchstart", function (event) { - if (_enabledLGTouchNavigation && element.getAttribute("aria-expanded") === "false") { - event.preventDefault(); - - element.setAttribute("aria-expanded", "true"); - - // Register an new event listener after the touch ended, which is triggered once when an - // element on the page is pressed. This allows us to reset the touch status of the navigation - // entry when the entry is no longer open, so that it does not redirect to the page when you - // click it again. - element.addEventListener( - "touchend", - () => { - document.body.addEventListener( - "touchstart", - () => { - document.body.addEventListener( - "touchend", - (event) => { - const parent = element.parentElement!; - const target = event.target as HTMLElement; - if (!parent.contains(target) && target !== parent) { - element.setAttribute("aria-expanded", "false"); - } - }, - { - once: true, - }, - ); - }, - { - once: true, - }, - ); - }, - { once: true }, - ); - } - }); + element.addEventListener( + "touchstart", + (event) => { + if (_enabledLGTouchNavigation && element.getAttribute("aria-expanded") === "false") { + event.preventDefault(); + + element.setAttribute("aria-expanded", "true"); + + // Register an new event listener after the touch ended, which is triggered once when an + // element on the page is pressed. This allows us to reset the touch status of the navigation + // entry when the entry is no longer open, so that it does not redirect to the page when you + // click it again. + element.addEventListener( + "touchend", + () => { + document.body.addEventListener( + "touchstart", + () => { + document.body.addEventListener( + "touchend", + (event) => { + const parent = element.parentElement!; + const target = event.target as HTMLElement; + if (!parent.contains(target) && target !== parent) { + element.setAttribute("aria-expanded", "false"); + } + }, + { + once: true, + }, + ); + }, + { + once: true, + }, + ); + }, + { once: true }, + ); + } + }, + { passive: false }, + ); }); } diff --git a/wcfsetup/install/files/js/WoltLabSuite/Core/Ui/Mobile.js b/wcfsetup/install/files/js/WoltLabSuite/Core/Ui/Mobile.js index 00c8f11849..45de7cd1d4 100644 --- a/wcfsetup/install/files/js/WoltLabSuite/Core/Ui/Mobile.js +++ b/wcfsetup/install/files/js/WoltLabSuite/Core/Ui/Mobile.js @@ -205,7 +205,7 @@ define(["require", "exports", "tslib", "../Core", "../Dom/Change/Listener", "../ function setupLGTouchNavigation() { _enabledLGTouchNavigation = true; document.querySelectorAll(".boxMenuHasChildren > a").forEach((element) => { - element.addEventListener("touchstart", function (event) { + element.addEventListener("touchstart", (event) => { if (_enabledLGTouchNavigation && element.getAttribute("aria-expanded") === "false") { event.preventDefault(); element.setAttribute("aria-expanded", "true"); @@ -229,7 +229,7 @@ define(["require", "exports", "tslib", "../Core", "../Dom/Change/Listener", "../ }); }, { once: true }); } - }); + }, { passive: false }); }); } function enableLGTouchNavigation() { -- 2.20.1