(function($TD, $TDX){ // // Variable: Collection of all <a> tags. // var links = document.getElementsByTagName("A"); // // Function: Adds an event listener to all elements in the array or collection. // var addEventListener = function(collection, type, listener){ for(let index = 0; index < collection.length; index++){ collection[index].addEventListener(type, listener); } }; // // Block: Hook into links to bypass default open function. // addEventListener(links, "click", function(e){ $TD.openBrowser(e.currentTarget.getAttribute("href")); e.preventDefault(); if ($TDX.skipOnLinkClick){ let parentClasses = e.currentTarget.parentNode.classList; if (parentClasses.contains("js-tweet-text") || parentClasses.contains("js-quoted-tweet-text") || parentClasses.contains("js-timestamp")){ $TD.loadNextNotification(); } } }); // // Block: Allow bypassing of t.co in context menus. // addEventListener(links, "contextmenu", function(e){ $TD.setLastRightClickedLink(e.currentTarget.getAttribute("data-full-url") || ""); }); // // Block: Expand shortened links on hover or display tooltip. // (function(){ var cutStart = function(str, search){ return str.startsWith(search) ? str.substr(search.length) : str; }; var prevMouseX = -1, prevMouseY = -1; var tooltipTimer, tooltipDisplayed; addEventListener(links, "mouseenter", function(e){ var me = e.currentTarget; var url = me.getAttribute("data-full-url"); if (!url)return; var text = me.textContent; if (text.charCodeAt(text.length-1) !== 8230){ // horizontal ellipsis return; } if ($TDX.expandLinksOnHover){ tooltipTimer = window.setTimeout(function(){ var expanded = url; expanded = cutStart(expanded, "https://"); expanded = cutStart(expanded, "http://"); expanded = cutStart(expanded, "www."); me.setAttribute("td-prev-text", text); me.innerHTML = expanded; }, 200); } else{ tooltipTimer = window.setTimeout(function(){ $TD.displayTooltip(url, true); tooltipDisplayed = true; }, 400); } }); addEventListener(links, "mouseleave", function(e){ if (!e.currentTarget.hasAttribute("data-full-url"))return; if ($TDX.expandLinksOnHover){ var prevText = e.currentTarget.getAttribute("td-prev-text"); if (prevText){ e.currentTarget.innerHTML = prevText; } } window.clearTimeout(tooltipTimer); if (tooltipDisplayed){ tooltipDisplayed = false; $TD.displayTooltip(null, true); } }); addEventListener(links, "mousemove", function(e){ if (tooltipDisplayed && (prevMouseX !== e.clientX || prevMouseY !== e.clientY)){ var url = e.currentTarget.getAttribute("data-full-url"); if (!url)return; $TD.displayTooltip(url, true); prevMouseX = e.clientX; prevMouseY = e.clientY; } }); })(); // // Block: Setup a skip button. // (function(){ if (document.body.hasAttribute("td-example-notification")){ return; } document.body.insertAdjacentHTML("afterbegin", [ '<svg id="td-skip" xmlns="http://www.w3.org/2000/svg" width="10" height="17" viewBox="0 0 350 600" style="position:fixed;left:30px;bottom:10px;z-index:1000">', '<path fill="#888" d="M0,151.656l102.208-102.22l247.777,247.775L102.208,544.986L0,442.758l145.546-145.547">', '</svg>' ].join("")); document.getElementById("td-skip").addEventListener("click", function(){ $TD.loadNextNotification(); }); })(); // // Block: Setup a hover class on body. // document.body.addEventListener("mouseenter", function(){ document.body.classList.add("td-hover"); }); document.body.addEventListener("mouseleave", function(){ document.body.classList.remove("td-hover"); }); })($TD, $TDX);