JSTRIS+ FIXED

Busca adicionar melhorias no JSTRIS

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         JSTRIS+ FIXED
// @namespace    http://tampermonkey.net/
// @version      0.64
// @description  Busca adicionar melhorias no JSTRIS
// @author       fix by Noblezito
// @match        *://*.jstris.jezevec10.com/*
// @grant        none
// ==/UserScript==

(function(){

    'use strict';

    const baseLoad = window.onload;
    window.onload = async () => {

        baseLoad();

        // Funções
        const $ = selector => document.querySelector(selector);
        const $$ = (selector, cb) => {
            const elements = document.querySelectorAll(selector);
            elements.forEach(cb);
            return elements;
        };
        const sleep = (s) => new Promise(resolve => setTimeout(resolve, s * 1000));
        const show_alert = (msg) => {

            const target = document.querySelector("#alert");
            target.innerHTML = msg;
            target.classList.add("showed");
            setTimeout(() => {target.classList.remove("showed")}, 3000);

        };
        const each = function(arr, cb){

            var breaked = false;
            for(var index in arr) {

                var value = arr[index];
                breaked = cb(value, index);
                if(breaked){
                    break
                }

            }
            return breaked;
        };
        const create = (elementName, configs = {}, append = null) => {

            const element = document.createElement(elementName);
            each(configs, (value, config) => {element[config] = value});
            if(append) element.append(append);
            return element;

        };
        const appendStyle = (elementName, style) => {

            if(style[style.length - 1] !== ";") style += ";";
            $(elementName).style = $(elementName).getAttribute("style") + style;

        };
        const toggleClass = (el, className) => {

            if(typeof el === "string") el = $(el);

            if(!el.classList.contains(className))
                el.classList.add(className);
            else
                el.classList.remove(className);

        };


        // Estilo
        const styleBlock = create("style", {innerHTML : styleText});

        // Alerta
        const alert = create("div", {
            id : "alert",
            onclick : function(){this.classList.remove("showed")}
        });


        // Sala Privada x1
        const privateRoomX1 = create("button", {
            innerHTML : "Sala Privada x1",
            onclick : async () => {

                $("#lobby").click();
                $("#createRoomButton").click();
                $("#more_adv").click();
                $("#hasSolid").checked = true;
                $("#isPrivate").checked = true;
                $("#hostStart").checked = true;
                $("#numPlayers").value = 2;
                $("#create").click();

                while(!$(".joinLink")) await sleep(.5);
                selectText($(".joinLink"));

                try {
                    const successful = document.execCommand('copy');
                    const msg = successful ? 'Link da sala copiado' : 'Erro ao copiar link da sala';
                    show_alert(msg);
                }catch(err){
                    show_alert("Erro ao copiar link da sala!");
                }

            }
        });
        // Sala Privada x100
        const privateRoomX100 = create("button", {
            innerHTML : "Sala Privada x100",
            onclick : async () => {

                $("#lobby").click();
                $("#createRoomButton").click();
                $("#more_adv").click();
                $("#hasSolid").checked = true;
                $("#isPrivate").checked = true;
                $("#hostStart").checked = true;
                $("#create").click();

                while(!$(".joinLink")) await sleep(.5);
                selectText($(".joinLink"));

                try {
                    const successful = document.execCommand('copy');
                    const msg = successful ? 'Link da sala copiado' : 'Erro ao copiar link da sala';
                    show_alert(msg);
                }catch(err){
                    show_alert("Erro ao copiar link da sala!");
                }

            }
        });
        // Show Chat Button
        const showChat = create("button", {
            innerHTML : "Chat",
            onclick : () => {toggleClass(".chatArea", "removed");toggleClass("#chatInputArea", "removed")}
        });


        const centerCanvas = create("li", {},
            create("a", {
                innerHTML : "Mudar Layout",
                onclick : () => {toggleClass("#gc", "center")}
            })
        );


        // Appends
        $("#buttonsBox").prepend(privateRoomX1);
        $("#buttonsBox").prepend(privateRoomX100);
        $("#buttonsBox").prepend(showChat);
        $("nav .navbar-nav").append(centerCanvas);
        $("body").append(styleBlock);
        $("body").append(alert);

        // Mudar os textos
        $("#settingsSave").innerHTML = "Salvar";
        $("#settingsReset").innerHTML = "Redefinir";
        $("#res").innerHTML = "Novo jogo";
        $("#statLabels span").innerHTML = "Tempo";

        // Expandir slots
        window.setInterval(() => {

            document.querySelectorAll(".slot").forEach(el => {

                el.onclick = function(){

                    const has = this.classList.contains("expanded");

                    $$(".slot",el => {
                        el.classList.remove("expanded");
                    });

                    if(!has)
                        toggleClass(this, "expanded");

                }

            })

        }, 2000);


    };

}());


