From 489e7b9e4f951ea1b7dbe7dea5f221bedb000f13 Mon Sep 17 00:00:00 2001 From: Adrian Rosin Date: Mon, 19 Feb 2024 09:48:41 +0100 Subject: [PATCH] not displaying button when prefers-reduced-motion is set to reduce #30 --- static/script-bon.js | 51 ++++++++++++++++++++++++++------------------ 1 file changed, 30 insertions(+), 21 deletions(-) diff --git a/static/script-bon.js b/static/script-bon.js index 0b054c9..e680051 100644 --- a/static/script-bon.js +++ b/static/script-bon.js @@ -6,6 +6,8 @@ document.addEventListener('DOMContentLoaded', function() { function setupPage() { // Checks if the user didn't enable prefers-reduced-motion let animationEnabled = window.matchMedia('(prefers-reduced-motion: no-preference)').matches; + // Boolean to keep track of current animation state, starts at true because it is linked to the button which is only displayed when animationEnabled is true + let currentAnimationState = true; // Dictionary to keep track of animation intervals let animationIntervals = {}; // Dictionary to keep track of delay count for each animation @@ -93,7 +95,7 @@ function setupPage() { function toggleAnimation() { // Play or pause the animations based on current state - if (animationEnabled) { + if (currentAnimationState) { // Pause the animations toggleable.style.display = 'none'; imgTopToggleable.style.display = 'block'; @@ -111,34 +113,41 @@ function setupPage() { }); } // Toggle animation state - animationEnabled = !animationEnabled; + currentAnimationState = !currentAnimationState; } let lastScrollTop = 0; let isCallbackRegistered = false; window.addEventListener("scroll", function() { - if (!isCallbackRegistered) { - window.requestAnimationFrame(function() { - let currentPosition = window.scrollY || document.documentElement.scrollTop; - const toggleButton = document.querySelectorAll('.toggleButton'); + const toggleButton = document.querySelectorAll('.toggleButton'); + if (animationEnabled) { + if (!isCallbackRegistered) { + window.requestAnimationFrame(function () { + let currentPosition = window.scrollY || document.documentElement.scrollTop; - if (currentPosition > lastScrollTop) { - // Scroll down - toggleButton.forEach(button => { - button.style.display = "none"; - }); - } else { - // Scroll up - toggleButton.forEach(button => { - button.style.display = "block"; - }); - } - lastScrollTop = currentPosition <= 0 ? 0 : currentPosition; // For Mobile or negative scrolling - isCallbackRegistered = false; + if (currentPosition > lastScrollTop) { + // Scroll down + toggleButton.forEach(button => { + button.style.display = "none"; + }); + } else { + // Scroll up + toggleButton.forEach(button => { + button.style.display = "block"; + }); + } + lastScrollTop = currentPosition <= 0 ? 0 : currentPosition; // For Mobile or negative scrolling + isCallbackRegistered = false; + }); + + isCallbackRegistered = true; + } + } + else { + toggleButton.forEach(button => { + button.style.display = "none"; }); - - isCallbackRegistered = true; } }); }