Leandro Hernan Rojas bba48a7e28
All checks were successful
CI/CD Pipeline / Build and Deploy with Docker Compose (push) Successful in 10m52s
Update UI y API Vendedores y Mapeo de Quote
2025-04-28 14:38:00 -03:00

209 lines
7.4 KiB
Plaintext

@page "/sales/people"
@using Domain.Entities
@using Domain.Generics
@using phronCare.UIBlazor.Services.Sales
@inject IToastService toastService
@inject NavigationManager Navigation
@inject PeopleService peopleService
<div class="card">
<div class="card-header d-flex justify-content-center align-items-center" style="zoom:80%;">
<h3 class="card-title m-0">Búsqueda de Vendedores</h3>
</div>
<div class="card-body" style="zoom:80%;">
<div class="mb-4 space-y-2">
<input @bind="SearchParams.Name" placeholder="Nombre" class="border rounded p-1 w-full" />
<input @bind="SearchParams.Email" placeholder="Email" class="border rounded p-1 w-full" />
<button class="btn btn-primary rounded-pill" @onclick="BuscarPersonas">
<i class="fas fa-binoculars me-1"></i> Buscar
</button>
<button class="btn btn-success rounded-pill" @onclick="NuevaPersona">
<i class="fas fa-plus me-1"></i> Nueva
</button>
<button class="btn btn-success rounded-pill" @onclick="ExportarExcel">
<i class="fas fa-file-excel me-1"></i> Excel
</button>
<button class="btn btn-secondary rounded-pill" @onclick="Cancelar">
<i class="fas fa-arrow-left me-1"></i> Volver
</button>
</div>
<hr />
<div>
@if (TablaPersonas != null && TablaPersonas.Any())
{
<PhTable Columns="TableColumns"
Data="TablaPersonas"
SelectionField="Id"
RowsPerPage="SearchParams.PageSize"
RenderButtons="true" Buttons="botones"
ShowPageButtons="false"
ShowQuickSearch="false"
RenderSelect="false" />
}
else
{
<p>No hay resultados.</p>
}
</div>
</div>
<div class="card-footer d-flex justify-content-center align-items-center" style="zoom:80%;">
<div class="d-flex align-items-center gap-3">
<button class="btn btn-secondary rounded-pill" @onclick="PrimeraPagina" disabled="@(SearchParams.Page == 1)">
<i class="fas fa-angle-double-left me-1"></i> Primera
</button>
<button class="btn btn-secondary rounded-pill" @onclick="AnteriorPagina" disabled="@(!PuedeRetroceder)">
<i class="fas fa-chevron-left me-1"></i> Anterior
</button>
<span class="mx-2">
Página <strong>@SearchParams.Page</strong> de <strong>@TotalPaginas</strong>
</span>
<button class="btn btn-secondary rounded-pill" @onclick="SiguientePagina" disabled="@(!PuedeAvanzar)">
Siguiente <i class="fas fa-chevron-right ms-1"></i>
</button>
<button class="btn btn-secondary rounded-pill" @onclick="UltimaPagina" disabled="@(SearchParams.Page == TotalPaginas)">
Última <i class="fas fa-angle-double-right ms-1"></i>
</button>
<div class="d-flex align-items-center ms-3">
<input type="number" class="form-control form-control-sm rounded" style="width: 80px;" min="1" max="@TotalPaginas" @bind="PaginaDeseada" />
<button class="btn btn-outline-primary btn-sm ms-2 rounded-pill" @onclick="IrAPagina">
<i class="fas fa-arrow-right-to-bracket me-1"></i> Ir
</button>
</div>
</div>
</div>
</div>
@code {
protected override void OnInitialized()
{
botones = new List<PhTable.ButtonOptions>
{
new PhTable.ButtonOptions
{
Caption = "Editar",
ElementClass = "btn btn-dark btn-sm rounded-pill",
UrlAction = "/sales/personform/",
OnClickAction = async (id) =>
{
if (int.TryParse(id, out var personId))
{
Navigation.NavigateTo($"/sales/personform/{personId}");
}
}
}
};
}
private PeopleSearchParams SearchParams = new();
private PagedResult<EPerson>? PagedResult;
private List<Dictionary<string, object>> TablaPersonas = new();
private List<string> TableColumns = new()
{
"Id", "Nombre", "Email", "Teléfono", "Comision", "Activo"
};
private int PaginaDeseada = 1;
private async Task BuscarPersonas()
{
await CargarPersonas();
}
private async Task CargarPersonas()
{
PagedResult = await peopleService.SearchPeopleAsync(SearchParams);
if (PagedResult?.Items is not null)
{
TablaPersonas = PagedResult.Items.Select(p => new Dictionary<string, object>
{
{ "Id", p.Id },
{ "Nombre", $"{p.Name}" },
{ "Email", p.Email ?? string.Empty },
{ "Teléfono", p.Phone ?? string.Empty },
{ "Comision", p.DefaultCommissionPercent ?? 0 },
{ "Activo", p.Active ? "Sí" : "No" }
}).ToList();
}
}
private async Task ExportarExcel()
{
var searchParams = new PeopleSearchParams
{
Name = SearchParams.Name, // Aquí podés obtener los filtros de los campos en el formulario
Email = SearchParams.Email,
Page = 1,
PageSize = int.MaxValue // Puedes ajustar el tamaño de la página para exportar todos los registros
};
try
{
await peopleService.ExportFilteredAsync(searchParams);
toastService.ShowSuccess("Exportación completada exitosamente.");
}
catch (Exception ex)
{
toastService.ShowError($"{ex.Message}");
}
}
private async Task PrimeraPagina()
{
SearchParams.Page = 1;
await BuscarPersonas();
}
private async Task UltimaPagina()
{
SearchParams.Page = TotalPaginas;
await BuscarPersonas();
}
private async Task IrAPagina()
{
if (PaginaDeseada >= 1 && PaginaDeseada <= TotalPaginas)
{
SearchParams.Page = PaginaDeseada;
await BuscarPersonas();
}
else
{
toastService.ShowWarning("Número de página fuera de rango.");
}
}
private async Task SiguientePagina() => await CambiarPagina(1);
private async Task AnteriorPagina() => await CambiarPagina(-1);
private async Task CambiarPagina(int delta)
{
var nuevaPagina = SearchParams.Page + delta;
if (nuevaPagina >= 1 && nuevaPagina <= TotalPaginas)
{
SearchParams.Page = nuevaPagina;
await CargarPersonas();
}
}
private void NuevaPersona()
{
Navigation.NavigateTo("/sales/personform/");
}
private void Cancelar()
{
Navigation.NavigateTo("/DashboardPanel");
}
private bool PuedeRetroceder => PagedResult != null && SearchParams.Page > 1;
private bool PuedeAvanzar => PagedResult != null && SearchParams.Page < TotalPaginas;
private int TotalPaginas => PagedResult is null ? 1 :
(int)Math.Ceiling((double)(PagedResult.TotalItems) / SearchParams.PageSize);
List<PhTable.ButtonOptions> botones = new();
}