2021-11-22 20:57:56 +01:00
|
|
|
|
using System.Linq;
|
|
|
|
|
|
using Content.Client.Eui;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
using Content.Shared.Administration.Logs;
|
|
|
|
|
|
using Content.Shared.Eui;
|
|
|
|
|
|
using JetBrains.Annotations;
|
2021-12-08 23:03:08 +01:00
|
|
|
|
using Robust.Client.Graphics;
|
|
|
|
|
|
using Robust.Client.UserInterface;
|
|
|
|
|
|
using Robust.Client.UserInterface.Controls;
|
2022-04-16 20:57:50 +02:00
|
|
|
|
using static Content.Shared.Administration.Logs.AdminLogsEuiMsg;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
namespace Content.Client.Administration.UI.Logs;
|
|
|
|
|
|
|
|
|
|
|
|
[UsedImplicitly]
|
2022-02-16 00:23:23 -07:00
|
|
|
|
public sealed class AdminLogsEui : BaseEui
|
2021-11-22 19:08:27 +01:00
|
|
|
|
{
|
2021-12-08 23:03:08 +01:00
|
|
|
|
[Dependency] private readonly IClyde _clyde = default!;
|
|
|
|
|
|
[Dependency] private readonly IUserInterfaceManager _uiManager = default!;
|
|
|
|
|
|
|
2021-11-22 19:08:27 +01:00
|
|
|
|
public AdminLogsEui()
|
|
|
|
|
|
{
|
2021-12-08 23:03:08 +01:00
|
|
|
|
LogsWindow = new AdminLogsWindow();
|
2023-04-29 15:16:24 +12:00
|
|
|
|
LogsWindow.OnClose += OnCloseWindow;
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl = LogsWindow.Logs;
|
2021-12-08 23:03:08 +01:00
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl.LogSearch.OnTextEntered += _ => RequestLogs();
|
|
|
|
|
|
LogsControl.RefreshButton.OnPressed += _ => RequestLogs();
|
|
|
|
|
|
LogsControl.NextButton.OnPressed += _ => NextLogs();
|
|
|
|
|
|
LogsControl.PopOutButton.OnPressed += _ => PopOut();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
private WindowRoot? Root { get; set; }
|
|
|
|
|
|
|
|
|
|
|
|
private IClydeWindow? ClydeWindow { get; set; }
|
2021-12-08 23:03:08 +01:00
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
private AdminLogsWindow? LogsWindow { get; set; }
|
2021-12-08 23:03:08 +01:00
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
private AdminLogsControl LogsControl { get; }
|
2021-11-22 19:08:27 +01:00
|
|
|
|
|
|
|
|
|
|
private bool FirstState { get; set; } = true;
|
|
|
|
|
|
|
2021-12-08 23:03:08 +01:00
|
|
|
|
private void OnRequestClosed(WindowRequestClosedEventArgs args)
|
|
|
|
|
|
{
|
2023-04-29 15:16:24 +12:00
|
|
|
|
SendMessage(new CloseEuiMessage());
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void OnCloseWindow()
|
|
|
|
|
|
{
|
|
|
|
|
|
if (ClydeWindow == null)
|
|
|
|
|
|
SendMessage(new CloseEuiMessage());
|
2021-12-08 23:03:08 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-11-22 19:08:27 +01:00
|
|
|
|
private void RequestLogs()
|
|
|
|
|
|
{
|
|
|
|
|
|
var request = new LogsRequest(
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl.SelectedRoundId,
|
2022-06-29 09:53:58 +02:00
|
|
|
|
LogsControl.Search,
|
2021-12-24 20:48:21 +01:00
|
|
|
|
LogsControl.SelectedTypes.ToHashSet(),
|
2021-11-22 19:08:27 +01:00
|
|
|
|
null,
|
|
|
|
|
|
null,
|
|
|
|
|
|
null,
|
2023-02-28 10:09:35 -06:00
|
|
|
|
LogsControl.SelectedPlayers.Count != 0,
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl.SelectedPlayers.ToArray(),
|
2021-11-22 19:08:27 +01:00
|
|
|
|
null,
|
2023-02-28 10:09:35 -06:00
|
|
|
|
LogsControl.IncludeNonPlayerLogs,
|
2021-11-22 19:08:27 +01:00
|
|
|
|
DateOrder.Descending);
|
|
|
|
|
|
|
|
|
|
|
|
SendMessage(request);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void NextLogs()
|
|
|
|
|
|
{
|
2023-05-17 04:04:28 -07:00
|
|
|
|
LogsControl.NextButton.Disabled = true;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
var request = new NextLogsRequest();
|
|
|
|
|
|
SendMessage(request);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
private void PopOut()
|
|
|
|
|
|
{
|
|
|
|
|
|
if (LogsWindow == null)
|
|
|
|
|
|
{
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var monitor = _clyde.EnumerateMonitors().First();
|
|
|
|
|
|
|
|
|
|
|
|
ClydeWindow = _clyde.CreateWindow(new WindowCreateParameters
|
|
|
|
|
|
{
|
|
|
|
|
|
Maximized = false,
|
|
|
|
|
|
Title = "Admin Logs",
|
|
|
|
|
|
Monitor = monitor,
|
2023-05-17 04:04:28 -07:00
|
|
|
|
Width = 1100,
|
2021-12-09 00:05:42 +01:00
|
|
|
|
Height = 400
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2023-04-29 15:16:24 +12:00
|
|
|
|
LogsControl.Orphan();
|
|
|
|
|
|
LogsWindow.Dispose();
|
|
|
|
|
|
LogsWindow = null;
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
ClydeWindow.RequestClosed += OnRequestClosed;
|
|
|
|
|
|
ClydeWindow.DisposeOnClose = true;
|
|
|
|
|
|
|
|
|
|
|
|
Root = _uiManager.CreateWindowRoot(ClydeWindow);
|
|
|
|
|
|
Root.AddChild(LogsControl);
|
|
|
|
|
|
|
|
|
|
|
|
LogsControl.PopOutButton.Disabled = true;
|
|
|
|
|
|
LogsControl.PopOutButton.Visible = false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-11-22 19:08:27 +01:00
|
|
|
|
public override void HandleState(EuiStateBase state)
|
|
|
|
|
|
{
|
|
|
|
|
|
var s = (AdminLogsEuiState) state;
|
|
|
|
|
|
|
|
|
|
|
|
if (s.IsLoading)
|
|
|
|
|
|
{
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl.SetCurrentRound(s.RoundId);
|
|
|
|
|
|
LogsControl.SetPlayers(s.Players);
|
2023-05-17 04:04:28 -07:00
|
|
|
|
LogsControl.UpdateCount(round: s.RoundLogs);
|
2021-11-28 14:29:46 +01:00
|
|
|
|
|
2021-12-25 19:18:04 +01:00
|
|
|
|
if (!FirstState)
|
2021-11-28 14:29:46 +01:00
|
|
|
|
{
|
2021-12-25 19:18:04 +01:00
|
|
|
|
return;
|
2021-11-28 14:29:46 +01:00
|
|
|
|
}
|
2021-12-25 19:18:04 +01:00
|
|
|
|
|
|
|
|
|
|
FirstState = false;
|
|
|
|
|
|
LogsControl.SetRoundSpinBox(s.RoundId);
|
|
|
|
|
|
RequestLogs();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public override void HandleMessage(EuiMessageBase msg)
|
|
|
|
|
|
{
|
|
|
|
|
|
base.HandleMessage(msg);
|
|
|
|
|
|
|
|
|
|
|
|
switch (msg)
|
|
|
|
|
|
{
|
2022-06-29 10:38:24 +02:00
|
|
|
|
case NewLogs newLogs:
|
|
|
|
|
|
if (newLogs.Replace)
|
|
|
|
|
|
{
|
|
|
|
|
|
LogsControl.SetLogs(newLogs.Logs);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
LogsControl.AddLogs(newLogs.Logs);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
LogsControl.NextButton.Disabled = !newLogs.HasNext;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
break;
|
2023-02-18 19:00:17 -06:00
|
|
|
|
|
|
|
|
|
|
case SetLogFilter setLogFilter:
|
|
|
|
|
|
if (setLogFilter.Search != null)
|
|
|
|
|
|
LogsControl.LogSearch.SetText(setLogFilter.Search);
|
|
|
|
|
|
|
|
|
|
|
|
if (setLogFilter.Types != null)
|
|
|
|
|
|
LogsControl.SetTypesSelection(setLogFilter.Types, setLogFilter.InvertTypes);
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
public override void Opened()
|
|
|
|
|
|
{
|
|
|
|
|
|
base.Opened();
|
|
|
|
|
|
|
|
|
|
|
|
LogsWindow?.OpenCentered();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2021-11-22 19:08:27 +01:00
|
|
|
|
public override void Closed()
|
|
|
|
|
|
{
|
|
|
|
|
|
base.Closed();
|
|
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
if (ClydeWindow != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
ClydeWindow.RequestClosed -= OnRequestClosed;
|
|
|
|
|
|
}
|
2021-12-08 23:03:08 +01:00
|
|
|
|
|
2021-12-09 00:05:42 +01:00
|
|
|
|
LogsControl.Dispose();
|
|
|
|
|
|
LogsWindow?.Dispose();
|
|
|
|
|
|
Root?.Dispose();
|
|
|
|
|
|
ClydeWindow?.Dispose();
|
2021-11-22 19:08:27 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|