Warehouses #1

Merged
trent merged 159 commits from Warehouses into master 2026-01-10 20:24:17 +00:00
25 changed files with 474 additions and 198 deletions
Showing only changes of commit 55f7ed76fd - Show all commits

View File

@@ -16,155 +16,155 @@ public class HangfireJobsController(
IRecurringJobManager recurringJobManager, IRecurringJobManager recurringJobManager,
ITaskSchedulerService service) : Controller ITaskSchedulerService service) : Controller
{ {
[HttpGet("GetJobsToRun")] // [HttpGet("GetJobsToRun")]
public async Task<ActionResult<IEnumerable<JobModel>>> GetJobsToRun() // public async Task<ActionResult<IEnumerable<JobModel>>> GetJobsToRun()
{ // {
IList<JobModel> jobsToRun = new List<JobModel>(); // IList<JobModel> jobsToRun = new List<JobModel>();
//
using (IStorageConnection? connection = jobStorage.GetConnection()) // using (IStorageConnection? connection = jobStorage.GetConnection())
{ // {
IList<RecurringJobDto>? recurringJobs = connection.GetRecurringJobs(); // IList<RecurringJobDto>? recurringJobs = connection.GetRecurringJobs();
IList<TaskSchedulerDto>? taskSchedulers = (await service.GetTaskSchedulers()).ToList(); // IList<TaskSchedulerDto>? taskSchedulers = (await service.GetTaskSchedulers()).ToList();
//
foreach (var recurringJob in recurringJobs) // foreach (var recurringJob in recurringJobs)
{ // {
TaskSchedulerDto? taskScheduler = taskSchedulers?.FirstOrDefault(ts => ts.Name == recurringJob.Id); // TaskSchedulerDto? taskScheduler = taskSchedulers?.FirstOrDefault(ts => ts.Name == recurringJob.Id);
//
if (taskScheduler != null) // if (taskScheduler != null)
{ // {
jobsToRun.Add(new JobModel(recurringJob.Id, recurringJob.Cron, taskScheduler.Path, // jobsToRun.Add(new JobModel(recurringJob.Id, recurringJob.Cron, taskScheduler.Path,
recurringJob.LastExecution, recurringJob.NextExecution, recurringJob.Job)); // recurringJob.LastExecution, recurringJob.NextExecution, recurringJob.Job));
} // }
} // }
} // }
//
return Ok(jobsToRun); // return Ok(jobsToRun);
} // }
//
[HttpPost("run")] // [HttpPost("run")]
public async Task<IActionResult> RunJobs() // public async Task<IActionResult> RunJobs()
{ // {
var jobsToRun = (await GetJobsToRun()).Value?.ToList(); // var jobsToRun = (await GetJobsToRun()).Value?.ToList();
//
if (jobsToRun == null || jobsToRun.Count == 0) // if (jobsToRun == null || jobsToRun.Count == 0)
{ // {
return BadRequest("Nie udało się pobrać zadań do uruchomienia."); // return BadRequest("Nie udało się pobrać zadań do uruchomienia.");
} // }
//
foreach (var job in jobsToRun) // foreach (var job in jobsToRun)
{ // {
if (!string.IsNullOrEmpty(job.Path)) // if (!string.IsNullOrEmpty(job.Path))
{ // {
recurringJobManager.AddOrUpdate(job.JobId, () => RunConsoleApplication(job.Path), job.Cron, // recurringJobManager.AddOrUpdate(job.JobId, () => RunConsoleApplication(job.Path), job.Cron,
new RecurringJobOptions { TimeZone = TimeZoneInfo.Local }); // new RecurringJobOptions { TimeZone = TimeZoneInfo.Local });
} // }
} // }
//
return Ok("Zadania zostały zaplanowane do uruchamiania zgodnie z ich CRON."); // return Ok("Zadania zostały zaplanowane do uruchamiania zgodnie z ich CRON.");
} // }
//
[HttpPost("add")] // [HttpPost("add")]
public async Task<IActionResult> AddTask([FromBody] TaskSchedulerDto taskSchedulerDto) // public async Task<IActionResult> AddTask([FromBody] TaskSchedulerDto taskSchedulerDto)
{ // {
var taskScheduler = new OrdersManagementDataModel.Entities.TaskScheduler // var taskScheduler = new OrdersManagementDataModel.Entities.TaskScheduler
{ // {
Name = taskSchedulerDto.Name, // Name = taskSchedulerDto.Name,
Path = taskSchedulerDto.Path, // Path = taskSchedulerDto.Path,
CronOptions = taskSchedulerDto.CronOptions, // CronOptions = taskSchedulerDto.CronOptions,
CreateDate = DateTime.UtcNow // CreateDate = DateTime.UtcNow
}; // };
//
int result = await service.AddTaskScheduler(taskSchedulerDto); // int result = await service.AddTaskScheduler(taskSchedulerDto);
//
if (result == 0) // if (result == 0)
{ // {
return BadRequest("Nie udało się dodać zadania."); // return BadRequest("Nie udało się dodać zadania.");
} // }
//
recurringJobManager.AddOrUpdate(taskScheduler.Name, () => RunConsoleApplication(taskScheduler.Path), // recurringJobManager.AddOrUpdate(taskScheduler.Name, () => RunConsoleApplication(taskScheduler.Path),
taskScheduler.CronOptions, new RecurringJobOptions { TimeZone = TimeZoneInfo.Local }); // taskScheduler.CronOptions, new RecurringJobOptions { TimeZone = TimeZoneInfo.Local });
//
return Ok("Zadanie zostało dodane."); // return Ok("Zadanie zostało dodane.");
} // }
//
[HttpPost("delete")] // [HttpPost("delete")]
public async Task<IActionResult> DeleteTask([FromBody] TaskSchedulerDto taskSchedulerDto) // public async Task<IActionResult> DeleteTask([FromBody] TaskSchedulerDto taskSchedulerDto)
{ // {
int result = await service.DeleteTaskScheduler(taskSchedulerDto.RowPointer); // int result = await service.DeleteTaskScheduler(taskSchedulerDto.RowPointer);
//
if (result == 0) // if (result == 0)
{ // {
return BadRequest("Nie udało się usunąć zadania."); // return BadRequest("Nie udało się usunąć zadania.");
} // }
//
recurringJobManager.RemoveIfExists(taskSchedulerDto.Name); // recurringJobManager.RemoveIfExists(taskSchedulerDto.Name);
//
return Ok("Zadanie zostało usunięte."); // return Ok("Zadanie zostało usunięte.");
} // }
//
[HttpGet] // [HttpGet]
public async Task<ActionResult<IEnumerable<TaskSchedulerDto>>> GetTasks() // public async Task<ActionResult<IEnumerable<TaskSchedulerDto>>> GetTasks()
{ // {
var tasks = await service.GetTaskSchedulers(); // var tasks = await service.GetTaskSchedulers();
//
foreach (TaskSchedulerDto taskSchedulerDto in tasks) // foreach (TaskSchedulerDto taskSchedulerDto in tasks)
{ // {
var job = GetJob(taskSchedulerDto.Name); // var job = GetJob(taskSchedulerDto.Name);
taskSchedulerDto.LastExecution = job?.LastExecution; // taskSchedulerDto.LastExecution = job?.LastExecution;
taskSchedulerDto.NextExecution = job?.NextExecution; // taskSchedulerDto.NextExecution = job?.NextExecution;
} // }
//
return Ok(tasks); // return Ok(tasks);
} // }
//
[HttpGet("by-name")] // [HttpGet("by-name")]
public async Task<ActionResult<TaskSchedulerDto>> GetTaskSchedulerByTaskName([FromQuery] string name) // public async Task<ActionResult<TaskSchedulerDto>> GetTaskSchedulerByTaskName([FromQuery] string name)
{ // {
var taskSchedulerDto = await service.GetTaskSchedulerByTaskName(name); // var taskSchedulerDto = await service.GetTaskSchedulerByTaskName(name);
//
if (taskSchedulerDto == null) return NotFound(); // if (taskSchedulerDto == null) return NotFound();
//
var job = GetJob(taskSchedulerDto.Name); // var job = GetJob(taskSchedulerDto.Name);
taskSchedulerDto.LastExecution = job?.LastExecution; // taskSchedulerDto.LastExecution = job?.LastExecution;
taskSchedulerDto.NextExecution = job?.NextExecution; // taskSchedulerDto.NextExecution = job?.NextExecution;
//
return Ok(taskSchedulerDto); // return Ok(taskSchedulerDto);
} // }
//
private RecurringJobDto? GetJob(string jobId) // private RecurringJobDto? GetJob(string jobId)
{ // {
using IStorageConnection? connection = jobStorage.GetConnection(); // using IStorageConnection? connection = jobStorage.GetConnection();
IList<RecurringJobDto>? recurringJobs = connection.GetRecurringJobs(); // IList<RecurringJobDto>? recurringJobs = connection.GetRecurringJobs();
return recurringJobs.FirstOrDefault(x => x.Id == jobId); // return recurringJobs.FirstOrDefault(x => x.Id == jobId);
} // }
//
public void RunConsoleApplication(string pathToApp) // public void RunConsoleApplication(string pathToApp)
{ // {
try // try
{ // {
var process = new Process // var process = new Process
{ // {
StartInfo = new ProcessStartInfo // StartInfo = new ProcessStartInfo
{ // {
FileName = pathToApp, // FileName = pathToApp,
UseShellExecute = false, // UseShellExecute = false,
RedirectStandardOutput = true, // RedirectStandardOutput = true,
RedirectStandardError = true, // RedirectStandardError = true,
CreateNoWindow = true, // CreateNoWindow = true,
WorkingDirectory = Path.GetDirectoryName(pathToApp) // WorkingDirectory = Path.GetDirectoryName(pathToApp)
} // }
}; // };
process.Start(); // process.Start();
string output = process.StandardOutput.ReadToEnd(); // string output = process.StandardOutput.ReadToEnd();
string error = process.StandardError.ReadToEnd(); // string error = process.StandardError.ReadToEnd();
process.WaitForExit(); // process.WaitForExit();
//
Console.WriteLine($"Output: {output}"); // Console.WriteLine($"Output: {output}");
Console.WriteLine($"Error: {error}"); // Console.WriteLine($"Error: {error}");
} // }
catch (Exception ex) // catch (Exception ex)
{ // {
Console.WriteLine($"Error executing console application: {ex.Message}"); // Console.WriteLine($"Error executing console application: {ex.Message}");
} // }
} // }
} }

