2023-09-16 07:18:10 +01:00
|
|
|
using Content.Server.Objectives.Components;
|
|
|
|
|
using Content.Server.Shuttles.Systems;
|
|
|
|
|
using Content.Shared.CCVar;
|
|
|
|
|
using Content.Shared.Mind;
|
|
|
|
|
using Content.Shared.Objectives.Components;
|
|
|
|
|
using Robust.Shared.Configuration;
|
|
|
|
|
|
|
|
|
|
namespace Content.Server.Objectives.Systems;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Handles kill person condition logic and picking random kill targets.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public sealed class KillPersonConditionSystem : EntitySystem
|
|
|
|
|
{
|
|
|
|
|
[Dependency] private readonly EmergencyShuttleSystem _emergencyShuttle = default!;
|
|
|
|
|
[Dependency] private readonly IConfigurationManager _config = default!;
|
|
|
|
|
[Dependency] private readonly SharedMindSystem _mind = default!;
|
|
|
|
|
[Dependency] private readonly TargetObjectiveSystem _target = default!;
|
|
|
|
|
|
|
|
|
|
public override void Initialize()
|
|
|
|
|
{
|
|
|
|
|
base.Initialize();
|
|
|
|
|
|
|
|
|
|
SubscribeLocalEvent<KillPersonConditionComponent, ObjectiveGetProgressEvent>(OnGetProgress);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void OnGetProgress(EntityUid uid, KillPersonConditionComponent comp, ref ObjectiveGetProgressEvent args)
|
|
|
|
|
{
|
|
|
|
|
if (!_target.GetTarget(uid, out var target))
|
|
|
|
|
return;
|
|
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
args.Progress = GetProgress(target.Value, comp.RequireDead, comp.RequireMaroon);
|
2023-09-16 07:18:10 +01:00
|
|
|
}
|
|
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
private float GetProgress(EntityUid target, bool requireDead, bool requireMaroon)
|
2023-09-16 07:18:10 +01:00
|
|
|
{
|
|
|
|
|
// deleted or gibbed or something, counts as dead
|
|
|
|
|
if (!TryComp<MindComponent>(target, out var mind) || mind.OwnedEntity == null)
|
|
|
|
|
return 1f;
|
|
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
var targetDead = _mind.IsCharacterDeadIc(mind);
|
|
|
|
|
var targetMarooned = !_emergencyShuttle.IsTargetEscaping(target) &&
|
|
|
|
|
_emergencyShuttle.ShuttlesLeft;
|
|
|
|
|
if (!_config.GetCVar(CCVars.EmergencyShuttleEnabled) && requireMaroon)
|
|
|
|
|
{
|
|
|
|
|
requireDead = true;
|
|
|
|
|
requireMaroon = false;
|
|
|
|
|
}
|
2023-09-16 07:18:10 +01:00
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
if (requireDead && !targetDead)
|
2023-09-16 07:18:10 +01:00
|
|
|
return 0f;
|
|
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
if (requireMaroon) // if evac is still here and target hasn't boarded, show 50% to give you an indicator that you are doing good
|
|
|
|
|
return targetMarooned ? 1f : _emergencyShuttle.EmergencyShuttleArrived ? 0.5f : 0f;
|
2023-09-16 07:18:10 +01:00
|
|
|
|
2025-04-20 16:34:19 -05:00
|
|
|
return 1f; // Good job you did it woohoo
|
2023-09-16 07:18:10 +01:00
|
|
|
}
|
|
|
|
|
}
|