{userChannel.channel.name}
Chaîne
Aucune chaîne associée à ce compte.
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 (
{userChannel.channel.name}
Aucune chaîne associée à ce compte.