]> git.smokeofanarchy.ru Git - space-station-14.git/commitdiff
Alert display lights now properly react to power changes. (#14839)
authorMenshin <Menshin@users.noreply.github.com>
Sat, 25 Mar 2023 03:10:48 +0000 (04:10 +0100)
committerGitHub <noreply@github.com>
Sat, 25 Mar 2023 03:10:48 +0000 (20:10 -0700)
Content.Client/AlertLevel/AlertLevelDisplaySystem.cs
Content.Server/AlertLevel/AlertLevelDisplaySystem.cs
Content.Shared/AlertLevel/SharedAlertLevelDisplay.cs

index cbeda8ff7c2ef02049a3d4a12e47f69b9e629f0f..fb093ff448567fdd6c2239862aeeaf0430d76f0f 100644 (file)
@@ -15,32 +15,32 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
         SubscribeLocalEvent<AlertLevelDisplayComponent, AppearanceChangeEvent>(OnAppearanceChange);
     }
 
-    private void OnAppearanceChange(EntityUid uid, AlertLevelDisplayComponent component, ref AppearanceChangeEvent args)
+    private void OnAppearanceChange(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ref AppearanceChangeEvent args)
     {
         if (args.Sprite == null)
         {
             return;
         }
+        var layer = args.Sprite.LayerMapReserveBlank(AlertLevelDisplay.Layer);
 
-        if (!args.Sprite.LayerMapTryGet(AlertLevelDisplay.Layer, out _))
+        if (args.AppearanceData.TryGetValue(AlertLevelDisplay.Powered, out var poweredObject))
         {
-            var layer = args.Sprite.AddLayer(new RSI.StateId(component.AlertVisuals.Values.First()));
-            args.Sprite.LayerMapSet(AlertLevelDisplay.Layer, layer);
+            args.Sprite.LayerSetVisible(layer, poweredObject is true);
         }
 
         if (!args.AppearanceData.TryGetValue(AlertLevelDisplay.CurrentLevel, out var level))
         {
-            args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(component.AlertVisuals.Values.First()));
+            args.Sprite.LayerSetState(layer, alertLevelDisplay.AlertVisuals.Values.First());
             return;
         }
 
-        if (component.AlertVisuals.TryGetValue((string) level, out var visual))
+        if (alertLevelDisplay.AlertVisuals.TryGetValue((string) level, out var visual))
         {
-            args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(visual));
+            args.Sprite.LayerSetState(layer, visual);
         }
         else
         {
-            args.Sprite.LayerSetState(AlertLevelDisplay.Layer, new RSI.StateId(component.AlertVisuals.Values.First()));
+            args.Sprite.LayerSetState(layer, alertLevelDisplay.AlertVisuals.Values.First());
         }
     }
 }
index c6fdbf581753b5b1a37ee21784550d18de6a9298..043f69e420c64feb51e22f2f46cc858facd0f1d1 100644 (file)
@@ -1,3 +1,4 @@
+using Content.Server.Power.Components;
 using Content.Server.Station.Systems;
 using Content.Shared.AlertLevel;
 using Robust.Server.GameObjects;
@@ -13,6 +14,7 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
     {
         SubscribeLocalEvent<AlertLevelChangedEvent>(OnAlertChanged);
         SubscribeLocalEvent<AlertLevelDisplayComponent, ComponentInit>(OnDisplayInit);
+        SubscribeLocalEvent<AlertLevelDisplayComponent, PowerChangedEvent>(OnPowerChanged);
     }
 
     private void OnAlertChanged(AlertLevelChangedEvent args)
@@ -23,7 +25,7 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
         }
     }
 
-    private void OnDisplayInit(EntityUid uid, AlertLevelDisplayComponent component, ComponentInit args)
+    private void OnDisplayInit(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ComponentInit args)
     {
         if (TryComp(uid, out AppearanceComponent? appearance))
         {
@@ -34,4 +36,11 @@ public sealed class AlertLevelDisplaySystem : EntitySystem
             }
         }
     }
+    private void OnPowerChanged(EntityUid uid, AlertLevelDisplayComponent alertLevelDisplay, ref PowerChangedEvent args)
+    {
+        if (!TryComp(uid, out AppearanceComponent? appearance))
+            return;
+
+        _appearance.SetData(uid, AlertLevelDisplay.Powered, args.Powered, appearance);
+    }
 }
index 37634740f67140e99552a752ae9f7e53efafa593..84d6c07eb0663dfb0e21a1e6ebb81b90515b2388 100644 (file)
@@ -6,5 +6,6 @@ namespace Content.Shared.AlertLevel;
 public enum AlertLevelDisplay
 {
     CurrentLevel,
-    Layer
+    Layer,
+    Powered
 }