diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java | 6 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/features/inventory/ActiveBeaconEffect.kt | 69 |
2 files changed, 75 insertions, 0 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java b/src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java index 062f29b30..510f953ca 100644 --- a/src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java +++ b/src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java @@ -292,4 +292,10 @@ public class InventoryConfig { @ConfigEditorBoolean @FeatureToggle public boolean hexAsColorInLore = true; + + @Expose + @ConfigOption(name = "Highlight Active Beacon Effect", desc = "Highlights the currently selected beacon effect in the beacon inventory.") + @ConfigEditorBoolean + @FeatureToggle + public boolean highlightActiveBeaconEffect = true; } diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/ActiveBeaconEffect.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/ActiveBeaconEffect.kt new file mode 100644 index 000000000..d0bc67fde --- /dev/null +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/ActiveBeaconEffect.kt @@ -0,0 +1,69 @@ +package at.hannibal2.skyhanni.features.inventory + +import at.hannibal2.skyhanni.SkyHanniMod +import at.hannibal2.skyhanni.data.IslandType +import at.hannibal2.skyhanni.events.GuiContainerEvent +import at.hannibal2.skyhanni.events.InventoryCloseEvent +import at.hannibal2.skyhanni.events.InventoryFullyOpenedEvent +import at.hannibal2.skyhanni.skyhannimodule.SkyHanniModule +import at.hannibal2.skyhanni.utils.ItemUtils.getLore +import at.hannibal2.skyhanni.utils.LorenzColor +import at.hannibal2.skyhanni.utils.LorenzUtils.isInIsland +import at.hannibal2.skyhanni.utils.RegexUtils.matches +import at.hannibal2.skyhanni.utils.RenderUtils.highlight +import at.hannibal2.skyhanni.utils.repopatterns.RepoPattern +import net.minecraftforge.fml.common.eventhandler.SubscribeEvent + +@SkyHanniModule +object ActiveBeaconEffect { + + val config get() = SkyHanniMod.feature.inventory + + private val patternGroup = RepoPattern.group("inventory.activebeaconeffect") + + /** + * REGEX-TEST: Profile Stat Upgrades + */ + private val inventoryPattern by patternGroup.pattern( + "inventory", + "Profile Stat Upgrades", + ) + + /** + * REGEX-TEST: §aActive stat boost! + */ + private val slotPattern by patternGroup.pattern( + "slot.active", + "§aActive stat boost!", + ) + + private var slot: Int? = null + + @SubscribeEvent + fun onInventoryFullyOpened(event: InventoryFullyOpenedEvent) { + if (!isEnabled()) return + if (!inventoryPattern.matches(event.inventoryName)) { + slot = null + return + } + + slot = event.inventoryItems.filter { (_, stack) -> + stack.getLore().any { slotPattern.matches(it) } + }.firstNotNullOfOrNull { it.key } + } + + @SubscribeEvent + fun onInventoryClose(event: InventoryCloseEvent) { + slot = null + } + + @SubscribeEvent + fun onBackgroundDrawn(event: GuiContainerEvent.BackgroundDrawnEvent) { + if (!isEnabled()) return + val slot = slot ?: return + + event.gui.inventorySlots.getSlot(slot) highlight LorenzColor.GREEN + } + + fun isEnabled() = IslandType.PRIVATE_ISLAND.isInIsland() && config.highlightActiveBeaconEffect +} |