| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- using Content.Server.Power.Components;
- using Content.Server.Power.EntitySystems;
- using Content.Server.Power.Events;
- using Content.Shared.Chemistry.EntitySystems;
- using Content.Shared.Damage.Events;
- using Content.Shared.Examine;
- using Content.Shared.Item;
- using Content.Shared.Item.ItemToggle;
- using Content.Shared.Item.ItemToggle.Components;
- using Content.Shared.Popups;
- using Content.Shared.Stunnable;
- namespace Content.Server.Stunnable.Systems
- {
- public sealed class StunbatonSystem : SharedStunbatonSystem
- {
- [Dependency] private readonly SharedItemSystem _item = default!;
- [Dependency] private readonly RiggableSystem _riggableSystem = default!;
- [Dependency] private readonly SharedPopupSystem _popup = default!;
- [Dependency] private readonly BatterySystem _battery = default!;
- [Dependency] private readonly ItemToggleSystem _itemToggle = default!;
- public override void Initialize()
- {
- base.Initialize();
- SubscribeLocalEvent<StunbatonComponent, ExaminedEvent>(OnExamined);
- SubscribeLocalEvent<StunbatonComponent, SolutionContainerChangedEvent>(OnSolutionChange);
- SubscribeLocalEvent<StunbatonComponent, StaminaDamageOnHitAttemptEvent>(OnStaminaHitAttempt);
- SubscribeLocalEvent<StunbatonComponent, ItemToggleActivateAttemptEvent>(TryTurnOn);
- SubscribeLocalEvent<StunbatonComponent, ItemToggledEvent>(ToggleDone);
- SubscribeLocalEvent<StunbatonComponent, ChargeChangedEvent>(OnChargeChanged);
- }
- private void OnStaminaHitAttempt(Entity<StunbatonComponent> entity, ref StaminaDamageOnHitAttemptEvent args)
- {
- if (!_itemToggle.IsActivated(entity.Owner) ||
- !TryComp<BatteryComponent>(entity.Owner, out var battery) || !_battery.TryUseCharge(entity.Owner, entity.Comp.EnergyPerUse, battery))
- {
- args.Cancelled = true;
- }
- }
- private void OnExamined(Entity<StunbatonComponent> entity, ref ExaminedEvent args)
- {
- var onMsg = _itemToggle.IsActivated(entity.Owner)
- ? Loc.GetString("comp-stunbaton-examined-on")
- : Loc.GetString("comp-stunbaton-examined-off");
- args.PushMarkup(onMsg);
- if (TryComp<BatteryComponent>(entity.Owner, out var battery))
- {
- var count = (int) (battery.CurrentCharge / entity.Comp.EnergyPerUse);
- args.PushMarkup(Loc.GetString("melee-battery-examine", ("color", "yellow"), ("count", count)));
- }
- }
- private void ToggleDone(Entity<StunbatonComponent> entity, ref ItemToggledEvent args)
- {
- _item.SetHeldPrefix(entity.Owner, args.Activated ? "on" : "off");
- }
- private void TryTurnOn(Entity<StunbatonComponent> entity, ref ItemToggleActivateAttemptEvent args)
- {
- if (!TryComp<BatteryComponent>(entity, out var battery) || battery.CurrentCharge < entity.Comp.EnergyPerUse)
- {
- args.Cancelled = true;
- if (args.User != null)
- {
- _popup.PopupEntity(Loc.GetString("stunbaton-component-low-charge"), (EntityUid) args.User, (EntityUid) args.User);
- }
- return;
- }
- if (TryComp<RiggableComponent>(entity, out var rig) && rig.IsRigged)
- {
- _riggableSystem.Explode(entity.Owner, battery, args.User);
- }
- }
- // https://github.com/space-wizards/space-station-14/pull/17288#discussion_r1241213341
- private void OnSolutionChange(Entity<StunbatonComponent> entity, ref SolutionContainerChangedEvent args)
- {
- // Explode if baton is activated and rigged.
- if (!TryComp<RiggableComponent>(entity, out var riggable) ||
- !TryComp<BatteryComponent>(entity, out var battery))
- return;
- if (_itemToggle.IsActivated(entity.Owner) && riggable.IsRigged)
- _riggableSystem.Explode(entity.Owner, battery);
- }
- private void SendPowerPulse(EntityUid target, EntityUid? user, EntityUid used)
- {
- RaiseLocalEvent(target, new PowerPulseEvent()
- {
- Used = used,
- User = user
- });
- }
- private void OnChargeChanged(Entity<StunbatonComponent> entity, ref ChargeChangedEvent args)
- {
- if (TryComp<BatteryComponent>(entity.Owner, out var battery) &&
- battery.CurrentCharge < entity.Comp.EnergyPerUse)
- {
- _itemToggle.TryDeactivate(entity.Owner, predicted: false);
- }
- }
- }
- }
|