View File

@@ -23,4 +23,16 @@ public class WzHeaderController(IWzHeaderService service, IMaterialTransactionSe
await materialTransactionService.GetByCustomerNumber(customerNumber, customerSequence); await materialTransactionService.GetByCustomerNumber(customerNumber, customerSequence);
return Ok(materialTransactions); return Ok(materialTransactions);
} }
[HttpPost]
public async Task<ActionResult> CreateHeader([FromBody] WzHeaderDto wzHeader)
{
if (wzHeader == null)
{
return BadRequest("WzHeader cannot be null.");
}
await service.CreateHeader(wzHeader);
return CreatedAtAction(nameof(CreateHeader), wzHeader);
}
} }

View File

@@ -0,0 +1,29 @@
using Microsoft.AspNetCore.Mvc;
using SytelineSaAppEfDataModel.Dtos;
using SytelineSaAppEfDataModel.Services;
namespace FaKrosnoApi.Controllers;
[ApiController]
[Route("api/[controller]")]
public class WzRowMeyleController(IWzRowMeyleService service) : Controller
{
[HttpGet]
public async Task<ActionResult<IEnumerable<WzRowMeyleDto>>> GetAll()
{
IEnumerable<WzRowMeyleDto> wzRows = await service.GetAll();
return Ok(wzRows);
}
[HttpPost]
public async Task<ActionResult> CreateRows([FromBody] IEnumerable<WzRowMeyleDto> rows)
{
if (rows == null || !rows.Any())
{
return BadRequest("No rows provided.");
}
await service.CreateRows(rows);
return CreatedAtAction(nameof(GetAll), new { count = rows.Count() }, rows);
}
}

