| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- using Content.Server.Power.EntitySystems;
- using Content.Server.Research.Components;
- using Content.Shared.UserInterface;
- using Content.Shared.Access.Components;
- using Content.Shared.Emag.Components;
- using Content.Shared.Emag.Systems;
- using Content.Shared.IdentityManagement;
- using Content.Shared.Research.Components;
- using Content.Shared.Research.Prototypes;
- namespace Content.Server.Research.Systems;
- public sealed partial class ResearchSystem
- {
- [Dependency] private readonly EmagSystem _emag = default!;
- private void InitializeConsole()
- {
- SubscribeLocalEvent<ResearchConsoleComponent, ConsoleUnlockTechnologyMessage>(OnConsoleUnlock);
- SubscribeLocalEvent<ResearchConsoleComponent, BeforeActivatableUIOpenEvent>(OnConsoleBeforeUiOpened);
- SubscribeLocalEvent<ResearchConsoleComponent, ResearchServerPointsChangedEvent>(OnPointsChanged);
- SubscribeLocalEvent<ResearchConsoleComponent, ResearchRegistrationChangedEvent>(OnConsoleRegistrationChanged);
- SubscribeLocalEvent<ResearchConsoleComponent, TechnologyDatabaseModifiedEvent>(OnConsoleDatabaseModified);
- SubscribeLocalEvent<ResearchConsoleComponent, TechnologyDatabaseSynchronizedEvent>(OnConsoleDatabaseSynchronized);
- SubscribeLocalEvent<ResearchConsoleComponent, GotEmaggedEvent>(OnEmagged);
- }
- private void OnConsoleUnlock(EntityUid uid, ResearchConsoleComponent component, ConsoleUnlockTechnologyMessage args)
- {
- var act = args.Actor;
- if (!this.IsPowered(uid, EntityManager))
- return;
- if (!PrototypeManager.TryIndex<TechnologyPrototype>(args.Id, out var technologyPrototype))
- return;
- if (TryComp<AccessReaderComponent>(uid, out var access) && !_accessReader.IsAllowed(act, uid, access))
- {
- _popup.PopupEntity(Loc.GetString("research-console-no-access-popup"), act);
- return;
- }
- if (!UnlockTechnology(uid, args.Id, act))
- return;
- if (!_emag.CheckFlag(uid, EmagType.Interaction))
- {
- var getIdentityEvent = new TryGetIdentityShortInfoEvent(uid, act);
- RaiseLocalEvent(getIdentityEvent);
- var message = Loc.GetString(
- "research-console-unlock-technology-radio-broadcast",
- ("technology", Loc.GetString(technologyPrototype.Name)),
- ("amount", technologyPrototype.Cost),
- ("approver", getIdentityEvent.Title ?? string.Empty)
- );
- _radio.SendRadioMessage(uid, message, component.AnnouncementChannel, uid, escapeMarkup: false);
- }
- SyncClientWithServer(uid);
- UpdateConsoleInterface(uid, component);
- }
- private void OnConsoleBeforeUiOpened(EntityUid uid, ResearchConsoleComponent component, BeforeActivatableUIOpenEvent args)
- {
- SyncClientWithServer(uid);
- }
- private void UpdateConsoleInterface(EntityUid uid, ResearchConsoleComponent? component = null, ResearchClientComponent? clientComponent = null)
- {
- if (!Resolve(uid, ref component, ref clientComponent, false))
- return;
- ResearchConsoleBoundInterfaceState state;
- if (TryGetClientServer(uid, out _, out var serverComponent, clientComponent))
- {
- var points = clientComponent.ConnectedToServer ? serverComponent.Points : 0;
- state = new ResearchConsoleBoundInterfaceState(points);
- }
- else
- {
- state = new ResearchConsoleBoundInterfaceState(default);
- }
- _uiSystem.SetUiState(uid, ResearchConsoleUiKey.Key, state);
- }
- private void OnPointsChanged(EntityUid uid, ResearchConsoleComponent component, ref ResearchServerPointsChangedEvent args)
- {
- if (!_uiSystem.IsUiOpen(uid, ResearchConsoleUiKey.Key))
- return;
- UpdateConsoleInterface(uid, component);
- }
- private void OnConsoleRegistrationChanged(EntityUid uid, ResearchConsoleComponent component, ref ResearchRegistrationChangedEvent args)
- {
- SyncClientWithServer(uid);
- UpdateConsoleInterface(uid, component);
- }
- private void OnConsoleDatabaseModified(EntityUid uid, ResearchConsoleComponent component, ref TechnologyDatabaseModifiedEvent args)
- {
- SyncClientWithServer(uid);
- UpdateConsoleInterface(uid, component);
- }
- private void OnConsoleDatabaseSynchronized(EntityUid uid, ResearchConsoleComponent component, ref TechnologyDatabaseSynchronizedEvent args)
- {
- UpdateConsoleInterface(uid, component);
- }
- private void OnEmagged(Entity<ResearchConsoleComponent> ent, ref GotEmaggedEvent args)
- {
- if (!_emag.CompareFlag(args.Type, EmagType.Interaction))
- return;
- if (_emag.CheckFlag(ent, EmagType.Interaction))
- return;
- args.Handled = true;
- }
- }
|