Twitch Multi-Redirect

Redirect Twitch with options

目前為 2016-09-04 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Twitch Multi-Redirect
// @namespace    RexOmni
// @version      1.0
// @description  Redirect Twitch with options
// @author       RexOmniFurtim
// @match        https://www.twitch.tv/*
// @exclude      https://www.twitch.tv/
// @exclude      https://www.twitch.tv/directory/*
// @grant        GM_getValue
// @grant        GM_setValue
// @run-at       document-idle
// @noframes
// ==/UserScript==

(function() {
    'use strict';

    ///////////
    // SETUP //
    ///////////
    var tmr = new Object();
    tmr.intervals = [];
    tmr.elements = [];
    tmr.options = [
        'TwitchLS',
        'Multitwitch'
    ];
    tmr.redirects = { // Redirect functions
        'twitchls' : function(){ window.location.replace('http://twitchls.com/' + tmr.channel); },
        'multitwitch' : function(){ window.location.replace('http://multitwitch.tv/' + tmr.channel); }
    };
    tmr.settings = new Object();
    // load settings
    tmr.settings.redirectTarget = GM_getValue("tmr-redirectTarget", 'twitchls');
    tmr.settings.redirectTimer = GM_getValue("tmr-redirectTimer", '850');

    tmr.channel = window.location.pathname.substring(1, window.location.pathname.length);
    console.log('%c' + tmr.channel, 'background: #3333ff; color: #fff; font-size: 22px;');

    ////////////
    // CREATE //
    ////////////

    // 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><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.savebtn = document.getElementById('TMR-Savebtn');

    // populate the drop-down, select
    var numOptions = tmr.options.length;
    for (var i = 0; i < numOptions; i++) {
        var option = document.createElement("option");
        option.text = tmr.options[i];
        option.value = tmr.options[i].toLowerCase();
        tmr.elements.select.add(option);
    }

    // save the selection
    tmr.elements.savebtn.onclick = function(){
        //save the data
        GM_setValue("twitchmultiredirect", tmr.elements.select.options[tmr.elements.select.selectedIndex].value);
        tmr.elements.container.style.display = 'none';
    };

    // on click anywhere stop redirect
    tmr.elements.container.onclick = function(){
        tmr.elements.container.onclick = null;
        console.log('%cStopping Redirect', 'background: #3333ff; color: #fff; font-size: 22px;');

        clearTimeout(tmr.intervals.redirect);
        tmr.elements.warning.style.display = 'none';
        tmr.elements.container.style.display = 'none';
        tmr.elements.settings.style.display = 'block';

        tmr.intervals.gear = setInterval(addGear, 250);
    };

    // Interval
    tmr.intervals.redirect = setTimeout(function(){

        if (shouldRedirect() ){

            // if the redirect target function is found is found
            if( tmr.redirects[tmr.settings.redirectTarget] !== null ){
                tmr.redirects[tmr.settings.redirectTarget]();
            }
            else{
                console.log("TMR: redirection target funciton not found");
                tmr.elements.container.click();
            }
        } // shouldRedirect
        else{
            tmr.elements.container.click();
        }
    }, tmr.settings.redirectTimer);

    // Check to see whether the redirect param is set to false
    function shouldRedirect(){
        var pathArray = /redirect=([^&]+)/.exec(window.location.href);
        
        if (pathArray === null){
            return true;
        }
        var param = pathArray[1];
        var result = param ? param : 'false';

        if (result == 'false'){
            return false;
        }

        return true;
    }

    // add the gear when the hcat popup is available
    function addGear(){
        var chatpopup = document.getElementsByClassName('js-chat-settings chat-settings chat-menu dropmenu');

        // if chat popup is found
        if (chatpopup.length > 0){
            clearInterval(tmr.intervals.gear);

            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.onclick = function(){
                tmr.elements.container.style.display = 'block';
                tmr.elements.select.selectedIndex = 0;
            };
        }
    }

    console.log('%c AutotwitchLS loaded! ', 'background: #333; color: #fff; font-size: 2em;');
})();