View File

@@ -103,6 +103,7 @@ builder.Services.AddScoped<IProductService, ProductService>();
builder.Services.AddScoped<IMaterialTransactionService, MaterialTransactionService>(); builder.Services.AddScoped<IMaterialTransactionService, MaterialTransactionService>();
builder.Services.AddScoped<IWzClientService, WzClientService>(); builder.Services.AddScoped<IWzClientService, WzClientService>();
builder.Services.AddScoped<IWzHeaderService, WzHeaderService>(); builder.Services.AddScoped<IWzHeaderService, WzHeaderService>();
builder.Services.AddScoped<IWzRowMeyleService, WzRowMeyleService>();
builder.Services.AddHostedService<TimedHostedService>(); builder.Services.AddHostedService<TimedHostedService>();

View File

@@ -35,14 +35,14 @@
<MenuItem Text="Zamówienia DELFOR" Url="/" IconCss="fa-solid fa-landmark"></MenuItem> <MenuItem Text="Zamówienia DELFOR" Url="/" IconCss="fa-solid fa-landmark"></MenuItem>
<MenuItem Text="Zarządzanie Indeksami" Url="/Products" IconCss="fa-solid fa-basket-shopping"></MenuItem> <MenuItem Text="Zarządzanie Indeksami" Url="/Products" IconCss="fa-solid fa-basket-shopping"></MenuItem>
<MenuItem Text="Magazyn" Url="/Warehouse" IconCss="fa-solid fa-warehouse"></MenuItem> <MenuItem Text="Magazyn" Url="/Warehouse" IconCss="fa-solid fa-warehouse"></MenuItem>
@* <MenuItem Text="Zamówienia klienta EDI" Url="/EdiCustomerOrders" IconCss="fa-solid fa-list-check"></MenuItem> *@ @if (IsAdminRoute())
@* <MenuItem Text="Zamówienia klienta" Url="/CustomerOrders" IconCss="fa-solid fa-database"></MenuItem> *@
@if (UserName == "pkus")
{ {
<MenuItem Text="Admin" IconCss="fa-solid fa-screwdriver-wrench"> <MenuItem Text="Administracja" Url="/Admin/PK" IconCss="fa-solid fa-screwdriver-wrench">
<MenuItems> <MenuItems>
<MenuItem Text = "Użytkownicy" Url = "/Admin/UsersManager" IconCss="fa-solid fa-user-tie"></MenuItem> <MenuItem Text="Użytkownicy" Url = "/Admin/PK/UsersManager" IconCss="fa-solid fa-user-tie"></MenuItem>
<MenuItem Text= "Scheduler" Url = "/Admin/Scheduler" IconCss="fa-solid fa-calendar-week"></MenuItem> <MenuItem Text="Scheduler" Url = "/Admin/PK/Scheduler" IconCss="fa-solid fa-calendar-week"></MenuItem>
<MenuItem Text="Zamówienia klienta EDI" Url="/Admin/PK/EdiCustomerOrders" IconCss="fa-solid fa-list-check"></MenuItem>
<MenuItem Text="Zamówienia klienta" Url="/Admin/PK/CustomerOrders" IconCss="fa-solid fa-database"></MenuItem>
</MenuItems> </MenuItems>
</MenuItem> </MenuItem>
} }
@@ -64,6 +64,12 @@
private bool IsAuthenticated { get; set; } private bool IsAuthenticated { get; set; }
private string UserName { get; set; } = string.Empty; private string UserName { get; set; } = string.Empty;
private bool IsAdminRoute()
{
var path = new Uri(NavigationManager.Uri).AbsolutePath;
return path.StartsWith("/admin", StringComparison.OrdinalIgnoreCase);
}
protected override void OnInitialized() protected override void OnInitialized()
{ {
// ClaimsPrincipal currentUser = AuthenticationStateProvider.GetCurrentUser(); // ClaimsPrincipal currentUser = AuthenticationStateProvider.GetCurrentUser();

View File

@@ -1,4 +1,4 @@
@page "/Admin/Scheduler" @page "/Admin/PK/Scheduler"
@using System.Security.Claims @using System.Security.Claims
@using Microsoft.AspNetCore.Authorization @using Microsoft.AspNetCore.Authorization

View File

@@ -1,4 +1,4 @@
@page "/admin/UsersManager" @page "/Admin/PK/UsersManager"
@using System.Security.Claims @using System.Security.Claims
@using Microsoft.AspNetCore.Authorization @using Microsoft.AspNetCore.Authorization

View File

@@ -1,4 +1,4 @@
@page "/CustomerOrder/{CustomerOrderId:guid}" @page "/Admin/PK/CustomerOrder/{CustomerOrderId:guid}"
@inject CustomerOrderService CustomerOrderService @inject CustomerOrderService CustomerOrderService
@inject ScheduleOrderService ScheduleOrderService @inject ScheduleOrderService ScheduleOrderService

View File

@@ -1,4 +1,4 @@
@page "/CustomerOrders" @page "/Admin/PK/CustomerOrders"
@inject CustomerOrderService CustomerOrderService @inject CustomerOrderService CustomerOrderService
@inject NavigationManager NavigationManager @inject NavigationManager NavigationManager

View File

@@ -1,4 +1,4 @@
@page "/CustomerOrdersTranslations" @page "/admin"
@using SytelineSaAppEfDataModel.Dtos @using SytelineSaAppEfDataModel.Dtos
@using Syncfusion.Blazor.Cards @using Syncfusion.Blazor.Cards

View File

@@ -1,4 +1,4 @@
@page "/EdiCustomerOrder/{CustomerOrderId:guid}" @page "/Admin/PK/EdiCustomerOrder/{CustomerOrderId:guid}"
@inject EdiCustomerOrderService EdiCustomerOrderService @inject EdiCustomerOrderService EdiCustomerOrderService
@inject NavigationManager NavigationManager @inject NavigationManager NavigationManager

View File

@@ -1,4 +1,4 @@
@page "/EdiCustomerOrders" @page "/Admin/PK/EdiCustomerOrders"
@inject EdiCustomerOrderService EdiCustomerOrderService @inject EdiCustomerOrderService EdiCustomerOrderService
@inject NavigationManager NavigationManager @inject NavigationManager NavigationManager

View File

@@ -3,6 +3,10 @@
@using Syncfusion.Blazor.Cards @using Syncfusion.Blazor.Cards
@using Syncfusion.Blazor.Grids @using Syncfusion.Blazor.Grids
@using SytelineSaAppEfDataModel.Dtos @using SytelineSaAppEfDataModel.Dtos
@using Syncfusion.Blazor.DropDowns
@using FilterType = Syncfusion.Blazor.Grids.FilterType
@using SelectionMode = Syncfusion.Blazor.Grids.SelectionMode
@using Syncfusion.Blazor.Navigations
@inject WarehouseService WarehouseService @inject WarehouseService WarehouseService
@@ -12,34 +16,41 @@
<h3 class="text-primary">Dokumenty WZ na Magazynie</h3> <h3 class="text-primary">Dokumenty WZ na Magazynie</h3>
</CardHeader> </CardHeader>
<CardContent> <CardContent>
@* <SfGrid @ref="" *@ <h5 class="text-primary mb-3">Klient</h5>
@* AllowFiltering="true" *@ <SfDropDownList TValue="Guid?" TItem="WzClientDto" DataSource="@_clients" Placeholder="Wybierz Klienta">
@* AllowPaging="true" *@ <DropDownListFieldSettings Value="ID" Text="Name"/>
@* AllowSorting="true" *@ <DropDownListEvents TValue="Guid?" TItem="WzClientDto" ValueChange="OnValueChange"/>
@* AllowSelection="true" *@ </SfDropDownList>
@* TValue="" *@ @if (_isVisible)
@* DataSource="" *@ {
@* EnableAdaptiveUI="true"> *@ <h5 class="text-primary mb-3">Dokumenty WZ</h5>
@* <GridTemplates> *@ <SfGrid @ref="_grid"
@* <DetailTemplate> *@ AllowFiltering="true"
@* @{ *@ AllowPaging="true"
@* } *@ AllowSorting="true"
@* </DetailTemplate> *@ AllowSelection="true"
@* </GridTemplates> *@ TValue="MaterialTransactionDto"
@* <GridColumns> *@ DataSource="@_materialTransactions"
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.CustomerOrderNumber) HeaderText="Numer Zamówienia" Width="110"></GridColumn> #1# *@ EnableAdaptiveUI="true">
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.CustomerPoNumber) HeaderText="Zamówienie Klienta" Width="100"></GridColumn> #1# *@ <GridColumns>
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.CustomerNumber) HeaderText="Numer Klienta" Width="90"></GridColumn> #1# *@ <GridColumn Field=@nameof(MaterialTransactionDto.MTGroupNum) HeaderText="Numer WZ" TextAlign="TextAlign.Center" Width="110"></GridColumn>
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.CustomerSequence) HeaderText="Odbiorca" Width="80"></GridColumn> #1# *@ <GridColumn Field=@nameof(MaterialTransactionDto.Item) HeaderText="Indeks" TextAlign="TextAlign.Center" Width="80"></GridColumn>
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.CreateDate) HeaderText="Data Otrzymania" TextAlign="TextAlign.Center" Width="110"></GridColumn> #1# *@ <GridColumn Field=@nameof(MaterialTransactionDto.Qty) HeaderText="Ilość sztuk" TextAlign="TextAlign.Right" Width="90"></GridColumn>
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.SlOrderNumber) HeaderText="Zamówienie SL" Width="100"></GridColumn> #1# *@ <GridColumn Field=@nameof(MaterialTransactionDto.CreateDate) HeaderText="Data utworzenia" TextAlign="TextAlign.Center" Width="100"></GridColumn>
@* $1$ <GridColumn Field=@nameof(EdiCustomerOrderDto.SentToSl) HeaderText="Wysłane do SL" TextAlign="TextAlign.Center" Width="80"></GridColumn> #1# *@ <GridColumn Field=@nameof(MaterialTransactionDto.RefNum) HeaderText="Numer zamówienia" TextAlign="TextAlign.Center" Width="110"></GridColumn>
@* </GridColumns> *@ </GridColumns>
@* <GridFilterSettings Type="FilterType.Excel"/> *@ <SfToolbar>
@* <GridPageSettings PageSize="10"/> *@ <ToolbarItems>
@* <GridSelectionSettings Mode="SelectionMode.Row" Type="SelectionType.Multiple"/> *@ <ToolbarItem Type="ItemType.Button" Text="Utwórz Packing List" Id="CreatePackingList"
@* $1$ <GridEvents TValue="EdiCustomerOrderDto" OnRecordDoubleClick="OnRowDoubleClick" RowSelected="RowSelected"/> #1# *@ PrefixIcon="e-icons e-save" OnClick="CreatePackingList"/>
@* </SfGrid> *@ </ToolbarItems>
</SfToolbar>
<GridFilterSettings Type="FilterType.Excel"/>
<GridPageSettings PageSize="10" PageSizes="@(new[] { 10, 20, 50, 100 })"/>
<GridSelectionSettings Mode="SelectionMode.Row" Type="SelectionType.Multiple"/>
@* <GridEvents TValue="EdiCustomerOrderDto" OnRecordDoubleClick="OnRowDoubleClick" RowSelected="RowSelected"/> *@
</SfGrid>
}
</CardContent> </CardContent>
<CardFooter> <CardFooter>
<small class="text-muted">FA Krosno Manager © @(DateTime.Now.Year)</small> <small class="text-muted">FA Krosno Manager © @(DateTime.Now.Year)</small>
@@ -48,11 +59,68 @@
</div> </div>
@code { @code {
private SfGrid<MaterialTransactionDto> _grid;
IEnumerable<WzClientDto> _clients = new List<WzClientDto>();
IEnumerable<MaterialTransactionDto> _materialTransactions = new List<MaterialTransactionDto>();
WzClientDto? _selectedClient;
bool _isVisible = false;
protected override async Task OnAfterRenderAsync(bool firstRender) protected override async Task OnAfterRenderAsync(bool firstRender)
{ {
if (firstRender) if (firstRender)
{ {
IEnumerable<MaterialTransactionDto> task = await WarehouseService.GetAllClientWzsAsync("K005531", 0); _clients = await WarehouseService.GetAllClientsAsync();
StateHasChanged();
}
}
private async Task OnValueChange(ChangeEventArgs<Guid?, WzClientDto> args)
{
if (args.Value.HasValue)
{
_selectedClient = args.ItemData;
_isVisible = true;
_materialTransactions = await WarehouseService.GetAllClientWzsAsync(_selectedClient.CustomerNumber, _selectedClient.CustomerSequence ?? 0);
}
else
{
_selectedClient = null;
_isVisible = false;
}
StateHasChanged();
}
private async Task CreatePackingList()
{
var selectedRecords = await _grid.GetSelectedRecordsAsync();
if (selectedRecords.Any())
{
WzHeaderDto wzHeader = new WzHeaderDto
{
ID = Guid.NewGuid(),
FK_Client = _selectedClient?.ID
};
await WarehouseService.CreateWzHeaderAsync(wzHeader);
switch (_selectedClient?.Name.ToUpper())
{
case "MEYLE":
IList<WzRowMeyleDto> rows = new List<WzRowMeyleDto>();
foreach (MaterialTransactionDto materialTransactionDto in selectedRecords)
{
rows.Add(new WzRowMeyleDto
{
ID = Guid.NewGuid(),
Quantity = Math.Abs((int?)materialTransactionDto.Qty ?? 0),
//ItemNumber =
});
}
break;
}
} }
} }
} }

