Greasy Fork

Greasy Fork is available in English.

TripTag Enhancer

Laat zien welke steden wel/geen trip hebben.

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         TripTag Enhancer
// @version      2.3
// @description  Laat zien welke steden wel/geen trip hebben.
// @author       archdukeDaan
// @match        https://*.grepolis.com/game/*
// @license      MIT
// @namespace    https://dlnvt.nl
// @grant        GM_setValue
// @grant        GM_getValue
// @require      https://code.jquery.com/jquery-3.6.0.min.js
// ==/UserScript==

(function() {
    'use strict';

    // wacht tot document is geladen
    $(document).ready(function () {
        setTimeout(console.log(`Archduke script: ${GM_info.script.name} is geladen`), 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
            if (laadSettings().auto_trip_kaart == true){
                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<vensters.length;i++){
                        var venster = vensters[i]
                        // check of dit eiland venster al een knop heeft
                        if (venster.querySelector("#tripknopEiland") == null){
                            addTripKnop('eiland',venster)
                        }
                    }
                }
                setTimeout(checkEilandWindowOpen, 500);
            }, 500);
        }
        
    });

    function resetSettings(){
        GM_setValue("archduke_menu_auto_trip_kaart", true)
        GM_setValue("archduke_menu_auto_trip_eiland", true)
        GM_setValue("archduke_menu_auto_trip_profiel", false)
        GM_setValue("archduke_menu_trip_allianties", [])
        GM_setValue("archduke_menu_trip_spelers", [])
        GM_setValue("archduke_menu_trip_eigen_stad", false)
        GM_setValue("archduke_menu_trip_pos_x", 70)
        GM_setValue("archduke_menu_trip_pos_y", 60)
        GM_setValue("archduke_menu_trip_module", true)
    }

    // verkrijg de voorkeuren
    function laadSettings(){
        var auto_trip_kaart = GM_getValue('archduke_menu_auto_trip_kaart')
        if (auto_trip_kaart == null){
            auto_trip_kaart = true
        }
        var auto_trip_eiland = GM_getValue('archduke_menu_auto_trip_eiland')
        if (auto_trip_eiland == null){
            auto_trip_eiland = true
        }
        var auto_trip_profiel = GM_getValue('archduke_menu_auto_trip_profiel')
        if (auto_trip_profiel == null){
            auto_trip_profiel = false
        }
        var trip_allianties = GM_getValue('archduke_menu_trip_allianties')
        if (trip_allianties == null){
            trip_allianties = []
        }
        var trip_eigen_stad = GM_getValue('archduke_menu_trip_eigen_stad')
        if (trip_eigen_stad == null){
            trip_eigen_stad = false
        }
        var trip_module = GM_getValue('archduke_menu_trip_module')
        if (trip_module == null){
            trip_module = true
        }
        var trip_spelers = GM_getValue('archduke_menu_trip_spelers')
        if (trip_spelers == null){
            trip_spelers = []
        }
        var trip_pos_x = GM_getValue("archduke_menu_trip_pos_x")
        if (trip_pos_x == null) {
            trip_pos_x = 70
        }
        var trip_pos_y = GM_getValue("archduke_menu_trip_pos_y")
        if (trip_pos_y == null) {
            trip_pos_y = 60
        }
        var settings = {
            "trip_module": trip_module,
            'auto_trip_kaart': auto_trip_kaart,
            'auto_trip_eiland': auto_trip_eiland,
            'auto_trip_profiel': auto_trip_profiel,
            "trip_allianties" : trip_allianties,
            "trip_eigen_stad" : trip_eigen_stad,
            "trip_spelers": trip_spelers,
            "trip_pos_x": trip_pos_x,
            "trip_pos_y": trip_pos_y,
        }
        return settings
        
    }

    function addTripKnop(knop_type,venster) {
        var button = document.createElement('span');
        button.textContent = 'Tripjes';
        button.style.zIndex = 1000;
        button.style.width = '50px'
        button.style.padding = '4px';
        button.style.marginTop = '4px'
        button.style.marginBottom = '4px'
        button.style.color = 'white';
        button.style.border = '1px solid black';
        button.style.borderRadius = '5px';
        button.style.cursor = 'pointer';
        button.style.marginLeft = '15px';

        var settings = laadSettings()

        if (knop_type == 'profiel'){
            button.addEventListener('click', function(){
                generateTripjesOpProfiel();
            }, false);
            button.setAttribute('id', 'tripknopProfiel');

            // voeg de knop als tweede element toe aan de game_header van de stedenlijst op het profiel
            var profiel = document.getElementById("player_towns")
            var element = profiel.children[0].querySelector('.game_header');
            element.insertBefore(button,element.children[0]);

            var bool = settings.auto_trip_profiel
            if (bool == true){
                button.click()
            }

        } else if (knop_type == 'eiland'){
            button.addEventListener('click', function(){
                generateTripjesOpEiland(venster);
            }, false);
            button.setAttribute('id', `tripknopEiland`);
            button.style.backgroundColor = 'blue';

            var eiland_controls = venster.querySelector("#island_towns_controls")
            eiland_controls.appendChild(button)
            var bool = settings.auto_trip_eiland
            if (bool == true){
                button.click()
            }
        }
        console.log("Trip knop toegevoegd!")
    }

    function getHuidigeSpeler(){
        var playerObj = MM.getModels().Player
        var player = Object.values(playerObj)[0].attributes;
        var huidigeSpeler = player.name
        return huidigeSpeler
    }

    function getTripLijst(){
        // verkrijg alle tripjes en stop ze in een lijst
        const steden_met_troepen_buiten = ITowns.all_supporting_units.fragments

        var triplijst = []

        Object.values(steden_met_troepen_buiten).forEach((stad) => {
            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<profiel.length;i++){
            var el = profiel[i]
            if (el.tagName == "H3"){
                naam = el.innerHTML
                break
            }
        }
        return naam
    }

    function getStedenLijstOpProfiel(){
        // verkrijg stedenlijst dom element van een speler zn profiel
        var profiel_steden = document.getElementById("player_towns").children[0].children
        var steden = false
        for(let i=0;i<profiel_steden.length;i++){
            var el2 = profiel_steden[i]
            if (el2.tagName == "UL"){
                steden = el2.children
                break
            }
        }
        //console.log(steden)
        return steden
    }

    function getStedenLijstOpEiland(venster){
        // verkrijg stedenlijst dom element van een eiland
        var eiland_steden = venster.querySelector("#island_info_towns_left_sorted_by_name").children
        //console.log(steden)
        return eiland_steden
    }

    function getAlliantieFromLink(stad_obj){
        // verkrijg de alliantie van de eigenaar van een stad vanuit de GP link DOM element
        // als speler geen alliantie heeft, return -1
        if (stad_obj.querySelector('.gp_alliance_link') != null){
            var link_as_str = stad_obj.querySelector('.gp_alliance_link').outerHTML;
            var alliantie = link_as_str.split("Layout.allianceProfile.open")[1].split(",")[1].split(")")[0]
            return parseInt(alliantie)
        } else {
            return -1
        }
    }

    function getAllOpenEilandVensters(){
        var vensters = document.getElementsByClassName("island_info_wrapper")
        return vensters
    }

    function generateTripjesOpEiland(venster){
        // indien van toepassing, verwijder de oude tags op het eiland informatie scherm
        venster.querySelector("#island_info_towns_left_sorted_by_name").querySelectorAll('.tripTag').forEach(e => 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 ){
                // filter eigen stad weg
                var eigen_stad_bool = settings.trip_eigen_stad
                if (eigen_stad_bool == false){
                    if (stad_eigenaar == getHuidigeSpeler()){
                        continue
                    }
                }
                //filter spelers weg waar geen tag bij hoeft
                if (settings.trip_spelers.includes(stad_eigenaar) == true){
                    continue
                }
                
                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<originalFunc.length;i++){
                // maak tag alleen op de stadsvlag ivm dubbele tags per stad
                var dom_element = originalFunc[i]
                var class_list = dom_element.classList
                //console.log(class_list)
                if (class_list.contains("flag")){
                    // verkrijg de triplijst
                    var triplijst = getTripLijst()

                    var stad_id = stad.id
                    var stad_alliantie = stad.alliance_id
                    var stad_eigenaar = stad.player_name

                    var settings = laadSettings()
                    var allianties = settings.trip_allianties
                    var eigen_stad = settings.trip_eigen_stad
                    if ((allianties.includes(stad_alliantie) == true)){
                        if(eigen_stad == false){
                            if(stad_eigenaar == getHuidigeSpeler()){
                                return originalFunc
                            }
                        }
                        if (settings.trip_spelers.includes(stad_eigenaar) == true){
                            return originalFunc
                        }
                        // tag
                        var tag = document.createElement('div');
                        tag.style.zIndex = 2000;
                        tag.style.cursor = 'pointer';
                        tag.setAttribute('class','tripTag')
                        tag.style.fontWeight = 'bold';
                        tag.style.width = '15px';
                        tag.style.height = '15px';
                        tag.style.borderRadius = '50%'
                        tag.style.position = 'relative';
                        tag.style.top = settings.trip_pos_y+"%";
                        tag.style.left = settings.trip_pos_x+"%";
                        tag.style.border = '2px solid black'

                        // kijk of er een trip in de stad ligt
                        var j = triplijst.findIndex( e => (e.stad_id == stad_id) )
                        if (j>-1){
                            tag.style.backgroundColor = 'green'
                        } else {
                            tag.style.backgroundColor = 'red'
                        }
                        $(originalFunc[i]).append(tag);
                    }
                }
            }
        }
        return originalFunc
    }

    /////////////////////////////////////////////////////////////////////////////
    // menu 
    /////////////////////////////////////////////////////////////////////////////

    function maakMenu(){
        var titel = "Archduke Menu"
        var menu = new ArchdukeMenu(titel)

        menu.addItemMenuSelection("TripTag Enhancer", maakTripInstellingen)
        menu.clickMenu("TripTag Enhancer")
    }

    function maakTripInstellingen(){       
        // maak instellingen
        var instelling = new Instellingen("tripenhancer","Voorkeuren","Bepaal het gedrag van de tripjes detector door de checkboxen aan te vinken.")

        // maak alle knopjes
        instelling.createCheckBox("Activeer de trip detector ( vereist refresh van de pagina )","trip_module")
        instelling.createCheckBox("Weergeef automatisch de trip tags op de kaart ( vereist refresh van de pagina )","auto_trip_kaart")
        instelling.createCheckBox("Weergeef automatisch de trip tags op het eiland scherm","auto_trip_eiland")
        instelling.createCheckBox("Weergeef automatisch de trip tags op het profiel van een speler","auto_trip_profiel")
        instelling.createCheckBox("Weergeef trip tags bij je eigen steden","trip_eigen_stad")
        instelling.createTextBox("Bepaal de x-positie van de TripTag op de kaart ten opzichten van de stadsvlag.")
        instelling.createInputBox(70,"trip_pos_x")
        instelling.createTextBox("Bepaal de y-positie van de TripTag op de kaart ten opzichten van de stadsvlag.")
        instelling.createInputBox(60,"trip_pos_y")
        // opslaan knop
        instelling.createKnop("Opslaan",null)

        instelling.createInnerBox("archduke_menu_trip_allianties","Alleen voor onderstaande allianties zullen trip tag worden getoond.","Alliantie ID","Opslaan","input_ally_id",saveInstellingenAllianties)

        instelling.createInnerBox("archduke_menu_trip_spelers","Onderstaande spelers zullen geen trip tag krijgen.","Grepolis Naam","Opslaan","input_speler_id",saveInstellingenSpelers)

        instelling.createKnop("Reset instellingen", resetSettings)

        // voeg aan menu
        var menu_right = document.getElementById("archduke_menu_right")
        menu_right.appendChild(instelling.instelling)

        // 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]
            addRowToInnerBox(ally_id,"archduke_menu_trip_allianties",saveInstellingenAllianties)
        }
        for (let i=0; i < settings.trip_spelers.length;i++){
            var speler_id = settings.trip_spelers[i]
            addRowToInnerBox(speler_id,"archduke_menu_trip_spelers",saveInstellingenSpelers)
        }
        document.getElementById("archduke_menu_trip_pos_x").value = settings.trip_pos_x
        document.getElementById("archduke_menu_trip_pos_y").value = settings.trip_pos_y
    }

    function saveInstellingenAllianties(){
        var entries = document.body.querySelectorAll(".archduke_menu_trip_allianties")
        var allianties = []
        for (let i=0;i<entries.length;i++){
            var ally = entries[i]
            var ally_id = parseInt(ally.id.substring(30))
            allianties.push(ally_id)
        }
        GM_setValue("archduke_menu_trip_allianties",allianties)
    }

    function saveInstellingenSpelers(){
        var entries = document.body.querySelectorAll(".archduke_menu_trip_spelers")
        var spelers = []
        for (let i=0;i<entries.length;i++){
            var speler = entries[i]
            var speler_naam = speler.id.substring(27).trim()
            spelers.push(speler_naam)
        }
        GM_setValue("archduke_menu_trip_spelers",spelers)
    }

    /////////////////////////////////////////////////////////////////////////////
    // menu classes en knop
    /////////////////////////////////////////////////////////////////////////////
    function maakMenuKnop(){
        if (document.getElementById("archduke_menu") == null){
            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)
        }
        document.getElementById("archduke_menu").addEventListener('click', maakMenu)
    }

    function getImageData() {
        return ""
    }

    function addRowToInnerBox(input_txt,name,save_function){
        var li = document.createElement("li")
        li.style.listStyleType = 'square'
        li.setAttribute("class",name)
        li.setAttribute('id',name+"_"+input_txt)

        var a = document.createElement("a")
        a.innerHTML = input_txt
        li.appendChild(a)

        var a = document.createElement("a")
        a.setAttribute("class",'cancel')
        a.addEventListener('click', function(){
            li.remove()
            save_function()
        })
        li.appendChild(a)
        document.getElementById(`${name}_list`).appendChild(li)
    }

    class Instellingen {
        constructor (naam, titel, beschrijving){
            this.naam = naam
            this.instelling = this.createWrapper()
            this.parent = this.createParent()
            this.section = this.createSection(titel)
            this.group = this.createGroup(beschrijving)
            this.inner_box_add_row = this.addRowToInnerBox
        }
    
        createWrapper(){
            if (document.getElementById("archduke_menu_right") != null){
                document.getElementById("archduke_menu_right").innerHTML = ""
            }
            var el = document.createElement("div")
            el.setAttribute('id',"archduke_menu_instellingen")
            return el
        };
    
        createParent(){
            var form = document.createElement("form")
            this.instelling.appendChild(form)
            return form
        };
    
        createSection(titel){
            var section = document.createElement("div")
            section.setAttribute("class",'section')
            section.style.display = 'block'
    
            var section_titel = document.createElement("div")
            section_titel.innerHTML = titel
            section_titel.setAttribute("class",'game_header bold')
            section.appendChild(section_titel)
    
            this.parent.appendChild(section)
    
            return section
        };
    
        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)
    
            this.section.appendChild(group)
    
            return group
        };
    
        createCheckBox(beschrijving,id){
            var checkbox = document.createElement("div")
            checkbox.setAttribute('class',"checkbox_new large archduke_menu_checkbox")
            checkbox.setAttribute('id', `archduke_menu_${id}`)
    
            var btn = document.createElement("div")
            btn.setAttribute("class","cbx_icon")
            checkbox.appendChild(btn)
    
            var text = document.createElement("div")
            text.setAttribute("class","cbx_caption")
            text.innerHTML = beschrijving
            checkbox.appendChild(text)
    
            checkbox.addEventListener('click', function(){
                this.classList.toggle('checked')
            })
    
            this.group.appendChild(checkbox)
            var breakline = document.createElement("br")
            this.group.appendChild(breakline)
    
            return checkbox
        };

        createTextBox(text,id=null){
            var div = document.createElement("p")
            if (id != null){
                div.setAttribute("id",id)
            }
            div.innerHTML = text

            this.group.appendChild(div)
        }

        createInputBox(default_value,id){
            var div = document.createElement("div")
            div.setAttribute("class","windowmgr_max_concurrent_input textbox")

            var left = document.createElement("div")
            left.setAttribute("class","left")
            div.appendChild(left)

            var right = document.createElement("div")
            right.setAttribute("class","right")
            div.appendChild(right)

            var middle = document.createElement("div")
            middle.setAttribute("class","middle")
            div.appendChild(middle)

            var input = document.createElement("input")
            input.type = 'text'
            input.tabIndex = 1
            input.placeholder = default_value
            input.pattern = "^\d+$"
            input.setAttribute('id', `archduke_menu_${id}`)
            input.setAttribute('class',"archduke_menu_checkbox")
            middle.appendChild(input)

            var breakline = document.createElement("br")

            this.group.appendChild(div)
            this.group.appendChild(breakline)
        }
    
        createKnop(text, f){
            var el = document.createElement("div")
            el.setAttribute("class",'button_new')
            el.style.marginTop = "10px"
    
            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)
            
            if (f == null){
                btn.addEventListener('click', this.save_instellingen)
            } else {
                btn.addEventListener('click', f )
            }
            
    
            this.group.appendChild(el)
            return el
        };
    
        save_instellingen(){
            var instel = document.body.querySelectorAll(".archduke_menu_checkbox")
            for (let i=0;i<instel.length;i++){
                var box = instel[i]
                var id = box.id
                var tag = box.tagName

                if (tag == "INPUT"){
                    var checked = box.value
                } else {
                    var checked = false
                    if (box.classList.contains('checked')){
                        checked = true
                    }
                }
                
                GM_setValue(id,checked)
                console.log(id,GM_getValue(id))
            }
        };
    
        createInnerBox(name,box_title,label_text,button_text,input_id,save_function){
            var el = document.createElement("div")
            el.setAttribute("class",'game_inner_box')
            el.style.marginTop = '20px'
    
            var child = document.createElement('div')
            child.setAttribute('class',"game_border")
            el.appendChild(child)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_top")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_bottom")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_left")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_right")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_corner corner1")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_corner corner2")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_corner corner3")
            child.appendChild(e)
    
            var e = document.createElement('div')
            e.setAttribute('class',"game_border_corner corner4")
            child.appendChild(e)
    
            var title = document.createElement('div')
            title.setAttribute('class',"game_header bold")
            title.style.margin = '5px 0 5px 0'
            title.innerHTML = box_title
            child.appendChild(title)
    
            var list = document.createElement("div")
            var list_ul = document.createElement("ul")
            list_ul.setAttribute("class",'game_list')
            list_ul.setAttribute("id",`${name}_list`)
            list_ul.style.listStyle = 'disc'
            list_ul.style.width = '490px'
            list_ul.style.margin = '5px 0px 15px 35px'
            list.appendChild(list_ul)
            child.appendChild(list)
    
            var list_text = document.createElement('div')
            list_text.style.float = 'left'
            child.appendChild(list_text)
    
            var label = document.createElement("label")
            label.setAttribute("class","bold")
            label.style.marginLeft = '5px'
            label.innerHTML = label_text+" : "
            list_text.appendChild(label)
    
            var span = document.createElement("span")
            span.setAttribute("class","grepo_input")
            list_text.appendChild(span)
    
            var span_left = document.createElement("span")
            span_left.setAttribute("class","left")
            span.appendChild(span_left)
    
            var span_right = document.createElement("span")
            span_right.setAttribute("class","right")
            span_left.appendChild(span_right)
    
            var input = document.createElement("input")
            input.setAttribute("class", 'ac_input')
            input.setAttribute("id",input_id)
            input.type = 'text'
            input.value = ''
            input.autocomplete = 'off'
            span_right.appendChild(input)
    
            var btn = this.createKnop(button_text)
            child.appendChild(btn)
            btn.addEventListener('click', function(){
                var input_txt = document.getElementById(input_id).value
                if (input_txt != ""){
                    input_txt = input_txt.trim()
                    document.getElementById(input_id).value = ''
                    var li = document.createElement("li")
                    li.style.listStyleType = 'square'
                    li.setAttribute("class",name)
                    li.setAttribute('id',name+"_"+input_txt)
            
                    var a = document.createElement("a")
                    a.innerHTML = input_txt
                    li.appendChild(a)
            
                    var a = document.createElement("a")
                    a.setAttribute("class",'cancel')
                    a.addEventListener('click', function(){
                        li.remove()
                        save_function()
                    })
                    li.appendChild(a)
                    list_ul.appendChild(li)
                    save_function()
                }
            })
    
            this.group.appendChild(el)
        };
    
    }
    
    class ArchdukeMenu {
    
        constructor(titel){
            this.titel = titel
            this.window = this.createWindow()
            this.frame = this.window.parentElement.parentElement.children[1].children[4]
            this.menu_selection = this.createMenuSelectorContainer()
            this.instelling = this.createMenuContentContainer()
        }
    
        checkMenuOpen(){
            var find = false
            var dom_element = null
            for(let i of document.getElementsByClassName('ui-dialog-title')){
                if(i.innerHTML == this.titel){
                    find = true;
                    dom_element = i
                }
            }
            return [find,dom_element]
        }
    
        createWindow(){
            var [find,dom_element] = this.checkMenuOpen()
            if (find == false){
                var window = Layout.wnd.Create(Layout.wnd.TYPE_DIALOG, this.titel);
                // 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 == this.titel){
                        dom_element = i;
                    }
                }
            }
            console.log(find)
            return dom_element
        }
    
        createMenuSelectorContainer(){
            var container_left = document.getElementById("archduke_menu_left")
            var list = document.getElementById("archduke_menu_module_list")
            if ( container_left == null){
    
                var container_left = document.createElement("div")
                container_left.setAttribute("id","archduke_menu_left")
                container_left.setAttribute("class",'settings_menu')
    
                var el = document.createElement("b")
                el.innerHTML = 'Scripts'
                container_left.appendChild(el)
    
                list = document.createElement("ul")
                list.setAttribute("id","archduke_menu_module_list")
                container_left.appendChild(list)
    
                this.frame.appendChild(container_left)
            }
            return list
        }
    
        createMenuContentContainer(){
            var container_right = document.getElementById("archduke_menu_right")
            if (container_right == null){
                var container_right = document.createElement("div")
                container_right.setAttribute("id","archduke_menu_right")
                container_right.setAttribute("class",'settings-container')
                this.frame.appendChild(container_right)
            }
            return container_right
        }
    
        addItemMenuSelection(naam,f){
            if (document.getElementById(`archduke_menu_selection_${naam}`) == null){
                var el = document.createElement("li")
                el.style.marginBottom = '10px'
                var a = document.createElement('a')
                a.innerHTML = naam
                a.setAttribute("class",`settings-link`)
                a.setAttribute("id",`archduke_menu_selection_${naam}`)
                a.addEventListener('click', function(){
                    f()
                })
                el.appendChild(a)
                this.menu_selection.appendChild(el)
            }
        }

        clickMenu(naam){
            var btn = document.getElementById(`archduke_menu_selection_${naam}`)
            if (btn != null){
                btn.click()
            }
        }
    }

})();