Mejorar navbar: cambiar menú de sidebar a horizontal con dropdowns y ajustar tarjeta de BD

This commit is contained in:
Admin
2026-01-16 20:46:45 -06:00
parent 0b3d76822d
commit 1d17386299
9 changed files with 2065 additions and 234 deletions

View File

@@ -1,17 +1,6 @@
</main>
</div>
<!-- /#page-content-wrapper -->
</div>
<!-- /#wrapper -->
<!-- Scripts -->
<script src="https://code.jquery.com/jquery-3.7.1.min.js" integrity="sha256-/JqT3SQfawRcv/BIHPThkBvs0OEvtFFmqPF/lYI/Cxo=" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js" integrity="sha384-C6RzsynM9kWDrMNeT87bh95OGNyZPhcTNXj1NW7RuBCsyN/o0jlpcV8Qyq46cDfL" crossorigin="anonymous"></script>
</main>
</div>
<!-- /#page-content-wrapper -->
</div>
<!-- /#wrapper -->
<!-- Scripts -->
<script src="https://code.jquery.com/jquery-3.7.1.min.js" integrity="sha256-/JqT3SQfawRcv/BIHPThkBvs0OEvtFFmqPF/lYI/Cxo=" crossorigin="anonymous"></script>
@@ -19,132 +8,6 @@
<script src="<?php echo asset('js/summernote-bs5.min.js'); ?>" defer></script>
<script src="<?php echo asset('js/main.js'); ?>" defer></script>
<!-- Script para el menú desplegable -->
<script>
// Función para inicializar el menú
function initMenu() {
const menuToggle = document.getElementById('menu-toggle');
const wrapper = document.getElementById('wrapper');
const sidebar = document.getElementById('sidebar-wrapper');
const overlay = document.querySelector('.overlay');
let isMobile = window.innerWidth <= 768;
let isTransitioning = false;
// Función para abrir el menú
function openMenu() {
if (isTransitioning || !wrapper || !overlay) return;
isTransitioning = true;
wrapper.classList.add('toggled');
overlay.classList.add('show'); // Usar la clase 'show'
isTransitioning = false;
}
// Función para cerrar el menú
function closeMenu() {
if (isTransitioning || !wrapper || !overlay) return;
isTransitioning = true;
overlay.classList.remove('show'); // Usar la clase 'show'
// Esperar a que termine la transición antes de ocultar
const onTransitionEnd = () => {
if (!overlay.classList.contains('show')) { // Verificar si la clase 'show' ya no está
wrapper.classList.remove('toggled');
overlay.removeEventListener('transitionend', onTransitionEnd);
isTransitioning = false;
}
};
overlay.addEventListener('transitionend', onTransitionEnd, { once: true });
}
// Función para alternar el menú
function toggleMenu() {
if (wrapper.classList.contains('toggled')) {
closeMenu();
} else {
openMenu();
}
}
// Evento para el botón de menú
if (menuToggle) {
menuToggle.addEventListener('click', function(e) {
e.preventDefault();
e.stopPropagation();
toggleMenu();
});
}
// Cerrar el menú al hacer clic en el overlay
if (overlay) {
overlay.addEventListener('click', function(e) {
e.stopPropagation();
closeMenu();
});
}
// Cerrar el menú al hacer clic en un enlace en pantallas pequeñas
const navLinks = document.querySelectorAll('.list-group-item');
navLinks.forEach(function(link) {
link.addEventListener('click', function() {
if (window.innerWidth <= 768) {
toggleMenu();
}
});
});
// Ajustar el menú al cambiar el tamaño de la ventana
function handleResize() {
if (isTransitioning) return;
const newIsMobile = window.innerWidth <= 768;
if (newIsMobile !== isMobile) {
isMobile = newIsMobile;
if (!isMobile) {
// En pantallas grandes, asegurarse de que el menú esté visible
if (wrapper) wrapper.classList.remove('toggled');
if (overlay) {
overlay.classList.remove('show'); // Usar la clase 'show'
}
}
} else {
// En móviles, asegurarse de que el menú esté cerrado al inicio
if (wrapper) wrapper.classList.remove('toggled');
if (overlay) {
overlay.classList.remove('show'); // Usar la clase 'show'
}
}
}
// Manejar el evento de redimensionamiento
window.addEventListener('resize', handleResize);
// Inicializar el estado del menú
handleResize();
}
// Inicializar el menú cuando el DOM esté listo
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initMenu);
} else {
initMenu();
}
// Manejar el evento de carga completa para asegurar que todo esté listo
window.addEventListener('load', function() {
// Asegurarse de que el menú se inicialice correctamente
if (typeof initMenu === 'function') {
initMenu();
}
});
</script>
<script src="/assets/js/translate_frontend.js"></script>
<!-- Script para eliminar el Debug Language List -->
<script>
document.addEventListener('DOMContentLoaded', function() {
@@ -152,8 +15,72 @@
if (debugList) {
debugList.remove();
}
// Fix para dropdowns en móvil
const dropdownToggles = document.querySelectorAll('.dropdown-toggle');
dropdownToggles.forEach(toggle => {
toggle.addEventListener('click', function(e) {
e.preventDefault();
e.stopPropagation();
// Obtener el elemento dropdown
const dropdown = this.closest('.dropdown') || this.parentElement;
const menu = this.nextElementSibling;
if (menu && menu.classList.contains('dropdown-menu')) {
// Toggle la clase 'show'
if (menu.classList.contains('show')) {
menu.classList.remove('show');
this.classList.remove('show');
this.setAttribute('aria-expanded', 'false');
} else {
// Cerrar otros dropdowns
document.querySelectorAll('.dropdown-menu.show').forEach(m => {
m.classList.remove('show');
m.previousElementSibling?.classList.remove('show');
});
menu.classList.add('show');
this.classList.add('show');
this.setAttribute('aria-expanded', 'true');
}
}
});
});
// Cerrar dropdowns al hacer clic en un item
const dropdownItems = document.querySelectorAll('.dropdown-item');
dropdownItems.forEach(item => {
item.addEventListener('click', function() {
// Cerrar todos los dropdowns
document.querySelectorAll('.dropdown-menu.show').forEach(m => {
m.classList.remove('show');
m.previousElementSibling?.classList.remove('show');
});
document.querySelectorAll('.dropdown-toggle.show').forEach(t => {
t.classList.remove('show');
t.setAttribute('aria-expanded', 'false');
});
});
});
// Cerrar dropdowns al hacer clic fuera
document.addEventListener('click', function(e) {
if (!e.target.closest('.dropdown') && !e.target.closest('.nav-item.dropdown')) {
document.querySelectorAll('.dropdown-menu.show').forEach(m => {
m.classList.remove('show');
m.previousElementSibling?.classList.remove('show');
});
document.querySelectorAll('.dropdown-toggle.show').forEach(t => {
t.classList.remove('show');
t.setAttribute('aria-expanded', 'false');
});
}
});
});
</script>
<script src="/assets/js/translate_frontend.js"></script>
</body>
</html>