Last active
August 25, 2019 02:59
-
-
Save disco0/93394f437762d748bdf08fec7c9bb99e to your computer and use it in GitHub Desktop.
Force Twitter feed to display latest tweets
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name TwitterLiveFeed | |
// @author disk0 | |
// @description Force Twitter feed to display latest tweets | |
// @version 0.1.1 | |
// @run-at document-idle | |
// @namespace disk0/twitter | |
// @icon  | |
// @updateUrl https://gist.githubusercontent.com/disco0/93394f437762d748bdf08fec7c9bb99e/raw | |
// @downloadUrl https://gist.githubusercontent.com/disco0/93394f437762d748bdf08fec7c9bb99e/raw | |
// @match https://*.twitter.com/* | |
// @grant GM_info | |
// ==/UserScript== | |
( async () => { | |
// console wank | |
const log = (msg) => console.log( `[${GM_info.script.name}]`, msg ); | |
// Set default timeout time | |
const timeoutDef = 500; | |
// Element selectors used to target/navigate page | |
const headerSel = `[data-testid="primaryColumn"] h2[aria-level="2"][role="heading"]`; | |
const menuSel = `[aria-label="Top Tweets on"]`; | |
const buttonSel = `[role="menu"] [role="button"]`; | |
// Define stuff | |
const waitSelector = function($selector, $timeout = timeoutDef || 2000) { | |
return new Promise((resolve, reject) => { | |
const startTimeout = () => setTimeout(() => reject(), $timeout); | |
if (typeof $selector === "undefined") { reject(); } | |
const waitForElement = function() { | |
let el = document.querySelector($selector); | |
if (el) | |
{ | |
resolve(el); | |
} | |
else | |
{ | |
window.requestAnimationFrame(waitForElement); | |
} | |
}; | |
startTimeout(); | |
waitForElement(); | |
}); | |
}; | |
const waitClick = function($selector, $msgSucc, $timeout) { | |
return new Promise((resolve, reject) => { | |
waitSelector($selector, $timeout) | |
.then(el => { | |
if (el.click) | |
{ | |
el.click(); | |
if ($msgSucc) log($msgSucc); | |
resolve(el); | |
} | |
else | |
{ | |
reject(`Element not clickable.`); | |
} | |
}) | |
.catch(reject); | |
}); | |
}; | |
// Do stuff | |
try | |
{ | |
let headerEl = await waitSelector(headerSel); | |
if (headerEl.textContent === `Latest Tweets`) | |
{ | |
log(`Currently viewing latest tweets`); | |
return; | |
} | |
await waitClick(menuSel); | |
await waitClick(buttonSel, `\tTimeline updated.`); | |
} | |
catch { } | |
})(); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment