shell bypass 403

GrazzMean Shell

Uname: Linux p3plzcpnl499967.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
Software: Apache
PHP version: 8.2.30 [ PHP INFO ] PHP os: Linux
Server Ip: 208.109.40.231
Your Ip: 216.73.216.26
User: nayff91c5tsx (10005085) | Group: nayff91c5tsx (10005085)
Safe Mode: OFF
Disable Function:
NONE

name : 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'); // Set aria-expanded=false on the SVG element within this menu item

        var svgElement = open_item.parentNode.querySelector('svg');

        if (svgElement) {
          svgElement.setAttribute('aria-expanded', 'false');
        }
      }

      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'); // Set aria-expanded=true on the SVG element within this menu item

      var svgElement = closed_item.parentNode.querySelector('svg');

      if (svgElement) {
        svgElement.setAttribute('aria-expanded', 'true');
      }

      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 svgElement = menu_items_with_children[i].querySelector('svg');

          if (svgElement) {
            svgElement.addEventListener('click', listener_submenu_click);
            svgElement.setAttribute('aria-expanded', 'false');
          }

          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 svgElement = menu_items_with_children[i].querySelector('svg');

        if (svgElement) {
          svgElement.addEventListener('click', listener_submenu_click);
          svgElement.addEventListener('keypress', e => {
            ['Space', 'Enter'].includes(e.code) && listener_submenu_click(e);
          });
          svgElement.setAttribute('tabindex', '0');
          svgElement.setAttribute('aria-expanded', 'false');
        }

        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;;AAGA;;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAAA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AACA;;AACA;;AAAA;;AAEA;AACA;AACA;;AAGA;;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAAA;AAEA;;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;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;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;;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;;;;;;AC9dA;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\t\n\t\t\t\t// Set aria-expanded=false on the SVG element within this menu item\n\t\t\t\tvar svgElement = open_item.parentNode.querySelector( 'svg' );\n\t\t\t\tif ( svgElement ) {\n\t\t\t\t\tsvgElement.setAttribute( 'aria-expanded', 'false' );\n\t\t\t\t}\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\t// Set aria-expanded=true on the SVG element within this menu item\n\t\t\tvar svgElement = closed_item.parentNode.querySelector( 'svg' );\n\t\t\tif ( svgElement ) {\n\t\t\t\tsvgElement.setAttribute( 'aria-expanded', 'true' );\n\t\t\t}\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 svgElement = menu_items_with_children[i].querySelector( 'svg' );\n\t\t\t\t\tif ( svgElement ) {\n\t\t\t\t\t\tsvgElement.addEventListener( 'click', listener_submenu_click );\n\t\t\t\t\t\tsvgElement.setAttribute( 'aria-expanded', 'false' );\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 svgElement = menu_items_with_children[i].querySelector( 'svg' );\n\n\t\t\t\tif ( svgElement ) {\n\t\t\t\t\tsvgElement.addEventListener( 'click', listener_submenu_click );\n\t\t\t\t\tsvgElement.addEventListener( 'keypress', ( e ) => { ['Space', 'Enter'].includes( e.code ) && listener_submenu_click( e ) } );\n\t\t\t\t\tsvgElement.setAttribute( 'tabindex', '0' );\n\t\t\t\t\tsvgElement.setAttribute( 'aria-expanded', 'false' );\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} )();","// 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":""}
© 2026 GrazzMean