// ==UserScript== // @name Geoguessr Better Menu // @namespace https://greasyfork.org/en/users/997484-aimee4737 // @version 2.7 // @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 // @require https://update.greasyfork.org/scripts/460322/1246943/Geoguessr%20Styles%20Scan.js // @downloadURL https://update.greasyfork.icu/scripts/456575/Geoguessr%20Better%20Menu.user.js // @updateURL https://update.greasyfork.icu/scripts/456575/Geoguessr%20Better%20Menu.meta.js // ==/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 ongoing_games = ` Ongoing Games ` const activities = ` Activities ` const my_maps = ` My Maps ` const liked_maps = ` Liked Maps ` const new_party = ` Party ` const profile = ` Profile ` const badges = ` Badges ` const account = ` Account ` const shop = ` Shop ` const community = ` Community ` const explorer = ` Explorer ` const daily_challenge = ` Daily Challenge ` const streaks = ` Streaks ` // items to show in menu (can customise list using variable names defined above) const items = [liked_maps, ongoing_games, multiplayer, shop] // ====================================================================================================================================================== async function setup(items) { await scanStyles(); const start = `
` const end = `
` let html = "" for (let item of items) { html = html + start + item + end } return html } 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__']") // hides promos if (document.querySelector("[class^='header_promoDealButtonWrapper__']")) { document.querySelector("[class^='header_promoDealButtonWrapper__']").style.display = "none" } // hides existing page labels if (document.querySelectorAll("[class^='header_pageLabel__']").length > 1) { document.querySelectorAll("[class^='header_pageLabel__']")[1].style.display = "none" } // adds new page labels if (!document.querySelector("[class^='newItems']")) { let menu = document.createElement("div") menu.classList.add(cn("header_pageLabel__")) menu.style.display = "flex" header.childNodes[1].before(menu) // creates new div from html const newItems = document.createElement("div") newItems.className = "newItems" setup(items).then(function(result) { newItems.innerHTML = result }) newItems.style.display = "flex" // prepends new div menu.prepend(newItems) } header.style.display = "grid" header.style.gridAutoFlow = "column" // 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(cn("slanted-wrapper_variantWhite__")) newItems.childNodes[i].classList.add(cn("slanted-wrapper_variantGrayTransparent__")) if (link.href == url) { link.style.color = "#1a1a2e" newItems.childNodes[i].classList.remove(cn("slanted-wrapper_variantGrayTransparent__")) newItems.childNodes[i].classList.add(cn("slanted-wrapper_variantWhite__")) } } } } if (document.querySelector("[class^='footer_footer__']")) { document.querySelector("[class^='footer_footer__']").style.display = "none" } if (document.querySelector("[class^='signed-in-start-page_avatar__']")) { document.querySelector("[class^='signed-in-start-page_avatar__']").style.display = "none" } if (document.querySelector("[class^='signed-in-start-page_playDailyReminder__']")) { document.querySelector("[class^='signed-in-start-page_playDailyReminder__']").style.display = "none" } } let observer = new MutationObserver((mutations) => { refresh(); }); observer.observe(document.body, { characterDataOldValue: false, subtree: true, childList: true, characterData: false });