Added Sending to CustomerOrders more than one order (selected ones)
This commit is contained in:
@@ -40,23 +40,23 @@
|
||||
</div>
|
||||
</div>
|
||||
<br/>
|
||||
<SortableList TItem="EdiCustomerOrderTranslateDto" Data="_ediCustomerOrderTranslate">
|
||||
<ItemTemplate>
|
||||
<u>Id:</u> <b>@context.Id</b><br />
|
||||
<u>CoEdiOrder:</u> <b>@context.CoEdiOrder</b><br />
|
||||
<u>CoRowPointer:</u> <b>@context.CoRowPointer</b><br />
|
||||
<u>CoCoNum:</u> <b>@context.CoCoNum</b><br />
|
||||
<u>CoType:</u> <b>@context.CoType</b><br />
|
||||
<u>CoTakenBy:</u> <b>@context.CoTakenBy</b><br />
|
||||
<u>EdiCoCoNum:</u> <b>@context.EdiCoCoNum</b><br />
|
||||
<u>OrdersCount:</u> <b>@context.OrdersCount</b><br />
|
||||
<u>OrderFound:</u> <b>@context.OrderFound</b><br />
|
||||
<u>CreatedDate:</u> <b>@context.CreatedDate.ToString("yyyy-MM-dd HH:mm:ss")</b><br />
|
||||
<u>FoundNumbers:</u> <b>@context.FoundNumbers</b><br />
|
||||
<u>ScheduleOrderId:</u> <b>@context.ScheduleOrderId</b><br />
|
||||
</ItemTemplate>
|
||||
</SortableList>
|
||||
<br />
|
||||
@* <SortableList TItem="EdiCustomerOrderTranslateDto" Data="_ediCustomerOrderTranslate"> *@
|
||||
@* <ItemTemplate> *@
|
||||
@* <u>Id:</u> <b>@context.Id</b><br /> *@
|
||||
@* <u>CoEdiOrder:</u> <b>@context.CoEdiOrder</b><br /> *@
|
||||
@* <u>CoRowPointer:</u> <b>@context.CoRowPointer</b><br /> *@
|
||||
@* <u>CoCoNum:</u> <b>@context.CoCoNum</b><br /> *@
|
||||
@* <u>CoType:</u> <b>@context.CoType</b><br /> *@
|
||||
@* <u>CoTakenBy:</u> <b>@context.CoTakenBy</b><br /> *@
|
||||
@* <u>EdiCoCoNum:</u> <b>@context.EdiCoCoNum</b><br /> *@
|
||||
@* <u>OrdersCount:</u> <b>@context.OrdersCount</b><br /> *@
|
||||
@* <u>OrderFound:</u> <b>@context.OrderFound</b><br /> *@
|
||||
@* <u>CreatedDate:</u> <b>@context.CreatedDate.ToString("yyyy-MM-dd HH:mm:ss")</b><br /> *@
|
||||
@* <u>FoundNumbers:</u> <b>@context.FoundNumbers</b><br /> *@
|
||||
@* <u>ScheduleOrderId:</u> <b>@context.ScheduleOrderId</b><br /> *@
|
||||
@* </ItemTemplate> *@
|
||||
@* </SortableList> *@
|
||||
@* <br /> *@
|
||||
<div class="row">
|
||||
<h3>Indeksy</h3>
|
||||
</div>
|
||||
|
||||
@@ -21,7 +21,7 @@
|
||||
{
|
||||
<div class="row">
|
||||
<div class="col-md-12">
|
||||
<Button Color="ButtonColor.Primary" @onclick="SendOrderToSyteLine">Księguj bieżący</Button>
|
||||
<Button Color="ButtonColor.Primary" @onclick="SendOrderToSyteLine">@_text</Button>
|
||||
</div>
|
||||
</div>
|
||||
}
|
||||
@@ -37,6 +37,7 @@
|
||||
PageSize="20"
|
||||
AllowSelection="true"
|
||||
AllowRowClick="true"
|
||||
SelectionMode="GridSelectionMode.Multiple"
|
||||
OnRowDoubleClick="OnRowDoubleClick"
|
||||
SelectedItemsChanged="SelectedItemsChanged">
|
||||
|
||||
@@ -72,9 +73,22 @@
|
||||
</Grid>
|
||||
</div>
|
||||
|
||||
<Modal @ref="_modal" Title="@_modalDto.Title">
|
||||
<Modal @ref="_modal" Title="@_text">
|
||||
<BodyTemplate>
|
||||
@_modalDto.Body
|
||||
@if (_responses.Any(x => x.Status == 1))
|
||||
{
|
||||
foreach (ResponseDto response in _responses.Where(x => x.Status == 1))
|
||||
{
|
||||
<p>Zamówienie EDI @response.Identifier zostało poprawnie zaksięgowane w Zamówieniach klienta pod numerem '@response.ExternalIdentifier'</p>
|
||||
}
|
||||
}
|
||||
@if (_responses.Any(x => x.Status == 0))
|
||||
{
|
||||
foreach (ResponseDto response in _responses.Where(x => x.Status == 0))
|
||||
{
|
||||
<p>Błąd: Zamówienie EDI @response.Identifier nie zostało poprawnie zaksięgowane w Zamówieniach klienta.<br/>Lista błędów:<br/>@response.Message</p>
|
||||
}
|
||||
}
|
||||
</BodyTemplate>
|
||||
<FooterTemplate>
|
||||
<Button Color="ButtonColor.Primary" @onclick="OnHideModalClick">OK</Button>
|
||||
@@ -83,19 +97,22 @@
|
||||
|
||||
@code {
|
||||
Grid<EdiCustomerOrderDto>? _grid;
|
||||
private IEnumerable<EdiCustomerOrderDto>? _ediCustomerOrders;
|
||||
private List<EdiCustomerOrderDto> _ediCustomerOrders = new();
|
||||
private List<EdiCustomerOrderDto> _selectedEdiCustomerOrders = new();
|
||||
|
||||
private EdiCustomerOrderDto? _selectedEdiCustomerOrder;
|
||||
private List<ResponseDto> _responses = new();
|
||||
|
||||
private Modal _modal = default!;
|
||||
private ModalDto _modalDto = new(null, null);
|
||||
|
||||
private bool _isVisible;
|
||||
private bool _filter;
|
||||
private bool _filter = true;
|
||||
|
||||
private string _text = "Księguj bieżący";
|
||||
|
||||
private async Task<GridDataProviderResult<EdiCustomerOrderDto>> EdiCustomerOrdersDataProvider(GridDataProviderRequest<EdiCustomerOrderDto> request)
|
||||
{
|
||||
_ediCustomerOrders = await EdiCustomerOrderService.GetEdiCustomerOrdersAsync() ?? new List<EdiCustomerOrderDto>();
|
||||
_ediCustomerOrders = (await EdiCustomerOrderService.GetEdiCustomerOrdersAsync() ?? new List<EdiCustomerOrderDto>()).ToList();
|
||||
_ediCustomerOrders = _ediCustomerOrders.OrderByDescending(x => x.CreateDate).ToList();
|
||||
|
||||
if (_filter)
|
||||
@@ -103,6 +120,8 @@
|
||||
_ediCustomerOrders = _ediCustomerOrders.Where(x => x.Posted == 0).ToList();
|
||||
}
|
||||
|
||||
_filter = true;
|
||||
|
||||
StateHasChanged();
|
||||
|
||||
return await Task.FromResult(request.ApplyTo(_ediCustomerOrders));
|
||||
@@ -115,30 +134,39 @@
|
||||
NavigationManager.NavigateTo($"/EdiCustomerOrder/{customerOrderId}");
|
||||
}
|
||||
|
||||
private async void SendOrderToSyteLine()
|
||||
private async Task<bool> SendOrderToSyteLine()
|
||||
{
|
||||
if (_selectedEdiCustomerOrder == null) return;
|
||||
if (!_selectedEdiCustomerOrders.Any()) return false;
|
||||
|
||||
ResponseDto response = await EdiCustomerOrderService.SendOrderToSyteline(_selectedEdiCustomerOrder.CustomerOrderNumber);
|
||||
_responses = new List<ResponseDto>();
|
||||
|
||||
foreach (EdiCustomerOrderDto selectedEdiCustomerOrder in _selectedEdiCustomerOrders)
|
||||
{
|
||||
ResponseDto response = await EdiCustomerOrderService.SendOrderToSyteline(selectedEdiCustomerOrder.CustomerOrderNumber);
|
||||
|
||||
if (response.Status == 1)
|
||||
{
|
||||
_modalDto = new ModalDto("Wysłano", $"Zamówienie EDI {_selectedEdiCustomerOrder.CustomerOrderNumber} zostało poprawnie zaksięgowane w Zamówieniach klienta pod numerem '{_selectedEdiCustomerOrder.EdiCustomerOrderTranslates.FirstOrDefault()?.CoCoNum}'");
|
||||
await _modal.ShowAsync();
|
||||
response.ExternalIdentifier = selectedEdiCustomerOrder.EdiCustomerOrderTranslates.FirstOrDefault()?.CoCoNum;
|
||||
}
|
||||
|
||||
_grid?.RefreshDataAsync();
|
||||
_responses.Add(response);
|
||||
}
|
||||
else
|
||||
{
|
||||
_modalDto = new ModalDto("Błąd", $"Zamówienie EDI {_selectedEdiCustomerOrder.CustomerOrderNumber} nie zostało poprawnie zaksięgowane w Zamówieniach klienta.{Environment.NewLine}Lista błędów:{Environment.NewLine}{response.Message}");
|
||||
|
||||
await _modal.ShowAsync();
|
||||
}
|
||||
_grid?.RefreshDataAsync();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
private void SelectedItemsChanged(HashSet<EdiCustomerOrderDto> obj)
|
||||
{
|
||||
_selectedEdiCustomerOrder = obj.FirstOrDefault() ?? null;
|
||||
_isVisible = _selectedEdiCustomerOrder?.Posted == 0;
|
||||
_isVisible = false;
|
||||
|
||||
if (!obj.Any()) return;
|
||||
|
||||
_selectedEdiCustomerOrders = obj.ToList();
|
||||
_isVisible = _selectedEdiCustomerOrders.Any(x => x.Posted == 0);
|
||||
_text = obj.Count > 1 ? "Księguj zaznaczone" : "Księguj bieżący";
|
||||
}
|
||||
|
||||
private async Task OnHideModalClick()
|
||||
|
||||
@@ -4,7 +4,6 @@
|
||||
|
||||
<div class="container-fluid">
|
||||
<div class="row">
|
||||
<div class="col-md-4 bg-light" style="min-height: 150vh;">
|
||||
<h2 style="margin: 5px">Indeksy:</h2>
|
||||
<Grid @ref="_grid"
|
||||
TItem="ScheduleOrderDetailDto"
|
||||
@@ -22,10 +21,12 @@
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="Id" PropertyName="Id">
|
||||
@context.ID
|
||||
</GridColumn>
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="SalesChannelProductCode" PropertyName="SalesChannelProductCode">
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="SalesChannelProductCode"
|
||||
PropertyName="SalesChannelProductCode">
|
||||
@context.Sc_productCode
|
||||
</GridColumn>
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="ShipperProductCode" PropertyName="ShipperProductCode">
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="ShipperProductCode"
|
||||
PropertyName="ShipperProductCode">
|
||||
@context.Sh_productCode
|
||||
</GridColumn>
|
||||
<GridColumn TItem="ScheduleOrderDetailDto" HeaderText="Price" PropertyName="Price">
|
||||
@@ -33,9 +34,10 @@
|
||||
</GridColumn>
|
||||
</GridColumns>
|
||||
</Grid>
|
||||
</div>
|
||||
@if (_isVisible)
|
||||
{
|
||||
<div id="rightTopContainer" class="col-12 bg-light" style="height: auto;">
|
||||
<div class="row">
|
||||
<h2 style="margin: 5px">Dodatkowe informacje:</h2>
|
||||
<SortableList TItem="ScheduleOrderDetailMiscDto" Data="_scheduleOrderDetailMiscs">
|
||||
<ItemTemplate>
|
||||
@@ -44,12 +46,10 @@
|
||||
</SortableList>
|
||||
</div>
|
||||
}
|
||||
</div>
|
||||
<div class="col-md-8">
|
||||
<div class="row">
|
||||
|
||||
@if (_isVisible)
|
||||
{
|
||||
<div id="rightBottomContainer" class="col-12 bg-light">
|
||||
<div class="row">
|
||||
<h2 style="margin: 5px">Harmonogramy:</h2>
|
||||
<Grid @ref="_detailDetailsGrid"
|
||||
TItem="ScheduleOrderDetailDetailDto"
|
||||
@@ -67,7 +67,8 @@
|
||||
<GridColumn TItem="ScheduleOrderDetailDetailDto" HeaderText="Id" PropertyName="Id">
|
||||
@context.ID
|
||||
</GridColumn>
|
||||
<GridColumn TItem="ScheduleOrderDetailDetailDto" HeaderText="DateFrom" PropertyName="DateFrom">
|
||||
<GridColumn TItem="ScheduleOrderDetailDetailDto" HeaderText="DateFrom"
|
||||
PropertyName="DateFrom">
|
||||
@context.DateFrom
|
||||
</GridColumn>
|
||||
<GridColumn TItem="ScheduleOrderDetailDetailDto" HeaderText="DateTo" PropertyName="DateTo">
|
||||
@@ -81,7 +82,7 @@
|
||||
</div>
|
||||
@if (_isVisibleDetailDetail)
|
||||
{
|
||||
<div id="rightTopContainer" class="col-12 bg-light" style="height: auto;">
|
||||
<div class="row">
|
||||
<h2 style="margin: 5px">Dodatkowe informacje:</h2>
|
||||
<SortableList TItem="ScheduleOrderDetailDetailMiscDto" Data="_scheduleOrderDetailDetailMiscs">
|
||||
<ItemTemplate>
|
||||
@@ -92,13 +93,9 @@
|
||||
}
|
||||
}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@code {
|
||||
[Parameter]
|
||||
public int ScheduleOrderId { get; set; }
|
||||
[Parameter] public int ScheduleOrderId { get; set; }
|
||||
private bool _isVisible;
|
||||
private bool _isVisibleDetailDetail;
|
||||
|
||||
|
||||
@@ -5,12 +5,14 @@
|
||||
public int Status { get; set; }
|
||||
public string Identifier { get; set; }
|
||||
public string? Message { get; set; }
|
||||
public string? ExternalIdentifier { get; set; }
|
||||
|
||||
public ResponseDto(int status, string identifier, string? message)
|
||||
public ResponseDto(int status, string identifier, string? message, string? externalIdentifier)
|
||||
{
|
||||
Status = status;
|
||||
Identifier = identifier;
|
||||
Message = message;
|
||||
ExternalIdentifier = externalIdentifier;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -23,7 +23,7 @@ namespace OrdersManagement.Services
|
||||
|
||||
if (responseMessage.IsSuccessStatusCode)
|
||||
{
|
||||
return new ResponseDto(1, customerOrderNumber, null);
|
||||
return new ResponseDto(1, customerOrderNumber, null, null);
|
||||
}
|
||||
|
||||
string? errorMessage = null;
|
||||
@@ -35,7 +35,7 @@ namespace OrdersManagement.Services
|
||||
errorMessage = string.Join("\r\n", logs.Select(x => x.ErrMsg));
|
||||
}
|
||||
|
||||
return new ResponseDto(0, customerOrderNumber, errorMessage);
|
||||
return new ResponseDto(0, customerOrderNumber, errorMessage, null);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user