Commit Graph

30 Commits

Author SHA1 Message Date
f3753f2e04 Feature: Mostrar usuarios en DispositivoCard sin expandir
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 31s
- Agregar preview de usuarios que utilizan el dispositivo
- Usuarios conectados en badge rosa, desconectados en gris
- Mostrar contador total de usuarios
2025-11-24 18:23:40 -06:00
96a8f95f9e Refactor: Migrar UI completa a Tailwind CSS v4 + shadcn-vue
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 58s
- Reemplazar CSS nativo con Tailwind CSS v4 y utilidades custom
- Crear librería de componentes UI basada en shadcn-vue (Radix Vue)
- Componentes UI: Button, Card, Input, Textarea, Badge, Dialog, Avatar, DropdownMenu
- Migrar todos los componentes existentes a Tailwind utilities
- Convertir EventCard.js (htm) a EventCard.vue (SFC)
- Implementar sistema de temas dark/light con clase .dark
- Mantener efectos glassmorphism via @utility custom
- Eliminar styles.css legacy
2025-11-24 18:12:24 -06:00
1b47b60c5b Fix: Corregir reglas CSS de colapsar en móvil
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 26s
- Mover reglas de grid de 52px a media query desktop-only
- Evitar que reglas de desktop sobrescriban comportamiento móvil
- Soluciona contenedores cortados en vista móvil
2025-10-28 17:40:40 -06:00
0fdcc56f90 Fix: Mostrar botones de colapsar solo en móvil
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 16s
- Ocultar botones de colapsar en vista desktop
- En móvil, contenedores colapsados ocupan solo el alto del header
- Mantener comportamiento desktop (52px width cuando colapsado)
- Mejorar UX en dispositivos móviles evitando contenedores inutilizables
2025-10-28 17:33:02 -06:00
08e8e1f7d3 Solucionar problemas de PWA y cache
Some checks failed
build-and-deploy / build-and-deploy (push) Failing after 11s
- Agregar manifest.json a rutas públicas de Traefik (anteriormente solo estaba manifest.webmanifest)
- Cambiar estrategia de cache del Service Worker de cache-first a estrategia inteligente:
  * Archivos de build (/assets/): Network-first con cache fallback
  * HTML: Network-first siempre para obtener última versión
  * Recursos estáticos (iconos, manifest): Cache-first (no cambian)
- Incrementar versión de cache de v2 a v3 para forzar limpieza
- Evitar redirecciones a Authentik para archivos manifest

Esto soluciona:
- Error CORS en manifest.json (ya no redirige a Authentik)
- Problemas de cache que requerían limpiar datos del navegador
- Archivos desactualizados servidos desde cache
2025-10-28 10:33:38 -06:00
732edadcb6 Eliminar todos los efectos de movimiento en hover
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 26s
- Quitar transform translateY de UserCard hover (card-inner y botones)
- Quitar transform translateY de .icon-btn hover en styles.css
- Quitar transform translateY de .card hover en styles.css
- Quitar transform translateY de GroupCheckButton hover
- Reemplazar efectos de movimiento por cambios sutiles de opacidad
- Actualizar transiciones para remover propiedades transform innecesarias
2025-10-28 10:18:10 -06:00
5c39dc1fd2 Rediseñar UserCard con estilo minimalista inspirado en diseño 3D
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 15s
- Cambiar a diseño limpio tipo ficha con información organizada en filas label-value
- Reducir avatar a inicial pequeña (36x36px) con fondo sutil
- Implementar sistema de sombras suaves de múltiples capas para profundidad
- Simplificar paleta de colores con acentos sutiles
- Mejorar tipografía con mejor jerarquía (18px título, 13px info)
- Cambiar botones a diseño minimalista con borde sutil
- Agregar transiciones suaves con cubic-bezier para movimiento natural
- Implementar hover con elevación de 4px y sombras progresivas
- Organizar información en formato tabla limpia (vlan, estado, conexión, etiquetas)
- Reducir efectos visuales excesivos por diseño más elegante y profesional
2025-10-28 10:12:30 -06:00
37fdcaec9c Mejorar diseño de UserCard con avatares, iconos y mejor jerarquía visual
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 24s
- Agregar avatar circular con inicial del usuario y estados visuales (normal, conectado, deshabilitado)
- Implementar iconos SVG en todos los botones de acción (editar, desconectar, habilitar/deshabilitar, eliminar, expandir)
- Mejorar jerarquía de información con chips de colores específicos (VLAN azul, activo verde, deshabilitado rojo, conectado rosa)
- Agregar animación pulse en avatar cuando el usuario está conectado
- Implementar efectos hover con elevación y sombras rosas
- Organizar etiquetas y dispositivos en secciones separadas con bordes
- Resolver conflictos de merge en styles.css (mantener estilos de scrollbar y gradientes de topbar/panel)
- Agregar responsive design para móviles
- Mejorar transiciones y efectos glassmorphism en toda la card
2025-10-28 10:04:40 -06:00
1ea50f0aa5 Solucionar errores de CORS manteniendo seguridad de Authentik
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 46s
PROBLEMA:
- Frontend hacía fetch a APIs protegidas por Authentik
- Cuando sesión expiraba, Authentik redirigía causando error de CORS
- TypeError: Failed to fetch

