{"version":3,"sources":["webpack:///./node_modules/@splidejs/splide/dist/js/splide.esm.js","webpack:///./node_modules/@splidejs/vue-splide/src/js/components/Splide.vue","webpack:///./node_modules/@splidejs/vue-splide/src/js/constants/events.js","webpack:///./node_modules/@splidejs/vue-splide/src/js/components/Splide.vue?c5be","webpack:///./node_modules/@splidejs/vue-splide/src/js/components/SplideSlide.vue","webpack:///./node_modules/@splidejs/vue-splide/src/js/components/SplideSlide.vue?74a6","webpack:///./src/view/uiElements/ui-elements-styled.js"],"names":["root","factory","module","exports","self","__webpack_modules__","311","__unused_webpack_module","__webpack_exports__","__webpack_require__","r","d","module_Splide","states_namespaceObject","CREATED","DESTROYED","IDLE","MOUNTED","MOVING","core_event","data","Event","on","events","handler","elm","options","split","forEach","event","addEventListener","push","off","filter","item","unsubscribe","emit","_len","arguments","length","args","Array","_key","apply","destroy","removeEventListener","state","initialState","curr","set","is","_extends","Object","assign","target","i","source","key","prototype","hasOwnProperty","call","this","keys","each","obj","callback","some","index","values","map","isObject","subject","merge","_ref","from","to","value","object_assign","defineProperty","getOwnPropertyDescriptor","toArray","isArray","between","m1","m2","Math","min","max","sprintf","format","replacements","replace","unit","type","parseFloat","pad","number","toPixel","div","create","applyStyle","position","width","append","clientWidth","dom_remove","find","selector","querySelector","child","parent","tagOrClassName","children","hasClass","tagName","tag","attrs","document","createElement","setAttribute","domify","html","innerHTML","firstChild","elms","parentElement","removeChild","appendChild","before","ref","insertBefore","styles","prop","style","addOrRemoveClasses","classes","remove","name","classList","addClass","removeClass","className","contains","getAttribute","removeAttribute","names","getRect","getBoundingClientRect","loaded","images","querySelectorAll","count","img","onload","onerror","SLIDE","LOOP","FADE","slide","Splide","Components","list","endCallback","mount","Elements","e","start","destIndex","newIndex","prevIndex","coord","done","edgeIndex","Controller","speed","rewindSpeed","transition","easing","transform","x","y","fade","Fade","track","height","clientHeight","setTimeout","slides","compose","Transition","components","Component","toLowerCase","MESSAGE_PREFIX","error","message","console","exist","Error","ROOT","ELEMENT_CLASSES","slider","container","arrows","arrow","prev","next","pagination","page","clone","progress","bar","autoplay","play","pause","spinner","sr","STATUS_CLASSES","active","visible","loading","I18N","first","last","slideX","pageX","DEFAULTS","rewind","waitForTransition","fixedWidth","fixedHeight","heightRatio","autoWidth","autoHeight","perPage","perMove","clones","focus","gap","padding","arrowPath","interval","pauseOnHover","pauseOnFocus","resetProgress","lazyLoad","preloadPages","keyboard","drag","dragAngleThreshold","swipeDistanceThreshold","flickVelocityThreshold","flickPower","flickMaxPages","direction","cover","accessibility","slideFocus","isNavigation","trimSpace","updateOnMove","throttle","breakpoints","i18n","_defineProperties","props","descriptor","enumerable","configurable","writable","_createClass","Constructor","protoProps","staticProps","Element","State","STATES","_o","_i","_c","_e","_t","_proto","Extensions","_this","component","required","undefined","mounted","visibility","sync","splide","sibling","_this$Event","concat","go","control","wait","add","refresh","bind","completely","_this2","reverse","get","parseInt","created","JSON","parse","RTL","TTB","STYLE_RESTORE_EVENTS","elements_slide","realIndex","STATUS_UPDATE_EVENTS","Slide","isClone","id","update","restoreStyles","_update","display","isActive","isVisible","ceil","trackRect","slideRect","top","bottom","left","right","isWithin","within","diff","abs","forVisibility","UID_NAME","components_elements","Slides","window","uid","init","getClasses","collect","register","SlideObject","getSlide","getSlides","includeClones","getSlidesByPage","idx","toIndex","splice","findParts","rootClass","floor","controller","isLoop","silently","trim","Track","matches","String","match","indicator","parsePage","hasFocus","pageLength","toPage","edge","isRtl","newOptions","sign","Layout","isVertical","isFade","isRTL","isLoopPending","jump","newPosition","getTrimmedPosition","toCoord","onTransitionEnd","translate","cancel","shift","toPosition","innerSize","totalSize","size","minDistance","Infinity","slideIndex","distance","slideSize","offset","cloneCount","Clones","getCloneCount","generateClones","slice","cloneDeeply","baseCount","dimension","fixedSize","cloneNode","horizontal","margin","resize","paddingLeft","paddingRight","totalWidth","listRect","slideWidth","offsetWidth","slideHeight","vertical","paddingTop","paddingBottom","totalHeight","offsetHeight","func","timeout","createInterval","elapse","rate","_window","requestAnimationFrame","_pause","step","timestamp","reset","layout","maxWidth","drag_abs","MIN_VELOCITY","FRICTION_REDUCER","startCoord","startInfo","currentInfo","isDragging","axis","Drag","disabled","move","passive","end","preventDefault","analyze","cancelable","resist","shouldMove","angle","atan","PI","_start","_end","log","info","velocity","absV","destination","timeStamp","touches","_ref2","clientX","clientY","_ref3","_ref3$x","fromX","_ref3$y","fromY","startTime","time","duration","click","Click","onClick","capture","stopPropagation","stopImmediatePropagation","PAUSE_FLAGS","HOVER","FOCUS","MANUAL","flags","Autoplay","flag","f","indexOf","switchOn","Cover","uncover","src","background","XML_NAME_SPACE","PATH","SIZE","Arrows","createArrow","appendArrows","updateDisabled","_Components$Controlle","nextIndex","isEnough","wrapper","firstElementChild","ATTRIBUTES_UPDATE_EVENT","UPDATE_EVENT","Pagination","createPagination","updateAttributes","getItem","items","button","li","SRC_DATA_NAME","SRCSET_DATA_NAME","lazyload","isSequential","Lazyload","srcset","loadNext","check","isNaN","image","load","ARIA_CURRENRT","ARIA_CONTROLS","ARIA_LABEL","ARIA_HIDDEN","TAB_INDEX","KEY_MAP","ltr","ArrowLeft","ArrowRight","Left","Right","rtl","ttb","ArrowUp","ArrowDown","Up","Down","a11y","allAttributes","A11y","updateSlide","initArrows","updateArrows","initPagination","updatePagination","initNavigation","updateNavigation","initAutoplay","controls","prevLabel","nextLabel","activeItem","text","label","join","isButton","main","mainSlide","SYNC_EVENT","CLICK_EVENTS","TRIGGER_KEYS","Sync","syncMain","syncSibling","moveSibling","THROTTLE","initialOptions","prevPoint","throttledCheck","Breakpoints","matchMedia","sort","n","m","point","mql","getPoint","COMPLETE","Options","LazyLoad","Keyboard","_inheritsLoose","subClass","superClass","constructor","__proto__","_Core","__webpack_module_cache__","moduleId","definition","o","Symbol","toStringTag","class","_createElementBlock","_hoisted_1","$props","hasSliderWrapper","_hoisted_2","_createElementVNode","_hoisted_3","_hoisted_4","_renderSlot","_ctx","$slots","_hoisted_5","_hoisted_6","EVENTS","default","Boolean","extensions","Function","$el","beforeDestroy","watch","remount","computed","methods","$emit","$nextTick","__exports__","render","Styled","theme","CardStyleWrapper"],"mappings":"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","file":"js/chunk-63574628.39bb70ca.js","sourcesContent":["/*!\n * Splide.js\n * Version : 2.4.20\n * License : MIT\n * Copyright: 2020 Naotoshi Fujita\n */\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Splide\"] = factory();\n\telse\n\t\troot[\"Splide\"] = factory();\n})(self, function() {\nreturn /******/ (() => { // webpackBootstrap\n/******/ \t\"use strict\";\n/******/ \tvar __webpack_modules__ = ({\n\n/***/ 311:\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => /* binding */ module_Splide\n});\n\n// NAMESPACE OBJECT: ./src/js/constants/states.js\nvar states_namespaceObject = {};\n__webpack_require__.r(states_namespaceObject);\n__webpack_require__.d(states_namespaceObject, {\n \"CREATED\": () => CREATED,\n \"DESTROYED\": () => DESTROYED,\n \"IDLE\": () => IDLE,\n \"MOUNTED\": () => MOUNTED,\n \"MOVING\": () => MOVING\n});\n\n;// CONCATENATED MODULE: ./src/js/core/event.js\n/**\r\n * The function for providing an Event object simply managing events.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * The function for providing an Event object simply managing events.\r\n */\n/* harmony default export */ const core_event = (function () {\n /**\r\n * Store all event data.\r\n *\r\n * @type {Array}\r\n */\n var data = [];\n var Event = {\n /**\r\n * Subscribe the given event(s).\r\n *\r\n * @param {string} events - An event name. Use space to separate multiple events.\r\n * Also, namespace is accepted by dot, such as 'resize.{namespace}'.\r\n * @param {function} handler - A callback function.\r\n * @param {Element} elm - Optional. Native event will be listened to when this arg is provided.\r\n * @param {Object} options - Optional. Options for addEventListener.\r\n */\n on: function on(events, handler, elm, options) {\n if (elm === void 0) {\n elm = null;\n }\n\n if (options === void 0) {\n options = {};\n }\n\n events.split(' ').forEach(function (event) {\n if (elm) {\n elm.addEventListener(event, handler, options);\n }\n\n data.push({\n event: event,\n handler: handler,\n elm: elm,\n options: options\n });\n });\n },\n\n /**\r\n * Unsubscribe the given event(s).\r\n *\r\n * @param {string} events - A event name or names split by space.\r\n * @param {Element} elm - Optional. removeEventListener() will be called when this arg is provided.\r\n */\n off: function off(events, elm) {\n if (elm === void 0) {\n elm = null;\n }\n\n events.split(' ').forEach(function (event) {\n data = data.filter(function (item) {\n if (item && item.event === event && item.elm === elm) {\n unsubscribe(item);\n return false;\n }\n\n return true;\n });\n });\n },\n\n /**\r\n * Emit an event.\r\n * This method is only for custom events.\r\n *\r\n * @param {string} event - An event name.\r\n * @param {*} args - Any number of arguments passed to handlers.\r\n */\n emit: function emit(event) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n data.forEach(function (item) {\n if (!item.elm && item.event.split('.')[0] === event) {\n item.handler.apply(item, args);\n }\n });\n },\n\n /**\r\n * Clear event data.\r\n */\n destroy: function destroy() {\n data.forEach(unsubscribe);\n data = [];\n }\n };\n /**\r\n * Remove the registered event listener.\r\n *\r\n * @param {Object} item - An object containing event data.\r\n */\n\n function unsubscribe(item) {\n if (item.elm) {\n item.elm.removeEventListener(item.event, item.handler, item.options);\n }\n }\n\n return Event;\n});\n;// CONCATENATED MODULE: ./src/js/core/state.js\n/**\r\n * The function providing a super simple state system.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * The function providing a super simple state system.\r\n *\r\n * @param {string|number} initialState - Provide the initial state value.\r\n */\n/* harmony default export */ const state = (function (initialState) {\n /**\r\n * Store the current state.\r\n *\r\n * @type {string|number}\r\n */\n var curr = initialState;\n return {\n /**\r\n * Change state.\r\n *\r\n * @param {string|number} state - A new state.\r\n */\n set: function set(state) {\n curr = state;\n },\n\n /**\r\n * Verify if the current state is given one or not.\r\n *\r\n * @param {string|number} state - A state name to be verified.\r\n *\r\n * @return {boolean} - True if the current state is the given one.\r\n */\n is: function is(state) {\n return state === curr;\n }\n };\n});\n;// CONCATENATED MODULE: ./src/js/utils/object.js\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n/**\r\n * Some utility functions related with Object, supporting IE.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\nvar keys = Object.keys;\n/**\r\n * Iterate an object like Array.forEach.\r\n * IE doesn't support forEach of HTMLCollection.\r\n *\r\n * @param {Object} obj - An object.\r\n * @param {function} callback - A function handling each value. Arguments are value, property and index.\r\n */\n\nfunction each(obj, callback) {\n keys(obj).some(function (key, index) {\n return callback(obj[key], key, index);\n });\n}\n/**\r\n * Return values of the given object as an array.\r\n * IE doesn't support Object.values.\r\n *\r\n * @param {Object} obj - An object.\r\n *\r\n * @return {Array} - An array containing all values of the given object.\r\n */\n\nfunction values(obj) {\n return keys(obj).map(function (key) {\n return obj[key];\n });\n}\n/**\r\n * Check if the given subject is object or not.\r\n *\r\n * @param {*} subject - A subject to be verified.\r\n *\r\n * @return {boolean} - True if object, false otherwise.\r\n */\n\nfunction isObject(subject) {\n return typeof subject === 'object';\n}\n/**\r\n * Merge two objects deeply.\r\n *\r\n * @param {Object} to - An object where \"from\" is merged.\r\n * @param {Object} from - An object merged to \"to\".\r\n *\r\n * @return {Object} - A merged object.\r\n */\n\nfunction merge(_ref, from) {\n var to = _extends({}, _ref);\n\n each(from, function (value, key) {\n if (isObject(value)) {\n if (!isObject(to[key])) {\n to[key] = {};\n }\n\n to[key] = merge(to[key], value);\n } else {\n to[key] = value;\n }\n });\n return to;\n}\n/**\r\n * Assign all properties \"from\" to \"to\" object.\r\n *\r\n * @param {Object} to - An object where properties are assigned.\r\n * @param {Object} from - An object whose properties are assigned to \"to\".\r\n *\r\n * @return {Object} - An assigned object.\r\n */\n\nfunction object_assign(to, from) {\n keys(from).forEach(function (key) {\n if (!to[key]) {\n Object.defineProperty(to, key, Object.getOwnPropertyDescriptor(from, key));\n }\n });\n return to;\n}\n;// CONCATENATED MODULE: ./src/js/utils/utils.js\n/**\r\n * A package of some miscellaneous utility functions.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Convert the given value to array.\r\n *\r\n * @param {*} value - Any value.\r\n *\r\n * @return {*[]} - Array containing the given value.\r\n */\n\nfunction toArray(value) {\n return Array.isArray(value) ? value : [value];\n}\n/**\r\n * Check if the given value is between min and max.\r\n * Min will be returned when the value is less than min or max will do when greater than max.\r\n *\r\n * @param {number} value - A number to be checked.\r\n * @param {number} m1 - Minimum or maximum number.\r\n * @param {number} m2 - Maximum or minimum number.\r\n *\r\n * @return {number} - A value itself, min or max.\r\n */\n\nfunction between(value, m1, m2) {\n return Math.min(Math.max(value, m1 > m2 ? m2 : m1), m1 > m2 ? m1 : m2);\n}\n/**\r\n * The sprintf method with minimum functionality.\r\n *\r\n * @param {string} format - The string format.\r\n * @param {string|Array} replacements - Replacements accepting multiple arguments.\r\n *\r\n * @returns {string} - Converted string.\r\n */\n\nfunction sprintf(format, replacements) {\n var i = 0;\n return format.replace(/%s/g, function () {\n return toArray(replacements)[i++];\n });\n}\n/**\r\n * Append px unit to the given subject if necessary.\r\n *\r\n * @param {number|string} value - A value that may not include an unit.\r\n *\r\n * @return {string} - If the value is string, return itself.\r\n * If number, do value + \"px\". An empty string, otherwise.\r\n */\n\nfunction unit(value) {\n var type = typeof value;\n\n if (type === 'number' && value > 0) {\n return parseFloat(value) + 'px';\n }\n\n return type === 'string' ? value : '';\n}\n/**\r\n * Pad start with 0.\r\n *\r\n * @param {number} number - A number to be filled with 0.\r\n *\r\n * @return {string|number} - Padded number.\r\n */\n\nfunction pad(number) {\n return number < 10 ? '0' + number : number;\n}\n/**\r\n * Convert the given value to pixel.\r\n *\r\n * @param {Element} root - Root element where a dummy div is appended.\r\n * @param {string|number} value - CSS value to be converted, such as 10rem.\r\n *\r\n * @return {number} - Pixel.\r\n */\n\nfunction toPixel(root, value) {\n if (typeof value === 'string') {\n var div = create('div', {});\n applyStyle(div, {\n position: 'absolute',\n width: value\n });\n append(root, div);\n value = div.clientWidth;\n dom_remove(div);\n }\n\n return +value || 0;\n}\n;// CONCATENATED MODULE: ./src/js/utils/dom.js\n/**\r\n * Some utility functions related with DOM.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n/**\r\n * Find the first element matching the given selector.\r\n * Be aware that all selectors after a space are ignored.\r\n *\r\n * @param {Element|Node} elm - An ancestor element.\r\n * @param {string} selector - DOMString.\r\n *\r\n * @return {Element|null} - A found element or null.\r\n */\n\nfunction find(elm, selector) {\n return elm ? elm.querySelector(selector.split(' ')[0]) : null;\n}\n/**\r\n * Find a first child having the given tag or class name.\r\n *\r\n * @param {Element} parent - A parent element.\r\n * @param {string} tagOrClassName - A tag or class name.\r\n *\r\n * @return {Element|undefined} - A found element on success or undefined on failure.\r\n */\n\nfunction child(parent, tagOrClassName) {\n return children(parent, tagOrClassName)[0];\n}\n/**\r\n * Return chile elements that matches the provided tag or class name.\r\n *\r\n * @param {Element} parent - A parent element.\r\n * @param {string} tagOrClassName - A tag or class name.\r\n *\r\n * @return {Element[]} - Found elements.\r\n */\n\nfunction children(parent, tagOrClassName) {\n if (parent) {\n return values(parent.children).filter(function (child) {\n return hasClass(child, tagOrClassName.split(' ')[0]) || child.tagName === tagOrClassName;\n });\n }\n\n return [];\n}\n/**\r\n * Create an element with some optional attributes.\r\n *\r\n * @param {string} tag - A tag name.\r\n * @param {Object} attrs - An object any attribute pairs of name and value.\r\n *\r\n * @return {Element} - A created element.\r\n */\n\nfunction create(tag, attrs) {\n var elm = document.createElement(tag);\n each(attrs, function (value, key) {\n return setAttribute(elm, key, value);\n });\n return elm;\n}\n/**\r\n * Convert HTML string to DOM node.\r\n *\r\n * @param {string} html - HTML string.\r\n *\r\n * @return {Node} - A created node.\r\n */\n\nfunction domify(html) {\n var div = create('div', {});\n div.innerHTML = html;\n return div.firstChild;\n}\n/**\r\n * Remove a given element from a DOM tree.\r\n *\r\n * @param {Element|Element[]} elms - Element(s) to be removed.\r\n */\n\nfunction dom_remove(elms) {\n toArray(elms).forEach(function (elm) {\n if (elm) {\n var parent = elm.parentElement;\n parent && parent.removeChild(elm);\n }\n });\n}\n/**\r\n * Append a child to a given element.\r\n *\r\n * @param {Element} parent - A parent element.\r\n * @param {Element} child - An element to be appended.\r\n */\n\nfunction append(parent, child) {\n if (parent) {\n parent.appendChild(child);\n }\n}\n/**\r\n * Insert an element before the reference element.\r\n *\r\n * @param {Element|Node} ref - A reference element.\r\n * @param {Element} elm - An element to be inserted.\r\n */\n\nfunction before(elm, ref) {\n if (elm && ref) {\n var parent = ref.parentElement;\n parent && parent.insertBefore(elm, ref);\n }\n}\n/**\r\n * Apply styles to the given element.\r\n *\r\n * @param {Element} elm - An element where styles are applied.\r\n * @param {Object} styles - Object containing styles.\r\n */\n\nfunction applyStyle(elm, styles) {\n if (elm) {\n each(styles, function (value, prop) {\n if (value !== null) {\n elm.style[prop] = value;\n }\n });\n }\n}\n/**\r\n * Add or remove classes to/from the element.\r\n * This function is for internal usage.\r\n *\r\n * @param {Element} elm - An element where classes are added.\r\n * @param {string|string[]} classes - Class names being added.\r\n * @param {boolean} remove - Whether to remove or add classes.\r\n */\n\nfunction addOrRemoveClasses(elm, classes, remove) {\n if (elm) {\n toArray(classes).forEach(function (name) {\n if (name) {\n elm.classList[remove ? 'remove' : 'add'](name);\n }\n });\n }\n}\n/**\r\n * Add classes to the element.\r\n *\r\n * @param {Element} elm - An element where classes are added.\r\n * @param {string|string[]} classes - Class names being added.\r\n */\n\n\nfunction addClass(elm, classes) {\n addOrRemoveClasses(elm, classes, false);\n}\n/**\r\n * Remove a class from the element.\r\n *\r\n * @param {Element} elm - An element where classes are removed.\r\n * @param {string|string[]} classes - A class name being removed.\r\n */\n\nfunction removeClass(elm, classes) {\n addOrRemoveClasses(elm, classes, true);\n}\n/**\r\n * Verify if the provided element has the class or not.\r\n *\r\n * @param {Element} elm - An element.\r\n * @param {string} className - A class name.\r\n *\r\n * @return {boolean} - True if the element has the class or false if not.\r\n */\n\nfunction hasClass(elm, className) {\n return !!elm && elm.classList.contains(className);\n}\n/**\r\n * Set attribute to the given element.\r\n *\r\n * @param {Element} elm - An element where an attribute is assigned.\r\n * @param {string} name - Attribute name.\r\n * @param {string|number|boolean} value - Attribute value.\r\n */\n\nfunction setAttribute(elm, name, value) {\n if (elm) {\n elm.setAttribute(name, value);\n }\n}\n/**\r\n * Get attribute from the given element.\r\n *\r\n * @param {Element} elm - An element where an attribute is assigned.\r\n * @param {string} name - Attribute name.\r\n *\r\n * @return {string} - The value of the given attribute if available. An empty string if not.\r\n */\n\nfunction getAttribute(elm, name) {\n return elm ? elm.getAttribute(name) : '';\n}\n/**\r\n * Remove attribute from the given element.\r\n *\r\n * @param {Element|Element[]} elms - An element where an attribute is removed.\r\n * @param {string|string[]} names - Attribute name.\r\n */\n\nfunction removeAttribute(elms, names) {\n toArray(names).forEach(function (name) {\n toArray(elms).forEach(function (elm) {\n return elm && elm.removeAttribute(name);\n });\n });\n}\n/**\r\n * Return the Rect object of the provided object.\r\n *\r\n * @param {Element} elm - An element.\r\n *\r\n * @return {ClientRect|DOMRect} - A rect object.\r\n */\n\nfunction getRect(elm) {\n return elm.getBoundingClientRect();\n}\n/**\r\n * Trigger the given callback after all images contained by the element are loaded.\r\n *\r\n * @param {Element} elm - Element that may contain images.\r\n * @param {Function} callback - Callback function fired right after all images are loaded.\r\n */\n\nfunction loaded(elm, callback) {\n var images = elm.querySelectorAll('img');\n var length = images.length;\n\n if (length) {\n var count = 0;\n each(images, function (img) {\n img.onload = img.onerror = function () {\n if (++count === length) {\n callback();\n }\n };\n });\n } else {\n // Trigger the callback immediately if there is no image.\n callback();\n }\n}\n;// CONCATENATED MODULE: ./src/js/constants/types.js\n/**\r\n * Export slider types.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Normal slider.\r\n *\r\n * @type {string}\r\n */\nvar SLIDE = 'slide';\n/**\r\n * Loop after the last slide and before the first one.\r\n *\r\n * @type {string}\r\n */\n\nvar LOOP = 'loop';\n/**\r\n * The track doesn't move.\r\n *\r\n * @type {string}\r\n */\n\nvar FADE = 'fade';\n;// CONCATENATED MODULE: ./src/js/transitions/slide/index.js\n/**\r\n * The component for general slide effect transition.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n/**\r\n * The component for general slide effect transition.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const slide = (function (Splide, Components) {\n /**\r\n * Hold the list element.\r\n *\r\n * @type {Element}\r\n */\n var list;\n /**\r\n * Hold the onEnd callback function.\r\n *\r\n * @type {function}\r\n */\n\n var endCallback;\n return {\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n list = Components.Elements.list;\n Splide.on('transitionend', function (e) {\n if (e.target === list && endCallback) {\n endCallback();\n }\n }, list);\n },\n\n /**\r\n * Start transition.\r\n *\r\n * @param {number} destIndex - Destination slide index that might be clone's.\r\n * @param {number} newIndex - New index.\r\n * @param {number} prevIndex - Previous index.\r\n * @param {Object} coord - Destination coordinates.\r\n * @param {function} done - Callback function must be invoked when transition is completed.\r\n */\n start: function start(destIndex, newIndex, prevIndex, coord, done) {\n var options = Splide.options;\n var edgeIndex = Components.Controller.edgeIndex;\n var speed = options.speed;\n endCallback = done;\n\n if (Splide.is(SLIDE)) {\n if (prevIndex === 0 && newIndex >= edgeIndex || prevIndex >= edgeIndex && newIndex === 0) {\n speed = options.rewindSpeed || speed;\n }\n }\n\n applyStyle(list, {\n transition: \"transform \" + speed + \"ms \" + options.easing,\n transform: \"translate(\" + coord.x + \"px,\" + coord.y + \"px)\"\n });\n }\n };\n});\n;// CONCATENATED MODULE: ./src/js/transitions/fade/index.js\n/**\r\n * The component for fade transition.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n/**\r\n * The component for fade transition.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const fade = (function (Splide, Components) {\n var Fade = {\n /**\r\n * Called when the component is mounted.\r\n * Apply transition style to the first slide.\r\n */\n mount: function mount() {\n apply(Splide.index);\n },\n\n /**\r\n * Start transition.\r\n *\r\n * @param {number} destIndex - Destination slide index that might be clone's.\r\n * @param {number} newIndex - New index.\r\n * @param {number} prevIndex - Previous index.\r\n * @param {Object} coord - Destination coordinates.\r\n * @param {function} done - Callback function must be invoked when transition is completed.\r\n */\n start: function start(destIndex, newIndex, prevIndex, coord, done) {\n var track = Components.Elements.track;\n applyStyle(track, {\n height: unit(track.clientHeight)\n });\n apply(newIndex);\n setTimeout(function () {\n done();\n applyStyle(track, {\n height: ''\n });\n });\n }\n };\n /**\r\n * Apply transition style to the slide specified by the given index.\r\n *\r\n * @param {number} index - A slide index.\r\n */\n\n function apply(index) {\n var options = Splide.options;\n applyStyle(Components.Elements.slides[index], {\n transition: \"opacity \" + options.speed + \"ms \" + options.easing\n });\n }\n\n return Fade;\n});\n;// CONCATENATED MODULE: ./src/js/transitions/index.js\n/**\r\n * Export transition components.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n;// CONCATENATED MODULE: ./src/js/core/composer.js\n/**\r\n * Provide a function for composing components.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n/**\r\n * Compose components.\r\n *\r\n * @param {Splide} Splide - Splide instance.\r\n * @param {Object} Components - Additional components.\r\n * @param {function} Transition - Change component for transition.\r\n *\r\n * @return {Object} - An object containing all components.\r\n */\n\nfunction compose(Splide, Components, Transition) {\n var components = {};\n each(Components, function (Component, name) {\n components[name] = Component(Splide, components, name.toLowerCase());\n });\n\n if (!Transition) {\n Transition = Splide.is(FADE) ? fade : slide;\n }\n\n components.Transition = Transition(Splide, components);\n return components;\n}\n;// CONCATENATED MODULE: ./src/js/utils/error.js\n/**\r\n * Utility functions for outputting logs.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Prefix of an error massage.\r\n *\r\n * @type {string}\r\n */\nvar MESSAGE_PREFIX = '[SPLIDE]';\n/**\r\n * Display an error message on the browser console.\r\n *\r\n * @param {string} message - An error message.\r\n */\n\nfunction error(message) {\n console.error(MESSAGE_PREFIX + \" \" + message);\n}\n/**\r\n * Check existence of the given object and throw an error if it doesn't.\r\n *\r\n * @throws {Error}\r\n *\r\n * @param {*} subject - A subject to be confirmed.\r\n * @param {string} message - An error message.\r\n */\n\nfunction exist(subject, message) {\n if (!subject) {\n throw new Error(message);\n }\n}\n;// CONCATENATED MODULE: ./src/js/constants/classes.js\n/**\r\n * Export class names.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * A root class name.\r\n *\r\n * @type {string}\r\n */\nvar ROOT = 'splide';\n/**\r\n * The definition table of all classes for elements.\r\n * They might be modified by options.\r\n *\r\n * @type {Object}\r\n */\n\nvar ELEMENT_CLASSES = {\n root: ROOT,\n slider: ROOT + \"__slider\",\n track: ROOT + \"__track\",\n list: ROOT + \"__list\",\n slide: ROOT + \"__slide\",\n container: ROOT + \"__slide__container\",\n arrows: ROOT + \"__arrows\",\n arrow: ROOT + \"__arrow\",\n prev: ROOT + \"__arrow--prev\",\n next: ROOT + \"__arrow--next\",\n pagination: ROOT + \"__pagination\",\n page: ROOT + \"__pagination__page\",\n clone: ROOT + \"__slide--clone\",\n progress: ROOT + \"__progress\",\n bar: ROOT + \"__progress__bar\",\n autoplay: ROOT + \"__autoplay\",\n play: ROOT + \"__play\",\n pause: ROOT + \"__pause\",\n spinner: ROOT + \"__spinner\",\n sr: ROOT + \"__sr\"\n};\n/**\r\n * Definitions of status classes.\r\n *\r\n * @type {Object}\r\n */\n\nvar STATUS_CLASSES = {\n active: 'is-active',\n visible: 'is-visible',\n loading: 'is-loading'\n};\n;// CONCATENATED MODULE: ./src/js/constants/i18n.js\n/**\r\n * Export i18n texts as object.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Texts for i18n.\r\n *\r\n * @type {Object}\r\n */\nvar I18N = {\n prev: 'Previous slide',\n next: 'Next slide',\n first: 'Go to first slide',\n last: 'Go to last slide',\n slideX: 'Go to slide %s',\n pageX: 'Go to page %s',\n play: 'Start autoplay',\n pause: 'Pause autoplay'\n};\n;// CONCATENATED MODULE: ./src/js/constants/defaults.js\n/**\r\n * Export default options.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\nvar DEFAULTS = {\n /**\r\n * Determine a slider type.\r\n * - 'slide': Regular slider.\r\n * - 'loop' : Carousel slider.\r\n * - 'fade' : Change slides with fade transition. perPage, drag options are ignored.\r\n *\r\n * @type {string}\r\n */\n type: 'slide',\n\n /**\r\n * Whether to rewind a slider before the first slide or after the last one.\r\n * In \"loop\" mode, this option is ignored.\r\n *\r\n * @type {boolean}\r\n */\n rewind: false,\n\n /**\r\n * Transition speed in milliseconds.\r\n *\r\n * @type {number}\r\n */\n speed: 400,\n\n /**\r\n * Transition speed on rewind in milliseconds.\r\n *\r\n * @type {number}\r\n */\n rewindSpeed: 0,\n\n /**\r\n * Whether to prevent any actions while a slider is transitioning.\r\n * If false, navigation, drag and swipe work while the slider is running.\r\n * Even so, it will be forced to wait for transition in some cases in the loop mode to shift a slider.\r\n *\r\n * @type {boolean}\r\n */\n waitForTransition: true,\n\n /**\r\n * Define slider max width.\r\n *\r\n * @type {number}\r\n */\n width: 0,\n\n /**\r\n * Define slider height.\r\n *\r\n * @type {number}\r\n */\n height: 0,\n\n /**\r\n * Fix width of slides. CSS format is allowed such as 10em, 80% or 80vw.\r\n * perPage number will be ignored when this option is falsy.\r\n *\r\n * @type {number|string}\r\n */\n fixedWidth: 0,\n\n /**\r\n * Fix height of slides. CSS format is allowed such as 10em, 80vh but % unit is not accepted.\r\n * heightRatio option will be ignored when this option is falsy.\r\n *\r\n * @type {number|string}\r\n */\n fixedHeight: 0,\n\n /**\r\n * Determine height of slides by ratio to a slider width.\r\n * This will be ignored when the fixedHeight is provided.\r\n *\r\n * @type {number}\r\n */\n heightRatio: 0,\n\n /**\r\n * If true, slide width will be determined by the element width itself.\r\n * - perPage/perMove should be 1.\r\n *\r\n * @type {boolean}\r\n */\n autoWidth: false,\n\n /**\r\n * If true, slide height will be determined by the element width itself.\r\n * - perPage/perMove should be 1.\r\n *\r\n * @type {boolean}\r\n */\n autoHeight: false,\n\n /**\r\n * Determine how many slides should be displayed per page.\r\n *\r\n * @type {number}\r\n */\n perPage: 1,\n\n /**\r\n * Determine how many slides should be moved when a slider goes to next or perv.\r\n *\r\n * @type {number}\r\n */\n perMove: 0,\n\n /**\r\n * Determine manually how many clones should be generated on the left and right side.\r\n * The total number of clones will be twice of this number.\r\n *\r\n * @type {number}\r\n */\n clones: 0,\n\n /**\r\n * Start index.\r\n *\r\n * @type {number}\r\n */\n start: 0,\n\n /**\r\n * Determine which slide should be focused if there are multiple slides in a page.\r\n * A string \"center\" is acceptable for centering slides.\r\n *\r\n * @type {boolean|number|string}\r\n */\n focus: false,\n\n /**\r\n * Gap between slides. CSS format is allowed such as 1em.\r\n *\r\n * @type {number|string}\r\n */\n gap: 0,\n\n /**\r\n * Set padding-left/right in horizontal mode or padding-top/bottom in vertical one.\r\n * Give a single value to set a same size for both sides or\r\n * do an object for different sizes.\r\n * Also, CSS format is allowed such as 1em.\r\n *\r\n * @example\r\n * - 10: Number\r\n * - '1em': CSS format.\r\n * - { left: 0, right: 20 }: Object for different sizes in horizontal mode.\r\n * - { top: 0, bottom: 20 }: Object for different sizes in vertical mode.\r\n *\r\n * @type {number|string|Object}\r\n */\n padding: 0,\n\n /**\r\n * Whether to append arrows.\r\n *\r\n * @type {boolean}\r\n */\n arrows: true,\n\n /**\r\n * Change the arrow SVG path like 'm7.61 0.807-2.12...'.\r\n *\r\n * @type {string}\r\n */\n arrowPath: '',\n\n /**\r\n * Whether to append pagination(indicator dots) or not.\r\n *\r\n * @type {boolean}\r\n */\n pagination: true,\n\n /**\r\n * Activate autoplay.\r\n *\r\n * @type {boolean}\r\n */\n autoplay: false,\n\n /**\r\n * Autoplay interval in milliseconds.\r\n *\r\n * @type {number}\r\n */\n interval: 5000,\n\n /**\r\n * Whether to stop autoplay when a slider is hovered.\r\n *\r\n * @type {boolean}\r\n */\n pauseOnHover: true,\n\n /**\r\n * Whether to stop autoplay when a slider elements are focused.\r\n * True is recommended for accessibility.\r\n *\r\n * @type {boolean}\r\n */\n pauseOnFocus: true,\n\n /**\r\n * Whether to reset progress of the autoplay timer when resumed.\r\n *\r\n * @type {boolean}\r\n */\n resetProgress: true,\n\n /**\r\n * Loading images lazily.\r\n * Image src must be provided by a data-splide-lazy attribute.\r\n *\r\n * - false: Do nothing.\r\n * - 'nearby': Only images around an active slide will be loaded.\r\n * - 'sequential': All images will be sequentially loaded.\r\n *\r\n * @type {boolean|string}\r\n */\n lazyLoad: false,\n\n /**\r\n * This option works only when a lazyLoad option is \"nearby\".\r\n * Determine how many pages(not slides) around an active slide should be loaded beforehand.\r\n *\r\n * @type {number}\r\n */\n preloadPages: 1,\n\n /**\r\n * Easing for CSS transition. For example, linear, ease or cubic-bezier().\r\n *\r\n * @type {string}\r\n */\n easing: 'cubic-bezier(.42,.65,.27,.99)',\n\n /**\r\n * Whether to enable keyboard shortcuts\r\n * - true or 'global': Listen to keydown event of the document.\r\n * - 'focused': Listen to the keydown event of the slider root element. tabindex=\"0\" will be added to the element.\r\n * - false: Disable keyboard shortcuts.\r\n *\r\n * @type {boolean|string}\r\n */\n keyboard: 'global',\n\n /**\r\n * Whether to allow mouse drag and touch swipe.\r\n *\r\n * @type {boolean}\r\n */\n drag: true,\n\n /**\r\n * The angle threshold for drag.\r\n * The slider starts moving only when the drag angle is less than this threshold.\r\n *\r\n * @type {number}\r\n */\n dragAngleThreshold: 30,\n\n /**\r\n * Distance threshold for determining if the action is \"flick\" or \"swipe\".\r\n * When a drag distance is over this value, the action will be treated as \"swipe\", not \"flick\".\r\n *\r\n * @type {number}\r\n */\n swipeDistanceThreshold: 150,\n\n /**\r\n * Velocity threshold for determining if the action is \"flick\" or \"swipe\".\r\n * Around 0.5 is recommended.\r\n *\r\n * @type {number}\r\n */\n flickVelocityThreshold: .6,\n\n /**\r\n * Determine power of flick. The larger number this is, the farther a slider runs by flick.\r\n * Around 500 is recommended.\r\n *\r\n * @type {number}\r\n */\n flickPower: 600,\n\n /**\r\n * Limit a number of pages to move by flick.\r\n *\r\n * @type {number}\r\n */\n flickMaxPages: 1,\n\n /**\r\n * Slider direction.\r\n * - 'ltr': Left to right.\r\n * - 'rtl': Right to left.\r\n * - 'ttb': Top to bottom.\r\n *\r\n * @type {string}\r\n */\n direction: 'ltr',\n\n /**\r\n * Set img src to background-image of its parent element.\r\n * Images with various sizes can be displayed as same dimension without cropping work.\r\n * fixedHeight or heightRatio is required.\r\n *\r\n * @type {boolean}\r\n */\n cover: false,\n\n /**\r\n * Whether to enable accessibility(aria and screen reader texts) or not.\r\n *\r\n * @type {boolean}\r\n */\n accessibility: true,\n\n /**\r\n * Whether to add tabindex=\"0\" to visible slides or not.\r\n *\r\n * @type {boolean}\r\n */\n slideFocus: true,\n\n /**\r\n * Determine if a slider is navigation for another.\r\n * Use \"sync\" API to synchronize two sliders.\r\n *\r\n * @type {boolean}\r\n */\n isNavigation: false,\n\n /**\r\n * Whether to trim spaces before the fist slide or after the last one when \"focus\" is not 0.\r\n *\r\n * @type {boolean}\r\n */\n trimSpace: true,\n\n /**\r\n * The \"is-active\" class is added after transition as default.\r\n * If true, it will be added before move.\r\n *\r\n * @type {boolean}\r\n */\n updateOnMove: false,\n\n /**\r\n * Throttle duration in milliseconds for the resize event.\r\n *\r\n * @type {number}\r\n */\n throttle: 100,\n\n /**\r\n * Whether to destroy a slider or not.\r\n *\r\n * @type {boolean}\r\n */\n destroy: false,\n\n /**\r\n * Options for specific breakpoints.\r\n *\r\n * @example\r\n * {\r\n * 1000: {\r\n * perPage: 3,\r\n * gap: 20\r\n * },\r\n * 600: {\r\n * perPage: 1,\r\n * gap: 5,\r\n * }\r\n * }\r\n *\r\n * @type {boolean|Object}\r\n */\n breakpoints: false,\n\n /**\r\n * Collection of class names.\r\n *\r\n * @see ./classes.js\r\n *\r\n * @type {Object}\r\n */\n classes: ELEMENT_CLASSES,\n\n /**\r\n * Collection of i18n texts.\r\n *\r\n * @see ./i18n.js\r\n *\r\n * @type {Object}\r\n */\n i18n: I18N\n};\n;// CONCATENATED MODULE: ./src/js/constants/states.js\n/**\r\n * Export state constants.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Splide has been just created.\r\n *\r\n * @type {number}\r\n */\nvar CREATED = 1;\n/**\r\n * All components have been mounted and initialized.\r\n *\r\n * @type {number}\r\n */\n\nvar MOUNTED = 2;\n/**\r\n * Splide is ready for transition.\r\n *\r\n * @type {number}\r\n */\n\nvar IDLE = 3;\n/**\r\n * Splide is moving.\r\n *\r\n * @type {number}\r\n */\n\nvar MOVING = 4;\n/**\r\n * Splide is moving.\r\n *\r\n * @type {number}\r\n */\n\nvar DESTROYED = 5;\n;// CONCATENATED MODULE: ./src/js/splide.js\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n/**\r\n * The main class for applying Splide to an element.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\n\n\n\n/**\r\n * The main class for applying Splide to an element,\r\n * providing some APIs to control the behavior.\r\n */\n\nvar Splide = /*#__PURE__*/function () {\n /**\r\n * Splide constructor.\r\n *\r\n * @throws {Error} When the given root element or selector is invalid.\r\n *\r\n * @param {Element|string} root - A selector for a root element or an element itself.\r\n * @param {Object} options - Optional. Options to change default behaviour.\r\n * @param {Object} Components - Optional. Components.\r\n */\n function Splide(root, options, Components) {\n if (options === void 0) {\n options = {};\n }\n\n if (Components === void 0) {\n Components = {};\n }\n\n this.root = root instanceof Element ? root : document.querySelector(root);\n exist(this.root, 'An invalid element/selector was given.');\n this.Components = null;\n this.Event = core_event();\n this.State = state(CREATED);\n this.STATES = states_namespaceObject;\n this._o = merge(DEFAULTS, options);\n this._i = 0;\n this._c = Components;\n this._e = {}; // Extensions\n\n this._t = null; // Transition\n }\n /**\r\n * Compose and mount components.\r\n *\r\n * @param {Object} Extensions - Optional. Additional components.\r\n * @param {function} Transition - Optional. Set a custom transition component.\r\n *\r\n * @return {Splide|undefined} - This instance or undefined if an exception occurred.\r\n */\n\n\n var _proto = Splide.prototype;\n\n _proto.mount = function mount(Extensions, Transition) {\n var _this = this;\n\n if (Extensions === void 0) {\n Extensions = this._e;\n }\n\n if (Transition === void 0) {\n Transition = this._t;\n }\n\n // Reset the state.\n this.State.set(CREATED);\n this._e = Extensions;\n this._t = Transition;\n this.Components = compose(this, merge(this._c, Extensions), Transition);\n\n try {\n each(this.Components, function (component, key) {\n var required = component.required;\n\n if (required === undefined || required) {\n component.mount && component.mount();\n } else {\n delete _this.Components[key];\n }\n });\n } catch (e) {\n error(e.message);\n return;\n }\n\n var State = this.State;\n State.set(MOUNTED);\n each(this.Components, function (component) {\n component.mounted && component.mounted();\n });\n this.emit('mounted');\n State.set(IDLE);\n this.emit('ready');\n applyStyle(this.root, {\n visibility: 'visible'\n });\n this.on('move drag', function () {\n return State.set(MOVING);\n }).on('moved dragged', function () {\n return State.set(IDLE);\n });\n return this;\n }\n /**\r\n * Set sync target.\r\n *\r\n * @param {Splide} splide - A Splide instance.\r\n *\r\n * @return {Splide} - This instance.\r\n */\n ;\n\n _proto.sync = function sync(splide) {\n this.sibling = splide;\n return this;\n }\n /**\r\n * Register callback fired on the given event(s).\r\n *\r\n * @param {string} events - An event name. Use space to separate multiple events.\r\n * Also, namespace is accepted by dot, such as 'resize.{namespace}'.\r\n * @param {function} handler - A callback function.\r\n * @param {Element} elm - Optional. Native event will be listened to when this arg is provided.\r\n * @param {Object} options - Optional. Options for addEventListener.\r\n *\r\n * @return {Splide} - This instance.\r\n */\n ;\n\n _proto.on = function on(events, handler, elm, options) {\n if (elm === void 0) {\n elm = null;\n }\n\n if (options === void 0) {\n options = {};\n }\n\n this.Event.on(events, handler, elm, options);\n return this;\n }\n /**\r\n * Unsubscribe the given event.\r\n *\r\n * @param {string} events - A event name.\r\n * @param {Element} elm - Optional. removeEventListener() will be called when this arg is provided.\r\n *\r\n * @return {Splide} - This instance.\r\n */\n ;\n\n _proto.off = function off(events, elm) {\n if (elm === void 0) {\n elm = null;\n }\n\n this.Event.off(events, elm);\n return this;\n }\n /**\r\n * Emit an event.\r\n *\r\n * @param {string} event - An event name.\r\n * @param {*} args - Any number of arguments passed to handlers.\r\n */\n ;\n\n _proto.emit = function emit(event) {\n var _this$Event;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n (_this$Event = this.Event).emit.apply(_this$Event, [event].concat(args));\n\n return this;\n }\n /**\r\n * Go to the slide specified by the given control.\r\n *\r\n * @param {string|number} control - A control pattern.\r\n * @param {boolean} wait - Optional. Whether to wait for transition.\r\n */\n ;\n\n _proto.go = function go(control, wait) {\n if (wait === void 0) {\n wait = this.options.waitForTransition;\n }\n\n if (this.State.is(IDLE) || this.State.is(MOVING) && !wait) {\n this.Components.Controller.go(control, false);\n }\n\n return this;\n }\n /**\r\n * Verify whether the slider type is the given one or not.\r\n *\r\n * @param {string} type - A slider type.\r\n *\r\n * @return {boolean} - True if the slider type is the provided type or false if not.\r\n */\n ;\n\n _proto.is = function is(type) {\n return type === this._o.type;\n }\n /**\r\n * Insert a slide.\r\n *\r\n * @param {Element|string} slide - A slide element to be added.\r\n * @param {number} index - A slide will be added at the position.\r\n */\n ;\n\n _proto.add = function add(slide, index) {\n if (index === void 0) {\n index = -1;\n }\n\n this.Components.Elements.add(slide, index, this.refresh.bind(this));\n return this;\n }\n /**\r\n * Remove the slide designated by the index.\r\n *\r\n * @param {number} index - A slide index.\r\n */\n ;\n\n _proto.remove = function remove(index) {\n this.Components.Elements.remove(index);\n this.refresh();\n return this;\n }\n /**\r\n * Destroy all Slide objects and clones and recreate them again.\r\n */\n ;\n\n _proto.refresh = function refresh() {\n this.emit('refresh:before').emit('refresh').emit('resize');\n return this;\n }\n /**\r\n * Destroy the Splide.\r\n * \"Completely\" boolean is mainly for breakpoints.\r\n *\r\n * @param {boolean} completely - Destroy completely.\r\n */\n ;\n\n _proto.destroy = function destroy(completely) {\n var _this2 = this;\n\n if (completely === void 0) {\n completely = true;\n }\n\n // Postpone destroy because it should be done after mount.\n if (this.State.is(CREATED)) {\n this.on('ready', function () {\n return _this2.destroy(completely);\n });\n return;\n }\n\n values(this.Components).reverse().forEach(function (component) {\n component.destroy && component.destroy(completely);\n });\n this.emit('destroy', completely); // Destroy all event handlers, including ones for native events.\n\n this.Event.destroy();\n this.State.set(DESTROYED);\n return this;\n }\n /**\r\n * Return the current slide index.\r\n *\r\n * @return {number} - The current slide index.\r\n // */\n ;\n\n _createClass(Splide, [{\n key: \"index\",\n get: function get() {\n return this._i;\n }\n /**\r\n * Set the current slide index.\r\n *\r\n * @param {number|string} index - A new index.\r\n */\n ,\n set: function set(index) {\n this._i = parseInt(index);\n }\n /**\r\n * Return length of slides.\r\n * This is an alias of Elements.length.\r\n *\r\n * @return {number} - A number of slides.\r\n */\n\n }, {\n key: \"length\",\n get: function get() {\n return this.Components.Elements.length;\n }\n /**\r\n * Return options.\r\n *\r\n * @return {Object} - Options object.\r\n */\n\n }, {\n key: \"options\",\n get: function get() {\n return this._o;\n }\n /**\r\n * Set options with merging the given object to the current one.\r\n *\r\n * @param {Object} options - New options.\r\n */\n ,\n set: function set(options) {\n var created = this.State.is(CREATED);\n\n if (!created) {\n this.emit('update');\n }\n\n this._o = merge(this._o, options);\n\n if (!created) {\n this.emit('updated', this._o);\n }\n }\n /**\r\n * Return the class list.\r\n * This is an alias of Splide.options.classList.\r\n *\r\n * @return {Object} - An object containing all class list.\r\n */\n\n }, {\n key: \"classes\",\n get: function get() {\n return this._o.classes;\n }\n /**\r\n * Return the i18n strings.\r\n * This is an alias of Splide.options.i18n.\r\n *\r\n * @return {Object} - An object containing all i18n strings.\r\n */\n\n }, {\n key: \"i18n\",\n get: function get() {\n return this._o.i18n;\n }\n }]);\n\n return Splide;\n}();\n\n\n;// CONCATENATED MODULE: ./src/js/components/options/index.js\n/**\r\n * The component for initializing options.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n/**\r\n * The component for initializing options.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const options = (function (Splide) {\n /**\r\n * Retrieve options from the data attribute.\r\n * Note that IE10 doesn't support dataset property.\r\n *\r\n * @type {string}\r\n */\n var options = getAttribute(Splide.root, 'data-splide');\n\n if (options) {\n try {\n Splide.options = JSON.parse(options);\n } catch (e) {\n error(e.message);\n }\n }\n\n return {\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n if (Splide.State.is(CREATED)) {\n Splide.index = Splide.options.start;\n }\n }\n };\n});\n;// CONCATENATED MODULE: ./src/js/constants/directions.js\n/**\r\n * Export layout modes.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Enumerate slides from left to right.\r\n *\r\n * @type {string}\r\n */\nvar LTR = 'ltr';\n/**\r\n * Enumerate slides from right to left.\r\n *\r\n * @type {string}\r\n */\n\nvar RTL = 'rtl';\n/**\r\n * Enumerate slides in a col.\r\n *\r\n * @type {string}\r\n */\n\nvar TTB = 'ttb';\n;// CONCATENATED MODULE: ./src/js/components/elements/slide.js\n/**\r\n * The sub component for handling each slide.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\n\n/**\r\n * Events for restoring original styles.\r\n *\r\n * @type {string}\r\n */\n\nvar STYLE_RESTORE_EVENTS = 'update.slide';\n/**\r\n * The sub component for handling each slide.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {number} index - An unique slide index.\r\n * @param {number} realIndex - Clones should pass a real slide index.\r\n * @param {Element} slide - A slide element.\r\n *\r\n * @return {Object} - The sub component object.\r\n */\n\n/* harmony default export */ const elements_slide = (function (Splide, index, realIndex, slide) {\n /**\r\n * Whether to update \"is-active\" class before or after transition.\r\n *\r\n * @type {boolean}\r\n */\n var updateOnMove = Splide.options.updateOnMove;\n /**\r\n * Events when the slide status is updated.\r\n * Append a namespace to remove listeners later.\r\n *\r\n * @type {string}\r\n */\n\n var STATUS_UPDATE_EVENTS = 'ready.slide updated.slide resized.slide moved.slide' + (updateOnMove ? ' move.slide' : '');\n /**\r\n * Slide sub component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Slide = {\n /**\r\n * Slide element.\r\n *\r\n * @type {Element}\r\n */\n slide: slide,\n\n /**\r\n * Slide index.\r\n *\r\n * @type {number}\r\n */\n index: index,\n\n /**\r\n * Real index for clones.\r\n *\r\n * @type {number}\r\n */\n realIndex: realIndex,\n\n /**\r\n * Container element if available.\r\n *\r\n * @type {Element|undefined}\r\n */\n container: child(slide, Splide.classes.container),\n\n /**\r\n * Whether this is a cloned slide or not.\r\n *\r\n * @type {boolean}\r\n */\n isClone: realIndex > -1,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n var _this = this;\n\n if (!this.isClone) {\n slide.id = Splide.root.id + \"-slide\" + pad(index + 1);\n }\n\n Splide.on(STATUS_UPDATE_EVENTS, function () {\n return _this.update();\n }).on(STYLE_RESTORE_EVENTS, restoreStyles).on('click', function () {\n return Splide.emit('click', _this);\n }, slide);\n /*\r\n * Add \"is-active\" class to a clone element temporarily\r\n * and it will be removed on \"moved\" event.\r\n */\n\n if (updateOnMove) {\n Splide.on('move.slide', function (newIndex) {\n if (newIndex === realIndex) {\n _update(true, false);\n }\n });\n } // Make sure the slide is shown.\n\n\n applyStyle(slide, {\n display: ''\n }); // Hold the original styles.\n\n this.styles = getAttribute(slide, 'style') || '';\n },\n\n /**\r\n * Destroy.\r\n */\n destroy: function destroy() {\n Splide.off(STATUS_UPDATE_EVENTS).off(STYLE_RESTORE_EVENTS).off('click', slide);\n removeClass(slide, values(STATUS_CLASSES));\n restoreStyles();\n removeAttribute(this.container, 'style');\n },\n\n /**\r\n * Update active and visible status.\r\n */\n update: function update() {\n _update(this.isActive(), false);\n\n _update(this.isVisible(), true);\n },\n\n /**\r\n * Check whether this slide is active or not.\r\n *\r\n * @return {boolean} - True if the slide is active or false if not.\r\n */\n isActive: function isActive() {\n return Splide.index === index;\n },\n\n /**\r\n * Check whether this slide is visible in the viewport or not.\r\n *\r\n * @return {boolean} - True if the slide is visible or false if not.\r\n */\n isVisible: function isVisible() {\n var active = this.isActive();\n\n if (Splide.is(FADE) || active) {\n return active;\n }\n\n var ceil = Math.ceil;\n var trackRect = getRect(Splide.Components.Elements.track);\n var slideRect = getRect(slide);\n\n if (Splide.options.direction === TTB) {\n return trackRect.top <= slideRect.top && slideRect.bottom <= ceil(trackRect.bottom);\n }\n\n return trackRect.left <= slideRect.left && slideRect.right <= ceil(trackRect.right);\n },\n\n /**\r\n * Calculate how far this slide is from another slide and\r\n * return true if the distance is within the given number.\r\n *\r\n * @param {number} from - Index of a target slide.\r\n * @param {number} within - True if the slide is within this number.\r\n *\r\n * @return {boolean} - True if the slide is within the number or false otherwise.\r\n */\n isWithin: function isWithin(from, within) {\n var diff = Math.abs(from - index);\n\n if (!Splide.is(SLIDE) && !this.isClone) {\n diff = Math.min(diff, Splide.length - diff);\n }\n\n return diff < within;\n }\n };\n /**\r\n * Update classes for activity or visibility.\r\n *\r\n * @param {boolean} active - Is active/visible or not.\r\n * @param {boolean} forVisibility - Toggle classes for activity or visibility.\r\n */\n\n function _update(active, forVisibility) {\n var type = forVisibility ? 'visible' : 'active';\n var className = STATUS_CLASSES[type];\n\n if (active) {\n addClass(slide, className);\n Splide.emit(\"\" + type, Slide);\n } else {\n if (hasClass(slide, className)) {\n removeClass(slide, className);\n Splide.emit(\"\" + (forVisibility ? 'hidden' : 'inactive'), Slide);\n }\n }\n }\n /**\r\n * Restore the original styles.\r\n */\n\n\n function restoreStyles() {\n setAttribute(slide, 'style', Slide.styles);\n }\n\n return Slide;\n});\n;// CONCATENATED MODULE: ./src/js/components/elements/index.js\n/**\r\n * The component for main elements.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\n/**\r\n * The property name for UID stored in a window object.\r\n *\r\n * @type {string}\r\n */\n\nvar UID_NAME = 'uid';\n/**\r\n * The component for main elements.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const components_elements = (function (Splide, Components) {\n /**\r\n * Hold the root element.\r\n *\r\n * @type {Element}\r\n */\n var root = Splide.root;\n /**\r\n * Hold the class list.\r\n *\r\n * @type {Object}\r\n */\n\n var classes = Splide.classes;\n /**\r\n * Store Slide objects.\r\n *\r\n * @type {Array}\r\n */\n\n var Slides = [];\n /*\r\n * Assign unique ID to the root element if it doesn't have the one.\r\n * Note that IE doesn't support padStart() to fill the uid by 0.\r\n */\n\n if (!root.id) {\n window.splide = window.splide || {};\n var uid = window.splide[UID_NAME] || 0;\n window.splide[UID_NAME] = ++uid;\n root.id = \"splide\" + pad(uid);\n }\n /**\r\n * Elements component object.\r\n *\r\n * @type {Object}\r\n */\n\n\n var Elements = {\n /**\r\n * Called when the component is mounted.\r\n * Collect main elements and store them as member properties.\r\n */\n mount: function mount() {\n var _this = this;\n\n this.init();\n Splide.on('refresh', function () {\n _this.destroy();\n\n _this.init();\n }).on('updated', function () {\n removeClass(root, getClasses());\n addClass(root, getClasses());\n });\n },\n\n /**\r\n * Destroy.\r\n */\n destroy: function destroy() {\n Slides.forEach(function (Slide) {\n Slide.destroy();\n });\n Slides = [];\n removeClass(root, getClasses());\n },\n\n /**\r\n * Initialization.\r\n */\n init: function init() {\n var _this2 = this;\n\n collect();\n addClass(root, getClasses());\n this.slides.forEach(function (slide, index) {\n _this2.register(slide, index, -1);\n });\n },\n\n /**\r\n * Register a slide to create a Slide object and handle its behavior.\r\n *\r\n * @param {Element} slide - A slide element.\r\n * @param {number} index - A unique index. This can be negative.\r\n * @param {number} realIndex - A real index for clones. Set -1 for real slides.\r\n */\n register: function register(slide, index, realIndex) {\n var SlideObject = elements_slide(Splide, index, realIndex, slide);\n SlideObject.mount();\n Slides.push(SlideObject);\n },\n\n /**\r\n * Return the Slide object designated by the index.\r\n * Note that \"find\" is not supported by IE.\r\n *\r\n * @return {Object|undefined} - A Slide object if available. Undefined if not.\r\n */\n getSlide: function getSlide(index) {\n return Slides.filter(function (Slide) {\n return Slide.index === index;\n })[0];\n },\n\n /**\r\n * Return all Slide objects.\r\n *\r\n * @param {boolean} includeClones - Whether to include cloned slides or not.\r\n *\r\n * @return {Object[]} - Slide objects.\r\n */\n getSlides: function getSlides(includeClones) {\n return includeClones ? Slides : Slides.filter(function (Slide) {\n return !Slide.isClone;\n });\n },\n\n /**\r\n * Return Slide objects belonging to the given page.\r\n *\r\n * @param {number} page - A page number.\r\n *\r\n * @return {Object[]} - An array containing Slide objects.\r\n */\n getSlidesByPage: function getSlidesByPage(page) {\n var idx = Components.Controller.toIndex(page);\n var options = Splide.options;\n var max = options.focus !== false ? 1 : options.perPage;\n return Slides.filter(function (_ref) {\n var index = _ref.index;\n return idx <= index && index < idx + max;\n });\n },\n\n /**\r\n * Insert a slide to a slider.\r\n * Need to refresh Splide after adding a slide.\r\n *\r\n * @param {Node|string} slide - A slide element to be added.\r\n * @param {number} index - A slide will be added at the position.\r\n * @param {Function} callback - Called right after the slide is added to the DOM tree.\r\n */\n add: function add(slide, index, callback) {\n if (typeof slide === 'string') {\n slide = domify(slide);\n }\n\n if (slide instanceof Element) {\n var ref = this.slides[index]; // This will be removed in mount() of a Slide component.\n\n applyStyle(slide, {\n display: 'none'\n });\n\n if (ref) {\n before(slide, ref);\n this.slides.splice(index, 0, slide);\n } else {\n append(this.list, slide);\n this.slides.push(slide);\n }\n\n loaded(slide, function () {\n callback && callback(slide);\n });\n }\n },\n\n /**\r\n * Remove a slide from a slider.\r\n * Need to refresh Splide after removing a slide.\r\n *\r\n * @param index - Slide index.\r\n */\n remove: function remove(index) {\n dom_remove(this.slides.splice(index, 1)[0]);\n },\n\n /**\r\n * Trigger the provided callback for each Slide object.\r\n *\r\n * @param {Function} callback - A callback function. The first argument will be the Slide object.\r\n */\n each: function each(callback) {\n Slides.forEach(callback);\n },\n\n /**\r\n * Return slides length without clones.\r\n *\r\n * @return {number} - Slide length.\r\n */\n get length() {\n return this.slides.length;\n },\n\n /**\r\n * Return \"SlideObjects\" length including clones.\r\n *\r\n * @return {number} - Slide length including clones.\r\n */\n get total() {\n return Slides.length;\n }\n\n };\n /**\r\n * Collect elements.\r\n */\n\n function collect() {\n Elements.slider = child(root, classes.slider);\n Elements.track = find(root, \".\" + classes.track);\n Elements.list = child(Elements.track, classes.list);\n exist(Elements.track && Elements.list, 'Track or list was not found.');\n Elements.slides = children(Elements.list, classes.slide);\n var arrows = findParts(classes.arrows);\n Elements.arrows = {\n prev: find(arrows, \".\" + classes.prev),\n next: find(arrows, \".\" + classes.next)\n };\n var autoplay = findParts(classes.autoplay);\n Elements.bar = find(findParts(classes.progress), \".\" + classes.bar);\n Elements.play = find(autoplay, \".\" + classes.play);\n Elements.pause = find(autoplay, \".\" + classes.pause);\n Elements.track.id = Elements.track.id || root.id + \"-track\";\n Elements.list.id = Elements.list.id || root.id + \"-list\";\n }\n /**\r\n * Return class names for the root element.\r\n */\n\n\n function getClasses() {\n var rootClass = classes.root;\n var options = Splide.options;\n return [rootClass + \"--\" + options.type, rootClass + \"--\" + options.direction, options.drag ? rootClass + \"--draggable\" : '', options.isNavigation ? rootClass + \"--nav\" : '', STATUS_CLASSES.active];\n }\n /**\r\n * Find parts only from children of the root or track.\r\n *\r\n * @return {Element} - A found element or undefined.\r\n */\n\n\n function findParts(className) {\n return child(root, className) || child(Elements.slider, className);\n }\n\n return Elements;\n});\n;// CONCATENATED MODULE: ./src/js/components/controller/index.js\n/**\r\n * The component for controlling the track.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\nvar floor = Math.floor;\n/**\r\n * The component for controlling the track.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const controller = (function (Splide, Components) {\n /**\r\n * Store current options.\r\n *\r\n * @type {Object}\r\n */\n var options;\n /**\r\n * True if the slide is LOOP mode.\r\n *\r\n * @type {boolean}\r\n */\n\n var isLoop;\n /**\r\n * Controller component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Controller = {\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n options = Splide.options;\n isLoop = Splide.is(LOOP);\n bind();\n },\n\n /**\r\n * Make track run by the given control.\r\n * - \"+{i}\" : Increment the slide index by i.\r\n * - \"-{i}\" : Decrement the slide index by i.\r\n * - \"{i}\" : Go to the slide whose index is i.\r\n * - \">\" : Go to next page.\r\n * - \"<\" : Go to prev page.\r\n * - \">{i}\" : Go to page i.\r\n *\r\n * @param {string|number} control - A control pattern.\r\n * @param {boolean} silently - Go to the destination without event emission.\r\n */\n go: function go(control, silently) {\n var destIndex = this.trim(this.parse(control));\n Components.Track.go(destIndex, this.rewind(destIndex), silently);\n },\n\n /**\r\n * Parse the given control and return the destination index for the track.\r\n *\r\n * @param {string} control - A control target pattern.\r\n *\r\n * @return {number} - A parsed target.\r\n */\n parse: function parse(control) {\n var index = Splide.index;\n var matches = String(control).match(/([+\\-<>]+)(\\d+)?/);\n var indicator = matches ? matches[1] : '';\n var number = matches ? parseInt(matches[2]) : 0;\n\n switch (indicator) {\n case '+':\n index += number || 1;\n break;\n\n case '-':\n index -= number || 1;\n break;\n\n case '>':\n case '<':\n index = parsePage(number, index, indicator === '<');\n break;\n\n default:\n index = parseInt(control);\n }\n\n return index;\n },\n\n /**\r\n * Compute index from the given page number.\r\n *\r\n * @param {number} page - Page number.\r\n *\r\n * @return {number} - A computed page number.\r\n */\n toIndex: function toIndex(page) {\n if (hasFocus()) {\n return page;\n }\n\n var length = Splide.length;\n var perPage = options.perPage;\n var index = page * perPage;\n index = index - (this.pageLength * perPage - length) * floor(index / length); // Adjustment for the last page.\n\n if (length - perPage <= index && index < length) {\n index = length - perPage;\n }\n\n return index;\n },\n\n /**\r\n * Compute page number from the given slide index.\r\n *\r\n * @param {number} index - Slide index.\r\n *\r\n * @return {number} - A computed page number.\r\n */\n toPage: function toPage(index) {\n if (hasFocus()) {\n return index;\n }\n\n var length = Splide.length;\n var perPage = options.perPage; // Make the last \"perPage\" number of slides belong to the last page.\n\n if (length - perPage <= index && index < length) {\n return floor((length - 1) / perPage);\n }\n\n return floor(index / perPage);\n },\n\n /**\r\n * Trim the given index according to the current mode.\r\n * Index being returned could be less than 0 or greater than the length in Loop mode.\r\n *\r\n * @param {number} index - An index being trimmed.\r\n *\r\n * @return {number} - A trimmed index.\r\n */\n trim: function trim(index) {\n if (!isLoop) {\n index = options.rewind ? this.rewind(index) : between(index, 0, this.edgeIndex);\n }\n\n return index;\n },\n\n /**\r\n * Rewind the given index if it's out of range.\r\n *\r\n * @param {number} index - An index.\r\n *\r\n * @return {number} - A rewound index.\r\n */\n rewind: function rewind(index) {\n var edge = this.edgeIndex;\n\n if (isLoop) {\n while (index > edge) {\n index -= edge + 1;\n }\n\n while (index < 0) {\n index += edge + 1;\n }\n } else {\n if (index > edge) {\n index = 0;\n } else if (index < 0) {\n index = edge;\n }\n }\n\n return index;\n },\n\n /**\r\n * Check if the direction is \"rtl\" or not.\r\n *\r\n * @return {boolean} - True if \"rtl\" or false if not.\r\n */\n isRtl: function isRtl() {\n return options.direction === RTL;\n },\n\n /**\r\n * Return the page length.\r\n *\r\n * @return {number} - Max page number.\r\n */\n get pageLength() {\n var length = Splide.length;\n return hasFocus() ? length : Math.ceil(length / options.perPage);\n },\n\n /**\r\n * Return the edge index.\r\n *\r\n * @return {number} - Edge index.\r\n */\n get edgeIndex() {\n var length = Splide.length;\n\n if (!length) {\n return 0;\n }\n\n if (hasFocus() || options.isNavigation || isLoop) {\n return length - 1;\n }\n\n return length - options.perPage;\n },\n\n /**\r\n * Return the index of the previous slide.\r\n *\r\n * @return {number} - The index of the previous slide if available. -1 otherwise.\r\n */\n get prevIndex() {\n var prev = Splide.index - 1;\n\n if (isLoop || options.rewind) {\n prev = this.rewind(prev);\n }\n\n return prev > -1 ? prev : -1;\n },\n\n /**\r\n * Return the index of the next slide.\r\n *\r\n * @return {number} - The index of the next slide if available. -1 otherwise.\r\n */\n get nextIndex() {\n var next = Splide.index + 1;\n\n if (isLoop || options.rewind) {\n next = this.rewind(next);\n }\n\n return Splide.index < next && next <= this.edgeIndex || next === 0 ? next : -1;\n }\n\n };\n /**\r\n * Listen to some events.\r\n */\n\n function bind() {\n Splide.on('move', function (newIndex) {\n Splide.index = newIndex;\n }).on('updated refresh', function (newOptions) {\n options = newOptions || options;\n Splide.index = between(Splide.index, 0, Controller.edgeIndex);\n });\n }\n /**\r\n * Verify if the focus option is available or not.\r\n *\r\n * @return {boolean} - True if a slider has the focus option.\r\n */\n\n\n function hasFocus() {\n return options.focus !== false;\n }\n /**\r\n * Return the next or previous page index computed by the page number and current index.\r\n *\r\n * @param {number} number - Specify the page number.\r\n * @param {number} index - Current index.\r\n * @param {boolean} prev - Prev or next.\r\n *\r\n * @return {number} - Slide index.\r\n */\n\n\n function parsePage(number, index, prev) {\n if (number > -1) {\n return Controller.toIndex(number);\n }\n\n var perMove = options.perMove;\n var sign = prev ? -1 : 1;\n\n if (perMove) {\n return index + perMove * sign;\n }\n\n return Controller.toIndex(Controller.toPage(index) + sign);\n }\n\n return Controller;\n});\n;// CONCATENATED MODULE: ./src/js/components/track/index.js\n/**\r\n * The component for moving list in the track.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\nvar abs = Math.abs;\n/**\r\n * The component for moving list in the track.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const track = (function (Splide, Components) {\n /**\r\n * Hold the Layout component.\r\n *\r\n * @type {Object}\r\n */\n var Layout;\n /**\r\n * Hold the Layout component.\r\n *\r\n * @type {Object}\r\n */\n\n var Elements;\n /**\r\n * Store the list element.\r\n *\r\n * @type {Element}\r\n */\n\n var list;\n /**\r\n * Whether the current direction is vertical or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isVertical = Splide.options.direction === TTB;\n /**\r\n * Whether the slider type is FADE or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isFade = Splide.is(FADE);\n /**\r\n * Whether the slider direction is RTL or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isRTL = Splide.options.direction === RTL;\n /**\r\n * This will be true while transitioning from the last index to the first one.\r\n *\r\n * @type {boolean}\r\n */\n\n var isLoopPending = false;\n /**\r\n * Sign for the direction. Only RTL mode uses the positive sign.\r\n *\r\n * @type {number}\r\n */\n\n var sign = isRTL ? 1 : -1;\n /**\r\n * Track component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Track = {\n /**\r\n * Make public the sign defined locally.\r\n *\r\n * @type {number}\r\n */\n sign: sign,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n Elements = Components.Elements;\n Layout = Components.Layout;\n list = Elements.list;\n },\n\n /**\r\n * Called after the component is mounted.\r\n * The resize event must be registered after the Layout's one is done.\r\n */\n mounted: function mounted() {\n var _this = this;\n\n if (!isFade) {\n this.jump(0);\n Splide.on('mounted resize updated', function () {\n _this.jump(Splide.index);\n });\n }\n },\n\n /**\r\n * Go to the given destination index.\r\n * After arriving there, the track is jump to the new index without animation, mainly for loop mode.\r\n *\r\n * @param {number} destIndex - A destination index.\r\n * This can be negative or greater than slides length for reaching clones.\r\n * @param {number} newIndex - An actual new index. They are always same in Slide and Rewind mode.\r\n * @param {boolean} silently - If true, suppress emitting events.\r\n */\n go: function go(destIndex, newIndex, silently) {\n var newPosition = getTrimmedPosition(destIndex);\n var prevIndex = Splide.index; // Prevent any actions while transitioning from the last index to the first one for jump.\n\n if (Splide.State.is(MOVING) && isLoopPending) {\n return;\n }\n\n isLoopPending = destIndex !== newIndex;\n\n if (!silently) {\n Splide.emit('move', newIndex, prevIndex, destIndex);\n }\n\n if (Math.abs(newPosition - this.position) >= 1 || isFade) {\n Components.Transition.start(destIndex, newIndex, prevIndex, this.toCoord(newPosition), function () {\n onTransitionEnd(destIndex, newIndex, prevIndex, silently);\n });\n } else {\n if (destIndex !== prevIndex && Splide.options.trimSpace === 'move') {\n Components.Controller.go(destIndex + destIndex - prevIndex, silently);\n } else {\n onTransitionEnd(destIndex, newIndex, prevIndex, silently);\n }\n }\n },\n\n /**\r\n * Move the track to the specified index.\r\n *\r\n * @param {number} index - A destination index where the track jumps.\r\n */\n jump: function jump(index) {\n this.translate(getTrimmedPosition(index));\n },\n\n /**\r\n * Set the list position by CSS translate property.\r\n *\r\n * @param {number} position - A new position value.\r\n */\n translate: function translate(position) {\n applyStyle(list, {\n transform: \"translate\" + (isVertical ? 'Y' : 'X') + \"(\" + position + \"px)\"\n });\n },\n\n /**\r\n * Cancel the transition and set the list position.\r\n * Also, loop the slider if necessary.\r\n */\n cancel: function cancel() {\n if (Splide.is(LOOP)) {\n this.shift();\n } else {\n // Ensure the current position.\n this.translate(this.position);\n }\n\n applyStyle(list, {\n transition: ''\n });\n },\n\n /**\r\n * Shift the slider if it exceeds borders on the edge.\r\n */\n shift: function shift() {\n var position = abs(this.position);\n var left = abs(this.toPosition(0));\n var right = abs(this.toPosition(Splide.length));\n var innerSize = right - left;\n\n if (position < left) {\n position += innerSize;\n } else if (position > right) {\n position -= innerSize;\n }\n\n this.translate(sign * position);\n },\n\n /**\r\n * Trim redundant spaces on the left or right edge if necessary.\r\n *\r\n * @param {number} position - Position value to be trimmed.\r\n *\r\n * @return {number} - Trimmed position.\r\n */\n trim: function trim(position) {\n if (!Splide.options.trimSpace || Splide.is(LOOP)) {\n return position;\n }\n\n var edge = sign * (Layout.totalSize() - Layout.size - Layout.gap);\n return between(position, edge, 0);\n },\n\n /**\r\n * Calculate the closest slide index from the given position.\r\n *\r\n * @param {number} position - A position converted to an slide index.\r\n *\r\n * @return {number} - The closest slide index.\r\n */\n toIndex: function toIndex(position) {\n var _this2 = this;\n\n var index = 0;\n var minDistance = Infinity;\n Elements.getSlides(true).forEach(function (Slide) {\n var slideIndex = Slide.index;\n var distance = abs(_this2.toPosition(slideIndex) - position);\n\n if (distance < minDistance) {\n minDistance = distance;\n index = slideIndex;\n }\n });\n return index;\n },\n\n /**\r\n * Return coordinates object by the given position.\r\n *\r\n * @param {number} position - A position value.\r\n *\r\n * @return {Object} - A coordinates object.\r\n */\n toCoord: function toCoord(position) {\n return {\n x: isVertical ? 0 : position,\n y: isVertical ? position : 0\n };\n },\n\n /**\r\n * Calculate the track position by a slide index.\r\n *\r\n * @param {number} index - Slide index.\r\n *\r\n * @return {Object} - Calculated position.\r\n */\n toPosition: function toPosition(index) {\n var position = Layout.totalSize(index) - Layout.slideSize(index) - Layout.gap;\n return sign * (position + this.offset(index));\n },\n\n /**\r\n * Return the current offset value, considering direction.\r\n *\r\n * @return {number} - Offset amount.\r\n */\n offset: function offset(index) {\n var focus = Splide.options.focus;\n var slideSize = Layout.slideSize(index);\n\n if (focus === 'center') {\n return -(Layout.size - slideSize) / 2;\n }\n\n return -(parseInt(focus) || 0) * (slideSize + Layout.gap);\n },\n\n /**\r\n * Return the current position.\r\n * This returns the correct position even while transitioning by CSS.\r\n *\r\n * @return {number} - Current position.\r\n */\n get position() {\n var prop = isVertical ? 'top' : isRTL ? 'right' : 'left';\n return getRect(list)[prop] - (getRect(Elements.track)[prop] - Layout.padding[prop] * sign);\n }\n\n };\n /**\r\n * Called whenever slides arrive at a destination.\r\n *\r\n * @param {number} destIndex - A destination index.\r\n * @param {number} newIndex - A new index.\r\n * @param {number} prevIndex - A previous index.\r\n * @param {boolean} silently - If true, suppress emitting events.\r\n */\n\n function onTransitionEnd(destIndex, newIndex, prevIndex, silently) {\n applyStyle(list, {\n transition: ''\n });\n isLoopPending = false;\n\n if (!isFade) {\n Track.jump(newIndex);\n }\n\n if (!silently) {\n Splide.emit('moved', newIndex, prevIndex, destIndex);\n }\n }\n /**\r\n * Convert index to the trimmed position.\r\n *\r\n * @return {number} - Trimmed position.\r\n */\n\n\n function getTrimmedPosition(index) {\n return Track.trim(Track.toPosition(index));\n }\n\n return Track;\n});\n;// CONCATENATED MODULE: ./src/js/components/clones/index.js\n/**\r\n * The component for cloning some slides for \"loop\" mode of the track.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n/**\r\n * The component for cloning some slides for \"loop\" mode of the track.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const clones = (function (Splide, Components) {\n /**\r\n * Store information of all clones.\r\n *\r\n * @type {Array}\r\n */\n var clones = [];\n /**\r\n * Store the current clone count on one side.\r\n *\r\n * @type {number}\r\n */\n\n var cloneCount = 0;\n /**\r\n * Keep Elements component.\r\n *\r\n * @type {Object}\r\n */\n\n var Elements = Components.Elements;\n /**\r\n * Clones component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Clones = {\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n var _this = this;\n\n if (Splide.is(LOOP)) {\n init();\n Splide.on('refresh:before', function () {\n _this.destroy();\n }).on('refresh', init).on('resize', function () {\n if (cloneCount !== getCloneCount()) {\n // Destroy before refresh not to collect clones by the Elements component.\n _this.destroy();\n\n Splide.refresh();\n }\n });\n }\n },\n\n /**\r\n * Destroy.\r\n */\n destroy: function destroy() {\n dom_remove(clones);\n clones = [];\n },\n\n /**\r\n * Return all clones.\r\n *\r\n * @return {Element[]} - Cloned elements.\r\n */\n get clones() {\n return clones;\n },\n\n /**\r\n * Return clone length.\r\n *\r\n * @return {number} - A length of clones.\r\n */\n get length() {\n return clones.length;\n }\n\n };\n /**\r\n * Initialization.\r\n */\n\n function init() {\n Clones.destroy();\n cloneCount = getCloneCount();\n generateClones(cloneCount);\n }\n /**\r\n * Generate and append/prepend clones.\r\n *\r\n * @param {number} count - The half number of clones.\r\n */\n\n\n function generateClones(count) {\n var length = Elements.length,\n register = Elements.register;\n\n if (length) {\n var slides = Elements.slides;\n\n while (slides.length < count) {\n slides = slides.concat(slides);\n } // Clones after the last element.\n\n\n slides.slice(0, count).forEach(function (elm, index) {\n var clone = cloneDeeply(elm);\n append(Elements.list, clone);\n clones.push(clone);\n register(clone, index + length, index % length);\n }); // Clones before the first element.\n\n slides.slice(-count).forEach(function (elm, index) {\n var clone = cloneDeeply(elm);\n before(clone, slides[0]);\n clones.push(clone);\n register(clone, index - count, (length + index - count % length) % length);\n });\n }\n }\n /**\r\n * Return half count of clones to be generated.\r\n * Clone count is determined by:\r\n * - \"clones\" value in the options.\r\n * - Number of slides that can be placed in a view in \"fixed\" mode.\r\n * - Max pages a flick action can move.\r\n * - Whether the slide length is enough for perPage.\r\n *\r\n * @return {number} - Count for clones.\r\n */\n\n\n function getCloneCount() {\n var options = Splide.options;\n\n if (options.clones) {\n return options.clones;\n } // Use the slide length in autoWidth mode because the number cannot be calculated.\n\n\n var baseCount = options.autoWidth || options.autoHeight ? Elements.length : options.perPage;\n var dimension = options.direction === TTB ? 'Height' : 'Width';\n var fixedSize = toPixel(Splide.root, options[\"fixed\" + dimension]);\n\n if (fixedSize) {\n // Roughly calculate the count. This needs not to be strict.\n baseCount = Math.ceil(Elements.track[\"client\" + dimension] / fixedSize);\n }\n\n return baseCount * (options.drag ? options.flickMaxPages + 1 : 1);\n }\n /**\r\n * Clone deeply the given element.\r\n *\r\n * @param {Element} elm - An element being duplicated.\r\n *\r\n * @return {Node} - A cloned node(element).\r\n */\n\n\n function cloneDeeply(elm) {\n var clone = elm.cloneNode(true);\n addClass(clone, Splide.classes.clone); // ID should not be duplicated.\n\n removeAttribute(clone, 'id');\n return clone;\n }\n\n return Clones;\n});\n;// CONCATENATED MODULE: ./src/js/components/layout/directions/horizontal.js\n/**\r\n * The resolver component for horizontal layout.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n/**\r\n * The resolver component for horizontal layout.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The resolver object.\r\n */\n\n/* harmony default export */ const horizontal = (function (Splide, Components) {\n /**\r\n * Keep the Elements component.\r\n *\r\n * @type {string}\r\n */\n var Elements = Components.Elements;\n /**\r\n * Keep the root element.\r\n *\r\n * @type {Element}\r\n */\n\n var root = Splide.root;\n /**\r\n * Keep the track element.\r\n *\r\n * @type {Element}\r\n */\n\n var track;\n /**\r\n * Keep the latest options.\r\n *\r\n * @type {Element}\r\n */\n\n var options = Splide.options;\n return {\n /**\r\n * Margin property name.\r\n *\r\n * @type {string}\r\n */\n margin: 'margin' + (options.direction === RTL ? 'Left' : 'Right'),\n\n /**\r\n * Always 0 because the height will be determined by inner contents.\r\n *\r\n * @type {number}\r\n */\n height: 0,\n\n /**\r\n * Initialization.\r\n */\n init: function init() {\n this.resize();\n },\n\n /**\r\n * Resize gap and padding.\r\n * This must be called on init.\r\n */\n resize: function resize() {\n options = Splide.options;\n track = Elements.track;\n this.gap = toPixel(root, options.gap);\n var padding = options.padding;\n var left = toPixel(root, padding.left || padding);\n var right = toPixel(root, padding.right || padding);\n this.padding = {\n left: left,\n right: right\n };\n applyStyle(track, {\n paddingLeft: unit(left),\n paddingRight: unit(right)\n });\n },\n\n /**\r\n * Return total width from the left of the list to the right of the slide specified by the provided index.\r\n *\r\n * @param {number} index - Optional. A slide index. If undefined, total width of the slider will be returned.\r\n *\r\n * @return {number} - Total width to the right side of the specified slide, or 0 for an invalid index.\r\n */\n totalWidth: function totalWidth(index) {\n if (index === void 0) {\n index = Splide.length - 1;\n }\n\n var Slide = Elements.getSlide(index);\n var width = 0;\n\n if (Slide) {\n var slideRect = getRect(Slide.slide);\n var listRect = getRect(Elements.list);\n\n if (options.direction === RTL) {\n width = listRect.right - slideRect.left;\n } else {\n width = slideRect.right - listRect.left;\n }\n\n width += this.gap;\n }\n\n return width;\n },\n\n /**\r\n * Return the slide width in px.\r\n *\r\n * @param {number} index - Slide index.\r\n *\r\n * @return {number} - The slide width.\r\n */\n slideWidth: function slideWidth(index) {\n if (options.autoWidth) {\n var Slide = Elements.getSlide(index);\n return Slide ? Slide.slide.offsetWidth : 0;\n }\n\n var width = options.fixedWidth || (this.width + this.gap) / options.perPage - this.gap;\n return toPixel(root, width);\n },\n\n /**\r\n * Return the slide height in px.\r\n *\r\n * @return {number} - The slide height.\r\n */\n slideHeight: function slideHeight() {\n var height = options.height || options.fixedHeight || this.width * options.heightRatio;\n return toPixel(root, height);\n },\n\n /**\r\n * Return slider width without padding.\r\n *\r\n * @return {number} - Current slider width.\r\n */\n get width() {\n return track.clientWidth - this.padding.left - this.padding.right;\n }\n\n };\n});\n;// CONCATENATED MODULE: ./src/js/components/layout/directions/vertical.js\n/**\r\n * The resolver component for vertical layout.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n/**\r\n * The resolver component for vertical layout.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The resolver object.\r\n */\n\n/* harmony default export */ const vertical = (function (Splide, Components) {\n /**\r\n * Keep the Elements component.\r\n *\r\n * @type {string}\r\n */\n var Elements = Components.Elements;\n /**\r\n * Keep the root element.\r\n *\r\n * @type {Element}\r\n */\n\n var root = Splide.root;\n /**\r\n * Keep the track element.\r\n *\r\n * @type {Element}\r\n */\n\n var track;\n /**\r\n * Keep the latest options.\r\n *\r\n * @type {Element}\r\n */\n\n var options;\n return {\n /**\r\n * Margin property name.\r\n *\r\n * @type {string}\r\n */\n margin: 'marginBottom',\n\n /**\r\n * Initialization.\r\n */\n init: function init() {\n this.resize();\n },\n\n /**\r\n * Resize gap and padding.\r\n * This must be called on init.\r\n */\n resize: function resize() {\n options = Splide.options;\n track = Elements.track;\n this.gap = toPixel(root, options.gap);\n var padding = options.padding;\n var top = toPixel(root, padding.top || padding);\n var bottom = toPixel(root, padding.bottom || padding);\n this.padding = {\n top: top,\n bottom: bottom\n };\n applyStyle(track, {\n paddingTop: unit(top),\n paddingBottom: unit(bottom)\n });\n },\n\n /**\r\n * Return total height from the top of the list to the bottom of the slide specified by the provided index.\r\n *\r\n * @param {number} index - Optional. A slide index. If undefined, total height of the slider will be returned.\r\n *\r\n * @return {number} - Total height to the bottom of the specified slide, or 0 for an invalid index.\r\n */\n totalHeight: function totalHeight(index) {\n if (index === void 0) {\n index = Splide.length - 1;\n }\n\n var Slide = Elements.getSlide(index);\n\n if (Slide) {\n return getRect(Slide.slide).bottom - getRect(Elements.list).top + this.gap;\n }\n\n return 0;\n },\n\n /**\r\n * Return the slide width in px.\r\n *\r\n * @return {number} - The slide width.\r\n */\n slideWidth: function slideWidth() {\n return toPixel(root, options.fixedWidth || this.width);\n },\n\n /**\r\n * Return the slide height in px.\r\n *\r\n * @param {number} index - Slide index.\r\n *\r\n * @return {number} - The slide height.\r\n */\n slideHeight: function slideHeight(index) {\n if (options.autoHeight) {\n var Slide = Elements.getSlide(index);\n return Slide ? Slide.slide.offsetHeight : 0;\n }\n\n var height = options.fixedHeight || (this.height + this.gap) / options.perPage - this.gap;\n return toPixel(root, height);\n },\n\n /**\r\n * Return slider width without padding.\r\n *\r\n * @return {number} - Current slider width.\r\n */\n get width() {\n return track.clientWidth;\n },\n\n /**\r\n * Return slide height without padding.\r\n *\r\n * @return {number} - Slider height.\r\n */\n get height() {\n var height = options.height || this.width * options.heightRatio;\n exist(height, '\"height\" or \"heightRatio\" is missing.');\n return toPixel(root, height) - this.padding.top - this.padding.bottom;\n }\n\n };\n});\n;// CONCATENATED MODULE: ./src/js/utils/time.js\n/**\r\n * A package of utility functions related with time.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Simple throttle function that controls how often the given function is executed.\r\n *\r\n * @param {function} func - A function to be throttled.\r\n * @param {number} wait - Time in millisecond for interval of execution.\r\n *\r\n * @return {Function} - A debounced function.\r\n */\nfunction throttle(func, wait) {\n var timeout; // Declare function by the \"function\" keyword to prevent \"this\" from being inherited.\n\n return function () {\n if (!timeout) {\n timeout = setTimeout(function () {\n func();\n timeout = null;\n }, wait);\n }\n };\n}\n/**\r\n * Custom setInterval function that provides progress rate as callback.\r\n *\r\n * @param {function} callback - A callback function fired every time the interval time passes.\r\n * @param {number} interval - Interval duration in milliseconds.\r\n * @param {function} progress - A callback function fired whenever the progress goes.\r\n *\r\n * @return {Object} - An object containing play() and pause() functions.\r\n */\n\nfunction createInterval(callback, interval, progress) {\n var _window = window,\n requestAnimationFrame = _window.requestAnimationFrame;\n var start,\n elapse,\n rate,\n _pause = true;\n\n var step = function step(timestamp) {\n if (!_pause) {\n if (!start) {\n start = timestamp;\n\n if (rate && rate < 1) {\n start -= rate * interval;\n }\n }\n\n elapse = timestamp - start;\n rate = elapse / interval;\n\n if (elapse >= interval) {\n start = 0;\n rate = 1;\n callback();\n }\n\n if (progress) {\n progress(rate);\n }\n\n requestAnimationFrame(step);\n }\n };\n\n return {\n pause: function pause() {\n _pause = true;\n start = 0;\n },\n play: function play(reset) {\n start = 0;\n\n if (reset) {\n rate = 0;\n }\n\n if (_pause) {\n _pause = false;\n requestAnimationFrame(step);\n }\n }\n };\n}\n;// CONCATENATED MODULE: ./src/js/components/layout/index.js\n/**\r\n * The component for handing slide layouts and their sizes.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\n\n\n/**\r\n * The component for handing slide layouts and their sizes.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const layout = (function (Splide, Components) {\n /**\r\n * Keep the Elements component.\r\n *\r\n * @type {string}\r\n */\n var Elements = Components.Elements;\n /**\r\n * Whether the slider is vertical or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isVertical = Splide.options.direction === TTB;\n /**\r\n * Layout component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Layout = object_assign({\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n bind();\n init(); // The word \"size\" means width for a horizontal slider and height for a vertical slider.\n\n this.totalSize = isVertical ? this.totalHeight : this.totalWidth;\n this.slideSize = isVertical ? this.slideHeight : this.slideWidth;\n },\n\n /**\r\n * Destroy the component.\r\n */\n destroy: function destroy() {\n removeAttribute([Elements.list, Elements.track], 'style');\n },\n\n /**\r\n * Return the slider height on the vertical mode or width on the horizontal mode.\r\n *\r\n * @return {number}\r\n */\n get size() {\n return isVertical ? this.height : this.width;\n }\n\n }, isVertical ? vertical(Splide, Components) : horizontal(Splide, Components));\n /**\r\n * Init slider styles according to options.\r\n */\n\n function init() {\n Layout.init();\n applyStyle(Splide.root, {\n maxWidth: unit(Splide.options.width)\n });\n Elements.each(function (Slide) {\n Slide.slide.style[Layout.margin] = unit(Layout.gap);\n });\n resize();\n }\n /**\r\n * Listen the resize native event with throttle.\r\n * Initialize when the component is mounted or options are updated.\r\n */\n\n\n function bind() {\n Splide.on('resize load', throttle(function () {\n Splide.emit('resize');\n }, Splide.options.throttle), window).on('resize', resize).on('updated refresh', init);\n }\n /**\r\n * Resize the track and slide elements.\r\n */\n\n\n function resize() {\n var options = Splide.options;\n Layout.resize();\n applyStyle(Elements.track, {\n height: unit(Layout.height)\n });\n var slideHeight = options.autoHeight ? null : unit(Layout.slideHeight());\n Elements.each(function (Slide) {\n applyStyle(Slide.container, {\n height: slideHeight\n });\n applyStyle(Slide.slide, {\n width: options.autoWidth ? null : unit(Layout.slideWidth(Slide.index)),\n height: Slide.container ? null : slideHeight\n });\n });\n Splide.emit('resized');\n }\n\n return Layout;\n});\n;// CONCATENATED MODULE: ./src/js/components/drag/index.js\n/**\r\n * The component for supporting mouse drag and swipe.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n\n\nvar drag_abs = Math.abs;\n/**\r\n * If the absolute velocity is greater thant this value,\r\n * a slider always goes to a different slide after drag, not allowed to stay on a current slide.\r\n */\n\nvar MIN_VELOCITY = 0.1;\n/**\r\n * Adjust how much the track can be pulled on the first or last page.\r\n * The larger number this is, the farther the track moves.\r\n * This should be around 5 - 9.\r\n *\r\n * @type {number}\r\n */\n\nvar FRICTION_REDUCER = 7;\n/**\r\n * The component supporting mouse drag and swipe.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const drag = (function (Splide, Components) {\n /**\r\n * Store the Move component.\r\n *\r\n * @type {Object}\r\n */\n var Track = Components.Track;\n /**\r\n * Store the Controller component.\r\n *\r\n * @type {Object}\r\n */\n\n var Controller = Components.Controller;\n /**\r\n * Coordinate of the track on starting drag.\r\n *\r\n * @type {Object}\r\n */\n\n var startCoord;\n /**\r\n * Analyzed info on starting drag.\r\n *\r\n * @type {Object|null}\r\n */\n\n var startInfo;\n /**\r\n * Analyzed info being updated while dragging/swiping.\r\n *\r\n * @type {Object}\r\n */\n\n var currentInfo;\n /**\r\n * Determine whether slides are being dragged or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isDragging;\n /**\r\n * Whether the slider direction is vertical or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var isVertical = Splide.options.direction === TTB;\n /**\r\n * Axis for the direction.\r\n *\r\n * @type {string}\r\n */\n\n var axis = isVertical ? 'y' : 'x';\n /**\r\n * Drag component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Drag = {\n /**\r\n * Whether dragging is disabled or not.\r\n *\r\n * @type {boolean}\r\n */\n disabled: false,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n var _this = this;\n\n var Elements = Components.Elements;\n var track = Elements.track;\n Splide.on('touchstart mousedown', start, track).on('touchmove mousemove', move, track, {\n passive: false\n }).on('touchend touchcancel mouseleave mouseup dragend', end, track).on('mounted refresh', function () {\n // Prevent dragging an image or anchor itself.\n each(Elements.list.querySelectorAll('img, a'), function (elm) {\n Splide.off('dragstart', elm).on('dragstart', function (e) {\n e.preventDefault();\n }, elm, {\n passive: false\n });\n });\n }).on('mounted updated', function () {\n _this.disabled = !Splide.options.drag;\n });\n }\n };\n /**\r\n * Called when the track starts to be dragged.\r\n *\r\n * @param {TouchEvent|MouseEvent} e - TouchEvent or MouseEvent object.\r\n */\n\n function start(e) {\n if (!Drag.disabled && !isDragging) {\n // These prams are used to evaluate whether the slider should start moving.\n init(e);\n }\n }\n /**\r\n * Initialize parameters.\r\n *\r\n * @param {TouchEvent|MouseEvent} e - TouchEvent or MouseEvent object.\r\n */\n\n\n function init(e) {\n startCoord = Track.toCoord(Track.position);\n startInfo = analyze(e, {});\n currentInfo = startInfo;\n }\n /**\r\n * Called while the track being dragged.\r\n *\r\n * @param {TouchEvent|MouseEvent} e - TouchEvent or MouseEvent object.\r\n */\n\n\n function move(e) {\n if (startInfo) {\n currentInfo = analyze(e, startInfo);\n\n if (isDragging) {\n if (e.cancelable) {\n e.preventDefault();\n }\n\n if (!Splide.is(FADE)) {\n var position = startCoord[axis] + currentInfo.offset[axis];\n Track.translate(resist(position));\n }\n } else {\n if (shouldMove(currentInfo)) {\n Splide.emit('drag', startInfo);\n isDragging = true;\n Track.cancel(); // These params are actual drag data.\n\n init(e);\n }\n }\n }\n }\n /**\r\n * Determine whether to start moving the track or not by drag angle.\r\n *\r\n * @param {Object} info - An information object.\r\n *\r\n * @return {boolean} - True if the track should be moved or false if not.\r\n */\n\n\n function shouldMove(_ref) {\n var offset = _ref.offset;\n\n if (Splide.State.is(MOVING) && Splide.options.waitForTransition) {\n return false;\n }\n\n var angle = Math.atan(drag_abs(offset.y) / drag_abs(offset.x)) * 180 / Math.PI;\n\n if (isVertical) {\n angle = 90 - angle;\n }\n\n return angle < Splide.options.dragAngleThreshold;\n }\n /**\r\n * Resist dragging the track on the first/last page because there is no more.\r\n *\r\n * @param {number} position - A position being applied to the track.\r\n *\r\n * @return {Object} - Adjusted position.\r\n */\n\n\n function resist(position) {\n if (Splide.is(SLIDE)) {\n var sign = Track.sign;\n\n var _start = sign * Track.trim(Track.toPosition(0));\n\n var _end = sign * Track.trim(Track.toPosition(Controller.edgeIndex));\n\n position *= sign;\n\n if (position < _start) {\n position = _start - FRICTION_REDUCER * Math.log(_start - position);\n } else if (position > _end) {\n position = _end + FRICTION_REDUCER * Math.log(position - _end);\n }\n\n position *= sign;\n }\n\n return position;\n }\n /**\r\n * Called when dragging ends.\r\n */\n\n\n function end() {\n startInfo = null;\n\n if (isDragging) {\n Splide.emit('dragged', currentInfo);\n go(currentInfo);\n isDragging = false;\n }\n }\n /**\r\n * Go to the slide determined by the analyzed data.\r\n *\r\n * @param {Object} info - An info object.\r\n */\n\n\n function go(info) {\n var velocity = info.velocity[axis];\n var absV = drag_abs(velocity);\n\n if (absV > 0) {\n var options = Splide.options;\n var index = Splide.index;\n var sign = velocity < 0 ? -1 : 1;\n var destIndex = index;\n\n if (!Splide.is(FADE)) {\n var destination = Track.position;\n\n if (absV > options.flickVelocityThreshold && drag_abs(info.offset[axis]) < options.swipeDistanceThreshold) {\n destination += sign * Math.min(absV * options.flickPower, Components.Layout.size * (options.flickMaxPages || 1));\n }\n\n destIndex = Track.toIndex(destination);\n }\n /*\r\n * Do not allow the track to go to a previous position if there is enough velocity.\r\n * Always use the adjacent index for the fade mode.\r\n */\n\n\n if (destIndex === index && absV > MIN_VELOCITY) {\n destIndex = index + sign * Track.sign;\n }\n\n if (Splide.is(SLIDE)) {\n destIndex = between(destIndex, 0, Controller.edgeIndex);\n }\n\n Controller.go(destIndex, options.isNavigation);\n }\n }\n /**\r\n * Analyze the given event object and return important information for handling swipe behavior.\r\n *\r\n * @param {Event} e - Touch or Mouse event object.\r\n * @param {Object} startInfo - Information analyzed on start for calculating difference from the current one.\r\n *\r\n * @return {Object} - An object containing analyzed information, such as offset, velocity, etc.\r\n */\n\n\n function analyze(e, startInfo) {\n var timeStamp = e.timeStamp,\n touches = e.touches;\n\n var _ref2 = touches ? touches[0] : e,\n clientX = _ref2.clientX,\n clientY = _ref2.clientY;\n\n var _ref3 = startInfo.to || {},\n _ref3$x = _ref3.x,\n fromX = _ref3$x === void 0 ? clientX : _ref3$x,\n _ref3$y = _ref3.y,\n fromY = _ref3$y === void 0 ? clientY : _ref3$y;\n\n var startTime = startInfo.time || 0;\n var offset = {\n x: clientX - fromX,\n y: clientY - fromY\n };\n var duration = timeStamp - startTime;\n var velocity = {\n x: offset.x / duration,\n y: offset.y / duration\n };\n return {\n to: {\n x: clientX,\n y: clientY\n },\n offset: offset,\n time: timeStamp,\n velocity: velocity\n };\n }\n\n return Drag;\n});\n;// CONCATENATED MODULE: ./src/js/components/click/index.js\n/**\r\n * The component for handling a click event.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * The component for handling a click event.\r\n * Click should be disabled during drag/swipe.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n/* harmony default export */ const click = (function (Splide, Components) {\n /**\r\n * Whether click is disabled or not.\r\n *\r\n * @type {boolean}\r\n */\n var disabled = false;\n /**\r\n * Click component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Click = {\n /**\r\n * Mount only when the drag is activated and the slide type is not \"fade\".\r\n *\r\n * @type {boolean}\r\n */\n required: Splide.options.drag,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n Splide.on('click', onClick, Components.Elements.track, {\n capture: true\n }).on('drag', function () {\n disabled = true;\n }).on('dragged', function () {\n // Make sure the flag is released after the click event is fired.\n setTimeout(function () {\n disabled = false;\n });\n });\n }\n };\n /**\r\n * Called when a track element is clicked.\r\n *\r\n * @param {Event} e - A click event.\r\n */\n\n function onClick(e) {\n if (disabled) {\n e.preventDefault();\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n\n return Click;\n});\n;// CONCATENATED MODULE: ./src/js/components/autoplay/index.js\n/**\r\n * The component for playing slides automatically.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n/**\r\n * Set of pause flags.\r\n */\n\nvar PAUSE_FLAGS = {\n HOVER: 1,\n FOCUS: 2,\n MANUAL: 3\n};\n/**\r\n * The component for playing slides automatically.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n * @param {string} name - A component name as a lowercase string.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const autoplay = (function (Splide, Components, name) {\n /**\r\n * Store pause flags.\r\n *\r\n * @type {Array}\r\n */\n var flags = [];\n /**\r\n * Store an interval object.\r\n *\r\n * @type {Object};\r\n */\n\n var interval;\n /**\r\n * Keep the Elements component.\r\n *\r\n * @type {string}\r\n */\n\n var Elements = Components.Elements;\n /**\r\n * Autoplay component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Autoplay = {\n /**\r\n * Required only when the autoplay option is true.\r\n *\r\n * @type {boolean}\r\n */\n required: Splide.options.autoplay,\n\n /**\r\n * Called when the component is mounted.\r\n * Note that autoplay starts only if there are slides over perPage number.\r\n */\n mount: function mount() {\n var options = Splide.options;\n\n if (Elements.slides.length > options.perPage) {\n interval = createInterval(function () {\n Splide.go('>');\n }, options.interval, function (rate) {\n Splide.emit(name + \":playing\", rate);\n\n if (Elements.bar) {\n applyStyle(Elements.bar, {\n width: rate * 100 + \"%\"\n });\n }\n });\n bind();\n this.play();\n }\n },\n\n /**\r\n * Start autoplay.\r\n *\r\n * @param {number} flag - A pause flag to be removed.\r\n */\n play: function play(flag) {\n if (flag === void 0) {\n flag = 0;\n }\n\n flags = flags.filter(function (f) {\n return f !== flag;\n });\n\n if (!flags.length) {\n Splide.emit(name + \":play\");\n interval.play(Splide.options.resetProgress);\n }\n },\n\n /**\r\n * Pause autoplay.\r\n * Note that Array.includes is not supported by IE.\r\n *\r\n * @param {number} flag - A pause flag to be added.\r\n */\n pause: function pause(flag) {\n if (flag === void 0) {\n flag = 0;\n }\n\n interval.pause();\n\n if (flags.indexOf(flag) === -1) {\n flags.push(flag);\n }\n\n if (flags.length === 1) {\n Splide.emit(name + \":pause\");\n }\n }\n };\n /**\r\n * Listen some events.\r\n */\n\n function bind() {\n var options = Splide.options;\n var sibling = Splide.sibling;\n var elms = [Splide.root, sibling ? sibling.root : null];\n\n if (options.pauseOnHover) {\n switchOn(elms, 'mouseleave', PAUSE_FLAGS.HOVER, true);\n switchOn(elms, 'mouseenter', PAUSE_FLAGS.HOVER, false);\n }\n\n if (options.pauseOnFocus) {\n switchOn(elms, 'focusout', PAUSE_FLAGS.FOCUS, true);\n switchOn(elms, 'focusin', PAUSE_FLAGS.FOCUS, false);\n }\n\n if (Elements.play) {\n Splide.on('click', function () {\n // Need to be removed a focus flag at first.\n Autoplay.play(PAUSE_FLAGS.FOCUS);\n Autoplay.play(PAUSE_FLAGS.MANUAL);\n }, Elements.play);\n }\n\n if (Elements.pause) {\n switchOn([Elements.pause], 'click', PAUSE_FLAGS.MANUAL, false);\n }\n\n Splide.on('move refresh', function () {\n Autoplay.play();\n }) // Rewind the timer.\n .on('destroy', function () {\n Autoplay.pause();\n });\n }\n /**\r\n * Play or pause on the given event.\r\n *\r\n * @param {Element[]} elms - Elements.\r\n * @param {string} event - An event name or names.\r\n * @param {number} flag - A pause flag defined on the top.\r\n * @param {boolean} play - Determine whether to play or pause.\r\n */\n\n\n function switchOn(elms, event, flag, play) {\n elms.forEach(function (elm) {\n Splide.on(event, function () {\n Autoplay[play ? 'play' : 'pause'](flag);\n }, elm);\n });\n }\n\n return Autoplay;\n});\n;// CONCATENATED MODULE: ./src/js/components/cover/index.js\n/**\r\n * The component for change an img element to background image of its wrapper.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * The component for change an img element to background image of its wrapper.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const cover = (function (Splide, Components) {\n /**\r\n * Hold options.\r\n *\r\n * @type {Object}\r\n */\n var options = Splide.options;\n /**\r\n * Cover component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Cover = {\n /**\r\n * Required only when \"cover\" option is true.\r\n *\r\n * @type {boolean}\r\n */\n required: options.cover,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n Splide.on('lazyload:loaded', function (img) {\n cover(img, false);\n });\n Splide.on('mounted updated refresh', function () {\n return apply(false);\n });\n },\n\n /**\r\n * Destroy.\r\n */\n destroy: function destroy() {\n apply(true);\n }\n };\n /**\r\n * Apply \"cover\" to all slides.\r\n *\r\n * @param {boolean} uncover - If true, \"cover\" will be clear.\r\n */\n\n function apply(uncover) {\n Components.Elements.each(function (Slide) {\n var img = child(Slide.slide, 'IMG') || child(Slide.container, 'IMG');\n\n if (img && img.src) {\n cover(img, uncover);\n }\n });\n }\n /**\r\n * Set background image of the parent element, using source of the given image element.\r\n *\r\n * @param {Element} img - An image element.\r\n * @param {boolean} uncover - Reset \"cover\".\r\n */\n\n\n function cover(img, uncover) {\n applyStyle(img.parentElement, {\n background: uncover ? '' : \"center/cover no-repeat url(\\\"\" + img.src + \"\\\")\"\n });\n applyStyle(img, {\n display: uncover ? '' : 'none'\n });\n }\n\n return Cover;\n});\n;// CONCATENATED MODULE: ./src/js/components/arrows/path.js\n/**\r\n * Export vector path for an arrow.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n/**\r\n * Namespace definition for SVG element.\r\n *\r\n * @type {string}\r\n */\nvar XML_NAME_SPACE = 'http://www.w3.org/2000/svg';\n/**\r\n * The arrow vector path.\r\n *\r\n * @type {number}\r\n */\n\nvar PATH = 'm15.5 0.932-4.3 4.38 14.5 14.6-14.5 14.5 4.3 4.4 14.6-14.6 4.4-4.3-4.4-4.4-14.6-14.6z';\n/**\r\n * SVG width and height.\r\n *\r\n * @type {number}\r\n */\n\nvar SIZE = 40;\n;// CONCATENATED MODULE: ./src/js/components/arrows/index.js\n/**\r\n * The component for appending prev/next arrows.\r\n *\r\n * @author Naotoshi Fujita\r\n * @copyright Naotoshi Fujita. All rights reserved.\r\n */\n\n\n\n/**\r\n * The component for appending prev/next arrows.\r\n *\r\n * @param {Splide} Splide - A Splide instance.\r\n * @param {Object} Components - An object containing components.\r\n * @param {string} name - A component name as a lowercase string.\r\n *\r\n * @return {Object} - The component object.\r\n */\n\n/* harmony default export */ const arrows = (function (Splide, Components, name) {\n /**\r\n * Previous arrow element.\r\n *\r\n * @type {Element|undefined}\r\n */\n var prev;\n /**\r\n * Next arrow element.\r\n *\r\n * @type {Element|undefined}\r\n */\n\n var next;\n /**\r\n * Store the class list.\r\n *\r\n * @type {Object}\r\n */\n\n var classes = Splide.classes;\n /**\r\n * Hold the root element.\r\n *\r\n * @type {Element}\r\n */\n\n var root = Splide.root;\n /**\r\n * Whether arrows are created programmatically or not.\r\n *\r\n * @type {boolean}\r\n */\n\n var created;\n /**\r\n * Hold the Elements component.\r\n *\r\n * @type {Object}\r\n */\n\n var Elements = Components.Elements;\n /**\r\n * Arrows component object.\r\n *\r\n * @type {Object}\r\n */\n\n var Arrows = {\n /**\r\n * Required when the arrows option is true.\r\n *\r\n * @type {boolean}\r\n */\n required: Splide.options.arrows,\n\n /**\r\n * Called when the component is mounted.\r\n */\n mount: function mount() {\n // Attempt to get arrows from HTML source.\n prev = Elements.arrows.prev;\n next = Elements.arrows.next; // If arrows were not found in HTML, let's generate them.\n\n if ((!prev || !next) && Splide.options.arrows) {\n prev = createArrow(true);\n next = createArrow(false);\n created = true;\n appendArrows();\n }\n\n if (prev && next) {\n bind();\n }\n\n this.arrows = {\n prev: prev,\n next: next\n };\n },\n\n /**\r\n * Called after all components are mounted.\r\n */\n mounted: function mounted() {\n Splide.emit(name + \":mounted\", prev, next);\n },\n\n /**\r\n * Destroy.\r\n */\n destroy: function destroy() {\n removeAttribute([prev, next], 'disabled');\n\n if (created) {\n dom_remove(prev.parentElement);\n }\n }\n };\n /**\r\n * Listen to native and custom events.\r\n */\n\n function bind() {\n Splide.on('click', function () {\n Splide.go('<');\n }, prev).on('click', function () {\n Splide.go('>');\n }, next).on('mounted move updated refresh', updateDisabled);\n }\n /**\r\n * Update a disabled attribute.\r\n */\n\n\n function updateDisabled() {\n var _Components$Controlle = Components.Controller,\n prevIndex = _Components$Controlle.prevIndex,\n nextIndex = _Components$Controlle.nextIndex;\n var isEnough = Splide.length > Splide.options.perPage || Splide.is(LOOP);\n prev.disabled = prevIndex < 0 || !isEnough;\n next.disabled = nextIndex < 0 || !isEnough;\n Splide.emit(name + \":updated\", prev, next, prevIndex, nextIndex);\n }\n /**\r\n * Create a wrapper element and append arrows.\r\n */\n\n\n function appendArrows() {\n var wrapper = create('div', {\n \"class\": classes.arrows\n });\n append(wrapper, prev);\n append(wrapper, next);\n var slider = Elements.slider;\n var parent = Splide.options.arrows === 'slider' && slider ? slider : root;\n before(wrapper, parent.firstElementChild);\n }\n /**\r\n * Create an arrow element.\r\n *\r\n * @param {boolean} prev - Determine to create a prev arrow or next arrow.\r\n *\r\n * @return {Element} - A created arrow element.\r\n */\n\n\n function createArrow(prev) {\n var arrow = \"