Enjambre Discografia Site
// fondo de imagen con gradiente + ícono representativo const bgGradient = `linear-gradient(135deg, ${album.coverColor}dd, ${album.coverColor}aa)`; // lista de tracks (mostrar máximo 6 primeros) const trackListItems = album.tracks.slice(0, 8).map(track => `<li><i class="fas fa-music" style="font-size: 0.6rem; margin-right: 4px;"></i> ${escapeHtml(track)}</li>`).join(''); const moreTracks = album.tracks.length > 8 ? `<li style="background: none;">+${album.tracks.length - 8} más</li>` : '';
/* controls bar */ .controls { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; background: #fffcf7; padding: 1.2rem 2rem; border-bottom: 1px solid #e2d5c8; box-shadow: 0 2px 8px rgba(0,0,0,0.02); } .search-box { flex: 2; min-width: 200px; display: flex; align-items: center; background: #f3ede7; border-radius: 60px; padding: 0.4rem 1rem; border: 1px solid #e0cfc0; transition: all 0.2s; } .search-box i { color: #aa7e5a; margin-right: 10px; font-size: 1.1rem; } .search-box input { background: transparent; border: none; padding: 0.7rem 0; font-size: 1rem; width: 100%; outline: none; font-weight: 400; font-family: 'Inter', monospace; } .filter-buttons { display: flex; flex-wrap: wrap; gap: 0.6rem; } .filter-btn { background: #ede4db; border: none; padding: 0.5rem 1.2rem; border-radius: 40px; font-weight: 500; font-size: 0.85rem; cursor: pointer; transition: all 0.2s ease; font-family: 'Inter', sans-serif; color: #3a2e26; display: inline-flex; align-items: center; gap: 6px; } .filter-btn i { font-size: 0.8rem; } .filter-btn.active { background: #aa7e5a; color: white; box-shadow: 0 4px 10px rgba(170,126,90,0.3); } .filter-btn:hover:not(.active) { background: #d6c8bc; transform: translateY(-1px); } .stats { background: #e9dfd5; padding: 0.4rem 1rem; border-radius: 40px; font-size: 0.85rem; font-weight: 500; color: #4a372a; }
body { background: linear-gradient(145deg, #f6f2eb 0%, #e8e2d8 100%); font-family: 'Inter', sans-serif; color: #1e1b17; scroll-behavior: smooth; } enjambre discografia
// renderizar grid con animación sencilla function render() { const filteredData = filterDiscos(); const total = filteredData.length; statsSpan.innerHTML = `📀 ${total} ${total === 1 ? 'disco' : 'discos'}`;
// añadir efecto de pequeño detalle extra: click en estadística para resetear búsqueda opcional (doble click) statsSpan.addEventListener('dblclick', () => { searchInput.value = ''; currentSearch = ''; render(); searchInput.focus(); }); // tooltip informal statsSpan.title = "Doble clic para limpiar búsqueda"; </script> </body> </html> // fondo de imagen con gradiente + ícono
// elementos DOM const gridContainer = document.getElementById('discogGrid'); const searchInput = document.getElementById('searchInput'); const filterBtns = document.querySelectorAll('.filter-btn'); const statsSpan = document.getElementById('statsCounter');
// filtrar por tipo if (currentFilter !== 'all') { filtered = filtered.filter(album => album.type === currentFilter); } 'fas fa-microphone' : (typeIcon === '💿'
// evento búsqueda searchInput.addEventListener('input', onSearchInput);
html += ` <div class="card"> <div class="card-img" style="background: ${bgGradient}; display: flex; flex-direction: column; justify-content: center; align-items: center;"> <i class="${album.icon}" style="font-size: 4rem; color: rgba(255,245,225,0.9); text-shadow: 2px 2px 0px rgba(0,0,0,0.2);"></i> <span style="margin-top: 10px; font-size: 0.7rem; font-weight: 600; background: rgba(0,0,0,0.4); padding: 0.2rem 1rem; border-radius: 20px; backdrop-filter: blur(2px); color: white;">${album.year}</span> </div> <div class="card-content"> <div class="album-year"> <span>${album.year}</span> <span><i class="far fa-calendar-alt"></i></span> </div> <div class="album-title">${escapeHtml(album.title)}</div> <div class="album-type"><i class="${typeIcon === '🎙️' ? 'fas fa-microphone' : (typeIcon === '💿' ? 'fas fa-cd' : 'fas fa-head-side-vr')}" style="margin-right: 5px;"></i> ${typeLabel}</div> <div class="tracklist"> <h4><i class="fas fa-list-ul"></i> Canciones destacadas</h4> <ul> ${trackListItems} ${moreTracks} </ul> </div> </div> </div> `; } gridContainer.innerHTML = html; }
