Files
analiticaNucleo/nuxt4-app/app/components/TotalesIngresoCompra.vue
josedario87 f8c53da6fc
All checks were successful
build-and-deploy / build (push) Successful in 43s
build-and-deploy / deploy (push) Successful in 4s
feat: restaurar panorama facturador con nueva arquitectura basada en Metabase
- Crear endpoint /api/metabase/panorama.post.ts que ejecuta las 9 queries en paralelo
- Restaurar y adaptar panorama.vue para usar el nuevo endpoint
- Crear componentes auxiliares: SecosVendidos, TotalesIngresoCompra, TotalesMonetarios, TotalesVerde, MetricBox, RechazosRechazoCard
- Adaptar RechazosSubproductos para recibir data directamente de Metabase
- Toda la transformación de datos ocurre en las queries SQL de Metabase
- Sin uso de stores ni composables de métricas
- Agregar documentación de queries en archivos MD
2025-10-14 10:34:27 -06:00

79 lines
3.4 KiB
Vue

<template>
<UCard class="brand-card border border-transparent">
<template #header>
<h2 class="text-xl font-bold brand-section-title">Totales de Ingreso y Compra</h2>
</template>
<div class="space-y-6">
<!-- Uva -->
<div>
<h3 class="text-lg font-semibold text-[var(--brand-primary)] mb-3">Uva</h3>
<div class="grid grid-cols-1 md:grid-cols-4 gap-3">
<MetricBox label="LB Uva Ingresada" :value="formatNumber(data.total_lb_uva_ingresada) + ' lb'" />
<MetricBox label="QQ Seco Ingresado" :value="formatNumber(data.total_qq_seco_uva_ingresado) + ' QQ'" />
<MetricBox label="LB Uva Pagada" :value="formatNumber(data.total_lb_uva_pagada) + ' lb'" color="green" />
<MetricBox label="LB Uva en Depósito" :value="formatNumber(data.total_lb_uva_deposito) + ' lb'" color="yellow" />
</div>
</div>
<!-- Mojado -->
<div>
<h3 class="text-lg font-semibold text-[var(--brand-primary)] mb-3">Mojado</h3>
<div class="grid grid-cols-1 md:grid-cols-3 gap-3">
<MetricBox label="QQ Seco Ingresado" :value="formatNumber(data.total_qq_seco_mojado_ingresado) + ' QQ'" />
<MetricBox label="QQ Seco Pagado" :value="formatNumber(data.total_qq_seco_mojado_pagado) + ' QQ'" color="green" />
<MetricBox label="QQ en Depósito" :value="formatNumber(data.total_qq_mojado_deposito) + ' QQ'" color="yellow" />
</div>
</div>
<!-- Oreado -->
<div>
<h3 class="text-lg font-semibold text-[var(--brand-primary)] mb-3">Oreado</h3>
<div class="grid grid-cols-1 md:grid-cols-3 gap-3">
<MetricBox label="QQ Seco Ingresado" :value="formatNumber(data.total_qq_seco_oreado_ingresado) + ' QQ'" />
<MetricBox label="QQ Seco Pagado" :value="formatNumber(data.total_qq_seco_oreado_pagado) + ' QQ'" color="green" />
<MetricBox label="QQ en Depósito" :value="formatNumber(data.total_qq_oreado_deposito) + ' QQ'" color="yellow" />
</div>
</div>
<!-- Totales Generales -->
<div class="pt-4 border-t border-[#3a2a16]">
<h3 class="text-lg font-semibold text-[var(--brand-primary)] mb-3">Totales Generales</h3>
<div class="grid grid-cols-1 md:grid-cols-3 gap-3">
<MetricBox label="QQ Seco Ingresado" :value="formatNumber(data.total_qq_seco_ingresado) + ' QQ'" />
<MetricBox label="QQ Seco Comprado" :value="formatNumber(data.total_qq_seco_comprado) + ' QQ'" color="green" />
<MetricBox label="QQ Seco en Depósito" :value="formatNumber(data.total_qq_seco_deposito) + ' QQ'" color="yellow" />
</div>
</div>
</div>
</UCard>
</template>
<script setup lang="ts">
const props = defineProps<{
data: {
total_lb_uva_ingresada: number
total_qq_seco_uva_ingresado: number
total_qq_seco_mojado_ingresado: number
total_qq_seco_oreado_ingresado: number
total_qq_seco_ingresado: number
total_lb_uva_pagada: number
total_qq_seco_uva_pagado: number
total_qq_seco_mojado_pagado: number
total_qq_seco_oreado_pagado: number
total_qq_seco_comprado: number
total_lb_uva_deposito: number
total_qq_mojado_deposito: number
total_qq_oreado_deposito: number
total_qq_seco_deposito: number
}
}>()
const formatNumber = (value: number) => {
return new Intl.NumberFormat('es-HN', {
minimumFractionDigits: 2,
maximumFractionDigits: 2
}).format(value)
}
</script>