Enfin le graphique

master
Maxime ROCHER 5 months ago
parent 6b3a7283b5
commit 3070676b20

@ -1,17 +1,37 @@
@page "/commentary-chart" @page "/commentary-chart"
@using MudBlazor
<MudCard Class="p-4"> <h1>Nombre de commentaires par mois</h1>
<MudCardContent>
<h3 class="text-center mb-4">Statistiques des Commentaires - Année @SelectedYear</h3>
<MudSelect T="int" Label="Sélectionner l'année" @bind-SelectedValue="SelectedYear" Dense="true" Immediate="true" OnValueChanged="UpdateChartData"> <MudChart ChartType="ChartType.Bar" ChartSeries="@Series" @bind-SelectedIndex="Index" LegendPosition="Position.Bottom" XAxisLabels="@XAxisLabels" Width="100%" Height="350px"></MudChart>
@foreach (var year in AvailableYears)
@code {
private int Index = -1;
private List<ChartSeries> Series = new();
private string[] XAxisLabels = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" };
[Inject] private WF_WebAdmin.Service.ICommentaryService CommentaryService { get; set; } = default!;
protected override async Task OnInitializedAsync()
{
var comments = await CommentaryService.GetCommentsAsync();
var groupedData = comments.GroupBy(c => c.DateCreation.Month)
.OrderBy(g => g.Key)
.Select(g => new { Month = g.Key - 1, Value = g.Count() })
.ToList();
double[] data = new double[12];
foreach (var item in groupedData)
{
data[item.Month] = item.Value;
}
Series = new List<ChartSeries>
{
new ChartSeries
{ {
<MudSelectItem T="int" Value="@year">@year</MudSelectItem> Name = "",
Data = data
} }
</MudSelect> };
}
<MudChart ChartType="ChartType.Bar" Labels="@Labels" Data="@ChartData" /> }
</MudCardContent>
</MudCard>

@ -1,72 +0,0 @@
using Microsoft.AspNetCore.Components;
using MudBlazor;
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Threading.Tasks;
using WF_WebAdmin.Model;
using WF_WebAdmin.Service;
namespace WF_WebAdmin.Pages
{
public partial class CommentaryChart : ComponentBase
{
[Inject] public ICommentaryService CommentaryService { get; set; } = default!;
public List<string> Labels { get; set; } = new();
public List<double[]> ChartData { get; set; } = new();
public List<int> AvailableYears { get; set; } = new();
public int SelectedYear { get; set; }
private List<Commentary> AllComments = new();
protected override async Task OnInitializedAsync()
{
// Charger tous les commentaires
AllComments = await CommentaryService.GetCommentsAsync();
if (!AllComments.Any())
{
Labels = new List<string> { "Aucun commentaire" };
ChartData = new List<double[]> { new double[] { 0 } };
return;
}
AvailableYears = AllComments
.Select(c => c.DateCreation.Year)
.Distinct()
.OrderBy(y => y)
.ToList();
SelectedYear = AvailableYears.Max();
UpdateChartData(SelectedYear);
}
private void UpdateChartData(int newYear)
{
SelectedYear = newYear;
var filteredComments = AllComments
.Where(c => c.DateCreation.Year == SelectedYear)
.ToList();
if (!filteredComments.Any())
{
Labels = new List<string> { "Aucun commentaire" };
ChartData = new List<double[]> { new double[] { 0 } };
return;
}
var grouped = Enumerable.Range(1, 12)
.ToDictionary(
month => new DateTime(SelectedYear, month, 1).ToString("MMMM", CultureInfo.InvariantCulture),
month => filteredComments.Count(c => c.DateCreation.Month == month)
);
Labels = grouped.Keys.ToList();
ChartData = new List<double[]> { grouped.Values.Select(v => (double)v).ToArray() };
}
}
}

