Fix lasso buckle (#1246)

Co-authored-by: Pieter-Jan Briers <pieterjan.briers+git@gmail.com>
This commit is contained in:
DrSmugleaf
2020-07-02 23:36:06 +02:00
committed by GitHub
parent bc24a852f9
commit 0a8a383019
9 changed files with 86 additions and 30 deletions

View File

@@ -10,7 +10,6 @@ using Content.Shared.GameObjects.EntitySystems;
using JetBrains.Annotations;
using Robust.Server.GameObjects;
using Robust.Server.GameObjects.EntitySystems;
using Robust.Shared.Audio;
using Robust.Shared.GameObjects;
using Robust.Shared.Interfaces.GameObjects;
using Robust.Shared.IoC;
@@ -22,17 +21,29 @@ using Robust.Shared.ViewVariables;
namespace Content.Server.GameObjects.Components.Mobs
{
[RegisterComponent]
public class BuckleComponent : SharedBuckleComponent, IActionBlocker, IInteractHand, IEffectBlocker
public class BuckleComponent : SharedBuckleComponent, IInteractHand
{
#pragma warning disable 649
[Dependency] private readonly IEntitySystemManager _entitySystem;
[Dependency] private readonly IServerNotifyManager _notifyManager;
#pragma warning restore 649
[CanBeNull] private StrapComponent _buckledTo;
private int _size;
[ViewVariables, CanBeNull]
public StrapComponent BuckledTo { get; private set; }
public StrapComponent BuckledTo
{
get => _buckledTo;
private set
{
_buckledTo = value;
Dirty();
}
}
[ViewVariables]
protected override bool Buckled => BuckledTo != null;
[ViewVariables]
public int Size => _size;
@@ -42,9 +53,9 @@ namespace Content.Server.GameObjects.Components.Mobs
if (Owner.TryGetComponent(out ServerStatusEffectsComponent status))
{
status.ChangeStatusEffectIcon(StatusEffect.Buckled,
BuckledTo == null
? "/Textures/Mob/UI/Buckle/unbuckled.png"
: "/Textures/Mob/UI/Buckle/buckled.png");
Buckled
? "/Textures/Mob/UI/Buckle/buckled.png"
: "/Textures/Mob/UI/Buckle/unbuckled.png");
}
}
@@ -86,7 +97,7 @@ namespace Content.Server.GameObjects.Components.Mobs
return false;
}
if (BuckledTo != null)
if (Buckled)
{
_notifyManager.PopupMessage(Owner, user,
Loc.GetString(Owner == user
@@ -277,33 +288,22 @@ namespace Content.Server.GameObjects.Components.Mobs
BuckleStatus();
}
public override ComponentState GetComponentState()
{
return new BuckleComponentState(Buckled);
}
bool IInteractHand.InteractHand(InteractHandEventArgs eventArgs)
{
return TryUnbuckle(eventArgs.User);
}
bool IActionBlocker.CanMove()
{
return BuckledTo == null;
}
bool IActionBlocker.CanChangeDirection()
{
return BuckledTo == null;
}
bool IEffectBlocker.CanFall()
{
return BuckledTo == null;
}
[Verb]
private sealed class BuckleVerb : Verb<BuckleComponent>
{
protected override void GetData(IEntity user, BuckleComponent component, VerbData data)
{
if (!ActionBlockerSystem.CanInteract(user) ||
component.BuckledTo == null)
if (!ActionBlockerSystem.CanInteract(user) || !component.Buckled)
{
data.Visibility = VerbVisibility.Invisible;
return;