aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/io
diff options
context:
space:
mode:
authorLorenz <lo.scherf@gmail.com>2022-07-30 22:57:32 +0200
committerLorenz <lo.scherf@gmail.com>2022-07-30 22:57:32 +0200
commit55a7d9426f50f67ed4e39962238dad018dfc6b37 (patch)
treed81502036d024af79d9ff6108142f67df02460ad /src/main/java/io
parentd7d365997d8e42791403d20c6a0bb1ea8f7a74db (diff)
downloadNotEnoughUpdates-55a7d9426f50f67ed4e39962238dad018dfc6b37.tar.gz
NotEnoughUpdates-55a7d9426f50f67ed4e39962238dad018dfc6b37.tar.bz2
NotEnoughUpdates-55a7d9426f50f67ed4e39962238dad018dfc6b37.zip
moved overlay hover of repo logic into api class and removed other static instances
Diffstat (limited to 'src/main/java/io')
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/NotEnoughUpdates.java8
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperManager.java14
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlay.java192
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlayHover.java161
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperTooltips.java10
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperChatLoader.java13
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperInventoryLoader.java16
7 files changed, 228 insertions, 186 deletions
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/NotEnoughUpdates.java b/src/main/java/io/github/moulberry/notenoughupdates/NotEnoughUpdates.java
index eeb6f096..17886a04 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/NotEnoughUpdates.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/NotEnoughUpdates.java
@@ -295,14 +295,8 @@ public class NotEnoughUpdates {
MinecraftForge.EVENT_BUS.register(new OldAnimationChecker());
MinecraftForge.EVENT_BUS.register(new SignCalculator());
MinecraftForge.EVENT_BUS.register(TrophyRewardOverlay.getInstance());
-
- MinecraftForge.EVENT_BUS.register(MinionHelperInventoryLoader.getInstance());
- MinecraftForge.EVENT_BUS.register(MinionHelperOverlay.getInstance());
- MinecraftForge.EVENT_BUS.register(MinionHelperTooltips.getInstance());
- MinecraftForge.EVENT_BUS.register(MinionHelperManager.getInstance());
- MinecraftForge.EVENT_BUS.register(MinionHelperChatLoader.getInstance());
-
MinecraftForge.EVENT_BUS.register(PowerStoneStatsDisplay.getInstance());
+ MinecraftForge.EVENT_BUS.register(MinionHelperManager.getInstance());
MinecraftForge.EVENT_BUS.register(navigation);
if (Minecraft.getMinecraft().getResourceManager() instanceof IReloadableResourceManager) {
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperManager.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperManager.java
index ac11be50..53fb06d3 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperManager.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperManager.java
@@ -21,6 +21,8 @@ package io.github.moulberry.notenoughupdates.miscgui.minionhelper;
import io.github.moulberry.notenoughupdates.NotEnoughUpdates;
import io.github.moulberry.notenoughupdates.miscgui.minionhelper.loaders.MinionHelperApiLoader;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.loaders.MinionHelperChatLoader;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.loaders.MinionHelperInventoryLoader;
import io.github.moulberry.notenoughupdates.miscgui.minionhelper.loaders.MinionHelperRepoLoader;
import io.github.moulberry.notenoughupdates.util.Utils;
import net.minecraft.client.Minecraft;
@@ -41,6 +43,10 @@ public class MinionHelperManager {
private final MinionHelperRequirementsManager requirementsManager = new MinionHelperRequirementsManager(this);
private final MinionHelperApiLoader api = new MinionHelperApiLoader(this);
private final MinionHelperRepoLoader repo = new MinionHelperRepoLoader(this);
+ private final MinionHelperOverlay overlay = new MinionHelperOverlay(this);
+ private final MinionHelperTooltips tooltips = new MinionHelperTooltips(this);
+ private final MinionHelperChatLoader chatLoader = new MinionHelperChatLoader(this);
+ private final MinionHelperInventoryLoader inventoryLoader = new MinionHelperInventoryLoader(this);
public static MinionHelperManager getInstance() {
if (instance == null) {
@@ -53,6 +59,10 @@ public class MinionHelperManager {
MinecraftForge.EVENT_BUS.register(priceCalculation);
MinecraftForge.EVENT_BUS.register(api);
MinecraftForge.EVENT_BUS.register(repo);
+ MinecraftForge.EVENT_BUS.register(overlay);
+ MinecraftForge.EVENT_BUS.register(tooltips);
+ MinecraftForge.EVENT_BUS.register(chatLoader);
+ MinecraftForge.EVENT_BUS.register(inventoryLoader);
}
public boolean inCraftedMinionsInventory() {
@@ -188,4 +198,8 @@ public class MinionHelperManager {
public MinionHelperRepoLoader getRepo() {
return repo;
}
+
+ public MinionHelperOverlay getOverlay() {
+ return overlay;
+ }
}
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlay.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlay.java
index 81fd0801..e9cb0a53 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlay.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlay.java
@@ -19,18 +19,12 @@
package io.github.moulberry.notenoughupdates.miscgui.minionhelper;
-import com.google.common.collect.ArrayListMultimap;
import com.google.common.collect.Lists;
import io.github.moulberry.notenoughupdates.NotEnoughUpdates;
import io.github.moulberry.notenoughupdates.miscgui.TrophyRewardOverlay;
-import io.github.moulberry.notenoughupdates.miscgui.minionhelper.loaders.MinionHelperRepoLoader;
import io.github.moulberry.notenoughupdates.miscgui.minionhelper.renderables.RenderableObject;
import io.github.moulberry.notenoughupdates.miscgui.minionhelper.renderables.RenderableText;
-import io.github.moulberry.notenoughupdates.miscgui.minionhelper.requirements.CollectionRequirement;
-import io.github.moulberry.notenoughupdates.miscgui.minionhelper.requirements.MinionRequirement;
-import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.CraftingSource;
import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.MinionSource;
-import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.NpcSource;
import io.github.moulberry.notenoughupdates.mixins.AccessorGuiContainer;
import io.github.moulberry.notenoughupdates.util.NotificationHandler;
import io.github.moulberry.notenoughupdates.util.Utils;
@@ -49,25 +43,20 @@ import org.lwjgl.input.Keyboard;
import org.lwjgl.input.Mouse;
import org.lwjgl.opengl.GL11;
-import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;
-import java.util.List;
import java.util.Map;
public class MinionHelperOverlay {
- private static MinionHelperOverlay instance = null;
- private final MinionHelperManager manager = MinionHelperManager.getInstance();
- private Minion lastHovered = null;
+ private final MinionHelperManager manager;
+ private final MinionHelperOverlayHover hover;
private LinkedHashMap<String, RenderableObject> cacheRenderMapShift = null;
private LinkedHashMap<String, RenderableObject> cacheRenderMapNoShift = null;
- public static MinionHelperOverlay getInstance() {
- if (instance == null) {
- instance = new MinionHelperOverlay();
- }
- return instance;
+ public MinionHelperOverlay(MinionHelperManager manager) {
+ this.manager = manager;
+ hover = new MinionHelperOverlayHover(this, manager);
}
@SubscribeEvent
@@ -101,7 +90,7 @@ public class MinionHelperOverlay {
LinkedHashMap<String, RenderableObject> renderMap = getRenderMap();
- renderHover(renderMap);
+ hover.renderHover(renderMap);
render(event, renderMap);
}
@@ -111,9 +100,7 @@ public class MinionHelperOverlay {
if (!manager.isReadyToUse()) return;
if (!Mouse.getEventButtonState()) return;
- LinkedHashMap<String, RenderableObject> renderMap = getRenderMap();
-
- RenderableObject mouseObject = getObjectOverMouse(renderMap);
+ RenderableObject mouseObject = getObjectOverMouse(getRenderMap());
if (mouseObject != null) {
if (mouseObject instanceof MinionSource) {
@@ -124,139 +111,6 @@ public class MinionHelperOverlay {
}
}
- private RenderableObject getObjectOverMouse(LinkedHashMap<String, RenderableObject> renderMap) {
- GuiScreen gui = Minecraft.getMinecraft().currentScreen;
- if (!(gui instanceof GuiChest)) return null;
-
- int xSize = ((AccessorGuiContainer) gui).getXSize();
- int guiLeft = ((AccessorGuiContainer) gui).getGuiLeft();
- int guiTop = ((AccessorGuiContainer) gui).getGuiTop();
-
- int x = guiLeft + xSize + 4;
- int y = guiTop;
-
- final ScaledResolution scaledresolution = new ScaledResolution(Minecraft.getMinecraft());
- final int scaledWidth = scaledresolution.getScaledWidth();
- final int scaledHeight = scaledresolution.getScaledHeight();
- int mouseX = Mouse.getX() * scaledWidth / Minecraft.getMinecraft().displayWidth;
- int mouseY = scaledHeight - Mouse.getY() * scaledHeight / Minecraft.getMinecraft().displayHeight - 1;
-
- int index = 0;
- for (RenderableObject renderableObject : renderMap.values()) {
-
- if (mouseX > x && mouseX < x + 130 &&
- mouseY > y + index && mouseY < y + 13 + index) {
- return renderableObject;
- }
- index += 10;
- }
-
- return null;
- }
-
- private void renderHover(LinkedHashMap<String, RenderableObject> renderMap) {
- lastHovered = null;
-
- if (!(Minecraft.getMinecraft().currentScreen instanceof GuiChest)) return;
-
- final ScaledResolution scaledresolution = new ScaledResolution(Minecraft.getMinecraft());
- final int scaledWidth = scaledresolution.getScaledWidth();
- final int scaledHeight = scaledresolution.getScaledHeight();
- int mouseX = Mouse.getX() * scaledWidth / Minecraft.getMinecraft().displayWidth;
- int mouseY = scaledHeight - Mouse.getY() * scaledHeight / Minecraft.getMinecraft().displayHeight - 1;
-
- RenderableObject mouseObject = getObjectOverMouse(renderMap);
- if (mouseObject != null) {
- GlStateManager.pushMatrix();
- GlStateManager.scale(2f / scaledresolution.getScaleFactor(), 2f / scaledresolution.getScaleFactor(), 1);
- Utils.drawHoveringText(getTooltip(mouseObject),
- mouseX * scaledresolution.getScaleFactor() / 2,
- mouseY * scaledresolution.getScaleFactor() / 2,
- scaledWidth * scaledresolution.getScaleFactor() / 2,
- scaledHeight * scaledresolution.getScaleFactor() / 2, -1, Minecraft.getMinecraft().fontRendererObj
- );
- GlStateManager.popMatrix();
- }
- }
-
- private List<String> getTooltip(RenderableObject renderableObject) {
- List<String> lines = new ArrayList<>();
-
- if (renderableObject instanceof RenderableText) {
- RenderableText renderableText = (RenderableText) renderableObject;
- lines.addAll(renderableText.getLines());
- } else if (renderableObject instanceof MinionSource) {
- MinionSource minionSource = (MinionSource) renderableObject;
-
- Minion minion = minionSource.getMinion();
- lastHovered = minion;
- String displayName = minion.getDisplayName();
- lines.add("§9" + displayName + " " + minion.getTier());
- List<MinionRequirement> requirements = manager.getRequirementsManager().getRequirements(minionSource.getMinion());
- if (!requirements.isEmpty()) {
- for (MinionRequirement requirement : requirements) {
- //TODO maybe change the §7 color
- String color = manager.getRequirementsManager().meetRequirement(minion, requirement) ? "§a" : "§7";
- if (requirement instanceof CollectionRequirement && manager.getApi().isCollectionApiDisabled()) {
- color = "§cAPI DISABLED! §7";
- }
- lines.add(" §8- " + color + requirement.printDescription());
- }
- } else {
- lines.add("§cNo requirements loaded!");
- }
-
- if (minionSource instanceof CraftingSource) {
- CraftingSource craftingSource = (CraftingSource) minionSource;
- lines.add("");
- String format = manager.getPriceCalculation().calculateUpgradeCostsFormat(craftingSource, true);
- if (minion.getTier() == 1) {
- lines.add("§7Full crafting costs: " + format);
- } else {
- lines.add("§7Upgrade costs: " + format);
- }
- formatItems(lines, grabAllItems(craftingSource.getItems()));
-
- } else if (minionSource instanceof NpcSource) {
- NpcSource npcSource = (NpcSource) minionSource;
- String npcName = npcSource.getNpcName();
- lines.add("");
- lines.add("§7Buy from: §9" + npcName + " (NPC)");
- lines.add("");
- lines.add("§7Buy costs: " + manager.getPriceCalculation().calculateUpgradeCostsFormat(npcSource, true));
- lines.add(" §8- " + manager.getPriceCalculation().formatCoins(npcSource.getCoins()));
- formatItems(lines, grabAllItems(npcSource.getItems()));
- }
-
- lines.add("");
- lines.add("§eClick to view recipe");
- }
- return lines;
- }
-
- private void formatItems(List<String> lines, Map<String, Integer> allItems) {
- for (Map.Entry<String, Integer> entry : allItems.entrySet()) {
- String internalName = entry.getKey();
- String name = manager.getRepo().getDisplayName(internalName);
-
- int amount = entry.getValue();
- String amountText = amount != 1 ? amount + "§7x " : "";
- String price = manager.getPriceCalculation().formatCoins(manager.getPriceCalculation().getPrice(internalName) * amount);
- lines.add(" §8- §a" + amountText + "§f" + name + " " + price);
- }
- }
-
- private Map<String, Integer> grabAllItems(ArrayListMultimap<String, Integer> multimap) {
- Map<String, Integer> allItems = new HashMap<>();
- for (Map.Entry<String, Integer> entry : multimap.entries()) {
- String name = entry.getKey();
- int amount = entry.getValue();
- amount = allItems.getOrDefault(name, 0) + amount;
- allItems.put(name, amount);
- }
- return allItems;
- }
-
private Map<Minion, Long> getMissing(boolean shift) {
Map<Minion, Long> prices = new HashMap<>();
for (Minion minion : manager.getAllMinions().values()) {
@@ -292,7 +146,7 @@ public class MinionHelperOverlay {
String prefix = "";
if (renderableObject instanceof MinionSource) {
Minion minion = ((MinionSource) renderableObject).getMinion();
- if (lastHovered == minion) {
+ if (minion == hover.getLastHovered()) {
prefix = "§e";
}
}
@@ -354,4 +208,34 @@ public class MinionHelperOverlay {
return renderMap;
}
+
+ RenderableObject getObjectOverMouse(LinkedHashMap<String, RenderableObject> renderMap) {
+ GuiScreen gui = Minecraft.getMinecraft().currentScreen;
+ if (!(gui instanceof GuiChest)) return null;
+
+ int xSize = ((AccessorGuiContainer) gui).getXSize();
+ int guiLeft = ((AccessorGuiContainer) gui).getGuiLeft();
+ int guiTop = ((AccessorGuiContainer) gui).getGuiTop();
+
+ int x = guiLeft + xSize + 4;
+ int y = guiTop;
+
+ final ScaledResolution scaledresolution = new ScaledResolution(Minecraft.getMinecraft());
+ final int scaledWidth = scaledresolution.getScaledWidth();
+ final int scaledHeight = scaledresolution.getScaledHeight();
+ int mouseX = Mouse.getX() * scaledWidth / Minecraft.getMinecraft().displayWidth;
+ int mouseY = scaledHeight - Mouse.getY() * scaledHeight / Minecraft.getMinecraft().displayHeight - 1;
+
+ int index = 0;
+ for (RenderableObject renderableObject : renderMap.values()) {
+
+ if (mouseX > x && mouseX < x + 130 &&
+ mouseY > y + index && mouseY < y + 13 + index) {
+ return renderableObject;
+ }
+ index += 10;
+ }
+
+ return null;
+ }
}
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlayHover.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlayHover.java
new file mode 100644
index 00000000..8bc04731
--- /dev/null
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperOverlayHover.java
@@ -0,0 +1,161 @@
+/*
+ * Copyright (C) 2022 NotEnoughUpdates contributors
+ *
+ * This file is part of NotEnoughUpdates.
+ *
+ * NotEnoughUpdates is free software: you can redistribute it
+ * and/or modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation, either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * NotEnoughUpdates is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with NotEnoughUpdates. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+package io.github.moulberry.notenoughupdates.miscgui.minionhelper;
+
+import com.google.common.collect.ArrayListMultimap;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.renderables.RenderableObject;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.renderables.RenderableText;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.requirements.CollectionRequirement;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.requirements.MinionRequirement;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.CraftingSource;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.MinionSource;
+import io.github.moulberry.notenoughupdates.miscgui.minionhelper.sources.NpcSource;
+import io.github.moulberry.notenoughupdates.util.Utils;
+import net.minecraft.client.Minecraft;
+import net.minecraft.client.gui.ScaledResolution;
+import net.minecraft.client.gui.inventory.GuiChest;
+import net.minecraft.client.renderer.GlStateManager;
+import org.lwjgl.input.Mouse;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
+
+public class MinionHelperOverlayHover {
+
+ private final MinionHelperOverlay overlay;
+ private final MinionHelperManager manager;
+ private Minion lastHovered = null;
+
+ public MinionHelperOverlayHover(MinionHelperOverlay overlay, MinionHelperManager manager) {
+ this.overlay = overlay;
+ this.manager = manager;
+ }
+
+ void renderHover(LinkedHashMap<String, RenderableObject> renderMap) {
+ lastHovered = null;
+
+ if (!(Minecraft.getMinecraft().currentScreen instanceof GuiChest)) return;
+
+ final ScaledResolution scaledresolution = new ScaledResolution(Minecraft.getMinecraft());
+ final int scaledWidth = scaledresolution.getScaledWidth();
+ final int scaledHeight = scaledresolution.getScaledHeight();
+ int mouseX = Mouse.getX() * scaledWidth / Minecraft.getMinecraft().displayWidth;
+ int mouseY = scaledHeight - Mouse.getY() * scaledHeight / Minecraft.getMinecraft().displayHeight - 1;
+
+ RenderableObject mouseObject = overlay.getObjectOverMouse(renderMap);
+ if (mouseObject != null) {
+ GlStateManager.pushMatrix();
+ GlStateManager.scale(2f / scaledresolution.getScaleFactor(), 2f / scaledresolution.getScaleFactor(), 1);
+ Utils.drawHoveringText(getTooltip(mouseObject),
+ mouseX * scaledresolution.getScaleFactor() / 2,
+ mouseY * scaledresolution.getScaleFactor() / 2,
+ scaledWidth * scaledresolution.getScaleFactor() / 2,
+ scaledHeight * scaledresolution.getScaleFactor() / 2, -1, Minecraft.getMinecraft().fontRendererObj
+ );
+ GlStateManager.popMatrix();
+ }
+ }
+
+ private List<String> getTooltip(RenderableObject renderableObject) {
+ List<String> lines = new ArrayList<>();
+
+ if (renderableObject instanceof RenderableText) {
+ RenderableText renderableText = (RenderableText) renderableObject;
+ lines.addAll(renderableText.getLines());
+ } else if (renderableObject instanceof MinionSource) {
+ MinionSource minionSource = (MinionSource) renderableObject;
+
+ Minion minion = minionSource.getMinion();
+ lastHovered = minion;
+ String displayName = minion.getDisplayName();
+ lines.add("§9" + displayName + " " + minion.getTier());
+ List<MinionRequirement> requirements = manager.getRequirementsManager().getRequirements(minionSource.getMinion());
+ if (!requirements.isEmpty()) {
+ for (MinionRequirement requirement : requirements) {
+ //TODO maybe change the §7 color
+ String color = manager.getRequirementsManager().meetRequirement(minion, requirement) ? "§a" : "§7";
+ if (requirement instanceof CollectionRequirement && manager.getApi().isCollectionApiDisabled()) {
+ color = "§cAPI DISABLED! §7";
+ }
+ lines.add(" §8- " + color + requirement.printDescription());
+ }
+ } else {
+ lines.add("§cNo requirements loaded!");
+ }
+
+ if (minionSource instanceof CraftingSource) {
+ CraftingSource craftingSource = (CraftingSource) minionSource;
+ lines.add("");
+ String format = manager.getPriceCalculation().calculateUpgradeCostsFormat(craftingSource, true);
+ if (minion.getTier() == 1) {
+ lines.add("§7Full crafting costs: " + format);
+ } else {
+ lines.add("§7Upgrade costs: " + format);
+ }
+ formatItems(lines, grabAllItems(craftingSource.getItems()));
+
+ } else if (minionSource instanceof NpcSource) {
+ NpcSource npcSource = (NpcSource) minionSource;
+ String npcName = npcSource.getNpcName();
+ lines.add("");
+ lines.add("§7Buy from: §9" + npcName + " (NPC)");
+ lines.add("");
+ lines.add("§7Buy costs: " + manager.getPriceCalculation().calculateUpgradeCostsFormat(npcSource, true));
+ lines.add(" §8- " + manager.getPriceCalculation().formatCoins(npcSource.getCoins()));
+ formatItems(lines, grabAllItems(npcSource.getItems()));
+ }
+
+ lines.add("");
+ lines.add("§eClick to view recipe");
+ }
+ return lines;
+ }
+
+ private void formatItems(List<String> lines, Map<String, Integer> allItems) {
+ for (Map.Entry<String, Integer> entry : allItems.entrySet()) {
+ String internalName = entry.getKey();
+ String name = manager.getRepo().getDisplayName(internalName);
+
+ int amount = entry.getValue();
+ String amountText = amount != 1 ? amount + "§7x " : "";
+ String price = manager.getPriceCalculation().formatCoins(
+ manager.getPriceCalculation().getPrice(internalName) * amount);
+ lines.add(" §8- §a" + amountText + "§f" + name + " " + price);
+ }
+ }
+
+ private Map<String, Integer> grabAllItems(ArrayListMultimap<String, Integer> multimap) {
+ Map<String, Integer> allItems = new HashMap<>();
+ for (Map.Entry<String, Integer> entry : multimap.entries()) {
+ String name = entry.getKey();
+ int amount = entry.getValue();
+ amount = allItems.getOrDefault(name, 0) + amount;
+ allItems.put(name, amount);
+ }
+ return allItems;
+ }
+
+ public Minion getLastHovered() {
+ return lastHovered;
+ }
+}
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperTooltips.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperTooltips.java
index b92ee768..ee250b89 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperTooltips.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/MinionHelperTooltips.java
@@ -32,16 +32,12 @@ import org.lwjgl.input.Keyboard;
import java.util.List;
public class MinionHelperTooltips {
- private static MinionHelperTooltips instance = null;
- private final MinionHelperManager manager = MinionHelperManager.getInstance();
+ private final MinionHelperManager manager;
private boolean pressedShiftLast = false;
private boolean showFullCost = false;
- public static MinionHelperTooltips getInstance() {
- if (instance == null) {
- instance = new MinionHelperTooltips();
- }
- return instance;
+ public MinionHelperTooltips(MinionHelperManager manager) {
+ this.manager = manager;
}
@SubscribeEvent(priority = EventPriority.LOW)
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperChatLoader.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperChatLoader.java
index ed379354..36f6b515 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperChatLoader.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperChatLoader.java
@@ -29,14 +29,11 @@ import net.minecraftforge.fml.common.eventhandler.EventPriority;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
public class MinionHelperChatLoader {
- private static MinionHelperChatLoader instance = null;
- private final MinionHelperManager manager = MinionHelperManager.getInstance();
- public static MinionHelperChatLoader getInstance() {
- if (instance == null) {
- instance = new MinionHelperChatLoader();
- }
- return instance;
+ private final MinionHelperManager manager;
+
+ public MinionHelperChatLoader(MinionHelperManager manager) {
+ this.manager = manager;
}
@SubscribeEvent(priority = EventPriority.LOW, receiveCanceled = true)
@@ -61,7 +58,7 @@ public class MinionHelperChatLoader {
String name = text.substring(rawTier.length() + 1);
setCrafted(manager.getMinionByName(name, tier));
- MinionHelperOverlay.getInstance().resetCache();
+ manager.getOverlay().resetCache();
}
if (message.startsWith("§r§7Switching to profile ")) {
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperInventoryLoader.java b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperInventoryLoader.java
index 249b49ee..b8943c38 100644
--- a/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperInventoryLoader.java
+++ b/src/main/java/io/github/moulberry/notenoughupdates/miscgui/minionhelper/loaders/MinionHelperInventoryLoader.java
@@ -38,19 +38,15 @@ import java.util.ArrayList;
import java.util.List;
public class MinionHelperInventoryLoader {
- private static MinionHelperInventoryLoader instance = null;
- private final MinionHelperManager manager = MinionHelperManager.getInstance();
private final List<String> loadedAlready = new ArrayList<>();
-
- public static MinionHelperInventoryLoader getInstance() {
- if (instance == null) {
- instance = new MinionHelperInventoryLoader();
- }
- return instance;
- }
+ private final MinionHelperManager manager;
int ticks = 0;
+ public MinionHelperInventoryLoader(MinionHelperManager manager) {
+ this.manager = manager;
+ }
+
@SubscribeEvent
public void onTick(TickEvent.ClientTickEvent event) {
if (!NotEnoughUpdates.INSTANCE.hasSkyblockScoreboard()) return;
@@ -112,7 +108,7 @@ public class MinionHelperInventoryLoader {
}
}
if (crafted > 0) {
- MinionHelperOverlay.getInstance().resetCache();
+ manager.getOverlay().resetCache();
}
}
}