Item strip delay dependant on slot. (#8900)
This commit is contained in:
@@ -9,13 +9,21 @@ namespace Content.Server.Strip
|
||||
[Access(typeof(StrippableSystem))]
|
||||
public sealed class StrippableComponent : SharedStrippableComponent
|
||||
{
|
||||
/// <summary>
|
||||
/// How long it takes to open the strip menu.
|
||||
/// This should be relatively short so it's not a hassle
|
||||
/// but so it also doesn't open immediately during melee combat
|
||||
/// </summary>
|
||||
[ViewVariables]
|
||||
[DataField("openDelay")]
|
||||
public float OpenDelay = 4f;
|
||||
public float OpenDelay = 1f;
|
||||
|
||||
/// <summary>
|
||||
/// The strip delay for hands.
|
||||
/// </summary>
|
||||
[ViewVariables]
|
||||
[DataField("delay")]
|
||||
public float StripDelay = 2f;
|
||||
[DataField("handDelay")]
|
||||
public float HandStripDelay = 3f;
|
||||
|
||||
public override bool Drop(DragDropEvent args)
|
||||
{
|
||||
|
||||
@@ -274,7 +274,13 @@ namespace Content.Server.Strip
|
||||
return true;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.StripDelay, CancellationToken.None, component.Owner)
|
||||
if (!_inventorySystem.TryGetSlot(component.Owner, slot, out var slotDef))
|
||||
{
|
||||
Logger.Error($"{ToPrettyString(user)} attempted to place an item in a non-existent inventory slot ({slot}) on {ToPrettyString(component.Owner)}");
|
||||
return;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, slotDef.StripTime, CancellationToken.None, component.Owner)
|
||||
{
|
||||
ExtraCheck = Check,
|
||||
BreakOnStun = true,
|
||||
@@ -328,7 +334,7 @@ namespace Content.Server.Strip
|
||||
return true;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.StripDelay, CancellationToken.None, component.Owner)
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.HandStripDelay, CancellationToken.None, component.Owner)
|
||||
{
|
||||
ExtraCheck = Check,
|
||||
BreakOnStun = true,
|
||||
@@ -374,7 +380,13 @@ namespace Content.Server.Strip
|
||||
return true;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.StripDelay, CancellationToken.None, component.Owner)
|
||||
if (!_inventorySystem.TryGetSlot(component.Owner, slot, out var slotDef))
|
||||
{
|
||||
Logger.Error($"{ToPrettyString(user)} attempted to place an item in a non-existent inventory slot ({slot}) on {ToPrettyString(component.Owner)}");
|
||||
return;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, slotDef.StripTime, CancellationToken.None, component.Owner)
|
||||
{
|
||||
ExtraCheck = Check,
|
||||
BreakOnStun = true,
|
||||
@@ -425,7 +437,7 @@ namespace Content.Server.Strip
|
||||
return true;
|
||||
}
|
||||
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.StripDelay, CancellationToken.None, component.Owner)
|
||||
var doAfterArgs = new DoAfterEventArgs(user, component.HandStripDelay, CancellationToken.None, component.Owner)
|
||||
{
|
||||
ExtraCheck = Check,
|
||||
BreakOnStun = true,
|
||||
|
||||
Reference in New Issue
Block a user