File: /var/www/innodrive/src/js/modules/hamburger.js
import { disableBodyScroll, clearAllBodyScrollLocks } from 'body-scroll-lock';
class Hamburger {
constructor (container) {
this.hamburger = container;
this.hamburgerOpenToggle = this.hamburger.querySelector('.hamburger');
this.hamburgerCloseToggle = document.querySelector('.main-header__hamburger-close');
this.menuObj = document.querySelector('.main-header__hamburger-dropdown');
this.opened = false;
this.open = this.open.bind(this);
this.close = this.close.bind(this);
this.hamburgerOpenToggle.addEventListener('click', this.open);
this.hamburgerCloseToggle.addEventListener('click', this.close);
}
get opened () {
return this.isOpened;
}
set opened (status) {
this.isOpened = status;
}
open () {
this.hamburger.classList.add('js-opened');
this.opened = true;
disableBodyScroll(this.menuObj);
}
close () {
this.hamburger.classList.remove('js-opened');
this.opened = false;
clearAllBodyScrollLocks();
}
}
export default () => {
const hamburgerContainer = document.querySelector('.main-header__hamburger');
if (!hamburgerContainer) { return }
hamburgerContainer.hamburger = new Hamburger(hamburgerContainer);
};