Skip to content

Commit

Permalink
Offshore Gas Drilling and Pumping (#2403)
Browse files Browse the repository at this point in the history
* gaslock wip

* gaslock WIP

* gaslock: entity's more or less good

* deposits & drills, WIP

* gas deposit drill WIP

* More work on deposits and drills, still WIP

* random gas deposits, drill fixes

* drill visualizers, ignore deposits, yaml fixes

* Gas deposits, pipe fixes for the drill

* gaslock RSI fix

* gaslock to binary.yml, joinSystem test

* GasDepositExtractor: push into net, not pipe

* Clear pump on undock

* WIP docking types, sale point

* selective docking WIP

* WIP gas sale point, console, gas sale UI

* Bidirectional pressure pipes

* gaslock console wip

* cleanup, smaller deposits

* Add gaslocks to the atmospheric alerts computer

* Fix gaslock pipe readout

* Remove unused deposits

* Undupe AtmosDirectionChanged log value

* Address test failures

* Add remaining missing containers

* Fix missing source/sink port refs in gas sale comp

* maps and maps

* fix gas drill examine text

* make storage canisters craftable

* gas price changes

* N2/O2 to zero, fix trit/frezon comment

* comment out edison for now

* Lower cargo canister prices, raise plasma

* gasbender: resolve duped IDs

* Fix invalid network config ref

* canister arbitrage fix

* Narrow gaslock, fix bidirectional pump UI overlap

* Remove GaslockReversed reference in ambition

* internal gas sale point, better piping

* max extraction rate, deposit suffixes

* gas sale point: inherit from basemachinepowered

* sale point: fix parent order

* gas sale port: dockable pump->dockable pipe

* No gas sale point alerts entry

* Rename dockablepumpsystem file, nix unneeded deps

* Dirty gas deposit extractor UI on open

* MapInit, not ComponentInit, hide unanchored docks

* Working sale point

* Gasbender: fix unpowered thrusters

* Gas sale console UI

* Appraise, not Refresh

* Edison: two online SMESes, coloured pipes

* cleanup

* fix mining drill BUI

* muddled gas deposits

* Gas sale UI: only show present gases

* fix ref to gaslock window

* gas sale point screen, remove unused console

* ShuttleDockControl: Frontier comments

* Remove other missing Gaslock console windows

* add generic keys, panel open to NF computers RSI

---------

Co-authored-by: Dvir <[email protected]>
Co-authored-by: Checkraze <[email protected]>
  • Loading branch information
3 people authored Jan 18, 2025
1 parent 161e516 commit 30ac7d8
Show file tree
Hide file tree
Showing 115 changed files with 6,425 additions and 1,472 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
using Content.Shared.Atmos.Components;
using Content.Shared.Shuttles.Events; // Frontier
using Content.Shared._NF.Atmos.BUI; // Frontier

namespace Content.Client.Atmos.Consoles;

Expand All @@ -23,7 +25,7 @@ protected override void UpdateState(BoundUserInterfaceState state)
var castState = (AtmosAlertsComputerBoundInterfaceState) state;

EntMan.TryGetComponent<TransformComponent>(Owner, out var xform);
_menu?.UpdateUI(xform?.Coordinates, castState.AirAlarms, castState.FireAlarms, castState.FocusData);
_menu?.UpdateUI(xform?.Coordinates, castState.AirAlarms, castState.FireAlarms, castState.FocusData, castState.Gaslocks, castState.FocusGaslockData); // Frontier: add gaslocks, focusGaslockData
}

public void SendFocusChangeMessage(NetEntity? netEntity)
Expand All @@ -36,6 +38,28 @@ public void SendDeviceSilencedMessage(NetEntity netEntity, bool silenceDevice)
SendMessage(new AtmosAlertsComputerDeviceSilencedMessage(netEntity, silenceDevice));
}

// Frontier: gaslock message
public void SendGaslockChangeDirectionMessage(NetEntity netEntity, bool direction)
{
SendMessage(new RemoteGasPressurePumpChangePumpDirectionMessage(netEntity, direction));
}

public void SendGaslockPressureChangeMessage(NetEntity netEntity, float pressure)
{
SendMessage(new RemoteGasPressurePumpChangeOutputPressureMessage(netEntity, pressure));
}

public void SendGaslockChangeEnabled(NetEntity netEntity, bool enabled)
{
SendMessage(new RemoteGasPressurePumpToggleStatusMessage(netEntity, enabled));
}

