diff options
-rw-r--r-- | featureClass/class.js | 72 | ||||
-rw-r--r-- | featureClass/featureManager.js | 399 | ||||
-rw-r--r-- | features/betterGuis/dungeonReadyGui.js | 4 | ||||
-rw-r--r-- | features/betterGuis/index.js | 20 | ||||
-rw-r--r-- | features/betterGuis/museumGui.js | 166 | ||||
-rw-r--r-- | features/dataLoader/index.js | 15 | ||||
-rw-r--r-- | features/dungeonMap/index.js | 12 | ||||
-rw-r--r-- | features/dungeonSolvers/index.js | 1185 | ||||
-rw-r--r-- | features/globalSettings/firstLoadPage.js | 2 | ||||
-rw-r--r-- | features/globalSettings/index.js | 5 | ||||
-rw-r--r-- | features/hud/HudTextElement.js | 125 | ||||
-rw-r--r-- | features/hud/index.js | 365 | ||||
-rw-r--r-- | features/lockedFeatures/index.js | 2 | ||||
-rw-r--r-- | metadata.json | 4 |
14 files changed, 1291 insertions, 1085 deletions
diff --git a/featureClass/class.js b/featureClass/class.js index d1ddbc6..bb438d9 100644 --- a/featureClass/class.js +++ b/featureClass/class.js @@ -2,7 +2,7 @@ /// <reference lib="es2015" /> class Feature { - constructor(){ + constructor() { this.FeatureManager = undefined this.events = {} this.customEvents = {} @@ -14,27 +14,27 @@ class Feature { this.enabled = false } - setId(id){ + setId(id) { this.id = id } - getId(){ + getId() { return this.id } - _onDisable(){ - Object.values(this.events).forEach(e=>this.FeatureManager.unregisterEvent(e)) //calling parent unregister to avoid the set in unregister event - Object.values(this.customEvents).forEach(e=>this.FeatureManager.unregisterCustom(e)) //calling parent unregister to avoid the set in unregister event - Object.values(this.forgeEvents).forEach(e=>this.FeatureManager.unregisterForge(e)) //calling parent unregister to avoid the set in unregister event - Object.values(this.soopyEvents).forEach(e=>this.FeatureManager.unregisterSoopy(e)) //calling parent unregister to avoid the set in unregister event + _onDisable() { + Object.values(this.events).forEach(e => this.FeatureManager.unregisterEvent(e)) //calling parent unregister to avoid the set in unregister event + Object.values(this.customEvents).forEach(e => this.FeatureManager.unregisterCustom(e)) //calling parent unregister to avoid the set in unregister event + Object.values(this.forgeEvents).forEach(e => this.FeatureManager.unregisterForge(e)) //calling parent unregister to avoid the set in unregister event + Object.values(this.soopyEvents).forEach(e => this.FeatureManager.unregisterSoopy(e)) //calling parent unregister to avoid the set in unregister event this.onDisable() - + this.events = {} this.customEvents = {} this.enabled = false } - _onEnable(parent){ + _onEnable(parent) { this.FeatureManager = parent this.enabled = true @@ -42,10 +42,10 @@ class Feature { this.onEnable() } - onDisable(){} - onEnable(){} + onDisable() { } + onEnable() { } - registerEvent(event, func){ + registerEvent(event, func) { let theEvent = this.FeatureManager.registerEvent(event, func, this) this.events[theEvent.id] = theEvent @@ -53,12 +53,12 @@ class Feature { return theEvent } - unregisterEvent(event){ + unregisterEvent(event) { this.FeatureManager.unregisterEvent(event) delete this.events[event.id] } - registerSoopy(event, func){ + registerSoopy(event, func) { let theEvent = this.FeatureManager.registerSoopy(event, func, this) this.soopyEvents[theEvent.id] = theEvent @@ -66,48 +66,48 @@ class Feature { return theEvent } - unregisterSoopy(event){ + unregisterSoopy(event) { this.FeatureManager.unregisterSoopy(event) delete this.soopyEvents[event.id] } - registerForge(event, func, messageIfError){ + registerForge(event, func, messageIfError) { let theEvent - try{ - theEvent = this.FeatureManager.registerForge(event, func, this) - }catch(e){ - if(!messageIfError) messageIfError = "An error occured while registering the event " + event.class.toString().split(".").pop() + ", this may cause " + this.constructor.name + " to not work properly." + try { + theEvent = this.FeatureManager.registerForge(event, func, this) + } catch (e) { //TODO: option to disable this chat message + fallback register for some that support (eg fallback of RenderWorldLastEvent to ct 'renderWorld') + if (!messageIfError) messageIfError = "An error occured while registering the event " + event.class.toString().split(".").pop() + ", this may cause " + this.constructor.name + " to not work properly." ChatLib.chat(this.FeatureManager.messagePrefix + messageIfError) } - if(theEvent)this.forgeEvents[theEvent.id] = theEvent + if (theEvent) this.forgeEvents[theEvent.id] = theEvent return theEvent } - unregisterForge(event){ - if(!event) return - + unregisterForge(event) { + if (!event) return + this.FeatureManager.unregisterForge(event) delete this.forgeEvents[event.id] } - registerChat(criteria, func){ + registerChat(criteria, func) { let theEvent = this.FeatureManager.registerChat(criteria, func, this) this.customEvents[theEvent.id] = theEvent return theEvent } - registerActionBar(criteria, func){ + registerActionBar(criteria, func) { let theEvent = this.FeatureManager.registerActionBar(criteria, func, this) this.customEvents[theEvent.id] = theEvent return theEvent } - registerStep(isFps, interval, func){ + registerStep(isFps, interval, func) { let theEvent = this.FeatureManager.registerStep(isFps, interval, func, this) this.customEvents[theEvent.id] = theEvent @@ -115,7 +115,7 @@ class Feature { return theEvent } - registerCustom(event, func){ + registerCustom(event, func) { let theEvent = this.FeatureManager.registerCustom(event, func, this) this.customEvents[theEvent.id] = theEvent @@ -123,28 +123,28 @@ class Feature { return theEvent } - registerCommand(name, func){ + registerCommand(name, func) { this.FeatureManager.commandFuncs[name] = func - this.FeatureManager.registerCommand(name, (...args)=>{ - if(this.FeatureManager.commandFuncs[name]){ + this.FeatureManager.registerCommand(name, (...args) => { + if (this.FeatureManager.commandFuncs[name]) { this.FeatureManager.commandFuncs[name].call(this, ...(args || [])) - }else{ + } else { ChatLib.chat(this.FeatureManager.messagePrefix + "This command is not available atm") } }, this) } - unregisterCommand(name){ + unregisterCommand(name) { delete this.FeatureManager.commandFuncs[name] } - unregisterCustom(event){ + unregisterCustom(event) { this.FeatureManager.unregisterCustom(event) delete this.customEvents[event.id] } - createCustomEvent(eventId){ + createCustomEvent(eventId) { return this.FeatureManager.createCustomEvent(eventId) } } diff --git a/featureClass/featureManager.js b/featureClass/featureManager.js index 809e608..78e06dd 100644 --- a/featureClass/featureManager.js +++ b/featureClass/featureManager.js @@ -6,7 +6,7 @@ const File = Java.type("java.io.File") import metadata from "../metadata.js" import soopyV2Server from "../socketConnection"; import { fetch } from "../utils/networkUtils"; -import { registerForge as registerForgeBase, unregisterForge as unregisterForgeBase} from "./forgeEvents.js" +import { registerForge as registerForgeBase, unregisterForge as unregisterForgeBase } from "./forgeEvents.js" const JSLoader = Java.type("com.chattriggers.ctjs.engine.langs.js.JSLoader") const UrlModuleSourceProvider = Java.type("org.mozilla.javascript.commonjs.module.provider.UrlModuleSourceProvider") @@ -15,22 +15,22 @@ const StrongCachingModuleScriptProviderClass = Java.type("org.mozilla.javascript let StrongCachingModuleScriptProvider = new StrongCachingModuleScriptProviderClass(UrlModuleSourceProviderInstance) let CTRequire = new JSLoader.CTRequire(StrongCachingModuleScriptProvider) -let loadedModules = [] +let loadedModules = new Set() -function RequireNoCache(place){ - if(loadedModules.includes(place)){ - loadedModules.push(place) +function RequireNoCache(place) { + if (!logger.isDev) return require(place) + if (!loadedModules.has(place)) { + loadedModules.add(place) return require(place) //performance optimisation } - if(!logger.isDev) return require(place) - + StrongCachingModuleScriptProvider = new StrongCachingModuleScriptProviderClass(UrlModuleSourceProviderInstance) CTRequire = new JSLoader.CTRequire(StrongCachingModuleScriptProvider) return CTRequire(place) } class FeatureManager { - constructor(){ + constructor() { this.isDev = logger.isDev @@ -71,29 +71,29 @@ class FeatureManager { this.featureSettingsData = {} - let fetchD = fetch("http://soopymc.my.to/api/soopyv2/ping").async(d=>{ - if(fetchD.responseCode() >= 400 || fetchD.responseCode() === -1){ - ChatLib.chat(this.messagePrefix + "&cError: Could not connect to Soopy's server. This may cause issues with features breaking but will (hopefully) be back soon.") + let fetchD = fetch("http://soopymc.my.to/api/soopyv2/ping").async(d => { + if (fetchD.responseCode() >= 400 || fetchD.responseCode() === -1) { + ChatLib.chat(this.messagePrefix + "&cError: Could not connect to Soopy's server. This may cause issues with some features but will (hopefully) be back soon.") } - - new Thread(()=>{ + + new Thread(() => { this.loadFeatureMetas() - + this.loadFeatureSettings() - - Object.keys(this.featureMetas).forEach((feature)=>{ - if(this.featureSettingsData[feature] && this.featureSettingsData[feature].enabled){ + + Object.keys(this.featureMetas).forEach((feature) => { + if (this.featureSettingsData[feature] && this.featureSettingsData[feature].enabled) { this.loadFeature(feature) } }) - + this.finishedLoading = true }).start() }, true) - this.registerStep(false, 30, ()=>{ - if(this.featureSettingsDataLastUpdated){ - new Thread(()=>{ + this.registerStep(false, 30, () => { + if (this.featureSettingsDataLastUpdated) { + new Thread(() => { this.saveFeatureSettings() }).start() } @@ -101,69 +101,72 @@ class FeatureManager { this.registerEvent("worldUnload", this.saveFeatureSettings, this) - this.registerEvent("gameUnload", ()=>{ + this.registerEvent("gameUnload", () => { this.saveFeatureSettings() this.unloadAllFeatures() this.enabled = false }, this) - this.registerStep(true, 2, ()=>{ - if(this.reloadModuleTime!==0 && Date.now()-this.reloadModuleTime > 0){ - new Thread(()=>{ - this.reloadModuleTime = 0 - this.reloadingModules.forEach(m=>{ - this.unloadFeature(m) - }) - this.reloadingModules.forEach(m=>{ - this.loadFeature(m) - }) - this.reloadingModules = [] - }).start() - } - }, this) - this.watches = {} - this.addedWatches = [] - this.watchService = Java.type("java.nio.file.FileSystems").getDefault().newWatchService(); - this.reloadingModules = [] - this.reloadModuleTime = 0 - new Thread(()=>{ - while(this.enabled){ - key = this.watchService.take(); - let moduleToReload = this.watches[key] - if(this.features[moduleToReload] && !this.reloadingModules.includes(moduleToReload)){ //if enabled && not alr in queue - this.reloadingModules.push(moduleToReload) - this.reloadModuleTime = Date.now()+5000 + if (this.isDev) { + this.registerStep(true, 2, () => { + if (this.reloadModuleTime !== 0 && Date.now() - this.reloadModuleTime > 0) { + new Thread(() => { + this.reloadModuleTime = 0 + this.reloadingModules.forEach(m => { + this.unloadFeature(m) + }) + this.reloadingModules.forEach(m => { + this.loadFeature(m) + }) + this.reloadingModules = [] + }).start() } - key.pollEvents()/*.forEach(event=>{ + }, this) + + this.watches = {} + this.addedWatches = [] + this.watchService = Java.type("java.nio.file.FileSystems").getDefault().newWatchService(); + this.reloadingModules = [] + this.reloadModuleTime = 0 + new Thread(() => { + while (this.enabled) { + key = this.watchService.take(); + let moduleToReload = this.watches[key] + if (this.features[moduleToReload] && !this.reloadingModules.includes(moduleToReload)) { //if enabled && not alr in queue + this.reloadingModules.push(moduleToReload) + this.reloadModuleTime = Date.now() + 5000 + } + key.pollEvents()/*.forEach(event=>{ console.log(event.context().toString()) })*/ - key.reset(); - } - }).start() + key.reset(); + } + }).start() + } - this.registerCommand("soopyunloadfeature", (args)=>{ - new Thread(()=>{ + this.registerCommand("soopyunloadfeature", (args) => { + new Thread(() => { this.unloadFeature(args) }).start() }, this) - this.registerCommand("soopyloadfeature", (args)=>{ - new Thread(()=>{ + this.registerCommand("soopyloadfeature", (args) => { + new Thread(() => { this.loadFeature(args) }).start() }, this) - this.registerCommand("soopyreloadfeature", (args)=>{ - new Thread(()=>{ + this.registerCommand("soopyreloadfeature", (args) => { + new Thread(() => { this.unloadFeature(args) - + this.loadFeature(args) }).start() }, this) - this.registerCommand("soopysetlongeventtime", (args)=>{ + this.registerCommand("soopysetlongeventtime", (args) => { this.longEventTime = parseInt(args) }, this) - this.registerCommand("soopylaginformation", (args)=>{ //TODO: make this a dedicated GUI - new Thread(()=>{ + this.registerCommand("soopylaginformation", (args) => { //TODO: make this a dedicated GUI + new Thread(() => { this.recordingPerformanceUsage = true this.performanceUsage = {} ChatLib.chat(this.messagePrefix + "Recording performance impact, this will take 10 seconds to complete!") @@ -173,21 +176,21 @@ class FeatureManager { let totalMsGlobal = 0 this.recordingPerformanceUsage = false ChatLib.chat(this.messagePrefix + "Performance impact:") - Object.keys(this.performanceUsage).sort((a, b)=>{ + Object.keys(this.performanceUsage).sort((a, b) => { let totalMsA = 0 - Object.keys(this.performanceUsage[a]).forEach((event)=>{ + Object.keys(this.performanceUsage[a]).forEach((event) => { totalMsA += this.performanceUsage[a][event].time }) let totalMsB = 0 - Object.keys(this.performanceUsage[b]).forEach((event)=>{ + Object.keys(this.performanceUsage[b]).forEach((event) => { totalMsB += this.performanceUsage[b][event].time }) - return totalMsA-totalMsB - }).forEach((moduleName)=>{ + return totalMsA - totalMsB + }).forEach((moduleName) => { let totalMs = 0 let totalCalls = 0 - Object.keys(this.performanceUsage[moduleName]).forEach((event)=>{ + Object.keys(this.performanceUsage[moduleName]).forEach((event) => { totalMs += this.performanceUsage[moduleName][event].time totalCalls += this.performanceUsage[moduleName][event].count }) @@ -196,8 +199,8 @@ class FeatureManager { ChatLib.chat("&eModule: &7" + moduleName) ChatLib.chat("&eTotal: &7" + totalMs.toFixed(2) + "ms (" + totalCalls + " calls)") - Object.keys(this.performanceUsage[moduleName]).sort((a, b)=>{return this.performanceUsage[moduleName][a].time-this.performanceUsage[moduleName][b].time}).forEach((event)=>{ - ChatLib.chat(" &eEvent:&7 " + event + " - " + this.performanceUsage[moduleName][event].time.toFixed(2) + "ms (" + this.performanceUsage[moduleName][event].count + " calls) [" + ((this.performanceUsage[moduleName][event].time/this.performanceUsage[moduleName][event].count).toFixed(2)) + "ms avg]") + Object.keys(this.performanceUsage[moduleName]).sort((a, b) => { return this.performanceUsage[moduleName][a].time - this.performanceUsage[moduleName][b].time }).forEach((event) => { + ChatLib.chat(" &eEvent:&7 " + event + " - " + this.performanceUsage[moduleName][event].time.toFixed(2) + "ms (" + this.performanceUsage[moduleName][event].count + " calls) [" + ((this.performanceUsage[moduleName][event].time / this.performanceUsage[moduleName][event].count).toFixed(2)) + "ms avg]") }) }) @@ -206,12 +209,12 @@ class FeatureManager { }, this) } - loadFeatureSettings(){ + loadFeatureSettings() { logger.logMessage("Loading settings", 4) let data = FileLib.read("soopyAddonsData", "soopyaddonsbetafeaturesdata.json") - if(!data){ + if (!data) { this.loadDefaultFeatureSettings(); return; } @@ -223,44 +226,44 @@ class FeatureManager { this.ensureNewSettingsExist() } - saveFeatureSettings(){ - if(!this.featureSettingsDataLastUpdated) return - + saveFeatureSettings() { + if (!this.featureSettingsDataLastUpdated) return + FileLib.write("soopyAddonsData", "soopyaddonsbetafeaturesdata.json", JSON.stringify(this.featureSettingsData)) - + this.featureSettingsDataLastUpdated = false logger.logMessage("Saved settings", 4) } - loadDefaultFeatureSettings(){ - Object.keys(this.featureMetas).forEach((feature)=>{ + loadDefaultFeatureSettings() { + Object.keys(this.featureMetas).forEach((feature) => { this.featureSettingsData[feature] = { enabled: this.featureMetas[feature].defaultEnabled, subSettings: {} } }) - - this.featureSettingsDataLastUpdated= true + + this.featureSettingsDataLastUpdated = true logger.logMessage("Loaded default settings", 4) } - ensureNewSettingsExist(){ - Object.keys(this.featureMetas).forEach((feature)=>{ - if(!this.featureSettingsData[feature]){ + ensureNewSettingsExist() { + Object.keys(this.featureMetas).forEach((feature) => { + if (!this.featureSettingsData[feature]) { this.featureSettingsData[feature] = { enabled: this.featureMetas[feature].defaultEnabled, subSettings: {} } - this.featureSettingsDataLastUpdated= true + this.featureSettingsDataLastUpdated = true logger.logMessage("Loaded default settings for " + feature, 4) } }) } - startCatchingEvent(event){ - if(this.eventObjects[event]) return + startCatchingEvent(event) { + if (this.eventObjects[event]) return //SBA compatability or something (removed) // if(event === "renderOverlay"){ @@ -273,60 +276,62 @@ class FeatureManager { // } // }) // }else{ - this.eventObjects[event] = register(event, (...args)=>{ - // let start = Date.now() - this.triggerEvent(event, args) - // this.eventTimingData[event] = (this.eventTimingData[event] || 0)+(Date.now()-start) - }) + this.eventObjects[event] = register(event, (...args) => { + // let start = Date.now() + this.triggerEvent(event, args) + // this.eventTimingData[event] = (this.eventTimingData[event] || 0)+(Date.now()-start) + }) //} logger.logMessage("Registered " + event + " event", 4) } - triggerEvent(event, args){ - if(this.events[event]) - try{ - for(Event of Object.values(this.events[event])){ - if(Event.context.enabled){ - this.startRecordingPerformance(Event.context.constructor.name, event) - let start = Date.now() - Event.func.call(Event.context, ...args) - let time = Date.now()-start - if(time > this.longEventTime){ - logger.logMessage("Long event triggered [" + time + "ms] (" + Event.context.constructor.name + "/" + event + ")", 3) + triggerEvent(event, args) { + if (this.events[event]) { + try { + for (Event of Object.values(this.events[event])) { + if (Event.context.enabled) { + this.startRecordingPerformance(Event.context.constructor.name, event) + let start = Date.now() + Event.func.call(Event.context, ...args) + let time = Date.now() - start + if (time > this.longEventTime) { + logger.logMessage("Long event triggered [" + time + "ms] (" + Event.context.constructor.name + "/" + event + ")", 3) + } + this.stopRecordingPerformance(Event.context.constructor.name, event) } - this.stopRecordingPerformance(Event.context.constructor.name, event) } + } catch (e) { + logger.logMessage("Error in " + event + " event: " + JSON.stringify(e, undefined, 2), 2) + + soopyV2Server.reportError(e, "Error in " + event + " event.") } - }catch(e){ - logger.logMessage("Error in " + event + " event: " + JSON.stringify(e, undefined, 2), 2) - - soopyV2Server.reportError(e, "Error in " + event + " event.") } } - triggerSoopy(event, args){ - if(this.soopyEventHandlers[event]) - try{ - for(Event of Object.values(this.soopyEventHandlers[event])){ - if(Event.context.enabled){ - this.startRecordingPerformance(Event.context.constructor.name, event) - let start = Date.now() - Event.func.call(Event.context, ...args) - let time = Date.now()-start - if(time > this.longEventTime){ - logger.logMessage("Long event triggered [" + time + "ms] (" + Event.context.constructor.name + "/" + event + ")", 3) + triggerSoopy(event, args) { + if (this.soopyEventHandlers[event]) { + try { + for (Event of Object.values(this.soopyEventHandlers[event])) { + if (Event.context.enabled) { + this.startRecordingPerformance(Event.context.constructor.name, event) + let start = Date.now() + Event.func.call(Event.context, ...args) + let time = Date.now() - start + if (time > this.longEventTime) { + logger.logMessage("Long event triggered [" + time + "ms] (" + Event.context.constructor.name + "/" + event + ")", 3) + } + this.stopRecordingPerformance(Event.context.constructor.name, event) } - this.stopRecordingPerformance(Event.context.constructor.name, event) } + } catch (e) { + logger.logMessage("Error in soopy " + event + " event: " + JSON.stringify(e, undefined, 2), 2) + soopyV2Server.reportError(e, "Error in soopy " + event + " event.") } - }catch(e){ - logger.logMessage("Error in soopy " + event + " event: " + JSON.stringify(e, undefined, 2), 2) - soopyV2Server.reportError(e, "Error in soopy " + event + " event.") } } - stopCatchingEvent(event){ - if(!this.eventObjects[event]) return + stopCatchingEvent(event) { + if (!this.eventObjects[event]) return this.eventObjects[event].unregister() delete this.eventObjects[event] @@ -334,8 +339,8 @@ class FeatureManager { logger.logMessage("Unregistered " + event + " event", 4) } - registerEvent(event, func, context){ - if(!this.events[event]){ + registerEvent(event, func, context) { + if (!this.events[event]) { this.events[event] = [] this.startCatchingEvent(event) } @@ -350,8 +355,8 @@ class FeatureManager { return theEvent } - registerSoopy(event, func, context){ - if(!this.soopyEventHandlers[event]){ + registerSoopy(event, func, context) { + if (!this.soopyEventHandlers[event]) { this.soopyEventHandlers[event] = [] } @@ -366,7 +371,7 @@ class FeatureManager { return theEvent } - registerChat(criteria, func, context){ + registerChat(criteria, func, context) { let event = this.registerCustom("chat", func, context) event.trigger.setChatCriteria(criteria) @@ -374,7 +379,7 @@ class FeatureManager { return event } - registerActionBar(criteria, func, context){ + registerActionBar(criteria, func, context) { let event = this.registerCustom("actionBar", func, context) @@ -382,7 +387,7 @@ class FeatureManager { return event } - registerCommand(commandName, func, context){ + registerCommand(commandName, func, context) { let event = this.registerCustom("command", func, context) @@ -390,35 +395,35 @@ class FeatureManager { return event } - registerStep(isFps, interval, func, context){ + registerStep(isFps, interval, func, context) { let event = this.registerCustom("step", func, context) - event.trigger[isFps?"setFps":"setDelay"](interval) + event.trigger[isFps ? "setFps" : "setDelay"](interval) return event } - registerCustom(type, func, context){ + registerCustom(type, func, context) { let id = this.lastChatEventId++ this.customEvents[id] = { func: func, context: context, - trigger: register(type, (...args)=>{ - try{ - if(context.enabled){ + trigger: register(type, (...args) => { + try { + if (context.enabled) { this.startRecordingPerformance(context.constructor.name, type) let start = Date.now() func.call(context, ...(args || [])) - let time = Date.now()-start - if(time > this.longEventTime){ + let time = Date.now() - start + if (time > this.longEventTime) { logger.logMessage("Long event triggered [" + time + "ms] (" + context.constructor.name + "/" + type + ")", 3) } this.stopRecordingPerformance(context.constructor.name, type) } - }catch(e){ + } catch (e) { logger.logMessage("Error in " + type + " event: " + JSON.stringify(e, undefined, 2), 2) - + soopyV2Server.reportError(e, "Error in " + type + " event.") } }), @@ -428,27 +433,27 @@ class FeatureManager { return this.customEvents[id] } - registerForge(event, func, context){ + registerForge(event, func, context) { let id = this.lastForgeEventId++ this.forgeEvents[id] = { func: func, context: context, - trigger: registerForgeBase(event, (...args)=>{ - try{ - if(context.enabled){ + trigger: registerForgeBase(event, (...args) => { + try { + if (context.enabled) { this.startRecordingPerformance(context.constructor.name, event.class.name) let start = Date.now() func.call(context, ...(args || [])) - let time = Date.now()-start - if(time > this.longEventTime){ + let time = Date.now() - start + if (time > this.longEventTime) { logger.logMessage("Long (forge) event triggered (" + context.constructor.name + "/" + event.class.toString() + ")", 3) } this.stopRecordingPerformance(context.constructor.name, event.class.name) } - }catch(e){ + } catch (e) { logger.logMessage("Error in " + event.class.toString() + " (forge) event: " + JSON.stringify(e, undefined, 2), 2) - + soopyV2Server.reportError(e, "Error in " + event.class.toString() + " (forge) event.") } }), @@ -458,84 +463,84 @@ class FeatureManager { return this.forgeEvents[id] } - unregisterForge(event){ + unregisterForge(event) { unregisterForgeBase(this.forgeEvents[event.id].trigger) delete this.forgeEvents[event.id] } - unregisterCustom(event){ + unregisterCustom(event) { event.trigger.unregister() delete this.customEvents[event.id] } - unregisterEvent(event){ - if(!this.events[event.event]) return + unregisterEvent(event) { + if (!this.events[event.event]) return - this.events[event.event] = this.events[event.event].filter((e)=>{ + this.events[event.event] = this.events[event.event].filter((e) => { return e.id !== event.id }) - - if(this.events[event.event].length === 0){ + + if (this.events[event.event].length === 0) { this.stopCatchingEvent(event.event) delete this.events[event.event] } } - unregisterSoopy(event){ - if(!this.soopyEventHandlers[event.event]) return + unregisterSoopy(event) { + if (!this.soopyEventHandlers[event.event]) return - this.soopyEventHandlers[event.event] = this.soopyEventHandlers[event.event].filter((e)=>{ + this.soopyEventHandlers[event.event] = this.soopyEventHandlers[event.event].filter((e) => { return e.id !== event.id }) - - if(this.soopyEventHandlers[event.event].length === 0){ + + if (this.soopyEventHandlers[event.event].length === 0) { delete this.events[event.event] } } - loadFeatureMetas(){ + loadFeatureMetas() { let featuresDir = new File("./config/ChatTriggers/modules/" + metadata.name + "/features") - featuresDir.list().forEach((pathName)=>{ - if(pathName.includes(".")) return; + featuresDir.list().forEach((pathName) => { + if (pathName.includes(".")) return; - try{ - let data = JSON.parse(FileLib.read( metadata.name + "/features/" + pathName,"metadata.json")) - if(data === null){ + try { + let data = JSON.parse(FileLib.read(metadata.name + "/features/" + pathName, "metadata.json")) + if (data === null) { return; } data.id = pathName this.featureMetas[pathName] = data - }catch(e){ + } catch (e) { console.log("Error loading feature metadata for " + pathName) console.log(JSON.stringify(e, undefined, 2)) } }) } - loadFeature(feature){ //run in seperate thread so onenable can do network requests - if(this.features[feature]) return - - try{ - + loadFeature(feature) { //run in seperate thread so onenable can do network requests + if (this.features[feature]) return + + try { + let LoadedFeature = RequireNoCache("../features/" + feature + "/index.js") // let LoadedFeature = RequireNoCache(new File("config/ChatTriggers/modules/" + metadata.name + "/features/" + feature + "/index.js")) - + this.features[feature] = LoadedFeature - + LoadedFeature.class.setId(feature) - + LoadedFeature.class._onEnable(this) - + logger.logMessage("Loaded feature " + feature, 3) - if(this.isDev && !this.addedWatches.includes(feature)){ + if (this.isDev && !this.addedWatches.includes(feature)) { this.addedWatches.push(feature) let path = Java.type("java.nio.file.Paths").get("./config/ChatTriggers/modules/SoopyV2/features/" + feature + "/"); this.watches[path.register(this.watchService, Java.type("java.nio.file.StandardWatchEventKinds").ENTRY_MODIFY)] = feature } - }catch(e){ + } catch (e) { logger.logMessage("Error loading feature " + feature, 1) console.log(JSON.stringify(e, undefined, 2)) ChatLib.chat(this.messagePrefix + "Error loading feature " + feature) @@ -546,8 +551,8 @@ class FeatureManager { return this } - unloadFeature(feature){ - if(!this.features[feature]) return + unloadFeature(feature) { + if (!this.features[feature]) return this.features[feature].class._onDisable() @@ -558,55 +563,55 @@ class FeatureManager { return this } - unloadAllFeatures(){ - Object.keys(this.features).forEach((feature)=>{ + unloadAllFeatures() { + Object.keys(this.features).forEach((feature) => { this.unloadFeature(feature) }) } - isFeatureLoaded(feature){ + isFeatureLoaded(feature) { return !!this.features[feature] } - getLoadedFeatures(){ + getLoadedFeatures() { return Object.keys(this.features) } - createCustomEvent(eventId){ + createCustomEvent(eventId) { logger.logMessage("Registered custom " + eventId + " event", 4) return { - trigger: (...args)=>{ + trigger: (...args) => { this.triggerSoopy(eventId, args) } } } - startRecordingPerformance(feature, event){ - if(!this.recordingPerformanceUsage) return + startRecordingPerformance(feature, event) { + if (!this.recordingPerformanceUsage) return - if(!this.performanceUsage[feature]) this.performanceUsage[feature] = {} - if(!this.performanceUsage[feature][event]) this.performanceUsage[feature][event] = {time: 0,count: 0} + if (!this.performanceUsage[feature]) this.performanceUsage[feature] = {} + if (!this.performanceUsage[feature][event]) this.performanceUsage[feature][event] = { time: 0, count: 0 } let instant = Instant.now() - let time = (instant.getEpochSecond() + (instant.getNano() / 1000000000))*1000; + let time = (instant.getEpochSecond() + (instant.getNano() / 1000000000)) * 1000; this.performanceUsage[feature][event].startTime = time } - stopRecordingPerformance(feature, event){ - if(!this.recordingPerformanceUsage) return + stopRecordingPerformance(feature, event) { + if (!this.recordingPerformanceUsage) return let instant = Instant.now() - let time = (instant.getEpochSecond() + (instant.getNano() / 1000000000))*1000; + let time = (instant.getEpochSecond() + (instant.getNano() / 1000000000)) * 1000; this.performanceUsage[feature][event].time += time - this.performanceUsage[feature][event].startTime this.performanceUsage[feature][event].count++ } } -if(!global.soopyv2featuremanagerthing){ +if (!global.soopyv2featuremanagerthing) { global.soopyv2featuremanagerthing = new FeatureManager() - register("gameUnload", ()=>{ + register("gameUnload", () => { global.soopyv2featuremanagerthing = undefined }) } diff --git a/features/betterGuis/dungeonReadyGui.js b/features/betterGuis/dungeonReadyGui.js index 2428f5b..956d4a6 100644 --- a/features/betterGuis/dungeonReadyGui.js +++ b/features/betterGuis/dungeonReadyGui.js @@ -25,7 +25,7 @@ class DungeonReadyGui { if(event.gui && event.gui.field_147002_h){ Player.getPlayer().field_71070_bA = event.gui.field_147002_h - if(!Player.getOpenedInventory().getName().startsWith("Catacombs - Floor ")){ + if(!Player.getContainer().getName().startsWith("Catacombs - Floor ")){ return } @@ -34,7 +34,7 @@ class DungeonReadyGui { } return } - if(name === "Start Dungeon"){ + if(name === "Start Dungeon?" || name.startsWith("Catacombs - Floor ")){ if(event.gui && event.gui.field_147002_h) Player.getPlayer().field_71070_bA = event.gui.field_147002_h this.soopyGui.open() diff --git a/features/betterGuis/index.js b/features/betterGuis/index.js index 23a7efa..1e9c144 100644 --- a/features/betterGuis/index.js +++ b/features/betterGuis/index.js @@ -118,7 +118,7 @@ class BetterGuis extends Feature { // logger.logMessage(hoveredSlotId, 4) - if(this.guiSlotClicked(ChatLib.removeFormatting(Player.getOpenedInventory().getName()), hoveredSlotId)){ + if(this.guiSlotClicked(ChatLib.removeFormatting(Player.getContainer().getName()), hoveredSlotId)){ cancel(event) } } @@ -129,19 +129,19 @@ class BetterGuis extends Feature { // if(this.dungeonReadyGuiEnabled.getValue()) this.dungeonReady.tick.call(this.dungeonReady) if(this.replaceSbMenuClicks.getValue()){ - if(Player.getOpenedInventory() && Player.getOpenedInventory().getName()==="SkyBlock Menu"){ + if(Player.getContainer() && Player.getContainer().getName()==="SkyBlock Menu"){ if(this.lastWindowId === 0){ - this.lastWindowId = Player.getOpenedInventory().getWindowId() + this.lastWindowId = Player.getContainer().getWindowId() return; } - if(Player.getOpenedInventory().getWindowId()!==this.lastWindowId){ - this.lastWindowId = Player.getOpenedInventory().getWindowId() + if(Player.getContainer().getWindowId()!==this.lastWindowId){ + this.lastWindowId = Player.getContainer().getWindowId() this.shouldHold+= 10 if(Date.now()-this.clickSlotTime >1000){ this.clickSlot = -1 } if(this.clickSlot && this.clickSlot != -1){ - Player.getOpenedInventory().click(this.clickSlot, false, "MIDDLE") + Player.getContainer().click(this.clickSlot, false, "MIDDLE") this.clickSlot = -1 } }else{ @@ -169,7 +169,7 @@ class BetterGuis extends Feature { this.clickSlot = slotId this.clickSlotTime = Date.now() }else{ - Player.getOpenedInventory().click(slotId, false, "MIDDLE") + Player.getContainer().click(slotId, false, "MIDDLE") } break; } @@ -177,18 +177,18 @@ class BetterGuis extends Feature { break default: if(this.middleClickGuis.includes(inventoryName)){ - Player.getOpenedInventory().click(slotId, false, "MIDDLE") + Player.getContainer().click(slotId, false, "MIDDLE") return true } for(let thing of this.middleClickStartsWith){ if(inventoryName.startsWith(thing)){ - Player.getOpenedInventory().click(slotId, false, "MIDDLE") + Player.getContainer().click(slotId, false, "MIDDLE") return true } } for(let thing of this.middleClickEndsWith){ if(inventoryName.endsWith(thing)){ - Player.getOpenedInventory().click(slotId, false, "MIDDLE") + Player.getContainer().click(slotId, false, "MIDDLE") return true } } diff --git a/features/betterGuis/museumGui.js b/features/betterGuis/museumGui.js index 7015e5f..0f7a3e9 100644 --- a/features/betterGuis/museumGui.js +++ b/features/betterGuis/museumGui.js @@ -46,7 +46,7 @@ class MuseumGui { this.weaponsIndicator = new SoopyBoxElement().setLocation(leftOffset, 0.05, widthPer*4/5, 0.15) this.weaponsIndicator.addEvent(new SoopyRenderEvent().setHandler(()=>{ - if(this.weaponsIndicator.hovered && ChatLib.removeFormatting(Player.getOpenedInventory().getStackInSlot(4).getName()) !== "Weapons"){ + if(this.weaponsIndicator.hovered && ChatLib.removeFormatting(Player.getContainer().getStackInSlot(4).getName()) !== "Weapons"){ this.weaponText.location.location.x.set(0.05, 500) this.weaponText.location.size.x.set(0.9, 500) this.weaponText.location.location.y.set(0.025, 500) @@ -56,7 +56,7 @@ class MuseumGui { Renderer.translate(0,0,100) Renderer.drawRect(Renderer.color(0,0,0,100), this.weaponsIndicator.location.getXExact(), this.weaponsIndicator.location.getYExact(), this.weaponsIndicator.location.getWidthExact(), this.weaponsIndicator.location.getHeightExact()) - let clicks = Player.getOpenedInventory().getName() === "Your Museum"?"1":"2" + let clicks = Player.getContainer().getName() === "Your Museum"?"1":"2" Renderer.translate(0,0,100) renderLibs.drawStringCenteredFull(clicks, this.weaponsIndicator.location.getXExact()+this.weaponsIndicator.location.getWidthExact()/2, this.weaponsIndicator.location.getYExact()+this.weaponsIndicator.location.getHeightExact()/2, Math.min(this.weaponsIndicator.location.getWidthExact()/Renderer.getStringWidth(clicks)/4, this.weaponsIndicator.location.getHeightExact()/4/2)) }else{ @@ -81,7 +81,7 @@ class MuseumGui { this.armourIndicator = new SoopyBoxElement().setLocation(leftOffset+widthPer, 0.05, widthPer*4/5, 0.15) this.armourIndicator.addEvent(new SoopyRenderEvent().setHandler(()=>{ - if(this.armourIndicator.hovered && ChatLib.removeFormatting(Player.getOpenedInventory().getStackInSlot(4).getName()) !== "Armor Sets"){ + if(this.armourIndicator.hovered && ChatLib.removeFormatting(Player.getContainer().getStackInSlot(4).getName()) !== "Armor Sets"){ this.armourText.location.location.x.set(0.05, 500) this.armourText.location.size.x.set(0.9, 500) this.armourText.location.location.y.set(0.025, 500) @@ -91,7 +91,7 @@ class MuseumGui { Renderer.translate(0,0,100) Renderer.drawRect(Renderer.color(0,0,0,100), this.armourIndicator.location.getXExact(), this.armourIndicator.location.getYExact(), this.armourIndicator.location.getWidthExact(), this.armourIndicator.location.getHeightExact()) - let clicks = Player.getOpenedInventory().getName() === "Your Museum"?"1":"2" + let clicks = Player.getContainer().getName() === "Your Museum"?"1":"2" Renderer.translate(0,0,100) renderLibs.drawStringCenteredFull(clicks, this.armourIndicator.location.getXExact()+this.armourIndicator.location.getWidthExact()/2, this.armourIndicator.location.getYExact()+this.armourIndicator.location.getHeightExact()/2, Math.min(this.armourIndicator.location.getWidthExact()/Renderer.getStringWidth(clicks)/4, this.armourIndicator.location.getHeightExact()/4/2)) }else{ @@ -115,7 +115,7 @@ class MuseumGui { this.raritiesIndicator = new SoopyBoxElement().setLocation(leftOffset+widthPer*2, 0.05, widthPer*4/5, 0.15) this.raritiesIndicator.addEvent(new SoopyRenderEvent().setHandler(()=>{ - if(this.raritiesIndicator.hovered && ChatLib.removeFormatting(Player.getOpenedInventory().getStackInSlot(4).getName()) !== "Rarities"){ + if(this.raritiesIndicator.hovered && ChatLib.removeFormatting(Player.getContainer().getStackInSlot(4).getName()) !== "Rarities"){ this.raritiesText.location.location.x.set(0.05, 500) this.raritiesText.location.size.x.set(0.9, 500) this.raritiesText.location.location.y.set(0.025, 500) @@ -125,7 +125,7 @@ class MuseumGui { Renderer.translate(0,0,100) Renderer.drawRect(Renderer.color(0,0,0,100), this.raritiesIndicator.location.getXExact(), this.raritiesIndicator.location.getYExact(), this.raritiesIndicator.location.getWidthExact(), this.raritiesIndicator.location.getHeightExact()) - let clicks = Player.getOpenedInventory().getName() === "Your Museum"?"1":"2" + let clicks = Player.getContainer().getName() === "Your Museum"?"1":"2" Renderer.translate(0,0,100) renderLibs.drawStringCenteredFull(clicks, this.raritiesIndicator.location.getXExact()+this.raritiesIndicator.location.getWidthExact()/2, this.raritiesIndicator.location.getYExact()+this.raritiesIndicator.location.getHeightExact()/2, Math.min(this.raritiesIndicator.location.getWidthExact()/Renderer.getStringWidth(clicks)/4, this.raritiesIndicator.location.getHeightExact()/4/2)) }else{ @@ -150,7 +150,7 @@ class MuseumGui { this.specialIndicator = new SoopyBoxElement().setLocation(leftOffset+widthPer*3, 0.05, widthPer*4/5, 0.15) this.specialIndicator.addEvent(new SoopyRenderEvent().setHandler(()=>{ - if(this.specialIndicator.hovered && ChatLib.removeFormatting(Player.getOpenedInventory().getStackInSlot(4).getName()) !== "Special Items"){ + if(this.specialIndicator.hovered && ChatLib.removeFormatting(Player.getContainer().getStackInSlot(4).getName()) !== "Special Items"){ this.specialText.location.location.x.set(0.05, 500) this.specialText.location.size.x.set(0.9, 500) this.specialText.location.location.y.set(0.025, 500) @@ -160,7 +160,7 @@ class MuseumGui { Renderer.translate(0,0,100) Renderer.drawRect(Renderer.color(0,0,0,100), this.specialIndicator.location.getXExact(), this.specialIndicator.location.getYExact(), this.specialIndicator.location.getWidthExact(), this.specialIndicator.location.getHeightExact()) - let clicks = Player.getOpenedInventory().getName() === "Your Museum"?"1":"2" + let clicks = Player.getContainer().getName() === "Your Museum"?"1":"2" Renderer.translate(0,0,100) renderLibs.drawStringCenteredFull(clicks, this.specialIndicator.location.getXExact()+this.specialIndicator.location.getWidthExact()/2, this.specialIndicator.location.getYExact()+this.specialIndicator.location.getHeightExact()/2, Math.min(this.specialIndicator.location.getWidthExact()/Renderer.getStringWidth(clicks)/4, this.specialIndicator.location.getHeightExact()/4/2)) @@ -302,61 +302,61 @@ class MuseumGui { } clickedTopButton(type){ - if(ChatLib.removeFormatting(Player.getOpenedInventory().getStackInSlot(4).getName())===type) return + if(ChatLib.removeFormatting(Player.getContainer().getStackInSlot(4).getName())===type) return - if(Player.getOpenedInventory().getName() === "Your Museum"){ + if(Player.getContainer().getName() === "Your Museum"){ //if on main page can just directly click on it switch(type){ case "Weapons": - Player.getOpenedInventory().click(19, false, "MIDDLE") + Player.getContainer().click(19, false, "MIDDLE") break case "Armor Sets": - Player.getOpenedInventory().click(21, false, "MIDDLE") + Player.getContainer().click(21, false, "MIDDLE") break case "Rarities": - Player.getOpenedInventory().click(23, false, "MIDDLE") + Player.getContainer().click(23, false, "MIDDLE") break case "Special Items": - Player.getOpenedInventory().click(25, false, "MIDDLE") + Player.getContainer().click(25, false, "MIDDLE") break } }else{ - Player.getOpenedInventory().click(48, false, "MIDDLE") + Player.getContainer().click(48, false, "MIDDLE") } } nextPage(){ let itempages = ["Weapons", "Armor Sets", "Rarities", "Special Items"] - if(itempages.includes(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()])){ - Player.getOpenedInventory().click(53, false, "MIDDLE") + if(itempages.includes(this.replacePage[Player.getContainer().getName().split("➜").pop()])){ + Player.getContainer().click(53, false, "MIDDLE") - let [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + let [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) this.regenItems(currPage+1) } } previousPage(){ let itempages = ["Weapons", "Armor Sets", "Rarities", "Special Items"] - if(itempages.includes(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()])){ - Player.getOpenedInventory().click(45, false, "MIDDLE") + if(itempages.includes(this.replacePage[Player.getContainer().getName().split("➜").pop()])){ + Player.getContainer().click(45, false, "MIDDLE") - let [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + let [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) this.regenItems(currPage-1) } } tickMenu(first=false){ if(!first && (this.tickI++)%5!==0){ - if(this.lastGuiTitle === Player.getOpenedInventory().getName()){ + if(this.lastGuiTitle === Player.getContainer().getName()){ return } } - this.lastGuiTitle = Player.getOpenedInventory().getName() + this.lastGuiTitle = Player.getContainer().getName() - if(Player.getOpenedInventory().getName() === "Your Museum"){//main page - if(!Player.getOpenedInventory().getStackInSlot(19)) return + if(Player.getContainer().getName() === "Your Museum"){//main page + if(!Player.getContainer().getStackInSlot(19)) return - let lore = Player.getOpenedInventory().getStackInSlot(19).getLore() + let lore = Player.getContainer().getStackInSlot(19).getLore() lore.forEach((line, i)=>{ if(i===0) return @@ -369,7 +369,7 @@ class MuseumGui { }) this.weaponsIndicator.setLore(lore) - lore = Player.getOpenedInventory().getStackInSlot(21).getLore() + lore = Player.getContainer().getStackInSlot(21).getLore() lore.forEach((line, i)=>{ if(i===0) return @@ -382,7 +382,7 @@ class MuseumGui { }) this.armourIndicator.setLore(lore) - lore = Player.getOpenedInventory().getStackInSlot(23).getLore() + lore = Player.getContainer().getStackInSlot(23).getLore() lore.forEach((line, i)=>{ if(i===0) return @@ -395,7 +395,7 @@ class MuseumGui { }) this.raritiesIndicator.setLore(lore) - lore = Player.getOpenedInventory().getStackInSlot(25).getLore() + lore = Player.getContainer().getStackInSlot(25).getLore() lore.forEach((line, i)=>{ if(i===0) return @@ -405,16 +405,16 @@ class MuseumGui { }) this.specialIndicator.setLore(lore) - if((this.pageTitle.text !== ("§5"+Player.getOpenedInventory().getName()) || first) && !this.searchText){ + if((this.pageTitle.text !== ("§5"+Player.getContainer().getName()) || first) && !this.searchText){ this.itemsBox.clearChildren() let rewardsButton = new ButtonWithArrow().setText("§5Rewards").setLocation(0.1,0.05,0.8,0.2) rewardsButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(40, false, "MIDDLE") + Player.getContainer().click(40, false, "MIDDLE") })) this.itemsBox.addChild(rewardsButton) let browserButton = new ButtonWithArrow().setText("§5Museum Browser").setLocation(0.1,0.3,0.8,0.2) browserButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(50, false, "MIDDLE") + Player.getContainer().click(50, false, "MIDDLE") })) this.itemsBox.addChild(browserButton) @@ -429,18 +429,18 @@ class MuseumGui { this.donateBox.visable = false let itempages = ["Weapons", "Armor Sets", "Rarities", "Special Items"] - if(itempages.includes(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()])){ - let page = this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()] - let [currPage, pageNum] = Player.getOpenedInventory().getName().includes("/")?Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)):[1,1] + if(itempages.includes(this.replacePage[Player.getContainer().getName().split("➜").pop()])){ + let page = this.replacePage[Player.getContainer().getName().split("➜").pop()] + let [currPage, pageNum] = Player.getContainer().getName().includes("/")?Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)):[1,1] if(!this.searchText){ if(currPage > 1){ this.previousButton.visable = true - if(Player.getOpenedInventory().getStackInSlot(45)) this.previousButton.setLore(Player.getOpenedInventory().getStackInSlot(45).getLore()) + if(Player.getContainer().getStackInSlot(45)) this.previousButton.setLore(Player.getContainer().getStackInSlot(45).getLore()) } if(currPage < pageNum){ this.nextButton.visable = true - if(Player.getOpenedInventory().getStackInSlot(53))this.nextButton.setLore(Player.getOpenedInventory().getStackInSlot(53).getLore()) + if(Player.getContainer().getStackInSlot(53))this.nextButton.setLore(Player.getContainer().getStackInSlot(53).getLore()) } } @@ -449,7 +449,7 @@ class MuseumGui { let oldDonateItems = JSON.stringify(this.donateItems) this.donateItems = [] let donateArmorSets = {} - Player.getOpenedInventory().getItems().forEach((item, slot)=>{ + Player.getContainer().getItems().forEach((item, slot)=>{ if(!item) return if(item.getID() === -1) return item.getLore().forEach(line=>{ @@ -495,7 +495,7 @@ class MuseumGui { for(let i = 0;i<4;i++){ for(let j = 10;j<17;j++){ let slot = i*9+j - let item = Player.getOpenedInventory().getStackInSlot(slot) + let item = Player.getContainer().getStackInSlot(slot) let sb_id = utils.getSBID(item) if(!this.itemsInPages[page][currPage]) this.itemsInPages[page][currPage] = [] @@ -529,37 +529,37 @@ class MuseumGui { if(changed || this.guiUpdated || first) this.regenItems(currPage) } - if(Player.getOpenedInventory().getName() === "Confirm Donation"){ - let this_confirm_temp_str = (Player.getOpenedInventory().getStackInSlot(4)?.getName() || "") +(Player.getOpenedInventory().getStackInSlot(2)?.getName() || "") + (Player.getOpenedInventory().getStackInSlot(20)?.getName() || "") + (Player.getOpenedInventory().getStackInSlot(24)?.getName() || "")//4, 24, 20 + if(Player.getContainer().getName() === "Confirm Donation"){ + let this_confirm_temp_str = (Player.getContainer().getStackInSlot(4)?.getName() || "") +(Player.getContainer().getStackInSlot(2)?.getName() || "") + (Player.getContainer().getStackInSlot(20)?.getName() || "") + (Player.getContainer().getStackInSlot(24)?.getName() || "")//4, 24, 20 if(this.confirm_temp !== this_confirm_temp_str || first){ this.confirm_temp = this_confirm_temp_str this.itemsBox.clearChildren() - let isArmour = utils.getSBID(Player.getOpenedInventory().getStackInSlot(4))===null + let isArmour = utils.getSBID(Player.getContainer().getStackInSlot(4))===null if(isArmour){ - let name = Player.getOpenedInventory().getStackInSlot(2).getName() - let itemBox = new BoxWithText().setText(name.startsWith("§f")?"&7"+name.substr(2):name).setLocation(0.1,0.05,0.8,0.2).setLore(Player.getOpenedInventory().getStackInSlot(2).getLore()) + let name = Player.getContainer().getStackInSlot(2).getName() + let itemBox = new BoxWithText().setText(name.startsWith("§f")?"&7"+name.substr(2):name).setLocation(0.1,0.05,0.8,0.2).setLore(Player.getContainer().getStackInSlot(2).getLore()) this.itemsBox.addChild(itemBox) }else{ - let name = Player.getOpenedInventory().getStackInSlot(4).getName() - let itemBox = new BoxWithText().setText(name.startsWith("§f")?"&7"+name.substr(2):name).setLocation(0.1,0.05,0.8,0.2).setLore(Player.getOpenedInventory().getStackInSlot(4).getLore()) + let name = Player.getContainer().getStackInSlot(4).getName() + let itemBox = new BoxWithText().setText(name.startsWith("§f")?"&7"+name.substr(2):name).setLocation(0.1,0.05,0.8,0.2).setLore(Player.getContainer().getStackInSlot(4).getLore()) this.itemsBox.addChild(itemBox) } - if(Player.getOpenedInventory().getStackInSlot(24) && Player.getOpenedInventory().getStackInSlot(20)){ + if(Player.getContainer().getStackInSlot(24) && Player.getContainer().getStackInSlot(20)){ - let cancelButton = new ButtonWithArrow().setText("§cCancel").setLocation(0.1,0.4,0.35,0.2).setDirectionRight(false).setLore(Player.getOpenedInventory().getStackInSlot(24).getLore()) + let cancelButton = new ButtonWithArrow().setText("§cCancel").setLocation(0.1,0.4,0.35,0.2).setDirectionRight(false).setLore(Player.getContainer().getStackInSlot(24).getLore()) cancelButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(24, false, "LEFT") + Player.getContainer().click(24, false, "LEFT") })) this.itemsBox.addChild(cancelButton) - let confirmButton = new ButtonWithArrow().setText("§aConfirm Donation").setLocation(0.55,0.4,0.35,0.2).setLore(Player.getOpenedInventory().getStackInSlot(20).getLore()) + let confirmButton = new ButtonWithArrow().setText("§aConfirm Donation").setLocation(0.55,0.4,0.35,0.2).setLore(Player.getContainer().getStackInSlot(20).getLore()) confirmButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(20, false, "LEFT") + Player.getContainer().click(20, false, "LEFT") })) this.itemsBox.addChild(confirmButton) } @@ -579,7 +579,7 @@ class MuseumGui { this.favoriteTitleBox.visable = true } - this.pageTitle.setText("§5"+Player.getOpenedInventory().getName()) + this.pageTitle.setText("§5"+Player.getContainer().getName()) this.guiUpdated = false } @@ -588,7 +588,7 @@ class MuseumGui { this.donateItems.forEach((item, i)=>{ let itemButton = new ButtonWithArrow().setText(item.name.startsWith("§f")?"&7"+item.name.substr(2):item.name).setLocation(0.05,0.025+0.125*i,0.9,0.1).setLore(item.lore) itemButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(item.slot, false, "LEFT") + Player.getContainer().click(item.slot, false, "LEFT") })) this.donateBox.addChild(itemButton) }) @@ -597,7 +597,7 @@ class MuseumGui { } showSearchItems(){ - if(Player.getOpenedInventory().getName() === "Confirm Donation") return + if(Player.getContainer().getName() === "Confirm Donation") return if(!this.searchText){ this.tickMenu(true) @@ -663,21 +663,21 @@ class MuseumGui { this.addItemToFavorites(fItem, fItem.page, fItem.page2, fItem.slotNum) return } - // Player.getOpenedInventory().click(item.slotNum, false,button===1?"RIGHT":"LEFT") + // Player.getContainer().click(item.slotNum, false,button===1?"RIGHT":"LEFT") let currPage, pageNum - if(Player.getOpenedInventory().getName().includes("/")){ - [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + if(Player.getContainer().getName().includes("/")){ + [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) } - if(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()]===fItem.page){ + if(this.replacePage[Player.getContainer().getName().split("➜").pop()]===fItem.page){ if(currPage === fItem.page2){ - Player.getOpenedInventory().click(fItem.slotNum, false,"LEFT") + Player.getContainer().click(fItem.slotNum, false,"LEFT") }else{ if(currPage < fItem.page2){ - Player.getOpenedInventory().click(53, false,"MIDDLE") + Player.getContainer().click(53, false,"MIDDLE") }else{ - Player.getOpenedInventory().click(45, false,"MIDDLE") + Player.getContainer().click(45, false,"MIDDLE") } } }else{ @@ -693,14 +693,14 @@ class MuseumGui { let clicks = "?" let currPage, pageNum - if(Player.getOpenedInventory().getName().includes("/")){ - [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + if(Player.getContainer().getName().includes("/")){ + [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) } let pageClicks = Math.abs(currPage-fItem.page2) - if(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()]===fItem.page){ + if(this.replacePage[Player.getContainer().getName().split("➜").pop()]===fItem.page){ clicks = (pageClicks+1) + "" }else{ - if(Player.getOpenedInventory().getName() === "Your Museum"){ + if(Player.getContainer().getName() === "Your Museum"){ clicks = (1+fItem.page2) + "" }else{ clicks = (2+fItem.page2) + "" @@ -734,7 +734,7 @@ class MuseumGui { this.itemsBox.clearChildren() - let page = this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()] + let page = this.replacePage[Player.getContainer().getName().split("➜").pop()] let y = 0.0325 let itemNum = 0 @@ -766,8 +766,8 @@ class MuseumGui { this.addItemToFavorites(slot, page, page2, slotNum) return } - // Player.getOpenedInventory().click(slotNum, false,button===1?"RIGHT":"LEFT") - Player.getOpenedInventory().click(slotNum, false,"LEFT") //TODO: add right click support for viewing armour sets + // Player.getContainer().click(slotNum, false,button===1?"RIGHT":"LEFT") + Player.getContainer().click(slotNum, false,"LEFT") //TODO: add right click support for viewing armour sets })) if(this.favoriteIds.includes(slot.sb_id)){ child.setColor(200, 255, 200) @@ -830,21 +830,21 @@ class MuseumGui { this.addItemToFavorites(fItem, fItem.page, fItem.page2, fItem.slotNum) return } - // Player.getOpenedInventory().click(item.slotNum, false,button===1?"RIGHT":"LEFT") + // Player.getContainer().click(item.slotNum, false,button===1?"RIGHT":"LEFT") let currPage, pageNum - if(Player.getOpenedInventory().getName().includes("/")){ - [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + if(Player.getContainer().getName().includes("/")){ + [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) } - if(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()]===fItem.page){ + if(this.replacePage[Player.getContainer().getName().split("➜").pop()]===fItem.page){ if(currPage === fItem.page2){ - Player.getOpenedInventory().click(fItem.slotNum, false,"LEFT") + Player.getContainer().click(fItem.slotNum, false,"LEFT") }else{ if(currPage < fItem.page2){ - Player.getOpenedInventory().click(53, false,"MIDDLE") + Player.getContainer().click(53, false,"MIDDLE") }else{ - Player.getOpenedInventory().click(45, false,"MIDDLE") + Player.getContainer().click(45, false,"MIDDLE") } } }else{ @@ -860,14 +860,14 @@ class MuseumGui { let clicks = "?" let currPage, pageNum - if(Player.getOpenedInventory().getName().includes("/")){ - [currPage, pageNum] = Player.getOpenedInventory().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) + if(Player.getContainer().getName().includes("/")){ + [currPage, pageNum] = Player.getContainer().getName().split(")")[0].split("(")[1].split("/").map(a=>parseInt(a)) } let pageClicks = Math.abs(currPage-fItem.page2) - if(this.replacePage[Player.getOpenedInventory().getName().split("➜").pop()]===fItem.page){ + if(this.replacePage[Player.getContainer().getName().split("➜").pop()]===fItem.page){ clicks = (pageClicks+1) + "" }else{ - if(Player.getOpenedInventory().getName() === "Your Museum"){ + if(Player.getContainer().getName() === "Your Museum"){ clicks = (1+fItem.page2) + "" }else{ clicks = (2+fItem.page2) + "" @@ -904,10 +904,10 @@ class MuseumGui { if(event.gui && event.gui.field_147002_h){ Player.getPlayer().field_71070_bA = event.gui.field_147002_h - if(Player.getOpenedInventory().getName() === "Museum Rewards"){ + if(Player.getContainer().getName() === "Museum Rewards"){ return } - if(Player.getOpenedInventory().getName().startsWith("Museum Browser")){ + if(Player.getContainer().getName().startsWith("Museum Browser")){ return } @@ -937,12 +937,12 @@ class MuseumGui { this.itemsBox.clearChildren() let rewardsButton = new ButtonWithArrow().setText("§5Rewards").setLocation(0.1,0.05,0.8,0.2) rewardsButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(40, false, "MIDDLE") + Player.getContainer().click(40, false, "MIDDLE") })) this.itemsBox.addChild(rewardsButton) let browserButton = new ButtonWithArrow().setText("§5Museum Browser").setLocation(0.1,0.3,0.8,0.2) browserButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(50, false, "MIDDLE") + Player.getContainer().click(50, false, "MIDDLE") })) this.itemsBox.addChild(browserButton) diff --git a/features/dataLoader/index.js b/features/dataLoader/index.js index dbaf841..fe11e42 100644 --- a/features/dataLoader/index.js +++ b/features/dataLoader/index.js @@ -18,6 +18,8 @@ class DataLoader extends Feature { this.isInSkyblock = false + this.dungeonPercentCleared = 0 + this.registerStep(true, 2, this.step) this.registerEvent("worldLoad", this.worldLoad) @@ -91,7 +93,15 @@ class DataLoader extends Feature { TabList.getNames().forEach(n=>{ n = ChatLib.removeFormatting(n) if(n.includes(": ")){ - this.stats[n.split(": ")[0].trim()] = n.split(": ")[1].trim() + if(n.includes('Secrets Found')){ + if(n.includes('%')){ + this.stats["Secrets Found%"] = n.split(": ")[1] + }else{ + this.stats["Secrets Found"] = n.split(": ")[1] + } + }else{ + this.stats[n.split(": ")[0].trim()] = n.split(": ")[1].trim() + } } }) } @@ -121,6 +131,9 @@ class DataLoader extends Feature { if(name.startsWith("Bits: ")){ this.bits = parseInt(name.split("Bits: ")[1].split(" ")[0]) } + if(name.startsWith("Cleared: ")){ + this.dungeonPercentCleared = parseInt(name.split(" ")[1])/100 + } if(name.endsWith("Combat XP")){ this.slayerXpToSpawn = ChatLib.removeFormatting(name).split("(")[1].split(")")[0].split("/").map(parseInt) diff --git a/features/dungeonMap/index.js b/features/dungeonMap/index.js index f8abb4e..db22135 100644 --- a/features/dungeonMap/index.js +++ b/features/dungeonMap/index.js @@ -720,7 +720,7 @@ class SpiritLeapOverlay { tick(){ let itemsNew = {} - if(Player.getOpenedInventory()?.getName() === "Spirit Leap"){ + if(Player.getContainer()?.getName() === "Spirit Leap"){ this.players = {} Scoreboard.getLines().forEach(line=>{ @@ -733,7 +733,7 @@ class SpiritLeapOverlay { }) for(let i = 1;i<9*3;i++){ - let item = Player.getOpenedInventory().getStackInSlot(i) + let item = Player.getContainer().getStackInSlot(i) if(item && item.getID()!==160){ itemsNew[item.getName()] = i } @@ -745,7 +745,7 @@ class SpiritLeapOverlay { Object.keys(this.items).forEach((name, i)=>{ let button = new ButtonWithArrow().setText((ChatLib.removeFormatting(name)===this.parent.lastDoorOpener?"&4":"&2")+"["+this.players[ChatLib.removeFormatting(name)]+"] "+ChatLib.removeFormatting(name)).addEvent(new SoopyMouseClickEvent().setHandler(()=>{ - Player.getOpenedInventory().click(itemsNew[name]) + Player.getContainer().click(itemsNew[name]) ChatLib.chat("Leaping to " + name) })).setLocation((i%2)*0.5,Math.floor(i/2)*0.5,0.5,0.5) button.text.setLocation(0.5, 0, 0.4, 1) @@ -833,12 +833,12 @@ class soopyGuiMapRendererThing extends SoopyGuiElement { let closestPlayer = this.getClosestPlayerTo(x, y, size, scale, mouseX, mouseY) if(closestPlayer){ - if(Player.getOpenedInventory()?.getName() === "Spirit Leap"){ + if(Player.getContainer()?.getName() === "Spirit Leap"){ for(let i = 1;i<9*3;i++){ - let item = Player.getOpenedInventory().getStackInSlot(i) + let item = Player.getContainer().getStackInSlot(i) if(item && item.getID()!==160){ if(ChatLib.removeFormatting(item.getName()) === closestPlayer.username){ - Player.getOpenedInventory().click(i) + Player.getContainer().click(i) ChatLib.chat("Leaping to " + closestPlayer.username) } } diff --git a/features/dungeonSolvers/index.js b/features/dungeonSolvers/index.js index 8e95961..b4f1793 100644 --- a/features/dungeonSolvers/index.js +++ b/features/dungeonSolvers/index.js @@ -9,224 +9,369 @@ import HudTextElement from "../hud/HudTextElement"; import LocationSetting from "../settings/settingThings/location"; import ToggleSetting from "../settings/settingThings/toggle"; -const EntityArrow = Java.type("net.minecraft.entity.projectile.EntityArrow") -const EntityBlaze = Java.type("net.minecraft.entity.monster.EntityBlaze") -const AxisAlignedBB = Java.type("net.minecraft.util.AxisAlignedBB") -let translate -try{ - translate = net.minecraft.util.StringTranslate.func_74808_a() -}catch(e){ +const EntityArrow = Java.type("net.minecraft.entity.projectile.EntityArrow"); +const EntityBlaze = Java.type("net.minecraft.entity.monster.EntityBlaze"); +const AxisAlignedBB = Java.type("net.minecraft.util.AxisAlignedBB"); +let translate; +try { + translate = net.minecraft.util.StringTranslate.func_74808_a(); +} catch (e) { //player doesent have translate (using english default) } class DungeonSolvers extends Feature { - constructor() { - super(); - } - - onEnable() { - this.initVariables(); - - this.lividData = {}; - this.lividData.lividColor = { - Vendetta: "&f", - Crossed: "&d", - Hockey: "&c", - Doctor: "&7", - Frog: "&2", - Smile: "&a", - Scream: "&9", - Purple: "&5", - Arcade: "&e", - }; - this.onWorldLoad(); - - this.lividFindEnabled = new ToggleSetting("Correct livid finder", "Finds the real livid to kill in the f5 boss fight", true, "livid_find_enabled", this); - this.lividFindHud = new ToggleSetting("Show Livid Hp", "Shows the nametag of the correct livid", true, "livid_hud_enabled", this).requires(this.lividFindEnabled); - this.lividHpElement = new HudTextElement().setToggleSetting(this.lividFindHud).setLocationSetting(new LocationSetting("Correct Livid Hp Location", "Allows you to edit the location of the correct livid hp text", "livid_hp_location", this, [10, 50, 1, 1]).requires(this.lividFindHud).editTempText("§r§e﴾ §c§lLivid§r §a7M§c❤ §e﴿§r")); - - this.hudElements.push(this.lividHpElement); - - this.lividFindBox = new ToggleSetting("Put a box around the correct livid", "This helps to locate it in the group", true, "livid_box_enabled", this).requires(this.lividFindEnabled); - this.lividFindNametags = new ToggleSetting("Hide the nametags of incorrect livids", "This helps to locate it in the group", true, "livid_nametags_enabled", this).requires(this.lividFindEnabled); - - this.spiritBowDestroyTimer = new ToggleSetting("Timer for when the spirit bow will self destruct", "", true, "spirit_bow_destroy_timer", this); - this.spiritBowDestroyElement = new HudTextElement().setToggleSetting(this.spiritBowDestroyTimer).setLocationSetting(new LocationSetting("Spirit bow destroy timer location", "Allows you to edit the location of the timer", "spirit_destroy_location", this, [10, 70, 3, 1]).requires(this.spiritBowDestroyTimer).editTempText("&dBow Destroyed in: &c15s")); - - this.spiritBearSpawnTimer = new ToggleSetting("Timer for when the spirit bear will spawn", "", true, "spirit_bear_spawn_timer", this); - this.spiritBearSpawnElement = new HudTextElement().setToggleSetting(this.spiritBearSpawnTimer).setLocationSetting(new LocationSetting("Spirit bear spawn timer location", "Allows you to edit the location of the timer", "spirit_bear_spawn_location", this, [10, 70, 3, 1]).requires(this.spiritBearSpawnTimer).editTempText("&dBear spawned in: &c1.57s")); - - this.hudElements.push(this.spiritBearSpawnElement); - this.hudElements.push(this.spiritBowDestroyElement); - - this.bloodCampAssist = new ToggleSetting("Assist blood camp", "Helps guess where and when blood mobs will spawn", true, "blood_camp_assist", this); - - this.runSpeedRates = new ToggleSetting("Show run speed and exp rates", "(Run speed includes downtime inbetween runs, only shows while doing dungeon runs)", true, "run_speed_rates", this); - this.runSpeedRatesElement = new HudTextElement() - .setText("&6Run speed&7> &fLoading...\n&6Exp/hour&7> &fLoading...\n&6Runs/hour&7> &fLoading...") - .setToggleSetting(this.runSpeedRates) - .setLocationSetting(new LocationSetting("Run speed and exp rates location", "Allows you to edit the location of the information", "run_speed_rates_location", this, [10, 100, 1, 1]).requires(this.runSpeedRates).editTempText("&6Run speed&7> &f4:30\n&6Exp/hour&7> &f1,234,567\n&6Runs/hour&7> &f17")); - - this.hudElements.push(this.runSpeedRatesElement); - - this.blazeSolver = new ToggleSetting("Blaze Puzzle Solver", "Shows what order to kill the blazes in", true, "blaze_solver", this); - - this.lastDungFinishes = []; - this.lastDungExps = []; - this.registerChat("${start}+&r&3${exp} Catacombs Experience&r", (start, exp) => { - if (ChatLib.removeFormatting(start).replace(/ /gi, "").length > 0) return; - this.lastDungExps.push(parseFloat(exp.replace(/,/gi, ""))); - if (this.lastDungExps.length > 5) { - this.lastDungExps.shift(); - } - - this.lastDungFinishes.push(Date.now()); - if (this.lastDungFinishes.length > 5) { - this.lastDungFinishes.shift(); - } - }); - this.forgorEnabled = new ToggleSetting("Change withermancer death message to forgor ", "", true, "withermancer_forgor", this); - - this.registerChat("&r&c ☠ &r${player} were killed by Withermancer&r&7 and became a ghost&r&7.&r", (player, e) => { - if (this.forgorEnabled.getValue()) { - cancel(e); - ChatLib.chat(player + " forgor ☠"); - } - }); - this.registerChat("&r&c ☠ &r${player} was killed by Withermancer&r&7 and became a ghost&r&7.&r", (player, e) => { - if (this.forgorEnabled.getValue()) { - cancel(e); - ChatLib.chat(player + " forgor ☠"); - } - }); - - this.spiritBowPickUps = []; - this.registerChat("&r&aYou picked up the &r&5Spirit Bow&r&a! Use it to attack &r&cThorn&r&a!&r", () => { - this.spiritBowPickUps.push(Date.now()); - }); - - - this.bearSpawning = 0 - this.registerChat("&r&a&lThe &r&5&lSpirit Bow &r&a&lhas dropped!&r", ()=>{ - this.bearSpawning = -Date.now() - }) - - this.todoE = []; - this.eMovingThing = {}; - this.bloodX = -1; - this.bloodY = -1; - this.startSpawningTime = 0; - this.spawnIdThing = 0; - - this.checkingPing = false; - this.lastPingCheck = 0; - this.lastPings = [undefined, undefined, undefined]; - this.ping = 0; - this.pingI = 0; - - this.arrows = [] - this.blazes = [] - this.blazeX = -1; - this.blazeY = -1; - - this.registerStep(true, 2, this.step); - this.registerStep(true, 10, this.step2); - this.registerEvent("worldLoad", this.onWorldLoad); - - this.registerEvent("renderOverlay", this.renderHud); - this.registerEvent("renderWorld", this.renderWorld); - - this.registerChat("&b&bYou are currently connected to server &6${*}&r", (e) => { - if (this.checkingPing) { - this.lastPings[this.pingI % 3] = Date.now() - this.lastPingCheck; - cancel(e); - this.checkingPing = false; - - if (this.lastPings.includes(undefined)) { - this.ping = this.lastPings[this.pingI % 3]; - } else { - this.ping = [...this.lastPings].sort((a, b) => a - b)[1]; - } - this.pingI++; - } - }); - - this.registerForge(net.minecraftforge.event.entity.EntityJoinWorldEvent, this.entityJoinWorldEvent); - // this.registerEvent("renderEntity", this.renderEntity) - this.renderEntityEvent = undefined; - - this.onWorldLoad(); - } - - entityJoinWorldEvent(event) { - if (this.bloodCampAssist.getValue()) this.todoE.push(event.entity); - - // if(event.entity instanceof EntityArrow){ - // this.arrows.push(new Entity(event.entity)) - // } - if(event.entity instanceof EntityBlaze){ - // console.log("Blaze joined world") - this.addBlaze(new Entity(event.entity)) + constructor() { + super(); } - } - renderWorld(ticks) { - if (this.lividFindBox.getValue()) { - if (this.lividData.correctLividEntity) { - renderUtils.drawBoxAtEntity(this.lividData.correctLividEntity, 255, 0, 0, 0.75, -2, ticks); - } - } + onEnable() { + this.initVariables(); + + this.lividData = {}; + this.lividData.lividColor = { + Vendetta: "&f", + Crossed: "&d", + Hockey: "&c", + Doctor: "&7", + Frog: "&2", + Smile: "&a", + Scream: "&9", + Purple: "&5", + Arcade: "&e", + }; + this.onWorldLoad(); + + this.lividFindEnabled = new ToggleSetting("Correct livid finder", "Finds the real livid to kill in the f5 boss fight", true, "livid_find_enabled", this); + this.lividFindHud = new ToggleSetting("Show Livid Hp", "Shows the nametag of the correct livid", true, "livid_hud_enabled", this).requires(this.lividFindEnabled); + this.lividHpElement = new HudTextElement().setToggleSetting(this.lividFindHud).setLocationSetting(new LocationSetting("Correct Livid Hp Location", "Allows you to edit the location of the correct livid hp text", "livid_hp_location", this, [10, 50, 1, 1]).requires(this.lividFindHud).editTempText("§r§e﴾ §c§lLivid§r §a7M§c❤ §e﴿§r")); + + this.hudElements.push(this.lividHpElement); + + this.lividFindBox = new ToggleSetting("Put a box around the correct livid", "This helps to locate it in the group", true, "livid_box_enabled", this).requires(this.lividFindEnabled); + this.lividFindNametags = new ToggleSetting("Hide the nametags of incorrect livids", "This helps to locate it in the group", true, "livid_nametags_enabled", this).requires(this.lividFindEnabled); + + this.spiritBowDestroyTimer = new ToggleSetting("Timer for when the spirit bow will self destruct", "", true, "spirit_bow_destroy_timer", this); + this.spiritBowDestroyElement = new HudTextElement().setToggleSetting(this.spiritBowDestroyTimer).setLocationSetting(new LocationSetting("Spirit bow destroy timer location", "Allows you to edit the location of the timer", "spirit_destroy_location", this, [10, 70, 3, 1]).requires(this.spiritBowDestroyTimer).editTempText("&dBow Destroyed in: &c15s")); + + this.spiritBearSpawnTimer = new ToggleSetting("Timer for when the spirit bear will spawn", "", true, "spirit_bear_spawn_timer", this); + this.spiritBearSpawnElement = new HudTextElement().setToggleSetting(this.spiritBearSpawnTimer).setLocationSetting(new LocationSetting("Spirit bear spawn timer location", "Allows you to edit the location of the timer", "spirit_bear_spawn_location", this, [10, 70, 3, 1]).requires(this.spiritBearSpawnTimer).editTempText("&dBear spawned in: &c1.57s")); + + this.hudElements.push(this.spiritBearSpawnElement); + this.hudElements.push(this.spiritBowDestroyElement); + + this.bloodCampAssist = new ToggleSetting("Assist blood camp", "Helps guess where and when blood mobs will spawn", true, "blood_camp_assist", this); + + this.runSpeedRates = new ToggleSetting("Show run speed and exp rates", "(Run speed includes downtime inbetween runs, only shows while doing dungeon runs)", true, "run_speed_rates", this); + this.runSpeedRatesElement = new HudTextElement() + .setText("&6Run speed&7> &fLoading...\n&6Exp/hour&7> &fLoading...\n&6Runs/hour&7> &fLoading...") + .setToggleSetting(this.runSpeedRates) + .setLocationSetting(new LocationSetting("Run speed and exp rates location", "Allows you to edit the location of the information", "run_speed_rates_location", this, [10, 100, 1, 1]).requires(this.runSpeedRates).editTempText("&6Run speed&7> &f4:30\n&6Exp/hour&7> &f1,234,567\n&6Runs/hour&7> &f17")); + + this.scoreCalculation = new ToggleSetting("Show score calculation", "", true, "run_score_calc", this); + this.scoreElement = new HudTextElement().setToggleSetting(this.scoreCalculation).setLocationSetting(new LocationSetting("Score calculation location", "Allows you to edit the location of the score calc", "score_calc_location", this, [10, 130, 1, 1]).requires(this.scoreCalculation).editTempText("Editing temp text here")); + + this.hudElements.push(this.runSpeedRatesElement); + this.hudElements.push(this.scoreElement); + + this.blazeSolver = new ToggleSetting("Blaze Puzzle Solver", "Shows what order to kill the blazes in", true, "blaze_solver", this); + + this.lastDungFinishes = []; + this.lastDungExps = []; + this.registerChat("${start}+&r&3${exp} Catacombs Experience&r", (start, exp) => { + if (ChatLib.removeFormatting(start).replace(/ /gi, "").length > 0) return; + this.lastDungExps.push(parseFloat(exp.replace(/,/gi, ""))); + if (this.lastDungExps.length > 5) { + this.lastDungExps.shift(); + } + + this.lastDungFinishes.push(Date.now()); + if (this.lastDungFinishes.length > 5) { + this.lastDungFinishes.shift(); + } + }); + this.forgorEnabled = new ToggleSetting("Change withermancer death message to forgor ", "", true, "withermancer_forgor", this); - if (this.bloodCampAssist.getValue()) { - this.skulls.forEach((skull) => { - let skullE = skull.getEntity(); - // renderUtils.drawBoxAtEntity(skull, 255, 0, 0, 0.5, 0.5, ticks) + this.registerChat("&r&c ☠ &r${player} were killed by Withermancer&r&7 and became a ghost&r&7.&r", (player, e) => { + if (this.forgorEnabled.getValue()) { + cancel(e); + ChatLib.chat(player + " forgor ☠"); + } + }); + this.registerChat("&r&c ☠ &r${player} was killed by Withermancer&r&7 and became a ghost&r&7.&r", (player, e) => { + if (this.forgorEnabled.getValue()) { + cancel(e); + ChatLib.chat(player + " forgor ☠"); + } + }); - if (this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook) { - let startPoint = [skullE[f.posX.Entity], skullE[f.posY.Entity], skullE[f.posZ.Entity]]; + this.spiritBowPickUps = []; + this.registerChat("&r&aYou picked up the &r&5Spirit Bow&r&a! Use it to attack &r&cThorn&r&a!&r", () => { + this.spiritBowPickUps.push(Date.now()); + }); - let xSpeed2 = (startPoint[0] - this.eMovingThing[skull.getUUID().toString()].startX) / this.eMovingThing[skull.getUUID().toString()].timeTook; - let ySpeed2 = (startPoint[1] - this.eMovingThing[skull.getUUID().toString()].startY) / this.eMovingThing[skull.getUUID().toString()].timeTook; - let zSpeed2 = (startPoint[2] - this.eMovingThing[skull.getUUID().toString()].startZ) / this.eMovingThing[skull.getUUID().toString()].timeTook; + this.bearSpawning = 0; + this.registerChat("&r&a&lThe &r&5&lSpirit Bow &r&a&lhas dropped!&r", () => { + this.bearSpawning = -Date.now(); + }); - let time = (this.spawnIdThing >= 4 ? 2900 : 4850) - this.eMovingThing[skull.getUUID().toString()].timeTook; - let endPoint1 = this.eMovingThing[skull.getUUID().toString()].endPoint; - let endPoint2 = this.eMovingThing[skull.getUUID().toString()].endPointLast; - let endPointUpdated = Math.min(Date.now() - this.eMovingThing[skull.getUUID().toString()].endPointUpdated, 100); - if(!endPoint2) return - let endPoint = [endPoint2[0] + ((endPoint1[0] - endPoint2[0]) * endPointUpdated) / 100, endPoint2[1] + ((endPoint1[1] - endPoint2[1]) * endPointUpdated) / 100, endPoint2[2] + ((endPoint1[2] - endPoint2[2]) * endPointUpdated) / 100]; - let pingPoint = [startPoint[0] + xSpeed2 * this.ping, startPoint[1] + ySpeed2 * this.ping, startPoint[2] + zSpeed2 * this.ping]; + this.todoE = []; + this.eMovingThing = {}; + this.bloodX = -1; + this.bloodY = -1; + this.startSpawningTime = 0; + this.spawnIdThing = 0; + + this.failedPuzzleCount = 0; + this.totalPuzzleCount = 0; + this.completedPuzzleCount = 0; + + this.checkingPing = false; + this.lastPingCheck = 0; + this.lastPings = [undefined, undefined, undefined]; + this.ping = 0; + this.pingI = 0; + + this.arrows = []; + this.blazes = []; + this.blazeX = -1; + this.blazeY = -1; + + this.dungeonSecretRquired = { + 1: 0.3, + 2: 0.4, + 3: 0.5, + 4: 0.6, + 5: 0.7, + 6: 0.85, + 7: 1, + }; + this.floorSecondMod = { + 1: 120, + 2: 120, + 3: 120, + 4: 120, + 5: 240, + 6: 120, + 7: 360, + }; + + this.registerStep(true, 2, this.step); + this.registerStep(true, 10, this.step2); + this.registerEvent("worldLoad", this.onWorldLoad); + + this.registerEvent("renderOverlay", this.renderHud); + this.registerEvent("renderWorld", this.renderWorld); + + this.bloodOpenedBonus = false; + this.goneInBonus = false; + this.registerChat("&r&cThe &r&c&lBLOOD DOOR&r&c has been opened!&r", () => { + this.bloodOpenedBonus = true; + this.goneInBonus = true; + }); + this.registerChat("&r&c[BOSS] The Watcher&r&f: You have proven yourself. You may pass.&r", () => { + this.bloodOpenedBonus = false; + this.goneInBonus = true; + }); + let enteredBossMessages = ["&r&4[BOSS] Maxor&r&c: &r&cWELL WELL WELL LOOK WHO’S HERE!&r", "&r&c[BOSS] Livid&r&f: Welcome, you arrive right on time. I am Livid, the Master of Shadows.&r", "&r&c[BOSS] Thorn&r&f: Welcome Adventurers! I am Thorn, the Spirit! And host of the Vegan Trials!&r", "&r&c[BOSS] The Professor&r&f: I was burdened with terrible news recently...&r", "&r&c[BOSS] Scarf&r&f: This is where the journey ends for you, Adventurers.&r", "&r&c[BOSS] Bonzo&r&f: Gratz for making it this far, but I’m basically unbeatable.&r", "&r&c[BOSS] Sadan&r&f: So you made it all the way &r&fhere...and&r&f you wish to defy me? Sadan?!&r"] + enteredBossMessages.forEach(msg => { + this.registerChat(msg, () => { + this.goneInBonus = false; + this.bloodOpenedBonus = false; + }); + }) - renderUtils.drawLineWithDepth(startPoint[0], startPoint[1] + 2, startPoint[2], endPoint[0], endPoint[1] + 2, endPoint[2], 255, 0, 0, 2); + this.registerChat("&b&bYou are currently connected to server &6${*}&r", (e) => { + if (this.checkingPing) { + this.lastPings[this.pingI % 3] = Date.now() - this.lastPingCheck; + cancel(e); + this.checkingPing = false; - if (this.ping < time) { - renderUtils.drawBoxAtBlockNotVisThruWalls(pingPoint[0] - 0.5, pingPoint[1] + 1.5, pingPoint[2] - 0.5, 0, 255, 0); - renderUtils.drawBoxAtBlockNotVisThruWalls(endPoint[0] - 0.5, endPoint[1] + 1.5, endPoint[2] - 0.5, 255, 0, 0); + if (this.lastPings.includes(undefined)) { + this.ping = this.lastPings[this.pingI % 3]; } else { - renderUtils.drawBoxAtBlockNotVisThruWalls(endPoint[0] - 0.5, endPoint[1] + 1.5, endPoint[2] - 0.5, 0, 0, 255); + this.ping = [...this.lastPings].sort((a, b) => a - b)[1]; } - - // if(this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook){ - // Tessellator.drawString((time/1000).toFixed(3)+"s", endPoint[0], endPoint[1]+2, endPoint[2]) - // } + this.pingI++; } }); - } - if(this.blazeX !== -1 && this.blazes.length > 0 && this.blazeSolver.getValue()){ - renderUtils.drawBoxAtEntity(this.blazes[0], 255, 0, 0, 1, 2, ticks, 2) + this.registerForge(net.minecraftforge.event.entity.EntityJoinWorldEvent, this.entityJoinWorldEvent); + // this.registerEvent("renderEntity", this.renderEntity) + this.renderEntityEvent = undefined; + + this.onWorldLoad(); + } + + calculateDungeonScore() { + if (!this.FeatureManager.features["dataLoader"].class.dungeonFloor) { + this.scoreElement.setText(""); + return; + } + + // Information about the dungeon + let deaths = parseInt(this.FeatureManager.features["dataLoader"].class.stats.Deaths.replace("(", "").replace(")", "")); + let firstDeathHadSpirit = false; //TODO: this + + let seconds = 0; + if (this.FeatureManager.features["dataLoader"].class.stats.Time !== "Soon!") { + let data = this.FeatureManager.features["dataLoader"].class.stats.Time.split(" "); + seconds += parseInt(data.pop() || 0); + seconds += parseInt(data.pop() || 0) * 60; + seconds += parseInt(data.pop() || 0) * 60 * 60; + } + let timeLimit = this.FeatureManager.features["dataLoader"].class.dungeonFloor[0] === "M" ? 480 : this.floorSecondMod[this.FeatureManager.features["dataLoader"].class.dungeonFloor[1]]; + let inDungeonSeconds = seconds - timeLimit; - let lastLoc = [this.blazes[0].getX(), this.blazes[0].getY()+1.5, this.blazes[0].getZ()] - this.blazes.forEach((blaze, i) => { - if(i<3 && i!==0){ - renderUtils.drawLineWithDepth(lastLoc[0], lastLoc[1], lastLoc[2], blaze.getX(), blaze.getY()+1.5, blaze.getZ(), i===1?0:255, i===1?255:0, 0, 3/i) - lastLoc = [blaze.getX(), blaze.getY()+1.5,blaze.getZ()] + let clearedPercent = this.FeatureManager.features["dataLoader"].class.dungeonPercentCleared; + + let dungeonFloor = this.FeatureManager.features["dataLoader"].class.dungeonFloor[1]; + + let secretPercentRequired = this.FeatureManager.features["dataLoader"].class.dungeonFloor[0] === "M" ? 1 : this.dungeonSecretRquired[dungeonFloor]; + + let clearedRooms = parseInt(this.FeatureManager.features["dataLoader"].class.stats["Completed Rooms"]); + + let totalRooms = clearedRooms / clearedPercent || 25; + + let currentSecretsFound = parseInt(this.FeatureManager.features["dataLoader"].class.stats["Secrets Found"]); + let currentSecretPercent = parseFloat(this.FeatureManager.features["dataLoader"].class.stats["Secrets Found%"].replace("%", "")) / 100; + + let mimicKilled = false; //TODO: this + let crypts = parseInt(this.FeatureManager.features["dataLoader"].class.stats["Crypts"]); + + let ezpz = false; + + let maxSecrets = currentSecretsFound / currentSecretPercent || 50; + + //Actual Score Calculation + let skillScore = Math.floor(Math.max(20, (20 - (this.totalPuzzleCount - this.completedPuzzleCount) * 10 + (((80 * (clearedRooms + this.bloodOpenedBonus + this.goneInBonus)) / totalRooms) - deaths * 2 + firstDeathHadSpirit)))); + let exploreScore = (Math.floor((60 * (clearedRooms + this.bloodOpenedBonus + this.goneInBonus)) / totalRooms) + Math.floor(Math.min(40, (40 * currentSecretsFound) / secretPercentRequired / maxSecrets))); + let speedScore; + if (inDungeonSeconds < 480) { + speedScore = 100; + } else if (inDungeonSeconds < 600) { + speedScore = Math.ceil(140 - inDungeonSeconds / 12); + } else if (inDungeonSeconds < 840) { + speedScore = Math.ceil(115 - inDungeonSeconds / 24); + } else if (inDungeonSeconds < 1140) { + speedScore = Math.ceil(108 - inDungeonSeconds / 30); + } else if (inDungeonSeconds < 3940) { + speedScore = Math.ceil(98.5 - inDungeonSeconds / 40); + } else { + speedScore = 0; + } + let bonus = Math.min(5, crypts) + mimicKilled * 2 + ezpz * 10; + + //Calculating secrets for s/s+ + + let hypotheticalSkillScore = Math.floor(Math.max(20, (20 - (this.failedPuzzleCount) * 10 + 80 - deaths * 2 + firstDeathHadSpirit))); + let hypotheticalSpeedScore = speedScore + + //Calculating for S + let hypotheticalBonusScoreS = Math.min(5, crypts) + mimicKilled * 2 + ezpz * 10; + + let sNeededSecrets = Math.min(maxSecrets * secretPercentRequired, Math.ceil((270 - hypotheticalSkillScore - hypotheticalBonusScoreS - hypotheticalSpeedScore - 60) * maxSecrets * secretPercentRequired / 40)); + + sNeededSecrets = Math.max(currentSecretsFound, sNeededSecrets) + + let hypotheticalScoreGottenS = hypotheticalSkillScore + hypotheticalSpeedScore + hypotheticalBonusScoreS + 60 + Math.floor(Math.min(40, (40 * sNeededSecrets) / secretPercentRequired / maxSecrets)); + let sCryptsNeeded = Math.max(crypts, Math.min(5, (270 - hypotheticalScoreGottenS))) + hypotheticalScoreGottenS -= hypotheticalBonusScoreS + hypotheticalBonusScoreS = sCryptsNeeded + mimicKilled * 2 + ezpz * 10 + hypotheticalScoreGottenS += hypotheticalBonusScoreS + + let sPossible = hypotheticalScoreGottenS >= 270 + + //Calculating for S+ + let hypotheticalBonusScoreSplus = 5 + mimicKilled * 2 + ezpz * 10; + + let splusNeededSecrets = Math.ceil((300 - hypotheticalSkillScore - hypotheticalBonusScoreSplus - hypotheticalSpeedScore - 60) * maxSecrets * secretPercentRequired / 40); + + let splusPossible = splusNeededSecrets <= maxSecrets * secretPercentRequired + + splusNeededSecrets = Math.max(currentSecretsFound, splusNeededSecrets) + + let hypotheticalScoreGottenSPlus = hypotheticalSkillScore + hypotheticalSpeedScore + hypotheticalBonusScoreSplus + 60 + Math.floor(Math.min(40, (40 * splusNeededSecrets) / secretPercentRequired / maxSecrets)); + let splusCryptsNeeded = Math.max(crypts, 5 - (hypotheticalScoreGottenSPlus - 300)) + hypotheticalScoreGottenSPlus -= hypotheticalBonusScoreSplus + hypotheticalBonusScoreSplus = splusCryptsNeeded + mimicKilled * 2 + ezpz * 10 + hypotheticalScoreGottenSPlus += hypotheticalBonusScoreSplus + + //Setting hud element + let sPlusText = currentSecretsFound === 0 ? "??" : (skillScore + exploreScore + speedScore + bonus) >= 300 ? ": ✔" : splusPossible ? `(${hypotheticalScoreGottenSPlus}): ${currentSecretsFound}/${splusNeededSecrets} +${crypts}c/${splusCryptsNeeded}` : "✖" + let sText = currentSecretsFound === 0 ? " ??" : (skillScore + exploreScore + speedScore + bonus) >= 270 ? " : ✔" : sPossible ? `(${hypotheticalScoreGottenS}): ${currentSecretsFound}/${sNeededSecrets} +${crypts}c/${sCryptsNeeded}` : "✖" + + this.scoreElement.setText(`&dScore: ${skillScore + exploreScore + speedScore + bonus}\n&aS+ ${sPlusText}\n&aS ${sText}`); + } + + entityJoinWorldEvent(event) { + if (this.bloodCampAssist.getValue()) this.todoE.push(event.entity); + + // if(event.entity instanceof EntityArrow){ + // this.arrows.push(new Entity(event.entity)) + // } + if (event.entity instanceof EntityBlaze) { + // console.log("Blaze joined world") + this.addBlaze(new Entity(event.entity)); + } + } + + renderWorld(ticks) { + if (this.lividFindBox.getValue()) { + if (this.lividData.correctLividEntity) { + renderUtils.drawBoxAtEntity(this.lividData.correctLividEntity, 255, 0, 0, 0.75, -2, ticks); } - }) + } + + if (this.bloodCampAssist.getValue()) { + this.skulls.forEach((skull) => { + let skullE = skull.getEntity(); + // renderUtils.drawBoxAtEntity(skull, 255, 0, 0, 0.5, 0.5, ticks) + + if (this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook) { + let startPoint = [skullE[f.posX.Entity], skullE[f.posY.Entity], skullE[f.posZ.Entity]]; + + let xSpeed2 = (startPoint[0] - this.eMovingThing[skull.getUUID().toString()].startX) / this.eMovingThing[skull.getUUID().toString()].timeTook; + let ySpeed2 = (startPoint[1] - this.eMovingThing[skull.getUUID().toString()].startY) / this.eMovingThing[skull.getUUID().toString()].timeTook; + let zSpeed2 = (startPoint[2] - this.eMovingThing[skull.getUUID().toString()].startZ) / this.eMovingThing[skull.getUUID().toString()].timeTook; + + let time = (this.spawnIdThing >= 4 ? 2900 : 4850) - this.eMovingThing[skull.getUUID().toString()].timeTook; + let endPoint1 = this.eMovingThing[skull.getUUID().toString()].endPoint; + let endPoint2 = this.eMovingThing[skull.getUUID().toString()].endPointLast; + let endPointUpdated = Math.min(Date.now() - this.eMovingThing[skull.getUUID().toString()].endPointUpdated, 100); + if (!endPoint2) return; + let endPoint = [endPoint2[0] + ((endPoint1[0] - endPoint2[0]) * endPointUpdated) / 100, endPoint2[1] + ((endPoint1[1] - endPoint2[1]) * endPointUpdated) / 100, endPoint2[2] + ((endPoint1[2] - endPoint2[2]) * endPointUpdated) / 100]; + let pingPoint = [startPoint[0] + xSpeed2 * this.ping, startPoint[1] + ySpeed2 * this.ping, startPoint[2] + zSpeed2 * this.ping]; + + renderUtils.drawLineWithDepth(startPoint[0], startPoint[1] + 2, startPoint[2], endPoint[0], endPoint[1] + 2, endPoint[2], 255, 0, 0, 2); + + if (this.ping < time) { + renderUtils.drawBoxAtBlockNotVisThruWalls(pingPoint[0] - 0.5, pingPoint[1] + 1.5, pingPoint[2] - 0.5, 0, 255, 0); + renderUtils.drawBoxAtBlockNotVisThruWalls(endPoint[0] - 0.5, endPoint[1] + 1.5, endPoint[2] - 0.5, 255, 0, 0); + } else { + renderUtils.drawBoxAtBlockNotVisThruWalls(endPoint[0] - 0.5, endPoint[1] + 1.5, endPoint[2] - 0.5, 0, 0, 255); + } + + // if(this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook){ + // Tessellator.drawString((time/1000).toFixed(3)+"s", endPoint[0], endPoint[1]+2, endPoint[2]) + // } + } + }); + } + + if (this.blazeX !== -1 && this.blazes.length > 0 && this.blazeSolver.getValue()) { + renderUtils.drawBoxAtEntity(this.blazes[0], 255, 0, 0, 1, 2, ticks, 2); + + let lastLoc = [this.blazes[0].getX(), this.blazes[0].getY() + 1.5, this.blazes[0].getZ()]; + this.blazes.forEach((blaze, i) => { + if (i < 3 && i !== 0) { + renderUtils.drawLineWithDepth(lastLoc[0], lastLoc[1], lastLoc[2], blaze.getX(), blaze.getY() + 1.5, blaze.getZ(), i === 1 ? 0 : 255, i === 1 ? 255 : 0, 0, 3 / i); + lastLoc = [blaze.getX(), blaze.getY() + 1.5, blaze.getZ()]; + } + }); + } } - } - renderEntity(entity, position, ticks, event) { + renderEntity(entity, position, ticks, event) { if (this.lividFindNametags.getValue()) { if (this.lividData.correctLividEntity) { if (entity.getName().includes("Livid") && entity.getName().includes("❤") && entity.getUUID() !== this.lividData.correctLividEntity.getUUID()) { @@ -234,353 +379,379 @@ class DungeonSolvers extends Feature { } } } - } - - renderHud() { - if(this.bearSpawning && this.bearSpawning > 0){ - this.spiritBearSpawnElement.setText("&dBear spawned in: &c" + (Math.max(0,this.bearSpawning-Date.now())/1000).toFixed(2) + "s") - }else{ - this.spiritBearSpawnElement.setText("") } - for (let element of this.hudElements) { - element.render(); - } - } - - onWorldLoad() { - this.lividData.correctLividColor = undefined; - this.lividData.correctLividColorHP = undefined; - this.lividData.sayLividColors = []; - this.lividData.sayLividColors2 = []; - this.lividData.correctLividEntity = undefined; - this.lividHpElement && this.lividHpElement.setText(""); - - this.startSpawningTime = 0; - this.spawnIdThing = 0; - this.eMovingThing = {}; - this.bloodX = -1; - this.bloodY = -1; - this.blazeX = -1; - this.blazeY = -1; - this.skulls = []; - this.arrows = [] - this.blazes = [] - World.getAllEntitiesOfType(net.minecraft.entity.item.EntityArmorStand).forEach((e) => { - if (e.getEntity()[m.getEquipmentInSlot](4) && e.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { - this.addSkull(e); + renderHud() { + if (this.bearSpawning && this.bearSpawning > 0) { + this.spiritBearSpawnElement.setText("&dBear spawned in: &c" + (Math.max(0, this.bearSpawning - Date.now()) / 1000).toFixed(2) + "s"); + } else { + this.spiritBearSpawnElement.setText(""); } - }); - World.getAllEntitiesOfType(EntityBlaze).forEach((e) => { - this.addBlaze(e) - }); - // World.getAllEntitiesOfType(EntityArrow).forEach((e) => { - // this.arrows.push(e) - // }); - } - - step2() { - if (this.bloodCampAssist.getValue()) { - this.skulls.forEach((skull) => { - let skullE = skull.getEntity(); - // renderUtils.drawBoxAtEntity(skull, 255, 0, 0, 0.5, 0.5, ticks) - - let xSpeed = skullE[f.posX.Entity] - skullE[f.lastTickPosX]; - let ySpeed = skullE[f.posY.Entity] - skullE[f.lastTickPosY]; - let zSpeed = skullE[f.posZ.Entity] - skullE[f.lastTickPosZ]; - - if (this.eMovingThing[skull.getUUID().toString()] && Date.now() - this.eMovingThing[skull.getUUID().toString()].startMovingTime > 5000) { - this.eMovingThing[skull.getUUID().toString()].logged = true; - this.spawnIdThing++; - - delete this.eMovingThing[skull.getUUID().toString()]; - this.skulls = this.skulls.filter((e) => { - if (e.getUUID().toString() === skull.getUUID().toString()) { - return false; - } - return true; - }); - return; - } - - if (xSpeed !== 0 || ySpeed !== 0) { - if (!this.eMovingThing[skull.getUUID().toString()]) this.eMovingThing[skull.getUUID().toString()] = { startMovingTime: Date.now(), startX: skullE[f.posX.Entity], startY: skullE[f.posY.Entity], startZ: skullE[f.posZ.Entity] }; - - if (this.eMovingThing[skull.getUUID().toString()].lastX !== skullE[f.posX.Entity] || this.eMovingThing[skull.getUUID().toString()].lastY !== skullE[f.posY.Entity]) { - this.eMovingThing[skull.getUUID().toString()].timeTook = Date.now() - this.eMovingThing[skull.getUUID().toString()].startMovingTime; - } else if (!this.eMovingThing[skull.getUUID().toString()].logged && (skullE[f.isDead] || !skullE[m.getEquipmentInSlot](4) || !skullE[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName()))) { - this.eMovingThing[skull.getUUID().toString()].logged = true; - this.spawnIdThing++; - - delete this.eMovingThing[skull.getUUID().toString()]; - this.skulls = this.skulls.filter((e) => { - if (e.getUUID().toString() === skull.getUUID().toString()) { - return false; - } - return true; - }); - return; - } - - this.eMovingThing[skull.getUUID().toString()].lastX = skullE[f.posX.Entity]; - this.eMovingThing[skull.getUUID().toString()].lastY = skullE[f.posY.Entity]; - - if (!this.startSpawningTime) this.startSpawningTime = Date.now(); - } - - if (this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook) { - let startPoint = [skullE[f.posX.Entity], skullE[f.posY.Entity], skullE[f.posZ.Entity]]; - - let xSpeed2 = (startPoint[0] - this.eMovingThing[skull.getUUID().toString()].startX) / this.eMovingThing[skull.getUUID().toString()].timeTook; - let ySpeed2 = (startPoint[1] - this.eMovingThing[skull.getUUID().toString()].startY) / this.eMovingThing[skull.getUUID().toString()].timeTook; - let zSpeed2 = (startPoint[2] - this.eMovingThing[skull.getUUID().toString()].startZ) / this.eMovingThing[skull.getUUID().toString()].timeTook; - - let time = (this.spawnIdThing >= 4 ? 2900 : 4875) - this.eMovingThing[skull.getUUID().toString()].timeTook; - let endPoint = [startPoint[0] + xSpeed2 * time, startPoint[1] + ySpeed2 * time, startPoint[2] + zSpeed2 * time]; - - this.eMovingThing[skull.getUUID().toString()].endPointLast = this.eMovingThing[skull.getUUID().toString()].endPoint; - this.eMovingThing[skull.getUUID().toString()].endPoint = endPoint; - this.eMovingThing[skull.getUUID().toString()].endPointUpdated = Date.now(); - - // if(this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook){ - // Tessellator.drawString((time/1000).toFixed(3)+"s", endPoint[0], endPoint[1]+2, endPoint[2]) - // } - } - }); - } - - if(this.blazeX !== -1){ - this.blazes = this.blazes.filter(e=>!e.getEntity()[f.isDead]) - - this.blazes.sort((a, b)=>a.getEntity().func_110143_aJ()-b.getEntity().func_110143_aJ()) - if(World.getBlockAt(this.blazeX+17-43, 18, this.blazeY+16-43).getType().getID() === 9){ - this.blazes = this.blazes.reverse() + + for (let element of this.hudElements) { + element.render(); } } - // this.arrows = this.arrows.filter(e=>{ - // let x = e.getX() - // let y = e.getY() - // let z = e.getZ() + onWorldLoad() { + this.goneInBonus = false; + this.bloodOpenedBonus = false; + this.lividData.correctLividColor = undefined; + this.lividData.correctLividColorHP = undefined; + this.lividData.sayLividColors = []; + this.lividData.sayLividColors2 = []; + this.lividData.correctLividEntity = undefined; + this.lividHpElement && this.lividHpElement.setText(""); + + this.startSpawningTime = 0; + this.spawnIdThing = 0; + this.eMovingThing = {}; + this.bloodX = -1; + this.bloodY = -1; + this.blazeX = -1; + this.blazeY = -1; + this.skulls = []; + this.arrows = []; + this.blazes = []; + World.getAllEntitiesOfType(net.minecraft.entity.item.EntityArmorStand).forEach((e) => { + if (e.getEntity()[m.getEquipmentInSlot](4) && e.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { + this.addSkull(e); + } + }); + World.getAllEntitiesOfType(EntityBlaze).forEach((e) => { + this.addBlaze(e); + }); + // World.getAllEntitiesOfType(EntityArrow).forEach((e) => { + // this.arrows.push(e) + // }); + } + + step2() { + if (this.scoreCalculation.getValue()) this.calculateDungeonScore(); + if (this.bloodCampAssist.getValue()) { + this.skulls.forEach((skull) => { + let skullE = skull.getEntity(); + // renderUtils.drawBoxAtEntity(skull, 255, 0, 0, 0.5, 0.5, ticks) + + let xSpeed = skullE[f.posX.Entity] - skullE[f.lastTickPosX]; + let ySpeed = skullE[f.posY.Entity] - skullE[f.lastTickPosY]; + let zSpeed = skullE[f.posZ.Entity] - skullE[f.lastTickPosZ]; + + if (this.eMovingThing[skull.getUUID().toString()] && Date.now() - this.eMovingThing[skull.getUUID().toString()].startMovingTime > 5000) { + this.eMovingThing[skull.getUUID().toString()].logged = true; + this.spawnIdThing++; + + delete this.eMovingThing[skull.getUUID().toString()]; + this.skulls = this.skulls.filter((e) => { + if (e.getUUID().toString() === skull.getUUID().toString()) { + return false; + } + return true; + }); + return; + } + + if (xSpeed !== 0 || ySpeed !== 0) { + if (!this.eMovingThing[skull.getUUID().toString()]) this.eMovingThing[skull.getUUID().toString()] = { startMovingTime: Date.now(), startX: skullE[f.posX.Entity], startY: skullE[f.posY.Entity], startZ: skullE[f.posZ.Entity] }; + + if (this.eMovingThing[skull.getUUID().toString()].lastX !== skullE[f.posX.Entity] || this.eMovingThing[skull.getUUID().toString()].lastY !== skullE[f.posY.Entity]) { + this.eMovingThing[skull.getUUID().toString()].timeTook = Date.now() - this.eMovingThing[skull.getUUID().toString()].startMovingTime; + } else if (!this.eMovingThing[skull.getUUID().toString()].logged && (skullE[f.isDead] || !skullE[m.getEquipmentInSlot](4) || !skullE[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName()))) { + this.eMovingThing[skull.getUUID().toString()].logged = true; + this.spawnIdThing++; + + delete this.eMovingThing[skull.getUUID().toString()]; + this.skulls = this.skulls.filter((e) => { + if (e.getUUID().toString() === skull.getUUID().toString()) { + return false; + } + return true; + }); + return; + } + + this.eMovingThing[skull.getUUID().toString()].lastX = skullE[f.posX.Entity]; + this.eMovingThing[skull.getUUID().toString()].lastY = skullE[f.posY.Entity]; - // let mX = e.getMotionX() - // let mY = e.getMotionY() - // let mZ = e.getMotionZ() + if (!this.startSpawningTime) this.startSpawningTime = Date.now(); + } + + if (this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook) { + let startPoint = [skullE[f.posX.Entity], skullE[f.posY.Entity], skullE[f.posZ.Entity]]; + + let xSpeed2 = (startPoint[0] - this.eMovingThing[skull.getUUID().toString()].startX) / this.eMovingThing[skull.getUUID().toString()].timeTook; + let ySpeed2 = (startPoint[1] - this.eMovingThing[skull.getUUID().toString()].startY) / this.eMovingThing[skull.getUUID().toString()].timeTook; + let zSpeed2 = (startPoint[2] - this.eMovingThing[skull.getUUID().toString()].startZ) / this.eMovingThing[skull.getUUID().toString()].timeTook; + + let time = (this.spawnIdThing >= 4 ? 2900 : 4875) - this.eMovingThing[skull.getUUID().toString()].timeTook; + let endPoint = [startPoint[0] + xSpeed2 * time, startPoint[1] + ySpeed2 * time, startPoint[2] + zSpeed2 * time]; + + this.eMovingThing[skull.getUUID().toString()].endPointLast = this.eMovingThing[skull.getUUID().toString()].endPoint; + this.eMovingThing[skull.getUUID().toString()].endPoint = endPoint; + this.eMovingThing[skull.getUUID().toString()].endPointUpdated = Date.now(); + + // if(this.eMovingThing[skull.getUUID().toString()] && this.eMovingThing[skull.getUUID().toString()].timeTook){ + // Tessellator.drawString((time/1000).toFixed(3)+"s", endPoint[0], endPoint[1]+2, endPoint[2]) + // } + } + }); + } + + if (this.blazeX !== -1) { + this.blazes = this.blazes.filter((e) => !e.getEntity()[f.isDead]); - // for(let i = 0;i<100;i++){ - // x+=mX - // y+=mY - // z+=mZ + this.blazes.sort((a, b) => a.getEntity().func_110143_aJ() - b.getEntity().func_110143_aJ()); + if ( + World.getBlockAt(this.blazeX + 17 - 43, 18, this.blazeY + 16 - 43) + .getType() + .getID() === 9 + ) { + this.blazes = this.blazes.reverse(); + } + } + + // this.arrows = this.arrows.filter(e=>{ + // let x = e.getX() + // let y = e.getY() + // let z = e.getZ() + + // let mX = e.getMotionX() + // let mY = e.getMotionY() + // let mZ = e.getMotionZ() + + // for(let i = 0;i<100;i++){ + // x+=mX + // y+=mY + // z+=mZ - // mX*=0.99 - // mY*=0.99 - // mZ*=0.99 + // mX*=0.99 + // mY*=0.99 + // mZ*=0.99 - // mY-=0.05 + // mY-=0.05 - // this.blazes = this.blazes.filter(e1=>{ - // let boundingBox = e1.getEntity().func_174813_aQ() + // this.blazes = this.blazes.filter(e1=>{ + // let boundingBox = e1.getEntity().func_174813_aQ() - // if(boundingBox.intersectsWith(new AxisAlignedBB(x-e.getEntity().field_70130_N/2,y,z-e.getEntity().field_70130_N/2,x+e.getEntity().field_70130_N/2,y+e.getEntity().field_70131_O,z+e.getEntity().field_70130_N/2))){ - // return false - // } - // return true - // }) - - // if(World.getBlockAt(x, y, z).getType().getID() !== 0){ - // break; - // } - // } + // if(boundingBox.intersectsWith(new AxisAlignedBB(x-e.getEntity().field_70130_N/2,y,z-e.getEntity().field_70130_N/2,x+e.getEntity().field_70130_N/2,y+e.getEntity().field_70131_O,z+e.getEntity().field_70130_N/2))){ + // return false + // } + // return true + // }) - // return !e.getEntity()[f.isDead] - // }) + // if(World.getBlockAt(x, y, z).getType().getID() !== 0){ + // break; + // } + // } - if(this.spiritBearSpawnTimer.getValue() && (this.FeatureManager.features["dataLoader"].class.dungeonFloor === "F4" || this.FeatureManager.features["dataLoader"].class.dungeonFloor === "M4")){ - let id = World.getBlockAt(7, 77, 34).type.getID() + // return !e.getEntity()[f.isDead] + // }) - if((!this.bearSpawning || (this.bearSpawning<0 && this.bearSpawning>-Date.now()+500)) && id === 169){ - this.bearSpawning = Date.now()+3500 + if (this.spiritBearSpawnTimer.getValue() && (this.FeatureManager.features["dataLoader"].class.dungeonFloor === "F4" || this.FeatureManager.features["dataLoader"].class.dungeonFloor === "M4")) { + let id = World.getBlockAt(7, 77, 34).type.getID(); + + if ((!this.bearSpawning || (this.bearSpawning < 0 && this.bearSpawning > -Date.now() + 500)) && id === 169) { + this.bearSpawning = Date.now() + 3500; + } } } - } - - addSkull(skull) { - if (this.bloodX !== -1) { - let xA = (skull.getX()+8) - ((skull.getX()+8) % 32); - let yA = (skull.getZ()+8) - ((skull.getZ()+8) % 32); - - if (xA !== this.bloodX || yA !== this.bloodY) return; - } else { - if (skull.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().trim() === getPlayerHeadName().replace("%s",Player.getName())) { - this.bloodX = (skull.getX()+8) - ((skull.getX()+8) % 32); - this.bloodY = (skull.getZ()+8) - ((skull.getZ()+8) % 32); - this.skulls = []; - World.getAllEntitiesOfType(net.minecraft.entity.item.EntityArmorStand).forEach((e) => { - if (e.getEntity()[m.getEquipmentInSlot](4) && e.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { - this.addSkull(e); - } - }); - } - return; - } - this.skulls.push(skull); - } - - addBlaze(blaze){ - if(!this.FeatureManager.features["dataLoader"].class.dungeonFloor) return - if(this.blazeX === -1){ - this.blazes.push(blaze) - let locs = {} - - this.blazes.forEach(b=>{ - if(!locs[((b.getX()+8)-((b.getX()+8)%32))+"_"+((b.getZ()+8)-((b.getZ()+8)%32))])locs[((b.getX()+8)-((b.getX()+8)%32))+"_"+((b.getZ()+8)-((b.getZ()+8)%32))] = 0 - locs[((b.getX()+8)-((b.getX()+8)%32))+"_"+((b.getZ()+8)-((b.getZ()+8)%32))]++ - }) - - Object.keys(locs).forEach(k=>{ - if(locs[k] === 4){ - [this.blazeX, this.blazeY] = k.split("_").map(a=>~~a) + + addSkull(skull) { + if (this.bloodX !== -1) { + let xA = skull.getX() + 8 - ((skull.getX() + 8) % 32); + let yA = skull.getZ() + 8 - ((skull.getZ() + 8) % 32); + + if (xA !== this.bloodX || yA !== this.bloodY) return; + } else { + if (skull.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().trim() === getPlayerHeadName().replace("%s", Player.getName())) { + this.bloodX = skull.getX() + 8 - ((skull.getX() + 8) % 32); + this.bloodY = skull.getZ() + 8 - ((skull.getZ() + 8) % 32); + this.skulls = []; + World.getAllEntitiesOfType(net.minecraft.entity.item.EntityArmorStand).forEach((e) => { + if (e.getEntity()[m.getEquipmentInSlot](4) && e.getEntity()[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { + this.addSkull(e); + } + }); + } + return; + } + this.skulls.push(skull); + } + + addBlaze(blaze) { + if (!this.FeatureManager.features["dataLoader"].class.dungeonFloor) return; + if (this.blazeX === -1) { + this.blazes.push(blaze); + let locs = {}; + + this.blazes.forEach((b) => { + if (!locs[b.getX() + 8 - ((b.getX() + 8) % 32) + "_" + (b.getZ() + 8 - ((b.getZ() + 8) % 32))]) locs[b.getX() + 8 - ((b.getX() + 8) % 32) + "_" + (b.getZ() + 8 - ((b.getZ() + 8) % 32))] = 0; + locs[b.getX() + 8 - ((b.getX() + 8) % 32) + "_" + (b.getZ() + 8 - ((b.getZ() + 8) % 32))]++; + }); + + Object.keys(locs).forEach((k) => { + if (locs[k] === 4) { + [this.blazeX, this.blazeY] = k.split("_").map((a) => ~~a); } - }) + }); - if(this.blazeX !== -1){ - this.blazes = [] - World.getAllEntitiesOfType(EntityBlaze).forEach((e)=>{ - if((e.getX()+8)-(e.getX()+8)%32 === this.blazeX && (e.getZ()+8)-(e.getZ()+8)%32 === this.blazeY){ - this.blazes.push(e) + if (this.blazeX !== -1) { + this.blazes = []; + World.getAllEntitiesOfType(EntityBlaze).forEach((e) => { + if (e.getX() + 8 - ((e.getX() + 8) % 32) === this.blazeX && e.getZ() + 8 - ((e.getZ() + 8) % 32) === this.blazeY) { + this.blazes.push(e); } - }) + }); } - }else{ - if((blaze.getX()+8)-(blaze.getX()+8)%32 === this.blazeX && (blaze.getZ()+8)-(blaze.getZ()+8)%32 === this.blazeY){ - this.blazes.push(blaze) - this.blazes.sort((a, b)=>a.getEntity().func_110143_aJ()-b.getEntity().func_110143_aJ()) - if(World.getBlockAt(this.blazeX+17-43, 18, this.blazeY+16-43).getType().getID() === 9){ - this.blazes = this.blazes.reverse() + } else { + if (blaze.getX() + 8 - ((blaze.getX() + 8) % 32) === this.blazeX && blaze.getZ() + 8 - ((blaze.getZ() + 8) % 32) === this.blazeY) { + this.blazes.push(blaze); + this.blazes.sort((a, b) => a.getEntity().func_110143_aJ() - b.getEntity().func_110143_aJ()); + if ( + World.getBlockAt(this.blazeX + 17 - 43, 18, this.blazeY + 16 - 43) + .getType() + .getID() === 9 + ) { + this.blazes = this.blazes.reverse(); } } } } - step() { - //2fps - if (this.lividFindEnabled.getValue() && (this.FeatureManager.features["dataLoader"].class.dungeonFloor === "F5" || this.FeatureManager.features["dataLoader"].class.dungeonFloor === "M5")) { - let type = World.getBlockAt(3, 108, 30).getMetadata(); - - let typeReplace = { - 0: "Vendetta", - 2: "Crossed", - 4: "Arcade", - 5: "Smile", - 6: "Crossed", - 7: "Doctor", - 8: "Doctor", - 10: "Purple", - 11: "Scream", - 13: "Frog", - 14: "Hockey", - }; - - World.getAllEntities().forEach((entity) => { - let entityName = entity.getName(); - - if (entityName.includes("Livid") && entityName.includes("❤")) { - // ChatLib.chat("D: " + entityName.substr(1, 1) + " asd " + this.lividData.lividColor[typeReplace[type]].split("").pop()) - if (entityName.substr(1, 1) === this.lividData.lividColor[typeReplace[type]].split("").pop()) { - this.lividHpElement.setText(entityName); - this.lividData.correctLividEntity = entity; - } - } - }); - } - - if (this.lividData.correctLividEntity) { - if (!this.renderEntityEvent) { - this.renderEntityEvent = this.registerEvent("renderEntity", this.renderEntity); - } - } else { - if (this.renderEntityEvent) { - this.unregisterEvent(this.renderEntityEvent); - this.renderEntityEvent = undefined; - } - } - - this.spiritBowPickUps = this.spiritBowPickUps.filter((pickUp) => Date.now() - pickUp < 20000); - if (this.spiritBowPickUps[0]) { - this.spiritBowDestroyElement.setText("&dBow Destroyed in: &c" + Math.round((this.spiritBowPickUps[0] + 20000 - Date.now()) / 1000) + "s"); - } else { - this.spiritBowDestroyElement.setText(""); - } - // this.spiritBowPickUps - if (this.bloodCampAssist.getValue()) { - this.todoE.forEach((e) => { - let en = new Entity(e); - // console.log(en.getName()) - if (en.getName().trim() === getArmorStandName() && e[m.getEquipmentInSlot](4) && e[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { - this.addSkull(en); - } - }); - - this.todoE = []; - - if (Date.now() - this.lastPingCheck > 60000 * 30 || (Date.now() - this.lastPingCheck > 60000 && this.lastPings.includes(undefined)) && this.bloodX!== -1) { - this.lastPingCheck = Date.now(); - ChatLib.command("whereami"); - this.checkingPing = true; - } - } - - let averageExp = this.lastDungExps.reduce((a, b) => a + b, 0) / this.lastDungExps.length; - let averageLength = (this.lastDungFinishes[this.lastDungFinishes.length - 1] - this.lastDungFinishes[0]) / (this.lastDungFinishes.length - 1); - let runsperHour = (60000 * 60) / averageLength; - let expPerHour = averageExp * runsperHour; - - if (Date.now() - this.lastDungFinishes[this.lastDungFinishes.length - 1] < 60000 * 5 || this.FeatureManager.features["dataLoader"].class.dungeonFloor) { - if (this.lastDungFinishes.length > 1) { - this.runSpeedRatesElement.setText("&6Run speed&7> &f" + Math.floor(averageLength / 60000) + ":" + ((Math.floor(averageLength / 1000) % 60 < 10 ? "0" : "") + (Math.floor(averageLength / 1000) % 60)) + "\n&6Exp/hour&7> &f" + numberWithCommas(Math.round(expPerHour)) + "\n&6Runs/hour&7> &f" + Math.floor(runsperHour)); - } else { - this.runSpeedRatesElement.setText("&6Run speed&7> &fLoading...\n&6Exp/hour&7> &fLoading...\n&6Runs/hour&7> &fLoading..."); - } - } else { - this.runSpeedRatesElement.setText(""); - } - } - - initVariables() { - this.lividFindEnabled = undefined; - this.lividData = undefined; - this.hudElements = []; - } - - onDisable() { - this.initVariables(); - } + step() { + this.failedPuzzleCount = 0; + this.totalPuzzleCount = 0; + this.completedPuzzleCount = 0; + TabList.getNames().forEach((n) => { + let name = ChatLib.removeFormatting(n).trim().split(" "); + let end = name.pop(); + // console.log(end) Water Board: [✔] + if (end !== "[✦]" && end !== "[✔]" && end !== "[✖]") { + end = name.pop(); + // console.log(end) Water Board: [✔] + if (end !== "[✦]" && end !== "[✔]" && end !== "[✖]") return; + } + this.totalPuzzleCount++; + if (end === "[✖]") this.failedPuzzleCount++; + if (end === "[✔]") this.completedPuzzleCount++; + }); + + if (this.lividFindEnabled.getValue() && (this.FeatureManager.features["dataLoader"].class.dungeonFloor === "F5" || this.FeatureManager.features["dataLoader"].class.dungeonFloor === "M5")) { + let type = World.getBlockAt(3, 108, 30).getMetadata(); + + let typeReplace = { + 0: "Vendetta", + 2: "Crossed", + 4: "Arcade", + 5: "Smile", + 6: "Crossed", + 7: "Doctor", + 8: "Doctor", + 10: "Purple", + 11: "Scream", + 13: "Frog", + 14: "Hockey", + }; + + World.getAllEntities().forEach((entity) => { + let entityName = entity.getName(); + + if (entityName.includes("Livid") && entityName.includes("❤")) { + // ChatLib.chat("D: " + entityName.substr(1, 1) + " asd " + this.lividData.lividColor[typeReplace[type]].split("").pop()) + if (entityName.substr(1, 1) === this.lividData.lividColor[typeReplace[type]].split("").pop()) { + this.lividHpElement.setText(entityName); + this.lividData.correctLividEntity = entity; + } + } + }); + } + + if (this.lividData.correctLividEntity) { + if (!this.renderEntityEvent) { + this.renderEntityEvent = this.registerEvent("renderEntity", this.renderEntity); + } + } else { + if (this.renderEntityEvent) { + this.unregisterEvent(this.renderEntityEvent); + this.renderEntityEvent = undefined; + } + } + + this.spiritBowPickUps = this.spiritBowPickUps.filter((pickUp) => Date.now() - pickUp < 20000); + if (this.spiritBowPickUps[0]) { + this.spiritBowDestroyElement.setText("&dBow Destroyed in: &c" + Math.round((this.spiritBowPickUps[0] + 20000 - Date.now()) / 1000) + "s"); + } else { + this.spiritBowDestroyElement.setText(""); + } + // this.spiritBowPickUps + if (this.bloodCampAssist.getValue()) { + this.todoE.forEach((e) => { + let en = new Entity(e); + // console.log(en.getName()) + if (en.getName().trim() === getArmorStandName() && e[m.getEquipmentInSlot](4) && e[m.getEquipmentInSlot](4)[m.getDisplayName.ItemStack]().endsWith(getSkullName())) { + this.addSkull(en); + } + }); + + this.todoE = []; + + if (Date.now() - this.lastPingCheck > 60000 * 30 || (Date.now() - this.lastPingCheck > 60000 && this.lastPings.includes(undefined) && this.bloodX !== -1)) { + this.lastPingCheck = Date.now(); + ChatLib.command("whereami"); + this.checkingPing = true; + } + } + + let averageExp = this.lastDungExps.reduce((a, b) => a + b, 0) / this.lastDungExps.length; + let averageLength = (this.lastDungFinishes[this.lastDungFinishes.length - 1] - this.lastDungFinishes[0]) / (this.lastDungFinishes.length - 1); + let runsperHour = (60000 * 60) / averageLength; + let expPerHour = averageExp * runsperHour; + + if (Date.now() - this.lastDungFinishes[this.lastDungFinishes.length - 1] < 60000 * 5 || this.FeatureManager.features["dataLoader"].class.dungeonFloor) { + if (this.lastDungFinishes.length > 1) { + this.runSpeedRatesElement.setText("&6Run speed&7> &f" + Math.floor(averageLength / 60000) + ":" + ((Math.floor(averageLength / 1000) % 60 < 10 ? "0" : "") + (Math.floor(averageLength / 1000) % 60)) + "\n&6Exp/hour&7> &f" + numberWithCommas(Math.round(expPerHour)) + "\n&6Runs/hour&7> &f" + Math.floor(runsperHour)); + } else { + this.runSpeedRatesElement.setText("&6Run speed&7> &fLoading...\n&6Exp/hour&7> &fLoading...\n&6Runs/hour&7> &fLoading..."); + } + } else { + this.runSpeedRatesElement.setText(""); + } + } + + initVariables() { + this.lividFindEnabled = undefined; + this.lividData = undefined; + this.hudElements = []; + } + + onDisable() { + this.initVariables(); + } } module.exports = { - class: new DungeonSolvers(), + class: new DungeonSolvers(), }; - -function getSkullName(){ - if(translate){ - return translate.func_74805_b("item.skull.char.name") +function getSkullName() { + if (translate) { + return translate.func_74805_b("item.skull.char.name"); } - return "Head" + return "Head"; } -function getPlayerHeadName(){ - if(translate){ - return translate.func_74805_b("item.skull.player.name") +function getPlayerHeadName() { + if (translate) { + return translate.func_74805_b("item.skull.player.name"); } - return "%s's Head" + return "%s's Head"; } -function getArmorStandName(){ - if(translate){ - return translate.func_74805_b("item.armorStand.name") +function getArmorStandName() { + if (translate) { + return translate.func_74805_b("item.armorStand.name"); } - return "Armor Stand" -}
\ No newline at end of file + return "Armor Stand"; +} diff --git a/features/globalSettings/firstLoadPage.js b/features/globalSettings/firstLoadPage.js index 429c867..d38f927 100644 --- a/features/globalSettings/firstLoadPage.js +++ b/features/globalSettings/firstLoadPage.js @@ -17,6 +17,7 @@ class FirstLoadPage extends SoopyGuiElement { backButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ this.guiPage.prevPage() + this.guiPage.closeSidebarPage() })) this.addChild(backButton) @@ -26,6 +27,7 @@ class FirstLoadPage extends SoopyGuiElement { nextButton.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ this.guiPage.nextPage() + this.guiPage.closeSidebarPage() })) this.addChild(nextButton) diff --git a/features/globalSettings/index.js b/features/globalSettings/index.js index 14f51bd..604f887 100644 --- a/features/globalSettings/index.js +++ b/features/globalSettings/index.js @@ -40,9 +40,8 @@ class Hud extends Feature { this.reportErrorsSetting = new ToggleSetting("Send module errors to soopy server", "This will allow me to more effectivly fix them", false, "privacy_send_errors", this) - this.sendChatSetting = new ToggleSetting("Send (hashed) chat messages to soopy server", "This will allow the hide spam feature to detect messages that are spam", false, "privacy_send_chat", this) - - this.privacySettings = [this.reportErrorsSetting, this.sendChatSetting] + + this.privacySettings = [this.reportErrorsSetting] this.firstLoadPageData = JSON.parse(FileLib.read("soopyAddonsData", "soopyv2firstloaddata.json") || "{}") || {} diff --git a/features/hud/HudTextElement.js b/features/hud/HudTextElement.js index be9e4ee..d2a2c91 100644 --- a/features/hud/HudTextElement.js +++ b/features/hud/HudTextElement.js @@ -1,5 +1,5 @@ -class HudTextElement{ - constructor(){ +class HudTextElement { + constructor() { this.text = "" this.toggleSetting = undefined @@ -14,104 +14,123 @@ class HudTextElement{ this.editBaseHeight = undefined this.tempDisableTime = 0 + + this.renderTextCache = [[""], [""]] + this.textChanged = false } - setBaseEditWidth(width){ + setBaseEditWidth(width) { this.editBaseWidth = width return this } - setBaseEditHeight(height){ + setBaseEditHeight(height) { this.editBaseHeight = height return this } - setText(text){ + setText(text = "") { this.text = text - - if(this.locationSetting && this.locationSetting.shadowType === 2){ + + if (this.locationSetting && this.locationSetting.shadowType === 2) { this.blackText = "&0" + ChatLib.removeFormatting(text) } + + this.renderTextCache = [this.text.split("\n"), this.blackText.split("\n")] return this } - setToggleSetting(setting){ + setToggleSetting(setting) { this.toggleSetting = setting return this } - setLocationSetting(setting){ + setLocationSetting(setting) { this.locationSetting = setting setting.setParent(this) - if(this.locationSetting.shadowType === 2){ + if (this.locationSetting.shadowType === 2) { this.blackText = "&0" + ChatLib.removeFormatting(text) } return this } - isEnabled(){ - if(!this.toggleSetting) return true + isEnabled() { + if (!this.toggleSetting) return true return this.locationSetting && this.toggleSetting.getValue() } - render(){ - if(this.toggleSetting && !this.toggleSetting.getValue() || !this.locationSetting) return - if(Date.now()-this.tempDisableTime < 100) return + render() { + if (this.toggleSetting && !this.toggleSetting.getValue() || !this.locationSetting) return + if (Date.now() - this.tempDisableTime < 100) return this.renderRaw() } - getWidth(locationBox=false){ - if(locationBox && this.editBaseWidth) return this.editBaseWidth - return Math.max(...(this.getText()[0].map(a=>Renderer.getStringWidth(ChatLib.removeFormatting(a))))) + getWidth(locationBox = false) { + if (locationBox && this.editBaseWidth) return this.editBaseWidth + return Math.max(...(this.getText()[0].map(a => Renderer.getStringWidth(ChatLib.removeFormatting(a))))) } - getHeight(locationBox=false){ - if(locationBox && this.editBaseHeight) return this.editBaseHeight - return 9*this.getText()[0].length + getHeight(locationBox = false) { + if (locationBox && this.editBaseHeight) return this.editBaseHeight + return 9 * this.getText()[0].length } - getText(){ - let text = this.text - let blackText = this.blackText - if(Date.now()-this.editTempTimeV < 100){ - if(this.editTempTextV){ + getText() { + if (Date.now() - this.editTempTimeV < 100) { + let text = this.text + if (this.editTempTextV) { text = this.editTempTextV - blackText = "&0" + ChatLib.removeFormatting(text) } - - if(ChatLib.removeFormatting(text) === ""){ + + if (ChatLib.removeFormatting(text) === "") { text = "&0Empty string" + } + + return text.split("\n") + } + return this.renderTextCache + } + + getBlackText() { + if (Date.now() - this.editTempTimeV < 100) { + let text = this.text + let blackText = this.blackText + if (this.editTempTextV) { + text = this.editTempTextV + blackText = "&0" + ChatLib.removeFormatting(text) + } + + if (ChatLib.removeFormatting(text) === "") { blackText = "&0Empty string" } + + return blackText.split("\n") } - return [text.split("\n"), blackText.split("\n")] + return this.renderBlackTextCache } - renderRaw(){ - try{ - let [text, blackText] = this.getText() - - text.forEach((line, i)=>{ - Renderer.scale(this.locationSetting.scale, this.locationSetting.scale) - switch(this.locationSetting.shadowType){ - case 0: - Renderer.drawString(line, this.locationSetting.x/this.locationSetting.scale, this.locationSetting.y/this.locationSetting.scale +9*i) + renderRaw() { + let text = this.getText() + + text.forEach((line, i) => { + Renderer.scale(this.locationSetting.scale, this.locationSetting.scale) + switch (this.locationSetting.shadowType) { + case 0: + Renderer.drawString(line, this.locationSetting.x / this.locationSetting.scale, this.locationSetting.y / this.locationSetting.scale + 9 * i) break; - case 1: - Renderer.drawStringWithShadow(line, this.locationSetting.x/this.locationSetting.scale, this.locationSetting.y/this.locationSetting.scale +9*i) + case 1: + Renderer.drawStringWithShadow(line, this.locationSetting.x / this.locationSetting.scale, this.locationSetting.y / this.locationSetting.scale + 9 * i) break; - case 2: - Renderer.drawString(blackText[i], (this.locationSetting.x+1)/this.locationSetting.scale, this.locationSetting.y/this.locationSetting.scale +9*i) - Renderer.drawString(blackText[i], (this.locationSetting.x-1)/this.locationSetting.scale, this.locationSetting.y/this.locationSetting.scale +9*i) - Renderer.drawString(blackText[i], this.locationSetting.x/this.locationSetting.scale, (this.locationSetting.y+1)/this.locationSetting.scale +9*i) - Renderer.drawString(blackText[i], this.locationSetting.x/this.locationSetting.scale, (this.locationSetting.y-1)/this.locationSetting.scale +9*i) - - Renderer.drawString(line, this.locationSetting.x/this.locationSetting.scale, this.locationSetting.y/this.locationSetting.scale +9*i) + case 2: + let blackText = this.getBlackText() + Renderer.drawString(blackText[i], (this.locationSetting.x + 1) / this.locationSetting.scale, this.locationSetting.y / this.locationSetting.scale + 9 * i) + Renderer.drawString(blackText[i], (this.locationSetting.x - 1) / this.locationSetting.scale, this.locationSetting.y / this.locationSetting.scale + 9 * i) + Renderer.drawString(blackText[i], this.locationSetting.x / this.locationSetting.scale, (this.locationSetting.y + 1) / this.locationSetting.scale + 9 * i) + Renderer.drawString(blackText[i], this.locationSetting.x / this.locationSetting.scale, (this.locationSetting.y - 1) / this.locationSetting.scale + 9 * i) + + Renderer.drawString(line, this.locationSetting.x / this.locationSetting.scale, this.locationSetting.y / this.locationSetting.scale + 9 * i) break; - } - }) - Renderer.scale(1, 1) - }catch(e){ //incase of wrong opengl context - } + } + }) } } diff --git a/features/hud/index.js b/features/hud/index.js index 823f489..27d12e5 100644 --- a/features/hud/index.js +++ b/features/hud/index.js @@ -19,8 +19,8 @@ class Hud extends Feature { super() } - initVariables(){ - + initVariables() { + this.hudElements = [] this.fpsElement = undefined @@ -30,21 +30,21 @@ class Hud extends Feature { this.fpsEnabledSetting = undefined this.cpsEnabledSetting = undefined this.soulflowEnabledSetting = undefined - this.soulflowShowWarningSetting=undefined - this.soulflowShowWhen0Setting=undefined - this.petEnabledSetting=undefined + this.soulflowShowWarningSetting = undefined + this.soulflowShowWhen0Setting = undefined + this.petEnabledSetting = undefined this.fpsFastSetting = undefined this.fpsLowSetting = undefined - this.cpsSeperate =undefined - this.cpsIncludeRight =undefined - + this.cpsSeperate = undefined + this.cpsIncludeRight = undefined + this.petLevels = undefined this.lastTickTime = undefined this.framesSince = undefined this.lastframe = undefined this.Instant = undefined - + this.lastFrameRates = undefined this.fps = undefined @@ -63,7 +63,7 @@ class Hud extends Feature { this.impactTest = undefined } - onEnable(){ + onEnable() { this.initVariables() this.numberUtils = require("../../utils/numberUtils.js") @@ -95,7 +95,7 @@ class Hud extends Feature { .requires(this.petEnabledSetting) .editTempText("&6Pet&7> &7[Lvl 100] &aEnderman")) this.hudElements.push(this.petElement) - + this.soulflowEnabledSetting = new ToggleSetting("Show Soulflow", "Whether the soulflow count is rendered onto the screen", true, "soulflow_enabled", this) this.soulflowShowWarningSetting = new ToggleSetting("Show no Talisman Warning", "Shows a warning if you dont have a soulflow talis in ur inv", true, "soulflow_notalis_warning", this).requires(this.soulflowEnabledSetting) this.soulflowShowWhen0Setting = new ToggleSetting("Show When 0 Soulflow", "If this is off it wont render when you have 0 soulflow", true, "soulflow_showwhen_0", this).requires(this.soulflowEnabledSetting) @@ -109,18 +109,18 @@ class Hud extends Feature { this.witherImpactCooldownSetting = new ToggleSetting("Show Wither Impact Cooldown", "This will render a small cooldown above your crosshair", true, "wither_impact_cooldown_enabled", this) this.guidedSheepCooldownSetting = new ToggleSetting("Show Guided Sheep / Explosive Shot Cooldown", "This will render a small cooldown below your crosshair", true, "guided_sheep_cooldown_enabled", this) - + this.showSpotifyPlaying = new ToggleSetting("Show Current Playing Spotify Song", "(WINDOWS + Spotify Desktop only)", false, "spotify_now_playing", this) this.spotifyElement = new HudTextElement() .setText("&6Spotify&7> ") - .setBaseEditWidth(Renderer.getStringWidth("Spotify> ")+150) + .setBaseEditWidth(Renderer.getStringWidth("Spotify> ") + 150) .setToggleSetting(this.showSpotifyPlaying) .setLocationSetting(new LocationSetting("Spotify Location", "Allows you to edit the location of the spotify text", "spotify_now_playing_location", this, [10, 80, 1, 1]) .requires(this.showSpotifyPlaying) .editTempText("&6Spotify&7> &cNot open")) this.spotifyElement2 = new HudTextElement().setToggleSetting(this.showSpotifyPlaying).setLocationSetting({ - setParent: ()=>{}, - x: this.spotifyElement.locationSetting.x+this.spotifyElement.getWidth(), + setParent: () => { }, + x: this.spotifyElement.locationSetting.x + this.spotifyElement.getWidth(), y: this.spotifyElement.locationSetting.y, scale: this.spotifyElement.locationSetting.scale, shadowType: this.spotifyElement.locationSetting.shadowType @@ -147,29 +147,29 @@ class Hud extends Feature { }) hudStatTypes.completions_enterance = "Enterance completions" - for(let i = 1;i<8;i++){ - hudStatTypes["completions_floor_"+i] = "Floor " + i + " completions" + for (let i = 1; i < 8; i++) { + hudStatTypes["completions_floor_" + i] = "Floor " + i + " completions" } - for(let i = 1;i<8;i++){ - hudStatTypes["completions_master_"+i] = "Master " + i + " completions" + for (let i = 1; i < 8; i++) { + hudStatTypes["completions_master_" + i] = "Master " + i + " completions" } - for(let i = 1;i<8;i++){ - hudStatTypes["completions_dungeon_"+i] = "Dungeon " + i + " completions" + for (let i = 1; i < 8; i++) { + hudStatTypes["completions_dungeon_" + i] = "Dungeon " + i + " completions" } this.hudStat = [] - for(let i = 0;i<5;i++){ + for (let i = 0; i < 5; i++) { this.hudStat[i] = {} - this.hudStat[i].enabled = new ToggleSetting("Hud Stat Slot #"+(i+1), "Allows you to render a custom stat on your hud", false, "hud_stat_"+i, this) - this.hudStat[i].type = new DropdownSetting("Hud Stat Slot #" + (i + 1) + " Type", "The type of stat to render", "weight" , "hud_stat_" + i + "_type", this, hudStatTypes) - this.hudStat[i].location = new LocationSetting("Hud Stat Slot #"+(i+1)+" Location", "Allows you to edit the location of the hud stat", "hud_stat_"+i+"_location", this, [10, 50+i*10, 1, 1]).editTempText("&6Hud Stat&7> &f12,345") + this.hudStat[i].enabled = new ToggleSetting("Hud Stat Slot #" + (i + 1), "Allows you to render a custom stat on your hud", false, "hud_stat_" + i, this) + this.hudStat[i].type = new DropdownSetting("Hud Stat Slot #" + (i + 1) + " Type", "The type of stat to render", "weight", "hud_stat_" + i + "_type", this, hudStatTypes) + this.hudStat[i].location = new LocationSetting("Hud Stat Slot #" + (i + 1) + " Location", "Allows you to edit the location of the hud stat", "hud_stat_" + i + "_location", this, [10, 50 + i * 10, 1, 1]).editTempText("&6Hud Stat&7> &f12,345") this.hudStat[i].textElement = new HudTextElement().setToggleSetting(this.hudStat[i].enabled).setLocationSetting(this.hudStat[i].location).setText("&6Hud Stat&7> &fLoading...") - this.hudStat[i].onlySb = new ToggleSetting("Hud Stat Slot #"+(i+1)+" Only SB", "Only render this stat when you are in skyblock", true, "hud_stat_"+i+"_only_sb", this).requires(this.hudStat[i].enabled) + this.hudStat[i].onlySb = new ToggleSetting("Hud Stat Slot #" + (i + 1) + " Only SB", "Only render this stat when you are in skyblock", true, "hud_stat_" + i + "_only_sb", this).requires(this.hudStat[i].enabled) this.hudStat[i].location.requires(this.hudStat[i].enabled) this.hudStat[i].type.requires(this.hudStat[i].enabled) - if(this.hudStat[i-1]){ - this.hudStat[i].enabled.requires(this.hudStat[i-1].enabled) + if (this.hudStat[i - 1]) { + this.hudStat[i].enabled.requires(this.hudStat[i - 1].enabled) } } @@ -201,8 +201,8 @@ class Hud extends Feature { this.lastStatData = undefined - this.lastFrameRates = [0,0,0,0,0,0,0,0,0,0] - this.lastFrameRatesS = [0,0,0,0,0,0,0,0,0,0] + this.lastFrameRates = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0] + this.lastFrameRatesS = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0] this.Instant = Java.type("java.time.Instant"); @@ -218,43 +218,43 @@ class Hud extends Feature { this.petLevels = {} this.petText = "&6Pet&7> &fLoading..." this.petElement.setText(this.petText) - this.registerChat("&cAutopet &eequipped your ${pet}&e! &a&lVIEW RULE&r", (pet)=>{ - this.petElement.setText("&6Pet&7> "+pet) - this.petText = "&6Pet&7> "+pet + this.registerChat("&cAutopet &eequipped your ${pet}&e! &a&lVIEW RULE&r", (pet) => { + this.petElement.setText("&6Pet&7> " + pet) + this.petText = "&6Pet&7> " + pet this.lastSwappedPet = Date.now() }) - this.registerChat("&r&aYou summoned your &r${pet}&r&a!&r", (pet)=>{ - this.petElement.setText("&6Pet&7> &7[Lvl " + (this.petLevels[pet.replace("&", "§")]||"??") +"] "+pet) - this.petText = "&6Pet&7> &7[Lvl " + (this.petLevels[pet.replace("&", "§")]||"??") +"] "+pet + this.registerChat("&r&aYou summoned your &r${pet}&r&a!&r", (pet) => { + this.petElement.setText("&6Pet&7> &7[Lvl " + (this.petLevels[pet.replace("&", "§")] || "??") + "] " + pet) + this.petText = "&6Pet&7> &7[Lvl " + (this.petLevels[pet.replace("&", "§")] || "??") + "] " + pet this.lastSwappedPet = Date.now() }) - this.registerChat("&r&aYou despawned your &r${*}&r&a!&r", ()=>{ + this.registerChat("&r&aYou despawned your &r${*}&r&a!&r", () => { this.petElement.setText("&6Pet&7> &cNone") this.petText = "&6Pet&7> &cNone" this.lastSwappedPet = Date.now() }) - this.registerChat("&r&aYour &r${pet} &r&alevelled up to level &r&9${level}&r&a!&r", (pet, level)=>{ - this.petElement.setText("&6Pet&7> &7[Lvl " + (level||"??") +"] "+pet) - this.petText = "&6Pet&7> &7[Lvl " + (level||"??") +"] "+pet + this.registerChat("&r&aYour &r${pet} &r&alevelled up to level &r&9${level}&r&a!&r", (pet, level) => { + this.petElement.setText("&6Pet&7> &7[Lvl " + (level || "??") + "] " + pet) + this.petText = "&6Pet&7> &7[Lvl " + (level || "??") + "] " + pet this.lastSwappedPet = Date.now() }) this.registerSoopy("apiLoad", this.apiLoad) - if(this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock){ + if (this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock) { this.apiLoad(this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock, "skyblock", true, true) this.lastSwappedPet = Date.now() } - if(this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock_raw){ + if (this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock_raw) { this.apiLoad(this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock_raw, "skyblock", false, true) } - new Thread(()=>{ //TODO: dont create this thread if you have the feature disabled - while(this.enabled){ + new Thread(() => { //TODO: dont create this thread if you have the feature disabled + while (this.enabled) { this.updateSpotify() Thread.sleep(5000) } @@ -263,7 +263,7 @@ class Hud extends Feature { this.registerActionBar("${m}", this.actionbarMessage) } - onDisable(){ + onDisable() { this.fpsEnabledSetting.delete() this.fpsFastSetting.delete() this.cpsEnabledSetting.delete() @@ -271,140 +271,138 @@ class Hud extends Feature { this.initVariables() } - renderHud(){ - - if(this.fpsFastSetting.getValue()){ - if(this.fpsLowSetting.getValue()){ + renderHud() { + if (this.fpsFastSetting.getValue()) { + if (this.fpsLowSetting.getValue()) { this.fpsElement.setText("&6Fps&7> &f" + Math.round(this.fps.get()) + "&7/" + Math.round(this.lowFps.get())) - }else{ + } else { this.fpsElement.setText("&6Fps&7> &f" + Math.round(this.fps.get())) } } - for(let element of this.hudElements){ + for (let element of this.hudElements) { element.render() } - if(this.showSpotifyPlaying.getValue() && Date.now()-this.spotifyElement.tempDisableTime > 100){ + if (this.showSpotifyPlaying.getValue() && Date.now() - this.spotifyElement.tempDisableTime > 100) { let scale = this.spotifyElement.locationSetting.scale - let spotifyWidth1 = this.spotifyElement.getWidth()*scale + let spotifyWidth1 = this.spotifyElement.getWidth() * scale this.spotifyElement.render() - this.spotifyElement2.locationSetting.x = this.spotifyElement.locationSetting.x+spotifyWidth1 + this.spotifyElement2.locationSetting.x = this.spotifyElement.locationSetting.x + spotifyWidth1 this.spotifyElement2.locationSetting.y = this.spotifyElement.locationSetting.y this.spotifyElement2.locationSetting.scale = scale - this.spotifyElement2.locationSetting.shadowType = this.spotifyElement.locationSetting.shadowType - - let spotifyWidth2 = this.spotifyElement2.getWidth()*scale - if(spotifyWidth2>150*scale){ - let w2 = spotifyWidth2/scale-150 - let offX = (Date.now()/50)%(w2*2+100) - offX=Math.max(0,offX-50) - if(offX>w2+50){ - offX = w2-(offX-w2-50) - }else if(offX>w2){ + this.spotifyElement2.locationSetting.shadowType = this.spotifyElement.locationSetting.shadowType + + let spotifyWidth2 = this.spotifyElement2.getWidth() * scale + if (spotifyWidth2 > 150 * scale) { + let w2 = spotifyWidth2 / scale - 150 + let offX = (Date.now() / 50) % (w2 * 2 + 100) + offX = Math.max(0, offX - 50) + if (offX > w2 + 50) { + offX = w2 - (offX - w2 - 50) + } else if (offX > w2) { offX = w2 } - this.spotifyElement2.locationSetting.x = this.spotifyElement.locationSetting.x+spotifyWidth1-offX*scale - - renderLibs.scizzorFast(this.spotifyElement.locationSetting.x+spotifyWidth1, this.spotifyElement2.locationSetting.y, 150*scale, this.spotifyElement2.getHeight()*scale) + this.spotifyElement2.locationSetting.x = this.spotifyElement.locationSetting.x + spotifyWidth1 - offX * scale + + renderLibs.scizzorFast(this.spotifyElement.locationSetting.x + spotifyWidth1, this.spotifyElement2.locationSetting.y, 150 * scale, this.spotifyElement2.getHeight() * scale) this.spotifyElement2.render() renderLibs.stopScizzor() - }else{ + } else { this.spotifyElement2.render() } } - if (this.witherImpactCooldownSetting.getValue() && Date.now()-this.lastWitherImpact < 10000) { - Renderer.drawString(Math.max(0,Math.ceil((5000-(Date.now()-this.lastWitherImpact))/1000)) + "s", Renderer.screen.getWidth() / 2 - Renderer.getStringWidth(Math.max(0,Math.ceil((5000-(Date.now()-this.lastWitherImpact))/1000)) + "s") / 2, Renderer.screen.getHeight() / 2 - 15) + if (this.witherImpactCooldownSetting.getValue() && Date.now() - this.lastWitherImpact < 10000) { + Renderer.drawString(Math.max(0, Math.ceil((5000 - (Date.now() - this.lastWitherImpact)) / 1000)) + "s", Renderer.screen.getWidth() / 2 - Renderer.getStringWidth(Math.max(0, Math.ceil((5000 - (Date.now() - this.lastWitherImpact)) / 1000)) + "s") / 2, Renderer.screen.getHeight() / 2 - 15) } - - for(let stat of this.hudStat){ + for (let stat of this.hudStat) { stat.textElement.render() } } - - renderWorld(){ - if(!this.fpsEnabledSetting.getValue() ||!this.fpsFastSetting.getValue()) return + + renderWorld() { + if (!this.fpsEnabledSetting.getValue() || !this.fpsFastSetting.getValue()) return this.framesSince++ - + let instant = this.Instant.now() - let time = instant.getEpochSecond() + (instant.getNano() / 1000000000); + let time = instant.getEpochSecond() + (instant.getNano() / 1000000000); let thisframeTime = time - this.lastFrame - if(thisframeTime > this.slowestFrameTime){ + if (thisframeTime > this.slowestFrameTime) { this.slowestFrameTime = thisframeTime } this.lastFrame = time } - actionbarMessage(m){ - if(ChatLib.removeFormatting(m).includes("(Wither Impact)")){ - if(Date.now()-this.aup < 750){ + actionbarMessage(m) { + if (ChatLib.removeFormatting(m).includes("(Wither Impact)")) { + if (Date.now() - this.aup < 750) { this.lastWitherImpact = Date.now() this.aup = 0 - }else{ + } else { this.impactTest = Date.now() } } } - - step(){ - if(!Player.getPlayer()) return + + step() { + if (!Player.getPlayer()) return this.updateHudThingos() let fps = 0 - if(this.fpsEnabledSetting.getValue() && this.fpsFastSetting.getValue()){ + if (this.fpsEnabledSetting.getValue() && this.fpsFastSetting.getValue()) { //set fps to fast fps // console.log(`${this.framesSince} ${this.lastFrame-this.lastTickTime}`) - fps = this.framesSince/(this.lastFrame-this.lastTickTime) - if(this.lastFrame===this.lastTickTime) fps = 0 + fps = this.framesSince / (this.lastFrame - this.lastTickTime) + if (this.lastFrame === this.lastTickTime) fps = 0 this.lastTickTime = this.lastFrame this.framesSince = 0 this.lastFrameRates.push(fps) this.lastFrameRates.shift() - if(this.slowestFrameTime > 0){ - this.lastFrameRatesS.push(1/this.slowestFrameTime) - }else{ + if (this.slowestFrameTime > 0) { + this.lastFrameRatesS.push(1 / this.slowestFrameTime) + } else { this.lastFrameRatesS.push(0) } this.lastFrameRatesS.shift() this.slowestFrameTime = 0 - - fps = this.lastFrameRates.reduce((a,b) => a+b, 0) / this.lastFrameRates.length + + fps = this.lastFrameRates.reduce((a, b) => a + b, 0) / this.lastFrameRates.length this.fps.set(fps, 200) - if(this.fpsLowSetting.getValue()) this.lowFps.set(this.lastFrameRatesS.reduce((a,b) => a+b, 0) / this.lastFrameRatesS.length, 200) - }else{ + if (this.fpsLowSetting.getValue()) this.lowFps.set(this.lastFrameRatesS.reduce((a, b) => a + b, 0) / this.lastFrameRatesS.length, 200) + } else { fps = Client.getFPS() this.fpsElement.setText("&6Fps&7> &f" + fps) } let cpsText = CPS.getLeftClicksAverage() - if(this.cpsIncludeRight.getValue()){ - if(this.cpsSeperate.getValue()){ + if (this.cpsIncludeRight.getValue()) { + if (this.cpsSeperate.getValue()) { cpsText += "&7 | &f" + CPS.getRightClicksAverage() - }else{ + } else { cpsText += CPS.getRightClicksAverage() } } this.cpsElement.setText("&6Cps&7> &f" + cpsText) //Scan opened inventory for all pet levels - if(Player && Player.getOpenedInventory() && Player.getOpenedInventory().getName().includes(") Pets")){ - let inv = Player.getOpenedInventory().getItems() - for(let i = 0; i < inv.length; i++){ - if(inv[i]!=null && inv[i].getName().includes("[Lvl ")){ + if (Player && Player.getContainer() && Player.getContainer().getName().includes(") Pets")) { + let inv = Player.getContainer().getItems() + for (let i = 0; i < inv.length; i++) { + if (inv[i] != null && inv[i].getName().includes("[Lvl ")) { let level = inv[i].getName().split(" ")[1].replace("]", "") - if(!this.petLevels[inv[i].getName().split("] ")[1]] || this.petLevels[inv[i].getName().split("] ")[1]] < level)this.petLevels[inv[i].getName().split("] ")[1]] = level + if (!this.petLevels[inv[i].getName().split("] ")[1]] || this.petLevels[inv[i].getName().split("] ")[1]] < level) this.petLevels[inv[i].getName().split("] ")[1]] = level - if(Date.now()-this.lastSwappedPet > 1000){ + if (Date.now() - this.lastSwappedPet > 1000) { inv[i].getLore().forEach(line => { - if(line.includes("Click to despawn.")){ + if (line.includes("Click to despawn.")) { this.petElement.setText("&6Pet&7> &7" + inv[i].getName().split("(")[0]) this.petText = "&6Pet&7> &7" + inv[i].getName().split("(")[0] } @@ -414,59 +412,58 @@ class Hud extends Feature { } } - if(Player.getPlayer()[m.getAbsorptionAmount]() > this.lastAbsorbtion){ - if(Date.now()-this.impactTest < 750){ + if (Player.getPlayer()[m.getAbsorptionAmount]() > this.lastAbsorbtion) { + if (Date.now() - this.impactTest < 750) { this.lastWitherImpact = Date.now() this.impactTest = 0 - }else{ + } else { this.aup = Date.now() } } this.lastAbsorbtion = Player.getPlayer()[m.getAbsorptionAmount]() } - step_5second(){ - - if(!this.soulflowEnabledSetting.getValue()) return - if(!Player.getPlayer()) return - if(!Player.getInventory()) return + step_5second() { + if (!this.soulflowEnabledSetting.getValue()) return + if (!Player.getPlayer()) return + if (!Player.getInventory()) return - if(!this.FeatureManager.features["dataLoader"].class.isInSkyblock){ + if (!this.FeatureManager.features["dataLoader"].class.isInSkyblock) { this.soulflowElement.setText("") this.petElement.setText("") return - }else{ + } else { this.petElement.setText(this.petText) } let soulflowCount = 0 let hasSoulflowItem = false - Player.getInventory().getItems().forEach(i=>{ - + Player.getInventory().getItems().forEach(i => { + let id; - try{ + try { id = i.getNBT().getCompoundTag("tag").getCompoundTag("ExtraAttributes").getString("id") - }catch(e){} + } catch (e) { } - if(id === "SOULFLOW_PILE" || id=== "SOULFLOW_BATTERY" || id === "SOULFLOW_SUPERCELL"){ + if (id === "SOULFLOW_PILE" || id === "SOULFLOW_BATTERY" || id === "SOULFLOW_SUPERCELL") { //soulflowCount - i.getLore().forEach(line=>{ - if(line.startsWith("§5§o§7Internalized:")){ + i.getLore().forEach(line => { + if (line.startsWith("§5§o§7Internalized:")) { hasSoulflowItem = true - soulflowCount = parseInt(ChatLib.removeFormatting(line).substr("Internalized: ".length).split("⸎")[0].replace(/,/g,"")) + soulflowCount = parseInt(ChatLib.removeFormatting(line).substr("Internalized: ".length).split("⸎")[0].replace(/,/g, "")) } }) } }) - if(!hasSoulflowItem){ - if(this.soulflowShowWarningSetting.getValue()){ + if (!hasSoulflowItem) { + if (this.soulflowShowWarningSetting.getValue()) { this.soulflowElement.setText("&6Soulflow&7> &cNO TALISMAN") - }else{ + } else { this.soulflowElement.setText("") } return; } - if(soulflowCount > 0 && !this.soulflowShowWhen0Setting.getValue()){ + if (soulflowCount > 0 && !this.soulflowShowWhen0Setting.getValue()) { this.soulflowElement.setText("") return; } @@ -474,19 +471,19 @@ class Hud extends Feature { this.soulflowElement.setText("&6Soulflow&7> &f" + this.numberUtils.numberWithCommas(soulflowCount)) } - statApiLoadThingo(data){ - data.profiles.forEach(p=>{ - if(!this.lastStatData || (p.members[Player.getUUID().toString().replace(/-/g,"")] && p.members[Player.getUUID().toString().replace(/-/g,"")].last_save > this.lastStatData.last_save)){ - this.lastStatData = p.members[Player.getUUID().toString().replace(/-/g,"")] + statApiLoadThingo(data) { + data.profiles.forEach(p => { + if (!this.lastStatData || (p.members[Player.getUUID().toString().replace(/-/g, "")] && p.members[Player.getUUID().toString().replace(/-/g, "")].last_save > this.lastStatData.last_save)) { + this.lastStatData = p.members[Player.getUUID().toString().replace(/-/g, "")] } }) this.updateHudThingos() } - updateSpotify(){ - if(!this.showSpotifyPlaying.getValue()) return - + updateSpotify() { + if (!this.showSpotifyPlaying.getValue()) return + let currentSong = "&cNot open" let spotifyProcesses = [] let process = new ProcessBuilder("tasklist.exe", "/fo", "csv", "/nh").start(); @@ -494,17 +491,17 @@ class Hud extends Feature { if (sc.hasNextLine()) sc.nextLine(); while (sc.hasNextLine()) { let line = sc.nextLine(); - let parts = line.replace("\"","").split("\",\""); + let parts = line.replace("\"", "").split("\",\""); let unq = parts[0] let pid = parts[1] - if(unq==="Spotify.exe"){ + if (unq === "Spotify.exe") { spotifyProcesses.push(pid) // console.log(parts.join(" ")); } } process.waitFor(); - while(spotifyProcesses.length > 0){ + while (spotifyProcesses.length > 0) { let pid = spotifyProcesses.pop() // console.log("Loading pid " + pid) let process = new ProcessBuilder("tasklist.exe", "/FO", "csv", "/V", "/FI", "\"PID eq " + pid + "\"").start(); @@ -512,15 +509,15 @@ class Hud extends Feature { if (sc.hasNextLine()) sc.nextLine(); while (sc.hasNextLine()) { let line = sc.nextLine(); - let parts = line.replace("\"","").split("\",\""); - let song = parts[parts.length-1].substr(0,parts[parts.length-1].length-1) - if(song === "N/A") continue - - if(song === "Spotify Free"||song === "Spotify Premium"||song === "AngleHiddenWindow"){ + let parts = line.replace("\"", "").split("\",\""); + let song = parts[parts.length - 1].substr(0, parts[parts.length - 1].length - 1) + if (song === "N/A") continue + + if (song === "Spotify Free" || song === "Spotify Premium" || song === "AngleHiddenWindow") { currentSong = "&cPaused" - }else{ - if(song === "Spotify") song = "Advertisement" - currentSong = "&a" + song.replace(/&/g, "&⭍").replace(" - "," &7-&b ") + } else { + if (song === "Spotify") song = "Advertisement" + currentSong = "&a" + song.replace(/&/g, "&⭍").replace(" - ", " &7-&b ") } } @@ -530,9 +527,9 @@ class Hud extends Feature { this.spotifyElement2.setText(currentSong.normalize("NFD").replace(/[\u0300-\u036f]/g, "")) } - updateHudThingos(){ + updateHudThingos() { let insb = this.FeatureManager.features["dataLoader"].class.isInSkyblock - if(Date.now()-this.lastUpdatedStatData > 5*60000 && this.hudStat[0].enabled.getValue() && (!this.lastStatData || insb || this.hudStat.map(a=>(!a.enabled.getValue() || a.onlySb.getValue())).includes(false))){ + if (Date.now() - this.lastUpdatedStatData > 5 * 60000 && this.hudStat[0].enabled.getValue() && (!this.lastStatData || insb || this.hudStat.map(a => (!a.enabled.getValue() || a.onlySb.getValue())).includes(false))) { this.FeatureManager.features["dataLoader"].class.loadApiData("skyblock", false) @@ -540,87 +537,87 @@ class Hud extends Feature { return } - this.hudStat.forEach(stat=>{ - if(stat.enabled.getValue()){ + this.hudStat.forEach(stat => { + if (stat.enabled.getValue()) { this.updateHudThing(stat, insb) } }) } - updateHudThing(thing, insb){ - if(!this.lastStatData) return + updateHudThing(thing, insb) { + if (!this.lastStatData) return - if(!insb && thing.onlySb.getValue()){ + if (!insb && thing.onlySb.getValue()) { thing.textElement.setText("") return } let type = thing.type.getValue() - + let string = "Unknown stat" - if(type === "totaldeaths"){ + if (type === "totaldeaths") { string = "&6Deaths&7> &f" + this.numberUtils.numberWithCommas(this.lastStatData.death_count) } - if(type === "cata"){ + if (type === "cata") { let cataData = getLevelByXp(this.lastStatData.dungeons.dungeon_types.catacombs.experience, 2, Infinity) - string = "&6Cata&7> &f" + (~~((cataData.level+cataData.progress)*100)/100).toFixed(2) + " &7(" + this.numberUtils.numberWithCommas(cataData.xpCurrent) + (cataData.level===50?"":"/" + this.numberUtils.numberWithCommas(cataData.xpForNext)) + ")" + string = "&6Cata&7> &f" + (~~((cataData.level + cataData.progress) * 100) / 100).toFixed(2) + " &7(" + this.numberUtils.numberWithCommas(cataData.xpCurrent) + (cataData.level === 50 ? "" : "/" + this.numberUtils.numberWithCommas(cataData.xpForNext)) + ")" } - + Object.keys(this.skillLevelCaps).forEach(skill => { - if(type === skill){ + if (type === skill) { let skillData = getLevelByXp(this.lastStatData[skill], 0, this.skillLevelCaps[skill]) - string = "&6" + firstLetterCapital(skill.split("_").pop()) + "&7> &f" + (skillData.level+skillData.progress).toFixed(2) + " &7(" + this.numberUtils.numberWithCommas(skillData.xpCurrent) + (skillData.level===this.skillLevelCaps[skill]?"":"/" + this.numberUtils.numberWithCommas(skillData.xpForNext)) + ")" + string = "&6" + firstLetterCapital(skill.split("_").pop()) + "&7> &f" + (skillData.level + skillData.progress).toFixed(2) + " &7(" + this.numberUtils.numberWithCommas(skillData.xpCurrent) + (skillData.level === this.skillLevelCaps[skill] ? "" : "/" + this.numberUtils.numberWithCommas(skillData.xpForNext)) + ")" } }) - if(type === "completions_enterance"){ - string = "&6E Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[0]||0)) + if (type === "completions_enterance") { + string = "&6E Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[0] || 0)) } - if(type.startsWith("completions_floor_")){ + if (type.startsWith("completions_floor_")) { let floor = parseInt(type.split("_").pop()) - string = "&6F" + floor +" Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[floor]||0)) + string = "&6F" + floor + " Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[floor] || 0)) } - if(type.startsWith("completions_master_")){ + if (type.startsWith("completions_master_")) { let floor = parseInt(type.split("_").pop()) - string = "&6M" + floor +" Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.master_catacombs?.tier_completions?.[floor]||0)) + string = "&6M" + floor + " Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.master_catacombs?.tier_completions?.[floor] || 0)) } - if(type.startsWith("completions_dungeon_")){ + if (type.startsWith("completions_dungeon_")) { let floor = parseInt(type.split("_").pop()) - string = "&6Dungeon " + floor +" Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[floor]||0)+(this.lastStatData.dungeons?.dungeon_types?.master_catacombs?.tier_completions?.[floor]||0)) + string = "&6Dungeon " + floor + " Comps&7> &f" + this.numberUtils.numberWithCommas((this.lastStatData.dungeons?.dungeon_types?.catacombs?.tier_completions?.[floor] || 0) + (this.lastStatData.dungeons?.dungeon_types?.master_catacombs?.tier_completions?.[floor] || 0)) } - + thing.textElement.setText(string) } - apiLoad(data, dataType, isSoopyServer, isLatest){ - if(dataType === "skyblock" && !isSoopyServer){ + apiLoad(data, dataType, isSoopyServer, isLatest) { + if (dataType === "skyblock" && !isSoopyServer) { this.statApiLoadThingo(data) } - if(!isSoopyServer || !isLatest) return - if(dataType !== "skyblock") return + if (!isSoopyServer || !isLatest) return + if (dataType !== "skyblock") return let pet = data.data.profiles[data.data.stats.currentProfileId].members[Player.getUUID().replace(/-/g, "")].selectedPet - if(!pet){ + if (!pet) { this.petElement.setText("&6Pet&7> &cNone") this.petText = "&6Pet&7> &cNone" return; } - let petTierColor = { - "COMMON": "&f", - "UNCOMMON": "&a", - "RARE": "&9", - "EPIC": "&5", - "LEGENDARY": "&6", - "MYTHIC": "&d" - } + let petTierColor = { + "COMMON": "&f", + "UNCOMMON": "&a", + "RARE": "&9", + "EPIC": "&5", + "LEGENDARY": "&6", + "MYTHIC": "&d" + } - this.petElement.setText("&6Pet&7> &7[Lvl " + (pet.level.level||"??") + "] " + petTierColor[pet.tier] + pet.name) - this.petText = "&6Pet&7> &7[Lvl " + (pet.level.level||"??") + "] " + petTierColor[pet.tier] + pet.name + this.petElement.setText("&6Pet&7> &7[Lvl " + (pet.level.level || "??") + "] " + petTierColor[pet.tier] + pet.name) + this.petText = "&6Pet&7> &7[Lvl " + (pet.level.level || "??") + "] " + petTierColor[pet.tier] + pet.name } - worldLoad(){ + worldLoad() { this.lastUpdatedStatData = 0 } } diff --git a/features/lockedFeatures/index.js b/features/lockedFeatures/index.js index ca69a27..1332cd1 100644 --- a/features/lockedFeatures/index.js +++ b/features/lockedFeatures/index.js @@ -76,7 +76,7 @@ class LockedFeatures extends Feature { if(i === playerPos-1) nextProgress = [parseFloat(u.startingAmount), u.progress] if(i === playerPos) playerProgress = [parseFloat(u.startingAmount), u.progress] if(i === playerPos+1) prevProgress = [parseFloat(u.startingAmount), u.progress] - if(i === playerPos-1 || i === playerPos || i === playerPos+1){ + if(i === playerPos-1 || i === playerPos || i === playerPos+1 || (playerPos === 0 && i===playerPos+2)){ text += "§6#" + (i+1) text += "§7 - " text += "§e"+u.username diff --git a/metadata.json b/metadata.json index 6a9e206..e24894a 100644 --- a/metadata.json +++ b/metadata.json @@ -5,7 +5,7 @@ "entry": "index.js", "description": "SoopyV2", "name": "SoopyV2", - "version": "2.1.48", - "versionId": 175, + "version": "2.1.49", + "versionId": 176, "requires": ["soopyApis", "soopyAddonsData", "CustomTabCompletions", "guimanager", "mappings","BeaconBeam"] } |