From e7d25da33cb03a43d2408aa1533d86e18f9df844 Mon Sep 17 00:00:00 2001 From: Ryan Kulp Date: Thu, 4 May 2023 17:19:55 -0700 Subject: [PATCH] ability to block ads inside "sidebar" when image is opened full screen --- content.js | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/content.js b/content.js index 1311452..7914eda 100644 --- a/content.js +++ b/content.js @@ -51,13 +51,27 @@ function hideAd(ad) { console.log('Twitter ads hidden: ', adsHidden.toString()); } +function getAndHideAds() { + getAds().forEach(hideAd) +} + // hide ads on page load -document.addEventListener('load', () => getAds().forEach(hideAd)); +document.addEventListener('load', () => getAndHideAds()); // oftentimes, tweets render after onload. LCP should catch them. new PerformanceObserver((entryList) => { - getAds().forEach(hideAd); + getAndHideAds(); }).observe({type: 'largest-contentful-paint', buffered: true}); // re-check as user scrolls -document.addEventListener('scroll', () => getAds().forEach(hideAd)); +document.addEventListener('scroll', () => getAndHideAds()); + +// re-check as user scrolls tweet sidebar (exists when image is opened) +var sidebarExists = setInterval(function() { + let timelines = document.querySelectorAll("[aria-label='Timeline: Conversation']"); + + if (timelines.length == 2) { + let tweetSidebar = document.querySelectorAll("[aria-label='Timeline: Conversation']")[0].parentElement.parentElement; + tweetSidebar.addEventListener('scroll', () => getAndHideAds()); + } +}, 500); \ No newline at end of file