2020-11-09 20:22:19 -08:00
|
|
|
|
using System;
|
2021-06-09 22:19:39 +02:00
|
|
|
|
using Content.Server.Gravity.EntitySystems;
|
2020-12-13 14:28:20 -08:00
|
|
|
|
using Content.Shared.Alert;
|
2020-11-09 20:22:19 -08:00
|
|
|
|
using Robust.Shared.GameObjects;
|
|
|
|
|
|
using Robust.Shared.Log;
|
2021-02-11 01:13:03 -08:00
|
|
|
|
using Robust.Shared.Network;
|
2020-11-09 20:22:19 -08:00
|
|
|
|
using Robust.Shared.Players;
|
|
|
|
|
|
|
2021-06-09 22:19:39 +02:00
|
|
|
|
namespace Content.Server.Alert
|
2020-11-09 20:22:19 -08:00
|
|
|
|
{
|
|
|
|
|
|
[RegisterComponent]
|
|
|
|
|
|
[ComponentReference(typeof(SharedAlertsComponent))]
|
|
|
|
|
|
public sealed class ServerAlertsComponent : SharedAlertsComponent
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
protected override void Startup()
|
|
|
|
|
|
{
|
|
|
|
|
|
base.Startup();
|
|
|
|
|
|
|
|
|
|
|
|
if (EntitySystem.TryGet<WeightlessSystem>(out var weightlessSystem))
|
|
|
|
|
|
{
|
|
|
|
|
|
weightlessSystem.AddAlert(this);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
Logger.WarningS("alert", "weightlesssystem not found");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-06-19 19:41:26 -07:00
|
|
|
|
protected override void OnRemove()
|
2020-11-09 20:22:19 -08:00
|
|
|
|
{
|
|
|
|
|
|
if (EntitySystem.TryGet<WeightlessSystem>(out var weightlessSystem))
|
|
|
|
|
|
{
|
|
|
|
|
|
weightlessSystem.RemoveAlert(this);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2021-03-16 15:50:20 +01:00
|
|
|
|
Logger.WarningS("alert", $"{nameof(WeightlessSystem)} not found");
|
2020-11-09 20:22:19 -08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
base.OnRemove();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-10-27 18:10:40 +02:00
|
|
|
|
[Obsolete("Component Messages are deprecated, use Entity Events instead.")]
|
2021-03-16 15:50:20 +01:00
|
|
|
|
public override void HandleNetworkMessage(ComponentMessage message, INetChannel netChannel, ICommonSession? session = null)
|
2020-11-09 20:22:19 -08:00
|
|
|
|
{
|
|
|
|
|
|
base.HandleNetworkMessage(message, netChannel, session);
|
|
|
|
|
|
|
|
|
|
|
|
if (session == null)
|
|
|
|
|
|
{
|
|
|
|
|
|
throw new ArgumentNullException(nameof(session));
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
switch (message)
|
|
|
|
|
|
{
|
|
|
|
|
|
case ClickAlertMessage msg:
|
|
|
|
|
|
{
|
|
|
|
|
|
var player = session.AttachedEntity;
|
|
|
|
|
|
|
|
|
|
|
|
if (player != Owner)
|
|
|
|
|
|
{
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-09-03 14:11:12 +10:00
|
|
|
|
if (!IsShowingAlert(msg.Type))
|
2020-12-13 14:28:20 -08:00
|
|
|
|
{
|
|
|
|
|
|
Logger.DebugS("alert", "user {0} attempted to" +
|
|
|
|
|
|
" click alert {1} which is not currently showing for them",
|
2021-09-03 14:11:12 +10:00
|
|
|
|
player.Name, msg.Type);
|
2020-12-13 14:28:20 -08:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-09-03 14:11:12 +10:00
|
|
|
|
if (!AlertManager.TryGet(msg.Type, out var alert))
|
2020-11-09 20:22:19 -08:00
|
|
|
|
{
|
2021-09-03 14:11:12 +10:00
|
|
|
|
Logger.WarningS("alert", "unrecognized encoded alert {0}", msg.Type);
|
2021-03-05 12:46:04 +01:00
|
|
|
|
break;
|
2020-11-09 20:22:19 -08:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-03-05 12:46:04 +01:00
|
|
|
|
alert.OnClick?.AlertClicked(new ClickAlertEventArgs(player, alert));
|
2020-11-09 20:22:19 -08:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|