From 7ebf97b3b706c6d1a321d3477b6fb2e45b27ff25 Mon Sep 17 00:00:00 2001 From: recanman <29310982+recanman@users.noreply.github.com> Date: Fri, 13 Sep 2024 23:06:44 -0700 Subject: [PATCH] feat: stop fetching exchange rates after inactivity --- src/js/main.js | 40 +++++++++++++++++++++++++++++++++++++++- 1 file changed, 39 insertions(+), 1 deletion(-) diff --git a/src/js/main.js b/src/js/main.js index aca7c6b..ae739b8 100644 --- a/src/js/main.js +++ b/src/js/main.js @@ -14,7 +14,45 @@ const exchangeRates = {}; const runConvert = () => lastModifiedField === 'xmr' ? xmrConvert() : fiatConvert(); +let updateInterval +const startFetching = () => updateInterval = setInterval(fetchUpdatedExchangeRates, 5000); +const stopFetching = () => { + clearInterval(updateInterval) + updateInterval = null; +}; +const inactivityTimeout = 30 * 1000; // 30 seconds +let lastActivity = Date.now() + +const resetActivity = () => lastActivity = Date.now() +const checkInactivity = () => { + if (Date.now() - lastActivity > inactivityTimeout) { + console.log('Inactivity detected, stopping exchange rate updates'); + stopFetching(); + } else { + requestAnimationFrame(checkInactivity); + } +} + +document.addEventListener('focus', () => { + const focused = document.hasFocus(); + console.log(`Page is ${focused ? 'visible' : 'hidden'}`); + + if (focused && !updateInterval) { + console.log('Restarting exchange rate updates'); + startFetching(); + + resetActivity(); + requestAnimationFrame(checkInactivity); + } else { + stopFetching(); + } +}); +window.addEventListener('mousemove', resetActivity); +window.addEventListener('keydown', resetActivity); +window.addEventListener('touchstart', resetActivity); + +requestAnimationFrame(checkInactivity); document.addEventListener('DOMContentLoaded', () => { const copyXMRBtn = document.getElementById('copyXMRBtn'); @@ -71,7 +109,7 @@ document.addEventListener('DOMContentLoaded', () => { // Fetch updated exchange rates immediately, then every 5 seconds fetchUpdatedExchangeRates(true) - setInterval(fetchUpdatedExchangeRates, 5000); + startFetching(); }); function fetchUpdatedExchangeRates(showAlert = false) {