Files
wwdpublic/Content.Server/_White/Examine/ExaminableCharacterSystem.cs
Spatison 54086988e3 Mass clean up (#587)
* mass clean up

(cherry picked from commit 12bb873b02c1ef50e20763542b030452cc0613da)

* Revert "Centrifuge buff (#393)"

This reverts commit 2a59a18230.

(cherry picked from commit 9ee495ab4bb365e1ccd3dc627ecb55114fea6944)

* Shoving merge conflict

* fix rich traitor

* fix test

* yml

* fix test

* fix test

* ohh
2025-06-16 20:35:48 +03:00

113 lines
4.3 KiB
C#

using Content.Server.Chat.Managers;
using Content.Server.IdentityManagement;
using Content.Shared._White.CCVar;
using Content.Shared.Chat;
using Content.Shared.Examine;
using Content.Shared.Inventory;
using Robust.Shared.Configuration;
using Robust.Shared.Player;
namespace Content.Server._White.Examine
{
public sealed class ExaminableCharacterSystem : EntitySystem
{
[Dependency] private readonly InventorySystem _inventorySystem = default!;
[Dependency] private readonly IdentitySystem _identitySystem = default!;
[Dependency] private readonly EntityManager _entityManager = default!;
[Dependency] private readonly IChatManager _chatManager = default!;
[Dependency] private readonly INetConfigurationManager _netConfigManager = default!;
public override void Initialize()
{
SubscribeLocalEvent<ExaminableCharacterComponent, ExaminedEvent>(HandleExamine);
}
private void HandleExamine(EntityUid uid, ExaminableCharacterComponent comp, ExaminedEvent args)
{
var selfaware = (args.Examiner == args.Examined);
var logLines = new List<string>();
string canseeloc = "examine-can-see";
string nameloc = "examine-name";
if (selfaware)
{
canseeloc += "-selfaware";
nameloc += "-selfaware";
}
var identity = _identitySystem.GetEntityIdentity(uid);
var name = Loc.GetString(nameloc, ("name", identity));
logLines.Add($"[color=DarkGray][font size=10]{name}[/font][/color]");
var cansee = Loc.GetString(canseeloc, ("ent", uid));
logLines.Add($"[color=DarkGray][font size=10]{cansee}[/font][/color]");
var slotLabels = new Dictionary<string, string>
{
{ "head", "head-" },
{ "eyes", "eyes-" },
{ "mask", "mask-" },
{ "neck", "neck-" },
{ "ears", "ears-" },
{ "jumpsuit", "jumpsuit-" },
{ "outerClothing", "outer-" },
{ "back", "back-" },
{ "gloves", "gloves-" },
{ "belt", "belt-" },
{ "id", "id-" },
{ "shoes", "shoes-" },
{ "suitstorage", "suitstorage-" }
};
var priority = 13;
foreach (var slotEntry in slotLabels)
{
var slotName = slotEntry.Key;
var slotLabel = slotEntry.Value;
slotLabel += "examine";
if (selfaware)
slotLabel += "-selfaware";
if (!_inventorySystem.TryGetSlotEntity(uid, slotName, out var slotEntity)
|| HasComp<ExaminableCharacterHideIconComponent>(slotEntity.Value)) // WD EDIT
continue;
if (_entityManager.TryGetComponent<MetaDataComponent>(slotEntity, out var metaData))
{
var item = Loc.GetString(slotLabel, ("item", metaData.EntityName), ("ent", uid));
args.PushMarkup($"[font size=10]{item}[/font]", priority);
logLines.Add($"[color=DarkGray][font size=10]{item}[/font][/color]");
priority--;
}
}
if (priority < 13) // If nothing is worn dont show
{
args.PushMarkup($"[font size=10]{cansee}[/font]", 14);
}
else
{
string canseenothingloc = "examine-can-see-nothing";
if (selfaware)
canseenothingloc += "-selfaware";
var canseenothing = Loc.GetString(canseenothingloc, ("ent", uid));
logLines.Add($"[color=DarkGray][font size=10]{canseenothing}[/font][/color]");
}
var combinedLog = string.Join("\n", logLines);
if (TryComp<ActorComponent>(args.Examiner, out var actorComponent))
{
if (_netConfigManager.GetClientCVar(actorComponent.PlayerSession.Channel, WhiteCVars.LogInChat))
_chatManager.ChatMessageToOne(ChatChannel.Emotes, combinedLog, combinedLog, EntityUid.Invalid, false, actorComponent.PlayerSession.Channel, recordReplay: false);
}
}
}
}