Agregar sistema de vinculaciones con registros externos de Metabase
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 2m46s

- Nuevo schema BD para vinculaciones_externas con constraint único por período
- Cliente Metabase para consultar Ingresos, Carretas, Salidas y Rechazos
- Endpoints API para registros externos (/api/externos/*) y vinculaciones (/api/vinculaciones/*)
- Composable useRegistrosExternos con lógica de vinculación individual y masiva
- Componentes: TablaRegistros, ModalAsignar, ProgressDashboard
- Tab "Externos" en app.vue con sub-tabs y dashboard de progreso
- LotesCard.vue ahora muestra registros vinculados al lote
This commit is contained in:
2025-11-29 15:25:26 -06:00
parent 1c96b696fa
commit ce8bad68d5
38 changed files with 2987 additions and 1 deletions

View File

@@ -0,0 +1,52 @@
/**
* GET /api/externos/ingresos
*
* Obtiene los ingresos del período de cosecha desde Metabase.
* Incluye información de estado de vinculación.
*/
import { getIngresos } from '../../utils/metabase'
import { getRegistrosVinculados } from '../../utils/queries'
export default defineEventHandler(async (event) => {
try {
const query = getQuery(event)
const periodo = (query.periodo as string) || '25-26'
const soloSinVincular = query.sinVincular === 'true'
// Obtener ingresos desde Metabase
const ingresos = await getIngresos(periodo)
// Obtener IDs ya vinculados desde nuestra BD local
const vinculados = await getRegistrosVinculados('ingreso', periodo)
const vinculadosSet = new Set(vinculados)
// Marcar cada ingreso con su estado de vinculación
const ingresosConEstado = ingresos.map((ingreso: any) => ({
...ingreso,
vinculado: vinculadosSet.has(ingreso.id),
}))
// Filtrar si solo se quieren los no vinculados
const resultado = soloSinVincular
? ingresosConEstado.filter((i: any) => !i.vinculado)
: ingresosConEstado
return {
success: true,
data: resultado,
meta: {
total: resultado.length,
vinculados: ingresosConEstado.filter((i: any) => i.vinculado).length,
sinVincular: ingresosConEstado.filter((i: any) => !i.vinculado).length,
periodo,
},
}
} catch (error: any) {
console.error('[API] Error obteniendo ingresos:', error)
throw createError({
statusCode: error.statusCode || 500,
statusMessage: error.message || 'Error obteniendo ingresos',
})
}
})