public void SendGaslockUndock(NetEntity netEntity)
{
SendMessage(new UndockRequestMessage { DockEntity = netEntity });
}
// End Frontier

protected override void Dispose(bool disposing)
{
base.Dispose(disposing);
Expand Down
5 changes: 5 additions & 0 deletions Content.Client/Atmos/Consoles/AtmosAlertsComputerWindow.xaml
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,11 @@
<ScrollContainer HorizontalExpand="True" Margin="8, 8, 8, 8">
<BoxContainer Name="FireAlarmsTable" Orientation="Vertical" VerticalExpand="True" HorizontalExpand="True" Margin="0 0 0 10"/>
</ScrollContainer>
<!-- Frontier: gaslock entries -->
<ScrollContainer HorizontalExpand="True" Margin="8, 8, 8, 8">
<BoxContainer Name="GaslocksTable" Orientation="Vertical" VerticalExpand="True" HorizontalExpand="True" Margin="0 0 0 10"/>
</ScrollContainer>
<!-- End Frontier: gaslock entries -->
</TabContainer>

<!-- Overlay toggles -->
Expand Down
131 changes: 120 additions & 11 deletions Content.Client/Atmos/Consoles/AtmosAlertsComputerWindow.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
using Robust.Shared.Utility;
using System.Diagnostics.CodeAnalysis;
using System.Linq;
using Content.Client._NF.Atmos.Consoles; // Frontier

namespace Content.Client.Atmos.Consoles;

Expand All @@ -30,6 +31,7 @@ public sealed partial class AtmosAlertsComputerWindow : FancyWindow

private AtmosAlertsComputerEntry[]? _airAlarms = null;
private AtmosAlertsComputerEntry[]? _fireAlarms = null;
private AtmosAlertsComputerEntry[]? _gaslocks = null; // Frontier
private IEnumerable<AtmosAlertsComputerEntry>? _allAlarms = null;

private IEnumerable<AtmosAlertsComputerEntry>? _activeAlarms = null;
Expand All @@ -38,6 +40,13 @@ public sealed partial class AtmosAlertsComputerWindow : FancyWindow
public event Action<NetEntity?>? SendFocusChangeMessageAction;
public event Action<NetEntity, bool>? SendDeviceSilencedMessageAction;

// Frontier: gaslock actions
public event Action<NetEntity, bool>? SendGaslockChangeDirectionMessageAction;
public event Action<NetEntity, float>? SendGaslockPressureChangeMessageAction;
public event Action<NetEntity, bool>? SendGaslockChangeEnabledAction;
public event Action<NetEntity>? SendGaslockUndockAction;
// End Frontier: gaslock actions

private bool _autoScrollActive = false;
private bool _autoScrollAwaitsUpdate = false;

Expand Down Expand Up @@ -77,7 +86,7 @@ public AtmosAlertsComputerWindow(AtmosAlertsComputerBoundUserInterface userInter
{
NavMap.MapUid = xform.GridUid;

// Assign station name
// Assign station name
if (_entManager.TryGetComponent<MetaDataComponent>(xform.GridUid, out var stationMetaData))
stationName = stationMetaData.EntityName;

Expand All @@ -103,6 +112,7 @@ public AtmosAlertsComputerWindow(AtmosAlertsComputerBoundUserInterface userInter
MasterTabContainer.SetTabTitle(0, Loc.GetString("atmos-alerts-window-tab-no-alerts"));
MasterTabContainer.SetTabTitle(1, Loc.GetString("atmos-alerts-window-tab-air-alarms"));
MasterTabContainer.SetTabTitle(2, Loc.GetString("atmos-alerts-window-tab-fire-alarms"));
MasterTabContainer.SetTabTitle(3, Loc.GetString("atmos-alerts-window-tab-gaslocks")); // Frontier

// Set UI toggles
ShowInactiveAlarms.OnToggled += _ => OnShowAlarmsToggled(ShowInactiveAlarms, AtmosAlarmType.Invalid);
Expand All @@ -113,6 +123,12 @@ public AtmosAlertsComputerWindow(AtmosAlertsComputerBoundUserInterface userInter
// Set atmos monitoring message action
SendFocusChangeMessageAction += userInterface.SendFocusChangeMessage;
SendDeviceSilencedMessageAction += userInterface.SendDeviceSilencedMessage;

// Frontier: set gaslock message actions
SendGaslockChangeDirectionMessageAction += userInterface.SendGaslockChangeDirectionMessage;
SendGaslockPressureChangeMessageAction += userInterface.SendGaslockPressureChangeMessage;
SendGaslockChangeEnabledAction += userInterface.SendGaslockChangeEnabled;
SendGaslockUndockAction += userInterface.SendGaslockUndock;
}

#region Toggle handling
Expand Down Expand Up @@ -162,7 +178,7 @@ private void OnSilenceAlertsToggled(NetEntity netEntity, bool toggleState)

#endregion

public void UpdateUI(EntityCoordinates? consoleCoords, AtmosAlertsComputerEntry[] airAlarms, AtmosAlertsComputerEntry[] fireAlarms, AtmosAlertsFocusDeviceData? focusData)
public void UpdateUI(EntityCoordinates? consoleCoords, AtmosAlertsComputerEntry[] airAlarms, AtmosAlertsComputerEntry[] fireAlarms, AtmosAlertsFocusDeviceData? focusData, AtmosAlertsComputerEntry[] gaslocks, AtmosAlertsFocusGaslockData? focusGaslockData) // Frontier: add gaslocks, gaslock data
{
if (_owner == null)
return;
Expand All @@ -179,7 +195,9 @@ public void UpdateUI(EntityCoordinates? consoleCoords, AtmosAlertsComputerEntry[
// Retain alarm data for use inbetween updates
_airAlarms = airAlarms;
_fireAlarms = fireAlarms;
_gaslocks = gaslocks; // Frontier
_allAlarms = airAlarms.Concat(fireAlarms);
_allAlarms = airAlarms.Concat(gaslocks); // Frontier

var silenced = console.SilencedDevices;

Expand Down Expand Up @@ -245,6 +263,11 @@ public void UpdateUI(EntityCoordinates? consoleCoords, AtmosAlertsComputerEntry[
while (FireAlarmsTable.ChildCount > fireAlarms.Length)
FireAlarmsTable.RemoveChild(FireAlarmsTable.GetChild(FireAlarmsTable.ChildCount - 1));

// Frontier: gaslocks
while (GaslocksTable.ChildCount > gaslocks.Length)
GaslocksTable.RemoveChild(GaslocksTable.GetChild(GaslocksTable.ChildCount - 1));
// End Frontier

// Update all entries in each table
for (int index = 0; index < _activeAlarms.Count(); index++)
{
Expand All @@ -264,6 +287,14 @@ public void UpdateUI(EntityCoordinates? consoleCoords, AtmosAlertsComputerEntry[
UpdateUIEntry(entry, index, FireAlarmsTable, console, focusData);
}

// Frontier: gaslocks
for (int index = 0; index < gaslocks.Count(); index++)
{
var entry = gaslocks.ElementAt(index);
UpdateGaslockUIEntry(entry, index, GaslocksTable, console, focusGaslockData);
}
// End Frontier

// If no alerts are active, display a message
if (MasterTabContainer.CurrentTab == 0 && activeAlarmCount == 0)
{
Expand Down Expand Up @@ -391,6 +422,7 @@ private void UpdateUIEntry(AtmosAlertsComputerEntry entry, int index, Control ta
UpdateConsoleTable(console, AlertsTable, _trackedEntity);
UpdateConsoleTable(console, AirAlarmsTable, _trackedEntity);
UpdateConsoleTable(console, FireAlarmsTable, _trackedEntity);
UpdateConsoleTable(console, GaslocksTable, _trackedEntity); // Frontier
};

// On toggling the silence check box
Expand Down Expand Up @@ -424,20 +456,92 @@ private void UpdateUIEntry(AtmosAlertsComputerEntry entry, int index, Control ta
entryContainer.SilenceAlarmProgressBar.Visible = (table == AlertsTable && _deviceSilencingProgress.ContainsKey(entry.NetEntity));
}

// Frontier: separate UpdateUI function for gaslocks
private void UpdateGaslockUIEntry(AtmosAlertsComputerEntry entry, int index, Control table, AtmosAlertsComputerComponent console, AtmosAlertsFocusGaslockData? focusData = null)
{
// Make new UI entry if required
if (index >= table.ChildCount)
{
var newEntryContainer = new AtmosAlarmGaslockEntryContainer(entry.NetEntity, _entManager.GetCoordinates(entry.Coordinates));

newEntryContainer.SendChangeDirectionMessageAction += SendGaslockChangeDirectionMessageAction;
newEntryContainer.SendPressureChangeAction += SendGaslockPressureChangeMessageAction;
newEntryContainer.SendChangeEnabledAction += SendGaslockChangeEnabledAction;
newEntryContainer.SendUndockAction += SendGaslockUndockAction;

// On click
newEntryContainer.FocusButton.OnButtonUp += args =>
{
if (_trackedEntity == newEntryContainer.NetEntity)
{
_trackedEntity = null;
}

else
{
_trackedEntity = newEntryContainer.NetEntity;

if (newEntryContainer.Coordinates != null)
NavMap.CenterToCoordinates(newEntryContainer.Coordinates.Value);
}

// Send message to console that the focus has changed
SendFocusChangeMessageAction?.Invoke(_trackedEntity);

// Update affected UI elements across all tables
UpdateConsoleTable(console, AlertsTable, _trackedEntity);
UpdateConsoleTable(console, AirAlarmsTable, _trackedEntity);
UpdateConsoleTable(console, FireAlarmsTable, _trackedEntity);
UpdateConsoleTable(console, GaslocksTable, _trackedEntity); // Frontier
};

// Add the entry to the current table
table.AddChild(newEntryContainer);
}

// Update values and UI elements
var tableChild = table.GetChild(index);

if (tableChild is not AtmosAlarmGaslockEntryContainer)
{
table.RemoveChild(tableChild);
UpdateGaslockUIEntry(entry, index, table, console, focusData);

return;
}

var entryContainer = (AtmosAlarmGaslockEntryContainer)tableChild;

entryContainer.UpdateEntry(entry, entry.NetEntity == _trackedEntity, focusData);
}
// End Frontier: separate UpdateUI function for gaslocks

private void UpdateConsoleTable(AtmosAlertsComputerComponent console, Control table, NetEntity? currTrackedEntity)
{
foreach (var tableChild in table.Children)
{
if (tableChild is not AtmosAlarmEntryContainer)
continue;
// Frontier: multiple type checks
if (tableChild is AtmosAlarmEntryContainer)
{
var entryContainer = (AtmosAlarmEntryContainer)tableChild;

var entryContainer = (AtmosAlarmEntryContainer)tableChild;
if (entryContainer.NetEntity != currTrackedEntity)
entryContainer.RemoveAsFocus();

if (entryContainer.NetEntity != currTrackedEntity)
entryContainer.RemoveAsFocus();
else if (entryContainer.NetEntity == currTrackedEntity)
entryContainer.SetAsFocus();
}
else if (tableChild is AtmosAlarmGaslockEntryContainer)
{
var entryContainer = (AtmosAlarmGaslockEntryContainer)tableChild;

else if (entryContainer.NetEntity == currTrackedEntity)
entryContainer.SetAsFocus();
if (entryContainer.NetEntity != currTrackedEntity)
entryContainer.RemoveAsFocus();

else if (entryContainer.NetEntity == currTrackedEntity)
entryContainer.SetAsFocus();
}
// End Frontier
}
}

Expand All @@ -464,6 +568,8 @@ private void SetTrackedEntityFromNavMap(NetEntity? netEntity)
MasterTabContainer.CurrentTab = 1; break;
case AtmosAlertsComputerGroup.FireAlarm:
MasterTabContainer.CurrentTab = 2; break;
case AtmosAlertsComputerGroup.Gaslock: // Frontier
MasterTabContainer.CurrentTab = 3; break; // Frontier
}
}

Expand Down Expand Up @@ -565,12 +671,15 @@ private bool TryGetNextScrollPosition([NotNullWhen(true)] out float? nextScrollP

foreach (var control in container.Children)
{
if (control == null || control is not AtmosAlarmEntryContainer)
if (control == null) // Frontier: move type checks down
continue;

if (((AtmosAlarmEntryContainer)control).NetEntity == _trackedEntity)
if (control is AtmosAlarmEntryContainer && ((AtmosAlarmEntryContainer)control).NetEntity == _trackedEntity) // Frontier: add type check
return true;

if (control is AtmosAlarmGaslockEntryContainer && ((AtmosAlarmGaslockEntryContainer)control).NetEntity == _trackedEntity) // Frontier
return true; // Frontier

nextScrollPosition += control.Height;
}

Expand Down
1 change: 1 addition & 0 deletions Content.Client/Entry/EntryPoint.cs
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@ public override void Init()
_prototypeManager.RegisterIgnore("alertLevels");
_prototypeManager.RegisterIgnore("nukeopsRole");
_prototypeManager.RegisterIgnore("ghostRoleRaffleDecider");
_prototypeManager.RegisterIgnore("gasDeposit"); // Frontier
_prototypeManager.RegisterIgnore("pointOfInterest"); // Frontier: worldgen-related, server-only

_componentFactory.GenerateNetIds();
Expand Down
25 changes: 19 additions & 6 deletions Content.Client/Shuttles/UI/ShuttleDockControl.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,9 @@ protected override void Draw(DrawingHandleScreen handle)
var canDockChange = _timing.CurTime > _nextDockChange;
var lineOffset = (float) _timing.RealTime.TotalSeconds * 30f;

var viewedDockType = _viewedState?.DockType ?? DockType.None; // Frontier: cache dock type
var viewedReceiveOnly = _viewedState?.ReceiveOnly ?? true; // Frontier: cache receive only

foreach (var grid in _grids)
{
EntManager.TryGetComponent(grid.Owner, out IFFComponent? iffComp);
Expand Down Expand Up @@ -214,11 +217,13 @@ protected override void Draw(DrawingHandleScreen handle)

if (HighlightedDock == dock.Entity)
{
otherDockColor = Color.ToSrgb(Color.Magenta);
//otherDockColor = Color.ToSrgb(Color.Magenta); // Frontier
otherDockColor = Color.ToSrgb(dock.HighlightedRadarColor); // Frontier
}
else
{
otherDockColor = Color.ToSrgb(Color.Purple);
// otherDockColor = Color.ToSrgb(Color.Purple); // Frontier
otherDockColor = Color.ToSrgb(dock.RadarColor); // Frontier
}

/*
Expand All @@ -236,6 +241,7 @@ protected override void Draw(DrawingHandleScreen handle)
if (dockButton != null && dock.GridDockedWith != null)
{
dockButton.Disabled = !canDockChange;
dockButton.Visible = true; // Frontier: undock should always be visible.
}

// If the dock is in range then also do highlighting
Expand Down Expand Up @@ -265,18 +271,25 @@ protected override void Draw(DrawingHandleScreen handle)
var canDock = distanceSq < maxDockDistSq && inAlignment;

if (dockButton != null)
{
dockButton.Disabled = !canDock && dock.GridDockedWith == null || !canDockChange; // Frontier: add "&& dock.GridDockedWith == null"
dockButton.Visible = dock.GridDockedWith != null || (dock.DockType & viewedDockType) != DockType.None && !viewedReceiveOnly; // Frontier: do not enable docking for receive-only docks
}

var lineColor = inAlignment ? Color.Lime : Color.Red;
handle.DrawDottedLine(viewedDockPos.Value, collisionCenter, lineColor, offset: lineOffset);
}
else if (dockButton != null)
{
dockButton.Visible = dock.GridDockedWith != null; // Frontier: do not enable docking for receive-only docks
}

canDraw = true;
}
else
else if (dockButton != null)
{
if (dockButton != null)
dockButton.Disabled = true;
dockButton.Disabled = true;
dockButton.Visible = dock.GridDockedWith != null || (dock.DockType & viewedDockType) != DockType.None && !viewedReceiveOnly; // Frontier
}
}

Expand Down Expand Up @@ -312,7 +325,7 @@ protected override void Draw(DrawingHandleScreen handle)
ScalePosition(Vector2.Transform(new Vector2(-0.5f, 0.5f), rotation)),
ScalePosition(Vector2.Transform(new Vector2(0.5f, -0.5f), rotation)));

var dockColor = Color.Magenta;
var dockColor = _viewedState?.HighlightedRadarColor ?? Color.Magenta; // Frontier - use ViewedState
var connectionColor = Color.Pink;

handle.DrawRect(ourDockConnection, connectionColor.WithAlpha(0.2f));
Expand Down
3 changes: 2 additions & 1 deletion Content.Client/Shuttles/UI/ShuttleNavControl.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -387,7 +387,8 @@ private void DrawDocks(DrawingHandleScreen handle, EntityUid uid, Matrix3x2 grid
continue;
}

var color = Color.ToSrgb(Color.Magenta);
//var color = Color.ToSrgb(Color.Magenta); // Frontier
var color = Color.ToSrgb(state.HighlightedRadarColor); // Frontier

var verts = new[]
{
Expand Down
Loading

0 comments on commit 30ac7d8

Please sign in to comment.