RND Rework [Death to Techweb] (#16370)
* Techweb rework * more ui work * finishing ui * Finish all the C# logic * the techs + lathes * remove old-tech * mirror-review
This commit is contained in:
@@ -4,91 +4,63 @@ using Content.Shared.Research.Systems;
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Client.GameObjects;
|
||||
|
||||
namespace Content.Client.Research.UI
|
||||
{
|
||||
[UsedImplicitly]
|
||||
public sealed class ResearchConsoleBoundUserInterface : BoundUserInterface
|
||||
{
|
||||
public int Points { get; private set; }
|
||||
public int PointsPerSecond { get; private set; }
|
||||
private ResearchConsoleMenu? _consoleMenu;
|
||||
private TechnologyDatabaseComponent? _technologyDatabase;
|
||||
private readonly IEntityManager _entityManager;
|
||||
private readonly SharedResearchSystem _research;
|
||||
namespace Content.Client.Research.UI;
|
||||
|
||||
public ResearchConsoleBoundUserInterface(ClientUserInterfaceComponent owner, Enum uiKey) : base(owner, uiKey)
|
||||
[UsedImplicitly]
|
||||
public sealed class ResearchConsoleBoundUserInterface : BoundUserInterface
|
||||
{
|
||||
|
||||
private ResearchConsoleMenu? _consoleMenu;
|
||||
|
||||
|
||||
public ResearchConsoleBoundUserInterface(ClientUserInterfaceComponent owner, Enum uiKey) : base(owner, uiKey)
|
||||
{
|
||||
SendMessage(new ConsoleServerSyncMessage());
|
||||
}
|
||||
|
||||
protected override void Open()
|
||||
{
|
||||
base.Open();
|
||||
|
||||
var owner = Owner.Owner;
|
||||
|
||||
_consoleMenu = new ResearchConsoleMenu(owner);
|
||||
|
||||
_consoleMenu.OnTechnologyCardPressed += id =>
|
||||
{
|
||||
SendMessage(new ConsoleUnlockTechnologyMessage(id));
|
||||
};
|
||||
|
||||
_consoleMenu.OnServerButtonPressed += () =>
|
||||
{
|
||||
SendMessage(new ConsoleServerSelectionMessage());
|
||||
};
|
||||
|
||||
_consoleMenu.OnSyncButtonPressed += () =>
|
||||
{
|
||||
SendMessage(new ConsoleServerSyncMessage());
|
||||
_entityManager = IoCManager.Resolve<IEntityManager>();
|
||||
_research = _entityManager.System<SharedResearchSystem>();
|
||||
}
|
||||
};
|
||||
|
||||
protected override void Open()
|
||||
{
|
||||
base.Open();
|
||||
_consoleMenu.OnClose += Close;
|
||||
|
||||
if (!_entityManager.TryGetComponent(Owner.Owner, out _technologyDatabase))
|
||||
return;
|
||||
_consoleMenu.OpenCentered();
|
||||
}
|
||||
|
||||
_consoleMenu = new ResearchConsoleMenu(this);
|
||||
protected override void UpdateState(BoundUserInterfaceState state)
|
||||
{
|
||||
base.UpdateState(state);
|
||||
|
||||
_consoleMenu.OnClose += Close;
|
||||
if (state is not ResearchConsoleBoundInterfaceState castState)
|
||||
return;
|
||||
_consoleMenu?.UpdatePanels(castState);
|
||||
_consoleMenu?.UpdateInformationPanel(castState);
|
||||
}
|
||||
|
||||
_consoleMenu.ServerSyncButton.OnPressed += (_) =>
|
||||
{
|
||||
SendMessage(new ConsoleServerSyncMessage());
|
||||
};
|
||||
|
||||
_consoleMenu.ServerSelectionButton.OnPressed += (_) =>
|
||||
{
|
||||
SendMessage(new ConsoleServerSelectionMessage());
|
||||
};
|
||||
|
||||
_consoleMenu.UnlockButton.OnPressed += (_) =>
|
||||
{
|
||||
if (_consoleMenu.TechnologySelected != null)
|
||||
{
|
||||
SendMessage(new ConsoleUnlockTechnologyMessage(_consoleMenu.TechnologySelected.ID));
|
||||
}
|
||||
};
|
||||
|
||||
_consoleMenu.OpenCentered();
|
||||
}
|
||||
|
||||
public bool IsTechnologyUnlocked(TechnologyPrototype technology)
|
||||
{
|
||||
if (_technologyDatabase == null)
|
||||
return false;
|
||||
|
||||
return _research.IsTechnologyUnlocked(_technologyDatabase.Owner, technology, _technologyDatabase);
|
||||
}
|
||||
|
||||
public bool CanUnlockTechnology(TechnologyPrototype technology)
|
||||
{
|
||||
if (_technologyDatabase == null)
|
||||
return false;
|
||||
|
||||
return _research.ArePrerequesitesUnlocked(_technologyDatabase.Owner, technology, _technologyDatabase);
|
||||
}
|
||||
|
||||
protected override void UpdateState(BoundUserInterfaceState state)
|
||||
{
|
||||
base.UpdateState(state);
|
||||
|
||||
var castState = (ResearchConsoleBoundInterfaceState)state;
|
||||
Points = castState.Points;
|
||||
PointsPerSecond = castState.PointsPerSecond;
|
||||
// We update the user interface here.
|
||||
_consoleMenu?.PopulatePoints();
|
||||
_consoleMenu?.Populate();
|
||||
}
|
||||
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
base.Dispose(disposing);
|
||||
if (!disposing)
|
||||
return;
|
||||
_consoleMenu?.Dispose();
|
||||
}
|
||||
protected override void Dispose(bool disposing)
|
||||
{
|
||||
base.Dispose(disposing);
|
||||
if (!disposing)
|
||||
return;
|
||||
_consoleMenu?.Dispose();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user