| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- using System.Numerics;
- using Content.Shared.NPC.Components;
- using Content.Shared.NPC.Systems;
- using Content.Shared.Whitelist;
- using Robust.Shared.Collections;
- using Robust.Shared.Map;
- using Robust.Shared.Random;
- using NPCImprintingOnSpawnBehaviourComponent = Content.Server.NPC.Components.NPCImprintingOnSpawnBehaviourComponent;
- namespace Content.Server.NPC.Systems;
- public sealed partial class NPCImprintingOnSpawnBehaviourSystem : SharedNPCImprintingOnSpawnBehaviourSystem
- {
- [Dependency] private readonly EntityLookupSystem _lookup = default!;
- [Dependency] private readonly NPCSystem _npc = default!;
- [Dependency] private readonly IRobustRandom _random = default!;
- [Dependency] private readonly EntityWhitelistSystem _whitelistSystem = default!;
- public override void Initialize()
- {
- base.Initialize();
- SubscribeLocalEvent<NPCImprintingOnSpawnBehaviourComponent, MapInitEvent>(OnMapInit);
- }
- private void OnMapInit(Entity<NPCImprintingOnSpawnBehaviourComponent> imprinting, ref MapInitEvent args)
- {
- HashSet<EntityUid> friends = new();
- _lookup.GetEntitiesInRange(imprinting, imprinting.Comp.SpawnFriendsSearchRadius, friends);
- foreach (var friend in friends)
- {
- if (_whitelistSystem.IsWhitelistPassOrNull(imprinting.Comp.Whitelist, friend))
- {
- AddImprintingTarget(imprinting, friend, imprinting.Comp);
- }
- }
- if (imprinting.Comp.Follow && imprinting.Comp.Friends.Count > 0)
- {
- var mommy = _random.Pick(imprinting.Comp.Friends);
- _npc.SetBlackboard(imprinting, NPCBlackboard.FollowTarget, new EntityCoordinates(mommy, Vector2.Zero));
- }
- }
- public void AddImprintingTarget(EntityUid entity, EntityUid friend, NPCImprintingOnSpawnBehaviourComponent component)
- {
- component.Friends.Add(friend);
- var exception = EnsureComp<FactionExceptionComponent>(entity);
- exception.Ignored.Add(friend);
- }
- }
|