Drawaria.online Scripts Original (Reupload)

just a compilation of random scripts

// ==UserScript==
// @name         Drawaria.online Scripts Original (Reupload)
// @namespace    http://tampermonkey.net/
// @version      1.5.1
// @description  just a compilation of random scripts
// @match        https://*.drawaria.online/*
// @require      https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/jquery-cookie/1.4.1/jquery.cookie.min.js
// @author       Jkhenz
// @icon         
// @grant        none
// ==/UserScript==


(function ($, undefined) {
    $(function () {

        let curUrl = location.href;
        if(curUrl.includes('drawaria.online/avatar/builder')){

            //Avatar Builder
            let wait;
            Start();

            function Start(){
                wait = setInterval(function(){
                    if($('.Canvas').length === 1){
                        Avatar();
                        AvatarAlt();
                        StopWaiting();
                    }
                }, 200);
            }

            function StopWaiting(){
                clearInterval(wait);
            }

            function Avatar(){
                $('header').append('<label class="Button" for="image_input">Upload Image</label><input style="display:none" id="image_input" type="file" accept=".jfif, .jpg, .png">');
                let uploaded_image;
                $("#image_input").change(function() {
                    const reader = new FileReader();
                    if(this.files[0].size<7000000){
                        reader.addEventListener('load', function (){
                            uploaded_image = reader.result;
                            if(LOGGEDIN){
                                $.post("/saveavatar", {
                                    "avatarsave_builder":(`${JSON.stringify(ACCOUNT_AVATARSAVE)}`),
                                    "imagedata": (`${uploaded_image}`),
                                    "fromeditor": false
                                })
                            }else{
                                localStorage.setItem("avatarimagedata",(`${uploaded_image}`));
                                $.removeCookie('wt', { path: '/' });
                            }
                            $('label')[0].innerHTML = "Saving...";
                            setInterval(function(){
                                $('label')[0].innerHTML = "Save OK!";
                                let curUrl = window.location.href;
                                let domain = curUrl.replace("avatar/builder/","");
                                window.location.href = domain;
                            }, 2000);

                        });
                        reader.readAsDataURL(this.files[0]);
                    }
                    else{
                        alert("image file size is too large");
                    }
                });

            }
            function AvatarAlt(){
                $('.Canvas').append('<label for="image_input2" style="width:128px; height:128px; position:absolute; cursor:pointer" ><input style="display:none" id="image_input2" type="file" accept="image/*" >');

                let uploaded_image2;
                $("#image_input2").change(function() {
                    const reader = new FileReader();

                    reader.addEventListener('load', function (){
                        uploaded_image2 = reader.result;
                        imgChange(uploaded_image2);

                    });
                    reader.readAsDataURL(this.files[0]);

                });

            }
            function imgChange(imagePath) {
                var canvas=document.getElementsByClassName("main")[0];
                var ctx=canvas.getContext("2d");
                var img=new Image();
                img.onload = function(){

                    ctx.clearRect(0, 0, canvas.width, canvas.height);
                    ctx.drawImage(img,0,0,canvas.width,canvas.width);
                };
                img.src=imagePath;
            }

        }else{
            let rightBar = $("#rightbar");
            $('<div id="assistPanel">').insertAfter(rightBar.children()[3]);

            //join in a room
            let joinRoomObserver = new MutationObserver(function(mutations) {
                if(mutations[0].target.textContent.includes('Word guessing')){
                    Status();
                    AutoStar();
                    WordHints();
                }else{
                    Token();
                    Status();

                }
                joinRoomObserver.disconnect();
            });
            joinRoomObserver.observe($('#infotext')[0], {childList: true });
        }

        //Token
        function Token(){
            let tokens = [
                {val : 'random', text: 'Random'},
                {val : 'fa-thumbs-up', text: 'Like'},
                {val : 'fa-heart', text: 'Heart'},
                {val : 'fa-paint-brush', text: 'Paint Brush'},
                {val : 'fa-cocktail', text: 'Cocktail'},
                {val : 'fa-hand-peace', text: 'Peace'},
                {val : 'fa-feather-alt', text: 'Feather'},
                {val : 'fa-trophy', text: 'Trophy'},
                {val : 'fa-mug-hot', text: 'Coffee'},
                {val : 'fa-gift', text: 'Gift'}
            ];
            $("#assistPanel").append('<div id="tokenPanel" style="margin-top:0.4rem; display: flex; flex-direction: column;"><button id="give">Give Token</button></div>');
            let tokenSel = $('<select id="selToken"style="width:100%">').prependTo("#tokenPanel");
            $(tokens).each(function() {
                tokenSel.append($("<option>").attr('value',this.val).text(this.text));
            });

            $("#give").click(function() {
                if($('#infotext').children()[0].textContent.includes("Word guessing")){
                    alert('not working in guessing game');
                    return;
                }
                GiveToken();
            });

            if(localStorage.getItem('lastToken')==null){
                localStorage.setItem('lastToken','random');
            }
            let selToken=$('#selToken')[0];
            selToken.value = localStorage.getItem('lastToken');

            function GiveToken(){
                if($('.playerlist-name-loggedin').length===0){
                    alert('no loggedin players to give token' );
                    return;
                }
                for(let i=0 ; i < $('.playerlist-name-loggedin').length;i++){
                    $('.playerlist-name-loggedin')[i].click();
                    if($('.playerlist-menu-playername')[i].textContent =="­­" || $('.playerlist-menu-playername')[i].textContent =="Liy Lalire" || selToken.value == "random"){
                        let arr=[];
                        for(let j =0; j<9;j++){
                            if($('.playerlist-tokens > .' + tokens [j+1].val)[i].innerHTML==''){
                                arr.push(0);
                            }else{
                                arr.push(parseInt($('.playerlist-tokens > .' + tokens [j+1].val)[i].innerHTML));
                            }
                        }
                        let min = Math.min.apply(Math, arr);
                        let ind = arr.indexOf(min);
                        $('.playerlist-tokens > .' + tokens[ind+1].val)[i].click();
                    }else{
                        $('.playerlist-tokens > .' + tokens[selToken.selectedIndex].val)[i].click();
                    }
                }
                localStorage.setItem('lastToken',selToken.value);
                $('.playerlist-menu-hidebutton').click();
                $("#give").prop("disabled",true);
                setTimeout(function(){ $("#give").prop("disabled",false) }, 300)
            }
        }

        //Status
        function Status(){
            let status = [
                {val : 0, text: 'Music Enabled'},
                {val : 1, text: 'AFK 1'},
                {val : 2, text: 'AFK 2'},
                {val : 3, text: 'Inventory Open'},
                {val : 4, text: 'Friend List Open'}
            ];

            $("#assistPanel").append('<div id="statusPanel" style="margin-top:0.4rem; display: flex; flex-direction: column;"><button id="togStats">Toggle Status</button><div id="toggleAll" style="display: flex; flex-direction: row;justify:center;"><button style="flex:1" id="addAll" >Add All</button><button  style="flex:1" id="remAll">Remove All</button></div></div>');

            let statusSel = $('<select id="selStat"style="width:100%">').prependTo("#statusPanel");
            $(status).each(function() {
                statusSel.append($("<option>").attr('value',this.val).text(this.text));
            });

            if(localStorage.getItem('lastStat')==null){
                localStorage.setItem('lastStat',0);
            }
            let selStat=$('#selStat')[0];
            selStat.value = localStorage.getItem('lastStat');

            $("#togStats").click(function() {
                localStorage.setItem('lastStat',selStat.value);
                ToggleStats($('#selStat').val());
            });

            $('#addAll').click(function() {
                AddAllStats(true);
            });
            $('#remAll').click(function() {
                AddAllStats(false);
            });

            function GetCurStats(){
                let allStats = ['fas fa-music', 'far fa-moon', 'fas fa-moon', 'fas fa-box', 'fas fa-user-friends'];
                let self = $('.playerlist-name-self')[0];
                let playerStats = self.nextElementSibling.childNodes[3].childNodes;
                let curStats=[];
                for(let i = 0;i< playerStats.length;i++){
                    curStats.push(allStats.indexOf(playerStats[i].className));
                }
                return curStats;
            }

            function AddAllStats(cond){
                let curStats=GetCurStats();
                for(let i=0;i<=4;i++){
                    if(curStats.includes(i)!=cond){
                        PLAYERFLAGS_INVENTORYOPEN=i;
                        $('.extmenu-button')[1].click();
                        $('.close')[6].click();
                    }
                }
                PLAYERFLAGS_INVENTORYOPEN=3;
            }

            function ToggleStats(statsNum){
                PLAYERFLAGS_INVENTORYOPEN=statsNum;
                $('.extmenu-button')[1].click();
                $('.close')[6].click();
                PLAYERFLAGS_INVENTORYOPEN=3;
            }
        }

        //Star Bot

        function AutoStar(){
            $("#assistPanel").append('<div id="autoStarPanel" style="margin-top:0.4rem; display: flex; flex-direction: column;"><button id="autoStar">Star Bot: Off</button></div>');

            $('#autoStar').click(function() {
                if( this.textContent=='Star Bot: On'){
                    this.textContent='Star Bot: Off';
                }
                else{
                    this.textContent='Star Bot: On';
                    $('.ratedrawerbox-button').click();
                }
            });

            let questionMarkObserver = new MutationObserver(function(mutations) {
                if($('#autoStar')[0].textContent=='Star Bot: On'){
                    $('.ratedrawerbox-button').click();
                }
            });
            questionMarkObserver.observe($('#targetword')[0], {attributes: true, attributeFilter:['style']});

        }

        //WordHints
        function WordHints(){
            (async () => {
                'use strict';

                const sendButton=document.getElementById('chatattop-sendbutton');
                const inputChat = document.getElementById('chatbox_textinput');
                const targetWord = document.getElementsByClassName("topbox-content-targetword")[1];
                const rightbar = document.getElementById('rightbar');

                const refreshDelay = 500;
                let wordList;
                let targetWordVal = '';
                let assistantPanel;
                let hintBox;

                const hintClick = (event) => {
                    const inputChatVal = inputChat.value;
                    inputChat.value = event.target.innerHTML;
                    sendButton.click();

                };

                const assist = (event, wordChanged = false) => {
                    let wordRegex = targetWord.textContent.replace(/_/g, '[^ \\-"]');
                    wordRegex = '"'.concat(wordRegex, '"');
                    wordRegex = new RegExp(wordRegex, 'g');

                    let hints = wordList.match(wordRegex);

                    if (!hints) {
                        hintBox.innerHTML = '<span style="color:black">Sorry, no hints available!</span>';
                        return;
                    } else {
                        hintBox.innerHTML = '<span style="color:black">Click on a hint to submit it: </span><br>';
                    }

                    hints = hints.map((hint) => {
                        return hint.substring(1, hint.length - 1);
                    });
                    hints = hints.sort((a, b) => {
                        return a.toLowerCase().localeCompare(b.toLowerCase());
                    });

                    const inputChatVal = inputChat.value;
                    const inputList = [];

                    hints.forEach((hint) => {

                        const hintSpan = document.createElement('a');
                        hintSpan.innerHTML = hint;
                        hintSpan.style.color = 'royalblue';
                        hintSpan.style.backgroundColor = "#FDFD8F";
                        hintSpan.href = 'javascript:void(0);';
                        hintSpan.onclick = hintClick;

                        if (!(inputChatVal && hint.toLowerCase().search(inputChatVal.toLowerCase()) !== -1 )) {
                            hintSpan.style.display= 'none';
                            inputList.push(hint);
                        }else{
                            hintBox.appendChild(hintSpan);
                            hintBox.appendChild(document.createTextNode(', '));
                        }
                    });
                    inputList.forEach((hint) => {
                        const hintSpan = document.createElement('a');
                        hintSpan.innerHTML = hint;
                        hintSpan.style.backgroundColor = 'none';
                        hintSpan.href = 'javascript:void(0);';
                        hintSpan.onclick = hintClick;
                        hintBox.appendChild(hintSpan);
                        hintBox.appendChild(document.createTextNode(', '));
                    });

                    hintBox.removeChild(hintBox.lastChild);

                };


                const initialize = async () => {

                    wordList = "https://api.npoint.io/fe8c64660af45e03961d";

                    try {
                        wordList = await fetch(wordList).then((response) => response.json());
                    } catch (e) {
                        await new Promise((resolve) => setTimeout(resolve, refreshDelay));
                        return initialize();
                    }

                    wordList = JSON.stringify(wordList);

                    wordList = wordList.substring(1, wordList.length - 1);

                    assistantPanel = document.createElement('p');

                    assistantPanel.style = `
        display: none;
        background: rgb(238, 238, 238);
        overflow-wrap: break-word;
        border-radius: 2px;
        border: 4px solid rgb(238, 238, 238);
        width: 100%;
        height: 100%;
        overflow-y: auto;
        color: rgb(57, 117, 206);
        margin: 8px 0 0 0;

    `;

                    hintBox = document.createElement('span');
                    assistantPanel.appendChild(hintBox);

                    rightbar.insertBefore(
                        assistantPanel,
                        rightbar.childNodes[3]
                    );

                    inputChat.onkeyup = assist;

                    setInterval(() => {

                        if(document.getElementById('targetword_tip').style.display == "none"){
                            assistantPanel.style.display = "none";
                            $("#assistPanel").show();
                        }else{
                            assistantPanel.style.display = "";
                            $("#assistPanel").hide();
                        }
                        if (
                            targetWord &&
                            targetWord.textContent.indexOf('_') !== -1
                        ) {
                            if (targetWordVal !== targetWord.textContent) {
                                hintBox.style.display = '';

                                assist(undefined, true);
                                targetWordVal = targetWord.textContent;
                            }
                        } else {
                            hintBox.style.display = 'none';
                            targetWordVal = '';

                        }
                    }, refreshDelay);
                };
                initialize();
            })();

        }

        //Delete likes data
        let regex = new RegExp('^r[0-9]');
        let keys = Object.keys(localStorage),
            len = keys.length;
        for(let i=0; i < len;i++){
            if(regex.test(keys[i])){
                if(keys[i].length==7){
                    localStorage.removeItem(keys[i]);
                }
            }
        }

        //remove limit in sticker size
        let launchStickerObserver = new MutationObserver(function(mutations) {
            for (let i=0, mutation; mutation = mutations[i]; i++) {
                if (mutation.attributeName == 'disabled') {
                    if (mutation.target.disabled) {
                        $('.fa-parachute-box').parent().prop("disabled",false);
                    }
                }
            };
        });
        launchStickerObserver.observe($('.fa-parachute-box').parent()[0], {attributes: true});

        //remove refresh list
        let refreshWordObserver = new MutationObserver(function(mutations) {
            for (let i=0, mutation; mutation = mutations[i]; i++) {
                if (mutation.attributeName == 'disabled') {
                    if (mutation.target.disabled) {
                        $('#wordchooser-refreshlist').prop("disabled",false);
                    }
                }
            };
        });
        refreshWordObserver.observe($('#wordchooser-refreshlist')[0], {attributes: true});


    });
})(window.jQuery.noConflict(true));