From 0efebf46bc17735d12fb718161a440c1113e2b6d Mon Sep 17 00:00:00 2001 From: Mixces Date: Fri, 9 Aug 2024 20:25:28 -0500 Subject: [PATCH] add 1.12.2 compatibility to "Allow drop key to work properly with side mouse buttons" --- .../GuiContainerMixin_MouseBindFix.java | 24 +++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/src/main/java/club/sk1er/patcher/mixins/bugfixes/mousebindfix/GuiContainerMixin_MouseBindFix.java b/src/main/java/club/sk1er/patcher/mixins/bugfixes/mousebindfix/GuiContainerMixin_MouseBindFix.java index 86c5e324..8d5ab502 100644 --- a/src/main/java/club/sk1er/patcher/mixins/bugfixes/mousebindfix/GuiContainerMixin_MouseBindFix.java +++ b/src/main/java/club/sk1er/patcher/mixins/bugfixes/mousebindfix/GuiContainerMixin_MouseBindFix.java @@ -2,6 +2,9 @@ import net.minecraft.client.gui.GuiScreen; import net.minecraft.client.gui.inventory.GuiContainer; +//#if MC==11202 +//$$ import net.minecraft.inventory.ClickType; +//#endif import net.minecraft.inventory.Slot; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Shadow; @@ -11,19 +14,27 @@ @Mixin(GuiContainer.class) public abstract class GuiContainerMixin_MouseBindFix extends GuiScreen { + //#if MC==10809 @Shadow private Slot theSlot; @Shadow protected abstract void handleMouseClick(Slot par1, int par2, int par3, int par4); + //#else + //$$ @Shadow + //$$ private Slot hoveredSlot; + //$$ + //$$ @Shadow + //$$ protected abstract void handleMouseClick(Slot slotIn, int slotId, int mouseButton, ClickType type); + //#endif - @Inject(method = "mouseClicked", at = @At("HEAD"), cancellable = true) + @Inject(method = "mouseClicked", at = @At("HEAD")) private void patcher$checkCloseClick(int mouseX, int mouseY, int mouseButton, CallbackInfo ci) { int keyCode = mouseButton - 100; if (keyCode == mc.gameSettings.keyBindInventory.getKeyCode()) { mc.thePlayer.closeScreen(); - ci.cancel(); } + //#if MC==10809 if (theSlot != null && theSlot.getHasStack()) { if (keyCode == mc.gameSettings.keyBindPickBlock.getKeyCode()) { handleMouseClick(theSlot, theSlot.slotNumber, 0, 3); @@ -31,5 +42,14 @@ public abstract class GuiContainerMixin_MouseBindFix extends GuiScreen { handleMouseClick(theSlot, theSlot.slotNumber, isCtrlKeyDown() ? 1 : 0, 4); } } + //#else + //$$ if (hoveredSlot != null && hoveredSlot.getHasStack()) { + //$$ if (mc.gameSettings.keyBindPickBlock.isActiveAndMatches(keyCode)) { + //$$ handleMouseClick(hoveredSlot, hoveredSlot.slotNumber, 0, ClickType.CLONE); + //$$ } else if (mc.gameSettings.keyBindDrop.isActiveAndMatches(keyCode)) { + //$$ handleMouseClick(hoveredSlot, hoveredSlot.slotNumber, isCtrlKeyDown() ? 1 : 0, ClickType.THROW); + //$$ } + //$$ } + //#endif } }