Feat: Implementa ABM y anulación de ajustes manuales
Este commit introduce la funcionalidad completa para la gestión de ajustes manuales (créditos/débitos) en la cuenta corriente de un suscriptor, cerrando un requerimiento clave detectado en el análisis del flujo de trabajo manual. Backend: - Se añade la tabla `susc_Ajustes` para registrar movimientos manuales. - Se crean el Modelo, DTOs, Repositorio y Servicio (`AjusteService`) para el ABM completo de los ajustes. - Se implementa la lógica para anular ajustes que se encuentren en estado "Pendiente", registrando el usuario y fecha de anulación para mantener la trazabilidad. - Se integra la lógica de aplicación de ajustes pendientes en el `FacturacionService`, afectando el `ImporteFinal` de la factura generada. - Se añaden los nuevos endpoints en `AjustesController` para crear, listar y anular ajustes. Frontend: - Se crea el componente `CuentaCorrienteSuscriptorTab` para mostrar el historial de ajustes de un cliente. - Se desarrolla el modal `AjusteFormModal` que permite a los usuarios registrar nuevos créditos o débitos. - Se integra una nueva pestaña "Cuenta Corriente / Ajustes" en la vista de gestión de un suscriptor. - Se añade la funcionalidad de "Anular" en la tabla de ajustes, permitiendo a los usuarios corregir errores antes del ciclo de facturación.
This commit is contained in:
		
							
								
								
									
										26
									
								
								Frontend/src/services/Suscripciones/ajusteService.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								Frontend/src/services/Suscripciones/ajusteService.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| import apiClient from '../apiClient'; | ||||
| import type { AjusteDto } from '../../models/dtos/Suscripciones/AjusteDto'; | ||||
| import type { CreateAjusteDto } from '../../models/dtos/Suscripciones/CreateAjusteDto'; | ||||
|  | ||||
| const API_URL_BY_SUSCRIPTOR = '/suscriptores'; | ||||
| const API_URL_BASE = '/ajustes'; | ||||
|  | ||||
| const getAjustesPorSuscriptor = async (idSuscriptor: number): Promise<AjusteDto[]> => { | ||||
|     const response = await apiClient.get<AjusteDto[]>(`${API_URL_BY_SUSCRIPTOR}/${idSuscriptor}/ajustes`); | ||||
|     return response.data; | ||||
| }; | ||||
|  | ||||
| const createAjusteManual = async (data: CreateAjusteDto): Promise<AjusteDto> => { | ||||
|     const response = await apiClient.post<AjusteDto>(API_URL_BASE, data); | ||||
|     return response.data; | ||||
| }; | ||||
|  | ||||
| const anularAjuste = async (idAjuste: number): Promise<void> => { | ||||
|     await apiClient.post(`${API_URL_BASE}/${idAjuste}/anular`); | ||||
| }; | ||||
|  | ||||
| export default { | ||||
|     getAjustesPorSuscriptor, | ||||
|     createAjusteManual, | ||||
|     anularAjuste | ||||
| }; | ||||
		Reference in New Issue
	
	Block a user