// ==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", false)
GM_setValue("archduke_menu_auto_trip_eiland", false)
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)
}
// verkrijg de voorkeuren
function laadSettings(){
var auto_trip_kaart = GM_getValue('archduke_menu_auto_trip_kaart')
if (auto_trip_kaart == null){
auto_trip_kaart = false
}
var auto_trip_eiland = GM_getValue('archduke_menu_auto_trip_eiland')
if (auto_trip_eiland == null){
auto_trip_eiland = false
}
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","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()
}
}
}
})();