75 lines
2.9 KiB
JavaScript
75 lines
2.9 KiB
JavaScript
|
/******/ (() => { // webpackBootstrap
|
||
|
/******/ "use strict";
|
||
|
var __webpack_exports__ = {};
|
||
|
|
||
|
|
||
|
class elementorHelloThemeHandler {
|
||
|
constructor() {
|
||
|
this.initSettings();
|
||
|
this.initElements();
|
||
|
this.bindEvents();
|
||
|
}
|
||
|
initSettings() {
|
||
|
this.settings = {
|
||
|
selectors: {
|
||
|
menuToggle: '.site-header .site-navigation-toggle',
|
||
|
menuToggleHolder: '.site-header .site-navigation-toggle-holder',
|
||
|
dropdownMenu: '.site-header .site-navigation-dropdown'
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
initElements() {
|
||
|
this.elements = {
|
||
|
window,
|
||
|
menuToggle: document.querySelector(this.settings.selectors.menuToggle),
|
||
|
menuToggleHolder: document.querySelector(this.settings.selectors.menuToggleHolder),
|
||
|
dropdownMenu: document.querySelector(this.settings.selectors.dropdownMenu)
|
||
|
};
|
||
|
}
|
||
|
bindEvents() {
|
||
|
var _this$elements$menuTo;
|
||
|
if (!this.elements.menuToggleHolder || (_this$elements$menuTo = this.elements.menuToggleHolder) !== null && _this$elements$menuTo !== void 0 && _this$elements$menuTo.classList.contains('hide')) {
|
||
|
return;
|
||
|
}
|
||
|
this.elements.menuToggle.addEventListener('click', () => this.handleMenuToggle());
|
||
|
this.elements.menuToggle.addEventListener('keyup', event => {
|
||
|
const ENTER_KEY = 13;
|
||
|
const SPACE_KEY = 32;
|
||
|
if (ENTER_KEY === event.keyCode || SPACE_KEY === event.keyCode) {
|
||
|
event.currentTarget.click();
|
||
|
}
|
||
|
});
|
||
|
this.elements.dropdownMenu.querySelectorAll('.menu-item-has-children > a').forEach(anchorElement => anchorElement.addEventListener('click', event => this.handleMenuChildren(event)));
|
||
|
}
|
||
|
closeMenuItems() {
|
||
|
this.elements.menuToggleHolder.classList.remove('elementor-active');
|
||
|
this.elements.window.removeEventListener('resize', () => this.closeMenuItems());
|
||
|
}
|
||
|
handleMenuToggle() {
|
||
|
const isDropdownVisible = !this.elements.menuToggleHolder.classList.contains('elementor-active');
|
||
|
this.elements.menuToggle.setAttribute('aria-expanded', isDropdownVisible);
|
||
|
this.elements.dropdownMenu.setAttribute('aria-hidden', !isDropdownVisible);
|
||
|
this.elements.menuToggleHolder.classList.toggle('elementor-active', isDropdownVisible);
|
||
|
|
||
|
// Always close all sub active items.
|
||
|
this.elements.dropdownMenu.querySelectorAll('.elementor-active').forEach(item => item.classList.remove('elementor-active'));
|
||
|
if (isDropdownVisible) {
|
||
|
this.elements.window.addEventListener('resize', () => this.closeMenuItems());
|
||
|
} else {
|
||
|
this.elements.window.removeEventListener('resize', () => this.closeMenuItems());
|
||
|
}
|
||
|
}
|
||
|
handleMenuChildren(event) {
|
||
|
const anchor = event.currentTarget;
|
||
|
const parentLi = anchor.parentElement;
|
||
|
if (!(parentLi !== null && parentLi !== void 0 && parentLi.classList)) {
|
||
|
return;
|
||
|
}
|
||
|
parentLi.classList.toggle('elementor-active');
|
||
|
}
|
||
|
}
|
||
|
document.addEventListener('DOMContentLoaded', () => {
|
||
|
new elementorHelloThemeHandler();
|
||
|
});
|
||
|
/******/ })()
|
||
|
;
|