aboutsummaryrefslogtreecommitdiff
path: root/features/dataLoader/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'features/dataLoader/index.js')
-rw-r--r--features/dataLoader/index.js96
1 files changed, 57 insertions, 39 deletions
diff --git a/features/dataLoader/index.js b/features/dataLoader/index.js
index fe11e42..21bfe76 100644
--- a/features/dataLoader/index.js
+++ b/features/dataLoader/index.js
@@ -1,6 +1,7 @@
/// <reference types="../../../CTAutocomplete" />
/// <reference lib="es2015" />
import Feature from "../../featureClass/class";
+import socketConnection from "../../socketConnection";
import { fetch } from "../../utils/networkUtils";
class DataLoader extends Feature {
@@ -8,7 +9,7 @@ class DataLoader extends Feature {
super()
}
- onEnable(){
+ onEnable() {
this.initVariables()
this.stats = {}
@@ -26,6 +27,9 @@ class DataLoader extends Feature {
this.api_loaded_event = this.createCustomEvent("apiLoad")
+ this.lastServer = undefined
+ this.lastSentServer = 0
+
this.loadedApiDatas = {}
this.lastApiData = {
@@ -40,44 +44,44 @@ class DataLoader extends Feature {
this.loadApi()
}
- worldLoad(){
+ worldLoad() {
this.area = undefined
this.areaFine = undefined
this.worldLoaded = true
}
- loadApi(){
- fetch("http://soopymc.my.to/api/v2/player_skyblock/" + Player.getUUID().replace(/-/g, "")).json(data=>{
+ loadApi() {
+ fetch("http://soopymc.my.to/api/v2/player_skyblock/" + Player.getUUID().replace(/-/g, "")).json(data => {
- if(!data.success) return
+ if (!data.success) return
this.api_loaded_event.trigger(data, "skyblock", true, true)
this.lastApiData.skyblock = data
})
}
- loadApiData(type, soopyServer){
- if(this.FeatureManager.features["globalSettings"] === undefined || this.FeatureManager.features["globalSettings"].class.apiKeySetting === undefined){
+ loadApiData(type, soopyServer) {
+ if (this.FeatureManager.features["globalSettings"] === undefined || this.FeatureManager.features["globalSettings"].class.apiKeySetting === undefined) {
return
}
let key = this.FeatureManager.features["globalSettings"].class.apiKeySetting.getValue()
- if(!key) return
+ if (!key) return
- if(this.loadedApiDatas[type] !== undefined){
- if(Date.now()-this.loadedApiDatas[type] < 5000 && !this.worldLoaded) return
+ if (this.loadedApiDatas[type] !== undefined) {
+ if (Date.now() - this.loadedApiDatas[type] < 5000 && !this.worldLoaded) return
}
- this.worldLoaded =false
+ this.worldLoaded = false
this.loadedApiDatas[type] = Date.now()
- if(soopyServer){
+ if (soopyServer) {
+
+ } else {
+ if (type === "skyblock") {
+ fetch("https://api.hypixel.net/skyblock/profiles?key=" + key + "&uuid=" + Player.getUUID().replace(/-/g, "")).json(data => {
+ if (!data.success) return
- }else{
- if(type === "skyblock"){
- fetch("https://api.hypixel.net/skyblock/profiles?key=" + key + "&uuid=" + Player.getUUID().replace(/-/g, "")).json(data=>{
- if(!data.success) return
-
this.api_loaded_event.trigger(data, "skyblock", false, true)
this.lastApiData.skyblock_raw = data
})
@@ -85,66 +89,80 @@ class DataLoader extends Feature {
}
}
- step(){ //2fps
+ step() { //2fps
+ this.isInSkyblock = Scoreboard.getTitle()?.removeFormatting().includes("SKYBLOCK")
+
+ if (!this.isInSkyblock) {
+ this.stats = {}
+ return
+ }
+
this.stats["Area"] = undefined
this.stats["Dungeon"] = undefined
- if(World.isLoaded() && TabList.getNames()){
- TabList.getNames().forEach(n=>{
+ if (World.isLoaded() && TabList.getNames()) {
+ TabList.getNames().forEach(n => {
n = ChatLib.removeFormatting(n)
- if(n.includes(": ")){
- if(n.includes('Secrets Found')){
- if(n.includes('%')){
+ if (n.includes(": ")) {
+ if (n.includes('Secrets Found')) {
+ if (n.includes('%')) {
this.stats["Secrets Found%"] = n.split(": ")[1]
- }else{
+ } else {
this.stats["Secrets Found"] = n.split(": ")[1]
}
- }else{
+ } else {
this.stats[n.split(": ")[0].trim()] = n.split(": ")[1].trim()
}
}
})
}
- if(this.stats["Dungeon"]){
+ if (this.stats["Dungeon"]) {
this.stats["Area"] = this.stats["Dungeon"]
this.isInDungeon = true
- }else{
+ } else {
this.isInDungeon = false
}
this.dungeonFloor = undefined
this.slayerXpToSpawn = undefined
- Scoreboard.getLines().forEach(line=>{
+ Scoreboard.getLines().forEach(line => {
let name = ChatLib.removeFormatting(line.getName()).replace(/[^A-z0-9 \:\(\)\.]/g, "")
- if(this.isInDungeon){
- if(name.includes("The Catacombs (")){
+ if (this.isInDungeon) {
+ if (name.includes("The Catacombs (")) {
this.dungeonFloor = name.split("(")[1].split(")")[0].toUpperCase()
}
}
- if(ChatLib.removeFormatting(line).startsWith(" ⏣ ")){
+ if (ChatLib.removeFormatting(line).startsWith(" ⏣ ")) {
this.areaFine = ChatLib.removeFormatting(line).split(" ⏣ ")[1].replace(/[^A-z0-9 \:\(\)\.\-]/g, "")
}
- if(name.startsWith("Purse: ")){
+ if (name.startsWith("Purse: ")) {
this.purse = parseInt(name.split("Purse: ")[1].split(" ")[0])
}
- if(name.startsWith("Bits: ")){
+ 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.startsWith("Cleared: ")) {
+ this.dungeonPercentCleared = parseInt(name.split(" ")[1]) / 100
}
- if(name.endsWith("Combat XP")){
+ if (name.endsWith("Combat XP")) {
this.slayerXpToSpawn = ChatLib.removeFormatting(name).split("(")[1].split(")")[0].split("/").map(parseInt)
}
})
- this.isInSkyblock = Scoreboard.getTitle()?.removeFormatting().includes("SKYBLOCK")
this.area = this.stats["Area"]
+
+
+ if (this.lastServer !== this.FeatureManager.features["dataLoader"].class.stats.Server || Date.now() - this.lastSentServer > 60000 * 5) {
+ this.lastServer = this.FeatureManager.features["dataLoader"].class.stats.Server;
+ this.lastSentServer = Date.now()
+
+ socketConnection.setServer(this.FeatureManager.features["dataLoader"].class.stats.Server);
+ }
}
- initVariables(){
+ initVariables() {
this.stats = undefined
this.isInDungeon = false
@@ -157,7 +175,7 @@ class DataLoader extends Feature {
this.isInSkyblock = undefined
}
- onDisable(){
+ onDisable() {
this.initVariables()
}
}