diff options
author | snowleo <schneeleo@gmail.com> | 2011-12-09 02:48:39 +0100 |
---|---|---|
committer | snowleo <schneeleo@gmail.com> | 2011-12-09 02:48:57 +0100 |
commit | de12c5c6d17147714c9452f76f8337dd996eb220 (patch) | |
tree | b25eecd8db4e77b65e8734eeabb9e6b69322c380 /EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java | |
parent | 95d5217f588f11f3477e57420c3c678d4f7e4293 (diff) | |
download | Essentials-de12c5c6d17147714c9452f76f8337dd996eb220.tar Essentials-de12c5c6d17147714c9452f76f8337dd996eb220.tar.gz Essentials-de12c5c6d17147714c9452f76f8337dd996eb220.tar.lz Essentials-de12c5c6d17147714c9452f76f8337dd996eb220.tar.xz Essentials-de12c5c6d17147714c9452f76f8337dd996eb220.zip |
Fix broken charge for shout and question
Diffstat (limited to 'EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java')
-rw-r--r-- | EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java index 17a219acd..22989d4f9 100644 --- a/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java +++ b/EssentialsChat/src/com/earth2me/essentials/chat/EssentialsChatPlayerListenerHighest.java @@ -10,14 +10,25 @@ import org.bukkit.event.player.PlayerChatEvent; public class EssentialsChatPlayerListenerHighest extends EssentialsChatPlayer { - public EssentialsChatPlayerListenerHighest(Server server, IEssentials ess, Map<String, IEssentialsChatListener> listeners) + private final transient Map<PlayerChatEvent, String> charges; + + public EssentialsChatPlayerListenerHighest(final Server server, + final IEssentials ess, + final Map<String, IEssentialsChatListener> listeners, + final Map<PlayerChatEvent, String> charges) { super(server, ess, listeners); + this.charges = charges; } @Override public void onPlayerChat(final PlayerChatEvent event) { + String charge = charges.remove(event); + if (charge == null) + { + charge = "chat"; + } if (isAborted(event)) { return; @@ -27,22 +38,14 @@ public class EssentialsChatPlayerListenerHighest extends EssentialsChatPlayer * This file should handle charging the user for the action before returning control back */ final User user = ess.getUser(event.getPlayer()); - final String chatType = getChatType(event.getMessage()); - final StringBuilder command = new StringBuilder(); - command.append("chat"); - - if (chatType.length() > 0) - { - command.append("-").append(chatType); - } try { - charge(user, command.toString()); + charge(user, charge); } catch (ChargeException e) { - ess.showError(user, e, command.toString()); + ess.showError(user, e, charge); event.setCancelled(true); return; } |