123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- package com.gmail.nossr50.party.commands;
- import org.bukkit.command.Command;
- import org.bukkit.command.CommandExecutor;
- import org.bukkit.command.CommandSender;
- import org.bukkit.entity.Player;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.commands.CommandHelper;
- import com.gmail.nossr50.datatypes.PlayerProfile;
- import com.gmail.nossr50.events.chat.McMMOPartyChatEvent;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.party.Party;
- import com.gmail.nossr50.party.PartyManager;
- import com.gmail.nossr50.util.Users;
- public class PCommand implements CommandExecutor {
- private final mcMMO plugin;
- public PCommand (mcMMO plugin) {
- this.plugin = plugin;
- }
- @Override
- public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
- PlayerProfile profile;
- String usage = LocaleLoader.getString("Commands.Usage.2", new Object[] {"p", "<" + LocaleLoader.getString("Commands.Usage.PartyName") + ">", "<" + LocaleLoader.getString("Commands.Usage.Message") + ">"});
- if (CommandHelper.noCommandPermissions(sender, "mcmmo.commands.party")) {
- return true;
- }
- switch (args.length) {
- case 0:
- if (sender instanceof Player) {
- profile = Users.getProfile((Player) sender);
- if (profile.getAdminChatMode()) {
- profile.toggleAdminChat();
- }
- profile.togglePartyChat();
- if (profile.getPartyChatMode()) {
- sender.sendMessage(LocaleLoader.getString("Commands.Party.Chat.On"));
- }
- else {
- sender.sendMessage(LocaleLoader.getString("Commands.Party.Chat.Off"));
- }
- }
- else {
- sender.sendMessage(usage);
- }
- return true;
- default:
- if (sender instanceof Player) {
- Player player = (Player) sender;
- Party party = Users.getProfile(player).getParty();
- if (party == null) {
- player.sendMessage(LocaleLoader.getString("Commands.Party.None"));
- return true;
- }
- StringBuilder builder = new StringBuilder();
- builder.append(args[0]);
- for (int i = 1; i < args.length; i++) {
- builder.append(" ");
- builder.append(args[i]);
- }
- String message = builder.toString();
- McMMOPartyChatEvent chatEvent = new McMMOPartyChatEvent(plugin, player.getName(), party.getName(), message);
- plugin.getServer().getPluginManager().callEvent(chatEvent);
- if (chatEvent.isCancelled()) {
- return true;
- }
- message = chatEvent.getMessage();
- String prefix = LocaleLoader.getString("Commands.Party.Chat.Prefix", new Object[] {player.getName()} );
- plugin.getLogger().info("[P](" + party.getName() + ")" + "<" + player.getName() + "> " + message);
- for (Player member : party.getOnlineMembers()) {
- member.sendMessage(prefix + message);
- }
- }
- else {
- if (args.length < 2) {
- sender.sendMessage(usage);
- return true;
- }
- if (!PartyManager.isParty(args[0])) {
- sender.sendMessage(LocaleLoader.getString("Party.InvalidName"));
- return true;
- }
- StringBuilder builder = new StringBuilder();
- builder.append(args[1]);
- for (int i = 2; i < args.length; i++) {
- builder.append(" ");
- builder.append(args[i]);
- }
- String message = builder.toString();
- McMMOPartyChatEvent chatEvent = new McMMOPartyChatEvent(plugin, "Console", args[0], message);
- plugin.getServer().getPluginManager().callEvent(chatEvent);
- if (chatEvent.isCancelled()) {
- return true;
- }
- message = chatEvent.getMessage();
- String prefix = LocaleLoader.getString("Commands.Party.Chat.Prefix", new Object[] {LocaleLoader.getString("Commands.Chat.Console")} );
- plugin.getLogger().info("[P](" + args[0] + ")" + "<*Console*> " + message);
- for (Player member : PartyManager.getOnlineMembers(args[0])) {
- member.sendMessage(prefix + message);
- }
- }
- return true;
- }
- }
- }
|