mirror of
https://github.com/AtlasMediaGroup/TotalFreedomMod.git
synced 2025-04-06 19:43:14 +00:00
- Cleans up /potion a tiny bit - Rewrites part of /moblimiter - Resolves FS-346 by cleaning up /setlever - Modernizes /opall a bit - Changes more components to use Adventure
223 lines
8.1 KiB
Java
223 lines
8.1 KiB
Java
package me.totalfreedom.totalfreedommod.command;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Arrays;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
import me.totalfreedom.totalfreedommod.rank.Rank;
|
|
import me.totalfreedom.totalfreedommod.util.FUtil;
|
|
import org.bukkit.ChatColor;
|
|
import org.bukkit.command.Command;
|
|
import org.bukkit.command.CommandSender;
|
|
import org.bukkit.entity.Player;
|
|
import org.bukkit.potion.PotionEffect;
|
|
import org.bukkit.potion.PotionEffectType;
|
|
|
|
@CommandPermissions(level = Rank.OP, source = SourceType.BOTH)
|
|
@CommandParameters(
|
|
description = "Manipulate your potion effects. Duration is measured in server ticks (~20 ticks per second).",
|
|
usage = "/<command> <list | clearall | clear [target name] | add <type> <duration> <amplifier> [target name]>",
|
|
aliases = "effect")
|
|
public class Command_potion extends FreedomCommand
|
|
{
|
|
@Override
|
|
public boolean run(CommandSender sender, Player playerSender, Command cmd, String commandLabel, String[] args, boolean senderIsConsole)
|
|
{
|
|
switch (args.length)
|
|
{
|
|
case 1:
|
|
{
|
|
if (args[0].equalsIgnoreCase("list"))
|
|
{
|
|
msg("Potion effect types: " + FUtil.listToString(Arrays.stream(PotionEffectType.values())
|
|
.map(PotionEffectType::getName).toList()), ChatColor.AQUA);
|
|
}
|
|
else if (args[0].equalsIgnoreCase("clearall"))
|
|
{
|
|
if (!(plugin.al.isAdmin(sender) || senderIsConsole))
|
|
{
|
|
noPerms();
|
|
return true;
|
|
}
|
|
|
|
FUtil.adminAction(sender.getName(), "Clearing all potion effects from all players", true);
|
|
server.getOnlinePlayers().forEach(target -> target.getActivePotionEffects().forEach(effect ->
|
|
target.removePotionEffect(effect.getType())));
|
|
}
|
|
}
|
|
|
|
case 2:
|
|
{
|
|
if (args[0].equalsIgnoreCase("clear"))
|
|
{
|
|
Player target = playerSender;
|
|
if (args.length == 2)
|
|
{
|
|
if (!plugin.al.isAdmin(sender) && !args[1].equalsIgnoreCase(sender.getName()))
|
|
{
|
|
msg(ChatColor.RED + "Only admins can clear potion effects from other players.");
|
|
return true;
|
|
}
|
|
target = getPlayer(args[1], true);
|
|
}
|
|
else
|
|
{
|
|
if (senderIsConsole)
|
|
{
|
|
msg("You must specify a target player when using this command from the console.");
|
|
return true;
|
|
}
|
|
}
|
|
|
|
if (target == null)
|
|
{
|
|
msg(PLAYER_NOT_FOUND, ChatColor.RED);
|
|
return true;
|
|
}
|
|
|
|
for (PotionEffect potion_effect : target.getActivePotionEffects())
|
|
{
|
|
target.removePotionEffect(potion_effect.getType());
|
|
}
|
|
|
|
msg("Cleared all active potion effects " + (!target.equals(playerSender) ? "from player "
|
|
+ target.getName() + "." : "from yourself."), ChatColor.AQUA);
|
|
}
|
|
break;
|
|
}
|
|
|
|
case 4:
|
|
case 5:
|
|
{
|
|
if (args[0].equalsIgnoreCase("add"))
|
|
{
|
|
Player target = playerSender;
|
|
|
|
if (args.length == 5)
|
|
{
|
|
if (!plugin.al.isAdmin(sender) && !args[4].equalsIgnoreCase(sender.getName()))
|
|
{
|
|
msg("Only admins can apply potion effects to other players.", ChatColor.RED);
|
|
return true;
|
|
}
|
|
|
|
target = getPlayer(args[4]);
|
|
|
|
if (target == null || plugin.al.isVanished(target.getUniqueId()) && !plugin.al.isAdmin(sender))
|
|
{
|
|
msg(PLAYER_NOT_FOUND);
|
|
return true;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (senderIsConsole)
|
|
{
|
|
msg("You must specify a target player when using this command from the console.");
|
|
return true;
|
|
}
|
|
}
|
|
|
|
PotionEffectType effectType = PotionEffectType.getByName(args[1]);
|
|
if (effectType == null)
|
|
{
|
|
msg("Invalid potion effect: " + args[1], ChatColor.AQUA);
|
|
return true;
|
|
}
|
|
|
|
int duration;
|
|
try
|
|
{
|
|
duration = Math.min(Integer.parseInt(args[2]), 100000);
|
|
}
|
|
catch (NumberFormatException ex)
|
|
{
|
|
msg("Invalid duration: " + args[2], ChatColor.RED);
|
|
return true;
|
|
}
|
|
|
|
int amplifier;
|
|
try
|
|
{
|
|
amplifier = Math.min(Integer.parseInt(args[3]), 100000);
|
|
}
|
|
catch (NumberFormatException ex)
|
|
{
|
|
msg("Invalid potion amplifier: " + args[3], ChatColor.RED);
|
|
return true;
|
|
}
|
|
|
|
PotionEffect new_effect = effectType.createEffect(duration, amplifier);
|
|
target.addPotionEffect(new_effect);
|
|
msg("Added potion effect: " + new_effect.getType().getName()
|
|
+ ", Duration: " + new_effect.getDuration()
|
|
+ ", Amplifier: " + new_effect.getAmplifier()
|
|
+ (!target.equals(playerSender) ? " to player " + target.getName() + "." : " to yourself."), ChatColor.AQUA);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public List<String> getTabCompleteOptions(CommandSender sender, Command command, String alias, String[] args)
|
|
{
|
|
switch (args.length)
|
|
{
|
|
case 1 ->
|
|
{
|
|
List<String> arguments = new ArrayList<>(Arrays.asList("list", "clear", "add"));
|
|
if (plugin.al.isAdmin(sender))
|
|
{
|
|
arguments.add("clearall");
|
|
}
|
|
return arguments;
|
|
}
|
|
case 2 ->
|
|
{
|
|
if (args[0].equalsIgnoreCase("clear"))
|
|
{
|
|
if (plugin.al.isAdmin(sender))
|
|
{
|
|
return FUtil.getPlayerList();
|
|
}
|
|
}
|
|
else if (args[0].equalsIgnoreCase("add"))
|
|
{
|
|
return Arrays.stream(PotionEffectType.values()).map(PotionEffectType::getName).toList();
|
|
}
|
|
}
|
|
case 3 ->
|
|
{
|
|
if (args[0].equalsIgnoreCase("add"))
|
|
{
|
|
return Collections.singletonList("<duration>");
|
|
}
|
|
}
|
|
case 4 ->
|
|
{
|
|
if (args[0].equalsIgnoreCase("add"))
|
|
{
|
|
return Collections.singletonList("<amplifier>");
|
|
}
|
|
}
|
|
case 5 ->
|
|
{
|
|
if (plugin.al.isAdmin(sender) && args[0].equalsIgnoreCase("add"))
|
|
{
|
|
return FUtil.getPlayerList();
|
|
}
|
|
}
|
|
default ->
|
|
{
|
|
}
|
|
}
|
|
|
|
return Collections.emptyList();
|
|
}
|
|
} |