Add ability to put spesos into cargo console (#24263)
I thought we had it already but maybe it was an unfinished pr or something.
This commit is contained in:
@@ -5,9 +5,11 @@ using Content.Server.Paper;
|
|||||||
using Content.Server.Station.Components;
|
using Content.Server.Station.Components;
|
||||||
using Content.Shared.Cargo;
|
using Content.Shared.Cargo;
|
||||||
using Content.Shared.Cargo.BUI;
|
using Content.Shared.Cargo.BUI;
|
||||||
|
using Content.Shared.Cargo.Components;
|
||||||
using Content.Shared.Cargo.Events;
|
using Content.Shared.Cargo.Events;
|
||||||
using Content.Shared.Cargo.Prototypes;
|
using Content.Shared.Cargo.Prototypes;
|
||||||
using Content.Shared.Database;
|
using Content.Shared.Database;
|
||||||
|
using Content.Shared.Interaction;
|
||||||
using Robust.Shared.Map;
|
using Robust.Shared.Map;
|
||||||
using Robust.Shared.Player;
|
using Robust.Shared.Player;
|
||||||
using Robust.Shared.Prototypes;
|
using Robust.Shared.Prototypes;
|
||||||
@@ -35,9 +37,30 @@ namespace Content.Server.Cargo.Systems
|
|||||||
SubscribeLocalEvent<CargoOrderConsoleComponent, CargoConsoleApproveOrderMessage>(OnApproveOrderMessage);
|
SubscribeLocalEvent<CargoOrderConsoleComponent, CargoConsoleApproveOrderMessage>(OnApproveOrderMessage);
|
||||||
SubscribeLocalEvent<CargoOrderConsoleComponent, BoundUIOpenedEvent>(OnOrderUIOpened);
|
SubscribeLocalEvent<CargoOrderConsoleComponent, BoundUIOpenedEvent>(OnOrderUIOpened);
|
||||||
SubscribeLocalEvent<CargoOrderConsoleComponent, ComponentInit>(OnInit);
|
SubscribeLocalEvent<CargoOrderConsoleComponent, ComponentInit>(OnInit);
|
||||||
|
SubscribeLocalEvent<CargoOrderConsoleComponent, InteractUsingEvent>(OnInteractUsing);
|
||||||
Reset();
|
Reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnInteractUsing(EntityUid uid, CargoOrderConsoleComponent component, ref InteractUsingEvent args)
|
||||||
|
{
|
||||||
|
if (!HasComp<CashComponent>(args.Used))
|
||||||
|
return;
|
||||||
|
|
||||||
|
var price = _pricing.GetPrice(args.Used);
|
||||||
|
|
||||||
|
if (price == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var stationUid = _station.GetOwningStation(args.Used);
|
||||||
|
|
||||||
|
if (!TryComp(stationUid, out StationBankAccountComponent? bank))
|
||||||
|
return;
|
||||||
|
|
||||||
|
_audio.PlayPvs(component.ConfirmSound, uid);
|
||||||
|
UpdateBankAccount(stationUid.Value, bank, (int) price);
|
||||||
|
QueueDel(args.Used);
|
||||||
|
}
|
||||||
|
|
||||||
private void OnInit(EntityUid uid, CargoOrderConsoleComponent orderConsole, ComponentInit args)
|
private void OnInit(EntityUid uid, CargoOrderConsoleComponent orderConsole, ComponentInit args)
|
||||||
{
|
{
|
||||||
var station = _station.GetOwningStation(uid);
|
var station = _station.GetOwningStation(uid);
|
||||||
|
|||||||
12
Content.Shared/Cargo/Components/CashComponent.cs
Normal file
12
Content.Shared/Cargo/Components/CashComponent.cs
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
using Robust.Shared.GameStates;
|
||||||
|
|
||||||
|
namespace Content.Shared.Cargo.Components;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Can be inserted into a <see cref="Content.Server.Cargo.Components.CargoOrderConsoleComponent"/> to increase the station's bank account.
|
||||||
|
/// </summary>
|
||||||
|
[RegisterComponent, NetworkedComponent]
|
||||||
|
public sealed partial class CashComponent : Component
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
@@ -4,6 +4,7 @@
|
|||||||
name: spesos
|
name: spesos
|
||||||
description: You gotta have money.
|
description: You gotta have money.
|
||||||
components:
|
components:
|
||||||
|
- type: Cash
|
||||||
- type: Item
|
- type: Item
|
||||||
shape:
|
shape:
|
||||||
- 0,0,1,0
|
- 0,0,1,0
|
||||||
|
|||||||
Reference in New Issue
Block a user