$(document).ready(() => { let currentUser = null; let allRoles = []; const token = localStorage.getItem("access_token"); if (!token) { window.location.href = "/login"; return; } loadProfile(); function loadProfile() { showLoadingState(); Promise.all([ fetch("/api/auth/me", { headers: { Authorization: "Bearer " + token }, }).then((response) => { if (!response.ok) { if (response.status === 401) { throw new Error("Unauthorized"); } throw new Error(`HTTP error! status: ${response.status}`); } return response.json(); }), fetch("/api/auth/roles", { headers: { Authorization: "Bearer " + token }, }).then((response) => { if (response.ok) return response.json(); return { roles: [] }; }), ]) .then(([user, rolesData]) => { currentUser = user; allRoles = rolesData.roles || []; renderProfile(user); renderAccountInfo(user); renderRoles(user.roles, allRoles); renderActions(); document.title = `LiB - ${user.full_name || user.username}`; }) .catch((error) => { console.error("Error loading profile:", error); if (error.message === "Unauthorized") { localStorage.removeItem("access_token"); localStorage.removeItem("refresh_token"); window.location.href = "/login"; } else { showErrorState(error.message); } }); } function renderProfile(user) { const $card = $("#profile-card"); const displayName = user.full_name || user.username; const firstLetter = displayName.charAt(0).toUpperCase(); const emailHash = sha256(user.email.trim().toLowerCase()); const avatarUrl = `https://www.gravatar.com/avatar/${emailHash}?d=identicon&s=200`; $card.html(`
@${escapeHtml(user.username)}
ID пользователя
${user.id}
Имя пользователя
@${escapeHtml(user.username)}
Полное имя
${escapeHtml(user.full_name || "Не указано")}
${escapeHtml(user.email)}
У вас нет назначенных ролей
`); return; } const roleDescriptions = {}; allRoles.forEach((role) => { roleDescriptions[role.name] = role.description; }); const roleIcons = { admin: ``, librarian: ``, member: ``, }; const roleColors = { admin: "bg-red-100 text-red-800 border-red-200", librarian: "bg-blue-100 text-blue-800 border-blue-200", member: "bg-green-100 text-green-800 border-green-200", }; let rolesHtml = '${escapeHtml(description)}