From 45b6551b40cfe21f31c3f793bb4d362138ab761f Mon Sep 17 00:00:00 2001 From: Natalia Portillo Date: Fri, 12 Sep 2025 16:43:29 +0100 Subject: [PATCH] Add FireWire registers management view with delete and consolidate functionality --- .../Components/Admin/AdminNavMenu.razor | 3 + .../Admin/Pages/FireWire/List.razor | 124 ++++++++++++++++ .../Admin/Pages/FireWire/List.razor.cs | 136 ++++++++++++++++++ 3 files changed, 263 insertions(+) create mode 100644 Aaru.Server/Components/Admin/Pages/FireWire/List.razor create mode 100644 Aaru.Server/Components/Admin/Pages/FireWire/List.razor.cs diff --git a/Aaru.Server/Components/Admin/AdminNavMenu.razor b/Aaru.Server/Components/Admin/AdminNavMenu.razor index d954e536..51f5ca97 100644 --- a/Aaru.Server/Components/Admin/AdminNavMenu.razor +++ b/Aaru.Server/Components/Admin/AdminNavMenu.razor @@ -26,6 +26,9 @@ Filters + + FireWire registers + Media formats diff --git a/Aaru.Server/Components/Admin/Pages/FireWire/List.razor b/Aaru.Server/Components/Admin/Pages/FireWire/List.razor new file mode 100644 index 00000000..4937cd8c --- /dev/null +++ b/Aaru.Server/Components/Admin/Pages/FireWire/List.razor @@ -0,0 +1,124 @@ +@page "/admin/firewire" +@attribute [Authorize] +@layout AdminLayout + +@inject Microsoft.EntityFrameworkCore.IDbContextFactory DbContextFactory + +FireWire registers + +@if(!_initialized) +{ +
+

Loading...

+
+ + return; +} + +
+

FireWire registers

+ + + + + + + + + + + + + @foreach(FireWire item in _items) + { + + + + + + + + + } + +
+ @DisplayNameHelper.GetDisplayName(typeof(FireWire), nameof(FireWire.Manufacturer)) + + @DisplayNameHelper.GetDisplayName(typeof(FireWire), nameof(FireWire.Product)) + + @DisplayNameHelper.GetDisplayName(typeof(FireWire), nameof(FireWire.VendorID)) + + @DisplayNameHelper.GetDisplayName(typeof(FireWire), nameof(FireWire.ProductID)) + + @DisplayNameHelper.GetDisplayName(typeof(FireWire), nameof(FireWire.RemovableMedia)) + + Actions +
+ @item.Manufacturer + + @item.Product + + @item.VendorID + + @item.ProductID + + @item.RemovableMedia + + + Edit + + +
+ + @if(_duplicates.Count > 0) + { +
+ The following USB devices have duplicates. + + + @foreach(FireWireModel item in _duplicates) + { + + + + + + + } + +
+ @item.Manufacturer + + @item.Product + + @item.VendorID + + @item.ProductID +
+
+ + + } +
+ + + +
Are you sure you want to delete the duplicates?
+
+ + + + +
+ + + +
Are you sure you want to delete this FireWire device?
+
+ + + + +
\ No newline at end of file diff --git a/Aaru.Server/Components/Admin/Pages/FireWire/List.razor.cs b/Aaru.Server/Components/Admin/Pages/FireWire/List.razor.cs new file mode 100644 index 00000000..7419eb24 --- /dev/null +++ b/Aaru.Server/Components/Admin/Pages/FireWire/List.razor.cs @@ -0,0 +1,136 @@ +using Aaru.Server.Database.Models; +using BlazorBootstrap; +using Microsoft.EntityFrameworkCore; +using DbContext = Aaru.Server.Database.DbContext; + +namespace Aaru.Server.Components.Admin.Pages.FireWire; + +public partial class List +{ + private Modal? _consolidateModal; + private int _deleteId; + private Modal? _deleteModal; + List _duplicates; + bool _initialized; + List _items; + + + /// + protected override async Task OnInitializedAsync() + { + await base.OnInitializedAsync(); + + StateHasChanged(); + + await RefreshItemsAsync(); + + _initialized = true; + + StateHasChanged(); + } + + async Task RefreshItemsAsync() + { + await using DbContext ctx = await DbContextFactory.CreateDbContextAsync(); + + _items = await ctx.FireWire.OrderBy(static f => f.Manufacturer).ThenBy(static f => f.Product).ToListAsync(); + + _duplicates = await ctx.FireWire.GroupBy(static x => new + { + x.VendorID, + x.ProductID, + x.Manufacturer, + x.Product, + x.RemovableMedia + }) + .Where(static x => x.Count() > 1) + .Select(static x => new FireWireModel + { + VendorID = x.Key.VendorID, + ProductID = x.Key.ProductID, + Manufacturer = x.Key.Manufacturer, + Product = x.Key.Product, + RemovableMedia = x.Key.RemovableMedia + }) + .ToListAsync(); + } + + Task ConsolidateDuplicatesAsync() => _consolidateModal?.ShowAsync(); + + Task HideConsolidateModalAsync() => _consolidateModal?.HideAsync(); + + async Task ConfirmConsolidateAsync() + { + await using DbContext ctx = await DbContextFactory.CreateDbContextAsync(); + + foreach(FireWireModel duplicate in _duplicates) + { + CommonTypes.Metadata.FireWire? master = ctx.FireWire.FirstOrDefault(m => m.VendorID == duplicate.VendorID && + m.ProductID == + duplicate.ProductID && + m.Manufacturer == + duplicate.Manufacturer && + m.Product == + duplicate.Product && + m.RemovableMedia == + duplicate.RemovableMedia); + + if(master is null) continue; + + foreach(CommonTypes.Metadata.FireWire firewire in await ctx.FireWire + .Where(m => m.VendorID == duplicate.VendorID && + m.ProductID == duplicate.ProductID && + m.Manufacturer == + duplicate.Manufacturer && + m.Product == duplicate.Product && + m.RemovableMedia == + duplicate.RemovableMedia) + .Skip(1) + .ToArrayAsync()) + { + foreach(Device device in ctx.Devices.Where(d => d.FireWire.Id == firewire.Id)) device.FireWire = master; + + foreach(UploadedReport report in ctx.Reports.Where(d => d.FireWire.Id == firewire.Id)) + report.FireWire = master; + + ctx.FireWire.Remove(firewire); + } + } + + await ctx.SaveChangesAsync(); + + await RefreshItemsAsync(); + + StateHasChanged(); + } + + private async Task ShowDeleteModal(int id) + { + _deleteId = id; + if(_deleteModal != null) await _deleteModal.ShowAsync(); + } + + private async Task HideDeleteModal() + { + if(_deleteModal != null) await _deleteModal.HideAsync(); + } + + private async Task ConfirmDelete() + { + await DeleteAsync(_deleteId); + await HideDeleteModal(); + await RefreshItemsAsync(); + } + + private async Task DeleteAsync(int id) + { + await using DbContext ctx = await DbContextFactory.CreateDbContextAsync(); + CommonTypes.Metadata.FireWire? firewire = await ctx.FireWire.FindAsync(id); + + if(firewire is not null) + { + ctx.FireWire.Remove(firewire); + await ctx.SaveChangesAsync(); + } + } +} \ No newline at end of file