Skip to content

Instantly share code, notes, and snippets.

@thekalinga
Last active September 17, 2020 19:52
Show Gist options
  • Save thekalinga/b754dc7f3979bfad6bfa217a9e521afc to your computer and use it in GitHub Desktop.
Save thekalinga/b754dc7f3979bfad6bfa217a9e521afc to your computer and use it in GitHub Desktop.
Twitter- Prepare tweets for screenshots
// ==UserScript==
// @name Twitter: Prepare tweets for screenshots
// @namespace http://tampermonkey.net/
// @version 0.1
// @description try to take over the world!
// @author You
// @match https://*twitter.com/*/status/*
// @grant none
// ==/UserScript==
(function() {
'use strict';
function undo() {
addToggleableClasses();
removeClass(document.getElementsByTagName('body')[0], 'toggle');
toggle.src = showNavIcon;
}
function apply() {
addToggleableClasses();
addClass(document.getElementsByTagName('body')[0], 'toggle');
toggle.src = hideNavIcon;
}
function addToggleClass(el) {
if (!hasClass(el, 'toggleable')) {
addClass(el, 'toggleable');
}
}
function addToggleableClasses() {
document.querySelectorAll('h2[role="heading"]').forEach(heading => {
if (heading.textContent === 'Tweet') {
var container = heading.parentNode.parentNode
.parentNode.parentNode
.parentNode.parentNode
.parentNode.parentNode;
addToggleClass(container);
}
});
var actionContainers = document.querySelectorAll('div[aria-label*="replies"]');
actionContainers.forEach(actionContainer => {
addToggleClass(actionContainer);
});
actionContainers = document.querySelectorAll('div[aria-label*="reply"]');
actionContainers.forEach(actionContainer => {
addToggleClass(actionContainer);
});
actionContainers = document.querySelectorAll('div[aria-label*="Reply"]');
actionContainers.forEach(actionContainer => {
var container = actionContainer.parentNode.parentNode;
addToggleClass(container);
});
var analyticsLinks = document.querySelectorAll('a[href$="/analytics"]');
analyticsLinks.forEach(analyticsLink => {
addToggleClass(analyticsLink);
});
var statInfoLinks = document.querySelectorAll('a[href$="/retweets"]');
statInfoLinks.forEach(statInfoLink => {
var statInfoContainer = statInfoLink.parentNode.parentNode;
addToggleClass(statInfoContainer);
});
document.querySelectorAll('span').forEach(threadHeaderSpan => {
if (threadHeaderSpan.textContent === 'Thread') {
var container = threadHeaderSpan;
do {
container = container.parentNode;
} while (container.parentNode.parentNode.dataset.testid !== 'primaryColumn');
addToggleClass(container);
}
});
// for tweets of one's own
document.querySelectorAll('span').forEach(likesSpan => {
if (likesSpan.textContent === 'Likes' || likesSpan.textContent === 'Like') {
var container = likesSpan.parentNode.parentNode
.parentNode;
addToggleClass(container);
}
});
document.querySelectorAll('span').forEach(addAnotherTweetSpan => {
if (addAnotherTweetSpan.textContent === 'Add another Tweet') {
var container = addAnotherTweetSpan;
do {
container = container.parentNode;
} while (!container.hasAttribute('href'));
addToggleClass(container.parentNode.parentNode);
}
});
// blacken
document.querySelectorAll('time').forEach(timeEl => {
var headerRow = timeEl.parentNode.parentNode.parentNode.parentNode.parentNode;
addToggleClass(headerRow);
var profilePicContainer = headerRow.parentNode.previousSibling;
addToggleClass(profilePicContainer);
// var garbageContainer = headerRow.parentNode.previousSibling;
// addToggleClass(garbageContainer);
});
document.querySelectorAll('[data-testid="tweet"]').forEach(tweet => {
addToggleClass(tweet.previousSibling);
});
document.querySelectorAll('[data-testid="tweet"]').forEach(tweet => {
if (tweet.childNodes[1].childNodes[1]?.childNodes?.length == 4) {
addToggleClass(tweet.childNodes[1].childNodes[1].childNodes[0]);
}
});
var anchorNode = document.evaluate("//span[contains(., 'Twitter Web App')]", document, null, XPathResult.ANY_TYPE, null).iterateNext();
if (anchorNode !== null) {
var heading = anchorNode.parentNode.parentNode.parentNode.parentNode.parentNode.previousSibling;
addToggleClass(heading);
}
}
var showing = false;
var hideNavIcon = '';
var showNavIcon = '';
var toggle = document.createElement('img');
toggle.src = showNavIcon;
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 .toggleable {
display: none;
}
.toggle article div {
font-size: 15px !important;
}
/*
.toggle .toggle-blacken {
color: black;
background-color: black;
}
*/
`;
document.getElementsByTagName('head')[0].appendChild(newStyleToBeApplied);
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