Add LOOC and change OOC color (#5841)
This commit is contained in:
@@ -8,5 +8,6 @@
|
|||||||
<cc:CommandButton Command="restart" Text="{Loc server-reboot}" />
|
<cc:CommandButton Command="restart" Text="{Loc server-reboot}" />
|
||||||
<cc:CommandButton Command="shutdown" Text="{Loc server-shutdown}" />
|
<cc:CommandButton Command="shutdown" Text="{Loc server-shutdown}" />
|
||||||
<cc:CommandButton Command="setooc" Text="{Loc server-ooc-toggle}" />
|
<cc:CommandButton Command="setooc" Text="{Loc server-ooc-toggle}" />
|
||||||
|
<cc:CommandButton Command="setlooc" Text="{Loc server-looc-toggle}" />
|
||||||
</GridContainer>
|
</GridContainer>
|
||||||
</Control>
|
</Control>
|
||||||
|
|||||||
@@ -10,7 +10,8 @@ namespace Content.Client.Chat
|
|||||||
{
|
{
|
||||||
ChatChannel.Server => Color.Orange,
|
ChatChannel.Server => Color.Orange,
|
||||||
ChatChannel.Radio => Color.LimeGreen,
|
ChatChannel.Radio => Color.LimeGreen,
|
||||||
ChatChannel.OOC => Color.LightSkyBlue,
|
ChatChannel.LOOC => Color.LightSkyBlue,
|
||||||
|
ChatChannel.OOC => Color.RoyalBlue,
|
||||||
ChatChannel.Dead => Color.MediumPurple,
|
ChatChannel.Dead => Color.MediumPurple,
|
||||||
ChatChannel.Admin => Color.Red,
|
ChatChannel.Admin => Color.Red,
|
||||||
_ => Color.DarkGray
|
_ => Color.DarkGray
|
||||||
|
|||||||
@@ -188,6 +188,8 @@ namespace Content.Client.Chat.Managers
|
|||||||
// can always send/recieve OOC
|
// can always send/recieve OOC
|
||||||
SelectableChannels |= ChatSelectChannel.OOC;
|
SelectableChannels |= ChatSelectChannel.OOC;
|
||||||
FilterableChannels |= ChatChannel.OOC;
|
FilterableChannels |= ChatChannel.OOC;
|
||||||
|
SelectableChannels |= ChatSelectChannel.LOOC;
|
||||||
|
FilterableChannels |= ChatChannel.LOOC;
|
||||||
|
|
||||||
// can always hear server (nobody can actually send server messages).
|
// can always hear server (nobody can actually send server messages).
|
||||||
FilterableChannels |= ChatChannel.Server;
|
FilterableChannels |= ChatChannel.Server;
|
||||||
@@ -318,6 +320,10 @@ namespace Content.Client.Chat.Managers
|
|||||||
_consoleHost.ExecuteCommand(text.ToString());
|
_consoleHost.ExecuteCommand(text.ToString());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ChatSelectChannel.LOOC:
|
||||||
|
_consoleHost.ExecuteCommand($"looc \"{CommandParsing.Escape(str)}\"");
|
||||||
|
break;
|
||||||
|
|
||||||
case ChatSelectChannel.OOC:
|
case ChatSelectChannel.OOC:
|
||||||
_consoleHost.ExecuteCommand($"ooc \"{CommandParsing.Escape(str)}\"");
|
_consoleHost.ExecuteCommand($"ooc \"{CommandParsing.Escape(str)}\"");
|
||||||
break;
|
break;
|
||||||
|
|||||||
@@ -44,6 +44,7 @@ namespace Content.Client.Chat.UI
|
|||||||
ChatSelectChannel.Local,
|
ChatSelectChannel.Local,
|
||||||
ChatSelectChannel.Emotes,
|
ChatSelectChannel.Emotes,
|
||||||
ChatSelectChannel.Radio,
|
ChatSelectChannel.Radio,
|
||||||
|
ChatSelectChannel.LOOC,
|
||||||
ChatSelectChannel.OOC,
|
ChatSelectChannel.OOC,
|
||||||
ChatSelectChannel.Dead,
|
ChatSelectChannel.Dead,
|
||||||
ChatSelectChannel.Admin
|
ChatSelectChannel.Admin
|
||||||
@@ -491,7 +492,8 @@ namespace Content.Client.Chat.UI
|
|||||||
return channel switch
|
return channel switch
|
||||||
{
|
{
|
||||||
ChatSelectChannel.Radio => Color.LimeGreen,
|
ChatSelectChannel.Radio => Color.LimeGreen,
|
||||||
ChatSelectChannel.OOC => Color.LightSkyBlue,
|
ChatSelectChannel.LOOC => Color.LightSkyBlue,
|
||||||
|
ChatSelectChannel.OOC => Color.RoyalBlue,
|
||||||
ChatSelectChannel.Dead => Color.MediumPurple,
|
ChatSelectChannel.Dead => Color.MediumPurple,
|
||||||
ChatSelectChannel.Admin => Color.Red,
|
ChatSelectChannel.Admin => Color.Red,
|
||||||
_ => Color.DarkGray
|
_ => Color.DarkGray
|
||||||
|
|||||||
56
Content.Server/Chat/Commands/LOOCCommand.cs
Normal file
56
Content.Server/Chat/Commands/LOOCCommand.cs
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
using Content.Server.Administration;
|
||||||
|
using Content.Server.Chat.Managers;
|
||||||
|
using Content.Server.Players;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Robust.Server.Player;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.Enums;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
|
||||||
|
namespace Content.Server.Chat.Commands
|
||||||
|
{
|
||||||
|
[AnyCommand]
|
||||||
|
internal class LOOCCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "looc";
|
||||||
|
public string Description => "Send Local Out Of Character chat messages.";
|
||||||
|
public string Help => "looc <text>";
|
||||||
|
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
var player = shell.Player as IPlayerSession;
|
||||||
|
if (player == null)
|
||||||
|
{
|
||||||
|
shell.WriteLine("This command cannot be run from the server.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (player.Status != SessionStatus.InGame || player.AttachedEntity == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (args.Length < 1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var message = string.Join(" ", args).Trim();
|
||||||
|
if (string.IsNullOrEmpty(message))
|
||||||
|
return;
|
||||||
|
|
||||||
|
var chat = IoCManager.Resolve<IChatManager>();
|
||||||
|
var mindComponent = player.ContentData()?.Mind;
|
||||||
|
|
||||||
|
if (mindComponent == null)
|
||||||
|
{
|
||||||
|
shell.WriteError("You don't have a mind!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mindComponent.OwnedEntity == null)
|
||||||
|
{
|
||||||
|
shell.WriteError("You don't have an entity!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
chat.EntityLOOC(mindComponent.OwnedEntity.Value, message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
44
Content.Server/Chat/Commands/SetLOOCCommand.cs
Normal file
44
Content.Server/Chat/Commands/SetLOOCCommand.cs
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
using Content.Server.Administration;
|
||||||
|
using Content.Shared.Administration;
|
||||||
|
using Content.Shared.CCVar;
|
||||||
|
using Robust.Shared.Configuration;
|
||||||
|
using Robust.Shared.Console;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Localization;
|
||||||
|
|
||||||
|
namespace Content.Server.Chat.Commands;
|
||||||
|
|
||||||
|
[AdminCommand(AdminFlags.Server)]
|
||||||
|
public class SetLOOCCommand : IConsoleCommand
|
||||||
|
{
|
||||||
|
public string Command => "setlooc";
|
||||||
|
public string Description => Loc.GetString("set-looc-command-description");
|
||||||
|
public string Help => Loc.GetString("set-looc-command-help");
|
||||||
|
public void Execute(IConsoleShell shell, string argStr, string[] args)
|
||||||
|
{
|
||||||
|
var cfg = IoCManager.Resolve<IConfigurationManager>();
|
||||||
|
|
||||||
|
if (args.Length > 1)
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("set-looc-command-too-many-arguments-error"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var looc = cfg.GetCVar(CCVars.LoocEnabled);
|
||||||
|
|
||||||
|
if (args.Length == 0)
|
||||||
|
{
|
||||||
|
looc = !looc;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (args.Length == 1 && !bool.TryParse(args[0], out looc))
|
||||||
|
{
|
||||||
|
shell.WriteError(Loc.GetString("set-looc-command-invalid-argument-error"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg.SetCVar(CCVars.LoocEnabled, looc);
|
||||||
|
|
||||||
|
shell.WriteLine(Loc.GetString(looc ? "set-looc-command-looc-enabled" : "set-looc-command-looc-disabled"));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -59,12 +59,15 @@ namespace Content.Server.Chat.Managers
|
|||||||
private readonly List<TransformChat> _chatTransformHandlers = new();
|
private readonly List<TransformChat> _chatTransformHandlers = new();
|
||||||
private bool _oocEnabled = true;
|
private bool _oocEnabled = true;
|
||||||
private bool _adminOocEnabled = true;
|
private bool _adminOocEnabled = true;
|
||||||
|
private bool _loocEnabled = true;
|
||||||
|
private bool _adminLoocEnabled = true;
|
||||||
|
|
||||||
public void Initialize()
|
public void Initialize()
|
||||||
{
|
{
|
||||||
_netManager.RegisterNetMessage<MsgChatMessage>();
|
_netManager.RegisterNetMessage<MsgChatMessage>();
|
||||||
|
|
||||||
_configurationManager.OnValueChanged(CCVars.OocEnabled, OnOocEnabledChanged, true);
|
_configurationManager.OnValueChanged(CCVars.OocEnabled, OnOocEnabledChanged, true);
|
||||||
|
_configurationManager.OnValueChanged(CCVars.LoocEnabled, OnLoocEnabledChanged, true);
|
||||||
_configurationManager.OnValueChanged(CCVars.AdminOocEnabled, OnAdminOocEnabledChanged, true);
|
_configurationManager.OnValueChanged(CCVars.AdminOocEnabled, OnAdminOocEnabledChanged, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -74,6 +77,12 @@ namespace Content.Server.Chat.Managers
|
|||||||
DispatchServerAnnouncement(Loc.GetString(val ? "chat-manager-ooc-chat-enabled-message" : "chat-manager-ooc-chat-disabled-message"));
|
DispatchServerAnnouncement(Loc.GetString(val ? "chat-manager-ooc-chat-enabled-message" : "chat-manager-ooc-chat-disabled-message"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnLoocEnabledChanged(bool val)
|
||||||
|
{
|
||||||
|
_loocEnabled = val;
|
||||||
|
DispatchServerAnnouncement(Loc.GetString(val ? "chat-manager-looc-chat-enabled-message" : "chat-manager-looc-chat-disabled-message"));
|
||||||
|
}
|
||||||
|
|
||||||
private void OnAdminOocEnabledChanged(bool val)
|
private void OnAdminOocEnabledChanged(bool val)
|
||||||
{
|
{
|
||||||
_adminOocEnabled = val;
|
_adminOocEnabled = val;
|
||||||
@@ -238,6 +247,47 @@ namespace Content.Server.Chat.Managers
|
|||||||
_netManager.ServerSendToMany(msg, clients);
|
_netManager.ServerSendToMany(msg, clients);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void EntityLOOC(EntityUid source, string message)
|
||||||
|
{
|
||||||
|
// Check if entity is a player
|
||||||
|
if (!_entManager.TryGetComponent(source, out ActorComponent? actor))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_adminManager.IsAdmin(actor.PlayerSession))
|
||||||
|
{
|
||||||
|
if (!_adminLoocEnabled)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (!_loocEnabled)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if message exceeds the character limit
|
||||||
|
if (message.Length > MaxMessageLength)
|
||||||
|
{
|
||||||
|
DispatchServerMessage(actor.PlayerSession, Loc.GetString("chat-manager-max-message-length-exceeded-message", ("limit", MaxMessageLength)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
message = FormattedMessage.EscapeText(message);
|
||||||
|
|
||||||
|
var clients = Filter.Empty()
|
||||||
|
.AddInRange(_entManager.GetComponent<TransformComponent>(source).MapPosition, VoiceRange)
|
||||||
|
.Recipients
|
||||||
|
.Select(p => p.ConnectedClient)
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
var msg = _netManager.CreateNetMessage<MsgChatMessage>();
|
||||||
|
msg.Channel = ChatChannel.LOOC;
|
||||||
|
msg.Message = message;
|
||||||
|
msg.MessageWrap = Loc.GetString("chat-manager-entity-looc-wrap-message", ("entityName", Name: _entManager.GetComponent<MetaDataComponent>(source).EntityName));
|
||||||
|
_netManager.ServerSendToMany(msg, clients);
|
||||||
|
}
|
||||||
public void SendOOC(IPlayerSession player, string message)
|
public void SendOOC(IPlayerSession player, string message)
|
||||||
{
|
{
|
||||||
if (_adminManager.IsAdmin(player))
|
if (_adminManager.IsAdmin(player))
|
||||||
|
|||||||
@@ -25,6 +25,7 @@ namespace Content.Server.Chat.Managers
|
|||||||
/// <param name="hideChat">If true, message will not be logged to chat boxes but will still produce a speech bubble.</param>
|
/// <param name="hideChat">If true, message will not be logged to chat boxes but will still produce a speech bubble.</param>
|
||||||
void EntitySay(EntityUid source, string message, bool hideChat=false);
|
void EntitySay(EntityUid source, string message, bool hideChat=false);
|
||||||
void EntityMe(EntityUid source, string action);
|
void EntityMe(EntityUid source, string action);
|
||||||
|
void EntityLOOC(EntityUid source, string message);
|
||||||
|
|
||||||
void SendOOC(IPlayerSession player, string message);
|
void SendOOC(IPlayerSession player, string message);
|
||||||
void SendAdminChat(IPlayerSession player, string message);
|
void SendAdminChat(IPlayerSession player, string message);
|
||||||
|
|||||||
@@ -485,6 +485,15 @@ namespace Content.Shared.CCVar
|
|||||||
public static readonly CVarDef<bool> AdminOocEnabled =
|
public static readonly CVarDef<bool> AdminOocEnabled =
|
||||||
CVarDef.Create("ooc.enabled_admin", true, CVar.NOTIFY);
|
CVarDef.Create("ooc.enabled_admin", true, CVar.NOTIFY);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* LOOC
|
||||||
|
*/
|
||||||
|
|
||||||
|
public static readonly CVarDef<bool> LoocEnabled = CVarDef.Create("looc.enabled", true, CVar.NOTIFY);
|
||||||
|
|
||||||
|
public static readonly CVarDef<bool> AdminLoocEnabled =
|
||||||
|
CVarDef.Create("looc.enabled_admin", true, CVar.NOTIFY);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Entity Menu Grouping Types
|
* Entity Menu Grouping Types
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -30,36 +30,41 @@ namespace Content.Shared.Chat
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
Radio = 1 << 3,
|
Radio = 1 << 3,
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Local out-of-character channel
|
||||||
|
/// </summary>
|
||||||
|
LOOC = 1 << 4,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Out-of-character channel
|
/// Out-of-character channel
|
||||||
/// </summary>
|
/// </summary>
|
||||||
OOC = 1 << 4,
|
OOC = 1 << 5,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Visual events the player can see.
|
/// Visual events the player can see.
|
||||||
/// Basically like visual_message in SS13.
|
/// Basically like visual_message in SS13.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
Visual = 1 << 5,
|
Visual = 1 << 6,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Emotes
|
/// Emotes
|
||||||
/// </summary>
|
/// </summary>
|
||||||
Emotes = 1 << 6,
|
Emotes = 1 << 7,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Deadchat
|
/// Deadchat
|
||||||
/// </summary>
|
/// </summary>
|
||||||
Dead = 1 << 7,
|
Dead = 1 << 8,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Admin chat
|
/// Admin chat
|
||||||
/// </summary>
|
/// </summary>
|
||||||
Admin = 1 << 8,
|
Admin = 1 << 9,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Unspecified.
|
/// Unspecified.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
Unspecified = 1 << 9,
|
Unspecified = 1 << 10,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Channels considered to be IC.
|
/// Channels considered to be IC.
|
||||||
|
|||||||
@@ -23,6 +23,11 @@ namespace Content.Shared.Chat
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
Radio = ChatChannel.Radio,
|
Radio = ChatChannel.Radio,
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Local out-of-character channel
|
||||||
|
/// </summary>
|
||||||
|
LOOC = ChatChannel.LOOC,
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Out-of-character channel
|
/// Out-of-character channel
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
set-looc-command-description = Allows you to enable or disable LOOC.
|
||||||
|
set-looc-command-help = Usage: setlooc OR setlooc [value]
|
||||||
|
set-looc-command-too-many-arguments-error = Too many arguments.
|
||||||
|
set-looc-command-invalid-argument-error = Invalid argument.
|
||||||
|
set-looc-command-looc-enabled = LOOC chat has been enabled.
|
||||||
|
set-looc-command-looc-disabled = LOOC chat has been disabled.
|
||||||
@@ -1,3 +1,4 @@
|
|||||||
server-reboot = Reboot
|
server-reboot = Reboot
|
||||||
server-shutdown = Shutdown
|
server-shutdown = Shutdown
|
||||||
server-ooc-toggle = Toggle OOC
|
server-ooc-toggle = Toggle OOC
|
||||||
|
server-looc-toggle = Toggle LOOC
|
||||||
|
|||||||
@@ -3,6 +3,8 @@
|
|||||||
chat-manager-max-message-length = Your message exceeds {$maxMessageLength} character limit
|
chat-manager-max-message-length = Your message exceeds {$maxMessageLength} character limit
|
||||||
chat-manager-ooc-chat-enabled-message = OOC chat has been enabled.
|
chat-manager-ooc-chat-enabled-message = OOC chat has been enabled.
|
||||||
chat-manager-ooc-chat-disabled-message = OOC chat has been disabled.
|
chat-manager-ooc-chat-disabled-message = OOC chat has been disabled.
|
||||||
|
chat-manager-looc-chat-enabled-message = LOOC chat has been enabled.
|
||||||
|
chat-manager-looc-chat-disabled-message = LOOC chat has been disabled.
|
||||||
chat-manager-admin-ooc-chat-enabled-message = Admin OOC chat has been enabled.
|
chat-manager-admin-ooc-chat-enabled-message = Admin OOC chat has been enabled.
|
||||||
chat-manager-admin-ooc-chat-disabled-message = Admin OOC chat has been disabled.
|
chat-manager-admin-ooc-chat-disabled-message = Admin OOC chat has been disabled.
|
||||||
chat-manager-max-message-length-exceeded-message = Your message exceeded {$limit} character limit
|
chat-manager-max-message-length-exceeded-message = Your message exceeded {$limit} character limit
|
||||||
@@ -12,6 +14,7 @@ chat-manager-sender-announcement-wrap-message = {$sender} Announcement:
|
|||||||
{"{0}"}
|
{"{0}"}
|
||||||
chat-manager-entity-say-wrap-message = {$entityName} says: "{"{0}"}"
|
chat-manager-entity-say-wrap-message = {$entityName} says: "{"{0}"}"
|
||||||
chat-manager-entity-me-wrap-message = {$entityName} {"{0}"}
|
chat-manager-entity-me-wrap-message = {$entityName} {"{0}"}
|
||||||
|
chat-manager-entity-looc-wrap-message = LOOC: {$entityName}: {"{0}"}
|
||||||
chat-manager-send-ooc-wrap-message = OOC: {$playerName}: {"{0}"}
|
chat-manager-send-ooc-wrap-message = OOC: {$playerName}: {"{0}"}
|
||||||
chat-manager-send-ooc-patron-wrap-message = OOC: [color={$patronColor}]{$playerName}[/color]: {"{0}"}
|
chat-manager-send-ooc-patron-wrap-message = OOC: [color={$patronColor}]{$playerName}[/color]: {"{0}"}
|
||||||
chat-manager-send-dead-chat-wrap-message = {$deadChannelName}: {$playerName}: {"{0}"}
|
chat-manager-send-dead-chat-wrap-message = {$deadChannelName}: {$playerName}: {"{0}"}
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ hud-chatbox-select-channel-Console = Console
|
|||||||
hud-chatbox-select-channel-Dead = Dead
|
hud-chatbox-select-channel-Dead = Dead
|
||||||
hud-chatbox-select-channel-Emotes = Emotes
|
hud-chatbox-select-channel-Emotes = Emotes
|
||||||
hud-chatbox-select-channel-Local = Local
|
hud-chatbox-select-channel-Local = Local
|
||||||
|
hud-chatbox-select-channel-LOOC = LOOC
|
||||||
hud-chatbox-select-channel-OOC = OOC
|
hud-chatbox-select-channel-OOC = OOC
|
||||||
hud-chatbox-select-channel-Radio = Radio
|
hud-chatbox-select-channel-Radio = Radio
|
||||||
|
|
||||||
@@ -13,6 +14,7 @@ hud-chatbox-channel-Admin = Admin
|
|||||||
hud-chatbox-channel-Dead = Dead
|
hud-chatbox-channel-Dead = Dead
|
||||||
hud-chatbox-channel-Emotes = Emotes
|
hud-chatbox-channel-Emotes = Emotes
|
||||||
hud-chatbox-channel-Local = Local
|
hud-chatbox-channel-Local = Local
|
||||||
|
hud-chatbox-channel-LOOC = LOOC
|
||||||
hud-chatbox-channel-OOC = OOC
|
hud-chatbox-channel-OOC = OOC
|
||||||
hud-chatbox-channel-Radio = Radio
|
hud-chatbox-channel-Radio = Radio
|
||||||
hud-chatbox-channel-Server = Server
|
hud-chatbox-channel-Server = Server
|
||||||
|
|||||||
Reference in New Issue
Block a user