Files
GestionIntegralWeb/Frontend/src/services/Impresion/tiradaService.ts
dmolinari 28c1b88a92
All checks were successful
Optimized Build and Deploy / remote-build-and-deploy (push) Successful in 12m54s
Feat: Implementar modificación de Tiradas y mejorar UX/UI
**Backend:**
- Se ha añadido el endpoint `PUT /api/tiradas` para manejar la modificación de una Tirada, identificada por su clave única (fecha, idPublicacion, idPlanta).
- Se implementó un mecanismo de actualización granular para las secciones de la tirada (`bob_RegPublicaciones`), reemplazando la estrategia anterior de "eliminar todo y recrear".
  - La nueva lógica reconcilia el estado entrante con el de la base de datos, realizando operaciones individuales de `INSERT`, `UPDATE` y `DELETE` para cada sección.
  - Esto mejora significativamente el rendimiento y proporciona un historial de auditoría mucho más preciso.
- Se añadieron los DTOs `UpdateTiradaRequestDto` y `UpdateDetalleSeccionTiradaDto` para soportar el nuevo payload de modificación.
- Se expandieron los repositorios `IRegPublicacionSeccionRepository` y `IPubliSeccionRepository` con métodos para operaciones granulares (`UpdateAsync`, `DeleteByIdAsync`, `GetByIdsAndPublicacionAsync`).

**Frontend:**
- El componente `TiradaFormModal` ha sido refactorizado para funcionar tanto en modo "Crear" como en modo "Editar", recibiendo una prop `tiradaToEdit`.
- Se implementó una lógica de carga asíncrona robusta que obtiene los datos completos de una tirada antes de abrir el modal en modo edición.

**Mejoras de UI/UX:**
- Se ha rediseñado el layout de la lista de tiradas en `GestionarTiradasPage`:
  - Los botones de acción (Editar, Borrar) y los datos clave (chips de ejemplares y páginas) ahora se encuentran en una cabecera estática.
  - Estos elementos permanecen fijos en la parte superior y no se desplazan al expandir el acordeón, mejorando la consistencia visual.
- Se ha mejorado la tabla de secciones dentro del `TiradaFormModal`:
  - El botón "+ AGREGAR SECCIÓN" ahora está fijo en la parte inferior de la tabla, permaneciendo siempre visible incluso cuando la lista de secciones tiene scroll.
  - Al agregar una nueva sección, la lista se desplaza automáticamente hacia abajo para mostrar la nueva fila.
2025-07-23 14:05:58 -03:00

56 lines
1.9 KiB
TypeScript

import apiClient from '../apiClient';
import type { TiradaDto } from '../../models/dtos/Impresion/TiradaDto';
import type { CreateTiradaRequestDto } from '../../models/dtos/Impresion/CreateTiradaRequestDto';
import type { UpdateTiradaRequestDto } from '../../models/dtos/Impresion/UpdateTiradaRequestDto';
interface GetTiradasParams {
fecha?: string | null; // "yyyy-MM-dd"
idPublicacion?: number | null;
idPlanta?: number | null;
}
const getTiradas = async (filters: GetTiradasParams): Promise<TiradaDto[]> => {
const params: Record<string, string | number> = {};
if (filters.fecha) params.fecha = filters.fecha;
if (filters.idPublicacion) params.idPublicacion = filters.idPublicacion;
if (filters.idPlanta) params.idPlanta = filters.idPlanta;
const response = await apiClient.get<TiradaDto[]>('/tiradas', { params });
return response.data;
};
const registrarTirada = async (data: CreateTiradaRequestDto): Promise<TiradaDto> => {
const response = await apiClient.post<TiradaDto>('/tiradas', data);
return response.data; // El backend devuelve la tirada creada
};
const modificarTirada = async (fecha: string, idPublicacion: number, idPlanta: number, data: UpdateTiradaRequestDto): Promise<TiradaDto> => {
const response = await apiClient.put<TiradaDto>('/tiradas', data, {
params: {
fecha,
idPublicacion,
idPlanta
}
});
return response.data;
};
const deleteTiradaCompleta = async (fecha: string, idPublicacion: number, idPlanta: number): Promise<void> => {
// Los parámetros van en la query string para este DELETE
await apiClient.delete('/tiradas', {
params: {
fecha,
idPublicacion,
idPlanta
}
});
};
const tiradaService = {
getTiradas,
registrarTirada,
modificarTirada,
deleteTiradaCompleta,
};
export default tiradaService;