@ -18,7 +18,6 @@
<PackageReference Include="MudBlazor" Version="6.2.0" /> <PackageReference Include="MudBlazor" Version="6.2.0" />
<PackageReference Include="Npgsql" Version="9.0.2" /> <PackageReference Include="Npgsql" Version="9.0.2" />
<PackageReference Include="Blazored.Modal" Version="7.2.0" /> <PackageReference Include="Blazored.Modal" Version="7.2.0" />
<PackageReference Include="Syncfusion.Blazor.Charts" Version="28.2.4" />
</ItemGroup> </ItemGroup>
</Project> </Project>

@ -1,359 +1,702 @@
[ [
{ {
"id_comment": 1, "id_comment": 1,
"quote": 1, "quote": 19,
"users": 1, "users": 29,
"dateC": "2024-10-10", "dateC": "2024-01-22",
"comment": "coucou" "comment": "Citation magnifique."
}, },
{ {
"id_comment": 2, "id_comment": 2,
"quote": 1, "quote": 6,
"users": 2, "users": 18,
"dateC": "2024-10-11", "dateC": "2024-01-20",
"comment": "Super citation !" "comment": "Paroles sages."
}, },
{ {
"id_comment": 3, "id_comment": 3,
"quote": 1, "quote": 2,
"users": 3, "users": 8,
"dateC": "2024-10-12", "dateC": "2024-01-25",
"comment": "Très inspirant." "comment": "Citation puissante."
}, },
{ {
"id_comment": 4, "id_comment": 4,
"quote": 2, "quote": 11,
"users": 4, "users": 31,
"dateC": "2024-10-13", "dateC": "2024-01-01",
"comment": "J'adore cette phrase." "comment": "Très poétique."
}, },
{ {
"id_comment": 5, "id_comment": 5,
"quote": 2, "quote": 8,
"users": 5, "users": 6,
"dateC": "2024-10-14", "dateC": "2024-02-06",
"comment": "Citation profonde." "comment": "Belle pensée."
}, },
{ {
"id_comment": 6, "id_comment": 6,
"quote": 2, "quote": 13,
"users": 6, "users": 37,
"dateC": "2024-10-15", "dateC": "2024-02-01",
"comment": "Belle pensée." "comment": "Citation exceptionnelle."
}, },
{ {
"id_comment": 7, "id_comment": 7,
"quote": 3, "quote": 2,
"users": 7, "users": 33,
"dateC": "2024-10-16", "dateC": "2024-02-11",
"comment": "Très motivant." "comment": "Belle pensée."
}, },
{ {
"id_comment": 8, "id_comment": 8,
"quote": 3, "quote": 7,
"users": 8, "users": 28,
"dateC": "2024-10-17", "dateC": "2024-02-07",
"comment": "Citation puissante." "comment": "Très émouvant."
}, },
{ {
"id_comment": 9, "id_comment": 9,
"quote": 3, "quote": 1,
"users": 9, "users": 48,
"dateC": "2024-10-18", "dateC": "2024-03-05",
"comment": "Paroles sages." "comment": "Très motivant."
}, },
{ {
"id_comment": 10, "id_comment": 10,
"quote": 4, "quote": 16,
"users": 10, "users": 14,
"dateC": "2024-10-19", "dateC": "2024-03-13",
"comment": "Très réfléchi." "comment": "Très motivant."
}, },
{ {
"id_comment": 11, "id_comment": 11,
"quote": 4, "quote": 10,
"users": 11, "users": 9,
"dateC": "2024-10-20", "dateC": "2024-03-13",
"comment": "Citation magnifique." "comment": "Très touchant."
}, },
{ {
"id_comment": 12, "id_comment": 12,
"quote": 4, "quote": 4,
"users": 12, "users": 44,
"dateC": "2024-10-21", "dateC": "2024-03-01",
"comment": "Très touchant." "comment": "Très touchant."
}, },
{ {
"id_comment": 13, "id_comment": 13,
"quote": 5, "quote": 9,
"users": 13, "users": 8,
"dateC": "2024-10-22", "dateC": "2024-04-04",
"comment": "Citation parfaite." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 14, "id_comment": 14,
"quote": 5, "quote": 3,
"users": 14, "users": 49,
"dateC": "2024-10-23", "dateC": "2024-04-18",
"comment": "Très émouvant." "comment": "Très émouvant."
}, },
{ {
"id_comment": 15, "id_comment": 15,
"quote": 5, "quote": 19,
"users": 15, "users": 3,
"dateC": "2024-10-24", "dateC": "2024-04-07",
"comment": "Citation merveilleuse." "comment": "Très motivant."
}, },
{ {
"id_comment": 16, "id_comment": 16,
"quote": 6, "quote": 4,
"users": 16, "users": 9,
"dateC": "2024-10-25", "dateC": "2024-04-25",
"comment": "Très poétique." "comment": "Très motivant."
}, },
{ {
"id_comment": 17, "id_comment": 17,
"quote": 6, "quote": 17,
"users": 17, "users": 40,
"dateC": "2024-10-26", "dateC": "2024-05-04",
"comment": "Citation exceptionnelle." "comment": "Très émouvant."
}, },
{ {
"id_comment": 18, "id_comment": 18,
"quote": 6, "quote": 6,
"users": 18, "users": 21,
"dateC": "2024-10-27", "dateC": "2024-05-11",
"comment": "Très inspirant." "comment": "Très poétique."
}, },
{ {
"id_comment": 19, "id_comment": 19,
"quote": 7, "quote": 16,
"users": 19, "users": 3,
"dateC": "2024-10-28", "dateC": "2024-05-08",
"comment": "J'adore cette phrase." "comment": "Citation exceptionnelle."
}, },
{ {
"id_comment": 20, "id_comment": 20,
"quote": 7, "quote": 1,
"users": 20, "users": 17,
"dateC": "2024-10-29", "dateC": "2024-05-04",
"comment": "Citation profonde." "comment": "Très touchant."
}, },
{ {
"id_comment": 21, "id_comment": 21,
"quote": 7, "quote": 14,
"users": 21, "users": 34,
"dateC": "2024-08-30", "dateC": "2024-06-01",
"comment": "Belle pensée." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 22, "id_comment": 22,
"quote": 8, "quote": 12,
"users": 22, "users": 23,
"dateC": "2024-10-31", "dateC": "2024-06-03",
"comment": "Très motivant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 23, "id_comment": 23,
"quote": 8, "quote": 11,
"users": 23, "users": 47,
"dateC": "2024-11-01", "dateC": "2024-06-05",
"comment": "Citation puissante." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 24, "id_comment": 24,
"quote": 8, "quote": 16,
"users": 24, "users": 28,
"dateC": "2024-11-02", "dateC": "2024-06-07",
"comment": "Paroles sages." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 25, "id_comment": 25,
"quote": 9, "quote": 19,
"users": 25, "users": 39,
"dateC": "2024-11-03", "dateC": "2024-07-01",
"comment": "Très réfléchi." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 26, "id_comment": 26,
"quote": 9, "quote": 13,
"users": 26, "users": 31,
"dateC": "2024-11-04", "dateC": "2024-07-02",
"comment": "Citation magnifique." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 27, "id_comment": 27,
"quote": 9, "quote": 1,
"users": 27, "users": 33,
"dateC": "2024-11-05", "dateC": "2024-07-03",
"comment": "Très touchant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 28, "id_comment": 28,
"quote": 10, "quote": 17,
"users": 28, "users": 20,
"dateC": "2024-11-06", "dateC": "2024-07-04",
"comment": "Citation parfaite." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 29, "id_comment": 29,
"quote": 10, "quote": 13,
"users": 29, "users": 29,
"dateC": "2024-11-07", "dateC": "2024-08-01",
"comment": "Très émouvant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 30, "id_comment": 30,
"quote": 10, "quote": 11,
"users": 30, "users": 27,
"dateC": "2024-11-08", "dateC": "2024-08-02",
"comment": "Citation merveilleuse." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 31, "id_comment": 31,
"quote": 11, "quote": 18,
"users": 31, "users": 35,
"dateC": "2024-11-09", "dateC": "2024-08-03",
"comment": "Très poétique." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 32, "id_comment": 32,
"quote": 11, "quote": 13,
"users": 32, "users": 32,
"dateC": "2024-11-10", "dateC": "2024-08-04",
"comment": "Citation exceptionnelle." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 33, "id_comment": 33,
"quote": 11, "quote": 13,
"users": 33, "users": 3,
"dateC": "2024-11-11", "dateC": "2024-09-01",
"comment": "Très inspirant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 34, "id_comment": 34,
"quote": 12, "quote": 15,
"users": 34, "users": 43,
"dateC": "2024-11-12", "dateC": "2024-09-02",
"comment": "J'adore cette phrase." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 35, "id_comment": 35,
"quote": 12, "quote": 11,
"users": 35, "users": 15,
"dateC": "2024-11-13", "dateC": "2024-09-03",
"comment": "Citation profonde." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 36, "id_comment": 36,
"quote": 12, "quote": 10,
"users": 36, "users": 22,
"dateC": "2024-11-14", "dateC": "2024-09-04",
"comment": "Belle pensée." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 37, "id_comment": 37,
"quote": 13, "quote": 17,
"users": 37, "users": 23,
"dateC": "2024-11-15", "dateC": "2024-10-01",
"comment": "Très motivant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 38, "id_comment": 38,
"quote": 13, "quote": 14,
"users": 38, "users": 40,
"dateC": "2024-11-16", "dateC": "2024-10-02",
"comment": "Citation puissante." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 39, "id_comment": 39,
"quote": 13, "quote": 15,
"users": 39, "users": 41,
"dateC": "2024-11-17", "dateC": "2024-10-03",
"comment": "Paroles sages." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 40, "id_comment": 40,
"quote": 14, "quote": 16,
"users": 40, "users": 42,
"dateC": "2024-11-18", "dateC": "2024-10-04",
"comment": "Très réfléchi." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 41, "id_comment": 41,
"quote": 14, "quote": 10,
"users": 41, "users": 39,
"dateC": "2024-11-19", "dateC": "2024-11-01",
"comment": "Citation magnifique." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 42, "id_comment": 42,
"quote": 14, "quote": 17,
"users": 42, "users": 43,
"dateC": "2024-11-20", "dateC": "2024-11-02",
"comment": "Très touchant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 43, "id_comment": 43,
"quote": 15, "quote": 13,
"users": 43, "users": 27,
"dateC": "2024-11-21", "dateC": "2024-11-03",
"comment": "Citation parfaite." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 44, "id_comment": 44,
"quote": 15, "quote": 12,
"users": 44, "users": 29,
"dateC": "2024-11-22", "dateC": "2024-11-04",
"comment": "Très émouvant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 45, "id_comment": 45,
"quote": 15, "quote": 11,
"users": 45, "users": 32,
"dateC": "2024-11-23", "dateC": "2024-12-01",
"comment": "Citation merveilleuse." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 46, "id_comment": 46,
"quote": 16, "quote": 15,
"users": 46, "users": 31,
"dateC": "2024-11-24", "dateC": "2024-12-02",
"comment": "Très poétique." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 47, "id_comment": 47,
"quote": 16, "quote": 18,
"users": 47, "users": 33,
"dateC": "2024-11-25", "dateC": "2024-12-03",
"comment": "Citation exceptionnelle." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 48, "id_comment": 48,
"quote": 16, "quote": 14,
"users": 48, "users": 34,
"dateC": "2024-11-26", "dateC": "2024-12-04",
"comment": "Très inspirant." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 49, "id_comment": 49,
"quote": 17, "quote": 19,
"users": 49, "users": 35,
"dateC": "2024-11-27", "dateC": "2024-12-05",
"comment": "J'adore cette phrase." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 50, "id_comment": 50,
"quote": 17, "quote": 17,
"users": 50, "users": 36,
"dateC": "2024-11-28", "dateC": "2024-12-06",
"comment": "Citation profonde." "comment": "Citation magnifique."
}, },
{ {
"id_comment": 51, "id_comment": 51,
"quote": 16,
"users": 37,
"dateC": "2024-12-07",
"comment": "Citation magnifique."
},
{
"id_comment": 52,
"quote": 13,
"users": 38,
"dateC": "2024-12-08",
"comment": "Citation magnifique."
},
{
"id_comment": 53,
"quote": 12,
"users": 39,
"dateC": "2024-12-09",
"comment": "Citation magnifique."
},
{
"id_comment": 54,
"quote": 11,
"users": 40,
"dateC": "2024-12-10",
"comment": "Citation magnifique."
},
{
"id_comment": 55,
"quote": 10,
"users": 41,
"dateC": "2024-12-11",
"comment": "Citation magnifique."
},
{
"id_comment": 56,
"quote": 9,
"users": 42,
"dateC": "2024-12-12",
"comment": "Citation magnifique."
},
{
"id_comment": 57,
"quote": 8,
"users": 43,
"dateC": "2024-12-13",
"comment": "Citation magnifique."
},
{
"id_comment": 58,
"quote": 7,
"users": 44,
"dateC": "2024-12-14",
"comment": "Citation magnifique."
},
{
"id_comment": 59,
"quote": 6,
"users": 45,
"dateC": "2024-12-15",
"comment": "Citation magnifique."
},
{
"id_comment": 60,
"quote": 5,
"users": 46,
"dateC": "2024-12-16",
"comment": "Citation magnifique."
},
{
"id_comment": 61,
"quote": 4,
"users": 47,
"dateC": "2024-12-17",
"comment": "Citation magnifique."
},
{
"id_comment": 62,
"quote": 3,
"users": 48,
"dateC": "2024-12-18",
"comment": "Citation magnifique."
},
{
"id_comment": 63,
"quote": 2,
"users": 49,
"dateC": "2024-12-19",
"comment": "Citation magnifique."
},
{
"id_comment": 64,
"quote": 1,
"users": 50,
"dateC": "2024-12-20",
"comment": "Citation magnifique."
},
{
"id_comment": 65,
"quote": 19,
"users": 1,
"dateC": "2024-12-21",
"comment": "Citation magnifique."
},
{
"id_comment": 66,
"quote": 18,
"users": 2,
"dateC": "2024-12-22",
"comment": "Citation magnifique."
},
{
"id_comment": 67,
"quote": 17, "quote": 17,
"users": 51, "users": 3,
"dateC": "2024-11-29", "dateC": "2024-12-23",
"comment": "Belle pensée." "comment": "Citation magnifique."
},
{
"id_comment": 68,
"quote": 16,
"users": 4,
"dateC": "2024-12-24",
"comment": "Citation magnifique."
},
{
"id_comment": 69,
"quote": 15,
"users": 5,
"dateC": "2024-12-25",
"comment": "Citation magnifique."
},
{
"id_comment": 70,
"quote": 14,
"users": 6,
"dateC": "2024-12-26",
"comment": "Citation magnifique."
},
{
"id_comment": 71,
"quote": 13,
"users": 7,
"dateC": "2024-12-27",
"comment": "Citation magnifique."
},
{
"id_comment": 72,
"quote": 12,
"users": 8,
"dateC": "2024-12-28",
"comment": "Citation magnifique."
},
{
"id_comment": 73,
"quote": 11,
"users": 9,
"dateC": "2024-01-01",
"comment": "Citation magnifique."
},
{
"id_comment": 74,
"quote": 10,
"users": 10,
"dateC": "2024-01-02",
"comment": "Citation magnifique."
},
{
"id_comment": 75,
"quote": 9,
"users": 11,
"dateC": "2024-01-03",
"comment": "Citation magnifique."
},
{
"id_comment": 76,
"quote": 8,
"users": 12,
"dateC": "2024-01-04",
"comment": "Citation magnifique."
},
{
"id_comment": 77,
"quote": 7,
"users": 13,
"dateC": "2024-01-05",
"comment": "Citation magnifique."
},
{
"id_comment": 78,
"quote": 6,
"users": 14,
"dateC": "2024-01-06",
"comment": "Citation magnifique."
},
{
"id_comment": 79,
"quote": 5,
"users": 15,
"dateC": "2024-01-07",
"comment": "Citation magnifique."
},
{
"id_comment": 80,
"quote": 4,
"users": 16,
"dateC": "2024-01-08",
"comment": "Citation magnifique."
},
{
"id_comment": 81,
"quote": 3,
"users": 17,
"dateC": "2024-01-09",
"comment": "Citation magnifique."
},
{
"id_comment": 82,
"quote": 2,
"users": 18,
"dateC": "2024-01-10",
"comment": "Citation magnifique."
},
{
"id_comment": 83,
"quote": 15,
"users": 33,
"dateC": "2024-06-24",
"comment": "Citation exceptionnelle."
},
{
"id_comment": 84,
"quote": 19,
"users": 15,
"dateC": "2024-03-11",
"comment": "Citation merveilleuse."
},
{
"id_comment": 85,
"quote": 4,
"users": 16,
"dateC": "2024-01-19",
"comment": "Citation merveilleuse."
},
{
"id_comment": 86,
"quote": 10,
"users": 20,
"dateC": "2024-01-15",
"comment": "Très émouvant."
},
{
"id_comment": 87,
"quote": 3,
"users": 33,
"dateC": "2024-12-17",
"comment": "Très touchant."
},
{
"id_comment": 88,
"quote": 5,
"users": 8,
"dateC": "2024-07-01",
"comment": "Citation exceptionnelle."
},
{
"id_comment": 89,
"quote": 13,
"users": 28,
"dateC": "2024-02-20",
"comment": "Citation merveilleuse."
},
{
"id_comment": 90,
"quote": 18,
"users": 24,
"dateC": "2024-09-16",
"comment": "Citation merveilleuse."
},
{
"id_comment": 91,
"quote": 17,
"users": 43,
"dateC": "2024-06-20",
"comment": "Très réfléchi."
},
{
"id_comment": 92,
"quote": 13,
"users": 36,
"dateC": "2024-11-08",
"comment": "Super citation !"
},
{
"id_comment": 93,
"quote": 19,
"users": 41,
"dateC": "2024-01-20",
"comment": "Super citation !"
},
{
"id_comment": 94,
"quote": 13,
"users": 10,
"dateC": "2024-05-03",
"comment": "Citation magnifique."
},
{
"id_comment": 95,
"quote": 4,
"users": 49,
"dateC": "2024-07-01",
"comment": "Citation profonde."
},
{
"id_comment": 96,
"quote": 16,
"users": 21,
"dateC": "2024-11-08",
"comment": "Citation merveilleuse."
},
{
"id_comment": 97,
"quote": 14,
"users": 27,
"dateC": "2024-11-20",
"comment": "Citation puissante."
},
{
"id_comment": 98,
"quote": 4,
"users": 39,
"dateC": "2024-12-11",
"comment": "Très motivant."
},
{
"id_comment": 99,
"quote": 9,
"users": 26,
"dateC": "2024-09-27",
"comment": "Paroles sages."
},
{
"id_comment": 100,
"quote": 3,
"users": 42,
"dateC": "2024-02-12",
"comment": "Citation merveilleuse."
} }
] ]
Loading…
Cancel
Save