aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java
diff options
context:
space:
mode:
authorKevinthegreat <92656833+kevinthegreat1@users.noreply.github.com>2024-06-08 12:17:10 +0800
committerKevinthegreat <92656833+kevinthegreat1@users.noreply.github.com>2024-06-08 12:17:10 +0800
commitf9c514db798a32956a9c96201c8871f44501a7a4 (patch)
treefc6d4c205b6feeeeb58c8932af1d00cca0a16b2a /src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java
parentdbd04ba00b94fcc28bb6d801c8e49ecf6e791ce0 (diff)
downloadSkyblocker-f9c514db798a32956a9c96201c8871f44501a7a4.tar.gz
Skyblocker-f9c514db798a32956a9c96201c8871f44501a7a4.tar.bz2
Skyblocker-f9c514db798a32956a9c96201c8871f44501a7a4.zip
Move tooltip injection point
Diffstat (limited to 'src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java')
-rw-r--r--src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java22
1 files changed, 9 insertions, 13 deletions
diff --git a/src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java b/src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java
index e4dc09fb..35b91639 100644
--- a/src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java
+++ b/src/main/java/de/hysky/skyblocker/mixins/HandledScreenMixin.java
@@ -1,7 +1,6 @@
package de.hysky.skyblocker.mixins;
-import com.llamalad7.mixinextras.injector.wrapoperation.Operation;
-import com.llamalad7.mixinextras.injector.wrapoperation.WrapOperation;
+import com.llamalad7.mixinextras.injector.ModifyReturnValue;
import com.llamalad7.mixinextras.sugar.Local;
import com.mojang.blaze3d.systems.RenderSystem;
import de.hysky.skyblocker.SkyblockerMod;
@@ -24,11 +23,9 @@ import de.hysky.skyblocker.skyblock.quicknav.QuickNavButton;
import de.hysky.skyblocker.utils.ItemUtils;
import de.hysky.skyblocker.utils.Utils;
import de.hysky.skyblocker.utils.render.gui.ContainerSolver;
-import net.minecraft.client.font.TextRenderer;
import net.minecraft.client.gui.DrawContext;
import net.minecraft.client.gui.screen.Screen;
import net.minecraft.client.gui.screen.ingame.HandledScreen;
-import net.minecraft.client.item.TooltipData;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.inventory.SimpleInventory;
import net.minecraft.item.Item;
@@ -41,10 +38,7 @@ import net.minecraft.text.Text;
import net.minecraft.util.Identifier;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
-import org.spongepowered.asm.mixin.Final;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.Shadow;
-import org.spongepowered.asm.mixin.Unique;
+import org.spongepowered.asm.mixin.*;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.ModifyVariable;
@@ -53,7 +47,6 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
import java.util.List;
import java.util.Map;
-import java.util.Optional;
import java.util.Set;
import java.util.regex.Matcher;
@@ -101,6 +94,9 @@ public abstract class HandledScreenMixin<T extends ScreenHandler> extends Screen
@Final
protected T handler;
+ @Shadow
+ protected abstract List<Text> getTooltipFromItem(ItemStack stack);
+
@Unique
private List<QuickNavButton> quickNavButtons;
@@ -182,7 +178,7 @@ public abstract class HandledScreenMixin<T extends ScreenHandler> extends Screen
// Compactor Preview
if (SkyblockerConfigManager.get().uiAndVisuals.compactorDeletorPreview) {
Matcher matcher = CompactorDeletorPreview.NAME.matcher(ItemUtils.getItemId(stack));
- if (matcher.matches() && CompactorDeletorPreview.drawPreview(context, stack, matcher.group("type"), matcher.group("size"), x, y)) {
+ if (matcher.matches() && CompactorDeletorPreview.drawPreview(context, stack, getTooltipFromItem(stack), matcher.group("type"), matcher.group("size"), x, y)) {
ci.cancel();
}
}
@@ -194,9 +190,9 @@ public abstract class HandledScreenMixin<T extends ScreenHandler> extends Screen
}
@SuppressWarnings("deprecation")
- @WrapOperation(method = "drawMouseoverTooltip", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/DrawContext;drawTooltip(Lnet/minecraft/client/font/TextRenderer;Ljava/util/List;Ljava/util/Optional;II)V"))
- private void skyblocker$tooltips$drawMouseoverTooltip(DrawContext context, TextRenderer textRenderer, List<Text> text, Optional<TooltipData> data, int x, int y, Operation<Void> original) {
- original.call(context, textRenderer, TooltipManager.addToTooltip(text, focusedSlot), data, x, y);
+ @ModifyReturnValue(method = "getTooltipFromItem", at = @At("RETURN"))
+ private List<Text> skyblocker$tooltips$addToTooltip(List<Text> tooltip) {
+ return TooltipManager.addToTooltip(tooltip, focusedSlot);
}
@ModifyVariable(method = "drawSlot", at = @At(value = "LOAD", ordinal = 3), ordinal = 0)