View File

@@ -0,0 +1,7 @@
@page "/Warehouse/PackList"
<h3>WarehousePackList</h3>
@code {
}

View File

@@ -2,13 +2,15 @@ using SytelineSaAppEfDataModel.Dtos;
namespace OrdersManagement.Services; namespace OrdersManagement.Services;
public class WarehouseService public class WarehouseService(IHttpClientFactory httpClientFactory)
{ {
private readonly HttpClient _httpClient; private readonly HttpClient _httpClient = httpClientFactory.CreateClient("FaKrosnoApi");
public WarehouseService(IHttpClientFactory httpClientFactory) public async Task<IEnumerable<WzClientDto>> GetAllClientsAsync()
{ {
_httpClient = httpClientFactory.CreateClient("FaKrosnoApi"); var response = await _httpClient.GetAsync($"api/WzClient");
response.EnsureSuccessStatusCode();
return await response.Content.ReadFromJsonAsync<IEnumerable<WzClientDto>>();
} }
public async Task<IEnumerable<MaterialTransactionDto>> GetAllClientWzsAsync(string customerNumber, int customerSequence) public async Task<IEnumerable<MaterialTransactionDto>> GetAllClientWzsAsync(string customerNumber, int customerSequence)
@@ -18,4 +20,24 @@ public class WarehouseService
response.EnsureSuccessStatusCode(); response.EnsureSuccessStatusCode();
return await response.Content.ReadFromJsonAsync<IEnumerable<MaterialTransactionDto>>(); return await response.Content.ReadFromJsonAsync<IEnumerable<MaterialTransactionDto>>();
} }
public async Task CreateWzHeaderAsync(WzHeaderDto wzHeader)
{
var response = await _httpClient.PostAsJsonAsync("api/WzHeader", wzHeader);
response.EnsureSuccessStatusCode();
if (response.StatusCode != System.Net.HttpStatusCode.Created)
{
throw new Exception("Failed to create WzHeader");
}
}
public async Task CreateWzRowMeyleAsync(IEnumerable<WzRowMeyleDto> wzRowMeyles)
{
var response = await _httpClient.PostAsJsonAsync("api/WzRowMeyle", wzRowMeyles);
response.EnsureSuccessStatusCode();
if (response.StatusCode != System.Net.HttpStatusCode.Created)
{
throw new Exception("Failed to create WzRowMeyle");
}
}
} }

