aboutsummaryrefslogtreecommitdiff
path: root/src/features
diff options
context:
space:
mode:
authorSoopyboo32 <49228220+Soopyboo32@users.noreply.github.com>2022-09-17 19:39:05 +0800
committerSoopyboo32 <49228220+Soopyboo32@users.noreply.github.com>2022-09-17 19:39:05 +0800
commit431e4fc9d1657a50ebc34b8ac24f9bfaea06417f (patch)
tree5987bb14f38d2999c682970429f34b41eb3e5826 /src/features
parente73f2efdf0f50aa775c540317394d46428e9704f (diff)
downloadSoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.tar.gz
SoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.tar.bz2
SoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.zip
Initial move to babel + change fetch to use async/await
Diffstat (limited to 'src/features')
-rw-r--r--src/features/bestiary/index.js250
-rw-r--r--src/features/bestiary/metadata.json8
-rw-r--r--src/features/betterGuis/dungeonReadyGui.js284
-rw-r--r--src/features/betterGuis/index.js386
-rw-r--r--src/features/betterGuis/metadata.json8
-rw-r--r--src/features/betterGuis/museumGui.js1024
-rw-r--r--src/features/changeLogGUI/index.js255
-rw-r--r--src/features/changeLogGUI/metadata.json8
-rw-r--r--src/features/cosmetics/cosmetic.js29
-rw-r--r--src/features/cosmetics/cosmetic/dragon/dragonWings.js482
-rw-r--r--src/features/cosmetics/hiddenRequirement.js4
-rw-r--r--src/features/cosmetics/index.js271
-rw-r--r--src/features/cosmetics/metadata.json8
-rw-r--r--src/features/dataLoader/index.js280
-rw-r--r--src/features/dataLoader/metadata.json8
-rw-r--r--src/features/dungeonMap/dungeonBossImages/f1.pngbin0 -> 4681 bytes
-rw-r--r--src/features/dungeonMap/index.js1186
-rw-r--r--src/features/dungeonMap/map.pngbin0 -> 5648 bytes
-rw-r--r--src/features/dungeonMap/metadata.json8
-rw-r--r--src/features/dungeonMap2/DungeonMapData.js513
-rw-r--r--src/features/dungeonMap2/DungeonMapRoom.js256
-rw-r--r--src/features/dungeonMap2/DungeonRoomStaticData.js19
-rw-r--r--src/features/dungeonMap2/index.js312
-rw-r--r--src/features/dungeonMap2/metadata.json8
-rw-r--r--src/features/dungeonRoutes/index.js481
-rw-r--r--src/features/dungeonRoutes/metadata.json8
-rw-r--r--src/features/dungeonRoutes/routesData.json1296
-rw-r--r--src/features/dungeonSolvers/f7data.json263
-rw-r--r--src/features/dungeonSolvers/index.js1270
-rw-r--r--src/features/dungeonSolvers/metadata.json8
-rw-r--r--src/features/events/index.js816
-rw-r--r--src/features/events/metadata.json8
-rw-r--r--src/features/eventsGUI/index.js287
-rw-r--r--src/features/eventsGUI/metadata.json8
-rw-r--r--src/features/featureBase/index.js24
-rw-r--r--src/features/featureBase/metadata.json8
-rw-r--r--src/features/fpsImproveGui/index.js49
-rw-r--r--src/features/fpsImproveGui/metadata.json8
-rw-r--r--src/features/fragBot/index.js84
-rw-r--r--src/features/fragBot/metadata.json8
-rw-r--r--src/features/friendsGUI/index.js363
-rw-r--r--src/features/friendsGUI/metadata.json8
-rw-r--r--src/features/globalSettings/firstLoadPage.js42
-rw-r--r--src/features/globalSettings/firstLoadPages.js135
-rw-r--r--src/features/globalSettings/index.js1121
-rw-r--r--src/features/globalSettings/metadata.json8
-rw-r--r--src/features/globalSettings/warps.json41
-rw-r--r--src/features/guild/index.js70
-rw-r--r--src/features/guild/metadata.json8
-rw-r--r--src/features/hud/HudTextElement.js143
-rw-r--r--src/features/hud/index.js812
-rw-r--r--src/features/hud/metadata.json8
-rw-r--r--src/features/lockedFeatures/index.js121
-rw-r--r--src/features/lockedFeatures/metadata.json8
-rw-r--r--src/features/mining/coords.json202
-rw-r--r--src/features/mining/index.js469
-rw-r--r--src/features/mining/metadata.json8
-rw-r--r--src/features/nether/index.js406
-rw-r--r--src/features/nether/metadata.json8
-rw-r--r--src/features/networthGUI/index.js239
-rw-r--r--src/features/networthGUI/metadata.json8
-rw-r--r--src/features/performance/hiddenRequirement.js7
-rw-r--r--src/features/performance/index.js128
-rw-r--r--src/features/performance/metadata.json8
-rw-r--r--src/features/senitherGui/index.js453
-rw-r--r--src/features/senitherGui/metadata.json8
-rw-r--r--src/features/settings/helpDataLoader.js50
-rw-r--r--src/features/settings/index.js332
-rw-r--r--src/features/settings/locationSettingHolder.js27
-rw-r--r--src/features/settings/metadata.json8
-rw-r--r--src/features/settings/settingThings/FakeRequireToggle.js27
-rw-r--r--src/features/settings/settingThings/button.js18
-rw-r--r--src/features/settings/settingThings/dropdownSetting.js41
-rw-r--r--src/features/settings/settingThings/imageLocation.js321
-rw-r--r--src/features/settings/settingThings/location.js340
-rw-r--r--src/features/settings/settingThings/settingBase.js162
-rw-r--r--src/features/settings/settingThings/textSetting.js41
-rw-r--r--src/features/settings/settingThings/toggle.js62
-rw-r--r--src/features/settings/settingsCommunicator.js35
-rw-r--r--src/features/slayers/index.js1022
-rw-r--r--src/features/slayers/metadata.json8
-rw-r--r--src/features/soopyGui/GuiPage.js68
-rw-r--r--src/features/soopyGui/categoryManager.js37
-rw-r--r--src/features/soopyGui/index.js215
-rw-r--r--src/features/soopyGui/metadata.json8
-rw-r--r--src/features/spamHider/index.js351
-rw-r--r--src/features/spamHider/metadata.json8
-rw-r--r--src/features/specialMining/index.js461
-rw-r--r--src/features/specialMining/metadata.json8
-rw-r--r--src/features/statHistoryGui/index.js189
-rw-r--r--src/features/statHistoryGui/metadata.json8
-rw-r--r--src/features/stat_next_to_name/index.js193
-rw-r--r--src/features/stat_next_to_name/metadata.json8
-rw-r--r--src/features/streamsGUI/index.js181
-rw-r--r--src/features/streamsGUI/metadata.json8
-rw-r--r--src/features/suggestionsGui/index.js217
-rw-r--r--src/features/suggestionsGui/metadata.json8
-rw-r--r--src/features/waypoints/index.js323
-rw-r--r--src/features/waypoints/metadata.json8
-rw-r--r--src/features/waypoints/minewaypoints_socket.js49
-rw-r--r--src/features/waypoints/pathfind.js96
101 files changed, 20003 insertions, 0 deletions
diff --git a/src/features/bestiary/index.js b/src/features/bestiary/index.js
new file mode 100644
index 0000000..da09463
--- /dev/null
+++ b/src/features/bestiary/index.js
@@ -0,0 +1,250 @@
+/// <reference types="../../../../CTAutocomplete" />
+/// <reference lib="es2015" />
+import Feature from "../../featureClass/class";
+import { numberWithCommas } from "../../utils/numberUtils";
+import HudTextElement from "../hud/HudTextElement";
+import DropdownSetting from "../settings/settingThings/dropdownSetting";
+import LocationSetting from "../settings/settingThings/location";
+import SettingBase from "../settings/settingThings/settingBase";
+import ToggleSetting from "../settings/settingThings/toggle";
+
+let dontUseApi = new Set()
+dontUseApi.add("arachne")
+dontUseApi.add("barbarian_duke_x")
+dontUseApi.add("bladesoul")
+dontUseApi.add("mage_outlaw")
+dontUseApi.add("ashfang")
+dontUseApi.add("magma_cube_boss")
+dontUseApi.add("headless_horseman")
+dontUseApi.add("dragon")
+
+
+class Bestiary extends Feature {
+ constructor() {
+ super()
+ }
+
+ onEnable() {
+ this.bestiaryData = JSON.parse(FileLib.read("soopyAddonsData", "bestiaryData.json") || "{}")
+ this.bestiaryChanged = false
+
+ this.bestiaryApiTracking = {}
+
+ this.registerStep(true, 5, this.scanInv)
+ this.registerStep(false, 5, this.saveData)
+
+
+ this.bestiaryStatTypes = {
+ "barbarian_duke_x": "Barbarian Duke X"
+ }
+ Object.keys(this.bestiaryData).forEach(k => {
+ if (this.bestiaryData[k].guiName) this.bestiaryStatTypes[k] = this.bestiaryData[k].guiName
+ })
+
+ new SettingBase("NOTE: u need to open ur bestiary menu", "before this will work", true, "info_bestiary", this)
+ this.hudStat = []
+ for (let i = 0; i < 10; i++) {
+ this.hudStat[i] = {}
+ this.hudStat[i].enabled = new ToggleSetting("Bestiary Slot #" + (i + 1), "Allows you to render a custom besiary kills on your hud", false, "bestiary_stat_" + i, this)
+ this.hudStat[i].type = new DropdownSetting("Bestiary Slot #" + (i + 1) + " Type", "The bestiary type", "barbarian_duke_x", "bestiary_stat_" + i + "_type", this, this.bestiaryStatTypes)
+ this.hudStat[i].location = new LocationSetting("Bestiary Slot #" + (i + 1) + " Location", "Allows you to edit the location of the bestiary stat", "bestiary_stat_" + i + "_location", this, [10, 50 + i * 10, 1, 1]).editTempText("&6Bestiary Stat Stat&7> &f12,345")
+ this.hudStat[i].textElement = new HudTextElement().setToggleSetting(this.hudStat[i].enabled).setLocationSetting(this.hudStat[i].location).setText("&6Bestiary Stat&7> &fLoading...")
+ this.hudStat[i].onlySb = new ToggleSetting("Bestiary Slot #" + (i + 1) + " Only SB", "Only render this stat when you are in skyblock", true, "bestiary_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)
+ }
+ }
+
+ this.registerStep(false, 5, this.updateHudElements)
+ let lastThing = undefined
+ let lastThingTime = 0
+ this.registerChat("${chat}", (chat) => {
+ let thing
+ switch (chat.trim()) {
+ case "MAGE OUTLAW DOWN!":
+ thing = "mage_outlaw"
+ break;
+ case "BARBARIAN DUKE X DOWN!":
+ thing = "barbarian_duke_x"
+ break;
+ case "BLADESOUL DOWN!":
+ thing = "bladesoul"
+ break;
+ case "ASHFANG DOWN!":
+ thing = "ashfang"
+ break;
+ // case "MAGMA BOSS DOWN!":
+ // thing = "magma_cube_boss"
+ // break;
+ case "ARACHNE DOWN!":
+ lastThing = "arachne"
+ lastThingTime = Date.now()
+ break;
+ case "HORSEMAN DOWN!":
+ lastThing = "arachne"
+ lastThingTime = Date.now()
+ break;
+ default:
+ break;
+ }
+ if (chat.includes("DRAGON")) {
+ lastThing = "dragon"
+ lastThingTime = Date.now()
+ }
+
+ if (chat.trim().startsWith("Your Damage: ")) {
+ let dmg = parseInt(chat.trim().split("Your Damage: ")[1].split(" ")[0])
+ if (dmg > 0 && Date.now() - lastThingTime < 1000) {
+ thing = lastThing
+ lastThing = ""
+ lastThingTime = 0
+ }
+ }
+
+ if (thing) {
+ this.bestiaryData[thing].guessCount++
+ this.bestiaryChanged = true
+ }
+ })
+ this.registerSoopy("apiLoad", this.apiLoad);
+
+ if (this.FeatureManager.features["dataLoader"] && this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock_raw) {
+ this.apiLoad(this.FeatureManager.features["dataLoader"].class.lastApiData.skyblock_raw, "skyblock", false, true);
+ }
+ }
+
+ getBestiaryCount(id) {
+ if (!this.bestiaryData[id]) return "???"
+ let count = this.bestiaryData[id].count
+
+ if (!dontUseApi.has(id)) {
+ let currApiData = this.bestiaryApiTracking[id]
+
+ count += currApiData - this.bestiaryData[id].apiCount
+ }
+
+ count += this.bestiaryData[id].guessCount
+
+ return count
+ }
+
+ updateHudElements() {
+ if (!this.FeatureManager.features["dataLoader"]) return
+
+ let insb = this.FeatureManager.features["dataLoader"].class.isInSkyblock
+
+ this.hudStat.forEach(stat => {
+ if (stat.enabled.getValue()) {
+ if (!insb && stat.onlySb.getValue()) {
+ stat.textElement.setText("")
+ return
+ }
+
+ let type = stat.type.getValue()
+
+ stat.textElement.setText(`&6${this.bestiaryData[type]?.guiName}&7> &f${numberWithCommas(this.getBestiaryCount(type))}`)
+ } else {
+ stat.textElement.setText("")
+ }
+ })
+ }
+
+ apiLoad(data, dataType, isSoopyServer, isLatest) {
+ if (isSoopyServer || !isLatest) return;
+ if (dataType !== "skyblock") return;
+
+ let currentProfile = {}
+ let currentProfileTime = 0
+
+ data.profiles.forEach(p => {
+ if (p.members[Player.getUUID().toString().replace(/-/g, "")].last_save > currentProfileTime) {
+ currentProfileTime = p.members[Player.getUUID().toString().replace(/-/g, "")].last_save
+ currentProfile = p.members[Player.getUUID().toString().replace(/-/g, "")]
+ }
+ })
+
+ Object.keys(currentProfile.stats).forEach(key => {
+ if (key.startsWith("kills_")) {
+ this.bestiaryApiTracking[key.replace("kills_", "")] = currentProfile.stats[key]
+ }
+ })
+ }
+
+ scanInv() {
+ if (!Player.getContainer()) return
+ if (!Player.getContainer().getName().startsWith("Bestiary ➜ ")) return
+ let tempChanged = false
+ let seen = new Set()
+
+ for (let item of Player.getContainer().getItems()) {
+ if (!item) continue
+ let name = ChatLib.removeFormatting(item.getName()).split(" ")
+ name.pop()
+ let apiName = name.join("_").toLowerCase()
+ if (seen.has(apiName)) continue
+ seen.add(apiName)
+
+ if (apiName === "skeletor_prime") continue
+
+ if (this.bestiaryApiTracking[apiName] || dontUseApi.has(apiName)) {
+
+ let count = 0
+
+ for (let l of item.getLore()) {
+ l = ChatLib.removeFormatting(l)
+
+ if (l.startsWith("Kills: ")) {
+ count = parseInt(l.split("Kills: ")[1].replace(/,/g, ""))
+ break;
+ }
+ }
+
+ let needsChange = !this.bestiaryData[apiName] || this.bestiaryData[apiName].guiName !== name.join(" ") || this.bestiaryData[apiName].count !== count || this.bestiaryData[apiName].apiCount !== (this.bestiaryApiTracking[apiName] || 0) || this.bestiaryData[apiName].guessCount !== 0
+ if (needsChange) {
+ this.bestiaryData[apiName] = {
+ guiName: name.join(" "),
+ count,
+ apiCount: this.bestiaryApiTracking[apiName] || 0,
+ guessCount: 0
+ }
+ this.bestiaryChanged = true
+
+ tempChanged = true
+
+ }
+ }
+ }