f87a1a5c28
CRITICAL BUG FIX: Hover states now sync between action bar and hamburger menu Changes: 1. Added mouseenter/mouseleave handlers to menu PDF button - templates/partials/navigation/hamburger-menu.html:178-181 - Added .menu-pdf-btn class for targeting - Added hyperscript hover sync events 2. Updated syncPdfHover() function - static/js/cv-functions.js:71-82 - Now selects both .pdf-btn and .menu-pdf-btn - Both buttons get .pdf-hover-sync class on hover 3. Updated syncPrintHover() function - static/js/cv-functions.js:88-99 - Now selects both .print-btn and .menu-print-btn - Both buttons get .print-hover-sync class on hover 4. Added CSS for menu PDF button hover sync - static/css/main.css:2690-2700 - .menu-pdf-btn.pdf-hover-sync styling (white bg, red icon) - Matches action bar PDF button hover state 5. Created comprehensive hover sync test - tests/mjs/8-hover-sync.test.mjs - Tests all 4 hover scenarios (bar→menu, menu→bar for both buttons) - Validates event handlers and CSS class application - Manual verification instructions included Behavior now correct: ✅ Hovering action bar PDF button highlights menu PDF button ✅ Hovering action bar Print button highlights menu Print button ✅ Hovering menu PDF button highlights action bar PDF button ✅ Hovering menu Print button highlights action bar Print button Fixes documented bug from PROJECT-MEMORY.md Section 3.
197 lines
12 KiB
HTML
197 lines
12 KiB
HTML
{{define "hamburger-menu"}}
|
|
<!-- Navigation Menu (Hidden by default) -->
|
|
<nav id="navigation-menu" class="navigation-menu no-print" role="navigation" aria-label="CV sections">
|
|
<div class="menu-content">
|
|
<!-- CV Sections - Quick Navigation -->
|
|
<div class="menu-item-submenu">
|
|
<a href="#" class="menu-item has-submenu">
|
|
<iconify-icon icon="mdi:menu" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Secciones CV{{else}}CV Sections{{end}}</span>
|
|
<iconify-icon icon="mdi:chevron-right" width="16" height="16" class="submenu-arrow"></iconify-icon>
|
|
</a>
|
|
<div class="submenu-content">
|
|
<a href="#education" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('education').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:school" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Formación{{else}}Training{{end}}</span>
|
|
</a>
|
|
<a href="#skills" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('skills').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:brain" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Competencias{{else}}Skills{{end}}</span>
|
|
</a>
|
|
<a href="#experience" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('experience').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:office-building" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Experiencia{{else}}Experience{{end}}</span>
|
|
</a>
|
|
<a href="#awards" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('awards').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:trophy" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Premios y Reconocimientos{{else}}Awards{{end}}</span>
|
|
</a>
|
|
<a href="#projects" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('projects').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:web" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Proyectos Personales / Freelance{{else}}Personal / Freelance Projects{{end}}</span>
|
|
</a>
|
|
<a href="#courses" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('courses').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:school" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Cursos Realizados{{else}}Courses{{end}}</span>
|
|
</a>
|
|
<a href="#languages" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('languages').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:translate" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Idiomas{{else}}Languages{{end}}</span>
|
|
</a>
|
|
<a href="#references" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('references').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:link-variant" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Referencias{{else}}References{{end}}</span>
|
|
</a>
|
|
<a href="#other" class="menu-item"
|
|
_="on click call event.preventDefault() then call document.getElementById('other').scrollIntoView({behavior: 'smooth'})">
|
|
<iconify-icon icon="mdi:information" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Otros{{else}}Other{{end}}</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Quick Actions Section -->
|
|
<div class="menu-section-wrapper">
|
|
<div class="menu-item menu-item-header">
|
|
<iconify-icon icon="mdi:cog-outline" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Acciones Rápidas{{else}}Quick Actions{{end}}</span>
|
|
</div>
|
|
|
|
<a href="#" class="menu-item menu-item-action" onclick="collapseAllSections(event)">
|
|
<iconify-icon icon="mdi:arrow-collapse-all" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Colapsar Todo{{else}}Collapse All{{end}}</span>
|
|
</a>
|
|
<a href="#" class="menu-item menu-item-action" onclick="expandAllSections(event)">
|
|
<iconify-icon icon="mdi:arrow-expand-all" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Expandir Todo{{else}}Expand All{{end}}</span>
|
|
</a>
|
|
<a href="#" id="show-zoom-menu-btn" class="menu-item menu-item-action zoom-hidden">
|
|
<iconify-icon icon="mdi:magnify" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Zoom{{else}}Zoom{{end}}</span>
|
|
</a>
|
|
</div>
|
|
|
|
<!-- View Controls in menu (visible only on mobile < 900px) -->
|
|
<div class="menu-controls-section">
|
|
<div class="menu-item menu-item-header">
|
|
<iconify-icon icon="mdi:tune-variant" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Controles de Vista{{else}}View Controls{{end}}</span>
|
|
</div>
|
|
|
|
<!-- CV Length toggle -->
|
|
<div class="menu-control-item" id="mobile-length-toggle">
|
|
<label class="menu-control-label">
|
|
<iconify-icon icon="mdi:file-document-outline" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Longitud{{else}}Length{{end}}</span>
|
|
</label>
|
|
<div style="display: flex; align-items: center; gap: 8px;">
|
|
<label class="icon-toggle">
|
|
<input type="checkbox"
|
|
id="lengthToggleMenu"
|
|
{{if eq .CVLengthClass "cv-long"}}checked{{end}}
|
|
hx-post="/toggle/length?lang={{.Lang}}"
|
|
hx-swap="none"
|
|
_="on change call toggleCVLength(my.checked)">
|
|
<span class="icon-toggle-slider">
|
|
<iconify-icon icon="mdi:file-document-outline" width="16" height="16" class="icon-left"></iconify-icon>
|
|
<iconify-icon icon="mdi:file-document-multiple-outline" width="16" height="16" class="icon-right"></iconify-icon>
|
|
</span>
|
|
</label>
|
|
<iconify-icon icon="mdi:loading"
|
|
class="htmx-indicator spinning small dark"
|
|
width="14"
|
|
height="14"
|
|
aria-label="Saving"></iconify-icon>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Icon toggle -->
|
|
<div class="menu-control-item" id="mobile-icon-toggle">
|
|
<label class="menu-control-label">
|
|
<iconify-icon icon="mdi:image-multiple-outline" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Iconos{{else}}Icons{{end}}</span>
|
|
</label>
|
|
<div style="display: flex; align-items: center; gap: 8px;">
|
|
<label class="icon-toggle">
|
|
<input type="checkbox"
|
|
id="iconToggleMenu"
|
|
{{if .ShowIcons}}checked{{end}}
|
|
hx-post="/toggle/icons?lang={{.Lang}}"
|
|
hx-swap="none"
|
|
_="on change call toggleIcons(my.checked)">
|
|
<span class="icon-toggle-slider">
|
|
<iconify-icon icon="mdi:image-off-outline" width="16" height="16" class="icon-left"></iconify-icon>
|
|
<iconify-icon icon="mdi:image-multiple-outline" width="16" height="16" class="icon-right"></iconify-icon>
|
|
</span>
|
|
</label>
|
|
<iconify-icon icon="mdi:loading"
|
|
class="htmx-indicator spinning small dark"
|
|
width="14"
|
|
height="14"
|
|
aria-label="Saving"></iconify-icon>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Theme toggle -->
|
|
<div class="menu-control-item" id="mobile-theme-toggle">
|
|
<label class="menu-control-label">
|
|
<iconify-icon icon="mdi:page-layout-sidebar-left" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Vista{{else}}View{{end}}</span>
|
|
</label>
|
|
<div style="display: flex; align-items: center; gap: 8px;">
|
|
<label class="icon-toggle">
|
|
<input type="checkbox"
|
|
id="themeToggleMenu"
|
|
{{if .ThemeClean}}checked{{end}}
|
|
hx-post="/toggle/theme?lang={{.Lang}}"
|
|
hx-swap="none"
|
|
_="on change call toggleTheme(my.checked)">
|
|
<span class="icon-toggle-slider">
|
|
<iconify-icon icon="mdi:page-layout-sidebar-left" width="16" height="16" class="icon-left"></iconify-icon>
|
|
<iconify-icon icon="mdi:page-layout-body" width="16" height="16" class="icon-right"></iconify-icon>
|
|
</span>
|
|
</label>
|
|
<iconify-icon icon="mdi:loading"
|
|
class="htmx-indicator spinning small dark"
|
|
width="14"
|
|
height="14"
|
|
aria-label="Saving"></iconify-icon>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Action Buttons in menu (visible only on mobile < 900px) -->
|
|
<div class="menu-actions-section">
|
|
<div class="menu-item menu-item-header">
|
|
<iconify-icon icon="mdi:lightning-bolt" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Acciones{{else}}Actions{{end}}</span>
|
|
</div>
|
|
|
|
<button class="menu-action-btn menu-pdf-btn"
|
|
onclick="document.getElementById('pdf-modal').showModal()"
|
|
_="on mouseenter call syncPdfHover(true)
|
|
on mouseleave call syncPdfHover(false)">
|
|
<iconify-icon icon="catppuccin:pdf" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Descargar como PDF{{else}}Download as PDF{{end}}</span>
|
|
</button>
|
|
|
|
<button class="menu-action-btn menu-print-btn"
|
|
_="on click call printFriendly()
|
|
on mouseenter call syncPrintHover(true)
|
|
on mouseleave call syncPrintHover(false)">
|
|
<iconify-icon icon="mdi:leaf" width="20" height="20"></iconify-icon>
|
|
<span>{{if eq .Lang "es"}}Imprimir amigable{{else}}Print Friendly{{end}}</span>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
{{end}}
|