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

View File

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