jackson/components/Navbar.tsx

62 lines
2.1 KiB
TypeScript

import type { Session } from 'next-auth';
import React from 'react';
import { signOut } from 'next-auth/react';
import classNames from 'classnames';
import Link from 'next/link';
import { useTranslation } from 'next-i18next';
import PowerIcon from '@heroicons/react/20/solid/PowerIcon';
export const Navbar = ({ session }: { session: Session | null }) => {
const [isOpen, setIsOpen] = React.useState(false);
const { t } = useTranslation('common');
return (
<div className='flex flex-1 justify-between px-4'>
<div className='flex flex-1'></div>
<div className='ml-4 flex items-center md:ml-6'>
<div className='relative ml-3'>
{session && (
<div>
<button
type='button'
className='flex h-8 w-8 items-center justify-center rounded-full bg-secondary uppercase text-cyan-50 focus:outline-none'
aria-expanded='false'
aria-haspopup='true'
data-testid='user-avatar'
onClick={() => {
setIsOpen(!isOpen);
}}>
<span className='sr-only'>{t('open_menu')}</span>
{session?.user?.name?.[0]}
</button>
</div>
)}
{session && (
<div
className={classNames(
'absolute right-0 mt-2 w-48 origin-top-right rounded-md bg-white py-1 shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none',
{ hidden: !isOpen }
)}
role='menu'
aria-orientation='vertical'
aria-labelledby='user-menu-button'
tabIndex={-1}>
<Link
href=''
className='link flex px-4 py-2 text-sm hover:link-primary'
role='menuitem'
tabIndex={-1}
data-testid='logout'
id='user-menu-item-2'
onClick={() => signOut()}>
<PowerIcon className='mr-1 h-5 w-5' aria-hidden />
{t('sign_out')}
</Link>
</div>
)}
</div>
</div>
</div>
);
};