This reverts commit d21e4a1d4e.
This commit is contained in:
@@ -1,11 +0,0 @@
|
|||||||
using Content.Server.StationEvents.Events;
|
|
||||||
|
|
||||||
namespace Content.Server.StationEvents.Components;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Added to APCs to prevent them from turning on until event end
|
|
||||||
/// </summary>
|
|
||||||
[RegisterComponent, Access(typeof(PowerGridCheckRule))]
|
|
||||||
public sealed class PowerGridCheckDisabledComponent : Component
|
|
||||||
{
|
|
||||||
}
|
|
||||||
@@ -6,7 +6,9 @@ using Robust.Shared.Utility;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using Content.Server.Power.EntitySystems;
|
using Content.Server.Power.EntitySystems;
|
||||||
using Timer = Robust.Shared.Timing.Timer;
|
using Timer = Robust.Shared.Timing.Timer;
|
||||||
|
using System.Linq;
|
||||||
using Content.Server.GameTicking.Rules.Components;
|
using Content.Server.GameTicking.Rules.Components;
|
||||||
|
using Robust.Shared.Random;
|
||||||
using Content.Server.Station.Components;
|
using Content.Server.Station.Components;
|
||||||
using Content.Server.StationEvents.Components;
|
using Content.Server.StationEvents.Components;
|
||||||
|
|
||||||
@@ -17,13 +19,6 @@ namespace Content.Server.StationEvents.Events
|
|||||||
{
|
{
|
||||||
[Dependency] private readonly ApcSystem _apcSystem = default!;
|
[Dependency] private readonly ApcSystem _apcSystem = default!;
|
||||||
|
|
||||||
public override void Initialize()
|
|
||||||
{
|
|
||||||
base.Initialize();
|
|
||||||
|
|
||||||
SubscribeLocalEvent<PowerGridCheckDisabledComponent, ApcToggleMainBreakerAttemptEvent>(OnApcToggleMainBreaker);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Started(EntityUid uid, PowerGridCheckRuleComponent component, GameRuleComponent gameRule, GameRuleStartedEvent args)
|
protected override void Started(EntityUid uid, PowerGridCheckRuleComponent component, GameRuleComponent gameRule, GameRuleStartedEvent args)
|
||||||
{
|
{
|
||||||
base.Started(uid, component, gameRule, args);
|
base.Started(uid, component, gameRule, args);
|
||||||
@@ -31,11 +26,10 @@ namespace Content.Server.StationEvents.Events
|
|||||||
if (!TryGetRandomStation(out var chosenStation))
|
if (!TryGetRandomStation(out var chosenStation))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
var query = AllEntityQuery<ApcComponent, TransformComponent>();
|
foreach (var (apc, transform) in EntityQuery<ApcComponent, TransformComponent>(true))
|
||||||
while (query.MoveNext(out var target, out var apc, out var transform))
|
|
||||||
{
|
{
|
||||||
if (apc.MainBreakerEnabled && CompOrNull<StationMemberComponent>(transform.GridUid)?.Station == chosenStation)
|
if (apc.MainBreakerEnabled && CompOrNull<StationMemberComponent>(transform.GridUid)?.Station == chosenStation)
|
||||||
component.Powered.Add(target);
|
component.Powered.Add(apc.Owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
RobustRandom.Shuffle(component.Powered);
|
RobustRandom.Shuffle(component.Powered);
|
||||||
@@ -54,10 +48,9 @@ namespace Content.Server.StationEvents.Events
|
|||||||
|
|
||||||
if (TryComp(entity, out ApcComponent? apcComponent))
|
if (TryComp(entity, out ApcComponent? apcComponent))
|
||||||
{
|
{
|
||||||
if (!apcComponent.MainBreakerEnabled)
|
if(!apcComponent.MainBreakerEnabled)
|
||||||
_apcSystem.ApcToggleBreaker(entity, apcComponent);
|
_apcSystem.ApcToggleBreaker(entity, apcComponent);
|
||||||
}
|
}
|
||||||
RemComp<PowerGridCheckDisabledComponent>(entity);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Can't use the default EndAudio
|
// Can't use the default EndAudio
|
||||||
@@ -95,14 +88,8 @@ namespace Content.Server.StationEvents.Events
|
|||||||
if (apcComponent.MainBreakerEnabled)
|
if (apcComponent.MainBreakerEnabled)
|
||||||
_apcSystem.ApcToggleBreaker(selected, apcComponent);
|
_apcSystem.ApcToggleBreaker(selected, apcComponent);
|
||||||
}
|
}
|
||||||
EnsureComp<PowerGridCheckDisabledComponent>(selected);
|
|
||||||
component.Unpowered.Add(selected);
|
component.Unpowered.Add(selected);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnApcToggleMainBreaker(EntityUid uid, PowerGridCheckDisabledComponent component, ref ApcToggleMainBreakerAttemptEvent args)
|
|
||||||
{
|
|
||||||
args.Cancelled = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user