diff --git a/dist/slotmachine.js b/dist/slotmachine.js index 5e560ea..d542e28 100644 --- a/dist/slotmachine.js +++ b/dist/slotmachine.js @@ -9,172 +9,11 @@ root["SlotMachine"] = factory(); })(self, () => { return /******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ 75: -/***/ (function(module) { - -// Generated by CoffeeScript 1.12.2 -(function() { - var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime; - - if ((typeof performance !== "undefined" && performance !== null) && performance.now) { - module.exports = function() { - return performance.now(); - }; - } else if ((typeof process !== "undefined" && process !== null) && process.hrtime) { - module.exports = function() { - return (getNanoSeconds() - nodeLoadTime) / 1e6; - }; - hrtime = process.hrtime; - getNanoSeconds = function() { - var hr; - hr = hrtime(); - return hr[0] * 1e9 + hr[1]; - }; - moduleLoadTime = getNanoSeconds(); - upTime = process.uptime() * 1e9; - nodeLoadTime = moduleLoadTime - upTime; - } else if (Date.now) { - module.exports = function() { - return Date.now() - loadTime; - }; - loadTime = Date.now(); - } else { - module.exports = function() { - return new Date().getTime() - loadTime; - }; - loadTime = new Date().getTime(); - } - -}).call(this); - -//# sourceMappingURL=performance-now.js.map - - -/***/ }), - -/***/ 87: -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -var now = __webpack_require__(75) - , root = typeof window === 'undefined' ? __webpack_require__.g : window - , vendors = ['moz', 'webkit'] - , suffix = 'AnimationFrame' - , raf = root['request' + suffix] - , caf = root['cancel' + suffix] || root['cancelRequest' + suffix] - -for(var i = 0; !raf && i < vendors.length; i++) { - raf = root[vendors[i] + 'Request' + suffix] - caf = root[vendors[i] + 'Cancel' + suffix] - || root[vendors[i] + 'CancelRequest' + suffix] -} - -// Some versions of FF have rAF but not cAF -if(!raf || !caf) { - var last = 0 - , id = 0 - , queue = [] - , frameDuration = 1000 / 60 - - raf = function(callback) { - if(queue.length === 0) { - var _now = now() - , next = Math.max(0, frameDuration - (_now - last)) - last = next + _now - setTimeout(function() { - var cp = queue.slice(0) - // Clear queue here to prevent - // callbacks from appending listeners - // to the current frame's queue - queue.length = 0 - for(var i = 0; i < cp.length; i++) { - if(!cp[i].cancelled) { - try{ - cp[i].callback(last) - } catch(e) { - setTimeout(function() { throw e }, 0) - } - } - } - }, Math.round(next)) - } - queue.push({ - handle: ++id, - callback: callback, - cancelled: false - }) - return id - } - - caf = function(handle) { - for(var i = 0; i < queue.length; i++) { - if(queue[i].handle === handle) { - queue[i].cancelled = true - } - } - } -} - -module.exports = function(fn) { - // Wrap in a new function to prevent - // `cancel` potentially being assigned - // to the native rAF function - return raf.call(root, fn) -} -module.exports.cancel = function() { - caf.apply(root, arguments) -} -module.exports.polyfill = function(object) { - if (!object) { - object = root; - } - object.requestAnimationFrame = raf - object.cancelAnimationFrame = caf -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } +/******/ "use strict"; +/******/ // The require scope +/******/ var __webpack_require__ = {}; /******/ /************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports @@ -187,18 +26,6 @@ module.exports.polyfill = function(object) { /******/ }; /******/ })(); /******/ -/******/ /* webpack/runtime/global */ -/******/ (() => { -/******/ __webpack_require__.g = (function() { -/******/ if (typeof globalThis === 'object') return globalThis; -/******/ try { -/******/ return this || new Function('return this')(); -/******/ } catch (e) { -/******/ if (typeof window === 'object') return window; -/******/ } -/******/ })(); -/******/ })(); -/******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) @@ -206,401 +33,295 @@ module.exports.polyfill = function(object) { /******/ /************************************************************************/ var __webpack_exports__ = {}; -// This entry need to be wrapped in an IIFE because it need to be in strict mode. -(() => { -"use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { - "default": () => (/* binding */ lib) + "default": () => (/* binding */ SlotMachine) }); -// EXTERNAL MODULE: ./node_modules/raf/index.js -var raf = __webpack_require__(87); -var raf_default = /*#__PURE__*/__webpack_require__.n(raf); ;// CONCATENATED MODULE: ./lib/raf.ts - -function raf_raf(cb, timeout = 0) { - setTimeout(() => raf_default()(cb), timeout); +function raf(cb, timeout = 0) { + setTimeout(() => requestAnimationFrame(cb), timeout); } -;// CONCATENATED MODULE: ./lib/timer.ts -class Timer { - constructor(cb, delay) { - this.cb = cb; - this.initialDelay = delay; - this.delay = delay; - this.running = false; - this.resume(); - return this; - } - _start() { - this.timer = setTimeout(() => { - this.running = false; - this.cb(this); - }, this.delay); +;// CONCATENATED MODULE: ./lib/dom.ts +class Container { + constructor(container) { + this.container = container; + this.tiles = []; + this.tileNodes = []; + const tileElements = [].slice.call(this.container.children); + this.container.style.overflow = 'hidden'; + this.element = document.createElement('div'); + this.element.classList.add('slot-machine__container'); + this.element.style.transition = '1s ease-in-out'; + this.container.appendChild(this.element); + this.tiles = [...tileElements].map((element) => new Tile(element)); + this.tileNodes = [ + this.tiles[this.tiles.length - 1].clone(), + ...this.tiles, + this.tiles[0].clone(), + ]; + this.wrapTiles(); + } + wrapTiles() { + this.tileNodes.forEach((tile) => { + this.element.appendChild(tile.element); + }); } - cancel() { - this.running = false; - clearTimeout(this.timer); + get lastTileOffset() { + return this.tiles[0].offset; } - pause() { - if (this.running) { - this.delay -= new Date().getTime() - this.startTime; - this.cancel(); + getTileOffset(index) { + let offset = 0; + for (let i = 0; i < index; i++) { + offset += this.tiles[i].offset; } + return -this.lastTileOffset - offset; } - resume() { - if (!this.running) { - this.running = true; - this.startTime = new Date().getTime(); - this._start(); - } + get maxTopOffset() { + return -1 * (this.tiles.reduce((acc, { offset }) => acc + offset, 0) + this.lastTileOffset); + } +} +class Tile { + constructor(element) { + this.element = element; + this.element.classList.add('slot-machine__tile'); } - reset() { - this.cancel(); - this.delay = this.initialDelay; - this._start(); + clone() { + const element = this.element.cloneNode(true); + return new Tile(element); } - add(extraDelay) { - this.pause(); - this.delay += extraDelay; - this.resume(); + get offset() { + return this.element.offsetHeight; } } -;// CONCATENATED MODULE: ./lib/slot-machine.ts - - -const defaults = { +;// CONCATENATED MODULE: ./lib/constants.ts +function randomInteger(min, max) { + return Math.floor(Math.random() * (max - min + 1)) + min; +} +const DEFAULTS = { active: 0, delay: 200, - auto: false, - spins: 5, - randomize: undefined, - onComplete: undefined, - inViewport: true, + randomize: (_, max) => randomInteger(0, max), direction: 'up', - transition: 'ease-in-out', }; -var FX; -(function (FX) { - FX["NO_TRANSITION"] = "slotMachineNoTransition"; - FX["FAST"] = "slotMachineBlurFast"; - FX["NORMAL"] = "slotMachineBlurMedium"; - FX["SLOW"] = "slotMachineBlurSlow"; - FX["TURTLE"] = "slotMachineBlurTurtle"; - FX["GRADIENT"] = "slotMachineGradient"; - FX["STOP"] = "slotMachineGradient"; -})(FX || (FX = {})); +var CONTAINER_FX; +(function (CONTAINER_FX) { + CONTAINER_FX["GRADIENT"] = "slot-machine__container--gradient"; +})(CONTAINER_FX || (CONTAINER_FX = {})); +var TILE_FX; +(function (TILE_FX) { + TILE_FX["NO_TRANSITION"] = "slot-machine__tile--no-transition"; + TILE_FX["FAST"] = "slot-machine__tile--blur-fast"; + TILE_FX["NORMAL"] = "slot-machine__tile--blur-medium"; + TILE_FX["SLOW"] = "slot-machine__tile--blur-slow"; + TILE_FX["TURTLE"] = "slot-machine__tile--blur-turtle"; + TILE_FX["STOP"] = "slot-machine__tile--gradient"; +})(TILE_FX || (TILE_FX = {})); + +;// CONCATENATED MODULE: ./lib/index.ts + + + +const timeout = (delay) => new Promise((res) => setTimeout(res, delay)); class SlotMachine { constructor(element, options) { - this.element = element; - this.tiles = [].slice.call(this.element.children); this.running = false; this.stopping = false; - this.element.style.overflow = 'hidden'; - this._wrapTiles(); - this._minTop = -this._fakeFirstTile.offsetHeight; - this._maxTop = -this.tiles.reduce((acc, tile) => acc + tile.offsetHeight, 0); - this.changeSettings({ ...defaults, ...options }); - this._setBounds(); + this.element = element; + this.container = new Container(this.element); + this.setOptions(options); + this.active = this.options.active; + this.setupBounds(); this._resetPosition(); - if (this.auto) { - this.run(); - } } - changeSettings(options) { - Object.keys(options).forEach((key) => { - this[key] = options[key]; - }); - } - _wrapTiles() { - this.container = document.createElement('div'); - this.container.classList.add('slotMachineContainer'); - this.container.style.transition = '1s ease-in-out'; - this.element.appendChild(this.container); - this._fakeFirstTile = this.tiles[this.tiles.length - 1].cloneNode(true); - this.container.appendChild(this._fakeFirstTile); - this.tiles.forEach((tile) => { - this.container.appendChild(tile); - }); - this._fakeLastTile = this.tiles[0].cloneNode(true); - this.container.appendChild(this._fakeLastTile); + setOptions(options) { + this.options = { ...DEFAULTS, ...options }; } - _setBounds() { - const initial = this.getTileOffset(this.active); - const first = this.getTileOffset(this.tiles.length); - const last = this.getTileOffset(this.tiles.length); + setupBounds() { + const initial = this.container.getTileOffset(this.active); + const first = this.container.getTileOffset(0); + const last = this.container.getTileOffset(this.container.tiles.length - 1); this._bounds = { up: { - key: 'up', initial, - first: 0, - last, - to: this._maxTop, - firstToLast: last, - lastToFirst: 0, + from: last, + to: 0, + nextReset: 0, + prevReset: this.container.maxTopOffset, }, down: { - key: 'down', initial, - first, - last: 0, - to: this._minTop, - firstToLast: last, - lastToFirst: 0, + from: first, + to: this.container.maxTopOffset, + nextReset: 0, + prevReset: this.container.maxTopOffset, }, }; } + get bounds() { + return this._bounds[this.options.direction]; + } get active() { return this._active; } set active(index) { - if (index < 0 || index >= this.tiles.length || isNaN(index)) { + if (index < 0 || index >= this.container.tiles.length || isNaN(index)) { index = 0; } this._active = index; } - get direction() { - return this._direction; - } - set direction(direction) { - if (this.running) { - return; - } - this._direction = direction === 'down' ? 'down' : 'up'; - } - get bounds() { - return this._bounds[this._direction]; - } get transition() { return this._transition; } set transition(transition) { this._transition = transition || 'ease-in-out'; } - get visibleTile() { - const firstTileHeight = this.tiles[0].offsetHeight; - const rawContainerMargin = this.container.style.transform || ''; - const matrixRegExp = /^matrix\(-?\d+,\s?-?\d+,\s?-?\d+,\s?-?\d+,\s?-?\d+,\s?(-?\d+)\)$/; - const containerMargin = parseInt(rawContainerMargin.replace(matrixRegExp, '$1'), 10); - return Math.abs(Math.round(containerMargin / firstTileHeight)) - 1; - } - get random() { - return Math.floor(Math.random() * this.tiles.length); - } - get custom() { - let choosen = this.random; - if (this.randomize) { - let index = this.randomize(this.active); - if (index < 0 || index >= this.tiles.length) { - index = 0; - } - choosen = index; - } - return choosen; - } get _prevIndex() { const prevIndex = this.active - 1; - return prevIndex < 0 ? this.tiles.length - 1 : prevIndex; + return prevIndex < 0 ? this.container.tiles.length - 1 : prevIndex; } get _nextIndex() { const nextIndex = this.active + 1; - return nextIndex < this.tiles.length ? nextIndex : 0; + return nextIndex < this.container.tiles.length ? nextIndex : 0; } get prevIndex() { - return this.direction === 'up' ? this._nextIndex : this._prevIndex; + return this.options.direction === 'up' ? this._nextIndex : this._prevIndex; } get nextIndex() { - return this.direction === 'up' ? this._prevIndex : this._nextIndex; - } - get visible() { - const rect = this.element.getBoundingClientRect(); - const windowHeight = window.innerHeight || document.documentElement.clientHeight; - const windowWidth = window.innerWidth || document.documentElement.clientWidth; - const vertInView = rect.top <= windowHeight && rect.top + rect.height >= 0; - const horInView = rect.left <= windowWidth && rect.left + rect.width >= 0; - return vertInView && horInView; + return this.options.direction === 'up' ? this._prevIndex : this._nextIndex; } set _animationFX(effect) { - const delay = this.delay / 4; - raf_raf(() => { - [...this.tiles, this._fakeLastTile, this._fakeFirstTile].forEach((tile) => { - tile.classList.remove(FX.FAST, FX.NORMAL, FX.SLOW, FX.TURTLE); - if (effect !== FX.STOP) { + const delay = this.options.delay / 4; + raf(() => { + this.container.tiles + .map(({ element }) => element) + .forEach((tile) => { + tile.classList.remove(TILE_FX.FAST, TILE_FX.NORMAL, TILE_FX.SLOW, TILE_FX.TURTLE); + if (effect !== TILE_FX.STOP) { tile.classList.add(effect); } }); - if (effect === FX.STOP) { - this.container.classList.remove(FX.GRADIENT); + if (effect === TILE_FX.STOP) { + this.container.element.classList.remove(CONTAINER_FX.GRADIENT); } else { - this.container.classList.add(FX.GRADIENT); + this.container.element.classList.add(CONTAINER_FX.GRADIENT); } }, delay); } - _changeTransition(delay = this.delay, transition = this.transition) { - this.container.style.transition = `${delay / 1000}s ${transition}`; + _changeTransition(delay = this.options.delay, transition = this.transition) { + this.container.element.style.transition = `${delay / 1000}s ${transition}`; } _changeTransform(margin) { - this.container.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`; + this.container.element.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`; } _isGoingBackward() { - return !!(this.active === 0 && - this.nextActive === this.tiles.length - 1); + return !!(this.active === 0 && this.nextActive === this.container.tiles.length - 1); } _isGoingForward() { - return !!(this.active === this.tiles.length - 1 && - this.nextActive === 0); - } - getTileOffset(index) { - let offset = 0; - for (let i = 0; i < index; i++) { - offset += this.tiles[i].offsetHeight; - } - return this._minTop - offset; + return !!(this.active === this.container.tiles.length - 1 && this.nextActive === 0); } _resetPosition(margin) { - this.container.classList.toggle(FX.NO_TRANSITION); + this.container.element.classList.toggle(TILE_FX.NO_TRANSITION); this._changeTransform(margin !== undefined ? margin : this.bounds.initial); - this.container.offsetHeight; - this.container.classList.toggle(FX.NO_TRANSITION); + this.container.element.offsetHeight; + this.container.element.classList.toggle(TILE_FX.NO_TRANSITION); } - next() { - this.direction = 'down'; + async next() { this.nextActive = this.nextIndex; this.running = true; - this.stop(); - return this.nextActive; + await this.stop(0); + return this.active; } - prev() { - this.direction = 'up'; - this.nextActive = this.nextIndex; + async prev() { + this.nextActive = this.prevIndex; this.running = true; - this.stop(); - return this.nextActive; + await this.stop(0); + return this.active; } _getDelayFromSpins(spins) { - let delay = this.delay; + let delay = this.options.delay; this.transition = 'linear'; switch (spins) { case 1: delay /= 0.5; this.transition = 'ease-out'; - this._animationFX = FX.TURTLE; + this._animationFX = TILE_FX.TURTLE; break; case 2: delay /= 0.75; - this._animationFX = FX.SLOW; + this._animationFX = TILE_FX.SLOW; break; case 3: delay /= 1; - this._animationFX = FX.NORMAL; + this._animationFX = TILE_FX.NORMAL; break; case 4: delay /= 1.25; - this._animationFX = FX.NORMAL; + this._animationFX = TILE_FX.NORMAL; break; default: delay /= 1.5; - this._animationFX = FX.FAST; + this._animationFX = TILE_FX.FAST; } return delay; } - shuffle(spins, onComplete) { - if (typeof spins === 'function') { - onComplete = spins; + shuffle(spins) { + if (this.running || this.stopping) { + return; } + this.nextActive = this.options.randomize(this.active, this.container.tiles.length); + this.remainingSpins = spins; + return this._shuffle(); + } + async _shuffle() { this.running = true; - if (!this.visible && this.inViewport === true) { - this.stop(onComplete); - } - else { - const delay = this._getDelayFromSpins(spins); - this._changeTransition(delay); - this._changeTransform(this.bounds.to); - raf_raf(() => { - if (!this.stopping && this.running) { - const left = spins - 1; - this._resetPosition(this.bounds.first); - if (left > 1) { - this.shuffle(left, onComplete); - } - else { - this.stop(onComplete); - } - } - }, delay); + const delay = this._getDelayFromSpins(this.remainingSpins); + this._changeTransition(delay); + this._changeTransform(this.bounds.to); + await timeout(delay); + if (!this.stopping && this.running) { + this.remainingSpins--; + this._resetPosition(this.bounds.from); + if (this.remainingSpins > 1) { + await this._shuffle(); + } + else { + await this.stop(0); + } } - return this.nextActive; } - stop(onStop) { + async stop(spins = 0) { if (!this.running || this.stopping) { return this.nextActive; } + if (this.running && !this.stopping && spins) { + this.remainingSpins = spins; + return; + } this.running = true; this.stopping = true; - if (!Number.isInteger(this.nextActive)) { - this.nextActive = this.custom; - } if (this._isGoingBackward()) { - this._resetPosition(this.bounds.firstToLast); + this._resetPosition(this.bounds.prevReset); } else if (this._isGoingForward()) { - this._resetPosition(this.bounds.lastToFirst); + this._resetPosition(this.bounds.nextReset); } this.active = this.nextActive; const delay = this._getDelayFromSpins(1); this._changeTransition(delay); - this._animationFX = FX.STOP; - this._changeTransform(this.getTileOffset(this.active)); - raf_raf(() => { - this.stopping = false; - this.running = false; - this.nextActive = undefined; - if (typeof this.onComplete === 'function') { - this.onComplete(this.active); - } - if (typeof onStop === 'function') { - onStop.apply(this, [this.active]); - } - }, delay); - return this.active; - } - run() { - if (this.running) { - return; - } - this._timer = new Timer(() => { - if (!this.visible && this.inViewport === true) { - raf_raf(() => { - this._timer.reset(); - }, 500); - } - else { - this.shuffle(this.spins, () => { - this._timer.reset(); - }); - } - }, this.delay); - } - destroy() { - this._fakeFirstTile.remove(); - this._fakeLastTile.remove(); - this.tiles.forEach((tile) => { - this.element.appendChild(tile); - }); - this.container.remove(); + this._animationFX = TILE_FX.STOP; + this._changeTransform(this.container.getTileOffset(this.active)); + await timeout(delay); + this.stopping = false; + this.running = false; + this.nextActive = undefined; } } -;// CONCATENATED MODULE: ./lib/index.ts - -/* harmony default export */ const lib = (SlotMachine); - -})(); - __webpack_exports__ = __webpack_exports__["default"]; /******/ return __webpack_exports__; /******/ })() diff --git a/dist/slotmachine.js.map b/dist/slotmachine.js.map index 139956a..48dca52 100644 --- a/dist/slotmachine.js.map +++ b/dist/slotmachine.js.map @@ -1 +1 @@ -{"version":3,"file":"slotmachine.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;ACVA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;;;;;;;;ACnCA,UAAU,mBAAO,CAAC,EAAiB;AACnC,2CAA2C,qBAAM;AACjD;AACA;AACA;AACA;;AAEA,eAAe,4BAA4B;AAC3C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,eAAe;AACtC;AACA;AACA;AACA,cAAc;AACd,sCAAsC,SAAS;AAC/C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;;;;;;;UC1EA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC;;;;;WCPD;;;;;;;;;;;;;;;;;;ACAwC;AAGzB,SAAS,OAAG,CAAC,EAAY,EAAE,OAAO,GAAG,CAAC;IACnD,UAAU,CAAC,GAAG,EAAE,CAAC,aAAqB,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;AACvD,CAAC;;;ACHc,MAAM,KAAK;I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","sources":["webpack://SlotMachine/webpack/universalModuleDefinition","webpack://SlotMachine/./node_modules/performance-now/lib/performance-now.js","webpack://SlotMachine/./node_modules/raf/index.js","webpack://SlotMachine/webpack/bootstrap","webpack://SlotMachine/webpack/runtime/compat get default export","webpack://SlotMachine/webpack/runtime/define property getters","webpack://SlotMachine/webpack/runtime/global","webpack://SlotMachine/webpack/runtime/hasOwnProperty shorthand","webpack://SlotMachine/./lib/raf.ts","webpack://SlotMachine/./lib/timer.ts","webpack://SlotMachine/./lib/slot-machine.ts","webpack://SlotMachine/./lib/index.ts"],"sourcesContent":["(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(\"SlotMachine\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"SlotMachine\"] = factory();\n\telse\n\t\troot[\"SlotMachine\"] = factory();\n})(self, () => {\nreturn ","// Generated by CoffeeScript 1.12.2\n(function() {\n var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n module.exports = function() {\n return performance.now();\n };\n } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n module.exports = function() {\n return (getNanoSeconds() - nodeLoadTime) / 1e6;\n };\n hrtime = process.hrtime;\n getNanoSeconds = function() {\n var hr;\n hr = hrtime();\n return hr[0] * 1e9 + hr[1];\n };\n moduleLoadTime = getNanoSeconds();\n upTime = process.uptime() * 1e9;\n nodeLoadTime = moduleLoadTime - upTime;\n } else if (Date.now) {\n module.exports = function() {\n return Date.now() - loadTime;\n };\n loadTime = Date.now();\n } else {\n module.exports = function() {\n return new Date().getTime() - loadTime;\n };\n loadTime = new Date().getTime();\n }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","var now = require('performance-now')\n , root = typeof window === 'undefined' ? global : window\n , vendors = ['moz', 'webkit']\n , suffix = 'AnimationFrame'\n , raf = root['request' + suffix]\n , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n raf = root[vendors[i] + 'Request' + suffix]\n caf = root[vendors[i] + 'Cancel' + suffix]\n || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n var last = 0\n , id = 0\n , queue = []\n , frameDuration = 1000 / 60\n\n raf = function(callback) {\n if(queue.length === 0) {\n var _now = now()\n , next = Math.max(0, frameDuration - (_now - last))\n last = next + _now\n setTimeout(function() {\n var cp = queue.slice(0)\n // Clear queue here to prevent\n // callbacks from appending listeners\n // to the current frame's queue\n queue.length = 0\n for(var i = 0; i < cp.length; i++) {\n if(!cp[i].cancelled) {\n try{\n cp[i].callback(last)\n } catch(e) {\n setTimeout(function() { throw e }, 0)\n }\n }\n }\n }, Math.round(next))\n }\n queue.push({\n handle: ++id,\n callback: callback,\n cancelled: false\n })\n return id\n }\n\n caf = function(handle) {\n for(var i = 0; i < queue.length; i++) {\n if(queue[i].handle === handle) {\n queue[i].cancelled = true\n }\n }\n }\n}\n\nmodule.exports = function(fn) {\n // Wrap in a new function to prevent\n // `cancel` potentially being assigned\n // to the native rAF function\n return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function(object) {\n if (!object) {\n object = root;\n }\n object.requestAnimationFrame = raf\n object.cancelAnimationFrame = caf\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import requestAnimationFrame from 'raf';\nimport { Callback } from './types';\n\nexport default function raf(cb: Callback, timeout = 0) {\n setTimeout(() => requestAnimationFrame(cb), timeout);\n}\n","import { Callback } from './types';\n\nexport default class Timer {\n cb: Callback;\n initialDelay: number;\n delay: number;\n startTime: number;\n timer: NodeJS.Timeout;\n running: boolean;\n\n constructor(cb: Callback, delay: number) {\n this.cb = cb;\n this.initialDelay = delay;\n this.delay = delay;\n this.running = false;\n\n this.resume();\n\n return this;\n }\n\n _start() {\n this.timer = setTimeout(() => {\n this.running = false;\n this.cb(this);\n }, this.delay);\n }\n\n cancel() {\n this.running = false;\n clearTimeout(this.timer);\n }\n\n pause() {\n if (this.running) {\n this.delay -= new Date().getTime() - this.startTime;\n this.cancel();\n }\n }\n\n resume() {\n if (!this.running) {\n this.running = true;\n this.startTime = new Date().getTime();\n\n this._start();\n }\n }\n\n reset() {\n this.cancel();\n this.delay = this.initialDelay;\n this._start();\n }\n\n add(extraDelay: number) {\n this.pause();\n this.delay += extraDelay;\n this.resume();\n }\n}\n","import raf from './raf';\nimport Timer from './timer';\n\nexport type RandomizeCallback = (active: number) => number;\nexport type OnCompleteCallback = (active: number) => any;\n\nexport type Direction = 'up' | 'down';\n\nexport type Bound = {\n key: Direction;\n initial: number;\n first: number;\n last: number;\n to: number;\n firstToLast: number;\n lastToFirst: number;\n};\n\nexport type Bounds = Record;\n\nexport type Options = {\n active?: number;\n delay?: number;\n auto?: boolean;\n spins?: number;\n randomize?: RandomizeCallback;\n onComplete?: OnCompleteCallback;\n inViewport?: boolean;\n direction?: Direction;\n transition?: string;\n};\n\nconst defaults: Options = {\n active: 0, // Active element [Number]\n delay: 200, // Animation time [Number]\n auto: false, // Repeat delay [false||Number]\n spins: 5, // Number of spins when auto [Number]\n randomize: undefined, // Randomize function, must return a number with the selected position\n onComplete: undefined, // Callback function(result)\n inViewport: true, // Stops animations if the element isn´t visible on the screen\n direction: 'up', // Animation direction ['up'||'down']\n transition: 'ease-in-out',\n};\n\nexport enum FX {\n NO_TRANSITION = 'slotMachineNoTransition',\n FAST = 'slotMachineBlurFast',\n NORMAL = 'slotMachineBlurMedium',\n SLOW = 'slotMachineBlurSlow',\n TURTLE = 'slotMachineBlurTurtle',\n GRADIENT = 'slotMachineGradient',\n STOP = 'slotMachineGradient',\n}\n\nexport default class SlotMachine implements Options {\n container: HTMLElement;\n element: HTMLElement;\n tiles: HTMLElement[];\n running: boolean;\n stopping: boolean;\n nextActive?: number;\n\n // options\n delay: number;\n auto: boolean;\n spins: number;\n randomize?: RandomizeCallback;\n onComplete?: OnCompleteCallback;\n inViewport: boolean;\n\n private _active: number;\n private _minTop: number;\n private _maxTop: number;\n private _fakeFirstTile: HTMLElement;\n private _fakeLastTile: HTMLElement;\n private _bounds: Bounds;\n private _direction: Direction;\n private _transition: string;\n private _timer: Timer;\n\n constructor(element: HTMLElement, options: Options) {\n this.element = element;\n // Slot Machine elements\n this.tiles = [].slice.call(this.element.children) as HTMLElement[];\n // Machine is running?\n this.running = false;\n // Machine is stopping?\n this.stopping = false;\n // Disable overflow\n this.element.style.overflow = 'hidden';\n // Wrap elements inside container\n this._wrapTiles();\n // Set min top offset\n this._minTop = -this._fakeFirstTile.offsetHeight;\n // Set max top offset\n this._maxTop = -this.tiles.reduce((acc, tile) => acc + tile.offsetHeight, 0);\n // Call setters if neccesary\n this.changeSettings({ ...defaults, ...options });\n // Initialize spin direction [up, down]\n this._setBounds();\n // Show active element\n this._resetPosition();\n // Start auto animation\n if (this.auto) {\n this.run();\n }\n }\n\n changeSettings(options: Options) {\n Object.keys(options).forEach((key) => {\n // Trigger setters\n this[key] = options[key]; /* @ts-ignore */\n });\n }\n\n _wrapTiles() {\n this.container = document.createElement('div');\n this.container.classList.add('slotMachineContainer');\n this.container.style.transition = '1s ease-in-out';\n this.element.appendChild(this.container);\n\n this._fakeFirstTile = this.tiles[this.tiles.length - 1].cloneNode(true) as HTMLElement;\n this.container.appendChild(this._fakeFirstTile);\n\n this.tiles.forEach((tile) => {\n this.container.appendChild(tile);\n });\n\n this._fakeLastTile = this.tiles[0].cloneNode(true) as HTMLElement;\n this.container.appendChild(this._fakeLastTile);\n }\n\n _setBounds() {\n const initial = this.getTileOffset(this.active);\n const first = this.getTileOffset(this.tiles.length);\n const last = this.getTileOffset(this.tiles.length);\n\n this._bounds = {\n up: {\n key: 'up',\n initial,\n first: 0,\n last,\n to: this._maxTop,\n firstToLast: last,\n lastToFirst: 0,\n },\n down: {\n key: 'down',\n initial,\n first,\n last: 0,\n to: this._minTop,\n firstToLast: last,\n lastToFirst: 0,\n },\n };\n }\n\n get active() {\n return this._active;\n }\n\n set active(index: number) {\n if (index < 0 || index >= this.tiles.length || isNaN(index)) {\n index = 0;\n }\n\n this._active = index;\n }\n\n get direction() {\n return this._direction;\n }\n\n set direction(direction: Direction) {\n if (this.running) {\n return;\n }\n\n this._direction = direction === 'down' ? 'down' : 'up';\n }\n\n get bounds() {\n return this._bounds[this._direction];\n }\n\n get transition() {\n return this._transition;\n }\n\n set transition(transition: string) {\n this._transition = transition || 'ease-in-out';\n }\n\n get visibleTile() {\n const firstTileHeight = this.tiles[0].offsetHeight;\n const rawContainerMargin = this.container.style.transform || '';\n const matrixRegExp = /^matrix\\(-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?(-?\\d+)\\)$/;\n const containerMargin = parseInt(rawContainerMargin.replace(matrixRegExp, '$1'), 10);\n\n return Math.abs(Math.round(containerMargin / firstTileHeight)) - 1;\n }\n\n get random() {\n return Math.floor(Math.random() * this.tiles.length);\n }\n\n get custom() {\n let choosen = this.random;\n\n if (this.randomize) {\n let index = this.randomize(this.active);\n if (index < 0 || index >= this.tiles.length) {\n index = 0;\n }\n choosen = index;\n }\n\n return choosen;\n }\n\n get _prevIndex() {\n const prevIndex = this.active - 1;\n\n return prevIndex < 0 ? this.tiles.length - 1 : prevIndex;\n }\n\n get _nextIndex() {\n const nextIndex = this.active + 1;\n\n return nextIndex < this.tiles.length ? nextIndex : 0;\n }\n\n get prevIndex() {\n return this.direction === 'up' ? this._nextIndex : this._prevIndex;\n }\n\n get nextIndex() {\n return this.direction === 'up' ? this._prevIndex : this._nextIndex;\n }\n\n get visible() {\n const rect = this.element.getBoundingClientRect();\n const windowHeight = window.innerHeight || document.documentElement.clientHeight;\n const windowWidth = window.innerWidth || document.documentElement.clientWidth;\n const vertInView = rect.top <= windowHeight && rect.top + rect.height >= 0;\n const horInView = rect.left <= windowWidth && rect.left + rect.width >= 0;\n\n return vertInView && horInView;\n }\n\n set _animationFX(effect: FX) {\n const delay = this.delay / 4;\n\n raf(() => {\n [...this.tiles, this._fakeLastTile, this._fakeFirstTile].forEach((tile) => {\n tile.classList.remove(FX.FAST, FX.NORMAL, FX.SLOW, FX.TURTLE);\n if (effect !== FX.STOP) {\n tile.classList.add(effect);\n }\n });\n\n if (effect === FX.STOP) {\n this.container.classList.remove(FX.GRADIENT);\n } else {\n this.container.classList.add(FX.GRADIENT);\n }\n }, delay);\n }\n\n _changeTransition(delay = this.delay, transition = this.transition) {\n this.container.style.transition = `${delay / 1000}s ${transition}`;\n }\n\n _changeTransform(margin: number) {\n this.container.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`;\n }\n\n _isGoingBackward() {\n return !!(\n this.active === 0 &&\n this.nextActive === this.tiles.length - 1\n );\n }\n\n _isGoingForward() {\n return !!(\n this.active === this.tiles.length - 1 &&\n this.nextActive === 0\n );\n }\n\n getTileOffset(index: number) {\n let offset = 0;\n\n for (let i = 0; i < index; i++) {\n offset += this.tiles[i].offsetHeight;\n }\n\n return this._minTop - offset;\n }\n\n _resetPosition(margin?: number) {\n this.container.classList.toggle(FX.NO_TRANSITION);\n this._changeTransform(margin !== undefined ? margin : this.bounds.initial);\n // Force reflow, flushing the CSS changes\n this.container.offsetHeight;\n this.container.classList.toggle(FX.NO_TRANSITION);\n }\n\n next() {\n this.direction = 'down';\n this.nextActive = this.nextIndex;\n this.running = true;\n this.stop();\n\n return this.nextActive;\n }\n\n prev() {\n this.direction = 'up';\n this.nextActive = this.nextIndex;\n this.running = true;\n this.stop();\n\n return this.nextActive;\n }\n\n _getDelayFromSpins(spins: number) {\n let delay = this.delay;\n this.transition = 'linear';\n\n switch (spins) {\n case 1:\n delay /= 0.5;\n this.transition = 'ease-out';\n this._animationFX = FX.TURTLE;\n break;\n case 2:\n delay /= 0.75;\n this._animationFX = FX.SLOW;\n break;\n case 3:\n delay /= 1;\n this._animationFX = FX.NORMAL;\n break;\n case 4:\n delay /= 1.25;\n this._animationFX = FX.NORMAL;\n break;\n default:\n delay /= 1.5;\n this._animationFX = FX.FAST;\n }\n\n return delay;\n }\n\n shuffle(spins: number, onComplete: OnCompleteCallback) {\n // Make spins optional\n if (typeof spins === 'function') {\n onComplete = spins;\n }\n this.running = true;\n // Perform animation\n if (!this.visible && this.inViewport === true) {\n this.stop(onComplete);\n } else {\n const delay = this._getDelayFromSpins(spins);\n // this.delay = delay;\n this._changeTransition(delay);\n this._changeTransform(this.bounds.to);\n raf(() => {\n if (!this.stopping && this.running) {\n const left = spins - 1;\n\n this._resetPosition(this.bounds.first);\n\n if (left > 1) {\n // Repeat animation\n this.shuffle(left, onComplete);\n } else {\n this.stop(onComplete);\n }\n }\n }, delay);\n }\n\n return this.nextActive;\n }\n\n stop(onStop?: OnCompleteCallback) {\n if (!this.running || this.stopping) {\n return this.nextActive;\n }\n\n this.running = true;\n this.stopping = true;\n\n if (!Number.isInteger(this.nextActive)) {\n // Get random or custom element\n this.nextActive = this.custom;\n }\n\n // Check direction to prevent jumping\n if (this._isGoingBackward()) {\n this._resetPosition(this.bounds.firstToLast);\n } else if (this._isGoingForward()) {\n this._resetPosition(this.bounds.lastToFirst);\n }\n\n // Update last choosen element index\n this.active = this.nextActive as number;\n\n // Perform animation\n const delay = this._getDelayFromSpins(1);\n // this.delay = delay;\n this._changeTransition(delay);\n this._animationFX = FX.STOP;\n this._changeTransform(this.getTileOffset(this.active));\n raf(() => {\n this.stopping = false;\n this.running = false;\n this.nextActive = undefined;\n\n if (typeof this.onComplete === 'function') {\n this.onComplete(this.active);\n }\n\n if (typeof onStop === 'function') {\n onStop.apply(this, [this.active]);\n }\n }, delay);\n\n return this.active;\n }\n\n run() {\n if (this.running) {\n return;\n }\n\n this._timer = new Timer(() => {\n if (!this.visible && this.inViewport === true) {\n raf(() => {\n this._timer.reset();\n }, 500);\n } else {\n this.shuffle(this.spins, () => {\n this._timer.reset();\n });\n }\n }, this.delay);\n }\n\n destroy() {\n this._fakeFirstTile.remove();\n this._fakeLastTile.remove();\n // this.$tiles.unwrap();\n\n // Unwrap tiles\n this.tiles.forEach((tile) => {\n this.element.appendChild(tile);\n });\n\n this.container.remove();\n }\n}\n","import SlotMachine from './slot-machine';\n\nexport default SlotMachine;\n"],"names":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"slotmachine.js","mappings":"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","sources":["webpack://SlotMachine/webpack/universalModuleDefinition","webpack://SlotMachine/webpack/bootstrap","webpack://SlotMachine/webpack/runtime/define property getters","webpack://SlotMachine/webpack/runtime/hasOwnProperty shorthand","webpack://SlotMachine/./lib/raf.ts","webpack://SlotMachine/./lib/dom.ts","webpack://SlotMachine/./lib/constants.ts","webpack://SlotMachine/./lib/index.ts"],"sourcesContent":["(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(\"SlotMachine\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"SlotMachine\"] = factory();\n\telse\n\t\troot[\"SlotMachine\"] = factory();\n})(self, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import { Callback } from './types';\n\nexport default function raf(cb: Callback, timeout = 0) {\n setTimeout(() => requestAnimationFrame(cb), timeout);\n}\n","export class Container {\n element: HTMLElement;\n tiles: Tile[] = [];\n tileNodes: Tile[] = [];\n\n constructor(public container: HTMLElement) {\n const tileElements = [].slice.call(this.container.children) as HTMLElement[];\n\n this.container.style.overflow = 'hidden';\n this.element = document.createElement('div');\n this.element.classList.add('slot-machine__container');\n this.element.style.transition = '1s ease-in-out';\n this.container.appendChild(this.element);\n this.tiles = [...tileElements].map((element) => new Tile(element));\n this.tileNodes = [\n this.tiles[this.tiles.length - 1].clone(),\n ...this.tiles,\n this.tiles[0].clone(),\n ];\n this.wrapTiles();\n }\n\n private wrapTiles() {\n this.tileNodes.forEach((tile) => {\n this.element.appendChild(tile.element);\n });\n }\n\n private get lastTileOffset() {\n return this.tiles[0].offset;\n }\n\n getTileOffset(index: number) {\n let offset = 0;\n\n for (let i = 0; i < index; i++) {\n offset += this.tiles[i].offset;\n }\n\n return -this.lastTileOffset - offset;\n }\n\n get maxTopOffset() {\n return -1 * (this.tiles.reduce((acc, { offset }) => acc + offset, 0) + this.lastTileOffset);\n }\n}\n\nexport class Tile {\n constructor(public element: HTMLElement) {\n this.element.classList.add('slot-machine__tile');\n }\n\n clone() {\n const element = this.element.cloneNode(true) as HTMLElement;\n\n return new Tile(element);\n }\n\n get offset() {\n return this.element.offsetHeight;\n }\n}\n","import { Options } from './types';\n\nfunction randomInteger(min: number, max: number) {\n return Math.floor(Math.random() * (max - min + 1)) + min;\n}\n\nexport const DEFAULTS: Required = {\n active: 0, // Active element [Number]\n delay: 200, // Animation time [Number]\n randomize: (_, max) => randomInteger(0, max), // Randomize function, must return a number with the selected position\n direction: 'up', // Animation direction ['up'||'down']\n};\n\nexport enum CONTAINER_FX {\n GRADIENT = 'slot-machine__container--gradient',\n}\n\nexport enum TILE_FX {\n NO_TRANSITION = 'slot-machine__tile--no-transition',\n FAST = 'slot-machine__tile--blur-fast',\n NORMAL = 'slot-machine__tile--blur-medium',\n SLOW = 'slot-machine__tile--blur-slow',\n TURTLE = 'slot-machine__tile--blur-turtle',\n STOP = 'slot-machine__tile--gradient',\n}\n","import raf from './raf';\nimport { Container } from './dom';\nimport type { Bounds, Options } from './types';\nimport { DEFAULTS, TILE_FX, CONTAINER_FX } from './constants';\n\nconst timeout = (delay: number) => new Promise((res) => setTimeout(res, delay));\n\nexport default class SlotMachine {\n container: Container;\n element: HTMLElement;\n running = false;\n stopping = false;\n nextActive?: number;\n\n private remainingSpins: number;\n private options: Required;\n private _active: number;\n private _bounds: Bounds;\n private _transition: string;\n\n constructor(element: HTMLElement, options: Options) {\n this.element = element;\n // Setup DOM\n this.container = new Container(this.element);\n // Set plugin options\n this.setOptions(options);\n this.active = this.options.active;\n this.setupBounds();\n // Show active element\n this._resetPosition();\n }\n\n setOptions(options: Options) {\n this.options = { ...DEFAULTS, ...options };\n }\n\n private setupBounds() {\n const initial = this.container.getTileOffset(this.active);\n const first = this.container.getTileOffset(0);\n const last = this.container.getTileOffset(this.container.tiles.length - 1);\n\n this._bounds = {\n up: {\n initial,\n from: last,\n to: 0,\n nextReset: 0,\n prevReset: this.container.maxTopOffset,\n },\n down: {\n initial,\n from: first,\n to: this.container.maxTopOffset,\n nextReset: 0,\n prevReset: this.container.maxTopOffset,\n },\n };\n }\n\n get bounds() {\n return this._bounds[this.options.direction];\n }\n\n get active() {\n return this._active;\n }\n\n set active(index: number) {\n if (index < 0 || index >= this.container.tiles.length || isNaN(index)) {\n index = 0;\n }\n\n this._active = index;\n }\n\n private get transition() {\n return this._transition;\n }\n\n private set transition(transition: string) {\n this._transition = transition || 'ease-in-out';\n }\n\n get _prevIndex() {\n const prevIndex = this.active - 1;\n\n return prevIndex < 0 ? this.container.tiles.length - 1 : prevIndex;\n }\n\n get _nextIndex() {\n const nextIndex = this.active + 1;\n\n return nextIndex < this.container.tiles.length ? nextIndex : 0;\n }\n\n get prevIndex() {\n return this.options.direction === 'up' ? this._nextIndex : this._prevIndex;\n }\n\n get nextIndex() {\n return this.options.direction === 'up' ? this._prevIndex : this._nextIndex;\n }\n\n set _animationFX(effect: TILE_FX) {\n const delay = this.options.delay / 4;\n\n raf(() => {\n this.container.tiles\n .map(({ element }) => element)\n .forEach((tile) => {\n tile.classList.remove(TILE_FX.FAST, TILE_FX.NORMAL, TILE_FX.SLOW, TILE_FX.TURTLE);\n if (effect !== TILE_FX.STOP) {\n tile.classList.add(effect);\n }\n });\n\n if (effect === TILE_FX.STOP) {\n this.container.element.classList.remove(CONTAINER_FX.GRADIENT);\n } else {\n this.container.element.classList.add(CONTAINER_FX.GRADIENT);\n }\n }, delay);\n }\n\n _changeTransition(delay = this.options.delay, transition = this.transition) {\n this.container.element.style.transition = `${delay / 1000}s ${transition}`;\n }\n\n _changeTransform(margin: number) {\n this.container.element.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`;\n }\n\n _isGoingBackward() {\n return !!(this.active === 0 && this.nextActive === this.container.tiles.length - 1);\n }\n\n _isGoingForward() {\n return !!(this.active === this.container.tiles.length - 1 && this.nextActive === 0);\n }\n\n _resetPosition(margin?: number) {\n this.container.element.classList.toggle(TILE_FX.NO_TRANSITION);\n this._changeTransform(margin !== undefined ? margin : this.bounds.initial);\n // Force reflow, flushing the CSS changes\n this.container.element.offsetHeight;\n this.container.element.classList.toggle(TILE_FX.NO_TRANSITION);\n }\n\n async next() {\n this.nextActive = this.nextIndex;\n this.running = true;\n await this.stop(0);\n\n return this.active;\n }\n\n async prev() {\n this.nextActive = this.prevIndex;\n this.running = true;\n await this.stop(0);\n\n return this.active;\n }\n\n _getDelayFromSpins(spins: number) {\n let delay = this.options.delay;\n this.transition = 'linear';\n\n switch (spins) {\n case 1:\n delay /= 0.5;\n this.transition = 'ease-out';\n this._animationFX = TILE_FX.TURTLE;\n break;\n case 2:\n delay /= 0.75;\n this._animationFX = TILE_FX.SLOW;\n break;\n case 3:\n delay /= 1;\n this._animationFX = TILE_FX.NORMAL;\n break;\n case 4:\n delay /= 1.25;\n this._animationFX = TILE_FX.NORMAL;\n break;\n default:\n delay /= 1.5;\n this._animationFX = TILE_FX.FAST;\n }\n\n return delay;\n }\n\n shuffle(spins: number) {\n if (this.running || this.stopping) {\n return;\n }\n\n this.nextActive = this.options.randomize(this.active, this.container.tiles.length);\n this.remainingSpins = spins;\n\n return this._shuffle();\n }\n\n private async _shuffle() {\n this.running = true;\n // Perform animation\n const delay = this._getDelayFromSpins(this.remainingSpins);\n this._changeTransition(delay);\n this._changeTransform(this.bounds.to);\n\n await timeout(delay);\n\n if (!this.stopping && this.running) {\n this.remainingSpins--;\n\n this._resetPosition(this.bounds.from);\n\n if (this.remainingSpins > 1) {\n // Repeat animation\n await this._shuffle();\n } else {\n await this.stop(0);\n }\n }\n }\n\n async stop(spins = 0) {\n if (!this.running || this.stopping) {\n return this.nextActive;\n }\n\n if (this.running && !this.stopping && spins) {\n this.remainingSpins = spins;\n return;\n }\n\n this.running = true;\n this.stopping = true;\n\n // Check direction to prevent jumping\n if (this._isGoingBackward()) {\n this._resetPosition(this.bounds.prevReset);\n } else if (this._isGoingForward()) {\n this._resetPosition(this.bounds.nextReset);\n }\n\n // Update last choosen element index\n this.active = this.nextActive as number;\n\n // Perform animation\n const delay = this._getDelayFromSpins(1);\n this._changeTransition(delay);\n this._animationFX = TILE_FX.STOP;\n this._changeTransform(this.container.getTileOffset(this.active));\n\n await timeout(delay);\n\n this.stopping = false;\n this.running = false;\n this.nextActive = undefined;\n }\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/slotmachine.min.js b/dist/slotmachine.min.js index 380d31b..01cbed5 100644 --- a/dist/slotmachine.min.js +++ b/dist/slotmachine.min.js @@ -1,2 +1,2 @@ -!function(t,i){"object"==typeof exports&&"object"==typeof module?module.exports=i():"function"==typeof define&&define.amd?define("SlotMachine",[],i):"object"==typeof exports?exports.SlotMachine=i():t.SlotMachine=i()}(self,(()=>(()=>{var t={75:function(t){(function(){var i,e,s,n,r,o;"undefined"!=typeof performance&&null!==performance&&performance.now?t.exports=function(){return performance.now()}:"undefined"!=typeof process&&null!==process&&process.hrtime?(t.exports=function(){return(i()-r)/1e6},e=process.hrtime,n=(i=function(){var t;return 1e9*(t=e())[0]+t[1]})(),o=1e9*process.uptime(),r=n-o):Date.now?(t.exports=function(){return Date.now()-s},s=Date.now()):(t.exports=function(){return(new Date).getTime()-s},s=(new Date).getTime())}).call(this)},87:(t,i,e)=>{for(var s=e(75),n="undefined"==typeof window?e.g:window,r=["moz","webkit"],o="AnimationFrame",h=n["request"+o],a=n["cancel"+o]||n["cancelRequest"+o],l=0;!h&&l{var i=t&&t.__esModule?()=>t.default:()=>t;return e.d(i,{a:i}),i},e.d=(t,i)=>{for(var s in i)e.o(i,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:i[s]})},e.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),e.o=(t,i)=>Object.prototype.hasOwnProperty.call(t,i);var s={};return(()=>{"use strict";e.d(s,{default:()=>a});var t=e(87),i=e.n(t);function n(t,e=0){setTimeout((()=>i()(t)),e)}class r{constructor(t,i){return this.cb=t,this.initialDelay=i,this.delay=i,this.running=!1,this.resume(),this}_start(){this.timer=setTimeout((()=>{this.running=!1,this.cb(this)}),this.delay)}cancel(){this.running=!1,clearTimeout(this.timer)}pause(){this.running&&(this.delay-=(new Date).getTime()-this.startTime,this.cancel())}resume(){this.running||(this.running=!0,this.startTime=(new Date).getTime(),this._start())}reset(){this.cancel(),this.delay=this.initialDelay,this._start()}add(t){this.pause(),this.delay+=t,this.resume()}}const o={active:0,delay:200,auto:!1,spins:5,randomize:void 0,onComplete:void 0,inViewport:!0,direction:"up",transition:"ease-in-out"};var h;!function(t){t.NO_TRANSITION="slotMachineNoTransition",t.FAST="slotMachineBlurFast",t.NORMAL="slotMachineBlurMedium",t.SLOW="slotMachineBlurSlow",t.TURTLE="slotMachineBlurTurtle",t.GRADIENT="slotMachineGradient",t.STOP="slotMachineGradient"}(h||(h={}));const a=class{constructor(t,i){this.element=t,this.tiles=[].slice.call(this.element.children),this.running=!1,this.stopping=!1,this.element.style.overflow="hidden",this._wrapTiles(),this._minTop=-this._fakeFirstTile.offsetHeight,this._maxTop=-this.tiles.reduce(((t,i)=>t+i.offsetHeight),0),this.changeSettings({...o,...i}),this._setBounds(),this._resetPosition(),this.auto&&this.run()}changeSettings(t){Object.keys(t).forEach((i=>{this[i]=t[i]}))}_wrapTiles(){this.container=document.createElement("div"),this.container.classList.add("slotMachineContainer"),this.container.style.transition="1s ease-in-out",this.element.appendChild(this.container),this._fakeFirstTile=this.tiles[this.tiles.length-1].cloneNode(!0),this.container.appendChild(this._fakeFirstTile),this.tiles.forEach((t=>{this.container.appendChild(t)})),this._fakeLastTile=this.tiles[0].cloneNode(!0),this.container.appendChild(this._fakeLastTile)}_setBounds(){const t=this.getTileOffset(this.active),i=this.getTileOffset(this.tiles.length),e=this.getTileOffset(this.tiles.length);this._bounds={up:{key:"up",initial:t,first:0,last:e,to:this._maxTop,firstToLast:e,lastToFirst:0},down:{key:"down",initial:t,first:i,last:0,to:this._minTop,firstToLast:e,lastToFirst:0}}}get active(){return this._active}set active(t){(t<0||t>=this.tiles.length||isNaN(t))&&(t=0),this._active=t}get direction(){return this._direction}set direction(t){this.running||(this._direction="down"===t?"down":"up")}get bounds(){return this._bounds[this._direction]}get transition(){return this._transition}set transition(t){this._transition=t||"ease-in-out"}get visibleTile(){const t=this.tiles[0].offsetHeight,i=this.container.style.transform||"",e=parseInt(i.replace(/^matrix\(-?\d+,\s?-?\d+,\s?-?\d+,\s?-?\d+,\s?-?\d+,\s?(-?\d+)\)$/,"$1"),10);return Math.abs(Math.round(e/t))-1}get random(){return Math.floor(Math.random()*this.tiles.length)}get custom(){let t=this.random;if(this.randomize){let i=this.randomize(this.active);(i<0||i>=this.tiles.length)&&(i=0),t=i}return t}get _prevIndex(){const t=this.active-1;return t<0?this.tiles.length-1:t}get _nextIndex(){const t=this.active+1;return t=0,n=t.left<=e&&t.left+t.width>=0;return s&&n}set _animationFX(t){n((()=>{[...this.tiles,this._fakeLastTile,this._fakeFirstTile].forEach((i=>{i.classList.remove(h.FAST,h.NORMAL,h.SLOW,h.TURTLE),t!==h.STOP&&i.classList.add(t)})),t===h.STOP?this.container.classList.remove(h.GRADIENT):this.container.classList.add(h.GRADIENT)}),this.delay/4)}_changeTransition(t=this.delay,i=this.transition){this.container.style.transition=`${t/1e3}s ${i}`}_changeTransform(t){this.container.style.transform=`matrix(1, 0, 0, 1, 0, ${t})`}_isGoingBackward(){return!(0!==this.active||this.nextActive!==this.tiles.length-1)}_isGoingForward(){return!(this.active!==this.tiles.length-1||0!==this.nextActive)}getTileOffset(t){let i=0;for(let e=0;e{if(!this.stopping&&this.running){const e=t-1;this._resetPosition(this.bounds.first),e>1?this.shuffle(e,i):this.stop(i)}}),e)}else this.stop(i);return this.nextActive}stop(t){if(!this.running||this.stopping)return this.nextActive;this.running=!0,this.stopping=!0,Number.isInteger(this.nextActive)||(this.nextActive=this.custom),this._isGoingBackward()?this._resetPosition(this.bounds.firstToLast):this._isGoingForward()&&this._resetPosition(this.bounds.lastToFirst),this.active=this.nextActive;const i=this._getDelayFromSpins(1);return this._changeTransition(i),this._animationFX=h.STOP,this._changeTransform(this.getTileOffset(this.active)),n((()=>{this.stopping=!1,this.running=!1,this.nextActive=void 0,"function"==typeof this.onComplete&&this.onComplete(this.active),"function"==typeof t&&t.apply(this,[this.active])}),i),this.active}run(){this.running||(this._timer=new r((()=>{this.visible||!0!==this.inViewport?this.shuffle(this.spins,(()=>{this._timer.reset()})):n((()=>{this._timer.reset()}),500)}),this.delay))}destroy(){this._fakeFirstTile.remove(),this._fakeLastTile.remove(),this.tiles.forEach((t=>{this.element.appendChild(t)})),this.container.remove()}}})(),s=s.default})())); +!function(t,i){"object"==typeof exports&&"object"==typeof module?module.exports=i():"function"==typeof define&&define.amd?define("SlotMachine",[],i):"object"==typeof exports?exports.SlotMachine=i():t.SlotMachine=i()}(self,(()=>(()=>{"use strict";var t={d:(i,e)=>{for(var s in e)t.o(e,s)&&!t.o(i,s)&&Object.defineProperty(i,s,{enumerable:!0,get:e[s]})},o:(t,i)=>Object.prototype.hasOwnProperty.call(t,i)},i={};t.d(i,{default:()=>h});class e{constructor(t){this.container=t,this.tiles=[],this.tileNodes=[];const i=[].slice.call(this.container.children);this.container.style.overflow="hidden",this.element=document.createElement("div"),this.element.classList.add("slot-machine__container"),this.element.style.transition="1s ease-in-out",this.container.appendChild(this.element),this.tiles=[...i].map((t=>new s(t))),this.tileNodes=[this.tiles[this.tiles.length-1].clone(),...this.tiles,this.tiles[0].clone()],this.wrapTiles()}wrapTiles(){this.tileNodes.forEach((t=>{this.element.appendChild(t.element)}))}get lastTileOffset(){return this.tiles[0].offset}getTileOffset(t){let i=0;for(let e=0;et+i),0)+this.lastTileOffset)}}class s{constructor(t){this.element=t,this.element.classList.add("slot-machine__tile")}clone(){const t=this.element.cloneNode(!0);return new s(t)}get offset(){return this.element.offsetHeight}}const n={active:0,delay:200,randomize:(t,i)=>function(t,i){return Math.floor(Math.random()*(i-t+1))+t}(0,i),direction:"up"};var o,a;!function(t){t.GRADIENT="slot-machine__container--gradient"}(o||(o={})),function(t){t.NO_TRANSITION="slot-machine__tile--no-transition",t.FAST="slot-machine__tile--blur-fast",t.NORMAL="slot-machine__tile--blur-medium",t.SLOW="slot-machine__tile--blur-slow",t.TURTLE="slot-machine__tile--blur-turtle",t.STOP="slot-machine__tile--gradient"}(a||(a={}));const r=t=>new Promise((i=>setTimeout(i,t)));class h{constructor(t,i){this.running=!1,this.stopping=!1,this.element=t,this.container=new e(this.element),this.setOptions(i),this.active=this.options.active,this.setupBounds(),this._resetPosition()}setOptions(t){this.options={...n,...t}}setupBounds(){const t=this.container.getTileOffset(this.active),i=this.container.getTileOffset(0),e=this.container.getTileOffset(this.container.tiles.length-1);this._bounds={up:{initial:t,from:e,to:0,nextReset:0,prevReset:this.container.maxTopOffset},down:{initial:t,from:i,to:this.container.maxTopOffset,nextReset:0,prevReset:this.container.maxTopOffset}}}get bounds(){return this._bounds[this.options.direction]}get active(){return this._active}set active(t){(t<0||t>=this.container.tiles.length||isNaN(t))&&(t=0),this._active=t}get transition(){return this._transition}set transition(t){this._transition=t||"ease-in-out"}get _prevIndex(){const t=this.active-1;return t<0?this.container.tiles.length-1:t}get _nextIndex(){const t=this.active+1;return trequestAnimationFrame(t)),i)}((()=>{this.container.tiles.map((({element:t})=>t)).forEach((i=>{i.classList.remove(a.FAST,a.NORMAL,a.SLOW,a.TURTLE),t!==a.STOP&&i.classList.add(t)})),t===a.STOP?this.container.element.classList.remove(o.GRADIENT):this.container.element.classList.add(o.GRADIENT)}),this.options.delay/4)}_changeTransition(t=this.options.delay,i=this.transition){this.container.element.style.transition=`${t/1e3}s ${i}`}_changeTransform(t){this.container.element.style.transform=`matrix(1, 0, 0, 1, 0, ${t})`}_isGoingBackward(){return!(0!==this.active||this.nextActive!==this.container.tiles.length-1)}_isGoingForward(){return!(this.active!==this.container.tiles.length-1||0!==this.nextActive)}_resetPosition(t){this.container.element.classList.toggle(a.NO_TRANSITION),this._changeTransform(void 0!==t?t:this.bounds.initial),this.container.element.offsetHeight,this.container.element.classList.toggle(a.NO_TRANSITION)}async next(){return this.nextActive=this.nextIndex,this.running=!0,await this.stop(0),this.active}async prev(){return this.nextActive=this.prevIndex,this.running=!0,await this.stop(0),this.active}_getDelayFromSpins(t){let i=this.options.delay;switch(this.transition="linear",t){case 1:i/=.5,this.transition="ease-out",this._animationFX=a.TURTLE;break;case 2:i/=.75,this._animationFX=a.SLOW;break;case 3:i/=1,this._animationFX=a.NORMAL;break;case 4:i/=1.25,this._animationFX=a.NORMAL;break;default:i/=1.5,this._animationFX=a.FAST}return i}shuffle(t){if(!this.running&&!this.stopping)return this.nextActive=this.options.randomize(this.active,this.container.tiles.length),this.remainingSpins=t,this._shuffle()}async _shuffle(){this.running=!0;const t=this._getDelayFromSpins(this.remainingSpins);this._changeTransition(t),this._changeTransform(this.bounds.to),await r(t),!this.stopping&&this.running&&(this.remainingSpins--,this._resetPosition(this.bounds.from),this.remainingSpins>1?await this._shuffle():await this.stop(0))}async stop(t=0){if(!this.running||this.stopping)return this.nextActive;if(this.running&&!this.stopping&&t)return void(this.remainingSpins=t);this.running=!0,this.stopping=!0,this._isGoingBackward()?this._resetPosition(this.bounds.prevReset):this._isGoingForward()&&this._resetPosition(this.bounds.nextReset),this.active=this.nextActive;const i=this._getDelayFromSpins(1);this._changeTransition(i),this._animationFX=a.STOP,this._changeTransform(this.container.getTileOffset(this.active)),await r(i),this.stopping=!1,this.running=!1,this.nextActive=void 0}}return i=i.default})())); //# sourceMappingURL=slotmachine.min.js.map \ No newline at end of file diff --git a/dist/slotmachine.min.js.map b/dist/slotmachine.min.js.map index 2ab8969..4267b7e 100644 --- a/dist/slotmachine.min.js.map +++ b/dist/slotmachine.min.js.map @@ -1 +1 @@ -{"version":3,"file":"slotmachine.min.js","mappings":"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","sources":["webpack://SlotMachine/webpack/universalModuleDefinition","webpack://SlotMachine/./node_modules/performance-now/lib/performance-now.js","webpack://SlotMachine/./node_modules/raf/index.js","webpack://SlotMachine/webpack/bootstrap","webpack://SlotMachine/webpack/runtime/compat get default export","webpack://SlotMachine/webpack/runtime/define property getters","webpack://SlotMachine/webpack/runtime/global","webpack://SlotMachine/webpack/runtime/hasOwnProperty shorthand","webpack://SlotMachine/./lib/raf.ts","webpack://SlotMachine/./lib/timer.ts","webpack://SlotMachine/./lib/slot-machine.ts","webpack://SlotMachine/./lib/index.ts"],"sourcesContent":["(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(\"SlotMachine\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"SlotMachine\"] = factory();\n\telse\n\t\troot[\"SlotMachine\"] = factory();\n})(self, () => {\nreturn ","// Generated by CoffeeScript 1.12.2\n(function() {\n var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n module.exports = function() {\n return performance.now();\n };\n } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n module.exports = function() {\n return (getNanoSeconds() - nodeLoadTime) / 1e6;\n };\n hrtime = process.hrtime;\n getNanoSeconds = function() {\n var hr;\n hr = hrtime();\n return hr[0] * 1e9 + hr[1];\n };\n moduleLoadTime = getNanoSeconds();\n upTime = process.uptime() * 1e9;\n nodeLoadTime = moduleLoadTime - upTime;\n } else if (Date.now) {\n module.exports = function() {\n return Date.now() - loadTime;\n };\n loadTime = Date.now();\n } else {\n module.exports = function() {\n return new Date().getTime() - loadTime;\n };\n loadTime = new Date().getTime();\n }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","var now = require('performance-now')\n , root = typeof window === 'undefined' ? global : window\n , vendors = ['moz', 'webkit']\n , suffix = 'AnimationFrame'\n , raf = root['request' + suffix]\n , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n raf = root[vendors[i] + 'Request' + suffix]\n caf = root[vendors[i] + 'Cancel' + suffix]\n || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n var last = 0\n , id = 0\n , queue = []\n , frameDuration = 1000 / 60\n\n raf = function(callback) {\n if(queue.length === 0) {\n var _now = now()\n , next = Math.max(0, frameDuration - (_now - last))\n last = next + _now\n setTimeout(function() {\n var cp = queue.slice(0)\n // Clear queue here to prevent\n // callbacks from appending listeners\n // to the current frame's queue\n queue.length = 0\n for(var i = 0; i < cp.length; i++) {\n if(!cp[i].cancelled) {\n try{\n cp[i].callback(last)\n } catch(e) {\n setTimeout(function() { throw e }, 0)\n }\n }\n }\n }, Math.round(next))\n }\n queue.push({\n handle: ++id,\n callback: callback,\n cancelled: false\n })\n return id\n }\n\n caf = function(handle) {\n for(var i = 0; i < queue.length; i++) {\n if(queue[i].handle === handle) {\n queue[i].cancelled = true\n }\n }\n }\n}\n\nmodule.exports = function(fn) {\n // Wrap in a new function to prevent\n // `cancel` potentially being assigned\n // to the native rAF function\n return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function(object) {\n if (!object) {\n object = root;\n }\n object.requestAnimationFrame = raf\n object.cancelAnimationFrame = caf\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","import requestAnimationFrame from 'raf';\nimport { Callback } from './types';\n\nexport default function raf(cb: Callback, timeout = 0) {\n setTimeout(() => requestAnimationFrame(cb), timeout);\n}\n","import { Callback } from './types';\n\nexport default class Timer {\n cb: Callback;\n initialDelay: number;\n delay: number;\n startTime: number;\n timer: NodeJS.Timeout;\n running: boolean;\n\n constructor(cb: Callback, delay: number) {\n this.cb = cb;\n this.initialDelay = delay;\n this.delay = delay;\n this.running = false;\n\n this.resume();\n\n return this;\n }\n\n _start() {\n this.timer = setTimeout(() => {\n this.running = false;\n this.cb(this);\n }, this.delay);\n }\n\n cancel() {\n this.running = false;\n clearTimeout(this.timer);\n }\n\n pause() {\n if (this.running) {\n this.delay -= new Date().getTime() - this.startTime;\n this.cancel();\n }\n }\n\n resume() {\n if (!this.running) {\n this.running = true;\n this.startTime = new Date().getTime();\n\n this._start();\n }\n }\n\n reset() {\n this.cancel();\n this.delay = this.initialDelay;\n this._start();\n }\n\n add(extraDelay: number) {\n this.pause();\n this.delay += extraDelay;\n this.resume();\n }\n}\n","import raf from './raf';\nimport Timer from './timer';\n\nexport type RandomizeCallback = (active: number) => number;\nexport type OnCompleteCallback = (active: number) => any;\n\nexport type Direction = 'up' | 'down';\n\nexport type Bound = {\n key: Direction;\n initial: number;\n first: number;\n last: number;\n to: number;\n firstToLast: number;\n lastToFirst: number;\n};\n\nexport type Bounds = Record;\n\nexport type Options = {\n active?: number;\n delay?: number;\n auto?: boolean;\n spins?: number;\n randomize?: RandomizeCallback;\n onComplete?: OnCompleteCallback;\n inViewport?: boolean;\n direction?: Direction;\n transition?: string;\n};\n\nconst defaults: Options = {\n active: 0, // Active element [Number]\n delay: 200, // Animation time [Number]\n auto: false, // Repeat delay [false||Number]\n spins: 5, // Number of spins when auto [Number]\n randomize: undefined, // Randomize function, must return a number with the selected position\n onComplete: undefined, // Callback function(result)\n inViewport: true, // Stops animations if the element isn´t visible on the screen\n direction: 'up', // Animation direction ['up'||'down']\n transition: 'ease-in-out',\n};\n\nexport enum FX {\n NO_TRANSITION = 'slotMachineNoTransition',\n FAST = 'slotMachineBlurFast',\n NORMAL = 'slotMachineBlurMedium',\n SLOW = 'slotMachineBlurSlow',\n TURTLE = 'slotMachineBlurTurtle',\n GRADIENT = 'slotMachineGradient',\n STOP = 'slotMachineGradient',\n}\n\nexport default class SlotMachine implements Options {\n container: HTMLElement;\n element: HTMLElement;\n tiles: HTMLElement[];\n running: boolean;\n stopping: boolean;\n nextActive?: number;\n\n // options\n delay: number;\n auto: boolean;\n spins: number;\n randomize?: RandomizeCallback;\n onComplete?: OnCompleteCallback;\n inViewport: boolean;\n\n private _active: number;\n private _minTop: number;\n private _maxTop: number;\n private _fakeFirstTile: HTMLElement;\n private _fakeLastTile: HTMLElement;\n private _bounds: Bounds;\n private _direction: Direction;\n private _transition: string;\n private _timer: Timer;\n\n constructor(element: HTMLElement, options: Options) {\n this.element = element;\n // Slot Machine elements\n this.tiles = [].slice.call(this.element.children) as HTMLElement[];\n // Machine is running?\n this.running = false;\n // Machine is stopping?\n this.stopping = false;\n // Disable overflow\n this.element.style.overflow = 'hidden';\n // Wrap elements inside container\n this._wrapTiles();\n // Set min top offset\n this._minTop = -this._fakeFirstTile.offsetHeight;\n // Set max top offset\n this._maxTop = -this.tiles.reduce((acc, tile) => acc + tile.offsetHeight, 0);\n // Call setters if neccesary\n this.changeSettings({ ...defaults, ...options });\n // Initialize spin direction [up, down]\n this._setBounds();\n // Show active element\n this._resetPosition();\n // Start auto animation\n if (this.auto) {\n this.run();\n }\n }\n\n changeSettings(options: Options) {\n Object.keys(options).forEach((key) => {\n // Trigger setters\n this[key] = options[key]; /* @ts-ignore */\n });\n }\n\n _wrapTiles() {\n this.container = document.createElement('div');\n this.container.classList.add('slotMachineContainer');\n this.container.style.transition = '1s ease-in-out';\n this.element.appendChild(this.container);\n\n this._fakeFirstTile = this.tiles[this.tiles.length - 1].cloneNode(true) as HTMLElement;\n this.container.appendChild(this._fakeFirstTile);\n\n this.tiles.forEach((tile) => {\n this.container.appendChild(tile);\n });\n\n this._fakeLastTile = this.tiles[0].cloneNode(true) as HTMLElement;\n this.container.appendChild(this._fakeLastTile);\n }\n\n _setBounds() {\n const initial = this.getTileOffset(this.active);\n const first = this.getTileOffset(this.tiles.length);\n const last = this.getTileOffset(this.tiles.length);\n\n this._bounds = {\n up: {\n key: 'up',\n initial,\n first: 0,\n last,\n to: this._maxTop,\n firstToLast: last,\n lastToFirst: 0,\n },\n down: {\n key: 'down',\n initial,\n first,\n last: 0,\n to: this._minTop,\n firstToLast: last,\n lastToFirst: 0,\n },\n };\n }\n\n get active() {\n return this._active;\n }\n\n set active(index: number) {\n if (index < 0 || index >= this.tiles.length || isNaN(index)) {\n index = 0;\n }\n\n this._active = index;\n }\n\n get direction() {\n return this._direction;\n }\n\n set direction(direction: Direction) {\n if (this.running) {\n return;\n }\n\n this._direction = direction === 'down' ? 'down' : 'up';\n }\n\n get bounds() {\n return this._bounds[this._direction];\n }\n\n get transition() {\n return this._transition;\n }\n\n set transition(transition: string) {\n this._transition = transition || 'ease-in-out';\n }\n\n get visibleTile() {\n const firstTileHeight = this.tiles[0].offsetHeight;\n const rawContainerMargin = this.container.style.transform || '';\n const matrixRegExp = /^matrix\\(-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?-?\\d+,\\s?(-?\\d+)\\)$/;\n const containerMargin = parseInt(rawContainerMargin.replace(matrixRegExp, '$1'), 10);\n\n return Math.abs(Math.round(containerMargin / firstTileHeight)) - 1;\n }\n\n get random() {\n return Math.floor(Math.random() * this.tiles.length);\n }\n\n get custom() {\n let choosen = this.random;\n\n if (this.randomize) {\n let index = this.randomize(this.active);\n if (index < 0 || index >= this.tiles.length) {\n index = 0;\n }\n choosen = index;\n }\n\n return choosen;\n }\n\n get _prevIndex() {\n const prevIndex = this.active - 1;\n\n return prevIndex < 0 ? this.tiles.length - 1 : prevIndex;\n }\n\n get _nextIndex() {\n const nextIndex = this.active + 1;\n\n return nextIndex < this.tiles.length ? nextIndex : 0;\n }\n\n get prevIndex() {\n return this.direction === 'up' ? this._nextIndex : this._prevIndex;\n }\n\n get nextIndex() {\n return this.direction === 'up' ? this._prevIndex : this._nextIndex;\n }\n\n get visible() {\n const rect = this.element.getBoundingClientRect();\n const windowHeight = window.innerHeight || document.documentElement.clientHeight;\n const windowWidth = window.innerWidth || document.documentElement.clientWidth;\n const vertInView = rect.top <= windowHeight && rect.top + rect.height >= 0;\n const horInView = rect.left <= windowWidth && rect.left + rect.width >= 0;\n\n return vertInView && horInView;\n }\n\n set _animationFX(effect: FX) {\n const delay = this.delay / 4;\n\n raf(() => {\n [...this.tiles, this._fakeLastTile, this._fakeFirstTile].forEach((tile) => {\n tile.classList.remove(FX.FAST, FX.NORMAL, FX.SLOW, FX.TURTLE);\n if (effect !== FX.STOP) {\n tile.classList.add(effect);\n }\n });\n\n if (effect === FX.STOP) {\n this.container.classList.remove(FX.GRADIENT);\n } else {\n this.container.classList.add(FX.GRADIENT);\n }\n }, delay);\n }\n\n _changeTransition(delay = this.delay, transition = this.transition) {\n this.container.style.transition = `${delay / 1000}s ${transition}`;\n }\n\n _changeTransform(margin: number) {\n this.container.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`;\n }\n\n _isGoingBackward() {\n return !!(\n this.active === 0 &&\n this.nextActive === this.tiles.length - 1\n );\n }\n\n _isGoingForward() {\n return !!(\n this.active === this.tiles.length - 1 &&\n this.nextActive === 0\n );\n }\n\n getTileOffset(index: number) {\n let offset = 0;\n\n for (let i = 0; i < index; i++) {\n offset += this.tiles[i].offsetHeight;\n }\n\n return this._minTop - offset;\n }\n\n _resetPosition(margin?: number) {\n this.container.classList.toggle(FX.NO_TRANSITION);\n this._changeTransform(margin !== undefined ? margin : this.bounds.initial);\n // Force reflow, flushing the CSS changes\n this.container.offsetHeight;\n this.container.classList.toggle(FX.NO_TRANSITION);\n }\n\n next() {\n this.direction = 'down';\n this.nextActive = this.nextIndex;\n this.running = true;\n this.stop();\n\n return this.nextActive;\n }\n\n prev() {\n this.direction = 'up';\n this.nextActive = this.nextIndex;\n this.running = true;\n this.stop();\n\n return this.nextActive;\n }\n\n _getDelayFromSpins(spins: number) {\n let delay = this.delay;\n this.transition = 'linear';\n\n switch (spins) {\n case 1:\n delay /= 0.5;\n this.transition = 'ease-out';\n this._animationFX = FX.TURTLE;\n break;\n case 2:\n delay /= 0.75;\n this._animationFX = FX.SLOW;\n break;\n case 3:\n delay /= 1;\n this._animationFX = FX.NORMAL;\n break;\n case 4:\n delay /= 1.25;\n this._animationFX = FX.NORMAL;\n break;\n default:\n delay /= 1.5;\n this._animationFX = FX.FAST;\n }\n\n return delay;\n }\n\n shuffle(spins: number, onComplete: OnCompleteCallback) {\n // Make spins optional\n if (typeof spins === 'function') {\n onComplete = spins;\n }\n this.running = true;\n // Perform animation\n if (!this.visible && this.inViewport === true) {\n this.stop(onComplete);\n } else {\n const delay = this._getDelayFromSpins(spins);\n // this.delay = delay;\n this._changeTransition(delay);\n this._changeTransform(this.bounds.to);\n raf(() => {\n if (!this.stopping && this.running) {\n const left = spins - 1;\n\n this._resetPosition(this.bounds.first);\n\n if (left > 1) {\n // Repeat animation\n this.shuffle(left, onComplete);\n } else {\n this.stop(onComplete);\n }\n }\n }, delay);\n }\n\n return this.nextActive;\n }\n\n stop(onStop?: OnCompleteCallback) {\n if (!this.running || this.stopping) {\n return this.nextActive;\n }\n\n this.running = true;\n this.stopping = true;\n\n if (!Number.isInteger(this.nextActive)) {\n // Get random or custom element\n this.nextActive = this.custom;\n }\n\n // Check direction to prevent jumping\n if (this._isGoingBackward()) {\n this._resetPosition(this.bounds.firstToLast);\n } else if (this._isGoingForward()) {\n this._resetPosition(this.bounds.lastToFirst);\n }\n\n // Update last choosen element index\n this.active = this.nextActive as number;\n\n // Perform animation\n const delay = this._getDelayFromSpins(1);\n // this.delay = delay;\n this._changeTransition(delay);\n this._animationFX = FX.STOP;\n this._changeTransform(this.getTileOffset(this.active));\n raf(() => {\n this.stopping = false;\n this.running = false;\n this.nextActive = undefined;\n\n if (typeof this.onComplete === 'function') {\n this.onComplete(this.active);\n }\n\n if (typeof onStop === 'function') {\n onStop.apply(this, [this.active]);\n }\n }, delay);\n\n return this.active;\n }\n\n run() {\n if (this.running) {\n return;\n }\n\n this._timer = new Timer(() => {\n if (!this.visible && this.inViewport === true) {\n raf(() => {\n this._timer.reset();\n }, 500);\n } else {\n this.shuffle(this.spins, () => {\n this._timer.reset();\n });\n }\n }, this.delay);\n }\n\n destroy() {\n this._fakeFirstTile.remove();\n this._fakeLastTile.remove();\n // this.$tiles.unwrap();\n\n // Unwrap tiles\n this.tiles.forEach((tile) => {\n this.element.appendChild(tile);\n });\n\n this.container.remove();\n }\n}\n","import SlotMachine from './slot-machine';\n\nexport default SlotMachine;\n"],"names":["root","factory","exports","module","define","amd","self","getNanoSeconds","hrtime","loadTime","moduleLoadTime","nodeLoadTime","upTime","performance","now","process","hr","uptime","Date","getTime","call","this","window","g","vendors","suffix","raf","caf","i","length","last","id","queue","callback","_now","next","Math","max","setTimeout","cp","slice","cancelled","e","round","push","handle","fn","cancel","apply","arguments","polyfill","object","requestAnimationFrame","cancelAnimationFrame","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","globalThis","Function","obj","prop","prototype","hasOwnProperty","cb","timeout","Timer","constructor","delay","initialDelay","running","resume","_start","timer","clearTimeout","pause","startTime","reset","add","extraDelay","defaults","active","auto","spins","randomize","onComplete","inViewport","direction","transition","FX","element","options","tiles","children","stopping","style","overflow","_wrapTiles","_minTop","_fakeFirstTile","offsetHeight","_maxTop","reduce","acc","tile","changeSettings","_setBounds","_resetPosition","run","keys","forEach","container","document","createElement","classList","appendChild","cloneNode","_fakeLastTile","initial","getTileOffset","first","_bounds","up","to","firstToLast","lastToFirst","down","_active","index","isNaN","_direction","bounds","_transition","visibleTile","firstTileHeight","rawContainerMargin","transform","containerMargin","parseInt","replace","abs","random","floor","custom","choosen","_prevIndex","prevIndex","_nextIndex","nextIndex","visible","rect","getBoundingClientRect","windowHeight","innerHeight","documentElement","clientHeight","windowWidth","innerWidth","clientWidth","vertInView","top","height","horInView","left","width","_animationFX","effect","remove","FAST","NORMAL","SLOW","TURTLE","STOP","GRADIENT","_changeTransition","_changeTransform","margin","_isGoingBackward","nextActive","_isGoingForward","offset","toggle","NO_TRANSITION","stop","prev","_getDelayFromSpins","shuffle","onStop","Number","isInteger","_timer","destroy"],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"slotmachine.min.js","mappings":"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","sources":["webpack://SlotMachine/webpack/universalModuleDefinition","webpack://SlotMachine/webpack/bootstrap","webpack://SlotMachine/webpack/runtime/define property getters","webpack://SlotMachine/webpack/runtime/hasOwnProperty shorthand","webpack://SlotMachine/./lib/dom.ts","webpack://SlotMachine/./lib/constants.ts","webpack://SlotMachine/./lib/index.ts","webpack://SlotMachine/./lib/raf.ts"],"sourcesContent":["(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(\"SlotMachine\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"SlotMachine\"] = factory();\n\telse\n\t\troot[\"SlotMachine\"] = factory();\n})(self, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","export class Container {\n element: HTMLElement;\n tiles: Tile[] = [];\n tileNodes: Tile[] = [];\n\n constructor(public container: HTMLElement) {\n const tileElements = [].slice.call(this.container.children) as HTMLElement[];\n\n this.container.style.overflow = 'hidden';\n this.element = document.createElement('div');\n this.element.classList.add('slot-machine__container');\n this.element.style.transition = '1s ease-in-out';\n this.container.appendChild(this.element);\n this.tiles = [...tileElements].map((element) => new Tile(element));\n this.tileNodes = [\n this.tiles[this.tiles.length - 1].clone(),\n ...this.tiles,\n this.tiles[0].clone(),\n ];\n this.wrapTiles();\n }\n\n private wrapTiles() {\n this.tileNodes.forEach((tile) => {\n this.element.appendChild(tile.element);\n });\n }\n\n private get lastTileOffset() {\n return this.tiles[0].offset;\n }\n\n getTileOffset(index: number) {\n let offset = 0;\n\n for (let i = 0; i < index; i++) {\n offset += this.tiles[i].offset;\n }\n\n return -this.lastTileOffset - offset;\n }\n\n get maxTopOffset() {\n return -1 * (this.tiles.reduce((acc, { offset }) => acc + offset, 0) + this.lastTileOffset);\n }\n}\n\nexport class Tile {\n constructor(public element: HTMLElement) {\n this.element.classList.add('slot-machine__tile');\n }\n\n clone() {\n const element = this.element.cloneNode(true) as HTMLElement;\n\n return new Tile(element);\n }\n\n get offset() {\n return this.element.offsetHeight;\n }\n}\n","import { Options } from './types';\n\nfunction randomInteger(min: number, max: number) {\n return Math.floor(Math.random() * (max - min + 1)) + min;\n}\n\nexport const DEFAULTS: Required = {\n active: 0, // Active element [Number]\n delay: 200, // Animation time [Number]\n randomize: (_, max) => randomInteger(0, max), // Randomize function, must return a number with the selected position\n direction: 'up', // Animation direction ['up'||'down']\n};\n\nexport enum CONTAINER_FX {\n GRADIENT = 'slot-machine__container--gradient',\n}\n\nexport enum TILE_FX {\n NO_TRANSITION = 'slot-machine__tile--no-transition',\n FAST = 'slot-machine__tile--blur-fast',\n NORMAL = 'slot-machine__tile--blur-medium',\n SLOW = 'slot-machine__tile--blur-slow',\n TURTLE = 'slot-machine__tile--blur-turtle',\n STOP = 'slot-machine__tile--gradient',\n}\n","import raf from './raf';\nimport { Container } from './dom';\nimport type { Bounds, Options } from './types';\nimport { DEFAULTS, TILE_FX, CONTAINER_FX } from './constants';\n\nconst timeout = (delay: number) => new Promise((res) => setTimeout(res, delay));\n\nexport default class SlotMachine {\n container: Container;\n element: HTMLElement;\n running = false;\n stopping = false;\n nextActive?: number;\n\n private remainingSpins: number;\n private options: Required;\n private _active: number;\n private _bounds: Bounds;\n private _transition: string;\n\n constructor(element: HTMLElement, options: Options) {\n this.element = element;\n // Setup DOM\n this.container = new Container(this.element);\n // Set plugin options\n this.setOptions(options);\n this.active = this.options.active;\n this.setupBounds();\n // Show active element\n this._resetPosition();\n }\n\n setOptions(options: Options) {\n this.options = { ...DEFAULTS, ...options };\n }\n\n private setupBounds() {\n const initial = this.container.getTileOffset(this.active);\n const first = this.container.getTileOffset(0);\n const last = this.container.getTileOffset(this.container.tiles.length - 1);\n\n this._bounds = {\n up: {\n initial,\n from: last,\n to: 0,\n nextReset: 0,\n prevReset: this.container.maxTopOffset,\n },\n down: {\n initial,\n from: first,\n to: this.container.maxTopOffset,\n nextReset: 0,\n prevReset: this.container.maxTopOffset,\n },\n };\n }\n\n get bounds() {\n return this._bounds[this.options.direction];\n }\n\n get active() {\n return this._active;\n }\n\n set active(index: number) {\n if (index < 0 || index >= this.container.tiles.length || isNaN(index)) {\n index = 0;\n }\n\n this._active = index;\n }\n\n private get transition() {\n return this._transition;\n }\n\n private set transition(transition: string) {\n this._transition = transition || 'ease-in-out';\n }\n\n get _prevIndex() {\n const prevIndex = this.active - 1;\n\n return prevIndex < 0 ? this.container.tiles.length - 1 : prevIndex;\n }\n\n get _nextIndex() {\n const nextIndex = this.active + 1;\n\n return nextIndex < this.container.tiles.length ? nextIndex : 0;\n }\n\n get prevIndex() {\n return this.options.direction === 'up' ? this._nextIndex : this._prevIndex;\n }\n\n get nextIndex() {\n return this.options.direction === 'up' ? this._prevIndex : this._nextIndex;\n }\n\n set _animationFX(effect: TILE_FX) {\n const delay = this.options.delay / 4;\n\n raf(() => {\n this.container.tiles\n .map(({ element }) => element)\n .forEach((tile) => {\n tile.classList.remove(TILE_FX.FAST, TILE_FX.NORMAL, TILE_FX.SLOW, TILE_FX.TURTLE);\n if (effect !== TILE_FX.STOP) {\n tile.classList.add(effect);\n }\n });\n\n if (effect === TILE_FX.STOP) {\n this.container.element.classList.remove(CONTAINER_FX.GRADIENT);\n } else {\n this.container.element.classList.add(CONTAINER_FX.GRADIENT);\n }\n }, delay);\n }\n\n _changeTransition(delay = this.options.delay, transition = this.transition) {\n this.container.element.style.transition = `${delay / 1000}s ${transition}`;\n }\n\n _changeTransform(margin: number) {\n this.container.element.style.transform = `matrix(1, 0, 0, 1, 0, ${margin})`;\n }\n\n _isGoingBackward() {\n return !!(this.active === 0 && this.nextActive === this.container.tiles.length - 1);\n }\n\n _isGoingForward() {\n return !!(this.active === this.container.tiles.length - 1 && this.nextActive === 0);\n }\n\n _resetPosition(margin?: number) {\n this.container.element.classList.toggle(TILE_FX.NO_TRANSITION);\n this._changeTransform(margin !== undefined ? margin : this.bounds.initial);\n // Force reflow, flushing the CSS changes\n this.container.element.offsetHeight;\n this.container.element.classList.toggle(TILE_FX.NO_TRANSITION);\n }\n\n async next() {\n this.nextActive = this.nextIndex;\n this.running = true;\n await this.stop(0);\n\n return this.active;\n }\n\n async prev() {\n this.nextActive = this.prevIndex;\n this.running = true;\n await this.stop(0);\n\n return this.active;\n }\n\n _getDelayFromSpins(spins: number) {\n let delay = this.options.delay;\n this.transition = 'linear';\n\n switch (spins) {\n case 1:\n delay /= 0.5;\n this.transition = 'ease-out';\n this._animationFX = TILE_FX.TURTLE;\n break;\n case 2:\n delay /= 0.75;\n this._animationFX = TILE_FX.SLOW;\n break;\n case 3:\n delay /= 1;\n this._animationFX = TILE_FX.NORMAL;\n break;\n case 4:\n delay /= 1.25;\n this._animationFX = TILE_FX.NORMAL;\n break;\n default:\n delay /= 1.5;\n this._animationFX = TILE_FX.FAST;\n }\n\n return delay;\n }\n\n shuffle(spins: number) {\n if (this.running || this.stopping) {\n return;\n }\n\n this.nextActive = this.options.randomize(this.active, this.container.tiles.length);\n this.remainingSpins = spins;\n\n return this._shuffle();\n }\n\n private async _shuffle() {\n this.running = true;\n // Perform animation\n const delay = this._getDelayFromSpins(this.remainingSpins);\n this._changeTransition(delay);\n this._changeTransform(this.bounds.to);\n\n await timeout(delay);\n\n if (!this.stopping && this.running) {\n this.remainingSpins--;\n\n this._resetPosition(this.bounds.from);\n\n if (this.remainingSpins > 1) {\n // Repeat animation\n await this._shuffle();\n } else {\n await this.stop(0);\n }\n }\n }\n\n async stop(spins = 0) {\n if (!this.running || this.stopping) {\n return this.nextActive;\n }\n\n if (this.running && !this.stopping && spins) {\n this.remainingSpins = spins;\n return;\n }\n\n this.running = true;\n this.stopping = true;\n\n // Check direction to prevent jumping\n if (this._isGoingBackward()) {\n this._resetPosition(this.bounds.prevReset);\n } else if (this._isGoingForward()) {\n this._resetPosition(this.bounds.nextReset);\n }\n\n // Update last choosen element index\n this.active = this.nextActive as number;\n\n // Perform animation\n const delay = this._getDelayFromSpins(1);\n this._changeTransition(delay);\n this._animationFX = TILE_FX.STOP;\n this._changeTransform(this.container.getTileOffset(this.active));\n\n await timeout(delay);\n\n this.stopping = false;\n this.running = false;\n this.nextActive = undefined;\n }\n}\n","import { Callback } from './types';\n\nexport default function raf(cb: Callback, timeout = 0) {\n setTimeout(() => requestAnimationFrame(cb), timeout);\n}\n"],"names":["root","factory","exports","module","define","amd","self","__webpack_require__","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","Container","constructor","container","tiles","tileNodes","tileElements","slice","this","children","style","overflow","element","document","createElement","classList","add","transition","appendChild","map","Tile","length","clone","wrapTiles","forEach","tile","lastTileOffset","offset","getTileOffset","index","i","maxTopOffset","reduce","acc","cloneNode","offsetHeight","DEFAULTS","active","delay","randomize","_","max","min","Math","floor","random","randomInteger","direction","CONTAINER_FX","TILE_FX","timeout","Promise","res","setTimeout","SlotMachine","options","running","stopping","setOptions","setupBounds","_resetPosition","initial","first","last","_bounds","up","from","to","nextReset","prevReset","down","bounds","_active","isNaN","_transition","_prevIndex","prevIndex","_nextIndex","nextIndex","_animationFX","effect","cb","requestAnimationFrame","raf","remove","FAST","NORMAL","SLOW","TURTLE","STOP","GRADIENT","_changeTransition","_changeTransform","margin","transform","_isGoingBackward","nextActive","_isGoingForward","toggle","NO_TRANSITION","undefined","async","stop","_getDelayFromSpins","spins","shuffle","remainingSpins","_shuffle"],"sourceRoot":""} \ No newline at end of file