{"version":3,"file":"static/chunks/719-a6eef023d467f198.js","mappings":"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","sources":["webpack://_N_E/./node_modules/swiper/components-shared/utils.js","webpack://_N_E/./node_modules/swiper/components-shared/params-list.js","webpack://_N_E/./node_modules/swiper/components-shared/get-params.js","webpack://_N_E/./node_modules/swiper/components-shared/mount-swiper.js","webpack://_N_E/./node_modules/swiper/shared/calc-looped-slides.js","webpack://_N_E/./node_modules/swiper/react/loop.js","webpack://_N_E/./node_modules/swiper/components-shared/get-changed-params.js","webpack://_N_E/./node_modules/swiper/react/get-children.js","webpack://_N_E/./node_modules/swiper/components-shared/update-swiper.js","webpack://_N_E/./node_modules/swiper/react/virtual.js","webpack://_N_E/./node_modules/swiper/components-shared/update-on-virtual-data.js","webpack://_N_E/./node_modules/swiper/react/use-isomorphic-layout-effect.js","webpack://_N_E/./node_modules/swiper/react/context.js","webpack://_N_E/./node_modules/swiper/react/swiper.js","webpack://_N_E/./node_modules/swiper/react/swiper-slide.js","webpack://_N_E/./node_modules/swiper/react/swiper-react.js","webpack://_N_E/./node_modules/ssr-window/ssr-window.esm.js","webpack://_N_E/./node_modules/dom7/dom7.esm.js","webpack://_N_E/./node_modules/swiper/shared/dom.js","webpack://_N_E/./node_modules/swiper/shared/utils.js","webpack://_N_E/./node_modules/swiper/shared/get-support.js","webpack://_N_E/./node_modules/swiper/shared/get-device.js","webpack://_N_E/./node_modules/swiper/shared/get-browser.js","webpack://_N_E/./node_modules/swiper/core/modules/resize/resize.js","webpack://_N_E/./node_modules/swiper/core/modules/observer/observer.js","webpack://_N_E/./node_modules/swiper/core/events-emitter.js","webpack://_N_E/./node_modules/swiper/core/update/updateSize.js","webpack://_N_E/./node_modules/swiper/core/update/updateSlides.js","webpack://_N_E/./node_modules/swiper/core/update/updateAutoHeight.js","webpack://_N_E/./node_modules/swiper/core/update/updateSlidesOffset.js","webpack://_N_E/./node_modules/swiper/core/update/updateSlidesProgress.js","webpack://_N_E/./node_modules/swiper/core/update/updateProgress.js","webpack://_N_E/./node_modules/swiper/core/update/updateSlidesClasses.js","webpack://_N_E/./node_modules/swiper/core/update/updateActiveIndex.js","webpack://_N_E/./node_modules/swiper/core/update/updateClickedSlide.js","webpack://_N_E/./node_modules/swiper/core/update/index.js","webpack://_N_E/./node_modules/swiper/core/translate/getTranslate.js","webpack://_N_E/./node_modules/swiper/core/translate/setTranslate.js","webpack://_N_E/./node_modules/swiper/core/translate/minTranslate.js","webpack://_N_E/./node_modules/swiper/core/translate/maxTranslate.js","webpack://_N_E/./node_modules/swiper/core/translate/translateTo.js","webpack://_N_E/./node_modules/swiper/core/translate/index.js","webpack://_N_E/./node_modules/swiper/core/transition/setTransition.js","webpack://_N_E/./node_modules/swiper/core/transition/transitionEmit.js","webpack://_N_E/./node_modules/swiper/core/transition/transitionStart.js","webpack://_N_E/./node_modules/swiper/core/transition/transitionEnd.js","webpack://_N_E/./node_modules/swiper/core/transition/index.js","webpack://_N_E/./node_modules/swiper/core/slide/slideTo.js","webpack://_N_E/./node_modules/swiper/core/slide/slideToLoop.js","webpack://_N_E/./node_modules/swiper/core/slide/slideNext.js","webpack://_N_E/./node_modules/swiper/core/slide/slidePrev.js","webpack://_N_E/./node_modules/swiper/core/slide/slideReset.js","webpack://_N_E/./node_modules/swiper/core/slide/slideToClosest.js","webpack://_N_E/./node_modules/swiper/core/slide/slideToClickedSlide.js","webpack://_N_E/./node_modules/swiper/core/slide/index.js","webpack://_N_E/./node_modules/swiper/core/loop/loopCreate.js","webpack://_N_E/./node_modules/swiper/core/loop/loopFix.js","webpack://_N_E/./node_modules/swiper/core/loop/loopDestroy.js","webpack://_N_E/./node_modules/swiper/core/loop/index.js","webpack://_N_E/./node_modules/swiper/core/grab-cursor/setGrabCursor.js","webpack://_N_E/./node_modules/swiper/core/grab-cursor/unsetGrabCursor.js","webpack://_N_E/./node_modules/swiper/core/grab-cursor/index.js","webpack://_N_E/./node_modules/swiper/core/events/onTouchStart.js","webpack://_N_E/./node_modules/swiper/core/events/onTouchMove.js","webpack://_N_E/./node_modules/swiper/core/events/onTouchEnd.js","webpack://_N_E/./node_modules/swiper/core/events/onResize.js","webpack://_N_E/./node_modules/swiper/core/events/onClick.js","webpack://_N_E/./node_modules/swiper/core/events/onScroll.js","webpack://_N_E/./node_modules/swiper/core/events/index.js","webpack://_N_E/./node_modules/swiper/core/breakpoints/setBreakpoint.js","webpack://_N_E/./node_modules/swiper/core/breakpoints/getBreakpoint.js","webpack://_N_E/./node_modules/swiper/core/breakpoints/index.js","webpack://_N_E/./node_modules/swiper/core/classes/addClasses.js","webpack://_N_E/./node_modules/swiper/core/classes/removeClasses.js","webpack://_N_E/./node_modules/swiper/core/classes/index.js","webpack://_N_E/./node_modules/swiper/core/images/loadImage.js","webpack://_N_E/./node_modules/swiper/core/images/preloadImages.js","webpack://_N_E/./node_modules/swiper/core/images/index.js","webpack://_N_E/./node_modules/swiper/core/check-overflow/index.js","webpack://_N_E/./node_modules/swiper/core/defaults.js","webpack://_N_E/./node_modules/swiper/core/moduleExtendParams.js","webpack://_N_E/./node_modules/swiper/core/core.js","webpack://_N_E/./node_modules/swiper/modules/virtual/virtual.js","webpack://_N_E/./node_modules/swiper/modules/keyboard/keyboard.js","webpack://_N_E/./node_modules/swiper/modules/mousewheel/mousewheel.js","webpack://_N_E/./node_modules/swiper/shared/create-element-if-not-defined.js","webpack://_N_E/./node_modules/swiper/modules/navigation/navigation.js","webpack://_N_E/./node_modules/swiper/shared/classes-to-selector.js","webpack://_N_E/./node_modules/swiper/modules/pagination/pagination.js","webpack://_N_E/./node_modules/swiper/modules/scrollbar/scrollbar.js","webpack://_N_E/./node_modules/swiper/modules/parallax/parallax.js","webpack://_N_E/./node_modules/swiper/modules/zoom/zoom.js","webpack://_N_E/./node_modules/swiper/modules/lazy/lazy.js","webpack://_N_E/./node_modules/swiper/modules/controller/controller.js","webpack://_N_E/./node_modules/swiper/modules/a11y/a11y.js","webpack://_N_E/./node_modules/swiper/modules/history/history.js","webpack://_N_E/./node_modules/swiper/modules/hash-navigation/hash-navigation.js","webpack://_N_E/./node_modules/swiper/modules/autoplay/autoplay.js","webpack://_N_E/./node_modules/swiper/modules/thumbs/thumbs.js","webpack://_N_E/./node_modules/swiper/modules/free-mode/free-mode.js","webpack://_N_E/./node_modules/swiper/modules/effect-cube/effect-cube.js","webpack://_N_E/./node_modules/swiper/shared/create-shadow.js","webpack://_N_E/./node_modules/swiper/modules/effect-flip/effect-flip.js","webpack://_N_E/./node_modules/swiper/modules/effect-coverflow/effect-coverflow.js","webpack://_N_E/./node_modules/swiper/modules/effect-creative/effect-creative.js","webpack://_N_E/./node_modules/swiper/modules/effect-cards/effect-cards.js","webpack://_N_E/./node_modules/swiper/swiper.esm.js","webpack://_N_E/"],"sourcesContent":["function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction extend(target, src) {\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n Object.keys(src).filter(key => noExtend.indexOf(key) < 0).forEach(key => {\n if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject(src[key]) && isObject(target[key]) && Object.keys(src[key]).length > 0) {\n if (src[key].__swiper__) target[key] = src[key];else extend(target[key], src[key]);\n } else {\n target[key] = src[key];\n }\n });\n}\n\nfunction needsNavigation(params = {}) {\n return params.navigation && typeof params.navigation.nextEl === 'undefined' && typeof params.navigation.prevEl === 'undefined';\n}\n\nfunction needsPagination(params = {}) {\n return params.pagination && typeof params.pagination.el === 'undefined';\n}\n\nfunction needsScrollbar(params = {}) {\n return params.scrollbar && typeof params.scrollbar.el === 'undefined';\n}\n\nfunction uniqueClasses(classNames = '') {\n const classes = classNames.split(' ').map(c => c.trim()).filter(c => !!c);\n const unique = [];\n classes.forEach(c => {\n if (unique.indexOf(c) < 0) unique.push(c);\n });\n return unique.join(' ');\n}\n\nexport { isObject, extend, needsNavigation, needsPagination, needsScrollbar, uniqueClasses };","/* underscore in name -> watch for changes */\nconst paramsList = ['modules', 'init', '_direction', 'touchEventsTarget', 'initialSlide', '_speed', 'cssMode', 'updateOnWindowResize', 'resizeObserver', 'nested', 'focusableElements', '_enabled', '_width', '_height', 'preventInteractionOnTransition', 'userAgent', 'url', '_edgeSwipeDetection', '_edgeSwipeThreshold', '_freeMode', '_autoHeight', 'setWrapperSize', 'virtualTranslate', '_effect', 'breakpoints', '_spaceBetween', '_slidesPerView', 'maxBackfaceHiddenSlides', '_grid', '_slidesPerGroup', '_slidesPerGroupSkip', '_slidesPerGroupAuto', '_centeredSlides', '_centeredSlidesBounds', '_slidesOffsetBefore', '_slidesOffsetAfter', 'normalizeSlideIndex', '_centerInsufficientSlides', '_watchOverflow', 'roundLengths', 'touchRatio', 'touchAngle', 'simulateTouch', '_shortSwipes', '_longSwipes', 'longSwipesRatio', 'longSwipesMs', '_followFinger', 'allowTouchMove', '_threshold', 'touchMoveStopPropagation', 'touchStartPreventDefault', 'touchStartForcePreventDefault', 'touchReleaseOnEdges', 'uniqueNavElements', '_resistance', '_resistanceRatio', '_watchSlidesProgress', '_grabCursor', 'preventClicks', 'preventClicksPropagation', '_slideToClickedSlide', '_preloadImages', 'updateOnImagesReady', '_loop', '_loopAdditionalSlides', '_loopedSlides', '_loopedSlidesLimit', '_loopFillGroupWithBlank', 'loopPreventsSlide', '_rewind', '_allowSlidePrev', '_allowSlideNext', '_swipeHandler', '_noSwiping', 'noSwipingClass', 'noSwipingSelector', 'passiveListeners', 'containerModifierClass', 'slideClass', 'slideBlankClass', 'slideActiveClass', 'slideDuplicateActiveClass', 'slideVisibleClass', 'slideDuplicateClass', 'slideNextClass', 'slideDuplicateNextClass', 'slidePrevClass', 'slideDuplicatePrevClass', 'wrapperClass', 'runCallbacksOnInit', 'observer', 'observeParents', 'observeSlideChildren', // modules\n'a11y', '_autoplay', '_controller', 'coverflowEffect', 'cubeEffect', 'fadeEffect', 'flipEffect', 'creativeEffect', 'cardsEffect', 'hashNavigation', 'history', 'keyboard', 'lazy', 'mousewheel', '_navigation', '_pagination', 'parallax', '_scrollbar', '_thumbs', 'virtual', 'zoom'];\nexport { paramsList };","import Swiper from 'swiper';\nimport { isObject, extend } from './utils.js';\nimport { paramsList } from './params-list.js';\n\nfunction getParams(obj = {}, splitEvents = true) {\n const params = {\n on: {}\n };\n const events = {};\n const passedParams = {};\n extend(params, Swiper.defaults);\n extend(params, Swiper.extendedDefaults);\n params._emitClasses = true;\n params.init = false;\n const rest = {};\n const allowedParams = paramsList.map(key => key.replace(/_/, ''));\n const plainObj = Object.assign({}, obj);\n Object.keys(plainObj).forEach(key => {\n if (typeof obj[key] === 'undefined') return;\n\n if (allowedParams.indexOf(key) >= 0) {\n if (isObject(obj[key])) {\n params[key] = {};\n passedParams[key] = {};\n extend(params[key], obj[key]);\n extend(passedParams[key], obj[key]);\n } else {\n params[key] = obj[key];\n passedParams[key] = obj[key];\n }\n } else if (key.search(/on[A-Z]/) === 0 && typeof obj[key] === 'function') {\n if (splitEvents) {\n events[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n } else {\n params.on[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n }\n } else {\n rest[key] = obj[key];\n }\n });\n ['navigation', 'pagination', 'scrollbar'].forEach(key => {\n if (params[key] === true) params[key] = {};\n if (params[key] === false) delete params[key];\n });\n return {\n params,\n passedParams,\n rest,\n events\n };\n}\n\nexport { getParams };","import { needsNavigation, needsPagination, needsScrollbar } from './utils.js';\n\nfunction mountSwiper({\n el,\n nextEl,\n prevEl,\n paginationEl,\n scrollbarEl,\n swiper\n}, swiperParams) {\n if (needsNavigation(swiperParams) && nextEl && prevEl) {\n swiper.params.navigation.nextEl = nextEl;\n swiper.originalParams.navigation.nextEl = nextEl;\n swiper.params.navigation.prevEl = prevEl;\n swiper.originalParams.navigation.prevEl = prevEl;\n }\n\n if (needsPagination(swiperParams) && paginationEl) {\n swiper.params.pagination.el = paginationEl;\n swiper.originalParams.pagination.el = paginationEl;\n }\n\n if (needsScrollbar(swiperParams) && scrollbarEl) {\n swiper.params.scrollbar.el = scrollbarEl;\n swiper.originalParams.scrollbar.el = scrollbarEl;\n }\n\n swiper.init(el);\n}\n\nexport { mountSwiper };","import Swiper from 'swiper';\nexport const calcLoopedSlides = (slides, swiperParams) => {\n let slidesPerViewParams = swiperParams.slidesPerView;\n\n if (swiperParams.breakpoints) {\n const breakpoint = Swiper.prototype.getBreakpoint(swiperParams.breakpoints);\n const breakpointOnlyParams = breakpoint in swiperParams.breakpoints ? swiperParams.breakpoints[breakpoint] : undefined;\n\n if (breakpointOnlyParams && breakpointOnlyParams.slidesPerView) {\n slidesPerViewParams = breakpointOnlyParams.slidesPerView;\n }\n }\n\n let loopedSlides = Math.ceil(parseFloat(swiperParams.loopedSlides || slidesPerViewParams, 10));\n loopedSlides += swiperParams.loopAdditionalSlides;\n\n if (loopedSlides > slides.length && swiperParams.loopedSlidesLimit) {\n loopedSlides = slides.length;\n }\n\n return loopedSlides;\n};","import React from 'react';\nimport { calcLoopedSlides } from '../shared/calc-looped-slides.js';\n\nfunction renderLoop(swiper, slides, swiperParams) {\n const modifiedSlides = slides.map((child, index) => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n 'data-swiper-slide-index': index\n });\n });\n\n function duplicateSlide(child, index, position) {\n return /*#__PURE__*/React.cloneElement(child, {\n key: `${child.key}-duplicate-${index}-${position}`,\n className: `${child.props.className || ''} ${swiperParams.slideDuplicateClass}`\n });\n }\n\n if (swiperParams.loopFillGroupWithBlank) {\n const blankSlidesNum = swiperParams.slidesPerGroup - modifiedSlides.length % swiperParams.slidesPerGroup;\n\n if (blankSlidesNum !== swiperParams.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankSlide = /*#__PURE__*/React.createElement(\"div\", {\n className: `${swiperParams.slideClass} ${swiperParams.slideBlankClass}`\n });\n modifiedSlides.push(blankSlide);\n }\n }\n }\n\n if (swiperParams.slidesPerView === 'auto' && !swiperParams.loopedSlides) {\n swiperParams.loopedSlides = modifiedSlides.length;\n }\n\n const loopedSlides = calcLoopedSlides(modifiedSlides, swiperParams);\n const prependSlides = [];\n const appendSlides = [];\n\n for (let i = 0; i < loopedSlides; i += 1) {\n const index = i - Math.floor(i / modifiedSlides.length) * modifiedSlides.length;\n appendSlides.push(duplicateSlide(modifiedSlides[index], i, 'append'));\n prependSlides.unshift(duplicateSlide(modifiedSlides[modifiedSlides.length - index - 1], i, 'prepend'));\n }\n\n if (swiper) {\n swiper.loopedSlides = loopedSlides;\n }\n\n return [...prependSlides, ...modifiedSlides, ...appendSlides];\n}\n\nexport { calcLoopedSlides, renderLoop };","import { paramsList } from './params-list.js';\nimport { isObject } from './utils.js';\n\nfunction getChangedParams(swiperParams, oldParams, children, oldChildren, getKey) {\n const keys = [];\n if (!oldParams) return keys;\n\n const addKey = key => {\n if (keys.indexOf(key) < 0) keys.push(key);\n };\n\n if (children && oldChildren) {\n const oldChildrenKeys = oldChildren.map(getKey);\n const childrenKeys = children.map(getKey);\n if (oldChildrenKeys.join('') !== childrenKeys.join('')) addKey('children');\n if (oldChildren.length !== children.length) addKey('children');\n }\n\n const watchParams = paramsList.filter(key => key[0] === '_').map(key => key.replace(/_/, ''));\n watchParams.forEach(key => {\n if (key in swiperParams && key in oldParams) {\n if (isObject(swiperParams[key]) && isObject(oldParams[key])) {\n const newKeys = Object.keys(swiperParams[key]);\n const oldKeys = Object.keys(oldParams[key]);\n\n if (newKeys.length !== oldKeys.length) {\n addKey(key);\n } else {\n newKeys.forEach(newKey => {\n if (swiperParams[key][newKey] !== oldParams[key][newKey]) {\n addKey(key);\n }\n });\n oldKeys.forEach(oldKey => {\n if (swiperParams[key][oldKey] !== oldParams[key][oldKey]) addKey(key);\n });\n }\n } else if (swiperParams[key] !== oldParams[key]) {\n addKey(key);\n }\n }\n });\n return keys;\n}\n\nexport { getChangedParams };","import React from 'react';\n\nfunction isChildSwiperSlide(child) {\n return child.type && child.type.displayName && child.type.displayName.includes('SwiperSlide');\n}\n\nfunction processChildren(c) {\n const slides = [];\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.children) {\n processChildren(child.props.children).forEach(slide => slides.push(slide));\n }\n });\n return slides;\n}\n\nfunction getChildren(c) {\n const slides = [];\n const slots = {\n 'container-start': [],\n 'container-end': [],\n 'wrapper-start': [],\n 'wrapper-end': []\n };\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.slot && slots[child.props.slot]) {\n slots[child.props.slot].push(child);\n } else if (child.props && child.props.children) {\n const foundSlides = processChildren(child.props.children);\n\n if (foundSlides.length > 0) {\n foundSlides.forEach(slide => slides.push(slide));\n } else {\n slots['container-end'].push(child);\n }\n } else {\n slots['container-end'].push(child);\n }\n });\n return {\n slides,\n slots\n };\n}\n\nexport { getChildren };","import { isObject, extend } from './utils.js';\n\nfunction updateSwiper({\n swiper,\n slides,\n passedParams,\n changedParams,\n nextEl,\n prevEl,\n scrollbarEl,\n paginationEl\n}) {\n const updateParams = changedParams.filter(key => key !== 'children' && key !== 'direction');\n const {\n params: currentParams,\n pagination,\n navigation,\n scrollbar,\n virtual,\n thumbs\n } = swiper;\n let needThumbsInit;\n let needControllerInit;\n let needPaginationInit;\n let needScrollbarInit;\n let needNavigationInit;\n\n if (changedParams.includes('thumbs') && passedParams.thumbs && passedParams.thumbs.swiper && currentParams.thumbs && !currentParams.thumbs.swiper) {\n needThumbsInit = true;\n }\n\n if (changedParams.includes('controller') && passedParams.controller && passedParams.controller.control && currentParams.controller && !currentParams.controller.control) {\n needControllerInit = true;\n }\n\n if (changedParams.includes('pagination') && passedParams.pagination && (passedParams.pagination.el || paginationEl) && (currentParams.pagination || currentParams.pagination === false) && pagination && !pagination.el) {\n needPaginationInit = true;\n }\n\n if (changedParams.includes('scrollbar') && passedParams.scrollbar && (passedParams.scrollbar.el || scrollbarEl) && (currentParams.scrollbar || currentParams.scrollbar === false) && scrollbar && !scrollbar.el) {\n needScrollbarInit = true;\n }\n\n if (changedParams.includes('navigation') && passedParams.navigation && (passedParams.navigation.prevEl || prevEl) && (passedParams.navigation.nextEl || nextEl) && (currentParams.navigation || currentParams.navigation === false) && navigation && !navigation.prevEl && !navigation.nextEl) {\n needNavigationInit = true;\n }\n\n const destroyModule = mod => {\n if (!swiper[mod]) return;\n swiper[mod].destroy();\n\n if (mod === 'navigation') {\n currentParams[mod].prevEl = undefined;\n currentParams[mod].nextEl = undefined;\n swiper[mod].prevEl = undefined;\n swiper[mod].nextEl = undefined;\n } else {\n currentParams[mod].el = undefined;\n swiper[mod].el = undefined;\n }\n };\n\n updateParams.forEach(key => {\n if (isObject(currentParams[key]) && isObject(passedParams[key])) {\n extend(currentParams[key], passedParams[key]);\n } else {\n const newValue = passedParams[key];\n\n if ((newValue === true || newValue === false) && (key === 'navigation' || key === 'pagination' || key === 'scrollbar')) {\n if (newValue === false) {\n destroyModule(key);\n }\n } else {\n currentParams[key] = passedParams[key];\n }\n }\n });\n\n if (updateParams.includes('controller') && !needControllerInit && swiper.controller && swiper.controller.control && currentParams.controller && currentParams.controller.control) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (changedParams.includes('children') && slides && virtual && currentParams.virtual.enabled) {\n virtual.slides = slides;\n virtual.update(true);\n } else if (changedParams.includes('children') && swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (needThumbsInit) {\n const initialized = thumbs.init();\n if (initialized) thumbs.update(true);\n }\n\n if (needControllerInit) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (needPaginationInit) {\n if (paginationEl) currentParams.pagination.el = paginationEl;\n pagination.init();\n pagination.render();\n pagination.update();\n }\n\n if (needScrollbarInit) {\n if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;\n scrollbar.init();\n scrollbar.updateSize();\n scrollbar.setTranslate();\n }\n\n if (needNavigationInit) {\n if (nextEl) currentParams.navigation.nextEl = nextEl;\n if (prevEl) currentParams.navigation.prevEl = prevEl;\n navigation.init();\n navigation.update();\n }\n\n if (changedParams.includes('allowSlideNext')) {\n swiper.allowSlideNext = passedParams.allowSlideNext;\n }\n\n if (changedParams.includes('allowSlidePrev')) {\n swiper.allowSlidePrev = passedParams.allowSlidePrev;\n }\n\n if (changedParams.includes('direction')) {\n swiper.changeDirection(passedParams.direction, false);\n }\n\n swiper.update();\n}\n\nexport { updateSwiper };","import React from 'react';\n\nfunction renderVirtual(swiper, slides, virtualData) {\n if (!virtualData) return null;\n const style = swiper.isHorizontal() ? {\n [swiper.rtlTranslate ? 'right' : 'left']: `${virtualData.offset}px`\n } : {\n top: `${virtualData.offset}px`\n };\n return slides.filter((child, index) => index >= virtualData.from && index <= virtualData.to).map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n style\n });\n });\n}\n\nexport { renderVirtual };","export const updateOnVirtualData = swiper => {\n if (!swiper || swiper.destroyed || !swiper.params.virtual || swiper.params.virtual && !swiper.params.virtual.enabled) return;\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (swiper.parallax && swiper.params.parallax && swiper.params.parallax.enabled) {\n swiper.parallax.setTranslate();\n }\n};","import { useEffect, useLayoutEffect } from 'react';\n\nfunction useIsomorphicLayoutEffect(callback, deps) {\n // eslint-disable-next-line\n if (typeof window === 'undefined') return useEffect(callback, deps);\n return useLayoutEffect(callback, deps);\n}\n\nexport { useIsomorphicLayoutEffect };","import { createContext, useContext } from 'react';\nexport const SwiperSlideContext = /*#__PURE__*/createContext(null);\nexport const useSwiperSlide = () => {\n return useContext(SwiperSlideContext);\n};\nexport const SwiperContext = /*#__PURE__*/createContext(null);\nexport const useSwiper = () => {\n return useContext(SwiperContext);\n};","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, useEffect, forwardRef } from 'react';\nimport SwiperCore from 'swiper';\nimport { getParams } from '../components-shared/get-params.js';\nimport { mountSwiper } from '../components-shared/mount-swiper.js';\nimport { needsScrollbar, needsNavigation, needsPagination, uniqueClasses, extend } from '../components-shared/utils.js';\nimport { renderLoop, calcLoopedSlides } from './loop.js';\nimport { getChangedParams } from '../components-shared/get-changed-params.js';\nimport { getChildren } from './get-children.js';\nimport { updateSwiper } from '../components-shared/update-swiper.js';\nimport { renderVirtual } from './virtual.js';\nimport { updateOnVirtualData } from '../components-shared/update-on-virtual-data.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperContext } from './context.js';\nconst Swiper = /*#__PURE__*/forwardRef(function (_temp, externalElRef) {\n let {\n className,\n tag: Tag = 'div',\n wrapperTag: WrapperTag = 'div',\n children,\n onSwiper,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n let eventsAssigned = false;\n const [containerClasses, setContainerClasses] = useState('swiper');\n const [virtualData, setVirtualData] = useState(null);\n const [breakpointChanged, setBreakpointChanged] = useState(false);\n const initializedRef = useRef(false);\n const swiperElRef = useRef(null);\n const swiperRef = useRef(null);\n const oldPassedParamsRef = useRef(null);\n const oldSlides = useRef(null);\n const nextElRef = useRef(null);\n const prevElRef = useRef(null);\n const paginationElRef = useRef(null);\n const scrollbarElRef = useRef(null);\n const {\n params: swiperParams,\n passedParams,\n rest: restProps,\n events\n } = getParams(rest);\n const {\n slides,\n slots\n } = getChildren(children);\n\n const onBeforeBreakpoint = () => {\n setBreakpointChanged(!breakpointChanged);\n };\n\n Object.assign(swiperParams.on, {\n _containerClasses(swiper, classes) {\n setContainerClasses(classes);\n }\n\n });\n\n const initSwiper = () => {\n // init swiper\n Object.assign(swiperParams.on, events);\n eventsAssigned = true;\n swiperRef.current = new SwiperCore(swiperParams);\n\n swiperRef.current.loopCreate = () => {};\n\n swiperRef.current.loopDestroy = () => {};\n\n if (swiperParams.loop) {\n swiperRef.current.loopedSlides = calcLoopedSlides(slides, swiperParams);\n }\n\n if (swiperRef.current.virtual && swiperRef.current.params.virtual.enabled) {\n swiperRef.current.virtual.slides = slides;\n const extendWith = {\n cache: false,\n slides,\n renderExternal: setVirtualData,\n renderExternalUpdate: false\n };\n extend(swiperRef.current.params.virtual, extendWith);\n extend(swiperRef.current.originalParams.virtual, extendWith);\n }\n };\n\n if (!swiperElRef.current) {\n initSwiper();\n } // Listen for breakpoints change\n\n\n if (swiperRef.current) {\n swiperRef.current.on('_beforeBreakpoint', onBeforeBreakpoint);\n }\n\n const attachEvents = () => {\n if (eventsAssigned || !events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.on(eventName, events[eventName]);\n });\n };\n\n const detachEvents = () => {\n if (!events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.off(eventName, events[eventName]);\n });\n };\n\n useEffect(() => {\n return () => {\n if (swiperRef.current) swiperRef.current.off('_beforeBreakpoint', onBeforeBreakpoint);\n };\n }); // set initialized flag\n\n useEffect(() => {\n if (!initializedRef.current && swiperRef.current) {\n swiperRef.current.emitSlidesClasses();\n initializedRef.current = true;\n }\n }); // mount swiper\n\n useIsomorphicLayoutEffect(() => {\n if (externalElRef) {\n externalElRef.current = swiperElRef.current;\n }\n\n if (!swiperElRef.current) return;\n\n if (swiperRef.current.destroyed) {\n initSwiper();\n }\n\n mountSwiper({\n el: swiperElRef.current,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n paginationEl: paginationElRef.current,\n scrollbarEl: scrollbarElRef.current,\n swiper: swiperRef.current\n }, swiperParams);\n if (onSwiper) onSwiper(swiperRef.current); // eslint-disable-next-line\n\n return () => {\n if (swiperRef.current && !swiperRef.current.destroyed) {\n swiperRef.current.destroy(true, false);\n }\n };\n }, []); // watch for params change\n\n useIsomorphicLayoutEffect(() => {\n attachEvents();\n const changedParams = getChangedParams(passedParams, oldPassedParamsRef.current, slides, oldSlides.current, c => c.key);\n oldPassedParamsRef.current = passedParams;\n oldSlides.current = slides;\n\n if (changedParams.length && swiperRef.current && !swiperRef.current.destroyed) {\n updateSwiper({\n swiper: swiperRef.current,\n slides,\n passedParams,\n changedParams,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n scrollbarEl: scrollbarElRef.current,\n paginationEl: paginationElRef.current\n });\n }\n\n return () => {\n detachEvents();\n };\n }); // update on virtual update\n\n useIsomorphicLayoutEffect(() => {\n updateOnVirtualData(swiperRef.current);\n }, [virtualData]); // bypass swiper instance to slides\n\n function renderSlides() {\n if (swiperParams.virtual) {\n return renderVirtual(swiperRef.current, slides, virtualData);\n }\n\n if (!swiperParams.loop || swiperRef.current && swiperRef.current.destroyed) {\n return slides.map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper: swiperRef.current\n });\n });\n }\n\n return renderLoop(swiperRef.current, slides, swiperParams);\n }\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: swiperElRef,\n className: uniqueClasses(`${containerClasses}${className ? ` ${className}` : ''}`)\n }, restProps), /*#__PURE__*/React.createElement(SwiperContext.Provider, {\n value: swiperRef.current\n }, slots['container-start'], /*#__PURE__*/React.createElement(WrapperTag, {\n className: \"swiper-wrapper\"\n }, slots['wrapper-start'], renderSlides(), slots['wrapper-end']), needsNavigation(swiperParams) && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"div\", {\n ref: prevElRef,\n className: \"swiper-button-prev\"\n }), /*#__PURE__*/React.createElement(\"div\", {\n ref: nextElRef,\n className: \"swiper-button-next\"\n })), needsScrollbar(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: scrollbarElRef,\n className: \"swiper-scrollbar\"\n }), needsPagination(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: paginationElRef,\n className: \"swiper-pagination\"\n }), slots['container-end']));\n});\nSwiper.displayName = 'Swiper';\nexport { Swiper };","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, forwardRef } from 'react';\nimport { uniqueClasses } from '../components-shared/utils.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperSlideContext } from './context.js';\nconst SwiperSlide = /*#__PURE__*/forwardRef(function (_temp, externalRef) {\n let {\n tag: Tag = 'div',\n children,\n className = '',\n swiper,\n zoom,\n virtualIndex,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n const slideElRef = useRef(null);\n const [slideClasses, setSlideClasses] = useState('swiper-slide');\n\n function updateClasses(_s, el, classNames) {\n if (el === slideElRef.current) {\n setSlideClasses(classNames);\n }\n }\n\n useIsomorphicLayoutEffect(() => {\n if (externalRef) {\n externalRef.current = slideElRef.current;\n }\n\n if (!slideElRef.current || !swiper) {\n return;\n }\n\n if (swiper.destroyed) {\n if (slideClasses !== 'swiper-slide') {\n setSlideClasses('swiper-slide');\n }\n\n return;\n }\n\n swiper.on('_slideClass', updateClasses); // eslint-disable-next-line\n\n return () => {\n if (!swiper) return;\n swiper.off('_slideClass', updateClasses);\n };\n });\n useIsomorphicLayoutEffect(() => {\n if (swiper && slideElRef.current && !swiper.destroyed) {\n setSlideClasses(swiper.getSlideClasses(slideElRef.current));\n }\n }, [swiper]);\n const slideData = {\n isActive: slideClasses.indexOf('swiper-slide-active') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-active') >= 0,\n isVisible: slideClasses.indexOf('swiper-slide-visible') >= 0,\n isDuplicate: slideClasses.indexOf('swiper-slide-duplicate') >= 0,\n isPrev: slideClasses.indexOf('swiper-slide-prev') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-prev') >= 0,\n isNext: slideClasses.indexOf('swiper-slide-next') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-next') >= 0\n };\n\n const renderChildren = () => {\n return typeof children === 'function' ? children(slideData) : children;\n };\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: slideElRef,\n className: uniqueClasses(`${slideClasses}${className ? ` ${className}` : ''}`),\n \"data-swiper-slide-index\": virtualIndex\n }, rest), /*#__PURE__*/React.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, zoom ? /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-zoom-container\",\n \"data-swiper-zoom\": typeof zoom === 'number' ? zoom : undefined\n }, renderChildren()) : renderChildren()));\n});\nSwiperSlide.displayName = 'SwiperSlide';\nexport { SwiperSlide };","/**\n * Swiper React 8.4.6\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2023 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: January 17, 2023\n */\n\nimport { Swiper } from './swiper.js';\nimport { SwiperSlide } from './swiper-slide.js';\nexport { useSwiperSlide, useSwiper } from './context.js';\nexport { Swiper, SwiperSlide };","/**\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.6\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2023, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: February 2, 2023\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(' 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 transitionStart(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionstart', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionstart', fireCallBack);\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, transitionStart, 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 $ from '../../shared/dom.js';\nimport { setCSSProperty } from '../../shared/utils.js';\nexport default function Virtual({\n swiper,\n extendParams,\n on,\n emit\n}) {\n extendParams({\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n renderExternalUpdate: true,\n addSlidesBefore: 0,\n addSlidesAfter: 0\n }\n });\n let cssModeTimeout;\n swiper.virtual = {\n cache: {},\n from: undefined,\n to: undefined,\n slides: [],\n offset: 0,\n slidesGrid: []\n };\n\n function renderSlide(slide, index) {\n const params = swiper.params.virtual;\n\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n\n const $slideEl = params.renderSlide ? $(params.renderSlide.call(swiper, slide, index)) : $(`
${slide}
`);\n if (!$slideEl.attr('data-swiper-slide-index')) $slideEl.attr('data-swiper-slide-index', index);\n if (params.cache) swiper.virtual.cache[index] = $slideEl;\n return $slideEl;\n }\n\n function update(force) {\n const {\n slidesPerView,\n slidesPerGroup,\n centeredSlides\n } = swiper.params;\n const {\n addSlidesBefore,\n addSlidesAfter\n } = swiper.params.virtual;\n const {\n from: previousFrom,\n to: previousTo,\n slides,\n slidesGrid: previousSlidesGrid,\n offset: previousOffset\n } = swiper.virtual;\n\n if (!swiper.params.cssMode) {\n swiper.updateActiveIndex();\n }\n\n const activeIndex = swiper.activeIndex || 0;\n let offsetProp;\n if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';\n let slidesAfter;\n let slidesBefore;\n\n if (centeredSlides) {\n slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n } else {\n slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;\n slidesBefore = slidesPerGroup + addSlidesBefore;\n }\n\n const from = Math.max((activeIndex || 0) - slidesBefore, 0);\n const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n const offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n Object.assign(swiper.virtual, {\n from,\n to,\n offset,\n slidesGrid: swiper.slidesGrid\n });\n\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n emit('virtualUpdate');\n }\n\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.css(offsetProp, `${offset}px`);\n }\n\n swiper.updateProgress();\n emit('virtualUpdate');\n return;\n }\n\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset,\n from,\n to,\n slides: function getSlides() {\n const slidesToRender = [];\n\n for (let i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n\n return slidesToRender;\n }()\n });\n\n if (swiper.params.virtual.renderExternalUpdate) {\n onRendered();\n } else {\n emit('virtualUpdate');\n }\n\n return;\n }\n\n const prependIndexes = [];\n const appendIndexes = [];\n\n if (force) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();\n } else {\n for (let i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${i}\"]`).remove();\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n if (i >= from && i <= to) {\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(i);\n } else {\n if (i > previousTo) appendIndexes.push(i);\n if (i < previousFrom) prependIndexes.push(i);\n }\n }\n }\n\n appendIndexes.forEach(index => {\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort((a, b) => b - a).forEach(index => {\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, `${offset}px`);\n onRendered();\n }\n\n function appendSlide(slides) {\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.push(slides[i]);\n }\n } else {\n swiper.virtual.slides.push(slides);\n }\n\n update(true);\n }\n\n function prependSlide(slides) {\n const activeIndex = swiper.activeIndex;\n let newActiveIndex = activeIndex + 1;\n let numberOfNewSlides = 1;\n\n if (Array.isArray(slides)) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.unshift(slides[i]);\n }\n\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\n }\n\n if (swiper.params.virtual.cache) {\n const cache = swiper.virtual.cache;\n const newCache = {};\n Object.keys(cache).forEach(cachedIndex => {\n const $cachedEl = cache[cachedIndex];\n const cachedElIndex = $cachedEl.attr('data-swiper-slide-index');\n\n if (cachedElIndex) {\n $cachedEl.attr('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);\n }\n\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = $cachedEl;\n });\n swiper.virtual.cache = newCache;\n }\n\n update(true);\n swiper.slideTo(newActiveIndex, 0);\n }\n\n function removeSlide(slidesIndexes) {\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;\n let activeIndex = swiper.activeIndex;\n\n if (Array.isArray(slidesIndexes)) {\n for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\n }\n\n if (slidesIndexes[i] < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n } else {\n swiper.virtual.slides.splice(slidesIndexes, 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n\n if (slidesIndexes < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n\n update(true);\n swiper.slideTo(activeIndex, 0);\n }\n\n function removeAllSlides() {\n swiper.virtual.slides = [];\n\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n\n update(true);\n swiper.slideTo(0, 0);\n }\n\n on('beforeInit', () => {\n if (!swiper.params.virtual.enabled) return;\n swiper.virtual.slides = swiper.params.virtual.slides;\n swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n\n if (!swiper.params.initialSlide) {\n update();\n }\n });\n on('setTranslate', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode && !swiper._immediateVirtual) {\n clearTimeout(cssModeTimeout);\n cssModeTimeout = setTimeout(() => {\n update();\n }, 100);\n } else {\n update();\n }\n });\n on('init update resize', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);\n }\n });\n Object.assign(swiper.virtual, {\n appendSlide,\n prependSlide,\n removeSlide,\n removeAllSlides,\n update\n });\n}","/* eslint-disable consistent-return */\nimport { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Keyboard({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n const window = getWindow();\n swiper.keyboard = {\n enabled: false\n };\n extendParams({\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n pageUpDown: true\n }\n });\n\n function handle(event) {\n if (!swiper.enabled) return;\n const {\n rtlTranslate: rtl\n } = swiper;\n let e = event;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n const kc = e.keyCode || e.charCode;\n const pageUpDown = swiper.params.keyboard.pageUpDown;\n const isPageUp = pageUpDown && kc === 33;\n const isPageDown = pageUpDown && kc === 34;\n const isArrowLeft = kc === 37;\n const isArrowRight = kc === 39;\n const isArrowUp = kc === 38;\n const isArrowDown = kc === 40; // Directions locks\n\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n if (!inView) return undefined;\n }\n\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n } else {\n if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n\n emit('keyPress', kc);\n return undefined;\n }\n\n function enable() {\n if (swiper.keyboard.enabled) return;\n $(document).on('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n\n function disable() {\n if (!swiper.keyboard.enabled) return;\n $(document).off('keydown', handle);\n swiper.keyboard.enabled = false;\n }\n\n on('init', () => {\n if (swiper.params.keyboard.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n if (swiper.keyboard.enabled) {\n disable();\n }\n });\n Object.assign(swiper.keyboard, {\n enable,\n disable\n });\n}","/* eslint-disable consistent-return */\nimport { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now, nextTick } from '../../shared/utils.js';\nexport default function Mousewheel({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n mousewheel: {\n enabled: false,\n releaseOnEdges: false,\n invert: false,\n forceToAxis: false,\n sensitivity: 1,\n eventsTarget: 'container',\n thresholdDelta: null,\n thresholdTime: null\n }\n });\n swiper.mousewheel = {\n enabled: false\n };\n let timeout;\n let lastScrollTime = now();\n let lastEventBeforeSnap;\n const recentWheelEvents = [];\n\n function normalize(e) {\n // Reasonable defaults\n const PIXEL_STEP = 10;\n const LINE_HEIGHT = 40;\n const PAGE_HEIGHT = 800;\n let sX = 0;\n let sY = 0; // spinX, spinY\n\n let pX = 0;\n let pY = 0; // pixelX, pixelY\n // Legacy\n\n if ('detail' in e) {\n sY = e.detail;\n }\n\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n } // side scrolling on FF with DOMMouseScroll\n\n\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n\n if (e.shiftKey && !pX) {\n // if user scrolls with shift he wants horizontal scroll\n pX = pY;\n pY = 0;\n }\n\n if ((pX || pY) && e.deltaMode) {\n if (e.deltaMode === 1) {\n // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else {\n // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n } // Fall-back if spin cannot be determined\n\n\n if (pX && !sX) {\n sX = pX < 1 ? -1 : 1;\n }\n\n if (pY && !sY) {\n sY = pY < 1 ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY\n };\n }\n\n function handleMouseEnter() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = true;\n }\n\n function handleMouseLeave() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = false;\n }\n\n function animateSlider(newEvent) {\n if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {\n // Prevent if delta of wheel scroll delta is below configured threshold\n return false;\n }\n\n if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {\n // Prevent if time between scrolls is below configured threshold\n return false;\n } // If the movement is NOT big enough and\n // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):\n // Don't go any further (avoid insignificant scroll movement).\n\n\n if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {\n // Return false as a default\n return true;\n } // If user is scrolling towards the end:\n // If the slider hasn't hit the latest slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to next slide and\n // emit a scroll event.\n // Else (the user is scrolling towards the beginning) and\n // if the slider hasn't hit the first slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to prev slide and\n // emit a scroll event.\n\n\n if (newEvent.direction < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n emit('scroll', newEvent.raw);\n }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n emit('scroll', newEvent.raw);\n } // If you got here is because an animation has been triggered so store the current time\n\n\n lastScrollTime = new window.Date().getTime(); // Return false as a default\n\n return false;\n }\n\n function releaseScroll(newEvent) {\n const params = swiper.params.mousewheel;\n\n if (newEvent.direction < 0) {\n if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n\n return false;\n }\n\n function handle(event) {\n let e = event;\n let disableParentSwiper = true;\n if (!swiper.enabled) return;\n const params = swiper.params.mousewheel;\n\n if (swiper.params.cssMode) {\n e.preventDefault();\n }\n\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n if (!swiper.mouseEntered && !target[0].contains(e.target) && !params.releaseOnEdges) return true;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n let delta = 0;\n const rtlFactor = swiper.rtlTranslate ? -1 : 1;\n const data = normalize(e);\n\n if (params.forceToAxis) {\n if (swiper.isHorizontal()) {\n if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;\n } else {\n delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n }\n\n if (delta === 0) return true;\n if (params.invert) delta = -delta; // Get the scroll positions\n\n let positions = swiper.getTranslate() + delta * params.sensitivity;\n if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();\n if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate(); // When loop is true:\n // the disableParentSwiper will be true.\n // When loop is false:\n // if the scroll positions is not on edge,\n // then the disableParentSwiper will be true.\n // if the scroll on edge positions,\n // then the disableParentSwiper will be false.\n\n disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());\n if (disableParentSwiper && swiper.params.nested) e.stopPropagation();\n\n if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {\n // Register the new event in a variable which stores the relevant data\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta),\n raw: event\n }; // Keep the most recent events\n\n if (recentWheelEvents.length >= 2) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n recentWheelEvents.push(newEvent); // If there is at least one previous recorded event:\n // If direction has changed or\n // if the scroll is quicker than the previous one:\n // Animate the slider.\n // Else (this is the first time the wheel is moved):\n // Animate the slider.\n\n if (prevEvent) {\n if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {\n animateSlider(newEvent);\n }\n } else {\n animateSlider(newEvent);\n } // If it's time to release the scroll:\n // Return now so you don't hit the preventDefault.\n\n\n if (releaseScroll(newEvent)) {\n return true;\n }\n } else {\n // Freemode or scrollContainer:\n // If we recently snapped after a momentum scroll, then ignore wheel events\n // to give time for the deceleration to finish. Stop ignoring after 500 msecs\n // or if it's a new scroll (larger delta or inverse sign as last event before\n // an end-of-momentum snap).\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta)\n };\n const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;\n\n if (!ignoreWheelEvents) {\n lastEventBeforeSnap = undefined;\n\n if (swiper.params.loop) {\n swiper.loopFix();\n }\n\n let position = swiper.getTranslate() + delta * params.sensitivity;\n const wasBeginning = swiper.isBeginning;\n const wasEnd = swiper.isEnd;\n if (position >= swiper.minTranslate()) position = swiper.minTranslate();\n if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();\n swiper.setTransition(0);\n swiper.setTranslate(position);\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode.sticky) {\n // When wheel scrolling starts with sticky (aka snap) enabled, then detect\n // the end of a momentum scroll by storing recent (N=15?) wheel events.\n // 1. do all N events have decreasing or same (absolute value) delta?\n // 2. did all N events arrive in the last M (M=500?) msecs?\n // 3. does the earliest event have an (absolute value) delta that's\n // at least P (P=1?) larger than the most recent event's delta?\n // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?\n // If 1-4 are \"yes\" then we're near the end of a momentum scroll deceleration.\n // Snap immediately and ignore remaining wheel events in this scroll.\n // See comment above for \"remaining wheel events in this scroll\" determination.\n // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.\n clearTimeout(timeout);\n timeout = undefined;\n\n if (recentWheelEvents.length >= 15) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n const firstEvent = recentWheelEvents[0];\n recentWheelEvents.push(newEvent);\n\n if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {\n // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.\n recentWheelEvents.splice(0);\n } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {\n // We're at the end of the deceleration of a momentum scroll, so there's no need\n // to wait for more events. Snap ASAP on the next tick.\n // Also, because there's some remaining momentum we'll bias the snap in the\n // direction of the ongoing scroll because it's better UX for the scroll to snap\n // in the same direction as the scroll instead of reversing to snap. Therefore,\n // if it's already scrolled more than 20% in the current direction, keep going.\n const snapToThreshold = delta > 0 ? 0.8 : 0.2;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n timeout = nextTick(() => {\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 0); // no delay; move on next tick\n }\n\n if (!timeout) {\n // if we get here, then we haven't detected the end of a momentum scroll, so\n // we'll consider a scroll \"complete\" when there haven't been any wheel events\n // for 500ms.\n timeout = nextTick(() => {\n const snapToThreshold = 0.5;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 500);\n }\n } // Emit event\n\n\n if (!ignoreWheelEvents) emit('scroll', e); // Stop autoplay\n\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop(); // Return page scroll on edge positions\n\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;\n }\n }\n\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n return false;\n }\n\n function events(method) {\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n target[method]('mouseenter', handleMouseEnter);\n target[method]('mouseleave', handleMouseLeave);\n target[method]('wheel', handle);\n }\n\n function enable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.removeEventListener('wheel', handle);\n return true;\n }\n\n if (swiper.mousewheel.enabled) return false;\n events('on');\n swiper.mousewheel.enabled = true;\n return true;\n }\n\n function disable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.addEventListener(event, handle);\n return true;\n }\n\n if (!swiper.mousewheel.enabled) return false;\n events('off');\n swiper.mousewheel.enabled = false;\n return true;\n }\n\n on('init', () => {\n if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {\n disable();\n }\n\n if (swiper.params.mousewheel.enabled) enable();\n });\n on('destroy', () => {\n if (swiper.params.cssMode) {\n enable();\n }\n\n if (swiper.mousewheel.enabled) disable();\n });\n Object.assign(swiper.mousewheel, {\n enable,\n disable\n });\n}","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}\">`;\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 = `` + ' / ' + ``;\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 = ``;\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 { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Scrollbar({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n let isTouched = false;\n let timeout = null;\n let dragTimeout = null;\n let dragStartPos;\n let dragSize;\n let trackSize;\n let divider;\n extendParams({\n scrollbar: {\n el: null,\n dragSize: 'auto',\n hide: false,\n draggable: false,\n snapOnRelease: true,\n lockClass: 'swiper-scrollbar-lock',\n dragClass: 'swiper-scrollbar-drag',\n scrollbarDisabledClass: 'swiper-scrollbar-disabled',\n horizontalClass: `swiper-scrollbar-horizontal`,\n verticalClass: `swiper-scrollbar-vertical`\n }\n });\n swiper.scrollbar = {\n el: null,\n dragEl: null,\n $el: null,\n $dragEl: null\n };\n\n function setTranslate() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar,\n rtlTranslate: rtl,\n progress\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n const params = swiper.params.scrollbar;\n let newSize = dragSize;\n let newPos = (trackSize - dragSize) * progress;\n\n if (rtl) {\n newPos = -newPos;\n\n if (newPos > 0) {\n newSize = dragSize - newPos;\n newPos = 0;\n } else if (-newPos + dragSize > trackSize) {\n newSize = trackSize + newPos;\n }\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) {\n newSize = trackSize - newPos;\n }\n\n if (swiper.isHorizontal()) {\n $dragEl.transform(`translate3d(${newPos}px, 0, 0)`);\n $dragEl[0].style.width = `${newSize}px`;\n } else {\n $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);\n $dragEl[0].style.height = `${newSize}px`;\n }\n\n if (params.hide) {\n clearTimeout(timeout);\n $el[0].style.opacity = 1;\n timeout = setTimeout(() => {\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n }\n\n function setTransition(duration) {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n swiper.scrollbar.$dragEl.transition(duration);\n }\n\n function updateSize() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n $dragEl[0].style.width = '';\n $dragEl[0].style.height = '';\n trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n\n if (swiper.isHorizontal()) {\n $dragEl[0].style.width = `${dragSize}px`;\n } else {\n $dragEl[0].style.height = `${dragSize}px`;\n }\n\n if (divider >= 1) {\n $el[0].style.display = 'none';\n } else {\n $el[0].style.display = '';\n }\n\n if (swiper.params.scrollbar.hide) {\n $el[0].style.opacity = 0;\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n scrollbar.$el[swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function getPointerPosition(e) {\n if (swiper.isHorizontal()) {\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientX : e.clientX;\n }\n\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientY : e.clientY;\n }\n\n function setDragPosition(e) {\n const {\n scrollbar,\n rtlTranslate: rtl\n } = swiper;\n const {\n $el\n } = scrollbar;\n let positionRatio;\n positionRatio = (getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n\n if (rtl) {\n positionRatio = 1 - positionRatio;\n }\n\n const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;\n swiper.updateProgress(position);\n swiper.setTranslate(position);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n function onDragStart(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n isTouched = true;\n dragStartPos = e.target === $dragEl[0] || e.target === $dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n setDragPosition(e);\n clearTimeout(dragTimeout);\n $el.transition(0);\n\n if (params.hide) {\n $el.css('opacity', 1);\n }\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', 'none');\n }\n\n emit('scrollbarDragStart', e);\n }\n\n function onDragMove(e) {\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n if (!isTouched) return;\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n emit('scrollbarDragMove', e);\n }\n\n function onDragEnd(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el\n } = scrollbar;\n if (!isTouched) return;\n isTouched = false;\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', '');\n $wrapperEl.transition('');\n }\n\n if (params.hide) {\n clearTimeout(dragTimeout);\n dragTimeout = nextTick(() => {\n $el.css('opacity', 0);\n $el.transition(400);\n }, 1000);\n }\n\n emit('scrollbarDragEnd', e);\n\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n }\n\n function events(method) {\n const {\n scrollbar,\n touchEventsTouch,\n touchEventsDesktop,\n params,\n support\n } = swiper;\n const $el = scrollbar.$el;\n if (!$el) return;\n const target = $el[0];\n const activeListener = support.passiveListener && params.passiveListeners ? {\n passive: false,\n capture: false\n } : false;\n const passiveListener = support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (!target) return;\n const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n\n if (!support.touch) {\n target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);\n document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);\n document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);\n } else {\n target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);\n target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);\n target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);\n }\n }\n\n function enableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('on');\n }\n\n function disableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('off');\n }\n\n function init() {\n const {\n scrollbar,\n $el: $swiperEl\n } = swiper;\n swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {\n el: 'swiper-scrollbar'\n });\n const params = swiper.params.scrollbar;\n if (!params.el) return;\n let $el = $(params.el);\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {\n $el = $swiperEl.find(params.el);\n }\n\n $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`);\n\n if ($dragEl.length === 0) {\n $dragEl = $(`
`);\n $el.append($dragEl);\n }\n\n Object.assign(scrollbar, {\n $el,\n el: $el[0],\n $dragEl,\n dragEl: $dragEl[0]\n });\n\n if (params.draggable) {\n enableDraggable();\n }\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function destroy() {\n const params = swiper.params.scrollbar;\n const $el = swiper.scrollbar.$el;\n\n if ($el) {\n $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n }\n\n disableDraggable();\n }\n\n on('init', () => {\n if (swiper.params.scrollbar.enabled === false) {\n // eslint-disable-next-line\n disable();\n } else {\n init();\n updateSize();\n setTranslate();\n }\n });\n on('update resize observerUpdate lock unlock', () => {\n updateSize();\n });\n on('setTranslate', () => {\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n setTransition(duration);\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.scrollbar;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n });\n on('destroy', () => {\n destroy();\n });\n\n const enable = () => {\n swiper.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);\n\n if (swiper.scrollbar.$el) {\n swiper.scrollbar.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n\n init();\n updateSize();\n setTranslate();\n };\n\n const disable = () => {\n swiper.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);\n\n if (swiper.scrollbar.$el) {\n swiper.scrollbar.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n\n destroy();\n };\n\n Object.assign(swiper.scrollbar, {\n enable,\n disable,\n updateSize,\n setTranslate,\n init,\n destroy\n });\n}","import $ from '../../shared/dom.js';\nexport default function Parallax({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n parallax: {\n enabled: false\n }\n });\n\n const setTransform = (el, progress) => {\n const {\n rtl\n } = swiper;\n const $el = $(el);\n const rtlFactor = rtl ? -1 : 1;\n const p = $el.attr('data-swiper-parallax') || '0';\n let x = $el.attr('data-swiper-parallax-x');\n let y = $el.attr('data-swiper-parallax-y');\n const scale = $el.attr('data-swiper-parallax-scale');\n const opacity = $el.attr('data-swiper-parallax-opacity');\n\n if (x || y) {\n x = x || '0';\n y = y || '0';\n } else if (swiper.isHorizontal()) {\n x = p;\n y = '0';\n } else {\n y = p;\n x = '0';\n }\n\n if (x.indexOf('%') >= 0) {\n x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n } else {\n x = `${x * progress * rtlFactor}px`;\n }\n\n if (y.indexOf('%') >= 0) {\n y = `${parseInt(y, 10) * progress}%`;\n } else {\n y = `${y * progress}px`;\n }\n\n if (typeof opacity !== 'undefined' && opacity !== null) {\n const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n $el[0].style.opacity = currentOpacity;\n }\n\n if (typeof scale === 'undefined' || scale === null) {\n $el.transform(`translate3d(${x}, ${y}, 0px)`);\n } else {\n const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);\n }\n };\n\n const setTranslate = () => {\n const {\n $el,\n slides,\n progress,\n snapGrid\n } = swiper;\n $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, progress);\n });\n slides.each((slideEl, slideIndex) => {\n let slideProgress = slideEl.progress;\n\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n }\n\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, slideProgress);\n });\n });\n };\n\n const setTransition = (duration = swiper.params.speed) => {\n const {\n $el\n } = swiper;\n $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(parallaxEl => {\n const $parallaxEl = $(parallaxEl);\n let parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) parallaxDuration = 0;\n $parallaxEl.transition(parallaxDuration);\n });\n };\n\n on('beforeInit', () => {\n if (!swiper.params.parallax.enabled) return;\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n });\n on('init', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTranslate', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTransition', (_swiper, duration) => {\n if (!swiper.params.parallax.enabled) return;\n setTransition(duration);\n });\n}","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { getTranslate } from '../../shared/utils.js';\nexport default function Zoom({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: 'swiper-zoom-container',\n zoomedSlideClass: 'swiper-slide-zoomed'\n }\n });\n swiper.zoom = {\n enabled: false\n };\n let currentScale = 1;\n let isScaling = false;\n let gesturesEnabled;\n let fakeGestureTouched;\n let fakeGestureMoved;\n const gesture = {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3\n };\n const image = {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {}\n };\n const velocity = {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined\n };\n let scale = 1;\n Object.defineProperty(swiper.zoom, 'scale', {\n get() {\n return scale;\n },\n\n set(value) {\n if (scale !== value) {\n const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined;\n const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined;\n emit('zoomChange', value, imageEl, slideEl);\n }\n\n scale = value;\n }\n\n });\n\n function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) return 1;\n const x1 = e.targetTouches[0].pageX;\n const y1 = e.targetTouches[0].pageY;\n const x2 = e.targetTouches[1].pageX;\n const y2 = e.targetTouches[1].pageY;\n const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n return distance;\n } // Events\n\n\n function onGestureStart(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n\n if (!support.gestures) {\n if (e.type !== 'touchstart' || e.type === 'touchstart' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureTouched = true;\n gesture.scaleStart = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n if (gesture.$slideEl.length === 0) gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n\n if (gesture.$imageEl) {\n gesture.$imageEl.transition(0);\n }\n\n isScaling = true;\n }\n\n function onGestureChange(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (e.type !== 'touchmove' || e.type === 'touchmove' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureMoved = true;\n gesture.scaleMove = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) {\n if (e.type === 'gesturechange') onGestureStart(e);\n return;\n }\n\n if (support.gestures) {\n zoom.scale = e.scale * currentScale;\n } else {\n zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n }\n\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n }\n\n if (zoom.scale < params.minRatio) {\n zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n }\n\n gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function onGestureEnd(e) {\n const device = swiper.device;\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (!fakeGestureTouched || !fakeGestureMoved) {\n return;\n }\n\n if (e.type !== 'touchend' || e.type === 'touchend' && e.changedTouches.length < 2 && !device.android) {\n return;\n }\n\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n currentScale = zoom.scale;\n isScaling = false;\n if (zoom.scale === 1) gesture.$slideEl = undefined;\n }\n\n function onTouchStart(e) {\n const device = swiper.device;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n if (image.isTouched) return;\n if (device.android && e.cancelable) e.preventDefault();\n image.isTouched = true;\n image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n }\n\n function onTouchMove(e) {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) return;\n\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = getTranslate(gesture.$imageWrapEl[0], 'x') || 0;\n image.startY = getTranslate(gesture.$imageWrapEl[0], 'y') || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n } // Define if we need image drag\n\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n\n if (!image.isMoved && !isScaling) {\n if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {\n image.isTouched = false;\n return;\n }\n\n if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {\n image.isTouched = false;\n return;\n }\n }\n\n if (e.cancelable) {\n e.preventDefault();\n }\n\n e.stopPropagation();\n image.isMoved = true;\n image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX;\n image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY;\n\n if (image.currentX < image.minX) {\n image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n }\n\n if (image.currentX > image.maxX) {\n image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n }\n\n if (image.currentY < image.minY) {\n image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n }\n\n if (image.currentY > image.maxY) {\n image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\n } // Velocity\n\n\n if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;\n if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;\n if (!velocity.prevTime) velocity.prevTime = Date.now();\n velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;\n if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;\n velocity.prevPositionX = image.touchesCurrent.x;\n velocity.prevPositionY = image.touchesCurrent.y;\n velocity.prevTime = Date.now();\n gesture.$imageWrapEl.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTouchEnd() {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\n }\n\n image.isTouched = false;\n image.isMoved = false;\n let momentumDurationX = 300;\n let momentumDurationY = 300;\n const momentumDistanceX = velocity.x * momentumDurationX;\n const newPositionX = image.currentX + momentumDistanceX;\n const momentumDistanceY = velocity.y * momentumDurationY;\n const newPositionY = image.currentY + momentumDistanceY; // Fix duration\n\n if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);\n if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);\n const momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n image.currentX = newPositionX;\n image.currentY = newPositionY; // Define if we need image drag\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n gesture.$imageWrapEl.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTransitionEnd() {\n const zoom = swiper.zoom;\n\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n if (gesture.$imageEl) {\n gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');\n }\n\n if (gesture.$imageWrapEl) {\n gesture.$imageWrapEl.transform('translate3d(0,0,0)');\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\n }\n }\n\n function zoomIn(e) {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (e && e.target) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n }\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.touchAction = 'none';\n }\n\n gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);\n let touchX;\n let touchY;\n let offsetX;\n let offsetY;\n let diffX;\n let diffY;\n let translateX;\n let translateY;\n let imageWidth;\n let imageHeight;\n let scaledWidth;\n let scaledHeight;\n let translateMinX;\n let translateMinY;\n let translateMaxX;\n let translateMaxY;\n let slideWidth;\n let slideHeight;\n\n if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n\n zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left + window.scrollX;\n offsetY = gesture.$slideEl.offset().top + window.scrollY;\n diffX = offsetX + slideWidth / 2 - touchX;\n diffY = offsetY + slideHeight / 2 - touchY;\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n\n if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n\n gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);\n gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function zoomOut() {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.style.touchAction = '';\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');\n gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');\n gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);\n gesture.$slideEl = undefined;\n } // Toggle Zoom\n\n\n function zoomToggle(e) {\n const zoom = swiper.zoom;\n\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoomOut();\n } else {\n // Zoom In\n zoomIn(e);\n }\n }\n\n function getListeners() {\n const support = swiper.support;\n const passiveListener = swiper.touchEvents.start === 'touchstart' && support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n const activeListenerWithCapture = support.passiveListener ? {\n passive: false,\n capture: true\n } : true;\n return {\n passiveListener,\n activeListenerWithCapture\n };\n }\n\n function getSlideSelector() {\n return `.${swiper.params.slideClass}`;\n }\n\n function toggleGestures(method) {\n const {\n passiveListener\n } = getListeners();\n const slideSelector = getSlideSelector();\n swiper.$wrapperEl[method]('gesturestart', slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl[method]('gesturechange', slideSelector, onGestureChange, passiveListener);\n swiper.$wrapperEl[method]('gestureend', slideSelector, onGestureEnd, passiveListener);\n }\n\n function enableGestures() {\n if (gesturesEnabled) return;\n gesturesEnabled = true;\n toggleGestures('on');\n }\n\n function disableGestures() {\n if (!gesturesEnabled) return;\n gesturesEnabled = false;\n toggleGestures('off');\n } // Attach/Detach Events\n\n\n function enable() {\n const zoom = swiper.zoom;\n if (zoom.enabled) return;\n zoom.enabled = true;\n const support = swiper.support;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n function disable() {\n const zoom = swiper.zoom;\n if (!zoom.enabled) return;\n const support = swiper.support;\n zoom.enabled = false;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n on('init', () => {\n if (swiper.params.zoom.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n disable();\n });\n on('touchStart', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchStart(e);\n });\n on('touchEnd', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchEnd(e);\n });\n on('doubleTap', (_s, e) => {\n if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n zoomToggle(e);\n }\n });\n on('transitionEnd', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n onTransitionEnd();\n }\n });\n on('slideChange', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {\n onTransitionEnd();\n }\n });\n Object.assign(swiper.zoom, {\n enable,\n disable,\n in: zoomIn,\n out: zoomOut,\n toggle: zoomToggle\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}","/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\nimport { nextTick } from '../../shared/utils.js';\nexport default function Controller({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n controller: {\n control: undefined,\n inverse: false,\n by: 'slide' // or 'container'\n\n }\n });\n swiper.controller = {\n control: undefined\n };\n\n function LinearSpline(x, y) {\n const binarySearch = function search() {\n let maxIndex;\n let minIndex;\n let guess;\n return (array, val) => {\n minIndex = -1;\n maxIndex = array.length;\n\n while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n\n return maxIndex;\n };\n }();\n\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n\n let i1;\n let i3;\n\n this.interpolate = function interpolate(x2) {\n if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n\n return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];\n };\n\n return this;\n } // xxx: for now i will just save one spline function to to\n\n\n function getInterpolateFunction(c) {\n if (!swiper.controller.spline) {\n swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n }\n\n function setTranslate(_t, byController) {\n const controlled = swiper.controller.control;\n let multiplier;\n let controlledTranslate;\n const Swiper = swiper.constructor;\n\n function setControlledTranslate(c) {\n // this will create an Interpolate function based on the snapGrids\n // x is the Grid of the scrolled scroller and y will be the controlled scroller\n // it makes sense to create this only once and recall it for the interpolation\n // the function does a lot of value caching for performance\n const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n\n if (swiper.params.controller.by === 'slide') {\n getInterpolateFunction(c); // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n // but it did not work out\n\n controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n }\n\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\n }\n\n if (Array.isArray(controlled)) {\n for (let i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTranslate(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTranslate(controlled);\n }\n }\n\n function setTransition(duration, byController) {\n const Swiper = swiper.constructor;\n const controlled = swiper.controller.control;\n let i;\n\n function setControlledTransition(c) {\n c.setTransition(duration, swiper);\n\n if (duration !== 0) {\n c.transitionStart();\n\n if (c.params.autoHeight) {\n nextTick(() => {\n c.updateAutoHeight();\n });\n }\n\n c.$wrapperEl.transitionEnd(() => {\n if (!controlled) return;\n\n if (c.params.loop && swiper.params.controller.by === 'slide') {\n c.loopFix();\n }\n\n c.transitionEnd();\n });\n }\n }\n\n if (Array.isArray(controlled)) {\n for (i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTransition(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTransition(controlled);\n }\n }\n\n function removeSpline() {\n if (!swiper.controller.control) return;\n\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n }\n\n on('beforeInit', () => {\n swiper.controller.control = swiper.params.controller.control;\n });\n on('update', () => {\n removeSpline();\n });\n on('resize', () => {\n removeSpline();\n });\n on('observerUpdate', () => {\n removeSpline();\n });\n on('setTranslate', (_s, translate, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTranslate(translate, byController);\n });\n on('setTransition', (_s, duration, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTransition(duration, byController);\n });\n Object.assign(swiper.controller, {\n setTranslate,\n setTransition\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 = $(``);\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}","import { getWindow } from 'ssr-window';\nexport default function History({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n history: {\n enabled: false,\n root: '',\n replaceState: false,\n key: 'slides',\n keepQuery: false\n }\n });\n let initialized = false;\n let paths = {};\n\n const slugify = text => {\n return text.toString().replace(/\\s+/g, '-').replace(/[^\\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');\n };\n\n const getPathValues = urlOverride => {\n const window = getWindow();\n let location;\n\n if (urlOverride) {\n location = new URL(urlOverride);\n } else {\n location = window.location;\n }\n\n const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');\n const total = pathArray.length;\n const key = pathArray[total - 2];\n const value = pathArray[total - 1];\n return {\n key,\n value\n };\n };\n\n const setHistory = (key, index) => {\n const window = getWindow();\n if (!initialized || !swiper.params.history.enabled) return;\n let location;\n\n if (swiper.params.url) {\n location = new URL(swiper.params.url);\n } else {\n location = window.location;\n }\n\n const slide = swiper.slides.eq(index);\n let value = slugify(slide.attr('data-history'));\n\n if (swiper.params.history.root.length > 0) {\n let root = swiper.params.history.root;\n if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);\n value = `${root}/${key}/${value}`;\n } else if (!location.pathname.includes(key)) {\n value = `${key}/${value}`;\n }\n\n if (swiper.params.history.keepQuery) {\n value += location.search;\n }\n\n const currentState = window.history.state;\n\n if (currentState && currentState.value === value) {\n return;\n }\n\n if (swiper.params.history.replaceState) {\n window.history.replaceState({\n value\n }, null, value);\n } else {\n window.history.pushState({\n value\n }, null, value);\n }\n };\n\n const scrollToSlide = (speed, value, runCallbacks) => {\n if (value) {\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHistory = slugify(slide.attr('data-history'));\n\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n };\n\n const setHistoryPopState = () => {\n paths = getPathValues(swiper.params.url);\n scrollToSlide(swiper.params.speed, paths.value, false);\n };\n\n const init = () => {\n const window = getWindow();\n if (!swiper.params.history) return;\n\n if (!window.history || !window.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n\n initialized = true;\n paths = getPathValues(swiper.params.url);\n if (!paths.key && !paths.value) return;\n scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n\n if (!swiper.params.history.replaceState) {\n window.addEventListener('popstate', setHistoryPopState);\n }\n };\n\n const destroy = () => {\n const window = getWindow();\n\n if (!swiper.params.history.replaceState) {\n window.removeEventListener('popstate', setHistoryPopState);\n }\n };\n\n on('init', () => {\n if (swiper.params.history.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.history.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n}","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function HashNavigation({\n swiper,\n extendParams,\n emit,\n on\n}) {\n let initialized = false;\n const document = getDocument();\n const window = getWindow();\n extendParams({\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false\n }\n });\n\n const onHashChange = () => {\n emit('hashChange');\n const newHash = document.location.hash.replace('#', '');\n const activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');\n\n if (newHash !== activeSlideHash) {\n const newIndex = swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash=\"${newHash}\"]`).index();\n if (typeof newIndex === 'undefined') return;\n swiper.slideTo(newIndex);\n }\n };\n\n const setHash = () => {\n if (!initialized || !swiper.params.hashNavigation.enabled) return;\n\n if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr('data-hash')}` || '');\n emit('hashSet');\n } else {\n const slide = swiper.slides.eq(swiper.activeIndex);\n const hash = slide.attr('data-hash') || slide.attr('data-history');\n document.location.hash = hash || '';\n emit('hashSet');\n }\n };\n\n const init = () => {\n if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;\n initialized = true;\n const hash = document.location.hash.replace('#', '');\n\n if (hash) {\n const speed = 0;\n\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHash = slide.attr('data-hash') || slide.attr('data-history');\n\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n\n if (swiper.params.hashNavigation.watchState) {\n $(window).on('hashchange', onHashChange);\n }\n };\n\n const destroy = () => {\n if (swiper.params.hashNavigation.watchState) {\n $(window).off('hashchange', onHashChange);\n }\n };\n\n on('init', () => {\n if (swiper.params.hashNavigation.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.hashNavigation.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHash();\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHash();\n }\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}","import { isObject } from '../../shared/utils.js';\nimport $ from '../../shared/dom.js';\nexport default function Thumb({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n thumbs: {\n swiper: null,\n multipleActiveThumbs: true,\n autoScrollOffset: 0,\n slideThumbActiveClass: 'swiper-slide-thumb-active',\n thumbsContainerClass: 'swiper-thumbs'\n }\n });\n let initialized = false;\n let swiperCreated = false;\n swiper.thumbs = {\n swiper: null\n };\n\n function onThumbClick() {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n const clickedIndex = thumbsSwiper.clickedIndex;\n const clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;\n let slideToIndex;\n\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n\n if (swiper.params.loop) {\n let currentIndex = swiper.activeIndex;\n\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n\n const prevIndex = swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n const nextIndex = swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n if (typeof prevIndex === 'undefined') slideToIndex = nextIndex;else if (typeof nextIndex === 'undefined') slideToIndex = prevIndex;else if (nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex = nextIndex;else slideToIndex = prevIndex;\n }\n\n swiper.slideTo(slideToIndex);\n }\n\n function init() {\n const {\n thumbs: thumbsParams\n } = swiper.params;\n if (initialized) return false;\n initialized = true;\n const SwiperClass = swiper.constructor;\n\n if (thumbsParams.swiper instanceof SwiperClass) {\n swiper.thumbs.swiper = thumbsParams.swiper;\n Object.assign(swiper.thumbs.swiper.originalParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n Object.assign(swiper.thumbs.swiper.params, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n } else if (isObject(thumbsParams.swiper)) {\n const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);\n Object.assign(thumbsSwiperParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);\n swiperCreated = true;\n }\n\n swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', onThumbClick);\n return true;\n }\n\n function update(initial) {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView; // Activate thumbs\n\n let thumbsToActivate = 1;\n const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n\n if (!swiper.params.thumbs.multipleActiveThumbs) {\n thumbsToActivate = 1;\n }\n\n thumbsToActivate = Math.floor(thumbsToActivate);\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).addClass(thumbActiveClass);\n }\n } else {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);\n }\n }\n\n const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n\n if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n let currentThumbsIndex = thumbsSwiper.activeIndex;\n let newThumbsIndex;\n let direction;\n\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix(); // eslint-disable-next-line\n\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n } // Find actual thumbs index to slide to\n\n\n const prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n const nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n\n if (typeof prevThumbsIndex === 'undefined') {\n newThumbsIndex = nextThumbsIndex;\n } else if (typeof nextThumbsIndex === 'undefined') {\n newThumbsIndex = prevThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex : currentThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = nextThumbsIndex;\n } else {\n newThumbsIndex = prevThumbsIndex;\n }\n\n direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';\n } else {\n newThumbsIndex = swiper.realIndex;\n direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';\n }\n\n if (useOffset) {\n newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;\n }\n\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n } else {\n newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n }\n } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) {// newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n }\n }\n\n on('beforeInit', () => {\n const {\n thumbs\n } = swiper.params;\n if (!thumbs || !thumbs.swiper) return;\n init();\n update(true);\n });\n on('slideChange update resize observerUpdate', () => {\n update();\n });\n on('setTransition', (_s, duration) => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n thumbsSwiper.setTransition(duration);\n });\n on('beforeDestroy', () => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n\n if (swiperCreated) {\n thumbsSwiper.destroy();\n }\n });\n Object.assign(swiper.thumbs, {\n init,\n update\n });\n}","import { now } from '../../shared/utils.js';\nexport default function freeMode({\n swiper,\n extendParams,\n emit,\n once\n}) {\n extendParams({\n freeMode: {\n enabled: false,\n momentum: true,\n momentumRatio: 1,\n momentumBounce: true,\n momentumBounceRatio: 1,\n momentumVelocityRatio: 1,\n sticky: false,\n minimumVelocity: 0.02\n }\n });\n\n function onTouchStart() {\n const translate = swiper.getTranslate();\n swiper.setTranslate(translate);\n swiper.setTransition(0);\n swiper.touchEventsData.velocities.length = 0;\n swiper.freeMode.onTouchEnd({\n currentPos: swiper.rtl ? swiper.translate : -swiper.translate\n });\n }\n\n function onTouchMove() {\n const {\n touchEventsData: data,\n touches\n } = swiper; // Velocity\n\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime\n });\n }\n\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: now()\n });\n }\n\n function onTouchEnd({\n currentPos\n }) {\n const {\n params,\n $wrapperEl,\n rtlTranslate: rtl,\n snapGrid,\n touchEventsData: data\n } = swiper; // Time diff\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime;\n\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (currentPos > -swiper.maxTranslate()) {\n if (swiper.slides.length < snapGrid.length) {\n swiper.slideTo(snapGrid.length - 1);\n } else {\n swiper.slideTo(swiper.slides.length - 1);\n }\n\n return;\n }\n\n if (params.freeMode.momentum) {\n if (data.velocities.length > 1) {\n const lastMoveEvent = data.velocities.pop();\n const velocityEvent = data.velocities.pop();\n const distance = lastMoveEvent.position - velocityEvent.position;\n const time = lastMoveEvent.time - velocityEvent.time;\n swiper.velocity = distance / time;\n swiper.velocity /= 2;\n\n if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {\n swiper.velocity = 0;\n } // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n\n\n if (time > 150 || now() - lastMoveEvent.time > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\n }\n\n swiper.velocity *= params.freeMode.momentumVelocityRatio;\n data.velocities.length = 0;\n let momentumDuration = 1000 * params.freeMode.momentumRatio;\n const momentumDistance = swiper.velocity * momentumDuration;\n let newPosition = swiper.translate + momentumDistance;\n if (rtl) newPosition = -newPosition;\n let doBounce = false;\n let afterBouncePosition;\n const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;\n let needsLoopFix;\n\n if (newPosition < swiper.maxTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (newPosition > swiper.minTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition - swiper.minTranslate() > bounceAmount) {\n newPosition = swiper.minTranslate() + bounceAmount;\n }\n\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (params.freeMode.sticky) {\n let nextSlide;\n\n for (let j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n }\n\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n newPosition = snapGrid[nextSlide];\n } else {\n newPosition = snapGrid[nextSlide - 1];\n }\n\n newPosition = -newPosition;\n }\n\n if (needsLoopFix) {\n once('transitionEnd', () => {\n swiper.loopFix();\n });\n } // Fix duration\n\n\n if (swiper.velocity !== 0) {\n if (rtl) {\n momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n } else {\n momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n }\n\n if (params.freeMode.sticky) {\n // If freeMode.sticky is active and the user ends a swipe with a slow-velocity\n // event, then durations can be 20+ seconds to slide one (or zero!) slides.\n // It's easy to see this when simulating touch with mouse events. To fix this,\n // limit single-slide swipes to the default slide duration. This also has the\n // nice side effect of matching slide speed if the user stopped moving before\n // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.\n // For faster swipes, also apply limits (albeit higher ones).\n const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);\n const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];\n\n if (moveDistance < currentSlideSize) {\n momentumDuration = params.speed;\n } else if (moveDistance < 2 * currentSlideSize) {\n momentumDuration = params.speed * 1.5;\n } else {\n momentumDuration = params.speed * 2.5;\n }\n }\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (params.freeMode.momentumBounce && doBounce) {\n swiper.updateProgress(afterBouncePosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n emit('momentumBounce');\n swiper.setTransition(params.speed);\n setTimeout(() => {\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }, 0);\n });\n } else if (swiper.velocity) {\n emit('_freeModeNoMomentumRelease');\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\n }\n\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n } else if (params.freeMode) {\n emit('_freeModeNoMomentumRelease');\n }\n\n if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n }\n\n Object.assign(swiper, {\n freeMode: {\n onTouchStart,\n onTouchMove,\n onTouchEnd\n }\n });\n}","import $ from '../../shared/dom.js';\nimport effectInit from '../../shared/effect-init.js';\nexport default function EffectCube({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94\n }\n });\n\n const createSlideShadows = ($slideEl, progress, isHorizontal) => {\n let shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = $(`
`);\n $slideEl.append(shadowBefore);\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = $(`
`);\n $slideEl.append(shadowAfter);\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n };\n\n const recreateShadows = () => {\n // create new ones\n const isHorizontal = swiper.isHorizontal();\n swiper.slides.each(slideEl => {\n const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n createSlideShadows($(slideEl), progress, isHorizontal);\n });\n };\n\n const setTranslate = () => {\n const {\n $el,\n $wrapperEl,\n slides,\n width: swiperWidth,\n height: swiperHeight,\n rtlTranslate: rtl,\n size: swiperSize,\n browser\n } = swiper;\n const params = swiper.params.cubeEffect;\n const isHorizontal = swiper.isHorizontal();\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n let wrapperRotate = 0;\n let $cubeShadowEl;\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $wrapperEl.append($cubeShadowEl);\n }\n\n $cubeShadowEl.css({\n height: `${swiperWidth}px`\n });\n } else {\n $cubeShadowEl = $el.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $el.append($cubeShadowEl);\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let slideIndex = i;\n\n if (isVirtual) {\n slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);\n }\n\n let slideAngle = slideIndex * 90;\n let round = Math.floor(slideAngle / 360);\n\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n\n const progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n let tx = 0;\n let ty = 0;\n let tz = 0;\n\n if (slideIndex % 4 === 0) {\n tx = -round * 4 * swiperSize;\n tz = 0;\n } else if ((slideIndex - 1) % 4 === 0) {\n tx = 0;\n tz = -round * 4 * swiperSize;\n } else if ((slideIndex - 2) % 4 === 0) {\n tx = swiperSize + round * 4 * swiperSize;\n tz = swiperSize;\n } else if ((slideIndex - 3) % 4 === 0) {\n tx = -swiperSize;\n tz = 3 * swiperSize + swiperSize * 4 * round;\n }\n\n if (rtl) {\n tx = -tx;\n }\n\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n\n const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;\n\n if (progress <= 1 && progress > -1) {\n wrapperRotate = slideIndex * 90 + progress * 90;\n if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;\n }\n\n $slideEl.transform(transform);\n\n if (params.slideShadows) {\n createSlideShadows($slideEl, progress, isHorizontal);\n }\n }\n\n $wrapperEl.css({\n '-webkit-transform-origin': `50% 50% -${swiperSize / 2}px`,\n 'transform-origin': `50% 50% -${swiperSize / 2}px`\n });\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);\n } else {\n const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;\n const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);\n const scale1 = params.shadowScale;\n const scale2 = params.shadowScale / multiplier;\n const offset = params.shadowOffset;\n $cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);\n }\n }\n\n const zFactor = browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0;\n $wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`);\n $wrapperEl[0].style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);\n };\n\n const setTransition = duration => {\n const {\n $el,\n slides\n } = swiper;\n slides.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n $el.find('.swiper-cube-shadow').transition(duration);\n }\n };\n\n effectInit({\n effect: 'cube',\n swiper,\n on,\n setTranslate,\n setTransition,\n recreateShadows,\n getEffectParams: () => swiper.params.cubeEffect,\n perspective: () => true,\n overwriteParams: () => ({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n resistanceRatio: 0,\n spaceBetween: 0,\n centeredSlides: false,\n virtualTranslate: true\n })\n });\n}","import $ from './dom.js';\nexport default function createShadow(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n\n if (!$shadowEl.length) {\n $shadowEl = $(`
`);\n $shadowContainer.append($shadowEl);\n }\n\n return $shadowEl;\n}","import $ from '../../shared/dom.js';\nimport createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectFlip({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n transformEl: null\n }\n });\n\n const createSlideShadows = ($slideEl, progress, params) => {\n let shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = createShadow(params, $slideEl, swiper.isHorizontal() ? 'left' : 'top');\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = createShadow(params, $slideEl, swiper.isHorizontal() ? 'right' : 'bottom');\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n };\n\n const recreateShadows = () => {\n // Set shadows\n const params = swiper.params.flipEffect;\n swiper.slides.each(slideEl => {\n const $slideEl = $(slideEl);\n let progress = $slideEl[0].progress;\n\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min(slideEl.progress, 1), -1);\n }\n\n createSlideShadows($slideEl, progress, params);\n });\n };\n\n const setTranslate = () => {\n const {\n slides,\n rtlTranslate: rtl\n } = swiper;\n const params = swiper.params.flipEffect;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let progress = $slideEl[0].progress;\n\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const rotate = -180 * progress;\n let rotateY = rotate;\n let rotateX = 0;\n let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let ty = 0;\n\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n\n if (params.slideShadows) {\n createSlideShadows($slideEl, progress, params);\n }\n\n const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.flipEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'flip',\n swiper,\n on,\n setTranslate,\n setTransition,\n recreateShadows,\n getEffectParams: () => swiper.params.flipEffect,\n perspective: () => true,\n overwriteParams: () => ({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nexport default function EffectCoverflow({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n width: swiperWidth,\n height: swiperHeight,\n slides,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;\n const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\n }\n\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n\n if (Math.abs(translateX) < 0.001) translateX = 0;\n if (Math.abs(translateY) < 0.001) translateY = 0;\n if (Math.abs(translateZ) < 0.001) translateZ = 0;\n if (Math.abs(rotateY) < 0.001) rotateY = 0;\n if (Math.abs(rotateX) < 0.001) rotateX = 0;\n if (Math.abs(scale) < 0.001) scale = 0;\n const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');\n }\n\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');\n }\n\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n };\n\n effectInit({\n effect: 'coverflow',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true\n })\n });\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectCreative({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n creativeEffect: {\n transformEl: null,\n limitProgress: 1,\n shadowPerProgress: false,\n progressMultiplier: 1,\n perspective: true,\n prev: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n },\n next: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n }\n }\n });\n\n const getTranslateValue = value => {\n if (typeof value === 'string') return value;\n return `${value}px`;\n };\n\n const setTranslate = () => {\n const {\n slides,\n $wrapperEl,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.creativeEffect;\n const {\n progressMultiplier: multiplier\n } = params;\n const isCenteredSlides = swiper.params.centeredSlides;\n\n if (isCenteredSlides) {\n const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);\n let originalProgress = progress;\n\n if (!isCenteredSlides) {\n originalProgress = Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];\n const r = [0, 0, 0];\n let custom = false;\n\n if (!swiper.isHorizontal()) {\n t[1] = t[0];\n t[0] = 0;\n }\n\n let data = {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n scale: 1,\n opacity: 1\n };\n\n if (progress < 0) {\n data = params.next;\n custom = true;\n } else if (progress > 0) {\n data = params.prev;\n custom = true;\n } // set translate\n\n\n t.forEach((value, index) => {\n t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n }); // set rotates\n\n r.forEach((value, index) => {\n r[index] = data.rotate[index] * Math.abs(progress * multiplier);\n });\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const translateString = t.join(', ');\n const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;\n const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;\n const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;\n const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows\n\n if (custom && data.shadow || !custom) {\n let $shadowEl = $slideEl.children('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0 && data.shadow) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) {\n const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n $shadowEl[0].style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n }\n }\n\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform).css({\n opacity: opacityString\n });\n\n if (data.origin) {\n $targetEl.css('transform-origin', data.origin);\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.creativeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl,\n allSlides: true\n });\n };\n\n effectInit({\n effect: 'creative',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => swiper.params.creativeEffect.perspective,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectCards({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cardsEffect: {\n slideShadows: true,\n transformEl: null,\n rotate: true,\n perSlideRotate: 2,\n perSlideOffset: 8\n }\n });\n\n const setTranslate = () => {\n const {\n slides,\n activeIndex\n } = swiper;\n const params = swiper.params.cardsEffect;\n const {\n startTranslate,\n isTouched\n } = swiper.touchEventsData;\n const currentTranslate = swiper.translate;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max(slideProgress, -4), 4);\n let offset = $slideEl[0].swiperSlideOffset;\n\n if (swiper.params.centeredSlides && !swiper.params.cssMode) {\n swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);\n }\n\n if (swiper.params.centeredSlides && swiper.params.cssMode) {\n offset -= slides[0].swiperSlideOffset;\n }\n\n let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let tY = 0;\n const tZ = -100 * Math.abs(progress);\n let scale = 1;\n let rotate = -params.perSlideRotate * progress;\n let tXAdd = params.perSlideOffset - Math.abs(progress) * 0.75;\n const slideIndex = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.from + i : i;\n const isSwipeToNext = (slideIndex === activeIndex || slideIndex === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;\n const isSwipeToPrev = (slideIndex === activeIndex || slideIndex === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;\n\n if (isSwipeToNext || isSwipeToPrev) {\n const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;\n rotate += -28 * progress * subProgress;\n scale += -0.5 * subProgress;\n tXAdd += 96 * subProgress;\n tY = `${-25 * subProgress * Math.abs(progress)}%`;\n }\n\n if (progress < 0) {\n // next\n tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;\n } else if (progress > 0) {\n // prev\n tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;\n } else {\n tX = `${tX}px`;\n }\n\n if (!swiper.isHorizontal()) {\n const prevY = tY;\n tY = tX;\n tX = prevY;\n }\n\n const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;\n const transform = `\n translate3d(${tX}, ${tY}, ${tZ}px)\n rotateZ(${params.rotate ? rotate : 0}deg)\n scale(${scaleString})\n `;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowEl = $slideEl.find('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) $shadowEl[0].style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.cardsEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'cards',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}","/**\n * Swiper 8.4.6\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2023 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: January 17, 2023\n */\n\nexport { default as Swiper, default } from './core/core.js';\nexport { default as Virtual } from './modules/virtual/virtual.js';\nexport { default as Keyboard } from './modules/keyboard/keyboard.js';\nexport { default as Mousewheel } from './modules/mousewheel/mousewheel.js';\nexport { default as Navigation } from './modules/navigation/navigation.js';\nexport { default as Pagination } from './modules/pagination/pagination.js';\nexport { default as Scrollbar } from './modules/scrollbar/scrollbar.js';\nexport { default as Parallax } from './modules/parallax/parallax.js';\nexport { default as Zoom } from './modules/zoom/zoom.js';\nexport { default as Lazy } from './modules/lazy/lazy.js';\nexport { default as Controller } from './modules/controller/controller.js';\nexport { default as A11y } from './modules/a11y/a11y.js';\nexport { default as History } from './modules/history/history.js';\nexport { default as HashNavigation } from './modules/hash-navigation/hash-navigation.js';\nexport { default as Autoplay } from './modules/autoplay/autoplay.js';\nexport { default as Thumbs } from './modules/thumbs/thumbs.js';\nexport { default as FreeMode } from './modules/free-mode/free-mode.js';\nexport { default as Grid } from './modules/grid/grid.js';\nexport { default as Manipulation } from './modules/manipulation/manipulation.js';\nexport { default as EffectFade } from './modules/effect-fade/effect-fade.js';\nexport { default as EffectCube } from './modules/effect-cube/effect-cube.js';\nexport { default as EffectFlip } from './modules/effect-flip/effect-flip.js';\nexport { default as EffectCoverflow } from './modules/effect-coverflow/effect-coverflow.js';\nexport { default as EffectCreative } from './modules/effect-creative/effect-creative.js';\nexport { default as EffectCards } from './modules/effect-cards/effect-cards.js';","\"use strict\";\n(self[\"webpackChunk_N_E\"] = self[\"webpackChunk_N_E\"] || []).push([[719],{\n\n/***/ 30719:\n/***/ (function(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"tq\": function() { return /* reexport */ Swiper; },\n \"o5\": function() { return /* reexport */ SwiperSlide; }\n});\n\n// UNUSED EXPORTS: useSwiper, useSwiperSlide\n\n// EXTERNAL MODULE: ./node_modules/react/index.js\nvar react = __webpack_require__(67294);\n// EXTERNAL MODULE: ./node_modules/swiper/swiper.esm.js + 90 modules\nvar swiper_esm = __webpack_require__(71911);\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/utils.js\nfunction isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction extend(target, src) {\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n Object.keys(src).filter(key => noExtend.indexOf(key) < 0).forEach(key => {\n if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject(src[key]) && isObject(target[key]) && Object.keys(src[key]).length > 0) {\n if (src[key].__swiper__) target[key] = src[key];else extend(target[key], src[key]);\n } else {\n target[key] = src[key];\n }\n });\n}\n\nfunction needsNavigation(params = {}) {\n return params.navigation && typeof params.navigation.nextEl === 'undefined' && typeof params.navigation.prevEl === 'undefined';\n}\n\nfunction needsPagination(params = {}) {\n return params.pagination && typeof params.pagination.el === 'undefined';\n}\n\nfunction needsScrollbar(params = {}) {\n return params.scrollbar && typeof params.scrollbar.el === 'undefined';\n}\n\nfunction uniqueClasses(classNames = '') {\n const classes = classNames.split(' ').map(c => c.trim()).filter(c => !!c);\n const unique = [];\n classes.forEach(c => {\n if (unique.indexOf(c) < 0) unique.push(c);\n });\n return unique.join(' ');\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/params-list.js\n/* underscore in name -> watch for changes */\nconst paramsList = ['modules', 'init', '_direction', 'touchEventsTarget', 'initialSlide', '_speed', 'cssMode', 'updateOnWindowResize', 'resizeObserver', 'nested', 'focusableElements', '_enabled', '_width', '_height', 'preventInteractionOnTransition', 'userAgent', 'url', '_edgeSwipeDetection', '_edgeSwipeThreshold', '_freeMode', '_autoHeight', 'setWrapperSize', 'virtualTranslate', '_effect', 'breakpoints', '_spaceBetween', '_slidesPerView', 'maxBackfaceHiddenSlides', '_grid', '_slidesPerGroup', '_slidesPerGroupSkip', '_slidesPerGroupAuto', '_centeredSlides', '_centeredSlidesBounds', '_slidesOffsetBefore', '_slidesOffsetAfter', 'normalizeSlideIndex', '_centerInsufficientSlides', '_watchOverflow', 'roundLengths', 'touchRatio', 'touchAngle', 'simulateTouch', '_shortSwipes', '_longSwipes', 'longSwipesRatio', 'longSwipesMs', '_followFinger', 'allowTouchMove', '_threshold', 'touchMoveStopPropagation', 'touchStartPreventDefault', 'touchStartForcePreventDefault', 'touchReleaseOnEdges', 'uniqueNavElements', '_resistance', '_resistanceRatio', '_watchSlidesProgress', '_grabCursor', 'preventClicks', 'preventClicksPropagation', '_slideToClickedSlide', '_preloadImages', 'updateOnImagesReady', '_loop', '_loopAdditionalSlides', '_loopedSlides', '_loopedSlidesLimit', '_loopFillGroupWithBlank', 'loopPreventsSlide', '_rewind', '_allowSlidePrev', '_allowSlideNext', '_swipeHandler', '_noSwiping', 'noSwipingClass', 'noSwipingSelector', 'passiveListeners', 'containerModifierClass', 'slideClass', 'slideBlankClass', 'slideActiveClass', 'slideDuplicateActiveClass', 'slideVisibleClass', 'slideDuplicateClass', 'slideNextClass', 'slideDuplicateNextClass', 'slidePrevClass', 'slideDuplicatePrevClass', 'wrapperClass', 'runCallbacksOnInit', 'observer', 'observeParents', 'observeSlideChildren', // modules\n'a11y', '_autoplay', '_controller', 'coverflowEffect', 'cubeEffect', 'fadeEffect', 'flipEffect', 'creativeEffect', 'cardsEffect', 'hashNavigation', 'history', 'keyboard', 'lazy', 'mousewheel', '_navigation', '_pagination', 'parallax', '_scrollbar', '_thumbs', 'virtual', 'zoom'];\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/get-params.js\n\n\n\n\nfunction getParams(obj = {}, splitEvents = true) {\n const params = {\n on: {}\n };\n const events = {};\n const passedParams = {};\n extend(params, swiper_esm/* default.defaults */.ZP.defaults);\n extend(params, swiper_esm/* default.extendedDefaults */.ZP.extendedDefaults);\n params._emitClasses = true;\n params.init = false;\n const rest = {};\n const allowedParams = paramsList.map(key => key.replace(/_/, ''));\n const plainObj = Object.assign({}, obj);\n Object.keys(plainObj).forEach(key => {\n if (typeof obj[key] === 'undefined') return;\n\n if (allowedParams.indexOf(key) >= 0) {\n if (isObject(obj[key])) {\n params[key] = {};\n passedParams[key] = {};\n extend(params[key], obj[key]);\n extend(passedParams[key], obj[key]);\n } else {\n params[key] = obj[key];\n passedParams[key] = obj[key];\n }\n } else if (key.search(/on[A-Z]/) === 0 && typeof obj[key] === 'function') {\n if (splitEvents) {\n events[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n } else {\n params.on[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n }\n } else {\n rest[key] = obj[key];\n }\n });\n ['navigation', 'pagination', 'scrollbar'].forEach(key => {\n if (params[key] === true) params[key] = {};\n if (params[key] === false) delete params[key];\n });\n return {\n params,\n passedParams,\n rest,\n events\n };\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/mount-swiper.js\n\n\nfunction mountSwiper({\n el,\n nextEl,\n prevEl,\n paginationEl,\n scrollbarEl,\n swiper\n}, swiperParams) {\n if (needsNavigation(swiperParams) && nextEl && prevEl) {\n swiper.params.navigation.nextEl = nextEl;\n swiper.originalParams.navigation.nextEl = nextEl;\n swiper.params.navigation.prevEl = prevEl;\n swiper.originalParams.navigation.prevEl = prevEl;\n }\n\n if (needsPagination(swiperParams) && paginationEl) {\n swiper.params.pagination.el = paginationEl;\n swiper.originalParams.pagination.el = paginationEl;\n }\n\n if (needsScrollbar(swiperParams) && scrollbarEl) {\n swiper.params.scrollbar.el = scrollbarEl;\n swiper.originalParams.scrollbar.el = scrollbarEl;\n }\n\n swiper.init(el);\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/calc-looped-slides.js\n\nconst calcLoopedSlides = (slides, swiperParams) => {\n let slidesPerViewParams = swiperParams.slidesPerView;\n\n if (swiperParams.breakpoints) {\n const breakpoint = swiper_esm/* default.prototype.getBreakpoint */.ZP.prototype.getBreakpoint(swiperParams.breakpoints);\n const breakpointOnlyParams = breakpoint in swiperParams.breakpoints ? swiperParams.breakpoints[breakpoint] : undefined;\n\n if (breakpointOnlyParams && breakpointOnlyParams.slidesPerView) {\n slidesPerViewParams = breakpointOnlyParams.slidesPerView;\n }\n }\n\n let loopedSlides = Math.ceil(parseFloat(swiperParams.loopedSlides || slidesPerViewParams, 10));\n loopedSlides += swiperParams.loopAdditionalSlides;\n\n if (loopedSlides > slides.length && swiperParams.loopedSlidesLimit) {\n loopedSlides = slides.length;\n }\n\n return loopedSlides;\n};\n;// CONCATENATED MODULE: ./node_modules/swiper/react/loop.js\n\n\n\nfunction renderLoop(swiper, slides, swiperParams) {\n const modifiedSlides = slides.map((child, index) => {\n return /*#__PURE__*/react.cloneElement(child, {\n swiper,\n 'data-swiper-slide-index': index\n });\n });\n\n function duplicateSlide(child, index, position) {\n return /*#__PURE__*/react.cloneElement(child, {\n key: `${child.key}-duplicate-${index}-${position}`,\n className: `${child.props.className || ''} ${swiperParams.slideDuplicateClass}`\n });\n }\n\n if (swiperParams.loopFillGroupWithBlank) {\n const blankSlidesNum = swiperParams.slidesPerGroup - modifiedSlides.length % swiperParams.slidesPerGroup;\n\n if (blankSlidesNum !== swiperParams.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankSlide = /*#__PURE__*/react.createElement(\"div\", {\n className: `${swiperParams.slideClass} ${swiperParams.slideBlankClass}`\n });\n modifiedSlides.push(blankSlide);\n }\n }\n }\n\n if (swiperParams.slidesPerView === 'auto' && !swiperParams.loopedSlides) {\n swiperParams.loopedSlides = modifiedSlides.length;\n }\n\n const loopedSlides = calcLoopedSlides(modifiedSlides, swiperParams);\n const prependSlides = [];\n const appendSlides = [];\n\n for (let i = 0; i < loopedSlides; i += 1) {\n const index = i - Math.floor(i / modifiedSlides.length) * modifiedSlides.length;\n appendSlides.push(duplicateSlide(modifiedSlides[index], i, 'append'));\n prependSlides.unshift(duplicateSlide(modifiedSlides[modifiedSlides.length - index - 1], i, 'prepend'));\n }\n\n if (swiper) {\n swiper.loopedSlides = loopedSlides;\n }\n\n return [...prependSlides, ...modifiedSlides, ...appendSlides];\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/get-changed-params.js\n\n\n\nfunction getChangedParams(swiperParams, oldParams, children, oldChildren, getKey) {\n const keys = [];\n if (!oldParams) return keys;\n\n const addKey = key => {\n if (keys.indexOf(key) < 0) keys.push(key);\n };\n\n if (children && oldChildren) {\n const oldChildrenKeys = oldChildren.map(getKey);\n const childrenKeys = children.map(getKey);\n if (oldChildrenKeys.join('') !== childrenKeys.join('')) addKey('children');\n if (oldChildren.length !== children.length) addKey('children');\n }\n\n const watchParams = paramsList.filter(key => key[0] === '_').map(key => key.replace(/_/, ''));\n watchParams.forEach(key => {\n if (key in swiperParams && key in oldParams) {\n if (isObject(swiperParams[key]) && isObject(oldParams[key])) {\n const newKeys = Object.keys(swiperParams[key]);\n const oldKeys = Object.keys(oldParams[key]);\n\n if (newKeys.length !== oldKeys.length) {\n addKey(key);\n } else {\n newKeys.forEach(newKey => {\n if (swiperParams[key][newKey] !== oldParams[key][newKey]) {\n addKey(key);\n }\n });\n oldKeys.forEach(oldKey => {\n if (swiperParams[key][oldKey] !== oldParams[key][oldKey]) addKey(key);\n });\n }\n } else if (swiperParams[key] !== oldParams[key]) {\n addKey(key);\n }\n }\n });\n return keys;\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/react/get-children.js\n\n\nfunction isChildSwiperSlide(child) {\n return child.type && child.type.displayName && child.type.displayName.includes('SwiperSlide');\n}\n\nfunction processChildren(c) {\n const slides = [];\n react.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.children) {\n processChildren(child.props.children).forEach(slide => slides.push(slide));\n }\n });\n return slides;\n}\n\nfunction getChildren(c) {\n const slides = [];\n const slots = {\n 'container-start': [],\n 'container-end': [],\n 'wrapper-start': [],\n 'wrapper-end': []\n };\n react.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.slot && slots[child.props.slot]) {\n slots[child.props.slot].push(child);\n } else if (child.props && child.props.children) {\n const foundSlides = processChildren(child.props.children);\n\n if (foundSlides.length > 0) {\n foundSlides.forEach(slide => slides.push(slide));\n } else {\n slots['container-end'].push(child);\n }\n } else {\n slots['container-end'].push(child);\n }\n });\n return {\n slides,\n slots\n };\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/update-swiper.js\n\n\nfunction updateSwiper({\n swiper,\n slides,\n passedParams,\n changedParams,\n nextEl,\n prevEl,\n scrollbarEl,\n paginationEl\n}) {\n const updateParams = changedParams.filter(key => key !== 'children' && key !== 'direction');\n const {\n params: currentParams,\n pagination,\n navigation,\n scrollbar,\n virtual,\n thumbs\n } = swiper;\n let needThumbsInit;\n let needControllerInit;\n let needPaginationInit;\n let needScrollbarInit;\n let needNavigationInit;\n\n if (changedParams.includes('thumbs') && passedParams.thumbs && passedParams.thumbs.swiper && currentParams.thumbs && !currentParams.thumbs.swiper) {\n needThumbsInit = true;\n }\n\n if (changedParams.includes('controller') && passedParams.controller && passedParams.controller.control && currentParams.controller && !currentParams.controller.control) {\n needControllerInit = true;\n }\n\n if (changedParams.includes('pagination') && passedParams.pagination && (passedParams.pagination.el || paginationEl) && (currentParams.pagination || currentParams.pagination === false) && pagination && !pagination.el) {\n needPaginationInit = true;\n }\n\n if (changedParams.includes('scrollbar') && passedParams.scrollbar && (passedParams.scrollbar.el || scrollbarEl) && (currentParams.scrollbar || currentParams.scrollbar === false) && scrollbar && !scrollbar.el) {\n needScrollbarInit = true;\n }\n\n if (changedParams.includes('navigation') && passedParams.navigation && (passedParams.navigation.prevEl || prevEl) && (passedParams.navigation.nextEl || nextEl) && (currentParams.navigation || currentParams.navigation === false) && navigation && !navigation.prevEl && !navigation.nextEl) {\n needNavigationInit = true;\n }\n\n const destroyModule = mod => {\n if (!swiper[mod]) return;\n swiper[mod].destroy();\n\n if (mod === 'navigation') {\n currentParams[mod].prevEl = undefined;\n currentParams[mod].nextEl = undefined;\n swiper[mod].prevEl = undefined;\n swiper[mod].nextEl = undefined;\n } else {\n currentParams[mod].el = undefined;\n swiper[mod].el = undefined;\n }\n };\n\n updateParams.forEach(key => {\n if (isObject(currentParams[key]) && isObject(passedParams[key])) {\n extend(currentParams[key], passedParams[key]);\n } else {\n const newValue = passedParams[key];\n\n if ((newValue === true || newValue === false) && (key === 'navigation' || key === 'pagination' || key === 'scrollbar')) {\n if (newValue === false) {\n destroyModule(key);\n }\n } else {\n currentParams[key] = passedParams[key];\n }\n }\n });\n\n if (updateParams.includes('controller') && !needControllerInit && swiper.controller && swiper.controller.control && currentParams.controller && currentParams.controller.control) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (changedParams.includes('children') && slides && virtual && currentParams.virtual.enabled) {\n virtual.slides = slides;\n virtual.update(true);\n } else if (changedParams.includes('children') && swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (needThumbsInit) {\n const initialized = thumbs.init();\n if (initialized) thumbs.update(true);\n }\n\n if (needControllerInit) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (needPaginationInit) {\n if (paginationEl) currentParams.pagination.el = paginationEl;\n pagination.init();\n pagination.render();\n pagination.update();\n }\n\n if (needScrollbarInit) {\n if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;\n scrollbar.init();\n scrollbar.updateSize();\n scrollbar.setTranslate();\n }\n\n if (needNavigationInit) {\n if (nextEl) currentParams.navigation.nextEl = nextEl;\n if (prevEl) currentParams.navigation.prevEl = prevEl;\n navigation.init();\n navigation.update();\n }\n\n if (changedParams.includes('allowSlideNext')) {\n swiper.allowSlideNext = passedParams.allowSlideNext;\n }\n\n if (changedParams.includes('allowSlidePrev')) {\n swiper.allowSlidePrev = passedParams.allowSlidePrev;\n }\n\n if (changedParams.includes('direction')) {\n swiper.changeDirection(passedParams.direction, false);\n }\n\n swiper.update();\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/react/virtual.js\n\n\nfunction renderVirtual(swiper, slides, virtualData) {\n if (!virtualData) return null;\n const style = swiper.isHorizontal() ? {\n [swiper.rtlTranslate ? 'right' : 'left']: `${virtualData.offset}px`\n } : {\n top: `${virtualData.offset}px`\n };\n return slides.filter((child, index) => index >= virtualData.from && index <= virtualData.to).map(child => {\n return /*#__PURE__*/react.cloneElement(child, {\n swiper,\n style\n });\n });\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/components-shared/update-on-virtual-data.js\nconst updateOnVirtualData = swiper => {\n if (!swiper || swiper.destroyed || !swiper.params.virtual || swiper.params.virtual && !swiper.params.virtual.enabled) return;\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (swiper.parallax && swiper.params.parallax && swiper.params.parallax.enabled) {\n swiper.parallax.setTranslate();\n }\n};\n;// CONCATENATED MODULE: ./node_modules/swiper/react/use-isomorphic-layout-effect.js\n\n\nfunction useIsomorphicLayoutEffect(callback, deps) {\n // eslint-disable-next-line\n if (typeof window === 'undefined') return (0,react.useEffect)(callback, deps);\n return (0,react.useLayoutEffect)(callback, deps);\n}\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/react/context.js\n\nconst SwiperSlideContext = /*#__PURE__*/(0,react.createContext)(null);\nconst useSwiperSlide = () => {\n return useContext(SwiperSlideContext);\n};\nconst SwiperContext = /*#__PURE__*/(0,react.createContext)(null);\nconst useSwiper = () => {\n return useContext(SwiperContext);\n};\n;// CONCATENATED MODULE: ./node_modules/swiper/react/swiper.js\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst Swiper = /*#__PURE__*/(0,react.forwardRef)(function (_temp, externalElRef) {\n let {\n className,\n tag: Tag = 'div',\n wrapperTag: WrapperTag = 'div',\n children,\n onSwiper,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n let eventsAssigned = false;\n const [containerClasses, setContainerClasses] = (0,react.useState)('swiper');\n const [virtualData, setVirtualData] = (0,react.useState)(null);\n const [breakpointChanged, setBreakpointChanged] = (0,react.useState)(false);\n const initializedRef = (0,react.useRef)(false);\n const swiperElRef = (0,react.useRef)(null);\n const swiperRef = (0,react.useRef)(null);\n const oldPassedParamsRef = (0,react.useRef)(null);\n const oldSlides = (0,react.useRef)(null);\n const nextElRef = (0,react.useRef)(null);\n const prevElRef = (0,react.useRef)(null);\n const paginationElRef = (0,react.useRef)(null);\n const scrollbarElRef = (0,react.useRef)(null);\n const {\n params: swiperParams,\n passedParams,\n rest: restProps,\n events\n } = getParams(rest);\n const {\n slides,\n slots\n } = getChildren(children);\n\n const onBeforeBreakpoint = () => {\n setBreakpointChanged(!breakpointChanged);\n };\n\n Object.assign(swiperParams.on, {\n _containerClasses(swiper, classes) {\n setContainerClasses(classes);\n }\n\n });\n\n const initSwiper = () => {\n // init swiper\n Object.assign(swiperParams.on, events);\n eventsAssigned = true;\n swiperRef.current = new swiper_esm/* default */.ZP(swiperParams);\n\n swiperRef.current.loopCreate = () => {};\n\n swiperRef.current.loopDestroy = () => {};\n\n if (swiperParams.loop) {\n swiperRef.current.loopedSlides = calcLoopedSlides(slides, swiperParams);\n }\n\n if (swiperRef.current.virtual && swiperRef.current.params.virtual.enabled) {\n swiperRef.current.virtual.slides = slides;\n const extendWith = {\n cache: false,\n slides,\n renderExternal: setVirtualData,\n renderExternalUpdate: false\n };\n extend(swiperRef.current.params.virtual, extendWith);\n extend(swiperRef.current.originalParams.virtual, extendWith);\n }\n };\n\n if (!swiperElRef.current) {\n initSwiper();\n } // Listen for breakpoints change\n\n\n if (swiperRef.current) {\n swiperRef.current.on('_beforeBreakpoint', onBeforeBreakpoint);\n }\n\n const attachEvents = () => {\n if (eventsAssigned || !events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.on(eventName, events[eventName]);\n });\n };\n\n const detachEvents = () => {\n if (!events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.off(eventName, events[eventName]);\n });\n };\n\n (0,react.useEffect)(() => {\n return () => {\n if (swiperRef.current) swiperRef.current.off('_beforeBreakpoint', onBeforeBreakpoint);\n };\n }); // set initialized flag\n\n (0,react.useEffect)(() => {\n if (!initializedRef.current && swiperRef.current) {\n swiperRef.current.emitSlidesClasses();\n initializedRef.current = true;\n }\n }); // mount swiper\n\n useIsomorphicLayoutEffect(() => {\n if (externalElRef) {\n externalElRef.current = swiperElRef.current;\n }\n\n if (!swiperElRef.current) return;\n\n if (swiperRef.current.destroyed) {\n initSwiper();\n }\n\n mountSwiper({\n el: swiperElRef.current,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n paginationEl: paginationElRef.current,\n scrollbarEl: scrollbarElRef.current,\n swiper: swiperRef.current\n }, swiperParams);\n if (onSwiper) onSwiper(swiperRef.current); // eslint-disable-next-line\n\n return () => {\n if (swiperRef.current && !swiperRef.current.destroyed) {\n swiperRef.current.destroy(true, false);\n }\n };\n }, []); // watch for params change\n\n useIsomorphicLayoutEffect(() => {\n attachEvents();\n const changedParams = getChangedParams(passedParams, oldPassedParamsRef.current, slides, oldSlides.current, c => c.key);\n oldPassedParamsRef.current = passedParams;\n oldSlides.current = slides;\n\n if (changedParams.length && swiperRef.current && !swiperRef.current.destroyed) {\n updateSwiper({\n swiper: swiperRef.current,\n slides,\n passedParams,\n changedParams,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n scrollbarEl: scrollbarElRef.current,\n paginationEl: paginationElRef.current\n });\n }\n\n return () => {\n detachEvents();\n };\n }); // update on virtual update\n\n useIsomorphicLayoutEffect(() => {\n updateOnVirtualData(swiperRef.current);\n }, [virtualData]); // bypass swiper instance to slides\n\n function renderSlides() {\n if (swiperParams.virtual) {\n return renderVirtual(swiperRef.current, slides, virtualData);\n }\n\n if (!swiperParams.loop || swiperRef.current && swiperRef.current.destroyed) {\n return slides.map(child => {\n return /*#__PURE__*/react.cloneElement(child, {\n swiper: swiperRef.current\n });\n });\n }\n\n return renderLoop(swiperRef.current, slides, swiperParams);\n }\n\n return /*#__PURE__*/react.createElement(Tag, _extends({\n ref: swiperElRef,\n className: uniqueClasses(`${containerClasses}${className ? ` ${className}` : ''}`)\n }, restProps), /*#__PURE__*/react.createElement(SwiperContext.Provider, {\n value: swiperRef.current\n }, slots['container-start'], /*#__PURE__*/react.createElement(WrapperTag, {\n className: \"swiper-wrapper\"\n }, slots['wrapper-start'], renderSlides(), slots['wrapper-end']), needsNavigation(swiperParams) && /*#__PURE__*/react.createElement(react.Fragment, null, /*#__PURE__*/react.createElement(\"div\", {\n ref: prevElRef,\n className: \"swiper-button-prev\"\n }), /*#__PURE__*/react.createElement(\"div\", {\n ref: nextElRef,\n className: \"swiper-button-next\"\n })), needsScrollbar(swiperParams) && /*#__PURE__*/react.createElement(\"div\", {\n ref: scrollbarElRef,\n className: \"swiper-scrollbar\"\n }), needsPagination(swiperParams) && /*#__PURE__*/react.createElement(\"div\", {\n ref: paginationElRef,\n className: \"swiper-pagination\"\n }), slots['container-end']));\n});\nSwiper.displayName = 'Swiper';\n\n;// CONCATENATED MODULE: ./node_modules/swiper/react/swiper-slide.js\nfunction swiper_slide_extends() { swiper_slide_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return swiper_slide_extends.apply(this, arguments); }\n\n\n\n\n\nconst SwiperSlide = /*#__PURE__*/(0,react.forwardRef)(function (_temp, externalRef) {\n let {\n tag: Tag = 'div',\n children,\n className = '',\n swiper,\n zoom,\n virtualIndex,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n const slideElRef = (0,react.useRef)(null);\n const [slideClasses, setSlideClasses] = (0,react.useState)('swiper-slide');\n\n function updateClasses(_s, el, classNames) {\n if (el === slideElRef.current) {\n setSlideClasses(classNames);\n }\n }\n\n useIsomorphicLayoutEffect(() => {\n if (externalRef) {\n externalRef.current = slideElRef.current;\n }\n\n if (!slideElRef.current || !swiper) {\n return;\n }\n\n if (swiper.destroyed) {\n if (slideClasses !== 'swiper-slide') {\n setSlideClasses('swiper-slide');\n }\n\n return;\n }\n\n swiper.on('_slideClass', updateClasses); // eslint-disable-next-line\n\n return () => {\n if (!swiper) return;\n swiper.off('_slideClass', updateClasses);\n };\n });\n useIsomorphicLayoutEffect(() => {\n if (swiper && slideElRef.current && !swiper.destroyed) {\n setSlideClasses(swiper.getSlideClasses(slideElRef.current));\n }\n }, [swiper]);\n const slideData = {\n isActive: slideClasses.indexOf('swiper-slide-active') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-active') >= 0,\n isVisible: slideClasses.indexOf('swiper-slide-visible') >= 0,\n isDuplicate: slideClasses.indexOf('swiper-slide-duplicate') >= 0,\n isPrev: slideClasses.indexOf('swiper-slide-prev') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-prev') >= 0,\n isNext: slideClasses.indexOf('swiper-slide-next') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-next') >= 0\n };\n\n const renderChildren = () => {\n return typeof children === 'function' ? children(slideData) : children;\n };\n\n return /*#__PURE__*/react.createElement(Tag, swiper_slide_extends({\n ref: slideElRef,\n className: uniqueClasses(`${slideClasses}${className ? ` ${className}` : ''}`),\n \"data-swiper-slide-index\": virtualIndex\n }, rest), /*#__PURE__*/react.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, zoom ? /*#__PURE__*/react.createElement(\"div\", {\n className: \"swiper-zoom-container\",\n \"data-swiper-zoom\": typeof zoom === 'number' ? zoom : undefined\n }, renderChildren()) : renderChildren()));\n});\nSwiperSlide.displayName = 'SwiperSlide';\n\n;// CONCATENATED MODULE: ./node_modules/swiper/react/swiper-react.js\n/**\n * Swiper React 8.4.6\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2023 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: January 17, 2023\n */\n\n\n\n\n\n\n/***/ }),\n\n/***/ 71911:\n/***/ (function(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"W_\": function() { return /* reexport */ Navigation; },\n \"tl\": function() { return /* reexport */ Pagination; },\n \"ZP\": function() { return /* reexport */ core; }\n});\n\n// UNUSED EXPORTS: A11y, Autoplay, Controller, EffectCards, EffectCoverflow, EffectCreative, EffectCube, EffectFade, EffectFlip, FreeMode, Grid, HashNavigation, History, Keyboard, Lazy, Manipulation, Mousewheel, Parallax, Scrollbar, Swiper, Thumbs, Virtual, Zoom\n\n;// CONCATENATED MODULE: ./node_modules/ssr-window/ssr-window.esm.js\n/**\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 ssr_window_esm_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 (ssr_window_esm_isObject(src[key]) &&\n ssr_window_esm_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 ssr_window_esm_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 ssr_window_esm_getWindow() {\n const win = typeof window !== 'undefined' ? window : {};\n extend(win, ssrWindow);\n return win;\n}\n\n\n\n;// CONCATENATED MODULE: ./node_modules/dom7/dom7.esm.js\n/**\n * Dom7 4.0.6\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2023, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: February 2, 2023\n */\n\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 dom7_esm_$(selector, context) {\n const window = ssr_window_esm_getWindow();\n const document = ssr_window_esm_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(' 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 (dom7_esm_$(target).is(targetSelector)) listener.apply(target, eventData);else {\n const parents = dom7_esm_$(target).parents(); // eslint-disable-line\n\n for (let k = 0; k < parents.length; k += 1) {\n if (dom7_esm_$(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 = ssr_window_esm_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 transitionStart(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionstart', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionstart', fireCallBack);\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 dom7_esm_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 dom7_esm_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 = ssr_window_esm_getWindow();\n const document = ssr_window_esm_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 = ssr_window_esm_getWindow();\n if (this[0]) return window.getComputedStyle(this[0], null);\n return {};\n}\n\nfunction css(props, value) {\n const window = ssr_window_esm_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 dom7_esm_$(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 dom7_esm_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 = ssr_window_esm_getWindow();\n const document = ssr_window_esm_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 = dom7_esm_$(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 dom7_esm_$([]);\n }\n\n if (index < 0) {\n const returnIndex = length + index;\n if (returnIndex < 0) return dom7_esm_$([]);\n return dom7_esm_$([this[returnIndex]]);\n }\n\n return dom7_esm_$([this[index]]);\n}\n\nfunction append(...els) {\n let newChild;\n const document = ssr_window_esm_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 dom7_esm_$(parent).append(this);\n return this;\n}\n\nfunction prepend(newChild) {\n const document = ssr_window_esm_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 dom7_esm_$(parent).prepend(this);\n return this;\n}\n\nfunction insertBefore(selector) {\n const before = dom7_esm_$(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 = dom7_esm_$(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 && dom7_esm_$(this[0].nextElementSibling).is(selector)) {\n return dom7_esm_$([this[0].nextElementSibling]);\n }\n\n return dom7_esm_$([]);\n }\n\n if (this[0].nextElementSibling) return dom7_esm_$([this[0].nextElementSibling]);\n return dom7_esm_$([]);\n }\n\n return dom7_esm_$([]);\n}\n\nfunction nextAll(selector) {\n const nextEls = [];\n let el = this[0];\n if (!el) return dom7_esm_$([]);\n\n while (el.nextElementSibling) {\n const next = el.nextElementSibling; // eslint-disable-line\n\n if (selector) {\n if (dom7_esm_$(next).is(selector)) nextEls.push(next);\n } else nextEls.push(next);\n\n el = next;\n }\n\n return dom7_esm_$(nextEls);\n}\n\nfunction prev(selector) {\n if (this.length > 0) {\n const el = this[0];\n\n if (selector) {\n if (el.previousElementSibling && dom7_esm_$(el.previousElementSibling).is(selector)) {\n return dom7_esm_$([el.previousElementSibling]);\n }\n\n return dom7_esm_$([]);\n }\n\n if (el.previousElementSibling) return dom7_esm_$([el.previousElementSibling]);\n return dom7_esm_$([]);\n }\n\n return dom7_esm_$([]);\n}\n\nfunction prevAll(selector) {\n const prevEls = [];\n let el = this[0];\n if (!el) return dom7_esm_$([]);\n\n while (el.previousElementSibling) {\n const prev = el.previousElementSibling; // eslint-disable-line\n\n if (selector) {\n if (dom7_esm_$(prev).is(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n\n el = prev;\n }\n\n return dom7_esm_$(prevEls);\n}\n\nfunction siblings(selector) {\n return this.nextAll(selector).add(this.prevAll(selector));\n}\n\nfunction dom7_esm_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 (dom7_esm_$(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n\n return dom7_esm_$(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 (dom7_esm_$(parent).is(selector)) parents.push(parent);\n } else {\n parents.push(parent);\n }\n\n parent = parent.parentNode;\n }\n }\n\n return dom7_esm_$(parents);\n}\n\nfunction closest(selector) {\n let closest = this; // eslint-disable-line\n\n if (typeof selector === 'undefined') {\n return dom7_esm_$([]);\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 dom7_esm_$(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 || dom7_esm_$(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n\n return dom7_esm_$(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 = dom7_esm_$(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 dom7_esm_$(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 dom7_esm_blur = shortcut('blur');\nconst dom7_esm_focus = shortcut('focus');\nconst focusin = shortcut('focusin');\nconst focusout = shortcut('focusout');\nconst keyup = shortcut('keyup');\nconst keydown = shortcut('keydown');\nconst keypress = shortcut('keypress');\nconst dom7_esm_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 dom7_esm_scroll = shortcut('scroll');\n\n/* harmony default export */ var dom7_esm = ((/* unused pure expression or super */ null && (dom7_esm_$)));\n\n\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/dom.js\n\nconst Methods = {\n addClass: addClass,\n removeClass: removeClass,\n hasClass: hasClass,\n toggleClass: toggleClass,\n attr: attr,\n removeAttr: removeAttr,\n transform: transform,\n transition: transition,\n on: on,\n off: off,\n trigger: trigger,\n transitionEnd: transitionEnd,\n outerWidth: dom7_esm_outerWidth,\n outerHeight: dom7_esm_outerHeight,\n styles: styles,\n offset: offset,\n css: css,\n each: each,\n html: html,\n text: dom7_esm_text,\n is: is,\n index: index,\n eq: eq,\n append: append,\n prepend: prepend,\n next: next,\n nextAll: nextAll,\n prev: prev,\n prevAll: prevAll,\n parent: dom7_esm_parent,\n parents: parents,\n closest: closest,\n find: find,\n children: children,\n filter: filter,\n remove: remove\n};\nObject.keys(Methods).forEach(methodName => {\n Object.defineProperty(dom7_esm_$.fn, methodName, {\n value: Methods[methodName],\n writable: true\n });\n});\n/* harmony default export */ var dom = (dom7_esm_$);\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/utils.js\n\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 utils_nextTick(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\n\nfunction utils_now() {\n return Date.now();\n}\n\nfunction utils_getComputedStyle(el) {\n const window = ssr_window_esm_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 utils_getTranslate(el, axis = 'x') {\n const window = ssr_window_esm_getWindow();\n let matrix;\n let curTransform;\n let transformMatrix;\n const curStyle = utils_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 utils_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 utils_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 (utils_isObject(to[nextKey]) && utils_isObject(nextSource[nextKey])) {\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n utils_extend(to[nextKey], nextSource[nextKey]);\n }\n } else if (!utils_isObject(to[nextKey]) && utils_isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n utils_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 utils_setCSSProperty(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\n}\n\nfunction animateCSSModeScroll({\n swiper,\n targetPosition,\n side\n}) {\n const window = ssr_window_esm_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\n\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/get-support.js\n\nlet support;\n\nfunction calcSupport() {\n const window = ssr_window_esm_getWindow();\n const document = ssr_window_esm_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\n\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/get-device.js\n\n\nlet deviceCached;\n\nfunction calcDevice({\n userAgent\n} = {}) {\n const support = getSupport();\n const window = ssr_window_esm_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\n\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/get-browser.js\n\nlet browser;\n\nfunction calcBrowser() {\n const window = ssr_window_esm_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\n\n;// CONCATENATED MODULE: ./node_modules/swiper/core/modules/resize/resize.js\n\nfunction Resize({\n swiper,\n on,\n emit\n}) {\n const window = ssr_window_esm_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/modules/observer/observer.js\n\nfunction Observer({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const observers = [];\n const window = ssr_window_esm_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events-emitter.js\n/* eslint-disable no-underscore-dangle */\n/* harmony default export */ var events_emitter = ({\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});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateSize.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateSlides.js\n\nfunction 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 utils_setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');\n utils_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 utils_setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n utils_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateAutoHeight.js\n\nfunction 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 || dom([])).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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateSlidesOffset.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateSlidesProgress.js\n\nfunction 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 = dom(swiper.visibleSlides);\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateProgress.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateSlidesClasses.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateActiveIndex.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/updateClickedSlide.js\n\nfunction updateClickedSlide(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = dom(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(dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/update/index.js\n\n\n\n\n\n\n\n\n\n/* harmony default export */ var update = ({\n updateSize: updateSize,\n updateSlides: updateSlides,\n updateAutoHeight: updateAutoHeight,\n updateSlidesOffset: updateSlidesOffset,\n updateSlidesProgress: updateSlidesProgress,\n updateProgress: updateProgress,\n updateSlidesClasses: updateSlidesClasses,\n updateActiveIndex: updateActiveIndex,\n updateClickedSlide: updateClickedSlide\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/getTranslate.js\n\nfunction 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 = utils_getTranslate($wrapperEl[0], axis);\n if (rtl) currentTranslate = -currentTranslate;\n return currentTranslate || 0;\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/setTranslate.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/minTranslate.js\nfunction minTranslate() {\n return -this.snapGrid[0];\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/maxTranslate.js\nfunction maxTranslate() {\n return -this.snapGrid[this.snapGrid.length - 1];\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/translateTo.js\n\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/translate/index.js\n\n\n\n\n\n/* harmony default export */ var translate = ({\n getTranslate: getSwiperTranslate,\n setTranslate: setTranslate,\n minTranslate: minTranslate,\n maxTranslate: maxTranslate,\n translateTo: translateTo\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/transition/setTransition.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/transition/transitionEmit.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/transition/transitionStart.js\n\nfunction transitionStart_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/transition/transitionEnd.js\n\nfunction transitionEnd_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/transition/index.js\n\n\n\n/* harmony default export */ var core_transition = ({\n setTransition: setTransition,\n transitionStart: transitionStart_transitionStart,\n transitionEnd: transitionEnd_transitionEnd\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideTo.js\n\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideToLoop.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideNext.js\n/* eslint no-unused-vars: \"off\" */\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slidePrev.js\n/* eslint no-unused-vars: \"off\" */\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideReset.js\n/* eslint no-unused-vars: \"off\" */\nfunction slideReset(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideToClosest.js\n/* eslint no-unused-vars: \"off\" */\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/slideToClickedSlide.js\n\n\nfunction 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(dom(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 utils_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 utils_nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/slide/index.js\n\n\n\n\n\n\n\n/* harmony default export */ var slide = ({\n slideTo: slideTo,\n slideToLoop: slideToLoop,\n slideNext: slideNext,\n slidePrev: slidePrev,\n slideReset: slideReset,\n slideToClosest: slideToClosest,\n slideToClickedSlide: slideToClickedSlide\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/loop/loopCreate.js\n\n\nfunction loopCreate() {\n const swiper = this;\n const document = ssr_window_esm_getDocument();\n const {\n params,\n $wrapperEl\n } = swiper; // Remove duplicated slides\n\n const $selector = $wrapperEl.children().length > 0 ? dom($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 = dom(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 = dom(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(dom(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n\n for (let i = prependSlides.length - 1; i >= 0; i -= 1) {\n $selector.prepend(dom(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/loop/loopFix.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/loop/loopDestroy.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/loop/index.js\n\n\n\n/* harmony default export */ var loop = ({\n loopCreate: loopCreate,\n loopFix: loopFix,\n loopDestroy: loopDestroy\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/grab-cursor/setGrabCursor.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/grab-cursor/unsetGrabCursor.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/grab-cursor/index.js\n\n\n/* harmony default export */ var grab_cursor = ({\n setGrabCursor: setGrabCursor,\n unsetGrabCursor: unsetGrabCursor\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onTouchStart.js\n\n\n // 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 === ssr_window_esm_getDocument() || el === ssr_window_esm_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\nfunction onTouchStart(event) {\n const swiper = this;\n const document = ssr_window_esm_getDocument();\n const window = ssr_window_esm_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 = dom(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 = dom(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 = utils_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 && dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onTouchMove.js\n\n\n\nfunction onTouchMove(event) {\n const document = ssr_window_esm_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 (!dom(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 = utils_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 && dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onTouchEnd.js\n\nfunction 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 = utils_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 = utils_now();\n utils_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onResize.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onClick.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/onScroll.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/events/index.js\n\n\n\n\n\n\n\nlet dummyEventAttached = false;\n\nfunction dummyEventListener() {}\n\nconst events = (swiper, method) => {\n const document = ssr_window_esm_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 = ssr_window_esm_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\n/* harmony default export */ var core_events = ({\n attachEvents,\n detachEvents\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/breakpoints/setBreakpoint.js\n\n\nconst isGridEnabled = (swiper, params) => {\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\n\nfunction 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 utils_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/breakpoints/getBreakpoint.js\n\nfunction getBreakpoint(breakpoints, base = 'window', containerEl) {\n if (!breakpoints || base === 'container' && !containerEl) return undefined;\n let breakpoint = false;\n const window = ssr_window_esm_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/breakpoints/index.js\n\n\n/* harmony default export */ var breakpoints = ({\n setBreakpoint: setBreakpoint,\n getBreakpoint: getBreakpoint\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/classes/addClasses.js\nfunction 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\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/classes/removeClasses.js\nfunction removeClasses() {\n const swiper = this;\n const {\n $el,\n classNames\n } = swiper;\n $el.removeClass(classNames.join(' '));\n swiper.emitContainerClasses();\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/classes/index.js\n\n\n/* harmony default export */ var classes = ({\n addClasses: addClasses,\n removeClasses: removeClasses\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/images/loadImage.js\n\n\nfunction loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {\n const window = ssr_window_esm_getWindow();\n let image;\n\n function onReady() {\n if (callback) callback();\n }\n\n const isPicture = dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/images/preloadImages.js\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/images/index.js\n\n\n/* harmony default export */ var core_images = ({\n loadImage: loadImage,\n preloadImages: preloadImages\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/check-overflow/index.js\nfunction 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\n/* harmony default export */ var check_overflow = ({\n checkOverflow\n});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/defaults.js\n/* harmony default export */ var defaults = ({\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});\n;// CONCATENATED MODULE: ./node_modules/swiper/core/moduleExtendParams.js\n\nfunction 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 utils_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 utils_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 utils_extend(allModulesParams, obj);\n };\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/core/core.js\n/* eslint no-param-reassign: \"off\" */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst prototypes = {\n eventsEmitter: events_emitter,\n update: update,\n translate: translate,\n transition: core_transition,\n slide: slide,\n loop: loop,\n grabCursor: grab_cursor,\n events: core_events,\n breakpoints: breakpoints,\n checkOverflow: check_overflow,\n classes: classes,\n images: core_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 = utils_extend({}, params);\n if (el && !params.el) params.el = el;\n\n if (params.el && dom(params.el).length > 1) {\n const swipers = [];\n dom(params.el).each(containerEl => {\n const newParams = utils_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 = utils_extend({}, defaults, allModulesParams); // Extend defaults with passed params\n\n swiper.params = utils_extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = utils_extend({}, swiper.params);\n swiper.passedParams = utils_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.$ = dom; // Extend Swiper\n\n Object.assign(swiper, {\n enabled: swiper.params.enabled,\n el,\n // Classes\n classNames: [],\n // Slides\n slides: dom(),\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: utils_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 = dom(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 = dom(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 dom($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 = ssr_window_esm_getDocument();\n const wrapper = document.createElement('div');\n $wrapperEl = dom(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 utils_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]);\n/* harmony default export */ var core = (Swiper);\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/virtual/virtual.js\n\n\nfunction Virtual({\n swiper,\n extendParams,\n on,\n emit\n}) {\n extendParams({\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n renderExternalUpdate: true,\n addSlidesBefore: 0,\n addSlidesAfter: 0\n }\n });\n let cssModeTimeout;\n swiper.virtual = {\n cache: {},\n from: undefined,\n to: undefined,\n slides: [],\n offset: 0,\n slidesGrid: []\n };\n\n function renderSlide(slide, index) {\n const params = swiper.params.virtual;\n\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n\n const $slideEl = params.renderSlide ? $(params.renderSlide.call(swiper, slide, index)) : $(`
${slide}
`);\n if (!$slideEl.attr('data-swiper-slide-index')) $slideEl.attr('data-swiper-slide-index', index);\n if (params.cache) swiper.virtual.cache[index] = $slideEl;\n return $slideEl;\n }\n\n function update(force) {\n const {\n slidesPerView,\n slidesPerGroup,\n centeredSlides\n } = swiper.params;\n const {\n addSlidesBefore,\n addSlidesAfter\n } = swiper.params.virtual;\n const {\n from: previousFrom,\n to: previousTo,\n slides,\n slidesGrid: previousSlidesGrid,\n offset: previousOffset\n } = swiper.virtual;\n\n if (!swiper.params.cssMode) {\n swiper.updateActiveIndex();\n }\n\n const activeIndex = swiper.activeIndex || 0;\n let offsetProp;\n if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';\n let slidesAfter;\n let slidesBefore;\n\n if (centeredSlides) {\n slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n } else {\n slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;\n slidesBefore = slidesPerGroup + addSlidesBefore;\n }\n\n const from = Math.max((activeIndex || 0) - slidesBefore, 0);\n const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n const offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n Object.assign(swiper.virtual, {\n from,\n to,\n offset,\n slidesGrid: swiper.slidesGrid\n });\n\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n emit('virtualUpdate');\n }\n\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.css(offsetProp, `${offset}px`);\n }\n\n swiper.updateProgress();\n emit('virtualUpdate');\n return;\n }\n\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset,\n from,\n to,\n slides: function getSlides() {\n const slidesToRender = [];\n\n for (let i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n\n return slidesToRender;\n }()\n });\n\n if (swiper.params.virtual.renderExternalUpdate) {\n onRendered();\n } else {\n emit('virtualUpdate');\n }\n\n return;\n }\n\n const prependIndexes = [];\n const appendIndexes = [];\n\n if (force) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();\n } else {\n for (let i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${i}\"]`).remove();\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n if (i >= from && i <= to) {\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(i);\n } else {\n if (i > previousTo) appendIndexes.push(i);\n if (i < previousFrom) prependIndexes.push(i);\n }\n }\n }\n\n appendIndexes.forEach(index => {\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort((a, b) => b - a).forEach(index => {\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, `${offset}px`);\n onRendered();\n }\n\n function appendSlide(slides) {\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.push(slides[i]);\n }\n } else {\n swiper.virtual.slides.push(slides);\n }\n\n update(true);\n }\n\n function prependSlide(slides) {\n const activeIndex = swiper.activeIndex;\n let newActiveIndex = activeIndex + 1;\n let numberOfNewSlides = 1;\n\n if (Array.isArray(slides)) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.unshift(slides[i]);\n }\n\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\n }\n\n if (swiper.params.virtual.cache) {\n const cache = swiper.virtual.cache;\n const newCache = {};\n Object.keys(cache).forEach(cachedIndex => {\n const $cachedEl = cache[cachedIndex];\n const cachedElIndex = $cachedEl.attr('data-swiper-slide-index');\n\n if (cachedElIndex) {\n $cachedEl.attr('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);\n }\n\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = $cachedEl;\n });\n swiper.virtual.cache = newCache;\n }\n\n update(true);\n swiper.slideTo(newActiveIndex, 0);\n }\n\n function removeSlide(slidesIndexes) {\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;\n let activeIndex = swiper.activeIndex;\n\n if (Array.isArray(slidesIndexes)) {\n for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\n }\n\n if (slidesIndexes[i] < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n } else {\n swiper.virtual.slides.splice(slidesIndexes, 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n\n if (slidesIndexes < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n\n update(true);\n swiper.slideTo(activeIndex, 0);\n }\n\n function removeAllSlides() {\n swiper.virtual.slides = [];\n\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n\n update(true);\n swiper.slideTo(0, 0);\n }\n\n on('beforeInit', () => {\n if (!swiper.params.virtual.enabled) return;\n swiper.virtual.slides = swiper.params.virtual.slides;\n swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n\n if (!swiper.params.initialSlide) {\n update();\n }\n });\n on('setTranslate', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode && !swiper._immediateVirtual) {\n clearTimeout(cssModeTimeout);\n cssModeTimeout = setTimeout(() => {\n update();\n }, 100);\n } else {\n update();\n }\n });\n on('init update resize', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);\n }\n });\n Object.assign(swiper.virtual, {\n appendSlide,\n prependSlide,\n removeSlide,\n removeAllSlides,\n update\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/keyboard/keyboard.js\n/* eslint-disable consistent-return */\n\n\nfunction Keyboard({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n const window = getWindow();\n swiper.keyboard = {\n enabled: false\n };\n extendParams({\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n pageUpDown: true\n }\n });\n\n function handle(event) {\n if (!swiper.enabled) return;\n const {\n rtlTranslate: rtl\n } = swiper;\n let e = event;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n const kc = e.keyCode || e.charCode;\n const pageUpDown = swiper.params.keyboard.pageUpDown;\n const isPageUp = pageUpDown && kc === 33;\n const isPageDown = pageUpDown && kc === 34;\n const isArrowLeft = kc === 37;\n const isArrowRight = kc === 39;\n const isArrowUp = kc === 38;\n const isArrowDown = kc === 40; // Directions locks\n\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n if (!inView) return undefined;\n }\n\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n } else {\n if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n\n emit('keyPress', kc);\n return undefined;\n }\n\n function enable() {\n if (swiper.keyboard.enabled) return;\n $(document).on('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n\n function disable() {\n if (!swiper.keyboard.enabled) return;\n $(document).off('keydown', handle);\n swiper.keyboard.enabled = false;\n }\n\n on('init', () => {\n if (swiper.params.keyboard.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n if (swiper.keyboard.enabled) {\n disable();\n }\n });\n Object.assign(swiper.keyboard, {\n enable,\n disable\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/mousewheel/mousewheel.js\n/* eslint-disable consistent-return */\n\n\n\nfunction Mousewheel({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n mousewheel: {\n enabled: false,\n releaseOnEdges: false,\n invert: false,\n forceToAxis: false,\n sensitivity: 1,\n eventsTarget: 'container',\n thresholdDelta: null,\n thresholdTime: null\n }\n });\n swiper.mousewheel = {\n enabled: false\n };\n let timeout;\n let lastScrollTime = now();\n let lastEventBeforeSnap;\n const recentWheelEvents = [];\n\n function normalize(e) {\n // Reasonable defaults\n const PIXEL_STEP = 10;\n const LINE_HEIGHT = 40;\n const PAGE_HEIGHT = 800;\n let sX = 0;\n let sY = 0; // spinX, spinY\n\n let pX = 0;\n let pY = 0; // pixelX, pixelY\n // Legacy\n\n if ('detail' in e) {\n sY = e.detail;\n }\n\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n } // side scrolling on FF with DOMMouseScroll\n\n\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n\n if (e.shiftKey && !pX) {\n // if user scrolls with shift he wants horizontal scroll\n pX = pY;\n pY = 0;\n }\n\n if ((pX || pY) && e.deltaMode) {\n if (e.deltaMode === 1) {\n // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else {\n // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n } // Fall-back if spin cannot be determined\n\n\n if (pX && !sX) {\n sX = pX < 1 ? -1 : 1;\n }\n\n if (pY && !sY) {\n sY = pY < 1 ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY\n };\n }\n\n function handleMouseEnter() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = true;\n }\n\n function handleMouseLeave() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = false;\n }\n\n function animateSlider(newEvent) {\n if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {\n // Prevent if delta of wheel scroll delta is below configured threshold\n return false;\n }\n\n if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {\n // Prevent if time between scrolls is below configured threshold\n return false;\n } // If the movement is NOT big enough and\n // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):\n // Don't go any further (avoid insignificant scroll movement).\n\n\n if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {\n // Return false as a default\n return true;\n } // If user is scrolling towards the end:\n // If the slider hasn't hit the latest slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to next slide and\n // emit a scroll event.\n // Else (the user is scrolling towards the beginning) and\n // if the slider hasn't hit the first slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to prev slide and\n // emit a scroll event.\n\n\n if (newEvent.direction < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n emit('scroll', newEvent.raw);\n }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n emit('scroll', newEvent.raw);\n } // If you got here is because an animation has been triggered so store the current time\n\n\n lastScrollTime = new window.Date().getTime(); // Return false as a default\n\n return false;\n }\n\n function releaseScroll(newEvent) {\n const params = swiper.params.mousewheel;\n\n if (newEvent.direction < 0) {\n if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n\n return false;\n }\n\n function handle(event) {\n let e = event;\n let disableParentSwiper = true;\n if (!swiper.enabled) return;\n const params = swiper.params.mousewheel;\n\n if (swiper.params.cssMode) {\n e.preventDefault();\n }\n\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n if (!swiper.mouseEntered && !target[0].contains(e.target) && !params.releaseOnEdges) return true;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n let delta = 0;\n const rtlFactor = swiper.rtlTranslate ? -1 : 1;\n const data = normalize(e);\n\n if (params.forceToAxis) {\n if (swiper.isHorizontal()) {\n if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;\n } else {\n delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n }\n\n if (delta === 0) return true;\n if (params.invert) delta = -delta; // Get the scroll positions\n\n let positions = swiper.getTranslate() + delta * params.sensitivity;\n if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();\n if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate(); // When loop is true:\n // the disableParentSwiper will be true.\n // When loop is false:\n // if the scroll positions is not on edge,\n // then the disableParentSwiper will be true.\n // if the scroll on edge positions,\n // then the disableParentSwiper will be false.\n\n disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());\n if (disableParentSwiper && swiper.params.nested) e.stopPropagation();\n\n if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {\n // Register the new event in a variable which stores the relevant data\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta),\n raw: event\n }; // Keep the most recent events\n\n if (recentWheelEvents.length >= 2) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n recentWheelEvents.push(newEvent); // If there is at least one previous recorded event:\n // If direction has changed or\n // if the scroll is quicker than the previous one:\n // Animate the slider.\n // Else (this is the first time the wheel is moved):\n // Animate the slider.\n\n if (prevEvent) {\n if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {\n animateSlider(newEvent);\n }\n } else {\n animateSlider(newEvent);\n } // If it's time to release the scroll:\n // Return now so you don't hit the preventDefault.\n\n\n if (releaseScroll(newEvent)) {\n return true;\n }\n } else {\n // Freemode or scrollContainer:\n // If we recently snapped after a momentum scroll, then ignore wheel events\n // to give time for the deceleration to finish. Stop ignoring after 500 msecs\n // or if it's a new scroll (larger delta or inverse sign as last event before\n // an end-of-momentum snap).\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta)\n };\n const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;\n\n if (!ignoreWheelEvents) {\n lastEventBeforeSnap = undefined;\n\n if (swiper.params.loop) {\n swiper.loopFix();\n }\n\n let position = swiper.getTranslate() + delta * params.sensitivity;\n const wasBeginning = swiper.isBeginning;\n const wasEnd = swiper.isEnd;\n if (position >= swiper.minTranslate()) position = swiper.minTranslate();\n if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();\n swiper.setTransition(0);\n swiper.setTranslate(position);\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode.sticky) {\n // When wheel scrolling starts with sticky (aka snap) enabled, then detect\n // the end of a momentum scroll by storing recent (N=15?) wheel events.\n // 1. do all N events have decreasing or same (absolute value) delta?\n // 2. did all N events arrive in the last M (M=500?) msecs?\n // 3. does the earliest event have an (absolute value) delta that's\n // at least P (P=1?) larger than the most recent event's delta?\n // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?\n // If 1-4 are \"yes\" then we're near the end of a momentum scroll deceleration.\n // Snap immediately and ignore remaining wheel events in this scroll.\n // See comment above for \"remaining wheel events in this scroll\" determination.\n // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.\n clearTimeout(timeout);\n timeout = undefined;\n\n if (recentWheelEvents.length >= 15) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n const firstEvent = recentWheelEvents[0];\n recentWheelEvents.push(newEvent);\n\n if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {\n // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.\n recentWheelEvents.splice(0);\n } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {\n // We're at the end of the deceleration of a momentum scroll, so there's no need\n // to wait for more events. Snap ASAP on the next tick.\n // Also, because there's some remaining momentum we'll bias the snap in the\n // direction of the ongoing scroll because it's better UX for the scroll to snap\n // in the same direction as the scroll instead of reversing to snap. Therefore,\n // if it's already scrolled more than 20% in the current direction, keep going.\n const snapToThreshold = delta > 0 ? 0.8 : 0.2;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n timeout = nextTick(() => {\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 0); // no delay; move on next tick\n }\n\n if (!timeout) {\n // if we get here, then we haven't detected the end of a momentum scroll, so\n // we'll consider a scroll \"complete\" when there haven't been any wheel events\n // for 500ms.\n timeout = nextTick(() => {\n const snapToThreshold = 0.5;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 500);\n }\n } // Emit event\n\n\n if (!ignoreWheelEvents) emit('scroll', e); // Stop autoplay\n\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop(); // Return page scroll on edge positions\n\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;\n }\n }\n\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n return false;\n }\n\n function events(method) {\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n target[method]('mouseenter', handleMouseEnter);\n target[method]('mouseleave', handleMouseLeave);\n target[method]('wheel', handle);\n }\n\n function enable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.removeEventListener('wheel', handle);\n return true;\n }\n\n if (swiper.mousewheel.enabled) return false;\n events('on');\n swiper.mousewheel.enabled = true;\n return true;\n }\n\n function disable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.addEventListener(event, handle);\n return true;\n }\n\n if (!swiper.mousewheel.enabled) return false;\n events('off');\n swiper.mousewheel.enabled = false;\n return true;\n }\n\n on('init', () => {\n if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {\n disable();\n }\n\n if (swiper.params.mousewheel.enabled) enable();\n });\n on('destroy', () => {\n if (swiper.params.cssMode) {\n enable();\n }\n\n if (swiper.mousewheel.enabled) disable();\n });\n Object.assign(swiper.mousewheel, {\n enable,\n disable\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/create-element-if-not-defined.js\n\nfunction create_element_if_not_defined_createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n const document = ssr_window_esm_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}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/navigation/navigation.js\n\n\nfunction 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 = dom(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 = create_element_if_not_defined_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 && !dom(targetEl).is($prevEl) && !dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/classes-to-selector.js\nfunction classes_to_selector_classesToSelector(classes = '') {\n return `.${classes.trim().replace(/([\\.:!\\/])/g, '\\\\$1') // eslint-disable-line\n .replace(/ /g, '.')}`;\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/pagination/pagination.js\n\n\n\nfunction 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 = dom(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(classes_to_selector_classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n $el.find(classes_to_selector_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(classes_to_selector_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}\">`;\n }\n }\n\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find(classes_to_selector_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 = `` + ' / ' + ``;\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 = ``;\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 = create_element_if_not_defined_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 = dom(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 (dom(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', classes_to_selector_classesToSelector(params.bulletClass), function onClick(e) {\n e.preventDefault();\n let index = dom(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', classes_to_selector_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 && !dom(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}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/scrollbar/scrollbar.js\n\n\n\n\nfunction Scrollbar({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n let isTouched = false;\n let timeout = null;\n let dragTimeout = null;\n let dragStartPos;\n let dragSize;\n let trackSize;\n let divider;\n extendParams({\n scrollbar: {\n el: null,\n dragSize: 'auto',\n hide: false,\n draggable: false,\n snapOnRelease: true,\n lockClass: 'swiper-scrollbar-lock',\n dragClass: 'swiper-scrollbar-drag',\n scrollbarDisabledClass: 'swiper-scrollbar-disabled',\n horizontalClass: `swiper-scrollbar-horizontal`,\n verticalClass: `swiper-scrollbar-vertical`\n }\n });\n swiper.scrollbar = {\n el: null,\n dragEl: null,\n $el: null,\n $dragEl: null\n };\n\n function setTranslate() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar,\n rtlTranslate: rtl,\n progress\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n const params = swiper.params.scrollbar;\n let newSize = dragSize;\n let newPos = (trackSize - dragSize) * progress;\n\n if (rtl) {\n newPos = -newPos;\n\n if (newPos > 0) {\n newSize = dragSize - newPos;\n newPos = 0;\n } else if (-newPos + dragSize > trackSize) {\n newSize = trackSize + newPos;\n }\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) {\n newSize = trackSize - newPos;\n }\n\n if (swiper.isHorizontal()) {\n $dragEl.transform(`translate3d(${newPos}px, 0, 0)`);\n $dragEl[0].style.width = `${newSize}px`;\n } else {\n $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);\n $dragEl[0].style.height = `${newSize}px`;\n }\n\n if (params.hide) {\n clearTimeout(timeout);\n $el[0].style.opacity = 1;\n timeout = setTimeout(() => {\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n }\n\n function setTransition(duration) {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n swiper.scrollbar.$dragEl.transition(duration);\n }\n\n function updateSize() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n $dragEl[0].style.width = '';\n $dragEl[0].style.height = '';\n trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n\n if (swiper.isHorizontal()) {\n $dragEl[0].style.width = `${dragSize}px`;\n } else {\n $dragEl[0].style.height = `${dragSize}px`;\n }\n\n if (divider >= 1) {\n $el[0].style.display = 'none';\n } else {\n $el[0].style.display = '';\n }\n\n if (swiper.params.scrollbar.hide) {\n $el[0].style.opacity = 0;\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n scrollbar.$el[swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function getPointerPosition(e) {\n if (swiper.isHorizontal()) {\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientX : e.clientX;\n }\n\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientY : e.clientY;\n }\n\n function setDragPosition(e) {\n const {\n scrollbar,\n rtlTranslate: rtl\n } = swiper;\n const {\n $el\n } = scrollbar;\n let positionRatio;\n positionRatio = (getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n\n if (rtl) {\n positionRatio = 1 - positionRatio;\n }\n\n const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;\n swiper.updateProgress(position);\n swiper.setTranslate(position);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n function onDragStart(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n isTouched = true;\n dragStartPos = e.target === $dragEl[0] || e.target === $dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n setDragPosition(e);\n clearTimeout(dragTimeout);\n $el.transition(0);\n\n if (params.hide) {\n $el.css('opacity', 1);\n }\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', 'none');\n }\n\n emit('scrollbarDragStart', e);\n }\n\n function onDragMove(e) {\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n if (!isTouched) return;\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n emit('scrollbarDragMove', e);\n }\n\n function onDragEnd(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el\n } = scrollbar;\n if (!isTouched) return;\n isTouched = false;\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', '');\n $wrapperEl.transition('');\n }\n\n if (params.hide) {\n clearTimeout(dragTimeout);\n dragTimeout = nextTick(() => {\n $el.css('opacity', 0);\n $el.transition(400);\n }, 1000);\n }\n\n emit('scrollbarDragEnd', e);\n\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n }\n\n function events(method) {\n const {\n scrollbar,\n touchEventsTouch,\n touchEventsDesktop,\n params,\n support\n } = swiper;\n const $el = scrollbar.$el;\n if (!$el) return;\n const target = $el[0];\n const activeListener = support.passiveListener && params.passiveListeners ? {\n passive: false,\n capture: false\n } : false;\n const passiveListener = support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (!target) return;\n const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n\n if (!support.touch) {\n target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);\n document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);\n document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);\n } else {\n target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);\n target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);\n target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);\n }\n }\n\n function enableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('on');\n }\n\n function disableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('off');\n }\n\n function init() {\n const {\n scrollbar,\n $el: $swiperEl\n } = swiper;\n swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {\n el: 'swiper-scrollbar'\n });\n const params = swiper.params.scrollbar;\n if (!params.el) return;\n let $el = $(params.el);\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {\n $el = $swiperEl.find(params.el);\n }\n\n $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`);\n\n if ($dragEl.length === 0) {\n $dragEl = $(`
`);\n $el.append($dragEl);\n }\n\n Object.assign(scrollbar, {\n $el,\n el: $el[0],\n $dragEl,\n dragEl: $dragEl[0]\n });\n\n if (params.draggable) {\n enableDraggable();\n }\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function destroy() {\n const params = swiper.params.scrollbar;\n const $el = swiper.scrollbar.$el;\n\n if ($el) {\n $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n }\n\n disableDraggable();\n }\n\n on('init', () => {\n if (swiper.params.scrollbar.enabled === false) {\n // eslint-disable-next-line\n disable();\n } else {\n init();\n updateSize();\n setTranslate();\n }\n });\n on('update resize observerUpdate lock unlock', () => {\n updateSize();\n });\n on('setTranslate', () => {\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n setTransition(duration);\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.scrollbar;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n });\n on('destroy', () => {\n destroy();\n });\n\n const enable = () => {\n swiper.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);\n\n if (swiper.scrollbar.$el) {\n swiper.scrollbar.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n\n init();\n updateSize();\n setTranslate();\n };\n\n const disable = () => {\n swiper.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);\n\n if (swiper.scrollbar.$el) {\n swiper.scrollbar.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n\n destroy();\n };\n\n Object.assign(swiper.scrollbar, {\n enable,\n disable,\n updateSize,\n setTranslate,\n init,\n destroy\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/parallax/parallax.js\n\nfunction Parallax({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n parallax: {\n enabled: false\n }\n });\n\n const setTransform = (el, progress) => {\n const {\n rtl\n } = swiper;\n const $el = $(el);\n const rtlFactor = rtl ? -1 : 1;\n const p = $el.attr('data-swiper-parallax') || '0';\n let x = $el.attr('data-swiper-parallax-x');\n let y = $el.attr('data-swiper-parallax-y');\n const scale = $el.attr('data-swiper-parallax-scale');\n const opacity = $el.attr('data-swiper-parallax-opacity');\n\n if (x || y) {\n x = x || '0';\n y = y || '0';\n } else if (swiper.isHorizontal()) {\n x = p;\n y = '0';\n } else {\n y = p;\n x = '0';\n }\n\n if (x.indexOf('%') >= 0) {\n x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n } else {\n x = `${x * progress * rtlFactor}px`;\n }\n\n if (y.indexOf('%') >= 0) {\n y = `${parseInt(y, 10) * progress}%`;\n } else {\n y = `${y * progress}px`;\n }\n\n if (typeof opacity !== 'undefined' && opacity !== null) {\n const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n $el[0].style.opacity = currentOpacity;\n }\n\n if (typeof scale === 'undefined' || scale === null) {\n $el.transform(`translate3d(${x}, ${y}, 0px)`);\n } else {\n const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);\n }\n };\n\n const setTranslate = () => {\n const {\n $el,\n slides,\n progress,\n snapGrid\n } = swiper;\n $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, progress);\n });\n slides.each((slideEl, slideIndex) => {\n let slideProgress = slideEl.progress;\n\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n }\n\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, slideProgress);\n });\n });\n };\n\n const setTransition = (duration = swiper.params.speed) => {\n const {\n $el\n } = swiper;\n $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(parallaxEl => {\n const $parallaxEl = $(parallaxEl);\n let parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) parallaxDuration = 0;\n $parallaxEl.transition(parallaxDuration);\n });\n };\n\n on('beforeInit', () => {\n if (!swiper.params.parallax.enabled) return;\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n });\n on('init', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTranslate', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTransition', (_swiper, duration) => {\n if (!swiper.params.parallax.enabled) return;\n setTransition(duration);\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/zoom/zoom.js\n\n\n\nfunction Zoom({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: 'swiper-zoom-container',\n zoomedSlideClass: 'swiper-slide-zoomed'\n }\n });\n swiper.zoom = {\n enabled: false\n };\n let currentScale = 1;\n let isScaling = false;\n let gesturesEnabled;\n let fakeGestureTouched;\n let fakeGestureMoved;\n const gesture = {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3\n };\n const image = {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {}\n };\n const velocity = {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined\n };\n let scale = 1;\n Object.defineProperty(swiper.zoom, 'scale', {\n get() {\n return scale;\n },\n\n set(value) {\n if (scale !== value) {\n const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined;\n const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined;\n emit('zoomChange', value, imageEl, slideEl);\n }\n\n scale = value;\n }\n\n });\n\n function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) return 1;\n const x1 = e.targetTouches[0].pageX;\n const y1 = e.targetTouches[0].pageY;\n const x2 = e.targetTouches[1].pageX;\n const y2 = e.targetTouches[1].pageY;\n const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n return distance;\n } // Events\n\n\n function onGestureStart(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n\n if (!support.gestures) {\n if (e.type !== 'touchstart' || e.type === 'touchstart' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureTouched = true;\n gesture.scaleStart = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n if (gesture.$slideEl.length === 0) gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n\n if (gesture.$imageEl) {\n gesture.$imageEl.transition(0);\n }\n\n isScaling = true;\n }\n\n function onGestureChange(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (e.type !== 'touchmove' || e.type === 'touchmove' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureMoved = true;\n gesture.scaleMove = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) {\n if (e.type === 'gesturechange') onGestureStart(e);\n return;\n }\n\n if (support.gestures) {\n zoom.scale = e.scale * currentScale;\n } else {\n zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n }\n\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n }\n\n if (zoom.scale < params.minRatio) {\n zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n }\n\n gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function onGestureEnd(e) {\n const device = swiper.device;\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (!fakeGestureTouched || !fakeGestureMoved) {\n return;\n }\n\n if (e.type !== 'touchend' || e.type === 'touchend' && e.changedTouches.length < 2 && !device.android) {\n return;\n }\n\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n currentScale = zoom.scale;\n isScaling = false;\n if (zoom.scale === 1) gesture.$slideEl = undefined;\n }\n\n function onTouchStart(e) {\n const device = swiper.device;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n if (image.isTouched) return;\n if (device.android && e.cancelable) e.preventDefault();\n image.isTouched = true;\n image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n }\n\n function onTouchMove(e) {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) return;\n\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = getTranslate(gesture.$imageWrapEl[0], 'x') || 0;\n image.startY = getTranslate(gesture.$imageWrapEl[0], 'y') || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n } // Define if we need image drag\n\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n\n if (!image.isMoved && !isScaling) {\n if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {\n image.isTouched = false;\n return;\n }\n\n if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {\n image.isTouched = false;\n return;\n }\n }\n\n if (e.cancelable) {\n e.preventDefault();\n }\n\n e.stopPropagation();\n image.isMoved = true;\n image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX;\n image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY;\n\n if (image.currentX < image.minX) {\n image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n }\n\n if (image.currentX > image.maxX) {\n image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n }\n\n if (image.currentY < image.minY) {\n image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n }\n\n if (image.currentY > image.maxY) {\n image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\n } // Velocity\n\n\n if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;\n if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;\n if (!velocity.prevTime) velocity.prevTime = Date.now();\n velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;\n if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;\n velocity.prevPositionX = image.touchesCurrent.x;\n velocity.prevPositionY = image.touchesCurrent.y;\n velocity.prevTime = Date.now();\n gesture.$imageWrapEl.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTouchEnd() {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\n }\n\n image.isTouched = false;\n image.isMoved = false;\n let momentumDurationX = 300;\n let momentumDurationY = 300;\n const momentumDistanceX = velocity.x * momentumDurationX;\n const newPositionX = image.currentX + momentumDistanceX;\n const momentumDistanceY = velocity.y * momentumDurationY;\n const newPositionY = image.currentY + momentumDistanceY; // Fix duration\n\n if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);\n if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);\n const momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n image.currentX = newPositionX;\n image.currentY = newPositionY; // Define if we need image drag\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n gesture.$imageWrapEl.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTransitionEnd() {\n const zoom = swiper.zoom;\n\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n if (gesture.$imageEl) {\n gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');\n }\n\n if (gesture.$imageWrapEl) {\n gesture.$imageWrapEl.transform('translate3d(0,0,0)');\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\n }\n }\n\n function zoomIn(e) {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (e && e.target) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n }\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.touchAction = 'none';\n }\n\n gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);\n let touchX;\n let touchY;\n let offsetX;\n let offsetY;\n let diffX;\n let diffY;\n let translateX;\n let translateY;\n let imageWidth;\n let imageHeight;\n let scaledWidth;\n let scaledHeight;\n let translateMinX;\n let translateMinY;\n let translateMaxX;\n let translateMaxY;\n let slideWidth;\n let slideHeight;\n\n if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n\n zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left + window.scrollX;\n offsetY = gesture.$slideEl.offset().top + window.scrollY;\n diffX = offsetX + slideWidth / 2 - touchX;\n diffY = offsetY + slideHeight / 2 - touchY;\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n\n if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n\n gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);\n gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function zoomOut() {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.style.touchAction = '';\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');\n gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');\n gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);\n gesture.$slideEl = undefined;\n } // Toggle Zoom\n\n\n function zoomToggle(e) {\n const zoom = swiper.zoom;\n\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoomOut();\n } else {\n // Zoom In\n zoomIn(e);\n }\n }\n\n function getListeners() {\n const support = swiper.support;\n const passiveListener = swiper.touchEvents.start === 'touchstart' && support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n const activeListenerWithCapture = support.passiveListener ? {\n passive: false,\n capture: true\n } : true;\n return {\n passiveListener,\n activeListenerWithCapture\n };\n }\n\n function getSlideSelector() {\n return `.${swiper.params.slideClass}`;\n }\n\n function toggleGestures(method) {\n const {\n passiveListener\n } = getListeners();\n const slideSelector = getSlideSelector();\n swiper.$wrapperEl[method]('gesturestart', slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl[method]('gesturechange', slideSelector, onGestureChange, passiveListener);\n swiper.$wrapperEl[method]('gestureend', slideSelector, onGestureEnd, passiveListener);\n }\n\n function enableGestures() {\n if (gesturesEnabled) return;\n gesturesEnabled = true;\n toggleGestures('on');\n }\n\n function disableGestures() {\n if (!gesturesEnabled) return;\n gesturesEnabled = false;\n toggleGestures('off');\n } // Attach/Detach Events\n\n\n function enable() {\n const zoom = swiper.zoom;\n if (zoom.enabled) return;\n zoom.enabled = true;\n const support = swiper.support;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n function disable() {\n const zoom = swiper.zoom;\n if (!zoom.enabled) return;\n const support = swiper.support;\n zoom.enabled = false;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n on('init', () => {\n if (swiper.params.zoom.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n disable();\n });\n on('touchStart', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchStart(e);\n });\n on('touchEnd', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchEnd(e);\n });\n on('doubleTap', (_s, e) => {\n if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n zoomToggle(e);\n }\n });\n on('transitionEnd', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n onTransitionEnd();\n }\n });\n on('slideChange', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {\n onTransitionEnd();\n }\n });\n Object.assign(swiper.zoom, {\n enable,\n disable,\n in: zoomIn,\n out: zoomOut,\n toggle: zoomToggle\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/lazy/lazy.js\n\n\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/controller/controller.js\n/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\n\nfunction Controller({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n controller: {\n control: undefined,\n inverse: false,\n by: 'slide' // or 'container'\n\n }\n });\n swiper.controller = {\n control: undefined\n };\n\n function LinearSpline(x, y) {\n const binarySearch = function search() {\n let maxIndex;\n let minIndex;\n let guess;\n return (array, val) => {\n minIndex = -1;\n maxIndex = array.length;\n\n while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n\n return maxIndex;\n };\n }();\n\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n\n let i1;\n let i3;\n\n this.interpolate = function interpolate(x2) {\n if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n\n return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];\n };\n\n return this;\n } // xxx: for now i will just save one spline function to to\n\n\n function getInterpolateFunction(c) {\n if (!swiper.controller.spline) {\n swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n }\n\n function setTranslate(_t, byController) {\n const controlled = swiper.controller.control;\n let multiplier;\n let controlledTranslate;\n const Swiper = swiper.constructor;\n\n function setControlledTranslate(c) {\n // this will create an Interpolate function based on the snapGrids\n // x is the Grid of the scrolled scroller and y will be the controlled scroller\n // it makes sense to create this only once and recall it for the interpolation\n // the function does a lot of value caching for performance\n const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n\n if (swiper.params.controller.by === 'slide') {\n getInterpolateFunction(c); // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n // but it did not work out\n\n controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n }\n\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\n }\n\n if (Array.isArray(controlled)) {\n for (let i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTranslate(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTranslate(controlled);\n }\n }\n\n function setTransition(duration, byController) {\n const Swiper = swiper.constructor;\n const controlled = swiper.controller.control;\n let i;\n\n function setControlledTransition(c) {\n c.setTransition(duration, swiper);\n\n if (duration !== 0) {\n c.transitionStart();\n\n if (c.params.autoHeight) {\n nextTick(() => {\n c.updateAutoHeight();\n });\n }\n\n c.$wrapperEl.transitionEnd(() => {\n if (!controlled) return;\n\n if (c.params.loop && swiper.params.controller.by === 'slide') {\n c.loopFix();\n }\n\n c.transitionEnd();\n });\n }\n }\n\n if (Array.isArray(controlled)) {\n for (i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTransition(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTransition(controlled);\n }\n }\n\n function removeSpline() {\n if (!swiper.controller.control) return;\n\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n }\n\n on('beforeInit', () => {\n swiper.controller.control = swiper.params.controller.control;\n });\n on('update', () => {\n removeSpline();\n });\n on('resize', () => {\n removeSpline();\n });\n on('observerUpdate', () => {\n removeSpline();\n });\n on('setTranslate', (_s, translate, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTranslate(translate, byController);\n });\n on('setTransition', (_s, duration, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTransition(duration, byController);\n });\n Object.assign(swiper.controller, {\n setTranslate,\n setTransition\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/a11y/a11y.js\n\n\nfunction 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 = $(``);\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}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/history/history.js\n\nfunction History({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n history: {\n enabled: false,\n root: '',\n replaceState: false,\n key: 'slides',\n keepQuery: false\n }\n });\n let initialized = false;\n let paths = {};\n\n const slugify = text => {\n return text.toString().replace(/\\s+/g, '-').replace(/[^\\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');\n };\n\n const getPathValues = urlOverride => {\n const window = getWindow();\n let location;\n\n if (urlOverride) {\n location = new URL(urlOverride);\n } else {\n location = window.location;\n }\n\n const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');\n const total = pathArray.length;\n const key = pathArray[total - 2];\n const value = pathArray[total - 1];\n return {\n key,\n value\n };\n };\n\n const setHistory = (key, index) => {\n const window = getWindow();\n if (!initialized || !swiper.params.history.enabled) return;\n let location;\n\n if (swiper.params.url) {\n location = new URL(swiper.params.url);\n } else {\n location = window.location;\n }\n\n const slide = swiper.slides.eq(index);\n let value = slugify(slide.attr('data-history'));\n\n if (swiper.params.history.root.length > 0) {\n let root = swiper.params.history.root;\n if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);\n value = `${root}/${key}/${value}`;\n } else if (!location.pathname.includes(key)) {\n value = `${key}/${value}`;\n }\n\n if (swiper.params.history.keepQuery) {\n value += location.search;\n }\n\n const currentState = window.history.state;\n\n if (currentState && currentState.value === value) {\n return;\n }\n\n if (swiper.params.history.replaceState) {\n window.history.replaceState({\n value\n }, null, value);\n } else {\n window.history.pushState({\n value\n }, null, value);\n }\n };\n\n const scrollToSlide = (speed, value, runCallbacks) => {\n if (value) {\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHistory = slugify(slide.attr('data-history'));\n\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n };\n\n const setHistoryPopState = () => {\n paths = getPathValues(swiper.params.url);\n scrollToSlide(swiper.params.speed, paths.value, false);\n };\n\n const init = () => {\n const window = getWindow();\n if (!swiper.params.history) return;\n\n if (!window.history || !window.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n\n initialized = true;\n paths = getPathValues(swiper.params.url);\n if (!paths.key && !paths.value) return;\n scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n\n if (!swiper.params.history.replaceState) {\n window.addEventListener('popstate', setHistoryPopState);\n }\n };\n\n const destroy = () => {\n const window = getWindow();\n\n if (!swiper.params.history.replaceState) {\n window.removeEventListener('popstate', setHistoryPopState);\n }\n };\n\n on('init', () => {\n if (swiper.params.history.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.history.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/hash-navigation/hash-navigation.js\n\n\nfunction HashNavigation({\n swiper,\n extendParams,\n emit,\n on\n}) {\n let initialized = false;\n const document = getDocument();\n const window = getWindow();\n extendParams({\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false\n }\n });\n\n const onHashChange = () => {\n emit('hashChange');\n const newHash = document.location.hash.replace('#', '');\n const activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');\n\n if (newHash !== activeSlideHash) {\n const newIndex = swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash=\"${newHash}\"]`).index();\n if (typeof newIndex === 'undefined') return;\n swiper.slideTo(newIndex);\n }\n };\n\n const setHash = () => {\n if (!initialized || !swiper.params.hashNavigation.enabled) return;\n\n if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr('data-hash')}` || '');\n emit('hashSet');\n } else {\n const slide = swiper.slides.eq(swiper.activeIndex);\n const hash = slide.attr('data-hash') || slide.attr('data-history');\n document.location.hash = hash || '';\n emit('hashSet');\n }\n };\n\n const init = () => {\n if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;\n initialized = true;\n const hash = document.location.hash.replace('#', '');\n\n if (hash) {\n const speed = 0;\n\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHash = slide.attr('data-hash') || slide.attr('data-history');\n\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n\n if (swiper.params.hashNavigation.watchState) {\n $(window).on('hashchange', onHashChange);\n }\n };\n\n const destroy = () => {\n if (swiper.params.hashNavigation.watchState) {\n $(window).off('hashchange', onHashChange);\n }\n };\n\n on('init', () => {\n if (swiper.params.hashNavigation.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.hashNavigation.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHash();\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHash();\n }\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/autoplay/autoplay.js\n/* eslint no-underscore-dangle: \"off\" */\n\n/* eslint no-use-before-define: \"off\" */\n\n\nfunction 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}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/thumbs/thumbs.js\n\n\nfunction Thumb({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n thumbs: {\n swiper: null,\n multipleActiveThumbs: true,\n autoScrollOffset: 0,\n slideThumbActiveClass: 'swiper-slide-thumb-active',\n thumbsContainerClass: 'swiper-thumbs'\n }\n });\n let initialized = false;\n let swiperCreated = false;\n swiper.thumbs = {\n swiper: null\n };\n\n function onThumbClick() {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n const clickedIndex = thumbsSwiper.clickedIndex;\n const clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;\n let slideToIndex;\n\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n\n if (swiper.params.loop) {\n let currentIndex = swiper.activeIndex;\n\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n\n const prevIndex = swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n const nextIndex = swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n if (typeof prevIndex === 'undefined') slideToIndex = nextIndex;else if (typeof nextIndex === 'undefined') slideToIndex = prevIndex;else if (nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex = nextIndex;else slideToIndex = prevIndex;\n }\n\n swiper.slideTo(slideToIndex);\n }\n\n function init() {\n const {\n thumbs: thumbsParams\n } = swiper.params;\n if (initialized) return false;\n initialized = true;\n const SwiperClass = swiper.constructor;\n\n if (thumbsParams.swiper instanceof SwiperClass) {\n swiper.thumbs.swiper = thumbsParams.swiper;\n Object.assign(swiper.thumbs.swiper.originalParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n Object.assign(swiper.thumbs.swiper.params, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n } else if (isObject(thumbsParams.swiper)) {\n const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);\n Object.assign(thumbsSwiperParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);\n swiperCreated = true;\n }\n\n swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', onThumbClick);\n return true;\n }\n\n function update(initial) {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView; // Activate thumbs\n\n let thumbsToActivate = 1;\n const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n\n if (!swiper.params.thumbs.multipleActiveThumbs) {\n thumbsToActivate = 1;\n }\n\n thumbsToActivate = Math.floor(thumbsToActivate);\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).addClass(thumbActiveClass);\n }\n } else {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);\n }\n }\n\n const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n\n if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n let currentThumbsIndex = thumbsSwiper.activeIndex;\n let newThumbsIndex;\n let direction;\n\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix(); // eslint-disable-next-line\n\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n } // Find actual thumbs index to slide to\n\n\n const prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n const nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n\n if (typeof prevThumbsIndex === 'undefined') {\n newThumbsIndex = nextThumbsIndex;\n } else if (typeof nextThumbsIndex === 'undefined') {\n newThumbsIndex = prevThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex : currentThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = nextThumbsIndex;\n } else {\n newThumbsIndex = prevThumbsIndex;\n }\n\n direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';\n } else {\n newThumbsIndex = swiper.realIndex;\n direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';\n }\n\n if (useOffset) {\n newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;\n }\n\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n } else {\n newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n }\n } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) {// newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n }\n }\n\n on('beforeInit', () => {\n const {\n thumbs\n } = swiper.params;\n if (!thumbs || !thumbs.swiper) return;\n init();\n update(true);\n });\n on('slideChange update resize observerUpdate', () => {\n update();\n });\n on('setTransition', (_s, duration) => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n thumbsSwiper.setTransition(duration);\n });\n on('beforeDestroy', () => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n\n if (swiperCreated) {\n thumbsSwiper.destroy();\n }\n });\n Object.assign(swiper.thumbs, {\n init,\n update\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/free-mode/free-mode.js\n\nfunction freeMode({\n swiper,\n extendParams,\n emit,\n once\n}) {\n extendParams({\n freeMode: {\n enabled: false,\n momentum: true,\n momentumRatio: 1,\n momentumBounce: true,\n momentumBounceRatio: 1,\n momentumVelocityRatio: 1,\n sticky: false,\n minimumVelocity: 0.02\n }\n });\n\n function onTouchStart() {\n const translate = swiper.getTranslate();\n swiper.setTranslate(translate);\n swiper.setTransition(0);\n swiper.touchEventsData.velocities.length = 0;\n swiper.freeMode.onTouchEnd({\n currentPos: swiper.rtl ? swiper.translate : -swiper.translate\n });\n }\n\n function onTouchMove() {\n const {\n touchEventsData: data,\n touches\n } = swiper; // Velocity\n\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime\n });\n }\n\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: now()\n });\n }\n\n function onTouchEnd({\n currentPos\n }) {\n const {\n params,\n $wrapperEl,\n rtlTranslate: rtl,\n snapGrid,\n touchEventsData: data\n } = swiper; // Time diff\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime;\n\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (currentPos > -swiper.maxTranslate()) {\n if (swiper.slides.length < snapGrid.length) {\n swiper.slideTo(snapGrid.length - 1);\n } else {\n swiper.slideTo(swiper.slides.length - 1);\n }\n\n return;\n }\n\n if (params.freeMode.momentum) {\n if (data.velocities.length > 1) {\n const lastMoveEvent = data.velocities.pop();\n const velocityEvent = data.velocities.pop();\n const distance = lastMoveEvent.position - velocityEvent.position;\n const time = lastMoveEvent.time - velocityEvent.time;\n swiper.velocity = distance / time;\n swiper.velocity /= 2;\n\n if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {\n swiper.velocity = 0;\n } // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n\n\n if (time > 150 || now() - lastMoveEvent.time > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\n }\n\n swiper.velocity *= params.freeMode.momentumVelocityRatio;\n data.velocities.length = 0;\n let momentumDuration = 1000 * params.freeMode.momentumRatio;\n const momentumDistance = swiper.velocity * momentumDuration;\n let newPosition = swiper.translate + momentumDistance;\n if (rtl) newPosition = -newPosition;\n let doBounce = false;\n let afterBouncePosition;\n const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;\n let needsLoopFix;\n\n if (newPosition < swiper.maxTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (newPosition > swiper.minTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition - swiper.minTranslate() > bounceAmount) {\n newPosition = swiper.minTranslate() + bounceAmount;\n }\n\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (params.freeMode.sticky) {\n let nextSlide;\n\n for (let j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n }\n\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n newPosition = snapGrid[nextSlide];\n } else {\n newPosition = snapGrid[nextSlide - 1];\n }\n\n newPosition = -newPosition;\n }\n\n if (needsLoopFix) {\n once('transitionEnd', () => {\n swiper.loopFix();\n });\n } // Fix duration\n\n\n if (swiper.velocity !== 0) {\n if (rtl) {\n momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n } else {\n momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n }\n\n if (params.freeMode.sticky) {\n // If freeMode.sticky is active and the user ends a swipe with a slow-velocity\n // event, then durations can be 20+ seconds to slide one (or zero!) slides.\n // It's easy to see this when simulating touch with mouse events. To fix this,\n // limit single-slide swipes to the default slide duration. This also has the\n // nice side effect of matching slide speed if the user stopped moving before\n // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.\n // For faster swipes, also apply limits (albeit higher ones).\n const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);\n const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];\n\n if (moveDistance < currentSlideSize) {\n momentumDuration = params.speed;\n } else if (moveDistance < 2 * currentSlideSize) {\n momentumDuration = params.speed * 1.5;\n } else {\n momentumDuration = params.speed * 2.5;\n }\n }\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (params.freeMode.momentumBounce && doBounce) {\n swiper.updateProgress(afterBouncePosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n emit('momentumBounce');\n swiper.setTransition(params.speed);\n setTimeout(() => {\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }, 0);\n });\n } else if (swiper.velocity) {\n emit('_freeModeNoMomentumRelease');\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\n }\n\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n } else if (params.freeMode) {\n emit('_freeModeNoMomentumRelease');\n }\n\n if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n }\n\n Object.assign(swiper, {\n freeMode: {\n onTouchStart,\n onTouchMove,\n onTouchEnd\n }\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/effect-cube/effect-cube.js\n\n\nfunction EffectCube({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94\n }\n });\n\n const createSlideShadows = ($slideEl, progress, isHorizontal) => {\n let shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = $(`
`);\n $slideEl.append(shadowBefore);\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = $(`
`);\n $slideEl.append(shadowAfter);\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n };\n\n const recreateShadows = () => {\n // create new ones\n const isHorizontal = swiper.isHorizontal();\n swiper.slides.each(slideEl => {\n const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n createSlideShadows($(slideEl), progress, isHorizontal);\n });\n };\n\n const setTranslate = () => {\n const {\n $el,\n $wrapperEl,\n slides,\n width: swiperWidth,\n height: swiperHeight,\n rtlTranslate: rtl,\n size: swiperSize,\n browser\n } = swiper;\n const params = swiper.params.cubeEffect;\n const isHorizontal = swiper.isHorizontal();\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n let wrapperRotate = 0;\n let $cubeShadowEl;\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $wrapperEl.append($cubeShadowEl);\n }\n\n $cubeShadowEl.css({\n height: `${swiperWidth}px`\n });\n } else {\n $cubeShadowEl = $el.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $el.append($cubeShadowEl);\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let slideIndex = i;\n\n if (isVirtual) {\n slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);\n }\n\n let slideAngle = slideIndex * 90;\n let round = Math.floor(slideAngle / 360);\n\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n\n const progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n let tx = 0;\n let ty = 0;\n let tz = 0;\n\n if (slideIndex % 4 === 0) {\n tx = -round * 4 * swiperSize;\n tz = 0;\n } else if ((slideIndex - 1) % 4 === 0) {\n tx = 0;\n tz = -round * 4 * swiperSize;\n } else if ((slideIndex - 2) % 4 === 0) {\n tx = swiperSize + round * 4 * swiperSize;\n tz = swiperSize;\n } else if ((slideIndex - 3) % 4 === 0) {\n tx = -swiperSize;\n tz = 3 * swiperSize + swiperSize * 4 * round;\n }\n\n if (rtl) {\n tx = -tx;\n }\n\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n\n const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;\n\n if (progress <= 1 && progress > -1) {\n wrapperRotate = slideIndex * 90 + progress * 90;\n if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;\n }\n\n $slideEl.transform(transform);\n\n if (params.slideShadows) {\n createSlideShadows($slideEl, progress, isHorizontal);\n }\n }\n\n $wrapperEl.css({\n '-webkit-transform-origin': `50% 50% -${swiperSize / 2}px`,\n 'transform-origin': `50% 50% -${swiperSize / 2}px`\n });\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);\n } else {\n const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;\n const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);\n const scale1 = params.shadowScale;\n const scale2 = params.shadowScale / multiplier;\n const offset = params.shadowOffset;\n $cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);\n }\n }\n\n const zFactor = browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0;\n $wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`);\n $wrapperEl[0].style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);\n };\n\n const setTransition = duration => {\n const {\n $el,\n slides\n } = swiper;\n slides.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n $el.find('.swiper-cube-shadow').transition(duration);\n }\n };\n\n effectInit({\n effect: 'cube',\n swiper,\n on,\n setTranslate,\n setTransition,\n recreateShadows,\n getEffectParams: () => swiper.params.cubeEffect,\n perspective: () => true,\n overwriteParams: () => ({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n resistanceRatio: 0,\n spaceBetween: 0,\n centeredSlides: false,\n virtualTranslate: true\n })\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/shared/create-shadow.js\n\nfunction create_shadow_createShadow(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n\n if (!$shadowEl.length) {\n $shadowEl = $(`
`);\n $shadowContainer.append($shadowEl);\n }\n\n return $shadowEl;\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/effect-flip/effect-flip.js\n\n\n\n\n\nfunction EffectFlip({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n transformEl: null\n }\n });\n\n const createSlideShadows = ($slideEl, progress, params) => {\n let shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = createShadow(params, $slideEl, swiper.isHorizontal() ? 'left' : 'top');\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = createShadow(params, $slideEl, swiper.isHorizontal() ? 'right' : 'bottom');\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n };\n\n const recreateShadows = () => {\n // Set shadows\n const params = swiper.params.flipEffect;\n swiper.slides.each(slideEl => {\n const $slideEl = $(slideEl);\n let progress = $slideEl[0].progress;\n\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min(slideEl.progress, 1), -1);\n }\n\n createSlideShadows($slideEl, progress, params);\n });\n };\n\n const setTranslate = () => {\n const {\n slides,\n rtlTranslate: rtl\n } = swiper;\n const params = swiper.params.flipEffect;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let progress = $slideEl[0].progress;\n\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const rotate = -180 * progress;\n let rotateY = rotate;\n let rotateX = 0;\n let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let ty = 0;\n\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n\n if (params.slideShadows) {\n createSlideShadows($slideEl, progress, params);\n }\n\n const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.flipEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'flip',\n swiper,\n on,\n setTranslate,\n setTransition,\n recreateShadows,\n getEffectParams: () => swiper.params.flipEffect,\n perspective: () => true,\n overwriteParams: () => ({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/effect-coverflow/effect-coverflow.js\n\n\n\nfunction EffectCoverflow({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n width: swiperWidth,\n height: swiperHeight,\n slides,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;\n const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\n }\n\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n\n if (Math.abs(translateX) < 0.001) translateX = 0;\n if (Math.abs(translateY) < 0.001) translateY = 0;\n if (Math.abs(translateZ) < 0.001) translateZ = 0;\n if (Math.abs(rotateY) < 0.001) rotateY = 0;\n if (Math.abs(rotateX) < 0.001) rotateX = 0;\n if (Math.abs(scale) < 0.001) scale = 0;\n const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');\n }\n\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');\n }\n\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n };\n\n effectInit({\n effect: 'coverflow',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true\n })\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/effect-creative/effect-creative.js\n\n\n\n\nfunction EffectCreative({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n creativeEffect: {\n transformEl: null,\n limitProgress: 1,\n shadowPerProgress: false,\n progressMultiplier: 1,\n perspective: true,\n prev: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n },\n next: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n }\n }\n });\n\n const getTranslateValue = value => {\n if (typeof value === 'string') return value;\n return `${value}px`;\n };\n\n const setTranslate = () => {\n const {\n slides,\n $wrapperEl,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.creativeEffect;\n const {\n progressMultiplier: multiplier\n } = params;\n const isCenteredSlides = swiper.params.centeredSlides;\n\n if (isCenteredSlides) {\n const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);\n let originalProgress = progress;\n\n if (!isCenteredSlides) {\n originalProgress = Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];\n const r = [0, 0, 0];\n let custom = false;\n\n if (!swiper.isHorizontal()) {\n t[1] = t[0];\n t[0] = 0;\n }\n\n let data = {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n scale: 1,\n opacity: 1\n };\n\n if (progress < 0) {\n data = params.next;\n custom = true;\n } else if (progress > 0) {\n data = params.prev;\n custom = true;\n } // set translate\n\n\n t.forEach((value, index) => {\n t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n }); // set rotates\n\n r.forEach((value, index) => {\n r[index] = data.rotate[index] * Math.abs(progress * multiplier);\n });\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const translateString = t.join(', ');\n const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;\n const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;\n const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;\n const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows\n\n if (custom && data.shadow || !custom) {\n let $shadowEl = $slideEl.children('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0 && data.shadow) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) {\n const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n $shadowEl[0].style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n }\n }\n\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform).css({\n opacity: opacityString\n });\n\n if (data.origin) {\n $targetEl.css('transform-origin', data.origin);\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.creativeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl,\n allSlides: true\n });\n };\n\n effectInit({\n effect: 'creative',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => swiper.params.creativeEffect.perspective,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/modules/effect-cards/effect-cards.js\n\n\n\n\nfunction EffectCards({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cardsEffect: {\n slideShadows: true,\n transformEl: null,\n rotate: true,\n perSlideRotate: 2,\n perSlideOffset: 8\n }\n });\n\n const setTranslate = () => {\n const {\n slides,\n activeIndex\n } = swiper;\n const params = swiper.params.cardsEffect;\n const {\n startTranslate,\n isTouched\n } = swiper.touchEventsData;\n const currentTranslate = swiper.translate;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max(slideProgress, -4), 4);\n let offset = $slideEl[0].swiperSlideOffset;\n\n if (swiper.params.centeredSlides && !swiper.params.cssMode) {\n swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);\n }\n\n if (swiper.params.centeredSlides && swiper.params.cssMode) {\n offset -= slides[0].swiperSlideOffset;\n }\n\n let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let tY = 0;\n const tZ = -100 * Math.abs(progress);\n let scale = 1;\n let rotate = -params.perSlideRotate * progress;\n let tXAdd = params.perSlideOffset - Math.abs(progress) * 0.75;\n const slideIndex = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.from + i : i;\n const isSwipeToNext = (slideIndex === activeIndex || slideIndex === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;\n const isSwipeToPrev = (slideIndex === activeIndex || slideIndex === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;\n\n if (isSwipeToNext || isSwipeToPrev) {\n const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;\n rotate += -28 * progress * subProgress;\n scale += -0.5 * subProgress;\n tXAdd += 96 * subProgress;\n tY = `${-25 * subProgress * Math.abs(progress)}%`;\n }\n\n if (progress < 0) {\n // next\n tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;\n } else if (progress > 0) {\n // prev\n tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;\n } else {\n tX = `${tX}px`;\n }\n\n if (!swiper.isHorizontal()) {\n const prevY = tY;\n tY = tX;\n tX = prevY;\n }\n\n const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;\n const transform = `\n translate3d(${tX}, ${tY}, ${tZ}px)\n rotateZ(${params.rotate ? rotate : 0}deg)\n scale(${scaleString})\n `;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowEl = $slideEl.find('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) $shadowEl[0].style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.cardsEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'cards',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n;// CONCATENATED MODULE: ./node_modules/swiper/swiper.esm.js\n/**\n * Swiper 8.4.6\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2023 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: January 17, 2023\n */\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/***/ })\n\n}]);"],"names":["self","push","__unused_webpack___webpack_module__","__webpack_exports__","__webpack_require__","d","Swiper","SwiperSlide","react","swiper_esm","isObject","o","constructor","Object","prototype","toString","call","slice","extend","target","src","noExtend","keys","filter","key","indexOf","forEach","length","__swiper__","needsNavigation","params","navigation","nextEl","prevEl","needsPagination","pagination","el","needsScrollbar","scrollbar","uniqueClasses","classNames","classes","split","map","c","trim","unique","join","paramsList","calcLoopedSlides","slides","swiperParams","slidesPerViewParams","slidesPerView","breakpoints","breakpoint","ZP","getBreakpoint","breakpointOnlyParams","undefined","loopedSlides","Math","ceil","parseFloat","loopAdditionalSlides","loopedSlidesLimit","isChildSwiperSlide","child","type","displayName","includes","processChildren","Children","toArray","props","children","slide","updateOnVirtualData","swiper","destroyed","virtual","enabled","updateSlides","updateProgress","updateSlidesClasses","lazy","load","parallax","setTranslate","useIsomorphicLayoutEffect","callback","deps","window","useEffect","useLayoutEffect","SwiperSlideContext","createContext","SwiperContext","_extends","assign","bind","i","arguments","source","hasOwnProperty","apply","forwardRef","_temp","externalElRef","className","tag","Tag","wrapperTag","WrapperTag","onSwiper","rest","eventsAssigned","containerClasses","setContainerClasses","useState","virtualData","setVirtualData","breakpointChanged","setBreakpointChanged","initializedRef","useRef","swiperElRef","swiperRef","oldPassedParamsRef","oldSlides","nextElRef","prevElRef","paginationElRef","scrollbarElRef","passedParams","restProps","events","getParams","obj","splitEvents","on","defaults","extendedDefaults","_emitClasses","init","allowedParams","replace","plainObj","search","toLowerCase","substr","slots","getChildren","slot","foundSlides","onBeforeBreakpoint","_containerClasses","initSwiper","current","loopCreate","loopDestroy","loop","extendWith","cache","renderExternal","renderExternalUpdate","originalParams","attachEvents","eventName","detachEvents","off","emitSlidesClasses","mountSwiper","paginationEl","scrollbarEl","destroy","changedParams","getChangedParams","oldParams","oldChildren","getKey","addKey","oldChildrenKeys","childrenKeys","watchParams","newKeys","oldKeys","newKey","oldKey","updateSwiper","updateParams","currentParams","thumbs","needThumbsInit","needControllerInit","needPaginationInit","needScrollbarInit","needNavigationInit","controller","control","destroyModule","mod","newValue","update","initialized","render","updateSize","allowSlideNext","allowSlidePrev","changeDirection","direction","createElement","ref","Provider","value","renderVirtual","style","isHorizontal","rtlTranslate","offset","top","index","from","to","cloneElement","renderLoop","modifiedSlides","duplicateSlide","position","slideDuplicateClass","loopFillGroupWithBlank","blankSlidesNum","slidesPerGroup","blankSlide","slideClass","slideBlankClass","prependSlides","appendSlides","floor","unshift","Fragment","swiper_slide_extends","externalRef","zoom","virtualIndex","slideElRef","slideClasses","setSlideClasses","updateClasses","_s","getSlideClasses","slideData","isActive","isVisible","isDuplicate","isPrev","isNext","renderChildren","ssr_window_esm_isObject","Navigation","Pagination","core","ssrDocument","body","addEventListener","removeEventListener","activeElement","blur","nodeName","querySelector","querySelectorAll","getElementById","createEvent","initEvent","childNodes","setAttribute","getElementsByTagName","createElementNS","importNode","location","hash","host","hostname","href","origin","pathname","protocol","ssr_window_esm_getDocument","doc","document","ssrWindow","navigator","userAgent","history","replaceState","pushState","go","back","CustomEvent","getComputedStyle","getPropertyValue","Image","Date","screen","setTimeout","clearTimeout","matchMedia","requestAnimationFrame","cancelAnimationFrame","id","ssr_window_esm_getWindow","win","Dom7","Array","items","makeReactive","proto","__proto__","defineProperty","get","set","arrayFlat","arr","res","isArray","arrayFilter","dom7_esm_$","selector","context","html","toCreate","tempParent","innerHTML","qsa","a","nodeType","arrayUnique","uniqueArray","fn","noTrigger","shortcut","name","args","trigger","Methods","addClass","classList","add","removeClass","remove","hasClass","contains","toggleClass","toggle","attr","attrs","getAttribute","attrName","removeAttr","removeAttribute","transform","transition","duration","transitionDuration","eventType","targetSelector","listener","capture","handleLiveEvent","e","eventData","dom7EventData","is","parents","k","handleEvent","j","event","dom7LiveListeners","proxyListener","dom7Listeners","handlers","handler","splice","dom7proxy","evt","detail","bubbles","cancelable","data","dataIndex","dispatchEvent","transitionEnd","dom","fireCallBack","outerWidth","includeMargins","styles","offsetWidth","outerHeight","offsetHeight","box","getBoundingClientRect","clientTop","clientLeft","scrollTop","scrollY","scrollLeft","scrollX","left","css","prop","each","text","textContent","compareWith","matches","webkitMatchesSelector","msMatchesSelector","previousSibling","eq","returnIndex","append","els","newChild","tempDiv","firstChild","appendChild","prepend","insertBefore","next","nextElementSibling","nextAll","nextEls","prev","previousElementSibling","prevAll","prevEls","parent","parentNode","closest","find","foundElements","found","result","removeChild","methodName","writable","utils_nextTick","delay","utils_now","now","utils_isObject","isNode","node","HTMLElement","utils_extend","nextSource","keysArray","nextIndex","len","nextKey","desc","getOwnPropertyDescriptor","enumerable","utils_setCSSProperty","varName","varValue","setProperty","animateCSSModeScroll","targetPosition","side","startPosition","translate","startTime","time","speed","wrapperEl","scrollSnapType","cssModeFrameID","dir","isOutOfBound","animate","getTime","progress","max","min","currentPosition","easeProgress","cos","PI","scrollTo","overflow","support","getSupport","calcSupport","smoothScroll","documentElement","touch","DocumentTouch","passiveListener","supportsPassive","opts","gestures","deviceCached","browser","events_emitter","priority","eventsListeners","method","once","onceHandler","__emitterProxy","onAny","eventsAnyListeners","offAny","eventHandler","emit","eventsArray","transitionEmit","runCallbacks","step","activeIndex","previousIndex","onTouchStart","touchEventsData","touches","animating","preventInteractionOnTransition","cssMode","loopFix","originalEvent","$targetEl","touchEventsTarget","isTouchEvent","which","button","isTouched","isMoved","swipingClassHasValue","noSwipingClass","eventPath","composedPath","path","shadowRoot","noSwipingSelector","isTargetShadow","noSwiping","closestElement","base","__closestFrom","assignedSlot","getRootNode","allowClick","swipeHandler","currentX","targetTouches","pageX","currentY","pageY","startX","startY","edgeSwipeDetection","iOSEdgeSwipeDetection","edgeSwipeThreshold","iOSEdgeSwipeThreshold","innerWidth","preventDefault","allowTouchCallbacks","isScrolling","startMoving","touchStartTime","swipeDirection","threshold","allowThresholdMove","focusableElements","shouldPreventDefault","allowTouchMove","touchStartPreventDefault","touchStartForcePreventDefault","isContentEditable","freeMode","onTouchMove","rtl","targetTouch","changedTouches","preventedByNestedSwiper","touchReleaseOnEdges","isVertical","maxTranslate","minTranslate","diffX","diffY","sqrt","touchAngle","atan2","abs","touchMoveStopPropagation","nested","stopPropagation","startTranslate","getTranslate","setTransition","$wrapperEl","allowMomentumBounce","grabCursor","setGrabCursor","diff","touchRatio","currentTranslate","disableParentSwiper","resistanceRatio","resistance","followFinger","watchSlidesProgress","updateActiveIndex","onTouchEnd","slidesGrid","touchEndTime","timeDiff","pathTree","updateClickedSlide","lastClickTime","currentPos","stopIndex","groupSize","slidesSizesGrid","slidesPerGroupSkip","increment","rewindFirstIndex","rewindLastIndex","rewind","isBeginning","isEnd","ratio","longSwipesMs","longSwipes","slideTo","longSwipesRatio","shortSwipes","isNavButtonTarget","onResize","setBreakpoint","snapGrid","centeredSlides","autoplay","running","paused","run","watchOverflow","checkOverflow","onClick","preventClicks","preventClicksPropagation","stopImmediatePropagation","onScroll","previousTranslate","newProgress","translatesDiff","dummyEventAttached","dummyEventListener","touchEvents","device","domMethod","swiperMethod","start","passiveListeners","passive","move","end","cancel","updateOnWindowResize","ios","android","isGridEnabled","grid","rows","initialSlide","resizeObserver","createElements","width","height","url","autoHeight","setWrapperSize","virtualTranslate","effect","breakpointsBase","spaceBetween","slidesPerGroupAuto","centeredSlidesBounds","slidesOffsetBefore","slidesOffsetAfter","normalizeSlideIndex","centerInsufficientSlides","roundLengths","simulateTouch","uniqueNavElements","slideToClickedSlide","preloadImages","updateOnImagesReady","loopPreventsSlide","maxBackfaceHiddenSlides","containerModifierClass","slideActiveClass","slideDuplicateActiveClass","slideVisibleClass","slideNextClass","slideDuplicateNextClass","slidePrevClass","slideDuplicatePrevClass","wrapperClass","runCallbacksOnInit","prototypes","eventsEmitter","$el","clientWidth","clientHeight","parseInt","Number","isNaN","size","getDirectionLabel","property","getDirectionPropertyValue","label","swiperSize","wrongRTL","isVirtual","previousSlidesLength","slidesLength","offsetBefore","offsetAfter","previousSnapGridLength","previousSlidesGridLength","slidePosition","prevSlideSize","virtualSize","marginLeft","marginBottom","marginTop","marginRight","gridEnabled","initSlides","slideSize","shouldResetSlideSize","updateSlide","slideStyles","currentTransform","currentWebKitTransform","webkitTransform","paddingLeft","paddingRight","boxSizing","swiperSlideSize","updateWrapperSize","newSlidesGrid","slidesGridItem","_","slideIndex","allSlidesSize","slideSizeValue","maxSnap","snap","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","v","updateSlidesOffset","backFaceHiddenClass","hasClassBackfaceClassAdded","updateAutoHeight","activeSlides","newHeight","getSlideByIndex","visibleSlides","swiperSlideOffset","offsetLeft","offsetTop","updateSlidesProgress","offsetCenter","visibleSlidesIndexes","slideOffset","slideProgress","originalSlideProgress","slideBefore","slideAfter","originalProgress","multiplier","wasBeginning","wasEnd","realIndex","activeSlide","nextSlide","prevSlide","newActiveIndex","previousRealIndex","previousSnapIndex","skip","slideFound","clickedSlide","clickedIndex","axis","utils_getTranslate","matrix","curTransform","transformMatrix","curStyle","utils_getComputedStyle","currentStyle","WebKitCSSMatrix","MozTransform","OTransform","MsTransform","msTransform","m41","m42","byController","x","y","translateTo","translateBounds","internal","newTranslate","isH","behavior","onTranslateToWrapperTransitionEnd","transitionStart","initial","indexAsNumber","isValidNumber","isFinite","normalizedTranslate","normalizedGrid","normalizedGridNext","t","_immediateVirtual","_swiperImmediateVirtual","onSlideToWrapperTransitionEnd","slideToLoop","newIndex","slideNext","perGroup","slidesPerViewDynamic","_clientLeft","slidePrev","normalize","val","normalizedSnapGrid","prevSnap","prevSnapIndex","prevIndex","lastIndex","slideReset","slideToClosest","currentSnap","nextSnap","slideToIndex","$selector","blankNode","cloneNode","snapTranslate","slideChanged","moving","isLocked","cursor","unsetGrabCursor","currentBreakpoint","breakpointParams","wasMultiRow","isMultiRow","wasEnabled","emitContainerClasses","fill","wasModuleEnabled","isModuleEnabled","disable","enable","directionChanged","needsReLoop","isEnabled","containerEl","currentHeight","innerHeight","points","point","minRatio","sort","b","wasLocked","lastSlideIndex","lastSlideRightEdge","addClasses","suffixes","prepareClasses","entries","prefix","resultClasses","item","removeClasses","images","loadImage","imageEl","srcset","sizes","checkForComplete","image","onReady","isPicture","complete","onload","onerror","imagesLoaded","imagesToLoad","currentSrc","swipers","newParams","getDevice","overrides","calcDevice","platform","ua","screenWidth","screenHeight","match","ipad","ipod","iphone","macos","iPadScreens","os","calcBrowser","isSafari","isWebView","test","modules","__modules__","allModulesParams","extendParams","moduleParamName","moduleParams","auto","$","velocity","desktop","touchEventsTouch","touchEventsDesktop","clickTimeout","velocities","cls","slideEl","updates","view","exact","spv","breakLoop","slideInView","translateValue","translated","newDirection","needUpdate","currentDirection","mounted","getWrapperSelector","getWrapper","options","wrapper","mount","deleteInstance","cleanStyles","deleteProps","object","extendDefaults","newDefaults","installModule","use","module","m","prototypeGroup","protoMethod","observer","animationFrame","resizeHandler","createObserver","ResizeObserver","newWidth","contentBoxSize","contentRect","inlineSize","blockSize","observe","removeObserver","unobserve","orientationChangeHandler","observers","attach","ObserverFunc","MutationObserver","WebkitMutationObserver","mutations","observerUpdate","attributes","childList","characterData","observeParents","containerParents","observeSlideChildren","disconnect","create_element_if_not_defined_createElementIfNotDefined","checkProps","element","getEl","toggleEl","disabled","disabledClass","tagName","lockClass","$nextEl","$prevEl","onPrevClick","onNextClick","hideOnClick","hiddenClass","navigationDisabledClass","targetEl","clickable","isHidden","classes_to_selector_classesToSelector","pfx","bulletElement","renderBullet","renderProgressbar","renderFraction","renderCustom","progressbarOpposite","dynamicBullets","dynamicMainBullets","formatFractionCurrent","number","formatFractionTotal","bulletClass","bulletActiveClass","modifierClass","currentClass","totalClass","progressbarFillClass","progressbarOppositeClass","clickableClass","horizontalClass","verticalClass","paginationDisabledClass","bullets","bulletSize","dynamicBulletIndex","isPaginationDisabled","setSideBullets","$bulletEl","total","paginationType","firstIndex","midIndex","suffix","bullet","$bullet","bulletIndex","$firstDisplayedBullet","$lastDisplayedBullet","dynamicBulletsLength","bulletsOffset","offsetProp","progressbarDirection","scale","scaleX","scaleY","paginationHTML","numberOfBullets"],"sourceRoot":""}