aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/at/hannibal2/skyhanni/features/misc/discordrpc/DiscordStatus.kt37
1 files changed, 30 insertions, 7 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/features/misc/discordrpc/DiscordStatus.kt b/src/main/java/at/hannibal2/skyhanni/features/misc/discordrpc/DiscordStatus.kt
index 4a2ef02c4..f9caf4146 100644
--- a/src/main/java/at/hannibal2/skyhanni/features/misc/discordrpc/DiscordStatus.kt
+++ b/src/main/java/at/hannibal2/skyhanni/features/misc/discordrpc/DiscordStatus.kt
@@ -1,12 +1,16 @@
package at.hannibal2.skyhanni.features.misc.discordrpc
-// SkyblockAddons code, adapted for SkyHanni
+// SkyblockAddons code, adapted for SkyHanni with some additions and fixes
import at.hannibal2.skyhanni.SkyHanniMod
-import at.hannibal2.skyhanni.data.*
+import at.hannibal2.skyhanni.data.ActionBarStatsData
import at.hannibal2.skyhanni.data.GardenCropMilestones.Companion.getCounter
import at.hannibal2.skyhanni.data.GardenCropMilestones.Companion.getTierForCrops
import at.hannibal2.skyhanni.data.GardenCropMilestones.Companion.progressToNextLevel
+import at.hannibal2.skyhanni.data.HypixelData
+import at.hannibal2.skyhanni.data.IslandType
+import at.hannibal2.skyhanni.data.ProfileStorageData
+import at.hannibal2.skyhanni.data.ScoreboardData
import at.hannibal2.skyhanni.features.garden.GardenAPI.getCropType
import at.hannibal2.skyhanni.features.rift.everywhere.RiftAPI
import at.hannibal2.skyhanni.utils.InventoryUtils
@@ -27,6 +31,7 @@ var lastKnownDisplayStrings: MutableMap<DiscordStatus, String> =
mutableMapOf() // if the displayMessageSupplier is ever a placeholder, return from this instead
val purseRegex = Regex("""(?:Purse|Piggy): ([\d,]+)[\d.]*""")
+val motesRegex = Regex("""Motes: ([\d,]+)""")
val bitsRegex = Regex("""Bits: ([\d|,]+)[\d|.]*""")
val stackingEnchants = mapOf(
@@ -74,12 +79,11 @@ val stackingEnchants = mapOf(
private fun getVisitingName(): String {
val tabData = getTabList()
- val ownerRegex = Pattern.compile(".*Owner: (?<username>\\w+).*")
+ val ownerRegex = Regex(".*Owner: (\\w+).*")
for (line in tabData) {
val colorlessLine = line.removeColor()
- val ownerMatcher = ownerRegex.matcher(colorlessLine)
- if (ownerMatcher.matches()) {
- return ownerMatcher.group("username")
+ if (ownerRegex.matches(colorlessLine)) {
+ return ownerRegex.find(colorlessLine)!!.groupValues[1]
}
}
return "Someone"
@@ -92,10 +96,22 @@ enum class DiscordStatus(private val displayMessageSupplier: Supplier<String>?)
LOCATION({
var location = LorenzUtils.skyBlockArea
val island = LorenzUtils.skyBlockIsland
+
if (location == "Your Island") location = "Private Island"
if (island == IslandType.PRIVATE_ISLAND_GUEST) lastKnownDisplayStrings[LOCATION] =
"${getVisitingName()}'s Island"
- else if (location != "None" && location != "invalid") {
+ else if (island == IslandType.GARDEN) {
+ if (location.startsWith("Plot: ")) {
+ lastKnownDisplayStrings[LOCATION] = "Personal Garden ($location)" // Personal Garden (Plot: 8)
+ } else {
+ lastKnownDisplayStrings[LOCATION] = "Personal Garden"
+ }
+ } else if (island == IslandType.GARDEN_GUEST) {
+ lastKnownDisplayStrings[LOCATION] = "${getVisitingName()}'s Garden"
+ if (location.startsWith("Plot: ")) {
+ lastKnownDisplayStrings[LOCATION] = "${lastKnownDisplayStrings[LOCATION]} ($location)"
+ } // "MelonKingDe's Garden (Plot: 8)"
+ } else if (location != "None" && location != "invalid") {
lastKnownDisplayStrings[LOCATION] = location
}
lastKnownDisplayStrings[LOCATION] ?: "None"// only display None if we don't have a last known area
@@ -107,10 +123,17 @@ enum class DiscordStatus(private val displayMessageSupplier: Supplier<String>?)
val coins = scoreboard.firstOrNull { purseRegex.matches(it.removeColor()) }?.let {
purseRegex.find(it.removeColor())?.groupValues?.get(1) ?: ""
}
+ val motes = scoreboard.firstOrNull { motesRegex.matches(it.removeColor()) }?.let {
+ motesRegex.find(it.removeColor())?.groupValues?.get(1) ?: ""
+ }
if (coins == "1") {
lastKnownDisplayStrings[PURSE] = "1 Coin"
} else if (coins != "" && coins != null) {
lastKnownDisplayStrings[PURSE] = "$coins Coins"
+ } else if (motes == "1") {
+ lastKnownDisplayStrings[PURSE] = "1 Mote"
+ } else if (motes != "" && motes != null) {
+ lastKnownDisplayStrings[PURSE] = "$motes Motes"
}
lastKnownDisplayStrings[PURSE] ?: ""
}),