Added /chatonly (/co).
This commit is contained in:
@@ -79,3 +79,12 @@ command unmute {
|
|||||||
help Unmutes a player.;
|
help Unmutes a player.;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
command chatonly {
|
||||||
|
alias co;
|
||||||
|
[empty] {
|
||||||
|
run chatonly;
|
||||||
|
help Shows that you're onlu able to chat, nothing else.;
|
||||||
|
type player;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,7 +1,10 @@
|
|||||||
package com.redstoner.modules.chat;
|
package com.redstoner.modules.chat;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
@@ -11,6 +14,7 @@ import org.bukkit.event.EventHandler;
|
|||||||
import org.bukkit.event.EventPriority;
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
import com.nemez.cmdmgr.Command;
|
import com.nemez.cmdmgr.Command;
|
||||||
import com.redstoner.annotations.AutoRegisterListener;
|
import com.redstoner.annotations.AutoRegisterListener;
|
||||||
@@ -32,15 +36,17 @@ import net.nemez.chatapi.ChatAPI;
|
|||||||
public class Chat implements Module, Listener
|
public class Chat implements Module, Listener
|
||||||
{
|
{
|
||||||
private final Map<String, String> defaults = new HashMap<>();
|
private final Map<String, String> defaults = new HashMap<>();
|
||||||
|
private Set<UUID> chatonly = new HashSet<>();
|
||||||
|
|
||||||
public Chat()
|
public Chat()
|
||||||
{
|
{
|
||||||
defaults.put("chat", " %n §7→§r %m");
|
defaults.put("chat", " %n§7%c →§r %m");
|
||||||
defaults.put("me", " §7- %n §7⇦ %m");
|
defaults.put("me", " §7- %n§7%c ⇦ %m");
|
||||||
defaults.put("action", " §7- %n §7⇦ %m");
|
defaults.put("action", " §7- %n§7%c ⇦ %m");
|
||||||
defaults.put("say", " §7[§9%n§7]:§r %m");
|
defaults.put("say", " §7[§9%n§7]%c:§r %m");
|
||||||
defaults.put("shrug", " %n §7→§r %m ¯\\_(ツ)_/¯");
|
defaults.put("shrug", " %n§7%c →§r %m ¯\\_(ツ)_/¯");
|
||||||
defaults.put("print", "%m");
|
defaults.put("print", "%m");
|
||||||
|
defaults.put("%c", "(c)");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -53,6 +59,7 @@ public class Chat implements Module, Listener
|
|||||||
DataManager.setConfig("say", defaults.get("say"));
|
DataManager.setConfig("say", defaults.get("say"));
|
||||||
DataManager.setConfig("shrug", defaults.get("shrug"));
|
DataManager.setConfig("shrug", defaults.get("shrug"));
|
||||||
DataManager.setConfig("print", defaults.get("print"));
|
DataManager.setConfig("print", defaults.get("print"));
|
||||||
|
DataManager.setConfig("%c", defaults.get("%c"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR)
|
@EventHandler(priority = EventPriority.MONITOR)
|
||||||
@@ -66,6 +73,12 @@ public class Chat implements Module, Listener
|
|||||||
broadcastFormatted("chat", player, message, event);
|
broadcastFormatted("chat", player, message, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
chatonly.remove(event.getPlayer().getUniqueId());
|
||||||
|
}
|
||||||
|
|
||||||
@Command(hook = "me")
|
@Command(hook = "me")
|
||||||
public boolean me(CommandSender sender, String message)
|
public boolean me(CommandSender sender, String message)
|
||||||
{
|
{
|
||||||
@@ -164,6 +177,21 @@ public class Chat implements Module, Listener
|
|||||||
return true;
|
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)
|
public boolean broadcastFormatted(String format, CommandSender sender, String message)
|
||||||
{
|
{
|
||||||
return broadcastFormatted(format, sender, message, Utils.getName(sender), null);
|
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,
|
public boolean broadcastFormatted(String format, CommandSender sender, String message, String name,
|
||||||
AsyncPlayerChatEvent event)
|
AsyncPlayerChatEvent event)
|
||||||
{
|
{
|
||||||
|
boolean isChatOnly = sender instanceof Player && chatonly.contains(((Player)sender).getUniqueId());
|
||||||
if ((boolean) DataManager.getOrDefault(sender, "muted", false))
|
if ((boolean) DataManager.getOrDefault(sender, "muted", false))
|
||||||
{
|
{
|
||||||
getLogger().message(sender, true, "You have been muted!");
|
getLogger().message(sender, true, "You have been muted!");
|
||||||
@@ -190,7 +219,7 @@ public class Chat implements Module, Listener
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
String raw = (String) DataManager.getConfigOrDefault(format, defaults.get(format));
|
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),
|
Utils.broadcast("", ChatAPI.colorify(sender, formatted),
|
||||||
wrap(ModuleLoader.exists("Ignore") ? Ignore.getIgnoredBy(sender) : null, event));
|
wrap(ModuleLoader.exists("Ignore") ? Ignore.getIgnoredBy(sender) : null, event));
|
||||||
return true;
|
return true;
|
||||||
@@ -206,7 +235,7 @@ public class Chat implements Module, Listener
|
|||||||
@Override
|
@Override
|
||||||
public boolean sendTo(CommandSender recipient)
|
public boolean sendTo(CommandSender recipient)
|
||||||
{
|
{
|
||||||
if (recipient instanceof ConsoleCommandSender)
|
if (recipient instanceof ConsoleCommandSender || filter == null)
|
||||||
return true;
|
return true;
|
||||||
return filter.sendTo(recipient) && event.getRecipients().contains(recipient);
|
return filter.sendTo(recipient) && event.getRecipients().contains(recipient);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user