Brigadier

This commit is contained in:
2026-05-19 21:41:59 -04:00
parent 157b8996fa
commit 3bd56f5aac
5 changed files with 45 additions and 28 deletions
+7 -1
View File
@@ -11,6 +11,12 @@ public class LibsDisguises extends PlexModule
public static boolean enabled = true; public static boolean enabled = true;
DisguiseListener disguiseListener; DisguiseListener disguiseListener;
@Override
public void load()
{
loadMessages("libsdisguises/messages.yml");
}
@Override @Override
public void enable() public void enable()
{ {
@@ -21,7 +27,7 @@ public class LibsDisguises extends PlexModule
} }
registerCommand(new DisguiseToggleCMD()); registerCommand(new DisguiseToggleCMD());
registerCommand(new UndisguiseAllCMD()); registerCommand(new UndisguiseAllCMD());
disguiseListener = new DisguiseListener(api()); disguiseListener = new DisguiseListener(this);
disguiseListener.getCommands(); disguiseListener.getCommands();
registerListener(disguiseListener); registerListener(disguiseListener);
} }
@@ -1,23 +1,26 @@
package dev.plex.command; package dev.plex.command;
import dev.plex.LibsDisguises; import dev.plex.LibsDisguises;
import dev.plex.command.annotation.CommandParameters;
import dev.plex.command.annotation.CommandPermissions;
import dev.plex.listener.UndisguiseEvent; import dev.plex.listener.UndisguiseEvent;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import net.kyori.adventure.text.Component; import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.format.NamedTextColor;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
@CommandParameters(name = "disguisetoggle", description = "Toggle LibsDisguises", aliases = "dtoggle") public class DisguiseToggleCMD extends SimplePlexCommand
@CommandPermissions(permission = "plex.libsdisguises.disguisetoggle")
public class DisguiseToggleCMD extends PlexCommand
{ {
public DisguiseToggleCMD()
{
super(command("disguisetoggle")
.description("Toggle LibsDisguises")
.aliases("dtoggle")
.permission("plex.libsdisguises.disguisetoggle")
.build());
}
@Override @Override
protected Component execute(@NotNull CommandSender commandSender, @Nullable Player player, @NotNull String[] strings) protected Component execute(@NotNull CommandSender commandSender, @Nullable Player player, @NotNull String[] strings)
{ {
@@ -26,12 +29,12 @@ public class DisguiseToggleCMD extends PlexCommand
{ {
Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(true)); Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(true));
} }
Bukkit.broadcast(Component.text(commandSender.getName() + " - " + (LibsDisguises.enabled ? "Enabling LibsDisguises" : "Disabling LibsDisguises")).color((LibsDisguises.enabled ? NamedTextColor.AQUA : NamedTextColor.RED))); broadcast(messageComponent(LibsDisguises.enabled ? "disguisesEnabled" : "disguisesDisabled", commandSender.getName()));
return null; return null;
} }
@Override @Override
public @NotNull List<String> smartTabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException protected @NotNull List<String> suggestions(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException
{ {
return Collections.emptyList(); return Collections.emptyList();
} }
@@ -1,42 +1,46 @@
package dev.plex.command; package dev.plex.command;
import dev.plex.command.annotation.CommandParameters;
import dev.plex.command.annotation.CommandPermissions;
import dev.plex.listener.UndisguiseEvent; import dev.plex.listener.UndisguiseEvent;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import net.kyori.adventure.text.Component; import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.format.NamedTextColor;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
@CommandParameters(name = "undisguiseall", usage = "/<command> [-a]", description = "Undisguise all players", aliases = "undisall,uall") public class UndisguiseAllCMD extends SimplePlexCommand
@CommandPermissions(permission = "plex.libsdisguises.undisguiseall")
public class UndisguiseAllCMD extends PlexCommand
{ {
public UndisguiseAllCMD()
{
super(command("undisguiseall")
.description("Undisguise all players")
.usage("/<command> [-a]")
.aliases("undisall,uall")
.permission("plex.libsdisguises.undisguiseall")
.build());
}
@Override @Override
protected Component execute(@NotNull CommandSender sender, @Nullable Player player, @NotNull String[] args) protected Component execute(@NotNull CommandSender sender, @Nullable Player player, @NotNull String[] args)
{ {
if (args.length == 0) if (args.length == 0)
{ {
Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(false)); Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(false));
Bukkit.broadcast(Component.text(sender.getName() + " - Undisguising all non-admins").color(NamedTextColor.RED)); broadcast(messageComponent("undisguiseAllNonAdmins", sender.getName()));
return null; return null;
} }
else if (args[0].equalsIgnoreCase("-a")) else if (args[0].equalsIgnoreCase("-a"))
{ {
Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(true)); Bukkit.getServer().getPluginManager().callEvent(new UndisguiseEvent(true));
Bukkit.broadcast(Component.text(sender.getName() + " - Undisguising all players").color(NamedTextColor.RED)); broadcast(messageComponent("undisguiseAllPlayers", sender.getName()));
return null; return null;
} }
return usage(); return usage();
} }
@Override @Override
public @NotNull List<String> smartTabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException protected @NotNull List<String> suggestions(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException
{ {
if (silentCheckPermission(sender, this.getPermission())) if (silentCheckPermission(sender, this.getPermission()))
{ {
@@ -1,7 +1,6 @@
package dev.plex.listener; package dev.plex.listener;
import dev.plex.LibsDisguises; import dev.plex.LibsDisguises;
import dev.plex.api.PlexApi;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import me.libraryaddict.disguise.DisguiseAPI; import me.libraryaddict.disguise.DisguiseAPI;
@@ -13,8 +12,6 @@ import me.libraryaddict.disguise.disguisetypes.watchers.PhantomWatcher;
import me.libraryaddict.disguise.disguisetypes.watchers.SlimeWatcher; import me.libraryaddict.disguise.disguisetypes.watchers.SlimeWatcher;
import me.libraryaddict.disguise.disguisetypes.watchers.WitherWatcher; import me.libraryaddict.disguise.disguisetypes.watchers.WitherWatcher;
import me.libraryaddict.disguise.events.DisguiseEvent; import me.libraryaddict.disguise.events.DisguiseEvent;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.format.NamedTextColor;
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer; import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
@@ -28,11 +25,11 @@ import org.bukkit.plugin.Plugin;
public class DisguiseListener extends PlexListener public class DisguiseListener extends PlexListener
{ {
private final PlexApi api; private final LibsDisguises module;
public DisguiseListener(PlexApi api) public DisguiseListener(LibsDisguises module)
{ {
this.api = api; this.module = module;
} }
private static float safeYMod(float f) private static float safeYMod(float f)
@@ -47,7 +44,7 @@ public class DisguiseListener extends PlexListener
Player playerSender = event.getCommandSender() instanceof Player player ? player : null; Player playerSender = event.getCommandSender() instanceof Player player ? player : null;
if (event.getDisguise().getType() == DisguiseType.FISHING_HOOK) if (event.getDisguise().getType() == DisguiseType.FISHING_HOOK)
{ {
event.getCommandSender().sendMessage(Component.text("You cannot use Fishing Hook disguises").color(NamedTextColor.RED)); event.getCommandSender().sendMessage(module.messageComponent("fishingHookDisguiseDenied"));
return; return;
} }
String name = event.getDisguise().getWatcher().getCustomName(); String name = event.getDisguise().getWatcher().getCustomName();
@@ -57,7 +54,7 @@ public class DisguiseListener extends PlexListener
// each color code counts as one char rather than two, for flexibility // each color code counts as one char rather than two, for flexibility
if (((name.length() - noColorLen) / 2) + noColorLen > 32) if (((name.length() - noColorLen) / 2) + noColorLen > 32)
{ {
event.getCommandSender().sendMessage(Component.text("Your disguise name is too long").color(NamedTextColor.RED)); event.getCommandSender().sendMessage(module.messageComponent("disguiseNameTooLong"));
return; return;
} }
} }
@@ -151,7 +148,7 @@ public class DisguiseListener extends PlexListener
{ {
if (message.equalsIgnoreCase(command.getName()) || message.equalsIgnoreCase(commandAliases)) if (message.equalsIgnoreCase(command.getName()) || message.equalsIgnoreCase(commandAliases))
{ {
event.getPlayer().sendMessage(Component.text("LibsDisguises is currently disabled.").color(NamedTextColor.RED)); event.getPlayer().sendMessage(module.messageComponent("libsDisguisesCurrentlyDisabled"));
event.setCancelled(true); event.setCancelled(true);
break; break;
} }
@@ -170,7 +167,7 @@ public class DisguiseListener extends PlexListener
commands.addAll(commandList); commands.addAll(commandList);
} }
} }
api.logging().info("Successfully fetched all LibsDisguises commands!"); module.api().logging().info("Successfully fetched all LibsDisguises commands!");
return commands; return commands;
} }
} }
@@ -0,0 +1,7 @@
disguisesEnabled: "<aqua>{0} - Enabling LibsDisguises"
disguisesDisabled: "<red>{0} - Disabling LibsDisguises"
undisguiseAllNonAdmins: "<red>{0} - Undisguising all non-admins"
undisguiseAllPlayers: "<red>{0} - Undisguising all players"
fishingHookDisguiseDenied: "<red>You cannot use Fishing Hook disguises"
disguiseNameTooLong: "<red>Your disguise name is too long"
libsDisguisesCurrentlyDisabled: "<red>LibsDisguises is currently disabled."