prigoana.com/wallpaper.html
EduardSkibidiEdger c93dfb3a76 sdjhtrdthr
2024-12-06 18:40:31 +02:00

170 lines
4.8 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Last.fm Now Playing</title>
<style>
@font-face {
font-family: 'CustomFont';
src: url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600&display=swap') format('woff2');
}
body {
margin: 0;
padding: 0;
height: 100vh;
overflow: hidden;
background-color: #000;
font-family: 'CustomFont', Arial, sans-serif;
}
#background {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-size: cover;
background-position: center;
filter: blur(10px);
z-index: -1;
transition: background-image 1s ease-in-out;
}
.noblur #background {
filter: none;
}
#track-info {
position: absolute;
bottom: 20px;
left: 20px;
color: white;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}
#track-info h1, #track-info p {
opacity: 1;
transform: translateY(0);
transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}
#track-info h1 {
font-size: 2.5em;
margin-bottom: 0.5em;
}
#track-info p {
font-size: 1.3em;
margin: 0.2em 0;
}
.hidden {
opacity: 0;
transform: translateY(20px);
}
.fade-in {
opacity: 0;
animation: fadeIn 0.5s forwards;
}
@keyframes fadeIn {
0% {
opacity: 0;
}
100% {
opacity: 1;
}
}
</style>
</head>
<body>
<div id="background"></div>
<div id="track-info">
<h1 id="track-title"></h1>
<p id="track-artist"></p>
<p id="track-album"></p>
</div>
<script>
const username = localStorage.getItem('lastfmUsername') || 'yetiuard';
const url = `https://lastfm-last-played.biancarosa.com.br/${username}/latest-song`;
const backgroundElement = document.getElementById('background');
const trackTitleElement = document.getElementById('track-title');
const trackArtistElement = document.getElementById('track-artist');
const trackAlbumElement = document.getElementById('track-album');
const placeholderImage = "";
let previousTrack = "", previousAlbumImage = "";
// Check if #noblur is in the URL
if (window.location.hash === "#noblur") {
document.body.classList.add('noblur');
}
async function fetchLastPlayedSong() {
try {
const response = await fetch(url);
const { track } = await response.json();
if (!track) return;
const trackName = formatTrackName(track.name);
const artistName = track.artist?.['#text'];
const albumName = track.album?.['#text'];
const albumImage = track.image.find(img => img.size === "large")?.['#text'] || placeholderImage;
if (trackName !== previousTrack || albumImage !== previousAlbumImage) {
updateTrackInfo(trackName, artistName, albumName, albumImage);
previousTrack = trackName;
previousAlbumImage = albumImage;
}
} catch (error) {
console.error("Error fetching Last.fm data:", error);
}
}
function formatTrackName(name) {
// Remove "(Album Version (Explicit))" from the track title if it exists
return name.replace(/ \(Album Version \(Explicit\)\)/i, '');
}
function updateTrackInfo(trackName, artistName, albumName, albumImage) {
preloadImage(albumImage, () => {
// Update background and track info
backgroundElement.style.backgroundImage = `url(${albumImage})`;
// Fade out current text
trackTitleElement.classList.add('hidden');
trackArtistElement.classList.add('hidden');
trackAlbumElement.classList.add('hidden');
setTimeout(() => {
// Update track information
trackTitleElement.textContent = trackName;
trackArtistElement.textContent = artistName || "Unknown Artist";
trackAlbumElement.textContent = albumName || "Unknown Album";
// Apply fade-in animation to new text
trackTitleElement.classList.remove('hidden');
trackArtistElement.classList.remove('hidden');
trackAlbumElement.classList.remove('hidden');
trackTitleElement.classList.add('fade-in');
trackArtistElement.classList.add('fade-in');
trackAlbumElement.classList.add('fade-in');
}, 500); // Match transition timing
});
}
function preloadImage(src, callback) {
const img = new Image();
img.src = src;
img.onload = callback;
}
fetchLastPlayedSong();
setInterval(fetchLastPlayedSong, 1000);
</script>
</body>
</html>