| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- using Content.Server.Labels.Components;
- using Content.Shared.Containers.ItemSlots;
- using Content.Shared.Examine;
- using Content.Shared.Labels;
- using Content.Shared.Labels.Components;
- using Content.Shared.Labels.EntitySystems;
- using Content.Shared.Paper;
- using JetBrains.Annotations;
- using Robust.Shared.Containers;
- namespace Content.Server.Labels
- {
- /// <summary>
- /// A system that lets players see the contents of a label on an object.
- /// </summary>
- [UsedImplicitly]
- public sealed class LabelSystem : SharedLabelSystem
- {
- [Dependency] private readonly ItemSlotsSystem _itemSlotsSystem = default!;
- [Dependency] private readonly SharedAppearanceSystem _appearance = default!;
- public const string ContainerName = "paper_label";
- public override void Initialize()
- {
- base.Initialize();
- SubscribeLocalEvent<PaperLabelComponent, ComponentInit>(OnComponentInit);
- SubscribeLocalEvent<PaperLabelComponent, ComponentRemove>(OnComponentRemove);
- SubscribeLocalEvent<PaperLabelComponent, EntInsertedIntoContainerMessage>(OnContainerModified);
- SubscribeLocalEvent<PaperLabelComponent, EntRemovedFromContainerMessage>(OnContainerModified);
- SubscribeLocalEvent<PaperLabelComponent, ExaminedEvent>(OnExamined);
- }
- /// <summary>
- /// Apply or remove a label on an entity.
- /// </summary>
- /// <param name="uid">EntityUid to change label on</param>
- /// <param name="text">intended label text (null to remove)</param>
- /// <param name="label">label component for resolve</param>
- /// <param name="metadata">metadata component for resolve</param>
- public override void Label(EntityUid uid, string? text, MetaDataComponent? metadata = null, LabelComponent? label = null)
- {
- if (!Resolve(uid, ref label, false))
- label = EnsureComp<LabelComponent>(uid);
- label.CurrentLabel = text;
- NameMod.RefreshNameModifiers(uid);
- Dirty(uid, label);
- }
- private void OnComponentInit(EntityUid uid, PaperLabelComponent component, ComponentInit args)
- {
- _itemSlotsSystem.AddItemSlot(uid, ContainerName, component.LabelSlot);
- UpdateAppearance((uid, component));
- }
- private void OnComponentRemove(EntityUid uid, PaperLabelComponent component, ComponentRemove args)
- {
- _itemSlotsSystem.RemoveItemSlot(uid, component.LabelSlot);
- }
- private void OnExamined(EntityUid uid, PaperLabelComponent comp, ExaminedEvent args)
- {
- if (comp.LabelSlot.Item is not {Valid: true} item)
- return;
- using (args.PushGroup(nameof(PaperLabelComponent)))
- {
- if (!args.IsInDetailsRange)
- {
- args.PushMarkup(Loc.GetString("comp-paper-label-has-label-cant-read"));
- return;
- }
- if (!EntityManager.TryGetComponent(item, out PaperComponent? paper))
- // Assuming yaml has the correct entity whitelist, this should not happen.
- return;
- if (string.IsNullOrWhiteSpace(paper.Content))
- {
- args.PushMarkup(Loc.GetString("comp-paper-label-has-label-blank"));
- return;
- }
- args.PushMarkup(Loc.GetString("comp-paper-label-has-label"));
- var text = paper.Content;
- args.PushMarkup(text.TrimEnd());
- }
- }
- private void OnContainerModified(EntityUid uid, PaperLabelComponent label, ContainerModifiedMessage args)
- {
- if (!label.Initialized) return;
- if (args.Container.ID != label.LabelSlot.ID)
- return;
- UpdateAppearance((uid, label));
- }
- private void UpdateAppearance(Entity<PaperLabelComponent, AppearanceComponent?> ent)
- {
- if (!Resolve(ent, ref ent.Comp2, false))
- return;
- var slot = ent.Comp1.LabelSlot;
- _appearance.SetData(ent, PaperLabelVisuals.HasLabel, slot.HasItem, ent.Comp2);
- if (TryComp<PaperLabelTypeComponent>(slot.Item, out var type))
- _appearance.SetData(ent, PaperLabelVisuals.LabelType, type.PaperType, ent.Comp2);
- }
- }
- }
|