| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- // SPDX-FileCopyrightText: 2024 deltanedas <39013340+deltanedas@users.noreply.github.com>
- // SPDX-FileCopyrightText: 2024 deltanedas <@deltanedas:kde.org>
- // SPDX-FileCopyrightText: 2024 gluesniffler <159397573+gluesniffler@users.noreply.github.com>
- // SPDX-FileCopyrightText: 2025 Aiden <28298836+Aidenkrz@users.noreply.github.com>
- //
- // SPDX-License-Identifier: AGPL-3.0-or-later
- using Content.Shared.Item.ItemToggle.Components;
- using Content.Shared.Popups;
- using Content.Shared.Smoking;
- using Content.Shared.Weapons.Ranged;
- using Content.Shared.Weapons.Ranged.Components;
- using Content.Shared.Weapons.Ranged.Events;
- namespace Content.Shared._Shitmed.Medical.Surgery.Tools;
- /// <summary>
- /// Prevents using esword or welder when off, laser when no charges.
- /// </summary>
- public sealed class SurgeryToolConditionsSystem : EntitySystem
- {
- [Dependency] private readonly SharedPopupSystem _popup = default!;
- public override void Initialize()
- {
- base.Initialize();
- SubscribeLocalEvent<ItemToggleComponent, SurgeryToolUsedEvent>(OnToggleUsed);
- SubscribeLocalEvent<GunComponent, SurgeryToolUsedEvent>(OnGunUsed);
- }
- private void OnToggleUsed(Entity<ItemToggleComponent> ent, ref SurgeryToolUsedEvent args)
- {
- if (ent.Comp.Activated)
- return;
- _popup.PopupEntity(Loc.GetString("surgery-tool-turn-on"), ent, args.User);
- args.Cancelled = true;
- }
- private void OnGunUsed(Entity<GunComponent> ent, ref SurgeryToolUsedEvent args)
- {
- var coords = Transform(args.User).Coordinates;
- var ev = new TakeAmmoEvent(1, new List<(EntityUid? Entity, IShootable Shootable)>(), coords, args.User);
- if (ev.Ammo.Count > 0)
- return;
- _popup.PopupEntity(Loc.GetString("surgery-tool-reload"), ent, args.User);
- args.Cancelled = true;
- }
- }
|