Fixes, implemented ChatRooms, less code for preprocess
This commit is contained in:
parent
2ab6a5f4eb
commit
7174a97728
3 changed files with 67 additions and 87 deletions
|
@ -158,7 +158,7 @@ public class ChatProcessing {
|
||||||
((List<TellrawPart>) json.getExtra()).add(0, new TellrawPart("[SPY]"));
|
((List<TellrawPart>) json.getExtra()).add(0, new TellrawPart("[SPY]"));
|
||||||
jsonstr = toJson(json);
|
jsonstr = toJson(json);
|
||||||
Bukkit.getServer().dispatchCommand(PluginMain.Console, String.format(
|
Bukkit.getServer().dispatchCommand(PluginMain.Console, String.format(
|
||||||
"tellraw @a[score_%s=1000,score_%s_min=1000 %s", channel.ID, channel.ID, jsonstr));
|
"tellraw @a[score_%s=1000,score_%s_min=1000] %s", channel.ID, channel.ID, jsonstr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
|
|
|
@ -339,8 +339,6 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
private static RecipientTestResult checkTownNationChatInternal(CommandSender sender, boolean nationchat,
|
private static RecipientTestResult checkTownNationChatInternal(CommandSender sender, boolean nationchat,
|
||||||
Resident resident) {
|
Resident resident) {
|
||||||
try {
|
try {
|
||||||
if (resident != null && resident.getModes().contains("spy"))
|
|
||||||
return new RecipientTestResult(1000); // There won't be more than a thousand towns/nations probably
|
|
||||||
/*
|
/*
|
||||||
* p.sendMessage(String.format("[SPY-%s] - %s: %s", channel.DisplayName, ((Player) sender).getDisplayName(), message));
|
* p.sendMessage(String.format("[SPY-%s] - %s: %s", channel.DisplayName, ((Player) sender).getDisplayName(), message));
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -2,9 +2,12 @@ package buttondevteam.chat.listener;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.*;
|
import org.bukkit.event.*;
|
||||||
import org.bukkit.event.entity.PlayerDeathEvent;
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
@ -18,6 +21,7 @@ import buttondevteam.lib.TBMCChatEvent;
|
||||||
import buttondevteam.lib.TBMCCoreAPI;
|
import buttondevteam.lib.TBMCCoreAPI;
|
||||||
import buttondevteam.lib.chat.Channel;
|
import buttondevteam.lib.chat.Channel;
|
||||||
import buttondevteam.lib.chat.ChatChannelRegisterEvent;
|
import buttondevteam.lib.chat.ChatChannelRegisterEvent;
|
||||||
|
import buttondevteam.lib.chat.ChatRoom;
|
||||||
import buttondevteam.lib.chat.TBMCChatAPI;
|
import buttondevteam.lib.chat.TBMCChatAPI;
|
||||||
import buttondevteam.lib.player.TBMCPlayer;
|
import buttondevteam.lib.player.TBMCPlayer;
|
||||||
import buttondevteam.lib.player.TBMCPlayerGetInfoEvent;
|
import buttondevteam.lib.player.TBMCPlayerGetInfoEvent;
|
||||||
|
@ -58,43 +62,67 @@ public class PlayerListener implements Listener {
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST)
|
@EventHandler(priority = EventPriority.HIGHEST)
|
||||||
public void PlayerCommandPreprocess(PlayerCommandPreprocessEvent event) {
|
public void PlayerCommandPreprocess(PlayerCommandPreprocessEvent event) {
|
||||||
if (event.getMessage().length() < 2)
|
if (!event.isCancelled())
|
||||||
return;
|
event.setCancelled(onCommandPreprocess(event.getPlayer(), event.getMessage()));
|
||||||
int index = event.getMessage().indexOf(" ");
|
}
|
||||||
ChatPlayer mp = TBMCPlayer.getPlayer(event.getPlayer().getUniqueId(), ChatPlayer.class);
|
|
||||||
|
private boolean onCommandPreprocess(CommandSender sender, String message) {
|
||||||
|
if (message.length() < 2)
|
||||||
|
return false;
|
||||||
|
int index = message.indexOf(" ");
|
||||||
|
ChatPlayer mp;
|
||||||
|
if (sender instanceof Player)
|
||||||
|
mp = TBMCPlayer.getPlayer(((Player) sender).getUniqueId(), ChatPlayer.class);
|
||||||
|
else
|
||||||
|
mp = null;
|
||||||
String cmd = "";
|
String cmd = "";
|
||||||
if (index == -1) { // Only the command is run
|
if (index == -1 && (sender instanceof Player || sender instanceof ConsoleCommandSender)) { // Only the command is run
|
||||||
cmd = event.getMessage().substring(1);
|
// ^^ We can only store player or console channels - Directly sending to channels would still work if they had an event
|
||||||
|
cmd = sender instanceof ConsoleCommandSender ? message : message.substring(1);
|
||||||
for (Channel channel : Channel.getChannels()) {
|
for (Channel channel : Channel.getChannels()) {
|
||||||
if (cmd.equalsIgnoreCase(channel.ID)) {
|
if (cmd.equalsIgnoreCase(channel.ID)) {
|
||||||
if (mp.CurrentChannel.equals(channel))
|
Supplier<Channel> getch = () -> sender instanceof Player ? mp.CurrentChannel : ConsoleChannel;
|
||||||
mp.CurrentChannel = Channel.GlobalChat;
|
Consumer<Channel> setch = ch -> {
|
||||||
else
|
if (sender instanceof Player)
|
||||||
mp.CurrentChannel = channel;
|
mp.CurrentChannel = ch;
|
||||||
event.getPlayer().sendMessage("§6You are now talking in: §b" + mp.CurrentChannel.DisplayName);
|
else
|
||||||
event.setCancelled(true);
|
ConsoleChannel = ch;
|
||||||
break;
|
};
|
||||||
|
Channel oldch = getch.get();
|
||||||
|
if (oldch instanceof ChatRoom)
|
||||||
|
((ChatRoom) oldch).leaveRoom(sender);
|
||||||
|
if (oldch.equals(channel))
|
||||||
|
setch.accept(Channel.GlobalChat);
|
||||||
|
else {
|
||||||
|
setch.accept(channel);
|
||||||
|
if (channel instanceof ChatRoom)
|
||||||
|
((ChatRoom) channel).joinRoom(sender);
|
||||||
|
}
|
||||||
|
sender.sendMessage("§6You are now talking in: §b" + getch.get().DisplayName);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else { // We have arguments
|
} else { // We have arguments
|
||||||
cmd = event.getMessage().substring(1, index);
|
cmd = sender instanceof ConsoleCommandSender ? message.substring(0, index) : message.substring(1, index);
|
||||||
if (cmd.equalsIgnoreCase("tpahere")) {
|
if (cmd.equalsIgnoreCase("tpahere")) {
|
||||||
Player player = Bukkit.getPlayer(event.getMessage().substring(index + 1));
|
Player player = Bukkit.getPlayer(message.substring(index + 1));
|
||||||
if (player != null)
|
if (player != null && sender instanceof Player)
|
||||||
player.sendMessage("§b" + event.getPlayer().getDisplayName() + " §bis in this world: "
|
player.sendMessage("§b" + ((Player) sender).getDisplayName() + " §bis in this world: "
|
||||||
+ event.getPlayer().getWorld().getName());
|
+ ((Player) sender).getWorld().getName());
|
||||||
} else if (cmd.equalsIgnoreCase("minecraft:me")) {
|
} else if (cmd.equalsIgnoreCase("minecraft:me")) {
|
||||||
if (!PluginMain.essentials.getUser(event.getPlayer()).isMuted()) {
|
if (!(sender instanceof Player) || !PluginMain.essentials.getUser((Player) sender).isMuted()) {
|
||||||
event.setCancelled(true);
|
String msg = message.substring(index + 1);
|
||||||
String message = event.getMessage().substring(index + 1);
|
Bukkit.broadcastMessage(String.format("* %s %s", ((Player) sender).getDisplayName(), msg));
|
||||||
Bukkit.broadcastMessage(String.format("* %s %s", event.getPlayer().getDisplayName(), message));
|
return true;
|
||||||
|
} else {
|
||||||
|
sender.sendMessage("§cCan't use /minecraft:me while muted.");
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
for (Channel channel : Channel.getChannels()) {
|
for (Channel channel : Channel.getChannels()) {
|
||||||
if (cmd.equalsIgnoreCase(channel.ID)) {
|
if (cmd.equalsIgnoreCase(channel.ID)) {
|
||||||
event.setCancelled(true);
|
TBMCChatAPI.SendChatMessage(channel, sender, message.substring(index + 1));
|
||||||
TBMCChatAPI.SendChatMessage(channel, event.getPlayer(),
|
return true;
|
||||||
event.getMessage().substring(index + 1));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// TODO: Target selectors
|
// TODO: Target selectors
|
||||||
|
@ -103,24 +131,24 @@ public class PlayerListener implements Listener {
|
||||||
if (cmd.toLowerCase().startsWith("un")) {
|
if (cmd.toLowerCase().startsWith("un")) {
|
||||||
for (HelpTopic ht : PluginMain.Instance.getServer().getHelpMap().getHelpTopics()) {
|
for (HelpTopic ht : PluginMain.Instance.getServer().getHelpMap().getHelpTopics()) {
|
||||||
if (ht.getName().equalsIgnoreCase("/" + cmd))
|
if (ht.getName().equalsIgnoreCase("/" + cmd))
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
if (PluginMain.permission.has(event.getPlayer(), "tbmc.admin")) {
|
if (PluginMain.permission.has(sender, "tbmc.admin")) {
|
||||||
String s = cmd.substring(2);
|
String s = cmd.substring(2);
|
||||||
Player target = null;
|
Player target = null;
|
||||||
target = Bukkit.getPlayer(event.getMessage().substring(index + 1));
|
target = Bukkit.getPlayer(message.substring(index + 1));
|
||||||
if (target == null) {
|
if (target == null) {
|
||||||
event.getPlayer().sendMessage("§cError: Player not found. (/un" + s + " <player>)");
|
sender.sendMessage("§cError: Player not found. (/un" + s + " <player>)");
|
||||||
event.setCancelled(true);
|
return true;
|
||||||
}
|
|
||||||
if (target != null) {
|
|
||||||
target.addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 10 * 20, 5, false, false));
|
|
||||||
Bukkit.broadcastMessage(
|
|
||||||
event.getPlayer().getDisplayName() + " un" + s + "'d " + target.getDisplayName());
|
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
}
|
||||||
|
target.addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 10 * 20, 5, false, false));
|
||||||
|
Bukkit.broadcastMessage(
|
||||||
|
(sender instanceof Player ? ((Player) sender).getDisplayName() : sender.getName()) + " un" + s
|
||||||
|
+ "'d " + target.getDisplayName());
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
|
@ -204,54 +232,8 @@ public class PlayerListener implements Listener {
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST)
|
@EventHandler(priority = EventPriority.HIGHEST)
|
||||||
public void onConsoleCommand(ServerCommandEvent event) {
|
public void onConsoleCommand(ServerCommandEvent event) {
|
||||||
if (event.getCommand().length() < 2)
|
if (onCommandPreprocess(event.getSender(), event.getCommand()))
|
||||||
return;
|
event.setCommand("dontrunthiscmd");
|
||||||
int index = event.getCommand().indexOf(" ");
|
|
||||||
String cmd = "";
|
|
||||||
if (index == -1) {
|
|
||||||
cmd = event.getCommand();
|
|
||||||
for (Channel channel : Channel.getChannels()) {
|
|
||||||
if (cmd.equalsIgnoreCase(channel.ID)) {
|
|
||||||
if (ConsoleChannel.equals(channel))
|
|
||||||
ConsoleChannel = Channel.GlobalChat;
|
|
||||||
else
|
|
||||||
ConsoleChannel = channel;
|
|
||||||
event.getSender().sendMessage("§6You are now talking in: §b" + ConsoleChannel.DisplayName);
|
|
||||||
event.setCommand("dontrunthiscmd");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
cmd = event.getCommand().substring(0, index);
|
|
||||||
for (Channel channel : Channel.getChannels()) {
|
|
||||||
if (cmd.equalsIgnoreCase(channel.ID)) {
|
|
||||||
Channel c = ConsoleChannel;
|
|
||||||
ConsoleChannel = channel;
|
|
||||||
TBMCChatAPI.SendChatMessage(PlayerListener.ConsoleChannel, Bukkit.getConsoleSender(),
|
|
||||||
event.getCommand().substring(index + 1));
|
|
||||||
ConsoleChannel = c;
|
|
||||||
event.setCommand("dontrunthiscmd");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (cmd.toLowerCase().startsWith("un")) {
|
|
||||||
for (HelpTopic ht : PluginMain.Instance.getServer().getHelpMap().getHelpTopics()) {
|
|
||||||
if (ht.getName().equalsIgnoreCase("/" + cmd))
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
String s = cmd.substring(2);
|
|
||||||
Player target = null;
|
|
||||||
target = Bukkit.getPlayer(event.getCommand().substring(index + 1));
|
|
||||||
if (target == null) {
|
|
||||||
event.getSender().sendMessage("§cError: Player not found. (/un" + s + " <player>)");
|
|
||||||
event.setCommand("dontrunthiscmd");
|
|
||||||
}
|
|
||||||
if (target != null) {
|
|
||||||
target.addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 10 * 20, 5, false, false));
|
|
||||||
Bukkit.broadcastMessage(event.getSender().getName() + " un" + s + "'d " + target.getDisplayName());
|
|
||||||
event.setCommand("dontrunthiscmd");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
|
|
Loading…
Reference in a new issue