* Intercom buffs and fixes * remove unused bui state * mild sec intercom buff * reinforce sec intercoms
164 lines
6.0 KiB
C#
164 lines
6.0 KiB
C#
using Content.Shared.Administration.Logs;
|
|
using Content.Shared.Database;
|
|
using Content.Shared.Examine;
|
|
using Content.Shared.Interaction;
|
|
using Content.Shared.Tools.Systems;
|
|
using Content.Shared.UserInterface;
|
|
using Robust.Shared.Audio.Systems;
|
|
|
|
namespace Content.Shared.Wires;
|
|
|
|
public abstract class SharedWiresSystem : EntitySystem
|
|
{
|
|
[Dependency] protected readonly ISharedAdminLogManager AdminLogger = default!;
|
|
[Dependency] private readonly ActivatableUISystem _activatableUI = default!;
|
|
[Dependency] protected readonly SharedAppearanceSystem Appearance = default!;
|
|
[Dependency] protected readonly SharedAudioSystem Audio = default!;
|
|
[Dependency] protected readonly SharedToolSystem Tool = default!;
|
|
|
|
public override void Initialize()
|
|
{
|
|
base.Initialize();
|
|
|
|
SubscribeLocalEvent<WiresPanelComponent, ComponentStartup>(OnStartup);
|
|
SubscribeLocalEvent<WiresPanelComponent, WirePanelDoAfterEvent>(OnPanelDoAfter);
|
|
SubscribeLocalEvent<WiresPanelComponent, InteractUsingEvent>(OnInteractUsing);
|
|
SubscribeLocalEvent<WiresPanelComponent, ExaminedEvent>(OnExamine);
|
|
|
|
SubscribeLocalEvent<ActivatableUIRequiresPanelComponent, ActivatableUIOpenAttemptEvent>(OnAttemptOpenActivatableUI);
|
|
SubscribeLocalEvent<ActivatableUIRequiresPanelComponent, PanelChangedEvent>(OnActivatableUIPanelChanged);
|
|
}
|
|
|
|
private void OnStartup(Entity<WiresPanelComponent> ent, ref ComponentStartup args)
|
|
{
|
|
UpdateAppearance(ent, ent);
|
|
}
|
|
|
|
private void OnPanelDoAfter(EntityUid uid, WiresPanelComponent panel, WirePanelDoAfterEvent args)
|
|
{
|
|
if (args.Cancelled)
|
|
return;
|
|
|
|
if (!TogglePanel(uid, panel, !panel.Open, args.User))
|
|
return;
|
|
|
|
AdminLogger.Add(LogType.Action, LogImpact.Low, $"{ToPrettyString(args.User):user} screwed {ToPrettyString(uid):target}'s maintenance panel {(panel.Open ? "open" : "closed")}");
|
|
|
|
var sound = panel.Open ? panel.ScrewdriverOpenSound : panel.ScrewdriverCloseSound;
|
|
Audio.PlayPredicted(sound, uid, args.User);
|
|
args.Handled = true;
|
|
}
|
|
|
|
private void OnInteractUsing(Entity<WiresPanelComponent> ent, ref InteractUsingEvent args)
|
|
{
|
|
if (!Tool.HasQuality(args.Used, ent.Comp.OpeningTool))
|
|
return;
|
|
|
|
if (!CanTogglePanel(ent, args.User))
|
|
return;
|
|
|
|
if (!Tool.UseTool(
|
|
args.Used,
|
|
args.User,
|
|
ent,
|
|
(float) ent.Comp.OpenDelay.TotalSeconds,
|
|
ent.Comp.OpeningTool,
|
|
new WirePanelDoAfterEvent()))
|
|
{
|
|
return;
|
|
}
|
|
|
|
AdminLogger.Add(LogType.Action, LogImpact.Low,
|
|
$"{ToPrettyString(args.User):user} is screwing {ToPrettyString(ent):target}'s {(ent.Comp.Open ? "open" : "closed")} maintenance panel at {Transform(ent).Coordinates:targetlocation}");
|
|
args.Handled = true;
|
|
}
|
|
|
|
private void OnExamine(EntityUid uid, WiresPanelComponent component, ExaminedEvent args)
|
|
{
|
|
using (args.PushGroup(nameof(WiresPanelComponent)))
|
|
{
|
|
if (!component.Open)
|
|
{
|
|
if (!string.IsNullOrEmpty(component.ExamineTextClosed))
|
|
args.PushMarkup(Loc.GetString(component.ExamineTextClosed));
|
|
}
|
|
else
|
|
{
|
|
if (!string.IsNullOrEmpty(component.ExamineTextOpen))
|
|
args.PushMarkup(Loc.GetString(component.ExamineTextOpen));
|
|
|
|
if (TryComp<WiresPanelSecurityComponent>(uid, out var wiresPanelSecurity) &&
|
|
wiresPanelSecurity.Examine != null)
|
|
{
|
|
args.PushMarkup(Loc.GetString(wiresPanelSecurity.Examine));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public void ChangePanelVisibility(EntityUid uid, WiresPanelComponent component, bool visible)
|
|
{
|
|
component.Visible = visible;
|
|
UpdateAppearance(uid, component);
|
|
Dirty(uid, component);
|
|
}
|
|
|
|
protected void UpdateAppearance(EntityUid uid, WiresPanelComponent panel)
|
|
{
|
|
if (TryComp<AppearanceComponent>(uid, out var appearance))
|
|
Appearance.SetData(uid, WiresVisuals.MaintenancePanelState, panel.Open && panel.Visible, appearance);
|
|
}
|
|
|
|
public bool TogglePanel(EntityUid uid, WiresPanelComponent component, bool open, EntityUid? user = null)
|
|
{
|
|
if (!CanTogglePanel((uid, component), user))
|
|
return false;
|
|
|
|
component.Open = open;
|
|
UpdateAppearance(uid, component);
|
|
Dirty(uid, component);
|
|
|
|
var ev = new PanelChangedEvent(component.Open);
|
|
RaiseLocalEvent(uid, ref ev);
|
|
return true;
|
|
}
|
|
|
|
public bool CanTogglePanel(Entity<WiresPanelComponent> ent, EntityUid? user)
|
|
{
|
|
var attempt = new AttemptChangePanelEvent(ent.Comp.Open, user);
|
|
RaiseLocalEvent(ent, ref attempt);
|
|
return !attempt.Cancelled;
|
|
}
|
|
|
|
public bool IsPanelOpen(Entity<WiresPanelComponent?> entity)
|
|
{
|
|
if (!Resolve(entity, ref entity.Comp, false))
|
|
return true;
|
|
|
|
// Listen, i don't know what the fuck this component does. it's stapled on shit for airlocks
|
|
// but it looks like an almost direct duplication of WiresPanelComponent except with a shittier API.
|
|
if (TryComp<WiresPanelSecurityComponent>(entity, out var wiresPanelSecurity) &&
|
|
!wiresPanelSecurity.WiresAccessible)
|
|
return false;
|
|
|
|
return entity.Comp.Open;
|
|
}
|
|
|
|
private void OnAttemptOpenActivatableUI(EntityUid uid, ActivatableUIRequiresPanelComponent component, ActivatableUIOpenAttemptEvent args)
|
|
{
|
|
if (args.Cancelled || !TryComp<WiresPanelComponent>(uid, out var wires))
|
|
return;
|
|
|
|
if (component.RequireOpen != wires.Open)
|
|
args.Cancel();
|
|
}
|
|
|
|
private void OnActivatableUIPanelChanged(EntityUid uid, ActivatableUIRequiresPanelComponent component, ref PanelChangedEvent args)
|
|
{
|
|
if (args.Open == component.RequireOpen)
|
|
return;
|
|
|
|
_activatableUI.CloseAll(uid);
|
|
}
|
|
}
|