Migrate commands chart to Blazor.Bootstrap.

This commit is contained in:
2025-05-20 21:39:51 +01:00
parent 284e14b906
commit 1184d1357f
2 changed files with 31 additions and 22 deletions

View File

@@ -1,6 +1,6 @@
@using Aaru.Server.Database @using Aaru.Server.Database
@using Aaru.Server.Database.Models @using Aaru.Server.Database.Models
@using Blazorise.Charts @using BlazorBootstrap
@using Blazorise.DataGrid @using Blazorise.DataGrid
@rendermode InteractiveServer @rendermode InteractiveServer

View File

@@ -1,5 +1,5 @@
using Aaru.Server.Database.Models; using Aaru.Server.Database.Models;
using Blazorise.Charts; using BlazorBootstrap;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using DbContext = Aaru.Server.Database.DbContext; using DbContext = Aaru.Server.Database.DbContext;
@@ -7,9 +7,9 @@ namespace Aaru.Server.Components.Pages.Statistics;
public partial class Commands public partial class Commands
{ {
PieChart<long>? _commandsChart; PieChart _commandsChart;
List<long> _commandsCounts = []; List<double?> _commandsCounts = [];
string[] _commandsLabels = []; List<string> _commandsLabels = [];
bool _isAlreadyInitialized; bool _isAlreadyInitialized;
List<Command> CommandsList { get; set; } = []; List<Command> CommandsList { get; set; } = [];
@@ -35,31 +35,40 @@ public partial class Commands
_commandsLabels = await ctx.Commands.OrderByDescending(static o => o.Count) _commandsLabels = await ctx.Commands.OrderByDescending(static o => o.Count)
.Take(10) .Take(10)
.Select(static v => v.Name) .Select(static v => v.Name)
.ToArrayAsync(); .ToListAsync();
_commandsCounts = await ctx.Commands.OrderByDescending(static o => o.Count) _commandsCounts = await ctx.Commands.OrderByDescending(static o => o.Count)
.Take(10) .Take(10)
.Select(static x => x.Count) .Select(static x => (double?)x.Count)
.ToListAsync(); .ToListAsync();
if(_commandsLabels.Length >= 10) if(_commandsLabels.Count >= 10)
{ {
_commandsLabels[9] = "Other"; _commandsLabels[9] = "Other";
_commandsCounts[9] = ctx.Commands.Sum(static o => o.Count) - _commandsCounts.Take(9).Sum(); _commandsCounts[9] = ctx.Commands.Sum(static o => o.Count) - _commandsCounts.Take(9).Sum();
} }
#pragma warning disable CS8604 // Possible null reference argument. PieChartOptions pieChartOptions = new()
await Common.HandleRedrawAsync(_commandsChart, _commandsLabels, GetCommandsChartDataset);
#pragma warning restore CS8604 // Possible null reference argument.
}
PieChartDataset<long> GetCommandsChartDataset() => new()
{ {
Label = $"Top {_commandsLabels.Length} used commands", Responsive = true
Data = _commandsCounts,
BackgroundColor = Common.BackgroundColors,
BorderColor = Common.BorderColors,
BorderWidth = 1
}; };
pieChartOptions.Plugins.Title.Text = $"Top {_commandsLabels.Count} used commands";
pieChartOptions.Plugins.Title.Display = true;
var chartData = new ChartData
{
Labels = _commandsLabels,
Datasets =
[
new PieChartDataset
{
Data = _commandsCounts
}
]
};
await _commandsChart.InitializeAsync(chartData, pieChartOptions);
}
} }