// Preset
let baseH = 700;
let base2H = 500;
let baseW = 700;
let canvasW = 600;
let canvasH = 600;
let qCH = 500;
let stageW = 600;

const styleText = `
    body{
        background-color: #13181d!important;
        overflow-x: hidden!important;

    }

    nav > .container, nav{
        background-color: #090d11!important
    }
    nav{
        margin: 0!important;
    }
    #gc{
        height: calc(100vh - 60px)!important;
        overflow-y: auto!important;
        width: 100%!important;
        overflow-x: hidden!important;
        padding-left: 0;
    }
    #gc.center{
        margin-left: 20%!important;
    }
    #gameFrame{
        width: 100vw!important;
        margin: 0!important;
        padding-top: 20px!important;
    }
    #players{
        width: calc(100vw - 700px)!important;
        margin: !important;
    }
    #lrem{
        color: #fff!important;
    }
    #sprintText{
        color: #f1f1f1!important;
    }
    #main{
        width: 700px!important;
    }
    #holdCanvas{
        padding-left: 60px!important;
        margin-right: 35px!important;
    }
    #stage{
        width: 45%!important;
        height: 596px;
    }
    #rstage{
        height: 596px;
        margin-left: 0!important;
        width: 25%!important;
    }
    #buttonsBox{
        margin: 0!important;
        display: flex!important;
        flex-direction: column-reverse!important;
        width: calc(100% - 20px)!important;
        padding-bottom: 40px!important;
    }
    .modeBtns{top:425px!important;height:0px!important}
    #buttonsBox button{
        padding: 10px!important;
        border-radius: 10px!important;
        background-color: gray!important;
        font-weight: bold!important;
        border: 0!important;
        outline: none!important;
        color: #fff!important;
        margin-bottom: 10px!important;
    }

    #gstats{
        margin: 0!important;
        width: calc(100% - 20px)!important;
    }
    #statLabels{
        color: #fff!important;
    }
    #statLabels span{
        text-align: left!important;
    }
    #glstats{
        margin: 0!important;
        width: 73px!important;
    }
    #main > div:nth-child(4){
        position: absolute!important;
        bottom: 0!important;
        width: 30%!important;
        padding-left: 15px;
    }
    #bgLayer{
        height: 596px;
        width: 100%!important;
    }
    #myCanvas{
        height: 596px;
        width: 100%!important;
    }
    #queueCanvas{
        height: 480px;
        margin-left: 0!important;
        padding-left: 30px!important;
    }
    .gCapt{
        width: 100%!important;
    }
    #rInfoBox{
        margin: 0!important;
        padding-top: 14px!important;
    }
    #gameSlots{
        height: 596px;
        margin-bottom: 0!important;
    }
    .slots{margin-top: -10px}

    #chatInputArea{
        display:block;
        height: 50px!important;
        width: 50%!important;
    }

    #chatInputArea.removed{
        left:100%!important;
    }
    .chatArea{
        display: block;
        width: 50%!important;
        margin-top: 2.5%;
        height: 100px
    }
    .chatArea.removed{
        left:100%!important;
    }

    #resultsBox{
        width: 50%!important;
    }
    #chatBox{
        height: 100px!important;
        border-radius: 10px!important;
}

    #chatExpand{
    display:none}
    #frLobby{
    display:none}
    .chatInputC .warnI{bottom: 20px}


    #chatInput{
        height: 33px!important;
        margin: 0!important;
        border-radius: 10px!important;
        padding: 20px!important;
        color: #fff!important;
        background-color: rgb(81,81,81)!important;
        outline: none!important;
    }
    #sendMsg{
        border: 0!important;
        color: #fff!important;
        font-weight: bold!important;
        height: 40px!important;
        outline: none!important;
        border-radius: 10px!important;
        background-color: red!important;
    }

    #reportU{
        width: 50%!important;
    }
    #resultsBox{
        width: 50%!important;
    }


    #connectStatus{
        display: none!important;
    }
    .comboclass{
        top: -78px!important;
    }
    #practice-menu-big{
        width: 100%!important;
    }
    #settingsBox{
        top: 60px!important;
        width: 50vw!important;
        height: calc(100vh - 60px)!important;
        transition-duration: .25s!important;
        transition-duration: .25s;
        left: 50vw!important;
    }

    #settingsBox > button{
        border: 0!important;
        padding: 10px 15px!important;
        border-radius: 5px!important;
        background-color: red!important;
        color: #fff!important;
        width: 49%!important;
        margin: -1% 0.5% 0 0.5%!important;
        float: left!important;
        height: 40px!important;
        font-weight: bold!important;
        outline: none!important;
    }
    #settingsBox > button svg{
        display: none!important;
    }

    #settingsBox .settingsTabs{
        height: calc(100% - 40px)!important;
    }

    #settingsBox .setTab{
        height: calc(100% - 47px)!important;
        margin-top: 14px!important;
        border-radius: 0px 10px 10px!important;
        border-color: mediumpurple!important;
    }
    #tabsMenu a{
        background-color: red!important;
        border: 0!important;
        padding: 15px!important;
        border-radius: 10px 10px 0 0!important;
        color: #fff!important;
    }
    #tabsMenu a.active{
        background-color: lightpink!important;
        color: #212121!important;
    }
    #lobbyBox{
        height: calc(100vh - 60px)!important;
        top: -20px!important;
        left: 0%!important;
        width: calc(100vw - 700px)!important;
        margin: 0!important;
        border: 0!important;
        border-radius: 10px 0 0 10px!important;
        padding: 20px!important;
        transition-duration: .25s;
    }
    #lobbyBox.showed{
        left: 0!important;
    }

    #lobbyBottom button{
        border: 0;
        padding: 10px 15px!important;
        border-radius: 10px!important;
        background-color: red!important;
        color: #fff!important;
        height: 40px!important;
        font-weight: bold!important;
        outline: none!important;
    }
    #lobbyBottom svg{display: none!important}
    #editRoomButton{background-color: #ffc107!important;}
    #alert{
        position: absolute;
        padding: 15px 40px;
        background-color: red;
        color: #fff;
        left: 50vw;
        border-radius: 10px;
        transform: translateX(-50%);
        bottom: 20px;
        font-weight: bold;
        opacity: 0;
        transition-duration: .25s;
        font-size: 16px;
    }
    #alert.showed{
        opacity: 1;
        z-index: 999;
    }
    #buttonsBox button:enabled{
        background-color: #ffc107!important;
        color: black!important;
    }
    #buttonsBox button:disabled{
        color: black!important;
        background-color: red!important;
    }
    #buttonsBox button#res:disabled::after,button:disabled{color:black}

    .slot{
        cursor: pointer!important;
    }
    .slot.expanded{
        z-index: 999!important;
        top: 15px!important;
        width: 150px!important;
        left: 500px!important;
    }
    .slot.expanded canvas{
        width: 150px!important;
    }
    .slot.expanded > div{
        margin-top: 10px!important;
    }
    .slot.expanded > span{
        background-color: #212121!important;
        text-align: center!important;
        width: 150px!important;
        height: 50px!important;
    }
    .slot.expanded .bgLayer{
        background-color: #212121!important;
    }
    .slot.expanded a{
       font-size: 16px!important;
    }
    nav a{cursor:pointer!important}
`;