diff options
13 files changed, 202 insertions, 76 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/api/CollectionAPI.kt b/src/main/java/at/hannibal2/skyhanni/api/CollectionAPI.kt index 3e7e1f7bf..1f5adacf7 100644 --- a/src/main/java/at/hannibal2/skyhanni/api/CollectionAPI.kt +++ b/src/main/java/at/hannibal2/skyhanni/api/CollectionAPI.kt @@ -1,5 +1,6 @@ package at.hannibal2.skyhanni.api +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.events.CollectionUpdateEvent import at.hannibal2.skyhanni.events.InventoryFullyOpenedEvent import at.hannibal2.skyhanni.events.ItemAddEvent @@ -88,6 +89,7 @@ object CollectionAPI { @SubscribeEvent fun onItemAdd(event: ItemAddEvent) { + if (event.source == ItemAddManager.Source.COMMAND) return val internalName = event.internalName val amount = NEUItems.getPrimitiveMultiplier(internalName).amount if (amount > 1) return diff --git a/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt b/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt index f7101cd4b..edfdb2d7a 100644 --- a/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt +++ b/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt @@ -12,6 +12,7 @@ import at.hannibal2.skyhanni.data.PartyAPI import at.hannibal2.skyhanni.data.SackAPI import at.hannibal2.skyhanni.data.ScoreboardData import at.hannibal2.skyhanni.data.TitleManager +import at.hannibal2.skyhanni.data.TrackerManager import at.hannibal2.skyhanni.data.bazaar.HypixelBazaarFetcher import at.hannibal2.skyhanni.features.bingo.card.BingoCardDisplay import at.hannibal2.skyhanni.features.bingo.card.nextstephelper.BingoNextStepHelper @@ -438,6 +439,10 @@ object Commands { "shresetpunchcard", "Resets the Rift Punchcard Artifact player list.", ) { PunchcardHighlight.clearList() } + registerCommand( + "shedittracker", + "Changes the tracked item amount for Diana, Fishing, Pest, Excavator, and Slayer Item Trackers.", + ) { TrackerManager.commandEditTracker(it) } } private fun developersDebugFeatures() { diff --git a/src/main/java/at/hannibal2/skyhanni/data/ItemAddManager.kt b/src/main/java/at/hannibal2/skyhanni/data/ItemAddManager.kt index 26658eee7..4906f5f80 100644 --- a/src/main/java/at/hannibal2/skyhanni/data/ItemAddManager.kt +++ b/src/main/java/at/hannibal2/skyhanni/data/ItemAddManager.kt @@ -25,6 +25,7 @@ object ItemAddManager { enum class Source { ITEM_ADD, SACKS, + COMMAND, } private val ARCHFIEND_DICE = "ARCHFIEND_DICE".asInternalName() diff --git a/src/main/java/at/hannibal2/skyhanni/data/TrackerManager.kt b/src/main/java/at/hannibal2/skyhanni/data/TrackerManager.kt index 71b60d76e..c1a7a60c3 100644 --- a/src/main/java/at/hannibal2/skyhanni/data/TrackerManager.kt +++ b/src/main/java/at/hannibal2/skyhanni/data/TrackerManager.kt @@ -3,8 +3,12 @@ package at.hannibal2.skyhanni.data import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.events.ConfigLoadEvent import at.hannibal2.skyhanni.events.GuiRenderEvent +import at.hannibal2.skyhanni.events.ItemAddEvent import at.hannibal2.skyhanni.skyhannimodule.SkyHanniModule +import at.hannibal2.skyhanni.utils.ChatUtils import at.hannibal2.skyhanni.utils.ConditionalUtils +import at.hannibal2.skyhanni.utils.NEUInternalName +import at.hannibal2.skyhanni.utils.NumberUtil.formatIntOrUserError import net.minecraftforge.fml.common.eventhandler.EventPriority import net.minecraftforge.fml.common.eventhandler.SubscribeEvent @@ -13,6 +17,7 @@ object TrackerManager { private var hasChanged = false var dirty = false + var commandEditTrackerSuccess = false @SubscribeEvent fun onConfigLoad(event: ConfigLoadEvent) { @@ -36,4 +41,30 @@ object TrackerManager { hasChanged = false } } + + fun commandEditTracker(args: Array<String>) { + if (args.size < 2) { + ChatUtils.userError("Usage: /shedittracker <item name> <amount>") + return + } + + val amount = args.last().formatIntOrUserError() ?: return + if (amount == 0) { + ChatUtils.userError("Amount can not be zero!") + return + } + + val rawName = args.dropLast(1).joinToString(" ") + val internalName = NEUInternalName.fromItemNameOrInternalName(rawName) + if (!internalName.isKnownItem()) { + ChatUtils.chat("No item found for '$rawName'!") + return + } + + commandEditTrackerSuccess = false + ItemAddEvent(internalName, amount, ItemAddManager.Source.COMMAND).postAndCatch() + if (!commandEditTrackerSuccess) { + ChatUtils.userError("Could not edit the Item Tracker! Does this item belong to this tracker? Is the tracker active right now?") + } + } } diff --git a/src/main/java/at/hannibal2/skyhanni/features/event/diana/DianaProfitTracker.kt b/src/main/java/at/hannibal2/skyhanni/features/event/diana/DianaProfitTracker.kt index 1ba2724c3..01d2c1d2e 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/event/diana/DianaProfitTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/event/diana/DianaProfitTracker.kt @@ -1,6 +1,7 @@ package at.hannibal2.skyhanni.features.event.diana import at.hannibal2.skyhanni.SkyHanniMod +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.data.jsonobjects.repo.DianaDropsJson import at.hannibal2.skyhanni.events.GuiRenderEvent import at.hannibal2.skyhanni.events.ItemAddEvent @@ -33,17 +34,18 @@ object DianaProfitTracker { private val patternGroup = RepoPattern.group("diana.chat") private val chatDugOutPattern by patternGroup.pattern( "burrow.dug", - "(§eYou dug out a Griffin Burrow!|§eYou finished the Griffin burrow chain!) .*" + "(§eYou dug out a Griffin Burrow!|§eYou finished the Griffin burrow chain!) .*", ) private val chatDugOutCoinsPattern by patternGroup.pattern( "coins", - "§6§lWow! §r§eYou dug out §r§6(?<coins>.*) coins§r§e!" + "§6§lWow! §r§eYou dug out §r§6(?<coins>.*) coins§r§e!", ) private val tracker = SkyHanniItemTracker( "Diana Profit Tracker", { Data() }, - { it.diana.dianaProfitTracker }) { drawDisplay(it) } + { it.diana.dianaProfitTracker }, + ) { drawDisplay(it) } class Data : ItemTrackerData() { @@ -70,7 +72,7 @@ object DianaProfitTracker { val burrowDugCoinsFormat = item.totalAmount.shortFormat() return listOf( "§7Digging treasures gave you", - "§6$burrowDugCoinsFormat coins §7in total." + "§6$burrowDugCoinsFormat coins §7in total.", ) } } @@ -84,8 +86,8 @@ object DianaProfitTracker { addAsSingletonList( Renderable.hoverTips( "§7Burrows dug: §e${treasureCoins.addSeparators()}", - listOf("§7You dug out griffin burrows §e${treasureCoins.addSeparators()} §7times.") - ) + listOf("§7You dug out griffin burrows §e${treasureCoins.addSeparators()} §7times."), + ), ) addAsSingletonList(tracker.addTotalProfit(profit, data.burrowsDug, "burrow")) @@ -97,14 +99,16 @@ object DianaProfitTracker { fun onItemAdd(event: ItemAddEvent) { if (!isEnabled()) return - val internalName = event.internalName + tryAddItem(event.internalName, event.amount, event.source == ItemAddManager.Source.COMMAND) + } - if (!isAllowedItem(internalName)) { + private fun tryAddItem(internalName: NEUInternalName, amount: Int, command: Boolean) { + if (!isAllowedItem(internalName) && internalName != NEUInternalName.SKYBLOCK_COIN) { ChatUtils.debug("Ignored non-diana item pickup: '$internalName'") return } - tracker.addItem(internalName, event.amount) + tracker.addItem(internalName, amount, command) } @SubscribeEvent @@ -119,7 +123,7 @@ object DianaProfitTracker { } chatDugOutCoinsPattern.matchMatcher(message) { BurrowAPI.lastBurrowRelatedChatMessage = SimpleTimeMark.now() - tracker.addCoins(group("coins").formatInt()) + tryAddItem(NEUInternalName.SKYBLOCK_COIN, group("coins").formatInt(), command = false) tryHide(event) } diff --git a/src/main/java/at/hannibal2/skyhanni/features/fishing/tracker/FishingProfitTracker.kt b/src/main/java/at/hannibal2/skyhanni/features/fishing/tracker/FishingProfitTracker.kt index b99c03ff5..a0590816e 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/fishing/tracker/FishingProfitTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/fishing/tracker/FishingProfitTracker.kt @@ -1,6 +1,7 @@ package at.hannibal2.skyhanni.features.fishing.tracker import at.hannibal2.skyhanni.SkyHanniMod +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.data.jsonobjects.repo.FishingProfitItemsJson import at.hannibal2.skyhanni.events.FishingBobberCastEvent import at.hannibal2.skyhanni.events.GuiRenderEvent @@ -43,14 +44,15 @@ object FishingProfitTracker { private val coinsChatPattern by RepoPattern.pattern( "fishing.tracker.chat.coins", - ".* CATCH! §r§bYou found §r§6(?<coins>.*) Coins§r§b\\." + ".* CATCH! §r§bYou found §r§6(?<coins>.*) Coins§r§b\\.", ) private var lastCatchTime = SimpleTimeMark.farPast() private val tracker = SkyHanniItemTracker( "Fishing Profit Tracker", { Data() }, - { it.fishing.fishingProfitTracker }) { drawDisplay(it) } + { it.fishing.fishingProfitTracker }, + ) { drawDisplay(it) } class Data : ItemTrackerData() { @@ -64,7 +66,7 @@ object FishingProfitTracker { return listOf( "§7Caught §e${timesCaught.addSeparators()} §7times.", - "§7Your catch rate: §c$catchRate" + "§7Your catch rate: §c$catchRate", ) } @@ -73,7 +75,7 @@ object FishingProfitTracker { override fun getCoinDescription(item: TrackedItem): List<String> { val mobKillCoinsFormat = item.totalAmount.shortFormat() return listOf( - "§7You fished up §6$mobKillCoinsFormat coins §7already." + "§7You fished up §6$mobKillCoinsFormat coins §7already.", ) } @@ -127,8 +129,8 @@ object FishingProfitTracker { addAsSingletonList( Renderable.hoverTips( "§7Times fished: §e${fishedCount.addSeparators()}", - listOf("§7You've reeled in §e${fishedCount.addSeparators()} §7catches.") - ) + listOf("§7You've reeled in §e${fishedCount.addSeparators()} §7catches."), + ), ) addAsSingletonList(tracker.addTotalProfit(profit, data.totalCatchAmount, "catch")) @@ -152,7 +154,7 @@ object FishingProfitTracker { val id = list.indexOf(currentCategory) currentCategory = list[(id + 1) % list.size] tracker.update() - } + }, ) } @@ -178,7 +180,7 @@ object FishingProfitTracker { "Loaded $label not in a fishing category", "Found items missing in itemCategories", "missingItems" to missingItems, - noStackTrace = true + noStackTrace = true, ) } } @@ -186,15 +188,21 @@ object FishingProfitTracker { @SubscribeEvent fun onItemAdd(event: ItemAddEvent) { if (!isEnabled()) return + + if (event.source == ItemAddManager.Source.COMMAND) { + tryAddItem(event.internalName, event.amount, command = true) + return + } + DelayedRun.runDelayed(500.milliseconds) { - maybeAddItem(event.internalName, event.amount) + tryAddItem(event.internalName, event.amount, command = false) } } @SubscribeEvent fun onChat(event: LorenzChatEvent) { coinsChatPattern.matchMatcher(event.message) { - tracker.addCoins(group("coins").formatInt()) + tryAddItem(NEUInternalName.SKYBLOCK_COIN, group("coins").formatInt(), command = false) addCatch() } } @@ -221,14 +229,14 @@ object FishingProfitTracker { lastCatchTime = SimpleTimeMark.farPast() } - private fun maybeAddItem(internalName: NEUInternalName, amount: Int) { + private fun tryAddItem(internalName: NEUInternalName, amount: Int, command: Boolean) { if (!FishingAPI.isFishing(checkRodInHand = false)) return if (!isAllowedItem(internalName)) { ChatUtils.debug("Ignored non-fishing item pickup: $internalName'") return } - tracker.addItem(internalName, amount) + tracker.addItem(internalName, amount, command) addCatch() } diff --git a/src/main/java/at/hannibal2/skyhanni/features/garden/pests/PestProfitTracker.kt b/src/main/java/at/hannibal2/skyhanni/features/garden/pests/PestProfitTracker.kt index 5f630335b..1d2710c7c 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/garden/pests/PestProfitTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/garden/pests/PestProfitTracker.kt @@ -2,8 +2,10 @@ package at.hannibal2.skyhanni.features.garden.pests import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.data.IslandType +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.events.GuiRenderEvent import at.hannibal2.skyhanni.events.IslandChangeEvent +import at.hannibal2.skyhanni.events.ItemAddEvent import at.hannibal2.skyhanni.events.LorenzChatEvent import at.hannibal2.skyhanni.events.PurseChangeCause import at.hannibal2.skyhanni.events.PurseChangeEvent @@ -37,14 +39,15 @@ object PestProfitTracker { */ private val pestRareDropPattern by patternGroup.pattern( "raredrop", - "§6§l(?:RARE|PET) DROP! (?:§r)?(?<item>.+) §6\\(§6\\+.*☘\\)" + "§6§l(?:RARE|PET) DROP! (?:§r)?(?<item>.+) §6\\(§6\\+.*☘\\)", ) private var lastPestKillTime = SimpleTimeMark.farPast() private val tracker = SkyHanniItemTracker( "Pest Profit Tracker", { Data() }, - { it.garden.pestProfitTracker }) { drawDisplay(it) } + { it.garden.pestProfitTracker }, + ) { drawDisplay(it) } class Data : ItemTrackerData() { override fun resetItems() { @@ -56,7 +59,7 @@ object PestProfitTracker { val dropRate = LorenzUtils.formatPercentage(percentage.coerceAtMost(1.0)) return listOf( "§7Dropped §e${timesGained.addSeparators()} §7times.", - "§7Your drop rate: §c$dropRate." + "§7Your drop rate: §c$dropRate.", ) } @@ -66,7 +69,7 @@ object PestProfitTracker { val pestsCoinsFormat = item.totalAmount.shortFormat() return listOf( "§7Killing pests gives you coins.", - "§7You got §6$pestsCoinsFormat coins §7that way." + "§7You got §6$pestsCoinsFormat coins §7that way.", ) } @@ -75,24 +78,38 @@ object PestProfitTracker { } @SubscribeEvent + fun onItemAdd(event: ItemAddEvent) { + if (!isEnabled()) return + + val internalName = event.internalName + if (event.source == ItemAddManager.Source.COMMAND) { + tryAddItem(internalName, event.amount, command = true) + } + } + + @SubscribeEvent fun onChat(event: LorenzChatEvent) { if (!isEnabled()) return PestAPI.pestDeathChatPattern.matchMatcher(event.message) { val amount = group("amount").toInt() val internalName = NEUInternalName.fromItemNameOrNull(group("item")) ?: return - tracker.addItem(internalName, amount) + tryAddItem(internalName, amount, command = false) addKill() if (config.hideChat) event.blockedReason = "pest_drop" } pestRareDropPattern.matchMatcher(event.message) { val internalName = NEUInternalName.fromItemNameOrNull(group("item")) ?: return - tracker.addItem(internalName, 1) + tryAddItem(internalName, 1, command = false) // pests always have guaranteed loot, therefore there's no need to add kill here } } + private fun tryAddItem(internalName: NEUInternalName, amount: Int, command: Boolean) { + tracker.addItem(internalName, amount, command) + } + private fun addKill() { tracker.modify { it.totalPestsKills++ @@ -108,8 +125,8 @@ object PestProfitTracker { addAsSingletonList( Renderable.hoverTips( "§7Pests killed: §e${pestsKilled.addSeparators()}", - listOf("§7You killed pests §e${pestsKilled.addSeparators()} §7times.") - ) + listOf("§7You killed pests §e${pestsKilled.addSeparators()} §7times."), + ), ) addAsSingletonList(tracker.addTotalProfit(profit, data.totalPestsKills, "kill")) @@ -131,7 +148,7 @@ object PestProfitTracker { val coins = event.coins if (coins > 1000) return if (event.reason == PurseChangeCause.GAIN_MOB_KILL && lastPestKillTime.passedSince() < 2.seconds) { - tracker.addCoins(coins.toInt()) + tryAddItem(NEUInternalName.SKYBLOCK_COIN, coins.toInt(), command = false) } } diff --git a/src/main/java/at/hannibal2/skyhanni/features/mining/fossilexcavator/ExcavatorProfitTracker.kt b/src/main/java/at/hannibal2/skyhanni/features/mining/fossilexcavator/ExcavatorProfitTracker.kt index dcf9b8c4d..ef3b780b7 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/mining/fossilexcavator/ExcavatorProfitTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/mining/fossilexcavator/ExcavatorProfitTracker.kt @@ -2,8 +2,10 @@ package at.hannibal2.skyhanni.features.mining.fossilexcavator import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.data.IslandType +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.events.GuiRenderEvent import at.hannibal2.skyhanni.events.IslandChangeEvent +import at.hannibal2.skyhanni.events.ItemAddEvent import at.hannibal2.skyhanni.events.mining.FossilExcavationEvent import at.hannibal2.skyhanni.skyhannimodule.SkyHanniModule import at.hannibal2.skyhanni.utils.ChatUtils @@ -155,6 +157,20 @@ object ExcavatorProfitTracker { } @SubscribeEvent + fun onItemAdd(event: ItemAddEvent) { + if (!isEnabled()) return + + val internalName = event.internalName + if (event.source == ItemAddManager.Source.COMMAND) { + tryAddItem(internalName, event.amount, command = true) + } + } + + private fun tryAddItem(internalName: NEUInternalName, amount: Int, command: Boolean) { + tracker.addItem(internalName, amount, command) + } + + @SubscribeEvent fun onFossilExcavation(event: FossilExcavationEvent) { if (!isEnabled()) return for ((name, amount) in event.loot) { @@ -185,11 +201,11 @@ object ExcavatorProfitTracker { val internalName = NEUInternalName.fromItemNameOrNull(name) if (internalName == null) { - ChatUtils.debug("no price for exavator profit: '$name'") + ChatUtils.debug("no price for excavator profit: '$name'") return } // TODO use primitive item stacks in trackers - tracker.addItem(internalName, amount) + tryAddItem(internalName, amount, command = false) } @SubscribeEvent diff --git a/src/main/java/at/hannibal2/skyhanni/features/slayer/SlayerProfitTracker.kt b/src/main/java/at/hannibal2/skyhanni/features/slayer/SlayerProfitTracker.kt index 372c7daa9..d2f50358d 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/slayer/SlayerProfitTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/slayer/SlayerProfitTracker.kt @@ -3,6 +3,7 @@ package at.hannibal2.skyhanni.features.slayer import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.config.ConfigUpdaterMigrator import at.hannibal2.skyhanni.config.storage.ProfileSpecificStorage +import at.hannibal2.skyhanni.data.ItemAddManager import at.hannibal2.skyhanni.data.SlayerAPI import at.hannibal2.skyhanni.data.jsonobjects.repo.SlayerProfitTrackerItemsJson import at.hannibal2.skyhanni.events.GuiRenderEvent @@ -46,7 +47,7 @@ object SlayerProfitTracker { */ private val autoSlayerBankPattern by RepoPattern.pattern( "slayer.autoslayer.bank.chat", - "§7Took (?<coins>.+) coins from your bank for auto-slayer\\.\\.\\." + "§7Took (?<coins>.+) coins from your bank for auto-slayer\\.\\.\\.", ) class Data : ItemTrackerData() { @@ -78,7 +79,7 @@ object SlayerProfitTracker { val mobKillCoinsFormat = item.totalAmount.shortFormat() return listOf( "§7Killing mobs gives you coins (more with scavenger).", - "§7You got §6$mobKillCoinsFormat coins §7that way." + "§7You got §6$mobKillCoinsFormat coins §7that way.", ) } } @@ -104,7 +105,7 @@ object SlayerProfitTracker { if (!isEnabled()) return val coins = event.coins if (event.reason == PurseChangeCause.GAIN_MOB_KILL && SlayerAPI.isInCorrectArea) { - getTracker()?.addCoins(coins.toInt()) + tryAddItem(NEUInternalName.SKYBLOCK_COIN, coins.toInt(), command = false) } if (event.reason == PurseChangeCause.LOSE_SLAYER_QUEST_STARTED) { addSlayerCosts(coins) @@ -133,7 +134,7 @@ object SlayerProfitTracker { return trackers.getOrPut(itemLogCategory) { val getStorage: (ProfileSpecificStorage) -> Data = { it.slayerProfitData.getOrPut( - itemLogCategory + itemLogCategory, ) { Data() } } SkyHanniItemTracker("$itemLogCategory Profit Tracker", { Data() }, getStorage) { drawDisplay(it) } @@ -153,15 +154,16 @@ object SlayerProfitTracker { if (!SlayerAPI.isInCorrectArea) return if (!SlayerAPI.hasActiveSlayerQuest()) return - val internalName = event.internalName - val amount = event.amount + tryAddItem(event.internalName, event.amount, event.source == ItemAddManager.Source.COMMAND) + } - if (!isAllowedItem(internalName)) { + private fun tryAddItem(internalName: NEUInternalName, amount: Int, command: Boolean) { + if (!isAllowedItem(internalName) && internalName != NEUInternalName.SKYBLOCK_COIN) { ChatUtils.debug("Ignored non-slayer item pickup: '$internalName' '$itemLogCategory'") return } - getTracker()?.addItem(internalName, amount) + getTracker()?.addItem(internalName, amount, command) } private fun isAllowedItem(internalName: NEUInternalName): Boolean { @@ -176,12 +178,12 @@ object SlayerProfitTracker { var profit = tracker.drawItems(data, { true }, this) val slayerSpawnCost = data.slayerSpawnCost if (slayerSpawnCost != 0L) { - val mobKillCoinsFormat = slayerSpawnCost.shortFormat() + val slayerSpawnCostFormat = slayerSpawnCost.shortFormat() addAsSingletonList( Renderable.hoverTips( - " §7Slayer Spawn Costs: §c$mobKillCoinsFormat", - listOf("§7You paid §c$mobKillCoinsFormat §7in total", "§7for starting the slayer quests.") - ) + " §7Slayer Spawn Costs: §c$slayerSpawnCostFormat", + listOf("§7You paid §c$slayerSpawnCostFormat §7in total", "§7for starting the slayer quests."), + ), ) profit += slayerSpawnCost } @@ -190,8 +192,8 @@ object SlayerProfitTracker { addAsSingletonList( Renderable.hoverTips( "§7Bosses killed: §e${slayerCompletedCount.addSeparators()}", - listOf("§7You killed the $itemLogCategory boss", "§e${slayerCompletedCount.addSeparators()} §7times.") - ) + listOf("§7You killed the $itemLogCategory boss", "§e${slayerCompletedCount.addSeparators()} §7times."), + ), ) addAsSingletonList(tracker.addTotalProfit(profit, data.slayerCompletedCount, "boss")) @@ -204,7 +206,7 @@ object SlayerProfitTracker { val text = " §6Mob kill coins§7: §6$mobKillCoinsFormat" val lore = listOf( "§7Killing mobs gives you coins (more with scavenger)", - "§7You got §e$mobKillCoinsFormat §7coins in total this way" + "§7You got §e$mobKillCoinsFormat §7coins in total this way", ) text to lore diff --git a/src/main/java/at/hannibal2/skyhanni/utils/ItemUtils.kt b/src/main/java/at/hannibal2/skyhanni/utils/ItemUtils.kt index 612f048de..1a75b4cbc 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/ItemUtils.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/ItemUtils.kt @@ -68,10 +68,9 @@ object ItemUtils { } // TODO change else janni is sad - fun ItemStack.isCoopSoulBound(): Boolean = - getLore().any { - it == "§8§l* §8Co-op Soulbound §8§l*" || it == "§8§l* §8Soulbound §8§l*" - } + fun ItemStack.isCoopSoulBound(): Boolean = getLore().any { + it == "§8§l* §8Co-op Soulbound §8§l*" || it == "§8§l* §8Soulbound §8§l*" + } // TODO change else janni is sad fun ItemStack.isSoulBound(): Boolean = getLore().any { it == "§8§l* §8Soulbound §8§l*" } @@ -82,8 +81,7 @@ object ItemUtils { fun getItemsInInventory(withCursorItem: Boolean = false): List<ItemStack> { val list: LinkedList<ItemStack> = LinkedList() - val player = Minecraft.getMinecraft().thePlayer - ?: ErrorManager.skyHanniError("getItemsInInventoryWithSlots: player is null!") + val player = Minecraft.getMinecraft().thePlayer ?: ErrorManager.skyHanniError("getItemsInInventoryWithSlots: player is null!") for (slot in player.openContainer.inventorySlots) { if (slot.hasStack) { @@ -138,8 +136,8 @@ object ItemUtils { if (tagCompound == null) return null val nbt = tagCompound if (!nbt.hasKey("SkullOwner")) return null - return nbt.getCompoundTag("SkullOwner").getCompoundTag("Properties") - .getTagList("textures", Constants.NBT.TAG_COMPOUND).getCompoundTagAt(0).getString("Value") + return nbt.getCompoundTag("SkullOwner").getCompoundTag("Properties").getTagList("textures", Constants.NBT.TAG_COMPOUND) + .getCompoundTagAt(0).getString("Value") } fun ItemStack.getSkullOwner(): String? { @@ -208,8 +206,7 @@ object ItemUtils { for (line in this.getLore().reversed()) { val (category, rarity) = UtilsPatterns.rarityLoreLinePattern.matchMatcher(line) { - group("itemCategory").replace(" ", "_") to - group("rarity").replace(" ", "_") + group("itemCategory").replace(" ", "_") to group("rarity").replace(" ", "_") } ?: continue val itemCategory = getItemCategory(category, name, cleanName) @@ -290,8 +287,7 @@ object ItemUtils { return data.itemRarity } - private fun itemRarityLastCheck(data: CachedItemData) = - data.itemRarityLastCheck.passedSince() > 10.seconds + private fun itemRarityLastCheck(data: CachedItemData) = data.itemRarityLastCheck.passedSince() > 10.seconds /** * Use when comparing the name (e.g. regex), not for showing to the user @@ -391,6 +387,9 @@ object ItemUtils { val NEUInternalName.itemNameWithoutColor: String get() = itemName.removeColor() + val NEUInternalName.readableInternalName: String + get() = asString().replace("_", " ").lowercase() + private fun NEUInternalName.grabItemName(): String { if (this == NEUInternalName.WISP_POTION) { return "§fWisp's Ice-Flavored Water" diff --git a/src/main/java/at/hannibal2/skyhanni/utils/NEUInternalName.kt b/src/main/java/at/hannibal2/skyhanni/utils/NEUInternalName.kt index 18568869a..6d0eb33e5 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/NEUInternalName.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/NEUInternalName.kt @@ -1,5 +1,7 @@ package at.hannibal2.skyhanni.utils +import at.hannibal2.skyhanni.utils.NEUItems.getItemStackOrNull + class NEUInternalName private constructor(private val internalName: String) { companion object { @@ -20,7 +22,25 @@ class NEUInternalName private constructor(private val internalName: String) { } fun fromItemNameOrNull(itemName: String): NEUInternalName? = - ItemNameResolver.getInternalNameOrNull(itemName.removeSuffix(" Pet")) + ItemNameResolver.getInternalNameOrNull(itemName.removeSuffix(" Pet")) ?: getCoins(itemName) + + fun fromItemNameOrInternalName(itemName: String): NEUInternalName = + fromItemNameOrNull(itemName) ?: itemName.asInternalName() + + private fun getCoins(itemName: String): NEUInternalName? = if (isCoins(itemName)) SKYBLOCK_COIN else null + + private fun isCoins(itemName: String): Boolean = + itemName.lowercase().let { + when (it) { + "coin", "coins", + "skyblock coin", "skyblock coins", + "skyblock_coin", "skyblock_coins", + -> true + + else -> false + } + } + fun fromItemName(itemName: String): NEUInternalName = fromItemNameOrNull(itemName) ?: run { val name = "itemName:$itemName" @@ -52,4 +72,6 @@ class NEUInternalName private constructor(private val internalName: String) { fun replace(oldValue: String, newValue: String) = internalName.replace(oldValue.uppercase(), newValue.uppercase()).asInternalName() + + fun isKnownItem(): Boolean = getItemStackOrNull() != null || this == SKYBLOCK_COIN } diff --git a/src/main/java/at/hannibal2/skyhanni/utils/tracker/ItemTrackerData.kt b/src/main/java/at/hannibal2/skyhanni/utils/tracker/ItemTrackerData.kt index 4b871377b..bce63e2d1 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/tracker/ItemTrackerData.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/tracker/ItemTrackerData.kt @@ -24,12 +24,17 @@ abstract class ItemTrackerData : TrackerData() { resetItems() } - fun addItem(internalName: NEUInternalName, stackSize: Int) { + fun addItem(internalName: NEUInternalName, amount: Int, command: Boolean) { val item = items.getOrPut(internalName) { TrackedItem() } - item.timesGained++ - item.totalAmount += stackSize + if (!command) { + item.timesGained++ + } + item.totalAmount += amount item.lastTimeUpdated = SimpleTimeMark.now() + if (command && item.totalAmount <= 0) { + items.remove(internalName) + } } @Expose diff --git a/src/main/java/at/hannibal2/skyhanni/utils/tracker/SkyHanniItemTracker.kt b/src/main/java/at/hannibal2/skyhanni/utils/tracker/SkyHanniItemTracker.kt index 684a7eb00..e7af81cea 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/tracker/SkyHanniItemTracker.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/tracker/SkyHanniItemTracker.kt @@ -3,11 +3,13 @@ package at.hannibal2.skyhanni.utils.tracker import at.hannibal2.skyhanni.SkyHanniMod import at.hannibal2.skyhanni.config.storage.ProfileSpecificStorage import at.hannibal2.skyhanni.data.SlayerAPI +import at.hannibal2.skyhanni.data.TrackerManager import at.hannibal2.skyhanni.utils.ChatUtils import at.hannibal2.skyhanni.utils.CollectionUtils.addAsSingletonList import at.hannibal2.skyhanni.utils.CollectionUtils.sortedDesc import at.hannibal2.skyhanni.utils.ItemPriceSource import at.hannibal2.skyhanni.utils.ItemUtils.itemName +import at.hannibal2.skyhanni.utils.ItemUtils.readableInternalName import at.hannibal2.skyhanni.utils.KeyboardManager import at.hannibal2.skyhanni.utils.LorenzUtils import at.hannibal2.skyhanni.utils.LorenzUtils.addSelector @@ -26,23 +28,29 @@ class SkyHanniItemTracker<Data : ItemTrackerData>( ) : SkyHanniTracker<Data>(name, createNewSession, getStorage, drawDisplay) { companion object { - val SKYBLOCK_COIN = NEUInternalName.SKYBLOCK_COIN } - fun addCoins(coins: Int) { - addItem(SKYBLOCK_COIN, coins) - } - - fun addItem(internalName: NEUInternalName, amount: Int) { + fun addItem(internalName: NEUInternalName, amount: Int, command: Boolean) { modify { - it.addItem(internalName, amount) + it.addItem(internalName, amount, command) } - getSharedTracker()?.let { - val hidden = it.get(DisplayMode.TOTAL).items[internalName]!!.hidden - it.get(DisplayMode.SESSION).items[internalName]!!.hidden = hidden + getSharedTracker()?.let { sharedData -> + sharedData.get(DisplayMode.TOTAL).items[internalName]?.let { data -> + sharedData.get(DisplayMode.SESSION).items[internalName]!!.hidden = data.hidden + } } + if (command) { + TrackerManager.commandEditTrackerSuccess = true + val displayName = internalName.itemName + if (amount > 0) { + ChatUtils.chat("Manually added to $name: §r$displayName §7(${amount}x§7)") + } else { + ChatUtils.chat("Manually removed from $name: §r$displayName §7(${-amount}x§7)") + } + return + } // TODO move the function to common val (itemName, price) = SlayerAPI.getItemNameAndPrice(internalName, amount) if (config.warnings.chat && price >= config.warnings.minimumChat) { @@ -62,7 +70,7 @@ class SkyHanniItemTracker<Data : ItemTrackerData>( onChange = { config.priceSource = ItemPriceSource.entries[it.ordinal] // todo avoid ordinal update() - } + }, ) } } @@ -140,7 +148,7 @@ class SkyHanniItemTracker<Data : ItemTrackerData>( } update() - } + }, ) else Renderable.string(displayName) lists.addAsSingletonList(renderable) @@ -172,6 +180,12 @@ class SkyHanniItemTracker<Data : ItemTrackerData>( } add("§eClick to " + (if (hidden) "show" else "hide") + "!") add("§eControl + Click to remove this item!") + + add("") + add("§7Use §e/shedittracker ${internalName.readableInternalName} <amount>") + add("§7to edit the number.") + add("§7Use negative numbers to remove items.") + if (SkyHanniMod.feature.dev.debug.enabled) { add("") add("§7${internalName}") |