Skip to content

Instantly share code, notes, and snippets.

@thekalinga
Created March 25, 2021 11:26
Show Gist options
  • Save thekalinga/922998ecffc31895b48e80f45862c16f to your computer and use it in GitHub Desktop.
Save thekalinga/922998ecffc31895b48e80f45862c16f to your computer and use it in GitHub Desktop.
Scroll.in ad remover
// ==UserScript==
// @name Scroll ad remover
// @namespace http://tampermonkey.net/
// @version 0.1
// @description try to take over the world!
// @author You
// @match https://scroll.in/article/*
// @grant none
// ==/UserScript==
(function() {
'use strict';
function undo() {
removeClass(document.getElementsByTagName('body')[0], 'toggle');
toggle.src = showNavIcon;
}
function apply() {
addClass(document.getElementsByTagName('body')[0], 'toggle');
toggle.src = hideNavIcon;
}
var showing = false;
var hideNavIcon = '';
var showNavIcon = '';
var toggle = document.createElement('img');
toggle.src = hideNavIcon;
toggle.style.position = 'fixed';
toggle.style.bottom = "10px";
toggle.style.right = "10px";
toggle.style.width = "20px";
toggle.style.height = "20px";
toggle.style.cursor = "pointer";
toggle.style.zIndex = "9999";
toggle.addEventListener("click", function() {
if (!showing) {
apply();
} else {
undo();
}
showing = !showing;
});
document.getElementsByTagName('body')[0].appendChild(toggle);
var newStyleToBeApplied = document.createElement('style');
newStyleToBeApplied.type= 'text/css';
newStyleToBeApplied.innerHTML = `
.toggle .scroll-article-content,
.toggle header
{
width: 80% !important;
max-width: none;
}
.toggle .scroll-article-content,
.toggle figcaption,
.toggle h1,
.toggle h2,
.toggle h3
{
font-family: Crimson Pro Light;
line-height: 1.5em;
letter-spacing: normal;
}
.toggle .in-article-adx,
.toggle .global-navigation,
.toggle .below-navigation-banner-wrapper,
.toggle .notification-alert-banner,
.toggle .scroll-navigation-container
{
display: none !important;
}
`;
document.getElementsByTagName('head')[0].appendChild(newStyleToBeApplied);
apply();
showing = !showing;
function hasClass(el, className) {
if (el.classList) {
return el.classList.contains(className);
} else {
return !!el.className.match(new RegExp('(\\s|^)' + className + '(\\s|$)'));
}
}
function addClass(el, className) {
if (el.classList) {
el.classList.add(className);
}
else if (!hasClass(el, className)) {
el.className += " " + className;
}
}
function removeClass(el, className) {
if (el.classList) {
el.classList.remove(className);
} else if (hasClass(el, className)) {
var reg = new RegExp('(\\s|^)' + className + '(\\s|$)');
el.className=el.className.replace(reg, ' ');
}
}
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment