mirror of
https://github.com/plexusorg/Plex.git
synced 2025-04-18 15:53:00 +00:00
* Attempt to improve the tab completion for Plex * i give up for the night * steven is a god * Fix permission node
45 lines
1.7 KiB
Java
45 lines
1.7 KiB
Java
package dev.plex.command.impl;
|
|
|
|
import com.google.common.collect.ImmutableList;
|
|
import dev.plex.command.PlexCommand;
|
|
import dev.plex.command.annotation.CommandParameters;
|
|
import dev.plex.command.annotation.CommandPermissions;
|
|
import dev.plex.player.PlexPlayer;
|
|
import dev.plex.util.PlexUtils;
|
|
import net.kyori.adventure.text.Component;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
import org.jetbrains.annotations.NotNull;
|
|
import org.jetbrains.annotations.Nullable;
|
|
|
|
import java.util.List;
|
|
|
|
@CommandParameters(name = "lockup", description = "Lockup a player on the server", usage = "/<command> <player>")
|
|
@CommandPermissions(permission = "plex.lockup")
|
|
public class LockupCMD extends PlexCommand
|
|
{
|
|
@Override
|
|
protected Component execute(@NotNull CommandSender sender, @Nullable Player playerSender, String[] args)
|
|
{
|
|
if (args.length != 1)
|
|
{
|
|
return usage();
|
|
}
|
|
Player player = getNonNullPlayer(args[0]);
|
|
PlexPlayer punishedPlayer = getOfflinePlexPlayer(player.getUniqueId());
|
|
|
|
punishedPlayer.setLockedUp(!punishedPlayer.isLockedUp());
|
|
if (punishedPlayer.isLockedUp())
|
|
{
|
|
player.openInventory(player.getInventory());
|
|
}
|
|
PlexUtils.broadcast(messageComponent(punishedPlayer.isLockedUp() ? "lockedUpPlayer" : "unlockedPlayer", sender.getName(), player.getName()));
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public @NotNull List<String> smartTabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) throws IllegalArgumentException
|
|
{
|
|
return args.length == 1 && silentCheckPermission(sender, this.getPermission()) ? PlexUtils.getPlayerNameList() : ImmutableList.of();
|
|
}
|
|
} |