View File

@@ -6,4 +6,5 @@ public class WzClientDto
public string CustomerNumber { get; set; } public string CustomerNumber { get; set; }
public int? CustomerSequence { get; set; } public int? CustomerSequence { get; set; }
public DateTime CreatedDate { get; set; } public DateTime CreatedDate { get; set; }
public string Name { get; set; }
} }

View File

@@ -0,0 +1,13 @@
namespace SytelineSaAppEfDataModel.Dtos;
public class WzRowMeyleDto
{
public Guid ID { get; set; }
public Guid? FK_Header { get; set; }
public string OrderNumber { get; set; }
public string ItemNumber { get; set; }
public int? Quantity { get; set; }
public int? PalletNumber { get; set; }
public string WzNumber { get; set; }
public string PartNumber { get; set; }
}

View File

@@ -6,4 +6,5 @@ public class WzClient
public string CustomerNumber { get; set; } public string CustomerNumber { get; set; }
public int? CustomerSequence { get; set; } public int? CustomerSequence { get; set; }
public DateTime CreatedDate { get; set; } public DateTime CreatedDate { get; set; }
public string Name { get; set; }
} }

View File

@@ -0,0 +1,16 @@
namespace SytelineSaAppEfDataModel.Entities;
public class WzRowMeyle
{
public Guid ID { get; set; }
public Guid? FK_Header { get; set; }
public string OrderNumber { get; set; }
public string ItemNumber { get; set; }
public int? Quantity { get; set; }
public int? PalletNumber { get; set; }
public string WzNumber { get; set; }
public string PartNumber { get; set; }
// Navigation property
public WzHeader Header { get; set; }
}

