[Feat] Mindslave - имплант подчинения (#152)
* tweak: стандартизация названий имплантеров * add: mindslave implant * add: briefing, uplink listing, overlay icons * add: new mindslave overlay icons by JustNemo * remove: ненужный файлик удалён * fix: фикс доставания импланта подчинения
This commit is contained in:
@@ -1,5 +1,4 @@
|
||||
using System.Diagnostics.CodeAnalysis;
|
||||
using System.Linq;
|
||||
using Content.Shared.Containers.ItemSlots;
|
||||
using Content.Shared.DoAfter;
|
||||
using Content.Shared.Examine;
|
||||
@@ -15,24 +14,46 @@ using Robust.Shared.Utility;
|
||||
namespace Content.Shared.Implants;
|
||||
|
||||
//WD EDIT START
|
||||
public class SubdermalImplantInserted
|
||||
public sealed class SubdermalImplantInserted
|
||||
{
|
||||
public EntityUid Entity;
|
||||
/// <summary>
|
||||
/// Entity who implants
|
||||
/// </summary>
|
||||
public EntityUid User;
|
||||
|
||||
/// <summary>
|
||||
/// Entity being implanted
|
||||
/// </summary>
|
||||
public EntityUid Target;
|
||||
|
||||
public SubdermalImplantComponent Component;
|
||||
public SubdermalImplantInserted(EntityUid entity, SubdermalImplantComponent component)
|
||||
|
||||
public SubdermalImplantInserted(EntityUid user, EntityUid target, SubdermalImplantComponent component)
|
||||
{
|
||||
Entity = entity;
|
||||
User = user;
|
||||
Target = target;
|
||||
Component = component;
|
||||
}
|
||||
}
|
||||
|
||||
public class SubdermalImplantRemoved
|
||||
public sealed class SubdermalImplantRemoved
|
||||
{
|
||||
public EntityUid Entity;
|
||||
/// <summary>
|
||||
/// Entity who removes implant
|
||||
/// </summary>
|
||||
public EntityUid User;
|
||||
|
||||
/// <summary>
|
||||
/// Entity which implant is removing
|
||||
/// </summary>
|
||||
public EntityUid Target;
|
||||
|
||||
public SubdermalImplantComponent Component;
|
||||
public SubdermalImplantRemoved(EntityUid entity, SubdermalImplantComponent component)
|
||||
|
||||
public SubdermalImplantRemoved(EntityUid user, EntityUid target, SubdermalImplantComponent component)
|
||||
{
|
||||
Entity = entity;
|
||||
User = user;
|
||||
Target = target;
|
||||
Component = component;
|
||||
}
|
||||
}
|
||||
@@ -90,10 +111,11 @@ public abstract class SharedImplanterSystem : EntitySystem
|
||||
|
||||
if (component.ImplanterSlot.ContainerSlot != null)
|
||||
_container.Remove(implant.Value, component.ImplanterSlot.ContainerSlot);
|
||||
|
||||
implantComp.ImplantedEntity = target;
|
||||
implantContainer.OccludesLight = false;
|
||||
_container.Insert(implant.Value, implantContainer);
|
||||
RaiseLocalEvent(new SubdermalImplantInserted(implantComp.ImplantedEntity!.Value, implantComp)); //WD EDIT
|
||||
RaiseLocalEvent(implant.Value, new SubdermalImplantInserted(user, target, implantComp)); //WD EDIT
|
||||
|
||||
if (component.CurrentMode == ImplanterToggleMode.Inject && !component.ImplantOnly)
|
||||
DrawMode(implanter, component);
|
||||
@@ -103,7 +125,7 @@ public abstract class SharedImplanterSystem : EntitySystem
|
||||
var ev = new TransferDnaEvent { Donor = target, Recipient = implanter };
|
||||
RaiseLocalEvent(target, ref ev);
|
||||
|
||||
Dirty(component);
|
||||
Dirty(implanter, component);
|
||||
}
|
||||
|
||||
public bool CanImplant(
|
||||
@@ -146,45 +168,47 @@ public abstract class SharedImplanterSystem : EntitySystem
|
||||
|
||||
var permanentFound = false;
|
||||
|
||||
if (_container.TryGetContainer(target, ImplanterComponent.ImplantSlotId, out var implantContainer))
|
||||
if (!_container.TryGetContainer(target, ImplanterComponent.ImplantSlotId, out var implantContainer))
|
||||
return;
|
||||
|
||||
var implantCompQuery = GetEntityQuery<SubdermalImplantComponent>();
|
||||
|
||||
foreach (var implant in implantContainer.ContainedEntities)
|
||||
{
|
||||
var implantCompQuery = GetEntityQuery<SubdermalImplantComponent>();
|
||||
if (!implantCompQuery.TryGetComponent(implant, out var implantComp))
|
||||
continue;
|
||||
|
||||
foreach (var implant in implantContainer.ContainedEntities)
|
||||
//Don't remove a permanent implant and look for the next that can be drawn
|
||||
if (!_container.CanRemove(implant, implantContainer))
|
||||
{
|
||||
if (!implantCompQuery.TryGetComponent(implant, out var implantComp))
|
||||
continue;
|
||||
var implantName = Identity.Entity(implant, EntityManager);
|
||||
var targetName = Identity.Entity(target, EntityManager);
|
||||
var failedPermanentMessage = Loc.GetString("implanter-draw-failed-permanent",
|
||||
("implant", implantName), ("target", targetName));
|
||||
|
||||
//Don't remove a permanent implant and look for the next that can be drawn
|
||||
if (!_container.CanRemove(implant, implantContainer))
|
||||
{
|
||||
var implantName = Identity.Entity(implant, EntityManager);
|
||||
var targetName = Identity.Entity(target, EntityManager);
|
||||
var failedPermanentMessage = Loc.GetString("implanter-draw-failed-permanent",
|
||||
("implant", implantName), ("target", targetName));
|
||||
_popup.PopupEntity(failedPermanentMessage, target, user);
|
||||
permanentFound = implantComp.Permanent;
|
||||
continue;
|
||||
}
|
||||
|
||||
_container.Remove(implant, implantContainer);
|
||||
RaiseLocalEvent(new SubdermalImplantRemoved(implantComp.ImplantedEntity!.Value, implantComp)); // WD EDIT
|
||||
implantComp.ImplantedEntity = null;
|
||||
_container.Insert(implant, implanterContainer);
|
||||
_popup.PopupEntity(failedPermanentMessage, target, user);
|
||||
permanentFound = implantComp.Permanent;
|
||||
|
||||
var ev = new TransferDnaEvent { Donor = target, Recipient = implanter };
|
||||
RaiseLocalEvent(target, ref ev);
|
||||
|
||||
//Break so only one implant is drawn
|
||||
break;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (component.CurrentMode == ImplanterToggleMode.Draw && !component.ImplantOnly && !permanentFound)
|
||||
ImplantMode(implanter, component);
|
||||
RaiseLocalEvent(implant, new SubdermalImplantRemoved(user, target, implantComp)); // WD EDIT
|
||||
_container.Remove(implant, implantContainer);
|
||||
|
||||
Dirty(component);
|
||||
implantComp.ImplantedEntity = null;
|
||||
_container.Insert(implant, implanterContainer);
|
||||
permanentFound = implantComp.Permanent;
|
||||
|
||||
var ev = new TransferDnaEvent { Donor = target, Recipient = implanter };
|
||||
RaiseLocalEvent(target, ref ev);
|
||||
|
||||
//Break so only one implant is drawn
|
||||
break;
|
||||
}
|
||||
|
||||
if (component.CurrentMode == ImplanterToggleMode.Draw && !component.ImplantOnly && !permanentFound)
|
||||
ImplantMode(implanter, component);
|
||||
|
||||
Dirty(implanter, component);
|
||||
}
|
||||
|
||||
private void ImplantMode(EntityUid uid, ImplanterComponent component)
|
||||
@@ -204,26 +228,24 @@ public abstract class SharedImplanterSystem : EntitySystem
|
||||
if (!TryComp<AppearanceComponent>(uid, out var appearance))
|
||||
return;
|
||||
|
||||
bool implantFound;
|
||||
var implantFound = component.ImplanterSlot.HasItem;
|
||||
|
||||
if (component.ImplanterSlot.HasItem)
|
||||
implantFound = true;
|
||||
|
||||
else
|
||||
implantFound = false;
|
||||
|
||||
if (component.CurrentMode == ImplanterToggleMode.Inject && !component.ImplantOnly)
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
|
||||
else if (component.CurrentMode == ImplanterToggleMode.Inject && component.ImplantOnly)
|
||||
switch (component.CurrentMode)
|
||||
{
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
_appearance.SetData(uid, ImplanterImplantOnlyVisuals.ImplantOnly, component.ImplantOnly,
|
||||
appearance);
|
||||
}
|
||||
case ImplanterToggleMode.Inject when !component.ImplantOnly:
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
break;
|
||||
case ImplanterToggleMode.Inject when component.ImplantOnly:
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
_appearance.SetData(uid, ImplanterImplantOnlyVisuals.ImplantOnly, component.ImplantOnly,
|
||||
appearance);
|
||||
|
||||
else
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
break;
|
||||
case ImplanterToggleMode.Draw:
|
||||
default:
|
||||
_appearance.SetData(uid, ImplanterVisuals.Full, implantFound, appearance);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user