!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("@popperjs/core")):"function"==typeof define&&define.amd?define(["@popperjs/core"],e):(t=t||self).tippy=e(t.Popper)}(this,function(t){"use strict";var e="undefined"!=typeof window&&"undefined"!=typeof document,n=e?navigator.userAgent:"",i=/MSIE |Trident\//.test(n),r="tippy-box",o="tippy-content",a="tippy-backdrop",s="tippy-arrow",p="tippy-svg-arrow",c={passive:!0,capture:!0};function u(t,e,n){if(Array.isArray(t)){var i=t[e];return null==i?Array.isArray(n)?n[e]:n:i}return t}function l(t,e){var n={}.toString.call(t);return 0===n.indexOf("[object")&&n.indexOf(e+"]")>-1}function f(t,e){return"function"==typeof t?t.apply(void 0,e):t}function d(t,e){return 0===e?t:function(i){clearTimeout(n),n=setTimeout(function(){t(i)},e)};var n}function v(t,e){var n=Object.assign({},t);return e.forEach(function(t){delete n[t]}),n}function m(t){return[].concat(t)}function h(t,e){-1===t.indexOf(e)&&t.push(e)}function g(t){return t.split("-")[0]}function y(t){return[].slice.call(t)}function b(){return document.createElement("div")}function w(t){return["Element","Fragment"].some(function(e){return l(t,e)})}function x(t){return l(t,"MouseEvent")}function E(t){return!(!t||!t._tippy||t._tippy.reference!==t)}function T(t){return w(t)?[t]:function(t){return l(t,"NodeList")}(t)?y(t):Array.isArray(t)?t:y(document.querySelectorAll(t))}function O(t,e){t.forEach(function(t){t&&(t.style.transitionDuration=e+"ms")})}function C(t,e){t.forEach(function(t){t&&t.setAttribute("data-state",e)})}function A(t){var e,n=m(t)[0];return(null==n?void 0:null==(e=n.ownerDocument)?void 0:e.body)?n.ownerDocument:document}function j(t,e,n){var i=e+"EventListener";["transitionend","webkitTransitionEnd"].forEach(function(e){t[i](e,n)})}var L,D={isTouch:!1},k=0;function S(){D.isTouch||(D.isTouch=!0,window.performance&&document.addEventListener("mousemove",M))}function M(){var t=performance.now();t-k<20&&(D.isTouch=!1,document.removeEventListener("mousemove",M)),k=t}function P(){var t=document.activeElement;if(E(t)){var e=t._tippy;t.blur&&!e.state.isVisible&&t.blur()}}function R(t){return[t+"() was called on a"+("destroy"===t?"n already-":" ")+"destroyed instance. This is a no-op but","indicates a potential memory leak."].join(" ")}function I(t){return t.replace(/[ \t]{2,}/g," ").replace(/^[ \t]*/gm,"").trim()}function V(t){return I("\n  %ctippy.js\n\n  %c"+I(t)+"\n\n  %c👷‍ This is a development-only message. It will be removed in production.\n  ")}function N(t){return[V(t),"color: #00C584; font-size: 1.3em; font-weight: bold;","line-height: 1.5","color: #a6a095;"]}function B(t,e){var n;t&&!L.has(e)&&(L.add(e),(n=console).warn.apply(n,N(e)))}function H(t,e){var n;t&&!L.has(e)&&(L.add(e),(n=console).error.apply(n,N(e)))}L=new Set;var U={animateFill:!1,followCursor:!1,inlinePositioning:!1,sticky:!1},F=Object.assign({appendTo:function(){return document.body},aria:{content:"auto",expanded:"auto"},delay:0,duration:[300,250],getReferenceClientRect:null,hideOnClick:!0,ignoreAttributes:!1,interactive:!1,interactiveBorder:2,interactiveDebounce:0,moveTransition:"",offset:[0,10],onAfterUpdate:function(){},onBeforeUpdate:function(){},onCreate:function(){},onDestroy:function(){},onHidden:function(){},onHide:function(){},onMount:function(){},onShow:function(){},onShown:function(){},onTrigger:function(){},onUntrigger:function(){},onClickOutside:function(){},placement:"top",plugins:[],popperOptions:{},render:null,showOnCreate:!1,touch:!0,trigger:"mouseenter focus",triggerTarget:null},U,{},{allowHTML:!1,animation:"fade",arrow:!0,content:"",inertia:!1,maxWidth:350,role:"tooltip",theme:"",zIndex:9999}),Y=Object.keys(F);function z(t){var e=(t.plugins||[]).reduce(function(e,n){var i=n.name,r=n.defaultValue;return i&&(e[i]=void 0!==t[i]?t[i]:r),e},{});return Object.assign({},t,{},e)}function W(t,e){var n=Object.assign({},e,{content:f(e.content,[t])},e.ignoreAttributes?{}:function(t,e){return(e?Object.keys(z(Object.assign({},F,{plugins:e}))):Y).reduce(function(e,n){var i=(t.getAttribute("data-tippy-"+n)||"").trim();if(!i)return e;if("content"===n)e[n]=i;else try{e[n]=JSON.parse(i)}catch(t){e[n]=i}return e},{})}(t,e.plugins));return n.aria=Object.assign({},F.aria,{},n.aria),n.aria={expanded:"auto"===n.aria.expanded?e.interactive:n.aria.expanded,content:"auto"===n.aria.content?e.interactive?null:"describedby":n.aria.content},n}function _(t,e){void 0===t&&(t={}),void 0===e&&(e=[]),Object.keys(t).forEach(function(t){var n,i,r=v(F,Object.keys(U)),o=(n=r,i=t,!{}.hasOwnProperty.call(n,i));o&&(o=0===e.filter(function(e){return e.name===t}).length),B(o,["`"+t+"`","is not a valid prop. You may have spelled it incorrectly, or if it's","a plugin, forgot to pass it in an array as props.plugins.","\n\n","All props: https://atomiks.github.io/tippyjs/v6/all-props/\n","Plugins: https://atomiks.github.io/tippyjs/v6/plugins/"].join(" "))})}var q=function(){return"innerHTML"};function X(t,e){t[q()]=e}function $(t){var e=b();return!0===t?e.className=s:(e.className=p,w(t)?e.appendChild(t):X(e,t)),e}function J(t,e){w(e.content)?(X(t,""),t.appendChild(e.content)):"function"!=typeof e.content&&(e.allowHTML?X(t,e.content):t.textContent=e.content)}function G(t){var e=t.firstElementChild,n=y(e.children);return{box:e,content:n.find(function(t){return t.classList.contains(o)}),arrow:n.find(function(t){return t.classList.contains(s)||t.classList.contains(p)}),backdrop:n.find(function(t){return t.classList.contains(a)})}}function K(t){var e=b(),n=b();n.className=r,n.setAttribute("data-state","hidden"),n.setAttribute("tabindex","-1");var i=b();function a(n,i){var r=G(e),o=r.box,a=r.content,s=r.arrow;i.theme?o.setAttribute("data-theme",i.theme):o.removeAttribute("data-theme"),"string"==typeof i.animation?o.setAttribute("data-animation",i.animation):o.removeAttribute("data-animation"),i.inertia?o.setAttribute("data-inertia",""):o.removeAttribute("data-inertia"),o.style.maxWidth="number"==typeof i.maxWidth?i.maxWidth+"px":i.maxWidth,i.role?o.setAttribute("role",i.role):o.removeAttribute("role"),n.content===i.content&&n.allowHTML===i.allowHTML||J(a,t.props),i.arrow?s?n.arrow!==i.arrow&&(o.removeChild(s),o.appendChild($(i.arrow))):o.appendChild($(i.arrow)):s&&o.removeChild(s)}return i.className=o,i.setAttribute("data-state","hidden"),J(i,t.props),e.appendChild(n),n.appendChild(i),a(t.props,t.props),{popper:e,onUpdate:a}}K.$$tippy=!0;var Q=1,Z=[],tt=[];function et(e,n){var r,o,a,s,p,l,v,w,E,T=W(e,Object.assign({},F,{},z((r=n,Object.keys(r).reduce(function(t,e){return void 0!==r[e]&&(t[e]=r[e]),t},{}))))),L=!1,k=!1,S=!1,M=!1,P=[],I=d(xt,T.interactiveDebounce),V=Q++,N=(E=T.plugins).filter(function(t,e){return E.indexOf(t)===e}),U={id:V,reference:e,popper:b(),popperInstance:null,props:T,state:{isEnabled:!0,isVisible:!1,isDestroyed:!1,isMounted:!1,isShown:!1},plugins:N,clearDelayTimeouts:function(){clearTimeout(o),clearTimeout(a),cancelAnimationFrame(s)},setProps:function(t){if(B(U.state.isDestroyed,R("setProps")),U.state.isDestroyed)return;st("onBeforeUpdate",[U,t]),bt();var n=U.props,i=W(e,Object.assign({},U.props,{},t,{ignoreAttributes:!0}));U.props=i,yt(),n.interactiveDebounce!==i.interactiveDebounce&&(ut(),I=d(xt,i.interactiveDebounce));n.triggerTarget&&!i.triggerTarget?m(n.triggerTarget).forEach(function(t){t.removeAttribute("aria-expanded")}):i.triggerTarget&&e.removeAttribute("aria-expanded");ct(),at(),q&&q(n,i);U.popperInstance&&(Ct(),jt().forEach(function(t){requestAnimationFrame(t._tippy.popperInstance.forceUpdate)}));st("onAfterUpdate",[U,t])},setContent:function(t){U.setProps({content:t})},show:function(){B(U.state.isDestroyed,R("show"));var t=U.state.isVisible,e=U.state.isDestroyed,n=!U.state.isEnabled,i=D.isTouch&&!U.props.touch,r=u(U.props.duration,0,F.duration);if(t||e||n||i)return;if(nt().hasAttribute("disabled"))return;if(st("onShow",[U],!1),!1===U.props.onShow(U))return;U.state.isVisible=!0,et()&&(_.style.visibility="visible");at(),vt(),U.state.isMounted||(_.style.transition="none");if(et()){var o=rt(),a=o.box,s=o.content;O([a,s],0)}v=function(){var t;if(U.state.isVisible&&!M){if(M=!0,_.offsetHeight,_.style.transition=U.props.moveTransition,et()&&U.props.animation){var e=rt(),n=e.box,i=e.content;O([n,i],r),C([n,i],"visible")}pt(),ct(),h(tt,U),null==(t=U.popperInstance)||t.forceUpdate(),U.state.isMounted=!0,st("onMount",[U]),U.props.animation&&et()&&function(t,e){ht(t,e)}(r,function(){U.state.isShown=!0,st("onShown",[U])})}},function(){var t,e=U.props.appendTo,n=nt();t=U.props.interactive&&e===F.appendTo||"parent"===e?n.parentNode:f(e,[n]);t.contains(_)||t.appendChild(_);Ct(),B(U.props.interactive&&e===F.appendTo&&n.nextElementSibling!==_,["Interactive tippy element may not be accessible via keyboard","navigation because it is not directly after the reference element","in the DOM source order.","\n\n","Using a wrapper <div> or <span> tag around the reference element","solves this by creating a new parentNode context.","\n\n","Specifying `appendTo: document.body` silences this warning, but it","assumes you are using a focus management solution to handle","keyboard navigation.","\n\n","See: https://atomiks.github.io/tippyjs/v6/accessibility/#interactivity"].join(" "))}()},hide:function(){B(U.state.isDestroyed,R("hide"));var t=!U.state.isVisible,e=U.state.isDestroyed,n=!U.state.isEnabled,i=u(U.props.duration,1,F.duration);if(t||e||n)return;if(st("onHide",[U],!1),!1===U.props.onHide(U))return;U.state.isVisible=!1,U.state.isShown=!1,M=!1,L=!1,et()&&(_.style.visibility="hidden");if(ut(),mt(),at(),et()){var r=rt(),o=r.box,a=r.content;U.props.animation&&(O([o,a],i),C([o,a],"hidden"))}pt(),ct(),U.props.animation?et()&&function(t,e){ht(t,function(){!U.state.isVisible&&_.parentNode&&_.parentNode.contains(_)&&e()})}(i,U.unmount):U.unmount()},hideWithInteractivity:function(t){B(U.state.isDestroyed,R("hideWithInteractivity")),it().addEventListener("mousemove",I),h(Z,I),I(t)},enable:function(){U.state.isEnabled=!0},disable:function(){U.hide(),U.state.isEnabled=!1},unmount:function(){B(U.state.isDestroyed,R("unmount")),U.state.isVisible&&U.hide();if(!U.state.isMounted)return;At(),jt().forEach(function(t){t._tippy.unmount()}),_.parentNode&&_.parentNode.removeChild(_);tt=tt.filter(function(t){return t!==U}),U.state.isMounted=!1,st("onHidden",[U])},destroy:function(){if(B(U.state.isDestroyed,R("destroy")),U.state.isDestroyed)return;U.clearDelayTimeouts(),U.unmount(),bt(),delete e._tippy,U.state.isDestroyed=!0,st("onDestroy",[U])}};if(!T.render)return H(!0,"render() function has not been supplied."),U;var Y=T.render(U),_=Y.popper,q=Y.onUpdate;_.setAttribute("data-tippy-root",""),_.id="tippy-"+U.id,U.popper=_,e._tippy=U,_._tippy=U;var X=N.map(function(t){return t.fn(U)}),$=e.hasAttribute("aria-expanded");return yt(),ct(),at(),st("onCreate",[U]),T.showOnCreate&&Lt(),_.addEventListener("mouseenter",function(){U.props.interactive&&U.state.isVisible&&U.clearDelayTimeouts()}),_.addEventListener("mouseleave",function(t){U.props.interactive&&U.props.trigger.indexOf("mouseenter")>=0&&(it().addEventListener("mousemove",I),I(t))}),U;function J(){var t=U.props.touch;return Array.isArray(t)?t:[t,0]}function K(){return"hold"===J()[0]}function et(){var t;return!!(null==(t=U.props.render)?void 0:t.$$tippy)}function nt(){return w||e}function it(){var t=nt().parentNode;return t?A(t):document}function rt(){return G(_)}function ot(t){return U.state.isMounted&&!U.state.isVisible||D.isTouch||p&&"focus"===p.type?0:u(U.props.delay,t?0:1,F.delay)}function at(){_.style.pointerEvents=U.props.interactive&&U.state.isVisible?"":"none",_.style.zIndex=""+U.props.zIndex}function st(t,e,n){var i;(void 0===n&&(n=!0),X.forEach(function(n){n[t]&&n[t].apply(void 0,e)}),n)&&(i=U.props)[t].apply(i,e)}function pt(){var t=U.props.aria;if(t.content){var n="aria-"+t.content,i=_.id;m(U.props.triggerTarget||e).forEach(function(t){var e=t.getAttribute(n);if(U.state.isVisible)t.setAttribute(n,e?e+" "+i:i);else{var r=e&&e.replace(i,"").trim();r?t.setAttribute(n,r):t.removeAttribute(n)}})}}function ct(){!$&&U.props.aria.expanded&&m(U.props.triggerTarget||e).forEach(function(t){U.props.interactive?t.setAttribute("aria-expanded",U.state.isVisible&&t===nt()?"true":"false"):t.removeAttribute("aria-expanded")})}function ut(){it().removeEventListener("mousemove",I),Z=Z.filter(function(t){return t!==I})}function lt(t){if(!(D.isTouch&&(S||"mousedown"===t.type)||U.props.interactive&&_.contains(t.target))){if(nt().contains(t.target)){if(D.isTouch)return;if(U.state.isVisible&&U.props.trigger.indexOf("click")>=0)return}else st("onClickOutside",[U,t]);!0===U.props.hideOnClick&&(U.clearDelayTimeouts(),U.hide(),k=!0,setTimeout(function(){k=!1}),U.state.isMounted||mt())}}function ft(){S=!0}function dt(){S=!1}function vt(){var t=it();t.addEventListener("mousedown",lt,!0),t.addEventListener("touchend",lt,c),t.addEventListener("touchstart",dt,c),t.addEventListener("touchmove",ft,c)}function mt(){var t=it();t.removeEventListener("mousedown",lt,!0),t.removeEventListener("touchend",lt,c),t.removeEventListener("touchstart",dt,c),t.removeEventListener("touchmove",ft,c)}function ht(t,e){var n=rt().box;function i(t){t.target===n&&(j(n,"remove",i),e())}if(0===t)return e();j(n,"remove",l),j(n,"add",i),l=i}function gt(t,n,i){void 0===i&&(i=!1),m(U.props.triggerTarget||e).forEach(function(e){e.addEventListener(t,n,i),P.push({node:e,eventType:t,handler:n,options:i})})}function yt(){var t;K()&&(gt("touchstart",wt,{passive:!0}),gt("touchend",Et,{passive:!0})),(t=U.props.trigger,t.split(/\s+/).filter(Boolean)).forEach(function(t){if("manual"!==t)switch(gt(t,wt),t){case"mouseenter":gt("mouseleave",Et);break;case"focus":gt(i?"focusout":"blur",Tt);break;case"focusin":gt("focusout",Tt)}})}function bt(){P.forEach(function(t){var e=t.node,n=t.eventType,i=t.handler,r=t.options;e.removeEventListener(n,i,r)}),P=[]}function wt(t){var e,n=!1;if(U.state.isEnabled&&!Ot(t)&&!k){var i="focus"===(null==(e=p)?void 0:e.type);p=t,w=t.currentTarget,ct(),!U.state.isVisible&&x(t)&&Z.forEach(function(e){return e(t)}),"click"===t.type&&(U.props.trigger.indexOf("mouseenter")<0||L)&&!1!==U.props.hideOnClick&&U.state.isVisible?n=!0:Lt(t),"click"===t.type&&(L=!n),n&&!i&&Dt(t)}}function xt(t){var e=t.target,n=nt().contains(e)||_.contains(e);"mousemove"===t.type&&n||function(t,e){var n=e.clientX,i=e.clientY;return t.every(function(t){var e=t.popperRect,r=t.popperState,o=t.props.interactiveBorder,a=g(r.placement),s=r.modifiersData.offset;if(!s)return!0;var p="bottom"===a?s.top.y:0,c="top"===a?s.bottom.y:0,u="right"===a?s.left.x:0,l="left"===a?s.right.x:0,f=e.top-i+p>o,d=i-e.bottom-c>o,v=e.left-n+u>o,m=n-e.right-l>o;return f||d||v||m})}(jt().concat(_).map(function(t){var e,n=null==(e=t._tippy.popperInstance)?void 0:e.state;return n?{popperRect:t.getBoundingClientRect(),popperState:n,props:T}:null}).filter(Boolean),t)&&(ut(),Dt(t))}function Et(t){Ot(t)||U.props.trigger.indexOf("click")>=0&&L||(U.props.interactive?U.hideWithInteractivity(t):Dt(t))}function Tt(t){U.props.trigger.indexOf("focusin")<0&&t.target!==nt()||U.props.interactive&&t.relatedTarget&&_.contains(t.relatedTarget)||Dt(t)}function Ot(t){return!!D.isTouch&&K()!==t.type.indexOf("touch")>=0}function Ct(){At();var n=U.props,i=n.popperOptions,r=n.placement,o=n.offset,a=n.getReferenceClientRect,s=n.moveTransition,p=et()?G(_).arrow:null,c=a?{getBoundingClientRect:a,contextElement:a.contextElement||nt()}:e,u=[{name:"offset",options:{offset:o}},{name:"preventOverflow",options:{padding:{top:2,bottom:2,left:5,right:5}}},{name:"flip",options:{padding:5}},{name:"computeStyles",options:{adaptive:!s}},{name:"$$tippy",enabled:!0,phase:"beforeWrite",requires:["computeStyles"],fn:function(t){var e=t.state;if(et()){var n=rt().box;["placement","reference-hidden","escaped"].forEach(function(t){"placement"===t?n.setAttribute("data-placement",e.placement):e.attributes.popper["data-popper-"+t]?n.setAttribute("data-"+t,""):n.removeAttribute("data-"+t)}),e.attributes.popper={}}}}];et()&&p&&u.push({name:"arrow",options:{element:p,padding:3}}),u.push.apply(u,(null==i?void 0:i.modifiers)||[]),U.popperInstance=t.createPopper(c,_,Object.assign({},i,{placement:r,onFirstUpdate:v,modifiers:u}))}function At(){U.popperInstance&&(U.popperInstance.destroy(),U.popperInstance=null)}function jt(){return y(_.querySelectorAll("[data-tippy-root]"))}function Lt(t){U.clearDelayTimeouts(),t&&st("onTrigger",[U,t]),vt();var e=ot(!0),n=J(),i=n[0],r=n[1];D.isTouch&&"hold"===i&&r&&(e=r),e?o=setTimeout(function(){U.show()},e):U.show()}function Dt(t){if(U.clearDelayTimeouts(),st("onUntrigger",[U,t]),U.state.isVisible){if(!(U.props.trigger.indexOf("mouseenter")>=0&&U.props.trigger.indexOf("click")>=0&&["mouseleave","mousemove"].indexOf(t.type)>=0&&L)){var e=ot(!1);e?a=setTimeout(function(){U.state.isVisible&&U.hide()},e):s=requestAnimationFrame(function(){U.hide()})}}else mt()}}function nt(t,e){void 0===e&&(e={});var n=F.plugins.concat(e.plugins||[]);!function(t){var e=!t,n="[object Object]"===Object.prototype.toString.call(t)&&!t.addEventListener;H(e,["tippy() was passed","`"+String(t)+"`","as its targets (first) argument. Valid types are: String, Element,","Element[], or NodeList."].join(" ")),H(n,["tippy() was passed a plain object which is not supported as an argument","for virtual positioning. Use props.getReferenceClientRect instead."].join(" "))}(t),_(e,n),document.addEventListener("touchstart",S,c),window.addEventListener("blur",P);var i=Object.assign({},e,{plugins:n}),r=T(t),o=w(i.content),a=r.length>1;B(o&&a,["tippy() was passed an Element as the `content` prop, but more than","one tippy instance was created by this invocation. This means the","content element will only be appended to the last tippy instance.","\n\n","Instead, pass the .innerHTML of the element, or use a function that","returns a cloned version of the element instead.","\n\n","1) content: element.innerHTML\n","2) content: ()=> element.cloneNode(true)"].join(" "));var s=r.reduce(function(t,e){var n=e&&et(e,i);return n&&t.push(n),t},[]);return w(t)?s[0]:s}nt.defaultProps=F,nt.setDefaultProps=function(t){_(t,[]),Object.keys(t).forEach(function(e){F[e]=t[e]})},nt.currentInput=D;var it=Object.assign({},t.applyStyles,{effect:function(t){var e=t.state,n={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};Object.assign(e.elements.popper.style,n.popper),e.styles=n,e.elements.arrow&&Object.assign(e.elements.arrow.style,n.arrow)}}),rt={mouseover:"mouseenter",focusin:"focus",click:"click"};var ot={name:"animateFill",defaultValue:!1,fn:function(t){var e;if(!(null==(e=t.props.render)?void 0:e.$$tippy))return H(t.props.animateFill,"The `animateFill` plugin requires the default render function."),{};var n=G(t.popper),i=n.box,r=n.content,o=t.props.animateFill?function(){var t=b();return t.className=a,C([t],"hidden"),t}():null;return{onCreate:function(){o&&(i.insertBefore(o,i.firstElementChild),i.setAttribute("data-animatefill",""),i.style.overflow="hidden",t.setProps({arrow:!1,animation:"shift-away"}))},onMount:function(){if(o){var t=i.style.transitionDuration,e=Number(t.replace("ms",""));r.style.transitionDelay=Math.round(e/10)+"ms",o.style.transitionDuration=t,C([o],"visible")}},onShow:function(){o&&(o.style.transitionDuration="0ms")},onHide:function(){o&&C([o],"hidden")}}}};var at={clientX:0,clientY:0},st=[];function pt(t){var e=t.clientX,n=t.clientY;at={clientX:e,clientY:n}}var ct={name:"followCursor",defaultValue:!1,fn:function(t){var e=t.reference,n=A(t.props.triggerTarget||e),i=!1,r=!1,o=!0,a=t.props;function s(){return"initial"===t.props.followCursor&&t.state.isVisible}function p(){n.addEventListener("mousemove",l)}function c(){n.removeEventListener("mousemove",l)}function u(){i=!0,t.setProps({getReferenceClientRect:null}),i=!1}function l(n){var i=!n.target||e.contains(n.target),r=t.props.followCursor,o=n.clientX,a=n.clientY,s=e.getBoundingClientRect(),p=o-s.left,c=a-s.top;!i&&t.props.interactive||t.setProps({getReferenceClientRect:function(){var t=e.getBoundingClientRect(),n=o,i=a;"initial"===r&&(n=t.left+p,i=t.top+c);var s="horizontal"===r?t.top:i,u="vertical"===r?t.right:n,l="horizontal"===r?t.bottom:i,f="vertical"===r?t.left:n;return{width:u-f,height:l-s,top:s,right:u,bottom:l,left:f}}})}function f(){t.props.followCursor&&(st.push({instance:t,doc:n}),function(t){t.addEventListener("mousemove",pt)}(n))}function d(){0===(st=st.filter(function(e){return e.instance!==t})).filter(function(t){return t.doc===n}).length&&function(t){t.removeEventListener("mousemove",pt)}(n)}return{onCreate:f,onDestroy:d,onBeforeUpdate:function(){a=t.props},onAfterUpdate:function(e,n){var o=n.followCursor;i||void 0!==o&&a.followCursor!==o&&(d(),o?(f(),!t.state.isMounted||r||s()||p()):(c(),u()))},onMount:function(){t.props.followCursor&&!r&&(o&&(l(at),o=!1),s()||p())},onTrigger:function(t,e){x(e)&&(at={clientX:e.clientX,clientY:e.clientY}),r="focus"===e.type},onHidden:function(){t.props.followCursor&&(u(),c(),o=!0)}}}};var ut={name:"inlinePositioning",defaultValue:!1,fn:function(t){var e,n=t.reference;var i=-1,r=!1,o={name:"tippyInlinePositioning",enabled:!0,phase:"afterWrite",fn:function(r){var o=r.state;t.props.inlinePositioning&&(e!==o.placement&&t.setProps({getReferenceClientRect:function(){return function(t,e,n,i){if(n.length<2||null===t)return e;if(2===n.length&&i>=0&&n[0].left>n[1].right)return n[i]||e;switch(t){case"top":case"bottom":var r=n[0],o=n[n.length-1],a="top"===t,s=r.top,p=o.bottom,c=a?r.left:o.left,u=a?r.right:o.right,l=u-c,f=p-s;return{top:s,bottom:p,left:c,right:u,width:l,height:f};case"left":case"right":var d=Math.min.apply(Math,n.map(function(t){return t.left})),v=Math.max.apply(Math,n.map(function(t){return t.right})),m=n.filter(function(e){return"left"===t?e.left===d:e.right===v}),h=m[0].top,g=m[m.length-1].bottom,y=d,b=v,w=b-y,x=g-h;return{top:h,bottom:g,left:y,right:b,width:w,height:x};default:return e}}(g(o.placement),n.getBoundingClientRect(),y(n.getClientRects()),i)}}),e=o.placement)}};function a(){var e;r||(e=function(t,e){var n;return{popperOptions:Object.assign({},t.popperOptions,{modifiers:[].concat(((null==(n=t.popperOptions)?void 0:n.modifiers)||[]).filter(function(t){return t.name!==e.name}),[e])})}}(t.props,o),r=!0,t.setProps(e),r=!1)}return{onCreate:a,onAfterUpdate:a,onTrigger:function(e,n){if(x(n)){var r=y(t.reference.getClientRects()),o=r.find(function(t){return t.left-2<=n.clientX&&t.right+2>=n.clientX&&t.top-2<=n.clientY&&t.bottom+2>=n.clientY});i=r.indexOf(o)}},onUntrigger:function(){i=-1}}}};var lt={name:"sticky",defaultValue:!1,fn:function(t){var e=t.reference,n=t.popper;function i(e){return!0===t.props.sticky||t.props.sticky===e}var r=null,o=null;function a(){var s=i("reference")?(t.popperInstance?t.popperInstance.state.elements.reference:e).getBoundingClientRect():null,p=i("popper")?n.getBoundingClientRect():null;(s&&ft(r,s)||p&&ft(o,p))&&t.popperInstance&&t.popperInstance.update(),r=s,o=p,t.state.isMounted&&requestAnimationFrame(a)}return{onMount:function(){t.props.sticky&&a()}}}};function ft(t,e){return!t||!e||(t.top!==e.top||t.right!==e.right||t.bottom!==e.bottom||t.left!==e.left)}return e&&function(t){var e=document.createElement("style");e.textContent=t,e.setAttribute("data-tippy-stylesheet","");var n=document.head,i=document.querySelector("head>style,head>link");i?n.insertBefore(e,i):n.appendChild(e)}('.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}[data-tippy-root]{max-width:calc(100vw - 10px)}.tippy-box{position:relative;background-color:#333;color:#fff;border-radius:4px;font-size:14px;line-height:1.4;outline:0;transition-property:transform,visibility,opacity}.tippy-box[data-placement^=top]>.tippy-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-arrow:before{bottom:-7px;left:0;border-width:8px 8px 0;border-top-color:initial;transform-origin:center top}.tippy-box[data-placement^=bottom]>.tippy-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-arrow:before{top:-7px;left:0;border-width:0 8px 8px;border-bottom-color:initial;transform-origin:center bottom}.tippy-box[data-placement^=left]>.tippy-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-arrow:before{border-width:8px 0 8px 8px;border-left-color:initial;right:-7px;transform-origin:center left}.tippy-box[data-placement^=right]>.tippy-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-arrow:before{left:-7px;border-width:8px 8px 8px 0;border-right-color:initial;transform-origin:center right}.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}.tippy-arrow{width:16px;height:16px;color:#333}.tippy-arrow:before{content:"";position:absolute;border-color:transparent;border-style:solid}.tippy-content{position:relative;padding:5px 9px;z-index:1}'),nt.setDefaultProps({plugins:[ot,ct,ut,lt],render:K}),nt.createSingleton=function(t,e){var n;void 0===e&&(e={}),H(!Array.isArray(t),["The first argument passed to createSingleton() must be an array of","tippy instances. The passed value was",String(t)].join(" "));var i,r=t,o=[],a=e.overrides,s=[],p=!1;function c(){o=r.map(function(t){return t.reference})}function u(t){r.forEach(function(e){t?e.enable():e.disable()})}function l(t){return r.map(function(e){var n=e.setProps;return e.setProps=function(r){n(r),e.reference===i&&t.setProps(r)},function(){e.setProps=n}})}function f(t,e){var n=o.indexOf(e);if(e!==i){i=e;var s=(a||[]).concat("content").reduce(function(t,e){return t[e]=r[n].props[e],t},{});t.setProps(Object.assign({},s,{getReferenceClientRect:"function"==typeof s.getReferenceClientRect?s.getReferenceClientRect:function(){return e.getBoundingClientRect()}}))}}u(!1),c();var d={fn:function(){return{onDestroy:function(){u(!0)},onHidden:function(){i=null},onClickOutside:function(t){t.props.showOnCreate&&!p&&(p=!0,i=null)},onShow:function(t){t.props.showOnCreate&&!p&&(p=!0,f(t,o[0]))},onTrigger:function(t,e){f(t,e.currentTarget)}}}},m=nt(b(),Object.assign({},v(e,["overrides"]),{plugins:[d].concat(e.plugins||[]),triggerTarget:o,popperOptions:Object.assign({},e.popperOptions,{modifiers:[].concat((null==(n=e.popperOptions)?void 0:n.modifiers)||[],[it])})})),h=m.show;m.show=function(t){if(h(),!i&&null==t)return f(m,o[0]);if(!i||null!=t){if("number"==typeof t)return o[t]&&f(m,o[t]);if(r.includes(t)){var e=t.reference;return f(m,e)}return o.includes(t)?f(m,t):void 0}},m.showNext=function(){var t=o[0];if(!i)return m.show(0);var e=o.indexOf(i);m.show(o[e+1]||t)},m.showPrevious=function(){var t=o[o.length-1];if(!i)return m.show(t);var e=o.indexOf(i),n=o[e-1]||t;m.show(n)};var g=m.setProps;return m.setProps=function(t){a=t.overrides||a,g(t)},m.setInstances=function(t){u(!0),s.forEach(function(t){return t()}),r=t,u(!1),c(),l(m),m.setProps({triggerTarget:o})},s=l(m),m},nt.delegate=function(t,e){H(!(e&&e.target),["You must specity a `target` prop indicating a CSS selector string matching","the target elements that should receive a tippy."].join(" "));var n=[],i=[],r=!1,o=e.target,a=v(e,["target"]),s=Object.assign({},a,{trigger:"manual",touch:!1}),p=Object.assign({},a,{showOnCreate:!0}),u=nt(t,s);function l(t){if(t.target&&!r){var n=t.target.closest(o);if(n){var a=n.getAttribute("data-tippy-trigger")||e.trigger||F.trigger;if(!n._tippy&&!("touchstart"===t.type&&"boolean"==typeof p.touch||"touchstart"!==t.type&&a.indexOf(rt[t.type])<0)){var s=nt(n,p);s&&(i=i.concat(s))}}}}function f(t,e,i,r){void 0===r&&(r=!1),t.addEventListener(e,i,r),n.push({node:t,eventType:e,handler:i,options:r})}return m(u).forEach(function(t){var e=t.destroy,o=t.enable,a=t.disable;t.destroy=function(t){void 0===t&&(t=!0),t&&i.forEach(function(t){t.destroy()}),i=[],n.forEach(function(t){var e=t.node,n=t.eventType,i=t.handler,r=t.options;e.removeEventListener(n,i,r)}),n=[],e()},t.enable=function(){o(),i.forEach(function(t){return t.enable()}),r=!1},t.disable=function(){a(),i.forEach(function(t){return t.disable()}),r=!0},function(t){var e=t.reference;f(e,"touchstart",l,c),f(e,"mouseover",l),f(e,"focusin",l),f(e,"click",l)}(t)}),u},nt.hideAll=function(t){var e=void 0===t?{}:t,n=e.exclude,i=e.duration;tt.forEach(function(t){var e=!1;if(n&&(e=E(n)?t.reference===n:t.popper===n.popper),!e){var r=t.props.duration;t.setProps({duration:i}),t.hide(),t.state.isDestroyed||t.setProps({duration:r})}})},nt.roundArrow='<svg width="16" height="6" xmlns="http://www.w3.org/2000/svg"><path d="M0 6s1.796-.013 4.67-3.615C5.851.9 6.93.006 8 0c1.07-.006 2.148.887 3.343 2.385C14.233 6.005 16 6 16 6H0z"></svg>',nt});
(function (global, factory){
typeof exports==='object'&&typeof module!=='undefined' ? module.exports=factory() :
typeof define==='function'&&define.amd ? define(factory) :
(global=typeof globalThis!=='undefined' ? globalThis:global||self, global.Swiper=factory());
})(this, (function (){ 'use strict';
function isObject$1(obj){
return obj!==null&&typeof obj==='object'&&'constructor' in obj&&obj.constructor===Object;
}
function extend$1(target, src){
if(target===void 0){
target={};}
if(src===void 0){
src={};}
Object.keys(src).forEach(key=> {
if(typeof target[key]==='undefined') target[key]=src[key];else if(isObject$1(src[key])&&isObject$1(target[key])&&Object.keys(src[key]).length > 0){
extend$1(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 getDocument(){
const doc=typeof document!=='undefined' ? document:{};
extend$1(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(typeof setTimeout==='undefined'){
callback();
return null;
}
return setTimeout(callback, 0);
},
cancelAnimationFrame(id){
if(typeof setTimeout==='undefined'){
return;
}
clearTimeout(id);
}};
function getWindow(){
const win=typeof window!=='undefined' ? window:{};
extend$1(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(typeof items==='number'){
super(items);
}else{
super(...(items||[]));
makeReactive(this);
}}
}
function arrayFlat(arr){
if(arr===void 0){
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(uniqueArray.indexOf(arr[i])===-1) uniqueArray.push(arr[i]);
}
return uniqueArray;
}
function qsa(selector, context){
if(typeof selector!=='string'){
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 $(selector, context){
const window=getWindow();
const document=getDocument();
let arr=[];
if(!context&&selector instanceof Dom7){
return selector;
}
if(!selector){
return new Dom7(arr);
}
if(typeof selector==='string'){
const html=selector.trim();
if(html.indexOf('<') >=0&&html.indexOf('>') >=0){
let toCreate='div';
if(html.indexOf('<li')===0) toCreate='ul';
if(html.indexOf('<tr')===0) toCreate='tbody';
if(html.indexOf('<td')===0||html.indexOf('<th')===0) toCreate='tr';
if(html.indexOf('<tbody')===0) toCreate='table';
if(html.indexOf('<option')===0) toCreate='select';
const tempParent=document.createElement(toCreate);
tempParent.innerHTML=html;
for (let i=0; i < tempParent.childNodes.length; i +=1){
arr.push(tempParent.childNodes[i]);
}}else{
arr=qsa(selector.trim(), context||document);
}}else if(selector.nodeType||selector===window||selector===document){
arr.push(selector);
}else if(Array.isArray(selector)){
if(selector instanceof Dom7) return selector;
arr=selector;
}
return new Dom7(arrayUnique(arr));
}
$.fn=Dom7.prototype;
function addClass(){
for (var _len=arguments.length, classes=new Array(_len), _key=0; _key < _len; _key++){
classes[_key]=arguments[_key];
}
const classNames=arrayFlat(classes.map(c=> c.split(' ')));
this.forEach(el=> {
el.classList.add(...classNames);
});
return this;
}
function removeClass(){
for (var _len2=arguments.length, classes=new Array(_len2), _key2=0; _key2 < _len2; _key2++){
classes[_key2]=arguments[_key2];
}
const classNames=arrayFlat(classes.map(c=> c.split(' ')));
this.forEach(el=> {
el.classList.remove(...classNames);
});
return this;
}
function toggleClass(){
for (var _len3=arguments.length, classes=new Array(_len3), _key3=0; _key3 < _len3; _key3++){
classes[_key3]=arguments[_key3];
}
const classNames=arrayFlat(classes.map(c=> c.split(' ')));
this.forEach(el=> {
classNames.forEach(className=> {
el.classList.toggle(className);
});
});
}
function hasClass(){
for (var _len4=arguments.length, classes=new Array(_len4), _key4=0; _key4 < _len4; _key4++){
classes[_key4]=arguments[_key4];
}
const classNames=arrayFlat(classes.map(c=> c.split(' ')));
return arrayFilter(this, el=> {
return classNames.filter(className=> el.classList.contains(className)).length > 0;
}).length > 0;
}
function attr(attrs, value){
if(arguments.length===1&&typeof attrs==='string'){
if(this[0]) return this[0].getAttribute(attrs);
return undefined;
}
for (let i=0; i < this.length; i +=1){
if(arguments.length===2){
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$1(duration){
for (let i=0; i < this.length; i +=1){
this[i].style.transitionDuration=typeof duration!=='string' ? `${duration}ms`:duration;
}
return this;
}
function on(){
for (var _len5=arguments.length, args=new Array(_len5), _key5=0; _key5 < _len5; _key5++){
args[_key5]=arguments[_key5];
}
let [eventType, targetSelector, listener, capture]=args;
if(typeof args[1]==='function'){
[eventType, listener, capture]=args;
targetSelector=undefined;
}
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($(target).is(targetSelector)) listener.apply(target, eventData);else {
const parents=$(target).parents();
for (let k=0; k < parents.length; k +=1){
if($(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(){
for (var _len6=arguments.length, args=new Array(_len6), _key6=0; _key6 < _len6; _key6++){
args[_key6]=arguments[_key6];
}
let [eventType, targetSelector, listener, capture]=args;
if(typeof args[1]==='function'){
[eventType, listener, capture]=args;
targetSelector=undefined;
}
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(){
const window=getWindow();
for (var _len9=arguments.length, args=new Array(_len9), _key9=0; _key9 < _len9; _key9++){
args[_key9]=arguments[_key9];
}
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$1(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 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 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=getWindow();
const document=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=getWindow();
if(this[0]) return window.getComputedStyle(this[0], null);
return {};}
function css(props, value){
const window=getWindow();
let i;
if(arguments.length===1){
if(typeof props==='string'){
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(arguments.length===2&&typeof props==='string'){
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 $(result);
}
function html(html){
if(typeof html==='undefined'){
return this[0] ? this[0].innerHTML:null;
}
for (let i=0; i < this.length; i +=1){
this[i].innerHTML=html;
}
return this;
}
function text(text){
if(typeof text==='undefined'){
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=getWindow();
const document=getDocument();
const el=this[0];
let compareWith;
let i;
if(!el||typeof selector==='undefined') return false;
if(typeof selector==='string'){
if(el.matches) return el.matches(selector);
if(el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);
if(el.msMatchesSelector) return el.msMatchesSelector(selector);
compareWith=$(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 ((child=child.previousSibling)!==null){
if(child.nodeType===1) i +=1;
}
return i;
}
return undefined;
}
function eq(index){
if(typeof index==='undefined') return this;
const length=this.length;
if(index > length - 1){
return $([]);
}
if(index < 0){
const returnIndex=length + index;
if(returnIndex < 0) return $([]);
return $([this[returnIndex]]);
}
return $([this[index]]);
}
function append(){
let newChild;
const document=getDocument();
for (let k=0; k < arguments.length; k +=1){
newChild=k < 0||arguments.length <=k ? undefined:arguments[k];
for (let i=0; i < this.length; i +=1){
if(typeof newChild==='string'){
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=getDocument();
let i;
let j;
for (i=0; i < this.length; i +=1){
if(typeof newChild==='string'){
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&&$(this[0].nextElementSibling).is(selector)){
return $([this[0].nextElementSibling]);
}
return $([]);
}
if(this[0].nextElementSibling) return $([this[0].nextElementSibling]);
return $([]);
}
return $([]);
}
function nextAll(selector){
const nextEls=[];
let el=this[0];
if(!el) return $([]);
while (el.nextElementSibling){
const next=el.nextElementSibling;
if(selector){
if($(next).is(selector)) nextEls.push(next);
} else nextEls.push(next);
el=next;
}
return $(nextEls);
}
function prev(selector){
if(this.length > 0){
const el=this[0];
if(selector){
if(el.previousElementSibling&&$(el.previousElementSibling).is(selector)){
return $([el.previousElementSibling]);
}
return $([]);
}
if(el.previousElementSibling) return $([el.previousElementSibling]);
return $([]);
}
return $([]);
}
function prevAll(selector){
const prevEls=[];
let el=this[0];
if(!el) return $([]);
while (el.previousElementSibling){
const prev=el.previousElementSibling;
if(selector){
if($(prev).is(selector)) prevEls.push(prev);
} else prevEls.push(prev);
el=prev;
}
return $(prevEls);
}
function parent(selector){
const parents=[];
for (let i=0; i < this.length; i +=1){
if(this[i].parentNode!==null){
if(selector){
if($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);
}else{
parents.push(this[i].parentNode);
}}
}
return $(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($(parent).is(selector)) parents.push(parent);
}else{
parents.push(parent);
}
parent=parent.parentNode;
}}
return $(parents);
}
function closest(selector){
let closest=this;
if(typeof selector==='undefined'){
return $([]);
}
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 $(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||$(childNodes[j]).is(selector)){
children.push(childNodes[j]);
}}
}
return $(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 Methods={
addClass,
removeClass,
hasClass,
toggleClass,
attr,
removeAttr,
transform,
transition: transition$1,
on,
off,
trigger,
transitionEnd: transitionEnd$1,
outerWidth,
outerHeight,
styles,
offset,
css,
each,
html,
text,
is,
index,
eq,
append,
prepend,
next,
nextAll,
prev,
prevAll,
parent,
parents,
closest,
find,
children,
filter,
remove
};
Object.keys(Methods).forEach(methodName=> {
Object.defineProperty($.fn, methodName, {
value: Methods[methodName],
writable: true
});
});
function deleteProps(obj){
const object=obj;
Object.keys(object).forEach(key=> {
try {
object[key]=null;
} catch (e){
}
try {
delete object[key];
} catch (e){
}});
}
function nextTick(callback, delay){
if(delay===void 0){
delay=0;
}
return setTimeout(callback, delay);
}
function now(){
return Date.now();
}
function getComputedStyle$1(el){
const window=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 getTranslate(el, axis){
if(axis===void 0){
axis='x';
}
const window=getWindow();
let matrix;
let curTransform;
let transformMatrix;
const curStyle=getComputedStyle$1(el);
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(curTransform==='none' ? '':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(axis==='x'){
if(window.WebKitCSSMatrix) curTransform=transformMatrix.m41;
else if(matrix.length===16) curTransform=parseFloat(matrix[12]);
else curTransform=parseFloat(matrix[4]);
}
if(axis==='y'){
if(window.WebKitCSSMatrix) curTransform=transformMatrix.m42;
else if(matrix.length===16) curTransform=parseFloat(matrix[13]);
else curTransform=parseFloat(matrix[5]);
}
return curTransform||0;
}
function isObject(o){
return typeof o==='object'&&o!==null&&o.constructor&&Object.prototype.toString.call(o).slice(8, -1)==='Object';
}
function isNode(node){
if(typeof window!=='undefined'&&typeof window.HTMLElement!=='undefined'){
return node instanceof HTMLElement;
}
return node&&(node.nodeType===1||node.nodeType===11);
}
function extend(){
const to=Object(arguments.length <=0 ? undefined:arguments[0]);
const noExtend=['__proto__', 'constructor', 'prototype'];
for (let i=1; i < arguments.length; i +=1){
const nextSource=i < 0||arguments.length <=i ? undefined:arguments[i];
if(nextSource!==undefined&&nextSource!==null&&!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(desc!==undefined&&desc.enumerable){
if(isObject(to[nextKey])&&isObject(nextSource[nextKey])){
if(nextSource[nextKey].__swiper__){
to[nextKey]=nextSource[nextKey];
}else{
extend(to[nextKey], nextSource[nextKey]);
}}else if(!isObject(to[nextKey])&&isObject(nextSource[nextKey])){
to[nextKey]={};
if(nextSource[nextKey].__swiper__){
to[nextKey]=nextSource[nextKey];
}else{
extend(to[nextKey], nextSource[nextKey]);
}}else{
to[nextKey]=nextSource[nextKey];
}}
}}
}
return to;
}
function setCSSProperty(el, varName, varValue){
el.style.setProperty(varName, varValue);
}
function animateCSSModeScroll(_ref){
let {
swiper,
targetPosition,
side
}=_ref;
const window=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)=> {
return dir==='next'&&current >=target||dir==='prev'&&current <=target;
};
const animate=()=> {
time=new Date().getTime();
if(startTime===null){
startTime=time;
}
const progress=Math.max(Math.min((time - startTime) / duration, 1), 0);
const easeProgress=0.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=getWindow();
const document=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
}=_temp===void 0 ? {}:_temp;
const support=getSupport();
const window=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=platform==='Win32';
let macos=platform==='MacIntel';
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(overrides===void 0){
overrides={};}
if(!deviceCached){
deviceCached=calcDevice(overrides);
}
return deviceCached;
}
let browser;
function calcBrowser(){
const window=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=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&&typeof window.ResizeObserver!=='undefined'){
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=getWindow();
const attach=function (target, options){
if(options===void 0){
options={};}
const ObserverFunc=window.MutationObserver||window.WebkitMutationObserver;
const observer=new ObserverFunc(mutations=> {
if(mutations.length===1){
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: typeof options.attributes==='undefined' ? true:options.attributes,
childList: typeof options.childList==='undefined' ? true:options.childList,
characterData: typeof options.characterData==='undefined' ? 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);
}
var eventsEmitter={
on(events, handler, priority){
const self=this;
if(!self.eventsListeners||self.destroyed) return self;
if(typeof handler!=='function') 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(typeof handler!=='function') 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(typeof handler!=='function') 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(typeof handler==='undefined'){
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(typeof args[0]==='string'||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(typeof swiper.params.width!=='undefined'&&swiper.params.width!==null){
width=swiper.params.width;
}else{
width=$el[0].clientWidth;
}
if(typeof swiper.params.height!=='undefined'&&swiper.params.height!==null){
height=swiper.params.height;
}else{
height=$el[0].clientHeight;
}
if(width===0&&swiper.isHorizontal()||height===0&&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(typeof offsetBefore==='function'){
offsetBefore=params.slidesOffsetBefore.call(swiper);
}
let offsetAfter=params.slidesOffsetAfter;
if(typeof offsetAfter==='function'){
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(typeof swiperSize==='undefined'){
return;
}
if(typeof spaceBetween==='string'&&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){
setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');
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=params.slidesPerView==='auto'&&params.breakpoints&&Object.keys(params.breakpoints).filter(key=> {
return typeof params.breakpoints[key].slidesPerView!=='undefined';
}).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(slide.css('display')==='none') continue;
if(params.slidesPerView==='auto'){
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&&boxSizing==='border-box'){
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(prevSlideSize===0&&i!==0) slidePosition=slidePosition - swiperSize / 2 - spaceBetween;
if(i===0) slidePosition=slidePosition - swiperSize / 2 - spaceBetween;
if(Math.abs(slidePosition) < 1 / 1000) 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&&(params.effect==='slide'||params.effect==='coverflow')){
$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(snapGrid.length===0) snapGrid=[0];
if(params.spaceBetween!==0){
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){
setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);
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&&(params.effect==='slide'||params.effect==='fade')){
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(typeof speed==='number'){
swiper.setTransition(speed);
}else if(speed===true){
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(swiper.params.slidesPerView!=='auto'&&swiper.params.slidesPerView > 1){
if(swiper.params.centeredSlides){
(swiper.visibleSlides||$([])).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(typeof activeSlides[i]!=='undefined'){
const height=activeSlides[i].offsetHeight;
newHeight=height > newHeight ? height:newHeight;
}}
if(newHeight||newHeight===0) 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(translate===void 0){
translate=this&&this.translate||0;
}
const swiper=this;
const params=swiper.params;
const {
slides,
rtlTranslate: rtl,
snapGrid
}=swiper;
if(slides.length===0) return;
if(typeof slides[0].swiperSlideOffset==='undefined') 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=$(swiper.visibleSlides);
}
function updateProgress(translate){
const swiper=this;
if(typeof translate==='undefined'){
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(translatesDiff===0){
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&&nextSlide.length===0){
nextSlide=slides.eq(0);
nextSlide.addClass(params.slideNextClass);
}
let prevSlide=activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);
if(params.loop&&prevSlide.length===0){
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(typeof activeIndex==='undefined'){
for (let i=0; i < slidesGrid.length; i +=1){
if(typeof slidesGrid[i + 1]!=='undefined'){
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||typeof activeIndex==='undefined') 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=$(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($(slide).attr('data-swiper-slide-index'), 10);
}else{
swiper.clickedIndex=slideIndex;
}}else{
swiper.clickedSlide=undefined;
swiper.clickedIndex=undefined;
return;
}
if(params.slideToClickedSlide&&swiper.clickedIndex!==undefined&&swiper.clickedIndex!==swiper.activeIndex){
swiper.slideToClickedSlide();
}}
var update={
updateSize,
updateSlides,
updateAutoHeight,
updateSlidesOffset,
updateSlidesProgress,
updateProgress,
updateSlidesClasses,
updateActiveIndex,
updateClickedSlide
};
function getSwiperTranslate(axis){
if(axis===void 0){
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=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(translatesDiff===0){
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(translate===void 0){
translate=0;
}
if(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
if(translateBounds===void 0){
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(speed===0){
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(speed===0){
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;
}
var 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(dir==='reset'){
swiper.emit(`slideResetTransition${step}`);
return;
}
swiper.emit(`slideChangeTransition${step}`);
if(dir==='next'){
swiper.emit(`slideNextTransition${step}`);
}else{
swiper.emit(`slidePrevTransition${step}`);
}}
}
function transitionStart(runCallbacks, direction){
if(runCallbacks===void 0){
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(runCallbacks, direction){
if(runCallbacks===void 0){
runCallbacks=true;
}
const swiper=this;
const {
params
}=swiper;
swiper.animating=false;
if(params.cssMode) return;
swiper.setTransition(0);
transitionEmit({
swiper,
runCallbacks,
direction,
step: 'End'
});
}
var transition={
setTransition,
transitionStart,
transitionEnd
};
function slideTo(index, speed, runCallbacks, internal, initial){
if(index===void 0){
index=0;
}
if(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
if(typeof index!=='number'&&typeof index!=='string'){
throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);
}
if(typeof index==='string'){
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;
const translate=-snapGrid[snapIndex];
if(params.normalizeSlideIndex){
for (let i=0; i < slidesGrid.length; i +=1){
const normalizedTranslate=-Math.floor(translate * 100);
const normalizedGrid=Math.floor(slidesGrid[i] * 100);
const normalizedGridNext=Math.floor(slidesGrid[i + 1] * 100);
if(typeof slidesGrid[i + 1]!=='undefined'){
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;
}}
if(slideIndex!==(previousIndex||0)&&runCallbacks){
swiper.emit('beforeSlideChangeStart');
}
swiper.updateProgress(translate);
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(params.effect!=='slide'){
swiper.setTranslate(translate);
}
if(direction!=='reset'){
swiper.transitionStart(runCallbacks, direction);
swiper.transitionEnd(runCallbacks, direction);
}
return false;
}
if(params.cssMode){
const isH=swiper.isHorizontal();
const t=rtl ? translate:-translate;
if(speed===0){
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(speed===0){
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(index===void 0){
index=0;
}
if(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
if(typeof index==='string'){
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(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
const swiper=this;
const {
animating,
enabled,
params
}=swiper;
if(!enabled) return swiper;
let perGroup=params.slidesPerGroup;
if(params.slidesPerView==='auto'&&params.slidesPerGroup===1&&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(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
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(typeof prevSnap==='undefined'&&params.cssMode){
let prevSnapIndex;
snapGrid.forEach((snap, snapIndex)=> {
if(normalizedTranslate >=snap){
prevSnapIndex=snapIndex;
}});
if(typeof prevSnapIndex!=='undefined'){
prevSnap=snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1:prevSnapIndex];
}}
let prevIndex=0;
if(typeof prevSnap!=='undefined'){
prevIndex=slidesGrid.indexOf(prevSnap);
if(prevIndex < 0) prevIndex=swiper.activeIndex - 1;
if(params.slidesPerView==='auto'&&params.slidesPerGroup===1&&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(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
const swiper=this;
return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);
}
function slideToClosest(speed, runCallbacks, internal, threshold){
if(speed===void 0){
speed=this.params.speed;
}
if(runCallbacks===void 0){
runCallbacks=true;
}
if(threshold===void 0){
threshold=0.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=params.slidesPerView==='auto' ? swiper.slidesPerViewDynamic():params.slidesPerView;
let slideToIndex=swiper.clickedIndex;
let realIndex;
if(params.loop){
if(swiper.animating) return;
realIndex=parseInt($(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();
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();
nextTick(()=> {
swiper.slideTo(slideToIndex);
});
}else{
swiper.slideTo(slideToIndex);
}}else{
swiper.slideTo(slideToIndex);
}}
var slide={
slideTo,
slideToLoop,
slideNext,
slidePrev,
slideReset,
slideToClosest,
slideToClickedSlide
};
function loopCreate(){
const swiper=this;
const document=getDocument();
const {
params,
$wrapperEl
}=swiper;
const $selector=$wrapperEl.children().length > 0 ? $($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=$(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);
$selector.append(blankNode);
}
slides=$selector.children(`.${params.slideClass}`);
}}
if(params.slidesPerView==='auto'&&!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.params.loopedSlidesLimit){
swiper.loopedSlides=slides.length;
}
const prependSlides=[];
const appendSlides=[];
slides.each((el, index)=> {
const slide=$(el);
slide.attr('data-swiper-slide-index', index);
});
for (let i=0; i < swiper.loopedSlides; i +=1){
const index=i - Math.floor(i / slides.length) * slides.length;
appendSlides.push(slides.eq(index)[0]);
prependSlides.unshift(slides.eq(slides.length - index - 1)[0]);
}
for (let i=0; i < appendSlides.length; i +=1){
$selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));
}
for (let i=prependSlides.length - 1; i >=0; i -=1){
$selector.prepend($(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 - loopedSlides * 3 + activeIndex;
newIndex +=loopedSlides;
const slideChanged=swiper.slideTo(newIndex, 0, false, true);
if(slideChanged&&diff!==0){
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&&diff!==0){
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');
}
var 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=swiper.params.touchEventsTarget==='container' ? 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[swiper.params.touchEventsTarget==='container' ? 'el':'wrapperEl'].style.cursor='';
}
var grabCursor={
setGrabCursor,
unsetGrabCursor
};
function closestElement(selector, base){
if(base===void 0){
base=this;
}
function __closestFrom(el){
if(!el||el===getDocument()||el===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=getDocument();
const window=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=$(e.target);
if(params.touchEventsTarget==='wrapper'){
if(!$targetEl.closest(swiper.wrapperEl).length) return;
}
data.isTouchEvent=e.type==='touchstart';
if(!data.isTouchEvent&&'which' in e&&e.which===3) return;
if(!data.isTouchEvent&&'button' in e&&e.button > 0) return;
if(data.isTouched&&data.isMoved) return;
const swipingClassHasValue = !!params.noSwipingClass&&params.noSwipingClass!=='';
const eventPath=event.composedPath ? event.composedPath():event.path;
if(swipingClassHasValue&&e.target&&e.target.shadowRoot&&eventPath){
$targetEl=$(eventPath[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=e.type==='touchstart' ? e.targetTouches[0].pageX:e.pageX;
touches.currentY=e.type==='touchstart' ? 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(edgeSwipeDetection==='prevent'){
event.preventDefault();
}else{
return;
}}
Object.assign(data, {
isTouched: true,
isMoved: false,
allowTouchCallbacks: true,
isScrolling: undefined,
startMoving: undefined
});
touches.startX=startX;
touches.startY=startY;
data.touchStartTime=now();
swiper.allowClick=true;
swiper.updateSize();
swiper.swipeDirection=undefined;
if(params.threshold > 0) data.allowThresholdMove=false;
if(e.type!=='touchstart'){
let preventDefault=true;
if($targetEl.is(data.focusableElements)){
preventDefault=false;
if($targetEl[0].nodeName==='SELECT'){
data.isTouched=false;
}}
if(document.activeElement&&$(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=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&&e.type!=='touchmove') return;
const targetTouch=e.type==='touchmove'&&e.targetTouches&&(e.targetTouches[0]||e.changedTouches[0]);
const pageX=e.type==='touchmove' ? targetTouch.pageX:e.pageX;
const pageY=e.type==='touchmove' ? targetTouch.pageY:e.pageY;
if(e.preventedByNestedSwiper){
touches.startX=pageX;
touches.startY=pageY;
return;
}
if(!swiper.allowTouchMove){
if(!$(e.target).is(data.focusableElements)){
swiper.allowClick=false;
}
if(data.isTouched){
Object.assign(touches, {
startX: pageX,
startY: pageY,
currentX: pageX,
currentY: pageY
});
data.touchStartTime=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&&$(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(typeof data.isScrolling==='undefined'){
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=Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;
data.isScrolling=swiper.isHorizontal() ? touchAngle > params.touchAngle:90 - touchAngle > params.touchAngle;
}}
}
if(data.isScrolling){
swiper.emit('touchMoveOpposite', e);
}
if(typeof data.startMoving==='undefined'){
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&&(swiper.allowSlideNext===true||swiper.allowSlidePrev===true)){
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&&swiper.swipeDirection==='next'&&data.currentTranslate < data.startTranslate){
data.currentTranslate=data.startTranslate;
}
if(!swiper.allowSlidePrev&&swiper.swipeDirection==='prev'&&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&&(swiper.allowSlideNext===true||swiper.allowSlidePrev===true)){
swiper.setGrabCursor(false);
}
const touchEndTime=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=now();
nextTick(()=> {
if(!swiper.destroyed) swiper.allowClick=true;
});
if(!data.isTouched||!data.isMoved||!swiper.swipeDirection||touches.diff===0||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(typeof slidesGrid[i + increment]!=='undefined'){
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(swiper.swipeDirection==='next'){
if(ratio >=params.longSwipesRatio) swiper.slideTo(params.rewind&&swiper.isEnd ? rewindFirstIndex:stopIndex + increment);else swiper.slideTo(stopIndex);
}
if(swiper.swipeDirection==='prev'){
if(ratio > 1 - params.longSwipesRatio){
swiper.slideTo(stopIndex + increment);
}else if(rewindLastIndex!==null&&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(swiper.swipeDirection==='next'){
swiper.slideTo(rewindFirstIndex!==null ? rewindFirstIndex:stopIndex + increment);
}
if(swiper.swipeDirection==='prev'){
swiper.slideTo(rewindLastIndex!==null ? 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&&el.offsetWidth===0) return;
if(params.breakpoints){
swiper.setBreakpoint();
}
const {
allowSlideNext,
allowSlidePrev,
snapGrid
}=swiper;
swiper.allowSlideNext=true;
swiper.allowSlidePrev=true;
swiper.updateSize();
swiper.updateSlides();
swiper.updateSlidesClasses();
if((params.slidesPerView==='auto'||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(swiper.translate===0) swiper.translate=0;
swiper.updateActiveIndex();
swiper.updateSlidesClasses();
let newProgress;
const translatesDiff=swiper.maxTranslate() - swiper.minTranslate();
if(translatesDiff===0){
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=getDocument();
const {
params,
touchEvents,
el,
wrapperEl,
device,
support
}=swiper;
const capture = !!params.nested;
const domMethod=method==='on' ? '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=touchEvents.start==='touchstart'&&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=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');
}
var events$1={
attachEvents,
detachEvents
};
const isGridEnabled=(swiper, params)=> {
return 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&&Object.keys(breakpoints).length===0) return;
const breakpoint=swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);
if(!breakpoint||swiper.currentBreakpoint===breakpoint) return;
const breakpointOnlyParams=breakpoint in breakpoints ? breakpoints[breakpoint]:undefined;
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&&breakpointParams.grid.fill==='column'||!breakpointParams.grid.fill&&params.grid.fill==='column'){
$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();
}
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(base===void 0){
base='window';
}
if(!breakpoints||base==='container'&&!containerEl) return undefined;
let breakpoint=false;
const window=getWindow();
const currentHeight=base==='window' ? window.innerHeight:containerEl.clientHeight;
const points=Object.keys(breakpoints).map(point=> {
if(typeof point==='string'&&point.indexOf('@')===0){
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(base==='window'){
if(window.matchMedia(`(min-width: ${value}px)`).matches){
breakpoint=point;
}}else if(value <=containerEl.clientWidth){
breakpoint=point;
}}
return breakpoint||'max';
}
var breakpoints={
setBreakpoint,
getBreakpoint
};
function prepareClasses(entries, prefix){
const resultClasses=[];
entries.forEach(item=> {
if(typeof item==='object'){
Object.keys(item).forEach(classNames=> {
if(item[classNames]){
resultClasses.push(prefix + classNames);
}});
}else if(typeof item==='string'){
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': rtl
}, {
'grid': params.grid&&params.grid.rows > 1
}, {
'grid-column': params.grid&&params.grid.rows > 1&&params.grid.fill==='column'
}, {
'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(){
const swiper=this;
const {
$el,
classNames
}=swiper;
$el.removeClass(classNames.join(' '));
swiper.emitContainerClasses();
}
var classes={
addClasses,
removeClasses
};
function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback){
const window=getWindow();
let image;
function onReady(){
if(callback) callback();
}
const isPicture=$(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(typeof swiper==='undefined'||swiper===null||!swiper||swiper.destroyed) return;
if(swiper.imagesLoaded!==undefined) 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);
}}
var 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] + slidesOffsetBefore * 2;
swiper.isLocked=swiper.size > lastSlideRightEdge;
}else{
swiper.isLocked=swiper.snapGrid.length===1;
}
if(params.allowSlideNext===true){
swiper.allowSlideNext = !swiper.isLocked;
}
if(params.allowSlidePrev===true){
swiper.allowSlidePrev = !swiper.isLocked;
}
if(wasLocked&&wasLocked!==swiper.isLocked){
swiper.isEnd=false;
}
if(wasLocked!==swiper.isLocked){
swiper.emit(swiper.isLocked ? 'lock':'unlock');
}}
var checkOverflow$1={
checkOverflow
};
var 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: undefined,
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: 0.5,
longSwipesMs: 300,
followFinger: true,
allowTouchMove: true,
threshold: 0,
touchMoveStopPropagation: false,
touchStartPreventDefault: true,
touchStartForcePreventDefault: false,
touchReleaseOnEdges: false,
uniqueNavElements: true,
resistance: true,
resistanceRatio: 0.85,
watchSlidesProgress: false,
grabCursor: false,
preventClicks: true,
preventClicksPropagation: true,
slideToClickedSlide: false,
preloadImages: true,
updateOnImagesReady: true,
loop: false,
loopAdditionalSlides: 0,
loopedSlides: null,
loopedSlidesLimit: true,
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(obj===void 0){
obj={};}
const moduleParamName=Object.keys(obj)[0];
const moduleParams=obj[moduleParamName];
if(typeof moduleParams!=='object'||moduleParams===null){
extend(allModulesParams, obj);
return;
}
if(['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >=0&&params[moduleParamName]===true){
params[moduleParamName]={
auto: true
};}
if(!(moduleParamName in params&&'enabled' in moduleParams)){
extend(allModulesParams, obj);
return;
}
if(params[moduleParamName]===true){
params[moduleParamName]={
enabled: true
};}
if(typeof params[moduleParamName]==='object'&&!('enabled' in params[moduleParamName])){
params[moduleParamName].enabled=true;
}
if(!params[moduleParamName]) params[moduleParamName]={
enabled: false
};
extend(allModulesParams, obj);
};}
const prototypes={
eventsEmitter,
update,
translate,
transition,
slide,
loop,
grabCursor,
events: events$1,
breakpoints,
checkOverflow: checkOverflow$1,
classes,
images
};
const extendedDefaults={};
class 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(args.length===1&&args[0].constructor&&Object.prototype.toString.call(args[0]).slice(8, -1)==='Object'){
params=args[0];
}else{
[el, params]=args;
}
if(!params) params={};
params=extend({}, params);
if(el&&!params.el) params.el=el;
if(params.el&&$(params.el).length > 1){
const swipers=[];
$(params.el).each(containerEl=> {
const newParams=extend({}, params, {
el: containerEl
});
swipers.push(new 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=extend({}, defaults, allModulesParams);
swiper.params=extend({}, swiperParams, extendedDefaults, params);
swiper.originalParams=extend({}, swiper.params);
swiper.passedParams=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.$=$;
Object.assign(swiper, {
enabled: swiper.params.enabled,
el,
classNames: [],
slides: $(),
slidesGrid: [],
snapGrid: [],
slidesSizesGrid: [],
isHorizontal(){
return swiper.params.direction==='horizontal';
},
isVertical(){
return swiper.params.direction==='vertical';
},
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: undefined,
isMoved: undefined,
allowTouchCallbacks: undefined,
touchStartTime: undefined,
isScrolling: undefined,
currentTranslate: undefined,
startTranslate: undefined,
allowThresholdMove: undefined,
focusableElements: swiper.params.focusableElements,
lastClickTime: now(),
clickTimeout: undefined,
velocities: [],
allowMomentumBounce: undefined,
isTouchEvent: undefined,
startMoving: undefined
},
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, typeof speed==='undefined' ? 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=> {
return className.indexOf('swiper')===0||className.indexOf(swiper.params.containerModifierClass)===0;
});
swiper.emit('_containerClasses', cls.join(' '));
}
getSlideClasses(slideEl){
const swiper=this;
if(swiper.destroyed) return '';
return slideEl.className.split(' ').filter(className=> {
return className.indexOf('swiper-slide')===0||className.indexOf(swiper.params.slideClass)===0;
}).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(view===void 0){
view='current';
}
if(exact===void 0){
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(view==='current'){
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 ? swiper.translate * -1: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((swiper.params.slidesPerView==='auto'||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(needUpdate===void 0){
needUpdate=true;
}
const swiper=this;
const currentDirection=swiper.params.direction;
if(!newDirection){
newDirection=currentDirection==='horizontal' ? 'vertical':'horizontal';
}
if(newDirection===currentDirection||newDirection!=='horizontal'&&newDirection!=='vertical'){
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(newDirection==='vertical'){
slideEl.style.width='';
}else{
slideEl.style.height='';
}});
swiper.emit('changeDirection');
if(needUpdate) swiper.update();
return swiper;
}
changeLanguageDirection(direction){
const swiper=this;
if(swiper.rtl&&direction==='rtl'||!swiper.rtl&&direction==='ltr') return;
swiper.rtl=direction==='rtl';
swiper.rtlTranslate=swiper.params.direction==='horizontal'&&swiper.rtl;
if(swiper.rtl){
swiper.$el.addClass(`${swiper.params.containerModifierClass}rtl`);
swiper.el.dir='rtl';
}else{
swiper.$el.removeClass(`${swiper.params.containerModifierClass}rtl`);
swiper.el.dir='ltr';
}
swiper.update();
}
mount(el){
const swiper=this;
if(swiper.mounted) return true;
const $el=$(el||swiper.params.el);
el=$el[0];
if(!el){
return false;
}
el.swiper=swiper;
const getWrapperSelector=()=> {
return `.${(swiper.params.wrapperClass||'').trim().split(' ').join('.')}`;
};
const getWrapper=()=> {
if(el&&el.shadowRoot&&el.shadowRoot.querySelector){
const res=$(el.shadowRoot.querySelector(getWrapperSelector()));
res.children=options=> $el.children(options);
return res;
}
if(!$el.children){
return $($el).children(getWrapperSelector());
}
return $el.children(getWrapperSelector());
};
let $wrapperEl=getWrapper();
if($wrapperEl.length===0&&swiper.params.createElements){
const document=getDocument();
const wrapper=document.createElement('div');
$wrapperEl=$(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: el.dir.toLowerCase()==='rtl'||$el.css('direction')==='rtl',
rtlTranslate: swiper.params.direction==='horizontal'&&(el.dir.toLowerCase()==='rtl'||$el.css('direction')==='rtl'),
wrongRTL: $wrapperEl.css('display')==='-webkit-box'
});
return true;
}
init(el){
const swiper=this;
if(swiper.initialized) return swiper;
const mounted=swiper.mount(el);
if(mounted===false) 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(deleteInstance===void 0){
deleteInstance=true;
}
if(cleanStyles===void 0){
cleanStyles=true;
}
const swiper=this;
const {
params,
$el,
$wrapperEl,
slides
}=swiper;
if(typeof swiper.params==='undefined'||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(deleteInstance!==false){
swiper.$el[0].swiper=null;
deleteProps(swiper);
}
swiper.destroyed=true;
return null;
}
static extendDefaults(newDefaults){
extend(extendedDefaults, newDefaults);
}
static get extendedDefaults(){
return extendedDefaults;
}
static get defaults(){
return defaults;
}
static installModule(mod){
if(!Swiper.prototype.__modules__) Swiper.prototype.__modules__=[];
const modules=Swiper.prototype.__modules__;
if(typeof mod==='function'&&modules.indexOf(mod) < 0){
modules.push(mod);
}}
static use(module){
if(Array.isArray(module)){
module.forEach(m=> Swiper.installModule(m));
return Swiper;
}
Swiper.installModule(module);
return Swiper;
}}
Object.keys(prototypes).forEach(prototypeGroup=> {
Object.keys(prototypes[prototypeGroup]).forEach(protoMethod=> {
Swiper.prototype[protoMethod]=prototypes[prototypeGroup][protoMethod];
});
});
Swiper.use([Resize, Observer]);
function Virtual(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
extendParams({
virtual: {
enabled: false,
slides: [],
cache: true,
renderSlide: null,
renderExternal: null,
renderExternalUpdate: true,
addSlidesBefore: 0,
addSlidesAfter: 0
}});
let cssModeTimeout;
swiper.virtual={
cache: {},
from: undefined,
to: undefined,
slides: [],
offset: 0,
slidesGrid: []
};
function renderSlide(slide, index){
const params=swiper.params.virtual;
if(params.cache&&swiper.virtual.cache[index]){
return swiper.virtual.cache[index];
}
const $slideEl=params.renderSlide ? $(params.renderSlide.call(swiper, slide, index)):$(`<div class="${swiper.params.slideClass}" data-swiper-slide-index="${index}">${slide}</div>`);
if(!$slideEl.attr('data-swiper-slide-index')) $slideEl.attr('data-swiper-slide-index', index);
if(params.cache) swiper.virtual.cache[index]=$slideEl;
return $slideEl;
}
function update(force){
const {
slidesPerView,
slidesPerGroup,
centeredSlides
}=swiper.params;
const {
addSlidesBefore,
addSlidesAfter
}=swiper.params.virtual;
const {
from: previousFrom,
to: previousTo,
slides,
slidesGrid: previousSlidesGrid,
offset: previousOffset
}=swiper.virtual;
if(!swiper.params.cssMode){
swiper.updateActiveIndex();
}
const activeIndex=swiper.activeIndex||0;
let offsetProp;
if(swiper.rtlTranslate) offsetProp='right';else offsetProp=swiper.isHorizontal() ? 'left':'top';
let slidesAfter;
let slidesBefore;
if(centeredSlides){
slidesAfter=Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;
slidesBefore=Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;
}else{
slidesAfter=slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;
slidesBefore=slidesPerGroup + addSlidesBefore;
}
const from=Math.max((activeIndex||0) - slidesBefore, 0);
const to=Math.min((activeIndex||0) + slidesAfter, slides.length - 1);
const offset=(swiper.slidesGrid[from]||0) - (swiper.slidesGrid[0]||0);
Object.assign(swiper.virtual, {
from,
to,
offset,
slidesGrid: swiper.slidesGrid
});
function onRendered(){
swiper.updateSlides();
swiper.updateProgress();
swiper.updateSlidesClasses();
if(swiper.lazy&&swiper.params.lazy.enabled){
swiper.lazy.load();
}
emit('virtualUpdate');
}
if(previousFrom===from&&previousTo===to&&!force){
if(swiper.slidesGrid!==previousSlidesGrid&&offset!==previousOffset){
swiper.slides.css(offsetProp, `${offset}px`);
}
swiper.updateProgress();
emit('virtualUpdate');
return;
}
if(swiper.params.virtual.renderExternal){
swiper.params.virtual.renderExternal.call(swiper, {
offset,
from,
to,
slides: function getSlides(){
const slidesToRender=[];
for (let i=from; i <=to; i +=1){
slidesToRender.push(slides[i]);
}
return slidesToRender;
}()
});
if(swiper.params.virtual.renderExternalUpdate){
onRendered();
}else{
emit('virtualUpdate');
}
return;
}
const prependIndexes=[];
const appendIndexes=[];
if(force){
swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();
}else{
for (let i=previousFrom; i <=previousTo; i +=1){
if(i < from||i > to){
swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index="${i}"]`).remove();
}}
}
for (let i=0; i < slides.length; i +=1){
if(i >=from&&i <=to){
if(typeof previousTo==='undefined'||force){
appendIndexes.push(i);
}else{
if(i > previousTo) appendIndexes.push(i);
if(i < previousFrom) prependIndexes.push(i);
}}
}
appendIndexes.forEach(index=> {
swiper.$wrapperEl.append(renderSlide(slides[index], index));
});
prependIndexes.sort((a, b)=> b - a).forEach(index=> {
swiper.$wrapperEl.prepend(renderSlide(slides[index], index));
});
swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, `${offset}px`);
onRendered();
}
function appendSlide(slides){
if(typeof slides==='object'&&'length' in slides){
for (let i=0; i < slides.length; i +=1){
if(slides[i]) swiper.virtual.slides.push(slides[i]);
}}else{
swiper.virtual.slides.push(slides);
}
update(true);
}
function prependSlide(slides){
const activeIndex=swiper.activeIndex;
let newActiveIndex=activeIndex + 1;
let numberOfNewSlides=1;
if(Array.isArray(slides)){
for (let i=0; i < slides.length; i +=1){
if(slides[i]) swiper.virtual.slides.unshift(slides[i]);
}
newActiveIndex=activeIndex + slides.length;
numberOfNewSlides=slides.length;
}else{
swiper.virtual.slides.unshift(slides);
}
if(swiper.params.virtual.cache){
const cache=swiper.virtual.cache;
const newCache={};
Object.keys(cache).forEach(cachedIndex=> {
const $cachedEl=cache[cachedIndex];
const cachedElIndex=$cachedEl.attr('data-swiper-slide-index');
if(cachedElIndex){
$cachedEl.attr('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);
}
newCache[parseInt(cachedIndex, 10) + numberOfNewSlides]=$cachedEl;
});
swiper.virtual.cache=newCache;
}
update(true);
swiper.slideTo(newActiveIndex, 0);
}
function removeSlide(slidesIndexes){
if(typeof slidesIndexes==='undefined'||slidesIndexes===null) return;
let activeIndex=swiper.activeIndex;
if(Array.isArray(slidesIndexes)){
for (let i=slidesIndexes.length - 1; i >=0; i -=1){
swiper.virtual.slides.splice(slidesIndexes[i], 1);
if(swiper.params.virtual.cache){
delete swiper.virtual.cache[slidesIndexes[i]];
}
if(slidesIndexes[i] < activeIndex) activeIndex -=1;
activeIndex=Math.max(activeIndex, 0);
}}else{
swiper.virtual.slides.splice(slidesIndexes, 1);
if(swiper.params.virtual.cache){
delete swiper.virtual.cache[slidesIndexes];
}
if(slidesIndexes < activeIndex) activeIndex -=1;
activeIndex=Math.max(activeIndex, 0);
}
update(true);
swiper.slideTo(activeIndex, 0);
}
function removeAllSlides(){
swiper.virtual.slides=[];
if(swiper.params.virtual.cache){
swiper.virtual.cache={};}
update(true);
swiper.slideTo(0, 0);
}
on('beforeInit', ()=> {
if(!swiper.params.virtual.enabled) return;
swiper.virtual.slides=swiper.params.virtual.slides;
swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);
swiper.params.watchSlidesProgress=true;
swiper.originalParams.watchSlidesProgress=true;
if(!swiper.params.initialSlide){
update();
}});
on('setTranslate', ()=> {
if(!swiper.params.virtual.enabled) return;
if(swiper.params.cssMode&&!swiper._immediateVirtual){
clearTimeout(cssModeTimeout);
cssModeTimeout=setTimeout(()=> {
update();
}, 100);
}else{
update();
}});
on('init update resize', ()=> {
if(!swiper.params.virtual.enabled) return;
if(swiper.params.cssMode){
setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);
}});
Object.assign(swiper.virtual, {
appendSlide,
prependSlide,
removeSlide,
removeAllSlides,
update
});
}
function Keyboard(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
const document=getDocument();
const window=getWindow();
swiper.keyboard={
enabled: false
};
extendParams({
keyboard: {
enabled: false,
onlyInViewport: true,
pageUpDown: true
}});
function handle(event){
if(!swiper.enabled) return;
const {
rtlTranslate: rtl
}=swiper;
let e=event;
if(e.originalEvent) e=e.originalEvent;
const kc=e.keyCode||e.charCode;
const pageUpDown=swiper.params.keyboard.pageUpDown;
const isPageUp=pageUpDown&&kc===33;
const isPageDown=pageUpDown&&kc===34;
const isArrowLeft=kc===37;
const isArrowRight=kc===39;
const isArrowUp=kc===38;
const isArrowDown=kc===40;
if(!swiper.allowSlideNext&&(swiper.isHorizontal()&&isArrowRight||swiper.isVertical()&&isArrowDown||isPageDown)){
return false;
}
if(!swiper.allowSlidePrev&&(swiper.isHorizontal()&&isArrowLeft||swiper.isVertical()&&isArrowUp||isPageUp)){
return false;
}
if(e.shiftKey||e.altKey||e.ctrlKey||e.metaKey){
return undefined;
}
if(document.activeElement&&document.activeElement.nodeName&&(document.activeElement.nodeName.toLowerCase()==='input'||document.activeElement.nodeName.toLowerCase()==='textarea')){
return undefined;
}
if(swiper.params.keyboard.onlyInViewport&&(isPageUp||isPageDown||isArrowLeft||isArrowRight||isArrowUp||isArrowDown)){
let inView=false;
if(swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0&&swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length===0){
return undefined;
}
const $el=swiper.$el;
const swiperWidth=$el[0].clientWidth;
const swiperHeight=$el[0].clientHeight;
const windowWidth=window.innerWidth;
const windowHeight=window.innerHeight;
const swiperOffset=swiper.$el.offset();
if(rtl) swiperOffset.left -=swiper.$el[0].scrollLeft;
const swiperCoord=[[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];
for (let i=0; i < swiperCoord.length; i +=1){
const point=swiperCoord[i];
if(point[0] >=0&&point[0] <=windowWidth&&point[1] >=0&&point[1] <=windowHeight){
if(point[0]===0&&point[1]===0) continue;
inView=true;
}}
if(!inView) return undefined;
}
if(swiper.isHorizontal()){
if(isPageUp||isPageDown||isArrowLeft||isArrowRight){
if(e.preventDefault) e.preventDefault();else e.returnValue=false;
}
if((isPageDown||isArrowRight)&&!rtl||(isPageUp||isArrowLeft)&&rtl) swiper.slideNext();
if((isPageUp||isArrowLeft)&&!rtl||(isPageDown||isArrowRight)&&rtl) swiper.slidePrev();
}else{
if(isPageUp||isPageDown||isArrowUp||isArrowDown){
if(e.preventDefault) e.preventDefault();else e.returnValue=false;
}
if(isPageDown||isArrowDown) swiper.slideNext();
if(isPageUp||isArrowUp) swiper.slidePrev();
}
emit('keyPress', kc);
return undefined;
}
function enable(){
if(swiper.keyboard.enabled) return;
$(document).on('keydown', handle);
swiper.keyboard.enabled=true;
}
function disable(){
if(!swiper.keyboard.enabled) return;
$(document).off('keydown', handle);
swiper.keyboard.enabled=false;
}
on('init', ()=> {
if(swiper.params.keyboard.enabled){
enable();
}});
on('destroy', ()=> {
if(swiper.keyboard.enabled){
disable();
}});
Object.assign(swiper.keyboard, {
enable,
disable
});
}
function Mousewheel(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
const window=getWindow();
extendParams({
mousewheel: {
enabled: false,
releaseOnEdges: false,
invert: false,
forceToAxis: false,
sensitivity: 1,
eventsTarget: 'container',
thresholdDelta: null,
thresholdTime: null
}});
swiper.mousewheel={
enabled: false
};
let timeout;
let lastScrollTime=now();
let lastEventBeforeSnap;
const recentWheelEvents=[];
function normalize(e){
const PIXEL_STEP=10;
const LINE_HEIGHT=40;
const PAGE_HEIGHT=800;
let sX=0;
let sY=0;
let pX=0;
let pY=0;
if('detail' in e){
sY=e.detail;
}
if('wheelDelta' in e){
sY=-e.wheelDelta / 120;
}
if('wheelDeltaY' in e){
sY=-e.wheelDeltaY / 120;
}
if('wheelDeltaX' in e){
sX=-e.wheelDeltaX / 120;
}
if('axis' in e&&e.axis===e.HORIZONTAL_AXIS){
sX=sY;
sY=0;
}
pX=sX * PIXEL_STEP;
pY=sY * PIXEL_STEP;
if('deltaY' in e){
pY=e.deltaY;
}
if('deltaX' in e){
pX=e.deltaX;
}
if(e.shiftKey&&!pX){
pX=pY;
pY=0;
}
if((pX||pY)&&e.deltaMode){
if(e.deltaMode===1){
pX *=LINE_HEIGHT;
pY *=LINE_HEIGHT;
}else{
pX *=PAGE_HEIGHT;
pY *=PAGE_HEIGHT;
}}
if(pX&&!sX){
sX=pX < 1 ? -1:1;
}
if(pY&&!sY){
sY=pY < 1 ? -1:1;
}
return {
spinX: sX,
spinY: sY,
pixelX: pX,
pixelY: pY
};}
function handleMouseEnter(){
if(!swiper.enabled) return;
swiper.mouseEntered=true;
}
function handleMouseLeave(){
if(!swiper.enabled) return;
swiper.mouseEntered=false;
}
function animateSlider(newEvent){
if(swiper.params.mousewheel.thresholdDelta&&newEvent.delta < swiper.params.mousewheel.thresholdDelta){
return false;
}
if(swiper.params.mousewheel.thresholdTime&&now() - lastScrollTime < swiper.params.mousewheel.thresholdTime){
return false;
}
if(newEvent.delta >=6&&now() - lastScrollTime < 60){
return true;
}
if(newEvent.direction < 0){
if((!swiper.isEnd||swiper.params.loop)&&!swiper.animating){
swiper.slideNext();
emit('scroll', newEvent.raw);
}}else if((!swiper.isBeginning||swiper.params.loop)&&!swiper.animating){
swiper.slidePrev();
emit('scroll', newEvent.raw);
}
lastScrollTime=new window.Date().getTime();
return false;
}
function releaseScroll(newEvent){
const params=swiper.params.mousewheel;
if(newEvent.direction < 0){
if(swiper.isEnd&&!swiper.params.loop&&params.releaseOnEdges){
return true;
}}else if(swiper.isBeginning&&!swiper.params.loop&&params.releaseOnEdges){
return true;
}
return false;
}
function handle(event){
let e=event;
let disableParentSwiper=true;
if(!swiper.enabled) return;
const params=swiper.params.mousewheel;
if(swiper.params.cssMode){
e.preventDefault();
}
let target=swiper.$el;
if(swiper.params.mousewheel.eventsTarget!=='container'){
target=$(swiper.params.mousewheel.eventsTarget);
}
if(!swiper.mouseEntered&&!target[0].contains(e.target)&&!params.releaseOnEdges) return true;
if(e.originalEvent) e=e.originalEvent;
let delta=0;
const rtlFactor=swiper.rtlTranslate ? -1:1;
const data=normalize(e);
if(params.forceToAxis){
if(swiper.isHorizontal()){
if(Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta=-data.pixelX * rtlFactor;else return true;
}else if(Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta=-data.pixelY;else return true;
}else{
delta=Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor:-data.pixelY;
}
if(delta===0) return true;
if(params.invert) delta=-delta;
let positions=swiper.getTranslate() + delta * params.sensitivity;
if(positions >=swiper.minTranslate()) positions=swiper.minTranslate();
if(positions <=swiper.maxTranslate()) positions=swiper.maxTranslate();
disableParentSwiper=swiper.params.loop ? true:!(positions===swiper.minTranslate()||positions===swiper.maxTranslate());
if(disableParentSwiper&&swiper.params.nested) e.stopPropagation();
if(!swiper.params.freeMode||!swiper.params.freeMode.enabled){
const newEvent={
time: now(),
delta: Math.abs(delta),
direction: Math.sign(delta),
raw: event
};
if(recentWheelEvents.length >=2){
recentWheelEvents.shift();
}
const prevEvent=recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1]:undefined;
recentWheelEvents.push(newEvent);
if(prevEvent){
if(newEvent.direction!==prevEvent.direction||newEvent.delta > prevEvent.delta||newEvent.time > prevEvent.time + 150){
animateSlider(newEvent);
}}else{
animateSlider(newEvent);
}
if(releaseScroll(newEvent)){
return true;
}}else{
const newEvent={
time: now(),
delta: Math.abs(delta),
direction: Math.sign(delta)
};
const ignoreWheelEvents=lastEventBeforeSnap&&newEvent.time < lastEventBeforeSnap.time + 500&&newEvent.delta <=lastEventBeforeSnap.delta&&newEvent.direction===lastEventBeforeSnap.direction;
if(!ignoreWheelEvents){
lastEventBeforeSnap=undefined;
if(swiper.params.loop){
swiper.loopFix();
}
let position=swiper.getTranslate() + delta * params.sensitivity;
const wasBeginning=swiper.isBeginning;
const wasEnd=swiper.isEnd;
if(position >=swiper.minTranslate()) position=swiper.minTranslate();
if(position <=swiper.maxTranslate()) position=swiper.maxTranslate();
swiper.setTransition(0);
swiper.setTranslate(position);
swiper.updateProgress();
swiper.updateActiveIndex();
swiper.updateSlidesClasses();
if(!wasBeginning&&swiper.isBeginning||!wasEnd&&swiper.isEnd){
swiper.updateSlidesClasses();
}
if(swiper.params.freeMode.sticky){
clearTimeout(timeout);
timeout=undefined;
if(recentWheelEvents.length >=15){
recentWheelEvents.shift();
}
const prevEvent=recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1]:undefined;
const firstEvent=recentWheelEvents[0];
recentWheelEvents.push(newEvent);
if(prevEvent&&(newEvent.delta > prevEvent.delta||newEvent.direction!==prevEvent.direction)){
recentWheelEvents.splice(0);
}else if(recentWheelEvents.length >=15&&newEvent.time - firstEvent.time < 500&&firstEvent.delta - newEvent.delta >=1&&newEvent.delta <=6){
const snapToThreshold=delta > 0 ? 0.8:0.2;
lastEventBeforeSnap=newEvent;
recentWheelEvents.splice(0);
timeout=nextTick(()=> {
swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
}, 0);
}
if(!timeout){
timeout=nextTick(()=> {
const snapToThreshold=0.5;
lastEventBeforeSnap=newEvent;
recentWheelEvents.splice(0);
swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
}, 500);
}}
if(!ignoreWheelEvents) emit('scroll', e);
if(swiper.params.autoplay&&swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop();
if(position===swiper.minTranslate()||position===swiper.maxTranslate()) return true;
}}
if(e.preventDefault) e.preventDefault();else e.returnValue=false;
return false;
}
function events(method){
let target=swiper.$el;
if(swiper.params.mousewheel.eventsTarget!=='container'){
target=$(swiper.params.mousewheel.eventsTarget);
}
target[method]('mouseenter', handleMouseEnter);
target[method]('mouseleave', handleMouseLeave);
target[method]('wheel', handle);
}
function enable(){
if(swiper.params.cssMode){
swiper.wrapperEl.removeEventListener('wheel', handle);
return true;
}
if(swiper.mousewheel.enabled) return false;
events('on');
swiper.mousewheel.enabled=true;
return true;
}
function disable(){
if(swiper.params.cssMode){
swiper.wrapperEl.addEventListener(event, handle);
return true;
}
if(!swiper.mousewheel.enabled) return false;
events('off');
swiper.mousewheel.enabled=false;
return true;
}
on('init', ()=> {
if(!swiper.params.mousewheel.enabled&&swiper.params.cssMode){
disable();
}
if(swiper.params.mousewheel.enabled) enable();
});
on('destroy', ()=> {
if(swiper.params.cssMode){
enable();
}
if(swiper.mousewheel.enabled) disable();
});
Object.assign(swiper.mousewheel, {
enable,
disable
});
}
function createElementIfNotDefined(swiper, originalParams, params, checkProps){
const document=getDocument();
if(swiper.params.createElements){
Object.keys(checkProps).forEach(key=> {
if(!params[key]&&params.auto===true){
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=$(el);
if(swiper.params.uniqueNavElements&&typeof el==='string'&&$el.length > 1&&swiper.$el.find(el).length===1){
$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]&&$el[0].tagName==='BUTTON') $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();
emit('navigationPrev');
}
function onNextClick(e){
e.preventDefault();
if(swiper.isEnd&&!swiper.params.loop&&!swiper.params.rewind) return;
swiper.slideNext();
emit('navigationNext');
}
function init(){
const params=swiper.params.navigation;
swiper.params.navigation=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(swiper.params.navigation.enabled===false){
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&&!$(targetEl).is($prevEl)&&!$(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(isHidden===true){
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 classesToSelector(classes){
if(classes===void 0){
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||swiper.pagination.$el.length===0;
}
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 - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup):swiper.snapGrid.length;
if(swiper.params.loop){
current=Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);
if(current > slidesLength - 1 - swiper.loopedSlides * 2){
current -=slidesLength - swiper.loopedSlides * 2;
}
if(current > total - 1) current -=total;
if(current < 0&&swiper.params.paginationType!=='bullets') current=total + current;
}else if(typeof swiper.snapIndex!=='undefined'){
current=swiper.snapIndex;
}else{
current=swiper.activeIndex||0;
}
if(params.type==='bullets'&&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&&swiper.previousIndex!==undefined){
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=$(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(params.type==='fraction'){
$el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));
$el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));
}
if(params.type==='progressbar'){
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(progressbarDirection==='horizontal'){
scaleX=scale;
}else{
scaleY=scale;
}
$el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);
}
if(params.type==='custom'&&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(params.type==='bullets'){
let numberOfBullets=swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / 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}"></${params.bulletElement}>`;
}}
$el.html(paginationHTML);
swiper.pagination.bullets=$el.find(classesToSelector(params.bulletClass));
}
if(params.type==='fraction'){
if(params.renderFraction){
paginationHTML=params.renderFraction.call(swiper, params.currentClass, params.totalClass);
}else{
paginationHTML=`<span class="${params.currentClass}"></span>` + ' / ' + `<span class="${params.totalClass}"></span>`;
}
$el.html(paginationHTML);
}
if(params.type==='progressbar'){
if(params.renderProgressbar){
paginationHTML=params.renderProgressbar.call(swiper, params.progressbarFillClass);
}else{
paginationHTML=`<span class="${params.progressbarFillClass}"></span>`;
}
$el.html(paginationHTML);
}
if(params.type!=='custom'){
emit('paginationRender', swiper.pagination.$el[0]);
}}
function init(){
swiper.params.pagination=createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {
el: 'swiper-pagination'
});
const params=swiper.params.pagination;
if(!params.el) return;
let $el=$(params.el);
if($el.length===0) return;
if(swiper.params.uniqueNavElements&&typeof params.el==='string'&&$el.length > 1){
$el=swiper.$el.find(params.el);
if($el.length > 1){
$el=$el.filter(el=> {
if($(el).parents('.swiper')[0]!==swiper.el) return false;
return true;
});
}}
if(params.type==='bullets'&&params.clickable){
$el.addClass(params.clickableClass);
}
$el.addClass(params.modifierClass + params.type);
$el.addClass(swiper.isHorizontal() ? params.horizontalClass:params.verticalClass);
if(params.type==='bullets'&&params.dynamicBullets){
$el.addClass(`${params.modifierClass}${params.type}-dynamic`);
dynamicBulletIndex=0;
if(params.dynamicMainBullets < 1){
params.dynamicMainBullets=1;
}}
if(params.type==='progressbar'&&params.progressbarOpposite){
$el.addClass(params.progressbarOppositeClass);
}
if(params.clickable){
$el.on('click', classesToSelector(params.bulletClass), function onClick(e){
e.preventDefault();
let index=$(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', classesToSelector(params.bulletClass));
}}
on('init', ()=> {
if(swiper.params.pagination.enabled===false){
disable();
}else{
init();
render();
update();
}});
on('activeIndexChange', ()=> {
if(swiper.params.loop){
update();
}else if(typeof swiper.snapIndex==='undefined'){
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&&$el.length > 0&&!$(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(isHidden===true){
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 Scrollbar(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
const document=getDocument();
let isTouched=false;
let timeout=null;
let dragTimeout=null;
let dragStartPos;
let dragSize;
let trackSize;
let divider;
extendParams({
scrollbar: {
el: null,
dragSize: 'auto',
hide: false,
draggable: false,
snapOnRelease: true,
lockClass: 'swiper-scrollbar-lock',
dragClass: 'swiper-scrollbar-drag',
scrollbarDisabledClass: 'swiper-scrollbar-disabled',
horizontalClass: `swiper-scrollbar-horizontal`,
verticalClass: `swiper-scrollbar-vertical`
}});
swiper.scrollbar={
el: null,
dragEl: null,
$el: null,
$dragEl: null
};
function setTranslate(){
if(!swiper.params.scrollbar.el||!swiper.scrollbar.el) return;
const {
scrollbar,
rtlTranslate: rtl,
progress
}=swiper;
const {
$dragEl,
$el
}=scrollbar;
const params=swiper.params.scrollbar;
let newSize=dragSize;
let newPos=(trackSize - dragSize) * progress;
if(rtl){
newPos=-newPos;
if(newPos > 0){
newSize=dragSize - newPos;
newPos=0;
}else if(-newPos + dragSize > trackSize){
newSize=trackSize + newPos;
}}else if(newPos < 0){
newSize=dragSize + newPos;
newPos=0;
}else if(newPos + dragSize > trackSize){
newSize=trackSize - newPos;
}
if(swiper.isHorizontal()){
$dragEl.transform(`translate3d(${newPos}px, 0, 0)`);
$dragEl[0].style.width=`${newSize}px`;
}else{
$dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);
$dragEl[0].style.height=`${newSize}px`;
}
if(params.hide){
clearTimeout(timeout);
$el[0].style.opacity=1;
timeout=setTimeout(()=> {
$el[0].style.opacity=0;
$el.transition(400);
}, 1000);
}}
function setTransition(duration){
if(!swiper.params.scrollbar.el||!swiper.scrollbar.el) return;
swiper.scrollbar.$dragEl.transition(duration);
}
function updateSize(){
if(!swiper.params.scrollbar.el||!swiper.scrollbar.el) return;
const {
scrollbar
}=swiper;
const {
$dragEl,
$el
}=scrollbar;
$dragEl[0].style.width='';
$dragEl[0].style.height='';
trackSize=swiper.isHorizontal() ? $el[0].offsetWidth:$el[0].offsetHeight;
divider=swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0]:0));
if(swiper.params.scrollbar.dragSize==='auto'){
dragSize=trackSize * divider;
}else{
dragSize=parseInt(swiper.params.scrollbar.dragSize, 10);
}
if(swiper.isHorizontal()){
$dragEl[0].style.width=`${dragSize}px`;
}else{
$dragEl[0].style.height=`${dragSize}px`;
}
if(divider >=1){
$el[0].style.display='none';
}else{
$el[0].style.display='';
}
if(swiper.params.scrollbar.hide){
$el[0].style.opacity=0;
}
if(swiper.params.watchOverflow&&swiper.enabled){
scrollbar.$el[swiper.isLocked ? 'addClass':'removeClass'](swiper.params.scrollbar.lockClass);
}}
function getPointerPosition(e){
if(swiper.isHorizontal()){
return e.type==='touchstart'||e.type==='touchmove' ? e.targetTouches[0].clientX:e.clientX;
}
return e.type==='touchstart'||e.type==='touchmove' ? e.targetTouches[0].clientY:e.clientY;
}
function setDragPosition(e){
const {
scrollbar,
rtlTranslate: rtl
}=swiper;
const {
$el
}=scrollbar;
let positionRatio;
positionRatio=(getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? 'left':'top'] - (dragStartPos!==null ? dragStartPos:dragSize / 2)) / (trackSize - dragSize);
positionRatio=Math.max(Math.min(positionRatio, 1), 0);
if(rtl){
positionRatio=1 - positionRatio;
}
const position=swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;
swiper.updateProgress(position);
swiper.setTranslate(position);
swiper.updateActiveIndex();
swiper.updateSlidesClasses();
}
function onDragStart(e){
const params=swiper.params.scrollbar;
const {
scrollbar,
$wrapperEl
}=swiper;
const {
$el,
$dragEl
}=scrollbar;
isTouched=true;
dragStartPos=e.target===$dragEl[0]||e.target===$dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left':'top']:null;
e.preventDefault();
e.stopPropagation();
$wrapperEl.transition(100);
$dragEl.transition(100);
setDragPosition(e);
clearTimeout(dragTimeout);
$el.transition(0);
if(params.hide){
$el.css('opacity', 1);
}
if(swiper.params.cssMode){
swiper.$wrapperEl.css('scroll-snap-type', 'none');
}
emit('scrollbarDragStart', e);
}
function onDragMove(e){
const {
scrollbar,
$wrapperEl
}=swiper;
const {
$el,
$dragEl
}=scrollbar;
if(!isTouched) return;
if(e.preventDefault) e.preventDefault();else e.returnValue=false;
setDragPosition(e);
$wrapperEl.transition(0);
$el.transition(0);
$dragEl.transition(0);
emit('scrollbarDragMove', e);
}
function onDragEnd(e){
const params=swiper.params.scrollbar;
const {
scrollbar,
$wrapperEl
}=swiper;
const {
$el
}=scrollbar;
if(!isTouched) return;
isTouched=false;
if(swiper.params.cssMode){
swiper.$wrapperEl.css('scroll-snap-type', '');
$wrapperEl.transition('');
}
if(params.hide){
clearTimeout(dragTimeout);
dragTimeout=nextTick(()=> {
$el.css('opacity', 0);
$el.transition(400);
}, 1000);
}
emit('scrollbarDragEnd', e);
if(params.snapOnRelease){
swiper.slideToClosest();
}}
function events(method){
const {
scrollbar,
touchEventsTouch,
touchEventsDesktop,
params,
support
}=swiper;
const $el=scrollbar.$el;
if(!$el) return;
const target=$el[0];
const activeListener=support.passiveListener&&params.passiveListeners ? {
passive: false,
capture: false
}:false;
const passiveListener=support.passiveListener&&params.passiveListeners ? {
passive: true,
capture: false
}:false;
if(!target) return;
const eventMethod=method==='on' ? 'addEventListener':'removeEventListener';
if(!support.touch){
target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);
document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);
document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);
}else{
target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);
target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);
target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);
}}
function enableDraggable(){
if(!swiper.params.scrollbar.el||!swiper.scrollbar.el) return;
events('on');
}
function disableDraggable(){
if(!swiper.params.scrollbar.el||!swiper.scrollbar.el) return;
events('off');
}
function init(){
const {
scrollbar,
$el: $swiperEl
}=swiper;
swiper.params.scrollbar=createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {
el: 'swiper-scrollbar'
});
const params=swiper.params.scrollbar;
if(!params.el) return;
let $el=$(params.el);
if(swiper.params.uniqueNavElements&&typeof params.el==='string'&&$el.length > 1&&$swiperEl.find(params.el).length===1){
$el=$swiperEl.find(params.el);
}
$el.addClass(swiper.isHorizontal() ? params.horizontalClass:params.verticalClass);
let $dragEl=$el.find(`.${swiper.params.scrollbar.dragClass}`);
if($dragEl.length===0){
$dragEl=$(`<div class="${swiper.params.scrollbar.dragClass}"></div>`);
$el.append($dragEl);
}
Object.assign(scrollbar, {
$el,
el: $el[0],
$dragEl,
dragEl: $dragEl[0]
});
if(params.draggable){
enableDraggable();
}
if($el){
$el[swiper.enabled ? 'removeClass':'addClass'](swiper.params.scrollbar.lockClass);
}}
function destroy(){
const params=swiper.params.scrollbar;
const $el=swiper.scrollbar.$el;
if($el){
$el.removeClass(swiper.isHorizontal() ? params.horizontalClass:params.verticalClass);
}
disableDraggable();
}
on('init', ()=> {
if(swiper.params.scrollbar.enabled===false){
disable();
}else{
init();
updateSize();
setTranslate();
}});
on('update resize observerUpdate lock unlock', ()=> {
updateSize();
});
on('setTranslate', ()=> {
setTranslate();
});
on('setTransition', (_s, duration)=> {
setTransition(duration);
});
on('enable disable', ()=> {
const {
$el
}=swiper.scrollbar;
if($el){
$el[swiper.enabled ? 'removeClass':'addClass'](swiper.params.scrollbar.lockClass);
}});
on('destroy', ()=> {
destroy();
});
const enable=()=> {
swiper.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);
if(swiper.scrollbar.$el){
swiper.scrollbar.$el.removeClass(swiper.params.scrollbar.scrollbarDisabledClass);
}
init();
updateSize();
setTranslate();
};
const disable=()=> {
swiper.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);
if(swiper.scrollbar.$el){
swiper.scrollbar.$el.addClass(swiper.params.scrollbar.scrollbarDisabledClass);
}
destroy();
};
Object.assign(swiper.scrollbar, {
enable,
disable,
updateSize,
setTranslate,
init,
destroy
});
}
function Parallax(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
parallax: {
enabled: false
}});
const setTransform=(el, progress)=> {
const {
rtl
}=swiper;
const $el=$(el);
const rtlFactor=rtl ? -1:1;
const p=$el.attr('data-swiper-parallax')||'0';
let x=$el.attr('data-swiper-parallax-x');
let y=$el.attr('data-swiper-parallax-y');
const scale=$el.attr('data-swiper-parallax-scale');
const opacity=$el.attr('data-swiper-parallax-opacity');
if(x||y){
x=x||'0';
y=y||'0';
}else if(swiper.isHorizontal()){
x=p;
y='0';
}else{
y=p;
x='0';
}
if(x.indexOf('%') >=0){
x=`${parseInt(x, 10) * progress * rtlFactor}%`;
}else{
x=`${x * progress * rtlFactor}px`;
}
if(y.indexOf('%') >=0){
y=`${parseInt(y, 10) * progress}%`;
}else{
y=`${y * progress}px`;
}
if(typeof opacity!=='undefined'&&opacity!==null){
const currentOpacity=opacity - (opacity - 1) * (1 - Math.abs(progress));
$el[0].style.opacity=currentOpacity;
}
if(typeof scale==='undefined'||scale===null){
$el.transform(`translate3d(${x}, ${y}, 0px)`);
}else{
const currentScale=scale - (scale - 1) * (1 - Math.abs(progress));
$el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);
}};
const setTranslate=()=> {
const {
$el,
slides,
progress,
snapGrid
}=swiper;
$el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el=> {
setTransform(el, progress);
});
slides.each((slideEl, slideIndex)=> {
let slideProgress=slideEl.progress;
if(swiper.params.slidesPerGroup > 1&&swiper.params.slidesPerView!=='auto'){
slideProgress +=Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);
}
slideProgress=Math.min(Math.max(slideProgress, -1), 1);
$(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el=> {
setTransform(el, slideProgress);
});
});
};
const setTransition=function (duration){
if(duration===void 0){
duration=swiper.params.speed;
}
const {
$el
}=swiper;
$el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(parallaxEl=> {
const $parallaxEl=$(parallaxEl);
let parallaxDuration=parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10)||duration;
if(duration===0) parallaxDuration=0;
$parallaxEl.transition(parallaxDuration);
});
};
on('beforeInit', ()=> {
if(!swiper.params.parallax.enabled) return;
swiper.params.watchSlidesProgress=true;
swiper.originalParams.watchSlidesProgress=true;
});
on('init', ()=> {
if(!swiper.params.parallax.enabled) return;
setTranslate();
});
on('setTranslate', ()=> {
if(!swiper.params.parallax.enabled) return;
setTranslate();
});
on('setTransition', (_swiper, duration)=> {
if(!swiper.params.parallax.enabled) return;
setTransition(duration);
});
}
function Zoom(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
const window=getWindow();
extendParams({
zoom: {
enabled: false,
maxRatio: 3,
minRatio: 1,
toggle: true,
containerClass: 'swiper-zoom-container',
zoomedSlideClass: 'swiper-slide-zoomed'
}});
swiper.zoom={
enabled: false
};
let currentScale=1;
let isScaling=false;
let gesturesEnabled;
let fakeGestureTouched;
let fakeGestureMoved;
const gesture={
$slideEl: undefined,
slideWidth: undefined,
slideHeight: undefined,
$imageEl: undefined,
$imageWrapEl: undefined,
maxRatio: 3
};
const image={
isTouched: undefined,
isMoved: undefined,
currentX: undefined,
currentY: undefined,
minX: undefined,
minY: undefined,
maxX: undefined,
maxY: undefined,
width: undefined,
height: undefined,
startX: undefined,
startY: undefined,
touchesStart: {},
touchesCurrent: {}};
const velocity={
x: undefined,
y: undefined,
prevPositionX: undefined,
prevPositionY: undefined,
prevTime: undefined
};
let scale=1;
Object.defineProperty(swiper.zoom, 'scale', {
get(){
return scale;
},
set(value){
if(scale!==value){
const imageEl=gesture.$imageEl ? gesture.$imageEl[0]:undefined;
const slideEl=gesture.$slideEl ? gesture.$slideEl[0]:undefined;
emit('zoomChange', value, imageEl, slideEl);
}
scale=value;
}});
function getDistanceBetweenTouches(e){
if(e.targetTouches.length < 2) return 1;
const x1=e.targetTouches[0].pageX;
const y1=e.targetTouches[0].pageY;
const x2=e.targetTouches[1].pageX;
const y2=e.targetTouches[1].pageY;
const distance=Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
return distance;
}
function onGestureStart(e){
const support=swiper.support;
const params=swiper.params.zoom;
fakeGestureTouched=false;
fakeGestureMoved=false;
if(!support.gestures){
if(e.type!=='touchstart'||e.type==='touchstart'&&e.targetTouches.length < 2){
return;
}
fakeGestureTouched=true;
gesture.scaleStart=getDistanceBetweenTouches(e);
}
if(!gesture.$slideEl||!gesture.$slideEl.length){
gesture.$slideEl=$(e.target).closest(`.${swiper.params.slideClass}`);
if(gesture.$slideEl.length===0) gesture.$slideEl=swiper.slides.eq(swiper.activeIndex);
gesture.$imageEl=gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
gesture.$imageWrapEl=gesture.$imageEl.parent(`.${params.containerClass}`);
gesture.maxRatio=gesture.$imageWrapEl.attr('data-swiper-zoom')||params.maxRatio;
if(gesture.$imageWrapEl.length===0){
gesture.$imageEl=undefined;
return;
}}
if(gesture.$imageEl){
gesture.$imageEl.transition(0);
}
isScaling=true;
}
function onGestureChange(e){
const support=swiper.support;
const params=swiper.params.zoom;
const zoom=swiper.zoom;
if(!support.gestures){
if(e.type!=='touchmove'||e.type==='touchmove'&&e.targetTouches.length < 2){
return;
}
fakeGestureMoved=true;
gesture.scaleMove=getDistanceBetweenTouches(e);
}
if(!gesture.$imageEl||gesture.$imageEl.length===0){
if(e.type==='gesturechange') onGestureStart(e);
return;
}
if(support.gestures){
zoom.scale=e.scale * currentScale;
}else{
zoom.scale=gesture.scaleMove / gesture.scaleStart * currentScale;
}
if(zoom.scale > gesture.maxRatio){
zoom.scale=gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;
}
if(zoom.scale < params.minRatio){
zoom.scale=params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;
}
gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);
}
function onGestureEnd(e){
const device=swiper.device;
const support=swiper.support;
const params=swiper.params.zoom;
const zoom=swiper.zoom;
if(!support.gestures){
if(!fakeGestureTouched||!fakeGestureMoved){
return;
}
if(e.type!=='touchend'||e.type==='touchend'&&e.changedTouches.length < 2&&!device.android){
return;
}
fakeGestureTouched=false;
fakeGestureMoved=false;
}
if(!gesture.$imageEl||gesture.$imageEl.length===0) return;
zoom.scale=Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);
gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);
currentScale=zoom.scale;
isScaling=false;
if(zoom.scale===1) gesture.$slideEl=undefined;
}
function onTouchStart(e){
const device=swiper.device;
if(!gesture.$imageEl||gesture.$imageEl.length===0) return;
if(image.isTouched) return;
if(device.android&&e.cancelable) e.preventDefault();
image.isTouched=true;
image.touchesStart.x=e.type==='touchstart' ? e.targetTouches[0].pageX:e.pageX;
image.touchesStart.y=e.type==='touchstart' ? e.targetTouches[0].pageY:e.pageY;
}
function onTouchMove(e){
const zoom=swiper.zoom;
if(!gesture.$imageEl||gesture.$imageEl.length===0) return;
swiper.allowClick=false;
if(!image.isTouched||!gesture.$slideEl) return;
if(!image.isMoved){
image.width=gesture.$imageEl[0].offsetWidth;
image.height=gesture.$imageEl[0].offsetHeight;
image.startX=getTranslate(gesture.$imageWrapEl[0], 'x')||0;
image.startY=getTranslate(gesture.$imageWrapEl[0], 'y')||0;
gesture.slideWidth=gesture.$slideEl[0].offsetWidth;
gesture.slideHeight=gesture.$slideEl[0].offsetHeight;
gesture.$imageWrapEl.transition(0);
}
const scaledWidth=image.width * zoom.scale;
const scaledHeight=image.height * zoom.scale;
if(scaledWidth < gesture.slideWidth&&scaledHeight < gesture.slideHeight) return;
image.minX=Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
image.maxX=-image.minX;
image.minY=Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
image.maxY=-image.minY;
image.touchesCurrent.x=e.type==='touchmove' ? e.targetTouches[0].pageX:e.pageX;
image.touchesCurrent.y=e.type==='touchmove' ? e.targetTouches[0].pageY:e.pageY;
if(!image.isMoved&&!isScaling){
if(swiper.isHorizontal()&&(Math.floor(image.minX)===Math.floor(image.startX)&&image.touchesCurrent.x < image.touchesStart.x||Math.floor(image.maxX)===Math.floor(image.startX)&&image.touchesCurrent.x > image.touchesStart.x)){
image.isTouched=false;
return;
}
if(!swiper.isHorizontal()&&(Math.floor(image.minY)===Math.floor(image.startY)&&image.touchesCurrent.y < image.touchesStart.y||Math.floor(image.maxY)===Math.floor(image.startY)&&image.touchesCurrent.y > image.touchesStart.y)){
image.isTouched=false;
return;
}}
if(e.cancelable){
e.preventDefault();
}
e.stopPropagation();
image.isMoved=true;
image.currentX=image.touchesCurrent.x - image.touchesStart.x + image.startX;
image.currentY=image.touchesCurrent.y - image.touchesStart.y + image.startY;
if(image.currentX < image.minX){
image.currentX=image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;
}
if(image.currentX > image.maxX){
image.currentX=image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;
}
if(image.currentY < image.minY){
image.currentY=image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;
}
if(image.currentY > image.maxY){
image.currentY=image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;
}
if(!velocity.prevPositionX) velocity.prevPositionX=image.touchesCurrent.x;
if(!velocity.prevPositionY) velocity.prevPositionY=image.touchesCurrent.y;
if(!velocity.prevTime) velocity.prevTime=Date.now();
velocity.x=(image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;
velocity.y=(image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;
if(Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x=0;
if(Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y=0;
velocity.prevPositionX=image.touchesCurrent.x;
velocity.prevPositionY=image.touchesCurrent.y;
velocity.prevTime=Date.now();
gesture.$imageWrapEl.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);
}
function onTouchEnd(){
const zoom=swiper.zoom;
if(!gesture.$imageEl||gesture.$imageEl.length===0) return;
if(!image.isTouched||!image.isMoved){
image.isTouched=false;
image.isMoved=false;
return;
}
image.isTouched=false;
image.isMoved=false;
let momentumDurationX=300;
let momentumDurationY=300;
const momentumDistanceX=velocity.x * momentumDurationX;
const newPositionX=image.currentX + momentumDistanceX;
const momentumDistanceY=velocity.y * momentumDurationY;
const newPositionY=image.currentY + momentumDistanceY;
if(velocity.x!==0) momentumDurationX=Math.abs((newPositionX - image.currentX) / velocity.x);
if(velocity.y!==0) momentumDurationY=Math.abs((newPositionY - image.currentY) / velocity.y);
const momentumDuration=Math.max(momentumDurationX, momentumDurationY);
image.currentX=newPositionX;
image.currentY=newPositionY;
const scaledWidth=image.width * zoom.scale;
const scaledHeight=image.height * zoom.scale;
image.minX=Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
image.maxX=-image.minX;
image.minY=Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
image.maxY=-image.minY;
image.currentX=Math.max(Math.min(image.currentX, image.maxX), image.minX);
image.currentY=Math.max(Math.min(image.currentY, image.maxY), image.minY);
gesture.$imageWrapEl.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);
}
function onTransitionEnd(){
const zoom=swiper.zoom;
if(gesture.$slideEl&&swiper.previousIndex!==swiper.activeIndex){
if(gesture.$imageEl){
gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');
}
if(gesture.$imageWrapEl){
gesture.$imageWrapEl.transform('translate3d(0,0,0)');
}
zoom.scale=1;
currentScale=1;
gesture.$slideEl=undefined;
gesture.$imageEl=undefined;
gesture.$imageWrapEl=undefined;
}}
function zoomIn(e){
const zoom=swiper.zoom;
const params=swiper.params.zoom;
if(!gesture.$slideEl){
if(e&&e.target){
gesture.$slideEl=$(e.target).closest(`.${swiper.params.slideClass}`);
}
if(!gesture.$slideEl){
if(swiper.params.virtual&&swiper.params.virtual.enabled&&swiper.virtual){
gesture.$slideEl=swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);
}else{
gesture.$slideEl=swiper.slides.eq(swiper.activeIndex);
}}
gesture.$imageEl=gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
gesture.$imageWrapEl=gesture.$imageEl.parent(`.${params.containerClass}`);
}
if(!gesture.$imageEl||gesture.$imageEl.length===0||!gesture.$imageWrapEl||gesture.$imageWrapEl.length===0) return;
if(swiper.params.cssMode){
swiper.wrapperEl.style.overflow='hidden';
swiper.wrapperEl.style.touchAction='none';
}
gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);
let touchX;
let touchY;
let offsetX;
let offsetY;
let diffX;
let diffY;
let translateX;
let translateY;
let imageWidth;
let imageHeight;
let scaledWidth;
let scaledHeight;
let translateMinX;
let translateMinY;
let translateMaxX;
let translateMaxY;
let slideWidth;
let slideHeight;
if(typeof image.touchesStart.x==='undefined'&&e){
touchX=e.type==='touchend' ? e.changedTouches[0].pageX:e.pageX;
touchY=e.type==='touchend' ? e.changedTouches[0].pageY:e.pageY;
}else{
touchX=image.touchesStart.x;
touchY=image.touchesStart.y;
}
zoom.scale=gesture.$imageWrapEl.attr('data-swiper-zoom')||params.maxRatio;
currentScale=gesture.$imageWrapEl.attr('data-swiper-zoom')||params.maxRatio;
if(e){
slideWidth=gesture.$slideEl[0].offsetWidth;
slideHeight=gesture.$slideEl[0].offsetHeight;
offsetX=gesture.$slideEl.offset().left + window.scrollX;
offsetY=gesture.$slideEl.offset().top + window.scrollY;
diffX=offsetX + slideWidth / 2 - touchX;
diffY=offsetY + slideHeight / 2 - touchY;
imageWidth=gesture.$imageEl[0].offsetWidth;
imageHeight=gesture.$imageEl[0].offsetHeight;
scaledWidth=imageWidth * zoom.scale;
scaledHeight=imageHeight * zoom.scale;
translateMinX=Math.min(slideWidth / 2 - scaledWidth / 2, 0);
translateMinY=Math.min(slideHeight / 2 - scaledHeight / 2, 0);
translateMaxX=-translateMinX;
translateMaxY=-translateMinY;
translateX=diffX * zoom.scale;
translateY=diffY * zoom.scale;
if(translateX < translateMinX){
translateX=translateMinX;
}
if(translateX > translateMaxX){
translateX=translateMaxX;
}
if(translateY < translateMinY){
translateY=translateMinY;
}
if(translateY > translateMaxY){
translateY=translateMaxY;
}}else{
translateX=0;
translateY=0;
}
gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);
gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);
}
function zoomOut(){
const zoom=swiper.zoom;
const params=swiper.params.zoom;
if(!gesture.$slideEl){
if(swiper.params.virtual&&swiper.params.virtual.enabled&&swiper.virtual){
gesture.$slideEl=swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);
}else{
gesture.$slideEl=swiper.slides.eq(swiper.activeIndex);
}
gesture.$imageEl=gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
gesture.$imageWrapEl=gesture.$imageEl.parent(`.${params.containerClass}`);
}
if(!gesture.$imageEl||gesture.$imageEl.length===0||!gesture.$imageWrapEl||gesture.$imageWrapEl.length===0) return;
if(swiper.params.cssMode){
swiper.wrapperEl.style.overflow='';
swiper.wrapperEl.style.touchAction='';
}
zoom.scale=1;
currentScale=1;
gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');
gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');
gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);
gesture.$slideEl=undefined;
}
function zoomToggle(e){
const zoom=swiper.zoom;
if(zoom.scale&&zoom.scale!==1){
zoomOut();
}else{
zoomIn(e);
}}
function getListeners(){
const support=swiper.support;
const passiveListener=swiper.touchEvents.start==='touchstart'&&support.passiveListener&&swiper.params.passiveListeners ? {
passive: true,
capture: false
}:false;
const activeListenerWithCapture=support.passiveListener ? {
passive: false,
capture: true
}:true;
return {
passiveListener,
activeListenerWithCapture
};}
function getSlideSelector(){
return `.${swiper.params.slideClass}`;
}
function toggleGestures(method){
const {
passiveListener
}=getListeners();
const slideSelector=getSlideSelector();
swiper.$wrapperEl[method]('gesturestart', slideSelector, onGestureStart, passiveListener);
swiper.$wrapperEl[method]('gesturechange', slideSelector, onGestureChange, passiveListener);
swiper.$wrapperEl[method]('gestureend', slideSelector, onGestureEnd, passiveListener);
}
function enableGestures(){
if(gesturesEnabled) return;
gesturesEnabled=true;
toggleGestures('on');
}
function disableGestures(){
if(!gesturesEnabled) return;
gesturesEnabled=false;
toggleGestures('off');
}
function enable(){
const zoom=swiper.zoom;
if(zoom.enabled) return;
zoom.enabled=true;
const support=swiper.support;
const {
passiveListener,
activeListenerWithCapture
}=getListeners();
const slideSelector=getSlideSelector();
if(support.gestures){
swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);
swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);
}else if(swiper.touchEvents.start==='touchstart'){
swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);
swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);
swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);
if(swiper.touchEvents.cancel){
swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);
}}
swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);
}
function disable(){
const zoom=swiper.zoom;
if(!zoom.enabled) return;
const support=swiper.support;
zoom.enabled=false;
const {
passiveListener,
activeListenerWithCapture
}=getListeners();
const slideSelector=getSlideSelector();
if(support.gestures){
swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);
swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);
}else if(swiper.touchEvents.start==='touchstart'){
swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);
swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);
swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);
if(swiper.touchEvents.cancel){
swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);
}}
swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);
}
on('init', ()=> {
if(swiper.params.zoom.enabled){
enable();
}});
on('destroy', ()=> {
disable();
});
on('touchStart', (_s, e)=> {
if(!swiper.zoom.enabled) return;
onTouchStart(e);
});
on('touchEnd', (_s, e)=> {
if(!swiper.zoom.enabled) return;
onTouchEnd();
});
on('doubleTap', (_s, e)=> {
if(!swiper.animating&&swiper.params.zoom.enabled&&swiper.zoom.enabled&&swiper.params.zoom.toggle){
zoomToggle(e);
}});
on('transitionEnd', ()=> {
if(swiper.zoom.enabled&&swiper.params.zoom.enabled){
onTransitionEnd();
}});
on('slideChange', ()=> {
if(swiper.zoom.enabled&&swiper.params.zoom.enabled&&swiper.params.cssMode){
onTransitionEnd();
}});
Object.assign(swiper.zoom, {
enable,
disable,
in: zoomIn,
out: zoomOut,
toggle: zoomToggle
});
}
function Lazy(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
extendParams({
lazy: {
checkInView: false,
enabled: false,
loadPrevNext: false,
loadPrevNextAmount: 1,
loadOnTransitionStart: false,
scrollingElement: '',
elementClass: 'swiper-lazy',
loadingClass: 'swiper-lazy-loading',
loadedClass: 'swiper-lazy-loaded',
preloaderClass: 'swiper-lazy-preloader'
}});
swiper.lazy={};
let scrollHandlerAttached=false;
let initialImageLoaded=false;
function loadInSlide(index, loadInDuplicate){
if(loadInDuplicate===void 0){
loadInDuplicate=true;
}
const params=swiper.params.lazy;
if(typeof index==='undefined') return;
if(swiper.slides.length===0) return;
const isVirtual=swiper.virtual&&swiper.params.virtual.enabled;
const $slideEl=isVirtual ? swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-swiper-slide-index="${index}"]`):swiper.slides.eq(index);
const $images=$slideEl.find(`.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`);
if($slideEl.hasClass(params.elementClass)&&!$slideEl.hasClass(params.loadedClass)&&!$slideEl.hasClass(params.loadingClass)){
$images.push($slideEl[0]);
}
if($images.length===0) return;
$images.each(imageEl=> {
const $imageEl=$(imageEl);
$imageEl.addClass(params.loadingClass);
const background=$imageEl.attr('data-background');
const src=$imageEl.attr('data-src');
const srcset=$imageEl.attr('data-srcset');
const sizes=$imageEl.attr('data-sizes');
const $pictureEl=$imageEl.parent('picture');
swiper.loadImage($imageEl[0], src||background, srcset, sizes, false, ()=> {
if(typeof swiper==='undefined'||swiper===null||!swiper||swiper&&!swiper.params||swiper.destroyed) return;
if(background){
$imageEl.css('background-image', `url("${background}")`);
$imageEl.removeAttr('data-background');
}else{
if(srcset){
$imageEl.attr('srcset', srcset);
$imageEl.removeAttr('data-srcset');
}
if(sizes){
$imageEl.attr('sizes', sizes);
$imageEl.removeAttr('data-sizes');
}
if($pictureEl.length){
$pictureEl.children('source').each(sourceEl=> {
const $source=$(sourceEl);
if($source.attr('data-srcset')){
$source.attr('srcset', $source.attr('data-srcset'));
$source.removeAttr('data-srcset');
}});
}
if(src){
$imageEl.attr('src', src);
$imageEl.removeAttr('data-src');
}}
$imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);
$slideEl.find(`.${params.preloaderClass}`).remove();
if(swiper.params.loop&&loadInDuplicate){
const slideOriginalIndex=$slideEl.attr('data-swiper-slide-index');
if($slideEl.hasClass(swiper.params.slideDuplicateClass)){
const originalSlide=swiper.$wrapperEl.children(`[data-swiper-slide-index="${slideOriginalIndex}"]:not(.${swiper.params.slideDuplicateClass})`);
loadInSlide(originalSlide.index(), false);
}else{
const duplicatedSlide=swiper.$wrapperEl.children(`.${swiper.params.slideDuplicateClass}[data-swiper-slide-index="${slideOriginalIndex}"]`);
loadInSlide(duplicatedSlide.index(), false);
}}
emit('lazyImageReady', $slideEl[0], $imageEl[0]);
if(swiper.params.autoHeight){
swiper.updateAutoHeight();
}});
emit('lazyImageLoad', $slideEl[0], $imageEl[0]);
});
}
function load(){
const {
$wrapperEl,
params: swiperParams,
slides,
activeIndex
}=swiper;
const isVirtual=swiper.virtual&&swiperParams.virtual.enabled;
const params=swiperParams.lazy;
let slidesPerView=swiperParams.slidesPerView;
if(slidesPerView==='auto'){
slidesPerView=0;
}
function slideExist(index){
if(isVirtual){
if($wrapperEl.children(`.${swiperParams.slideClass}[data-swiper-slide-index="${index}"]`).length){
return true;
}}else if(slides[index]) return true;
return false;
}
function slideIndex(slideEl){
if(isVirtual){
return $(slideEl).attr('data-swiper-slide-index');
}
return $(slideEl).index();
}
if(!initialImageLoaded) initialImageLoaded=true;
if(swiper.params.watchSlidesProgress){
$wrapperEl.children(`.${swiperParams.slideVisibleClass}`).each(slideEl=> {
const index=isVirtual ? $(slideEl).attr('data-swiper-slide-index'):$(slideEl).index();
loadInSlide(index);
});
}else if(slidesPerView > 1){
for (let i=activeIndex; i < activeIndex + slidesPerView; i +=1){
if(slideExist(i)) loadInSlide(i);
}}else{
loadInSlide(activeIndex);
}
if(params.loadPrevNext){
if(slidesPerView > 1||params.loadPrevNextAmount&&params.loadPrevNextAmount > 1){
const amount=params.loadPrevNextAmount;
const spv=Math.ceil(slidesPerView);
const maxIndex=Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);
const minIndex=Math.max(activeIndex - Math.max(spv, amount), 0);
for (let i=activeIndex + spv; i < maxIndex; i +=1){
if(slideExist(i)) loadInSlide(i);
}
for (let i=minIndex; i < activeIndex; i +=1){
if(slideExist(i)) loadInSlide(i);
}}else{
const nextSlide=$wrapperEl.children(`.${swiperParams.slideNextClass}`);
if(nextSlide.length > 0) loadInSlide(slideIndex(nextSlide));
const prevSlide=$wrapperEl.children(`.${swiperParams.slidePrevClass}`);
if(prevSlide.length > 0) loadInSlide(slideIndex(prevSlide));
}}
}
function checkInViewOnLoad(){
const window=getWindow();
if(!swiper||swiper.destroyed) return;
const $scrollElement=swiper.params.lazy.scrollingElement ? $(swiper.params.lazy.scrollingElement):$(window);
const isWindow=$scrollElement[0]===window;
const scrollElementWidth=isWindow ? window.innerWidth:$scrollElement[0].offsetWidth;
const scrollElementHeight=isWindow ? window.innerHeight:$scrollElement[0].offsetHeight;
const swiperOffset=swiper.$el.offset();
const {
rtlTranslate: rtl
}=swiper;
let inView=false;
if(rtl) swiperOffset.left -=swiper.$el[0].scrollLeft;
const swiperCoord=[[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiper.width, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiper.height], [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height]];
for (let i=0; i < swiperCoord.length; i +=1){
const point=swiperCoord[i];
if(point[0] >=0&&point[0] <=scrollElementWidth&&point[1] >=0&&point[1] <=scrollElementHeight){
if(point[0]===0&&point[1]===0) continue;
inView=true;
}}
const passiveListener=swiper.touchEvents.start==='touchstart'&&swiper.support.passiveListener&&swiper.params.passiveListeners ? {
passive: true,
capture: false
}:false;
if(inView){
load();
$scrollElement.off('scroll', checkInViewOnLoad, passiveListener);
}else if(!scrollHandlerAttached){
scrollHandlerAttached=true;
$scrollElement.on('scroll', checkInViewOnLoad, passiveListener);
}}
on('beforeInit', ()=> {
if(swiper.params.lazy.enabled&&swiper.params.preloadImages){
swiper.params.preloadImages=false;
}});
on('init', ()=> {
if(swiper.params.lazy.enabled){
if(swiper.params.lazy.checkInView){
checkInViewOnLoad();
}else{
load();
}}
});
on('scroll', ()=> {
if(swiper.params.freeMode&&swiper.params.freeMode.enabled&&!swiper.params.freeMode.sticky){
load();
}});
on('scrollbarDragMove resize _freeModeNoMomentumRelease', ()=> {
if(swiper.params.lazy.enabled){
if(swiper.params.lazy.checkInView){
checkInViewOnLoad();
}else{
load();
}}
});
on('transitionStart', ()=> {
if(swiper.params.lazy.enabled){
if(swiper.params.lazy.loadOnTransitionStart||!swiper.params.lazy.loadOnTransitionStart&&!initialImageLoaded){
if(swiper.params.lazy.checkInView){
checkInViewOnLoad();
}else{
load();
}}
}});
on('transitionEnd', ()=> {
if(swiper.params.lazy.enabled&&!swiper.params.lazy.loadOnTransitionStart){
if(swiper.params.lazy.checkInView){
checkInViewOnLoad();
}else{
load();
}}
});
on('slideChange', ()=> {
const {
lazy,
cssMode,
watchSlidesProgress,
touchReleaseOnEdges,
resistanceRatio
}=swiper.params;
if(lazy.enabled&&(cssMode||watchSlidesProgress&&(touchReleaseOnEdges||resistanceRatio===0))){
load();
}});
on('destroy', ()=> {
if(!swiper.$el) return;
swiper.$el.find(`.${swiper.params.lazy.loadingClass}`).removeClass(swiper.params.lazy.loadingClass);
});
Object.assign(swiper.lazy, {
load,
loadInSlide
});
}
function Controller(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
controller: {
control: undefined,
inverse: false,
by: 'slide'
}});
swiper.controller={
control: undefined
};
function LinearSpline(x, y){
const binarySearch=function search(){
let maxIndex;
let minIndex;
let guess;
return (array, val)=> {
minIndex=-1;
maxIndex=array.length;
while (maxIndex - minIndex > 1){
guess=maxIndex + minIndex >> 1;
if(array[guess] <=val){
minIndex=guess;
}else{
maxIndex=guess;
}}
return maxIndex;
};}();
this.x=x;
this.y=y;
this.lastIndex=x.length - 1;
let i1;
let i3;
this.interpolate=function interpolate(x2){
if(!x2) return 0;
i3=binarySearch(this.x, x2);
i1=i3 - 1;
return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];
};
return this;
}
function getInterpolateFunction(c){
if(!swiper.controller.spline){
swiper.controller.spline=swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid):new LinearSpline(swiper.snapGrid, c.snapGrid);
}}
function setTranslate(_t, byController){
const controlled=swiper.controller.control;
let multiplier;
let controlledTranslate;
const Swiper=swiper.constructor;
function setControlledTranslate(c){
const translate=swiper.rtlTranslate ? -swiper.translate:swiper.translate;
if(swiper.params.controller.by==='slide'){
getInterpolateFunction(c);
controlledTranslate=-swiper.controller.spline.interpolate(-translate);
}
if(!controlledTranslate||swiper.params.controller.by==='container'){
multiplier=(c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());
controlledTranslate=(translate - swiper.minTranslate()) * multiplier + c.minTranslate();
}
if(swiper.params.controller.inverse){
controlledTranslate=c.maxTranslate() - controlledTranslate;
}
c.updateProgress(controlledTranslate);
c.setTranslate(controlledTranslate, swiper);
c.updateActiveIndex();
c.updateSlidesClasses();
}
if(Array.isArray(controlled)){
for (let i=0; i < controlled.length; i +=1){
if(controlled[i]!==byController&&controlled[i] instanceof Swiper){
setControlledTranslate(controlled[i]);
}}
}else if(controlled instanceof Swiper&&byController!==controlled){
setControlledTranslate(controlled);
}}
function setTransition(duration, byController){
const Swiper=swiper.constructor;
const controlled=swiper.controller.control;
let i;
function setControlledTransition(c){
c.setTransition(duration, swiper);
if(duration!==0){
c.transitionStart();
if(c.params.autoHeight){
nextTick(()=> {
c.updateAutoHeight();
});
}
c.$wrapperEl.transitionEnd(()=> {
if(!controlled) return;
if(c.params.loop&&swiper.params.controller.by==='slide'){
c.loopFix();
}
c.transitionEnd();
});
}}
if(Array.isArray(controlled)){
for (i=0; i < controlled.length; i +=1){
if(controlled[i]!==byController&&controlled[i] instanceof Swiper){
setControlledTransition(controlled[i]);
}}
}else if(controlled instanceof Swiper&&byController!==controlled){
setControlledTransition(controlled);
}}
function removeSpline(){
if(!swiper.controller.control) return;
if(swiper.controller.spline){
swiper.controller.spline=undefined;
delete swiper.controller.spline;
}}
on('beforeInit', ()=> {
swiper.controller.control=swiper.params.controller.control;
});
on('update', ()=> {
removeSpline();
});
on('resize', ()=> {
removeSpline();
});
on('observerUpdate', ()=> {
removeSpline();
});
on('setTranslate', (_s, translate, byController)=> {
if(!swiper.controller.control) return;
swiper.controller.setTranslate(translate, byController);
});
on('setTransition', (_s, duration, byController)=> {
if(!swiper.controller.control) return;
swiper.controller.setTransition(duration, byController);
});
Object.assign(swiper.controller, {
setTranslate,
setTransition
});
}
function A11y(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
a11y: {
enabled: true,
notificationClass: 'swiper-notification',
prevSlideMessage: 'Previous slide',
nextSlideMessage: 'Next slide',
firstSlideMessage: 'This is the first slide',
lastSlideMessage: 'This is the last slide',
paginationBulletMessage: 'Go to slide {{index}}',
slideLabelMessage: '{{index}} / {{slidesLength}}',
containerMessage: null,
containerRoleDescriptionMessage: null,
itemRoleDescriptionMessage: null,
slideRole: 'group',
id: null
}});
swiper.a11y={
clicked: false
};
let liveRegion=null;
function notify(message){
const notification=liveRegion;
if(notification.length===0) return;
notification.html('');
notification.html(message);
}
function getRandomNumber(size){
if(size===void 0){
size=16;
}
const randomChar=()=> Math.round(16 * Math.random()).toString(16);
return 'x'.repeat(size).replace(/x/g, randomChar);
}
function makeElFocusable($el){
$el.attr('tabIndex', '0');
}
function makeElNotFocusable($el){
$el.attr('tabIndex', '-1');
}
function addElRole($el, role){
$el.attr('role', role);
}
function addElRoleDescription($el, description){
$el.attr('aria-roledescription', description);
}
function addElControls($el, controls){
$el.attr('aria-controls', controls);
}
function addElLabel($el, label){
$el.attr('aria-label', label);
}
function addElId($el, id){
$el.attr('id', id);
}
function addElLive($el, live){
$el.attr('aria-live', live);
}
function disableEl($el){
$el.attr('aria-disabled', true);
}
function enableEl($el){
$el.attr('aria-disabled', false);
}
function onEnterOrSpaceKey(e){
if(e.keyCode!==13&&e.keyCode!==32) return;
const params=swiper.params.a11y;
const $targetEl=$(e.target);
if(swiper.navigation&&swiper.navigation.$nextEl&&$targetEl.is(swiper.navigation.$nextEl)){
if(!(swiper.isEnd&&!swiper.params.loop)){
swiper.slideNext();
}
if(swiper.isEnd){
notify(params.lastSlideMessage);
}else{
notify(params.nextSlideMessage);
}}
if(swiper.navigation&&swiper.navigation.$prevEl&&$targetEl.is(swiper.navigation.$prevEl)){
if(!(swiper.isBeginning&&!swiper.params.loop)){
swiper.slidePrev();
}
if(swiper.isBeginning){
notify(params.firstSlideMessage);
}else{
notify(params.prevSlideMessage);
}}
if(swiper.pagination&&$targetEl.is(classesToSelector(swiper.params.pagination.bulletClass))){
$targetEl[0].click();
}}
function updateNavigation(){
if(swiper.params.loop||swiper.params.rewind||!swiper.navigation) return;
const {
$nextEl,
$prevEl
}=swiper.navigation;
if($prevEl&&$prevEl.length > 0){
if(swiper.isBeginning){
disableEl($prevEl);
makeElNotFocusable($prevEl);
}else{
enableEl($prevEl);
makeElFocusable($prevEl);
}}
if($nextEl&&$nextEl.length > 0){
if(swiper.isEnd){
disableEl($nextEl);
makeElNotFocusable($nextEl);
}else{
enableEl($nextEl);
makeElFocusable($nextEl);
}}
}
function hasPagination(){
return swiper.pagination&&swiper.pagination.bullets&&swiper.pagination.bullets.length;
}
function hasClickablePagination(){
return hasPagination()&&swiper.params.pagination.clickable;
}
function updatePagination(){
const params=swiper.params.a11y;
if(!hasPagination()) return;
swiper.pagination.bullets.each(bulletEl=> {
const $bulletEl=$(bulletEl);
if(swiper.params.pagination.clickable){
makeElFocusable($bulletEl);
if(!swiper.params.pagination.renderBullet){
addElRole($bulletEl, 'button');
addElLabel($bulletEl, params.paginationBulletMessage.replace(/\{\{index\}\}/, $bulletEl.index() + 1));
}}
if($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)){
$bulletEl.attr('aria-current', 'true');
}else{
$bulletEl.removeAttr('aria-current');
}});
}
const initNavEl=($el, wrapperId, message)=> {
makeElFocusable($el);
if($el[0].tagName!=='BUTTON'){
addElRole($el, 'button');
$el.on('keydown', onEnterOrSpaceKey);
}
addElLabel($el, message);
addElControls($el, wrapperId);
};
const handlePointerDown=()=> {
swiper.a11y.clicked=true;
};
const handlePointerUp=()=> {
requestAnimationFrame(()=> {
requestAnimationFrame(()=> {
if(!swiper.destroyed){
swiper.a11y.clicked=false;
}});
});
};
const handleFocus=e => {
if(swiper.a11y.clicked) return;
const slideEl=e.target.closest(`.${swiper.params.slideClass}`);
if(!slideEl||!swiper.slides.includes(slideEl)) return;
const isActive=swiper.slides.indexOf(slideEl)===swiper.activeIndex;
const isVisible=swiper.params.watchSlidesProgress&&swiper.visibleSlides&&swiper.visibleSlides.includes(slideEl);
if(isActive||isVisible) return;
if(e.sourceCapabilities&&e.sourceCapabilities.firesTouchEvents) return;
if(swiper.isHorizontal()){
swiper.el.scrollLeft=0;
}else{
swiper.el.scrollTop=0;
}
swiper.slideTo(swiper.slides.indexOf(slideEl), 0);
};
const initSlides=()=> {
const params=swiper.params.a11y;
if(params.itemRoleDescriptionMessage){
addElRoleDescription($(swiper.slides), params.itemRoleDescriptionMessage);
}
if(params.slideRole){
addElRole($(swiper.slides), params.slideRole);
}
const slidesLength=swiper.params.loop ? swiper.slides.filter(el=> !el.classList.contains(swiper.params.slideDuplicateClass)).length:swiper.slides.length;
if(params.slideLabelMessage){
swiper.slides.each((slideEl, index)=> {
const $slideEl=$(slideEl);
const slideIndex=swiper.params.loop ? parseInt($slideEl.attr('data-swiper-slide-index'), 10):index;
const ariaLabelMessage=params.slideLabelMessage.replace(/\{\{index\}\}/, slideIndex + 1).replace(/\{\{slidesLength\}\}/, slidesLength);
addElLabel($slideEl, ariaLabelMessage);
});
}};
const init=()=> {
const params=swiper.params.a11y;
swiper.$el.append(liveRegion);
const $containerEl=swiper.$el;
if(params.containerRoleDescriptionMessage){
addElRoleDescription($containerEl, params.containerRoleDescriptionMessage);
}
if(params.containerMessage){
addElLabel($containerEl, params.containerMessage);
}
const $wrapperEl=swiper.$wrapperEl;
const wrapperId=params.id||$wrapperEl.attr('id')||`swiper-wrapper-${getRandomNumber(16)}`;
const live=swiper.params.autoplay&&swiper.params.autoplay.enabled ? 'off':'polite';
addElId($wrapperEl, wrapperId);
addElLive($wrapperEl, live);
initSlides();
let $nextEl;
let $prevEl;
if(swiper.navigation&&swiper.navigation.$nextEl){
$nextEl=swiper.navigation.$nextEl;
}
if(swiper.navigation&&swiper.navigation.$prevEl){
$prevEl=swiper.navigation.$prevEl;
}
if($nextEl&&$nextEl.length){
initNavEl($nextEl, wrapperId, params.nextSlideMessage);
}
if($prevEl&&$prevEl.length){
initNavEl($prevEl, wrapperId, params.prevSlideMessage);
}
if(hasClickablePagination()){
swiper.pagination.$el.on('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);
}
swiper.$el.on('focus', handleFocus, true);
swiper.$el.on('pointerdown', handlePointerDown, true);
swiper.$el.on('pointerup', handlePointerUp, true);
};
function destroy(){
if(liveRegion&&liveRegion.length > 0) liveRegion.remove();
let $nextEl;
let $prevEl;
if(swiper.navigation&&swiper.navigation.$nextEl){
$nextEl=swiper.navigation.$nextEl;
}
if(swiper.navigation&&swiper.navigation.$prevEl){
$prevEl=swiper.navigation.$prevEl;
}
if($nextEl){
$nextEl.off('keydown', onEnterOrSpaceKey);
}
if($prevEl){
$prevEl.off('keydown', onEnterOrSpaceKey);
}
if(hasClickablePagination()){
swiper.pagination.$el.off('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);
}
swiper.$el.off('focus', handleFocus, true);
swiper.$el.off('pointerdown', handlePointerDown, true);
swiper.$el.off('pointerup', handlePointerUp, true);
}
on('beforeInit', ()=> {
liveRegion=$(`<span class="${swiper.params.a11y.notificationClass}" aria-live="assertive" aria-atomic="true"></span>`);
});
on('afterInit', ()=> {
if(!swiper.params.a11y.enabled) return;
init();
});
on('slidesLengthChange snapGridLengthChange slidesGridLengthChange', ()=> {
if(!swiper.params.a11y.enabled) return;
initSlides();
});
on('fromEdge toEdge afterInit lock unlock', ()=> {
if(!swiper.params.a11y.enabled) return;
updateNavigation();
});
on('paginationUpdate', ()=> {
if(!swiper.params.a11y.enabled) return;
updatePagination();
});
on('destroy', ()=> {
if(!swiper.params.a11y.enabled) return;
destroy();
});
}
function History(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
history: {
enabled: false,
root: '',
replaceState: false,
key: 'slides',
keepQuery: false
}});
let initialized=false;
let paths={};
const slugify=text=> {
return text.toString().replace(/\s+/g, '-').replace(/[^\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');
};
const getPathValues=urlOverride=> {
const window=getWindow();
let location;
if(urlOverride){
location=new URL(urlOverride);
}else{
location=window.location;
}
const pathArray=location.pathname.slice(1).split('/').filter(part=> part!=='');
const total=pathArray.length;
const key=pathArray[total - 2];
const value=pathArray[total - 1];
return {
key,
value
};};
const setHistory=(key, index)=> {
const window=getWindow();
if(!initialized||!swiper.params.history.enabled) return;
let location;
if(swiper.params.url){
location=new URL(swiper.params.url);
}else{
location=window.location;
}
const slide=swiper.slides.eq(index);
let value=slugify(slide.attr('data-history'));
if(swiper.params.history.root.length > 0){
let root=swiper.params.history.root;
if(root[root.length - 1]==='/') root=root.slice(0, root.length - 1);
value=`${root}/${key}/${value}`;
}else if(!location.pathname.includes(key)){
value=`${key}/${value}`;
}
if(swiper.params.history.keepQuery){
value +=location.search;
}
const currentState=window.history.state;
if(currentState&&currentState.value===value){
return;
}
if(swiper.params.history.replaceState){
window.history.replaceState({
value
}, null, value);
}else{
window.history.pushState({
value
}, null, value);
}};
const scrollToSlide=(speed, value, runCallbacks)=> {
if(value){
for (let i=0, length=swiper.slides.length; i < length; i +=1){
const slide=swiper.slides.eq(i);
const slideHistory=slugify(slide.attr('data-history'));
if(slideHistory===value&&!slide.hasClass(swiper.params.slideDuplicateClass)){
const index=slide.index();
swiper.slideTo(index, speed, runCallbacks);
}}
}else{
swiper.slideTo(0, speed, runCallbacks);
}};
const setHistoryPopState=()=> {
paths=getPathValues(swiper.params.url);
scrollToSlide(swiper.params.speed, paths.value, false);
};
const init=()=> {
const window=getWindow();
if(!swiper.params.history) return;
if(!window.history||!window.history.pushState){
swiper.params.history.enabled=false;
swiper.params.hashNavigation.enabled=true;
return;
}
initialized=true;
paths=getPathValues(swiper.params.url);
if(!paths.key&&!paths.value) return;
scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);
if(!swiper.params.history.replaceState){
window.addEventListener('popstate', setHistoryPopState);
}};
const destroy=()=> {
const window=getWindow();
if(!swiper.params.history.replaceState){
window.removeEventListener('popstate', setHistoryPopState);
}};
on('init', ()=> {
if(swiper.params.history.enabled){
init();
}});
on('destroy', ()=> {
if(swiper.params.history.enabled){
destroy();
}});
on('transitionEnd _freeModeNoMomentumRelease', ()=> {
if(initialized){
setHistory(swiper.params.history.key, swiper.activeIndex);
}});
on('slideChange', ()=> {
if(initialized&&swiper.params.cssMode){
setHistory(swiper.params.history.key, swiper.activeIndex);
}});
}
function HashNavigation(_ref){
let {
swiper,
extendParams,
emit,
on
}=_ref;
let initialized=false;
const document=getDocument();
const window=getWindow();
extendParams({
hashNavigation: {
enabled: false,
replaceState: false,
watchState: false
}});
const onHashChange=()=> {
emit('hashChange');
const newHash=document.location.hash.replace('#', '');
const activeSlideHash=swiper.slides.eq(swiper.activeIndex).attr('data-hash');
if(newHash!==activeSlideHash){
const newIndex=swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash="${newHash}"]`).index();
if(typeof newIndex==='undefined') return;
swiper.slideTo(newIndex);
}};
const setHash=()=> {
if(!initialized||!swiper.params.hashNavigation.enabled) return;
if(swiper.params.hashNavigation.replaceState&&window.history&&window.history.replaceState){
window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr('data-hash')}`||'');
emit('hashSet');
}else{
const slide=swiper.slides.eq(swiper.activeIndex);
const hash=slide.attr('data-hash')||slide.attr('data-history');
document.location.hash=hash||'';
emit('hashSet');
}};
const init=()=> {
if(!swiper.params.hashNavigation.enabled||swiper.params.history&&swiper.params.history.enabled) return;
initialized=true;
const hash=document.location.hash.replace('#', '');
if(hash){
const speed=0;
for (let i=0, length=swiper.slides.length; i < length; i +=1){
const slide=swiper.slides.eq(i);
const slideHash=slide.attr('data-hash')||slide.attr('data-history');
if(slideHash===hash&&!slide.hasClass(swiper.params.slideDuplicateClass)){
const index=slide.index();
swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);
}}
}
if(swiper.params.hashNavigation.watchState){
$(window).on('hashchange', onHashChange);
}};
const destroy=()=> {
if(swiper.params.hashNavigation.watchState){
$(window).off('hashchange', onHashChange);
}};
on('init', ()=> {
if(swiper.params.hashNavigation.enabled){
init();
}});
on('destroy', ()=> {
if(swiper.params.hashNavigation.enabled){
destroy();
}});
on('transitionEnd _freeModeNoMomentumRelease', ()=> {
if(initialized){
setHash();
}});
on('slideChange', ()=> {
if(initialized&&swiper.params.cssMode){
setHash();
}});
}
function Autoplay(_ref){
let {
swiper,
extendParams,
on,
emit
}=_ref;
let timeout;
swiper.autoplay={
running: false,
paused: false
};
extendParams({
autoplay: {
enabled: false,
delay: 3000,
waitForTransition: true,
disableOnInteraction: true,
stopOnLastSlide: false,
reverseDirection: false,
pauseOnMouseEnter: false
}});
function run(){
if(!swiper.size){
swiper.autoplay.running=false;
swiper.autoplay.paused=false;
return;
}
const $activeSlideEl=swiper.slides.eq(swiper.activeIndex);
let delay=swiper.params.autoplay.delay;
if($activeSlideEl.attr('data-swiper-autoplay')){
delay=$activeSlideEl.attr('data-swiper-autoplay')||swiper.params.autoplay.delay;
}
clearTimeout(timeout);
timeout=nextTick(()=> {
let autoplayResult;
if(swiper.params.autoplay.reverseDirection){
if(swiper.params.loop){
swiper.loopFix();
autoplayResult=swiper.slidePrev(swiper.params.speed, true, true);
emit('autoplay');
}else if(!swiper.isBeginning){
autoplayResult=swiper.slidePrev(swiper.params.speed, true, true);
emit('autoplay');
}else if(!swiper.params.autoplay.stopOnLastSlide){
autoplayResult=swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);
emit('autoplay');
}else{
stop();
}}else if(swiper.params.loop){
swiper.loopFix();
autoplayResult=swiper.slideNext(swiper.params.speed, true, true);
emit('autoplay');
}else if(!swiper.isEnd){
autoplayResult=swiper.slideNext(swiper.params.speed, true, true);
emit('autoplay');
}else if(!swiper.params.autoplay.stopOnLastSlide){
autoplayResult=swiper.slideTo(0, swiper.params.speed, true, true);
emit('autoplay');
}else{
stop();
}
if(swiper.params.cssMode&&swiper.autoplay.running) run();else if(autoplayResult===false){
run();
}}, delay);
}
function start(){
if(typeof timeout!=='undefined') return false;
if(swiper.autoplay.running) return false;
swiper.autoplay.running=true;
emit('autoplayStart');
run();
return true;
}
function stop(){
if(!swiper.autoplay.running) return false;
if(typeof timeout==='undefined') return false;
if(timeout){
clearTimeout(timeout);
timeout=undefined;
}
swiper.autoplay.running=false;
emit('autoplayStop');
return true;
}
function pause(speed){
if(!swiper.autoplay.running) return;
if(swiper.autoplay.paused) return;
if(timeout) clearTimeout(timeout);
swiper.autoplay.paused=true;
if(speed===0||!swiper.params.autoplay.waitForTransition){
swiper.autoplay.paused=false;
run();
}else{
['transitionend', 'webkitTransitionEnd'].forEach(event=> {
swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd);
});
}}
function onVisibilityChange(){
const document=getDocument();
if(document.visibilityState==='hidden'&&swiper.autoplay.running){
pause();
}
if(document.visibilityState==='visible'&&swiper.autoplay.paused){
run();
swiper.autoplay.paused=false;
}}
function onTransitionEnd(e){
if(!swiper||swiper.destroyed||!swiper.$wrapperEl) return;
if(e.target!==swiper.$wrapperEl[0]) return;
['transitionend', 'webkitTransitionEnd'].forEach(event=> {
swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);
});
swiper.autoplay.paused=false;
if(!swiper.autoplay.running){
stop();
}else{
run();
}}
function onMouseEnter(){
if(swiper.params.autoplay.disableOnInteraction){
stop();
}else{
emit('autoplayPause');
pause();
}
['transitionend', 'webkitTransitionEnd'].forEach(event=> {
swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);
});
}
function onMouseLeave(){
if(swiper.params.autoplay.disableOnInteraction){
return;
}
swiper.autoplay.paused=false;
emit('autoplayResume');
run();
}
function attachMouseEvents(){
if(swiper.params.autoplay.pauseOnMouseEnter){
swiper.$el.on('mouseenter', onMouseEnter);
swiper.$el.on('mouseleave', onMouseLeave);
}}
function detachMouseEvents(){
swiper.$el.off('mouseenter', onMouseEnter);
swiper.$el.off('mouseleave', onMouseLeave);
}
on('init', ()=> {
if(swiper.params.autoplay.enabled){
start();
const document=getDocument();
document.addEventListener('visibilitychange', onVisibilityChange);
attachMouseEvents();
}});
on('beforeTransitionStart', (_s, speed, internal)=> {
if(swiper.autoplay.running){
if(internal||!swiper.params.autoplay.disableOnInteraction){
swiper.autoplay.pause(speed);
}else{
stop();
}}
});
on('sliderFirstMove', ()=> {
if(swiper.autoplay.running){
if(swiper.params.autoplay.disableOnInteraction){
stop();
}else{
pause();
}}
});
on('touchEnd', ()=> {
if(swiper.params.cssMode&&swiper.autoplay.paused&&!swiper.params.autoplay.disableOnInteraction){
run();
}});
on('destroy', ()=> {
detachMouseEvents();
if(swiper.autoplay.running){
stop();
}
const document=getDocument();
document.removeEventListener('visibilitychange', onVisibilityChange);
});
Object.assign(swiper.autoplay, {
pause,
run,
start,
stop
});
}
function Thumb(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
thumbs: {
swiper: null,
multipleActiveThumbs: true,
autoScrollOffset: 0,
slideThumbActiveClass: 'swiper-slide-thumb-active',
thumbsContainerClass: 'swiper-thumbs'
}});
let initialized=false;
let swiperCreated=false;
swiper.thumbs={
swiper: null
};
function onThumbClick(){
const thumbsSwiper=swiper.thumbs.swiper;
if(!thumbsSwiper||thumbsSwiper.destroyed) return;
const clickedIndex=thumbsSwiper.clickedIndex;
const clickedSlide=thumbsSwiper.clickedSlide;
if(clickedSlide&&$(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;
if(typeof clickedIndex==='undefined'||clickedIndex===null) return;
let slideToIndex;
if(thumbsSwiper.params.loop){
slideToIndex=parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);
}else{
slideToIndex=clickedIndex;
}
if(swiper.params.loop){
let currentIndex=swiper.activeIndex;
if(swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)){
swiper.loopFix();
swiper._clientLeft=swiper.$wrapperEl[0].clientLeft;
currentIndex=swiper.activeIndex;
}
const prevIndex=swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index="${slideToIndex}"]`).eq(0).index();
const nextIndex=swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index="${slideToIndex}"]`).eq(0).index();
if(typeof prevIndex==='undefined') slideToIndex=nextIndex;else if(typeof nextIndex==='undefined') slideToIndex=prevIndex;else if(nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex=nextIndex;else slideToIndex=prevIndex;
}
swiper.slideTo(slideToIndex);
}
function init(){
const {
thumbs: thumbsParams
}=swiper.params;
if(initialized) return false;
initialized=true;
const SwiperClass=swiper.constructor;
if(thumbsParams.swiper instanceof SwiperClass){
swiper.thumbs.swiper=thumbsParams.swiper;
Object.assign(swiper.thumbs.swiper.originalParams, {
watchSlidesProgress: true,
slideToClickedSlide: false
});
Object.assign(swiper.thumbs.swiper.params, {
watchSlidesProgress: true,
slideToClickedSlide: false
});
}else if(isObject(thumbsParams.swiper)){
const thumbsSwiperParams=Object.assign({}, thumbsParams.swiper);
Object.assign(thumbsSwiperParams, {
watchSlidesProgress: true,
slideToClickedSlide: false
});
swiper.thumbs.swiper=new SwiperClass(thumbsSwiperParams);
swiperCreated=true;
}
swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);
swiper.thumbs.swiper.on('tap', onThumbClick);
return true;
}
function update(initial){
const thumbsSwiper=swiper.thumbs.swiper;
if(!thumbsSwiper||thumbsSwiper.destroyed) return;
const slidesPerView=thumbsSwiper.params.slidesPerView==='auto' ? thumbsSwiper.slidesPerViewDynamic():thumbsSwiper.params.slidesPerView;
let thumbsToActivate=1;
const thumbActiveClass=swiper.params.thumbs.slideThumbActiveClass;
if(swiper.params.slidesPerView > 1&&!swiper.params.centeredSlides){
thumbsToActivate=swiper.params.slidesPerView;
}
if(!swiper.params.thumbs.multipleActiveThumbs){
thumbsToActivate=1;
}
thumbsToActivate=Math.floor(thumbsToActivate);
thumbsSwiper.slides.removeClass(thumbActiveClass);
if(thumbsSwiper.params.loop||thumbsSwiper.params.virtual&&thumbsSwiper.params.virtual.enabled){
for (let i=0; i < thumbsToActivate; i +=1){
thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index="${swiper.realIndex + i}"]`).addClass(thumbActiveClass);
}}else{
for (let i=0; i < thumbsToActivate; i +=1){
thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);
}}
const autoScrollOffset=swiper.params.thumbs.autoScrollOffset;
const useOffset=autoScrollOffset&&!thumbsSwiper.params.loop;
if(swiper.realIndex!==thumbsSwiper.realIndex||useOffset){
let currentThumbsIndex=thumbsSwiper.activeIndex;
let newThumbsIndex;
let direction;
if(thumbsSwiper.params.loop){
if(thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)){
thumbsSwiper.loopFix();
thumbsSwiper._clientLeft=thumbsSwiper.$wrapperEl[0].clientLeft;
currentThumbsIndex=thumbsSwiper.activeIndex;
}
const prevThumbsIndex=thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index="${swiper.realIndex}"]`).eq(0).index();
const nextThumbsIndex=thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index="${swiper.realIndex}"]`).eq(0).index();
if(typeof prevThumbsIndex==='undefined'){
newThumbsIndex=nextThumbsIndex;
}else if(typeof nextThumbsIndex==='undefined'){
newThumbsIndex=prevThumbsIndex;
}else if(nextThumbsIndex - currentThumbsIndex===currentThumbsIndex - prevThumbsIndex){
newThumbsIndex=thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex:currentThumbsIndex;
}else if(nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex){
newThumbsIndex=nextThumbsIndex;
}else{
newThumbsIndex=prevThumbsIndex;
}
direction=swiper.activeIndex > swiper.previousIndex ? 'next':'prev';
}else{
newThumbsIndex=swiper.realIndex;
direction=newThumbsIndex > swiper.previousIndex ? 'next':'prev';
}
if(useOffset){
newThumbsIndex +=direction==='next' ? autoScrollOffset:-1 * autoScrollOffset;
}
if(thumbsSwiper.visibleSlidesIndexes&&thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0){
if(thumbsSwiper.params.centeredSlides){
if(newThumbsIndex > currentThumbsIndex){
newThumbsIndex=newThumbsIndex - Math.floor(slidesPerView / 2) + 1;
}else{
newThumbsIndex=newThumbsIndex + Math.floor(slidesPerView / 2) - 1;
}}else if(newThumbsIndex > currentThumbsIndex&&thumbsSwiper.params.slidesPerGroup===1) ;
thumbsSwiper.slideTo(newThumbsIndex, initial ? 0:undefined);
}}
}
on('beforeInit', ()=> {
const {
thumbs
}=swiper.params;
if(!thumbs||!thumbs.swiper) return;
init();
update(true);
});
on('slideChange update resize observerUpdate', ()=> {
update();
});
on('setTransition', (_s, duration)=> {
const thumbsSwiper=swiper.thumbs.swiper;
if(!thumbsSwiper||thumbsSwiper.destroyed) return;
thumbsSwiper.setTransition(duration);
});
on('beforeDestroy', ()=> {
const thumbsSwiper=swiper.thumbs.swiper;
if(!thumbsSwiper||thumbsSwiper.destroyed) return;
if(swiperCreated){
thumbsSwiper.destroy();
}});
Object.assign(swiper.thumbs, {
init,
update
});
}
function freeMode(_ref){
let {
swiper,
extendParams,
emit,
once
}=_ref;
extendParams({
freeMode: {
enabled: false,
momentum: true,
momentumRatio: 1,
momentumBounce: true,
momentumBounceRatio: 1,
momentumVelocityRatio: 1,
sticky: false,
minimumVelocity: 0.02
}});
function onTouchStart(){
const translate=swiper.getTranslate();
swiper.setTranslate(translate);
swiper.setTransition(0);
swiper.touchEventsData.velocities.length=0;
swiper.freeMode.onTouchEnd({
currentPos: swiper.rtl ? swiper.translate:-swiper.translate
});
}
function onTouchMove(){
const {
touchEventsData: data,
touches
}=swiper;
if(data.velocities.length===0){
data.velocities.push({
position: touches[swiper.isHorizontal() ? 'startX':'startY'],
time: data.touchStartTime
});
}
data.velocities.push({
position: touches[swiper.isHorizontal() ? 'currentX':'currentY'],
time: now()
});
}
function onTouchEnd(_ref2){
let {
currentPos
}=_ref2;
const {
params,
$wrapperEl,
rtlTranslate: rtl,
snapGrid,
touchEventsData: data
}=swiper;
const touchEndTime=now();
const timeDiff=touchEndTime - data.touchStartTime;
if(currentPos < -swiper.minTranslate()){
swiper.slideTo(swiper.activeIndex);
return;
}
if(currentPos > -swiper.maxTranslate()){
if(swiper.slides.length < snapGrid.length){
swiper.slideTo(snapGrid.length - 1);
}else{
swiper.slideTo(swiper.slides.length - 1);
}
return;
}
if(params.freeMode.momentum){
if(data.velocities.length > 1){
const lastMoveEvent=data.velocities.pop();
const velocityEvent=data.velocities.pop();
const distance=lastMoveEvent.position - velocityEvent.position;
const time=lastMoveEvent.time - velocityEvent.time;
swiper.velocity=distance / time;
swiper.velocity /=2;
if(Math.abs(swiper.velocity) < params.freeMode.minimumVelocity){
swiper.velocity=0;
}
if(time > 150||now() - lastMoveEvent.time > 300){
swiper.velocity=0;
}}else{
swiper.velocity=0;
}
swiper.velocity *=params.freeMode.momentumVelocityRatio;
data.velocities.length=0;
let momentumDuration=1000 * params.freeMode.momentumRatio;
const momentumDistance=swiper.velocity * momentumDuration;
let newPosition=swiper.translate + momentumDistance;
if(rtl) newPosition=-newPosition;
let doBounce=false;
let afterBouncePosition;
const bounceAmount=Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;
let needsLoopFix;
if(newPosition < swiper.maxTranslate()){
if(params.freeMode.momentumBounce){
if(newPosition + swiper.maxTranslate() < -bounceAmount){
newPosition=swiper.maxTranslate() - bounceAmount;
}
afterBouncePosition=swiper.maxTranslate();
doBounce=true;
data.allowMomentumBounce=true;
}else{
newPosition=swiper.maxTranslate();
}
if(params.loop&&params.centeredSlides) needsLoopFix=true;
}else if(newPosition > swiper.minTranslate()){
if(params.freeMode.momentumBounce){
if(newPosition - swiper.minTranslate() > bounceAmount){
newPosition=swiper.minTranslate() + bounceAmount;
}
afterBouncePosition=swiper.minTranslate();
doBounce=true;
data.allowMomentumBounce=true;
}else{
newPosition=swiper.minTranslate();
}
if(params.loop&&params.centeredSlides) needsLoopFix=true;
}else if(params.freeMode.sticky){
let nextSlide;
for (let j=0; j < snapGrid.length; j +=1){
if(snapGrid[j] > -newPosition){
nextSlide=j;
break;
}}
if(Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition)||swiper.swipeDirection==='next'){
newPosition=snapGrid[nextSlide];
}else{
newPosition=snapGrid[nextSlide - 1];
}
newPosition=-newPosition;
}
if(needsLoopFix){
once('transitionEnd', ()=> {
swiper.loopFix();
});
}
if(swiper.velocity!==0){
if(rtl){
momentumDuration=Math.abs((-newPosition - swiper.translate) / swiper.velocity);
}else{
momentumDuration=Math.abs((newPosition - swiper.translate) / swiper.velocity);
}
if(params.freeMode.sticky){
const moveDistance=Math.abs((rtl ? -newPosition:newPosition) - swiper.translate);
const currentSlideSize=swiper.slidesSizesGrid[swiper.activeIndex];
if(moveDistance < currentSlideSize){
momentumDuration=params.speed;
}else if(moveDistance < 2 * currentSlideSize){
momentumDuration=params.speed * 1.5;
}else{
momentumDuration=params.speed * 2.5;
}}
}else if(params.freeMode.sticky){
swiper.slideToClosest();
return;
}
if(params.freeMode.momentumBounce&&doBounce){
swiper.updateProgress(afterBouncePosition);
swiper.setTransition(momentumDuration);
swiper.setTranslate(newPosition);
swiper.transitionStart(true, swiper.swipeDirection);
swiper.animating=true;
$wrapperEl.transitionEnd(()=> {
if(!swiper||swiper.destroyed||!data.allowMomentumBounce) return;
emit('momentumBounce');
swiper.setTransition(params.speed);
setTimeout(()=> {
swiper.setTranslate(afterBouncePosition);
$wrapperEl.transitionEnd(()=> {
if(!swiper||swiper.destroyed) return;
swiper.transitionEnd();
});
}, 0);
});
}else if(swiper.velocity){
emit('_freeModeNoMomentumRelease');
swiper.updateProgress(newPosition);
swiper.setTransition(momentumDuration);
swiper.setTranslate(newPosition);
swiper.transitionStart(true, swiper.swipeDirection);
if(!swiper.animating){
swiper.animating=true;
$wrapperEl.transitionEnd(()=> {
if(!swiper||swiper.destroyed) return;
swiper.transitionEnd();
});
}}else{
swiper.updateProgress(newPosition);
}
swiper.updateActiveIndex();
swiper.updateSlidesClasses();
}else if(params.freeMode.sticky){
swiper.slideToClosest();
return;
}else if(params.freeMode){
emit('_freeModeNoMomentumRelease');
}
if(!params.freeMode.momentum||timeDiff >=params.longSwipesMs){
swiper.updateProgress();
swiper.updateActiveIndex();
swiper.updateSlidesClasses();
}}
Object.assign(swiper, {
freeMode: {
onTouchStart,
onTouchMove,
onTouchEnd
}});
}
function Grid(_ref){
let {
swiper,
extendParams
}=_ref;
extendParams({
grid: {
rows: 1,
fill: 'column'
}});
let slidesNumberEvenToRows;
let slidesPerRow;
let numFullColumns;
const initSlides=slidesLength=> {
const {
slidesPerView
}=swiper.params;
const {
rows,
fill
}=swiper.params.grid;
slidesPerRow=slidesNumberEvenToRows / rows;
numFullColumns=Math.floor(slidesLength / rows);
if(Math.floor(slidesLength / rows)===slidesLength / rows){
slidesNumberEvenToRows=slidesLength;
}else{
slidesNumberEvenToRows=Math.ceil(slidesLength / rows) * rows;
}
if(slidesPerView!=='auto'&&fill==='row'){
slidesNumberEvenToRows=Math.max(slidesNumberEvenToRows, slidesPerView * rows);
}};
const updateSlide=(i, slide, slidesLength, getDirectionLabel)=> {
const {
slidesPerGroup,
spaceBetween
}=swiper.params;
const {
rows,
fill
}=swiper.params.grid;
let newSlideOrderIndex;
let column;
let row;
if(fill==='row'&&slidesPerGroup > 1){
const groupIndex=Math.floor(i / (slidesPerGroup * rows));
const slideIndexInGroup=i - rows * slidesPerGroup * groupIndex;
const columnsInGroup=groupIndex===0 ? slidesPerGroup:Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);
row=Math.floor(slideIndexInGroup / columnsInGroup);
column=slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;
newSlideOrderIndex=column + row * slidesNumberEvenToRows / rows;
slide.css({
'-webkit-order': newSlideOrderIndex,
order: newSlideOrderIndex
});
}else if(fill==='column'){
column=Math.floor(i / rows);
row=i - column * rows;
if(column > numFullColumns||column===numFullColumns&&row===rows - 1){
row +=1;
if(row >=rows){
row=0;
column +=1;
}}
}else{
row=Math.floor(i / slidesPerRow);
column=i - row * slidesPerRow;
}
slide.css(getDirectionLabel('margin-top'), row!==0 ? spaceBetween&&`${spaceBetween}px`:'');
};
const updateWrapperSize=(slideSize, snapGrid, getDirectionLabel)=> {
const {
spaceBetween,
centeredSlides,
roundLengths
}=swiper.params;
const {
rows
}=swiper.params.grid;
swiper.virtualSize=(slideSize + spaceBetween) * slidesNumberEvenToRows;
swiper.virtualSize=Math.ceil(swiper.virtualSize / rows) - spaceBetween;
swiper.$wrapperEl.css({
[getDirectionLabel('width')]: `${swiper.virtualSize + spaceBetween}px`
});
if(centeredSlides){
snapGrid.splice(0, snapGrid.length);
const newSlidesGrid=[];
for (let i=0; i < snapGrid.length; i +=1){
let slidesGridItem=snapGrid[i];
if(roundLengths) slidesGridItem=Math.floor(slidesGridItem);
if(snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);
}
snapGrid.push(...newSlidesGrid);
}};
swiper.grid={
initSlides,
updateSlide,
updateWrapperSize
};}
function appendSlide(slides){
const swiper=this;
const {
$wrapperEl,
params
}=swiper;
if(params.loop){
swiper.loopDestroy();
}
if(typeof slides==='object'&&'length' in slides){
for (let i=0; i < slides.length; i +=1){
if(slides[i]) $wrapperEl.append(slides[i]);
}}else{
$wrapperEl.append(slides);
}
if(params.loop){
swiper.loopCreate();
}
if(!params.observer){
swiper.update();
}}
function prependSlide(slides){
const swiper=this;
const {
params,
$wrapperEl,
activeIndex
}=swiper;
if(params.loop){
swiper.loopDestroy();
}
let newActiveIndex=activeIndex + 1;
if(typeof slides==='object'&&'length' in slides){
for (let i=0; i < slides.length; i +=1){
if(slides[i]) $wrapperEl.prepend(slides[i]);
}
newActiveIndex=activeIndex + slides.length;
}else{
$wrapperEl.prepend(slides);
}
if(params.loop){
swiper.loopCreate();
}
if(!params.observer){
swiper.update();
}
swiper.slideTo(newActiveIndex, 0, false);
}
function addSlide(index, slides){
const swiper=this;
const {
$wrapperEl,
params,
activeIndex
}=swiper;
let activeIndexBuffer=activeIndex;
if(params.loop){
activeIndexBuffer -=swiper.loopedSlides;
swiper.loopDestroy();
swiper.slides=$wrapperEl.children(`.${params.slideClass}`);
}
const baseLength=swiper.slides.length;
if(index <=0){
swiper.prependSlide(slides);
return;
}
if(index >=baseLength){
swiper.appendSlide(slides);
return;
}
let newActiveIndex=activeIndexBuffer > index ? activeIndexBuffer + 1:activeIndexBuffer;
const slidesBuffer=[];
for (let i=baseLength - 1; i >=index; i -=1){
const currentSlide=swiper.slides.eq(i);
currentSlide.remove();
slidesBuffer.unshift(currentSlide);
}
if(typeof slides==='object'&&'length' in slides){
for (let i=0; i < slides.length; i +=1){
if(slides[i]) $wrapperEl.append(slides[i]);
}
newActiveIndex=activeIndexBuffer > index ? activeIndexBuffer + slides.length:activeIndexBuffer;
}else{
$wrapperEl.append(slides);
}
for (let i=0; i < slidesBuffer.length; i +=1){
$wrapperEl.append(slidesBuffer[i]);
}
if(params.loop){
swiper.loopCreate();
}
if(!params.observer){
swiper.update();
}
if(params.loop){
swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
}else{
swiper.slideTo(newActiveIndex, 0, false);
}}
function removeSlide(slidesIndexes){
const swiper=this;
const {
params,
$wrapperEl,
activeIndex
}=swiper;
let activeIndexBuffer=activeIndex;
if(params.loop){
activeIndexBuffer -=swiper.loopedSlides;
swiper.loopDestroy();
swiper.slides=$wrapperEl.children(`.${params.slideClass}`);
}
let newActiveIndex=activeIndexBuffer;
let indexToRemove;
if(typeof slidesIndexes==='object'&&'length' in slidesIndexes){
for (let i=0; i < slidesIndexes.length; i +=1){
indexToRemove=slidesIndexes[i];
if(swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();
if(indexToRemove < newActiveIndex) newActiveIndex -=1;
}
newActiveIndex=Math.max(newActiveIndex, 0);
}else{
indexToRemove=slidesIndexes;
if(swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();
if(indexToRemove < newActiveIndex) newActiveIndex -=1;
newActiveIndex=Math.max(newActiveIndex, 0);
}
if(params.loop){
swiper.loopCreate();
}
if(!params.observer){
swiper.update();
}
if(params.loop){
swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
}else{
swiper.slideTo(newActiveIndex, 0, false);
}}
function removeAllSlides(){
const swiper=this;
const slidesIndexes=[];
for (let i=0; i < swiper.slides.length; i +=1){
slidesIndexes.push(i);
}
swiper.removeSlide(slidesIndexes);
}
function Manipulation(_ref){
let {
swiper
}=_ref;
Object.assign(swiper, {
appendSlide: appendSlide.bind(swiper),
prependSlide: prependSlide.bind(swiper),
addSlide: addSlide.bind(swiper),
removeSlide: removeSlide.bind(swiper),
removeAllSlides: removeAllSlides.bind(swiper)
});
}
function effectInit(params){
const {
effect,
swiper,
on,
setTranslate,
setTransition,
overwriteParams,
perspective,
recreateShadows,
getEffectParams
}=params;
on('beforeInit', ()=> {
if(swiper.params.effect!==effect) return;
swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);
if(perspective&&perspective()){
swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);
}
const overwriteParamsResult=overwriteParams ? overwriteParams():{};
Object.assign(swiper.params, overwriteParamsResult);
Object.assign(swiper.originalParams, overwriteParamsResult);
});
on('setTranslate', ()=> {
if(swiper.params.effect!==effect) return;
setTranslate();
});
on('setTransition', (_s, duration)=> {
if(swiper.params.effect!==effect) return;
setTransition(duration);
});
on('transitionEnd', ()=> {
if(swiper.params.effect!==effect) return;
if(recreateShadows){
if(!getEffectParams||!getEffectParams().slideShadows) return;
swiper.slides.each(slideEl=> {
const $slideEl=swiper.$(slideEl);
$slideEl.find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').remove();
});
recreateShadows();
}});
let requireUpdateOnVirtual;
on('virtualUpdate', ()=> {
if(swiper.params.effect!==effect) return;
if(!swiper.slides.length){
requireUpdateOnVirtual=true;
}
requestAnimationFrame(()=> {
if(requireUpdateOnVirtual&&swiper.slides&&swiper.slides.length){
setTranslate();
requireUpdateOnVirtual=false;
}});
});
}
function effectTarget(effectParams, $slideEl){
if(effectParams.transformEl){
return $slideEl.find(effectParams.transformEl).css({
'backface-visibility': 'hidden',
'-webkit-backface-visibility': 'hidden'
});
}
return $slideEl;
}
function effectVirtualTransitionEnd(_ref){
let {
swiper,
duration,
transformEl,
allSlides
}=_ref;
const {
slides,
activeIndex,
$wrapperEl
}=swiper;
if(swiper.params.virtualTranslate&&duration!==0){
let eventTriggered=false;
let $transitionEndTarget;
if(allSlides){
$transitionEndTarget=transformEl ? slides.find(transformEl):slides;
}else{
$transitionEndTarget=transformEl ? slides.eq(activeIndex).find(transformEl):slides.eq(activeIndex);
}
$transitionEndTarget.transitionEnd(()=> {
if(eventTriggered) return;
if(!swiper||swiper.destroyed) return;
eventTriggered=true;
swiper.animating=false;
const triggerEvents=['webkitTransitionEnd', 'transitionend'];
for (let i=0; i < triggerEvents.length; i +=1){
$wrapperEl.trigger(triggerEvents[i]);
}});
}}
function EffectFade(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
fadeEffect: {
crossFade: false,
transformEl: null
}});
const setTranslate=()=> {
const {
slides
}=swiper;
const params=swiper.params.fadeEffect;
for (let i=0; i < slides.length; i +=1){
const $slideEl=swiper.slides.eq(i);
const offset=$slideEl[0].swiperSlideOffset;
let tx=-offset;
if(!swiper.params.virtualTranslate) tx -=swiper.translate;
let ty=0;
if(!swiper.isHorizontal()){
ty=tx;
tx=0;
}
const slideOpacity=swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs($slideEl[0].progress), 0):1 + Math.min(Math.max($slideEl[0].progress, -1), 0);
const $targetEl=effectTarget(params, $slideEl);
$targetEl.css({
opacity: slideOpacity
}).transform(`translate3d(${tx}px, ${ty}px, 0px)`);
}};
const setTransition=duration=> {
const {
transformEl
}=swiper.params.fadeEffect;
const $transitionElements=transformEl ? swiper.slides.find(transformEl):swiper.slides;
$transitionElements.transition(duration);
effectVirtualTransitionEnd({
swiper,
duration,
transformEl,
allSlides: true
});
};
effectInit({
effect: 'fade',
swiper,
on,
setTranslate,
setTransition,
overwriteParams: ()=> ({
slidesPerView: 1,
slidesPerGroup: 1,
watchSlidesProgress: true,
spaceBetween: 0,
virtualTranslate: !swiper.params.cssMode
})
});
}
function EffectCube(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
cubeEffect: {
slideShadows: true,
shadow: true,
shadowOffset: 20,
shadowScale: 0.94
}});
const createSlideShadows=($slideEl, progress, isHorizontal)=> {
let shadowBefore=isHorizontal ? $slideEl.find('.swiper-slide-shadow-left'):$slideEl.find('.swiper-slide-shadow-top');
let shadowAfter=isHorizontal ? $slideEl.find('.swiper-slide-shadow-right'):$slideEl.find('.swiper-slide-shadow-bottom');
if(shadowBefore.length===0){
shadowBefore=$(`<div class="swiper-slide-shadow-${isHorizontal ? 'left':'top'}"></div>`);
$slideEl.append(shadowBefore);
}
if(shadowAfter.length===0){
shadowAfter=$(`<div class="swiper-slide-shadow-${isHorizontal ? 'right':'bottom'}"></div>`);
$slideEl.append(shadowAfter);
}
if(shadowBefore.length) shadowBefore[0].style.opacity=Math.max(-progress, 0);
if(shadowAfter.length) shadowAfter[0].style.opacity=Math.max(progress, 0);
};
const recreateShadows=()=> {
const isHorizontal=swiper.isHorizontal();
swiper.slides.each(slideEl=> {
const progress=Math.max(Math.min(slideEl.progress, 1), -1);
createSlideShadows($(slideEl), progress, isHorizontal);
});
};
const setTranslate=()=> {
const {
$el,
$wrapperEl,
slides,
width: swiperWidth,
height: swiperHeight,
rtlTranslate: rtl,
size: swiperSize,
browser
}=swiper;
const params=swiper.params.cubeEffect;
const isHorizontal=swiper.isHorizontal();
const isVirtual=swiper.virtual&&swiper.params.virtual.enabled;
let wrapperRotate=0;
let $cubeShadowEl;
if(params.shadow){
if(isHorizontal){
$cubeShadowEl=$wrapperEl.find('.swiper-cube-shadow');
if($cubeShadowEl.length===0){
$cubeShadowEl=$('<div class="swiper-cube-shadow"></div>');
$wrapperEl.append($cubeShadowEl);
}
$cubeShadowEl.css({
height: `${swiperWidth}px`
});
}else{
$cubeShadowEl=$el.find('.swiper-cube-shadow');
if($cubeShadowEl.length===0){
$cubeShadowEl=$('<div class="swiper-cube-shadow"></div>');
$el.append($cubeShadowEl);
}}
}
for (let i=0; i < slides.length; i +=1){
const $slideEl=slides.eq(i);
let slideIndex=i;
if(isVirtual){
slideIndex=parseInt($slideEl.attr('data-swiper-slide-index'), 10);
}
let slideAngle=slideIndex * 90;
let round=Math.floor(slideAngle / 360);
if(rtl){
slideAngle=-slideAngle;
round=Math.floor(-slideAngle / 360);
}
const progress=Math.max(Math.min($slideEl[0].progress, 1), -1);
let tx=0;
let ty=0;
let tz=0;
if(slideIndex % 4===0){
tx=-round * 4 * swiperSize;
tz=0;
}else if((slideIndex - 1) % 4===0){
tx=0;
tz=-round * 4 * swiperSize;
}else if((slideIndex - 2) % 4===0){
tx=swiperSize + round * 4 * swiperSize;
tz=swiperSize;
}else if((slideIndex - 3) % 4===0){
tx=-swiperSize;
tz=3 * swiperSize + swiperSize * 4 * round;
}
if(rtl){
tx=-tx;
}
if(!isHorizontal){
ty=tx;
tx=0;
}
const transform=`rotateX(${isHorizontal ? 0:-slideAngle}deg) rotateY(${isHorizontal ? slideAngle:0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;
if(progress <=1&&progress > -1){
wrapperRotate=slideIndex * 90 + progress * 90;
if(rtl) wrapperRotate=-slideIndex * 90 - progress * 90;
}
$slideEl.transform(transform);
if(params.slideShadows){
createSlideShadows($slideEl, progress, isHorizontal);
}}
$wrapperEl.css({
'-webkit-transform-origin': `50% 50% -${swiperSize / 2}px`,
'transform-origin': `50% 50% -${swiperSize / 2}px`
});
if(params.shadow){
if(isHorizontal){
$cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);
}else{
const shadowAngle=Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;
const multiplier=1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);
const scale1=params.shadowScale;
const scale2=params.shadowScale / multiplier;
const offset=params.shadowOffset;
$cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);
}}
const zFactor=browser.isSafari||browser.isWebView ? -swiperSize / 2:0;
$wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0:wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate:0}deg)`);
$wrapperEl[0].style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);
};
const setTransition=duration=> {
const {
$el,
slides
}=swiper;
slides.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
if(swiper.params.cubeEffect.shadow&&!swiper.isHorizontal()){
$el.find('.swiper-cube-shadow').transition(duration);
}};
effectInit({
effect: 'cube',
swiper,
on,
setTranslate,
setTransition,
recreateShadows,
getEffectParams: ()=> swiper.params.cubeEffect,
perspective: ()=> true,
overwriteParams: ()=> ({
slidesPerView: 1,
slidesPerGroup: 1,
watchSlidesProgress: true,
resistanceRatio: 0,
spaceBetween: 0,
centeredSlides: false,
virtualTranslate: true
})
});
}
function createShadow(params, $slideEl, side){
const shadowClass=`swiper-slide-shadow${side ? `-${side}`:''}`;
const $shadowContainer=params.transformEl ? $slideEl.find(params.transformEl):$slideEl;
let $shadowEl=$shadowContainer.children(`.${shadowClass}`);
if(!$shadowEl.length){
$shadowEl=$(`<div class="swiper-slide-shadow${side ? `-${side}`:''}"></div>`);
$shadowContainer.append($shadowEl);
}
return $shadowEl;
}
function EffectFlip(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
flipEffect: {
slideShadows: true,
limitRotation: true,
transformEl: null
}});
const createSlideShadows=($slideEl, progress, params)=> {
let shadowBefore=swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left'):$slideEl.find('.swiper-slide-shadow-top');
let shadowAfter=swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right'):$slideEl.find('.swiper-slide-shadow-bottom');
if(shadowBefore.length===0){
shadowBefore=createShadow(params, $slideEl, swiper.isHorizontal() ? 'left':'top');
}
if(shadowAfter.length===0){
shadowAfter=createShadow(params, $slideEl, swiper.isHorizontal() ? 'right':'bottom');
}
if(shadowBefore.length) shadowBefore[0].style.opacity=Math.max(-progress, 0);
if(shadowAfter.length) shadowAfter[0].style.opacity=Math.max(progress, 0);
};
const recreateShadows=()=> {
const params=swiper.params.flipEffect;
swiper.slides.each(slideEl=> {
const $slideEl=$(slideEl);
let progress=$slideEl[0].progress;
if(swiper.params.flipEffect.limitRotation){
progress=Math.max(Math.min(slideEl.progress, 1), -1);
}
createSlideShadows($slideEl, progress, params);
});
};
const setTranslate=()=> {
const {
slides,
rtlTranslate: rtl
}=swiper;
const params=swiper.params.flipEffect;
for (let i=0; i < slides.length; i +=1){
const $slideEl=slides.eq(i);
let progress=$slideEl[0].progress;
if(swiper.params.flipEffect.limitRotation){
progress=Math.max(Math.min($slideEl[0].progress, 1), -1);
}
const offset=$slideEl[0].swiperSlideOffset;
const rotate=-180 * progress;
let rotateY=rotate;
let rotateX=0;
let tx=swiper.params.cssMode ? -offset - swiper.translate:-offset;
let ty=0;
if(!swiper.isHorizontal()){
ty=tx;
tx=0;
rotateX=-rotateY;
rotateY=0;
}else if(rtl){
rotateY=-rotateY;
}
$slideEl[0].style.zIndex=-Math.abs(Math.round(progress)) + slides.length;
if(params.slideShadows){
createSlideShadows($slideEl, progress, params);
}
const transform=`translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;
const $targetEl=effectTarget(params, $slideEl);
$targetEl.transform(transform);
}};
const setTransition=duration=> {
const {
transformEl
}=swiper.params.flipEffect;
const $transitionElements=transformEl ? swiper.slides.find(transformEl):swiper.slides;
$transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
effectVirtualTransitionEnd({
swiper,
duration,
transformEl
});
};
effectInit({
effect: 'flip',
swiper,
on,
setTranslate,
setTransition,
recreateShadows,
getEffectParams: ()=> swiper.params.flipEffect,
perspective: ()=> true,
overwriteParams: ()=> ({
slidesPerView: 1,
slidesPerGroup: 1,
watchSlidesProgress: true,
spaceBetween: 0,
virtualTranslate: !swiper.params.cssMode
})
});
}
function EffectCoverflow(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
coverflowEffect: {
rotate: 50,
stretch: 0,
depth: 100,
scale: 1,
modifier: 1,
slideShadows: true,
transformEl: null
}});
const setTranslate=()=> {
const {
width: swiperWidth,
height: swiperHeight,
slides,
slidesSizesGrid
}=swiper;
const params=swiper.params.coverflowEffect;
const isHorizontal=swiper.isHorizontal();
const transform=swiper.translate;
const center=isHorizontal ? -transform + swiperWidth / 2:-transform + swiperHeight / 2;
const rotate=isHorizontal ? params.rotate:-params.rotate;
const translate=params.depth;
for (let i=0, length=slides.length; i < length; i +=1){
const $slideEl=slides.eq(i);
const slideSize=slidesSizesGrid[i];
const slideOffset=$slideEl[0].swiperSlideOffset;
const centerOffset=(center - slideOffset - slideSize / 2) / slideSize;
const offsetMultiplier=typeof params.modifier==='function' ? params.modifier(centerOffset):centerOffset * params.modifier;
let rotateY=isHorizontal ? rotate * offsetMultiplier:0;
let rotateX=isHorizontal ? 0:rotate * offsetMultiplier;
let translateZ=-translate * Math.abs(offsetMultiplier);
let stretch=params.stretch;
if(typeof stretch==='string'&&stretch.indexOf('%')!==-1){
stretch=parseFloat(params.stretch) / 100 * slideSize;
}
let translateY=isHorizontal ? 0:stretch * offsetMultiplier;
let translateX=isHorizontal ? stretch * offsetMultiplier:0;
let scale=1 - (1 - params.scale) * Math.abs(offsetMultiplier);
if(Math.abs(translateX) < 0.001) translateX=0;
if(Math.abs(translateY) < 0.001) translateY=0;
if(Math.abs(translateZ) < 0.001) translateZ=0;
if(Math.abs(rotateY) < 0.001) rotateY=0;
if(Math.abs(rotateX) < 0.001) rotateX=0;
if(Math.abs(scale) < 0.001) scale=0;
const slideTransform=`translate3d(${translateX}px,${translateY}px,${translateZ}px)  rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;
const $targetEl=effectTarget(params, $slideEl);
$targetEl.transform(slideTransform);
$slideEl[0].style.zIndex=-Math.abs(Math.round(offsetMultiplier)) + 1;
if(params.slideShadows){
let $shadowBeforeEl=isHorizontal ? $slideEl.find('.swiper-slide-shadow-left'):$slideEl.find('.swiper-slide-shadow-top');
let $shadowAfterEl=isHorizontal ? $slideEl.find('.swiper-slide-shadow-right'):$slideEl.find('.swiper-slide-shadow-bottom');
if($shadowBeforeEl.length===0){
$shadowBeforeEl=createShadow(params, $slideEl, isHorizontal ? 'left':'top');
}
if($shadowAfterEl.length===0){
$shadowAfterEl=createShadow(params, $slideEl, isHorizontal ? 'right':'bottom');
}
if($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity=offsetMultiplier > 0 ? offsetMultiplier:0;
if($shadowAfterEl.length) $shadowAfterEl[0].style.opacity=-offsetMultiplier > 0 ? -offsetMultiplier:0;
}}
};
const setTransition=duration=> {
const {
transformEl
}=swiper.params.coverflowEffect;
const $transitionElements=transformEl ? swiper.slides.find(transformEl):swiper.slides;
$transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
};
effectInit({
effect: 'coverflow',
swiper,
on,
setTranslate,
setTransition,
perspective: ()=> true,
overwriteParams: ()=> ({
watchSlidesProgress: true
})
});
}
function EffectCreative(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
creativeEffect: {
transformEl: null,
limitProgress: 1,
shadowPerProgress: false,
progressMultiplier: 1,
perspective: true,
prev: {
translate: [0, 0, 0],
rotate: [0, 0, 0],
opacity: 1,
scale: 1
},
next: {
translate: [0, 0, 0],
rotate: [0, 0, 0],
opacity: 1,
scale: 1
}}
});
const getTranslateValue=value=> {
if(typeof value==='string') return value;
return `${value}px`;
};
const setTranslate=()=> {
const {
slides,
$wrapperEl,
slidesSizesGrid
}=swiper;
const params=swiper.params.creativeEffect;
const {
progressMultiplier: multiplier
}=params;
const isCenteredSlides=swiper.params.centeredSlides;
if(isCenteredSlides){
const margin=slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore||0;
$wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);
}
for (let i=0; i < slides.length; i +=1){
const $slideEl=slides.eq(i);
const slideProgress=$slideEl[0].progress;
const progress=Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);
let originalProgress=progress;
if(!isCenteredSlides){
originalProgress=Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);
}
const offset=$slideEl[0].swiperSlideOffset;
const t=[swiper.params.cssMode ? -offset - swiper.translate:-offset, 0, 0];
const r=[0, 0, 0];
let custom=false;
if(!swiper.isHorizontal()){
t[1]=t[0];
t[0]=0;
}
let data={
translate: [0, 0, 0],
rotate: [0, 0, 0],
scale: 1,
opacity: 1
};
if(progress < 0){
data=params.next;
custom=true;
}else if(progress > 0){
data=params.prev;
custom=true;
}
t.forEach((value, index)=> {
t[index]=`calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;
});
r.forEach((value, index)=> {
r[index]=data.rotate[index] * Math.abs(progress * multiplier);
});
$slideEl[0].style.zIndex=-Math.abs(Math.round(slideProgress)) + slides.length;
const translateString=t.join(', ');
const rotateString=`rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;
const scaleString=originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})`:`scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;
const opacityString=originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier:1 - (1 - data.opacity) * originalProgress * multiplier;
const transform=`translate3d(${translateString}) ${rotateString} ${scaleString}`;
if(custom&&data.shadow||!custom){
let $shadowEl=$slideEl.children('.swiper-slide-shadow');
if($shadowEl.length===0&&data.shadow){
$shadowEl=createShadow(params, $slideEl);
}
if($shadowEl.length){
const shadowOpacity=params.shadowPerProgress ? progress * (1 / params.limitProgress):progress;
$shadowEl[0].style.opacity=Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);
}}
const $targetEl=effectTarget(params, $slideEl);
$targetEl.transform(transform).css({
opacity: opacityString
});
if(data.origin){
$targetEl.css('transform-origin', data.origin);
}}
};
const setTransition=duration=> {
const {
transformEl
}=swiper.params.creativeEffect;
const $transitionElements=transformEl ? swiper.slides.find(transformEl):swiper.slides;
$transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);
effectVirtualTransitionEnd({
swiper,
duration,
transformEl,
allSlides: true
});
};
effectInit({
effect: 'creative',
swiper,
on,
setTranslate,
setTransition,
perspective: ()=> swiper.params.creativeEffect.perspective,
overwriteParams: ()=> ({
watchSlidesProgress: true,
virtualTranslate: !swiper.params.cssMode
})
});
}
function EffectCards(_ref){
let {
swiper,
extendParams,
on
}=_ref;
extendParams({
cardsEffect: {
slideShadows: true,
transformEl: null,
rotate: true,
perSlideRotate: 2,
perSlideOffset: 8
}});
const setTranslate=()=> {
const {
slides,
activeIndex
}=swiper;
const params=swiper.params.cardsEffect;
const {
startTranslate,
isTouched
}=swiper.touchEventsData;
const currentTranslate=swiper.translate;
for (let i=0; i < slides.length; i +=1){
const $slideEl=slides.eq(i);
const slideProgress=$slideEl[0].progress;
const progress=Math.min(Math.max(slideProgress, -4), 4);
let offset=$slideEl[0].swiperSlideOffset;
if(swiper.params.centeredSlides&&!swiper.params.cssMode){
swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);
}
if(swiper.params.centeredSlides&&swiper.params.cssMode){
offset -=slides[0].swiperSlideOffset;
}
let tX=swiper.params.cssMode ? -offset - swiper.translate:-offset;
let tY=0;
const tZ=-100 * Math.abs(progress);
let scale=1;
let rotate=-params.perSlideRotate * progress;
let tXAdd=params.perSlideOffset - Math.abs(progress) * 0.75;
const slideIndex=swiper.virtual&&swiper.params.virtual.enabled ? swiper.virtual.from + i:i;
const isSwipeToNext=(slideIndex===activeIndex||slideIndex===activeIndex - 1)&&progress > 0&&progress < 1&&(isTouched||swiper.params.cssMode)&&currentTranslate < startTranslate;
const isSwipeToPrev=(slideIndex===activeIndex||slideIndex===activeIndex + 1)&&progress < 0&&progress > -1&&(isTouched||swiper.params.cssMode)&&currentTranslate > startTranslate;
if(isSwipeToNext||isSwipeToPrev){
const subProgress=(1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;
rotate +=-28 * progress * subProgress;
scale +=-0.5 * subProgress;
tXAdd +=96 * subProgress;
tY=`${-25 * subProgress * Math.abs(progress)}%`;
}
if(progress < 0){
tX=`calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;
}else if(progress > 0){
tX=`calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;
}else{
tX=`${tX}px`;
}
if(!swiper.isHorizontal()){
const prevY=tY;
tY=tX;
tX=prevY;
}
const scaleString=progress < 0 ? `${1 + (1 - scale) * progress}`:`${1 - (1 - scale) * progress}`;
const transform=`
translate3d(${tX}, ${tY}, ${tZ}px)
rotateZ(${params.rotate ? rotate:0}deg)
scale(${scaleString})
`;
if(params.slideShadows){
let $shadowEl=$slideEl.find('.swiper-slide-shadow');
if($shadowEl.length===0){
$shadowEl=createShadow(params, $slideEl);
}
if($shadowEl.length) $shadowEl[0].style.opacity=Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);
}
$slideEl[0].style.zIndex=-Math.abs(Math.round(slideProgress)) + slides.length;
const $targetEl=effectTarget(params, $slideEl);
$targetEl.transform(transform);
}};
const setTransition=duration=> {
const {
transformEl
}=swiper.params.cardsEffect;
const $transitionElements=transformEl ? swiper.slides.find(transformEl):swiper.slides;
$transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);
effectVirtualTransitionEnd({
swiper,
duration,
transformEl
});
};
effectInit({
effect: 'cards',
swiper,
on,
setTranslate,
setTransition,
perspective: ()=> true,
overwriteParams: ()=> ({
watchSlidesProgress: true,
virtualTranslate: !swiper.params.cssMode
})
});
}
const modules=[Virtual, Keyboard, Mousewheel, Navigation, Pagination, Scrollbar, Parallax, Zoom, Lazy, Controller, A11y, History, HashNavigation, Autoplay, Thumb, freeMode, Grid, Manipulation, EffectFade, EffectCube, EffectFlip, EffectCoverflow, EffectCreative, EffectCards];
Swiper.use(modules);
return Swiper;
}));
!function(t,e){"object"==typeof module&&module.exports?module.exports=e():t.EvEmitter=e()}("undefined"!=typeof window?window:this,(function(){function t(){}let e=t.prototype;return e.on=function(t,e){if(!t||!e)return this;let i=this._events=this._events||{},s=i[t]=i[t]||[];return s.includes(e)||s.push(e),this},e.once=function(t,e){if(!t||!e)return this;this.on(t,e);let i=this._onceEvents=this._onceEvents||{};return(i[t]=i[t]||{})[e]=!0,this},e.off=function(t,e){let i=this._events&&this._events[t];if(!i||!i.length)return this;let s=i.indexOf(e);return-1!=s&&i.splice(s,1),this},e.emitEvent=function(t,e){let i=this._events&&this._events[t];if(!i||!i.length)return this;i=i.slice(0),e=e||[];let s=this._onceEvents&&this._onceEvents[t];for(let n of i){s&&s[n]&&(this.off(t,n),delete s[n]),n.apply(this,e)}return this},e.allOff=function(){return delete this._events,delete this._onceEvents,this},t})),
function(t,e){"object"==typeof module&&module.exports?module.exports=e(t,require("ev-emitter")):t.imagesLoaded=e(t,t.EvEmitter)}("undefined"!=typeof window?window:this,(function(t,e){let i=t.jQuery,s=t.console;function n(t,e,o){if(!(this instanceof n))return new n(t,e,o);let r=t;var h;("string"==typeof t&&(r=document.querySelectorAll(t)),r)?(this.elements=(h=r,Array.isArray(h)?h:"object"==typeof h&&"number"==typeof h.length?[...h]:[h]),this.options={},"function"==typeof e?o=e:Object.assign(this.options,e),o&&this.on("always",o),this.getImages(),i&&(this.jqDeferred=new i.Deferred),setTimeout(this.check.bind(this))):s.error(`Bad element for imagesLoaded ${r||t}`)}n.prototype=Object.create(e.prototype),n.prototype.getImages=function(){this.images=[],this.elements.forEach(this.addElementImages,this)};const o=[1,9,11];n.prototype.addElementImages=function(t){"IMG"===t.nodeName&&this.addImage(t),!0===this.options.background&&this.addElementBackgroundImages(t);let{nodeType:e}=t;if(!e||!o.includes(e))return;let i=t.querySelectorAll("img");for(let t of i)this.addImage(t);if("string"==typeof this.options.background){let e=t.querySelectorAll(this.options.background);for(let t of e)this.addElementBackgroundImages(t)}};const r=/url\((['"])?(.*?)\1\)/gi;function h(t){this.img=t}function d(t,e){this.url=t,this.element=e,this.img=new Image}return n.prototype.addElementBackgroundImages=function(t){let e=getComputedStyle(t);if(!e)return;let i=r.exec(e.backgroundImage);for(;null!==i;){let s=i&&i[2];s&&this.addBackground(s,t),i=r.exec(e.backgroundImage)}},n.prototype.addImage=function(t){let e=new h(t);this.images.push(e)},n.prototype.addBackground=function(t,e){let i=new d(t,e);this.images.push(i)},n.prototype.check=function(){if(this.progressedCount=0,this.hasAnyBroken=!1,!this.images.length)return void this.complete();let t=(t,e,i)=>{setTimeout((()=>{this.progress(t,e,i)}))};this.images.forEach((function(e){e.once("progress",t),e.check()}))},n.prototype.progress=function(t,e,i){this.progressedCount++,this.hasAnyBroken=this.hasAnyBroken||!t.isLoaded,this.emitEvent("progress",[this,t,e]),this.jqDeferred&&this.jqDeferred.notify&&this.jqDeferred.notify(this,t),this.progressedCount===this.images.length&&this.complete(),this.options.debug&&s&&s.log(`progress: ${i}`,t,e)},n.prototype.complete=function(){let t=this.hasAnyBroken?"fail":"done";if(this.isComplete=!0,this.emitEvent(t,[this]),this.emitEvent("always",[this]),this.jqDeferred){let t=this.hasAnyBroken?"reject":"resolve";this.jqDeferred[t](this)}},h.prototype=Object.create(e.prototype),h.prototype.check=function(){this.getIsImageComplete()?this.confirm(0!==this.img.naturalWidth,"naturalWidth"):(this.proxyImage=new Image,this.img.crossOrigin&&(this.proxyImage.crossOrigin=this.img.crossOrigin),this.proxyImage.addEventListener("load",this),this.proxyImage.addEventListener("error",this),this.img.addEventListener("load",this),this.img.addEventListener("error",this),this.proxyImage.src=this.img.currentSrc||this.img.src)},h.prototype.getIsImageComplete=function(){return this.img.complete&&this.img.naturalWidth},h.prototype.confirm=function(t,e){this.isLoaded=t;let{parentNode:i}=this.img,s="PICTURE"===i.nodeName?i:this.img;this.emitEvent("progress",[this,s,e])},h.prototype.handleEvent=function(t){let e="on"+t.type;this[e]&&this[e](t)},h.prototype.onload=function(){this.confirm(!0,"onload"),this.unbindEvents()},h.prototype.onerror=function(){this.confirm(!1,"onerror"),this.unbindEvents()},h.prototype.unbindEvents=function(){this.proxyImage.removeEventListener("load",this),this.proxyImage.removeEventListener("error",this),this.img.removeEventListener("load",this),this.img.removeEventListener("error",this)},d.prototype=Object.create(h.prototype),d.prototype.check=function(){this.img.addEventListener("load",this),this.img.addEventListener("error",this),this.img.src=this.url,this.getIsImageComplete()&&(this.confirm(0!==this.img.naturalWidth,"naturalWidth"),this.unbindEvents())},d.prototype.unbindEvents=function(){this.img.removeEventListener("load",this),this.img.removeEventListener("error",this)},d.prototype.confirm=function(t,e){this.isLoaded=t,this.emitEvent("progress",[this,this.element,e])},n.makeJQueryPlugin=function(e){(e=e||t.jQuery)&&(i=e,i.fn.imagesLoaded=function(t,e){return new n(this,t,e).jqDeferred.promise(i(this))})},n.makeJQueryPlugin(),n}));
!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var f;"undefined"!=typeof window?f=window:"undefined"!=typeof global?f=global:"undefined"!=typeof self&&(f=self),f.sbjs=e()}}(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(_dereq_,module,exports){
"use strict";
var init=_dereq_('./init');
var sbjs={
init: function(prefs){
this.get=init(prefs);
if(prefs&&prefs.callback&&typeof prefs.callback==='function'){
prefs.callback(this.get);
}}
};
module.exports=sbjs;
},{"./init":6}],2:[function(_dereq_,module,exports){
"use strict";
var terms=_dereq_('./terms'),
utils=_dereq_('./helpers/utils');
var data={
containers: {
current:          'sbjs_current',
current_extra:    'sbjs_current_add',
first:            'sbjs_first',
first_extra:      'sbjs_first_add',
session:          'sbjs_session',
udata:            'sbjs_udata',
promocode:        'sbjs_promo'
},
service: {
migrations:       'sbjs_migrations'
},
delimiter:          '|||',
aliases: {
main: {
type:           'typ',
source:         'src',
medium:         'mdm',
campaign:       'cmp',
content:        'cnt',
term:           'trm',
id:             'id',
platform:       'plt',
format:         'fmt',
tactic:         'tct'
},
extra: {
fire_date:      'fd',
entrance_point: 'ep',
referer:        'rf'
},
session: {
pages_seen:     'pgs',
current_page:   'cpg'
},
udata: {
visits:         'vst',
ip:             'uip',
agent:          'uag'
},
promo:            'code'
},
pack: {
main: function(sbjs){
return (
data.aliases.main.type      + '=' + sbjs.type     + data.delimiter +
data.aliases.main.source    + '=' + sbjs.source   + data.delimiter +
data.aliases.main.medium    + '=' + sbjs.medium   + data.delimiter +
data.aliases.main.campaign  + '=' + sbjs.campaign + data.delimiter +
data.aliases.main.content   + '=' + sbjs.content  + data.delimiter +
data.aliases.main.term      + '=' + sbjs.term     + data.delimiter +
data.aliases.main.id        + '=' + sbjs.id       + data.delimiter +
data.aliases.main.platform  + '=' + sbjs.platform + data.delimiter +
data.aliases.main.format    + '=' + sbjs.format   + data.delimiter +
data.aliases.main.tactic    + '=' + sbjs.tactic
);
},
extra: function(timezone_offset){
return (
data.aliases.extra.fire_date      + '=' + utils.setDate(new Date, timezone_offset) + data.delimiter +
data.aliases.extra.entrance_point + '=' + document.location.href                   + data.delimiter +
data.aliases.extra.referer        + '=' + (document.referrer||terms.none)
);
},
user: function(visits, user_ip){
return (
data.aliases.udata.visits + '=' + visits  + data.delimiter +
data.aliases.udata.ip     + '=' + user_ip + data.delimiter +
data.aliases.udata.agent  + '=' + navigator.userAgent
);
},
session: function(pages){
return (
data.aliases.session.pages_seen   + '=' + pages + data.delimiter +
data.aliases.session.current_page + '=' + document.location.href
);
},
promo: function(promo){
return (
data.aliases.promo + '=' + utils.setLeadingZeroToInt(utils.randomInt(promo.min, promo.max), promo.max.toString().length)
);
}}
};
module.exports=data;
},{"./helpers/utils":5,"./terms":9}],3:[function(_dereq_,module,exports){
"use strict";
var delimiter=_dereq_('../data').delimiter;
module.exports={
useBase64: false,
setBase64Flag: function(value){
this.useBase64=value;
},
encodeData: function(s){
return encodeURIComponent(s).replace(/\!/g, '%21')
.replace(/\~/g, '%7E')
.replace(/\*/g, '%2A')
.replace(/\'/g, '%27')
.replace(/\(/g, '%28')
.replace(/\)/g, '%29');
},
decodeData: function(s){
try {
return decodeURIComponent(s).replace(/\%21/g, '!')
.replace(/\%7E/g, '~')
.replace(/\%2A/g, '*')
.replace(/\%27/g, "'")
.replace(/\%28/g, '(')
.replace(/\%29/g, ')');
} catch(err1){
try { return unescape(s); } catch(err2){ return ''; }}
},
set: function(name, value, minutes, domain, excl_subdomains){
var expires, basehost;
if(minutes){
var date=new Date();
date.setTime(date.getTime() + (minutes * 60 * 1000));
expires='; expires=' + date.toGMTString();
}else{
expires='';
}
if(domain&&!excl_subdomains){
basehost=';domain=.' + domain;
}else{
basehost='';
}
var cookie_content=this.encodeData(value);
if(this.useBase64){
cookie_content=btoa(cookie_content).replace(/=+$/, '');
}
document.cookie=this.encodeData(name) + '=' + cookie_content + expires + basehost + '; path=/';
},
get: function(name){
var nameEQ=this.encodeData(name) + '=',
ca=document.cookie.split(';');
for (var i=0; i < ca.length; i++){
var c=ca[i];
while (c.charAt(0)===' '){ c=c.substring(1, c.length); }
if(c.indexOf(nameEQ)===0){
var cookie_content=c.substring(nameEQ.length, c.length);
if(/^[A-Za-z0-9+/]+$/.test(cookie_content)){
try {
cookie_content=atob(cookie_content.padEnd(Math.ceil(cookie_content.length / 4) * 4, "="));
} catch (error){
}}
return this.decodeData(cookie_content);
}}
return null;
},
destroy: function(name, domain, excl_subdomains){
this.set(name, '', -1, domain, excl_subdomains);
},
parse: function(yummy){
var cookies=[],
data={};
if(typeof yummy==='string'){
cookies.push(yummy);
}else{
for (var prop in yummy){
if(yummy.hasOwnProperty(prop)){
cookies.push(yummy[prop]);
}}
}
for (var i1=0; i1 < cookies.length; i1++){
var cookie_array;
data[this.unsbjs(cookies[i1])]={};
if(this.get(cookies[i1])){
cookie_array=this.get(cookies[i1]).split(delimiter);
}else{
cookie_array=[];
}
for (var i2=0; i2 < cookie_array.length; i2++){
var tmp_array=cookie_array[i2].split('='),
result_array=tmp_array.splice(0, 1);
result_array.push(tmp_array.join('='));
data[this.unsbjs(cookies[i1])][result_array[0]]=this.decodeData(result_array[1]);
}}
return data;
},
unsbjs: function (string){
return string.replace('sbjs_', '');
}};},{"../data":2}],4:[function(_dereq_,module,exports){
"use strict";
module.exports={
parse: function(str){
var o=this.parseOptions,
m=o.parser[o.strictMode ? 'strict':'loose'].exec(str),
uri={},
i=14;
while (i--){ uri[o.key[i]]=m[i]||''; }
uri[o.q.name]={};
uri[o.key[12]].replace(o.q.parser, function ($0, $1, $2){
if($1){ uri[o.q.name][$1]=$2; }});
return uri;
},
parseOptions: {
strictMode: false,
key: ['source','protocol','authority','userInfo','user','password','host','port','relative','path','directory','file','query','anchor'],
q: {
name:   'queryKey',
parser: /(?:^|&)([^&=]*)=?([^&]*)/g
},
parser: {
strict: /^(?:([^:\/?#]+):)?(?:\/\/((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?))?((((?:[^?#\/]*\/)*)([^?#]*))(?:\?([^#]*))?(?:#(.*))?)/,
loose:  /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/
}},
getParam: function(custom_params){
var query_string={},
query=custom_params ? custom_params:window.location.search.substring(1),
vars=query.split('&');
for (var i=0; i < vars.length; i++){
var pair=vars[i].split('=');
if(typeof query_string[pair[0]]==='undefined'){
query_string[pair[0]]=pair[1];
}else if(typeof query_string[pair[0]]==='string'){
var arr=[ query_string[pair[0]], pair[1] ];
query_string[pair[0]]=arr;
}else{
query_string[pair[0]].push(pair[1]);
}}
return query_string;
},
getHost: function(request){
return this.parse(request).host.replace('www.', '');
}};},{}],5:[function(_dereq_,module,exports){
"use strict";
module.exports={
escapeRegexp: function(string){
return string.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
},
setDate: function(date, offset){
var utc_offset=date.getTimezoneOffset() / 60,
now_hours=date.getHours(),
custom_offset=offset||offset===0 ? offset:-utc_offset;
date.setHours(now_hours + utc_offset + custom_offset);
var year=date.getFullYear(),
month=this.setLeadingZeroToInt(date.getMonth() + 1,   2),
day=this.setLeadingZeroToInt(date.getDate(),        2),
hour=this.setLeadingZeroToInt(date.getHours(),       2),
minute=this.setLeadingZeroToInt(date.getMinutes(),     2),
second=this.setLeadingZeroToInt(date.getSeconds(),     2);
return (year + '-' + month + '-' + day + ' ' + hour + ':' + minute + ':' + second);
},
setLeadingZeroToInt: function(num, size){
var s=num + '';
while (s.length < size){ s='0' + s; }
return s;
},
randomInt: function(min, max){
return Math.floor(Math.random() * (max - min + 1)) + min;
}};},{}],6:[function(_dereq_,module,exports){
"use strict";
var data=_dereq_('./data'),
terms=_dereq_('./terms'),
cookies=_dereq_('./helpers/cookies'),
uri=_dereq_('./helpers/uri'),
utils=_dereq_('./helpers/utils'),
params=_dereq_('./params'),
migrations=_dereq_('./migrations');
module.exports=function(prefs){
var p=params.fetch(prefs);
var get_param=uri.getParam();
var domain=p.domain.host,
isolate=p.domain.isolate,
lifetime=p.lifetime;
cookies.setBase64Flag(p.base64);
migrations.go(lifetime, domain, isolate);
var __sbjs_type,
__sbjs_source,
__sbjs_medium,
__sbjs_campaign,
__sbjs_content,
__sbjs_term,
__sbjs_id,
__sbjs_platform,
__sbjs_format,
__sbjs_tactic;
function mainData(){
var sbjs_data;
if(typeof get_param.utm_source!=='undefined' ||
typeof get_param.utm_medium!=='undefined' ||
typeof get_param.utm_campaign!=='undefined' ||
typeof get_param.utm_content!=='undefined' ||
typeof get_param.utm_term!=='undefined' ||
typeof get_param.utm_id!=='undefined' ||
typeof get_param.utm_source_platform!=='undefined' ||
typeof get_param.utm_creative_format!=='undefined' ||
typeof get_param.utm_marketing_tactic!=='undefined' ||
typeof get_param.gclid!=='undefined' ||
typeof get_param.yclid!=='undefined' ||
typeof get_param[p.campaign_param]!=='undefined' ||
typeof get_param[p.term_param]!=='undefined' ||
typeof get_param[p.content_param]!=='undefined'
){
setFirstAndCurrentExtraData();
sbjs_data=getData(terms.traffic.utm);
}else if(checkReferer(terms.traffic.organic)){
setFirstAndCurrentExtraData();
sbjs_data=getData(terms.traffic.organic);
}else if(!cookies.get(data.containers.session)&&checkReferer(terms.traffic.referral)){
setFirstAndCurrentExtraData();
sbjs_data=getData(terms.traffic.referral);
}else if(!cookies.get(data.containers.first)&&!cookies.get(data.containers.current)){
setFirstAndCurrentExtraData();
sbjs_data=getData(terms.traffic.typein);
}else{
return cookies.get(data.containers.current);
}
return sbjs_data;
}
function getData(type){
switch (type){
case terms.traffic.utm:
__sbjs_type=terms.traffic.utm;
if(typeof get_param.utm_source!=='undefined'){
__sbjs_source=get_param.utm_source;
}else if(typeof get_param.gclid!=='undefined'){
__sbjs_source='google';
}else if(typeof get_param.yclid!=='undefined'){
__sbjs_source='yandex';
}else{
__sbjs_source=terms.none;
}
if(typeof get_param.utm_medium!=='undefined'){
__sbjs_medium=get_param.utm_medium;
}else if(typeof get_param.gclid!=='undefined'){
__sbjs_medium='cpc';
}else if(typeof get_param.yclid!=='undefined'){
__sbjs_medium='cpc';
}else{
__sbjs_medium=terms.none;
}
if(typeof get_param.utm_campaign!=='undefined'){
__sbjs_campaign=get_param.utm_campaign;
}else if(typeof get_param[p.campaign_param]!=='undefined'){
__sbjs_campaign=get_param[p.campaign_param];
}else if(typeof get_param.gclid!=='undefined'){
__sbjs_campaign='google_cpc';
}else if(typeof get_param.yclid!=='undefined'){
__sbjs_campaign='yandex_cpc';
}else{
__sbjs_campaign=terms.none;
}
if(typeof get_param.utm_content!=='undefined'){
__sbjs_content=get_param.utm_content;
}else if(typeof get_param[p.content_param]!=='undefined'){
__sbjs_content=get_param[p.content_param];
}else{
__sbjs_content=terms.none;
}
__sbjs_id=get_param.utm_id||terms.none;
__sbjs_platform=get_param.utm_source_platform||terms.none;
__sbjs_format=get_param.utm_creative_format||terms.none;
__sbjs_tactic=get_param.utm_marketing_tactic||terms.none;
if(typeof get_param.utm_term!=='undefined'){
__sbjs_term=get_param.utm_term;
}else if(typeof get_param[p.term_param]!=='undefined'){
__sbjs_term=get_param[p.term_param];
}else{
__sbjs_term=getUtmTerm()||terms.none;
}
break;
case terms.traffic.organic:
__sbjs_type=terms.traffic.organic;
__sbjs_source=__sbjs_source||uri.getHost(document.referrer);
__sbjs_medium=terms.referer.organic;
__sbjs_campaign=terms.none;
__sbjs_content=terms.none;
__sbjs_term=terms.none;
__sbjs_id=terms.none;
__sbjs_platform=terms.none;
__sbjs_format=terms.none;
__sbjs_tactic=terms.none;
break;
case terms.traffic.referral:
__sbjs_type=terms.traffic.referral;
__sbjs_source=__sbjs_source||uri.getHost(document.referrer);
__sbjs_medium=__sbjs_medium||terms.referer.referral;
__sbjs_campaign=terms.none;
__sbjs_content=uri.parse(document.referrer).path;
__sbjs_term=terms.none;
__sbjs_id=terms.none;
__sbjs_platform=terms.none;
__sbjs_format=terms.none;
__sbjs_tactic=terms.none;
break;
case terms.traffic.typein:
__sbjs_type=terms.traffic.typein;
__sbjs_source=p.typein_attributes.source;
__sbjs_medium=p.typein_attributes.medium;
__sbjs_campaign=terms.none;
__sbjs_content=terms.none;
__sbjs_term=terms.none;
__sbjs_id=terms.none;
__sbjs_platform=terms.none;
__sbjs_format=terms.none;
__sbjs_tactic=terms.none;
break;
default:
__sbjs_type=terms.oops;
__sbjs_source=terms.oops;
__sbjs_medium=terms.oops;
__sbjs_campaign=terms.oops;
__sbjs_content=terms.oops;
__sbjs_term=terms.oops;
__sbjs_id=terms.oops;
__sbjs_platform=terms.oops;
__sbjs_format=terms.oops;
__sbjs_tactic=terms.oops;
}
var sbjs_data={
type:             __sbjs_type,
source:           __sbjs_source,
medium:           __sbjs_medium,
campaign:         __sbjs_campaign,
content:          __sbjs_content,
term:             __sbjs_term,
id:               __sbjs_id,
platform:         __sbjs_platform,
format:           __sbjs_format,
tactic:           __sbjs_tactic
};
return data.pack.main(sbjs_data);
}
function getUtmTerm(){
var referer=document.referrer;
if(get_param.utm_term){
return get_param.utm_term;
}else if(referer&&uri.parse(referer).host&&uri.parse(referer).host.match(/^(?:.*\.)?yandex\..{2,9}$/i)){
try {
return uri.getParam(uri.parse(document.referrer).query).text;
} catch (err){
return false;
}}else{
return false;
}}
function checkReferer(type){
var referer=document.referrer;
switch(type){
case terms.traffic.organic:
return (!!referer&&checkRefererHost(referer)&&isOrganic(referer));
case terms.traffic.referral:
return (!!referer&&checkRefererHost(referer)&&isReferral(referer));
default:
return false;
}}
function checkRefererHost(referer){
if(p.domain){
if(!isolate){
var host_regex=new RegExp('^(?:.*\\.)?' + utils.escapeRegexp(domain) + '$', 'i');
return !(uri.getHost(referer).match(host_regex));
}else{
return (uri.getHost(referer)!==uri.getHost(domain));
}}else{
return (uri.getHost(referer)!==uri.getHost(document.location.href));
}}
function isOrganic(referer){
var y_host='yandex',
y_param='text',
g_host='google';
var y_host_regex=new RegExp('^(?:.*\\.)?'  + utils.escapeRegexp(y_host)  + '\\..{2,9}$'),
y_param_regex=new RegExp('.*'           + utils.escapeRegexp(y_param) + '=.*'),
g_host_regex=new RegExp('^(?:www\\.)?' + utils.escapeRegexp(g_host)  + '\\..{2,9}$');
if(!!uri.parse(referer).query &&
!!uri.parse(referer).host.match(y_host_regex) &&
!!uri.parse(referer).query.match(y_param_regex)
){
__sbjs_source=y_host;
return true;
}else if(!!uri.parse(referer).host.match(g_host_regex)){
__sbjs_source=g_host;
return true;
}else if(!!uri.parse(referer).query){
for (var i=0; i < p.organics.length; i++){
if(uri.parse(referer).host.match(new RegExp('^(?:.*\\.)?' + utils.escapeRegexp(p.organics[i].host)  + '$', 'i')) &&
uri.parse(referer).query.match(new RegExp('.*'         + utils.escapeRegexp(p.organics[i].param) + '=.*', 'i'))
){
__sbjs_source=p.organics[i].display||p.organics[i].host;
return true;
}
if(i + 1===p.organics.length){
return false;
}}
}else{
return false;
}}
function isReferral(referer){
if(p.referrals.length > 0){
for (var i=0; i < p.referrals.length; i++){
if(uri.parse(referer).host.match(new RegExp('^(?:.*\\.)?' + utils.escapeRegexp(p.referrals[i].host) + '$', 'i'))){
__sbjs_source=p.referrals[i].display||p.referrals[i].host;
__sbjs_medium=p.referrals[i].medium||terms.referer.referral;
return true;
}
if(i + 1===p.referrals.length){
__sbjs_source=uri.getHost(referer);
return true;
}}
}else{
__sbjs_source=uri.getHost(referer);
return true;
}}
function setFirstAndCurrentExtraData(){
cookies.set(data.containers.current_extra, data.pack.extra(p.timezone_offset), lifetime, domain, isolate);
if(!cookies.get(data.containers.first_extra)){
cookies.set(data.containers.first_extra, data.pack.extra(p.timezone_offset), lifetime, domain, isolate);
}}
(function setData(){
cookies.set(data.containers.current, mainData(), lifetime, domain, isolate);
if(!cookies.get(data.containers.first)){
cookies.set(data.containers.first, cookies.get(data.containers.current), lifetime, domain, isolate);
}
var visits, udata;
if(!cookies.get(data.containers.udata)){
visits=1;
udata=data.pack.user(visits, p.user_ip);
}else{
visits=parseInt(cookies.parse(data.containers.udata)[cookies.unsbjs(data.containers.udata)][data.aliases.udata.visits])||1;
visits=cookies.get(data.containers.session) ? visits:visits + 1;
udata=data.pack.user(visits, p.user_ip);
}
cookies.set(data.containers.udata, udata, lifetime, domain, isolate);
var pages_count;
if(!cookies.get(data.containers.session)){
pages_count=1;
}else{
pages_count=parseInt(cookies.parse(data.containers.session)[cookies.unsbjs(data.containers.session)][data.aliases.session.pages_seen])||1;
pages_count +=1;
}
cookies.set(data.containers.session, data.pack.session(pages_count), p.session_length, domain, isolate);
if(p.promocode&&!cookies.get(data.containers.promocode)){
cookies.set(data.containers.promocode, data.pack.promo(p.promocode), lifetime, domain, isolate);
}})();
return cookies.parse(data.containers);
};},{"./data":2,"./helpers/cookies":3,"./helpers/uri":4,"./helpers/utils":5,"./migrations":7,"./params":8,"./terms":9}],7:[function(_dereq_,module,exports){
"use strict";
var data=_dereq_('./data'),
cookies=_dereq_('./helpers/cookies');
module.exports={
go: function(lifetime, domain, isolate){
var migrate=this.migrations,
_with={ l: lifetime, d: domain, i: isolate };
var i;
if(!cookies.get(data.containers.first)&&!cookies.get(data.service.migrations)){
var mids=[];
for (i=0; i < migrate.length; i++){ mids.push(migrate[i].id); }
var advance='';
for (i=0; i < mids.length; i++){
advance +=mids[i] + '=1';
if(i < mids.length - 1){ advance +=data.delimiter; }}
cookies.set(data.service.migrations, advance, _with.l, _with.d, _with.i);
}else if(!cookies.get(data.service.migrations)){
for (i=0; i < migrate.length; i++){
migrate[i].go(migrate[i].id, _with);
}}
},
migrations: [
{
id: '1418474375998',
version: '1.0.0-beta',
go: function(mid, _with){
var success=mid + '=1',
fail=mid + '=0';
var safeReplace=function($0, $1, $2){
return ($1||$2 ? $0:data.delimiter);
};
try {
var _in=[];
for (var prop in data.containers){
if(data.containers.hasOwnProperty(prop)){
_in.push(data.containers[prop]);
}}
for (var i=0; i < _in.length; i++){
if(cookies.get(_in[i])){
var buffer=cookies.get(_in[i]).replace(/(\|)?\|(\|)?/g, safeReplace);
cookies.destroy(_in[i], _with.d, _with.i);
cookies.destroy(_in[i], _with.d, !_with.i);
cookies.set(_in[i], buffer, _with.l, _with.d, _with.i);
}}
if(cookies.get(data.containers.session)){
cookies.set(data.containers.session, data.pack.session(0), _with.l, _with.d, _with.i);
}
cookies.set(data.service.migrations, success, _with.l, _with.d, _with.i);
} catch (err){
cookies.set(data.service.migrations, fail, _with.l, _with.d, _with.i);
}}
}
]
};},{"./data":2,"./helpers/cookies":3}],8:[function(_dereq_,module,exports){
"use strict";
var terms=_dereq_('./terms'),
uri=_dereq_('./helpers/uri');
module.exports={
fetch: function(prefs){
var user=prefs||{},
params={};
params.lifetime=this.validate.checkFloat(user.lifetime)||6;
params.lifetime=parseInt(params.lifetime * 30 * 24 * 60);
params.session_length=this.validate.checkInt(user.session_length)||30;
params.timezone_offset=this.validate.checkInt(user.timezone_offset);
params.base64=user.base64||false;
params.campaign_param=user.campaign_param||false;
params.term_param=user.term_param||false;
params.content_param=user.content_param||false;
params.user_ip=user.user_ip||terms.none;
if(user.promocode){
params.promocode={};
params.promocode.min=parseInt(user.promocode.min)||100000;
params.promocode.max=parseInt(user.promocode.max)||999999;
}else{
params.promocode=false;
}
if(user.typein_attributes&&user.typein_attributes.source&&user.typein_attributes.medium){
params.typein_attributes={};
params.typein_attributes.source=user.typein_attributes.source;
params.typein_attributes.medium=user.typein_attributes.medium;
}else{
params.typein_attributes={ source: '(direct)', medium: '(none)' };}
if(user.domain&&this.validate.isString(user.domain)){
params.domain={ host: user.domain, isolate: false };}else if(user.domain&&user.domain.host){
params.domain=user.domain;
}else{
params.domain={ host: uri.getHost(document.location.hostname), isolate: false };}
params.referrals=[];
if(user.referrals&&user.referrals.length > 0){
for (var ir=0; ir < user.referrals.length; ir++){
if(user.referrals[ir].host){
params.referrals.push(user.referrals[ir]);
}}
}
params.organics=[];
if(user.organics&&user.organics.length > 0){
for (var io=0; io < user.organics.length; io++){
if(user.organics[io].host&&user.organics[io].param){
params.organics.push(user.organics[io]);
}}
}
params.organics.push({ host: 'bing.com',      param: 'q',     display: 'bing'            });
params.organics.push({ host: 'yahoo.com',     param: 'p',     display: 'yahoo'           });
params.organics.push({ host: 'about.com',     param: 'q',     display: 'about'           });
params.organics.push({ host: 'aol.com',       param: 'q',     display: 'aol'             });
params.organics.push({ host: 'ask.com',       param: 'q',     display: 'ask'             });
params.organics.push({ host: 'globososo.com', param: 'q',     display: 'globo'           });
params.organics.push({ host: 'go.mail.ru',    param: 'q',     display: 'go.mail.ru'      });
params.organics.push({ host: 'rambler.ru',    param: 'query', display: 'rambler'         });
params.organics.push({ host: 'tut.by',        param: 'query', display: 'tut.by'          });
params.referrals.push({ host: 't.co',                         display: 'twitter.com'     });
params.referrals.push({ host: 'plus.url.google.com',          display: 'plus.google.com' });
return params;
},
validate: {
checkFloat: function(v){
return v&&this.isNumeric(parseFloat(v)) ? parseFloat(v):false;
},
checkInt: function(v){
return v&&this.isNumeric(parseInt(v)) ? parseInt(v):false;
},
isNumeric: function(v){
return !isNaN(v);
},
isString: function(v){
return Object.prototype.toString.call(v)==='[object String]';
}}
};},{"./helpers/uri":4,"./terms":9}],9:[function(_dereq_,module,exports){
"use strict";
module.exports={
traffic: {
utm:        'utm',
organic:    'organic',
referral:   'referral',
typein:     'typein'
},
referer: {
referral:   'referral',
organic:    'organic',
social:     'social'
},
none:         '(none)',
oops:         '(Houston, we have a problem)'
};},{}]},{},[1])(1)
});
(function(wc_order_attribution){
'use strict';
const params=wc_order_attribution.params;
const $=document.querySelector.bind(document);
const propertyAccessor=(obj, path)=> path.split('.').reduce(( acc, part)=> acc&&acc[ part ], obj);
const returnNull=()=> null;
const stringifyFalsyInputValue=(value)=> value===null||value===undefined ? '':value;
const CHECKOUT_STORE_KEY='wc/store/checkout';
wc_order_attribution.getAttributionData=function(){
const accessor=params.allowTracking&&isSbjsAvailable() ? propertyAccessor:returnNull;
const getter=isSbjsAvailable() ? sbjs.get:{};
const entries=Object.entries(wc_order_attribution.fields)
.map(( [ key, property ])=> [ key, accessor(getter, property) ]);
return Object.fromEntries(entries);
}
function removeDuplicateInputGroups(){
document.querySelectorAll('wc-order-attribution-inputs').forEach(( group, index)=> {
if(index > 0){
group.remove();
}});
}
function updateFormValues(values){
removeDuplicateInputGroups();
for(const element of document.querySelectorAll('wc-order-attribution-inputs') ){
element.values=values;
}};
function updateCheckoutBlockData(values){
if(window.wp &&
window.wp.data &&
window.wp.data.dispatch &&
window.wc &&
window.wc.wcBlocksData
){
window.wp.data
.dispatch(window.wc.wcBlocksData.CHECKOUT_STORE_KEY)
.setExtensionData('woocommerce/order-attribution',
values,
true
);
}}
function isSbjsAvailable(){
return typeof sbjs!=='undefined';
}
wc_order_attribution.setOrderTracking=function(allow){
params.allowTracking=allow;
if(! allow){
removeTrackingCookies();
}else if(! isSbjsAvailable()){
return;
}else{
sbjs.init({
lifetime: Number(params.lifetime),
session_length: Number(params.session),
base64: Boolean(params.base64),
timezone_offset: '0',
});
}
const values=wc_order_attribution.getAttributionData();
updateFormValues(values);
updateCheckoutBlockData(values);
}
function removeTrackingCookies(){
const domain=window.location.hostname;
const sbCookies=[
'sbjs_current',
'sbjs_current_add',
'sbjs_first',
'sbjs_first_add',
'sbjs_session',
'sbjs_udata',
'sbjs_migrations',
'sbjs_promo'
];
sbCookies.forEach(( name)=> {
document.cookie=`${name}=; path=/; max-age=-999; domain=.${domain};`;
});
}
wc_order_attribution.setOrderTracking(params.allowTracking);
function eventuallyInitializeCheckoutBlock(){
if(window.wp&&window.wp.data&&typeof window.wp.data.subscribe==='function'
){
const unsubscribe=window.wp.data.subscribe(function (){
unsubscribe();
updateCheckoutBlockData(wc_order_attribution.getAttributionData());
}, CHECKOUT_STORE_KEY);
}};
if(document.readyState==="loading"){
document.addEventListener("DOMContentLoaded", eventuallyInitializeCheckoutBlock);
}else{
eventuallyInitializeCheckoutBlock();
}
window.customElements.define('wc-order-attribution-inputs', class extends HTMLElement {
constructor(){
super();
this._fieldNames=Object.keys(wc_order_attribution.fields);
if(this.hasOwnProperty('_values') ){
let values=this.values;
delete this.values;
this.values=values||{};}}
connectedCallback(){
this.innerHTML='';
const inputs=new DocumentFragment();
for(const fieldName of this._fieldNames){
const input=document.createElement('input');
input.type='hidden';
input.name=`${params.prefix}${fieldName}`;
input.value=stringifyFalsyInputValue(( this.values&&this.values[ fieldName ])||'');
inputs.appendChild(input);
}
this.appendChild(inputs);
}
set values(values){
this._values=values;
if(this.isConnected){
for(const fieldName of this._fieldNames){
const input=this.querySelector(`input[name="${params.prefix}${fieldName}"]`);
if(input){
input.value=stringifyFalsyInputValue(this.values[ fieldName ]);
}else{
console.warn(`Field "${fieldName}" not found. ` +
`Most likely, the '<wc-order-attribution-inputs>' element was manipulated.`
);
}}
}}
get values(){
return this._values;
}});
}(window.wc_order_attribution) );