| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- using Content.Server.Chemistry.Components;
- using Content.Shared.Chemistry.EntitySystems;
- using Content.Shared.Chemistry.Reagent;
- using Content.Shared.NameModifier.EntitySystems;
- using Robust.Shared.Prototypes;
- namespace Content.Server.Chemistry.EntitySystems;
- public sealed class TransformableContainerSystem : EntitySystem
- {
- [Dependency] private readonly IPrototypeManager _prototypeManager = default!;
- [Dependency] private readonly SharedSolutionContainerSystem _solutionsSystem = default!;
- [Dependency] private readonly MetaDataSystem _metadataSystem = default!;
- [Dependency] private readonly NameModifierSystem _nameMod = default!;
- public override void Initialize()
- {
- base.Initialize();
- SubscribeLocalEvent<TransformableContainerComponent, MapInitEvent>(OnMapInit);
- SubscribeLocalEvent<TransformableContainerComponent, SolutionContainerChangedEvent>(OnSolutionChange);
- SubscribeLocalEvent<TransformableContainerComponent, RefreshNameModifiersEvent>(OnRefreshNameModifiers);
- }
- private void OnMapInit(Entity<TransformableContainerComponent> entity, ref MapInitEvent args)
- {
- var meta = MetaData(entity.Owner);
- if (string.IsNullOrEmpty(entity.Comp.InitialDescription))
- {
- entity.Comp.InitialDescription = meta.EntityDescription;
- }
- }
- private void OnSolutionChange(Entity<TransformableContainerComponent> entity, ref SolutionContainerChangedEvent args)
- {
- if (!_solutionsSystem.TryGetFitsInDispenser(entity.Owner, out _, out var solution))
- return;
- //Transform container into initial state when emptied
- if (entity.Comp.CurrentReagent != null && solution.Contents.Count == 0)
- {
- CancelTransformation(entity);
- }
- //the biggest reagent in the solution decides the appearance
- var reagentId = solution.GetPrimaryReagentId();
- //If biggest reagent didn't changed - don't change anything at all
- if (entity.Comp.CurrentReagent != null && entity.Comp.CurrentReagent.ID == reagentId?.Prototype)
- {
- return;
- }
- //Only reagents with spritePath property can change appearance of transformable containers!
- if (!string.IsNullOrWhiteSpace(reagentId?.Prototype)
- && _prototypeManager.TryIndex(reagentId.Value.Prototype, out ReagentPrototype? proto))
- {
- var metadata = MetaData(entity.Owner);
- _metadataSystem.SetEntityDescription(entity.Owner, proto.LocalizedDescription, metadata);
- entity.Comp.CurrentReagent = proto;
- entity.Comp.Transformed = true;
- }
- _nameMod.RefreshNameModifiers(entity.Owner);
- }
- private void OnRefreshNameModifiers(Entity<TransformableContainerComponent> entity, ref RefreshNameModifiersEvent args)
- {
- if (entity.Comp.CurrentReagent is { } currentReagent)
- {
- args.AddModifier("transformable-container-component-glass", priority: -1, ("reagent", currentReagent.LocalizedName));
- }
- }
- private void CancelTransformation(Entity<TransformableContainerComponent> entity)
- {
- entity.Comp.CurrentReagent = null;
- entity.Comp.Transformed = false;
- var metadata = MetaData(entity);
- _nameMod.RefreshNameModifiers(entity.Owner);
- if (!string.IsNullOrEmpty(entity.Comp.InitialDescription))
- {
- _metadataSystem.SetEntityDescription(entity.Owner, entity.Comp.InitialDescription, metadata);
- }
- }
- }
|