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' | import Image from 'next/image' | ||||||
| 
 | 
 | ||||||
| export default function Bio() { | export default function Home() { | ||||||
|   return ( |   return ( | ||||||
|     <div className="max-w-2xl mx-auto"> |     <div className="max-w-2xl mx-auto"> | ||||||
|       <div className="mb-12 text-center"> |       <div className="mb-12 text-center"> | ||||||
|  | @ -28,7 +28,7 @@ export default function Bio() { | ||||||
|         </p> |         </p> | ||||||
|       </section> |       </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> |         <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> |         <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"> |         <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"> | ||||||
							
								
								
									
										14
									
								
								app/page.tsx
									
										
									
									
									
								
							
							
						
						
									
										14
									
								
								app/page.tsx
									
										
									
									
									
								
							|  | @ -1,15 +1,17 @@ | ||||||
| import Header from './components/Header' | import Header from './components/Header'; | ||||||
| import Bio from './components/Bio' | import HomePg from './components/pages/Home'; | ||||||
| import Footer from './components/Footer' | import Footer from './components/Footer'; | ||||||
|  | import NowPlaying from './components/NowPlaying'; | ||||||
| 
 | 
 | ||||||
| export default function Home() { | export default function Home() { | ||||||
|   return ( |   return ( | ||||||
|     <div className="min-h-screen flex flex-col"> |     <div className="min-h-screen flex flex-col"> | ||||||
|       <Header /> |       <Header /> | ||||||
|       <main className="flex-grow container mx-auto px-4 py-12"> |       <main className="flex-grow container mx-auto px-4 py-12"> | ||||||
|         <Bio /> |         <HomePg /> | ||||||
|  |         <NowPlaying /> | ||||||
|       </main> |       </main> | ||||||
|       <Footer /> |       <Footer /> | ||||||
|     </div> |     </div> | ||||||
|   ) |   ); | ||||||
| } | } | ||||||
|  | @ -22,7 +22,7 @@ | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "typescript": "^5", |     "typescript": "^5", | ||||||
|     "@types/node": "^20", |     "@types/node": "^20", | ||||||
|     "@types/react": "^19", |     "@types/react": "^19.0.2", | ||||||
|     "@types/react-dom": "^19", |     "@types/react-dom": "^19", | ||||||
|     "postcss": "^8", |     "postcss": "^8", | ||||||
|     "tailwindcss": "^3.4.1", |     "tailwindcss": "^3.4.1", | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue