mirror of
https://github.com/AtlasMediaGroup/TotalFreedomMod.git
synced 2025-04-22 17:53:02 +00:00
Lombok implementation removal. I have also gone through and replaced things with inline methods and variables, lambdas, and simplified loops down, removed unnecessary guard clauses, and overall cleaned up every single class. This took a long time, please do remember to follow proper naming conventions, don't include unnecessary guard clauses, follow exception rules and comment rules, and please PLEASE remember to use the DIAMOND OPERATOR rather than just inferring RAW TYPES!!! Thank you!!
88 lines
2.6 KiB
Java
88 lines
2.6 KiB
Java
package me.totalfreedom.totalfreedommod.command;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
import me.totalfreedom.totalfreedommod.rank.Rank;
|
|
import me.totalfreedom.totalfreedommod.util.FUtil;
|
|
import org.apache.commons.lang.StringUtils;
|
|
import org.bukkit.command.Command;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.potion.PotionEffectType;
|
|
|
|
@CommandPermissions(level = Rank.OP, source = SourceType.BOTH)
|
|
@CommandParameters(description = "Shows (optionally clears) invisible players", usage = "/<command> [clear]")
|
|
public class Command_invis extends FreedomCommand
|
|
{
|
|
|
|
@Override
|
|
public boolean run(CommandSender sender, Player playerSender, Command cmd, String commandLabel, String[] args, boolean senderIsConsole)
|
|
{
|
|
boolean clear = false;
|
|
|
|
if (args.length >= 1)
|
|
{
|
|
if (args[0].equalsIgnoreCase("clear"))
|
|
{
|
|
if (!plugin.al.isAdmin(sender))
|
|
{
|
|
return noPerms();
|
|
}
|
|
else
|
|
{
|
|
FUtil.adminAction(sender.getName(), "Clearing all invisibility potion effects from all players", true);
|
|
clear = true;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
List<String> players = new ArrayList<>();
|
|
int clears = 0;
|
|
|
|
for (Player player : server.getOnlinePlayers())
|
|
{
|
|
if (player.hasPotionEffect(PotionEffectType.INVISIBILITY) && !plugin.al.isVanished(player.getName()))
|
|
{
|
|
players.add(player.getName());
|
|
if (clear && !plugin.al.isAdmin(player))
|
|
{
|
|
player.removePotionEffect((PotionEffectType.INVISIBILITY));
|
|
clears++;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (players.isEmpty())
|
|
{
|
|
msg("There are no invisible players");
|
|
return true;
|
|
}
|
|
|
|
if (clear)
|
|
{
|
|
msg("Cleared " + clears + " players");
|
|
}
|
|
else
|
|
{
|
|
msg("Invisible players (" + players.size() + "): " + StringUtils.join(players, ", "));
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public List<String> getTabCompleteOptions(CommandSender sender, Command command, String alias, String[] args)
|
|
{
|
|
if (args.length == 1 && plugin.al.isAdmin(sender))
|
|
{
|
|
return Collections.singletonList("clear");
|
|
}
|
|
|
|
return Collections.emptyList();
|
|
}
|
|
} |