2023-05-14 13:15:18 +10:00
|
|
|
using Content.Shared.Damage;
|
|
|
|
|
using Content.Shared.Projectiles;
|
|
|
|
|
using Content.Shared.Weapons.Melee.Events;
|
2023-11-27 22:12:34 +11:00
|
|
|
using Robust.Shared.Audio;
|
|
|
|
|
using Robust.Shared.Audio.Systems;
|
2023-06-01 15:36:37 +10:00
|
|
|
using Robust.Shared.Network;
|
2023-05-14 13:15:18 +10:00
|
|
|
using Robust.Shared.Physics.Events;
|
|
|
|
|
using Robust.Shared.Timing;
|
|
|
|
|
|
|
|
|
|
namespace Content.Shared.Weapons.Marker;
|
|
|
|
|
|
|
|
|
|
public abstract class SharedDamageMarkerSystem : EntitySystem
|
|
|
|
|
{
|
|
|
|
|
[Dependency] private readonly IGameTiming _timing = default!;
|
2023-06-01 15:36:37 +10:00
|
|
|
[Dependency] private readonly INetManager _netManager = default!;
|
2023-05-14 13:15:18 +10:00
|
|
|
[Dependency] private readonly SharedAudioSystem _audio = default!;
|
2023-06-28 12:04:39 +10:00
|
|
|
[Dependency] private readonly DamageableSystem _damageable = default!;
|
2023-05-14 13:15:18 +10:00
|
|
|
|
|
|
|
|
public override void Initialize()
|
|
|
|
|
{
|
|
|
|
|
base.Initialize();
|
|
|
|
|
SubscribeLocalEvent<DamageMarkerOnCollideComponent, StartCollideEvent>(OnMarkerCollide);
|
|
|
|
|
SubscribeLocalEvent<DamageMarkerComponent, AttackedEvent>(OnMarkerAttacked);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void OnMarkerAttacked(EntityUid uid, DamageMarkerComponent component, AttackedEvent args)
|
|
|
|
|
{
|
|
|
|
|
if (component.Marker != args.Used)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
args.BonusDamage += component.Damage;
|
|
|
|
|
RemCompDeferred<DamageMarkerComponent>(uid);
|
|
|
|
|
_audio.PlayPredicted(component.Sound, uid, args.User);
|
2023-06-28 12:04:39 +10:00
|
|
|
|
|
|
|
|
if (TryComp<LeechOnMarkerComponent>(args.Used, out var leech))
|
|
|
|
|
{
|
|
|
|
|
_damageable.TryChangeDamage(args.User, leech.Leech, true, false, origin: args.Used);
|
|
|
|
|
}
|
2023-05-14 13:15:18 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void Update(float frameTime)
|
|
|
|
|
{
|
|
|
|
|
base.Update(frameTime);
|
|
|
|
|
|
|
|
|
|
var query = EntityQueryEnumerator<DamageMarkerComponent>();
|
|
|
|
|
|
|
|
|
|
while (query.MoveNext(out var uid, out var comp))
|
|
|
|
|
{
|
|
|
|
|
if (comp.EndTime > _timing.CurTime)
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
RemCompDeferred<DamageMarkerComponent>(uid);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void OnMarkerCollide(EntityUid uid, DamageMarkerOnCollideComponent component, ref StartCollideEvent args)
|
|
|
|
|
{
|
|
|
|
|
if (!args.OtherFixture.Hard ||
|
2023-08-23 18:55:58 +10:00
|
|
|
args.OurFixtureId != SharedProjectileSystem.ProjectileFixture ||
|
2023-05-14 13:15:18 +10:00
|
|
|
component.Amount <= 0 ||
|
|
|
|
|
component.Whitelist?.IsValid(args.OtherEntity, EntityManager) == false ||
|
|
|
|
|
!TryComp<ProjectileComponent>(uid, out var projectile) ||
|
2023-09-22 02:45:21 -07:00
|
|
|
projectile.Weapon == null)
|
2023-05-14 13:15:18 +10:00
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Markers are exclusive, deal with it.
|
|
|
|
|
var marker = EnsureComp<DamageMarkerComponent>(args.OtherEntity);
|
|
|
|
|
marker.Damage = new DamageSpecifier(component.Damage);
|
2023-09-22 02:45:21 -07:00
|
|
|
marker.Marker = projectile.Weapon.Value;
|
2023-05-14 13:15:18 +10:00
|
|
|
marker.EndTime = _timing.CurTime + component.Duration;
|
|
|
|
|
component.Amount--;
|
2024-03-19 23:27:02 -04:00
|
|
|
Dirty(args.OtherEntity, marker);
|
2023-05-14 13:15:18 +10:00
|
|
|
|
2023-06-01 15:36:37 +10:00
|
|
|
if (_netManager.IsServer)
|
2023-05-14 13:15:18 +10:00
|
|
|
{
|
2023-06-01 15:36:37 +10:00
|
|
|
if (component.Amount <= 0)
|
|
|
|
|
{
|
|
|
|
|
QueueDel(uid);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2024-03-19 23:27:02 -04:00
|
|
|
Dirty(uid, component);
|
2023-06-01 15:36:37 +10:00
|
|
|
}
|
2023-05-14 13:15:18 +10:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|