mirror of
https://github.com/plexusorg/Module-LibsDisguises.git
synced 2026-06-04 01:06:55 +00:00
Brigadier
This commit is contained in:
@@ -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."
|
||||||
Reference in New Issue
Block a user