// ==UserScript== // @name Grepolis tripjes detector // @version 2025-01-28 // @description Laat op het profiel van een speler of op het eiland scherm zien welke steden wel/geen trip hebben // @author archdukeDaan // @match https://*.grepolis.com/* // @exclude https://*.grepolis.com/start // @license MIT // @namespace https://tampermonkey.net/ // @grant GM_setValue // @grant GM_getValue // @require https://code.jquery.com/jquery-3.6.0.min.js // @downloadURL none // ==/UserScript== (function() { 'use strict'; // wacht tot document is geladen $(document).ready(function () { setTimeout(console.log("Archduke Script running..."), 5000); // maak de knop om naar het menu te gaan maakMenuKnop() // laadt de trip detector module aan de hand van de voorkeuren if (laadSettings().trip_module == true){ // maak een wrapper function over de createTownDiv function // voordat een stad wordt gemaakt op de kaart, run eerst mijn functie en dan pas de grepo functie var wrapper = function(originalFunc) { return function() { var wrapper = originalFunc.apply(this, arguments); return generateTripjesOpKaart(wrapper, arguments); }; }; MapTiles.createTownDiv = wrapper(MapTiles.createTownDiv); // timer om te checken of de knop moet worden geplaatst // er kan maar maximaal 1 profiel tegelijk open staan setTimeout(function checkProfielWindowOpen() { if (document.getElementById("player_towns") != null) { if (document.getElementById("tripknopProfiel") == null){ addTripKnop('profiel') } } setTimeout(checkProfielWindowOpen, 500); }, 500); // timer om te checken of de knop moet worden geplaatst // er kunnen meerdere eilanden vensters tegelijk open staan setTimeout(function checkEilandWindowOpen() { if (document.getElementsByClassName("island_info_wrapper") != null) { // verkrijg alle openstaande eiland vensters var vensters = getAllOpenEilandVensters() for(let i=0;i { var tripjes = stad.models tripjes.forEach((trip) => { var trip_info = trip.attributes var stad_naam = trip_info.current_town_name var stad_speler = trip_info.current_town_player_name var stad_id = trip_info.current_town_id //var trip_stad_herkomst = trip_info.home_town_name var row = {"stad_naam":stad_naam,"stad_speler":stad_speler,"stad_id":stad_id} triplijst.push( row ) }); }); //console.log(triplijst) return triplijst } function getProfileName(){ // verkrijg speler naam van het huidige profiel dat open staat var profiel = document.getElementById("player_info").children var naam = "" for(let i=0;i e.remove()); // verkrijg stedenlijst op het eiland var steden = getStedenLijstOpEiland(venster) // verkrijg de triplijst var triplijst = getTripLijst() // loop over de steden en voeg tag 'geen trip' toe als de stadsnaam niet in triplijst staat for (let k=0; k < steden.length; k++){ var stad_obj = steden[k] var stad_naam = stad_obj.querySelector(".gp_town_link").innerHTML; var stad_eigenaar_dom = stad_obj.querySelector(".gp_player_link") var stad_eigenaar = "Spookstad" if (stad_eigenaar_dom != null){ stad_eigenaar = stad_eigenaar_dom.innerHTML; } var stad_alliantie = getAlliantieFromLink(stad_obj); // plaats geen tag als de stad van de huidige speler is // plaats geen tag als de alliantie van de eigenaar van de stad niet in de alliantie lijst staat var settings = laadSettings() var allianties = settings.trip_allianties if ( allianties.includes(stad_alliantie) == true ){ var eigen_stad_bool = settings.eigen_stad if (eigen_stad_bool == false){ if (stad_eigenaar == getHuidigeSpeler()){ return } } var tag = document.createElement('div'); tag.style.zIndex = 1000; tag.style.cursor = 'pointer'; tag.setAttribute('class','tripTag') tag.style.fontWeight = 'bold'; tag.style.marginLeft = '10px'; // kijk of er een trip in de stad ligt var j = triplijst.findIndex( e => (e.stad_naam == stad_naam) && (e.stad_speler == stad_eigenaar) ) if (j>-1){ tag.textContent = "Wel trip"; tag.style.color = 'green' } else { tag.textContent = "Geen trip"; tag.style.color = 'red' } // voeg de tag toe aan de DOM steden[k].appendChild(tag); } } } function generateTripjesOpProfiel(){ // indien van toepassing, verwijder de oude tags op het profiel document.getElementById("player_towns").querySelectorAll('.tripTag').forEach(e => e.remove()); // verkrijg naam op het profiel var naam = getProfileName() // verkrijg de triplijst var triplijst = getTripLijst() // verkrijg stedenlijst op het profiel var steden = getStedenLijstOpProfiel() // loop over de steden en voeg tag 'geen trip' of 'wel trip' toe for (let k=0; k < steden.length; k++){ var stad = steden[k].children[1] var stad_naam = stad.innerHTML var tag = document.createElement('span'); tag.style.zIndex = 1000; tag.style.cursor = 'pointer'; tag.setAttribute('class','tripTag') tag.style.fontWeight = 'bold'; // kijk of er een trip in de stad ligt var j = triplijst.findIndex( e => (e.stad_naam == stad_naam) & (e.stad_speler == naam) ) if (j>-1){ tag.textContent = "Wel trip"; tag.style.color = 'green' } else { tag.textContent = "Geen trip"; tag.style.color = 'red' } // voeg de tag toe aan de DOM steden[k].appendChild(tag) } } function generateTripjesOpKaart(originalFunc, args){ var stad = args[0] //console.log(stad) // check of stad een speler heeft, dus of het geen spookstad is if(stad.player_id != null){ // createTownDiv 2 keer geroepen per stad, eens voor de stad en eens voor de stad vlag for (let i=0;i (e.stad_id == stad_id) ) if (j>-1){ tag.style.backgroundColor = 'green' } else { tag.style.backgroundColor = 'red' } $(originalFunc[i]).append(tag); } } } } return originalFunc } function maakMenuKnop(){ var knop = document.createElement("div") knop.setAttribute("id","archduke_menu") knop.addEventListener('click', maakMenu) knop.style.position = 'absolute' knop.style.top = '3px' knop.style.height = '27px' knop.style.left = "35%" knop.style.width = '70px' knop.style.cursor = 'pointer' knop.style.zIndex = '2000' var icon = document.createElement("div") icon.setAttribute("class",'icon') icon.style.position = 'relative' icon.style.width = '100%' icon.style.height = '100%' icon.style.backgroundImage = `url(${getImageData()})` knop.appendChild(icon) document.body.appendChild(knop) } function maakMenu(){ var menuTitel = 'Archduke Menu' var titel_dom = null // check of er al een menu window open staat var find = false; for(let i of document.getElementsByClassName('ui-dialog-title')){ if(i.innerHTML == menuTitel){ find = true; titel_dom = i } } // maak nieuwe window indien nodig if(find == false){ var window = Layout.wnd.Create(Layout.wnd.TYPE_DIALOG, "Archduke Menu"); // zet window size window.setHeight(document.body.scrollHeight/2); window.setWidth('800'); window.setContent(''); // clear window for(let i of document.getElementsByClassName('ui-dialog-title')){ if(i.innerHTML == menuTitel){ titel_dom = i; } } } // maak mini pagina om in de frame te zetten var frame = titel_dom.parentElement.parentElement.children[1].children[4]; frame.innerHTML = ''; // maak menu voor module selectie aan de linker kant var container_left = document.createElement("div") container_left.setAttribute("id","archduke_menu_left") container_left.setAttribute("class",'settings-menu') frame.appendChild(container_left) var ul = document.createElement("ul") // maak module selectors var el = document.createElement("b") el.innerHTML = 'Scripts' container_left.append(el) var el = maakModuleSelector('Trip Detector') ul.append(el) var el = maakModuleSelector('Placeholder naam') ul.append(el) var el = maakModuleSelector('Placeholder naam') ul.append(el) container_left.appendChild(ul) // maak instellingen voor module aan de rechter kant var container_right = document.createElement("div") container_right.setAttribute("id","archduke_menu_right") container_right.setAttribute("class",'settings-container') frame.appendChild(container_right) // maak module instellingen var el = maakTripInstellingen() container_right.appendChild(el) // check settings in de local storage var settings = laadSettings() if (settings.auto_trip_eiland){ document.getElementById("archduke_menu_auto_trip_eiland").classList.add('checked') } if (settings.auto_trip_kaart){ document.getElementById("archduke_menu_auto_trip_kaart").classList.add('checked') } if (settings.auto_trip_profiel){ document.getElementById("archduke_menu_auto_trip_profiel").classList.add('checked') } if (settings.trip_eigen_stad){ document.getElementById("archduke_menu_trip_eigen_stad").classList.add('checked') } if (settings.trip_module){ document.getElementById("archduke_menu_trip_module").classList.add('checked') } for (let i=0; i < settings.trip_allianties.length;i++){ var ally_id = settings.trip_allianties[i] addRowToMenuList(document.getElementById('archduke_menu_alliantie_list'),ally_id) } } function maakModuleSelector(naam){ var el = document.createElement("li") el.style.marginBottom = '10px' var a = document.createElement('a') a.innerHTML = naam a.setAttribute("class","settings-link") el.appendChild(a) return el } function maakTripInstellingen(){ // maak container var el = document.createElement("div") el.setAttribute('id',"archduke_menu_instellingen") var form = document.createElement("form") el.appendChild(form) // maak section var section = createSection('Voorkeuren') form.appendChild(section) // maak groep waar alle knopjes in komen var group = createGroup("Bepaal het gedrag van de tripjes detector door de checkboxen aan te vinken.") // maak alle knopjes var trip_module = createCheckBox("Activeer de trip detector ( vereist refresh van de pagina )", 'trip_module') var auto_weergeef_kaart = createCheckBox("Weergeef automatisch de trip tags op de kaart", 'auto_trip_kaart') var auto_weergeef_eiland = createCheckBox("Weergeef automatisch de trip tags op het eiland scherm",'auto_trip_eiland') var auto_weergeef_profiel = createCheckBox("Weergeef automatisch de trip tags op het profiel van een speler",'auto_trip_profiel') var auto_weergeef_eigen_stad = createCheckBox("Weergeef trip tags bij je eigen steden",'trip_eigen_stad') // opslaan knop var btn = createKnop("Opslaan",saveInstellingen) // voeg alles toe aan de section group.appendChild(trip_module) group.appendChild(document.createElement("br")) group.appendChild(auto_weergeef_kaart) group.appendChild(document.createElement("br")) group.appendChild(auto_weergeef_eiland) group.appendChild(document.createElement("br")) group.appendChild(auto_weergeef_profiel) group.appendChild(document.createElement("br")) group.appendChild(auto_weergeef_eigen_stad) group.appendChild(document.createElement("br")) group.appendChild(btn) section.append(group) // maak inner box var box = createInnerBox("Alleen voor onderstaande allianties zullen trip tags worden getoond.",'input_ally_id','Alliantie ID', 'Opslaan',"archduke_menu_alliantie_list",saveInstellingenAllianties) group.appendChild(box) return el } function createSection(sectie_naam){ var section = document.createElement("div") section.setAttribute("class",'section') section.style.display = 'block' var section_titel = document.createElement("div") section_titel.innerHTML = sectie_naam section_titel.setAttribute("class",'game_header bold') section.appendChild(section_titel) return section } function createGroup(beschrijving){ var group = document.createElement("div") group.setAttribute("class",'group') var group_text = document.createElement("p") group_text.innerHTML = beschrijving group.appendChild(group_text) return group } function createCheckBox(beschrijving, id){ var el = document.createElement("div") el.setAttribute('class',"checkbox_new large archduke_menu_checkbox") el.setAttribute('id', `archduke_menu_${id}`) var btn = document.createElement("div") btn.setAttribute("class","cbx_icon") el.appendChild(btn) var text = document.createElement("div") text.setAttribute("class","cbx_caption") text.innerHTML = beschrijving el.appendChild(text) el.addEventListener('click', function(){ this.classList.toggle('checked') }) return el } function createKnop(text, f){ var el = document.createElement("div") el.setAttribute("class",'button_new') var el2 = document.createElement("div") el2.setAttribute("class",'left') var el3 = document.createElement("div") el3.setAttribute("class",'right') var btn = document.createElement("div") btn.setAttribute("class",'caption js-caption') var btn_txt = document.createElement("span") btn_txt.innerHTML = text var btn_ef = document.createElement("div") btn_ef.setAttribute('class',"effect js-effect") el.appendChild(el2) el.appendChild(el3) btn.appendChild(btn_txt) btn.appendChild(btn_ef) el.appendChild(btn) btn.addEventListener('click', f) return el } function saveInstellingen(){ var checkboxen = document.body.querySelectorAll(".archduke_menu_checkbox") for (let i=0;i