"use strict";(globalThis.blocksyJsonP=globalThis.blocksyJsonP||[]).push([[400],{400:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{eval('// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "mount": () => (/* binding */ mount)\n});\n\n// EXTERNAL MODULE: external "jQuery"\nvar external_jQuery_ = __webpack_require__(194);\nvar external_jQuery_default = /*#__PURE__*/__webpack_require__.n(external_jQuery_);\n;// CONCATENATED MODULE: ./node_modules/flexy/dist/flexy.es.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty2(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty2(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nconst getRightOrBottom = (rect, flexyInstance) => {\n if (flexyInstance.options.orientation === "vertical") {\n return rect.top + rect.height;\n }\n\n return rect.right;\n};\n\nconst getLeftOrTop = (rect, flexyInstance) => {\n if (flexyInstance.options.orientation === "vertical") {\n return rect.top;\n }\n\n return rect.left;\n};\n\nconst getDimensionFor = (rect, flexyInstance) => {\n if (flexyInstance.options.orientation === "vertical") {\n return rect.height;\n }\n\n return rect.width;\n};\n/**\n * Develop a suggestion-based mechanism.\n * That is, ignore a checking for a specific side when we do not have a need\n * for it. Also, when we don\'t care about that particular side.\n *\n * TODO: implement _both_ strategy for wrapAround\n */\n\n\nconst fetchWrapAroundStatusFor = function (flexyInstance, elementsOnBehind) {\n let theSideWeAreMovingOnto = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : "left";\n let wrapAroundMode = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : "container";\n const sliderContainer = flexyInstance.sliderContainer;\n let relativeDelta = 0;\n\n if (theSideWeAreMovingOnto === "left") {\n let leftmostOffset = [...sliderContainer.children].reduce((leftmostEl, currentEl) => {\n let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n return currentLeft < left ? currentEl : leftmostEl;\n }, {\n getBoundingClientRect: () => ({\n left: 100000000000,\n bottom: 100000000000,\n top: 100000000000,\n right: 100000000000\n })\n });\n\n if (getLeftOrTop(nullifyTransforms(leftmostOffset, flexyInstance.options.nullifyTransformEl), flexyInstance) > (wrapAroundMode === "container" ? getLeftOrTop(nullifyTransforms(sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance) : 0)) {\n relativeDelta = -1 * getDimensionFor(nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance);\n elementsOnBehind = elementsOnBehind === sliderContainer.children.length ? 1 : elementsOnBehind + 1;\n }\n }\n\n if (theSideWeAreMovingOnto === "right") {\n let rightmostOffset = [...sliderContainer.children].reduce((rightmostEl, currentEl) => {\n let right = getRightOrBottom(nullifyTransforms(rightmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n let currentRight = getRightOrBottom(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n return right > currentRight ? rightmostEl : currentEl;\n }, {\n getBoundingClientRect: () => ({\n left: -1,\n bottom: -9999999999999,\n top: -1,\n right: -1\n })\n });\n\n if (getRightOrBottom(nullifyTransforms(rightmostOffset, flexyInstance.options.nullifyTransformEl), flexyInstance) < (wrapAroundMode === "container" ? getRightOrBottom(nullifyTransforms(sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance) : window.innerWidth)) {\n relativeDelta = getDimensionFor(nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance);\n elementsOnBehind = elementsOnBehind === 1 ? sliderContainer.children.length : elementsOnBehind - 1;\n }\n }\n\n return {\n relativeDelta,\n elementsOnBehind\n };\n};\n\nfunction nullifyTransforms(el) {\n let elementToLookAt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n if (!el) return null;\n\n if (el.getBoundingClientRect && !el.firstElementChild) {\n return el.getBoundingClientRect();\n }\n\n if (!elementToLookAt) {\n elementToLookAt = el;\n } //add sanity checks and default values\n\n\n let {\n top,\n left,\n right,\n width,\n height\n } = el.getBoundingClientRect();\n let transformArr = window.getComputedStyle(elementToLookAt).transform.split(/\\(|,|\\)/).slice(1, -1).map(v => parseFloat(v));\n\n if (transformArr.length != 6) {\n return el.getBoundingClientRect();\n } // 2D matrix\n // need some math to apply inverse of matrix\n // That is the matrix of the transformation of the element\n\n\n var t = transformArr;\n let det = t[0] * t[3] - t[1] * t[2];\n /*if (transformArr.length > 6)*/\n //3D matrix\n //haven\'t done the calculation to apply inverse of 4x4 matrix\n\n return {\n width: width / t[0],\n height: height / t[3],\n left: (left * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n right: (right * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n top: (-left * t[1] + top * t[0] + t[4] * t[1] - t[0] * t[5]) / det\n };\n}\n\nconst renderPillsFor = flexyInstance => {\n if (!flexyInstance.options.pillsContainerSelector) return;\n flexyInstance.options.pillsContainerSelector.querySelector(".active") && flexyInstance.options.pillsContainerSelector.querySelector(".active").classList.remove("active");\n flexyInstance.options.pillsContainerSelector.children[flexyInstance.state.previousCurrentIndex].classList.add("active");\n\n if (flexyInstance.options.pillsFlexyInstance) {\n let localFlexyInstance = flexyInstance.options.pillsFlexyInstance.flexy;\n let allPills = [...flexyInstance.options.pillsContainerSelector.children];\n let fromIndex = [...localFlexyInstance.sliderContainer.children].indexOf([...localFlexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n let left = getLeftOrTop(nullifyTransforms(leftmostEl, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance);\n let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance);\n return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(localFlexyInstance.sliderContainer, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(localFlexyInstance.sliderContainer, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance)) ? currentEl : leftmostEl;\n }, {\n getBoundingClientRect: () => ({\n left: 100000000000,\n top: 100000000000\n })\n }));\n let toIndex = 0;\n\n if (localFlexyInstance.options.orientation === "horizontal") {\n let perPage = Math.round(nullifyTransforms(localFlexyInstance.sliderContainer).width / nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild).width);\n toIndex = flexyInstance.state.previousCurrentIndex;\n\n if (perPage === 5) {\n if (flexyInstance.state.previousCurrentIndex > 2) {\n toIndex = flexyInstance.state.previousCurrentIndex - 2;\n }\n\n if (allPills.length - 1 - flexyInstance.state.previousCurrentIndex < 3) {\n toIndex = allPills.length - 5;\n }\n }\n\n if (perPage === 3) {\n if (flexyInstance.state.previousCurrentIndex >= 1) {\n toIndex = flexyInstance.state.previousCurrentIndex - 1;\n }\n\n if (allPills.length - 1 - flexyInstance.state.previousCurrentIndex < 1) {\n toIndex = allPills.length - 3;\n }\n }\n } else {\n toIndex = flexyInstance.state.previousCurrentIndex;\n }\n\n let amountToTheLeft = Math.abs(toIndex - fromIndex);\n let amountToTheRight = Math.min(fromIndex, toIndex) + (allPills.length - Math.max(fromIndex, toIndex));\n let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight >= amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n let resultTarget = Math.round(localFlexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) / 100 + getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) * p;\n localFlexyInstance.state = _objectSpread(_objectSpread({}, localFlexyInstance.state), {}, {\n positionTarget: resultTarget\n });\n }\n};\n\nconst mountPillsListeners = flexyInstance => {\n if (!flexyInstance.options.pillsContainerSelector) return;\n let allPills = [...flexyInstance.options.pillsContainerSelector.children];\n\n const handlePillEvent = singlePill => {\n let fromIndex = [...flexyInstance.sliderContainer.children].indexOf([...flexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) ? currentEl : leftmostEl;\n }, {\n getBoundingClientRect: () => ({\n left: 100000000000\n })\n }));\n let toIndex = allPills.indexOf(singlePill);\n flexyInstance.options.pillsContainerSelector.querySelector(".active") && flexyInstance.options.pillsContainerSelector.querySelector(".active").classList.remove("active");\n singlePill.classList.add("active");\n let amountToTheLeft = Math.abs(toIndex - fromIndex);\n let amountToTheRight = Math.min(fromIndex, toIndex) + (allPills.length - Math.max(fromIndex, toIndex));\n let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight >= amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n let resultTarget = Math.round(flexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100 + getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) * p;\n flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n positionTarget: resultTarget\n });\n };\n\n if (flexyInstance.options.initialDragEvent && flexyInstance.options.initialDragEvent.target.closest(".flexy-pills > * > *")) {\n setTimeout(() => {\n handlePillEvent(flexyInstance.options.initialDragEvent.target.closest(".flexy-pills > * > *"));\n });\n }\n\n allPills.map(singlePill => singlePill.addEventListener("click", e => {\n handlePillEvent(singlePill);\n e.preventDefault();\n }));\n};\n\nconst moveToIndexFor = (flexyInstance, cb) => {\n let fromIndex = [...flexyInstance.sliderContainer.children].indexOf([...flexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) ? currentEl : leftmostEl;\n }, {\n getBoundingClientRect: () => ({\n left: 100000000000,\n top: 100000000000\n })\n }));\n let toIndex = cb(fromIndex);\n\n if (toIndex < 0) {\n toIndex = flexyInstance.sliderContainer.children.length - 1;\n }\n\n if (toIndex > flexyInstance.sliderContainer.children.length - 1) {\n toIndex = 0;\n }\n\n let amountToTheLeft = Math.abs(toIndex - fromIndex);\n let amountToTheRight = Math.min(fromIndex, toIndex) + (flexyInstance.sliderContainer.children.length - Math.max(fromIndex, toIndex));\n let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight > amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n let resultTarget = Math.round(flexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100 + getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) * p;\n flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n positionTarget: resultTarget\n });\n};\n\nconst mountArrowsListeners = flexyInstance => {\n flexyInstance.options.leftArrow && flexyInstance.options.leftArrow.addEventListener("click", e => {\n e.preventDefault();\n moveToIndexFor(flexyInstance, fromIndex => fromIndex - 1);\n });\n flexyInstance.options.rightArrow && flexyInstance.options.rightArrow.addEventListener("click", e => {\n e.preventDefault();\n moveToIndexFor(flexyInstance, fromIndex => fromIndex + 1);\n });\n};\n\nconst handleHoverStateFor = flexyInstance => {\n const sliderContainer = flexyInstance.sliderContainer;\n if (!flexyInstance.options.autoplay) return;\n sliderContainer.addEventListener("mouseenter", () => flexyInstance.options = _objectSpread(_objectSpread({}, flexyInstance.options), {}, {\n autoplay: false,\n _autoplay: flexyInstance.options.autoplay\n }));\n sliderContainer.addEventListener("mouseleave", () => {\n flexyInstance.options = _objectSpread(_objectSpread({}, flexyInstance.options), {}, {\n autoplay: flexyInstance.options._autoplay,\n _autoplay: false\n });\n flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n lastTimeAnimated: new Date().getTime()\n });\n });\n};\n\nconst adjustContainerHeightFor = flexyInstance => {\n if (!flexyInstance.options.adjustHeight) return;\n let currentChild = flexyInstance.sliderContainer.children[flexyInstance.state.previousCurrentIndex];\n flexyInstance.sliderContainer.style.setProperty("--sliderHeight", `${(currentChild.firstElementChild || currentChild).getBoundingClientRect().height}px`);\n};\n\nconst handleDragFor = (flexyInstance, getState, setState) => {\n if (!flexyInstance.options.hasDragAndDrop) {\n return;\n }\n\n const sliderContainer = flexyInstance.sliderContainer;\n\n const handleDown = e => {\n if (!getState().sliderActivated) return;\n\n if (flexyInstance.options.elementsThatDoNotStartDrag.reduce((shouldSkipDrag, selector) => shouldSkipDrag ? true : e.target.matches(selector) || e.target.closest(selector), false)) {\n return;\n } // e.preventDefault()\n\n\n e.stopPropagation();\n\n if (e.type !== "touchstart") {\n e.preventDefault();\n }\n\n flexyInstance.options.onDragStart(e);\n setState(_objectSpread(_objectSpread({}, getState()), {}, {\n startX: e.pageX || e.touches[0].pageX,\n endX: e.pageX || e.touches[0].pageX,\n mouseDown: true,\n downScrollPosition: {\n x: window.pageXOffset,\n y: window.pageYOffset\n },\n positionSnapshot: getState().positionX\n }));\n\n const handleMouseUp = e => {\n if (!getState().mouseDown) return;\n e.stopPropagation();\n setState(_objectSpread(_objectSpread({}, getState()), {}, {\n mouseDown: false\n }));\n document.removeEventListener("mousemove", handleMouseMove);\n document.removeEventListener("mouseup", handleMouseUp);\n document.removeEventListener("touchmove", handleMouseMove);\n document.removeEventListener("touchend", handleMouseUp);\n let state = getState();\n let fromPercentage = state.positionX * 100 / nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl).width;\n setState(_objectSpread(_objectSpread({}, getState()), {}, {\n positionTarget: nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl).width * (Math.abs(state.endX - state.startX) > 50 ? state.endX - state.startX < 0 ? Math.floor(fromPercentage / 100) * 100 : Math.ceil(fromPercentage / 100) * 100 : Math.round(fromPercentage / 100) * 100) / 100\n }));\n };\n\n const handleMouseMove = e => {\n let {\n pageX: endX\n } = e;\n\n if (!endX) {\n endX = e.touches[0].pageX;\n }\n\n if (!getState().mouseDown) return;\n let state = getState();\n setState(_objectSpread(_objectSpread({}, state), {}, {\n endX\n }));\n\n if (Math.abs(state.downScrollPosition.x - state.scrollPosition.x) > 3 || Math.abs(state.downScrollPosition.y - state.scrollPosition.y) > 5) {\n handleMouseUp(e);\n }\n };\n\n document.addEventListener("mousemove", handleMouseMove);\n document.addEventListener("mouseup", handleMouseUp);\n document.addEventListener("touchmove", handleMouseMove);\n document.addEventListener("touchend", handleMouseUp);\n };\n\n sliderContainer.addEventListener("mousedown", handleDown);\n sliderContainer.addEventListener("touchstart", handleDown);\n\n if (flexyInstance.options.initialDragEvent && !flexyInstance.options.initialDragEvent.target.closest(".flexy-pills > * > *")) {\n requestAnimationFrame(() => {\n handleDown(flexyInstance.options.initialDragEvent);\n });\n }\n};\n\nconst clamp = (n, min, max) => Math.min(Math.max(n, min), max);\n\nconst DESTROYED = "__DESTROYED__";\n\nclass Flexy {\n constructor(sliderContainer) {\n var _this = this;\n\n let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _defineProperty(this, "getDefaultState", () => ({\n elementsOnBehind: 1,\n positionSnapshot: 0,\n positionX: 0,\n\n /**\n * The thing the algorithm tends to move the slides to\n */\n positionTarget: 0,\n velocity: 0,\n containerInnerWidth: this.sliderContainer ? getDimensionFor(nullifyTransforms(this.sliderContainer, this.nullifyTransformEl), this) : 0,\n slideWidth: this.sliderContainer ? getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.sliderContainer), this) : 0,\n previousCurrentIndex: 0,\n startX: 0,\n endX: 0,\n mouseDown: false,\n lastTimeAnimated: Infinity\n }));\n\n _defineProperty(this, "state", this.getDefaultState());\n\n _defineProperty(this, "options", {\n onDragStart: () => {},\n autoplay: false,\n scaleRotateEffect: false,\n pillsContainerSelector: null,\n pillsFlexyInstance: null,\n flexyAttributeEl: null,\n initialDragEvent: null,\n adjustHeight: false,\n // container | viewport\n wrapAroundMode: "container",\n // horizontal | vertical\n orientation: "horizontal",\n nullifyTransformEl: null,\n elementsThatDoNotStartDrag: [],\n hasDragAndDrop: true\n });\n\n _defineProperty(this, "sliderContainer", null);\n\n _defineProperty(this, "drawLoop", function () {\n let fallThroughTheFirstDraw = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n let oldPositionX = fallThroughTheFirstDraw ? Infinity : _this.state.positionX; // TODO: maybe do a smarter destroy\n\n if (_this.state.sliderActivated === DESTROYED) {\n return;\n }\n\n if (_this.state.containerInnerWidth !== nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl).width) {\n _this.refreshActivation();\n }\n\n _this.state = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, _this.state), _this.state.sliderActivated ? ((t, c) => c(t))(_this.state.velocity + (\n /**\n * Apply different forces based on the conditions\n */\n _this.state.mouseDown ? _this.state.positionSnapshot + (_this.state.endX - _this.state.startX) - _this.state.positionX - _this.state.velocity : (_this.state.positionTarget - _this.state.positionX) * 0.02), velocity => ({\n velocity: velocity * 0.72,\n positionX: _this.state.positionX + velocity\n })) : {}), _this.state.sliderActivated && Math.abs(_this.state.containerInnerWidth - getDimensionFor(nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl), _this)) > 1 ? {\n positionX: Math.round(getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this) * (Math.round(_this.state.positionX / _this.state.slideWidth) * 100) / 100),\n positionTarget: Math.round(getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this) * (Math.round(_this.state.positionX / _this.state.slideWidth) * 100) / 100)\n } : {}), {}, {\n scrollPosition: {\n x: window.pageXOffset,\n y: window.pageYOffset\n },\n containerInnerWidth: getDimensionFor(nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl), _this),\n slideWidth: getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)\n });\n\n if ((oldPositionX !== _this.state.positionX || Math.abs(_this.state.positionX - _this.state.positionTarget) > 0.1) && !fallThroughTheFirstDraw) {\n if (_this.state.sliderActivated) {\n let {\n relativeDelta,\n elementsOnBehind\n } = fetchWrapAroundStatusFor(_this, _this.state.elementsOnBehind, _this.state.mouseDown ? _this.state.endX <= _this.state.startX ? "right" : "left" : _this.state.positionX >= _this.state.positionTarget ? "right" : "left", _this.options.wrapAroundMode);\n _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n elementsOnBehind,\n positionTarget: _this.state.positionTarget + relativeDelta,\n positionX: _this.state.positionX + relativeDelta,\n positionSnapshot: _this.state.positionSnapshot + relativeDelta\n });\n }\n }\n\n if (_this.options.autoplay && _this.state.sliderActivated) {\n if (Math.abs(_this.state.positionX - _this.state.positionTarget) < 0.5) {\n if (new Date().getTime() / 1000 - _this.state.lastTimeAnimated / 1000 > (parseFloat(_this.options.autoplay, 10) ? parseFloat(_this.options.autoplay, 10) : 3)) {\n _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n positionTarget: _this.state.positionX - getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)\n });\n }\n }\n }\n\n if (!_this.state.mouseDown && _this.state.sliderActivated) {\n if (Math.abs(_this.state.positionX - _this.state.positionTarget) < 0.2) {\n _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n positionX: _this.state.positionTarget,\n velocity: 0\n });\n }\n\n let oldIndex = _this.state.previousCurrentIndex;\n _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n previousCurrentIndex: clamp(_this.state.elementsOnBehind > Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) ? Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) + (_this.sliderContainer.children.length - _this.state.elementsOnBehind) : Math.abs(Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) - _this.state.elementsOnBehind), 0, _this.sliderContainer.children.length - 1)\n });\n\n if (oldIndex !== _this.state.previousCurrentIndex) {\n renderPillsFor(_this);\n adjustContainerHeightFor(_this);\n [..._this.sliderContainer.querySelectorAll("video")].map(video => {\n video.pause();\n });\n [..._this.sliderContainer.querySelectorAll(\'iframe[src*="youtu"]\')].map(i => {\n i.contentWindow.postMessage(\'{"event":"command","func":"stopVideo","args":""}\', "*");\n });\n [..._this.sliderContainer.querySelectorAll(\'iframe:not([src*="youtu"])\')].map(i => {\n const source = i.src;\n i.src = "";\n i.src = source;\n });\n }\n }\n\n if (_this.state.positionX !== oldPositionX && _this.state.sliderActivated) {\n _this.render(); // handleScaleRotateEffectFor(this)\n\n\n _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n lastTimeAnimated: new Date().getTime()\n });\n }\n\n requestAnimationFrame(() => _this.drawLoop());\n });\n\n this.options = _objectSpread(_objectSpread({}, this.options), {}, {\n flexyAttributeEl: sliderContainer,\n nullifyTransformEl: sliderContainer\n }, options);\n this.sliderContainer = sliderContainer;\n mountPillsListeners(this);\n mountArrowsListeners(this);\n handleHoverStateFor(this);\n handleDragFor(this, () => this.state, newState => this.state = newState);\n [...this.sliderContainer.children].map(singleSlide => singleSlide.addEventListener("click", e => Math.abs(this.state.startX - this.state.endX) > 3 && e.preventDefault()));\n let _elementsOnBehind = 1;\n let firstItem = 1;\n let flexyAttributeElStyle = getComputedStyle(this.options.flexyAttributeEl);\n\n if (flexyAttributeElStyle.getPropertyValue("--current-item")) {\n firstItem = parseInt(flexyAttributeElStyle.getPropertyValue("--current-item"));\n _elementsOnBehind = this.sliderContainer.children.length;\n }\n\n this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n elementsOnBehind: _elementsOnBehind,\n positionX: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this) * firstItem * -1,\n positionTarget: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this) * firstItem * -1,\n containerInnerWidth: getDimensionFor(nullifyTransforms(this.sliderContainer, this.nullifyTransformEl), this),\n slideWidth: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this)\n });\n this.refreshActivation();\n requestAnimationFrame(() => this.drawLoop(true));\n adjustContainerHeightFor(this);\n }\n\n destroy() {\n this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n sliderActivated: DESTROYED\n });\n }\n\n refreshActivation() {\n let totalSlidesWidth = getDimensionFor(nullifyTransforms(this.sliderContainer.children[0], this.options.nullifyTransformEl) || {\n width: 0,\n height: 0\n }, this) * this.sliderContainer.children.length;\n this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n sliderActivated: this.sliderContainer ? getComputedStyle(this.sliderContainer, ":after").content.indexOf("no-flexy") === -1 && totalSlidesWidth > getDimensionFor(nullifyTransforms(this.sliderContainer, this.options.nullifyTransformEl), this) + 10 : false\n /*\n &&\n totalSlidesWidth > window.innerWidth\n */\n\n });\n\n if (this.state.sliderActivated) {\n this.options.flexyAttributeEl.dataset.flexy = "";\n } else {\n this.options.flexyAttributeEl.removeAttribute("data-flexy");\n [...this.sliderContainer.children].map(el => el.removeAttribute("style"));\n }\n }\n\n render() {\n [...this.sliderContainer.children].map(el => {\n if (this.options.orientation === "vertical") {\n el.style.transform = `translate3d(0, ${this.state.positionX}px, 0)`;\n } else {\n el.style.transform = `translate3d(${this.state.positionX}px, 0, 0)`;\n }\n });\n\n if (this.state.mouseDown) {\n this.options.flexyAttributeEl.dataset.flexyDragging = "";\n } else {\n this.options.flexyAttributeEl.removeAttribute("data-flexy-dragging");\n }\n\n if (this.state.elementsOnBehind > 0) {\n [...this.sliderContainer.children].slice(0, this.state.elementsOnBehind * -1).map(el => el.style.order = 2);\n [...this.sliderContainer.children].slice(this.state.elementsOnBehind * -1).map(el => el.style.order = 1);\n } else {\n [...this.sliderContainer.children].map(el => el.style.order = 1);\n }\n }\n\n}\n\n\n// EXTERNAL MODULE: external "ctEvents"\nvar external_ctEvents_ = __webpack_require__(601);\nvar external_ctEvents_default = /*#__PURE__*/__webpack_require__.n(external_ctEvents_);\n// EXTERNAL MODULE: ./static/js/frontend/helpers/current-screen.js\nvar current_screen = __webpack_require__(410);\n;// CONCATENATED MODULE: ./static/js/frontend/flexy.js\nfunction flexy_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction flexy_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? flexy_ownKeys(Object(source), !0).forEach(function (key) { flexy_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : flexy_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction flexy_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst mount = (sliderEl, args) => {\n // sliderEl = sliderEl.parentNode\n if (sliderEl.flexy) {\n return;\n }\n\n let maybePillsSlider = sliderEl.querySelector(\'.flexy-pills [data-flexy]\');\n const inst = new Flexy(sliderEl.querySelector(\'.flexy-items\'), flexy_objectSpread(flexy_objectSpread(flexy_objectSpread({\n flexyAttributeEl: sliderEl,\n elementsThatDoNotStartDrag: [\'.twentytwenty-handle\'],\n adjustHeight: !!sliderEl.querySelector(\'.flexy-items\').dataset.height\n }, args.event ? {\n initialDragEvent: args.event\n } : {}), {}, {\n autoplay: Object.keys(sliderEl.dataset).indexOf(\'autoplay\') > -1 && parseInt(sliderEl.dataset.autoplay, 10) ? sliderEl.dataset.autoplay : false\n }, sliderEl.querySelector(\'.flexy-pills\') ? {\n pillsContainerSelector: sliderEl.querySelector(\'.flexy-pills\').firstElementChild\n } : {}), {}, {\n leftArrow: sliderEl.querySelector(\'.flexy .flexy-arrow-prev\'),\n rightArrow: sliderEl.querySelector(\'.flexy .flexy-arrow-next\'),\n scaleRotateEffect: false,\n onDragStart: e => {\n if (!e.target.closest(\'.flexy-items\')) {\n return;\n }\n\n Array.from(e.target.closest(\'.flexy-items\').querySelectorAll(\'.zoomImg\')).map(img => {\n external_jQuery_default()(img).stop().fadeTo(120, 0);\n });\n },\n // viewport | container\n wrapAroundMode: sliderEl.dataset.wrap === \'viewport\' ? \'viewport\' : \'container\'\n }, maybePillsSlider ? {\n pillsFlexyInstance: maybePillsSlider\n } : {}));\n\n if (maybePillsSlider) {\n const inst = new Flexy(maybePillsSlider, flexy_objectSpread({\n elementsThatDoNotStartDrag: [\'.twentytwenty-handle\'],\n // viewport | container\n wrapAroundMode: maybePillsSlider.dataset.wrap === \'viewport\' ? \'viewport\' : \'container\',\n leftArrow: maybePillsSlider.parentNode.querySelector(\'.flexy-arrow-prev\'),\n rightArrow: maybePillsSlider.parentNode.querySelector(\'.flexy-arrow-next\'),\n hasDragAndDrop: false\n }, maybePillsSlider.closest(\'.thumbs-left\') && (0,current_screen/* getCurrentScreen */.C)({\n withTablet: true\n }) !== \'mobile\' ? {\n orientation: \'vertical\'\n } : {}));\n maybePillsSlider.flexy = inst;\n }\n\n sliderEl.flexy = inst;\n};\nexternal_ctEvents_default().on(\'ct:flexy:update-height\', () => {\n ;\n [...document.querySelectorAll(\'.flexy-container\')].map(el => {\n if (!el.flexy) {\n return;\n }\n\n adjustContainerHeightFor(el.flexy);\n });\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"400.js","mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://ctFrontend/./node_modules/flexy/dist/flexy.es.js?6321","webpack://ctFrontend/./static/js/frontend/flexy.js?057c"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty2(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty2(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _defineProperty(obj, key, value) {\n  if (key in obj) {\n    Object.defineProperty(obj, key, {\n      value: value,\n      enumerable: true,\n      configurable: true,\n      writable: true\n    });\n  } else {\n    obj[key] = value;\n  }\n\n  return obj;\n}\n\nconst getRightOrBottom = (rect, flexyInstance) => {\n  if (flexyInstance.options.orientation === \"vertical\") {\n    return rect.top + rect.height;\n  }\n\n  return rect.right;\n};\n\nconst getLeftOrTop = (rect, flexyInstance) => {\n  if (flexyInstance.options.orientation === \"vertical\") {\n    return rect.top;\n  }\n\n  return rect.left;\n};\n\nconst getDimensionFor = (rect, flexyInstance) => {\n  if (flexyInstance.options.orientation === \"vertical\") {\n    return rect.height;\n  }\n\n  return rect.width;\n};\n/**\n * Develop a suggestion-based mechanism.\n * That is, ignore a checking for a specific side when we do not have a need\n * for it. Also, when we don't care about that particular side.\n *\n * TODO: implement _both_ strategy for wrapAround\n */\n\n\nconst fetchWrapAroundStatusFor = function (flexyInstance, elementsOnBehind) {\n  let theSideWeAreMovingOnto = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : \"left\";\n  let wrapAroundMode = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : \"container\";\n  const sliderContainer = flexyInstance.sliderContainer;\n  let relativeDelta = 0;\n\n  if (theSideWeAreMovingOnto === \"left\") {\n    let leftmostOffset = [...sliderContainer.children].reduce((leftmostEl, currentEl) => {\n      let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      return currentLeft < left ? currentEl : leftmostEl;\n    }, {\n      getBoundingClientRect: () => ({\n        left: 100000000000,\n        bottom: 100000000000,\n        top: 100000000000,\n        right: 100000000000\n      })\n    });\n\n    if (getLeftOrTop(nullifyTransforms(leftmostOffset, flexyInstance.options.nullifyTransformEl), flexyInstance) > (wrapAroundMode === \"container\" ? getLeftOrTop(nullifyTransforms(sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance) : 0)) {\n      relativeDelta = -1 * getDimensionFor(nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      elementsOnBehind = elementsOnBehind === sliderContainer.children.length ? 1 : elementsOnBehind + 1;\n    }\n  }\n\n  if (theSideWeAreMovingOnto === \"right\") {\n    let rightmostOffset = [...sliderContainer.children].reduce((rightmostEl, currentEl) => {\n      let right = getRightOrBottom(nullifyTransforms(rightmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      let currentRight = getRightOrBottom(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      return right > currentRight ? rightmostEl : currentEl;\n    }, {\n      getBoundingClientRect: () => ({\n        left: -1,\n        bottom: -9999999999999,\n        top: -1,\n        right: -1\n      })\n    });\n\n    if (getRightOrBottom(nullifyTransforms(rightmostOffset, flexyInstance.options.nullifyTransformEl), flexyInstance) < (wrapAroundMode === \"container\" ? getRightOrBottom(nullifyTransforms(sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance) : window.innerWidth)) {\n      relativeDelta = getDimensionFor(nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      elementsOnBehind = elementsOnBehind === 1 ? sliderContainer.children.length : elementsOnBehind - 1;\n    }\n  }\n\n  return {\n    relativeDelta,\n    elementsOnBehind\n  };\n};\n\nfunction nullifyTransforms(el) {\n  let elementToLookAt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n  if (!el) return null;\n\n  if (el.getBoundingClientRect && !el.firstElementChild) {\n    return el.getBoundingClientRect();\n  }\n\n  if (!elementToLookAt) {\n    elementToLookAt = el;\n  } //add sanity checks and default values\n\n\n  let {\n    top,\n    left,\n    right,\n    width,\n    height\n  } = el.getBoundingClientRect();\n  let transformArr = window.getComputedStyle(elementToLookAt).transform.split(/\\(|,|\\)/).slice(1, -1).map(v => parseFloat(v));\n\n  if (transformArr.length != 6) {\n    return el.getBoundingClientRect();\n  } // 2D matrix\n  // need some math to apply inverse of matrix\n  // That is the matrix of the transformation of the element\n\n\n  var t = transformArr;\n  let det = t[0] * t[3] - t[1] * t[2];\n  /*if (transformArr.length > 6)*/\n  //3D matrix\n  //haven't done the calculation to apply inverse of 4x4 matrix\n\n  return {\n    width: width / t[0],\n    height: height / t[3],\n    left: (left * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n    right: (right * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n    top: (-left * t[1] + top * t[0] + t[4] * t[1] - t[0] * t[5]) / det\n  };\n}\n\nconst renderPillsFor = flexyInstance => {\n  if (!flexyInstance.options.pillsContainerSelector) return;\n  flexyInstance.options.pillsContainerSelector.querySelector(\".active\") && flexyInstance.options.pillsContainerSelector.querySelector(\".active\").classList.remove(\"active\");\n  flexyInstance.options.pillsContainerSelector.children[flexyInstance.state.previousCurrentIndex].classList.add(\"active\");\n\n  if (flexyInstance.options.pillsFlexyInstance) {\n    let localFlexyInstance = flexyInstance.options.pillsFlexyInstance.flexy;\n    let allPills = [...flexyInstance.options.pillsContainerSelector.children];\n    let fromIndex = [...localFlexyInstance.sliderContainer.children].indexOf([...localFlexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n      let left = getLeftOrTop(nullifyTransforms(leftmostEl, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance);\n      let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance);\n      return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(localFlexyInstance.sliderContainer, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(localFlexyInstance.sliderContainer, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance)) ? currentEl : leftmostEl;\n    }, {\n      getBoundingClientRect: () => ({\n        left: 100000000000,\n        top: 100000000000\n      })\n    }));\n    let toIndex = 0;\n\n    if (localFlexyInstance.options.orientation === \"horizontal\") {\n      let perPage = Math.round(nullifyTransforms(localFlexyInstance.sliderContainer).width / nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild).width);\n      toIndex = flexyInstance.state.previousCurrentIndex;\n\n      if (perPage === 5) {\n        if (flexyInstance.state.previousCurrentIndex > 2) {\n          toIndex = flexyInstance.state.previousCurrentIndex - 2;\n        }\n\n        if (allPills.length - 1 - flexyInstance.state.previousCurrentIndex < 3) {\n          toIndex = allPills.length - 5;\n        }\n      }\n\n      if (perPage === 3) {\n        if (flexyInstance.state.previousCurrentIndex >= 1) {\n          toIndex = flexyInstance.state.previousCurrentIndex - 1;\n        }\n\n        if (allPills.length - 1 - flexyInstance.state.previousCurrentIndex < 1) {\n          toIndex = allPills.length - 3;\n        }\n      }\n    } else {\n      toIndex = flexyInstance.state.previousCurrentIndex;\n    }\n\n    let amountToTheLeft = Math.abs(toIndex - fromIndex);\n    let amountToTheRight = Math.min(fromIndex, toIndex) + (allPills.length - Math.max(fromIndex, toIndex));\n    let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight >= amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n    let resultTarget = Math.round(localFlexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) / 100 + getDimensionFor(nullifyTransforms(localFlexyInstance.sliderContainer.firstElementChild, localFlexyInstance.options.nullifyTransformEl), localFlexyInstance) * p;\n    localFlexyInstance.state = _objectSpread(_objectSpread({}, localFlexyInstance.state), {}, {\n      positionTarget: resultTarget\n    });\n  }\n};\n\nconst mountPillsListeners = flexyInstance => {\n  if (!flexyInstance.options.pillsContainerSelector) return;\n  let allPills = [...flexyInstance.options.pillsContainerSelector.children];\n\n  const handlePillEvent = singlePill => {\n    let fromIndex = [...flexyInstance.sliderContainer.children].indexOf([...flexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n      let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n      return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) ? currentEl : leftmostEl;\n    }, {\n      getBoundingClientRect: () => ({\n        left: 100000000000\n      })\n    }));\n    let toIndex = allPills.indexOf(singlePill);\n    flexyInstance.options.pillsContainerSelector.querySelector(\".active\") && flexyInstance.options.pillsContainerSelector.querySelector(\".active\").classList.remove(\"active\");\n    singlePill.classList.add(\"active\");\n    let amountToTheLeft = Math.abs(toIndex - fromIndex);\n    let amountToTheRight = Math.min(fromIndex, toIndex) + (allPills.length - Math.max(fromIndex, toIndex));\n    let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight >= amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n    let resultTarget = Math.round(flexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100 + getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) * p;\n    flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n      positionTarget: resultTarget\n    });\n  };\n\n  if (flexyInstance.options.initialDragEvent && flexyInstance.options.initialDragEvent.target.closest(\".flexy-pills > * > *\")) {\n    setTimeout(() => {\n      handlePillEvent(flexyInstance.options.initialDragEvent.target.closest(\".flexy-pills > * > *\"));\n    });\n  }\n\n  allPills.map(singlePill => singlePill.addEventListener(\"click\", e => {\n    handlePillEvent(singlePill);\n    e.preventDefault();\n  }));\n};\n\nconst moveToIndexFor = (flexyInstance, cb) => {\n  let fromIndex = [...flexyInstance.sliderContainer.children].indexOf([...flexyInstance.sliderContainer.children].reduce((leftmostEl, currentEl) => {\n    let left = getLeftOrTop(nullifyTransforms(leftmostEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n    let currentLeft = getLeftOrTop(nullifyTransforms(currentEl, flexyInstance.options.nullifyTransformEl), flexyInstance);\n    return Math.abs(currentLeft - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) < Math.abs(left - getLeftOrTop(nullifyTransforms(flexyInstance.sliderContainer, flexyInstance.options.nullifyTransformEl), flexyInstance)) ? currentEl : leftmostEl;\n  }, {\n    getBoundingClientRect: () => ({\n      left: 100000000000,\n      top: 100000000000\n    })\n  }));\n  let toIndex = cb(fromIndex);\n\n  if (toIndex < 0) {\n    toIndex = flexyInstance.sliderContainer.children.length - 1;\n  }\n\n  if (toIndex > flexyInstance.sliderContainer.children.length - 1) {\n    toIndex = 0;\n  }\n\n  let amountToTheLeft = Math.abs(toIndex - fromIndex);\n  let amountToTheRight = Math.min(fromIndex, toIndex) + (flexyInstance.sliderContainer.children.length - Math.max(fromIndex, toIndex));\n  let p = Math.min(amountToTheLeft, amountToTheRight) * (amountToTheRight > amountToTheLeft ? fromIndex > toIndex ? 1 : -1 : fromIndex > toIndex ? -1 : 1);\n  let resultTarget = Math.round(flexyInstance.state.positionX * 100 / getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100) * 100 * getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) / 100 + getDimensionFor(nullifyTransforms(flexyInstance.sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl), flexyInstance) * p;\n  flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n    positionTarget: resultTarget\n  });\n};\n\nconst mountArrowsListeners = flexyInstance => {\n  flexyInstance.options.leftArrow && flexyInstance.options.leftArrow.addEventListener(\"click\", e => {\n    e.preventDefault();\n    moveToIndexFor(flexyInstance, fromIndex => fromIndex - 1);\n  });\n  flexyInstance.options.rightArrow && flexyInstance.options.rightArrow.addEventListener(\"click\", e => {\n    e.preventDefault();\n    moveToIndexFor(flexyInstance, fromIndex => fromIndex + 1);\n  });\n};\n\nconst handleHoverStateFor = flexyInstance => {\n  const sliderContainer = flexyInstance.sliderContainer;\n  if (!flexyInstance.options.autoplay) return;\n  sliderContainer.addEventListener(\"mouseenter\", () => flexyInstance.options = _objectSpread(_objectSpread({}, flexyInstance.options), {}, {\n    autoplay: false,\n    _autoplay: flexyInstance.options.autoplay\n  }));\n  sliderContainer.addEventListener(\"mouseleave\", () => {\n    flexyInstance.options = _objectSpread(_objectSpread({}, flexyInstance.options), {}, {\n      autoplay: flexyInstance.options._autoplay,\n      _autoplay: false\n    });\n    flexyInstance.state = _objectSpread(_objectSpread({}, flexyInstance.state), {}, {\n      lastTimeAnimated: new Date().getTime()\n    });\n  });\n};\n\nconst adjustContainerHeightFor = flexyInstance => {\n  if (!flexyInstance.options.adjustHeight) return;\n  let currentChild = flexyInstance.sliderContainer.children[flexyInstance.state.previousCurrentIndex];\n  flexyInstance.sliderContainer.style.setProperty(\"--sliderHeight\", `${(currentChild.firstElementChild || currentChild).getBoundingClientRect().height}px`);\n};\n\nconst handleDragFor = (flexyInstance, getState, setState) => {\n  if (!flexyInstance.options.hasDragAndDrop) {\n    return;\n  }\n\n  const sliderContainer = flexyInstance.sliderContainer;\n\n  const handleDown = e => {\n    if (!getState().sliderActivated) return;\n\n    if (flexyInstance.options.elementsThatDoNotStartDrag.reduce((shouldSkipDrag, selector) => shouldSkipDrag ? true : e.target.matches(selector) || e.target.closest(selector), false)) {\n      return;\n    } // e.preventDefault()\n\n\n    e.stopPropagation();\n\n    if (e.type !== \"touchstart\") {\n      e.preventDefault();\n    }\n\n    flexyInstance.options.onDragStart(e);\n    setState(_objectSpread(_objectSpread({}, getState()), {}, {\n      startX: e.pageX || e.touches[0].pageX,\n      endX: e.pageX || e.touches[0].pageX,\n      mouseDown: true,\n      downScrollPosition: {\n        x: window.pageXOffset,\n        y: window.pageYOffset\n      },\n      positionSnapshot: getState().positionX\n    }));\n\n    const handleMouseUp = e => {\n      if (!getState().mouseDown) return;\n      e.stopPropagation();\n      setState(_objectSpread(_objectSpread({}, getState()), {}, {\n        mouseDown: false\n      }));\n      document.removeEventListener(\"mousemove\", handleMouseMove);\n      document.removeEventListener(\"mouseup\", handleMouseUp);\n      document.removeEventListener(\"touchmove\", handleMouseMove);\n      document.removeEventListener(\"touchend\", handleMouseUp);\n      let state = getState();\n      let fromPercentage = state.positionX * 100 / nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl).width;\n      setState(_objectSpread(_objectSpread({}, getState()), {}, {\n        positionTarget: nullifyTransforms(sliderContainer.firstElementChild, flexyInstance.options.nullifyTransformEl).width * (Math.abs(state.endX - state.startX) > 50 ? state.endX - state.startX < 0 ? Math.floor(fromPercentage / 100) * 100 : Math.ceil(fromPercentage / 100) * 100 : Math.round(fromPercentage / 100) * 100) / 100\n      }));\n    };\n\n    const handleMouseMove = e => {\n      let {\n        pageX: endX\n      } = e;\n\n      if (!endX) {\n        endX = e.touches[0].pageX;\n      }\n\n      if (!getState().mouseDown) return;\n      let state = getState();\n      setState(_objectSpread(_objectSpread({}, state), {}, {\n        endX\n      }));\n\n      if (Math.abs(state.downScrollPosition.x - state.scrollPosition.x) > 3 || Math.abs(state.downScrollPosition.y - state.scrollPosition.y) > 5) {\n        handleMouseUp(e);\n      }\n    };\n\n    document.addEventListener(\"mousemove\", handleMouseMove);\n    document.addEventListener(\"mouseup\", handleMouseUp);\n    document.addEventListener(\"touchmove\", handleMouseMove);\n    document.addEventListener(\"touchend\", handleMouseUp);\n  };\n\n  sliderContainer.addEventListener(\"mousedown\", handleDown);\n  sliderContainer.addEventListener(\"touchstart\", handleDown);\n\n  if (flexyInstance.options.initialDragEvent && !flexyInstance.options.initialDragEvent.target.closest(\".flexy-pills > * > *\")) {\n    requestAnimationFrame(() => {\n      handleDown(flexyInstance.options.initialDragEvent);\n    });\n  }\n};\n\nconst clamp = (n, min, max) => Math.min(Math.max(n, min), max);\n\nconst DESTROYED = \"__DESTROYED__\";\n\nclass Flexy {\n  constructor(sliderContainer) {\n    var _this = this;\n\n    let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n    _defineProperty(this, \"getDefaultState\", () => ({\n      elementsOnBehind: 1,\n      positionSnapshot: 0,\n      positionX: 0,\n\n      /**\n       * The thing the algorithm tends to move the slides to\n       */\n      positionTarget: 0,\n      velocity: 0,\n      containerInnerWidth: this.sliderContainer ? getDimensionFor(nullifyTransforms(this.sliderContainer, this.nullifyTransformEl), this) : 0,\n      slideWidth: this.sliderContainer ? getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.sliderContainer), this) : 0,\n      previousCurrentIndex: 0,\n      startX: 0,\n      endX: 0,\n      mouseDown: false,\n      lastTimeAnimated: Infinity\n    }));\n\n    _defineProperty(this, \"state\", this.getDefaultState());\n\n    _defineProperty(this, \"options\", {\n      onDragStart: () => {},\n      autoplay: false,\n      scaleRotateEffect: false,\n      pillsContainerSelector: null,\n      pillsFlexyInstance: null,\n      flexyAttributeEl: null,\n      initialDragEvent: null,\n      adjustHeight: false,\n      // container | viewport\n      wrapAroundMode: \"container\",\n      // horizontal | vertical\n      orientation: \"horizontal\",\n      nullifyTransformEl: null,\n      elementsThatDoNotStartDrag: [],\n      hasDragAndDrop: true\n    });\n\n    _defineProperty(this, \"sliderContainer\", null);\n\n    _defineProperty(this, \"drawLoop\", function () {\n      let fallThroughTheFirstDraw = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n      let oldPositionX = fallThroughTheFirstDraw ? Infinity : _this.state.positionX; // TODO: maybe do a smarter destroy\n\n      if (_this.state.sliderActivated === DESTROYED) {\n        return;\n      }\n\n      if (_this.state.containerInnerWidth !== nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl).width) {\n        _this.refreshActivation();\n      }\n\n      _this.state = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, _this.state), _this.state.sliderActivated ? ((t, c) => c(t))(_this.state.velocity + (\n      /**\n       * Apply different forces based on the conditions\n       */\n      _this.state.mouseDown ? _this.state.positionSnapshot + (_this.state.endX - _this.state.startX) - _this.state.positionX - _this.state.velocity : (_this.state.positionTarget - _this.state.positionX) * 0.02), velocity => ({\n        velocity: velocity * 0.72,\n        positionX: _this.state.positionX + velocity\n      })) : {}), _this.state.sliderActivated && Math.abs(_this.state.containerInnerWidth - getDimensionFor(nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl), _this)) > 1 ? {\n        positionX: Math.round(getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this) * (Math.round(_this.state.positionX / _this.state.slideWidth) * 100) / 100),\n        positionTarget: Math.round(getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this) * (Math.round(_this.state.positionX / _this.state.slideWidth) * 100) / 100)\n      } : {}), {}, {\n        scrollPosition: {\n          x: window.pageXOffset,\n          y: window.pageYOffset\n        },\n        containerInnerWidth: getDimensionFor(nullifyTransforms(_this.sliderContainer, _this.nullifyTransformEl), _this),\n        slideWidth: getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)\n      });\n\n      if ((oldPositionX !== _this.state.positionX || Math.abs(_this.state.positionX - _this.state.positionTarget) > 0.1) && !fallThroughTheFirstDraw) {\n        if (_this.state.sliderActivated) {\n          let {\n            relativeDelta,\n            elementsOnBehind\n          } = fetchWrapAroundStatusFor(_this, _this.state.elementsOnBehind, _this.state.mouseDown ? _this.state.endX <= _this.state.startX ? \"right\" : \"left\" : _this.state.positionX >= _this.state.positionTarget ? \"right\" : \"left\", _this.options.wrapAroundMode);\n          _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n            elementsOnBehind,\n            positionTarget: _this.state.positionTarget + relativeDelta,\n            positionX: _this.state.positionX + relativeDelta,\n            positionSnapshot: _this.state.positionSnapshot + relativeDelta\n          });\n        }\n      }\n\n      if (_this.options.autoplay && _this.state.sliderActivated) {\n        if (Math.abs(_this.state.positionX - _this.state.positionTarget) < 0.5) {\n          if (new Date().getTime() / 1000 - _this.state.lastTimeAnimated / 1000 > (parseFloat(_this.options.autoplay, 10) ? parseFloat(_this.options.autoplay, 10) : 3)) {\n            _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n              positionTarget: _this.state.positionX - getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)\n            });\n          }\n        }\n      }\n\n      if (!_this.state.mouseDown && _this.state.sliderActivated) {\n        if (Math.abs(_this.state.positionX - _this.state.positionTarget) < 0.2) {\n          _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n            positionX: _this.state.positionTarget,\n            velocity: 0\n          });\n        }\n\n        let oldIndex = _this.state.previousCurrentIndex;\n        _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n          previousCurrentIndex: clamp(_this.state.elementsOnBehind > Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) ? Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) + (_this.sliderContainer.children.length - _this.state.elementsOnBehind) : Math.abs(Math.round(Math.abs(_this.state.positionTarget) / getDimensionFor(nullifyTransforms(_this.sliderContainer.firstElementChild, _this.options.nullifyTransformEl), _this)) - _this.state.elementsOnBehind), 0, _this.sliderContainer.children.length - 1)\n        });\n\n        if (oldIndex !== _this.state.previousCurrentIndex) {\n          renderPillsFor(_this);\n          adjustContainerHeightFor(_this);\n          [..._this.sliderContainer.querySelectorAll(\"video\")].map(video => {\n            video.pause();\n          });\n          [..._this.sliderContainer.querySelectorAll('iframe[src*=\"youtu\"]')].map(i => {\n            i.contentWindow.postMessage('{\"event\":\"command\",\"func\":\"stopVideo\",\"args\":\"\"}', \"*\");\n          });\n          [..._this.sliderContainer.querySelectorAll('iframe:not([src*=\"youtu\"])')].map(i => {\n            const source = i.src;\n            i.src = \"\";\n            i.src = source;\n          });\n        }\n      }\n\n      if (_this.state.positionX !== oldPositionX && _this.state.sliderActivated) {\n        _this.render(); // handleScaleRotateEffectFor(this)\n\n\n        _this.state = _objectSpread(_objectSpread({}, _this.state), {}, {\n          lastTimeAnimated: new Date().getTime()\n        });\n      }\n\n      requestAnimationFrame(() => _this.drawLoop());\n    });\n\n    this.options = _objectSpread(_objectSpread({}, this.options), {}, {\n      flexyAttributeEl: sliderContainer,\n      nullifyTransformEl: sliderContainer\n    }, options);\n    this.sliderContainer = sliderContainer;\n    mountPillsListeners(this);\n    mountArrowsListeners(this);\n    handleHoverStateFor(this);\n    handleDragFor(this, () => this.state, newState => this.state = newState);\n    [...this.sliderContainer.children].map(singleSlide => singleSlide.addEventListener(\"click\", e => Math.abs(this.state.startX - this.state.endX) > 3 && e.preventDefault()));\n    let _elementsOnBehind = 1;\n    let firstItem = 1;\n    let flexyAttributeElStyle = getComputedStyle(this.options.flexyAttributeEl);\n\n    if (flexyAttributeElStyle.getPropertyValue(\"--current-item\")) {\n      firstItem = parseInt(flexyAttributeElStyle.getPropertyValue(\"--current-item\"));\n      _elementsOnBehind = this.sliderContainer.children.length;\n    }\n\n    this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n      elementsOnBehind: _elementsOnBehind,\n      positionX: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this) * firstItem * -1,\n      positionTarget: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this) * firstItem * -1,\n      containerInnerWidth: getDimensionFor(nullifyTransforms(this.sliderContainer, this.nullifyTransformEl), this),\n      slideWidth: getDimensionFor(nullifyTransforms(this.sliderContainer.firstElementChild, this.options.nullifyTransformEl), this)\n    });\n    this.refreshActivation();\n    requestAnimationFrame(() => this.drawLoop(true));\n    adjustContainerHeightFor(this);\n  }\n\n  destroy() {\n    this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n      sliderActivated: DESTROYED\n    });\n  }\n\n  refreshActivation() {\n    let totalSlidesWidth = getDimensionFor(nullifyTransforms(this.sliderContainer.children[0], this.options.nullifyTransformEl) || {\n      width: 0,\n      height: 0\n    }, this) * this.sliderContainer.children.length;\n    this.state = _objectSpread(_objectSpread({}, this.state), {}, {\n      sliderActivated: this.sliderContainer ? getComputedStyle(this.sliderContainer, \":after\").content.indexOf(\"no-flexy\") === -1 && totalSlidesWidth > getDimensionFor(nullifyTransforms(this.sliderContainer, this.options.nullifyTransformEl), this) + 10 : false\n      /*\n      &&\n          totalSlidesWidth > window.innerWidth\n          */\n\n    });\n\n    if (this.state.sliderActivated) {\n      this.options.flexyAttributeEl.dataset.flexy = \"\";\n    } else {\n      this.options.flexyAttributeEl.removeAttribute(\"data-flexy\");\n      [...this.sliderContainer.children].map(el => el.removeAttribute(\"style\"));\n    }\n  }\n\n  render() {\n    [...this.sliderContainer.children].map(el => {\n      if (this.options.orientation === \"vertical\") {\n        el.style.transform = `translate3d(0, ${this.state.positionX}px, 0)`;\n      } else {\n        el.style.transform = `translate3d(${this.state.positionX}px, 0, 0)`;\n      }\n    });\n\n    if (this.state.mouseDown) {\n      this.options.flexyAttributeEl.dataset.flexyDragging = \"\";\n    } else {\n      this.options.flexyAttributeEl.removeAttribute(\"data-flexy-dragging\");\n    }\n\n    if (this.state.elementsOnBehind > 0) {\n      [...this.sliderContainer.children].slice(0, this.state.elementsOnBehind * -1).map(el => el.style.order = 2);\n      [...this.sliderContainer.children].slice(this.state.elementsOnBehind * -1).map(el => el.style.order = 1);\n    } else {\n      [...this.sliderContainer.children].map(el => el.style.order = 1);\n    }\n  }\n\n}\n\nexport { Flexy, adjustContainerHeightFor };","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport $ from 'jquery';\nimport { Flexy, adjustContainerHeightFor } from 'flexy';\nimport ctEvents from 'ct-events';\nimport { getCurrentScreen } from '../frontend/helpers/current-screen';\nexport const mount = (sliderEl, args) => {\n  // sliderEl = sliderEl.parentNode\n  if (sliderEl.flexy) {\n    return;\n  }\n\n  let maybePillsSlider = sliderEl.querySelector('.flexy-pills [data-flexy]');\n  const inst = new Flexy(sliderEl.querySelector('.flexy-items'), _objectSpread(_objectSpread(_objectSpread({\n    flexyAttributeEl: sliderEl,\n    elementsThatDoNotStartDrag: ['.twentytwenty-handle'],\n    adjustHeight: !!sliderEl.querySelector('.flexy-items').dataset.height\n  }, args.event ? {\n    initialDragEvent: args.event\n  } : {}), {}, {\n    autoplay: Object.keys(sliderEl.dataset).indexOf('autoplay') > -1 && parseInt(sliderEl.dataset.autoplay, 10) ? sliderEl.dataset.autoplay : false\n  }, sliderEl.querySelector('.flexy-pills') ? {\n    pillsContainerSelector: sliderEl.querySelector('.flexy-pills').firstElementChild\n  } : {}), {}, {\n    leftArrow: sliderEl.querySelector('.flexy .flexy-arrow-prev'),\n    rightArrow: sliderEl.querySelector('.flexy .flexy-arrow-next'),\n    scaleRotateEffect: false,\n    onDragStart: e => {\n      if (!e.target.closest('.flexy-items')) {\n        return;\n      }\n\n      Array.from(e.target.closest('.flexy-items').querySelectorAll('.zoomImg')).map(img => {\n        $(img).stop().fadeTo(120, 0);\n      });\n    },\n    // viewport | container\n    wrapAroundMode: sliderEl.dataset.wrap === 'viewport' ? 'viewport' : 'container'\n  }, maybePillsSlider ? {\n    pillsFlexyInstance: maybePillsSlider\n  } : {}));\n\n  if (maybePillsSlider) {\n    const inst = new Flexy(maybePillsSlider, _objectSpread({\n      elementsThatDoNotStartDrag: ['.twentytwenty-handle'],\n      // viewport | container\n      wrapAroundMode: maybePillsSlider.dataset.wrap === 'viewport' ? 'viewport' : 'container',\n      leftArrow: maybePillsSlider.parentNode.querySelector('.flexy-arrow-prev'),\n      rightArrow: maybePillsSlider.parentNode.querySelector('.flexy-arrow-next'),\n      hasDragAndDrop: false\n    }, maybePillsSlider.closest('.thumbs-left') && getCurrentScreen({\n      withTablet: true\n    }) !== 'mobile' ? {\n      orientation: 'vertical'\n    } : {}));\n    maybePillsSlider.flexy = inst;\n  }\n\n  sliderEl.flexy = inst;\n};\nctEvents.on('ct:flexy:update-height', () => {\n  ;\n  [...document.querySelectorAll('.flexy-container')].map(el => {\n    if (!el.flexy) {\n      return;\n    }\n\n    adjustContainerHeightFor(el.flexy);\n  });\n});"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///400\n')}}]);