(() => { "use strict"; function isWebp() { function testWebP(callback) { let webP = new Image; webP.onload = webP.onerror = function() { callback(2 == webP.height); }; webP.src = ""; } testWebP((function(support) { let className = true === support ? "webp" : "no-webp"; document.documentElement.classList.add(className); })); } let isMobile = { Android: function() { return navigator.userAgent.match(/Android/i); }, BlackBerry: function() { return navigator.userAgent.match(/BlackBerry/i); }, iOS: function() { return navigator.userAgent.match(/iPhone|iPad|iPod/i); }, Opera: function() { return navigator.userAgent.match(/Opera Mini/i); }, Windows: function() { return navigator.userAgent.match(/IEMobile/i); }, any: function() { return isMobile.Android() || isMobile.BlackBerry() || isMobile.iOS() || isMobile.Opera() || isMobile.Windows(); } }; function addTouchClass() { if (isMobile.any()) document.documentElement.classList.add("touch"); } function getHash() { if (location.hash) return location.hash.replace("#", ""); } let bodyLockStatus = true; let bodyLockToggle = (delay = 500) => { if (document.documentElement.classList.contains("lock")) bodyUnlock(delay); else bodyLock(delay); }; let bodyUnlock = (delay = 500) => { let body = document.querySelector("body"); if (bodyLockStatus) { let lock_padding = document.querySelectorAll("[data-lp]"); setTimeout((() => { for (let index = 0; index < lock_padding.length; index++) { const el = lock_padding[index]; el.style.paddingRight = "0px"; } body.style.paddingRight = "0px"; document.documentElement.classList.remove("lock"); }), delay); bodyLockStatus = false; setTimeout((function() { bodyLockStatus = true; }), delay); } }; let bodyLock = (delay = 500) => { let body = document.querySelector("body"); if (bodyLockStatus) { let lock_padding = document.querySelectorAll("[data-lp]"); for (let index = 0; index < lock_padding.length; index++) { const el = lock_padding[index]; el.style.paddingRight = window.innerWidth - document.querySelector(".wrapper").offsetWidth + "px"; } body.style.paddingRight = window.innerWidth - document.querySelector(".wrapper").offsetWidth + "px"; document.documentElement.classList.add("lock"); bodyLockStatus = false; setTimeout((function() { bodyLockStatus = true; }), delay); } }; function menuInit() { if (document.querySelector(".icon-menu")) document.addEventListener("click", (function(e) { if (bodyLockStatus && e.target.closest(".icon-menu")) { bodyLockToggle(); document.documentElement.classList.toggle("menu-open"); } })); } function menuClose() { bodyUnlock(); document.documentElement.classList.remove("menu-open"); } function functions_FLS(message) { setTimeout((() => { if (window.FLS) console.log(message); }), 0); } let gotoblock_gotoBlock = (targetBlock, noHeader = false, speed = 500, offsetTop = 0) => { const targetBlockElement = document.querySelector(targetBlock); if (targetBlockElement) { let headerItem = ""; let headerItemHeight = 0; if (noHeader) { headerItem = "header.header"; headerItemHeight = document.querySelector(headerItem).offsetHeight; } let options = { speedAsDuration: true, speed, header: headerItem, offset: offsetTop, easing: "easeOutQuad" }; document.documentElement.classList.contains("menu-open") ? menuClose() : null; if ("undefined" !== typeof SmoothScroll) (new SmoothScroll).animateScroll(targetBlockElement, "", options); else { let targetBlockElementPosition = targetBlockElement.getBoundingClientRect().top + scrollY; targetBlockElementPosition = headerItemHeight ? targetBlockElementPosition - headerItemHeight : targetBlockElementPosition; targetBlockElementPosition = offsetTop ? targetBlockElementPosition - offsetTop : targetBlockElementPosition; window.scrollTo({ top: targetBlockElementPosition, behavior: "smooth" }); } functions_FLS(`[gotoBlock]: Юхуу...едем к ${targetBlock}`); } else functions_FLS(`[gotoBlock]: Ой ой..Такого блока нет на странице: ${targetBlock}`); }; function ssr_window_esm_isObject(obj) { return null !== obj && "object" === typeof obj && "constructor" in obj && obj.constructor === Object; } function extend(target = {}, src = {}) { Object.keys(src).forEach((key => { if ("undefined" === typeof target[key]) target[key] = src[key]; else if (ssr_window_esm_isObject(src[key]) && ssr_window_esm_isObject(target[key]) && Object.keys(src[key]).length > 0) extend(target[key], src[key]); })); } const ssrDocument = { body: {}, addEventListener() {}, removeEventListener() {}, activeElement: { blur() {}, nodeName: "" }, querySelector() { return null; }, querySelectorAll() { return []; }, getElementById() { return null; }, createEvent() { return { initEvent() {} }; }, createElement() { return { children: [], childNodes: [], style: {}, setAttribute() {}, getElementsByTagName() { return []; } }; }, createElementNS() { return {}; }, importNode() { return null; }, location: { hash: "", host: "", hostname: "", href: "", origin: "", pathname: "", protocol: "", search: "" } }; function ssr_window_esm_getDocument() { const doc = "undefined" !== typeof document ? document : {}; extend(doc, ssrDocument); return doc; } const ssrWindow = { document: ssrDocument, navigator: { userAgent: "" }, location: { hash: "", host: "", hostname: "", href: "", origin: "", pathname: "", protocol: "", search: "" }, history: { replaceState() {}, pushState() {}, go() {}, back() {} }, CustomEvent: function CustomEvent() { return this; }, addEventListener() {}, removeEventListener() {}, getComputedStyle() { return { getPropertyValue() { return ""; } }; }, Image() {}, Date() {}, screen: {}, setTimeout() {}, clearTimeout() {}, matchMedia() { return {}; }, requestAnimationFrame(callback) { if ("undefined" === typeof setTimeout) { callback(); return null; } return setTimeout(callback, 0); }, cancelAnimationFrame(id) { if ("undefined" === typeof setTimeout) return; clearTimeout(id); } }; function ssr_window_esm_getWindow() { const win = "undefined" !== typeof window ? window : {}; extend(win, ssrWindow); return win; } function makeReactive(obj) { const proto = obj.__proto__; Object.defineProperty(obj, "__proto__", { get() { return proto; }, set(value) { proto.__proto__ = value; } }); } class Dom7 extends Array { constructor(items) { if ("number" === typeof items) super(items); else { super(...items || []); makeReactive(this); } } } function arrayFlat(arr = []) { const res = []; arr.forEach((el => { if (Array.isArray(el)) res.push(...arrayFlat(el)); else res.push(el); })); return res; } function arrayFilter(arr, callback) { return Array.prototype.filter.call(arr, callback); } function arrayUnique(arr) { const uniqueArray = []; for (let i = 0; i < arr.length; i += 1) if (-1 === uniqueArray.indexOf(arr[i])) uniqueArray.push(arr[i]); return uniqueArray; } function qsa(selector, context) { if ("string" !== typeof selector) return [ selector ]; const a = []; const res = context.querySelectorAll(selector); for (let i = 0; i < res.length; i += 1) a.push(res[i]); return a; } function dom7_esm_$(selector, context) { const window = ssr_window_esm_getWindow(); const document = ssr_window_esm_getDocument(); let arr = []; if (!context && selector instanceof Dom7) return selector; if (!selector) return new Dom7(arr); if ("string" === typeof selector) { const html = selector.trim(); if (html.indexOf("<") >= 0 && html.indexOf(">") >= 0) { let toCreate = "div"; if (0 === html.indexOf(" c.split(" ")))); this.forEach((el => { el.classList.add(...classNames); })); return this; } function removeClass(...classes) { const classNames = arrayFlat(classes.map((c => c.split(" ")))); this.forEach((el => { el.classList.remove(...classNames); })); return this; } function toggleClass(...classes) { const classNames = arrayFlat(classes.map((c => c.split(" ")))); this.forEach((el => { classNames.forEach((className => { el.classList.toggle(className); })); })); } function hasClass(...classes) { const classNames = arrayFlat(classes.map((c => c.split(" ")))); return arrayFilter(this, (el => classNames.filter((className => el.classList.contains(className))).length > 0)).length > 0; } function attr(attrs, value) { if (1 === arguments.length && "string" === typeof attrs) { if (this[0]) return this[0].getAttribute(attrs); return; } for (let i = 0; i < this.length; i += 1) if (2 === arguments.length) this[i].setAttribute(attrs, value); else for (const attrName in attrs) { this[i][attrName] = attrs[attrName]; this[i].setAttribute(attrName, attrs[attrName]); } return this; } function removeAttr(attr) { for (let i = 0; i < this.length; i += 1) this[i].removeAttribute(attr); return this; } function transform(transform) { for (let i = 0; i < this.length; i += 1) this[i].style.transform = transform; return this; } function transition(duration) { for (let i = 0; i < this.length; i += 1) this[i].style.transitionDuration = "string" !== typeof duration ? `${duration}ms` : duration; return this; } function on(...args) { let [eventType, targetSelector, listener, capture] = args; if ("function" === typeof args[1]) { [eventType, listener, capture] = args; targetSelector = void 0; } if (!capture) capture = false; function handleLiveEvent(e) { const target = e.target; if (!target) return; const eventData = e.target.dom7EventData || []; if (eventData.indexOf(e) < 0) eventData.unshift(e); if (dom7_esm_$(target).is(targetSelector)) listener.apply(target, eventData); else { const parents = dom7_esm_$(target).parents(); for (let k = 0; k < parents.length; k += 1) if (dom7_esm_$(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData); } } function handleEvent(e) { const eventData = e && e.target ? e.target.dom7EventData || [] : []; if (eventData.indexOf(e) < 0) eventData.unshift(e); listener.apply(this, eventData); } const events = eventType.split(" "); let j; for (let i = 0; i < this.length; i += 1) { const el = this[i]; if (!targetSelector) for (j = 0; j < events.length; j += 1) { const event = events[j]; if (!el.dom7Listeners) el.dom7Listeners = {}; if (!el.dom7Listeners[event]) el.dom7Listeners[event] = []; el.dom7Listeners[event].push({ listener, proxyListener: handleEvent }); el.addEventListener(event, handleEvent, capture); } else for (j = 0; j < events.length; j += 1) { const event = events[j]; if (!el.dom7LiveListeners) el.dom7LiveListeners = {}; if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = []; el.dom7LiveListeners[event].push({ listener, proxyListener: handleLiveEvent }); el.addEventListener(event, handleLiveEvent, capture); } } return this; } function off(...args) { let [eventType, targetSelector, listener, capture] = args; if ("function" === typeof args[1]) { [eventType, listener, capture] = args; targetSelector = void 0; } if (!capture) capture = false; const events = eventType.split(" "); for (let i = 0; i < events.length; i += 1) { const event = events[i]; for (let j = 0; j < this.length; j += 1) { const el = this[j]; let handlers; if (!targetSelector && el.dom7Listeners) handlers = el.dom7Listeners[event]; else if (targetSelector && el.dom7LiveListeners) handlers = el.dom7LiveListeners[event]; if (handlers && handlers.length) for (let k = handlers.length - 1; k >= 0; k -= 1) { const handler = handlers[k]; if (listener && handler.listener === listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } else if (!listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } } } } return this; } function trigger(...args) { const window = ssr_window_esm_getWindow(); const events = args[0].split(" "); const eventData = args[1]; for (let i = 0; i < events.length; i += 1) { const event = events[i]; for (let j = 0; j < this.length; j += 1) { const el = this[j]; if (window.CustomEvent) { const evt = new window.CustomEvent(event, { detail: eventData, bubbles: true, cancelable: true }); el.dom7EventData = args.filter(((data, dataIndex) => dataIndex > 0)); el.dispatchEvent(evt); el.dom7EventData = []; delete el.dom7EventData; } } } return this; } function transitionEnd(callback) { const dom = this; function fireCallBack(e) { if (e.target !== this) return; callback.call(this, e); dom.off("transitionend", fireCallBack); } if (callback) dom.on("transitionend", fireCallBack); return this; } function dom7_esm_outerWidth(includeMargins) { if (this.length > 0) { if (includeMargins) { const styles = this.styles(); return this[0].offsetWidth + parseFloat(styles.getPropertyValue("margin-right")) + parseFloat(styles.getPropertyValue("margin-left")); } return this[0].offsetWidth; } return null; } function dom7_esm_outerHeight(includeMargins) { if (this.length > 0) { if (includeMargins) { const styles = this.styles(); return this[0].offsetHeight + parseFloat(styles.getPropertyValue("margin-top")) + parseFloat(styles.getPropertyValue("margin-bottom")); } return this[0].offsetHeight; } return null; } function offset() { if (this.length > 0) { const window = ssr_window_esm_getWindow(); const document = ssr_window_esm_getDocument(); const el = this[0]; const box = el.getBoundingClientRect(); const body = document.body; const clientTop = el.clientTop || body.clientTop || 0; const clientLeft = el.clientLeft || body.clientLeft || 0; const scrollTop = el === window ? window.scrollY : el.scrollTop; const scrollLeft = el === window ? window.scrollX : el.scrollLeft; return { top: box.top + scrollTop - clientTop, left: box.left + scrollLeft - clientLeft }; } return null; } function styles() { const window = ssr_window_esm_getWindow(); if (this[0]) return window.getComputedStyle(this[0], null); return {}; } function css(props, value) { const window = ssr_window_esm_getWindow(); let i; if (1 === arguments.length) if ("string" === typeof props) { if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props); } else { for (i = 0; i < this.length; i += 1) for (const prop in props) this[i].style[prop] = props[prop]; return this; } if (2 === arguments.length && "string" === typeof props) { for (i = 0; i < this.length; i += 1) this[i].style[props] = value; return this; } return this; } function each(callback) { if (!callback) return this; this.forEach(((el, index) => { callback.apply(el, [ el, index ]); })); return this; } function filter(callback) { const result = arrayFilter(this, callback); return dom7_esm_$(result); } function html(html) { if ("undefined" === typeof html) return this[0] ? this[0].innerHTML : null; for (let i = 0; i < this.length; i += 1) this[i].innerHTML = html; return this; } function dom7_esm_text(text) { if ("undefined" === typeof text) return this[0] ? this[0].textContent.trim() : null; for (let i = 0; i < this.length; i += 1) this[i].textContent = text; return this; } function is(selector) { const window = ssr_window_esm_getWindow(); const document = ssr_window_esm_getDocument(); const el = this[0]; let compareWith; let i; if (!el || "undefined" === typeof selector) return false; if ("string" === typeof selector) { if (el.matches) return el.matches(selector); if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector); if (el.msMatchesSelector) return el.msMatchesSelector(selector); compareWith = dom7_esm_$(selector); for (i = 0; i < compareWith.length; i += 1) if (compareWith[i] === el) return true; return false; } if (selector === document) return el === document; if (selector === window) return el === window; if (selector.nodeType || selector instanceof Dom7) { compareWith = selector.nodeType ? [ selector ] : selector; for (i = 0; i < compareWith.length; i += 1) if (compareWith[i] === el) return true; return false; } return false; } function index() { let child = this[0]; let i; if (child) { i = 0; while (null !== (child = child.previousSibling)) if (1 === child.nodeType) i += 1; return i; } return; } function eq(index) { if ("undefined" === typeof index) return this; const length = this.length; if (index > length - 1) return dom7_esm_$([]); if (index < 0) { const returnIndex = length + index; if (returnIndex < 0) return dom7_esm_$([]); return dom7_esm_$([ this[returnIndex] ]); } return dom7_esm_$([ this[index] ]); } function append(...els) { let newChild; const document = ssr_window_esm_getDocument(); for (let k = 0; k < els.length; k += 1) { newChild = els[k]; for (let i = 0; i < this.length; i += 1) if ("string" === typeof newChild) { const tempDiv = document.createElement("div"); tempDiv.innerHTML = newChild; while (tempDiv.firstChild) this[i].appendChild(tempDiv.firstChild); } else if (newChild instanceof Dom7) for (let j = 0; j < newChild.length; j += 1) this[i].appendChild(newChild[j]); else this[i].appendChild(newChild); } return this; } function prepend(newChild) { const document = ssr_window_esm_getDocument(); let i; let j; for (i = 0; i < this.length; i += 1) if ("string" === typeof newChild) { const tempDiv = document.createElement("div"); tempDiv.innerHTML = newChild; for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]); } else if (newChild instanceof Dom7) for (j = 0; j < newChild.length; j += 1) this[i].insertBefore(newChild[j], this[i].childNodes[0]); else this[i].insertBefore(newChild, this[i].childNodes[0]); return this; } function next(selector) { if (this.length > 0) { if (selector) { if (this[0].nextElementSibling && dom7_esm_$(this[0].nextElementSibling).is(selector)) return dom7_esm_$([ this[0].nextElementSibling ]); return dom7_esm_$([]); } if (this[0].nextElementSibling) return dom7_esm_$([ this[0].nextElementSibling ]); return dom7_esm_$([]); } return dom7_esm_$([]); } function nextAll(selector) { const nextEls = []; let el = this[0]; if (!el) return dom7_esm_$([]); while (el.nextElementSibling) { const next = el.nextElementSibling; if (selector) { if (dom7_esm_$(next).is(selector)) nextEls.push(next); } else nextEls.push(next); el = next; } return dom7_esm_$(nextEls); } function prev(selector) { if (this.length > 0) { const el = this[0]; if (selector) { if (el.previousElementSibling && dom7_esm_$(el.previousElementSibling).is(selector)) return dom7_esm_$([ el.previousElementSibling ]); return dom7_esm_$([]); } if (el.previousElementSibling) return dom7_esm_$([ el.previousElementSibling ]); return dom7_esm_$([]); } return dom7_esm_$([]); } function prevAll(selector) { const prevEls = []; let el = this[0]; if (!el) return dom7_esm_$([]); while (el.previousElementSibling) { const prev = el.previousElementSibling; if (selector) { if (dom7_esm_$(prev).is(selector)) prevEls.push(prev); } else prevEls.push(prev); el = prev; } return dom7_esm_$(prevEls); } function dom7_esm_parent(selector) { const parents = []; for (let i = 0; i < this.length; i += 1) if (null !== this[i].parentNode) if (selector) { if (dom7_esm_$(this[i].parentNode).is(selector)) parents.push(this[i].parentNode); } else parents.push(this[i].parentNode); return dom7_esm_$(parents); } function parents(selector) { const parents = []; for (let i = 0; i < this.length; i += 1) { let parent = this[i].parentNode; while (parent) { if (selector) { if (dom7_esm_$(parent).is(selector)) parents.push(parent); } else parents.push(parent); parent = parent.parentNode; } } return dom7_esm_$(parents); } function closest(selector) { let closest = this; if ("undefined" === typeof selector) return dom7_esm_$([]); if (!closest.is(selector)) closest = closest.parents(selector).eq(0); return closest; } function find(selector) { const foundElements = []; for (let i = 0; i < this.length; i += 1) { const found = this[i].querySelectorAll(selector); for (let j = 0; j < found.length; j += 1) foundElements.push(found[j]); } return dom7_esm_$(foundElements); } function children(selector) { const children = []; for (let i = 0; i < this.length; i += 1) { const childNodes = this[i].children; for (let j = 0; j < childNodes.length; j += 1) if (!selector || dom7_esm_$(childNodes[j]).is(selector)) children.push(childNodes[j]); } return dom7_esm_$(children); } function remove() { for (let i = 0; i < this.length; i += 1) if (this[i].parentNode) this[i].parentNode.removeChild(this[i]); return this; } const noTrigger = "resize scroll".split(" "); function shortcut(name) { function eventHandler(...args) { if ("undefined" === typeof args[0]) { for (let i = 0; i < this.length; i += 1) if (noTrigger.indexOf(name) < 0) if (name in this[i]) this[i][name](); else dom7_esm_$(this[i]).trigger(name); return this; } return this.on(name, ...args); } return eventHandler; } shortcut("click"); shortcut("blur"); shortcut("focus"); shortcut("focusin"); shortcut("focusout"); shortcut("keyup"); shortcut("keydown"); shortcut("keypress"); shortcut("submit"); shortcut("change"); shortcut("mousedown"); shortcut("mousemove"); shortcut("mouseup"); shortcut("mouseenter"); shortcut("mouseleave"); shortcut("mouseout"); shortcut("mouseover"); shortcut("touchstart"); shortcut("touchend"); shortcut("touchmove"); shortcut("resize"); shortcut("scroll"); const Methods = { addClass, removeClass, hasClass, toggleClass, attr, removeAttr, transform, transition, on, off, trigger, transitionEnd, outerWidth: dom7_esm_outerWidth, outerHeight: dom7_esm_outerHeight, styles, offset, css, each, html, text: dom7_esm_text, is, index, eq, append, prepend, next, nextAll, prev, prevAll, parent: dom7_esm_parent, parents, closest, find, children, filter, remove }; Object.keys(Methods).forEach((methodName => { Object.defineProperty(dom7_esm_$.fn, methodName, { value: Methods[methodName], writable: true }); })); const dom = dom7_esm_$; function deleteProps(obj) { const object = obj; Object.keys(object).forEach((key => { try { object[key] = null; } catch (e) {} try { delete object[key]; } catch (e) {} })); } function utils_nextTick(callback, delay) { if (void 0 === delay) delay = 0; return setTimeout(callback, delay); } function utils_now() { return Date.now(); } function utils_getComputedStyle(el) { const window = ssr_window_esm_getWindow(); let style; if (window.getComputedStyle) style = window.getComputedStyle(el, null); if (!style && el.currentStyle) style = el.currentStyle; if (!style) style = el.style; return style; } function utils_getTranslate(el, axis) { if (void 0 === axis) axis = "x"; const window = ssr_window_esm_getWindow(); let matrix; let curTransform; let transformMatrix; const curStyle = utils_getComputedStyle(el, null); if (window.WebKitCSSMatrix) { curTransform = curStyle.transform || curStyle.webkitTransform; if (curTransform.split(",").length > 6) curTransform = curTransform.split(", ").map((a => a.replace(",", "."))).join(", "); transformMatrix = new window.WebKitCSSMatrix("none" === curTransform ? "" : curTransform); } else { transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue("transform").replace("translate(", "matrix(1, 0, 0, 1,"); matrix = transformMatrix.toString().split(","); } if ("x" === axis) if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; else if (16 === matrix.length) curTransform = parseFloat(matrix[12]); else curTransform = parseFloat(matrix[4]); if ("y" === axis) if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; else if (16 === matrix.length) curTransform = parseFloat(matrix[13]); else curTransform = parseFloat(matrix[5]); return curTransform || 0; } function utils_isObject(o) { return "object" === typeof o && null !== o && o.constructor && "Object" === Object.prototype.toString.call(o).slice(8, -1); } function isNode(node) { if ("undefined" !== typeof window && "undefined" !== typeof window.HTMLElement) return node instanceof HTMLElement; return node && (1 === node.nodeType || 11 === node.nodeType); } function utils_extend() { const to = Object(arguments.length <= 0 ? void 0 : arguments[0]); const noExtend = [ "__proto__", "constructor", "prototype" ]; for (let i = 1; i < arguments.length; i += 1) { const nextSource = i < 0 || arguments.length <= i ? void 0 : arguments[i]; if (void 0 !== nextSource && null !== nextSource && !isNode(nextSource)) { const keysArray = Object.keys(Object(nextSource)).filter((key => noExtend.indexOf(key) < 0)); for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) { const nextKey = keysArray[nextIndex]; const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); if (void 0 !== desc && desc.enumerable) if (utils_isObject(to[nextKey]) && utils_isObject(nextSource[nextKey])) if (nextSource[nextKey].__swiper__) to[nextKey] = nextSource[nextKey]; else utils_extend(to[nextKey], nextSource[nextKey]); else if (!utils_isObject(to[nextKey]) && utils_isObject(nextSource[nextKey])) { to[nextKey] = {}; if (nextSource[nextKey].__swiper__) to[nextKey] = nextSource[nextKey]; else utils_extend(to[nextKey], nextSource[nextKey]); } else to[nextKey] = nextSource[nextKey]; } } } return to; } function utils_setCSSProperty(el, varName, varValue) { el.style.setProperty(varName, varValue); } function animateCSSModeScroll(_ref) { let {swiper, targetPosition, side} = _ref; const window = ssr_window_esm_getWindow(); const startPosition = -swiper.translate; let startTime = null; let time; const duration = swiper.params.speed; swiper.wrapperEl.style.scrollSnapType = "none"; window.cancelAnimationFrame(swiper.cssModeFrameID); const dir = targetPosition > startPosition ? "next" : "prev"; const isOutOfBound = (current, target) => "next" === dir && current >= target || "prev" === dir && current <= target; const animate = () => { time = (new Date).getTime(); if (null === startTime) startTime = time; const progress = Math.max(Math.min((time - startTime) / duration, 1), 0); const easeProgress = .5 - Math.cos(progress * Math.PI) / 2; let currentPosition = startPosition + easeProgress * (targetPosition - startPosition); if (isOutOfBound(currentPosition, targetPosition)) currentPosition = targetPosition; swiper.wrapperEl.scrollTo({ [side]: currentPosition }); if (isOutOfBound(currentPosition, targetPosition)) { swiper.wrapperEl.style.overflow = "hidden"; swiper.wrapperEl.style.scrollSnapType = ""; setTimeout((() => { swiper.wrapperEl.style.overflow = ""; swiper.wrapperEl.scrollTo({ [side]: currentPosition }); })); window.cancelAnimationFrame(swiper.cssModeFrameID); return; } swiper.cssModeFrameID = window.requestAnimationFrame(animate); }; animate(); } let support; function calcSupport() { const window = ssr_window_esm_getWindow(); const document = ssr_window_esm_getDocument(); return { smoothScroll: document.documentElement && "scrollBehavior" in document.documentElement.style, touch: !!("ontouchstart" in window || window.DocumentTouch && document instanceof window.DocumentTouch), passiveListener: function checkPassiveListener() { let supportsPassive = false; try { const opts = Object.defineProperty({}, "passive", { get() { supportsPassive = true; } }); window.addEventListener("testPassiveListener", null, opts); } catch (e) {} return supportsPassive; }(), gestures: function checkGestures() { return "ongesturestart" in window; }() }; } function getSupport() { if (!support) support = calcSupport(); return support; } let deviceCached; function calcDevice(_temp) { let {userAgent} = void 0 === _temp ? {} : _temp; const support = getSupport(); const window = ssr_window_esm_getWindow(); const platform = window.navigator.platform; const ua = userAgent || window.navigator.userAgent; const device = { ios: false, android: false }; const screenWidth = window.screen.width; const screenHeight = window.screen.height; const android = ua.match(/(Android);?[\s\/]+([\d.]+)?/); let ipad = ua.match(/(iPad).*OS\s([\d_]+)/); const ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/); const iphone = !ipad && ua.match(/(iPhone\sOS|iOS)\s([\d_]+)/); const windows = "Win32" === platform; let macos = "MacIntel" === platform; const iPadScreens = [ "1024x1366", "1366x1024", "834x1194", "1194x834", "834x1112", "1112x834", "768x1024", "1024x768", "820x1180", "1180x820", "810x1080", "1080x810" ]; if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) { ipad = ua.match(/(Version)\/([\d.]+)/); if (!ipad) ipad = [ 0, 1, "13_0_0" ]; macos = false; } if (android && !windows) { device.os = "android"; device.android = true; } if (ipad || iphone || ipod) { device.os = "ios"; device.ios = true; } return device; } function getDevice(overrides) { if (void 0 === overrides) overrides = {}; if (!deviceCached) deviceCached = calcDevice(overrides); return deviceCached; } let browser; function calcBrowser() { const window = ssr_window_esm_getWindow(); function isSafari() { const ua = window.navigator.userAgent.toLowerCase(); return ua.indexOf("safari") >= 0 && ua.indexOf("chrome") < 0 && ua.indexOf("android") < 0; } return { isSafari: isSafari(), isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent) }; } function getBrowser() { if (!browser) browser = calcBrowser(); return browser; } function Resize(_ref) { let {swiper, on, emit} = _ref; const window = ssr_window_esm_getWindow(); let observer = null; let animationFrame = null; const resizeHandler = () => { if (!swiper || swiper.destroyed || !swiper.initialized) return; emit("beforeResize"); emit("resize"); }; const createObserver = () => { if (!swiper || swiper.destroyed || !swiper.initialized) return; observer = new ResizeObserver((entries => { animationFrame = window.requestAnimationFrame((() => { const {width, height} = swiper; let newWidth = width; let newHeight = height; entries.forEach((_ref2 => { let {contentBoxSize, contentRect, target} = _ref2; if (target && target !== swiper.el) return; newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize; newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize; })); if (newWidth !== width || newHeight !== height) resizeHandler(); })); })); observer.observe(swiper.el); }; const removeObserver = () => { if (animationFrame) window.cancelAnimationFrame(animationFrame); if (observer && observer.unobserve && swiper.el) { observer.unobserve(swiper.el); observer = null; } }; const orientationChangeHandler = () => { if (!swiper || swiper.destroyed || !swiper.initialized) return; emit("orientationchange"); }; on("init", (() => { if (swiper.params.resizeObserver && "undefined" !== typeof window.ResizeObserver) { createObserver(); return; } window.addEventListener("resize", resizeHandler); window.addEventListener("orientationchange", orientationChangeHandler); })); on("destroy", (() => { removeObserver(); window.removeEventListener("resize", resizeHandler); window.removeEventListener("orientationchange", orientationChangeHandler); })); } function Observer(_ref) { let {swiper, extendParams, on, emit} = _ref; const observers = []; const window = ssr_window_esm_getWindow(); const attach = function(target, options) { if (void 0 === options) options = {}; const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver; const observer = new ObserverFunc((mutations => { if (1 === mutations.length) { emit("observerUpdate", mutations[0]); return; } const observerUpdate = function observerUpdate() { emit("observerUpdate", mutations[0]); }; if (window.requestAnimationFrame) window.requestAnimationFrame(observerUpdate); else window.setTimeout(observerUpdate, 0); })); observer.observe(target, { attributes: "undefined" === typeof options.attributes ? true : options.attributes, childList: "undefined" === typeof options.childList ? true : options.childList, characterData: "undefined" === typeof options.characterData ? true : options.characterData }); observers.push(observer); }; const init = () => { if (!swiper.params.observer) return; if (swiper.params.observeParents) { const containerParents = swiper.$el.parents(); for (let i = 0; i < containerParents.length; i += 1) attach(containerParents[i]); } attach(swiper.$el[0], { childList: swiper.params.observeSlideChildren }); attach(swiper.$wrapperEl[0], { attributes: false }); }; const destroy = () => { observers.forEach((observer => { observer.disconnect(); })); observers.splice(0, observers.length); }; extendParams({ observer: false, observeParents: false, observeSlideChildren: false }); on("init", init); on("destroy", destroy); } const events_emitter = { on(events, handler, priority) { const self = this; if (!self.eventsListeners || self.destroyed) return self; if ("function" !== typeof handler) return self; const method = priority ? "unshift" : "push"; events.split(" ").forEach((event => { if (!self.eventsListeners[event]) self.eventsListeners[event] = []; self.eventsListeners[event][method](handler); })); return self; }, once(events, handler, priority) { const self = this; if (!self.eventsListeners || self.destroyed) return self; if ("function" !== typeof handler) return self; function onceHandler() { self.off(events, onceHandler); if (onceHandler.__emitterProxy) delete onceHandler.__emitterProxy; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) args[_key] = arguments[_key]; handler.apply(self, args); } onceHandler.__emitterProxy = handler; return self.on(events, onceHandler, priority); }, onAny(handler, priority) { const self = this; if (!self.eventsListeners || self.destroyed) return self; if ("function" !== typeof handler) return self; const method = priority ? "unshift" : "push"; if (self.eventsAnyListeners.indexOf(handler) < 0) self.eventsAnyListeners[method](handler); return self; }, offAny(handler) { const self = this; if (!self.eventsListeners || self.destroyed) return self; if (!self.eventsAnyListeners) return self; const index = self.eventsAnyListeners.indexOf(handler); if (index >= 0) self.eventsAnyListeners.splice(index, 1); return self; }, off(events, handler) { const self = this; if (!self.eventsListeners || self.destroyed) return self; if (!self.eventsListeners) return self; events.split(" ").forEach((event => { if ("undefined" === typeof handler) self.eventsListeners[event] = []; else if (self.eventsListeners[event]) self.eventsListeners[event].forEach(((eventHandler, index) => { if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) self.eventsListeners[event].splice(index, 1); })); })); return self; }, emit() { const self = this; if (!self.eventsListeners || self.destroyed) return self; if (!self.eventsListeners) return self; let events; let data; let context; for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) args[_key2] = arguments[_key2]; if ("string" === typeof args[0] || Array.isArray(args[0])) { events = args[0]; data = args.slice(1, args.length); context = self; } else { events = args[0].events; data = args[0].data; context = args[0].context || self; } data.unshift(context); const eventsArray = Array.isArray(events) ? events : events.split(" "); eventsArray.forEach((event => { if (self.eventsAnyListeners && self.eventsAnyListeners.length) self.eventsAnyListeners.forEach((eventHandler => { eventHandler.apply(context, [ event, ...data ]); })); if (self.eventsListeners && self.eventsListeners[event]) self.eventsListeners[event].forEach((eventHandler => { eventHandler.apply(context, data); })); })); return self; } }; function updateSize() { const swiper = this; let width; let height; const $el = swiper.$el; if ("undefined" !== typeof swiper.params.width && null !== swiper.params.width) width = swiper.params.width; else width = $el[0].clientWidth; if ("undefined" !== typeof swiper.params.height && null !== swiper.params.height) height = swiper.params.height; else height = $el[0].clientHeight; if (0 === width && swiper.isHorizontal() || 0 === height && swiper.isVertical()) return; width = width - parseInt($el.css("padding-left") || 0, 10) - parseInt($el.css("padding-right") || 0, 10); height = height - parseInt($el.css("padding-top") || 0, 10) - parseInt($el.css("padding-bottom") || 0, 10); if (Number.isNaN(width)) width = 0; if (Number.isNaN(height)) height = 0; Object.assign(swiper, { width, height, size: swiper.isHorizontal() ? width : height }); } function updateSlides() { const swiper = this; function getDirectionLabel(property) { if (swiper.isHorizontal()) return property; return { width: "height", "margin-top": "margin-left", "margin-bottom ": "margin-right", "margin-left": "margin-top", "margin-right": "margin-bottom", "padding-left": "padding-top", "padding-right": "padding-bottom", marginRight: "marginBottom" }[property]; } function getDirectionPropertyValue(node, label) { return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0); } const params = swiper.params; const {$wrapperEl, size: swiperSize, rtlTranslate: rtl, wrongRTL} = swiper; const isVirtual = swiper.virtual && params.virtual.enabled; const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length; const slides = $wrapperEl.children(`.${swiper.params.slideClass}`); const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length; let snapGrid = []; const slidesGrid = []; const slidesSizesGrid = []; let offsetBefore = params.slidesOffsetBefore; if ("function" === typeof offsetBefore) offsetBefore = params.slidesOffsetBefore.call(swiper); let offsetAfter = params.slidesOffsetAfter; if ("function" === typeof offsetAfter) offsetAfter = params.slidesOffsetAfter.call(swiper); const previousSnapGridLength = swiper.snapGrid.length; const previousSlidesGridLength = swiper.slidesGrid.length; let spaceBetween = params.spaceBetween; let slidePosition = -offsetBefore; let prevSlideSize = 0; let index = 0; if ("undefined" === typeof swiperSize) return; if ("string" === typeof spaceBetween && spaceBetween.indexOf("%") >= 0) spaceBetween = parseFloat(spaceBetween.replace("%", "")) / 100 * swiperSize; swiper.virtualSize = -spaceBetween; if (rtl) slides.css({ marginLeft: "", marginBottom: "", marginTop: "" }); else slides.css({ marginRight: "", marginBottom: "", marginTop: "" }); if (params.centeredSlides && params.cssMode) { utils_setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-before", ""); utils_setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-after", ""); } const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid; if (gridEnabled) swiper.grid.initSlides(slidesLength); let slideSize; const shouldResetSlideSize = "auto" === params.slidesPerView && params.breakpoints && Object.keys(params.breakpoints).filter((key => "undefined" !== typeof params.breakpoints[key].slidesPerView)).length > 0; for (let i = 0; i < slidesLength; i += 1) { slideSize = 0; const slide = slides.eq(i); if (gridEnabled) swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel); if ("none" === slide.css("display")) continue; if ("auto" === params.slidesPerView) { if (shouldResetSlideSize) slides[i].style[getDirectionLabel("width")] = ``; const slideStyles = getComputedStyle(slide[0]); const currentTransform = slide[0].style.transform; const currentWebKitTransform = slide[0].style.webkitTransform; if (currentTransform) slide[0].style.transform = "none"; if (currentWebKitTransform) slide[0].style.webkitTransform = "none"; if (params.roundLengths) slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true); else { const width = getDirectionPropertyValue(slideStyles, "width"); const paddingLeft = getDirectionPropertyValue(slideStyles, "padding-left"); const paddingRight = getDirectionPropertyValue(slideStyles, "padding-right"); const marginLeft = getDirectionPropertyValue(slideStyles, "margin-left"); const marginRight = getDirectionPropertyValue(slideStyles, "margin-right"); const boxSizing = slideStyles.getPropertyValue("box-sizing"); if (boxSizing && "border-box" === boxSizing) slideSize = width + marginLeft + marginRight; else { const {clientWidth, offsetWidth} = slide[0]; slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth); } } if (currentTransform) slide[0].style.transform = currentTransform; if (currentWebKitTransform) slide[0].style.webkitTransform = currentWebKitTransform; if (params.roundLengths) slideSize = Math.floor(slideSize); } else { slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView; if (params.roundLengths) slideSize = Math.floor(slideSize); if (slides[i]) slides[i].style[getDirectionLabel("width")] = `${slideSize}px`; } if (slides[i]) slides[i].swiperSlideSize = slideSize; slidesSizesGrid.push(slideSize); if (params.centeredSlides) { slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween; if (0 === prevSlideSize && 0 !== i) slidePosition = slidePosition - swiperSize / 2 - spaceBetween; if (0 === i) slidePosition = slidePosition - swiperSize / 2 - spaceBetween; if (Math.abs(slidePosition) < 1 / 1e3) slidePosition = 0; if (params.roundLengths) slidePosition = Math.floor(slidePosition); if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition); slidesGrid.push(slidePosition); } else { if (params.roundLengths) slidePosition = Math.floor(slidePosition); if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition); slidesGrid.push(slidePosition); slidePosition = slidePosition + slideSize + spaceBetween; } swiper.virtualSize += slideSize + spaceBetween; prevSlideSize = slideSize; index += 1; } swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter; if (rtl && wrongRTL && ("slide" === params.effect || "coverflow" === params.effect)) $wrapperEl.css({ width: `${swiper.virtualSize + params.spaceBetween}px` }); if (params.setWrapperSize) $wrapperEl.css({ [getDirectionLabel("width")]: `${swiper.virtualSize + params.spaceBetween}px` }); if (gridEnabled) swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel); if (!params.centeredSlides) { const newSlidesGrid = []; for (let i = 0; i < snapGrid.length; i += 1) { let slidesGridItem = snapGrid[i]; if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem); if (snapGrid[i] <= swiper.virtualSize - swiperSize) newSlidesGrid.push(slidesGridItem); } snapGrid = newSlidesGrid; if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) snapGrid.push(swiper.virtualSize - swiperSize); } if (0 === snapGrid.length) snapGrid = [ 0 ]; if (0 !== params.spaceBetween) { const key = swiper.isHorizontal() && rtl ? "marginLeft" : getDirectionLabel("marginRight"); slides.filter(((_, slideIndex) => { if (!params.cssMode) return true; if (slideIndex === slides.length - 1) return false; return true; })).css({ [key]: `${spaceBetween}px` }); } if (params.centeredSlides && params.centeredSlidesBounds) { let allSlidesSize = 0; slidesSizesGrid.forEach((slideSizeValue => { allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0); })); allSlidesSize -= params.spaceBetween; const maxSnap = allSlidesSize - swiperSize; snapGrid = snapGrid.map((snap => { if (snap < 0) return -offsetBefore; if (snap > maxSnap) return maxSnap + offsetAfter; return snap; })); } if (params.centerInsufficientSlides) { let allSlidesSize = 0; slidesSizesGrid.forEach((slideSizeValue => { allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0); })); allSlidesSize -= params.spaceBetween; if (allSlidesSize < swiperSize) { const allSlidesOffset = (swiperSize - allSlidesSize) / 2; snapGrid.forEach(((snap, snapIndex) => { snapGrid[snapIndex] = snap - allSlidesOffset; })); slidesGrid.forEach(((snap, snapIndex) => { slidesGrid[snapIndex] = snap + allSlidesOffset; })); } } Object.assign(swiper, { slides, snapGrid, slidesGrid, slidesSizesGrid }); if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) { utils_setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-before", `${-snapGrid[0]}px`); utils_setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-after", `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`); const addToSnapGrid = -swiper.snapGrid[0]; const addToSlidesGrid = -swiper.slidesGrid[0]; swiper.snapGrid = swiper.snapGrid.map((v => v + addToSnapGrid)); swiper.slidesGrid = swiper.slidesGrid.map((v => v + addToSlidesGrid)); } if (slidesLength !== previousSlidesLength) swiper.emit("slidesLengthChange"); if (snapGrid.length !== previousSnapGridLength) { if (swiper.params.watchOverflow) swiper.checkOverflow(); swiper.emit("snapGridLengthChange"); } if (slidesGrid.length !== previousSlidesGridLength) swiper.emit("slidesGridLengthChange"); if (params.watchSlidesProgress) swiper.updateSlidesOffset(); if (!isVirtual && !params.cssMode && ("slide" === params.effect || "fade" === params.effect)) { const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`; const hasClassBackfaceClassAdded = swiper.$el.hasClass(backFaceHiddenClass); if (slidesLength <= params.maxBackfaceHiddenSlides) { if (!hasClassBackfaceClassAdded) swiper.$el.addClass(backFaceHiddenClass); } else if (hasClassBackfaceClassAdded) swiper.$el.removeClass(backFaceHiddenClass); } } function updateAutoHeight(speed) { const swiper = this; const activeSlides = []; const isVirtual = swiper.virtual && swiper.params.virtual.enabled; let newHeight = 0; let i; if ("number" === typeof speed) swiper.setTransition(speed); else if (true === speed) swiper.setTransition(swiper.params.speed); const getSlideByIndex = index => { if (isVirtual) return swiper.slides.filter((el => parseInt(el.getAttribute("data-swiper-slide-index"), 10) === index))[0]; return swiper.slides.eq(index)[0]; }; if ("auto" !== swiper.params.slidesPerView && swiper.params.slidesPerView > 1) if (swiper.params.centeredSlides) (swiper.visibleSlides || dom([])).each((slide => { activeSlides.push(slide); })); else for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) { const index = swiper.activeIndex + i; if (index > swiper.slides.length && !isVirtual) break; activeSlides.push(getSlideByIndex(index)); } else activeSlides.push(getSlideByIndex(swiper.activeIndex)); for (i = 0; i < activeSlides.length; i += 1) if ("undefined" !== typeof activeSlides[i]) { const height = activeSlides[i].offsetHeight; newHeight = height > newHeight ? height : newHeight; } if (newHeight || 0 === newHeight) swiper.$wrapperEl.css("height", `${newHeight}px`); } function updateSlidesOffset() { const swiper = this; const slides = swiper.slides; for (let i = 0; i < slides.length; i += 1) slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop; } function updateSlidesProgress(translate) { if (void 0 === translate) translate = this && this.translate || 0; const swiper = this; const params = swiper.params; const {slides, rtlTranslate: rtl, snapGrid} = swiper; if (0 === slides.length) return; if ("undefined" === typeof slides[0].swiperSlideOffset) swiper.updateSlidesOffset(); let offsetCenter = -translate; if (rtl) offsetCenter = translate; slides.removeClass(params.slideVisibleClass); swiper.visibleSlidesIndexes = []; swiper.visibleSlides = []; for (let i = 0; i < slides.length; i += 1) { const slide = slides[i]; let slideOffset = slide.swiperSlideOffset; if (params.cssMode && params.centeredSlides) slideOffset -= slides[0].swiperSlideOffset; const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween); const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween); const slideBefore = -(offsetCenter - slideOffset); const slideAfter = slideBefore + swiper.slidesSizesGrid[i]; const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size; if (isVisible) { swiper.visibleSlides.push(slide); swiper.visibleSlidesIndexes.push(i); slides.eq(i).addClass(params.slideVisibleClass); } slide.progress = rtl ? -slideProgress : slideProgress; slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress; } swiper.visibleSlides = dom(swiper.visibleSlides); } function updateProgress(translate) { const swiper = this; if ("undefined" === typeof translate) { const multiplier = swiper.rtlTranslate ? -1 : 1; translate = swiper && swiper.translate && swiper.translate * multiplier || 0; } const params = swiper.params; const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); let {progress, isBeginning, isEnd} = swiper; const wasBeginning = isBeginning; const wasEnd = isEnd; if (0 === translatesDiff) { progress = 0; isBeginning = true; isEnd = true; } else { progress = (translate - swiper.minTranslate()) / translatesDiff; isBeginning = progress <= 0; isEnd = progress >= 1; } Object.assign(swiper, { progress, isBeginning, isEnd }); if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate); if (isBeginning && !wasBeginning) swiper.emit("reachBeginning toEdge"); if (isEnd && !wasEnd) swiper.emit("reachEnd toEdge"); if (wasBeginning && !isBeginning || wasEnd && !isEnd) swiper.emit("fromEdge"); swiper.emit("progress", progress); } function updateSlidesClasses() { const swiper = this; const {slides, params, $wrapperEl, activeIndex, realIndex} = swiper; const isVirtual = swiper.virtual && params.virtual.enabled; slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`); let activeSlide; if (isVirtual) activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index="${activeIndex}"]`); else activeSlide = slides.eq(activeIndex); activeSlide.addClass(params.slideActiveClass); if (params.loop) if (activeSlide.hasClass(params.slideDuplicateClass)) $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index="${realIndex}"]`).addClass(params.slideDuplicateActiveClass); else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${realIndex}"]`).addClass(params.slideDuplicateActiveClass); let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass); if (params.loop && 0 === nextSlide.length) { nextSlide = slides.eq(0); nextSlide.addClass(params.slideNextClass); } let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass); if (params.loop && 0 === prevSlide.length) { prevSlide = slides.eq(-1); prevSlide.addClass(params.slidePrevClass); } if (params.loop) { 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); else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${nextSlide.attr("data-swiper-slide-index")}"]`).addClass(params.slideDuplicateNextClass); 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); else $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${prevSlide.attr("data-swiper-slide-index")}"]`).addClass(params.slideDuplicatePrevClass); } swiper.emitSlidesClasses(); } function updateActiveIndex(newActiveIndex) { const swiper = this; const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate; const {slidesGrid, snapGrid, params, activeIndex: previousIndex, realIndex: previousRealIndex, snapIndex: previousSnapIndex} = swiper; let activeIndex = newActiveIndex; let snapIndex; if ("undefined" === typeof activeIndex) { for (let i = 0; i < slidesGrid.length; i += 1) if ("undefined" !== typeof slidesGrid[i + 1]) { if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) activeIndex = i; else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) activeIndex = i + 1; } else if (translate >= slidesGrid[i]) activeIndex = i; if (params.normalizeSlideIndex) if (activeIndex < 0 || "undefined" === typeof activeIndex) activeIndex = 0; } if (snapGrid.indexOf(translate) >= 0) snapIndex = snapGrid.indexOf(translate); else { const skip = Math.min(params.slidesPerGroupSkip, activeIndex); snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup); } if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1; if (activeIndex === previousIndex) { if (snapIndex !== previousSnapIndex) { swiper.snapIndex = snapIndex; swiper.emit("snapIndexChange"); } return; } const realIndex = parseInt(swiper.slides.eq(activeIndex).attr("data-swiper-slide-index") || activeIndex, 10); Object.assign(swiper, { snapIndex, realIndex, previousIndex, activeIndex }); swiper.emit("activeIndexChange"); swiper.emit("snapIndexChange"); if (previousRealIndex !== realIndex) swiper.emit("realIndexChange"); if (swiper.initialized || swiper.params.runCallbacksOnInit) swiper.emit("slideChange"); } function updateClickedSlide(e) { const swiper = this; const params = swiper.params; const slide = dom(e).closest(`.${params.slideClass}`)[0]; let slideFound = false; let slideIndex; if (slide) for (let i = 0; i < swiper.slides.length; i += 1) if (swiper.slides[i] === slide) { slideFound = true; slideIndex = i; break; } if (slide && slideFound) { swiper.clickedSlide = slide; if (swiper.virtual && swiper.params.virtual.enabled) swiper.clickedIndex = parseInt(dom(slide).attr("data-swiper-slide-index"), 10); else swiper.clickedIndex = slideIndex; } else { swiper.clickedSlide = void 0; swiper.clickedIndex = void 0; return; } if (params.slideToClickedSlide && void 0 !== swiper.clickedIndex && swiper.clickedIndex !== swiper.activeIndex) swiper.slideToClickedSlide(); } const update = { updateSize, updateSlides, updateAutoHeight, updateSlidesOffset, updateSlidesProgress, updateProgress, updateSlidesClasses, updateActiveIndex, updateClickedSlide }; function getSwiperTranslate(axis) { if (void 0 === axis) axis = this.isHorizontal() ? "x" : "y"; const swiper = this; const {params, rtlTranslate: rtl, translate, $wrapperEl} = swiper; if (params.virtualTranslate) return rtl ? -translate : translate; if (params.cssMode) return translate; let currentTranslate = utils_getTranslate($wrapperEl[0], axis); if (rtl) currentTranslate = -currentTranslate; return currentTranslate || 0; } function setTranslate(translate, byController) { const swiper = this; const {rtlTranslate: rtl, params, $wrapperEl, wrapperEl, progress} = swiper; let x = 0; let y = 0; const z = 0; if (swiper.isHorizontal()) x = rtl ? -translate : translate; else y = translate; if (params.roundLengths) { x = Math.floor(x); y = Math.floor(y); } if (params.cssMode) wrapperEl[swiper.isHorizontal() ? "scrollLeft" : "scrollTop"] = swiper.isHorizontal() ? -x : -y; else if (!params.virtualTranslate) $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`); swiper.previousTranslate = swiper.translate; swiper.translate = swiper.isHorizontal() ? x : y; let newProgress; const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); if (0 === translatesDiff) newProgress = 0; else newProgress = (translate - swiper.minTranslate()) / translatesDiff; if (newProgress !== progress) swiper.updateProgress(translate); swiper.emit("setTranslate", swiper.translate, byController); } function minTranslate() { return -this.snapGrid[0]; } function maxTranslate() { return -this.snapGrid[this.snapGrid.length - 1]; } function translateTo(translate, speed, runCallbacks, translateBounds, internal) { if (void 0 === translate) translate = 0; if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; if (void 0 === translateBounds) translateBounds = true; const swiper = this; const {params, wrapperEl} = swiper; if (swiper.animating && params.preventInteractionOnTransition) return false; const minTranslate = swiper.minTranslate(); const maxTranslate = swiper.maxTranslate(); let newTranslate; if (translateBounds && translate > minTranslate) newTranslate = minTranslate; else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate; else newTranslate = translate; swiper.updateProgress(newTranslate); if (params.cssMode) { const isH = swiper.isHorizontal(); if (0 === speed) wrapperEl[isH ? "scrollLeft" : "scrollTop"] = -newTranslate; else { if (!swiper.support.smoothScroll) { animateCSSModeScroll({ swiper, targetPosition: -newTranslate, side: isH ? "left" : "top" }); return true; } wrapperEl.scrollTo({ [isH ? "left" : "top"]: -newTranslate, behavior: "smooth" }); } return true; } if (0 === speed) { swiper.setTransition(0); swiper.setTranslate(newTranslate); if (runCallbacks) { swiper.emit("beforeTransitionStart", speed, internal); swiper.emit("transitionEnd"); } } else { swiper.setTransition(speed); swiper.setTranslate(newTranslate); if (runCallbacks) { swiper.emit("beforeTransitionStart", speed, internal); swiper.emit("transitionStart"); } if (!swiper.animating) { swiper.animating = true; if (!swiper.onTranslateToWrapperTransitionEnd) swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) { if (!swiper || swiper.destroyed) return; if (e.target !== this) return; swiper.$wrapperEl[0].removeEventListener("transitionend", swiper.onTranslateToWrapperTransitionEnd); swiper.$wrapperEl[0].removeEventListener("webkitTransitionEnd", swiper.onTranslateToWrapperTransitionEnd); swiper.onTranslateToWrapperTransitionEnd = null; delete swiper.onTranslateToWrapperTransitionEnd; if (runCallbacks) swiper.emit("transitionEnd"); }; swiper.$wrapperEl[0].addEventListener("transitionend", swiper.onTranslateToWrapperTransitionEnd); swiper.$wrapperEl[0].addEventListener("webkitTransitionEnd", swiper.onTranslateToWrapperTransitionEnd); } } return true; } const translate = { getTranslate: getSwiperTranslate, setTranslate, minTranslate, maxTranslate, translateTo }; function setTransition(duration, byController) { const swiper = this; if (!swiper.params.cssMode) swiper.$wrapperEl.transition(duration); swiper.emit("setTransition", duration, byController); } function transitionEmit(_ref) { let {swiper, runCallbacks, direction, step} = _ref; const {activeIndex, previousIndex} = swiper; let dir = direction; if (!dir) if (activeIndex > previousIndex) dir = "next"; else if (activeIndex < previousIndex) dir = "prev"; else dir = "reset"; swiper.emit(`transition${step}`); if (runCallbacks && activeIndex !== previousIndex) { if ("reset" === dir) { swiper.emit(`slideResetTransition${step}`); return; } swiper.emit(`slideChangeTransition${step}`); if ("next" === dir) swiper.emit(`slideNextTransition${step}`); else swiper.emit(`slidePrevTransition${step}`); } } function transitionStart(runCallbacks, direction) { if (void 0 === runCallbacks) runCallbacks = true; const swiper = this; const {params} = swiper; if (params.cssMode) return; if (params.autoHeight) swiper.updateAutoHeight(); transitionEmit({ swiper, runCallbacks, direction, step: "Start" }); } function transitionEnd_transitionEnd(runCallbacks, direction) { if (void 0 === runCallbacks) runCallbacks = true; const swiper = this; const {params} = swiper; swiper.animating = false; if (params.cssMode) return; swiper.setTransition(0); transitionEmit({ swiper, runCallbacks, direction, step: "End" }); } const core_transition = { setTransition, transitionStart, transitionEnd: transitionEnd_transitionEnd }; function slideTo(index, speed, runCallbacks, internal, initial) { if (void 0 === index) index = 0; if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; if ("number" !== typeof index && "string" !== typeof index) throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`); if ("string" === typeof index) { const indexAsNumber = parseInt(index, 10); const isValidNumber = isFinite(indexAsNumber); if (!isValidNumber) throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`); index = indexAsNumber; } const swiper = this; let slideIndex = index; if (slideIndex < 0) slideIndex = 0; const {params, snapGrid, slidesGrid, previousIndex, activeIndex, rtlTranslate: rtl, wrapperEl, enabled} = swiper; if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) return false; const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex); let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup); if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1; if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) swiper.emit("beforeSlideChangeStart"); const translate = -snapGrid[snapIndex]; swiper.updateProgress(translate); if (params.normalizeSlideIndex) for (let i = 0; i < slidesGrid.length; i += 1) { const normalizedTranslate = -Math.floor(100 * translate); const normalizedGrid = Math.floor(100 * slidesGrid[i]); const normalizedGridNext = Math.floor(100 * slidesGrid[i + 1]); if ("undefined" !== typeof slidesGrid[i + 1]) { if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) slideIndex = i; else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) slideIndex = i + 1; } else if (normalizedTranslate >= normalizedGrid) slideIndex = i; } if (swiper.initialized && slideIndex !== activeIndex) { if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) return false; if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) if ((activeIndex || 0) !== slideIndex) return false; } let direction; if (slideIndex > activeIndex) direction = "next"; else if (slideIndex < activeIndex) direction = "prev"; else direction = "reset"; if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) { swiper.updateActiveIndex(slideIndex); if (params.autoHeight) swiper.updateAutoHeight(); swiper.updateSlidesClasses(); if ("slide" !== params.effect) swiper.setTranslate(translate); if ("reset" !== direction) { swiper.transitionStart(runCallbacks, direction); swiper.transitionEnd(runCallbacks, direction); } return false; } if (params.cssMode) { const isH = swiper.isHorizontal(); const t = rtl ? translate : -translate; if (0 === speed) { const isVirtual = swiper.virtual && swiper.params.virtual.enabled; if (isVirtual) { swiper.wrapperEl.style.scrollSnapType = "none"; swiper._immediateVirtual = true; } wrapperEl[isH ? "scrollLeft" : "scrollTop"] = t; if (isVirtual) requestAnimationFrame((() => { swiper.wrapperEl.style.scrollSnapType = ""; swiper._swiperImmediateVirtual = false; })); } else { if (!swiper.support.smoothScroll) { animateCSSModeScroll({ swiper, targetPosition: t, side: isH ? "left" : "top" }); return true; } wrapperEl.scrollTo({ [isH ? "left" : "top"]: t, behavior: "smooth" }); } return true; } swiper.setTransition(speed); swiper.setTranslate(translate); swiper.updateActiveIndex(slideIndex); swiper.updateSlidesClasses(); swiper.emit("beforeTransitionStart", speed, internal); swiper.transitionStart(runCallbacks, direction); if (0 === speed) swiper.transitionEnd(runCallbacks, direction); else if (!swiper.animating) { swiper.animating = true; if (!swiper.onSlideToWrapperTransitionEnd) swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) { if (!swiper || swiper.destroyed) return; if (e.target !== this) return; swiper.$wrapperEl[0].removeEventListener("transitionend", swiper.onSlideToWrapperTransitionEnd); swiper.$wrapperEl[0].removeEventListener("webkitTransitionEnd", swiper.onSlideToWrapperTransitionEnd); swiper.onSlideToWrapperTransitionEnd = null; delete swiper.onSlideToWrapperTransitionEnd; swiper.transitionEnd(runCallbacks, direction); }; swiper.$wrapperEl[0].addEventListener("transitionend", swiper.onSlideToWrapperTransitionEnd); swiper.$wrapperEl[0].addEventListener("webkitTransitionEnd", swiper.onSlideToWrapperTransitionEnd); } return true; } function slideToLoop(index, speed, runCallbacks, internal) { if (void 0 === index) index = 0; if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; if ("string" === typeof index) { const indexAsNumber = parseInt(index, 10); const isValidNumber = isFinite(indexAsNumber); if (!isValidNumber) throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`); index = indexAsNumber; } const swiper = this; let newIndex = index; if (swiper.params.loop) newIndex += swiper.loopedSlides; return swiper.slideTo(newIndex, speed, runCallbacks, internal); } function slideNext(speed, runCallbacks, internal) { if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; const swiper = this; const {animating, enabled, params} = swiper; if (!enabled) return swiper; let perGroup = params.slidesPerGroup; if ("auto" === params.slidesPerView && 1 === params.slidesPerGroup && params.slidesPerGroupAuto) perGroup = Math.max(swiper.slidesPerViewDynamic("current", true), 1); const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup; if (params.loop) { if (animating && params.loopPreventsSlide) return false; swiper.loopFix(); swiper._clientLeft = swiper.$wrapperEl[0].clientLeft; } if (params.rewind && swiper.isEnd) return swiper.slideTo(0, speed, runCallbacks, internal); return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal); } function slidePrev(speed, runCallbacks, internal) { if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; const swiper = this; const {params, animating, snapGrid, slidesGrid, rtlTranslate, enabled} = swiper; if (!enabled) return swiper; if (params.loop) { if (animating && params.loopPreventsSlide) return false; swiper.loopFix(); swiper._clientLeft = swiper.$wrapperEl[0].clientLeft; } const translate = rtlTranslate ? swiper.translate : -swiper.translate; function normalize(val) { if (val < 0) return -Math.floor(Math.abs(val)); return Math.floor(val); } const normalizedTranslate = normalize(translate); const normalizedSnapGrid = snapGrid.map((val => normalize(val))); let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1]; if ("undefined" === typeof prevSnap && params.cssMode) { let prevSnapIndex; snapGrid.forEach(((snap, snapIndex) => { if (normalizedTranslate >= snap) prevSnapIndex = snapIndex; })); if ("undefined" !== typeof prevSnapIndex) prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex]; } let prevIndex = 0; if ("undefined" !== typeof prevSnap) { prevIndex = slidesGrid.indexOf(prevSnap); if (prevIndex < 0) prevIndex = swiper.activeIndex - 1; if ("auto" === params.slidesPerView && 1 === params.slidesPerGroup && params.slidesPerGroupAuto) { prevIndex = prevIndex - swiper.slidesPerViewDynamic("previous", true) + 1; prevIndex = Math.max(prevIndex, 0); } } if (params.rewind && swiper.isBeginning) { const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1; return swiper.slideTo(lastIndex, speed, runCallbacks, internal); } return swiper.slideTo(prevIndex, speed, runCallbacks, internal); } function slideReset(speed, runCallbacks, internal) { if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; const swiper = this; return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal); } function slideToClosest(speed, runCallbacks, internal, threshold) { if (void 0 === speed) speed = this.params.speed; if (void 0 === runCallbacks) runCallbacks = true; if (void 0 === threshold) threshold = .5; const swiper = this; let index = swiper.activeIndex; const skip = Math.min(swiper.params.slidesPerGroupSkip, index); const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup); const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate; if (translate >= swiper.snapGrid[snapIndex]) { const currentSnap = swiper.snapGrid[snapIndex]; const nextSnap = swiper.snapGrid[snapIndex + 1]; if (translate - currentSnap > (nextSnap - currentSnap) * threshold) index += swiper.params.slidesPerGroup; } else { const prevSnap = swiper.snapGrid[snapIndex - 1]; const currentSnap = swiper.snapGrid[snapIndex]; if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) index -= swiper.params.slidesPerGroup; } index = Math.max(index, 0); index = Math.min(index, swiper.slidesGrid.length - 1); return swiper.slideTo(index, speed, runCallbacks, internal); } function slideToClickedSlide() { const swiper = this; const {params, $wrapperEl} = swiper; const slidesPerView = "auto" === params.slidesPerView ? swiper.slidesPerViewDynamic() : params.slidesPerView; let slideToIndex = swiper.clickedIndex; let realIndex; if (params.loop) { if (swiper.animating) return; realIndex = parseInt(dom(swiper.clickedSlide).attr("data-swiper-slide-index"), 10); if (params.centeredSlides) if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) { swiper.loopFix(); slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`).eq(0).index(); utils_nextTick((() => { swiper.slideTo(slideToIndex); })); } else swiper.slideTo(slideToIndex); else if (slideToIndex > swiper.slides.length - slidesPerView) { swiper.loopFix(); slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`).eq(0).index(); utils_nextTick((() => { swiper.slideTo(slideToIndex); })); } else swiper.slideTo(slideToIndex); } else swiper.slideTo(slideToIndex); } const slide = { slideTo, slideToLoop, slideNext, slidePrev, slideReset, slideToClosest, slideToClickedSlide }; function loopCreate() { const swiper = this; const document = ssr_window_esm_getDocument(); const {params, $wrapperEl} = swiper; const $selector = $wrapperEl.children().length > 0 ? dom($wrapperEl.children()[0].parentNode) : $wrapperEl; $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove(); let slides = $selector.children(`.${params.slideClass}`); if (params.loopFillGroupWithBlank) { const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup; if (blankSlidesNum !== params.slidesPerGroup) { for (let i = 0; i < blankSlidesNum; i += 1) { const blankNode = dom(document.createElement("div")).addClass(`${params.slideClass} ${params.slideBlankClass}`); $selector.append(blankNode); } slides = $selector.children(`.${params.slideClass}`); } } if ("auto" === params.slidesPerView && !params.loopedSlides) params.loopedSlides = slides.length; swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10)); swiper.loopedSlides += params.loopAdditionalSlides; if (swiper.loopedSlides > slides.length) swiper.loopedSlides = slides.length; const prependSlides = []; const appendSlides = []; slides.each(((el, index) => { const slide = dom(el); if (index < swiper.loopedSlides) appendSlides.push(el); if (index < slides.length && index >= slides.length - swiper.loopedSlides) prependSlides.push(el); slide.attr("data-swiper-slide-index", index); })); for (let i = 0; i < appendSlides.length; i += 1) $selector.append(dom(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass)); for (let i = prependSlides.length - 1; i >= 0; i -= 1) $selector.prepend(dom(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass)); } function loopFix() { const swiper = this; swiper.emit("beforeLoopFix"); const {activeIndex, slides, loopedSlides, allowSlidePrev, allowSlideNext, snapGrid, rtlTranslate: rtl} = swiper; let newIndex; swiper.allowSlidePrev = true; swiper.allowSlideNext = true; const snapTranslate = -snapGrid[activeIndex]; const diff = snapTranslate - swiper.getTranslate(); if (activeIndex < loopedSlides) { newIndex = slides.length - 3 * loopedSlides + activeIndex; newIndex += loopedSlides; const slideChanged = swiper.slideTo(newIndex, 0, false, true); if (slideChanged && 0 !== diff) swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff); } else if (activeIndex >= slides.length - loopedSlides) { newIndex = -slides.length + activeIndex + loopedSlides; newIndex += loopedSlides; const slideChanged = swiper.slideTo(newIndex, 0, false, true); if (slideChanged && 0 !== diff) swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff); } swiper.allowSlidePrev = allowSlidePrev; swiper.allowSlideNext = allowSlideNext; swiper.emit("loopFix"); } function loopDestroy() { const swiper = this; const {$wrapperEl, params, slides} = swiper; $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove(); slides.removeAttr("data-swiper-slide-index"); } const loop = { loopCreate, loopFix, loopDestroy }; function setGrabCursor(moving) { const swiper = this; if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return; const el = "container" === swiper.params.touchEventsTarget ? swiper.el : swiper.wrapperEl; el.style.cursor = "move"; el.style.cursor = moving ? "grabbing" : "grab"; } function unsetGrabCursor() { const swiper = this; if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return; swiper["container" === swiper.params.touchEventsTarget ? "el" : "wrapperEl"].style.cursor = ""; } const grab_cursor = { setGrabCursor, unsetGrabCursor }; function closestElement(selector, base) { if (void 0 === base) base = this; function __closestFrom(el) { if (!el || el === ssr_window_esm_getDocument() || el === ssr_window_esm_getWindow()) return null; if (el.assignedSlot) el = el.assignedSlot; const found = el.closest(selector); if (!found && !el.getRootNode) return null; return found || __closestFrom(el.getRootNode().host); } return __closestFrom(base); } function onTouchStart(event) { const swiper = this; const document = ssr_window_esm_getDocument(); const window = ssr_window_esm_getWindow(); const data = swiper.touchEventsData; const {params, touches, enabled} = swiper; if (!enabled) return; if (swiper.animating && params.preventInteractionOnTransition) return; if (!swiper.animating && params.cssMode && params.loop) swiper.loopFix(); let e = event; if (e.originalEvent) e = e.originalEvent; let $targetEl = dom(e.target); if ("wrapper" === params.touchEventsTarget) if (!$targetEl.closest(swiper.wrapperEl).length) return; data.isTouchEvent = "touchstart" === e.type; if (!data.isTouchEvent && "which" in e && 3 === e.which) return; if (!data.isTouchEvent && "button" in e && e.button > 0) return; if (data.isTouched && data.isMoved) return; const swipingClassHasValue = !!params.noSwipingClass && "" !== params.noSwipingClass; if (swipingClassHasValue && e.target && e.target.shadowRoot && event.path && event.path[0]) $targetEl = dom(event.path[0]); const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`; const isTargetShadow = !!(e.target && e.target.shadowRoot); if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, $targetEl[0]) : $targetEl.closest(noSwipingSelector)[0])) { swiper.allowClick = true; return; } if (params.swipeHandler) if (!$targetEl.closest(params.swipeHandler)[0]) return; touches.currentX = "touchstart" === e.type ? e.targetTouches[0].pageX : e.pageX; touches.currentY = "touchstart" === e.type ? e.targetTouches[0].pageY : e.pageY; const startX = touches.currentX; const startY = touches.currentY; const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection; const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold; if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) if ("prevent" === edgeSwipeDetection) event.preventDefault(); else return; Object.assign(data, { isTouched: true, isMoved: false, allowTouchCallbacks: true, isScrolling: void 0, startMoving: void 0 }); touches.startX = startX; touches.startY = startY; data.touchStartTime = utils_now(); swiper.allowClick = true; swiper.updateSize(); swiper.swipeDirection = void 0; if (params.threshold > 0) data.allowThresholdMove = false; if ("touchstart" !== e.type) { let preventDefault = true; if ($targetEl.is(data.focusableElements)) { preventDefault = false; if ("SELECT" === $targetEl[0].nodeName) data.isTouched = false; } if (document.activeElement && dom(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) document.activeElement.blur(); const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault; if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) e.preventDefault(); } if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) swiper.freeMode.onTouchStart(); swiper.emit("touchStart", e); } function onTouchMove(event) { const document = ssr_window_esm_getDocument(); const swiper = this; const data = swiper.touchEventsData; const {params, touches, rtlTranslate: rtl, enabled} = swiper; if (!enabled) return; let e = event; if (e.originalEvent) e = e.originalEvent; if (!data.isTouched) { if (data.startMoving && data.isScrolling) swiper.emit("touchMoveOpposite", e); return; } if (data.isTouchEvent && "touchmove" !== e.type) return; const targetTouch = "touchmove" === e.type && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]); const pageX = "touchmove" === e.type ? targetTouch.pageX : e.pageX; const pageY = "touchmove" === e.type ? targetTouch.pageY : e.pageY; if (e.preventedByNestedSwiper) { touches.startX = pageX; touches.startY = pageY; return; } if (!swiper.allowTouchMove) { if (!dom(e.target).is(data.focusableElements)) swiper.allowClick = false; if (data.isTouched) { Object.assign(touches, { startX: pageX, startY: pageY, currentX: pageX, currentY: pageY }); data.touchStartTime = utils_now(); } return; } if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) if (swiper.isVertical()) { if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) { data.isTouched = false; data.isMoved = false; return; } } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) return; if (data.isTouchEvent && document.activeElement) if (e.target === document.activeElement && dom(e.target).is(data.focusableElements)) { data.isMoved = true; swiper.allowClick = false; return; } if (data.allowTouchCallbacks) swiper.emit("touchMove", e); if (e.targetTouches && e.targetTouches.length > 1) return; touches.currentX = pageX; touches.currentY = pageY; const diffX = touches.currentX - touches.startX; const diffY = touches.currentY - touches.startY; if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return; if ("undefined" === typeof data.isScrolling) { let touchAngle; if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) data.isScrolling = false; else if (diffX * diffX + diffY * diffY >= 25) { touchAngle = 180 * Math.atan2(Math.abs(diffY), Math.abs(diffX)) / Math.PI; data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle; } } if (data.isScrolling) swiper.emit("touchMoveOpposite", e); if ("undefined" === typeof data.startMoving) if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) data.startMoving = true; if (data.isScrolling) { data.isTouched = false; return; } if (!data.startMoving) return; swiper.allowClick = false; if (!params.cssMode && e.cancelable) e.preventDefault(); if (params.touchMoveStopPropagation && !params.nested) e.stopPropagation(); if (!data.isMoved) { if (params.loop && !params.cssMode) swiper.loopFix(); data.startTranslate = swiper.getTranslate(); swiper.setTransition(0); if (swiper.animating) swiper.$wrapperEl.trigger("webkitTransitionEnd transitionend"); data.allowMomentumBounce = false; if (params.grabCursor && (true === swiper.allowSlideNext || true === swiper.allowSlidePrev)) swiper.setGrabCursor(true); swiper.emit("sliderFirstMove", e); } swiper.emit("sliderMove", e); data.isMoved = true; let diff = swiper.isHorizontal() ? diffX : diffY; touches.diff = diff; diff *= params.touchRatio; if (rtl) diff = -diff; swiper.swipeDirection = diff > 0 ? "prev" : "next"; data.currentTranslate = diff + data.startTranslate; let disableParentSwiper = true; let resistanceRatio = params.resistanceRatio; if (params.touchReleaseOnEdges) resistanceRatio = 0; if (diff > 0 && data.currentTranslate > swiper.minTranslate()) { disableParentSwiper = false; if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio; } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) { disableParentSwiper = false; if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio; } if (disableParentSwiper) e.preventedByNestedSwiper = true; if (!swiper.allowSlideNext && "next" === swiper.swipeDirection && data.currentTranslate < data.startTranslate) data.currentTranslate = data.startTranslate; if (!swiper.allowSlidePrev && "prev" === swiper.swipeDirection && data.currentTranslate > data.startTranslate) data.currentTranslate = data.startTranslate; if (!swiper.allowSlidePrev && !swiper.allowSlideNext) data.currentTranslate = data.startTranslate; if (params.threshold > 0) if (Math.abs(diff) > params.threshold || data.allowThresholdMove) { if (!data.allowThresholdMove) { data.allowThresholdMove = true; touches.startX = touches.currentX; touches.startY = touches.currentY; data.currentTranslate = data.startTranslate; touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY; return; } } else { data.currentTranslate = data.startTranslate; return; } if (!params.followFinger || params.cssMode) return; if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) { swiper.updateActiveIndex(); swiper.updateSlidesClasses(); } if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) swiper.freeMode.onTouchMove(); swiper.updateProgress(data.currentTranslate); swiper.setTranslate(data.currentTranslate); } function onTouchEnd(event) { const swiper = this; const data = swiper.touchEventsData; const {params, touches, rtlTranslate: rtl, slidesGrid, enabled} = swiper; if (!enabled) return; let e = event; if (e.originalEvent) e = e.originalEvent; if (data.allowTouchCallbacks) swiper.emit("touchEnd", e); data.allowTouchCallbacks = false; if (!data.isTouched) { if (data.isMoved && params.grabCursor) swiper.setGrabCursor(false); data.isMoved = false; data.startMoving = false; return; } if (params.grabCursor && data.isMoved && data.isTouched && (true === swiper.allowSlideNext || true === swiper.allowSlidePrev)) swiper.setGrabCursor(false); const touchEndTime = utils_now(); const timeDiff = touchEndTime - data.touchStartTime; if (swiper.allowClick) { const pathTree = e.path || e.composedPath && e.composedPath(); swiper.updateClickedSlide(pathTree && pathTree[0] || e.target); swiper.emit("tap click", e); if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) swiper.emit("doubleTap doubleClick", e); } data.lastClickTime = utils_now(); utils_nextTick((() => { if (!swiper.destroyed) swiper.allowClick = true; })); if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || 0 === touches.diff || data.currentTranslate === data.startTranslate) { data.isTouched = false; data.isMoved = false; data.startMoving = false; return; } data.isTouched = false; data.isMoved = false; data.startMoving = false; let currentPos; if (params.followFinger) currentPos = rtl ? swiper.translate : -swiper.translate; else currentPos = -data.currentTranslate; if (params.cssMode) return; if (swiper.params.freeMode && params.freeMode.enabled) { swiper.freeMode.onTouchEnd({ currentPos }); return; } let stopIndex = 0; let groupSize = swiper.slidesSizesGrid[0]; for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) { const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup; if ("undefined" !== typeof slidesGrid[i + increment]) { if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) { stopIndex = i; groupSize = slidesGrid[i + increment] - slidesGrid[i]; } } else if (currentPos >= slidesGrid[i]) { stopIndex = i; groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2]; } } let rewindFirstIndex = null; let rewindLastIndex = null; if (params.rewind) if (swiper.isBeginning) rewindLastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1; else if (swiper.isEnd) rewindFirstIndex = 0; const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize; const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup; if (timeDiff > params.longSwipesMs) { if (!params.longSwipes) { swiper.slideTo(swiper.activeIndex); return; } if ("next" === swiper.swipeDirection) if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment); else swiper.slideTo(stopIndex); if ("prev" === swiper.swipeDirection) if (ratio > 1 - params.longSwipesRatio) swiper.slideTo(stopIndex + increment); else if (null !== rewindLastIndex && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) swiper.slideTo(rewindLastIndex); else swiper.slideTo(stopIndex); } else { if (!params.shortSwipes) { swiper.slideTo(swiper.activeIndex); return; } const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl); if (!isNavButtonTarget) { if ("next" === swiper.swipeDirection) swiper.slideTo(null !== rewindFirstIndex ? rewindFirstIndex : stopIndex + increment); if ("prev" === swiper.swipeDirection) swiper.slideTo(null !== rewindLastIndex ? rewindLastIndex : stopIndex); } else if (e.target === swiper.navigation.nextEl) swiper.slideTo(stopIndex + increment); else swiper.slideTo(stopIndex); } } function onResize() { const swiper = this; const {params, el} = swiper; if (el && 0 === el.offsetWidth) return; if (params.breakpoints) swiper.setBreakpoint(); const {allowSlideNext, allowSlidePrev, snapGrid} = swiper; swiper.allowSlideNext = true; swiper.allowSlidePrev = true; swiper.updateSize(); swiper.updateSlides(); swiper.updateSlidesClasses(); if (("auto" === params.slidesPerView || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) swiper.slideTo(swiper.slides.length - 1, 0, false, true); else swiper.slideTo(swiper.activeIndex, 0, false, true); if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) swiper.autoplay.run(); swiper.allowSlidePrev = allowSlidePrev; swiper.allowSlideNext = allowSlideNext; if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) swiper.checkOverflow(); } function onClick(e) { const swiper = this; if (!swiper.enabled) return; if (!swiper.allowClick) { if (swiper.params.preventClicks) e.preventDefault(); if (swiper.params.preventClicksPropagation && swiper.animating) { e.stopPropagation(); e.stopImmediatePropagation(); } } } function onScroll() { const swiper = this; const {wrapperEl, rtlTranslate, enabled} = swiper; if (!enabled) return; swiper.previousTranslate = swiper.translate; if (swiper.isHorizontal()) swiper.translate = -wrapperEl.scrollLeft; else swiper.translate = -wrapperEl.scrollTop; if (0 === swiper.translate) swiper.translate = 0; swiper.updateActiveIndex(); swiper.updateSlidesClasses(); let newProgress; const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); if (0 === translatesDiff) newProgress = 0; else newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff; if (newProgress !== swiper.progress) swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate); swiper.emit("setTranslate", swiper.translate, false); } let dummyEventAttached = false; function dummyEventListener() {} const events = (swiper, method) => { const document = ssr_window_esm_getDocument(); const {params, touchEvents, el, wrapperEl, device, support} = swiper; const capture = !!params.nested; const domMethod = "on" === method ? "addEventListener" : "removeEventListener"; const swiperMethod = method; if (!support.touch) { el[domMethod](touchEvents.start, swiper.onTouchStart, false); document[domMethod](touchEvents.move, swiper.onTouchMove, capture); document[domMethod](touchEvents.end, swiper.onTouchEnd, false); } else { const passiveListener = "touchstart" === touchEvents.start && support.passiveListener && params.passiveListeners ? { passive: true, capture: false } : false; el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener); el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? { passive: false, capture } : capture); el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener); if (touchEvents.cancel) el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener); } if (params.preventClicks || params.preventClicksPropagation) el[domMethod]("click", swiper.onClick, true); if (params.cssMode) wrapperEl[domMethod]("scroll", swiper.onScroll); if (params.updateOnWindowResize) swiper[swiperMethod](device.ios || device.android ? "resize orientationchange observerUpdate" : "resize observerUpdate", onResize, true); else swiper[swiperMethod]("observerUpdate", onResize, true); }; function attachEvents() { const swiper = this; const document = ssr_window_esm_getDocument(); const {params, support} = swiper; swiper.onTouchStart = onTouchStart.bind(swiper); swiper.onTouchMove = onTouchMove.bind(swiper); swiper.onTouchEnd = onTouchEnd.bind(swiper); if (params.cssMode) swiper.onScroll = onScroll.bind(swiper); swiper.onClick = onClick.bind(swiper); if (support.touch && !dummyEventAttached) { document.addEventListener("touchstart", dummyEventListener); dummyEventAttached = true; } events(swiper, "on"); } function detachEvents() { const swiper = this; events(swiper, "off"); } const core_events = { attachEvents, detachEvents }; const isGridEnabled = (swiper, params) => swiper.grid && params.grid && params.grid.rows > 1; function setBreakpoint() { const swiper = this; const {activeIndex, initialized, loopedSlides = 0, params, $el} = swiper; const breakpoints = params.breakpoints; if (!breakpoints || breakpoints && 0 === Object.keys(breakpoints).length) return; const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el); if (!breakpoint || swiper.currentBreakpoint === breakpoint) return; const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : void 0; const breakpointParams = breakpointOnlyParams || swiper.originalParams; const wasMultiRow = isGridEnabled(swiper, params); const isMultiRow = isGridEnabled(swiper, breakpointParams); const wasEnabled = params.enabled; if (wasMultiRow && !isMultiRow) { $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`); swiper.emitContainerClasses(); } else if (!wasMultiRow && isMultiRow) { $el.addClass(`${params.containerModifierClass}grid`); if (breakpointParams.grid.fill && "column" === breakpointParams.grid.fill || !breakpointParams.grid.fill && "column" === params.grid.fill) $el.addClass(`${params.containerModifierClass}grid-column`); swiper.emitContainerClasses(); } [ "navigation", "pagination", "scrollbar" ].forEach((prop => { const wasModuleEnabled = params[prop] && params[prop].enabled; const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled; if (wasModuleEnabled && !isModuleEnabled) swiper[prop].disable(); if (!wasModuleEnabled && isModuleEnabled) swiper[prop].enable(); })); const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction; const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged); if (directionChanged && initialized) swiper.changeDirection(); utils_extend(swiper.params, breakpointParams); const isEnabled = swiper.params.enabled; Object.assign(swiper, { allowTouchMove: swiper.params.allowTouchMove, allowSlideNext: swiper.params.allowSlideNext, allowSlidePrev: swiper.params.allowSlidePrev }); if (wasEnabled && !isEnabled) swiper.disable(); else if (!wasEnabled && isEnabled) swiper.enable(); swiper.currentBreakpoint = breakpoint; swiper.emit("_beforeBreakpoint", breakpointParams); if (needsReLoop && initialized) { swiper.loopDestroy(); swiper.loopCreate(); swiper.updateSlides(); swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false); } swiper.emit("breakpoint", breakpointParams); } function getBreakpoint(breakpoints, base, containerEl) { if (void 0 === base) base = "window"; if (!breakpoints || "container" === base && !containerEl) return; let breakpoint = false; const window = ssr_window_esm_getWindow(); const currentHeight = "window" === base ? window.innerHeight : containerEl.clientHeight; const points = Object.keys(breakpoints).map((point => { if ("string" === typeof point && 0 === point.indexOf("@")) { const minRatio = parseFloat(point.substr(1)); const value = currentHeight * minRatio; return { value, point }; } return { value: point, point }; })); points.sort(((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10))); for (let i = 0; i < points.length; i += 1) { const {point, value} = points[i]; if ("window" === base) { if (window.matchMedia(`(min-width: ${value}px)`).matches) breakpoint = point; } else if (value <= containerEl.clientWidth) breakpoint = point; } return breakpoint || "max"; } const breakpoints = { setBreakpoint, getBreakpoint }; function prepareClasses(entries, prefix) { const resultClasses = []; entries.forEach((item => { if ("object" === typeof item) Object.keys(item).forEach((classNames => { if (item[classNames]) resultClasses.push(prefix + classNames); })); else if ("string" === typeof item) resultClasses.push(prefix + item); })); return resultClasses; } function addClasses() { const swiper = this; const {classNames, params, rtl, $el, device, support} = swiper; const suffixes = prepareClasses([ "initialized", params.direction, { "pointer-events": !support.touch }, { "free-mode": swiper.params.freeMode && params.freeMode.enabled }, { autoheight: params.autoHeight }, { rtl }, { grid: params.grid && params.grid.rows > 1 }, { "grid-column": params.grid && params.grid.rows > 1 && "column" === params.grid.fill }, { android: device.android }, { ios: device.ios }, { "css-mode": params.cssMode }, { centered: params.cssMode && params.centeredSlides }, { "watch-progress": params.watchSlidesProgress } ], params.containerModifierClass); classNames.push(...suffixes); $el.addClass([ ...classNames ].join(" ")); swiper.emitContainerClasses(); } function removeClasses_removeClasses() { const swiper = this; const {$el, classNames} = swiper; $el.removeClass(classNames.join(" ")); swiper.emitContainerClasses(); } const classes = { addClasses, removeClasses: removeClasses_removeClasses }; function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) { const window = ssr_window_esm_getWindow(); let image; function onReady() { if (callback) callback(); } const isPicture = dom(imageEl).parent("picture")[0]; if (!isPicture && (!imageEl.complete || !checkForComplete)) if (src) { image = new window.Image; image.onload = onReady; image.onerror = onReady; if (sizes) image.sizes = sizes; if (srcset) image.srcset = srcset; if (src) image.src = src; } else onReady(); else onReady(); } function preloadImages() { const swiper = this; swiper.imagesToLoad = swiper.$el.find("img"); function onReady() { if ("undefined" === typeof swiper || null === swiper || !swiper || swiper.destroyed) return; if (void 0 !== swiper.imagesLoaded) swiper.imagesLoaded += 1; if (swiper.imagesLoaded === swiper.imagesToLoad.length) { if (swiper.params.updateOnImagesReady) swiper.update(); swiper.emit("imagesReady"); } } for (let i = 0; i < swiper.imagesToLoad.length; i += 1) { const imageEl = swiper.imagesToLoad[i]; swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute("src"), imageEl.srcset || imageEl.getAttribute("srcset"), imageEl.sizes || imageEl.getAttribute("sizes"), true, onReady); } } const core_images = { loadImage, preloadImages }; function checkOverflow() { const swiper = this; const {isLocked: wasLocked, params} = swiper; const {slidesOffsetBefore} = params; if (slidesOffsetBefore) { const lastSlideIndex = swiper.slides.length - 1; const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + 2 * slidesOffsetBefore; swiper.isLocked = swiper.size > lastSlideRightEdge; } else swiper.isLocked = 1 === swiper.snapGrid.length; if (true === params.allowSlideNext) swiper.allowSlideNext = !swiper.isLocked; if (true === params.allowSlidePrev) swiper.allowSlidePrev = !swiper.isLocked; if (wasLocked && wasLocked !== swiper.isLocked) swiper.isEnd = false; if (wasLocked !== swiper.isLocked) swiper.emit(swiper.isLocked ? "lock" : "unlock"); } const check_overflow = { checkOverflow }; const defaults = { init: true, direction: "horizontal", touchEventsTarget: "wrapper", initialSlide: 0, speed: 300, cssMode: false, updateOnWindowResize: true, resizeObserver: true, nested: false, createElements: false, enabled: true, focusableElements: "input, select, option, textarea, button, video, label", width: null, height: null, preventInteractionOnTransition: false, userAgent: null, url: null, edgeSwipeDetection: false, edgeSwipeThreshold: 20, autoHeight: false, setWrapperSize: false, virtualTranslate: false, effect: "slide", breakpoints: void 0, breakpointsBase: "window", spaceBetween: 0, slidesPerView: 1, slidesPerGroup: 1, slidesPerGroupSkip: 0, slidesPerGroupAuto: false, centeredSlides: false, centeredSlidesBounds: false, slidesOffsetBefore: 0, slidesOffsetAfter: 0, normalizeSlideIndex: true, centerInsufficientSlides: false, watchOverflow: true, roundLengths: false, touchRatio: 1, touchAngle: 45, simulateTouch: true, shortSwipes: true, longSwipes: true, longSwipesRatio: .5, longSwipesMs: 300, followFinger: true, allowTouchMove: true, threshold: 0, touchMoveStopPropagation: false, touchStartPreventDefault: true, touchStartForcePreventDefault: false, touchReleaseOnEdges: false, uniqueNavElements: true, resistance: true, resistanceRatio: .85, watchSlidesProgress: false, grabCursor: false, preventClicks: true, preventClicksPropagation: true, slideToClickedSlide: false, preloadImages: true, updateOnImagesReady: true, loop: false, loopAdditionalSlides: 0, loopedSlides: null, loopFillGroupWithBlank: false, loopPreventsSlide: true, rewind: false, allowSlidePrev: true, allowSlideNext: true, swipeHandler: null, noSwiping: true, noSwipingClass: "swiper-no-swiping", noSwipingSelector: null, passiveListeners: true, maxBackfaceHiddenSlides: 10, containerModifierClass: "swiper-", slideClass: "swiper-slide", slideBlankClass: "swiper-slide-invisible-blank", slideActiveClass: "swiper-slide-active", slideDuplicateActiveClass: "swiper-slide-duplicate-active", slideVisibleClass: "swiper-slide-visible", slideDuplicateClass: "swiper-slide-duplicate", slideNextClass: "swiper-slide-next", slideDuplicateNextClass: "swiper-slide-duplicate-next", slidePrevClass: "swiper-slide-prev", slideDuplicatePrevClass: "swiper-slide-duplicate-prev", wrapperClass: "swiper-wrapper", runCallbacksOnInit: true, _emitClasses: false }; function moduleExtendParams(params, allModulesParams) { return function extendParams(obj) { if (void 0 === obj) obj = {}; const moduleParamName = Object.keys(obj)[0]; const moduleParams = obj[moduleParamName]; if ("object" !== typeof moduleParams || null === moduleParams) { utils_extend(allModulesParams, obj); return; } if ([ "navigation", "pagination", "scrollbar" ].indexOf(moduleParamName) >= 0 && true === params[moduleParamName]) params[moduleParamName] = { auto: true }; if (!(moduleParamName in params && "enabled" in moduleParams)) { utils_extend(allModulesParams, obj); return; } if (true === params[moduleParamName]) params[moduleParamName] = { enabled: true }; if ("object" === typeof params[moduleParamName] && !("enabled" in params[moduleParamName])) params[moduleParamName].enabled = true; if (!params[moduleParamName]) params[moduleParamName] = { enabled: false }; utils_extend(allModulesParams, obj); }; } const prototypes = { eventsEmitter: events_emitter, update, translate, transition: core_transition, slide, loop, grabCursor: grab_cursor, events: core_events, breakpoints, checkOverflow: check_overflow, classes, images: core_images }; const extendedDefaults = {}; class core_Swiper { constructor() { let el; let params; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) args[_key] = arguments[_key]; if (1 === args.length && args[0].constructor && "Object" === Object.prototype.toString.call(args[0]).slice(8, -1)) params = args[0]; else [el, params] = args; if (!params) params = {}; params = utils_extend({}, params); if (el && !params.el) params.el = el; if (params.el && dom(params.el).length > 1) { const swipers = []; dom(params.el).each((containerEl => { const newParams = utils_extend({}, params, { el: containerEl }); swipers.push(new core_Swiper(newParams)); })); return swipers; } const swiper = this; swiper.__swiper__ = true; swiper.support = getSupport(); swiper.device = getDevice({ userAgent: params.userAgent }); swiper.browser = getBrowser(); swiper.eventsListeners = {}; swiper.eventsAnyListeners = []; swiper.modules = [ ...swiper.__modules__ ]; if (params.modules && Array.isArray(params.modules)) swiper.modules.push(...params.modules); const allModulesParams = {}; swiper.modules.forEach((mod => { mod({ swiper, extendParams: moduleExtendParams(params, allModulesParams), on: swiper.on.bind(swiper), once: swiper.once.bind(swiper), off: swiper.off.bind(swiper), emit: swiper.emit.bind(swiper) }); })); const swiperParams = utils_extend({}, defaults, allModulesParams); swiper.params = utils_extend({}, swiperParams, extendedDefaults, params); swiper.originalParams = utils_extend({}, swiper.params); swiper.passedParams = utils_extend({}, params); if (swiper.params && swiper.params.on) Object.keys(swiper.params.on).forEach((eventName => { swiper.on(eventName, swiper.params.on[eventName]); })); if (swiper.params && swiper.params.onAny) swiper.onAny(swiper.params.onAny); swiper.$ = dom; Object.assign(swiper, { enabled: swiper.params.enabled, el, classNames: [], slides: dom(), slidesGrid: [], snapGrid: [], slidesSizesGrid: [], isHorizontal() { return "horizontal" === swiper.params.direction; }, isVertical() { return "vertical" === swiper.params.direction; }, activeIndex: 0, realIndex: 0, isBeginning: true, isEnd: false, translate: 0, previousTranslate: 0, progress: 0, velocity: 0, animating: false, allowSlideNext: swiper.params.allowSlideNext, allowSlidePrev: swiper.params.allowSlidePrev, touchEvents: function touchEvents() { const touch = [ "touchstart", "touchmove", "touchend", "touchcancel" ]; const desktop = [ "pointerdown", "pointermove", "pointerup" ]; swiper.touchEventsTouch = { start: touch[0], move: touch[1], end: touch[2], cancel: touch[3] }; swiper.touchEventsDesktop = { start: desktop[0], move: desktop[1], end: desktop[2] }; return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop; }(), touchEventsData: { isTouched: void 0, isMoved: void 0, allowTouchCallbacks: void 0, touchStartTime: void 0, isScrolling: void 0, currentTranslate: void 0, startTranslate: void 0, allowThresholdMove: void 0, focusableElements: swiper.params.focusableElements, lastClickTime: utils_now(), clickTimeout: void 0, velocities: [], allowMomentumBounce: void 0, isTouchEvent: void 0, startMoving: void 0 }, allowClick: true, allowTouchMove: swiper.params.allowTouchMove, touches: { startX: 0, startY: 0, currentX: 0, currentY: 0, diff: 0 }, imagesToLoad: [], imagesLoaded: 0 }); swiper.emit("_swiper"); if (swiper.params.init) swiper.init(); return swiper; } enable() { const swiper = this; if (swiper.enabled) return; swiper.enabled = true; if (swiper.params.grabCursor) swiper.setGrabCursor(); swiper.emit("enable"); } disable() { const swiper = this; if (!swiper.enabled) return; swiper.enabled = false; if (swiper.params.grabCursor) swiper.unsetGrabCursor(); swiper.emit("disable"); } setProgress(progress, speed) { const swiper = this; progress = Math.min(Math.max(progress, 0), 1); const min = swiper.minTranslate(); const max = swiper.maxTranslate(); const current = (max - min) * progress + min; swiper.translateTo(current, "undefined" === typeof speed ? 0 : speed); swiper.updateActiveIndex(); swiper.updateSlidesClasses(); } emitContainerClasses() { const swiper = this; if (!swiper.params._emitClasses || !swiper.el) return; const cls = swiper.el.className.split(" ").filter((className => 0 === className.indexOf("swiper") || 0 === className.indexOf(swiper.params.containerModifierClass))); swiper.emit("_containerClasses", cls.join(" ")); } getSlideClasses(slideEl) { const swiper = this; if (swiper.destroyed) return ""; return slideEl.className.split(" ").filter((className => 0 === className.indexOf("swiper-slide") || 0 === className.indexOf(swiper.params.slideClass))).join(" "); } emitSlidesClasses() { const swiper = this; if (!swiper.params._emitClasses || !swiper.el) return; const updates = []; swiper.slides.each((slideEl => { const classNames = swiper.getSlideClasses(slideEl); updates.push({ slideEl, classNames }); swiper.emit("_slideClass", slideEl, classNames); })); swiper.emit("_slideClasses", updates); } slidesPerViewDynamic(view, exact) { if (void 0 === view) view = "current"; if (void 0 === exact) exact = false; const swiper = this; const {params, slides, slidesGrid, slidesSizesGrid, size: swiperSize, activeIndex} = swiper; let spv = 1; if (params.centeredSlides) { let slideSize = slides[activeIndex].swiperSlideSize; let breakLoop; for (let i = activeIndex + 1; i < slides.length; i += 1) if (slides[i] && !breakLoop) { slideSize += slides[i].swiperSlideSize; spv += 1; if (slideSize > swiperSize) breakLoop = true; } for (let i = activeIndex - 1; i >= 0; i -= 1) if (slides[i] && !breakLoop) { slideSize += slides[i].swiperSlideSize; spv += 1; if (slideSize > swiperSize) breakLoop = true; } } else if ("current" === view) for (let i = activeIndex + 1; i < slides.length; i += 1) { const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize; if (slideInView) spv += 1; } else for (let i = activeIndex - 1; i >= 0; i -= 1) { const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize; if (slideInView) spv += 1; } return spv; } update() { const swiper = this; if (!swiper || swiper.destroyed) return; const {snapGrid, params} = swiper; if (params.breakpoints) swiper.setBreakpoint(); swiper.updateSize(); swiper.updateSlides(); swiper.updateProgress(); swiper.updateSlidesClasses(); function setTranslate() { const translateValue = swiper.rtlTranslate ? -1 * swiper.translate : swiper.translate; const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate()); swiper.setTranslate(newTranslate); swiper.updateActiveIndex(); swiper.updateSlidesClasses(); } let translated; if (swiper.params.freeMode && swiper.params.freeMode.enabled) { setTranslate(); if (swiper.params.autoHeight) swiper.updateAutoHeight(); } else { if (("auto" === swiper.params.slidesPerView || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true); else translated = swiper.slideTo(swiper.activeIndex, 0, false, true); if (!translated) setTranslate(); } if (params.watchOverflow && snapGrid !== swiper.snapGrid) swiper.checkOverflow(); swiper.emit("update"); } changeDirection(newDirection, needUpdate) { if (void 0 === needUpdate) needUpdate = true; const swiper = this; const currentDirection = swiper.params.direction; if (!newDirection) newDirection = "horizontal" === currentDirection ? "vertical" : "horizontal"; if (newDirection === currentDirection || "horizontal" !== newDirection && "vertical" !== newDirection) return swiper; swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`); swiper.emitContainerClasses(); swiper.params.direction = newDirection; swiper.slides.each((slideEl => { if ("vertical" === newDirection) slideEl.style.width = ""; else slideEl.style.height = ""; })); swiper.emit("changeDirection"); if (needUpdate) swiper.update(); return swiper; } mount(el) { const swiper = this; if (swiper.mounted) return true; const $el = dom(el || swiper.params.el); el = $el[0]; if (!el) return false; el.swiper = swiper; const getWrapperSelector = () => `.${(swiper.params.wrapperClass || "").trim().split(" ").join(".")}`; const getWrapper = () => { if (el && el.shadowRoot && el.shadowRoot.querySelector) { const res = dom(el.shadowRoot.querySelector(getWrapperSelector())); res.children = options => $el.children(options); return res; } if (!$el.children) return dom($el).children(getWrapperSelector()); return $el.children(getWrapperSelector()); }; let $wrapperEl = getWrapper(); if (0 === $wrapperEl.length && swiper.params.createElements) { const document = ssr_window_esm_getDocument(); const wrapper = document.createElement("div"); $wrapperEl = dom(wrapper); wrapper.className = swiper.params.wrapperClass; $el.append(wrapper); $el.children(`.${swiper.params.slideClass}`).each((slideEl => { $wrapperEl.append(slideEl); })); } Object.assign(swiper, { $el, el, $wrapperEl, wrapperEl: $wrapperEl[0], mounted: true, rtl: "rtl" === el.dir.toLowerCase() || "rtl" === $el.css("direction"), rtlTranslate: "horizontal" === swiper.params.direction && ("rtl" === el.dir.toLowerCase() || "rtl" === $el.css("direction")), wrongRTL: "-webkit-box" === $wrapperEl.css("display") }); return true; } init(el) { const swiper = this; if (swiper.initialized) return swiper; const mounted = swiper.mount(el); if (false === mounted) return swiper; swiper.emit("beforeInit"); if (swiper.params.breakpoints) swiper.setBreakpoint(); swiper.addClasses(); if (swiper.params.loop) swiper.loopCreate(); swiper.updateSize(); swiper.updateSlides(); if (swiper.params.watchOverflow) swiper.checkOverflow(); if (swiper.params.grabCursor && swiper.enabled) swiper.setGrabCursor(); if (swiper.params.preloadImages) swiper.preloadImages(); if (swiper.params.loop) swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true); else swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true); swiper.attachEvents(); swiper.initialized = true; swiper.emit("init"); swiper.emit("afterInit"); return swiper; } destroy(deleteInstance, cleanStyles) { if (void 0 === deleteInstance) deleteInstance = true; if (void 0 === cleanStyles) cleanStyles = true; const swiper = this; const {params, $el, $wrapperEl, slides} = swiper; if ("undefined" === typeof swiper.params || swiper.destroyed) return null; swiper.emit("beforeDestroy"); swiper.initialized = false; swiper.detachEvents(); if (params.loop) swiper.loopDestroy(); if (cleanStyles) { swiper.removeClasses(); $el.removeAttr("style"); $wrapperEl.removeAttr("style"); if (slides && slides.length) slides.removeClass([ params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass ].join(" ")).removeAttr("style").removeAttr("data-swiper-slide-index"); } swiper.emit("destroy"); Object.keys(swiper.eventsListeners).forEach((eventName => { swiper.off(eventName); })); if (false !== deleteInstance) { swiper.$el[0].swiper = null; deleteProps(swiper); } swiper.destroyed = true; return null; } static extendDefaults(newDefaults) { utils_extend(extendedDefaults, newDefaults); } static get extendedDefaults() { return extendedDefaults; } static get defaults() { return defaults; } static installModule(mod) { if (!core_Swiper.prototype.__modules__) core_Swiper.prototype.__modules__ = []; const modules = core_Swiper.prototype.__modules__; if ("function" === typeof mod && modules.indexOf(mod) < 0) modules.push(mod); } static use(module) { if (Array.isArray(module)) { module.forEach((m => core_Swiper.installModule(m))); return core_Swiper; } core_Swiper.installModule(module); return core_Swiper; } } Object.keys(prototypes).forEach((prototypeGroup => { Object.keys(prototypes[prototypeGroup]).forEach((protoMethod => { core_Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod]; })); })); core_Swiper.use([ Resize, Observer ]); const core = core_Swiper; function create_element_if_not_defined_createElementIfNotDefined(swiper, originalParams, params, checkProps) { const document = ssr_window_esm_getDocument(); if (swiper.params.createElements) Object.keys(checkProps).forEach((key => { if (!params[key] && true === params.auto) { let element = swiper.$el.children(`.${checkProps[key]}`)[0]; if (!element) { element = document.createElement("div"); element.className = checkProps[key]; swiper.$el.append(element); } params[key] = element; originalParams[key] = element; } })); return params; } function Navigation(_ref) { let {swiper, extendParams, on, emit} = _ref; extendParams({ navigation: { nextEl: null, prevEl: null, hideOnClick: false, disabledClass: "swiper-button-disabled", hiddenClass: "swiper-button-hidden", lockClass: "swiper-button-lock", navigationDisabledClass: "swiper-navigation-disabled" } }); swiper.navigation = { nextEl: null, $nextEl: null, prevEl: null, $prevEl: null }; function getEl(el) { let $el; if (el) { $el = dom(el); if (swiper.params.uniqueNavElements && "string" === typeof el && $el.length > 1 && 1 === swiper.$el.find(el).length) $el = swiper.$el.find(el); } return $el; } function toggleEl($el, disabled) { const params = swiper.params.navigation; if ($el && $el.length > 0) { $el[disabled ? "addClass" : "removeClass"](params.disabledClass); if ($el[0] && "BUTTON" === $el[0].tagName) $el[0].disabled = disabled; if (swiper.params.watchOverflow && swiper.enabled) $el[swiper.isLocked ? "addClass" : "removeClass"](params.lockClass); } } function update() { if (swiper.params.loop) return; const {$nextEl, $prevEl} = swiper.navigation; toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind); toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind); } function onPrevClick(e) { e.preventDefault(); if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return; swiper.slidePrev(); } function onNextClick(e) { e.preventDefault(); if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return; swiper.slideNext(); } function init() { const params = swiper.params.navigation; swiper.params.navigation = create_element_if_not_defined_createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, { nextEl: "swiper-button-next", prevEl: "swiper-button-prev" }); if (!(params.nextEl || params.prevEl)) return; const $nextEl = getEl(params.nextEl); const $prevEl = getEl(params.prevEl); if ($nextEl && $nextEl.length > 0) $nextEl.on("click", onNextClick); if ($prevEl && $prevEl.length > 0) $prevEl.on("click", onPrevClick); Object.assign(swiper.navigation, { $nextEl, nextEl: $nextEl && $nextEl[0], $prevEl, prevEl: $prevEl && $prevEl[0] }); if (!swiper.enabled) { if ($nextEl) $nextEl.addClass(params.lockClass); if ($prevEl) $prevEl.addClass(params.lockClass); } } function destroy() { const {$nextEl, $prevEl} = swiper.navigation; if ($nextEl && $nextEl.length) { $nextEl.off("click", onNextClick); $nextEl.removeClass(swiper.params.navigation.disabledClass); } if ($prevEl && $prevEl.length) { $prevEl.off("click", onPrevClick); $prevEl.removeClass(swiper.params.navigation.disabledClass); } } on("init", (() => { if (false === swiper.params.navigation.enabled) disable(); else { init(); update(); } })); on("toEdge fromEdge lock unlock", (() => { update(); })); on("destroy", (() => { destroy(); })); on("enable disable", (() => { const {$nextEl, $prevEl} = swiper.navigation; if ($nextEl) $nextEl[swiper.enabled ? "removeClass" : "addClass"](swiper.params.navigation.lockClass); if ($prevEl) $prevEl[swiper.enabled ? "removeClass" : "addClass"](swiper.params.navigation.lockClass); })); on("click", ((_s, e) => { const {$nextEl, $prevEl} = swiper.navigation; const targetEl = e.target; if (swiper.params.navigation.hideOnClick && !dom(targetEl).is($prevEl) && !dom(targetEl).is($nextEl)) { if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return; let isHidden; if ($nextEl) isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass); else if ($prevEl) isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass); if (true === isHidden) emit("navigationShow"); else emit("navigationHide"); if ($nextEl) $nextEl.toggleClass(swiper.params.navigation.hiddenClass); if ($prevEl) $prevEl.toggleClass(swiper.params.navigation.hiddenClass); } })); const enable = () => { swiper.$el.removeClass(swiper.params.navigation.navigationDisabledClass); init(); update(); }; const disable = () => { swiper.$el.addClass(swiper.params.navigation.navigationDisabledClass); destroy(); }; Object.assign(swiper.navigation, { enable, disable, update, init, destroy }); } function classes_to_selector_classesToSelector(classes) { if (void 0 === classes) classes = ""; return `.${classes.trim().replace(/([\.:!\/])/g, "\\$1").replace(/ /g, ".")}`; } function Pagination(_ref) { let {swiper, extendParams, on, emit} = _ref; const pfx = "swiper-pagination"; extendParams({ pagination: { el: null, bulletElement: "span", clickable: false, hideOnClick: false, renderBullet: null, renderProgressbar: null, renderFraction: null, renderCustom: null, progressbarOpposite: false, type: "bullets", dynamicBullets: false, dynamicMainBullets: 1, formatFractionCurrent: number => number, formatFractionTotal: number => number, bulletClass: `${pfx}-bullet`, bulletActiveClass: `${pfx}-bullet-active`, modifierClass: `${pfx}-`, currentClass: `${pfx}-current`, totalClass: `${pfx}-total`, hiddenClass: `${pfx}-hidden`, progressbarFillClass: `${pfx}-progressbar-fill`, progressbarOppositeClass: `${pfx}-progressbar-opposite`, clickableClass: `${pfx}-clickable`, lockClass: `${pfx}-lock`, horizontalClass: `${pfx}-horizontal`, verticalClass: `${pfx}-vertical`, paginationDisabledClass: `${pfx}-disabled` } }); swiper.pagination = { el: null, $el: null, bullets: [] }; let bulletSize; let dynamicBulletIndex = 0; function isPaginationDisabled() { return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || 0 === swiper.pagination.$el.length; } function setSideBullets($bulletEl, position) { const {bulletActiveClass} = swiper.params.pagination; $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`); } function update() { const rtl = swiper.rtl; const params = swiper.params.pagination; if (isPaginationDisabled()) return; const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length; const $el = swiper.pagination.$el; let current; const total = swiper.params.loop ? Math.ceil((slidesLength - 2 * swiper.loopedSlides) / swiper.params.slidesPerGroup) : swiper.snapGrid.length; if (swiper.params.loop) { current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup); if (current > slidesLength - 1 - 2 * swiper.loopedSlides) current -= slidesLength - 2 * swiper.loopedSlides; if (current > total - 1) current -= total; if (current < 0 && "bullets" !== swiper.params.paginationType) current = total + current; } else if ("undefined" !== typeof swiper.snapIndex) current = swiper.snapIndex; else current = swiper.activeIndex || 0; if ("bullets" === params.type && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) { const bullets = swiper.pagination.bullets; let firstIndex; let lastIndex; let midIndex; if (params.dynamicBullets) { bulletSize = bullets.eq(0)[swiper.isHorizontal() ? "outerWidth" : "outerHeight"](true); $el.css(swiper.isHorizontal() ? "width" : "height", `${bulletSize * (params.dynamicMainBullets + 4)}px`); if (params.dynamicMainBullets > 1 && void 0 !== swiper.previousIndex) { dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0); if (dynamicBulletIndex > params.dynamicMainBullets - 1) dynamicBulletIndex = params.dynamicMainBullets - 1; else if (dynamicBulletIndex < 0) dynamicBulletIndex = 0; } firstIndex = Math.max(current - dynamicBulletIndex, 0); lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1); midIndex = (lastIndex + firstIndex) / 2; } bullets.removeClass([ "", "-next", "-next-next", "-prev", "-prev-prev", "-main" ].map((suffix => `${params.bulletActiveClass}${suffix}`)).join(" ")); if ($el.length > 1) bullets.each((bullet => { const $bullet = dom(bullet); const bulletIndex = $bullet.index(); if (bulletIndex === current) $bullet.addClass(params.bulletActiveClass); if (params.dynamicBullets) { if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) $bullet.addClass(`${params.bulletActiveClass}-main`); if (bulletIndex === firstIndex) setSideBullets($bullet, "prev"); if (bulletIndex === lastIndex) setSideBullets($bullet, "next"); } })); else { const $bullet = bullets.eq(current); const bulletIndex = $bullet.index(); $bullet.addClass(params.bulletActiveClass); if (params.dynamicBullets) { const $firstDisplayedBullet = bullets.eq(firstIndex); const $lastDisplayedBullet = bullets.eq(lastIndex); for (let i = firstIndex; i <= lastIndex; i += 1) bullets.eq(i).addClass(`${params.bulletActiveClass}-main`); if (swiper.params.loop) if (bulletIndex >= bullets.length) { for (let i = params.dynamicMainBullets; i >= 0; i -= 1) bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`); bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`); } else { setSideBullets($firstDisplayedBullet, "prev"); setSideBullets($lastDisplayedBullet, "next"); } else { setSideBullets($firstDisplayedBullet, "prev"); setSideBullets($lastDisplayedBullet, "next"); } } } if (params.dynamicBullets) { const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4); const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize; const offsetProp = rtl ? "right" : "left"; bullets.css(swiper.isHorizontal() ? offsetProp : "top", `${bulletsOffset}px`); } } if ("fraction" === params.type) { $el.find(classes_to_selector_classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1)); $el.find(classes_to_selector_classesToSelector(params.totalClass)).text(params.formatFractionTotal(total)); } if ("progressbar" === params.type) { let progressbarDirection; if (params.progressbarOpposite) progressbarDirection = swiper.isHorizontal() ? "vertical" : "horizontal"; else progressbarDirection = swiper.isHorizontal() ? "horizontal" : "vertical"; const scale = (current + 1) / total; let scaleX = 1; let scaleY = 1; if ("horizontal" === progressbarDirection) scaleX = scale; else scaleY = scale; $el.find(classes_to_selector_classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed); } if ("custom" === params.type && params.renderCustom) { $el.html(params.renderCustom(swiper, current + 1, total)); emit("paginationRender", $el[0]); } else emit("paginationUpdate", $el[0]); if (swiper.params.watchOverflow && swiper.enabled) $el[swiper.isLocked ? "addClass" : "removeClass"](params.lockClass); } function render() { const params = swiper.params.pagination; if (isPaginationDisabled()) return; const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length; const $el = swiper.pagination.$el; let paginationHTML = ""; if ("bullets" === params.type) { let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - 2 * swiper.loopedSlides) / swiper.params.slidesPerGroup) : swiper.snapGrid.length; if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) numberOfBullets = slidesLength; for (let i = 0; i < numberOfBullets; i += 1) if (params.renderBullet) paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass); else paginationHTML += `<${params.bulletElement} class="${params.bulletClass}">`; $el.html(paginationHTML); swiper.pagination.bullets = $el.find(classes_to_selector_classesToSelector(params.bulletClass)); } if ("fraction" === params.type) { if (params.renderFraction) paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass); else paginationHTML = `` + " / " + ``; $el.html(paginationHTML); } if ("progressbar" === params.type) { if (params.renderProgressbar) paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass); else paginationHTML = ``; $el.html(paginationHTML); } if ("custom" !== params.type) emit("paginationRender", swiper.pagination.$el[0]); } function init() { swiper.params.pagination = create_element_if_not_defined_createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, { el: "swiper-pagination" }); const params = swiper.params.pagination; if (!params.el) return; let $el = dom(params.el); if (0 === $el.length) return; if (swiper.params.uniqueNavElements && "string" === typeof params.el && $el.length > 1) { $el = swiper.$el.find(params.el); if ($el.length > 1) $el = $el.filter((el => { if (dom(el).parents(".swiper")[0] !== swiper.el) return false; return true; })); } if ("bullets" === params.type && params.clickable) $el.addClass(params.clickableClass); $el.addClass(params.modifierClass + params.type); $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass); if ("bullets" === params.type && params.dynamicBullets) { $el.addClass(`${params.modifierClass}${params.type}-dynamic`); dynamicBulletIndex = 0; if (params.dynamicMainBullets < 1) params.dynamicMainBullets = 1; } if ("progressbar" === params.type && params.progressbarOpposite) $el.addClass(params.progressbarOppositeClass); if (params.clickable) $el.on("click", classes_to_selector_classesToSelector(params.bulletClass), (function onClick(e) { e.preventDefault(); let index = dom(this).index() * swiper.params.slidesPerGroup; if (swiper.params.loop) index += swiper.loopedSlides; swiper.slideTo(index); })); Object.assign(swiper.pagination, { $el, el: $el[0] }); if (!swiper.enabled) $el.addClass(params.lockClass); } function destroy() { const params = swiper.params.pagination; if (isPaginationDisabled()) return; const $el = swiper.pagination.$el; $el.removeClass(params.hiddenClass); $el.removeClass(params.modifierClass + params.type); $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass); if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass); if (params.clickable) $el.off("click", classes_to_selector_classesToSelector(params.bulletClass)); } on("init", (() => { if (false === swiper.params.pagination.enabled) disable(); else { init(); render(); update(); } })); on("activeIndexChange", (() => { if (swiper.params.loop) update(); else if ("undefined" === typeof swiper.snapIndex) update(); })); on("snapIndexChange", (() => { if (!swiper.params.loop) update(); })); on("slidesLengthChange", (() => { if (swiper.params.loop) { render(); update(); } })); on("snapGridLengthChange", (() => { if (!swiper.params.loop) { render(); update(); } })); on("destroy", (() => { destroy(); })); on("enable disable", (() => { const {$el} = swiper.pagination; if ($el) $el[swiper.enabled ? "removeClass" : "addClass"](swiper.params.pagination.lockClass); })); on("lock unlock", (() => { update(); })); on("click", ((_s, e) => { const targetEl = e.target; const {$el} = swiper.pagination; if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el.length > 0 && !dom(targetEl).hasClass(swiper.params.pagination.bulletClass)) { if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return; const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass); if (true === isHidden) emit("paginationShow"); else emit("paginationHide"); $el.toggleClass(swiper.params.pagination.hiddenClass); } })); const enable = () => { swiper.$el.removeClass(swiper.params.pagination.paginationDisabledClass); if (swiper.pagination.$el) swiper.pagination.$el.removeClass(swiper.params.pagination.paginationDisabledClass); init(); render(); update(); }; const disable = () => { swiper.$el.addClass(swiper.params.pagination.paginationDisabledClass); if (swiper.pagination.$el) swiper.pagination.$el.addClass(swiper.params.pagination.paginationDisabledClass); destroy(); }; Object.assign(swiper.pagination, { enable, disable, render, update, init, destroy }); } function initSliders() { if (document.querySelector(".about__slider")) new core(".about__slider", { modules: [ Navigation ], observer: true, observeParents: true, slidesPerView: 4, spaceBetween: 0, autoHeight: true, speed: 800, breakpoints: { 320: { slidesPerView: 1.5, spaceBetween: 4, autoHeight: true }, 560: { slidesPerView: 3 }, 768: { slidesPerView: 4, spaceBetween: 4 } }, on: {} }); if (document.querySelector(".team__slider")) new core(".team__slider", { modules: [ Navigation ], observer: true, observeParents: true, slidesPerView: 3, spaceBetween: 16, autoHeight: true, speed: 800, breakpoints: { 320: { slidesPerView: 1.5, spaceBetween: 16, autoHeight: true }, 560: { slidesPerView: 3 }, 768: { slidesPerView: 3, spaceBetween: 16 } }, on: {} }); if (document.querySelector(".crypto__slider")) new core(".crypto__slider", { modules: [ Navigation ], observer: true, observeParents: true, slidesPerView: 4, spaceBetween: 8, autoHeight: true, speed: 800, breakpoints: { 320: { slidesPerView: 1.5, spaceBetween: 4, autoHeight: true }, 560: { slidesPerView: 3 }, 768: { slidesPerView: 4, spaceBetween: 4 } }, on: {} }); if (document.querySelector(".virtual__slider")) new core(".virtual__slider", { modules: [ Navigation ], observer: true, observeParents: true, slidesPerView: 2, spaceBetween: 8, autoHeight: true, speed: 800, breakpoints: { 320: { slidesPerView: 1.5, spaceBetween: 8, autoHeight: true }, 768: { slidesPerView: 2, spaceBetween: 8 } }, on: {} }); if (document.querySelector(".data__slider")) new core(".data__slider", { modules: [ Navigation ], observer: true, observeParents: true, slidesPerView: 3, spaceBetween: 16, autoHeight: true, speed: 800, breakpoints: { 320: { slidesPerView: 1.5, spaceBetween: 16, autoHeight: true }, 560: { slidesPerView: 3 }, 768: { slidesPerView: 3, spaceBetween: 16 } }, on: {} }); if (document.querySelector(".projects__slider")) new core(".projects__slider", { modules: [ Navigation, Pagination ], observer: true, observeParents: true, slidesPerView: 1, spaceBetween: 16, speed: 800, pagination: { el: ".swiper-pagination", type: "bullets", clickable: true } }); } window.addEventListener("load", (function(e) { initSliders(); })); let addWindowScrollEvent = false; function pageNavigation() { document.addEventListener("click", pageNavigationAction); document.addEventListener("watcherCallback", pageNavigationAction); function pageNavigationAction(e) { if ("click" === e.type) { const targetElement = e.target; if (targetElement.closest("[data-goto]")) { const gotoLink = targetElement.closest("[data-goto]"); const gotoLinkSelector = gotoLink.dataset.goto ? gotoLink.dataset.goto : ""; const noHeader = gotoLink.hasAttribute("data-goto-header") ? true : false; const gotoSpeed = gotoLink.dataset.gotoSpeed ? gotoLink.dataset.gotoSpeed : 500; const offsetTop = gotoLink.dataset.gotoTop ? parseInt(gotoLink.dataset.gotoTop) : 0; gotoblock_gotoBlock(gotoLinkSelector, noHeader, gotoSpeed, offsetTop); e.preventDefault(); } } else if ("watcherCallback" === e.type && e.detail) { const entry = e.detail.entry; const targetElement = entry.target; if ("navigator" === targetElement.dataset.watch) { document.querySelector(`[data-goto]._navigator-active`); let navigatorCurrentItem; if (targetElement.id && document.querySelector(`[data-goto="#${targetElement.id}"]`)) navigatorCurrentItem = document.querySelector(`[data-goto="#${targetElement.id}"]`); else if (targetElement.classList.length) for (let index = 0; index < targetElement.classList.length; index++) { const element = targetElement.classList[index]; if (document.querySelector(`[data-goto=".${element}"]`)) { navigatorCurrentItem = document.querySelector(`[data-goto=".${element}"]`); break; } } if (entry.isIntersecting) navigatorCurrentItem ? navigatorCurrentItem.classList.add("_navigator-active") : null; else navigatorCurrentItem ? navigatorCurrentItem.classList.remove("_navigator-active") : null; } } } if (getHash()) { let goToHash; if (document.querySelector(`#${getHash()}`)) goToHash = `#${getHash()}`; else if (document.querySelector(`.${getHash()}`)) goToHash = `.${getHash()}`; goToHash ? gotoblock_gotoBlock(goToHash, true, 500, 20) : null; } } function headerScroll() { addWindowScrollEvent = true; const header = document.querySelector("header.header"); const headerShow = header.hasAttribute("data-scroll-show"); const headerShowTimer = header.dataset.scrollShow ? header.dataset.scrollShow : 500; const startPoint = header.dataset.scroll ? header.dataset.scroll : 1; let scrollDirection = 0; let timer; document.addEventListener("windowScroll", (function(e) { const scrollTop = window.scrollY; clearTimeout(timer); if (scrollTop >= startPoint) { !header.classList.contains("_header-scroll") ? header.classList.add("_header-scroll") : null; if (headerShow) { if (scrollTop > scrollDirection) header.classList.contains("_header-show") ? header.classList.remove("_header-show") : null; else !header.classList.contains("_header-show") ? header.classList.add("_header-show") : null; timer = setTimeout((() => { !header.classList.contains("_header-show") ? header.classList.add("_header-show") : null; }), headerShowTimer); } } else { header.classList.contains("_header-scroll") ? header.classList.remove("_header-scroll") : null; if (headerShow) header.classList.contains("_header-show") ? header.classList.remove("_header-show") : null; } scrollDirection = scrollTop <= 0 ? 0 : scrollTop; })); } setTimeout((() => { if (addWindowScrollEvent) { let windowScroll = new Event("windowScroll"); window.addEventListener("scroll", (function(e) { document.dispatchEvent(windowScroll); })); } }), 0); const animItems = document.querySelectorAll("._anim-items"); if (animItems.length > 0) { window.addEventListener("scroll", animOnScroll); function animOnScroll() { for (let index = 0; index < animItems.length; index++) { const animItem = animItems[index]; const animItemHeight = animItem.offsetHeight; const animItemOffset = offset(animItem).top; const animStart = 4; let animItemPoint = window.innerHeight - animItemHeight / animStart; if (animItemHeight > window.innerHeight) animItemPoint = window.innerHeight - window.innerHeight / animStart; if (pageYOffset > animItemOffset - animItemPoint && pageYOffset < animItemOffset + animItemHeight) animItem.classList.add("_active"); else if (!animItem.classList.contains("_anim-no-hide")) animItem.classList.remove("_active"); } } function offset(el) { const rect = el.getBoundingClientRect(), scrollLeft = window.pageXOffset || document.documentElement.scrollLeft, scrollTop = window.pageYOffset || document.documentElement.scrollTop; return { top: rect.top + scrollTop, left: rect.left + scrollLeft }; } setTimeout((() => { animOnScroll(); }), 300); } window["FLS"] = true; isWebp(); addTouchClass(); menuInit(); pageNavigation(); headerScroll(); })();