您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
Set of tools and aids for the game Gladiatus
当前为
// ==UserScript== // @name Gladiatus Tools // @namespace http://greasyfork.icu/users/904482 // @version 0.4.0 // @description Set of tools and aids for the game Gladiatus // @author lpachecob // @grant none // @match *.gladiatus.gameforge.com/game/index.php* // @icon https://cdn.jsdelivr.net/gh/lpachecob/Gladiatus-Tools@main/images/favicon.ico // @license MIT // ==/UserScript== //global variables const getURL = window.location.search.split("&"); const oro = parseInt(document.getElementById("sstat_gold_val").innerText.replace(/\./g, '')); var dobleClickEvent = document.createEvent('MouseEvents'); dobleClickEvent.initEvent('dblclick', true, true); let sh = { get : ()=>{ for (let element of getURL) { if(element.includes("sh") == true){ return element; } } } } class GladiatusTools{ static SetTool(){ const mainMenu = document.getElementById("mainmenu"); if (getURL[0] == "?mod=guildMarket" && getURL[1] != "submod=control") { Mercado.Run(); } else if (getURL[0] == "?mod=guildMarket" && getURL[1] == "submod=control") { //comming soon } else if (getURL[0] == "?mod=auction") { AcutionHouseTools(); } else if (getURL[0] == "?mod=forge" && getURL[1] == "submod=smeltery") { SmelteryTimeSaverExtension(); } else if (getURL[0] == "?mod=forge" && getURL[1] == "submod=forge") { Herreria(); }else if(getURL[0] == "?mod=packages"){ Paquetes.UI(); Paquetes.MoverFiltros(); } } static Run(){ Menu.Dibujar(); GladiatusTools.SetTool(); Notificaciones.Rotativos(); GuardarOro.Run(); ExtenderBotones.Paquetes(); window.addEventListener("load", () => { localStorage.TimeSaverExist = TimeSaver.Exist(); TimeSaver.setKeyForStop(JSON.parse(localStorage.TimeSaverExist)); TimeSaver.StopOnKey(); }); } } class insertOnPage{ // Antes que el propio elemento. static beforebegin(object, html){ object.insertAdjacentHTML("beforebegin", html); } //Justo dentro del elemento, antes de su primer elemento hijo. static afterbegin(object, html){ object.insertAdjacentHTML("afterbegin", html); } //Justo dentro del elemento, después de su último elemento hijo. static beforeend(object, html){ object.insertAdjacentHTML("beforeend", html); } //Después del propio elemento. static afterend(object, html){ object.insertAdjacentHTML("afterend", html); } } class Observer{ static ForRemovedNodes(ItemForWait, instructions){ const observer = new MutationObserver((mutationList) => { mutationList.forEach((mutation)=> { if(mutation.removedNodes.length){ instructions(); } }) }); // Opcions para el observer const observerOptions = { attributes: true, childList: true, subtree: true, characterData: false, attributeOldValue: false, characterDataOldValue: false }; observer.observe(ItemForWait, observerOptions); } } class Formatter{ static abbreviateNumber(number){ var SI_SYMBOL = ["", "k", "kk", "kkk", "kkkk", "kkkkk", "kkkkkk"]; // what tier? (determines SI symbol) var tier = Math.log10(Math.abs(number)) / 3 | 0; // if zero, we don't need a suffix if(tier == 0) return number; // get suffix and determine scale var suffix = SI_SYMBOL[tier]; var scale = Math.pow(10, tier * 3); // scale the number var scaled = number / scale; // format number and add suffix return scaled.toFixed(1) + suffix; } } class Menu{ static Dibujar(){ document.body.insertAdjacentHTML("afterbegin",` <style> .menutools { display: none; width: 422px; height: -webkit-fill-available; position: fixed; z-index: 10000; top: 0; right: 0; background-color: #111; overflow-x: hidden; padding-top: 16px; padding-left: 12px; } .menutools a { padding: 8px 8px 8px 32px; text-decoration: none; font-size: 25px; color: #818181; display: block; } .menutools a:hover { color: #f1f1f1; } .menutools .closebtn { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; } .menutools > h1{ color: #ffffff; } .menutools > h2{ color: #ffffff; } .menutools > h3{ color: #ffffff; } .menutools > label{ color: #ffffff; } .menutools > div{ color: #ffffff; } .btnMenu{ font-size:20px; cursor:pointer; position: fixed; top: 134px; right: 4%; background: transparent; border: transparent; z-index: 10000; } @media screen and (max-height: 450px) { .menutools { padding-top: 15px; } .menutools a { font-size: 18px; } } </style> <button id="MenuOpen" title="𝗖𝗢𝗡𝗙𝗜𝗚𝗨𝗥𝗔𝗖𝗜𝗢𝗡\nGLADIATUS TOOLS" class="btnMenu"> <img style="height: 112px;" src="https://cdn.jsdelivr.net/gh/lpachecob/Gladiatus-Tools@main/images/favicon.ico"></button> <div id="menuSidenav" class="menutools"> <h1>Configuración</h1> <hr/> <a id="CloseMenu" href="#" class="closebtn">×</a> <div id="menuContent"></div> </div> `); let menuOpen = document.getElementById("MenuOpen"); menuOpen.addEventListener("click", Menu.openNav); menuOpen.addEventListener("touchstart",Menu.openNav); let closeMenu = document.getElementById("CloseMenu"); closeMenu.addEventListener("click", Menu.closeNav); } static openNav() { document.getElementById("menuSidenav").style.display = "block"; } static closeNav() { document.getElementById("menuSidenav").style.display = "none"; } static addConfig(html){ html+= "<hr/>" insertOnPage.beforeend(document.getElementById("menuContent"),html); } } class Notificaciones{ static Rotativos(){ Menu.addConfig(` <h2>Notificaciones</h2> <ul> <label><input type="checkbox" id="NotificarOro" style=""> Notifica si tengo oro para guardar</label> </ul> <ul id="MontosNotificar" style="display: flex;background-color: white;width: 324px;height: auto;margin-left: 43px;padding: 6px;flex-direction: row;flex-wrap: wrap;"> <input type="number" title="Presiona ENTER para guardar." id="InputNotificarOro" placeholder="Oro" style="background-color: #bebebe;color: white;font-weight: bold;font-size: 12px;width: 79px;height: 23px;"> </ul> `); let MontosNotificar = document.getElementById("MontosNotificar"); let InputNotificarOro = document.getElementById("InputNotificarOro"); let MontosGuardados = []; if(localStorage.MontosGuardados == undefined){ localStorage.MontosGuardados = '["100000"]'; }else{ MontosGuardados = JSON.parse(localStorage.MontosGuardados) } InputNotificarOro.addEventListener("keypress",(input)=>{ if (input.key === 'Enter') { if (!MontosGuardados.includes(InputNotificarOro.value) && InputNotificarOro.value != "") { MontosGuardados.push(InputNotificarOro.value); InputNotificarOro.value = ""; localStorage.MontosGuardados = JSON.stringify(MontosGuardados.sort(function(a, b){return a - b})); window.location.reload() } } }); let NotificarOro = document.getElementById("NotificarOro"); //.checked indica si está activo o no if (localStorage.NotificarOro == undefined) { localStorage.NotificarOro = NotificarOro.checked } else { NotificarOro.checked = JSON.parse(localStorage.NotificarOro); } NotificarOro.addEventListener("change", () => { localStorage.NotificarOro = NotificarOro.checked; }) if (JSON.parse(localStorage.NotificarOro) == true) { Notificaciones.Mensaje(); Notificaciones.MostrarRotativosSeleccionados(); Notificaciones.EliminarRotativo(); } } static Mensaje(){ let MontosGuardados = JSON.parse(localStorage.MontosGuardados); let mensaje = ""; for(let monto of MontosGuardados){ if (Math.floor(oro / monto) >= 2) { mensaje += `Empaqueta ` + Math.floor(oro / monto) + ` rotativos de `+ Formatter.abbreviateNumber(monto)+`\n`; } else if (Math.floor(oro / monto) == 1) { mensaje += `Empaqueta ` + Math.floor(oro / monto) + ` rotativo de `+ Formatter.abbreviateNumber(monto)+`\n`; } } if (mensaje != "") { document.getElementById("mmonetbar").insertAdjacentHTML("beforeend",` <a href="game/index.php?mod=guildMarket" style="display: contents;"> <div id="testnoti" class="notification-box notification-info" style="position: fixed;right: 0px;"><div class="icon"></div>` + mensaje + `</div> </a> <style> /* Notifications */ .notification-box{cursor: pointer;background-position: 15px center;background-repeat: no-repeat;box-shadow: 0 0 12px #000;color: #FFFFFF;margin: 0 0 6px;opacity: 0.9;padding: 5px 5px 5px 28px;width: 200px;white-space: pre-wrap; z-index: 10000;}.notification-info{background-color: #2F96B4;border: 1px solid #267890;} <style>`); } } static MostrarRotativosSeleccionados(){ let MontosGuardados = JSON.parse(localStorage.MontosGuardados); let indiceDeRotativoBorrar; let MontosNotificar = document.getElementById("MontosNotificar"); let contador = 0; for(let monto of MontosGuardados){ insertOnPage.beforeend(MontosNotificar,` <div style="border-style: groove;color: black;width: fit-content;padding: 2px;font-size: 12px;"> `+Formatter.abbreviateNumber(monto)+` <button name="NotificaRotativoBorrar" data-index="`+contador+`" style="color: red;font-weight: bold;font-size: 16px;border: none;background: none;">x</button> </div> `) contador++; } } static EliminarRotativo(){ let MontosGuardados = JSON.parse(localStorage.MontosGuardados); let NotificaRotativoBorrar = document.getElementsByName("NotificaRotativoBorrar") for (let boton of NotificaRotativoBorrar) { boton.addEventListener("click",()=>{ MontosGuardados.splice(boton.attributes[1].value,1) localStorage.MontosGuardados = JSON.stringify(MontosGuardados.sort(function(a, b){return a - b})); window.location.reload() }) boton.addEventListener("touchstart",()=>{ MontosGuardados.splice(boton.attributes[1].value,1) localStorage.MontosGuardados = JSON.stringify(MontosGuardados.sort(function(a, b){return a - b})); window.location.reload() }) } } } class Mercado{ static Config(){ Menu.addConfig(` <h2>Mercado de la Alianza</h2> <ul id="MercadoAlianza" style="display: flex;background-color: white;width: 324px;height: auto;margin-left: 43px;padding: 6px;flex-direction: row;flex-wrap: wrap;"> <input type="number" title="Presiona ENTER para guardar." id="InputMercadoAlianza" placeholder="Oro" style="background-color: #bebebe;color: white;font-weight: bold;font-size: 12px;width: 79px;height: 23px;"> </ul> `); let MercadoAlianza = document.getElementById("MercadoAlianza"); let InputMercadoAlianza = document.getElementById("InputMercadoAlianza"); let MontosMercado = []; if(localStorage.MontosMercado == undefined){ localStorage.MontosMercado = '["100000"]'; }else{ MontosMercado = JSON.parse(localStorage.MontosMercado) } InputMercadoAlianza.addEventListener("keypress",(input)=>{ if (input.key === 'Enter') { if (!MontosMercado.includes(InputMercadoAlianza.value) && InputMercadoAlianza.value != "") { MontosMercado.push(InputMercadoAlianza.value); InputMercadoAlianza.value = ""; localStorage.MontosMercado = JSON.stringify(MontosMercado.sort(function(a, b){return a - b})); window.location.reload() } } }); } static MostrarRotativosSeleccionados(){ let MontosMercado = JSON.parse(localStorage.MontosMercado); let indiceDeRotativoBorrar; let MercadoAlianza = document.getElementById("MercadoAlianza"); let contador = 0; for(let monto of MontosMercado){ insertOnPage.beforeend(MercadoAlianza,` <div style="border-style: groove;color: black;width: fit-content;padding: 2px;font-size: 12px;"> `+Formatter.abbreviateNumber(monto)+` <button name="MercadoRotativoBorrar" data-index="`+contador+`" style="color: red;font-weight: bold;font-size: 16px;border: none;background: none;">x</button> </div> `) contador++; } } static EliminarRotativo(){ let MontosMercado = JSON.parse(localStorage.MontosMercado); let NotificaRotativoBorrar = document.getElementsByName("MercadoRotativoBorrar") for (let boton of NotificaRotativoBorrar) { boton.addEventListener("click",()=>{ MontosMercado.splice(boton.attributes[1].value,1) localStorage.MontosMercado = JSON.stringify(MontosMercado.sort(function(a, b){return a - b})); window.location.reload() }) boton.addEventListener("touchstart",()=>{ MontosMercado.splice(boton.attributes[1].value,1) localStorage.MontosMercado = JSON.stringify(MontosMercado.sort(function(a, b){return a - b})); window.location.reload() }) } } static VentaRapida(){ let panelVenta = document.getElementById("sellForm"); let inputPrecio = document.getElementById("preis"); let inputDuracion = document.getElementById("dauer"); let botonVender = document.getElementsByName("anbieten")[0]; let marketInventory = document.getElementById("market_inventory"); let oro = parseFloat(document.getElementById("sstat_gold_val").textContent); let cajaVenta = document.getElementsByClassName("ui-droppable")[0]; let contentItem = document.getElementsByClassName("contentItem")[0]; insertOnPage.afterbegin(contentItem,` <h2 id="VentaRapidaMenuTitle" class="section-header" style="cursor: pointer;">Venta Rapida</h2> <section id="VentaRapidaMenu" style="display: block;"> <p>Coloca un item y elige el precio para vender.</p> </section> `); insertOnPage.beforebegin(panelVenta,` <section id="CompraRapidaMenu" style="display: block; margin: 12px;"> <label title="Solo se comprarán los objetos cuyo valor sea igual a los que tienen los rotativos" style="cursor: pointer;"> <button id="CompraTodo" class="awesome-button">Comprar</button> </label> <select id="TipoCompra" style="margin: 8px; font-size: 14px;"> <option>Mayor a menor ⬇</option> <option>Menor a mayor ⬆</option> </select> </section> `); let MontosMercado = JSON.parse(localStorage.MontosMercado); let ventaRapidaMenu = document.getElementById("VentaRapidaMenu"); for(let monto of MontosMercado){ insertOnPage.beforeend(ventaRapidaMenu,` <button name="BotonVender" data-input="`+monto+`" class="awesome-button" style="margin:5px;" data-toggle="tooltip" title="Costo de venta: `+Formatter.abbreviateNumber(monto*0.04)+` 💰" >`+Formatter.abbreviateNumber(monto)+`</button> `) }; insertOnPage.beforeend(ventaRapidaMenu,` <section id="" style="display: block; margin: 11px"> <small>Elegir duración</small> <select id="SelectHora" size="1"> <option value="1">2 h</option> <option value="2">8 h</option> <option value="3">24 h</option> </select> </section>`); let selectHora = document.getElementById("SelectHora"); if (localStorage.SelectHora == undefined) { localStorage.SelectHora = 1; selectHora.value = 1; } else { selectHora.value = localStorage.SelectHora; } selectHora.addEventListener("change", (event) => { localStorage.SelectHora = selectHora.value; }); let ventaRapidaMenuTitle = document.getElementById("VentaRapidaMenuTitle"); ventaRapidaMenuTitle.addEventListener("click", () => { if (ventaRapidaMenu.style.display == "none") { ventaRapidaMenu.style.display = "block"; } else { ventaRapidaMenu.style.display = "none"; } }); ventaRapidaMenuTitle.addEventListener("touchstart",()=>{ if (ventaRapidaMenu.style.display == "none") { ventaRapidaMenu.style.display = "block"; } else { ventaRapidaMenu.style.display = "none"; } }); let BotononesVender = document.getElementsByName("BotonVender") for (let boton of BotononesVender) { boton.addEventListener("click",()=>{ inputPrecio.value = boton.attributes[1].value; inputDuracion.value = localStorage.SelectHora; botonVender.click(); }) boton.addEventListener("touchstart",()=>{ inputPrecio.value = boton.attributes[1].value; inputDuracion.value = localStorage.SelectHora; botonVender.click(); }) } } static Comprar(){ let CompraTodo = document.getElementById("CompraTodo"); let TipoCompra = document.getElementById("TipoCompra"); let MontosMercado = JSON.parse(localStorage.MontosMercado); if (localStorage.TipoCompra == undefined) { localStorage.TipoCompra = 0; } else { TipoCompra.selectedIndex = localStorage.TipoCompra; } TipoCompra.addEventListener("change", (event) => { localStorage.TipoCompra = TipoCompra.selectedIndex; }); let marketTableChildren = document.getElementById("market_table").children[0].children[0].children let marketItems = []; for (let item of marketTableChildren) { if(item.tagName == "TR" && item.children[0].tagName == "TD" && item.children[1].children[0].children[0].style.color == "green"){ if(MontosMercado.includes(item.children[2].innerText.replace(/\./g, ''))){ marketItems.push(item) } } } CompraTodo.addEventListener("click",()=>{ switch(TipoCompra.selectedIndex){ case 0 : Mercado.Mayor_Menor(marketItems); break; case 1: Mercado.Menor_Mayor(marketItems); break default: console.error("No se pudo procesar la compra"); break; } }) } static Mayor_Menor(marketItems){ let aux = marketItems[0].children[2].innerText.replace(/\./g, '') let oro = parseInt(document.getElementById("sstat_gold_val").textContent.replace(/\./g, '')); let orden = [] for (let item of marketItems) { if(item.children[2].innerText.replace(/\./g, '') >= aux){ orden.unshift(item) } aux = item.children[2].innerText.replace(/\./g, ''); } for (let item of orden){ let valor = parseInt(item.children[2].innerText.replace(/\./g, '')) //; //console.log(item.children[2].innerText.replace(/\./g, '')) if(valor < oro){ item.children[5].children[0].click(); oro = oro - valor; } } } static Menor_Mayor(marketItems){ let aux = marketItems[0].children[2].innerText.replace(/\./g, '') let oro = parseInt(document.getElementById("sstat_gold_val").textContent.replace(/\./g, '')); let orden = [] for (let item of marketItems) { if(item.children[2].innerText.replace(/\./g, '') >= aux){ orden.push(item) } aux = item.children[2].innerText.replace(/\./g, ''); } for (let item of orden){ let valor = parseInt(item.children[2].innerText.replace(/\./g, '')) //; //console.log(item.children[2].innerText.replace(/\./g, '')) if(valor < oro){ item.children[5].children[0].click(); oro = oro - valor; } } } static Run(){ Mercado.Config(); Mercado.MostrarRotativosSeleccionados(); Mercado.EliminarRotativo(); Mercado.VentaRapida(); Mercado.Comprar(); } } function AcutionHouseTools() { let item = document.getElementsByTagName("TD"); let oro = parseInt(document.getElementById("sstat_gold_val").textContent.replace(/\./g, '')); let menu = document.getElementsByClassName("section-header")[1]; menu.insertAdjacentHTML( "beforebegin", ` <h2 id = "MenuCompraTitle" class = "section-header" style = "cursor: pointer;"> Compra Rápida </h2> <section id = "MenuCompra" style = "display: block;"> </section>` ); let SectionMenuCompra = document.getElementById("MenuCompra"); /* SectionMenuCompra.insertAdjacentHTML('beforeend', ` <p>Indica un precio máximo para comprar o compra todo lo que te alcance.</p> <p><small>No se sobrepujará a los compañeros de alianza.</small></p> `); */ SectionMenuCompra.insertAdjacentHTML( "beforeend", ` <p>Se comprará todo lo que alcance con el oro que tienes.</p> <p><small>No se sobrepujará a los compañeros de alianza.</small></p> ` ); SectionMenuCompra.insertAdjacentHTML( "beforeend", ` <input type = "number" id = "OroMaximo" placeholder = "Oro máximo a gastar" style = "width:150px" hidden>` ); SectionMenuCompra.insertAdjacentHTML( "beforeend", ` <button id = "BotonComprar" class = "awesome-button" style = "margin:5px;" data-toggle = "tooltip" title = "Se comprará toda la comida que alcance con el oro que tengas"> Comprar todo </button>` ); let oroMaximo = document.getElementById("OroMaximo"); let botonComprar = document.getElementById("BotonComprar"); oroMaximo.addEventListener("input", () => { if (oroMaximo.value.length > 0) { botonComprar.title = "Se comprara la comida que alcance con: " + oroMaximo.value + " 🥇"; botonComprar.innerHTML = "\n Comprar \n"; } else if (oroMaximo.value.length == 0) { botonComprar.title = "Se comprará toda la comida que alcance con el oro que tengas"; botonComprar.innerHTML = "\n Comprar todo\n"; } }); botonComprar.addEventListener("click", () => { if (oroMaximo.value.length > 0) { //Proximamente } else if (oroMaximo.value.length == 0) { for (let isItem = 0; isItem < item.length; isItem++) { if(item[isItem].hasAttribute("width")==true){ let auction_bid_div = item[isItem].children[1].children[0].children[7].children; let auction_item_div = item[isItem].children[1].children[0].children[6].children[1].children[0]; let itemSplit = auction_item_div.attributes[6].textContent.substring(4,9); //console.log(auction_bid_div[2]); let costo = parseInt(auction_bid_div[2].value); if (costo < oro) { oro = oro - costo; //console.log(oro," - ",costo) let PujaDeAlguien; if ( auction_bid_div[0].innerText.split("\n")[0] == "No hay pujas." || auction_bid_div[0].innerText.split("\n")[0] == "Ya hay pujas existentes." ) { //items[i].children[3].click(); if(itemSplit != "Pollo"){ auction_bid_div[3].click(); } } } } } } }); botonComprar.addEventListener("touchstart",()=>{ if (oroMaximo.value.length > 0) { //Proximamente } else if (oroMaximo.value.length == 0) { for (let isItem = 0; isItem < item.length; isItem++) { if(item[isItem].hasAttribute("width")==true){ let auction_bid_div = item[isItem].children[1].children[0].children[7].children; let auction_item_div = item[isItem].children[1].children[0].children[6].children[1].children[0]; let itemSplit = auction_item_div.attributes[6].textContent.substring(4,9); //console.log(auction_bid_div[2]); let costo = parseInt(auction_bid_div[2].value); if (costo < oro) { oro = oro - costo; //console.log(oro," - ",costo) let PujaDeAlguien; if ( auction_bid_div[0].innerText.split("\n")[0] == "No hay pujas." || auction_bid_div[0].innerText.split("\n")[0] == "Ya hay pujas existentes." ) { //items[i].children[3].click(); if(itemSplit != "Pollo"){ auction_bid_div[3].click(); } } } } } } }); let menuCompraTitle = document.getElementById("MenuCompraTitle"); menuCompraTitle.addEventListener("click", () => { if (SectionMenuCompra.style.display == "none") { SectionMenuCompra.style.display = "block"; } else { SectionMenuCompra.style.display = "none"; } }); } function SmelteryTimeSaverExtension() { let inv = document.getElementById("inv") window.addEventListener("load", () => { if (document.getElementsByClassName("smelter-actions")[0] != undefined) { let inventario = document.getElementsByClassName("smelter-actions")[0]; let items = document.getElementsByClassName("ui-draggable"); let btnFundicion = FindBtn("Iniciar función"); let btnGuardarRecursos = FindBtn("Enviar todo a Horreum"); let mensaje = document.getElementsByClassName("gts-error-message")[0]; inventario.insertAdjacentHTML( "beforeend", ` <strong>Acciones Rapidas</strong> <br/> Selecciona un inventario para fundir <select id="SelectInventario" size="1"> <option value="Ⅰ">Ⅰ</option> <option value="Ⅱ">Ⅱ</option> <option value="Ⅲ">Ⅲ</option> <option value="Ⅳ">Ⅳ</option> <option value="Ⅴ">Ⅴ</option> <option value="Ⅵ">Ⅵ</option> <option value="Ⅶ">Ⅶ</option> <option value="Ⅷ">Ⅷ</option> </select> <hr> <button class="awesome-button" type="button" id="FundirTodo"> Fundir Todo </button> <button class="awesome-button" type="button" id="GuardarFundir"> Guardar y Fundir </button> ` ); let selectInventario = document.getElementById("SelectInventario"); let inventoryTabs = document.getElementsByClassName("awesome-tabs"); let inventorySelected; for (let index = 4; index < inventoryTabs.length; index++) { if (inventoryTabs[index].text == localStorage.InventarioFundicion) { inventorySelected = inventoryTabs[index]; } } if(localStorage.GuardarRecursos == undefined){ localStorage.GuardarRecursos = false; } const observer = new MutationObserver((mutationList) => { mutationList.forEach((mutation)=> { if(mutation.removedNodes.length){ if(JSON.parse(localStorage.GuardarRecursos) == true){ inventorySelected.click(); btnFundicion.click(); for (let index = 9; index < items.length; index++) { items[index].click(); } localStorage.GuardarRecursos = false; } } }) }); // Opcions para el observer const observerOptions = { attributes: true, childList: true, subtree: true, characterData: false, attributeOldValue: false, characterDataOldValue: false }; observer.observe(inv, observerOptions); if(JSON.parse(localStorage.GuardarRecursos) == true){ inventorySelected.click(); btnFundicion.click(); for (let index = 9; index < items.length; index++) { items[index].click(); } localStorage.GuardarRecursos = false; } let GuardarFundir = document.getElementById("GuardarFundir"); GuardarFundir.addEventListener("click", () => { localStorage.GuardarRecursos = true; btnGuardarRecursos.click(); }); let fundirTodo = document.getElementById("FundirTodo"); fundirTodo.addEventListener("click",()=>{ inventorySelected.click(); btnFundicion.click(); for (let index = 9; index < items.length; index++) { items[index].click(); } }); mensaje.addEventListener("DOMNodeInserted", () => { window.location.reload(); }, false); } else { console.log("time saver extension not installed"); } }); function FindBtn(textContent) { let elements = document.getElementsByClassName("awesome-button"); let elementsArray = [].slice.call(elements); for (let index = 0; index < elementsArray.length; index++) { let element = elementsArray[index]; if (element.textContent === textContent) { return element; } } } function Observer(observar){ let observerReturn = [[],[]] const observer = new MutationObserver((mutationList) => { mutationList.forEach((mutation)=> { if(mutation.addedNodes.length){ observerReturn[0].push(mutation.addedNodes[0]); } if(mutation.removedNodes.length){ observerReturn[1].push(mutation.removedNodes[0]); } //console.log(mutation.type); }) }); // Opcions para el observer const observerOptions = { attributes: true, childList: true, subtree: true, characterData: false, attributeOldValue: false, characterDataOldValue: false }; observer.observe(observar, observerOptions); return observerReturn; } } function Herreria(){ /*let selectPrefix0 = document.getElementById("prefix0") selectPrefix0.hidden; selectPrefix0.insertAdjacentHTML("beforebegin",`<input id="inputPrefix" list="prefixList" style="width: 102px;"><datalist id="prefixList"></option></datalist>`); let inputPrefix = document.getElementById("inputPrefix"); inputPrefix.setAttribute("onkeyup",selectPrefix0.attributes.onkeyup.textContent); inputPrefix.setAttribute("onchange",selectPrefix0.attributes.onchange.textContent); let prefixList = document.getElementById("prefixList"); let prefijos = [[],[],[],[]] let prefijosOptgroup = document.getElementsByTagName("optgroup")[0].children for (let index = 0; index < prefijosOptgroup.length; index++) { prefijos[0].push(prefijosOptgroup[index].text) prefijos[1].push(prefijosOptgroup[index].value) prefijos[2].push(prefijosOptgroup[index].attributes["data-level"].textContent); prefijos[2].push(prefijosOptgroup[index].attributes["data-name"].textContent); } for (let index = 0; index < prefijos[0].length; index++) { var option = document.createElement('option'); option.value = prefijos[0][index]; option.setAttribute("data_value",prefijos[1][index]); prefixList.appendChild(option); } inputPrefix.addEventListener("change",()=>{ selectPrefix0.selectedIndex = prefijos[0].indexOf(inputPrefix.value); selectPrefix0.value = prefijos[1][prefijos[0].indexOf(inputPrefix.value)]; });*/ } class Paquetes { static filtros(){ let inputQry = document.getElementsByName("qry"); inputQry[0].setAttribute("list","customSearch"); inputQry[0].insertAdjacentHTML("afterend", `<datalist id="customSearch"></datalist>`); /*let GladiatusToolsMenu = document.getElementById("GladiatusToolsMenu"); GladiatusToolsMenu.insertAdjacentHTML("beforeend",` <button class="dropbtn"></button> <div class="dropdown-content" id="GladiatusToolsMenu"> menu de paquetes </div> `);*/ } static UI(){ let inventoryBox = document.getElementsByClassName("inventoryBox")[0]; insertOnPage.afterbegin(inventoryBox,` <div> <div class="panelBusqueda"></div> <button id="buscarRotativos" class="awesome-button buscarRotativos">🔎 Buscar Items</button> <input class="SelectCategorias" type="search" id="categoria" list="listaCategorias" value="Mercado"> <datalist id="listaCategorias"> <option>Banco de trabajo</option> <option>Casa de subastas</option> <option>Ermitaño</option> <option>Expedición</option> <option>Fundición</option> <option>Jefe de la Mazmorra</option> <option>Mazmorra</option> <option>Mercado</option> <option>Panteón</option> <option>Recompensa de la misión</option> </datalist> <div id="MercadoFavoritos" class="Favoritos" style="display: none"><h2 id="mensaje"></h2></div> <style> @media only screen and (max-width: 1760px) { .panelBusqueda{position: inherit; height: 41px; width: 299px; background: #ded2ad; left: 305px; top: -33px; } .buscarRotativos{position: relative; right: -22px; top: -26px; color: white; font-weight: bold; font-size: 13px;} .SelectCategorias{ position: relative; right: -30px; top: -23px; width: 132px; font-size: 18px;} .Favoritos {position: relative; width: 278px; height: 97px; top: -14px; background: rgb(222, 210, 173); padding: 11px; overflow: scroll; overflow-x: hidden;} } @media only screen and (min-width: 1760px) { .panelBusqueda{position: absolute;height: 41px;width: 408px;background: #ded2ad;left: 405px;top: -33px;} .buscarRotativos{position: absolute;right: -255px;top: -25px;color: white;font-weight: bold;font-size: 13px;} .SelectCategorias{position: absolute; right: -476px; top: -23px;} .Favoritos {position: absolute; width: 388px; height: 395px; left: 405px; top: 8px; background: rgb(222, 210, 173); padding: 10px; display: block;overflow: scroll;overflow-x: hidden; display:none;} } .Favoritos::-webkit-scrollbar { width: 10px; } /* Track */ .Favoritos::-webkit-scrollbar-track { background: #f1f1f1; } /* Handle */ .Favoritos::-webkit-scrollbar-thumb { background: #888; } /* Handle on hover */ .Favoritos::-webkit-scrollbar-thumb:hover { background: #555; } </style> </div>`) let buscarRotativos = document.getElementById("buscarRotativos"); let categoria = document.getElementById("categoria"); buscarRotativos.addEventListener("click",()=>{ Paquetes.PonerEnFavoritos(categoria.value) }) buscarRotativos.addEventListener("touchstart",()=>{ Paquetes.PonerEnFavoritos(categoria.value) }) if(localStorage.paquetesCategoria == undefined){ localStorage.paquetesCategoria = "Mercado"; }else{categoria.value = localStorage.paquetesCategoria} categoria.addEventListener("change",()=>{localStorage.paquetesCategoria = categoria.value}); } static PonerEnFavoritos(textContent){ let MercadoFavoritos = document.getElementById("MercadoFavoritos"); let rotativos = Paquetes.EncontrarRotativos(textContent); MercadoFavoritos.style.display = "block"; MercadoFavoritos.innerHTML = `<h2 id="mensaje"></h2>`; let mensaje = document.getElementById("mensaje"); if (rotativos.length > 0){ mensaje.innerText = "Objetos Encontrados!"; for (let item of rotativos) { MercadoFavoritos.append(item) } } else {mensaje.innerHTML = ` <div title="Se recomienda utilizar la extención gladiatus crazy addon\ny colocar el 'Número de paginas a cargar' desde 10 en adelante" style="text-align: center;"> No se encontraron objetos, intenta nuevamente. <?xml version="1.0" ?><svg style="width: 13px; margin-top: -42px; margin-bottom: -25px; margin-left: 281px;" height="48" viewBox="0 0 48 48" width="48" xmlns="http://www.w3.org/2000/svg"><path d="M0 0h48v48h-48z" fill="none"/><path d="M22 34h4v-12h-4v12zm2-30c-11.05 0-20 8.95-20 20s8.95 20 20 20 20-8.95 20-20-8.95-20-20-20zm0 36c-8.82 0-16-7.18-16-16s7.18-16 16-16 16 7.18 16 16-7.18 16-16 16zm-2-22h4v-4h-4v4z"/></svg> </div> <br/>`;} } static EncontrarRotativos(textContent){ let rotativos = [] let packages = document.getElementById("packages"); //packages.children[1].children[2].children[0].attributes[6].textContent.includes("Oro") for (let item of packages.children) { if(!!item.children[1] == true && item.children[1].textContent == textContent ){ let atributes = item.children[2].children[0].attributes; for (let atribute of atributes) { if(atribute.name == "data-tooltip"){ if(atribute.textContent.includes('Oro","white"') == false){ rotativos.push(item) } } } } } return rotativos } static MoverFiltros(){ let filtros = document.getElementsByClassName("package-advance-filters")[0]; filtros.setAttribute("style","width: 500px;margin-left: auto;") let article = document.getElementsByTagName("article")[0]; let sectionHeaders = document.getElementsByClassName("section-header") for (let section of sectionHeaders) { if(section.innerHTML.includes("Paquetes")==true){ article.insertBefore(filtros,section) } } } } //style="width: 500px;margin-left: auto;" class TimeSaver{ static Exist(){ const timeSaverr = !!document.getElementsByClassName("auto-settings")[0] return timeSaverr; } static setKeyForStop(timeSaverExist){ if(timeSaverExist==true){ Menu.addConfig(` <h3>TimeSaver</h3> <ul>Atajos de Teclado <ul>Pausar Bot: <input maxlength="1" id="timeSaverHotKeySelectedKey" style="width: 100px;background: white;"><button id="Btnconfirmar" title="click para guardar" style="background: transparent; border: transparent;"></button></ul> <ul style="color: #0fea0f;" id="timeSaverHotKeyConfirmation" hidden>✔ Cambios guardados correctamente</ul> <ul><label><input id="timeSaverHotKeyCheckbox" type="checkbox"> Utilizar combinación con ctrl<label></ul> </ul>`); let timeSaverHotKeySelectedKey = document.getElementById("timeSaverHotKeySelectedKey"); let timeSaverHotKeyCheckbox = document.getElementById("timeSaverHotKeyCheckbox"); let timeSaverHotKeyConfirmation = document.getElementById("timeSaverHotKeyConfirmation"); let Btnconfirmar = document.getElementById("Btnconfirmar"); Btnconfirmar.addEventListener("click",()=>{Btnconfirmar.textContent = ""; timeSaverHotKeyConfirmation.hidden = false;}); if(localStorage.timeSaverHotKeyCheckbox == undefined){ localStorage.timeSaverHotKeyCheckbox = false; } else { timeSaverHotKeyCheckbox.checked = JSON.parse(localStorage.timeSaverHotKeyCheckbox); } timeSaverHotKeyCheckbox.addEventListener("change",()=>{localStorage.timeSaverHotKeyCheckbox=timeSaverHotKeyCheckbox.checked;}) if(localStorage.timeSaverHotKeySelectedKey == undefined){ localStorage.timeSaverHotKeySelectedKey = ""; } else { timeSaverHotKeySelectedKey.value = localStorage.timeSaverHotKeySelectedKey; } timeSaverHotKeySelectedKey.addEventListener("keydown",()=>{timeSaverHotKeySelectedKey.select(); Btnconfirmar.textContent = "✅"; }) timeSaverHotKeySelectedKey.addEventListener("change",()=>{localStorage.timeSaverHotKeySelectedKey = timeSaverHotKeySelectedKey.value;}) } } static StopOnKey(){ document.addEventListener('keyup', (e)=>{ let selectKey = localStorage.timeSaverHotKeySelectedKey; let useControl = JSON.parse(localStorage.timeSaverHotKeyCheckbox); if (useControl == true && e.ctrlKey && e.key === selectKey) { TimeSaver.StopBot(); } if (useControl == false && e.key === selectKey) { TimeSaver.StopBot(); } }, false); } static StopBot(){ let timeSaver = document.getElementsByClassName("auto-settings")[0] let botonPlay = timeSaver.children[3]; if (botonPlay.classList[2] == "show") { //bot desactivado botonPlay.click(); } } } class ExtenderBotones{ static Paquetes(){ let menue_packages = document.getElementById("menue_packages"); let url = window.location.search.split("&"); insertOnPage.afterend(menue_packages,` <button id="extenderPaquetes" class="awesome-button extederPaquetes" title="Presiona para abrir el menú de paquetes">+</button> <div id="menuBotonPaquetes" class="menuBotonPaquetes"> <div class="icon-out"><a class="icon food-icon" href="index.php?mod=packages&f=7&fq=-1&qry=&page=1&`+sh.get()+`" title="Ir a paquetes, Utilizable"></a></div> </div> <style> .menuBotonPaquetes { display: none; position: absolute; opacity: 1; background: rgb(222, 210, 173); top: 42px; right: 4px; padding: 10px; } #menuBotonPaquetes .icon-out { float: left; } #menuBotonPaquetes .icon { width: 25px; height: 25px; display: block; cursor: pointer; } .food-icon { background: transparent url(https://cdn.jsdelivr.net/gh/lpachecob/Gladiatus-Tools@main/images/buttons.png) -395px 0px no-repeat; } .extederPaquetes { position: absolute; right: -10px; top: -3px; height: 19px; width: 21px; color: white; background: #8e2a2a; border: none; } </style> `); let menuBotonPaquetes = document.getElementById("menuBotonPaquetes"); let extenderPaquetes = document.getElementById("extenderPaquetes"); let menuAbierto = false; extenderPaquetes.addEventListener("click",()=>{ menuAbierto = !menuAbierto; if(menuAbierto == true){ menuBotonPaquetes.style.display = 'block'; } else { menuBotonPaquetes.style.display = 'none'; } }) document.addEventListener('mouseup', function(e) { var container = document.getElementById("extenderPaquetes"); if (!container.contains(e.target)) { menuBotonPaquetes.style.display = 'none'; } }); } } class GuardarOro{ static UI(){ Menu.addConfig(` <h3>Guardar Oro</h3> <ul><label><input id="GuardarOroCheck" type="checkbox"> Guardar tu oro automaticamente<label></ul> <ul><select id="TipoDeGuardado"><option disabled>Mercado</option><option disabled>Casa de subastas</option><option>Entrenamiento</option></select></ul> `); let GuardarOroCheck = document.getElementById("GuardarOroCheck"); ; let TipoDeGuardado = document.getElementById("TipoDeGuardado") if (localStorage.GuardarOroCheck == undefined) { localStorage.GuardarOroCheck = GuardarOroCheck.checked } else { GuardarOroCheck.checked = JSON.parse(localStorage.GuardarOroCheck); } GuardarOroCheck.addEventListener("change", () => { localStorage.GuardarOroCheck = GuardarOroCheck.checked; }) if (localStorage.TipoDeGuardado == undefined) { localStorage.TipoDeGuardado = TipoDeGuardado.selectedIndex } else { TipoDeGuardado.selectedIndex = localStorage.TipoDeGuardado; } TipoDeGuardado.addEventListener("change", () => { localStorage.TipoDeGuardado = TipoDeGuardado.selectedIndex; location.reload(); }) if(TipoDeGuardado.selectedIndex == 0 || TipoDeGuardado.selectedIndex == 1){ insertOnPage.afterend(TipoDeGuardado,`<ul>Oro Máximo a tener suelto: <input id="OroMaximoSuelto" style="width: 100px;background: white;" value="0"></ul`); let OroMaximoSuelto = document.getElementById("OroMaximoSuelto") if (localStorage.OroMaximoSuelto == undefined) { localStorage.OroMaximoSuelto = OroMaximoSuelto.value } else { OroMaximoSuelto.value = localStorage.OroMaximoSuelto; } OroMaximoSuelto.addEventListener("input", () => { localStorage.OroMaximoSuelto = OroMaximoSuelto.value; }) } if(TipoDeGuardado.selectedIndex == 2){ insertOnPage.afterend(TipoDeGuardado,` <select id="SeleccionarEntrenamiento"><option>Fuerza</option><option>Destreza</option><option>Agilidad</option><option>Constitución</option><option>Carisma</option><option>Inteligencia</option></select> `) let SeleccionarEntrenamiento = document.getElementById("SeleccionarEntrenamiento"); if (localStorage.SeleccionarEntrenamiento == undefined) { localStorage.SeleccionarEntrenamiento = SeleccionarEntrenamiento.selectedIndex } else { SeleccionarEntrenamiento.selectedIndex = localStorage.SeleccionarEntrenamiento; } SeleccionarEntrenamiento.addEventListener("change", () => { localStorage.SeleccionarEntrenamiento = SeleccionarEntrenamiento.selectedIndex; }) } } static VerSiTengoOro(oroTrigger){ let oroTriggerParse = parseInt(oroTrigger) if(oro > oroTriggerParse){ return true; }else{ return false; } } static Guardar(){ let EntrenamientoLink = "https://s45-es.gladiatus.gameforge.com/game/index.php?mod=training&"+sh.get(); let GuardarOroCheck = document.getElementById("GuardarOroCheck") if(GuardarOroCheck.checked){ let tipoDeGuardado = { get : ()=>{ let TipoDeGuardado = document.getElementById("TipoDeGuardado"); return TipoDeGuardado.selectedIndex }, __ifNeedTriggerGold : ()=>{ }, __ifNeedChoiseAnStat : ()=>{ let SeleccionarEntrenamiento = document.getElementById("SeleccionarEntrenamiento"); return SeleccionarEntrenamiento.selectedIndex; } } let data = { init : ()=>{ if (getURL[0] == "?mod=training") { let TrainingBox = document.getElementById("training_box"); let Stats = { get : ()=>{ let stats = [] for (let index = 1; index < 7; index++){ stats.push(TrainingBox.children[index]) } return stats; }, push : ()=>{ let statPrices = [] for (let statPrice of Stats.get()) { statPrices.push(parseInt(statPrice.children[1].children[0].children[0].innerText.replace(/\./g, ''))) } localStorage.PlayerStatsPrices = JSON.stringify(statPrices); } } Stats.push(); } } } if(localStorage.PlayerStatsPrices == undefined){ window.location.href = "https://s45-es.gladiatus.gameforge.com/game/index.php?mod=training&"+sh.get(); } data.init() let training_box = document.getElementById("training_box"); let trainButtons = { get : ()=>{ let buttons = [] for (let index = 1; index < 7; index++) { buttons.push(training_box.children[index].children[1].children[1]) } return buttons; } } ///////////// //ir a guardar let playerStatsPrices = JSON.parse(localStorage.PlayerStatsPrices) if(playerStatsPrices[tipoDeGuardado.__ifNeedChoiseAnStat()] < oro){ window.location.href = EntrenamientoLink; trainButtons.get()[tipoDeGuardado.__ifNeedChoiseAnStat()].click(); } } } static Run(){ GuardarOro.UI(); GuardarOro.Guardar(); } } ////////////////////////////////////////////////////////////////////// /** * run script */ GladiatusTools.Run();