{"mappings":"IQCI,ECCA,ECDA,E,S,E,C,C,C,C,C,C,C,E,O,c,C,E,E,C,I,E,I,E,W,C,E,a,C,C,E,C,I,E,W,E,C,E,E,C,E,E,E,iB,A,O,I,A,C,E,S,C,E,G,K,E,O,C,C,E,C,O,C,G,K,E,C,I,E,C,C,E,A,Q,C,C,E,C,I,E,C,G,E,Q,C,C,E,O,C,C,E,C,E,E,I,C,E,O,C,E,E,O,E,E,O,A,C,I,E,A,M,uB,E,I,O,E,I,C,mB,C,C,E,Q,C,S,C,C,C,E,C,C,E,C,C,E,E,iB,C,G,I,E,E,Q,C,E,Q,S,C,C,C,E,E,E,O,C,I,I,G,E,E,O,C,W,I,G,E,E,O,C,c,I,G,E,E,O,C,c,I,G,E,E,O,C,W,I,G,E,E,O,C,O,I,G,E,E,O,C,a,I,G,E,E,O,C,Y,I,G,E,E,O,C,a,I,G,E,E,O,C,K,I,G,E,E,O,C,M,I,G,E,E,O,C,U,I,G,E,E,O,C,gB,I,G,E,E,O,C,a,I,G,E,E,O,C,c,I,G,E,E,O,C,S,I,G,E,E,O,C,S,I,G,E,E,O,C,M,I,G,E,E,O,C,O,I,G,E,E,O,C,S,I,G,E,E,O,C,O,I,G,E,E,O,C,O,I,G,E,E,O,C,K,I,G,E,E,O,C,Q,I,G,E,E,O,C,K,I,G,E,E,O,C,S,I,G,E,E,O,C,U,I,G,E,E,O,C,O,I,G,E,E,O,C,U,I,G,E,E,O,C,O,I,G,E,E,O,C,U,I,G,E,E,O,C,S,I,G,E,E,O,C,U,I,G,E,E,O,C,U,I,G,E,E,O,C,O,I,G,E,E,O,C,W,I,G,E,E,O,C,S,I,GTSH,IAAA,EAAA,EAAA,QAkBD,OAAM,UAAa,MACjB,YAAY,CAAK,CAAE,CACb,AAAiB,UAAjB,OAAO,EACT,KAAK,CAAC,IAEN,KAAK,IAAK,GAAS,EAAE,EACrB,AApBN,SAAsB,CAAG,EACvB,IAAM,EAAQ,EAAI,SAAS,CAC3B,OAAO,cAAc,CAAC,EAAK,YAAa,CACtC,IAAA,IACS,EAGT,IAAI,CAAK,EACP,EAAM,SAAS,CAAG,CACpB,CAEF,EACF,EAQmB,IAAI,EAErB,CAEF,CAEA,SAAS,EAAU,EAAM,EAAE,EACzB,IAAM,EAAM,EAAE,CAQd,OAPA,EAAI,OAAO,CAAC,AAAA,IACN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","sources":["","node_modules/.pnpm/dom7@4.0.6/node_modules/dom7/dom7.esm.js","node_modules/.pnpm/ssr-window@4.0.2/node_modules/ssr-window/ssr-window.esm.js","js/main.ts","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/swiper.esm.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/core.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/dom.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/utils.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/get-support.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/get-device.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/get-browser.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/modules/resize/resize.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/modules/observer/observer.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events-emitter.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateSize.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateSlides.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateAutoHeight.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateSlidesOffset.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateSlidesProgress.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateProgress.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateSlidesClasses.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateActiveIndex.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/update/updateClickedSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/getTranslate.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/setTranslate.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/minTranslate.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/maxTranslate.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/translate/translateTo.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/transition/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/transition/setTransition.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/transition/transitionStart.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/transition/transitionEmit.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/transition/transitionEnd.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideTo.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideToLoop.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideNext.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slidePrev.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideReset.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideToClosest.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/slide/slideToClickedSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/loop/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/loop/loopCreate.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/loop/loopFix.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/loop/loopDestroy.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/grab-cursor/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/grab-cursor/setGrabCursor.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/grab-cursor/unsetGrabCursor.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onTouchStart.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onTouchMove.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onTouchEnd.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onResize.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onClick.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/events/onScroll.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/breakpoints/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/breakpoints/setBreakpoint.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/breakpoints/getBreakpoint.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/classes/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/classes/addClasses.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/classes/removeClasses.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/images/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/images/loadImage.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/images/preloadImages.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/check-overflow/index.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/defaults.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/core/moduleExtendParams.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/virtual/virtual.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/keyboard/keyboard.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/mousewheel/mousewheel.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/navigation/navigation.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/create-element-if-not-defined.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/pagination/pagination.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/classes-to-selector.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/scrollbar/scrollbar.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/parallax/parallax.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/zoom/zoom.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/lazy/lazy.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/controller/controller.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/a11y/a11y.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/history/history.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/hash-navigation/hash-navigation.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/autoplay/autoplay.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/thumbs/thumbs.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/free-mode/free-mode.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/grid/grid.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/manipulation.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/methods/appendSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/methods/prependSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/methods/addSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/methods/removeSlide.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/manipulation/methods/removeAllSlides.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-fade/effect-fade.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/effect-init.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/effect-target.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/effect-virtual-transition-end.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-cube/effect-cube.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-flip/effect-flip.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/shared/create-shadow.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-coverflow/effect-coverflow.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-creative/effect-creative.js","node_modules/.pnpm/swiper@7.4.1/node_modules/swiper/modules/effect-cards/effect-cards.js"],"sourcesContent":["\nfunction $parcel$export(e, n, v, s) {\n Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});\n}\n\n var $parcel$global = globalThis;\n \nvar $parcel$modules = {};\nvar $parcel$inits = {};\n\nvar parcelRequire = $parcel$global[\"parcelRequiredb49\"];\n\nif (parcelRequire == null) {\n parcelRequire = function(id) {\n if (id in $parcel$modules) {\n return $parcel$modules[id].exports;\n }\n if (id in $parcel$inits) {\n var init = $parcel$inits[id];\n delete $parcel$inits[id];\n var module = {id: id, exports: {}};\n $parcel$modules[id] = module;\n init.call(module.exports, module, module.exports);\n return module.exports;\n }\n var err = new Error(\"Cannot find module '\" + id + \"'\");\n err.code = 'MODULE_NOT_FOUND';\n throw err;\n };\n\n parcelRequire.register = function register(id, init) {\n $parcel$inits[id] = init;\n };\n\n $parcel$global[\"parcelRequiredb49\"] = parcelRequire;\n}\n\nvar parcelRegister = parcelRequire.register;\nparcelRegister(\"horZ8\", function(module, exports) {\n\n$parcel$export(module.exports, \"$\", () => $);\n$parcel$export(module.exports, \"addClass\", () => addClass);\n$parcel$export(module.exports, \"removeClass\", () => removeClass);\n$parcel$export(module.exports, \"toggleClass\", () => toggleClass);\n$parcel$export(module.exports, \"hasClass\", () => hasClass);\n$parcel$export(module.exports, \"attr\", () => attr);\n$parcel$export(module.exports, \"removeAttr\", () => removeAttr);\n$parcel$export(module.exports, \"transform\", () => transform);\n$parcel$export(module.exports, \"transition\", () => transition);\n$parcel$export(module.exports, \"on\", () => on);\n$parcel$export(module.exports, \"off\", () => off);\n$parcel$export(module.exports, \"trigger\", () => trigger);\n$parcel$export(module.exports, \"transitionEnd\", () => transitionEnd);\n$parcel$export(module.exports, \"outerWidth\", () => outerWidth);\n$parcel$export(module.exports, \"outerHeight\", () => outerHeight);\n$parcel$export(module.exports, \"offset\", () => offset);\n$parcel$export(module.exports, \"styles\", () => styles);\n$parcel$export(module.exports, \"css\", () => css);\n$parcel$export(module.exports, \"each\", () => each);\n$parcel$export(module.exports, \"filter\", () => filter);\n$parcel$export(module.exports, \"html\", () => html);\n$parcel$export(module.exports, \"text\", () => text);\n$parcel$export(module.exports, \"is\", () => is);\n$parcel$export(module.exports, \"index\", () => index);\n$parcel$export(module.exports, \"eq\", () => eq);\n$parcel$export(module.exports, \"append\", () => append);\n$parcel$export(module.exports, \"prepend\", () => prepend);\n$parcel$export(module.exports, \"next\", () => next);\n$parcel$export(module.exports, \"nextAll\", () => nextAll);\n$parcel$export(module.exports, \"prev\", () => prev);\n$parcel$export(module.exports, \"prevAll\", () => prevAll);\n$parcel$export(module.exports, \"parent\", () => parent);\n$parcel$export(module.exports, \"parents\", () => parents);\n$parcel$export(module.exports, \"closest\", () => closest);\n$parcel$export(module.exports, \"find\", () => find);\n$parcel$export(module.exports, \"children\", () => children);\n$parcel$export(module.exports, \"remove\", () => remove);\n/**\n * Dom7 4.0.6\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2023, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: February 2, 2023\n */ \nvar $101nH = parcelRequire(\"101nH\");\n/* eslint-disable no-proto */ function makeReactive(obj) {\n const proto = obj.__proto__;\n Object.defineProperty(obj, \"__proto__\", {\n get () {\n return proto;\n },\n set (value) {\n proto.__proto__ = value;\n }\n });\n}\nclass Dom7 extends Array {\n constructor(items){\n if (typeof items === \"number\") super(items);\n else {\n super(...items || []);\n makeReactive(this);\n }\n }\n}\nfunction arrayFlat(arr = []) {\n const res = [];\n arr.forEach((el)=>{\n if (Array.isArray(el)) res.push(...arrayFlat(el));\n else res.push(el);\n });\n return res;\n}\nfunction arrayFilter(arr, callback) {\n return Array.prototype.filter.call(arr, callback);\n}\nfunction arrayUnique(arr) {\n const uniqueArray = [];\n for(let i = 0; i < arr.length; i += 1)if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);\n return uniqueArray;\n}\nfunction toCamelCase(string) {\n return string.toLowerCase().replace(/-(.)/g, (match, group)=>group.toUpperCase());\n}\n// eslint-disable-next-line\nfunction qsa(selector, context) {\n if (typeof selector !== \"string\") return [\n selector\n ];\n const a = [];\n const res = context.querySelectorAll(selector);\n for(let i = 0; i < res.length; i += 1)a.push(res[i]);\n return a;\n}\nfunction $(selector, context) {\n const window = (0, $101nH.getWindow)();\n const document = (0, $101nH.getDocument)();\n let arr = [];\n if (!context && selector instanceof Dom7) return selector;\n if (!selector) return new Dom7(arr);\n if (typeof selector === \"string\") {\n const html = selector.trim();\n if (html.indexOf(\"<\") >= 0 && html.indexOf(\">\") >= 0) {\n let toCreate = \"div\";\n if (html.indexOf(\"c.split(\" \")));\n this.forEach((el)=>{\n el.classList.add(...classNames);\n });\n return this;\n}\nfunction removeClass(...classes) {\n const classNames = arrayFlat(classes.map((c)=>c.split(\" \")));\n this.forEach((el)=>{\n el.classList.remove(...classNames);\n });\n return this;\n}\nfunction toggleClass(...classes) {\n const classNames = arrayFlat(classes.map((c)=>c.split(\" \")));\n this.forEach((el)=>{\n classNames.forEach((className)=>{\n el.classList.toggle(className);\n });\n });\n}\nfunction hasClass(...classes) {\n const classNames = arrayFlat(classes.map((c)=>c.split(\" \")));\n return arrayFilter(this, (el)=>{\n return classNames.filter((className)=>el.classList.contains(className)).length > 0;\n }).length > 0;\n}\nfunction attr(attrs, value) {\n if (arguments.length === 1 && typeof attrs === \"string\") {\n // Get attr\n if (this[0]) return this[0].getAttribute(attrs);\n return undefined;\n } // Set attrs\n for(let i = 0; i < this.length; i += 1){\n if (arguments.length === 2) // String\n this[i].setAttribute(attrs, value);\n else // Object\n for(const attrName in attrs){\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n return this;\n}\nfunction removeAttr(attr) {\n for(let i = 0; i < this.length; i += 1)this[i].removeAttribute(attr);\n return this;\n}\nfunction prop(props, value) {\n if (arguments.length === 1 && typeof props === \"string\") {\n // Get prop\n if (this[0]) return this[0][props];\n } else {\n // Set props\n for(let i = 0; i < this.length; i += 1){\n if (arguments.length === 2) // String\n this[i][props] = value;\n else // Object\n for(const propName in props)this[i][propName] = props[propName];\n }\n return this;\n }\n return this;\n}\nfunction data(key, value) {\n let el;\n if (typeof value === \"undefined\") {\n el = this[0];\n if (!el) return undefined; // Get value\n if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) return el.dom7ElementDataStorage[key];\n const dataKey = el.getAttribute(`data-${key}`);\n if (dataKey) return dataKey;\n return undefined;\n } // Set value\n for(let i = 0; i < this.length; i += 1){\n el = this[i];\n if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};\n el.dom7ElementDataStorage[key] = value;\n }\n return this;\n}\nfunction removeData(key) {\n for(let i = 0; i < this.length; i += 1){\n const el = this[i];\n if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {\n el.dom7ElementDataStorage[key] = null;\n delete el.dom7ElementDataStorage[key];\n }\n }\n}\nfunction dataset() {\n const el = this[0];\n if (!el) return undefined;\n const dataset = {}; // eslint-disable-line\n if (el.dataset) for(const dataKey in el.dataset)dataset[dataKey] = el.dataset[dataKey];\n else for(let i = 0; i < el.attributes.length; i += 1){\n const attr = el.attributes[i];\n if (attr.name.indexOf(\"data-\") >= 0) dataset[toCamelCase(attr.name.split(\"data-\")[1])] = attr.value;\n }\n for(const key in dataset){\n if (dataset[key] === \"false\") dataset[key] = false;\n else if (dataset[key] === \"true\") dataset[key] = true;\n else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;\n }\n return dataset;\n}\nfunction val(value) {\n if (typeof value === \"undefined\") {\n // get value\n const el = this[0];\n if (!el) return undefined;\n if (el.multiple && el.nodeName.toLowerCase() === \"select\") {\n const values = [];\n for(let i = 0; i < el.selectedOptions.length; i += 1)values.push(el.selectedOptions[i].value);\n return values;\n }\n return el.value;\n } // set value\n for(let i = 0; i < this.length; i += 1){\n const el = this[i];\n if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === \"select\") for(let j = 0; j < el.options.length; j += 1)el.options[j].selected = value.indexOf(el.options[j].value) >= 0;\n else el.value = value;\n }\n return this;\n}\nfunction value(value) {\n return this.val(value);\n}\nfunction transform(transform) {\n for(let i = 0; i < this.length; i += 1)this[i].style.transform = transform;\n return this;\n}\nfunction transition(duration) {\n for(let i = 0; i < this.length; i += 1)this[i].style.transitionDuration = typeof duration !== \"string\" ? `${duration}ms` : duration;\n return this;\n}\nfunction on(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n if (typeof args[1] === \"function\") {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n if (!capture) capture = false;\n function handleLiveEvent(e) {\n const target = e.target;\n if (!target) return;\n const eventData = e.target.dom7EventData || [];\n if (eventData.indexOf(e) < 0) eventData.unshift(e);\n if ($(target).is(targetSelector)) listener.apply(target, eventData);\n else {\n const parents = $(target).parents(); // eslint-disable-line\n for(let k = 0; k < parents.length; k += 1)if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);\n }\n }\n function handleEvent(e) {\n const eventData = e && e.target ? e.target.dom7EventData || [] : [];\n if (eventData.indexOf(e) < 0) eventData.unshift(e);\n listener.apply(this, eventData);\n }\n const events = eventType.split(\" \");\n let j;\n for(let i = 0; i < this.length; i += 1){\n const el = this[i];\n if (!targetSelector) for(j = 0; j < events.length; j += 1){\n const event = events[j];\n if (!el.dom7Listeners) el.dom7Listeners = {};\n if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];\n el.dom7Listeners[event].push({\n listener: listener,\n proxyListener: handleEvent\n });\n el.addEventListener(event, handleEvent, capture);\n }\n else // Live events\n for(j = 0; j < events.length; j += 1){\n const event = events[j];\n if (!el.dom7LiveListeners) el.dom7LiveListeners = {};\n if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];\n el.dom7LiveListeners[event].push({\n listener: listener,\n proxyListener: handleLiveEvent\n });\n el.addEventListener(event, handleLiveEvent, capture);\n }\n }\n return this;\n}\nfunction off(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n if (typeof args[1] === \"function\") {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n if (!capture) capture = false;\n const events = eventType.split(\" \");\n for(let i = 0; i < events.length; i += 1){\n const event = events[i];\n for(let j = 0; j < this.length; j += 1){\n const el = this[j];\n let handlers;\n if (!targetSelector && el.dom7Listeners) handlers = el.dom7Listeners[event];\n else if (targetSelector && el.dom7LiveListeners) handlers = el.dom7LiveListeners[event];\n if (handlers && handlers.length) for(let k = handlers.length - 1; k >= 0; k -= 1){\n const handler = handlers[k];\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n return this;\n}\nfunction once(...args) {\n const dom = this;\n let [eventName, targetSelector, listener, capture] = args;\n if (typeof args[1] === \"function\") {\n [eventName, listener, capture] = args;\n targetSelector = undefined;\n }\n function onceHandler(...eventArgs) {\n listener.apply(this, eventArgs);\n dom.off(eventName, targetSelector, onceHandler, capture);\n if (onceHandler.dom7proxy) delete onceHandler.dom7proxy;\n }\n onceHandler.dom7proxy = listener;\n return dom.on(eventName, targetSelector, onceHandler, capture);\n}\nfunction trigger(...args) {\n const window = (0, $101nH.getWindow)();\n const events = args[0].split(\" \");\n const eventData = args[1];\n for(let i = 0; i < events.length; i += 1){\n const event = events[i];\n for(let j = 0; j < this.length; j += 1){\n const el = this[j];\n if (window.CustomEvent) {\n const evt = new window.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true\n });\n el.dom7EventData = args.filter((data, dataIndex)=>dataIndex > 0);\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n }\n return this;\n}\nfunction transitionStart(callback) {\n const dom = this;\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off(\"transitionstart\", fireCallBack);\n }\n if (callback) dom.on(\"transitionstart\", fireCallBack);\n return this;\n}\nfunction transitionEnd(callback) {\n const dom = this;\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off(\"transitionend\", fireCallBack);\n }\n if (callback) dom.on(\"transitionend\", fireCallBack);\n return this;\n}\nfunction animationEnd(callback) {\n const dom = this;\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off(\"animationend\", fireCallBack);\n }\n if (callback) dom.on(\"animationend\", fireCallBack);\n return this;\n}\nfunction width() {\n const window = (0, $101nH.getWindow)();\n if (this[0] === window) return window.innerWidth;\n if (this.length > 0) return parseFloat(this.css(\"width\"));\n return null;\n}\nfunction outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue(\"margin-right\")) + parseFloat(styles.getPropertyValue(\"margin-left\"));\n }\n return this[0].offsetWidth;\n }\n return null;\n}\nfunction height() {\n const window = (0, $101nH.getWindow)();\n if (this[0] === window) return window.innerHeight;\n if (this.length > 0) return parseFloat(this.css(\"height\"));\n return null;\n}\nfunction outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue(\"margin-top\")) + parseFloat(styles.getPropertyValue(\"margin-bottom\"));\n }\n return this[0].offsetHeight;\n }\n return null;\n}\nfunction offset() {\n if (this.length > 0) {\n const window = (0, $101nH.getWindow)();\n const document = (0, $101nH.getDocument)();\n const el = this[0];\n const box = el.getBoundingClientRect();\n const body = document.body;\n const clientTop = el.clientTop || body.clientTop || 0;\n const clientLeft = el.clientLeft || body.clientLeft || 0;\n const scrollTop = el === window ? window.scrollY : el.scrollTop;\n const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n return {\n top: box.top + scrollTop - clientTop,\n left: box.left + scrollLeft - clientLeft\n };\n }\n return null;\n}\nfunction hide() {\n for(let i = 0; i < this.length; i += 1)this[i].style.display = \"none\";\n return this;\n}\nfunction show() {\n const window = (0, $101nH.getWindow)();\n for(let i = 0; i < this.length; i += 1){\n const el = this[i];\n if (el.style.display === \"none\") el.style.display = \"\";\n if (window.getComputedStyle(el, null).getPropertyValue(\"display\") === \"none\") // Still not visible\n el.style.display = \"block\";\n }\n return this;\n}\nfunction styles() {\n const window = (0, $101nH.getWindow)();\n if (this[0]) return window.getComputedStyle(this[0], null);\n return {};\n}\nfunction css(props, value) {\n const window = (0, $101nH.getWindow)();\n let i;\n if (arguments.length === 1) {\n if (typeof props === \"string\") {\n // .css('width')\n if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);\n } else {\n // .css({ width: '100px' })\n for(i = 0; i < this.length; i += 1)for(const prop in props)this[i].style[prop] = props[prop];\n return this;\n }\n }\n if (arguments.length === 2 && typeof props === \"string\") {\n // .css('width', '100px')\n for(i = 0; i < this.length; i += 1)this[i].style[props] = value;\n return this;\n }\n return this;\n}\nfunction each(callback) {\n if (!callback) return this;\n this.forEach((el, index)=>{\n callback.apply(el, [\n el,\n index\n ]);\n });\n return this;\n}\nfunction filter(callback) {\n const result = arrayFilter(this, callback);\n return $(result);\n}\nfunction html(html) {\n if (typeof html === \"undefined\") return this[0] ? this[0].innerHTML : null;\n for(let i = 0; i < this.length; i += 1)this[i].innerHTML = html;\n return this;\n}\nfunction text(text) {\n if (typeof text === \"undefined\") return this[0] ? this[0].textContent.trim() : null;\n for(let i = 0; i < this.length; i += 1)this[i].textContent = text;\n return this;\n}\nfunction is(selector) {\n const window = (0, $101nH.getWindow)();\n const document = (0, $101nH.getDocument)();\n const el = this[0];\n let compareWith;\n let i;\n if (!el || typeof selector === \"undefined\") return false;\n if (typeof selector === \"string\") {\n if (el.matches) return el.matches(selector);\n if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);\n if (el.msMatchesSelector) return el.msMatchesSelector(selector);\n compareWith = $(selector);\n for(i = 0; i < compareWith.length; i += 1){\n if (compareWith[i] === el) return true;\n }\n return false;\n }\n if (selector === document) return el === document;\n if (selector === window) return el === window;\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [\n selector\n ] : selector;\n for(i = 0; i < compareWith.length; i += 1){\n if (compareWith[i] === el) return true;\n }\n return false;\n }\n return false;\n}\nfunction index() {\n let child = this[0];\n let i;\n if (child) {\n i = 0; // eslint-disable-next-line\n while((child = child.previousSibling) !== null)if (child.nodeType === 1) i += 1;\n return i;\n }\n return undefined;\n}\nfunction eq(index) {\n if (typeof index === \"undefined\") return this;\n const length = this.length;\n if (index > length - 1) return $([]);\n if (index < 0) {\n const returnIndex = length + index;\n if (returnIndex < 0) return $([]);\n return $([\n this[returnIndex]\n ]);\n }\n return $([\n this[index]\n ]);\n}\nfunction append(...els) {\n let newChild;\n const document = (0, $101nH.getDocument)();\n for(let k = 0; k < els.length; k += 1){\n newChild = els[k];\n for(let i = 0; i < this.length; i += 1){\n if (typeof newChild === \"string\") {\n const tempDiv = document.createElement(\"div\");\n tempDiv.innerHTML = newChild;\n while(tempDiv.firstChild)this[i].appendChild(tempDiv.firstChild);\n } else if (newChild instanceof Dom7) for(let j = 0; j < newChild.length; j += 1)this[i].appendChild(newChild[j]);\n else this[i].appendChild(newChild);\n }\n }\n return this;\n}\nfunction appendTo(parent) {\n $(parent).append(this);\n return this;\n}\nfunction prepend(newChild) {\n const document = (0, $101nH.getDocument)();\n let i;\n let j;\n for(i = 0; i < this.length; i += 1){\n if (typeof newChild === \"string\") {\n const tempDiv = document.createElement(\"div\");\n tempDiv.innerHTML = newChild;\n for(j = tempDiv.childNodes.length - 1; j >= 0; j -= 1)this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n } else if (newChild instanceof Dom7) for(j = 0; j < newChild.length; j += 1)this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n else this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n return this;\n}\nfunction prependTo(parent) {\n $(parent).prepend(this);\n return this;\n}\nfunction insertBefore(selector) {\n const before = $(selector);\n for(let i = 0; i < this.length; i += 1){\n if (before.length === 1) before[0].parentNode.insertBefore(this[i], before[0]);\n else if (before.length > 1) for(let j = 0; j < before.length; j += 1)before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);\n }\n}\nfunction insertAfter(selector) {\n const after = $(selector);\n for(let i = 0; i < this.length; i += 1){\n if (after.length === 1) after[0].parentNode.insertBefore(this[i], after[0].nextSibling);\n else if (after.length > 1) for(let j = 0; j < after.length; j += 1)after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);\n }\n}\nfunction next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) return $([\n this[0].nextElementSibling\n ]);\n return $([]);\n }\n if (this[0].nextElementSibling) return $([\n this[0].nextElementSibling\n ]);\n return $([]);\n }\n return $([]);\n}\nfunction nextAll(selector) {\n const nextEls = [];\n let el = this[0];\n if (!el) return $([]);\n while(el.nextElementSibling){\n const next = el.nextElementSibling; // eslint-disable-line\n if (selector) {\n if ($(next).is(selector)) nextEls.push(next);\n } else nextEls.push(next);\n el = next;\n }\n return $(nextEls);\n}\nfunction prev(selector) {\n if (this.length > 0) {\n const el = this[0];\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) return $([\n el.previousElementSibling\n ]);\n return $([]);\n }\n if (el.previousElementSibling) return $([\n el.previousElementSibling\n ]);\n return $([]);\n }\n return $([]);\n}\nfunction prevAll(selector) {\n const prevEls = [];\n let el = this[0];\n if (!el) return $([]);\n while(el.previousElementSibling){\n const prev = el.previousElementSibling; // eslint-disable-line\n if (selector) {\n if ($(prev).is(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n el = prev;\n }\n return $(prevEls);\n}\nfunction siblings(selector) {\n return this.nextAll(selector).add(this.prevAll(selector));\n}\nfunction parent(selector) {\n const parents = []; // eslint-disable-line\n for(let i = 0; i < this.length; i += 1)if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n } else parents.push(this[i].parentNode);\n }\n return $(parents);\n}\nfunction parents(selector) {\n const parents = []; // eslint-disable-line\n for(let i = 0; i < this.length; i += 1){\n let parent = this[i].parentNode; // eslint-disable-line\n while(parent){\n if (selector) {\n if ($(parent).is(selector)) parents.push(parent);\n } else parents.push(parent);\n parent = parent.parentNode;\n }\n }\n return $(parents);\n}\nfunction closest(selector) {\n let closest = this; // eslint-disable-line\n if (typeof selector === \"undefined\") return $([]);\n if (!closest.is(selector)) closest = closest.parents(selector).eq(0);\n return closest;\n}\nfunction find(selector) {\n const foundElements = [];\n for(let i = 0; i < this.length; i += 1){\n const found = this[i].querySelectorAll(selector);\n for(let j = 0; j < found.length; j += 1)foundElements.push(found[j]);\n }\n return $(foundElements);\n}\nfunction children(selector) {\n const children = []; // eslint-disable-line\n for(let i = 0; i < this.length; i += 1){\n const childNodes = this[i].children;\n for(let j = 0; j < childNodes.length; j += 1)if (!selector || $(childNodes[j]).is(selector)) children.push(childNodes[j]);\n }\n return $(children);\n}\nfunction remove() {\n for(let i = 0; i < this.length; i += 1)if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);\n return this;\n}\nfunction detach() {\n return this.remove();\n}\nfunction add(...els) {\n const dom = this;\n let i;\n let j;\n for(i = 0; i < els.length; i += 1){\n const toAdd = $(els[i]);\n for(j = 0; j < toAdd.length; j += 1)dom.push(toAdd[j]);\n }\n return dom;\n}\nfunction empty() {\n for(let i = 0; i < this.length; i += 1){\n const el = this[i];\n if (el.nodeType === 1) {\n for(let j = 0; j < el.childNodes.length; j += 1)if (el.childNodes[j].parentNode) el.childNodes[j].parentNode.removeChild(el.childNodes[j]);\n el.textContent = \"\";\n }\n }\n return this;\n}\n// eslint-disable-next-line\nfunction scrollTo(...args) {\n const window = (0, $101nH.getWindow)();\n let [left, top, duration, easing, callback] = args;\n if (args.length === 4 && typeof easing === \"function\") {\n callback = easing;\n [left, top, duration, callback, easing] = args;\n }\n if (typeof easing === \"undefined\") easing = \"swing\";\n return this.each(function animate() {\n const el = this;\n let currentTop;\n let currentLeft;\n let maxTop;\n let maxLeft;\n let newTop;\n let newLeft;\n let scrollTop; // eslint-disable-line\n let scrollLeft; // eslint-disable-line\n let animateTop = top > 0 || top === 0;\n let animateLeft = left > 0 || left === 0;\n if (typeof easing === \"undefined\") easing = \"swing\";\n if (animateTop) {\n currentTop = el.scrollTop;\n if (!duration) el.scrollTop = top;\n }\n if (animateLeft) {\n currentLeft = el.scrollLeft;\n if (!duration) el.scrollLeft = left;\n }\n if (!duration) return;\n if (animateTop) {\n maxTop = el.scrollHeight - el.offsetHeight;\n newTop = Math.max(Math.min(top, maxTop), 0);\n }\n if (animateLeft) {\n maxLeft = el.scrollWidth - el.offsetWidth;\n newLeft = Math.max(Math.min(left, maxLeft), 0);\n }\n let startTime = null;\n if (animateTop && newTop === currentTop) animateTop = false;\n if (animateLeft && newLeft === currentLeft) animateLeft = false;\n function render(time = new Date().getTime()) {\n if (startTime === null) startTime = time;\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = easing === \"linear\" ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;\n let done;\n if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);\n if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);\n if (animateTop && newTop > currentTop && scrollTop >= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n if (animateTop && newTop < currentTop && scrollTop <= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n if (done) {\n if (callback) callback();\n return;\n }\n if (animateTop) el.scrollTop = scrollTop;\n if (animateLeft) el.scrollLeft = scrollLeft;\n window.requestAnimationFrame(render);\n }\n window.requestAnimationFrame(render);\n });\n} // scrollTop(top, duration, easing, callback) {\nfunction scrollTop(...args) {\n let [top, duration, easing, callback] = args;\n if (args.length === 3 && typeof easing === \"function\") [top, duration, callback, easing] = args;\n const dom = this;\n if (typeof top === \"undefined\") {\n if (dom.length > 0) return dom[0].scrollTop;\n return null;\n }\n return dom.scrollTo(undefined, top, duration, easing, callback);\n}\nfunction scrollLeft(...args) {\n let [left, duration, easing, callback] = args;\n if (args.length === 3 && typeof easing === \"function\") [left, duration, callback, easing] = args;\n const dom = this;\n if (typeof left === \"undefined\") {\n if (dom.length > 0) return dom[0].scrollLeft;\n return null;\n }\n return dom.scrollTo(left, undefined, duration, easing, callback);\n}\n// eslint-disable-next-line\nfunction animate(initialProps, initialParams) {\n const window = (0, $101nH.getWindow)();\n const els = this;\n const a = {\n props: Object.assign({}, initialProps),\n params: Object.assign({\n duration: 300,\n easing: \"swing\" // or 'linear'\n }, initialParams),\n elements: els,\n animating: false,\n que: [],\n easingProgress (easing, progress) {\n if (easing === \"swing\") return 0.5 - Math.cos(progress * Math.PI) / 2;\n if (typeof easing === \"function\") return easing(progress);\n return progress;\n },\n stop () {\n if (a.frameId) window.cancelAnimationFrame(a.frameId);\n a.animating = false;\n a.elements.each((el)=>{\n const element = el;\n delete element.dom7AnimateInstance;\n });\n a.que = [];\n },\n done (complete) {\n a.animating = false;\n a.elements.each((el)=>{\n const element = el;\n delete element.dom7AnimateInstance;\n });\n if (complete) complete(els);\n if (a.que.length > 0) {\n const que = a.que.shift();\n a.animate(que[0], que[1]);\n }\n },\n animate (props, params) {\n if (a.animating) {\n a.que.push([\n props,\n params\n ]);\n return a;\n }\n const elements = []; // Define & Cache Initials & Units\n a.elements.each((el, index)=>{\n let initialFullValue;\n let initialValue;\n let unit;\n let finalValue;\n let finalFullValue;\n if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;\n elements[index] = {\n container: el\n };\n Object.keys(props).forEach((prop)=>{\n initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(\",\", \".\");\n initialValue = parseFloat(initialFullValue);\n unit = initialFullValue.replace(initialValue, \"\");\n finalValue = parseFloat(props[prop]);\n finalFullValue = props[prop] + unit;\n elements[index][prop] = {\n initialFullValue: initialFullValue,\n initialValue: initialValue,\n unit: unit,\n finalValue: finalValue,\n finalFullValue: finalFullValue,\n currentValue: initialValue\n };\n });\n });\n let startTime = null;\n let time;\n let elementsDone = 0;\n let propsDone = 0;\n let done;\n let began = false;\n a.animating = true;\n function render() {\n time = new Date().getTime();\n let progress;\n let easeProgress; // let el;\n if (!began) {\n began = true;\n if (params.begin) params.begin(els);\n }\n if (startTime === null) startTime = time;\n if (params.progress) // eslint-disable-next-line\n params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);\n elements.forEach((element)=>{\n const el = element;\n if (done || el.done) return;\n Object.keys(props).forEach((prop)=>{\n if (done || el.done) return;\n progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);\n easeProgress = a.easingProgress(params.easing, progress);\n const { initialValue, finalValue, unit } = el[prop];\n el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);\n const currentValue = el[prop].currentValue;\n if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {\n el.container.style[prop] = finalValue + unit;\n propsDone += 1;\n if (propsDone === Object.keys(props).length) {\n el.done = true;\n elementsDone += 1;\n }\n if (elementsDone === elements.length) done = true;\n }\n if (done) {\n a.done(params.complete);\n return;\n }\n el.container.style[prop] = currentValue + unit;\n });\n });\n if (done) return; // Then call\n a.frameId = window.requestAnimationFrame(render);\n }\n a.frameId = window.requestAnimationFrame(render);\n return a;\n }\n };\n if (a.elements.length === 0) return els;\n let animateInstance;\n for(let i = 0; i < a.elements.length; i += 1)if (a.elements[i].dom7AnimateInstance) animateInstance = a.elements[i].dom7AnimateInstance;\n else a.elements[i].dom7AnimateInstance = a;\n if (!animateInstance) animateInstance = a;\n if (initialProps === \"stop\") animateInstance.stop();\n else animateInstance.animate(a.props, a.params);\n return els;\n}\nfunction stop() {\n const els = this;\n for(let i = 0; i < els.length; i += 1)if (els[i].dom7AnimateInstance) els[i].dom7AnimateInstance.stop();\n}\nconst noTrigger = \"resize scroll\".split(\" \");\nfunction shortcut(name) {\n function eventHandler(...args) {\n if (typeof args[0] === \"undefined\") {\n for(let i = 0; i < this.length; i += 1)if (noTrigger.indexOf(name) < 0) {\n if (name in this[i]) this[i][name]();\n else $(this[i]).trigger(name);\n }\n return this;\n }\n return this.on(name, ...args);\n }\n return eventHandler;\n}\nconst click = shortcut(\"click\");\nconst blur = shortcut(\"blur\");\nconst focus = shortcut(\"focus\");\nconst focusin = shortcut(\"focusin\");\nconst focusout = shortcut(\"focusout\");\nconst keyup = shortcut(\"keyup\");\nconst keydown = shortcut(\"keydown\");\nconst keypress = shortcut(\"keypress\");\nconst submit = shortcut(\"submit\");\nconst change = shortcut(\"change\");\nconst mousedown = shortcut(\"mousedown\");\nconst mousemove = shortcut(\"mousemove\");\nconst mouseup = shortcut(\"mouseup\");\nconst mouseenter = shortcut(\"mouseenter\");\nconst mouseleave = shortcut(\"mouseleave\");\nconst mouseout = shortcut(\"mouseout\");\nconst mouseover = shortcut(\"mouseover\");\nconst touchstart = shortcut(\"touchstart\");\nconst touchend = shortcut(\"touchend\");\nconst touchmove = shortcut(\"touchmove\");\nconst resize = shortcut(\"resize\");\nconst scroll = shortcut(\"scroll\");\nvar $ca9a62d1bf7d9241$export$2e2bcd8739ae039 = $;\n\n});\nparcelRegister(\"101nH\", function(module, exports) {\n\n$parcel$export(module.exports, \"getDocument\", () => $0ba6dcd7640852a2$export$f65ca476c09acec0);\n$parcel$export(module.exports, \"getWindow\", () => $0ba6dcd7640852a2$export$38b2d434cce3ea22);\n/**\n * SSR Window 4.0.2\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2021, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: December 13, 2021\n */ /* eslint-disable no-param-reassign */ function $0ba6dcd7640852a2$var$isObject(obj) {\n return obj !== null && typeof obj === \"object\" && \"constructor\" in obj && obj.constructor === Object;\n}\nfunction $0ba6dcd7640852a2$export$8b58be045bf06082(target = {}, src = {}) {\n Object.keys(src).forEach((key)=>{\n if (typeof target[key] === \"undefined\") target[key] = src[key];\n else if ($0ba6dcd7640852a2$var$isObject(src[key]) && $0ba6dcd7640852a2$var$isObject(target[key]) && Object.keys(src[key]).length > 0) $0ba6dcd7640852a2$export$8b58be045bf06082(target[key], src[key]);\n });\n}\nconst $0ba6dcd7640852a2$export$3fdcb9b4d81368d8 = {\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 $0ba6dcd7640852a2$export$f65ca476c09acec0() {\n const doc = typeof document !== \"undefined\" ? document : {};\n $0ba6dcd7640852a2$export$8b58be045bf06082(doc, $0ba6dcd7640852a2$export$3fdcb9b4d81368d8);\n return doc;\n}\nconst $0ba6dcd7640852a2$export$8582633f185c62bb = {\n document: $0ba6dcd7640852a2$export$3fdcb9b4d81368d8,\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\") return;\n clearTimeout(id);\n }\n};\nfunction $0ba6dcd7640852a2$export$38b2d434cce3ea22() {\n const win = typeof window !== \"undefined\" ? window : {};\n $0ba6dcd7640852a2$export$8b58be045bf06082(win, $0ba6dcd7640852a2$export$8582633f185c62bb);\n return win;\n}\n\n});\n\n\n/**\n * Swiper 7.4.1\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2021 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: December 24, 2021\n */ /* eslint no-param-reassign: \"off\" */ \nvar $101nH = parcelRequire(\"101nH\");\n\nvar $horZ8 = parcelRequire(\"horZ8\");\nconst $5172d1d318d9c216$var$Methods = {\n addClass: $horZ8.addClass,\n removeClass: $horZ8.removeClass,\n hasClass: $horZ8.hasClass,\n toggleClass: $horZ8.toggleClass,\n attr: $horZ8.attr,\n removeAttr: $horZ8.removeAttr,\n transform: $horZ8.transform,\n transition: $horZ8.transition,\n on: $horZ8.on,\n off: $horZ8.off,\n trigger: $horZ8.trigger,\n transitionEnd: $horZ8.transitionEnd,\n outerWidth: $horZ8.outerWidth,\n outerHeight: $horZ8.outerHeight,\n styles: $horZ8.styles,\n offset: $horZ8.offset,\n css: $horZ8.css,\n each: $horZ8.each,\n html: $horZ8.html,\n text: $horZ8.text,\n is: $horZ8.is,\n index: $horZ8.index,\n eq: $horZ8.eq,\n append: $horZ8.append,\n prepend: $horZ8.prepend,\n next: $horZ8.next,\n nextAll: $horZ8.nextAll,\n prev: $horZ8.prev,\n prevAll: $horZ8.prevAll,\n parent: $horZ8.parent,\n parents: $horZ8.parents,\n closest: $horZ8.closest,\n find: $horZ8.find,\n children: $horZ8.children,\n filter: $horZ8.filter,\n remove: $horZ8.remove\n};\nObject.keys($5172d1d318d9c216$var$Methods).forEach((methodName)=>{\n Object.defineProperty((0, $horZ8.$).fn, methodName, {\n value: $5172d1d318d9c216$var$Methods[methodName],\n writable: true\n });\n});\nvar $5172d1d318d9c216$export$2e2bcd8739ae039 = (0, $horZ8.$);\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $3b5ddcf6fe080905$export$8694e5c03a4df8e6(obj) {\n const object = obj;\n Object.keys(object).forEach((key)=>{\n try {\n object[key] = null;\n } catch (e) {}\n try {\n delete object[key];\n } catch (e) {}\n });\n}\nfunction $3b5ddcf6fe080905$export$bdd553fddd433dcb(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\nfunction $3b5ddcf6fe080905$export$461939dd4422153() {\n return Date.now();\n}\nfunction $3b5ddcf6fe080905$export$3735103072e4a80(el) {\n const window1 = (0, $101nH.getWindow)();\n let style;\n if (window1.getComputedStyle) style = window1.getComputedStyle(el, null);\n if (!style && el.currentStyle) style = el.currentStyle;\n if (!style) style = el.style;\n return style;\n}\nfunction $3b5ddcf6fe080905$export$5ec402b7fcf74398(el, axis = \"x\") {\n const window1 = (0, $101nH.getWindow)();\n let matrix;\n let curTransform;\n let transformMatrix;\n const curStyle = $3b5ddcf6fe080905$export$3735103072e4a80(el, null);\n if (window1.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n if (curTransform.split(\",\").length > 6) curTransform = curTransform.split(\", \").map((a)=>a.replace(\",\", \".\")).join(\", \");\n // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n transformMatrix = new window1.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 (window1.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers\n else curTransform = parseFloat(matrix[4]);\n }\n if (axis === \"y\") {\n // Latest Chrome and webkits Fix\n if (window1.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers\n else curTransform = parseFloat(matrix[5]);\n }\n return curTransform || 0;\n}\nfunction $3b5ddcf6fe080905$export$a6cdc56e425d0d0a(o) {\n return typeof o === \"object\" && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === \"Object\";\n}\nfunction $3b5ddcf6fe080905$var$isNode(node) {\n // eslint-disable-next-line\n if (typeof window !== \"undefined\" && typeof window.HTMLElement !== \"undefined\") return node instanceof HTMLElement;\n return node && (node.nodeType === 1 || node.nodeType === 11);\n}\nfunction $3b5ddcf6fe080905$export$8b58be045bf06082(...args) {\n const to = Object(args[0]);\n const noExtend = [\n \"__proto__\",\n \"constructor\",\n \"prototype\"\n ];\n for(let i = 1; i < args.length; i += 1){\n const nextSource = args[i];\n if (nextSource !== undefined && nextSource !== null && !$3b5ddcf6fe080905$var$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 ($3b5ddcf6fe080905$export$a6cdc56e425d0d0a(to[nextKey]) && $3b5ddcf6fe080905$export$a6cdc56e425d0d0a(nextSource[nextKey])) {\n if (nextSource[nextKey].__swiper__) to[nextKey] = nextSource[nextKey];\n else $3b5ddcf6fe080905$export$8b58be045bf06082(to[nextKey], nextSource[nextKey]);\n } else if (!$3b5ddcf6fe080905$export$a6cdc56e425d0d0a(to[nextKey]) && $3b5ddcf6fe080905$export$a6cdc56e425d0d0a(nextSource[nextKey])) {\n to[nextKey] = {};\n if (nextSource[nextKey].__swiper__) to[nextKey] = nextSource[nextKey];\n else $3b5ddcf6fe080905$export$8b58be045bf06082(to[nextKey], nextSource[nextKey]);\n } else to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n return to;\n}\nfunction $3b5ddcf6fe080905$export$a607267f322101fd(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\n}\nfunction $3b5ddcf6fe080905$export$a5dd2b4b1a116d6d({ swiper: swiper, targetPosition: targetPosition, side: side }) {\n const window1 = (0, $101nH.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 window1.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) startTime = time;\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)) currentPosition = targetPosition;\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 window1.cancelAnimationFrame(swiper.cssModeFrameID);\n return;\n }\n swiper.cssModeFrameID = window1.requestAnimationFrame(animate);\n };\n animate();\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nlet $d0e306ed97de446f$var$support;\nfunction $d0e306ed97de446f$var$calcSupport() {\n const window = (0, $101nH.getWindow)();\n const document = (0, $101nH.getDocument)();\n return {\n smoothScroll: document.documentElement && \"scrollBehavior\" in document.documentElement.style,\n touch: !!(\"ontouchstart\" in window || window.DocumentTouch && document instanceof window.DocumentTouch),\n passiveListener: function checkPassiveListener() {\n let supportsPassive = false;\n try {\n const opts = Object.defineProperty({}, \"passive\", {\n // eslint-disable-next-line\n get () {\n supportsPassive = true;\n }\n });\n window.addEventListener(\"testPassiveListener\", null, opts);\n } catch (e) {}\n return supportsPassive;\n }(),\n gestures: function checkGestures() {\n return \"ongesturestart\" in window;\n }()\n };\n}\nfunction $d0e306ed97de446f$export$d61c7b85ff180578() {\n if (!$d0e306ed97de446f$var$support) $d0e306ed97de446f$var$support = $d0e306ed97de446f$var$calcSupport();\n return $d0e306ed97de446f$var$support;\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nlet $ee7403737d46980d$var$deviceCached;\nfunction $ee7403737d46980d$var$calcDevice({ userAgent: userAgent } = {}) {\n const support = (0, $d0e306ed97de446f$export$d61c7b85ff180578)();\n const window = (0, $101nH.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\"; // iPadOs 13 fix\n const iPadScreens = [\n \"1024x1366\",\n \"1366x1024\",\n \"834x1194\",\n \"1194x834\",\n \"834x1112\",\n \"1112x834\",\n \"768x1024\",\n \"1024x768\",\n \"820x1180\",\n \"1180x820\",\n \"810x1080\",\n \"1080x810\"\n ];\n if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n ipad = ua.match(/(Version)\\/([\\d.]+)/);\n if (!ipad) ipad = [\n 0,\n 1,\n \"13_0_0\"\n ];\n macos = false;\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 } // Export object\n return device;\n}\nfunction $ee7403737d46980d$export$30c823bc834d6ab4(overrides = {}) {\n if (!$ee7403737d46980d$var$deviceCached) $ee7403737d46980d$var$deviceCached = $ee7403737d46980d$var$calcDevice(overrides);\n return $ee7403737d46980d$var$deviceCached;\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nlet $2a3bcebc4608246a$var$browser;\nfunction $2a3bcebc4608246a$var$calcBrowser() {\n const window = (0, $101nH.getWindow)();\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 return {\n isSafari: isSafari(),\n isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n };\n}\nfunction $2a3bcebc4608246a$export$89e15fc796a4a429() {\n if (!$2a3bcebc4608246a$var$browser) $2a3bcebc4608246a$var$browser = $2a3bcebc4608246a$var$calcBrowser();\n return $2a3bcebc4608246a$var$browser;\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $bc702361aff2dca8$export$2e2bcd8739ae039({ swiper: swiper, on: on, emit: emit }) {\n const window = (0, $101nH.getWindow)();\n let observer = 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 const { width: width, height: height } = swiper;\n let newWidth = width;\n let newHeight = height;\n entries.forEach(({ contentBoxSize: contentBoxSize, contentRect: contentRect, target: target })=>{\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) resizeHandler();\n });\n observer.observe(swiper.el);\n };\n const removeObserver = ()=>{\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}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $0d0a9e98fa108d39$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n const observers = [];\n const window = (0, $101nH.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 (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) window.requestAnimationFrame(observerUpdate);\n else window.setTimeout(observerUpdate, 0);\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 = swiper.$el.parents();\n for(let i = 0; i < containerParents.length; i += 1)attach(containerParents[i]);\n } // Observe container\n attach(swiper.$el[0], {\n childList: swiper.params.observeSlideChildren\n }); // Observe wrapper\n attach(swiper.$wrapperEl[0], {\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}\n\n\n/* eslint-disable no-underscore-dangle */ var $582816759a7d7191$export$2e2bcd8739ae039 = {\n on (events, handler, priority) {\n const self = this;\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 (typeof handler !== \"function\") return self;\n function onceHandler(...args) {\n self.off(events, onceHandler);\n if (onceHandler.__emitterProxy) delete onceHandler.__emitterProxy;\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 (typeof handler !== \"function\") return self;\n const method = priority ? \"unshift\" : \"push\";\n if (self.eventsAnyListeners.indexOf(handler) < 0) self.eventsAnyListeners[method](handler);\n return self;\n },\n offAny (handler) {\n const self = this;\n if (!self.eventsAnyListeners) return self;\n const index = self.eventsAnyListeners.indexOf(handler);\n if (index >= 0) self.eventsAnyListeners.splice(index, 1);\n return self;\n },\n off (events, handler) {\n const self = this;\n if (!self.eventsListeners) return self;\n events.split(\" \").forEach((event)=>{\n if (typeof handler === \"undefined\") self.eventsListeners[event] = [];\n else if (self.eventsListeners[event]) self.eventsListeners[event].forEach((eventHandler, index)=>{\n if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) self.eventsListeners[event].splice(index, 1);\n });\n });\n return self;\n },\n emit (...args) {\n const self = this;\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) self.eventsAnyListeners.forEach((eventHandler)=>{\n eventHandler.apply(context, [\n event,\n ...data\n ]);\n });\n if (self.eventsListeners && self.eventsListeners[event]) self.eventsListeners[event].forEach((eventHandler)=>{\n eventHandler.apply(context, data);\n });\n });\n return self;\n }\n};\n\n\nfunction $ab0255aa0327cda9$export$2e2bcd8739ae039() {\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) width = swiper.params.width;\n else width = $el[0].clientWidth;\n if (typeof swiper.params.height !== \"undefined\" && swiper.params.height !== null) height = swiper.params.height;\n else height = $el[0].clientHeight;\n if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) return;\n // Subtract paddings\n width = width - parseInt($el.css(\"padding-left\") || 0, 10) - parseInt($el.css(\"padding-right\") || 0, 10);\n height = height - parseInt($el.css(\"padding-top\") || 0, 10) - parseInt($el.css(\"padding-bottom\") || 0, 10);\n if (Number.isNaN(width)) width = 0;\n if (Number.isNaN(height)) height = 0;\n Object.assign(swiper, {\n width: width,\n height: height,\n size: swiper.isHorizontal() ? width : height\n });\n}\n\n\n\nfunction $26f6d48351a2a3a8$export$2e2bcd8739ae039() {\n const swiper = this;\n function getDirectionLabel(property) {\n if (swiper.isHorizontal()) return property;\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 { $wrapperEl: $wrapperEl, size: swiperSize, rtlTranslate: rtl, wrongRTL: wrongRTL } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);\n const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n let snapGrid = [];\n const slidesGrid = [];\n const slidesSizesGrid = [];\n let offsetBefore = params.slidesOffsetBefore;\n if (typeof offsetBefore === \"function\") offsetBefore = params.slidesOffsetBefore.call(swiper);\n let offsetAfter = params.slidesOffsetAfter;\n if (typeof offsetAfter === \"function\") offsetAfter = params.slidesOffsetAfter.call(swiper);\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\") return;\n if (typeof spaceBetween === \"string\" && spaceBetween.indexOf(\"%\") >= 0) spaceBetween = parseFloat(spaceBetween.replace(\"%\", \"\")) / 100 * swiperSize;\n swiper.virtualSize = -spaceBetween; // reset margins\n if (rtl) slides.css({\n marginLeft: \"\",\n marginBottom: \"\",\n marginTop: \"\"\n });\n else slides.css({\n marginRight: \"\",\n marginBottom: \"\",\n marginTop: \"\"\n }); // reset cssMode offsets\n if (params.centeredSlides && params.cssMode) {\n (0, $3b5ddcf6fe080905$export$a607267f322101fd)(swiper.wrapperEl, \"--swiper-centered-offset-before\", \"\");\n (0, $3b5ddcf6fe080905$export$a607267f322101fd)(swiper.wrapperEl, \"--swiper-centered-offset-after\", \"\");\n }\n const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n if (gridEnabled) swiper.grid.initSlides(slidesLength);\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 const slide = slides.eq(i);\n if (gridEnabled) swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n if (slide.css(\"display\") === \"none\") continue; // eslint-disable-line\n if (params.slidesPerView === \"auto\") {\n if (shouldResetSlideSize) slides[i].style[getDirectionLabel(\"width\")] = ``;\n const slideStyles = getComputedStyle(slide[0]);\n const currentTransform = slide[0].style.transform;\n const currentWebKitTransform = slide[0].style.webkitTransform;\n if (currentTransform) slide[0].style.transform = \"none\";\n if (currentWebKitTransform) slide[0].style.webkitTransform = \"none\";\n if (params.roundLengths) slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);\n else {\n // eslint-disable-next-line\n const width = getDirectionPropertyValue(slideStyles, \"width\");\n const paddingLeft = getDirectionPropertyValue(slideStyles, \"padding-left\");\n const paddingRight = getDirectionPropertyValue(slideStyles, \"padding-right\");\n const marginLeft = getDirectionPropertyValue(slideStyles, \"margin-left\");\n const marginRight = getDirectionPropertyValue(slideStyles, \"margin-right\");\n const boxSizing = slideStyles.getPropertyValue(\"box-sizing\");\n if (boxSizing && boxSizing === \"border-box\") slideSize = width + marginLeft + marginRight;\n else {\n const { clientWidth: clientWidth, offsetWidth: offsetWidth } = slide[0];\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n }\n }\n if (currentTransform) slide[0].style.transform = currentTransform;\n if (currentWebKitTransform) slide[0].style.webkitTransform = currentWebKitTransform;\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]) slides[i].style[getDirectionLabel(\"width\")] = `${slideSize}px`;\n }\n if (slides[i]) slides[i].swiperSlideSize = slideSize;\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) < 0.001) 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\")) $wrapperEl.css({\n width: `${swiper.virtualSize + params.spaceBetween}px`\n });\n if (params.setWrapperSize) $wrapperEl.css({\n [getDirectionLabel(\"width\")]: `${swiper.virtualSize + params.spaceBetween}px`\n });\n if (gridEnabled) swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\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) newSlidesGrid.push(slidesGridItem);\n }\n snapGrid = newSlidesGrid;\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) snapGrid.push(swiper.virtualSize - swiperSize);\n }\n if (snapGrid.length === 0) snapGrid = [\n 0\n ];\n if (params.spaceBetween !== 0) {\n const key = swiper.isHorizontal() && rtl ? \"marginLeft\" : getDirectionLabel(\"marginRight\");\n slides.filter((_, slideIndex)=>{\n if (!params.cssMode) return true;\n if (slideIndex === slides.length - 1) return false;\n return true;\n }).css({\n [key]: `${spaceBetween}px`\n });\n }\n if (params.centeredSlides && params.centeredSlidesBounds) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach((slideSizeValue)=>{\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n const maxSnap = allSlidesSize - swiperSize;\n snapGrid = snapGrid.map((snap)=>{\n if (snap < 0) return -offsetBefore;\n if (snap > maxSnap) return maxSnap + offsetAfter;\n return snap;\n });\n }\n if (params.centerInsufficientSlides) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach((slideSizeValue)=>{\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n 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: slides,\n snapGrid: snapGrid,\n slidesGrid: slidesGrid,\n slidesSizesGrid: slidesSizesGrid\n });\n if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n (0, $3b5ddcf6fe080905$export$a607267f322101fd)(swiper.wrapperEl, \"--swiper-centered-offset-before\", `${-snapGrid[0]}px`);\n (0, $3b5ddcf6fe080905$export$a607267f322101fd)(swiper.wrapperEl, \"--swiper-centered-offset-after\", `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n const addToSnapGrid = -swiper.snapGrid[0];\n const addToSlidesGrid = -swiper.slidesGrid[0];\n swiper.snapGrid = swiper.snapGrid.map((v)=>v + addToSnapGrid);\n swiper.slidesGrid = swiper.slidesGrid.map((v)=>v + addToSlidesGrid);\n }\n if (slidesLength !== previousSlidesLength) swiper.emit(\"slidesLengthChange\");\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n swiper.emit(\"snapGridLengthChange\");\n }\n if (slidesGrid.length !== previousSlidesGridLength) swiper.emit(\"slidesGridLengthChange\");\n if (params.watchSlidesProgress) swiper.updateSlidesOffset();\n}\n\n\nfunction $1c7d8d4cc67e702d$export$2e2bcd8739ae039(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\") swiper.setTransition(speed);\n else if (speed === true) swiper.setTransition(swiper.params.speed);\n const getSlideByIndex = (index)=>{\n if (isVirtual) return swiper.slides.filter((el)=>parseInt(el.getAttribute(\"data-swiper-slide-index\"), 10) === index)[0];\n return swiper.slides.eq(index)[0];\n }; // Find slides currently in view\n if (swiper.params.slidesPerView !== \"auto\" && swiper.params.slidesPerView > 1) {\n if (swiper.params.centeredSlides) swiper.visibleSlides.each((slide)=>{\n activeSlides.push(slide);\n });\n else 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 } else activeSlides.push(getSlideByIndex(swiper.activeIndex));\n // Find new height from highest slide in view\n for(i = 0; i < activeSlides.length; i += 1)if (typeof activeSlides[i] !== \"undefined\") {\n const height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n // Update Height\n if (newHeight || newHeight === 0) swiper.$wrapperEl.css(\"height\", `${newHeight}px`);\n}\n\n\nfunction $976eb22b16d08d15$export$2e2bcd8739ae039() {\n const swiper = this;\n const slides = swiper.slides;\n for(let i = 0; i < slides.length; i += 1)slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n}\n\n\n\nfunction $322af04ac98546ad$export$2e2bcd8739ae039(translate = this && this.translate || 0) {\n const swiper = this;\n const params = swiper.params;\n const { slides: slides, rtlTranslate: rtl, snapGrid: snapGrid } = swiper;\n if (slides.length === 0) return;\n if (typeof slides[0].swiperSlideOffset === \"undefined\") swiper.updateSlidesOffset();\n let offsetCenter = -translate;\n if (rtl) offsetCenter = translate; // Visible Slides\n slides.removeClass(params.slideVisibleClass);\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\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) slideOffset -= slides[0].swiperSlideOffset;\n const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const slideBefore = -(offsetCenter - slideOffset);\n const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n slide.progress = rtl ? -slideProgress : slideProgress;\n slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n }\n swiper.visibleSlides = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.visibleSlides);\n}\n\n\nfunction $b79d663ec9ea8304$export$2e2bcd8739ae039(translate) {\n const swiper = this;\n if (typeof translate === \"undefined\") {\n const multiplier = swiper.rtlTranslate ? -1 : 1; // 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 { progress: progress, isBeginning: isBeginning, isEnd: isEnd } = 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 isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n Object.assign(swiper, {\n progress: progress,\n isBeginning: isBeginning,\n isEnd: isEnd\n });\n if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n if (isBeginning && !wasBeginning) swiper.emit(\"reachBeginning toEdge\");\n if (isEnd && !wasEnd) swiper.emit(\"reachEnd toEdge\");\n if (wasBeginning && !isBeginning || wasEnd && !isEnd) swiper.emit(\"fromEdge\");\n swiper.emit(\"progress\", progress);\n}\n\n\nfunction $60d1c541ec2e209e$export$2e2bcd8739ae039() {\n const swiper = this;\n const { slides: slides, params: params, $wrapperEl: $wrapperEl, activeIndex: activeIndex, realIndex: realIndex } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);\n let activeSlide;\n if (isVirtual) activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index=\"${activeIndex}\"]`);\n else activeSlide = slides.eq(activeIndex);\n // Active classes\n activeSlide.addClass(params.slideActiveClass);\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n } // Next Slide\n let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n } // Prev Slide\n let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${nextSlide.attr(\"data-swiper-slide-index\")}\"]`).addClass(params.slideDuplicateNextClass);\n else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${nextSlide.attr(\"data-swiper-slide-index\")}\"]`).addClass(params.slideDuplicateNextClass);\n if (prevSlide.hasClass(params.slideDuplicateClass)) $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${prevSlide.attr(\"data-swiper-slide-index\")}\"]`).addClass(params.slideDuplicatePrevClass);\n else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${prevSlide.attr(\"data-swiper-slide-index\")}\"]`).addClass(params.slideDuplicatePrevClass);\n }\n swiper.emitSlidesClasses();\n}\n\n\nfunction $15cec1327f1b2db4$export$2e2bcd8739ae039(newActiveIndex) {\n const swiper = this;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n const { slidesGrid: slidesGrid, snapGrid: snapGrid, params: params, activeIndex: previousIndex, realIndex: previousRealIndex, snapIndex: previousSnapIndex } = swiper;\n let activeIndex = newActiveIndex;\n let snapIndex;\n if (typeof activeIndex === \"undefined\") {\n for(let i = 0; i < slidesGrid.length; i += 1){\n if (typeof slidesGrid[i + 1] !== \"undefined\") {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) activeIndex = i;\n else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) activeIndex = i + 1;\n } else if (translate >= slidesGrid[i]) activeIndex = i;\n } // Normalize slideIndex\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === \"undefined\") activeIndex = 0;\n }\n }\n if (snapGrid.indexOf(translate) >= 0) 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 return;\n } // Get real index\n const realIndex = parseInt(swiper.slides.eq(activeIndex).attr(\"data-swiper-slide-index\") || activeIndex, 10);\n Object.assign(swiper, {\n snapIndex: snapIndex,\n realIndex: realIndex,\n previousIndex: previousIndex,\n activeIndex: activeIndex\n });\n swiper.emit(\"activeIndexChange\");\n swiper.emit(\"snapIndexChange\");\n if (previousRealIndex !== realIndex) swiper.emit(\"realIndexChange\");\n if (swiper.initialized || swiper.params.runCallbacksOnInit) swiper.emit(\"slideChange\");\n}\n\n\n\nfunction $e1d2390eace53b2a$export$2e2bcd8739ae039(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e).closest(`.${params.slideClass}`)[0];\n let slideFound = false;\n let slideIndex;\n if (slide) {\n for(let i = 0; i < swiper.slides.length; i += 1)if (swiper.slides[i] === slide) {\n slideFound = true;\n slideIndex = i;\n break;\n }\n }\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n if (swiper.virtual && swiper.params.virtual.enabled) swiper.clickedIndex = parseInt((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slide).attr(\"data-swiper-slide-index\"), 10);\n else swiper.clickedIndex = slideIndex;\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) swiper.slideToClickedSlide();\n}\n\n\nvar $b1a554d3d868d881$export$2e2bcd8739ae039 = {\n updateSize: $ab0255aa0327cda9$export$2e2bcd8739ae039,\n updateSlides: $26f6d48351a2a3a8$export$2e2bcd8739ae039,\n updateAutoHeight: $1c7d8d4cc67e702d$export$2e2bcd8739ae039,\n updateSlidesOffset: $976eb22b16d08d15$export$2e2bcd8739ae039,\n updateSlidesProgress: $322af04ac98546ad$export$2e2bcd8739ae039,\n updateProgress: $b79d663ec9ea8304$export$2e2bcd8739ae039,\n updateSlidesClasses: $60d1c541ec2e209e$export$2e2bcd8739ae039,\n updateActiveIndex: $15cec1327f1b2db4$export$2e2bcd8739ae039,\n updateClickedSlide: $e1d2390eace53b2a$export$2e2bcd8739ae039\n};\n\n\n\nfunction $7e2cedb5746ba023$export$2e2bcd8739ae039(axis = this.isHorizontal() ? \"x\" : \"y\") {\n const swiper = this;\n const { params: params, rtlTranslate: rtl, translate: translate, $wrapperEl: $wrapperEl } = swiper;\n if (params.virtualTranslate) return rtl ? -translate : translate;\n if (params.cssMode) return translate;\n let currentTranslate = (0, $3b5ddcf6fe080905$export$5ec402b7fcf74398)($wrapperEl[0], axis);\n if (rtl) currentTranslate = -currentTranslate;\n return currentTranslate || 0;\n}\n\n\nfunction $28e941172b95e7ee$export$2e2bcd8739ae039(translate, byController) {\n const swiper = this;\n const { rtlTranslate: rtl, params: params, $wrapperEl: $wrapperEl, wrapperEl: wrapperEl, progress: progress } = swiper;\n let x = 0;\n let y = 0;\n const z = 0;\n if (swiper.isHorizontal()) x = rtl ? -translate : translate;\n else y = translate;\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n if (params.cssMode) wrapperEl[swiper.isHorizontal() ? \"scrollLeft\" : \"scrollTop\"] = swiper.isHorizontal() ? -x : -y;\n else if (!params.virtualTranslate) $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n if (translatesDiff === 0) newProgress = 0;\n else newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n if (newProgress !== progress) swiper.updateProgress(translate);\n swiper.emit(\"setTranslate\", swiper.translate, byController);\n}\n\n\nfunction $93b00be9a53c1801$export$2e2bcd8739ae039() {\n return -this.snapGrid[0];\n}\n\n\nfunction $fe88ac6bb8867724$export$2e2bcd8739ae039() {\n return -this.snapGrid[this.snapGrid.length - 1];\n}\n\n\n\nfunction $cf9660fc212484bd$export$2e2bcd8739ae039(translate = 0, speed = this.params.speed, runCallbacks = true, translateBounds = true, internal) {\n const swiper = this;\n const { params: params, wrapperEl: wrapperEl } = swiper;\n if (swiper.animating && params.preventInteractionOnTransition) return false;\n const minTranslate = swiper.minTranslate();\n const maxTranslate = swiper.maxTranslate();\n let newTranslate;\n if (translateBounds && translate > minTranslate) newTranslate = minTranslate;\n else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;\n else newTranslate = translate; // Update progress\n swiper.updateProgress(newTranslate);\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n if (speed === 0) wrapperEl[isH ? \"scrollLeft\" : \"scrollTop\"] = -newTranslate;\n else {\n if (!swiper.support.smoothScroll) {\n (0, $3b5ddcf6fe080905$export$a5dd2b4b1a116d6d)({\n swiper: 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) swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener(\"transitionend\", swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener(\"webkitTransitionEnd\", swiper.onTranslateToWrapperTransitionEnd);\n swiper.onTranslateToWrapperTransitionEnd = null;\n delete swiper.onTranslateToWrapperTransitionEnd;\n if (runCallbacks) swiper.emit(\"transitionEnd\");\n };\n swiper.$wrapperEl[0].addEventListener(\"transitionend\", swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener(\"webkitTransitionEnd\", swiper.onTranslateToWrapperTransitionEnd);\n }\n }\n return true;\n}\n\n\nvar $028b1822730f50f3$export$2e2bcd8739ae039 = {\n getTranslate: $7e2cedb5746ba023$export$2e2bcd8739ae039,\n setTranslate: $28e941172b95e7ee$export$2e2bcd8739ae039,\n minTranslate: $93b00be9a53c1801$export$2e2bcd8739ae039,\n maxTranslate: $fe88ac6bb8867724$export$2e2bcd8739ae039,\n translateTo: $cf9660fc212484bd$export$2e2bcd8739ae039\n};\n\n\nfunction $7243b17b4cd71915$export$2e2bcd8739ae039(duration, byController) {\n const swiper = this;\n if (!swiper.params.cssMode) swiper.$wrapperEl.transition(duration);\n swiper.emit(\"setTransition\", duration, byController);\n}\n\n\nfunction $1b0227d4093c7233$export$2e2bcd8739ae039({ swiper: swiper, runCallbacks: runCallbacks, direction: direction, step: step }) {\n const { activeIndex: activeIndex, previousIndex: previousIndex } = swiper;\n let dir = direction;\n if (!dir) {\n if (activeIndex > previousIndex) dir = \"next\";\n else if (activeIndex < previousIndex) dir = \"prev\";\n 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\") swiper.emit(`slideNextTransition${step}`);\n else swiper.emit(`slidePrevTransition${step}`);\n }\n}\n\n\nfunction $566804600dd26728$export$2e2bcd8739ae039(runCallbacks = true, direction) {\n const swiper = this;\n const { params: params } = swiper;\n if (params.cssMode) return;\n if (params.autoHeight) swiper.updateAutoHeight();\n (0, $1b0227d4093c7233$export$2e2bcd8739ae039)({\n swiper: swiper,\n runCallbacks: runCallbacks,\n direction: direction,\n step: \"Start\"\n });\n}\n\n\n\nfunction $92982ef5a90b424d$export$2e2bcd8739ae039(runCallbacks = true, direction) {\n const swiper = this;\n const { params: params } = swiper;\n swiper.animating = false;\n if (params.cssMode) return;\n swiper.setTransition(0);\n (0, $1b0227d4093c7233$export$2e2bcd8739ae039)({\n swiper: swiper,\n runCallbacks: runCallbacks,\n direction: direction,\n step: \"End\"\n });\n}\n\n\nvar $e55bfef53a84db3b$export$2e2bcd8739ae039 = {\n setTransition: $7243b17b4cd71915$export$2e2bcd8739ae039,\n transitionStart: $566804600dd26728$export$2e2bcd8739ae039,\n transitionEnd: $92982ef5a90b424d$export$2e2bcd8739ae039\n};\n\n\n\nfunction $6834d0a3161ec1bd$export$2e2bcd8739ae039(index = 0, speed = this.params.speed, runCallbacks = true, internal, initial) {\n if (typeof index !== \"number\" && typeof index !== \"string\") throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);\n if (typeof index === \"string\") {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */ const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */ const isValidNumber = isFinite(indexAsNumber);\n if (!isValidNumber) throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n index = indexAsNumber;\n }\n const swiper = this;\n let slideIndex = index;\n if (slideIndex < 0) slideIndex = 0;\n const { params: params, snapGrid: snapGrid, slidesGrid: slidesGrid, previousIndex: previousIndex, activeIndex: activeIndex, rtlTranslate: rtl, wrapperEl: wrapperEl, enabled: enabled } = swiper;\n if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) return false;\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 if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) swiper.emit(\"beforeSlideChangeStart\");\n const translate = -snapGrid[snapIndex]; // Update progress\n swiper.updateProgress(translate); // Normalize slideIndex\n if (params.normalizeSlideIndex) 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) slideIndex = i;\n else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) slideIndex = i + 1;\n } else if (normalizedTranslate >= normalizedGrid) slideIndex = i;\n }\n // Directions locks\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) return false;\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) return false;\n }\n }\n let direction;\n if (slideIndex > activeIndex) direction = \"next\";\n else if (slideIndex < activeIndex) direction = \"prev\";\n else direction = \"reset\"; // Update Index\n if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n swiper.updateActiveIndex(slideIndex); // Update Height\n if (params.autoHeight) swiper.updateAutoHeight();\n swiper.updateSlidesClasses();\n if (params.effect !== \"slide\") swiper.setTranslate(translate);\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 wrapperEl[isH ? \"scrollLeft\" : \"scrollTop\"] = t;\n if (isVirtual) requestAnimationFrame(()=>{\n swiper.wrapperEl.style.scrollSnapType = \"\";\n swiper._swiperImmediateVirtual = false;\n });\n } else {\n if (!swiper.support.smoothScroll) {\n (0, $3b5ddcf6fe080905$export$a5dd2b4b1a116d6d)({\n swiper: 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) swiper.transitionEnd(runCallbacks, direction);\n else if (!swiper.animating) {\n swiper.animating = true;\n if (!swiper.onSlideToWrapperTransitionEnd) swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener(\"transitionend\", swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener(\"webkitTransitionEnd\", swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n swiper.$wrapperEl[0].addEventListener(\"transitionend\", swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener(\"webkitTransitionEnd\", swiper.onSlideToWrapperTransitionEnd);\n }\n return true;\n}\n\n\nfunction $06b38374f3563166$export$2e2bcd8739ae039(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n let newIndex = index;\n if (swiper.params.loop) newIndex += swiper.loopedSlides;\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n}\n\n\n/* eslint no-unused-vars: \"off\" */ function $aa601ae9326be246$export$2e2bcd8739ae039(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const { animating: animating, enabled: enabled, params: params } = swiper;\n if (!enabled) return swiper;\n let perGroup = params.slidesPerGroup;\n if (params.slidesPerView === \"auto\" && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) perGroup = Math.max(swiper.slidesPerViewDynamic(\"current\", true), 1);\n const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n if (params.rewind && swiper.isEnd) return swiper.slideTo(0, speed, runCallbacks, internal);\n return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}\n\n\n/* eslint no-unused-vars: \"off\" */ function $7b3453e22bdf8084$export$2e2bcd8739ae039(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const { params: params, animating: animating, snapGrid: snapGrid, slidesGrid: slidesGrid, rtlTranslate: rtlTranslate, enabled: enabled } = swiper;\n if (!enabled) return swiper;\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].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) // prevSnap = snap;\n prevSnapIndex = snapIndex;\n });\n if (typeof prevSnapIndex !== \"undefined\") prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\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) return swiper.slideTo(swiper.slides.length - 1, speed, runCallbacks, internal);\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}\n\n\n/* eslint no-unused-vars: \"off\" */ function $0203643609db25e8$export$2e2bcd8739ae039(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}\n\n\n/* eslint no-unused-vars: \"off\" */ function $c9874fa76d566365$export$2e2bcd8739ae039(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) index += swiper.params.slidesPerGroup;\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) index -= swiper.params.slidesPerGroup;\n }\n index = Math.max(index, 0);\n index = Math.min(index, swiper.slidesGrid.length - 1);\n return swiper.slideTo(index, speed, runCallbacks, internal);\n}\n\n\n\n\nfunction $6efbdcb44451ba35$export$2e2bcd8739ae039() {\n const swiper = this;\n const { params: params, $wrapperEl: $wrapperEl } = swiper;\n const slidesPerView = params.slidesPerView === \"auto\" ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n let slideToIndex = swiper.clickedIndex;\n let realIndex;\n if (params.loop) {\n if (swiper.animating) return;\n realIndex = parseInt((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.clickedSlide).attr(\"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 = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n swiper.slideTo(slideToIndex);\n });\n } else swiper.slideTo(slideToIndex);\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n swiper.slideTo(slideToIndex);\n });\n } else swiper.slideTo(slideToIndex);\n } else swiper.slideTo(slideToIndex);\n}\n\n\nvar $033d75a631c825a1$export$2e2bcd8739ae039 = {\n slideTo: $6834d0a3161ec1bd$export$2e2bcd8739ae039,\n slideToLoop: $06b38374f3563166$export$2e2bcd8739ae039,\n slideNext: $aa601ae9326be246$export$2e2bcd8739ae039,\n slidePrev: $7b3453e22bdf8084$export$2e2bcd8739ae039,\n slideReset: $0203643609db25e8$export$2e2bcd8739ae039,\n slideToClosest: $c9874fa76d566365$export$2e2bcd8739ae039,\n slideToClickedSlide: $6efbdcb44451ba35$export$2e2bcd8739ae039\n};\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $3988cee579429a7b$export$2e2bcd8739ae039() {\n const swiper = this;\n const document = (0, $101nH.getDocument)();\n const { params: params, $wrapperEl: $wrapperEl } = swiper; // Remove duplicated slides\n const $selector = $wrapperEl.children().length > 0 ? (0, $5172d1d318d9c216$export$2e2bcd8739ae039)($wrapperEl.children()[0].parentNode) : $wrapperEl;\n $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();\n let slides = $selector.children(`.${params.slideClass}`);\n if (params.loopFillGroupWithBlank) {\n const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;\n if (blankSlidesNum !== params.slidesPerGroup) {\n for(let i = 0; i < blankSlidesNum; i += 1){\n const blankNode = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(document.createElement(\"div\")).addClass(`${params.slideClass} ${params.slideBlankClass}`);\n $selector.append(blankNode);\n }\n slides = $selector.children(`.${params.slideClass}`);\n }\n }\n if (params.slidesPerView === \"auto\" && !params.loopedSlides) params.loopedSlides = slides.length;\n swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));\n swiper.loopedSlides += params.loopAdditionalSlides;\n if (swiper.loopedSlides > slides.length) swiper.loopedSlides = slides.length;\n const prependSlides = [];\n const appendSlides = [];\n slides.each((el, index)=>{\n const slide = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el);\n if (index < swiper.loopedSlides) appendSlides.push(el);\n if (index < slides.length && index >= slides.length - swiper.loopedSlides) prependSlides.push(el);\n slide.attr(\"data-swiper-slide-index\", index);\n });\n for(let i = 0; i < appendSlides.length; i += 1)$selector.append((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n for(let i = prependSlides.length - 1; i >= 0; i -= 1)$selector.prepend((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n}\n\n\nfunction $19d9aebec8ce509d$export$2e2bcd8739ae039() {\n const swiper = this;\n swiper.emit(\"beforeLoopFix\");\n const { activeIndex: activeIndex, slides: slides, loopedSlides: loopedSlides, allowSlidePrev: allowSlidePrev, allowSlideNext: allowSlideNext, snapGrid: snapGrid, rtlTranslate: rtl } = swiper;\n let newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n const snapTranslate = -snapGrid[activeIndex];\n const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding\n if (activeIndex < loopedSlides) {\n newIndex = slides.length - loopedSlides * 3 + activeIndex;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged && diff !== 0) swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n } else if (activeIndex >= slides.length - loopedSlides) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n if (slideChanged && diff !== 0) swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n swiper.emit(\"loopFix\");\n}\n\n\nfunction $f96fb0c2c08d0283$export$2e2bcd8739ae039() {\n const swiper = this;\n const { $wrapperEl: $wrapperEl, params: params, slides: slides } = swiper;\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();\n slides.removeAttr(\"data-swiper-slide-index\");\n}\n\n\nvar $fa6325dd81ce274d$export$2e2bcd8739ae039 = {\n loopCreate: $3988cee579429a7b$export$2e2bcd8739ae039,\n loopFix: $19d9aebec8ce509d$export$2e2bcd8739ae039,\n loopDestroy: $f96fb0c2c08d0283$export$2e2bcd8739ae039\n};\n\n\nfunction $9293c5763f0d7e88$export$2e2bcd8739ae039(moving) {\n const swiper = this;\n if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n const el = swiper.params.touchEventsTarget === \"container\" ? swiper.el : swiper.wrapperEl;\n el.style.cursor = \"move\";\n el.style.cursor = moving ? \"-webkit-grabbing\" : \"-webkit-grab\";\n el.style.cursor = moving ? \"-moz-grabbin\" : \"-moz-grab\";\n el.style.cursor = moving ? \"grabbing\" : \"grab\";\n}\n\n\nfunction $9a45bb4d970835c5$export$2e2bcd8739ae039() {\n const swiper = this;\n if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n swiper[swiper.params.touchEventsTarget === \"container\" ? \"el\" : \"wrapperEl\"].style.cursor = \"\";\n}\n\n\nvar $f83e5b45fe02bfa5$export$2e2bcd8739ae039 = {\n setGrabCursor: $9293c5763f0d7e88$export$2e2bcd8739ae039,\n unsetGrabCursor: $9a45bb4d970835c5$export$2e2bcd8739ae039\n};\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nvar $101nH = parcelRequire(\"101nH\");\n\n\nfunction $c068e03d11ae7cb6$var$closestElement(selector, base = this) {\n function __closestFrom(el) {\n if (!el || el === (0, $101nH.getDocument)() || el === (0, $101nH.getWindow)()) return null;\n if (el.assignedSlot) el = el.assignedSlot;\n const found = el.closest(selector);\n return found || __closestFrom(el.getRootNode().host);\n }\n return __closestFrom(base);\n}\nfunction $c068e03d11ae7cb6$export$2e2bcd8739ae039(event) {\n const swiper = this;\n const document = (0, $101nH.getDocument)();\n const window = (0, $101nH.getWindow)();\n const data = swiper.touchEventsData;\n const { params: params, touches: touches, enabled: enabled } = swiper;\n if (!enabled) return;\n if (swiper.animating && params.preventInteractionOnTransition) return;\n if (!swiper.animating && params.cssMode && params.loop) swiper.loopFix();\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n let $targetEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e.target);\n if (params.touchEventsTarget === \"wrapper\") {\n if (!$targetEl.closest(swiper.wrapperEl).length) return;\n }\n data.isTouchEvent = e.type === \"touchstart\";\n if (!data.isTouchEvent && \"which\" in e && e.which === 3) return;\n if (!data.isTouchEvent && \"button\" in e && e.button > 0) return;\n if (data.isTouched && data.isMoved) return; // change target el for shadow root component\n const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== \"\";\n if (swipingClassHasValue && e.target && e.target.shadowRoot && event.path && event.path[0]) $targetEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(event.path[0]);\n const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element\n if (params.noSwiping && (isTargetShadow ? $c068e03d11ae7cb6$var$closestElement(noSwipingSelector, e.target) : $targetEl.closest(noSwipingSelector)[0])) {\n swiper.allowClick = true;\n return;\n }\n if (params.swipeHandler) {\n if (!$targetEl.closest(params.swipeHandler)[0]) return;\n }\n touches.currentX = e.type === \"touchstart\" ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === \"touchstart\" ? e.targetTouches[0].pageY : e.pageY;\n const startX = touches.currentX;\n const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n 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\") event.preventDefault();\n else return;\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 = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) data.allowThresholdMove = false;\n if (e.type !== \"touchstart\") {\n let preventDefault = true;\n if ($targetEl.is(data.focusableElements)) preventDefault = false;\n if (document.activeElement && (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) document.activeElement.blur();\n const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) e.preventDefault();\n }\n swiper.emit(\"touchStart\", e);\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\n\nfunction $90ca77dda1086c37$export$2e2bcd8739ae039(event) {\n const document = (0, $101nH.getDocument)();\n const swiper = this;\n const data = swiper.touchEventsData;\n const { params: params, touches: touches, rtlTranslate: rtl, enabled: enabled } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) swiper.emit(\"touchMoveOpposite\", e);\n return;\n }\n if (data.isTouchEvent && e.type !== \"touchmove\") return;\n const targetTouch = e.type === \"touchmove\" && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);\n const pageX = e.type === \"touchmove\" ? targetTouch.pageX : e.pageX;\n const pageY = e.type === \"touchmove\" ? targetTouch.pageY : e.pageY;\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n if (!swiper.allowTouchMove) {\n // isMoved = true;\n swiper.allowClick = false;\n if (data.isTouched) {\n Object.assign(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY\n });\n data.touchStartTime = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\n }\n return;\n }\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) // Vertical\n {\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()) return;\n }\n if (data.isTouchEvent && document.activeElement) {\n if (e.target === document.activeElement && (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e.target).is(data.focusableElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n if (data.allowTouchCallbacks) swiper.emit(\"touchMove\", e);\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) data.isScrolling = false;\n else // 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 if (data.isScrolling) swiper.emit(\"touchMoveOpposite\", e);\n if (typeof data.startMoving === \"undefined\") {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) data.startMoving = true;\n }\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n if (!data.startMoving) return;\n swiper.allowClick = false;\n if (!params.cssMode && e.cancelable) e.preventDefault();\n if (params.touchMoveStopPropagation && !params.nested) e.stopPropagation();\n if (!data.isMoved) {\n if (params.loop && !params.cssMode) swiper.loopFix();\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n if (swiper.animating) swiper.$wrapperEl.trigger(\"webkitTransitionEnd transitionend\");\n data.allowMomentumBounce = false; // Grab Cursor\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) swiper.setGrabCursor(true);\n swiper.emit(\"sliderFirstMove\", e);\n }\n swiper.emit(\"sliderMove\", e);\n data.isMoved = true;\n let diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n diff *= params.touchRatio;\n if (rtl) diff = -diff;\n swiper.swipeDirection = diff > 0 ? \"prev\" : \"next\";\n data.currentTranslate = diff + data.startTranslate;\n let disableParentSwiper = true;\n let resistanceRatio = params.resistanceRatio;\n if (params.touchReleaseOnEdges) resistanceRatio = 0;\n if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n }\n if (disableParentSwiper) e.preventedByNestedSwiper = true;\n // Directions locks\n if (!swiper.allowSlideNext && swiper.swipeDirection === \"next\" && data.currentTranslate < data.startTranslate) data.currentTranslate = data.startTranslate;\n if (!swiper.allowSlidePrev && swiper.swipeDirection === \"prev\" && data.currentTranslate > data.startTranslate) data.currentTranslate = data.startTranslate;\n if (!swiper.allowSlidePrev && !swiper.allowSlideNext) data.currentTranslate = data.startTranslate;\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; // 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) swiper.freeMode.onTouchMove();\n // Update progress\n swiper.updateProgress(data.currentTranslate); // Update translate\n swiper.setTranslate(data.currentTranslate);\n}\n\n\n\nfunction $7a326ec7d22df549$export$2e2bcd8739ae039(event) {\n const swiper = this;\n const data = swiper.touchEventsData;\n const { params: params, touches: touches, rtlTranslate: rtl, slidesGrid: slidesGrid, enabled: enabled } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n if (data.allowTouchCallbacks) swiper.emit(\"touchEnd\", e);\n data.allowTouchCallbacks = false;\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) swiper.setGrabCursor(false);\n data.isMoved = false;\n data.startMoving = false;\n return;\n } // Return Grab Cursor\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) swiper.setGrabCursor(false);\n // Time diff\n const touchEndTime = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\n const timeDiff = touchEndTime - data.touchStartTime; // 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) swiper.emit(\"doubleTap doubleClick\", e);\n }\n data.lastClickTime = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\n (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\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) currentPos = rtl ? swiper.translate : -swiper.translate;\n else currentPos = -data.currentTranslate;\n if (params.cssMode) return;\n if (swiper.params.freeMode && params.freeMode.enabled) {\n swiper.freeMode.onTouchEnd({\n currentPos: currentPos\n });\n return;\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 } // 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(stopIndex + increment);\n else swiper.slideTo(stopIndex);\n }\n if (swiper.swipeDirection === \"prev\") {\n if (ratio > 1 - params.longSwipesRatio) swiper.slideTo(stopIndex + increment);\n else swiper.slideTo(stopIndex);\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\") swiper.slideTo(stopIndex + increment);\n if (swiper.swipeDirection === \"prev\") swiper.slideTo(stopIndex);\n } else if (e.target === swiper.navigation.nextEl) swiper.slideTo(stopIndex + increment);\n else swiper.slideTo(stopIndex);\n }\n}\n\n\nfunction $5937dd0d5d42a619$export$2e2bcd8739ae039() {\n const swiper = this;\n const { params: params, el: el } = swiper;\n if (el && el.offsetWidth === 0) return; // Breakpoints\n if (params.breakpoints) swiper.setBreakpoint();\n // Save locks\n const { allowSlideNext: allowSlideNext, allowSlidePrev: allowSlidePrev, snapGrid: snapGrid } = swiper; // Disable locks on resize\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateSlidesClasses();\n if ((params.slidesPerView === \"auto\" || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n else swiper.slideTo(swiper.activeIndex, 0, false, true);\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) swiper.autoplay.run();\n // Return locks after resize\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) swiper.checkOverflow();\n}\n\n\nfunction $a208f3f006ed227f$export$2e2bcd8739ae039(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}\n\n\nfunction $e5fc741aa4ac34ad$export$2e2bcd8739ae039() {\n const swiper = this;\n const { wrapperEl: wrapperEl, rtlTranslate: rtlTranslate, enabled: enabled } = swiper;\n if (!enabled) return;\n swiper.previousTranslate = swiper.translate;\n if (swiper.isHorizontal()) swiper.translate = -wrapperEl.scrollLeft;\n else swiper.translate = -wrapperEl.scrollTop;\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) newProgress = 0;\n else newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n if (newProgress !== swiper.progress) swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n swiper.emit(\"setTranslate\", swiper.translate, false);\n}\n\n\nlet $09c019bd8128ad9a$var$dummyEventAttached = false;\nfunction $09c019bd8128ad9a$var$dummyEventListener() {}\nconst $09c019bd8128ad9a$var$events = (swiper, method)=>{\n const document = (0, $101nH.getDocument)();\n const { params: params, touchEvents: touchEvents, el: el, wrapperEl: wrapperEl, device: device, support: support } = swiper;\n const capture = !!params.nested;\n const domMethod = method === \"on\" ? \"addEventListener\" : \"removeEventListener\";\n const swiperMethod = method; // Touch Events\n if (!support.touch) {\n el[domMethod](touchEvents.start, swiper.onTouchStart, false);\n document[domMethod](touchEvents.move, swiper.onTouchMove, capture);\n document[domMethod](touchEvents.end, swiper.onTouchEnd, false);\n } else {\n const passiveListener = touchEvents.start === \"touchstart\" && support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);\n el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {\n passive: false,\n capture: capture\n } : capture);\n el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);\n if (touchEvents.cancel) el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);\n } // Prevent Links Clicks\n if (params.preventClicks || params.preventClicksPropagation) el[domMethod](\"click\", swiper.onClick, true);\n if (params.cssMode) wrapperEl[domMethod](\"scroll\", swiper.onScroll);\n // Resize handler\n if (params.updateOnWindowResize) swiper[swiperMethod](device.ios || device.android ? \"resize orientationchange observerUpdate\" : \"resize observerUpdate\", (0, $5937dd0d5d42a619$export$2e2bcd8739ae039), true);\n else swiper[swiperMethod](\"observerUpdate\", (0, $5937dd0d5d42a619$export$2e2bcd8739ae039), true);\n};\nfunction $09c019bd8128ad9a$var$attachEvents() {\n const swiper = this;\n const document = (0, $101nH.getDocument)();\n const { params: params, support: support } = swiper;\n swiper.onTouchStart = (0, $c068e03d11ae7cb6$export$2e2bcd8739ae039).bind(swiper);\n swiper.onTouchMove = (0, $90ca77dda1086c37$export$2e2bcd8739ae039).bind(swiper);\n swiper.onTouchEnd = (0, $7a326ec7d22df549$export$2e2bcd8739ae039).bind(swiper);\n if (params.cssMode) swiper.onScroll = (0, $e5fc741aa4ac34ad$export$2e2bcd8739ae039).bind(swiper);\n swiper.onClick = (0, $a208f3f006ed227f$export$2e2bcd8739ae039).bind(swiper);\n if (support.touch && !$09c019bd8128ad9a$var$dummyEventAttached) {\n document.addEventListener(\"touchstart\", $09c019bd8128ad9a$var$dummyEventListener);\n $09c019bd8128ad9a$var$dummyEventAttached = true;\n }\n $09c019bd8128ad9a$var$events(swiper, \"on\");\n}\nfunction $09c019bd8128ad9a$var$detachEvents() {\n const swiper = this;\n $09c019bd8128ad9a$var$events(swiper, \"off\");\n}\nvar $09c019bd8128ad9a$export$2e2bcd8739ae039 = {\n attachEvents: $09c019bd8128ad9a$var$attachEvents,\n detachEvents: $09c019bd8128ad9a$var$detachEvents\n};\n\n\n\nconst $dbd03792c4fa18b9$var$isGridEnabled = (swiper, params)=>{\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\nfunction $dbd03792c4fa18b9$export$2e2bcd8739ae039() {\n const swiper = this;\n const { activeIndex: activeIndex, initialized: initialized, loopedSlides: loopedSlides = 0, params: params, $el: $el } = swiper;\n const breakpoints = params.breakpoints;\n if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters\n 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 = $dbd03792c4fa18b9$var$isGridEnabled(swiper, params);\n const isMultiRow = $dbd03792c4fa18b9$var$isGridEnabled(swiper, breakpointParams);\n const wasEnabled = params.enabled;\n if (wasMultiRow && !isMultiRow) {\n $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n } else if (!wasMultiRow && isMultiRow) {\n $el.addClass(`${params.containerModifierClass}grid`);\n if (breakpointParams.grid.fill && breakpointParams.grid.fill === \"column\" || !breakpointParams.grid.fill && params.grid.fill === \"column\") $el.addClass(`${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n }\n const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n if (directionChanged && initialized) swiper.changeDirection();\n (0, $3b5ddcf6fe080905$export$8b58be045bf06082)(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) swiper.disable();\n else if (!wasEnabled && isEnabled) swiper.enable();\n swiper.currentBreakpoint = breakpoint;\n swiper.emit(\"_beforeBreakpoint\", breakpointParams);\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);\n }\n swiper.emit(\"breakpoint\", breakpointParams);\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $99d8d592923d4160$export$2e2bcd8739ae039(breakpoints, base = \"window\", containerEl) {\n if (!breakpoints || base === \"container\" && !containerEl) return undefined;\n let breakpoint = false;\n const window = (0, $101nH.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: value,\n point: point\n };\n }\n return {\n value: point,\n point: 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 { point: point, value: value } = points[i];\n if (base === \"window\") {\n if (window.matchMedia(`(min-width: ${value}px)`).matches) breakpoint = point;\n } else if (value <= containerEl.clientWidth) breakpoint = point;\n }\n return breakpoint || \"max\";\n}\n\n\nvar $0bc34efe122bd687$export$2e2bcd8739ae039 = {\n setBreakpoint: $dbd03792c4fa18b9$export$2e2bcd8739ae039,\n getBreakpoint: $99d8d592923d4160$export$2e2bcd8739ae039\n};\n\n\nfunction $65be96cb684c831c$var$prepareClasses(entries, prefix) {\n const resultClasses = [];\n entries.forEach((item)=>{\n if (typeof item === \"object\") Object.keys(item).forEach((classNames)=>{\n if (item[classNames]) resultClasses.push(prefix + classNames);\n });\n else if (typeof item === \"string\") resultClasses.push(prefix + item);\n });\n return resultClasses;\n}\nfunction $65be96cb684c831c$export$2e2bcd8739ae039() {\n const swiper = this;\n const { classNames: classNames, params: params, rtl: rtl, $el: $el, device: device, support: support } = swiper; // prettier-ignore\n const suffixes = $65be96cb684c831c$var$prepareClasses([\n \"initialized\",\n params.direction,\n {\n \"pointer-events\": !support.touch\n },\n {\n \"free-mode\": swiper.params.freeMode && params.freeMode.enabled\n },\n {\n \"autoheight\": params.autoHeight\n },\n {\n \"rtl\": rtl\n },\n {\n \"grid\": params.grid && params.grid.rows > 1\n },\n {\n \"grid-column\": params.grid && params.grid.rows > 1 && params.grid.fill === \"column\"\n },\n {\n \"android\": device.android\n },\n {\n \"ios\": device.ios\n },\n {\n \"css-mode\": params.cssMode\n },\n {\n \"centered\": params.cssMode && params.centeredSlides\n }\n ], params.containerModifierClass);\n classNames.push(...suffixes);\n $el.addClass([\n ...classNames\n ].join(\" \"));\n swiper.emitContainerClasses();\n}\n\n\nfunction $d9eec47a3230c870$export$2e2bcd8739ae039() {\n const swiper = this;\n const { $el: $el, classNames: classNames } = swiper;\n $el.removeClass(classNames.join(\" \"));\n swiper.emitContainerClasses();\n}\n\n\nvar $8ff1555fe826e9cf$export$2e2bcd8739ae039 = {\n addClasses: $65be96cb684c831c$export$2e2bcd8739ae039,\n removeClasses: $d9eec47a3230c870$export$2e2bcd8739ae039\n};\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $1c283a68eedfebfc$export$2e2bcd8739ae039(imageEl, src, srcset, sizes, checkForComplete, callback) {\n const window = (0, $101nH.getWindow)();\n let image;\n function onReady() {\n if (callback) callback();\n }\n const isPicture = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(imageEl).parent(\"picture\")[0];\n if (!isPicture && (!imageEl.complete || !checkForComplete)) {\n if (src) {\n image = new window.Image();\n image.onload = onReady;\n image.onerror = onReady;\n if (sizes) image.sizes = sizes;\n if (srcset) image.srcset = srcset;\n if (src) image.src = src;\n } else onReady();\n } else // image already loaded...\n onReady();\n}\n\n\nfunction $53ccdf8311c6fbd7$export$2e2bcd8739ae039() {\n const swiper = this;\n swiper.imagesToLoad = swiper.$el.find(\"img\");\n function onReady() {\n if (typeof swiper === \"undefined\" || swiper === null || !swiper || swiper.destroyed) return;\n if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) swiper.update();\n swiper.emit(\"imagesReady\");\n }\n }\n for(let i = 0; i < swiper.imagesToLoad.length; i += 1){\n const imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute(\"src\"), imageEl.srcset || imageEl.getAttribute(\"srcset\"), imageEl.sizes || imageEl.getAttribute(\"sizes\"), true, onReady);\n }\n}\n\n\nvar $becb320a79571231$export$2e2bcd8739ae039 = {\n loadImage: $1c283a68eedfebfc$export$2e2bcd8739ae039,\n preloadImages: $53ccdf8311c6fbd7$export$2e2bcd8739ae039\n};\n\n\nfunction $75389aa07e372df7$var$checkOverflow() {\n const swiper = this;\n const { isLocked: wasLocked, params: params } = swiper;\n const { slidesOffsetBefore: slidesOffsetBefore } = 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 swiper.isLocked = swiper.snapGrid.length === 1;\n if (params.allowSlideNext === true) swiper.allowSlideNext = !swiper.isLocked;\n if (params.allowSlidePrev === true) swiper.allowSlidePrev = !swiper.isLocked;\n if (wasLocked && wasLocked !== swiper.isLocked) swiper.isEnd = false;\n if (wasLocked !== swiper.isLocked) swiper.emit(swiper.isLocked ? \"lock\" : \"unlock\");\n}\nvar $75389aa07e372df7$export$2e2bcd8739ae039 = {\n checkOverflow: $75389aa07e372df7$var$checkOverflow\n};\n\n\nvar $c5498ea2679b026d$export$2e2bcd8739ae039 = {\n init: true,\n direction: \"horizontal\",\n touchEventsTarget: \"wrapper\",\n initialSlide: 0,\n speed: 300,\n cssMode: false,\n updateOnWindowResize: true,\n resizeObserver: true,\n nested: false,\n createElements: false,\n enabled: true,\n focusableElements: \"input, select, option, textarea, button, video, label\",\n // Overrides\n width: null,\n height: null,\n //\n preventInteractionOnTransition: false,\n // ssr\n userAgent: null,\n url: null,\n // To support iOS's swipe-to-go-back gesture (when being used in-app).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n // Autoheight\n autoHeight: false,\n // Set wrapper width\n setWrapperSize: false,\n // Virtual Translate\n virtualTranslate: false,\n // Effects\n effect: \"slide\",\n // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n // Breakpoints\n breakpoints: undefined,\n breakpointsBase: \"window\",\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerGroup: 1,\n slidesPerGroupSkip: 0,\n slidesPerGroupAuto: false,\n centeredSlides: false,\n centeredSlidesBounds: false,\n slidesOffsetBefore: 0,\n // in px\n slidesOffsetAfter: 0,\n // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: true,\n // Round length\n roundLengths: false,\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: false,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n // Unique Navigation Elements\n uniqueNavElements: true,\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n // Progress\n watchSlidesProgress: false,\n // Cursor\n grabCursor: false,\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopFillGroupWithBlank: false,\n loopPreventsSlide: true,\n // rewind\n rewind: false,\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null,\n // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: \"swiper-no-swiping\",\n noSwipingSelector: null,\n // Passive Listeners\n passiveListeners: true,\n // NS\n containerModifierClass: \"swiper-\",\n // NEW\n slideClass: \"swiper-slide\",\n slideBlankClass: \"swiper-slide-invisible-blank\",\n slideActiveClass: \"swiper-slide-active\",\n slideDuplicateActiveClass: \"swiper-slide-duplicate-active\",\n slideVisibleClass: \"swiper-slide-visible\",\n slideDuplicateClass: \"swiper-slide-duplicate\",\n slideNextClass: \"swiper-slide-next\",\n slideDuplicateNextClass: \"swiper-slide-duplicate-next\",\n slidePrevClass: \"swiper-slide-prev\",\n slideDuplicatePrevClass: \"swiper-slide-duplicate-prev\",\n wrapperClass: \"swiper-wrapper\",\n // Callbacks\n runCallbacksOnInit: true,\n // Internals\n _emitClasses: false\n};\n\n\n\nfunction $50af25a1a97754c0$export$2e2bcd8739ae039(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 (0, $3b5ddcf6fe080905$export$8b58be045bf06082)(allModulesParams, obj);\n return;\n }\n if ([\n \"navigation\",\n \"pagination\",\n \"scrollbar\"\n ].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) params[moduleParamName] = {\n auto: true\n };\n if (!(moduleParamName in params && \"enabled\" in moduleParams)) {\n (0, $3b5ddcf6fe080905$export$8b58be045bf06082)(allModulesParams, obj);\n return;\n }\n if (params[moduleParamName] === true) params[moduleParamName] = {\n enabled: true\n };\n if (typeof params[moduleParamName] === \"object\" && !(\"enabled\" in params[moduleParamName])) params[moduleParamName].enabled = true;\n if (!params[moduleParamName]) params[moduleParamName] = {\n enabled: false\n };\n (0, $3b5ddcf6fe080905$export$8b58be045bf06082)(allModulesParams, obj);\n };\n}\n\n\nconst $7923a396d019f6bb$var$prototypes = {\n eventsEmitter: $582816759a7d7191$export$2e2bcd8739ae039,\n update: $b1a554d3d868d881$export$2e2bcd8739ae039,\n translate: $028b1822730f50f3$export$2e2bcd8739ae039,\n transition: $e55bfef53a84db3b$export$2e2bcd8739ae039,\n slide: $033d75a631c825a1$export$2e2bcd8739ae039,\n loop: $fa6325dd81ce274d$export$2e2bcd8739ae039,\n grabCursor: $f83e5b45fe02bfa5$export$2e2bcd8739ae039,\n events: $09c019bd8128ad9a$export$2e2bcd8739ae039,\n breakpoints: $0bc34efe122bd687$export$2e2bcd8739ae039,\n checkOverflow: $75389aa07e372df7$export$2e2bcd8739ae039,\n classes: $8ff1555fe826e9cf$export$2e2bcd8739ae039,\n images: $becb320a79571231$export$2e2bcd8739ae039\n};\nconst $7923a396d019f6bb$var$extendedDefaults = {};\nclass $7923a396d019f6bb$var$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\") params = args[0];\n else [el, params] = args;\n if (!params) params = {};\n params = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, params);\n if (el && !params.el) params.el = el;\n if (params.el && (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(params.el).length > 1) {\n const swipers = [];\n (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(params.el).each((containerEl)=>{\n const newParams = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, params, {\n el: containerEl\n });\n swipers.push(new $7923a396d019f6bb$var$Swiper(newParams));\n });\n return swipers;\n } // Swiper Instance\n const swiper = this;\n swiper.__swiper__ = true;\n swiper.support = (0, $d0e306ed97de446f$export$d61c7b85ff180578)();\n swiper.device = (0, $ee7403737d46980d$export$30c823bc834d6ab4)({\n userAgent: params.userAgent\n });\n swiper.browser = (0, $2a3bcebc4608246a$export$89e15fc796a4a429)();\n swiper.eventsListeners = {};\n swiper.eventsAnyListeners = [];\n swiper.modules = [\n ...swiper.__modules__\n ];\n if (params.modules && Array.isArray(params.modules)) swiper.modules.push(...params.modules);\n const allModulesParams = {};\n swiper.modules.forEach((mod)=>{\n mod({\n swiper: swiper,\n extendParams: (0, $50af25a1a97754c0$export$2e2bcd8739ae039)(params, allModulesParams),\n on: swiper.on.bind(swiper),\n once: swiper.once.bind(swiper),\n off: swiper.off.bind(swiper),\n emit: swiper.emit.bind(swiper)\n });\n }); // Extend defaults with modules params\n const swiperParams = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, (0, $c5498ea2679b026d$export$2e2bcd8739ae039), allModulesParams); // Extend defaults with passed params\n swiper.params = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, swiperParams, $7923a396d019f6bb$var$extendedDefaults, params);\n swiper.originalParams = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, swiper.params);\n swiper.passedParams = (0, $3b5ddcf6fe080905$export$8b58be045bf06082)({}, params); // add event listeners\n if (swiper.params && swiper.params.on) Object.keys(swiper.params.on).forEach((eventName)=>{\n swiper.on(eventName, swiper.params.on[eventName]);\n });\n if (swiper.params && swiper.params.onAny) swiper.onAny(swiper.params.onAny);\n // Save Dom lib\n swiper.$ = (0, $5172d1d318d9c216$export$2e2bcd8739ae039); // Extend Swiper\n Object.assign(swiper, {\n enabled: swiper.params.enabled,\n el: el,\n // Classes\n classNames: [],\n // Slides\n slides: (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(),\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 // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n // Touch Events\n touchEvents: function touchEvents() {\n const touch = [\n \"touchstart\",\n \"touchmove\",\n \"touchend\",\n \"touchcancel\"\n ];\n const desktop = [\n \"pointerdown\",\n \"pointermove\",\n \"pointerup\"\n ];\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n cancel: touch[3]\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2]\n };\n return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }(),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n focusableElements: swiper.params.focusableElements,\n // Last click time\n lastClickTime: (0, $3b5ddcf6fe080905$export$461939dd4422153)(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined\n },\n // Clicks\n allowClick: true,\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0\n },\n // Images\n imagesToLoad: [],\n imagesLoaded: 0\n });\n swiper.emit(\"_swiper\"); // Init\n if (swiper.params.init) swiper.init();\n // Return app instance\n return swiper;\n }\n enable() {\n const swiper = this;\n if (swiper.enabled) return;\n swiper.enabled = true;\n if (swiper.params.grabCursor) swiper.setGrabCursor();\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) swiper.unsetGrabCursor();\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 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.each((slideEl)=>{\n const classNames = swiper.getSlideClasses(slideEl);\n updates.push({\n slideEl: slideEl,\n classNames: 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 { params: params, slides: slides, slidesGrid: slidesGrid, slidesSizesGrid: slidesSizesGrid, size: swiperSize, activeIndex: activeIndex } = 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)if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n for(let i = activeIndex - 1; i >= 0; i -= 1)if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n } else {\n // eslint-disable-next-line\n if (view === \"current\") 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) spv += 1;\n }\n else // previous\n for(let i = activeIndex - 1; i >= 0; i -= 1){\n const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n if (slideInView) spv += 1;\n }\n }\n return spv;\n }\n update() {\n const swiper = this;\n if (!swiper || swiper.destroyed) return;\n const { snapGrid: snapGrid, params: params } = swiper; // Breakpoints\n if (params.breakpoints) swiper.setBreakpoint();\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) swiper.updateAutoHeight();\n } else {\n if ((swiper.params.slidesPerView === \"auto\" || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n else translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n if (!translated) setTranslate();\n }\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) swiper.checkOverflow();\n swiper.emit(\"update\");\n }\n changeDirection(newDirection, needUpdate = true) {\n const swiper = this;\n const currentDirection = swiper.params.direction;\n if (!newDirection) // eslint-disable-next-line\n newDirection = currentDirection === \"horizontal\" ? \"vertical\" : \"horizontal\";\n if (newDirection === currentDirection || newDirection !== \"horizontal\" && newDirection !== \"vertical\") return swiper;\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);\n swiper.emitContainerClasses();\n swiper.params.direction = newDirection;\n swiper.slides.each((slideEl)=>{\n if (newDirection === \"vertical\") slideEl.style.width = \"\";\n else slideEl.style.height = \"\";\n });\n swiper.emit(\"changeDirection\");\n if (needUpdate) swiper.update();\n return swiper;\n }\n mount(el) {\n const swiper = this;\n if (swiper.mounted) return true; // Find el\n const $el = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el || swiper.params.el);\n el = $el[0];\n if (!el) return false;\n el.swiper = swiper;\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 = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items\n res.children = (options)=>$el.children(options);\n return res;\n }\n return $el.children(getWrapperSelector());\n }; // Find Wrapper\n let $wrapperEl = getWrapper();\n if ($wrapperEl.length === 0 && swiper.params.createElements) {\n const document = (0, $101nH.getDocument)();\n const wrapper = document.createElement(\"div\");\n $wrapperEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(wrapper);\n wrapper.className = swiper.params.wrapperClass;\n $el.append(wrapper);\n $el.children(`.${swiper.params.slideClass}`).each((slideEl)=>{\n $wrapperEl.append(slideEl);\n });\n }\n Object.assign(swiper, {\n $el: $el,\n el: el,\n $wrapperEl: $wrapperEl,\n wrapperEl: $wrapperEl[0],\n mounted: true,\n // RTL\n rtl: el.dir.toLowerCase() === \"rtl\" || $el.css(\"direction\") === \"rtl\",\n rtlTranslate: swiper.params.direction === \"horizontal\" && (el.dir.toLowerCase() === \"rtl\" || $el.css(\"direction\") === \"rtl\"),\n wrongRTL: $wrapperEl.css(\"display\") === \"-webkit-box\"\n });\n return true;\n }\n init(el) {\n const swiper = this;\n if (swiper.initialized) return swiper;\n const mounted = swiper.mount(el);\n if (mounted === false) return swiper;\n swiper.emit(\"beforeInit\"); // Set breakpoint\n if (swiper.params.breakpoints) swiper.setBreakpoint();\n // Add Classes\n swiper.addClasses(); // Create loop\n if (swiper.params.loop) swiper.loopCreate();\n // Update size\n swiper.updateSize(); // Update slides\n swiper.updateSlides();\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n // Set Grab Cursor\n if (swiper.params.grabCursor && swiper.enabled) swiper.setGrabCursor();\n if (swiper.params.preloadImages) swiper.preloadImages();\n // Slide To Initial Slide\n if (swiper.params.loop) swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);\n else swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n // Attach events\n swiper.attachEvents(); // Init Flag\n swiper.initialized = true; // 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 { params: params, $el: $el, $wrapperEl: $wrapperEl, slides: slides } = swiper;\n if (typeof swiper.params === \"undefined\" || swiper.destroyed) return null;\n swiper.emit(\"beforeDestroy\"); // Init Flag\n swiper.initialized = false; // Detach events\n swiper.detachEvents(); // Destroy loop\n if (params.loop) swiper.loopDestroy();\n // Cleanup styles\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr(\"style\");\n $wrapperEl.removeAttr(\"style\");\n if (slides && slides.length) slides.removeClass([\n params.slideVisibleClass,\n params.slideActiveClass,\n params.slideNextClass,\n params.slidePrevClass\n ].join(\" \")).removeAttr(\"style\").removeAttr(\"data-swiper-slide-index\");\n }\n swiper.emit(\"destroy\"); // Detach emitter events\n Object.keys(swiper.eventsListeners).forEach((eventName)=>{\n swiper.off(eventName);\n });\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n (0, $3b5ddcf6fe080905$export$8694e5c03a4df8e6)(swiper);\n }\n swiper.destroyed = true;\n return null;\n }\n static extendDefaults(newDefaults) {\n (0, $3b5ddcf6fe080905$export$8b58be045bf06082)($7923a396d019f6bb$var$extendedDefaults, newDefaults);\n }\n static get extendedDefaults() {\n return $7923a396d019f6bb$var$extendedDefaults;\n }\n static get defaults() {\n return 0, $c5498ea2679b026d$export$2e2bcd8739ae039;\n }\n static installModule(mod) {\n if (!$7923a396d019f6bb$var$Swiper.prototype.__modules__) $7923a396d019f6bb$var$Swiper.prototype.__modules__ = [];\n const modules = $7923a396d019f6bb$var$Swiper.prototype.__modules__;\n if (typeof mod === \"function\" && modules.indexOf(mod) < 0) modules.push(mod);\n }\n static use(module) {\n if (Array.isArray(module)) {\n module.forEach((m)=>$7923a396d019f6bb$var$Swiper.installModule(m));\n return $7923a396d019f6bb$var$Swiper;\n }\n $7923a396d019f6bb$var$Swiper.installModule(module);\n return $7923a396d019f6bb$var$Swiper;\n }\n}\nObject.keys($7923a396d019f6bb$var$prototypes).forEach((prototypeGroup)=>{\n Object.keys($7923a396d019f6bb$var$prototypes[prototypeGroup]).forEach((protoMethod)=>{\n $7923a396d019f6bb$var$Swiper.prototype[protoMethod] = $7923a396d019f6bb$var$prototypes[prototypeGroup][protoMethod];\n });\n});\n$7923a396d019f6bb$var$Swiper.use([\n (0, $bc702361aff2dca8$export$2e2bcd8739ae039),\n (0, $0d0a9e98fa108d39$export$2e2bcd8739ae039)\n]);\nvar $7923a396d019f6bb$export$2e2bcd8739ae039 = $7923a396d019f6bb$var$Swiper;\n\n\n\n\nfunction $ff7c4cc51f2ce52d$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n renderExternalUpdate: true,\n addSlidesBefore: 0,\n addSlidesAfter: 0\n }\n });\n let cssModeTimeout;\n swiper.virtual = {\n cache: {},\n from: undefined,\n to: undefined,\n slides: [],\n offset: 0,\n slidesGrid: []\n };\n function renderSlide(slide, index) {\n const params = swiper.params.virtual;\n if (params.cache && swiper.virtual.cache[index]) return swiper.virtual.cache[index];\n const $slideEl = params.renderSlide ? (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(params.renderSlide.call(swiper, slide, index)) : (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(`
${slide}
`);\n if (!$slideEl.attr(\"data-swiper-slide-index\")) $slideEl.attr(\"data-swiper-slide-index\", index);\n if (params.cache) swiper.virtual.cache[index] = $slideEl;\n return $slideEl;\n }\n function update(force) {\n const { slidesPerView: slidesPerView, slidesPerGroup: slidesPerGroup, centeredSlides: centeredSlides } = swiper.params;\n const { addSlidesBefore: addSlidesBefore, addSlidesAfter: addSlidesAfter } = swiper.params.virtual;\n const { from: previousFrom, to: previousTo, slides: slides, slidesGrid: previousSlidesGrid, offset: previousOffset } = swiper.virtual;\n if (!swiper.params.cssMode) swiper.updateActiveIndex();\n const activeIndex = swiper.activeIndex || 0;\n let offsetProp;\n if (swiper.rtlTranslate) offsetProp = \"right\";\n 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 = slidesPerGroup + addSlidesBefore;\n }\n const from = Math.max((activeIndex || 0) - slidesBefore, 0);\n const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n const offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n Object.assign(swiper.virtual, {\n from: from,\n to: to,\n offset: offset,\n slidesGrid: swiper.slidesGrid\n });\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n if (swiper.lazy && swiper.params.lazy.enabled) swiper.lazy.load();\n }\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) swiper.slides.css(offsetProp, `${offset}px`);\n swiper.updateProgress();\n return;\n }\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset: offset,\n from: from,\n to: to,\n slides: function getSlides() {\n const slidesToRender = [];\n for(let i = from; i <= to; i += 1)slidesToRender.push(slides[i]);\n return slidesToRender;\n }()\n });\n if (swiper.params.virtual.renderExternalUpdate) onRendered();\n return;\n }\n const prependIndexes = [];\n const appendIndexes = [];\n if (force) swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();\n else {\n for(let i = previousFrom; i <= previousTo; i += 1)if (i < from || i > to) swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${i}\"]`).remove();\n }\n for(let i = 0; i < slides.length; i += 1)if (i >= from && i <= to) {\n if (typeof previousTo === \"undefined\" || force) appendIndexes.push(i);\n else {\n if (i > previousTo) appendIndexes.push(i);\n if (i < previousFrom) prependIndexes.push(i);\n }\n }\n appendIndexes.forEach((index)=>{\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort((a, b)=>b - a).forEach((index)=>{\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children(\".swiper-slide\").css(offsetProp, `${offset}px`);\n onRendered();\n }\n function appendSlide(slides) {\n if (typeof slides === \"object\" && \"length\" in slides) {\n for(let i = 0; i < slides.length; i += 1)if (slides[i]) swiper.virtual.slides.push(slides[i]);\n } else swiper.virtual.slides.push(slides);\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)if (slides[i]) swiper.virtual.slides.unshift(slides[i]);\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else swiper.virtual.slides.unshift(slides);\n if (swiper.params.virtual.cache) {\n const cache = swiper.virtual.cache;\n const newCache = {};\n Object.keys(cache).forEach((cachedIndex)=>{\n const $cachedEl = cache[cachedIndex];\n const cachedElIndex = $cachedEl.attr(\"data-swiper-slide-index\");\n if (cachedElIndex) $cachedEl.attr(\"data-swiper-slide-index\", parseInt(cachedElIndex, 10) + numberOfNewSlides);\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)) for(let i = slidesIndexes.length - 1; i >= 0; i -= 1){\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n if (swiper.params.virtual.cache) delete swiper.virtual.cache[slidesIndexes[i]];\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) delete swiper.virtual.cache[slidesIndexes];\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) swiper.virtual.cache = {};\n update(true);\n swiper.slideTo(0, 0);\n }\n on(\"beforeInit\", ()=>{\n if (!swiper.params.virtual.enabled) return;\n swiper.virtual.slides = swiper.params.virtual.slides;\n swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n if (!swiper.params.initialSlide) update();\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 update();\n });\n on(\"init update resize\", ()=>{\n if (!swiper.params.virtual.enabled) return;\n if (swiper.params.cssMode) (0, $3b5ddcf6fe080905$export$a607267f322101fd)(swiper.wrapperEl, \"--swiper-virtual-size\", `${swiper.virtualSize}px`);\n });\n Object.assign(swiper.virtual, {\n appendSlide: appendSlide,\n prependSlide: prependSlide,\n removeSlide: removeSlide,\n removeAllSlides: removeAllSlides,\n update: update\n });\n}\n\n\n/* eslint-disable consistent-return */ \nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $e24b9da43b8b0f3e$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n const document = (0, $101nH.getDocument)();\n const window = (0, $101nH.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 { rtlTranslate: rtl } = 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; // Directions locks\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) return false;\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) return false;\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) return undefined;\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === \"input\" || document.activeElement.nodeName.toLowerCase() === \"textarea\")) return undefined;\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) return undefined;\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [\n [\n swiperOffset.left,\n swiperOffset.top\n ],\n [\n swiperOffset.left + swiperWidth,\n swiperOffset.top\n ],\n [\n swiperOffset.left,\n swiperOffset.top + swiperHeight\n ],\n [\n swiperOffset.left + swiperWidth,\n swiperOffset.top + swiperHeight\n ]\n ];\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();\n 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();\n 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 (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(document).on(\"keydown\", handle);\n swiper.keyboard.enabled = true;\n }\n function disable() {\n if (!swiper.keyboard.enabled) return;\n (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(document).off(\"keydown\", handle);\n swiper.keyboard.enabled = false;\n }\n on(\"init\", ()=>{\n if (swiper.params.keyboard.enabled) enable();\n });\n on(\"destroy\", ()=>{\n if (swiper.keyboard.enabled) disable();\n });\n Object.assign(swiper.keyboard, {\n enable: enable,\n disable: disable\n });\n}\n\n\n/* eslint-disable consistent-return */ \nvar $101nH = parcelRequire(\"101nH\");\n\n\nfunction $a3f3b37234b3c48b$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n const window = (0, $101nH.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 = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\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 // Legacy\n if (\"detail\" in e) sY = e.detail;\n if (\"wheelDelta\" in e) sY = -e.wheelDelta / 120;\n if (\"wheelDeltaY\" in e) sY = -e.wheelDeltaY / 120;\n if (\"wheelDeltaX\" in e) sX = -e.wheelDeltaX / 120;\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) pY = e.deltaY;\n if (\"deltaX\" in e) pX = e.deltaX;\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 } // Fall-back if spin cannot be determined\n if (pX && !sX) sX = pX < 1 ? -1 : 1;\n if (pY && !sY) sY = pY < 1 ? -1 : 1;\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) // Prevent if delta of wheel scroll delta is below configured threshold\n return false;\n if (swiper.params.mousewheel.thresholdTime && (0, $3b5ddcf6fe080905$export$461939dd4422153)() - lastScrollTime < swiper.params.mousewheel.thresholdTime) // Prevent if time between scrolls is below configured threshold\n return false;\n // If the movement is NOT big enough and\n // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):\n // Don't go any further (avoid insignificant scroll movement).\n if (newEvent.delta >= 6 && (0, $3b5ddcf6fe080905$export$461939dd4422153)() - lastScrollTime < 60) // Return false as a default\n return true;\n // If user is scrolling towards the end:\n // If the slider hasn't hit the latest slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to next slide and\n // emit a scroll event.\n // Else (the user is scrolling towards the beginning) and\n // if the slider hasn't hit the first slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to prev slide and\n // emit a scroll event.\n if (newEvent.direction < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n emit(\"scroll\", newEvent.raw);\n }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n emit(\"scroll\", newEvent.raw);\n } // If you got here is because an animation has been triggered so store the current time\n lastScrollTime = new window.Date().getTime(); // 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) // Return true to animate scroll on edges\n return true;\n } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) // Return true to animate scroll on edges\n return true;\n return false;\n }\n function handle(event1) {\n let e = event1;\n let disableParentSwiper = true;\n if (!swiper.enabled) return;\n const params = swiper.params.mousewheel;\n if (swiper.params.cssMode) e.preventDefault();\n let target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarget !== \"container\") target = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.params.mousewheel.eventsTarget);\n if (!swiper.mouseEntered && !target[0].contains(e.target) && !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;\n else return true;\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;\n else return true;\n } else delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n if (delta === 0) return true;\n if (params.invert) delta = -delta; // 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(); // 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: (0, $3b5ddcf6fe080905$export$461939dd4422153)(),\n delta: Math.abs(delta),\n direction: Math.sign(delta),\n raw: event1\n }; // Keep the most recent events\n if (recentWheelEvents.length >= 2) recentWheelEvents.shift(); // only store the last N events\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n recentWheelEvents.push(newEvent); // If there is at least one previous recorded event:\n // If direction has changed or\n // if the scroll is quicker than the previous one:\n // Animate the slider.\n // Else (this is the first time the wheel is moved):\n // Animate the slider.\n if (prevEvent) {\n if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) animateSlider(newEvent);\n } else animateSlider(newEvent);\n // If it's time to release the scroll:\n // Return now so you don't hit the preventDefault.\n if (releaseScroll(newEvent)) return true;\n } else {\n // Freemode or scrollContainer:\n // If we recently snapped after a momentum scroll, then ignore wheel events\n // to give time for the deceleration to finish. Stop ignoring after 500 msecs\n // or if it's a new scroll (larger delta or inverse sign as last event before\n // an end-of-momentum snap).\n const newEvent = {\n time: (0, $3b5ddcf6fe080905$export$461939dd4422153)(),\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 if (swiper.params.loop) swiper.loopFix();\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) swiper.updateSlidesClasses();\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) recentWheelEvents.shift(); // only store the last N events\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)) // 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 = (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 0); // no delay; move on next tick\n }\n if (!timeout) // 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 = (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n const snapToThreshold = 0.5;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 500);\n } // Emit event\n if (!ignoreWheelEvents) emit(\"scroll\", e); // Stop autoplay\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop(); // Return page scroll on edge positions\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;\n }\n }\n if (e.preventDefault) e.preventDefault();\n else e.returnValue = false;\n return false;\n }\n function events(method) {\n let target = swiper.$el;\n if (swiper.params.mousewheel.eventsTarget !== \"container\") target = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.params.mousewheel.eventsTarget);\n target[method](\"mouseenter\", handleMouseEnter);\n target[method](\"mouseleave\", handleMouseLeave);\n target[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(\"on\");\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(\"off\");\n swiper.mousewheel.enabled = false;\n return true;\n }\n on(\"init\", ()=>{\n if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) disable();\n if (swiper.params.mousewheel.enabled) enable();\n });\n on(\"destroy\", ()=>{\n if (swiper.params.cssMode) enable();\n if (swiper.mousewheel.enabled) disable();\n });\n Object.assign(swiper.mousewheel, {\n enable: enable,\n disable: disable\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $9eb7674adf88813c$export$2e2bcd8739ae039(swiper, originalParams, params, checkProps) {\n const document = (0, $101nH.getDocument)();\n if (swiper.params.createElements) Object.keys(checkProps).forEach((key)=>{\n if (!params[key] && params.auto === true) {\n let element = swiper.$el.children(`.${checkProps[key]}`)[0];\n if (!element) {\n element = document.createElement(\"div\");\n element.className = checkProps[key];\n swiper.$el.append(element);\n }\n params[key] = element;\n originalParams[key] = element;\n }\n });\n return params;\n}\n\n\n\nfunction $195a45db380e21d8$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\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 }\n });\n swiper.navigation = {\n nextEl: null,\n $nextEl: null,\n prevEl: null,\n $prevEl: null\n };\n function getEl(el) {\n let $el;\n if (el) {\n $el = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el);\n if (swiper.params.uniqueNavElements && typeof el === \"string\" && $el.length > 1 && swiper.$el.find(el).length === 1) $el = swiper.$el.find(el);\n }\n return $el;\n }\n function toggleEl($el, disabled) {\n const params = swiper.params.navigation;\n if ($el && $el.length > 0) {\n $el[disabled ? \"addClass\" : \"removeClass\"](params.disabledClass);\n if ($el[0] && $el[0].tagName === \"BUTTON\") $el[0].disabled = disabled;\n if (swiper.params.watchOverflow && swiper.enabled) $el[swiper.isLocked ? \"addClass\" : \"removeClass\"](params.lockClass);\n }\n }\n function update() {\n // Update Navigation Buttons\n if (swiper.params.loop) return;\n const { $nextEl: $nextEl, $prevEl: $prevEl } = swiper.navigation;\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 }\n function onNextClick(e) {\n e.preventDefault();\n if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;\n swiper.slideNext();\n }\n function init() {\n const params = swiper.params.navigation;\n swiper.params.navigation = (0, $9eb7674adf88813c$export$2e2bcd8739ae039)(swiper, swiper.originalParams.navigation, swiper.params.navigation, {\n nextEl: \"swiper-button-next\",\n prevEl: \"swiper-button-prev\"\n });\n if (!(params.nextEl || params.prevEl)) return;\n const $nextEl = getEl(params.nextEl);\n const $prevEl = getEl(params.prevEl);\n if ($nextEl && $nextEl.length > 0) $nextEl.on(\"click\", onNextClick);\n if ($prevEl && $prevEl.length > 0) $prevEl.on(\"click\", onPrevClick);\n Object.assign(swiper.navigation, {\n $nextEl: $nextEl,\n nextEl: $nextEl && $nextEl[0],\n $prevEl: $prevEl,\n prevEl: $prevEl && $prevEl[0]\n });\n if (!swiper.enabled) {\n if ($nextEl) $nextEl.addClass(params.lockClass);\n if ($prevEl) $prevEl.addClass(params.lockClass);\n }\n }\n function destroy() {\n const { $nextEl: $nextEl, $prevEl: $prevEl } = swiper.navigation;\n if ($nextEl && $nextEl.length) {\n $nextEl.off(\"click\", onNextClick);\n $nextEl.removeClass(swiper.params.navigation.disabledClass);\n }\n if ($prevEl && $prevEl.length) {\n $prevEl.off(\"click\", onPrevClick);\n $prevEl.removeClass(swiper.params.navigation.disabledClass);\n }\n }\n on(\"init\", ()=>{\n init();\n update();\n });\n on(\"toEdge fromEdge lock unlock\", ()=>{\n update();\n });\n on(\"destroy\", ()=>{\n destroy();\n });\n on(\"enable disable\", ()=>{\n const { $nextEl: $nextEl, $prevEl: $prevEl } = swiper.navigation;\n if ($nextEl) $nextEl[swiper.enabled ? \"removeClass\" : \"addClass\"](swiper.params.navigation.lockClass);\n if ($prevEl) $prevEl[swiper.enabled ? \"removeClass\" : \"addClass\"](swiper.params.navigation.lockClass);\n });\n on(\"click\", (_s, e)=>{\n const { $nextEl: $nextEl, $prevEl: $prevEl } = swiper.navigation;\n const targetEl = e.target;\n if (swiper.params.navigation.hideOnClick && !(0, $5172d1d318d9c216$export$2e2bcd8739ae039)(targetEl).is($prevEl) && !(0, $5172d1d318d9c216$export$2e2bcd8739ae039)(targetEl).is($nextEl)) {\n if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;\n let isHidden;\n if ($nextEl) isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);\n else if ($prevEl) isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);\n if (isHidden === true) emit(\"navigationShow\");\n else emit(\"navigationHide\");\n if ($nextEl) $nextEl.toggleClass(swiper.params.navigation.hiddenClass);\n if ($prevEl) $prevEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n });\n Object.assign(swiper.navigation, {\n update: update,\n init: init,\n destroy: destroy\n });\n}\n\n\n\nfunction $c149d04ee6362df0$export$2e2bcd8739ae039(classes = \"\") {\n return `.${classes.trim().replace(/([\\.:!\\/])/g, \"\\\\$1\") // eslint-disable-line\n .replace(/ /g, \".\")}`;\n}\n\n\n\nfunction $d3de1033415288cd$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\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 }\n });\n swiper.pagination = {\n el: null,\n $el: null,\n bullets: []\n };\n let bulletSize;\n let dynamicBulletIndex = 0;\n function isPaginationDisabled() {\n return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;\n }\n function setSideBullets($bulletEl, position) {\n const { bulletActiveClass: bulletActiveClass } = swiper.params.pagination;\n $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);\n }\n function update() {\n // Render || Update Pagination bullets/items\n const rtl = swiper.rtl;\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el; // Current/Total\n let current;\n const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n if (current > slidesLength - 1 - swiper.loopedSlides * 2) current -= slidesLength - swiper.loopedSlides * 2;\n if (current > total - 1) current -= total;\n if (current < 0 && swiper.params.paginationType !== \"bullets\") current = total + current;\n } else if (typeof swiper.snapIndex !== \"undefined\") current = swiper.snapIndex;\n else current = swiper.activeIndex || 0;\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 = bullets.eq(0)[swiper.isHorizontal() ? \"outerWidth\" : \"outerHeight\"](true);\n $el.css(swiper.isHorizontal() ? \"width\" : \"height\", `${bulletSize * (params.dynamicMainBullets + 4)}px`);\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);\n if (dynamicBulletIndex > params.dynamicMainBullets - 1) dynamicBulletIndex = params.dynamicMainBullets - 1;\n else if (dynamicBulletIndex < 0) dynamicBulletIndex = 0;\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.removeClass([\n \"\",\n \"-next\",\n \"-next-next\",\n \"-prev\",\n \"-prev-prev\",\n \"-main\"\n ].map((suffix)=>`${params.bulletActiveClass}${suffix}`).join(\" \"));\n if ($el.length > 1) bullets.each((bullet)=>{\n const $bullet = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(bullet);\n const bulletIndex = $bullet.index();\n if (bulletIndex === current) $bullet.addClass(params.bulletActiveClass);\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) $bullet.addClass(`${params.bulletActiveClass}-main`);\n if (bulletIndex === firstIndex) setSideBullets($bullet, \"prev\");\n if (bulletIndex === lastIndex) setSideBullets($bullet, \"next\");\n }\n });\n else {\n const $bullet = bullets.eq(current);\n const bulletIndex = $bullet.index();\n $bullet.addClass(params.bulletActiveClass);\n if (params.dynamicBullets) {\n const $firstDisplayedBullet = bullets.eq(firstIndex);\n const $lastDisplayedBullet = bullets.eq(lastIndex);\n for(let i = firstIndex; i <= lastIndex; i += 1)bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);\n if (swiper.params.loop) {\n if (bulletIndex >= bullets.length) {\n for(let i = params.dynamicMainBullets; i >= 0; i -= 1)bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);\n bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);\n } else {\n setSideBullets($firstDisplayedBullet, \"prev\");\n setSideBullets($lastDisplayedBullet, \"next\");\n }\n } else {\n setSideBullets($firstDisplayedBullet, \"prev\");\n setSideBullets($lastDisplayedBullet, \"next\");\n }\n }\n }\n if (params.dynamicBullets) {\n const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n const offsetProp = rtl ? \"right\" : \"left\";\n bullets.css(swiper.isHorizontal() ? offsetProp : \"top\", `${bulletsOffset}px`);\n }\n }\n if (params.type === \"fraction\") {\n $el.find((0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n $el.find((0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.totalClass)).text(params.formatFractionTotal(total));\n }\n if (params.type === \"progressbar\") {\n let progressbarDirection;\n if (params.progressbarOpposite) progressbarDirection = swiper.isHorizontal() ? \"vertical\" : \"horizontal\";\n else progressbarDirection = swiper.isHorizontal() ? \"horizontal\" : \"vertical\";\n const scale = (current + 1) / total;\n let scaleX = 1;\n let scaleY = 1;\n if (progressbarDirection === \"horizontal\") scaleX = scale;\n else scaleY = scale;\n $el.find((0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);\n }\n if (params.type === \"custom\" && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n emit(\"paginationRender\", $el[0]);\n } else emit(\"paginationUpdate\", $el[0]);\n if (swiper.params.watchOverflow && swiper.enabled) $el[swiper.isLocked ? \"addClass\" : \"removeClass\"](params.lockClass);\n }\n function render() {\n // Render Container\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el;\n let paginationHTML = \"\";\n if (params.type === \"bullets\") {\n let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) numberOfBullets = slidesLength;\n for(let i = 0; i < numberOfBullets; i += 1)if (params.renderBullet) paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n else paginationHTML += `<${params.bulletElement} class=\"${params.bulletClass}\">`;\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find((0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.bulletClass));\n }\n if (params.type === \"fraction\") {\n if (params.renderFraction) paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n else paginationHTML = `` + \" / \" + ``;\n $el.html(paginationHTML);\n }\n if (params.type === \"progressbar\") {\n if (params.renderProgressbar) paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n else paginationHTML = ``;\n $el.html(paginationHTML);\n }\n if (params.type !== \"custom\") emit(\"paginationRender\", swiper.pagination.$el[0]);\n }\n function init() {\n swiper.params.pagination = (0, $9eb7674adf88813c$export$2e2bcd8739ae039)(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 = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(params.el);\n if ($el.length === 0) return;\n if (swiper.params.uniqueNavElements && typeof params.el === \"string\" && $el.length > 1) {\n $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper\n if ($el.length > 1) $el = $el.filter((el)=>{\n if ((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el).parents(\".swiper\")[0] !== swiper.el) return false;\n return true;\n });\n }\n if (params.type === \"bullets\" && params.clickable) $el.addClass(params.clickableClass);\n $el.addClass(params.modifierClass + params.type);\n $el.addClass(params.modifierClass + swiper.params.direction);\n if (params.type === \"bullets\" && params.dynamicBullets) {\n $el.addClass(`${params.modifierClass}${params.type}-dynamic`);\n dynamicBulletIndex = 0;\n if (params.dynamicMainBullets < 1) params.dynamicMainBullets = 1;\n }\n if (params.type === \"progressbar\" && params.progressbarOpposite) $el.addClass(params.progressbarOppositeClass);\n if (params.clickable) $el.on(\"click\", (0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.bulletClass), function onClick(e) {\n e.preventDefault();\n let index = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) index += swiper.loopedSlides;\n swiper.slideTo(index);\n });\n Object.assign(swiper.pagination, {\n $el: $el,\n el: $el[0]\n });\n if (!swiper.enabled) $el.addClass(params.lockClass);\n }\n function destroy() {\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const $el = swiper.pagination.$el;\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n $el.removeClass(params.modifierClass + swiper.params.direction);\n if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);\n if (params.clickable) $el.off(\"click\", (0, $c149d04ee6362df0$export$2e2bcd8739ae039)(params.bulletClass));\n }\n on(\"init\", ()=>{\n init();\n render();\n update();\n });\n on(\"activeIndexChange\", ()=>{\n if (swiper.params.loop) update();\n else if (typeof swiper.snapIndex === \"undefined\") update();\n });\n on(\"snapIndexChange\", ()=>{\n if (!swiper.params.loop) update();\n });\n on(\"slidesLengthChange\", ()=>{\n if (swiper.params.loop) {\n render();\n update();\n }\n });\n on(\"snapGridLengthChange\", ()=>{\n if (!swiper.params.loop) {\n render();\n update();\n }\n });\n on(\"destroy\", ()=>{\n destroy();\n });\n on(\"enable disable\", ()=>{\n const { $el: $el } = swiper.pagination;\n if ($el) $el[swiper.enabled ? \"removeClass\" : \"addClass\"](swiper.params.pagination.lockClass);\n });\n on(\"lock unlock\", ()=>{\n update();\n });\n on(\"click\", (_s, e)=>{\n const targetEl = e.target;\n const { $el: $el } = swiper.pagination;\n if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el.length > 0 && !(0, $5172d1d318d9c216$export$2e2bcd8739ae039)(targetEl).hasClass(swiper.params.pagination.bulletClass)) {\n if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);\n if (isHidden === true) emit(\"paginationShow\");\n else emit(\"paginationHide\");\n $el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n });\n Object.assign(swiper.pagination, {\n render: render,\n update: update,\n init: init,\n destroy: destroy\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\n\n\nfunction $89b0ffb0cc11b521$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n const document = (0, $101nH.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 }\n });\n swiper.scrollbar = {\n el: null,\n dragEl: null,\n $el: null,\n $dragEl: null\n };\n function setTranslate() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const { scrollbar: scrollbar, rtlTranslate: rtl, progress: progress } = swiper;\n const { $dragEl: $dragEl, $el: $el } = scrollbar;\n const params = swiper.params.scrollbar;\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) newSize = trackSize + newPos;\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) newSize = trackSize - newPos;\n if (swiper.isHorizontal()) {\n $dragEl.transform(`translate3d(${newPos}px, 0, 0)`);\n $dragEl[0].style.width = `${newSize}px`;\n } else {\n $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);\n $dragEl[0].style.height = `${newSize}px`;\n }\n if (params.hide) {\n clearTimeout(timeout);\n $el[0].style.opacity = 1;\n timeout = setTimeout(()=>{\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n }\n function setTransition(duration) {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n swiper.scrollbar.$dragEl.transition(duration);\n }\n function updateSize() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const { scrollbar: scrollbar } = swiper;\n const { $dragEl: $dragEl, $el: $el } = scrollbar;\n $dragEl[0].style.width = \"\";\n $dragEl[0].style.height = \"\";\n trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n if (swiper.params.scrollbar.dragSize === \"auto\") dragSize = trackSize * divider;\n else dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n if (swiper.isHorizontal()) $dragEl[0].style.width = `${dragSize}px`;\n else $dragEl[0].style.height = `${dragSize}px`;\n if (divider >= 1) $el[0].style.display = \"none\";\n else $el[0].style.display = \"\";\n if (swiper.params.scrollbar.hide) $el[0].style.opacity = 0;\n if (swiper.params.watchOverflow && swiper.enabled) scrollbar.$el[swiper.isLocked ? \"addClass\" : \"removeClass\"](swiper.params.scrollbar.lockClass);\n }\n function getPointerPosition(e) {\n if (swiper.isHorizontal()) return e.type === \"touchstart\" || e.type === \"touchmove\" ? e.targetTouches[0].clientX : e.clientX;\n return e.type === \"touchstart\" || e.type === \"touchmove\" ? e.targetTouches[0].clientY : e.clientY;\n }\n function setDragPosition(e) {\n const { scrollbar: scrollbar, rtlTranslate: rtl } = swiper;\n const { $el: $el } = scrollbar;\n let positionRatio;\n positionRatio = (getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? \"left\" : \"top\"] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n if (rtl) positionRatio = 1 - positionRatio;\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 { scrollbar: scrollbar, $wrapperEl: $wrapperEl } = swiper;\n const { $el: $el, $dragEl: $dragEl } = scrollbar;\n isTouched = true;\n dragStartPos = e.target === $dragEl[0] || e.target === $dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? \"left\" : \"top\"] : null;\n e.preventDefault();\n e.stopPropagation();\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n setDragPosition(e);\n clearTimeout(dragTimeout);\n $el.transition(0);\n if (params.hide) $el.css(\"opacity\", 1);\n if (swiper.params.cssMode) swiper.$wrapperEl.css(\"scroll-snap-type\", \"none\");\n emit(\"scrollbarDragStart\", e);\n }\n function onDragMove(e) {\n const { scrollbar: scrollbar, $wrapperEl: $wrapperEl } = swiper;\n const { $el: $el, $dragEl: $dragEl } = scrollbar;\n if (!isTouched) return;\n if (e.preventDefault) e.preventDefault();\n else e.returnValue = false;\n setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n emit(\"scrollbarDragMove\", e);\n }\n function onDragEnd(e) {\n const params = swiper.params.scrollbar;\n const { scrollbar: scrollbar, $wrapperEl: $wrapperEl } = swiper;\n const { $el: $el } = scrollbar;\n if (!isTouched) return;\n isTouched = false;\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css(\"scroll-snap-type\", \"\");\n $wrapperEl.transition(\"\");\n }\n if (params.hide) {\n clearTimeout(dragTimeout);\n dragTimeout = (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n $el.css(\"opacity\", 0);\n $el.transition(400);\n }, 1000);\n }\n emit(\"scrollbarDragEnd\", e);\n if (params.snapOnRelease) swiper.slideToClosest();\n }\n function events(method) {\n const { scrollbar: scrollbar, touchEventsTouch: touchEventsTouch, touchEventsDesktop: touchEventsDesktop, params: params, support: support } = swiper;\n const $el = scrollbar.$el;\n const target = $el[0];\n const activeListener = support.passiveListener && params.passiveListeners ? {\n passive: false,\n capture: false\n } : false;\n const passiveListener = support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (!target) return;\n const eventMethod = method === \"on\" ? \"addEventListener\" : \"removeEventListener\";\n if (!support.touch) {\n target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);\n document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);\n document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);\n } else {\n target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);\n target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);\n target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);\n }\n }\n function enableDraggable() {\n if (!swiper.params.scrollbar.el) return;\n events(\"on\");\n }\n function disableDraggable() {\n if (!swiper.params.scrollbar.el) return;\n events(\"off\");\n }\n function init() {\n const { scrollbar: scrollbar, $el: $swiperEl } = swiper;\n swiper.params.scrollbar = (0, $9eb7674adf88813c$export$2e2bcd8739ae039)(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 = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(params.el);\n if (swiper.params.uniqueNavElements && typeof params.el === \"string\" && $el.length > 1 && $swiperEl.find(params.el).length === 1) $el = $swiperEl.find(params.el);\n let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`);\n if ($dragEl.length === 0) {\n $dragEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(`
`);\n $el.append($dragEl);\n }\n Object.assign(scrollbar, {\n $el: $el,\n el: $el[0],\n $dragEl: $dragEl,\n dragEl: $dragEl[0]\n });\n if (params.draggable) enableDraggable();\n if ($el) $el[swiper.enabled ? \"removeClass\" : \"addClass\"](swiper.params.scrollbar.lockClass);\n }\n function destroy() {\n disableDraggable();\n }\n on(\"init\", ()=>{\n init();\n updateSize();\n setTranslate();\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 { $el: $el } = swiper.scrollbar;\n if ($el) $el[swiper.enabled ? \"removeClass\" : \"addClass\"](swiper.params.scrollbar.lockClass);\n });\n on(\"destroy\", ()=>{\n destroy();\n });\n Object.assign(swiper.scrollbar, {\n updateSize: updateSize,\n setTranslate: setTranslate,\n init: init,\n destroy: destroy\n });\n}\n\n\n\nfunction $c468c41da9e5e22d$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n parallax: {\n enabled: false\n }\n });\n const setTransform = (el, progress)=>{\n const { rtl: rtl } = swiper;\n const $el = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(el);\n const rtlFactor = rtl ? -1 : 1;\n const p = $el.attr(\"data-swiper-parallax\") || \"0\";\n let x = $el.attr(\"data-swiper-parallax-x\");\n let y = $el.attr(\"data-swiper-parallax-y\");\n const scale = $el.attr(\"data-swiper-parallax-scale\");\n const opacity = $el.attr(\"data-swiper-parallax-opacity\");\n 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) x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n else x = `${x * progress * rtlFactor}px`;\n if (y.indexOf(\"%\") >= 0) y = `${parseInt(y, 10) * progress}%`;\n else y = `${y * progress}px`;\n if (typeof opacity !== \"undefined\" && opacity !== null) {\n const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n $el[0].style.opacity = currentOpacity;\n }\n if (typeof scale === \"undefined\" || scale === null) $el.transform(`translate3d(${x}, ${y}, 0px)`);\n else {\n const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);\n }\n };\n const setTranslate = ()=>{\n const { $el: $el, slides: slides, progress: progress, snapGrid: snapGrid } = swiper;\n $el.children(\"[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]\").each((el)=>{\n setTransform(el, progress);\n });\n slides.each((slideEl, slideIndex)=>{\n let slideProgress = slideEl.progress;\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== \"auto\") slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl).find(\"[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]\").each((el)=>{\n setTransform(el, slideProgress);\n });\n });\n };\n const setTransition = (duration = swiper.params.speed)=>{\n const { $el: $el } = swiper;\n $el.find(\"[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]\").each((parallaxEl)=>{\n const $parallaxEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(parallaxEl);\n let parallaxDuration = parseInt($parallaxEl.attr(\"data-swiper-parallax-duration\"), 10) || duration;\n if (duration === 0) parallaxDuration = 0;\n $parallaxEl.transition(parallaxDuration);\n });\n };\n on(\"beforeInit\", ()=>{\n if (!swiper.params.parallax.enabled) return;\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n });\n on(\"init\", ()=>{\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on(\"setTranslate\", ()=>{\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on(\"setTransition\", (_swiper, duration)=>{\n if (!swiper.params.parallax.enabled) return;\n setTransition(duration);\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\n\nfunction $90c3785df4b8ec7f$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n const window = (0, $101nH.getWindow)();\n extendParams({\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: \"swiper-zoom-container\",\n zoomedSlideClass: \"swiper-slide-zoomed\"\n }\n });\n swiper.zoom = {\n enabled: false\n };\n let currentScale = 1;\n let isScaling = false;\n let gesturesEnabled;\n let fakeGestureTouched;\n let fakeGestureMoved;\n const gesture = {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3\n };\n const image = {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {}\n };\n const velocity = {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined\n };\n let scale = 1;\n Object.defineProperty(swiper.zoom, \"scale\", {\n get () {\n return scale;\n },\n set (value) {\n if (scale !== value) {\n const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined;\n const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined;\n emit(\"zoomChange\", value, imageEl, slideEl);\n }\n scale = value;\n }\n });\n function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) return 1;\n const x1 = e.targetTouches[0].pageX;\n const y1 = e.targetTouches[0].pageY;\n const x2 = e.targetTouches[1].pageX;\n const y2 = e.targetTouches[1].pageY;\n const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n return distance;\n } // Events\n function onGestureStart(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n if (!support.gestures) {\n if (e.type !== \"touchstart\" || e.type === \"touchstart\" && e.targetTouches.length < 2) return;\n fakeGestureTouched = true;\n gesture.scaleStart = getDistanceBetweenTouches(e);\n }\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e.target).closest(`.${swiper.params.slideClass}`);\n if (gesture.$slideEl.length === 0) gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find(\"picture, img, svg, canvas, .swiper-zoom-target\").eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n gesture.maxRatio = gesture.$imageWrapEl.attr(\"data-swiper-zoom\") || params.maxRatio;\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n if (gesture.$imageEl) gesture.$imageEl.transition(0);\n isScaling = true;\n }\n function onGestureChange(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n if (!support.gestures) {\n if (e.type !== \"touchmove\" || e.type === \"touchmove\" && e.targetTouches.length < 2) return;\n fakeGestureMoved = true;\n gesture.scaleMove = getDistanceBetweenTouches(e);\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) {\n if (e.type === \"gesturechange\") onGestureStart(e);\n return;\n }\n if (support.gestures) zoom.scale = e.scale * currentScale;\n else zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n if (zoom.scale > gesture.maxRatio) zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n if (zoom.scale < params.minRatio) zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n function onGestureEnd(e) {\n const device = swiper.device;\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n if (!support.gestures) {\n if (!fakeGestureTouched || !fakeGestureMoved) return;\n if (e.type !== \"touchend\" || e.type === \"touchend\" && e.changedTouches.length < 2 && !device.android) return;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n currentScale = zoom.scale;\n isScaling = false;\n if (zoom.scale === 1) gesture.$slideEl = undefined;\n }\n function onTouchStart(e) {\n const device = swiper.device;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n if (image.isTouched) return;\n if (device.android && e.cancelable) e.preventDefault();\n image.isTouched = true;\n image.touchesStart.x = e.type === \"touchstart\" ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === \"touchstart\" ? e.targetTouches[0].pageY : e.pageY;\n }\n function onTouchMove(e) {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) return;\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = (0, $3b5ddcf6fe080905$export$5ec402b7fcf74398)(gesture.$imageWrapEl[0], \"x\") || 0;\n image.startY = (0, $3b5ddcf6fe080905$export$5ec402b7fcf74398)(gesture.$imageWrapEl[0], \"y\") || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n } // Define if we need image drag\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.touchesCurrent.x = e.type === \"touchmove\" ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === \"touchmove\" ? e.targetTouches[0].pageY : e.pageY;\n 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) e.preventDefault();\n e.stopPropagation();\n image.isMoved = true;\n image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX;\n image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY;\n if (image.currentX < image.minX) image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n if (image.currentX > image.maxX) image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n if (image.currentY < image.minY) image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n if (image.currentY > image.maxY) image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\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.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n function onTouchEnd() {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) 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; // 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; // 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.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n function onTransitionEnd() {\n const zoom = swiper.zoom;\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n if (gesture.$imageEl) gesture.$imageEl.transform(\"translate3d(0,0,0) scale(1)\");\n if (gesture.$imageWrapEl) gesture.$imageWrapEl.transform(\"translate3d(0,0,0)\");\n zoom.scale = 1;\n currentScale = 1;\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\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) gesture.$slideEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e.target).closest(`.${swiper.params.slideClass}`);\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n else gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find(\"picture, img, svg, canvas, .swiper-zoom-target\").eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = \"hidden\";\n swiper.wrapperEl.style.touchAction = \"none\";\n }\n gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);\n let touchX;\n let touchY;\n let offsetX;\n let offsetY;\n let diffX;\n let diffY;\n let translateX;\n let translateY;\n let imageWidth;\n let imageHeight;\n let scaledWidth;\n let scaledHeight;\n let translateMinX;\n let translateMinY;\n let translateMaxX;\n let translateMaxY;\n let slideWidth;\n let slideHeight;\n if (typeof image.touchesStart.x === \"undefined\" && e) {\n touchX = e.type === \"touchend\" ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === \"touchend\" ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n zoom.scale = gesture.$imageWrapEl.attr(\"data-swiper-zoom\") || params.maxRatio;\n currentScale = gesture.$imageWrapEl.attr(\"data-swiper-zoom\") || params.maxRatio;\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left + window.scrollX;\n offsetY = gesture.$slideEl.offset().top + window.scrollY;\n diffX = offsetX + slideWidth / 2 - touchX;\n diffY = offsetY + slideHeight / 2 - touchY;\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n if (translateX < translateMinX) translateX = translateMinX;\n if (translateX > translateMaxX) translateX = translateMaxX;\n if (translateY < translateMinY) translateY = translateMinY;\n if (translateY > translateMaxY) translateY = translateMaxY;\n } else {\n translateX = 0;\n translateY = 0;\n }\n gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);\n gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n 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) gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n else gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find(\"picture, img, svg, canvas, .swiper-zoom-target\").eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) 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.transition(300).transform(\"translate3d(0,0,0)\");\n gesture.$imageEl.transition(300).transform(\"translate3d(0,0,0) scale(1)\");\n gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);\n gesture.$slideEl = undefined;\n } // Toggle Zoom\n function zoomToggle(e) {\n const zoom = swiper.zoom;\n if (zoom.scale && zoom.scale !== 1) // Zoom Out\n zoomOut();\n else // Zoom In\n zoomIn(e);\n }\n function getListeners() {\n const support = swiper.support;\n const passiveListener = swiper.touchEvents.start === \"touchstart\" && support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n const activeListenerWithCapture = support.passiveListener ? {\n passive: false,\n capture: true\n } : true;\n return {\n passiveListener: passiveListener,\n activeListenerWithCapture: activeListenerWithCapture\n };\n }\n function getSlideSelector() {\n return `.${swiper.params.slideClass}`;\n }\n function toggleGestures(method) {\n const { passiveListener: passiveListener } = getListeners();\n const slideSelector = getSlideSelector();\n swiper.$wrapperEl[method](\"gesturestart\", slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl[method](\"gesturechange\", slideSelector, onGestureChange, passiveListener);\n swiper.$wrapperEl[method](\"gestureend\", slideSelector, onGestureEnd, passiveListener);\n }\n function enableGestures() {\n if (gesturesEnabled) return;\n gesturesEnabled = true;\n toggleGestures(\"on\");\n }\n function disableGestures() {\n if (!gesturesEnabled) return;\n gesturesEnabled = false;\n toggleGestures(\"off\");\n } // Attach/Detach Events\n function enable() {\n const zoom = swiper.zoom;\n if (zoom.enabled) return;\n zoom.enabled = true;\n const support = swiper.support;\n const { passiveListener: passiveListener, activeListenerWithCapture: activeListenerWithCapture } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n if (support.gestures) {\n swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === \"touchstart\") {\n swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n if (swiper.touchEvents.cancel) swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n } // Move image\n swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n function disable() {\n const zoom = swiper.zoom;\n if (!zoom.enabled) return;\n const support = swiper.support;\n zoom.enabled = false;\n const { passiveListener: passiveListener, activeListenerWithCapture: activeListenerWithCapture } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n if (support.gestures) {\n swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === \"touchstart\") {\n swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n if (swiper.touchEvents.cancel) swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n } // Move image\n swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n on(\"init\", ()=>{\n if (swiper.params.zoom.enabled) enable();\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) zoomToggle(e);\n });\n on(\"transitionEnd\", ()=>{\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) onTransitionEnd();\n });\n on(\"slideChange\", ()=>{\n if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) onTransitionEnd();\n });\n Object.assign(swiper.zoom, {\n enable: enable,\n disable: disable,\n in: zoomIn,\n out: zoomOut,\n toggle: zoomToggle\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $7567f913e8efc13f$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n extendParams({\n lazy: {\n checkInView: false,\n enabled: false,\n loadPrevNext: false,\n loadPrevNextAmount: 1,\n loadOnTransitionStart: false,\n scrollingElement: \"\",\n elementClass: \"swiper-lazy\",\n loadingClass: \"swiper-lazy-loading\",\n loadedClass: \"swiper-lazy-loaded\",\n preloaderClass: \"swiper-lazy-preloader\"\n }\n });\n swiper.lazy = {};\n let scrollHandlerAttached = false;\n let initialImageLoaded = false;\n function loadInSlide(index, loadInDuplicate = true) {\n const params = swiper.params.lazy;\n if (typeof index === \"undefined\") return;\n if (swiper.slides.length === 0) return;\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n const $slideEl = isVirtual ? swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${index}\"]`) : swiper.slides.eq(index);\n const $images = $slideEl.find(`.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`);\n if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) $images.push($slideEl[0]);\n if ($images.length === 0) return;\n $images.each((imageEl)=>{\n const $imageEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(imageEl);\n $imageEl.addClass(params.loadingClass);\n const background = $imageEl.attr(\"data-background\");\n const src = $imageEl.attr(\"data-src\");\n const srcset = $imageEl.attr(\"data-srcset\");\n const sizes = $imageEl.attr(\"data-sizes\");\n const $pictureEl = $imageEl.parent(\"picture\");\n swiper.loadImage($imageEl[0], src || background, srcset, sizes, false, ()=>{\n if (typeof swiper === \"undefined\" || swiper === null || !swiper || swiper && !swiper.params || swiper.destroyed) return;\n if (background) {\n $imageEl.css(\"background-image\", `url(\"${background}\")`);\n $imageEl.removeAttr(\"data-background\");\n } else {\n if (srcset) {\n $imageEl.attr(\"srcset\", srcset);\n $imageEl.removeAttr(\"data-srcset\");\n }\n if (sizes) {\n $imageEl.attr(\"sizes\", sizes);\n $imageEl.removeAttr(\"data-sizes\");\n }\n if ($pictureEl.length) $pictureEl.children(\"source\").each((sourceEl)=>{\n const $source = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(sourceEl);\n if ($source.attr(\"data-srcset\")) {\n $source.attr(\"srcset\", $source.attr(\"data-srcset\"));\n $source.removeAttr(\"data-srcset\");\n }\n });\n if (src) {\n $imageEl.attr(\"src\", src);\n $imageEl.removeAttr(\"data-src\");\n }\n }\n $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);\n $slideEl.find(`.${params.preloaderClass}`).remove();\n if (swiper.params.loop && loadInDuplicate) {\n const slideOriginalIndex = $slideEl.attr(\"data-swiper-slide-index\");\n if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {\n const originalSlide = swiper.$wrapperEl.children(`[data-swiper-slide-index=\"${slideOriginalIndex}\"]:not(.${swiper.params.slideDuplicateClass})`);\n loadInSlide(originalSlide.index(), false);\n } else {\n const duplicatedSlide = swiper.$wrapperEl.children(`.${swiper.params.slideDuplicateClass}[data-swiper-slide-index=\"${slideOriginalIndex}\"]`);\n loadInSlide(duplicatedSlide.index(), false);\n }\n }\n emit(\"lazyImageReady\", $slideEl[0], $imageEl[0]);\n if (swiper.params.autoHeight) swiper.updateAutoHeight();\n });\n emit(\"lazyImageLoad\", $slideEl[0], $imageEl[0]);\n });\n }\n function load() {\n const { $wrapperEl: $wrapperEl, params: swiperParams, slides: slides, activeIndex: activeIndex } = swiper;\n const isVirtual = swiper.virtual && swiperParams.virtual.enabled;\n const params = swiperParams.lazy;\n let slidesPerView = swiperParams.slidesPerView;\n if (slidesPerView === \"auto\") slidesPerView = 0;\n function slideExist(index) {\n if (isVirtual) {\n if ($wrapperEl.children(`.${swiperParams.slideClass}[data-swiper-slide-index=\"${index}\"]`).length) return true;\n } else if (slides[index]) return true;\n return false;\n }\n function slideIndex(slideEl) {\n if (isVirtual) return (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl).attr(\"data-swiper-slide-index\");\n return (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl).index();\n }\n if (!initialImageLoaded) initialImageLoaded = true;\n if (swiper.params.watchSlidesProgress) $wrapperEl.children(`.${swiperParams.slideVisibleClass}`).each((slideEl)=>{\n const index = isVirtual ? (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl).attr(\"data-swiper-slide-index\") : (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl).index();\n loadInSlide(index);\n });\n else if (slidesPerView > 1) {\n for(let i = activeIndex; i < activeIndex + slidesPerView; i += 1)if (slideExist(i)) loadInSlide(i);\n } else loadInSlide(activeIndex);\n if (params.loadPrevNext) {\n if (slidesPerView > 1 || params.loadPrevNextAmount && params.loadPrevNextAmount > 1) {\n const amount = params.loadPrevNextAmount;\n const spv = slidesPerView;\n const maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);\n const minIndex = Math.max(activeIndex - Math.max(spv, amount), 0); // Next Slides\n for(let i = activeIndex + slidesPerView; i < maxIndex; i += 1)if (slideExist(i)) loadInSlide(i);\n // Prev Slides\n for(let i = minIndex; i < activeIndex; i += 1)if (slideExist(i)) loadInSlide(i);\n } else {\n const nextSlide = $wrapperEl.children(`.${swiperParams.slideNextClass}`);\n if (nextSlide.length > 0) loadInSlide(slideIndex(nextSlide));\n const prevSlide = $wrapperEl.children(`.${swiperParams.slidePrevClass}`);\n if (prevSlide.length > 0) loadInSlide(slideIndex(prevSlide));\n }\n }\n }\n function checkInViewOnLoad() {\n const window = (0, $101nH.getWindow)();\n if (!swiper || swiper.destroyed) return;\n const $scrollElement = swiper.params.lazy.scrollingElement ? (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.params.lazy.scrollingElement) : (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(window);\n const isWindow = $scrollElement[0] === window;\n const scrollElementWidth = isWindow ? window.innerWidth : $scrollElement[0].offsetWidth;\n const scrollElementHeight = isWindow ? window.innerHeight : $scrollElement[0].offsetHeight;\n const swiperOffset = swiper.$el.offset();\n const { rtlTranslate: rtl } = swiper;\n let inView = false;\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [\n [\n swiperOffset.left,\n swiperOffset.top\n ],\n [\n swiperOffset.left + swiper.width,\n swiperOffset.top\n ],\n [\n swiperOffset.left,\n swiperOffset.top + swiper.height\n ],\n [\n swiperOffset.left + swiper.width,\n swiperOffset.top + swiper.height\n ]\n ];\n for(let i = 0; i < swiperCoord.length; i += 1){\n const point = swiperCoord[i];\n if (point[0] >= 0 && point[0] <= scrollElementWidth && point[1] >= 0 && point[1] <= scrollElementHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n inView = true;\n }\n }\n const passiveListener = swiper.touchEvents.start === \"touchstart\" && swiper.support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (inView) {\n load();\n $scrollElement.off(\"scroll\", checkInViewOnLoad, passiveListener);\n } else if (!scrollHandlerAttached) {\n scrollHandlerAttached = true;\n $scrollElement.on(\"scroll\", checkInViewOnLoad, passiveListener);\n }\n }\n on(\"beforeInit\", ()=>{\n if (swiper.params.lazy.enabled && swiper.params.preloadImages) swiper.params.preloadImages = false;\n });\n on(\"init\", ()=>{\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.checkInView) checkInViewOnLoad();\n else load();\n }\n });\n on(\"scroll\", ()=>{\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.freeMode.sticky) load();\n });\n on(\"scrollbarDragMove resize _freeModeNoMomentumRelease\", ()=>{\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.checkInView) checkInViewOnLoad();\n else load();\n }\n });\n on(\"transitionStart\", ()=>{\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.loadOnTransitionStart || !swiper.params.lazy.loadOnTransitionStart && !initialImageLoaded) {\n if (swiper.params.lazy.checkInView) checkInViewOnLoad();\n else load();\n }\n }\n });\n on(\"transitionEnd\", ()=>{\n if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {\n if (swiper.params.lazy.checkInView) checkInViewOnLoad();\n else load();\n }\n });\n on(\"slideChange\", ()=>{\n const { lazy: lazy, cssMode: cssMode, watchSlidesProgress: watchSlidesProgress, touchReleaseOnEdges: touchReleaseOnEdges, resistanceRatio: resistanceRatio } = swiper.params;\n if (lazy.enabled && (cssMode || watchSlidesProgress && (touchReleaseOnEdges || resistanceRatio === 0))) load();\n });\n Object.assign(swiper.lazy, {\n load: load,\n loadInSlide: loadInSlide\n });\n}\n\n\n/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */ \nfunction $561315a2ed799cf8$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n controller: {\n control: undefined,\n inverse: false,\n by: \"slide\" // or 'container'\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) minIndex = guess;\n else maxIndex = guess;\n }\n return maxIndex;\n };\n }();\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n let i1;\n let i3;\n this.interpolate = function interpolate(x2) {\n if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n 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 } // xxx: for now i will just save one spline function to to\n function getInterpolateFunction(c) {\n if (!swiper.controller.spline) 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 // 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); // 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 controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n }\n if (swiper.params.controller.inverse) controlledTranslate = c.maxTranslate() - controlledTranslate;\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)if (controlled[i] !== byController && controlled[i] instanceof Swiper) setControlledTranslate(controlled[i]);\n } else if (controlled instanceof Swiper && byController !== controlled) setControlledTranslate(controlled);\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 c.setTransition(duration, swiper);\n if (duration !== 0) {\n c.transitionStart();\n if (c.params.autoHeight) (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n c.updateAutoHeight();\n });\n c.$wrapperEl.transitionEnd(()=>{\n if (!controlled) return;\n if (c.params.loop && swiper.params.controller.by === \"slide\") c.loopFix();\n c.transitionEnd();\n });\n }\n }\n if (Array.isArray(controlled)) {\n for(i = 0; i < controlled.length; i += 1)if (controlled[i] !== byController && controlled[i] instanceof Swiper) setControlledTransition(controlled[i]);\n } else if (controlled instanceof Swiper && byController !== controlled) setControlledTransition(controlled);\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 swiper.controller.control = swiper.params.controller.control;\n });\n on(\"update\", ()=>{\n removeSpline();\n });\n on(\"resize\", ()=>{\n removeSpline();\n });\n on(\"observerUpdate\", ()=>{\n removeSpline();\n });\n on(\"setTranslate\", (_s, translate, byController)=>{\n if (!swiper.controller.control) return;\n swiper.controller.setTranslate(translate, byController);\n });\n on(\"setTransition\", (_s, duration, byController)=>{\n if (!swiper.controller.control) return;\n swiper.controller.setTransition(duration, byController);\n });\n Object.assign(swiper.controller, {\n setTranslate: setTranslate,\n setTransition: setTransition\n });\n}\n\n\n\n\nfunction $fe3f6aaa25e9f5c2$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\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 }\n });\n let liveRegion = null;\n function notify(message) {\n const notification = liveRegion;\n if (notification.length === 0) return;\n notification.html(\"\");\n notification.html(message);\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.attr(\"tabIndex\", \"0\");\n }\n function makeElNotFocusable($el) {\n $el.attr(\"tabIndex\", \"-1\");\n }\n function addElRole($el, role) {\n $el.attr(\"role\", role);\n }\n function addElRoleDescription($el, description) {\n $el.attr(\"aria-roledescription\", description);\n }\n function addElControls($el, controls) {\n $el.attr(\"aria-controls\", controls);\n }\n function addElLabel($el, label) {\n $el.attr(\"aria-label\", label);\n }\n function addElId($el, id) {\n $el.attr(\"id\", id);\n }\n function addElLive($el, live) {\n $el.attr(\"aria-live\", live);\n }\n function disableEl($el) {\n $el.attr(\"aria-disabled\", true);\n }\n function enableEl($el) {\n $el.attr(\"aria-disabled\", false);\n }\n function onEnterOrSpaceKey(e) {\n if (e.keyCode !== 13 && e.keyCode !== 32) return;\n const params = swiper.params.a11y;\n const $targetEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(e.target);\n if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {\n if (!(swiper.isEnd && !swiper.params.loop)) swiper.slideNext();\n if (swiper.isEnd) notify(params.lastSlideMessage);\n else notify(params.nextSlideMessage);\n }\n if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {\n if (!(swiper.isBeginning && !swiper.params.loop)) swiper.slidePrev();\n if (swiper.isBeginning) notify(params.firstSlideMessage);\n else notify(params.prevSlideMessage);\n }\n if (swiper.pagination && $targetEl.is((0, $c149d04ee6362df0$export$2e2bcd8739ae039)(swiper.params.pagination.bulletClass))) $targetEl[0].click();\n }\n function updateNavigation() {\n if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;\n const { $nextEl: $nextEl, $prevEl: $prevEl } = swiper.navigation;\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n disableEl($prevEl);\n makeElNotFocusable($prevEl);\n } else {\n enableEl($prevEl);\n makeElFocusable($prevEl);\n }\n }\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n disableEl($nextEl);\n makeElNotFocusable($nextEl);\n } else {\n enableEl($nextEl);\n makeElFocusable($nextEl);\n }\n }\n }\n 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.each((bulletEl)=>{\n const $bulletEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(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\\}\\}/, $bulletEl.index() + 1));\n }\n }\n if ($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)) $bulletEl.attr(\"aria-current\", \"true\");\n else $bulletEl.removeAttr(\"aria-current\");\n });\n }\n const initNavEl = ($el, wrapperId, message)=>{\n makeElFocusable($el);\n if ($el[0].tagName !== \"BUTTON\") {\n addElRole($el, \"button\");\n $el.on(\"keydown\", onEnterOrSpaceKey);\n }\n addElLabel($el, message);\n addElControls($el, wrapperId);\n };\n function init() {\n const params = swiper.params.a11y;\n swiper.$el.append(liveRegion); // Container\n const $containerEl = swiper.$el;\n if (params.containerRoleDescriptionMessage) addElRoleDescription($containerEl, params.containerRoleDescriptionMessage);\n if (params.containerMessage) addElLabel($containerEl, params.containerMessage);\n // Wrapper\n const $wrapperEl = swiper.$wrapperEl;\n const wrapperId = $wrapperEl.attr(\"id\") || `swiper-wrapper-${getRandomNumber(16)}`;\n const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? \"off\" : \"polite\";\n addElId($wrapperEl, wrapperId);\n addElLive($wrapperEl, live); // Slide\n if (params.itemRoleDescriptionMessage) addElRoleDescription((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.slides), params.itemRoleDescriptionMessage);\n addElRole((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(swiper.slides), params.slideRole);\n const slidesLength = swiper.params.loop ? swiper.slides.filter((el)=>!el.classList.contains(swiper.params.slideDuplicateClass)).length : swiper.slides.length;\n swiper.slides.each((slideEl, index)=>{\n const $slideEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(slideEl);\n const slideIndex = swiper.params.loop ? parseInt($slideEl.attr(\"data-swiper-slide-index\"), 10) : index;\n const ariaLabelMessage = params.slideLabelMessage.replace(/\\{\\{index\\}\\}/, slideIndex + 1).replace(/\\{\\{slidesLength\\}\\}/, slidesLength);\n addElLabel($slideEl, ariaLabelMessage);\n }); // Navigation\n let $nextEl;\n let $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) $nextEl = swiper.navigation.$nextEl;\n if (swiper.navigation && swiper.navigation.$prevEl) $prevEl = swiper.navigation.$prevEl;\n if ($nextEl && $nextEl.length) initNavEl($nextEl, wrapperId, params.nextSlideMessage);\n if ($prevEl && $prevEl.length) initNavEl($prevEl, wrapperId, params.prevSlideMessage);\n // Pagination\n if (hasClickablePagination()) swiper.pagination.$el.on(\"keydown\", (0, $c149d04ee6362df0$export$2e2bcd8739ae039)(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n }\n function destroy() {\n if (liveRegion && liveRegion.length > 0) liveRegion.remove();\n let $nextEl;\n let $prevEl;\n if (swiper.navigation && swiper.navigation.$nextEl) $nextEl = swiper.navigation.$nextEl;\n if (swiper.navigation && swiper.navigation.$prevEl) $prevEl = swiper.navigation.$prevEl;\n if ($nextEl) $nextEl.off(\"keydown\", onEnterOrSpaceKey);\n if ($prevEl) $prevEl.off(\"keydown\", onEnterOrSpaceKey);\n // Pagination\n if (hasClickablePagination()) swiper.pagination.$el.off(\"keydown\", (0, $c149d04ee6362df0$export$2e2bcd8739ae039)(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n }\n on(\"beforeInit\", ()=>{\n liveRegion = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(``);\n });\n on(\"afterInit\", ()=>{\n if (!swiper.params.a11y.enabled) return;\n init();\n updateNavigation();\n });\n on(\"toEdge\", ()=>{\n if (!swiper.params.a11y.enabled) return;\n updateNavigation();\n });\n on(\"fromEdge\", ()=>{\n if (!swiper.params.a11y.enabled) return;\n updateNavigation();\n });\n on(\"paginationUpdate\", ()=>{\n if (!swiper.params.a11y.enabled) return;\n updatePagination();\n });\n on(\"destroy\", ()=>{\n if (!swiper.params.a11y.enabled) return;\n destroy();\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\nfunction $fce99e6fff63585e$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n history: {\n enabled: false,\n root: \"\",\n replaceState: false,\n key: \"slides\"\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 = (0, $101nH.getWindow)();\n let location;\n if (urlOverride) location = new URL(urlOverride);\n else location = window.location;\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: key,\n value: value\n };\n };\n const setHistory = (key, index)=>{\n const window = (0, $101nH.getWindow)();\n if (!initialized || !swiper.params.history.enabled) return;\n let location;\n if (swiper.params.url) location = new URL(swiper.params.url);\n else location = window.location;\n const slide = swiper.slides.eq(index);\n let value = slugify(slide.attr(\"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}/${value}`;\n } else if (!location.pathname.includes(key)) value = `${key}/${value}`;\n const currentState = window.history.state;\n if (currentState && currentState.value === value) return;\n if (swiper.params.history.replaceState) window.history.replaceState({\n value: value\n }, null, value);\n else window.history.pushState({\n value: value\n }, null, value);\n };\n const scrollToSlide = (speed, value, runCallbacks)=>{\n if (value) for(let i = 0, length = swiper.slides.length; i < length; i += 1){\n const slide = swiper.slides.eq(i);\n const slideHistory = slugify(slide.attr(\"data-history\"));\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n else swiper.slideTo(0, speed, runCallbacks);\n };\n const setHistoryPopState = ()=>{\n paths = getPathValues(swiper.params.url);\n scrollToSlide(swiper.params.speed, swiper.paths.value, false);\n };\n const init = ()=>{\n const window = (0, $101nH.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) return;\n scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n if (!swiper.params.history.replaceState) window.addEventListener(\"popstate\", setHistoryPopState);\n };\n const destroy = ()=>{\n const window = (0, $101nH.getWindow)();\n if (!swiper.params.history.replaceState) window.removeEventListener(\"popstate\", setHistoryPopState);\n };\n on(\"init\", ()=>{\n if (swiper.params.history.enabled) init();\n });\n on(\"destroy\", ()=>{\n if (swiper.params.history.enabled) destroy();\n });\n on(\"transitionEnd _freeModeNoMomentumRelease\", ()=>{\n if (initialized) setHistory(swiper.params.history.key, swiper.activeIndex);\n });\n on(\"slideChange\", ()=>{\n if (initialized && swiper.params.cssMode) setHistory(swiper.params.history.key, swiper.activeIndex);\n });\n}\n\n\n\nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $7ef992910ceea715$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, emit: emit, on: on }) {\n let initialized = false;\n const document = (0, $101nH.getDocument)();\n const window = (0, $101nH.getWindow)();\n extendParams({\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false\n }\n });\n const onHashChange = ()=>{\n emit(\"hashChange\");\n const newHash = document.location.hash.replace(\"#\", \"\");\n const activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr(\"data-hash\");\n if (newHash !== activeSlideHash) {\n const newIndex = swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash=\"${newHash}\"]`).index();\n if (typeof newIndex === \"undefined\") return;\n swiper.slideTo(newIndex);\n }\n };\n const setHash = ()=>{\n if (!initialized || !swiper.params.hashNavigation.enabled) return;\n if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr(\"data-hash\")}` || \"\");\n emit(\"hashSet\");\n } else {\n const slide = swiper.slides.eq(swiper.activeIndex);\n const hash = slide.attr(\"data-hash\") || slide.attr(\"data-history\");\n document.location.hash = hash || \"\";\n emit(\"hashSet\");\n }\n };\n 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 for(let i = 0, length = swiper.slides.length; i < length; i += 1){\n const slide = swiper.slides.eq(i);\n const slideHash = slide.attr(\"data-hash\") || slide.attr(\"data-history\");\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n if (swiper.params.hashNavigation.watchState) (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(window).on(\"hashchange\", onHashChange);\n };\n const destroy = ()=>{\n if (swiper.params.hashNavigation.watchState) (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(window).off(\"hashchange\", onHashChange);\n };\n on(\"init\", ()=>{\n if (swiper.params.hashNavigation.enabled) init();\n });\n on(\"destroy\", ()=>{\n if (swiper.params.hashNavigation.enabled) destroy();\n });\n on(\"transitionEnd _freeModeNoMomentumRelease\", ()=>{\n if (initialized) setHash();\n });\n on(\"slideChange\", ()=>{\n if (initialized && swiper.params.cssMode) setHash();\n });\n}\n\n\n/* eslint no-underscore-dangle: \"off\" */ /* eslint no-use-before-define: \"off\" */ \nvar $101nH = parcelRequire(\"101nH\");\n\nfunction $4bf9a5ab274c84eb$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on, emit: emit }) {\n let timeout;\n swiper.autoplay = {\n running: false,\n paused: false\n };\n extendParams({\n autoplay: {\n enabled: false,\n delay: 3000,\n waitForTransition: true,\n disableOnInteraction: true,\n stopOnLastSlide: false,\n reverseDirection: false,\n pauseOnMouseEnter: false\n }\n });\n function run() {\n const $activeSlideEl = swiper.slides.eq(swiper.activeIndex);\n let delay = swiper.params.autoplay.delay;\n if ($activeSlideEl.attr(\"data-swiper-autoplay\")) delay = $activeSlideEl.attr(\"data-swiper-autoplay\") || swiper.params.autoplay.delay;\n clearTimeout(timeout);\n timeout = (0, $3b5ddcf6fe080905$export$bdd553fddd433dcb)(()=>{\n let autoplayResult;\n if (swiper.params.autoplay.reverseDirection) {\n if (swiper.params.loop) {\n swiper.loopFix();\n autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else if (!swiper.isBeginning) {\n autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n autoplayResult = swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else stop();\n } else if (swiper.params.loop) {\n swiper.loopFix();\n autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else if (!swiper.isEnd) {\n autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n autoplayResult = swiper.slideTo(0, swiper.params.speed, true, true);\n emit(\"autoplay\");\n } else stop();\n if (swiper.params.cssMode && swiper.autoplay.running) run();\n else if (autoplayResult === false) run();\n }, delay);\n }\n function start() {\n if (typeof timeout !== \"undefined\") return false;\n if (swiper.autoplay.running) return false;\n swiper.autoplay.running = true;\n emit(\"autoplayStart\");\n run();\n return true;\n }\n function stop() {\n if (!swiper.autoplay.running) return false;\n if (typeof timeout === \"undefined\") return false;\n if (timeout) {\n clearTimeout(timeout);\n timeout = undefined;\n }\n swiper.autoplay.running = false;\n emit(\"autoplayStop\");\n return true;\n }\n function pause(speed) {\n if (!swiper.autoplay.running) return;\n if (swiper.autoplay.paused) return;\n if (timeout) clearTimeout(timeout);\n swiper.autoplay.paused = true;\n if (speed === 0 || !swiper.params.autoplay.waitForTransition) {\n swiper.autoplay.paused = false;\n run();\n } else [\n \"transitionend\",\n \"webkitTransitionEnd\"\n ].forEach((event)=>{\n swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd);\n });\n }\n function onVisibilityChange() {\n const document = (0, $101nH.getDocument)();\n if (document.visibilityState === \"hidden\" && swiper.autoplay.running) pause();\n if (document.visibilityState === \"visible\" && swiper.autoplay.paused) {\n run();\n swiper.autoplay.paused = false;\n }\n }\n function onTransitionEnd(e) {\n if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return;\n if (e.target !== swiper.$wrapperEl[0]) return;\n [\n \"transitionend\",\n \"webkitTransitionEnd\"\n ].forEach((event)=>{\n swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n });\n swiper.autoplay.paused = false;\n if (!swiper.autoplay.running) stop();\n else run();\n }\n function onMouseEnter() {\n if (swiper.params.autoplay.disableOnInteraction) stop();\n else pause();\n [\n \"transitionend\",\n \"webkitTransitionEnd\"\n ].forEach((event)=>{\n swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n });\n }\n function onMouseLeave() {\n if (swiper.params.autoplay.disableOnInteraction) return;\n swiper.autoplay.paused = false;\n run();\n }\n function attachMouseEvents() {\n if (swiper.params.autoplay.pauseOnMouseEnter) {\n swiper.$el.on(\"mouseenter\", onMouseEnter);\n swiper.$el.on(\"mouseleave\", onMouseLeave);\n }\n }\n function detachMouseEvents() {\n swiper.$el.off(\"mouseenter\", onMouseEnter);\n swiper.$el.off(\"mouseleave\", onMouseLeave);\n }\n on(\"init\", ()=>{\n if (swiper.params.autoplay.enabled) {\n start();\n const document = (0, $101nH.getDocument)();\n document.addEventListener(\"visibilitychange\", onVisibilityChange);\n attachMouseEvents();\n }\n });\n on(\"beforeTransitionStart\", (_s, speed, internal)=>{\n if (swiper.autoplay.running) {\n if (internal || !swiper.params.autoplay.disableOnInteraction) swiper.autoplay.pause(speed);\n else stop();\n }\n });\n on(\"sliderFirstMove\", ()=>{\n if (swiper.autoplay.running) {\n if (swiper.params.autoplay.disableOnInteraction) stop();\n else pause();\n }\n });\n on(\"touchEnd\", ()=>{\n if (swiper.params.cssMode && swiper.autoplay.paused && !swiper.params.autoplay.disableOnInteraction) run();\n });\n on(\"destroy\", ()=>{\n detachMouseEvents();\n if (swiper.autoplay.running) stop();\n const document = (0, $101nH.getDocument)();\n document.removeEventListener(\"visibilitychange\", onVisibilityChange);\n });\n Object.assign(swiper.autoplay, {\n pause: pause,\n run: run,\n start: start,\n stop: stop\n });\n}\n\n\n\n\nfunction $17f4a4f2ff0ef6a3$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\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) return;\n const clickedIndex = thumbsSwiper.clickedIndex;\n const clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;\n if (typeof clickedIndex === \"undefined\" || clickedIndex === null) return;\n let slideToIndex;\n if (thumbsSwiper.params.loop) slideToIndex = parseInt((0, $5172d1d318d9c216$export$2e2bcd8739ae039)(thumbsSwiper.clickedSlide).attr(\"data-swiper-slide-index\"), 10);\n else slideToIndex = clickedIndex;\n if (swiper.params.loop) {\n let currentIndex = swiper.activeIndex;\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix(); // eslint-disable-next-line\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n const prevIndex = swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n const nextIndex = swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n if (typeof prevIndex === \"undefined\") slideToIndex = nextIndex;\n else if (typeof nextIndex === \"undefined\") slideToIndex = prevIndex;\n else if (nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex = nextIndex;\n else slideToIndex = prevIndex;\n }\n swiper.slideTo(slideToIndex);\n }\n function init() {\n const { thumbs: thumbsParams } = 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 } else if ((0, $3b5ddcf6fe080905$export$a6cdc56e425d0d0a)(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.addClass(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) return;\n const slidesPerView = thumbsSwiper.params.slidesPerView === \"auto\" ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView;\n const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n let currentThumbsIndex = thumbsSwiper.activeIndex;\n let newThumbsIndex;\n let direction;\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix(); // eslint-disable-next-line\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n } // Find actual thumbs index to slide to\n const prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n const nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n if (typeof prevThumbsIndex === \"undefined\") newThumbsIndex = nextThumbsIndex;\n else if (typeof nextThumbsIndex === \"undefined\") newThumbsIndex = prevThumbsIndex;\n else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) newThumbsIndex = thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex : currentThumbsIndex;\n else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) newThumbsIndex = nextThumbsIndex;\n else newThumbsIndex = prevThumbsIndex;\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) newThumbsIndex += direction === \"next\" ? autoScrollOffset : -1 * autoScrollOffset;\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n else newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n } else newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup;\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n } // Activate thumbs\n let thumbsToActivate = 1;\n const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) thumbsToActivate = swiper.params.slidesPerView;\n if (!swiper.params.thumbs.multipleActiveThumbs) thumbsToActivate = 1;\n thumbsToActivate = Math.floor(thumbsToActivate);\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) for(let i = 0; i < thumbsToActivate; i += 1)thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).addClass(thumbActiveClass);\n else for(let i = 0; i < thumbsToActivate; i += 1)thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);\n }\n on(\"beforeInit\", ()=>{\n const { thumbs: thumbs } = swiper.params;\n if (!thumbs || !thumbs.swiper) return;\n init();\n update(true);\n });\n on(\"slideChange update resize observerUpdate\", ()=>{\n if (!swiper.thumbs.swiper) return;\n update();\n });\n on(\"setTransition\", (_s, duration)=>{\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n thumbsSwiper.setTransition(duration);\n });\n on(\"beforeDestroy\", ()=>{\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n if (swiperCreated && thumbsSwiper) thumbsSwiper.destroy();\n });\n Object.assign(swiper.thumbs, {\n init: init,\n update: update\n });\n}\n\n\n\nfunction $a02dba2b19d6df14$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, emit: emit, once: once }) {\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 onTouchMove() {\n const { touchEventsData: data, touches: touches } = swiper; // Velocity\n if (data.velocities.length === 0) data.velocities.push({\n position: touches[swiper.isHorizontal() ? \"startX\" : \"startY\"],\n time: data.touchStartTime\n });\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? \"currentX\" : \"currentY\"],\n time: (0, $3b5ddcf6fe080905$export$461939dd4422153)()\n });\n }\n function onTouchEnd({ currentPos: currentPos }) {\n const { params: params, $wrapperEl: $wrapperEl, rtlTranslate: rtl, snapGrid: snapGrid, touchEventsData: data } = swiper; // Time diff\n const touchEndTime = (0, $3b5ddcf6fe080905$export$461939dd4422153)();\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) swiper.slideTo(snapGrid.length - 1);\n else swiper.slideTo(swiper.slides.length - 1);\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) swiper.velocity = 0;\n // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n if (time > 150 || (0, $3b5ddcf6fe080905$export$461939dd4422153)() - lastMoveEvent.time > 300) swiper.velocity = 0;\n } else swiper.velocity = 0;\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) newPosition = swiper.maxTranslate() - bounceAmount;\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else newPosition = swiper.maxTranslate();\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) newPosition = swiper.minTranslate() + bounceAmount;\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else newPosition = swiper.minTranslate();\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)if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === \"next\") newPosition = snapGrid[nextSlide];\n else newPosition = snapGrid[nextSlide - 1];\n newPosition = -newPosition;\n }\n if (needsLoopFix) once(\"transitionEnd\", ()=>{\n swiper.loopFix();\n });\n // Fix duration\n if (swiper.velocity !== 0) {\n if (rtl) momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n else momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\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) momentumDuration = params.speed;\n else if (moveDistance < 2 * currentSlideSize) momentumDuration = params.speed * 1.5;\n else momentumDuration = params.speed * 2.5;\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 $wrapperEl.transitionEnd(()=>{\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n emit(\"momentumBounce\");\n swiper.setTransition(params.speed);\n setTimeout(()=>{\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(()=>{\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }, 0);\n });\n } else if (swiper.velocity) {\n emit(\"_freeModeNoMomentumRelease\");\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(()=>{\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }\n } else swiper.updateProgress(newPosition);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n } else if (params.freeMode) emit(\"_freeModeNoMomentumRelease\");\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 onTouchMove: onTouchMove,\n onTouchEnd: onTouchEnd\n }\n });\n}\n\n\nfunction $45f02e3844f02fdc$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams }) {\n extendParams({\n grid: {\n rows: 1,\n fill: \"column\"\n }\n });\n let slidesNumberEvenToRows;\n let slidesPerRow;\n let numFullColumns;\n const initSlides = (slidesLength)=>{\n const { slidesPerView: slidesPerView } = swiper.params;\n const { rows: rows, fill: fill } = swiper.params.grid;\n slidesPerRow = slidesNumberEvenToRows / rows;\n numFullColumns = Math.floor(slidesLength / rows);\n if (Math.floor(slidesLength / rows) === slidesLength / rows) slidesNumberEvenToRows = slidesLength;\n else slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows;\n if (slidesPerView !== \"auto\" && fill === \"row\") slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, slidesPerView * rows);\n };\n const updateSlide = (i, slide, slidesLength, getDirectionLabel)=>{\n const { slidesPerGroup: slidesPerGroup, spaceBetween: spaceBetween } = swiper.params;\n const { rows: rows, fill: fill } = swiper.params.grid; // Set slides order\n let newSlideOrderIndex;\n let column;\n let row;\n if (fill === \"row\" && slidesPerGroup > 1) {\n const groupIndex = Math.floor(i / (slidesPerGroup * rows));\n const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex;\n const columnsInGroup = groupIndex === 0 ? slidesPerGroup : Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);\n row = Math.floor(slideIndexInGroup / columnsInGroup);\n column = slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;\n newSlideOrderIndex = column + row * slidesNumberEvenToRows / rows;\n slide.css({\n \"-webkit-order\": newSlideOrderIndex,\n order: newSlideOrderIndex\n });\n } else if (fill === \"column\") {\n column = Math.floor(i / rows);\n row = i - column * rows;\n if (column > numFullColumns || column === numFullColumns && row === rows - 1) {\n row += 1;\n if (row >= rows) {\n row = 0;\n column += 1;\n }\n }\n } else {\n row = Math.floor(i / slidesPerRow);\n column = i - row * slidesPerRow;\n }\n slide.css(getDirectionLabel(\"margin-top\"), row !== 0 ? spaceBetween && `${spaceBetween}px` : \"\");\n };\n const updateWrapperSize = (slideSize, snapGrid, getDirectionLabel)=>{\n const { spaceBetween: spaceBetween, centeredSlides: centeredSlides, roundLengths: roundLengths } = swiper.params;\n const { rows: rows } = swiper.params.grid;\n swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows;\n swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween;\n swiper.$wrapperEl.css({\n [getDirectionLabel(\"width\")]: `${swiper.virtualSize + spaceBetween}px`\n });\n if (centeredSlides) {\n snapGrid.splice(0, snapGrid.length);\n const newSlidesGrid = [];\n for(let i = 0; i < snapGrid.length; i += 1){\n let slidesGridItem = snapGrid[i];\n if (roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);\n }\n snapGrid.push(...newSlidesGrid);\n }\n };\n swiper.grid = {\n initSlides: initSlides,\n updateSlide: updateSlide,\n updateWrapperSize: updateWrapperSize\n };\n}\n\n\nfunction $47cba5bd614d1591$export$2e2bcd8739ae039(slides) {\n const swiper = this;\n const { $wrapperEl: $wrapperEl, params: params } = swiper;\n if (params.loop) swiper.loopDestroy();\n if (typeof slides === \"object\" && \"length\" in slides) {\n for(let i = 0; i < slides.length; i += 1)if (slides[i]) $wrapperEl.append(slides[i]);\n } else $wrapperEl.append(slides);\n if (params.loop) swiper.loopCreate();\n if (!params.observer) swiper.update();\n}\n\n\nfunction $5118e534b77b7714$export$2e2bcd8739ae039(slides) {\n const swiper = this;\n const { params: params, $wrapperEl: $wrapperEl, activeIndex: activeIndex } = swiper;\n if (params.loop) swiper.loopDestroy();\n let newActiveIndex = activeIndex + 1;\n if (typeof slides === \"object\" && \"length\" in slides) {\n for(let i = 0; i < slides.length; i += 1)if (slides[i]) $wrapperEl.prepend(slides[i]);\n newActiveIndex = activeIndex + slides.length;\n } else $wrapperEl.prepend(slides);\n if (params.loop) swiper.loopCreate();\n if (!params.observer) swiper.update();\n swiper.slideTo(newActiveIndex, 0, false);\n}\n\n\nfunction $6f2201e0448c61a1$export$2e2bcd8739ae039(index, slides) {\n const swiper = this;\n const { $wrapperEl: $wrapperEl, params: params, activeIndex: activeIndex } = swiper;\n let activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children(`.${params.slideClass}`);\n }\n const baseLength = swiper.slides.length;\n if (index <= 0) {\n swiper.prependSlide(slides);\n return;\n }\n if (index >= baseLength) {\n swiper.appendSlide(slides);\n return;\n }\n let newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;\n const slidesBuffer = [];\n for(let i = baseLength - 1; i >= index; i -= 1){\n const currentSlide = swiper.slides.eq(i);\n currentSlide.remove();\n slidesBuffer.unshift(currentSlide);\n }\n if (typeof slides === \"object\" && \"length\" in slides) {\n for(let i = 0; i < slides.length; i += 1)if (slides[i]) $wrapperEl.append(slides[i]);\n newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;\n } else $wrapperEl.append(slides);\n for(let i = 0; i < slidesBuffer.length; i += 1)$wrapperEl.append(slidesBuffer[i]);\n if (params.loop) swiper.loopCreate();\n if (!params.observer) swiper.update();\n if (params.loop) swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n else swiper.slideTo(newActiveIndex, 0, false);\n}\n\n\nfunction $6e1eb1c852b27ebe$export$2e2bcd8739ae039(slidesIndexes) {\n const swiper = this;\n const { params: params, $wrapperEl: $wrapperEl, activeIndex: activeIndex } = swiper;\n let activeIndexBuffer = activeIndex;\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children(`.${params.slideClass}`);\n }\n let newActiveIndex = activeIndexBuffer;\n let indexToRemove;\n if (typeof slidesIndexes === \"object\" && \"length\" in slidesIndexes) {\n for(let i = 0; i < slidesIndexes.length; i += 1){\n indexToRemove = slidesIndexes[i];\n if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();\n if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n }\n newActiveIndex = Math.max(newActiveIndex, 0);\n } else {\n indexToRemove = slidesIndexes;\n if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();\n if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n newActiveIndex = Math.max(newActiveIndex, 0);\n }\n if (params.loop) swiper.loopCreate();\n if (!params.observer) swiper.update();\n if (params.loop) swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n else swiper.slideTo(newActiveIndex, 0, false);\n}\n\n\nfunction $5448b068026374e0$export$2e2bcd8739ae039() {\n const swiper = this;\n const slidesIndexes = [];\n for(let i = 0; i < swiper.slides.length; i += 1)slidesIndexes.push(i);\n swiper.removeSlide(slidesIndexes);\n}\n\n\nfunction $df3643fb44988378$export$2e2bcd8739ae039({ swiper: swiper }) {\n Object.assign(swiper, {\n appendSlide: (0, $47cba5bd614d1591$export$2e2bcd8739ae039).bind(swiper),\n prependSlide: (0, $5118e534b77b7714$export$2e2bcd8739ae039).bind(swiper),\n addSlide: (0, $6f2201e0448c61a1$export$2e2bcd8739ae039).bind(swiper),\n removeSlide: (0, $6e1eb1c852b27ebe$export$2e2bcd8739ae039).bind(swiper),\n removeAllSlides: (0, $5448b068026374e0$export$2e2bcd8739ae039).bind(swiper)\n });\n}\n\n\nfunction $5b27eece2262ddde$export$2e2bcd8739ae039(params) {\n const { effect: effect, swiper: swiper, on: on, setTranslate: setTranslate, setTransition: setTransition, overwriteParams: overwriteParams, perspective: perspective } = params;\n on(\"beforeInit\", ()=>{\n if (swiper.params.effect !== effect) return;\n swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);\n if (perspective && perspective()) swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);\n const overwriteParamsResult = overwriteParams ? overwriteParams() : {};\n Object.assign(swiper.params, overwriteParamsResult);\n Object.assign(swiper.originalParams, overwriteParamsResult);\n });\n on(\"setTranslate\", ()=>{\n if (swiper.params.effect !== effect) return;\n setTranslate();\n });\n on(\"setTransition\", (_s, duration)=>{\n if (swiper.params.effect !== effect) return;\n setTransition(duration);\n });\n}\n\n\nfunction $25ad290d0538560d$export$2e2bcd8739ae039(effectParams, $slideEl) {\n if (effectParams.transformEl) return $slideEl.find(effectParams.transformEl).css({\n \"backface-visibility\": \"hidden\",\n \"-webkit-backface-visibility\": \"hidden\"\n });\n return $slideEl;\n}\n\n\nfunction $f94ef5c7b60f41aa$export$2e2bcd8739ae039({ swiper: swiper, duration: duration, transformEl: transformEl, allSlides: allSlides }) {\n const { slides: slides, activeIndex: activeIndex, $wrapperEl: $wrapperEl } = swiper;\n if (swiper.params.virtualTranslate && duration !== 0) {\n let eventTriggered = false;\n let $transitionEndTarget;\n if (allSlides) $transitionEndTarget = transformEl ? slides.find(transformEl) : slides;\n else $transitionEndTarget = transformEl ? slides.eq(activeIndex).find(transformEl) : slides.eq(activeIndex);\n $transitionEndTarget.transitionEnd(()=>{\n if (eventTriggered) return;\n if (!swiper || swiper.destroyed) return;\n eventTriggered = true;\n swiper.animating = false;\n const triggerEvents = [\n \"webkitTransitionEnd\",\n \"transitionend\"\n ];\n for(let i = 0; i < triggerEvents.length; i += 1)$wrapperEl.trigger(triggerEvents[i]);\n });\n }\n}\n\n\nfunction $85f77ad10ff3a47c$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n fadeEffect: {\n crossFade: false,\n transformEl: null\n }\n });\n const setTranslate = ()=>{\n const { slides: slides } = swiper;\n const params = swiper.params.fadeEffect;\n for(let i = 0; i < slides.length; i += 1){\n const $slideEl = swiper.slides.eq(i);\n const offset = $slideEl[0].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[0].progress), 0) : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0);\n const $targetEl = (0, $25ad290d0538560d$export$2e2bcd8739ae039)(params, $slideEl);\n $targetEl.css({\n opacity: slideOpacity\n }).transform(`translate3d(${tx}px, ${ty}px, 0px)`);\n }\n };\n const setTransition = (duration)=>{\n const { transformEl: transformEl } = swiper.params.fadeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration);\n (0, $f94ef5c7b60f41aa$export$2e2bcd8739ae039)({\n swiper: swiper,\n duration: duration,\n transformEl: transformEl,\n allSlides: true\n });\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"fade\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n overwriteParams: ()=>({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n\n\n\n\nfunction $3422a46b8f7777a5$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94\n }\n });\n const setTranslate = ()=>{\n const { $el: $el, $wrapperEl: $wrapperEl, slides: slides, width: swiperWidth, height: swiperHeight, rtlTranslate: rtl, size: swiperSize, browser: browser } = 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 = $wrapperEl.find(\".swiper-cube-shadow\");\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)('
');\n $wrapperEl.append($cubeShadowEl);\n }\n $cubeShadowEl.css({\n height: `${swiperWidth}px`\n });\n } else {\n $cubeShadowEl = $el.find(\".swiper-cube-shadow\");\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)('
');\n $el.append($cubeShadowEl);\n }\n }\n }\n for(let i = 0; i < slides.length; i += 1){\n const $slideEl = slides.eq(i);\n let slideIndex = i;\n if (isVirtual) slideIndex = parseInt($slideEl.attr(\"data-swiper-slide-index\"), 10);\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[0].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) tx = -tx;\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.transform(transform);\n if (params.slideShadows) {\n // Set shadows\n let shadowBefore = isHorizontal ? $slideEl.find(\".swiper-slide-shadow-left\") : $slideEl.find(\".swiper-slide-shadow-top\");\n let shadowAfter = isHorizontal ? $slideEl.find(\".swiper-slide-shadow-right\") : $slideEl.find(\".swiper-slide-shadow-bottom\");\n if (shadowBefore.length === 0) {\n shadowBefore = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(`
`);\n $slideEl.append(shadowBefore);\n }\n if (shadowAfter.length === 0) {\n shadowAfter = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(`
`);\n $slideEl.append(shadowAfter);\n }\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n }\n }\n $wrapperEl.css({\n \"-webkit-transform-origin\": `50% 50% -${swiperSize / 2}px`,\n \"transform-origin\": `50% 50% -${swiperSize / 2}px`\n });\n if (params.shadow) {\n if (isHorizontal) $cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);\n else {\n const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;\n const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);\n const scale1 = params.shadowScale;\n const scale2 = params.shadowScale / multiplier;\n const offset = params.shadowOffset;\n $cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);\n }\n }\n const zFactor = browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0;\n $wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`);\n };\n const setTransition = (duration)=>{\n const { $el: $el, slides: slides } = swiper;\n slides.transition(duration).find(\".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left\").transition(duration);\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) $el.find(\".swiper-cube-shadow\").transition(duration);\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"cube\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n perspective: ()=>true,\n overwriteParams: ()=>({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n resistanceRatio: 0,\n spaceBetween: 0,\n centeredSlides: false,\n virtualTranslate: true\n })\n });\n}\n\n\n\nfunction $98c68cb457f5085f$export$2e2bcd8739ae039(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : \"\"}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n if (!$shadowEl.length) {\n $shadowEl = (0, $5172d1d318d9c216$export$2e2bcd8739ae039)(`
`);\n $shadowContainer.append($shadowEl);\n }\n return $shadowEl;\n}\n\n\n\n\n\nfunction $9f09f65d9f374949$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n transformEl: null\n }\n });\n const setTranslate = ()=>{\n const { slides: slides, rtlTranslate: rtl } = swiper;\n const params = swiper.params.flipEffect;\n for(let i = 0; i < slides.length; i += 1){\n const $slideEl = slides.eq(i);\n let progress = $slideEl[0].progress;\n if (swiper.params.flipEffect.limitRotation) progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n const offset = $slideEl[0].swiperSlideOffset;\n const rotate = -180 * progress;\n let rotateY = rotate;\n let rotateX = 0;\n let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let ty = 0;\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) rotateY = -rotateY;\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n if (params.slideShadows) {\n // Set shadows\n let shadowBefore = swiper.isHorizontal() ? $slideEl.find(\".swiper-slide-shadow-left\") : $slideEl.find(\".swiper-slide-shadow-top\");\n let shadowAfter = swiper.isHorizontal() ? $slideEl.find(\".swiper-slide-shadow-right\") : $slideEl.find(\".swiper-slide-shadow-bottom\");\n if (shadowBefore.length === 0) shadowBefore = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl, swiper.isHorizontal() ? \"left\" : \"top\");\n if (shadowAfter.length === 0) shadowAfter = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl, swiper.isHorizontal() ? \"right\" : \"bottom\");\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n }\n const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;\n const $targetEl = (0, $25ad290d0538560d$export$2e2bcd8739ae039)(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n const setTransition = (duration)=>{\n const { transformEl: transformEl } = swiper.params.flipEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find(\".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left\").transition(duration);\n (0, $f94ef5c7b60f41aa$export$2e2bcd8739ae039)({\n swiper: swiper,\n duration: duration,\n transformEl: transformEl\n });\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"flip\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n perspective: ()=>true,\n overwriteParams: ()=>({\n slidesPerView: 1,\n slidesPerGroup: 1,\n watchSlidesProgress: true,\n spaceBetween: 0,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n\n\n\n\n\nfunction $cbb6bfced20b97fb$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n const setTranslate = ()=>{\n const { width: swiperWidth, height: swiperHeight, slides: slides, slidesSizesGrid: slidesSizesGrid } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n for(let i = 0, length = slides.length; i < length; i += 1){\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const offsetMultiplier = (center - slideOffset - slideSize / 2) / slideSize * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n if (typeof stretch === \"string\" && stretch.indexOf(\"%\") !== -1) stretch = parseFloat(params.stretch) / 100 * slideSize;\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n 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 = (0, $25ad290d0538560d$export$2e2bcd8739ae039)(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find(\".swiper-slide-shadow-left\") : $slideEl.find(\".swiper-slide-shadow-top\");\n let $shadowAfterEl = isHorizontal ? $slideEl.find(\".swiper-slide-shadow-right\") : $slideEl.find(\".swiper-slide-shadow-bottom\");\n if ($shadowBeforeEl.length === 0) $shadowBeforeEl = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl, isHorizontal ? \"left\" : \"top\");\n if ($shadowAfterEl.length === 0) $shadowAfterEl = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl, isHorizontal ? \"right\" : \"bottom\");\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n const setTransition = (duration)=>{\n const { transformEl: transformEl } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find(\".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left\").transition(duration);\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"coverflow\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n perspective: ()=>true,\n overwriteParams: ()=>({\n watchSlidesProgress: true\n })\n });\n}\n\n\n\n\n\n\nfunction $59b673d2f7d1d598$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n creativeEffect: {\n transformEl: null,\n limitProgress: 1,\n shadowPerProgress: false,\n progressMultiplier: 1,\n perspective: true,\n prev: {\n translate: [\n 0,\n 0,\n 0\n ],\n rotate: [\n 0,\n 0,\n 0\n ],\n opacity: 1,\n scale: 1\n },\n next: {\n translate: [\n 0,\n 0,\n 0\n ],\n rotate: [\n 0,\n 0,\n 0\n ],\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 { slides: slides, $wrapperEl: $wrapperEl, slidesSizesGrid: slidesSizesGrid } = swiper;\n const params = swiper.params.creativeEffect;\n const { progressMultiplier: multiplier } = params;\n const isCenteredSlides = swiper.params.centeredSlides;\n if (isCenteredSlides) {\n const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);\n }\n for(let i = 0; i < slides.length; i += 1){\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);\n let originalProgress = progress;\n if (!isCenteredSlides) originalProgress = Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);\n const offset = $slideEl[0].swiperSlideOffset;\n const t = [\n swiper.params.cssMode ? -offset - swiper.translate : -offset,\n 0,\n 0\n ];\n const r = [\n 0,\n 0,\n 0\n ];\n let custom = false;\n if (!swiper.isHorizontal()) {\n t[1] = t[0];\n t[0] = 0;\n }\n let data = {\n translate: [\n 0,\n 0,\n 0\n ],\n rotate: [\n 0,\n 0,\n 0\n ],\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 } // set translate\n t.forEach((value, index)=>{\n t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n }); // set rotates\n r.forEach((value, index)=>{\n r[index] = data.rotate[index] * Math.abs(progress * multiplier);\n });\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const translateString = t.join(\", \");\n const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;\n const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;\n const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;\n const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows\n if (custom && data.shadow || !custom) {\n let $shadowEl = $slideEl.children(\".swiper-slide-shadow\");\n if ($shadowEl.length === 0 && data.shadow) $shadowEl = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl);\n if ($shadowEl.length) {\n const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n $shadowEl[0].style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n }\n }\n const $targetEl = (0, $25ad290d0538560d$export$2e2bcd8739ae039)(params, $slideEl);\n $targetEl.transform(transform).css({\n opacity: opacityString\n });\n if (data.origin) $targetEl.css(\"transform-origin\", data.origin);\n }\n };\n const setTransition = (duration)=>{\n const { transformEl: transformEl } = swiper.params.creativeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find(\".swiper-slide-shadow\").transition(duration);\n (0, $f94ef5c7b60f41aa$export$2e2bcd8739ae039)({\n swiper: swiper,\n duration: duration,\n transformEl: transformEl,\n allSlides: true\n });\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"creative\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n perspective: ()=>swiper.params.creativeEffect.perspective,\n overwriteParams: ()=>({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n\n\n\n\n\n\nfunction $57d98b66e9d18969$export$2e2bcd8739ae039({ swiper: swiper, extendParams: extendParams, on: on }) {\n extendParams({\n cardsEffect: {\n slideShadows: true,\n transformEl: null\n }\n });\n const setTranslate = ()=>{\n const { slides: slides, activeIndex: activeIndex } = swiper;\n const params = swiper.params.cardsEffect;\n const { startTranslate: startTranslate, isTouched: isTouched } = swiper.touchEventsData;\n const currentTranslate = swiper.translate;\n for(let i = 0; i < slides.length; i += 1){\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max(slideProgress, -4), 4);\n let offset = $slideEl[0].swiperSlideOffset;\n if (swiper.params.centeredSlides && !swiper.params.cssMode) swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);\n if (swiper.params.centeredSlides && swiper.params.cssMode) offset -= slides[0].swiperSlideOffset;\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 = -2 * progress;\n let tXAdd = 8 - Math.abs(progress) * 0.75;\n const isSwipeToNext = (i === activeIndex || i === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;\n const isSwipeToPrev = (i === activeIndex || i === 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) // next\n tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;\n else if (progress > 0) // prev\n tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;\n else tX = `${tX}px`;\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(${rotate}deg)\n scale(${scaleString})\n `;\n if (params.slideShadows) {\n // Set shadows\n let $shadowEl = $slideEl.find(\".swiper-slide-shadow\");\n if ($shadowEl.length === 0) $shadowEl = (0, $98c68cb457f5085f$export$2e2bcd8739ae039)(params, $slideEl);\n if ($shadowEl.length) $shadowEl[0].style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n }\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const $targetEl = (0, $25ad290d0538560d$export$2e2bcd8739ae039)(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n const setTransition = (duration)=>{\n const { transformEl: transformEl } = swiper.params.cardsEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find(\".swiper-slide-shadow\").transition(duration);\n (0, $f94ef5c7b60f41aa$export$2e2bcd8739ae039)({\n swiper: swiper,\n duration: duration,\n transformEl: transformEl\n });\n };\n (0, $5b27eece2262ddde$export$2e2bcd8739ae039)({\n effect: \"cards\",\n swiper: swiper,\n on: on,\n setTranslate: setTranslate,\n setTransition: setTransition,\n perspective: ()=>true,\n overwriteParams: ()=>({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}\n\n\n\n\n(0, $7923a396d019f6bb$export$2e2bcd8739ae039).use([\n (0, $195a45db380e21d8$export$2e2bcd8739ae039),\n (0, $d3de1033415288cd$export$2e2bcd8739ae039),\n (0, $4bf9a5ab274c84eb$export$2e2bcd8739ae039)\n]);\n// Swipers\nconst $307ade30fbf6a1ec$var$swiperHero = new (0, $7923a396d019f6bb$export$2e2bcd8739ae039)(\".swiper-hero\", {\n pagination: {\n el: \".swiper-pagination\"\n },\n navigation: {\n nextEl: \".swiper-hero-next\",\n prevEl: \".swiper-hero-prev\"\n },\n loop: true,\n autoplay: {\n delay: 8000\n }\n});\nconst $307ade30fbf6a1ec$var$swiperReview = new (0, $7923a396d019f6bb$export$2e2bcd8739ae039)(\".swiper-review\", {\n // Local parameters\n centeredSlides: true,\n loop: true,\n autoplay: true,\n // Responsive breakpoints\n breakpoints: {\n 320: {\n slidesPerView: 1\n },\n 900: {\n slidesPerView: \"auto\"\n }\n },\n navigation: {\n nextEl: \".swiper-button-next\",\n prevEl: \".swiper-button-prev\"\n }\n});\nconst $307ade30fbf6a1ec$var$swiperMenu = new (0, $7923a396d019f6bb$export$2e2bcd8739ae039)(\".swiper-menu\", {\n // Local parameters\n centeredSlides: true,\n // Responsive breakpoints\n breakpoints: {\n 320: {\n slidesPerView: 1,\n spaceBetween: 10\n },\n 900: {\n slidesPerView: \"auto\",\n spaceBetween: 70\n }\n },\n navigation: {\n nextEl: \".swiper-button-next\",\n prevEl: \".swiper-button-prev\"\n }\n});\n// Mobile navigation\n// - Lock scroll on Mobile Navigation\nconst $307ade30fbf6a1ec$var$navToggle = document.querySelector(\"#nav-toggle\");\n$307ade30fbf6a1ec$var$navToggle.addEventListener(\"click\", (e)=>{\n const navLayout = document.querySelector(\".header-nav__mobile\");\n $307ade30fbf6a1ec$var$navToggle.classList.toggle(\"nav-toggle--active\");\n navLayout.classList.toggle(\"header-nav__mobile--open\");\n});\n// Menu-block Arrows\nconst $307ade30fbf6a1ec$var$mondayToggle = document.querySelector(\"#monday-toggle\");\nconst $307ade30fbf6a1ec$var$tuesdayToggle = document.querySelector(\"#tuesday-toggle\");\nconst $307ade30fbf6a1ec$var$wednesdayToggle = document.querySelector(\"#wednesday-toggle\");\nconst $307ade30fbf6a1ec$var$thursdayToggle = document.querySelector(\"#thursday-toggle\");\nconst $307ade30fbf6a1ec$var$fridayToggle = document.querySelector(\"#friday-toggle\");\nif (document.body.contains($307ade30fbf6a1ec$var$mondayToggle)) $307ade30fbf6a1ec$var$mondayToggle.addEventListener(\"click\", (e)=>{\n $307ade30fbf6a1ec$var$mondayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\");\n});\nif (document.body.contains($307ade30fbf6a1ec$var$tuesdayToggle)) $307ade30fbf6a1ec$var$tuesdayToggle.addEventListener(\"click\", (e)=>{\n $307ade30fbf6a1ec$var$tuesdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\");\n});\nif (document.body.contains($307ade30fbf6a1ec$var$wednesdayToggle)) $307ade30fbf6a1ec$var$wednesdayToggle.addEventListener(\"click\", (e)=>{\n $307ade30fbf6a1ec$var$wednesdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\");\n});\nif (document.body.contains($307ade30fbf6a1ec$var$thursdayToggle)) $307ade30fbf6a1ec$var$thursdayToggle.addEventListener(\"click\", (e)=>{\n $307ade30fbf6a1ec$var$thursdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\");\n});\nif (document.body.contains($307ade30fbf6a1ec$var$fridayToggle)) $307ade30fbf6a1ec$var$fridayToggle.addEventListener(\"click\", (e)=>{\n $307ade30fbf6a1ec$var$fridayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\");\n});\n// Window Scroll Header\nwindow.onscroll = function() {\n $307ade30fbf6a1ec$var$scrollFunction();\n};\nfunction $307ade30fbf6a1ec$var$scrollFunction() {\n const header = document.querySelector(\".nav-layout\");\n if (document.body.scrollTop > 50 || document.documentElement.scrollTop > 50) document.getElementById(\"header-logo\").style.height = \"60px\";\n else document.getElementById(\"header-logo\").style.height = \"74px\";\n}\n\n\n//# sourceMappingURL=main.js.map\n","/**\n * Dom7 4.0.6\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2023, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: February 2, 2023\n */\nimport { getWindow, getDocument } from 'ssr-window';\n\n/* eslint-disable no-proto */\nfunction makeReactive(obj) {\n const proto = obj.__proto__;\n Object.defineProperty(obj, '__proto__', {\n get() {\n return proto;\n },\n\n set(value) {\n proto.__proto__ = value;\n }\n\n });\n}\n\nclass Dom7 extends Array {\n constructor(items) {\n if (typeof items === 'number') {\n super(items);\n } else {\n super(...(items || []));\n makeReactive(this);\n }\n }\n\n}\n\nfunction arrayFlat(arr = []) {\n const res = [];\n arr.forEach(el => {\n if (Array.isArray(el)) {\n res.push(...arrayFlat(el));\n } else {\n res.push(el);\n }\n });\n return res;\n}\nfunction arrayFilter(arr, callback) {\n return Array.prototype.filter.call(arr, callback);\n}\nfunction arrayUnique(arr) {\n const uniqueArray = [];\n\n for (let i = 0; i < arr.length; i += 1) {\n if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);\n }\n\n return uniqueArray;\n}\nfunction toCamelCase(string) {\n return string.toLowerCase().replace(/-(.)/g, (match, group) => group.toUpperCase());\n}\n\n// eslint-disable-next-line\n\nfunction qsa(selector, context) {\n if (typeof selector !== 'string') {\n return [selector];\n }\n\n const a = [];\n const res = context.querySelectorAll(selector);\n\n for (let i = 0; i < res.length; i += 1) {\n a.push(res[i]);\n }\n\n return a;\n}\n\nfunction $(selector, context) {\n const window = getWindow();\n const document = getDocument();\n let arr = [];\n\n if (!context && selector instanceof Dom7) {\n return selector;\n }\n\n if (!selector) {\n return new Dom7(arr);\n }\n\n if (typeof selector === 'string') {\n const html = selector.trim();\n\n if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n let toCreate = 'div';\n if (html.indexOf(' c.split(' ')));\n this.forEach(el => {\n el.classList.add(...classNames);\n });\n return this;\n}\n\nfunction removeClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n el.classList.remove(...classNames);\n });\n return this;\n}\n\nfunction toggleClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n classNames.forEach(className => {\n el.classList.toggle(className);\n });\n });\n}\n\nfunction hasClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n return arrayFilter(this, el => {\n return classNames.filter(className => el.classList.contains(className)).length > 0;\n }).length > 0;\n}\n\nfunction attr(attrs, value) {\n if (arguments.length === 1 && typeof attrs === 'string') {\n // Get attr\n if (this[0]) return this[0].getAttribute(attrs);\n return undefined;\n } // Set attrs\n\n\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i].setAttribute(attrs, value);\n } else {\n // Object\n for (const attrName in attrs) {\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n }\n\n return this;\n}\n\nfunction removeAttr(attr) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].removeAttribute(attr);\n }\n\n return this;\n}\n\nfunction prop(props, value) {\n if (arguments.length === 1 && typeof props === 'string') {\n // Get prop\n if (this[0]) return this[0][props];\n } else {\n // Set props\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i][props] = value;\n } else {\n // Object\n for (const propName in props) {\n this[i][propName] = props[propName];\n }\n }\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction data(key, value) {\n let el;\n\n if (typeof value === 'undefined') {\n el = this[0];\n if (!el) return undefined; // Get value\n\n if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) {\n return el.dom7ElementDataStorage[key];\n }\n\n const dataKey = el.getAttribute(`data-${key}`);\n\n if (dataKey) {\n return dataKey;\n }\n\n return undefined;\n } // Set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n el = this[i];\n if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};\n el.dom7ElementDataStorage[key] = value;\n }\n\n return this;\n}\n\nfunction removeData(key) {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {\n el.dom7ElementDataStorage[key] = null;\n delete el.dom7ElementDataStorage[key];\n }\n }\n}\n\nfunction dataset() {\n const el = this[0];\n if (!el) return undefined;\n const dataset = {}; // eslint-disable-line\n\n if (el.dataset) {\n for (const dataKey in el.dataset) {\n dataset[dataKey] = el.dataset[dataKey];\n }\n } else {\n for (let i = 0; i < el.attributes.length; i += 1) {\n const attr = el.attributes[i];\n\n if (attr.name.indexOf('data-') >= 0) {\n dataset[toCamelCase(attr.name.split('data-')[1])] = attr.value;\n }\n }\n }\n\n for (const key in dataset) {\n if (dataset[key] === 'false') dataset[key] = false;else if (dataset[key] === 'true') dataset[key] = true;else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;\n }\n\n return dataset;\n}\n\nfunction val(value) {\n if (typeof value === 'undefined') {\n // get value\n const el = this[0];\n if (!el) return undefined;\n\n if (el.multiple && el.nodeName.toLowerCase() === 'select') {\n const values = [];\n\n for (let i = 0; i < el.selectedOptions.length; i += 1) {\n values.push(el.selectedOptions[i].value);\n }\n\n return values;\n }\n\n return el.value;\n } // set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === 'select') {\n for (let j = 0; j < el.options.length; j += 1) {\n el.options[j].selected = value.indexOf(el.options[j].value) >= 0;\n }\n } else {\n el.value = value;\n }\n }\n\n return this;\n}\n\nfunction value(value) {\n return this.val(value);\n}\n\nfunction transform(transform) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transform = transform;\n }\n\n return this;\n}\n\nfunction transition(duration) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transitionDuration = typeof duration !== 'string' ? `${duration}ms` : duration;\n }\n\n return this;\n}\n\nfunction on(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n\n function handleLiveEvent(e) {\n const target = e.target;\n if (!target) return;\n const eventData = e.target.dom7EventData || [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n if ($(target).is(targetSelector)) listener.apply(target, eventData);else {\n const parents = $(target).parents(); // eslint-disable-line\n\n for (let k = 0; k < parents.length; k += 1) {\n if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);\n }\n }\n }\n\n function handleEvent(e) {\n const eventData = e && e.target ? e.target.dom7EventData || [] : [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n listener.apply(this, eventData);\n }\n\n const events = eventType.split(' ');\n let j;\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (!targetSelector) {\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7Listeners) el.dom7Listeners = {};\n if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];\n el.dom7Listeners[event].push({\n listener,\n proxyListener: handleEvent\n });\n el.addEventListener(event, handleEvent, capture);\n }\n } else {\n // Live events\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7LiveListeners) el.dom7LiveListeners = {};\n if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];\n el.dom7LiveListeners[event].push({\n listener,\n proxyListener: handleLiveEvent\n });\n el.addEventListener(event, handleLiveEvent, capture);\n }\n }\n }\n\n return this;\n}\n\nfunction off(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n const events = eventType.split(' ');\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n let handlers;\n\n if (!targetSelector && el.dom7Listeners) {\n handlers = el.dom7Listeners[event];\n } else if (targetSelector && el.dom7LiveListeners) {\n handlers = el.dom7LiveListeners[event];\n }\n\n if (handlers && handlers.length) {\n for (let k = handlers.length - 1; k >= 0; k -= 1) {\n const handler = handlers[k];\n\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n }\n\n return this;\n}\n\nfunction once(...args) {\n const dom = this;\n let [eventName, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventName, listener, capture] = args;\n targetSelector = undefined;\n }\n\n function onceHandler(...eventArgs) {\n listener.apply(this, eventArgs);\n dom.off(eventName, targetSelector, onceHandler, capture);\n\n if (onceHandler.dom7proxy) {\n delete onceHandler.dom7proxy;\n }\n }\n\n onceHandler.dom7proxy = listener;\n return dom.on(eventName, targetSelector, onceHandler, capture);\n}\n\nfunction trigger(...args) {\n const window = getWindow();\n const events = args[0].split(' ');\n const eventData = args[1];\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n\n if (window.CustomEvent) {\n const evt = new window.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true\n });\n el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0);\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n }\n\n return this;\n}\n\nfunction transitionStart(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionstart', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionstart', fireCallBack);\n }\n\n return this;\n}\n\nfunction transitionEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionend', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionend', fireCallBack);\n }\n\n return this;\n}\n\nfunction animationEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('animationend', fireCallBack);\n }\n\n if (callback) {\n dom.on('animationend', fireCallBack);\n }\n\n return this;\n}\n\nfunction width() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerWidth;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('width'));\n }\n\n return null;\n}\n\nfunction outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n }\n\n return this[0].offsetWidth;\n }\n\n return null;\n}\n\nfunction height() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerHeight;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('height'));\n }\n\n return null;\n}\n\nfunction outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n }\n\n return this[0].offsetHeight;\n }\n\n return null;\n}\n\nfunction offset() {\n if (this.length > 0) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n const box = el.getBoundingClientRect();\n const body = document.body;\n const clientTop = el.clientTop || body.clientTop || 0;\n const clientLeft = el.clientLeft || body.clientLeft || 0;\n const scrollTop = el === window ? window.scrollY : el.scrollTop;\n const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n return {\n top: box.top + scrollTop - clientTop,\n left: box.left + scrollLeft - clientLeft\n };\n }\n\n return null;\n}\n\nfunction hide() {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.display = 'none';\n }\n\n return this;\n}\n\nfunction show() {\n const window = getWindow();\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.style.display === 'none') {\n el.style.display = '';\n }\n\n if (window.getComputedStyle(el, null).getPropertyValue('display') === 'none') {\n // Still not visible\n el.style.display = 'block';\n }\n }\n\n return this;\n}\n\nfunction styles() {\n const window = getWindow();\n if (this[0]) return window.getComputedStyle(this[0], null);\n return {};\n}\n\nfunction css(props, value) {\n const window = getWindow();\n let i;\n\n if (arguments.length === 1) {\n if (typeof props === 'string') {\n // .css('width')\n if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);\n } else {\n // .css({ width: '100px' })\n for (i = 0; i < this.length; i += 1) {\n for (const prop in props) {\n this[i].style[prop] = props[prop];\n }\n }\n\n return this;\n }\n }\n\n if (arguments.length === 2 && typeof props === 'string') {\n // .css('width', '100px')\n for (i = 0; i < this.length; i += 1) {\n this[i].style[props] = value;\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction each(callback) {\n if (!callback) return this;\n this.forEach((el, index) => {\n callback.apply(el, [el, index]);\n });\n return this;\n}\n\nfunction filter(callback) {\n const result = arrayFilter(this, callback);\n return $(result);\n}\n\nfunction html(html) {\n if (typeof html === 'undefined') {\n return this[0] ? this[0].innerHTML : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].innerHTML = html;\n }\n\n return this;\n}\n\nfunction text(text) {\n if (typeof text === 'undefined') {\n return this[0] ? this[0].textContent.trim() : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].textContent = text;\n }\n\n return this;\n}\n\nfunction is(selector) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n let compareWith;\n let i;\n if (!el || typeof selector === 'undefined') return false;\n\n if (typeof selector === 'string') {\n if (el.matches) return el.matches(selector);\n if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);\n if (el.msMatchesSelector) return el.msMatchesSelector(selector);\n compareWith = $(selector);\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n if (selector === document) {\n return el === document;\n }\n\n if (selector === window) {\n return el === window;\n }\n\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [selector] : selector;\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n return false;\n}\n\nfunction index() {\n let child = this[0];\n let i;\n\n if (child) {\n i = 0; // eslint-disable-next-line\n\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) i += 1;\n }\n\n return i;\n }\n\n return undefined;\n}\n\nfunction eq(index) {\n if (typeof index === 'undefined') return this;\n const length = this.length;\n\n if (index > length - 1) {\n return $([]);\n }\n\n if (index < 0) {\n const returnIndex = length + index;\n if (returnIndex < 0) return $([]);\n return $([this[returnIndex]]);\n }\n\n return $([this[index]]);\n}\n\nfunction append(...els) {\n let newChild;\n const document = getDocument();\n\n for (let k = 0; k < els.length; k += 1) {\n newChild = els[k];\n\n for (let i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n while (tempDiv.firstChild) {\n this[i].appendChild(tempDiv.firstChild);\n }\n } else if (newChild instanceof Dom7) {\n for (let j = 0; j < newChild.length; j += 1) {\n this[i].appendChild(newChild[j]);\n }\n } else {\n this[i].appendChild(newChild);\n }\n }\n }\n\n return this;\n}\n\nfunction appendTo(parent) {\n $(parent).append(this);\n return this;\n}\n\nfunction prepend(newChild) {\n const document = getDocument();\n let i;\n let j;\n\n for (i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n }\n } else if (newChild instanceof Dom7) {\n for (j = 0; j < newChild.length; j += 1) {\n this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n }\n } else {\n this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n }\n\n return this;\n}\n\nfunction prependTo(parent) {\n $(parent).prepend(this);\n return this;\n}\n\nfunction insertBefore(selector) {\n const before = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (before.length === 1) {\n before[0].parentNode.insertBefore(this[i], before[0]);\n } else if (before.length > 1) {\n for (let j = 0; j < before.length; j += 1) {\n before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);\n }\n }\n }\n}\n\nfunction insertAfter(selector) {\n const after = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (after.length === 1) {\n after[0].parentNode.insertBefore(this[i], after[0].nextSibling);\n } else if (after.length > 1) {\n for (let j = 0; j < after.length; j += 1) {\n after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);\n }\n }\n }\n}\n\nfunction next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n return $([this[0].nextElementSibling]);\n }\n\n return $([]);\n }\n\n if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction nextAll(selector) {\n const nextEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.nextElementSibling) {\n const next = el.nextElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(next).is(selector)) nextEls.push(next);\n } else nextEls.push(next);\n\n el = next;\n }\n\n return $(nextEls);\n}\n\nfunction prev(selector) {\n if (this.length > 0) {\n const el = this[0];\n\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n return $([el.previousElementSibling]);\n }\n\n return $([]);\n }\n\n if (el.previousElementSibling) return $([el.previousElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction prevAll(selector) {\n const prevEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.previousElementSibling) {\n const prev = el.previousElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(prev).is(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n\n el = prev;\n }\n\n return $(prevEls);\n}\n\nfunction siblings(selector) {\n return this.nextAll(selector).add(this.prevAll(selector));\n}\n\nfunction parent(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n\n return $(parents);\n}\n\nfunction parents(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n let parent = this[i].parentNode; // eslint-disable-line\n\n while (parent) {\n if (selector) {\n if ($(parent).is(selector)) parents.push(parent);\n } else {\n parents.push(parent);\n }\n\n parent = parent.parentNode;\n }\n }\n\n return $(parents);\n}\n\nfunction closest(selector) {\n let closest = this; // eslint-disable-line\n\n if (typeof selector === 'undefined') {\n return $([]);\n }\n\n if (!closest.is(selector)) {\n closest = closest.parents(selector).eq(0);\n }\n\n return closest;\n}\n\nfunction find(selector) {\n const foundElements = [];\n\n for (let i = 0; i < this.length; i += 1) {\n const found = this[i].querySelectorAll(selector);\n\n for (let j = 0; j < found.length; j += 1) {\n foundElements.push(found[j]);\n }\n }\n\n return $(foundElements);\n}\n\nfunction children(selector) {\n const children = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n const childNodes = this[i].children;\n\n for (let j = 0; j < childNodes.length; j += 1) {\n if (!selector || $(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n\n return $(children);\n}\n\nfunction remove() {\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);\n }\n\n return this;\n}\n\nfunction detach() {\n return this.remove();\n}\n\nfunction add(...els) {\n const dom = this;\n let i;\n let j;\n\n for (i = 0; i < els.length; i += 1) {\n const toAdd = $(els[i]);\n\n for (j = 0; j < toAdd.length; j += 1) {\n dom.push(toAdd[j]);\n }\n }\n\n return dom;\n}\n\nfunction empty() {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.nodeType === 1) {\n for (let j = 0; j < el.childNodes.length; j += 1) {\n if (el.childNodes[j].parentNode) {\n el.childNodes[j].parentNode.removeChild(el.childNodes[j]);\n }\n }\n\n el.textContent = '';\n }\n }\n\n return this;\n}\n\n// eslint-disable-next-line\n\nfunction scrollTo(...args) {\n const window = getWindow();\n let [left, top, duration, easing, callback] = args;\n\n if (args.length === 4 && typeof easing === 'function') {\n callback = easing;\n [left, top, duration, callback, easing] = args;\n }\n\n if (typeof easing === 'undefined') easing = 'swing';\n return this.each(function animate() {\n const el = this;\n let currentTop;\n let currentLeft;\n let maxTop;\n let maxLeft;\n let newTop;\n let newLeft;\n let scrollTop; // eslint-disable-line\n\n let scrollLeft; // eslint-disable-line\n\n let animateTop = top > 0 || top === 0;\n let animateLeft = left > 0 || left === 0;\n\n if (typeof easing === 'undefined') {\n easing = 'swing';\n }\n\n if (animateTop) {\n currentTop = el.scrollTop;\n\n if (!duration) {\n el.scrollTop = top;\n }\n }\n\n if (animateLeft) {\n currentLeft = el.scrollLeft;\n\n if (!duration) {\n el.scrollLeft = left;\n }\n }\n\n if (!duration) return;\n\n if (animateTop) {\n maxTop = el.scrollHeight - el.offsetHeight;\n newTop = Math.max(Math.min(top, maxTop), 0);\n }\n\n if (animateLeft) {\n maxLeft = el.scrollWidth - el.offsetWidth;\n newLeft = Math.max(Math.min(left, maxLeft), 0);\n }\n\n let startTime = null;\n if (animateTop && newTop === currentTop) animateTop = false;\n if (animateLeft && newLeft === currentLeft) animateLeft = false;\n\n function render(time = new Date().getTime()) {\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = easing === 'linear' ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;\n let done;\n if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);\n if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);\n\n if (animateTop && newTop > currentTop && scrollTop >= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateTop && newTop < currentTop && scrollTop <= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (done) {\n if (callback) callback();\n return;\n }\n\n if (animateTop) el.scrollTop = scrollTop;\n if (animateLeft) el.scrollLeft = scrollLeft;\n window.requestAnimationFrame(render);\n }\n\n window.requestAnimationFrame(render);\n });\n} // scrollTop(top, duration, easing, callback) {\n\n\nfunction scrollTop(...args) {\n let [top, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [top, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof top === 'undefined') {\n if (dom.length > 0) return dom[0].scrollTop;\n return null;\n }\n\n return dom.scrollTo(undefined, top, duration, easing, callback);\n}\n\nfunction scrollLeft(...args) {\n let [left, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [left, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof left === 'undefined') {\n if (dom.length > 0) return dom[0].scrollLeft;\n return null;\n }\n\n return dom.scrollTo(left, undefined, duration, easing, callback);\n}\n\n// eslint-disable-next-line\n\nfunction animate(initialProps, initialParams) {\n const window = getWindow();\n const els = this;\n const a = {\n props: Object.assign({}, initialProps),\n params: Object.assign({\n duration: 300,\n easing: 'swing' // or 'linear'\n\n /* Callbacks\n begin(elements)\n complete(elements)\n progress(elements, complete, remaining, start, tweenValue)\n */\n\n }, initialParams),\n elements: els,\n animating: false,\n que: [],\n\n easingProgress(easing, progress) {\n if (easing === 'swing') {\n return 0.5 - Math.cos(progress * Math.PI) / 2;\n }\n\n if (typeof easing === 'function') {\n return easing(progress);\n }\n\n return progress;\n },\n\n stop() {\n if (a.frameId) {\n window.cancelAnimationFrame(a.frameId);\n }\n\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n a.que = [];\n },\n\n done(complete) {\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n if (complete) complete(els);\n\n if (a.que.length > 0) {\n const que = a.que.shift();\n a.animate(que[0], que[1]);\n }\n },\n\n animate(props, params) {\n if (a.animating) {\n a.que.push([props, params]);\n return a;\n }\n\n const elements = []; // Define & Cache Initials & Units\n\n a.elements.each((el, index) => {\n let initialFullValue;\n let initialValue;\n let unit;\n let finalValue;\n let finalFullValue;\n if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;\n elements[index] = {\n container: el\n };\n Object.keys(props).forEach(prop => {\n initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(',', '.');\n initialValue = parseFloat(initialFullValue);\n unit = initialFullValue.replace(initialValue, '');\n finalValue = parseFloat(props[prop]);\n finalFullValue = props[prop] + unit;\n elements[index][prop] = {\n initialFullValue,\n initialValue,\n unit,\n finalValue,\n finalFullValue,\n currentValue: initialValue\n };\n });\n });\n let startTime = null;\n let time;\n let elementsDone = 0;\n let propsDone = 0;\n let done;\n let began = false;\n a.animating = true;\n\n function render() {\n time = new Date().getTime();\n let progress;\n let easeProgress; // let el;\n\n if (!began) {\n began = true;\n if (params.begin) params.begin(els);\n }\n\n if (startTime === null) {\n startTime = time;\n }\n\n if (params.progress) {\n // eslint-disable-next-line\n params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);\n }\n\n elements.forEach(element => {\n const el = element;\n if (done || el.done) return;\n Object.keys(props).forEach(prop => {\n if (done || el.done) return;\n progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);\n easeProgress = a.easingProgress(params.easing, progress);\n const {\n initialValue,\n finalValue,\n unit\n } = el[prop];\n el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);\n const currentValue = el[prop].currentValue;\n\n if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {\n el.container.style[prop] = finalValue + unit;\n propsDone += 1;\n\n if (propsDone === Object.keys(props).length) {\n el.done = true;\n elementsDone += 1;\n }\n\n if (elementsDone === elements.length) {\n done = true;\n }\n }\n\n if (done) {\n a.done(params.complete);\n return;\n }\n\n el.container.style[prop] = currentValue + unit;\n });\n });\n if (done) return; // Then call\n\n a.frameId = window.requestAnimationFrame(render);\n }\n\n a.frameId = window.requestAnimationFrame(render);\n return a;\n }\n\n };\n\n if (a.elements.length === 0) {\n return els;\n }\n\n let animateInstance;\n\n for (let i = 0; i < a.elements.length; i += 1) {\n if (a.elements[i].dom7AnimateInstance) {\n animateInstance = a.elements[i].dom7AnimateInstance;\n } else a.elements[i].dom7AnimateInstance = a;\n }\n\n if (!animateInstance) {\n animateInstance = a;\n }\n\n if (initialProps === 'stop') {\n animateInstance.stop();\n } else {\n animateInstance.animate(a.props, a.params);\n }\n\n return els;\n}\n\nfunction stop() {\n const els = this;\n\n for (let i = 0; i < els.length; i += 1) {\n if (els[i].dom7AnimateInstance) {\n els[i].dom7AnimateInstance.stop();\n }\n }\n}\n\nconst noTrigger = 'resize scroll'.split(' ');\n\nfunction shortcut(name) {\n function eventHandler(...args) {\n if (typeof args[0] === 'undefined') {\n for (let i = 0; i < this.length; i += 1) {\n if (noTrigger.indexOf(name) < 0) {\n if (name in this[i]) this[i][name]();else {\n $(this[i]).trigger(name);\n }\n }\n }\n\n return this;\n }\n\n return this.on(name, ...args);\n }\n\n return eventHandler;\n}\n\nconst click = shortcut('click');\nconst blur = shortcut('blur');\nconst focus = shortcut('focus');\nconst focusin = shortcut('focusin');\nconst focusout = shortcut('focusout');\nconst keyup = shortcut('keyup');\nconst keydown = shortcut('keydown');\nconst keypress = shortcut('keypress');\nconst submit = shortcut('submit');\nconst change = shortcut('change');\nconst mousedown = shortcut('mousedown');\nconst mousemove = shortcut('mousemove');\nconst mouseup = shortcut('mouseup');\nconst mouseenter = shortcut('mouseenter');\nconst mouseleave = shortcut('mouseleave');\nconst mouseout = shortcut('mouseout');\nconst mouseover = shortcut('mouseover');\nconst touchstart = shortcut('touchstart');\nconst touchend = shortcut('touchend');\nconst touchmove = shortcut('touchmove');\nconst resize = shortcut('resize');\nconst scroll = shortcut('scroll');\n\nexport default $;\nexport { $, add, addClass, animate, animationEnd, append, appendTo, attr, blur, change, children, click, closest, css, data, dataset, detach, each, empty, eq, filter, find, focus, focusin, focusout, hasClass, height, hide, html, index, insertAfter, insertBefore, is, keydown, keypress, keyup, mousedown, mouseenter, mouseleave, mousemove, mouseout, mouseover, mouseup, next, nextAll, off, offset, on, once, outerHeight, outerWidth, parent, parents, prepend, prependTo, prev, prevAll, prop, remove, removeAttr, removeClass, removeData, resize, scroll, scrollLeft, scrollTo, scrollTop, show, siblings, stop, styles, submit, text, toggleClass, touchend, touchmove, touchstart, transform, transition, transitionEnd, transitionStart, trigger, val, value, width };\n","/**\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 Swiper, { Navigation, Pagination, Autoplay } from 'swiper';\n\nSwiper.use([Navigation, Pagination, Autoplay]);\n\n// Swipers\nconst swiperHero = new Swiper('.swiper-hero', {\n pagination: {\n el: '.swiper-pagination',\n },\n navigation: {\n nextEl: '.swiper-hero-next',\n prevEl: '.swiper-hero-prev',\n },\n loop: true,\n autoplay: {\n delay: 8000\n },\n});\n\nconst swiperReview = new Swiper('.swiper-review', {\n // Local parameters\n centeredSlides: true,\n loop: true,\n autoplay: true,\n // Responsive breakpoints\n breakpoints: {\n 320: {\n slidesPerView: 1,\n },\n 900: {\n slidesPerView: \"auto\",\n },\n },\n navigation: {\n nextEl: '.swiper-button-next',\n prevEl: '.swiper-button-prev',\n },\n});\n\nconst swiperMenu = new Swiper('.swiper-menu', {\n // Local parameters\n centeredSlides: true,\n // Responsive breakpoints\n breakpoints: {\n 320: {\n slidesPerView: 1,\n spaceBetween: 10,\n },\n 900: {\n slidesPerView: \"auto\",\n spaceBetween: 70,\n }\n },\n navigation: {\n nextEl: '.swiper-button-next',\n prevEl: '.swiper-button-prev',\n },\n});\n\n\n\n// Mobile navigation\n// - Lock scroll on Mobile Navigation\nconst navToggle = document.querySelector(\"#nav-toggle\")\nnavToggle.addEventListener(\"click\", (e) => {\nconst navLayout = document.querySelector(\".header-nav__mobile\")\n navToggle.classList.toggle(\"nav-toggle--active\")\n navLayout.classList.toggle(\"header-nav__mobile--open\")\n})\n\n// Menu-block Arrows\nconst mondayToggle = document.querySelector(\"#monday-toggle\")\nconst tuesdayToggle = document.querySelector(\"#tuesday-toggle\")\nconst wednesdayToggle = document.querySelector(\"#wednesday-toggle\")\nconst thursdayToggle = document.querySelector(\"#thursday-toggle\")\nconst fridayToggle = document.querySelector(\"#friday-toggle\")\n\nif (document.body.contains(mondayToggle)) {\n mondayToggle.addEventListener(\"click\", (e) => {\n mondayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\")\n })\n}\n\nif (document.body.contains(tuesdayToggle)) {\n tuesdayToggle.addEventListener(\"click\", (e) => {\n tuesdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\")\n })\n}\n\nif (document.body.contains(wednesdayToggle)) {\n wednesdayToggle.addEventListener(\"click\", (e) => {\n wednesdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\")\n })\n}\n\nif (document.body.contains(thursdayToggle)) {\n thursdayToggle.addEventListener(\"click\", (e) => {\n thursdayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\")\n })\n}\nif (document.body.contains(fridayToggle)) {\n fridayToggle.addEventListener(\"click\", (e) => {\n fridayToggle.querySelector(\".arrow-down-black\").classList.toggle(\"arrow-down-black--active\")\n })\n}\n\n// Window Scroll Header\nwindow.onscroll = function() {scrollFunction()};\n\nfunction scrollFunction() {\n const header = document.querySelector(\".nav-layout\");\n if (document.body.scrollTop > 50 || document.documentElement.scrollTop > 50) {\n document.getElementById(\"header-logo\").style.height = \"60px\";\n }\n else {\n document.getElementById(\"header-logo\").style.height = \"74px\";\n }\n}\n","/**\n * Swiper 7.4.1\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2021 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: December 24, 2021\n */\n\nexport { default as Swiper, default } from './core/core.js';\nexport { default as Virtual } from './modules/virtual/virtual.js';\nexport { default as Keyboard } from './modules/keyboard/keyboard.js';\nexport { default as Mousewheel } from './modules/mousewheel/mousewheel.js';\nexport { default as Navigation } from './modules/navigation/navigation.js';\nexport { default as Pagination } from './modules/pagination/pagination.js';\nexport { default as Scrollbar } from './modules/scrollbar/scrollbar.js';\nexport { default as Parallax } from './modules/parallax/parallax.js';\nexport { default as Zoom } from './modules/zoom/zoom.js';\nexport { default as Lazy } from './modules/lazy/lazy.js';\nexport { default as Controller } from './modules/controller/controller.js';\nexport { default as A11y } from './modules/a11y/a11y.js';\nexport { default as History } from './modules/history/history.js';\nexport { default as HashNavigation } from './modules/hash-navigation/hash-navigation.js';\nexport { default as Autoplay } from './modules/autoplay/autoplay.js';\nexport { default as Thumbs } from './modules/thumbs/thumbs.js';\nexport { default as FreeMode } from './modules/free-mode/free-mode.js';\nexport { default as Grid } from './modules/grid/grid.js';\nexport { default as Manipulation } from './modules/manipulation/manipulation.js';\nexport { default as EffectFade } from './modules/effect-fade/effect-fade.js';\nexport { default as EffectCube } from './modules/effect-cube/effect-cube.js';\nexport { default as EffectFlip } from './modules/effect-flip/effect-flip.js';\nexport { default as EffectCoverflow } from './modules/effect-coverflow/effect-coverflow.js';\nexport { default as EffectCreative } from './modules/effect-creative/effect-creative.js';\nexport { default as EffectCards } from './modules/effect-cards/effect-cards.js';","/* eslint no-param-reassign: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport $ from '../shared/dom.js';\nimport { extend, now, deleteProps } from '../shared/utils.js';\nimport { getSupport } from '../shared/get-support.js';\nimport { getDevice } from '../shared/get-device.js';\nimport { getBrowser } from '../shared/get-browser.js';\nimport Resize from './modules/resize/resize.js';\nimport Observer from './modules/observer/observer.js';\nimport eventsEmitter from './events-emitter.js';\nimport update from './update/index.js';\nimport translate from './translate/index.js';\nimport transition from './transition/index.js';\nimport slide from './slide/index.js';\nimport loop from './loop/index.js';\nimport grabCursor from './grab-cursor/index.js';\nimport events from './events/index.js';\nimport breakpoints from './breakpoints/index.js';\nimport classes from './classes/index.js';\nimport images from './images/index.js';\nimport checkOverflow from './check-overflow/index.js';\nimport defaults from './defaults.js';\nimport moduleExtendParams from './moduleExtendParams.js';\nconst prototypes = {\n eventsEmitter,\n update,\n translate,\n transition,\n slide,\n loop,\n grabCursor,\n events,\n breakpoints,\n checkOverflow,\n classes,\n images\n};\nconst extendedDefaults = {};\n\nclass Swiper {\n constructor(...args) {\n let el;\n let params;\n\n if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {\n params = args[0];\n } else {\n [el, params] = args;\n }\n\n if (!params) params = {};\n params = extend({}, params);\n if (el && !params.el) params.el = el;\n\n if (params.el && $(params.el).length > 1) {\n const swipers = [];\n $(params.el).each(containerEl => {\n const newParams = extend({}, params, {\n el: containerEl\n });\n swipers.push(new Swiper(newParams));\n });\n return swipers;\n } // Swiper Instance\n\n\n const swiper = this;\n swiper.__swiper__ = true;\n swiper.support = getSupport();\n swiper.device = getDevice({\n userAgent: params.userAgent\n });\n swiper.browser = getBrowser();\n swiper.eventsListeners = {};\n swiper.eventsAnyListeners = [];\n swiper.modules = [...swiper.__modules__];\n\n if (params.modules && Array.isArray(params.modules)) {\n swiper.modules.push(...params.modules);\n }\n\n const allModulesParams = {};\n swiper.modules.forEach(mod => {\n mod({\n swiper,\n extendParams: moduleExtendParams(params, allModulesParams),\n on: swiper.on.bind(swiper),\n once: swiper.once.bind(swiper),\n off: swiper.off.bind(swiper),\n emit: swiper.emit.bind(swiper)\n });\n }); // Extend defaults with modules params\n\n const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params\n\n swiper.params = extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = extend({}, swiper.params);\n swiper.passedParams = extend({}, params); // add event listeners\n\n if (swiper.params && swiper.params.on) {\n Object.keys(swiper.params.on).forEach(eventName => {\n swiper.on(eventName, swiper.params.on[eventName]);\n });\n }\n\n if (swiper.params && swiper.params.onAny) {\n swiper.onAny(swiper.params.onAny);\n } // Save Dom lib\n\n\n swiper.$ = $; // Extend Swiper\n\n Object.assign(swiper, {\n enabled: swiper.params.enabled,\n el,\n // Classes\n classNames: [],\n // Slides\n slides: $(),\n slidesGrid: [],\n snapGrid: [],\n slidesSizesGrid: [],\n\n // isDirection\n isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n\n isVertical() {\n return swiper.params.direction === 'vertical';\n },\n\n // Indexes\n activeIndex: 0,\n realIndex: 0,\n //\n isBeginning: true,\n isEnd: false,\n // Props\n translate: 0,\n previousTranslate: 0,\n progress: 0,\n velocity: 0,\n animating: false,\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n // Touch Events\n touchEvents: function touchEvents() {\n const touch = ['touchstart', 'touchmove', 'touchend', 'touchcancel'];\n const desktop = ['pointerdown', 'pointermove', 'pointerup'];\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n cancel: touch[3]\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2]\n };\n return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }(),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n focusableElements: swiper.params.focusableElements,\n // Last click time\n lastClickTime: now(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined\n },\n // Clicks\n allowClick: true,\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0\n },\n // Images\n imagesToLoad: [],\n imagesLoaded: 0\n });\n swiper.emit('_swiper'); // Init\n\n if (swiper.params.init) {\n swiper.init();\n } // Return app instance\n\n\n return swiper;\n }\n\n enable() {\n const swiper = this;\n if (swiper.enabled) return;\n swiper.enabled = true;\n\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n\n swiper.emit('enable');\n }\n\n disable() {\n const swiper = this;\n if (!swiper.enabled) return;\n swiper.enabled = false;\n\n if (swiper.params.grabCursor) {\n swiper.unsetGrabCursor();\n }\n\n swiper.emit('disable');\n }\n\n setProgress(progress, speed) {\n const swiper = this;\n progress = Math.min(Math.max(progress, 0), 1);\n const min = swiper.minTranslate();\n const max = swiper.maxTranslate();\n const current = (max - min) * progress + min;\n swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n emitContainerClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const cls = swiper.el.className.split(' ').filter(className => {\n return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;\n });\n swiper.emit('_containerClasses', cls.join(' '));\n }\n\n getSlideClasses(slideEl) {\n const swiper = this;\n return slideEl.className.split(' ').filter(className => {\n return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;\n }).join(' ');\n }\n\n emitSlidesClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const updates = [];\n swiper.slides.each(slideEl => {\n const classNames = swiper.getSlideClasses(slideEl);\n updates.push({\n slideEl,\n classNames\n });\n swiper.emit('_slideClass', slideEl, classNames);\n });\n swiper.emit('_slideClasses', updates);\n }\n\n slidesPerViewDynamic(view = 'current', exact = false) {\n const swiper = this;\n const {\n params,\n slides,\n slidesGrid,\n slidesSizesGrid,\n size: swiperSize,\n activeIndex\n } = swiper;\n let spv = 1;\n\n if (params.centeredSlides) {\n let slideSize = slides[activeIndex].swiperSlideSize;\n let breakLoop;\n\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n } else {\n // eslint-disable-next-line\n if (view === 'current') {\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n } else {\n // previous\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n }\n }\n\n return spv;\n }\n\n update() {\n const swiper = this;\n if (!swiper || swiper.destroyed) return;\n const {\n snapGrid,\n params\n } = swiper; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n function setTranslate() {\n const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n let translated;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled) {\n setTranslate();\n\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (!translated) {\n setTranslate();\n }\n }\n\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n\n swiper.emit('update');\n }\n\n changeDirection(newDirection, needUpdate = true) {\n const swiper = this;\n const currentDirection = swiper.params.direction;\n\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n\n if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n return swiper;\n }\n\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);\n swiper.emitContainerClasses();\n swiper.params.direction = newDirection;\n swiper.slides.each(slideEl => {\n if (newDirection === 'vertical') {\n slideEl.style.width = '';\n } else {\n slideEl.style.height = '';\n }\n });\n swiper.emit('changeDirection');\n if (needUpdate) swiper.update();\n return swiper;\n }\n\n mount(el) {\n const swiper = this;\n if (swiper.mounted) return true; // Find el\n\n const $el = $(el || swiper.params.el);\n el = $el[0];\n\n if (!el) {\n return false;\n }\n\n el.swiper = swiper;\n\n const getWrapperSelector = () => {\n return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n };\n\n const getWrapper = () => {\n if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items\n\n res.children = options => $el.children(options);\n\n return res;\n }\n\n return $el.children(getWrapperSelector());\n }; // Find Wrapper\n\n\n let $wrapperEl = getWrapper();\n\n if ($wrapperEl.length === 0 && swiper.params.createElements) {\n const document = getDocument();\n const wrapper = document.createElement('div');\n $wrapperEl = $(wrapper);\n wrapper.className = swiper.params.wrapperClass;\n $el.append(wrapper);\n $el.children(`.${swiper.params.slideClass}`).each(slideEl => {\n $wrapperEl.append(slideEl);\n });\n }\n\n Object.assign(swiper, {\n $el,\n el,\n $wrapperEl,\n wrapperEl: $wrapperEl[0],\n mounted: true,\n // RTL\n rtl: el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl',\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n wrongRTL: $wrapperEl.css('display') === '-webkit-box'\n });\n return true;\n }\n\n init(el) {\n const swiper = this;\n if (swiper.initialized) return swiper;\n const mounted = swiper.mount(el);\n if (mounted === false) return swiper;\n swiper.emit('beforeInit'); // Set breakpoint\n\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n } // Add Classes\n\n\n swiper.addClasses(); // Create loop\n\n if (swiper.params.loop) {\n swiper.loopCreate();\n } // Update size\n\n\n swiper.updateSize(); // Update slides\n\n swiper.updateSlides();\n\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n } // Set Grab Cursor\n\n\n if (swiper.params.grabCursor && swiper.enabled) {\n swiper.setGrabCursor();\n }\n\n if (swiper.params.preloadImages) {\n swiper.preloadImages();\n } // Slide To Initial Slide\n\n\n if (swiper.params.loop) {\n swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n } // Attach events\n\n\n swiper.attachEvents(); // Init Flag\n\n swiper.initialized = true; // Emit\n\n swiper.emit('init');\n swiper.emit('afterInit');\n return swiper;\n }\n\n destroy(deleteInstance = true, cleanStyles = true) {\n const swiper = this;\n const {\n params,\n $el,\n $wrapperEl,\n slides\n } = swiper;\n\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n\n swiper.emit('beforeDestroy'); // Init Flag\n\n swiper.initialized = false; // Detach events\n\n swiper.detachEvents(); // Destroy loop\n\n if (params.loop) {\n swiper.loopDestroy();\n } // Cleanup styles\n\n\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr('style');\n $wrapperEl.removeAttr('style');\n\n if (slides && slides.length) {\n slides.removeClass([params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass].join(' ')).removeAttr('style').removeAttr('data-swiper-slide-index');\n }\n }\n\n swiper.emit('destroy'); // Detach emitter events\n\n Object.keys(swiper.eventsListeners).forEach(eventName => {\n swiper.off(eventName);\n });\n\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n deleteProps(swiper);\n }\n\n swiper.destroyed = true;\n return null;\n }\n\n static extendDefaults(newDefaults) {\n extend(extendedDefaults, newDefaults);\n }\n\n static get extendedDefaults() {\n return extendedDefaults;\n }\n\n static get defaults() {\n return defaults;\n }\n\n static installModule(mod) {\n if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n const modules = Swiper.prototype.__modules__;\n\n if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n modules.push(mod);\n }\n }\n\n static use(module) {\n if (Array.isArray(module)) {\n module.forEach(m => Swiper.installModule(m));\n return Swiper;\n }\n\n Swiper.installModule(module);\n return Swiper;\n }\n\n}\n\nObject.keys(prototypes).forEach(prototypeGroup => {\n Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n });\n});\nSwiper.use([Resize, Observer]);\nexport default Swiper;","import { $, addClass, removeClass, hasClass, toggleClass, attr, removeAttr, transform, transition, on, off, trigger, transitionEnd, outerWidth, outerHeight, styles, offset, css, each, html, text, is, index, eq, append, prepend, next, nextAll, prev, prevAll, parent, parents, closest, find, children, filter, remove } from 'dom7';\nconst Methods = {\n addClass,\n removeClass,\n hasClass,\n toggleClass,\n attr,\n removeAttr,\n transform,\n transition,\n on,\n off,\n trigger,\n transitionEnd,\n outerWidth,\n outerHeight,\n styles,\n offset,\n css,\n each,\n html,\n text,\n is,\n index,\n eq,\n append,\n prepend,\n next,\n nextAll,\n prev,\n prevAll,\n parent,\n parents,\n closest,\n find,\n children,\n filter,\n remove\n};\nObject.keys(Methods).forEach(methodName => {\n Object.defineProperty($.fn, methodName, {\n value: Methods[methodName],\n writable: true\n });\n});\nexport default $;","import { getWindow } from 'ssr-window';\n\nfunction deleteProps(obj) {\n const object = obj;\n Object.keys(object).forEach(key => {\n try {\n object[key] = null;\n } catch (e) {// no getter for object\n }\n\n try {\n delete object[key];\n } catch (e) {// something got wrong\n }\n });\n}\n\nfunction nextTick(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\n\nfunction now() {\n return Date.now();\n}\n\nfunction getComputedStyle(el) {\n const window = getWindow();\n let style;\n\n if (window.getComputedStyle) {\n style = window.getComputedStyle(el, null);\n }\n\n if (!style && el.currentStyle) {\n style = el.currentStyle;\n }\n\n if (!style) {\n style = el.style;\n }\n\n return style;\n}\n\nfunction getTranslate(el, axis = 'x') {\n const window = getWindow();\n let matrix;\n let curTransform;\n let transformMatrix;\n const curStyle = getComputedStyle(el, null);\n\n if (window.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n } // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n\n\n transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n } else {\n transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n matrix = transformMatrix.toString().split(',');\n }\n\n if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers\n else curTransform = parseFloat(matrix[4]);\n }\n\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers\n else curTransform = parseFloat(matrix[5]);\n }\n\n return curTransform || 0;\n}\n\nfunction isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction isNode(node) {\n // eslint-disable-next-line\n if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {\n return node instanceof HTMLElement;\n }\n\n return node && (node.nodeType === 1 || node.nodeType === 11);\n}\n\nfunction extend(...args) {\n const to = Object(args[0]);\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n\n for (let i = 1; i < args.length; i += 1) {\n const nextSource = args[i];\n\n if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\n\n for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n const nextKey = keysArray[nextIndex];\n const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n\n if (desc !== undefined && desc.enumerable) {\n if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n }\n\n return to;\n}\n\nfunction setCSSProperty(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\n}\n\nfunction animateCSSModeScroll({\n swiper,\n targetPosition,\n side\n}) {\n const window = getWindow();\n const startPosition = -swiper.translate;\n let startTime = null;\n let time;\n const duration = swiper.params.speed;\n swiper.wrapperEl.style.scrollSnapType = 'none';\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n const dir = targetPosition > startPosition ? 'next' : 'prev';\n\n const isOutOfBound = (current, target) => {\n return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n };\n\n const animate = () => {\n time = new Date().getTime();\n\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;\n let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n currentPosition = targetPosition;\n }\n\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.scrollSnapType = '';\n setTimeout(() => {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n });\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n return;\n }\n\n swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n };\n\n animate();\n}\n\nexport { animateCSSModeScroll, deleteProps, nextTick, now, getTranslate, isObject, extend, getComputedStyle, setCSSProperty };","import { getWindow, getDocument } from 'ssr-window';\nlet support;\n\nfunction calcSupport() {\n const window = getWindow();\n const document = getDocument();\n return {\n smoothScroll: document.documentElement && 'scrollBehavior' in document.documentElement.style,\n touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch),\n passiveListener: function checkPassiveListener() {\n let supportsPassive = false;\n\n try {\n const opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line\n get() {\n supportsPassive = true;\n }\n\n });\n window.addEventListener('testPassiveListener', null, opts);\n } catch (e) {// No support\n }\n\n return supportsPassive;\n }(),\n gestures: function checkGestures() {\n return 'ongesturestart' in window;\n }()\n };\n}\n\nfunction getSupport() {\n if (!support) {\n support = calcSupport();\n }\n\n return support;\n}\n\nexport { getSupport };","import { getWindow } from 'ssr-window';\nimport { getSupport } from './get-support.js';\nlet deviceCached;\n\nfunction calcDevice({\n userAgent\n} = {}) {\n const support = getSupport();\n const window = getWindow();\n const platform = window.navigator.platform;\n const ua = userAgent || window.navigator.userAgent;\n const device = {\n ios: false,\n android: false\n };\n const screenWidth = window.screen.width;\n const screenHeight = window.screen.height;\n const android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n\n let ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n const ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n const iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n const windows = platform === 'Win32';\n let macos = platform === 'MacIntel'; // iPadOs 13 fix\n\n const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\n\n if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n ipad = ua.match(/(Version)\\/([\\d.]+)/);\n if (!ipad) ipad = [0, 1, '13_0_0'];\n macos = false;\n } // Android\n\n\n if (android && !windows) {\n device.os = 'android';\n device.android = true;\n }\n\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n } // Export object\n\n\n return device;\n}\n\nfunction getDevice(overrides = {}) {\n if (!deviceCached) {\n deviceCached = calcDevice(overrides);\n }\n\n return deviceCached;\n}\n\nexport { getDevice };","import { getWindow } from 'ssr-window';\nlet browser;\n\nfunction calcBrowser() {\n const window = getWindow();\n\n function isSafari() {\n const ua = window.navigator.userAgent.toLowerCase();\n return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;\n }\n\n return {\n isSafari: isSafari(),\n isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n };\n}\n\nfunction getBrowser() {\n if (!browser) {\n browser = calcBrowser();\n }\n\n return browser;\n}\n\nexport { getBrowser };","import { getWindow } from 'ssr-window';\nexport default function Resize({\n swiper,\n on,\n emit\n}) {\n const window = getWindow();\n let observer = null;\n\n const resizeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('beforeResize');\n emit('resize');\n };\n\n const createObserver = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n observer = new ResizeObserver(entries => {\n const {\n width,\n height\n } = swiper;\n let newWidth = width;\n let newHeight = height;\n entries.forEach(({\n contentBoxSize,\n contentRect,\n target\n }) => {\n if (target && target !== swiper.el) return;\n newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;\n newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;\n });\n\n if (newWidth !== width || newHeight !== height) {\n resizeHandler();\n }\n });\n observer.observe(swiper.el);\n };\n\n const removeObserver = () => {\n if (observer && observer.unobserve && swiper.el) {\n observer.unobserve(swiper.el);\n observer = null;\n }\n };\n\n const orientationChangeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('orientationchange');\n };\n\n on('init', () => {\n if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n createObserver();\n return;\n }\n\n window.addEventListener('resize', resizeHandler);\n window.addEventListener('orientationchange', orientationChangeHandler);\n });\n on('destroy', () => {\n removeObserver();\n window.removeEventListener('resize', resizeHandler);\n window.removeEventListener('orientationchange', orientationChangeHandler);\n });\n}","import { getWindow } from 'ssr-window';\nexport default function Observer({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const observers = [];\n const window = getWindow();\n\n const attach = (target, options = {}) => {\n const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;\n const observer = new ObserverFunc(mutations => {\n // The observerUpdate event should only be triggered\n // once despite the number of mutations. Additional\n // triggers are redundant and are very costly\n if (mutations.length === 1) {\n emit('observerUpdate', mutations[0]);\n return;\n }\n\n const observerUpdate = function observerUpdate() {\n emit('observerUpdate', mutations[0]);\n };\n\n if (window.requestAnimationFrame) {\n window.requestAnimationFrame(observerUpdate);\n } else {\n window.setTimeout(observerUpdate, 0);\n }\n });\n observer.observe(target, {\n attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n childList: typeof options.childList === 'undefined' ? true : options.childList,\n characterData: typeof options.characterData === 'undefined' ? true : options.characterData\n });\n observers.push(observer);\n };\n\n const init = () => {\n if (!swiper.params.observer) return;\n\n if (swiper.params.observeParents) {\n const containerParents = swiper.$el.parents();\n\n for (let i = 0; i < containerParents.length; i += 1) {\n attach(containerParents[i]);\n }\n } // Observe container\n\n\n attach(swiper.$el[0], {\n childList: swiper.params.observeSlideChildren\n }); // Observe wrapper\n\n attach(swiper.$wrapperEl[0], {\n attributes: false\n });\n };\n\n const destroy = () => {\n observers.forEach(observer => {\n observer.disconnect();\n });\n observers.splice(0, observers.length);\n };\n\n extendParams({\n observer: false,\n observeParents: false,\n observeSlideChildren: false\n });\n on('init', init);\n on('destroy', destroy);\n}","/* eslint-disable no-underscore-dangle */\nexport default {\n on(events, handler, priority) {\n const self = this;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n events.split(' ').forEach(event => {\n if (!self.eventsListeners[event]) self.eventsListeners[event] = [];\n self.eventsListeners[event][method](handler);\n });\n return self;\n },\n\n once(events, handler, priority) {\n const self = this;\n if (typeof handler !== 'function') return self;\n\n function onceHandler(...args) {\n self.off(events, onceHandler);\n\n if (onceHandler.__emitterProxy) {\n delete onceHandler.__emitterProxy;\n }\n\n handler.apply(self, args);\n }\n\n onceHandler.__emitterProxy = handler;\n return self.on(events, onceHandler, priority);\n },\n\n onAny(handler, priority) {\n const self = this;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n\n if (self.eventsAnyListeners.indexOf(handler) < 0) {\n self.eventsAnyListeners[method](handler);\n }\n\n return self;\n },\n\n offAny(handler) {\n const self = this;\n if (!self.eventsAnyListeners) return self;\n const index = self.eventsAnyListeners.indexOf(handler);\n\n if (index >= 0) {\n self.eventsAnyListeners.splice(index, 1);\n }\n\n return self;\n },\n\n off(events, handler) {\n const self = this;\n if (!self.eventsListeners) return self;\n events.split(' ').forEach(event => {\n if (typeof handler === 'undefined') {\n self.eventsListeners[event] = [];\n } else if (self.eventsListeners[event]) {\n self.eventsListeners[event].forEach((eventHandler, index) => {\n if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {\n self.eventsListeners[event].splice(index, 1);\n }\n });\n }\n });\n return self;\n },\n\n emit(...args) {\n const self = this;\n if (!self.eventsListeners) return self;\n let events;\n let data;\n let context;\n\n if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n events = args[0];\n data = args.slice(1, args.length);\n context = self;\n } else {\n events = args[0].events;\n data = args[0].data;\n context = args[0].context || self;\n }\n\n data.unshift(context);\n const eventsArray = Array.isArray(events) ? events : events.split(' ');\n eventsArray.forEach(event => {\n if (self.eventsAnyListeners && self.eventsAnyListeners.length) {\n self.eventsAnyListeners.forEach(eventHandler => {\n eventHandler.apply(context, [event, ...data]);\n });\n }\n\n if (self.eventsListeners && self.eventsListeners[event]) {\n self.eventsListeners[event].forEach(eventHandler => {\n eventHandler.apply(context, data);\n });\n }\n });\n return self;\n }\n\n};","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};","export default function updateSize() {\n const swiper = this;\n let width;\n let height;\n const $el = swiper.$el;\n\n if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n width = swiper.params.width;\n } else {\n width = $el[0].clientWidth;\n }\n\n if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n height = swiper.params.height;\n } else {\n height = $el[0].clientHeight;\n }\n\n if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n return;\n } // Subtract paddings\n\n\n width = width - parseInt($el.css('padding-left') || 0, 10) - parseInt($el.css('padding-right') || 0, 10);\n height = height - parseInt($el.css('padding-top') || 0, 10) - parseInt($el.css('padding-bottom') || 0, 10);\n if (Number.isNaN(width)) width = 0;\n if (Number.isNaN(height)) height = 0;\n Object.assign(swiper, {\n width,\n height,\n size: swiper.isHorizontal() ? width : height\n });\n}","import { setCSSProperty } from '../../shared/utils.js';\nexport default function updateSlides() {\n const swiper = this;\n\n function getDirectionLabel(property) {\n if (swiper.isHorizontal()) {\n return property;\n } // prettier-ignore\n\n\n return {\n 'width': 'height',\n 'margin-top': 'margin-left',\n 'margin-bottom ': 'margin-right',\n 'margin-left': 'margin-top',\n 'margin-right': 'margin-bottom',\n 'padding-left': 'padding-top',\n 'padding-right': 'padding-bottom',\n 'marginRight': 'marginBottom'\n }[property];\n }\n\n function getDirectionPropertyValue(node, label) {\n return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);\n }\n\n const params = swiper.params;\n const {\n $wrapperEl,\n size: swiperSize,\n rtlTranslate: rtl,\n wrongRTL\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);\n const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n let snapGrid = [];\n const slidesGrid = [];\n const slidesSizesGrid = [];\n let offsetBefore = params.slidesOffsetBefore;\n\n if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n\n let offsetAfter = params.slidesOffsetAfter;\n\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\n }\n\n const previousSnapGridLength = swiper.snapGrid.length;\n const previousSlidesGridLength = swiper.slidesGrid.length;\n let spaceBetween = params.spaceBetween;\n let slidePosition = -offsetBefore;\n let prevSlideSize = 0;\n let index = 0;\n\n if (typeof swiperSize === 'undefined') {\n return;\n }\n\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n }\n\n swiper.virtualSize = -spaceBetween; // reset margins\n\n if (rtl) slides.css({\n marginLeft: '',\n marginBottom: '',\n marginTop: ''\n });else slides.css({\n marginRight: '',\n marginBottom: '',\n marginTop: ''\n }); // reset cssMode offsets\n\n if (params.centeredSlides && params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', '');\n }\n\n const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n\n if (gridEnabled) {\n swiper.grid.initSlides(slidesLength);\n } // Calc slides\n\n\n let slideSize;\n const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {\n return typeof params.breakpoints[key].slidesPerView !== 'undefined';\n }).length > 0;\n\n for (let i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n const slide = slides.eq(i);\n\n if (gridEnabled) {\n swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n }\n\n if (slide.css('display') === 'none') continue; // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n if (shouldResetSlideSize) {\n slides[i].style[getDirectionLabel('width')] = ``;\n }\n\n const slideStyles = getComputedStyle(slide[0]);\n const currentTransform = slide[0].style.transform;\n const currentWebKitTransform = slide[0].style.webkitTransform;\n\n if (currentTransform) {\n slide[0].style.transform = 'none';\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = 'none';\n }\n\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);\n } else {\n // eslint-disable-next-line\n const width = getDirectionPropertyValue(slideStyles, 'width');\n const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');\n const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');\n const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');\n const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');\n const boxSizing = slideStyles.getPropertyValue('box-sizing');\n\n if (boxSizing && boxSizing === 'border-box') {\n slideSize = width + marginLeft + marginRight;\n } else {\n const {\n clientWidth,\n offsetWidth\n } = slide[0];\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n }\n }\n\n if (currentTransform) {\n slide[0].style.transform = currentTransform;\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = currentWebKitTransform;\n }\n\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n } else {\n slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n\n if (slides[i]) {\n slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;\n }\n }\n\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n\n slidesSizesGrid.push(slideSize);\n\n if (params.centeredSlides) {\n slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;\n if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n } else {\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n slidePosition = slidePosition + slideSize + spaceBetween;\n }\n\n swiper.virtualSize += slideSize + spaceBetween;\n prevSlideSize = slideSize;\n index += 1;\n }\n\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n\n if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n $wrapperEl.css({\n width: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (params.setWrapperSize) {\n $wrapperEl.css({\n [getDirectionLabel('width')]: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (gridEnabled) {\n swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\n } // Remove last grid elements depending on width\n\n\n if (!params.centeredSlides) {\n const newSlidesGrid = [];\n\n for (let i = 0; i < snapGrid.length; i += 1) {\n let slidesGridItem = snapGrid[i];\n if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n\n if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem);\n }\n }\n\n snapGrid = newSlidesGrid;\n\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n\n if (snapGrid.length === 0) snapGrid = [0];\n\n if (params.spaceBetween !== 0) {\n const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');\n slides.filter((_, slideIndex) => {\n if (!params.cssMode) return true;\n\n if (slideIndex === slides.length - 1) {\n return false;\n }\n\n return true;\n }).css({\n [key]: `${spaceBetween}px`\n });\n }\n\n if (params.centeredSlides && params.centeredSlidesBounds) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n const maxSnap = allSlidesSize - swiperSize;\n snapGrid = snapGrid.map(snap => {\n if (snap < 0) return -offsetBefore;\n if (snap > maxSnap) return maxSnap + offsetAfter;\n return snap;\n });\n }\n\n if (params.centerInsufficientSlides) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n\n if (allSlidesSize < swiperSize) {\n const allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n snapGrid.forEach((snap, snapIndex) => {\n snapGrid[snapIndex] = snap - allSlidesOffset;\n });\n slidesGrid.forEach((snap, snapIndex) => {\n slidesGrid[snapIndex] = snap + allSlidesOffset;\n });\n }\n }\n\n Object.assign(swiper, {\n slides,\n snapGrid,\n slidesGrid,\n slidesSizesGrid\n });\n\n if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n const addToSnapGrid = -swiper.snapGrid[0];\n const addToSlidesGrid = -swiper.slidesGrid[0];\n swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);\n swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);\n }\n\n if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n swiper.emit('snapGridLengthChange');\n }\n\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n\n if (params.watchSlidesProgress) {\n swiper.updateSlidesOffset();\n }\n}","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\n if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n\n const getSlideByIndex = index => {\n if (isVirtual) {\n return swiper.slides.filter(el => parseInt(el.getAttribute('data-swiper-slide-index'), 10) === index)[0];\n }\n\n return swiper.slides.eq(index)[0];\n }; // Find slides currently in view\n\n\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n if (swiper.params.centeredSlides) {\n swiper.visibleSlides.each(slide => {\n activeSlides.push(slide);\n });\n } else {\n for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n const index = swiper.activeIndex + i;\n if (index > swiper.slides.length && !isVirtual) break;\n activeSlides.push(getSlideByIndex(index));\n }\n }\n } else {\n activeSlides.push(getSlideByIndex(swiper.activeIndex));\n } // Find new height from highest slide in view\n\n\n for (i = 0; i < activeSlides.length; i += 1) {\n if (typeof activeSlides[i] !== 'undefined') {\n const height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n } // Update Height\n\n\n if (newHeight || newHeight === 0) swiper.$wrapperEl.css('height', `${newHeight}px`);\n}","export default function updateSlidesOffset() {\n const swiper = this;\n const slides = swiper.slides;\n\n for (let i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateSlidesProgress(translate = this && this.translate || 0) {\n const swiper = this;\n const params = swiper.params;\n const {\n slides,\n rtlTranslate: rtl,\n snapGrid\n } = swiper;\n if (slides.length === 0) return;\n if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();\n let offsetCenter = -translate;\n if (rtl) offsetCenter = translate; // Visible Slides\n\n slides.removeClass(params.slideVisibleClass);\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n\n for (let i = 0; i < slides.length; i += 1) {\n const slide = slides[i];\n let slideOffset = slide.swiperSlideOffset;\n\n if (params.cssMode && params.centeredSlides) {\n slideOffset -= slides[0].swiperSlideOffset;\n }\n\n const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const slideBefore = -(offsetCenter - slideOffset);\n const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n\n slide.progress = rtl ? -slideProgress : slideProgress;\n slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n }\n\n swiper.visibleSlides = $(swiper.visibleSlides);\n}","export default function updateProgress(translate) {\n const swiper = this;\n\n if (typeof translate === 'undefined') {\n const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line\n\n translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n }\n\n const params = swiper.params;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n let {\n progress,\n isBeginning,\n isEnd\n } = swiper;\n const wasBeginning = isBeginning;\n const wasEnd = isEnd;\n\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / translatesDiff;\n isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n\n Object.assign(swiper, {\n progress,\n isBeginning,\n isEnd\n });\n if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n\n if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n swiper.emit('fromEdge');\n }\n\n swiper.emit('progress', progress);\n}","export default function updateSlidesClasses() {\n const swiper = this;\n const {\n slides,\n params,\n $wrapperEl,\n activeIndex,\n realIndex\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);\n let activeSlide;\n\n if (isVirtual) {\n activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index=\"${activeIndex}\"]`);\n } else {\n activeSlide = slides.eq(activeIndex);\n } // Active classes\n\n\n activeSlide.addClass(params.slideActiveClass);\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n }\n } // Next Slide\n\n\n let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);\n\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n } // Prev Slide\n\n\n let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);\n\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n }\n\n if (prevSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n }\n }\n\n swiper.emitSlidesClasses();\n}","export default function updateActiveIndex(newActiveIndex) {\n const swiper = this;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n const {\n slidesGrid,\n snapGrid,\n params,\n activeIndex: previousIndex,\n realIndex: previousRealIndex,\n snapIndex: previousSnapIndex\n } = swiper;\n let activeIndex = newActiveIndex;\n let snapIndex;\n\n if (typeof activeIndex === 'undefined') {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {\n activeIndex = i;\n } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n activeIndex = i + 1;\n }\n } else if (translate >= slidesGrid[i]) {\n activeIndex = i;\n }\n } // Normalize slideIndex\n\n\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n }\n }\n\n if (snapGrid.indexOf(translate) >= 0) {\n snapIndex = snapGrid.indexOf(translate);\n } else {\n const skip = Math.min(params.slidesPerGroupSkip, activeIndex);\n snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);\n }\n\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n\n return;\n } // Get real index\n\n\n const realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n Object.assign(swiper, {\n snapIndex,\n realIndex,\n previousIndex,\n activeIndex\n });\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n\n if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateClickedSlide(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = $(e).closest(`.${params.slideClass}`)[0];\n let slideFound = false;\n let slideIndex;\n\n if (slide) {\n for (let i = 0; i < swiper.slides.length; i += 1) {\n if (swiper.slides[i] === slide) {\n slideFound = true;\n slideIndex = i;\n break;\n }\n }\n }\n\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n } else {\n swiper.clickedIndex = slideIndex;\n }\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n swiper.slideToClickedSlide();\n }\n}","import 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};","import { getTranslate } from '../../shared/utils.js';\nexport default function getSwiperTranslate(axis = this.isHorizontal() ? 'x' : 'y') {\n const swiper = this;\n const {\n params,\n rtlTranslate: rtl,\n translate,\n $wrapperEl\n } = swiper;\n\n if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n\n if (params.cssMode) {\n return translate;\n }\n\n let currentTranslate = getTranslate($wrapperEl[0], axis);\n if (rtl) currentTranslate = -currentTranslate;\n return currentTranslate || 0;\n}","export default function setTranslate(translate, byController) {\n const swiper = this;\n const {\n rtlTranslate: rtl,\n params,\n $wrapperEl,\n wrapperEl,\n progress\n } = swiper;\n let x = 0;\n let y = 0;\n const z = 0;\n\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n\n if (params.cssMode) {\n wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n } else if (!params.virtualTranslate) {\n $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);\n }\n\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress\n\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, byController);\n}","export default function minTranslate() {\n return -this.snapGrid[0];\n}","export default function maxTranslate() {\n return -this.snapGrid[this.snapGrid.length - 1];\n}","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function translateTo(translate = 0, speed = this.params.speed, runCallbacks = true, translateBounds = true, internal) {\n const swiper = this;\n const {\n params,\n wrapperEl\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\n }\n\n const minTranslate = swiper.minTranslate();\n const maxTranslate = swiper.maxTranslate();\n let newTranslate;\n if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate; // Update progress\n\n swiper.updateProgress(newTranslate);\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n\n if (speed === 0) {\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: -newTranslate,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: -newTranslate,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n if (speed === 0) {\n swiper.setTransition(0);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionEnd');\n }\n } else {\n swiper.setTransition(speed);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionStart');\n }\n\n if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onTranslateToWrapperTransitionEnd) {\n swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n swiper.onTranslateToWrapperTransitionEnd = null;\n delete swiper.onTranslateToWrapperTransitionEnd;\n\n if (runCallbacks) {\n swiper.emit('transitionEnd');\n }\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n }\n }\n\n return true;\n}","import setTransition from './setTransition.js';\nimport transitionStart from './transitionStart.js';\nimport transitionEnd from './transitionEnd.js';\nexport default {\n setTransition,\n transitionStart,\n transitionEnd\n};","export default function setTransition(duration, byController) {\n const swiper = this;\n\n if (!swiper.params.cssMode) {\n swiper.$wrapperEl.transition(duration);\n }\n\n swiper.emit('setTransition', duration, byController);\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionStart(runCallbacks = true, direction) {\n const swiper = this;\n const {\n params\n } = swiper;\n if (params.cssMode) return;\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step: 'Start'\n });\n}","export default function transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step\n}) {\n const {\n activeIndex,\n previousIndex\n } = swiper;\n let dir = direction;\n\n if (!dir) {\n if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n }\n\n swiper.emit(`transition${step}`);\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit(`slideResetTransition${step}`);\n return;\n }\n\n swiper.emit(`slideChangeTransition${step}`);\n\n if (dir === 'next') {\n swiper.emit(`slideNextTransition${step}`);\n } else {\n swiper.emit(`slidePrevTransition${step}`);\n }\n }\n}","import transitionEmit from './transitionEmit.js';\nexport default function 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 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 { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function slideTo(index = 0, speed = this.params.speed, runCallbacks = true, internal, initial) {\n if (typeof index !== 'number' && typeof index !== 'string') {\n throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);\n }\n\n if (typeof index === 'string') {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */\n const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */\n\n const isValidNumber = isFinite(indexAsNumber);\n\n if (!isValidNumber) {\n throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n } // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n\n\n index = indexAsNumber;\n }\n\n const swiper = this;\n let slideIndex = index;\n if (slideIndex < 0) slideIndex = 0;\n const {\n params,\n snapGrid,\n slidesGrid,\n previousIndex,\n activeIndex,\n rtlTranslate: rtl,\n wrapperEl,\n enabled\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {\n return false;\n }\n\n const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);\n let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n\n if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n }\n\n const translate = -snapGrid[snapIndex]; // Update progress\n\n swiper.updateProgress(translate); // Normalize slideIndex\n\n if (params.normalizeSlideIndex) {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n const normalizedTranslate = -Math.floor(translate * 100);\n const normalizedGrid = Math.floor(slidesGrid[i] * 100);\n const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);\n\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {\n slideIndex = i;\n } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {\n slideIndex = i + 1;\n }\n } else if (normalizedTranslate >= normalizedGrid) {\n slideIndex = i;\n }\n }\n } // Directions locks\n\n\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) return false;\n }\n }\n\n let direction;\n if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset'; // Update Index\n\n if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n swiper.updateActiveIndex(slideIndex); // Update Height\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n swiper.updateSlidesClasses();\n\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n\n return false;\n }\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n const t = rtl ? translate : -translate;\n\n if (speed === 0) {\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n if (isVirtual) {\n swiper.wrapperEl.style.scrollSnapType = 'none';\n swiper._immediateVirtual = true;\n }\n\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n\n if (isVirtual) {\n requestAnimationFrame(() => {\n swiper.wrapperEl.style.scrollSnapType = '';\n swiper._swiperImmediateVirtual = false;\n });\n }\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: t,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: t,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n swiper.setTransition(speed);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n\n if (speed === 0) {\n swiper.transitionEnd(runCallbacks, direction);\n } else if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onSlideToWrapperTransitionEnd) {\n swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n }\n\n return true;\n}","export default function slideToLoop(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n let newIndex = index;\n\n if (swiper.params.loop) {\n newIndex += swiper.loopedSlides;\n }\n\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideNext(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n animating,\n enabled,\n params\n } = swiper;\n if (!enabled) return swiper;\n let perGroup = params.slidesPerGroup;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n }\n\n const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n if (params.rewind && swiper.isEnd) {\n return swiper.slideTo(0, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slidePrev(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n params,\n animating,\n snapGrid,\n slidesGrid,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return swiper;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n\n function normalize(val) {\n if (val < 0) return -Math.floor(Math.abs(val));\n return Math.floor(val);\n }\n\n const normalizedTranslate = normalize(translate);\n const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n\n if (typeof prevSnap === 'undefined' && params.cssMode) {\n let prevSnapIndex;\n snapGrid.forEach((snap, snapIndex) => {\n if (normalizedTranslate >= snap) {\n // prevSnap = snap;\n prevSnapIndex = snapIndex;\n }\n });\n\n if (typeof prevSnapIndex !== 'undefined') {\n prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n }\n }\n\n let prevIndex = 0;\n\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;\n prevIndex = Math.max(prevIndex, 0);\n }\n }\n\n if (params.rewind && swiper.isBeginning) {\n return swiper.slideTo(swiper.slides.length - 1, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideReset(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideToClosest(speed = this.params.speed, runCallbacks = true, internal, threshold = 0.5) {\n const swiper = this;\n let index = swiper.activeIndex;\n const skip = Math.min(swiper.params.slidesPerGroupSkip, index);\n const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n if (translate >= swiper.snapGrid[snapIndex]) {\n // The current translate is on or after the current snap index, so the choice\n // is between the current index and the one after it.\n const currentSnap = swiper.snapGrid[snapIndex];\n const nextSnap = swiper.snapGrid[snapIndex + 1];\n\n if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {\n index += swiper.params.slidesPerGroup;\n }\n } else {\n // The current translate is before the current snap index, so the choice\n // is between the current index and the one before it.\n const prevSnap = swiper.snapGrid[snapIndex - 1];\n const currentSnap = swiper.snapGrid[snapIndex];\n\n if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n index -= swiper.params.slidesPerGroup;\n }\n }\n\n index = Math.max(index, 0);\n index = Math.min(index, swiper.slidesGrid.length - 1);\n return swiper.slideTo(index, speed, runCallbacks, internal);\n}","import $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nexport default function slideToClickedSlide() {\n const swiper = this;\n const {\n params,\n $wrapperEl\n } = swiper;\n const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n let slideToIndex = swiper.clickedIndex;\n let realIndex;\n\n if (params.loop) {\n if (swiper.animating) return;\n realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n\n if (params.centeredSlides) {\n if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n}","import loopCreate from './loopCreate.js';\nimport loopFix from './loopFix.js';\nimport loopDestroy from './loopDestroy.js';\nexport default {\n loopCreate,\n loopFix,\n loopDestroy\n};","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loopCreate() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n $wrapperEl\n } = swiper; // Remove duplicated slides\n\n const $selector = $wrapperEl.children().length > 0 ? $($wrapperEl.children()[0].parentNode) : $wrapperEl;\n $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();\n let slides = $selector.children(`.${params.slideClass}`);\n\n if (params.loopFillGroupWithBlank) {\n const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;\n\n if (blankSlidesNum !== params.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankNode = $(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);\n $selector.append(blankNode);\n }\n\n slides = $selector.children(`.${params.slideClass}`);\n }\n }\n\n if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;\n swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));\n swiper.loopedSlides += params.loopAdditionalSlides;\n\n if (swiper.loopedSlides > slides.length) {\n swiper.loopedSlides = slides.length;\n }\n\n const prependSlides = [];\n const appendSlides = [];\n slides.each((el, index) => {\n const slide = $(el);\n\n if (index < swiper.loopedSlides) {\n appendSlides.push(el);\n }\n\n if (index < slides.length && index >= slides.length - swiper.loopedSlides) {\n prependSlides.push(el);\n }\n\n slide.attr('data-swiper-slide-index', index);\n });\n\n for (let i = 0; i < appendSlides.length; i += 1) {\n $selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n\n for (let i = prependSlides.length - 1; i >= 0; i -= 1) {\n $selector.prepend($(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n}","export default function loopFix() {\n const swiper = this;\n swiper.emit('beforeLoopFix');\n const {\n activeIndex,\n slides,\n loopedSlides,\n allowSlidePrev,\n allowSlideNext,\n snapGrid,\n rtlTranslate: rtl\n } = swiper;\n let newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n const snapTranslate = -snapGrid[activeIndex];\n const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding\n\n if (activeIndex < loopedSlides) {\n newIndex = slides.length - loopedSlides * 3 + activeIndex;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n } else if (activeIndex >= slides.length - loopedSlides) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n }\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n swiper.emit('loopFix');\n}","export default function loopDestroy() {\n const swiper = this;\n const {\n $wrapperEl,\n params,\n slides\n } = swiper;\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();\n slides.removeAttr('data-swiper-slide-index');\n}","import setGrabCursor from './setGrabCursor.js';\nimport unsetGrabCursor from './unsetGrabCursor.js';\nexport default {\n setGrabCursor,\n unsetGrabCursor\n};","export default function setGrabCursor(moving) {\n const swiper = this;\n if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n el.style.cursor = 'move';\n el.style.cursor = moving ? '-webkit-grabbing' : '-webkit-grab';\n el.style.cursor = moving ? '-moz-grabbin' : '-moz-grab';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n}","export default function unsetGrabCursor() {\n const swiper = this;\n\n if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n return;\n }\n\n swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n}","import { getDocument } from 'ssr-window';\nimport onTouchStart from './onTouchStart.js';\nimport onTouchMove from './onTouchMove.js';\nimport onTouchEnd from './onTouchEnd.js';\nimport onResize from './onResize.js';\nimport onClick from './onClick.js';\nimport onScroll from './onScroll.js';\nlet dummyEventAttached = false;\n\nfunction dummyEventListener() {}\n\nconst events = (swiper, method) => {\n const document = getDocument();\n const {\n params,\n touchEvents,\n el,\n wrapperEl,\n device,\n support\n } = swiper;\n const capture = !!params.nested;\n const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n const swiperMethod = method; // Touch Events\n\n if (!support.touch) {\n el[domMethod](touchEvents.start, swiper.onTouchStart, false);\n document[domMethod](touchEvents.move, swiper.onTouchMove, capture);\n document[domMethod](touchEvents.end, swiper.onTouchEnd, false);\n } else {\n const passiveListener = touchEvents.start === 'touchstart' && support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);\n el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {\n passive: false,\n capture\n } : capture);\n el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);\n\n if (touchEvents.cancel) {\n el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);\n }\n } // Prevent Links Clicks\n\n\n if (params.preventClicks || params.preventClicksPropagation) {\n el[domMethod]('click', swiper.onClick, true);\n }\n\n if (params.cssMode) {\n wrapperEl[domMethod]('scroll', swiper.onScroll);\n } // Resize handler\n\n\n if (params.updateOnWindowResize) {\n swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);\n } else {\n swiper[swiperMethod]('observerUpdate', onResize, true);\n }\n};\n\nfunction attachEvents() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n support\n } = swiper;\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n\n if (params.cssMode) {\n swiper.onScroll = onScroll.bind(swiper);\n }\n\n swiper.onClick = onClick.bind(swiper);\n\n if (support.touch && !dummyEventAttached) {\n document.addEventListener('touchstart', dummyEventListener);\n dummyEventAttached = true;\n }\n\n events(swiper, 'on');\n}\n\nfunction detachEvents() {\n const swiper = this;\n events(swiper, 'off');\n}\n\nexport default {\n attachEvents,\n detachEvents\n};","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js'; // Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\n\nfunction closestElement(selector, base = this) {\n function __closestFrom(el) {\n if (!el || el === getDocument() || el === getWindow()) return null;\n if (el.assignedSlot) el = el.assignedSlot;\n const found = el.closest(selector);\n return found || __closestFrom(el.getRootNode().host);\n }\n\n return __closestFrom(base);\n}\n\nexport default function onTouchStart(event) {\n const swiper = this;\n const document = getDocument();\n const window = getWindow();\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n enabled\n } = swiper;\n if (!enabled) return;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n\n if (!swiper.animating && params.cssMode && params.loop) {\n swiper.loopFix();\n }\n\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n let $targetEl = $(e.target);\n\n if (params.touchEventsTarget === 'wrapper') {\n if (!$targetEl.closest(swiper.wrapperEl).length) return;\n }\n\n data.isTouchEvent = e.type === 'touchstart';\n if (!data.isTouchEvent && 'which' in e && e.which === 3) return;\n if (!data.isTouchEvent && 'button' in e && e.button > 0) return;\n if (data.isTouched && data.isMoved) return; // change target el for shadow root component\n\n const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== '';\n\n if (swipingClassHasValue && e.target && e.target.shadowRoot && event.path && event.path[0]) {\n $targetEl = $(event.path[0]);\n }\n\n const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element\n\n if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, e.target) : $targetEl.closest(noSwipingSelector)[0])) {\n swiper.allowClick = true;\n return;\n }\n\n if (params.swipeHandler) {\n if (!$targetEl.closest(params.swipeHandler)[0]) return;\n }\n\n touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n const startX = touches.currentX;\n const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n\n const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n\n if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n if (edgeSwipeDetection === 'prevent') {\n event.preventDefault();\n } else {\n return;\n }\n }\n\n Object.assign(data, {\n isTouched: true,\n isMoved: false,\n allowTouchCallbacks: true,\n isScrolling: undefined,\n startMoving: undefined\n });\n touches.startX = startX;\n touches.startY = startY;\n data.touchStartTime = now();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) data.allowThresholdMove = false;\n\n if (e.type !== 'touchstart') {\n let preventDefault = true;\n if ($targetEl.is(data.focusableElements)) preventDefault = false;\n\n if (document.activeElement && $(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) {\n document.activeElement.blur();\n }\n\n const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n\n if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) {\n e.preventDefault();\n }\n }\n\n swiper.emit('touchStart', e);\n}","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js';\nexport default function onTouchMove(event) {\n const document = getDocument();\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n return;\n }\n\n if (data.isTouchEvent && e.type !== 'touchmove') return;\n const targetTouch = e.type === 'touchmove' && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);\n const pageX = e.type === 'touchmove' ? targetTouch.pageX : e.pageX;\n const pageY = e.type === 'touchmove' ? targetTouch.pageY : e.pageY;\n\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n\n if (!swiper.allowTouchMove) {\n // isMoved = true;\n swiper.allowClick = false;\n\n if (data.isTouched) {\n Object.assign(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY\n });\n data.touchStartTime = now();\n }\n\n return;\n }\n\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) {\n // Vertical\n if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {\n data.isTouched = false;\n data.isMoved = false;\n return;\n }\n } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {\n return;\n }\n }\n\n if (data.isTouchEvent && document.activeElement) {\n if (e.target === document.activeElement && $(e.target).is(data.focusableElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\n }\n\n if (e.targetTouches && e.targetTouches.length > 1) return;\n touches.currentX = pageX;\n touches.currentY = pageY;\n const diffX = touches.currentX - touches.startX;\n const diffY = touches.currentY - touches.startY;\n if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;\n\n if (typeof data.isScrolling === 'undefined') {\n let touchAngle;\n\n if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {\n data.isScrolling = false;\n } else {\n // eslint-disable-next-line\n if (diffX * diffX + diffY * diffY >= 25) {\n touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;\n data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;\n }\n }\n }\n\n if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n\n if (!data.startMoving) {\n return;\n }\n\n swiper.allowClick = false;\n\n if (!params.cssMode && e.cancelable) {\n e.preventDefault();\n }\n\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n\n if (!data.isMoved) {\n if (params.loop && !params.cssMode) {\n swiper.loopFix();\n }\n\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n\n if (swiper.animating) {\n swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n }\n\n data.allowMomentumBounce = false; // Grab Cursor\n\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n\n swiper.emit('sliderFirstMove', e);\n }\n\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n let diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n diff *= params.touchRatio;\n if (rtl) diff = -diff;\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n data.currentTranslate = diff + data.startTranslate;\n let disableParentSwiper = true;\n let resistanceRatio = params.resistanceRatio;\n\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n\n if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n }\n\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n } // Directions locks\n\n\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n data.currentTranslate = data.startTranslate;\n } // Threshold\n\n\n if (params.threshold > 0) {\n if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n if (!data.allowThresholdMove) {\n data.allowThresholdMove = true;\n touches.startX = touches.currentX;\n touches.startY = touches.currentY;\n data.currentTranslate = data.startTranslate;\n touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n return;\n }\n } else {\n data.currentTranslate = data.startTranslate;\n return;\n }\n }\n\n if (!params.followFinger || params.cssMode) return; // Update active index in free mode\n\n if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n swiper.freeMode.onTouchMove();\n } // Update progress\n\n\n swiper.updateProgress(data.currentTranslate); // Update translate\n\n swiper.setTranslate(data.currentTranslate);\n}","import { now, nextTick } from '../../shared/utils.js';\nexport default function onTouchEnd(event) {\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n slidesGrid,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n\n data.allowTouchCallbacks = false;\n\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n\n data.isMoved = false;\n data.startMoving = false;\n return;\n } // Return Grab Cursor\n\n\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n } // Time diff\n\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click\n\n if (swiper.allowClick) {\n const pathTree = e.path || e.composedPath && e.composedPath();\n swiper.updateClickedSlide(pathTree && pathTree[0] || e.target);\n swiper.emit('tap click', e);\n\n if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n swiper.emit('doubleTap doubleClick', e);\n }\n }\n\n data.lastClickTime = now();\n nextTick(() => {\n if (!swiper.destroyed) swiper.allowClick = true;\n });\n\n if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n let currentPos;\n\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n\n if (params.cssMode) {\n return;\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled) {\n swiper.freeMode.onTouchEnd({\n currentPos\n });\n return;\n } // Find current slide\n\n\n let stopIndex = 0;\n let groupSize = swiper.slidesSizesGrid[0];\n\n for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {\n const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (typeof slidesGrid[i + increment] !== 'undefined') {\n if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {\n stopIndex = i;\n groupSize = slidesGrid[i + increment] - slidesGrid[i];\n }\n } else if (currentPos >= slidesGrid[i]) {\n stopIndex = i;\n groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n }\n } // Find current slide size\n\n\n const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (swiper.swipeDirection === 'next') {\n if (ratio >= params.longSwipesRatio) swiper.slideTo(stopIndex + increment);else swiper.slideTo(stopIndex);\n }\n\n if (swiper.swipeDirection === 'prev') {\n if (ratio > 1 - params.longSwipesRatio) swiper.slideTo(stopIndex + increment);else swiper.slideTo(stopIndex);\n }\n } else {\n // Short swipes\n if (!params.shortSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n\n if (!isNavButtonTarget) {\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(stopIndex + increment);\n }\n\n if (swiper.swipeDirection === 'prev') {\n swiper.slideTo(stopIndex);\n }\n } else if (e.target === swiper.navigation.nextEl) {\n swiper.slideTo(stopIndex + increment);\n } else {\n swiper.slideTo(stopIndex);\n }\n }\n}","export default function onResize() {\n const swiper = this;\n const {\n params,\n el\n } = swiper;\n if (el && el.offsetWidth === 0) return; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n } // Save locks\n\n\n const {\n allowSlideNext,\n allowSlidePrev,\n snapGrid\n } = swiper; // Disable locks on resize\n\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateSlidesClasses();\n\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.run();\n } // Return locks after resize\n\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n}","export default function onClick(e) {\n const swiper = this;\n if (!swiper.enabled) return;\n\n if (!swiper.allowClick) {\n if (swiper.params.preventClicks) e.preventDefault();\n\n if (swiper.params.preventClicksPropagation && swiper.animating) {\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n}","export default function onScroll() {\n const swiper = this;\n const {\n wrapperEl,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return;\n swiper.previousTranslate = swiper.translate;\n\n if (swiper.isHorizontal()) {\n swiper.translate = -wrapperEl.scrollLeft;\n } else {\n swiper.translate = -wrapperEl.scrollTop;\n } // eslint-disable-next-line\n\n\n if (swiper.translate === -0) swiper.translate = 0;\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== swiper.progress) {\n swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, false);\n}","import setBreakpoint from './setBreakpoint.js';\nimport getBreakpoint from './getBreakpoint.js';\nexport default {\n setBreakpoint,\n getBreakpoint\n};","import { extend } from '../../shared/utils.js';\n\nconst isGridEnabled = (swiper, params) => {\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\n\nexport default function setBreakpoint() {\n const swiper = this;\n const {\n activeIndex,\n initialized,\n loopedSlides = 0,\n params,\n $el\n } = swiper;\n const breakpoints = params.breakpoints;\n if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters\n\n const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);\n if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;\n const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n const breakpointParams = breakpointOnlyParams || swiper.originalParams;\n const wasMultiRow = isGridEnabled(swiper, params);\n const isMultiRow = isGridEnabled(swiper, breakpointParams);\n const wasEnabled = params.enabled;\n\n if (wasMultiRow && !isMultiRow) {\n $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n } else if (!wasMultiRow && isMultiRow) {\n $el.addClass(`${params.containerModifierClass}grid`);\n\n if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n $el.addClass(`${params.containerModifierClass}grid-column`);\n }\n\n swiper.emitContainerClasses();\n }\n\n const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n if (directionChanged && initialized) {\n swiper.changeDirection();\n }\n\n extend(swiper.params, breakpointParams);\n const isEnabled = swiper.params.enabled;\n Object.assign(swiper, {\n allowTouchMove: swiper.params.allowTouchMove,\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev\n });\n\n if (wasEnabled && !isEnabled) {\n swiper.disable();\n } else if (!wasEnabled && isEnabled) {\n swiper.enable();\n }\n\n swiper.currentBreakpoint = breakpoint;\n swiper.emit('_beforeBreakpoint', breakpointParams);\n\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);\n }\n\n swiper.emit('breakpoint', breakpointParams);\n}","import { getWindow } from 'ssr-window';\nexport default function getBreakpoint(breakpoints, base = 'window', containerEl) {\n if (!breakpoints || base === 'container' && !containerEl) return undefined;\n let breakpoint = false;\n const window = getWindow();\n const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;\n const points = Object.keys(breakpoints).map(point => {\n if (typeof point === 'string' && point.indexOf('@') === 0) {\n const minRatio = parseFloat(point.substr(1));\n const value = currentHeight * minRatio;\n return {\n value,\n point\n };\n }\n\n return {\n value: point,\n point\n };\n });\n points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n\n for (let i = 0; i < points.length; i += 1) {\n const {\n point,\n value\n } = points[i];\n\n if (base === 'window') {\n if (window.matchMedia(`(min-width: ${value}px)`).matches) {\n breakpoint = point;\n }\n } else if (value <= containerEl.clientWidth) {\n breakpoint = point;\n }\n }\n\n return breakpoint || 'max';\n}","import addClasses from './addClasses.js';\nimport removeClasses from './removeClasses.js';\nexport default {\n addClasses,\n removeClasses\n};","function prepareClasses(entries, prefix) {\n const resultClasses = [];\n entries.forEach(item => {\n if (typeof item === 'object') {\n Object.keys(item).forEach(classNames => {\n if (item[classNames]) {\n resultClasses.push(prefix + classNames);\n }\n });\n } else if (typeof item === 'string') {\n resultClasses.push(prefix + item);\n }\n });\n return resultClasses;\n}\n\nexport default function addClasses() {\n const swiper = this;\n const {\n classNames,\n params,\n rtl,\n $el,\n device,\n support\n } = swiper; // prettier-ignore\n\n const suffixes = prepareClasses(['initialized', params.direction, {\n 'pointer-events': !support.touch\n }, {\n 'free-mode': swiper.params.freeMode && params.freeMode.enabled\n }, {\n 'autoheight': params.autoHeight\n }, {\n 'rtl': rtl\n }, {\n 'grid': params.grid && params.grid.rows > 1\n }, {\n 'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'\n }, {\n 'android': device.android\n }, {\n 'ios': device.ios\n }, {\n 'css-mode': params.cssMode\n }, {\n 'centered': params.cssMode && params.centeredSlides\n }], params.containerModifierClass);\n classNames.push(...suffixes);\n $el.addClass([...classNames].join(' '));\n swiper.emitContainerClasses();\n}","export default function removeClasses() {\n const swiper = this;\n const {\n $el,\n classNames\n } = swiper;\n $el.removeClass(classNames.join(' '));\n swiper.emitContainerClasses();\n}","import loadImage from './loadImage.js';\nimport preloadImages from './preloadImages.js';\nexport default {\n loadImage,\n preloadImages\n};","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {\n const window = getWindow();\n let image;\n\n function onReady() {\n if (callback) callback();\n }\n\n const isPicture = $(imageEl).parent('picture')[0];\n\n if (!isPicture && (!imageEl.complete || !checkForComplete)) {\n if (src) {\n image = new window.Image();\n image.onload = onReady;\n image.onerror = onReady;\n\n if (sizes) {\n image.sizes = sizes;\n }\n\n if (srcset) {\n image.srcset = srcset;\n }\n\n if (src) {\n image.src = src;\n }\n } else {\n onReady();\n }\n } else {\n // image already loaded...\n onReady();\n }\n}","export default function preloadImages() {\n const swiper = this;\n swiper.imagesToLoad = swiper.$el.find('img');\n\n function onReady() {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) return;\n if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;\n\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) swiper.update();\n swiper.emit('imagesReady');\n }\n }\n\n for (let i = 0; i < swiper.imagesToLoad.length; i += 1) {\n const imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute('src'), imageEl.srcset || imageEl.getAttribute('srcset'), imageEl.sizes || imageEl.getAttribute('sizes'), true, onReady);\n }\n}","function checkOverflow() {\n const swiper = this;\n const {\n isLocked: wasLocked,\n params\n } = swiper;\n const {\n slidesOffsetBefore\n } = params;\n\n if (slidesOffsetBefore) {\n const lastSlideIndex = swiper.slides.length - 1;\n const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;\n swiper.isLocked = swiper.size > lastSlideRightEdge;\n } else {\n swiper.isLocked = swiper.snapGrid.length === 1;\n }\n\n if (params.allowSlideNext === true) {\n swiper.allowSlideNext = !swiper.isLocked;\n }\n\n if (params.allowSlidePrev === true) {\n swiper.allowSlidePrev = !swiper.isLocked;\n }\n\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n }\n\n if (wasLocked !== swiper.isLocked) {\n swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n }\n}\n\nexport default {\n checkOverflow\n};","export default {\n init: true,\n direction: 'horizontal',\n touchEventsTarget: 'wrapper',\n initialSlide: 0,\n speed: 300,\n cssMode: false,\n updateOnWindowResize: true,\n resizeObserver: true,\n nested: false,\n createElements: false,\n enabled: true,\n focusableElements: 'input, select, option, textarea, button, video, label',\n // Overrides\n width: null,\n height: null,\n //\n preventInteractionOnTransition: false,\n // ssr\n userAgent: null,\n url: null,\n // To support iOS's swipe-to-go-back gesture (when being used in-app).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n // Autoheight\n autoHeight: false,\n // Set wrapper width\n setWrapperSize: false,\n // Virtual Translate\n virtualTranslate: false,\n // Effects\n effect: 'slide',\n // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n // Breakpoints\n breakpoints: undefined,\n breakpointsBase: 'window',\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerGroup: 1,\n slidesPerGroupSkip: 0,\n slidesPerGroupAuto: false,\n centeredSlides: false,\n centeredSlidesBounds: false,\n slidesOffsetBefore: 0,\n // in px\n slidesOffsetAfter: 0,\n // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: true,\n // Round length\n roundLengths: false,\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: false,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n // Unique Navigation Elements\n uniqueNavElements: true,\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n // Progress\n watchSlidesProgress: false,\n // Cursor\n grabCursor: false,\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopFillGroupWithBlank: false,\n loopPreventsSlide: true,\n // rewind\n rewind: false,\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null,\n // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: 'swiper-no-swiping',\n noSwipingSelector: null,\n // Passive Listeners\n passiveListeners: true,\n // NS\n containerModifierClass: 'swiper-',\n // NEW\n slideClass: 'swiper-slide',\n slideBlankClass: 'swiper-slide-invisible-blank',\n slideActiveClass: 'swiper-slide-active',\n slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideDuplicateClass: 'swiper-slide-duplicate',\n slideNextClass: 'swiper-slide-next',\n slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n slidePrevClass: 'swiper-slide-prev',\n slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n wrapperClass: 'swiper-wrapper',\n // Callbacks\n runCallbacksOnInit: true,\n // Internals\n _emitClasses: false\n};","import { extend } from '../shared/utils.js';\nexport default function moduleExtendParams(params, allModulesParams) {\n return function extendParams(obj = {}) {\n const moduleParamName = Object.keys(obj)[0];\n const moduleParams = obj[moduleParamName];\n\n if (typeof moduleParams !== 'object' || moduleParams === null) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {\n params[moduleParamName] = {\n auto: true\n };\n }\n\n if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (params[moduleParamName] === true) {\n params[moduleParamName] = {\n enabled: true\n };\n }\n\n if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n params[moduleParamName].enabled = true;\n }\n\n if (!params[moduleParamName]) params[moduleParamName] = {\n enabled: false\n };\n extend(allModulesParams, obj);\n };\n}","import $ from '../../shared/dom.js';\nimport { setCSSProperty } from '../../shared/utils.js';\nexport default function Virtual({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n virtual: {\n enabled: false,\n slides: [],\n cache: true,\n renderSlide: null,\n renderExternal: null,\n renderExternalUpdate: true,\n addSlidesBefore: 0,\n addSlidesAfter: 0\n }\n });\n let cssModeTimeout;\n swiper.virtual = {\n cache: {},\n from: undefined,\n to: undefined,\n slides: [],\n offset: 0,\n slidesGrid: []\n };\n\n function renderSlide(slide, index) {\n const params = swiper.params.virtual;\n\n if (params.cache && swiper.virtual.cache[index]) {\n return swiper.virtual.cache[index];\n }\n\n const $slideEl = params.renderSlide ? $(params.renderSlide.call(swiper, slide, index)) : $(`
${slide}
`);\n if (!$slideEl.attr('data-swiper-slide-index')) $slideEl.attr('data-swiper-slide-index', index);\n if (params.cache) swiper.virtual.cache[index] = $slideEl;\n return $slideEl;\n }\n\n function update(force) {\n const {\n slidesPerView,\n slidesPerGroup,\n centeredSlides\n } = swiper.params;\n const {\n addSlidesBefore,\n addSlidesAfter\n } = swiper.params.virtual;\n const {\n from: previousFrom,\n to: previousTo,\n slides,\n slidesGrid: previousSlidesGrid,\n offset: previousOffset\n } = swiper.virtual;\n\n if (!swiper.params.cssMode) {\n swiper.updateActiveIndex();\n }\n\n const activeIndex = swiper.activeIndex || 0;\n let offsetProp;\n if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';\n let slidesAfter;\n let slidesBefore;\n\n if (centeredSlides) {\n slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n } else {\n slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;\n slidesBefore = slidesPerGroup + addSlidesBefore;\n }\n\n const from = Math.max((activeIndex || 0) - slidesBefore, 0);\n const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);\n const offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n Object.assign(swiper.virtual, {\n from,\n to,\n offset,\n slidesGrid: swiper.slidesGrid\n });\n\n function onRendered() {\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n }\n\n if (previousFrom === from && previousTo === to && !force) {\n if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n swiper.slides.css(offsetProp, `${offset}px`);\n }\n\n swiper.updateProgress();\n return;\n }\n\n if (swiper.params.virtual.renderExternal) {\n swiper.params.virtual.renderExternal.call(swiper, {\n offset,\n from,\n to,\n slides: function getSlides() {\n const slidesToRender = [];\n\n for (let i = from; i <= to; i += 1) {\n slidesToRender.push(slides[i]);\n }\n\n return slidesToRender;\n }()\n });\n\n if (swiper.params.virtual.renderExternalUpdate) {\n onRendered();\n }\n\n return;\n }\n\n const prependIndexes = [];\n const appendIndexes = [];\n\n if (force) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();\n } else {\n for (let i = previousFrom; i <= previousTo; i += 1) {\n if (i < from || i > to) {\n swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${i}\"]`).remove();\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n if (i >= from && i <= to) {\n if (typeof previousTo === 'undefined' || force) {\n appendIndexes.push(i);\n } else {\n if (i > previousTo) appendIndexes.push(i);\n if (i < previousFrom) prependIndexes.push(i);\n }\n }\n }\n\n appendIndexes.forEach(index => {\n swiper.$wrapperEl.append(renderSlide(slides[index], index));\n });\n prependIndexes.sort((a, b) => b - a).forEach(index => {\n swiper.$wrapperEl.prepend(renderSlide(slides[index], index));\n });\n swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, `${offset}px`);\n onRendered();\n }\n\n function appendSlide(slides) {\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.push(slides[i]);\n }\n } else {\n swiper.virtual.slides.push(slides);\n }\n\n update(true);\n }\n\n function prependSlide(slides) {\n const activeIndex = swiper.activeIndex;\n let newActiveIndex = activeIndex + 1;\n let numberOfNewSlides = 1;\n\n if (Array.isArray(slides)) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) swiper.virtual.slides.unshift(slides[i]);\n }\n\n newActiveIndex = activeIndex + slides.length;\n numberOfNewSlides = slides.length;\n } else {\n swiper.virtual.slides.unshift(slides);\n }\n\n if (swiper.params.virtual.cache) {\n const cache = swiper.virtual.cache;\n const newCache = {};\n Object.keys(cache).forEach(cachedIndex => {\n const $cachedEl = cache[cachedIndex];\n const cachedElIndex = $cachedEl.attr('data-swiper-slide-index');\n\n if (cachedElIndex) {\n $cachedEl.attr('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);\n }\n\n newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = $cachedEl;\n });\n swiper.virtual.cache = newCache;\n }\n\n update(true);\n swiper.slideTo(newActiveIndex, 0);\n }\n\n function removeSlide(slidesIndexes) {\n if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;\n let activeIndex = swiper.activeIndex;\n\n if (Array.isArray(slidesIndexes)) {\n for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n swiper.virtual.slides.splice(slidesIndexes[i], 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes[i]];\n }\n\n if (slidesIndexes[i] < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n } else {\n swiper.virtual.slides.splice(slidesIndexes, 1);\n\n if (swiper.params.virtual.cache) {\n delete swiper.virtual.cache[slidesIndexes];\n }\n\n if (slidesIndexes < activeIndex) activeIndex -= 1;\n activeIndex = Math.max(activeIndex, 0);\n }\n\n update(true);\n swiper.slideTo(activeIndex, 0);\n }\n\n function removeAllSlides() {\n swiper.virtual.slides = [];\n\n if (swiper.params.virtual.cache) {\n swiper.virtual.cache = {};\n }\n\n update(true);\n swiper.slideTo(0, 0);\n }\n\n on('beforeInit', () => {\n if (!swiper.params.virtual.enabled) return;\n swiper.virtual.slides = swiper.params.virtual.slides;\n swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n\n if (!swiper.params.initialSlide) {\n update();\n }\n });\n on('setTranslate', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode && !swiper._immediateVirtual) {\n clearTimeout(cssModeTimeout);\n cssModeTimeout = setTimeout(() => {\n update();\n }, 100);\n } else {\n update();\n }\n });\n on('init update resize', () => {\n if (!swiper.params.virtual.enabled) return;\n\n if (swiper.params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);\n }\n });\n Object.assign(swiper.virtual, {\n appendSlide,\n prependSlide,\n removeSlide,\n removeAllSlides,\n update\n });\n}","/* eslint-disable consistent-return */\nimport { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Keyboard({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n const window = getWindow();\n swiper.keyboard = {\n enabled: false\n };\n extendParams({\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n pageUpDown: true\n }\n });\n\n function handle(event) {\n if (!swiper.enabled) return;\n const {\n rtlTranslate: rtl\n } = swiper;\n let e = event;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n const kc = e.keyCode || e.charCode;\n const pageUpDown = swiper.params.keyboard.pageUpDown;\n const isPageUp = pageUpDown && kc === 33;\n const isPageDown = pageUpDown && kc === 34;\n const isArrowLeft = kc === 37;\n const isArrowRight = kc === 39;\n const isArrowUp = kc === 38;\n const isArrowDown = kc === 40; // Directions locks\n\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n if (!inView) return undefined;\n }\n\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n } else {\n if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n\n emit('keyPress', kc);\n return undefined;\n }\n\n function enable() {\n if (swiper.keyboard.enabled) return;\n $(document).on('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n\n function disable() {\n if (!swiper.keyboard.enabled) return;\n $(document).off('keydown', handle);\n swiper.keyboard.enabled = false;\n }\n\n on('init', () => {\n if (swiper.params.keyboard.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n if (swiper.keyboard.enabled) {\n disable();\n }\n });\n Object.assign(swiper.keyboard, {\n enable,\n disable\n });\n}","/* eslint-disable consistent-return */\nimport { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now, nextTick } from '../../shared/utils.js';\nexport default function Mousewheel({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n mousewheel: {\n enabled: false,\n releaseOnEdges: false,\n invert: false,\n forceToAxis: false,\n sensitivity: 1,\n eventsTarget: 'container',\n thresholdDelta: null,\n thresholdTime: null\n }\n });\n swiper.mousewheel = {\n enabled: false\n };\n let timeout;\n let lastScrollTime = now();\n let lastEventBeforeSnap;\n const recentWheelEvents = [];\n\n function normalize(e) {\n // Reasonable defaults\n const PIXEL_STEP = 10;\n const LINE_HEIGHT = 40;\n const PAGE_HEIGHT = 800;\n let sX = 0;\n let sY = 0; // spinX, spinY\n\n let pX = 0;\n let pY = 0; // pixelX, pixelY\n // Legacy\n\n if ('detail' in e) {\n sY = e.detail;\n }\n\n if ('wheelDelta' in e) {\n sY = -e.wheelDelta / 120;\n }\n\n if ('wheelDeltaY' in e) {\n sY = -e.wheelDeltaY / 120;\n }\n\n if ('wheelDeltaX' in e) {\n sX = -e.wheelDeltaX / 120;\n } // side scrolling on FF with DOMMouseScroll\n\n\n if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in e) {\n pY = e.deltaY;\n }\n\n if ('deltaX' in e) {\n pX = e.deltaX;\n }\n\n if (e.shiftKey && !pX) {\n // if user scrolls with shift he wants horizontal scroll\n pX = pY;\n pY = 0;\n }\n\n if ((pX || pY) && e.deltaMode) {\n if (e.deltaMode === 1) {\n // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else {\n // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n } // Fall-back if spin cannot be determined\n\n\n if (pX && !sX) {\n sX = pX < 1 ? -1 : 1;\n }\n\n if (pY && !sY) {\n sY = pY < 1 ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: sY,\n pixelX: pX,\n pixelY: pY\n };\n }\n\n function handleMouseEnter() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = true;\n }\n\n function handleMouseLeave() {\n if (!swiper.enabled) return;\n swiper.mouseEntered = false;\n }\n\n function animateSlider(newEvent) {\n if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {\n // Prevent if delta of wheel scroll delta is below configured threshold\n return false;\n }\n\n if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {\n // Prevent if time between scrolls is below configured threshold\n return false;\n } // If the movement is NOT big enough and\n // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):\n // Don't go any further (avoid insignificant scroll movement).\n\n\n if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {\n // Return false as a default\n return true;\n } // If user is scrolling towards the end:\n // If the slider hasn't hit the latest slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to next slide and\n // emit a scroll event.\n // Else (the user is scrolling towards the beginning) and\n // if the slider hasn't hit the first slide or\n // if the slider is a loop and\n // if the slider isn't moving right now:\n // Go to prev slide and\n // emit a scroll event.\n\n\n if (newEvent.direction < 0) {\n if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n swiper.slideNext();\n emit('scroll', newEvent.raw);\n }\n } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n swiper.slidePrev();\n emit('scroll', newEvent.raw);\n } // If you got here is because an animation has been triggered so store the current time\n\n\n lastScrollTime = new window.Date().getTime(); // Return false as a default\n\n return false;\n }\n\n function releaseScroll(newEvent) {\n const params = swiper.params.mousewheel;\n\n if (newEvent.direction < 0) {\n if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {\n // Return true to animate scroll on edges\n return true;\n }\n\n return false;\n }\n\n function handle(event) {\n let e = event;\n let disableParentSwiper = true;\n if (!swiper.enabled) return;\n const params = swiper.params.mousewheel;\n\n if (swiper.params.cssMode) {\n e.preventDefault();\n }\n\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n if (!swiper.mouseEntered && !target[0].contains(e.target) && !params.releaseOnEdges) return true;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n let delta = 0;\n const rtlFactor = swiper.rtlTranslate ? -1 : 1;\n const data = normalize(e);\n\n if (params.forceToAxis) {\n if (swiper.isHorizontal()) {\n if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;\n } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;\n } else {\n delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n }\n\n if (delta === 0) return true;\n if (params.invert) delta = -delta; // Get the scroll positions\n\n let positions = swiper.getTranslate() + delta * params.sensitivity;\n if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();\n if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate(); // When loop is true:\n // the disableParentSwiper will be true.\n // When loop is false:\n // if the scroll positions is not on edge,\n // then the disableParentSwiper will be true.\n // if the scroll on edge positions,\n // then the disableParentSwiper will be false.\n\n disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());\n if (disableParentSwiper && swiper.params.nested) e.stopPropagation();\n\n if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {\n // Register the new event in a variable which stores the relevant data\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta),\n raw: event\n }; // Keep the most recent events\n\n if (recentWheelEvents.length >= 2) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n recentWheelEvents.push(newEvent); // If there is at least one previous recorded event:\n // If direction has changed or\n // if the scroll is quicker than the previous one:\n // Animate the slider.\n // Else (this is the first time the wheel is moved):\n // Animate the slider.\n\n if (prevEvent) {\n if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {\n animateSlider(newEvent);\n }\n } else {\n animateSlider(newEvent);\n } // If it's time to release the scroll:\n // Return now so you don't hit the preventDefault.\n\n\n if (releaseScroll(newEvent)) {\n return true;\n }\n } else {\n // Freemode or scrollContainer:\n // If we recently snapped after a momentum scroll, then ignore wheel events\n // to give time for the deceleration to finish. Stop ignoring after 500 msecs\n // or if it's a new scroll (larger delta or inverse sign as last event before\n // an end-of-momentum snap).\n const newEvent = {\n time: now(),\n delta: Math.abs(delta),\n direction: Math.sign(delta)\n };\n const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;\n\n if (!ignoreWheelEvents) {\n lastEventBeforeSnap = undefined;\n\n if (swiper.params.loop) {\n swiper.loopFix();\n }\n\n let position = swiper.getTranslate() + delta * params.sensitivity;\n const wasBeginning = swiper.isBeginning;\n const wasEnd = swiper.isEnd;\n if (position >= swiper.minTranslate()) position = swiper.minTranslate();\n if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();\n swiper.setTransition(0);\n swiper.setTranslate(position);\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n\n if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode.sticky) {\n // When wheel scrolling starts with sticky (aka snap) enabled, then detect\n // the end of a momentum scroll by storing recent (N=15?) wheel events.\n // 1. do all N events have decreasing or same (absolute value) delta?\n // 2. did all N events arrive in the last M (M=500?) msecs?\n // 3. does the earliest event have an (absolute value) delta that's\n // at least P (P=1?) larger than the most recent event's delta?\n // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?\n // If 1-4 are \"yes\" then we're near the end of a momentum scroll deceleration.\n // Snap immediately and ignore remaining wheel events in this scroll.\n // See comment above for \"remaining wheel events in this scroll\" determination.\n // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.\n clearTimeout(timeout);\n timeout = undefined;\n\n if (recentWheelEvents.length >= 15) {\n recentWheelEvents.shift(); // only store the last N events\n }\n\n const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n const firstEvent = recentWheelEvents[0];\n recentWheelEvents.push(newEvent);\n\n if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {\n // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.\n recentWheelEvents.splice(0);\n } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {\n // We're at the end of the deceleration of a momentum scroll, so there's no need\n // to wait for more events. Snap ASAP on the next tick.\n // Also, because there's some remaining momentum we'll bias the snap in the\n // direction of the ongoing scroll because it's better UX for the scroll to snap\n // in the same direction as the scroll instead of reversing to snap. Therefore,\n // if it's already scrolled more than 20% in the current direction, keep going.\n const snapToThreshold = delta > 0 ? 0.8 : 0.2;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n timeout = nextTick(() => {\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 0); // no delay; move on next tick\n }\n\n if (!timeout) {\n // if we get here, then we haven't detected the end of a momentum scroll, so\n // we'll consider a scroll \"complete\" when there haven't been any wheel events\n // for 500ms.\n timeout = nextTick(() => {\n const snapToThreshold = 0.5;\n lastEventBeforeSnap = newEvent;\n recentWheelEvents.splice(0);\n swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n }, 500);\n }\n } // Emit event\n\n\n if (!ignoreWheelEvents) emit('scroll', e); // Stop autoplay\n\n if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop(); // Return page scroll on edge positions\n\n if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;\n }\n }\n\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n return false;\n }\n\n function events(method) {\n let target = swiper.$el;\n\n if (swiper.params.mousewheel.eventsTarget !== 'container') {\n target = $(swiper.params.mousewheel.eventsTarget);\n }\n\n target[method]('mouseenter', handleMouseEnter);\n target[method]('mouseleave', handleMouseLeave);\n target[method]('wheel', handle);\n }\n\n function enable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.removeEventListener('wheel', handle);\n return true;\n }\n\n if (swiper.mousewheel.enabled) return false;\n events('on');\n swiper.mousewheel.enabled = true;\n return true;\n }\n\n function disable() {\n if (swiper.params.cssMode) {\n swiper.wrapperEl.addEventListener(event, handle);\n return true;\n }\n\n if (!swiper.mousewheel.enabled) return false;\n events('off');\n swiper.mousewheel.enabled = false;\n return true;\n }\n\n on('init', () => {\n if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {\n disable();\n }\n\n if (swiper.params.mousewheel.enabled) enable();\n });\n on('destroy', () => {\n if (swiper.params.cssMode) {\n enable();\n }\n\n if (swiper.mousewheel.enabled) disable();\n });\n Object.assign(swiper.mousewheel, {\n enable,\n disable\n });\n}","import createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nimport $ from '../../shared/dom.js';\nexport default function Navigation({\n swiper,\n extendParams,\n on,\n emit\n}) {\n extendParams({\n navigation: {\n nextEl: null,\n prevEl: null,\n hideOnClick: false,\n disabledClass: 'swiper-button-disabled',\n hiddenClass: 'swiper-button-hidden',\n lockClass: 'swiper-button-lock'\n }\n });\n swiper.navigation = {\n nextEl: null,\n $nextEl: null,\n prevEl: null,\n $prevEl: null\n };\n\n function getEl(el) {\n let $el;\n\n if (el) {\n $el = $(el);\n\n if (swiper.params.uniqueNavElements && typeof el === 'string' && $el.length > 1 && swiper.$el.find(el).length === 1) {\n $el = swiper.$el.find(el);\n }\n }\n\n return $el;\n }\n\n function toggleEl($el, disabled) {\n const params = swiper.params.navigation;\n\n if ($el && $el.length > 0) {\n $el[disabled ? 'addClass' : 'removeClass'](params.disabledClass);\n if ($el[0] && $el[0].tagName === 'BUTTON') $el[0].disabled = disabled;\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n }\n }\n\n function update() {\n // Update Navigation Buttons\n if (swiper.params.loop) return;\n const {\n $nextEl,\n $prevEl\n } = swiper.navigation;\n toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind);\n toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind);\n }\n\n function onPrevClick(e) {\n e.preventDefault();\n if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;\n swiper.slidePrev();\n }\n\n function onNextClick(e) {\n e.preventDefault();\n if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;\n swiper.slideNext();\n }\n\n function init() {\n const params = swiper.params.navigation;\n swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {\n nextEl: 'swiper-button-next',\n prevEl: 'swiper-button-prev'\n });\n if (!(params.nextEl || params.prevEl)) return;\n const $nextEl = getEl(params.nextEl);\n const $prevEl = getEl(params.prevEl);\n\n if ($nextEl && $nextEl.length > 0) {\n $nextEl.on('click', onNextClick);\n }\n\n if ($prevEl && $prevEl.length > 0) {\n $prevEl.on('click', onPrevClick);\n }\n\n Object.assign(swiper.navigation, {\n $nextEl,\n nextEl: $nextEl && $nextEl[0],\n $prevEl,\n prevEl: $prevEl && $prevEl[0]\n });\n\n if (!swiper.enabled) {\n if ($nextEl) $nextEl.addClass(params.lockClass);\n if ($prevEl) $prevEl.addClass(params.lockClass);\n }\n }\n\n function destroy() {\n const {\n $nextEl,\n $prevEl\n } = swiper.navigation;\n\n if ($nextEl && $nextEl.length) {\n $nextEl.off('click', onNextClick);\n $nextEl.removeClass(swiper.params.navigation.disabledClass);\n }\n\n if ($prevEl && $prevEl.length) {\n $prevEl.off('click', onPrevClick);\n $prevEl.removeClass(swiper.params.navigation.disabledClass);\n }\n }\n\n on('init', () => {\n init();\n update();\n });\n on('toEdge fromEdge lock unlock', () => {\n update();\n });\n on('destroy', () => {\n destroy();\n });\n on('enable disable', () => {\n const {\n $nextEl,\n $prevEl\n } = swiper.navigation;\n\n if ($nextEl) {\n $nextEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);\n }\n\n if ($prevEl) {\n $prevEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);\n }\n });\n on('click', (_s, e) => {\n const {\n $nextEl,\n $prevEl\n } = swiper.navigation;\n const targetEl = e.target;\n\n if (swiper.params.navigation.hideOnClick && !$(targetEl).is($prevEl) && !$(targetEl).is($nextEl)) {\n if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;\n let isHidden;\n\n if ($nextEl) {\n isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);\n } else if ($prevEl) {\n isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);\n }\n\n if (isHidden === true) {\n emit('navigationShow');\n } else {\n emit('navigationHide');\n }\n\n if ($nextEl) {\n $nextEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n\n if ($prevEl) {\n $prevEl.toggleClass(swiper.params.navigation.hiddenClass);\n }\n }\n });\n Object.assign(swiper.navigation, {\n update,\n init,\n destroy\n });\n}","import { getDocument } from 'ssr-window';\nexport default function createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n const document = getDocument();\n\n if (swiper.params.createElements) {\n Object.keys(checkProps).forEach(key => {\n if (!params[key] && params.auto === true) {\n let element = swiper.$el.children(`.${checkProps[key]}`)[0];\n\n if (!element) {\n element = document.createElement('div');\n element.className = checkProps[key];\n swiper.$el.append(element);\n }\n\n params[key] = element;\n originalParams[key] = element;\n }\n });\n }\n\n return params;\n}","import $ from '../../shared/dom.js';\nimport classesToSelector from '../../shared/classes-to-selector.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Pagination({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const pfx = 'swiper-pagination';\n extendParams({\n pagination: {\n el: null,\n bulletElement: 'span',\n clickable: false,\n hideOnClick: false,\n renderBullet: null,\n renderProgressbar: null,\n renderFraction: null,\n renderCustom: null,\n progressbarOpposite: false,\n type: 'bullets',\n // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n dynamicBullets: false,\n dynamicMainBullets: 1,\n formatFractionCurrent: number => number,\n formatFractionTotal: number => number,\n bulletClass: `${pfx}-bullet`,\n bulletActiveClass: `${pfx}-bullet-active`,\n modifierClass: `${pfx}-`,\n currentClass: `${pfx}-current`,\n totalClass: `${pfx}-total`,\n hiddenClass: `${pfx}-hidden`,\n progressbarFillClass: `${pfx}-progressbar-fill`,\n progressbarOppositeClass: `${pfx}-progressbar-opposite`,\n clickableClass: `${pfx}-clickable`,\n lockClass: `${pfx}-lock`,\n horizontalClass: `${pfx}-horizontal`,\n verticalClass: `${pfx}-vertical`\n }\n });\n swiper.pagination = {\n el: null,\n $el: null,\n bullets: []\n };\n let bulletSize;\n let dynamicBulletIndex = 0;\n\n function isPaginationDisabled() {\n return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;\n }\n\n function setSideBullets($bulletEl, position) {\n const {\n bulletActiveClass\n } = swiper.params.pagination;\n $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);\n }\n\n function update() {\n // Render || Update Pagination bullets/items\n const rtl = swiper.rtl;\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el; // Current/Total\n\n let current;\n const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n\n if (current > slidesLength - 1 - swiper.loopedSlides * 2) {\n current -= slidesLength - swiper.loopedSlides * 2;\n }\n\n if (current > total - 1) current -= total;\n if (current < 0 && swiper.params.paginationType !== 'bullets') current = total + current;\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n } else {\n current = swiper.activeIndex || 0;\n } // Types\n\n\n if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n const bullets = swiper.pagination.bullets;\n let firstIndex;\n let lastIndex;\n let midIndex;\n\n if (params.dynamicBullets) {\n bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n $el.css(swiper.isHorizontal() ? 'width' : 'height', `${bulletSize * (params.dynamicMainBullets + 4)}px`);\n\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);\n\n if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (dynamicBulletIndex < 0) {\n dynamicBulletIndex = 0;\n }\n }\n\n firstIndex = Math.max(current - dynamicBulletIndex, 0);\n lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n midIndex = (lastIndex + firstIndex) / 2;\n }\n\n bullets.removeClass(['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`).join(' '));\n\n if ($el.length > 1) {\n bullets.each(bullet => {\n const $bullet = $(bullet);\n const bulletIndex = $bullet.index();\n\n if (bulletIndex === current) {\n $bullet.addClass(params.bulletActiveClass);\n }\n\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n $bullet.addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (bulletIndex === firstIndex) {\n setSideBullets($bullet, 'prev');\n }\n\n if (bulletIndex === lastIndex) {\n setSideBullets($bullet, 'next');\n }\n }\n });\n } else {\n const $bullet = bullets.eq(current);\n const bulletIndex = $bullet.index();\n $bullet.addClass(params.bulletActiveClass);\n\n if (params.dynamicBullets) {\n const $firstDisplayedBullet = bullets.eq(firstIndex);\n const $lastDisplayedBullet = bullets.eq(lastIndex);\n\n for (let i = firstIndex; i <= lastIndex; i += 1) {\n bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (swiper.params.loop) {\n if (bulletIndex >= bullets.length) {\n for (let i = params.dynamicMainBullets; i >= 0; i -= 1) {\n bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n }\n }\n\n if (params.dynamicBullets) {\n const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n const offsetProp = rtl ? 'right' : 'left';\n bullets.css(swiper.isHorizontal() ? offsetProp : 'top', `${bulletsOffset}px`);\n }\n }\n\n if (params.type === 'fraction') {\n $el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n $el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));\n }\n\n if (params.type === 'progressbar') {\n let progressbarDirection;\n\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n\n const scale = (current + 1) / total;\n let scaleX = 1;\n let scaleY = 1;\n\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n\n $el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);\n }\n\n if (params.type === 'custom' && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n emit('paginationRender', $el[0]);\n } else {\n emit('paginationUpdate', $el[0]);\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n }\n\n function render() {\n // Render Container\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el;\n let paginationHTML = '';\n\n if (params.type === 'bullets') {\n let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) {\n numberOfBullets = slidesLength;\n }\n\n for (let i = 0; i < numberOfBullets; i += 1) {\n if (params.renderBullet) {\n paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n } else {\n paginationHTML += `<${params.bulletElement} class=\"${params.bulletClass}\">`;\n }\n }\n\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find(classesToSelector(params.bulletClass));\n }\n\n if (params.type === 'fraction') {\n if (params.renderFraction) {\n paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n } else {\n paginationHTML = `` + ' / ' + ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type !== 'custom') {\n emit('paginationRender', swiper.pagination.$el[0]);\n }\n }\n\n function init() {\n swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {\n el: 'swiper-pagination'\n });\n const params = swiper.params.pagination;\n if (!params.el) return;\n let $el = $(params.el);\n if ($el.length === 0) return;\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1) {\n $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper\n\n if ($el.length > 1) {\n $el = $el.filter(el => {\n if ($(el).parents('.swiper')[0] !== swiper.el) return false;\n return true;\n });\n }\n }\n\n if (params.type === 'bullets' && params.clickable) {\n $el.addClass(params.clickableClass);\n }\n\n $el.addClass(params.modifierClass + params.type);\n $el.addClass(params.modifierClass + swiper.params.direction);\n\n if (params.type === 'bullets' && params.dynamicBullets) {\n $el.addClass(`${params.modifierClass}${params.type}-dynamic`);\n dynamicBulletIndex = 0;\n\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n $el.addClass(params.progressbarOppositeClass);\n }\n\n if (params.clickable) {\n $el.on('click', classesToSelector(params.bulletClass), function onClick(e) {\n e.preventDefault();\n let index = $(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) index += swiper.loopedSlides;\n swiper.slideTo(index);\n });\n }\n\n Object.assign(swiper.pagination, {\n $el,\n el: $el[0]\n });\n\n if (!swiper.enabled) {\n $el.addClass(params.lockClass);\n }\n }\n\n function destroy() {\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const $el = swiper.pagination.$el;\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n $el.removeClass(params.modifierClass + swiper.params.direction);\n if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);\n\n if (params.clickable) {\n $el.off('click', classesToSelector(params.bulletClass));\n }\n }\n\n on('init', () => {\n init();\n render();\n update();\n });\n on('activeIndexChange', () => {\n if (swiper.params.loop) {\n update();\n } else if (typeof swiper.snapIndex === 'undefined') {\n update();\n }\n });\n on('snapIndexChange', () => {\n if (!swiper.params.loop) {\n update();\n }\n });\n on('slidesLengthChange', () => {\n if (swiper.params.loop) {\n render();\n update();\n }\n });\n on('snapGridLengthChange', () => {\n if (!swiper.params.loop) {\n render();\n update();\n }\n });\n on('destroy', () => {\n destroy();\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.pagination;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.pagination.lockClass);\n }\n });\n on('lock unlock', () => {\n update();\n });\n on('click', (_s, e) => {\n const targetEl = e.target;\n const {\n $el\n } = swiper.pagination;\n\n if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el.length > 0 && !$(targetEl).hasClass(swiper.params.pagination.bulletClass)) {\n if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);\n\n if (isHidden === true) {\n emit('paginationShow');\n } else {\n emit('paginationHide');\n }\n\n $el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n });\n Object.assign(swiper.pagination, {\n render,\n update,\n init,\n destroy\n });\n}","export default function classesToSelector(classes = '') {\n return `.${classes.trim().replace(/([\\.:!\\/])/g, '\\\\$1') // eslint-disable-line\n .replace(/ /g, '.')}`;\n}","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Scrollbar({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n let isTouched = false;\n let timeout = null;\n let dragTimeout = null;\n let dragStartPos;\n let dragSize;\n let trackSize;\n let divider;\n extendParams({\n scrollbar: {\n el: null,\n dragSize: 'auto',\n hide: false,\n draggable: false,\n snapOnRelease: true,\n lockClass: 'swiper-scrollbar-lock',\n dragClass: 'swiper-scrollbar-drag'\n }\n });\n swiper.scrollbar = {\n el: null,\n dragEl: null,\n $el: null,\n $dragEl: null\n };\n\n function setTranslate() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar,\n rtlTranslate: rtl,\n progress\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n const params = swiper.params.scrollbar;\n let newSize = dragSize;\n let newPos = (trackSize - dragSize) * progress;\n\n if (rtl) {\n newPos = -newPos;\n\n if (newPos > 0) {\n newSize = dragSize - newPos;\n newPos = 0;\n } else if (-newPos + dragSize > trackSize) {\n newSize = trackSize + newPos;\n }\n } else if (newPos < 0) {\n newSize = dragSize + newPos;\n newPos = 0;\n } else if (newPos + dragSize > trackSize) {\n newSize = trackSize - newPos;\n }\n\n if (swiper.isHorizontal()) {\n $dragEl.transform(`translate3d(${newPos}px, 0, 0)`);\n $dragEl[0].style.width = `${newSize}px`;\n } else {\n $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);\n $dragEl[0].style.height = `${newSize}px`;\n }\n\n if (params.hide) {\n clearTimeout(timeout);\n $el[0].style.opacity = 1;\n timeout = setTimeout(() => {\n $el[0].style.opacity = 0;\n $el.transition(400);\n }, 1000);\n }\n }\n\n function setTransition(duration) {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n swiper.scrollbar.$dragEl.transition(duration);\n }\n\n function updateSize() {\n if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n const {\n scrollbar\n } = swiper;\n const {\n $dragEl,\n $el\n } = scrollbar;\n $dragEl[0].style.width = '';\n $dragEl[0].style.height = '';\n trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;\n divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n\n if (swiper.params.scrollbar.dragSize === 'auto') {\n dragSize = trackSize * divider;\n } else {\n dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n }\n\n if (swiper.isHorizontal()) {\n $dragEl[0].style.width = `${dragSize}px`;\n } else {\n $dragEl[0].style.height = `${dragSize}px`;\n }\n\n if (divider >= 1) {\n $el[0].style.display = 'none';\n } else {\n $el[0].style.display = '';\n }\n\n if (swiper.params.scrollbar.hide) {\n $el[0].style.opacity = 0;\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n scrollbar.$el[swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function getPointerPosition(e) {\n if (swiper.isHorizontal()) {\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientX : e.clientX;\n }\n\n return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientY : e.clientY;\n }\n\n function setDragPosition(e) {\n const {\n scrollbar,\n rtlTranslate: rtl\n } = swiper;\n const {\n $el\n } = scrollbar;\n let positionRatio;\n positionRatio = (getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n\n if (rtl) {\n positionRatio = 1 - positionRatio;\n }\n\n const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;\n swiper.updateProgress(position);\n swiper.setTranslate(position);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n function onDragStart(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n isTouched = true;\n dragStartPos = e.target === $dragEl[0] || e.target === $dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n e.preventDefault();\n e.stopPropagation();\n $wrapperEl.transition(100);\n $dragEl.transition(100);\n setDragPosition(e);\n clearTimeout(dragTimeout);\n $el.transition(0);\n\n if (params.hide) {\n $el.css('opacity', 1);\n }\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', 'none');\n }\n\n emit('scrollbarDragStart', e);\n }\n\n function onDragMove(e) {\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el,\n $dragEl\n } = scrollbar;\n if (!isTouched) return;\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n setDragPosition(e);\n $wrapperEl.transition(0);\n $el.transition(0);\n $dragEl.transition(0);\n emit('scrollbarDragMove', e);\n }\n\n function onDragEnd(e) {\n const params = swiper.params.scrollbar;\n const {\n scrollbar,\n $wrapperEl\n } = swiper;\n const {\n $el\n } = scrollbar;\n if (!isTouched) return;\n isTouched = false;\n\n if (swiper.params.cssMode) {\n swiper.$wrapperEl.css('scroll-snap-type', '');\n $wrapperEl.transition('');\n }\n\n if (params.hide) {\n clearTimeout(dragTimeout);\n dragTimeout = nextTick(() => {\n $el.css('opacity', 0);\n $el.transition(400);\n }, 1000);\n }\n\n emit('scrollbarDragEnd', e);\n\n if (params.snapOnRelease) {\n swiper.slideToClosest();\n }\n }\n\n function events(method) {\n const {\n scrollbar,\n touchEventsTouch,\n touchEventsDesktop,\n params,\n support\n } = swiper;\n const $el = scrollbar.$el;\n const target = $el[0];\n const activeListener = support.passiveListener && params.passiveListeners ? {\n passive: false,\n capture: false\n } : false;\n const passiveListener = support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n if (!target) return;\n const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n\n if (!support.touch) {\n target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);\n document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);\n document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);\n } else {\n target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);\n target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);\n target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);\n }\n }\n\n function enableDraggable() {\n if (!swiper.params.scrollbar.el) return;\n events('on');\n }\n\n function disableDraggable() {\n if (!swiper.params.scrollbar.el) return;\n events('off');\n }\n\n function init() {\n const {\n scrollbar,\n $el: $swiperEl\n } = swiper;\n swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {\n el: 'swiper-scrollbar'\n });\n const params = swiper.params.scrollbar;\n if (!params.el) return;\n let $el = $(params.el);\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {\n $el = $swiperEl.find(params.el);\n }\n\n let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`);\n\n if ($dragEl.length === 0) {\n $dragEl = $(`
`);\n $el.append($dragEl);\n }\n\n Object.assign(scrollbar, {\n $el,\n el: $el[0],\n $dragEl,\n dragEl: $dragEl[0]\n });\n\n if (params.draggable) {\n enableDraggable();\n }\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n }\n\n function destroy() {\n disableDraggable();\n }\n\n on('init', () => {\n init();\n updateSize();\n setTranslate();\n });\n on('update resize observerUpdate lock unlock', () => {\n updateSize();\n });\n on('setTranslate', () => {\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n setTransition(duration);\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.scrollbar;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);\n }\n });\n on('destroy', () => {\n destroy();\n });\n Object.assign(swiper.scrollbar, {\n updateSize,\n setTranslate,\n init,\n destroy\n });\n}","import $ from '../../shared/dom.js';\nexport default function Parallax({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n parallax: {\n enabled: false\n }\n });\n\n const setTransform = (el, progress) => {\n const {\n rtl\n } = swiper;\n const $el = $(el);\n const rtlFactor = rtl ? -1 : 1;\n const p = $el.attr('data-swiper-parallax') || '0';\n let x = $el.attr('data-swiper-parallax-x');\n let y = $el.attr('data-swiper-parallax-y');\n const scale = $el.attr('data-swiper-parallax-scale');\n const opacity = $el.attr('data-swiper-parallax-opacity');\n\n if (x || y) {\n x = x || '0';\n y = y || '0';\n } else if (swiper.isHorizontal()) {\n x = p;\n y = '0';\n } else {\n y = p;\n x = '0';\n }\n\n if (x.indexOf('%') >= 0) {\n x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n } else {\n x = `${x * progress * rtlFactor}px`;\n }\n\n if (y.indexOf('%') >= 0) {\n y = `${parseInt(y, 10) * progress}%`;\n } else {\n y = `${y * progress}px`;\n }\n\n if (typeof opacity !== 'undefined' && opacity !== null) {\n const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n $el[0].style.opacity = currentOpacity;\n }\n\n if (typeof scale === 'undefined' || scale === null) {\n $el.transform(`translate3d(${x}, ${y}, 0px)`);\n } else {\n const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);\n }\n };\n\n const setTranslate = () => {\n const {\n $el,\n slides,\n progress,\n snapGrid\n } = swiper;\n $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, progress);\n });\n slides.each((slideEl, slideIndex) => {\n let slideProgress = slideEl.progress;\n\n if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n }\n\n slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {\n setTransform(el, slideProgress);\n });\n });\n };\n\n const setTransition = (duration = swiper.params.speed) => {\n const {\n $el\n } = swiper;\n $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(parallaxEl => {\n const $parallaxEl = $(parallaxEl);\n let parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;\n if (duration === 0) parallaxDuration = 0;\n $parallaxEl.transition(parallaxDuration);\n });\n };\n\n on('beforeInit', () => {\n if (!swiper.params.parallax.enabled) return;\n swiper.params.watchSlidesProgress = true;\n swiper.originalParams.watchSlidesProgress = true;\n });\n on('init', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTranslate', () => {\n if (!swiper.params.parallax.enabled) return;\n setTranslate();\n });\n on('setTransition', (_swiper, duration) => {\n if (!swiper.params.parallax.enabled) return;\n setTransition(duration);\n });\n}","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { getTranslate } from '../../shared/utils.js';\nexport default function Zoom({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const window = getWindow();\n extendParams({\n zoom: {\n enabled: false,\n maxRatio: 3,\n minRatio: 1,\n toggle: true,\n containerClass: 'swiper-zoom-container',\n zoomedSlideClass: 'swiper-slide-zoomed'\n }\n });\n swiper.zoom = {\n enabled: false\n };\n let currentScale = 1;\n let isScaling = false;\n let gesturesEnabled;\n let fakeGestureTouched;\n let fakeGestureMoved;\n const gesture = {\n $slideEl: undefined,\n slideWidth: undefined,\n slideHeight: undefined,\n $imageEl: undefined,\n $imageWrapEl: undefined,\n maxRatio: 3\n };\n const image = {\n isTouched: undefined,\n isMoved: undefined,\n currentX: undefined,\n currentY: undefined,\n minX: undefined,\n minY: undefined,\n maxX: undefined,\n maxY: undefined,\n width: undefined,\n height: undefined,\n startX: undefined,\n startY: undefined,\n touchesStart: {},\n touchesCurrent: {}\n };\n const velocity = {\n x: undefined,\n y: undefined,\n prevPositionX: undefined,\n prevPositionY: undefined,\n prevTime: undefined\n };\n let scale = 1;\n Object.defineProperty(swiper.zoom, 'scale', {\n get() {\n return scale;\n },\n\n set(value) {\n if (scale !== value) {\n const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined;\n const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined;\n emit('zoomChange', value, imageEl, slideEl);\n }\n\n scale = value;\n }\n\n });\n\n function getDistanceBetweenTouches(e) {\n if (e.targetTouches.length < 2) return 1;\n const x1 = e.targetTouches[0].pageX;\n const y1 = e.targetTouches[0].pageY;\n const x2 = e.targetTouches[1].pageX;\n const y2 = e.targetTouches[1].pageY;\n const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n return distance;\n } // Events\n\n\n function onGestureStart(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n\n if (!support.gestures) {\n if (e.type !== 'touchstart' || e.type === 'touchstart' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureTouched = true;\n gesture.scaleStart = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$slideEl || !gesture.$slideEl.length) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n if (gesture.$slideEl.length === 0) gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (gesture.$imageWrapEl.length === 0) {\n gesture.$imageEl = undefined;\n return;\n }\n }\n\n if (gesture.$imageEl) {\n gesture.$imageEl.transition(0);\n }\n\n isScaling = true;\n }\n\n function onGestureChange(e) {\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (e.type !== 'touchmove' || e.type === 'touchmove' && e.targetTouches.length < 2) {\n return;\n }\n\n fakeGestureMoved = true;\n gesture.scaleMove = getDistanceBetweenTouches(e);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) {\n if (e.type === 'gesturechange') onGestureStart(e);\n return;\n }\n\n if (support.gestures) {\n zoom.scale = e.scale * currentScale;\n } else {\n zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n }\n\n if (zoom.scale > gesture.maxRatio) {\n zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n }\n\n if (zoom.scale < params.minRatio) {\n zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n }\n\n gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function onGestureEnd(e) {\n const device = swiper.device;\n const support = swiper.support;\n const params = swiper.params.zoom;\n const zoom = swiper.zoom;\n\n if (!support.gestures) {\n if (!fakeGestureTouched || !fakeGestureMoved) {\n return;\n }\n\n if (e.type !== 'touchend' || e.type === 'touchend' && e.changedTouches.length < 2 && !device.android) {\n return;\n }\n\n fakeGestureTouched = false;\n fakeGestureMoved = false;\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n currentScale = zoom.scale;\n isScaling = false;\n if (zoom.scale === 1) gesture.$slideEl = undefined;\n }\n\n function onTouchStart(e) {\n const device = swiper.device;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n if (image.isTouched) return;\n if (device.android && e.cancelable) e.preventDefault();\n image.isTouched = true;\n image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n }\n\n function onTouchMove(e) {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n swiper.allowClick = false;\n if (!image.isTouched || !gesture.$slideEl) return;\n\n if (!image.isMoved) {\n image.width = gesture.$imageEl[0].offsetWidth;\n image.height = gesture.$imageEl[0].offsetHeight;\n image.startX = getTranslate(gesture.$imageWrapEl[0], 'x') || 0;\n image.startY = getTranslate(gesture.$imageWrapEl[0], 'y') || 0;\n gesture.slideWidth = gesture.$slideEl[0].offsetWidth;\n gesture.slideHeight = gesture.$slideEl[0].offsetHeight;\n gesture.$imageWrapEl.transition(0);\n } // Define if we need image drag\n\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;\n image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;\n\n if (!image.isMoved && !isScaling) {\n if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {\n image.isTouched = false;\n return;\n }\n\n if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {\n image.isTouched = false;\n return;\n }\n }\n\n if (e.cancelable) {\n e.preventDefault();\n }\n\n e.stopPropagation();\n image.isMoved = true;\n image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX;\n image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY;\n\n if (image.currentX < image.minX) {\n image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n }\n\n if (image.currentX > image.maxX) {\n image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n }\n\n if (image.currentY < image.minY) {\n image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n }\n\n if (image.currentY > image.maxY) {\n image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\n } // Velocity\n\n\n if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;\n if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;\n if (!velocity.prevTime) velocity.prevTime = Date.now();\n velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;\n if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;\n velocity.prevPositionX = image.touchesCurrent.x;\n velocity.prevPositionY = image.touchesCurrent.y;\n velocity.prevTime = Date.now();\n gesture.$imageWrapEl.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTouchEnd() {\n const zoom = swiper.zoom;\n if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;\n\n if (!image.isTouched || !image.isMoved) {\n image.isTouched = false;\n image.isMoved = false;\n return;\n }\n\n image.isTouched = false;\n image.isMoved = false;\n let momentumDurationX = 300;\n let momentumDurationY = 300;\n const momentumDistanceX = velocity.x * momentumDurationX;\n const newPositionX = image.currentX + momentumDistanceX;\n const momentumDistanceY = velocity.y * momentumDurationY;\n const newPositionY = image.currentY + momentumDistanceY; // Fix duration\n\n if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);\n if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);\n const momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n image.currentX = newPositionX;\n image.currentY = newPositionY; // Define if we need image drag\n\n const scaledWidth = image.width * zoom.scale;\n const scaledHeight = image.height * zoom.scale;\n image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n image.maxX = -image.minX;\n image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n image.maxY = -image.minY;\n image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n gesture.$imageWrapEl.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);\n }\n\n function onTransitionEnd() {\n const zoom = swiper.zoom;\n\n if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {\n if (gesture.$imageEl) {\n gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');\n }\n\n if (gesture.$imageWrapEl) {\n gesture.$imageWrapEl.transform('translate3d(0,0,0)');\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$slideEl = undefined;\n gesture.$imageEl = undefined;\n gesture.$imageWrapEl = undefined;\n }\n }\n\n function zoomIn(e) {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (e && e.target) {\n gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);\n }\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.touchAction = 'none';\n }\n\n gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);\n let touchX;\n let touchY;\n let offsetX;\n let offsetY;\n let diffX;\n let diffY;\n let translateX;\n let translateY;\n let imageWidth;\n let imageHeight;\n let scaledWidth;\n let scaledHeight;\n let translateMinX;\n let translateMinY;\n let translateMaxX;\n let translateMaxY;\n let slideWidth;\n let slideHeight;\n\n if (typeof image.touchesStart.x === 'undefined' && e) {\n touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;\n touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;\n } else {\n touchX = image.touchesStart.x;\n touchY = image.touchesStart.y;\n }\n\n zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;\n\n if (e) {\n slideWidth = gesture.$slideEl[0].offsetWidth;\n slideHeight = gesture.$slideEl[0].offsetHeight;\n offsetX = gesture.$slideEl.offset().left + window.scrollX;\n offsetY = gesture.$slideEl.offset().top + window.scrollY;\n diffX = offsetX + slideWidth / 2 - touchX;\n diffY = offsetY + slideHeight / 2 - touchY;\n imageWidth = gesture.$imageEl[0].offsetWidth;\n imageHeight = gesture.$imageEl[0].offsetHeight;\n scaledWidth = imageWidth * zoom.scale;\n scaledHeight = imageHeight * zoom.scale;\n translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n translateMaxX = -translateMinX;\n translateMaxY = -translateMinY;\n translateX = diffX * zoom.scale;\n translateY = diffY * zoom.scale;\n\n if (translateX < translateMinX) {\n translateX = translateMinX;\n }\n\n if (translateX > translateMaxX) {\n translateX = translateMaxX;\n }\n\n if (translateY < translateMinY) {\n translateY = translateMinY;\n }\n\n if (translateY > translateMaxY) {\n translateY = translateMaxY;\n }\n } else {\n translateX = 0;\n translateY = 0;\n }\n\n gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);\n gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);\n }\n\n function zoomOut() {\n const zoom = swiper.zoom;\n const params = swiper.params.zoom;\n\n if (!gesture.$slideEl) {\n if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);\n } else {\n gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);\n }\n\n gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);\n gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);\n }\n\n if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;\n\n if (swiper.params.cssMode) {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.style.touchAction = '';\n }\n\n zoom.scale = 1;\n currentScale = 1;\n gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');\n gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');\n gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);\n gesture.$slideEl = undefined;\n } // Toggle Zoom\n\n\n function zoomToggle(e) {\n const zoom = swiper.zoom;\n\n if (zoom.scale && zoom.scale !== 1) {\n // Zoom Out\n zoomOut();\n } else {\n // Zoom In\n zoomIn(e);\n }\n }\n\n function getListeners() {\n const support = swiper.support;\n const passiveListener = swiper.touchEvents.start === 'touchstart' && support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n const activeListenerWithCapture = support.passiveListener ? {\n passive: false,\n capture: true\n } : true;\n return {\n passiveListener,\n activeListenerWithCapture\n };\n }\n\n function getSlideSelector() {\n return `.${swiper.params.slideClass}`;\n }\n\n function toggleGestures(method) {\n const {\n passiveListener\n } = getListeners();\n const slideSelector = getSlideSelector();\n swiper.$wrapperEl[method]('gesturestart', slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl[method]('gesturechange', slideSelector, onGestureChange, passiveListener);\n swiper.$wrapperEl[method]('gestureend', slideSelector, onGestureEnd, passiveListener);\n }\n\n function enableGestures() {\n if (gesturesEnabled) return;\n gesturesEnabled = true;\n toggleGestures('on');\n }\n\n function disableGestures() {\n if (!gesturesEnabled) return;\n gesturesEnabled = false;\n toggleGestures('off');\n } // Attach/Detach Events\n\n\n function enable() {\n const zoom = swiper.zoom;\n if (zoom.enabled) return;\n zoom.enabled = true;\n const support = swiper.support;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n function disable() {\n const zoom = swiper.zoom;\n if (!zoom.enabled) return;\n const support = swiper.support;\n zoom.enabled = false;\n const {\n passiveListener,\n activeListenerWithCapture\n } = getListeners();\n const slideSelector = getSlideSelector(); // Scale image\n\n if (support.gestures) {\n swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);\n } else if (swiper.touchEvents.start === 'touchstart') {\n swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);\n swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);\n swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);\n\n if (swiper.touchEvents.cancel) {\n swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);\n }\n } // Move image\n\n\n swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);\n }\n\n on('init', () => {\n if (swiper.params.zoom.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n disable();\n });\n on('touchStart', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchStart(e);\n });\n on('touchEnd', (_s, e) => {\n if (!swiper.zoom.enabled) return;\n onTouchEnd(e);\n });\n on('doubleTap', (_s, e) => {\n if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n zoomToggle(e);\n }\n });\n on('transitionEnd', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n onTransitionEnd();\n }\n });\n on('slideChange', () => {\n if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {\n onTransitionEnd();\n }\n });\n Object.assign(swiper.zoom, {\n enable,\n disable,\n in: zoomIn,\n out: zoomOut,\n toggle: zoomToggle\n });\n}","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Lazy({\n swiper,\n extendParams,\n on,\n emit\n}) {\n extendParams({\n lazy: {\n checkInView: false,\n enabled: false,\n loadPrevNext: false,\n loadPrevNextAmount: 1,\n loadOnTransitionStart: false,\n scrollingElement: '',\n elementClass: 'swiper-lazy',\n loadingClass: 'swiper-lazy-loading',\n loadedClass: 'swiper-lazy-loaded',\n preloaderClass: 'swiper-lazy-preloader'\n }\n });\n swiper.lazy = {};\n let scrollHandlerAttached = false;\n let initialImageLoaded = false;\n\n function loadInSlide(index, loadInDuplicate = true) {\n const params = swiper.params.lazy;\n if (typeof index === 'undefined') return;\n if (swiper.slides.length === 0) return;\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n const $slideEl = isVirtual ? swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${index}\"]`) : swiper.slides.eq(index);\n const $images = $slideEl.find(`.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`);\n\n if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) {\n $images.push($slideEl[0]);\n }\n\n if ($images.length === 0) return;\n $images.each(imageEl => {\n const $imageEl = $(imageEl);\n $imageEl.addClass(params.loadingClass);\n const background = $imageEl.attr('data-background');\n const src = $imageEl.attr('data-src');\n const srcset = $imageEl.attr('data-srcset');\n const sizes = $imageEl.attr('data-sizes');\n const $pictureEl = $imageEl.parent('picture');\n swiper.loadImage($imageEl[0], src || background, srcset, sizes, false, () => {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper && !swiper.params || swiper.destroyed) return;\n\n if (background) {\n $imageEl.css('background-image', `url(\"${background}\")`);\n $imageEl.removeAttr('data-background');\n } else {\n if (srcset) {\n $imageEl.attr('srcset', srcset);\n $imageEl.removeAttr('data-srcset');\n }\n\n if (sizes) {\n $imageEl.attr('sizes', sizes);\n $imageEl.removeAttr('data-sizes');\n }\n\n if ($pictureEl.length) {\n $pictureEl.children('source').each(sourceEl => {\n const $source = $(sourceEl);\n\n if ($source.attr('data-srcset')) {\n $source.attr('srcset', $source.attr('data-srcset'));\n $source.removeAttr('data-srcset');\n }\n });\n }\n\n if (src) {\n $imageEl.attr('src', src);\n $imageEl.removeAttr('data-src');\n }\n }\n\n $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);\n $slideEl.find(`.${params.preloaderClass}`).remove();\n\n if (swiper.params.loop && loadInDuplicate) {\n const slideOriginalIndex = $slideEl.attr('data-swiper-slide-index');\n\n if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {\n const originalSlide = swiper.$wrapperEl.children(`[data-swiper-slide-index=\"${slideOriginalIndex}\"]:not(.${swiper.params.slideDuplicateClass})`);\n loadInSlide(originalSlide.index(), false);\n } else {\n const duplicatedSlide = swiper.$wrapperEl.children(`.${swiper.params.slideDuplicateClass}[data-swiper-slide-index=\"${slideOriginalIndex}\"]`);\n loadInSlide(duplicatedSlide.index(), false);\n }\n }\n\n emit('lazyImageReady', $slideEl[0], $imageEl[0]);\n\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n });\n emit('lazyImageLoad', $slideEl[0], $imageEl[0]);\n });\n }\n\n function load() {\n const {\n $wrapperEl,\n params: swiperParams,\n slides,\n activeIndex\n } = swiper;\n const isVirtual = swiper.virtual && swiperParams.virtual.enabled;\n const params = swiperParams.lazy;\n let slidesPerView = swiperParams.slidesPerView;\n\n if (slidesPerView === 'auto') {\n slidesPerView = 0;\n }\n\n function slideExist(index) {\n if (isVirtual) {\n if ($wrapperEl.children(`.${swiperParams.slideClass}[data-swiper-slide-index=\"${index}\"]`).length) {\n return true;\n }\n } else if (slides[index]) return true;\n\n return false;\n }\n\n function slideIndex(slideEl) {\n if (isVirtual) {\n return $(slideEl).attr('data-swiper-slide-index');\n }\n\n return $(slideEl).index();\n }\n\n if (!initialImageLoaded) initialImageLoaded = true;\n\n if (swiper.params.watchSlidesProgress) {\n $wrapperEl.children(`.${swiperParams.slideVisibleClass}`).each(slideEl => {\n const index = isVirtual ? $(slideEl).attr('data-swiper-slide-index') : $(slideEl).index();\n loadInSlide(index);\n });\n } else if (slidesPerView > 1) {\n for (let i = activeIndex; i < activeIndex + slidesPerView; i += 1) {\n if (slideExist(i)) loadInSlide(i);\n }\n } else {\n loadInSlide(activeIndex);\n }\n\n if (params.loadPrevNext) {\n if (slidesPerView > 1 || params.loadPrevNextAmount && params.loadPrevNextAmount > 1) {\n const amount = params.loadPrevNextAmount;\n const spv = slidesPerView;\n const maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);\n const minIndex = Math.max(activeIndex - Math.max(spv, amount), 0); // Next Slides\n\n for (let i = activeIndex + slidesPerView; i < maxIndex; i += 1) {\n if (slideExist(i)) loadInSlide(i);\n } // Prev Slides\n\n\n for (let i = minIndex; i < activeIndex; i += 1) {\n if (slideExist(i)) loadInSlide(i);\n }\n } else {\n const nextSlide = $wrapperEl.children(`.${swiperParams.slideNextClass}`);\n if (nextSlide.length > 0) loadInSlide(slideIndex(nextSlide));\n const prevSlide = $wrapperEl.children(`.${swiperParams.slidePrevClass}`);\n if (prevSlide.length > 0) loadInSlide(slideIndex(prevSlide));\n }\n }\n }\n\n function checkInViewOnLoad() {\n const window = getWindow();\n if (!swiper || swiper.destroyed) return;\n const $scrollElement = swiper.params.lazy.scrollingElement ? $(swiper.params.lazy.scrollingElement) : $(window);\n const isWindow = $scrollElement[0] === window;\n const scrollElementWidth = isWindow ? window.innerWidth : $scrollElement[0].offsetWidth;\n const scrollElementHeight = isWindow ? window.innerHeight : $scrollElement[0].offsetHeight;\n const swiperOffset = swiper.$el.offset();\n const {\n rtlTranslate: rtl\n } = swiper;\n let inView = false;\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiper.width, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiper.height], [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= scrollElementWidth && point[1] >= 0 && point[1] <= scrollElementHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n const passiveListener = swiper.touchEvents.start === 'touchstart' && swiper.support.passiveListener && swiper.params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n\n if (inView) {\n load();\n $scrollElement.off('scroll', checkInViewOnLoad, passiveListener);\n } else if (!scrollHandlerAttached) {\n scrollHandlerAttached = true;\n $scrollElement.on('scroll', checkInViewOnLoad, passiveListener);\n }\n }\n\n on('beforeInit', () => {\n if (swiper.params.lazy.enabled && swiper.params.preloadImages) {\n swiper.params.preloadImages = false;\n }\n });\n on('init', () => {\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.checkInView) {\n checkInViewOnLoad();\n } else {\n load();\n }\n }\n });\n on('scroll', () => {\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.freeMode.sticky) {\n load();\n }\n });\n on('scrollbarDragMove resize _freeModeNoMomentumRelease', () => {\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.checkInView) {\n checkInViewOnLoad();\n } else {\n load();\n }\n }\n });\n on('transitionStart', () => {\n if (swiper.params.lazy.enabled) {\n if (swiper.params.lazy.loadOnTransitionStart || !swiper.params.lazy.loadOnTransitionStart && !initialImageLoaded) {\n if (swiper.params.lazy.checkInView) {\n checkInViewOnLoad();\n } else {\n load();\n }\n }\n }\n });\n on('transitionEnd', () => {\n if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {\n if (swiper.params.lazy.checkInView) {\n checkInViewOnLoad();\n } else {\n load();\n }\n }\n });\n on('slideChange', () => {\n const {\n lazy,\n cssMode,\n watchSlidesProgress,\n touchReleaseOnEdges,\n resistanceRatio\n } = swiper.params;\n\n if (lazy.enabled && (cssMode || watchSlidesProgress && (touchReleaseOnEdges || resistanceRatio === 0))) {\n load();\n }\n });\n Object.assign(swiper.lazy, {\n load,\n loadInSlide\n });\n}","/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\nimport { nextTick } from '../../shared/utils.js';\nexport default function Controller({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n controller: {\n control: undefined,\n inverse: false,\n by: 'slide' // or 'container'\n\n }\n });\n swiper.controller = {\n control: undefined\n };\n\n function LinearSpline(x, y) {\n const binarySearch = function search() {\n let maxIndex;\n let minIndex;\n let guess;\n return (array, val) => {\n minIndex = -1;\n maxIndex = array.length;\n\n while (maxIndex - minIndex > 1) {\n guess = maxIndex + minIndex >> 1;\n\n if (array[guess] <= val) {\n minIndex = guess;\n } else {\n maxIndex = guess;\n }\n }\n\n return maxIndex;\n };\n }();\n\n this.x = x;\n this.y = y;\n this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value:\n // (x1,y1) is the known point before given value,\n // (x3,y3) is the known point after given value.\n\n let i1;\n let i3;\n\n this.interpolate = function interpolate(x2) {\n if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n\n i3 = binarySearch(this.x, x2);\n i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already:\n // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n\n return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];\n };\n\n return this;\n } // xxx: for now i will just save one spline function to to\n\n\n function getInterpolateFunction(c) {\n if (!swiper.controller.spline) {\n swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);\n }\n }\n\n function setTranslate(_t, byController) {\n const controlled = swiper.controller.control;\n let multiplier;\n let controlledTranslate;\n const Swiper = swiper.constructor;\n\n function setControlledTranslate(c) {\n // this will create an Interpolate function based on the snapGrids\n // x is the Grid of the scrolled scroller and y will be the controlled scroller\n // it makes sense to create this only once and recall it for the interpolation\n // the function does a lot of value caching for performance\n const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n\n if (swiper.params.controller.by === 'slide') {\n getInterpolateFunction(c); // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n // but it did not work out\n\n controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n }\n\n if (!controlledTranslate || swiper.params.controller.by === 'container') {\n multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n }\n\n if (swiper.params.controller.inverse) {\n controlledTranslate = c.maxTranslate() - controlledTranslate;\n }\n\n c.updateProgress(controlledTranslate);\n c.setTranslate(controlledTranslate, swiper);\n c.updateActiveIndex();\n c.updateSlidesClasses();\n }\n\n if (Array.isArray(controlled)) {\n for (let i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTranslate(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTranslate(controlled);\n }\n }\n\n function setTransition(duration, byController) {\n const Swiper = swiper.constructor;\n const controlled = swiper.controller.control;\n let i;\n\n function setControlledTransition(c) {\n c.setTransition(duration, swiper);\n\n if (duration !== 0) {\n c.transitionStart();\n\n if (c.params.autoHeight) {\n nextTick(() => {\n c.updateAutoHeight();\n });\n }\n\n c.$wrapperEl.transitionEnd(() => {\n if (!controlled) return;\n\n if (c.params.loop && swiper.params.controller.by === 'slide') {\n c.loopFix();\n }\n\n c.transitionEnd();\n });\n }\n }\n\n if (Array.isArray(controlled)) {\n for (i = 0; i < controlled.length; i += 1) {\n if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n setControlledTransition(controlled[i]);\n }\n }\n } else if (controlled instanceof Swiper && byController !== controlled) {\n setControlledTransition(controlled);\n }\n }\n\n function removeSpline() {\n if (!swiper.controller.control) return;\n\n if (swiper.controller.spline) {\n swiper.controller.spline = undefined;\n delete swiper.controller.spline;\n }\n }\n\n on('beforeInit', () => {\n swiper.controller.control = swiper.params.controller.control;\n });\n on('update', () => {\n removeSpline();\n });\n on('resize', () => {\n removeSpline();\n });\n on('observerUpdate', () => {\n removeSpline();\n });\n on('setTranslate', (_s, translate, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTranslate(translate, byController);\n });\n on('setTransition', (_s, duration, byController) => {\n if (!swiper.controller.control) return;\n swiper.controller.setTransition(duration, byController);\n });\n Object.assign(swiper.controller, {\n setTranslate,\n setTransition\n });\n}","import classesToSelector from '../../shared/classes-to-selector.js';\nimport $ from '../../shared/dom.js';\nexport default function A11y({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n a11y: {\n enabled: true,\n notificationClass: 'swiper-notification',\n prevSlideMessage: 'Previous slide',\n nextSlideMessage: 'Next slide',\n firstSlideMessage: 'This is the first slide',\n lastSlideMessage: 'This is the last slide',\n paginationBulletMessage: 'Go to slide {{index}}',\n slideLabelMessage: '{{index}} / {{slidesLength}}',\n containerMessage: null,\n containerRoleDescriptionMessage: null,\n itemRoleDescriptionMessage: null,\n slideRole: 'group'\n }\n });\n let liveRegion = null;\n\n function notify(message) {\n const notification = liveRegion;\n if (notification.length === 0) return;\n notification.html('');\n notification.html(message);\n }\n\n function getRandomNumber(size = 16) {\n const randomChar = () => Math.round(16 * Math.random()).toString(16);\n\n return 'x'.repeat(size).replace(/x/g, randomChar);\n }\n\n function makeElFocusable($el) {\n $el.attr('tabIndex', '0');\n }\n\n function makeElNotFocusable($el) {\n $el.attr('tabIndex', '-1');\n }\n\n function addElRole($el, role) {\n $el.attr('role', role);\n }\n\n function addElRoleDescription($el, description) {\n $el.attr('aria-roledescription', description);\n }\n\n function addElControls($el, controls) {\n $el.attr('aria-controls', controls);\n }\n\n function addElLabel($el, label) {\n $el.attr('aria-label', label);\n }\n\n function addElId($el, id) {\n $el.attr('id', id);\n }\n\n function addElLive($el, live) {\n $el.attr('aria-live', live);\n }\n\n function disableEl($el) {\n $el.attr('aria-disabled', true);\n }\n\n function enableEl($el) {\n $el.attr('aria-disabled', false);\n }\n\n function onEnterOrSpaceKey(e) {\n if (e.keyCode !== 13 && e.keyCode !== 32) return;\n const params = swiper.params.a11y;\n const $targetEl = $(e.target);\n\n if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {\n if (!(swiper.isEnd && !swiper.params.loop)) {\n swiper.slideNext();\n }\n\n if (swiper.isEnd) {\n notify(params.lastSlideMessage);\n } else {\n notify(params.nextSlideMessage);\n }\n }\n\n if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {\n if (!(swiper.isBeginning && !swiper.params.loop)) {\n swiper.slidePrev();\n }\n\n if (swiper.isBeginning) {\n notify(params.firstSlideMessage);\n } else {\n notify(params.prevSlideMessage);\n }\n }\n\n if (swiper.pagination && $targetEl.is(classesToSelector(swiper.params.pagination.bulletClass))) {\n $targetEl[0].click();\n }\n }\n\n function updateNavigation() {\n if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;\n const {\n $nextEl,\n $prevEl\n } = swiper.navigation;\n\n if ($prevEl && $prevEl.length > 0) {\n if (swiper.isBeginning) {\n disableEl($prevEl);\n makeElNotFocusable($prevEl);\n } else {\n enableEl($prevEl);\n makeElFocusable($prevEl);\n }\n }\n\n if ($nextEl && $nextEl.length > 0) {\n if (swiper.isEnd) {\n disableEl($nextEl);\n makeElNotFocusable($nextEl);\n } else {\n enableEl($nextEl);\n makeElFocusable($nextEl);\n }\n }\n }\n\n function hasPagination() {\n return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;\n }\n\n function hasClickablePagination() {\n return hasPagination() && swiper.params.pagination.clickable;\n }\n\n function updatePagination() {\n const params = swiper.params.a11y;\n if (!hasPagination()) return;\n swiper.pagination.bullets.each(bulletEl => {\n const $bulletEl = $(bulletEl);\n\n if (swiper.params.pagination.clickable) {\n makeElFocusable($bulletEl);\n\n if (!swiper.params.pagination.renderBullet) {\n addElRole($bulletEl, 'button');\n addElLabel($bulletEl, params.paginationBulletMessage.replace(/\\{\\{index\\}\\}/, $bulletEl.index() + 1));\n }\n }\n\n if ($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)) {\n $bulletEl.attr('aria-current', 'true');\n } else {\n $bulletEl.removeAttr('aria-current');\n }\n });\n }\n\n const initNavEl = ($el, wrapperId, message) => {\n makeElFocusable($el);\n\n if ($el[0].tagName !== 'BUTTON') {\n addElRole($el, 'button');\n $el.on('keydown', onEnterOrSpaceKey);\n }\n\n addElLabel($el, message);\n addElControls($el, wrapperId);\n };\n\n function init() {\n const params = swiper.params.a11y;\n swiper.$el.append(liveRegion); // Container\n\n const $containerEl = swiper.$el;\n\n if (params.containerRoleDescriptionMessage) {\n addElRoleDescription($containerEl, params.containerRoleDescriptionMessage);\n }\n\n if (params.containerMessage) {\n addElLabel($containerEl, params.containerMessage);\n } // Wrapper\n\n\n const $wrapperEl = swiper.$wrapperEl;\n const wrapperId = $wrapperEl.attr('id') || `swiper-wrapper-${getRandomNumber(16)}`;\n const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';\n addElId($wrapperEl, wrapperId);\n addElLive($wrapperEl, live); // Slide\n\n if (params.itemRoleDescriptionMessage) {\n addElRoleDescription($(swiper.slides), params.itemRoleDescriptionMessage);\n }\n\n addElRole($(swiper.slides), params.slideRole);\n const slidesLength = swiper.params.loop ? swiper.slides.filter(el => !el.classList.contains(swiper.params.slideDuplicateClass)).length : swiper.slides.length;\n swiper.slides.each((slideEl, index) => {\n const $slideEl = $(slideEl);\n const slideIndex = swiper.params.loop ? parseInt($slideEl.attr('data-swiper-slide-index'), 10) : index;\n const ariaLabelMessage = params.slideLabelMessage.replace(/\\{\\{index\\}\\}/, slideIndex + 1).replace(/\\{\\{slidesLength\\}\\}/, slidesLength);\n addElLabel($slideEl, ariaLabelMessage);\n }); // Navigation\n\n let $nextEl;\n let $prevEl;\n\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n\n if ($nextEl && $nextEl.length) {\n initNavEl($nextEl, wrapperId, params.nextSlideMessage);\n }\n\n if ($prevEl && $prevEl.length) {\n initNavEl($prevEl, wrapperId, params.prevSlideMessage);\n } // Pagination\n\n\n if (hasClickablePagination()) {\n swiper.pagination.$el.on('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n }\n }\n\n function destroy() {\n if (liveRegion && liveRegion.length > 0) liveRegion.remove();\n let $nextEl;\n let $prevEl;\n\n if (swiper.navigation && swiper.navigation.$nextEl) {\n $nextEl = swiper.navigation.$nextEl;\n }\n\n if (swiper.navigation && swiper.navigation.$prevEl) {\n $prevEl = swiper.navigation.$prevEl;\n }\n\n if ($nextEl) {\n $nextEl.off('keydown', onEnterOrSpaceKey);\n }\n\n if ($prevEl) {\n $prevEl.off('keydown', onEnterOrSpaceKey);\n } // Pagination\n\n\n if (hasClickablePagination()) {\n swiper.pagination.$el.off('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);\n }\n }\n\n on('beforeInit', () => {\n liveRegion = $(``);\n });\n on('afterInit', () => {\n if (!swiper.params.a11y.enabled) return;\n init();\n updateNavigation();\n });\n on('toEdge', () => {\n if (!swiper.params.a11y.enabled) return;\n updateNavigation();\n });\n on('fromEdge', () => {\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 }\n });\n let initialized = false;\n let paths = {};\n\n const slugify = text => {\n return text.toString().replace(/\\s+/g, '-').replace(/[^\\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');\n };\n\n const getPathValues = urlOverride => {\n const window = getWindow();\n let location;\n\n if (urlOverride) {\n location = new URL(urlOverride);\n } else {\n location = window.location;\n }\n\n const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');\n const total = pathArray.length;\n const key = pathArray[total - 2];\n const value = pathArray[total - 1];\n return {\n key,\n value\n };\n };\n\n const setHistory = (key, index) => {\n const window = getWindow();\n if (!initialized || !swiper.params.history.enabled) return;\n let location;\n\n if (swiper.params.url) {\n location = new URL(swiper.params.url);\n } else {\n location = window.location;\n }\n\n const slide = swiper.slides.eq(index);\n let value = slugify(slide.attr('data-history'));\n\n if (swiper.params.history.root.length > 0) {\n let root = swiper.params.history.root;\n if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);\n value = `${root}/${key}/${value}`;\n } else if (!location.pathname.includes(key)) {\n value = `${key}/${value}`;\n }\n\n const currentState = window.history.state;\n\n if (currentState && currentState.value === value) {\n return;\n }\n\n if (swiper.params.history.replaceState) {\n window.history.replaceState({\n value\n }, null, value);\n } else {\n window.history.pushState({\n value\n }, null, value);\n }\n };\n\n const scrollToSlide = (speed, value, runCallbacks) => {\n if (value) {\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHistory = slugify(slide.attr('data-history'));\n\n if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, runCallbacks);\n }\n }\n } else {\n swiper.slideTo(0, speed, runCallbacks);\n }\n };\n\n const setHistoryPopState = () => {\n paths = getPathValues(swiper.params.url);\n scrollToSlide(swiper.params.speed, swiper.paths.value, false);\n };\n\n const init = () => {\n const window = getWindow();\n if (!swiper.params.history) return;\n\n if (!window.history || !window.history.pushState) {\n swiper.params.history.enabled = false;\n swiper.params.hashNavigation.enabled = true;\n return;\n }\n\n initialized = true;\n paths = getPathValues(swiper.params.url);\n if (!paths.key && !paths.value) return;\n scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n\n if (!swiper.params.history.replaceState) {\n window.addEventListener('popstate', setHistoryPopState);\n }\n };\n\n const destroy = () => {\n const window = getWindow();\n\n if (!swiper.params.history.replaceState) {\n window.removeEventListener('popstate', setHistoryPopState);\n }\n };\n\n on('init', () => {\n if (swiper.params.history.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.history.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHistory(swiper.params.history.key, swiper.activeIndex);\n }\n });\n}","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function HashNavigation({\n swiper,\n extendParams,\n emit,\n on\n}) {\n let initialized = false;\n const document = getDocument();\n const window = getWindow();\n extendParams({\n hashNavigation: {\n enabled: false,\n replaceState: false,\n watchState: false\n }\n });\n\n const onHashChange = () => {\n emit('hashChange');\n const newHash = document.location.hash.replace('#', '');\n const activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');\n\n if (newHash !== activeSlideHash) {\n const newIndex = swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash=\"${newHash}\"]`).index();\n if (typeof newIndex === 'undefined') return;\n swiper.slideTo(newIndex);\n }\n };\n\n const setHash = () => {\n if (!initialized || !swiper.params.hashNavigation.enabled) return;\n\n if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr('data-hash')}` || '');\n emit('hashSet');\n } else {\n const slide = swiper.slides.eq(swiper.activeIndex);\n const hash = slide.attr('data-hash') || slide.attr('data-history');\n document.location.hash = hash || '';\n emit('hashSet');\n }\n };\n\n const init = () => {\n if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;\n initialized = true;\n const hash = document.location.hash.replace('#', '');\n\n if (hash) {\n const speed = 0;\n\n for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n const slide = swiper.slides.eq(i);\n const slideHash = slide.attr('data-hash') || slide.attr('data-history');\n\n if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {\n const index = slide.index();\n swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);\n }\n }\n }\n\n if (swiper.params.hashNavigation.watchState) {\n $(window).on('hashchange', onHashChange);\n }\n };\n\n const destroy = () => {\n if (swiper.params.hashNavigation.watchState) {\n $(window).off('hashchange', onHashChange);\n }\n };\n\n on('init', () => {\n if (swiper.params.hashNavigation.enabled) {\n init();\n }\n });\n on('destroy', () => {\n if (swiper.params.hashNavigation.enabled) {\n destroy();\n }\n });\n on('transitionEnd _freeModeNoMomentumRelease', () => {\n if (initialized) {\n setHash();\n }\n });\n on('slideChange', () => {\n if (initialized && swiper.params.cssMode) {\n setHash();\n }\n });\n}","/* eslint no-underscore-dangle: \"off\" */\n\n/* eslint no-use-before-define: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport { nextTick } from '../../shared/utils.js';\nexport default function Autoplay({\n swiper,\n extendParams,\n on,\n emit\n}) {\n let timeout;\n swiper.autoplay = {\n running: false,\n paused: false\n };\n extendParams({\n autoplay: {\n enabled: false,\n delay: 3000,\n waitForTransition: true,\n disableOnInteraction: true,\n stopOnLastSlide: false,\n reverseDirection: false,\n pauseOnMouseEnter: false\n }\n });\n\n function run() {\n const $activeSlideEl = swiper.slides.eq(swiper.activeIndex);\n let delay = swiper.params.autoplay.delay;\n\n if ($activeSlideEl.attr('data-swiper-autoplay')) {\n delay = $activeSlideEl.attr('data-swiper-autoplay') || swiper.params.autoplay.delay;\n }\n\n clearTimeout(timeout);\n timeout = nextTick(() => {\n let autoplayResult;\n\n if (swiper.params.autoplay.reverseDirection) {\n if (swiper.params.loop) {\n swiper.loopFix();\n autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n emit('autoplay');\n } else if (!swiper.isBeginning) {\n autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);\n emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n autoplayResult = swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);\n emit('autoplay');\n } else {\n stop();\n }\n } else if (swiper.params.loop) {\n swiper.loopFix();\n autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n emit('autoplay');\n } else if (!swiper.isEnd) {\n autoplayResult = swiper.slideNext(swiper.params.speed, true, true);\n emit('autoplay');\n } else if (!swiper.params.autoplay.stopOnLastSlide) {\n autoplayResult = swiper.slideTo(0, swiper.params.speed, true, true);\n emit('autoplay');\n } else {\n stop();\n }\n\n if (swiper.params.cssMode && swiper.autoplay.running) run();else if (autoplayResult === false) {\n run();\n }\n }, delay);\n }\n\n function start() {\n if (typeof timeout !== 'undefined') return false;\n if (swiper.autoplay.running) return false;\n swiper.autoplay.running = true;\n emit('autoplayStart');\n run();\n return true;\n }\n\n function stop() {\n if (!swiper.autoplay.running) return false;\n if (typeof timeout === 'undefined') return false;\n\n if (timeout) {\n clearTimeout(timeout);\n timeout = undefined;\n }\n\n swiper.autoplay.running = false;\n emit('autoplayStop');\n return true;\n }\n\n function pause(speed) {\n if (!swiper.autoplay.running) return;\n if (swiper.autoplay.paused) return;\n if (timeout) clearTimeout(timeout);\n swiper.autoplay.paused = true;\n\n if (speed === 0 || !swiper.params.autoplay.waitForTransition) {\n swiper.autoplay.paused = false;\n run();\n } else {\n ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd);\n });\n }\n }\n\n function onVisibilityChange() {\n const document = getDocument();\n\n if (document.visibilityState === 'hidden' && swiper.autoplay.running) {\n pause();\n }\n\n if (document.visibilityState === 'visible' && swiper.autoplay.paused) {\n run();\n swiper.autoplay.paused = false;\n }\n }\n\n function onTransitionEnd(e) {\n if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return;\n if (e.target !== swiper.$wrapperEl[0]) return;\n ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n });\n swiper.autoplay.paused = false;\n\n if (!swiper.autoplay.running) {\n stop();\n } else {\n run();\n }\n }\n\n function onMouseEnter() {\n if (swiper.params.autoplay.disableOnInteraction) {\n stop();\n } else {\n pause();\n }\n\n ['transitionend', 'webkitTransitionEnd'].forEach(event => {\n swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);\n });\n }\n\n function onMouseLeave() {\n if (swiper.params.autoplay.disableOnInteraction) {\n return;\n }\n\n swiper.autoplay.paused = false;\n run();\n }\n\n function attachMouseEvents() {\n if (swiper.params.autoplay.pauseOnMouseEnter) {\n swiper.$el.on('mouseenter', onMouseEnter);\n swiper.$el.on('mouseleave', onMouseLeave);\n }\n }\n\n function detachMouseEvents() {\n swiper.$el.off('mouseenter', onMouseEnter);\n swiper.$el.off('mouseleave', onMouseLeave);\n }\n\n on('init', () => {\n if (swiper.params.autoplay.enabled) {\n start();\n const document = getDocument();\n document.addEventListener('visibilitychange', onVisibilityChange);\n attachMouseEvents();\n }\n });\n on('beforeTransitionStart', (_s, speed, internal) => {\n if (swiper.autoplay.running) {\n if (internal || !swiper.params.autoplay.disableOnInteraction) {\n swiper.autoplay.pause(speed);\n } else {\n stop();\n }\n }\n });\n on('sliderFirstMove', () => {\n if (swiper.autoplay.running) {\n if (swiper.params.autoplay.disableOnInteraction) {\n stop();\n } else {\n pause();\n }\n }\n });\n on('touchEnd', () => {\n if (swiper.params.cssMode && swiper.autoplay.paused && !swiper.params.autoplay.disableOnInteraction) {\n run();\n }\n });\n on('destroy', () => {\n detachMouseEvents();\n\n if (swiper.autoplay.running) {\n stop();\n }\n\n const document = getDocument();\n document.removeEventListener('visibilitychange', onVisibilityChange);\n });\n Object.assign(swiper.autoplay, {\n pause,\n run,\n start,\n stop\n });\n}","import { isObject } from '../../shared/utils.js';\nimport $ from '../../shared/dom.js';\nexport default function Thumb({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n thumbs: {\n swiper: null,\n multipleActiveThumbs: true,\n autoScrollOffset: 0,\n slideThumbActiveClass: 'swiper-slide-thumb-active',\n thumbsContainerClass: 'swiper-thumbs'\n }\n });\n let initialized = false;\n let swiperCreated = false;\n swiper.thumbs = {\n swiper: null\n };\n\n function onThumbClick() {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n const clickedIndex = thumbsSwiper.clickedIndex;\n const clickedSlide = thumbsSwiper.clickedSlide;\n if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;\n if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;\n let slideToIndex;\n\n if (thumbsSwiper.params.loop) {\n slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n } else {\n slideToIndex = clickedIndex;\n }\n\n if (swiper.params.loop) {\n let currentIndex = swiper.activeIndex;\n\n if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n currentIndex = swiper.activeIndex;\n }\n\n const prevIndex = swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n const nextIndex = swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index=\"${slideToIndex}\"]`).eq(0).index();\n if (typeof prevIndex === 'undefined') slideToIndex = nextIndex;else if (typeof nextIndex === 'undefined') slideToIndex = prevIndex;else if (nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex = nextIndex;else slideToIndex = prevIndex;\n }\n\n swiper.slideTo(slideToIndex);\n }\n\n function init() {\n const {\n thumbs: thumbsParams\n } = swiper.params;\n if (initialized) return false;\n initialized = true;\n const SwiperClass = swiper.constructor;\n\n if (thumbsParams.swiper instanceof SwiperClass) {\n swiper.thumbs.swiper = thumbsParams.swiper;\n Object.assign(swiper.thumbs.swiper.originalParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n Object.assign(swiper.thumbs.swiper.params, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n } else if (isObject(thumbsParams.swiper)) {\n const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);\n Object.assign(thumbsSwiperParams, {\n watchSlidesProgress: true,\n slideToClickedSlide: false\n });\n swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);\n swiperCreated = true;\n }\n\n swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);\n swiper.thumbs.swiper.on('tap', onThumbClick);\n return true;\n }\n\n function update(initial) {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView;\n const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n\n if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n let currentThumbsIndex = thumbsSwiper.activeIndex;\n let newThumbsIndex;\n let direction;\n\n if (thumbsSwiper.params.loop) {\n if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {\n thumbsSwiper.loopFix(); // eslint-disable-next-line\n\n thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;\n currentThumbsIndex = thumbsSwiper.activeIndex;\n } // Find actual thumbs index to slide to\n\n\n const prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n const nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index=\"${swiper.realIndex}\"]`).eq(0).index();\n\n if (typeof prevThumbsIndex === 'undefined') {\n newThumbsIndex = nextThumbsIndex;\n } else if (typeof nextThumbsIndex === 'undefined') {\n newThumbsIndex = prevThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex : currentThumbsIndex;\n } else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) {\n newThumbsIndex = nextThumbsIndex;\n } else {\n newThumbsIndex = prevThumbsIndex;\n }\n\n direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';\n } else {\n newThumbsIndex = swiper.realIndex;\n direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';\n }\n\n if (useOffset) {\n newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;\n }\n\n if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n if (thumbsSwiper.params.centeredSlides) {\n if (newThumbsIndex > currentThumbsIndex) {\n newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n } else {\n newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n }\n } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) {// newThumbsIndex = newThumbsIndex - slidesPerView + 1;\n }\n\n thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n }\n } // Activate thumbs\n\n\n let thumbsToActivate = 1;\n const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n\n if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n thumbsToActivate = swiper.params.slidesPerView;\n }\n\n if (!swiper.params.thumbs.multipleActiveThumbs) {\n thumbsToActivate = 1;\n }\n\n thumbsToActivate = Math.floor(thumbsToActivate);\n thumbsSwiper.slides.removeClass(thumbActiveClass);\n\n if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).addClass(thumbActiveClass);\n }\n } else {\n for (let i = 0; i < thumbsToActivate; i += 1) {\n thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);\n }\n }\n }\n\n on('beforeInit', () => {\n const {\n thumbs\n } = swiper.params;\n if (!thumbs || !thumbs.swiper) return;\n init();\n update(true);\n });\n on('slideChange update resize observerUpdate', () => {\n if (!swiper.thumbs.swiper) return;\n update();\n });\n on('setTransition', (_s, duration) => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n thumbsSwiper.setTransition(duration);\n });\n on('beforeDestroy', () => {\n const thumbsSwiper = swiper.thumbs.swiper;\n if (!thumbsSwiper) return;\n\n if (swiperCreated && thumbsSwiper) {\n thumbsSwiper.destroy();\n }\n });\n Object.assign(swiper.thumbs, {\n init,\n update\n });\n}","import { now } from '../../shared/utils.js';\nexport default function freeMode({\n swiper,\n extendParams,\n emit,\n once\n}) {\n extendParams({\n freeMode: {\n enabled: false,\n momentum: true,\n momentumRatio: 1,\n momentumBounce: true,\n momentumBounceRatio: 1,\n momentumVelocityRatio: 1,\n sticky: false,\n minimumVelocity: 0.02\n }\n });\n\n function onTouchMove() {\n const {\n touchEventsData: data,\n touches\n } = swiper; // Velocity\n\n if (data.velocities.length === 0) {\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n time: data.touchStartTime\n });\n }\n\n data.velocities.push({\n position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n time: now()\n });\n }\n\n function onTouchEnd({\n currentPos\n }) {\n const {\n params,\n $wrapperEl,\n rtlTranslate: rtl,\n snapGrid,\n touchEventsData: data\n } = swiper; // Time diff\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime;\n\n if (currentPos < -swiper.minTranslate()) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (currentPos > -swiper.maxTranslate()) {\n if (swiper.slides.length < snapGrid.length) {\n swiper.slideTo(snapGrid.length - 1);\n } else {\n swiper.slideTo(swiper.slides.length - 1);\n }\n\n return;\n }\n\n if (params.freeMode.momentum) {\n if (data.velocities.length > 1) {\n const lastMoveEvent = data.velocities.pop();\n const velocityEvent = data.velocities.pop();\n const distance = lastMoveEvent.position - velocityEvent.position;\n const time = lastMoveEvent.time - velocityEvent.time;\n swiper.velocity = distance / time;\n swiper.velocity /= 2;\n\n if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {\n swiper.velocity = 0;\n } // this implies that the user stopped moving a finger then released.\n // There would be no events with distance zero, so the last event is stale.\n\n\n if (time > 150 || now() - lastMoveEvent.time > 300) {\n swiper.velocity = 0;\n }\n } else {\n swiper.velocity = 0;\n }\n\n swiper.velocity *= params.freeMode.momentumVelocityRatio;\n data.velocities.length = 0;\n let momentumDuration = 1000 * params.freeMode.momentumRatio;\n const momentumDistance = swiper.velocity * momentumDuration;\n let newPosition = swiper.translate + momentumDistance;\n if (rtl) newPosition = -newPosition;\n let doBounce = false;\n let afterBouncePosition;\n const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;\n let needsLoopFix;\n\n if (newPosition < swiper.maxTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n newPosition = swiper.maxTranslate() - bounceAmount;\n }\n\n afterBouncePosition = swiper.maxTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.maxTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (newPosition > swiper.minTranslate()) {\n if (params.freeMode.momentumBounce) {\n if (newPosition - swiper.minTranslate() > bounceAmount) {\n newPosition = swiper.minTranslate() + bounceAmount;\n }\n\n afterBouncePosition = swiper.minTranslate();\n doBounce = true;\n data.allowMomentumBounce = true;\n } else {\n newPosition = swiper.minTranslate();\n }\n\n if (params.loop && params.centeredSlides) needsLoopFix = true;\n } else if (params.freeMode.sticky) {\n let nextSlide;\n\n for (let j = 0; j < snapGrid.length; j += 1) {\n if (snapGrid[j] > -newPosition) {\n nextSlide = j;\n break;\n }\n }\n\n if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n newPosition = snapGrid[nextSlide];\n } else {\n newPosition = snapGrid[nextSlide - 1];\n }\n\n newPosition = -newPosition;\n }\n\n if (needsLoopFix) {\n once('transitionEnd', () => {\n swiper.loopFix();\n });\n } // Fix duration\n\n\n if (swiper.velocity !== 0) {\n if (rtl) {\n momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n } else {\n momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n }\n\n if (params.freeMode.sticky) {\n // If freeMode.sticky is active and the user ends a swipe with a slow-velocity\n // event, then durations can be 20+ seconds to slide one (or zero!) slides.\n // It's easy to see this when simulating touch with mouse events. To fix this,\n // limit single-slide swipes to the default slide duration. This also has the\n // nice side effect of matching slide speed if the user stopped moving before\n // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.\n // For faster swipes, also apply limits (albeit higher ones).\n const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);\n const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];\n\n if (moveDistance < currentSlideSize) {\n momentumDuration = params.speed;\n } else if (moveDistance < 2 * currentSlideSize) {\n momentumDuration = params.speed * 1.5;\n } else {\n momentumDuration = params.speed * 2.5;\n }\n }\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n }\n\n if (params.freeMode.momentumBounce && doBounce) {\n swiper.updateProgress(afterBouncePosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n emit('momentumBounce');\n swiper.setTransition(params.speed);\n setTimeout(() => {\n swiper.setTranslate(afterBouncePosition);\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }, 0);\n });\n } else if (swiper.velocity) {\n emit('_freeModeNoMomentumRelease');\n swiper.updateProgress(newPosition);\n swiper.setTransition(momentumDuration);\n swiper.setTranslate(newPosition);\n swiper.transitionStart(true, swiper.swipeDirection);\n\n if (!swiper.animating) {\n swiper.animating = true;\n $wrapperEl.transitionEnd(() => {\n if (!swiper || swiper.destroyed) return;\n swiper.transitionEnd();\n });\n }\n } else {\n swiper.updateProgress(newPosition);\n }\n\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n } else if (params.freeMode.sticky) {\n swiper.slideToClosest();\n return;\n } else if (params.freeMode) {\n emit('_freeModeNoMomentumRelease');\n }\n\n if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {\n swiper.updateProgress();\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n }\n\n Object.assign(swiper, {\n freeMode: {\n onTouchMove,\n onTouchEnd\n }\n });\n}","export default function Grid({\n swiper,\n extendParams\n}) {\n extendParams({\n grid: {\n rows: 1,\n fill: 'column'\n }\n });\n let slidesNumberEvenToRows;\n let slidesPerRow;\n let numFullColumns;\n\n const initSlides = slidesLength => {\n const {\n slidesPerView\n } = swiper.params;\n const {\n rows,\n fill\n } = swiper.params.grid;\n slidesPerRow = slidesNumberEvenToRows / rows;\n numFullColumns = Math.floor(slidesLength / rows);\n\n if (Math.floor(slidesLength / rows) === slidesLength / rows) {\n slidesNumberEvenToRows = slidesLength;\n } else {\n slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows;\n }\n\n if (slidesPerView !== 'auto' && fill === 'row') {\n slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, slidesPerView * rows);\n }\n };\n\n const updateSlide = (i, slide, slidesLength, getDirectionLabel) => {\n const {\n slidesPerGroup,\n spaceBetween\n } = swiper.params;\n const {\n rows,\n fill\n } = swiper.params.grid; // Set slides order\n\n let newSlideOrderIndex;\n let column;\n let row;\n\n if (fill === 'row' && slidesPerGroup > 1) {\n const groupIndex = Math.floor(i / (slidesPerGroup * rows));\n const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex;\n const columnsInGroup = groupIndex === 0 ? slidesPerGroup : Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);\n row = Math.floor(slideIndexInGroup / columnsInGroup);\n column = slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;\n newSlideOrderIndex = column + row * slidesNumberEvenToRows / rows;\n slide.css({\n '-webkit-order': newSlideOrderIndex,\n order: newSlideOrderIndex\n });\n } else if (fill === 'column') {\n column = Math.floor(i / rows);\n row = i - column * rows;\n\n if (column > numFullColumns || column === numFullColumns && row === rows - 1) {\n row += 1;\n\n if (row >= rows) {\n row = 0;\n column += 1;\n }\n }\n } else {\n row = Math.floor(i / slidesPerRow);\n column = i - row * slidesPerRow;\n }\n\n slide.css(getDirectionLabel('margin-top'), row !== 0 ? spaceBetween && `${spaceBetween}px` : '');\n };\n\n const updateWrapperSize = (slideSize, snapGrid, getDirectionLabel) => {\n const {\n spaceBetween,\n centeredSlides,\n roundLengths\n } = swiper.params;\n const {\n rows\n } = swiper.params.grid;\n swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows;\n swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween;\n swiper.$wrapperEl.css({\n [getDirectionLabel('width')]: `${swiper.virtualSize + spaceBetween}px`\n });\n\n if (centeredSlides) {\n snapGrid.splice(0, snapGrid.length);\n const newSlidesGrid = [];\n\n for (let i = 0; i < snapGrid.length; i += 1) {\n let slidesGridItem = snapGrid[i];\n if (roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);\n }\n\n snapGrid.push(...newSlidesGrid);\n }\n };\n\n swiper.grid = {\n initSlides,\n updateSlide,\n updateWrapperSize\n };\n}","import appendSlide from './methods/appendSlide.js';\nimport prependSlide from './methods/prependSlide.js';\nimport addSlide from './methods/addSlide.js';\nimport removeSlide from './methods/removeSlide.js';\nimport removeAllSlides from './methods/removeAllSlides.js';\nexport default function Manipulation({\n swiper\n}) {\n Object.assign(swiper, {\n appendSlide: appendSlide.bind(swiper),\n prependSlide: prependSlide.bind(swiper),\n addSlide: addSlide.bind(swiper),\n removeSlide: removeSlide.bind(swiper),\n removeAllSlides: removeAllSlides.bind(swiper)\n });\n}","export default function appendSlide(slides) {\n const swiper = this;\n const {\n $wrapperEl,\n params\n } = swiper;\n\n if (params.loop) {\n swiper.loopDestroy();\n }\n\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) $wrapperEl.append(slides[i]);\n }\n } else {\n $wrapperEl.append(slides);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!params.observer) {\n swiper.update();\n }\n}","export default function prependSlide(slides) {\n const swiper = this;\n const {\n params,\n $wrapperEl,\n activeIndex\n } = swiper;\n\n if (params.loop) {\n swiper.loopDestroy();\n }\n\n let newActiveIndex = activeIndex + 1;\n\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) $wrapperEl.prepend(slides[i]);\n }\n\n newActiveIndex = activeIndex + slides.length;\n } else {\n $wrapperEl.prepend(slides);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!params.observer) {\n swiper.update();\n }\n\n swiper.slideTo(newActiveIndex, 0, false);\n}","export default function addSlide(index, slides) {\n const swiper = this;\n const {\n $wrapperEl,\n params,\n activeIndex\n } = swiper;\n let activeIndexBuffer = activeIndex;\n\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children(`.${params.slideClass}`);\n }\n\n const baseLength = swiper.slides.length;\n\n if (index <= 0) {\n swiper.prependSlide(slides);\n return;\n }\n\n if (index >= baseLength) {\n swiper.appendSlide(slides);\n return;\n }\n\n let newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;\n const slidesBuffer = [];\n\n for (let i = baseLength - 1; i >= index; i -= 1) {\n const currentSlide = swiper.slides.eq(i);\n currentSlide.remove();\n slidesBuffer.unshift(currentSlide);\n }\n\n if (typeof slides === 'object' && 'length' in slides) {\n for (let i = 0; i < slides.length; i += 1) {\n if (slides[i]) $wrapperEl.append(slides[i]);\n }\n\n newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;\n } else {\n $wrapperEl.append(slides);\n }\n\n for (let i = 0; i < slidesBuffer.length; i += 1) {\n $wrapperEl.append(slidesBuffer[i]);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!params.observer) {\n swiper.update();\n }\n\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n}","export default function removeSlide(slidesIndexes) {\n const swiper = this;\n const {\n params,\n $wrapperEl,\n activeIndex\n } = swiper;\n let activeIndexBuffer = activeIndex;\n\n if (params.loop) {\n activeIndexBuffer -= swiper.loopedSlides;\n swiper.loopDestroy();\n swiper.slides = $wrapperEl.children(`.${params.slideClass}`);\n }\n\n let newActiveIndex = activeIndexBuffer;\n let indexToRemove;\n\n if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {\n for (let i = 0; i < slidesIndexes.length; i += 1) {\n indexToRemove = slidesIndexes[i];\n if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();\n if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n }\n\n newActiveIndex = Math.max(newActiveIndex, 0);\n } else {\n indexToRemove = slidesIndexes;\n if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();\n if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n newActiveIndex = Math.max(newActiveIndex, 0);\n }\n\n if (params.loop) {\n swiper.loopCreate();\n }\n\n if (!params.observer) {\n swiper.update();\n }\n\n if (params.loop) {\n swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n } else {\n swiper.slideTo(newActiveIndex, 0, false);\n }\n}","export default function removeAllSlides() {\n const swiper = this;\n const slidesIndexes = [];\n\n for (let i = 0; i < swiper.slides.length; i += 1) {\n slidesIndexes.push(i);\n }\n\n swiper.removeSlide(slidesIndexes);\n}","import effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectFade({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n fadeEffect: {\n crossFade: false,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n slides\n } = swiper;\n const params = swiper.params.fadeEffect;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = swiper.slides.eq(i);\n const offset = $slideEl[0].swiperSlideOffset;\n let tx = -offset;\n if (!swiper.params.virtualTranslate) tx -= swiper.translate;\n let ty = 0;\n\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n }\n\n const slideOpacity = swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs($slideEl[0].progress), 0) : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0);\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.css({\n opacity: slideOpacity\n }).transform(`translate3d(${tx}px, ${ty}px, 0px)`);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.fadeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl,\n allSlides: true\n });\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}","export default function effectInit(params) {\n const {\n effect,\n swiper,\n on,\n setTranslate,\n setTransition,\n overwriteParams,\n perspective\n } = params;\n on('beforeInit', () => {\n if (swiper.params.effect !== effect) return;\n swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);\n\n if (perspective && perspective()) {\n swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);\n }\n\n const overwriteParamsResult = overwriteParams ? overwriteParams() : {};\n Object.assign(swiper.params, overwriteParamsResult);\n Object.assign(swiper.originalParams, overwriteParamsResult);\n });\n on('setTranslate', () => {\n if (swiper.params.effect !== effect) return;\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n if (swiper.params.effect !== effect) return;\n setTransition(duration);\n });\n}","export default function effectTarget(effectParams, $slideEl) {\n if (effectParams.transformEl) {\n return $slideEl.find(effectParams.transformEl).css({\n 'backface-visibility': 'hidden',\n '-webkit-backface-visibility': 'hidden'\n });\n }\n\n return $slideEl;\n}","export default function effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl,\n allSlides\n}) {\n const {\n slides,\n activeIndex,\n $wrapperEl\n } = swiper;\n\n if (swiper.params.virtualTranslate && duration !== 0) {\n let eventTriggered = false;\n let $transitionEndTarget;\n\n if (allSlides) {\n $transitionEndTarget = transformEl ? slides.find(transformEl) : slides;\n } else {\n $transitionEndTarget = transformEl ? slides.eq(activeIndex).find(transformEl) : slides.eq(activeIndex);\n }\n\n $transitionEndTarget.transitionEnd(() => {\n if (eventTriggered) return;\n if (!swiper || swiper.destroyed) return;\n eventTriggered = true;\n swiper.animating = false;\n const triggerEvents = ['webkitTransitionEnd', 'transitionend'];\n\n for (let i = 0; i < triggerEvents.length; i += 1) {\n $wrapperEl.trigger(triggerEvents[i]);\n }\n });\n }\n}","import $ from '../../shared/dom.js';\nimport effectInit from '../../shared/effect-init.js';\nexport default function EffectCube({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cubeEffect: {\n slideShadows: true,\n shadow: true,\n shadowOffset: 20,\n shadowScale: 0.94\n }\n });\n\n const setTranslate = () => {\n const {\n $el,\n $wrapperEl,\n slides,\n width: swiperWidth,\n height: swiperHeight,\n rtlTranslate: rtl,\n size: swiperSize,\n browser\n } = swiper;\n const params = swiper.params.cubeEffect;\n const isHorizontal = swiper.isHorizontal();\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n let wrapperRotate = 0;\n let $cubeShadowEl;\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $wrapperEl.append($cubeShadowEl);\n }\n\n $cubeShadowEl.css({\n height: `${swiperWidth}px`\n });\n } else {\n $cubeShadowEl = $el.find('.swiper-cube-shadow');\n\n if ($cubeShadowEl.length === 0) {\n $cubeShadowEl = $('
');\n $el.append($cubeShadowEl);\n }\n }\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let slideIndex = i;\n\n if (isVirtual) {\n slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);\n }\n\n let slideAngle = slideIndex * 90;\n let round = Math.floor(slideAngle / 360);\n\n if (rtl) {\n slideAngle = -slideAngle;\n round = Math.floor(-slideAngle / 360);\n }\n\n const progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n let tx = 0;\n let ty = 0;\n let tz = 0;\n\n if (slideIndex % 4 === 0) {\n tx = -round * 4 * swiperSize;\n tz = 0;\n } else if ((slideIndex - 1) % 4 === 0) {\n tx = 0;\n tz = -round * 4 * swiperSize;\n } else if ((slideIndex - 2) % 4 === 0) {\n tx = swiperSize + round * 4 * swiperSize;\n tz = swiperSize;\n } else if ((slideIndex - 3) % 4 === 0) {\n tx = -swiperSize;\n tz = 3 * swiperSize + swiperSize * 4 * round;\n }\n\n if (rtl) {\n tx = -tx;\n }\n\n if (!isHorizontal) {\n ty = tx;\n tx = 0;\n }\n\n const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;\n\n if (progress <= 1 && progress > -1) {\n wrapperRotate = slideIndex * 90 + progress * 90;\n if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;\n }\n\n $slideEl.transform(transform);\n\n if (params.slideShadows) {\n // Set shadows\n let shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = $(`
`);\n $slideEl.append(shadowBefore);\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = $(`
`);\n $slideEl.append(shadowAfter);\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n }\n }\n\n $wrapperEl.css({\n '-webkit-transform-origin': `50% 50% -${swiperSize / 2}px`,\n 'transform-origin': `50% 50% -${swiperSize / 2}px`\n });\n\n if (params.shadow) {\n if (isHorizontal) {\n $cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);\n } else {\n const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;\n const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);\n const scale1 = params.shadowScale;\n const scale2 = params.shadowScale / multiplier;\n const offset = params.shadowOffset;\n $cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);\n }\n }\n\n const zFactor = browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0;\n $wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`);\n };\n\n const setTransition = duration => {\n const {\n $el,\n slides\n } = swiper;\n slides.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n\n if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n $el.find('.swiper-cube-shadow').transition(duration);\n }\n };\n\n effectInit({\n effect: 'cube',\n swiper,\n on,\n setTranslate,\n setTransition,\n 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 createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectFlip({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n flipEffect: {\n slideShadows: true,\n limitRotation: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n slides,\n rtlTranslate: rtl\n } = swiper;\n const params = swiper.params.flipEffect;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n let progress = $slideEl[0].progress;\n\n if (swiper.params.flipEffect.limitRotation) {\n progress = Math.max(Math.min($slideEl[0].progress, 1), -1);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const rotate = -180 * progress;\n let rotateY = rotate;\n let rotateX = 0;\n let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let ty = 0;\n\n if (!swiper.isHorizontal()) {\n ty = tx;\n tx = 0;\n rotateX = -rotateY;\n rotateY = 0;\n } else if (rtl) {\n rotateY = -rotateY;\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n\n if (params.slideShadows) {\n // Set shadows\n let shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if (shadowBefore.length === 0) {\n shadowBefore = createShadow(params, $slideEl, swiper.isHorizontal() ? 'left' : 'top');\n }\n\n if (shadowAfter.length === 0) {\n shadowAfter = createShadow(params, $slideEl, swiper.isHorizontal() ? 'right' : 'bottom');\n }\n\n if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);\n if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);\n }\n\n const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.flipEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'flip',\n swiper,\n on,\n setTranslate,\n setTransition,\n 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 $ from './dom.js';\nexport default function createShadow(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n\n if (!$shadowEl.length) {\n $shadowEl = $(`
`);\n $shadowContainer.append($shadowEl);\n }\n\n return $shadowEl;\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nexport default function EffectCoverflow({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n width: swiperWidth,\n height: swiperHeight,\n slides,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const offsetMultiplier = (center - slideOffset - slideSize / 2) / slideSize * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\n }\n\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n\n if (Math.abs(translateX) < 0.001) translateX = 0;\n if (Math.abs(translateY) < 0.001) translateY = 0;\n if (Math.abs(translateZ) < 0.001) translateZ = 0;\n if (Math.abs(rotateY) < 0.001) rotateY = 0;\n if (Math.abs(rotateX) < 0.001) rotateX = 0;\n if (Math.abs(scale) < 0.001) scale = 0;\n const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');\n }\n\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');\n }\n\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n };\n\n effectInit({\n effect: 'coverflow',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true\n })\n });\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectCreative({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n creativeEffect: {\n transformEl: null,\n limitProgress: 1,\n shadowPerProgress: false,\n progressMultiplier: 1,\n perspective: true,\n prev: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n },\n next: {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n opacity: 1,\n scale: 1\n }\n }\n });\n\n const getTranslateValue = value => {\n if (typeof value === 'string') return value;\n return `${value}px`;\n };\n\n const setTranslate = () => {\n const {\n slides,\n $wrapperEl,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.creativeEffect;\n const {\n progressMultiplier: multiplier\n } = params;\n const isCenteredSlides = swiper.params.centeredSlides;\n\n if (isCenteredSlides) {\n const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);\n }\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);\n let originalProgress = progress;\n\n if (!isCenteredSlides) {\n originalProgress = Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);\n }\n\n const offset = $slideEl[0].swiperSlideOffset;\n const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];\n const r = [0, 0, 0];\n let custom = false;\n\n if (!swiper.isHorizontal()) {\n t[1] = t[0];\n t[0] = 0;\n }\n\n let data = {\n translate: [0, 0, 0],\n rotate: [0, 0, 0],\n scale: 1,\n opacity: 1\n };\n\n if (progress < 0) {\n data = params.next;\n custom = true;\n } else if (progress > 0) {\n data = params.prev;\n custom = true;\n } // set translate\n\n\n t.forEach((value, index) => {\n t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n }); // set rotates\n\n r.forEach((value, index) => {\n r[index] = data.rotate[index] * Math.abs(progress * multiplier);\n });\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const translateString = t.join(', ');\n const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;\n const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;\n const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;\n const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows\n\n if (custom && data.shadow || !custom) {\n let $shadowEl = $slideEl.children('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0 && data.shadow) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) {\n const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n $shadowEl[0].style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n }\n }\n\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform).css({\n opacity: opacityString\n });\n\n if (data.origin) {\n $targetEl.css('transform-origin', data.origin);\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.creativeEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl,\n allSlides: true\n });\n };\n\n effectInit({\n effect: 'creative',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => swiper.params.creativeEffect.perspective,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nimport effectVirtualTransitionEnd from '../../shared/effect-virtual-transition-end.js';\nexport default function EffectCards({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n cardsEffect: {\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n slides,\n activeIndex\n } = swiper;\n const params = swiper.params.cardsEffect;\n const {\n startTranslate,\n isTouched\n } = swiper.touchEventsData;\n const currentTranslate = swiper.translate;\n\n for (let i = 0; i < slides.length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideProgress = $slideEl[0].progress;\n const progress = Math.min(Math.max(slideProgress, -4), 4);\n let offset = $slideEl[0].swiperSlideOffset;\n\n if (swiper.params.centeredSlides && !swiper.params.cssMode) {\n swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);\n }\n\n if (swiper.params.centeredSlides && swiper.params.cssMode) {\n offset -= slides[0].swiperSlideOffset;\n }\n\n let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n let tY = 0;\n const tZ = -100 * Math.abs(progress);\n let scale = 1;\n let rotate = -2 * progress;\n let tXAdd = 8 - Math.abs(progress) * 0.75;\n const isSwipeToNext = (i === activeIndex || i === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;\n const isSwipeToPrev = (i === activeIndex || i === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;\n\n if (isSwipeToNext || isSwipeToPrev) {\n const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;\n rotate += -28 * progress * subProgress;\n scale += -0.5 * subProgress;\n tXAdd += 96 * subProgress;\n tY = `${-25 * subProgress * Math.abs(progress)}%`;\n }\n\n if (progress < 0) {\n // next\n tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;\n } else if (progress > 0) {\n // prev\n tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;\n } else {\n tX = `${tX}px`;\n }\n\n if (!swiper.isHorizontal()) {\n const prevY = tY;\n tY = tX;\n tX = prevY;\n }\n\n const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;\n const transform = `\n translate3d(${tX}, ${tY}, ${tZ}px)\n rotateZ(${rotate}deg)\n scale(${scaleString})\n `;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowEl = $slideEl.find('.swiper-slide-shadow');\n\n if ($shadowEl.length === 0) {\n $shadowEl = createShadow(params, $slideEl);\n }\n\n if ($shadowEl.length) $shadowEl[0].style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n }\n\n $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(transform);\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.cardsEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);\n effectVirtualTransitionEnd({\n swiper,\n duration,\n transformEl\n });\n };\n\n effectInit({\n effect: 'cards',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true,\n virtualTranslate: !swiper.params.cssMode\n })\n });\n}"],"names":["$d0e306ed97de446f$var$support","$ee7403737d46980d$var$deviceCached","$2a3bcebc4608246a$var$browser","$parcel$export","e","n","v","s","Object","defineProperty","get","set","enumerable","configurable","$parcel$global","globalThis","$parcel$modules","$parcel$inits","parcelRequire","id","exports","init","module","call","err","Error","code","register","parcelRegister","$","addClass","removeClass","toggleClass","hasClass","attr","removeAttr","transform","transition","on","off","trigger","transitionEnd","outerWidth","outerHeight","offset","styles","css","each","filter","html","text","is","index","eq","append","prepend","next","nextAll","prev","prevAll","parent","parents","closest","find","children","remove","$101nH","Dom7","Array","constructor","items","makeReactive","obj","proto","__proto__","value","arrayFlat","arr","res","forEach","el","isArray","push","arrayFilter","callback","prototype","selector","context","window","getWindow","document","getDocument","trim","indexOf","toCreate","tempParent","createElement","innerHTML","i","childNodes","length","qsa","a","querySelectorAll","nodeType","arrayUnique","uniqueArray","classes","classNames","map","c","split","classList","add","className","toggle","contains","attrs","arguments","getAttribute","setAttribute","attrName","removeAttribute","style","duration","transitionDuration","args","j","eventType","targetSelector","listener","capture","handleLiveEvent","target","eventData","dom7EventData","unshift","apply","k","handleEvent","undefined","events","event","dom7LiveListeners","proxyListener","addEventListener","dom7Listeners","handlers","handler","removeEventListener","splice","dom7proxy","CustomEvent","evt","detail","bubbles","cancelable","data","dataIndex","dispatchEvent","dom","fireCallBack","includeMargins","offsetWidth","parseFloat","getPropertyValue","offsetHeight","box","getBoundingClientRect","body","clientTop","clientLeft","scrollTop","scrollY","scrollLeft","scrollX","top","left","getComputedStyle","props","prop","textContent","compareWith","matches","webkitMatchesSelector","msMatchesSelector","child","previousSibling","returnIndex","els","newChild","tempDiv","firstChild","appendChild","insertBefore","nextElementSibling","nextEls","previousElementSibling","prevEls","parentNode","foundElements","found","removeChild","fn","noTrigger","shortcut","name","$0ba6dcd7640852a2$var$isObject","$0ba6dcd7640852a2$export$8b58be045bf06082","src","keys","key","$0ba6dcd7640852a2$export$f65ca476c09acec0","$0ba6dcd7640852a2$export$38b2d434cce3ea22","$0ba6dcd7640852a2$export$3fdcb9b4d81368d8","activeElement","blur","nodeName","querySelector","getElementById","createEvent","initEvent","getElementsByTagName","createElementNS","importNode","location","hash","host","hostname","href","origin","pathname","protocol","search","doc","$0ba6dcd7640852a2$export$8582633f185c62bb","navigator","userAgent","history","replaceState","pushState","go","back","Image","Date","screen","setTimeout","clearTimeout","matchMedia","requestAnimationFrame","cancelAnimationFrame","win","$horZ8","$5172d1d318d9c216$var$Methods","methodName","writable","$5172d1d318d9c216$export$2e2bcd8739ae039","$3b5ddcf6fe080905$export$bdd553fddd433dcb","delay","$3b5ddcf6fe080905$export$461939dd4422153","now","$3b5ddcf6fe080905$export$a6cdc56e425d0d0a","o","toString","slice","$3b5ddcf6fe080905$export$8b58be045bf06082","to","noExtend","nextSource","HTMLElement","node","keysArray","nextIndex","len","nextKey","desc","getOwnPropertyDescriptor","__swiper__","$3b5ddcf6fe080905$export$a607267f322101fd","varName","varValue","setProperty","$3b5ddcf6fe080905$export$a5dd2b4b1a116d6d","swiper","targetPosition","side","time","window1","startPosition","translate","startTime","params","speed","wrapperEl","scrollSnapType","cssModeFrameID","dir","isOutOfBound","current","animate","getTime","currentPosition","easeProgress","Math","cos","progress","max","min","PI","scrollTo","overflow","$d0e306ed97de446f$export$d61c7b85ff180578","$d0e306ed97de446f$var$calcSupport","smoothScroll","documentElement","touch","DocumentTouch","passiveListener","supportsPassive","opts","gestures","$1b0227d4093c7233$export$2e2bcd8739ae039","runCallbacks","direction","step","activeIndex","previousIndex","emit","$c068e03d11ae7cb6$export$2e2bcd8739ae039","touchEventsData","touches","enabled","animating","preventInteractionOnTransition","cssMode","loop","loopFix","originalEvent","$targetEl","touchEventsTarget","isTouchEvent","type","which","button","isTouched","isMoved","noSwipingClass","shadowRoot","path","noSwipingSelector","isTargetShadow","noSwiping","$c068e03d11ae7cb6$var$closestElement","base","__closestFrom","assignedSlot","getRootNode","allowClick","swipeHandler","currentX","targetTouches","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","$90ca77dda1086c37$export$2e2bcd8739ae039","rtlTranslate","rtl","targetTouch","changedTouches","preventedByNestedSwiper","touchReleaseOnEdges","isVertical","maxTranslate","minTranslate","diffX","diffY","sqrt","touchAngle","isHorizontal","atan2","abs","touchMoveStopPropagation","nested","stopPropagation","startTranslate","getTranslate","setTransition","$wrapperEl","allowMomentumBounce","grabCursor","allowSlideNext","allowSlidePrev","setGrabCursor","diff","touchRatio","currentTranslate","disableParentSwiper","resistanceRatio","resistance","followFinger","freeMode","watchSlidesProgress","updateActiveIndex","updateSlidesClasses","onTouchMove","updateProgress","setTranslate","$7a326ec7d22df549$export$2e2bcd8739ae039","currentPos","slidesGrid","touchEndTime","timeDiff","pathTree","composedPath","updateClickedSlide","lastClickTime","destroyed","onTouchEnd","stopIndex","groupSize","slidesSizesGrid","slidesPerGroupSkip","slidesPerGroup","increment","ratio","longSwipesMs","longSwipes","slideTo","longSwipesRatio","shortSwipes","navigation","nextEl","prevEl","$5937dd0d5d42a619$export$2e2bcd8739ae039","breakpoints","setBreakpoint","snapGrid","updateSlides","slidesPerView","isEnd","isBeginning","centeredSlides","slides","autoplay","running","paused","run","watchOverflow","checkOverflow","$a208f3f006ed227f$export$2e2bcd8739ae039","preventClicks","preventClicksPropagation","stopImmediatePropagation","$e5fc741aa4ac34ad$export$2e2bcd8739ae039","previousTranslate","translatesDiff","$09c019bd8128ad9a$var$dummyEventAttached","$09c019bd8128ad9a$var$dummyEventListener","$09c019bd8128ad9a$var$events","method","touchEvents","device","support","domMethod","start","passiveListeners","passive","onTouchStart","move","end","cancel","onClick","onScroll","updateOnWindowResize","ios","android","$dbd03792c4fa18b9$var$isGridEnabled","grid","rows","$c5498ea2679b026d$export$2e2bcd8739ae039","initialSlide","resizeObserver","createElements","width","height","url","autoHeight","setWrapperSize","virtualTranslate","effect","breakpointsBase","spaceBetween","slidesPerGroupAuto","centeredSlidesBounds","slidesOffsetBefore","slidesOffsetAfter","normalizeSlideIndex","centerInsufficientSlides","roundLengths","simulateTouch","uniqueNavElements","slideToClickedSlide","preloadImages","updateOnImagesReady","loopAdditionalSlides","loopedSlides","loopFillGroupWithBlank","loopPreventsSlide","rewind","containerModifierClass","slideClass","slideBlankClass","slideActiveClass","slideDuplicateActiveClass","slideVisibleClass","slideDuplicateClass","slideNextClass","slideDuplicateNextClass","slidePrevClass","slideDuplicatePrevClass","wrapperClass","runCallbacksOnInit","_emitClasses","$7923a396d019f6bb$var$prototypes","eventsEmitter","priority","self","eventsListeners","once","onceHandler","__emitterProxy","onAny","eventsAnyListeners","offAny","eventHandler","eventsArray","update","$el","clientWidth","clientHeight","parseInt","Number","isNaN","size","slideSize","getDirectionLabel","property","getDirectionPropertyValue","label","swiperSize","wrongRTL","isVirtual","virtual","previousSlidesLength","slidesLength","offsetBefore","offsetAfter","previousSnapGridLength","previousSlidesGridLength","slidePosition","prevSlideSize","replace","virtualSize","marginLeft","marginBottom","marginTop","marginRight","gridEnabled","initSlides","shouldResetSlideSize","slide","updateSlide","slideStyles","currentTransform","currentWebKitTransform","webkitTransform","paddingLeft","paddingRight","boxSizing","floor","swiperSlideSize","updateWrapperSize","newSlidesGrid","slidesGridItem","_","slideIndex","allSlidesSize","slideSizeValue","maxSnap","snap","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","updateSlidesOffset","updateAutoHeight","activeSlides","newHeight","getSlideByIndex","visibleSlides","ceil","swiperSlideOffset","offsetLeft","offsetTop","updateSlidesProgress","offsetCenter","visibleSlidesIndexes","slideOffset","slideProgress","originalSlideProgress","slideBefore","slideAfter","originalProgress","multiplier","wasBeginning","wasEnd","activeSlide","realIndex","nextSlide","prevSlide","emitSlidesClasses","newActiveIndex","previousRealIndex","previousSnapIndex","skip","initialized","slideFound","clickedSlide","clickedIndex","axis","matrix","curTransform","transformMatrix","curStyle","$3b5ddcf6fe080905$export$3735103072e4a80","currentStyle","WebKitCSSMatrix","join","MozTransform","OTransform","MsTransform","msTransform","m41","m42","byController","x","y","translateTo","translateBounds","internal","newTranslate","isH","behavior","onTranslateToWrapperTransitionEnd","transitionStart","initial","indexAsNumber","isFinite","normalizedTranslate","normalizedGrid","normalizedGridNext","t","_immediateVirtual","_swiperImmediateVirtual","onSlideToWrapperTransitionEnd","slideToLoop","newIndex","slideNext","perGroup","slidesPerViewDynamic","_clientLeft","slidePrev","normalize","val","normalizedSnapGrid","prevSnap","prevSnapIndex","prevIndex","slideReset","slideToClosest","currentSnap","nextSnap","slideToIndex","loopCreate","$selector","blankSlidesNum","blankNode","prependSlides","appendSlides","cloneNode","snapTranslate","loopDestroy","moving","isLocked","cursor","unsetGrabCursor","attachEvents","bind","detachEvents","breakpoint","getBreakpoint","currentBreakpoint","breakpointParams","breakpointOnlyParams","originalParams","wasMultiRow","isMultiRow","wasEnabled","emitContainerClasses","fill","directionChanged","needsReLoop","changeDirection","isEnabled","disable","enable","containerEl","currentHeight","innerHeight","points","point","substr","sort","b","wasLocked","lastSlideIndex","lastSlideRightEdge","addClasses","suffixes","$65be96cb684c831c$var$prepareClasses","entries","prefix","resultClasses","item","removeClasses","images","loadImage","imageEl","srcset","sizes","checkForComplete","image","onReady","complete","onload","onerror","imagesLoaded","imagesToLoad","currentSrc","$7923a396d019f6bb$var$extendedDefaults","$7923a396d019f6bb$var$Swiper","swipers","newParams","overrides","$ee7403737d46980d$var$calcDevice","platform","ua","screenWidth","screenHeight","match","ipad","ipod","iphone","macos","iPadScreens","os","browser","$2a3bcebc4608246a$var$calcBrowser","isSafari","toLowerCase","isWebView","test","modules","__modules__","allModulesParams","mod","extendParams","moduleParamName","moduleParams","auto","swiperParams","passedParams","eventName","velocity","touchEventsTouch","touchEventsDesktop","clickTimeout","velocities","setProgress","cls","getSlideClasses","slideEl","updates","view","exact","spv","breakLoop","newDirection","needUpdate","currentDirection","mount","mounted","getWrapperSelector","getWrapper","options","wrapper","destroy","deleteInstance","cleanStyles","object","extendDefaults","newDefaults","extendedDefaults","defaults","installModule","use","m","$9eb7674adf88813c$export$2e2bcd8739ae039","checkProps","element","$c149d04ee6362df0$export$2e2bcd8739ae039","prototypeGroup","protoMethod","observer","resizeHandler","createObserver","ResizeObserver","newWidth","contentBoxSize","contentRect","inlineSize","blockSize","observe","removeObserver","unobserve","orientationChangeHandler","observers","attach","MutationObserver","WebkitMutationObserver","mutations","observerUpdate","attributes","childList","characterData","observeParents","observeSlideChildren","containerParents","disconnect","getEl","toggleEl","disabled","disabledClass","tagName","lockClass","$nextEl","$prevEl","onPrevClick","onNextClick","hideOnClick","hiddenClass","_s","targetEl","isHidden","pagination","clickable","bulletSize","pfx","bulletElement","renderBullet","renderProgressbar","renderFraction","renderCustom","progressbarOpposite","dynamicBullets","dynamicMainBullets","formatFractionCurrent","number","formatFractionTotal","bulletClass","bulletActiveClass","modifierClass","currentClass","totalClass","progressbarFillClass","progressbarOppositeClass","clickableClass","horizontalClass","verticalClass","bullets","dynamicBulletIndex","isPaginationDisabled","setSideBullets","$bulletEl","position","total","paginationType","firstIndex","lastIndex","midIndex","suffix","bullet","$bullet","bulletIndex","$firstDisplayedBullet","$lastDisplayedBullet","dynamicBulletsLength","bulletsOffset","progressbarDirection","scale","scaleX","scaleY","render","paginationHTML","numberOfBullets","timeout","$activeSlideEl","autoplayResult","reverseDirection","stopOnLastSlide","stop","pause","waitForTransition","onTransitionEnd","onVisibilityChange","visibilityState","onMouseEnter","disableOnInteraction","onMouseLeave","pauseOnMouseEnter","$307ade30fbf6a1ec$var$navToggle","navLayout","$307ade30fbf6a1ec$var$mondayToggle","$307ade30fbf6a1ec$var$tuesdayToggle","$307ade30fbf6a1ec$var$wednesdayToggle","$307ade30fbf6a1ec$var$thursdayToggle","$307ade30fbf6a1ec$var$fridayToggle","onscroll"],"version":3,"file":"main.js.map","sourceRoot":"../../"}