|
@@ -8,7 +8,7 @@ import org.bukkit.entity.Player;
|
|
|
|
|
|
import com.gmail.nossr50.Users;
|
|
import com.gmail.nossr50.Users;
|
|
import com.gmail.nossr50.mcMMO;
|
|
import com.gmail.nossr50.mcMMO;
|
|
-import com.gmail.nossr50.mcPermissions;
|
|
|
|
|
|
+import com.gmail.nossr50.commands.CommandHelper;
|
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
|
import com.gmail.nossr50.events.party.McMMOPartyChangeEvent;
|
|
import com.gmail.nossr50.events.party.McMMOPartyChangeEvent;
|
|
import com.gmail.nossr50.events.party.McMMOPartyChangeEvent.EventReason;
|
|
import com.gmail.nossr50.events.party.McMMOPartyChangeEvent.EventReason;
|
|
@@ -22,254 +22,252 @@ public class PartyCommand implements CommandExecutor {
|
|
this.plugin = plugin;
|
|
this.plugin = plugin;
|
|
}
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
|
- public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
|
|
|
-
|
|
|
|
- if (!(sender instanceof Player)) {
|
|
|
|
- sender.sendMessage("This command does not support console useage."); //TODO: Needs more locale.
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- Player player = (Player) sender;
|
|
|
|
- PlayerProfile PP = Users.getProfile(player);
|
|
|
|
-
|
|
|
|
- if (!mcPermissions.getInstance().party(player)) {
|
|
|
|
- player.sendMessage(ChatColor.YELLOW + "[mcMMO] " + ChatColor.DARK_RED + mcLocale.getString("mcPlayerListener.NoPermission"));
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- Party Pinstance = Party.getInstance();
|
|
|
|
-
|
|
|
|
- if (PP.inParty() && (!Pinstance.isParty(PP.getParty()) || !Pinstance.isInParty(player, PP))) {
|
|
|
|
- Pinstance.addToParty(player, PP, PP.getParty(), false, null);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if (args.length == 0 && !PP.inParty()) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help1", new Object[] { "party "}));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help2", new Object[] { "party "}));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help3", new Object[] { "party " }));
|
|
|
|
- return true;
|
|
|
|
- } else if (args.length == 0 && PP.inParty()) {
|
|
|
|
- String tempList = "";
|
|
|
|
- int x = 0;
|
|
|
|
- for (Player p : plugin.getServer().getOnlinePlayers()) {
|
|
|
|
- if (PP.getParty().equals(Users.getProfile(p).getParty())) {
|
|
|
|
- if (p != null && x + 1 >= Pinstance.partyCount(player)) {
|
|
|
|
- if (Pinstance.isPartyLeader(p.getName(), PP.getParty())) {
|
|
|
|
- tempList += ChatColor.GOLD + p.getName();
|
|
|
|
- x++;
|
|
|
|
- } else {
|
|
|
|
- tempList += ChatColor.WHITE + p.getName();
|
|
|
|
- x++;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- if (p != null && x < Pinstance.partyCount(player)) {
|
|
|
|
- if (Pinstance.isPartyLeader(p.getName(), PP.getParty())) {
|
|
|
|
- tempList += ChatColor.GOLD + p.getName() + ", ";
|
|
|
|
- x++;
|
|
|
|
- } else {
|
|
|
|
- tempList += ChatColor.WHITE + p.getName() + ", ";
|
|
|
|
- x++;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- player.sendMessage(mcLocale.getString("mcPlayerListener.YouAreInParty", new Object[] { PP.getParty() }));
|
|
|
|
- player.sendMessage(mcLocale.getString("mcPlayerListener.PartyMembers") + " (" + tempList + ChatColor.GREEN + ")");
|
|
|
|
-
|
|
|
|
- //Master Apprentice Stuff
|
|
|
|
- //Show the player all their bonuses when they type /party
|
|
|
|
-
|
|
|
|
- /*
|
|
|
|
- for(Player a : Party.getInstance().getPartyMembers(player))
|
|
|
|
- {
|
|
|
|
- if(Party.getInstance().isPartyLeader(a.getName(), PP.getParty()) && !a.getName().equals(player.getName()))
|
|
|
|
- {
|
|
|
|
- PlayerProfile LP = Users.getProfile(a);
|
|
|
|
- for(SkillType type : SkillType.values())
|
|
|
|
- {
|
|
|
|
- //Skip this one
|
|
|
|
- if(type == SkillType.ALL)
|
|
|
|
- continue;
|
|
|
|
-
|
|
|
|
- if(LP.getSkillLevel(type) > PP.getSkillLevel(type))
|
|
|
|
- {
|
|
|
|
- //Tell them what their skill bonus is for this skill
|
|
|
|
- int leaderLevel = LP.getSkillLevel(type);
|
|
|
|
- int difference = leaderLevel - PP.getSkillLevel(type);
|
|
|
|
-
|
|
|
|
- double bonusModifier = (difference*0.75D)/100D;
|
|
|
|
- double trueBonus = bonusModifier * 100;
|
|
|
|
- player.sendMessage("You get "+trueBonus+"% more XP from "+type.toString());
|
|
|
|
- //double percent = (trueBonus/100)*100;
|
|
|
|
- } else
|
|
|
|
- {
|
|
|
|
- //Tell them they have no bonus.. or not
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- } else if(Party.getInstance().isPartyLeader(a.getName(), PP.getParty()) && a.getName().equals(player.getName()))
|
|
|
|
- {
|
|
|
|
- //Tell them they are providing bonuses
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- */
|
|
|
|
-
|
|
|
|
- return true;
|
|
|
|
- } else if (args.length == 1) {
|
|
|
|
- if (args[0].equals("q") && PP.inParty()) {
|
|
|
|
-
|
|
|
|
- McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, PP.getParty(), null, EventReason.LEFT_PARTY);
|
|
|
|
- plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
|
|
+ @Override
|
|
|
|
+ public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
|
|
|
|
|
- if (event.isCancelled()) {
|
|
|
|
- return true;
|
|
|
|
|
|
+ if (CommandHelper.noConsoleUsage(sender)) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (CommandHelper.noCommandPermissions(sender, "mcmmo.commands.party")) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ Player player = (Player) sender;
|
|
|
|
+ String playerName = player.getName();
|
|
|
|
+ PlayerProfile PP = Users.getProfile(player);
|
|
|
|
+
|
|
|
|
+ Party partyInstance = Party.getInstance();
|
|
|
|
+ boolean inParty = PP.inParty();
|
|
|
|
+ String partyName = PP.getParty();
|
|
|
|
+ boolean isLeader = partyInstance.isPartyLeader(playerName, partyName);
|
|
|
|
+
|
|
|
|
+ if (PP.inParty() && (!partyInstance.isParty(PP.getParty()) || !partyInstance.isInParty(player, PP))) {
|
|
|
|
+ partyInstance.addToParty(player, PP, PP.getParty(), false, null);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ switch (args.length) {
|
|
|
|
+ case 0:
|
|
|
|
+ if (!inParty) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.0"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.1"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.2"));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ String tempList = "";
|
|
|
|
+
|
|
|
|
+ for (Player p : partyInstance.getAllMembers(player)) {
|
|
|
|
+ if (p.equals(partyInstance.getPartyLeader(partyName))) {
|
|
|
|
+ tempList = ChatColor.GOLD + p.getName();
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ tempList = ChatColor.WHITE + p.getName();
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ tempList += ChatColor.GOLD + playerName;
|
|
}
|
|
}
|
|
|
|
+ else {
|
|
|
|
+ tempList += ChatColor.WHITE + playerName;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ player.sendMessage(mcLocale.getString("Commands.Party.InParty", new Object[] { partyName }));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Commands.Party.Members", new Object[] { tempList }));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return true;
|
|
|
|
|
|
- Pinstance.removeFromParty(player, PP);
|
|
|
|
- player.sendMessage(mcLocale.getString("mcPlayerListener.LeftParty"));
|
|
|
|
- return true;
|
|
|
|
-
|
|
|
|
- } else if (args[0].equalsIgnoreCase("?")) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help4", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help2", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help5", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help6", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help7", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help8", new Object[] { "party " }));
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Help9", new Object[] { "party " }));
|
|
|
|
- } else if (args[0].equalsIgnoreCase("lock")) {
|
|
|
|
- if (PP.inParty()) {
|
|
|
|
- if (Pinstance.isPartyLeader(player.getName(), PP.getParty())) {
|
|
|
|
- Pinstance.lockParty(PP.getParty());
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Locked"));
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.InvalidName"));
|
|
|
|
- }
|
|
|
|
- } else if (args[0].equalsIgnoreCase("unlock")) {
|
|
|
|
- if (PP.inParty()) {
|
|
|
|
- if (Pinstance.isPartyLeader(player.getName(), PP.getParty())) {
|
|
|
|
- Pinstance.unlockParty(PP.getParty());
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.Unlocked"));
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.InvalidName"));
|
|
|
|
- }
|
|
|
|
- // Party debugging command.
|
|
|
|
- // } else if (args[0].equalsIgnoreCase("dump")) {
|
|
|
|
- // Pinstance.dump(player);
|
|
|
|
- } else {
|
|
|
|
- if (PP.inParty()) {
|
|
|
|
- McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, PP.getParty(), args[0], EventReason.CHANGED_PARTIES);
|
|
|
|
- plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
-
|
|
|
|
- if (event.isCancelled()) {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- Pinstance.removeFromParty(player, PP);
|
|
|
|
- }
|
|
|
|
- else {
|
|
|
|
|
|
+ case 1:
|
|
|
|
+ if (args[0].equalsIgnoreCase("q")) {
|
|
|
|
+ if (inParty) {
|
|
|
|
+ McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, partyName, null, EventReason.LEFT_PARTY);
|
|
|
|
+ plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
+
|
|
|
|
+ if (event.isCancelled()) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.removeFromParty(player, PP);
|
|
|
|
+ player.sendMessage(mcLocale.getString("Commands.Party.Leave"));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage("Commands.Party.None");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else if (args[0].equals("?")) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.3"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.1"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.4"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.5"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.6"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.7"));
|
|
|
|
+ }
|
|
|
|
+ else if (args[0].equalsIgnoreCase("lock")) {
|
|
|
|
+ if (inParty) {
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ if (partyInstance.isPartyLocked(partyName)) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.IsLocked"));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ partyInstance.lockParty(partyName);
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Locked"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage("Commands.Party.None");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else if (args[0].equalsIgnoreCase("unlock")) {
|
|
|
|
+ if (inParty) {
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ if (!partyInstance.isPartyLocked(partyName)) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.IsntLocked"));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ partyInstance.unlockParty(partyName);
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Unlocked"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage("Commands.Party.None");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ if (inParty) {
|
|
|
|
+ McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, partyName, args[0], EventReason.CHANGED_PARTIES);
|
|
|
|
+ plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
+
|
|
|
|
+ if (event.isCancelled()) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.removeFromParty(player, PP);
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, null, args[0], EventReason.JOINED_PARTY);
|
|
McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, null, args[0], EventReason.JOINED_PARTY);
|
|
plugin.getServer().getPluginManager().callEvent(event);
|
|
plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
|
|
if (event.isCancelled()) {
|
|
if (event.isCancelled()) {
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
- }
|
|
|
|
- Pinstance.addToParty(player, PP, args[0], false, null);
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
- } else if (args.length == 2 && PP.inParty()) {
|
|
|
|
- if (args[0].equalsIgnoreCase("password")) {
|
|
|
|
- if (Pinstance.isPartyLeader(player.getName(), PP.getParty())) {
|
|
|
|
- if (Pinstance.isPartyLocked(PP.getParty())) {
|
|
|
|
- Pinstance.setPartyPassword(PP.getParty(), args[1]);
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.PasswordSet", new Object[] { args[1] }));
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.IsntLocked"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
- }
|
|
|
|
- } else if (args[0].equalsIgnoreCase("kick")) {
|
|
|
|
- if (Pinstance.isPartyLeader(player.getName(), PP.getParty())) {
|
|
|
|
- if (Pinstance.isPartyLocked(PP.getParty())) {
|
|
|
|
- Player tPlayer = null;
|
|
|
|
- if (plugin.getServer().getPlayer(args[1]) != null)
|
|
|
|
- tPlayer = plugin.getServer().getPlayer(args[1]);
|
|
|
|
- if (tPlayer == null) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.CouldNotKick", new Object[] { args[1] }));
|
|
|
|
- }
|
|
|
|
- if (!Pinstance.inSameParty(player, tPlayer)) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotInYourParty", new Object[] { tPlayer.getName() }));
|
|
|
|
- } else {
|
|
|
|
- // Not an admin
|
|
|
|
- if (!mcPermissions.getInstance().admin(player)) {
|
|
|
|
- // Can't kick an admin
|
|
|
|
- if (mcPermissions.getInstance().admin(tPlayer)) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.CouldNotKick", new Object[] { tPlayer.getName() }));
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- PlayerProfile tPP = Users.getProfile(tPlayer);
|
|
|
|
-
|
|
|
|
- McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, tPP.getParty(), null, EventReason.KICKED_FROM_PARTY);
|
|
|
|
- plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
-
|
|
|
|
- if (event.isCancelled()) {
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- Pinstance.removeFromParty(tPlayer, tPP);
|
|
|
|
-
|
|
|
|
- tPlayer.sendMessage(mcLocale.getString("mcPlayerListener.LeftParty"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.IsntLocked"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
- }
|
|
|
|
- } else if (args[0].equalsIgnoreCase("owner")) {
|
|
|
|
- if (Pinstance.isPartyLeader(player.getName(), PP.getParty())) {
|
|
|
|
- Player tPlayer = null;
|
|
|
|
- if (plugin.getServer().getPlayer(args[1]) != null)
|
|
|
|
- tPlayer = plugin.getServer().getPlayer(args[1]);
|
|
|
|
- if (tPlayer == null) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.CouldNotSetOwner", new Object[] { args[1] }));
|
|
|
|
- }
|
|
|
|
- if (!Pinstance.inSameParty(player, tPlayer)) {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.CouldNotSetOwner", new Object[] { tPlayer.getName() }));
|
|
|
|
- } else {
|
|
|
|
- Pinstance.setPartyLeader(PP.getParty(), tPlayer.getName());
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, PP.getParty(), args[0], EventReason.CHANGED_PARTIES);
|
|
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.addToParty(player, PP, args[0], false, null);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return true;
|
|
|
|
+
|
|
|
|
+ case 2:
|
|
|
|
+ if (PP.inParty()) {
|
|
|
|
+ if (args[0].equalsIgnoreCase("password")) {
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ if (!partyInstance.isPartyLocked(partyName)) {
|
|
|
|
+ partyInstance.lockParty(partyName);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.setPartyPassword(partyName, args[1]);
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.PasswordSet", new Object[] { args[1] }));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else if (args[0].equalsIgnoreCase("kick")) {
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ Player target = plugin.getServer().getPlayer(args[1]);
|
|
|
|
+
|
|
|
|
+ if (target == null) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.CouldNotKick", new Object[] { args[1] }));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ PlayerProfile PPt = Users.getProfile(target);
|
|
|
|
+ String targetName = target.getName();
|
|
|
|
+
|
|
|
|
+ if (!partyInstance.inSameParty(player, (Player) target)) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotInYourParty", new Object[] { targetName }));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ else {
|
|
|
|
+ McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, partyName, null, EventReason.KICKED_FROM_PARTY);
|
|
|
|
+ plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
+
|
|
|
|
+ if (event.isCancelled()) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.removeFromParty(target, PPt);
|
|
|
|
+ target.sendMessage(mcLocale.getString("Commands.Party.Kick", new Object[] { partyName }));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else if (args[0].equalsIgnoreCase("owner")) {
|
|
|
|
+ if (isLeader) {
|
|
|
|
+ Player target = plugin.getServer().getPlayer(args[1]);
|
|
|
|
+
|
|
|
|
+ if (target == null) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.CouldNotSetOwner"));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ String targetName = target.getName();
|
|
|
|
+
|
|
|
|
+ if (!partyInstance.inSameParty(player, (Player) target)) {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotInYourParty", new Object[] { targetName }));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ else {
|
|
|
|
+ partyInstance.setPartyLeader(partyName, targetName);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.NotOwner"));
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, partyName, args[0], EventReason.CHANGED_PARTIES);
|
|
|
|
+ plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
+
|
|
|
|
+ if (event.isCancelled()) {
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ partyInstance.removeFromParty(player, PP);
|
|
|
|
+ partyInstance.addToParty(player, PP, args[0], false, args[1]);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, null, args[0], EventReason.JOINED_PARTY);
|
|
plugin.getServer().getPluginManager().callEvent(event);
|
|
plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
|
|
if (event.isCancelled()) {
|
|
if (event.isCancelled()) {
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
- Pinstance.removeFromParty(player, PP);
|
|
|
|
- Pinstance.addToParty(player, PP, args[0], false, args[1]);
|
|
|
|
- }
|
|
|
|
- } else if (args.length == 2 && !PP.inParty()) {
|
|
|
|
- McMMOPartyChangeEvent event = new McMMOPartyChangeEvent(player, null, args[0], EventReason.JOINED_PARTY);
|
|
|
|
- plugin.getServer().getPluginManager().callEvent(event);
|
|
|
|
-
|
|
|
|
- if (event.isCancelled()) {
|
|
|
|
- return true;
|
|
|
|
|
|
+
|
|
|
|
+ partyInstance.addToParty(player, PP, args[0], false, args[1]);
|
|
}
|
|
}
|
|
- Pinstance.addToParty(player, PP, args[0], false, args[1]);
|
|
|
|
- }
|
|
|
|
|
|
|
|
- return true;
|
|
|
|
- }
|
|
|
|
|
|
+ return true;
|
|
|
|
+
|
|
|
|
+ default:
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.0"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.1"));
|
|
|
|
+ player.sendMessage(mcLocale.getString("Party.Help.2"));
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
}
|
|
}
|