2020-08-30 11:28:46 +02:00
|
|
|
|
using Content.Shared.Interfaces;
|
2021-02-11 01:13:03 -08:00
|
|
|
|
using Robust.Server.Player;
|
|
|
|
|
|
using Robust.Shared.GameObjects;
|
2020-08-30 11:28:46 +02:00
|
|
|
|
using Robust.Shared.IoC;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Content.Server.Utility
|
|
|
|
|
|
{
|
|
|
|
|
|
public static class NotifyExtensions
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Pops up a message for every player around <see cref="source"/> to see,
|
|
|
|
|
|
/// except for <see cref="source"/> itself.
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="source">The entity on which to popup the message.</param>
|
|
|
|
|
|
/// <param name="message">The message to show.</param>
|
2020-09-12 15:48:22 +02:00
|
|
|
|
/// <param name="playerManager">
|
|
|
|
|
|
/// The instance of player manager to use, will be resolved automatically
|
|
|
|
|
|
/// if null.
|
|
|
|
|
|
/// </param>
|
2020-08-30 11:28:46 +02:00
|
|
|
|
/// <param name="range">
|
|
|
|
|
|
/// The range in which to search for players, defaulting to one screen.
|
|
|
|
|
|
/// </param>
|
2020-09-12 15:48:22 +02:00
|
|
|
|
public static void PopupMessageOtherClients(this IEntity source, string message, IPlayerManager playerManager = null, int range = 15)
|
2020-08-30 11:28:46 +02:00
|
|
|
|
{
|
2020-09-12 15:48:22 +02:00
|
|
|
|
playerManager ??= IoCManager.Resolve<IPlayerManager>();
|
|
|
|
|
|
|
2020-09-06 16:11:53 +02:00
|
|
|
|
var viewers = playerManager.GetPlayersInRange(source.Transform.Coordinates, range);
|
2020-08-30 11:28:46 +02:00
|
|
|
|
|
|
|
|
|
|
foreach (var viewer in viewers)
|
|
|
|
|
|
{
|
|
|
|
|
|
var viewerEntity = viewer.AttachedEntity;
|
|
|
|
|
|
|
|
|
|
|
|
if (viewerEntity == null || source == viewerEntity)
|
|
|
|
|
|
{
|
|
|
|
|
|
continue;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
source.PopupMessage(viewer.AttachedEntity, message);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2020-09-12 15:48:22 +02:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Pops up a message at the given entity's location for everyone,
|
|
|
|
|
|
/// including itself, to see.
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="source">The entity above which to show the message.</param>
|
|
|
|
|
|
/// <param name="message">The message to be seen.</param>
|
|
|
|
|
|
/// <param name="playerManager">
|
|
|
|
|
|
/// The instance of player manager to use, will be resolved automatically
|
|
|
|
|
|
/// if null.
|
|
|
|
|
|
/// </param>
|
|
|
|
|
|
/// <param name="range">
|
|
|
|
|
|
/// The range in which to search for players, defaulting to one screen.
|
|
|
|
|
|
/// </param>
|
|
|
|
|
|
public static void PopupMessageEveryone(this IEntity source, string message, IPlayerManager playerManager = null, int range = 15)
|
|
|
|
|
|
{
|
|
|
|
|
|
source.PopupMessage(message);
|
|
|
|
|
|
source.PopupMessageOtherClients(message, playerManager, range);
|
|
|
|
|
|
}
|
2020-08-30 11:28:46 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|