{"version":3,"file":"static/chunks/2379.7ae244455964c03d.js","mappings":"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","sources":["webpack://_N_E/./node_modules/ssr-window/ssr-window.esm.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/shared/process-lazy-preloader.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/onLoad.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/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/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/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/shared/effect-target.js","webpack://_N_E/./node_modules/swiper/shared/effect-virtual-transition-end.js","webpack://_N_E/./node_modules/swiper/modules/effect-fade/effect-fade.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/./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/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/"],"sourcesContent":["/**\n * SSR Window 4.0.2\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2021, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: December 13, 2021\n */\n/* eslint-disable no-param-reassign */\nfunction isObject(obj) {\n return (obj !== null &&\n typeof obj === 'object' &&\n 'constructor' in obj &&\n obj.constructor === Object);\n}\nfunction extend(target = {}, src = {}) {\n Object.keys(src).forEach((key) => {\n if (typeof target[key] === 'undefined')\n target[key] = src[key];\n else if (isObject(src[key]) &&\n isObject(target[key]) &&\n Object.keys(src[key]).length > 0) {\n extend(target[key], src[key]);\n }\n });\n}\n\nconst ssrDocument = {\n body: {},\n addEventListener() { },\n removeEventListener() { },\n activeElement: {\n blur() { },\n nodeName: '',\n },\n querySelector() {\n return null;\n },\n querySelectorAll() {\n return [];\n },\n getElementById() {\n return null;\n },\n createEvent() {\n return {\n initEvent() { },\n };\n },\n createElement() {\n return {\n children: [],\n childNodes: [],\n style: {},\n setAttribute() { },\n getElementsByTagName() {\n return [];\n },\n };\n },\n createElementNS() {\n return {};\n },\n importNode() {\n return null;\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n};\nfunction getDocument() {\n const doc = typeof document !== 'undefined' ? document : {};\n extend(doc, ssrDocument);\n return doc;\n}\n\nconst ssrWindow = {\n document: ssrDocument,\n navigator: {\n userAgent: '',\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n history: {\n replaceState() { },\n pushState() { },\n go() { },\n back() { },\n },\n CustomEvent: function CustomEvent() {\n return this;\n },\n addEventListener() { },\n removeEventListener() { },\n getComputedStyle() {\n return {\n getPropertyValue() {\n return '';\n },\n };\n },\n Image() { },\n Date() { },\n screen: {},\n setTimeout() { },\n clearTimeout() { },\n matchMedia() {\n return {};\n },\n requestAnimationFrame(callback) {\n if (typeof setTimeout === 'undefined') {\n callback();\n return null;\n }\n return setTimeout(callback, 0);\n },\n cancelAnimationFrame(id) {\n if (typeof setTimeout === 'undefined') {\n return;\n }\n clearTimeout(id);\n },\n};\nfunction getWindow() {\n const win = typeof window !== 'undefined' ? window : {};\n extend(win, ssrWindow);\n return win;\n}\n\nexport { extend, getDocument, getWindow, ssrDocument, ssrWindow };\n","import { getWindow, getDocument } from 'ssr-window';\nfunction deleteProps(obj) {\n const object = obj;\n Object.keys(object).forEach(key => {\n try {\n object[key] = null;\n } catch (e) {\n // no getter for object\n }\n try {\n delete object[key];\n } catch (e) {\n // something got wrong\n }\n });\n}\nfunction nextTick(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\nfunction now() {\n return Date.now();\n}\nfunction getComputedStyle(el) {\n const window = getWindow();\n let style;\n if (window.getComputedStyle) {\n style = window.getComputedStyle(el, null);\n }\n if (!style && el.currentStyle) {\n style = el.currentStyle;\n }\n if (!style) {\n style = el.style;\n }\n return style;\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 if (window.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n }\n // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\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 if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41;\n // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[12]);\n // Normal Browsers\n else curTransform = parseFloat(matrix[4]);\n }\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42;\n // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[13]);\n // Normal Browsers\n else curTransform = parseFloat(matrix[5]);\n }\n return curTransform || 0;\n}\nfunction isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\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 return node && (node.nodeType === 1 || node.nodeType === 11);\n}\nfunction extend(...args) {\n const to = Object(args[0]);\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n for (let i = 1; i < args.length; i += 1) {\n const nextSource = args[i];\n if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\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 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 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 return to;\n}\nfunction setCSSProperty(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\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 const isOutOfBound = (current, target) => {\n return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n };\n const animate = () => {\n time = new Date().getTime();\n if (startTime === null) {\n startTime = time;\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 if (isOutOfBound(currentPosition, targetPosition)) {\n currentPosition = targetPosition;\n }\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\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 swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n };\n animate();\n}\nfunction getSlideTransformEl(slideEl) {\n return slideEl.querySelector('.swiper-slide-transform') || slideEl.shadowEl && slideEl.shadowEl.querySelector('.swiper-slide-transform') || slideEl;\n}\nfunction findElementsInElements(elements = [], selector = '') {\n const found = [];\n elements.forEach(el => {\n found.push(...el.querySelectorAll(selector));\n });\n return found;\n}\nfunction elementChildren(element, selector = '') {\n return [...element.children].filter(el => el.matches(selector));\n}\nfunction createElement(tag, classes = []) {\n const el = document.createElement(tag);\n el.classList.add(...(Array.isArray(classes) ? classes : [classes]));\n return el;\n}\nfunction elementOffset(el) {\n const window = getWindow();\n const document = getDocument();\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}\nfunction elementPrevAll(el, selector) {\n const prevEls = [];\n while (el.previousElementSibling) {\n const prev = el.previousElementSibling; // eslint-disable-line\n if (selector) {\n if (prev.matches(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n el = prev;\n }\n return prevEls;\n}\nfunction elementNextAll(el, selector) {\n const nextEls = [];\n while (el.nextElementSibling) {\n const next = el.nextElementSibling; // eslint-disable-line\n if (selector) {\n if (next.matches(selector)) nextEls.push(next);\n } else nextEls.push(next);\n el = next;\n }\n return nextEls;\n}\nfunction elementStyle(el, prop) {\n const window = getWindow();\n return window.getComputedStyle(el, null).getPropertyValue(prop);\n}\nfunction elementIndex(el) {\n let child = el;\n let i;\n if (child) {\n i = 0;\n // eslint-disable-next-line\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) i += 1;\n }\n return i;\n }\n return undefined;\n}\nfunction elementParents(el, selector) {\n const parents = []; // eslint-disable-line\n let parent = el.parentElement; // eslint-disable-line\n while (parent) {\n if (selector) {\n if (parent.matches(selector)) parents.push(parent);\n } else {\n parents.push(parent);\n }\n parent = parent.parentElement;\n }\n return parents;\n}\nfunction elementTransitionEnd(el, callback) {\n function fireCallBack(e) {\n if (e.target !== el) return;\n callback.call(el, e);\n el.removeEventListener('transitionend', fireCallBack);\n }\n if (callback) {\n el.addEventListener('transitionend', fireCallBack);\n }\n}\nfunction elementOuterSize(el, size, includeMargins) {\n const window = getWindow();\n if (includeMargins) {\n return el[size === 'width' ? 'offsetWidth' : 'offsetHeight'] + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-right' : 'margin-top')) + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-left' : 'margin-bottom'));\n }\n return el.offsetWidth;\n}\nexport { animateCSSModeScroll, deleteProps, nextTick, now, getTranslate, isObject, extend, getComputedStyle, setCSSProperty, getSlideTransformEl,\n// dom\nfindElementsInElements, createElement, elementChildren, elementOffset, elementPrevAll, elementNextAll, elementStyle, elementIndex, elementParents, elementTransitionEnd, elementOuterSize };","import { getWindow, getDocument } from 'ssr-window';\nlet support;\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 };\n}\nfunction getSupport() {\n if (!support) {\n support = calcSupport();\n }\n return support;\n}\nexport { getSupport };","import { getWindow } from 'ssr-window';\nimport { getSupport } from './get-support.js';\nlet deviceCached;\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 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';\n\n // iPadOs 13 fix\n const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\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 }\n\n // Android\n if (android && !windows) {\n device.os = 'android';\n device.android = true;\n }\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n }\n\n // Export object\n return device;\n}\nfunction getDevice(overrides = {}) {\n if (!deviceCached) {\n deviceCached = calcDevice(overrides);\n }\n return deviceCached;\n}\nexport { getDevice };","import { getWindow } from 'ssr-window';\nlet browser;\nfunction calcBrowser() {\n const window = getWindow();\n let needPerspectiveFix = false;\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 if (isSafari()) {\n const ua = String(window.navigator.userAgent);\n if (ua.includes('Version/')) {\n const [major, minor] = ua.split('Version/')[1].split(' ')[0].split('.').map(num => Number(num));\n needPerspectiveFix = major < 16 || major === 16 && minor < 2;\n }\n }\n return {\n isSafari: needPerspectiveFix || isSafari(),\n needPerspectiveFix,\n isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n };\n}\nfunction getBrowser() {\n if (!browser) {\n browser = calcBrowser();\n }\n return browser;\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 const resizeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('beforeResize');\n emit('resize');\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 if (newWidth !== width || newHeight !== height) {\n resizeHandler();\n }\n });\n });\n observer.observe(swiper.el);\n };\n const removeObserver = () => {\n if (animationFrame) {\n window.cancelAnimationFrame(animationFrame);\n }\n if (observer && observer.unobserve && swiper.el) {\n observer.unobserve(swiper.el);\n observer = null;\n }\n };\n const orientationChangeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('orientationchange');\n };\n on('init', () => {\n if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n createObserver();\n return;\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';\nimport { elementParents } from '../../../shared/utils.js';\nexport default function Observer({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const observers = [];\n const window = getWindow();\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 (swiper.__preventObserver__) return;\n if (mutations.length === 1) {\n emit('observerUpdate', mutations[0]);\n return;\n }\n const observerUpdate = function observerUpdate() {\n emit('observerUpdate', mutations[0]);\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 const init = () => {\n if (!swiper.params.observer) return;\n if (swiper.params.observeParents) {\n const containerParents = elementParents(swiper.el);\n for (let i = 0; i < containerParents.length; i += 1) {\n attach(containerParents[i]);\n }\n }\n // Observe container\n attach(swiper.el, {\n childList: swiper.params.observeSlideChildren\n });\n\n // Observe wrapper\n attach(swiper.wrapperEl, {\n attributes: false\n });\n };\n const destroy = () => {\n observers.forEach(observer => {\n observer.disconnect();\n });\n observers.splice(0, observers.length);\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 */\n\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 once(events, handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n function onceHandler(...args) {\n self.off(events, onceHandler);\n if (onceHandler.__emitterProxy) {\n delete onceHandler.__emitterProxy;\n }\n handler.apply(self, args);\n }\n onceHandler.__emitterProxy = handler;\n return self.on(events, onceHandler, priority);\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 if (self.eventsAnyListeners.indexOf(handler) < 0) {\n self.eventsAnyListeners[method](handler);\n }\n return self;\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 if (index >= 0) {\n self.eventsAnyListeners.splice(index, 1);\n }\n return self;\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 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 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 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 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};","import { elementStyle } from '../../shared/utils.js';\nexport default function updateSize() {\n const swiper = this;\n let width;\n let height;\n const el = swiper.el;\n if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n width = swiper.params.width;\n } else {\n width = el.clientWidth;\n }\n if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n height = swiper.params.height;\n } else {\n height = el.clientHeight;\n }\n if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n return;\n }\n\n // Subtract paddings\n width = width - parseInt(elementStyle(el, 'padding-left') || 0, 10) - parseInt(elementStyle(el, 'padding-right') || 0, 10);\n height = height - parseInt(elementStyle(el, 'padding-top') || 0, 10) - parseInt(elementStyle(el, '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 { elementChildren, elementOuterSize, elementStyle, setCSSProperty } from '../../shared/utils.js';\nexport default function updateSlides() {\n const swiper = this;\n function getDirectionLabel(property) {\n if (swiper.isHorizontal()) {\n return property;\n }\n // prettier-ignore\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 function getDirectionPropertyValue(node, label) {\n return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);\n }\n const params = swiper.params;\n const {\n wrapperEl,\n slidesEl,\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 = elementChildren(slidesEl, `.${swiper.params.slideClass}, swiper-slide`);\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 if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n let offsetAfter = params.slidesOffsetAfter;\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\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 if (typeof swiperSize === 'undefined') {\n return;\n }\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n } else if (typeof spaceBetween === 'string') {\n spaceBetween = parseFloat(spaceBetween);\n }\n swiper.virtualSize = -spaceBetween;\n\n // reset margins\n slides.forEach(slideEl => {\n if (rtl) {\n slideEl.style.marginLeft = '';\n } else {\n slideEl.style.marginRight = '';\n }\n slideEl.style.marginBottom = '';\n slideEl.style.marginTop = '';\n });\n\n // reset cssMode offsets\n if (params.centeredSlides && params.cssMode) {\n setCSSProperty(wrapperEl, '--swiper-centered-offset-before', '');\n setCSSProperty(wrapperEl, '--swiper-centered-offset-after', '');\n }\n const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n if (gridEnabled) {\n swiper.grid.initSlides(slidesLength);\n }\n\n // Calc slides\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 for (let i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n let slide;\n if (slides[i]) slide = slides[i];\n if (gridEnabled) {\n swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n }\n if (slides[i] && elementStyle(slide, 'display') === 'none') continue; // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n if (shouldResetSlideSize) {\n slides[i].style[getDirectionLabel('width')] = ``;\n }\n const slideStyles = getComputedStyle(slide);\n const currentTransform = slide.style.transform;\n const currentWebKitTransform = slide.style.webkitTransform;\n if (currentTransform) {\n slide.style.transform = 'none';\n }\n if (currentWebKitTransform) {\n slide.style.webkitTransform = 'none';\n }\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal() ? elementOuterSize(slide, 'width', true) : elementOuterSize(slide, 'height', 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 if (boxSizing && boxSizing === 'border-box') {\n slideSize = width + marginLeft + marginRight;\n } else {\n const {\n clientWidth,\n offsetWidth\n } = slide;\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n }\n }\n if (currentTransform) {\n slide.style.transform = currentTransform;\n }\n if (currentWebKitTransform) {\n slide.style.webkitTransform = currentWebKitTransform;\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 if (slides[i]) {\n slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;\n }\n }\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n slidesSizesGrid.push(slideSize);\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 swiper.virtualSize += slideSize + spaceBetween;\n prevSlideSize = slideSize;\n index += 1;\n }\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n wrapperEl.style.width = `${swiper.virtualSize + spaceBetween}px`;\n }\n if (params.setWrapperSize) {\n wrapperEl.style[getDirectionLabel('width')] = `${swiper.virtualSize + spaceBetween}px`;\n }\n if (gridEnabled) {\n swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\n }\n\n // Remove last grid elements depending on width\n if (!params.centeredSlides) {\n const newSlidesGrid = [];\n for (let i = 0; i < snapGrid.length; i += 1) {\n let slidesGridItem = snapGrid[i];\n if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem);\n }\n }\n snapGrid = newSlidesGrid;\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n if (isVirtual && params.loop) {\n const size = slidesSizesGrid[0] + spaceBetween;\n if (params.slidesPerGroup > 1) {\n const groups = Math.ceil((swiper.virtual.slidesBefore + swiper.virtual.slidesAfter) / params.slidesPerGroup);\n const groupSize = size * params.slidesPerGroup;\n for (let i = 0; i < groups; i += 1) {\n snapGrid.push(snapGrid[snapGrid.length - 1] + groupSize);\n }\n }\n for (let i = 0; i < swiper.virtual.slidesBefore + swiper.virtual.slidesAfter; i += 1) {\n if (params.slidesPerGroup === 1) {\n snapGrid.push(snapGrid[snapGrid.length - 1] + size);\n }\n slidesGrid.push(slidesGrid[slidesGrid.length - 1] + size);\n swiper.virtualSize += size;\n }\n }\n if (snapGrid.length === 0) snapGrid = [0];\n if (spaceBetween !== 0) {\n const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');\n slides.filter((_, slideIndex) => {\n if (!params.cssMode || params.loop) return true;\n if (slideIndex === slides.length - 1) {\n return false;\n }\n return true;\n }).forEach(slideEl => {\n slideEl.style[key] = `${spaceBetween}px`;\n });\n }\n if (params.centeredSlides && params.centeredSlidesBounds) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (spaceBetween || 0);\n });\n allSlidesSize -= 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 if (params.centerInsufficientSlides) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (spaceBetween || 0);\n });\n allSlidesSize -= spaceBetween;\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 Object.assign(swiper, {\n slides,\n snapGrid,\n slidesGrid,\n slidesSizesGrid\n });\n if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n setCSSProperty(wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n setCSSProperty(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 if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n swiper.emit('snapGridLengthChange');\n }\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n if (params.watchSlidesProgress) {\n swiper.updateSlidesOffset();\n }\n if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {\n const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;\n const hasClassBackfaceClassAdded = swiper.el.classList.contains(backFaceHiddenClass);\n if (slidesLength <= params.maxBackfaceHiddenSlides) {\n if (!hasClassBackfaceClassAdded) swiper.el.classList.add(backFaceHiddenClass);\n } else if (hasClassBackfaceClassAdded) {\n swiper.el.classList.remove(backFaceHiddenClass);\n }\n }\n}","export 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 if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n const getSlideByIndex = index => {\n if (isVirtual) {\n return swiper.slides[swiper.getSlideIndexByData(index)];\n }\n return swiper.slides[index];\n };\n // Find slides currently in view\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n if (swiper.params.centeredSlides) {\n (swiper.visibleSlides || []).forEach(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 }\n\n // Find new height from highest slide in view\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 }\n\n // Update Height\n if (newHeight || newHeight === 0) swiper.wrapperEl.style.height = `${newHeight}px`;\n}","export default function updateSlidesOffset() {\n const swiper = this;\n const slides = swiper.slides;\n // eslint-disable-next-line\n const minusOffset = swiper.isElement ? swiper.isHorizontal() ? swiper.wrapperEl.offsetLeft : swiper.wrapperEl.offsetTop : 0;\n for (let i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = (swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop) - minusOffset - swiper.cssOverflowAdjustment();\n }\n}","export 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;\n\n // Visible Slides\n slides.forEach(slideEl => {\n slideEl.classList.remove(params.slideVisibleClass);\n });\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n let spaceBetween = params.spaceBetween;\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiper.size;\n } else if (typeof spaceBetween === 'string') {\n spaceBetween = parseFloat(spaceBetween);\n }\n for (let i = 0; i < slides.length; i += 1) {\n const slide = slides[i];\n let slideOffset = slide.swiperSlideOffset;\n if (params.cssMode && params.centeredSlides) {\n slideOffset -= slides[0].swiperSlideOffset;\n }\n const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + spaceBetween);\n const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + 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 if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides[i].classList.add(params.slideVisibleClass);\n }\n slide.progress = rtl ? -slideProgress : slideProgress;\n slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n }\n}","export default function updateProgress(translate) {\n const swiper = this;\n if (typeof translate === 'undefined') {\n const multiplier = swiper.rtlTranslate ? -1 : 1;\n // eslint-disable-next-line\n translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n }\n const params = swiper.params;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n let {\n progress,\n isBeginning,\n isEnd,\n progressLoop\n } = swiper;\n const wasBeginning = isBeginning;\n const wasEnd = isEnd;\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / translatesDiff;\n const isBeginningRounded = Math.abs(translate - swiper.minTranslate()) < 1;\n const isEndRounded = Math.abs(translate - swiper.maxTranslate()) < 1;\n isBeginning = isBeginningRounded || progress <= 0;\n isEnd = isEndRounded || progress >= 1;\n if (isBeginningRounded) progress = 0;\n if (isEndRounded) progress = 1;\n }\n if (params.loop) {\n const firstSlideIndex = swiper.getSlideIndexByData(0);\n const lastSlideIndex = swiper.getSlideIndexByData(swiper.slides.length - 1);\n const firstSlideTranslate = swiper.slidesGrid[firstSlideIndex];\n const lastSlideTranslate = swiper.slidesGrid[lastSlideIndex];\n const translateMax = swiper.slidesGrid[swiper.slidesGrid.length - 1];\n const translateAbs = Math.abs(translate);\n if (translateAbs >= firstSlideTranslate) {\n progressLoop = (translateAbs - firstSlideTranslate) / translateMax;\n } else {\n progressLoop = (translateAbs + translateMax - lastSlideTranslate) / translateMax;\n }\n if (progressLoop > 1) progressLoop -= 1;\n }\n Object.assign(swiper, {\n progress,\n progressLoop,\n isBeginning,\n isEnd\n });\n if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n swiper.emit('fromEdge');\n }\n swiper.emit('progress', progress);\n}","import { elementChildren, elementNextAll, elementPrevAll } from '../../shared/utils.js';\nexport default function updateSlidesClasses() {\n const swiper = this;\n const {\n slides,\n params,\n slidesEl,\n activeIndex\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n const getFilteredSlide = selector => {\n return elementChildren(slidesEl, `.${params.slideClass}${selector}, swiper-slide${selector}`)[0];\n };\n slides.forEach(slideEl => {\n slideEl.classList.remove(params.slideActiveClass, params.slideNextClass, params.slidePrevClass);\n });\n let activeSlide;\n if (isVirtual) {\n if (params.loop) {\n let slideIndex = activeIndex - swiper.virtual.slidesBefore;\n if (slideIndex < 0) slideIndex = swiper.virtual.slides.length + slideIndex;\n if (slideIndex >= swiper.virtual.slides.length) slideIndex -= swiper.virtual.slides.length;\n activeSlide = getFilteredSlide(`[data-swiper-slide-index=\"${slideIndex}\"]`);\n } else {\n activeSlide = getFilteredSlide(`[data-swiper-slide-index=\"${activeIndex}\"]`);\n }\n } else {\n activeSlide = slides[activeIndex];\n }\n if (activeSlide) {\n // Active classes\n activeSlide.classList.add(params.slideActiveClass);\n\n // Next Slide\n let nextSlide = elementNextAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];\n if (params.loop && !nextSlide) {\n nextSlide = slides[0];\n }\n if (nextSlide) {\n nextSlide.classList.add(params.slideNextClass);\n }\n // Prev Slide\n let prevSlide = elementPrevAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];\n if (params.loop && !prevSlide === 0) {\n prevSlide = slides[slides.length - 1];\n }\n if (prevSlide) {\n prevSlide.classList.add(params.slidePrevClass);\n }\n }\n swiper.emitSlidesClasses();\n}","export const processLazyPreloader = (swiper, imageEl) => {\n if (!swiper || swiper.destroyed || !swiper.params) return;\n const slideSelector = () => swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;\n const slideEl = imageEl.closest(slideSelector());\n if (slideEl) {\n const lazyEl = slideEl.querySelector(`.${swiper.params.lazyPreloaderClass}`);\n if (lazyEl) lazyEl.remove();\n }\n};\nconst unlazy = (swiper, index) => {\n if (!swiper.slides[index]) return;\n const imageEl = swiper.slides[index].querySelector('[loading=\"lazy\"]');\n if (imageEl) imageEl.removeAttribute('loading');\n};\nexport const preload = swiper => {\n if (!swiper || swiper.destroyed || !swiper.params) return;\n let amount = swiper.params.lazyPreloadPrevNext;\n const len = swiper.slides.length;\n if (!len || !amount || amount < 0) return;\n amount = Math.min(amount, len);\n const slidesPerView = swiper.params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(swiper.params.slidesPerView);\n const activeIndex = swiper.activeIndex;\n const slideIndexLastInView = activeIndex + slidesPerView - 1;\n if (swiper.params.rewind) {\n for (let i = activeIndex - amount; i <= slideIndexLastInView + amount; i += 1) {\n const realIndex = (i % len + len) % len;\n if (realIndex !== activeIndex && realIndex > slideIndexLastInView) unlazy(swiper, realIndex);\n }\n } else {\n for (let i = Math.max(slideIndexLastInView - amount, 0); i <= Math.min(slideIndexLastInView + amount, len - 1); i += 1) {\n if (i !== activeIndex && i > slideIndexLastInView) unlazy(swiper, i);\n }\n }\n};","import { preload } from '../../shared/process-lazy-preloader.js';\nexport function getActiveIndexByTranslate(swiper) {\n const {\n slidesGrid,\n params\n } = swiper;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n let activeIndex;\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 }\n // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n }\n return activeIndex;\n}\nexport default function updateActiveIndex(newActiveIndex) {\n const swiper = this;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n const {\n snapGrid,\n params,\n activeIndex: previousIndex,\n realIndex: previousRealIndex,\n snapIndex: previousSnapIndex\n } = swiper;\n let activeIndex = newActiveIndex;\n let snapIndex;\n const getVirtualRealIndex = aIndex => {\n let realIndex = aIndex - swiper.virtual.slidesBefore;\n if (realIndex < 0) {\n realIndex = swiper.virtual.slides.length + realIndex;\n }\n if (realIndex >= swiper.virtual.slides.length) {\n realIndex -= swiper.virtual.slides.length;\n }\n return realIndex;\n };\n if (typeof activeIndex === 'undefined') {\n activeIndex = getActiveIndexByTranslate(swiper);\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 if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n if (swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {\n swiper.realIndex = getVirtualRealIndex(activeIndex);\n }\n return;\n }\n // Get real index\n let realIndex;\n if (swiper.virtual && params.virtual.enabled && params.loop) {\n realIndex = getVirtualRealIndex(activeIndex);\n } else if (swiper.slides[activeIndex]) {\n realIndex = parseInt(swiper.slides[activeIndex].getAttribute('data-swiper-slide-index') || activeIndex, 10);\n } else {\n realIndex = activeIndex;\n }\n Object.assign(swiper, {\n previousSnapIndex,\n snapIndex,\n previousRealIndex,\n realIndex,\n previousIndex,\n activeIndex\n });\n if (swiper.initialized) {\n preload(swiper);\n }\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n}","export default function updateClickedSlide(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = e.closest(`.${params.slideClass}, swiper-slide`);\n let slideFound = false;\n let slideIndex;\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 if (slide && slideFound) {\n swiper.clickedSlide = slide;\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt(slide.getAttribute('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 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 if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n if (params.cssMode) {\n return translate;\n }\n let currentTranslate = getTranslate(wrapperEl, axis);\n currentTranslate += swiper.cssOverflowAdjustment();\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 progress\n } = swiper;\n let x = 0;\n let y = 0;\n const z = 0;\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y;\n if (params.cssMode) {\n wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n } else if (!params.virtualTranslate) {\n if (swiper.isHorizontal()) {\n x -= swiper.cssOverflowAdjustment();\n } else {\n y -= swiper.cssOverflowAdjustment();\n }\n wrapperEl.style.transform = `translate3d(${x}px, ${y}px, ${z}px)`;\n }\n\n // Check if we need to update progress\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n }\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\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 if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\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;\n\n // Update progress\n swiper.updateProgress(newTranslate);\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\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 wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: -newTranslate,\n behavior: 'smooth'\n });\n }\n return true;\n }\n if (speed === 0) {\n swiper.setTransition(0);\n swiper.setTranslate(newTranslate);\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 if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionStart');\n }\n if (!swiper.animating) {\n swiper.animating = true;\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.removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.onTranslateToWrapperTransitionEnd = null;\n delete swiper.onTranslateToWrapperTransitionEnd;\n if (runCallbacks) {\n swiper.emit('transitionEnd');\n }\n };\n }\n swiper.wrapperEl.addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\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 if (!swiper.params.cssMode) {\n swiper.wrapperEl.style.transitionDuration = `${duration}ms`;\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 if (!dir) {\n if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n }\n swiper.emit(`transition${step}`);\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit(`slideResetTransition${step}`);\n return;\n }\n swiper.emit(`slideChangeTransition${step}`);\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 if (params.autoHeight) {\n swiper.updateAutoHeight();\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 === 'string') {\n index = parseInt(index, 10);\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 if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {\n return false;\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];\n // Normalize slideIndex\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 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 }\n // Directions locks\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) {\n return false;\n }\n }\n }\n if (slideIndex !== (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n }\n\n // Update progress\n swiper.updateProgress(translate);\n let direction;\n if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset';\n\n // Update Index\n if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n swiper.updateActiveIndex(slideIndex);\n // Update Height\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n swiper.updateSlidesClasses();\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n return false;\n }\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n const t = rtl ? translate : -translate;\n if (speed === 0) {\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n if (isVirtual) {\n swiper.wrapperEl.style.scrollSnapType = 'none';\n swiper._immediateVirtual = true;\n }\n if (isVirtual && !swiper._cssModeVirtualInitialSet && swiper.params.initialSlide > 0) {\n swiper._cssModeVirtualInitialSet = true;\n requestAnimationFrame(() => {\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n });\n } else {\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n }\n if (isVirtual) {\n requestAnimationFrame(() => {\n swiper.wrapperEl.style.scrollSnapType = '';\n swiper._immediateVirtual = 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 wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: t,\n behavior: 'smooth'\n });\n }\n return true;\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 if (speed === 0) {\n swiper.transitionEnd(runCallbacks, direction);\n } else if (!swiper.animating) {\n swiper.animating = true;\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.removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n swiper.wrapperEl.addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n }\n return true;\n}","export default function slideToLoop(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n if (typeof index === 'string') {\n const indexAsNumber = parseInt(index, 10);\n index = indexAsNumber;\n }\n const swiper = this;\n let newIndex = index;\n if (swiper.params.loop) {\n if (swiper.virtual && swiper.params.virtual.enabled) {\n // eslint-disable-next-line\n newIndex = newIndex + swiper.virtual.slidesBefore;\n } else {\n newIndex = swiper.getSlideIndexByData(newIndex);\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 enabled,\n params,\n animating\n } = swiper;\n if (!enabled) return swiper;\n let perGroup = params.slidesPerGroup;\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n }\n const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n if (params.loop) {\n if (animating && !isVirtual && params.loopPreventsSliding) return false;\n swiper.loopFix({\n direction: 'next'\n });\n // eslint-disable-next-line\n swiper._clientLeft = swiper.wrapperEl.clientLeft;\n }\n if (params.rewind && swiper.isEnd) {\n return swiper.slideTo(0, speed, runCallbacks, internal);\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 snapGrid,\n slidesGrid,\n rtlTranslate,\n enabled,\n animating\n } = swiper;\n if (!enabled) return swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n if (params.loop) {\n if (animating && !isVirtual && params.loopPreventsSliding) return false;\n swiper.loopFix({\n direction: 'prev'\n });\n // eslint-disable-next-line\n swiper._clientLeft = swiper.wrapperEl.clientLeft;\n }\n const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n function normalize(val) {\n if (val < 0) return -Math.floor(Math.abs(val));\n return Math.floor(val);\n }\n const normalizedTranslate = normalize(translate);\n const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\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 if (typeof prevSnapIndex !== 'undefined') {\n prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n }\n }\n let prevIndex = 0;\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\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 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 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 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 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 if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n index -= swiper.params.slidesPerGroup;\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 { elementChildren, nextTick } from '../../shared/utils.js';\nexport default function slideToClickedSlide() {\n const swiper = this;\n const {\n params,\n slidesEl\n } = swiper;\n const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n let slideToIndex = swiper.clickedIndex;\n let realIndex;\n const slideSelector = swiper.isElement ? `swiper-slide` : `.${params.slideClass}`;\n if (params.loop) {\n if (swiper.animating) return;\n realIndex = parseInt(swiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);\n if (params.centeredSlides) {\n if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n swiper.loopFix();\n slideToIndex = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index=\"${realIndex}\"]`)[0]);\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 = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index=\"${realIndex}\"]`)[0]);\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 { elementChildren } from '../../shared/utils.js';\nexport default function loopCreate(slideRealIndex) {\n const swiper = this;\n const {\n params,\n slidesEl\n } = swiper;\n if (!params.loop || swiper.virtual && swiper.params.virtual.enabled) return;\n const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n slides.forEach((el, index) => {\n el.setAttribute('data-swiper-slide-index', index);\n });\n swiper.loopFix({\n slideRealIndex,\n direction: params.centeredSlides ? undefined : 'next'\n });\n}","export default function loopFix({\n slideRealIndex,\n slideTo = true,\n direction,\n setTranslate,\n activeSlideIndex,\n byController,\n byMousewheel\n} = {}) {\n const swiper = this;\n if (!swiper.params.loop) return;\n swiper.emit('beforeLoopFix');\n const {\n slides,\n allowSlidePrev,\n allowSlideNext,\n slidesEl,\n params\n } = swiper;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n if (swiper.virtual && params.virtual.enabled) {\n if (slideTo) {\n if (!params.centeredSlides && swiper.snapIndex === 0) {\n swiper.slideTo(swiper.virtual.slides.length, 0, false, true);\n } else if (params.centeredSlides && swiper.snapIndex < params.slidesPerView) {\n swiper.slideTo(swiper.virtual.slides.length + swiper.snapIndex, 0, false, true);\n } else if (swiper.snapIndex === swiper.snapGrid.length - 1) {\n swiper.slideTo(swiper.virtual.slidesBefore, 0, false, true);\n }\n }\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n swiper.emit('loopFix');\n return;\n }\n const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(parseFloat(params.slidesPerView, 10));\n let loopedSlides = params.loopedSlides || slidesPerView;\n if (loopedSlides % params.slidesPerGroup !== 0) {\n loopedSlides += params.slidesPerGroup - loopedSlides % params.slidesPerGroup;\n }\n swiper.loopedSlides = loopedSlides;\n const prependSlidesIndexes = [];\n const appendSlidesIndexes = [];\n let activeIndex = swiper.activeIndex;\n if (typeof activeSlideIndex === 'undefined') {\n activeSlideIndex = swiper.getSlideIndex(swiper.slides.filter(el => el.classList.contains(params.slideActiveClass))[0]);\n } else {\n activeIndex = activeSlideIndex;\n }\n const isNext = direction === 'next' || !direction;\n const isPrev = direction === 'prev' || !direction;\n let slidesPrepended = 0;\n let slidesAppended = 0;\n // prepend last slides before start\n if (activeSlideIndex < loopedSlides) {\n slidesPrepended = Math.max(loopedSlides - activeSlideIndex, params.slidesPerGroup);\n for (let i = 0; i < loopedSlides - activeSlideIndex; i += 1) {\n const index = i - Math.floor(i / slides.length) * slides.length;\n prependSlidesIndexes.push(slides.length - index - 1);\n }\n } else if (activeSlideIndex /* + slidesPerView */ > swiper.slides.length - loopedSlides * 2) {\n slidesAppended = Math.max(activeSlideIndex - (swiper.slides.length - loopedSlides * 2), params.slidesPerGroup);\n for (let i = 0; i < slidesAppended; i += 1) {\n const index = i - Math.floor(i / slides.length) * slides.length;\n appendSlidesIndexes.push(index);\n }\n }\n if (isPrev) {\n prependSlidesIndexes.forEach(index => {\n swiper.slides[index].swiperLoopMoveDOM = true;\n slidesEl.prepend(swiper.slides[index]);\n swiper.slides[index].swiperLoopMoveDOM = false;\n });\n }\n if (isNext) {\n appendSlidesIndexes.forEach(index => {\n swiper.slides[index].swiperLoopMoveDOM = true;\n slidesEl.append(swiper.slides[index]);\n swiper.slides[index].swiperLoopMoveDOM = false;\n });\n }\n swiper.recalcSlides();\n if (params.slidesPerView === 'auto') {\n swiper.updateSlides();\n }\n if (params.watchSlidesProgress) {\n swiper.updateSlidesOffset();\n }\n if (slideTo) {\n if (prependSlidesIndexes.length > 0 && isPrev) {\n if (typeof slideRealIndex === 'undefined') {\n const currentSlideTranslate = swiper.slidesGrid[activeIndex];\n const newSlideTranslate = swiper.slidesGrid[activeIndex + slidesPrepended];\n const diff = newSlideTranslate - currentSlideTranslate;\n if (byMousewheel) {\n swiper.setTranslate(swiper.translate - diff);\n } else {\n swiper.slideTo(activeIndex + slidesPrepended, 0, false, true);\n if (setTranslate) {\n swiper.touches[swiper.isHorizontal() ? 'startX' : 'startY'] += diff;\n }\n }\n } else {\n if (setTranslate) {\n swiper.slideToLoop(slideRealIndex, 0, false, true);\n }\n }\n } else if (appendSlidesIndexes.length > 0 && isNext) {\n if (typeof slideRealIndex === 'undefined') {\n const currentSlideTranslate = swiper.slidesGrid[activeIndex];\n const newSlideTranslate = swiper.slidesGrid[activeIndex - slidesAppended];\n const diff = newSlideTranslate - currentSlideTranslate;\n if (byMousewheel) {\n swiper.setTranslate(swiper.translate - diff);\n } else {\n swiper.slideTo(activeIndex - slidesAppended, 0, false, true);\n if (setTranslate) {\n swiper.touches[swiper.isHorizontal() ? 'startX' : 'startY'] += diff;\n }\n }\n } else {\n swiper.slideToLoop(slideRealIndex, 0, false, true);\n }\n }\n }\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n if (swiper.controller && swiper.controller.control && !byController) {\n const loopParams = {\n slideRealIndex,\n slideTo: false,\n direction,\n setTranslate,\n activeSlideIndex,\n byController: true\n };\n if (Array.isArray(swiper.controller.control)) {\n swiper.controller.control.forEach(c => {\n if (!c.destroyed && c.params.loop) c.loopFix(loopParams);\n });\n } else if (swiper.controller.control instanceof swiper.constructor && swiper.controller.control.params.loop) {\n swiper.controller.control.loopFix(loopParams);\n }\n }\n swiper.emit('loopFix');\n}","export default function loopDestroy() {\n const swiper = this;\n const {\n params,\n slidesEl\n } = swiper;\n if (!params.loop || swiper.virtual && swiper.params.virtual.enabled) return;\n swiper.recalcSlides();\n const newSlidesOrder = [];\n swiper.slides.forEach(slideEl => {\n const index = typeof slideEl.swiperSlideIndex === 'undefined' ? slideEl.getAttribute('data-swiper-slide-index') * 1 : slideEl.swiperSlideIndex;\n newSlidesOrder[index] = slideEl;\n });\n swiper.slides.forEach(slideEl => {\n slideEl.removeAttribute('data-swiper-slide-index');\n });\n newSlidesOrder.forEach(slideEl => {\n slidesEl.append(slideEl);\n });\n swiper.recalcSlides();\n swiper.slideTo(swiper.realIndex, 0);\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.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n if (swiper.isElement) {\n swiper.__preventObserver__ = true;\n }\n el.style.cursor = 'move';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n if (swiper.isElement) {\n requestAnimationFrame(() => {\n swiper.__preventObserver__ = false;\n });\n }\n}","export default function unsetGrabCursor() {\n const swiper = this;\n if (swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n return;\n }\n if (swiper.isElement) {\n swiper.__preventObserver__ = true;\n }\n swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n if (swiper.isElement) {\n requestAnimationFrame(() => {\n swiper.__preventObserver__ = false;\n });\n }\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 { now } from '../../shared/utils.js';\n\n// Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\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 if (!found && !el.getRootNode) {\n return null;\n }\n return found || __closestFrom(el.getRootNode().host);\n }\n return __closestFrom(base);\n}\nexport default function onTouchStart(event) {\n const swiper = this;\n const document = getDocument();\n const window = getWindow();\n const data = swiper.touchEventsData;\n data.evCache.push(event);\n const {\n params,\n touches,\n enabled\n } = swiper;\n if (!enabled) return;\n if (!params.simulateTouch && event.pointerType === 'mouse') return;\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n if (!swiper.animating && params.cssMode && params.loop) {\n swiper.loopFix();\n }\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n let targetEl = e.target;\n if (params.touchEventsTarget === 'wrapper') {\n if (!swiper.wrapperEl.contains(targetEl)) return;\n }\n if ('which' in e && e.which === 3) return;\n if ('button' in e && e.button > 0) return;\n if (data.isTouched && data.isMoved) return;\n\n // change target el for shadow root component\n const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== '';\n // eslint-disable-next-line\n const eventPath = event.composedPath ? event.composedPath() : event.path;\n if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {\n targetEl = eventPath[0];\n }\n const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n const isTargetShadow = !!(e.target && e.target.shadowRoot);\n\n // use closestElement for shadow root element to get the actual closest for nested shadow root element\n if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, targetEl) : targetEl.closest(noSwipingSelector))) {\n swiper.allowClick = true;\n return;\n }\n if (params.swipeHandler) {\n if (!targetEl.closest(params.swipeHandler)) return;\n }\n touches.currentX = e.pageX;\n touches.currentY = e.pageY;\n const startX = touches.currentX;\n const startY = touches.currentY;\n\n // 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 if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n if (edgeSwipeDetection === 'prevent') {\n event.preventDefault();\n } else {\n return;\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 let preventDefault = true;\n if (targetEl.matches(data.focusableElements)) {\n preventDefault = false;\n if (targetEl.nodeName === 'SELECT') {\n data.isTouched = false;\n }\n }\n if (document.activeElement && document.activeElement.matches(data.focusableElements) && document.activeElement !== targetEl) {\n document.activeElement.blur();\n }\n const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !targetEl.isContentEditable) {\n e.preventDefault();\n }\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {\n swiper.freeMode.onTouchStart();\n }\n swiper.emit('touchStart', e);\n}","import { getDocument } from 'ssr-window';\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 if (!params.simulateTouch && event.pointerType === 'mouse') return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n return;\n }\n const pointerIndex = data.evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);\n if (pointerIndex >= 0) data.evCache[pointerIndex] = e;\n const targetTouch = data.evCache.length > 1 ? data.evCache[0] : e;\n const pageX = targetTouch.pageX;\n const pageY = targetTouch.pageY;\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n if (!swiper.allowTouchMove) {\n if (!e.target.matches(data.focusableElements)) {\n swiper.allowClick = false;\n }\n if (data.isTouched) {\n Object.assign(touches, {\n startX: pageX,\n startY: pageY,\n prevX: swiper.touches.currentX,\n prevY: swiper.touches.currentY,\n currentX: pageX,\n currentY: pageY\n });\n data.touchStartTime = now();\n }\n return;\n }\n if (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 if (document.activeElement) {\n if (e.target === document.activeElement && e.target.matches(data.focusableElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\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 if (typeof data.isScrolling === 'undefined') {\n let touchAngle;\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 if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n if (data.isScrolling || swiper.zoom && swiper.params.zoom && swiper.params.zoom.enabled && data.evCache.length > 1) {\n data.isTouched = false;\n return;\n }\n if (!data.startMoving) {\n return;\n }\n swiper.allowClick = false;\n if (!params.cssMode && e.cancelable) {\n e.preventDefault();\n }\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n let diff = swiper.isHorizontal() ? diffX : diffY;\n let touchesDiff = swiper.isHorizontal() ? touches.currentX - touches.previousX : touches.currentY - touches.previousY;\n if (params.oneWayMovement) {\n diff = Math.abs(diff) * (rtl ? 1 : -1);\n touchesDiff = Math.abs(touchesDiff) * (rtl ? 1 : -1);\n }\n touches.diff = diff;\n diff *= params.touchRatio;\n if (rtl) {\n diff = -diff;\n touchesDiff = -touchesDiff;\n }\n const prevTouchesDirection = swiper.touchesDirection;\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n swiper.touchesDirection = touchesDiff > 0 ? 'prev' : 'next';\n const isLoop = swiper.params.loop && !params.cssMode;\n if (!data.isMoved) {\n if (isLoop) {\n swiper.loopFix({\n direction: swiper.swipeDirection\n });\n }\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n if (swiper.animating) {\n const evt = new window.CustomEvent('transitionend', {\n bubbles: true,\n cancelable: true\n });\n swiper.wrapperEl.dispatchEvent(evt);\n }\n data.allowMomentumBounce = false;\n // Grab Cursor\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n swiper.emit('sliderFirstMove', e);\n }\n let loopFixed;\n if (data.isMoved && prevTouchesDirection !== swiper.touchesDirection && isLoop && Math.abs(diff) >= 1) {\n // need another loop fix\n swiper.loopFix({\n direction: swiper.swipeDirection,\n setTranslate: true\n });\n loopFixed = true;\n }\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n data.currentTranslate = diff + data.startTranslate;\n let disableParentSwiper = true;\n let resistanceRatio = params.resistanceRatio;\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n if (diff > 0) {\n if (isLoop && !loopFixed && data.currentTranslate > (params.centeredSlides ? swiper.minTranslate() - swiper.size / 2 : swiper.minTranslate())) {\n swiper.loopFix({\n direction: 'prev',\n setTranslate: true,\n activeSlideIndex: 0\n });\n }\n if (data.currentTranslate > swiper.minTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) {\n data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n }\n }\n } else if (diff < 0) {\n if (isLoop && !loopFixed && data.currentTranslate < (params.centeredSlides ? swiper.maxTranslate() + swiper.size / 2 : swiper.maxTranslate())) {\n swiper.loopFix({\n direction: 'next',\n setTranslate: true,\n activeSlideIndex: swiper.slides.length - (params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(parseFloat(params.slidesPerView, 10)))\n });\n }\n if (data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) {\n data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n }\n }\n }\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n }\n\n // Directions locks\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n data.currentTranslate = data.startTranslate;\n }\n\n // Threshold\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 if (!params.followFinger || params.cssMode) return;\n\n // Update active index in free mode\n if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n swiper.freeMode.onTouchMove();\n }\n // Update progress\n swiper.updateProgress(data.currentTranslate);\n // Update translate\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 pointerIndex = data.evCache.findIndex(cachedEv => cachedEv.pointerId === event.pointerId);\n if (pointerIndex >= 0) {\n data.evCache.splice(pointerIndex, 1);\n }\n if (['pointercancel', 'pointerout', 'pointerleave'].includes(event.type)) {\n const proceed = event.type === 'pointercancel' && (swiper.browser.isSafari || swiper.browser.isWebView);\n if (!proceed) {\n return;\n }\n }\n const {\n params,\n touches,\n rtlTranslate: rtl,\n slidesGrid,\n enabled\n } = swiper;\n if (!enabled) return;\n if (!params.simulateTouch && event.pointerType === 'mouse') return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n data.allowTouchCallbacks = false;\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n // Return Grab Cursor\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n }\n\n // Time diff\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime;\n\n // Tap, doubleTap, Click\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 if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n swiper.emit('doubleTap doubleClick', e);\n }\n }\n data.lastClickTime = now();\n nextTick(() => {\n if (!swiper.destroyed) swiper.allowClick = true;\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 data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n let currentPos;\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n if (params.cssMode) {\n return;\n }\n if (swiper.params.freeMode && params.freeMode.enabled) {\n swiper.freeMode.onTouchEnd({\n currentPos\n });\n return;\n }\n\n // Find current slide\n let stopIndex = 0;\n let groupSize = swiper.slidesSizesGrid[0];\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 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 let rewindFirstIndex = null;\n let rewindLastIndex = null;\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 }\n // Find current slide size\n const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\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 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 const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n if (!isNavButtonTarget) {\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);\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;\n\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Save locks\n const {\n allowSlideNext,\n allowSlidePrev,\n snapGrid\n } = swiper;\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n // Disable locks on resize\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateSlidesClasses();\n const isVirtualLoop = isVirtual && params.loop;\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides && !isVirtualLoop) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n if (swiper.params.loop && !isVirtual) {\n swiper.slideToLoop(swiper.realIndex, 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 clearTimeout(swiper.autoplay.resizeTimeout);\n swiper.autoplay.resizeTimeout = setTimeout(() => {\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.resume();\n }\n }, 500);\n }\n // Return locks after resize\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\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 if (!swiper.allowClick) {\n if (swiper.params.preventClicks) e.preventDefault();\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 if (swiper.isHorizontal()) {\n swiper.translate = -wrapperEl.scrollLeft;\n } else {\n swiper.translate = -wrapperEl.scrollTop;\n }\n // eslint-disable-next-line\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 if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n }\n if (newProgress !== swiper.progress) {\n swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n }\n swiper.emit('setTranslate', swiper.translate, false);\n}","import { processLazyPreloader } from '../../shared/process-lazy-preloader.js';\nexport default function onLoad(e) {\n const swiper = this;\n processLazyPreloader(swiper, e.target);\n swiper.update();\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';\nimport onLoad from './onLoad.js';\nlet dummyEventAttached = false;\nfunction dummyEventListener() {}\nconst events = (swiper, method) => {\n const document = getDocument();\n const {\n params,\n el,\n wrapperEl,\n device\n } = swiper;\n const capture = !!params.nested;\n const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n const swiperMethod = method;\n\n // Touch Events\n el[domMethod]('pointerdown', swiper.onTouchStart, {\n passive: false\n });\n document[domMethod]('pointermove', swiper.onTouchMove, {\n passive: false,\n capture\n });\n document[domMethod]('pointerup', swiper.onTouchEnd, {\n passive: true\n });\n document[domMethod]('pointercancel', swiper.onTouchEnd, {\n passive: true\n });\n document[domMethod]('pointerout', swiper.onTouchEnd, {\n passive: true\n });\n document[domMethod]('pointerleave', swiper.onTouchEnd, {\n passive: true\n });\n\n // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) {\n el[domMethod]('click', swiper.onClick, true);\n }\n if (params.cssMode) {\n wrapperEl[domMethod]('scroll', swiper.onScroll);\n }\n\n // Resize handler\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 // Images loader\n el[domMethod]('load', swiper.onLoad, {\n capture: true\n });\n};\nfunction attachEvents() {\n const swiper = this;\n const document = getDocument();\n const {\n params\n } = swiper;\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n if (params.cssMode) {\n swiper.onScroll = onScroll.bind(swiper);\n }\n swiper.onClick = onClick.bind(swiper);\n swiper.onLoad = onLoad.bind(swiper);\n if (!dummyEventAttached) {\n document.addEventListener('touchstart', dummyEventListener);\n dummyEventAttached = true;\n }\n events(swiper, 'on');\n}\nfunction detachEvents() {\n const swiper = this;\n events(swiper, 'off');\n}\nexport default {\n attachEvents,\n detachEvents\n};","import { extend } from '../../shared/utils.js';\nconst isGridEnabled = (swiper, params) => {\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\nexport default function setBreakpoint() {\n const swiper = this;\n const {\n realIndex,\n initialized,\n params,\n el\n } = swiper;\n const breakpoints = params.breakpoints;\n if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return;\n\n // Get breakpoint for window width and update parameters\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 if (wasMultiRow && !isMultiRow) {\n el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n } else if (!wasMultiRow && isMultiRow) {\n el.classList.add(`${params.containerModifierClass}grid`);\n if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n el.classList.add(`${params.containerModifierClass}grid-column`);\n }\n swiper.emitContainerClasses();\n }\n\n // Toggle navigation, pagination, scrollbar\n ['navigation', 'pagination', 'scrollbar'].forEach(prop => {\n const wasModuleEnabled = params[prop] && params[prop].enabled;\n const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;\n if (wasModuleEnabled && !isModuleEnabled) {\n swiper[prop].disable();\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 if (directionChanged && initialized) {\n swiper.changeDirection();\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 if (wasEnabled && !isEnabled) {\n swiper.disable();\n } else if (!wasEnabled && isEnabled) {\n swiper.enable();\n }\n swiper.currentBreakpoint = breakpoint;\n swiper.emit('_beforeBreakpoint', breakpointParams);\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate(realIndex);\n swiper.updateSlides();\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 return {\n value: point,\n point\n };\n });\n points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n for (let i = 0; i < points.length; i += 1) {\n const {\n point,\n value\n } = points[i];\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 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}\nexport default function addClasses() {\n const swiper = this;\n const {\n classNames,\n params,\n rtl,\n el,\n device\n } = swiper;\n // prettier-ignore\n const suffixes = prepareClasses(['initialized', params.direction, {\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.classList.add(...classNames);\n swiper.emitContainerClasses();\n}","export default function removeClasses() {\n const swiper = this;\n const {\n el,\n classNames\n } = swiper;\n el.classList.remove(...classNames);\n swiper.emitContainerClasses();\n}","import addClasses from './addClasses.js';\nimport removeClasses from './removeClasses.js';\nexport default {\n addClasses,\n removeClasses\n};","function checkOverflow() {\n const swiper = this;\n const {\n isLocked: wasLocked,\n params\n } = swiper;\n const {\n slidesOffsetBefore\n } = params;\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 if (params.allowSlideNext === true) {\n swiper.allowSlideNext = !swiper.isLocked;\n }\n if (params.allowSlidePrev === true) {\n swiper.allowSlidePrev = !swiper.isLocked;\n }\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n }\n if (wasLocked !== swiper.isLocked) {\n swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n }\n}\nexport default {\n checkOverflow\n};","export default {\n init: true,\n direction: 'horizontal',\n oneWayMovement: false,\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\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: 5,\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 // loop\n loop: false,\n loopedSlides: null,\n loopPreventsSliding: 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 slideActiveClass: 'swiper-slide-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideNextClass: 'swiper-slide-next',\n slidePrevClass: 'swiper-slide-prev',\n wrapperClass: 'swiper-wrapper',\n lazyPreloaderClass: 'swiper-lazy-preloader',\n lazyPreloadPrevNext: 0,\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 if (typeof moduleParams !== 'object' || moduleParams === null) {\n extend(allModulesParams, obj);\n return;\n }\n if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {\n params[moduleParamName] = {\n auto: true\n };\n }\n if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n extend(allModulesParams, obj);\n return;\n }\n if (params[moduleParamName] === true) {\n params[moduleParamName] = {\n enabled: true\n };\n }\n if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n params[moduleParamName].enabled = true;\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 { extend, deleteProps, createElement, elementChildren, elementStyle, elementIndex } 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 checkOverflow from './check-overflow/index.js';\nimport defaults from './defaults.js';\nimport moduleExtendParams from './moduleExtendParams.js';\nimport { processLazyPreloader, preload } from '../shared/process-lazy-preloader.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};\nconst extendedDefaults = {};\nclass Swiper {\n constructor(...args) {\n let el;\n let params;\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 if (!params) params = {};\n params = extend({}, params);\n if (el && !params.el) params.el = el;\n const document = getDocument();\n if (params.el && typeof params.el === 'string' && document.querySelectorAll(params.el).length > 1) {\n const swipers = [];\n document.querySelectorAll(params.el).forEach(containerEl => {\n const newParams = extend({}, params, {\n el: containerEl\n });\n swipers.push(new Swiper(newParams));\n });\n // eslint-disable-next-line no-constructor-return\n return swipers;\n }\n\n // Swiper Instance\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 if (params.modules && Array.isArray(params.modules)) {\n swiper.modules.push(...params.modules);\n }\n const allModulesParams = {};\n swiper.modules.forEach(mod => {\n mod({\n params,\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 });\n\n // Extend defaults with modules params\n const swiperParams = extend({}, defaults, allModulesParams);\n\n // Extend defaults with passed params\n swiper.params = extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = extend({}, swiper.params);\n swiper.passedParams = extend({}, params);\n\n // add event listeners\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 if (swiper.params && swiper.params.onAny) {\n swiper.onAny(swiper.params.onAny);\n }\n\n // Extend Swiper\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 // isDirection\n isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n isVertical() {\n return swiper.params.direction === 'vertical';\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 cssOverflowAdjustment() {\n // Returns 0 unless `translate` is > 2**23\n // Should be subtracted from css values to prevent overflow\n return Math.trunc(this.translate / 2 ** 23) * 2 ** 23;\n },\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n // Touch Events\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: 0,\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n startMoving: undefined,\n evCache: []\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');\n\n // Init\n if (swiper.params.init) {\n swiper.init();\n }\n\n // Return app instance\n // eslint-disable-next-line no-constructor-return\n return swiper;\n }\n getSlideIndex(slideEl) {\n const {\n slidesEl,\n params\n } = this;\n const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n const firstSlideIndex = elementIndex(slides[0]);\n return elementIndex(slideEl) - firstSlideIndex;\n }\n getSlideIndexByData(index) {\n return this.getSlideIndex(this.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === index)[0]);\n }\n recalcSlides() {\n const swiper = this;\n const {\n slidesEl,\n params\n } = swiper;\n swiper.slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n }\n enable() {\n const swiper = this;\n if (swiper.enabled) return;\n swiper.enabled = true;\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n swiper.emit('enable');\n }\n disable() {\n const swiper = this;\n if (!swiper.enabled) return;\n swiper.enabled = false;\n if (swiper.params.grabCursor) {\n swiper.unsetGrabCursor();\n }\n swiper.emit('disable');\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 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 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 emitSlidesClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const updates = [];\n swiper.slides.forEach(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 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 if (params.centeredSlides) {\n let slideSize = slides[activeIndex].swiperSlideSize;\n let breakLoop;\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 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 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 if (slideInView) {\n spv += 1;\n }\n }\n }\n }\n return spv;\n }\n update() {\n const swiper = this;\n if (!swiper || swiper.destroyed) return;\n const {\n snapGrid,\n params\n } = swiper;\n // Breakpoints\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n [...swiper.el.querySelectorAll('[loading=\"lazy\"]')].forEach(imageEl => {\n if (imageEl.complete) {\n processLazyPreloader(swiper, imageEl);\n }\n });\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\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 let translated;\n if (swiper.params.freeMode && swiper.params.freeMode.enabled) {\n setTranslate();\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 const slides = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides : swiper.slides;\n translated = swiper.slideTo(slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n if (!translated) {\n setTranslate();\n }\n }\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n swiper.emit('update');\n }\n changeDirection(newDirection, needUpdate = true) {\n const swiper = this;\n const currentDirection = swiper.params.direction;\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n return swiper;\n }\n swiper.el.classList.remove(`${swiper.params.containerModifierClass}${currentDirection}`);\n swiper.el.classList.add(`${swiper.params.containerModifierClass}${newDirection}`);\n swiper.emitContainerClasses();\n swiper.params.direction = newDirection;\n swiper.slides.forEach(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 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 if (swiper.rtl) {\n swiper.el.classList.add(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'rtl';\n } else {\n swiper.el.classList.remove(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'ltr';\n }\n swiper.update();\n }\n mount(element) {\n const swiper = this;\n if (swiper.mounted) return true;\n\n // Find el\n let el = element || swiper.params.el;\n if (typeof el === 'string') {\n el = document.querySelector(el);\n }\n if (!el) {\n return false;\n }\n el.swiper = swiper;\n if (el.shadowEl) {\n swiper.isElement = true;\n }\n const getWrapperSelector = () => {\n return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n };\n const getWrapper = () => {\n if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n const res = el.shadowRoot.querySelector(getWrapperSelector());\n // Children needs to return slot items\n return res;\n }\n return elementChildren(el, getWrapperSelector())[0];\n };\n // Find Wrapper\n let wrapperEl = getWrapper();\n if (!wrapperEl && swiper.params.createElements) {\n wrapperEl = createElement('div', swiper.params.wrapperClass);\n el.append(wrapperEl);\n elementChildren(el, `.${swiper.params.slideClass}`).forEach(slideEl => {\n wrapperEl.append(slideEl);\n });\n }\n Object.assign(swiper, {\n el,\n wrapperEl,\n slidesEl: swiper.isElement ? el : wrapperEl,\n mounted: true,\n // RTL\n rtl: el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl',\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl'),\n wrongRTL: elementStyle(wrapperEl, 'display') === '-webkit-box'\n });\n return true;\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');\n\n // Set breakpoint\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n // Add Classes\n swiper.addClasses();\n\n // Update size\n swiper.updateSize();\n\n // Update slides\n swiper.updateSlides();\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n }\n\n // Set Grab Cursor\n if (swiper.params.grabCursor && swiper.enabled) {\n swiper.setGrabCursor();\n }\n\n // Slide To Initial Slide\n if (swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {\n swiper.slideTo(swiper.params.initialSlide + swiper.virtual.slidesBefore, 0, swiper.params.runCallbacksOnInit, false, true);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n }\n\n // Create loop\n if (swiper.params.loop) {\n swiper.loopCreate();\n }\n\n // Attach events\n swiper.attachEvents();\n [...swiper.el.querySelectorAll('[loading=\"lazy\"]')].forEach(imageEl => {\n if (imageEl.complete) {\n processLazyPreloader(swiper, imageEl);\n } else {\n imageEl.addEventListener('load', e => {\n processLazyPreloader(swiper, e.target);\n });\n }\n });\n preload(swiper);\n\n // Init Flag\n swiper.initialized = true;\n preload(swiper);\n\n // Emit\n swiper.emit('init');\n swiper.emit('afterInit');\n return swiper;\n }\n destroy(deleteInstance = true, cleanStyles = true) {\n const swiper = this;\n const {\n params,\n el,\n wrapperEl,\n slides\n } = swiper;\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n swiper.emit('beforeDestroy');\n\n // Init Flag\n swiper.initialized = false;\n\n // Detach events\n swiper.detachEvents();\n\n // Destroy loop\n if (params.loop) {\n swiper.loopDestroy();\n }\n\n // Cleanup styles\n if (cleanStyles) {\n swiper.removeClasses();\n el.removeAttribute('style');\n wrapperEl.removeAttribute('style');\n if (slides && slides.length) {\n slides.forEach(slideEl => {\n slideEl.classList.remove(params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass);\n slideEl.removeAttribute('style');\n slideEl.removeAttribute('data-swiper-slide-index');\n });\n }\n }\n swiper.emit('destroy');\n\n // Detach emitter events\n Object.keys(swiper.eventsListeners).forEach(eventName => {\n swiper.off(eventName);\n });\n if (deleteInstance !== false) {\n swiper.el.swiper = null;\n deleteProps(swiper);\n }\n swiper.destroyed = true;\n return null;\n }\n static extendDefaults(newDefaults) {\n extend(extendedDefaults, newDefaults);\n }\n static get extendedDefaults() {\n return extendedDefaults;\n }\n static get defaults() {\n return defaults;\n }\n static installModule(mod) {\n if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n const modules = Swiper.prototype.__modules__;\n if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n modules.push(mod);\n }\n }\n static use(module) {\n if (Array.isArray(module)) {\n module.forEach(m => Swiper.installModule(m));\n return Swiper;\n }\n Swiper.installModule(module);\n return Swiper;\n }\n}\nObject.keys(prototypes).forEach(prototypeGroup => {\n Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n });\n});\nSwiper.use([Resize, Observer]);\nexport default Swiper;","import { getDocument } from 'ssr-window';\nimport { createElement, elementChildren, 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 const document = getDocument();\n swiper.virtual = {\n cache: {},\n from: undefined,\n to: undefined,\n slides: [],\n offset: 0,\n slidesGrid: []\n };\n const tempDOM = document.createElement('div');\n function renderSlide(slide, index) {\n const params = swiper.params.virtual;\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n // eslint-disable-next-line\n let slideEl;\n if (params.renderSlide) {\n slideEl = params.renderSlide.call(swiper, slide, index);\n if (typeof slideEl === 'string') {\n tempDOM.innerHTML = slideEl;\n slideEl = tempDOM.children[0];\n }\n } else if (swiper.isElement) {\n slideEl = createElement('swiper-slide');\n } else {\n slideEl = createElement('div', swiper.params.slideClass);\n }\n slideEl.setAttribute('data-swiper-slide-index', index);\n if (!params.renderSlide) {\n slideEl.innerHTML = slide;\n }\n if (params.cache) swiper.virtual.cache[index] = slideEl;\n return slideEl;\n }\n function update(force) {\n const {\n slidesPerView,\n slidesPerGroup,\n centeredSlides,\n loop: isLoop\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 if (!swiper.params.cssMode) {\n swiper.updateActiveIndex();\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 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 = (isLoop ? slidesPerView : slidesPerGroup) + addSlidesBefore;\n }\n let from = activeIndex - slidesBefore;\n let to = activeIndex + slidesAfter;\n if (!isLoop) {\n from = Math.max(from, 0);\n to = Math.min(to, slides.length - 1);\n }\n let offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n if (isLoop && activeIndex >= slidesBefore) {\n from -= slidesBefore;\n if (!centeredSlides) offset += swiper.slidesGrid[0];\n } else if (isLoop && activeIndex < slidesBefore) {\n from = -slidesBefore;\n if (centeredSlides) offset += swiper.slidesGrid[0];\n }\n Object.assign(swiper.virtual, {\n from,\n to,\n offset,\n slidesGrid: swiper.slidesGrid,\n slidesBefore,\n slidesAfter\n });\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n emit('virtualUpdate');\n }\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.forEach(slideEl => {\n slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;\n });\n }\n swiper.updateProgress();\n emit('virtualUpdate');\n return;\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 for (let i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n return slidesToRender;\n }()\n });\n if (swiper.params.virtual.renderExternalUpdate) {\n onRendered();\n } else {\n emit('virtualUpdate');\n }\n return;\n }\n const prependIndexes = [];\n const appendIndexes = [];\n const getSlideIndex = index => {\n let slideIndex = index;\n if (index < 0) {\n slideIndex = slides.length + index;\n } else if (slideIndex >= slides.length) {\n // eslint-disable-next-line\n slideIndex = slideIndex - slides.length;\n }\n return slideIndex;\n };\n if (force) {\n swiper.slidesEl.querySelectorAll(`.${swiper.params.slideClass}, swiper-slide`).forEach(slideEl => {\n slideEl.remove();\n });\n } else {\n for (let i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n const slideIndex = getSlideIndex(i);\n swiper.slidesEl.querySelectorAll(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${slideIndex}\"], swiper-slide[data-swiper-slide-index=\"${slideIndex}\"]`).forEach(slideEl => {\n slideEl.remove();\n });\n }\n }\n }\n const loopFrom = isLoop ? -slides.length : 0;\n const loopTo = isLoop ? slides.length * 2 : slides.length;\n for (let i = loopFrom; i < loopTo; i += 1) {\n if (i >= from && i <= to) {\n const slideIndex = getSlideIndex(i);\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(slideIndex);\n } else {\n if (i > previousTo) appendIndexes.push(slideIndex);\n if (i < previousFrom) prependIndexes.push(slideIndex);\n }\n }\n }\n appendIndexes.forEach(index => {\n swiper.slidesEl.append(renderSlide(slides[index], index));\n });\n if (isLoop) {\n for (let i = prependIndexes.length - 1; i >= 0; i -= 1) {\n const index = prependIndexes[i];\n swiper.slidesEl.prepend(renderSlide(slides[index], index));\n }\n } else {\n prependIndexes.sort((a, b) => b - a);\n prependIndexes.forEach(index => {\n swiper.slidesEl.prepend(renderSlide(slides[index], index));\n });\n }\n elementChildren(swiper.slidesEl, '.swiper-slide, swiper-slide').forEach(slideEl => {\n slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;\n });\n onRendered();\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 update(true);\n }\n function prependSlide(slides) {\n const activeIndex = swiper.activeIndex;\n let newActiveIndex = activeIndex + 1;\n let numberOfNewSlides = 1;\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 newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\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.getAttribute('data-swiper-slide-index');\n if (cachedElIndex) {\n cachedEl.setAttribute('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);\n }\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = cachedEl;\n });\n swiper.virtual.cache = newCache;\n }\n update(true);\n swiper.slideTo(newActiveIndex, 0);\n }\n function removeSlide(slidesIndexes) {\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;\n let activeIndex = swiper.activeIndex;\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 if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\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 if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n if (slidesIndexes < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n update(true);\n swiper.slideTo(activeIndex, 0);\n }\n function removeAllSlides() {\n swiper.virtual.slides = [];\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n update(true);\n swiper.slideTo(0, 0);\n }\n on('beforeInit', () => {\n if (!swiper.params.virtual.enabled) return;\n let domSlidesAssigned;\n if (typeof swiper.passedParams.virtual.slides === 'undefined') {\n const slides = [...swiper.slidesEl.children].filter(el => el.matches(`.${swiper.params.slideClass}, swiper-slide`));\n if (slides && slides.length) {\n swiper.virtual.slides = [...slides];\n domSlidesAssigned = true;\n slides.forEach((slideEl, slideIndex) => {\n slideEl.setAttribute('data-swiper-slide-index', slideIndex);\n swiper.virtual.cache[slideIndex] = slideEl;\n slideEl.remove();\n });\n }\n }\n if (!domSlidesAssigned) {\n swiper.virtual.slides = swiper.params.virtual.slides;\n }\n swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n if (!swiper.params.initialSlide) {\n update();\n }\n });\n on('setTranslate', () => {\n if (!swiper.params.virtual.enabled) return;\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 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 { elementOffset, elementParents } from '../../shared/utils.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 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 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;\n // Directions locks\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false;\n // Check that swiper should be inside of visible area of window\n if (elementParents(swiper.el, `.${swiper.params.slideClass}, swiper-slide`).length > 0 && elementParents(swiper.el, `.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n const el = swiper.el;\n const swiperWidth = el.clientWidth;\n const swiperHeight = el.clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = elementOffset(el);\n if (rtl) swiperOffset.left -= el.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 for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\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 inView = true;\n }\n }\n if (!inView) return undefined;\n }\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\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 if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n emit('keyPress', kc);\n return undefined;\n }\n function enable() {\n if (swiper.keyboard.enabled) return;\n document.addEventListener('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n function disable() {\n if (!swiper.keyboard.enabled) return;\n document.removeEventListener('keydown', handle);\n swiper.keyboard.enabled = false;\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 { 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 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 let pX = 0;\n let pY = 0; // pixelX, pixelY\n\n // Legacy\n if ('detail' in e) {\n sY = e.detail;\n }\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n }\n\n // side scrolling on FF with DOMMouseScroll\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n if (e.shiftKey && !pX) {\n // if user scrolls with shift he wants horizontal scroll\n pX = pY;\n pY = 0;\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 }\n\n // Fall-back if spin cannot be determined\n if (pX && !sX) {\n sX = pX < 1 ? -1 : 1;\n }\n if (pY && !sY) {\n sY = pY < 1 ? -1 : 1;\n }\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY\n };\n }\n function handleMouseEnter() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = true;\n }\n function handleMouseLeave() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = false;\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 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 }\n\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 if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {\n // Return false as a default\n return true;\n }\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 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 }\n // If you got here is because an animation has been triggered so store the current time\n lastScrollTime = new window.Date().getTime();\n // Return false as a default\n return false;\n }\n function releaseScroll(newEvent) {\n const params = swiper.params.mousewheel;\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 return false;\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 if (swiper.params.cssMode) {\n e.preventDefault();\n }\n let targetEl = swiper.el;\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);\n }\n const targetElContainsTarget = targetEl && targetEl.contains(e.target);\n if (!swiper.mouseEntered && !targetElContainsTarget && !params.releaseOnEdges) return true;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n let delta = 0;\n const rtlFactor = swiper.rtlTranslate ? -1 : 1;\n const data = normalize(e);\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 if (delta === 0) return true;\n if (params.invert) delta = -delta;\n\n // Get the scroll positions\n let positions = swiper.getTranslate() + delta * params.sensitivity;\n if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();\n if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate();\n\n // 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 disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());\n if (disableParentSwiper && swiper.params.nested) e.stopPropagation();\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 };\n\n // Keep the most recent events\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);\n\n // 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 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 }\n\n // If it's time to release the scroll:\n // Return now so you don't hit the preventDefault.\n if (releaseScroll(newEvent)) {\n return true;\n }\n } else {\n // Freemode or scrollContainer:\n\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 if (!ignoreWheelEvents) {\n lastEventBeforeSnap = undefined;\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 if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {\n swiper.updateSlidesClasses();\n }\n if (swiper.params.loop) {\n swiper.loopFix({\n direction: newEvent.direction < 0 ? 'next' : 'prev',\n byMousewheel: true\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 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 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 }\n\n // Emit event\n if (!ignoreWheelEvents) emit('scroll', e);\n\n // Stop autoplay\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop();\n // Return page scroll on edge positions\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;\n }\n }\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n return false;\n }\n function events(method) {\n let targetEl = swiper.el;\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);\n }\n targetEl[method]('mouseenter', handleMouseEnter);\n targetEl[method]('mouseleave', handleMouseLeave);\n targetEl[method]('wheel', handle);\n }\n function enable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.removeEventListener('wheel', handle);\n return true;\n }\n if (swiper.mousewheel.enabled) return false;\n events('addEventListener');\n swiper.mousewheel.enabled = true;\n return true;\n }\n function disable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.addEventListener(event, handle);\n return true;\n }\n if (!swiper.mousewheel.enabled) return false;\n events('removeEventListener');\n swiper.mousewheel.enabled = false;\n return true;\n }\n on('init', () => {\n if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {\n disable();\n }\n if (swiper.params.mousewheel.enabled) enable();\n });\n on('destroy', () => {\n if (swiper.params.cssMode) {\n enable();\n }\n if (swiper.mousewheel.enabled) disable();\n });\n Object.assign(swiper.mousewheel, {\n enable,\n disable\n });\n}","import { createElement, elementChildren } from './utils.js';\nexport default function createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n if (swiper.params.createElements) {\n Object.keys(checkProps).forEach(key => {\n if (!params[key] && params.auto === true) {\n let element = elementChildren(swiper.el, `.${checkProps[key]}`)[0];\n if (!element) {\n element = createElement('div', checkProps[key]);\n element.className = checkProps[key];\n swiper.el.append(element);\n }\n params[key] = element;\n originalParams[key] = element;\n }\n });\n }\n return params;\n}","import createElementIfNotDefined from '../../shared/create-element-if-not-defined.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 prevEl: null\n };\n const makeElementsArray = el => {\n if (!Array.isArray(el)) el = [el].filter(e => !!e);\n return el;\n };\n function getEl(el) {\n let res;\n if (el && typeof el === 'string' && swiper.isElement) {\n res = swiper.el.shadowRoot.querySelector(el);\n if (res) return res;\n }\n if (el) {\n if (typeof el === 'string') res = [...document.querySelectorAll(el)];\n if (swiper.params.uniqueNavElements && typeof el === 'string' && res.length > 1 && swiper.el.querySelectorAll(el).length === 1) {\n res = swiper.el.querySelector(el);\n }\n }\n if (el && !res) return el;\n // if (Array.isArray(res) && res.length === 1) res = res[0];\n return res;\n }\n function toggleEl(el, disabled) {\n const params = swiper.params.navigation;\n el = makeElementsArray(el);\n el.forEach(subEl => {\n if (subEl) {\n subEl.classList[disabled ? 'add' : 'remove'](...params.disabledClass.split(' '));\n if (subEl.tagName === 'BUTTON') subEl.disabled = disabled;\n if (swiper.params.watchOverflow && swiper.enabled) {\n subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);\n }\n }\n });\n }\n function update() {\n // Update Navigation Buttons\n const {\n nextEl,\n prevEl\n } = swiper.navigation;\n if (swiper.params.loop) {\n toggleEl(prevEl, false);\n toggleEl(nextEl, false);\n return;\n }\n toggleEl(prevEl, swiper.isBeginning && !swiper.params.rewind);\n toggleEl(nextEl, swiper.isEnd && !swiper.params.rewind);\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 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 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 let nextEl = getEl(params.nextEl);\n let prevEl = getEl(params.prevEl);\n Object.assign(swiper.navigation, {\n nextEl,\n prevEl\n });\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n const initButton = (el, dir) => {\n if (el) {\n el.addEventListener('click', dir === 'next' ? onNextClick : onPrevClick);\n }\n if (!swiper.enabled && el) {\n el.classList.add(...params.lockClass.split(' '));\n }\n };\n nextEl.forEach(el => initButton(el, 'next'));\n prevEl.forEach(el => initButton(el, 'prev'));\n }\n function destroy() {\n let {\n nextEl,\n prevEl\n } = swiper.navigation;\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n const destroyButton = (el, dir) => {\n el.removeEventListener('click', dir === 'next' ? onNextClick : onPrevClick);\n el.classList.remove(...swiper.params.navigation.disabledClass.split(' '));\n };\n nextEl.forEach(el => destroyButton(el, 'next'));\n prevEl.forEach(el => destroyButton(el, 'prev'));\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 let {\n nextEl,\n prevEl\n } = swiper.navigation;\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.navigation.lockClass));\n });\n on('click', (_s, e) => {\n let {\n nextEl,\n prevEl\n } = swiper.navigation;\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n const targetEl = e.target;\n if (swiper.params.navigation.hideOnClick && !prevEl.includes(targetEl) && !nextEl.includes(targetEl)) {\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 if (nextEl.length) {\n isHidden = nextEl[0].classList.contains(swiper.params.navigation.hiddenClass);\n } else if (prevEl.length) {\n isHidden = prevEl[0].classList.contains(swiper.params.navigation.hiddenClass);\n }\n if (isHidden === true) {\n emit('navigationShow');\n } else {\n emit('navigationHide');\n }\n [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.toggle(swiper.params.navigation.hiddenClass));\n }\n });\n const enable = () => {\n swiper.el.classList.remove(...swiper.params.navigation.navigationDisabledClass.split(' '));\n init();\n update();\n };\n const disable = () => {\n swiper.el.classList.add(...swiper.params.navigation.navigationDisabledClass.split(' '));\n destroy();\n };\n Object.assign(swiper.navigation, {\n enable,\n disable,\n update,\n init,\n destroy\n });\n}","import classesToSelector from '../../shared/classes-to-selector.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nimport { elementIndex, elementOuterSize, elementParents } from '../../shared/utils.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 bullets: []\n };\n let bulletSize;\n let dynamicBulletIndex = 0;\n const makeElementsArray = el => {\n if (!Array.isArray(el)) el = [el].filter(e => !!e);\n return el;\n };\n function isPaginationDisabled() {\n return !swiper.params.pagination.el || !swiper.pagination.el || Array.isArray(swiper.pagination.el) && swiper.pagination.el.length === 0;\n }\n function setSideBullets(bulletEl, position) {\n const {\n bulletActiveClass\n } = swiper.params.pagination;\n if (!bulletEl) return;\n bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];\n if (bulletEl) {\n bulletEl.classList.add(`${bulletActiveClass}-${position}`);\n bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];\n if (bulletEl) {\n bulletEl.classList.add(`${bulletActiveClass}-${position}-${position}`);\n }\n }\n }\n function onBulletClick(e) {\n const bulletEl = e.target.closest(classesToSelector(swiper.params.pagination.bulletClass));\n if (!bulletEl) {\n return;\n }\n e.preventDefault();\n const index = elementIndex(bulletEl) * swiper.params.slidesPerGroup;\n if (swiper.params.loop) {\n if (swiper.realIndex === index) return;\n const newSlideIndex = swiper.getSlideIndexByData(index);\n const currentSlideIndex = swiper.getSlideIndexByData(swiper.realIndex);\n if (newSlideIndex > swiper.slides.length - swiper.loopedSlides) {\n swiper.loopFix({\n direction: newSlideIndex > currentSlideIndex ? 'next' : 'prev',\n activeSlideIndex: newSlideIndex,\n slideTo: false\n });\n }\n swiper.slideToLoop(index);\n } else {\n swiper.slideTo(index);\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 let el = swiper.pagination.el;\n el = makeElementsArray(el);\n // Current/Total\n let current;\n let previousIndex;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const total = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.loop) {\n previousIndex = swiper.previousRealIndex || 0;\n current = swiper.params.slidesPerGroup > 1 ? Math.floor(swiper.realIndex / swiper.params.slidesPerGroup) : swiper.realIndex;\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n previousIndex = swiper.previousSnapIndex;\n } else {\n previousIndex = swiper.previousIndex || 0;\n current = swiper.activeIndex || 0;\n }\n // Types\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 if (params.dynamicBullets) {\n bulletSize = elementOuterSize(bullets[0], swiper.isHorizontal() ? 'width' : 'height', true);\n el.forEach(subEl => {\n subEl.style[swiper.isHorizontal() ? 'width' : 'height'] = `${bulletSize * (params.dynamicMainBullets + 4)}px`;\n });\n if (params.dynamicMainBullets > 1 && previousIndex !== undefined) {\n dynamicBulletIndex += current - (previousIndex || 0);\n if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (dynamicBulletIndex < 0) {\n dynamicBulletIndex = 0;\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 bullets.forEach(bulletEl => {\n const classesToRemove = [...['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`)].map(s => typeof s === 'string' && s.includes(' ') ? s.split(' ') : s).flat();\n bulletEl.classList.remove(...classesToRemove);\n });\n if (el.length > 1) {\n bullets.forEach(bullet => {\n const bulletIndex = elementIndex(bullet);\n if (bulletIndex === current) {\n bullet.classList.add(...params.bulletActiveClass.split(' '));\n }\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n bullet.classList.add(...`${params.bulletActiveClass}-main`.split(' '));\n }\n if (bulletIndex === firstIndex) {\n setSideBullets(bullet, 'prev');\n }\n if (bulletIndex === lastIndex) {\n setSideBullets(bullet, 'next');\n }\n }\n });\n } else {\n const bullet = bullets[current];\n if (bullet) {\n bullet.classList.add(...params.bulletActiveClass.split(' '));\n }\n if (params.dynamicBullets) {\n const firstDisplayedBullet = bullets[firstIndex];\n const lastDisplayedBullet = bullets[lastIndex];\n for (let i = firstIndex; i <= lastIndex; i += 1) {\n if (bullets[i]) {\n bullets[i].classList.add(...`${params.bulletActiveClass}-main`.split(' '));\n }\n }\n setSideBullets(firstDisplayedBullet, 'prev');\n setSideBullets(lastDisplayedBullet, 'next');\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.forEach(bullet => {\n bullet.style[swiper.isHorizontal() ? offsetProp : 'top'] = `${bulletsOffset}px`;\n });\n }\n }\n el.forEach((subEl, subElIndex) => {\n if (params.type === 'fraction') {\n subEl.querySelectorAll(classesToSelector(params.currentClass)).forEach(fractionEl => {\n fractionEl.textContent = params.formatFractionCurrent(current + 1);\n });\n subEl.querySelectorAll(classesToSelector(params.totalClass)).forEach(totalEl => {\n totalEl.textContent = params.formatFractionTotal(total);\n });\n }\n if (params.type === 'progressbar') {\n let progressbarDirection;\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n const scale = (current + 1) / total;\n let scaleX = 1;\n let scaleY = 1;\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n subEl.querySelectorAll(classesToSelector(params.progressbarFillClass)).forEach(progressEl => {\n progressEl.style.transform = `translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`;\n progressEl.style.transitionDuration = `${swiper.params.speed}ms`;\n });\n }\n if (params.type === 'custom' && params.renderCustom) {\n subEl.innerHTML = params.renderCustom(swiper, current + 1, total);\n if (subElIndex === 0) emit('paginationRender', subEl);\n } else {\n if (subElIndex === 0) emit('paginationRender', subEl);\n emit('paginationUpdate', subEl);\n }\n if (swiper.params.watchOverflow && swiper.enabled) {\n subEl.classList[swiper.isLocked ? 'add' : 'remove'](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 let el = swiper.pagination.el;\n el = makeElementsArray(el);\n let paginationHTML = '';\n if (params.type === 'bullets') {\n let numberOfBullets = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && numberOfBullets > slidesLength) {\n numberOfBullets = slidesLength;\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 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 if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = ``;\n }\n }\n swiper.pagination.bullets = [];\n el.forEach(subEl => {\n if (params.type !== 'custom') {\n subEl.innerHTML = paginationHTML || '';\n }\n if (params.type === 'bullets') {\n swiper.pagination.bullets.push(...subEl.querySelectorAll(classesToSelector(params.bulletClass)));\n }\n });\n if (params.type !== 'custom') {\n emit('paginationRender', el[0]);\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;\n if (typeof params.el === 'string' && swiper.isElement) {\n el = swiper.el.shadowRoot.querySelector(params.el);\n }\n if (!el && typeof params.el === 'string') {\n el = [...document.querySelectorAll(params.el)];\n }\n if (!el) {\n el = params.el;\n }\n if (!el || el.length === 0) return;\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && Array.isArray(el) && el.length > 1) {\n el = [...swiper.el.querySelectorAll(params.el)];\n // check if it belongs to another nested Swiper\n if (el.length > 1) {\n el = el.filter(subEl => {\n if (elementParents(subEl, '.swiper')[0] !== swiper.el) return false;\n return true;\n })[0];\n }\n }\n if (Array.isArray(el) && el.length === 1) el = el[0];\n Object.assign(swiper.pagination, {\n el\n });\n el = makeElementsArray(el);\n el.forEach(subEl => {\n if (params.type === 'bullets' && params.clickable) {\n subEl.classList.add(params.clickableClass);\n }\n subEl.classList.add(params.modifierClass + params.type);\n subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n if (params.type === 'bullets' && params.dynamicBullets) {\n subEl.classList.add(`${params.modifierClass}${params.type}-dynamic`);\n dynamicBulletIndex = 0;\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n subEl.classList.add(params.progressbarOppositeClass);\n }\n if (params.clickable) {\n subEl.addEventListener('click', onBulletClick);\n }\n if (!swiper.enabled) {\n subEl.classList.add(params.lockClass);\n }\n });\n }\n function destroy() {\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n let el = swiper.pagination.el;\n if (el) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.classList.remove(params.hiddenClass);\n subEl.classList.remove(params.modifierClass + params.type);\n subEl.classList.remove(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n if (params.clickable) {\n subEl.removeEventListener('click', onBulletClick);\n }\n });\n }\n if (swiper.pagination.bullets) swiper.pagination.bullets.forEach(subEl => subEl.classList.remove(...params.bulletActiveClass.split(' ')));\n }\n on('changeDirection', () => {\n if (!swiper.pagination || !swiper.pagination.el) return;\n const params = swiper.params.pagination;\n let {\n el\n } = swiper.pagination;\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.classList.remove(params.horizontalClass, params.verticalClass);\n subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\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 (typeof swiper.snapIndex === 'undefined') {\n update();\n }\n });\n on('snapIndexChange', () => {\n update();\n });\n on('snapGridLengthChange', () => {\n render();\n update();\n });\n on('destroy', () => {\n destroy();\n });\n on('enable disable', () => {\n let {\n el\n } = swiper.pagination;\n if (el) {\n el = makeElementsArray(el);\n el.forEach(subEl => subEl.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.pagination.lockClass));\n }\n });\n on('lock unlock', () => {\n update();\n });\n on('click', (_s, e) => {\n const targetEl = e.target;\n let {\n el\n } = swiper.pagination;\n if (!Array.isArray(el)) el = [el].filter(element => !!element);\n if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && el && el.length > 0 && !targetEl.classList.contains(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[0].classList.contains(swiper.params.pagination.hiddenClass);\n if (isHidden === true) {\n emit('paginationShow');\n } else {\n emit('paginationHide');\n }\n el.forEach(subEl => subEl.classList.toggle(swiper.params.pagination.hiddenClass));\n }\n });\n const enable = () => {\n swiper.el.classList.remove(swiper.params.pagination.paginationDisabledClass);\n let {\n el\n } = swiper.pagination;\n if (el) {\n el = makeElementsArray(el);\n el.forEach(subEl => subEl.classList.remove(swiper.params.pagination.paginationDisabledClass));\n }\n init();\n render();\n update();\n };\n const disable = () => {\n swiper.el.classList.add(swiper.params.pagination.paginationDisabledClass);\n let {\n el\n } = swiper.pagination;\n if (el) {\n el = makeElementsArray(el);\n el.forEach(subEl => subEl.classList.add(swiper.params.pagination.paginationDisabledClass));\n }\n destroy();\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 { createElement, elementOffset, 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 };\n function setTranslate() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar,\n rtlTranslate: rtl\n } = swiper;\n const {\n dragEl,\n el\n } = scrollbar;\n const params = swiper.params.scrollbar;\n const progress = swiper.params.loop ? swiper.progressLoop : swiper.progress;\n let newSize = dragSize;\n let newPos = (trackSize - dragSize) * progress;\n if (rtl) {\n newPos = -newPos;\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 if (swiper.isHorizontal()) {\n dragEl.style.transform = `translate3d(${newPos}px, 0, 0)`;\n dragEl.style.width = `${newSize}px`;\n } else {\n dragEl.style.transform = `translate3d(0px, ${newPos}px, 0)`;\n dragEl.style.height = `${newSize}px`;\n }\n if (params.hide) {\n clearTimeout(timeout);\n el.style.opacity = 1;\n timeout = setTimeout(() => {\n el.style.opacity = 0;\n el.style.transitionDuration = '400ms';\n }, 1000);\n }\n }\n function setTransition(duration) {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n swiper.scrollbar.dragEl.style.transitionDuration = `${duration}ms`;\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.style.width = '';\n dragEl.style.height = '';\n trackSize = swiper.isHorizontal() ? el.offsetWidth : el.offsetHeight;\n divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n if (swiper.isHorizontal()) {\n dragEl.style.width = `${dragSize}px`;\n } else {\n dragEl.style.height = `${dragSize}px`;\n }\n if (divider >= 1) {\n el.style.display = 'none';\n } else {\n el.style.display = '';\n }\n if (swiper.params.scrollbar.hide) {\n el.style.opacity = 0;\n }\n if (swiper.params.watchOverflow && swiper.enabled) {\n scrollbar.el.classList[swiper.isLocked ? 'add' : 'remove'](swiper.params.scrollbar.lockClass);\n }\n }\n function getPointerPosition(e) {\n return swiper.isHorizontal() ? e.clientX : e.clientY;\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) - elementOffset(el)[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n if (rtl) {\n positionRatio = 1 - positionRatio;\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 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 ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n wrapperEl.style.transitionDuration = '100ms';\n dragEl.style.transitionDuration = '100ms';\n setDragPosition(e);\n clearTimeout(dragTimeout);\n el.style.transitionDuration = '0ms';\n if (params.hide) {\n el.style.opacity = 1;\n }\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style['scroll-snap-type'] = 'none';\n }\n emit('scrollbarDragStart', e);\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.style.transitionDuration = '0ms';\n el.style.transitionDuration = '0ms';\n dragEl.style.transitionDuration = '0ms';\n emit('scrollbarDragMove', e);\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 if (swiper.params.cssMode) {\n swiper.wrapperEl.style['scroll-snap-type'] = '';\n wrapperEl.style.transitionDuration = '';\n }\n if (params.hide) {\n clearTimeout(dragTimeout);\n dragTimeout = nextTick(() => {\n el.style.opacity = 0;\n el.style.transitionDuration = '400ms';\n }, 1000);\n }\n emit('scrollbarDragEnd', e);\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n }\n function events(method) {\n const {\n scrollbar,\n params\n } = swiper;\n const el = scrollbar.el;\n if (!el) return;\n const target = el;\n const activeListener = params.passiveListeners ? {\n passive: false,\n capture: false\n } : false;\n const passiveListener = params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (!target) return;\n const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n target[eventMethod]('pointerdown', onDragStart, activeListener);\n document[eventMethod]('pointermove', onDragMove, activeListener);\n document[eventMethod]('pointerup', onDragEnd, passiveListener);\n }\n function enableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('on');\n }\n function disableDraggable() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n events('off');\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;\n if (typeof params.el === 'string' && swiper.isElement) {\n el = swiper.el.shadowRoot.querySelector(params.el);\n }\n if (!el && typeof params.el === 'string') {\n el = document.querySelectorAll(params.el);\n } else if (!el) {\n el = params.el;\n }\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && el.length > 1 && swiperEl.querySelectorAll(params.el).length === 1) {\n el = swiperEl.querySelector(params.el);\n }\n if (el.length > 0) el = el[0];\n el.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n let dragEl;\n if (el) {\n dragEl = el.querySelector(`.${swiper.params.scrollbar.dragClass}`);\n if (!dragEl) {\n dragEl = createElement('div', swiper.params.scrollbar.dragClass);\n el.append(dragEl);\n }\n }\n Object.assign(scrollbar, {\n el,\n dragEl\n });\n if (params.draggable) {\n enableDraggable();\n }\n if (el) {\n el.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.scrollbar.lockClass);\n }\n }\n function destroy() {\n const params = swiper.params.scrollbar;\n const el = swiper.scrollbar.el;\n if (el) {\n el.classList.remove(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n }\n disableDraggable();\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 if (el) {\n el.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.scrollbar.lockClass);\n }\n });\n on('destroy', () => {\n destroy();\n });\n const enable = () => {\n swiper.el.classList.remove(swiper.params.scrollbar.scrollbarDisabledClass);\n if (swiper.scrollbar.el) {\n swiper.scrollbar.el.classList.remove(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n init();\n updateSize();\n setTranslate();\n };\n const disable = () => {\n swiper.el.classList.add(swiper.params.scrollbar.scrollbarDisabledClass);\n if (swiper.scrollbar.el) {\n swiper.scrollbar.el.classList.add(swiper.params.scrollbar.scrollbarDisabledClass);\n }\n destroy();\n };\n Object.assign(swiper.scrollbar, {\n enable,\n disable,\n updateSize,\n setTranslate,\n init,\n destroy\n });\n}","import { elementChildren } from '../../shared/utils.js';\nexport default function Parallax({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n parallax: {\n enabled: false\n }\n });\n const setTransform = (el, progress) => {\n const {\n rtl\n } = swiper;\n const rtlFactor = rtl ? -1 : 1;\n const p = el.getAttribute('data-swiper-parallax') || '0';\n let x = el.getAttribute('data-swiper-parallax-x');\n let y = el.getAttribute('data-swiper-parallax-y');\n const scale = el.getAttribute('data-swiper-parallax-scale');\n const opacity = el.getAttribute('data-swiper-parallax-opacity');\n const rotate = el.getAttribute('data-swiper-parallax-rotate');\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 if (x.indexOf('%') >= 0) {\n x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n } else {\n x = `${x * progress * rtlFactor}px`;\n }\n if (y.indexOf('%') >= 0) {\n y = `${parseInt(y, 10) * progress}%`;\n } else {\n y = `${y * progress}px`;\n }\n if (typeof opacity !== 'undefined' && opacity !== null) {\n const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n el.style.opacity = currentOpacity;\n }\n let transform = `translate3d(${x}, ${y}, 0px)`;\n if (typeof scale !== 'undefined' && scale !== null) {\n const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n transform += ` scale(${currentScale})`;\n }\n if (rotate && typeof rotate !== 'undefined' && rotate !== null) {\n const currentRotate = rotate * progress * -1;\n transform += ` rotate(${currentRotate}deg)`;\n }\n el.style.transform = transform;\n };\n const setTranslate = () => {\n const {\n el,\n slides,\n progress,\n snapGrid\n } = swiper;\n elementChildren(el, '[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').forEach(subEl => {\n setTransform(subEl, progress);\n });\n slides.forEach((slideEl, slideIndex) => {\n let slideProgress = slideEl.progress;\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n }\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n slideEl.querySelectorAll('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale], [data-swiper-parallax-rotate]').forEach(subEl => {\n setTransform(subEl, slideProgress);\n });\n });\n };\n const setTransition = (duration = swiper.params.speed) => {\n const {\n el\n } = swiper;\n el.querySelectorAll('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').forEach(parallaxEl => {\n let parallaxDuration = parseInt(parallaxEl.getAttribute('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) parallaxDuration = 0;\n parallaxEl.style.transitionDuration = `${parallaxDuration}ms`;\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 { elementChildren, elementOffset, elementParents, 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 fakeGestureTouched;\n let fakeGestureMoved;\n const evCache = [];\n const gesture = {\n originX: 0,\n originY: 0,\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 set(value) {\n if (scale !== value) {\n const imageEl = gesture.imageEl;\n const slideEl = gesture.slideEl;\n emit('zoomChange', value, imageEl, slideEl);\n }\n scale = value;\n }\n });\n function getDistanceBetweenTouches() {\n if (evCache.length < 2) return 1;\n const x1 = evCache[0].pageX;\n const y1 = evCache[0].pageY;\n const x2 = evCache[1].pageX;\n const y2 = evCache[1].pageY;\n const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n return distance;\n }\n function getScaleOrigin() {\n if (evCache.length < 2) return {\n x: null,\n y: null\n };\n const box = gesture.imageEl.getBoundingClientRect();\n return [(evCache[0].pageX + (evCache[1].pageX - evCache[0].pageX) / 2 - box.x) / currentScale, (evCache[0].pageY + (evCache[1].pageY - evCache[0].pageY) / 2 - box.y) / currentScale];\n }\n function getSlideSelector() {\n return swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;\n }\n function eventWithinSlide(e) {\n const slideSelector = getSlideSelector();\n if (e.target.matches(slideSelector)) return true;\n if (swiper.slides.filter(slideEl => slideEl.contains(e.target)).length > 0) return true;\n return false;\n }\n function eventWithinZoomContainer(e) {\n const selector = `.${swiper.params.zoom.containerClass}`;\n if (e.target.matches(selector)) return true;\n if ([...swiper.el.querySelectorAll(selector)].filter(containerEl => containerEl.contains(e.target)).length > 0) return true;\n return false;\n }\n\n // Events\n function onGestureStart(e) {\n if (e.pointerType === 'mouse') {\n evCache.splice(0, evCache.length);\n }\n if (!eventWithinSlide(e)) return;\n const params = swiper.params.zoom;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n evCache.push(e);\n if (evCache.length < 2) {\n return;\n }\n fakeGestureTouched = true;\n gesture.scaleStart = getDistanceBetweenTouches();\n if (!gesture.slideEl) {\n gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\n if (!gesture.slideEl) gesture.slideEl = swiper.slides[swiper.activeIndex];\n let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n if (imageEl) {\n imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n }\n gesture.imageEl = imageEl;\n if (imageEl) {\n gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n } else {\n gesture.imageWrapEl = undefined;\n }\n if (!gesture.imageWrapEl) {\n gesture.imageEl = undefined;\n return;\n }\n gesture.maxRatio = gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;\n }\n if (gesture.imageEl) {\n const [originX, originY] = getScaleOrigin();\n gesture.originX = originX;\n gesture.originY = originY;\n gesture.imageEl.style.transitionDuration = '0ms';\n }\n isScaling = true;\n }\n function onGestureChange(e) {\n if (!eventWithinSlide(e)) return;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);\n if (pointerIndex >= 0) evCache[pointerIndex] = e;\n if (evCache.length < 2) {\n return;\n }\n fakeGestureMoved = true;\n gesture.scaleMove = getDistanceBetweenTouches();\n if (!gesture.imageEl) {\n return;\n }\n zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n }\n if (zoom.scale < params.minRatio) {\n zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n }\n gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n }\n function onGestureEnd(e) {\n if (!eventWithinSlide(e)) return;\n if (e.pointerType === 'mouse' && e.type === 'pointerout') return;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);\n if (pointerIndex >= 0) evCache.splice(pointerIndex, 1);\n if (!fakeGestureTouched || !fakeGestureMoved) {\n return;\n }\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n if (!gesture.imageEl) return;\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.imageEl.style.transitionDuration = `${swiper.params.speed}ms`;\n gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n currentScale = zoom.scale;\n isScaling = false;\n if (zoom.scale > 1 && gesture.slideEl) {\n gesture.slideEl.classList.add(`${params.zoomedSlideClass}`);\n } else if (zoom.scale <= 1 && gesture.slideEl) {\n gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);\n }\n if (zoom.scale === 1) {\n gesture.originX = 0;\n gesture.originY = 0;\n gesture.slideEl = undefined;\n }\n }\n function onTouchStart(e) {\n const device = swiper.device;\n if (!gesture.imageEl) return;\n if (image.isTouched) return;\n if (device.android && e.cancelable) e.preventDefault();\n image.isTouched = true;\n const event = evCache.length > 0 ? evCache[0] : e;\n image.touchesStart.x = event.pageX;\n image.touchesStart.y = event.pageY;\n }\n function onTouchMove(e) {\n if (!eventWithinSlide(e) || !eventWithinZoomContainer(e)) return;\n const zoom = swiper.zoom;\n if (!gesture.imageEl) return;\n if (!image.isTouched || !gesture.slideEl) return;\n if (!image.isMoved) {\n image.width = gesture.imageEl.offsetWidth;\n image.height = gesture.imageEl.offsetHeight;\n image.startX = getTranslate(gesture.imageWrapEl, 'x') || 0;\n image.startY = getTranslate(gesture.imageWrapEl, 'y') || 0;\n gesture.slideWidth = gesture.slideEl.offsetWidth;\n gesture.slideHeight = gesture.slideEl.offsetHeight;\n gesture.imageWrapEl.style.transitionDuration = '0ms';\n }\n // Define if we need image drag\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 = evCache.length > 0 ? evCache[0].pageX : e.pageX;\n image.touchesCurrent.y = evCache.length > 0 ? evCache[0].pageY : e.pageY;\n const touchesDiff = Math.max(Math.abs(image.touchesCurrent.x - image.touchesStart.x), Math.abs(image.touchesCurrent.y - image.touchesStart.y));\n if (touchesDiff > 5) {\n swiper.allowClick = false;\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 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 if (e.cancelable) {\n e.preventDefault();\n }\n e.stopPropagation();\n image.isMoved = true;\n const scaleRatio = (zoom.scale - currentScale) / (gesture.maxRatio - swiper.params.zoom.minRatio);\n const {\n originX,\n originY\n } = gesture;\n image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX + scaleRatio * (image.width - originX * 2);\n image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY + scaleRatio * (image.height - originY * 2);\n if (image.currentX < image.minX) {\n image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n }\n if (image.currentX > image.maxX) {\n image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n }\n if (image.currentY < image.minY) {\n image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n }\n if (image.currentY > image.maxY) {\n image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\n }\n\n // Velocity\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.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;\n }\n function onTouchEnd() {\n const zoom = swiper.zoom;\n if (!gesture.imageEl) return;\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\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;\n\n // Fix duration\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;\n // Define if we need image drag\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.style.transitionDuration = `${momentumDuration}ms`;\n gesture.imageWrapEl.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;\n }\n function onTransitionEnd() {\n const zoom = swiper.zoom;\n if (gesture.slideEl && swiper.activeIndex !== swiper.slides.indexOf(gesture.slideEl)) {\n if (gesture.imageEl) {\n gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';\n }\n if (gesture.imageWrapEl) {\n gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';\n }\n gesture.slideEl.classList.remove(`${swiper.params.zoom.zoomedSlideClass}`);\n zoom.scale = 1;\n currentScale = 1;\n gesture.slideEl = undefined;\n gesture.imageEl = undefined;\n gesture.imageWrapEl = undefined;\n gesture.originX = 0;\n gesture.originY = 0;\n }\n }\n function zoomIn(e) {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n if (!gesture.slideEl) {\n if (e && e.target) {\n gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\n }\n if (!gesture.slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];\n } else {\n gesture.slideEl = swiper.slides[swiper.activeIndex];\n }\n }\n let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n if (imageEl) {\n imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n }\n gesture.imageEl = imageEl;\n if (imageEl) {\n gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n } else {\n gesture.imageWrapEl = undefined;\n }\n }\n if (!gesture.imageEl || !gesture.imageWrapEl) return;\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.touchAction = 'none';\n }\n gesture.slideEl.classList.add(`${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 if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.pageX;\n touchY = e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n const forceZoomRatio = typeof e === 'number' ? e : null;\n if (currentScale === 1 && forceZoomRatio) {\n touchX = undefined;\n touchY = undefined;\n }\n zoom.scale = forceZoomRatio || gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;\n currentScale = forceZoomRatio || gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;\n if (e && !(currentScale === 1 && forceZoomRatio)) {\n slideWidth = gesture.slideEl.offsetWidth;\n slideHeight = gesture.slideEl.offsetHeight;\n offsetX = elementOffset(gesture.slideEl).left + window.scrollX;\n offsetY = elementOffset(gesture.slideEl).top + window.scrollY;\n diffX = offsetX + slideWidth / 2 - touchX;\n diffY = offsetY + slideHeight / 2 - touchY;\n imageWidth = gesture.imageEl.offsetWidth;\n imageHeight = gesture.imageEl.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 if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n if (forceZoomRatio && zoom.scale === 1) {\n gesture.originX = 0;\n gesture.originY = 0;\n }\n gesture.imageWrapEl.style.transitionDuration = '300ms';\n gesture.imageWrapEl.style.transform = `translate3d(${translateX}px, ${translateY}px,0)`;\n gesture.imageEl.style.transitionDuration = '300ms';\n gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n }\n function zoomOut() {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n if (!gesture.slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];\n } else {\n gesture.slideEl = swiper.slides[swiper.activeIndex];\n }\n let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n if (imageEl) {\n imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n }\n gesture.imageEl = imageEl;\n if (imageEl) {\n gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n } else {\n gesture.imageWrapEl = undefined;\n }\n }\n if (!gesture.imageEl || !gesture.imageWrapEl) return;\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.style.touchAction = '';\n }\n zoom.scale = 1;\n currentScale = 1;\n gesture.imageWrapEl.style.transitionDuration = '300ms';\n gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';\n gesture.imageEl.style.transitionDuration = '300ms';\n gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';\n gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);\n gesture.slideEl = undefined;\n gesture.originX = 0;\n gesture.originY = 0;\n }\n\n // Toggle Zoom\n function zoomToggle(e) {\n const zoom = swiper.zoom;\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoomOut();\n } else {\n // Zoom In\n zoomIn(e);\n }\n }\n function getListeners() {\n const passiveListener = swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n const activeListenerWithCapture = swiper.params.passiveListeners ? {\n passive: false,\n capture: true\n } : true;\n return {\n passiveListener,\n activeListenerWithCapture\n };\n }\n\n // Attach/Detach Events\n function enable() {\n const zoom = swiper.zoom;\n if (zoom.enabled) return;\n zoom.enabled = true;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n\n // Scale image\n swiper.wrapperEl.addEventListener('pointerdown', onGestureStart, passiveListener);\n swiper.wrapperEl.addEventListener('pointermove', onGestureChange, activeListenerWithCapture);\n ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {\n swiper.wrapperEl.addEventListener(eventName, onGestureEnd, passiveListener);\n });\n\n // Move image\n swiper.wrapperEl.addEventListener('pointermove', onTouchMove, activeListenerWithCapture);\n }\n function disable() {\n const zoom = swiper.zoom;\n if (!zoom.enabled) return;\n zoom.enabled = false;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n\n // Scale image\n swiper.wrapperEl.removeEventListener('pointerdown', onGestureStart, passiveListener);\n swiper.wrapperEl.removeEventListener('pointermove', onGestureChange, activeListenerWithCapture);\n ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {\n swiper.wrapperEl.removeEventListener(eventName, onGestureEnd, passiveListener);\n });\n\n // Move image\n swiper.wrapperEl.removeEventListener('pointermove', onTouchMove, activeListenerWithCapture);\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}","/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\nimport { elementTransitionEnd, 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 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 while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n return maxIndex;\n };\n }();\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1;\n // 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 let i1;\n let i3;\n this.interpolate = function interpolate(x2) {\n if (!x2) return 0;\n\n // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1;\n\n // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];\n };\n return this;\n }\n function getInterpolateFunction(c) {\n swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n function setTranslate(_t, byController) {\n const controlled = swiper.controller.control;\n let multiplier;\n let controlledTranslate;\n const Swiper = swiper.constructor;\n function setControlledTranslate(c) {\n if (c.destroyed) return;\n\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 if (swiper.params.controller.by === 'slide') {\n getInterpolateFunction(c);\n // 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 controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n if (Number.isNaN(multiplier) || !Number.isFinite(multiplier)) {\n multiplier = 1;\n }\n controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n }\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\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 function setTransition(duration, byController) {\n const Swiper = swiper.constructor;\n const controlled = swiper.controller.control;\n let i;\n function setControlledTransition(c) {\n if (c.destroyed) return;\n c.setTransition(duration, swiper);\n if (duration !== 0) {\n c.transitionStart();\n if (c.params.autoHeight) {\n nextTick(() => {\n c.updateAutoHeight();\n });\n }\n elementTransitionEnd(c.wrapperEl, () => {\n if (!controlled) return;\n c.transitionEnd();\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 function removeSpline() {\n if (!swiper.controller.control) return;\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n }\n on('beforeInit', () => {\n if (typeof window !== 'undefined' && (\n // eslint-disable-line\n typeof swiper.params.controller.control === 'string' || swiper.params.controller.control instanceof HTMLElement)) {\n const controlElement = document.querySelector(swiper.params.controller.control);\n if (controlElement && controlElement.swiper) {\n swiper.controller.control = controlElement.swiper;\n } else if (controlElement) {\n const onControllerSwiper = e => {\n swiper.controller.control = e.detail[0];\n swiper.update();\n controlElement.removeEventListener('init', onControllerSwiper);\n };\n controlElement.addEventListener('init', onControllerSwiper);\n }\n return;\n }\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 || swiper.controller.control.destroyed) return;\n swiper.controller.setTranslate(translate, byController);\n });\n on('setTransition', (_s, duration, byController) => {\n if (!swiper.controller.control || swiper.controller.control.destroyed) 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 { createElement, elementIndex } from '../../shared/utils.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 function notify(message) {\n const notification = liveRegion;\n if (notification.length === 0) return;\n notification.innerHTML = '';\n notification.innerHTML = message;\n }\n const makeElementsArray = el => {\n if (!Array.isArray(el)) el = [el].filter(e => !!e);\n return el;\n };\n function getRandomNumber(size = 16) {\n const randomChar = () => Math.round(16 * Math.random()).toString(16);\n return 'x'.repeat(size).replace(/x/g, randomChar);\n }\n function makeElFocusable(el) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('tabIndex', '0');\n });\n }\n function makeElNotFocusable(el) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('tabIndex', '-1');\n });\n }\n function addElRole(el, role) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('role', role);\n });\n }\n function addElRoleDescription(el, description) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('aria-roledescription', description);\n });\n }\n function addElControls(el, controls) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('aria-controls', controls);\n });\n }\n function addElLabel(el, label) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('aria-label', label);\n });\n }\n function addElId(el, id) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('id', id);\n });\n }\n function addElLive(el, live) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('aria-live', live);\n });\n }\n function disableEl(el) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('aria-disabled', true);\n });\n }\n function enableEl(el) {\n el = makeElementsArray(el);\n el.forEach(subEl => {\n subEl.setAttribute('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 if (swiper.pagination && swiper.pagination.el && (targetEl === swiper.pagination.el || swiper.pagination.el.contains(e.target))) {\n if (!e.target.matches(classesToSelector(swiper.params.pagination.bulletClass))) return;\n }\n if (swiper.navigation && swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl) {\n if (!(swiper.isEnd && !swiper.params.loop)) {\n swiper.slideNext();\n }\n if (swiper.isEnd) {\n notify(params.lastSlideMessage);\n } else {\n notify(params.nextSlideMessage);\n }\n }\n if (swiper.navigation && swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl) {\n if (!(swiper.isBeginning && !swiper.params.loop)) {\n swiper.slidePrev();\n }\n if (swiper.isBeginning) {\n notify(params.firstSlideMessage);\n } else {\n notify(params.prevSlideMessage);\n }\n }\n if (swiper.pagination && targetEl.matches(classesToSelector(swiper.params.pagination.bulletClass))) {\n targetEl.click();\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 if (prevEl) {\n if (swiper.isBeginning) {\n disableEl(prevEl);\n makeElNotFocusable(prevEl);\n } else {\n enableEl(prevEl);\n makeElFocusable(prevEl);\n }\n }\n if (nextEl) {\n if (swiper.isEnd) {\n disableEl(nextEl);\n makeElNotFocusable(nextEl);\n } else {\n enableEl(nextEl);\n makeElFocusable(nextEl);\n }\n }\n }\n function hasPagination() {\n return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;\n }\n function hasClickablePagination() {\n return hasPagination() && swiper.params.pagination.clickable;\n }\n function updatePagination() {\n const params = swiper.params.a11y;\n if (!hasPagination()) return;\n swiper.pagination.bullets.forEach(bulletEl => {\n if (swiper.params.pagination.clickable) {\n makeElFocusable(bulletEl);\n if (!swiper.params.pagination.renderBullet) {\n addElRole(bulletEl, 'button');\n addElLabel(bulletEl, params.paginationBulletMessage.replace(/\\{\\{index\\}\\}/, elementIndex(bulletEl) + 1));\n }\n }\n if (bulletEl.matches(classesToSelector(swiper.params.pagination.bulletActiveClass))) {\n bulletEl.setAttribute('aria-current', 'true');\n } else {\n bulletEl.removeAttribute('aria-current');\n }\n });\n }\n const initNavEl = (el, wrapperId, message) => {\n makeElFocusable(el);\n if (el.tagName !== 'BUTTON') {\n addElRole(el, 'button');\n el.addEventListener('keydown', onEnterOrSpaceKey);\n }\n addElLabel(el, message);\n addElControls(el, wrapperId);\n };\n const handlePointerDown = () => {\n swiper.a11y.clicked = true;\n };\n const handlePointerUp = () => {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n if (!swiper.destroyed) {\n swiper.a11y.clicked = false;\n }\n });\n });\n };\n const handleFocus = e => {\n if (swiper.a11y.clicked) return;\n const slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\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 if (swiper.isHorizontal()) {\n swiper.el.scrollLeft = 0;\n } else {\n swiper.el.scrollTop = 0;\n }\n swiper.slideTo(swiper.slides.indexOf(slideEl), 0);\n };\n const initSlides = () => {\n const params = swiper.params.a11y;\n if (params.itemRoleDescriptionMessage) {\n addElRoleDescription(swiper.slides, params.itemRoleDescriptionMessage);\n }\n if (params.slideRole) {\n addElRole(swiper.slides, params.slideRole);\n }\n const slidesLength = swiper.slides.length;\n if (params.slideLabelMessage) {\n swiper.slides.forEach((slideEl, index) => {\n const slideIndex = swiper.params.loop ? parseInt(slideEl.getAttribute('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 const init = () => {\n const params = swiper.params.a11y;\n if (swiper.isElement) {\n swiper.el.shadowEl.append(liveRegion);\n } else {\n swiper.el.append(liveRegion);\n }\n\n // Container\n const containerEl = swiper.el;\n if (params.containerRoleDescriptionMessage) {\n addElRoleDescription(containerEl, params.containerRoleDescriptionMessage);\n }\n if (params.containerMessage) {\n addElLabel(containerEl, params.containerMessage);\n }\n\n // Wrapper\n const wrapperEl = swiper.wrapperEl;\n const wrapperId = params.id || wrapperEl.getAttribute('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);\n\n // Slide\n initSlides();\n\n // Navigation\n let {\n nextEl,\n prevEl\n } = swiper.navigation ? swiper.navigation : {};\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n if (nextEl) {\n nextEl.forEach(el => initNavEl(el, wrapperId, params.nextSlideMessage));\n }\n if (prevEl) {\n prevEl.forEach(el => initNavEl(el, wrapperId, params.prevSlideMessage));\n }\n\n // Pagination\n if (hasClickablePagination()) {\n const paginationEl = Array.isArray(swiper.pagination.el) ? swiper.pagination.el : [swiper.pagination.el];\n paginationEl.forEach(el => {\n el.addEventListener('keydown', onEnterOrSpaceKey);\n });\n }\n\n // Tab focus\n swiper.el.addEventListener('focus', handleFocus, true);\n swiper.el.addEventListener('pointerdown', handlePointerDown, true);\n swiper.el.addEventListener('pointerup', handlePointerUp, true);\n };\n function destroy() {\n if (liveRegion) liveRegion.remove();\n let {\n nextEl,\n prevEl\n } = swiper.navigation ? swiper.navigation : {};\n nextEl = makeElementsArray(nextEl);\n prevEl = makeElementsArray(prevEl);\n if (nextEl) {\n nextEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));\n }\n if (prevEl) {\n prevEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));\n }\n\n // Pagination\n if (hasClickablePagination()) {\n const paginationEl = Array.isArray(swiper.pagination.el) ? swiper.pagination.el : [swiper.pagination.el];\n paginationEl.forEach(el => {\n el.removeEventListener('keydown', onEnterOrSpaceKey);\n });\n }\n\n // Tab focus\n swiper.el.removeEventListener('focus', handleFocus, true);\n swiper.el.removeEventListener('pointerdown', handlePointerDown, true);\n swiper.el.removeEventListener('pointerup', handlePointerUp, true);\n }\n on('beforeInit', () => {\n liveRegion = createElement('span', swiper.params.a11y.notificationClass);\n liveRegion.setAttribute('aria-live', 'assertive');\n liveRegion.setAttribute('aria-atomic', 'true');\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 const slugify = text => {\n return text.toString().replace(/\\s+/g, '-').replace(/[^\\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');\n };\n const getPathValues = urlOverride => {\n const window = getWindow();\n let location;\n if (urlOverride) {\n location = new URL(urlOverride);\n } else {\n location = window.location;\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 const setHistory = (key, index) => {\n const window = getWindow();\n if (!initialized || !swiper.params.history.enabled) return;\n let location;\n if (swiper.params.url) {\n location = new URL(swiper.params.url);\n } else {\n location = window.location;\n }\n const slide = swiper.slides[index];\n let value = slugify(slide.getAttribute('data-history'));\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 ? `${key}/` : ''}${value}`;\n } else if (!location.pathname.includes(key)) {\n value = `${key ? `${key}/` : ''}${value}`;\n }\n if (swiper.params.history.keepQuery) {\n value += location.search;\n }\n const currentState = window.history.state;\n if (currentState && currentState.value === value) {\n return;\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 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[i];\n const slideHistory = slugify(slide.getAttribute('data-history'));\n if (slideHistory === value) {\n const index = swiper.getSlideIndex(slide);\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n };\n const setHistoryPopState = () => {\n paths = getPathValues(swiper.params.url);\n scrollToSlide(swiper.params.speed, paths.value, false);\n };\n const init = () => {\n const window = getWindow();\n if (!swiper.params.history) return;\n if (!window.history || !window.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n initialized = true;\n paths = getPathValues(swiper.params.url);\n if (!paths.key && !paths.value) {\n if (!swiper.params.history.replaceState) {\n window.addEventListener('popstate', setHistoryPopState);\n }\n return;\n }\n scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n if (!swiper.params.history.replaceState) {\n window.addEventListener('popstate', setHistoryPopState);\n }\n };\n const destroy = () => {\n const window = getWindow();\n if (!swiper.params.history.replaceState) {\n window.removeEventListener('popstate', setHistoryPopState);\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 { elementChildren } from '../../shared/utils.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 getSlideIndex(_s, hash) {\n if (swiper.virtual && swiper.params.virtual.enabled) {\n const slideWithHash = swiper.slides.filter(slideEl => slideEl.getAttribute('data-hash') === hash)[0];\n if (!slideWithHash) return 0;\n const index = parseInt(slideWithHash.getAttribute('data-swiper-slide-index'), 10);\n return index;\n }\n return swiper.getSlideIndex(elementChildren(swiper.slidesEl, `.${swiper.params.slideClass}[data-hash=\"${hash}\"], swiper-slide[data-hash=\"${hash}\"]`)[0]);\n }\n }\n });\n const onHashChange = () => {\n emit('hashChange');\n const newHash = document.location.hash.replace('#', '');\n const activeSlideEl = swiper.slidesEl.querySelector(`[data-swiper-slide-index=\"${swiper.activeIndex}\"]`);\n const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') : '';\n if (newHash !== activeSlideHash) {\n const newIndex = swiper.params.hashNavigation.getSlideIndex(swiper, newHash);\n console.log(newIndex);\n if (typeof newIndex === 'undefined') return;\n swiper.slideTo(newIndex);\n }\n };\n const setHash = () => {\n if (!initialized || !swiper.params.hashNavigation.enabled) return;\n const activeSlideEl = swiper.slidesEl.querySelector(`[data-swiper-slide-index=\"${swiper.activeIndex}\"]`);\n const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') || activeSlideEl.getAttribute('data-history') : '';\n if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n window.history.replaceState(null, null, `#${activeSlideHash}` || '');\n emit('hashSet');\n } else {\n document.location.hash = activeSlideHash || '';\n emit('hashSet');\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 if (hash) {\n const speed = 0;\n const index = swiper.params.hashNavigation.getSlideIndex(swiper, hash);\n swiper.slideTo(index || 0, speed, swiper.params.runCallbacksOnInit, true);\n }\n if (swiper.params.hashNavigation.watchState) {\n window.addEventListener('hashchange', onHashChange);\n }\n };\n const destroy = () => {\n if (swiper.params.hashNavigation.watchState) {\n window.removeEventListener('hashchange', onHashChange);\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/* eslint no-use-before-define: \"off\" */\nimport { getDocument } from 'ssr-window';\nexport default function Autoplay({\n swiper,\n extendParams,\n on,\n emit,\n params\n}) {\n swiper.autoplay = {\n running: false,\n paused: false,\n timeLeft: 0\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 let timeout;\n let raf;\n let autoplayDelayTotal = params && params.autoplay ? params.autoplay.delay : 3000;\n let autoplayDelayCurrent = params && params.autoplay ? params.autoplay.delay : 3000;\n let autoplayTimeLeft;\n let autoplayStartTime = new Date().getTime;\n let wasPaused;\n let isTouched;\n let pausedByTouch;\n let touchStartTimeout;\n let slideChanged;\n let pausedByInteraction;\n function onTransitionEnd(e) {\n if (!swiper || swiper.destroyed || !swiper.wrapperEl) return;\n if (e.target !== swiper.wrapperEl) return;\n swiper.wrapperEl.removeEventListener('transitionend', onTransitionEnd);\n resume();\n }\n const calcTimeLeft = () => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n if (swiper.autoplay.paused) {\n wasPaused = true;\n } else if (wasPaused) {\n autoplayDelayCurrent = autoplayTimeLeft;\n wasPaused = false;\n }\n const timeLeft = swiper.autoplay.paused ? autoplayTimeLeft : autoplayStartTime + autoplayDelayCurrent - new Date().getTime();\n swiper.autoplay.timeLeft = timeLeft;\n emit('autoplayTimeLeft', timeLeft, timeLeft / autoplayDelayTotal);\n raf = requestAnimationFrame(() => {\n calcTimeLeft();\n });\n };\n const getSlideDelay = () => {\n let activeSlideEl;\n if (swiper.virtual && swiper.params.virtual.enabled) {\n activeSlideEl = swiper.slides.filter(slideEl => slideEl.classList.contains('swiper-slide-active'))[0];\n } else {\n activeSlideEl = swiper.slides[swiper.activeIndex];\n }\n if (!activeSlideEl) return undefined;\n const currentSlideDelay = parseInt(activeSlideEl.getAttribute('data-swiper-autoplay'), 10);\n return currentSlideDelay;\n };\n const run = delayForce => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n cancelAnimationFrame(raf);\n calcTimeLeft();\n let delay = typeof delayForce === 'undefined' ? swiper.params.autoplay.delay : delayForce;\n autoplayDelayTotal = swiper.params.autoplay.delay;\n autoplayDelayCurrent = swiper.params.autoplay.delay;\n const currentSlideDelay = getSlideDelay();\n if (!Number.isNaN(currentSlideDelay) && currentSlideDelay > 0 && typeof delayForce === 'undefined') {\n delay = currentSlideDelay;\n autoplayDelayTotal = currentSlideDelay;\n autoplayDelayCurrent = currentSlideDelay;\n }\n autoplayTimeLeft = delay;\n const speed = swiper.params.speed;\n const proceed = () => {\n if (!swiper || swiper.destroyed) return;\n if (swiper.params.autoplay.reverseDirection) {\n if (!swiper.isBeginning || swiper.params.loop || swiper.params.rewind) {\n swiper.slidePrev(speed, true, true);\n emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(swiper.slides.length - 1, speed, true, true);\n emit('autoplay');\n }\n } else {\n if (!swiper.isEnd || swiper.params.loop || swiper.params.rewind) {\n swiper.slideNext(speed, true, true);\n emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n swiper.slideTo(0, speed, true, true);\n emit('autoplay');\n }\n }\n if (swiper.params.cssMode) {\n autoplayStartTime = new Date().getTime();\n requestAnimationFrame(() => {\n run();\n });\n }\n };\n if (delay > 0) {\n clearTimeout(timeout);\n timeout = setTimeout(() => {\n proceed();\n }, delay);\n } else {\n requestAnimationFrame(() => {\n proceed();\n });\n }\n\n // eslint-disable-next-line\n return delay;\n };\n const start = () => {\n swiper.autoplay.running = true;\n run();\n emit('autoplayStart');\n };\n const stop = () => {\n swiper.autoplay.running = false;\n clearTimeout(timeout);\n cancelAnimationFrame(raf);\n emit('autoplayStop');\n };\n const pause = (internal, reset) => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n clearTimeout(timeout);\n if (!internal) {\n pausedByInteraction = true;\n }\n const proceed = () => {\n emit('autoplayPause');\n if (swiper.params.autoplay.waitForTransition) {\n swiper.wrapperEl.addEventListener('transitionend', onTransitionEnd);\n } else {\n resume();\n }\n };\n swiper.autoplay.paused = true;\n if (reset) {\n if (slideChanged) {\n autoplayTimeLeft = swiper.params.autoplay.delay;\n }\n slideChanged = false;\n proceed();\n return;\n }\n const delay = autoplayTimeLeft || swiper.params.autoplay.delay;\n autoplayTimeLeft = delay - (new Date().getTime() - autoplayStartTime);\n if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop) return;\n if (autoplayTimeLeft < 0) autoplayTimeLeft = 0;\n proceed();\n };\n const resume = () => {\n if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop || swiper.destroyed || !swiper.autoplay.running) return;\n autoplayStartTime = new Date().getTime();\n if (pausedByInteraction) {\n pausedByInteraction = false;\n run(autoplayTimeLeft);\n } else {\n run();\n }\n swiper.autoplay.paused = false;\n emit('autoplayResume');\n };\n const onVisibilityChange = () => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n const document = getDocument();\n if (document.visibilityState === 'hidden') {\n pausedByInteraction = true;\n pause(true);\n }\n if (document.visibilityState === 'visible') {\n resume();\n }\n };\n const onPointerEnter = e => {\n if (e.pointerType !== 'mouse') return;\n pausedByInteraction = true;\n pause(true);\n };\n const onPointerLeave = e => {\n if (e.pointerType !== 'mouse') return;\n if (swiper.autoplay.paused) {\n resume();\n }\n };\n const attachMouseEvents = () => {\n if (swiper.params.autoplay.pauseOnMouseEnter) {\n swiper.el.addEventListener('pointerenter', onPointerEnter);\n swiper.el.addEventListener('pointerleave', onPointerLeave);\n }\n };\n const detachMouseEvents = () => {\n swiper.el.removeEventListener('pointerenter', onPointerEnter);\n swiper.el.removeEventListener('pointerleave', onPointerLeave);\n };\n const attachDocumentEvents = () => {\n const document = getDocument();\n document.addEventListener('visibilitychange', onVisibilityChange);\n };\n const detachDocumentEvents = () => {\n const document = getDocument();\n document.removeEventListener('visibilitychange', onVisibilityChange);\n };\n on('init', () => {\n if (swiper.params.autoplay.enabled) {\n attachMouseEvents();\n attachDocumentEvents();\n autoplayStartTime = new Date().getTime();\n start();\n }\n });\n on('destroy', () => {\n detachMouseEvents();\n detachDocumentEvents();\n if (swiper.autoplay.running) {\n stop();\n }\n });\n on('beforeTransitionStart', (_s, speed, internal) => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n if (internal || !swiper.params.autoplay.disableOnInteraction) {\n pause(true, true);\n } else {\n stop();\n }\n });\n on('sliderFirstMove', () => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n if (swiper.params.autoplay.disableOnInteraction) {\n stop();\n return;\n }\n isTouched = true;\n pausedByTouch = false;\n pausedByInteraction = false;\n touchStartTimeout = setTimeout(() => {\n pausedByInteraction = true;\n pausedByTouch = true;\n pause(true);\n }, 200);\n });\n on('touchEnd', () => {\n if (swiper.destroyed || !swiper.autoplay.running || !isTouched) return;\n clearTimeout(touchStartTimeout);\n clearTimeout(timeout);\n if (swiper.params.autoplay.disableOnInteraction) {\n pausedByTouch = false;\n isTouched = false;\n return;\n }\n if (pausedByTouch && swiper.params.cssMode) resume();\n pausedByTouch = false;\n isTouched = false;\n });\n on('slideChange', () => {\n if (swiper.destroyed || !swiper.autoplay.running) return;\n slideChanged = true;\n });\n Object.assign(swiper.autoplay, {\n start,\n stop,\n pause,\n resume\n });\n}","import { getDocument } from 'ssr-window';\nimport { elementChildren, isObject } from '../../shared/utils.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 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.classList.contains(swiper.params.thumbs.slideThumbActiveClass)) return;\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;\n let slideToIndex;\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt(thumbsSwiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n if (swiper.params.loop) {\n swiper.slideToLoop(slideToIndex);\n } else {\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 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 swiper.thumbs.swiper.update();\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 swiper.thumbs.swiper.el.classList.add(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', onThumbClick);\n return true;\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;\n\n // Activate thumbs\n let thumbsToActivate = 1;\n const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n if (!swiper.params.thumbs.multipleActiveThumbs) {\n thumbsToActivate = 1;\n }\n thumbsToActivate = Math.floor(thumbsToActivate);\n thumbsSwiper.slides.forEach(slideEl => slideEl.classList.remove(thumbActiveClass));\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n elementChildren(thumbsSwiper.slidesEl, `[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).forEach(slideEl => {\n slideEl.classList.add(thumbActiveClass);\n });\n }\n } else {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n if (thumbsSwiper.slides[swiper.realIndex + i]) {\n thumbsSwiper.slides[swiper.realIndex + i].classList.add(thumbActiveClass);\n }\n }\n }\n const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n const currentThumbsIndex = thumbsSwiper.activeIndex;\n let newThumbsIndex;\n let direction;\n if (thumbsSwiper.params.loop) {\n const newThumbsSlide = thumbsSwiper.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') === `${swiper.realIndex}`)[0];\n newThumbsIndex = thumbsSwiper.slides.indexOf(newThumbsSlide);\n direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';\n } else {\n newThumbsIndex = swiper.realIndex;\n direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';\n }\n if (useOffset) {\n newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;\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) {\n // newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n }\n }\n on('beforeInit', () => {\n const {\n thumbs\n } = swiper.params;\n if (!thumbs || !thumbs.swiper) return;\n if (typeof thumbs.swiper === 'string' || thumbs.swiper instanceof HTMLElement) {\n const document = getDocument();\n const getThumbsElementAndInit = () => {\n const thumbsElement = typeof thumbs.swiper === 'string' ? document.querySelector(thumbs.swiper) : thumbs.swiper;\n if (thumbsElement && thumbsElement.swiper) {\n thumbs.swiper = thumbsElement.swiper;\n init();\n update(true);\n } else if (thumbsElement) {\n const onThumbsSwiper = e => {\n thumbs.swiper = e.detail[0];\n thumbsElement.removeEventListener('init', onThumbsSwiper);\n init();\n update(true);\n thumbs.swiper.update();\n swiper.update();\n };\n thumbsElement.addEventListener('init', onThumbsSwiper);\n }\n return thumbsElement;\n };\n const watchForThumbsToAppear = () => {\n if (swiper.destroyed) return;\n const thumbsElement = getThumbsElementAndInit();\n if (!thumbsElement) {\n requestAnimationFrame(watchForThumbsToAppear);\n }\n };\n requestAnimationFrame(watchForThumbsToAppear);\n } else {\n init();\n update(true);\n }\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 if (swiperCreated) {\n thumbsSwiper.destroy();\n }\n });\n Object.assign(swiper.thumbs, {\n init,\n update\n });\n}","import { elementTransitionEnd, 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 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 function onTouchMove() {\n const {\n touchEventsData: data,\n touches\n } = swiper;\n // Velocity\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime\n });\n }\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: now()\n });\n }\n function onTouchEnd({\n currentPos\n }) {\n const {\n params,\n wrapperEl,\n rtlTranslate: rtl,\n snapGrid,\n touchEventsData: data\n } = swiper;\n // Time diff\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime;\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\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 return;\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 if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {\n swiper.velocity = 0;\n }\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 if (time > 150 || now() - lastMoveEvent.time > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\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 if (newPosition < swiper.maxTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\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 afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (params.freeMode.sticky) {\n let nextSlide;\n for (let j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\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 newPosition = -newPosition;\n }\n if (needsLoopFix) {\n once('transitionEnd', () => {\n swiper.loopFix();\n });\n }\n // Fix duration\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 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 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 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 elementTransitionEnd(wrapperEl, () => {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n emit('momentumBounce');\n swiper.setTransition(params.speed);\n setTimeout(() => {\n swiper.setTranslate(afterBouncePosition);\n elementTransitionEnd(wrapperEl, () => {\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 if (!swiper.animating) {\n swiper.animating = true;\n elementTransitionEnd(wrapperEl, () => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\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 if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n }\n Object.assign(swiper, {\n freeMode: {\n onTouchStart,\n onTouchMove,\n onTouchEnd\n }\n });\n}","import { getSlideTransformEl } from './utils.js';\nexport default function effectTarget(effectParams, slideEl) {\n const transformEl = getSlideTransformEl(slideEl);\n if (transformEl !== slideEl) {\n transformEl.style.backfaceVisibility = 'hidden';\n transformEl.style['-webkit-backface-visibility'] = 'hidden';\n }\n return transformEl;\n}","import { elementTransitionEnd } from './utils.js';\nexport default function effectVirtualTransitionEnd({\n swiper,\n duration,\n transformElements,\n allSlides\n}) {\n const {\n activeIndex\n } = swiper;\n const getSlide = el => {\n if (!el.parentElement) {\n // assume shadow root\n const slide = swiper.slides.filter(slideEl => slideEl.shadowEl && slideEl.shadowEl === el.parentNode)[0];\n return slide;\n }\n return el.parentElement;\n };\n if (swiper.params.virtualTranslate && duration !== 0) {\n let eventTriggered = false;\n let transitionEndTarget;\n if (allSlides) {\n transitionEndTarget = transformElements;\n } else {\n transitionEndTarget = transformElements.filter(transformEl => {\n const el = transformEl.classList.contains('swiper-slide-transform') ? getSlide(transformEl) : transformEl;\n return swiper.getSlideIndex(el) === activeIndex;\n });\n }\n transitionEndTarget.forEach(el => {\n elementTransitionEnd(el, () => {\n if (eventTriggered) return;\n if (!swiper || swiper.destroyed) return;\n eventTriggered = true;\n swiper.animating = false;\n const evt = new window.CustomEvent('transitionend', {\n bubbles: true,\n cancelable: true\n });\n swiper.wrapperEl.dispatchEvent(evt);\n });\n });\n }\n}","import effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nimport { getSlideTransformEl } from '../../shared/utils.js';\nexport default function EffectFade({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n fadeEffect: {\n crossFade: false\n }\n });\n const setTranslate = () => {\n const {\n slides\n } = swiper;\n const params = swiper.params.fadeEffect;\n for (let i = 0; i < slides.length; i += 1) {\n const slideEl = swiper.slides[i];\n const offset = slideEl.swiperSlideOffset;\n let tx = -offset;\n if (!swiper.params.virtualTranslate) tx -= swiper.translate;\n let ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n }\n const slideOpacity = swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs(slideEl.progress), 0) : 1 + Math.min(Math.max(slideEl.progress, -1), 0);\n const targetEl = effectTarget(params, slideEl);\n targetEl.style.opacity = slideOpacity;\n targetEl.style.transform = `translate3d(${tx}px, ${ty}px, 0px)`;\n }\n };\n const setTransition = duration => {\n const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n transformElements.forEach(el => {\n el.style.transitionDuration = `${duration}ms`;\n });\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformElements,\n allSlides: true\n });\n };\n effectInit({\n effect: 'fade',\n swiper,\n on,\n setTranslate,\n setTransition,\n overwriteParams: () => ({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}","import effectInit from '../../shared/effect-init.js';\nimport { createElement } from '../../shared/utils.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 const createSlideShadows = (slideEl, progress, isHorizontal) => {\n let shadowBefore = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n let shadowAfter = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n if (!shadowBefore) {\n shadowBefore = createElement('div', `swiper-slide-shadow-${isHorizontal ? 'left' : 'top'}`);\n slideEl.append(shadowBefore);\n }\n if (!shadowAfter) {\n shadowAfter = createElement('div', `swiper-slide-shadow-${isHorizontal ? 'right' : 'bottom'}`);\n slideEl.append(shadowAfter);\n }\n if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);\n if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);\n };\n const recreateShadows = () => {\n // create new ones\n const isHorizontal = swiper.isHorizontal();\n swiper.slides.forEach(slideEl => {\n const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n createSlideShadows(slideEl, progress, isHorizontal);\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 if (params.shadow) {\n if (isHorizontal) {\n cubeShadowEl = swiper.slidesEl.querySelector('.swiper-cube-shadow');\n if (!cubeShadowEl) {\n cubeShadowEl = createElement('div', 'swiper-cube-shadow');\n swiper.slidesEl.append(cubeShadowEl);\n }\n cubeShadowEl.style.height = `${swiperWidth}px`;\n } else {\n cubeShadowEl = el.querySelector('.swiper-cube-shadow');\n if (!cubeShadowEl) {\n cubeShadowEl = createElement('div', 'swiper-cube-shadow');\n el.append(cubeShadowEl);\n }\n }\n }\n for (let i = 0; i < slides.length; i += 1) {\n const slideEl = slides[i];\n let slideIndex = i;\n if (isVirtual) {\n slideIndex = parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10);\n }\n let slideAngle = slideIndex * 90;\n let round = Math.floor(slideAngle / 360);\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n let tx = 0;\n let ty = 0;\n let tz = 0;\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 if (rtl) {\n tx = -tx;\n }\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;\n if (progress <= 1 && progress > -1) {\n wrapperRotate = slideIndex * 90 + progress * 90;\n if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;\n }\n slideEl.style.transform = transform;\n if (params.slideShadows) {\n createSlideShadows(slideEl, progress, isHorizontal);\n }\n }\n wrapperEl.style.transformOrigin = `50% 50% -${swiperSize / 2}px`;\n wrapperEl.style['-webkit-transform-origin'] = `50% 50% -${swiperSize / 2}px`;\n if (params.shadow) {\n if (isHorizontal) {\n cubeShadowEl.style.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.style.transform = `scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`;\n }\n }\n const zFactor = (browser.isSafari || browser.isWebView) && browser.needPerspectiveFix ? -swiperSize / 2 : 0;\n wrapperEl.style.transform = `translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`;\n wrapperEl.style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);\n };\n const setTransition = duration => {\n const {\n el,\n slides\n } = swiper;\n slides.forEach(slideEl => {\n slideEl.style.transitionDuration = `${duration}ms`;\n slideEl.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(subEl => {\n subEl.style.transitionDuration = `${duration}ms`;\n });\n });\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n const shadowEl = el.querySelector('.swiper-cube-shadow');\n if (shadowEl) shadowEl.style.transitionDuration = `${duration}ms`;\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 { createElement, getSlideTransformEl } from './utils.js';\nexport default function createShadow(params, slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const shadowContainer = getSlideTransformEl(slideEl);\n let shadowEl = shadowContainer.querySelector(`.${shadowClass}`);\n if (!shadowEl) {\n shadowEl = createElement('div', `swiper-slide-shadow${side ? `-${side}` : ''}`);\n shadowContainer.append(shadowEl);\n }\n return shadowEl;\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';\nimport { getSlideTransformEl } from '../../shared/utils.js';\nexport default function EffectFlip({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n flipEffect: {\n slideShadows: true,\n limitRotation: true\n }\n });\n const createSlideShadows = (slideEl, progress, params) => {\n let shadowBefore = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n let shadowAfter = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n if (!shadowBefore) {\n shadowBefore = createShadow(params, slideEl, swiper.isHorizontal() ? 'left' : 'top');\n }\n if (!shadowAfter) {\n shadowAfter = createShadow(params, slideEl, swiper.isHorizontal() ? 'right' : 'bottom');\n }\n if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);\n if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);\n };\n const recreateShadows = () => {\n // Set shadows\n const params = swiper.params.flipEffect;\n swiper.slides.forEach(slideEl => {\n let progress = slideEl.progress;\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min(slideEl.progress, 1), -1);\n }\n createSlideShadows(slideEl, progress, params);\n });\n };\n const setTranslate = () => {\n const {\n slides,\n rtlTranslate: rtl\n } = swiper;\n const params = swiper.params.flipEffect;\n for (let i = 0; i < slides.length; i += 1) {\n const slideEl = slides[i];\n let progress = slideEl.progress;\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min(slideEl.progress, 1), -1);\n }\n const offset = slideEl.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 if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n slideEl.style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n if (params.slideShadows) {\n createSlideShadows(slideEl, progress, params);\n }\n const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;\n const targetEl = effectTarget(params, slideEl);\n targetEl.style.transform = transform;\n }\n };\n const setTransition = duration => {\n const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n transformElements.forEach(el => {\n el.style.transitionDuration = `${duration}ms`;\n el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {\n shadowEl.style.transitionDuration = `${duration}ms`;\n });\n });\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformElements\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';\nimport { getSlideTransformEl } from '../../shared/utils.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 }\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;\n // Each slide offset from center\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const slideEl = slides[i];\n const slideSize = slidesSizesGrid[i];\n const slideOffset = slideEl.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;\n // var rotateZ = 0\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch;\n // Allow percentage to make a relative stretch for responsive sliders\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\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);\n\n // Fix for ultra small values\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.style.transform = slideTransform;\n slideEl.style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n if (params.slideShadows) {\n // Set shadows\n let shadowBeforeEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n let shadowAfterEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n if (!shadowBeforeEl) {\n shadowBeforeEl = createShadow(params, slideEl, isHorizontal ? 'left' : 'top');\n }\n if (!shadowAfterEl) {\n shadowAfterEl = createShadow(params, slideEl, isHorizontal ? 'right' : 'bottom');\n }\n if (shadowBeforeEl) shadowBeforeEl.style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if (shadowAfterEl) shadowAfterEl.style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n const setTransition = duration => {\n const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n transformElements.forEach(el => {\n el.style.transitionDuration = `${duration}ms`;\n el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {\n shadowEl.style.transitionDuration = `${duration}ms`;\n });\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';\nimport { getSlideTransformEl } from '../../shared/utils.js';\nexport default function EffectCreative({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n creativeEffect: {\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 const getTranslateValue = value => {\n if (typeof value === 'string') return value;\n return `${value}px`;\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 if (isCenteredSlides) {\n const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n wrapperEl.style.transform = `translateX(calc(50% - ${margin}px))`;\n }\n for (let i = 0; i < slides.length; i += 1) {\n const slideEl = slides[i];\n const slideProgress = slideEl.progress;\n const progress = Math.min(Math.max(slideEl.progress, -params.limitProgress), params.limitProgress);\n let originalProgress = progress;\n if (!isCenteredSlides) {\n originalProgress = Math.min(Math.max(slideEl.originalProgress, -params.limitProgress), params.limitProgress);\n }\n const offset = slideEl.swiperSlideOffset;\n const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];\n const r = [0, 0, 0];\n let custom = false;\n if (!swiper.isHorizontal()) {\n t[1] = t[0];\n t[0] = 0;\n }\n let data = {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n scale: 1,\n opacity: 1\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 }\n // set translate\n t.forEach((value, index) => {\n t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n });\n // set rotates\n r.forEach((value, index) => {\n r[index] = data.rotate[index] * Math.abs(progress * multiplier);\n });\n slideEl.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}`;\n\n // Set shadows\n if (custom && data.shadow || !custom) {\n let shadowEl = slideEl.querySelector('.swiper-slide-shadow');\n if (!shadowEl && data.shadow) {\n shadowEl = createShadow(params, slideEl);\n }\n if (shadowEl) {\n const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n shadowEl.style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n }\n }\n const targetEl = effectTarget(params, slideEl);\n targetEl.style.transform = transform;\n targetEl.style.opacity = opacityString;\n if (data.origin) {\n targetEl.style.transformOrigin = data.origin;\n }\n }\n };\n const setTransition = duration => {\n const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n transformElements.forEach(el => {\n el.style.transitionDuration = `${duration}ms`;\n el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {\n shadowEl.style.transitionDuration = `${duration}ms`;\n });\n });\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformElements,\n allSlides: true\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';\nimport { getSlideTransformEl } from '../../shared/utils.js';\nexport default function EffectCards({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cardsEffect: {\n slideShadows: true,\n rotate: true,\n perSlideRotate: 2,\n perSlideOffset: 8\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 for (let i = 0; i < slides.length; i += 1) {\n const slideEl = slides[i];\n const slideProgress = slideEl.progress;\n const progress = Math.min(Math.max(slideProgress, -4), 4);\n let offset = slideEl.swiperSlideOffset;\n if (swiper.params.centeredSlides && !swiper.params.cssMode) {\n swiper.wrapperEl.style.transform = `translateX(${swiper.minTranslate()}px)`;\n }\n if (swiper.params.centeredSlides && swiper.params.cssMode) {\n offset -= slides[0].swiperSlideOffset;\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 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 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 if (!swiper.isHorizontal()) {\n const prevY = tY;\n tY = tX;\n tX = prevY;\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 if (params.slideShadows) {\n // Set shadows\n let shadowEl = slideEl.querySelector('.swiper-slide-shadow');\n if (!shadowEl) {\n shadowEl = createShadow(params, slideEl);\n }\n if (shadowEl) shadowEl.style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n }\n slideEl.style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const targetEl = effectTarget(params, slideEl);\n targetEl.style.transform = transform;\n }\n };\n const setTransition = duration => {\n const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n transformElements.forEach(el => {\n el.style.transitionDuration = `${duration}ms`;\n el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {\n shadowEl.style.transitionDuration = `${duration}ms`;\n });\n });\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformElements\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 9.3.0\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: May 8, 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 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';","function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\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}\nfunction needsNavigation(params = {}) {\n return params.navigation && typeof params.navigation.nextEl === 'undefined' && typeof params.navigation.prevEl === 'undefined';\n}\nfunction needsPagination(params = {}) {\n return params.pagination && typeof params.pagination.el === 'undefined';\n}\nfunction needsScrollbar(params = {}) {\n return params.scrollbar && typeof params.scrollbar.el === 'undefined';\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}\nfunction attrToProp(attrName = '') {\n return attrName.replace(/-[a-z]/g, l => l.toUpperCase().replace('-', ''));\n}\nfunction wrapperClass(className = '') {\n if (!className) return 'swiper-wrapper';\n if (!className.includes('swiper-wrapper')) return `swiper-wrapper ${className}`;\n return className;\n}\nexport { isObject, extend, needsNavigation, needsPagination, needsScrollbar, uniqueClasses, attrToProp, wrapperClass };","/* underscore in name -> watch for changes */\nconst paramsList = ['eventsPrefix', 'injectStyles', 'injectStylesUrls', 'modules', 'init', '_direction', 'oneWayMovement', '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', '_loop', 'loopedSlides', 'loopPreventsSliding', '_rewind', '_allowSlidePrev', '_allowSlideNext', '_swipeHandler', '_noSwiping', 'noSwipingClass', 'noSwipingSelector', 'passiveListeners', 'containerModifierClass', 'slideClass', 'slideActiveClass', 'slideVisibleClass', 'slideNextClass', 'slidePrevClass', 'wrapperClass', 'lazyPreloaderClass', 'lazyPreloadPrevNext', 'runCallbacksOnInit', 'observer', 'observeParents', 'observeSlideChildren',\n// modules\n'a11y', '_autoplay', '_controller', 'coverflowEffect', 'cubeEffect', 'fadeEffect', 'flipEffect', 'creativeEffect', 'cardsEffect', 'hashNavigation', 'history', 'keyboard', 'mousewheel', '_navigation', '_pagination', 'parallax', '_scrollbar', '_thumbs', 'virtual', 'zoom', 'control'];\nexport { paramsList };","import Swiper from 'swiper';\nimport { isObject, extend } from './utils.js';\nimport { paramsList } from './params-list.js';\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 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}\nexport { getParams };","import { needsNavigation, needsPagination, needsScrollbar } from './utils.js';\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 if (needsPagination(swiperParams) && paginationEl) {\n swiper.params.pagination.el = paginationEl;\n swiper.originalParams.pagination.el = paginationEl;\n }\n if (needsScrollbar(swiperParams) && scrollbarEl) {\n swiper.params.scrollbar.el = scrollbarEl;\n swiper.originalParams.scrollbar.el = scrollbarEl;\n }\n swiper.init(el);\n}\nexport { mountSwiper };","import { paramsList } from './params-list.js';\nimport { isObject } from './utils.js';\nfunction getChangedParams(swiperParams, oldParams, children, oldChildren, getKey) {\n const keys = [];\n if (!oldParams) return keys;\n const addKey = key => {\n if (keys.indexOf(key) < 0) keys.push(key);\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 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 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}\nexport { getChangedParams };","import React from 'react';\nfunction isChildSwiperSlide(child) {\n return child.type && child.type.displayName && child.type.displayName.includes('SwiperSlide');\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}\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 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}\nexport { getChildren };","import { isObject, extend } from './utils.js';\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' && key !== 'wrapperClass');\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 let loopNeedDestroy;\n let loopNeedEnable;\n let loopNeedReloop;\n if (changedParams.includes('thumbs') && passedParams.thumbs && passedParams.thumbs.swiper && currentParams.thumbs && !currentParams.thumbs.swiper) {\n needThumbsInit = true;\n }\n if (changedParams.includes('controller') && passedParams.controller && passedParams.controller.control && currentParams.controller && !currentParams.controller.control) {\n needControllerInit = true;\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 if (changedParams.includes('scrollbar') && passedParams.scrollbar && (passedParams.scrollbar.el || scrollbarEl) && (currentParams.scrollbar || currentParams.scrollbar === false) && scrollbar && !scrollbar.el) {\n needScrollbarInit = true;\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 const destroyModule = mod => {\n if (!swiper[mod]) return;\n swiper[mod].destroy();\n if (mod === 'navigation') {\n if (swiper.isElement) {\n swiper[mod].prevEl.remove();\n swiper[mod].nextEl.remove();\n }\n currentParams[mod].prevEl = undefined;\n currentParams[mod].nextEl = undefined;\n swiper[mod].prevEl = undefined;\n swiper[mod].nextEl = undefined;\n } else {\n if (swiper.isElement) {\n swiper[mod].el.remove();\n }\n currentParams[mod].el = undefined;\n swiper[mod].el = undefined;\n }\n };\n if (changedParams.includes('loop') && swiper.isElement) {\n if (currentParams.loop && !passedParams.loop) {\n loopNeedDestroy = true;\n } else if (!currentParams.loop && passedParams.loop) {\n loopNeedEnable = true;\n } else {\n loopNeedReloop = true;\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 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 if (updateParams.includes('controller') && !needControllerInit && swiper.controller && swiper.controller.control && currentParams.controller && currentParams.controller.control) {\n swiper.controller.control = currentParams.controller.control;\n }\n if (changedParams.includes('children') && slides && virtual && currentParams.virtual.enabled) {\n virtual.slides = slides;\n virtual.update(true);\n }\n if (changedParams.includes('children') && slides && currentParams.loop) {\n loopNeedReloop = true;\n }\n if (needThumbsInit) {\n const initialized = thumbs.init();\n if (initialized) thumbs.update(true);\n }\n if (needControllerInit) {\n swiper.controller.control = currentParams.controller.control;\n }\n if (needPaginationInit) {\n if (swiper.isElement && (!paginationEl || typeof paginationEl === 'string')) {\n paginationEl = document.createElement('div');\n paginationEl.classList.add('swiper-pagination');\n swiper.el.shadowEl.appendChild(paginationEl);\n }\n if (paginationEl) currentParams.pagination.el = paginationEl;\n pagination.init();\n pagination.render();\n pagination.update();\n }\n if (needScrollbarInit) {\n if (swiper.isElement && (!scrollbarEl || typeof scrollbarEl === 'string')) {\n scrollbarEl = document.createElement('div');\n scrollbarEl.classList.add('swiper-scrollbar');\n swiper.el.shadowEl.appendChild(scrollbarEl);\n }\n if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;\n scrollbar.init();\n scrollbar.updateSize();\n scrollbar.setTranslate();\n }\n if (needNavigationInit) {\n if (swiper.isElement) {\n if (!nextEl || typeof nextEl === 'string') {\n nextEl = document.createElement('div');\n nextEl.classList.add('swiper-button-next');\n swiper.el.shadowEl.appendChild(nextEl);\n }\n if (!prevEl || typeof prevEl === 'string') {\n prevEl = document.createElement('div');\n prevEl.classList.add('swiper-button-prev');\n swiper.el.shadowEl.appendChild(prevEl);\n }\n }\n if (nextEl) currentParams.navigation.nextEl = nextEl;\n if (prevEl) currentParams.navigation.prevEl = prevEl;\n navigation.init();\n navigation.update();\n }\n if (changedParams.includes('allowSlideNext')) {\n swiper.allowSlideNext = passedParams.allowSlideNext;\n }\n if (changedParams.includes('allowSlidePrev')) {\n swiper.allowSlidePrev = passedParams.allowSlidePrev;\n }\n if (changedParams.includes('direction')) {\n swiper.changeDirection(passedParams.direction, false);\n }\n if (loopNeedDestroy || loopNeedReloop) {\n swiper.loopDestroy();\n }\n if (loopNeedEnable || loopNeedReloop) {\n swiper.loopCreate();\n }\n swiper.update();\n}\nexport { updateSwiper };","import React from 'react';\nfunction renderVirtual(swiper, slides, virtualData) {\n if (!virtualData) return null;\n const getSlideIndex = index => {\n let slideIndex = index;\n if (index < 0) {\n slideIndex = slides.length + index;\n } else if (slideIndex >= slides.length) {\n // eslint-disable-next-line\n slideIndex = slideIndex - slides.length;\n }\n return slideIndex;\n };\n const style = swiper.isHorizontal() ? {\n [swiper.rtlTranslate ? 'right' : 'left']: `${virtualData.offset}px`\n } : {\n top: `${virtualData.offset}px`\n };\n const {\n from,\n to\n } = virtualData;\n const loopFrom = swiper.params.loop ? -slides.length : 0;\n const loopTo = swiper.params.loop ? slides.length * 2 : slides.length;\n const slidesToRender = [];\n for (let i = loopFrom; i < loopTo; i += 1) {\n if (i >= from && i <= to) {\n slidesToRender.push(slides[getSlideIndex(i)]);\n }\n }\n return slidesToRender.map((child, index) => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n style,\n key: `slide-${index}`\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 if (swiper.parallax && swiper.params.parallax && swiper.params.parallax.enabled) {\n swiper.parallax.setTranslate();\n }\n};","import { useEffect, useLayoutEffect } from 'react';\nfunction useIsomorphicLayoutEffect(callback, deps) {\n // eslint-disable-next-line\n if (typeof window === 'undefined') return useEffect(callback, deps);\n return useLayoutEffect(callback, deps);\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); }\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, wrapperClass } from '../components-shared/utils.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 const onBeforeBreakpoint = () => {\n setBreakpointChanged(!breakpointChanged);\n };\n Object.assign(swiperParams.on, {\n _containerClasses(swiper, classes) {\n setContainerClasses(classes);\n }\n });\n const initSwiper = () => {\n // init swiper\n Object.assign(swiperParams.on, events);\n eventsAssigned = true;\n const passParams = {\n ...swiperParams\n };\n delete passParams.wrapperClass;\n swiperRef.current = new SwiperCore(passParams);\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 if (!swiperElRef.current) {\n initSwiper();\n }\n\n // Listen for breakpoints change\n if (swiperRef.current) {\n swiperRef.current.on('_beforeBreakpoint', onBeforeBreakpoint);\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 const detachEvents = () => {\n if (!events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.off(eventName, events[eventName]);\n });\n };\n useEffect(() => {\n return () => {\n if (swiperRef.current) swiperRef.current.off('_beforeBreakpoint', onBeforeBreakpoint);\n };\n });\n\n // set initialized flag\n useEffect(() => {\n if (!initializedRef.current && swiperRef.current) {\n swiperRef.current.emitSlidesClasses();\n initializedRef.current = true;\n }\n });\n\n // mount swiper\n useIsomorphicLayoutEffect(() => {\n if (externalElRef) {\n externalElRef.current = swiperElRef.current;\n }\n if (!swiperElRef.current) return;\n if (swiperRef.current.destroyed) {\n initSwiper();\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);\n // eslint-disable-next-line\n return () => {\n if (swiperRef.current && !swiperRef.current.destroyed) {\n swiperRef.current.destroy(true, false);\n }\n };\n }, []);\n\n // watch for params change\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 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 return () => {\n detachEvents();\n };\n });\n\n // update on virtual update\n useIsomorphicLayoutEffect(() => {\n updateOnVirtualData(swiperRef.current);\n }, [virtualData]);\n\n // bypass swiper instance to slides\n function renderSlides() {\n if (swiperParams.virtual) {\n return renderVirtual(swiperRef.current, slides, virtualData);\n }\n return slides.map((child, index) => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper: swiperRef.current,\n swiperSlideIndex: index\n });\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: wrapperClass(swiperParams.wrapperClass)\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); }\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 lazy,\n virtualIndex,\n swiperSlideIndex,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n const slideElRef = useRef(null);\n const [slideClasses, setSlideClasses] = useState('swiper-slide');\n const [lazyLoaded, setLazyLoaded] = useState(false);\n function updateClasses(_s, el, classNames) {\n if (el === slideElRef.current) {\n setSlideClasses(classNames);\n }\n }\n useIsomorphicLayoutEffect(() => {\n if (typeof swiperSlideIndex !== 'undefined') {\n slideElRef.current.swiperSlideIndex = swiperSlideIndex;\n }\n if (externalRef) {\n externalRef.current = slideElRef.current;\n }\n if (!slideElRef.current || !swiper) {\n return;\n }\n if (swiper.destroyed) {\n if (slideClasses !== 'swiper-slide') {\n setSlideClasses('swiper-slide');\n }\n return;\n }\n swiper.on('_slideClass', updateClasses);\n // eslint-disable-next-line\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,\n isVisible: slideClasses.indexOf('swiper-slide-visible') >= 0,\n isPrev: slideClasses.indexOf('swiper-slide-prev') >= 0,\n isNext: slideClasses.indexOf('swiper-slide-next') >= 0\n };\n const renderChildren = () => {\n return typeof children === 'function' ? children(slideData) : children;\n };\n const onLoad = () => {\n setLazyLoaded(true);\n };\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: slideElRef,\n className: uniqueClasses(`${slideClasses}${className ? ` ${className}` : ''}`),\n \"data-swiper-slide-index\": virtualIndex,\n onLoad: onLoad\n }, rest), zoom && /*#__PURE__*/React.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-zoom-container\",\n \"data-swiper-zoom\": typeof zoom === 'number' ? zoom : undefined\n }, renderChildren(), lazy && !lazyLoaded && /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-lazy-preloader\"\n }))), !zoom && /*#__PURE__*/React.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, renderChildren(), lazy && !lazyLoaded && /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-lazy-preloader\"\n })));\n});\nSwiperSlide.displayName = 'SwiperSlide';\nexport { SwiperSlide };","/**\n * Swiper React 9.3.0\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: May 8, 2023\n */\n\nimport { Swiper } from './swiper.js';\nimport { SwiperSlide } from './swiper-slide.js';\nexport { useSwiperSlide, useSwiper } from './context.js';\nexport { Swiper, SwiperSlide };"],"names":["support","deviceCached","browser","ssr_window_esm_isObject","obj","constructor","Object","extend","target","src","keys","forEach","key","length","ssrDocument","body","addEventListener","removeEventListener","activeElement","blur","nodeName","querySelector","querySelectorAll","getElementById","createEvent","initEvent","createElement","children","childNodes","style","setAttribute","getElementsByTagName","createElementNS","importNode","location","hash","host","hostname","href","origin","pathname","protocol","search","ssr_window_esm_getDocument","doc","document","ssrWindow","navigator","userAgent","history","replaceState","pushState","go","back","CustomEvent","getComputedStyle","getPropertyValue","Image","Date","screen","setTimeout","clearTimeout","matchMedia","requestAnimationFrame","callback","cancelAnimationFrame","id","ssr_window_esm_getWindow","win","window","utils_nextTick","delay","utils_now","now","utils_isObject","o","prototype","toString","call","slice","utils_extend","args","to","noExtend","i","nextSource","HTMLElement","node","nodeType","keysArray","filter","indexOf","nextIndex","len","nextKey","desc","getOwnPropertyDescriptor","undefined","enumerable","__swiper__","utils_setCSSProperty","el","varName","varValue","setProperty","animateCSSModeScroll","swiper","targetPosition","side","time","startPosition","translate","startTime","duration","params","speed","wrapperEl","scrollSnapType","cssModeFrameID","dir","isOutOfBound","current","animate","getTime","progress","Math","max","min","currentPosition","easeProgress","cos","PI","scrollTo","overflow","utils_elementChildren","element","selector","matches","elementStyle","prop","utils_elementIndex","child","previousSibling","utils_elementOuterSize","size","includeMargins","parseFloat","offsetWidth","getSupport","calcSupport","smoothScroll","documentElement","touch","DocumentTouch","processLazyPreloader","imageEl","destroyed","slideEl","closest","isElement","slideClass","lazyEl","lazyPreloaderClass","remove","unlazy","index","slides","removeAttribute","preload","amount","lazyPreloadPrevNext","slidesPerView","slidesPerViewDynamic","ceil","activeIndex","slideIndexLastInView","rewind","realIndex","transitionEmit","runCallbacks","direction","step","previousIndex","emit","onTouchStart","event","data","touchEventsData","evCache","push","touches","enabled","simulateTouch","pointerType","animating","preventInteractionOnTransition","cssMode","loop","loopFix","e","originalEvent","targetEl","touchEventsTarget","contains","which","button","isTouched","isMoved","swipingClassHasValue","noSwipingClass","eventPath","composedPath","path","shadowRoot","noSwipingSelector","isTargetShadow","noSwiping","closestElement","base","__closestFrom","assignedSlot","found","getRootNode","allowClick","swipeHandler","currentX","pageX","currentY","pageY","startX","startY","edgeSwipeDetection","iOSEdgeSwipeDetection","edgeSwipeThreshold","iOSEdgeSwipeThreshold","innerWidth","preventDefault","assign","allowTouchCallbacks","isScrolling","startMoving","touchStartTime","updateSize","swipeDirection","threshold","allowThresholdMove","focusableElements","shouldPreventDefault","allowTouchMove","touchStartPreventDefault","touchStartForcePreventDefault","isContentEditable","freeMode","onTouchMove","loopFixed","rtlTranslate","rtl","pointerIndex","findIndex","cachedEv","pointerId","targetTouch","preventedByNestedSwiper","prevX","prevY","touchReleaseOnEdges","isVertical","maxTranslate","minTranslate","targetTouches","diffX","diffY","sqrt","touchAngle","isHorizontal","atan2","abs","zoom","cancelable","touchMoveStopPropagation","nested","stopPropagation","diff","touchesDiff","previousX","previousY","oneWayMovement","touchRatio","prevTouchesDirection","touchesDirection","isLoop","startTranslate","getTranslate","setTransition","evt","bubbles","dispatchEvent","allowMomentumBounce","grabCursor","allowSlideNext","allowSlidePrev","setGrabCursor","setTranslate","currentTranslate","disableParentSwiper","resistanceRatio","centeredSlides","activeSlideIndex","resistance","followFinger","watchSlidesProgress","updateActiveIndex","updateSlidesClasses","updateProgress","onTouchEnd","currentPos","splice","includes","type","proceed","isSafari","isWebView","slidesGrid","touchEndTime","timeDiff","pathTree","updateClickedSlide","lastClickTime","stopIndex","groupSize","slidesSizesGrid","slidesPerGroupSkip","slidesPerGroup","increment","rewindFirstIndex","rewindLastIndex","isBeginning","virtual","isEnd","ratio","longSwipesMs","longSwipes","slideTo","longSwipesRatio","shortSwipes","isNavButtonTarget","navigation","nextEl","prevEl","onResize","breakpoints","setBreakpoint","snapGrid","isVirtual","updateSlides","isVirtualLoop","slideToLoop","autoplay","running","paused","resizeTimeout","resume","watchOverflow","checkOverflow","onClick","preventClicks","preventClicksPropagation","stopImmediatePropagation","onScroll","previousTranslate","scrollLeft","scrollTop","translatesDiff","onLoad","update","dummyEventAttached","dummyEventListener","events","method","device","capture","domMethod","passive","updateOnWindowResize","ios","android","isGridEnabled","grid","rows","defaults","init","initialSlide","resizeObserver","createElements","width","height","url","autoHeight","setWrapperSize","virtualTranslate","effect","breakpointsBase","spaceBetween","slidesPerGroupAuto","centeredSlidesBounds","slidesOffsetBefore","slidesOffsetAfter","normalizeSlideIndex","centerInsufficientSlides","roundLengths","uniqueNavElements","slideToClickedSlide","loopedSlides","loopPreventsSliding","passiveListeners","maxBackfaceHiddenSlides","containerModifierClass","slideActiveClass","slideVisibleClass","slideNextClass","slidePrevClass","wrapperClass","runCallbacksOnInit","_emitClasses","prototypes","eventsEmitter","on","handler","priority","self","eventsListeners","split","once","onceHandler","off","__emitterProxy","apply","onAny","eventsAnyListeners","offAny","eventHandler","context","Array","isArray","unshift","eventsArray","clientWidth","clientHeight","parseInt","Number","isNaN","slideSize","getDirectionLabel","property","getDirectionPropertyValue","label","slidesEl","swiperSize","wrongRTL","previousSlidesLength","slidesLength","offsetBefore","offsetAfter","previousSnapGridLength","previousSlidesGridLength","slidePosition","prevSlideSize","replace","virtualSize","marginLeft","marginRight","marginBottom","marginTop","gridEnabled","initSlides","shouldResetSlideSize","slide","updateSlide","slideStyles","currentTransform","transform","currentWebKitTransform","webkitTransform","paddingLeft","paddingRight","boxSizing","floor","swiperSlideSize","updateWrapperSize","newSlidesGrid","slidesGridItem","groups","slidesBefore","slidesAfter","_","slideIndex","allSlidesSize","slideSizeValue","maxSnap","map","snap","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","v","updateSlidesOffset","backFaceHiddenClass","hasClassBackfaceClassAdded","classList","add","updateAutoHeight","activeSlides","newHeight","getSlideByIndex","getSlideIndexByData","visibleSlides","offsetHeight","minusOffset","offsetLeft","offsetTop","swiperSlideOffset","cssOverflowAdjustment","updateSlidesProgress","offsetCenter","visibleSlidesIndexes","slideOffset","slideProgress","originalSlideProgress","slideBefore","slideAfter","isVisible","originalProgress","multiplier","progressLoop","wasBeginning","wasEnd","isBeginningRounded","isEndRounded","firstSlideIndex","lastSlideIndex","firstSlideTranslate","lastSlideTranslate","translateMax","translateAbs","activeSlide","getFilteredSlide","nextSlide","elementNextAll","nextEls","nextElementSibling","next","prevSlide","elementPrevAll","prevEls","previousElementSibling","prev","emitSlidesClasses","newActiveIndex","previousRealIndex","previousSnapIndex","getVirtualRealIndex","aIndex","getActiveIndexByTranslate","skip","getAttribute","initialized","slideFound","clickedSlide","clickedIndex","axis","utils_getTranslate","matrix","curTransform","transformMatrix","curStyle","utils_getComputedStyle","currentStyle","WebKitCSSMatrix","a","join","MozTransform","OTransform","MsTransform","msTransform","m41","m42","byController","x","y","translateTo","translateBounds","internal","newTranslate","isH","behavior","onTranslateToWrapperTransitionEnd","transition","transitionDuration","transitionStart","transitionEnd","initial","normalizedTranslate","normalizedGrid","normalizedGridNext","t","_immediateVirtual","_cssModeVirtualInitialSet","onSlideToWrapperTransitionEnd","indexAsNumber","newIndex","slideNext","perGroup","_clientLeft","clientLeft","slidePrev","normalize","val","normalizedSnapGrid","prevSnap","prevSnapIndex","prevIndex","lastIndex","slideReset","slideToClosest","currentSnap","nextSnap","slideToIndex","slideSelector","getSlideIndex","loopCreate","slideRealIndex","byMousewheel","prependSlidesIndexes","appendSlidesIndexes","isNext","isPrev","slidesPrepended","slidesAppended","swiperLoopMoveDOM","prepend","append","recalcSlides","currentSlideTranslate","newSlideTranslate","controller","control","loopParams","c","loopDestroy","newSlidesOrder","swiperSlideIndex","moving","isLocked","__preventObserver__","cursor","unsetGrabCursor","attachEvents","bind","detachEvents","breakpoint","getBreakpoint","currentBreakpoint","breakpointOnlyParams","breakpointParams","originalParams","wasMultiRow","isMultiRow","wasEnabled","emitContainerClasses","fill","wasModuleEnabled","isModuleEnabled","disable","enable","directionChanged","needsReLoop","changeDirection","isEnabled","containerEl","currentHeight","innerHeight","points","point","minRatio","substr","value","sort","b","wasLocked","lastSlideRightEdge","classes","addClasses","classNames","suffixes","prepareClasses","entries","prefix","resultClasses","item","removeClasses","extendedDefaults","Swiper","swipers","newParams","getDevice","overrides","calcDevice","platform","ua","screenWidth","screenHeight","match","ipad","ipod","iphone","macos","iPadScreens","os","calcBrowser","needPerspectiveFix","toLowerCase","String","major","minor","num","test","modules","__modules__","allModulesParams","mod","extendParams","moduleParamName","moduleParams","auto","swiperParams","passedParams","eventName","velocity","trunc","clickTimeout","velocities","imagesToLoad","imagesLoaded","setProgress","cls","className","getSlideClasses","updates","view","exact","spv","breakLoop","slideInView","translated","translateValue","complete","newDirection","needUpdate","currentDirection","changeLanguageDirection","mount","mounted","shadowEl","getWrapperSelector","trim","getWrapper","res","utils_createElement","tag","destroy","deleteInstance","cleanStyles","deleteProps","object","extendDefaults","newDefaults","installModule","use","module","m","components_shared_utils_isObject","components_shared_utils_extend","needsNavigation","needsPagination","pagination","needsScrollbar","scrollbar","uniqueClasses","unique","prototypeGroup","protoMethod","observer","animationFrame","resizeHandler","createObserver","ResizeObserver","newWidth","contentBoxSize","contentRect","inlineSize","blockSize","observe","removeObserver","unobserve","orientationChangeHandler","observers","attach","options","ObserverFunc","MutationObserver","WebkitMutationObserver","mutations","observerUpdate","attributes","childList","characterData","observeParents","containerParents","utils_elementParents","parents","parent","parentElement","observeSlideChildren","disconnect","paramsList","isChildSwiperSlide","displayName","updateOnVirtualData","parallax","useIsomorphicLayoutEffect","deps","react","useEffect","useLayoutEffect","SwiperSlideContext","createContext","SwiperContext","useSwiper","useContext","_extends","arguments","source","hasOwnProperty","swiper_Swiper","forwardRef","_temp","externalElRef","Tag","wrapperTag","WrapperTag","onSwiper","rest","eventsAssigned","containerClasses","setContainerClasses","useState","virtualData","setVirtualData","breakpointChanged","setBreakpointChanged","initializedRef","useRef","swiperElRef","swiperRef","oldPassedParamsRef","oldSlides","nextElRef","prevElRef","paginationElRef","scrollbarElRef","restProps","getParams","splitEvents","core","allowedParams","plainObj","slots","getChildren","Children","toArray","props","slot","foundSlides","processChildren","onBeforeBreakpoint","_containerClasses","initSwiper","passParams","extendWith","cache","renderExternal","renderExternalUpdate","mountSwiper","paginationEl","scrollbarEl","changedParams","getChangedParams","oldParams","oldChildren","getKey","addKey","oldChildrenKeys","childrenKeys","watchParams","newKeys","oldKeys","newKey","oldKey","updateSwiper","needThumbsInit","needControllerInit","needPaginationInit","needScrollbarInit","needNavigationInit","loopNeedDestroy","loopNeedEnable","loopNeedReloop","updateParams","currentParams","thumbs","destroyModule","newValue","appendChild","render","ref","Provider","renderVirtual","offset","top","from","loopFrom","loopTo","slidesToRender","cloneElement","Fragment","swiper_slide_extends","SwiperSlide","externalRef","lazy","virtualIndex","slideElRef","slideClasses","setSlideClasses","lazyLoaded","setLazyLoaded","updateClasses","_s","slideData","isActive","renderChildren"],"sourceRoot":""}