Still formatting messages...
This commit is contained in:
parent
4ca1c6a2d7
commit
578d37c777
1 changed files with 71 additions and 71 deletions
|
@ -107,7 +107,7 @@ public class ChatProcessing {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append("(");
|
sb.append("(?i)(");
|
||||||
for (Player p : PluginMain.GetPlayers())
|
for (Player p : PluginMain.GetPlayers())
|
||||||
sb.append(p.getName()).append("|");
|
sb.append(p.getName()).append("|");
|
||||||
sb.deleteCharAt(sb.length() - 1);
|
sb.deleteCharAt(sb.length() - 1);
|
||||||
|
@ -119,6 +119,7 @@ public class ChatProcessing {
|
||||||
if (p == null) {
|
if (p == null) {
|
||||||
System.out.println("Error: Can't find player " + match
|
System.out.println("Error: Can't find player " + match
|
||||||
+ " but it was reported as online.");
|
+ " but it was reported as online.");
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
MaybeOfflinePlayer mpp = MaybeOfflinePlayer
|
MaybeOfflinePlayer mpp = MaybeOfflinePlayer
|
||||||
.AddPlayerIfNeeded(p.getUniqueId());
|
.AddPlayerIfNeeded(p.getUniqueId());
|
||||||
|
@ -129,76 +130,73 @@ public class ChatProcessing {
|
||||||
else
|
else
|
||||||
p.playSound(p.getLocation(), PlayerListener.NotificationSound,
|
p.playSound(p.getLocation(), PlayerListener.NotificationSound,
|
||||||
1.0f, (float) PlayerListener.NotificationPitch);
|
1.0f, (float) PlayerListener.NotificationPitch);
|
||||||
color = String.format("§%x", (mpp.GetFlairColor() == 0x00 ? 0xb
|
String color = String.format("§%x",
|
||||||
: mpp.GetFlairColor()));
|
(mpp.GetFlairColor() == 0x00 ? 0xb : mpp.GetFlairColor()));
|
||||||
return true;
|
return true; // TODO
|
||||||
}));
|
}));
|
||||||
|
|
||||||
if (!hadurls) {
|
formatters
|
||||||
for (Player p : PluginMain.GetPlayers()) {
|
.add(new ChatFormatter(
|
||||||
String color = ""; // TODO: Regex with all names and check for
|
Pattern.compile(sb.toString()),
|
||||||
// the correct JSON behind them
|
ChatFormatter.Color.Aqua,
|
||||||
if (formattedmessage.matches("(?i).*"
|
"",
|
||||||
+ Pattern.quote(p.getName()) + ".*")) {
|
(String match) -> {
|
||||||
if (PlayerListener.NotificationSound == null)
|
|
||||||
p.playSound(p.getLocation(),
|
|
||||||
Sound.ENTITY_ARROW_HIT_PLAYER, 1.0f, 0.5f); // TODO:
|
|
||||||
// Airhorn
|
|
||||||
else
|
|
||||||
p.playSound(p.getLocation(),
|
|
||||||
PlayerListener.NotificationSound, 1.0f,
|
|
||||||
(float) PlayerListener.NotificationPitch);
|
|
||||||
MaybeOfflinePlayer mpp = MaybeOfflinePlayer
|
|
||||||
.AddPlayerIfNeeded(p.getUniqueId());
|
|
||||||
color = String.format(
|
|
||||||
"§%x",
|
|
||||||
(mpp.GetFlairColor() == 0x00 ? 0xb : mpp
|
|
||||||
.GetFlairColor()));
|
|
||||||
}
|
|
||||||
|
|
||||||
formattedmessage = formattedmessage
|
|
||||||
.replaceAll(
|
|
||||||
"(?i)" + Pattern.quote(p.getName()),
|
|
||||||
String.format(
|
|
||||||
"\",\"color\":\"%s\"},{\"text\":\"%s%s%s\",\"color\":\"blue\"},{\"text\":\"",
|
|
||||||
colormode, color, p.getName(), "§r"));
|
|
||||||
}
|
|
||||||
for (String n : PlayerListener.nicknames.keySet()) {
|
for (String n : PlayerListener.nicknames.keySet()) {
|
||||||
Player p = null;
|
|
||||||
String nwithoutformatting = new String(n);
|
String nwithoutformatting = new String(n);
|
||||||
int index;
|
int index;
|
||||||
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
while ((index = nwithoutformatting
|
||||||
nwithoutformatting = nwithoutformatting.replace("§k"
|
.indexOf("§k")) != -1)
|
||||||
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
nwithoutformatting = nwithoutformatting.replace(
|
||||||
|
"§k"
|
||||||
|
+ nwithoutformatting
|
||||||
|
.charAt(index + 2),
|
||||||
|
""); // Support
|
||||||
// for
|
// for
|
||||||
// one
|
// one
|
||||||
// random
|
// random
|
||||||
// char
|
// char
|
||||||
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
nwithoutformatting = nwithoutformatting.replace("§"
|
nwithoutformatting = nwithoutformatting.replace(
|
||||||
+ nwithoutformatting.charAt(index + 1), "");
|
"§"
|
||||||
if (formattedmessage.matches("(?i).*"
|
+ nwithoutformatting
|
||||||
+ Pattern.quote(nwithoutformatting) + ".*")) {
|
.charAt(index + 1),
|
||||||
p = Bukkit.getPlayer(PlayerListener.nicknames.get(n));
|
"");
|
||||||
|
if (!match.equalsIgnoreCase(nwithoutformatting))
|
||||||
|
return false; // TODO
|
||||||
|
Player p = Bukkit
|
||||||
|
.getPlayer(PlayerListener.nicknames
|
||||||
|
.get(n));
|
||||||
|
if (p == null) {
|
||||||
|
System.out
|
||||||
|
.println("Error: Can't find player "
|
||||||
|
+ match
|
||||||
|
+ " but it was reported as online.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mpp = MaybeOfflinePlayer
|
||||||
|
.AddPlayerIfNeeded(p.getUniqueId());
|
||||||
if (PlayerListener.NotificationSound == null)
|
if (PlayerListener.NotificationSound == null)
|
||||||
p.playSound(p.getLocation(),
|
p.playSound(p.getLocation(),
|
||||||
Sound.ENTITY_ARROW_HIT_PLAYER, 1.0f, 0.5f); // 2015.08.12.
|
Sound.ENTITY_ARROW_HIT_PLAYER,
|
||||||
|
1.0f, 0.5f); // TODO:
|
||||||
|
// Airhorn
|
||||||
else
|
else
|
||||||
p.playSound(p.getLocation(),
|
p.playSound(
|
||||||
PlayerListener.NotificationSound, 1.0f,
|
p.getLocation(),
|
||||||
|
PlayerListener.NotificationSound,
|
||||||
|
1.0f,
|
||||||
(float) PlayerListener.NotificationPitch);
|
(float) PlayerListener.NotificationPitch);
|
||||||
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId());
|
String color = String.format("§%x",
|
||||||
|
(mpp.GetFlairColor() == 0x00 ? 0xb
|
||||||
|
: mpp.GetFlairColor()));
|
||||||
}
|
}
|
||||||
if (p != null) {
|
return true; // TODO
|
||||||
|
}));
|
||||||
|
|
||||||
formattedmessage = formattedmessage
|
formatters.add(new ChatFormatter(Pattern.compile("(?i)"
|
||||||
.replaceAll(
|
+ Pattern.quote("@console")), ChatFormatter.Color.Aqua, ""));
|
||||||
"(?i)" + Pattern.quote(nwithoutformatting),
|
|
||||||
String.format(
|
if (!hadurls) {
|
||||||
"\",\"color\":\"%s\"},{\"text\":\"%s%s\",\"color\":\"blue\"},{\"text\":\"",
|
|
||||||
colormode, n, "§r"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (formattedmessage.matches("(?i).*" + Pattern.quote("@console")
|
if (formattedmessage.matches("(?i).*" + Pattern.quote("@console")
|
||||||
+ ".*")) {
|
+ ".*")) {
|
||||||
|
@ -246,7 +244,9 @@ public class ChatProcessing {
|
||||||
: "")));
|
: "")));
|
||||||
json.append("{\"text\":\"> \",\"color\":\"white\"},");
|
json.append("{\"text\":\"> \",\"color\":\"white\"},");
|
||||||
|
|
||||||
int index = -1;
|
formatters.add(new ChatFormatter("#(\w+)", ChatFormatter.Color.Blue, "", "https://twitter.com/hashtag/$1"));
|
||||||
|
|
||||||
|
/*int index = -1;
|
||||||
ArrayList<String> list = new ArrayList<String>();
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
while ((index = message.indexOf("#", index + 1)) != -1) {
|
while ((index = message.indexOf("#", index + 1)) != -1) {
|
||||||
int index2 = message.indexOf(" ", index + 1);
|
int index2 = message.indexOf(" ", index + 1);
|
||||||
|
@ -269,7 +269,7 @@ public class ChatProcessing {
|
||||||
String.format(
|
String.format(
|
||||||
"\",\"color\":\"%s\"},{\"text\":\"#%s\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}},{\"text\":\"",
|
"\",\"color\":\"%s\"},{\"text\":\"#%s\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}},{\"text\":\"",
|
||||||
colormode, original, original));
|
colormode, original, original));
|
||||||
}
|
}*/
|
||||||
|
|
||||||
json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]",
|
json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]",
|
||||||
formattedmessage, colormode));
|
formattedmessage, colormode));
|
||||||
|
|
Loading…
Reference in a new issue