feat(client): migrate WorkOrderFilterPanel to API clients

This commit is contained in:
Joseph Doherty
2026-01-06 10:33:36 -05:00
parent 8e05afb34f
commit ead947bf57
@@ -1,5 +1,6 @@
@* Work order filter panel with upload/download/clear functionality *@ @* Work order filter panel with upload/download/clear functionality *@
@inject IFileService FileService @using JdeScoping.Core.ApiContracts
@inject IFileApiClient FileApi
@inject DialogService DialogService @inject DialogService DialogService
@inject NotificationService NotificationService @inject NotificationService NotificationService
@@ -47,8 +48,15 @@
private async Task DownloadTemplateAsync() private async Task DownloadTemplateAsync()
{ {
var workOrderNumbers = WorkOrders.Select(wo => wo.WorkOrderNumber).ToList(); var result = await FileApi.DownloadWorkOrdersTemplateAsync(WorkOrders.AsReadOnly());
await FileService.DownloadTemplateAsync("workorders", workOrderNumbers); result.Switch(
bytes => { _ = JSRuntime.InvokeVoidAsync("downloadFile", "workorders_template.xlsx", bytes); },
_ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Template not found."); },
validation => { NotificationService.Notify(NotificationSeverity.Error, "Error", string.Join("; ", validation.FieldErrors.SelectMany(e => e.Value))); },
_ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Session expired."); },
_ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Access denied."); },
error => { NotificationService.Notify(NotificationSeverity.Error, "Error", error.Message); }
);
} }
private async Task TriggerFileInput() private async Task TriggerFileInput()
@@ -64,19 +72,22 @@
try try
{ {
using var stream = e.File.OpenReadStream(maxAllowedSize: 10 * 1024 * 1024); // 10MB max using var stream = e.File.OpenReadStream(maxAllowedSize: 10 * 1024 * 1024); // 10MB max
var result = await FileService.UploadAsync<WorkOrderViewModel>("workorders", stream, e.File.Name); var result = await FileApi.UploadWorkOrdersAsync(stream, e.File.Name);
if (result.WasSuccessful) result.Switch(
{ workOrders =>
WorkOrders.Clear(); {
WorkOrders.AddRange(result.Data); WorkOrders.Clear();
await WorkOrdersChanged.InvokeAsync(WorkOrders); WorkOrders.AddRange(workOrders);
NotificationService.Notify(NotificationSeverity.Success, "Upload Complete", $"Loaded {result.Data.Count} work orders."); _ = WorkOrdersChanged.InvokeAsync(WorkOrders);
} NotificationService.Notify(NotificationSeverity.Success, "Upload Complete", $"Loaded {workOrders.Count} work orders.");
else },
{ _ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Upload endpoint not found."); },
NotificationService.Notify(NotificationSeverity.Error, "Upload Failed", result.ErrorMessage); validation => { NotificationService.Notify(NotificationSeverity.Error, "Upload Failed", string.Join("; ", validation.FieldErrors.SelectMany(e => e.Value))); },
} _ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Session expired."); },
_ => { NotificationService.Notify(NotificationSeverity.Error, "Error", "Access denied."); },
error => { NotificationService.Notify(NotificationSeverity.Error, "Upload Failed", error.Message); }
);
} }
catch (Exception ex) catch (Exception ex)
{ {