NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Twitch Multi-Redirect // @namespace RexOmni // @version 1.2 // @description Redirect Twitch with options // @author RexOmniFurtim // @match https://www.twitch.tv/* // @exclude https://www.twitch.tv/directory/* // @grant GM_getValue // @grant GM_setValue // @run-at document-start // @noframes // ==/UserScript== (function() { 'use strict'; // if not top frame, stop if (frameElement) { return; } /////////// // SETUP // /////////// let tmr = { }; tmr.intervals = []; tmr.elements = []; tmr.options = [ 'TwitchLS', 'Multitwitch' ]; tmr.redirects = { // Redirect functions 'TwitchLS' : ()=> { window.location.replace('http://twitchls.com/' + tmr.channel); }, 'Multitwitch' : ()=>{ window.location.replace('http://multitwitch.tv/' + tmr.channel); } }; tmr.settings = { }; // load settings tmr.settings.redirectTarget = GM_getValue("tmr-redirectTarget", 'TwitchLS'); tmr.settings.redirectTimer = GM_getValue("tmr-redirectTimer", 2000); tmr.channel = window.location.pathname.substring(1, window.location.pathname.length); /////////// // START // /////////// // redirect immediately if redirect set to 0 if(tmr.settings.redirectTimer === 0 && shouldRedirect()){ console.log('redirecting early'); redirect(); return; } else{ document.addEventListener("DOMContentLoaded", ()=> { createBlock(); // If the url says not to redirect, stop the redirect if( !urlParamRedirect() ){ tmr.elements.container.click(); } }); } /////////////// // FUNCTIONS // /////////////// // redirect to the target function redirect(){ tmr.redirects[tmr.settings.redirectTarget](); } function setRedirectTimeout(){ tmr.intervals.redirect = setTimeout(()=>{ // if the redirect target function is found is found if( tmr.redirects[tmr.settings.redirectTarget] !== null ){ // let the user know navigation has begun tmr.elements.warning.style.background = 'black'; // activate naviagtion function redirect(); } else{ console.log("TMR: redirection target funciton not found"); cancelRedirect(); } }, tmr.settings.redirectTimer); } function cancelRedirect(){ clearTimeout(tmr.intervals.redirect); tmr.intervals.redirect = null; tmr.elements.container.onclick = null; console.log('%cStopping Redirect', 'background: #3333ff; color: #fff; font-size: 22px;'); tmr.elements.warning.style.display = 'none'; tmr.elements.container.style.display = 'none'; tmr.elements.settings.style.display = 'block'; addGear(); } function createBlock(){ // create and add div tmr.elements.container = document.createElement('div'); tmr.elements.container.innerHTML = ' <div style="width:100%;height:100%;position:absolute;background:rgba(255,0,0,0.5);z-index:99999;text-align:center;cursor:pointer;"> <div style="background:white;padding: 2rem;margin: 2rem;"> <p style="font-size:6rem;">Twitch Multi-Redirect</p> <hr style="margin-top: 3rem;"> <div id="TMR-Warning" style="margin-top:2rem;display:block;"> <p style="font-size: 2rem; background: rgba(0,0,255,.4); padding-bottom: 0.5rem;">Click anywhere to stop redirecting</p> </div> <div id="TMR-Settings" style="margin-top:2rem;display:none"> <p style="font-size:4rem;background:rgba(0,125,125,.5);padding-bottom:2rem;padding-top:1rem;">Settings</p> <div style="width: 100%;margin-top: 2rem;"> <span style="padding-right:.7rem">Redirection target</span><select id="TMR-Select"> </select><br><span style="padding-right:.7rem">Wait (ms)</span><input type=Number value=850 id="TMR-Timer"/> <br> <input id="TMR-Savebtn" type="button" value="Save"> </div> </div> </div> </div>'; document.body.insertBefore(tmr.elements.container, document.body.firstChild); tmr.elements.warning = document.getElementById("TMR-Warning"); tmr.elements.settings = document.getElementById("TMR-Settings"); tmr.elements.select = document.getElementById("TMR-Select"); tmr.elements.timer = document.getElementById('TMR-Timer'); tmr.elements.savebtn = document.getElementById('TMR-Savebtn'); // populate the drop-down, select let numOptions = tmr.options.length; for (let i = 0; i < numOptions; i++) { let option = document.createElement("option"); option.text = tmr.options[i]; option.value = tmr.options[i]; //option.setAttribute("id", "TMR-" + tmr.options[i]); tmr.elements.select.add(option); } // set the setting elements to setting values // TODO: Get the value of select to equal the right element //tmr.elements.select.value = document.getElementById("TMR-" + tmr.settings.redirectTarget); //console.log(document.getElementById("TMR-" + tmr.settings.redirectTarget)); tmr.elements.select.selectedIndex = tmr.options.indexOf(tmr.settings.redirectTarget); tmr.elements.timer.value = Number(tmr.settings.redirectTimer); // save the selection tmr.elements.savebtn.onclick = ()=>{ //save the data GM_setValue("tmr-redirectTarget", tmr.elements.select.value); GM_setValue("tmr-redirectTimer", tmr.elements.timer.value); tmr.elements.container.style.display = 'none'; }; // start the redirect Timeout setRedirectTimeout(); // on click anywhere stop redirect tmr.elements.container.onclick = ()=>{cancelRedirect();}; } // Return the redirect url param as bool function urlParamRedirect(){ let pathArray = /redirect=([^&]+)/.exec(window.location.href); // deault behavior if (pathArray === null){ return true; } return ( pathArray[1] === '0' ) ? false : true; } // Returns whether the page should redirect // Keep for inclusion of other checks when they are ported. function shouldRedirect(){ return urlParamRedirect(); } // add the gear when the hcat popup is available function addGear(){ // wait until chat popup available let gearInterval = setInterval(()=>{ let chatpopup = document.getElementsByClassName('chat-settings chat-menu dropmenu'); if(chatpopup.length > 0){ clearInterval(gearInterval); gearInterval = null; tmr.elements.gear = document.createElement('div'); tmr.elements.gear.innerHTML = '<div style="cursor:pointer;background: rgba(237,237,237,0.7);padding: 0.5rem 10rem 0.2rem 1.3rem;"> <img src="" style=" width: 15%;"> <span style="">TMR Settings</span> </div>'; chatpopup[0].insertBefore(tmr.elements.gear, chatpopup[0].firstChild); // Gear onclick function; tmr.elements.gear.addEventListener('click', ()=>{ tmr.elements.container.style.display = 'block'; }); } }, 100); } console.log('%c AutotwitchLS loaded! ', 'background: #333; color: #fff; font-size: 2em;'); })();