mirror of
https://github.com/hazemKrimi/personal-website.git
synced 2026-05-02 02:10:27 +00:00
97 lines
2.1 KiB
TypeScript
97 lines
2.1 KiB
TypeScript
import { FC, useContext, useState } from 'react';
|
|
import { DarkModeContext } from './DarkMode';
|
|
import styled from 'styled-components';
|
|
import Image from 'next/image';
|
|
import Button from './Button';
|
|
import IconButton from './IconButton';
|
|
import { useRouter } from 'next/router';
|
|
import MobileNav from './MobileNav';
|
|
|
|
const Bar = styled.nav`
|
|
user-select: none;
|
|
width: 100%;
|
|
display: grid;
|
|
grid-template-columns: auto 1fr;
|
|
align-items: center;
|
|
padding: 1rem 0rem;
|
|
|
|
h2 {
|
|
font-size: 1.7rem;
|
|
|
|
@media (max-width: 768px) {
|
|
font-size: 1rem;
|
|
}
|
|
}
|
|
|
|
div {
|
|
display: grid;
|
|
align-items: center;
|
|
column-gap: 1rem;
|
|
|
|
@media (max-width: 768px) {
|
|
column-gap: 0.5rem;
|
|
}
|
|
}
|
|
|
|
.logo {
|
|
cursor: pointer;
|
|
grid-template-columns: repeat(2, auto);
|
|
justify-content: flex-start;
|
|
}
|
|
|
|
.buttons {
|
|
grid-template-columns: repeat(5, auto);
|
|
justify-content: flex-end;
|
|
|
|
@media (max-width: 768px) {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
.mobile-buttons {
|
|
display: none;
|
|
|
|
@media (max-width: 768px) {
|
|
display: grid;
|
|
grid-template-columns: repeat(2, auto);
|
|
justify-content: flex-end;
|
|
}
|
|
}
|
|
`;
|
|
|
|
const Nav: FC = () => {
|
|
const [mobileNavOpen, setMobileNavOpen] = useState<boolean>(false);
|
|
const { dark, toggle } = useContext(DarkModeContext);
|
|
const router = useRouter();
|
|
|
|
return (
|
|
<Bar>
|
|
<div className='logo'>
|
|
<Image className='logo-image' src='/logo.jpg' alt='Logo Image' width={48} height={48} />
|
|
<h2>Hazem Krimi</h2>
|
|
</div>
|
|
<div className='buttons'>
|
|
<IconButton icon={dark ? '/sun.svg' : '/moon.svg'} onClick={toggle} />
|
|
<Button>About</Button>
|
|
<Button>Blog</Button>
|
|
<Button>Portfolio</Button>
|
|
<Button variant='outline' onClick={() => router.push('/resume.pdf')}>
|
|
Resume
|
|
</Button>
|
|
</div>
|
|
<div className='mobile-buttons'>
|
|
<Button variant='outline' onClick={() => router.push('/hazem-krimi.pdf')}>
|
|
Resume
|
|
</Button>
|
|
<IconButton
|
|
icon={dark ? '/light-menu.svg' : '/dark-menu.svg'}
|
|
onClick={() => setMobileNavOpen(true)}
|
|
/>
|
|
</div>
|
|
<MobileNav open={mobileNavOpen} close={() => setMobileNavOpen(false)} />
|
|
</Bar>
|
|
);
|
|
};
|
|
|
|
export default Nav;
|