From 54759b7e8c53a39082fbf9b85ef631ff22e52148 Mon Sep 17 00:00:00 2001 From: Penar Musaraj Date: Mon, 9 May 2022 09:04:03 -0400 Subject: [PATCH] FIX: Limit pan event handler to fix scrolling in TOC (#16673) --- .../discourse/app/components/topic-navigation.js | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/app/assets/javascripts/discourse/app/components/topic-navigation.js b/app/assets/javascripts/discourse/app/components/topic-navigation.js index a08444022c2..d8caa86fd42 100644 --- a/app/assets/javascripts/discourse/app/components/topic-navigation.js +++ b/app/assets/javascripts/discourse/app/components/topic-navigation.js @@ -168,14 +168,18 @@ export default Component.extend(PanEvents, { }, panStart(e) { - if (e.originalEvent.target.classList.contains("docked")) { + const target = e.originalEvent.target; + + if ( + target.classList.contains("docked") || + !target.closest(".timeline-container") + ) { return; } e.originalEvent.preventDefault(); - const center = e.center; - const $centeredElement = $(document.elementFromPoint(center.x, center.y)); - if ($centeredElement.parents(".timeline-scrollarea-wrapper").length) { + const centeredElement = document.elementFromPoint(e.center.x, e.center.y); + if (centeredElement.closest(".timeline-scrollarea-wrapper")) { this.isPanning = false; } else if (e.direction === "up" || e.direction === "down") { this.isPanning = true;