Playok Backgammon Auto-Roll

Auto pass and auto roll for playok.com backgammon game

// ==UserScript==
// @run-at document-start
// @name         Playok Backgammon Auto-Roll
// @namespace    http://tampermonkey.net/
// @version      0.90
// @description  Auto pass and auto roll for playok.com backgammon game
// @author       Crowo
// @match        https://www.playok.com/*/backgammon/
// @match        https://www.playok.com/tr/tavla/
// @match        https://www.playok.com/el/tavli/
// @match        https://www.playok.com/ro/table/
// @match        https://www.playok.com/bg/tabla/
// @match        https://www.kurnik.pl/tryktrak/
// @match        https://www.playok.com/et/triktrakk/
// @match        https://www.playok.com/lv/bekgemons/
// @match        https://www.playok.com/sq/lojetavelle/
// @match        https://www.playok.com/ru/nardy/
// @match        https://www.playok.com/lt/nardai/
// @match        https://www.playok.com/pt/gamao/
// @match        https://www.playok.com/hu/triktrak
// @match        https://www.playok.com/cs/vrhcaby//

// @grant        none
// ==/UserScript==

(function setupAutoRoll() {
    'use strict';
    var btnStart = document.getElementsByClassName("lbprm")[0];
    if(btnStart) {
        window.name = "bg";
        btnStart.click();
        return;
    }
    window.onload = null;


    function removeScript(){
        const scriptTag = document.querySelector('script[src*="bg.js"]');

        if (!scriptTag)
            return false;
        var scriptSrc = scriptTag.src;
        scriptTag.remove();
        var xhr = new XMLHttpRequest();
        xhr.open("GET", scriptTag.src);
        xhr.onreadystatechange = function () {
            if(xhr.readyState === XMLHttpRequest.DONE && xhr.status === 200) {
                var script = xhr.responseText;
                var ix = script.lastIndexOf("for(a=this.fa.length-1;0<=a;a--)");
                if(ix > -1) {
                    script = script.substring(0, ix) + "calcPips(this.fa);" + script.substring(ix);
                    //eval(script);
                    var elm = document.createElement("script");
                    elm.innerHTML = script;
                    document.body.appendChild(elm);
                    var html = document.documentElement.outerHtml;
                    //var html = new XMLSerializer().serializeToString(document);
                    document.open();
                    document.write(html);
                    document.close();
                    document.body.removeChild(document.body.firstChild);

                    try{
                        k2start();
                    }
                    catch(err){
                        alert("smt wrong");
                        setTimeout(function retry(){
                            try{
                                k2start();
                            }
                            catch(err){
                                setTimeout(retry, 100);
                            }
                        }, 100);
                    }
                }
            }
        };
        xhr.send();
        return true;
    }
    if(!removeScript())
        new MutationObserver((_, observer) => {
            if(removeScript())
                observer.disconnect();
        }).observe(document.documentElement, { childList: true, subtree: true });


    var dialogs = document.getElementsByClassName("ctpan");
    if(dialogs.length != 3){
        setTimeout(setupAutoRoll, 100);
        return;
    }

    window.calcPips = function(ua){
        window.ua = ua;
        var pip1 = 0;
        var pip2 = 0;
        var num;
        for(var i = 0; i < ua.length; i++){
            if(ua[i].color > 1 || (num = ua[i].x) < 1)
                continue;
            if(num == 7)
                num = 0;
            else if(num == 20)
                num = 25;
            else if(num < 7){
            }
            else if(num < 20)
                num--;
            else
                num -= 2;
            if(ua[i].color == 0)
                pip1 += num;
            else
                pip2 += (25 - num);
        }
        if(pip1Div){
            pip1Div.innerText = "PIP#1: " + pip1;
            pip2Div.innerText = "PIP#2: " + pip2;
        }
    };

    var css = document.createElement("style");
    css.innerText = '.modal {display: none;position: fixed;z-index: 9999;left: 0;top: 0;width: 100%;height: 100%;overflow: auto;background-color: rgb(0,0,0);background-color: rgba(0,0,0,0.4);} .modal-content {background-color: #fefefe;margin: 15% auto;padding: 20px;border: 1px solid #888;width: 80%;}';
    document.body.appendChild(css);
    var modal = document.createElement("div");
    modal.className = "modal";
    var modalContent = document.createElement("div");
    modalContent.className = "modal-content";
    modal.appendChild(modalContent);
    document.body.appendChild(modal);
    window.addEventListener("click", function(e){if(e.target == modal) modal.style.display = "none";});


    var container = document.getElementsByClassName("sbclrd")[0];
    var backgroundColors = ["#fbb", "#9ce", "#9ce"];
    var originalTitle = document.title;
    var whiteImage = "";
    var orgWhiteImage = "";
    var redImage = "";
    var orgRedImage = "";
    var whiteImages = [orgWhiteImage, whiteImage, orgWhiteImage];
    var redImages = [redImage, orgRedImage, orgRedImage];
    var lastTurn = 2;
    function getPlayerRating(playerName){
        var rows = document.getElementsByClassName("uls2")[0].rows;
        for(var i = 1; i < rows.length; i++){
            if(rows[i].cells[0].firstElementChild.firstElementChild && rows[i].cells[0].firstElementChild.firstElementChild.nextSibling.textContent === playerName)
                return rows[i].cells[2].innerText;
        }
    }
    function appendRating(playerNo){
        var pName = document.getElementsByClassName("f12")[playerNo].nextElementSibling.lastElementChild.lastElementChild.innerText;
        if(!pName)
            return;
        var parent = document.getElementsByClassName("f12")[playerNo];
        if(parent.firstElementChild)
        {
            var textNode = parent.firstElementChild.nextSibling;
            if(!pName || pName == "")
                textNode.textContent = "#" + (playerNo + 1);
            else{
                textNode.textContent = "(" + getPlayerRating(pName) + ")";
                var info = document.createElement("button");
                info.style.padding = 0;
                info.style.margin = 0;
                info.innerText = "Info";
                info.onclick = function(){
                    var xhr = new XMLHttpRequest();
                    xhr.open("GET", k2url.home + "stat.phtml?u=" + pName + "&g=bg");
                    xhr.onreadystatechange = function () {
                        if(xhr.readyState === XMLHttpRequest.DONE && xhr.status === 200) {
                            var html = xhr.responseText;
                            var ix = html.indexOf('<div class="clcol">');
                            var ix2 = html.indexOf('</div>', ix);
                            modalContent.innerHTML = html.substring(ix, ix2);
                            modal.style.display = "block";
                        }
                    };
                    xhr.send();
                };
                parent.appendChild(info);
            }
        }
    }
    var timeout;
    var observer = new MutationObserver(function() {
        var turn = 2;
        if(document.getElementsByClassName("f12")[0].lastElementChild.style.visibility == "inherit") {
            turn = 0;
        }
        else if(document.getElementsByClassName("f12")[1].lastElementChild.style.visibility == "inherit")
            turn = 1;
        if(turn != 2)
            document.title = originalTitle + " #" + (turn + 1) + ">" + document.getElementsByClassName("ttlcont")[0].nextElementSibling.childNodes[0].childNodes[turn].childNodes[2].childNodes[1].innerText;
        observer.disconnect();
        appendRating(0);
        appendRating(1);
        observer.observe(document.getElementsByClassName("ttlcont")[0].nextElementSibling, {childList: true, subtree: true});

        if(turn == lastTurn)
        {
            if(timeout)
            {
                clearTimeout(timeout);
                timeout = 0;
            }
            return;
        }
        if(!document.hasFocus())
            timeout = setTimeout(function(){new Audio('data:audio/wav;base64,UklGRl9vT19XQVZFZm10IBAAAAABAAEAQB8AAEAfAAABAAgAZGF0YU'+Array(1e3).join(123)).play(); timeout = 0;}, 1000);
        var images = document.querySelectorAll("img[src^='data:image/png'");
        for(var i = 0; i < images.length; i++){
            if(images[i].getAttribute("src") === orgWhiteImage ||images[i].getAttribute("src") === whiteImage)
                images[i].setAttribute("src", whiteImages[turn]);
            else if(images[i].getAttribute("src") === orgRedImage ||images[i].getAttribute("src") === redImage)
                images[i].setAttribute("src", redImages[turn]);
        }

        document.getElementsByClassName("sbclrd")[0].style.backgroundColor =  backgroundColors[turn];
        lastTurn = turn;
    });
    observer.observe(document.getElementsByClassName("ttlcont")[0].nextElementSibling, {childList: true, subtree: true});

    new MutationObserver(function(){ //click pass
        if(dialogs[2].style.display !== "none")
            dialogs[2].childNodes[0].childNodes[0].click();
    }).observe(dialogs[2], {attributes: true});
    document.getElementsByClassName("trqcont")[0].firstElementChild.insertAdjacentHTML("afterEnd", '<div style="line-height: initial; padding: 3px 0 32px 0;"><div style="float: left;"><div><input type="checkbox" id="chkAutoRoll" checked="true" onchange="autoRollChanged(this.checked);" /><label for="chkAutoRoll">Auto-Roll</label></div><div><input type="checkbox" id="chkDouble" /><label for="chkDouble">Double Next Turn</label></div></div><div style="float: left; margin-left: 14px;"><div id="pip1"></div><div id="pip2"></div></div></div>');
    var pip1Div = document.getElementById("pip1");
    var pip2Div = document.getElementById("pip2");
    var targetNode = dialogs[1];
    var btnRoll = targetNode.childNodes[0].childNodes[0];
    var btnDouble = document.getElementsByClassName("ctpan")[1].childNodes[0].childNodes[1];
    var chkAutoRoll = document.getElementById("chkAutoRoll");
    var chkDouble = document.getElementById("chkDouble");

    new MutationObserver(function(){ //click roll
        if(targetNode.style.display === "none")
            return;
        if(chkDouble.checked && !btnDouble.disabled) {
            btnDouble.click();
            chkDouble.checked = false;
            return;
        }
        if(chkAutoRoll.checked) {
            btnRoll.click();
        }
        if(chkAutoRoll.checked)
            btnRoll.click();
    }).observe(targetNode, {attributes: true});

    var cssHide = document.createElement("style");
    cssHide.innerHTML = "div.ctpan:nth-of-type(n+2), div.ctpan:nth-of-type(n+2) * { visibility: hidden; position: fixed; top: -9999px; left: -9999px; }";
    document.body.appendChild(cssHide);

    window.autoRollChanged = function(autoRoll){
        if(autoRoll){
            document.body.appendChild(cssHide);
            if(targetNode.style.display !== "none")
                btnRoll.click();
        }
        else
            document.body.removeChild(cssHide);
    };
})();