BreakOnDamage = true,
BreakOnStun = true,
RaiseOnUser = user == entityToMove,
- RaiseOnTarget = user != entityToMove
+ RaiseOnTarget = user != entityToMove,
+ RaiseOnUsed = false,
};
_doAfterSystem.DoAfter(args, ev);
BreakOnTargetMove = true,
BreakOnUserMove = true,
NeedHand = false,
+ RaiseOnTarget = false,
+ RaiseOnUser = false,
+ RaiseOnUsed = true,
};
_doAfterSystem.DoAfter(doAfterArgs);
var doAfterEventArgs = new DoAfterEventArgs(args.User, component.BatteryRemovalDelay, target: uid, used: args.Target)
{
BreakOnTargetMove = true,
- BreakOnUserMove = true
+ BreakOnUserMove = true,
+ RaiseOnTarget = true,
+ RaiseOnUsed = false,
+ RaiseOnUser = false,
};
_doAfter.DoAfter(doAfterEventArgs, removeBattery);
{
BreakOnUserMove = true,
BreakOnStun = true,
+ RaiseOnTarget = true,
+ RaiseOnUsed = false,
+ RaiseOnUser = false,
};
_doAfter.DoAfter(doAfterEventArgs, mechEntryEvent);
{
BreakOnUserMove = true,
BreakOnTargetMove = true,
- BreakOnStun = true
+ BreakOnStun = true,
+ RaiseOnTarget = true,
+ RaiseOnUsed = false,
+ RaiseOnUser = false,
};
_doAfter.DoAfter(doAfterEventArgs, mechExitEvent);
{
base.Initialize();
SubscribeLocalEvent<ResistLockerComponent, ContainerRelayMovementEntityEvent>(OnRelayMovement);
- SubscribeLocalEvent<ResistLockerComponent, DoAfterEvent>(OnDoAfter);
+ SubscribeLocalEvent<ResistLockerComponent, DoAfterEvent<LockerDoAfterData>>(OnDoAfter);
SubscribeLocalEvent<ResistLockerComponent, EntRemovedFromContainerMessage>(OnRemoved);
}
resistLockerComponent.IsResisting = true;
_popupSystem.PopupEntity(Loc.GetString("resist-locker-component-start-resisting"), user, user, PopupType.Large);
- _doAfterSystem.DoAfter(doAfterEventArgs);
+ _doAfterSystem.DoAfter(doAfterEventArgs, new LockerDoAfterData());
}
private void OnRemoved(EntityUid uid, ResistLockerComponent component, EntRemovedFromContainerMessage args)
component.CancelToken = null;
}
- private void OnDoAfter(EntityUid uid, ResistLockerComponent component, DoAfterEvent args)
+ private void OnDoAfter(EntityUid uid, ResistLockerComponent component, DoAfterEvent<LockerDoAfterData> args)
{
if (args.Cancelled)
{
component.CancelToken = null;
args.Handled = true;
}
+
+ private struct LockerDoAfterData
+ {
+ }
}
private void OnAfterInteract(EntityUid uid, FloorTileComponent component, AfterInteractEvent args)
{
- if (!args.CanReach)
+ if (!args.CanReach || args.Handled)
return;
if (!TryComp<StackComponent>(uid, out var stack))
continue;
PlaceAt(mapGrid, location, currentTileDefinition.TileId, component.PlaceTileSound);
+ args.Handled = true;
+ return;
}
}
else if (HasBaseTurf(currentTileDefinition, ContentTileDefinition.SpaceID))
gridXform.WorldPosition = locationMap.Position;
location = new EntityCoordinates(mapGrid.Owner, Vector2.Zero);
PlaceAt(mapGrid, location, _tileDefinitionManager[component.OutputTiles[0]].TileId, component.PlaceTileSound, mapGrid.TileSize / 2f);
+ args.Handled = true;
+ return;
}
}
}
if (!CanWeld(uid, tool, user, component))
return false;
- var toolEvData = new ToolEventData(new WeldFinishedEvent(user, tool), targetEntity: uid);
+ var toolEvData = new ToolEventData(new WeldFinishedEvent(user, tool), cancelledEv: new WeldCancelledEvent(),targetEntity: uid);
component.BeingWelded = _toolSystem.UseTool(tool, user, uid, component.WeldingTime.Seconds, new[] { component.WeldingQuality }, toolEvData, fuel: component.FuelConsumption);
// Log attempt