Backend:
Diseño de un AuditoriaController con un patrón para añadir endpoints de historial para diferentes entidades. Implementación de la lógica de servicio y repositorio para obtener datos de las tablas _H para: Usuarios (gral_Usuarios_H) Pagos de Distribuidores (cue_PagosDistribuidor_H) Notas de Crédito/Débito (cue_CreditosDebitos_H) Entradas/Salidas de Distribuidores (dist_EntradasSalidas_H) Entradas/Salidas de Canillitas (dist_EntradasSalidasCanillas_H) Novedades de Canillitas (dist_dtNovedadesCanillas_H) Ajustes Manuales de Saldo (cue_SaldoAjustesHistorial) Tipos de Pago (cue_dtTipopago_H) Canillitas (Maestro) (dist_dtCanillas_H) Distribuidores (Maestro) (dist_dtDistribuidores_H) Empresas (Maestro) (dist_dtEmpresas_H) DTOs específicos para cada tipo de historial, incluyendo NombreUsuarioModifico. Frontend: Servicio auditoriaService.ts con métodos para llamar a cada endpoint de historial. Página AuditoriaGeneralPage.tsx con: Selector de "Tipo de Entidad a Auditar". Filtros comunes (Fechas, Usuario Modificador, Tipo de Modificación, ID Entidad). Un DataGrid que muestra las columnas dinámicamente según el tipo de entidad seleccionada. Lógica para cargar los datos correspondientes. DTOs de historial en TypeScript. Actualizaciones en AppRoutes.tsx y MainLayout.tsx para la nueva sección de Auditoría (restringida a SuperAdmin).
This commit is contained in:
		| @@ -1,6 +1,7 @@ | ||||
