rsnext/examples/cms-buttercms/components/header-section.js
Maria Violante fec5318e91
Update buttercms example (#35436)
* remove old buttercms project files

* Updated .gitignore

* Add new buttercms files

* Add readme and remove name from package.json

* fix linting error

* Fix eslint

* Update examples/cms-buttercms/.gitignore

Co-authored-by: Lee Robinson <me@leerob.io>

* renamed .env.sample > .env.local.example

* remove dangerously allow svg

* Update examples/cms-buttercms/package.json

Co-authored-by: Lee Robinson <me@leerob.io>
2022-05-03 12:41:27 +02:00

51 lines
1.4 KiB
JavaScript

import { useEffect, useState, useRef } from 'react'
import Image from 'next/image'
import MainMenu from './main-menu/main-menu'
export default function HeaderSection({ mainMenu }) {
const [isNavbarSticky, setIsNavbarSticky] = useState(false)
const navbarAreaEl = useRef(null)
function fixNavBar() {
if (navbarAreaEl.current) {
setIsNavbarSticky(window.pageYOffset > navbarAreaEl.current.offsetTop)
}
}
useEffect(() => {
window.addEventListener('scroll', fixNavBar)
return () => {
window.removeEventListener('scroll', fixNavBar)
}
}, [])
return (
<header className="header">
<div
ref={navbarAreaEl}
className={`navbar-area ${isNavbarSticky ? 'sticky' : ''}`}
>
<div className="container">
<div className="row align-items-center">
<div className="col-lg-12">
<nav className="navbar navbar-expand-lg">
<a className="navbar-brand" href="https://buttercms.com">
<Image
src="https://cdn.buttercms.com/PBral0NQGmmFzV0uG7Q6"
alt="Logo"
width={180}
height={45}
/>
</a>
<MainMenu mainMenuLinks={mainMenu} />
</nav>
</div>
</div>
</div>
</div>
</header>
)
}