(globalThis.blocksyJsonP=globalThis.blocksyJsonP||[]).push([[627],{627:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"handleClick\": () => (/* binding */ handleClick),\n \"mount\": () => (/* binding */ overlay_mount)\n});\n\n// EXTERNAL MODULE: ./node_modules/body-scroll-lock/lib/bodyScrollLock.min.js\nvar bodyScrollLock_min = __webpack_require__(891);\n;// CONCATENATED MODULE: ./static/js/frontend/lazy/overlay/no-bounce.js\n\nconst isIosDevice = typeof window !== 'undefined' && window.navigator && window.navigator.platform && (/iP(ad|hone|od)/.test(window.navigator.platform) || window.navigator.platform === 'MacIntel' && window.navigator.maxTouchPoints > 1);\nvar enable = function (el) {\n if (!isIosDevice) {\n document.body.style.overflow = '';\n document.body.style.removeProperty('--scrollbar-width');\n } else {\n (0,bodyScrollLock_min.clearAllBodyScrollLocks)();\n }\n};\nvar disable = function (el) {\n if (!isIosDevice) {\n let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n\n if (scrollbarWidth > 0) {\n document.body.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);\n }\n\n document.body.style.overflow = 'hidden';\n } else {\n if (el) {\n (0,bodyScrollLock_min.disableBodyScroll)(el, {\n // reserveScrollBarGap: true,\n allowTouchMove: el => {\n if (el.closest('.select2-container')) {\n return true;\n }\n\n return false;\n }\n });\n }\n }\n};\n// EXTERNAL MODULE: external \"ctEvents\"\nvar external_ctEvents_ = __webpack_require__(601);\nvar external_ctEvents_default = /*#__PURE__*/__webpack_require__.n(external_ctEvents_);\n;// CONCATENATED MODULE: ./static/js/frontend/lazy/overlay/mobile-menu.js\nconst activateSubMenu = container => {\n const subMenu = container.querySelector('ul');\n requestAnimationFrame(() => {\n const actualHeight = subMenu.getBoundingClientRect().height;\n subMenu.style.height = '0px';\n subMenu.classList.add('is-animating');\n requestAnimationFrame(() => {\n subMenu.style.height = `${actualHeight}px`;\n whenTransitionEnds(subMenu, () => {\n subMenu.classList.remove('is-animating');\n subMenu.removeAttribute('style');\n });\n });\n });\n};\n\nconst deactivateSubMenu = (container, cb) => {\n const subMenu = container.querySelector('ul');\n requestAnimationFrame(() => {\n const actualHeight = subMenu.getBoundingClientRect().height;\n subMenu.style.height = `${actualHeight}px`;\n subMenu.classList.add('is-animating');\n requestAnimationFrame(() => {\n subMenu.style.height = '0px';\n whenTransitionEnds(subMenu, () => {\n subMenu.classList.remove('is-animating');\n subMenu.removeAttribute('style');\n cb();\n });\n });\n });\n};\n\nconst handleContainer = container => {\n if (!container) {\n return;\n }\n\n const arrow = container.querySelector('.ct-toggle-dropdown-mobile');\n\n if (container.classList.contains('dropdown-active')) {\n arrow.setAttribute('aria-expanded', 'false');\n arrow.setAttribute('aria-label', ct_localizations.expand_submenu);\n deactivateSubMenu(container, () => {\n container.classList.toggle('dropdown-active');\n [...container.querySelectorAll('.menu-item-has-children.dropdown-active, .page_item_has_children.dropdown-active')].map(el => el.classList.remove('dropdown-active'));\n });\n } else {\n arrow.setAttribute('aria-expanded', 'true');\n arrow.setAttribute('aria-label', ct_localizations.collapse_submenu);\n [...container.parentNode.children].map(el => el.classList.contains('dropdown-active') && handleContainer(el));\n container.classList.toggle('dropdown-active');\n activateSubMenu(container);\n }\n};\n\nconst mount = arrow => {\n if (arrow.hasListener) {\n return;\n }\n\n arrow.hasListener = true;\n let parentHref = arrow.previousElementSibling.getAttribute('href');\n\n if (!parentHref || parentHref === '#') {\n arrow.previousElementSibling.addEventListener('click', e => {\n e.preventDefault();\n e.stopPropagation();\n handleContainer(arrow.closest('.menu-item-has-children, .page_item_has_children'));\n });\n }\n\n arrow.addEventListener('click', e => {\n e.preventDefault();\n e.stopPropagation();\n handleContainer(arrow.closest('.menu-item-has-children, .page_item_has_children'));\n });\n};\n\nfunction whenTransitionEnds(el, cb) {\n const end = () => {\n el.removeEventListener('transitionend', onEnd);\n cb();\n };\n\n const onEnd = e => {\n if (e.target === el) {\n end();\n }\n };\n\n el.addEventListener('transitionend', onEnd);\n}\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/array.js\nvar toArray = function toArray(a) {\n var ret = Array(a.length);\n for (var i = 0; i < a.length; ++i) {\n ret[i] = a[i];\n }\n return ret;\n};\n\nvar arrayFind = function arrayFind(array, search) {\n return array.filter(function (a) {\n return a === search;\n })[0];\n};\n\nvar asArray = function asArray(a) {\n return Array.isArray(a) ? a : [a];\n};\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/tabOrder.js\n\n\nvar tabSort = function tabSort(a, b) {\n var tabDiff = a.tabIndex - b.tabIndex;\n var indexDiff = a.index - b.index;\n\n if (tabDiff) {\n if (!a.tabIndex) return 1;\n if (!b.tabIndex) return -1;\n }\n\n return tabDiff || indexDiff;\n};\n\nvar orderByTabIndex = function orderByTabIndex(nodes, filterNegative, keepGuards) {\n return toArray(nodes).map(function (node, index) {\n return {\n node: node,\n index: index,\n tabIndex: keepGuards && node.tabIndex === -1 ? (node.dataset || {}).focusGuard ? 0 : -1 : node.tabIndex\n };\n }).filter(function (data) {\n return !filterNegative || data.tabIndex >= 0;\n }).sort(tabSort);\n};\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/tabbables.js\n/* harmony default export */ const tabbables = (['button:enabled:not([readonly])', 'select:enabled:not([readonly])', 'textarea:enabled:not([readonly])', 'input:enabled:not([readonly])', 'a[href]', 'area[href]', 'iframe', 'object', 'embed', '[tabindex]', '[contenteditable]', '[autofocus]']);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/constants.js\nvar FOCUS_GROUP = 'data-focus-lock';\nvar FOCUS_DISABLED = 'data-focus-lock-disabled';\nvar FOCUS_ALLOW = 'data-no-focus-lock';\nvar FOCUS_AUTO = 'data-autofocus-inside';\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/tabUtils.js\n\n\n\n\nvar queryTabbables = tabbables.join(',');\nvar queryGuardTabbables = queryTabbables + ', [data-focus-guard]';\n\nvar getFocusables = function getFocusables(parents, withGuards) {\n return parents.reduce(function (acc, parent) {\n return acc.concat(\n // add all tabbables inside\n toArray(parent.querySelectorAll(withGuards ? queryGuardTabbables : queryTabbables)),\n // add if node is tabble itself\n parent.parentNode ? toArray(parent.parentNode.querySelectorAll(tabbables.join(','))).filter(function (node) {\n return node === parent;\n }) : []);\n }, []);\n};\n\nvar getParentAutofocusables = function getParentAutofocusables(parent) {\n var parentFocus = parent.querySelectorAll('[' + FOCUS_AUTO + ']');\n return toArray(parentFocus).map(function (node) {\n return getFocusables([node]);\n }).reduce(function (acc, nodes) {\n return acc.concat(nodes);\n }, []);\n};\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/DOMutils.js\n\n\n\n\nvar isElementHidden = function isElementHidden(computedStyle) {\n if (!computedStyle || !computedStyle.getPropertyValue) {\n return false;\n }\n return computedStyle.getPropertyValue('display') === 'none' || computedStyle.getPropertyValue('visibility') === 'hidden';\n};\n\nvar isVisible = function isVisible(node) {\n return !node || node === document || node.nodeType === Node.DOCUMENT_NODE || !isElementHidden(window.getComputedStyle(node, null)) && isVisible(node.parentNode);\n};\n\nvar notHiddenInput = function notHiddenInput(node) {\n return !((node.tagName === 'INPUT' || node.tagName === 'BUTTON') && (node.type === 'hidden' || node.disabled));\n};\n\nvar getParents = function getParents(node) {\n var parents = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n\n parents.push(node);\n if (node.parentNode) {\n getParents(node.parentNode, parents);\n }\n return parents;\n};\n\nvar getCommonParent = function getCommonParent(nodea, nodeb) {\n var parentsA = getParents(nodea);\n var parentsB = getParents(nodeb);\n\n for (var i = 0; i < parentsA.length; i += 1) {\n var currentParent = parentsA[i];\n if (parentsB.indexOf(currentParent) >= 0) {\n return currentParent;\n }\n }\n return false;\n};\n\nvar filterFocusable = function filterFocusable(nodes) {\n return toArray(nodes).filter(function (node) {\n return isVisible(node);\n }).filter(function (node) {\n return notHiddenInput(node);\n });\n};\n\nvar DOMutils_getTabbableNodes = function getTabbableNodes(topNodes, withGuards) {\n return orderByTabIndex(filterFocusable(getFocusables(topNodes, withGuards)), true, withGuards);\n};\n\nvar getAllTabbableNodes = function getAllTabbableNodes(topNodes) {\n return orderByTabIndex(filterFocusable(getFocusables(topNodes)), false);\n};\n\nvar parentAutofocusables = function parentAutofocusables(topNode) {\n return filterFocusable(getParentAutofocusables(topNode));\n};\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/firstFocus.js\nvar isRadio = function isRadio(node) {\n return node.tagName === 'INPUT' && node.type === 'radio';\n};\n\nvar findSelectedRadio = function findSelectedRadio(node, nodes) {\n return nodes.filter(isRadio).filter(function (el) {\n return el.name === node.name;\n }).filter(function (el) {\n return el.checked;\n })[0] || node;\n};\n\nvar pickFirstFocus = function pickFirstFocus(nodes) {\n if (nodes[0] && nodes.length > 1) {\n if (isRadio(nodes[0]) && nodes[0].name) {\n return findSelectedRadio(nodes[0], nodes);\n }\n }\n return nodes[0];\n};\n\nvar pickFocusable = function pickFocusable(nodes, index) {\n if (nodes.length > 1) {\n if (isRadio(nodes[index]) && nodes[index].name) {\n return nodes.indexOf(findSelectedRadio(nodes[index], nodes));\n }\n }\n return index;\n};\n\n/* harmony default export */ const utils_firstFocus = (pickFirstFocus);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/utils/all-affected.js\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\n\n\n\nvar filterNested = function filterNested(nodes) {\n var l = nodes.length;\n for (var i = 0; i < l; i += 1) {\n var _loop = function _loop(j) {\n if (i !== j) {\n if (nodes[i].contains(nodes[j])) {\n return {\n v: filterNested(nodes.filter(function (x) {\n return x !== nodes[j];\n }))\n };\n }\n }\n };\n\n for (var j = 0; j < l; j += 1) {\n var _ret = _loop(j);\n\n if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === \"object\") return _ret.v;\n }\n }\n return nodes;\n};\n\nvar getTopParent = function getTopParent(node) {\n return node.parentNode ? getTopParent(node.parentNode) : node;\n};\n\nvar all_affected_getAllAffectedNodes = function getAllAffectedNodes(node) {\n var nodes = asArray(node);\n return nodes.filter(Boolean).reduce(function (acc, currentNode) {\n var group = currentNode.getAttribute(FOCUS_GROUP);\n acc.push.apply(acc, group ? filterNested(toArray(getTopParent(currentNode).querySelectorAll('[' + FOCUS_GROUP + '=\"' + group + '\"]:not([' + FOCUS_DISABLED + '=\"disabled\"])'))) : [currentNode]);\n return acc;\n }, []);\n};\n\n/* harmony default export */ const all_affected = (all_affected_getAllAffectedNodes);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/focusMerge.js\n\n\n\n\n\nvar findAutoFocused = function findAutoFocused(autoFocusables) {\n return function (node) {\n return !!node.autofocus || node.dataset && !!node.dataset.autofocus || autoFocusables.indexOf(node) >= 0;\n };\n};\n\nvar isGuard = function isGuard(node) {\n return node && node.dataset && node.dataset.focusGuard;\n};\nvar notAGuard = function notAGuard(node) {\n return !isGuard(node);\n};\n\nvar newFocus = function newFocus(innerNodes, outerNodes, activeElement, lastNode, autoFocused) {\n var cnt = innerNodes.length;\n var firstFocus = innerNodes[0];\n var lastFocus = innerNodes[cnt - 1];\n var isOnGuard = isGuard(activeElement);\n\n // focus is inside\n if (innerNodes.indexOf(activeElement) >= 0) {\n return undefined;\n }\n\n var activeIndex = outerNodes.indexOf(activeElement);\n var lastIndex = outerNodes.indexOf(lastNode || activeIndex);\n var lastNodeInside = innerNodes.indexOf(lastNode);\n var indexDiff = activeIndex - lastIndex;\n var firstNodeIndex = outerNodes.indexOf(firstFocus);\n var lastNodeIndex = outerNodes.indexOf(lastFocus);\n\n var returnFirstNode = pickFocusable(innerNodes, 0);\n var returnLastNode = pickFocusable(innerNodes, cnt - 1);\n\n // new focus\n if (activeIndex === -1 || lastNodeInside === -1) {\n return innerNodes.indexOf(autoFocused && autoFocused.length ? utils_firstFocus(autoFocused) : utils_firstFocus(innerNodes));\n }\n // old focus\n if (!indexDiff && lastNodeInside >= 0) {\n return lastNodeInside;\n }\n // first element\n if (activeIndex <= firstNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n return returnLastNode;\n }\n // last element\n if (activeIndex >= firstNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n return returnFirstNode;\n }\n // jump out, but not on the guard\n if (indexDiff && Math.abs(indexDiff) > 1) {\n return lastNodeInside;\n }\n // focus above lock\n if (activeIndex <= firstNodeIndex) {\n return returnLastNode;\n }\n // focus below lock\n if (activeIndex > lastNodeIndex) {\n return returnFirstNode;\n }\n // index is inside tab order, but outside Lock\n if (indexDiff) {\n if (Math.abs(indexDiff) > 1) {\n return lastNodeInside;\n }\n return (cnt + lastNodeInside + indexDiff) % cnt;\n }\n // do nothing\n return undefined;\n};\n\nvar getTopCommonParent = function getTopCommonParent(baseActiveElement, leftEntry, rightEntries) {\n var activeElements = asArray(baseActiveElement);\n var leftEntries = asArray(leftEntry);\n var activeElement = activeElements[0];\n var topCommon = null;\n leftEntries.filter(Boolean).forEach(function (entry) {\n topCommon = getCommonParent(topCommon || entry, entry) || topCommon;\n rightEntries.filter(Boolean).forEach(function (subEntry) {\n var common = getCommonParent(activeElement, subEntry);\n if (common) {\n if (!topCommon || common.contains(topCommon)) {\n topCommon = common;\n } else {\n topCommon = getCommonParent(common, topCommon);\n }\n }\n });\n });\n return topCommon;\n};\n\nvar allParentAutofocusables = function allParentAutofocusables(entries) {\n return entries.reduce(function (acc, node) {\n return acc.concat(parentAutofocusables(node));\n }, []);\n};\n\nvar reorderNodes = function reorderNodes(srcNodes, dstNodes) {\n var remap = new Map();\n // no Set(dstNodes) for IE11 :(\n dstNodes.forEach(function (entity) {\n return remap.set(entity.node, entity);\n });\n // remap to dstNodes\n return srcNodes.map(function (node) {\n return remap.get(node);\n }).filter(Boolean);\n};\n\nvar getFocusabledIn = function getFocusabledIn(topNode) {\n var entries = getAllAffectedNodes(topNode).filter(notAGuard);\n var commonParent = getTopCommonParent(topNode, topNode, entries);\n var outerNodes = getTabbableNodes([commonParent], true);\n var innerElements = getTabbableNodes(entries).filter(function (_ref) {\n var node = _ref.node;\n return notAGuard(node);\n }).map(function (_ref2) {\n var node = _ref2.node;\n return node;\n });\n\n return outerNodes.map(function (_ref3) {\n var node = _ref3.node,\n index = _ref3.index;\n return {\n node: node,\n index: index,\n lockItem: innerElements.indexOf(node) >= 0,\n guard: isGuard(node)\n };\n });\n};\n\nvar getFocusMerge = function getFocusMerge(topNode, lastNode) {\n var activeElement = document && document.activeElement;\n var entries = all_affected(topNode).filter(notAGuard);\n\n var commonParent = getTopCommonParent(activeElement || topNode, topNode, entries);\n\n var innerElements = DOMutils_getTabbableNodes(entries).filter(function (_ref4) {\n var node = _ref4.node;\n return notAGuard(node);\n });\n\n if (!innerElements[0]) {\n innerElements = getAllTabbableNodes(entries).filter(function (_ref5) {\n var node = _ref5.node;\n return notAGuard(node);\n });\n if (!innerElements[0]) {\n return undefined;\n }\n }\n\n var outerNodes = DOMutils_getTabbableNodes([commonParent]).map(function (_ref6) {\n var node = _ref6.node;\n return node;\n });\n var orderedInnerElements = reorderNodes(outerNodes, innerElements);\n var innerNodes = orderedInnerElements.map(function (_ref7) {\n var node = _ref7.node;\n return node;\n });\n\n var newId = newFocus(innerNodes, outerNodes, activeElement, lastNode, innerNodes.filter(findAutoFocused(allParentAutofocusables(entries))));\n\n if (newId === undefined) {\n return newId;\n }\n return orderedInnerElements[newId];\n};\n\n/* harmony default export */ const focusMerge = (getFocusMerge);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/setFocus.js\n\n\nvar focusOn = function focusOn(target) {\n target.focus();\n if (target.contentWindow) {\n target.contentWindow.focus();\n }\n};\n\nvar guardCount = 0;\nvar lockDisabled = false;\n\n/* harmony default export */ const setFocus = (function (topNode, lastNode) {\n var focusable = focusMerge(topNode, lastNode);\n\n if (lockDisabled) {\n return;\n }\n\n if (focusable) {\n if (guardCount > 2) {\n // eslint-disable-next-line no-console\n console.error('FocusLock: focus-fighting detected. Only one focus management system could be active. ' + 'See https://github.com/theKashey/focus-lock/#focus-fighting');\n lockDisabled = true;\n setTimeout(function () {\n lockDisabled = false;\n }, 1);\n return;\n }\n guardCount++;\n focusOn(focusable.node);\n guardCount--;\n }\n});\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/index.js\n\n\n\n\n\n\n\n\n\n\n/* harmony default export */ const es2015 = (setFocus);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/focusIsHidden.js\n\n\n\nvar focusIsHidden = function focusIsHidden() {\n return document && toArray(document.querySelectorAll('[' + FOCUS_ALLOW + ']')).some(function (node) {\n return node.contains(document.activeElement);\n });\n};\n\n/* harmony default export */ const es2015_focusIsHidden = (focusIsHidden);\n;// CONCATENATED MODULE: ./node_modules/focus-lock/dist/es2015/focusInside.js\n\n\n\nvar focusInFrame = function focusInFrame(frame) {\n return frame === document.activeElement;\n};\n\nvar focusInsideIframe = function focusInsideIframe(topNode) {\n return !!arrayFind(toArray(topNode.querySelectorAll('iframe')), focusInFrame);\n};\n\nvar focusInside = function focusInside(topNode) {\n var activeElement = document && document.activeElement;\n\n if (!activeElement || activeElement.dataset && activeElement.dataset.focusGuard) {\n return false;\n }\n return all_affected(topNode).reduce(function (result, node) {\n return result || node.contains(activeElement) || focusInsideIframe(node);\n }, false);\n};\n\n/* harmony default export */ const es2015_focusInside = (focusInside);\n;// CONCATENATED MODULE: ./node_modules/dom-focus-lock/dist/index.esm.js\n\n\nvar lastActiveTrap = 0;\nvar lastActiveFocus = null;\n\nvar focusOnBody = function focusOnBody() {\n return document && document.activeElement === document.body;\n};\n\nvar isFreeFocus = function isFreeFocus() {\n return focusOnBody() || es2015_focusIsHidden();\n};\n\nvar activateTrap = function activateTrap() {\n var result = false;\n\n if (lastActiveTrap) {\n var observed = lastActiveTrap;\n\n if (!isFreeFocus()) {\n if (observed && !es2015_focusInside(observed)) {\n result = es2015(observed, lastActiveFocus);\n }\n\n lastActiveFocus = document.activeElement;\n }\n }\n\n return result;\n};\n\nvar reducePropsToState = function reducePropsToState(propsList) {\n return propsList.filter(function (node) {\n return node;\n }).slice(-1)[0];\n};\n\nvar handleStateChangeOnClient = function handleStateChangeOnClient(trap) {\n lastActiveTrap = trap;\n\n if (trap) {\n activateTrap();\n }\n};\n\nvar instances = [];\n\nvar emitChange = function emitChange(event) {\n if (handleStateChangeOnClient(reducePropsToState(instances))) {\n event && event.preventDefault();\n return true;\n }\n\n return false;\n};\n\nvar attachHandler = function attachHandler() {\n document.addEventListener('focusin', emitChange);\n};\n\nvar detachHandler = function detachHandler() {\n document.removeEventListener('focusin', emitChange);\n};\n\nvar focusLock = {\n on: function on(domNode) {\n if (instances.length === 0) {\n attachHandler();\n }\n\n if (instances.indexOf(domNode) < 0) {\n instances.push(domNode);\n emitChange();\n }\n },\n off: function off(domNode) {\n instances = instances.filter(function (node) {\n return node !== domNode;\n });\n emitChange();\n\n if (instances.length === 0) {\n detachHandler();\n }\n }\n};\n\n/* harmony default export */ const index_esm = (focusLock);\n\n;// CONCATENATED MODULE: ./static/js/frontend/helpers/focus-lock.js\n\n\nconst focusLockOn = container => {\n let focusLockToUse = index_esm;\n\n if (window.ctFrontend && window.ctFrontend.focusLock) {\n focusLockToUse = ctFrontend.focusLock;\n } else {\n window.ctFrontend = window.ctFrontend || {};\n window.ctFrontend.focusLock = focusLockToUse;\n }\n\n focusLockToUse.on(container);\n};\nconst focusLockOff = container => {\n let focusLockToUse = index_esm;\n\n if (window.ctFrontend && window.ctFrontend.focusLock) {\n focusLockToUse = ctFrontend.focusLock;\n } else {\n window.ctFrontend = window.ctFrontend || {};\n window.ctFrontend.focusLock = focusLockToUse;\n }\n\n focusLockToUse.off(container);\n};\n;// CONCATENATED MODULE: ./static/js/frontend/lazy/overlay.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst showOffcanvas = settings => {\n settings = _objectSpread({\n onClose: () => {},\n container: null,\n focus: true\n }, settings);\n [...document.querySelectorAll(`[data-toggle-panel*=\"${settings.container.id}\"]`), ...document.querySelectorAll(`[href*=\"${settings.container.id}\"]`)].map(trigger => {\n trigger.setAttribute('aria-expanded', 'true');\n });\n\n if (settings.focus) {\n setTimeout(() => {\n settings.container.querySelector('input') && settings.container.querySelector('input').focus();\n }, 200);\n }\n\n if (settings.container.querySelector('.ct-panel-content')) {\n settings.container.querySelector('.ct-panel-content').addEventListener('click', event => {\n Array.from(settings.container.querySelectorAll('select')).map(select => select.selectr && select.selectr.events.dismiss(event));\n });\n }\n\n if (settings.clickOutside && settings.container.querySelector('.ct-panel-content')) {\n settings.container.addEventListener('click', settings.handleContainerClick);\n }\n\n const onKeyUp = event => {\n const {\n keyCode,\n target\n } = event;\n if (keyCode !== 27) return;\n event.preventDefault();\n document.body.hasAttribute('data-panel') && hideOffcanvas(settings);\n document.removeEventListener('keyup', onKeyUp);\n };\n\n document.addEventListener('keyup', onKeyUp);\n let maybeCloseButton = settings.container && settings.container.querySelector('.ct-toggle-close');\n\n if (maybeCloseButton) {\n maybeCloseButton.addEventListener('click', event => {\n event.preventDefault();\n hideOffcanvas(settings);\n }, {\n once: true\n });\n\n if (!maybeCloseButton.hasEnterListener) {\n maybeCloseButton.hasEnterListener = true;\n maybeCloseButton.addEventListener('keyup', e => {\n if (13 == e.keyCode) {\n e.preventDefault();\n hideOffcanvas(settings);\n }\n });\n }\n }\n\n if (settings.computeScrollContainer || settings.container.querySelector('.ct-panel-content')) {\n disable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n setTimeout(() => {\n focusLockOn(settings.container.querySelector('.ct-panel-content').parentNode);\n });\n }\n /**\n * Add window event listener in the next frame. This allows us to freely\n * propagate the current clck event up the chain -- without the modal\n * getting closed.\n */\n\n\n window.addEventListener('click', settings.handleWindowClick, {\n capture: true\n });\n external_ctEvents_default().trigger('ct:modal:opened', settings.container);\n [...settings.container.querySelectorAll('.ct-toggle-dropdown-mobile')].map(arrow => {\n mount(arrow);\n });\n};\n\nconst hideOffcanvas = function (settings) {\n let args = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n settings = _objectSpread({\n onClose: () => {},\n container: null\n }, settings);\n args = _objectSpread({\n closeInstant: false\n }, args);\n\n if (!document.body.hasAttribute('data-panel')) {\n settings.container.classList.remove('active');\n settings.onClose();\n return;\n }\n\n ;\n [...document.querySelectorAll(`[data-toggle-panel*=\"${settings.container.id}\"]`), ...document.querySelectorAll(`[href*=\"${settings.container.id}\"]`)].map(trigger => {\n trigger.setAttribute('aria-expanded', 'false');\n });\n settings.container.classList.remove('active');\n\n if (args.closeInstant) {\n document.body.removeAttribute('data-panel');\n external_ctEvents_default().trigger('ct:modal:closed', settings.container);\n enable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n } else {\n document.body.dataset.panel = `out`;\n settings.container.addEventListener('transitionend', () => {\n setTimeout(() => {\n document.body.removeAttribute('data-panel');\n external_ctEvents_default().trigger('ct:modal:closed', settings.container);\n enable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n focusLockOff(settings.container.querySelector('.ct-panel-content').parentNode);\n }, 300);\n }, {\n once: true\n });\n }\n\n window.removeEventListener('click', settings.handleWindowClick, {\n capture: true\n });\n settings.container.removeEventListener('click', settings.handleContainerClick);\n settings.onClose();\n};\n\nconst handleClick = (e, settings) => {\n if (e && e.preventDefault) {\n e.preventDefault();\n }\n\n settings = _objectSpread({\n onClose: () => {},\n container: null,\n focus: false,\n clickOutside: true,\n isModal: false,\n computeScrollContainer: null,\n closeWhenLinkInside: false,\n handleContainerClick: event => {\n let isInsidePanelContent = event.target.closest('.ct-panel-content');\n let isPanelContentItself = [...settings.container.querySelectorAll('.ct-panel-content')].indexOf(event.target) > -1;\n\n if (settings.isModal && !isPanelContentItself && isInsidePanelContent || !settings.isModal && (isPanelContentItself || isInsidePanelContent) || event.target.closest('[class*=\"select2-container\"]')) {\n return;\n }\n\n if (window.getSelection().toString().length > 0) {\n return;\n }\n\n document.body.hasAttribute('data-panel') && hideOffcanvas(settings);\n },\n handleWindowClick: e => {\n if (settings.container.contains(e.target) || e.target === document.body || event.target.closest('[class*=\"select2-container\"]')) {\n return;\n }\n\n if (!document.body.hasAttribute('data-panel')) {\n return;\n }\n\n hideOffcanvas(settings);\n }\n }, settings);\n showOffcanvas(settings);\n /*\n if (document.body.hasAttribute('data-panel')) {\n \tif (\n \t\tsettings.isModal &&\n \t\t!settings.container.classList.contains('active')\n \t) {\n \t\tconst menuToggle = document.querySelector('.ct-header-trigger')\n \t\t\tif (menuToggle) {\n \t\t\tmenuToggle.click()\n \t\t}\n \t\t\tsetTimeout(() => {\n \t\t\tshowOffcanvas(settings)\n \t\t}, 600)\n \t} else {\n \t\thideOffcanvas(settings)\n \t}\n } else {\n \tshowOffcanvas(settings)\n }\n */\n\n if (settings.closeWhenLinkInside) {\n if (!settings.container.hasListener) {\n settings.container.hasListener = true;\n settings.container.addEventListener('click', event => {\n if (!event.target) {\n return;\n }\n\n let maybeA = event.target;\n\n if (event.target.closest('a')) {\n maybeA = event.target.closest('a');\n }\n\n if (!maybeA.closest('.ct-panel').classList.contains('active')) {\n return;\n }\n\n if (!maybeA.matches('a')) {\n return;\n }\n\n if (!maybeA.closest('nav[data-id*=\"menu\"]') && !maybeA.closest('[data-id*=\"text\"]') && !maybeA.closest('[data-id*=\"button\"]') && !maybeA.matches('.ct-offcanvas-trigger') && !maybeA.matches('.ct-header-account') && !maybeA.closest('.widget_nav_menu')) {\n return;\n }\n\n hideOffcanvas(settings, {\n closeInstant: maybeA.getAttribute('href')[0] !== '#'\n });\n setTimeout(() => {\n if (maybeA.matches('.ct-offcanvas-trigger') || maybeA.matches('.ct-header-account')) {\n maybeA.click();\n }\n }, 500);\n });\n }\n }\n};\nexternal_ctEvents_default().on('ct:offcanvas:force-close', settings => hideOffcanvas(settings));\nconst overlay_mount = (el, _ref) => {\n let {\n event,\n focus = false\n } = _ref;\n handleClick(event, {\n isModal: true,\n container: document.querySelector(el.dataset.togglePanel || el.hash),\n clickOutside: true,\n focus\n });\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"627.js","mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;;ACAA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACvFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://ctFrontend/./static/js/frontend/lazy/overlay/no-bounce.js?0870","webpack://ctFrontend/./static/js/frontend/lazy/overlay/mobile-menu.js?e043","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/array.js?9a7c","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/tabOrder.js?c1fb","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/tabbables.js?82ce","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/constants.js?c429","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/tabUtils.js?f09d","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/DOMutils.js?7cb3","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/firstFocus.js?0da1","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/utils/all-affected.js?4978","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/focusMerge.js?e55a","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/setFocus.js?2116","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/index.js?ca5b","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/focusIsHidden.js?a108","webpack://ctFrontend/./node_modules/focus-lock/dist/es2015/focusInside.js?3064","webpack://ctFrontend/./node_modules/dom-focus-lock/dist/index.esm.js?75ce","webpack://ctFrontend/./static/js/frontend/helpers/focus-lock.js?1008","webpack://ctFrontend/./static/js/frontend/lazy/overlay.js?635e"],"sourcesContent":["import { clearAllBodyScrollLocks, enableBodyScroll, disableBodyScroll } from 'body-scroll-lock';\nconst isIosDevice = typeof window !== 'undefined' && window.navigator && window.navigator.platform && (/iP(ad|hone|od)/.test(window.navigator.platform) || window.navigator.platform === 'MacIntel' && window.navigator.maxTouchPoints > 1);\nexport var enable = function (el) {\n  if (!isIosDevice) {\n    document.body.style.overflow = '';\n    document.body.style.removeProperty('--scrollbar-width');\n  } else {\n    clearAllBodyScrollLocks();\n  }\n};\nexport var disable = function (el) {\n  if (!isIosDevice) {\n    let scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n\n    if (scrollbarWidth > 0) {\n      document.body.style.setProperty('--scrollbar-width', `${scrollbarWidth}px`);\n    }\n\n    document.body.style.overflow = 'hidden';\n  } else {\n    if (el) {\n      disableBodyScroll(el, {\n        // reserveScrollBarGap: true,\n        allowTouchMove: el => {\n          if (el.closest('.select2-container')) {\n            return true;\n          }\n\n          return false;\n        }\n      });\n    }\n  }\n};","const activateSubMenu = container => {\n  const subMenu = container.querySelector('ul');\n  requestAnimationFrame(() => {\n    const actualHeight = subMenu.getBoundingClientRect().height;\n    subMenu.style.height = '0px';\n    subMenu.classList.add('is-animating');\n    requestAnimationFrame(() => {\n      subMenu.style.height = `${actualHeight}px`;\n      whenTransitionEnds(subMenu, () => {\n        subMenu.classList.remove('is-animating');\n        subMenu.removeAttribute('style');\n      });\n    });\n  });\n};\n\nconst deactivateSubMenu = (container, cb) => {\n  const subMenu = container.querySelector('ul');\n  requestAnimationFrame(() => {\n    const actualHeight = subMenu.getBoundingClientRect().height;\n    subMenu.style.height = `${actualHeight}px`;\n    subMenu.classList.add('is-animating');\n    requestAnimationFrame(() => {\n      subMenu.style.height = '0px';\n      whenTransitionEnds(subMenu, () => {\n        subMenu.classList.remove('is-animating');\n        subMenu.removeAttribute('style');\n        cb();\n      });\n    });\n  });\n};\n\nconst handleContainer = container => {\n  if (!container) {\n    return;\n  }\n\n  const arrow = container.querySelector('.ct-toggle-dropdown-mobile');\n\n  if (container.classList.contains('dropdown-active')) {\n    arrow.setAttribute('aria-expanded', 'false');\n    arrow.setAttribute('aria-label', ct_localizations.expand_submenu);\n    deactivateSubMenu(container, () => {\n      container.classList.toggle('dropdown-active');\n      [...container.querySelectorAll('.menu-item-has-children.dropdown-active, .page_item_has_children.dropdown-active')].map(el => el.classList.remove('dropdown-active'));\n    });\n  } else {\n    arrow.setAttribute('aria-expanded', 'true');\n    arrow.setAttribute('aria-label', ct_localizations.collapse_submenu);\n    [...container.parentNode.children].map(el => el.classList.contains('dropdown-active') && handleContainer(el));\n    container.classList.toggle('dropdown-active');\n    activateSubMenu(container);\n  }\n};\n\nexport const mount = arrow => {\n  if (arrow.hasListener) {\n    return;\n  }\n\n  arrow.hasListener = true;\n  let parentHref = arrow.previousElementSibling.getAttribute('href');\n\n  if (!parentHref || parentHref === '#') {\n    arrow.previousElementSibling.addEventListener('click', e => {\n      e.preventDefault();\n      e.stopPropagation();\n      handleContainer(arrow.closest('.menu-item-has-children, .page_item_has_children'));\n    });\n  }\n\n  arrow.addEventListener('click', e => {\n    e.preventDefault();\n    e.stopPropagation();\n    handleContainer(arrow.closest('.menu-item-has-children, .page_item_has_children'));\n  });\n};\n\nfunction whenTransitionEnds(el, cb) {\n  const end = () => {\n    el.removeEventListener('transitionend', onEnd);\n    cb();\n  };\n\n  const onEnd = e => {\n    if (e.target === el) {\n      end();\n    }\n  };\n\n  el.addEventListener('transitionend', onEnd);\n}","export var toArray = function toArray(a) {\n  var ret = Array(a.length);\n  for (var i = 0; i < a.length; ++i) {\n    ret[i] = a[i];\n  }\n  return ret;\n};\n\nexport var arrayFind = function arrayFind(array, search) {\n  return array.filter(function (a) {\n    return a === search;\n  })[0];\n};\n\nexport var asArray = function asArray(a) {\n  return Array.isArray(a) ? a : [a];\n};","import { toArray } from './array';\n\nexport var tabSort = function tabSort(a, b) {\n  var tabDiff = a.tabIndex - b.tabIndex;\n  var indexDiff = a.index - b.index;\n\n  if (tabDiff) {\n    if (!a.tabIndex) return 1;\n    if (!b.tabIndex) return -1;\n  }\n\n  return tabDiff || indexDiff;\n};\n\nexport var orderByTabIndex = function orderByTabIndex(nodes, filterNegative, keepGuards) {\n  return toArray(nodes).map(function (node, index) {\n    return {\n      node: node,\n      index: index,\n      tabIndex: keepGuards && node.tabIndex === -1 ? (node.dataset || {}).focusGuard ? 0 : -1 : node.tabIndex\n    };\n  }).filter(function (data) {\n    return !filterNegative || data.tabIndex >= 0;\n  }).sort(tabSort);\n};","export default ['button:enabled:not([readonly])', 'select:enabled:not([readonly])', 'textarea:enabled:not([readonly])', 'input:enabled:not([readonly])', 'a[href]', 'area[href]', 'iframe', 'object', 'embed', '[tabindex]', '[contenteditable]', '[autofocus]'];","export var FOCUS_GROUP = 'data-focus-lock';\nexport var FOCUS_DISABLED = 'data-focus-lock-disabled';\nexport var FOCUS_ALLOW = 'data-no-focus-lock';\nexport var FOCUS_AUTO = 'data-autofocus-inside';","import tabbables from './tabbables';\nimport { toArray } from './array';\nimport { FOCUS_AUTO } from '../constants';\n\nvar queryTabbables = tabbables.join(',');\nvar queryGuardTabbables = queryTabbables + ', [data-focus-guard]';\n\nexport var getFocusables = function getFocusables(parents, withGuards) {\n  return parents.reduce(function (acc, parent) {\n    return acc.concat(\n    // add all tabbables inside\n    toArray(parent.querySelectorAll(withGuards ? queryGuardTabbables : queryTabbables)),\n    // add if node is tabble itself\n    parent.parentNode ? toArray(parent.parentNode.querySelectorAll(tabbables.join(','))).filter(function (node) {\n      return node === parent;\n    }) : []);\n  }, []);\n};\n\nexport var getParentAutofocusables = function getParentAutofocusables(parent) {\n  var parentFocus = parent.querySelectorAll('[' + FOCUS_AUTO + ']');\n  return toArray(parentFocus).map(function (node) {\n    return getFocusables([node]);\n  }).reduce(function (acc, nodes) {\n    return acc.concat(nodes);\n  }, []);\n};","import { orderByTabIndex } from './tabOrder';\nimport { getFocusables, getParentAutofocusables } from './tabUtils';\nimport { toArray } from './array';\n\nvar isElementHidden = function isElementHidden(computedStyle) {\n  if (!computedStyle || !computedStyle.getPropertyValue) {\n    return false;\n  }\n  return computedStyle.getPropertyValue('display') === 'none' || computedStyle.getPropertyValue('visibility') === 'hidden';\n};\n\nexport var isVisible = function isVisible(node) {\n  return !node || node === document || node.nodeType === Node.DOCUMENT_NODE || !isElementHidden(window.getComputedStyle(node, null)) && isVisible(node.parentNode);\n};\n\nexport var notHiddenInput = function notHiddenInput(node) {\n  return !((node.tagName === 'INPUT' || node.tagName === 'BUTTON') && (node.type === 'hidden' || node.disabled));\n};\n\nvar getParents = function getParents(node) {\n  var parents = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n\n  parents.push(node);\n  if (node.parentNode) {\n    getParents(node.parentNode, parents);\n  }\n  return parents;\n};\n\nexport var getCommonParent = function getCommonParent(nodea, nodeb) {\n  var parentsA = getParents(nodea);\n  var parentsB = getParents(nodeb);\n\n  for (var i = 0; i < parentsA.length; i += 1) {\n    var currentParent = parentsA[i];\n    if (parentsB.indexOf(currentParent) >= 0) {\n      return currentParent;\n    }\n  }\n  return false;\n};\n\nexport var filterFocusable = function filterFocusable(nodes) {\n  return toArray(nodes).filter(function (node) {\n    return isVisible(node);\n  }).filter(function (node) {\n    return notHiddenInput(node);\n  });\n};\n\nexport var getTabbableNodes = function getTabbableNodes(topNodes, withGuards) {\n  return orderByTabIndex(filterFocusable(getFocusables(topNodes, withGuards)), true, withGuards);\n};\n\nexport var getAllTabbableNodes = function getAllTabbableNodes(topNodes) {\n  return orderByTabIndex(filterFocusable(getFocusables(topNodes)), false);\n};\n\nexport var parentAutofocusables = function parentAutofocusables(topNode) {\n  return filterFocusable(getParentAutofocusables(topNode));\n};","var isRadio = function isRadio(node) {\n  return node.tagName === 'INPUT' && node.type === 'radio';\n};\n\nvar findSelectedRadio = function findSelectedRadio(node, nodes) {\n  return nodes.filter(isRadio).filter(function (el) {\n    return el.name === node.name;\n  }).filter(function (el) {\n    return el.checked;\n  })[0] || node;\n};\n\nvar pickFirstFocus = function pickFirstFocus(nodes) {\n  if (nodes[0] && nodes.length > 1) {\n    if (isRadio(nodes[0]) && nodes[0].name) {\n      return findSelectedRadio(nodes[0], nodes);\n    }\n  }\n  return nodes[0];\n};\n\nexport var pickFocusable = function pickFocusable(nodes, index) {\n  if (nodes.length > 1) {\n    if (isRadio(nodes[index]) && nodes[index].name) {\n      return nodes.indexOf(findSelectedRadio(nodes[index], nodes));\n    }\n  }\n  return index;\n};\n\nexport default pickFirstFocus;","var _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nimport { FOCUS_DISABLED, FOCUS_GROUP } from '../constants';\nimport { asArray, toArray } from './array';\n\nvar filterNested = function filterNested(nodes) {\n  var l = nodes.length;\n  for (var i = 0; i < l; i += 1) {\n    var _loop = function _loop(j) {\n      if (i !== j) {\n        if (nodes[i].contains(nodes[j])) {\n          return {\n            v: filterNested(nodes.filter(function (x) {\n              return x !== nodes[j];\n            }))\n          };\n        }\n      }\n    };\n\n    for (var j = 0; j < l; j += 1) {\n      var _ret = _loop(j);\n\n      if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === \"object\") return _ret.v;\n    }\n  }\n  return nodes;\n};\n\nvar getTopParent = function getTopParent(node) {\n  return node.parentNode ? getTopParent(node.parentNode) : node;\n};\n\nvar getAllAffectedNodes = function getAllAffectedNodes(node) {\n  var nodes = asArray(node);\n  return nodes.filter(Boolean).reduce(function (acc, currentNode) {\n    var group = currentNode.getAttribute(FOCUS_GROUP);\n    acc.push.apply(acc, group ? filterNested(toArray(getTopParent(currentNode).querySelectorAll('[' + FOCUS_GROUP + '=\"' + group + '\"]:not([' + FOCUS_DISABLED + '=\"disabled\"])'))) : [currentNode]);\n    return acc;\n  }, []);\n};\n\nexport default getAllAffectedNodes;","import { getCommonParent, getTabbableNodes, getAllTabbableNodes, parentAutofocusables } from './utils/DOMutils';\nimport pickFirstFocus, { pickFocusable } from './utils/firstFocus';\nimport getAllAffectedNodes from './utils/all-affected';\nimport { asArray } from './utils/array';\n\nvar findAutoFocused = function findAutoFocused(autoFocusables) {\n  return function (node) {\n    return !!node.autofocus || node.dataset && !!node.dataset.autofocus || autoFocusables.indexOf(node) >= 0;\n  };\n};\n\nvar isGuard = function isGuard(node) {\n  return node && node.dataset && node.dataset.focusGuard;\n};\nvar notAGuard = function notAGuard(node) {\n  return !isGuard(node);\n};\n\nexport var newFocus = function newFocus(innerNodes, outerNodes, activeElement, lastNode, autoFocused) {\n  var cnt = innerNodes.length;\n  var firstFocus = innerNodes[0];\n  var lastFocus = innerNodes[cnt - 1];\n  var isOnGuard = isGuard(activeElement);\n\n  // focus is inside\n  if (innerNodes.indexOf(activeElement) >= 0) {\n    return undefined;\n  }\n\n  var activeIndex = outerNodes.indexOf(activeElement);\n  var lastIndex = outerNodes.indexOf(lastNode || activeIndex);\n  var lastNodeInside = innerNodes.indexOf(lastNode);\n  var indexDiff = activeIndex - lastIndex;\n  var firstNodeIndex = outerNodes.indexOf(firstFocus);\n  var lastNodeIndex = outerNodes.indexOf(lastFocus);\n\n  var returnFirstNode = pickFocusable(innerNodes, 0);\n  var returnLastNode = pickFocusable(innerNodes, cnt - 1);\n\n  // new focus\n  if (activeIndex === -1 || lastNodeInside === -1) {\n    return innerNodes.indexOf(autoFocused && autoFocused.length ? pickFirstFocus(autoFocused) : pickFirstFocus(innerNodes));\n  }\n  // old focus\n  if (!indexDiff && lastNodeInside >= 0) {\n    return lastNodeInside;\n  }\n  // first element\n  if (activeIndex <= firstNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n    return returnLastNode;\n  }\n  // last element\n  if (activeIndex >= firstNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n    return returnFirstNode;\n  }\n  // jump out, but not on the guard\n  if (indexDiff && Math.abs(indexDiff) > 1) {\n    return lastNodeInside;\n  }\n  // focus above lock\n  if (activeIndex <= firstNodeIndex) {\n    return returnLastNode;\n  }\n  // focus below lock\n  if (activeIndex > lastNodeIndex) {\n    return returnFirstNode;\n  }\n  // index is inside tab order, but outside Lock\n  if (indexDiff) {\n    if (Math.abs(indexDiff) > 1) {\n      return lastNodeInside;\n    }\n    return (cnt + lastNodeInside + indexDiff) % cnt;\n  }\n  // do nothing\n  return undefined;\n};\n\nvar getTopCommonParent = function getTopCommonParent(baseActiveElement, leftEntry, rightEntries) {\n  var activeElements = asArray(baseActiveElement);\n  var leftEntries = asArray(leftEntry);\n  var activeElement = activeElements[0];\n  var topCommon = null;\n  leftEntries.filter(Boolean).forEach(function (entry) {\n    topCommon = getCommonParent(topCommon || entry, entry) || topCommon;\n    rightEntries.filter(Boolean).forEach(function (subEntry) {\n      var common = getCommonParent(activeElement, subEntry);\n      if (common) {\n        if (!topCommon || common.contains(topCommon)) {\n          topCommon = common;\n        } else {\n          topCommon = getCommonParent(common, topCommon);\n        }\n      }\n    });\n  });\n  return topCommon;\n};\n\nvar allParentAutofocusables = function allParentAutofocusables(entries) {\n  return entries.reduce(function (acc, node) {\n    return acc.concat(parentAutofocusables(node));\n  }, []);\n};\n\nvar reorderNodes = function reorderNodes(srcNodes, dstNodes) {\n  var remap = new Map();\n  // no Set(dstNodes) for IE11 :(\n  dstNodes.forEach(function (entity) {\n    return remap.set(entity.node, entity);\n  });\n  // remap to dstNodes\n  return srcNodes.map(function (node) {\n    return remap.get(node);\n  }).filter(Boolean);\n};\n\nexport var getFocusabledIn = function getFocusabledIn(topNode) {\n  var entries = getAllAffectedNodes(topNode).filter(notAGuard);\n  var commonParent = getTopCommonParent(topNode, topNode, entries);\n  var outerNodes = getTabbableNodes([commonParent], true);\n  var innerElements = getTabbableNodes(entries).filter(function (_ref) {\n    var node = _ref.node;\n    return notAGuard(node);\n  }).map(function (_ref2) {\n    var node = _ref2.node;\n    return node;\n  });\n\n  return outerNodes.map(function (_ref3) {\n    var node = _ref3.node,\n        index = _ref3.index;\n    return {\n      node: node,\n      index: index,\n      lockItem: innerElements.indexOf(node) >= 0,\n      guard: isGuard(node)\n    };\n  });\n};\n\nvar getFocusMerge = function getFocusMerge(topNode, lastNode) {\n  var activeElement = document && document.activeElement;\n  var entries = getAllAffectedNodes(topNode).filter(notAGuard);\n\n  var commonParent = getTopCommonParent(activeElement || topNode, topNode, entries);\n\n  var innerElements = getTabbableNodes(entries).filter(function (_ref4) {\n    var node = _ref4.node;\n    return notAGuard(node);\n  });\n\n  if (!innerElements[0]) {\n    innerElements = getAllTabbableNodes(entries).filter(function (_ref5) {\n      var node = _ref5.node;\n      return notAGuard(node);\n    });\n    if (!innerElements[0]) {\n      return undefined;\n    }\n  }\n\n  var outerNodes = getTabbableNodes([commonParent]).map(function (_ref6) {\n    var node = _ref6.node;\n    return node;\n  });\n  var orderedInnerElements = reorderNodes(outerNodes, innerElements);\n  var innerNodes = orderedInnerElements.map(function (_ref7) {\n    var node = _ref7.node;\n    return node;\n  });\n\n  var newId = newFocus(innerNodes, outerNodes, activeElement, lastNode, innerNodes.filter(findAutoFocused(allParentAutofocusables(entries))));\n\n  if (newId === undefined) {\n    return newId;\n  }\n  return orderedInnerElements[newId];\n};\n\nexport default getFocusMerge;","import getFocusMerge from './focusMerge';\n\nexport var focusOn = function focusOn(target) {\n  target.focus();\n  if (target.contentWindow) {\n    target.contentWindow.focus();\n  }\n};\n\nvar guardCount = 0;\nvar lockDisabled = false;\n\nexport default (function (topNode, lastNode) {\n  var focusable = getFocusMerge(topNode, lastNode);\n\n  if (lockDisabled) {\n    return;\n  }\n\n  if (focusable) {\n    if (guardCount > 2) {\n      // eslint-disable-next-line no-console\n      console.error('FocusLock: focus-fighting detected. Only one focus management system could be active. ' + 'See https://github.com/theKashey/focus-lock/#focus-fighting');\n      lockDisabled = true;\n      setTimeout(function () {\n        lockDisabled = false;\n      }, 1);\n      return;\n    }\n    guardCount++;\n    focusOn(focusable.node);\n    guardCount--;\n  }\n});","import tabHook from './tabHook';\nimport focusMerge, { getFocusabledIn } from './focusMerge';\nimport focusInside from './focusInside';\nimport focusIsHidden from './focusIsHidden';\nimport setFocus from './setFocus';\nimport * as constants from './constants';\nimport getAllAffectedNodes from './utils/all-affected';\n\nexport { tabHook, focusInside, focusIsHidden, focusMerge, getFocusabledIn, constants, getAllAffectedNodes };\n\nexport default setFocus;","import { toArray } from './utils/array';\nimport { FOCUS_ALLOW } from './constants';\n\nvar focusIsHidden = function focusIsHidden() {\n  return document && toArray(document.querySelectorAll('[' + FOCUS_ALLOW + ']')).some(function (node) {\n    return node.contains(document.activeElement);\n  });\n};\n\nexport default focusIsHidden;","import getAllAffectedNodes from './utils/all-affected';\nimport { arrayFind, toArray } from './utils/array';\n\nvar focusInFrame = function focusInFrame(frame) {\n  return frame === document.activeElement;\n};\n\nvar focusInsideIframe = function focusInsideIframe(topNode) {\n  return !!arrayFind(toArray(topNode.querySelectorAll('iframe')), focusInFrame);\n};\n\nvar focusInside = function focusInside(topNode) {\n  var activeElement = document && document.activeElement;\n\n  if (!activeElement || activeElement.dataset && activeElement.dataset.focusGuard) {\n    return false;\n  }\n  return getAllAffectedNodes(topNode).reduce(function (result, node) {\n    return result || node.contains(activeElement) || focusInsideIframe(node);\n  }, false);\n};\n\nexport default focusInside;","import moveFocusInside, { focusIsHidden, focusInside } from 'focus-lock';\n\nvar lastActiveTrap = 0;\nvar lastActiveFocus = null;\n\nvar focusOnBody = function focusOnBody() {\n  return document && document.activeElement === document.body;\n};\n\nvar isFreeFocus = function isFreeFocus() {\n  return focusOnBody() || focusIsHidden();\n};\n\nvar activateTrap = function activateTrap() {\n  var result = false;\n\n  if (lastActiveTrap) {\n    var observed = lastActiveTrap;\n\n    if (!isFreeFocus()) {\n      if (observed && !focusInside(observed)) {\n        result = moveFocusInside(observed, lastActiveFocus);\n      }\n\n      lastActiveFocus = document.activeElement;\n    }\n  }\n\n  return result;\n};\n\nvar reducePropsToState = function reducePropsToState(propsList) {\n  return propsList.filter(function (node) {\n    return node;\n  }).slice(-1)[0];\n};\n\nvar handleStateChangeOnClient = function handleStateChangeOnClient(trap) {\n  lastActiveTrap = trap;\n\n  if (trap) {\n    activateTrap();\n  }\n};\n\nvar instances = [];\n\nvar emitChange = function emitChange(event) {\n  if (handleStateChangeOnClient(reducePropsToState(instances))) {\n    event && event.preventDefault();\n    return true;\n  }\n\n  return false;\n};\n\nvar attachHandler = function attachHandler() {\n  document.addEventListener('focusin', emitChange);\n};\n\nvar detachHandler = function detachHandler() {\n  document.removeEventListener('focusin', emitChange);\n};\n\nvar focusLock = {\n  on: function on(domNode) {\n    if (instances.length === 0) {\n      attachHandler();\n    }\n\n    if (instances.indexOf(domNode) < 0) {\n      instances.push(domNode);\n      emitChange();\n    }\n  },\n  off: function off(domNode) {\n    instances = instances.filter(function (node) {\n      return node !== domNode;\n    });\n    emitChange();\n\n    if (instances.length === 0) {\n      detachHandler();\n    }\n  }\n};\n\nexport default focusLock;\n","import focusLock from 'dom-focus-lock';\nimport { isTouchDevice } from './is-touch-device';\nexport const focusLockOn = container => {\n  let focusLockToUse = focusLock;\n\n  if (window.ctFrontend && window.ctFrontend.focusLock) {\n    focusLockToUse = ctFrontend.focusLock;\n  } else {\n    window.ctFrontend = window.ctFrontend || {};\n    window.ctFrontend.focusLock = focusLockToUse;\n  }\n\n  focusLockToUse.on(container);\n};\nexport const focusLockOff = container => {\n  let focusLockToUse = focusLock;\n\n  if (window.ctFrontend && window.ctFrontend.focusLock) {\n    focusLockToUse = ctFrontend.focusLock;\n  } else {\n    window.ctFrontend = window.ctFrontend || {};\n    window.ctFrontend.focusLock = focusLockToUse;\n  }\n\n  focusLockToUse.off(container);\n};","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { enable, disable } from './overlay/no-bounce';\nimport ctEvents from 'ct-events';\nimport { mount as mountMobileMenu } from './overlay/mobile-menu';\nimport { focusLockOn, focusLockOff } from '../helpers/focus-lock';\n\nconst showOffcanvas = settings => {\n  settings = _objectSpread({\n    onClose: () => {},\n    container: null,\n    focus: true\n  }, settings);\n  [...document.querySelectorAll(`[data-toggle-panel*=\"${settings.container.id}\"]`), ...document.querySelectorAll(`[href*=\"${settings.container.id}\"]`)].map(trigger => {\n    trigger.setAttribute('aria-expanded', 'true');\n  });\n\n  if (settings.focus) {\n    setTimeout(() => {\n      settings.container.querySelector('input') && settings.container.querySelector('input').focus();\n    }, 200);\n  }\n\n  if (settings.container.querySelector('.ct-panel-content')) {\n    settings.container.querySelector('.ct-panel-content').addEventListener('click', event => {\n      Array.from(settings.container.querySelectorAll('select')).map(select => select.selectr && select.selectr.events.dismiss(event));\n    });\n  }\n\n  if (settings.clickOutside && settings.container.querySelector('.ct-panel-content')) {\n    settings.container.addEventListener('click', settings.handleContainerClick);\n  }\n\n  const onKeyUp = event => {\n    const {\n      keyCode,\n      target\n    } = event;\n    if (keyCode !== 27) return;\n    event.preventDefault();\n    document.body.hasAttribute('data-panel') && hideOffcanvas(settings);\n    document.removeEventListener('keyup', onKeyUp);\n  };\n\n  document.addEventListener('keyup', onKeyUp);\n  let maybeCloseButton = settings.container && settings.container.querySelector('.ct-toggle-close');\n\n  if (maybeCloseButton) {\n    maybeCloseButton.addEventListener('click', event => {\n      event.preventDefault();\n      hideOffcanvas(settings);\n    }, {\n      once: true\n    });\n\n    if (!maybeCloseButton.hasEnterListener) {\n      maybeCloseButton.hasEnterListener = true;\n      maybeCloseButton.addEventListener('keyup', e => {\n        if (13 == e.keyCode) {\n          e.preventDefault();\n          hideOffcanvas(settings);\n        }\n      });\n    }\n  }\n\n  if (settings.computeScrollContainer || settings.container.querySelector('.ct-panel-content')) {\n    disable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n    setTimeout(() => {\n      focusLockOn(settings.container.querySelector('.ct-panel-content').parentNode);\n    });\n  }\n  /**\n   * Add window event listener in the next frame. This allows us to freely\n   * propagate the current clck event up the chain -- without the modal\n   * getting closed.\n   */\n\n\n  window.addEventListener('click', settings.handleWindowClick, {\n    capture: true\n  });\n  ctEvents.trigger('ct:modal:opened', settings.container);\n  [...settings.container.querySelectorAll('.ct-toggle-dropdown-mobile')].map(arrow => {\n    mountMobileMenu(arrow);\n  });\n};\n\nconst hideOffcanvas = function (settings) {\n  let args = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n  settings = _objectSpread({\n    onClose: () => {},\n    container: null\n  }, settings);\n  args = _objectSpread({\n    closeInstant: false\n  }, args);\n\n  if (!document.body.hasAttribute('data-panel')) {\n    settings.container.classList.remove('active');\n    settings.onClose();\n    return;\n  }\n\n  ;\n  [...document.querySelectorAll(`[data-toggle-panel*=\"${settings.container.id}\"]`), ...document.querySelectorAll(`[href*=\"${settings.container.id}\"]`)].map(trigger => {\n    trigger.setAttribute('aria-expanded', 'false');\n  });\n  settings.container.classList.remove('active');\n\n  if (args.closeInstant) {\n    document.body.removeAttribute('data-panel');\n    ctEvents.trigger('ct:modal:closed', settings.container);\n    enable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n  } else {\n    document.body.dataset.panel = `out`;\n    settings.container.addEventListener('transitionend', () => {\n      setTimeout(() => {\n        document.body.removeAttribute('data-panel');\n        ctEvents.trigger('ct:modal:closed', settings.container);\n        enable(settings.computeScrollContainer ? settings.computeScrollContainer() : settings.container.querySelector('.ct-panel-content'));\n        focusLockOff(settings.container.querySelector('.ct-panel-content').parentNode);\n      }, 300);\n    }, {\n      once: true\n    });\n  }\n\n  window.removeEventListener('click', settings.handleWindowClick, {\n    capture: true\n  });\n  settings.container.removeEventListener('click', settings.handleContainerClick);\n  settings.onClose();\n};\n\nexport const handleClick = (e, settings) => {\n  if (e && e.preventDefault) {\n    e.preventDefault();\n  }\n\n  settings = _objectSpread({\n    onClose: () => {},\n    container: null,\n    focus: false,\n    clickOutside: true,\n    isModal: false,\n    computeScrollContainer: null,\n    closeWhenLinkInside: false,\n    handleContainerClick: event => {\n      let isInsidePanelContent = event.target.closest('.ct-panel-content');\n      let isPanelContentItself = [...settings.container.querySelectorAll('.ct-panel-content')].indexOf(event.target) > -1;\n\n      if (settings.isModal && !isPanelContentItself && isInsidePanelContent || !settings.isModal && (isPanelContentItself || isInsidePanelContent) || event.target.closest('[class*=\"select2-container\"]')) {\n        return;\n      }\n\n      if (window.getSelection().toString().length > 0) {\n        return;\n      }\n\n      document.body.hasAttribute('data-panel') && hideOffcanvas(settings);\n    },\n    handleWindowClick: e => {\n      if (settings.container.contains(e.target) || e.target === document.body || event.target.closest('[class*=\"select2-container\"]')) {\n        return;\n      }\n\n      if (!document.body.hasAttribute('data-panel')) {\n        return;\n      }\n\n      hideOffcanvas(settings);\n    }\n  }, settings);\n  showOffcanvas(settings);\n  /*\n  if (document.body.hasAttribute('data-panel')) {\n  \tif (\n  \t\tsettings.isModal &&\n  \t\t!settings.container.classList.contains('active')\n  \t) {\n  \t\tconst menuToggle = document.querySelector('.ct-header-trigger')\n  \t\t\tif (menuToggle) {\n  \t\t\tmenuToggle.click()\n  \t\t}\n  \t\t\tsetTimeout(() => {\n  \t\t\tshowOffcanvas(settings)\n  \t\t}, 600)\n  \t} else {\n  \t\thideOffcanvas(settings)\n  \t}\n  } else {\n  \tshowOffcanvas(settings)\n  }\n  */\n\n  if (settings.closeWhenLinkInside) {\n    if (!settings.container.hasListener) {\n      settings.container.hasListener = true;\n      settings.container.addEventListener('click', event => {\n        if (!event.target) {\n          return;\n        }\n\n        let maybeA = event.target;\n\n        if (event.target.closest('a')) {\n          maybeA = event.target.closest('a');\n        }\n\n        if (!maybeA.closest('.ct-panel').classList.contains('active')) {\n          return;\n        }\n\n        if (!maybeA.matches('a')) {\n          return;\n        }\n\n        if (!maybeA.closest('nav[data-id*=\"menu\"]') && !maybeA.closest('[data-id*=\"text\"]') && !maybeA.closest('[data-id*=\"button\"]') && !maybeA.matches('.ct-offcanvas-trigger') && !maybeA.matches('.ct-header-account') && !maybeA.closest('.widget_nav_menu')) {\n          return;\n        }\n\n        hideOffcanvas(settings, {\n          closeInstant: maybeA.getAttribute('href')[0] !== '#'\n        });\n        setTimeout(() => {\n          if (maybeA.matches('.ct-offcanvas-trigger') || maybeA.matches('.ct-header-account')) {\n            maybeA.click();\n          }\n        }, 500);\n      });\n    }\n  }\n};\nctEvents.on('ct:offcanvas:force-close', settings => hideOffcanvas(settings));\nexport const mount = (el, _ref) => {\n  let {\n    event,\n    focus = false\n  } = _ref;\n  handleClick(event, {\n    isModal: true,\n    container: document.querySelector(el.dataset.togglePanel || el.hash),\n    clickOutside: true,\n    focus\n  });\n};"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///627\n")},891:function(module,exports){eval('var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;!function(e,t){if(true)!(__WEBPACK_AMD_DEFINE_ARRAY__ = [exports], __WEBPACK_AMD_DEFINE_FACTORY__ = (t),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === \'function\' ?\n\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));else { var o; }}(this,function(exports){"use strict";function i(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);t