File: //home/pvruk.co.uk/public_html-20250117120915/wp-content/themes/go/dist/js/frontend.js
/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ({
/***/ "./.dev/assets/shared/js/frontend/components/primary-menu.js":
/*!*******************************************************************!*\
!*** ./.dev/assets/shared/js/frontend/components/primary-menu.js ***!
\*******************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _vendor_responsive_nav__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../vendor/responsive-nav */ "./.dev/assets/shared/js/frontend/vendor/responsive-nav.js");
/* global TenUp */
/**
* Hook up navigation.
*/
const init = () => {
if (TenUp) {
TenUp.navigation({
target: '#header__navigation',
toggle: '#nav-toggle',
// eslint-disable-next-line
sub_menu_open: goFrontend.openMenuOnHover ? 'hover' : 'click'
});
}
document.addEventListener('keydown', lockMenuFocus);
};
/**
* Lock tabbing to the main navigation only.
*
* @param {event} e
*/
function lockMenuFocus(e) {
if (['Space', 'Enter', 'Tab'].includes[e.code] || !document.querySelector('body').classList.contains('menu-is-open')) {
return;
}
const element = document.querySelector(':focus');
const isShiftTab = e.shiftKey && e.code === 'Tab';
if (element.getAttribute('id') === 'nav-toggle') {
if (isShiftTab) {
return;
}
setTimeout(function () {
document.querySelectorAll('ul.primary-menu li:first-child a')[0].focus();
}, 10);
}
}
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (init);
/***/ }),
/***/ "./.dev/assets/shared/js/frontend/components/search-toggle.js":
/*!********************************************************************!*\
!*** ./.dev/assets/shared/js/frontend/components/search-toggle.js ***!
\********************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
const searchToggle = () => {
const searchToggleEl = document.getElementById('header__search-toggle');
if (!searchToggleEl) {
return;
}
const performToggle = element => {
const toggle = element;
const target = document.querySelector(toggle.dataset.toggleTarget);
if (target.classList.contains('show-modal')) {
// Hide the modal.
target.classList.remove('active');
setTimeout(() => {
target.classList.remove('show-modal');
toggle.focus();
}, 250);
} else {
// Show the modal.
target.classList.add('show-modal');
setTimeout(() => {
target.classList.add('active');
if (toggle.dataset.setFocus) {
const focusElement = document.querySelector(toggle.dataset.setFocus);
if (focusElement) {
const searchTerm = focusElement.value;
focusElement.value = '';
focusElement.focus();
focusElement.value = searchTerm;
}
}
}, 10);
}
};
document.querySelectorAll('*[data-toggle-target]').forEach(element => {
element.addEventListener('click', event => {
event.preventDefault();
performToggle(element);
});
}); // Close modal on escape key press.
document.addEventListener('keyup', event => {
if (event.keyCode === 27) {
event.preventDefault();
document.querySelectorAll('.search-modal.active').forEach(element => {
performToggle(document.querySelector('*[data-toggle-target="' + element.dataset.modalTargetString + '"]'));
});
}
}); // Close modal on outside click.
document.addEventListener('click', event => {
const target = event.target;
const modal = document.querySelector('.search-modal.active');
if (target === modal) {
performToggle(document.querySelector('*[data-toggle-target="' + modal.dataset.modalTargetString + '"]'));
}
});
document.addEventListener('keydown', lockSearchFocus);
};
/**
* Lock tabbing to the search form only.
*
* @param {event} e
*/
function lockSearchFocus(e) {
// If the keypress isn't a tab or the search form isn't active, return
if (e.keyCode !== 9 || !document.querySelector('.site-search.active')) {
return;
} // Current active element before it moves
const activeElement = document.activeElement; // If we're on the input and shift+tab was pressed, override and focus on button.
if (document.activeElement.classList.contains('search-form__input') && e.shiftKey) {
setTimeout(function () {
// Focus the correct button by only looking for it in the parent element
activeElement.parentElement.getElementsByClassName('search-input__button').item(0).focus();
}, 10);
} // If we're on the button and tab was pressed, override and focus on input.
if (document.activeElement.classList.contains('search-input__button') && !e.shiftKey) {
setTimeout(function () {
// Focus the correct input by only looking for it in the parent element
activeElement.parentElement.getElementsByClassName('search-form__input').item(0).focus();
}, 10);
}
}
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (searchToggle);
/***/ }),
/***/ "./.dev/assets/shared/js/frontend/components/woo-menu-cart.js":
/*!********************************************************************!*\
!*** ./.dev/assets/shared/js/frontend/components/woo-menu-cart.js ***!
\********************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
const menuObject = document.getElementById('header__cart-toggle');
const siteOverlay = document.getElementById('site-overlay');
const sideNav = document.getElementById('site-nav--cart');
const sideNavClose = document.getElementById('site-close-handle');
const wooMenuCart = () => {
if (null === menuObject || null === siteOverlay || null === sideNavClose) {
return;
}
document.body.classList.add('has-woo-cart-slideout');
menuObject.addEventListener('click', function (event) {
event.preventDefault();
toggleSideNavVisibility();
});
siteOverlay.addEventListener('click', toggleSideNavVisibility);
sideNavClose.addEventListener('click', toggleSideNavVisibility);
};
const toggleSideNavVisibility = () => {
sideNav.classList.toggle('active');
siteOverlay.classList.toggle('active');
document.body.classList.toggle('sidebar-move');
};
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (wooMenuCart);
/***/ }),
/***/ "./.dev/assets/shared/js/frontend/utility/debounce.js":
/*!************************************************************!*\
!*** ./.dev/assets/shared/js/frontend/utility/debounce.js ***!
\************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/**
*
* @param {Function} func Funtion to run against.
* @param {number} wait Amount to wait
* @param {boolean} immediate Trigger on leading edge?
*/
const debounce = (func, wait, immediate) => {
let timeout;
return function () {
const args = arguments;
const context = this;
/**
* Later
*/
const later = () => {
timeout = null;
if (!immediate) {
func.apply(context, args);
}
};
const callNow = immediate && !timeout;
clearTimeout(timeout);
timeout = setTimeout(later, wait);
if (callNow) {
func.apply(context, args);
}
};
};
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (debounce);
/***/ }),
/***/ "./.dev/assets/shared/js/frontend/vendor/responsive-nav.js":
/*!*****************************************************************!*\
!*** ./.dev/assets/shared/js/frontend/vendor/responsive-nav.js ***!
\*****************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _utility_debounce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utility/debounce */ "./.dev/assets/shared/js/frontend/utility/debounce.js");
/********************************
Name: WordPress Accessible Responsive Navigation Menu
Usage:
TenUp.build_menu({
'target' : '#primary-nav', // the selector of the nav menu <ul>
'toggle' : '#js-menu-toggle', // the ID of the link you're using to open/close the small screen menu
'sub_menu_open' : 'hover'
}, function() {
console.log('Amazing callback function!');
});
********************************/
/* eslint-disable */
(function () {
'use strict'; // Define global TenUp object if it doesn't exist
if ('object' !== typeof window.TenUp) {
window.TenUp = {};
}
/*
Cache and define some variables
*/
// init function
TenUp.navigation = function (options, callback) {
var defaults = {
'target': '#primary-nav',
'toggle': '#js-menu-toggle',
'sub_menu_open': 'hover'
};
var opt; // Map all default settings to user defined options if they exist
for (opt = 0; opt < defaults.length; opt = opt + 1) {
if (typeof options[opt] === 'undefined') {
options[opt] = defaults[opt];
}
}
var menu = document.querySelector(options.target); // Bail out if there's no menu
if (!menu) {
return;
}
var menu_id = menu.getAttribute('id');
var menu_toggle = document.querySelector(options.toggle);
var aria_controls = menu_toggle.getAttribute('aria-controls');
var sub_menu_acion = options.sub_menu_open;
var current_menu_item = menu.querySelector('.current-menu-item');
var menu_items_links = menu.querySelectorAll('.menu-item > a');
var menu_items_links_count = menu_items_links.length;
var menu_items_with_children = menu.querySelectorAll('.menu-item-has-children');
var menu_items_with_children_count = menu_items_with_children.length;
var currentTarget;
var target;
var i; // Listener for the menu open/close action
function listener_menu(e) {
// Stop links from firing
e.preventDefault();
if (document.body.classList.contains('menu-is-open')) {
// Close the menu
menu.setAttribute('aria-hidden', 'true');
menu_toggle.setAttribute('aria-expanded', 'false'); // Bubble to the document
document.body.classList.remove('menu-is-open');
} else {
// Open the menu
menu.setAttribute('aria-hidden', 'false');
menu_toggle.setAttribute('aria-expanded', 'true'); // Set focus to the first link
menu.querySelectorAll('a')[0].focus(); // Bubble to the document
document.body.classList.add('menu-is-open');
}
}
; // listener_menu()
// Listener for submenu on click
function listener_submenu_click(e) {
currentTarget = e.currentTarget;
target = e.target;
if (target.tagName === 'svg' || target.tagName === 'path') {
target = currentTarget.closest('.menu-item > a');
} else {
console.log(target.previousSibling.previousSibling.href);
if (goFrontend.isMobile) {
if (target.tagName === 'A') {
return;
}
if (target.tagName === 'UL') {
let tempURL = target.previousSibling.previousSibling.href;
if (null !== tempURL) {
window.location.href = tempURL;
return;
}
}
}
}
if (target.getAttribute('aria-haspopup')) {
// Stop links from firing
e.preventDefault(); // Stop events from bubbling up to parent elements
e.stopPropagation();
var parent_menu = target.parentNode;
var sub_menu = parent_menu.querySelector('.sub-menu');
var all_open_menus = menu.querySelectorAll('.child-has-focus');
var all_open_menus_count = all_open_menus.length;
var all_open_menu_triggers = menu.querySelectorAll('.child-has-focus > a.submenu-is-open');
var all_open_menu_triggers_count = all_open_menu_triggers.length;
var t;
if (get_screen_size('has-full-nav')) {
if (all_open_menu_triggers_count > 0) {
// Make sure only 1 menu item can be opened at a time
for (t = 0; t < all_open_menu_triggers_count; t = t + 1) {
// Check if the open menu is top-level, if so, close it
if (parent_menu.parentNode === menu) {
menu_sub_close(all_open_menu_triggers[t]);
}
} // for
} // if
} // if
if ((e.target.nodeName === 'A' || target.tagName === 'A') && target.classList.contains('submenu-is-open')) {
// The menu is already open, so this should be a close action
menu_sub_close(target);
} else {
menu_sub_close_all(); // The menu is closed, so this click should open it
menu_sub_open(target); // Reset the focus
sub_menu.querySelectorAll('a')[0].focus();
}
}
}
; // listener_submenu_click()
// Listener for same page link (hash) click
function listener_hash_click() {
// Close the menu
menu.setAttribute('aria-hidden', 'true');
menu_toggle.setAttribute('aria-expanded', 'false'); // Bubble to the document
document.body.classList.remove('menu-is-open');
}
; // When "hover", this is how focus should act
function listener_submenu_focus(e) {
var currentTarget = e.currentTarget;
var target = e.target;
var parent_menu = target.parentNode;
var sub_menu = parent_menu.querySelector('.sub-menu');
var all_open_menu_triggers = menu.querySelectorAll('.child-has-focus > a.submenu-is-open');
var all_open_menu_triggers_count = all_open_menu_triggers.length;
var t;
if (get_screen_size('has-full-nav')) {
if (all_open_menu_triggers_count > 0) {
// Make sure only 1 menu item can be opened at a time
for (t = 0; t < all_open_menu_triggers_count; t = t + 1) {
// Check if the open menu is top-level, if so, close it
if (parent_menu.parentNode === menu) {
menu_sub_close(all_open_menu_triggers[t]);
}
}
}
}
menu_sub_open(target);
}
; // Listener for the window resize
var listener_window = (0,_utility_debounce__WEBPACK_IMPORTED_MODULE_0__["default"])(function (e) {
if (get_screen_size('has-offscreen-nav')) {
menu_create();
} else {
menu_destroy();
}
}, 100); // listener_window()
// Close the menu if you click somewhere else
function listener_close_open_menus(e) {
var open_menus = menu.querySelectorAll('.submenu-is-open');
var open_menus_count = open_menus.length;
var opn; // if the event is keyup and it was the ESC key
if (e.type === 'keyup' && e.keyCode == 27) {
// We were getting some errors, so let's add in a checkpoint
if (open_menus_count) {
// Loop through all the open menus and close them
for (opn = 0; opn < open_menus.length; opn = opn + 1) {
menu_sub_close(open_menus[opn]);
} // for
// Return focus to the first open menu
if (sub_menu_acion === 'click') {
open_menus[0].focus();
}
} // if
// If the event was a mouseup
} else if (e.type === 'mouseup') {
if (!menu.contains(e.target) && menu.querySelector('.submenu-is-open')) {
// We were getting some error, so let's add in a second checkpoint
if (open_menus_count) {
for (opn = 0; opn < open_menus.length; opn = opn + 1) {
menu_sub_close(open_menus[opn]);
} // for
}
} // if
}
}
; // listener_close_open_menus()
function menu_sub_close(open_item) {
if (open_item && open_item.classList) {
open_item.classList.remove('submenu-is-open');
open_item.parentNode.classList.remove('child-has-focus');
}
if (open_item && open_item.parentNode && open_item.parentNode.querySelector('.sub-menu')) {
open_item.parentNode.querySelector('.sub-menu').setAttribute('aria-hidden', 'true');
}
}
; // menu_sub_close()
function menu_sub_close_all() {
var open_menus = menu.querySelectorAll('.submenu-is-open');
var open_menus_count = open_menus.length;
var opn; // We were getting some errors, so let's add in a checkpoint
if (open_menus_count) {
// Loop through all the open menus and close them
for (opn = 0; opn < open_menus.length; opn = opn + 1) {
menu_sub_close(open_menus[opn]);
} // for
} // if
}
; // menu_sub_close()
function menu_sub_open(closed_item) {
closed_item.classList.add('submenu-is-open');
closed_item.parentNode.classList.add('child-has-focus');
if (closed_item.parentNode.querySelector('.sub-menu')) {
closed_item.parentNode.querySelector('.sub-menu').setAttribute('aria-hidden', 'false');
}
}
; // menu_sub_open()
// Method to create the small screen menu
function menu_create() {
if (!document.body.classList.contains('has-offscreen-nav')) {
if (!document.body.classList.contains('menu-is-open')) {
menu.setAttribute('aria-hidden', 'true');
menu_toggle.setAttribute('aria-expanded', 'false');
} else {
menu.setAttribute('aria-hidden', 'false');
menu_toggle.setAttribute('aria-expanded', 'true');
} // Loop through all submenus and bind events when needed
for (i = 0; i < menu_items_with_children_count; i++) {
var svgElements = menu_items_with_children[i].querySelectorAll('svg');
for (var q = 0; q < svgElements.length; q = q + 1) {
svgElements[q].addEventListener('click', listener_submenu_click);
}
menu_items_with_children[i].removeEventListener('focusin', listener_submenu_focus);
} // for
// Loop through all links for hash and bind events when needed
for (i = 0; i < menu_items_links_count; i++) {
if (menu_items_links[i].hash && menu_items_links[i].pathname === '/') {
menu_items_links[i].addEventListener('click', listener_hash_click);
}
} // for
// Bind the event
menu_toggle.addEventListener('click', listener_menu); // Add the body class to prevent this from running again
document.body.classList.add('has-offscreen-nav');
document.body.classList.remove('has-full-nav');
}
}
; // menu_create()
// Method to destroy the small screen menu
function menu_destroy() {
var tmp_open;
var tmp_open_count;
var t;
if (!document.body.classList.contains('has-full-nav')) {
// Remove aria-hidden, because we don't need it.
menu.removeAttribute('aria-hidden'); // Loop through all submenus and bind events when needed
for (i = 0; i < menu_items_with_children_count; i = i + 1) {
if (sub_menu_acion !== 'click') {
menu_items_with_children[i].removeEventListener('click', listener_submenu_click);
menu_items_with_children[i].addEventListener('focusin', listener_submenu_focus);
menu.classList.remove('uses-click');
}
} // If we're not using click, the open menus need to be reset
if (sub_menu_acion !== 'click') {
tmp_open = document.querySelectorAll('.child-has-focus');
tmp_open_count = tmp_open.length;
for (t = 0; t < tmp_open_count; t = t + 1) {
tmp_open[t].classList.remove('child-has-focus');
tmp_open[t].querySelector('.submenu-is-open').classList.remove('submenu-is-open');
tmp_open[t].querySelector('.sub-menu').setAttribute('aria-hidden', 'true');
}
} // Unbind the event
menu_toggle.removeEventListener('click', listener_menu); // Add the body class to prevent this from running again
document.body.classList.add('has-full-nav');
document.body.classList.remove('has-offscreen-nav');
}
}
; // Check init menu state
if (get_screen_size('has-offscreen-nav')) {
menu_create();
} // If aria-controls isn't set, set it
if (!aria_controls) {
menu_toggle.setAttribute('aria-controls', menu_id);
}
if (current_menu_item) {
current_menu_item.querySelector('a').setAttribute('aria-current', 'page');
}
/*
Events
*/
// Debounced resize event to create and destroy the small screen menu options
window.addEventListener('resize', listener_window); // Close the submenus by clicking off of them or hitting ESC
document.addEventListener('mouseup', listener_close_open_menus);
document.addEventListener('keyup', listener_close_open_menus);
/*
Hiding and showing submenus (click, focus, hover)
*/
// Loop through all items with sub menus and bind focus to them for tabbing
for (i = 0; i < menu_items_with_children_count; i = i + 1) {
// Let a screen reader know this menu has a submenu by hooking into the first link
menu_items_with_children[i].querySelector('a').setAttribute('aria-haspopup', 'true'); // Hide and label each sub menu
menu_items_with_children[i].querySelector('.sub-menu').setAttribute('aria-hidden', 'true');
menu_items_with_children[i].querySelector('.sub-menu').setAttribute('aria-label', 'Submenu'); // If the screen is small or the action is set to click
if (get_screen_size('has-offscreen-nav') || sub_menu_acion === 'click') {
menu_items_with_children[i].addEventListener('click', listener_submenu_click);
var svgElements = menu_items_with_children[i].querySelectorAll('svg');
for (var z = 0; z < svgElements.length; z = z + 1) {
svgElements[z].addEventListener('click', listener_submenu_click);
svgElements[z].addEventListener('keypress', e => {
['Space', 'Enter'].includes(e.code) && listener_submenu_click(e);
});
svgElements[z].setAttribute('tabindex', '0');
}
menu.classList.add(sub_menu_acion === 'click' ? 'uses-click' : 'uses-hover');
} else if (sub_menu_acion !== 'click') {
if (get_screen_size('has-full-nav')) {
menu_items_with_children[i].addEventListener('mouseover', listener_submenu_focus);
menu_items_with_children[i].addEventListener('mouseout', function () {
var open_menus = menu.querySelectorAll('.submenu-is-open');
var open_menus_count = open_menus.length;
var opn; // We were getting some errors, so let's add in a checkpoint
if (open_menus_count) {
// Loop through all the open menus and close them
for (opn = 0; opn < open_menus_count; opn = opn + 1) {
menu_sub_close(open_menus[opn]);
} // for
}
});
menu_items_with_children[i].addEventListener('focusin', listener_submenu_focus);
menu_items_with_children[i].querySelectorAll('.sub-menu').forEach(submenu => {
submenu.addEventListener('mouseover', event => {
submenu.parentElement.classList.add('child-has-focus');
submenu.previousElementSibling.classList.add('submenu-is-open');
}, false);
});
} // if
} // if
} // for
// Execute the callback function
if (typeof callback === 'function') {
callback.call();
}
}; // build_menu()
/*
Helper functions
*/
// Get screen size from getComputedStyle (so we don't have to define each breakpoint twice) -- Values are set in CSS --
function get_screen_size(sizeString) {
var size = window.getComputedStyle(document.body, ':before').getPropertyValue('content');
if (size && size.indexOf(sizeString) !== -1) {
return true;
}
}
;
})();
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
(() => {
/*!****************************************************!*\
!*** ./.dev/assets/shared/js/frontend/frontend.js ***!
\****************************************************/
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _utility_debounce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utility/debounce */ "./.dev/assets/shared/js/frontend/utility/debounce.js");
/* harmony import */ var _components_primary_menu_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/primary-menu.js */ "./.dev/assets/shared/js/frontend/components/primary-menu.js");
/* harmony import */ var _components_search_toggle_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/search-toggle.js */ "./.dev/assets/shared/js/frontend/components/search-toggle.js");
/* harmony import */ var _components_woo_menu_cart_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./components/woo-menu-cart.js */ "./.dev/assets/shared/js/frontend/components/woo-menu-cart.js");
(0,_components_primary_menu_js__WEBPACK_IMPORTED_MODULE_1__["default"])();
(0,_components_search_toggle_js__WEBPACK_IMPORTED_MODULE_2__["default"])();
(0,_components_woo_menu_cart_js__WEBPACK_IMPORTED_MODULE_3__["default"])();
document.addEventListener('DOMContentLoaded', function () {
const hasSelectiveRefresh = 'undefined' !== typeof wp && wp.customize && wp.customize.selectiveRefresh && wp.customize.navMenusPreview.NavMenuInstancePartial; // partial-content-rendered might render multiple times for some reason, let's make sure to debouce this.
const init = (0,_utility_debounce__WEBPACK_IMPORTED_MODULE_0__["default"])(() => {
// we need to remove this before calling primary menu again.
document.body.classList.remove('has-offscreen-nav');
(0,_components_primary_menu_js__WEBPACK_IMPORTED_MODULE_1__["default"])();
(0,_components_search_toggle_js__WEBPACK_IMPORTED_MODULE_2__["default"])();
}, 1000);
if (hasSelectiveRefresh) {
wp.customize.selectiveRefresh.bind('partial-content-rendered', function (placement) {
const changedHeaderVariation = placement && 'null' !== placement.container[0].parentNode && 'header_variation' === placement.partial.id;
if (changedHeaderVariation) {
init();
}
});
}
});
})();
/******/ })()
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"js/frontend.js","mappings":";;;;;;;;;;;;;;;AAAA;AACA;AAEA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;;;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;AC1CA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAGA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;;AAGA;AACA;AACA;;AAEA;AACA;AAGA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;;;AACA;AACA;AACA;AACA;AACA;;;AAGA;;AAGA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;ACzGA;AACA;AACA;AACA;;AAEA;AACA;AAKA;AACA;;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA;AACA;;AAEA;AAEA;AACA;;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;ACjCA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;;AACA;AAEA;;AAGA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;AACA;AAEA;AACA;AACA;AACA;AAHA;AAKA;;AAGA;AAEA;AACA;AACA;AAEA;;AAEA;;AAGA;AAAA;AAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAGA;AACA;AACA;AACA;AACA;;AAGA;;AAGA;AACA;AAEA;;AAAA;AAEA;;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AACA;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAGA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AACA;;AACA;;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAGA;AACA;AACA;AACA;;AAAA;AAEA;;AACA;AAEA;AACA;AACA;;AAGA;AACA;;AAAA;;AAGA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;;AAAA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA;AAEA;AACA;AACA;;AAGA;AAEA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;;;AACA;AACA;AACA;AAEA;AAEA;;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;;AACA;AACA;;AAAA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAAA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AACA;;AACA;;AAAA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAAA;AAEA;;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AACA;AACA;AACA;;AACA;AACA;AAEA;;;AACA;AACA;AACA;AACA;AACA;AAEA;;;AACA;;AAGA;AACA;AACA;AACA;;AAAA;AAEA;;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;;AAGA;;AAGA;AACA;AACA;AACA;;AAAA;;AAGA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;AACA;;AAGA;AACA;AAEA;AACA;AACA;AAEA;;AACA;AAEA;AACA;;AAGA;AACA;;AAGA;AACA;AAEA;;AAEA;AAEA;AACA;AAAA;AAAA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAGA;AAEA;AACA;AAEA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA;;AACA;AAEA;;;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AAEA;;;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAAA;AAEA;;;;;;ACldA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACPA;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;ACNA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;;AAQA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAMA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://go/./.dev/assets/shared/js/frontend/components/primary-menu.js","webpack://go/./.dev/assets/shared/js/frontend/components/search-toggle.js","webpack://go/./.dev/assets/shared/js/frontend/components/woo-menu-cart.js","webpack://go/./.dev/assets/shared/js/frontend/utility/debounce.js","webpack://go/./.dev/assets/shared/js/frontend/vendor/responsive-nav.js","webpack://go/webpack/bootstrap","webpack://go/webpack/runtime/define property getters","webpack://go/webpack/runtime/hasOwnProperty shorthand","webpack://go/webpack/runtime/make namespace object","webpack://go/./.dev/assets/shared/js/frontend/frontend.js"],"sourcesContent":["/* global TenUp */\nimport '../vendor/responsive-nav';\n\n/**\n * Hook up navigation.\n */\nconst init = () => {\n\tif ( TenUp ) {\n\t\tTenUp.navigation( {\n\t\t\ttarget: '#header__navigation',\n\t\t\ttoggle: '#nav-toggle',\n\t\t\t// eslint-disable-next-line\n\t\t\tsub_menu_open: goFrontend.openMenuOnHover ? 'hover' : 'click'\n\t\t} );\n\t}\n\n\tdocument.addEventListener( 'keydown', lockMenuFocus );\n};\n\n/**\n * Lock tabbing to the main navigation only.\n *\n * @param {event} e\n */\nfunction lockMenuFocus( e ) {\n\tif ( [ 'Space', 'Enter', 'Tab' ].includes[ e.code ] || ! document.querySelector( 'body' ).classList.contains( 'menu-is-open' ) ) {\n\t\treturn;\n\t}\n\n\tconst element = document.querySelector( ':focus' );\n\tconst isShiftTab = ( e.shiftKey && e.code === 'Tab' );\n\n\tif ( element.getAttribute( 'id' ) === 'nav-toggle' ) {\n\t\tif ( isShiftTab ) {\n\t\t\treturn;\n\t\t}\n\t\tsetTimeout( function() {\n\t\t\tdocument.querySelectorAll( 'ul.primary-menu li:first-child a' )[ 0 ].focus();\n\t\t}, 10 );\n\t}\n}\n\nexport default init;\n","const searchToggle = () => {\n\tconst searchToggleEl = document.getElementById( 'header__search-toggle' );\n\n\tif ( ! searchToggleEl ) {\n\t\treturn;\n\t}\n\n\tconst performToggle = ( element ) => {\n\t\tconst toggle = element;\n\t\tconst target = document.querySelector( toggle.dataset.toggleTarget );\n\n\t\tif ( target.classList.contains( 'show-modal' ) ) {\n\t\t\t// Hide the modal.\n\t\t\ttarget.classList.remove( 'active' );\n\n\t\t\tsetTimeout( () => {\n\t\t\t\ttarget.classList.remove( 'show-modal' );\n\t\t\t\ttoggle.focus();\n\t\t\t}, 250 );\n\t\t} else {\n\t\t\t// Show the modal.\n\t\t\ttarget.classList.add( 'show-modal' );\n\n\t\t\tsetTimeout( () => {\n\t\t\t\ttarget.classList.add( 'active' );\n\n\t\t\t\tif ( toggle.dataset.setFocus ) {\n\t\t\t\t\tconst focusElement = document.querySelector( toggle.dataset.setFocus );\n\n\t\t\t\t\tif ( focusElement ) {\n\t\t\t\t\t\tconst searchTerm = focusElement.value;\n\t\t\t\t\t\tfocusElement.value = '';\n\t\t\t\t\t\tfocusElement.focus();\n\t\t\t\t\t\tfocusElement.value = searchTerm;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}, 10 );\n\t\t}\n\t};\n\n\tdocument.querySelectorAll( '*[data-toggle-target]' ).forEach( ( element ) => {\n\t\telement.addEventListener( 'click', ( event ) => {\n\t\t\tevent.preventDefault();\n\t\t\tperformToggle( element );\n\t\t} );\n\t} );\n\n\t// Close modal on escape key press.\n\tdocument.addEventListener( 'keyup', ( event ) => {\n\t\tif ( event.keyCode === 27 ) {\n\t\t\tevent.preventDefault();\n\t\t\tdocument.querySelectorAll( '.search-modal.active' ).forEach( ( element ) => {\n\t\t\t\tperformToggle(\n\t\t\t\t\tdocument.querySelector( '*[data-toggle-target=\"' + element.dataset.modalTargetString + '\"]' )\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\t} );\n\n\t// Close modal on outside click.\n\tdocument.addEventListener( 'click', ( event ) => {\n\t\tconst target = event.target;\n\t\tconst modal = document.querySelector( '.search-modal.active' );\n\n\t\tif ( target === modal ) {\n\t\t\tperformToggle(\n\t\t\t\tdocument.querySelector( '*[data-toggle-target=\"' + modal.dataset.modalTargetString + '\"]' )\n\t\t\t);\n\t\t}\n\t} );\n\n\tdocument.addEventListener( 'keydown', lockSearchFocus );\n};\n\n/**\n * Lock tabbing to the search form only.\n *\n * @param {event} e\n */\nfunction lockSearchFocus( e ) {\n\t// If the keypress isn't a tab or the search form isn't active, return\n\tif ( e.keyCode !== 9 || ! document.querySelector( '.site-search.active' ) ) {\n\t\treturn;\n\t}\n\n\t// Current active element before it moves\n\tconst activeElement = document.activeElement;\n\n\t// If we're on the input and shift+tab was pressed, override and focus on button.\n\tif ( document.activeElement.classList.contains( 'search-form__input' ) && e.shiftKey ) {\n\t\tsetTimeout( function() {\n\t\t\t// Focus the correct button by only looking for it in the parent element\n\t\t\tactiveElement.parentElement.getElementsByClassName( 'search-input__button' ).item( 0 ).focus();\n\t\t}, 10 );\n\t}\n\n\t// If we're on the button and tab was pressed, override and focus on input.\n\tif ( document.activeElement.classList.contains( 'search-input__button' ) && ! e.shiftKey ) {\n\t\tsetTimeout( function() {\n\t\t\t// Focus the correct input by only looking for it in the parent element\n\t\t\tactiveElement.parentElement.getElementsByClassName( 'search-form__input' ).item( 0 ).focus();\n\t\t}, 10 );\n\t}\n}\n\nexport default searchToggle;\n","const menuObject = document.getElementById( 'header__cart-toggle' );\nconst siteOverlay = document.getElementById( 'site-overlay' );\nconst sideNav = document.getElementById( 'site-nav--cart' );\nconst sideNavClose = document.getElementById( 'site-close-handle' );\n\nconst wooMenuCart = () => {\n\tif (\n\t\tnull === menuObject ||\n\t\tnull === siteOverlay ||\n\t\tnull === sideNavClose\n\t) {\n\t\treturn;\n\t}\n\n\tdocument.body.classList.add( 'has-woo-cart-slideout' );\n\n\tmenuObject.addEventListener( 'click', function( event ) {\n\t\tevent.preventDefault();\n\t\ttoggleSideNavVisibility();\n\t} );\n\n\tsiteOverlay.addEventListener( 'click', toggleSideNavVisibility );\n\tsideNavClose.addEventListener( 'click', toggleSideNavVisibility );\n};\n\nconst toggleSideNavVisibility = () => {\n\tsideNav.classList.toggle( 'active' );\n\tsiteOverlay.classList.toggle( 'active' );\n\tdocument.body.classList.toggle( 'sidebar-move' );\n};\n\nexport default wooMenuCart;\n","/**\n *\n * @param {Function} func      Funtion to run against.\n * @param {number}   wait      Amount to wait\n * @param {boolean}  immediate Trigger on leading edge?\n */\nconst debounce = ( func, wait, immediate ) => {\n\tlet timeout;\n\n\treturn function() {\n\t\tconst args = arguments;\n\t\tconst context = this;\n\n\t\t/**\n\t\t * Later\n\t\t */\n\t\tconst later = () => {\n\t\t\ttimeout = null;\n\t\t\tif ( ! immediate ) {\n\t\t\t\tfunc.apply( context, args );\n\t\t\t}\n\t\t};\n\n\t\tconst callNow = immediate && ! timeout;\n\n\t\tclearTimeout( timeout );\n\t\ttimeout = setTimeout( later, wait );\n\t\tif ( callNow ) {\n\t\t\tfunc.apply( context, args );\n\t\t}\n\t};\n};\n\nexport default debounce;\n","import debounce from \"../utility/debounce\";\n\n/********************************\n\n\tName: WordPress Accessible Responsive Navigation Menu\n\tUsage:\n\n\tTenUp.build_menu({\n\n\t\t'target'\t\t:\t'#primary-nav',      // the selector of the nav menu <ul>\n\t\t'toggle'\t\t:\t'#js-menu-toggle',   // the ID of the link you're using to open/close the small screen menu\n\t\t'sub_menu_open'\t:\t'hover'\n\n\t}, function() {\n\n\t\tconsole.log('Amazing callback function!');\n\n\t});\n\n********************************/\n/* eslint-disable */\n( function() {\n\n\t'use strict';\n\n\t// Define global TenUp object if it doesn't exist\n\tif ( 'object' !== typeof window.TenUp ) {\n\t\twindow.TenUp = {};\n\t}\n\n\t/*\n\t\tCache and define some variables\n\t*/\n\n\t// init function\n\tTenUp.navigation = function( options, callback ) {\n\n\t\tvar defaults = {\n\t\t\t'target'\t\t:\t'#primary-nav',\n\t\t\t'toggle'\t\t:\t'#js-menu-toggle',\n\t\t\t'sub_menu_open'\t:\t'hover'\n\t\t};\n\t\tvar opt;\n\n\t\t// Map all default settings to user defined options if they exist\n\t\tfor ( opt = 0; opt < defaults.length; opt = opt + 1 ) {\n\n\t\t\tif( typeof options[opt] === 'undefined' ) {\n\t\t\t\toptions[opt] = defaults[opt];\n\t\t\t}\n\n\t\t}\n\n\t\tvar menu = document.querySelector( options.target );\n\n\t\t// Bail out if there's no menu\n\t\tif ( ! menu ) { return; }\n\n\t\tvar menu_id = menu.getAttribute( 'id' );\n\t\tvar menu_toggle = document.querySelector( options.toggle );\n\t\tvar aria_controls = menu_toggle.getAttribute( 'aria-controls' );\n\t\tvar sub_menu_acion = options.sub_menu_open;\n\t\tvar current_menu_item = menu.querySelector( '.current-menu-item' );\n\t\tvar menu_items_links = menu.querySelectorAll( '.menu-item > a' );\n\t\tvar menu_items_links_count = menu_items_links.length;\n\t\tvar menu_items_with_children = menu.querySelectorAll( '.menu-item-has-children' );\n\t\tvar menu_items_with_children_count = menu_items_with_children.length;\n\t\tvar currentTarget;\n\t\tvar target;\n\t\tvar i;\n\n\t\t// Listener for the menu open/close action\n\t\tfunction listener_menu( e ) {\n\n\t\t\t// Stop links from firing\n\t\t\te.preventDefault();\n\n\t\t\tif ( document.body.classList.contains( 'menu-is-open' ) ) {\n\t\t\t\t// Close the menu\n\t\t\t\tmenu.setAttribute( 'aria-hidden', 'true' );\n\t\t\t\tmenu_toggle.setAttribute( 'aria-expanded', 'false' );\n\n\t\t\t\t// Bubble to the document\n\t\t\t\tdocument.body.classList.remove( 'menu-is-open' );\n\t\t\t} else {\n\t\t\t\t// Open the menu\n\t\t\t\tmenu.setAttribute( 'aria-hidden', 'false' );\n\t\t\t\tmenu_toggle.setAttribute( 'aria-expanded', 'true' );\n\n\t\t\t\t// Set focus to the first link\n\t\t\t\tmenu.querySelectorAll( 'a' )[0].focus();\n\n\t\t\t\t// Bubble to the document\n\t\t\t\tdocument.body.classList.add( 'menu-is-open' );\n\t\t\t}\n\n\t\t}; // listener_menu()\n\n\t\t// Listener for submenu on click\n\t\tfunction listener_submenu_click( e ) {\n\n\t\t\tcurrentTarget = e.currentTarget;\n\t\t\ttarget = e.target;\n\n\t\t\tif ( target.tagName === 'svg' || target.tagName === 'path' ) {\n\t\t\t\ttarget = currentTarget.closest( '.menu-item > a' );\n\t\t\t} else {\n\t\t\t\tconsole.log( target.previousSibling.previousSibling.href );\n\t\t\t\tif ( goFrontend.isMobile ) {\n\t\t\t\t\tif ( target.tagName === 'A' ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\tif ( target.tagName === 'UL' ) {\n\t\t\t\t\t\tlet tempURL = target.previousSibling.previousSibling.href;\n\t\t\t\t\t\tif ( null !== tempURL ) {\n\t\t\t\t\t\t\twindow.location.href = tempURL;\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( target.getAttribute( 'aria-haspopup' ) ) {\n\t\t\t\t// Stop links from firing\n\t\t\t\te.preventDefault();\n\n\t\t\t\t// Stop events from bubbling up to parent elements\n\t\t\t\te.stopPropagation();\n\n\t\t\t\tvar parent_menu = target.parentNode;\n\t\t\t\tvar sub_menu = parent_menu.querySelector( '.sub-menu' );\n\t\t\t\tvar all_open_menus = menu.querySelectorAll( '.child-has-focus' );\n\t\t\t\tvar all_open_menus_count = all_open_menus.length;\n\t\t\t\tvar all_open_menu_triggers = menu.querySelectorAll( '.child-has-focus > a.submenu-is-open' );\n\t\t\t\tvar all_open_menu_triggers_count = all_open_menu_triggers.length;\n\t\t\t\tvar t;\n\n\t\t\t\tif ( get_screen_size( 'has-full-nav' ) ) {\n\t\t\t\t\tif ( all_open_menu_triggers_count > 0 ) {\n\t\t\t\t\t\t// Make sure only 1 menu item can be opened at a time\n\t\t\t\t\t\tfor ( t = 0; t < all_open_menu_triggers_count; t = t + 1 ) {\n\n\t\t\t\t\t\t\t// Check if the open menu is top-level, if so, close it\n\t\t\t\t\t\t\tif ( parent_menu.parentNode === menu ) {\n\t\t\t\t\t\t\t\tmenu_sub_close( all_open_menu_triggers[t] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} // for\n\t\t\t\t\t} // if\n\t\t\t\t} // if\n\n\t\t\t\tif ( ( e.target.nodeName === 'A' || target.tagName === 'A' ) && target.classList.contains( 'submenu-is-open' ) ) {\n\t\t\t\t\t// The menu is already open, so this should be a close action\n\t\t\t\t\tmenu_sub_close( target );\n\t\t\t\t} else {\n\t\t\t\t\tmenu_sub_close_all();\n\t\t\t\t\t// The menu is closed, so this click should open it\n\t\t\t\t\tmenu_sub_open( target );\n\n\t\t\t\t\t// Reset the focus\n\t\t\t\t\tsub_menu.querySelectorAll('a')[0].focus();\n\t\t\t\t}\n\t\t\t}\n\t\t}; // listener_submenu_click()\n\n\t\t// Listener for same page link (hash) click\n\t\tfunction listener_hash_click() {\n\n\t\t\t// Close the menu\n\t\t\tmenu.setAttribute( 'aria-hidden', 'true' );\n\t\t\tmenu_toggle.setAttribute( 'aria-expanded', 'false' );\n\n\t\t\t// Bubble to the document\n\t\t\tdocument.body.classList.remove( 'menu-is-open' );\n\t\t};\n\n\t\t// When \"hover\", this is how focus should act\n\t\tfunction listener_submenu_focus( e ) {\n\n\t\t\tvar currentTarget = e.currentTarget;\n\t\t\tvar target = e.target;\n\t\t\tvar parent_menu = target.parentNode;\n\t\t\tvar sub_menu = parent_menu.querySelector( '.sub-menu' );\n\t\t\tvar all_open_menu_triggers = menu.querySelectorAll( '.child-has-focus > a.submenu-is-open' );\n\t\t\tvar all_open_menu_triggers_count = all_open_menu_triggers.length;\n\t\t\tvar t;\n\n\t\t\tif ( get_screen_size( 'has-full-nav' ) ) {\n\t\t\t\tif ( all_open_menu_triggers_count > 0 ) {\n\t\t\t\t\t// Make sure only 1 menu item can be opened at a time\n\t\t\t\t\tfor ( t = 0; t < all_open_menu_triggers_count; t = t + 1 ) {\n\t\t\t\t\t\t// Check if the open menu is top-level, if so, close it\n\t\t\t\t\t\tif ( parent_menu.parentNode === menu ) {\n\t\t\t\t\t\t\tmenu_sub_close( all_open_menu_triggers[t] );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tmenu_sub_open( target );\n\t\t};\n\n\t\t// Listener for the window resize\n\t\tvar listener_window = debounce( function( e ) {\n\t\t\tif( get_screen_size( 'has-offscreen-nav' ) ) {\n\t\t\t\tmenu_create();\n\t\t\t} else {\n\t\t\t\tmenu_destroy();\n\t\t\t}\n\t\t}, 100 ); // listener_window()\n\n\t\t// Close the menu if you click somewhere else\n\t\tfunction listener_close_open_menus( e ) {\n\n\t\t\tvar open_menus = menu.querySelectorAll('.submenu-is-open');\n\t\t\tvar open_menus_count = open_menus.length;\n\t\t\tvar opn;\n\n\t\t\t// if the event is keyup and it was the ESC key\n\t\t\tif ( e.type === 'keyup' && e.keyCode == 27 ) {\n\n\t\t\t\t// We were getting some errors, so let's add in a checkpoint\n\t\t\t\tif ( open_menus_count ) {\n\n\t\t\t\t\t// Loop through all the open menus and close them\n\t\t\t\t\tfor ( opn = 0; opn < open_menus.length; opn = opn + 1 ) {\n\n\t\t\t\t\t\tmenu_sub_close( open_menus[opn] );\n\n\t\t\t\t\t} // for\n\n\t\t\t\t\t// Return focus to the first open menu\n\t\t\t\t\tif ( sub_menu_acion === 'click' ) {\n\t\t\t\t\t\topen_menus[0].focus();\n\t\t\t\t\t}\n\n\t\t\t\t} // if\n\n\t\t\t// If the event was a mouseup\n\t\t\t} else if ( e.type === 'mouseup' ) {\n\n\t\t\t\tif ( ! menu.contains( e.target ) && menu.querySelector( '.submenu-is-open' ) ) {\n\t\t\t\t\t// We were getting some error, so let's add in a second checkpoint\n\t\t\t\t\tif ( open_menus_count ) {\n\t\t\t\t\t\tfor( opn = 0; opn < open_menus.length; opn = opn + 1 ) {\n\t\t\t\t\t\t\tmenu_sub_close( open_menus[opn] );\n\t\t\t\t\t\t} // for\n\t\t\t\t\t}\n\t\t\t\t} // if\n\t\t\t}\n\t\t}; // listener_close_open_menus()\n\n\t\tfunction menu_sub_close( open_item ) {\n\t\t\tif ( open_item && open_item.classList ) {\n\t\t\t\topen_item.classList.remove('submenu-is-open');\n\t\t\t\topen_item.parentNode.classList.remove('child-has-focus');\n\t\t\t}\n\n\t\t\tif ( open_item && open_item.parentNode && open_item.parentNode.querySelector( '.sub-menu' ) ) {\n\t\t\t\topen_item.parentNode.querySelector( '.sub-menu' ).setAttribute( 'aria-hidden', 'true' );\n\t\t\t}\n\t\t}; // menu_sub_close()\n\n\t\tfunction menu_sub_close_all() {\n\t\t\tvar open_menus = menu.querySelectorAll( '.submenu-is-open' );\n\t\t\tvar open_menus_count = open_menus.length;\n\t\t\tvar opn;\n\t\t\t// We were getting some errors, so let's add in a checkpoint\n\t\t\tif ( open_menus_count ) {\n\t\t\t\t// Loop through all the open menus and close them\n\t\t\t\tfor ( opn = 0; opn < open_menus.length; opn = opn + 1 ) {\n\t\t\t\t\tmenu_sub_close( open_menus[opn] );\n\t\t\t\t} // for\n\t\t\t} // if\n\t\t}; // menu_sub_close()\n\n\t\tfunction menu_sub_open( closed_item ) {\n\t\t\tclosed_item.classList.add( 'submenu-is-open' );\n\t\t\tclosed_item.parentNode.classList.add( 'child-has-focus' );\n\n\t\t\tif ( closed_item.parentNode.querySelector( '.sub-menu' ) ) {\n\t\t\t\tclosed_item.parentNode.querySelector( '.sub-menu' ).setAttribute( 'aria-hidden', 'false' );\n\t\t\t}\n\t\t}; // menu_sub_open()\n\n\t\t// Method to create the small screen menu\n\t\tfunction menu_create() {\n\n\t\t\tif ( ! document.body.classList.contains( 'has-offscreen-nav' ) ) {\n\n\t\t\t\tif ( ! document.body.classList.contains( 'menu-is-open' ) ) {\n\t\t\t\t\tmenu.setAttribute( 'aria-hidden', 'true' );\n\t\t\t\t\tmenu_toggle.setAttribute( 'aria-expanded', 'false' );\n\t\t\t\t} else {\n\t\t\t\t\tmenu.setAttribute( 'aria-hidden', 'false' );\n\t\t\t\t\tmenu_toggle.setAttribute( 'aria-expanded', 'true' );\n\t\t\t\t}\n\n\t\t\t\t// Loop through all submenus and bind events when needed\n\t\t\t\tfor ( i = 0; i < menu_items_with_children_count; i++ ) {\n\t\t\t\t\tvar svgElements = menu_items_with_children[i].querySelectorAll( 'svg' );\n\t\t\t\t\tfor ( var q = 0; q < svgElements.length; q = q + 1 ) {\n\t\t\t\t\t\tsvgElements[q].addEventListener( 'click', listener_submenu_click );\n\t\t\t\t\t}\n\t\t\t\t\tmenu_items_with_children[i].removeEventListener( 'focusin', listener_submenu_focus );\n\t\t\t\t} // for\n\n\t\t\t\t// Loop through all links for hash and bind events when needed\n\t\t\t\tfor ( i = 0; i < menu_items_links_count; i++ ) {\n\t\t\t\t\tif ( menu_items_links[i].hash && menu_items_links[i].pathname === '/' ) {\n\t\t\t\t\t\tmenu_items_links[i].addEventListener( 'click', listener_hash_click );\n\t\t\t\t\t}\n\t\t\t\t} // for\n\n\t\t\t\t// Bind the event\n\t\t\t\tmenu_toggle.addEventListener( 'click', listener_menu );\n\n\t\t\t\t// Add the body class to prevent this from running again\n\t\t\t\tdocument.body.classList.add( 'has-offscreen-nav' );\n\t\t\t\tdocument.body.classList.remove( 'has-full-nav' );\n\t\t\t}\n\t\t}; // menu_create()\n\n\t\t// Method to destroy the small screen menu\n\t\tfunction menu_destroy() {\n\n\t\t\tvar tmp_open\n\t\t\tvar tmp_open_count\n\t\t\tvar t;\n\n\t\t\tif ( ! document.body.classList.contains( 'has-full-nav' ) ) {\n\t\t\t\t// Remove aria-hidden, because we don't need it.\n\t\t\t\tmenu.removeAttribute( 'aria-hidden' );\n\n\t\t\t\t// Loop through all submenus and bind events when needed\n\t\t\t\tfor ( i = 0; i < menu_items_with_children_count; i = i + 1 ) {\n\t\t\t\t\tif ( sub_menu_acion !== 'click' ) {\n\t\t\t\t\t\tmenu_items_with_children[i].removeEventListener( 'click', listener_submenu_click );\n\t\t\t\t\t\tmenu_items_with_children[i].addEventListener( 'focusin', listener_submenu_focus );\n\t\t\t\t\t\tmenu.classList.remove('uses-click');\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// If we're not using click, the open menus need to be reset\n\t\t\t\tif ( sub_menu_acion !== 'click' ) {\n\t\t\t\t\ttmp_open = document.querySelectorAll('.child-has-focus');\n\t\t\t\t\ttmp_open_count = tmp_open.length;\n\n\t\t\t\t\tfor ( t = 0; t < tmp_open_count; t = t + 1 ) {\n\t\t\t\t\t\ttmp_open[t].classList.remove( 'child-has-focus' );\n\t\t\t\t\t\ttmp_open[t].querySelector( '.submenu-is-open' ).classList.remove( 'submenu-is-open' );\n\t\t\t\t\t\ttmp_open[t].querySelector( '.sub-menu' ).setAttribute( 'aria-hidden', 'true' );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Unbind the event\n\t\t\t\tmenu_toggle.removeEventListener( 'click', listener_menu );\n\n\t\t\t\t// Add the body class to prevent this from running again\n\t\t\t\tdocument.body.classList.add( 'has-full-nav' );\n\t\t\t\tdocument.body.classList.remove( 'has-offscreen-nav' );\n\t\t\t}\n\t\t};\n\n\t\t// Check init menu state\n\t\tif ( get_screen_size( 'has-offscreen-nav' ) ) {\n\t\t\tmenu_create();\n\t\t}\n\n\t\t// If aria-controls isn't set, set it\n\t\tif ( ! aria_controls ) {\n\t\t\tmenu_toggle.setAttribute( 'aria-controls', menu_id );\n\t\t}\n\n\t\tif ( current_menu_item ) {\n\t\t\tcurrent_menu_item.querySelector( 'a' ).setAttribute( 'aria-current', 'page' );\n\t\t}\n\n\t\t/*\n\t\t\tEvents\n\t\t*/\n\n\t\t// Debounced resize event to create and destroy the small screen menu options\n\t\twindow.addEventListener( 'resize', listener_window );\n\n\t\t// Close the submenus by clicking off of them or hitting ESC\n\t\tdocument.addEventListener( 'mouseup', listener_close_open_menus );\n\t\tdocument.addEventListener( 'keyup', listener_close_open_menus );\n\n\t\t/*\n\t\t\tHiding and showing submenus (click, focus, hover)\n\t\t*/\n\n\t\t// Loop through all items with sub menus and bind focus to them for tabbing\n\t\tfor ( i = 0; i < menu_items_with_children_count; i = i + 1 ) {\n\n\t\t\t// Let a screen reader know this menu has a submenu by hooking into the first link\n\t\t\tmenu_items_with_children[i].querySelector( 'a' ).setAttribute( 'aria-haspopup', 'true' );\n\n\t\t\t// Hide and label each sub menu\n\t\t\tmenu_items_with_children[i].querySelector( '.sub-menu' ).setAttribute( 'aria-hidden', 'true' );\n\t\t\tmenu_items_with_children[i].querySelector( '.sub-menu' ).setAttribute( 'aria-label', 'Submenu' );\n\n\t\t\t// If the screen is small or the action is set to click\n\t\t\tif ( get_screen_size( 'has-offscreen-nav' ) || sub_menu_acion === 'click' ) {\n\t\t\t\tmenu_items_with_children[i].addEventListener( 'click', listener_submenu_click );\n\n\t\t\t\tvar svgElements = menu_items_with_children[i].querySelectorAll( 'svg' );\n\n\t\t\t\tfor ( var z = 0; z < svgElements.length; z = z + 1 ) {\n\n\t\t\t\t\tsvgElements[z].addEventListener( 'click', listener_submenu_click );\n\t\t\t\t\tsvgElements[z].addEventListener( 'keypress', ( e ) => { ['Space', 'Enter'].includes( e.code ) && listener_submenu_click( e ) } );\n\t\t\t\t\tsvgElements[z].setAttribute( 'tabindex', '0' );\n\n\t\t\t\t}\n\n\t\t\t\tmenu.classList.add( sub_menu_acion === 'click' ? 'uses-click' : 'uses-hover' );\n\t\t\t} else if ( sub_menu_acion !== 'click' ) {\n\t\t\t\tif ( get_screen_size( 'has-full-nav' ) ) {\n\t\t\t\t\tmenu_items_with_children[i].addEventListener( 'mouseover', listener_submenu_focus );\n\t\t\t\t\tmenu_items_with_children[i].addEventListener( 'mouseout', function() {\n\t\t\t\t\t\tvar open_menus = menu.querySelectorAll( '.submenu-is-open' );\n\t\t\t\t\t\tvar open_menus_count = open_menus.length;\n\t\t\t\t\t\tvar opn;\n\n\t\t\t\t\t\t// We were getting some errors, so let's add in a checkpoint\n\t\t\t\t\t\tif ( open_menus_count ) {\n\n\t\t\t\t\t\t\t// Loop through all the open menus and close them\n\t\t\t\t\t\t\tfor ( opn = 0; opn < open_menus_count; opn = opn + 1 ) {\n\n\t\t\t\t\t\t\t\tmenu_sub_close( open_menus[opn] );\n\n\t\t\t\t\t\t\t} // for\n\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\t\t\t\t\tmenu_items_with_children[i].addEventListener( 'focusin', listener_submenu_focus );\n\t\t\t\t\tmenu_items_with_children[i].querySelectorAll( '.sub-menu' ).forEach( submenu => {\n\t\t\t\t\t\tsubmenu.addEventListener( 'mouseover', event => {\n\t\t\t\t\t\t\tsubmenu.parentElement.classList.add( 'child-has-focus' );\n\t\t\t\t\t\t\tsubmenu.previousElementSibling.classList.add( 'submenu-is-open' );\n\t\t\t\t\t\t}, false );\n\t\t\t\t\t} );\n\t\t\t\t} // if\n\t\t\t} // if\n\t\t} // for\n\n\t\t// Execute the callback function\n\t\tif ( typeof callback === 'function' ) {\n\t\t\tcallback.call();\n\t\t}\n\t}; // build_menu()\n\n\t/*\n\t\tHelper functions\n\t*/\n\n\t// Get screen size from getComputedStyle (so we don't have to define each breakpoint twice) -- Values are set in CSS --\n\tfunction get_screen_size( sizeString ) {\n\t\tvar size = window.getComputedStyle( document.body,':before' ).getPropertyValue( 'content' );\n\n\t\tif ( size && size.indexOf( sizeString ) !== -1 ) {\n\t\t\treturn true;\n\t\t}\n\t};\n\n} )();\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import debounce from './utility/debounce';\nimport primaryMenu from './components/primary-menu.js';\nimport searchToggle from './components/search-toggle.js';\nimport wooMenuCart from './components/woo-menu-cart.js';\n\nprimaryMenu();\nsearchToggle();\nwooMenuCart();\n\ndocument.addEventListener( 'DOMContentLoaded', function() {\n\tconst hasSelectiveRefresh = (\n\t\t'undefined' !== typeof wp &&\n\t\twp.customize &&\n\t\twp.customize.selectiveRefresh &&\n\t\twp.customize.navMenusPreview.NavMenuInstancePartial\n\t);\n\n\t// partial-content-rendered might render multiple times for some reason, let's make sure to debouce this.\n\tconst init = debounce( () => {\n\t\t// we need to remove this before calling primary menu again.\n\t\tdocument.body.classList.remove( 'has-offscreen-nav' );\n\n\t\tprimaryMenu();\n\t\tsearchToggle();\n\t}, 1000 );\n\n\tif ( hasSelectiveRefresh ) {\n\t\twp.customize.selectiveRefresh.bind( 'partial-content-rendered', function( placement ) {\n\t\t\tconst changedHeaderVariation = (\n\t\t\t\tplacement &&\n\t\t\t\t'null' !== placement.container[ 0 ].parentNode &&\n\t\t\t\t'header_variation' === placement.partial.id\n\t\t\t);\n\n\t\t\tif ( changedHeaderVariation ) {\n\t\t\t\tinit();\n\t\t\t}\n\t\t} );\n\t}\n} );\n"],"names":[],"sourceRoot":""}