Improved authentication; added fallbacks to 3D; cleaner dashboard charts
This commit is contained in:
@@ -6,6 +6,8 @@ import Image from 'next/image'
|
||||
import useUIStore from '../../app/store/uiStore'
|
||||
import useNavigationStore from '../../app/store/navigationStore'
|
||||
import { useNavigationService } from '@/services/navigationService'
|
||||
import useUserStore from '../../app/store/userStore'
|
||||
import { signOut } from 'next-auth/react'
|
||||
|
||||
interface NavigationItem {
|
||||
id: number
|
||||
@@ -130,8 +132,8 @@ const navigationSubItems: NavigationItem[] = [
|
||||
const Sidebar: React.FC<SidebarProps> = ({
|
||||
logoSrc,
|
||||
userInfo = {
|
||||
name: 'Александр',
|
||||
role: 'Администратор'
|
||||
name: '—',
|
||||
role: '—'
|
||||
},
|
||||
activeItem: propActiveItem,
|
||||
onCustomItemClick
|
||||
@@ -150,7 +152,35 @@ const Sidebar: React.FC<SidebarProps> = ({
|
||||
setNavigationSubMenuExpanded: setShowNavigationSubItems,
|
||||
toggleNavigationSubMenu
|
||||
} = useUIStore()
|
||||
|
||||
const { user, logout } = useUserStore()
|
||||
|
||||
const roleLabelMap: Record<string, string> = {
|
||||
engineer: 'Инженер',
|
||||
operator: 'Оператор',
|
||||
admin: 'Администратор',
|
||||
}
|
||||
const fullName = [user?.name, user?.surname].filter(Boolean).join(' ').trim()
|
||||
|
||||
const uiUserInfo = {
|
||||
name: fullName || user?.login || userInfo?.name || '—',
|
||||
role: roleLabelMap[(user?.account_type ?? '').toLowerCase()] || userInfo?.role || '—',
|
||||
avatar: user?.image || userInfo?.avatar,
|
||||
}
|
||||
|
||||
const handleLogout = async () => {
|
||||
try {
|
||||
await fetch('/api/auth/logout', {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
credentials: 'include',
|
||||
})
|
||||
} catch (e) {
|
||||
console.error('Logout request failed:', e)
|
||||
} finally {
|
||||
logout()
|
||||
await signOut({ redirect: true, callbackUrl: '/login' })
|
||||
}
|
||||
}
|
||||
const {
|
||||
openMonitoring,
|
||||
openFloorNavigation,
|
||||
@@ -401,9 +431,9 @@ const Sidebar: React.FC<SidebarProps> = ({
|
||||
role="img"
|
||||
aria-label="User avatar"
|
||||
>
|
||||
{userInfo.avatar && (
|
||||
{uiUserInfo.avatar && (
|
||||
<Image
|
||||
src={userInfo.avatar}
|
||||
src={uiUserInfo.avatar}
|
||||
alt="User avatar"
|
||||
className="w-full h-full rounded-lg object-cover"
|
||||
fill
|
||||
@@ -417,21 +447,24 @@ const Sidebar: React.FC<SidebarProps> = ({
|
||||
<div className="flex p-2 flex-1 grow items-center gap-2 relative rounded-md">
|
||||
<div className="flex flex-col items-start justify-center gap-0.5 relative flex-1 grow">
|
||||
<div className="self-stretch mt-[-1.00px] [font-family:'Inter-SemiBold',Helvetica] font-semibold text-white text-sm leading-[14px] relative tracking-[0] overflow-hidden text-ellipsis [display:-webkit-box] [-webkit-line-clamp:1] [-webkit-box-orient:vertical]">
|
||||
{userInfo.name}
|
||||
{uiUserInfo.name}
|
||||
</div>
|
||||
<div className="self-stretch [font-family:'Inter-Regular',Helvetica] font-normal text-[#71717a] text-[10px] leading-[10px] relative tracking-[0] overflow-hidden text-ellipsis [display:-webkit-box] [-webkit-line-clamp:1] [-webkit-box-orient:vertical]">
|
||||
{userInfo.role}
|
||||
{uiUserInfo.role}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<button
|
||||
className="relative w-4 h-4 aspect-[1] p-1 rounded hover:bg-gray-700 focus:bg-gray-700 focus:outline-none focus:ring-2 focus:ring-blue-500 transition-colors duration-200"
|
||||
aria-label="User menu"
|
||||
aria-label="Logout"
|
||||
title="Выйти"
|
||||
type="button"
|
||||
onClick={handleLogout}
|
||||
>
|
||||
<svg className="w-3.5 h-3.5 text-white" fill="currentColor" viewBox="0 0 24 24">
|
||||
<path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" />
|
||||
<svg className="w-5 h-5 text-white" fill="currentColor" viewBox="0 0 24 24" aria-hidden="true">
|
||||
<path d="M10 17l-5-5 5-5v3h8v4h-8v3z" />
|
||||
<path d="M20 3h-8v2h8v14h-8v2h8c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z" />
|
||||
</svg>
|
||||
</button>
|
||||
</footer>
|
||||
|
||||
Reference in New Issue
Block a user