diff --git a/Aaru.Server/Components/Admin/AdminNavMenu.razor b/Aaru.Server/Components/Admin/AdminNavMenu.razor index fc7327b0..9c00a769 100644 --- a/Aaru.Server/Components/Admin/AdminNavMenu.razor +++ b/Aaru.Server/Components/Admin/AdminNavMenu.razor @@ -17,6 +17,9 @@ Filesystems + + Filters + diff --git a/Aaru.Server/Components/Admin/Pages/Filters/View.razor b/Aaru.Server/Components/Admin/Pages/Filters/View.razor new file mode 100644 index 00000000..0056e57f --- /dev/null +++ b/Aaru.Server/Components/Admin/Pages/Filters/View.razor @@ -0,0 +1,44 @@ +@page "/admin/filters" +@attribute [Authorize] +@layout AdminLayout + +@inject Microsoft.EntityFrameworkCore.IDbContextFactory DbContextFactory + +Filters + +@if(!_initialized) +{ +
+

Loading...

+
+ + return; +} + +
+ + + + + + + + + @foreach(Filter item in _items) + { + + + + + } + +
+ @DisplayNameHelper.GetDisplayName(typeof(Filter), nameof(Filter.Name)) + + @DisplayNameHelper.GetDisplayName(typeof(Filter), nameof(Filter.Count)) +
+ @item.Name + + @item.Count +
+
\ No newline at end of file diff --git a/Aaru.Server/Components/Admin/Pages/Filters/View.razor.cs b/Aaru.Server/Components/Admin/Pages/Filters/View.razor.cs new file mode 100644 index 00000000..bd029e84 --- /dev/null +++ b/Aaru.Server/Components/Admin/Pages/Filters/View.razor.cs @@ -0,0 +1,27 @@ +using Aaru.Server.Database.Models; +using Microsoft.EntityFrameworkCore; +using DbContext = Aaru.Server.Database.DbContext; + +namespace Aaru.Server.Components.Admin.Pages.Filters; + +public partial class View +{ + bool _initialized; + List _items; + + /// + protected override async Task OnInitializedAsync() + { + await base.OnInitializedAsync(); + + StateHasChanged(); + + await using DbContext ctx = await DbContextFactory.CreateDbContextAsync(); + + _items = await ctx.Filters.OrderBy(static f => f.Name).ToListAsync(); + + _initialized = true; + + StateHasChanged(); + } +} \ No newline at end of file