0
0
mirror of https://github.com/Wurst-Imperium/Wurst7.git synced 2024-09-19 17:02:13 +02:00

Refactor ChatTranslator

This commit is contained in:
Alexander01998 2024-07-22 00:52:58 +02:00
parent 3f7f61092a
commit be6fd81e44
2 changed files with 33 additions and 21 deletions

View File

@ -7,7 +7,6 @@
*/ */
package net.wurstclient.hacks; package net.wurstclient.hacks;
import net.minecraft.text.Text;
import net.wurstclient.Category; import net.wurstclient.Category;
import net.wurstclient.SearchTags; import net.wurstclient.SearchTags;
import net.wurstclient.events.ChatInputListener; import net.wurstclient.events.ChatInputListener;
@ -24,19 +23,18 @@ import net.wurstclient.util.GoogleTranslate;
"google translator", "GoogleTranslation", "google translation"}) "google translator", "GoogleTranslation", "google translation"})
public final class ChatTranslatorHack extends Hack implements ChatInputListener public final class ChatTranslatorHack extends Hack implements ChatInputListener
{ {
private final LanguageSetting langFrom = private final LanguageSetting translateFrom =
LanguageSetting.withAutoDetect("Translate from", Language.AUTO_DETECT); LanguageSetting.withAutoDetect("Translate from", Language.AUTO_DETECT);
private final LanguageSetting langTo = private final LanguageSetting translateTo =
LanguageSetting.withoutAutoDetect("Translate to", Language.ENGLISH); LanguageSetting.withoutAutoDetect("Translate to", Language.ENGLISH);
public ChatTranslatorHack() public ChatTranslatorHack()
{ {
super("ChatTranslator"); super("ChatTranslator");
setCategory(Category.CHAT); setCategory(Category.CHAT);
addSetting(translateFrom);
addSetting(langFrom); addSetting(translateTo);
addSetting(langTo);
} }
@Override @Override
@ -54,26 +52,26 @@ public final class ChatTranslatorHack extends Hack implements ChatInputListener
@Override @Override
public void onReceivedMessage(ChatInputEvent event) public void onReceivedMessage(ChatInputEvent event)
{ {
Thread.ofVirtual().name("ChatTranslator") String message = event.getComponent().getString();
.uncaughtExceptionHandler((t, e) -> e.printStackTrace()) Language fromLang = translateFrom.getSelected();
.start(() -> translate(event.getComponent().getString())); Language toLang = translateTo.getSelected();
}
private void translate(String message)
{
String prefix =
"\u00a7a[\u00a7b" + langTo.getSelected() + "\u00a7a]:\u00a7r ";
if(message.startsWith(ChatUtils.WURST_PREFIX) if(message.startsWith(ChatUtils.WURST_PREFIX)
|| message.startsWith(prefix)) || message.startsWith(toLang.getPrefix()))
return; return;
Thread.ofVirtual().name("ChatTranslator")
.uncaughtExceptionHandler((t, e) -> e.printStackTrace())
.start(() -> showTranslated(message, fromLang, toLang));
}
private void showTranslated(String message, Language fromLang,
Language toLang)
{
String translated = GoogleTranslate.translate(message, String translated = GoogleTranslate.translate(message,
langFrom.getSelected().getValue(), langTo.getSelected().getValue()); fromLang.getValue(), toLang.getValue());
if(translated == null) if(translated != null)
return; MC.inGameHud.getChatHud().addMessage(toLang.prefixText(translated));
MC.inGameHud.getChatHud().addMessage(Text.literal(prefix + translated));
} }
} }

View File

@ -7,6 +7,8 @@
*/ */
package net.wurstclient.settings; package net.wurstclient.settings;
import net.minecraft.text.Text;
public final class LanguageSetting extends EnumSetting<LanguageSetting.Language> public final class LanguageSetting extends EnumSetting<LanguageSetting.Language>
{ {
private LanguageSetting(String name, String description, Language[] values, private LanguageSetting(String name, String description, Language[] values,
@ -71,11 +73,13 @@ public final class LanguageSetting extends EnumSetting<LanguageSetting.Language>
private final String name; private final String name;
private final String value; private final String value;
private final String prefix;
private Language(String name, String value) private Language(String name, String value)
{ {
this.name = name; this.name = name;
this.value = value; this.value = value;
prefix = "\u00a7a[\u00a7b" + value + "\u00a7a]:\u00a7r ";
} }
public String getValue() public String getValue()
@ -83,6 +87,16 @@ public final class LanguageSetting extends EnumSetting<LanguageSetting.Language>
return value; return value;
} }
public String getPrefix()
{
return prefix;
}
public Text prefixText(String s)
{
return Text.literal(prefix + s);
}
@Override @Override
public String toString() public String toString()
{ {