fix structure, add music widget
This commit is contained in:
		
							parent
							
								
									826d1d4b7d
								
							
						
					
					
						commit
						88149ed26a
					
				
					 4 changed files with 72 additions and 9 deletions
				
			
		
							
								
								
									
										61
									
								
								app/components/NowPlaying.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								app/components/NowPlaying.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | |||
| "use client"; | ||||
| 
 | ||||
| import React, { useEffect, useState, JSX } from 'react'; | ||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||
| import { faLastfm } from '@fortawesome/free-brands-svg-icons' | ||||
| import { faCompactDisc, faUser } from '@fortawesome/free-solid-svg-icons' | ||||
| 
 | ||||
| interface Track { | ||||
|   name: string; | ||||
|   artist: { '#text': string }; | ||||
|   album: { '#text': string }; | ||||
|   image: { '#text': string; size: string }[]; | ||||
|   url: string; | ||||
|   '@attr'?: { nowplaying: string }; | ||||
| } | ||||
| 
 | ||||
| const NowPlaying: React.FC = () => { | ||||
|   const [track, setTrack] = useState<Track | null>(null); | ||||
|   const apiUrl = process.env.LASTFM_API_URL || 'https://lastfm-last-played.biancarosa.com.br/aidxn_/latest-song'; | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     fetch(apiUrl) | ||||
|       .then(response => response.json()) | ||||
|       .then(data => setTrack(data.track)) | ||||
|       .catch(error => console.error('Error fetching now playing:', error)); | ||||
|   }, [apiUrl]); | ||||
| 
 | ||||
|   if (!track) { | ||||
|     return ( | ||||
|       <div className="max-w-2xl mx-auto"> | ||||
|         <h2 className="text-2xl font-bold mb-4 pt-10 text-gray-200">Music</h2> | ||||
|         <div className="flex justify-center items-center border border-gray-300 rounded-lg p-4 max-w-md mt-8"> | ||||
|           <span className="spinner-border animate-spin inline-block w-8 h-8 border-4 rounded-full" role="status"></span> | ||||
|         </div> | ||||
|       </div> | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <div className="max-w-2xl mx-auto"> | ||||
|       <h2 className="text-2xl font-bold mb-4 pt-10 text-gray-200">Music</h2> | ||||
|       <div className="now-playing flex items-center border border-gray-300 rounded-lg p-4 max-w-md mt-8 bg-white bg-opacity-10 backdrop-filter backdrop-blur-lg"> | ||||
|         <img  | ||||
|           src={track.image.find(img => img.size === 'large')?.['#text']}  | ||||
|           alt={track.name}  | ||||
|           className="w-24 h-24 rounded-lg mr-4" | ||||
|         /> | ||||
|         <div> | ||||
|           <p className="font-bold">{track.name}</p> | ||||
|           <p><FontAwesomeIcon icon={faCompactDisc} className="mr-1" /> {track.album['#text']}</p> | ||||
|           <i><FontAwesomeIcon icon={faUser} className="mr-1" /> {track.artist['#text']}</i> | ||||
|           <a href={track.url} target="_blank" rel="noopener noreferrer" className="text-blue-500 flex items-center"> | ||||
|             <FontAwesomeIcon icon={faLastfm} className="mr-2" /> View on Last.fm | ||||
|           </a> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   ); | ||||
| }; | ||||
| 
 | ||||
| export default NowPlaying; | ||||
|  | @ -1,6 +1,6 @@ | |||
| import Image from 'next/image' | ||||
| 
 | ||||
| export default function Bio() { | ||||
| export default function Home() { | ||||
|   return ( | ||||
|     <div className="max-w-2xl mx-auto"> | ||||
|       <div className="mb-12 text-center"> | ||||
|  | @ -28,7 +28,7 @@ export default function Bio() { | |||
|         </p> | ||||
|       </section> | ||||
|        | ||||
|       <section id="contact" className="text-center"> | ||||
|       <section id="contact"> | ||||
|         <h2 className="text-2xl font-semibold mb-4 text-gray-200">Send me a message</h2> | ||||
|         <p className="text-gray-300 mb-6">Feel free to reach out for collaborations or just a hello :)</p> | ||||
|         <a href="/contact" className="bg-gray-700 text-white px-8 py-3 rounded-full hover:bg-gray-600 transition-colors text-lg font-medium"> | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue