- add: Metrics

This commit is contained in:
2025-06-27 21:31:38 +03:00
parent 147915f684
commit 01ebe3219d
10 changed files with 233 additions and 81 deletions

View File

@@ -54,6 +54,8 @@
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.pdb" DestinationFolder="$(OutDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.deps.json" DestinationFolder="$(OutDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.runtimeconfig.json" DestinationFolder="$(OutDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\0Harmony.dll" DestinationFolder="$(OutDir)"/>
</Target>
<Target Name="PublishCheck" AfterTargets="Publish">
@@ -61,6 +63,8 @@
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.pdb" DestinationFolder="$(PublishDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.deps.json" DestinationFolder="$(PublishDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\Nebula.Runner.runtimeconfig.json" DestinationFolder="$(PublishDir)"/>
<Copy SourceFiles="..\Nebula.Runner\bin\$(Configuration)\$(TargetFramework)\0Harmony.dll" DestinationFolder="$(OutDir)"/>
</Target>
<ItemGroup>

View File

@@ -27,6 +27,8 @@ public sealed partial class ServerCompoundEntryViewModel :
[ObservableProperty] private bool _loading = true;
private string? _name;
private RobustUrl? _url;
private ServerFilter? _currentFilter;
public string? Name
{
@@ -58,14 +60,16 @@ public sealed partial class ServerCompoundEntryViewModel :
{
Task.Run(async () =>
{
_url = url;
try
{
Message = "Loading server entry...";
var status = await RestService.GetAsync<ServerStatus>(url.StatusUri, cancellationToken);
var status = await RestService.GetAsync<ServerStatus>(_url.StatusUri, cancellationToken);
CurrentEntry = ServiceProvider.GetService<ServerEntryModelView>()!.WithData(url,name, status);
CurrentEntry = ServiceProvider.GetService<ServerEntryModelView>()!.WithData(_url,name, status);
CurrentEntry.IsFavorite = IsFavorite;
CurrentEntry.Loading = false;
CurrentEntry.ProcessFilter(_currentFilter);
Loading = false;
}
catch (Exception e)
@@ -79,12 +83,20 @@ public sealed partial class ServerCompoundEntryViewModel :
public void ToggleFavorites()
{
if (CurrentEntry is null && _url is not null)
{
IsFavorite = !IsFavorite;
if(IsFavorite) FavoriteServerListProvider.AddFavorite(_url);
else FavoriteServerListProvider.RemoveFavorite(_url);
}
CurrentEntry?.ToggleFavorites();
}
public void ProcessFilter(ServerFilter? serverFilter)
{
_currentFilter = serverFilter;
if(CurrentEntry is IFilterConsumer filterConsumer)
filterConsumer.ProcessFilter(serverFilter);
}