Shell Shockers Server Dropdown Restorer

Puts back the server dropdown which was removed from the game some years ago. Has two modes, works with latest interface.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

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

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

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

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

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         Shell Shockers Server Dropdown Restorer
// @namespace    https://github.com/onlypuppy7/ShellShockersServerDropdownRestorer/
// @license      GPL-3.0
// @version      1.0.2
// @author       onlypuppy7
// @description  Puts back the server dropdown which was removed from the game some years ago. Has two modes, works with latest interface.
// @match        https://shellshock.io/*
// @grant        none
// @run-at       document-start
// @icon         https://github.com/onlypuppy7/ShellShockersServerDropdownRestorer/blob/main/logo.png?raw=true
// ==/UserScript==

const mode = "puppy"; // classic OR puppy

(async function () {
    while (!window.extern?.isGameReady) {
        await new Promise(resolve => setTimeout(resolve, 1000));
    };

    const regionSelect = document.getElementById("regionSelect");
    const playGameSection = document.getElementById("home_screen");

    if (regionSelect && playGameSection) {
        playGameSection.appendChild(regionSelect);
        regionSelect.style.position = "absolute";

        if (mode === "classic") {
            regionSelect.style.left = "20em";
            regionSelect.style.top = "3em";
            regionSelect.style.marginLeft = "0em";
        } else {
            regionSelect.style.top = "45.25em";
            regionSelect.style.left = "50%";
            regionSelect.style.marginLeft = "20em";
        };
    };
})();