SOLUCIÓN:
1. Backend inyecta window.__AUTHENTIK_USER__ en HTML inicial (app.js)
   - Servidor lee headers de Authentik y los pasa al frontend
   - Evita fetch innecesario en carga inicial

2. Frontend usa window.__AUTHENTIK_USER__ como fuente principal (useAuthentik.js)
   - Solo hace fetch cuando se fuerza refresh
   - Detecta errores de CORS como señal de sesión expirada
   - Muestra mensaje claro al usuario

3. App.vue detecta errores de autenticación en APIs
   - Cuando fetch falla con CORS, recarga página automáticamente
   - Authentik manejará la re-autenticación

SEGURIDAD:
- Todos los endpoints /api/* siguen protegidos por Authentik
- No se exponen APIs sin autenticación
- Headers de Authentik solo presentes con sesión válida
2025-10-27 15:15:44 -06:00
ab0f79e103 Agregar favicon.ico y apple-touch-icon.png
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 26s
2025-10-17 05:46:06 -06:00
3b36a3e3a7 fix3
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 13s
2025-10-17 05:31:56 -06:00
918ca465d6 Implementar autenticación Authentik completa
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 25s
- Backend: Nuevos endpoints /api/auth/status y /api/auth/check-group
- Frontend: Composable useAuthentik para gestión de autenticación
- Frontend: Componentes UserDropdown, UserAvatar, SessionStatusButton, GroupCheckButton
- Frontend: Integración en topbar con dropdown de usuario
- Config: URLs de Authentik y configuración de avatares
- Lectura de headers x-authentik-* inyectados por Traefik
- Verificación de grupos RBAC (frontend y backend)
- Validación de sesión contra Authentik
2025-10-17 04:47:30 -06:00
cba732fbca Implementar sistema de toast con detección de PWA
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 27s
Cambios:
- Crear componente Toast.vue con soporte para posiciones (top/bottom, left/center/right)
- Crear composable useToast.js para manejar notificaciones
- Integrar sistema de toast en App.vue
- Implementar detección de PWA:
  * Detecta si el usuario está en modo standalone (PWA instalada)
  * Si puede instalar, muestra toast con botón de instalación
  * Si ya está instalada pero no se usa, sugiere abrir en app
- Toast persistente hasta que el usuario interactúe
- Soporte para tema claro/oscuro
- Animaciones suaves y diseño moderno
- Responsive para móviles

El sistema permite mostrar toasts de tipo: success, error, warning, info, pwa
con opciones de posición, duración, acciones personalizadas y modo persistente.
2025-10-17 04:26:16 -06:00
dc2c373a4f Agregar botón de Inicio en el header
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 24s
Cambios en App.vue:
- Agregar botón Inicio con emoji 🏠 en el topbar
- Botón apunta a https://inicio.nucleoriofrio.com
- Posicionado al inicio de la sección de acciones
- Usa clase .icon-btn para consistencia visual

El botón usa scope extensions para navegar dentro de la PWA.
2025-10-17 04:18:16 -06:00
bf941aceb3 pwa compatible
All checks were successful
build-and-deploy / build (push) Successful in 11s
build-and-deploy / deploy (push) Successful in 15s
2025-09-26 21:20:34 -06:00
ca605a5759 app V1 completada 2025-09-26 19:55:12 -06:00
7d7a845a75 cronjob de manejo de invitados listo 2025-09-26 19:28:58 -06:00
0d4b0cbf67 UI/UX mejorados 5 2025-09-26 19:10:17 -06:00
9848bd46f1 edicion de metadata dispositivos, UI/UX 2025-09-26 18:20:36 -06:00
e10d8950d9 mejoras UI 4 2025-09-26 18:14:15 -06:00
bcc475045d creacion de vlans listo 2025-09-26 17:55:20 -06:00
44916b642b tablas y frontend visualizador de DB listo 2025-09-26 17:48:45 -06:00
3fc25719f3 a ver 2025-09-26 17:23:30 -06:00
dae25e9112 style(ui): update gradients, borders, and scrollbars 2025-09-26 17:20:34 -06:00
2953f18412 mejoras de UI 3 2025-09-26 17:17:57 -06:00
6e6523c0c8 mejoras de UI 2025-09-26 17:08:33 -06:00
c92df7bb9a frontend actualizado y mejorado extremadamente 2025-09-26 16:54:39 -06:00
974fe0b9e1 frontend actualizado y mejorado extremadamente 2025-09-26 16:54:39 -06:00
6510250513 codigo refactorizado y ordenado, listo para siguiente fase 2025-09-26 15:37:06 -06:00
4783f51454 codigo refactorizado y ordenado, listo para siguiente fase 2025-09-26 15:37:06 -06:00