diff options
author | Minenash <minenash@protonmail.com> | 2018-11-10 00:58:10 -0500 |
---|---|---|
committer | Minenash <minenash@protonmail.com> | 2018-11-10 00:58:10 -0500 |
commit | fe80557b8a7df5c1d03874931f76e6d88173d302 (patch) | |
tree | 4d0a7338406672dbf1b9a95158fc74fe0c95187f /src/main/java/com/redstoner/modules/chat | |
parent | 68a4f71e5c80ac2d40e945ea6ae06242759e8d6a (diff) |
Added /chatonly (/co).
Diffstat (limited to 'src/main/java/com/redstoner/modules/chat')
-rw-r--r-- | src/main/java/com/redstoner/modules/chat/Chat.cmd | 9 | ||||
-rw-r--r-- | src/main/java/com/redstoner/modules/chat/Chat.java | 43 |
2 files changed, 45 insertions, 7 deletions
diff --git a/src/main/java/com/redstoner/modules/chat/Chat.cmd b/src/main/java/com/redstoner/modules/chat/Chat.cmd index 3091609..2d73584 100644 --- a/src/main/java/com/redstoner/modules/chat/Chat.cmd +++ b/src/main/java/com/redstoner/modules/chat/Chat.cmd @@ -79,3 +79,12 @@ command unmute { help Unmutes a player.; } } + +command chatonly { + alias co; + [empty] { + run chatonly; + help Shows that you're onlu able to chat, nothing else.; + type player; + } +}
\ No newline at end of file diff --git a/src/main/java/com/redstoner/modules/chat/Chat.java b/src/main/java/com/redstoner/modules/chat/Chat.java index 1c7f8a1..4d32156 100644 --- a/src/main/java/com/redstoner/modules/chat/Chat.java +++ b/src/main/java/com/redstoner/modules/chat/Chat.java @@ -1,7 +1,10 @@ package com.redstoner.modules.chat; import java.util.HashMap; +import java.util.HashSet; import java.util.Map; +import java.util.Set; +import java.util.UUID; import org.bukkit.Bukkit; import org.bukkit.command.CommandSender; @@ -11,6 +14,7 @@ import org.bukkit.event.EventHandler; import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; import org.bukkit.event.player.AsyncPlayerChatEvent; +import org.bukkit.event.player.PlayerQuitEvent; import com.nemez.cmdmgr.Command; import com.redstoner.annotations.AutoRegisterListener; @@ -32,15 +36,17 @@ import net.nemez.chatapi.ChatAPI; public class Chat implements Module, Listener { private final Map<String, String> defaults = new HashMap<>(); + private Set<UUID> chatonly = new HashSet<>(); public Chat() { - defaults.put("chat", " %n §7→§r %m"); - defaults.put("me", " §7- %n §7⇦ %m"); - defaults.put("action", " §7- %n §7⇦ %m"); - defaults.put("say", " §7[§9%n§7]:§r %m"); - defaults.put("shrug", " %n §7→§r %m ¯\\_(ツ)_/¯"); + defaults.put("chat", " %n§7%c →§r %m"); + defaults.put("me", " §7- %n§7%c ⇦ %m"); + defaults.put("action", " §7- %n§7%c ⇦ %m"); + defaults.put("say", " §7[§9%n§7]%c:§r %m"); + defaults.put("shrug", " %n§7%c →§r %m ¯\\_(ツ)_/¯"); defaults.put("print", "%m"); + defaults.put("%c", "(c)"); } @Override @@ -53,6 +59,7 @@ public class Chat implements Module, Listener DataManager.setConfig("say", defaults.get("say")); DataManager.setConfig("shrug", defaults.get("shrug")); DataManager.setConfig("print", defaults.get("print")); + DataManager.setConfig("%c", defaults.get("%c")); } @EventHandler(priority = EventPriority.MONITOR) @@ -66,6 +73,12 @@ public class Chat implements Module, Listener broadcastFormatted("chat", player, message, event); } + @EventHandler + public void onLeave(PlayerQuitEvent event) + { + chatonly.remove(event.getPlayer().getUniqueId()); + } + @Command(hook = "me") public boolean me(CommandSender sender, String message) { @@ -164,6 +177,21 @@ public class Chat implements Module, Listener return true; } + @Command(hook = "chatonly") + public void chatonly(CommandSender sender) + { + UUID uuid = ((Player) sender).getUniqueId(); + + if (chatonly.contains(uuid)) { + chatonly.remove(uuid); + getLogger().message(sender, "You are no longer tagged with being only able to chat."); + } + else { + chatonly.add(uuid); + getLogger().message(sender, "You are now tagged with being only able to chat."); + } + } + public boolean broadcastFormatted(String format, CommandSender sender, String message) { return broadcastFormatted(format, sender, message, Utils.getName(sender), null); @@ -182,6 +210,7 @@ public class Chat implements Module, Listener public boolean broadcastFormatted(String format, CommandSender sender, String message, String name, AsyncPlayerChatEvent event) { + boolean isChatOnly = sender instanceof Player && chatonly.contains(((Player)sender).getUniqueId()); if ((boolean) DataManager.getOrDefault(sender, "muted", false)) { getLogger().message(sender, true, "You have been muted!"); @@ -190,7 +219,7 @@ public class Chat implements Module, Listener return false; } String raw = (String) DataManager.getConfigOrDefault(format, defaults.get(format)); - String formatted = raw.replace("%n", name).replace("%m", message); + String formatted = raw.replace("%n", name).replace("%m", message).replace("%c", isChatOnly? (String) DataManager.getConfigOrDefault("%c", defaults.get("%c")) : ""); Utils.broadcast("", ChatAPI.colorify(sender, formatted), wrap(ModuleLoader.exists("Ignore") ? Ignore.getIgnoredBy(sender) : null, event)); return true; @@ -206,7 +235,7 @@ public class Chat implements Module, Listener @Override public boolean sendTo(CommandSender recipient) { - if (recipient instanceof ConsoleCommandSender) + if (recipient instanceof ConsoleCommandSender || filter == null) return true; return filter.sendTo(recipient) && event.getRecipients().contains(recipient); } |