Files
wwdpublic/Content.Server/_Goobstation/Blob/Systems/BlobResourceSystem.cs
Kyoth25f ed2301f840 Port Blob (#2441)
Ports Blob from https://github.com/Goob-Station/Goob-Station/pull/975
that was ported from https://github.com/Rxup/space-station-14.

Credit to VigersRay for original code, Roudenn and Rxup for maintaining
and jorgun for the Goob port.

---

- [X] Port https://github.com/Goob-Station/Goob-Station/pull/975;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/1209;
- [X] Port Blob related code from
https://github.com/Goob-Station/Goob-Station/pull/1262;
- [X] Port Blob related code from
https://github.com/Goob-Station/Goob-Station/pull/1340;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/1408;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/1419;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/1440;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/1817;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/2077;
- [ ] ~Port https://github.com/Goob-Station/Goob-Station/pull/1916~;
- [ ] ~Port https://github.com/Goob-Station/Goob-Station/pull/1917~;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/2077;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/2092;
- [X] Port https://github.com/Goob-Station/Goob-Station/pull/2546;
- [X] Port https://github.com/Rxup/space-station-14/pull/963;
- [X] Port https://github.com/Rxup/space-station-14/pull/998;
- [ ] ~Port https://github.com/Goob-Station/Goob-Station/pull/2563~.

- [X] Enable Blob and Blob gamemode;
- [X] Add `StationGlobConfig` to all stations;
- [X] Use `AnnouncerSystem` in `BlobRuleSystem.cs`;
- [X] Blob language and Hivemind (from
https://github.com/Rxup/space-station-14/pull/176);
- [x] Change CVars location;
- [X] Add media.

---

<details><summary><h1>Media</h1></summary>
<p>
https://youtu.be/-WtMQwRcmrU?si=su3An6RtiCTZg-DV
</p>
</details>

---

🆑 VigersRay, Roudenn, Rxup, vladospupuos, fishbait and Kyoth25f
- add: Added a new antagonist: Blob

---------

Co-authored-by: fishbait <gnesse@gmail.com>
Co-authored-by: Fishbait <Fishbait@git.ml>
Co-authored-by: Aiden <aiden@djkraz.com>
Co-authored-by: beck-thompson <107373427+beck-thompson@users.noreply.github.com>
Co-authored-by: lanse12 <cloudability.ez@gmail.com>
Co-authored-by: BombasterDS <deniskaporoshok@gmail.com>
Co-authored-by: Aviu00 <93730715+Aviu00@users.noreply.github.com>
Co-authored-by: Piras314 <p1r4s@proton.me>
Co-authored-by: shibe <95730644+shibechef@users.noreply.github.com>
Co-authored-by: Ilya246 <57039557+Ilya246@users.noreply.github.com>
Co-authored-by: JohnOakman <sremy2012@hotmail.fr>
Co-authored-by: Fat Engineer Gaming <159075414+Fat-Engineer-Gaming@users.noreply.github.com>
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
Co-authored-by: Rouden <149893554+Roudenn@users.noreply.github.com>
2025-07-12 12:20:25 +10:00

50 lines
1.7 KiB
C#

using Content.Server._Goobstation.Blob.Components;
using Content.Shared._Goobstation.Blob;
using Content.Shared._Goobstation.Blob.Components;
using Content.Shared.FixedPoint;
using Content.Shared.Popups;
namespace Content.Server._Goobstation.Blob.Systems;
public sealed class BlobResourceSystem : EntitySystem
{
[Dependency] private readonly BlobCoreSystem _blobCoreSystem = default!;
[Dependency] private readonly SharedPopupSystem _popup = default!;
private EntityQuery<BlobTileComponent> _blobTile;
private EntityQuery<BlobCoreComponent> _blobCore;
public override void Initialize()
{
base.Initialize();
SubscribeLocalEvent<BlobResourceComponent, BlobSpecialGetPulseEvent>(OnPulsed);
SubscribeLocalEvent<BlobResourceComponent, BlobNodePulseEvent>(OnPulsed);
_blobTile = GetEntityQuery<BlobTileComponent>();
_blobCore = GetEntityQuery<BlobCoreComponent>();
}
private void OnPulsed<T>(EntityUid uid, BlobResourceComponent component, T args)
{
if (!_blobTile.TryComp(uid, out var blobTileComponent) || blobTileComponent.Core == null)
return;
if (!_blobCore.TryComp(blobTileComponent.Core, out var blobCoreComponent) ||
blobCoreComponent.Observer == null)
return;
var points = component.PointsPerPulsed;
if (blobCoreComponent.CurrentChem == BlobChemType.RegenerativeMateria)
{
points += 1;
}
_popup.PopupEntity(Loc.GetString("blob-get-resource", ("point", points)),
uid,
blobCoreComponent.Observer.Value,
PopupType.Large);
_blobCoreSystem.ChangeBlobPoint(blobTileComponent.Core.Value, points);
}
}