PROBLEMA IDENTIFICADO: - Dropdown "Buscador General de Precios Unitarios" (18 elementos) NO se despliega en hover - Usuario reportó: "el submenu no se despliega" en staging - Inspeccionado con Chrome DevTools MCP: dropdown permanece display:none en hover DIAGNÓSTICO: ✅ HTML correcto: <a class="nav-link dropdown-toggle" data-bs-toggle="dropdown"> ✅ Bootstrap 5 cargado: window.bootstrap existe ✅ Walker genera data-bs-toggle="dropdown" correctamente ❌ Bootstrap 5 usa CLICK por defecto, NO hover ❌ No había CSS para activar dropdown en hover ❌ Template base tampoco tiene dropdown hover CAUSA RAÍZ: Bootstrap 5 NUNCA ha usado hover por defecto. Requiere CSS adicional. SOLUCIÓN IMPLEMENTADA (CSS > JavaScript): Agregar 4 líneas CSS para dropdown hover SOLO en desktop (min-width: 992px) Archivo: componente-navbar.css (líneas 136-144) @media (min-width: 992px) { .nav-item:hover > .dropdown-menu { display: block; } } POR QUÉ CSS vs JavaScript: ✅ Super simple: 4 líneas vs 20-30 líneas JS ✅ Performance perfecto: Sin event listeners ✅ Híbrido perfecto: Hover desktop + Click móvil (Bootstrap) ✅ Compatible: Funciona aunque JS esté deshabilitado ✅ Menos bugs: Menos código = menos errores ARCHIVOS MODIFICADOS: - componente-navbar.css: +9 líneas (CSS dropdown hover) - functions.php: Version 1.0.15 → 1.0.16 RESULTADO: ✅ Desktop (>992px): Dropdown se despliega en hover instantáneamente ✅ Móvil (<992px): Sigue usando click nativo de Bootstrap ✅ Compatible con los 18 elementos + scroll del Issue #103 ✅ Sin conflictos con JavaScript existente TESTING PENDIENTE: - Verificar en staging que dropdown funciona en hover - Confirmar que NO interfiere con móvil (debe seguir usando click) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
145 lines
3.1 KiB
CSS
145 lines
3.1 KiB
CSS
/**
|
|
* Navbar Styles
|
|
*
|
|
* RESPONSABILIDAD: Estilos del componente de navegación principal
|
|
* - Navbar sticky
|
|
* - Navbar brand
|
|
* - Nav links y efectos hover
|
|
* - Dropdown menu
|
|
* - Dropdown items
|
|
*
|
|
* @package Apus_Theme
|
|
* @since 1.0.7
|
|
* @source apus-theme-template/css/style.css
|
|
*/
|
|
|
|
/* ========================================
|
|
Navbar Principal
|
|
======================================== */
|
|
|
|
.navbar {
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 1030;
|
|
background-color: var(--color-navy-primary) !important;
|
|
box-shadow: 0 4px 12px rgba(30, 58, 95, 0.15);
|
|
padding: 0.75rem 0;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.navbar.scrolled {
|
|
box-shadow: 0 6px 20px rgba(30, 58, 95, 0.25);
|
|
}
|
|
|
|
/* ========================================
|
|
Navbar Brand
|
|
======================================== */
|
|
|
|
.navbar-brand {
|
|
color: #ffffff !important;
|
|
font-weight: 700;
|
|
font-size: 1.5rem;
|
|
transition: color 0.3s ease;
|
|
}
|
|
|
|
.navbar-brand:hover {
|
|
color: var(--color-orange-primary) !important;
|
|
}
|
|
|
|
/* ========================================
|
|
Nav Links
|
|
======================================== */
|
|
|
|
.nav-link {
|
|
color: rgba(255, 255, 255, 0.9) !important;
|
|
font-weight: 500;
|
|
position: relative;
|
|
padding: 0.5rem 0.65rem !important;
|
|
transition: all 0.3s ease;
|
|
font-size: 0.9rem;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.nav-link::after {
|
|
content: '';
|
|
position: absolute;
|
|
bottom: 0;
|
|
left: 50%;
|
|
transform: translateX(-50%) scaleX(0);
|
|
width: 80%;
|
|
height: 2px;
|
|
background: var(--color-orange-primary);
|
|
transition: transform 0.3s ease;
|
|
}
|
|
|
|
.nav-link:hover {
|
|
color: var(--color-orange-primary) !important;
|
|
background-color: rgba(255, 133, 0, 0.1);
|
|
border-radius: 4px;
|
|
}
|
|
|
|
.nav-link:hover::after {
|
|
transform: translateX(-50%) scaleX(1);
|
|
}
|
|
|
|
/* ========================================
|
|
Dropdown Menu
|
|
======================================== */
|
|
|
|
.dropdown-menu {
|
|
background: #ffffff;
|
|
border: none;
|
|
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
|
|
border-radius: 8px;
|
|
padding: 0.5rem 0;
|
|
max-height: 70vh;
|
|
overflow-y: auto;
|
|
scroll-behavior: smooth;
|
|
scrollbar-width: thin;
|
|
scrollbar-color: var(--color-gray-400) transparent;
|
|
}
|
|
|
|
/* Webkit browsers (Chrome, Safari, Edge) scrollbar */
|
|
.dropdown-menu::-webkit-scrollbar {
|
|
width: 6px;
|
|
}
|
|
|
|
.dropdown-menu::-webkit-scrollbar-track {
|
|
background: transparent;
|
|
}
|
|
|
|
.dropdown-menu::-webkit-scrollbar-thumb {
|
|
background-color: var(--color-gray-400);
|
|
border-radius: 3px;
|
|
}
|
|
|
|
.dropdown-menu::-webkit-scrollbar-thumb:hover {
|
|
background-color: var(--color-gray-500);
|
|
}
|
|
|
|
/* ========================================
|
|
Dropdown Items
|
|
======================================== */
|
|
|
|
.dropdown-item {
|
|
color: var(--color-neutral-600);
|
|
padding: 0.5rem 1.25rem;
|
|
transition: all 0.3s ease;
|
|
font-weight: 500;
|
|
}
|
|
|
|
.dropdown-item:hover {
|
|
background-color: rgba(255, 133, 0, 0.1);
|
|
color: var(--color-orange-primary);
|
|
}
|
|
|
|
/* ========================================
|
|
Dropdown Hover (Desktop Only)
|
|
======================================== */
|
|
|
|
@media (min-width: 992px) {
|
|
.nav-item:hover > .dropdown-menu {
|
|
display: block;
|
|
}
|
|
}
|