aboutsummaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/features/inventory/InventoryConfig.java6
-rw-r--r--src/main/java/at/hannibal2/skyhanni/features/inventory/ActiveBeaconEffect.kt69
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
+}