@using FruitBank.Common.Dtos @using FruitBank.Common.Entities @using FruitBankHybrid.Shared.Components.FileUploads @using FruitBankHybrid.Shared.Databases @using FruitBankHybrid.Shared.Services.SignalRs @using System.Text @using AyCode.Core.Extensions @inject FruitBankSignalRClient FruitBankSignalRClient @if (IsMasterGrid) { var shippingDocument = ((ShippingDocument)context.DataItem); @{ var shippingItemPallets = shippingDocument?.ShippingItems?.SelectMany(oi => oi.ShippingItemPallets ?? []).ToList() ?? []; // } } @* *@ @code { [Inject] public required DatabaseClient Database { get; set; } [Parameter] public bool IsMasterGrid { get; set; } = false; [Parameter] public List? Shippings { get; set; } [Parameter] public IEnumerable? ProductDtos { get; set; } [Parameter] public List? ShippingDocuments { get; set; } [Parameter] public Func?, Task>? OnUploadedFileParsed { get; set; } const string ExportFileName = "ExportResult"; string GridSearchText = ""; bool EditItemsEnabled { get; set; } = true; int FocusedRowVisibleIndex { get; set; } IGrid Grid { get; set; } private int _activeTabIndex; protected override async Task OnInitializedAsync() { ProductDtos ??= await Database.ProductDtoTable.LoadDataAsync(true); Shippings ??= await FruitBankSignalRClient.GetShippings() ?? []; //ProductDtos ??= await FruitBankSignalRClient.GetProductDtos() ?? []; ShippingDocuments ??= await FruitBankSignalRClient.GetShippingDocuments() ?? []; // if (OrderDto != null) // OrderItemDtos = OrderDto.OrderItemDtos; } private async Task OnFileUploaded(byte[] arg) { string utfString = Encoding.UTF8.GetString(arg, 0, arg.Length); var partners = utfString.JsonTo>(); if (partners != null) { var id = ShippingDocuments.Max(x => x.Id); foreach (var shippingDocument in partners.SelectMany(partner => partner.ShippingDocuments ?? [])) { shippingDocument.Id = ++id; ShippingDocuments.Add(shippingDocument); } } Grid.Reload(); if (OnUploadedFileParsed != null) await OnUploadedFileParsed(partners); //await InvokeAsync(StateHasChanged); } async Task Grid_DataItemDeleting(GridDataItemDeletingEventArgs e) { // await NwindDataService.RemoveEmployeeAsync((EditableEmployee)e.DataItem); // await LoadGridDataAsync(); // if(Data.Length == 0) // UpdateEditItemsEnabled(false); } async Task Grid_EditModelSaving(GridEditModelSavingEventArgs e) { // if(e.IsNew) { // await NwindDataService.InsertEmployeeAsync((EditableEmployee)e.EditModel); // } else // await NwindDataService.UpdateEmployeeAsync((EditableEmployee)e.DataItem, (EditableEmployee)e.EditModel); // await LoadGridDataAsync(); EditItemsEnabled = true; } async Task NewItem_Click() { EditItemsEnabled = false; await Grid.StartEditNewRowAsync(); } async Task EditItem_Click() { EditItemsEnabled = false; await Grid.StartEditRowAsync(FocusedRowVisibleIndex); } void DeleteItem_Click() { EditItemsEnabled = false; Grid.ShowRowDeleteConfirmation(FocusedRowVisibleIndex); } void ColumnChooserItem_Click(ToolbarItemClickEventArgs e) { Grid.ShowColumnChooser(); } async Task ExportXlsxItem_Click() { await Grid.ExportToXlsxAsync(ExportFileName); } async Task ExportXlsItem_Click() { await Grid.ExportToXlsAsync(ExportFileName); } async Task ExportCsvItem_Click() { await Grid.ExportToCsvAsync(ExportFileName); } async Task ExportPdfItem_Click() { await Grid.ExportToPdfAsync(ExportFileName); } protected async Task OnActiveTabChanged(int activeTabIndex) { _activeTabIndex = activeTabIndex; return; // switch (_activeTabIndex) // { // case 0: // if(ProductDtos == null) // ProductDtos = (await FruitBankSignalRClient.GetProductDtos() ?? []); //.Where(o => o.HasMeasuringAccess(LoggedInModel.CustomerDto?.Id, LoggedInModel.IsRevisor)).OrderBy(o => o.DateOfReceipt).ToList(); // break; // case 1: // if(OrderDtos == null) // OrderDtos = (await FruitBankSignalRClient.GetAllOrderDtos() ?? []).OrderByDescending(o => o.Id).ToList(); //.Where(o => o.HasMeasuringAccess(LoggedInModel.CustomerDto?.Id, LoggedInModel.IsRevisor)).OrderBy(o => o.DateOfReceipt).ToList(); // break; // case 2: // if (OrderItemDtos == null) // OrderItemDtos = (await FruitBankSignalRClient.GetAllOrderItemDtos() ?? []).OrderByDescending(o => o.Id).ToList(); //.Where(o => o.HasMeasuringAccess(LoggedInModel.CustomerDto?.Id, LoggedInModel.IsRevisor)).OrderBy(o => o.DateOfReceipt).ToList(); // break; // } } }