Fix: Corregir configuración del modal de resultados
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 50s

- Cambiar v-model a v-model:open según @nuxt/ui v4.0.0
- Eliminar UCard interno que causaba renderizado permanente
- Usar slots nativos del Modal (#header) en lugar de Card
- Simplificar estilos usando clases de Tailwind estándar
- El modal ahora se mostrará solo cuando showResults sea true
This commit is contained in:
2025-10-31 10:30:56 -06:00
parent 9768b31e3e
commit 16175b7fd4

View File

@@ -32,11 +32,10 @@
/> />
<!-- Results Modal --> <!-- Results Modal -->
<UModal v-model="showResults"> <UModal v-model:open="showResults">
<UCard class="brand-card border border-transparent">
<template #header> <template #header>
<div class="flex justify-between items-center"> <div class="flex justify-between items-center">
<h3 class="text-lg font-semibold brand-section-title">Resultados: {{ selectedCardForResults?.name }}</h3> <h3 class="text-lg font-semibold">Resultados: {{ selectedCardForResults?.name }}</h3>
<UButton <UButton
color="gray" color="gray"
variant="ghost" variant="ghost"
@@ -46,18 +45,18 @@
</div> </div>
</template> </template>
<div v-if="currentResult" class="space-y-3"> <div v-if="currentResult" class="space-y-3 p-4">
<div class="flex flex-wrap gap-4 text-sm text-[var(--brand-text)]"> <div class="flex flex-wrap gap-4 text-sm">
<div> <div>
<span class="font-medium text-[var(--brand-text-muted)]">Filas:</span> <span class="font-medium text-gray-500 dark:text-gray-400">Filas:</span>
<span class="ml-2">{{ currentResult.data?.rows?.length || 0 }}</span> <span class="ml-2">{{ currentResult.data?.rows?.length || 0 }}</span>
</div> </div>
<div> <div>
<span class="font-medium text-[var(--brand-text-muted)]">Tiempo:</span> <span class="font-medium text-gray-500 dark:text-gray-400">Tiempo:</span>
<span class="ml-2">{{ currentResult.running_time || 0 }}ms</span> <span class="ml-2">{{ currentResult.running_time || 0 }}ms</span>
</div> </div>
<div> <div>
<span class="font-medium text-[var(--brand-text-muted)]">Estado:</span> <span class="font-medium text-gray-500 dark:text-gray-400">Estado:</span>
<UBadge :color="currentResult.status === 'completed' ? 'green' : 'yellow'"> <UBadge :color="currentResult.status === 'completed' ? 'green' : 'yellow'">
{{ currentResult.status }} {{ currentResult.status }}
</UBadge> </UBadge>
@@ -65,19 +64,19 @@
</div> </div>
<!-- Empty State --> <!-- Empty State -->
<div v-if="!currentResult.data?.rows || currentResult.data.rows.length === 0" class="p-8 text-center rounded-lg border border-[var(--brand-border)] bg-[var(--brand-surface)]"> <div v-if="!currentResult.data?.rows || currentResult.data.rows.length === 0" class="p-8 text-center rounded-lg border dark:border-gray-700 bg-gray-50 dark:bg-gray-800">
<div class="mx-auto w-16 h-16 mb-4 flex items-center justify-center bg-[#3a2a16] rounded-full"> <div class="mx-auto w-16 h-16 mb-4 flex items-center justify-center bg-gray-200 dark:bg-gray-700 rounded-full">
<svg class="w-8 h-8 text-[var(--brand-text-muted)]" fill="none" stroke="currentColor" viewBox="0 0 24 24"> <svg class="w-8 h-8 text-gray-400" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M20 13V6a2 2 0 00-2-2H6a2 2 0 00-2 2v7m16 0v5a2 2 0 01-2 2H6a2 2 0 01-2-2v-5m16 0h-2.586a1 1 0 00-.707.293l-2.414 2.414a1 1 0 01-.707.293h-3.172a1 1 0 01-.707-.293l-2.414-2.414A1 1 0 006.586 13H4"></path> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M20 13V6a2 2 0 00-2-2H6a2 2 0 00-2 2v7m16 0v5a2 2 0 01-2 2H6a2 2 0 01-2-2v-5m16 0h-2.586a1 1 0 00-.707.293l-2.414 2.414a1 1 0 01-.707.293h-3.172a1 1 0 01-.707-.293l-2.414-2.414A1 1 0 006.586 13H4"></path>
</svg> </svg>
</div> </div>
<h3 class="text-sm font-medium text-[var(--brand-text)] mb-1">No hay datos</h3> <h3 class="text-sm font-medium mb-1">No hay datos</h3>
<p class="text-xs text-[var(--brand-text-muted)]">La consulta se ejecutó correctamente pero no devolvió resultados.</p> <p class="text-xs text-gray-500 dark:text-gray-400">La consulta se ejecutó correctamente pero no devolvió resultados.</p>
</div> </div>
<!-- Data Display --> <!-- Data Display -->
<div v-else class="overflow-x-auto max-h-96"> <div v-else class="overflow-x-auto max-h-96">
<pre class="p-3 rounded-lg border border-[var(--brand-border)] bg-[var(--brand-surface)] text-xs whitespace-pre-wrap break-words text-[var(--brand-text)]">{{ JSON.stringify(currentResult.data, null, 2) }}</pre> <pre class="p-3 rounded-lg border dark:border-gray-700 bg-gray-50 dark:bg-gray-800 text-xs whitespace-pre-wrap break-words">{{ JSON.stringify(currentResult.data, null, 2) }}</pre>
</div> </div>
</div> </div>
@@ -86,9 +85,8 @@
color="red" color="red"
variant="soft" variant="soft"
:title="currentError" :title="currentError"
class="mt-3" class="m-4"
/> />
</UCard>
</UModal> </UModal>
</div> </div>
</template> </template>