WIP 1.18.3: Impl editing of server config in-game
Fixed Battle not checking Player haste/speed status for using "player_haste_speed" and "player_slow_speed".
This commit is contained in:
parent
bc598c41b7
commit
28291e5134
4 changed files with 507 additions and 259 deletions
|
@ -19,8 +19,7 @@ import net.minecraftforge.network.NetworkEvent;
|
|||
import java.util.UUID;
|
||||
import java.util.function.Supplier;
|
||||
|
||||
public class ClientProxy extends CommonProxy
|
||||
{
|
||||
public class ClientProxy extends CommonProxy {
|
||||
private BattleGui battleGui = null;
|
||||
private BattleMusic battleMusic = null;
|
||||
private int battleMusicCount = 0;
|
||||
|
@ -28,8 +27,7 @@ public class ClientProxy extends CommonProxy
|
|||
private Battle localBattle = null;
|
||||
|
||||
@Override
|
||||
protected void initializeClient()
|
||||
{
|
||||
protected void initializeClient() {
|
||||
battleGui = new BattleGui();
|
||||
battleMusic = null; // will be initialized in postInit()
|
||||
battleMusicCount = 0;
|
||||
|
@ -39,48 +37,40 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
@Override
|
||||
public void setBattleGuiTime(int timeRemaining)
|
||||
{
|
||||
public void setBattleGuiTime(int timeRemaining) {
|
||||
battleGui.setTimeRemaining(timeRemaining);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setBattleGuiBattleChanged()
|
||||
{
|
||||
public void setBattleGuiBattleChanged() {
|
||||
battleGui.battleChanged();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setBattleGuiAsGui()
|
||||
{
|
||||
if(Minecraft.getInstance().screen != battleGui)
|
||||
{
|
||||
public void setBattleGuiAsGui() {
|
||||
if (Minecraft.getInstance().screen != battleGui) {
|
||||
battleGui.turnEnd();
|
||||
Minecraft.getInstance().setScreen(battleGui);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void battleGuiTurnBegin()
|
||||
{
|
||||
public void battleGuiTurnBegin() {
|
||||
battleGui.turnBegin();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void battleGuiTurnEnd()
|
||||
{
|
||||
public void battleGuiTurnEnd() {
|
||||
battleGui.turnEnd();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void battleStarted()
|
||||
{
|
||||
public void battleStarted() {
|
||||
setBattleGuiAsGui();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void battleEnded()
|
||||
{
|
||||
public void battleEnded() {
|
||||
localBattle = null;
|
||||
Minecraft.getInstance().setScreen(null);
|
||||
stopMusic(true);
|
||||
|
@ -89,28 +79,24 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
@Override
|
||||
protected void postInitClient()
|
||||
{
|
||||
protected void postInitClient() {
|
||||
battleMusic = new BattleMusic(getLogger());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void playBattleMusic()
|
||||
{
|
||||
public void playBattleMusic() {
|
||||
Options gs = Minecraft.getInstance().options;
|
||||
battleMusic.playBattle(gs.getSoundSourceVolume(SoundSource.MUSIC) * gs.getSoundSourceVolume(SoundSource.MASTER));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void playSillyMusic()
|
||||
{
|
||||
public void playSillyMusic() {
|
||||
Options gs = Minecraft.getInstance().options;
|
||||
battleMusic.playSilly(gs.getSoundSourceVolume(SoundSource.MUSIC) * gs.getSoundSourceVolume(SoundSource.MASTER));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void stopMusic(boolean resumeMCSounds)
|
||||
{
|
||||
public void stopMusic(boolean resumeMCSounds) {
|
||||
battleMusic.stopMusic(resumeMCSounds);
|
||||
}
|
||||
|
||||
|
@ -118,11 +104,11 @@ public class ClientProxy extends CommonProxy
|
|||
* Sets what music to play based on type and loaded Config
|
||||
*/
|
||||
@Override
|
||||
public void typeEnteredBattle(String type)
|
||||
{
|
||||
public void typeEnteredBattle(String type) {
|
||||
if (localBattle == null) {
|
||||
return;
|
||||
} if(type == null || type.isEmpty() || getConfig().isBattleMusicType(type)) {
|
||||
}
|
||||
if (type == null || type.isEmpty() || getConfig().isBattleMusicType(type)) {
|
||||
++battleMusicCount;
|
||||
} else if (getConfig().isSillyMusicType(type)) {
|
||||
++sillyMusicCount;
|
||||
|
@ -133,10 +119,8 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
@Override
|
||||
public void typeLeftBattle(String type)
|
||||
{
|
||||
if(localBattle == null || localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty())
|
||||
{
|
||||
public void typeLeftBattle(String type) {
|
||||
if (localBattle == null || localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty()) {
|
||||
battleMusicCount = 0;
|
||||
sillyMusicCount = 0;
|
||||
return;
|
||||
|
@ -151,8 +135,7 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
@Override
|
||||
public void displayString(String message)
|
||||
{
|
||||
public void displayString(String message) {
|
||||
Component parentComponent = new TextComponent("");
|
||||
|
||||
TextComponent prefix = new TextComponent("TBM: ");
|
||||
|
@ -167,8 +150,7 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
@Override
|
||||
public void displayComponent(Component text)
|
||||
{
|
||||
public void displayComponent(Component text) {
|
||||
Component parentComponent = new TextComponent("");
|
||||
|
||||
TextComponent prefix = new TextComponent("TBM: ");
|
||||
|
@ -180,68 +162,49 @@ public class ClientProxy extends CommonProxy
|
|||
Minecraft.getInstance().player.sendMessage(parentComponent, new UUID(0, 0));
|
||||
}
|
||||
|
||||
private void checkBattleTypes(boolean entityLeft)
|
||||
{
|
||||
private void checkBattleTypes(boolean entityLeft) {
|
||||
// check that battle is still valid
|
||||
if (localBattle == null && entityLeft && (localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty())) {
|
||||
return;
|
||||
}
|
||||
|
||||
float percentage = 0.0f;
|
||||
if(sillyMusicCount == 0 && battleMusicCount == 0)
|
||||
{
|
||||
if (sillyMusicCount == 0 && battleMusicCount == 0) {
|
||||
percentage = 0.0f;
|
||||
}
|
||||
else if(battleMusicCount == 0)
|
||||
{
|
||||
} else if (battleMusicCount == 0) {
|
||||
percentage = 100.0f;
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
percentage = 100.0f * (float) sillyMusicCount / (float) (sillyMusicCount + battleMusicCount);
|
||||
}
|
||||
|
||||
if(percentage >= (float)getConfig().getSillyMusicThreshold())
|
||||
{
|
||||
if(battleMusic.isPlaying())
|
||||
{
|
||||
if(!battleMusic.isPlayingSilly() && battleMusic.hasSillyMusic())
|
||||
{
|
||||
if (percentage >= (float) getConfig().getSillyMusicThreshold()) {
|
||||
if (battleMusic.isPlaying()) {
|
||||
if (!battleMusic.isPlayingSilly() && battleMusic.hasSillyMusic()) {
|
||||
stopMusic(false);
|
||||
playSillyMusic();
|
||||
}
|
||||
}
|
||||
else if(battleMusic.hasSillyMusic())
|
||||
{
|
||||
} else if (battleMusic.hasSillyMusic()) {
|
||||
playSillyMusic();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if(battleMusic.isPlaying())
|
||||
{
|
||||
if(battleMusic.isPlayingSilly() && battleMusic.hasBattleMusic())
|
||||
{
|
||||
} else {
|
||||
if (battleMusic.isPlaying()) {
|
||||
if (battleMusic.isPlayingSilly() && battleMusic.hasBattleMusic()) {
|
||||
stopMusic(false);
|
||||
playBattleMusic();
|
||||
}
|
||||
}
|
||||
else if(battleMusic.hasBattleMusic())
|
||||
{
|
||||
} else if (battleMusic.hasBattleMusic()) {
|
||||
playBattleMusic();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Battle getLocalBattle()
|
||||
{
|
||||
public Battle getLocalBattle() {
|
||||
return localBattle;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void createLocalBattle(int id)
|
||||
{
|
||||
public void createLocalBattle(int id) {
|
||||
localBattle = new Battle(null, id, null, null, false, Minecraft.getInstance().level.dimension());
|
||||
}
|
||||
|
||||
|
@ -256,57 +219,44 @@ public class ClientProxy extends CommonProxy
|
|||
PacketBattleMessage pkt = (PacketBattleMessage) msg;
|
||||
Entity fromEntity = getEntity(pkt.getEntityIDFrom(), pkt.getDimension());
|
||||
Component from = new TextComponent("Unknown");
|
||||
if(fromEntity != null)
|
||||
{
|
||||
if (fromEntity != null) {
|
||||
from = fromEntity.getDisplayName();
|
||||
}
|
||||
else if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
|
||||
{
|
||||
} else if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
|
||||
fromEntity = TurnBasedMinecraftMod.proxy.getLocalBattle().getCombatantEntity(pkt.getEntityIDFrom());
|
||||
if(fromEntity != null)
|
||||
{
|
||||
if (fromEntity != null) {
|
||||
from = fromEntity.getDisplayName();
|
||||
}
|
||||
}
|
||||
Entity toEntity = TurnBasedMinecraftMod.proxy.getEntity(pkt.getEntityIDTo(), pkt.getDimension());
|
||||
Component to = new TextComponent("Unknown");
|
||||
if(toEntity != null)
|
||||
{
|
||||
if (toEntity != null) {
|
||||
to = toEntity.getDisplayName();
|
||||
}
|
||||
else if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
|
||||
{
|
||||
} else if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
|
||||
toEntity = TurnBasedMinecraftMod.proxy.getLocalBattle().getCombatantEntity(pkt.getEntityIDTo());
|
||||
if(toEntity != null)
|
||||
{
|
||||
if (toEntity != null) {
|
||||
to = toEntity.getDisplayName();
|
||||
}
|
||||
}
|
||||
|
||||
Component parentComponent = new TextComponent("");
|
||||
switch(pkt.getMessageType())
|
||||
{
|
||||
switch (pkt.getMessageType()) {
|
||||
case ENTERED:
|
||||
parentComponent.getSiblings().add(from);
|
||||
parentComponent.getSiblings().add(new TextComponent(" entered battle!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
if(TurnBasedMinecraftMod.proxy.getLocalBattle() == null || TurnBasedMinecraftMod.proxy.getLocalBattle().getId() != pkt.getAmount())
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getLocalBattle() == null || TurnBasedMinecraftMod.proxy.getLocalBattle().getId() != pkt.getAmount()) {
|
||||
TurnBasedMinecraftMod.proxy.createLocalBattle(pkt.getAmount());
|
||||
}
|
||||
TurnBasedMinecraftMod.proxy.battleStarted();
|
||||
TurnBasedMinecraftMod.proxy.typeEnteredBattle(pkt.getCustom());
|
||||
break;
|
||||
case FLEE:
|
||||
if(pkt.getAmount() != 0)
|
||||
{
|
||||
if (pkt.getAmount() != 0) {
|
||||
parentComponent.getSiblings().add(from);
|
||||
parentComponent.getSiblings().add(new TextComponent(" fled battle!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
TurnBasedMinecraftMod.proxy.typeLeftBattle(pkt.getCustom());
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
parentComponent.getSiblings().add(from);
|
||||
parentComponent.getSiblings().add(new TextComponent(" tried to flee battle but failed!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
|
@ -366,22 +316,18 @@ public class ClientProxy extends CommonProxy
|
|||
break;
|
||||
case USED_ITEM:
|
||||
parentComponent.getSiblings().add(from);
|
||||
switch(PacketBattleMessage.UsedItemAction.valueOf(pkt.getAmount()))
|
||||
{
|
||||
switch (PacketBattleMessage.UsedItemAction.valueOf(pkt.getAmount())) {
|
||||
case USED_NOTHING:
|
||||
parentComponent.getSiblings().add(new TextComponent(" tried to use nothing!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
case USED_INVALID:
|
||||
if(pkt.getCustom().length() > 0)
|
||||
{
|
||||
if (pkt.getCustom().length() > 0) {
|
||||
parentComponent.getSiblings().add(new TextComponent(" tried to consume "));
|
||||
parentComponent.getSiblings().add(new TextComponent(pkt.getCustom()));
|
||||
parentComponent.getSiblings().add(new TextComponent(" and failed!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
parentComponent.getSiblings().add(new TextComponent(" tried to consume an invalid item and failed!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
}
|
||||
|
@ -405,28 +351,21 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.battleGuiTurnBegin();
|
||||
break;
|
||||
case TURN_END:
|
||||
if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
|
||||
{
|
||||
if(pkt.getAmount() == 0)
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
|
||||
if (pkt.getAmount() == 0) {
|
||||
TurnBasedMinecraftMod.proxy.displayString("The turn ended!");
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TurnBasedMinecraftMod.proxy.displayString("The turn ended (abnormally due to internal error)!");
|
||||
}
|
||||
}
|
||||
TurnBasedMinecraftMod.proxy.battleGuiTurnEnd();
|
||||
break;
|
||||
case SWITCHED_ITEM:
|
||||
if(pkt.getAmount() != 0)
|
||||
{
|
||||
if (pkt.getAmount() != 0) {
|
||||
parentComponent.getSiblings().add(from);
|
||||
parentComponent.getSiblings().add(new TextComponent(" switched to a different item!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
parentComponent.getSiblings().add(from);
|
||||
parentComponent.getSiblings().add(new TextComponent(" switched to a different item but failed because it was invalid!"));
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
|
@ -494,10 +433,8 @@ public class ClientProxy extends CommonProxy
|
|||
} else if (msg.getClass() == PacketEditingMessage.class) {
|
||||
PacketEditingMessage pkt = (PacketEditingMessage) msg;
|
||||
Component parentComponent = new TextComponent("");
|
||||
switch(pkt.getType())
|
||||
{
|
||||
case ATTACK_ENTITY:
|
||||
{
|
||||
switch (pkt.getType()) {
|
||||
case ATTACK_ENTITY: {
|
||||
TextComponent text = new TextComponent("Attack the entity you want to edit for TurnBasedMinecraftMod. ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
|
@ -509,8 +446,7 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case PICK_EDIT:
|
||||
{
|
||||
case PICK_EDIT: {
|
||||
TextComponent text = new TextComponent("Edit what value? ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
|
@ -640,13 +576,12 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case SERVER_EDIT:
|
||||
{
|
||||
case SERVER_EDIT: {
|
||||
TextComponent parent = new TextComponent("Edit what server value? ");
|
||||
parent.setStyle(parent.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
TextComponent sub = new TextComponent("leave_battle_cooldown ");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
|
||||
|
||||
for (int i = 1; i <= 10; ++i) {
|
||||
TextComponent value = new TextComponent(String.valueOf(i) + ' ');
|
||||
|
@ -662,7 +597,7 @@ public class ClientProxy extends CommonProxy
|
|||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("aggro_start_battle_max_distance ");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("5 ");
|
||||
|
@ -699,7 +634,8 @@ public class ClientProxy extends CommonProxy
|
|||
.withColor(0xFFFFFF00)
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("If enabled, battles only start on a hit, not including mobs targeting players"))));
|
||||
new TextComponent("If enabled, battles only start on a hit, not including mobs targeting players")))
|
||||
.withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("true ");
|
||||
|
@ -725,7 +661,8 @@ public class ClientProxy extends CommonProxy
|
|||
.withColor(0xFFFFFF00)
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Allows use for /tbm-disable and /tbm-enable for all"))));
|
||||
new TextComponent("Allows use for /tbm-disable and /tbm-enable for all")))
|
||||
.withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("true ");
|
||||
|
@ -747,7 +684,7 @@ public class ClientProxy extends CommonProxy
|
|||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("max_in_battle ");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("2 ");
|
||||
|
@ -769,7 +706,7 @@ public class ClientProxy extends CommonProxy
|
|||
}
|
||||
|
||||
sub = new TextComponent("freeze_battle_combatants ");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("true ");
|
||||
|
@ -790,11 +727,79 @@ public class ClientProxy extends CommonProxy
|
|||
)));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("ignore_battle_types ");
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFF00FF00)
|
||||
.withClickEvent(new ClickEvent(
|
||||
ClickEvent.Action.RUN_COMMAND,
|
||||
"/tbm-server-edit ignore_battle_types"))
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Click to show current ignored categories, or use /tbm-server-edit ignore_battle_types add/remove <category_name>")
|
||||
))
|
||||
.withBold(true));
|
||||
parent.append(sub);
|
||||
|
||||
sub = new TextComponent("player_speed ");
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFFFFFF00)
|
||||
.withBold(true)
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Player default speed"))));
|
||||
parent.append(sub);
|
||||
|
||||
for (int i = 0; i <= 100; i += 5) {
|
||||
sub = new TextComponent(String.valueOf(i) + ' ');
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFF00FF00)
|
||||
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
|
||||
"/tbm-server-edit player_speed " + i)));
|
||||
parent.append(sub);
|
||||
}
|
||||
|
||||
sub = new TextComponent("player_haste_speed ");
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFFFFFF00)
|
||||
.withBold(true)
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Player speed when under the effects of \"Speed\"")
|
||||
)));
|
||||
parent.append(sub);
|
||||
|
||||
for (int i = 0; i <= 100; i += 5) {
|
||||
sub = new TextComponent(String.valueOf(i) + ' ');
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFF00FF00)
|
||||
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
|
||||
"/tbm-server-edit player_haste_speed " + i)));
|
||||
parent.append(sub);
|
||||
}
|
||||
|
||||
sub = new TextComponent("player_slow_speed ");
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFFFFFF00)
|
||||
.withBold(true)
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Player speed when under the effects of \"Slow\"")
|
||||
)));
|
||||
parent.append(sub);
|
||||
|
||||
for (int i = 0; i <= 100; i += 5) {
|
||||
sub = new TextComponent(String.valueOf(i) + ' ');
|
||||
sub.setStyle(sub.getStyle()
|
||||
.withColor(0xFF00FF00)
|
||||
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
|
||||
"/tbm-server-edit player_slow_speed " + i)));
|
||||
parent.append(sub);
|
||||
}
|
||||
|
||||
TurnBasedMinecraftMod.proxy.displayComponent(parent);
|
||||
break;
|
||||
}
|
||||
case EDIT_IGNORE_BATTLE:
|
||||
{
|
||||
case EDIT_IGNORE_BATTLE: {
|
||||
TextComponent text = new TextComponent("ignoreBattle: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
|
@ -812,18 +817,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_ATTACK_POWER:
|
||||
{
|
||||
case EDIT_ATTACK_POWER: {
|
||||
TextComponent text = new TextComponent("attackPower: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 15; ++i)
|
||||
{
|
||||
for (int i = 0; i <= 15; ++i) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i));
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackPower " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 15)
|
||||
{
|
||||
if (i < 15) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -834,18 +836,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_ATTACK_PROBABILITY:
|
||||
{
|
||||
case EDIT_ATTACK_PROBABILITY: {
|
||||
TextComponent text = new TextComponent("attackProbability: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 10; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 10; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackProbability " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -856,18 +855,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_ATTACK_VARIANCE:
|
||||
{
|
||||
case EDIT_ATTACK_VARIANCE: {
|
||||
TextComponent text = new TextComponent("attackVariance: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 10; ++i)
|
||||
{
|
||||
for (int i = 0; i <= 10; ++i) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i));
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackVariance " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 10)
|
||||
{
|
||||
if (i < 10) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -878,18 +874,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_ATTACK_EFFECT:
|
||||
{
|
||||
case EDIT_ATTACK_EFFECT: {
|
||||
TextComponent text = new TextComponent("attackEffect: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(EntityInfo.Effect e : EntityInfo.Effect.values())
|
||||
{
|
||||
for (EntityInfo.Effect e : EntityInfo.Effect.values()) {
|
||||
TextComponent option = new TextComponent(e.toString());
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackEffect " + e.toString())));
|
||||
text.getSiblings().add(option);
|
||||
if(e != EntityInfo.Effect.UNKNOWN)
|
||||
{
|
||||
if (e != EntityInfo.Effect.UNKNOWN) {
|
||||
// TODO find a better way to handle printing comma for items before last
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
|
@ -899,18 +892,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_ATTACK_EFFECT_PROBABILITY:
|
||||
{
|
||||
case EDIT_ATTACK_EFFECT_PROBABILITY: {
|
||||
TextComponent text = new TextComponent("attackEffectProbability: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackEffectProbability " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -921,18 +911,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_DEFENSE_DAMAGE:
|
||||
{
|
||||
case EDIT_DEFENSE_DAMAGE: {
|
||||
TextComponent text = new TextComponent("defenseDamage: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 15; ++i)
|
||||
{
|
||||
for (int i = 0; i <= 15; ++i) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i));
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit defenseDamage " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 15)
|
||||
{
|
||||
if (i < 15) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -943,18 +930,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_DEFENSE_DAMAGE_PROBABILITY:
|
||||
{
|
||||
case EDIT_DEFENSE_DAMAGE_PROBABILITY: {
|
||||
TextComponent text = new TextComponent("defenseDamageProbability: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit defenseDamageProbability " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -965,18 +949,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_EVASION:
|
||||
{
|
||||
case EDIT_EVASION: {
|
||||
TextComponent text = new TextComponent("evasion: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit evasion " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -987,18 +968,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_SPEED:
|
||||
{
|
||||
case EDIT_SPEED: {
|
||||
TextComponent text = new TextComponent("speed: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i));
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit speed " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -1009,15 +987,13 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_CATEGORY:
|
||||
{
|
||||
case EDIT_CATEGORY: {
|
||||
TextComponent text = new TextComponent("category: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
TextComponent option = new TextComponent("monster");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category monster")));
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("monster"))
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("monster")) {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("disabled");
|
||||
|
@ -1025,9 +1001,7 @@ public class ClientProxy extends CommonProxy
|
|||
optionInfo.getSiblings().add(optionInfoBool);
|
||||
optionInfo.getSiblings().add(new TextComponent(")"));
|
||||
option.getSiblings().add(optionInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("enabled");
|
||||
|
@ -1041,8 +1015,7 @@ public class ClientProxy extends CommonProxy
|
|||
|
||||
option = new TextComponent("animal");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category animal")));
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("animal"))
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("animal")) {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("disabled");
|
||||
|
@ -1050,9 +1023,7 @@ public class ClientProxy extends CommonProxy
|
|||
optionInfo.getSiblings().add(optionInfoBool);
|
||||
optionInfo.getSiblings().add(new TextComponent(")"));
|
||||
option.getSiblings().add(optionInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("enabled");
|
||||
|
@ -1066,8 +1037,7 @@ public class ClientProxy extends CommonProxy
|
|||
|
||||
option = new TextComponent("passive");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category passive")));
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("passive"))
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("passive")) {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("disabled");
|
||||
|
@ -1075,9 +1045,7 @@ public class ClientProxy extends CommonProxy
|
|||
optionInfo.getSiblings().add(optionInfoBool);
|
||||
optionInfo.getSiblings().add(new TextComponent(")"));
|
||||
option.getSiblings().add(optionInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("enabled");
|
||||
|
@ -1091,8 +1059,7 @@ public class ClientProxy extends CommonProxy
|
|||
|
||||
option = new TextComponent("boss");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category boss")));
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("boss"))
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("boss")) {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("disabled");
|
||||
|
@ -1100,9 +1067,7 @@ public class ClientProxy extends CommonProxy
|
|||
optionInfo.getSiblings().add(optionInfoBool);
|
||||
optionInfo.getSiblings().add(new TextComponent(")"));
|
||||
option.getSiblings().add(optionInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("enabled");
|
||||
|
@ -1116,8 +1081,7 @@ public class ClientProxy extends CommonProxy
|
|||
|
||||
option = new TextComponent("player");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category player")));
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("player"))
|
||||
{
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("player")) {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("disabled");
|
||||
|
@ -1125,9 +1089,7 @@ public class ClientProxy extends CommonProxy
|
|||
optionInfo.getSiblings().add(optionInfoBool);
|
||||
optionInfo.getSiblings().add(new TextComponent(")"));
|
||||
option.getSiblings().add(optionInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
TextComponent optionInfo = new TextComponent("(battle-");
|
||||
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
|
||||
TextComponent optionInfoBool = new TextComponent("enabled");
|
||||
|
@ -1144,18 +1106,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_DECISION_ATTACK:
|
||||
{
|
||||
case EDIT_DECISION_ATTACK: {
|
||||
TextComponent text = new TextComponent("decisionAttack: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionAttack " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -1164,18 +1123,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_DECISION_DEFEND:
|
||||
{
|
||||
case EDIT_DECISION_DEFEND: {
|
||||
TextComponent text = new TextComponent("decisionDefend: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionDefend " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
@ -1184,18 +1140,15 @@ public class ClientProxy extends CommonProxy
|
|||
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
|
||||
break;
|
||||
}
|
||||
case EDIT_DECISION_FLEE:
|
||||
{
|
||||
case EDIT_DECISION_FLEE: {
|
||||
TextComponent text = new TextComponent("decisionFlee: ");
|
||||
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
|
||||
|
||||
for(int i = 0; i <= 100; i += 10)
|
||||
{
|
||||
for (int i = 0; i <= 100; i += 10) {
|
||||
TextComponent option = new TextComponent(Integer.toString(i) + "%");
|
||||
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionFlee " + Integer.toString(i))));
|
||||
text.getSiblings().add(option);
|
||||
if(i < 100)
|
||||
{
|
||||
if (i < 100) {
|
||||
text.getSiblings().add(new TextComponent(", "));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,7 @@ import com.burnedkirby.TurnBasedMinecraft.common.networking.PacketBattleMessage;
|
|||
import net.minecraft.resources.ResourceKey;
|
||||
import net.minecraft.server.level.ServerPlayer;
|
||||
import net.minecraft.world.damagesource.DamageSource;
|
||||
import net.minecraft.world.effect.MobEffects;
|
||||
import net.minecraft.world.entity.Entity;
|
||||
import net.minecraft.world.entity.LivingEntity;
|
||||
import net.minecraft.world.entity.Mob;
|
||||
|
@ -1218,7 +1219,13 @@ public class Battle
|
|||
{
|
||||
if(c.entity instanceof Player)
|
||||
{
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed() > fastestEnemySpeed)
|
||||
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
|
||||
} else if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
|
||||
}
|
||||
if(playerSpeed > fastestEnemySpeed)
|
||||
{
|
||||
fastestEnemySpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
}
|
||||
|
@ -1238,7 +1245,13 @@ public class Battle
|
|||
{
|
||||
if(c.entity instanceof Player)
|
||||
{
|
||||
if(TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed() > fastestEnemySpeed)
|
||||
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
|
||||
} else if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
|
||||
}
|
||||
if(playerSpeed > fastestEnemySpeed)
|
||||
{
|
||||
fastestEnemySpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
}
|
||||
|
@ -1255,7 +1268,13 @@ public class Battle
|
|||
int fleeProbability = 0;
|
||||
if(next.entity instanceof Player)
|
||||
{
|
||||
if(fastestEnemySpeed >= TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed())
|
||||
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
if (((Player) next.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
|
||||
} else if (((Player) next.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
|
||||
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
|
||||
}
|
||||
if(fastestEnemySpeed >= playerSpeed)
|
||||
{
|
||||
fleeProbability = TurnBasedMinecraftMod.proxy.getConfig().getFleeBadProbability();
|
||||
}
|
||||
|
|
|
@ -936,16 +936,46 @@ public class Config
|
|||
return playerSpeed;
|
||||
}
|
||||
|
||||
public void setPlayerSpeed(int speed) {
|
||||
if (speed < 0) {
|
||||
speed = 0;
|
||||
} else if (speed > 100) {
|
||||
speed = 100;
|
||||
}
|
||||
|
||||
playerSpeed = speed;
|
||||
}
|
||||
|
||||
public int getPlayerHasteSpeed()
|
||||
{
|
||||
return playerHasteSpeed;
|
||||
}
|
||||
|
||||
public void setPlayerHasteSpeed(int speed) {
|
||||
if (speed < 0) {
|
||||
speed = 0;
|
||||
} else if (speed > 100) {
|
||||
speed = 100;
|
||||
}
|
||||
|
||||
playerHasteSpeed = speed;
|
||||
}
|
||||
|
||||
public int getPlayerSlowSpeed()
|
||||
{
|
||||
return playerSlowSpeed;
|
||||
}
|
||||
|
||||
public void setPlayerSlowSpeed(int speed) {
|
||||
if (speed < 0) {
|
||||
speed = 0;
|
||||
} else if (speed > 100) {
|
||||
speed = 100;
|
||||
}
|
||||
|
||||
playerSlowSpeed = speed;
|
||||
}
|
||||
|
||||
public int getPlayerAttackProbability()
|
||||
{
|
||||
return playerAttackProbability;
|
||||
|
@ -1096,11 +1126,85 @@ public class Config
|
|||
return true;
|
||||
}
|
||||
|
||||
public boolean updateConfigAppendToStringArray(String path, String string_value) {
|
||||
File configFile = new File(TurnBasedMinecraftMod.CONFIG_FILE_PATH);
|
||||
CommentedFileConfig conf = getConfigObj(configFile);
|
||||
|
||||
Collection<String> strings;
|
||||
try {
|
||||
strings = conf.get(path);
|
||||
} catch (Exception e) {
|
||||
TurnBasedMinecraftMod.logger.warn("Exception during fetching Collection<String> from config (append)");
|
||||
TurnBasedMinecraftMod.logger.warn(e);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (strings.contains(string_value)) {
|
||||
return false;
|
||||
}
|
||||
strings.add(string_value);
|
||||
|
||||
try {
|
||||
conf.set(path, strings);
|
||||
} catch (Exception e) {
|
||||
TurnBasedMinecraftMod.logger.warn("Exception during setting Collection<String> in config (append)");
|
||||
TurnBasedMinecraftMod.logger.warn(e);
|
||||
return false;
|
||||
}
|
||||
conf.save();
|
||||
conf.close();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public boolean updateConfigRemoveFromStringArray(String path, String string_value) {
|
||||
File configFile = new File(TurnBasedMinecraftMod.CONFIG_FILE_PATH);
|
||||
CommentedFileConfig conf = getConfigObj(configFile);
|
||||
|
||||
Collection<String> strings;
|
||||
try {
|
||||
strings = conf.get(path);
|
||||
} catch (Exception e) {
|
||||
TurnBasedMinecraftMod.logger.warn("Exception during fetching Collection<String> from config (removal)");
|
||||
TurnBasedMinecraftMod.logger.warn(e);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!strings.contains(string_value)) {
|
||||
return false;
|
||||
}
|
||||
strings.remove(string_value);
|
||||
|
||||
try {
|
||||
conf.set(path, strings);
|
||||
} catch (Exception e) {
|
||||
TurnBasedMinecraftMod.logger.warn("Exception during setting Collection<String> in config (removal)");
|
||||
TurnBasedMinecraftMod.logger.warn(e);
|
||||
return false;
|
||||
}
|
||||
conf.save();
|
||||
conf.close();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public boolean isIgnoreBattleType(String type)
|
||||
{
|
||||
return ignoreBattleTypes.contains(type);
|
||||
}
|
||||
|
||||
public Collection<String> getIgnoreBattleTypes() {
|
||||
return ignoreBattleTypes;
|
||||
}
|
||||
|
||||
public boolean removeIgnoreBattleType(String category) {
|
||||
return ignoreBattleTypes.remove(category);
|
||||
}
|
||||
|
||||
public boolean addIgnoreBattleType(String category) {
|
||||
return ignoreBattleTypes.add(category);
|
||||
}
|
||||
|
||||
public int getMinimumHitPercentage()
|
||||
{
|
||||
return minimumHitPercentage;
|
||||
|
|
|
@ -11,6 +11,8 @@ import com.mojang.brigadier.exceptions.CommandSyntaxException;
|
|||
import com.mojang.brigadier.exceptions.SimpleCommandExceptionType;
|
||||
import net.minecraft.commands.Commands;
|
||||
import net.minecraft.commands.arguments.EntityArgument;
|
||||
import net.minecraft.network.chat.ClickEvent;
|
||||
import net.minecraft.network.chat.HoverEvent;
|
||||
import net.minecraft.network.chat.TextComponent;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.server.level.ServerPlayer;
|
||||
|
@ -984,6 +986,176 @@ public class TurnBasedMinecraftMod {
|
|||
}
|
||||
return 1;
|
||||
})))
|
||||
.then(Commands.literal("ignore_battle_types").executes(c -> {
|
||||
TextComponent response = new TextComponent("Use ");
|
||||
TextComponent subResponse = new TextComponent("/tbm-server-edit ignore_battle_types add/remove <category> ");
|
||||
subResponse.setStyle(subResponse.getStyle().withColor(0xFFFFFF00));
|
||||
response.append(subResponse);
|
||||
|
||||
subResponse = new TextComponent("ignore_battle_types is currently: [");
|
||||
response.append(subResponse);
|
||||
|
||||
boolean isFirst = true;
|
||||
for (String category : TurnBasedMinecraftMod.proxy.getConfig().getIgnoreBattleTypes()) {
|
||||
if (!isFirst) {
|
||||
response.append(new TextComponent(", "));
|
||||
}
|
||||
subResponse = new TextComponent(category);
|
||||
subResponse.setStyle(subResponse.getStyle()
|
||||
.withColor(0xFF00FF00)
|
||||
.withClickEvent(new ClickEvent(
|
||||
ClickEvent.Action.RUN_COMMAND,
|
||||
"/tbm-server-edit ignore_battle_types remove " + category))
|
||||
.withHoverEvent(new HoverEvent(
|
||||
HoverEvent.Action.SHOW_TEXT,
|
||||
new TextComponent("Click to remove category"))));
|
||||
response.append(subResponse);
|
||||
isFirst = false;
|
||||
}
|
||||
response.append(new TextComponent("] "));
|
||||
c.getSource().sendSuccess(response, false);
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.literal("add").executes(c -> {
|
||||
c.getSource().sendFailure(new TextComponent("/tbm-server-edit ignore_battle_types add <category>"));
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.argument("category", StringArgumentType.greedyString()).executes(c -> {
|
||||
String category = StringArgumentType.getString(c, "category");
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().addIgnoreBattleType(category)
|
||||
&& TurnBasedMinecraftMod.proxy.getConfig().updateConfigAppendToStringArray("server_config.ignore_battle_types", category)) {
|
||||
TextComponent response = new TextComponent("Successfully appended category \"");
|
||||
|
||||
TextComponent sub = new TextComponent(category);
|
||||
sub.setStyle(sub.getStyle().withColor(0xFF00FF00));
|
||||
response.append(sub);
|
||||
|
||||
sub = new TextComponent("\" to ignore_battle_types");
|
||||
response.append(sub);
|
||||
|
||||
c.getSource().sendSuccess(response, true);
|
||||
return 1;
|
||||
}
|
||||
|
||||
c.getSource().sendFailure(new TextComponent(
|
||||
"Failed to append category \"" + category + "\" to ignore_battle_types"));
|
||||
return 1;
|
||||
})))
|
||||
.then(Commands.literal("remove").executes(c -> {
|
||||
c.getSource().sendFailure(new TextComponent("/tbm-server-edit ignore_battle_types remove <category>"));
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.argument("category", StringArgumentType.greedyString()).executes(c -> {
|
||||
String category = StringArgumentType.getString(c, "category");
|
||||
if (TurnBasedMinecraftMod.proxy.getConfig().removeIgnoreBattleType(category)
|
||||
&& TurnBasedMinecraftMod.proxy.getConfig().updateConfigRemoveFromStringArray("server_config.ignore_battle_types", category)) {
|
||||
TextComponent response = new TextComponent("Successfully removed category \"");
|
||||
|
||||
TextComponent sub = new TextComponent(category);
|
||||
sub.setStyle(sub.getStyle().withColor(0xFF00FF00));
|
||||
response.append(sub);
|
||||
|
||||
sub = new TextComponent("\" from ignore_battle_types");
|
||||
response.append(sub);
|
||||
|
||||
c.getSource().sendSuccess(response, true);
|
||||
return 1;
|
||||
}
|
||||
|
||||
c.getSource().sendFailure(new TextComponent(
|
||||
"Failed to remove category \"" + category + "\" to ignore_battle_types"));
|
||||
return 1;
|
||||
}))))
|
||||
.then(Commands.literal("player_speed").executes(c -> {
|
||||
TextComponent parent = new TextComponent("Use ");
|
||||
TextComponent sub = new TextComponent("/tbm-server-edit player_speed <0-100>");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
parent.append(sub);
|
||||
|
||||
c.getSource().sendSuccess(parent, false);
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.argument("speed", IntegerArgumentType.integer()).executes(c -> {
|
||||
int speed = IntegerArgumentType.getInteger(c, "speed");
|
||||
// setPlayerSpeed() in Config validates the value. Set it, then fetch it again.
|
||||
TurnBasedMinecraftMod.proxy.getConfig().setPlayerSpeed(speed);
|
||||
speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
|
||||
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_speed", speed)) {
|
||||
TurnBasedMinecraftMod.logger.warn(
|
||||
"Failed to set \"server_config.player_speed\" in config file!");
|
||||
c.getSource().sendFailure(new TextComponent(
|
||||
"Failed to set player_speed to \""
|
||||
+ speed
|
||||
+ "\" in config file!"));
|
||||
} else {
|
||||
TextComponent response = new TextComponent("Successfully set player_speed to: ");
|
||||
TextComponent subResponse = new TextComponent(String.valueOf(speed));
|
||||
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
|
||||
response.append(subResponse);
|
||||
c.getSource().sendSuccess(response, true);
|
||||
}
|
||||
return 1;
|
||||
})))
|
||||
.then(Commands.literal("player_haste_speed").executes(c -> {
|
||||
TextComponent parent = new TextComponent("Use ");
|
||||
TextComponent sub = new TextComponent("/tbm-server-edit player_haste_speed <0-100>");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
parent.append(sub);
|
||||
|
||||
c.getSource().sendSuccess(parent, false);
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.argument("haste_speed", IntegerArgumentType.integer()).executes(c -> {
|
||||
int haste_speed = IntegerArgumentType.getInteger(c, "haste_speed");
|
||||
// setPlayerHasteSpeed() in Config validates the value. Set it, then fetch it again.
|
||||
TurnBasedMinecraftMod.proxy.getConfig().setPlayerHasteSpeed(haste_speed);
|
||||
haste_speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
|
||||
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_haste_speed", haste_speed)) {
|
||||
TurnBasedMinecraftMod.logger.warn(
|
||||
"Failed to set \"server_config.player_haste_speed\" in config file!");
|
||||
c.getSource().sendFailure(new TextComponent(
|
||||
"Failed to set player_haste_speed to \""
|
||||
+ haste_speed
|
||||
+ "\" in config file!"));
|
||||
} else {
|
||||
TextComponent response = new TextComponent("Successfully set player_haste_speed to: ");
|
||||
TextComponent subResponse = new TextComponent(String.valueOf(haste_speed));
|
||||
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
|
||||
response.append(subResponse);
|
||||
c.getSource().sendSuccess(response, true);
|
||||
}
|
||||
return 1;
|
||||
})))
|
||||
.then(Commands.literal("player_slow_speed").executes(c -> {
|
||||
TextComponent parent = new TextComponent("Use ");
|
||||
TextComponent sub = new TextComponent("/tbm-server-edit player_slow_speed <0-100>");
|
||||
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
|
||||
parent.append(sub);
|
||||
|
||||
c.getSource().sendSuccess(parent, false);
|
||||
return 1;
|
||||
})
|
||||
.then(Commands.argument("slow_speed", IntegerArgumentType.integer()).executes(c -> {
|
||||
int slow_speed = IntegerArgumentType.getInteger(c, "slow_speed");
|
||||
// setPlayerSlowSpeed() in Config validates the value. Set it, then fetch it again.
|
||||
TurnBasedMinecraftMod.proxy.getConfig().setPlayerSlowSpeed(slow_speed);
|
||||
slow_speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
|
||||
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_slow_speed", slow_speed)) {
|
||||
TurnBasedMinecraftMod.logger.warn(
|
||||
"Failed to set \"server_config.player_slow_speed\" in config file!");
|
||||
c.getSource().sendFailure(new TextComponent(
|
||||
"Failed to set player_slow_speed to \""
|
||||
+ slow_speed
|
||||
+ "\" in config file!"));
|
||||
} else {
|
||||
TextComponent response = new TextComponent("Successfully set player_slow_speed to: ");
|
||||
TextComponent subResponse = new TextComponent(String.valueOf(slow_speed));
|
||||
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
|
||||
response.append(subResponse);
|
||||
c.getSource().sendSuccess(response, true);
|
||||
}
|
||||
return 1;
|
||||
})))
|
||||
);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue