{"version":3,"file":"/app.js","mappings":"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","sources":["webpack://Wikpis/webpack/runtime/chunk loaded","webpack://Wikpis/./node_modules/sidebarjs/lib/esm/sidebarjs.js","webpack://Wikpis/./src/scripts/components/menuResponsive.js","webpack://Wikpis/./node_modules/@glidejs/glide/dist/glide.esm.js","webpack://Wikpis/./src/scripts/components/slider.js","webpack://Wikpis/./src/scripts/app.js","webpack://Wikpis/./src/scripts/components/carrusel.js","webpack://Wikpis/webpack/bootstrap","webpack://Wikpis/webpack/runtime/hasOwnProperty shorthand","webpack://Wikpis/webpack/runtime/jsonp chunk loading","webpack://Wikpis/webpack/startup"],"sourcesContent":["var deferred = [];\n__webpack_require__.O = function(result, chunkIds, fn, priority) {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","/*\n * SidebarJS\n * Version 10.0.0\n * https://github.com/SidebarJS/sidebarjs#readme\n */\n\nconst SIDEBARJS = 'sidebarjs';\nconst SIDEBARJS_FALLBACK_NAME = '';\nconst SIDEBARJS_CONTENT = 'sidebarjs-content';\nconst SIDEBARJS_TRANSITION_START = 'sidebarjs--transition-start';\nconst SIDEBARJS_TRANSITION_END = 'sidebarjs--transition-end';\nconst IS_VISIBLE = `${SIDEBARJS}--is-visible`;\nconst IS_MOVING = `${SIDEBARJS}--is-moving`;\nconst POSITIONS = [\"left\" /* SidebarPosition.Left */, \"right\" /* SidebarPosition.Right */];\nconst EVENT_LISTENER_OPTIONS = { passive: true };\nconst TOUCH_START = 'touchstart';\nconst TOUCH_MOVE = 'touchmove';\nconst TOUCH_END = 'touchend';\nconst ELEMENT_ACTIONS = ['toggle', 'open', 'close'];\nconst DEFAULT_CONFIG = {\n documentMinSwipeX: 10,\n documentSwipeRange: 40,\n responsive: false,\n position: \"left\" /* SidebarPosition.Left */,\n backdropOpacity: 0.3,\n};\nfunction isStyleMapSupported() {\n return Boolean(window.CSS && window.CSS.number);\n}\nfunction create(element) {\n const el = document.createElement('div');\n el.setAttribute(element, '');\n return el;\n}\nfunction elemHasListener(elem, value) {\n return elem && typeof value === 'boolean' ? (elem.sidebarjsListener = value) : !!elem.sidebarjsListener;\n}\nfunction shouldDefineMainContent(mainContent) {\n if (mainContent) {\n mainContent.setAttribute(SIDEBARJS_CONTENT, '');\n return mainContent;\n }\n else {\n return document.querySelector(`[${SIDEBARJS_CONTENT}]`);\n }\n}\nfunction forEachActionElement(sidebarName, func) {\n for (let i = 0; i < ELEMENT_ACTIONS.length; i++) {\n const action = ELEMENT_ACTIONS[i];\n const elements = document.querySelectorAll(`[${SIDEBARJS}-${action}=\"${sidebarName}\"]`);\n for (let j = 0; j < elements.length; j++) {\n func(elements[j], action);\n }\n }\n}\nfunction targetElementIsBackdrop(e) {\n return e.target.hasAttribute(`${SIDEBARJS}-backdrop`);\n}\nfunction shouldInvokeFunction(fn) {\n if (fn) {\n fn();\n }\n}\n\nclass SidebarElement {\n constructor(options = {}) {\n this.toggle = () => {\n this.isVisible() ? this.close() : this.open();\n };\n this.open = () => {\n this.addComponentClass(IS_VISIBLE);\n this.setBackdropOpacity(this.backdropOpacity);\n };\n this.close = () => {\n this.removeComponentClass(IS_VISIBLE);\n this.clearStyle(this.backdrop);\n };\n this._onTouchStart = (e) => {\n this.initialTouch = e.touches[0].pageX;\n };\n this._onTouchMove = (e) => {\n const swipeDirection = -(this.initialTouch - e.touches[0].clientX);\n const sidebarMovement = this.container.clientWidth + (this.hasLeftPosition() ? swipeDirection : -swipeDirection);\n if (sidebarMovement <= this.container.clientWidth) {\n this.touchMoveSidebar = Math.abs(swipeDirection);\n this.moveSidebar(swipeDirection);\n }\n };\n this._onTouchEnd = () => {\n this.removeComponentClass(IS_MOVING);\n this.clearStyle(this.container);\n this.clearStyle(this.backdrop);\n this.touchMoveSidebar > this.container.clientWidth / 3.5 ? this.close() : this.open();\n this.initialTouch = null;\n this.touchMoveSidebar = null;\n };\n this._onSwipeOpenStart = (e) => {\n if (targetElementIsBackdrop(e)) {\n return;\n }\n const touchPositionX = e.touches[0].clientX;\n const documentTouch = this.hasLeftPosition() ? touchPositionX : document.body.clientWidth - touchPositionX;\n if (documentTouch < this.documentSwipeRange) {\n this._onTouchStart(e);\n }\n };\n this._onSwipeOpenMove = (e) => {\n if (!targetElementIsBackdrop(e) && this.initialTouch && !this.isVisible()) {\n const documentSwiped = e.touches[0].clientX - this.initialTouch;\n const hasLeftPosition = this.hasLeftPosition();\n const swipeX = hasLeftPosition ? documentSwiped : -documentSwiped;\n const sidebarMovement = this.container.clientWidth - swipeX;\n if (sidebarMovement > 0 && swipeX >= this.documentMinSwipeX) {\n this.openMovement = hasLeftPosition ? -sidebarMovement : sidebarMovement;\n this.moveSidebar(this.openMovement);\n }\n }\n };\n this._onSwipeOpenEnd = () => {\n if (this.openMovement) {\n this.openMovement = null;\n this._onTouchEnd();\n }\n };\n this._onTransitionStart = () => {\n const { open, close } = this.getTransitionType();\n if (open || close) {\n this.toggleTransitionClass(true);\n }\n };\n this._onTransitionEnd = () => {\n const { open, close, isVisible } = this.getTransitionType();\n if (open || close) {\n this.toggleTransitionClass(false);\n }\n if (open) {\n this._wasVisible = true;\n shouldInvokeFunction(this._emitOnOpen);\n }\n else if (close) {\n this._wasVisible = false;\n shouldInvokeFunction(this._emitOnClose);\n }\n if (this._emitOnChangeVisibility) {\n this._emitOnChangeVisibility({ isVisible });\n }\n };\n this.nativeGestures = new Map([\n [TOUCH_START, this._onTouchStart],\n [TOUCH_MOVE, this._onTouchMove],\n [TOUCH_END, this._onTouchEnd],\n ]);\n this.nativeOpenGestures = new Map([\n [TOUCH_START, this._onSwipeOpenStart],\n [TOUCH_MOVE, this._onSwipeOpenMove],\n [TOUCH_END, this._onSwipeOpenEnd],\n ]);\n const config = Object.assign(Object.assign({}, DEFAULT_CONFIG), options);\n const hasCustomTransclude = config.container && config.backdrop;\n this.component = config.component || document.querySelector(`[${SIDEBARJS}]`);\n this.container = hasCustomTransclude ? config.container : create(`${SIDEBARJS}-container`);\n this.backdrop = hasCustomTransclude ? config.backdrop : create(`${SIDEBARJS}-backdrop`);\n this.documentMinSwipeX = config.documentMinSwipeX;\n this.documentSwipeRange = config.documentSwipeRange;\n this.nativeSwipe = config.nativeSwipe !== false;\n this.nativeSwipeOpen = config.nativeSwipeOpen !== false;\n this.isStyleMapSupported = isStyleMapSupported();\n this.responsive = Boolean(config.responsive);\n this.mainContent = shouldDefineMainContent(config.mainContent);\n this.backdropOpacity = config.backdropOpacity;\n this.backdropOpacityRatio = 1 / config.backdropOpacity;\n this._emitOnOpen = config.onOpen;\n this._emitOnClose = config.onClose;\n this._emitOnChangeVisibility = config.onChangeVisibility;\n if (!hasCustomTransclude) {\n try {\n this.transcludeContent();\n }\n catch (e) {\n throw new Error('You must define an element with [sidebarjs] attribute');\n }\n }\n this.setSwipeGestures(true);\n if (this.responsive || this.mainContent) {\n this.setResponsive();\n }\n this.setPosition(config.position);\n this.addAttrsEventsListeners(this.component.getAttribute(SIDEBARJS));\n this.addTransitionListener();\n this.backdrop.addEventListener('click', this.close, EVENT_LISTENER_OPTIONS);\n }\n isVisible() {\n return this.component.classList.contains(IS_VISIBLE);\n }\n destroy() {\n this.removeNativeGestures();\n this.container.removeEventListener('transitionstart', this._onTransitionStart);\n this.container.removeEventListener('transitionend', this._onTransitionEnd);\n this.backdrop.removeEventListener('click', this.close);\n this.removeNativeOpenGestures();\n this.removeAttrsEventsListeners(this.component.getAttribute(SIDEBARJS));\n this.removeComponentClassPosition();\n while (this.container.firstElementChild) {\n this.component.appendChild(this.container.firstElementChild);\n }\n this.component.removeChild(this.container);\n this.component.removeChild(this.backdrop);\n Object.keys(this).forEach((key) => (this[key] = null));\n }\n setPosition(position) {\n this.addComponentClass(IS_MOVING);\n this.position = POSITIONS.indexOf(position) >= 0 ? position : \"left\" /* SidebarPosition.Left */;\n const resetMainContent = (document.querySelectorAll(`[${SIDEBARJS}]`) || []).length === 1;\n this.removeComponentClassPosition(resetMainContent);\n this.addComponentClass(`${SIDEBARJS}--${this.position}`);\n if (this.responsive && this.mainContent) {\n this.mainContent.classList.add(`${SIDEBARJS_CONTENT}--${this.position}`);\n }\n setTimeout(() => this.component && this.removeComponentClass(IS_MOVING), 200);\n }\n addAttrsEventsListeners(sidebarName) {\n forEachActionElement(sidebarName, (element, action) => {\n if (!elemHasListener(element)) {\n element.addEventListener('click', this[action], EVENT_LISTENER_OPTIONS);\n elemHasListener(element, true);\n }\n });\n }\n removeAttrsEventsListeners(sidebarName) {\n forEachActionElement(sidebarName, (element, action) => {\n if (elemHasListener(element)) {\n element.removeEventListener('click', this[action]);\n elemHasListener(element, false);\n }\n });\n }\n setSwipeGestures(value) {\n if (typeof value !== 'boolean') {\n throw new Error(`You provided a ${typeof value} value but setSwipeGestures needs a boolean value.`);\n }\n if (this.nativeSwipe) {\n value ? this.addNativeGestures() : this.removeNativeGestures();\n if (this.nativeSwipeOpen) {\n value ? this.addNativeOpenGestures() : this.removeNativeOpenGestures();\n }\n }\n }\n getTransitionType() {\n const isVisible = this.isVisible();\n const open = isVisible && !this._wasVisible;\n const close = !isVisible && this._wasVisible;\n return { open, close, isVisible };\n }\n toggleTransitionClass(isStart) {\n this.toggleComponentClass(SIDEBARJS_TRANSITION_END, !isStart);\n this.toggleComponentClass(SIDEBARJS_TRANSITION_START, isStart);\n }\n addTransitionListener() {\n this._wasVisible = this.isVisible();\n this.container.addEventListener('transitionstart', this._onTransitionStart, EVENT_LISTENER_OPTIONS);\n this.container.addEventListener('transitionend', this._onTransitionEnd, EVENT_LISTENER_OPTIONS);\n }\n removeComponentClassPosition(resetMainContent) {\n for (let i = 0; i < POSITIONS.length; i++) {\n this.removeComponentClass(`${SIDEBARJS}--${POSITIONS[i]}`);\n if (resetMainContent && this.mainContent) {\n this.mainContent.classList.remove(`${SIDEBARJS_CONTENT}--${POSITIONS[i]}`);\n }\n }\n }\n hasLeftPosition() {\n return this.position === \"left\" /* SidebarPosition.Left */;\n }\n hasRightPosition() {\n return this.position === \"right\" /* SidebarPosition.Right */;\n }\n transcludeContent() {\n while (this.component.firstChild) {\n this.container.appendChild(this.component.firstChild);\n }\n while (this.component.firstChild) {\n this.component.removeChild(this.component.firstChild);\n }\n this.component.appendChild(this.container);\n this.component.appendChild(this.backdrop);\n }\n addNativeGestures() {\n this.nativeGestures.forEach((action, event) => {\n this.component.addEventListener(event, action, EVENT_LISTENER_OPTIONS);\n });\n }\n removeNativeGestures() {\n this.nativeGestures.forEach((action, event) => {\n this.component.removeEventListener(event, action);\n });\n }\n addNativeOpenGestures() {\n this.nativeOpenGestures.forEach((action, event) => {\n document.addEventListener(event, action, EVENT_LISTENER_OPTIONS);\n });\n }\n removeNativeOpenGestures() {\n this.nativeOpenGestures.forEach((action, event) => {\n document.removeEventListener(event, action);\n });\n }\n moveSidebar(movement) {\n this.addComponentClass(IS_MOVING);\n this.applyStyle(this.container, 'transform', `translate(${movement}px, 0)`, true);\n this.updateBackdropOpacity(movement);\n }\n updateBackdropOpacity(movement) {\n const swipeProgress = 1 - Math.abs(movement) / this.container.clientWidth;\n const opacity = swipeProgress / this.backdropOpacityRatio;\n this.setBackdropOpacity(opacity);\n }\n setBackdropOpacity(opacity) {\n this.applyStyle(this.backdrop, 'opacity', opacity.toString());\n }\n setResponsive() {\n if (!this.responsive && this.mainContent) {\n throw new Error(`You provide a [${SIDEBARJS_CONTENT}] element without set {responsive: true}`);\n }\n if (this.responsive && !this.mainContent) {\n throw new Error(`You have set {responsive: true} without provide a [${SIDEBARJS_CONTENT}] element`);\n }\n this.addComponentClass('sidebarjs--responsive');\n }\n applyStyle(el, prop, val, vendorify) {\n if (this.isStyleMapSupported) {\n el.attributeStyleMap.set(prop, val);\n }\n else {\n el.style[prop] = val;\n if (vendorify) {\n const vendor = ('webkit' + prop.charAt(0).toUpperCase() + prop.slice(1));\n el.style[vendor] = val;\n }\n }\n }\n clearStyle(el) {\n if (this.isStyleMapSupported) {\n el.attributeStyleMap.clear();\n }\n else {\n el.removeAttribute('style');\n }\n }\n addComponentClass(className) {\n this.component.classList.add(className);\n }\n removeComponentClass(className) {\n this.component.classList.remove(className);\n }\n toggleComponentClass(className, force) {\n this.component.classList.toggle(className, force);\n }\n}\n\nclass SidebarService {\n constructor() {\n this.instances = {};\n }\n fallbackName(sidebarName) {\n return sidebarName || SIDEBARJS_FALLBACK_NAME;\n }\n getInstance(sidebarName) {\n return this.instances[this.fallbackName(sidebarName)];\n }\n create(options) {\n var _a;\n const name = this.fallbackName((_a = options === null || options === void 0 ? void 0 : options.component) === null || _a === void 0 ? void 0 : _a.getAttribute(SIDEBARJS));\n this.instances[name] = new SidebarElement(options);\n return this.instances[name];\n }\n open(sidebarName) {\n var _a;\n (_a = this.getInstance(sidebarName)) === null || _a === void 0 ? void 0 : _a.open();\n }\n close(sidebarName) {\n var _a;\n (_a = this.getInstance(sidebarName)) === null || _a === void 0 ? void 0 : _a.close();\n }\n toggle(sidebarName) {\n var _a;\n (_a = this.getInstance(sidebarName)) === null || _a === void 0 ? void 0 : _a.toggle();\n }\n isVisible(sidebarName) {\n var _a;\n return !!((_a = this.getInstance(sidebarName)) === null || _a === void 0 ? void 0 : _a.isVisible());\n }\n setPosition(position, sidebarName) {\n var _a;\n (_a = this.getInstance(sidebarName)) === null || _a === void 0 ? void 0 : _a.setPosition(position);\n }\n elemHasListener(elem, value) {\n return elemHasListener(elem, value);\n }\n destroy(sidebarName) {\n const name = this.fallbackName(sidebarName);\n if (this.instances[name]) {\n this.instances[name].destroy();\n this.instances[name] = null;\n delete this.instances[name];\n }\n }\n}\n\nexport { SidebarElement, SidebarService };\n","import { SidebarElement } from 'sidebarjs';\r\n\r\n(function ($) {\r\n\t$(document).ready(function () {\r\n\t\tconst menuResponsive = new SidebarElement({\r\n\t\t\tposition: 'left'\r\n\t\t});\r\n\t\tconst menuResponsiveMarkup = $('.nav-responsive');\r\n\t\tconst menuResponsiveButton = $('.nav-responsive__button');\r\n\t\tconst menuResponsiveItemsWithChildren = $('.nav-responsive .menu-item-has-children');\r\n\r\n\t\tconst menuResponsiveButtonSubmenuMarkup = `\r\n\t\t\t\r\n\t\t`;\r\n\r\n\t\tmenuResponsiveMarkup.css('display', 'unset');\r\n\r\n\t\tmenuResponsiveButton.click(function () {\r\n\t\t\tmenuResponsive.toggle();\r\n\t\t});\r\n\r\n\t\tmenuResponsiveItemsWithChildren.append(menuResponsiveButtonSubmenuMarkup);\r\n\r\n\t\tconst menuResponsiveButtonSubmenu = $('.nav-responsive .sub-menu__button');\r\n\r\n\t\tmenuResponsiveButtonSubmenu.click(function () {\r\n\t\t\tif ($(this).hasClass('open')) {\r\n\t\t\t\t$(this).siblings('.sub-menu').addClass('opened');\r\n\t\t\t}\r\n\r\n\t\t\tif ($(this).hasClass('close')) {\r\n\t\t\t\t$(this).siblings('.sub-menu').removeClass('opened');\r\n\t\t\t}\r\n\r\n\t\t\t$(this).toggleClass('open');\r\n\t\t\t$(this).toggleClass('close');\r\n\t\t});\r\n\t});\r\n})(jQuery);\r\n","/*!\n * Glide.js v3.6.0\n * (c) 2013-2022 Jędrzej Chałubek (https://github.com/jedrzejchalubek/)\n * Released under the MIT License.\n */\n\nfunction _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\n\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (typeof call === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return _assertThisInitialized(self);\n}\n\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return _possibleConstructorReturn(this, result);\n };\n}\n\nfunction _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = _getPrototypeOf(object);\n if (object === null) break;\n }\n\n return object;\n}\n\nfunction _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n _get = Reflect.get;\n } else {\n _get = function _get(target, property, receiver) {\n var base = _superPropBase(target, property);\n\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n\n return desc.value;\n };\n }\n\n return _get.apply(this, arguments);\n}\n\nvar defaults = {\n /**\n * Type of the movement.\n *\n * Available types:\n * `slider` - Rewinds slider to the start/end when it reaches the first or last slide.\n * `carousel` - Changes slides without starting over when it reaches the first or last slide.\n *\n * @type {String}\n */\n type: 'slider',\n\n /**\n * Start at specific slide number defined with zero-based index.\n *\n * @type {Number}\n */\n startAt: 0,\n\n /**\n * A number of slides visible on the single viewport.\n *\n * @type {Number}\n */\n perView: 1,\n\n /**\n * Focus currently active slide at a specified position in the track.\n *\n * Available inputs:\n * `center` - Current slide will be always focused at the center of a track.\n * `0,1,2,3...` - Current slide will be focused on the specified zero-based index.\n *\n * @type {String|Number}\n */\n focusAt: 0,\n\n /**\n * A size of the gap added between slides.\n *\n * @type {Number}\n */\n gap: 10,\n\n /**\n * Change slides after a specified interval. Use `false` for turning off autoplay.\n *\n * @type {Number|Boolean}\n */\n autoplay: false,\n\n /**\n * Stop autoplay on mouseover event.\n *\n * @type {Boolean}\n */\n hoverpause: true,\n\n /**\n * Allow for changing slides with left and right keyboard arrows.\n *\n * @type {Boolean}\n */\n keyboard: true,\n\n /**\n * Stop running `perView` number of slides from the end. Use this\n * option if you don't want to have an empty space after\n * a slider. Works only with `slider` type and a\n * non-centered `focusAt` setting.\n *\n * @type {Boolean}\n */\n bound: false,\n\n /**\n * Minimal swipe distance needed to change the slide. Use `false` for turning off a swiping.\n *\n * @type {Number|Boolean}\n */\n swipeThreshold: 80,\n\n /**\n * Minimal mouse drag distance needed to change the slide. Use `false` for turning off a dragging.\n *\n * @type {Number|Boolean}\n */\n dragThreshold: 120,\n\n /**\n * A number of slides moved on single swipe.\n *\n * Available types:\n * `` - Moves slider by one slide per swipe\n * `|` - Moves slider between views per swipe (number of slides defined in `perView` options)\n *\n * @type {String}\n */\n perSwipe: '',\n\n /**\n * Moving distance ratio of the slides on a swiping and dragging.\n *\n * @type {Number}\n */\n touchRatio: 0.5,\n\n /**\n * Angle required to activate slides moving on swiping or dragging.\n *\n * @type {Number}\n */\n touchAngle: 45,\n\n /**\n * Duration of the animation in milliseconds.\n *\n * @type {Number}\n */\n animationDuration: 400,\n\n /**\n * Allows looping the `slider` type. Slider will rewind to the first/last slide when it's at the start/end.\n *\n * @type {Boolean}\n */\n rewind: true,\n\n /**\n * Duration of the rewinding animation of the `slider` type in milliseconds.\n *\n * @type {Number}\n */\n rewindDuration: 800,\n\n /**\n * Easing function for the animation.\n *\n * @type {String}\n */\n animationTimingFunc: 'cubic-bezier(.165, .840, .440, 1)',\n\n /**\n * Wait for the animation to finish until the next user input can be processed\n *\n * @type {boolean}\n */\n waitForTransition: true,\n\n /**\n * Throttle costly events at most once per every wait milliseconds.\n *\n * @type {Number}\n */\n throttle: 10,\n\n /**\n * Moving direction mode.\n *\n * Available inputs:\n * - 'ltr' - left to right movement,\n * - 'rtl' - right to left movement.\n *\n * @type {String}\n */\n direction: 'ltr',\n\n /**\n * The distance value of the next and previous viewports which\n * have to peek in the current view. Accepts number and\n * pixels as a string. Left and right peeking can be\n * set up separately with a directions object.\n *\n * For example:\n * `100` - Peek 100px on the both sides.\n * { before: 100, after: 50 }` - Peek 100px on the left side and 50px on the right side.\n *\n * @type {Number|String|Object}\n */\n peek: 0,\n\n /**\n * Defines how many clones of current viewport will be generated.\n *\n * @type {Number}\n */\n cloningRatio: 1,\n\n /**\n * Collection of options applied at specified media breakpoints.\n * For example: display two slides per view under 800px.\n * `{\n * '800px': {\n * perView: 2\n * }\n * }`\n */\n breakpoints: {},\n\n /**\n * Collection of internally used HTML classes.\n *\n * @todo Refactor `slider` and `carousel` properties to single `type: { slider: '', carousel: '' }` object\n * @type {Object}\n */\n classes: {\n swipeable: 'glide--swipeable',\n dragging: 'glide--dragging',\n direction: {\n ltr: 'glide--ltr',\n rtl: 'glide--rtl'\n },\n type: {\n slider: 'glide--slider',\n carousel: 'glide--carousel'\n },\n slide: {\n clone: 'glide__slide--clone',\n active: 'glide__slide--active'\n },\n arrow: {\n disabled: 'glide__arrow--disabled'\n },\n nav: {\n active: 'glide__bullet--active'\n }\n }\n};\n\n/**\n * Outputs warning message to the bowser console.\n *\n * @param {String} msg\n * @return {Void}\n */\nfunction warn(msg) {\n console.error(\"[Glide warn]: \".concat(msg));\n}\n\n/**\n * Converts value entered as number\n * or string to integer value.\n *\n * @param {String} value\n * @returns {Number}\n */\nfunction toInt(value) {\n return parseInt(value);\n}\n/**\n * Converts value entered as number\n * or string to flat value.\n *\n * @param {String} value\n * @returns {Number}\n */\n\nfunction toFloat(value) {\n return parseFloat(value);\n}\n/**\n * Indicates whether the specified value is a string.\n *\n * @param {*} value\n * @return {Boolean}\n */\n\nfunction isString(value) {\n return typeof value === 'string';\n}\n/**\n * Indicates whether the specified value is an object.\n *\n * @param {*} value\n * @return {Boolean}\n *\n * @see https://github.com/jashkenas/underscore\n */\n\nfunction isObject(value) {\n var type = _typeof(value);\n\n return type === 'function' || type === 'object' && !!value; // eslint-disable-line no-mixed-operators\n}\n/**\n * Indicates whether the specified value is a function.\n *\n * @param {*} value\n * @return {Boolean}\n */\n\nfunction isFunction(value) {\n return typeof value === 'function';\n}\n/**\n * Indicates whether the specified value is undefined.\n *\n * @param {*} value\n * @return {Boolean}\n */\n\nfunction isUndefined(value) {\n return typeof value === 'undefined';\n}\n/**\n * Indicates whether the specified value is an array.\n *\n * @param {*} value\n * @return {Boolean}\n */\n\nfunction isArray(value) {\n return value.constructor === Array;\n}\n\n/**\n * Creates and initializes specified collection of extensions.\n * Each extension receives access to instance of glide and rest of components.\n *\n * @param {Object} glide\n * @param {Object} extensions\n *\n * @returns {Object}\n */\n\nfunction mount(glide, extensions, events) {\n var components = {};\n\n for (var name in extensions) {\n if (isFunction(extensions[name])) {\n components[name] = extensions[name](glide, components, events);\n } else {\n warn('Extension must be a function');\n }\n }\n\n for (var _name in components) {\n if (isFunction(components[_name].mount)) {\n components[_name].mount();\n }\n }\n\n return components;\n}\n\n/**\n * Defines getter and setter property on the specified object.\n *\n * @param {Object} obj Object where property has to be defined.\n * @param {String} prop Name of the defined property.\n * @param {Object} definition Get and set definitions for the property.\n * @return {Void}\n */\nfunction define(obj, prop, definition) {\n Object.defineProperty(obj, prop, definition);\n}\n/**\n * Sorts aphabetically object keys.\n *\n * @param {Object} obj\n * @return {Object}\n */\n\nfunction sortKeys(obj) {\n return Object.keys(obj).sort().reduce(function (r, k) {\n r[k] = obj[k];\n return r[k], r;\n }, {});\n}\n/**\n * Merges passed settings object with default options.\n *\n * @param {Object} defaults\n * @param {Object} settings\n * @return {Object}\n */\n\nfunction mergeOptions(defaults, settings) {\n var options = Object.assign({}, defaults, settings); // `Object.assign` do not deeply merge objects, so we\n // have to do it manually for every nested object\n // in options. Although it does not look smart,\n // it's smaller and faster than some fancy\n // merging deep-merge algorithm script.\n\n if (settings.hasOwnProperty('classes')) {\n options.classes = Object.assign({}, defaults.classes, settings.classes);\n\n if (settings.classes.hasOwnProperty('direction')) {\n options.classes.direction = Object.assign({}, defaults.classes.direction, settings.classes.direction);\n }\n\n if (settings.classes.hasOwnProperty('type')) {\n options.classes.type = Object.assign({}, defaults.classes.type, settings.classes.type);\n }\n\n if (settings.classes.hasOwnProperty('slide')) {\n options.classes.slide = Object.assign({}, defaults.classes.slide, settings.classes.slide);\n }\n\n if (settings.classes.hasOwnProperty('arrow')) {\n options.classes.arrow = Object.assign({}, defaults.classes.arrow, settings.classes.arrow);\n }\n\n if (settings.classes.hasOwnProperty('nav')) {\n options.classes.nav = Object.assign({}, defaults.classes.nav, settings.classes.nav);\n }\n }\n\n if (settings.hasOwnProperty('breakpoints')) {\n options.breakpoints = Object.assign({}, defaults.breakpoints, settings.breakpoints);\n }\n\n return options;\n}\n\nvar EventsBus = /*#__PURE__*/function () {\n /**\n * Construct a EventBus instance.\n *\n * @param {Object} events\n */\n function EventsBus() {\n var events = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n _classCallCheck(this, EventsBus);\n\n this.events = events;\n this.hop = events.hasOwnProperty;\n }\n /**\n * Adds listener to the specifed event.\n *\n * @param {String|Array} event\n * @param {Function} handler\n */\n\n\n _createClass(EventsBus, [{\n key: \"on\",\n value: function on(event, handler) {\n if (isArray(event)) {\n for (var i = 0; i < event.length; i++) {\n this.on(event[i], handler);\n }\n\n return;\n } // Create the event's object if not yet created\n\n\n if (!this.hop.call(this.events, event)) {\n this.events[event] = [];\n } // Add the handler to queue\n\n\n var index = this.events[event].push(handler) - 1; // Provide handle back for removal of event\n\n return {\n remove: function remove() {\n delete this.events[event][index];\n }\n };\n }\n /**\n * Runs registered handlers for specified event.\n *\n * @param {String|Array} event\n * @param {Object=} context\n */\n\n }, {\n key: \"emit\",\n value: function emit(event, context) {\n if (isArray(event)) {\n for (var i = 0; i < event.length; i++) {\n this.emit(event[i], context);\n }\n\n return;\n } // If the event doesn't exist, or there's no handlers in queue, just leave\n\n\n if (!this.hop.call(this.events, event)) {\n return;\n } // Cycle through events queue, fire!\n\n\n this.events[event].forEach(function (item) {\n item(context || {});\n });\n }\n }]);\n\n return EventsBus;\n}();\n\nvar Glide$1 = /*#__PURE__*/function () {\n /**\r\n * Construct glide.\r\n *\r\n * @param {String} selector\r\n * @param {Object} options\r\n */\n function Glide(selector) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, Glide);\n\n this._c = {};\n this._t = [];\n this._e = new EventsBus();\n this.disabled = false;\n this.selector = selector;\n this.settings = mergeOptions(defaults, options);\n this.index = this.settings.startAt;\n }\n /**\r\n * Initializes glide.\r\n *\r\n * @param {Object} extensions Collection of extensions to initialize.\r\n * @return {Glide}\r\n */\n\n\n _createClass(Glide, [{\n key: \"mount\",\n value: function mount$1() {\n var extensions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n this._e.emit('mount.before');\n\n if (isObject(extensions)) {\n this._c = mount(this, extensions, this._e);\n } else {\n warn('You need to provide a object on `mount()`');\n }\n\n this._e.emit('mount.after');\n\n return this;\n }\n /**\r\n * Collects an instance `translate` transformers.\r\n *\r\n * @param {Array} transformers Collection of transformers.\r\n * @return {Void}\r\n */\n\n }, {\n key: \"mutate\",\n value: function mutate() {\n var transformers = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n\n if (isArray(transformers)) {\n this._t = transformers;\n } else {\n warn('You need to provide a array on `mutate()`');\n }\n\n return this;\n }\n /**\r\n * Updates glide with specified settings.\r\n *\r\n * @param {Object} settings\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"update\",\n value: function update() {\n var settings = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n this.settings = mergeOptions(this.settings, settings);\n\n if (settings.hasOwnProperty('startAt')) {\n this.index = settings.startAt;\n }\n\n this._e.emit('update');\n\n return this;\n }\n /**\r\n * Change slide with specified pattern. A pattern must be in the special format:\r\n * `>` - Move one forward\r\n * `<` - Move one backward\r\n * `={i}` - Go to {i} zero-based slide (eq. '=1', will go to second slide)\r\n * `>>` - Rewinds to end (last slide)\r\n * `<<` - Rewinds to start (first slide)\r\n * `|>` - Move one viewport forward\r\n * `|<` - Move one viewport backward\r\n *\r\n * @param {String} pattern\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"go\",\n value: function go(pattern) {\n this._c.Run.make(pattern);\n\n return this;\n }\n /**\r\n * Move track by specified distance.\r\n *\r\n * @param {String} distance\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"move\",\n value: function move(distance) {\n this._c.Transition.disable();\n\n this._c.Move.make(distance);\n\n return this;\n }\n /**\r\n * Destroy instance and revert all changes done by this._c.\r\n *\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"destroy\",\n value: function destroy() {\n this._e.emit('destroy');\n\n return this;\n }\n /**\r\n * Start instance autoplaying.\r\n *\r\n * @param {Boolean|Number} interval Run autoplaying with passed interval regardless of `autoplay` settings\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"play\",\n value: function play() {\n var interval = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n if (interval) {\n this.settings.autoplay = interval;\n }\n\n this._e.emit('play');\n\n return this;\n }\n /**\r\n * Stop instance autoplaying.\r\n *\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"pause\",\n value: function pause() {\n this._e.emit('pause');\n\n return this;\n }\n /**\r\n * Sets glide into a idle status.\r\n *\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"disable\",\n value: function disable() {\n this.disabled = true;\n return this;\n }\n /**\r\n * Sets glide into a active status.\r\n *\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"enable\",\n value: function enable() {\n this.disabled = false;\n return this;\n }\n /**\r\n * Adds cuutom event listener with handler.\r\n *\r\n * @param {String|Array} event\r\n * @param {Function} handler\r\n * @return {Glide}\r\n */\n\n }, {\n key: \"on\",\n value: function on(event, handler) {\n this._e.on(event, handler);\n\n return this;\n }\n /**\r\n * Checks if glide is a precised type.\r\n *\r\n * @param {String} name\r\n * @return {Boolean}\r\n */\n\n }, {\n key: \"isType\",\n value: function isType(name) {\n return this.settings.type === name;\n }\n /**\r\n * Gets value of the core options.\r\n *\r\n * @return {Object}\r\n */\n\n }, {\n key: \"settings\",\n get: function get() {\n return this._o;\n }\n /**\r\n * Sets value of the core options.\r\n *\r\n * @param {Object} o\r\n * @return {Void}\r\n */\n ,\n set: function set(o) {\n if (isObject(o)) {\n this._o = o;\n } else {\n warn('Options must be an `object` instance.');\n }\n }\n /**\r\n * Gets current index of the slider.\r\n *\r\n * @return {Object}\r\n */\n\n }, {\n key: \"index\",\n get: function get() {\n return this._i;\n }\n /**\r\n * Sets current index a slider.\r\n *\r\n * @return {Object}\r\n */\n ,\n set: function set(i) {\n this._i = toInt(i);\n }\n /**\r\n * Gets type name of the slider.\r\n *\r\n * @return {String}\r\n */\n\n }, {\n key: \"type\",\n get: function get() {\n return this.settings.type;\n }\n /**\r\n * Gets value of the idle status.\r\n *\r\n * @return {Boolean}\r\n */\n\n }, {\n key: \"disabled\",\n get: function get() {\n return this._d;\n }\n /**\r\n * Sets value of the idle status.\r\n *\r\n * @return {Boolean}\r\n */\n ,\n set: function set(status) {\n this._d = !!status;\n }\n }]);\n\n return Glide;\n}();\n\nfunction Run (Glide, Components, Events) {\n var Run = {\n /**\n * Initializes autorunning of the glide.\n *\n * @return {Void}\n */\n mount: function mount() {\n this._o = false;\n },\n\n /**\n * Makes glides running based on the passed moving schema.\n *\n * @param {String} move\n */\n make: function make(move) {\n var _this = this;\n\n if (!Glide.disabled) {\n !Glide.settings.waitForTransition || Glide.disable();\n this.move = move;\n Events.emit('run.before', this.move);\n this.calculate();\n Events.emit('run', this.move);\n Components.Transition.after(function () {\n if (_this.isStart()) {\n Events.emit('run.start', _this.move);\n }\n\n if (_this.isEnd()) {\n Events.emit('run.end', _this.move);\n }\n\n if (_this.isOffset()) {\n _this._o = false;\n Events.emit('run.offset', _this.move);\n }\n\n Events.emit('run.after', _this.move);\n Glide.enable();\n });\n }\n },\n\n /**\n * Calculates current index based on defined move.\n *\n * @return {Number|Undefined}\n */\n calculate: function calculate() {\n var move = this.move,\n length = this.length;\n var steps = move.steps,\n direction = move.direction; // By default assume that size of view is equal to one slide\n\n var viewSize = 1; // While direction is `=` we want jump to\n // a specified index described in steps.\n\n if (direction === '=') {\n // Check if bound is true, \n // as we want to avoid whitespaces.\n if (Glide.settings.bound && toInt(steps) > length) {\n Glide.index = length;\n return;\n }\n\n Glide.index = steps;\n return;\n } // When pattern is equal to `>>` we want\n // fast forward to the last slide.\n\n\n if (direction === '>' && steps === '>') {\n Glide.index = length;\n return;\n } // When pattern is equal to `<<` we want\n // fast forward to the first slide.\n\n\n if (direction === '<' && steps === '<') {\n Glide.index = 0;\n return;\n } // pagination movement\n\n\n if (direction === '|') {\n viewSize = Glide.settings.perView || 1;\n } // we are moving forward\n\n\n if (direction === '>' || direction === '|' && steps === '>') {\n var index = calculateForwardIndex(viewSize);\n\n if (index > length) {\n this._o = true;\n }\n\n Glide.index = normalizeForwardIndex(index, viewSize);\n return;\n } // we are moving backward\n\n\n if (direction === '<' || direction === '|' && steps === '<') {\n var _index = calculateBackwardIndex(viewSize);\n\n if (_index < 0) {\n this._o = true;\n }\n\n Glide.index = normalizeBackwardIndex(_index, viewSize);\n return;\n }\n\n warn(\"Invalid direction pattern [\".concat(direction).concat(steps, \"] has been used\"));\n },\n\n /**\n * Checks if we are on the first slide.\n *\n * @return {Boolean}\n */\n isStart: function isStart() {\n return Glide.index <= 0;\n },\n\n /**\n * Checks if we are on the last slide.\n *\n * @return {Boolean}\n */\n isEnd: function isEnd() {\n return Glide.index >= this.length;\n },\n\n /**\n * Checks if we are making a offset run.\n *\n * @param {String} direction\n * @return {Boolean}\n */\n isOffset: function isOffset() {\n var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined;\n\n if (!direction) {\n return this._o;\n }\n\n if (!this._o) {\n return false;\n } // did we view to the right?\n\n\n if (direction === '|>') {\n return this.move.direction === '|' && this.move.steps === '>';\n } // did we view to the left?\n\n\n if (direction === '|<') {\n return this.move.direction === '|' && this.move.steps === '<';\n }\n\n return this.move.direction === direction;\n },\n\n /**\n * Checks if bound mode is active\n *\n * @return {Boolean}\n */\n isBound: function isBound() {\n return Glide.isType('slider') && Glide.settings.focusAt !== 'center' && Glide.settings.bound;\n }\n };\n /**\n * Returns index value to move forward/to the right\n *\n * @param viewSize\n * @returns {Number}\n */\n\n function calculateForwardIndex(viewSize) {\n var index = Glide.index;\n\n if (Glide.isType('carousel')) {\n return index + viewSize;\n }\n\n return index + (viewSize - index % viewSize);\n }\n /**\n * Normalizes the given forward index based on glide settings, preventing it to exceed certain boundaries\n *\n * @param index\n * @param length\n * @param viewSize\n * @returns {Number}\n */\n\n\n function normalizeForwardIndex(index, viewSize) {\n var length = Run.length;\n\n if (index <= length) {\n return index;\n }\n\n if (Glide.isType('carousel')) {\n return index - (length + 1);\n }\n\n if (Glide.settings.rewind) {\n // bound does funny things with the length, therefor we have to be certain\n // that we are on the last possible index value given by bound\n if (Run.isBound() && !Run.isEnd()) {\n return length;\n }\n\n return 0;\n }\n\n if (Run.isBound()) {\n return length;\n }\n\n return Math.floor(length / viewSize) * viewSize;\n }\n /**\n * Calculates index value to move backward/to the left\n *\n * @param viewSize\n * @returns {Number}\n */\n\n\n function calculateBackwardIndex(viewSize) {\n var index = Glide.index;\n\n if (Glide.isType('carousel')) {\n return index - viewSize;\n } // ensure our back navigation results in the same index as a forward navigation\n // to experience a homogeneous paging\n\n\n var view = Math.ceil(index / viewSize);\n return (view - 1) * viewSize;\n }\n /**\n * Normalizes the given backward index based on glide settings, preventing it to exceed certain boundaries\n *\n * @param index\n * @param length\n * @param viewSize\n * @returns {*}\n */\n\n\n function normalizeBackwardIndex(index, viewSize) {\n var length = Run.length;\n\n if (index >= 0) {\n return index;\n }\n\n if (Glide.isType('carousel')) {\n return index + (length + 1);\n }\n\n if (Glide.settings.rewind) {\n // bound does funny things with the length, therefor we have to be certain\n // that we are on first possible index value before we to rewind to the length given by bound\n if (Run.isBound() && Run.isStart()) {\n return length;\n }\n\n return Math.floor(length / viewSize) * viewSize;\n }\n\n return 0;\n }\n\n define(Run, 'move', {\n /**\n * Gets value of the move schema.\n *\n * @returns {Object}\n */\n get: function get() {\n return this._m;\n },\n\n /**\n * Sets value of the move schema.\n *\n * @returns {Object}\n */\n set: function set(value) {\n var step = value.substr(1);\n this._m = {\n direction: value.substr(0, 1),\n steps: step ? toInt(step) ? toInt(step) : step : 0\n };\n }\n });\n define(Run, 'length', {\n /**\n * Gets value of the running distance based\n * on zero-indexing number of slides.\n *\n * @return {Number}\n */\n get: function get() {\n var settings = Glide.settings;\n var length = Components.Html.slides.length; // If the `bound` option is active, a maximum running distance should be\n // reduced by `perView` and `focusAt` settings. Running distance\n // should end before creating an empty space after instance.\n\n if (this.isBound()) {\n return length - 1 - (toInt(settings.perView) - 1) + toInt(settings.focusAt);\n }\n\n return length - 1;\n }\n });\n define(Run, 'offset', {\n /**\n * Gets status of the offsetting flag.\n *\n * @return {Boolean}\n */\n get: function get() {\n return this._o;\n }\n });\n return Run;\n}\n\n/**\n * Returns a current time.\n *\n * @return {Number}\n */\nfunction now() {\n return new Date().getTime();\n}\n\n/**\n * Returns a function, that, when invoked, will only be triggered\n * at most once during a given window of time.\n *\n * @param {Function} func\n * @param {Number} wait\n * @param {Object=} options\n * @return {Function}\n *\n * @see https://github.com/jashkenas/underscore\n */\n\nfunction throttle(func, wait, options) {\n var timeout, context, args, result;\n var previous = 0;\n if (!options) options = {};\n\n var later = function later() {\n previous = options.leading === false ? 0 : now();\n timeout = null;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n };\n\n var throttled = function throttled() {\n var at = now();\n if (!previous && options.leading === false) previous = at;\n var remaining = wait - (at - previous);\n context = this;\n args = arguments;\n\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n\n previous = at;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n } else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(later, remaining);\n }\n\n return result;\n };\n\n throttled.cancel = function () {\n clearTimeout(timeout);\n previous = 0;\n timeout = context = args = null;\n };\n\n return throttled;\n}\n\nvar MARGIN_TYPE = {\n ltr: ['marginLeft', 'marginRight'],\n rtl: ['marginRight', 'marginLeft']\n};\nfunction Gaps (Glide, Components, Events) {\n var Gaps = {\n /**\n * Applies gaps between slides. First and last\n * slides do not receive it's edge margins.\n *\n * @param {HTMLCollection} slides\n * @return {Void}\n */\n apply: function apply(slides) {\n for (var i = 0, len = slides.length; i < len; i++) {\n var style = slides[i].style;\n var direction = Components.Direction.value;\n\n if (i !== 0) {\n style[MARGIN_TYPE[direction][0]] = \"\".concat(this.value / 2, \"px\");\n } else {\n style[MARGIN_TYPE[direction][0]] = '';\n }\n\n if (i !== slides.length - 1) {\n style[MARGIN_TYPE[direction][1]] = \"\".concat(this.value / 2, \"px\");\n } else {\n style[MARGIN_TYPE[direction][1]] = '';\n }\n }\n },\n\n /**\n * Removes gaps from the slides.\n *\n * @param {HTMLCollection} slides\n * @returns {Void}\n */\n remove: function remove(slides) {\n for (var i = 0, len = slides.length; i < len; i++) {\n var style = slides[i].style;\n style.marginLeft = '';\n style.marginRight = '';\n }\n }\n };\n define(Gaps, 'value', {\n /**\n * Gets value of the gap.\n *\n * @returns {Number}\n */\n get: function get() {\n return toInt(Glide.settings.gap);\n }\n });\n define(Gaps, 'grow', {\n /**\n * Gets additional dimensions value caused by gaps.\n * Used to increase width of the slides wrapper.\n *\n * @returns {Number}\n */\n get: function get() {\n return Gaps.value * Components.Sizes.length;\n }\n });\n define(Gaps, 'reductor', {\n /**\n * Gets reduction value caused by gaps.\n * Used to subtract width of the slides.\n *\n * @returns {Number}\n */\n get: function get() {\n var perView = Glide.settings.perView;\n return Gaps.value * (perView - 1) / perView;\n }\n });\n /**\n * Apply calculated gaps:\n * - after building, so slides (including clones) will receive proper margins\n * - on updating via API, to recalculate gaps with new options\n */\n\n Events.on(['build.after', 'update'], throttle(function () {\n Gaps.apply(Components.Html.wrapper.children);\n }, 30));\n /**\n * Remove gaps:\n * - on destroying to bring markup to its inital state\n */\n\n Events.on('destroy', function () {\n Gaps.remove(Components.Html.wrapper.children);\n });\n return Gaps;\n}\n\n/**\n * Finds siblings nodes of the passed node.\n *\n * @param {Element} node\n * @return {Array}\n */\nfunction siblings(node) {\n if (node && node.parentNode) {\n var n = node.parentNode.firstChild;\n var matched = [];\n\n for (; n; n = n.nextSibling) {\n if (n.nodeType === 1 && n !== node) {\n matched.push(n);\n }\n }\n\n return matched;\n }\n\n return [];\n}\n/**\n * Checks if passed node exist and is a valid element.\n *\n * @param {Element} node\n * @return {Boolean}\n */\n\nfunction exist(node) {\n if (node && node instanceof window.HTMLElement) {\n return true;\n }\n\n return false;\n}\n/**\n * Coerces a NodeList to an Array.\n *\n * @param {NodeList} nodeList\n * @return {Array}\n */\n\nfunction toArray(nodeList) {\n return Array.prototype.slice.call(nodeList);\n}\n\nvar TRACK_SELECTOR = '[data-glide-el=\"track\"]';\nfunction Html (Glide, Components, Events) {\n var Html = {\n /**\n * Setup slider HTML nodes.\n *\n * @param {Glide} glide\n */\n mount: function mount() {\n this.root = Glide.selector;\n this.track = this.root.querySelector(TRACK_SELECTOR);\n this.collectSlides();\n },\n\n /**\n * Collect slides\n */\n collectSlides: function collectSlides() {\n this.slides = toArray(this.wrapper.children).filter(function (slide) {\n return !slide.classList.contains(Glide.settings.classes.slide.clone);\n });\n }\n };\n define(Html, 'root', {\n /**\n * Gets node of the glide main element.\n *\n * @return {Object}\n */\n get: function get() {\n return Html._r;\n },\n\n /**\n * Sets node of the glide main element.\n *\n * @return {Object}\n */\n set: function set(r) {\n if (isString(r)) {\n r = document.querySelector(r);\n }\n\n if (exist(r)) {\n Html._r = r;\n } else {\n warn('Root element must be a existing Html node');\n }\n }\n });\n define(Html, 'track', {\n /**\n * Gets node of the glide track with slides.\n *\n * @return {Object}\n */\n get: function get() {\n return Html._t;\n },\n\n /**\n * Sets node of the glide track with slides.\n *\n * @return {Object}\n */\n set: function set(t) {\n if (exist(t)) {\n Html._t = t;\n } else {\n warn(\"Could not find track element. Please use \".concat(TRACK_SELECTOR, \" attribute.\"));\n }\n }\n });\n define(Html, 'wrapper', {\n /**\n * Gets node of the slides wrapper.\n *\n * @return {Object}\n */\n get: function get() {\n return Html.track.children[0];\n }\n });\n /**\n * Add/remove/reorder dynamic slides\n */\n\n Events.on('update', function () {\n Html.collectSlides();\n });\n return Html;\n}\n\nfunction Peek (Glide, Components, Events) {\n var Peek = {\n /**\n * Setups how much to peek based on settings.\n *\n * @return {Void}\n */\n mount: function mount() {\n this.value = Glide.settings.peek;\n }\n };\n define(Peek, 'value', {\n /**\n * Gets value of the peek.\n *\n * @returns {Number|Object}\n */\n get: function get() {\n return Peek._v;\n },\n\n /**\n * Sets value of the peek.\n *\n * @param {Number|Object} value\n * @return {Void}\n */\n set: function set(value) {\n if (isObject(value)) {\n value.before = toInt(value.before);\n value.after = toInt(value.after);\n } else {\n value = toInt(value);\n }\n\n Peek._v = value;\n }\n });\n define(Peek, 'reductor', {\n /**\n * Gets reduction value caused by peek.\n *\n * @returns {Number}\n */\n get: function get() {\n var value = Peek.value;\n var perView = Glide.settings.perView;\n\n if (isObject(value)) {\n return value.before / perView + value.after / perView;\n }\n\n return value * 2 / perView;\n }\n });\n /**\n * Recalculate peeking sizes on:\n * - when resizing window to update to proper percents\n */\n\n Events.on(['resize', 'update'], function () {\n Peek.mount();\n });\n return Peek;\n}\n\nfunction Move (Glide, Components, Events) {\n var Move = {\n /**\n * Constructs move component.\n *\n * @returns {Void}\n */\n mount: function mount() {\n this._o = 0;\n },\n\n /**\n * Calculates a movement value based on passed offset and currently active index.\n *\n * @param {Number} offset\n * @return {Void}\n */\n make: function make() {\n var _this = this;\n\n var offset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n this.offset = offset;\n Events.emit('move', {\n movement: this.value\n });\n Components.Transition.after(function () {\n Events.emit('move.after', {\n movement: _this.value\n });\n });\n }\n };\n define(Move, 'offset', {\n /**\n * Gets an offset value used to modify current translate.\n *\n * @return {Object}\n */\n get: function get() {\n return Move._o;\n },\n\n /**\n * Sets an offset value used to modify current translate.\n *\n * @return {Object}\n */\n set: function set(value) {\n Move._o = !isUndefined(value) ? toInt(value) : 0;\n }\n });\n define(Move, 'translate', {\n /**\n * Gets a raw movement value.\n *\n * @return {Number}\n */\n get: function get() {\n return Components.Sizes.slideWidth * Glide.index;\n }\n });\n define(Move, 'value', {\n /**\n * Gets an actual movement value corrected by offset.\n *\n * @return {Number}\n */\n get: function get() {\n var offset = this.offset;\n var translate = this.translate;\n\n if (Components.Direction.is('rtl')) {\n return translate + offset;\n }\n\n return translate - offset;\n }\n });\n /**\n * Make movement to proper slide on:\n * - before build, so glide will start at `startAt` index\n * - on each standard run to move to newly calculated index\n */\n\n Events.on(['build.before', 'run'], function () {\n Move.make();\n });\n return Move;\n}\n\nfunction Sizes (Glide, Components, Events) {\n var Sizes = {\n /**\n * Setups dimensions of slides.\n *\n * @return {Void}\n */\n setupSlides: function setupSlides() {\n var width = \"\".concat(this.slideWidth, \"px\");\n var slides = Components.Html.slides;\n\n for (var i = 0; i < slides.length; i++) {\n slides[i].style.width = width;\n }\n },\n\n /**\n * Setups dimensions of slides wrapper.\n *\n * @return {Void}\n */\n setupWrapper: function setupWrapper() {\n Components.Html.wrapper.style.width = \"\".concat(this.wrapperSize, \"px\");\n },\n\n /**\n * Removes applied styles from HTML elements.\n *\n * @returns {Void}\n */\n remove: function remove() {\n var slides = Components.Html.slides;\n\n for (var i = 0; i < slides.length; i++) {\n slides[i].style.width = '';\n }\n\n Components.Html.wrapper.style.width = '';\n }\n };\n define(Sizes, 'length', {\n /**\n * Gets count number of the slides.\n *\n * @return {Number}\n */\n get: function get() {\n return Components.Html.slides.length;\n }\n });\n define(Sizes, 'width', {\n /**\n * Gets width value of the slider (visible area).\n *\n * @return {Number}\n */\n get: function get() {\n return Components.Html.track.offsetWidth;\n }\n });\n define(Sizes, 'wrapperSize', {\n /**\n * Gets size of the slides wrapper.\n *\n * @return {Number}\n */\n get: function get() {\n return Sizes.slideWidth * Sizes.length + Components.Gaps.grow + Components.Clones.grow;\n }\n });\n define(Sizes, 'slideWidth', {\n /**\n * Gets width value of a single slide.\n *\n * @return {Number}\n */\n get: function get() {\n return Sizes.width / Glide.settings.perView - Components.Peek.reductor - Components.Gaps.reductor;\n }\n });\n /**\n * Apply calculated glide's dimensions:\n * - before building, so other dimensions (e.g. translate) will be calculated propertly\n * - when resizing window to recalculate sildes dimensions\n * - on updating via API, to calculate dimensions based on new options\n */\n\n Events.on(['build.before', 'resize', 'update'], function () {\n Sizes.setupSlides();\n Sizes.setupWrapper();\n });\n /**\n * Remove calculated glide's dimensions:\n * - on destoting to bring markup to its inital state\n */\n\n Events.on('destroy', function () {\n Sizes.remove();\n });\n return Sizes;\n}\n\nfunction Build (Glide, Components, Events) {\n var Build = {\n /**\n * Init glide building. Adds classes, sets\n * dimensions and setups initial state.\n *\n * @return {Void}\n */\n mount: function mount() {\n Events.emit('build.before');\n this.typeClass();\n this.activeClass();\n Events.emit('build.after');\n },\n\n /**\n * Adds `type` class to the glide element.\n *\n * @return {Void}\n */\n typeClass: function typeClass() {\n Components.Html.root.classList.add(Glide.settings.classes.type[Glide.settings.type]);\n },\n\n /**\n * Sets active class to current slide.\n *\n * @return {Void}\n */\n activeClass: function activeClass() {\n var classes = Glide.settings.classes;\n var slide = Components.Html.slides[Glide.index];\n\n if (slide) {\n slide.classList.add(classes.slide.active);\n siblings(slide).forEach(function (sibling) {\n sibling.classList.remove(classes.slide.active);\n });\n }\n },\n\n /**\n * Removes HTML classes applied at building.\n *\n * @return {Void}\n */\n removeClasses: function removeClasses() {\n var _Glide$settings$class = Glide.settings.classes,\n type = _Glide$settings$class.type,\n slide = _Glide$settings$class.slide;\n Components.Html.root.classList.remove(type[Glide.settings.type]);\n Components.Html.slides.forEach(function (sibling) {\n sibling.classList.remove(slide.active);\n });\n }\n };\n /**\n * Clear building classes:\n * - on destroying to bring HTML to its initial state\n * - on updating to remove classes before remounting component\n */\n\n Events.on(['destroy', 'update'], function () {\n Build.removeClasses();\n });\n /**\n * Remount component:\n * - on resizing of the window to calculate new dimensions\n * - on updating settings via API\n */\n\n Events.on(['resize', 'update'], function () {\n Build.mount();\n });\n /**\n * Swap active class of current slide:\n * - after each move to the new index\n */\n\n Events.on('move.after', function () {\n Build.activeClass();\n });\n return Build;\n}\n\nfunction Clones (Glide, Components, Events) {\n var Clones = {\n /**\n * Create pattern map and collect slides to be cloned.\n */\n mount: function mount() {\n this.items = [];\n\n if (Glide.isType('carousel')) {\n this.items = this.collect();\n }\n },\n\n /**\n * Collect clones with pattern.\n *\n * @return {[]}\n */\n collect: function collect() {\n var items = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n var slides = Components.Html.slides;\n var _Glide$settings = Glide.settings,\n perView = _Glide$settings.perView,\n classes = _Glide$settings.classes,\n cloningRatio = _Glide$settings.cloningRatio;\n\n if (slides.length !== 0) {\n var peekIncrementer = +!!Glide.settings.peek;\n var cloneCount = perView + peekIncrementer + Math.round(perView / 2);\n var append = slides.slice(0, cloneCount).reverse();\n var prepend = slides.slice(cloneCount * -1);\n\n for (var r = 0; r < Math.max(cloningRatio, Math.floor(perView / slides.length)); r++) {\n for (var i = 0; i < append.length; i++) {\n var clone = append[i].cloneNode(true);\n clone.classList.add(classes.slide.clone);\n items.push(clone);\n }\n\n for (var _i = 0; _i < prepend.length; _i++) {\n var _clone = prepend[_i].cloneNode(true);\n\n _clone.classList.add(classes.slide.clone);\n\n items.unshift(_clone);\n }\n }\n }\n\n return items;\n },\n\n /**\n * Append cloned slides with generated pattern.\n *\n * @return {Void}\n */\n append: function append() {\n var items = this.items;\n var _Components$Html = Components.Html,\n wrapper = _Components$Html.wrapper,\n slides = _Components$Html.slides;\n var half = Math.floor(items.length / 2);\n var prepend = items.slice(0, half).reverse();\n var append = items.slice(half * -1).reverse();\n var width = \"\".concat(Components.Sizes.slideWidth, \"px\");\n\n for (var i = 0; i < append.length; i++) {\n wrapper.appendChild(append[i]);\n }\n\n for (var _i2 = 0; _i2 < prepend.length; _i2++) {\n wrapper.insertBefore(prepend[_i2], slides[0]);\n }\n\n for (var _i3 = 0; _i3 < items.length; _i3++) {\n items[_i3].style.width = width;\n }\n },\n\n /**\n * Remove all cloned slides.\n *\n * @return {Void}\n */\n remove: function remove() {\n var items = this.items;\n\n for (var i = 0; i < items.length; i++) {\n Components.Html.wrapper.removeChild(items[i]);\n }\n }\n };\n define(Clones, 'grow', {\n /**\n * Gets additional dimensions value caused by clones.\n *\n * @return {Number}\n */\n get: function get() {\n return (Components.Sizes.slideWidth + Components.Gaps.value) * Clones.items.length;\n }\n });\n /**\n * Append additional slide's clones:\n * - while glide's type is `carousel`\n */\n\n Events.on('update', function () {\n Clones.remove();\n Clones.mount();\n Clones.append();\n });\n /**\n * Append additional slide's clones:\n * - while glide's type is `carousel`\n */\n\n Events.on('build.before', function () {\n if (Glide.isType('carousel')) {\n Clones.append();\n }\n });\n /**\n * Remove clones HTMLElements:\n * - on destroying, to bring HTML to its initial state\n */\n\n Events.on('destroy', function () {\n Clones.remove();\n });\n return Clones;\n}\n\nvar EventsBinder = /*#__PURE__*/function () {\n /**\n * Construct a EventsBinder instance.\n */\n function EventsBinder() {\n var listeners = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n _classCallCheck(this, EventsBinder);\n\n this.listeners = listeners;\n }\n /**\n * Adds events listeners to arrows HTML elements.\n *\n * @param {String|Array} events\n * @param {Element|Window|Document} el\n * @param {Function} closure\n * @param {Boolean|Object} capture\n * @return {Void}\n */\n\n\n _createClass(EventsBinder, [{\n key: \"on\",\n value: function on(events, el, closure) {\n var capture = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n\n if (isString(events)) {\n events = [events];\n }\n\n for (var i = 0; i < events.length; i++) {\n this.listeners[events[i]] = closure;\n el.addEventListener(events[i], this.listeners[events[i]], capture);\n }\n }\n /**\n * Removes event listeners from arrows HTML elements.\n *\n * @param {String|Array} events\n * @param {Element|Window|Document} el\n * @param {Boolean|Object} capture\n * @return {Void}\n */\n\n }, {\n key: \"off\",\n value: function off(events, el) {\n var capture = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n\n if (isString(events)) {\n events = [events];\n }\n\n for (var i = 0; i < events.length; i++) {\n el.removeEventListener(events[i], this.listeners[events[i]], capture);\n }\n }\n /**\n * Destroy collected listeners.\n *\n * @returns {Void}\n */\n\n }, {\n key: \"destroy\",\n value: function destroy() {\n delete this.listeners;\n }\n }]);\n\n return EventsBinder;\n}();\n\nfunction Resize (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var Resize = {\n /**\n * Initializes window bindings.\n */\n mount: function mount() {\n this.bind();\n },\n\n /**\n * Binds `rezsize` listener to the window.\n * It's a costly event, so we are debouncing it.\n *\n * @return {Void}\n */\n bind: function bind() {\n Binder.on('resize', window, throttle(function () {\n Events.emit('resize');\n }, Glide.settings.throttle));\n },\n\n /**\n * Unbinds listeners from the window.\n *\n * @return {Void}\n */\n unbind: function unbind() {\n Binder.off('resize', window);\n }\n };\n /**\n * Remove bindings from window:\n * - on destroying, to remove added EventListener\n */\n\n Events.on('destroy', function () {\n Resize.unbind();\n Binder.destroy();\n });\n return Resize;\n}\n\nvar VALID_DIRECTIONS = ['ltr', 'rtl'];\nvar FLIPED_MOVEMENTS = {\n '>': '<',\n '<': '>',\n '=': '='\n};\nfunction Direction (Glide, Components, Events) {\n var Direction = {\n /**\n * Setups gap value based on settings.\n *\n * @return {Void}\n */\n mount: function mount() {\n this.value = Glide.settings.direction;\n },\n\n /**\n * Resolves pattern based on direction value\n *\n * @param {String} pattern\n * @returns {String}\n */\n resolve: function resolve(pattern) {\n var token = pattern.slice(0, 1);\n\n if (this.is('rtl')) {\n return pattern.split(token).join(FLIPED_MOVEMENTS[token]);\n }\n\n return pattern;\n },\n\n /**\n * Checks value of direction mode.\n *\n * @param {String} direction\n * @returns {Boolean}\n */\n is: function is(direction) {\n return this.value === direction;\n },\n\n /**\n * Applies direction class to the root HTML element.\n *\n * @return {Void}\n */\n addClass: function addClass() {\n Components.Html.root.classList.add(Glide.settings.classes.direction[this.value]);\n },\n\n /**\n * Removes direction class from the root HTML element.\n *\n * @return {Void}\n */\n removeClass: function removeClass() {\n Components.Html.root.classList.remove(Glide.settings.classes.direction[this.value]);\n }\n };\n define(Direction, 'value', {\n /**\n * Gets value of the direction.\n *\n * @returns {Number}\n */\n get: function get() {\n return Direction._v;\n },\n\n /**\n * Sets value of the direction.\n *\n * @param {String} value\n * @return {Void}\n */\n set: function set(value) {\n if (VALID_DIRECTIONS.indexOf(value) > -1) {\n Direction._v = value;\n } else {\n warn('Direction value must be `ltr` or `rtl`');\n }\n }\n });\n /**\n * Clear direction class:\n * - on destroy to bring HTML to its initial state\n * - on update to remove class before reappling bellow\n */\n\n Events.on(['destroy', 'update'], function () {\n Direction.removeClass();\n });\n /**\n * Remount component:\n * - on update to reflect changes in direction value\n */\n\n Events.on('update', function () {\n Direction.mount();\n });\n /**\n * Apply direction class:\n * - before building to apply class for the first time\n * - on updating to reapply direction class that may changed\n */\n\n Events.on(['build.before', 'update'], function () {\n Direction.addClass();\n });\n return Direction;\n}\n\n/**\n * Reflects value of glide movement.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\nfunction Rtl (Glide, Components) {\n return {\n /**\n * Negates the passed translate if glide is in RTL option.\n *\n * @param {Number} translate\n * @return {Number}\n */\n modify: function modify(translate) {\n if (Components.Direction.is('rtl')) {\n return -translate;\n }\n\n return translate;\n }\n };\n}\n\n/**\n * Updates glide movement with a `gap` settings.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\nfunction Gap (Glide, Components) {\n return {\n /**\n * Modifies passed translate value with number in the `gap` settings.\n *\n * @param {Number} translate\n * @return {Number}\n */\n modify: function modify(translate) {\n var multiplier = Math.floor(translate / Components.Sizes.slideWidth);\n return translate + Components.Gaps.value * multiplier;\n }\n };\n}\n\n/**\n * Updates glide movement with width of additional clones width.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\nfunction Grow (Glide, Components) {\n return {\n /**\n * Adds to the passed translate width of the half of clones.\n *\n * @param {Number} translate\n * @return {Number}\n */\n modify: function modify(translate) {\n return translate + Components.Clones.grow / 2;\n }\n };\n}\n\n/**\n * Updates glide movement with a `peek` settings.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\n\nfunction Peeking (Glide, Components) {\n return {\n /**\n * Modifies passed translate value with a `peek` setting.\n *\n * @param {Number} translate\n * @return {Number}\n */\n modify: function modify(translate) {\n if (Glide.settings.focusAt >= 0) {\n var peek = Components.Peek.value;\n\n if (isObject(peek)) {\n return translate - peek.before;\n }\n\n return translate - peek;\n }\n\n return translate;\n }\n };\n}\n\n/**\n * Updates glide movement with a `focusAt` settings.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\nfunction Focusing (Glide, Components) {\n return {\n /**\n * Modifies passed translate value with index in the `focusAt` setting.\n *\n * @param {Number} translate\n * @return {Number}\n */\n modify: function modify(translate) {\n var gap = Components.Gaps.value;\n var width = Components.Sizes.width;\n var focusAt = Glide.settings.focusAt;\n var slideWidth = Components.Sizes.slideWidth;\n\n if (focusAt === 'center') {\n return translate - (width / 2 - slideWidth / 2);\n }\n\n return translate - slideWidth * focusAt - gap * focusAt;\n }\n };\n}\n\n/**\n * Applies diffrent transformers on translate value.\n *\n * @param {Object} Glide\n * @param {Object} Components\n * @return {Object}\n */\n\nfunction mutator (Glide, Components, Events) {\n /**\n * Merge instance transformers with collection of default transformers.\n * It's important that the Rtl component be last on the list,\n * so it reflects all previous transformations.\n *\n * @type {Array}\n */\n var TRANSFORMERS = [Gap, Grow, Peeking, Focusing].concat(Glide._t, [Rtl]);\n return {\n /**\n * Piplines translate value with registered transformers.\n *\n * @param {Number} translate\n * @return {Number}\n */\n mutate: function mutate(translate) {\n for (var i = 0; i < TRANSFORMERS.length; i++) {\n var transformer = TRANSFORMERS[i];\n\n if (isFunction(transformer) && isFunction(transformer().modify)) {\n translate = transformer(Glide, Components, Events).modify(translate);\n } else {\n warn('Transformer should be a function that returns an object with `modify()` method');\n }\n }\n\n return translate;\n }\n };\n}\n\nfunction Translate (Glide, Components, Events) {\n var Translate = {\n /**\n * Sets value of translate on HTML element.\n *\n * @param {Number} value\n * @return {Void}\n */\n set: function set(value) {\n var transform = mutator(Glide, Components).mutate(value);\n var translate3d = \"translate3d(\".concat(-1 * transform, \"px, 0px, 0px)\");\n Components.Html.wrapper.style.mozTransform = translate3d; // needed for supported Firefox 10-15\n\n Components.Html.wrapper.style.webkitTransform = translate3d; // needed for supported Chrome 10-35, Safari 5.1-8, and Opera 15-22\n\n Components.Html.wrapper.style.transform = translate3d;\n },\n\n /**\n * Removes value of translate from HTML element.\n *\n * @return {Void}\n */\n remove: function remove() {\n Components.Html.wrapper.style.transform = '';\n },\n\n /**\n * @return {number}\n */\n getStartIndex: function getStartIndex() {\n var length = Components.Sizes.length;\n var index = Glide.index;\n var perView = Glide.settings.perView;\n\n if (Components.Run.isOffset('>') || Components.Run.isOffset('|>')) {\n return length + (index - perView);\n } // \"modulo length\" converts an index that equals length to zero\n\n\n return (index + perView) % length;\n },\n\n /**\n * @return {number}\n */\n getTravelDistance: function getTravelDistance() {\n var travelDistance = Components.Sizes.slideWidth * Glide.settings.perView;\n\n if (Components.Run.isOffset('>') || Components.Run.isOffset('|>')) {\n // reverse travel distance so that we don't have to change subtract operations\n return travelDistance * -1;\n }\n\n return travelDistance;\n }\n };\n /**\n * Set new translate value:\n * - on move to reflect index change\n * - on updating via API to reflect possible changes in options\n */\n\n Events.on('move', function (context) {\n if (!Glide.isType('carousel') || !Components.Run.isOffset()) {\n return Translate.set(context.movement);\n }\n\n Components.Transition.after(function () {\n Events.emit('translate.jump');\n Translate.set(Components.Sizes.slideWidth * Glide.index);\n });\n var startWidth = Components.Sizes.slideWidth * Components.Translate.getStartIndex();\n return Translate.set(startWidth - Components.Translate.getTravelDistance());\n });\n /**\n * Remove translate:\n * - on destroying to bring markup to its inital state\n */\n\n Events.on('destroy', function () {\n Translate.remove();\n });\n return Translate;\n}\n\nfunction Transition (Glide, Components, Events) {\n /**\n * Holds inactivity status of transition.\n * When true transition is not applied.\n *\n * @type {Boolean}\n */\n var disabled = false;\n var Transition = {\n /**\n * Composes string of the CSS transition.\n *\n * @param {String} property\n * @return {String}\n */\n compose: function compose(property) {\n var settings = Glide.settings;\n\n if (!disabled) {\n return \"\".concat(property, \" \").concat(this.duration, \"ms \").concat(settings.animationTimingFunc);\n }\n\n return \"\".concat(property, \" 0ms \").concat(settings.animationTimingFunc);\n },\n\n /**\n * Sets value of transition on HTML element.\n *\n * @param {String=} property\n * @return {Void}\n */\n set: function set() {\n var property = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'transform';\n Components.Html.wrapper.style.transition = this.compose(property);\n },\n\n /**\n * Removes value of transition from HTML element.\n *\n * @return {Void}\n */\n remove: function remove() {\n Components.Html.wrapper.style.transition = '';\n },\n\n /**\n * Runs callback after animation.\n *\n * @param {Function} callback\n * @return {Void}\n */\n after: function after(callback) {\n setTimeout(function () {\n callback();\n }, this.duration);\n },\n\n /**\n * Enable transition.\n *\n * @return {Void}\n */\n enable: function enable() {\n disabled = false;\n this.set();\n },\n\n /**\n * Disable transition.\n *\n * @return {Void}\n */\n disable: function disable() {\n disabled = true;\n this.set();\n }\n };\n define(Transition, 'duration', {\n /**\n * Gets duration of the transition based\n * on currently running animation type.\n *\n * @return {Number}\n */\n get: function get() {\n var settings = Glide.settings;\n\n if (Glide.isType('slider') && Components.Run.offset) {\n return settings.rewindDuration;\n }\n\n return settings.animationDuration;\n }\n });\n /**\n * Set transition `style` value:\n * - on each moving, because it may be cleared by offset move\n */\n\n Events.on('move', function () {\n Transition.set();\n });\n /**\n * Disable transition:\n * - before initial build to avoid transitioning from `0` to `startAt` index\n * - while resizing window and recalculating dimensions\n * - on jumping from offset transition at start and end edges in `carousel` type\n */\n\n Events.on(['build.before', 'resize', 'translate.jump'], function () {\n Transition.disable();\n });\n /**\n * Enable transition:\n * - on each running, because it may be disabled by offset move\n */\n\n Events.on('run', function () {\n Transition.enable();\n });\n /**\n * Remove transition:\n * - on destroying to bring markup to its inital state\n */\n\n Events.on('destroy', function () {\n Transition.remove();\n });\n return Transition;\n}\n\n/**\n * Test via a getter in the options object to see\n * if the passive property is accessed.\n *\n * @see https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md#feature-detection\n */\nvar supportsPassive = false;\n\ntry {\n var opts = Object.defineProperty({}, 'passive', {\n get: function get() {\n supportsPassive = true;\n }\n });\n window.addEventListener('testPassive', null, opts);\n window.removeEventListener('testPassive', null, opts);\n} catch (e) {}\n\nvar supportsPassive$1 = supportsPassive;\n\nvar START_EVENTS = ['touchstart', 'mousedown'];\nvar MOVE_EVENTS = ['touchmove', 'mousemove'];\nvar END_EVENTS = ['touchend', 'touchcancel', 'mouseup', 'mouseleave'];\nvar MOUSE_EVENTS = ['mousedown', 'mousemove', 'mouseup', 'mouseleave'];\nfunction Swipe (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var swipeSin = 0;\n var swipeStartX = 0;\n var swipeStartY = 0;\n var disabled = false;\n var capture = supportsPassive$1 ? {\n passive: true\n } : false;\n var Swipe = {\n /**\n * Initializes swipe bindings.\n *\n * @return {Void}\n */\n mount: function mount() {\n this.bindSwipeStart();\n },\n\n /**\n * Handler for `swipestart` event. Calculates entry points of the user's tap.\n *\n * @param {Object} event\n * @return {Void}\n */\n start: function start(event) {\n if (!disabled && !Glide.disabled) {\n this.disable();\n var swipe = this.touches(event);\n swipeSin = null;\n swipeStartX = toInt(swipe.pageX);\n swipeStartY = toInt(swipe.pageY);\n this.bindSwipeMove();\n this.bindSwipeEnd();\n Events.emit('swipe.start');\n }\n },\n\n /**\n * Handler for `swipemove` event. Calculates user's tap angle and distance.\n *\n * @param {Object} event\n */\n move: function move(event) {\n if (!Glide.disabled) {\n var _Glide$settings = Glide.settings,\n touchAngle = _Glide$settings.touchAngle,\n touchRatio = _Glide$settings.touchRatio,\n classes = _Glide$settings.classes;\n var swipe = this.touches(event);\n var subExSx = toInt(swipe.pageX) - swipeStartX;\n var subEySy = toInt(swipe.pageY) - swipeStartY;\n var powEX = Math.abs(subExSx << 2);\n var powEY = Math.abs(subEySy << 2);\n var swipeHypotenuse = Math.sqrt(powEX + powEY);\n var swipeCathetus = Math.sqrt(powEY);\n swipeSin = Math.asin(swipeCathetus / swipeHypotenuse);\n\n if (swipeSin * 180 / Math.PI < touchAngle) {\n event.stopPropagation();\n Components.Move.make(subExSx * toFloat(touchRatio));\n Components.Html.root.classList.add(classes.dragging);\n Events.emit('swipe.move');\n } else {\n return false;\n }\n }\n },\n\n /**\n * Handler for `swipeend` event. Finitializes user's tap and decides about glide move.\n *\n * @param {Object} event\n * @return {Void}\n */\n end: function end(event) {\n if (!Glide.disabled) {\n var _Glide$settings2 = Glide.settings,\n perSwipe = _Glide$settings2.perSwipe,\n touchAngle = _Glide$settings2.touchAngle,\n classes = _Glide$settings2.classes;\n var swipe = this.touches(event);\n var threshold = this.threshold(event);\n var swipeDistance = swipe.pageX - swipeStartX;\n var swipeDeg = swipeSin * 180 / Math.PI;\n this.enable();\n\n if (swipeDistance > threshold && swipeDeg < touchAngle) {\n Components.Run.make(Components.Direction.resolve(\"\".concat(perSwipe, \"<\")));\n } else if (swipeDistance < -threshold && swipeDeg < touchAngle) {\n Components.Run.make(Components.Direction.resolve(\"\".concat(perSwipe, \">\")));\n } else {\n // While swipe don't reach distance apply previous transform.\n Components.Move.make();\n }\n\n Components.Html.root.classList.remove(classes.dragging);\n this.unbindSwipeMove();\n this.unbindSwipeEnd();\n Events.emit('swipe.end');\n }\n },\n\n /**\n * Binds swipe's starting event.\n *\n * @return {Void}\n */\n bindSwipeStart: function bindSwipeStart() {\n var _this = this;\n\n var _Glide$settings3 = Glide.settings,\n swipeThreshold = _Glide$settings3.swipeThreshold,\n dragThreshold = _Glide$settings3.dragThreshold;\n\n if (swipeThreshold) {\n Binder.on(START_EVENTS[0], Components.Html.wrapper, function (event) {\n _this.start(event);\n }, capture);\n }\n\n if (dragThreshold) {\n Binder.on(START_EVENTS[1], Components.Html.wrapper, function (event) {\n _this.start(event);\n }, capture);\n }\n },\n\n /**\n * Unbinds swipe's starting event.\n *\n * @return {Void}\n */\n unbindSwipeStart: function unbindSwipeStart() {\n Binder.off(START_EVENTS[0], Components.Html.wrapper, capture);\n Binder.off(START_EVENTS[1], Components.Html.wrapper, capture);\n },\n\n /**\n * Binds swipe's moving event.\n *\n * @return {Void}\n */\n bindSwipeMove: function bindSwipeMove() {\n var _this2 = this;\n\n Binder.on(MOVE_EVENTS, Components.Html.wrapper, throttle(function (event) {\n _this2.move(event);\n }, Glide.settings.throttle), capture);\n },\n\n /**\n * Unbinds swipe's moving event.\n *\n * @return {Void}\n */\n unbindSwipeMove: function unbindSwipeMove() {\n Binder.off(MOVE_EVENTS, Components.Html.wrapper, capture);\n },\n\n /**\n * Binds swipe's ending event.\n *\n * @return {Void}\n */\n bindSwipeEnd: function bindSwipeEnd() {\n var _this3 = this;\n\n Binder.on(END_EVENTS, Components.Html.wrapper, function (event) {\n _this3.end(event);\n });\n },\n\n /**\n * Unbinds swipe's ending event.\n *\n * @return {Void}\n */\n unbindSwipeEnd: function unbindSwipeEnd() {\n Binder.off(END_EVENTS, Components.Html.wrapper);\n },\n\n /**\n * Normalizes event touches points accorting to different types.\n *\n * @param {Object} event\n */\n touches: function touches(event) {\n if (MOUSE_EVENTS.indexOf(event.type) > -1) {\n return event;\n }\n\n return event.touches[0] || event.changedTouches[0];\n },\n\n /**\n * Gets value of minimum swipe distance settings based on event type.\n *\n * @return {Number}\n */\n threshold: function threshold(event) {\n var settings = Glide.settings;\n\n if (MOUSE_EVENTS.indexOf(event.type) > -1) {\n return settings.dragThreshold;\n }\n\n return settings.swipeThreshold;\n },\n\n /**\n * Enables swipe event.\n *\n * @return {self}\n */\n enable: function enable() {\n disabled = false;\n Components.Transition.enable();\n return this;\n },\n\n /**\n * Disables swipe event.\n *\n * @return {self}\n */\n disable: function disable() {\n disabled = true;\n Components.Transition.disable();\n return this;\n }\n };\n /**\n * Add component class:\n * - after initial building\n */\n\n Events.on('build.after', function () {\n Components.Html.root.classList.add(Glide.settings.classes.swipeable);\n });\n /**\n * Remove swiping bindings:\n * - on destroying, to remove added EventListeners\n */\n\n Events.on('destroy', function () {\n Swipe.unbindSwipeStart();\n Swipe.unbindSwipeMove();\n Swipe.unbindSwipeEnd();\n Binder.destroy();\n });\n return Swipe;\n}\n\nfunction Images (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var Images = {\n /**\n * Binds listener to glide wrapper.\n *\n * @return {Void}\n */\n mount: function mount() {\n this.bind();\n },\n\n /**\n * Binds `dragstart` event on wrapper to prevent dragging images.\n *\n * @return {Void}\n */\n bind: function bind() {\n Binder.on('dragstart', Components.Html.wrapper, this.dragstart);\n },\n\n /**\n * Unbinds `dragstart` event on wrapper.\n *\n * @return {Void}\n */\n unbind: function unbind() {\n Binder.off('dragstart', Components.Html.wrapper);\n },\n\n /**\n * Event handler. Prevents dragging.\n *\n * @return {Void}\n */\n dragstart: function dragstart(event) {\n event.preventDefault();\n }\n };\n /**\n * Remove bindings from images:\n * - on destroying, to remove added EventListeners\n */\n\n Events.on('destroy', function () {\n Images.unbind();\n Binder.destroy();\n });\n return Images;\n}\n\nfunction Anchors (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n /**\n * Holds detaching status of anchors.\n * Prevents detaching of already detached anchors.\n *\n * @private\n * @type {Boolean}\n */\n\n var detached = false;\n /**\n * Holds preventing status of anchors.\n * If `true` redirection after click will be disabled.\n *\n * @private\n * @type {Boolean}\n */\n\n var prevented = false;\n var Anchors = {\n /**\n * Setups a initial state of anchors component.\n *\n * @returns {Void}\n */\n mount: function mount() {\n /**\n * Holds collection of anchors elements.\n *\n * @private\n * @type {HTMLCollection}\n */\n this._a = Components.Html.wrapper.querySelectorAll('a');\n this.bind();\n },\n\n /**\n * Binds events to anchors inside a track.\n *\n * @return {Void}\n */\n bind: function bind() {\n Binder.on('click', Components.Html.wrapper, this.click);\n },\n\n /**\n * Unbinds events attached to anchors inside a track.\n *\n * @return {Void}\n */\n unbind: function unbind() {\n Binder.off('click', Components.Html.wrapper);\n },\n\n /**\n * Handler for click event. Prevents clicks when glide is in `prevent` status.\n *\n * @param {Object} event\n * @return {Void}\n */\n click: function click(event) {\n if (prevented) {\n event.stopPropagation();\n event.preventDefault();\n }\n },\n\n /**\n * Detaches anchors click event inside glide.\n *\n * @return {self}\n */\n detach: function detach() {\n prevented = true;\n\n if (!detached) {\n for (var i = 0; i < this.items.length; i++) {\n this.items[i].draggable = false;\n }\n\n detached = true;\n }\n\n return this;\n },\n\n /**\n * Attaches anchors click events inside glide.\n *\n * @return {self}\n */\n attach: function attach() {\n prevented = false;\n\n if (detached) {\n for (var i = 0; i < this.items.length; i++) {\n this.items[i].draggable = true;\n }\n\n detached = false;\n }\n\n return this;\n }\n };\n define(Anchors, 'items', {\n /**\n * Gets collection of the arrows HTML elements.\n *\n * @return {HTMLElement[]}\n */\n get: function get() {\n return Anchors._a;\n }\n });\n /**\n * Detach anchors inside slides:\n * - on swiping, so they won't redirect to its `href` attributes\n */\n\n Events.on('swipe.move', function () {\n Anchors.detach();\n });\n /**\n * Attach anchors inside slides:\n * - after swiping and transitions ends, so they can redirect after click again\n */\n\n Events.on('swipe.end', function () {\n Components.Transition.after(function () {\n Anchors.attach();\n });\n });\n /**\n * Unbind anchors inside slides:\n * - on destroying, to bring anchors to its initial state\n */\n\n Events.on('destroy', function () {\n Anchors.attach();\n Anchors.unbind();\n Binder.destroy();\n });\n return Anchors;\n}\n\nvar NAV_SELECTOR = '[data-glide-el=\"controls[nav]\"]';\nvar CONTROLS_SELECTOR = '[data-glide-el^=\"controls\"]';\nvar PREVIOUS_CONTROLS_SELECTOR = \"\".concat(CONTROLS_SELECTOR, \" [data-glide-dir*=\\\"<\\\"]\");\nvar NEXT_CONTROLS_SELECTOR = \"\".concat(CONTROLS_SELECTOR, \" [data-glide-dir*=\\\">\\\"]\");\nfunction Controls (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var capture = supportsPassive$1 ? {\n passive: true\n } : false;\n var Controls = {\n /**\n * Inits arrows. Binds events listeners\n * to the arrows HTML elements.\n *\n * @return {Void}\n */\n mount: function mount() {\n /**\n * Collection of navigation HTML elements.\n *\n * @private\n * @type {HTMLCollection}\n */\n this._n = Components.Html.root.querySelectorAll(NAV_SELECTOR);\n /**\n * Collection of controls HTML elements.\n *\n * @private\n * @type {HTMLCollection}\n */\n\n this._c = Components.Html.root.querySelectorAll(CONTROLS_SELECTOR);\n /**\n * Collection of arrow control HTML elements.\n *\n * @private\n * @type {Object}\n */\n\n this._arrowControls = {\n previous: Components.Html.root.querySelectorAll(PREVIOUS_CONTROLS_SELECTOR),\n next: Components.Html.root.querySelectorAll(NEXT_CONTROLS_SELECTOR)\n };\n this.addBindings();\n },\n\n /**\n * Sets active class to current slide.\n *\n * @return {Void}\n */\n setActive: function setActive() {\n for (var i = 0; i < this._n.length; i++) {\n this.addClass(this._n[i].children);\n }\n },\n\n /**\n * Removes active class to current slide.\n *\n * @return {Void}\n */\n removeActive: function removeActive() {\n for (var i = 0; i < this._n.length; i++) {\n this.removeClass(this._n[i].children);\n }\n },\n\n /**\n * Toggles active class on items inside navigation.\n *\n * @param {HTMLElement} controls\n * @return {Void}\n */\n addClass: function addClass(controls) {\n var settings = Glide.settings;\n var item = controls[Glide.index];\n\n if (!item) {\n return;\n }\n\n if (item) {\n item.classList.add(settings.classes.nav.active);\n siblings(item).forEach(function (sibling) {\n sibling.classList.remove(settings.classes.nav.active);\n });\n }\n },\n\n /**\n * Removes active class from active control.\n *\n * @param {HTMLElement} controls\n * @return {Void}\n */\n removeClass: function removeClass(controls) {\n var item = controls[Glide.index];\n\n if (item) {\n item.classList.remove(Glide.settings.classes.nav.active);\n }\n },\n\n /**\n * Calculates, removes or adds `Glide.settings.classes.disabledArrow` class on the control arrows\n */\n setArrowState: function setArrowState() {\n if (Glide.settings.rewind) {\n return;\n }\n\n var next = Controls._arrowControls.next;\n var previous = Controls._arrowControls.previous;\n this.resetArrowState(next, previous);\n\n if (Glide.index === 0) {\n this.disableArrow(previous);\n }\n\n if (Glide.index === Components.Run.length) {\n this.disableArrow(next);\n }\n },\n\n /**\n * Removes `Glide.settings.classes.disabledArrow` from given NodeList elements\n *\n * @param {NodeList[]} lists\n */\n resetArrowState: function resetArrowState() {\n var settings = Glide.settings;\n\n for (var _len = arguments.length, lists = new Array(_len), _key = 0; _key < _len; _key++) {\n lists[_key] = arguments[_key];\n }\n\n lists.forEach(function (list) {\n toArray(list).forEach(function (element) {\n element.classList.remove(settings.classes.arrow.disabled);\n });\n });\n },\n\n /**\n * Adds `Glide.settings.classes.disabledArrow` to given NodeList elements\n *\n * @param {NodeList[]} lists\n */\n disableArrow: function disableArrow() {\n var settings = Glide.settings;\n\n for (var _len2 = arguments.length, lists = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n lists[_key2] = arguments[_key2];\n }\n\n lists.forEach(function (list) {\n toArray(list).forEach(function (element) {\n element.classList.add(settings.classes.arrow.disabled);\n });\n });\n },\n\n /**\n * Adds handles to the each group of controls.\n *\n * @return {Void}\n */\n addBindings: function addBindings() {\n for (var i = 0; i < this._c.length; i++) {\n this.bind(this._c[i].children);\n }\n },\n\n /**\n * Removes handles from the each group of controls.\n *\n * @return {Void}\n */\n removeBindings: function removeBindings() {\n for (var i = 0; i < this._c.length; i++) {\n this.unbind(this._c[i].children);\n }\n },\n\n /**\n * Binds events to arrows HTML elements.\n *\n * @param {HTMLCollection} elements\n * @return {Void}\n */\n bind: function bind(elements) {\n for (var i = 0; i < elements.length; i++) {\n Binder.on('click', elements[i], this.click);\n Binder.on('touchstart', elements[i], this.click, capture);\n }\n },\n\n /**\n * Unbinds events binded to the arrows HTML elements.\n *\n * @param {HTMLCollection} elements\n * @return {Void}\n */\n unbind: function unbind(elements) {\n for (var i = 0; i < elements.length; i++) {\n Binder.off(['click', 'touchstart'], elements[i]);\n }\n },\n\n /**\n * Handles `click` event on the arrows HTML elements.\n * Moves slider in direction given via the\n * `data-glide-dir` attribute.\n *\n * @param {Object} event\n * @return {void}\n */\n click: function click(event) {\n if (!supportsPassive$1 && event.type === 'touchstart') {\n event.preventDefault();\n }\n\n var direction = event.currentTarget.getAttribute('data-glide-dir');\n Components.Run.make(Components.Direction.resolve(direction));\n }\n };\n define(Controls, 'items', {\n /**\n * Gets collection of the controls HTML elements.\n *\n * @return {HTMLElement[]}\n */\n get: function get() {\n return Controls._c;\n }\n });\n /**\n * Swap active class of current navigation item:\n * - after mounting to set it to initial index\n * - after each move to the new index\n */\n\n Events.on(['mount.after', 'move.after'], function () {\n Controls.setActive();\n });\n /**\n * Add or remove disabled class of arrow elements\n */\n\n Events.on(['mount.after', 'run'], function () {\n Controls.setArrowState();\n });\n /**\n * Remove bindings and HTML Classes:\n * - on destroying, to bring markup to its initial state\n */\n\n Events.on('destroy', function () {\n Controls.removeBindings();\n Controls.removeActive();\n Binder.destroy();\n });\n return Controls;\n}\n\nfunction Keyboard (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var Keyboard = {\n /**\n * Binds keyboard events on component mount.\n *\n * @return {Void}\n */\n mount: function mount() {\n if (Glide.settings.keyboard) {\n this.bind();\n }\n },\n\n /**\n * Adds keyboard press events.\n *\n * @return {Void}\n */\n bind: function bind() {\n Binder.on('keyup', document, this.press);\n },\n\n /**\n * Removes keyboard press events.\n *\n * @return {Void}\n */\n unbind: function unbind() {\n Binder.off('keyup', document);\n },\n\n /**\n * Handles keyboard's arrows press and moving glide foward and backward.\n *\n * @param {Object} event\n * @return {Void}\n */\n press: function press(event) {\n var perSwipe = Glide.settings.perSwipe;\n\n if (event.code === 'ArrowRight') {\n Components.Run.make(Components.Direction.resolve(\"\".concat(perSwipe, \">\")));\n }\n\n if (event.code === 'ArrowLeft') {\n Components.Run.make(Components.Direction.resolve(\"\".concat(perSwipe, \"<\")));\n }\n }\n };\n /**\n * Remove bindings from keyboard:\n * - on destroying to remove added events\n * - on updating to remove events before remounting\n */\n\n Events.on(['destroy', 'update'], function () {\n Keyboard.unbind();\n });\n /**\n * Remount component\n * - on updating to reflect potential changes in settings\n */\n\n Events.on('update', function () {\n Keyboard.mount();\n });\n /**\n * Destroy binder:\n * - on destroying to remove listeners\n */\n\n Events.on('destroy', function () {\n Binder.destroy();\n });\n return Keyboard;\n}\n\nfunction Autoplay (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n var Autoplay = {\n /**\n * Initializes autoplaying and events.\n *\n * @return {Void}\n */\n mount: function mount() {\n this.enable();\n this.start();\n\n if (Glide.settings.hoverpause) {\n this.bind();\n }\n },\n\n /**\n * Enables autoplaying\n *\n * @returns {Void}\n */\n enable: function enable() {\n this._e = true;\n },\n\n /**\n * Disables autoplaying.\n *\n * @returns {Void}\n */\n disable: function disable() {\n this._e = false;\n },\n\n /**\n * Starts autoplaying in configured interval.\n *\n * @param {Boolean|Number} force Run autoplaying with passed interval regardless of `autoplay` settings\n * @return {Void}\n */\n start: function start() {\n var _this = this;\n\n if (!this._e) {\n return;\n }\n\n this.enable();\n\n if (Glide.settings.autoplay) {\n if (isUndefined(this._i)) {\n this._i = setInterval(function () {\n _this.stop();\n\n Components.Run.make('>');\n\n _this.start();\n\n Events.emit('autoplay');\n }, this.time);\n }\n }\n },\n\n /**\n * Stops autorunning of the glide.\n *\n * @return {Void}\n */\n stop: function stop() {\n this._i = clearInterval(this._i);\n },\n\n /**\n * Stops autoplaying while mouse is over glide's area.\n *\n * @return {Void}\n */\n bind: function bind() {\n var _this2 = this;\n\n Binder.on('mouseover', Components.Html.root, function () {\n if (_this2._e) {\n _this2.stop();\n }\n });\n Binder.on('mouseout', Components.Html.root, function () {\n if (_this2._e) {\n _this2.start();\n }\n });\n },\n\n /**\n * Unbind mouseover events.\n *\n * @returns {Void}\n */\n unbind: function unbind() {\n Binder.off(['mouseover', 'mouseout'], Components.Html.root);\n }\n };\n define(Autoplay, 'time', {\n /**\n * Gets time period value for the autoplay interval. Prioritizes\n * times in `data-glide-autoplay` attrubutes over options.\n *\n * @return {Number}\n */\n get: function get() {\n var autoplay = Components.Html.slides[Glide.index].getAttribute('data-glide-autoplay');\n\n if (autoplay) {\n return toInt(autoplay);\n }\n\n return toInt(Glide.settings.autoplay);\n }\n });\n /**\n * Stop autoplaying and unbind events:\n * - on destroying, to clear defined interval\n * - on updating via API to reset interval that may changed\n */\n\n Events.on(['destroy', 'update'], function () {\n Autoplay.unbind();\n });\n /**\n * Stop autoplaying:\n * - before each run, to restart autoplaying\n * - on pausing via API\n * - on destroying, to clear defined interval\n * - while starting a swipe\n * - on updating via API to reset interval that may changed\n */\n\n Events.on(['run.before', 'swipe.start', 'update'], function () {\n Autoplay.stop();\n });\n Events.on(['pause', 'destroy'], function () {\n Autoplay.disable();\n Autoplay.stop();\n });\n /**\n * Start autoplaying:\n * - after each run, to restart autoplaying\n * - on playing via API\n * - while ending a swipe\n */\n\n Events.on(['run.after', 'swipe.end'], function () {\n Autoplay.start();\n });\n /**\n * Start autoplaying:\n * - after each run, to restart autoplaying\n * - on playing via API\n * - while ending a swipe\n */\n\n Events.on(['play'], function () {\n Autoplay.enable();\n Autoplay.start();\n });\n /**\n * Remount autoplaying:\n * - on updating via API to reset interval that may changed\n */\n\n Events.on('update', function () {\n Autoplay.mount();\n });\n /**\n * Destroy a binder:\n * - on destroying glide instance to clearup listeners\n */\n\n Events.on('destroy', function () {\n Binder.destroy();\n });\n return Autoplay;\n}\n\n/**\n * Sorts keys of breakpoint object so they will be ordered from lower to bigger.\n *\n * @param {Object} points\n * @returns {Object}\n */\n\nfunction sortBreakpoints(points) {\n if (isObject(points)) {\n return sortKeys(points);\n } else {\n warn(\"Breakpoints option must be an object\");\n }\n\n return {};\n}\n\nfunction Breakpoints (Glide, Components, Events) {\n /**\n * Instance of the binder for DOM Events.\n *\n * @type {EventsBinder}\n */\n var Binder = new EventsBinder();\n /**\n * Holds reference to settings.\n *\n * @type {Object}\n */\n\n var settings = Glide.settings;\n /**\n * Holds reference to breakpoints object in settings. Sorts breakpoints\n * from smaller to larger. It is required in order to proper\n * matching currently active breakpoint settings.\n *\n * @type {Object}\n */\n\n var points = sortBreakpoints(settings.breakpoints);\n /**\n * Cache initial settings before overwritting.\n *\n * @type {Object}\n */\n\n var defaults = Object.assign({}, settings);\n var Breakpoints = {\n /**\n * Matches settings for currectly matching media breakpoint.\n *\n * @param {Object} points\n * @returns {Object}\n */\n match: function match(points) {\n if (typeof window.matchMedia !== 'undefined') {\n for (var point in points) {\n if (points.hasOwnProperty(point)) {\n if (window.matchMedia(\"(max-width: \".concat(point, \"px)\")).matches) {\n return points[point];\n }\n }\n }\n }\n\n return defaults;\n }\n };\n /**\n * Overwrite instance settings with currently matching breakpoint settings.\n * This happens right after component initialization.\n */\n\n Object.assign(settings, Breakpoints.match(points));\n /**\n * Update glide with settings of matched brekpoint:\n * - window resize to update slider\n */\n\n Binder.on('resize', window, throttle(function () {\n Glide.settings = mergeOptions(settings, Breakpoints.match(points));\n }, Glide.settings.throttle));\n /**\n * Resort and update default settings:\n * - on reinit via API, so breakpoint matching will be performed with options\n */\n\n Events.on('update', function () {\n points = sortBreakpoints(points);\n defaults = Object.assign({}, settings);\n });\n /**\n * Unbind resize listener:\n * - on destroying, to bring markup to its initial state\n */\n\n Events.on('destroy', function () {\n Binder.off('resize', window);\n });\n return Breakpoints;\n}\n\nvar COMPONENTS = {\n // Required\n Html: Html,\n Translate: Translate,\n Transition: Transition,\n Direction: Direction,\n Peek: Peek,\n Sizes: Sizes,\n Gaps: Gaps,\n Move: Move,\n Clones: Clones,\n Resize: Resize,\n Build: Build,\n Run: Run,\n // Optional\n Swipe: Swipe,\n Images: Images,\n Anchors: Anchors,\n Controls: Controls,\n Keyboard: Keyboard,\n Autoplay: Autoplay,\n Breakpoints: Breakpoints\n};\n\nvar Glide = /*#__PURE__*/function (_Core) {\n _inherits(Glide, _Core);\n\n var _super = _createSuper(Glide);\n\n function Glide() {\n _classCallCheck(this, Glide);\n\n return _super.apply(this, arguments);\n }\n\n _createClass(Glide, [{\n key: \"mount\",\n value: function mount() {\n var extensions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return _get(_getPrototypeOf(Glide.prototype), \"mount\", this).call(this, Object.assign({}, COMPONENTS, extensions));\n }\n }]);\n\n return Glide;\n}(Glide$1);\n\nexport { Glide as default };\n","import Glide from '@glidejs/glide';\r\n\r\nwindow.onload = function (e) {\r\n if (document.querySelector('.main-front-page')) {\r\n const slides = document.querySelectorAll('.vital-ses__figure');\r\n const nextButton = document.querySelector('.vital-ses__button--rigth');\r\n const prevButton = document.querySelector('.vital-ses__button--left');\r\n let currentSlide = 0;\r\n\r\n slides[0].classList.add('active')\r\n\r\n nextButton.addEventListener('click', () => {\r\n slides[currentSlide].classList.remove('active');\r\n currentSlide = (currentSlide + 1) % slides.length;\r\n slides[currentSlide].classList.add('active');\r\n updateButtonOpacity();\r\n });\r\n prevButton.addEventListener('click', () => {\r\n slides[currentSlide].classList.remove('active');\r\n currentSlide = (currentSlide - 1 + slides.length) % slides.length;\r\n slides[currentSlide].classList.add('active');\r\n updateButtonOpacity();\r\n });\r\n function updateButtonOpacity() {\r\n if (currentSlide == 0) {\r\n prevButton.style.opacity = 0;\r\n prevButton.style.pointerEvents = \"none\";\r\n } else {\r\n prevButton.style.opacity = 1;\r\n prevButton.style.pointerEvents = \"auto\";\r\n }\r\n if (currentSlide == slides.length - 1) {\r\n nextButton.style.opacity = 0;\r\n nextButton.style.pointerEvents = \"none\";\r\n } else {\r\n nextButton.style.opacity = 1;\r\n nextButton.style.pointerEvents = \"auto\";\r\n }\r\n }\r\n }\r\n if (document.querySelector('.main-about')) {\r\n const slides = document.querySelectorAll('.team__card');\r\n const nextButton = document.querySelector('.team__button--rigth');\r\n const prevButton = document.querySelector('.team__button--left');\r\n let currentSlide = 0;\r\n\r\n slides[0].classList.add('active')\r\n\r\n nextButton.addEventListener('click', () => {\r\n slides[currentSlide].classList.remove('active');\r\n currentSlide = (currentSlide + 1) % slides.length;\r\n slides[currentSlide].classList.add('active');\r\n updateButtonOpacity();\r\n });\r\n prevButton.addEventListener('click', () => {\r\n slides[currentSlide].classList.remove('active');\r\n currentSlide = (currentSlide - 1 + slides.length) % slides.length;\r\n slides[currentSlide].classList.add('active');\r\n updateButtonOpacity();\r\n });\r\n function updateButtonOpacity() {\r\n if (currentSlide == 0) {\r\n prevButton.style.opacity = 0;\r\n prevButton.style.pointerEvents = \"none\";\r\n } else {\r\n prevButton.style.opacity = 1;\r\n prevButton.style.pointerEvents = \"auto\";\r\n }\r\n if (currentSlide == slides.length - 1) {\r\n nextButton.style.opacity = 0;\r\n nextButton.style.pointerEvents = \"none\";\r\n } else {\r\n nextButton.style.opacity = 1;\r\n nextButton.style.pointerEvents = \"auto\";\r\n }\r\n }\r\n }\r\n}\r\n","import { AJAX_WP_Query } from 'ajax-wp-query';\r\nimport './components/index';\r\n\r\nwindow.addEventListener(\"DOMContentLoaded\", function () {\r\n const toggle = document.querySelector(\".toggle\");\r\n const toggleHamburguer = document.querySelector(\".toggle__hamburguer\");\r\n toggle.addEventListener(\"click\", () => {\r\n toggleHamburguer.classList.toggle(\"disable\");\r\n });\r\n});\r\nwindow.addEventListener('scroll', function () {\r\n const header = document.querySelector('header');\r\n header.classList.toggle('header-scroll', window.scrollY > 0);\r\n});\r\n\r\n","jQuery(document).ready(function($) {\r\n $('.carrusel-esc').slick({\r\n infinite: true,\r\n slidesToShow: 3, // Ajusta la cantidad de slides visibles en escritorio\r\n slidesToScroll: 1,\r\n prevArrow: '',\r\n nextArrow: '',\r\n });\r\n});\r\n\r\njQuery(document).ready(function($) {\r\n $('.carrusel-mov').slick({\r\n infinite: true,\r\n slidesToShow: 1, // Ajusta la cantidad de slides visibles en escritorio\r\n slidesToScroll: 1,\r\n prevArrow: '',\r\n nextArrow: '',\r\n });\r\n});","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t260: 0,\n\t296: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkWikpis\"] = self[\"webpackChunkWikpis\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\n__webpack_require__.O(undefined, [296], function() { return __webpack_require__(46); })\nvar __webpack_exports__ = __webpack_require__.O(undefined, [296], function() { return __webpack_require__(781); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["deferred","SIDEBARJS","SIDEBARJS_CONTENT","IS_VISIBLE","IS_MOVING","POSITIONS","EVENT_LISTENER_OPTIONS","passive","TOUCH_START","TOUCH_MOVE","TOUCH_END","ELEMENT_ACTIONS","DEFAULT_CONFIG","documentMinSwipeX","documentSwipeRange","responsive","position","backdropOpacity","create","element","el","document","createElement","setAttribute","elemHasListener","elem","value","sidebarjsListener","forEachActionElement","sidebarName","func","i","length","action","elements","querySelectorAll","j","targetElementIsBackdrop","e","target","hasAttribute","shouldInvokeFunction","fn","SidebarElement","constructor","options","this","toggle","isVisible","close","open","addComponentClass","setBackdropOpacity","removeComponentClass","clearStyle","backdrop","_onTouchStart","initialTouch","touches","pageX","_onTouchMove","swipeDirection","clientX","container","clientWidth","hasLeftPosition","touchMoveSidebar","Math","abs","moveSidebar","_onTouchEnd","_onSwipeOpenStart","touchPositionX","body","_onSwipeOpenMove","documentSwiped","swipeX","sidebarMovement","openMovement","_onSwipeOpenEnd","_onTransitionStart","getTransitionType","toggleTransitionClass","_onTransitionEnd","_wasVisible","_emitOnOpen","_emitOnClose","_emitOnChangeVisibility","nativeGestures","Map","nativeOpenGestures","config","Object","assign","hasCustomTransclude","mainContent","component","querySelector","nativeSwipe","nativeSwipeOpen","isStyleMapSupported","Boolean","window","CSS","number","backdropOpacityRatio","onOpen","onClose","onChangeVisibility","transcludeContent","Error","setSwipeGestures","setResponsive","setPosition","addAttrsEventsListeners","getAttribute","addTransitionListener","addEventListener","classList","contains","destroy","removeNativeGestures","removeEventListener","removeNativeOpenGestures","removeAttrsEventsListeners","removeComponentClassPosition","firstElementChild","appendChild","removeChild","keys","forEach","key","indexOf","resetMainContent","add","setTimeout","addNativeGestures","addNativeOpenGestures","isStart","toggleComponentClass","remove","hasRightPosition","firstChild","event","movement","applyStyle","updateBackdropOpacity","opacity","toString","prop","val","vendorify","attributeStyleMap","set","style","vendor","charAt","toUpperCase","slice","clear","removeAttribute","className","force","$","jQuery","ready","menuResponsive","menuResponsiveMarkup","menuResponsiveButton","menuResponsiveItemsWithChildren","css","click","append","hasClass","siblings","addClass","removeClass","toggleClass","opts","defineProperty","get","CONTROLS_SELECTOR","concat","onload","updateButtonOpacity","currentSlide","prevButton","pointerEvents","slides","nextButton","toggleHamburguer","scrollY","slick","infinite","slidesToShow","slidesToScroll","prevArrow","nextArrow","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","m","O","result","chunkIds","priority","notFulfilled","Infinity","fulfilled","every","splice","r","o","obj","prototype","hasOwnProperty","call","installedChunks","chunkId","webpackJsonpCallback","parentChunkLoadingFunction","data","moreModules","runtime","some","id","chunkLoadingGlobal","self","bind","push","__webpack_exports__"],"sourceRoot":""}