Messages containing URLs won't be formatted to keep the original URL; clicking on the channel identifier (ex. [g]) will now copy the message.

This commit is contained in:
Norbi Peti 2015-12-31 20:19:52 +01:00
parent d7be9fbe30
commit d30126e1cf
6 changed files with 95 additions and 81 deletions

Binary file not shown.

View file

@ -25,6 +25,7 @@ public class MaybeOfflinePlayer {
// public int Tables = 10; // public int Tables = 10;
public Channel CurrentChannel = Channel.GlobalChat; public Channel CurrentChannel = Channel.GlobalChat;
public int FCount; public int FCount;
public boolean SendingLink = false;
public UUID UUID; public UUID UUID;

View file

@ -161,19 +161,47 @@ public class PlayerListener implements Listener { // 2015.07.16.
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
.getPlayer().getUniqueId()); .getPlayer().getUniqueId());
String message = event.getMessage(); // 2015.08.08. String message = event.getMessage();
message = message.replace("\"", "''");
// URLs
String[] parts = message.split("\\s+");
boolean hadurls = false;
for (String item : parts)
try {
URL url = new URL(item);
message = message
.replace(
item,
String.format(
"\",\"color\":\"%s\"},{\"text\":\"%s\",\"color\":\"%s\",\"underlined\":\"true\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open URL\",\"color\":\"blue\"}]}}},{\"text\":\"",
(greentext ? "green"
: player.CurrentChannel.Color),
url, (greentext ? "green"
: player.CurrentChannel.Color),
url));
hadurls = true;
// System.out.println("URL: " + url);
} catch (MalformedURLException e) {
}
if (!hadurls) {
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12. for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
String color = ""; // 2015.08.17. String color = ""; // 2015.08.17.
if (message.matches("(?i).*" + Pattern.quote(p.getName()) + ".*")) { if (message.matches("(?i).*" + Pattern.quote(p.getName())
+ ".*")) {
if (NotificationSound == null) if (NotificationSound == null)
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12. p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f,
0.5f); // 2015.08.12.
else else
p.playSound(p.getLocation(), NotificationSound, 1.0f, p.playSound(p.getLocation(), NotificationSound, 1.0f,
(float) NotificationPitch); // 2015.08.14. (float) NotificationPitch); // 2015.08.14.
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p MaybeOfflinePlayer mp = MaybeOfflinePlayer
.getUniqueId()); .AddPlayerIfNeeded(p.getUniqueId());
color = String.format("§%x", (mp.GetFlairColor() == 0x00 ? 0xb color = String.format(
: mp.GetFlairColor())); // TODO: Quiz queue "§%x",
(mp.GetFlairColor() == 0x00 ? 0xb : mp
.GetFlairColor())); // TODO: Quiz queue
} }
message = message.replaceAll( message = message.replaceAll(
@ -198,11 +226,12 @@ public class PlayerListener implements Listener { // 2015.07.16.
while ((index = nwithoutformatting.indexOf('§')) != -1) while ((index = nwithoutformatting.indexOf('§')) != -1)
nwithoutformatting = nwithoutformatting.replace("§" nwithoutformatting = nwithoutformatting.replace("§"
+ nwithoutformatting.charAt(index + 1), ""); + nwithoutformatting.charAt(index + 1), "");
if (message.matches("(?i).*" + Pattern.quote(nwithoutformatting) if (message.matches("(?i).*"
+ ".*")) { + Pattern.quote(nwithoutformatting) + ".*")) {
p = Bukkit.getPlayer(nicknames.get(n)); p = Bukkit.getPlayer(nicknames.get(n));
if (NotificationSound == null) if (NotificationSound == null)
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12. p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f,
0.5f); // 2015.08.12.
else else
p.playSound(p.getLocation(), NotificationSound, 1.0f, p.playSound(p.getLocation(), NotificationSound, 1.0f,
(float) NotificationPitch); // 2015.08.14. (float) NotificationPitch); // 2015.08.14.
@ -217,8 +246,7 @@ public class PlayerListener implements Listener { // 2015.07.16.
.substring(0, 2))); .substring(0, 2)));
} }
} }
}
event.setMessage(message);
/* /*
* event.setFormat(event .getFormat() .replace( "{rptag}", * event.setFormat(event .getFormat() .replace( "{rptag}",
@ -234,9 +262,11 @@ public class PlayerListener implements Listener { // 2015.07.16.
StringBuilder json = new StringBuilder(); StringBuilder json = new StringBuilder();
json.append("[\"\","); json.append("[\"\",");
json.append(String.format("{\"text\":\"[%s]%s <\"},", json.append(String
player.CurrentChannel.DisplayName, (!player.RPMode ? "[OOC]" .format("{\"text\":\"[%s]%s\",\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"Copy message\",\"color\":\"blue\"}},clickEvent:{\"action\":\"suggest_command\",\"value\":\"%s\"}},",
: ""))); player.CurrentChannel.DisplayName,
(!player.RPMode ? "[OOC]" : ""), event.getMessage()));
json.append("{\"text\":\" <\"},");
json.append(String.format("{\"text\":\"%s%s\",", event.getPlayer() json.append(String.format("{\"text\":\"%s%s\",", event.getPlayer()
.getDisplayName(), player.GetFormattedFlair())); .getDisplayName(), player.GetFormattedFlair()));
json.append("\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":["); json.append("\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[");
@ -266,10 +296,11 @@ public class PlayerListener implements Listener { // 2015.07.16.
String original = event.getMessage().substring(index + 1, index2); String original = event.getMessage().substring(index + 1, index2);
list.add(original); list.add(original);
} }
String finalstring = event.getMessage().replace("\"", "''");
if (!hadurls) {
for (String original : list) for (String original : list)
// Hashtags // Hashtags
finalstring = finalstring message = message
.replace( .replace(
"#" + original, "#" + original,
String.format( String.format(
@ -277,29 +308,10 @@ public class PlayerListener implements Listener { // 2015.07.16.
(greentext ? "green" (greentext ? "green"
: player.CurrentChannel.Color), : player.CurrentChannel.Color),
original, original)); original, original));
String[] parts = finalstring.split("\\s+");
// URLs
for (String item : parts)
try {
URL url = new URL(item);
finalstring = finalstring
.replace(
item,
String.format(
"\",\"color\":\"%s\"},{\"text\":\"%s\",\"color\":\"%s\",\"underlined\":\"true\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open URL\",\"color\":\"blue\"}]}}},{\"text\":\"",
(greentext ? "green"
: player.CurrentChannel.Color),
url, (greentext ? "green"
: player.CurrentChannel.Color),
url));
} catch (MalformedURLException e) {
} }
json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]", json.append(String.format("{\"text\":\"%s\",\"color\":\"%s\"}]",
finalstring, (greentext ? "green" message, (greentext ? "green" : player.CurrentChannel.Color)));
: player.CurrentChannel.Color)));
if (player.CurrentChannel.equals(Channel.TownChat) if (player.CurrentChannel.equals(Channel.TownChat)
|| player.CurrentChannel.equals(Channel.NationChat)) || player.CurrentChannel.equals(Channel.NationChat))
// for (Resident resident : // for (Resident resident :
@ -513,7 +525,8 @@ public class PlayerListener implements Listener { // 2015.07.16.
String.format("[%s] <%s%s> %s", String.format("[%s] <%s%s> %s",
player.CurrentChannel.DisplayName, event player.CurrentChannel.DisplayName, event
.getPlayer().getDisplayName(), player .getPlayer().getDisplayName(), player
.GetFormattedFlair(), message)); .GetFormattedFlair(), event
.getMessage()));
} }
@EventHandler @EventHandler