View File

@@ -21,6 +21,8 @@ namespace SytelineSaAppEfDataModel
CreateMap<EdiUser, EdiUserDto>().ReverseMap(); CreateMap<EdiUser, EdiUserDto>().ReverseMap();
CreateMap<MaterialTransaction, MaterialTransactionDto>().ReverseMap(); CreateMap<MaterialTransaction, MaterialTransactionDto>().ReverseMap();
CreateMap<WzClient, WzClientDto>().ReverseMap(); CreateMap<WzClient, WzClientDto>().ReverseMap();
CreateMap<WzHeader, WzHeaderDto>().ReverseMap();
CreateMap<WzRowMeyle, WzRowMeyleDto>().ReverseMap();
} }
} }
} }

View File

@@ -5,4 +5,5 @@ namespace SytelineSaAppEfDataModel.Services;
public interface IWzHeaderService public interface IWzHeaderService
{ {
Task<IEnumerable<WzHeaderDto>> GetAll(); Task<IEnumerable<WzHeaderDto>> GetAll();
Task CreateHeader(WzHeaderDto wzHeader);
} }

View File

@@ -0,0 +1,9 @@
using SytelineSaAppEfDataModel.Dtos;
namespace SytelineSaAppEfDataModel.Services;
public interface IWzRowMeyleService
{
Task<IEnumerable<WzRowMeyleDto>> GetAll();
Task CreateRows(IEnumerable<WzRowMeyleDto> rows);
}

