// ==UserScript== // @name Geoguessr Better Menu // @namespace https://greasyfork.org/en/users/997484-aimee4737 // @version 2.1 // @description Adds a menu bar to Geoguessr's new UI // @author aimee // @match https://www.geoguessr.com/* // @icon https://www.google.com/s2/favicons?sz=64&domain=geoguessr.com // @run-at document-start // @grant none // @license MIT // @downloadURL none // ==/UserScript== // ======================================== DO NOT EDIT OUTSIDE THIS SECTION UNLESS YOU KNOW WHAT YOU ARE DOING ======================================== // menu items (can customise following the same structure as the others) // const [variable name] = ` [name to show in menu] ` const singleplayer = ` Singleplayer ` const multiplayer = ` Multiplayer ` const party = ` Party ` const quiz = ` Quiz ` const ongoingGames = ` Ongoing Games ` const activities = ` Activities ` const myMaps = ` My Maps ` const likedMaps = ` Liked Maps ` const newParty = ` Party ` const profile = ` Profile ` const badges = ` Badges ` const account = ` Account ` // items to show in menu (can customise list using variable names defined above) const items = [singleplayer, multiplayer, party, ongoingGames, activities, likedMaps] // ====================================================================================================================================================== const start = `
` const end = `
` let html = "" for (let item of items) { html = html + start + item + end } const refresh = () => { // only refreshes if not loading if (document.querySelector("[class^='page-loading_loading__']")) return; // if header exists if (document.querySelector("[class^='header_header__']")) { const header = document.querySelector("[class^='header_header__']") // gets right section of header and hides avatar deals (div without any classes) const right = header.querySelector("[class^='header_context__']") for (let child of right.childNodes) { if (child.nodeName == "DIV" && child.classList.length == 0) { console.log(child) child.style.display = "none" } } // gets menu (middle) section of header (div without any classes) let menu for (let section of header.childNodes) { if (section.classList.length == 0) { menu = section menu.style.display = "flex" break } } // hides old menu items for (let child of menu.childNodes) { if (!child.classList.contains("newItems")) { child.style.display = "none" } } // adds better menu items if (document.querySelector(".newItems") === null) { // creates new div from html const newItems = document.createElement("div") newItems.className = "newItems" newItems.innerHTML = html newItems.style.display = "flex" // prepends new div menu.prepend(newItems) } } // highlights active menu item if (document.querySelector(".newItems")) { let url = window.location.href const newItems = document.querySelector(".newItems") for (let i = 0; i < newItems.childNodes.length; i++) { let link = newItems.childNodes[i].querySelector("a") link.style.color = "white" newItems.childNodes[i].classList.remove("slanted-wrapper_variantWhite__VKHvw") newItems.childNodes[i].classList.add("slanted-wrapper_variantGrayTransparent__aufaF") if (link.href == url) { link.style.color = "" newItems.childNodes[i].classList.remove("slanted-wrapper_variantGrayTransparent__aufaF") newItems.childNodes[i].classList.add("slanted-wrapper_variantWhite__VKHvw") } } } // hides maprunner on home if (document.querySelector("[class^='maprunner-start-page_content__']")) { document.querySelector("[class^='maprunner-start-page_content__']").style.display = "none" } if (document.querySelector("[class^='maprunner-start-page_progress__']")) { document.querySelector("[class^='maprunner-start-page_progress__']").style.display = "none" } if (document.querySelector("[class^='maprunner-signed-in-start-page_gradientPlate__']")) { document.querySelector("[class^='maprunner-signed-in-start-page_gradientPlate__']").style.display = "none" } if (document.querySelector("[class^='maprunner-signed-in-start-page_avatar__']")) { document.querySelector("[class^='maprunner-signed-in-start-page_avatar__']").style.display = "none" } // hides footer on home if (document.querySelector("[class^='footer_footer__']")) { document.querySelector("[class^='footer_footer__']").style.display = "none" } // hides secondary menu on home if (document.querySelector("[class^='secondary-menu_menu__']") && !document.querySelector("[class^='pop-out-main-menu_wrapper__']")) { document.querySelector("[class^='secondary-menu_menu__']").style.display = "none" } // hides ongoing games on home if (document.querySelectorAll("[class^='primary-menu_wrapper__']")) { const primaryMenu = document.querySelector("[class^='primary-menu_wrapper__']") for (let child of primaryMenu.childNodes) { if (child.childNodes.length > 1) { child.style.display = "none" } } } } let observer = new MutationObserver((mutations) => { refresh(); }); observer.observe(document.body, { characterDataOldValue: false, subtree: true, childList: true, characterData: false });