import Navbar from "../components/Navbar.jsx"; import {useEffect, useState} from "react"; import PlaylistCard from "../components/PlaylistCard.jsx"; import VideoCard from "../components/VideoCard.jsx"; import {useNavigate} from "react-router-dom"; export default function Account() { let user = JSON.parse(localStorage.getItem("user")) || {}; let token = localStorage.getItem("token") || ""; const [username, setUsername] = useState(user.username || ""); const [email, setEmail] = useState(user.email || ""); const [password, setPassword] = useState(""); const [confirmPassword, setConfirmPassword] = useState(""); const [isPictureEditActive, setIsPictureEditActive] = useState(false); const [userHistory, setUserHistory] = useState([]); const [userPlaylists, setUserPlaylists] = useState([]); const [userChannel, setUserChannel] = useState(null); const navigation = useNavigate(); const fetchUserChannel = async () => { try { const response = await fetch(`/api/users/${user.id}/channel`, { method: "GET", headers: { "Authorization": `Bearer ${token}`, } }); if (!response.ok) { throw new Error("Failed to fetch user data"); } const data = await response.json(); setUserChannel(data); } catch (error) { console.error("Error fetching user channel:", error); return null; } } const fetchUserHistory = async () => { if (!user.id || !token) { console.warn("User ID or token missing, skipping history fetch"); return; } try { const response = await fetch(`/api/users/${user.id}/history`, { method: "GET", headers: { "Authorization": `Bearer ${token}`, } }); if (!response.ok) { throw new Error("Failed to fetch user history"); } const data = await response.json(); setUserHistory(data); } catch (error) { console.error("Error fetching user history:", error); } } const fetchUserPlaylists = async () => { if (!user.id || !token) { console.warn("User ID or token missing, skipping playlists fetch"); return; } try { const response = await fetch(`/api/playlists/user/${user.id}`, { method: "GET", headers: { "Authorization": `Bearer ${token}`, } }); if (!response.ok) { throw new Error("Failed to fetch user playlists"); } const data = await response.json(); setUserPlaylists(data); } catch (error) { console.error("Error fetching user playlists:", error); } } useEffect(() => { fetchUserChannel(); fetchUserHistory(); fetchUserPlaylists(); }, []); const [editMode, setEditMode] = useState(false); const nonEditModeClasses = "text-2xl font-bold text-white p-2 focus:text-white focus:outline-none w-full font-montserrat"; const editModeClasses = nonEditModeClasses + " glassmorphism"; const handlePlaylistClick = (playlistId) => { navigation(`/playlist/${playlistId}`); } const handleUpdateUser = async () => { if (password !== confirmPassword) { alert("Les mots de passe ne correspondent pas."); return; } const updatedUser = { username, email, password: password || undefined, // Only send password if it's not empty }; try { const response = await fetch(`/api/users/${user.id}`, { method: "PUT", headers: { "Content-Type": "application/json", "Authorization": `Bearer ${token}`, }, body: JSON.stringify(updatedUser), }); if (!response.ok) { throw new Error("Failed to update user"); } const data = await response.json(); localStorage.setItem("user", JSON.stringify(data.user)); setEditMode(false); alert("Profil mis à jour avec succès !"); } catch (error) { console.error("Error updating user:", error); alert("Erreur lors de la mise à jour du profil."); } } return (
{/* Left side */} {/* Profile / Edit profile */}
setIsPictureEditActive(true)} onMouseLeave={() => setIsPictureEditActive(false)} >
setUsername(e.target.value)} placeholder="Nom d'utilisateur" disabled={!editMode} /> setEmail(e.target.value)} placeholder="Adresse mail" disabled={!editMode} /> { editMode && ( <> setPassword(e.target.value)} placeholder="**************" disabled={!editMode} /> setConfirmPassword(e.target.value)} placeholder="" disabled={!editMode} /> ) }
{ editMode ? (
) : ( ) }
{ /* Right side */}
{/* Channel */} {userChannel ? (

{userChannel.channel.name}

) : (

Chaîne

Aucune chaîne associée à ce compte.

)} {/* Playlists */}

Playlists

{ userPlaylists.map((playlist, index) => ( )) }
{/* History */}

Historique

{ userHistory.map((video, index) => (
)) }
) }