View File

@@ -1,6 +1,7 @@
using AutoMapper; using AutoMapper;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using SytelineSaAppEfDataModel.Dtos; using SytelineSaAppEfDataModel.Dtos;
using SytelineSaAppEfDataModel.Entities;
namespace SytelineSaAppEfDataModel.Services; namespace SytelineSaAppEfDataModel.Services;
@@ -10,4 +11,11 @@ public class WzHeaderService(SytelineSaAppDbContext context, IMapper mapper) : I
{ {
return await context.WzHeaders.Select(x => mapper.Map<WzHeaderDto>(x)).ToListAsync(); return await context.WzHeaders.Select(x => mapper.Map<WzHeaderDto>(x)).ToListAsync();
} }
public async Task CreateHeader(WzHeaderDto wzHeader)
{
var entity = mapper.Map<WzHeader>(wzHeader);
await context.WzHeaders.AddAsync(entity);
await context.SaveChangesAsync();
}
} }

View File

@@ -0,0 +1,21 @@
using AutoMapper;
using Microsoft.EntityFrameworkCore;
using SytelineSaAppEfDataModel.Dtos;
using SytelineSaAppEfDataModel.Entities;
namespace SytelineSaAppEfDataModel.Services;
public class WzRowMeyleService(SytelineSaAppDbContext context, IMapper mapper) : IWzRowMeyleService
{
public async Task<IEnumerable<WzRowMeyleDto>> GetAll()
{
return await context.WzRowsMeyle.Select(x => mapper.Map<WzRowMeyleDto>(x)).ToListAsync();
}
public async Task CreateRows(IEnumerable<WzRowMeyleDto> rows)
{
var entities = mapper.Map<IEnumerable<WzRowMeyle>>(rows);
await context.WzRowsMeyle.AddRangeAsync(entities);
await context.SaveChangesAsync();
}
}

View File

@@ -24,6 +24,7 @@ namespace SytelineSaAppEfDataModel
public DbSet<WzClient> WzClients { get; set; } public DbSet<WzClient> WzClients { get; set; }
public DbSet<WzHeader> WzHeaders { get; set; } public DbSet<WzHeader> WzHeaders { get; set; }
public DbSet<WzRowMeyle> WzRowsMeyle { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{ {
var configuration = new ConfigurationBuilder() var configuration = new ConfigurationBuilder()
@@ -799,7 +800,7 @@ namespace SytelineSaAppEfDataModel
entity.Property(e => e.WhseSplit) entity.Property(e => e.WhseSplit)
.HasColumnName("WhseSplit") .HasColumnName("WhseSplit")
.HasColumnType("tinyint") .HasColumnType("tinyint")
.IsRequired(false);; .IsRequired(false);
entity.Property(e => e.VariableId) entity.Property(e => e.VariableId)
.HasColumnName("VariableId") .HasColumnName("VariableId")
@@ -930,6 +931,64 @@ namespace SytelineSaAppEfDataModel
.HasColumnName("CreatedDate") .HasColumnName("CreatedDate")
.HasColumnType("timestamp") .HasColumnType("timestamp")
.IsRowVersion(); .IsRowVersion();
entity.Property(e => e.Name)
.HasColumnName("Name")
.HasMaxLength(255)
.IsRequired(false);
});
modelBuilder.Entity<WzRowMeyle>(entity =>
{
entity.ToTable("wz_row_meyle");
entity.HasKey(e => e.ID);
entity.Property(e => e.ID)
.HasColumnName("ID")
.HasColumnType("uniqueidentifier")
.HasDefaultValueSql("newid()");
entity.Property(e => e.FK_Header)
.HasColumnName("FK_Header")
.HasColumnType("uniqueidentifier")
.IsRequired(false);
entity.Property(e => e.OrderNumber)
.HasColumnName("order_number")
.HasMaxLength(100)
.IsRequired(false);
entity.Property(e => e.ItemNumber)
.HasColumnName("item_number")
.HasMaxLength(100)
.IsRequired(false);
entity.Property(e => e.Quantity)
.HasColumnName("quantity")
.HasColumnType("int")
.IsRequired(false);
entity.Property(e => e.PalletNumber)
.HasColumnName("pallet_number")
.HasColumnType("int")
.IsRequired(false);
entity.Property(e => e.WzNumber)
.HasColumnName("wz_number")
.HasMaxLength(100)
.IsRequired(false);
entity.Property(e => e.PartNumber)
.HasColumnName("part_number")
.HasMaxLength(100)
.IsRequired(false);
// Relationship
entity.HasOne(e => e.Header)
.WithMany()
.HasForeignKey(e => e.FK_Header)
.HasConstraintName("wz_rows_meyle_wz_header_ID_fk");
}); });
} }
} }