12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- package com.gmail.nossr50.commands.party;
- import com.gmail.nossr50.events.party.McMMOPartyChangeEvent.EventReason;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.util.commands.CommandUtils;
- import com.neetgames.mcmmo.party.Party;
- import org.bukkit.OfflinePlayer;
- import org.bukkit.command.Command;
- import org.bukkit.command.CommandExecutor;
- import org.bukkit.command.CommandSender;
- import org.bukkit.entity.Player;
- import org.jetbrains.annotations.NotNull;
- public class PartyKickCommand implements CommandExecutor {
- @Override
- public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String[] args) {
- if (args.length == 2) {
- if (mcMMO.getUserManager().queryPlayer((Player) sender) == null) {
- sender.sendMessage(LocaleLoader.getString("Profile.PendingLoad"));
- return true;
- }
- Party playerParty = mcMMO.getUserManager().queryPlayer((Player) sender).getParty();
- String targetName = CommandUtils.getMatchedPlayerName(args[1]);
- if (!playerParty.hasMember(targetName)) {
- sender.sendMessage(LocaleLoader.getString("Party.NotInYourParty", targetName));
- return true;
- }
- OfflinePlayer target = mcMMO.p.getServer().getOfflinePlayer(targetName);
- if (target.isOnline()) {
- Player onlineTarget = target.getPlayer();
- String partyName = playerParty.getPartyName();
- if (!mcMMO.getPartyManager().handlePartyChangeEvent(onlineTarget, partyName, null, EventReason.KICKED_FROM_PARTY)) {
- return true;
- }
- mcMMO.getPartyManager().processPartyLeaving(mcMMO.getUserManager().queryPlayer(onlineTarget));
- onlineTarget.sendMessage(LocaleLoader.getString("Commands.Party.Kick", partyName));
- }
- mcMMO.getPartyManager().removeFromParty(target, playerParty);
- return true;
- }
- sender.sendMessage(LocaleLoader.getString("Commands.Usage.2", "party", "kick", "<" + LocaleLoader.getString("Commands.Usage.Player") + ">"));
- return true;
- }
- }
|