Idk
This commit is contained in:
parent
c6ffdf1868
commit
4ca1c6a2d7
4 changed files with 117 additions and 119 deletions
|
@ -24,7 +24,7 @@ commands:
|
||||||
yeehaw:
|
yeehaw:
|
||||||
description: This command makes you yeehaw.
|
description: This command makes you yeehaw.
|
||||||
author: NorbiPeti
|
author: NorbiPeti
|
||||||
depend: [Essentials, Towny, Minigames, Votifier, WorldGuard, WorldEdit, ProtocolLib, FastLogin, Vault, AuthMe]
|
depend: [Essentials, Towny, Minigames, Votifier, WorldGuard, WorldEdit, ProtocolLib, Vault]
|
||||||
permissions:
|
permissions:
|
||||||
tbmc.admin:
|
tbmc.admin:
|
||||||
description: Gives access to /un- commands and /u admin commands
|
description: Gives access to /un- commands and /u admin commands
|
||||||
|
|
|
@ -5,6 +5,8 @@ import io.github.norbipeti.thebuttonmcchat.commands.UnlolCommand;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.EnumSet;
|
||||||
|
import java.util.function.Predicate;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
@ -72,8 +74,7 @@ public class ChatProcessing {
|
||||||
colormode = ChatFormatter.Color.Green;
|
colormode = ChatFormatter.Color.Green;
|
||||||
// If greentext, ignore channel or player colors
|
// If greentext, ignore channel or player colors
|
||||||
|
|
||||||
formatters.add(new ChatFormatter(Pattern.compile(".+"), colormode,
|
formatters.add(new ChatFormatter(Pattern.compile(".+"), colormode, ""));
|
||||||
""));
|
|
||||||
|
|
||||||
String formattedmessage = message;
|
String formattedmessage = message;
|
||||||
formattedmessage = formattedmessage.replace("\\", "\\\\");
|
formattedmessage = formattedmessage.replace("\\", "\\\\");
|
||||||
|
@ -99,16 +100,44 @@ public class ChatProcessing {
|
||||||
.compile("http[\\w:/?=$\\-_.+!*'(),]+"),
|
.compile("http[\\w:/?=$\\-_.+!*'(),]+"),
|
||||||
ChatFormatter.Format.Underlined, "", true));
|
ChatFormatter.Format.Underlined, "", true));
|
||||||
// TODO: Only format name mentions outisde open_url
|
// TODO: Only format name mentions outisde open_url
|
||||||
/*formattedmessage = formattedmessage
|
/*
|
||||||
.replace(
|
* formattedmessage = formattedmessage .replace( item, String.format(
|
||||||
item,
|
* "\",\"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\":\""
|
||||||
String.format(
|
* , colormode, url, colormode, url));
|
||||||
"\",\"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\":\"",
|
*/
|
||||||
colormode, url, colormode, url));*/
|
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("(");
|
||||||
|
for (Player p : PluginMain.GetPlayers())
|
||||||
|
sb.append(p.getName()).append("|");
|
||||||
|
sb.deleteCharAt(sb.length() - 1);
|
||||||
|
sb.append(")");
|
||||||
|
|
||||||
|
formatters.add(new ChatFormatter(Pattern.compile(sb.toString()),
|
||||||
|
ChatFormatter.Color.Aqua, "", (String match) -> {
|
||||||
|
Player p = Bukkit.getPlayer(match);
|
||||||
|
if (p == null) {
|
||||||
|
System.out.println("Error: Can't find player " + match
|
||||||
|
+ " but it was reported as online.");
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mpp = MaybeOfflinePlayer
|
||||||
|
.AddPlayerIfNeeded(p.getUniqueId());
|
||||||
|
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);
|
||||||
|
color = String.format("§%x", (mpp.GetFlairColor() == 0x00 ? 0xb
|
||||||
|
: mpp.GetFlairColor()));
|
||||||
|
return true;
|
||||||
|
}));
|
||||||
|
|
||||||
if (!hadurls) {
|
if (!hadurls) {
|
||||||
for (Player p : PluginMain.GetPlayers()) {
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
String color = ""; //TODO: Regex with all names and check for the correct JSON behind them
|
String color = ""; // TODO: Regex with all names and check for
|
||||||
|
// the correct JSON behind them
|
||||||
if (formattedmessage.matches("(?i).*"
|
if (formattedmessage.matches("(?i).*"
|
||||||
+ Pattern.quote(p.getName()) + ".*")) {
|
+ Pattern.quote(p.getName()) + ".*")) {
|
||||||
if (PlayerListener.NotificationSound == null)
|
if (PlayerListener.NotificationSound == null)
|
||||||
|
|
|
@ -45,8 +45,6 @@ import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
import au.com.mineauz.minigames.Minigames;
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
import com.earth2me.essentials.Essentials;
|
import com.earth2me.essentials.Essentials;
|
||||||
import com.github.games647.fastlogin.bukkit.FastLoginBukkit;
|
|
||||||
import com.github.games647.fastlogin.bukkit.PlayerProfile;
|
|
||||||
import com.palmergames.bukkit.towny.exceptions.NotRegisteredException;
|
import com.palmergames.bukkit.towny.exceptions.NotRegisteredException;
|
||||||
import com.palmergames.bukkit.towny.object.Resident;
|
import com.palmergames.bukkit.towny.object.Resident;
|
||||||
import com.palmergames.bukkit.towny.object.Town;
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
@ -57,8 +55,6 @@ import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
import com.vexsoftware.votifier.model.Vote;
|
import com.vexsoftware.votifier.model.Vote;
|
||||||
import com.vexsoftware.votifier.model.VotifierEvent;
|
import com.vexsoftware.votifier.model.VotifierEvent;
|
||||||
|
|
||||||
import fr.xephi.authme.AuthMe;
|
|
||||||
|
|
||||||
public class PlayerListener implements Listener {
|
public class PlayerListener implements Listener {
|
||||||
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
@ -96,13 +92,17 @@ public class PlayerListener implements Listener {
|
||||||
if (player == null)
|
if (player == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
PlayerProfile pp = ((FastLoginBukkit) FastLoginBukkit
|
/*
|
||||||
.getPlugin(FastLoginBukkit.class)).getStorage()
|
* PlayerProfile pp = ((FastLoginBukkit) FastLoginBukkit
|
||||||
.getProfile(player.getName(), true);
|
* .getPlugin(FastLoginBukkit.class)).getStorage()
|
||||||
boolean ispremium = pp != null && pp.isPremium();
|
* .getProfile(player.getName(), true); boolean ispremium =
|
||||||
|
* pp != null && pp.isPremium();
|
||||||
|
*/// Login stuff
|
||||||
|
|
||||||
if (ispremium
|
if (/*
|
||||||
&& mp.FlairState.equals(FlairStates.NoComment)) {
|
* ispremium &&
|
||||||
|
*/// Login stuff
|
||||||
|
mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
String json = String
|
String json = String
|
||||||
.format("[\"\",{\"text\":\"If you're from Reddit and you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]",
|
.format("[\"\",{\"text\":\"If you're from Reddit and you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]",
|
||||||
PluginMain.FlairThreadURL);
|
PluginMain.FlairThreadURL);
|
||||||
|
@ -121,63 +121,41 @@ public class PlayerListener implements Listener {
|
||||||
timer.schedule(tt, 15 * 1000);
|
timer.schedule(tt, 15 * 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
final Timer timer = new Timer();
|
/*
|
||||||
mp.LoginWarningCount = 0;
|
* final Timer timer = new Timer(); mp.LoginWarningCount = 0;
|
||||||
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
* PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
@Override
|
*
|
||||||
public void run() {
|
* @Override public void run() { final Player player =
|
||||||
final Player player = Bukkit.getPlayer(mp.PlayerName);
|
* Bukkit.getPlayer(mp.PlayerName); if (player == null) return;
|
||||||
if (player == null)
|
*
|
||||||
return;
|
* PlayerProfile pp = ((FastLoginBukkit) FastLoginBukkit
|
||||||
|
* .getPlugin(FastLoginBukkit.class)).getStorage()
|
||||||
PlayerProfile pp = ((FastLoginBukkit) FastLoginBukkit
|
* .getProfile(player.getName(), true); boolean ispremium = pp != null
|
||||||
.getPlugin(FastLoginBukkit.class)).getStorage()
|
* && pp.isPremium(); final MaybeOfflinePlayer mplayer = mp;
|
||||||
.getProfile(player.getName(), true);
|
*
|
||||||
boolean ispremium = pp != null && pp.isPremium();
|
* if (mp.LoginWarningCount < LoginWarningCountTotal) { if
|
||||||
final MaybeOfflinePlayer mplayer = mp;
|
* (AuthMe.getInstance().api.isAuthenticated(player)) { // The player
|
||||||
|
* logged in in any way if (!ispremium &&
|
||||||
if (mp.LoginWarningCount < LoginWarningCountTotal) {
|
* !mp.FlairState.equals(FlairStates.Accepted) &&
|
||||||
if (AuthMe.getInstance().api.isAuthenticated(player)) {
|
* !mp.FlairState.equals(FlairStates.Commented)) { // The player isn't
|
||||||
// The player logged in in any way
|
* premium, and doesn't have a // flair String json = String .format(
|
||||||
if (!ispremium
|
* "[\"\",{\"text\":\"Welcome! If you are a premium Minecraft user, please do /premium and relog, otherwise please verify your /r/thebutton flair to play, \",\"color\":\"gold\"},{\"text\":\"[here].\",\"color\":\"gold\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]"
|
||||||
&& !mp.FlairState.equals(FlairStates.Accepted)
|
* , PluginMain.FlairThreadURL);
|
||||||
&& !mp.FlairState.equals(FlairStates.Commented)) {
|
* PluginMain.Instance.getServer().dispatchCommand( PluginMain.Console,
|
||||||
// The player isn't premium, and doesn't have a
|
* "tellraw " + mp.PlayerName + " " + json); } } } else { if
|
||||||
// flair
|
* (AuthMe.getInstance().api.isAuthenticated(player)) { if (!ispremium
|
||||||
String json = String
|
* && !mplayer.FlairState .equals(FlairStates.Accepted) &&
|
||||||
.format("[\"\",{\"text\":\"Welcome! If you are a premium Minecraft user, please do /premium and relog, otherwise please verify your /r/thebutton flair to play, \",\"color\":\"gold\"},{\"text\":\"[here].\",\"color\":\"gold\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]",
|
* !mplayer.FlairState .equals(FlairStates.Commented)) {
|
||||||
PluginMain.FlairThreadURL);
|
* Bukkit.getScheduler().runTask(PluginMain.Instance, new Runnable() {
|
||||||
PluginMain.Instance.getServer().dispatchCommand(
|
*
|
||||||
PluginMain.Console,
|
* @Override public void run() { player.kickPlayer(
|
||||||
"tellraw " + mp.PlayerName + " " + json);
|
* "Please either use /premium and relog or verify your flair by commenting in the thread and using /u accept."
|
||||||
}
|
* ); } }); timer.cancel(); } } } mp.LoginWarningCount++; } }; tt.mp =
|
||||||
}
|
* mp; int timeout = AuthMe.getInstance().getConfig()
|
||||||
} else {
|
* .getInt("settings.restrictions.timeout"); timer.schedule(tt, (timeout
|
||||||
if (AuthMe.getInstance().api.isAuthenticated(player)) {
|
* / LoginWarningCountTotal) * 1000, (timeout / LoginWarningCountTotal)
|
||||||
if (!ispremium
|
* * 1000);
|
||||||
&& !mplayer.FlairState
|
*/// Login stuff
|
||||||
.equals(FlairStates.Accepted)
|
|
||||||
&& !mplayer.FlairState
|
|
||||||
.equals(FlairStates.Commented)) {
|
|
||||||
Bukkit.getScheduler().runTask(PluginMain.Instance,
|
|
||||||
new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
player.kickPlayer("Please either use /premium and relog or verify your flair by commenting in the thread and using /u accept.");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
timer.cancel();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
mp.LoginWarningCount++;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
tt.mp = mp;
|
|
||||||
int timeout = AuthMe.getInstance().getConfig()
|
|
||||||
.getInt("settings.restrictions.timeout");
|
|
||||||
timer.schedule(tt, (timeout / LoginWarningCountTotal) * 1000,
|
|
||||||
(timeout / LoginWarningCountTotal) * 1000);
|
|
||||||
|
|
||||||
/* NICKNAME LOGIC */
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
@ -355,17 +333,14 @@ public class PlayerListener implements Listener {
|
||||||
.getPlayer().getDisplayName(), message));
|
.getPlayer().getDisplayName(), message));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*boolean tping = false;
|
/*
|
||||||
boolean tphering = false;
|
* boolean tping = false; boolean tphering = false; if
|
||||||
if (cmd.equalsIgnoreCase("tpa") || cmd.equalsIgnoreCase("call")
|
* (cmd.equalsIgnoreCase("tpa") || cmd.equalsIgnoreCase("call") ||
|
||||||
|| cmd.equalsIgnoreCase("ecall")
|
* cmd.equalsIgnoreCase("ecall") || cmd.equalsIgnoreCase("etpa") ||
|
||||||
|| cmd.equalsIgnoreCase("etpa")
|
* cmd.equalsIgnoreCase("tpask") || cmd.equalsIgnoreCase("etpask"))
|
||||||
|| cmd.equalsIgnoreCase("tpask")
|
* tping = true; if (cmd.equalsIgnoreCase("tpahere") ||
|
||||||
|| cmd.equalsIgnoreCase("etpask"))
|
* cmd.equalsIgnoreCase("etpahere")) tphering = true;
|
||||||
tping = true;
|
*/
|
||||||
if (cmd.equalsIgnoreCase("tpahere")
|
|
||||||
|| cmd.equalsIgnoreCase("etpahere"))
|
|
||||||
tphering = true;*/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* for (HelpTopic ht : PluginMain.Instance.getServer()
|
* for (HelpTopic ht : PluginMain.Instance.getServer()
|
||||||
|
@ -381,37 +356,30 @@ public class PlayerListener implements Listener {
|
||||||
* break; }
|
* break; }
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*if (tphering) {
|
/*
|
||||||
Player target = Bukkit.getPlayer(event.getMessage()
|
* if (tphering) { Player target =
|
||||||
.substring(index + 1).split(" ")[0]);
|
* Bukkit.getPlayer(event.getMessage() .substring(index +
|
||||||
if (target != null
|
* 1).split(" ")[0]); if (target != null && BoardColl.get()
|
||||||
&& BoardColl.get()
|
* .getFactionAt(PS.valueOf(target.getLocation()))
|
||||||
.getFactionAt(PS.valueOf(target.getLocation()))
|
* .getId().equalsIgnoreCase("tower")) { event.getPlayer()
|
||||||
.getId().equalsIgnoreCase("tower")) {
|
* .sendMessage(
|
||||||
event.getPlayer()
|
* "§cYou are not allowed to teleport players out from the Tower");
|
||||||
.sendMessage(
|
* event.setCancelled(true); } }
|
||||||
"§cYou are not allowed to teleport players out from the Tower");
|
*/
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
/*
|
/*
|
||||||
* for (String s : Bukkit.getCommandAliases().get("/tpahere")) { if
|
* for (String s : Bukkit.getCommandAliases().get("/tpahere")) { if
|
||||||
* (cmd.equalsIgnoreCase(s)) { tping = true; break; } }
|
* (cmd.equalsIgnoreCase(s)) { tping = true; break; } }
|
||||||
*/
|
*/
|
||||||
/*if (tping) {
|
/*
|
||||||
if (
|
* if (tping) { if ( //
|
||||||
// MPlayer.get(event.getPlayer()).getFaction().getId().equalsIgnoreCase("nomansland"))
|
* MPlayer.get(event.getPlayer()).getFaction().getId
|
||||||
// {
|
* ().equalsIgnoreCase("nomansland")) // { BoardColl .get()
|
||||||
BoardColl
|
* .getFactionAt( PS.valueOf(event.getPlayer().getLocation()))
|
||||||
.get()
|
* .getId().equalsIgnoreCase("tower")) {
|
||||||
.getFactionAt(
|
* event.getPlayer().sendMessage(
|
||||||
PS.valueOf(event.getPlayer().getLocation()))
|
* "§cYou are not allowed to teleport to the Tower");
|
||||||
.getId().equalsIgnoreCase("tower")) {
|
* event.setCancelled(true); } }
|
||||||
event.getPlayer().sendMessage(
|
*/
|
||||||
"§cYou are not allowed to teleport to the Tower");
|
|
||||||
event.setCancelled(true);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
if (cmd.equalsIgnoreCase("sethome")) {
|
if (cmd.equalsIgnoreCase("sethome")) {
|
||||||
TownyUniverse tu = PluginMain.Instance.TU;
|
TownyUniverse tu = PluginMain.Instance.TU;
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package io.github.norbipeti.thebuttonmcchat.commands.ucmds;
|
package io.github.norbipeti.thebuttonmcchat.commands.ucmds;
|
||||||
|
|
||||||
import io.github.norbipeti.thebuttonmcchat.ChatFormatter;
|
import io.github.norbipeti.thebuttonmcchat.ChatFormatter;
|
||||||
|
import io.github.norbipeti.thebuttonmcchat.ChatFormatter.Color;
|
||||||
import io.github.norbipeti.thebuttonmcchat.MaybeOfflinePlayer;
|
import io.github.norbipeti.thebuttonmcchat.MaybeOfflinePlayer;
|
||||||
import io.github.norbipeti.thebuttonmcchat.PluginMain;
|
import io.github.norbipeti.thebuttonmcchat.PluginMain;
|
||||||
|
|
||||||
|
@ -24,7 +25,7 @@ public class CCommand extends UCommandBase {
|
||||||
if (args.length < 1) {
|
if (args.length < 1) {
|
||||||
if (PluginMain.permission.has(player, "tbmc.rainbow")) {
|
if (PluginMain.permission.has(player, "tbmc.rainbow")) {
|
||||||
p.RainbowPresserColorMode = !p.RainbowPresserColorMode;
|
p.RainbowPresserColorMode = !p.RainbowPresserColorMode;
|
||||||
p.OtherColorMode = "";
|
p.OtherColorMode = null;
|
||||||
if (p.RainbowPresserColorMode)
|
if (p.RainbowPresserColorMode)
|
||||||
player.sendMessage("§eRainbow colors §aenabled.");
|
player.sendMessage("§eRainbow colors §aenabled.");
|
||||||
else
|
else
|
||||||
|
@ -36,7 +37,7 @@ public class CCommand extends UCommandBase {
|
||||||
} else {
|
} else {
|
||||||
if (PluginMain.permission.has(player, "tbmc.admin")) {
|
if (PluginMain.permission.has(player, "tbmc.admin")) {
|
||||||
p.RainbowPresserColorMode = false;
|
p.RainbowPresserColorMode = false;
|
||||||
p.OtherColorMode = args[0];
|
p.OtherColorMode = null;
|
||||||
try {
|
try {
|
||||||
p.OtherColorMode = ChatFormatter.Color.valueOf(args[0]
|
p.OtherColorMode = ChatFormatter.Color.valueOf(args[0]
|
||||||
.toLowerCase());
|
.toLowerCase());
|
||||||
|
@ -44,7 +45,7 @@ public class CCommand extends UCommandBase {
|
||||||
player.sendMessage("§cUnknown message color: " + args[0]);
|
player.sendMessage("§cUnknown message color: " + args[0]);
|
||||||
player.sendMessage("§cUse color names, like blue, or dark_aqua");
|
player.sendMessage("§cUse color names, like blue, or dark_aqua");
|
||||||
}
|
}
|
||||||
if (p.OtherColorMode.length() > 0)
|
if (p.OtherColorMode != null)
|
||||||
player.sendMessage(String.format(
|
player.sendMessage(String.format(
|
||||||
"§eMessage color set to %s", p.OtherColorMode));
|
"§eMessage color set to %s", p.OtherColorMode));
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in a new issue