* Update RobustToolbox * Transition direct type usages * More updates * Fix invalid use of to map * Update RobustToolbox * Fix dropping items * Rename name usages of "GridCoordinates" to "EntityCoordinates" * Revert "Update RobustToolbox" This reverts commit 9f334a17c5908ded0043a63158bb671e4aa3f346. * Revert "Update RobustToolbox" This reverts commit 3a9c8cfa3606fa501aa84407796d2ad920853a09. # Conflicts: # RobustToolbox * Fix cursed IMapGrid method usage. * GridTileLookupTest now uses EntityCoordinates Co-authored-by: Víctor Aguilera Puerto <6766154+Zumorica@users.noreply.github.com> Co-authored-by: Víctor Aguilera Puerto <zddm@outlook.es>
51 lines
2.0 KiB
C#
51 lines
2.0 KiB
C#
using Content.Server.GameObjects.Components.Interactable;
|
|
using Content.Server.Interfaces.GameObjects.Components.Items;
|
|
using Content.Shared.GameObjects.Components.Interactable;
|
|
using Content.Shared.Interfaces.GameObjects.Components;
|
|
using Robust.Server.Interfaces.GameObjects;
|
|
using Robust.Shared.GameObjects;
|
|
using Robust.Shared.GameObjects.Components.Transform;
|
|
using Robust.Shared.Interfaces.Map;
|
|
using Robust.Shared.IoC;
|
|
using Robust.Shared.Localization;
|
|
using System.Threading.Tasks;
|
|
using Content.Shared.Interfaces;
|
|
|
|
namespace Content.Server.GameObjects.Components.Power.AME
|
|
{
|
|
[RegisterComponent]
|
|
[ComponentReference(typeof(IInteractUsing))]
|
|
public class AMEPartComponent : Component, IInteractUsing
|
|
{
|
|
[Dependency] private readonly IMapManager _mapManager = default!;
|
|
[Dependency] private readonly IServerEntityManager _serverEntityManager = default!;
|
|
|
|
public override string Name => "AMEPart";
|
|
|
|
async Task<bool> IInteractUsing.InteractUsing(InteractUsingEventArgs args)
|
|
{
|
|
if (!args.User.TryGetComponent(out IHandsComponent hands))
|
|
{
|
|
Owner.PopupMessage(args.User, Loc.GetString("You have no hands."));
|
|
return true;
|
|
}
|
|
|
|
var activeHandEntity = hands.GetActiveHand.Owner;
|
|
if (activeHandEntity.TryGetComponent<ToolComponent>(out var multitool) && multitool.Qualities == ToolQuality.Multitool)
|
|
{
|
|
|
|
var mapGrid = _mapManager.GetGrid(args.ClickLocation.GetGridId(_serverEntityManager));
|
|
var tile = mapGrid.GetTileRef(args.ClickLocation);
|
|
var snapPos = mapGrid.SnapGridCellFor(args.ClickLocation, SnapGridOffset.Center);
|
|
|
|
var ent = _serverEntityManager.SpawnEntity("AMEShielding", mapGrid.GridTileToLocal(snapPos));
|
|
ent.Transform.LocalRotation = Owner.Transform.LocalRotation;
|
|
|
|
Owner.Delete();
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
}
|