fishops nerf real (#25148)
* refactor ops * inherit dna and fiber when fish hydrated * :trollface: * kid named finger * :trollface: * move rehydrating to shared :trollface: * nobody noticed the popup being missing all this time * method ops --------- Co-authored-by: deltanedas <@deltanedas:kde.org>
This commit is contained in:
@@ -1,39 +0,0 @@
|
||||
using Content.Server.Chemistry.EntitySystems;
|
||||
using Content.Shared.Chemistry.Reagent;
|
||||
using Content.Shared.FixedPoint;
|
||||
using Robust.Shared.Prototypes;
|
||||
using Robust.Shared.Serialization.TypeSerializers.Implementations.Custom.Prototype;
|
||||
|
||||
namespace Content.Server.Chemistry.Components;
|
||||
|
||||
/// <summary>
|
||||
/// Basically, monkey cubes.
|
||||
/// But specifically, this component deletes the entity and spawns in a new entity when the entity is exposed to a certain amount of a given reagent.
|
||||
/// </summary>
|
||||
[RegisterComponent, Access(typeof(RehydratableSystem))]
|
||||
public sealed partial class RehydratableComponent : Component
|
||||
{
|
||||
/// <summary>
|
||||
/// The reagent that must be present to count as hydrated.
|
||||
/// </summary>
|
||||
[DataField("catalyst", customTypeSerializer: typeof(PrototypeIdSerializer<ReagentPrototype>)), ViewVariables(VVAccess.ReadWrite)]
|
||||
public string CatalystPrototype = "Water";
|
||||
|
||||
/// <summary>
|
||||
/// The minimum amount of catalyst that must be present to be hydrated.
|
||||
/// </summary>
|
||||
[DataField("catalystMinimum"), ViewVariables(VVAccess.ReadWrite)]
|
||||
public FixedPoint2 CatalystMinimum = FixedPoint2.Zero;
|
||||
|
||||
/// <summary>
|
||||
/// The entity to create when hydrated.
|
||||
/// </summary>
|
||||
[DataField("possibleSpawns"), ViewVariables(VVAccess.ReadWrite)]
|
||||
public List<string> PossibleSpawns = new();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Raised on the rehydrated entity with target being the new entity it became.
|
||||
/// </summary>
|
||||
[ByRefEvent]
|
||||
public readonly record struct GotRehydratedEvent(EntityUid Target);
|
||||
@@ -1,51 +0,0 @@
|
||||
using Content.Server.Chemistry.Components;
|
||||
using Content.Server.Chemistry.Containers.EntitySystems;
|
||||
using Content.Shared.Chemistry.EntitySystems;
|
||||
using Content.Shared.FixedPoint;
|
||||
using Content.Shared.Popups;
|
||||
using Robust.Shared.Random;
|
||||
|
||||
namespace Content.Server.Chemistry.EntitySystems;
|
||||
|
||||
public sealed class RehydratableSystem : EntitySystem
|
||||
{
|
||||
[Dependency] private readonly SharedPopupSystem _popups = default!;
|
||||
[Dependency] private readonly SolutionContainerSystem _solutions = default!;
|
||||
[Dependency] private readonly IRobustRandom _random = default!;
|
||||
|
||||
public override void Initialize()
|
||||
{
|
||||
base.Initialize();
|
||||
|
||||
SubscribeLocalEvent<RehydratableComponent, SolutionContainerChangedEvent>(OnSolutionChange);
|
||||
}
|
||||
|
||||
private void OnSolutionChange(Entity<RehydratableComponent> entity, ref SolutionContainerChangedEvent args)
|
||||
{
|
||||
var quantity = _solutions.GetTotalPrototypeQuantity(entity, entity.Comp.CatalystPrototype);
|
||||
if (quantity != FixedPoint2.Zero && quantity >= entity.Comp.CatalystMinimum)
|
||||
{
|
||||
Expand(entity);
|
||||
}
|
||||
}
|
||||
|
||||
// Try not to make this public if you can help it.
|
||||
private void Expand(Entity<RehydratableComponent> entity)
|
||||
{
|
||||
var (uid, comp) = entity;
|
||||
|
||||
_popups.PopupEntity(Loc.GetString("rehydratable-component-expands-message", ("owner", uid)), uid);
|
||||
|
||||
var randomMob = _random.Pick(comp.PossibleSpawns);
|
||||
|
||||
var target = Spawn(randomMob, Transform(uid).Coordinates);
|
||||
|
||||
Transform(target).AttachToGridOrMap();
|
||||
var ev = new GotRehydratedEvent(target);
|
||||
RaiseLocalEvent(uid, ref ev);
|
||||
|
||||
// prevent double hydration while queued
|
||||
RemComp<RehydratableComponent>(uid);
|
||||
QueueDel(uid);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user