aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/com
diff options
context:
space:
mode:
authorWyvest <45589059+Wyvest@users.noreply.github.com>2021-12-21 21:17:29 +0700
committerWyvest <45589059+Wyvest@users.noreply.github.com>2021-12-21 21:17:29 +0700
commit7ffe65977bef2a34262cf8690ba335ae5d915ef0 (patch)
treeb03d4b0ee12c999a223e16e2103e60dd7751cbe2 /src/main/java/com
parent870da2e7fcf370233c9e64d55dd0295cec6665f0 (diff)
downloadChatting-7ffe65977bef2a34262cf8690ba335ae5d915ef0.tar.gz
Chatting-7ffe65977bef2a34262cf8690ba335ae5d915ef0.tar.bz2
Chatting-7ffe65977bef2a34262cf8690ba335ae5d915ef0.zip
Chat tabs
Diffstat (limited to 'src/main/java/com')
-rw-r--r--src/main/java/com/raeids/stratus/mixin/GuiChatMixin.java33
-rw-r--r--src/main/java/com/raeids/stratus/mixin/GuiNewChatMixin.java11
-rw-r--r--src/main/java/com/raeids/stratus/mixin/GuiUtilRenderComponentsMixin.java26
3 files changed, 54 insertions, 16 deletions
diff --git a/src/main/java/com/raeids/stratus/mixin/GuiChatMixin.java b/src/main/java/com/raeids/stratus/mixin/GuiChatMixin.java
index be04586..4f9b2eb 100644
--- a/src/main/java/com/raeids/stratus/mixin/GuiChatMixin.java
+++ b/src/main/java/com/raeids/stratus/mixin/GuiChatMixin.java
@@ -1,7 +1,9 @@
package com.raeids.stratus.mixin;
import com.raeids.stratus.config.StratusConfig;
-import com.raeids.stratus.hook.ChatHookKt;
+import com.raeids.stratus.hook.ChatSearchingKt;
+import com.raeids.stratus.hook.ChatTab;
+import com.raeids.stratus.hook.ChatTabs;
import net.minecraft.client.gui.GuiChat;
import net.minecraft.client.gui.GuiScreen;
import org.spongepowered.asm.mixin.Mixin;
@@ -15,46 +17,49 @@ public abstract class GuiChatMixin extends GuiScreen {
@Inject(method = "initGui", at = @At("TAIL"))
private void init(CallbackInfo ci) {
if (StratusConfig.INSTANCE.getChatSearch()) {
- ChatHookKt.initGui();
+ ChatSearchingKt.initGui();
+ }
+ for (ChatTab chatTab : ChatTabs.INSTANCE.getTabs()) {
+ buttonList.add(chatTab.getButton());
}
}
@Inject(method = "drawScreen", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/GuiTextField;drawTextBox()V", shift = At.Shift.AFTER))
private void yeah(int mouseX, int mouseY, float partialTicks, CallbackInfo ci) {
- if (ChatHookKt.getInputField() != null) {
- ChatHookKt.getInputField().drawTextBox();
+ if (ChatSearchingKt.getInputField() != null) {
+ ChatSearchingKt.getInputField().drawTextBox();
}
}
@Inject(method = "onGuiClosed", at = @At("TAIL"))
private void onGuiClosed(CallbackInfo ci) {
- ChatHookKt.setInputField(null);
- ChatHookKt.setPrevText("");
+ ChatSearchingKt.setInputField(null);
+ ChatSearchingKt.setPrevText("");
}
@Inject(method = "updateScreen", at = @At("HEAD"))
private void updateScreen(CallbackInfo ci) {
- ChatHookKt.updateScreen();
+ ChatSearchingKt.updateScreen();
}
@Inject(method = "keyTyped", at = @At("HEAD"), cancellable = true)
private void keyTyped(char typedChar, int keyCode, CallbackInfo ci) {
- if (ChatHookKt.getInputField() != null) {
- if (ChatHookKt.getInputField().isFocused()) {
+ if (ChatSearchingKt.getInputField() != null) {
+ if (ChatSearchingKt.getInputField().isFocused()) {
ci.cancel();
- if (keyCode == 1 && ChatHookKt.getInputField().isFocused()) {
- ChatHookKt.getInputField().setFocused(false);
+ if (keyCode == 1 && ChatSearchingKt.getInputField().isFocused()) {
+ ChatSearchingKt.getInputField().setFocused(false);
return;
}
- ChatHookKt.getInputField().textboxKeyTyped(typedChar, keyCode);
+ ChatSearchingKt.getInputField().textboxKeyTyped(typedChar, keyCode);
}
}
}
@Inject(method = "mouseClicked", at = @At("HEAD"))
private void mouseClicked(int mouseX, int mouseY, int mouseButton, CallbackInfo ci) {
- if (ChatHookKt.getInputField() != null) {
- ChatHookKt.getInputField().mouseClicked(mouseX, mouseY, mouseButton);
+ if (ChatSearchingKt.getInputField() != null) {
+ ChatSearchingKt.getInputField().mouseClicked(mouseX, mouseY, mouseButton);
}
}
}
diff --git a/src/main/java/com/raeids/stratus/mixin/GuiNewChatMixin.java b/src/main/java/com/raeids/stratus/mixin/GuiNewChatMixin.java
index 48e2525..bbe1e9b 100644
--- a/src/main/java/com/raeids/stratus/mixin/GuiNewChatMixin.java
+++ b/src/main/java/com/raeids/stratus/mixin/GuiNewChatMixin.java
@@ -1,10 +1,12 @@
package com.raeids.stratus.mixin;
import com.raeids.stratus.Stratus;
-import com.raeids.stratus.hook.ChatHookKt;
+import com.raeids.stratus.hook.ChatSearchingKt;
+import com.raeids.stratus.hook.ChatTabs;
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.ChatLine;
import net.minecraft.client.gui.GuiNewChat;
+import net.minecraft.util.IChatComponent;
import org.spongepowered.asm.lib.Opcodes;
import org.spongepowered.asm.mixin.Final;
import org.spongepowered.asm.mixin.Mixin;
@@ -21,6 +23,11 @@ import java.util.List;
public class GuiNewChatMixin {
@Shadow @Final private Minecraft mc;
+ @Inject(method = "setChatLine", at = @At(value = "INVOKE", target = "Lnet/minecraft/util/MathHelper;floor_float(F)I", shift = At.Shift.AFTER))
+ private void setDoing(IChatComponent chatComponent, int chatLineId, int updateCounter, boolean displayOnly, CallbackInfo ci) {
+ ChatTabs.INSTANCE.setDoing(true);
+ }
+
@Inject(method = "drawChat", at = @At("HEAD"))
private void checkScreenshotKeybind(int j2, CallbackInfo ci) {
if (Stratus.INSTANCE.getKeybind().isPressed()) {
@@ -44,6 +51,6 @@ public class GuiNewChatMixin {
@Redirect(method = "drawChat", at = @At(value = "FIELD", target = "Lnet/minecraft/client/gui/GuiNewChat;drawnChatLines:Ljava/util/List;", opcode = Opcodes.GETFIELD))
private List<ChatLine> injected(GuiNewChat instance) {
- return ChatHookKt.filterMessages(drawnChatLines);
+ return ChatSearchingKt.filterMessages(drawnChatLines);
}
}
diff --git a/src/main/java/com/raeids/stratus/mixin/GuiUtilRenderComponentsMixin.java b/src/main/java/com/raeids/stratus/mixin/GuiUtilRenderComponentsMixin.java
new file mode 100644
index 0000000..05378cd
--- /dev/null
+++ b/src/main/java/com/raeids/stratus/mixin/GuiUtilRenderComponentsMixin.java
@@ -0,0 +1,26 @@
+package com.raeids.stratus.mixin;
+
+import com.raeids.stratus.hook.ChatTabs;
+import net.minecraft.client.gui.FontRenderer;
+import net.minecraft.client.gui.GuiUtilRenderComponents;
+import net.minecraft.util.IChatComponent;
+import org.spongepowered.asm.mixin.Mixin;
+import org.spongepowered.asm.mixin.injection.At;
+import org.spongepowered.asm.mixin.injection.Inject;
+import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
+
+import java.util.Collections;
+import java.util.List;
+
+@Mixin(GuiUtilRenderComponents.class)
+public class GuiUtilRenderComponentsMixin {
+ @Inject(method = "splitText", at = @At("HEAD"), cancellable = true)
+ private static void cancelText(IChatComponent k, int s1, FontRenderer chatcomponenttext, boolean l, boolean chatcomponenttext2, CallbackInfoReturnable<List<IChatComponent>> cir) {
+ if (ChatTabs.INSTANCE.isDoing()) {
+ ChatTabs.INSTANCE.setDoing(false);
+ if (!ChatTabs.INSTANCE.shouldRender(k.getUnformattedTextForChat())) {
+ cir.setReturnValue(Collections.emptyList());
+ }
+ }
+ }
+}