{"version":3,"mappings":"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","names":["isObject","obj","extend","target","src","key","ssrDocument","getDocument","doc","ssrWindow","callback","id","getWindow","win","makeReactive","proto","value","Dom7","items","arrayFlat","arr","res","el","arrayFilter","arrayUnique","uniqueArray","i","qsa","selector","context","a","$","window","document","html","toCreate","tempParent","addClass","classes","classNames","c","removeClass","toggleClass","className","hasClass","attr","attrs","attrName","removeAttr","transform","transition","duration","on","args","eventType","targetSelector","listener","capture","handleLiveEvent","e","eventData","parents","k","handleEvent","events","j","event","off","handlers","handler","trigger","evt","data","dataIndex","transitionEnd","dom","fireCallBack","outerWidth","includeMargins","styles","outerHeight","offset","box","body","clientTop","clientLeft","scrollTop","scrollLeft","css","props","prop","each","index","filter","result","text","is","compareWith","child","eq","length","returnIndex","append","els","newChild","tempDiv","prepend","next","nextAll","nextEls","prev","prevAll","prevEls","parent","closest","find","foundElements","found","children","childNodes","remove","Methods","methodName","deleteProps","object","nextTick","delay","now","getComputedStyle","style","getTranslate","axis","matrix","curTransform","transformMatrix","curStyle","o","isNode","node","to","noExtend","nextSource","keysArray","nextIndex","len","nextKey","desc","setCSSProperty","varName","varValue","animateCSSModeScroll","startPosition","swiper","startTime","time","dir","targetPosition","isOutOfBound","current","animate","progress","easeProgress","currentPosition","side","support","calcSupport","supportsPassive","opts","getSupport","deviceCached","calcDevice","platform","ua","userAgent","device","screenWidth","screenHeight","android","ipad","ipod","iphone","windows","macos","iPadScreens","getDevice","overrides","browser","calcBrowser","isSafari","getBrowser","Resize","observer","animationFrame","resizeHandler","emit","createObserver","entries","newWidth","width","newHeight","height","contentRect","contentBoxSize","removeObserver","orientationChangeHandler","Observer","observers","attach","options","ObserverFunc","mutations","observerUpdate","init","containerParents","destroy","extendParams","eventsEmitter","priority","self","method","onceHandler","eventHandler","updateSize","$el","updateSlides","getDirectionLabel","property","getDirectionPropertyValue","label","params","swiperSize","rtl","isVirtual","previousSlidesLength","slides","$wrapperEl","slidesLength","snapGrid","slidesGrid","slidesSizesGrid","offsetBefore","offsetAfter","previousSnapGridLength","previousSlidesGridLength","spaceBetween","slidePosition","prevSlideSize","gridEnabled","slideSize","shouldResetSlideSize","slide","slideStyles","currentTransform","currentWebKitTransform","paddingLeft","paddingRight","marginLeft","marginRight","boxSizing","offsetWidth","clientWidth","wrongRTL","newSlidesGrid","slidesGridItem","_","slideIndex","allSlidesSize","slideSizeValue","maxSnap","snap","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","v","backFaceHiddenClass","hasClassBackfaceClassAdded","updateAutoHeight","speed","activeSlides","getSlideByIndex","updateSlidesOffset","updateSlidesProgress","translate","offsetCenter","slideOffset","slideProgress","originalSlideProgress","slideBefore","slideAfter","updateProgress","multiplier","translatesDiff","wasBeginning","isBeginning","wasEnd","isEnd","updateSlidesClasses","activeSlide","activeIndex","realIndex","nextSlide","prevSlide","updateActiveIndex","newActiveIndex","previousIndex","previousRealIndex","previousSnapIndex","skip","updateClickedSlide","slideFound","update","getSwiperTranslate","currentTranslate","setTranslate","byController","x","y","z","wrapperEl","newProgress","minTranslate","maxTranslate","translateTo","runCallbacks","translateBounds","internal","newTranslate","isH","setTransition","transitionEmit","direction","step","transitionStart","slideTo","initial","indexAsNumber","enabled","normalizedTranslate","normalizedGrid","normalizedGridNext","t","slideToLoop","newIndex","slideNext","perGroup","increment","animating","slidePrev","rtlTranslate","normalize","val","normalizedSnapGrid","prevSnap","prevSnapIndex","prevIndex","lastIndex","slideReset","slideToClosest","threshold","currentSnap","nextSnap","slideToClickedSlide","slidesPerView","slideToIndex","loopCreate","$selector","blankSlidesNum","blankNode","prependSlides","appendSlides","loopFix","diff","loopedSlides","allowSlidePrev","allowSlideNext","loopDestroy","loop","setGrabCursor","moving","unsetGrabCursor","grabCursor","closestElement","base","__closestFrom","onTouchStart","$targetEl","swipingClassHasValue","eventPath","noSwipingSelector","isTargetShadow","touches","startX","startY","edgeSwipeDetection","edgeSwipeThreshold","preventDefault","shouldPreventDefault","onTouchMove","targetTouch","pageX","pageY","diffX","diffY","touchAngle","disableParentSwiper","resistanceRatio","onTouchEnd","touchEndTime","timeDiff","pathTree","currentPos","stopIndex","groupSize","rewindFirstIndex","rewindLastIndex","ratio","onResize","onClick","onScroll","dummyEventAttached","dummyEventListener","domMethod","swiperMethod","touchEvents","passiveListener","attachEvents","detachEvents","events$1","isGridEnabled","setBreakpoint","breakpoints","breakpoint","breakpointParams","wasMultiRow","isMultiRow","wasEnabled","wasModuleEnabled","isModuleEnabled","directionChanged","needsReLoop","initialized","isEnabled","getBreakpoint","containerEl","currentHeight","points","point","minRatio","b","prepareClasses","prefix","resultClasses","item","addClasses","suffixes","removeClasses","loadImage","imageEl","srcset","sizes","checkForComplete","image","onReady","preloadImages","images","checkOverflow","wasLocked","slidesOffsetBefore","lastSlideIndex","lastSlideRightEdge","checkOverflow$1","defaults","moduleExtendParams","allModulesParams","moduleParamName","moduleParams","prototypes","extendedDefaults","Swiper","swipers","newParams","mod","swiperParams","eventName","touch","desktop","min","cls","slideEl","updates","view","exact","spv","breakLoop","translateValue","translated","newDirection","needUpdate","currentDirection","getWrapperSelector","wrapper","deleteInstance","cleanStyles","newDefaults","modules","module","m","prototypeGroup","protoMethod","createElementIfNotDefined","originalParams","checkProps","element","Navigation","getEl","toggleEl","disabled","$prevEl","$nextEl","onPrevClick","onNextClick","disable","_s","targetEl","isHidden","enable","classesToSelector","Pagination","pfx","number","bulletSize","dynamicBulletIndex","isPaginationDisabled","setSideBullets","$bulletEl","position","bulletActiveClass","total","bullets","firstIndex","midIndex","suffix","bullet","$bullet","bulletIndex","$firstDisplayedBullet","$lastDisplayedBullet","dynamicBulletsLength","bulletsOffset","offsetProp","progressbarDirection","scale","scaleX","scaleY","render","paginationHTML","numberOfBullets","Lazy","scrollHandlerAttached","initialImageLoaded","loadInSlide","loadInDuplicate","$slideEl","$images","$imageEl","background","$pictureEl","sourceEl","$source","slideOriginalIndex","originalSlide","duplicatedSlide","load","slideExist","amount","maxIndex","minIndex","checkInViewOnLoad","$scrollElement","isWindow","scrollElementWidth","scrollElementHeight","swiperOffset","inView","swiperCoord","lazy","cssMode","watchSlidesProgress","touchReleaseOnEdges","A11y","liveRegion","notify","message","notification","getRandomNumber","size","randomChar","makeElFocusable","makeElNotFocusable","addElRole","role","addElRoleDescription","description","addElControls","controls","addElLabel","addElId","addElLive","live","disableEl","enableEl","onEnterOrSpaceKey","updateNavigation","hasPagination","hasClickablePagination","updatePagination","bulletEl","initNavEl","wrapperId","handlePointerDown","handlePointerUp","handleFocus","isActive","isVisible","initSlides","ariaLabelMessage","$containerEl","Autoplay","timeout","run","$activeSlideEl","autoplayResult","stop","start","pause","onTransitionEnd","onVisibilityChange","onMouseEnter","onMouseLeave","attachMouseEvents","detachMouseEvents","ref","pagination","slider","navNext","navPrev","hasSale","product","originalPrice","price","AttributeVisibility","ProductType","variant","configurableAttributes","attributes","internalName","_a","sortAttributeValueList","attributeValues","getValue","numberSizes","internationalClothingSizes","otherSizes","INTERNATIONAL_CLOTHING_SIZE_WEIGHTS","sortNumberSizes","sortInternationalProductSizes","formatToString","bWeight","_b","aWeight","valA","formatSizeNumber","valB","bFloat","aFloat","loading","formatConfigurableAttributes","onMounted","attribute","emitEvent","EventProductClick","p","variantAttributes","lazyLoadUpdate","_imports_0","_imports_1","_imports_2","_imports_3","_imports_4","_imports_5","_imports_6","_imports_7","isOpen","uuidv4","collapse","collapseInner","inject","watch","newValue","toggle","openElement","setOpenElement","beforeEnter","enter","afterEnter","beforeLeave","leave","afterLeave","defaultConfig","VueCookiesManager","config","propertyName","keyName","expireTimes","path","domain","secure","sameSite","_expires","_expireTime","_keys","_index","GLOBAL_COOKIES_MANAGER","useCookies","cookies","reactive","defineStore","recaptchaSiteKey","siteKey","script","isLoaded","isReady","actionName","newsletterTranslation","cookieApi","errorMessage","form","newsletterCookieKey","subscribedToNewsletter","recaptcha","useRecaptchaStore","loadRecaptcha","$event","submitForm","recapthcaToken","getSerializedFormData","serializedFormData","resp","defaultErrorMessage","formElement","formDataRecord","isClosed","hashTopNotificationContent","hash","closeNotification","topNotificaton","content","_c","_d","chr","useCollectionFilters","isMobileFiltersOpen","allfilterOptions","isChanged","searchTerm","collection","filters","loaded","currentUrl","setSearchTerm","setCollection","getActiveFilters","activeFilters","activeOptions","option","toggleMobileFilters","getUrlForFilters","routeParameters","currentKeys","getReplacedUrl","replacements","collectionParam","term","resetFilter","collectionFiltersStore","filtersOpen","toggleFilters","toggleOption","url","color","name","expandHexColor","r","g","luma","hexCode","hexValue","collectionFilterStore","candidateSelectors","candidateSelector","NoElement","matches","getRootNode","getCandidates","includeContainer","candidates","getCandidatesIteratively","elements","elementsToCheck","assigned","nestedCandidates","validCandidate","shadowRoot","validShadowRoot","_nestedCandidates","getTabindex","isScope","sortOrderedTabbables","isInput","isHiddenInput","isDetailsWithSummary","getCheckedRadio","nodes","isTabbableRadio","radioScope","queryRadios","radioSet","err","checked","isRadio","isNonTabbableRadio","isZeroArea","_node$getBoundingClie","_ref","displayCheck","getShadowRoot","isDirectSummary","nodeUnderDetails","nodeRootHost","nodeIsAttached","originalNode","parentElement","rootNode","isDisabledFromFieldset","parentNode","isNodeMatchingSelectorFocusable","isNodeMatchingSelectorTabbable","isValidShadowRootTabbable","shadowHostNode","tabIndex","sortByOrder","regularTabbables","orderedTabbables","candidateTabindex","acc","sortable","tabbable","focusable","isTabbable","focusableCandidateSelector","isFocusable","ownKeys","enumerableOnly","keys","symbols","sym","_objectSpread2","source","_defineProperty","activeFocusTraps","trapQueue","trap","activeTrap","trapIndex","isSelectableInput","isEscapeEvent","isTabEvent","fn","findIndex","idx","valueOrHandler","_len","_key","getActualTarget","createFocusTrap","userOptions","state","getOption","configOverrideOptions","optionName","configOptionName","findContainerIndex","container","tabbableNodes","getNodeForOption","optionValue","_len2","_key2","getInitialFocusNode","firstTabbableGroup","firstTabbableNode","updateTabbableNodes","focusableNodes","forward","nodeIdx","n","group","tryFocus","getReturnFocusNode","previousActiveElement","checkPointerDown","checkFocusIn","targetContained","checkTab","destinationNode","containerIndex","containerGroup","startOfGroupIndex","_ref2","destinationGroupIndex","destinationGroup","lastOfGroupIndex","_ref3","lastTabbableNode","_destinationGroupIndex","_destinationGroup","checkKey","checkClick","addListeners","removeListeners","activateOptions","onActivate","onPostActivate","checkCanFocusTrap","finishActivation","deactivateOptions","onDeactivate","onPostDeactivate","checkCanReturnFocus","returnFocus","finishDeactivation","containerElements","elementsAsArray","focusTrap","popup","keyDownHandler","close","applyFilters","collapsed","getUrl","manualSort","priceLowHighSort","priceHighLowSort","newestFirstSort","oldestFirstSort","selectedSort","selectData","sortIdToOption","updateSort","cur","activePage","getPaginationOptions","page","pageURL","prevURL","nextURL","useSearchStore","searchPanelOpened","isInitiated","searchQuery","toggleSearchPanel","computed","searchStore","cartStore","useCartStore","useMenuStore","toggleMobileMenu","mobileMenuOpened","isMenuItemActive","part","pathPart","touchEvent","root","handleEventOutside","onUnmounted","open","menuStore","hasGroup","chunkSize","chunkedArray","active","menuCloseBtn","onBeforeUnmount","alternateURLs","alternatedURLsAsMap","map","alternate","getAlternateURLs","leafNodes","alternates","links","popover","overlay","storeToRefs","useI18n","closePopup","changedIsOpen","displayPrice","currencyDisplayPrice","searchInput","searchURL","generateRoute","opened","createElement","tagName","appendToEl","toTransformString","propValue","setWidthHeight","w","h","LOAD_STATE","specialKeyUsed","getElementsFromOption","legacySelector","isPswpClass","PhotoSwipeEvent","type","details","Eventable","f1","f2","Placeholder","imageSrc","imgEl","Content","itemData","instance","isLazy","reload","placeholderEl","placeholderSrc","imageElement","isInitialSizeUpdate","sizesWidth","errorMsgEl","supportsDecode","getViewportSize","pswp","newViewportSize","parsePaddingOption","viewportSize","paddingValue","legacyPropName","getPanAreaSize","MAX_IMAGE_WIDTH","ZoomLevel","maxWidth","maxHeight","panAreaSize","elementSize","hRatio","vRatio","optionPrefix","currZoomLevel","lazyLoadData","zoomLevel","lazyLoadSlide","PhotoSwipeBase","numItems","dataSource","slideData","dataSourceItem","galleryElement","linkEl","thumbnailEl","PhotoSwipeLightbox","initialPoint","clickedIndex","clickedTarget","clickedChildIndex","promiseArray","pswpModuleType","uid","iterableModules","mainModule","imagesPerSlide","lightbox","gallery","availableVariants","selectedProduct","selectedProductHasSale","selectedPrice","selectedOriginalPrice","productName","hidePrice","setInitialSelectedProduct","addToCart","configurationOf","updateSelection","attributeValue","partiallyHideDescription","descriptionField","elementHasOverflow","expanded","isSticky","productInfo","navTrigger","relatedProductTypeReferences","navItems","tab","relations","prt","emitProductDetailEvent","handleDetailTabs","productRelations","productRelation","EventProductView","formatProduct","sectionTriggers","stickyObserver","sectionObserver","entry","intersectedIndex","tabs","displayDate","dateString","contactFormCookieKey","contactFormAlreadySubmitted","formValues","v$","useVuelidate","maxLength","expiresInMs","EventCollectionImpression","cookieBarKey","useCookieBar","showCookieBar","acceptCookies","denyCookies","cookieBarStore","cookiebar","acceptButton","pinia","createPinia","app","createApp","Notifications","i18n","BaseShipmentSelect","BaseCheckout","BaseCart","HeroSlider","ProductHighlightSlider","BrandSlider","TheFooter","BaseBreadcrumbs","BaseNewsletter","TopNotification","BaseSelect","BaseActions","ProductCard","BaseFilters","BaseFiltersMobile","CollectionOverviewEvent","RecursiveCollectionList","BaseProductOverviewSortingOptions","BasePagination","BaseTopMenu","BaseSocialIcons","BaseUsps","BaseSearchButton","BaseCartButton","BaseMobileUsps","BaseMainMenu","BaseMobileMenu","BaseMobileMenuButton","BaseLogo","BaseCartPopover","BaseSearchBar","BaseCookieBar","ArticlePreview","BaseArticle","ArticleCallToActionBlock","ArticleImageTextBlock","ArticleTitleTextBlock","BaseContact","ProductDetailSlider","ProductDetailInfo","ProductDetail","ShopTheLookProduct","BaseLanguageSwitch"],"sources":["../../node_modules/ssr-window/ssr-window.esm.js","../../node_modules/dom7/dom7.esm.js","../../node_modules/swiper/shared/dom.js","../../node_modules/swiper/shared/utils.js","../../node_modules/swiper/shared/get-support.js","../../node_modules/swiper/shared/get-device.js","../../node_modules/swiper/shared/get-browser.js","../../node_modules/swiper/core/modules/resize/resize.js","../../node_modules/swiper/core/modules/observer/observer.js","../../node_modules/swiper/core/events-emitter.js","../../node_modules/swiper/core/update/updateSize.js","../../node_modules/swiper/core/update/updateSlides.js","../../node_modules/swiper/core/update/updateAutoHeight.js","../../node_modules/swiper/core/update/updateSlidesOffset.js","../../node_modules/swiper/core/update/updateSlidesProgress.js","../../node_modules/swiper/core/update/updateProgress.js","../../node_modules/swiper/core/update/updateSlidesClasses.js","../../node_modules/swiper/core/update/updateActiveIndex.js","../../node_modules/swiper/core/update/updateClickedSlide.js","../../node_modules/swiper/core/update/index.js","../../node_modules/swiper/core/translate/getTranslate.js","../../node_modules/swiper/core/translate/setTranslate.js","../../node_modules/swiper/core/translate/minTranslate.js","../../node_modules/swiper/core/translate/maxTranslate.js","../../node_modules/swiper/core/translate/translateTo.js","../../node_modules/swiper/core/translate/index.js","../../node_modules/swiper/core/transition/setTransition.js","../../node_modules/swiper/core/transition/transitionEmit.js","../../node_modules/swiper/core/transition/transitionStart.js","../../node_modules/swiper/core/transition/transitionEnd.js","../../node_modules/swiper/core/transition/index.js","../../node_modules/swiper/core/slide/slideTo.js","../../node_modules/swiper/core/slide/slideToLoop.js","../../node_modules/swiper/core/slide/slideNext.js","../../node_modules/swiper/core/slide/slidePrev.js","../../node_modules/swiper/core/slide/slideReset.js","../../node_modules/swiper/core/slide/slideToClosest.js","../../node_modules/swiper/core/slide/slideToClickedSlide.js","../../node_modules/swiper/core/slide/index.js","../../node_modules/swiper/core/loop/loopCreate.js","../../node_modules/swiper/core/loop/loopFix.js","../../node_modules/swiper/core/loop/loopDestroy.js","../../node_modules/swiper/core/loop/index.js","../../node_modules/swiper/core/grab-cursor/setGrabCursor.js","../../node_modules/swiper/core/grab-cursor/unsetGrabCursor.js","../../node_modules/swiper/core/grab-cursor/index.js","../../node_modules/swiper/core/events/onTouchStart.js","../../node_modules/swiper/core/events/onTouchMove.js","../../node_modules/swiper/core/events/onTouchEnd.js","../../node_modules/swiper/core/events/onResize.js","../../node_modules/swiper/core/events/onClick.js","../../node_modules/swiper/core/events/onScroll.js","../../node_modules/swiper/core/events/index.js","../../node_modules/swiper/core/breakpoints/setBreakpoint.js","../../node_modules/swiper/core/breakpoints/getBreakpoint.js","../../node_modules/swiper/core/breakpoints/index.js","../../node_modules/swiper/core/classes/addClasses.js","../../node_modules/swiper/core/classes/removeClasses.js","../../node_modules/swiper/core/classes/index.js","../../node_modules/swiper/core/images/loadImage.js","../../node_modules/swiper/core/images/preloadImages.js","../../node_modules/swiper/core/images/index.js","../../node_modules/swiper/core/check-overflow/index.js","../../node_modules/swiper/core/defaults.js","../../node_modules/swiper/core/moduleExtendParams.js","../../node_modules/swiper/core/core.js","../../node_modules/swiper/shared/create-element-if-not-defined.js","../../node_modules/swiper/modules/navigation/navigation.js","../../node_modules/swiper/shared/classes-to-selector.js","../../node_modules/swiper/modules/pagination/pagination.js","../../node_modules/swiper/modules/lazy/lazy.js","../../node_modules/swiper/modules/a11y/a11y.js","../../node_modules/swiper/modules/autoplay/autoplay.js","../../src/components/HeroSlider.vue","../../src/models/product.ts","../../src/helper/product.ts","../../src/components/ProductCard.vue","../../src/components/ProductHighlightSlider.vue","../../src/components/BrandSlider.vue","../../src/assets/img/payment-logos/bancontact.png","../../src/assets/img/payment-logos/ideal.png","../../src/assets/img/payment-logos/maestro.png","../../src/assets/img/payment-logos/mastercard.png","../../src/assets/img/payment-logos/paypal.png","../../src/assets/img/payment-logos/visa.png","../../src/assets/img/payment-logos/sofort.png","../../src/assets/img/payment-logos/giropay.png","../../src/components/BaseCollapse.vue","../../src/components/BaseCollapseGroup.vue","../../src/components/TheFooter.vue","../../node_modules/vue3-cookies/dist/index.js","../../src/stores/recaptcha.ts","../../src/components/BaseNewsletter.vue","../../src/components/TopNotification.vue","../../src/stores/collection.ts","../../src/components/BaseActions.vue","../../src/components/collection/BaseFilterFieldset.vue","../../src/components/collection/BaseFilters.vue","../../node_modules/tabbable/dist/index.esm.js","../../node_modules/focus-trap/dist/focus-trap.esm.js","../../src/components/collection/BaseFilterPopup.vue","../../src/components/collection/ActiveFilter.vue","../../src/components/collection/BaseFiltersMobile.vue","../../src/components/collection/RecursiveCollectionList.vue","../../src/components/BaseProductOverviewSortingOptions.vue","../../src/components/BasePagination.vue","../../src/stores/search.ts","../../src/components/BaseSearchButton.vue","../../src/components/BaseCartButton.vue","../../src/components/BaseMobileUsps.vue","../../src/stores/menu.ts","../../src/components/BaseNavDropdown.vue","../../src/components/BaseMainMenu.vue","../../src/components/BaseDrilldown.vue","../../src/components/BaseMobileMenu.vue","../../src/components/BaseMobileMenuButton.vue","../../src/components/BaseCartPopover.vue","../../src/components/BaseSearchBar.vue","../../node_modules/photoswipe/dist/photoswipe-lightbox.esm.js","../../src/components/product-detail/ProductDetailSlider.vue","../../src/components/product-detail/ProductDetailInfo.vue","../../src/components/product-detail/ProductDetail.vue","../../src/components/blog/ArticlePreview.vue","../../src/components/blog/BaseArticle.vue","../../src/components/contact/BaseContact.vue","../../src/components/shop-the-look/ShopTheLookProduct.vue","../../src/components/CollectionOverviewEvent.vue","../../src/stores/cookie-bar.ts","../../src/components/BaseCookieBar.vue","../../src/main.ts"],"sourcesContent":["/**\n * SSR Window 4.0.2\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2021, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: December 13, 2021\n */\n/* eslint-disable no-param-reassign */\nfunction isObject(obj) {\n    return (obj !== null &&\n        typeof obj === 'object' &&\n        'constructor' in obj &&\n        obj.constructor === Object);\n}\nfunction extend(target = {}, src = {}) {\n    Object.keys(src).forEach((key) => {\n        if (typeof target[key] === 'undefined')\n            target[key] = src[key];\n        else if (isObject(src[key]) &&\n            isObject(target[key]) &&\n            Object.keys(src[key]).length > 0) {\n            extend(target[key], src[key]);\n        }\n    });\n}\n\nconst ssrDocument = {\n    body: {},\n    addEventListener() { },\n    removeEventListener() { },\n    activeElement: {\n        blur() { },\n        nodeName: '',\n    },\n    querySelector() {\n        return null;\n    },\n    querySelectorAll() {\n        return [];\n    },\n    getElementById() {\n        return null;\n    },\n    createEvent() {\n        return {\n            initEvent() { },\n        };\n    },\n    createElement() {\n        return {\n            children: [],\n            childNodes: [],\n            style: {},\n            setAttribute() { },\n            getElementsByTagName() {\n                return [];\n            },\n        };\n    },\n    createElementNS() {\n        return {};\n    },\n    importNode() {\n        return null;\n    },\n    location: {\n        hash: '',\n        host: '',\n        hostname: '',\n        href: '',\n        origin: '',\n        pathname: '',\n        protocol: '',\n        search: '',\n    },\n};\nfunction getDocument() {\n    const doc = typeof document !== 'undefined' ? document : {};\n    extend(doc, ssrDocument);\n    return doc;\n}\n\nconst ssrWindow = {\n    document: ssrDocument,\n    navigator: {\n        userAgent: '',\n    },\n    location: {\n        hash: '',\n        host: '',\n        hostname: '',\n        href: '',\n        origin: '',\n        pathname: '',\n        protocol: '',\n        search: '',\n    },\n    history: {\n        replaceState() { },\n        pushState() { },\n        go() { },\n        back() { },\n    },\n    CustomEvent: function CustomEvent() {\n        return this;\n    },\n    addEventListener() { },\n    removeEventListener() { },\n    getComputedStyle() {\n        return {\n            getPropertyValue() {\n                return '';\n            },\n        };\n    },\n    Image() { },\n    Date() { },\n    screen: {},\n    setTimeout() { },\n    clearTimeout() { },\n    matchMedia() {\n        return {};\n    },\n    requestAnimationFrame(callback) {\n        if (typeof setTimeout === 'undefined') {\n            callback();\n            return null;\n        }\n        return setTimeout(callback, 0);\n    },\n    cancelAnimationFrame(id) {\n        if (typeof setTimeout === 'undefined') {\n            return;\n        }\n        clearTimeout(id);\n    },\n};\nfunction getWindow() {\n    const win = typeof window !== 'undefined' ? window : {};\n    extend(win, ssrWindow);\n    return win;\n}\n\nexport { extend, getDocument, getWindow, ssrDocument, ssrWindow };\n","/**\n * Dom7 4.0.4\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2022, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: January 11, 2022\n */\nimport { getWindow, getDocument } from 'ssr-window';\n\n/* eslint-disable no-proto */\nfunction makeReactive(obj) {\n  const proto = obj.__proto__;\n  Object.defineProperty(obj, '__proto__', {\n    get() {\n      return proto;\n    },\n\n    set(value) {\n      proto.__proto__ = value;\n    }\n\n  });\n}\n\nclass Dom7 extends Array {\n  constructor(items) {\n    if (typeof items === 'number') {\n      super(items);\n    } else {\n      super(...(items || []));\n      makeReactive(this);\n    }\n  }\n\n}\n\nfunction arrayFlat(arr = []) {\n  const res = [];\n  arr.forEach(el => {\n    if (Array.isArray(el)) {\n      res.push(...arrayFlat(el));\n    } else {\n      res.push(el);\n    }\n  });\n  return res;\n}\nfunction arrayFilter(arr, callback) {\n  return Array.prototype.filter.call(arr, callback);\n}\nfunction arrayUnique(arr) {\n  const uniqueArray = [];\n\n  for (let i = 0; i < arr.length; i += 1) {\n    if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);\n  }\n\n  return uniqueArray;\n}\nfunction toCamelCase(string) {\n  return string.toLowerCase().replace(/-(.)/g, (match, group) => group.toUpperCase());\n}\n\n// eslint-disable-next-line\n\nfunction qsa(selector, context) {\n  if (typeof selector !== 'string') {\n    return [selector];\n  }\n\n  const a = [];\n  const res = context.querySelectorAll(selector);\n\n  for (let i = 0; i < res.length; i += 1) {\n    a.push(res[i]);\n  }\n\n  return a;\n}\n\nfunction $(selector, context) {\n  const window = getWindow();\n  const document = getDocument();\n  let arr = [];\n\n  if (!context && selector instanceof Dom7) {\n    return selector;\n  }\n\n  if (!selector) {\n    return new Dom7(arr);\n  }\n\n  if (typeof selector === 'string') {\n    const html = selector.trim();\n\n    if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n      let toCreate = 'div';\n      if (html.indexOf('<li') === 0) toCreate = 'ul';\n      if (html.indexOf('<tr') === 0) toCreate = 'tbody';\n      if (html.indexOf('<td') === 0 || html.indexOf('<th') === 0) toCreate = 'tr';\n      if (html.indexOf('<tbody') === 0) toCreate = 'table';\n      if (html.indexOf('<option') === 0) toCreate = 'select';\n      const tempParent = document.createElement(toCreate);\n      tempParent.innerHTML = html;\n\n      for (let i = 0; i < tempParent.childNodes.length; i += 1) {\n        arr.push(tempParent.childNodes[i]);\n      }\n    } else {\n      arr = qsa(selector.trim(), context || document);\n    } // arr = qsa(selector, document);\n\n  } else if (selector.nodeType || selector === window || selector === document) {\n    arr.push(selector);\n  } else if (Array.isArray(selector)) {\n    if (selector instanceof Dom7) return selector;\n    arr = selector;\n  }\n\n  return new Dom7(arrayUnique(arr));\n}\n\n$.fn = Dom7.prototype;\n\n// eslint-disable-next-line\n\nfunction addClass(...classes) {\n  const classNames = arrayFlat(classes.map(c => c.split(' ')));\n  this.forEach(el => {\n    el.classList.add(...classNames);\n  });\n  return this;\n}\n\nfunction removeClass(...classes) {\n  const classNames = arrayFlat(classes.map(c => c.split(' ')));\n  this.forEach(el => {\n    el.classList.remove(...classNames);\n  });\n  return this;\n}\n\nfunction toggleClass(...classes) {\n  const classNames = arrayFlat(classes.map(c => c.split(' ')));\n  this.forEach(el => {\n    classNames.forEach(className => {\n      el.classList.toggle(className);\n    });\n  });\n}\n\nfunction hasClass(...classes) {\n  const classNames = arrayFlat(classes.map(c => c.split(' ')));\n  return arrayFilter(this, el => {\n    return classNames.filter(className => el.classList.contains(className)).length > 0;\n  }).length > 0;\n}\n\nfunction attr(attrs, value) {\n  if (arguments.length === 1 && typeof attrs === 'string') {\n    // Get attr\n    if (this[0]) return this[0].getAttribute(attrs);\n    return undefined;\n  } // Set attrs\n\n\n  for (let i = 0; i < this.length; i += 1) {\n    if (arguments.length === 2) {\n      // String\n      this[i].setAttribute(attrs, value);\n    } else {\n      // Object\n      for (const attrName in attrs) {\n        this[i][attrName] = attrs[attrName];\n        this[i].setAttribute(attrName, attrs[attrName]);\n      }\n    }\n  }\n\n  return this;\n}\n\nfunction removeAttr(attr) {\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].removeAttribute(attr);\n  }\n\n  return this;\n}\n\nfunction prop(props, value) {\n  if (arguments.length === 1 && typeof props === 'string') {\n    // Get prop\n    if (this[0]) return this[0][props];\n  } else {\n    // Set props\n    for (let i = 0; i < this.length; i += 1) {\n      if (arguments.length === 2) {\n        // String\n        this[i][props] = value;\n      } else {\n        // Object\n        for (const propName in props) {\n          this[i][propName] = props[propName];\n        }\n      }\n    }\n\n    return this;\n  }\n\n  return this;\n}\n\nfunction data(key, value) {\n  let el;\n\n  if (typeof value === 'undefined') {\n    el = this[0];\n    if (!el) return undefined; // Get value\n\n    if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) {\n      return el.dom7ElementDataStorage[key];\n    }\n\n    const dataKey = el.getAttribute(`data-${key}`);\n\n    if (dataKey) {\n      return dataKey;\n    }\n\n    return undefined;\n  } // Set value\n\n\n  for (let i = 0; i < this.length; i += 1) {\n    el = this[i];\n    if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};\n    el.dom7ElementDataStorage[key] = value;\n  }\n\n  return this;\n}\n\nfunction removeData(key) {\n  for (let i = 0; i < this.length; i += 1) {\n    const el = this[i];\n\n    if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {\n      el.dom7ElementDataStorage[key] = null;\n      delete el.dom7ElementDataStorage[key];\n    }\n  }\n}\n\nfunction dataset() {\n  const el = this[0];\n  if (!el) return undefined;\n  const dataset = {}; // eslint-disable-line\n\n  if (el.dataset) {\n    for (const dataKey in el.dataset) {\n      dataset[dataKey] = el.dataset[dataKey];\n    }\n  } else {\n    for (let i = 0; i < el.attributes.length; i += 1) {\n      const attr = el.attributes[i];\n\n      if (attr.name.indexOf('data-') >= 0) {\n        dataset[toCamelCase(attr.name.split('data-')[1])] = attr.value;\n      }\n    }\n  }\n\n  for (const key in dataset) {\n    if (dataset[key] === 'false') dataset[key] = false;else if (dataset[key] === 'true') dataset[key] = true;else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;\n  }\n\n  return dataset;\n}\n\nfunction val(value) {\n  if (typeof value === 'undefined') {\n    // get value\n    const el = this[0];\n    if (!el) return undefined;\n\n    if (el.multiple && el.nodeName.toLowerCase() === 'select') {\n      const values = [];\n\n      for (let i = 0; i < el.selectedOptions.length; i += 1) {\n        values.push(el.selectedOptions[i].value);\n      }\n\n      return values;\n    }\n\n    return el.value;\n  } // set value\n\n\n  for (let i = 0; i < this.length; i += 1) {\n    const el = this[i];\n\n    if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === 'select') {\n      for (let j = 0; j < el.options.length; j += 1) {\n        el.options[j].selected = value.indexOf(el.options[j].value) >= 0;\n      }\n    } else {\n      el.value = value;\n    }\n  }\n\n  return this;\n}\n\nfunction value(value) {\n  return this.val(value);\n}\n\nfunction transform(transform) {\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].style.transform = transform;\n  }\n\n  return this;\n}\n\nfunction transition(duration) {\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].style.transitionDuration = typeof duration !== 'string' ? `${duration}ms` : duration;\n  }\n\n  return this;\n}\n\nfunction on(...args) {\n  let [eventType, targetSelector, listener, capture] = args;\n\n  if (typeof args[1] === 'function') {\n    [eventType, listener, capture] = args;\n    targetSelector = undefined;\n  }\n\n  if (!capture) capture = false;\n\n  function handleLiveEvent(e) {\n    const target = e.target;\n    if (!target) return;\n    const eventData = e.target.dom7EventData || [];\n\n    if (eventData.indexOf(e) < 0) {\n      eventData.unshift(e);\n    }\n\n    if ($(target).is(targetSelector)) listener.apply(target, eventData);else {\n      const parents = $(target).parents(); // eslint-disable-line\n\n      for (let k = 0; k < parents.length; k += 1) {\n        if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);\n      }\n    }\n  }\n\n  function handleEvent(e) {\n    const eventData = e && e.target ? e.target.dom7EventData || [] : [];\n\n    if (eventData.indexOf(e) < 0) {\n      eventData.unshift(e);\n    }\n\n    listener.apply(this, eventData);\n  }\n\n  const events = eventType.split(' ');\n  let j;\n\n  for (let i = 0; i < this.length; i += 1) {\n    const el = this[i];\n\n    if (!targetSelector) {\n      for (j = 0; j < events.length; j += 1) {\n        const event = events[j];\n        if (!el.dom7Listeners) el.dom7Listeners = {};\n        if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];\n        el.dom7Listeners[event].push({\n          listener,\n          proxyListener: handleEvent\n        });\n        el.addEventListener(event, handleEvent, capture);\n      }\n    } else {\n      // Live events\n      for (j = 0; j < events.length; j += 1) {\n        const event = events[j];\n        if (!el.dom7LiveListeners) el.dom7LiveListeners = {};\n        if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];\n        el.dom7LiveListeners[event].push({\n          listener,\n          proxyListener: handleLiveEvent\n        });\n        el.addEventListener(event, handleLiveEvent, capture);\n      }\n    }\n  }\n\n  return this;\n}\n\nfunction off(...args) {\n  let [eventType, targetSelector, listener, capture] = args;\n\n  if (typeof args[1] === 'function') {\n    [eventType, listener, capture] = args;\n    targetSelector = undefined;\n  }\n\n  if (!capture) capture = false;\n  const events = eventType.split(' ');\n\n  for (let i = 0; i < events.length; i += 1) {\n    const event = events[i];\n\n    for (let j = 0; j < this.length; j += 1) {\n      const el = this[j];\n      let handlers;\n\n      if (!targetSelector && el.dom7Listeners) {\n        handlers = el.dom7Listeners[event];\n      } else if (targetSelector && el.dom7LiveListeners) {\n        handlers = el.dom7LiveListeners[event];\n      }\n\n      if (handlers && handlers.length) {\n        for (let k = handlers.length - 1; k >= 0; k -= 1) {\n          const handler = handlers[k];\n\n          if (listener && handler.listener === listener) {\n            el.removeEventListener(event, handler.proxyListener, capture);\n            handlers.splice(k, 1);\n          } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n            el.removeEventListener(event, handler.proxyListener, capture);\n            handlers.splice(k, 1);\n          } else if (!listener) {\n            el.removeEventListener(event, handler.proxyListener, capture);\n            handlers.splice(k, 1);\n          }\n        }\n      }\n    }\n  }\n\n  return this;\n}\n\nfunction once(...args) {\n  const dom = this;\n  let [eventName, targetSelector, listener, capture] = args;\n\n  if (typeof args[1] === 'function') {\n    [eventName, listener, capture] = args;\n    targetSelector = undefined;\n  }\n\n  function onceHandler(...eventArgs) {\n    listener.apply(this, eventArgs);\n    dom.off(eventName, targetSelector, onceHandler, capture);\n\n    if (onceHandler.dom7proxy) {\n      delete onceHandler.dom7proxy;\n    }\n  }\n\n  onceHandler.dom7proxy = listener;\n  return dom.on(eventName, targetSelector, onceHandler, capture);\n}\n\nfunction trigger(...args) {\n  const window = getWindow();\n  const events = args[0].split(' ');\n  const eventData = args[1];\n\n  for (let i = 0; i < events.length; i += 1) {\n    const event = events[i];\n\n    for (let j = 0; j < this.length; j += 1) {\n      const el = this[j];\n\n      if (window.CustomEvent) {\n        const evt = new window.CustomEvent(event, {\n          detail: eventData,\n          bubbles: true,\n          cancelable: true\n        });\n        el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0);\n        el.dispatchEvent(evt);\n        el.dom7EventData = [];\n        delete el.dom7EventData;\n      }\n    }\n  }\n\n  return this;\n}\n\nfunction transitionEnd(callback) {\n  const dom = this;\n\n  function fireCallBack(e) {\n    if (e.target !== this) return;\n    callback.call(this, e);\n    dom.off('transitionend', fireCallBack);\n  }\n\n  if (callback) {\n    dom.on('transitionend', fireCallBack);\n  }\n\n  return this;\n}\n\nfunction animationEnd(callback) {\n  const dom = this;\n\n  function fireCallBack(e) {\n    if (e.target !== this) return;\n    callback.call(this, e);\n    dom.off('animationend', fireCallBack);\n  }\n\n  if (callback) {\n    dom.on('animationend', fireCallBack);\n  }\n\n  return this;\n}\n\nfunction width() {\n  const window = getWindow();\n\n  if (this[0] === window) {\n    return window.innerWidth;\n  }\n\n  if (this.length > 0) {\n    return parseFloat(this.css('width'));\n  }\n\n  return null;\n}\n\nfunction outerWidth(includeMargins) {\n  if (this.length > 0) {\n    if (includeMargins) {\n      const styles = this.styles();\n      return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n    }\n\n    return this[0].offsetWidth;\n  }\n\n  return null;\n}\n\nfunction height() {\n  const window = getWindow();\n\n  if (this[0] === window) {\n    return window.innerHeight;\n  }\n\n  if (this.length > 0) {\n    return parseFloat(this.css('height'));\n  }\n\n  return null;\n}\n\nfunction outerHeight(includeMargins) {\n  if (this.length > 0) {\n    if (includeMargins) {\n      const styles = this.styles();\n      return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n    }\n\n    return this[0].offsetHeight;\n  }\n\n  return null;\n}\n\nfunction offset() {\n  if (this.length > 0) {\n    const window = getWindow();\n    const document = getDocument();\n    const el = this[0];\n    const box = el.getBoundingClientRect();\n    const body = document.body;\n    const clientTop = el.clientTop || body.clientTop || 0;\n    const clientLeft = el.clientLeft || body.clientLeft || 0;\n    const scrollTop = el === window ? window.scrollY : el.scrollTop;\n    const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n    return {\n      top: box.top + scrollTop - clientTop,\n      left: box.left + scrollLeft - clientLeft\n    };\n  }\n\n  return null;\n}\n\nfunction hide() {\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].style.display = 'none';\n  }\n\n  return this;\n}\n\nfunction show() {\n  const window = getWindow();\n\n  for (let i = 0; i < this.length; i += 1) {\n    const el = this[i];\n\n    if (el.style.display === 'none') {\n      el.style.display = '';\n    }\n\n    if (window.getComputedStyle(el, null).getPropertyValue('display') === 'none') {\n      // Still not visible\n      el.style.display = 'block';\n    }\n  }\n\n  return this;\n}\n\nfunction styles() {\n  const window = getWindow();\n  if (this[0]) return window.getComputedStyle(this[0], null);\n  return {};\n}\n\nfunction css(props, value) {\n  const window = getWindow();\n  let i;\n\n  if (arguments.length === 1) {\n    if (typeof props === 'string') {\n      // .css('width')\n      if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);\n    } else {\n      // .css({ width: '100px' })\n      for (i = 0; i < this.length; i += 1) {\n        for (const prop in props) {\n          this[i].style[prop] = props[prop];\n        }\n      }\n\n      return this;\n    }\n  }\n\n  if (arguments.length === 2 && typeof props === 'string') {\n    // .css('width', '100px')\n    for (i = 0; i < this.length; i += 1) {\n      this[i].style[props] = value;\n    }\n\n    return this;\n  }\n\n  return this;\n}\n\nfunction each(callback) {\n  if (!callback) return this;\n  this.forEach((el, index) => {\n    callback.apply(el, [el, index]);\n  });\n  return this;\n}\n\nfunction filter(callback) {\n  const result = arrayFilter(this, callback);\n  return $(result);\n}\n\nfunction html(html) {\n  if (typeof html === 'undefined') {\n    return this[0] ? this[0].innerHTML : null;\n  }\n\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].innerHTML = html;\n  }\n\n  return this;\n}\n\nfunction text(text) {\n  if (typeof text === 'undefined') {\n    return this[0] ? this[0].textContent.trim() : null;\n  }\n\n  for (let i = 0; i < this.length; i += 1) {\n    this[i].textContent = text;\n  }\n\n  return this;\n}\n\nfunction is(selector) {\n  const window = getWindow();\n  const document = getDocument();\n  const el = this[0];\n  let compareWith;\n  let i;\n  if (!el || typeof selector === 'undefined') return false;\n\n  if (typeof selector === 'string') {\n    if (el.matches) return el.matches(selector);\n    if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);\n    if (el.msMatchesSelector) return el.msMatchesSelector(selector);\n    compareWith = $(selector);\n\n    for (i = 0; i < compareWith.length; i += 1) {\n      if (compareWith[i] === el) return true;\n    }\n\n    return false;\n  }\n\n  if (selector === document) {\n    return el === document;\n  }\n\n  if (selector === window) {\n    return el === window;\n  }\n\n  if (selector.nodeType || selector instanceof Dom7) {\n    compareWith = selector.nodeType ? [selector] : selector;\n\n    for (i = 0; i < compareWith.length; i += 1) {\n      if (compareWith[i] === el) return true;\n    }\n\n    return false;\n  }\n\n  return false;\n}\n\nfunction index() {\n  let child = this[0];\n  let i;\n\n  if (child) {\n    i = 0; // eslint-disable-next-line\n\n    while ((child = child.previousSibling) !== null) {\n      if (child.nodeType === 1) i += 1;\n    }\n\n    return i;\n  }\n\n  return undefined;\n}\n\nfunction eq(index) {\n  if (typeof index === 'undefined') return this;\n  const length = this.length;\n\n  if (index > length - 1) {\n    return $([]);\n  }\n\n  if (index < 0) {\n    const returnIndex = length + index;\n    if (returnIndex < 0) return $([]);\n    return $([this[returnIndex]]);\n  }\n\n  return $([this[index]]);\n}\n\nfunction append(...els) {\n  let newChild;\n  const document = getDocument();\n\n  for (let k = 0; k < els.length; k += 1) {\n    newChild = els[k];\n\n    for (let i = 0; i < this.length; i += 1) {\n      if (typeof newChild === 'string') {\n        const tempDiv = document.createElement('div');\n        tempDiv.innerHTML = newChild;\n\n        while (tempDiv.firstChild) {\n          this[i].appendChild(tempDiv.firstChild);\n        }\n      } else if (newChild instanceof Dom7) {\n        for (let j = 0; j < newChild.length; j += 1) {\n          this[i].appendChild(newChild[j]);\n        }\n      } else {\n        this[i].appendChild(newChild);\n      }\n    }\n  }\n\n  return this;\n}\n\nfunction appendTo(parent) {\n  $(parent).append(this);\n  return this;\n}\n\nfunction prepend(newChild) {\n  const document = getDocument();\n  let i;\n  let j;\n\n  for (i = 0; i < this.length; i += 1) {\n    if (typeof newChild === 'string') {\n      const tempDiv = document.createElement('div');\n      tempDiv.innerHTML = newChild;\n\n      for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n        this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n      }\n    } else if (newChild instanceof Dom7) {\n      for (j = 0; j < newChild.length; j += 1) {\n        this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n      }\n    } else {\n      this[i].insertBefore(newChild, this[i].childNodes[0]);\n    }\n  }\n\n  return this;\n}\n\nfunction prependTo(parent) {\n  $(parent).prepend(this);\n  return this;\n}\n\nfunction insertBefore(selector) {\n  const before = $(selector);\n\n  for (let i = 0; i < this.length; i += 1) {\n    if (before.length === 1) {\n      before[0].parentNode.insertBefore(this[i], before[0]);\n    } else if (before.length > 1) {\n      for (let j = 0; j < before.length; j += 1) {\n        before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);\n      }\n    }\n  }\n}\n\nfunction insertAfter(selector) {\n  const after = $(selector);\n\n  for (let i = 0; i < this.length; i += 1) {\n    if (after.length === 1) {\n      after[0].parentNode.insertBefore(this[i], after[0].nextSibling);\n    } else if (after.length > 1) {\n      for (let j = 0; j < after.length; j += 1) {\n        after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);\n      }\n    }\n  }\n}\n\nfunction next(selector) {\n  if (this.length > 0) {\n    if (selector) {\n      if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n        return $([this[0].nextElementSibling]);\n      }\n\n      return $([]);\n    }\n\n    if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);\n    return $([]);\n  }\n\n  return $([]);\n}\n\nfunction nextAll(selector) {\n  const nextEls = [];\n  let el = this[0];\n  if (!el) return $([]);\n\n  while (el.nextElementSibling) {\n    const next = el.nextElementSibling; // eslint-disable-line\n\n    if (selector) {\n      if ($(next).is(selector)) nextEls.push(next);\n    } else nextEls.push(next);\n\n    el = next;\n  }\n\n  return $(nextEls);\n}\n\nfunction prev(selector) {\n  if (this.length > 0) {\n    const el = this[0];\n\n    if (selector) {\n      if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n        return $([el.previousElementSibling]);\n      }\n\n      return $([]);\n    }\n\n    if (el.previousElementSibling) return $([el.previousElementSibling]);\n    return $([]);\n  }\n\n  return $([]);\n}\n\nfunction prevAll(selector) {\n  const prevEls = [];\n  let el = this[0];\n  if (!el) return $([]);\n\n  while (el.previousElementSibling) {\n    const prev = el.previousElementSibling; // eslint-disable-line\n\n    if (selector) {\n      if ($(prev).is(selector)) prevEls.push(prev);\n    } else prevEls.push(prev);\n\n    el = prev;\n  }\n\n  return $(prevEls);\n}\n\nfunction siblings(selector) {\n  return this.nextAll(selector).add(this.prevAll(selector));\n}\n\nfunction parent(selector) {\n  const parents = []; // eslint-disable-line\n\n  for (let i = 0; i < this.length; i += 1) {\n    if (this[i].parentNode !== null) {\n      if (selector) {\n        if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n      } else {\n        parents.push(this[i].parentNode);\n      }\n    }\n  }\n\n  return $(parents);\n}\n\nfunction parents(selector) {\n  const parents = []; // eslint-disable-line\n\n  for (let i = 0; i < this.length; i += 1) {\n    let parent = this[i].parentNode; // eslint-disable-line\n\n    while (parent) {\n      if (selector) {\n        if ($(parent).is(selector)) parents.push(parent);\n      } else {\n        parents.push(parent);\n      }\n\n      parent = parent.parentNode;\n    }\n  }\n\n  return $(parents);\n}\n\nfunction closest(selector) {\n  let closest = this; // eslint-disable-line\n\n  if (typeof selector === 'undefined') {\n    return $([]);\n  }\n\n  if (!closest.is(selector)) {\n    closest = closest.parents(selector).eq(0);\n  }\n\n  return closest;\n}\n\nfunction find(selector) {\n  const foundElements = [];\n\n  for (let i = 0; i < this.length; i += 1) {\n    const found = this[i].querySelectorAll(selector);\n\n    for (let j = 0; j < found.length; j += 1) {\n      foundElements.push(found[j]);\n    }\n  }\n\n  return $(foundElements);\n}\n\nfunction children(selector) {\n  const children = []; // eslint-disable-line\n\n  for (let i = 0; i < this.length; i += 1) {\n    const childNodes = this[i].children;\n\n    for (let j = 0; j < childNodes.length; j += 1) {\n      if (!selector || $(childNodes[j]).is(selector)) {\n        children.push(childNodes[j]);\n      }\n    }\n  }\n\n  return $(children);\n}\n\nfunction remove() {\n  for (let i = 0; i < this.length; i += 1) {\n    if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);\n  }\n\n  return this;\n}\n\nfunction detach() {\n  return this.remove();\n}\n\nfunction add(...els) {\n  const dom = this;\n  let i;\n  let j;\n\n  for (i = 0; i < els.length; i += 1) {\n    const toAdd = $(els[i]);\n\n    for (j = 0; j < toAdd.length; j += 1) {\n      dom.push(toAdd[j]);\n    }\n  }\n\n  return dom;\n}\n\nfunction empty() {\n  for (let i = 0; i < this.length; i += 1) {\n    const el = this[i];\n\n    if (el.nodeType === 1) {\n      for (let j = 0; j < el.childNodes.length; j += 1) {\n        if (el.childNodes[j].parentNode) {\n          el.childNodes[j].parentNode.removeChild(el.childNodes[j]);\n        }\n      }\n\n      el.textContent = '';\n    }\n  }\n\n  return this;\n}\n\n// eslint-disable-next-line\n\nfunction scrollTo(...args) {\n  const window = getWindow();\n  let [left, top, duration, easing, callback] = args;\n\n  if (args.length === 4 && typeof easing === 'function') {\n    callback = easing;\n    [left, top, duration, callback, easing] = args;\n  }\n\n  if (typeof easing === 'undefined') easing = 'swing';\n  return this.each(function animate() {\n    const el = this;\n    let currentTop;\n    let currentLeft;\n    let maxTop;\n    let maxLeft;\n    let newTop;\n    let newLeft;\n    let scrollTop; // eslint-disable-line\n\n    let scrollLeft; // eslint-disable-line\n\n    let animateTop = top > 0 || top === 0;\n    let animateLeft = left > 0 || left === 0;\n\n    if (typeof easing === 'undefined') {\n      easing = 'swing';\n    }\n\n    if (animateTop) {\n      currentTop = el.scrollTop;\n\n      if (!duration) {\n        el.scrollTop = top;\n      }\n    }\n\n    if (animateLeft) {\n      currentLeft = el.scrollLeft;\n\n      if (!duration) {\n        el.scrollLeft = left;\n      }\n    }\n\n    if (!duration) return;\n\n    if (animateTop) {\n      maxTop = el.scrollHeight - el.offsetHeight;\n      newTop = Math.max(Math.min(top, maxTop), 0);\n    }\n\n    if (animateLeft) {\n      maxLeft = el.scrollWidth - el.offsetWidth;\n      newLeft = Math.max(Math.min(left, maxLeft), 0);\n    }\n\n    let startTime = null;\n    if (animateTop && newTop === currentTop) animateTop = false;\n    if (animateLeft && newLeft === currentLeft) animateLeft = false;\n\n    function render(time = new Date().getTime()) {\n      if (startTime === null) {\n        startTime = time;\n      }\n\n      const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n      const easeProgress = easing === 'linear' ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;\n      let done;\n      if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);\n      if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);\n\n      if (animateTop && newTop > currentTop && scrollTop >= newTop) {\n        el.scrollTop = newTop;\n        done = true;\n      }\n\n      if (animateTop && newTop < currentTop && scrollTop <= newTop) {\n        el.scrollTop = newTop;\n        done = true;\n      }\n\n      if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {\n        el.scrollLeft = newLeft;\n        done = true;\n      }\n\n      if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {\n        el.scrollLeft = newLeft;\n        done = true;\n      }\n\n      if (done) {\n        if (callback) callback();\n        return;\n      }\n\n      if (animateTop) el.scrollTop = scrollTop;\n      if (animateLeft) el.scrollLeft = scrollLeft;\n      window.requestAnimationFrame(render);\n    }\n\n    window.requestAnimationFrame(render);\n  });\n} // scrollTop(top, duration, easing, callback) {\n\n\nfunction scrollTop(...args) {\n  let [top, duration, easing, callback] = args;\n\n  if (args.length === 3 && typeof easing === 'function') {\n    [top, duration, callback, easing] = args;\n  }\n\n  const dom = this;\n\n  if (typeof top === 'undefined') {\n    if (dom.length > 0) return dom[0].scrollTop;\n    return null;\n  }\n\n  return dom.scrollTo(undefined, top, duration, easing, callback);\n}\n\nfunction scrollLeft(...args) {\n  let [left, duration, easing, callback] = args;\n\n  if (args.length === 3 && typeof easing === 'function') {\n    [left, duration, callback, easing] = args;\n  }\n\n  const dom = this;\n\n  if (typeof left === 'undefined') {\n    if (dom.length > 0) return dom[0].scrollLeft;\n    return null;\n  }\n\n  return dom.scrollTo(left, undefined, duration, easing, callback);\n}\n\n// eslint-disable-next-line\n\nfunction animate(initialProps, initialParams) {\n  const window = getWindow();\n  const els = this;\n  const a = {\n    props: Object.assign({}, initialProps),\n    params: Object.assign({\n      duration: 300,\n      easing: 'swing' // or 'linear'\n\n      /* Callbacks\n      begin(elements)\n      complete(elements)\n      progress(elements, complete, remaining, start, tweenValue)\n      */\n\n    }, initialParams),\n    elements: els,\n    animating: false,\n    que: [],\n\n    easingProgress(easing, progress) {\n      if (easing === 'swing') {\n        return 0.5 - Math.cos(progress * Math.PI) / 2;\n      }\n\n      if (typeof easing === 'function') {\n        return easing(progress);\n      }\n\n      return progress;\n    },\n\n    stop() {\n      if (a.frameId) {\n        window.cancelAnimationFrame(a.frameId);\n      }\n\n      a.animating = false;\n      a.elements.each(el => {\n        const element = el;\n        delete element.dom7AnimateInstance;\n      });\n      a.que = [];\n    },\n\n    done(complete) {\n      a.animating = false;\n      a.elements.each(el => {\n        const element = el;\n        delete element.dom7AnimateInstance;\n      });\n      if (complete) complete(els);\n\n      if (a.que.length > 0) {\n        const que = a.que.shift();\n        a.animate(que[0], que[1]);\n      }\n    },\n\n    animate(props, params) {\n      if (a.animating) {\n        a.que.push([props, params]);\n        return a;\n      }\n\n      const elements = []; // Define & Cache Initials & Units\n\n      a.elements.each((el, index) => {\n        let initialFullValue;\n        let initialValue;\n        let unit;\n        let finalValue;\n        let finalFullValue;\n        if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;\n        elements[index] = {\n          container: el\n        };\n        Object.keys(props).forEach(prop => {\n          initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(',', '.');\n          initialValue = parseFloat(initialFullValue);\n          unit = initialFullValue.replace(initialValue, '');\n          finalValue = parseFloat(props[prop]);\n          finalFullValue = props[prop] + unit;\n          elements[index][prop] = {\n            initialFullValue,\n            initialValue,\n            unit,\n            finalValue,\n            finalFullValue,\n            currentValue: initialValue\n          };\n        });\n      });\n      let startTime = null;\n      let time;\n      let elementsDone = 0;\n      let propsDone = 0;\n      let done;\n      let began = false;\n      a.animating = true;\n\n      function render() {\n        time = new Date().getTime();\n        let progress;\n        let easeProgress; // let el;\n\n        if (!began) {\n          began = true;\n          if (params.begin) params.begin(els);\n        }\n\n        if (startTime === null) {\n          startTime = time;\n        }\n\n        if (params.progress) {\n          // eslint-disable-next-line\n          params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);\n        }\n\n        elements.forEach(element => {\n          const el = element;\n          if (done || el.done) return;\n          Object.keys(props).forEach(prop => {\n            if (done || el.done) return;\n            progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);\n            easeProgress = a.easingProgress(params.easing, progress);\n            const {\n              initialValue,\n              finalValue,\n              unit\n            } = el[prop];\n            el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);\n            const currentValue = el[prop].currentValue;\n\n            if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {\n              el.container.style[prop] = finalValue + unit;\n              propsDone += 1;\n\n              if (propsDone === Object.keys(props).length) {\n                el.done = true;\n                elementsDone += 1;\n              }\n\n              if (elementsDone === elements.length) {\n                done = true;\n              }\n            }\n\n            if (done) {\n              a.done(params.complete);\n              return;\n            }\n\n            el.container.style[prop] = currentValue + unit;\n          });\n        });\n        if (done) return; // Then call\n\n        a.frameId = window.requestAnimationFrame(render);\n      }\n\n      a.frameId = window.requestAnimationFrame(render);\n      return a;\n    }\n\n  };\n\n  if (a.elements.length === 0) {\n    return els;\n  }\n\n  let animateInstance;\n\n  for (let i = 0; i < a.elements.length; i += 1) {\n    if (a.elements[i].dom7AnimateInstance) {\n      animateInstance = a.elements[i].dom7AnimateInstance;\n    } else a.elements[i].dom7AnimateInstance = a;\n  }\n\n  if (!animateInstance) {\n    animateInstance = a;\n  }\n\n  if (initialProps === 'stop') {\n    animateInstance.stop();\n  } else {\n    animateInstance.animate(a.props, a.params);\n  }\n\n  return els;\n}\n\nfunction stop() {\n  const els = this;\n\n  for (let i = 0; i < els.length; i += 1) {\n    if (els[i].dom7AnimateInstance) {\n      els[i].dom7AnimateInstance.stop();\n    }\n  }\n}\n\nconst noTrigger = 'resize scroll'.split(' ');\n\nfunction shortcut(name) {\n  function eventHandler(...args) {\n    if (typeof args[0] === 'undefined') {\n      for (let i = 0; i < this.length; i += 1) {\n        if (noTrigger.indexOf(name) < 0) {\n          if (name in this[i]) this[i][name]();else {\n            $(this[i]).trigger(name);\n          }\n        }\n      }\n\n      return this;\n    }\n\n    return this.on(name, ...args);\n  }\n\n  return eventHandler;\n}\n\nconst click = shortcut('click');\nconst blur = shortcut('blur');\nconst focus = shortcut('focus');\nconst focusin = shortcut('focusin');\nconst focusout = shortcut('focusout');\nconst keyup = shortcut('keyup');\nconst keydown = shortcut('keydown');\nconst keypress = shortcut('keypress');\nconst submit = shortcut('submit');\nconst change = shortcut('change');\nconst mousedown = shortcut('mousedown');\nconst mousemove = shortcut('mousemove');\nconst mouseup = shortcut('mouseup');\nconst mouseenter = shortcut('mouseenter');\nconst mouseleave = shortcut('mouseleave');\nconst mouseout = shortcut('mouseout');\nconst mouseover = shortcut('mouseover');\nconst touchstart = shortcut('touchstart');\nconst touchend = shortcut('touchend');\nconst touchmove = shortcut('touchmove');\nconst resize = shortcut('resize');\nconst scroll = shortcut('scroll');\n\nexport default $;\nexport { $, add, addClass, animate, animationEnd, append, appendTo, attr, blur, change, children, click, closest, css, data, dataset, detach, each, empty, eq, filter, find, focus, focusin, focusout, hasClass, height, hide, html, index, insertAfter, insertBefore, is, keydown, keypress, keyup, mousedown, mouseenter, mouseleave, mousemove, mouseout, mouseover, mouseup, next, nextAll, off, offset, on, once, outerHeight, outerWidth, parent, parents, prepend, prependTo, prev, prevAll, prop, remove, removeAttr, removeClass, removeData, resize, scroll, scrollLeft, scrollTo, scrollTop, show, siblings, stop, styles, submit, text, toggleClass, touchend, touchmove, touchstart, transform, transition, transitionEnd, trigger, val, value, width };\n","import { $, addClass, removeClass, hasClass, toggleClass, attr, removeAttr, transform, transition, on, off, trigger, transitionEnd, outerWidth, outerHeight, styles, offset, css, each, html, text, is, index, eq, append, prepend, next, nextAll, prev, prevAll, parent, parents, closest, find, children, filter, remove } from 'dom7';\nconst Methods = {\n  addClass,\n  removeClass,\n  hasClass,\n  toggleClass,\n  attr,\n  removeAttr,\n  transform,\n  transition,\n  on,\n  off,\n  trigger,\n  transitionEnd,\n  outerWidth,\n  outerHeight,\n  styles,\n  offset,\n  css,\n  each,\n  html,\n  text,\n  is,\n  index,\n  eq,\n  append,\n  prepend,\n  next,\n  nextAll,\n  prev,\n  prevAll,\n  parent,\n  parents,\n  closest,\n  find,\n  children,\n  filter,\n  remove\n};\nObject.keys(Methods).forEach(methodName => {\n  Object.defineProperty($.fn, methodName, {\n    value: Methods[methodName],\n    writable: true\n  });\n});\nexport default $;","import { getWindow } from 'ssr-window';\n\nfunction deleteProps(obj) {\n  const object = obj;\n  Object.keys(object).forEach(key => {\n    try {\n      object[key] = null;\n    } catch (e) {// no getter for object\n    }\n\n    try {\n      delete object[key];\n    } catch (e) {// something got wrong\n    }\n  });\n}\n\nfunction nextTick(callback, delay = 0) {\n  return setTimeout(callback, delay);\n}\n\nfunction now() {\n  return Date.now();\n}\n\nfunction getComputedStyle(el) {\n  const window = getWindow();\n  let style;\n\n  if (window.getComputedStyle) {\n    style = window.getComputedStyle(el, null);\n  }\n\n  if (!style && el.currentStyle) {\n    style = el.currentStyle;\n  }\n\n  if (!style) {\n    style = el.style;\n  }\n\n  return style;\n}\n\nfunction getTranslate(el, axis = 'x') {\n  const window = getWindow();\n  let matrix;\n  let curTransform;\n  let transformMatrix;\n  const curStyle = getComputedStyle(el, null);\n\n  if (window.WebKitCSSMatrix) {\n    curTransform = curStyle.transform || curStyle.webkitTransform;\n\n    if (curTransform.split(',').length > 6) {\n      curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n    } // Some old versions of Webkit choke when 'none' is passed; pass\n    // empty string instead in this case\n\n\n    transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n  } else {\n    transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n    matrix = transformMatrix.toString().split(',');\n  }\n\n  if (axis === 'x') {\n    // Latest Chrome and webkits Fix\n    if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix\n    else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers\n    else curTransform = parseFloat(matrix[4]);\n  }\n\n  if (axis === 'y') {\n    // Latest Chrome and webkits Fix\n    if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix\n    else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers\n    else curTransform = parseFloat(matrix[5]);\n  }\n\n  return curTransform || 0;\n}\n\nfunction isObject(o) {\n  return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction isNode(node) {\n  // eslint-disable-next-line\n  if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {\n    return node instanceof HTMLElement;\n  }\n\n  return node && (node.nodeType === 1 || node.nodeType === 11);\n}\n\nfunction extend(...args) {\n  const to = Object(args[0]);\n  const noExtend = ['__proto__', 'constructor', 'prototype'];\n\n  for (let i = 1; i < args.length; i += 1) {\n    const nextSource = args[i];\n\n    if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n      const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\n\n      for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n        const nextKey = keysArray[nextIndex];\n        const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n\n        if (desc !== undefined && desc.enumerable) {\n          if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n            if (nextSource[nextKey].__swiper__) {\n              to[nextKey] = nextSource[nextKey];\n            } else {\n              extend(to[nextKey], nextSource[nextKey]);\n            }\n          } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n            to[nextKey] = {};\n\n            if (nextSource[nextKey].__swiper__) {\n              to[nextKey] = nextSource[nextKey];\n            } else {\n              extend(to[nextKey], nextSource[nextKey]);\n            }\n          } else {\n            to[nextKey] = nextSource[nextKey];\n          }\n        }\n      }\n    }\n  }\n\n  return to;\n}\n\nfunction setCSSProperty(el, varName, varValue) {\n  el.style.setProperty(varName, varValue);\n}\n\nfunction animateCSSModeScroll({\n  swiper,\n  targetPosition,\n  side\n}) {\n  const window = getWindow();\n  const startPosition = -swiper.translate;\n  let startTime = null;\n  let time;\n  const duration = swiper.params.speed;\n  swiper.wrapperEl.style.scrollSnapType = 'none';\n  window.cancelAnimationFrame(swiper.cssModeFrameID);\n  const dir = targetPosition > startPosition ? 'next' : 'prev';\n\n  const isOutOfBound = (current, target) => {\n    return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n  };\n\n  const animate = () => {\n    time = new Date().getTime();\n\n    if (startTime === null) {\n      startTime = time;\n    }\n\n    const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n    const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;\n    let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);\n\n    if (isOutOfBound(currentPosition, targetPosition)) {\n      currentPosition = targetPosition;\n    }\n\n    swiper.wrapperEl.scrollTo({\n      [side]: currentPosition\n    });\n\n    if (isOutOfBound(currentPosition, targetPosition)) {\n      swiper.wrapperEl.style.overflow = 'hidden';\n      swiper.wrapperEl.style.scrollSnapType = '';\n      setTimeout(() => {\n        swiper.wrapperEl.style.overflow = '';\n        swiper.wrapperEl.scrollTo({\n          [side]: currentPosition\n        });\n      });\n      window.cancelAnimationFrame(swiper.cssModeFrameID);\n      return;\n    }\n\n    swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n  };\n\n  animate();\n}\n\nexport { animateCSSModeScroll, deleteProps, nextTick, now, getTranslate, isObject, extend, getComputedStyle, setCSSProperty };","import { getWindow, getDocument } from 'ssr-window';\nlet support;\n\nfunction calcSupport() {\n  const window = getWindow();\n  const document = getDocument();\n  return {\n    smoothScroll: document.documentElement && 'scrollBehavior' in document.documentElement.style,\n    touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch),\n    passiveListener: function checkPassiveListener() {\n      let supportsPassive = false;\n\n      try {\n        const opts = Object.defineProperty({}, 'passive', {\n          // eslint-disable-next-line\n          get() {\n            supportsPassive = true;\n          }\n\n        });\n        window.addEventListener('testPassiveListener', null, opts);\n      } catch (e) {// No support\n      }\n\n      return supportsPassive;\n    }(),\n    gestures: function checkGestures() {\n      return 'ongesturestart' in window;\n    }()\n  };\n}\n\nfunction getSupport() {\n  if (!support) {\n    support = calcSupport();\n  }\n\n  return support;\n}\n\nexport { getSupport };","import { getWindow } from 'ssr-window';\nimport { getSupport } from './get-support.js';\nlet deviceCached;\n\nfunction calcDevice({\n  userAgent\n} = {}) {\n  const support = getSupport();\n  const window = getWindow();\n  const platform = window.navigator.platform;\n  const ua = userAgent || window.navigator.userAgent;\n  const device = {\n    ios: false,\n    android: false\n  };\n  const screenWidth = window.screen.width;\n  const screenHeight = window.screen.height;\n  const android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n\n  let ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n  const ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n  const iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n  const windows = platform === 'Win32';\n  let macos = platform === 'MacIntel'; // iPadOs 13 fix\n\n  const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\n\n  if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n    ipad = ua.match(/(Version)\\/([\\d.]+)/);\n    if (!ipad) ipad = [0, 1, '13_0_0'];\n    macos = false;\n  } // Android\n\n\n  if (android && !windows) {\n    device.os = 'android';\n    device.android = true;\n  }\n\n  if (ipad || iphone || ipod) {\n    device.os = 'ios';\n    device.ios = true;\n  } // Export object\n\n\n  return device;\n}\n\nfunction getDevice(overrides = {}) {\n  if (!deviceCached) {\n    deviceCached = calcDevice(overrides);\n  }\n\n  return deviceCached;\n}\n\nexport { getDevice };","import { getWindow } from 'ssr-window';\nlet browser;\n\nfunction calcBrowser() {\n  const window = getWindow();\n\n  function isSafari() {\n    const ua = window.navigator.userAgent.toLowerCase();\n    return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;\n  }\n\n  return {\n    isSafari: isSafari(),\n    isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n  };\n}\n\nfunction getBrowser() {\n  if (!browser) {\n    browser = calcBrowser();\n  }\n\n  return browser;\n}\n\nexport { getBrowser };","import { getWindow } from 'ssr-window';\nexport default function Resize({\n  swiper,\n  on,\n  emit\n}) {\n  const window = getWindow();\n  let observer = null;\n  let animationFrame = null;\n\n  const resizeHandler = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    emit('beforeResize');\n    emit('resize');\n  };\n\n  const createObserver = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    observer = new ResizeObserver(entries => {\n      animationFrame = window.requestAnimationFrame(() => {\n        const {\n          width,\n          height\n        } = swiper;\n        let newWidth = width;\n        let newHeight = height;\n        entries.forEach(({\n          contentBoxSize,\n          contentRect,\n          target\n        }) => {\n          if (target && target !== swiper.el) return;\n          newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;\n          newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;\n        });\n\n        if (newWidth !== width || newHeight !== height) {\n          resizeHandler();\n        }\n      });\n    });\n    observer.observe(swiper.el);\n  };\n\n  const removeObserver = () => {\n    if (animationFrame) {\n      window.cancelAnimationFrame(animationFrame);\n    }\n\n    if (observer && observer.unobserve && swiper.el) {\n      observer.unobserve(swiper.el);\n      observer = null;\n    }\n  };\n\n  const orientationChangeHandler = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    emit('orientationchange');\n  };\n\n  on('init', () => {\n    if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n      createObserver();\n      return;\n    }\n\n    window.addEventListener('resize', resizeHandler);\n    window.addEventListener('orientationchange', orientationChangeHandler);\n  });\n  on('destroy', () => {\n    removeObserver();\n    window.removeEventListener('resize', resizeHandler);\n    window.removeEventListener('orientationchange', orientationChangeHandler);\n  });\n}","import { getWindow } from 'ssr-window';\nexport default function Observer({\n  swiper,\n  extendParams,\n  on,\n  emit\n}) {\n  const observers = [];\n  const window = getWindow();\n\n  const attach = (target, options = {}) => {\n    const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;\n    const observer = new ObserverFunc(mutations => {\n      // The observerUpdate event should only be triggered\n      // once despite the number of mutations.  Additional\n      // triggers are redundant and are very costly\n      if (mutations.length === 1) {\n        emit('observerUpdate', mutations[0]);\n        return;\n      }\n\n      const observerUpdate = function observerUpdate() {\n        emit('observerUpdate', mutations[0]);\n      };\n\n      if (window.requestAnimationFrame) {\n        window.requestAnimationFrame(observerUpdate);\n      } else {\n        window.setTimeout(observerUpdate, 0);\n      }\n    });\n    observer.observe(target, {\n      attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n      childList: typeof options.childList === 'undefined' ? true : options.childList,\n      characterData: typeof options.characterData === 'undefined' ? true : options.characterData\n    });\n    observers.push(observer);\n  };\n\n  const init = () => {\n    if (!swiper.params.observer) return;\n\n    if (swiper.params.observeParents) {\n      const containerParents = swiper.$el.parents();\n\n      for (let i = 0; i < containerParents.length; i += 1) {\n        attach(containerParents[i]);\n      }\n    } // Observe container\n\n\n    attach(swiper.$el[0], {\n      childList: swiper.params.observeSlideChildren\n    }); // Observe wrapper\n\n    attach(swiper.$wrapperEl[0], {\n      attributes: false\n    });\n  };\n\n  const destroy = () => {\n    observers.forEach(observer => {\n      observer.disconnect();\n    });\n    observers.splice(0, observers.length);\n  };\n\n  extendParams({\n    observer: false,\n    observeParents: false,\n    observeSlideChildren: false\n  });\n  on('init', init);\n  on('destroy', destroy);\n}","/* eslint-disable no-underscore-dangle */\nexport default {\n  on(events, handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n    const method = priority ? 'unshift' : 'push';\n    events.split(' ').forEach(event => {\n      if (!self.eventsListeners[event]) self.eventsListeners[event] = [];\n      self.eventsListeners[event][method](handler);\n    });\n    return self;\n  },\n\n  once(events, handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n\n    function onceHandler(...args) {\n      self.off(events, onceHandler);\n\n      if (onceHandler.__emitterProxy) {\n        delete onceHandler.__emitterProxy;\n      }\n\n      handler.apply(self, args);\n    }\n\n    onceHandler.__emitterProxy = handler;\n    return self.on(events, onceHandler, priority);\n  },\n\n  onAny(handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n    const method = priority ? 'unshift' : 'push';\n\n    if (self.eventsAnyListeners.indexOf(handler) < 0) {\n      self.eventsAnyListeners[method](handler);\n    }\n\n    return self;\n  },\n\n  offAny(handler) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsAnyListeners) return self;\n    const index = self.eventsAnyListeners.indexOf(handler);\n\n    if (index >= 0) {\n      self.eventsAnyListeners.splice(index, 1);\n    }\n\n    return self;\n  },\n\n  off(events, handler) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsListeners) return self;\n    events.split(' ').forEach(event => {\n      if (typeof handler === 'undefined') {\n        self.eventsListeners[event] = [];\n      } else if (self.eventsListeners[event]) {\n        self.eventsListeners[event].forEach((eventHandler, index) => {\n          if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {\n            self.eventsListeners[event].splice(index, 1);\n          }\n        });\n      }\n    });\n    return self;\n  },\n\n  emit(...args) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsListeners) return self;\n    let events;\n    let data;\n    let context;\n\n    if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n      events = args[0];\n      data = args.slice(1, args.length);\n      context = self;\n    } else {\n      events = args[0].events;\n      data = args[0].data;\n      context = args[0].context || self;\n    }\n\n    data.unshift(context);\n    const eventsArray = Array.isArray(events) ? events : events.split(' ');\n    eventsArray.forEach(event => {\n      if (self.eventsAnyListeners && self.eventsAnyListeners.length) {\n        self.eventsAnyListeners.forEach(eventHandler => {\n          eventHandler.apply(context, [event, ...data]);\n        });\n      }\n\n      if (self.eventsListeners && self.eventsListeners[event]) {\n        self.eventsListeners[event].forEach(eventHandler => {\n          eventHandler.apply(context, data);\n        });\n      }\n    });\n    return self;\n  }\n\n};","export default function updateSize() {\n  const swiper = this;\n  let width;\n  let height;\n  const $el = swiper.$el;\n\n  if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n    width = swiper.params.width;\n  } else {\n    width = $el[0].clientWidth;\n  }\n\n  if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n    height = swiper.params.height;\n  } else {\n    height = $el[0].clientHeight;\n  }\n\n  if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n    return;\n  } // Subtract paddings\n\n\n  width = width - parseInt($el.css('padding-left') || 0, 10) - parseInt($el.css('padding-right') || 0, 10);\n  height = height - parseInt($el.css('padding-top') || 0, 10) - parseInt($el.css('padding-bottom') || 0, 10);\n  if (Number.isNaN(width)) width = 0;\n  if (Number.isNaN(height)) height = 0;\n  Object.assign(swiper, {\n    width,\n    height,\n    size: swiper.isHorizontal() ? width : height\n  });\n}","import { setCSSProperty } from '../../shared/utils.js';\nexport default function updateSlides() {\n  const swiper = this;\n\n  function getDirectionLabel(property) {\n    if (swiper.isHorizontal()) {\n      return property;\n    } // prettier-ignore\n\n\n    return {\n      'width': 'height',\n      'margin-top': 'margin-left',\n      'margin-bottom ': 'margin-right',\n      'margin-left': 'margin-top',\n      'margin-right': 'margin-bottom',\n      'padding-left': 'padding-top',\n      'padding-right': 'padding-bottom',\n      'marginRight': 'marginBottom'\n    }[property];\n  }\n\n  function getDirectionPropertyValue(node, label) {\n    return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);\n  }\n\n  const params = swiper.params;\n  const {\n    $wrapperEl,\n    size: swiperSize,\n    rtlTranslate: rtl,\n    wrongRTL\n  } = swiper;\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n  const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);\n  const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n  let snapGrid = [];\n  const slidesGrid = [];\n  const slidesSizesGrid = [];\n  let offsetBefore = params.slidesOffsetBefore;\n\n  if (typeof offsetBefore === 'function') {\n    offsetBefore = params.slidesOffsetBefore.call(swiper);\n  }\n\n  let offsetAfter = params.slidesOffsetAfter;\n\n  if (typeof offsetAfter === 'function') {\n    offsetAfter = params.slidesOffsetAfter.call(swiper);\n  }\n\n  const previousSnapGridLength = swiper.snapGrid.length;\n  const previousSlidesGridLength = swiper.slidesGrid.length;\n  let spaceBetween = params.spaceBetween;\n  let slidePosition = -offsetBefore;\n  let prevSlideSize = 0;\n  let index = 0;\n\n  if (typeof swiperSize === 'undefined') {\n    return;\n  }\n\n  if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n    spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n  }\n\n  swiper.virtualSize = -spaceBetween; // reset margins\n\n  if (rtl) slides.css({\n    marginLeft: '',\n    marginBottom: '',\n    marginTop: ''\n  });else slides.css({\n    marginRight: '',\n    marginBottom: '',\n    marginTop: ''\n  }); // reset cssMode offsets\n\n  if (params.centeredSlides && params.cssMode) {\n    setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');\n    setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', '');\n  }\n\n  const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n\n  if (gridEnabled) {\n    swiper.grid.initSlides(slidesLength);\n  } // Calc slides\n\n\n  let slideSize;\n  const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {\n    return typeof params.breakpoints[key].slidesPerView !== 'undefined';\n  }).length > 0;\n\n  for (let i = 0; i < slidesLength; i += 1) {\n    slideSize = 0;\n    const slide = slides.eq(i);\n\n    if (gridEnabled) {\n      swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n    }\n\n    if (slide.css('display') === 'none') continue; // eslint-disable-line\n\n    if (params.slidesPerView === 'auto') {\n      if (shouldResetSlideSize) {\n        slides[i].style[getDirectionLabel('width')] = ``;\n      }\n\n      const slideStyles = getComputedStyle(slide[0]);\n      const currentTransform = slide[0].style.transform;\n      const currentWebKitTransform = slide[0].style.webkitTransform;\n\n      if (currentTransform) {\n        slide[0].style.transform = 'none';\n      }\n\n      if (currentWebKitTransform) {\n        slide[0].style.webkitTransform = 'none';\n      }\n\n      if (params.roundLengths) {\n        slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);\n      } else {\n        // eslint-disable-next-line\n        const width = getDirectionPropertyValue(slideStyles, 'width');\n        const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');\n        const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');\n        const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');\n        const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');\n        const boxSizing = slideStyles.getPropertyValue('box-sizing');\n\n        if (boxSizing && boxSizing === 'border-box') {\n          slideSize = width + marginLeft + marginRight;\n        } else {\n          const {\n            clientWidth,\n            offsetWidth\n          } = slide[0];\n          slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n        }\n      }\n\n      if (currentTransform) {\n        slide[0].style.transform = currentTransform;\n      }\n\n      if (currentWebKitTransform) {\n        slide[0].style.webkitTransform = currentWebKitTransform;\n      }\n\n      if (params.roundLengths) slideSize = Math.floor(slideSize);\n    } else {\n      slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;\n      if (params.roundLengths) slideSize = Math.floor(slideSize);\n\n      if (slides[i]) {\n        slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;\n      }\n    }\n\n    if (slides[i]) {\n      slides[i].swiperSlideSize = slideSize;\n    }\n\n    slidesSizesGrid.push(slideSize);\n\n    if (params.centeredSlides) {\n      slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;\n      if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n      if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n      if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;\n      if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n      if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n      slidesGrid.push(slidePosition);\n    } else {\n      if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n      if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n      slidesGrid.push(slidePosition);\n      slidePosition = slidePosition + slideSize + spaceBetween;\n    }\n\n    swiper.virtualSize += slideSize + spaceBetween;\n    prevSlideSize = slideSize;\n    index += 1;\n  }\n\n  swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n\n  if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n    $wrapperEl.css({\n      width: `${swiper.virtualSize + params.spaceBetween}px`\n    });\n  }\n\n  if (params.setWrapperSize) {\n    $wrapperEl.css({\n      [getDirectionLabel('width')]: `${swiper.virtualSize + params.spaceBetween}px`\n    });\n  }\n\n  if (gridEnabled) {\n    swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\n  } // Remove last grid elements depending on width\n\n\n  if (!params.centeredSlides) {\n    const newSlidesGrid = [];\n\n    for (let i = 0; i < snapGrid.length; i += 1) {\n      let slidesGridItem = snapGrid[i];\n      if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n\n      if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n        newSlidesGrid.push(slidesGridItem);\n      }\n    }\n\n    snapGrid = newSlidesGrid;\n\n    if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n      snapGrid.push(swiper.virtualSize - swiperSize);\n    }\n  }\n\n  if (snapGrid.length === 0) snapGrid = [0];\n\n  if (params.spaceBetween !== 0) {\n    const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');\n    slides.filter((_, slideIndex) => {\n      if (!params.cssMode) return true;\n\n      if (slideIndex === slides.length - 1) {\n        return false;\n      }\n\n      return true;\n    }).css({\n      [key]: `${spaceBetween}px`\n    });\n  }\n\n  if (params.centeredSlides && params.centeredSlidesBounds) {\n    let allSlidesSize = 0;\n    slidesSizesGrid.forEach(slideSizeValue => {\n      allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n    });\n    allSlidesSize -= params.spaceBetween;\n    const maxSnap = allSlidesSize - swiperSize;\n    snapGrid = snapGrid.map(snap => {\n      if (snap < 0) return -offsetBefore;\n      if (snap > maxSnap) return maxSnap + offsetAfter;\n      return snap;\n    });\n  }\n\n  if (params.centerInsufficientSlides) {\n    let allSlidesSize = 0;\n    slidesSizesGrid.forEach(slideSizeValue => {\n      allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n    });\n    allSlidesSize -= params.spaceBetween;\n\n    if (allSlidesSize < swiperSize) {\n      const allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n      snapGrid.forEach((snap, snapIndex) => {\n        snapGrid[snapIndex] = snap - allSlidesOffset;\n      });\n      slidesGrid.forEach((snap, snapIndex) => {\n        slidesGrid[snapIndex] = snap + allSlidesOffset;\n      });\n    }\n  }\n\n  Object.assign(swiper, {\n    slides,\n    snapGrid,\n    slidesGrid,\n    slidesSizesGrid\n  });\n\n  if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n    setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n    setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n    const addToSnapGrid = -swiper.snapGrid[0];\n    const addToSlidesGrid = -swiper.slidesGrid[0];\n    swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);\n    swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);\n  }\n\n  if (slidesLength !== previousSlidesLength) {\n    swiper.emit('slidesLengthChange');\n  }\n\n  if (snapGrid.length !== previousSnapGridLength) {\n    if (swiper.params.watchOverflow) swiper.checkOverflow();\n    swiper.emit('snapGridLengthChange');\n  }\n\n  if (slidesGrid.length !== previousSlidesGridLength) {\n    swiper.emit('slidesGridLengthChange');\n  }\n\n  if (params.watchSlidesProgress) {\n    swiper.updateSlidesOffset();\n  }\n\n  if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {\n    const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;\n    const hasClassBackfaceClassAdded = swiper.$el.hasClass(backFaceHiddenClass);\n\n    if (slidesLength <= params.maxBackfaceHiddenSlides) {\n      if (!hasClassBackfaceClassAdded) swiper.$el.addClass(backFaceHiddenClass);\n    } else if (hasClassBackfaceClassAdded) {\n      swiper.$el.removeClass(backFaceHiddenClass);\n    }\n  }\n}","import $ from '../../shared/dom.js';\nexport default function updateAutoHeight(speed) {\n  const swiper = this;\n  const activeSlides = [];\n  const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n  let newHeight = 0;\n  let i;\n\n  if (typeof speed === 'number') {\n    swiper.setTransition(speed);\n  } else if (speed === true) {\n    swiper.setTransition(swiper.params.speed);\n  }\n\n  const getSlideByIndex = index => {\n    if (isVirtual) {\n      return swiper.slides.filter(el => parseInt(el.getAttribute('data-swiper-slide-index'), 10) === index)[0];\n    }\n\n    return swiper.slides.eq(index)[0];\n  }; // Find slides currently in view\n\n\n  if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n    if (swiper.params.centeredSlides) {\n      (swiper.visibleSlides || $([])).each(slide => {\n        activeSlides.push(slide);\n      });\n    } else {\n      for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n        const index = swiper.activeIndex + i;\n        if (index > swiper.slides.length && !isVirtual) break;\n        activeSlides.push(getSlideByIndex(index));\n      }\n    }\n  } else {\n    activeSlides.push(getSlideByIndex(swiper.activeIndex));\n  } // Find new height from highest slide in view\n\n\n  for (i = 0; i < activeSlides.length; i += 1) {\n    if (typeof activeSlides[i] !== 'undefined') {\n      const height = activeSlides[i].offsetHeight;\n      newHeight = height > newHeight ? height : newHeight;\n    }\n  } // Update Height\n\n\n  if (newHeight || newHeight === 0) swiper.$wrapperEl.css('height', `${newHeight}px`);\n}","export default function updateSlidesOffset() {\n  const swiper = this;\n  const slides = swiper.slides;\n\n  for (let i = 0; i < slides.length; i += 1) {\n    slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n  }\n}","import $ from '../../shared/dom.js';\nexport default function updateSlidesProgress(translate = this && this.translate || 0) {\n  const swiper = this;\n  const params = swiper.params;\n  const {\n    slides,\n    rtlTranslate: rtl,\n    snapGrid\n  } = swiper;\n  if (slides.length === 0) return;\n  if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();\n  let offsetCenter = -translate;\n  if (rtl) offsetCenter = translate; // Visible Slides\n\n  slides.removeClass(params.slideVisibleClass);\n  swiper.visibleSlidesIndexes = [];\n  swiper.visibleSlides = [];\n\n  for (let i = 0; i < slides.length; i += 1) {\n    const slide = slides[i];\n    let slideOffset = slide.swiperSlideOffset;\n\n    if (params.cssMode && params.centeredSlides) {\n      slideOffset -= slides[0].swiperSlideOffset;\n    }\n\n    const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n    const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n    const slideBefore = -(offsetCenter - slideOffset);\n    const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n    const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n\n    if (isVisible) {\n      swiper.visibleSlides.push(slide);\n      swiper.visibleSlidesIndexes.push(i);\n      slides.eq(i).addClass(params.slideVisibleClass);\n    }\n\n    slide.progress = rtl ? -slideProgress : slideProgress;\n    slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n  }\n\n  swiper.visibleSlides = $(swiper.visibleSlides);\n}","export default function updateProgress(translate) {\n  const swiper = this;\n\n  if (typeof translate === 'undefined') {\n    const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line\n\n    translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n  }\n\n  const params = swiper.params;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n  let {\n    progress,\n    isBeginning,\n    isEnd\n  } = swiper;\n  const wasBeginning = isBeginning;\n  const wasEnd = isEnd;\n\n  if (translatesDiff === 0) {\n    progress = 0;\n    isBeginning = true;\n    isEnd = true;\n  } else {\n    progress = (translate - swiper.minTranslate()) / translatesDiff;\n    isBeginning = progress <= 0;\n    isEnd = progress >= 1;\n  }\n\n  Object.assign(swiper, {\n    progress,\n    isBeginning,\n    isEnd\n  });\n  if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n\n  if (isBeginning && !wasBeginning) {\n    swiper.emit('reachBeginning toEdge');\n  }\n\n  if (isEnd && !wasEnd) {\n    swiper.emit('reachEnd toEdge');\n  }\n\n  if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n    swiper.emit('fromEdge');\n  }\n\n  swiper.emit('progress', progress);\n}","export default function updateSlidesClasses() {\n  const swiper = this;\n  const {\n    slides,\n    params,\n    $wrapperEl,\n    activeIndex,\n    realIndex\n  } = swiper;\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);\n  let activeSlide;\n\n  if (isVirtual) {\n    activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index=\"${activeIndex}\"]`);\n  } else {\n    activeSlide = slides.eq(activeIndex);\n  } // Active classes\n\n\n  activeSlide.addClass(params.slideActiveClass);\n\n  if (params.loop) {\n    // Duplicate to all looped slides\n    if (activeSlide.hasClass(params.slideDuplicateClass)) {\n      $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n    } else {\n      $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n    }\n  } // Next Slide\n\n\n  let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);\n\n  if (params.loop && nextSlide.length === 0) {\n    nextSlide = slides.eq(0);\n    nextSlide.addClass(params.slideNextClass);\n  } // Prev Slide\n\n\n  let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);\n\n  if (params.loop && prevSlide.length === 0) {\n    prevSlide = slides.eq(-1);\n    prevSlide.addClass(params.slidePrevClass);\n  }\n\n  if (params.loop) {\n    // Duplicate to all looped slides\n    if (nextSlide.hasClass(params.slideDuplicateClass)) {\n      $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n    } else {\n      $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n    }\n\n    if (prevSlide.hasClass(params.slideDuplicateClass)) {\n      $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n    } else {\n      $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n    }\n  }\n\n  swiper.emitSlidesClasses();\n}","export default function updateActiveIndex(newActiveIndex) {\n  const swiper = this;\n  const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n  const {\n    slidesGrid,\n    snapGrid,\n    params,\n    activeIndex: previousIndex,\n    realIndex: previousRealIndex,\n    snapIndex: previousSnapIndex\n  } = swiper;\n  let activeIndex = newActiveIndex;\n  let snapIndex;\n\n  if (typeof activeIndex === 'undefined') {\n    for (let i = 0; i < slidesGrid.length; i += 1) {\n      if (typeof slidesGrid[i + 1] !== 'undefined') {\n        if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {\n          activeIndex = i;\n        } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n          activeIndex = i + 1;\n        }\n      } else if (translate >= slidesGrid[i]) {\n        activeIndex = i;\n      }\n    } // Normalize slideIndex\n\n\n    if (params.normalizeSlideIndex) {\n      if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n    }\n  }\n\n  if (snapGrid.indexOf(translate) >= 0) {\n    snapIndex = snapGrid.indexOf(translate);\n  } else {\n    const skip = Math.min(params.slidesPerGroupSkip, activeIndex);\n    snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);\n  }\n\n  if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n\n  if (activeIndex === previousIndex) {\n    if (snapIndex !== previousSnapIndex) {\n      swiper.snapIndex = snapIndex;\n      swiper.emit('snapIndexChange');\n    }\n\n    return;\n  } // Get real index\n\n\n  const realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n  Object.assign(swiper, {\n    snapIndex,\n    realIndex,\n    previousIndex,\n    activeIndex\n  });\n  swiper.emit('activeIndexChange');\n  swiper.emit('snapIndexChange');\n\n  if (previousRealIndex !== realIndex) {\n    swiper.emit('realIndexChange');\n  }\n\n  if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n    swiper.emit('slideChange');\n  }\n}","import $ from '../../shared/dom.js';\nexport default function updateClickedSlide(e) {\n  const swiper = this;\n  const params = swiper.params;\n  const slide = $(e).closest(`.${params.slideClass}`)[0];\n  let slideFound = false;\n  let slideIndex;\n\n  if (slide) {\n    for (let i = 0; i < swiper.slides.length; i += 1) {\n      if (swiper.slides[i] === slide) {\n        slideFound = true;\n        slideIndex = i;\n        break;\n      }\n    }\n  }\n\n  if (slide && slideFound) {\n    swiper.clickedSlide = slide;\n\n    if (swiper.virtual && swiper.params.virtual.enabled) {\n      swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n    } else {\n      swiper.clickedIndex = slideIndex;\n    }\n  } else {\n    swiper.clickedSlide = undefined;\n    swiper.clickedIndex = undefined;\n    return;\n  }\n\n  if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n    swiper.slideToClickedSlide();\n  }\n}","import updateSize from './updateSize.js';\nimport updateSlides from './updateSlides.js';\nimport updateAutoHeight from './updateAutoHeight.js';\nimport updateSlidesOffset from './updateSlidesOffset.js';\nimport updateSlidesProgress from './updateSlidesProgress.js';\nimport updateProgress from './updateProgress.js';\nimport updateSlidesClasses from './updateSlidesClasses.js';\nimport updateActiveIndex from './updateActiveIndex.js';\nimport updateClickedSlide from './updateClickedSlide.js';\nexport default {\n  updateSize,\n  updateSlides,\n  updateAutoHeight,\n  updateSlidesOffset,\n  updateSlidesProgress,\n  updateProgress,\n  updateSlidesClasses,\n  updateActiveIndex,\n  updateClickedSlide\n};","import { getTranslate } from '../../shared/utils.js';\nexport default function getSwiperTranslate(axis = this.isHorizontal() ? 'x' : 'y') {\n  const swiper = this;\n  const {\n    params,\n    rtlTranslate: rtl,\n    translate,\n    $wrapperEl\n  } = swiper;\n\n  if (params.virtualTranslate) {\n    return rtl ? -translate : translate;\n  }\n\n  if (params.cssMode) {\n    return translate;\n  }\n\n  let currentTranslate = getTranslate($wrapperEl[0], axis);\n  if (rtl) currentTranslate = -currentTranslate;\n  return currentTranslate || 0;\n}","export default function setTranslate(translate, byController) {\n  const swiper = this;\n  const {\n    rtlTranslate: rtl,\n    params,\n    $wrapperEl,\n    wrapperEl,\n    progress\n  } = swiper;\n  let x = 0;\n  let y = 0;\n  const z = 0;\n\n  if (swiper.isHorizontal()) {\n    x = rtl ? -translate : translate;\n  } else {\n    y = translate;\n  }\n\n  if (params.roundLengths) {\n    x = Math.floor(x);\n    y = Math.floor(y);\n  }\n\n  if (params.cssMode) {\n    wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n  } else if (!params.virtualTranslate) {\n    $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);\n  }\n\n  swiper.previousTranslate = swiper.translate;\n  swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress\n\n  let newProgress;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n  if (translatesDiff === 0) {\n    newProgress = 0;\n  } else {\n    newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n  }\n\n  if (newProgress !== progress) {\n    swiper.updateProgress(translate);\n  }\n\n  swiper.emit('setTranslate', swiper.translate, byController);\n}","export default function minTranslate() {\n  return -this.snapGrid[0];\n}","export default function maxTranslate() {\n  return -this.snapGrid[this.snapGrid.length - 1];\n}","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function translateTo(translate = 0, speed = this.params.speed, runCallbacks = true, translateBounds = true, internal) {\n  const swiper = this;\n  const {\n    params,\n    wrapperEl\n  } = swiper;\n\n  if (swiper.animating && params.preventInteractionOnTransition) {\n    return false;\n  }\n\n  const minTranslate = swiper.minTranslate();\n  const maxTranslate = swiper.maxTranslate();\n  let newTranslate;\n  if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate; // Update progress\n\n  swiper.updateProgress(newTranslate);\n\n  if (params.cssMode) {\n    const isH = swiper.isHorizontal();\n\n    if (speed === 0) {\n      wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;\n    } else {\n      if (!swiper.support.smoothScroll) {\n        animateCSSModeScroll({\n          swiper,\n          targetPosition: -newTranslate,\n          side: isH ? 'left' : 'top'\n        });\n        return true;\n      }\n\n      wrapperEl.scrollTo({\n        [isH ? 'left' : 'top']: -newTranslate,\n        behavior: 'smooth'\n      });\n    }\n\n    return true;\n  }\n\n  if (speed === 0) {\n    swiper.setTransition(0);\n    swiper.setTranslate(newTranslate);\n\n    if (runCallbacks) {\n      swiper.emit('beforeTransitionStart', speed, internal);\n      swiper.emit('transitionEnd');\n    }\n  } else {\n    swiper.setTransition(speed);\n    swiper.setTranslate(newTranslate);\n\n    if (runCallbacks) {\n      swiper.emit('beforeTransitionStart', speed, internal);\n      swiper.emit('transitionStart');\n    }\n\n    if (!swiper.animating) {\n      swiper.animating = true;\n\n      if (!swiper.onTranslateToWrapperTransitionEnd) {\n        swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n          if (!swiper || swiper.destroyed) return;\n          if (e.target !== this) return;\n          swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n          swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n          swiper.onTranslateToWrapperTransitionEnd = null;\n          delete swiper.onTranslateToWrapperTransitionEnd;\n\n          if (runCallbacks) {\n            swiper.emit('transitionEnd');\n          }\n        };\n      }\n\n      swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n      swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n    }\n  }\n\n  return true;\n}","import getTranslate from './getTranslate.js';\nimport setTranslate from './setTranslate.js';\nimport minTranslate from './minTranslate.js';\nimport maxTranslate from './maxTranslate.js';\nimport translateTo from './translateTo.js';\nexport default {\n  getTranslate,\n  setTranslate,\n  minTranslate,\n  maxTranslate,\n  translateTo\n};","export default function setTransition(duration, byController) {\n  const swiper = this;\n\n  if (!swiper.params.cssMode) {\n    swiper.$wrapperEl.transition(duration);\n  }\n\n  swiper.emit('setTransition', duration, byController);\n}","export default function transitionEmit({\n  swiper,\n  runCallbacks,\n  direction,\n  step\n}) {\n  const {\n    activeIndex,\n    previousIndex\n  } = swiper;\n  let dir = direction;\n\n  if (!dir) {\n    if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n  }\n\n  swiper.emit(`transition${step}`);\n\n  if (runCallbacks && activeIndex !== previousIndex) {\n    if (dir === 'reset') {\n      swiper.emit(`slideResetTransition${step}`);\n      return;\n    }\n\n    swiper.emit(`slideChangeTransition${step}`);\n\n    if (dir === 'next') {\n      swiper.emit(`slideNextTransition${step}`);\n    } else {\n      swiper.emit(`slidePrevTransition${step}`);\n    }\n  }\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionStart(runCallbacks = true, direction) {\n  const swiper = this;\n  const {\n    params\n  } = swiper;\n  if (params.cssMode) return;\n\n  if (params.autoHeight) {\n    swiper.updateAutoHeight();\n  }\n\n  transitionEmit({\n    swiper,\n    runCallbacks,\n    direction,\n    step: 'Start'\n  });\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionEnd(runCallbacks = true, direction) {\n  const swiper = this;\n  const {\n    params\n  } = swiper;\n  swiper.animating = false;\n  if (params.cssMode) return;\n  swiper.setTransition(0);\n  transitionEmit({\n    swiper,\n    runCallbacks,\n    direction,\n    step: 'End'\n  });\n}","import setTransition from './setTransition.js';\nimport transitionStart from './transitionStart.js';\nimport transitionEnd from './transitionEnd.js';\nexport default {\n  setTransition,\n  transitionStart,\n  transitionEnd\n};","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function slideTo(index = 0, speed = this.params.speed, runCallbacks = true, internal, initial) {\n  if (typeof index !== 'number' && typeof index !== 'string') {\n    throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);\n  }\n\n  if (typeof index === 'string') {\n    /**\n     * The `index` argument converted from `string` to `number`.\n     * @type {number}\n     */\n    const indexAsNumber = parseInt(index, 10);\n    /**\n     * Determines whether the `index` argument is a valid `number`\n     * after being converted from the `string` type.\n     * @type {boolean}\n     */\n\n    const isValidNumber = isFinite(indexAsNumber);\n\n    if (!isValidNumber) {\n      throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n    } // Knowing that the converted `index` is a valid number,\n    // we can update the original argument's value.\n\n\n    index = indexAsNumber;\n  }\n\n  const swiper = this;\n  let slideIndex = index;\n  if (slideIndex < 0) slideIndex = 0;\n  const {\n    params,\n    snapGrid,\n    slidesGrid,\n    previousIndex,\n    activeIndex,\n    rtlTranslate: rtl,\n    wrapperEl,\n    enabled\n  } = swiper;\n\n  if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {\n    return false;\n  }\n\n  const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);\n  let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);\n  if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n  const translate = -snapGrid[snapIndex]; // Normalize slideIndex\n\n  if (params.normalizeSlideIndex) {\n    for (let i = 0; i < slidesGrid.length; i += 1) {\n      const normalizedTranslate = -Math.floor(translate * 100);\n      const normalizedGrid = Math.floor(slidesGrid[i] * 100);\n      const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);\n\n      if (typeof slidesGrid[i + 1] !== 'undefined') {\n        if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {\n          slideIndex = i;\n        } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {\n          slideIndex = i + 1;\n        }\n      } else if (normalizedTranslate >= normalizedGrid) {\n        slideIndex = i;\n      }\n    }\n  } // Directions locks\n\n\n  if (swiper.initialized && slideIndex !== activeIndex) {\n    if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n      return false;\n    }\n\n    if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n      if ((activeIndex || 0) !== slideIndex) return false;\n    }\n  }\n\n  if (slideIndex !== (previousIndex || 0) && runCallbacks) {\n    swiper.emit('beforeSlideChangeStart');\n  } // Update progress\n\n\n  swiper.updateProgress(translate);\n  let direction;\n  if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset'; // Update Index\n\n  if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n    swiper.updateActiveIndex(slideIndex); // Update Height\n\n    if (params.autoHeight) {\n      swiper.updateAutoHeight();\n    }\n\n    swiper.updateSlidesClasses();\n\n    if (params.effect !== 'slide') {\n      swiper.setTranslate(translate);\n    }\n\n    if (direction !== 'reset') {\n      swiper.transitionStart(runCallbacks, direction);\n      swiper.transitionEnd(runCallbacks, direction);\n    }\n\n    return false;\n  }\n\n  if (params.cssMode) {\n    const isH = swiper.isHorizontal();\n    const t = rtl ? translate : -translate;\n\n    if (speed === 0) {\n      const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n      if (isVirtual) {\n        swiper.wrapperEl.style.scrollSnapType = 'none';\n        swiper._immediateVirtual = true;\n      }\n\n      wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n\n      if (isVirtual) {\n        requestAnimationFrame(() => {\n          swiper.wrapperEl.style.scrollSnapType = '';\n          swiper._swiperImmediateVirtual = false;\n        });\n      }\n    } else {\n      if (!swiper.support.smoothScroll) {\n        animateCSSModeScroll({\n          swiper,\n          targetPosition: t,\n          side: isH ? 'left' : 'top'\n        });\n        return true;\n      }\n\n      wrapperEl.scrollTo({\n        [isH ? 'left' : 'top']: t,\n        behavior: 'smooth'\n      });\n    }\n\n    return true;\n  }\n\n  swiper.setTransition(speed);\n  swiper.setTranslate(translate);\n  swiper.updateActiveIndex(slideIndex);\n  swiper.updateSlidesClasses();\n  swiper.emit('beforeTransitionStart', speed, internal);\n  swiper.transitionStart(runCallbacks, direction);\n\n  if (speed === 0) {\n    swiper.transitionEnd(runCallbacks, direction);\n  } else if (!swiper.animating) {\n    swiper.animating = true;\n\n    if (!swiper.onSlideToWrapperTransitionEnd) {\n      swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n        if (!swiper || swiper.destroyed) return;\n        if (e.target !== this) return;\n        swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n        swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n        swiper.onSlideToWrapperTransitionEnd = null;\n        delete swiper.onSlideToWrapperTransitionEnd;\n        swiper.transitionEnd(runCallbacks, direction);\n      };\n    }\n\n    swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n    swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n  }\n\n  return true;\n}","export default function slideToLoop(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n  if (typeof index === 'string') {\n    /**\n     * The `index` argument converted from `string` to `number`.\n     * @type {number}\n     */\n    const indexAsNumber = parseInt(index, 10);\n    /**\n     * Determines whether the `index` argument is a valid `number`\n     * after being converted from the `string` type.\n     * @type {boolean}\n     */\n\n    const isValidNumber = isFinite(indexAsNumber);\n\n    if (!isValidNumber) {\n      throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n    } // Knowing that the converted `index` is a valid number,\n    // we can update the original argument's value.\n\n\n    index = indexAsNumber;\n  }\n\n  const swiper = this;\n  let newIndex = index;\n\n  if (swiper.params.loop) {\n    newIndex += swiper.loopedSlides;\n  }\n\n  return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideNext(speed = this.params.speed, runCallbacks = true, internal) {\n  const swiper = this;\n  const {\n    animating,\n    enabled,\n    params\n  } = swiper;\n  if (!enabled) return swiper;\n  let perGroup = params.slidesPerGroup;\n\n  if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n    perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n  }\n\n  const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n\n  if (params.loop) {\n    if (animating && params.loopPreventsSlide) return false;\n    swiper.loopFix(); // eslint-disable-next-line\n\n    swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n  }\n\n  if (params.rewind && swiper.isEnd) {\n    return swiper.slideTo(0, speed, runCallbacks, internal);\n  }\n\n  return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slidePrev(speed = this.params.speed, runCallbacks = true, internal) {\n  const swiper = this;\n  const {\n    params,\n    animating,\n    snapGrid,\n    slidesGrid,\n    rtlTranslate,\n    enabled\n  } = swiper;\n  if (!enabled) return swiper;\n\n  if (params.loop) {\n    if (animating && params.loopPreventsSlide) return false;\n    swiper.loopFix(); // eslint-disable-next-line\n\n    swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n  }\n\n  const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n\n  function normalize(val) {\n    if (val < 0) return -Math.floor(Math.abs(val));\n    return Math.floor(val);\n  }\n\n  const normalizedTranslate = normalize(translate);\n  const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n  let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n\n  if (typeof prevSnap === 'undefined' && params.cssMode) {\n    let prevSnapIndex;\n    snapGrid.forEach((snap, snapIndex) => {\n      if (normalizedTranslate >= snap) {\n        // prevSnap = snap;\n        prevSnapIndex = snapIndex;\n      }\n    });\n\n    if (typeof prevSnapIndex !== 'undefined') {\n      prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n    }\n  }\n\n  let prevIndex = 0;\n\n  if (typeof prevSnap !== 'undefined') {\n    prevIndex = slidesGrid.indexOf(prevSnap);\n    if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\n\n    if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n      prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;\n      prevIndex = Math.max(prevIndex, 0);\n    }\n  }\n\n  if (params.rewind && swiper.isBeginning) {\n    const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n    return swiper.slideTo(lastIndex, speed, runCallbacks, internal);\n  }\n\n  return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideReset(speed = this.params.speed, runCallbacks = true, internal) {\n  const swiper = this;\n  return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideToClosest(speed = this.params.speed, runCallbacks = true, internal, threshold = 0.5) {\n  const swiper = this;\n  let index = swiper.activeIndex;\n  const skip = Math.min(swiper.params.slidesPerGroupSkip, index);\n  const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);\n  const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n  if (translate >= swiper.snapGrid[snapIndex]) {\n    // The current translate is on or after the current snap index, so the choice\n    // is between the current index and the one after it.\n    const currentSnap = swiper.snapGrid[snapIndex];\n    const nextSnap = swiper.snapGrid[snapIndex + 1];\n\n    if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {\n      index += swiper.params.slidesPerGroup;\n    }\n  } else {\n    // The current translate is before the current snap index, so the choice\n    // is between the current index and the one before it.\n    const prevSnap = swiper.snapGrid[snapIndex - 1];\n    const currentSnap = swiper.snapGrid[snapIndex];\n\n    if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n      index -= swiper.params.slidesPerGroup;\n    }\n  }\n\n  index = Math.max(index, 0);\n  index = Math.min(index, swiper.slidesGrid.length - 1);\n  return swiper.slideTo(index, speed, runCallbacks, internal);\n}","import $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nexport default function slideToClickedSlide() {\n  const swiper = this;\n  const {\n    params,\n    $wrapperEl\n  } = swiper;\n  const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n  let slideToIndex = swiper.clickedIndex;\n  let realIndex;\n\n  if (params.loop) {\n    if (swiper.animating) return;\n    realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n\n    if (params.centeredSlides) {\n      if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n        swiper.loopFix();\n        slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n        nextTick(() => {\n          swiper.slideTo(slideToIndex);\n        });\n      } else {\n        swiper.slideTo(slideToIndex);\n      }\n    } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n      swiper.loopFix();\n      slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n      nextTick(() => {\n        swiper.slideTo(slideToIndex);\n      });\n    } else {\n      swiper.slideTo(slideToIndex);\n    }\n  } else {\n    swiper.slideTo(slideToIndex);\n  }\n}","import slideTo from './slideTo.js';\nimport slideToLoop from './slideToLoop.js';\nimport slideNext from './slideNext.js';\nimport slidePrev from './slidePrev.js';\nimport slideReset from './slideReset.js';\nimport slideToClosest from './slideToClosest.js';\nimport slideToClickedSlide from './slideToClickedSlide.js';\nexport default {\n  slideTo,\n  slideToLoop,\n  slideNext,\n  slidePrev,\n  slideReset,\n  slideToClosest,\n  slideToClickedSlide\n};","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loopCreate() {\n  const swiper = this;\n  const document = getDocument();\n  const {\n    params,\n    $wrapperEl\n  } = swiper; // Remove duplicated slides\n\n  const $selector = $wrapperEl.children().length > 0 ? $($wrapperEl.children()[0].parentNode) : $wrapperEl;\n  $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();\n  let slides = $selector.children(`.${params.slideClass}`);\n\n  if (params.loopFillGroupWithBlank) {\n    const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;\n\n    if (blankSlidesNum !== params.slidesPerGroup) {\n      for (let i = 0; i < blankSlidesNum; i += 1) {\n        const blankNode = $(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);\n        $selector.append(blankNode);\n      }\n\n      slides = $selector.children(`.${params.slideClass}`);\n    }\n  }\n\n  if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;\n  swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));\n  swiper.loopedSlides += params.loopAdditionalSlides;\n\n  if (swiper.loopedSlides > slides.length && swiper.params.loopedSlidesLimit) {\n    swiper.loopedSlides = slides.length;\n  }\n\n  const prependSlides = [];\n  const appendSlides = [];\n  slides.each((el, index) => {\n    const slide = $(el);\n    slide.attr('data-swiper-slide-index', index);\n  });\n\n  for (let i = 0; i < swiper.loopedSlides; i += 1) {\n    const index = i - Math.floor(i / slides.length) * slides.length;\n    appendSlides.push(slides.eq(index)[0]);\n    prependSlides.unshift(slides.eq(slides.length - index - 1)[0]);\n  }\n\n  for (let i = 0; i < appendSlides.length; i += 1) {\n    $selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n  }\n\n  for (let i = prependSlides.length - 1; i >= 0; i -= 1) {\n    $selector.prepend($(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n  }\n}","export default function loopFix() {\n  const swiper = this;\n  swiper.emit('beforeLoopFix');\n  const {\n    activeIndex,\n    slides,\n    loopedSlides,\n    allowSlidePrev,\n    allowSlideNext,\n    snapGrid,\n    rtlTranslate: rtl\n  } = swiper;\n  let newIndex;\n  swiper.allowSlidePrev = true;\n  swiper.allowSlideNext = true;\n  const snapTranslate = -snapGrid[activeIndex];\n  const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding\n\n  if (activeIndex < loopedSlides) {\n    newIndex = slides.length - loopedSlides * 3 + activeIndex;\n    newIndex += loopedSlides;\n    const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n    if (slideChanged && diff !== 0) {\n      swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n    }\n  } else if (activeIndex >= slides.length - loopedSlides) {\n    // Fix For Positive Oversliding\n    newIndex = -slides.length + activeIndex + loopedSlides;\n    newIndex += loopedSlides;\n    const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n    if (slideChanged && diff !== 0) {\n      swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n    }\n  }\n\n  swiper.allowSlidePrev = allowSlidePrev;\n  swiper.allowSlideNext = allowSlideNext;\n  swiper.emit('loopFix');\n}","export default function loopDestroy() {\n  const swiper = this;\n  const {\n    $wrapperEl,\n    params,\n    slides\n  } = swiper;\n  $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();\n  slides.removeAttr('data-swiper-slide-index');\n}","import loopCreate from './loopCreate.js';\nimport loopFix from './loopFix.js';\nimport loopDestroy from './loopDestroy.js';\nexport default {\n  loopCreate,\n  loopFix,\n  loopDestroy\n};","export default function setGrabCursor(moving) {\n  const swiper = this;\n  if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n  const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n  el.style.cursor = 'move';\n  el.style.cursor = moving ? 'grabbing' : 'grab';\n}","export default function unsetGrabCursor() {\n  const swiper = this;\n\n  if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n    return;\n  }\n\n  swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n}","import setGrabCursor from './setGrabCursor.js';\nimport unsetGrabCursor from './unsetGrabCursor.js';\nexport default {\n  setGrabCursor,\n  unsetGrabCursor\n};","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js'; // Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\n\nfunction closestElement(selector, base = this) {\n  function __closestFrom(el) {\n    if (!el || el === getDocument() || el === getWindow()) return null;\n    if (el.assignedSlot) el = el.assignedSlot;\n    const found = el.closest(selector);\n\n    if (!found && !el.getRootNode) {\n      return null;\n    }\n\n    return found || __closestFrom(el.getRootNode().host);\n  }\n\n  return __closestFrom(base);\n}\n\nexport default function onTouchStart(event) {\n  const swiper = this;\n  const document = getDocument();\n  const window = getWindow();\n  const data = swiper.touchEventsData;\n  const {\n    params,\n    touches,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n\n  if (swiper.animating && params.preventInteractionOnTransition) {\n    return;\n  }\n\n  if (!swiper.animating && params.cssMode && params.loop) {\n    swiper.loopFix();\n  }\n\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n  let $targetEl = $(e.target);\n\n  if (params.touchEventsTarget === 'wrapper') {\n    if (!$targetEl.closest(swiper.wrapperEl).length) return;\n  }\n\n  data.isTouchEvent = e.type === 'touchstart';\n  if (!data.isTouchEvent && 'which' in e && e.which === 3) return;\n  if (!data.isTouchEvent && 'button' in e && e.button > 0) return;\n  if (data.isTouched && data.isMoved) return; // change target el for shadow root component\n\n  const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== ''; // eslint-disable-next-line\n\n  const eventPath = event.composedPath ? event.composedPath() : event.path;\n\n  if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {\n    $targetEl = $(eventPath[0]);\n  }\n\n  const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n  const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element\n\n  if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, $targetEl[0]) : $targetEl.closest(noSwipingSelector)[0])) {\n    swiper.allowClick = true;\n    return;\n  }\n\n  if (params.swipeHandler) {\n    if (!$targetEl.closest(params.swipeHandler)[0]) return;\n  }\n\n  touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n  touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n  const startX = touches.currentX;\n  const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n\n  const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n  const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n\n  if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n    if (edgeSwipeDetection === 'prevent') {\n      event.preventDefault();\n    } else {\n      return;\n    }\n  }\n\n  Object.assign(data, {\n    isTouched: true,\n    isMoved: false,\n    allowTouchCallbacks: true,\n    isScrolling: undefined,\n    startMoving: undefined\n  });\n  touches.startX = startX;\n  touches.startY = startY;\n  data.touchStartTime = now();\n  swiper.allowClick = true;\n  swiper.updateSize();\n  swiper.swipeDirection = undefined;\n  if (params.threshold > 0) data.allowThresholdMove = false;\n\n  if (e.type !== 'touchstart') {\n    let preventDefault = true;\n\n    if ($targetEl.is(data.focusableElements)) {\n      preventDefault = false;\n\n      if ($targetEl[0].nodeName === 'SELECT') {\n        data.isTouched = false;\n      }\n    }\n\n    if (document.activeElement && $(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) {\n      document.activeElement.blur();\n    }\n\n    const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n\n    if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) {\n      e.preventDefault();\n    }\n  }\n\n  if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {\n    swiper.freeMode.onTouchStart();\n  }\n\n  swiper.emit('touchStart', e);\n}","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js';\nexport default function onTouchMove(event) {\n  const document = getDocument();\n  const swiper = this;\n  const data = swiper.touchEventsData;\n  const {\n    params,\n    touches,\n    rtlTranslate: rtl,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n\n  if (!data.isTouched) {\n    if (data.startMoving && data.isScrolling) {\n      swiper.emit('touchMoveOpposite', e);\n    }\n\n    return;\n  }\n\n  if (data.isTouchEvent && e.type !== 'touchmove') return;\n  const targetTouch = e.type === 'touchmove' && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);\n  const pageX = e.type === 'touchmove' ? targetTouch.pageX : e.pageX;\n  const pageY = e.type === 'touchmove' ? targetTouch.pageY : e.pageY;\n\n  if (e.preventedByNestedSwiper) {\n    touches.startX = pageX;\n    touches.startY = pageY;\n    return;\n  }\n\n  if (!swiper.allowTouchMove) {\n    if (!$(e.target).is(data.focusableElements)) {\n      swiper.allowClick = false;\n    }\n\n    if (data.isTouched) {\n      Object.assign(touches, {\n        startX: pageX,\n        startY: pageY,\n        currentX: pageX,\n        currentY: pageY\n      });\n      data.touchStartTime = now();\n    }\n\n    return;\n  }\n\n  if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n    if (swiper.isVertical()) {\n      // Vertical\n      if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {\n        data.isTouched = false;\n        data.isMoved = false;\n        return;\n      }\n    } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {\n      return;\n    }\n  }\n\n  if (data.isTouchEvent && document.activeElement) {\n    if (e.target === document.activeElement && $(e.target).is(data.focusableElements)) {\n      data.isMoved = true;\n      swiper.allowClick = false;\n      return;\n    }\n  }\n\n  if (data.allowTouchCallbacks) {\n    swiper.emit('touchMove', e);\n  }\n\n  if (e.targetTouches && e.targetTouches.length > 1) return;\n  touches.currentX = pageX;\n  touches.currentY = pageY;\n  const diffX = touches.currentX - touches.startX;\n  const diffY = touches.currentY - touches.startY;\n  if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;\n\n  if (typeof data.isScrolling === 'undefined') {\n    let touchAngle;\n\n    if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {\n      data.isScrolling = false;\n    } else {\n      // eslint-disable-next-line\n      if (diffX * diffX + diffY * diffY >= 25) {\n        touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;\n        data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;\n      }\n    }\n  }\n\n  if (data.isScrolling) {\n    swiper.emit('touchMoveOpposite', e);\n  }\n\n  if (typeof data.startMoving === 'undefined') {\n    if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n      data.startMoving = true;\n    }\n  }\n\n  if (data.isScrolling) {\n    data.isTouched = false;\n    return;\n  }\n\n  if (!data.startMoving) {\n    return;\n  }\n\n  swiper.allowClick = false;\n\n  if (!params.cssMode && e.cancelable) {\n    e.preventDefault();\n  }\n\n  if (params.touchMoveStopPropagation && !params.nested) {\n    e.stopPropagation();\n  }\n\n  if (!data.isMoved) {\n    if (params.loop && !params.cssMode) {\n      swiper.loopFix();\n    }\n\n    data.startTranslate = swiper.getTranslate();\n    swiper.setTransition(0);\n\n    if (swiper.animating) {\n      swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n    }\n\n    data.allowMomentumBounce = false; // Grab Cursor\n\n    if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n      swiper.setGrabCursor(true);\n    }\n\n    swiper.emit('sliderFirstMove', e);\n  }\n\n  swiper.emit('sliderMove', e);\n  data.isMoved = true;\n  let diff = swiper.isHorizontal() ? diffX : diffY;\n  touches.diff = diff;\n  diff *= params.touchRatio;\n  if (rtl) diff = -diff;\n  swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n  data.currentTranslate = diff + data.startTranslate;\n  let disableParentSwiper = true;\n  let resistanceRatio = params.resistanceRatio;\n\n  if (params.touchReleaseOnEdges) {\n    resistanceRatio = 0;\n  }\n\n  if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {\n    disableParentSwiper = false;\n    if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n  } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n    disableParentSwiper = false;\n    if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n  }\n\n  if (disableParentSwiper) {\n    e.preventedByNestedSwiper = true;\n  } // Directions locks\n\n\n  if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n    data.currentTranslate = data.startTranslate;\n  }\n\n  if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n    data.currentTranslate = data.startTranslate;\n  }\n\n  if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n    data.currentTranslate = data.startTranslate;\n  } // Threshold\n\n\n  if (params.threshold > 0) {\n    if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n      if (!data.allowThresholdMove) {\n        data.allowThresholdMove = true;\n        touches.startX = touches.currentX;\n        touches.startY = touches.currentY;\n        data.currentTranslate = data.startTranslate;\n        touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n        return;\n      }\n    } else {\n      data.currentTranslate = data.startTranslate;\n      return;\n    }\n  }\n\n  if (!params.followFinger || params.cssMode) return; // Update active index in free mode\n\n  if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n    swiper.updateActiveIndex();\n    swiper.updateSlidesClasses();\n  }\n\n  if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n    swiper.freeMode.onTouchMove();\n  } // Update progress\n\n\n  swiper.updateProgress(data.currentTranslate); // Update translate\n\n  swiper.setTranslate(data.currentTranslate);\n}","import { now, nextTick } from '../../shared/utils.js';\nexport default function onTouchEnd(event) {\n  const swiper = this;\n  const data = swiper.touchEventsData;\n  const {\n    params,\n    touches,\n    rtlTranslate: rtl,\n    slidesGrid,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n\n  if (data.allowTouchCallbacks) {\n    swiper.emit('touchEnd', e);\n  }\n\n  data.allowTouchCallbacks = false;\n\n  if (!data.isTouched) {\n    if (data.isMoved && params.grabCursor) {\n      swiper.setGrabCursor(false);\n    }\n\n    data.isMoved = false;\n    data.startMoving = false;\n    return;\n  } // Return Grab Cursor\n\n\n  if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n    swiper.setGrabCursor(false);\n  } // Time diff\n\n\n  const touchEndTime = now();\n  const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click\n\n  if (swiper.allowClick) {\n    const pathTree = e.path || e.composedPath && e.composedPath();\n    swiper.updateClickedSlide(pathTree && pathTree[0] || e.target);\n    swiper.emit('tap click', e);\n\n    if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n      swiper.emit('doubleTap doubleClick', e);\n    }\n  }\n\n  data.lastClickTime = now();\n  nextTick(() => {\n    if (!swiper.destroyed) swiper.allowClick = true;\n  });\n\n  if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n    data.isTouched = false;\n    data.isMoved = false;\n    data.startMoving = false;\n    return;\n  }\n\n  data.isTouched = false;\n  data.isMoved = false;\n  data.startMoving = false;\n  let currentPos;\n\n  if (params.followFinger) {\n    currentPos = rtl ? swiper.translate : -swiper.translate;\n  } else {\n    currentPos = -data.currentTranslate;\n  }\n\n  if (params.cssMode) {\n    return;\n  }\n\n  if (swiper.params.freeMode && params.freeMode.enabled) {\n    swiper.freeMode.onTouchEnd({\n      currentPos\n    });\n    return;\n  } // Find current slide\n\n\n  let stopIndex = 0;\n  let groupSize = swiper.slidesSizesGrid[0];\n\n  for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {\n    const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n    if (typeof slidesGrid[i + increment] !== 'undefined') {\n      if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {\n        stopIndex = i;\n        groupSize = slidesGrid[i + increment] - slidesGrid[i];\n      }\n    } else if (currentPos >= slidesGrid[i]) {\n      stopIndex = i;\n      groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n    }\n  }\n\n  let rewindFirstIndex = null;\n  let rewindLastIndex = null;\n\n  if (params.rewind) {\n    if (swiper.isBeginning) {\n      rewindLastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n    } else if (swiper.isEnd) {\n      rewindFirstIndex = 0;\n    }\n  } // Find current slide size\n\n\n  const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n  const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n  if (timeDiff > params.longSwipesMs) {\n    // Long touches\n    if (!params.longSwipes) {\n      swiper.slideTo(swiper.activeIndex);\n      return;\n    }\n\n    if (swiper.swipeDirection === 'next') {\n      if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);\n    }\n\n    if (swiper.swipeDirection === 'prev') {\n      if (ratio > 1 - params.longSwipesRatio) {\n        swiper.slideTo(stopIndex + increment);\n      } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {\n        swiper.slideTo(rewindLastIndex);\n      } else {\n        swiper.slideTo(stopIndex);\n      }\n    }\n  } else {\n    // Short swipes\n    if (!params.shortSwipes) {\n      swiper.slideTo(swiper.activeIndex);\n      return;\n    }\n\n    const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n\n    if (!isNavButtonTarget) {\n      if (swiper.swipeDirection === 'next') {\n        swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);\n      }\n\n      if (swiper.swipeDirection === 'prev') {\n        swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);\n      }\n    } else if (e.target === swiper.navigation.nextEl) {\n      swiper.slideTo(stopIndex + increment);\n    } else {\n      swiper.slideTo(stopIndex);\n    }\n  }\n}","export default function onResize() {\n  const swiper = this;\n  const {\n    params,\n    el\n  } = swiper;\n  if (el && el.offsetWidth === 0) return; // Breakpoints\n\n  if (params.breakpoints) {\n    swiper.setBreakpoint();\n  } // Save locks\n\n\n  const {\n    allowSlideNext,\n    allowSlidePrev,\n    snapGrid\n  } = swiper; // Disable locks on resize\n\n  swiper.allowSlideNext = true;\n  swiper.allowSlidePrev = true;\n  swiper.updateSize();\n  swiper.updateSlides();\n  swiper.updateSlidesClasses();\n\n  if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) {\n    swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n  } else {\n    swiper.slideTo(swiper.activeIndex, 0, false, true);\n  }\n\n  if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n    swiper.autoplay.run();\n  } // Return locks after resize\n\n\n  swiper.allowSlidePrev = allowSlidePrev;\n  swiper.allowSlideNext = allowSlideNext;\n\n  if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n    swiper.checkOverflow();\n  }\n}","export default function onClick(e) {\n  const swiper = this;\n  if (!swiper.enabled) return;\n\n  if (!swiper.allowClick) {\n    if (swiper.params.preventClicks) e.preventDefault();\n\n    if (swiper.params.preventClicksPropagation && swiper.animating) {\n      e.stopPropagation();\n      e.stopImmediatePropagation();\n    }\n  }\n}","export default function onScroll() {\n  const swiper = this;\n  const {\n    wrapperEl,\n    rtlTranslate,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  swiper.previousTranslate = swiper.translate;\n\n  if (swiper.isHorizontal()) {\n    swiper.translate = -wrapperEl.scrollLeft;\n  } else {\n    swiper.translate = -wrapperEl.scrollTop;\n  } // eslint-disable-next-line\n\n\n  if (swiper.translate === 0) swiper.translate = 0;\n  swiper.updateActiveIndex();\n  swiper.updateSlidesClasses();\n  let newProgress;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n  if (translatesDiff === 0) {\n    newProgress = 0;\n  } else {\n    newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n  }\n\n  if (newProgress !== swiper.progress) {\n    swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n  }\n\n  swiper.emit('setTranslate', swiper.translate, false);\n}","import { getDocument } from 'ssr-window';\nimport onTouchStart from './onTouchStart.js';\nimport onTouchMove from './onTouchMove.js';\nimport onTouchEnd from './onTouchEnd.js';\nimport onResize from './onResize.js';\nimport onClick from './onClick.js';\nimport onScroll from './onScroll.js';\nlet dummyEventAttached = false;\n\nfunction dummyEventListener() {}\n\nconst events = (swiper, method) => {\n  const document = getDocument();\n  const {\n    params,\n    touchEvents,\n    el,\n    wrapperEl,\n    device,\n    support\n  } = swiper;\n  const capture = !!params.nested;\n  const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n  const swiperMethod = method; // Touch Events\n\n  if (!support.touch) {\n    el[domMethod](touchEvents.start, swiper.onTouchStart, false);\n    document[domMethod](touchEvents.move, swiper.onTouchMove, capture);\n    document[domMethod](touchEvents.end, swiper.onTouchEnd, false);\n  } else {\n    const passiveListener = touchEvents.start === 'touchstart' && support.passiveListener && params.passiveListeners ? {\n      passive: true,\n      capture: false\n    } : false;\n    el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);\n    el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {\n      passive: false,\n      capture\n    } : capture);\n    el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);\n\n    if (touchEvents.cancel) {\n      el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);\n    }\n  } // Prevent Links Clicks\n\n\n  if (params.preventClicks || params.preventClicksPropagation) {\n    el[domMethod]('click', swiper.onClick, true);\n  }\n\n  if (params.cssMode) {\n    wrapperEl[domMethod]('scroll', swiper.onScroll);\n  } // Resize handler\n\n\n  if (params.updateOnWindowResize) {\n    swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);\n  } else {\n    swiper[swiperMethod]('observerUpdate', onResize, true);\n  }\n};\n\nfunction attachEvents() {\n  const swiper = this;\n  const document = getDocument();\n  const {\n    params,\n    support\n  } = swiper;\n  swiper.onTouchStart = onTouchStart.bind(swiper);\n  swiper.onTouchMove = onTouchMove.bind(swiper);\n  swiper.onTouchEnd = onTouchEnd.bind(swiper);\n\n  if (params.cssMode) {\n    swiper.onScroll = onScroll.bind(swiper);\n  }\n\n  swiper.onClick = onClick.bind(swiper);\n\n  if (support.touch && !dummyEventAttached) {\n    document.addEventListener('touchstart', dummyEventListener);\n    dummyEventAttached = true;\n  }\n\n  events(swiper, 'on');\n}\n\nfunction detachEvents() {\n  const swiper = this;\n  events(swiper, 'off');\n}\n\nexport default {\n  attachEvents,\n  detachEvents\n};","import { extend } from '../../shared/utils.js';\n\nconst isGridEnabled = (swiper, params) => {\n  return swiper.grid && params.grid && params.grid.rows > 1;\n};\n\nexport default function setBreakpoint() {\n  const swiper = this;\n  const {\n    activeIndex,\n    initialized,\n    loopedSlides = 0,\n    params,\n    $el\n  } = swiper;\n  const breakpoints = params.breakpoints;\n  if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters\n\n  const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);\n  if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;\n  const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n  const breakpointParams = breakpointOnlyParams || swiper.originalParams;\n  const wasMultiRow = isGridEnabled(swiper, params);\n  const isMultiRow = isGridEnabled(swiper, breakpointParams);\n  const wasEnabled = params.enabled;\n\n  if (wasMultiRow && !isMultiRow) {\n    $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);\n    swiper.emitContainerClasses();\n  } else if (!wasMultiRow && isMultiRow) {\n    $el.addClass(`${params.containerModifierClass}grid`);\n\n    if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n      $el.addClass(`${params.containerModifierClass}grid-column`);\n    }\n\n    swiper.emitContainerClasses();\n  } // Toggle navigation, pagination, scrollbar\n\n\n  ['navigation', 'pagination', 'scrollbar'].forEach(prop => {\n    const wasModuleEnabled = params[prop] && params[prop].enabled;\n    const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;\n\n    if (wasModuleEnabled && !isModuleEnabled) {\n      swiper[prop].disable();\n    }\n\n    if (!wasModuleEnabled && isModuleEnabled) {\n      swiper[prop].enable();\n    }\n  });\n  const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n  const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n  if (directionChanged && initialized) {\n    swiper.changeDirection();\n  }\n\n  extend(swiper.params, breakpointParams);\n  const isEnabled = swiper.params.enabled;\n  Object.assign(swiper, {\n    allowTouchMove: swiper.params.allowTouchMove,\n    allowSlideNext: swiper.params.allowSlideNext,\n    allowSlidePrev: swiper.params.allowSlidePrev\n  });\n\n  if (wasEnabled && !isEnabled) {\n    swiper.disable();\n  } else if (!wasEnabled && isEnabled) {\n    swiper.enable();\n  }\n\n  swiper.currentBreakpoint = breakpoint;\n  swiper.emit('_beforeBreakpoint', breakpointParams);\n\n  if (needsReLoop && initialized) {\n    swiper.loopDestroy();\n    swiper.loopCreate();\n    swiper.updateSlides();\n    swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);\n  }\n\n  swiper.emit('breakpoint', breakpointParams);\n}","import { getWindow } from 'ssr-window';\nexport default function getBreakpoint(breakpoints, base = 'window', containerEl) {\n  if (!breakpoints || base === 'container' && !containerEl) return undefined;\n  let breakpoint = false;\n  const window = getWindow();\n  const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;\n  const points = Object.keys(breakpoints).map(point => {\n    if (typeof point === 'string' && point.indexOf('@') === 0) {\n      const minRatio = parseFloat(point.substr(1));\n      const value = currentHeight * minRatio;\n      return {\n        value,\n        point\n      };\n    }\n\n    return {\n      value: point,\n      point\n    };\n  });\n  points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n\n  for (let i = 0; i < points.length; i += 1) {\n    const {\n      point,\n      value\n    } = points[i];\n\n    if (base === 'window') {\n      if (window.matchMedia(`(min-width: ${value}px)`).matches) {\n        breakpoint = point;\n      }\n    } else if (value <= containerEl.clientWidth) {\n      breakpoint = point;\n    }\n  }\n\n  return breakpoint || 'max';\n}","import setBreakpoint from './setBreakpoint.js';\nimport getBreakpoint from './getBreakpoint.js';\nexport default {\n  setBreakpoint,\n  getBreakpoint\n};","function prepareClasses(entries, prefix) {\n  const resultClasses = [];\n  entries.forEach(item => {\n    if (typeof item === 'object') {\n      Object.keys(item).forEach(classNames => {\n        if (item[classNames]) {\n          resultClasses.push(prefix + classNames);\n        }\n      });\n    } else if (typeof item === 'string') {\n      resultClasses.push(prefix + item);\n    }\n  });\n  return resultClasses;\n}\n\nexport default function addClasses() {\n  const swiper = this;\n  const {\n    classNames,\n    params,\n    rtl,\n    $el,\n    device,\n    support\n  } = swiper; // prettier-ignore\n\n  const suffixes = prepareClasses(['initialized', params.direction, {\n    'pointer-events': !support.touch\n  }, {\n    'free-mode': swiper.params.freeMode && params.freeMode.enabled\n  }, {\n    'autoheight': params.autoHeight\n  }, {\n    'rtl': rtl\n  }, {\n    'grid': params.grid && params.grid.rows > 1\n  }, {\n    'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'\n  }, {\n    'android': device.android\n  }, {\n    'ios': device.ios\n  }, {\n    'css-mode': params.cssMode\n  }, {\n    'centered': params.cssMode && params.centeredSlides\n  }, {\n    'watch-progress': params.watchSlidesProgress\n  }], params.containerModifierClass);\n  classNames.push(...suffixes);\n  $el.addClass([...classNames].join(' '));\n  swiper.emitContainerClasses();\n}","export default function removeClasses() {\n  const swiper = this;\n  const {\n    $el,\n    classNames\n  } = swiper;\n  $el.removeClass(classNames.join(' '));\n  swiper.emitContainerClasses();\n}","import addClasses from './addClasses.js';\nimport removeClasses from './removeClasses.js';\nexport default {\n  addClasses,\n  removeClasses\n};","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {\n  const window = getWindow();\n  let image;\n\n  function onReady() {\n    if (callback) callback();\n  }\n\n  const isPicture = $(imageEl).parent('picture')[0];\n\n  if (!isPicture && (!imageEl.complete || !checkForComplete)) {\n    if (src) {\n      image = new window.Image();\n      image.onload = onReady;\n      image.onerror = onReady;\n\n      if (sizes) {\n        image.sizes = sizes;\n      }\n\n      if (srcset) {\n        image.srcset = srcset;\n      }\n\n      if (src) {\n        image.src = src;\n      }\n    } else {\n      onReady();\n    }\n  } else {\n    // image already loaded...\n    onReady();\n  }\n}","export default function preloadImages() {\n  const swiper = this;\n  swiper.imagesToLoad = swiper.$el.find('img');\n\n  function onReady() {\n    if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) return;\n    if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;\n\n    if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n      if (swiper.params.updateOnImagesReady) swiper.update();\n      swiper.emit('imagesReady');\n    }\n  }\n\n  for (let i = 0; i < swiper.imagesToLoad.length; i += 1) {\n    const imageEl = swiper.imagesToLoad[i];\n    swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute('src'), imageEl.srcset || imageEl.getAttribute('srcset'), imageEl.sizes || imageEl.getAttribute('sizes'), true, onReady);\n  }\n}","import loadImage from './loadImage.js';\nimport preloadImages from './preloadImages.js';\nexport default {\n  loadImage,\n  preloadImages\n};","function checkOverflow() {\n  const swiper = this;\n  const {\n    isLocked: wasLocked,\n    params\n  } = swiper;\n  const {\n    slidesOffsetBefore\n  } = params;\n\n  if (slidesOffsetBefore) {\n    const lastSlideIndex = swiper.slides.length - 1;\n    const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;\n    swiper.isLocked = swiper.size > lastSlideRightEdge;\n  } else {\n    swiper.isLocked = swiper.snapGrid.length === 1;\n  }\n\n  if (params.allowSlideNext === true) {\n    swiper.allowSlideNext = !swiper.isLocked;\n  }\n\n  if (params.allowSlidePrev === true) {\n    swiper.allowSlidePrev = !swiper.isLocked;\n  }\n\n  if (wasLocked && wasLocked !== swiper.isLocked) {\n    swiper.isEnd = false;\n  }\n\n  if (wasLocked !== swiper.isLocked) {\n    swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n  }\n}\n\nexport default {\n  checkOverflow\n};","export default {\n  init: true,\n  direction: 'horizontal',\n  touchEventsTarget: 'wrapper',\n  initialSlide: 0,\n  speed: 300,\n  cssMode: false,\n  updateOnWindowResize: true,\n  resizeObserver: true,\n  nested: false,\n  createElements: false,\n  enabled: true,\n  focusableElements: 'input, select, option, textarea, button, video, label',\n  // Overrides\n  width: null,\n  height: null,\n  //\n  preventInteractionOnTransition: false,\n  // ssr\n  userAgent: null,\n  url: null,\n  // To support iOS's swipe-to-go-back gesture (when being used in-app).\n  edgeSwipeDetection: false,\n  edgeSwipeThreshold: 20,\n  // Autoheight\n  autoHeight: false,\n  // Set wrapper width\n  setWrapperSize: false,\n  // Virtual Translate\n  virtualTranslate: false,\n  // Effects\n  effect: 'slide',\n  // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n  // Breakpoints\n  breakpoints: undefined,\n  breakpointsBase: 'window',\n  // Slides grid\n  spaceBetween: 0,\n  slidesPerView: 1,\n  slidesPerGroup: 1,\n  slidesPerGroupSkip: 0,\n  slidesPerGroupAuto: false,\n  centeredSlides: false,\n  centeredSlidesBounds: false,\n  slidesOffsetBefore: 0,\n  // in px\n  slidesOffsetAfter: 0,\n  // in px\n  normalizeSlideIndex: true,\n  centerInsufficientSlides: false,\n  // Disable swiper and hide navigation when container not overflow\n  watchOverflow: true,\n  // Round length\n  roundLengths: false,\n  // Touches\n  touchRatio: 1,\n  touchAngle: 45,\n  simulateTouch: true,\n  shortSwipes: true,\n  longSwipes: true,\n  longSwipesRatio: 0.5,\n  longSwipesMs: 300,\n  followFinger: true,\n  allowTouchMove: true,\n  threshold: 0,\n  touchMoveStopPropagation: false,\n  touchStartPreventDefault: true,\n  touchStartForcePreventDefault: false,\n  touchReleaseOnEdges: false,\n  // Unique Navigation Elements\n  uniqueNavElements: true,\n  // Resistance\n  resistance: true,\n  resistanceRatio: 0.85,\n  // Progress\n  watchSlidesProgress: false,\n  // Cursor\n  grabCursor: false,\n  // Clicks\n  preventClicks: true,\n  preventClicksPropagation: true,\n  slideToClickedSlide: false,\n  // Images\n  preloadImages: true,\n  updateOnImagesReady: true,\n  // loop\n  loop: false,\n  loopAdditionalSlides: 0,\n  loopedSlides: null,\n  loopedSlidesLimit: true,\n  loopFillGroupWithBlank: false,\n  loopPreventsSlide: true,\n  // rewind\n  rewind: false,\n  // Swiping/no swiping\n  allowSlidePrev: true,\n  allowSlideNext: true,\n  swipeHandler: null,\n  // '.swipe-handler',\n  noSwiping: true,\n  noSwipingClass: 'swiper-no-swiping',\n  noSwipingSelector: null,\n  // Passive Listeners\n  passiveListeners: true,\n  maxBackfaceHiddenSlides: 10,\n  // NS\n  containerModifierClass: 'swiper-',\n  // NEW\n  slideClass: 'swiper-slide',\n  slideBlankClass: 'swiper-slide-invisible-blank',\n  slideActiveClass: 'swiper-slide-active',\n  slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n  slideVisibleClass: 'swiper-slide-visible',\n  slideDuplicateClass: 'swiper-slide-duplicate',\n  slideNextClass: 'swiper-slide-next',\n  slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n  slidePrevClass: 'swiper-slide-prev',\n  slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n  wrapperClass: 'swiper-wrapper',\n  // Callbacks\n  runCallbacksOnInit: true,\n  // Internals\n  _emitClasses: false\n};","import { extend } from '../shared/utils.js';\nexport default function moduleExtendParams(params, allModulesParams) {\n  return function extendParams(obj = {}) {\n    const moduleParamName = Object.keys(obj)[0];\n    const moduleParams = obj[moduleParamName];\n\n    if (typeof moduleParams !== 'object' || moduleParams === null) {\n      extend(allModulesParams, obj);\n      return;\n    }\n\n    if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {\n      params[moduleParamName] = {\n        auto: true\n      };\n    }\n\n    if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n      extend(allModulesParams, obj);\n      return;\n    }\n\n    if (params[moduleParamName] === true) {\n      params[moduleParamName] = {\n        enabled: true\n      };\n    }\n\n    if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n      params[moduleParamName].enabled = true;\n    }\n\n    if (!params[moduleParamName]) params[moduleParamName] = {\n      enabled: false\n    };\n    extend(allModulesParams, obj);\n  };\n}","/* eslint no-param-reassign: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport $ from '../shared/dom.js';\nimport { extend, now, deleteProps } from '../shared/utils.js';\nimport { getSupport } from '../shared/get-support.js';\nimport { getDevice } from '../shared/get-device.js';\nimport { getBrowser } from '../shared/get-browser.js';\nimport Resize from './modules/resize/resize.js';\nimport Observer from './modules/observer/observer.js';\nimport eventsEmitter from './events-emitter.js';\nimport update from './update/index.js';\nimport translate from './translate/index.js';\nimport transition from './transition/index.js';\nimport slide from './slide/index.js';\nimport loop from './loop/index.js';\nimport grabCursor from './grab-cursor/index.js';\nimport events from './events/index.js';\nimport breakpoints from './breakpoints/index.js';\nimport classes from './classes/index.js';\nimport images from './images/index.js';\nimport checkOverflow from './check-overflow/index.js';\nimport defaults from './defaults.js';\nimport moduleExtendParams from './moduleExtendParams.js';\nconst prototypes = {\n  eventsEmitter,\n  update,\n  translate,\n  transition,\n  slide,\n  loop,\n  grabCursor,\n  events,\n  breakpoints,\n  checkOverflow,\n  classes,\n  images\n};\nconst extendedDefaults = {};\n\nclass Swiper {\n  constructor(...args) {\n    let el;\n    let params;\n\n    if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {\n      params = args[0];\n    } else {\n      [el, params] = args;\n    }\n\n    if (!params) params = {};\n    params = extend({}, params);\n    if (el && !params.el) params.el = el;\n\n    if (params.el && $(params.el).length > 1) {\n      const swipers = [];\n      $(params.el).each(containerEl => {\n        const newParams = extend({}, params, {\n          el: containerEl\n        });\n        swipers.push(new Swiper(newParams));\n      }); // eslint-disable-next-line no-constructor-return\n\n      return swipers;\n    } // Swiper Instance\n\n\n    const swiper = this;\n    swiper.__swiper__ = true;\n    swiper.support = getSupport();\n    swiper.device = getDevice({\n      userAgent: params.userAgent\n    });\n    swiper.browser = getBrowser();\n    swiper.eventsListeners = {};\n    swiper.eventsAnyListeners = [];\n    swiper.modules = [...swiper.__modules__];\n\n    if (params.modules && Array.isArray(params.modules)) {\n      swiper.modules.push(...params.modules);\n    }\n\n    const allModulesParams = {};\n    swiper.modules.forEach(mod => {\n      mod({\n        swiper,\n        extendParams: moduleExtendParams(params, allModulesParams),\n        on: swiper.on.bind(swiper),\n        once: swiper.once.bind(swiper),\n        off: swiper.off.bind(swiper),\n        emit: swiper.emit.bind(swiper)\n      });\n    }); // Extend defaults with modules params\n\n    const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params\n\n    swiper.params = extend({}, swiperParams, extendedDefaults, params);\n    swiper.originalParams = extend({}, swiper.params);\n    swiper.passedParams = extend({}, params); // add event listeners\n\n    if (swiper.params && swiper.params.on) {\n      Object.keys(swiper.params.on).forEach(eventName => {\n        swiper.on(eventName, swiper.params.on[eventName]);\n      });\n    }\n\n    if (swiper.params && swiper.params.onAny) {\n      swiper.onAny(swiper.params.onAny);\n    } // Save Dom lib\n\n\n    swiper.$ = $; // Extend Swiper\n\n    Object.assign(swiper, {\n      enabled: swiper.params.enabled,\n      el,\n      // Classes\n      classNames: [],\n      // Slides\n      slides: $(),\n      slidesGrid: [],\n      snapGrid: [],\n      slidesSizesGrid: [],\n\n      // isDirection\n      isHorizontal() {\n        return swiper.params.direction === 'horizontal';\n      },\n\n      isVertical() {\n        return swiper.params.direction === 'vertical';\n      },\n\n      // Indexes\n      activeIndex: 0,\n      realIndex: 0,\n      //\n      isBeginning: true,\n      isEnd: false,\n      // Props\n      translate: 0,\n      previousTranslate: 0,\n      progress: 0,\n      velocity: 0,\n      animating: false,\n      // Locks\n      allowSlideNext: swiper.params.allowSlideNext,\n      allowSlidePrev: swiper.params.allowSlidePrev,\n      // Touch Events\n      touchEvents: function touchEvents() {\n        const touch = ['touchstart', 'touchmove', 'touchend', 'touchcancel'];\n        const desktop = ['pointerdown', 'pointermove', 'pointerup'];\n        swiper.touchEventsTouch = {\n          start: touch[0],\n          move: touch[1],\n          end: touch[2],\n          cancel: touch[3]\n        };\n        swiper.touchEventsDesktop = {\n          start: desktop[0],\n          move: desktop[1],\n          end: desktop[2]\n        };\n        return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n      }(),\n      touchEventsData: {\n        isTouched: undefined,\n        isMoved: undefined,\n        allowTouchCallbacks: undefined,\n        touchStartTime: undefined,\n        isScrolling: undefined,\n        currentTranslate: undefined,\n        startTranslate: undefined,\n        allowThresholdMove: undefined,\n        // Form elements to match\n        focusableElements: swiper.params.focusableElements,\n        // Last click time\n        lastClickTime: now(),\n        clickTimeout: undefined,\n        // Velocities\n        velocities: [],\n        allowMomentumBounce: undefined,\n        isTouchEvent: undefined,\n        startMoving: undefined\n      },\n      // Clicks\n      allowClick: true,\n      // Touches\n      allowTouchMove: swiper.params.allowTouchMove,\n      touches: {\n        startX: 0,\n        startY: 0,\n        currentX: 0,\n        currentY: 0,\n        diff: 0\n      },\n      // Images\n      imagesToLoad: [],\n      imagesLoaded: 0\n    });\n    swiper.emit('_swiper'); // Init\n\n    if (swiper.params.init) {\n      swiper.init();\n    } // Return app instance\n    // eslint-disable-next-line no-constructor-return\n\n\n    return swiper;\n  }\n\n  enable() {\n    const swiper = this;\n    if (swiper.enabled) return;\n    swiper.enabled = true;\n\n    if (swiper.params.grabCursor) {\n      swiper.setGrabCursor();\n    }\n\n    swiper.emit('enable');\n  }\n\n  disable() {\n    const swiper = this;\n    if (!swiper.enabled) return;\n    swiper.enabled = false;\n\n    if (swiper.params.grabCursor) {\n      swiper.unsetGrabCursor();\n    }\n\n    swiper.emit('disable');\n  }\n\n  setProgress(progress, speed) {\n    const swiper = this;\n    progress = Math.min(Math.max(progress, 0), 1);\n    const min = swiper.minTranslate();\n    const max = swiper.maxTranslate();\n    const current = (max - min) * progress + min;\n    swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);\n    swiper.updateActiveIndex();\n    swiper.updateSlidesClasses();\n  }\n\n  emitContainerClasses() {\n    const swiper = this;\n    if (!swiper.params._emitClasses || !swiper.el) return;\n    const cls = swiper.el.className.split(' ').filter(className => {\n      return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;\n    });\n    swiper.emit('_containerClasses', cls.join(' '));\n  }\n\n  getSlideClasses(slideEl) {\n    const swiper = this;\n    if (swiper.destroyed) return '';\n    return slideEl.className.split(' ').filter(className => {\n      return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;\n    }).join(' ');\n  }\n\n  emitSlidesClasses() {\n    const swiper = this;\n    if (!swiper.params._emitClasses || !swiper.el) return;\n    const updates = [];\n    swiper.slides.each(slideEl => {\n      const classNames = swiper.getSlideClasses(slideEl);\n      updates.push({\n        slideEl,\n        classNames\n      });\n      swiper.emit('_slideClass', slideEl, classNames);\n    });\n    swiper.emit('_slideClasses', updates);\n  }\n\n  slidesPerViewDynamic(view = 'current', exact = false) {\n    const swiper = this;\n    const {\n      params,\n      slides,\n      slidesGrid,\n      slidesSizesGrid,\n      size: swiperSize,\n      activeIndex\n    } = swiper;\n    let spv = 1;\n\n    if (params.centeredSlides) {\n      let slideSize = slides[activeIndex].swiperSlideSize;\n      let breakLoop;\n\n      for (let i = activeIndex + 1; i < slides.length; i += 1) {\n        if (slides[i] && !breakLoop) {\n          slideSize += slides[i].swiperSlideSize;\n          spv += 1;\n          if (slideSize > swiperSize) breakLoop = true;\n        }\n      }\n\n      for (let i = activeIndex - 1; i >= 0; i -= 1) {\n        if (slides[i] && !breakLoop) {\n          slideSize += slides[i].swiperSlideSize;\n          spv += 1;\n          if (slideSize > swiperSize) breakLoop = true;\n        }\n      }\n    } else {\n      // eslint-disable-next-line\n      if (view === 'current') {\n        for (let i = activeIndex + 1; i < slides.length; i += 1) {\n          const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;\n\n          if (slideInView) {\n            spv += 1;\n          }\n        }\n      } else {\n        // previous\n        for (let i = activeIndex - 1; i >= 0; i -= 1) {\n          const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n\n          if (slideInView) {\n            spv += 1;\n          }\n        }\n      }\n    }\n\n    return spv;\n  }\n\n  update() {\n    const swiper = this;\n    if (!swiper || swiper.destroyed) return;\n    const {\n      snapGrid,\n      params\n    } = swiper; // Breakpoints\n\n    if (params.breakpoints) {\n      swiper.setBreakpoint();\n    }\n\n    swiper.updateSize();\n    swiper.updateSlides();\n    swiper.updateProgress();\n    swiper.updateSlidesClasses();\n\n    function setTranslate() {\n      const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n      const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n      swiper.setTranslate(newTranslate);\n      swiper.updateActiveIndex();\n      swiper.updateSlidesClasses();\n    }\n\n    let translated;\n\n    if (swiper.params.freeMode && swiper.params.freeMode.enabled) {\n      setTranslate();\n\n      if (swiper.params.autoHeight) {\n        swiper.updateAutoHeight();\n      }\n    } else {\n      if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n        translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n      } else {\n        translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n      }\n\n      if (!translated) {\n        setTranslate();\n      }\n    }\n\n    if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n      swiper.checkOverflow();\n    }\n\n    swiper.emit('update');\n  }\n\n  changeDirection(newDirection, needUpdate = true) {\n    const swiper = this;\n    const currentDirection = swiper.params.direction;\n\n    if (!newDirection) {\n      // eslint-disable-next-line\n      newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n    }\n\n    if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n      return swiper;\n    }\n\n    swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);\n    swiper.emitContainerClasses();\n    swiper.params.direction = newDirection;\n    swiper.slides.each(slideEl => {\n      if (newDirection === 'vertical') {\n        slideEl.style.width = '';\n      } else {\n        slideEl.style.height = '';\n      }\n    });\n    swiper.emit('changeDirection');\n    if (needUpdate) swiper.update();\n    return swiper;\n  }\n\n  changeLanguageDirection(direction) {\n    const swiper = this;\n    if (swiper.rtl && direction === 'rtl' || !swiper.rtl && direction === 'ltr') return;\n    swiper.rtl = direction === 'rtl';\n    swiper.rtlTranslate = swiper.params.direction === 'horizontal' && swiper.rtl;\n\n    if (swiper.rtl) {\n      swiper.$el.addClass(`${swiper.params.containerModifierClass}rtl`);\n      swiper.el.dir = 'rtl';\n    } else {\n      swiper.$el.removeClass(`${swiper.params.containerModifierClass}rtl`);\n      swiper.el.dir = 'ltr';\n    }\n\n    swiper.update();\n  }\n\n  mount(el) {\n    const swiper = this;\n    if (swiper.mounted) return true; // Find el\n\n    const $el = $(el || swiper.params.el);\n    el = $el[0];\n\n    if (!el) {\n      return false;\n    }\n\n    el.swiper = swiper;\n\n    const getWrapperSelector = () => {\n      return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n    };\n\n    const getWrapper = () => {\n      if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n        const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items\n\n        res.children = options => $el.children(options);\n\n        return res;\n      }\n\n      if (!$el.children) {\n        return $($el).children(getWrapperSelector());\n      }\n\n      return $el.children(getWrapperSelector());\n    }; // Find Wrapper\n\n\n    let $wrapperEl = getWrapper();\n\n    if ($wrapperEl.length === 0 && swiper.params.createElements) {\n      const document = getDocument();\n      const wrapper = document.createElement('div');\n      $wrapperEl = $(wrapper);\n      wrapper.className = swiper.params.wrapperClass;\n      $el.append(wrapper);\n      $el.children(`.${swiper.params.slideClass}`).each(slideEl => {\n        $wrapperEl.append(slideEl);\n      });\n    }\n\n    Object.assign(swiper, {\n      $el,\n      el,\n      $wrapperEl,\n      wrapperEl: $wrapperEl[0],\n      mounted: true,\n      // RTL\n      rtl: el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl',\n      rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n      wrongRTL: $wrapperEl.css('display') === '-webkit-box'\n    });\n    return true;\n  }\n\n  init(el) {\n    const swiper = this;\n    if (swiper.initialized) return swiper;\n    const mounted = swiper.mount(el);\n    if (mounted === false) return swiper;\n    swiper.emit('beforeInit'); // Set breakpoint\n\n    if (swiper.params.breakpoints) {\n      swiper.setBreakpoint();\n    } // Add Classes\n\n\n    swiper.addClasses(); // Create loop\n\n    if (swiper.params.loop) {\n      swiper.loopCreate();\n    } // Update size\n\n\n    swiper.updateSize(); // Update slides\n\n    swiper.updateSlides();\n\n    if (swiper.params.watchOverflow) {\n      swiper.checkOverflow();\n    } // Set Grab Cursor\n\n\n    if (swiper.params.grabCursor && swiper.enabled) {\n      swiper.setGrabCursor();\n    }\n\n    if (swiper.params.preloadImages) {\n      swiper.preloadImages();\n    } // Slide To Initial Slide\n\n\n    if (swiper.params.loop) {\n      swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);\n    } else {\n      swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n    } // Attach events\n\n\n    swiper.attachEvents(); // Init Flag\n\n    swiper.initialized = true; // Emit\n\n    swiper.emit('init');\n    swiper.emit('afterInit');\n    return swiper;\n  }\n\n  destroy(deleteInstance = true, cleanStyles = true) {\n    const swiper = this;\n    const {\n      params,\n      $el,\n      $wrapperEl,\n      slides\n    } = swiper;\n\n    if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n      return null;\n    }\n\n    swiper.emit('beforeDestroy'); // Init Flag\n\n    swiper.initialized = false; // Detach events\n\n    swiper.detachEvents(); // Destroy loop\n\n    if (params.loop) {\n      swiper.loopDestroy();\n    } // Cleanup styles\n\n\n    if (cleanStyles) {\n      swiper.removeClasses();\n      $el.removeAttr('style');\n      $wrapperEl.removeAttr('style');\n\n      if (slides && slides.length) {\n        slides.removeClass([params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass].join(' ')).removeAttr('style').removeAttr('data-swiper-slide-index');\n      }\n    }\n\n    swiper.emit('destroy'); // Detach emitter events\n\n    Object.keys(swiper.eventsListeners).forEach(eventName => {\n      swiper.off(eventName);\n    });\n\n    if (deleteInstance !== false) {\n      swiper.$el[0].swiper = null;\n      deleteProps(swiper);\n    }\n\n    swiper.destroyed = true;\n    return null;\n  }\n\n  static extendDefaults(newDefaults) {\n    extend(extendedDefaults, newDefaults);\n  }\n\n  static get extendedDefaults() {\n    return extendedDefaults;\n  }\n\n  static get defaults() {\n    return defaults;\n  }\n\n  static installModule(mod) {\n    if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n    const modules = Swiper.prototype.__modules__;\n\n    if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n      modules.push(mod);\n    }\n  }\n\n  static use(module) {\n    if (Array.isArray(module)) {\n      module.forEach(m => Swiper.installModule(m));\n      return Swiper;\n    }\n\n    Swiper.installModule(module);\n    return Swiper;\n  }\n\n}\n\nObject.keys(prototypes).forEach(prototypeGroup => {\n  Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n    Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n  });\n});\nSwiper.use([Resize, Observer]);\nexport default Swiper;","import { getDocument } from 'ssr-window';\nexport default function createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n  const document = getDocument();\n\n  if (swiper.params.createElements) {\n    Object.keys(checkProps).forEach(key => {\n      if (!params[key] && params.auto === true) {\n        let element = swiper.$el.children(`.${checkProps[key]}`)[0];\n\n        if (!element) {\n          element = document.createElement('div');\n          element.className = checkProps[key];\n          swiper.$el.append(element);\n        }\n\n        params[key] = element;\n        originalParams[key] = element;\n      }\n    });\n  }\n\n  return params;\n}","import createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nimport $ from '../../shared/dom.js';\nexport default function Navigation({\n  swiper,\n  extendParams,\n  on,\n  emit\n}) {\n  extendParams({\n    navigation: {\n      nextEl: null,\n      prevEl: null,\n      hideOnClick: false,\n      disabledClass: 'swiper-button-disabled',\n      hiddenClass: 'swiper-button-hidden',\n      lockClass: 'swiper-button-lock',\n      navigationDisabledClass: 'swiper-navigation-disabled'\n    }\n  });\n  swiper.navigation = {\n    nextEl: null,\n    $nextEl: null,\n    prevEl: null,\n    $prevEl: null\n  };\n\n  function getEl(el) {\n    let $el;\n\n    if (el) {\n      $el = $(el);\n\n      if (swiper.params.uniqueNavElements && typeof el === 'string' && $el.length > 1 && swiper.$el.find(el).length === 1) {\n        $el = swiper.$el.find(el);\n      }\n    }\n\n    return $el;\n  }\n\n  function toggleEl($el, disabled) {\n    const params = swiper.params.navigation;\n\n    if ($el && $el.length > 0) {\n      $el[disabled ? 'addClass' : 'removeClass'](params.disabledClass);\n      if ($el[0] && $el[0].tagName === 'BUTTON') $el[0].disabled = disabled;\n\n      if (swiper.params.watchOverflow && swiper.enabled) {\n        $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n      }\n    }\n  }\n\n  function update() {\n    // Update Navigation Buttons\n    if (swiper.params.loop) return;\n    const {\n      $nextEl,\n      $prevEl\n    } = swiper.navigation;\n    toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind);\n    toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind);\n  }\n\n  function onPrevClick(e) {\n    e.preventDefault();\n    if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;\n    swiper.slidePrev();\n    emit('navigationPrev');\n  }\n\n  function onNextClick(e) {\n    e.preventDefault();\n    if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;\n    swiper.slideNext();\n    emit('navigationNext');\n  }\n\n  function init() {\n    const params = swiper.params.navigation;\n    swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {\n      nextEl: 'swiper-button-next',\n      prevEl: 'swiper-button-prev'\n    });\n    if (!(params.nextEl || params.prevEl)) return;\n    const $nextEl = getEl(params.nextEl);\n    const $prevEl = getEl(params.prevEl);\n\n    if ($nextEl && $nextEl.length > 0) {\n      $nextEl.on('click', onNextClick);\n    }\n\n    if ($prevEl && $prevEl.length > 0) {\n      $prevEl.on('click', onPrevClick);\n    }\n\n    Object.assign(swiper.navigation, {\n      $nextEl,\n      nextEl: $nextEl && $nextEl[0],\n      $prevEl,\n      prevEl: $prevEl && $prevEl[0]\n    });\n\n    if (!swiper.enabled) {\n      if ($nextEl) $nextEl.addClass(params.lockClass);\n      if ($prevEl) $prevEl.addClass(params.lockClass);\n    }\n  }\n\n  function destroy() {\n    const {\n      $nextEl,\n      $prevEl\n    } = swiper.navigation;\n\n    if ($nextEl && $nextEl.length) {\n      $nextEl.off('click', onNextClick);\n      $nextEl.removeClass(swiper.params.navigation.disabledClass);\n    }\n\n    if ($prevEl && $prevEl.length) {\n      $prevEl.off('click', onPrevClick);\n      $prevEl.removeClass(swiper.params.navigation.disabledClass);\n    }\n  }\n\n  on('init', () => {\n    if (swiper.params.navigation.enabled === false) {\n      // eslint-disable-next-line\n      disable();\n    } else {\n      init();\n      update();\n    }\n  });\n  on('toEdge fromEdge lock unlock', () => {\n    update();\n  });\n  on('destroy', () => {\n    destroy();\n  });\n  on('enable disable', () => {\n    const {\n      $nextEl,\n      $prevEl\n    } = swiper.navigation;\n\n    if ($nextEl) {\n      $nextEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);\n    }\n\n    if ($prevEl) {\n      $prevEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);\n    }\n  });\n  on('click', (_s, e) => {\n    const {\n      $nextEl,\n      $prevEl\n    } = swiper.navigation;\n    const targetEl = e.target;\n\n    if (swiper.params.navigation.hideOnClick && !$(targetEl).is($prevEl) && !$(targetEl).is($nextEl)) {\n      if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;\n      let isHidden;\n\n      if ($nextEl) {\n        isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);\n      } else if ($prevEl) {\n        isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);\n      }\n\n      if (isHidden === true) {\n        emit('navigationShow');\n      } else {\n        emit('navigationHide');\n      }\n\n      if ($nextEl) {\n        $nextEl.toggleClass(swiper.params.navigation.hiddenClass);\n      }\n\n      if ($prevEl) {\n        $prevEl.toggleClass(swiper.params.navigation.hiddenClass);\n      }\n    }\n  });\n\n  const enable = () => {\n    swiper.$el.removeClass(swiper.params.navigation.navigationDisabledClass);\n    init();\n    update();\n  };\n\n  const disable = () => {\n    swiper.$el.addClass(swiper.params.navigation.navigationDisabledClass);\n    destroy();\n  };\n\n  Object.assign(swiper.navigation, {\n    enable,\n    disable,\n    update,\n    init,\n    destroy\n  });\n}","export default function classesToSelector(classes = '') {\n  return `.${classes.trim().replace(/([\\.:!\\/])/g, '\\\\$1') // eslint-disable-line\n  .replace(/ /g, '.')}`;\n}","import $ from '../../shared/dom.js';\nimport classesToSelector from '../../shared/classes-to-selector.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Pagination({\n  swiper,\n  extendParams,\n  on,\n  emit\n}) {\n  const pfx = 'swiper-pagination';\n  extendParams({\n    pagination: {\n      el: null,\n      bulletElement: 'span',\n      clickable: false,\n      hideOnClick: false,\n      renderBullet: null,\n      renderProgressbar: null,\n      renderFraction: null,\n      renderCustom: null,\n      progressbarOpposite: false,\n      type: 'bullets',\n      // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n      dynamicBullets: false,\n      dynamicMainBullets: 1,\n      formatFractionCurrent: number => number,\n      formatFractionTotal: number => number,\n      bulletClass: `${pfx}-bullet`,\n      bulletActiveClass: `${pfx}-bullet-active`,\n      modifierClass: `${pfx}-`,\n      currentClass: `${pfx}-current`,\n      totalClass: `${pfx}-total`,\n      hiddenClass: `${pfx}-hidden`,\n      progressbarFillClass: `${pfx}-progressbar-fill`,\n      progressbarOppositeClass: `${pfx}-progressbar-opposite`,\n      clickableClass: `${pfx}-clickable`,\n      lockClass: `${pfx}-lock`,\n      horizontalClass: `${pfx}-horizontal`,\n      verticalClass: `${pfx}-vertical`,\n      paginationDisabledClass: `${pfx}-disabled`\n    }\n  });\n  swiper.pagination = {\n    el: null,\n    $el: null,\n    bullets: []\n  };\n  let bulletSize;\n  let dynamicBulletIndex = 0;\n\n  function isPaginationDisabled() {\n    return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;\n  }\n\n  function setSideBullets($bulletEl, position) {\n    const {\n      bulletActiveClass\n    } = swiper.params.pagination;\n    $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);\n  }\n\n  function update() {\n    // Render || Update Pagination bullets/items\n    const rtl = swiper.rtl;\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n    const $el = swiper.pagination.$el; // Current/Total\n\n    let current;\n    const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n    if (swiper.params.loop) {\n      current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n\n      if (current > slidesLength - 1 - swiper.loopedSlides * 2) {\n        current -= slidesLength - swiper.loopedSlides * 2;\n      }\n\n      if (current > total - 1) current -= total;\n      if (current < 0 && swiper.params.paginationType !== 'bullets') current = total + current;\n    } else if (typeof swiper.snapIndex !== 'undefined') {\n      current = swiper.snapIndex;\n    } else {\n      current = swiper.activeIndex || 0;\n    } // Types\n\n\n    if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n      const bullets = swiper.pagination.bullets;\n      let firstIndex;\n      let lastIndex;\n      let midIndex;\n\n      if (params.dynamicBullets) {\n        bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n        $el.css(swiper.isHorizontal() ? 'width' : 'height', `${bulletSize * (params.dynamicMainBullets + 4)}px`);\n\n        if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n          dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);\n\n          if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n            dynamicBulletIndex = params.dynamicMainBullets - 1;\n          } else if (dynamicBulletIndex < 0) {\n            dynamicBulletIndex = 0;\n          }\n        }\n\n        firstIndex = Math.max(current - dynamicBulletIndex, 0);\n        lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n        midIndex = (lastIndex + firstIndex) / 2;\n      }\n\n      bullets.removeClass(['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`).join(' '));\n\n      if ($el.length > 1) {\n        bullets.each(bullet => {\n          const $bullet = $(bullet);\n          const bulletIndex = $bullet.index();\n\n          if (bulletIndex === current) {\n            $bullet.addClass(params.bulletActiveClass);\n          }\n\n          if (params.dynamicBullets) {\n            if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n              $bullet.addClass(`${params.bulletActiveClass}-main`);\n            }\n\n            if (bulletIndex === firstIndex) {\n              setSideBullets($bullet, 'prev');\n            }\n\n            if (bulletIndex === lastIndex) {\n              setSideBullets($bullet, 'next');\n            }\n          }\n        });\n      } else {\n        const $bullet = bullets.eq(current);\n        const bulletIndex = $bullet.index();\n        $bullet.addClass(params.bulletActiveClass);\n\n        if (params.dynamicBullets) {\n          const $firstDisplayedBullet = bullets.eq(firstIndex);\n          const $lastDisplayedBullet = bullets.eq(lastIndex);\n\n          for (let i = firstIndex; i <= lastIndex; i += 1) {\n            bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);\n          }\n\n          if (swiper.params.loop) {\n            if (bulletIndex >= bullets.length) {\n              for (let i = params.dynamicMainBullets; i >= 0; i -= 1) {\n                bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);\n              }\n\n              bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);\n            } else {\n              setSideBullets($firstDisplayedBullet, 'prev');\n              setSideBullets($lastDisplayedBullet, 'next');\n            }\n          } else {\n            setSideBullets($firstDisplayedBullet, 'prev');\n            setSideBullets($lastDisplayedBullet, 'next');\n          }\n        }\n      }\n\n      if (params.dynamicBullets) {\n        const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n        const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n        const offsetProp = rtl ? 'right' : 'left';\n        bullets.css(swiper.isHorizontal() ? offsetProp : 'top', `${bulletsOffset}px`);\n      }\n    }\n\n    if (params.type === 'fraction') {\n      $el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n      $el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));\n    }\n\n    if (params.type === 'progressbar') {\n      let progressbarDirection;\n\n      if (params.progressbarOpposite) {\n        progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n      } else {\n        progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n      }\n\n      const scale = (current + 1) / total;\n      let scaleX = 1;\n      let scaleY = 1;\n\n      if (progressbarDirection === 'horizontal') {\n        scaleX = scale;\n      } else {\n        scaleY = scale;\n      }\n\n      $el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);\n    }\n\n    if (params.type === 'custom' && params.renderCustom) {\n      $el.html(params.renderCustom(swiper, current + 1, total));\n      emit('paginationRender', $el[0]);\n    } else {\n      emit('paginationUpdate', $el[0]);\n    }\n\n    if (swiper.params.watchOverflow && swiper.enabled) {\n      $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n    }\n  }\n\n  function render() {\n    // Render Container\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n    const $el = swiper.pagination.$el;\n    let paginationHTML = '';\n\n    if (params.type === 'bullets') {\n      let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n      if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) {\n        numberOfBullets = slidesLength;\n      }\n\n      for (let i = 0; i < numberOfBullets; i += 1) {\n        if (params.renderBullet) {\n          paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n        } else {\n          paginationHTML += `<${params.bulletElement} class=\"${params.bulletClass}\"></${params.bulletElement}>`;\n        }\n      }\n\n      $el.html(paginationHTML);\n      swiper.pagination.bullets = $el.find(classesToSelector(params.bulletClass));\n    }\n\n    if (params.type === 'fraction') {\n      if (params.renderFraction) {\n        paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n      } else {\n        paginationHTML = `<span class=\"${params.currentClass}\"></span>` + ' / ' + `<span class=\"${params.totalClass}\"></span>`;\n      }\n\n      $el.html(paginationHTML);\n    }\n\n    if (params.type === 'progressbar') {\n      if (params.renderProgressbar) {\n        paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n      } else {\n        paginationHTML = `<span class=\"${params.progressbarFillClass}\"></span>`;\n      }\n\n      $el.html(paginationHTML);\n    }\n\n    if (params.type !== 'custom') {\n      emit('paginationRender', swiper.pagination.$el[0]);\n    }\n  }\n\n  function init() {\n    swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {\n      el: 'swiper-pagination'\n    });\n    const params = swiper.params.pagination;\n    if (!params.el) return;\n    let $el = $(params.el);\n    if ($el.length === 0) return;\n\n    if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1) {\n      $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper\n\n      if ($el.length > 1) {\n        $el = $el.filter(el => {\n          if ($(el).parents('.swiper')[0] !== swiper.el) return false;\n          return true;\n        });\n      }\n    }\n\n    if (params.type === 'bullets' && params.clickable) {\n      $el.addClass(params.clickableClass);\n    }\n\n    $el.addClass(params.modifierClass + params.type);\n    $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n\n    if (params.type === 'bullets' && params.dynamicBullets) {\n      $el.addClass(`${params.modifierClass}${params.type}-dynamic`);\n      dynamicBulletIndex = 0;\n\n      if (params.dynamicMainBullets < 1) {\n        params.dynamicMainBullets = 1;\n      }\n    }\n\n    if (params.type === 'progressbar' && params.progressbarOpposite) {\n      $el.addClass(params.progressbarOppositeClass);\n    }\n\n    if (params.clickable) {\n      $el.on('click', classesToSelector(params.bulletClass), function onClick(e) {\n        e.preventDefault();\n        let index = $(this).index() * swiper.params.slidesPerGroup;\n        if (swiper.params.loop) index += swiper.loopedSlides;\n        swiper.slideTo(index);\n      });\n    }\n\n    Object.assign(swiper.pagination, {\n      $el,\n      el: $el[0]\n    });\n\n    if (!swiper.enabled) {\n      $el.addClass(params.lockClass);\n    }\n  }\n\n  function destroy() {\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    const $el = swiper.pagination.$el;\n    $el.removeClass(params.hiddenClass);\n    $el.removeClass(params.modifierClass + params.type);\n    $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n    if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);\n\n    if (params.clickable) {\n      $el.off('click', classesToSelector(params.bulletClass));\n    }\n  }\n\n  on('init', () => {\n    if (swiper.params.pagination.enabled === false) {\n      // eslint-disable-next-line\n      disable();\n    } else {\n      init();\n      render();\n      update();\n    }\n  });\n  on('activeIndexChange', () => {\n    if (swiper.params.loop) {\n      update();\n    } else if (typeof swiper.snapIndex === 'undefined') {\n      update();\n    }\n  });\n  on('snapIndexChange', () => {\n    if (!swiper.params.loop) {\n      update();\n    }\n  });\n  on('slidesLengthChange', () => {\n    if (swiper.params.loop) {\n      render();\n      update();\n    }\n  });\n  on('snapGridLengthChange', () => {\n    if (!swiper.params.loop) {\n      render();\n      update();\n    }\n  });\n  on('destroy', () => {\n    destroy();\n  });\n  on('enable disable', () => {\n    const {\n      $el\n    } = swiper.pagination;\n\n    if ($el) {\n      $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.pagination.lockClass);\n    }\n  });\n  on('lock unlock', () => {\n    update();\n  });\n  on('click', (_s, e) => {\n    const targetEl = e.target;\n    const {\n      $el\n    } = swiper.pagination;\n\n    if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el && $el.length > 0 && !$(targetEl).hasClass(swiper.params.pagination.bulletClass)) {\n      if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n      const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);\n\n      if (isHidden === true) {\n        emit('paginationShow');\n      } else {\n        emit('paginationHide');\n      }\n\n      $el.toggleClass(swiper.params.pagination.hiddenClass);\n    }\n  });\n\n  const enable = () => {\n    swiper.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n\n    if (swiper.pagination.$el) {\n      swiper.pagination.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n    }\n\n    init();\n    render();\n    update();\n  };\n\n  const disable = () => {\n    swiper.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n\n    if (swiper.pagination.$el) {\n      swiper.pagination.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n    }\n\n    destroy();\n  };\n\n  Object.assign(swiper.pagination, {\n    enable,\n    disable,\n    render,\n    update,\n    init,\n    destroy\n  });\n}","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Lazy({\n  swiper,\n  extendParams,\n  on,\n  emit\n}) {\n  extendParams({\n    lazy: {\n      checkInView: false,\n      enabled: false,\n      loadPrevNext: false,\n      loadPrevNextAmount: 1,\n      loadOnTransitionStart: false,\n      scrollingElement: '',\n      elementClass: 'swiper-lazy',\n      loadingClass: 'swiper-lazy-loading',\n      loadedClass: 'swiper-lazy-loaded',\n      preloaderClass: 'swiper-lazy-preloader'\n    }\n  });\n  swiper.lazy = {};\n  let scrollHandlerAttached = false;\n  let initialImageLoaded = false;\n\n  function loadInSlide(index, loadInDuplicate = true) {\n    const params = swiper.params.lazy;\n    if (typeof index === 'undefined') return;\n    if (swiper.slides.length === 0) return;\n    const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n    const $slideEl = isVirtual ? swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${index}\"]`) : swiper.slides.eq(index);\n    const $images = $slideEl.find(`.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`);\n\n    if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) {\n      $images.push($slideEl[0]);\n    }\n\n    if ($images.length === 0) return;\n    $images.each(imageEl => {\n      const $imageEl = $(imageEl);\n      $imageEl.addClass(params.loadingClass);\n      const background = $imageEl.attr('data-background');\n      const src = $imageEl.attr('data-src');\n      const srcset = $imageEl.attr('data-srcset');\n      const sizes = $imageEl.attr('data-sizes');\n      const $pictureEl = $imageEl.parent('picture');\n      swiper.loadImage($imageEl[0], src || background, srcset, sizes, false, () => {\n        if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper && !swiper.params || swiper.destroyed) return;\n\n        if (background) {\n          $imageEl.css('background-image', `url(\"${background}\")`);\n          $imageEl.removeAttr('data-background');\n        } else {\n          if (srcset) {\n            $imageEl.attr('srcset', srcset);\n            $imageEl.removeAttr('data-srcset');\n          }\n\n          if (sizes) {\n            $imageEl.attr('sizes', sizes);\n            $imageEl.removeAttr('data-sizes');\n          }\n\n          if ($pictureEl.length) {\n            $pictureEl.children('source').each(sourceEl => {\n              const $source = $(sourceEl);\n\n              if ($source.attr('data-srcset')) {\n                $source.attr('srcset', $source.attr('data-srcset'));\n                $source.removeAttr('data-srcset');\n              }\n            });\n          }\n\n          if (src) {\n            $imageEl.attr('src', src);\n            $imageEl.removeAttr('data-src');\n          }\n        }\n\n        $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);\n        $slideEl.find(`.${params.preloaderClass}`).remove();\n\n        if (swiper.params.loop && loadInDuplicate) {\n          const slideOriginalIndex = $slideEl.attr('data-swiper-slide-index');\n\n          if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {\n            const originalSlide = swiper.$wrapperEl.children(`[data-swiper-slide-index=\"${slideOriginalIndex}\"]:not(.${swiper.params.slideDuplicateClass})`);\n            loadInSlide(originalSlide.index(), false);\n          } else {\n            const duplicatedSlide = swiper.$wrapperEl.children(`.${swiper.params.slideDuplicateClass}[data-swiper-slide-index=\"${slideOriginalIndex}\"]`);\n            loadInSlide(duplicatedSlide.index(), false);\n          }\n        }\n\n        emit('lazyImageReady', $slideEl[0], $imageEl[0]);\n\n        if (swiper.params.autoHeight) {\n          swiper.updateAutoHeight();\n        }\n      });\n      emit('lazyImageLoad', $slideEl[0], $imageEl[0]);\n    });\n  }\n\n  function load() {\n    const {\n      $wrapperEl,\n      params: swiperParams,\n      slides,\n      activeIndex\n    } = swiper;\n    const isVirtual = swiper.virtual && swiperParams.virtual.enabled;\n    const params = swiperParams.lazy;\n    let slidesPerView = swiperParams.slidesPerView;\n\n    if (slidesPerView === 'auto') {\n      slidesPerView = 0;\n    }\n\n    function slideExist(index) {\n      if (isVirtual) {\n        if ($wrapperEl.children(`.${swiperParams.slideClass}[data-swiper-slide-index=\"${index}\"]`).length) {\n          return true;\n        }\n      } else if (slides[index]) return true;\n\n      return false;\n    }\n\n    function slideIndex(slideEl) {\n      if (isVirtual) {\n        return $(slideEl).attr('data-swiper-slide-index');\n      }\n\n      return $(slideEl).index();\n    }\n\n    if (!initialImageLoaded) initialImageLoaded = true;\n\n    if (swiper.params.watchSlidesProgress) {\n      $wrapperEl.children(`.${swiperParams.slideVisibleClass}`).each(slideEl => {\n        const index = isVirtual ? $(slideEl).attr('data-swiper-slide-index') : $(slideEl).index();\n        loadInSlide(index);\n      });\n    } else if (slidesPerView > 1) {\n      for (let i = activeIndex; i < activeIndex + slidesPerView; i += 1) {\n        if (slideExist(i)) loadInSlide(i);\n      }\n    } else {\n      loadInSlide(activeIndex);\n    }\n\n    if (params.loadPrevNext) {\n      if (slidesPerView > 1 || params.loadPrevNextAmount && params.loadPrevNextAmount > 1) {\n        const amount = params.loadPrevNextAmount;\n        const spv = Math.ceil(slidesPerView);\n        const maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);\n        const minIndex = Math.max(activeIndex - Math.max(spv, amount), 0); // Next Slides\n\n        for (let i = activeIndex + spv; i < maxIndex; i += 1) {\n          if (slideExist(i)) loadInSlide(i);\n        } // Prev Slides\n\n\n        for (let i = minIndex; i < activeIndex; i += 1) {\n          if (slideExist(i)) loadInSlide(i);\n        }\n      } else {\n        const nextSlide = $wrapperEl.children(`.${swiperParams.slideNextClass}`);\n        if (nextSlide.length > 0) loadInSlide(slideIndex(nextSlide));\n        const prevSlide = $wrapperEl.children(`.${swiperParams.slidePrevClass}`);\n        if (prevSlide.length > 0) loadInSlide(slideIndex(prevSlide));\n      }\n    }\n  }\n\n  function checkInViewOnLoad() {\n    const window = getWindow();\n    if (!swiper || swiper.destroyed) return;\n    const $scrollElement = swiper.params.lazy.scrollingElement ? $(swiper.params.lazy.scrollingElement) : $(window);\n    const isWindow = $scrollElement[0] === window;\n    const scrollElementWidth = isWindow ? window.innerWidth : $scrollElement[0].offsetWidth;\n    const scrollElementHeight = isWindow ? window.innerHeight : $scrollElement[0].offsetHeight;\n    const swiperOffset = swiper.$el.offset();\n    const {\n      rtlTranslate: rtl\n    } = swiper;\n    let inView = false;\n    if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n    const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiper.width, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiper.height], [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height]];\n\n    for (let i = 0; i < swiperCoord.length; i += 1) {\n      const point = swiperCoord[i];\n\n      if (point[0] >= 0 && point[0] <= scrollElementWidth && point[1] >= 0 && point[1] <= scrollElementHeight) {\n        if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n        inView = true;\n      }\n    }\n\n    const passiveListener = swiper.touchEvents.start === 'touchstart' && swiper.support.passiveListener && swiper.params.passiveListeners ? {\n      passive: true,\n      capture: false\n    } : false;\n\n    if (inView) {\n      load();\n      $scrollElement.off('scroll', checkInViewOnLoad, passiveListener);\n    } else if (!scrollHandlerAttached) {\n      scrollHandlerAttached = true;\n      $scrollElement.on('scroll', checkInViewOnLoad, passiveListener);\n    }\n  }\n\n  on('beforeInit', () => {\n    if (swiper.params.lazy.enabled && swiper.params.preloadImages) {\n      swiper.params.preloadImages = false;\n    }\n  });\n  on('init', () => {\n    if (swiper.params.lazy.enabled) {\n      if (swiper.params.lazy.checkInView) {\n        checkInViewOnLoad();\n      } else {\n        load();\n      }\n    }\n  });\n  on('scroll', () => {\n    if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.freeMode.sticky) {\n      load();\n    }\n  });\n  on('scrollbarDragMove resize _freeModeNoMomentumRelease', () => {\n    if (swiper.params.lazy.enabled) {\n      if (swiper.params.lazy.checkInView) {\n        checkInViewOnLoad();\n      } else {\n        load();\n      }\n    }\n  });\n  on('transitionStart', () => {\n    if (swiper.params.lazy.enabled) {\n      if (swiper.params.lazy.loadOnTransitionStart || !swiper.params.lazy.loadOnTransitionStart && !initialImageLoaded) {\n        if (swiper.params.lazy.checkInView) {\n          checkInViewOnLoad();\n        } else {\n          load();\n        }\n      }\n    }\n  });\n  on('transitionEnd', () => {\n    if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {\n      if (swiper.params.lazy.checkInView) {\n        checkInViewOnLoad();\n      } else {\n        load();\n      }\n    }\n  });\n  on('slideChange', () => {\n    const {\n      lazy,\n      cssMode,\n      watchSlidesProgress,\n      touchReleaseOnEdges,\n      resistanceRatio\n    } = swiper.params;\n\n    if (lazy.enabled && (cssMode || watchSlidesProgress && (touchReleaseOnEdges || resistanceRatio === 0))) {\n      load();\n    }\n  });\n  on('destroy', () => {\n    if (!swiper.$el) return;\n    swiper.$el.find(`.${swiper.params.lazy.loadingClass}`).removeClass(swiper.params.lazy.loadingClass);\n  });\n  Object.assign(swiper.lazy, {\n    load,\n    loadInSlide\n  });\n}","import classesToSelector from '../../shared/classes-to-selector.js';\nimport $ from '../../shared/dom.js';\nexport default function A11y({\n  swiper,\n  extendParams,\n  on\n}) {\n  extendParams({\n    a11y: {\n      enabled: true,\n      notificationClass: 'swiper-notification',\n      prevSlideMessage: 'Previous slide',\n      nextSlideMessage: 'Next slide',\n      firstSlideMessage: 'This is the first slide',\n      lastSlideMessage: 'This is the last slide',\n      paginationBulletMessage: 'Go to slide {{index}}',\n      slideLabelMessage: '{{index}} / {{slidesLength}}',\n      containerMessage: null,\n      containerRoleDescriptionMessage: null,\n      itemRoleDescriptionMessage: null,\n      slideRole: 'group',\n      id: null\n    }\n  });\n  swiper.a11y = {\n    clicked: false\n  };\n  let liveRegion = null;\n\n  function notify(message) {\n    const notification = liveRegion;\n    if (notification.length === 0) return;\n    notification.html('');\n    notification.html(message);\n  }\n\n  function getRandomNumber(size = 16) {\n    const randomChar = () => Math.round(16 * Math.random()).toString(16);\n\n    return 'x'.repeat(size).replace(/x/g, randomChar);\n  }\n\n  function makeElFocusable($el) {\n    $el.attr('tabIndex', '0');\n  }\n\n  function makeElNotFocusable($el) {\n    $el.attr('tabIndex', '-1');\n  }\n\n  function addElRole($el, role) {\n    $el.attr('role', role);\n  }\n\n  function addElRoleDescription($el, description) {\n    $el.attr('aria-roledescription', description);\n  }\n\n  function addElControls($el, controls) {\n    $el.attr('aria-controls', controls);\n  }\n\n  function addElLabel($el, label) {\n    $el.attr('aria-label', label);\n  }\n\n  function addElId($el, id) {\n    $el.attr('id', id);\n  }\n\n  function addElLive($el, live) {\n    $el.attr('aria-live', live);\n  }\n\n  function disableEl($el) {\n    $el.attr('aria-disabled', true);\n  }\n\n  function enableEl($el) {\n    $el.attr('aria-disabled', false);\n  }\n\n  function onEnterOrSpaceKey(e) {\n    if (e.keyCode !== 13 && e.keyCode !== 32) return;\n    const params = swiper.params.a11y;\n    const $targetEl = $(e.target);\n\n    if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {\n      if (!(swiper.isEnd && !swiper.params.loop)) {\n        swiper.slideNext();\n      }\n\n      if (swiper.isEnd) {\n        notify(params.lastSlideMessage);\n      } else {\n        notify(params.nextSlideMessage);\n      }\n    }\n\n    if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {\n      if (!(swiper.isBeginning && !swiper.params.loop)) {\n        swiper.slidePrev();\n      }\n\n      if (swiper.isBeginning) {\n        notify(params.firstSlideMessage);\n      } else {\n        notify(params.prevSlideMessage);\n      }\n    }\n\n    if (swiper.pagination && $targetEl.is(classesToSelector(swiper.params.pagination.bulletClass))) {\n      $targetEl[0].click();\n    }\n  }\n\n  function updateNavigation() {\n    if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;\n    const {\n      $nextEl,\n      $prevEl\n    } = swiper.navigation;\n\n    if ($prevEl && $prevEl.length > 0) {\n      if (swiper.isBeginning) {\n        disableEl($prevEl);\n        makeElNotFocusable($prevEl);\n      } else {\n        enableEl($prevEl);\n        makeElFocusable($prevEl);\n      }\n    }\n\n    if ($nextEl && $nextEl.length > 0) {\n      if (swiper.isEnd) {\n        disableEl($nextEl);\n        makeElNotFocusable($nextEl);\n      } else {\n        enableEl($nextEl);\n        makeElFocusable($nextEl);\n      }\n    }\n  }\n\n  function hasPagination() {\n    return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;\n  }\n\n  function hasClickablePagination() {\n    return hasPagination() && swiper.params.pagination.clickable;\n  }\n\n  function updatePagination() {\n    const params = swiper.params.a11y;\n    if (!hasPagination()) return;\n    swiper.pagination.bullets.each(bulletEl => {\n      const $bulletEl = $(bulletEl);\n\n      if (swiper.params.pagination.clickable) {\n        makeElFocusable($bulletEl);\n\n        if (!swiper.params.pagination.renderBullet) {\n          addElRole($bulletEl, 'button');\n          addElLabel($bulletEl, params.paginationBulletMessage.replace(/\\{\\{index\\}\\}/, $bulletEl.index() + 1));\n        }\n      }\n\n      if ($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)) {\n        $bulletEl.attr('aria-current', 'true');\n      } else {\n        $bulletEl.removeAttr('aria-current');\n      }\n    });\n  }\n\n  const initNavEl = ($el, wrapperId, message) => {\n    makeElFocusable($el);\n\n    if ($el[0].tagName !== 'BUTTON') {\n      addElRole($el, 'button');\n      $el.on('keydown', onEnterOrSpaceKey);\n    }\n\n    addElLabel($el, message);\n    addElControls($el, wrapperId);\n  };\n\n  const handlePointerDown = () => {\n    swiper.a11y.clicked = true;\n  };\n\n  const handlePointerUp = () => {\n    requestAnimationFrame(() => {\n      requestAnimationFrame(() => {\n        if (!swiper.destroyed) {\n          swiper.a11y.clicked = false;\n        }\n      });\n    });\n  };\n\n  const handleFocus = e => {\n    if (swiper.a11y.clicked) return;\n    const slideEl = e.target.closest(`.${swiper.params.slideClass}`);\n    if (!slideEl || !swiper.slides.includes(slideEl)) return;\n    const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex;\n    const isVisible = swiper.params.watchSlidesProgress && swiper.visibleSlides && swiper.visibleSlides.includes(slideEl);\n    if (isActive || isVisible) return;\n    if (e.sourceCapabilities && e.sourceCapabilities.firesTouchEvents) return;\n\n    if (swiper.isHorizontal()) {\n      swiper.el.scrollLeft = 0;\n    } else {\n      swiper.el.scrollTop = 0;\n    }\n\n    swiper.slideTo(swiper.slides.indexOf(slideEl), 0);\n  };\n\n  const initSlides = () => {\n    const params = swiper.params.a11y;\n\n    if (params.itemRoleDescriptionMessage) {\n      addElRoleDescription($(swiper.slides), params.itemRoleDescriptionMessage);\n    }\n\n    if (params.slideRole) {\n      addElRole($(swiper.slides), params.slideRole);\n    }\n\n    const slidesLength = swiper.params.loop ? swiper.slides.filter(el => !el.classList.contains(swiper.params.slideDuplicateClass)).length : swiper.slides.length;\n\n    if (params.slideLabelMessage) {\n      swiper.slides.each((slideEl, index) => {\n        const $slideEl = $(slideEl);\n        const slideIndex = swiper.params.loop ? parseInt($slideEl.attr('data-swiper-slide-index'), 10) : index;\n        const ariaLabelMessage = params.slideLabelMessage.replace(/\\{\\{index\\}\\}/, slideIndex + 1).replace(/\\{\\{slidesLength\\}\\}/, slidesLength);\n        addElLabel($slideEl, ariaLabelMessage);\n      });\n    }\n  };\n\n  const init = () => {\n    const params = swiper.params.a11y;\n    swiper.$el.append(liveRegion); // Container\n\n    const $containerEl = swiper.$el;\n\n    if (params.containerRoleDescriptionMessage) {\n      addElRoleDescription($containerEl, params.containerRoleDescriptionMessage);\n    }\n\n    if (params.containerMessage) {\n      addElLabel($containerEl, params.containerMessage);\n    } // Wrapper\n\n\n    const $wrapperEl = swiper.$wrapperEl;\n    const wrapperId = params.id || $wrapperEl.attr('id') || `swiper-wrapper-${getRandomNumber(16)}`;\n    const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';\n    addElId($wrapperEl, wrapperId);\n    addElLive($wrapperEl, live); // Slide\n\n    initSlides(); // Navigation\n\n    let $nextEl;\n    let $prevEl;\n\n    if (swiper.navigation && swiper.navigation.$nextEl) {\n      $nextEl = swiper.navigation.$nextEl;\n    }\n\n    if (swiper.navigation && swiper.navigation.$prevEl) {\n      $prevEl = swiper.navigation.$prevEl;\n    }\n\n    if ($nextEl && $nextEl.length) {\n      initNavEl($nextEl, wrapperId, params.nextSlideMessage);\n    }\n\n    if ($prevEl && $prevEl.length) {\n      initNavEl($prevEl, wrapperId, params.prevSlideMessage);\n    } // Pagination\n\n\n    if (hasClickablePagination()) {\n      swiper.pagination.$el.on('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n    } // Tab focus\n\n\n    swiper.$el.on('focus', handleFocus, true);\n    swiper.$el.on('pointerdown', handlePointerDown, true);\n    swiper.$el.on('pointerup', handlePointerUp, true);\n  };\n\n  function destroy() {\n    if (liveRegion && liveRegion.length > 0) liveRegion.remove();\n    let $nextEl;\n    let $prevEl;\n\n    if (swiper.navigation && swiper.navigation.$nextEl) {\n      $nextEl = swiper.navigation.$nextEl;\n    }\n\n    if (swiper.navigation && swiper.navigation.$prevEl) {\n      $prevEl = swiper.navigation.$prevEl;\n    }\n\n    if ($nextEl) {\n      $nextEl.off('keydown', onEnterOrSpaceKey);\n    }\n\n    if ($prevEl) {\n      $prevEl.off('keydown', onEnterOrSpaceKey);\n    } // Pagination\n\n\n    if (hasClickablePagination()) {\n      swiper.pagination.$el.off('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n    } // Tab focus\n\n\n    swiper.$el.off('focus', handleFocus, true);\n    swiper.$el.off('pointerdown', handlePointerDown, true);\n    swiper.$el.off('pointerup', handlePointerUp, true);\n  }\n\n  on('beforeInit', () => {\n    liveRegion = $(`<span class=\"${swiper.params.a11y.notificationClass}\" aria-live=\"assertive\" aria-atomic=\"true\"></span>`);\n  });\n  on('afterInit', () => {\n    if (!swiper.params.a11y.enabled) return;\n    init();\n  });\n  on('slidesLengthChange snapGridLengthChange slidesGridLengthChange', () => {\n    if (!swiper.params.a11y.enabled) return;\n    initSlides();\n  });\n  on('fromEdge toEdge afterInit lock unlock', () => {\n    if (!swiper.params.a11y.enabled) return;\n    updateNavigation();\n  });\n  on('paginationUpdate', () => {\n    if (!swiper.params.a11y.enabled) return;\n    updatePagination();\n  });\n  on('destroy', () => {\n    if (!swiper.params.a11y.enabled) return;\n    destroy();\n  });\n}","/* eslint no-underscore-dangle: \"off\" */\n\n/* eslint no-use-before-define: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport { nextTick } from '../../shared/utils.js';\nexport default function Autoplay({\n  swiper,\n  extendParams,\n  on,\n  emit\n}) {\n  let timeout;\n  swiper.autoplay = {\n    running: false,\n    paused: false\n  };\n  extendParams({\n    autoplay: {\n      enabled: false,\n      delay: 3000,\n      waitForTransition: true,\n      disableOnInteraction: true,\n      stopOnLastSlide: false,\n      reverseDirection: false,\n      pauseOnMouseEnter: false\n    }\n  });\n\n  function run() {\n    if (!swiper.size) {\n      swiper.autoplay.running = false;\n      swiper.autoplay.paused = false;\n      return;\n    }\n\n    const $activeSlideEl = swiper.slides.eq(swiper.activeIndex);\n    let delay = swiper.params.autoplay.delay;\n\n    if ($activeSlideEl.attr('data-swiper-autoplay')) {\n      delay = $activeSlideEl.attr('data-swiper-autoplay') || swiper.params.autoplay.delay;\n    }\n\n    clearTimeout(timeout);\n    timeout = nextTick(() => {\n      let autoplayResult;\n\n      if (swiper.params.autoplay.reverseDirection) {\n        if (swiper.params.loop) {\n          swiper.loopFix();\n          autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n          emit('autoplay');\n        } else if (!swiper.isBeginning) {\n          autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n          emit('autoplay');\n        } else if (!swiper.params.autoplay.stopOnLastSlide) {\n          autoplayResult = swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);\n          emit('autoplay');\n        } else {\n          stop();\n        }\n      } else if (swiper.params.loop) {\n        swiper.loopFix();\n        autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n        emit('autoplay');\n      } else if (!swiper.isEnd) {\n        autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n        emit('autoplay');\n      } else if (!swiper.params.autoplay.stopOnLastSlide) {\n        autoplayResult = swiper.slideTo(0, swiper.params.speed, true, true);\n        emit('autoplay');\n      } else {\n        stop();\n      }\n\n      if (swiper.params.cssMode && swiper.autoplay.running) run();else if (autoplayResult === false) {\n        run();\n      }\n    }, delay);\n  }\n\n  function start() {\n    if (typeof timeout !== 'undefined') return false;\n    if (swiper.autoplay.running) return false;\n    swiper.autoplay.running = true;\n    emit('autoplayStart');\n    run();\n    return true;\n  }\n\n  function stop() {\n    if (!swiper.autoplay.running) return false;\n    if (typeof timeout === 'undefined') return false;\n\n    if (timeout) {\n      clearTimeout(timeout);\n      timeout = undefined;\n    }\n\n    swiper.autoplay.running = false;\n    emit('autoplayStop');\n    return true;\n  }\n\n  function pause(speed) {\n    if (!swiper.autoplay.running) return;\n    if (swiper.autoplay.paused) return;\n    if (timeout) clearTimeout(timeout);\n    swiper.autoplay.paused = true;\n\n    if (speed === 0 || !swiper.params.autoplay.waitForTransition) {\n      swiper.autoplay.paused = false;\n      run();\n    } else {\n      ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n        swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd);\n      });\n    }\n  }\n\n  function onVisibilityChange() {\n    const document = getDocument();\n\n    if (document.visibilityState === 'hidden' && swiper.autoplay.running) {\n      pause();\n    }\n\n    if (document.visibilityState === 'visible' && swiper.autoplay.paused) {\n      run();\n      swiper.autoplay.paused = false;\n    }\n  }\n\n  function onTransitionEnd(e) {\n    if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return;\n    if (e.target !== swiper.$wrapperEl[0]) return;\n    ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n      swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n    });\n    swiper.autoplay.paused = false;\n\n    if (!swiper.autoplay.running) {\n      stop();\n    } else {\n      run();\n    }\n  }\n\n  function onMouseEnter() {\n    if (swiper.params.autoplay.disableOnInteraction) {\n      stop();\n    } else {\n      emit('autoplayPause');\n      pause();\n    }\n\n    ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n      swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n    });\n  }\n\n  function onMouseLeave() {\n    if (swiper.params.autoplay.disableOnInteraction) {\n      return;\n    }\n\n    swiper.autoplay.paused = false;\n    emit('autoplayResume');\n    run();\n  }\n\n  function attachMouseEvents() {\n    if (swiper.params.autoplay.pauseOnMouseEnter) {\n      swiper.$el.on('mouseenter', onMouseEnter);\n      swiper.$el.on('mouseleave', onMouseLeave);\n    }\n  }\n\n  function detachMouseEvents() {\n    swiper.$el.off('mouseenter', onMouseEnter);\n    swiper.$el.off('mouseleave', onMouseLeave);\n  }\n\n  on('init', () => {\n    if (swiper.params.autoplay.enabled) {\n      start();\n      const document = getDocument();\n      document.addEventListener('visibilitychange', onVisibilityChange);\n      attachMouseEvents();\n    }\n  });\n  on('beforeTransitionStart', (_s, speed, internal) => {\n    if (swiper.autoplay.running) {\n      if (internal || !swiper.params.autoplay.disableOnInteraction) {\n        swiper.autoplay.pause(speed);\n      } else {\n        stop();\n      }\n    }\n  });\n  on('sliderFirstMove', () => {\n    if (swiper.autoplay.running) {\n      if (swiper.params.autoplay.disableOnInteraction) {\n        stop();\n      } else {\n        pause();\n      }\n    }\n  });\n  on('touchEnd', () => {\n    if (swiper.params.cssMode && swiper.autoplay.paused && !swiper.params.autoplay.disableOnInteraction) {\n      run();\n    }\n  });\n  on('destroy', () => {\n    detachMouseEvents();\n\n    if (swiper.autoplay.running) {\n      stop();\n    }\n\n    const document = getDocument();\n    document.removeEventListener('visibilitychange', onVisibilityChange);\n  });\n  Object.assign(swiper.autoplay, {\n    pause,\n    run,\n    start,\n    stop\n  });\n}","<template>\n  <div class=\"m-hero-slide__slider\">\n    <div ref=\"slider\" class=\"swiper\">\n      <div class=\"swiper-wrapper\">\n        <slot></slot>\n      </div>\n      <div class=\"m-hero-slide__navigation u-visible@md\">\n        <button v-if=\"props.enableNavigationButtons\" type=\"button\" ref=\"navPrev\"\n          class=\"a-btn a-btn--icon m-hero-slide__nav m-hero-slide__nav--left\">\n          <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n            <use xlink:href=\"#navigation-left\" />\n          </svg>\n        </button>\n        <button v-if=\"props.enableNavigationButtons\" type=\"button\" ref=\"navNext\"\n          class=\"a-btn a-btn--icon m-hero-slide__nav m-hero-slide__nav--right\">\n          <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n            <use xlink:href=\"#navigation-right\" />\n          </svg>\n        </button>\n      </div>\n    </div>\n    <div class=\"swiper-pagination\" ref=\"pagination\"></div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport Swiper, { A11y, Autoplay, Navigation, Pagination } from 'swiper'\nimport 'swiper/css'\nimport 'swiper/css/pagination'\nimport { ComponentPublicInstance, nextTick, onMounted, ref } from 'vue'\n\nconst swiper = ref<Swiper>()\nconst pagination = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst slider = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst navNext = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst navPrev = ref<ComponentPublicInstance<HTMLDivElement>>()\n\nconst props = defineProps({\n  enableNavigationButtons: {\n    type: Boolean,\n    default: true,\n  }\n})\n\nonMounted(() => {\n  nextTick(() => {\n    swiper.value = new Swiper(slider.value as HTMLDivElement, {\n      modules: [Pagination, Navigation, A11y, Autoplay],\n      pagination: {\n        el: pagination.value,\n        type: 'bullets',\n      },\n      navigation: {\n        nextEl: navNext.value as HTMLDivElement,\n        prevEl: navPrev.value as HTMLDivElement,\n      },\n      autoplay: {\n        delay: 10000,\n      },\n      a11y: {\n        enabled: true,\n        containerMessage: 'Hero slider',\n      },\n      grabCursor: true,\n      loop: true,\n    })\n  })\n})\n</script>\n","export interface Product {\n    ID: string\n    name: string\n    quantity: number\n    price: number\n    attributes: Record<string, string>;\n    image_url: string,\n}\n\nexport interface ProductData {\n    ID: string\n    type: 'ProductTypeSimple' | 'ProductTypeConfiguable'\n    name: string\n    displayName: string\n    sku: string\n    description: string\n    // Be carefull it can be a string so you might need to explicitly cast it to number.\n    price: number|string\n    // Be carefull it can be a string so you might need to explicitly cast it to number.\n    originalPrice: number|string\n    media: Media[]\n    variants: Variant[]\n    attributes: { [key: string]: Attribute }\n    url: string\n    available: boolean\n    tags: string[]\n}\n\nexport function hasSale(product: {price: number|string\n    originalPrice: number|string}): boolean {\n    let price: number = Number(product.price)\n    let originalPrice: number = Number(product.originalPrice)\n    return price < originalPrice\n}\n\nexport interface Media {\n    thumbUrl: string\n    sourceUrl: string\n    title: string\n    alt: string\n}\n\nexport interface Variant {\n    ID: string\n    price: number|string\n    originalPrice: number|string\n    attributes: { [key: string]: Attribute }\n    available: boolean\n}\n\nexport interface Attribute {\n    name: string\n    value: string\n    visibility: AttributeVisibility[]\n}\n\nexport enum AttributeVisibility {\n    Catalog = 'catalog',\n    Sales = 'sales',\n}\n\nexport enum ProductType {\n    Simple = 'ProductTypeSimple',\n    Configurable = 'ProductTypeConfiguable',\n}\n","import { Variant } from \"../models/product\"\n\nexport function formatConfigurableAttributes(variant: Variant, configurableAttributes: string[]) {\n  const attributes: string[] = []\n  for (let internalName of configurableAttributes) {\n    if (!Object.keys(variant.attributes ?? {}).includes(internalName)) {\n      continue\n    }\n\n    attributes.push(variant.attributes[internalName].value)\n  }\n\n  return attributes.join(' - ')\n}\n\ntype getValue<T> = (v: T) => string\n\n// sorts items\nexport function sortAttributeValueList<T>(attributeValues: T[], getValue: getValue<T> = (v: T) => v + ''): T[] {\n  let numberSizes: T[] = []\n  let internationalClothingSizes: T[] = []\n  let otherSizes: T[] = []\n\n\n  for (let size of attributeValues) {\n    if (getValue(size).trim().toUpperCase() in INTERNATIONAL_CLOTHING_SIZE_WEIGHTS) {\n      internationalClothingSizes.push(size)\n    } else if (getValue(size).match(/(^(\\d+((\\.|\\,)\\d+)?)((\\/|-)(\\d+((\\.|\\,)\\d+)?))?$)/)) {\n      numberSizes.push(size)\n    } else {\n      otherSizes.push(size)\n    }\n  }\n\n  numberSizes.sort((a, b) => sortNumberSizes(a, b, getValue))\n  internationalClothingSizes.sort((a, b) => sortInternationalProductSizes(a, b, getValue))\n  otherSizes.sort((a, b) => getValue(a).localeCompare(getValue(b)))\n\n  return [...internationalClothingSizes, ...numberSizes, ...otherSizes]\n}\n\nfunction sortInternationalProductSizes<T>(a: T, b: T, formatToString: getValue<T>): number {\n  let aWeight: number = INTERNATIONAL_CLOTHING_SIZE_WEIGHTS[formatToString(a).trim().toUpperCase()] ?? 0\n  let bWeight: number = INTERNATIONAL_CLOTHING_SIZE_WEIGHTS[formatToString(b).trim().toUpperCase()] ?? 0\n  if (aWeight === bWeight) {\n    return 0\n  }\n\n  return aWeight > bWeight ? 1 : -1\n}\n\nfunction sortNumberSizes<T>(a: T, b: T, formatToString: getValue<T>): number {\n  const valA = formatSizeNumber(formatToString(a))\n  const valB = formatSizeNumber(formatToString(b))\n\n  let aFloat: number = parseFloat(valA)\n  let bFloat: number = parseFloat(valB)\n\n  if (aFloat === bFloat) {\n    return 0\n  }\n\n  return aFloat < bFloat ? -1 : 1\n}\n\nfunction formatSizeNumber(val: string): string {\n  if (val.match(/(\\d+\\,\\d+)/)) {\n    val = val.replace(/,/, '.')\n  }\n\n  if (val.match(/(^\\d+(\\.\\d+)?)(\\/|-)(\\d+(\\.\\d+)?$)/)) {\n    val = val.replace(/(\\/|-).*$/, '')\n  }\n\n  return val\n}\n\nconst INTERNATIONAL_CLOTHING_SIZE_WEIGHTS: Record<string, number> = {\n  \"3XS\": 0,\n  \"XXXS\": 0,\n  \"2XS\": 1,\n  \"XXS\": 1,\n  \"XS\": 2,\n  \"S\": 3,\n  \"M\": 4,\n  \"L\": 5,\n  \"XL\": 6,\n  \"XXL\": 7,\n  \"2XL\": 7,\n  \"XXXL\": 8,\n  \"3XL\": 8,\n  \"XXXXL\": 9,\n  \"4XL\": 9,\n  \"XXXXXL\": 10,\n  \"5XL\": 10\n}","<template>\n  <a :href=\"props.product.url\" @click.capture=\"$event => productClickEvent($event, props.product!)\"\n    class=\"m-product__card\" :aria-label=\"props.product.displayName\" v-if=\"!loading && props.product\">\n    <div class=\"m-product__card-img\">\n      <picture class=\"a-image a-image--contain\" style=\"--padding-ratio: calc(1/1)\">\n        <img class=\"a-image__img\" v-if=\"(props.product.media ?? []).length > 0\"\n          :src=\"props.product.media[0].thumbUrl + '?height=5&width=5'\"\n          :data-src=\"props.product.media[0].thumbUrl + '?height=346&width=346'\"\n          :data-srcset=\"props.product.media[0].thumbUrl + '?height=346&width=346 1x , ' + props.product.media[0].thumbUrl + '?height=692&width=692 2x'\"\n          :alt=\"props.product.media[0].alt\" loading=\"lazy\" />\n      </picture>\n      <picture class=\"a-image a-image--contain\">\n        <img class=\"a-image__img\" v-if=\"props.product.media.length === 1\"\n          :src=\"props.product.media[0].thumbUrl + '?height=5&width=5'\"\n          :data-src=\"props.product.media[0].thumbUrl + '?height=346&width=346'\"\n          :data-srcset=\"props.product.media[0].thumbUrl + '?height=346&width=346 1x , ' + props.product.media[0].thumbUrl + '?height=692&width=692 2x'\"\n          :alt=\"props.product.media[0].alt\" loading=\"lazy\" />\n        <img class=\"a-image__img\" v-if=\"props.product.media.length > 1\"\n          :src=\"props.product.media[1].thumbUrl + '?height=5&width=5'\"\n          :data-src=\"props.product.media[1].thumbUrl + '?height=346&width=346'\"\n          :data-srcset=\"props.product.media[1].thumbUrl + '?height=346&width=346 1x , ' + props.product.media[1].thumbUrl + '?height=692&width=692 2x'\"\n          :alt=\"props.product.media[1].alt\" loading=\"lazy\" />\n      </picture>\n      <div class=\"m-product__card-tags\">\n        <div class=\"m-product__card-tag m-product__card-tag--sale-percentage\"\n          v-if=\"props.displayDiscountPercentage && hasSale(props.product)\">\n          <span>\n            -{{ discountPercentage(props.product.price, props.product.originalPrice) }}%\n          </span>\n        </div>\n        <div v-else-if=\"hasSale(props.product)\" class=\"m-product__card-tag m-product__card-tag--red\"\n          v-if=\"hasSale(props.product)\">\n          <span>{{ translate('product.tags.sale') }}</span>\n        </div>\n        <div class=\"m-product__card-tag m-product__card-tag--black\" v-if=\"props.product.tags.includes('new')\">\n          <span>{{\n            translate('product.tags.new') }}</span>\n        </div>\n      </div>\n    </div>\n    <div class=\"m-product__card-info\">\n      <div class=\"m-product__card-title\" v-text=\"props.product.displayName\"></div>\n      <div class=\"m-product__card-prices\">\n        <div class=\"m-product__card-price m-product__card-price--sale\" v-if=\"hasSale(props.product)\">\n          {{ translate('product.price.sale_from', { price: displayPrice(props.product.price) }) }}\n        </div>\n        <div class=\"m-product__card-price m-product__card-price--old\" v-if=\"hasSale(props.product)\"\n          v-text=\"`${displayPrice(props.product.originalPrice)}`\">\n        </div>\n        <div class=\"m-product__card-price\" v-if=\"!hasSale(props.product)\" v-text=\"`${displayPrice(props.product.price)}`\">\n        </div>\n      </div>\n    </div>\n    <div class=\"m-product__card-variants\" v-if=\"props.product.variants\">\n      <ul class=\"m-product__card-variant-list\" aria-label=\"Varianten\">\n        <li class=\"m-product__card-variant\">\n          {{ formatConfigurableAttributes(props.product) }}\n        </li>\n      </ul>\n    </div>\n  </a>\n\n  <div class=\"m-product__card m-product__card--loading\" aria-label=\"\" v-if=\"loading\">\n    <div class=\"m-product__card-img\">\n      <picture class=\"a-image\" style=\"--padding-ratio: calc(1/1)\">\n      </picture>\n    </div>\n    <div class=\"m-product__card-info\">\n      <span class=\"m-product__card-title\"></span>\n      <div class=\"m-product__card-prices\"></div>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { Ref, onMounted, ref } from 'vue'\nimport { ProductData, hasSale } from '../models/product';\nimport { displayPrice, discountPercentage } from '../helper/currency';\nimport { translate } from '../helper-functions';\nimport { EventProductClick, emitEvent } from '../helper/tracking-events';\nimport { sortAttributeValueList } from '../helper/product';\n\nconst props = defineProps({\n  product: {\n    type: Object as () => ProductData,\n  },\n  configurableAttributes: {\n    type: Array<string>,\n    default: () => ['sc_size'],\n  },\n  displayDiscountPercentage: {\n    type: Boolean,\n    default: false,\n  },\n})\n\nconst loading: Ref<boolean> = ref(true)\n\nfunction formatConfigurableAttributes(product: ProductData) {\n  const attributes: string[] = []\n  for (let variant of product.variants) {\n    if (!variant.available) {\n      continue\n    }\n\n    for (let internalName of props.configurableAttributes) {\n      if (!Object.keys(variant.attributes ?? {}).includes(internalName)) {\n        continue\n      }\n\n      attributes.push(variant.attributes[internalName].value)\n    }\n  }\n\n  return sortAttributeValueList(attributes).join(' - ')\n}\n\nonMounted(async () => {\n  if (props.product) {\n    loading.value = false\n  }\n})\n\nfunction productClickEvent(event: Event, product: ProductData) {\n  let attributes: { [key: string]: string } = {}\n  for (let [key, attribute] of Object.entries(product.attributes)) {\n    attributes[key] = attribute.value\n  }\n\n  emitEvent(EventProductClick, {\n    ID: product.ID,\n    name: product.name,\n    variants: product.variants.map(p => {\n      let variantAttributes: { [key: string]: string } = {}\n      for (let [key, attribute] of Object.entries(product.attributes)) {\n        variantAttributes[key] = attribute.value\n      }\n\n      return {\n        ID: p.ID,\n        name: product.name,\n        price: p.price,\n        attributes: variantAttributes,\n      }\n    }),\n    price: product.price,\n    attributes: attributes,\n  })\n}\n</script>\n","<template>\n  <div class=\"m-product__swiper\">\n    <div ref=\"slider\" class=\"swiper\">\n      <div class=\"swiper-wrapper\">\n        <div class=\"swiper-slide swiper-slide--product\" v-for=\"product in props.products\" :key=\"product.ID\">\n          <product-card :product=\"product\" :display-discount-percentage=\"props.displayDiscountPercentage\"></product-card>\n        </div>\n      </div>\n    </div>\n    <button type=\"button\" ref=\"navPrev\" class=\"a-btn a-btn--icon m-product__swiper-nav m-product__swiper-nav--left\">\n      <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n        <use xlink:href=\"#navigation-left\" />\n      </svg>\n    </button>\n    <button type=\"button\" ref=\"navNext\" class=\"a-btn a-btn--icon m-product__swiper-nav m-product__swiper-nav--right\">\n      <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n        <use xlink:href=\"#navigation-right\" />\n      </svg>\n    </button>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport Swiper, { A11y, Navigation } from 'swiper'\nimport 'swiper/css'\nimport 'swiper/css/navigation'\nimport { nextTick, onMounted, ref } from 'vue'\nimport { ProductData } from '../models/product'\nimport ProductCard from './ProductCard.vue'\n\nconst swiper = ref<Swiper>()\n\nconst props = defineProps({\n  products: {\n    type: Object as () => ProductData[],\n    default: [],\n  },\n  displayDiscountPercentage: {\n    type: Boolean,\n    default: false,\n  },\n})\n\nconst slider = ref<HTMLDivElement>()\nconst navNext = ref<HTMLDivElement>()\nconst navPrev = ref<HTMLDivElement>()\n\nonMounted(() => {\n  nextTick(() => {\n    swiper.value = new Swiper(slider.value!, {\n      modules: [Navigation, A11y],\n      navigation: {\n        nextEl: navNext.value,\n        prevEl: navPrev.value,\n      },\n      a11y: {\n        enabled: true,\n        containerMessage: 'Hero slider',\n      },\n      grabCursor: true,\n      slidesPerView: 2.25,\n      spaceBetween: 16,\n      breakpoints: {\n        480: {\n          slidesPerView: 3.5,\n        },\n        1024: {\n          slidesPerView: 4.5,\n        },\n      },\n    })\n  })\n})\n\n\n</script>\n","<template>\n  <div class=\"m-brand-slide__slider\" v-show=\"!loading\">\n    <div ref=\"slider\" class=\"swiper\">\n      <div class=\"swiper-wrapper\">\n        <a v-for=\"brand of props.brands\" :href=\"brand.url\" class=\"m-brand-slide swiper-slide\">\n          <picture class=\"a-image a-image--contain\" style=\"--padding-ratio: calc(100 / 200);\">\n            <img class=\"a-image__img\" :src=\"brand.image\" :alt=\"brand.alt\" loading=\"lazy\">\n          </picture>\n        </a>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport Swiper, { A11y, Autoplay, Lazy } from 'swiper'\nimport 'swiper/css'\nimport { ComponentPublicInstance, nextTick, onMounted, Ref, ref } from 'vue'\nimport { lazyLoadUpdate } from '../lazyload';\n\nconst swiper = ref<Swiper>()\nconst slider = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst loading: Ref<boolean> = ref(true)\n\nconst props = defineProps({\n  brands: Array<{ image: string; url: string; alt: string; }>\n})\n\nonMounted(() => {\n  nextTick(() => {\n    lazyLoadUpdate()\n    swiper.value = new Swiper(slider.value as HTMLDivElement, {\n      modules: [A11y, Lazy, Autoplay],\n      autoplay: {\n        delay: 3000,\n      },\n      slidesPerView: 6.5,\n      centeredSlides: true,\n      grabCursor: true,\n      loop: true,\n      breakpoints: {\n        0: {\n          slidesPerView: 2.5,\n          spaceBetween: 16,\n        },\n        480: {\n          slidesPerView: 4.8,\n        },\n        1080: {\n          slidesPerView: 6.5,\n        }\n      }\n    })\n  })\n  loading.value = false\n})\n</script>\n","export default \"__VITE_ASSET__e7d00aaf__\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","export default \"data:image/png;base64,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\"","<template>\n  <div class=\"m-collapse\" :class=\"{ 'is-open': isOpen }\" ref=\"collapse\">\n    <button type=\"button\" class=\"m-collapse__title\" :aria-expanded=\"isOpen ? 'true' : 'false'\" :aria-controls=\"id\" @click=\"toggle\">\n      <slot name=\"title\"></slot>\n      <span class=\"m-collapse__icon\">\n        <span></span>\n        <span></span>\n      </span>\n    </button>\n\n    <transition @before-enter=\"beforeEnter\" @enter=\"enter\" @after-enter=\"afterEnter\" @before-leave=\"beforeLeave\" @leave=\"leave\" @after-leave=\"afterLeave\">\n      <div class=\"m-collapse__content\" v-show=\"isOpen\" :aria-expanded=\"isOpen ? 'true' : 'false'\" :aria-hidden=\"!isOpen ? 'true' : 'false'\" :id=\"id\">\n        <div class=\"m-collapse__inner\" ref=\"collapseInner\">\n          <slot></slot>\n        </div>\n      </div>\n    </transition>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { v4 as uuidv4 } from 'uuid'\nimport { ComponentPublicInstance, inject, onMounted, ref, watch } from 'vue'\n\nconst props = defineProps({\n  opened: {\n    type: Boolean,\n    default: false,\n  },\n})\n\nconst isOpen = ref(false)\nconst id = ref('collapse_' + uuidv4())\n\nconst collapse = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst collapseInner = ref<ComponentPublicInstance<HTMLDivElement>>()\n\nconst { openElement, setOpenElement } = inject<any>('element')\n\nonMounted(() => {\n  isOpen.value = props.opened\n})\n\nwatch(openElement, (newValue: string) => {\n  newValue === id.value ? isOpen.value = true : isOpen.value = false\n})\n\nconst toggle = () => { openElement.value === id.value ? setOpenElement(null) : setOpenElement(id.value) }\n\nconst beforeEnter = (el: any) => {\n  requestAnimationFrame(() => {\n    if (!el.style.height) {\n      el.style.height = '0px'\n    }\n\n    el.style.display = null\n  })\n}\n\nconst enter = (el: any) => {\n  requestAnimationFrame(() => {\n    requestAnimationFrame(() => {\n      el.style.height = `${el.scrollHeight}px`\n    })\n  })\n}\n\nconst afterEnter = (el: any) => {\n  el.style.height = null\n}\n\nconst beforeLeave = (el: any) => {\n  requestAnimationFrame(() => {\n    if (!el.style.height) {\n      el.style.height = `${el.offsetHeight}px`\n    }\n  })\n}\n\nconst leave = (el: any) => {\n  requestAnimationFrame(() => {\n    requestAnimationFrame(() => {\n      el.style.height = '0px'\n    })\n  })\n}\n\nconst afterLeave = (el: any) => {\n  el.style.height = null\n}\n</script>\n","<template>\n  <div class=\"m-collapse__group\">\n    <h2 class=\"m-collapse__group-title a-h3\" v-if=\"props.title\" v-text=\"props.title\"></h2>\n    <slot></slot>\n  </div>\n</template>\n\n<script setup lang=\"ts\">import { provide, ref } from 'vue'\n\n\nconst props = defineProps({\n  leaveOpen: {\n    type: Boolean,\n    default: false,\n  },\n  title: String,\n})\n\nconst openElement = ref('')\n\nconst setOpenElement = (id: string) => {\n  openElement.value = id\n}\n\nprovide('element', { openElement, setOpenElement })\n</script>\n","<template>\n  <footer>\n    <div class=\"o-footer\">\n      <div class=\"o-container\">\n        <div class=\"o-footer__center\">\n          <div class=\"o-footer__main a-layout\">\n            <div class=\"o-footer__item u-col-span:2@md\">\n              <h2 class=\"o-footer__item-title u-screen-reader-only\" id=\"footer-title-1\">Footer</h2>\n              <nav v-if=\"props.footerMenu.length > 0\" class=\"o-footer__nav\">\n                <ul aria-labelledby=\"footer-title-1\">\n                  <li v-for=\"menu of props.footerMenu\"><a :href=\"menu.url\">{{ menu.name }}</a></li>\n                </ul>\n              </nav>\n            </div>\n            <div\n              v-if=\"(props.textBlocks ?? []).length > 0\"\n              v-for=\"(block, index) in props.textBlocks\"\n              :class=\"`u-visible@md o-footer__item u-col-span:${index == 0 ? '4' : '3'}@md`\"\n            >\n              <h3 class=\"o-footer__item-title\">{{ block.title }}</h3>\n              <div class=\"o-editor-content o-editor-content--footer\" v-html=\"block.text\"></div>\n            </div>\n            <div\n              class=\"o-footer__item u-col-span:3@md\"\n              v-if=\"props.storeAddress !== null\"\n            >\n              <h3 class=\"o-footer__item-title\">{{ translate('contact.general.title') }}</h3>\n              <div class=\"o-editor-content o-editor-content--footer\">\n                {{ props.storeAddress.street }} {{ props.storeAddress.house_number }}{{\n                  props.storeAddress.house_number_extension ? ' ' +\n                props.storeAddress.house_number_extension : '' }}<br>\n                {{ props.storeAddress.zipcode }} {{ props.storeAddress.city }}<br>\n                <a :href=\"`mailto:${props.storeAddress.email}`\" :title=\"props.storeAddress.email\">{{\n                  props.storeAddress.email }}</a> <br>\n                <a :href=\"`tel:${props.storeAddress.phone}`\" :title=\"props.storeAddress.phone\">\n                  {{ props.storeAddress.phone }}</a><br><br>\n                <div v-html=\"props.storeAddress.note\">\n                </div>\n                <section\n                  class=\"m-contact__opening-hours\"\n                  v-if=\"props.storeAddress.opening_hours.length > 0\"\n                >\n                  <strong>\n                    {{ translate('contact.opening_hours.title') }}\n                  </strong>\n                  <table>\n                    <tbody>\n                      <tr v-for=\"openingHour of props.storeAddress.opening_hours\">\n                        <td>{{ openingHour.label }}</td>\n                        <td>{{ openingHour.value }}</td>\n                      </tr>\n                    </tbody>\n                  </table>\n                </section>\n              </div>\n            </div>\n            <base-collapse-group class=\"u-col-span:12 u-hidden@md\">\n              <base-collapse\n                v-if=\"(props.textBlocks ?? []).length > 0\"\n                v-for=\"block of props.textBlocks\"\n              >\n                <template v-slot:title>\n                  <h3 class=\"m-collapse__title m-collapse__title--footer\">{{ block.title }}</h3>\n                </template>\n                <div class=\"o-editor-content o-editor-content--footer\" v-html=\"block.text\"></div>\n              </base-collapse>\n            </base-collapse-group>\n          </div>\n          <div class=\"o-footer__line\"></div>\n          <div class=\"o-footer__main a-layout o-footer__main--under-line\">\n            <div class=\"o-footer__item u-col-span:2@md\">\n              <h3 class=\"o-footer__bottom-item-title\" id=\"footer-title-2\">{{\n                translate('global.social.follow_us') }}</h3>\n              <ul class=\"o-footer__socials\" aria-labelledby=\"footer-title-2\">\n                <li v-for=\"social of socialMedia\">\n                  <a\n                    :href=\"social.url\" class=\"o-footer__social-link\"\n                    :title=\"social.type.toLowerCase()\"\n                  >\n                    <svg class=\"a-icon\" aria-hidden=\"true\">\n                      <use :href=\"'#' + social.type.toLowerCase()\" />\n                    </svg>\n                  </a>\n                </li>\n              </ul>\n            </div>\n            <div class=\"o-footer__item u-col-span:10@md\">\n              <span class=\"a-h2 o-footer__bottom-item-title\">© {{ translate('global.shop.title') }}</span>\n              <ul v-if=\"props.serviceMenu\" class=\"o-footer__item-sub-menu\">\n                <li v-for=\"item of props.serviceMenu\"><a :href=\"item.url\">{{ item.name }}</a></li>\n              </ul>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-footer\">\n      <div class=\"o-footer__bottom\">\n        <ul class=\"o-footer__bottom-list\" v-if=\"paymentIcons && paymentIcons.length > 0\">\n          <li v-for=\"icon of paymentIcons\">\n            <picture class=\"a-image a-image--contain\">\n              <img\n                v-if=\"icon === 'Bancontact'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/bancontact.png\"\n                alt=\"Bancontact\"\n                loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'iDeal'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/ideal.png\"\n                alt=\"Ideal\" loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Maestro'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/maestro.png\"\n                alt=\"Maestro\" loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Mastercard'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/mastercard.png\"\n                alt=\"Mastercard\"\n                loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Paypal'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/paypal.png\"\n                alt=\"Paypal\" loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Visa'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/visa.png\"\n                alt=\"Visa\" loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Sofort'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/sofort.png\"\n                alt=\"Sofort\" loading=\"lazy\"\n              >\n              <img\n                v-if=\"icon === 'Giropay'\"\n                class=\"a-image__img\"\n                src=\"../assets/img/payment-logos/giropay.png\"\n                alt=\"Giropay\" loading=\"lazy\"\n              >\n            </picture>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </footer>\n</template>\n\n<script setup lang=\"ts\">\nimport { PropType, nextTick, onMounted } from 'vue'\nimport BaseCollapse from './BaseCollapse.vue'\nimport BaseCollapseGroup from './BaseCollapseGroup.vue'\nimport { translate } from '../helper-functions'\nimport { lazyLoadUpdate } from '../lazyload'\nimport { StoreAddress } from '../helper/address'\n\nconst props = defineProps({\n  footerMenu: {\n    type: Array<{ name: string; url: string; }>,\n    default: [],\n  },\n  serviceMenu: {\n    type: Array<{ name: string; url: string; }>,\n    default: [],\n  },\n  textBlocks: {\n    type: Array<{ title: string; text: string; }>,\n    default: [],\n  },\n  socialMedia: {\n    type: Array<{\n      type: string;\n      url: string;\n    }>,\n    default: [],\n  },\n  paymentIcons: {\n    type: Array<string>,\n    default: null,\n  },\n  storeAddress: {\n    type: Object as PropType<StoreAddress|null>,\n    default: null,\n  }\n})\n\nonMounted(() => {\n  nextTick(() => {\n    lazyLoadUpdate()\n  })\n})\n</script>\n","/**\r\n * Vue3 Cookies v1.0.0\r\n *\r\n * Forked from\r\n * https://github.com/cmp-cc/vue-cookies\r\n * And changed format to support Vue.js 3\r\n *\r\n */\r\nimport { reactive } from \"vue\";\r\nvar defaultConfig = {\r\n    expireTimes: \"1d\",\r\n    path: \"; path=/\",\r\n    domain: \"\",\r\n    secure: false,\r\n    sameSite: \"; SameSite=Lax\",\r\n};\r\nvar VueCookiesManager = /** @class */ (function () {\r\n    function VueCookiesManager() {\r\n        this.current_default_config = defaultConfig;\r\n    }\r\n    VueCookiesManager.prototype.config = function (config) {\r\n        for (var propertyName in this.current_default_config) {\r\n            this.current_default_config[propertyName] = config[propertyName]\r\n                ? config[propertyName]\r\n                : defaultConfig[propertyName];\r\n        }\r\n    };\r\n    VueCookiesManager.prototype.get = function (keyName) {\r\n        var value = decodeURIComponent(document.cookie.replace(new RegExp(\"(?:(?:^|.*;)\\\\s*\" +\r\n            encodeURIComponent(keyName).replace(/[\\-\\.\\+\\*]/g, \"\\\\$&\") +\r\n            \"\\\\s*\\\\=\\\\s*([^;]*).*$)|^.*$\"), \"$1\")) || null;\r\n        if (value &&\r\n            value.substring(0, 1) === \"{\" &&\r\n            value.substring(value.length - 1, value.length) === \"}\") {\r\n            try {\r\n                value = JSON.parse(value);\r\n            }\r\n            catch (e) {\r\n                return value;\r\n            }\r\n        }\r\n        return value;\r\n    };\r\n    VueCookiesManager.prototype.set = function (keyName, value, expireTimes, path, domain, secure, sameSite) {\r\n        if (!keyName) {\r\n            throw new Error(\"Cookie name is not found in the first argument.\");\r\n        }\r\n        else if (/^(?:expires|max-age|path|domain|secure|SameSite)$/i.test(keyName)) {\r\n            throw new Error('Cookie name illegality. Cannot be set to [\"expires\",\"max-age\",\"path\",\"domain\",\"secure\",\"SameSite\"]\\t current key name: ' +\r\n                keyName);\r\n        }\r\n        // support json object\r\n        if (value && value.constructor === Object) {\r\n            value = JSON.stringify(value);\r\n        }\r\n        var _expires = \"\";\r\n        if (expireTimes == undefined) {\r\n            expireTimes = this.current_default_config.expireTimes\r\n                ? this.current_default_config.expireTimes\r\n                : \"\";\r\n        }\r\n        if (expireTimes && expireTimes != 0) {\r\n            switch (expireTimes.constructor) {\r\n                case Number:\r\n                    if (expireTimes === Infinity || expireTimes === -1)\r\n                        _expires = \"; expires=Fri, 31 Dec 9999 23:59:59 GMT\";\r\n                    else\r\n                        _expires = \"; max-age=\" + expireTimes;\r\n                    break;\r\n                case String:\r\n                    if (/^(?:\\d+(y|m|d|h|min|s))$/i.test(expireTimes)) {\r\n                        // get capture number group\r\n                        var _expireTime = expireTimes.replace(/^(\\d+)(?:y|m|d|h|min|s)$/i, \"$1\");\r\n                        // get capture type group , to lower case\r\n                        switch (expireTimes\r\n                            .replace(/^(?:\\d+)(y|m|d|h|min|s)$/i, \"$1\")\r\n                            .toLowerCase()) {\r\n                            // Frequency sorting\r\n                            case \"m\":\r\n                                _expires = \"; max-age=\" + +_expireTime * 2592000;\r\n                                break; // 60 * 60 * 24 * 30\r\n                            case \"d\":\r\n                                _expires = \"; max-age=\" + +_expireTime * 86400;\r\n                                break; // 60 * 60 * 24\r\n                            case \"h\":\r\n                                _expires = \"; max-age=\" + +_expireTime * 3600;\r\n                                break; // 60 * 60\r\n                            case \"min\":\r\n                                _expires = \"; max-age=\" + +_expireTime * 60;\r\n                                break; // 60\r\n                            case \"s\":\r\n                                _expires = \"; max-age=\" + _expireTime;\r\n                                break;\r\n                            case \"y\":\r\n                                _expires = \"; max-age=\" + +_expireTime * 31104000;\r\n                                break; // 60 * 60 * 24 * 30 * 12\r\n                            default:\r\n                                new Error('unknown exception of \"set operation\"');\r\n                        }\r\n                    }\r\n                    else {\r\n                        _expires = \"; expires=\" + expireTimes;\r\n                    }\r\n                    break;\r\n                case Date:\r\n                    _expires = \"; expires=\" + expireTimes.toUTCString();\r\n                    break;\r\n            }\r\n        }\r\n        document.cookie =\r\n            encodeURIComponent(keyName) +\r\n                \"=\" +\r\n                encodeURIComponent(value) +\r\n                _expires +\r\n                (domain\r\n                    ? \"; domain=\" + domain\r\n                    : this.current_default_config.domain\r\n                        ? this.current_default_config.domain\r\n                        : \"\") +\r\n                (path\r\n                    ? \"; path=\" + path\r\n                    : this.current_default_config.path\r\n                        ? this.current_default_config.path\r\n                        : \"; path=/\") +\r\n                (secure == undefined\r\n                    ? this.current_default_config.secure\r\n                        ? \"; Secure\"\r\n                        : \"\"\r\n                    : secure\r\n                        ? \"; Secure\"\r\n                        : \"\") +\r\n                (sameSite == undefined\r\n                    ? this.current_default_config.sameSite\r\n                        ? \"; SameSute=\" + this.current_default_config.sameSite\r\n                        : \"\"\r\n                    : sameSite\r\n                        ? \"; SameSite=\" + sameSite\r\n                        : \"\");\r\n        return this;\r\n    };\r\n    VueCookiesManager.prototype.remove = function (keyName, path, domain) {\r\n        if (!keyName || !this.isKey(keyName)) {\r\n            return false;\r\n        }\r\n        document.cookie =\r\n            encodeURIComponent(keyName) +\r\n                \"=; expires=Thu, 01 Jan 1970 00:00:00 GMT\" +\r\n                (domain\r\n                    ? \"; domain=\" + domain\r\n                    : this.current_default_config.domain\r\n                        ? this.current_default_config.domain\r\n                        : \"\") +\r\n                (path\r\n                    ? \"; path=\" + path\r\n                    : this.current_default_config.path\r\n                        ? this.current_default_config.path\r\n                        : \"; path=/\") +\r\n                \"; SameSite=Lax\";\r\n        return true;\r\n    };\r\n    VueCookiesManager.prototype.isKey = function (keyName) {\r\n        return new RegExp(\"(?:^|;\\\\s*)\" +\r\n            encodeURIComponent(keyName).replace(/[\\-\\.\\+\\*]/g, \"\\\\$&\") +\r\n            \"\\\\s*\\\\=\").test(document.cookie);\r\n    };\r\n    VueCookiesManager.prototype.keys = function () {\r\n        if (!document.cookie)\r\n            return [];\r\n        var _keys = document.cookie\r\n            .replace(/((?:^|\\s*;)[^\\=]+)(?=;|$)|^\\s*|\\s*(?:\\=[^;]*)?(?:\\1|$)/g, \"\")\r\n            .split(/\\s*(?:\\=[^;]*)?;\\s*/);\r\n        for (var _index = 0; _index < _keys.length; _index++) {\r\n            _keys[_index] = decodeURIComponent(_keys[_index]);\r\n        }\r\n        return _keys;\r\n    };\r\n    return VueCookiesManager;\r\n}());\r\nexport default {\r\n    install: function (app, options) {\r\n        app.config.globalProperties.$cookies = new VueCookiesManager();\r\n        if (options) {\r\n            app.config.globalProperties.$cookies.config(options);\r\n        }\r\n    },\r\n};\r\nvar GLOBAL_COOKIES_MANAGER = null;\r\nfunction globalCookiesConfig(options) {\r\n    if (GLOBAL_COOKIES_MANAGER == null) {\r\n        GLOBAL_COOKIES_MANAGER = new VueCookiesManager();\r\n    }\r\n    GLOBAL_COOKIES_MANAGER.config(options);\r\n}\r\nfunction useCookies() {\r\n    if (GLOBAL_COOKIES_MANAGER == null) {\r\n        GLOBAL_COOKIES_MANAGER = new VueCookiesManager();\r\n    }\r\n    var cookies = reactive(GLOBAL_COOKIES_MANAGER);\r\n    return { cookies: cookies };\r\n}\r\nexport { globalCookiesConfig, useCookies };\r\n","import { defineStore } from \"pinia\"\nimport { ref, Ref } from \"vue\"\n\nexport const useRecaptchaStore = defineStore('recaptcha', () => {\n    const isLoaded: Ref<Boolean> = ref(false)\n    const recaptchaSiteKey: Ref<string> = ref('')\n    function init(siteKey: string) {\n        if (isLoaded.value) {\n            return\n        }\n\n        recaptchaSiteKey.value = siteKey\n        var script = document.createElement('script');\n        script.src = `https://www.google.com/recaptcha/api.js?render=${encodeURIComponent(recaptchaSiteKey.value)}`\n        document.head.appendChild(script)\n        isLoaded.value = true;\n    }\n    async function isReady(): Promise<boolean> {\n        if (!isLoaded.value) {\n            return false\n        }\n        await (window as any).grecaptcha.ready(() => { })\n        return true\n    }\n\n    async function getRecaptchaToken(actionName: string = 'submit'): Promise<string> {\n        const ready = await isReady()\n        if (!ready) {\n            return ''\n        }\n\n        return (window as any).grecaptcha.execute(recaptchaSiteKey.value, { action: actionName })\n    }\n\n    return {\n        init,\n        getRecaptchaToken\n    }\n})","<template>\n  <div v-if=\"newsletterTranslation\" class=\"o-component o-component--newsletter\">\n    <div class=\"m-newsletter\">\n      <div class=\"o-container a-layout\">\n        <div class=\"u-col-span:6@md\">\n          <div class=\"m-newsletter__info\">\n            <h2 class=\"m-newsletter__title\">{{ newsletterTranslation.title }}</h2>\n            <div class=\"m-newsletter__info o-editor-content o-editor-content--newsletter\">\n              <p>{{ newsletterTranslation.description }}</p>\n            </div>\n          </div>\n        </div>\n        <div class=\"u-col-span:6@md\">\n          <div class=\"m-newsletter__form-alert\" role=\"alert\">\n            <span v-if=\"subscribedToNewsletter && errorMessage === ''\" class=\"m-newsletter__alert--good\">{{\n              translate('newsletter.message.success') }}</span>\n            <span v-if=\"!subscribedToNewsletter && errorMessage !== ''\" class=\"m-newsletter__alert--error\">{{ errorMessage\n            }}</span>\n          </div>\n          <form ref=\"form\" method=\"post\" :action=\"props.endpoint\" class=\"m-newsletter__form\" @submit=\"submitForm($event)\"\n            v-if=\"!subscribedToNewsletter\">\n            <label for=\"email\" class=\"u-screen-reader-only\">{{ newsletterTranslation.label }}</label>\n            <input class=\"m-newsletter__input\" @focus=\"loadRecaptcha($event)\" type=\"email\"\n              :placeholder=\"newsletterTranslation.placeholder\" id=\"email\" name=\"email\" autocomplete=\"email\"\n              required />\n            <button v-if=\"!loading\" class=\"m-newsletter__btn\" type=\"submit\" >\n              {{ newsletterTranslation.button_text }}\n            </button>\n          </form>\n          <div class=\"m-newsletter__disclaimer o-editor-content o-editor-content--disclaimer\"\n            v-if=\"!subscribedToNewsletter\">\n            <p> {{ newsletterTranslation.disclaimer }}</p>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n<script setup lang=\"ts\">\nimport { Ref, ref, onMounted } from 'vue'\nimport { translate } from '../helper-functions'\nimport { useCookies } from \"vue3-cookies\";\nimport { useRecaptchaStore } from '../stores/recaptcha';\n\ninterface NewsletterTranslation {\n  button_text: string\n  description: string\n  disclaimer: string\n  label: string\n  placeholder: string\n  title: string\n}\n\nconst props = defineProps({\n  endpoint: {\n    type: String,\n    required: true,\n  },\n  recaptchaSiteKey: {\n    type: String,\n    required: true,\n  },\n  newsletterText: {\n    default: null,\n  },\n  enabled: {\n    default: false,\n  }\n})\nconst newsletterTranslation: NewsletterTranslation = typeof props.newsletterText === 'string' ? JSON.parse(props.newsletterText) : JSON.parse(JSON.stringify(props.newsletterText));\nconst cookieApi = useCookies()\nconst errorMessage: Ref<string> = ref('');\nconst form: Ref<HTMLFormElement | null> = ref(null)\nconst newsletterCookieKey: string = 'newsletter-subscribed';\nlet loading: Ref<boolean> = ref(true)\nlet subscribedToNewsletter: Ref<boolean> = ref(false)\nconst recaptcha = useRecaptchaStore()\nfunction loadRecaptcha($event: Event) {\n  recaptcha.init(props.recaptchaSiteKey)\n}\n\nonMounted(() => {\n  // Set initial value if the expected cookie is set!\n  subscribedToNewsletter.value = cookieApi.cookies.get(newsletterCookieKey) === '1';\n  // Retister function to submit the form to javascript window global as 'sendNewsletterForm'\n  // so google recaptcha can use the registerered callback with that name.\n  (window as any).sendNewsletterForm = submitForm;\n  loading.value = false\n})\n\nasync function submitForm($event: Event) {\n  $event.preventDefault()\n\n  loading.value = true\n  errorMessage.value = ''\n  let recapthcaToken = await recaptcha.getRecaptchaToken('newsletterSubmit')\n  const serializedFormData = getSerializedFormData(form.value!)\n\n  await fetch(props.endpoint, {\n    method: form.value!.method,\n    body: serializedFormData,\n    headers: {\n      'Content-Type': 'application/x-www-form-urlencoded',\n      'g-recaptcha-token': recapthcaToken,\n    },\n  }).then(async (resp) => {\n    if (!resp.ok || resp.headers.get('captchaError') === '1') {\n      let data = await resp.json()\n      errorMessage.value = data.error ?? defaultErrorMessage()\n      loading.value = false\n      return\n    }\n\n    cookieApi.cookies.set(newsletterCookieKey, '1')\n    subscribedToNewsletter.value = true\n  }).catch(resp => {\n    errorMessage.value = resp.error ?? defaultErrorMessage()\n  }).finally(() => {\n    loading.value = false\n  })\n}\n\nfunction defaultErrorMessage(): string {\n  return translate('newsletter.message.error')\n}\n\nfunction getSerializedFormData(formElement: HTMLFormElement): string {\n  const formData = new FormData(formElement)\n  let formDataRecord: Record<string, string> = {}\n  formData.forEach((value: FormDataEntryValue, key: string) => {\n    formDataRecord[key] = value.toString()\n  })\n  return new URLSearchParams(formDataRecord).toString()\n}\n</script>\n","<template>\n  <section class=\"m-notification\" aria-label=\"Mededeling\" v-if=\"!loading && !isClosed\">\n    <div class=\"m-notification__inner o-container o-container--header\">\n      <div class=\"m-notification__message\">\n        <span class=\"m-notification__title\">{{ props.topNotification?.title }}</span>\n        <div class=\"o-editor-content o-editor-content--notification\">\n          <p class=\"m-notification__text\">\n            {{ props.topNotification?.text }}\n            <a class=\"m-notification__text\" :href=\"props.topNotification?.url ?? '#'\">{{ props.topNotification?.url_text\n              ?? '' }}</a>\n          </p>\n        </div>\n      </div>\n      <button class=\"m-notification__close a-btn a-btn--close\" type=\"button\" @click=\"closeNotification()\">\n        {{ translate('top_notification.button.close') }}\n        <svg class=\"a-icon a-icon--close\" aria-hidden=\"true\">\n          <use href=\"#close\" />\n        </svg>\n      </button>\n    </div>\n  </section>\n</template>\n\n<script setup lang=\"ts\">\nimport { PropType, Ref, h, onMounted, ref } from 'vue'\nimport { translate } from '../helper-functions'\nimport { RemovableRef, useLocalStorage } from '@vueuse/core'\nimport { createHash } from 'crypto';\nlet loading: Ref<boolean> = ref(true)\nlet isClosed: RemovableRef<boolean>\n\ninterface TopNotification {\n  title: string\n  text: string\n  url: string\n  url_text: string\n}\nconst props = defineProps({\n  topNotification: {\n    type: Object as PropType<TopNotification>,\n  },\n})\n\nonMounted(() => {\n  const hash = hashTopNotificationContent(props.topNotification!)\n  isClosed = useLocalStorage(`top-notification.${hash}.is-closed`, false)\n  loading.value = false\n})\n\nfunction closeNotification() {\n  if (typeof isClosed === 'undefined' || isClosed === null) {\n    return\n  }\n\n  isClosed.value = true\n}\n\nfunction hashTopNotificationContent(topNotificaton: TopNotification): number {\n  const content: string = 'title:' + (topNotificaton.title ?? '') + ' text:' + (topNotificaton.text ?? '') +\n    ' url_text:' + (topNotificaton.url_text ?? '') + ' url:' + (topNotificaton.url ?? '');\n    let hash = 0;\n    for (let i = 0, len = content.length; i < len; i++) {\n        let chr = content.charCodeAt(i);\n        hash = (hash << 5) - hash + chr;\n        hash |= 0; // Convert to 32bit integer\n    }\n\n    return hash;\n}\n</script>\n","import { set } from \"@vueuse/core\";\nimport { defineStore } from \"pinia\"\nimport { ref, Ref } from \"vue\"\n// Raw filter data from the backend.\nexport interface FilterRaw {\n    name: string;\n    internal_name: string;\n    options: Array<RawFilterOption>;\n    columns: number\n    type: 'Default' | 'Color';\n}\n\n// Raw filter option data from the backend.\nexport interface RawFilterOption {\n    id: string\n    name: string\n    attribute_values: Array<string>\n    data: any\n    active: boolean\n}\n\nexport const useCollectionFilters = defineStore('collection-filters', () => {\n    const loaded: Ref<Boolean> = ref(false)\n    const isMobileFiltersOpen: Ref<Boolean> = ref(false)\n    const allfilterOptions: Ref<Record<string, FilterRaw>> = ref({})\n    const isChanged: Ref<boolean> = ref(false)\n    const searchTerm: Ref<string> = ref('')\n    const collection: Ref<string> = ref('')\n    function init(filters: FilterRaw[]) {\n        if (loaded.value) {\n            return;\n        }\n\n        filters.forEach(filter => {\n            if (typeof allfilterOptions.value[filter.internal_name] === 'undefined') {\n                allfilterOptions.value[filter.internal_name] = filter\n            }\n        })\n        let currentUrl = new URL(window.location.href)\n\n        setSearchTerm(currentUrl.searchParams.get('term') ?? '')\n        setCollection(currentUrl.searchParams.get('collection') ?? '')\n\n        isChanged.value = false\n        loaded.value = true\n    }\n\n    function getActiveFilters(): Record<string, FilterRaw> {\n        let activeFilters: Record<string, FilterRaw> = {}\n        for (let [key, value] of Object.entries(allfilterOptions.value)) {\n            let activeOptions = value.options.filter(option => option.active)\n            if (activeOptions.length === 0) {\n                continue;\n            }\n\n            activeFilters[key] = {\n                name: value.name,\n                internal_name: value.internal_name,\n                options: activeOptions,\n                columns: value.columns,\n                type: value.type,\n            }\n        }\n\n        return activeFilters\n    }\n\n    function toggleMobileFilters() {\n        isMobileFiltersOpen.value = !isMobileFiltersOpen.value\n    }\n\n    function getUrlForFilters(): string | null {\n        if (!isChanged.value) {\n            return null\n        }\n\n        let currentUrl = new URL(window.location.href)\n        let routeParameters: Record<string, string[]> = {}\n        let currentKeys = Array.from(currentUrl.searchParams.keys())\n        for (let key of currentKeys) {\n            if (!key.startsWith('filter_') && key !== 'collection' && key !== 'term') {\n                continue\n            }\n\n            currentUrl.searchParams.delete(key)\n        }\n\n        if (currentKeys.includes('page_number')) {\n            currentUrl.searchParams.delete('page_number')\n        }\n\n        let activeFilters = getActiveFilters()\n        for (let [key, value] of Object.entries(activeFilters)) {\n            routeParameters[key] = value.options.map(k => k.id)\n        }\n\n        for (let [key, value] of Object.entries(routeParameters)) {\n            currentUrl.searchParams.set(key, value.join(','))\n        }\n\n        if (searchTerm.value.length > 0) {\n            currentUrl.searchParams.set('term', searchTerm.value)\n        }\n\n        if (collection.value.length > 0) {\n            currentUrl.searchParams.set('collection', collection.value)\n        }\n\n        return currentUrl.toString()\n    }\n\n    function getReplacedUrl(replacements: {[key: string]: any}): string {\n        let currentUrl = new URL(window.location.href)\n        for (let [key, value] of Object.entries(replacements)) {\n            if (value === null) {\n                currentUrl.searchParams.delete(key)\n                continue;\n            }\n\n            currentUrl.searchParams.set(key, value)\n        }\n\n        return currentUrl.toString()\n    }\n\n\n    function setCollection(collectionParam: string) {\n        collection.value = collectionParam\n    }\n\n    function setSearchTerm(term: string) {\n        searchTerm.value = term\n    }\n\n    function resetFilter() {\n        for (let filter of Object.values(allfilterOptions.value)) {\n            for (let option of filter.options) {\n                if (option.active === false) {\n                    continue;\n                }\n\n                option.active = false\n            }\n        }\n\n        setCollection('')\n        setSearchTerm('')\n\n        isChanged.value = true\n    }\n\n    function toggleFilterOption(internalName: string, id: string) {\n        let filter = allfilterOptions.value[internalName] ?? null;\n        if (filter === null) {\n            return;\n        }\n\n        let option = filter.options.find(option => option.id === id)\n        if (typeof option === 'undefined') {\n            return;\n        }\n\n        option.active = !option.active\n        isChanged.value = true\n    }\n\n    return {\n        init,\n        isMobileFiltersOpen,\n        toggleMobileFilters,\n        getActiveFilters,\n        allfilterOptions,\n        isChanged,\n        getUrlForFilters,\n        resetFilter,\n        toggleFilterOption,\n        setCollection,\n        setSearchTerm,\n        getReplacedUrl,\n    }\n})\n","<template>\n  <button class=\"a-btn a-btn--filter\" type=\"button\" @click=\"collectionFiltersStore.toggleMobileFilters()\">\n    <span class=\"a-btn__label\">Filters</span>\n    <span class=\"a-btn__amount\" v-if=\"props.amountOfActiveFilters\" v-text=\"props.amountOfActiveFilters\"></span>\n  </button>\n  <slot name=\"select\"></slot>\n</template>\n\n<script setup lang=\"ts\">\nimport { useCollectionFilters } from '../stores/collection';\n\nlet collectionFiltersStore = useCollectionFilters()\nconst props = defineProps({\n  amountOfActiveFilters: {\n    type: Number,\n    required: true\n  },\n})\n</script>\n","<template>\n  <fieldset>\n    <button class=\"m-product__filter-title\" @click=\"toggleFilters()\" type=\"button\">\n      {{ name }}\n      <svg class=\"a-icon a-icon--collapse\" :class=\"{ 'reverse': filtersOpen }\" aria-hidden=\"true\">\n        <use href=\"#chevron-down\" />\n      </svg>\n    </button>\n    <legend v-text=\"`Kies een ${name} om op te filteren`\"></legend>\n    <div class=\"m-product__filter-checkboxes\" :class=\"{ 'open': filtersOpen }\" :style=\"`--filter-columns: ${columns}`\">\n      <div class=\"a-checkbox\" :class=\"{ 'a-checkbox--color': colors }\"\n        :style=\"colors ? `--color: ${filterOption?.data}` : ''\" v-for=\"filterOption in props.options\"\n        :key=\"filterOption.id\">\n        <input class=\"a-checkbox__input\" type=\"checkbox\" :checked=\"filterOption.active\"\n          @change=\"toggleOption(filterOption.id)\" :id=\"`${id}_${filterOption.id}`\" :name=\"filterOption.name\" />\n        <label :for=\"`${id}_${filterOption.id}`\" class=\"a-checkbox__box\">\n          <svg class=\"a-icon\" aria-hidden=\"true\"\n            :class=\"{ 'light': colors && isLightColor(filterOption?.data, filterOption.name) }\">\n            <use href=\"#check\" />\n          </svg>\n        </label>\n        <label class=\"a-checkbox__text\" :for=\"`${id}_${filterOption.id}`\" v-text=\"filterOption.name\"></label>\n      </div>\n    </div>\n  </fieldset>\n</template>\n\n<script setup lang=\"ts\">\nimport { v4 as uuidv4 } from 'uuid'\nimport { Ref, ref } from 'vue'\nimport { RawFilterOption, useCollectionFilters } from '../../stores/collection'\n\nconst collectionFiltersStore = useCollectionFilters()\nconst props = defineProps({\n  name: {\n    type: String,\n    required: true,\n  },\n  internalName: {\n    type: String,\n    required: true,\n  },\n  options: Array<RawFilterOption>,\n  columns: Number,\n  colors: Boolean,\n  mobile: {\n    type: Boolean,\n    default: false,\n  },\n})\n\nconst id = ref('fieldset_' + uuidv4())\nconst filtersOpen: Ref<Boolean> = ref(true)\n\nfunction toggleFilters() {\n  filtersOpen.value = !filtersOpen.value\n}\n\nfunction toggleOption(id: string) {\n  collectionFiltersStore.toggleFilterOption(props.internalName, id);\n  if (props.mobile === true) {\n    // Dont apply filters instantly on mobile wait until they are applied.\n    return;\n  }\n\n  let url = collectionFiltersStore.getUrlForFilters()\n  if (url === null) {\n    return\n  }\n\n  window.location.href = url\n}\n\nfunction isLightColor(color: string, name: string = ''): boolean {\n  try {\n    if (!color.match(/^#([0-9a-f]{3}|[0-9a-f]{6})$/i)) {\n      return false;\n    }\n\n    if (color.match(/^#([0-9a-f]{3}$)/i)) {\n      color = expandHexColor(color)\n    }\n\n    let result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(color);\n    if (result === null) {\n      return false;\n    }\n    let r = parseInt(result[1], 16)\n    let g = parseInt(result[2], 16)\n    let b = parseInt(result[3], 16)\n\n    var luma = 0.2126 * r + 0.7152 * g + 0.0722 * b; // per ITU-R BT.709\n\n    // This returns true if the color is light enough to use a black checkmark.\n    return luma > 190\n  } catch (e: any) {\n    return false;\n  }\n}\n\nfunction expandHexColor(hexCode: string): string {\n  const hexValue = hexCode.substring(1);\n\n  // If 3-digits, duplicate each digit.\n  if (hexValue.length === 3) {\n    const expandedHexValue = [...hexValue].map(x => `${x}${x}`).join('')\n    return `#${expandedHexValue}`;\n  }\n\n  // Otherwise, we'll assume it's a 6-digit code and return the original.\n  return hexCode;\n}\n</script>\n","<template v-if=\"!loading\">\n  <form class=\"m-product__filters\">\n    <template v-for=\"filter in Object.values(collectionFilterStore.allfilterOptions)\">\n      <BaseFilterFieldset :name=\"filter.name\" :internal-name=\"filter.internal_name\" :options=\"filter.options\"\n        :columns=\"filter.columns\" :mobile=\"props.mobile\" :colors=\"filter.type === 'Color'\" />\n    </template>\n  </form>\n</template>\n<script setup lang=\"ts\">\nimport BaseFilterFieldset from './BaseFilterFieldset.vue'\nimport { useCollectionFilters, FilterRaw } from '../../stores/collection'\nimport { onMounted, Ref, ref } from 'vue';\n\nconst collectionFilterStore = useCollectionFilters()\n\nconst props = defineProps({\n  filters: {\n    type: Array<FilterRaw>,\n    required: true,\n  },\n  mobile: {\n    type: Boolean,\n    required: false,\n    default: false,\n  }\n})\n\nlet loading: Ref<boolean> = ref(true)\n\nonMounted(() => {\n  collectionFilterStore.init(props.filters)\n  loading.value = false\n})\n\n</script>\n","/*!\n* tabbable 5.3.3\n* @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE\n*/\nvar candidateSelectors = ['input', 'select', 'textarea', 'a[href]', 'button', '[tabindex]:not(slot)', 'audio[controls]', 'video[controls]', '[contenteditable]:not([contenteditable=\"false\"])', 'details>summary:first-of-type', 'details'];\nvar candidateSelector = /* #__PURE__ */candidateSelectors.join(',');\nvar NoElement = typeof Element === 'undefined';\nvar matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\nvar getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {\n  return element.getRootNode();\n} : function (element) {\n  return element.ownerDocument;\n};\n/**\n * @param {Element} el container to check in\n * @param {boolean} includeContainer add container to check\n * @param {(node: Element) => boolean} filter filter candidates\n * @returns {Element[]}\n */\n\nvar getCandidates = function getCandidates(el, includeContainer, filter) {\n  var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));\n\n  if (includeContainer && matches.call(el, candidateSelector)) {\n    candidates.unshift(el);\n  }\n\n  candidates = candidates.filter(filter);\n  return candidates;\n};\n/**\n * @callback GetShadowRoot\n * @param {Element} element to check for shadow root\n * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.\n */\n\n/**\n * @callback ShadowRootFilter\n * @param {Element} shadowHostNode the element which contains shadow content\n * @returns {boolean} true if a shadow root could potentially contain valid candidates.\n */\n\n/**\n * @typedef {Object} CandidatesScope\n * @property {Element} scope contains inner candidates\n * @property {Element[]} candidates\n */\n\n/**\n * @typedef {Object} IterativeOptions\n * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;\n *  if a function, implies shadow support is enabled and either returns the shadow root of an element\n *  or a boolean stating if it has an undisclosed shadow root\n * @property {(node: Element) => boolean} filter filter candidates\n * @property {boolean} flatten if true then result will flatten any CandidatesScope into the returned list\n * @property {ShadowRootFilter} shadowRootFilter filter shadow roots;\n */\n\n/**\n * @param {Element[]} elements list of element containers to match candidates from\n * @param {boolean} includeContainer add container list to check\n * @param {IterativeOptions} options\n * @returns {Array.<Element|CandidatesScope>}\n */\n\n\nvar getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {\n  var candidates = [];\n  var elementsToCheck = Array.from(elements);\n\n  while (elementsToCheck.length) {\n    var element = elementsToCheck.shift();\n\n    if (element.tagName === 'SLOT') {\n      // add shadow dom slot scope (slot itself cannot be focusable)\n      var assigned = element.assignedElements();\n      var content = assigned.length ? assigned : element.children;\n      var nestedCandidates = getCandidatesIteratively(content, true, options);\n\n      if (options.flatten) {\n        candidates.push.apply(candidates, nestedCandidates);\n      } else {\n        candidates.push({\n          scope: element,\n          candidates: nestedCandidates\n        });\n      }\n    } else {\n      // check candidate element\n      var validCandidate = matches.call(element, candidateSelector);\n\n      if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {\n        candidates.push(element);\n      } // iterate over shadow content if possible\n\n\n      var shadowRoot = element.shadowRoot || // check for an undisclosed shadow\n      typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);\n      var validShadowRoot = !options.shadowRootFilter || options.shadowRootFilter(element);\n\n      if (shadowRoot && validShadowRoot) {\n        // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed\n        //  shadow exists, so look at light dom children as fallback BUT create a scope for any\n        //  child candidates found because they're likely slotted elements (elements that are\n        //  children of the web component element (which has the shadow), in the light dom, but\n        //  slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,\n        //  _after_ we return from this recursive call\n        var _nestedCandidates = getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);\n\n        if (options.flatten) {\n          candidates.push.apply(candidates, _nestedCandidates);\n        } else {\n          candidates.push({\n            scope: element,\n            candidates: _nestedCandidates\n          });\n        }\n      } else {\n        // there's not shadow so just dig into the element's (light dom) children\n        //  __without__ giving the element special scope treatment\n        elementsToCheck.unshift.apply(elementsToCheck, element.children);\n      }\n    }\n  }\n\n  return candidates;\n};\n\nvar getTabindex = function getTabindex(node, isScope) {\n  if (node.tabIndex < 0) {\n    // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n    // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n    // yet they are still part of the regular tab order; in FF, they get a default\n    // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n    // order, consider their tab index to be 0.\n    // Also browsers do not return `tabIndex` correctly for contentEditable nodes;\n    // so if they don't have a tabindex attribute specifically set, assume it's 0.\n    //\n    // isScope is positive for custom element with shadow root or slot that by default\n    // have tabIndex -1, but need to be sorted by document order in order for their\n    // content to be inserted in the correct position\n    if ((isScope || /^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || node.isContentEditable) && isNaN(parseInt(node.getAttribute('tabindex'), 10))) {\n      return 0;\n    }\n  }\n\n  return node.tabIndex;\n};\n\nvar sortOrderedTabbables = function sortOrderedTabbables(a, b) {\n  return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n};\n\nvar isInput = function isInput(node) {\n  return node.tagName === 'INPUT';\n};\n\nvar isHiddenInput = function isHiddenInput(node) {\n  return isInput(node) && node.type === 'hidden';\n};\n\nvar isDetailsWithSummary = function isDetailsWithSummary(node) {\n  var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {\n    return child.tagName === 'SUMMARY';\n  });\n  return r;\n};\n\nvar getCheckedRadio = function getCheckedRadio(nodes, form) {\n  for (var i = 0; i < nodes.length; i++) {\n    if (nodes[i].checked && nodes[i].form === form) {\n      return nodes[i];\n    }\n  }\n};\n\nvar isTabbableRadio = function isTabbableRadio(node) {\n  if (!node.name) {\n    return true;\n  }\n\n  var radioScope = node.form || getRootNode(node);\n\n  var queryRadios = function queryRadios(name) {\n    return radioScope.querySelectorAll('input[type=\"radio\"][name=\"' + name + '\"]');\n  };\n\n  var radioSet;\n\n  if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {\n    radioSet = queryRadios(window.CSS.escape(node.name));\n  } else {\n    try {\n      radioSet = queryRadios(node.name);\n    } catch (err) {\n      // eslint-disable-next-line no-console\n      console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);\n      return false;\n    }\n  }\n\n  var checked = getCheckedRadio(radioSet, node.form);\n  return !checked || checked === node;\n};\n\nvar isRadio = function isRadio(node) {\n  return isInput(node) && node.type === 'radio';\n};\n\nvar isNonTabbableRadio = function isNonTabbableRadio(node) {\n  return isRadio(node) && !isTabbableRadio(node);\n};\n\nvar isZeroArea = function isZeroArea(node) {\n  var _node$getBoundingClie = node.getBoundingClientRect(),\n      width = _node$getBoundingClie.width,\n      height = _node$getBoundingClie.height;\n\n  return width === 0 && height === 0;\n};\n\nvar isHidden = function isHidden(node, _ref) {\n  var displayCheck = _ref.displayCheck,\n      getShadowRoot = _ref.getShadowRoot;\n\n  // NOTE: visibility will be `undefined` if node is detached from the document\n  //  (see notes about this further down), which means we will consider it visible\n  //  (this is legacy behavior from a very long way back)\n  // NOTE: we check this regardless of `displayCheck=\"none\"` because this is a\n  //  _visibility_ check, not a _display_ check\n  if (getComputedStyle(node).visibility === 'hidden') {\n    return true;\n  }\n\n  var isDirectSummary = matches.call(node, 'details>summary:first-of-type');\n  var nodeUnderDetails = isDirectSummary ? node.parentElement : node;\n\n  if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {\n    return true;\n  } // The root node is the shadow root if the node is in a shadow DOM; some document otherwise\n  //  (but NOT _the_ document; see second 'If' comment below for more).\n  // If rootNode is shadow root, it'll have a host, which is the element to which the shadow\n  //  is attached, and the one we need to check if it's in the document or not (because the\n  //  shadow, and all nodes it contains, is never considered in the document since shadows\n  //  behave like self-contained DOMs; but if the shadow's HOST, which is part of the document,\n  //  is hidden, or is not in the document itself but is detached, it will affect the shadow's\n  //  visibility, including all the nodes it contains). The host could be any normal node,\n  //  or a custom element (i.e. web component). Either way, that's the one that is considered\n  //  part of the document, not the shadow root, nor any of its children (i.e. the node being\n  //  tested).\n  // If rootNode is not a shadow root, it won't have a host, and so rootNode should be the\n  //  document (per the docs) and while it's a Document-type object, that document does not\n  //  appear to be the same as the node's `ownerDocument` for some reason, so it's safer\n  //  to ignore the rootNode at this point, and use `node.ownerDocument`. Otherwise,\n  //  using `rootNode.contains(node)` will _always_ be true we'll get false-positives when\n  //  node is actually detached.\n\n\n  var nodeRootHost = getRootNode(node).host;\n  var nodeIsAttached = (nodeRootHost === null || nodeRootHost === void 0 ? void 0 : nodeRootHost.ownerDocument.contains(nodeRootHost)) || node.ownerDocument.contains(node);\n\n  if (!displayCheck || displayCheck === 'full') {\n    if (typeof getShadowRoot === 'function') {\n      // figure out if we should consider the node to be in an undisclosed shadow and use the\n      //  'non-zero-area' fallback\n      var originalNode = node;\n\n      while (node) {\n        var parentElement = node.parentElement;\n        var rootNode = getRootNode(node);\n\n        if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow\n        ) {\n          // node has an undisclosed shadow which means we can only treat it as a black box, so we\n          //  fall back to a non-zero-area test\n          return isZeroArea(node);\n        } else if (node.assignedSlot) {\n          // iterate up slot\n          node = node.assignedSlot;\n        } else if (!parentElement && rootNode !== node.ownerDocument) {\n          // cross shadow boundary\n          node = rootNode.host;\n        } else {\n          // iterate up normal dom\n          node = parentElement;\n        }\n      }\n\n      node = originalNode;\n    } // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support\n    //  (i.e. it does not also presume that all nodes might have undisclosed shadows); or\n    //  it might be a falsy value, which means shadow DOM support is disabled\n    // Since we didn't find it sitting in an undisclosed shadow (or shadows are disabled)\n    //  now we can just test to see if it would normally be visible or not, provided it's\n    //  attached to the main document.\n    // NOTE: We must consider case where node is inside a shadow DOM and given directly to\n    //  `isTabbable()` or `isFocusable()` -- regardless of `getShadowRoot` option setting.\n\n\n    if (nodeIsAttached) {\n      // this works wherever the node is: if there's at least one client rect, it's\n      //  somehow displayed; it also covers the CSS 'display: contents' case where the\n      //  node itself is hidden in place of its contents; and there's no need to search\n      //  up the hierarchy either\n      return !node.getClientRects().length;\n    } // Else, the node isn't attached to the document, which means the `getClientRects()`\n    //  API will __always__ return zero rects (this can happen, for example, if React\n    //  is used to render nodes onto a detached tree, as confirmed in this thread:\n    //  https://github.com/facebook/react/issues/9117#issuecomment-284228870)\n    //\n    // It also means that even window.getComputedStyle(node).display will return `undefined`\n    //  because styles are only computed for nodes that are in the document.\n    //\n    // NOTE: THIS HAS BEEN THE CASE FOR YEARS. It is not new, nor is it caused by tabbable\n    //  somehow. Though it was never stated officially, anyone who has ever used tabbable\n    //  APIs on nodes in detached containers has actually implicitly used tabbable in what\n    //  was later (as of v5.2.0 on Apr 9, 2021) called `displayCheck=\"none\"` mode -- essentially\n    //  considering __everything__ to be visible because of the innability to determine styles.\n\n  } else if (displayCheck === 'non-zero-area') {\n    // NOTE: Even though this tests that the node's client rect is non-zero to determine\n    //  whether it's displayed, and that a detached node will __always__ have a zero-area\n    //  client rect, we don't special-case for whether the node is attached or not. In\n    //  this mode, we do want to consider nodes that have a zero area to be hidden at all\n    //  times, and that includes attached or not.\n    return isZeroArea(node);\n  } // visible, as far as we can tell, or per current `displayCheck` mode\n\n\n  return false;\n}; // form fields (nested) inside a disabled fieldset are not focusable/tabbable\n//  unless they are in the _first_ <legend> element of the top-most disabled\n//  fieldset\n\n\nvar isDisabledFromFieldset = function isDisabledFromFieldset(node) {\n  if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {\n    var parentNode = node.parentElement; // check if `node` is contained in a disabled <fieldset>\n\n    while (parentNode) {\n      if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {\n        // look for the first <legend> among the children of the disabled <fieldset>\n        for (var i = 0; i < parentNode.children.length; i++) {\n          var child = parentNode.children.item(i); // when the first <legend> (in document order) is found\n\n          if (child.tagName === 'LEGEND') {\n            // if its parent <fieldset> is not nested in another disabled <fieldset>,\n            // return whether `node` is a descendant of its first <legend>\n            return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);\n          }\n        } // the disabled <fieldset> containing `node` has no <legend>\n\n\n        return true;\n      }\n\n      parentNode = parentNode.parentElement;\n    }\n  } // else, node's tabbable/focusable state should not be affected by a fieldset's\n  //  enabled/disabled state\n\n\n  return false;\n};\n\nvar isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {\n  if (node.disabled || isHiddenInput(node) || isHidden(node, options) || // For a details element with a summary, the summary element gets the focus\n  isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {\n    return false;\n  }\n\n  return true;\n};\n\nvar isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {\n  if (isNonTabbableRadio(node) || getTabindex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {\n    return false;\n  }\n\n  return true;\n};\n\nvar isValidShadowRootTabbable = function isValidShadowRootTabbable(shadowHostNode) {\n  var tabIndex = parseInt(shadowHostNode.getAttribute('tabindex'), 10);\n\n  if (isNaN(tabIndex) || tabIndex >= 0) {\n    return true;\n  } // If a custom element has an explicit negative tabindex,\n  // browsers will not allow tab targeting said element's children.\n\n\n  return false;\n};\n/**\n * @param {Array.<Element|CandidatesScope>} candidates\n * @returns Element[]\n */\n\n\nvar sortByOrder = function sortByOrder(candidates) {\n  var regularTabbables = [];\n  var orderedTabbables = [];\n  candidates.forEach(function (item, i) {\n    var isScope = !!item.scope;\n    var element = isScope ? item.scope : item;\n    var candidateTabindex = getTabindex(element, isScope);\n    var elements = isScope ? sortByOrder(item.candidates) : element;\n\n    if (candidateTabindex === 0) {\n      isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);\n    } else {\n      orderedTabbables.push({\n        documentOrder: i,\n        tabIndex: candidateTabindex,\n        item: item,\n        isScope: isScope,\n        content: elements\n      });\n    }\n  });\n  return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {\n    sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);\n    return acc;\n  }, []).concat(regularTabbables);\n};\n\nvar tabbable = function tabbable(el, options) {\n  options = options || {};\n  var candidates;\n\n  if (options.getShadowRoot) {\n    candidates = getCandidatesIteratively([el], options.includeContainer, {\n      filter: isNodeMatchingSelectorTabbable.bind(null, options),\n      flatten: false,\n      getShadowRoot: options.getShadowRoot,\n      shadowRootFilter: isValidShadowRootTabbable\n    });\n  } else {\n    candidates = getCandidates(el, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));\n  }\n\n  return sortByOrder(candidates);\n};\n\nvar focusable = function focusable(el, options) {\n  options = options || {};\n  var candidates;\n\n  if (options.getShadowRoot) {\n    candidates = getCandidatesIteratively([el], options.includeContainer, {\n      filter: isNodeMatchingSelectorFocusable.bind(null, options),\n      flatten: true,\n      getShadowRoot: options.getShadowRoot\n    });\n  } else {\n    candidates = getCandidates(el, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));\n  }\n\n  return candidates;\n};\n\nvar isTabbable = function isTabbable(node, options) {\n  options = options || {};\n\n  if (!node) {\n    throw new Error('No node provided');\n  }\n\n  if (matches.call(node, candidateSelector) === false) {\n    return false;\n  }\n\n  return isNodeMatchingSelectorTabbable(options, node);\n};\n\nvar focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');\n\nvar isFocusable = function isFocusable(node, options) {\n  options = options || {};\n\n  if (!node) {\n    throw new Error('No node provided');\n  }\n\n  if (matches.call(node, focusableCandidateSelector) === false) {\n    return false;\n  }\n\n  return isNodeMatchingSelectorFocusable(options, node);\n};\n\nexport { focusable, isFocusable, isTabbable, tabbable };\n//# sourceMappingURL=index.esm.js.map\n","/*!\n* focus-trap 6.9.4\n* @license MIT, https://github.com/focus-trap/focus-trap/blob/master/LICENSE\n*/\nimport { tabbable, focusable, isTabbable, isFocusable } from 'tabbable';\n\nfunction ownKeys(object, enumerableOnly) {\n  var keys = Object.keys(object);\n\n  if (Object.getOwnPropertySymbols) {\n    var symbols = Object.getOwnPropertySymbols(object);\n    enumerableOnly && (symbols = symbols.filter(function (sym) {\n      return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n    })), keys.push.apply(keys, symbols);\n  }\n\n  return keys;\n}\n\nfunction _objectSpread2(target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = null != arguments[i] ? arguments[i] : {};\n    i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n      _defineProperty(target, key, source[key]);\n    }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n      Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n    });\n  }\n\n  return target;\n}\n\nfunction _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nvar activeFocusTraps = function () {\n  var trapQueue = [];\n  return {\n    activateTrap: function activateTrap(trap) {\n      if (trapQueue.length > 0) {\n        var activeTrap = trapQueue[trapQueue.length - 1];\n\n        if (activeTrap !== trap) {\n          activeTrap.pause();\n        }\n      }\n\n      var trapIndex = trapQueue.indexOf(trap);\n\n      if (trapIndex === -1) {\n        trapQueue.push(trap);\n      } else {\n        // move this existing trap to the front of the queue\n        trapQueue.splice(trapIndex, 1);\n        trapQueue.push(trap);\n      }\n    },\n    deactivateTrap: function deactivateTrap(trap) {\n      var trapIndex = trapQueue.indexOf(trap);\n\n      if (trapIndex !== -1) {\n        trapQueue.splice(trapIndex, 1);\n      }\n\n      if (trapQueue.length > 0) {\n        trapQueue[trapQueue.length - 1].unpause();\n      }\n    }\n  };\n}();\n\nvar isSelectableInput = function isSelectableInput(node) {\n  return node.tagName && node.tagName.toLowerCase() === 'input' && typeof node.select === 'function';\n};\n\nvar isEscapeEvent = function isEscapeEvent(e) {\n  return e.key === 'Escape' || e.key === 'Esc' || e.keyCode === 27;\n};\n\nvar isTabEvent = function isTabEvent(e) {\n  return e.key === 'Tab' || e.keyCode === 9;\n};\n\nvar delay = function delay(fn) {\n  return setTimeout(fn, 0);\n}; // Array.find/findIndex() are not supported on IE; this replicates enough\n//  of Array.findIndex() for our needs\n\n\nvar findIndex = function findIndex(arr, fn) {\n  var idx = -1;\n  arr.every(function (value, i) {\n    if (fn(value)) {\n      idx = i;\n      return false; // break\n    }\n\n    return true; // next\n  });\n  return idx;\n};\n/**\n * Get an option's value when it could be a plain value, or a handler that provides\n *  the value.\n * @param {*} value Option's value to check.\n * @param {...*} [params] Any parameters to pass to the handler, if `value` is a function.\n * @returns {*} The `value`, or the handler's returned value.\n */\n\n\nvar valueOrHandler = function valueOrHandler(value) {\n  for (var _len = arguments.length, params = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n    params[_key - 1] = arguments[_key];\n  }\n\n  return typeof value === 'function' ? value.apply(void 0, params) : value;\n};\n\nvar getActualTarget = function getActualTarget(event) {\n  // NOTE: If the trap is _inside_ a shadow DOM, event.target will always be the\n  //  shadow host. However, event.target.composedPath() will be an array of\n  //  nodes \"clicked\" from inner-most (the actual element inside the shadow) to\n  //  outer-most (the host HTML document). If we have access to composedPath(),\n  //  then use its first element; otherwise, fall back to event.target (and\n  //  this only works for an _open_ shadow DOM; otherwise,\n  //  composedPath()[0] === event.target always).\n  return event.target.shadowRoot && typeof event.composedPath === 'function' ? event.composedPath()[0] : event.target;\n};\n\nvar createFocusTrap = function createFocusTrap(elements, userOptions) {\n  // SSR: a live trap shouldn't be created in this type of environment so this\n  //  should be safe code to execute if the `document` option isn't specified\n  var doc = (userOptions === null || userOptions === void 0 ? void 0 : userOptions.document) || document;\n\n  var config = _objectSpread2({\n    returnFocusOnDeactivate: true,\n    escapeDeactivates: true,\n    delayInitialFocus: true\n  }, userOptions);\n\n  var state = {\n    // containers given to createFocusTrap()\n    // @type {Array<HTMLElement>}\n    containers: [],\n    // list of objects identifying tabbable nodes in `containers` in the trap\n    // NOTE: it's possible that a group has no tabbable nodes if nodes get removed while the trap\n    //  is active, but the trap should never get to a state where there isn't at least one group\n    //  with at least one tabbable node in it (that would lead to an error condition that would\n    //  result in an error being thrown)\n    // @type {Array<{\n    //   container: HTMLElement,\n    //   tabbableNodes: Array<HTMLElement>, // empty if none\n    //   focusableNodes: Array<HTMLElement>, // empty if none\n    //   firstTabbableNode: HTMLElement|null,\n    //   lastTabbableNode: HTMLElement|null,\n    //   nextTabbableNode: (node: HTMLElement, forward: boolean) => HTMLElement|undefined\n    // }>}\n    containerGroups: [],\n    // same order/length as `containers` list\n    // references to objects in `containerGroups`, but only those that actually have\n    //  tabbable nodes in them\n    // NOTE: same order as `containers` and `containerGroups`, but __not necessarily__\n    //  the same length\n    tabbableGroups: [],\n    nodeFocusedBeforeActivation: null,\n    mostRecentlyFocusedNode: null,\n    active: false,\n    paused: false,\n    // timer ID for when delayInitialFocus is true and initial focus in this trap\n    //  has been delayed during activation\n    delayInitialFocusTimer: undefined\n  };\n  var trap; // eslint-disable-line prefer-const -- some private functions reference it, and its methods reference private functions, so we must declare here and define later\n\n  /**\n   * Gets a configuration option value.\n   * @param {Object|undefined} configOverrideOptions If true, and option is defined in this set,\n   *  value will be taken from this object. Otherwise, value will be taken from base configuration.\n   * @param {string} optionName Name of the option whose value is sought.\n   * @param {string|undefined} [configOptionName] Name of option to use __instead of__ `optionName`\n   *  IIF `configOverrideOptions` is not defined. Otherwise, `optionName` is used.\n   */\n\n  var getOption = function getOption(configOverrideOptions, optionName, configOptionName) {\n    return configOverrideOptions && configOverrideOptions[optionName] !== undefined ? configOverrideOptions[optionName] : config[configOptionName || optionName];\n  };\n  /**\n   * Finds the index of the container that contains the element.\n   * @param {HTMLElement} element\n   * @returns {number} Index of the container in either `state.containers` or\n   *  `state.containerGroups` (the order/length of these lists are the same); -1\n   *  if the element isn't found.\n   */\n\n\n  var findContainerIndex = function findContainerIndex(element) {\n    // NOTE: search `containerGroups` because it's possible a group contains no tabbable\n    //  nodes, but still contains focusable nodes (e.g. if they all have `tabindex=-1`)\n    //  and we still need to find the element in there\n    return state.containerGroups.findIndex(function (_ref) {\n      var container = _ref.container,\n          tabbableNodes = _ref.tabbableNodes;\n      return container.contains(element) || // fall back to explicit tabbable search which will take into consideration any\n      //  web components if the `tabbableOptions.getShadowRoot` option was used for\n      //  the trap, enabling shadow DOM support in tabbable (`Node.contains()` doesn't\n      //  look inside web components even if open)\n      tabbableNodes.find(function (node) {\n        return node === element;\n      });\n    });\n  };\n  /**\n   * Gets the node for the given option, which is expected to be an option that\n   *  can be either a DOM node, a string that is a selector to get a node, `false`\n   *  (if a node is explicitly NOT given), or a function that returns any of these\n   *  values.\n   * @param {string} optionName\n   * @returns {undefined | false | HTMLElement | SVGElement} Returns\n   *  `undefined` if the option is not specified; `false` if the option\n   *  resolved to `false` (node explicitly not given); otherwise, the resolved\n   *  DOM node.\n   * @throws {Error} If the option is set, not `false`, and is not, or does not\n   *  resolve to a node.\n   */\n\n\n  var getNodeForOption = function getNodeForOption(optionName) {\n    var optionValue = config[optionName];\n\n    if (typeof optionValue === 'function') {\n      for (var _len2 = arguments.length, params = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n        params[_key2 - 1] = arguments[_key2];\n      }\n\n      optionValue = optionValue.apply(void 0, params);\n    }\n\n    if (optionValue === true) {\n      optionValue = undefined; // use default value\n    }\n\n    if (!optionValue) {\n      if (optionValue === undefined || optionValue === false) {\n        return optionValue;\n      } // else, empty string (invalid), null (invalid), 0 (invalid)\n\n\n      throw new Error(\"`\".concat(optionName, \"` was specified but was not a node, or did not return a node\"));\n    }\n\n    var node = optionValue; // could be HTMLElement, SVGElement, or non-empty string at this point\n\n    if (typeof optionValue === 'string') {\n      node = doc.querySelector(optionValue); // resolve to node, or null if fails\n\n      if (!node) {\n        throw new Error(\"`\".concat(optionName, \"` as selector refers to no known node\"));\n      }\n    }\n\n    return node;\n  };\n\n  var getInitialFocusNode = function getInitialFocusNode() {\n    var node = getNodeForOption('initialFocus'); // false explicitly indicates we want no initialFocus at all\n\n    if (node === false) {\n      return false;\n    }\n\n    if (node === undefined) {\n      // option not specified: use fallback options\n      if (findContainerIndex(doc.activeElement) >= 0) {\n        node = doc.activeElement;\n      } else {\n        var firstTabbableGroup = state.tabbableGroups[0];\n        var firstTabbableNode = firstTabbableGroup && firstTabbableGroup.firstTabbableNode; // NOTE: `fallbackFocus` option function cannot return `false` (not supported)\n\n        node = firstTabbableNode || getNodeForOption('fallbackFocus');\n      }\n    }\n\n    if (!node) {\n      throw new Error('Your focus-trap needs to have at least one focusable element');\n    }\n\n    return node;\n  };\n\n  var updateTabbableNodes = function updateTabbableNodes() {\n    state.containerGroups = state.containers.map(function (container) {\n      var tabbableNodes = tabbable(container, config.tabbableOptions); // NOTE: if we have tabbable nodes, we must have focusable nodes; focusable nodes\n      //  are a superset of tabbable nodes\n\n      var focusableNodes = focusable(container, config.tabbableOptions);\n      return {\n        container: container,\n        tabbableNodes: tabbableNodes,\n        focusableNodes: focusableNodes,\n        firstTabbableNode: tabbableNodes.length > 0 ? tabbableNodes[0] : null,\n        lastTabbableNode: tabbableNodes.length > 0 ? tabbableNodes[tabbableNodes.length - 1] : null,\n\n        /**\n         * Finds the __tabbable__ node that follows the given node in the specified direction,\n         *  in this container, if any.\n         * @param {HTMLElement} node\n         * @param {boolean} [forward] True if going in forward tab order; false if going\n         *  in reverse.\n         * @returns {HTMLElement|undefined} The next tabbable node, if any.\n         */\n        nextTabbableNode: function nextTabbableNode(node) {\n          var forward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n          // NOTE: If tabindex is positive (in order to manipulate the tab order separate\n          //  from the DOM order), this __will not work__ because the list of focusableNodes,\n          //  while it contains tabbable nodes, does not sort its nodes in any order other\n          //  than DOM order, because it can't: Where would you place focusable (but not\n          //  tabbable) nodes in that order? They have no order, because they aren't tabbale...\n          // Support for positive tabindex is already broken and hard to manage (possibly\n          //  not supportable, TBD), so this isn't going to make things worse than they\n          //  already are, and at least makes things better for the majority of cases where\n          //  tabindex is either 0/unset or negative.\n          // FYI, positive tabindex issue: https://github.com/focus-trap/focus-trap/issues/375\n          var nodeIdx = focusableNodes.findIndex(function (n) {\n            return n === node;\n          });\n\n          if (nodeIdx < 0) {\n            return undefined;\n          }\n\n          if (forward) {\n            return focusableNodes.slice(nodeIdx + 1).find(function (n) {\n              return isTabbable(n, config.tabbableOptions);\n            });\n          }\n\n          return focusableNodes.slice(0, nodeIdx).reverse().find(function (n) {\n            return isTabbable(n, config.tabbableOptions);\n          });\n        }\n      };\n    });\n    state.tabbableGroups = state.containerGroups.filter(function (group) {\n      return group.tabbableNodes.length > 0;\n    }); // throw if no groups have tabbable nodes and we don't have a fallback focus node either\n\n    if (state.tabbableGroups.length <= 0 && !getNodeForOption('fallbackFocus') // returning false not supported for this option\n    ) {\n      throw new Error('Your focus-trap must have at least one container with at least one tabbable node in it at all times');\n    }\n  };\n\n  var tryFocus = function tryFocus(node) {\n    if (node === false) {\n      return;\n    }\n\n    if (node === doc.activeElement) {\n      return;\n    }\n\n    if (!node || !node.focus) {\n      tryFocus(getInitialFocusNode());\n      return;\n    }\n\n    node.focus({\n      preventScroll: !!config.preventScroll\n    });\n    state.mostRecentlyFocusedNode = node;\n\n    if (isSelectableInput(node)) {\n      node.select();\n    }\n  };\n\n  var getReturnFocusNode = function getReturnFocusNode(previousActiveElement) {\n    var node = getNodeForOption('setReturnFocus', previousActiveElement);\n    return node ? node : node === false ? false : previousActiveElement;\n  }; // This needs to be done on mousedown and touchstart instead of click\n  // so that it precedes the focus event.\n\n\n  var checkPointerDown = function checkPointerDown(e) {\n    var target = getActualTarget(e);\n\n    if (findContainerIndex(target) >= 0) {\n      // allow the click since it ocurred inside the trap\n      return;\n    }\n\n    if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n      // immediately deactivate the trap\n      trap.deactivate({\n        // if, on deactivation, we should return focus to the node originally-focused\n        //  when the trap was activated (or the configured `setReturnFocus` node),\n        //  then assume it's also OK to return focus to the outside node that was\n        //  just clicked, causing deactivation, as long as that node is focusable;\n        //  if it isn't focusable, then return focus to the original node focused\n        //  on activation (or the configured `setReturnFocus` node)\n        // NOTE: by setting `returnFocus: false`, deactivate() will do nothing,\n        //  which will result in the outside click setting focus to the node\n        //  that was clicked, whether it's focusable or not; by setting\n        //  `returnFocus: true`, we'll attempt to re-focus the node originally-focused\n        //  on activation (or the configured `setReturnFocus` node)\n        returnFocus: config.returnFocusOnDeactivate && !isFocusable(target, config.tabbableOptions)\n      });\n      return;\n    } // This is needed for mobile devices.\n    // (If we'll only let `click` events through,\n    // then on mobile they will be blocked anyways if `touchstart` is blocked.)\n\n\n    if (valueOrHandler(config.allowOutsideClick, e)) {\n      // allow the click outside the trap to take place\n      return;\n    } // otherwise, prevent the click\n\n\n    e.preventDefault();\n  }; // In case focus escapes the trap for some strange reason, pull it back in.\n\n\n  var checkFocusIn = function checkFocusIn(e) {\n    var target = getActualTarget(e);\n    var targetContained = findContainerIndex(target) >= 0; // In Firefox when you Tab out of an iframe the Document is briefly focused.\n\n    if (targetContained || target instanceof Document) {\n      if (targetContained) {\n        state.mostRecentlyFocusedNode = target;\n      }\n    } else {\n      // escaped! pull it back in to where it just left\n      e.stopImmediatePropagation();\n      tryFocus(state.mostRecentlyFocusedNode || getInitialFocusNode());\n    }\n  }; // Hijack Tab events on the first and last focusable nodes of the trap,\n  // in order to prevent focus from escaping. If it escapes for even a\n  // moment it can end up scrolling the page and causing confusion so we\n  // kind of need to capture the action at the keydown phase.\n\n\n  var checkTab = function checkTab(e) {\n    var target = getActualTarget(e);\n    updateTabbableNodes();\n    var destinationNode = null;\n\n    if (state.tabbableGroups.length > 0) {\n      // make sure the target is actually contained in a group\n      // NOTE: the target may also be the container itself if it's focusable\n      //  with tabIndex='-1' and was given initial focus\n      var containerIndex = findContainerIndex(target);\n      var containerGroup = containerIndex >= 0 ? state.containerGroups[containerIndex] : undefined;\n\n      if (containerIndex < 0) {\n        // target not found in any group: quite possible focus has escaped the trap,\n        //  so bring it back in to...\n        if (e.shiftKey) {\n          // ...the last node in the last group\n          destinationNode = state.tabbableGroups[state.tabbableGroups.length - 1].lastTabbableNode;\n        } else {\n          // ...the first node in the first group\n          destinationNode = state.tabbableGroups[0].firstTabbableNode;\n        }\n      } else if (e.shiftKey) {\n        // REVERSE\n        // is the target the first tabbable node in a group?\n        var startOfGroupIndex = findIndex(state.tabbableGroups, function (_ref2) {\n          var firstTabbableNode = _ref2.firstTabbableNode;\n          return target === firstTabbableNode;\n        });\n\n        if (startOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target, false))) {\n          // an exception case where the target is either the container itself, or\n          //  a non-tabbable node that was given focus (i.e. tabindex is negative\n          //  and user clicked on it or node was programmatically given focus)\n          //  and is not followed by any other tabbable node, in which\n          //  case, we should handle shift+tab as if focus were on the container's\n          //  first tabbable node, and go to the last tabbable node of the LAST group\n          startOfGroupIndex = containerIndex;\n        }\n\n        if (startOfGroupIndex >= 0) {\n          // YES: then shift+tab should go to the last tabbable node in the\n          //  previous group (and wrap around to the last tabbable node of\n          //  the LAST group if it's the first tabbable node of the FIRST group)\n          var destinationGroupIndex = startOfGroupIndex === 0 ? state.tabbableGroups.length - 1 : startOfGroupIndex - 1;\n          var destinationGroup = state.tabbableGroups[destinationGroupIndex];\n          destinationNode = destinationGroup.lastTabbableNode;\n        }\n      } else {\n        // FORWARD\n        // is the target the last tabbable node in a group?\n        var lastOfGroupIndex = findIndex(state.tabbableGroups, function (_ref3) {\n          var lastTabbableNode = _ref3.lastTabbableNode;\n          return target === lastTabbableNode;\n        });\n\n        if (lastOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target))) {\n          // an exception case where the target is the container itself, or\n          //  a non-tabbable node that was given focus (i.e. tabindex is negative\n          //  and user clicked on it or node was programmatically given focus)\n          //  and is not followed by any other tabbable node, in which\n          //  case, we should handle tab as if focus were on the container's\n          //  last tabbable node, and go to the first tabbable node of the FIRST group\n          lastOfGroupIndex = containerIndex;\n        }\n\n        if (lastOfGroupIndex >= 0) {\n          // YES: then tab should go to the first tabbable node in the next\n          //  group (and wrap around to the first tabbable node of the FIRST\n          //  group if it's the last tabbable node of the LAST group)\n          var _destinationGroupIndex = lastOfGroupIndex === state.tabbableGroups.length - 1 ? 0 : lastOfGroupIndex + 1;\n\n          var _destinationGroup = state.tabbableGroups[_destinationGroupIndex];\n          destinationNode = _destinationGroup.firstTabbableNode;\n        }\n      }\n    } else {\n      // NOTE: the fallbackFocus option does not support returning false to opt-out\n      destinationNode = getNodeForOption('fallbackFocus');\n    }\n\n    if (destinationNode) {\n      e.preventDefault();\n      tryFocus(destinationNode);\n    } // else, let the browser take care of [shift+]tab and move the focus\n\n  };\n\n  var checkKey = function checkKey(e) {\n    if (isEscapeEvent(e) && valueOrHandler(config.escapeDeactivates, e) !== false) {\n      e.preventDefault();\n      trap.deactivate();\n      return;\n    }\n\n    if (isTabEvent(e)) {\n      checkTab(e);\n      return;\n    }\n  };\n\n  var checkClick = function checkClick(e) {\n    var target = getActualTarget(e);\n\n    if (findContainerIndex(target) >= 0) {\n      return;\n    }\n\n    if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n      return;\n    }\n\n    if (valueOrHandler(config.allowOutsideClick, e)) {\n      return;\n    }\n\n    e.preventDefault();\n    e.stopImmediatePropagation();\n  }; //\n  // EVENT LISTENERS\n  //\n\n\n  var addListeners = function addListeners() {\n    if (!state.active) {\n      return;\n    } // There can be only one listening focus trap at a time\n\n\n    activeFocusTraps.activateTrap(trap); // Delay ensures that the focused element doesn't capture the event\n    // that caused the focus trap activation.\n\n    state.delayInitialFocusTimer = config.delayInitialFocus ? delay(function () {\n      tryFocus(getInitialFocusNode());\n    }) : tryFocus(getInitialFocusNode());\n    doc.addEventListener('focusin', checkFocusIn, true);\n    doc.addEventListener('mousedown', checkPointerDown, {\n      capture: true,\n      passive: false\n    });\n    doc.addEventListener('touchstart', checkPointerDown, {\n      capture: true,\n      passive: false\n    });\n    doc.addEventListener('click', checkClick, {\n      capture: true,\n      passive: false\n    });\n    doc.addEventListener('keydown', checkKey, {\n      capture: true,\n      passive: false\n    });\n    return trap;\n  };\n\n  var removeListeners = function removeListeners() {\n    if (!state.active) {\n      return;\n    }\n\n    doc.removeEventListener('focusin', checkFocusIn, true);\n    doc.removeEventListener('mousedown', checkPointerDown, true);\n    doc.removeEventListener('touchstart', checkPointerDown, true);\n    doc.removeEventListener('click', checkClick, true);\n    doc.removeEventListener('keydown', checkKey, true);\n    return trap;\n  }; //\n  // TRAP DEFINITION\n  //\n\n\n  trap = {\n    get active() {\n      return state.active;\n    },\n\n    get paused() {\n      return state.paused;\n    },\n\n    activate: function activate(activateOptions) {\n      if (state.active) {\n        return this;\n      }\n\n      var onActivate = getOption(activateOptions, 'onActivate');\n      var onPostActivate = getOption(activateOptions, 'onPostActivate');\n      var checkCanFocusTrap = getOption(activateOptions, 'checkCanFocusTrap');\n\n      if (!checkCanFocusTrap) {\n        updateTabbableNodes();\n      }\n\n      state.active = true;\n      state.paused = false;\n      state.nodeFocusedBeforeActivation = doc.activeElement;\n\n      if (onActivate) {\n        onActivate();\n      }\n\n      var finishActivation = function finishActivation() {\n        if (checkCanFocusTrap) {\n          updateTabbableNodes();\n        }\n\n        addListeners();\n\n        if (onPostActivate) {\n          onPostActivate();\n        }\n      };\n\n      if (checkCanFocusTrap) {\n        checkCanFocusTrap(state.containers.concat()).then(finishActivation, finishActivation);\n        return this;\n      }\n\n      finishActivation();\n      return this;\n    },\n    deactivate: function deactivate(deactivateOptions) {\n      if (!state.active) {\n        return this;\n      }\n\n      var options = _objectSpread2({\n        onDeactivate: config.onDeactivate,\n        onPostDeactivate: config.onPostDeactivate,\n        checkCanReturnFocus: config.checkCanReturnFocus\n      }, deactivateOptions);\n\n      clearTimeout(state.delayInitialFocusTimer); // noop if undefined\n\n      state.delayInitialFocusTimer = undefined;\n      removeListeners();\n      state.active = false;\n      state.paused = false;\n      activeFocusTraps.deactivateTrap(trap);\n      var onDeactivate = getOption(options, 'onDeactivate');\n      var onPostDeactivate = getOption(options, 'onPostDeactivate');\n      var checkCanReturnFocus = getOption(options, 'checkCanReturnFocus');\n      var returnFocus = getOption(options, 'returnFocus', 'returnFocusOnDeactivate');\n\n      if (onDeactivate) {\n        onDeactivate();\n      }\n\n      var finishDeactivation = function finishDeactivation() {\n        delay(function () {\n          if (returnFocus) {\n            tryFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation));\n          }\n\n          if (onPostDeactivate) {\n            onPostDeactivate();\n          }\n        });\n      };\n\n      if (returnFocus && checkCanReturnFocus) {\n        checkCanReturnFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation)).then(finishDeactivation, finishDeactivation);\n        return this;\n      }\n\n      finishDeactivation();\n      return this;\n    },\n    pause: function pause() {\n      if (state.paused || !state.active) {\n        return this;\n      }\n\n      state.paused = true;\n      removeListeners();\n      return this;\n    },\n    unpause: function unpause() {\n      if (!state.paused || !state.active) {\n        return this;\n      }\n\n      state.paused = false;\n      updateTabbableNodes();\n      addListeners();\n      return this;\n    },\n    updateContainerElements: function updateContainerElements(containerElements) {\n      var elementsAsArray = [].concat(containerElements).filter(Boolean);\n      state.containers = elementsAsArray.map(function (element) {\n        return typeof element === 'string' ? doc.querySelector(element) : element;\n      });\n\n      if (state.active) {\n        updateTabbableNodes();\n      }\n\n      return this;\n    }\n  }; // initialize container elements\n\n  trap.updateContainerElements(elements);\n  return trap;\n};\n\nexport { createFocusTrap };\n//# sourceMappingURL=focus-trap.esm.js.map\n","<template>\n  <div class=\"o-filter-popup\" ref=\"popup\">\n    <div class=\"o-filter-popup__head\">\n      <h2 class=\"a-h3 m-filter__head-title\">{{ translate('collection.filter.title') }}</h2>\n      <button class=\"m-filter__head-close\" @click=\"close\" type=\"button\">\n        <svg class=\"a-icon\" aria-hidden=\"true\">\n          <use href=\"#close\" />\n        </svg>\n      </button>\n    </div>\n    <div class=\"o-filter-popup__actives\" v-if=\"$slots.activeFilters\">\n      <div class=\"m-filter__active\">\n        <span class=\"m-product__filter-title\">\n          {{ translate('collection.filter.chosen_filters') }}\n          <a class=\"o-filter-popup__reset\" @click.prevent=\"collectionFilterStore.resetFilter(); close()\">\n            {{ translate('collection.filter.button_reset_filters') }}\n          </a>\n        </span>\n        <ul class=\"m-filter__list\" aria-label=\"Active filters\">\n          <slot name=\"activeFilters\"></slot>\n        </ul>\n      </div>\n    </div>\n    <div class=\"o-filter-popup__filters\">\n      <slot name=\"filters\"></slot>\n    </div>\n\n    <div class=\"o-filter-popup__buttons\">\n      <button class=\"a-btn a-btn--filter\" type=\"button\" @click=\"applyFilters()\" v-if=\"collectionFilterStore.isChanged\">\n        <span class=\"a-btn__label\"> {{ translate('collection.filter.button_apply') }}\n        </span>\n      </button>\n      <button class=\"a-btn a-btn--filter\" type=\"button\" @click=\"close\" v-if=\"!collectionFilterStore.isChanged\">\n        <span class=\"a-btn__label\">{{ translate('collection.filter.button_close') }}</span>\n      </button>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { createFocusTrap } from 'focus-trap'\nimport { ComponentPublicInstance, nextTick, onMounted, ref } from 'vue'\nimport { useCollectionFilters } from '../../stores/collection'\nimport { translate } from '../../helper-functions'\n\nconst collectionFilterStore = useCollectionFilters()\nconst focusTrap = ref<any>(null)\nconst popup = ref<ComponentPublicInstance<HTMLDivElement>>()\n\nonMounted(() => {\n  nextTick(() => {\n    focusTrap.value = createFocusTrap([popup.value as HTMLDivElement]).activate()\n    window.addEventListener('keydown', (e: KeyboardEvent) => keyDownHandler(e), true)\n  })\n})\n\nfunction close() {\n  focusTrap.value.deactivate()\n  collectionFilterStore.toggleMobileFilters()\n}\n\nfunction applyFilters() {\n  let url = collectionFilterStore.getUrlForFilters()\n  if (url === null) {\n    close();\n    return\n  }\n\n  window.location.href = url\n}\n\nfunction keyDownHandler(e: KeyboardEvent) {\n  e.key === 'Esc' || e.key === 'Escape' ? close() : null\n}\n</script>\n","<template >\n  <li v-if=\"props.filterOption.active\">\n    <a class=\"a-filter\" @click.prevent=\"collectionFiltersStore.toggleFilterOption(props.internalName, filterOption.id)\">\n      <div class=\"a-filter__label\" v-text=\"`${props.filterName}: ${props.filterOption.name}`\"></div>\n      <svg class=\"a-icon a-icon--filter\" aria-hidden=\"true\">\n        <use href=\"#close\" />\n      </svg>\n    </a>\n  </li>\n</template>\n\n<script setup lang=\"ts\">\nimport { RawFilterOption, useCollectionFilters } from '../../stores/collection'\nconst collectionFiltersStore = useCollectionFilters()\n\nconst props = defineProps({\n  filterName: {\n    type: String,\n    required: true,\n  },\n  internalName: {\n    type: String,\n    required: true,\n  },\n  filterOption: {\n    type: Object as () => RawFilterOption,\n    required: true,\n  },\n})\n\n</script>\n","<template v-if=\"!loading\">\n  <transition>\n    <template v-if=\"collectionFilterStore.isMobileFiltersOpen\">\n      <BaseFilterPopup @close=\"collectionFilterStore.toggleMobileFilters()\">\n        <template #activeFilters>\n          <template v-for=\"filter in Object.values(collectionFilterStore.getActiveFilters())\">\n            <ActiveFilter :filter-name=\"filter.name\" :internal-name=\"filter.internal_name\" :filter-option=\"option\"\n              v-for=\"option in filter.options\" />\n          </template>\n        </template>\n        <template #filters>\n          <BaseFilters :filters=\"props.filters\" :mobile=\"true\" />\n        </template>\n      </BaseFilterPopup>\n    </template>\n  </transition>\n</template>\n<script setup lang=\"ts\">\nimport BaseFilterPopup from './BaseFilterPopup.vue';\nimport { FilterRaw, useCollectionFilters } from '../../stores/collection';\nimport { onMounted, Ref, ref } from 'vue';\nimport BaseFilters from './BaseFilters.vue';\nimport ActiveFilter from './ActiveFilter.vue';\n\nlet collectionFilterStore = useCollectionFilters()\n\nconst props = defineProps({\n  filters: {\n    type: Array<FilterRaw>,\n    required: true,\n  },\n})\nlet loading: Ref<boolean> = ref(true)\n\nonMounted(() => {\n  collectionFilterStore.init(props.filters)\n  loading.value = false\n})\n\n</script>\n","<template>\n  <li\n    class=\"m-product-list__item\"\n    :class=\"{ 'active': props.collection.active_tree, 'empty': props.collection.empty }\"\n  >\n    <a\n      :href=\"url\" class=\"m-product-list__item-link\"\n      :class=\"{ 'active': props.collection.active, 'empty': props.collection.empty }\"\n      :aria-current=\"props.collection.active ? 'true' : 'false'\"\n    >\n      <span>{{ props.collection.name }}</span>\n    </a>\n\n    <ul\n      class=\"m-product-list__sub\"\n      v-if=\"props.collection.items.length > 0 && collapsed\"\n    >\n      <recursive-collection-list\n        :search-enabled=\"searchEnabled\"\n        v-for=\"item in props.collection.items\"\n        :key=\"item.url\"\n        :collection=\"item\"\n      >\n      </recursive-collection-list>\n    </ul>\n  </li>\n</template>\n<script setup lang=\"ts\">\nimport { Ref, onMounted, ref } from 'vue';\nimport { useCollectionFilters } from '../../stores/collection';\n\ninterface Collection {\n  ID: string,\n  name: string,\n  active_tree: Boolean,\n  active: Boolean,\n  empty: Boolean,\n  url: string,\n  items: Collection[],\n}\n\nlet collapsed: Ref<Boolean> = ref(false);\nlet url: Ref<string> = ref('');\n\nonMounted(() => {\n  collapsed.value = props.collection.active_tree;\n  url.value = getUrl();\n})\n\nconst collectionFilterStore = useCollectionFilters()\n\nconst props = defineProps({\n  collection: {\n    type: Object as () => Collection,\n    required: true,\n  },\n  searchEnabled: {\n    type: Boolean,\n    required: true,\n  }\n})\n\nfunction getUrl() {\n  if (props.searchEnabled) {\n    if (props.collection.active) {\n      return collectionFilterStore.getReplacedUrl({ collection: null })\n    }\n    return collectionFilterStore.getReplacedUrl({ collection: props.collection.ID })\n  }\n\n  return !props.collection.empty ? props.collection.url : ''\n}\n</script>\n","<template v-if=\"!loading\">\n  <base-select :options=\"selectData\" v-model=\"selectedSort\" @update:model-value=\"updateSort\" />\n</template>\n\n<script setup lang=\"ts\">\nimport { onMounted, Ref, ref } from 'vue';\nimport { translate } from '../helper-functions';\n\n\nconst props = defineProps({\n  hasManualOption: {\n    type: Boolean,\n    required: true,\n  },\n  initial: {\n    type: String,\n  }\n})\n\nconst manualSort = {\n  id: 'manual',\n  label: translate('collection.sorting.manual'),\n}\nconst priceLowHighSort = {\n  id: 'price-low',\n  label: translate('collection.sorting.price_low'),\n}\nconst priceHighLowSort = {\n  id: 'price-high',\n  label: translate('collection.sorting.price_high'),\n}\nconst newestFirstSort = {\n  id: 'newest-first',\n  label: translate('collection.sorting.newest'),\n}\nconst oldestFirstSort = {\n  id: 'oldest-first',\n  label: translate('collection.sorting.oldest'),\n}\ninterface option {\n  id: string;\n  label: string;\n}\nlet selectData: Ref<option[]> = ref([])\nlet selectedSort: Ref<option> = ref(newestFirstSort)\nlet loading: Ref<boolean> = ref(true)\n\nonMounted(() => {\n  if (props.hasManualOption) {\n    selectData.value.push(manualSort)\n  }\n\n  selectData.value.push(\n    newestFirstSort,\n    oldestFirstSort,\n    priceLowHighSort,\n    priceHighLowSort\n  )\n\n  selectedSort.value = sortIdToOption(props.initial ?? '')\n\n  loading.value = false\n});\n\nfunction sortIdToOption(initial: string): option {\n  switch (initial) {\n    case manualSort.id:\n      if(!props.hasManualOption) {\n        return newestFirstSort\n      }\n\n      return manualSort\n    case oldestFirstSort.id:\n      return oldestFirstSort\n    case priceLowHighSort.id:\n      return priceLowHighSort\n    case priceHighLowSort.id:\n      return priceHighLowSort\n    default:\n      return newestFirstSort\n  }\n}\n\nfunction updateSort(v: { id: any } | null) {\n  if (v === null) {\n    return\n  }\n\n  const cur = new URL(window.location.href)\n  cur.searchParams.set('sort', v.id as string)\n  window.location.href = cur.href\n}\n\n</script>\n","<template>\n  <nav class=\"o-product-overview__pagination m-pagination\" v-if=\"totalPages > 1\">\n    <ul class=\"m-pagination__list\">\n      <li>\n        <a v-if=\"activePage > 1\" :href=\"prevURL()\" rel=\"prev\" class=\"m-pagination__button m-pagination__button--arrow\" aria-current=\"false\" aria-label=\"Previous page\" aria-disabled=\"false\">\n          <svg class=\"a-icon a-icon--pagination\" aria-hidden=\"true\">\n            <use href=\"#chevron-left\" />\n          </svg>\n        </a>\n      </li>\n\n      <li><a :href=\"pageURL(1)\" class=\"m-pagination__button u-visible--flex@md\" :aria-current=\"activePage === 1 ? 'true' : 'false'\" :class=\"{ 'current': activePage === 1 }\" aria-disabled=\"false\">1</a></li>\n      <li><a v-if=\"activePage < 3\" :href=\"pageURL(1)\" class=\"m-pagination__button u-hidden--flex@md\" :class=\"{ 'current': activePage === 1 }\" aria-current=\"false\" aria-disabled=\"false\">1</a></li>\n\n      <!-- Begin dots of the pagination -->\n      <li><span v-if=\"activePage > 3\" class=\"m-pagination__button m-pagination__button--dots u-visible--flex@md\" aria-current=\"false\" aria-disabled=\"false\">...</span></li>\n\n      <template v-for=\"page in getPaginationOptions(activePage)\" :key=\"page\">\n        <li v-if=\"(page > 1 && page < totalPages)\">\n          <a :href=\"pageURL(page)\" class=\"m-pagination__button\" :class=\"{ 'current': page === activePage }\" :aria-current=\"page === activePage ? 'true' : 'false'\" aria-disabled=\"false\">{{ page }}</a>\n        </li>\n      </template>\n\n      <!-- End dots of the pagination -->\n      <li><span v-if=\"activePage < totalPages - 2\" class=\"m-pagination__button m-pagination__button--dots u-visible--flex@md\" aria-current=\"false\" aria-disabled=\"false\">...</span></li>\n\n      <li><a :href=\"pageURL(totalPages)\" class=\"m-pagination__button u-visible--flex@md\" :class=\"{ 'current': activePage === totalPages }\" :aria-current=\"activePage === totalPages ? 'true' : 'false'\" aria-disabled=\"false\">{{ totalPages }}</a></li>\n      <li><a v-if=\"activePage > totalPages - 2\" :href=\"pageURL(totalPages)\" class=\"m-pagination__button u-hidden--flex@md\" :class=\"{ 'current': activePage === totalPages }\" aria-current=\"false\" aria-disabled=\"false\">{{ totalPages }}</a></li>\n\n      <li>\n        <a v-if=\"activePage < totalPages\" :href=\"nextURL()\" rel=\"next\" class=\"m-pagination__button m-pagination__button--arrow\" aria-current=\"false\" aria-label=\"Next page\" aria-disabled=\"false\">\n          <svg class=\"a-icon a-icon--pagination\" aria-hidden=\"true\">\n            <use href=\"#chevron-right\" />\n          </svg>\n        </a>\n      </li>\n    </ul>\n  </nav>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref } from 'vue'\n\nconst props = defineProps({\n  currentPage: {\n    type: Number,\n    required: true,\n  },\n  totalPages: {\n    type: Number,\n    required: true,\n  },\n})\n\nconst activePage = ref(props.currentPage + 1)\n\nconst getPaginationOptions = (page: number) => {\n  const total = props.totalPages\n  switch (page) {\n    case 1:\n      return [2, 3]\n    case 2:\n      return [2, 3]\n    case 3:\n      return [2, 3, 4]\n    case total - 3:\n      return [page - 1, page, page + 1]\n    case total - 2:\n      return [page - 1, page, page + 1]\n    case total - 1:\n      return [page - 1, page]\n    case total:\n      return [page - 2, page - 1]\n    default:\n      return [page - 1, page, page + 1]\n      break\n  }\n}\n\nfunction pageURL(page: number): string {\n  const cur = new URL(window.location.href)\n  cur.searchParams.set('page_number', (page - 1).toString(10))\n  return cur.href\n}\n\nfunction prevURL(): string {\n  const cur = new URL(window.location.href)\n  cur.searchParams.set('page_number', (props.currentPage - 1).toString(10))\n  return cur.href\n}\n\nfunction nextURL(): string {\n  const cur = new URL(window.location.href)\n  cur.searchParams.set('page_number', (props.currentPage + 1).toString(10))\n  return cur.href\n}\n</script>\n","import { defineStore } from \"pinia\";\nimport { computed, ref, Ref } from \"vue\";\n\nexport const useSearchStore = defineStore('search', () => {\n    let searchQuery: Ref<string> = ref('')\n    let searchPanelOpened: Ref<boolean> = ref(false);\n    let isInitiated: Ref<boolean> = ref(false);\n\n    function init() {\n        if (isInitiated.value) {\n            return\n        }\n\n        try {\n            // Get search query from URL the parameter is term.\n            const urlParams = new URLSearchParams(window.location.search);\n            const term = urlParams.get('term');\n            if (term) {\n                searchQuery.value = term\n            }\n        } catch (e) {\n            console.error('Failed to get search query from URL', e)\n        }\n\n        isInitiated.value = true\n    }\n    function toggleSearchPanel() {\n        searchPanelOpened.value = !searchPanelOpened.value\n    }\n\n    return {\n        // State\n        searchPanelOpened: computed(()=> searchPanelOpened.value),\n        searchQuery,\n\n        // Actions\n        init,\n        toggleSearchPanel,\n    }\n})\n","<template >\n  <button type=\"button\" class=\"a-btn a-btn--icon\" :title=\"translate('global.search.label')\" @click=\"searchStore.toggleSearchPanel()\">\n    <svg class=\"a-icon a-icon--search\" aria-hidden=\"true\">\n      <use href=\"#search\" />\n    </svg>\n  </button>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSearchStore } from '../stores/search';\nimport { translate } from '../helper-functions';\n\nconst searchStore = useSearchStore();\n\n</script>\n","<template>\n  <button v-if=\"!cartStore.loadingCart\" type=\"button\" class=\"a-btn a-btn--icon\" @click=\"cartStore.openCart()\"\n    title=\"Shopping cart\">\n    <span class=\"a-cart\">\n      <svg class=\"a-icon a-icon--cart\" aria-hidden=\"true\">\n        <use href=\"#bag\" />\n      </svg>\n      <span class=\"a-cart__count\" :class=\"{ 'animate-ping': cartStore.productCount > 0 }\"></span>\n      <span class=\"a-cart__count\">{{ cartStore.productCount }}</span>\n    </span>\n    <span class=\"a-cart__price u-visible@md\" v-text=\"`${displayPrice(cartStore.cart.total)} `\"></span>\n  </button>\n  <button v-else class=\"a-btn a-btn--icon\" type=\"button\">\n    <svg class=\"animate-spin a-icon a-icon--cart\" aria-hidden=\"true\">\n      <use href=\"#arrow-path\" />\n    </svg>\n  </button>\n</template>\n\n<script setup lang=\"ts\">\nimport { onMounted } from 'vue';\nimport { displayPrice } from '../helper/currency';\nimport { useCartStore } from '../stores/cart';\n\nconst cartStore = useCartStore()\nonMounted(async () => {\n  await cartStore.init()\n})\n</script>\n","<template>\n  <div class=\"o-container\" v-if=\"props.usps && props.usps.length > 0\">\n    <div ref=\"slider\" class=\"m-header__usps--mobile u-hidden@lg\">\n      <div class=\"m-header__usps-wrapper swiper-wrapper\">\n        <div v-for=\"usp of props.usps\" class=\"m-header__usp m-header__usp--mobile swiper-slide\">\n          <svg class=\"a-icon a-icon--usp\">\n            <use xlink:href=\"#check\"></use>\n          </svg>\n          <span class=\"m-header__usps-text\">{{ usp }}</span>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport Swiper, { Autoplay } from 'swiper'\nimport 'swiper/css'\nimport { ComponentPublicInstance, nextTick, onMounted, ref } from 'vue'\n\nconst swiper = ref<Swiper>()\nconst slider = ref<ComponentPublicInstance<HTMLDivElement>>()\n\nconst props = defineProps({\n  usps: {\n    type: Array<string>,\n    default: [],\n  },\n})\n\nonMounted(() => {\n  nextTick(() => {\n    swiper.value = new Swiper(slider.value as HTMLDivElement, {\n      modules: [Autoplay],\n      loop: true,\n      grabCursor: true,\n      autoplay: {\n        delay: 3000,\n      },\n    })\n  })\n})\n</script>\n","import { defineStore } from \"pinia\";\nimport { ref, Ref } from \"vue\";\n\nexport interface MenuItem {\n    name: string;\n    url: string;\n    active: boolean;\n    items: Array<MenuItem>;\n    tags: Array<string>;\n}\n\nexport const useMenuStore = defineStore('menu', () => {\n    let mobileMenuOpened: Ref<boolean> = ref(false);\n\n    function toggleMobileMenu() {\n        mobileMenuOpened.value = !mobileMenuOpened.value\n    }\n\n    function isMenuItemActive(url: string): boolean {\n        let currentUrl = new URL(window.location.href)\n        currentUrl.search = ''\n        let path = ''\n        for (let pathPart of currentUrl.pathname.split('/').filter(part => part !== '')){\n            path += '/' + pathPart\n            if (path === url) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    return {\n        // State\n        mobileMenuOpened,\n\n        // Actions\n        toggleMobileMenu,\n        isMenuItemActive,\n    }\n})","<template>\n  <div class=\"m-dropdown\" @mouseleave=\"close\" ref=\"root\">\n    <component :is=\"props.url ? 'a' : 'button'\" :href=\"props.url ? props.url : null\" class=\"m-header-nav__link\" :class=\"{ 'is-active': isOpen }\" @mouseenter=\"open\" @touchStart=\"open\" @keydown.enter.prevent=\"toggle\" @keydown.esc.prevent=\"close\"\n      :aria-expanded=\"isOpen ? 'true' : 'false'\">\n      <span class=\"m-dropdown__label\" v-text=\"props.title\"></span>\n    </component>\n\n    <transition>\n      <div v-show=\"showDropdown && isOpen\" ref=\"content\" class=\"m-dropdown__content\" tabindex=\"-1\" >\n        <a v-if=\"props.url\" class=\"u-skip-link\" :href=\"url\">Navigeer naar {{ props.title }}</a>\n        <slot></slot>\n      </div>\n    </transition>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { nextTick, onMounted, onUnmounted, ref } from 'vue'\n\n\nconst props = defineProps({\n  showDropdown: {\n    type: Boolean,\n    default: false,\n  },\n  title: {\n    type: String,\n    required: true,\n  },\n  url: {\n    type: String,\n    default: null,\n  },\n})\n\nconst isOpen = ref(false)\nconst touchEvent = ref(\"touchstart\")\nconst content = ref<any>()\nconst root = ref<HTMLElement | null>(null)\n\nonMounted(() => {\n  document.addEventListener(\"touchstart\", handleEventOutside)\n  document.addEventListener(\"focusin\", handleEventOutside)\n})\n\nonUnmounted(() => {\n  document.removeEventListener(\"touchstart\", handleEventOutside)\n  document.removeEventListener(\"focusin\", handleEventOutside)\n})\n\nconst open = () => {\n  isOpen.value = true\n  window.addEventListener(\"keydown\", keyDownHandler, true)\n  touchEvent.value = ''\n\n  nextTick(() => {\n    content?.value?.focus()\n  })\n}\n\n\nconst close = () => {\n  window.removeEventListener(\"keydown\", keyDownHandler, true)\n  isOpen.value = false\n  touchEvent.value = \"touchstart\"\n}\n\nconst toggle = () => {\n  isOpen.value ? close() : open()\n}\n\nconst handleEventOutside = (e: any) => {\n  if (!root.value!.contains(e.target)) {\n    close()\n  }\n}\n\nconst keyDownHandler = (e: any) => {\n  e.key === 'Esc' || e.key === 'Escape' ? close() : null\n}\n</script>\n","<template>\n  <nav class=\"m-header-nav__center\">\n    <ul class=\"m-header-nav__list\" aria-label=\"Main menu\">\n      <li v-for=\"item of props.menuItems\" class=\"m-header-nav__item\"\n        :class=\"{ 'm-header-nav__item--sale': (item?.tags ?? []).includes('sale'), 'm-header-nav__item--new': (item?.tags ?? []).includes('new'), 'active': menuStore.isMenuItemActive(item.url) }\"\n        aria-expanded=\"false\">\n        <BaseNavDropdown v-if=\"item.items && item.items.length > 0\" :title=\"item.name\" :url=\"item.url\" :show-dropdown=\"item.items.length > 0\">\n          <ul class=\"m-dropdown__list\" tabindex=\"1\" :aria-label=\"item.name\" v-if=\"hasGroup(item)\">\n            <li v-for=\"group of item.items\" class=\"m-dropdown__item\">\n              <a :href=\"group.url\" class=\"m-dropdown__item-title\" v-if=\"(group.items ?? []).length > 0\">{{ group.name }}</a>\n              <ul v-if=\"(group.items ?? []).length > 0\"\n                v-for=\"batch of chunk(group.items ?? [], (group.items ?? []).length > 16 ? (group.items ?? []).length / 4 : (group.items ?? []).length / 2)\"\n                class=\"m-dropdown__grid-list\" :aria-label=\"group.name\">\n                <li class=\"m-dropdown__grid-row\">\n                  <ul class=\"m-dropdown__grid-items\" :aria-label=\"group.name\">\n                    <li v-for=\"groupItem of batch\" class=\"m-dropdown__grid-item\">\n                      <a :href=\"groupItem.url\" class=\"m-dropdown__grid-link\">{{ groupItem.name }}</a>\n                    </li>\n                  </ul>\n                </li>\n              </ul>\n            </li>\n          </ul>\n\n          <ul class=\"m-dropdown__list\" tabindex=\"1\" :aria-label=\"item.name\" v-if=\"!hasGroup(item)\">\n            <li class=\"m-dropdown__item\">\n              <ul v-if=\"(item.items ?? []).length > 0\"\n                v-for=\"batch of chunk(item.items ?? [], (item.items ?? []).length > 16 ? (item.items ?? []).length / 4 : (item.items ?? []).length / 2)\"\n                class=\"m-dropdown__grid-list\">\n                <li class=\"m-dropdown__grid-row\">\n                  <ul class=\"m-dropdown__grid-items\">\n                    <li v-for=\"batchItem of batch\" class=\"m-dropdown__grid-item\">\n                      <a :href=\"batchItem.url\" class=\"m-dropdown__grid-link\">{{ batchItem.name }}</a>\n                    </li>\n                  </ul>\n                </li>\n              </ul>\n            </li>\n          </ul>\n        </BaseNavDropdown>\n        <a v-if=\"item.items === null || item.items.length == 0\" :href=\"item.url\" class=\"m-header-nav__link\" :class=\"{'active': menuStore.isMenuItemActive(item.url)}\">{{ item.name }}</a>\n      </li>\n    </ul>\n  </nav>\n</template>\n<script setup lang=\"ts\">\nimport { MenuItem, useMenuStore } from '../stores/menu'\nimport BaseNavDropdown from './BaseNavDropdown.vue'\n\nconst menuStore = useMenuStore();\nconst props = defineProps({\n  menuItems: {\n    type: Array<MenuItem>,\n    default: [],\n  },\n})\n\n// Returns if the item has grandchildren. If so we render the group name names.\nfunction hasGroup(item: MenuItem): boolean {\n  return item.items?.some((group) => group.items?.length > 0) ?? false\n}\n\nfunction chunk<T>(arr: Array<T>, chunkSize: number): Array<T[]> {\n  var chunkedArray: Array<T[]> = []\n  arr = arr ?? []\n  if (arr.length === 0){\n    return chunkedArray\n  }\n  for (var i = 0; i < arr.length; i += chunkSize) {\n    chunkedArray.push(arr.slice(i, i + chunkSize))\n  }\n\n  return chunkedArray\n}\n</script>\n","<template>\n  <div class=\"m-drilldown\">\n    <button class=\"m-drilldown__btn\" type=\"button\" @click=\"open\">\n      <span v-text=\"label\"></span>\n      <svg class=\"m-drilldown__arrow\" aria-hidden=\"true\">\n        <use xlink:href=\"#chevron-right\" />\n      </svg>\n    </button>\n  </div>\n  <transition>\n    <div class=\"m-drilldown__content\" ref=\"content\" v-if=\"active\">\n      <button class=\"m-drilldown__btn m-drilldown__btn--heading\" type=\"button\" @click=\"close\">\n        <svg class=\"m-drilldown__arrow m-drilldown__arrow--left\" aria-hidden=\"true\">\n          <use xlink:href=\"#chevron-left\" />\n        </svg>\n        <span v-text=\"props.label\"></span>\n      </button>\n      <slot></slot>\n    </div>\n  </transition>\n</template>\n\n<script setup lang=\"ts\">\nimport { createFocusTrap } from \"focus-trap\"\nimport {nextTick, onBeforeUnmount, ref} from \"vue\"\n\nconst props = defineProps({ label: String })\nconst active = ref(false)\nconst focusTrap = ref<any>()\nconst content = ref<HTMLDivElement>()\nconst toggle = ref<HTMLDivElement>()\n\nconst open = () => {\n  active.value = true\n\n  nextTick(() => {\n    const elements: Array<HTMLElement> = [content.value as HTMLDivElement, toggle.value as HTMLDivElement]\n\n    const menuCloseBtn = document.getElementById('mobile-menu-close-btn')\n    if (menuCloseBtn) {\n      elements.push(menuCloseBtn)\n    }\n\n    focusTrap.value = createFocusTrap(elements).activate()\n    window.addEventListener('keydown', (e: KeyboardEvent) => keyDownHandler(e), true)\n  })\n}\n\nonBeforeUnmount(() => {\n  if (focusTrap.value) {\n    focusTrap.value.deactivate()\n  }\n})\n\nconst close = () => {\n  active.value = false\n  focusTrap.value.deactivate()\n}\n\nconst keyDownHandler = (e: KeyboardEvent) => {\n  e.key === 'Esc' || e.key === 'Escape' ? close() : null\n}\n</script>\n","<template >\n  <transition>\n    <div class=\"m-mobile-menu__wrapper\" v-if=\"menuStore.mobileMenuOpened\">\n      <div class=\"m-mobile-menu\" ref=\"mobileMenu\">\n        <button type=\"button\" id=\"mobile-menu-close-btn\" class=\"m-mobile-menu__close a-btn a-btn--icon\" aria-label=\"Sluiten\"\n          @click=\"menuStore.toggleMobileMenu()\">\n          <svg class=\"a-icon a-icon--close\" aria-hidden=\"true\">\n            <use href=\"#close\" />\n          </svg>\n        </button>\n\n        <div class=\"m-mobile-menu__head\">\n          <h2 class=\"m-mobile-menu__head-title a-h5\">{{ translate('menu.mobile.title') }}</h2>\n        </div>\n\n        <ul class=\"m-mobile-menu__list\" aria-label=\"Menu\">\n          <li v-for=\"item of props.mainMenuItems\" class=\"m-mobile-menu__list-item\"\n            :class=\"{ 'm-mobile-menu__list-item--sale': (item?.tags ?? []).includes('sale'), 'm-mobile-menu__list-item--new': (item?.tags ?? []).includes('new') }\">\n            <BaseDrilldown v-if=\"item.items && item.items.length > 0\" :label=\"item.name\">\n              <ul class=\"m-mobile-menu__list\" aria-label=\"Collections\">\n                <li class=\"m-mobile-menu__list-item\" v-if=\"!(item?.tags ?? []).includes('brands')\">\n                  <a :href=\"item.url\" class=\"m-mobile-menu__list-link\">{{\n                    translate('collection.products.show_all_products', {\n                      collection: item.name\n                    }) }}</a>\n                </li>\n                <template v-if=\"hasGroup(item)\">\n                  <template v-for=\"child of item.items\">\n                    <li v-for=\"grandChild of leafNodes(child)\" class=\"m-mobile-menu__list-item\">\n                      <a :href=\"grandChild.url\" class=\"m-mobile-menu__list-link\">{{ grandChild.name }}</a>\n                    </li>\n                    <li class=\"m-mobile-menu__seperator\"></li>\n                  </template>\n                </template>\n                <template v-else>\n                  <li v-for=\"child of leafNodes(item)\" class=\"m-mobile-menu__list-item\">\n                    <a :href=\"child.url\" class=\"m-mobile-menu__list-link\">{{ child.name }}</a>\n                  </li>\n                </template>\n              </ul>\n\n            </BaseDrilldown>\n            <a v-else :href=\"item.url\" class=\"m-mobile-menu__list-link\">{{ item.name }}</a>\n          </li>\n\n          <li class=\"m-mobile-menu__seperator\"></li>\n\n          <li class=\"m-mobile-menu__list-item\" v-if=\"props.topMenuItems && props.topMenuItems.length > 0\"\n            v-for=\"item of props.topMenuItems\">\n            <BaseDrilldown v-if=\"item.items && item.items.length > 0\" :label=\"item.name\">\n              <ul class=\"m-mobile-menu__list\" aria-label=\"Menu items\">\n                <li class=\"m-mobile-menu__list-item\">\n                  <a :href=\"item.url\" class=\"m-mobile-menu__list-link m-mobile-menu__list-link--current\">\n                    {{ translate('menu.mobile.visit', { title: item.name }) }}\n                  </a>\n                </li>\n                <li v-for=\"child of item.items\" class=\"m-mobile-menu__list-item\">\n                  <a :href=\"child.url\" class=\"m-mobile-menu__list-link\">\n                    {{ child.name }}\n                  </a>\n                </li>\n              </ul>\n            </BaseDrilldown>\n            <a v-else :href=\"item.url\" class=\"m-mobile-menu__list-link\">{{ item.name }}</a>\n          </li>\n        </ul>\n        <div v-if=\"alternateURLs.length > 0\" class=\"m-header-language-select\">\n          <base-language-switch :items=\"alternatedURLsAsMap\"></base-language-switch>\n        </div>\n      </div>\n      <div class=\"a-overlay\"></div>\n    </div>\n  </transition>\n</template>\n\n<script setup lang=\"ts\">\nimport { MenuItem, useMenuStore } from '../stores/menu';\nimport { translate } from '../helper-functions';\nimport BaseDrilldown from './BaseDrilldown.vue';\nimport { computed, onMounted, Ref, ref } from 'vue';\n\nconst menuStore = useMenuStore()\n\nconst props = defineProps({\n  mainMenuItems: {\n    type: Array<MenuItem>,\n    default: [],\n  },\n  topMenuItems: {\n    type: Array<MenuItem>,\n    default: [],\n  },\n})\n\ninterface AlternateURL {\n  locale: string;\n  url: string;\n}\n\nconst alternateURLs: Ref<Array<AlternateURL>> = ref([])\nconst alternatedURLsAsMap: Ref<Record<string, string>> = computed(() => {\n  const map: Record<string, string> = {}\n  alternateURLs.value.forEach((alternate) => {\n    map[alternate.locale] = alternate.url\n  })\n\n  return map\n})\n\nonMounted(() => {\n  alternateURLs.value = getAlternateURLs()\n})\n\n// Returns if the item has grandchildren. If so we render the group name names.\nfunction hasGroup(item: MenuItem): boolean {\n  return item.items?.some((group) => group.items?.length > 0) ?? false\n}\n\n// Items returns the menu items that should be displayed for a submenu.\n// It only displays the leaf nodes. This means that the following menu:\n// categorie\n//    jassen\n//    broeken\n// merken\n//    adidas\n//    nike\n//\n// Will only display jassen, broeken, adidas and nike.\nfunction leafNodes(item: MenuItem): Array<MenuItem> {\n  if (item.items && item.items.length > 0) {\n    return item.items.flatMap(leafNodes)\n  }\n\n  return [item]\n}\n\nfunction getAlternateURLs(): Array<AlternateURL> {\n  const links = document.getElementsByTagName('link')\n\n  const alternates = []\n  for (let i = 0; i < links.length; i++) {\n    if (links[i].rel === 'alternate') {\n      const locale = links[i].hreflang\n      const url = links[i].href\n      alternates.push({ locale, url })\n    }\n  }\n\n  return alternates\n}\n</script>\n","<template>\n  <button type=\"button\" class=\"m-header__hamburger u-hidden@lg\" aria-label=\"Open menu\" @click=\"menuStore.toggleMobileMenu()\">\n    <span></span>\n    <span></span>\n    <span></span>\n  </button>\n</template>\n\n<script setup lang=\"ts\">\nimport { useMenuStore } from '../stores/menu';\n\nconst menuStore = useMenuStore();\n\n</script>\n","<template>\n  <transition>\n    <div class=\"o-cart-popover\" v-if=\"cartStore.isPopoverOpened\" ref=\"popover\">\n      <div class=\"m-cart-popover__head\">\n        <h2 class=\"m-cart-popover__head-title a-h4\">\n          {{ t('cart.general.title') }}\n        </h2>\n        <button class=\"a-btn\" type=\"button\" :title=\"translate('cart.button.close')\" @click=\"closePopup\">\n          <svg class=\"a-icon a-icon--close\" aria-hidden=\"true\">\n            <use href=\"#close\" />\n          </svg>\n        </button>\n      </div>\n      <div v-if=\"cartStore.cart.products.length > 0\" class=\"o-cart-popover__inner\">\n        <transition-group name=\"cart-list\" tag=\"ul\" class=\"m-cart-popover__products\"\n          :aria-label=\"t('cart.general.title')\">\n          <li class=\"m-cart-popover__product\" v-for=\"product in cartStore.cart.products\" :key=\"product.ID\">\n            <div class=\"m-cart-popover__product-top\">\n              <div class=\"m-cart-popover__product-img\">\n                <!-- @TODO Fix images with correct sources padding-ratio alt and stuff -->\n                <picture class=\"a-image a-image--contain\" style=\"--padding-ratio: calc(1/1)\">\n                  <img class=\"a-image__img\" :src=\"product.image_url + '?width=60&height=60'\" :alt=\"product.name\" />\n                </picture>\n              </div>\n              <div class=\"m-cart-popover__product-info\">\n                <a href=\"#\" class=\"m-cart-popover__product-title\">\n                  {{ product.name }}\n                </a>\n                <span class=\"m-cart-popover__product-attribute\">\n                  <strong>\n                    {{ product.quantity + 'x' }}\n                  </strong>\n                </span>\n                <span class=\"m-cart-popover__product-attribute\"\n                  v-for=\"[name, attributeValue] of Object.entries(product.attributes)\">\n                  {{ attributeValue.name }}: {{ attributeValue.value }}\n                </span>\n              </div>\n              <div class=\"m-cart-popover__product-price\">\n                <span class=\"m-cart-popover__price--original\" v-if=\"product.price < product.original_price\">\n                  {{ displayPrice(product.original_price)}}\n                </span>\n                <span :class=\"{'m-cart-popover__price--discount': product.price < product.original_price}\">\n                  {{ displayPrice(product.price) }}\n                </span>\n              </div>\n            </div>\n            <div class=\"m-cart-popover__product-actions\">\n              <a :href=\"generateRoute('cart')\" class=\"m-cart-popover__product-action m-cart-popover__product-action-edit\"\n                :title=\"t('cart.button.edit')\" :aria-label=\"t('cart.button.edit')\">\n                <svg class=\"a-icon a-icon--cart-filter\" aria-hidden=\"true\">\n                  <use href=\"#edit\" />\n                </svg>\n              </a>\n            </div>\n          </li>\n        </transition-group>\n        <div class=\"m-cart-popover__prices\">\n          <div class=\"m-cart-popover__price\" v-if=\"cartStore.cart.checkout_method\">\n            <span class=\"m-cart-popover__price--label\">{{ cartStore.cart.checkout_method!.name }}</span>\n            <span class=\"m-cart-popover__price--shipping\"\n              :class=\"{ 'm-cart-popover__price--free': (cartStore.cart.checkout_method?.price ?? 0) === 0 }\">\n              {{ displayPrice(cartStore.cart.checkout_method!.price ?? 0) }}\n            </span>\n          </div>\n          <div class=\"m-cart-popover__price\" v-if=\"cartStore.cart.coupon\">\n            <span class=\"m-cart-popover__price--label\">\n              {{ t('cart.general.coupon_price.label', { code: cartStore.cart.coupon!.code }) }}</span>\n            <span class=\"m-cart-popover__price--coupon m-cart-popover__price--discount\">\n              {{ displayPrice((cartStore.cart.coupon!.discount ?? 0) * -1) }}\n            </span>\n          </div>\n          <div class=\"m-cart-popover__price\">\n            <span class=\"m-cart-popover__price--label\">\n              {{ t('cart.general.price_total') }}\n            </span>\n            <span class=\"m-cart-popover__price--total\">\n              {{ currencyDisplayPrice(cartStore.cart.total) }}\n            </span>\n          </div>\n        </div>\n        <div class=\"m-cart-popover__action\">\n          <a :href=\"generateRoute('cart')\" class=\"a-btn a-btn--add\">\n            {{ t('cart.button.checkout') }}\n          </a>\n        </div>\n      </div>\n      <div v-else-if=\"!cartStore.loadingCart\" class=\"a-notification a-notification--info\">\n        {{ translate('cart.empty.text') }}\n      </div>\n      <div v-else class=\"m-cart-popover__product m-cart-popover__product--skeleton\">\n        <div class=\"m-cart-popover__product-top\">\n          <div class=\"m-cart-popover__product-img\"></div>\n          <div class=\"m-cart-popover__product-info\">\n            <span class=\"m-cart-popover__product-title\"></span>\n            <span class=\"m-cart-popover__product-attribute\"></span>\n            <span class=\"m-cart-popover__product-attribute\"></span>\n          </div>\n          <div class=\"m-cart-popover__product-price\"></div>\n        </div>\n        <div class=\"m-cart-popover__product-actions\"></div>\n      </div>\n    </div>\n  </transition>\n  <transition>\n    <button v-if=\"cartStore.isPopoverOpened\" class=\"a-overlay\" aria-hidden=\"true\" type=\"button\" ref=\"overlay\"\n      @click=\"closePopup\" />\n  </transition>\n</template>\n\n<script setup lang=\"ts\">\n\nimport { createFocusTrap } from 'focus-trap'\nimport { storeToRefs } from 'pinia'\nimport { ComponentPublicInstance, nextTick, onMounted, ref, TransitionGroup, watch } from 'vue'\nimport { useCartStore } from '../stores/cart'\nimport { displayPrice as currencyDisplayPrice } from '../helper/currency'\nimport { generateRoute, translate } from '../helper-functions'\nimport { useI18n } from 'vue-i18n'\n\nconst focusTrap = ref<any>(null)\nconst popover = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst overlay = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst cartStore = useCartStore()\nconst { isPopoverOpened } = storeToRefs(cartStore)\nconst { t } = useI18n()\nconst closePopup = () => {\n  cartStore.closeCart()\n  focusTrap.value.deactivate()\n}\n\nconst keyDownHandler = (e: KeyboardEvent) => {\n  e.key === 'Esc' || e.key === 'Escape' ? closePopup() : null\n}\n\nonMounted(async () => {\n  await cartStore.init()\n  // Start with a closed popover on loading of this component.\n  cartStore.closeCart()\n})\n\nwatch(isPopoverOpened, (changedIsOpen) => {\n  if (changedIsOpen) {\n    nextTick(() => {\n      focusTrap.value = createFocusTrap([popover.value as HTMLDivElement, overlay.value as HTMLDivElement]).activate()\n      window.addEventListener('keydown', (e: KeyboardEvent) => keyDownHandler(e), true)\n    })\n  }\n})\n\nfunction displayPrice(price: number): string {\n  return currencyDisplayPrice(price ?? 0, translate('global.price.free'))\n}\n</script>\n","<template>\n  <transition>\n    <div class=\"m-search-bar\" role=\"dialog\" :aria-labelledby=\"translate('global.search.label')\"\n      :aria-describedby=\"translate('global.search.label')\" v-if=\"searchStore.searchPanelOpened\">\n      <div class=\"o-container\">\n        <form class=\"m-search-bar__form\" :action=\"searchURL\" method=\"get\">\n          <input name=\"term\" id=\"main_searchbar\" type=\"text\" class=\"m-search-bar__input\"\n            :placeholder=\"translate('global.search.placeholder')\" ref=\"searchInput\"\n            data-searchbar-input=\"\" v-model=\"searchStore.searchQuery\">\n          <button\n            type=\"submit\"\n            class=\"m-search-bar__search a-btn a-btn--searchbar\"\n            :title=\"translate('global.search.label')\"\n          >\n            <svg class=\"a-icon a-icon--search--search\">\n              <use xlink:href=\"#search\"></use>\n            </svg>\n          </button>\n          <button\n            type=\"button\"\n            class=\"m-search-bar__close a-btn a-btn--searchbar\"\n            data-searchbar=\"searchbar\"\n            @click=\"searchStore.toggleSearchPanel();\"\n            title=\"Close\"\n          >\n            <svg class=\"a-icon a-icon--close\">\n              <use xlink:href=\"#close\"></use>\n            </svg>\n          </button>\n        </form>\n      </div>\n    </div>\n  </transition>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSearchStore } from '../stores/search'\nimport { generateRoute, translate } from '../helper-functions'\nimport { Ref, nextTick, ref, watch, onMounted, computed } from 'vue'\n\nconst searchStore = useSearchStore()\nconst searchInput: Ref<HTMLElement | null> = ref(null)\nconst searchURL = computed(() => {\n  if (typeof (window as any).searchRoute !== \"undefined\") {\n    return (window as any).searchRoute\n  }\n\n  return generateRoute('search')\n})\n\nonMounted(() => {\n  searchStore.init()\n})\n\n\nwatch(() => searchStore.searchPanelOpened, (opened) => {\n  if (opened) {\n    nextTick(() => {\n      searchInput.value?.focus()\n    })\n  }\n})\n\n</script>\n","/*!\n  * PhotoSwipe Lightbox 5.3.7 - https://photoswipe.com\n  * (c) 2023 Dmytro Semenov\n  */\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n\r\n/**\r\n * @template {keyof HTMLElementTagNameMap} T\r\n * @param {string} className\r\n * @param {T} tagName\r\n * @param {Node} [appendToEl]\r\n * @returns {HTMLElementTagNameMap[T]}\r\n */\r\nfunction createElement(className, tagName, appendToEl) {\r\n  const el = document.createElement(tagName);\r\n  if (className) {\r\n    el.className = className;\r\n  }\r\n  if (appendToEl) {\r\n    appendToEl.appendChild(el);\r\n  }\r\n  return el;\r\n}\r\n\r\n/**\r\n * Get transform string\r\n *\r\n * @param {number} x\r\n * @param {number} [y]\r\n * @param {number} [scale]\r\n * @returns {string}\r\n */\r\nfunction toTransformString(x, y, scale) {\r\n  let propValue = `translate3d(${x}px,${y || 0}px,0)`;\r\n\r\n  if (scale !== undefined) {\r\n    propValue += ` scale3d(${scale},${scale},1)`;\r\n  }\r\n\r\n  return propValue;\r\n}\r\n\r\n/**\r\n * Apply width and height CSS properties to element\r\n *\r\n * @param {HTMLElement} el\r\n * @param {string | number} w\r\n * @param {string | number} h\r\n */\r\nfunction setWidthHeight(el, w, h) {\r\n  el.style.width = (typeof w === 'number') ? `${w}px` : w;\r\n  el.style.height = (typeof h === 'number') ? `${h}px` : h;\r\n}\r\n\r\n/** @typedef {LOAD_STATE[keyof LOAD_STATE]} LoadState */\r\n/** @type {{ IDLE: 'idle'; LOADING: 'loading'; LOADED: 'loaded'; ERROR: 'error' }} */\r\nconst LOAD_STATE = {\r\n  IDLE: 'idle',\r\n  LOADING: 'loading',\r\n  LOADED: 'loaded',\r\n  ERROR: 'error',\r\n};\r\n\r\n\r\n/**\r\n * Check if click or keydown event was dispatched\r\n * with a special key or via mouse wheel.\r\n *\r\n * @param {MouseEvent | KeyboardEvent} e\r\n * @returns {boolean}\r\n */\r\nfunction specialKeyUsed(e) {\r\n  return ('button' in e && e.button === 1) || e.ctrlKey || e.metaKey || e.altKey || e.shiftKey;\r\n}\r\n\r\n/**\r\n * Parse `gallery` or `children` options.\r\n *\r\n * @param {import('../photoswipe.js').ElementProvider} [option]\r\n * @param {string} [legacySelector]\r\n * @param {HTMLElement | Document} [parent]\r\n * @returns HTMLElement[]\r\n */\r\nfunction getElementsFromOption(option, legacySelector, parent = document) {\r\n  /** @type {HTMLElement[]} */\r\n  let elements = [];\r\n\r\n  if (option instanceof Element) {\r\n    elements = [option];\r\n  } else if (option instanceof NodeList || Array.isArray(option)) {\r\n    elements = Array.from(option);\r\n  } else {\r\n    const selector = typeof option === 'string' ? option : legacySelector;\r\n    if (selector) {\r\n      elements = Array.from(parent.querySelectorAll(selector));\r\n    }\r\n  }\r\n\r\n  return elements;\r\n}\r\n\r\n/**\r\n * Check if variable is PhotoSwipe class\r\n *\r\n * @param {any} fn\r\n * @returns {boolean}\r\n */\r\nfunction isPswpClass(fn) {\r\n  return typeof fn === 'function'\r\n    && fn.prototype\r\n    && fn.prototype.goTo;\r\n}\r\n\r\n/**\r\n * Check if browser is Safari\r\n *\r\n * @returns {boolean}\r\n */\r\nfunction isSafari() {\r\n  return !!(navigator.vendor && navigator.vendor.match(/apple/i));\r\n}\n\n/** @typedef {import('../lightbox/lightbox.js').default} PhotoSwipeLightbox */\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\r\n/** @typedef {import('../ui/ui-element.js').UIElementData} UIElementData */\r\n/** @typedef {import('../slide/content.js').default} ContentDefault */\r\n/** @typedef {import('../slide/slide.js').default} Slide */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n/** @typedef {import('../slide/zoom-level.js').default} ZoomLevel */\r\n/** @typedef {import('../slide/get-thumb-bounds.js').Bounds} Bounds */\r\n\r\n/**\r\n * Allow adding an arbitrary props to the Content\r\n * https://photoswipe.com/custom-content/#using-webp-image-format\r\n * @typedef {ContentDefault & Record<string, any>} Content\r\n */\r\n/** @typedef {{ x?: number; y?: number }} Point */\r\n\r\n/**\r\n * @typedef {Object} PhotoSwipeEventsMap https://photoswipe.com/events/\r\n *\r\n *\r\n * https://photoswipe.com/adding-ui-elements/\r\n *\r\n * @prop {undefined} uiRegister\r\n * @prop {{ data: UIElementData }} uiElementCreate\r\n *\r\n *\r\n * https://photoswipe.com/events/#initialization-events\r\n *\r\n * @prop {undefined} beforeOpen\r\n * @prop {undefined} firstUpdate\r\n * @prop {undefined} initialLayout\r\n * @prop {undefined} change\r\n * @prop {undefined} afterInit\r\n * @prop {undefined} bindEvents\r\n *\r\n *\r\n * https://photoswipe.com/events/#opening-or-closing-transition-events\r\n *\r\n * @prop {undefined} openingAnimationStart\r\n * @prop {undefined} openingAnimationEnd\r\n * @prop {undefined} closingAnimationStart\r\n * @prop {undefined} closingAnimationEnd\r\n *\r\n *\r\n * https://photoswipe.com/events/#closing-events\r\n *\r\n * @prop {undefined} close\r\n * @prop {undefined} destroy\r\n *\r\n *\r\n * https://photoswipe.com/events/#pointer-and-gesture-events\r\n *\r\n * @prop {{ originalEvent: PointerEvent }} pointerDown\r\n * @prop {{ originalEvent: PointerEvent }} pointerMove\r\n * @prop {{ originalEvent: PointerEvent }} pointerUp\r\n * @prop {{ bgOpacity: number }} pinchClose can be default prevented\r\n * @prop {{ panY: number }} verticalDrag can be default prevented\r\n *\r\n *\r\n * https://photoswipe.com/events/#slide-content-events\r\n *\r\n * @prop {{ content: Content }} contentInit\r\n * @prop {{ content: Content; isLazy: boolean }} contentLoad can be default prevented\r\n * @prop {{ content: Content; isLazy: boolean }} contentLoadImage can be default prevented\r\n * @prop {{ content: Content; slide: Slide; isError?: boolean }} loadComplete\r\n * @prop {{ content: Content; slide: Slide }} loadError\r\n * @prop {{ content: Content; width: number; height: number }} contentResize can be default prevented\r\n * @prop {{ content: Content; width: number; height: number; slide: Slide }} imageSizeChange\r\n * @prop {{ content: Content }} contentLazyLoad can be default prevented\r\n * @prop {{ content: Content }} contentAppend can be default prevented\r\n * @prop {{ content: Content }} contentActivate can be default prevented\r\n * @prop {{ content: Content }} contentDeactivate can be default prevented\r\n * @prop {{ content: Content }} contentRemove can be default prevented\r\n * @prop {{ content: Content }} contentDestroy can be default prevented\r\n *\r\n *\r\n * undocumented\r\n *\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} imageClickAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} bgClickAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} tapAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} doubleTapAction can be default prevented\r\n *\r\n * @prop {{ originalEvent: KeyboardEvent }} keydown can be default prevented\r\n * @prop {{ x: number; dragging: boolean }} moveMainScroll\r\n * @prop {{ slide: Slide }} firstZoomPan\r\n * @prop {{ slide: Slide | undefined, data: SlideData, index: number }} gettingData\r\n * @prop {undefined} beforeResize\r\n * @prop {undefined} resize\r\n * @prop {undefined} viewportSize\r\n * @prop {undefined} updateScrollOffset\r\n * @prop {{ slide: Slide }} slideInit\r\n * @prop {{ slide: Slide }} afterSetContent\r\n * @prop {{ slide: Slide }} slideLoad\r\n * @prop {{ slide: Slide }} appendHeavy can be default prevented\r\n * @prop {{ slide: Slide }} appendHeavyContent\r\n * @prop {{ slide: Slide }} slideActivate\r\n * @prop {{ slide: Slide }} slideDeactivate\r\n * @prop {{ slide: Slide }} slideDestroy\r\n * @prop {{ destZoomLevel: number, centerPoint: Point | undefined, transitionDuration: number | false | undefined }} beforeZoomTo\r\n * @prop {{ slide: Slide }} zoomPanUpdate\r\n * @prop {{ slide: Slide }} initialZoomPan\r\n * @prop {{ slide: Slide }} calcSlideSize\r\n * @prop {undefined} resolutionChanged\r\n * @prop {{ originalEvent: WheelEvent }} wheel can be default prevented\r\n * @prop {{ content: Content }} contentAppendImage can be default prevented\r\n * @prop {{ index: number; itemData: SlideData }} lazyLoadSlide can be default prevented\r\n * @prop {undefined} lazyLoad\r\n * @prop {{ slide: Slide }} calcBounds\r\n * @prop {{ zoomLevels: ZoomLevel, slideData: SlideData }} zoomLevelsUpdate\r\n *\r\n *\r\n * legacy\r\n *\r\n * @prop {undefined} init\r\n * @prop {undefined} initialZoomIn\r\n * @prop {undefined} initialZoomOut\r\n * @prop {undefined} initialZoomInEnd\r\n * @prop {undefined} initialZoomOutEnd\r\n * @prop {{ dataSource: DataSource | undefined, numItems: number }} numItems\r\n * @prop {{ itemData: SlideData; index: number }} itemData\r\n * @prop {{ index: number, itemData: SlideData, instance: PhotoSwipe }} thumbBounds\r\n */\r\n\r\n/**\r\n * @typedef {Object} PhotoSwipeFiltersMap https://photoswipe.com/filters/\r\n *\r\n * @prop {(numItems: number, dataSource: DataSource | undefined) => number} numItems\r\n * Modify the total amount of slides. Example on Data sources page.\r\n * https://photoswipe.com/filters/#numitems\r\n *\r\n * @prop {(itemData: SlideData, index: number) => SlideData} itemData\r\n * Modify slide item data. Example on Data sources page.\r\n * https://photoswipe.com/filters/#itemdata\r\n *\r\n * @prop {(itemData: SlideData, element: HTMLElement, linkEl: HTMLAnchorElement) => SlideData} domItemData\r\n * Modify item data when it's parsed from DOM element. Example on Data sources page.\r\n * https://photoswipe.com/filters/#domitemdata\r\n *\r\n * @prop {(clickedIndex: number, e: MouseEvent, instance: PhotoSwipeLightbox) => number} clickedIndex\r\n * Modify clicked gallery item index.\r\n * https://photoswipe.com/filters/#clickedindex\r\n *\r\n * @prop {(placeholderSrc: string | false, content: Content) => string | false} placeholderSrc\r\n * Modify placeholder image source.\r\n * https://photoswipe.com/filters/#placeholdersrc\r\n *\r\n * @prop {(isContentLoading: boolean, content: Content) => boolean} isContentLoading\r\n * Modify if the content is currently loading.\r\n * https://photoswipe.com/filters/#iscontentloading\r\n *\r\n * @prop {(isContentZoomable: boolean, content: Content) => boolean} isContentZoomable\r\n * Modify if the content can be zoomed.\r\n * https://photoswipe.com/filters/#iscontentzoomable\r\n *\r\n * @prop {(useContentPlaceholder: boolean, content: Content) => boolean} useContentPlaceholder\r\n * Modify if the placeholder should be used for the content.\r\n * https://photoswipe.com/filters/#usecontentplaceholder\r\n *\r\n * @prop {(isKeepingPlaceholder: boolean, content: Content) => boolean} isKeepingPlaceholder\r\n * Modify if the placeholder should be kept after the content is loaded.\r\n * https://photoswipe.com/filters/#iskeepingplaceholder\r\n *\r\n *\r\n * @prop {(contentErrorElement: HTMLElement, content: Content) => HTMLElement} contentErrorElement\r\n * Modify an element when the content has error state (for example, if image cannot be loaded).\r\n * https://photoswipe.com/filters/#contenterrorelement\r\n *\r\n * @prop {(element: HTMLElement, data: UIElementData) => HTMLElement} uiElement\r\n * Modify a UI element that's being created.\r\n * https://photoswipe.com/filters/#uielement\r\n *\r\n * @prop {(thumbnail: HTMLElement | null | undefined, itemData: SlideData, index: number) => HTMLElement} thumbEl\r\n * Modify the thubmnail element from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbel\r\n *\r\n * @prop {(thumbBounds: Bounds | undefined, itemData: SlideData, index: number) => Bounds} thumbBounds\r\n * Modify the thubmnail bounds from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbbounds\r\n *\r\n * @prop {(srcsetSizesWidth: number, content: Content) => number} srcsetSizesWidth\r\n *\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @typedef {{ fn: PhotoSwipeFiltersMap[T], priority: number }} Filter\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {PhotoSwipeEventsMap[T] extends undefined ? PhotoSwipeEvent<T> : PhotoSwipeEvent<T> & PhotoSwipeEventsMap[T]} AugmentedEvent\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {(event: AugmentedEvent<T>) => void} EventCallback\r\n */\r\n\r\n/**\r\n * Base PhotoSwipe event object\r\n *\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n */\r\nclass PhotoSwipeEvent {\r\n  /**\r\n   * @param {T} type\r\n   * @param {PhotoSwipeEventsMap[T]} [details]\r\n   */\r\n  constructor(type, details) {\r\n    this.type = type;\r\n    this.defaultPrevented = false;\r\n    if (details) {\r\n      Object.assign(this, details);\r\n    }\r\n  }\r\n\r\n  preventDefault() {\r\n    this.defaultPrevented = true;\r\n  }\r\n}\r\n\r\n/**\r\n * PhotoSwipe base class that can listen and dispatch for events.\r\n * Shared by PhotoSwipe Core and PhotoSwipe Lightbox, extended by base.js\r\n */\r\nclass Eventable {\r\n  constructor() {\r\n    /**\r\n     * @type {{ [T in keyof PhotoSwipeEventsMap]?: ((event: AugmentedEvent<T>) => void)[] }}\r\n     */\r\n    this._listeners = {};\r\n\r\n    /**\r\n     * @type {{ [T in keyof PhotoSwipeFiltersMap]?: Filter<T>[] }}\r\n     */\r\n    this._filters = {};\r\n\r\n    /** @type {PhotoSwipe | undefined} */\r\n    this.pswp = undefined;\r\n\r\n    /** @type {PhotoSwipeOptions | undefined} */\r\n    this.options = undefined;\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeFiltersMap} T\r\n   * @param {T} name\r\n   * @param {PhotoSwipeFiltersMap[T]} fn\r\n   * @param {number} priority\r\n   */\r\n  addFilter(name, fn, priority = 100) {\r\n    if (!this._filters[name]) {\r\n      this._filters[name] = [];\r\n    }\r\n\r\n    this._filters[name]?.push({ fn, priority });\r\n    this._filters[name]?.sort((f1, f2) => f1.priority - f2.priority);\r\n\r\n    this.pswp?.addFilter(name, fn, priority);\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeFiltersMap} T\r\n   * @param {T} name\r\n   * @param {PhotoSwipeFiltersMap[T]} fn\r\n   */\r\n  removeFilter(name, fn) {\r\n    if (this._filters[name]) {\r\n      // @ts-expect-error\r\n      this._filters[name] = this._filters[name].filter(filter => (filter.fn !== fn));\r\n    }\r\n\r\n    if (this.pswp) {\r\n      this.pswp.removeFilter(name, fn);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeFiltersMap} T\r\n   * @param {T} name\r\n   * @param {Parameters<PhotoSwipeFiltersMap[T]>} args\r\n   * @returns {Parameters<PhotoSwipeFiltersMap[T]>[0]}\r\n   */\r\n  applyFilters(name, ...args) {\r\n    this._filters[name]?.forEach((filter) => {\r\n      // @ts-expect-error\r\n      args[0] = filter.fn.apply(this, args);\r\n    });\r\n    return args[0];\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeEventsMap} T\r\n   * @param {T} name\r\n   * @param {EventCallback<T>} fn\r\n   */\r\n  on(name, fn) {\r\n    if (!this._listeners[name]) {\r\n      this._listeners[name] = [];\r\n    }\r\n    this._listeners[name]?.push(fn);\r\n\r\n    // When binding events to lightbox,\r\n    // also bind events to PhotoSwipe Core,\r\n    // if it's open.\r\n    this.pswp?.on(name, fn);\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeEventsMap} T\r\n   * @param {T} name\r\n   * @param {EventCallback<T>} fn\r\n   */\r\n  off(name, fn) {\r\n    if (this._listeners[name]) {\r\n      // @ts-expect-error\r\n      this._listeners[name] = this._listeners[name].filter(listener => (fn !== listener));\r\n    }\r\n\r\n    this.pswp?.off(name, fn);\r\n  }\r\n\r\n  /**\r\n   * @template {keyof PhotoSwipeEventsMap} T\r\n   * @param {T} name\r\n   * @param {PhotoSwipeEventsMap[T]} [details]\r\n   * @returns {AugmentedEvent<T>}\r\n   */\r\n  dispatch(name, details) {\r\n    if (this.pswp) {\r\n      return this.pswp.dispatch(name, details);\r\n    }\r\n\r\n    const event = /** @type {AugmentedEvent<T>} */ (new PhotoSwipeEvent(name, details));\r\n\r\n    this._listeners[name]?.forEach((listener) => {\r\n      listener.call(this, event);\r\n    });\r\n\r\n    return event;\r\n  }\r\n}\n\nclass Placeholder {\r\n  /**\r\n   * @param {string | false} imageSrc\r\n   * @param {HTMLElement} container\r\n   */\r\n  constructor(imageSrc, container) {\r\n    // Create placeholder\r\n    // (stretched thumbnail or simple div behind the main image)\r\n    /** @type {HTMLImageElement | HTMLDivElement | null} */\r\n    this.element = createElement(\r\n      'pswp__img pswp__img--placeholder',\r\n      imageSrc ? 'img' : 'div',\r\n      container\r\n    );\r\n\r\n    if (imageSrc) {\r\n      const imgEl = /** @type {HTMLImageElement} */ (this.element);\r\n      imgEl.decoding = 'async';\r\n      imgEl.alt = '';\r\n      imgEl.src = imageSrc;\r\n      imgEl.setAttribute('role', 'presentation');\r\n    }\r\n\r\n    this.element.setAttribute('aria-hidden', 'true');\r\n  }\r\n\r\n  /**\r\n   * @param {number} width\r\n   * @param {number} height\r\n   */\r\n  setDisplayedSize(width, height) {\r\n    if (!this.element) {\r\n      return;\r\n    }\r\n\r\n    if (this.element.tagName === 'IMG') {\r\n      // Use transform scale() to modify img placeholder size\r\n      // (instead of changing width/height directly).\r\n      // This helps with performance, specifically in iOS15 Safari.\r\n      setWidthHeight(this.element, 250, 'auto');\r\n      this.element.style.transformOrigin = '0 0';\r\n      this.element.style.transform = toTransformString(0, 0, width / 250);\r\n    } else {\r\n      setWidthHeight(this.element, width, height);\r\n    }\r\n  }\r\n\r\n  destroy() {\r\n    if (this.element?.parentNode) {\r\n      this.element.remove();\r\n    }\r\n    this.element = null;\r\n  }\r\n}\n\n/** @typedef {import('./slide.js').default} Slide */\r\n/** @typedef {import('./slide.js').SlideData} SlideData */\r\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\r\n/** @typedef {import('../util/util.js').LoadState} LoadState */\r\n\r\nclass Content {\r\n  /**\r\n   * @param {SlideData} itemData Slide data\r\n   * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox instance\r\n   * @param {number} index\r\n   */\r\n  constructor(itemData, instance, index) {\r\n    this.instance = instance;\r\n    this.data = itemData;\r\n    this.index = index;\r\n\r\n    /** @type {HTMLImageElement | HTMLDivElement | undefined} */\r\n    this.element = undefined;\r\n    /** @type {Placeholder | undefined} */\r\n    this.placeholder = undefined;\r\n    /** @type {Slide | undefined} */\r\n    this.slide = undefined;\r\n\r\n    this.displayedImageWidth = 0;\r\n    this.displayedImageHeight = 0;\r\n\r\n    this.width = Number(this.data.w) || Number(this.data.width) || 0;\r\n    this.height = Number(this.data.h) || Number(this.data.height) || 0;\r\n\r\n    this.isAttached = false;\r\n    this.hasSlide = false;\r\n    this.isDecoding = false;\r\n    /** @type {LoadState} */\r\n    this.state = LOAD_STATE.IDLE;\r\n\r\n    if (this.data.type) {\r\n      this.type = this.data.type;\r\n    } else if (this.data.src) {\r\n      this.type = 'image';\r\n    } else {\r\n      this.type = 'html';\r\n    }\r\n\r\n    this.instance.dispatch('contentInit', { content: this });\r\n  }\r\n\r\n  removePlaceholder() {\r\n    if (this.placeholder && !this.keepPlaceholder()) {\r\n      // With delay, as image might be loaded, but not rendered\r\n      setTimeout(() => {\r\n        if (this.placeholder) {\r\n          this.placeholder.destroy();\r\n          this.placeholder = undefined;\r\n        }\r\n      }, 1000);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Preload content\r\n   *\r\n   * @param {boolean} isLazy\r\n   * @param {boolean} [reload]\r\n   */\r\n  load(isLazy, reload) {\r\n    if (this.slide && this.usePlaceholder()) {\r\n      if (!this.placeholder) {\r\n        const placeholderSrc = this.instance.applyFilters(\r\n          'placeholderSrc',\r\n          // use  image-based placeholder only for the first slide,\r\n          // as rendering (even small stretched thumbnail) is an expensive operation\r\n          (this.data.msrc && this.slide.isFirstSlide) ? this.data.msrc : false,\r\n          this\r\n        );\r\n        this.placeholder = new Placeholder(\r\n          placeholderSrc,\r\n          this.slide.container\r\n        );\r\n      } else {\r\n        const placeholderEl = this.placeholder.element;\r\n        // Add placeholder to DOM if it was already created\r\n        if (placeholderEl && !placeholderEl.parentElement) {\r\n          this.slide.container.prepend(placeholderEl);\r\n        }\r\n      }\r\n    }\r\n\r\n    if (this.element && !reload) {\r\n      return;\r\n    }\r\n\r\n    if (this.instance.dispatch('contentLoad', { content: this, isLazy }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    if (this.isImageContent()) {\r\n      this.element = createElement('pswp__img', 'img');\r\n      // Start loading only after width is defined, as sizes might depend on it.\r\n      // Due to Safari feature, we must define sizes before srcset.\r\n      if (this.displayedImageWidth) {\r\n        this.loadImage(isLazy);\r\n      }\r\n    } else {\r\n      this.element = createElement('pswp__content', 'div');\r\n      this.element.innerHTML = this.data.html || '';\r\n    }\r\n\r\n    if (reload && this.slide) {\r\n      this.slide.updateContentSize(true);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Preload image\r\n   *\r\n   * @param {boolean} isLazy\r\n   */\r\n  loadImage(isLazy) {\r\n    if (!this.isImageContent()\r\n      || !this.element\r\n      || this.instance.dispatch('contentLoadImage', { content: this, isLazy }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    const imageElement = /** @type HTMLImageElement */ (this.element);\r\n\r\n    this.updateSrcsetSizes();\r\n\r\n    if (this.data.srcset) {\r\n      imageElement.srcset = this.data.srcset;\r\n    }\r\n\r\n    imageElement.src = this.data.src ?? '';\r\n    imageElement.alt = this.data.alt ?? '';\r\n\r\n    this.state = LOAD_STATE.LOADING;\r\n\r\n    if (imageElement.complete) {\r\n      this.onLoaded();\r\n    } else {\r\n      imageElement.onload = () => {\r\n        this.onLoaded();\r\n      };\r\n\r\n      imageElement.onerror = () => {\r\n        this.onError();\r\n      };\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Assign slide to content\r\n   *\r\n   * @param {Slide} slide\r\n   */\r\n  setSlide(slide) {\r\n    this.slide = slide;\r\n    this.hasSlide = true;\r\n    this.instance = slide.pswp;\r\n\r\n    // todo: do we need to unset slide?\r\n  }\r\n\r\n  /**\r\n   * Content load success handler\r\n   */\r\n  onLoaded() {\r\n    this.state = LOAD_STATE.LOADED;\r\n\r\n    if (this.slide && this.element) {\r\n      this.instance.dispatch('loadComplete', { slide: this.slide, content: this });\r\n\r\n      // if content is reloaded\r\n      if (this.slide.isActive\r\n          && this.slide.heavyAppended\r\n          && !this.element.parentNode) {\r\n        this.append();\r\n        this.slide.updateContentSize(true);\r\n      }\r\n\r\n      if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\r\n        this.removePlaceholder();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Content load error handler\r\n   */\r\n  onError() {\r\n    this.state = LOAD_STATE.ERROR;\r\n\r\n    if (this.slide) {\r\n      this.displayError();\r\n      this.instance.dispatch('loadComplete', { slide: this.slide, isError: true, content: this });\r\n      this.instance.dispatch('loadError', { slide: this.slide, content: this });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @returns {Boolean} If the content is currently loading\r\n   */\r\n  isLoading() {\r\n    return this.instance.applyFilters(\r\n      'isContentLoading',\r\n      this.state === LOAD_STATE.LOADING,\r\n      this\r\n    );\r\n  }\r\n\r\n  /**\r\n   * @returns {Boolean} If the content is in error state\r\n   */\r\n  isError() {\r\n    return this.state === LOAD_STATE.ERROR;\r\n  }\r\n\r\n  /**\r\n   * @returns {boolean} If the content is image\r\n   */\r\n  isImageContent() {\r\n    return this.type === 'image';\r\n  }\r\n\r\n  /**\r\n   * Update content size\r\n   *\r\n   * @param {Number} width\r\n   * @param {Number} height\r\n   */\r\n  setDisplayedSize(width, height) {\r\n    if (!this.element) {\r\n      return;\r\n    }\r\n\r\n    if (this.placeholder) {\r\n      this.placeholder.setDisplayedSize(width, height);\r\n    }\r\n\r\n    if (this.instance.dispatch(\r\n      'contentResize',\r\n      { content: this, width, height }).defaultPrevented\r\n    ) {\r\n      return;\r\n    }\r\n\r\n    setWidthHeight(this.element, width, height);\r\n\r\n    if (this.isImageContent() && !this.isError()) {\r\n      const isInitialSizeUpdate = (!this.displayedImageWidth && width);\r\n\r\n      this.displayedImageWidth = width;\r\n      this.displayedImageHeight = height;\r\n\r\n      if (isInitialSizeUpdate) {\r\n        this.loadImage(false);\r\n      } else {\r\n        this.updateSrcsetSizes();\r\n      }\r\n\r\n      if (this.slide) {\r\n        this.instance.dispatch(\r\n          'imageSizeChange',\r\n          { slide: this.slide, width, height, content: this }\r\n        );\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @returns {boolean} If the content can be zoomed\r\n   */\r\n  isZoomable() {\r\n    return this.instance.applyFilters(\r\n      'isContentZoomable',\r\n      this.isImageContent() && (this.state !== LOAD_STATE.ERROR),\r\n      this\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Update image srcset sizes attribute based on width and height\r\n   */\r\n  updateSrcsetSizes() {\r\n    // Handle srcset sizes attribute.\r\n    //\r\n    // Never lower quality, if it was increased previously.\r\n    // Chrome does this automatically, Firefox and Safari do not,\r\n    // so we store largest used size in dataset.\r\n    if (!this.isImageContent() || !this.element || !this.data.srcset) {\r\n      return;\r\n    }\r\n\r\n    const image = /** @type HTMLImageElement */ (this.element);\r\n    const sizesWidth = this.instance.applyFilters(\r\n      'srcsetSizesWidth',\r\n      this.displayedImageWidth,\r\n      this\r\n    );\r\n\r\n    if (\r\n      !image.dataset.largestUsedSize\r\n      || sizesWidth > parseInt(image.dataset.largestUsedSize, 10)\r\n    ) {\r\n      image.sizes = sizesWidth + 'px';\r\n      image.dataset.largestUsedSize = String(sizesWidth);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @returns {boolean} If content should use a placeholder (from msrc by default)\r\n   */\r\n  usePlaceholder() {\r\n    return this.instance.applyFilters(\r\n      'useContentPlaceholder',\r\n      this.isImageContent(),\r\n      this\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Preload content with lazy-loading param\r\n   */\r\n  lazyLoad() {\r\n    if (this.instance.dispatch('contentLazyLoad', { content: this }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    this.load(true);\r\n  }\r\n\r\n  /**\r\n   * @returns {boolean} If placeholder should be kept after content is loaded\r\n   */\r\n  keepPlaceholder() {\r\n    return this.instance.applyFilters(\r\n      'isKeepingPlaceholder',\r\n      this.isLoading(),\r\n      this\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Destroy the content\r\n   */\r\n  destroy() {\r\n    this.hasSlide = false;\r\n    this.slide = undefined;\r\n\r\n    if (this.instance.dispatch('contentDestroy', { content: this }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    this.remove();\r\n\r\n    if (this.placeholder) {\r\n      this.placeholder.destroy();\r\n      this.placeholder = undefined;\r\n    }\r\n\r\n    if (this.isImageContent() && this.element) {\r\n      this.element.onload = null;\r\n      this.element.onerror = null;\r\n      this.element = undefined;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Display error message\r\n   */\r\n  displayError() {\r\n    if (this.slide) {\r\n      let errorMsgEl = createElement('pswp__error-msg', 'div');\r\n      errorMsgEl.innerText = this.instance.options?.errorMsg ?? '';\r\n      errorMsgEl = /** @type {HTMLDivElement} */ (this.instance.applyFilters(\r\n        'contentErrorElement',\r\n        errorMsgEl,\r\n        this\r\n      ));\r\n      this.element = createElement('pswp__content pswp__error-msg-container', 'div');\r\n      this.element.appendChild(errorMsgEl);\r\n      this.slide.container.innerText = '';\r\n      this.slide.container.appendChild(this.element);\r\n      this.slide.updateContentSize(true);\r\n      this.removePlaceholder();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Append the content\r\n   */\r\n  append() {\r\n    if (this.isAttached || !this.element) {\r\n      return;\r\n    }\r\n\r\n    this.isAttached = true;\r\n\r\n    if (this.state === LOAD_STATE.ERROR) {\r\n      this.displayError();\r\n      return;\r\n    }\r\n\r\n    if (this.instance.dispatch('contentAppend', { content: this }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    const supportsDecode = ('decode' in this.element);\r\n\r\n    if (this.isImageContent()) {\r\n      // Use decode() on nearby slides\r\n      //\r\n      // Nearby slide images are in DOM and not hidden via display:none.\r\n      // However, they are placed offscreen (to the left and right side).\r\n      //\r\n      // Some browsers do not composite the image until it's actually visible,\r\n      // using decode() helps.\r\n      //\r\n      // You might ask \"why dont you just decode() and then append all images\",\r\n      // that's because I want to show image before it's fully loaded,\r\n      // as browser can render parts of image while it is loading.\r\n      // We do not do this in Safari due to partial loading bug.\r\n      if (supportsDecode && this.slide && (!this.slide.isActive || isSafari())) {\r\n        this.isDecoding = true;\r\n        // purposefully using finally instead of then,\r\n        // as if srcset sizes changes dynamically - it may cause decode error\r\n        /** @type {HTMLImageElement} */\r\n        (this.element).decode().catch(() => {}).finally(() => {\r\n          this.isDecoding = false;\r\n          this.appendImage();\r\n        });\r\n      } else {\r\n        this.appendImage();\r\n      }\r\n    } else if (this.slide && !this.element.parentNode) {\r\n      this.slide.container.appendChild(this.element);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Activate the slide,\r\n   * active slide is generally the current one,\r\n   * meaning the user can see it.\r\n   */\r\n  activate() {\r\n    if (this.instance.dispatch('contentActivate', { content: this }).defaultPrevented\r\n      || !this.slide) {\r\n      return;\r\n    }\r\n\r\n    if (this.isImageContent() && this.isDecoding && !isSafari()) {\r\n      // add image to slide when it becomes active,\r\n      // even if it's not finished decoding\r\n      this.appendImage();\r\n    } else if (this.isError()) {\r\n      this.load(false, true); // try to reload\r\n    }\r\n\r\n    if (this.slide.holderElement) {\r\n      this.slide.holderElement.setAttribute('aria-hidden', 'false');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Deactivate the content\r\n   */\r\n  deactivate() {\r\n    this.instance.dispatch('contentDeactivate', { content: this });\r\n    if (this.slide && this.slide.holderElement) {\r\n      this.slide.holderElement.setAttribute('aria-hidden', 'true');\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Remove the content from DOM\r\n   */\r\n  remove() {\r\n    this.isAttached = false;\r\n\r\n    if (this.instance.dispatch('contentRemove', { content: this }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    if (this.element && this.element.parentNode) {\r\n      this.element.remove();\r\n    }\r\n\r\n    if (this.placeholder && this.placeholder.element) {\r\n      this.placeholder.element.remove();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Append the image content to slide container\r\n   */\r\n  appendImage() {\r\n    if (!this.isAttached) {\r\n      return;\r\n    }\r\n\r\n    if (this.instance.dispatch('contentAppendImage', { content: this }).defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    // ensure that element exists and is not already appended\r\n    if (this.slide && this.element && !this.element.parentNode) {\r\n      this.slide.container.appendChild(this.element);\r\n    }\r\n\r\n    if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\r\n      this.removePlaceholder();\r\n    }\r\n  }\r\n}\n\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n\r\n/**\r\n * @param {PhotoSwipeOptions} options\r\n * @param {PhotoSwipeBase} pswp\r\n * @returns {Point}\r\n */\r\nfunction getViewportSize(options, pswp) {\r\n  if (options.getViewportSizeFn) {\r\n    const newViewportSize = options.getViewportSizeFn(options, pswp);\r\n    if (newViewportSize) {\r\n      return newViewportSize;\r\n    }\r\n  }\r\n\r\n  return {\r\n    x: document.documentElement.clientWidth,\r\n\r\n    // TODO: height on mobile is very incosistent due to toolbar\r\n    // find a way to improve this\r\n    //\r\n    // document.documentElement.clientHeight - doesn't seem to work well\r\n    y: window.innerHeight\r\n  };\r\n}\r\n\r\n/**\r\n * Parses padding option.\r\n * Supported formats:\r\n *\r\n * // Object\r\n * padding: {\r\n *  top: 0,\r\n *  bottom: 0,\r\n *  left: 0,\r\n *  right: 0\r\n * }\r\n *\r\n * // A function that returns the object\r\n * paddingFn: (viewportSize, itemData, index) => {\r\n *  return {\r\n *    top: 0,\r\n *    bottom: 0,\r\n *    left: 0,\r\n *    right: 0\r\n *  };\r\n * }\r\n *\r\n * // Legacy variant\r\n * paddingLeft: 0,\r\n * paddingRight: 0,\r\n * paddingTop: 0,\r\n * paddingBottom: 0,\r\n *\r\n * @param {'left' | 'top' | 'bottom' | 'right'} prop\r\n * @param {PhotoSwipeOptions} options PhotoSwipe options\r\n * @param {Point} viewportSize PhotoSwipe viewport size, for example: { x:800, y:600 }\r\n * @param {SlideData} itemData Data about the slide\r\n * @param {number} index Slide index\r\n * @returns {number}\r\n */\r\nfunction parsePaddingOption(prop, options, viewportSize, itemData, index) {\r\n  let paddingValue = 0;\r\n\r\n  if (options.paddingFn) {\r\n    paddingValue = options.paddingFn(viewportSize, itemData, index)[prop];\r\n  } else if (options.padding) {\r\n    paddingValue = options.padding[prop];\r\n  } else {\r\n    const legacyPropName = 'padding' + prop[0].toUpperCase() + prop.slice(1);\r\n    // @ts-expect-error\r\n    if (options[legacyPropName]) {\r\n      // @ts-expect-error\r\n      paddingValue = options[legacyPropName];\r\n    }\r\n  }\r\n\r\n  return Number(paddingValue) || 0;\r\n}\r\n\r\n/**\r\n * @param {PhotoSwipeOptions} options\r\n * @param {Point} viewportSize\r\n * @param {SlideData} itemData\r\n * @param {number} index\r\n * @returns {Point}\r\n */\r\nfunction getPanAreaSize(options, viewportSize, itemData, index) {\r\n  return {\r\n    x: viewportSize.x\r\n      - parsePaddingOption('left', options, viewportSize, itemData, index)\r\n      - parsePaddingOption('right', options, viewportSize, itemData, index),\r\n    y: viewportSize.y\r\n      - parsePaddingOption('top', options, viewportSize, itemData, index)\r\n      - parsePaddingOption('bottom', options, viewportSize, itemData, index)\r\n  };\r\n}\n\nconst MAX_IMAGE_WIDTH = 4000;\r\n\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n\r\n/** @typedef {'fit' | 'fill' | number | ((zoomLevelObject: ZoomLevel) => number)} ZoomLevelOption */\r\n\r\n/**\r\n * Calculates zoom levels for specific slide.\r\n * Depends on viewport size and image size.\r\n */\r\nclass ZoomLevel {\r\n  /**\r\n   * @param {PhotoSwipeOptions} options PhotoSwipe options\r\n   * @param {SlideData} itemData Slide data\r\n   * @param {number} index Slide index\r\n   * @param {PhotoSwipe} [pswp] PhotoSwipe instance, can be undefined if not initialized yet\r\n   */\r\n  constructor(options, itemData, index, pswp) {\r\n    this.pswp = pswp;\r\n    this.options = options;\r\n    this.itemData = itemData;\r\n    this.index = index;\r\n    /** @type { Point | null } */\r\n    this.panAreaSize = null;\r\n    /** @type { Point | null } */\r\n    this.elementSize = null;\r\n    this.fit = 1;\r\n    this.fill = 1;\r\n    this.vFill = 1;\r\n    this.initial = 1;\r\n    this.secondary = 1;\r\n    this.max = 1;\r\n    this.min = 1;\r\n  }\r\n\r\n  /**\r\n   * Calculate initial, secondary and maximum zoom level for the specified slide.\r\n   *\r\n   * It should be called when either image or viewport size changes.\r\n   *\r\n   * @param {number} maxWidth\r\n   * @param {number} maxHeight\r\n   * @param {Point} panAreaSize\r\n   */\r\n  update(maxWidth, maxHeight, panAreaSize) {\r\n    /** @type {Point} */\r\n    const elementSize = { x: maxWidth, y: maxHeight };\r\n    this.elementSize = elementSize;\r\n    this.panAreaSize = panAreaSize;\r\n\r\n    const hRatio = panAreaSize.x / elementSize.x;\r\n    const vRatio = panAreaSize.y / elementSize.y;\r\n\r\n    this.fit = Math.min(1, hRatio < vRatio ? hRatio : vRatio);\r\n    this.fill = Math.min(1, hRatio > vRatio ? hRatio : vRatio);\r\n\r\n    // zoom.vFill defines zoom level of the image\r\n    // when it has 100% of viewport vertical space (height)\r\n    this.vFill = Math.min(1, vRatio);\r\n\r\n    this.initial = this._getInitial();\r\n    this.secondary = this._getSecondary();\r\n    this.max = Math.max(\r\n      this.initial,\r\n      this.secondary,\r\n      this._getMax()\r\n    );\r\n\r\n    this.min = Math.min(\r\n      this.fit,\r\n      this.initial,\r\n      this.secondary\r\n    );\r\n\r\n    if (this.pswp) {\r\n      this.pswp.dispatch('zoomLevelsUpdate', { zoomLevels: this, slideData: this.itemData });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Parses user-defined zoom option.\r\n   *\r\n   * @private\r\n   * @param {'initial' | 'secondary' | 'max'} optionPrefix Zoom level option prefix (initial, secondary, max)\r\n   * @returns { number | undefined }\r\n   */\r\n  _parseZoomLevelOption(optionPrefix) {\r\n    const optionName = /** @type {'initialZoomLevel' | 'secondaryZoomLevel' | 'maxZoomLevel'} */ (\r\n      optionPrefix + 'ZoomLevel'\r\n    );\r\n    const optionValue = this.options[optionName];\r\n\r\n    if (!optionValue) {\r\n      return;\r\n    }\r\n\r\n    if (typeof optionValue === 'function') {\r\n      return optionValue(this);\r\n    }\r\n\r\n    if (optionValue === 'fill') {\r\n      return this.fill;\r\n    }\r\n\r\n    if (optionValue === 'fit') {\r\n      return this.fit;\r\n    }\r\n\r\n    return Number(optionValue);\r\n  }\r\n\r\n  /**\r\n   * Get zoom level to which image will be zoomed after double-tap gesture,\r\n   * or when user clicks on zoom icon,\r\n   * or mouse-click on image itself.\r\n   * If you return 1 image will be zoomed to its original size.\r\n   *\r\n   * @private\r\n   * @return {number}\r\n   */\r\n  _getSecondary() {\r\n    let currZoomLevel = this._parseZoomLevelOption('secondary');\r\n\r\n    if (currZoomLevel) {\r\n      return currZoomLevel;\r\n    }\r\n\r\n    // 3x of \"fit\" state, but not larger than original\r\n    currZoomLevel = Math.min(1, this.fit * 3);\r\n\r\n    if (this.elementSize && currZoomLevel * this.elementSize.x > MAX_IMAGE_WIDTH) {\r\n      currZoomLevel = MAX_IMAGE_WIDTH / this.elementSize.x;\r\n    }\r\n\r\n    return currZoomLevel;\r\n  }\r\n\r\n  /**\r\n   * Get initial image zoom level.\r\n   *\r\n   * @private\r\n   * @return {number}\r\n   */\r\n  _getInitial() {\r\n    return this._parseZoomLevelOption('initial') || this.fit;\r\n  }\r\n\r\n  /**\r\n   * Maximum zoom level when user zooms\r\n   * via zoom/pinch gesture,\r\n   * via cmd/ctrl-wheel or via trackpad.\r\n   *\r\n   * @private\r\n   * @return {number}\r\n   */\r\n  _getMax() {\r\n    // max zoom level is x4 from \"fit state\",\r\n    // used for zoom gesture and ctrl/trackpad zoom\r\n    return this._parseZoomLevelOption('max') || Math.max(1, this.fit * 4);\r\n  }\r\n}\n\n/**\r\n * Lazy-load an image\r\n * This function is used both by Lightbox and PhotoSwipe core,\r\n * thus it can be called before dialog is opened.\r\n *\r\n * @param {SlideData} itemData Data about the slide\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox instance\r\n * @param {number} index\r\n * @returns {Content} Image that is being decoded or false.\r\n */\r\nfunction lazyLoadData(itemData, instance, index) {\r\n  const content = instance.createContentFromData(itemData, index);\r\n  /** @type {ZoomLevel | undefined} */\r\n  let zoomLevel;\r\n\r\n  const { options } = instance;\r\n\r\n  // We need to know dimensions of the image to preload it,\r\n  // as it might use srcset, and we need to define sizes\r\n  if (options) {\r\n    zoomLevel = new ZoomLevel(options, itemData, -1);\r\n\r\n    let viewportSize;\r\n    if (instance.pswp) {\r\n      viewportSize = instance.pswp.viewportSize;\r\n    } else {\r\n      viewportSize = getViewportSize(options, instance);\r\n    }\r\n\r\n    const panAreaSize = getPanAreaSize(options, viewportSize, itemData, index);\r\n    zoomLevel.update(content.width, content.height, panAreaSize);\r\n  }\r\n\r\n  content.lazyLoad();\r\n\r\n  if (zoomLevel) {\r\n    content.setDisplayedSize(\r\n      Math.ceil(content.width * zoomLevel.initial),\r\n      Math.ceil(content.height * zoomLevel.initial)\r\n    );\r\n  }\r\n\r\n  return content;\r\n}\r\n\r\n\r\n/**\r\n * Lazy-loads specific slide.\r\n * This function is used both by Lightbox and PhotoSwipe core,\r\n * thus it can be called before dialog is opened.\r\n *\r\n * By default, it loads image based on viewport size and initial zoom level.\r\n *\r\n * @param {number} index Slide index\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox eventable instance\r\n * @returns {Content | undefined}\r\n */\r\nfunction lazyLoadSlide(index, instance) {\r\n  const itemData = instance.getItemData(index);\r\n\r\n  if (instance.dispatch('lazyLoadSlide', { index, itemData }).defaultPrevented) {\r\n    return;\r\n  }\r\n\r\n  return lazyLoadData(itemData, instance, index);\r\n}\n\n/** @typedef {import(\"../photoswipe.js\").default} PhotoSwipe */\r\n/** @typedef {import(\"../slide/slide.js\").SlideData} SlideData */\r\n\r\n/**\r\n * PhotoSwipe base class that can retrieve data about every slide.\r\n * Shared by PhotoSwipe Core and PhotoSwipe Lightbox\r\n */\r\nclass PhotoSwipeBase extends Eventable {\r\n  /**\r\n   * Get total number of slides\r\n   *\r\n   * @returns {number}\r\n   */\r\n  getNumItems() {\r\n    let numItems = 0;\r\n    const dataSource = this.options?.dataSource;\r\n\r\n    if (dataSource && 'length' in dataSource) {\r\n      // may be an array or just object with length property\r\n      numItems = dataSource.length;\r\n    } else if (dataSource && 'gallery' in dataSource) {\r\n      // query DOM elements\r\n      if (!dataSource.items) {\r\n        dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\r\n      }\r\n\r\n      if (dataSource.items) {\r\n        numItems = dataSource.items.length;\r\n      }\r\n    }\r\n\r\n    // legacy event, before filters were introduced\r\n    const event = this.dispatch('numItems', {\r\n      dataSource,\r\n      numItems\r\n    });\r\n    return this.applyFilters('numItems', event.numItems, dataSource);\r\n  }\r\n\r\n  /**\r\n   * @param {SlideData} slideData\r\n   * @param {number} index\r\n   * @returns {Content}\r\n   */\r\n  createContentFromData(slideData, index) {\r\n    return new Content(slideData, this, index);\r\n  }\r\n\r\n  /**\r\n   * Get item data by index.\r\n   *\r\n   * \"item data\" should contain normalized information that PhotoSwipe needs to generate a slide.\r\n   * For example, it may contain properties like\r\n   * `src`, `srcset`, `w`, `h`, which will be used to generate a slide with image.\r\n   *\r\n   * @param {number} index\r\n   * @returns {SlideData}\r\n   */\r\n  getItemData(index) {\r\n    const dataSource = this.options?.dataSource;\r\n    /** @type {SlideData | HTMLElement} */\r\n    let dataSourceItem = {};\r\n    if (Array.isArray(dataSource)) {\r\n      // Datasource is an array of elements\r\n      dataSourceItem = dataSource[index];\r\n    } else if (dataSource && 'gallery' in dataSource) {\r\n      // dataSource has gallery property,\r\n      // thus it was created by Lightbox, based on\r\n      // gallery and children options\r\n\r\n      // query DOM elements\r\n      if (!dataSource.items) {\r\n        dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\r\n      }\r\n\r\n      dataSourceItem = dataSource.items[index];\r\n    }\r\n\r\n    let itemData = dataSourceItem;\r\n\r\n    if (itemData instanceof Element) {\r\n      itemData = this._domElementToItemData(itemData);\r\n    }\r\n\r\n    // Dispatching the itemData event,\r\n    // it's a legacy verion before filters were introduced\r\n    const event = this.dispatch('itemData', {\r\n      itemData: itemData || {},\r\n      index\r\n    });\r\n\r\n    return this.applyFilters('itemData', event.itemData, index);\r\n  }\r\n\r\n  /**\r\n   * Get array of gallery DOM elements,\r\n   * based on childSelector and gallery element.\r\n   *\r\n   * @param {HTMLElement} galleryElement\r\n   * @returns {HTMLElement[]}\r\n   */\r\n  _getGalleryDOMElements(galleryElement) {\r\n    if (this.options?.children || this.options?.childSelector) {\r\n      return getElementsFromOption(\r\n        this.options.children,\r\n        this.options.childSelector,\r\n        galleryElement\r\n      ) || [];\r\n    }\r\n\r\n    return [galleryElement];\r\n  }\r\n\r\n  /**\r\n   * Converts DOM element to item data object.\r\n   *\r\n   * @param {HTMLElement} element DOM element\r\n   * @returns {SlideData}\r\n   */\r\n  _domElementToItemData(element) {\r\n    /** @type {SlideData} */\r\n    const itemData = {\r\n      element\r\n    };\r\n\r\n    const linkEl = /** @type {HTMLAnchorElement} */ (\r\n      element.tagName === 'A'\r\n        ? element\r\n        : element.querySelector('a')\r\n    );\r\n\r\n    if (linkEl) {\r\n      // src comes from data-pswp-src attribute,\r\n      // if it's empty link href is used\r\n      itemData.src = linkEl.dataset.pswpSrc || linkEl.href;\r\n\r\n      if (linkEl.dataset.pswpSrcset) {\r\n        itemData.srcset = linkEl.dataset.pswpSrcset;\r\n      }\r\n\r\n      itemData.width = linkEl.dataset.pswpWidth ? parseInt(linkEl.dataset.pswpWidth, 10) : 0;\r\n      itemData.height = linkEl.dataset.pswpHeight ? parseInt(linkEl.dataset.pswpHeight, 10) : 0;\r\n\r\n      // support legacy w & h properties\r\n      itemData.w = itemData.width;\r\n      itemData.h = itemData.height;\r\n\r\n      if (linkEl.dataset.pswpType) {\r\n        itemData.type = linkEl.dataset.pswpType;\r\n      }\r\n\r\n      const thumbnailEl = element.querySelector('img');\r\n\r\n      if (thumbnailEl) {\r\n        // msrc is URL to placeholder image that's displayed before large image is loaded\r\n        // by default it's displayed only for the first slide\r\n        itemData.msrc = thumbnailEl.currentSrc || thumbnailEl.src;\r\n        itemData.alt = thumbnailEl.getAttribute('alt') ?? '';\r\n      }\r\n\r\n      if (linkEl.dataset.pswpCropped || linkEl.dataset.cropped) {\r\n        itemData.thumbCropped = true;\r\n      }\r\n    }\r\n\r\n    return this.applyFilters('domItemData', itemData, element, linkEl);\r\n  }\r\n\r\n  /**\r\n   * Lazy-load by slide data\r\n   *\r\n   * @param {SlideData} itemData Data about the slide\r\n   * @param {number} index\r\n   * @returns {Content} Image that is being decoded or false.\r\n   */\r\n  lazyLoadData(itemData, index) {\r\n    return lazyLoadData(itemData, this, index);\r\n  }\r\n}\n\n/**\r\n * @template T\r\n * @typedef {import('../types.js').Type<T>} Type<T>\r\n */\r\n\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/content.js').default} Content */\r\n/** @typedef {import('../core/eventable.js').PhotoSwipeEventsMap} PhotoSwipeEventsMap */\r\n/** @typedef {import('../core/eventable.js').PhotoSwipeFiltersMap} PhotoSwipeFiltersMap */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {import('../core/eventable.js').EventCallback<T>} EventCallback<T>\r\n */\r\n\r\n/**\r\n * PhotoSwipe Lightbox\r\n *\r\n * - If user has unsupported browser it falls back to default browser action (just opens URL)\r\n * - Binds click event to links that should open PhotoSwipe\r\n * - parses DOM strcture for PhotoSwipe (retrieves large image URLs and sizes)\r\n * - Initializes PhotoSwipe\r\n *\r\n *\r\n * Loader options use the same object as PhotoSwipe, and supports such options:\r\n *\r\n * gallery - Element | Element[] | NodeList | string selector for the gallery element\r\n * children - Element | Element[] | NodeList | string selector for the gallery children\r\n *\r\n */\r\nclass PhotoSwipeLightbox extends PhotoSwipeBase {\r\n  /**\r\n   * @param {PhotoSwipeOptions} [options]\r\n   */\r\n  constructor(options) {\r\n    super();\r\n    /** @type {PhotoSwipeOptions} */\r\n    this.options = options || {};\r\n    this._uid = 0;\r\n    this.shouldOpen = false;\r\n    /**\r\n     * @private\r\n     * @type {Content | undefined}\r\n     */\r\n    this._preloadedContent = undefined;\r\n\r\n    this.onThumbnailsClick = this.onThumbnailsClick.bind(this);\r\n  }\r\n\r\n  /**\r\n   * Initialize lightbox, should be called only once.\r\n   * It's not included in the main constructor, so you may bind events before it.\r\n   */\r\n  init() {\r\n    // Bind click events to each gallery\r\n    getElementsFromOption(this.options.gallery, this.options.gallerySelector)\r\n      .forEach((galleryElement) => {\r\n        galleryElement.addEventListener('click', this.onThumbnailsClick, false);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * @param {MouseEvent} e\r\n   */\r\n  onThumbnailsClick(e) {\r\n    // Exit and allow default browser action if:\r\n    if (specialKeyUsed(e) // ... if clicked with a special key (ctrl/cmd...)\r\n        || window.pswp // ... if PhotoSwipe is already open\r\n        || window.navigator.onLine === false) { // ... if offline\r\n      return;\r\n    }\r\n\r\n    // If both clientX and clientY are 0 or not defined,\r\n    // the event is likely triggered by keyboard,\r\n    // so we do not pass the initialPoint\r\n    //\r\n    // Note that some screen readers emulate the mouse position,\r\n    // so it's not the ideal way to detect them.\r\n    //\r\n    /** @type {Point | null} */\r\n    let initialPoint = { x: e.clientX, y: e.clientY };\r\n\r\n    if (!initialPoint.x && !initialPoint.y) {\r\n      initialPoint = null;\r\n    }\r\n\r\n    let clickedIndex = this.getClickedIndex(e);\r\n    clickedIndex = this.applyFilters('clickedIndex', clickedIndex, e, this);\r\n    /** @type {DataSource} */\r\n    const dataSource = {\r\n      gallery: /** @type {HTMLElement} */ (e.currentTarget)\r\n    };\r\n\r\n    if (clickedIndex >= 0) {\r\n      e.preventDefault();\r\n      this.loadAndOpen(clickedIndex, dataSource, initialPoint);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get index of gallery item that was clicked.\r\n   *\r\n   * @param {MouseEvent} e click event\r\n   * @returns {number}\r\n   */\r\n  getClickedIndex(e) {\r\n    // legacy option\r\n    if (this.options.getClickedIndexFn) {\r\n      return this.options.getClickedIndexFn.call(this, e);\r\n    }\r\n\r\n    const clickedTarget = /** @type {HTMLElement} */ (e.target);\r\n    const childElements = getElementsFromOption(\r\n      this.options.children,\r\n      this.options.childSelector,\r\n      /** @type {HTMLElement} */ (e.currentTarget)\r\n    );\r\n    const clickedChildIndex = childElements.findIndex(\r\n      child => child === clickedTarget || child.contains(clickedTarget)\r\n    );\r\n\r\n    if (clickedChildIndex !== -1) {\r\n      return clickedChildIndex;\r\n    } else if (this.options.children || this.options.childSelector) {\r\n      // click wasn't on a child element\r\n      return -1;\r\n    }\r\n\r\n    // There is only one item (which is the gallery)\r\n    return 0;\r\n  }\r\n\r\n  /**\r\n   * Load and open PhotoSwipe\r\n   *\r\n   * @param {number} index\r\n   * @param {DataSource} dataSource\r\n   * @param {Point | null} [initialPoint]\r\n   * @returns {boolean}\r\n   */\r\n  loadAndOpen(index, dataSource, initialPoint) {\r\n    // Check if the gallery is already open\r\n    if (window.pswp) {\r\n      return false;\r\n    }\r\n\r\n    // set initial index\r\n    this.options.index = index;\r\n\r\n    // define options for PhotoSwipe constructor\r\n    this.options.initialPointerPos = initialPoint;\r\n\r\n    this.shouldOpen = true;\r\n    this.preload(index, dataSource);\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Load the main module and the slide content by index\r\n   *\r\n   * @param {number} index\r\n   * @param {DataSource} [dataSource]\r\n   */\r\n  preload(index, dataSource) {\r\n    const { options } = this;\r\n\r\n    if (dataSource) {\r\n      options.dataSource = dataSource;\r\n    }\r\n\r\n    // Add the main module\r\n    /** @type {Promise<Type<PhotoSwipe>>[]} */\r\n    const promiseArray = [];\r\n\r\n    const pswpModuleType = typeof options.pswpModule;\r\n    if (isPswpClass(options.pswpModule)) {\r\n      promiseArray.push(Promise.resolve(/** @type {Type<PhotoSwipe>} */ (options.pswpModule)));\r\n    } else if (pswpModuleType === 'string') {\r\n      throw new Error('pswpModule as string is no longer supported');\r\n    } else if (pswpModuleType === 'function') {\r\n      promiseArray.push(/** @type {() => Promise<Type<PhotoSwipe>>} */ (options.pswpModule)());\r\n    } else {\r\n      throw new Error('pswpModule is not valid');\r\n    }\r\n\r\n    // Add custom-defined promise, if any\r\n    if (typeof options.openPromise === 'function') {\r\n      // allow developers to perform some task before opening\r\n      promiseArray.push(options.openPromise());\r\n    }\r\n\r\n    if (options.preloadFirstSlide !== false && index >= 0) {\r\n      this._preloadedContent = lazyLoadSlide(index, this);\r\n    }\r\n\r\n    // Wait till all promises resolve and open PhotoSwipe\r\n    const uid = ++this._uid;\r\n    Promise.all(promiseArray).then((iterableModules) => {\r\n      if (this.shouldOpen) {\r\n        const mainModule = iterableModules[0];\r\n        this._openPhotoswipe(mainModule, uid);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * @private\r\n   * @param {Type<PhotoSwipe> | { default: Type<PhotoSwipe> }} module\r\n   * @param {number} uid\r\n   */\r\n  _openPhotoswipe(module, uid) {\r\n    // Cancel opening if UID doesn't match the current one\r\n    // (if user clicked on another gallery item before current was loaded).\r\n    //\r\n    // Or if shouldOpen flag is set to false\r\n    // (developer may modify it via public API)\r\n    if (uid !== this._uid && this.shouldOpen) {\r\n      return;\r\n    }\r\n\r\n    this.shouldOpen = false;\r\n\r\n    // PhotoSwipe is already open\r\n    if (window.pswp) {\r\n      return;\r\n    }\r\n\r\n    /**\r\n     * Pass data to PhotoSwipe and open init\r\n     *\r\n     * @type {PhotoSwipe}\r\n     */\r\n    const pswp = typeof module === 'object'\r\n        ? new module.default(this.options) // eslint-disable-line\r\n        : new module(this.options); // eslint-disable-line\r\n\r\n    this.pswp = pswp;\r\n    window.pswp = pswp;\r\n\r\n    // map listeners from Lightbox to PhotoSwipe Core\r\n    /** @type {(keyof PhotoSwipeEventsMap)[]} */\r\n    (Object.keys(this._listeners)).forEach((name) => {\r\n      this._listeners[name]?.forEach((fn) => {\r\n        pswp.on(name, /** @type {EventCallback<typeof name>} */(fn));\r\n      });\r\n    });\r\n\r\n    // same with filters\r\n    /** @type {(keyof PhotoSwipeFiltersMap)[]} */\r\n    (Object.keys(this._filters)).forEach((name) => {\r\n      this._filters[name]?.forEach((filter) => {\r\n        pswp.addFilter(name, filter.fn, filter.priority);\r\n      });\r\n    });\r\n\r\n    if (this._preloadedContent) {\r\n      pswp.contentLoader.addToCache(this._preloadedContent);\r\n      this._preloadedContent = undefined;\r\n    }\r\n\r\n    pswp.on('destroy', () => {\r\n      // clean up public variables\r\n      this.pswp = undefined;\r\n      delete window.pswp;\r\n    });\r\n\r\n    pswp.init();\r\n  }\r\n\r\n  /**\r\n   * Unbinds all events, closes PhotoSwipe if it's open.\r\n   */\r\n  destroy() {\r\n    this.pswp?.destroy();\r\n\r\n    this.shouldOpen = false;\r\n    this._listeners = {};\r\n\r\n    getElementsFromOption(this.options.gallery, this.options.gallerySelector)\r\n      .forEach((galleryElement) => {\r\n        galleryElement.removeEventListener('click', this.onThumbnailsClick, false);\r\n      });\r\n  }\r\n}\n\nexport { PhotoSwipeLightbox as default };\n//# sourceMappingURL=photoswipe-lightbox.esm.js.map\n","<template>\n  <div class=\"m-product__pswp-swiper\">\n    <div ref=\"slider\" class=\"swiper\">\n      <div class=\"swiper-wrapper\" id=\"product_detail_swiper\" ref=\"gallery\">\n        <template v-for=\"index in Math.ceil(props.media.length / imagesPerSlide)\" :key=\"index\">\n          <div class=\"m-product__pswp-slide swiper-slide\"\n            :style=\"`--columns: ${Math.ceil(Math.sqrt(imagesPerSlide))}; --rows: ${Math.ceil(imagesPerSlide / Math.ceil(Math.sqrt(imagesPerSlide)))}`\">\n            <template v-for=\"number in imagesPerSlide\" :key=\"number\">\n              <a v-if=\"props.media[getNumber(index, number)]\" class=\"m-product__pswp\"\n                :href=\"props.media[getNumber(index, number)].thumbUrl + '?width=2500&height=2500'\" :data-pswp-width=\"2500\"\n                :data-pswp-height=\"2500\" target=\"_blank\" rel=\"noreferrer\">\n                <picture class=\"a-image a-image--contain\" style=\"--padding-ratio: calc(1/1)\">\n                  <img class=\"a-image__img\" :src=\"props.media[getNumber(index, number)].thumbUrl + '?width=5&height=5'\"\n                    :data-src=\"props.media[getNumber(index, number)].thumbUrl + '?width=725&height=725'\"\n                    :title=\"props.media[getNumber(index, number)].title\" :alt=\"props.media[getNumber(index, number)].alt\"\n                    loading=\"lazy\">\n                </picture>\n              </a>\n            </template>\n          </div>\n        </template>\n      </div>\n      <div class=\"m-product-detail__navigation u-visible@md\">\n        <button type=\"button\" ref=\"navPrev\" class=\"a-btn a-btn--icon m-product__swiper-nav m-product__swiper-nav--left\">\n          <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n            <use xlink:href=\"#navigation-left\" />\n          </svg>\n        </button>\n        <button type=\"button\" ref=\"navNext\" class=\"a-btn a-btn--icon m-product__swiper-nav m-product__swiper-nav--right\">\n          <svg class=\"a-icon a-icon--navigation\" aria-hidden=\"true\">\n            <use xlink:href=\"#navigation-right\" />\n          </svg>\n        </button>\n      </div>\n    </div>\n    <div class=\"swiper-pagination product-detail-slider\" ref=\"pagination\"></div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport PhotoSwipeLightbox from 'photoswipe/lightbox'\nimport 'photoswipe/style.css'\nimport Swiper, { A11y, Lazy, Navigation, Pagination } from 'swiper'\nimport 'swiper/css'\nimport 'swiper/css/pagination'\nimport { ComponentPublicInstance, nextTick, onMounted, onUnmounted, ref } from 'vue'\nimport { Media } from '../../models/product'\n\nconst imagesPerSlide = ref(4)\nconst swiper = ref<Swiper>()\nconst lightbox = ref<any>()\nconst gallery = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst slider = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst pagination = ref<ComponentPublicInstance<HTMLDivElement>>()\nconst navNext = ref<ComponentPublicInstance<HTMLElement>>()\nconst navPrev = ref<ComponentPublicInstance<HTMLElement>>()\n\nconst props = defineProps({\n  media: {\n    type: Array<Media>,\n    default: () => [],\n  },\n})\nonMounted(() => {\n  lightbox.value = new PhotoSwipeLightbox({\n    gallery: gallery.value!,\n    children: 'a',\n    pswpModule: () => import('photoswipe'),\n  })\n\n  imagesPerSlide.value = props.media.length <= 2 ? 1 : 4\n  lightbox.value.init()\n  nextTick(() => {\n    swiper.value = new Swiper(slider.value as HTMLDivElement, {\n      modules: [Navigation, Pagination, A11y, Lazy],\n      pagination: {\n        el: pagination.value as HTMLDivElement,\n        type: 'bullets',\n      },\n      navigation: {\n        nextEl: navNext.value as HTMLElement,\n        prevEl: navPrev.value as HTMLElement,\n      },\n      a11y: {\n        enabled: true,\n        containerMessage: 'Merken slider',\n      },\n      slidesPerView: 1,\n      grabCursor: true,\n    })\n    lightbox.value.on('change', () => {\n      if (swiper.value) {\n        swiper.value.slideTo(Math.floor(lightbox.value.pswp.currIndex / imagesPerSlide.value))\n      }\n    })\n  })\n})\n\n\nonUnmounted(() => {\n  if (lightbox.value) {\n    lightbox.value.destroy()\n    lightbox.value = null\n  }\n})\n\nconst getNumber = (index: number, number: number) => {\n  return imagesPerSlide.value * (index - 1) + (number - 1)\n}\n</script>\n","<template>\n  <div class=\"m-product-info\">\n    <h1 class=\"m-product-info__title\">{{ productName }}</h1>\n    <div class=\"m-product-info__cost\" v-if=\"!hidePrice\">\n      <span\n        v-if=\"selectedProductHasSale\"\n        class=\"m-product-info__price m-product-info__price--sale\"\n      >\n        {{ selectedPrice }}\n      </span>\n      <span\n        v-if=\"selectedProductHasSale\"\n        class=\"m-product-info__price m-product-info__price--old\"\n      >\n        {{ selectedOriginalPrice }}\n      </span>\n      <span v-else class=\"m-product-info__price\">\n        {{ selectedPrice }}\n      </span>\n    </div>\n    <div class=\"m-product-info__variants\">\n      <div\n        v-for=\"[internalName, attributeValue] of Object.entries(props.product.attributes).filter(([internalName, av]) => props.displayedAttributes.includes(internalName))\"\n        class=\"m-product-info__variants-current\"\n        :key=\"internalName\"\n      >\n        <span>{{ attributeValue.name }}:</span> {{ attributeValue.value }}\n      </div>\n      <ul class=\"m-product-info__variants-list\" v-if=\"colorVariants.length > 0\">\n        <li class=\"m-product-info__variant active\">\n          <div class=\"m-product-info__variant-link\">\n            <picture\n              v-if=\"props.product.media.length > 0\"\n              class=\"a-image a-image--contain\"\n              style=\"--padding-ratio: calc(1/1);\"\n            >\n              <img class=\"a-image__img\"\n                :src=\"props.product.media[0].thumbUrl + '?widht=5&height=5'\"\n                :data-src=\"props.product.media[0].thumbUrl + '?widht=150&height=150'\"\n                :alt=\"props.product.media[0].alt\" loading=\"lazy\" />\n            </picture>\n          </div>\n        </li>\n        <li\n          v-for=\"colorVariant of colorVariants\"\n          class=\"m-product-info__variant\"\n          :key=\"colorVariant.ID\"\n        >\n          <a class=\"m-product-info__variant-link\" :href=\"colorVariant.url\">\n            <picture\n              v-if=\"colorVariant.media.length > 0\"\n              class=\"a-image a-image--contain\"\n              style=\"--padding-ratio: calc(1/1);\"\n            >\n              <img\n                class=\"a-image__img\"\n                :src=\"colorVariant.media[0].thumbUrl + '?widht=5&height=5'\"\n                :data-src=\"colorVariant.media[0].thumbUrl + '?widht=150&height=150'\"\n                :alt=\"colorVariant.media[0].alt\" loading=\"lazy\"\n              >\n            </picture>\n          </a>\n        </li>\n      </ul>\n    </div>\n    <div\n      v-if=\"!hidePrice && props.product.available\"\n      class=\"m-product-info__order\"\n    >\n      <!-- <button class=\"a-btn m-product-info__size-chart\" type=\"button\">Maatbalk</button> -->\n      <div class=\"m-products__sort\" v-if=\"props.product.variants.filter(v => v.available).length > 0\">\n        <select\n          v-model=\"selectedProduct\"\n          @change=\"$event => updateSelection(selectedProduct)\"\n          class=\"a-select\"\n          name=\"sort\"\n        >\n          <template\n            v-for=\"option in sortAttributeValueList(availableVariants, (variant: Variant): string => {\n              return formatConfigurableAttributes(variant, props.configurableAttributes)\n            })\"\n            :key=\"option.ID\"\n          >\n            <option\n              v-text=\"formatConfigurableAttributes(option, props.configurableAttributes)\"\n              :value=\"option\"\n              :selected=\"selectedProduct.ID === option.ID\"\n            >\n            </option>\n          </template>\n        </select>\n        <div class=\"a-select__icon\">\n          <svg class=\"a-icon a-icon--pagination\" aria-hidden=\"true\">\n            <use href=\"#chevron-down\" />\n          </svg>\n        </div>\n      </div>\n\n      <button class=\"a-btn a-btn--add\" type=\"button\" @click=\"$event => addToCart()\">\n        {{ t('cart.button.add-to-cart') }}\n      </button>\n    </div>\n    <div v-if=\"!hidePrice &&\n     !props.product.available\">\n      <p class=\"m-product-info__sold-out\">\n        {{ translate('product_detail.product_info.sold_out', {}) }}\n      </p>\n      <button class=\"a-btn a-btn--add\" type=\"button\" disabled>\n        {{ t('cart.button.add-to-cart') }}\n      </button>\n    </div>\n    <ul class=\"m-product-info__usps\" v-if=\"props.usps.length\">\n      <li class=\"m-product-info__usp\" v-for=\"usp in props.usps\" :key=\"usp\">\n        <svg class=\"a-icon a-icon--usp\">\n          <use xlink:href=\"#check\"></use>\n        </svg>\n        <span class=\"m-product-info__usp-text\">{{ usp }}</span>\n      </li>\n    </ul>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ComputedRef, Ref, computed, nextTick, onMounted, ref } from 'vue'\nimport { useCartStore } from '../../stores/cart'\nimport { displayPrice } from '../../helper/currency'\nimport { ProductData, Variant, hasSale, ProductType } from '../../models/product'\nimport { useI18n } from 'vue-i18n'\nimport { formatConfigurableAttributes, sortAttributeValueList } from '../../helper/product'\nimport { lazyLoadUpdate } from '../../lazyload'\nimport { translate } from '../../helper-functions'\n\nconst { t } = useI18n()\nconst cartStore = useCartStore()\n\nconst props = defineProps({\n  product: {\n    type: Object as () => ProductData,\n    required: true,\n  },\n  colorVariants: {\n    type: Array as () => ProductData[],\n    required: true,\n    default: () => [],\n  },\n  usps: {\n    type: Array as () => string[],\n    required: true,\n  },\n  configurableAttributes: {\n    type: Array<string>,\n    default: () => ['sc_size'],\n  },\n  displayedAttributes: {\n    type: Array<string>,\n    default: () => ['brand', 'sc_color', 'material'],\n  }\n})\nconst availableVariants = computed(() => {\n  return props.product.variants.filter(v => v.available)\n})\nconst selectedProduct: Ref<Variant> = ref(props.product)\nconst selectedProductHasSale: ComputedRef<boolean> = computed(() => {\n  return hasSale(selectedProduct.value)\n})\nconst selectedPrice:  ComputedRef<string> = computed(()=> displayPrice(selectedProduct.value.price))\nconst selectedOriginalPrice: ComputedRef<string> = computed(()=> displayPrice(selectedProduct.value.originalPrice))\nconst productName:  ComputedRef<string> = computed(()=> props.product.displayName)\nconst hidePrice: ComputedRef<boolean> = computed(() => {\n  return props.product.tags.includes('hide-price')\n})\n\nonMounted(async () => {\n  await cartStore.init()\n  setInitialSelectedProduct()\n  nextTick(() => {\n    lazyLoadUpdate()\n  })\n})\n\nfunction addToCart() {\n  let configurationOf = null\n  if (props.product.ID !== selectedProduct.value.ID) {\n    configurationOf = props.product.ID\n  }\n\n  cartStore.add(selectedProduct.value.ID, 1, configurationOf)\n}\n\nfunction updateSelection(variant: Variant) {\n  selectedProduct.value = variant\n  window.location.hash = variant.ID\n}\n\nfunction setInitialSelectedProduct() {\n  if (availableVariants.value.length > 0) {\n    if (window.location.hash !== '' && window.location.hash.substring(1).length > 0) {\n      let variant = availableVariants.value.find((variant) => {\n        if (variant.ID === window.location.hash.substring(1)) {\n          return true\n        }\n      })\n\n      if (variant) {\n        updateSelection(variant)\n        return\n      }\n    }\n\n    updateSelection(availableVariants.value[0])\n  } else {\n    updateSelection(props.product)\n  }\n}\n\n</script>\n","<template>\n  <span ref=\"navTrigger\"></span>\n  <div class=\"m-product__detail__nav-sticky\">\n    <div class=\"o-container\">\n      <nav class=\"m-product-detail__nav\">\n        <ol class=\"m-product-detail__nav-list\">\n          <!-- CORE-1978 Frontend: sticky menu / intersect observer -->\n          <li v-if=\"Object.keys(navItems).length > 0\" v-for=\"value, index of navItems\" class=\"m-product-detail__nav-item\"\n            :key=\"value.id\">\n            <button type=\"button\" @click.prevent=\"scrollToItem(value.element!, index)\">\n              {{ value.title }}\n            </button>\n          </li>\n        </ol>\n      </nav>\n    </div>\n  </div>\n  <div class=\"o-container\">\n    <div class=\"m-product-detail__trigger\"></div>\n    <section ref=\"description\" class=\"m-product-detail__section\"\n      :aria-label=\"translate('product_detail.description.area_label')\"\n      :data-section=\"translate('product_detail.description.section')\">\n      <h2 class=\"m-product-detail__section-title\">\n        {{ translate('product_detail.description.title') }}\n      </h2>\n      <div ref=\"descriptionField\" class=\"m-product-detail__description o-editor-content o-editor-content--description\"\n        :class=\"{ 'open': expanded }\" v-html=\"props.product.description\"></div>\n      <button v-if=\"partiallyHideDescription\" class=\"m-product-detail__description-btn a-btn\"\n        :class=\"{ 'open': expanded }\" type=\"button\" @click=\"toggle()\">\n        {{ expanded ? translate('product_detail.description.hide') :\n          translate('product_detail.description.show_more') }}\n      </button>\n    </section>\n    <div class=\"m-product-detail__trigger\"></div>\n    <section ref=\"productInfo\" class=\"m-product-detail__section m-product-detail__information\"\n      :aria-label=\"translate('product_detail.product_info.area_label')\"\n      :data-section=\"translate('product_detail.product_info.section')\">\n      <h2 class=\"m-product-detail__section-title\">\n        {{ translate('product_detail.product_info.title') }}\n      </h2>\n      <table class=\"m-product-detail__information-table\">\n        <tbody>\n          <tr v-for=\"attributeValue in attributes\" :key=\"attributeValue.internalName\">\n            <td>\n              {{ attributeValue.name }}\n            </td>\n            <td v-html=\"attributeValue.value\">\n            </td>\n          </tr>\n          <tr v-if=\"displayProductSku\">\n            <td>\n              {{ translate('product_detail.product_info.product_number') }}\n            </td>\n            <td>\n              {{ props.product.sku }}\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </section>\n    <template v-for=\"[internalName, productRelationType] of Object.entries(props.productRelations).filter(([internalName, prt]) => internalName != 'color_variant' && prt.products.length > 0)\" :key=\"internalName\">\n      <div class=\"m-product-detail__trigger\"></div>\n      <section :ref=\"(el) => {relatedProductTypeReferences[internalName] = el}\">\n      <h2>{{ productRelationType.name }}</h2>\n      <div class=\"o-product-overview__products\">\n        <product-card v-for=\"product of productRelationType.products\" :product=\"product\" :key=\"product.ID\" :display-discount-percentage=\"props.displayDiscountPercentage\"></product-card>\n      </div>\n    </section>\n    </template>\n\n  </div>\n</template>\n<script setup lang=\"ts\">\nimport { Ref, computed, nextTick, onMounted, ref, watch } from 'vue'\nimport { AttributeVisibility, ProductData } from '../../models/product'\nimport { translate } from '../../helper-functions'\nimport { EventProductView, EventProduct, emitEvent } from '../../helper/tracking-events'\nimport { lazyLoadUpdate } from '../../lazyload'\n\nconst props = defineProps({\n  product: {\n    type: Object as () => ProductData,\n    required: true,\n  },\n  productRelations: {\n    type: Object as () => {\n      [key: string]: {\n        name: string,\n        products: ProductData[]\n      }\n    },\n    default: () => ({}),\n    required: true,\n  },\n  displayDiscountPercentage: {\n    type: Boolean,\n    default: false,\n  },\n  displayProductSku: {\n    type: Boolean,\n    default: true,\n  }\n})\n\nconst attributes = computed(() => {\n  const attrs = []\n  for (const [name, attributeValue] of Object.entries(props.product.attributes)) {\n    if (attributeValue.visibility.includes(AttributeVisibility.Catalog)) {\n      attrs.push({ ...attributeValue, internalName: name })\n    }\n  }\n\n  return attrs\n})\n\nfunction scrollToItem(element: Element, key: Number) {\n  if (!element) {\n    return\n  }\n\n  element.scrollIntoView({ behavior: 'smooth', inline: 'start' })\n}\n\nconst descriptionField: Ref<HTMLElement | null> = ref(null)\nconst partiallyHideDescription = computed(() => {\n  if (!descriptionField.value) {\n    return false\n  }\n\n  return elementHasOverflow(descriptionField.value)\n})\n\nconst expanded = ref(false)\n\nconst isSticky: Ref<Boolean> = ref(false)\nconst description: Ref<Element | null> = ref(null)\nconst productInfo: Ref<Element | null> = ref(null)\nconst navTrigger: Ref<Element | null> = ref(null)\nconst relatedProductTypeReferences: Ref<{ [key: string]: Element | null | any  }> = ref({})\n\nconst navItems: Ref<Array<{ id: string; title: string; element: Element | null }>> = ref(\n  [\n    {\n      id: 'description',\n      title: translate('product_detail.description.title'),\n      element: description,\n    },\n    {\n      id: 'product_info',\n      title: translate('product_detail.product_info.title'),\n      element: productInfo,\n    },\n  ]\n)\n\nwatch(() => isSticky.value, (value) => {\n  if (!value) {\n    document.querySelectorAll('.m-product-detail__nav-item').forEach(tab => {\n      tab.classList.remove(\"active\")\n    })\n  }\n});\n\nonMounted(() => {\n  for (let [internalName, relations] of Object.entries(props.productRelations).filter(([internalName, prt]) => internalName != 'color_variant' && prt.products.length > 0)) {\n    if (!(internalName in relatedProductTypeReferences.value)){\n      relatedProductTypeReferences.value[internalName] = null\n    }\n\n    navItems.value.push({\n      id: internalName,\n      title: relations.name,\n      element: relatedProductTypeReferences.value[internalName]\n    })\n  }\n\n  emitProductDetailEvent()\n  nextTick(() => {\n    lazyLoadUpdate()\n    handleDetailTabs()\n  })\n})\n\nfunction emitProductDetailEvent() {\n  let productRelations: { [key: string]: EventProduct[] } = {}\n  for (let [key, productRelation] of Object.entries(props.productRelations)) {\n    productRelations[key] = productRelation.products.map(product => formatProduct(product))\n  }\n\n  emitEvent(EventProductView, {\n    product: formatProduct(props.product),\n    // Relations are created by the user and can vary from this example.\n    relations: productRelations,\n  })\n}\n\nfunction formatProduct(product: ProductData): EventProduct {\n  let attributes: { [key: string]: string } = {}\n  for (let [key, attribute] of Object.entries(props.product.attributes)) {\n    attributes[key] = attribute.value\n  }\n\n  return {\n    ID: product.ID,\n    name: product.name,\n    variants: (product.variants ?? []).map(v => {\n      let variantAttributes: { [key: string]: string } = {}\n      for (let [key, attribute] of Object.entries(v.attributes)) {\n        variantAttributes[key] = attribute.value\n      }\n      return {\n        ID: v.ID,\n        name: product.name,\n        price: Number(v.price),\n        attributes: variantAttributes,\n      }\n    }),\n    price: Number(product.price), // The price in cents, equivalent to €59.99.\n    attributes: attributes,\n  }\n}\n\nfunction elementHasOverflow(el: HTMLElement): boolean {\n  return el.clientWidth < el.scrollWidth || el.clientHeight < el.scrollHeight;\n}\n\nfunction handleDetailTabs() {\n  const tabs = document.querySelectorAll('.m-product-detail__nav-item');\n  const sectionTriggers = document.querySelectorAll('.m-product-detail__trigger');\n\n  const stickyObserver = new IntersectionObserver(entries => {\n    if (entries[0].boundingClientRect.y < 0) {\n      isSticky.value = true\n    } else {\n      isSticky.value = false\n    }\n  })\n\n  const sectionObserver = new IntersectionObserver((entries) => {\n    entries.forEach((entry) => {\n\n      if (! isSticky.value) {\n        return\n      }\n      let intersectedIndex = Array.from(sectionTriggers).indexOf(entry.target)\n\n      if (entry.isIntersecting) {\n        intersectedIndex = Array.from(sectionTriggers).indexOf(entry.target) - 1 > 0 ? Array.from(sectionTriggers).indexOf(entry.target) - 1 : 0\n      }\n\n      tabs.forEach(tab => {\n        tab.classList.remove(\"active\")\n      })\n\n      tabs[intersectedIndex].classList.add(\"active\")\n    })\n  }, {\n    rootMargin: '0px 0px 100% 0px',\n  })\n\n  if (navTrigger.value) {\n    stickyObserver.observe(navTrigger.value)\n  }\n\n  sectionTriggers.forEach(trigger => {\n    sectionObserver.observe(trigger)\n  })\n}\n\nfunction toggle() {\n  expanded.value = !expanded.value\n}\n\n</script>\n","<template>\n  <article class=\"m-blog__card u-col-span:4@md\" v-for=\"article of props.articles\">\n    <a :href=\"article.url\" class=\"m-blog__link\">\n      <picture v-if=\"article.overview_image\" class=\"a-image a-image--contain a-image--center-center\" style=\"--padding-ratio: calc(200/400)\">\n        <img class=\"a-image__img\" :src=\"article.overview_image + '?width=5&height=5' ?? ''\"  :data-src=\"article.overview_image + '?width=400&height=200' ?? ''\" loading=\"lazy\" />\n      </picture>\n\n      <div class=\"m-blog__info\">\n        <span class=\"m-blog__date\">{{ displayDate(article.created_at) }}</span>\n        <h2 class=\"m-blog__title a-h3\">{{ article.title }}</h2>\n        <p class=\"m-blog__description\" v-html=\"article.summary\"></p>\n      </div>\n    </a>\n  </article>\n</template>\n<script setup lang=\"ts\">\n\nfunction displayDate(dateString: string): string {\n  const date: Date = new Date(dateString)\n  return date.toLocaleDateString('default', { day: '2-digit', month: 'long', year: 'numeric' })\n}\n\nconst props = defineProps({\n  articles: {\n    type: Array<Article>,\n    default: [],\n    required: true,\n  },\n})\n\ninterface Article {\n  title: string;\n  summary: string;\n  url: string;\n  overview_image: string;\n  created_at: string;\n}\n\n</script>\n","<template >\n  <div class=\"o-component\">\n    <div class=\"o-container\">\n      <article class=\"o-article\">\n        <header class=\"o-article__header a-layout a-layout--clean\">\n          <span class=\"o-article__meta u-col-start:3@md u-col-end:11@md\">{{ displayDate(props.article.created_at) }}</span>\n          <h1 class=\"o-article__title u-col-start:3@md u-col-end:11@md\">{{ props.article.title }}</h1>\n          <div class=\"o-article__intro u-col-start:3@md u-col-end:11@md\" v-html=\"props.article.summary\">\n          </div>\n          <div v-if=\"settings.main_image_visible && props.article.featured_image\" class=\"o-article__hero u-col-start:2@md u-col-end:12@md\">\n            <picture class=\"a-image\" style=\"--padding-ratio: calc(1080 / 1920)\">\n              <img class=\"a-image__img\" width=\"100%\"\n                :src=\"props.article.featured_image?.thumbURL + '?width=5&height=5' ?? ''\"\n                :data-src=\"props.article.featured_image?.thumbURL + '?width=1920&height=1080' ?? ''\"\n                :alt=\"props.article.featured_image?.alt ?? ''\" loading=\"lazy\"/>\n            </picture>\n          </div>\n        </header>\n        <div v-if=\"settings.main_text_visible\" class=\"o-article__content a-layout a-layout--clean\">\n          <section class=\"u-col-start:3@md u-col-end:11@md\" v-html=\"props.article.content\"></section>\n        </div>\n        <div class=\"o-article__content\">\n          <template v-for=\"block in props.blocks\">\n            <ArticleCallToActionBlock v-if=\"typeof block.call_to_action !== 'undefined' || block.call_to_action === null\"\n              :call-to-actions=\"block.call_to_action ?? []\"></ArticleCallToActionBlock>\n            <ArticleTitleTextBlock v-if=\"block.title_text\" :title-text=\"block.title_text\">\n            </ArticleTitleTextBlock>\n            <ArticleImageTextBlock v-if=\"block.image_text_block\" :image-text=\"block.image_text_block\">\n            </ArticleImageTextBlock>\n          </template>\n        </div>\n      </article>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { PropType } from 'vue';\nimport ArticleTitleTextBlock from './ArticleTitleTextBlock.vue';\nimport ArticleImageTextBlock from './ArticleImageTextBlock.vue';\nimport ArticleCallToActionBlock from './ArticleCallToActionBlock.vue';\nimport { CallToActionBlock, ImageTextBlock, TitleTextBlock } from '../../helper/article';\n\nfunction displayDate(dateString: string): string {\n  const date: Date = new Date(dateString)\n  return date.toLocaleDateString('default', { day: '2-digit', month: 'long', year: 'numeric' })\n}\n\nconst props = defineProps({\n  article: {\n    type: Object as PropType<Article>,\n    required: true,\n  },\n  settings: {\n    type: Object as PropType<Settings>,\n    required: true,\n  },\n  blocks: {\n    type: Array<{\n      title_text: TitleTextBlock | null,\n      image_text_block: ImageTextBlock | null,\n      call_to_action: CallToActionBlock[] | null,\n    }>,\n    default: [],\n  }\n})\n\ninterface Article {\n  title: string,\n  created_at: string,\n  featured_image?: {\n    thumbURL: string;\n    alt: string;\n  },\n  summary: string,\n  content: string,\n}\n\ninterface Settings {\n  main_image_visible: boolean;\n  main_text_visible: boolean;\n}\n</script>\n","<template>\n  <div class=\"o-component\">\n    <div class=\"o-container\">\n      <h2 class=\"a-h1 m-contact__title\">{{ translate('contact.general.title') }}</h2>\n      <div class=\"m-contact\">\n        <div class=\"m-contact__left\">\n          <div v-for=\"storeAddress of props.storeAddresses\" class=\"m-contact__opening-hours\">\n            <h3 class=\"m-text__title a-h3\">\n              {{ storeAddress.name }}\n            </h3>\n            <div class=\"o-editor-content\">\n              {{ storeAddress.street }} {{ storeAddress.house_number }}{{ storeAddress.house_number_extension ? ' ' +\n                storeAddress.house_number_extension : '' }}<br>\n              {{ storeAddress.zipcode }} {{ storeAddress.city }}<br>\n              <a :href=\"`mailto:${storeAddress.email}`\" :title=\"storeAddress.email\">{{ storeAddress.email }}</a><br>\n              <a :href=\"`tel:${storeAddress.phone}`\" :title=\"storeAddress.phone\">{{ storeAddress.phone }}</a><br><br>\n              <div v-html=\"storeAddress.note\">\n              </div>\n              <section class=\"m-contact__opening-hours\" v-if=\"storeAddress.opening_hours.length > 0\">\n                <strong>\n                  {{ translate('contact.opening_hours.title') }}\n                </strong>\n                <table>\n                  <tbody>\n                    <tr v-for=\"openingHour of storeAddress.opening_hours\">\n                      <td>{{ openingHour.label }}</td>\n                      <td>{{ openingHour.value }}</td>\n                    </tr>\n                  </tbody>\n                </table>\n              </section>\n            </div>\n          </div>\n        </div>\n        <div class=\"m-contact__right\" v-if=\"!contactFormAlreadySubmitted\">\n          <h3 class=\"m-text__title a-h3\">\n            {{ translate('contact.form.title') }}\n          </h3>\n          <form ref=\"form\" class=\"m-contact__form\" method=\"post\" :action=\"props.formEndpoint\" @submit=\"submitForm\"\n            autocomplete=\"on\">\n\n            <!-- Name -->\n            <div>\n              <div class=\"a-input__contact\" :class=\"{ 'a-input--invalid': v$.name.$error }\">\n                <label class=\"a-input__contact\" for=\"form_name\">\n                  {{ translate('contact.form.field_name_label') }}\n                </label>\n                <input class=\"a-input\" type=\"text\" name=\"form_name\" v-model=\"formValues.name\"\n                  :placeholder=\"translate('contact.form.field_name_label')\" @focus=\"loadRecaptcha\"\n                  @blur=\"v$.name.$touch()\">\n                <p v-if=\"v$.name.$errors.length > 0\" class=\"a-input__label--error\">\n                  {{ v$.name.$errors[0].$message }}\n                </p>\n              </div>\n            </div>\n            <!-- Email -->\n            <div>\n              <div class=\"a-input__contact\" :class=\"{ 'a-input--invalid': v$.email.$error }\">\n                <label class=\"a-input__contact\" for=\"form_email\">\n                  {{ translate('contact.form.field_email_label') }}\n                </label>\n                <input class=\"a-input\" type=\"email\" name=\"form_email\" v-model=\"formValues.email\"\n                  :placeholder=\"translate('contact.form.field_email_label')\" @focus=\"loadRecaptcha\"\n                  @blur=\"v$.email.$touch()\">\n                <p v-if=\"v$.email.$errors.length > 0\" class=\"a-input__label--error\">\n                  {{ v$.email.$errors[0].$message }}\n                </p>\n              </div>\n            </div>\n            <!-- Phone number -->\n            <div>\n              <div class=\"a-input__contact\" :class=\"{ 'a-input--invalid': v$.phone.$error }\">\n                <label class=\"a-input__contact\" for=\"form_phone\">\n                  {{ translate('contact.form.field_phone_label') }}\n                </label>\n                <input class=\"a-input\" type=\"tel\" name=\"form_phone\"\n                  :placeholder=\"translate('contact.form.field_phone_label')\" v-model=\"formValues.message\"\n                  @focus=\"loadRecaptcha\" @blur=\"v$.phone.$touch()\">\n                <p v-if=\"v$.phone.$errors.length > 0\" class=\"a-input__label--error\">\n                  {{ v$.phone.$errors[0].$message }}\n                </p>\n              </div>\n            </div>\n            <!-- Message -->\n            <div>\n              <div class=\"a-input__contact\" :class=\"{ 'a-input--invalid': v$.message.$error }\">\n                <label class=\"a-input__contact\" for=\"form_message\">\n                  {{ translate('contact.form.field_comment_label') }}\n                </label>\n                <textarea class=\"a-textarea\" name=\"form_message\" cols=\"30\" rows=\"10\" maxlength=\"2000\"\n                  @focus=\"loadRecaptcha\" :placeholder=\"translate('contact.form.field_comment_label')\"\n                  @blur=\"v$.message.$touch()\">\n                </textarea>\n                <p v-if=\"v$.message.$errors.length > 0\" class=\"a-input__label--error\">\n                  {{ v$.message.$errors[0].$message }}\n                </p>\n              </div>\n            </div>\n            <input type=\"hidden\" name=\"b_7dfac84e9f9c202ac271ed_265328dfd53a5\" value=\"\" />\n            <button class=\"a-btn a-btn--primary\" type=\"submit\">\n              {{ translate('contact.form.button_submit') }}\n            </button>\n          </form>\n        </div>\n        <div class=\"u-col-start:6@md u-col-end:12@md\" v-if=\"contactFormAlreadySubmitted\">\n          <h3 class=\"m-text__title a-h3\">{{ translate('contact.form.title') }}</h3>\n          <div class=\"o-editor-content\">\n            <p>\n              {{ translate('contact.message.already_submitted') }}\n            </p>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n<script setup lang=\"ts\">\nimport { translate } from '../../helper-functions'\nimport { useRecaptchaStore } from '../../stores/recaptcha'\nimport { Ref, onMounted, ref } from 'vue'\nimport { useCookies } from 'vue3-cookies'\nimport useVuelidate from '@vuelidate/core'\nimport { maxLength, required } from '../../helper/validators'\nimport { StoreAddress } from '../../helper/address'\n\ninterface Form {\n  name: string\n  email: string\n  phone: string\n  message: string\n}\n\nconst recaptcha = useRecaptchaStore()\nconst loading: Ref<boolean> = ref(false)\nconst errorMessage: Ref<string> = ref('')\nconst form: Ref<HTMLFormElement | null> = ref(null)\nconst cookieApi = useCookies()\nconst contactFormCookieKey = 'contact-form-submitted'\nconst contactFormAlreadySubmitted: Ref<boolean> = ref(false)\nconst formValues: Ref<Form> = ref({\n  name: '',\n  email: '',\n  phone: '',\n  message: '',\n})\nconst v$ = useVuelidate({\n  name: {\n    required,\n    maxLength: maxLength(255)\n  },\n  email: {\n    required,\n    maxLength: maxLength(320)\n  },\n  phone: {},\n  message: {\n    required,\n    maxLength: maxLength(2000)\n  },\n}, formValues)\nconst props = defineProps({\n  storeAddresses: {\n    type: Array<StoreAddress>,\n    default: [],\n    required: true,\n  },\n  formEndpoint: {\n    type: String,\n    default: '/form/contact',\n    required: true,\n  },\n  recaptchaSiteKey: {\n    type: String,\n    default: '',\n    required: true,\n  }\n})\nfunction loadRecaptcha() {\n  if ((props.recaptchaSiteKey ?? '').length === 0) {\n    return\n  }\n\n  recaptcha.init(props.recaptchaSiteKey)\n}\n\nonMounted(() => {\n  if (cookieApi.cookies.get(contactFormCookieKey) === '1') {\n    errorMessage.value = translate('contact.error.already-submitted')\n    contactFormAlreadySubmitted.value = true\n    return\n  }\n\n  (window as any).sendNewsletterForm = submitForm\n  loading.value = false\n})\n\nasync function submitForm($event: Event) {\n  $event.preventDefault()\n\n  loading.value = true\n  errorMessage.value = ''\n  const recapthcaToken = await recaptcha.getRecaptchaToken('contactForm')\n  const serializedFormData = getSerializedFormData(form.value!)\n\n  await fetch(props.formEndpoint, {\n    method: form.value!.method,\n    body: serializedFormData,\n    headers: {\n      'Content-Type': 'application/x-www-form-urlencoded',\n      'g-recaptcha-token': recapthcaToken,\n    },\n  }).then(async (resp) => {\n    if (!resp.ok || resp.headers.get('captchaError') === '1') {\n      let data = await resp.json()\n      errorMessage.value = data.error ?? defaultErrorMessage()\n      loading.value = false\n      return\n    }\n    // expiresInMs is set to 30 seconds.\n    const expiresInMs = 1000 * 30\n\n    cookieApi.cookies.set(contactFormCookieKey, '1', new Date(Date.now() + expiresInMs))\n    contactFormAlreadySubmitted.value = true\n  }).catch(resp => {\n    errorMessage.value = resp.error\n  }).finally(() => {\n    loading.value = false\n  })\n}\n\nfunction getSerializedFormData(formElement: HTMLFormElement): string {\n  const formData = new FormData(formElement)\n  let formDataRecord: Record<string, string> = {}\n  formData.forEach((value: FormDataEntryValue, key: string) => {\n    formDataRecord[key] = value.toString()\n  })\n  return new URLSearchParams(formDataRecord).toString()\n}\n\nfunction defaultErrorMessage(): string {\n  return translate('contact.error.general')\n}\n</script>\n","<template>\n  <div class=\"o-container\" v-if=\"props.product\">\n    <div class=\"o-product-sets__detail\">\n      <picture class=\"a-image\" v-if=\"props.product.media && props.product.media.length > 0\" style=\"--padding\">\n        <img class=\"a-image__img\" :alt=\"props.product.media[0].alt\" :title=\"props.product.media[0].title\"\n          :src=\"props.product.media[0].thumbUrl + '?width=5&height=5'\"\n          :data-src=\"props.product.media[0].thumbUrl + '?width=434&height=434'\"\n          loading=\"lazy\" />\n      </picture>\n      <div class=\"m-product-set__info\">\n        <h3 class=\"m-product-info__title\">{{ props.product.displayName }}</h3>\n        <div class=\"m-product-info__cost\">\n          <span class=\"m-product-info__price m-product-info__price--sale\"\n            v-if=\"hasSale(props.product)\">{{ displayPrice(props.product.price) }}</span>\n          <span class=\"m-product-info__price m-product-info__price--old\"\n            v-if=\"hasSale(props.product)\">{{ displayPrice(props.product.originalPrice)\n            }}</span>\n          <span class=\"m-product-info__price\" v-else>{{ displayPrice(props.product.price) }}</span>\n        </div>\n        <form class=\"m-product-set__form\" @submit.prevent=\"cartStore.add(selectedProduct.ID, 1, props.product!.ID !== selectedProduct.ID ? props.product!.ID : null)\"\n          v-if=\"props.product.variants.length > 0\">\n          <div class=\"m-products__sort\">\n            <select v-model=\"selectedProduct\" class=\"a-select\" id=\"id\" name=\"sort\">\n              <template v-for=\"(option) in availableVariants\" :key=\"option.ID\">\n                <option :value=\"option\" :selected=\"selectedProduct.ID === option.ID\"\n                  v-text=\"formatConfigurableAttributes(option, props.configurableAttributes ?? [])\"></option>\n              </template>\n            </select>\n            <div class=\"a-select__icon\">\n              <svg class=\"a-icon a-icon--pagination\" aria-hidden=\"true\">\n                <use href=\"#chevron-down\" />\n              </svg>\n            </div>\n          </div>\n          <button class=\"a-btn a-btn--cart\" type=\"submit\">{{ t('cart.button.add-to-cart') }}</button>\n        </form>\n        <div class=\"m-product-set__form\">\n          <div class=\"m-products__sort\">\n            <button v-if=\"props.product.type === ProductType.Simple\" class=\"a-btn a-btn--cart\" type=\"button\"\n              @click=\"cartStore.add(selectedProduct.ID, 1, props.product!.ID !== selectedProduct.ID ? props.product!.ID : null)\">{{ t('cart.button.add-to-cart') }}</button>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { Ref, computed, onMounted, ref } from 'vue'\nimport { ProductData, ProductType, Variant, hasSale } from '../../models/product';\nimport { formatConfigurableAttributes } from '../../helper/product';\nimport { useI18n } from 'vue-i18n';\nimport { useCartStore } from '../../stores/cart';\nimport { displayPrice } from '../../helper/currency';\n\nconst cartStore = useCartStore()\nonMounted(async () => {\n  await cartStore.init()\n})\n\nconst { t } = useI18n()\nconst props = defineProps({\n  product: {\n    type: Object as () => ProductData,\n  },\n  configurableAttributes: {\n    type: Array<string>,\n    default: () => ['sc_size'],\n  }\n})\n\nconst loading = ref(true)\nconst availableVariants = computed(() => {\n  return (props.product?.variants ?? []).filter(v => v.available)\n})\nconst selectedProduct: Ref<Variant> = ref(props.product!)\n\nfunction setInitialSelectedProduct() {\n  if (availableVariants.value.length > 0) {\n    if (window.location.hash !== '' && window.location.hash.substring(1).length > 0) {\n      let variant = availableVariants.value.find((variant) => {\n        if (variant.ID === window.location.hash.substring(1)) {\n          return true\n        }\n      })\n      if (variant) {\n        selectedProduct.value = variant\n        return\n      }\n    }\n\n    selectedProduct.value = availableVariants.value[0]\n  } else {\n    selectedProduct.value= props.product!\n  }\n}\n\nonMounted(async () => {\n  if (props.product) {\n    setInitialSelectedProduct()\n    loading.value = false\n  }\n})\n</script>\n","<script setup lang=\"ts\">\nimport { onMounted } from 'vue';\nimport { EventCollectionImpression, emitEvent } from '../helper/tracking-events';\nimport { ProductData } from '../models/product';\n\nconst props = defineProps({\n  collection: {\n    type: String,\n  },\n  products: {\n    type: Array<ProductData>,\n    default: () => []\n  }\n})\n\nonMounted(() => {\n  emitEvent(EventCollectionImpression, {\n    collection: props.collection,\n    products: props.products.map(p => {\n      let attributes: { [key: string]: string } = {}\n      for (let [key, attribute] of Object.entries(p.attributes)) {\n        attributes[key] = attribute.value\n      }\n\n      return {\n        ID: p.ID,\n        name: p.name,\n        variants: p.variants.map(variant => {\n          let variantAttributes: { [key: string]: string } = {}\n          for (let [key, attribute] of Object.entries(variant.attributes)) {\n            variantAttributes[key] = attribute.value\n          }\n\n          return {\n            ID: variant.ID,\n            name: p.name,\n            price: variant.price,\n            attributes: variantAttributes,\n          }\n        }),\n        price: p.price,\n        attributes: attributes,\n      }\n    })\n  })\n})\n</script>\n","import { defineStore } from \"pinia\";\nimport { computed, ref, Ref } from \"vue\";\nimport { useCookies } from \"vue3-cookies\";\n\nconst cookieBarKey = 'cloudcommerce_cookies_enabled';\n\nexport const useCookieBar = defineStore('cookie-bar', () => {\n    const loading: Ref<boolean> = ref(true);\n    const showCookieBar: Ref<boolean> = ref(true);\n    const cookieApi = useCookies()\n\n    showCookieBar.value = cookieApi.cookies.get(cookieBarKey) !== '1' && cookieApi.cookies.get(cookieBarKey) !== '0';\n    loading.value = false;\n\n    function acceptCookies() {\n        cookieApi.cookies.set(cookieBarKey, '1', '1y');\n        window.location.reload();\n        showCookieBar.value = false;\n    }\n\n    function denyCookies() {\n        cookieApi.cookies.set(cookieBarKey, '0', '1y');\n        window.location.reload();\n        showCookieBar.value = false;\n    }\n\n    return {\n        // State\n        showCookieBar: computed(() => showCookieBar.value),\n\n        // Actions\n        acceptCookies, denyCookies,\n    }\n})\n","<template>\n  <transition>\n    <div class=\"m-cookiebar\" v-if=\"cookieBarStore.showCookieBar\" ref=\"cookiebar\">\n      <div class=\"m-cookiebar__content\">\n        <p class=\"m-cookiebar__text\" v-text=\"props.text\">\n        </p>\n        <a\n          v-if=\"props.readMoreButtonLink !== ''\"\n          class=\"m-cookiebar__link\"\n          :href=\"props.readMoreButtonLink\"\n        >\n          {{ props.readMoreButtonText }}\n        </a>\n      </div>\n      <div class=\"m-cookiebar__action\">\n        <button class=\"a-btn m-cookiebar__btn-deny\" type=\"button\" @click=\"cookieBarStore.denyCookies()\">\n          {{ props.denyButtonText }}\n        </button>\n        <button class=\"a-btn m-cookiebar__btn-accept\" ref=\"acceptButton\" type=\"button\" @click=\"cookieBarStore.acceptCookies()\">\n          {{ props.acceptButtonText }}\n        </button>\n      </div>\n    </div>\n  </transition>\n  <transition>\n    <span\n      v-if=\"cookieBarStore.showCookieBar\"\n      class=\"a-overlay a-overlay--not-clickable\"\n      aria-hidden=\"true\"\n      type=\"button\"\n      ref=\"overlay\"\n    >\n    </span>\n  </transition>\n</template>\n\n<script setup lang=\"ts\">\nimport { createFocusTrap } from 'focus-trap'\nimport { useCookieBar } from '../stores/cookie-bar'\nimport { Ref, nextTick, onMounted, ref } from 'vue'\n\nconst cookieBarStore = useCookieBar()\nconst cookiebar: Ref<Element | null> = ref(null)\nconst overlay: Ref<Element | null> = ref(null)\nconst acceptButton: Ref<Element | null> = ref(null)\nconst focusTrap: Ref<any> = ref(null)\nconst props = defineProps({\n  text: {\n    type: String,\n    required: false,\n    default: 'This website uses cookies to improve your experience.',\n  },\n  acceptButtonText: {\n    type: String,\n    required: false,\n    default: 'Allow cookies',\n  },\n  denyButtonText: {\n    type: String,\n    required: false,\n    default: 'Deny cookies',\n  },\n  readMoreButtonText: {\n    type: String,\n    required: false,\n    default: 'Read more',\n  },\n  readMoreButtonLink: {\n    type: String,\n    required: false,\n    default: '',\n  },\n})\n\nonMounted(async () => {\n  nextTick(() => {\n    try {\n      focusTrap.value = createFocusTrap([cookiebar.value as HTMLDivElement, overlay.value as HTMLDivElement], {\n        initialFocus: acceptButton.value as HTMLElement,\n      }).activate()\n    } catch (e) {}\n  })\n})\n\n</script>\n","import { createPinia } from 'pinia'\nimport Notifications from '@kyvg/vue3-notification'\nimport 'virtual:svg-icons-register'\nimport { createApp } from 'vue'\nimport i18n from './i18n'\nimport 'what-input'\nimport './scss/main.scss'\n\nimport HeroSlider from './components/HeroSlider.vue'\nimport ProductHighlightSlider from './components/ProductHighlightSlider.vue'\nimport BrandSlider from './components/BrandSlider.vue'\nimport TheFooter from './components/TheFooter.vue'\nimport BaseBreadcrumbs from './components/BaseBreadcrumbs.vue'\nimport BaseNewsletter from './components/BaseNewsletter.vue'\nimport TopNotification from './components/TopNotification.vue'\nimport BaseLanguageSwitch from './components/BaseLanguageSwitch.vue'\nimport BaseSelect from './components/BaseSelect.vue'\nimport BaseActions from './components/BaseActions.vue'\nimport BaseFilters from './components/collection/BaseFilters.vue'\nimport BaseFiltersMobile from './components/collection/BaseFiltersMobile.vue'\nimport RecursiveCollectionList from './components/collection/RecursiveCollectionList.vue'\nimport ProductCard from './components/ProductCard.vue'\nimport BaseProductOverviewSortingOptions from './components/BaseProductOverviewSortingOptions.vue'\nimport BasePagination from './components/BasePagination.vue'\nimport BaseTopMenu from './components/BaseTopMenu.vue'\nimport BaseSocialIcons from './components/BaseSocialIcons.vue'\nimport BaseUsps from './components/BaseUsps.vue'\nimport BaseSearchButton from './components/BaseSearchButton.vue'\nimport BaseCartButton from './components/BaseCartButton.vue'\nimport BaseMobileUsps from './components/BaseMobileUsps.vue'\nimport BaseMainMenu from './components/BaseMainMenu.vue'\nimport BaseMobileMenu from './components/BaseMobileMenu.vue'\nimport BaseMobileMenuButton from './components/BaseMobileMenuButton.vue'\nimport BaseLogo from './components/BaseLogo.vue'\nimport BaseCartPopover from './components/BaseCartPopover.vue'\nimport BaseSearchBar from './components/BaseSearchBar.vue'\nimport ProductDetailSlider from './components/product-detail/ProductDetailSlider.vue'\nimport ProductDetailInfo from './components/product-detail/ProductDetailInfo.vue'\nimport ProductDetail from './components/product-detail/ProductDetail.vue'\nimport ArticlePreview from './components/blog/ArticlePreview.vue'\nimport BaseArticle from './components/blog/BaseArticle.vue'\nimport ArticleCallToActionBlock from './components/blog/ArticleCallToActionBlock.vue'\nimport ArticleImageTextBlock from './components/blog/ArticleImageTextBlock.vue'\nimport ArticleTitleTextBlock from './components/blog/ArticleTitleTextBlock.vue'\nimport BaseContact from './components/contact/BaseContact.vue'\nimport ShopTheLookProduct from './components/shop-the-look/ShopTheLookProduct.vue'\nimport CollectionOverviewEvent from './components/CollectionOverviewEvent.vue'\nimport BaseCookieBar from './components/BaseCookieBar.vue'\n\nimport BaseShipmentSelect from './components/checkout/BaseShipmentSelect.vue'\nimport BaseCheckout from './components/checkout/BaseCheckout.vue'\nimport BaseCart from './components/checkout/BaseCart.vue'\n\nconst pinia = createPinia()\n\nconst app = createApp({}, {})\n\napp.use(pinia)\napp.use(Notifications)\napp.use(i18n)\n\n// Cart page components.\napp.component('base-shipment-select', BaseShipmentSelect)\napp.component('base-checkout', BaseCheckout)\napp.component('base-cart', BaseCart)\n\napp.component('base-notificatons', Notifications)\napp.component('hero-slider', HeroSlider)\napp.component('product-highlight-slider', ProductHighlightSlider)\napp.component('brand-slider', BrandSlider)\napp.component('the-footer', TheFooter)\n\napp.component('base-breadcrumbs', BaseBreadcrumbs)\napp.component('base-newsletter', BaseNewsletter)\napp.component('top-notification', TopNotification)\napp.component('newsletter-translation', BaseNewsletter)\n\napp.component('base-select', BaseSelect)\napp.component('base-actions', BaseActions)\n\napp.component('product-card', ProductCard)\n\napp.component('base-filters', BaseFilters)\napp.component('base-filters-mobile', BaseFiltersMobile)\n\napp.component('collection-overview-event', CollectionOverviewEvent)\n// Category\napp.component('recursive-collection-list', RecursiveCollectionList)\n\napp.component('base-product-overview-sorting-options', BaseProductOverviewSortingOptions)\napp.component('base-pagination', BasePagination)\n\n// Header components\napp.component('base-top-menu', BaseTopMenu)\napp.component('base-social-icons', BaseSocialIcons)\napp.component('base-usps', BaseUsps)\napp.component('base-search-button', BaseSearchButton)\napp.component('base-cart-button', BaseCartButton)\napp.component('base-mobile-usps', BaseMobileUsps)\napp.component('base-main-menu', BaseMainMenu)\napp.component('base-mobile-menu', BaseMobileMenu)\napp.component('base-mobile-menu-button', BaseMobileMenuButton)\napp.component('base-logo', BaseLogo)\n\n// Cart\napp.component('base-cart-popover', BaseCartPopover)\n\n// Search\napp.component('base-search-bar', BaseSearchBar)\n\n// Cookie bar\napp.component('base-cookie-bar', BaseCookieBar)\n\n// Blog\napp.component('article-preview', ArticlePreview)\napp.component('base-article', BaseArticle)\napp.component('article-call-to-action-block', ArticleCallToActionBlock)\napp.component('article-image-text-block', ArticleImageTextBlock)\napp.component('article-title-text-block', ArticleTitleTextBlock)\n\n// Contact\napp.component('base-contact', BaseContact)\n\n// Product detail components\napp.component('product-detail-slider', ProductDetailSlider)\napp.component('product-detail-info', ProductDetailInfo)\napp.component('product-detail', ProductDetail)\n\n// Shop the look\napp.component('shop-the-look-product', ShopTheLookProduct)\n\napp.component('base-language-switch', BaseLanguageSwitch)\napp.mount('#app')\n"],"file":"public/index.b447668c.js"}