| using GestionIntegral.Api.Data; | ||||
| using GestionIntegral.Api.Data.Repositories.Contables; | ||||
| using GestionIntegral.Api.Data.Repositories.Distribucion; | ||||
| using GestionIntegral.Api.Dtos.Auditoria; | ||||
| using GestionIntegral.Api.Dtos.Contables; | ||||
| using GestionIntegral.Api.Models.Contables; | ||||
| using Microsoft.Extensions.Logging; | ||||
| @@ -93,7 +94,7 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|             if (await _empresaRepo.GetByIdAsync(createDto.IdEmpresa) == null) | ||||
|                 return (null, "Empresa no válida."); | ||||
|             if (await _pagoRepo.ExistsByReciboAndTipoMovimientoAsync(createDto.Recibo, createDto.TipoMovimiento)) | ||||
|                  return (null, $"Ya existe un pago '{createDto.TipoMovimiento}' con el número de recibo '{createDto.Recibo}'."); | ||||
|                 return (null, $"Ya existe un pago '{createDto.TipoMovimiento}' con el número de recibo '{createDto.Recibo}'."); | ||||
|  | ||||
|             var nuevoPago = new PagoDistribuidor | ||||
|             { | ||||
| @@ -116,18 +117,18 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                     if (connection is System.Data.Common.DbConnection dbConn) await dbConn.OpenAsync(); else connection.Open(); | ||||
|                 } | ||||
|                 transaction = connection.BeginTransaction(); | ||||
|                  | ||||
|  | ||||
|                 var pagoCreado = await _pagoRepo.CreateAsync(nuevoPago, idUsuario, transaction); | ||||
|                 if (pagoCreado == null) throw new DataException("Error al registrar el pago."); | ||||
|  | ||||
|                 decimal montoParaSaldo; | ||||
|                 if (createDto.TipoMovimiento == "Recibido") | ||||
|                 { | ||||
|                     montoParaSaldo = -createDto.Monto;  | ||||
|                     montoParaSaldo = -createDto.Monto; | ||||
|                 } | ||||
|                 else  | ||||
|                 else | ||||
|                 { | ||||
|                     montoParaSaldo = createDto.Monto;  | ||||
|                     montoParaSaldo = createDto.Monto; | ||||
|                 } | ||||
|  | ||||
|                 bool saldoActualizado = await _saldoRepo.ModificarSaldoAsync("Distribuidores", pagoCreado.IdDistribuidor, pagoCreado.IdEmpresa, montoParaSaldo, transaction); | ||||
| @@ -143,7 +144,7 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                 _logger.LogError(ex, "Error CrearAsync PagoDistribuidor."); | ||||
|                 return (null, $"Error interno: {ex.Message}"); | ||||
|             } | ||||
|             finally  | ||||
|             finally | ||||
|             { | ||||
|                 if (connection.State == ConnectionState.Open) | ||||
|                 { | ||||
| @@ -164,8 +165,8 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                 } | ||||
|                 transaction = connection.BeginTransaction(); | ||||
|  | ||||
|                 var pagoExistente = await _pagoRepo.GetByIdAsync(idPago);  | ||||
|                 if (pagoExistente == null)  | ||||
|                 var pagoExistente = await _pagoRepo.GetByIdAsync(idPago); | ||||
|                 if (pagoExistente == null) | ||||
|                 { | ||||
|                     transaction.Rollback(); // Rollback si no se encuentra | ||||
|                     return (false, "Pago no encontrado."); | ||||
| @@ -176,7 +177,7 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                     transaction.Rollback(); | ||||
|                     return (false, "Tipo de pago no válido."); | ||||
|                 } | ||||
|                  | ||||
|  | ||||
|                 decimal impactoOriginalSaldo = pagoExistente.TipoMovimiento == "Recibido" ? -pagoExistente.Monto : pagoExistente.Monto; | ||||
|                 decimal impactoNuevoSaldo = pagoExistente.TipoMovimiento == "Recibido" ? -updateDto.Monto : updateDto.Monto; | ||||
|                 decimal diferenciaAjusteSaldo = impactoNuevoSaldo - impactoOriginalSaldo; | ||||
| @@ -184,14 +185,14 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                 var pagoParaActualizarEnRepo = new PagoDistribuidor | ||||
|                 { | ||||
|                     IdPago = pagoExistente.IdPago, | ||||
|                     IdDistribuidor = pagoExistente.IdDistribuidor,  | ||||
|                     Fecha = pagoExistente.Fecha,                    | ||||
|                     TipoMovimiento = pagoExistente.TipoMovimiento,  | ||||
|                     Recibo = pagoExistente.Recibo,                  | ||||
|                     Monto = updateDto.Monto,                        | ||||
|                     IdTipoPago = updateDto.IdTipoPago,              | ||||
|                     Detalle = updateDto.Detalle,                    | ||||
|                     IdEmpresa = pagoExistente.IdEmpresa             | ||||
|                     IdDistribuidor = pagoExistente.IdDistribuidor, | ||||
|                     Fecha = pagoExistente.Fecha, | ||||
|                     TipoMovimiento = pagoExistente.TipoMovimiento, | ||||
|                     Recibo = pagoExistente.Recibo, | ||||
|                     Monto = updateDto.Monto, | ||||
|                     IdTipoPago = updateDto.IdTipoPago, | ||||
|                     Detalle = updateDto.Detalle, | ||||
|                     IdEmpresa = pagoExistente.IdEmpresa | ||||
|                 }; | ||||
|  | ||||
|                 var actualizado = await _pagoRepo.UpdateAsync(pagoParaActualizarEnRepo, idUsuario, transaction); | ||||
| @@ -214,7 +215,7 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                 _logger.LogError(ex, "Error ActualizarAsync PagoDistribuidor ID: {Id}", idPago); | ||||
|                 return (false, $"Error interno: {ex.Message}"); | ||||
|             } | ||||
|              finally | ||||
|             finally | ||||
|             { | ||||
|                 if (connection.State == ConnectionState.Open) | ||||
|                 { | ||||
| @@ -231,17 +232,17 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|             { | ||||
|                 if (connection.State != ConnectionState.Open) | ||||
|                 { | ||||
|                      if (connection is System.Data.Common.DbConnection dbConn) await dbConn.OpenAsync(); else connection.Open(); | ||||
|                     if (connection is System.Data.Common.DbConnection dbConn) await dbConn.OpenAsync(); else connection.Open(); | ||||
|                 } | ||||
|                 transaction = connection.BeginTransaction(); | ||||
|                  | ||||
|  | ||||
|                 var pagoExistente = await _pagoRepo.GetByIdAsync(idPago); | ||||
|                 if (pagoExistente == null)  | ||||
|                 if (pagoExistente == null) | ||||
|                 { | ||||
|                     transaction.Rollback(); | ||||
|                     return (false, "Pago no encontrado."); | ||||
|                 } | ||||
|                  | ||||
|  | ||||
|                 decimal montoReversion = pagoExistente.TipoMovimiento == "Recibido" ? pagoExistente.Monto : -pagoExistente.Monto; | ||||
|  | ||||
|                 var eliminado = await _pagoRepo.DeleteAsync(idPago, idUsuario, transaction); | ||||
| @@ -269,5 +270,30 @@ namespace GestionIntegral.Api.Services.Contables | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         public async Task<IEnumerable<PagoDistribuidorHistorialDto>> ObtenerHistorialAsync( | ||||
|         DateTime? fechaDesde, DateTime? fechaHasta, | ||||
|         int? idUsuarioModifico, string? tipoModificacion, | ||||
|         int? idPagoAfectado) | ||||
|     { | ||||
|         var historialData = await _pagoRepo.GetHistorialAsync(fechaDesde, fechaHasta, idUsuarioModifico, tipoModificacion, idPagoAfectado); | ||||
|          | ||||
|         return historialData.Select(h => new PagoDistribuidorHistorialDto | ||||
|         { | ||||
|             Id_Pago = h.Historial.Id_Pago, | ||||
|             Id_Distribuidor = h.Historial.Id_Distribuidor, | ||||
|             Fecha = h.Historial.Fecha, | ||||
|             TipoMovimiento = h.Historial.TipoMovimiento, | ||||
|             Recibo = h.Historial.Recibo, | ||||
|             Monto = h.Historial.Monto, | ||||
|             Id_TipoPago = h.Historial.Id_TipoPago, | ||||
|             Detalle = h.Historial.Detalle, | ||||
|             Id_Empresa = h.Historial.Id_Empresa, | ||||
|             Id_Usuario = h.Historial.Id_Usuario, | ||||
|             NombreUsuarioModifico = h.NombreUsuarioModifico, | ||||
|             FechaMod = h.Historial.FechaMod, | ||||
|             TipoMod = h.Historial.TipoMod | ||||
|         }).ToList(); | ||||
|     } | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user