angular-responsive-carousel
Advanced tools
Comparing version 1.4.11 to 1.5.11
@@ -365,5 +365,7 @@ (function (global, factory) { | ||
this.initialPositionX = 0; | ||
this.newContainerPositionIndex = 0; // The index of the new position relative to the active index, for example -1 or +1 | ||
/* The index of the new position relative to the active index, for example -1 or +1 */ | ||
this.newContainerPositionIndex = 0; | ||
this.preliminarySlideCounter = 0; | ||
this.slideCounter = 0; // Scrolling Index (counter) | ||
/* Scrolling Index (counter) */ | ||
this.slideCounter = 0; | ||
this.previousSlideCounter = 0; | ||
@@ -377,19 +379,8 @@ this.isContentImages = true; | ||
_this.isTouchstart = true; | ||
if (_this.isSlideInProgress) { | ||
return; | ||
} | ||
var touches = event.touches; | ||
if (touches) { | ||
_this.startX = touches[0].clientX - _this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
_this.startX = event.clientX - _this.getCarouselElementPosition()['left']; | ||
} | ||
_this.startX = _this.getStartX(event); | ||
_this.containerInitialPositionX = _this.getElementPosition()['left'] - _this.getCarouselElementPosition()['left']; | ||
_this.isMoveInProgress = true; | ||
_this.stopTransformContainer(); | ||
}; | ||
this.handleHorizontalSwipe = function (event) { | ||
if (_this.isSlideInProgress) { | ||
return; | ||
} | ||
var touches = event.touches; | ||
@@ -407,3 +398,3 @@ if (touches) { | ||
this.handleTouchend = function (event) { | ||
if (_this.isSlideInProgress || !_this.isTouchstart) { | ||
if (!_this.isTouchstart) { | ||
_this.isTouchstart = false; | ||
@@ -561,2 +552,20 @@ return; | ||
}); | ||
Carousel.prototype.stopTransformContainer = function () { | ||
this.transformPositionX(this.containerInitialPositionX, 0); | ||
this.setSlideCounter(); | ||
this.isSlideInProgress = false; | ||
this.newContainerPositionIndex = 0; | ||
this.isSlideLengthLimited = undefined; | ||
}; | ||
Carousel.prototype.getStartX = function (event) { | ||
var touches = event.touches; | ||
var startX; | ||
if (touches) { | ||
startX = touches[0].clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
startX = event.clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
return startX; | ||
}; | ||
/* Move */ | ||
@@ -587,2 +596,3 @@ Carousel.prototype.moveContainer = function () { | ||
}; | ||
/* Offset the container to show the last cell completely */ | ||
Carousel.prototype.getContainerPositionCorrection = function () { | ||
@@ -689,5 +699,3 @@ var correction = 0; | ||
if (length === void 0) { length = 1; } | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'left'; | ||
@@ -698,5 +706,3 @@ this.handleSlide(length); | ||
if (length === void 0) { length = 1; } | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'right'; | ||
@@ -709,41 +715,57 @@ this.handleSlide(length); | ||
}; | ||
Carousel.prototype.handleSlide = function (slideLength) { | ||
if (slideLength === void 0) { slideLength = undefined; } | ||
this.slideLength = this.getSlideLength(); | ||
this.slideLength = slideLength ? slideLength : this.limitSlideLength(this.slideLength); | ||
if (this.direction === 'left' && !this.isSlideInProgress) { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
if (!this.detectLastSlide(this.slideCounter + this.slideLength)) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
Carousel.prototype.handleSlide = function (customSlideLength) { | ||
if (customSlideLength === void 0) { customSlideLength = undefined; } | ||
var isUsingButton = customSlideLength; | ||
if (isUsingButton && this.isSlideInProgress) { | ||
return; | ||
} | ||
this.slideLength = customSlideLength ? customSlideLength : this.limitSlideLength(this.getSlideLength()); | ||
if (this.direction === 'left') { | ||
this.handleLeftSlide(); | ||
} | ||
if (this.direction === 'right') { | ||
this.handleRightSlide(); | ||
} | ||
this.alignContainer(); | ||
}; | ||
Carousel.prototype.handleLeftSlide = function () { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
var isLastSlide = this.detectLastSlide(this.slideCounter + this.slideLength); | ||
if (!isLastSlide) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
if (this.direction === 'right' && !this.isSlideInProgress) { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
else { | ||
this.slideLength = 0; | ||
} | ||
}; | ||
Carousel.prototype.handleRightSlide = function () { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
this.alignContainer(); | ||
else { | ||
this.slideLength = 0; | ||
} | ||
}; | ||
@@ -758,2 +780,6 @@ Carousel.prototype.getSlideLength = function () { | ||
}; | ||
/* | ||
* Limits the length of the slide during calls to the next() and prev() | ||
* methods if the specified position is outside the cell length | ||
*/ | ||
Carousel.prototype.limitSlideLength = function (slideLength) { | ||
@@ -915,3 +941,3 @@ if (slideLength > 1) { | ||
this.objectFit = 'cover'; | ||
this.minSwipeDistance = 50; | ||
this.minSwipeDistance = 10; | ||
this.transitionDuration = 200; | ||
@@ -918,0 +944,0 @@ this.transitionTimingFunction = 'ease'; |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-responsive-carousel",["exports","@angular/core","@angular/common"],e):e((t=t||self)["angular-responsive-carousel"]={},t.ng.core,t.ng.common)}(this,(function(t,e,i){"use strict";var n=function(){function t(t){var e=this;this.eventType=void 0,this.handlers={},this.startX=0,this.startY=0,this.lastTap=0,this.doubleTapMinTimeout=300,this.tapMinTimeout=200,this.touchstartTime=0,this.i=0,this.isMousedown=!1,this._touchListeners={touchstart:"handleTouchstart",touchmove:"handleTouchmove",touchend:"handleTouchend"},this._mouseListeners={mousedown:"handleMousedown",mousemove:"handleMousemove",mouseup:"handleMouseup",wheel:"handleWheel"},this._otherListeners={resize:"handleResize"},this.handleTouchstart=function(t){e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getTouchstartPosition(t),e.runHandler("touchstart",t)},this.handleTouchmove=function(t){var i=t.touches;switch(e.detectPan(i)&&e.runHandler("pan",t),e.detectPinch(t)&&e.runHandler("pinch",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)},this.handleTouchend=function(t){var i=t.touches;e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.runHandler("touchend",t),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0,e.i=0)},this.handleMousedown=function(t){e.isMousedown=!0,e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getMousedownPosition(t),e.runHandler("mousedown",t)},this.handleMousemove=function(t){if(e.isMousedown){switch(e.runHandler("pan",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)}},this.handleMouseup=function(t){e.detectTap(),e.isMousedown=!1,e.runHandler("mouseup",t),e.eventType=void 0,e.i=0},this.handleWheel=function(t){e.runHandler("wheel",t)},this.handleResize=function(t){e.runHandler("resize",t)},this.properties=t,this.element=this.properties.element,this.elementPosition=this.getElementPosition(),this.toggleEventListeners("addEventListener")}return Object.defineProperty(t.prototype,"touchListeners",{get:function(){return this.properties.touchListeners?this.properties.touchListeners:this._touchListeners},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"mouseListeners",{get:function(){return this.properties.mouseListeners?this.properties.mouseListeners:this._mouseListeners},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"otherListeners",{get:function(){return this.properties.otherListeners?this.properties.otherListeners:this._otherListeners},enumerable:!1,configurable:!0}),t.prototype.destroy=function(){this.toggleEventListeners("removeEventListener")},t.prototype.toggleEventListeners=function(t){var e;for(var i in e="mouse and touch"===this.properties.listeners?Object.assign(this.touchListeners,this.mouseListeners):this.detectTouchScreen()?this.touchListeners:this.mouseListeners,this.properties.resize&&(e=Object.assign(e,this.otherListeners)),e){var n=e[i];"resize"===i?("addEventListener"===t&&window.addEventListener(i,this[n],!1),"removeEventListener"===t&&window.removeEventListener(i,this[n],!1)):"mouseup"===i||"mousemove"===i?("addEventListener"===t&&document.addEventListener(i,this[n],!1),"removeEventListener"===t&&document.removeEventListener(i,this[n],!1)):("addEventListener"===t&&this.element.addEventListener(i,this[n],!1),"removeEventListener"===t&&this.element.removeEventListener(i,this[n],!1))}},t.prototype.addEventListeners=function(t,e){window.addEventListener(t,this[e],!1)},t.prototype.removeEventListeners=function(t,e){window.removeEventListener(t,this[e],!1)},t.prototype.handleLinearSwipe=function(t){this.i++,this.i>3&&(this.eventType=this.getLinearSwipeType(t)),"horizontal-swipe"===this.eventType&&this.runHandler("horizontal-swipe",t),"vertical-swipe"===this.eventType&&this.runHandler("vertical-swipe",t)},t.prototype.runHandler=function(t,e){this.handlers[t]&&this.handlers[t](e)},t.prototype.detectPan=function(t){return 1===t.length&&!this.eventType||"pan"===this.eventType},t.prototype.detectDoubleTap=function(){var t=this;if(null==this.eventType){var e=(new Date).getTime(),i=e-this.lastTap;if(clearTimeout(this.doubleTapTimeout),i<this.doubleTapMinTimeout&&i>0)return!0;this.doubleTapTimeout=setTimeout((function(){clearTimeout(t.doubleTapTimeout)}),this.doubleTapMinTimeout),this.lastTap=e}},t.prototype.detectTap=function(){if(null==this.eventType){var t=(new Date).getTime()-this.touchstartTime;t>0&&(t<this.tapMinTimeout?this.runHandler("tap",event):this.runHandler("longtap",event))}},t.prototype.detectPinch=function(t){return 2===t.touches.length&&void 0===this.eventType||"pinch"===this.eventType},t.prototype.detectLinearSwipe=function(t){var e=t.touches;if(e){if(1===e.length&&!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)}else if(!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)},t.prototype.getLinearSwipeType=function(t){if("horizontal-swipe"!==this.eventType&&"vertical-swipe"!==this.eventType){var e=Math.abs(this.moveLeft(0,t)-this.startX);return 3*Math.abs(this.moveTop(0,t)-this.startY)>e?"vertical-swipe":"horizontal-swipe"}return this.eventType},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){this.startX=t.touches[0].clientX-this.elementPosition.left,this.startY=t.touches[0].clientY-this.elementPosition.top},t.prototype.getMousedownPosition=function(t){this.startX=t.clientX-this.elementPosition.left,this.startY=t.clientY-this.elementPosition.top},t.prototype.moveLeft=function(t,e){var i=e.touches;return i?i[t].clientX-this.elementPosition.left:e.clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){var i=e.touches;return i?i[t].clientY-this.elementPosition.top:e.clientY-this.elementPosition.top},t.prototype.detectTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},t.prototype.on=function(t,e){t&&(this.handlers[t]=e)},t}(),o=function(){function t(t){var e=this;this.initialPositionX=0,this.newContainerPositionIndex=0,this.preliminarySlideCounter=0,this.slideCounter=0,this.previousSlideCounter=0,this.isContentImages=!0,this.isLazyLoad=!0,this.isContainerLocked=!0,this.alignCells="left",this.initialContainerPosition=0,this.handleTouchstart=function(t){if(e.isTouchstart=!0,!e.isSlideInProgress){var i=t.touches;e.startX=i?i[0].clientX-e.getCarouselElementPosition().left:t.clientX-e.getCarouselElementPosition().left,e.containerInitialPositionX=e.getElementPosition().left-e.getCarouselElementPosition().left,e.isMoveInProgress=!0}},this.handleHorizontalSwipe=function(t){if(!e.isSlideInProgress){var i=t.touches;e.moveX=i?i[0].clientX-e.getCarouselElementPosition().left:t.clientX-e.getCarouselElementPosition().left,e.distanceAbs=e.getDistanceAbs(),e.direction=e.getDirection(),e.moveContainer()}},this.handleTouchend=function(t){!e.isSlideInProgress&&e.isTouchstart?(e.isMoveInProgress=!1,e.detectSlide()?e.handleSlide():(e.newContainerPositionIndex=0,e.alignContainer()),e.startX=e.moveX=e.distanceAbs=void 0,e.isTouchstart=!1):e.isTouchstart=!1},this.element=t.element,this.properties=t,this.cells=this.element.children,this.visibleWidth=this.properties.visibleWidth||this.element.parentElement.clientWidth,this.setContainerWidth(),this.alignContainer(0)}return Object.defineProperty(t.prototype,"cellLength",{get:function(){return this.images?this.images.length:this.cells.length},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"totalContainerCellsCount",{get:function(){if(this.images){var t=this.visibleCellsCount+2*this.overflowCellsLimit;return t>this.images.length&&(t=this.images.length),t}return this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isFirstCell",{get:function(){return 0===this.slideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lastCellIndex",{get:function(){return this.images.length?this.images.length-1:this.cells.length-1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"overflowCellsLimit",{get:function(){return this.images&&this.isImagesLessCellLimit?Math.floor((this.images.length-this.visibleCellsCount)/2):this.properties.overflowCellsLimit},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isImagesLessCellLimit",{get:function(){return 2*this.properties.overflowCellsLimit+this.visibleCellsCount>this.images.length},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellLimit",{get:function(){return this.visibleCellsCount+2*this.overflowCellsLimit},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"images",{get:function(){return this.properties.images},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"margin",{get:function(){return this.properties.margin},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"minSwipeDistance",{get:function(){return this.properties.minSwipeDistance},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"transitionDuration",{get:function(){return this.properties.transitionDuration},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"transitionTimingFunction",{get:function(){return this.properties.transitionTimingFunction},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"fullCellWidth",{get:function(){return this.properties.cellWidth+this.margin},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"visibleCellsCount",{get:function(){return Math.ceil(this.visibleWidth/this.fullCellWidth)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lapCounter",{get:function(){return Math.floor(this.slideCounter/this.totalContainerCellsCount)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"visibleCellsOverflowContainer",{get:function(){return this.visibleCellsCount*this.fullCellWidth-this.margin>this.visibleWidth},enumerable:!1,configurable:!0}),t.prototype.moveContainer=function(){var t=this.getMovePositionX();this.transformPositionX(t,0)},t.prototype.getMovePositionX=function(){var t=this.getDistance();return this.containerInitialPositionX-t},t.prototype.alignContainer=function(t){void 0===t&&(t=this.transitionDuration);var e=this.getContainerPosition();this.transformPositionX(e,t),this.setInitialContainerPosition(e)},t.prototype.getContainerPosition=function(){var t=this.getContainerPositionCorrection();return this.isContainerPositionCorrection=0!=t,this.initialContainerPosition+this.newContainerPositionIndex*this.fullCellWidth+t},t.prototype.setInitialContainerPosition=function(t){var e=this.getContainerPositionCorrection();this.initialContainerPosition=t-e},t.prototype.getContainerPositionCorrection=function(){var t=0;return this.properties.loop?0:((this.cellLength-this.preliminarySlideCounter<this.visibleCellsCount||this.isSlideLengthLimited)&&(this.visibleWidth<this.totalContainerCellsCount*this.fullCellWidth&&(t=-(this.visibleCellsCount*this.fullCellWidth-this.visibleWidth-this.margin)),t>=-this.margin&&(t=0)),t)},t.prototype.quicklyPositionContainer=function(){var t=this.getContainerPositionCorrection(),e=this.getNewContainerPosition()+t;this.transformPositionX(e,0),this.setInitialContainerPosition(e)},t.prototype.getNewContainerPosition=function(){return this.slideCounter>this.overflowCellsLimit&&"left"===this.alignCells?(this.lineUpCells(),-this.overflowCellsLimit*this.fullCellWidth):this.slideCounter<=this.overflowCellsLimit?(this.previousSlideCounter>this.overflowCellsLimit&&this.lineUpCells(),-this.slideCounter*this.fullCellWidth):void 0},t.prototype.setContainerWidth=function(){var t=this.getContainerWidth();this.element.style.width=t+"px"},t.prototype.getContainerWidth=function(){var t=this.totalContainerCellsCount*this.fullCellWidth,e=this.cellLength*this.fullCellWidth;return e<t&&(t=e),t},t.prototype.getFile=function(t){var e=this.getFileIndex(t),i=this.images[e];return i&&!i.type&&(i.type="image"),{image:this.images[e],imageIndex:e}},t.prototype.getFileIndex=function(t){var e,i=this.getPositionIndex(t),n=(this.totalContainerCellsCount,this.slideCounter);if(!this.isContainerLocked)return n<=this.overflowCellsLimit?t:(e=i+(n-this.overflowCellsLimit),this.images&&this.properties.loop&&(e%=this.images.length),e);"left"===this.alignCells&&(e=n>this.overflowCellsLimit?i+(n-this.overflowCellsLimit):t);return!(e>this.lastCellIndex&&!this.properties.loop)&&e},t.prototype.transformPositionX=function(t,e){void 0===e&&(e=this.transitionDuration),this.element.style.transition="transform "+e+"ms "+this.transitionTimingFunction,this.element.style.transform="translateX("+t+"px)"},t.prototype.detectSlide=function(){return this.distanceAbs>=this.minSwipeDistance},t.prototype.next=function(t){void 0===t&&(t=1),this.isSlideInProgress||(this.direction="left",this.handleSlide(t))},t.prototype.prev=function(t){void 0===t&&(t=1),this.isSlideInProgress||(this.direction="right",this.handleSlide(t))},t.prototype.select=function(t){this.slideCounter=t,this.quicklyPositionContainer()},t.prototype.handleSlide=function(t){void 0===t&&(t=void 0),this.slideLength=this.getSlideLength(),this.slideLength=t||this.limitSlideLength(this.slideLength),"left"!==this.direction||this.isSlideInProgress||(this.preliminarySlideCounter=this.slideCounter+this.slideLength,this.detectLastSlide(this.slideCounter+this.slideLength)||(this.newContainerPositionIndex=this.newContainerPositionIndex-this.slideLength,this.isSlideInProgress=!0,this.isLazyLoad&&(this.isContainerLocked=this.preliminarySlideCounter>this.overflowCellsLimit,this.detectContainerUnlock()&&(this.isContainerLocked=!1)))),"right"!==this.direction||this.isSlideInProgress||(this.slideCounter-this.slideLength<0&&(this.slideLength=this.slideCounter),this.preliminarySlideCounter=this.slideCounter-this.slideLength,this.isFirstCell||(this.newContainerPositionIndex=this.newContainerPositionIndex+this.slideLength,this.isSlideInProgress=!0,this.isLazyLoad&&(this.preliminarySlideCounter>this.overflowCellsLimit?this.isContainerLocked=!0:this.isContainerLocked=!1,this.detectContainerUnlock()&&(this.isContainerLocked=!1)))),this.alignContainer()},t.prototype.getSlideLength=function(){var t=this.getContainerPositionCorrection(),e=Math.floor((this.distanceAbs+t)/this.fullCellWidth);return this.distanceAbs%this.fullCellWidth>=this.minSwipeDistance&&e++,e},t.prototype.limitSlideLength=function(t){if(t>1)for(var e=0;e<t;e++){var i=this.slideCounter+(t-e);if(!this.detectLastSlide(i)){t-=e,this.isSlideLengthLimited=e>0;break}}return t},t.prototype.detectLastSlide=function(t){return!this.properties.loop&&this.cellLength-t<this.visibleCellsCount},t.prototype.isNextArrowDisabled=function(){return this.visibleCellsOverflowContainer?this.detectLastSlide(this.slideCounter+1)&&this.isContainerPositionCorrection:this.detectLastSlide(this.slideCounter+1)},t.prototype.isPrevArrowDisabled=function(){return 0===this.slideCounter},t.prototype.detectContainerUnlock=function(){return this.cellLength-this.preliminarySlideCounter<this.visibleCellsCount+this.overflowCellsLimit},t.prototype.handleSlideEnd=function(){this.isSlideInProgress&&(this.transformSlideEnd(),this.isSlideInProgress=!1,this.newContainerPositionIndex=0,this.isSlideLengthLimited=void 0)},t.prototype.transformSlideEnd=function(){this.isLazyLoad&&(this.setSlideCounter(),(this.images||!this.images&&this.properties.loop)&&this.quicklyPositionContainer()),this.previousSlideCounter=this.slideCounter},t.prototype.setSlideCounter=function(){"left"===this.direction&&(this.slideCounter=this.slideCounter+this.slideLength),"right"===this.direction&&(this.slideCounter=this.slideCounter-this.slideLength),this.direction=void 0,this.slideLength=0},t.prototype.resetTransition=function(){this.element.style.transition=""},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getCarouselElementPosition=function(){return this.properties.container.getBoundingClientRect()},t.prototype.getDistance=function(){return this.startX-this.moveX},t.prototype.getDistanceAbs=function(){return Math.abs(this.startX-this.moveX)},t.prototype.getDirection=function(){var t=Math.sign(this.startX-this.moveX);return-1===t?"right":1===t?"left":void 0},t.prototype.lineUpCells=function(){for(var t=this.element.children,e=0;e<t.length;e++){var i=t[e],n=this.getCellPositionX(e);i.style.transform="translateX("+n+"px)",i.style.width=this.properties.cellWidth+"px"}},t.prototype.getCellPositionX=function(t){return this.getPositionIndex(t)*this.fullCellWidth},t.prototype.getPositionIndex=function(t){var e,i=this.slideCounter,n=this.totalContainerCellsCount,o=i-this.overflowCellsLimit;return o>n&&(o%=n),o<0?t:((e=t-o)<0&&(e=n+e),e)},t.prototype.getCenterPositionIndex=function(){return(this.totalContainerCellsCount-1)/2},t.prototype.autoplay=function(){var t=this;this.autoplayId=setInterval((function(){t.next()}),this.properties.autoplayInterval)},t.prototype.stopAutoplay=function(){this.autoplayId&&clearInterval(this.autoplayId)},t.prototype.destroy=function(){this.stopAutoplay()},t}(),s=function(){function t(t,i){var n=this;this.elementRef=t,this.ref=i,this.minTimeout=30,this._cellWidth=200,this.events=new e.EventEmitter,this.height=200,this.loop=!1,this.autoplay=!1,this.autoplayInterval=5e3,this.pauseOnHover=!0,this.dots=!1,this.margin=10,this.objectFit="cover",this.minSwipeDistance=50,this.transitionDuration=200,this.transitionTimingFunction="ease",this.counterSeparator=" / ",this.overflowCellsLimit=3,this.listeners="mouse and touch",this.cellsToScroll=1,this.arrows=!0,this.arrowsTheme="light",this.hostClassCarousel=!0,this.handleTouchstart=function(t){n.touches.addEventListeners("mousemove","handleMousemove"),n.carousel.handleTouchstart(t),n.isMoving=!0},this.handleHorizontalSwipe=function(t){t.preventDefault(),n.carousel.handleHorizontalSwipe(t)},this.handleTouchend=function(t){t.touches;n.carousel.handleTouchend(t),n.touches.removeEventListeners("mousemove","handleMousemove"),n.isMoving=!1}}return Object.defineProperty(t.prototype,"isContainerLocked",{get:function(){return this.carousel.isContainerLocked},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"slideCounter",{get:function(){return this.carousel.slideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"previousSlideCounter",{get:function(){return this.carousel.previousSlideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lapCounter",{get:function(){return this.carousel.lapCounter},enumerable:!1,configurable:!0}),t.prototype.lineUpCells=function(){this.carousel.lineUpCells()},t.prototype.quicklyPositionContainer=function(){this.carousel.quicklyPositionContainer()},Object.defineProperty(t.prototype,"isLandscape",{get:function(){return window.innerWidth>window.innerHeight},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isSafari",{get:function(){var t=navigator.userAgent.toLowerCase();if(-1!==t.indexOf("safari"))return!(t.indexOf("chrome")>-1)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"counter",{get:function(){return(this.loop?this.slideCounter%this.cellLength:this.slideCounter)+1+this.counterSeparator+this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellsElement",{get:function(){return this.elementRef.nativeElement.querySelector(".carousel-cells")},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"images",{get:function(){return this._images},set:function(t){this._images=t},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellWidth",{set:function(t){t&&(this._cellWidth=t)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isCounter",{get:function(){return this._isCounter&&this.cellLength>1},set:function(t){t&&(this._isCounter=t)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"activeDotIndex",{get:function(){return this.slideCounter%this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellLimit",{get:function(){if(this.carousel)return this.carousel.cellLimit},enumerable:!1,configurable:!0}),t.prototype.onWindowResize=function(t){this.landscapeMode=this.isLandscape,this.ref.detectChanges(),this.initCarousel(),this.carousel.lineUpCells()},t.prototype.onMousemove=function(t){this.autoplay&&this.pauseOnHover&&this.carousel.stopAutoplay()},t.prototype.onMouseleave=function(t){this.autoplay&&this.pauseOnHover&&this.carousel.autoplay()},t.prototype.ngOnInit=function(){this.isNgContent=this.cellsElement.children.length>0,this.touches=new n({element:this.cellsElement,listeners:this.listeners,mouseListeners:{mousedown:"handleMousedown",mouseup:"handleMouseup"}}),this.touches.on("touchstart",this.handleTouchstart),this.touches.on("horizontal-swipe",this.handleHorizontalSwipe),this.touches.on("touchend",this.handleTouchend),this.touches.on("mousedown",this.handleTouchstart),this.touches.on("mouseup",this.handleTouchend),this.initCarousel(),this.setDimensions(),this.autoplay&&this.carousel.autoplay()},t.prototype.ngAfterViewInit=function(){this.cellLength=this.getCellLength(),this.dotsArr=Array(this.cellLength).fill(1),this.ref.detectChanges(),this.carousel.lineUpCells(),this.detectDomChanges()},t.prototype.ngOnChanges=function(t){(t.width||t.height||t.images)&&(this.setDimensions(),this.initCarousel(),this.carousel.lineUpCells(),this.ref.detectChanges())},t.prototype.ngOnDestroy=function(){this.touches.destroy(),this.carousel.destroy()},t.prototype.initCarousel=function(){this.carousel=new o({element:this.elementRef.nativeElement.querySelector(".carousel-cells"),container:this.elementRef.nativeElement,images:this.images,cellWidth:this.getCellWidth(),loop:this.loop,autoplayInterval:this.autoplayInterval,overflowCellsLimit:this.overflowCellsLimit,visibleWidth:this.width,margin:this.margin,minSwipeDistance:this.minSwipeDistance,transitionDuration:this.transitionDuration,transitionTimingFunction:this.transitionTimingFunction,videoProperties:this.videoProperties})},t.prototype.detectDomChanges=function(){var t=this;new MutationObserver((function(e){t.onDomChanges()})).observe(this.elementRef.nativeElement,{attributes:!0,childList:!0,characterData:!0})},t.prototype.onDomChanges=function(){this.cellLength=this.getCellLength(),this.carousel.lineUpCells(),this.ref.detectChanges()},t.prototype.setDimensions=function(){this.hostStyleHeight=this.height+"px",this.hostStyleWidth=this.width+"px"},t.prototype.getFile=function(t){return this.carousel.getFile(t)},t.prototype.handleTransitionendCellContainer=function(t){this.carousel.handleSlideEnd()},t.prototype.toggleVideo=function(t){event.preventDefault(),this.videoProperties.noPlay||(t.paused?(t.play(),this.isVideoPlaying=!0):(t.pause(),this.isVideoPlaying=!1),this.ref.detectChanges())},t.prototype.getCurrentIndex=function(){return this.carousel.slideCounter},t.prototype.getCellWidth=function(){var t=this.elementRef.nativeElement.clientWidth;return this.cellsToShow?(t-(this.cellsToShow>1?this.margin:0)*(this.cellsToShow-1))/this.cellsToShow:"100%"===this._cellWidth?t:this._cellWidth},t.prototype.next=function(){this.carousel.next(this.cellsToScroll),this.carousel.stopAutoplay()},t.prototype.prev=function(){this.carousel.prev(this.cellsToScroll),this.carousel.stopAutoplay()},t.prototype.select=function(t){this.carousel.select(t)},t.prototype.isNextArrowDisabled=function(){return this.carousel.isNextArrowDisabled()},t.prototype.isPrevArrowDisabled=function(){return this.carousel.isPrevArrowDisabled()},t.prototype.getCellLength=function(){return this.images?this.images.length:this.cellsElement.children.length},t}();s.decorators=[{type:e.Component,args:[{selector:"carousel, [carousel]",exportAs:"carousel",template:'<div class="carousel-counter" *ngIf="isCounter">{{counter}}</div>\n\n<div class="carousel-container" [class.carousel-moving]="isMoving">\n\t<div class="carousel-cells" #cells (transitionend)="handleTransitionendCellContainer($event)">\n\t\t<ng-content></ng-content>\n\n\t\t<ng-template ngFor let-image [ngForOf]="images" let-i="index">\n\t\t\t<div class="carousel-cell" \n\t\t\t\t*ngIf="i < cellLimit" \n\t\t\t\t[style.width]="getCellWidth()+\'px\'"\n\t\t\t\t[style.border-radius]="borderRadius+\'px\'">\n\n\t\t\t\t\x3c!-- Image --\x3e\n\t\t\t\t<img \n\t\t\t\t\t*ngIf="getFile(i) && getFile(i)[\'image\']" \n\t\t\t\t\t[src]="getFile(i)[\'image\'][\'path\']"\n\t\t\t\t\t[style.object-fit]="objectFit"\n\t\t\t\t\tdraggable="false" />\n\n\t\t\t\t\x3c!-- Video --\x3e\n\t\t\t\t<ng-template [ngIf]="getFile(i) && getFile(i)[\'type\'] === \'video\'">\n\t\t\t\t\t<div class="carousel-play" (click)="toggleVideo(video)"></div>\n\n\t\t\t\t\t<video #video\n\t\t\t\t\t\t[loop]="videoProperties.loop"\n\t\t\t\t\t\t[muted]="videoProperties.muted"\n\t\t\t\t\t\t[controls]="isSafari"\n\t\t\t\t\t\t[style.object-fit]="objectFit"\n\t\t\t\t\t\t[style.border-radius]="borderRadius+\'px\'">\n\t\t\t\t\t\t\n\t\t\t\t\t\t<source [src]="getFile(i)[\'path\']" type="video/mp4">\n\t\t\t\t\t</video>\n\t\t\t\t</ng-template>\n\t\t\t</div>\n\t\t</ng-template>\n\t</div>\n\n\t<div class="carousel-dots" *ngIf="dots">\n\t\t<div class="carousel-dot" [class.carousel-dot-active]="i === activeDotIndex" *ngFor="let dot of dotsArr; index as i"></div>\n\t</div>\n</div>\n\n<div class="carousel-arrows" \n\t[class.carousel-arrows-outside]="arrowsOutside" \n\t[class.carousel-dark-arrows]="arrowsTheme === \'dark\'"\n\t*ngIf="arrows">\n\t\n\t<div class="carousel-arrow carousel-arrow-prev" [class.carousel-arrow-disabled]="isPrevArrowDisabled()" (click)="prev()"></div>\n\t<div class="carousel-arrow carousel-arrow-next" [class.carousel-arrow-disabled]="isNextArrowDisabled()" (click)="next()"></div>\n</div>',styles:[":host{-moz-user-select:none;-webkit-user-select:none;box-sizing:border-box;display:block;height:100%;left:0;position:relative;top:0;transform-origin:top left;user-select:none;width:100%;z-index:10000}:host .carousel-container{cursor:grab;height:100%;overflow:hidden;width:100%}:host .carousel-container.carousel-moving{cursor:grabbing}:host .carousel-counter{background-color:rgba(23,37,68,.3);border-radius:13px;color:#fff;font-size:11px;line-height:normal;padding:5px 7px;position:absolute;right:24px;text-align:right;top:8px;transition:opacity .2s;z-index:30}:host ::ng-deep .carousel-cells{display:block;height:100%;transition:transform .2s;width:100%}:host ::ng-deep .carousel-cells .carousel-cell.swiper-prev-image{transform:translate3d(-100%,0,0)}:host ::ng-deep .carousel-cells .carousel-cell.swiper-next-image{transform:translate3d(100%,0,0)}:host ::ng-deep .carousel-cells .carousel-cell{height:100%;overflow:hidden;position:absolute;width:100%}:host ::ng-deep .carousel-cells .carousel-cell img,:host ::ng-deep .carousel-cells .carousel-cell video{height:100%;object-fit:contain;position:relative;width:100%}:host ::ng-deep .carousel-cells .carousel-cell img.swiper-hide{display:none}:host ::ng-deep .carousel-cells .carousel-cell .carousel-play{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}:host .carousel-arrow{background-color:#fff;background-position:50%;background-repeat:no-repeat;background-size:31px;border-radius:100px;box-shadow:0 0 5px rgba(0,0,0,.15);cursor:pointer;height:40px;margin-top:-20px;position:absolute;top:50%;width:40px;z-index:10}:host .carousel-arrow-prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNMTUuNDEgMTYuNTlMMTAuODMgMTJsNC41OC00LjU5TDE0IDZsLTYgNiA2IDYgMS40MS0xLjQxeiIvPjxwYXRoIGQ9Ik0wIDBoMjR2MjRIMFYweiIgZmlsbD0ibm9uZSIvPjwvc3ZnPg==);left:10px}:host .carousel-arrow-next{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNOC41OSAxNi41OUwxMy4xNyAxMiA4LjU5IDcuNDEgMTAgNmw2IDYtNiA2LTEuNDEtMS40MXoiLz48cGF0aCBkPSJNMCAwaDI0djI0SDBWMHoiIGZpbGw9Im5vbmUiLz48L3N2Zz4=);right:10px}:host .carousel-arrows-outside .carousel-arrow-prev{left:-60px}:host .carousel-arrows-outside .carousel-arrow-next{right:-60px}:host .carousel-dark-arrows .carousel-arrow{filter:invert(1)}:host .carousel-arrow-disabled{cursor:default;opacity:.5}:host .carousel-dots{bottom:0;left:0;position:absolute;right:0;text-align:center;z-index:10}:host .carousel-dots .carousel-dot{border:2px solid #fff;border-radius:100px;display:inline-block;height:8px;margin:4px;width:8px}:host .carousel-dots .carousel-dot-active{background-color:#fff}"]}]}],s.ctorParameters=function(){return[{type:e.ElementRef},{type:e.ChangeDetectorRef}]},s.propDecorators={images:[{type:e.Input}],events:[{type:e.Output}],height:[{type:e.Input}],width:[{type:e.Input}],loop:[{type:e.Input}],autoplay:[{type:e.Input}],autoplayInterval:[{type:e.Input}],pauseOnHover:[{type:e.Input}],dots:[{type:e.Input}],borderRadius:[{type:e.Input}],margin:[{type:e.Input}],objectFit:[{type:e.Input}],minSwipeDistance:[{type:e.Input}],transitionDuration:[{type:e.Input}],transitionTimingFunction:[{type:e.Input}],videoProperties:[{type:e.Input}],counterSeparator:[{type:e.Input}],overflowCellsLimit:[{type:e.Input}],listeners:[{type:e.Input}],cellsToShow:[{type:e.Input}],cellsToScroll:[{type:e.Input}],cellWidth:[{type:e.Input,args:["cellWidth"]}],isCounter:[{type:e.Input,args:["counter"]}],arrows:[{type:e.Input}],arrowsOutside:[{type:e.Input}],arrowsTheme:[{type:e.Input}],hostClassCarousel:[{type:e.HostBinding,args:["class.carousel"]}],hostStyleHeight:[{type:e.HostBinding,args:["style.height"]}],hostStyleWidth:[{type:e.HostBinding,args:["style.width"]}],onWindowResize:[{type:e.HostListener,args:["window:resize",["$event"]]}],onMousemove:[{type:e.HostListener,args:["mousemove",["$event"]]}],onMouseleave:[{type:e.HostListener,args:["mouseleave",["$event"]]}]};var r=function(){};r.decorators=[{type:e.NgModule,args:[{declarations:[s],imports:[i.CommonModule],exports:[s],providers:[],bootstrap:[],entryComponents:[s]}]}],t.CarouselComponent=s,t.IvyCarouselModule=r,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("angular-responsive-carousel",["exports","@angular/core","@angular/common"],e):e((t=t||self)["angular-responsive-carousel"]={},t.ng.core,t.ng.common)}(this,(function(t,e,i){"use strict";var n=function(){function t(t){var e=this;this.eventType=void 0,this.handlers={},this.startX=0,this.startY=0,this.lastTap=0,this.doubleTapMinTimeout=300,this.tapMinTimeout=200,this.touchstartTime=0,this.i=0,this.isMousedown=!1,this._touchListeners={touchstart:"handleTouchstart",touchmove:"handleTouchmove",touchend:"handleTouchend"},this._mouseListeners={mousedown:"handleMousedown",mousemove:"handleMousemove",mouseup:"handleMouseup",wheel:"handleWheel"},this._otherListeners={resize:"handleResize"},this.handleTouchstart=function(t){e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getTouchstartPosition(t),e.runHandler("touchstart",t)},this.handleTouchmove=function(t){var i=t.touches;switch(e.detectPan(i)&&e.runHandler("pan",t),e.detectPinch(t)&&e.runHandler("pinch",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)},this.handleTouchend=function(t){var i=t.touches;e.detectDoubleTap()&&e.runHandler("double-tap",t),e.detectTap(),e.runHandler("touchend",t),e.eventType="touchend",i&&0===i.length&&(e.eventType=void 0,e.i=0)},this.handleMousedown=function(t){e.isMousedown=!0,e.elementPosition=e.getElementPosition(),e.touchstartTime=(new Date).getTime(),void 0===e.eventType&&e.getMousedownPosition(t),e.runHandler("mousedown",t)},this.handleMousemove=function(t){if(e.isMousedown){switch(e.runHandler("pan",t),e.detectLinearSwipe(t)){case"horizontal-swipe":t.swipeType="horizontal-swipe",e.runHandler("horizontal-swipe",t);break;case"vertical-swipe":t.swipeType="vertical-swipe",e.runHandler("vertical-swipe",t)}(e.detectLinearSwipe(t)||"horizontal-swipe"===e.eventType||"vertical-swipe"===e.eventType)&&e.handleLinearSwipe(t)}},this.handleMouseup=function(t){e.detectTap(),e.isMousedown=!1,e.runHandler("mouseup",t),e.eventType=void 0,e.i=0},this.handleWheel=function(t){e.runHandler("wheel",t)},this.handleResize=function(t){e.runHandler("resize",t)},this.properties=t,this.element=this.properties.element,this.elementPosition=this.getElementPosition(),this.toggleEventListeners("addEventListener")}return Object.defineProperty(t.prototype,"touchListeners",{get:function(){return this.properties.touchListeners?this.properties.touchListeners:this._touchListeners},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"mouseListeners",{get:function(){return this.properties.mouseListeners?this.properties.mouseListeners:this._mouseListeners},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"otherListeners",{get:function(){return this.properties.otherListeners?this.properties.otherListeners:this._otherListeners},enumerable:!1,configurable:!0}),t.prototype.destroy=function(){this.toggleEventListeners("removeEventListener")},t.prototype.toggleEventListeners=function(t){var e;for(var i in e="mouse and touch"===this.properties.listeners?Object.assign(this.touchListeners,this.mouseListeners):this.detectTouchScreen()?this.touchListeners:this.mouseListeners,this.properties.resize&&(e=Object.assign(e,this.otherListeners)),e){var n=e[i];"resize"===i?("addEventListener"===t&&window.addEventListener(i,this[n],!1),"removeEventListener"===t&&window.removeEventListener(i,this[n],!1)):"mouseup"===i||"mousemove"===i?("addEventListener"===t&&document.addEventListener(i,this[n],!1),"removeEventListener"===t&&document.removeEventListener(i,this[n],!1)):("addEventListener"===t&&this.element.addEventListener(i,this[n],!1),"removeEventListener"===t&&this.element.removeEventListener(i,this[n],!1))}},t.prototype.addEventListeners=function(t,e){window.addEventListener(t,this[e],!1)},t.prototype.removeEventListeners=function(t,e){window.removeEventListener(t,this[e],!1)},t.prototype.handleLinearSwipe=function(t){this.i++,this.i>3&&(this.eventType=this.getLinearSwipeType(t)),"horizontal-swipe"===this.eventType&&this.runHandler("horizontal-swipe",t),"vertical-swipe"===this.eventType&&this.runHandler("vertical-swipe",t)},t.prototype.runHandler=function(t,e){this.handlers[t]&&this.handlers[t](e)},t.prototype.detectPan=function(t){return 1===t.length&&!this.eventType||"pan"===this.eventType},t.prototype.detectDoubleTap=function(){var t=this;if(null==this.eventType){var e=(new Date).getTime(),i=e-this.lastTap;if(clearTimeout(this.doubleTapTimeout),i<this.doubleTapMinTimeout&&i>0)return!0;this.doubleTapTimeout=setTimeout((function(){clearTimeout(t.doubleTapTimeout)}),this.doubleTapMinTimeout),this.lastTap=e}},t.prototype.detectTap=function(){if(null==this.eventType){var t=(new Date).getTime()-this.touchstartTime;t>0&&(t<this.tapMinTimeout?this.runHandler("tap",event):this.runHandler("longtap",event))}},t.prototype.detectPinch=function(t){return 2===t.touches.length&&void 0===this.eventType||"pinch"===this.eventType},t.prototype.detectLinearSwipe=function(t){var e=t.touches;if(e){if(1===e.length&&!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)}else if(!this.eventType||"horizontal-swipe"===this.eventType||"vertical-swipe"===this.eventType)return this.getLinearSwipeType(t)},t.prototype.getLinearSwipeType=function(t){if("horizontal-swipe"!==this.eventType&&"vertical-swipe"!==this.eventType){var e=Math.abs(this.moveLeft(0,t)-this.startX);return 3*Math.abs(this.moveTop(0,t)-this.startY)>e?"vertical-swipe":"horizontal-swipe"}return this.eventType},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getTouchstartPosition=function(t){this.startX=t.touches[0].clientX-this.elementPosition.left,this.startY=t.touches[0].clientY-this.elementPosition.top},t.prototype.getMousedownPosition=function(t){this.startX=t.clientX-this.elementPosition.left,this.startY=t.clientY-this.elementPosition.top},t.prototype.moveLeft=function(t,e){var i=e.touches;return i?i[t].clientX-this.elementPosition.left:e.clientX-this.elementPosition.left},t.prototype.moveTop=function(t,e){var i=e.touches;return i?i[t].clientY-this.elementPosition.top:e.clientY-this.elementPosition.top},t.prototype.detectTouchScreen=function(){var t=" -webkit- -moz- -o- -ms- ".split(" ");return"ontouchstart"in window||function(t){return window.matchMedia(t).matches}(["(",t.join("touch-enabled),("),"heartz",")"].join(""))},t.prototype.on=function(t,e){t&&(this.handlers[t]=e)},t}(),o=function(){function t(t){var e=this;this.initialPositionX=0,this.newContainerPositionIndex=0,this.preliminarySlideCounter=0,this.slideCounter=0,this.previousSlideCounter=0,this.isContentImages=!0,this.isLazyLoad=!0,this.isContainerLocked=!0,this.alignCells="left",this.initialContainerPosition=0,this.handleTouchstart=function(t){e.isTouchstart=!0,e.startX=e.getStartX(t),e.containerInitialPositionX=e.getElementPosition().left-e.getCarouselElementPosition().left,e.isMoveInProgress=!0,e.stopTransformContainer()},this.handleHorizontalSwipe=function(t){var i=t.touches;e.moveX=i?i[0].clientX-e.getCarouselElementPosition().left:t.clientX-e.getCarouselElementPosition().left,e.distanceAbs=e.getDistanceAbs(),e.direction=e.getDirection(),e.moveContainer()},this.handleTouchend=function(t){e.isTouchstart?(e.isMoveInProgress=!1,e.detectSlide()?e.handleSlide():(e.newContainerPositionIndex=0,e.alignContainer()),e.startX=e.moveX=e.distanceAbs=void 0,e.isTouchstart=!1):e.isTouchstart=!1},this.element=t.element,this.properties=t,this.cells=this.element.children,this.visibleWidth=this.properties.visibleWidth||this.element.parentElement.clientWidth,this.setContainerWidth(),this.alignContainer(0)}return Object.defineProperty(t.prototype,"cellLength",{get:function(){return this.images?this.images.length:this.cells.length},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"totalContainerCellsCount",{get:function(){if(this.images){var t=this.visibleCellsCount+2*this.overflowCellsLimit;return t>this.images.length&&(t=this.images.length),t}return this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isFirstCell",{get:function(){return 0===this.slideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lastCellIndex",{get:function(){return this.images.length?this.images.length-1:this.cells.length-1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"overflowCellsLimit",{get:function(){return this.images&&this.isImagesLessCellLimit?Math.floor((this.images.length-this.visibleCellsCount)/2):this.properties.overflowCellsLimit},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isImagesLessCellLimit",{get:function(){return 2*this.properties.overflowCellsLimit+this.visibleCellsCount>this.images.length},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellLimit",{get:function(){return this.visibleCellsCount+2*this.overflowCellsLimit},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"images",{get:function(){return this.properties.images},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"margin",{get:function(){return this.properties.margin},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"minSwipeDistance",{get:function(){return this.properties.minSwipeDistance},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"transitionDuration",{get:function(){return this.properties.transitionDuration},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"transitionTimingFunction",{get:function(){return this.properties.transitionTimingFunction},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"fullCellWidth",{get:function(){return this.properties.cellWidth+this.margin},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"visibleCellsCount",{get:function(){return Math.ceil(this.visibleWidth/this.fullCellWidth)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lapCounter",{get:function(){return Math.floor(this.slideCounter/this.totalContainerCellsCount)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"visibleCellsOverflowContainer",{get:function(){return this.visibleCellsCount*this.fullCellWidth-this.margin>this.visibleWidth},enumerable:!1,configurable:!0}),t.prototype.stopTransformContainer=function(){this.transformPositionX(this.containerInitialPositionX,0),this.setSlideCounter(),this.isSlideInProgress=!1,this.newContainerPositionIndex=0,this.isSlideLengthLimited=void 0},t.prototype.getStartX=function(t){var e=t.touches;return e?e[0].clientX-this.getCarouselElementPosition().left:t.clientX-this.getCarouselElementPosition().left},t.prototype.moveContainer=function(){var t=this.getMovePositionX();this.transformPositionX(t,0)},t.prototype.getMovePositionX=function(){var t=this.getDistance();return this.containerInitialPositionX-t},t.prototype.alignContainer=function(t){void 0===t&&(t=this.transitionDuration);var e=this.getContainerPosition();this.transformPositionX(e,t),this.setInitialContainerPosition(e)},t.prototype.getContainerPosition=function(){var t=this.getContainerPositionCorrection();return this.isContainerPositionCorrection=0!=t,this.initialContainerPosition+this.newContainerPositionIndex*this.fullCellWidth+t},t.prototype.setInitialContainerPosition=function(t){var e=this.getContainerPositionCorrection();this.initialContainerPosition=t-e},t.prototype.getContainerPositionCorrection=function(){var t=0;return this.properties.loop?0:((this.cellLength-this.preliminarySlideCounter<this.visibleCellsCount||this.isSlideLengthLimited)&&(this.visibleWidth<this.totalContainerCellsCount*this.fullCellWidth&&(t=-(this.visibleCellsCount*this.fullCellWidth-this.visibleWidth-this.margin)),t>=-this.margin&&(t=0)),t)},t.prototype.quicklyPositionContainer=function(){var t=this.getContainerPositionCorrection(),e=this.getNewContainerPosition()+t;this.transformPositionX(e,0),this.setInitialContainerPosition(e)},t.prototype.getNewContainerPosition=function(){return this.slideCounter>this.overflowCellsLimit&&"left"===this.alignCells?(this.lineUpCells(),-this.overflowCellsLimit*this.fullCellWidth):this.slideCounter<=this.overflowCellsLimit?(this.previousSlideCounter>this.overflowCellsLimit&&this.lineUpCells(),-this.slideCounter*this.fullCellWidth):void 0},t.prototype.setContainerWidth=function(){var t=this.getContainerWidth();this.element.style.width=t+"px"},t.prototype.getContainerWidth=function(){var t=this.totalContainerCellsCount*this.fullCellWidth,e=this.cellLength*this.fullCellWidth;return e<t&&(t=e),t},t.prototype.getFile=function(t){var e=this.getFileIndex(t),i=this.images[e];return i&&!i.type&&(i.type="image"),{image:this.images[e],imageIndex:e}},t.prototype.getFileIndex=function(t){var e,i=this.getPositionIndex(t),n=(this.totalContainerCellsCount,this.slideCounter);if(!this.isContainerLocked)return n<=this.overflowCellsLimit?t:(e=i+(n-this.overflowCellsLimit),this.images&&this.properties.loop&&(e%=this.images.length),e);"left"===this.alignCells&&(e=n>this.overflowCellsLimit?i+(n-this.overflowCellsLimit):t);return!(e>this.lastCellIndex&&!this.properties.loop)&&e},t.prototype.transformPositionX=function(t,e){void 0===e&&(e=this.transitionDuration),this.element.style.transition="transform "+e+"ms "+this.transitionTimingFunction,this.element.style.transform="translateX("+t+"px)"},t.prototype.detectSlide=function(){return this.distanceAbs>=this.minSwipeDistance},t.prototype.next=function(t){void 0===t&&(t=1),this.newContainerPositionIndex=0,this.direction="left",this.handleSlide(t)},t.prototype.prev=function(t){void 0===t&&(t=1),this.newContainerPositionIndex=0,this.direction="right",this.handleSlide(t)},t.prototype.select=function(t){this.slideCounter=t,this.quicklyPositionContainer()},t.prototype.handleSlide=function(t){void 0===t&&(t=void 0),t&&this.isSlideInProgress||(this.slideLength=t||this.limitSlideLength(this.getSlideLength()),"left"===this.direction&&this.handleLeftSlide(),"right"===this.direction&&this.handleRightSlide(),this.alignContainer())},t.prototype.handleLeftSlide=function(){this.preliminarySlideCounter=this.slideCounter+this.slideLength,this.detectLastSlide(this.slideCounter+this.slideLength)?this.slideLength=0:(this.newContainerPositionIndex=this.newContainerPositionIndex-this.slideLength,this.isSlideInProgress=!0,this.isLazyLoad&&(this.isContainerLocked=this.preliminarySlideCounter>this.overflowCellsLimit,this.detectContainerUnlock()&&(this.isContainerLocked=!1)))},t.prototype.handleRightSlide=function(){this.slideCounter-this.slideLength<0&&(this.slideLength=this.slideCounter),this.preliminarySlideCounter=this.slideCounter-this.slideLength,this.isFirstCell?this.slideLength=0:(this.newContainerPositionIndex=this.newContainerPositionIndex+this.slideLength,this.isSlideInProgress=!0,this.isLazyLoad&&(this.preliminarySlideCounter>this.overflowCellsLimit?this.isContainerLocked=!0:this.isContainerLocked=!1,this.detectContainerUnlock()&&(this.isContainerLocked=!1)))},t.prototype.getSlideLength=function(){var t=this.getContainerPositionCorrection(),e=Math.floor((this.distanceAbs+t)/this.fullCellWidth);return this.distanceAbs%this.fullCellWidth>=this.minSwipeDistance&&e++,e},t.prototype.limitSlideLength=function(t){if(t>1)for(var e=0;e<t;e++){var i=this.slideCounter+(t-e);if(!this.detectLastSlide(i)){t-=e,this.isSlideLengthLimited=e>0;break}}return t},t.prototype.detectLastSlide=function(t){return!this.properties.loop&&this.cellLength-t<this.visibleCellsCount},t.prototype.isNextArrowDisabled=function(){return this.visibleCellsOverflowContainer?this.detectLastSlide(this.slideCounter+1)&&this.isContainerPositionCorrection:this.detectLastSlide(this.slideCounter+1)},t.prototype.isPrevArrowDisabled=function(){return 0===this.slideCounter},t.prototype.detectContainerUnlock=function(){return this.cellLength-this.preliminarySlideCounter<this.visibleCellsCount+this.overflowCellsLimit},t.prototype.handleSlideEnd=function(){this.isSlideInProgress&&(this.transformSlideEnd(),this.isSlideInProgress=!1,this.newContainerPositionIndex=0,this.isSlideLengthLimited=void 0)},t.prototype.transformSlideEnd=function(){this.isLazyLoad&&(this.setSlideCounter(),(this.images||!this.images&&this.properties.loop)&&this.quicklyPositionContainer()),this.previousSlideCounter=this.slideCounter},t.prototype.setSlideCounter=function(){"left"===this.direction&&(this.slideCounter=this.slideCounter+this.slideLength),"right"===this.direction&&(this.slideCounter=this.slideCounter-this.slideLength),this.direction=void 0,this.slideLength=0},t.prototype.resetTransition=function(){this.element.style.transition=""},t.prototype.getElementPosition=function(){return this.element.getBoundingClientRect()},t.prototype.getCarouselElementPosition=function(){return this.properties.container.getBoundingClientRect()},t.prototype.getDistance=function(){return this.startX-this.moveX},t.prototype.getDistanceAbs=function(){return Math.abs(this.startX-this.moveX)},t.prototype.getDirection=function(){var t=Math.sign(this.startX-this.moveX);return-1===t?"right":1===t?"left":void 0},t.prototype.lineUpCells=function(){for(var t=this.element.children,e=0;e<t.length;e++){var i=t[e],n=this.getCellPositionX(e);i.style.transform="translateX("+n+"px)",i.style.width=this.properties.cellWidth+"px"}},t.prototype.getCellPositionX=function(t){return this.getPositionIndex(t)*this.fullCellWidth},t.prototype.getPositionIndex=function(t){var e,i=this.slideCounter,n=this.totalContainerCellsCount,o=i-this.overflowCellsLimit;return o>n&&(o%=n),o<0?t:((e=t-o)<0&&(e=n+e),e)},t.prototype.getCenterPositionIndex=function(){return(this.totalContainerCellsCount-1)/2},t.prototype.autoplay=function(){var t=this;this.autoplayId=setInterval((function(){t.next()}),this.properties.autoplayInterval)},t.prototype.stopAutoplay=function(){this.autoplayId&&clearInterval(this.autoplayId)},t.prototype.destroy=function(){this.stopAutoplay()},t}(),s=function(){function t(t,i){var n=this;this.elementRef=t,this.ref=i,this.minTimeout=30,this._cellWidth=200,this.events=new e.EventEmitter,this.height=200,this.loop=!1,this.autoplay=!1,this.autoplayInterval=5e3,this.pauseOnHover=!0,this.dots=!1,this.margin=10,this.objectFit="cover",this.minSwipeDistance=10,this.transitionDuration=200,this.transitionTimingFunction="ease",this.counterSeparator=" / ",this.overflowCellsLimit=3,this.listeners="mouse and touch",this.cellsToScroll=1,this.arrows=!0,this.arrowsTheme="light",this.hostClassCarousel=!0,this.handleTouchstart=function(t){n.touches.addEventListeners("mousemove","handleMousemove"),n.carousel.handleTouchstart(t),n.isMoving=!0},this.handleHorizontalSwipe=function(t){t.preventDefault(),n.carousel.handleHorizontalSwipe(t)},this.handleTouchend=function(t){t.touches;n.carousel.handleTouchend(t),n.touches.removeEventListeners("mousemove","handleMousemove"),n.isMoving=!1}}return Object.defineProperty(t.prototype,"isContainerLocked",{get:function(){return this.carousel.isContainerLocked},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"slideCounter",{get:function(){return this.carousel.slideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"previousSlideCounter",{get:function(){return this.carousel.previousSlideCounter},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"lapCounter",{get:function(){return this.carousel.lapCounter},enumerable:!1,configurable:!0}),t.prototype.lineUpCells=function(){this.carousel.lineUpCells()},t.prototype.quicklyPositionContainer=function(){this.carousel.quicklyPositionContainer()},Object.defineProperty(t.prototype,"isLandscape",{get:function(){return window.innerWidth>window.innerHeight},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isSafari",{get:function(){var t=navigator.userAgent.toLowerCase();if(-1!==t.indexOf("safari"))return!(t.indexOf("chrome")>-1)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"counter",{get:function(){return(this.loop?this.slideCounter%this.cellLength:this.slideCounter)+1+this.counterSeparator+this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellsElement",{get:function(){return this.elementRef.nativeElement.querySelector(".carousel-cells")},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"images",{get:function(){return this._images},set:function(t){this._images=t},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellWidth",{set:function(t){t&&(this._cellWidth=t)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isCounter",{get:function(){return this._isCounter&&this.cellLength>1},set:function(t){t&&(this._isCounter=t)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"activeDotIndex",{get:function(){return this.slideCounter%this.cellLength},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cellLimit",{get:function(){if(this.carousel)return this.carousel.cellLimit},enumerable:!1,configurable:!0}),t.prototype.onWindowResize=function(t){this.landscapeMode=this.isLandscape,this.ref.detectChanges(),this.initCarousel(),this.carousel.lineUpCells()},t.prototype.onMousemove=function(t){this.autoplay&&this.pauseOnHover&&this.carousel.stopAutoplay()},t.prototype.onMouseleave=function(t){this.autoplay&&this.pauseOnHover&&this.carousel.autoplay()},t.prototype.ngOnInit=function(){this.isNgContent=this.cellsElement.children.length>0,this.touches=new n({element:this.cellsElement,listeners:this.listeners,mouseListeners:{mousedown:"handleMousedown",mouseup:"handleMouseup"}}),this.touches.on("touchstart",this.handleTouchstart),this.touches.on("horizontal-swipe",this.handleHorizontalSwipe),this.touches.on("touchend",this.handleTouchend),this.touches.on("mousedown",this.handleTouchstart),this.touches.on("mouseup",this.handleTouchend),this.initCarousel(),this.setDimensions(),this.autoplay&&this.carousel.autoplay()},t.prototype.ngAfterViewInit=function(){this.cellLength=this.getCellLength(),this.dotsArr=Array(this.cellLength).fill(1),this.ref.detectChanges(),this.carousel.lineUpCells(),this.detectDomChanges()},t.prototype.ngOnChanges=function(t){(t.width||t.height||t.images)&&(this.setDimensions(),this.initCarousel(),this.carousel.lineUpCells(),this.ref.detectChanges())},t.prototype.ngOnDestroy=function(){this.touches.destroy(),this.carousel.destroy()},t.prototype.initCarousel=function(){this.carousel=new o({element:this.elementRef.nativeElement.querySelector(".carousel-cells"),container:this.elementRef.nativeElement,images:this.images,cellWidth:this.getCellWidth(),loop:this.loop,autoplayInterval:this.autoplayInterval,overflowCellsLimit:this.overflowCellsLimit,visibleWidth:this.width,margin:this.margin,minSwipeDistance:this.minSwipeDistance,transitionDuration:this.transitionDuration,transitionTimingFunction:this.transitionTimingFunction,videoProperties:this.videoProperties})},t.prototype.detectDomChanges=function(){var t=this;new MutationObserver((function(e){t.onDomChanges()})).observe(this.elementRef.nativeElement,{attributes:!0,childList:!0,characterData:!0})},t.prototype.onDomChanges=function(){this.cellLength=this.getCellLength(),this.carousel.lineUpCells(),this.ref.detectChanges()},t.prototype.setDimensions=function(){this.hostStyleHeight=this.height+"px",this.hostStyleWidth=this.width+"px"},t.prototype.getFile=function(t){return this.carousel.getFile(t)},t.prototype.handleTransitionendCellContainer=function(t){this.carousel.handleSlideEnd()},t.prototype.toggleVideo=function(t){event.preventDefault(),this.videoProperties.noPlay||(t.paused?(t.play(),this.isVideoPlaying=!0):(t.pause(),this.isVideoPlaying=!1),this.ref.detectChanges())},t.prototype.getCurrentIndex=function(){return this.carousel.slideCounter},t.prototype.getCellWidth=function(){var t=this.elementRef.nativeElement.clientWidth;return this.cellsToShow?(t-(this.cellsToShow>1?this.margin:0)*(this.cellsToShow-1))/this.cellsToShow:"100%"===this._cellWidth?t:this._cellWidth},t.prototype.next=function(){this.carousel.next(this.cellsToScroll),this.carousel.stopAutoplay()},t.prototype.prev=function(){this.carousel.prev(this.cellsToScroll),this.carousel.stopAutoplay()},t.prototype.select=function(t){this.carousel.select(t)},t.prototype.isNextArrowDisabled=function(){return this.carousel.isNextArrowDisabled()},t.prototype.isPrevArrowDisabled=function(){return this.carousel.isPrevArrowDisabled()},t.prototype.getCellLength=function(){return this.images?this.images.length:this.cellsElement.children.length},t}();s.decorators=[{type:e.Component,args:[{selector:"carousel, [carousel]",exportAs:"carousel",template:'<div class="carousel-counter" *ngIf="isCounter">{{counter}}</div>\n\n<div class="carousel-container" [class.carousel-moving]="isMoving">\n\t<div class="carousel-cells" #cells (transitionend)="handleTransitionendCellContainer($event)">\n\t\t<ng-content></ng-content>\n\n\t\t<ng-template ngFor let-image [ngForOf]="images" let-i="index">\n\t\t\t<div class="carousel-cell" \n\t\t\t\t*ngIf="i < cellLimit" \n\t\t\t\t[style.width]="getCellWidth()+\'px\'"\n\t\t\t\t[style.border-radius]="borderRadius+\'px\'">\n\n\t\t\t\t\x3c!-- Image --\x3e\n\t\t\t\t<img \n\t\t\t\t\t*ngIf="getFile(i) && getFile(i)[\'image\']" \n\t\t\t\t\t[src]="getFile(i)[\'image\'][\'path\']"\n\t\t\t\t\t[style.object-fit]="objectFit"\n\t\t\t\t\tdraggable="false" />\n\n\t\t\t\t\x3c!-- Video --\x3e\n\t\t\t\t<ng-template [ngIf]="getFile(i) && getFile(i)[\'type\'] === \'video\'">\n\t\t\t\t\t<div class="carousel-play" (click)="toggleVideo(video)"></div>\n\n\t\t\t\t\t<video #video\n\t\t\t\t\t\t[loop]="videoProperties.loop"\n\t\t\t\t\t\t[muted]="videoProperties.muted"\n\t\t\t\t\t\t[controls]="isSafari"\n\t\t\t\t\t\t[style.object-fit]="objectFit"\n\t\t\t\t\t\t[style.border-radius]="borderRadius+\'px\'">\n\t\t\t\t\t\t\n\t\t\t\t\t\t<source [src]="getFile(i)[\'path\']" type="video/mp4">\n\t\t\t\t\t</video>\n\t\t\t\t</ng-template>\n\t\t\t</div>\n\t\t</ng-template>\n\t</div>\n\n\t<div class="carousel-dots" *ngIf="dots">\n\t\t<div class="carousel-dot" [class.carousel-dot-active]="i === activeDotIndex" *ngFor="let dot of dotsArr; index as i"></div>\n\t</div>\n</div>\n\n<div class="carousel-arrows" \n\t[class.carousel-arrows-outside]="arrowsOutside" \n\t[class.carousel-dark-arrows]="arrowsTheme === \'dark\'"\n\t*ngIf="arrows">\n\t\n\t<div class="carousel-arrow carousel-arrow-prev" [class.carousel-arrow-disabled]="isPrevArrowDisabled()" (click)="prev()"></div>\n\t<div class="carousel-arrow carousel-arrow-next" [class.carousel-arrow-disabled]="isNextArrowDisabled()" (click)="next()"></div>\n</div>',styles:[":host{-moz-user-select:none;-webkit-user-select:none;box-sizing:border-box;display:block;height:100%;left:0;position:relative;top:0;transform-origin:top left;user-select:none;width:100%;z-index:10000}:host .carousel-container{cursor:grab;height:100%;overflow:hidden;width:100%}:host .carousel-container.carousel-moving{cursor:grabbing}:host .carousel-counter{background-color:rgba(23,37,68,.3);border-radius:13px;color:#fff;font-size:11px;line-height:normal;padding:5px 7px;position:absolute;right:24px;text-align:right;top:8px;transition:opacity .2s;z-index:30}:host ::ng-deep .carousel-cells{display:block;height:100%;transition:transform .2s;width:100%}:host ::ng-deep .carousel-cells .carousel-cell.swiper-prev-image{transform:translate3d(-100%,0,0)}:host ::ng-deep .carousel-cells .carousel-cell.swiper-next-image{transform:translate3d(100%,0,0)}:host ::ng-deep .carousel-cells .carousel-cell{height:100%;overflow:hidden;position:absolute;width:100%}:host ::ng-deep .carousel-cells .carousel-cell img,:host ::ng-deep .carousel-cells .carousel-cell video{height:100%;object-fit:contain;position:relative;width:100%}:host ::ng-deep .carousel-cells .carousel-cell img.swiper-hide{display:none}:host ::ng-deep .carousel-cells .carousel-cell .carousel-play{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}:host .carousel-arrow{background-color:#fff;background-position:50%;background-repeat:no-repeat;background-size:31px;border-radius:100px;box-shadow:0 0 5px rgba(0,0,0,.15);cursor:pointer;height:40px;margin-top:-20px;position:absolute;top:50%;width:40px;z-index:10}:host .carousel-arrow-prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNMTUuNDEgMTYuNTlMMTAuODMgMTJsNC41OC00LjU5TDE0IDZsLTYgNiA2IDYgMS40MS0xLjQxeiIvPjxwYXRoIGQ9Ik0wIDBoMjR2MjRIMFYweiIgZmlsbD0ibm9uZSIvPjwvc3ZnPg==);left:10px}:host .carousel-arrow-next{background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNOC41OSAxNi41OUwxMy4xNyAxMiA4LjU5IDcuNDEgMTAgNmw2IDYtNiA2LTEuNDEtMS40MXoiLz48cGF0aCBkPSJNMCAwaDI0djI0SDBWMHoiIGZpbGw9Im5vbmUiLz48L3N2Zz4=);right:10px}:host .carousel-arrows-outside .carousel-arrow-prev{left:-60px}:host .carousel-arrows-outside .carousel-arrow-next{right:-60px}:host .carousel-dark-arrows .carousel-arrow{filter:invert(1)}:host .carousel-arrow-disabled{cursor:default;opacity:.5}:host .carousel-dots{bottom:0;left:0;position:absolute;right:0;text-align:center;z-index:10}:host .carousel-dots .carousel-dot{border:2px solid #fff;border-radius:100px;display:inline-block;height:8px;margin:4px;width:8px}:host .carousel-dots .carousel-dot-active{background-color:#fff}"]}]}],s.ctorParameters=function(){return[{type:e.ElementRef},{type:e.ChangeDetectorRef}]},s.propDecorators={images:[{type:e.Input}],events:[{type:e.Output}],height:[{type:e.Input}],width:[{type:e.Input}],loop:[{type:e.Input}],autoplay:[{type:e.Input}],autoplayInterval:[{type:e.Input}],pauseOnHover:[{type:e.Input}],dots:[{type:e.Input}],borderRadius:[{type:e.Input}],margin:[{type:e.Input}],objectFit:[{type:e.Input}],minSwipeDistance:[{type:e.Input}],transitionDuration:[{type:e.Input}],transitionTimingFunction:[{type:e.Input}],videoProperties:[{type:e.Input}],counterSeparator:[{type:e.Input}],overflowCellsLimit:[{type:e.Input}],listeners:[{type:e.Input}],cellsToShow:[{type:e.Input}],cellsToScroll:[{type:e.Input}],cellWidth:[{type:e.Input,args:["cellWidth"]}],isCounter:[{type:e.Input,args:["counter"]}],arrows:[{type:e.Input}],arrowsOutside:[{type:e.Input}],arrowsTheme:[{type:e.Input}],hostClassCarousel:[{type:e.HostBinding,args:["class.carousel"]}],hostStyleHeight:[{type:e.HostBinding,args:["style.height"]}],hostStyleWidth:[{type:e.HostBinding,args:["style.width"]}],onWindowResize:[{type:e.HostListener,args:["window:resize",["$event"]]}],onMousemove:[{type:e.HostListener,args:["mousemove",["$event"]]}],onMouseleave:[{type:e.HostListener,args:["mouseleave",["$event"]]}]};var r=function(){};r.decorators=[{type:e.NgModule,args:[{declarations:[s],imports:[i.CommonModule],exports:[s],providers:[],bootstrap:[],entryComponents:[s]}]}],t.CarouselComponent=s,t.IvyCarouselModule=r,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=angular-responsive-carousel.umd.min.js.map |
@@ -19,3 +19,3 @@ import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output } from '@angular/core'; | ||
this.objectFit = 'cover'; | ||
this.minSwipeDistance = 50; | ||
this.minSwipeDistance = 10; | ||
this.transitionDuration = 200; | ||
@@ -321,2 +321,2 @@ this.transitionTimingFunction = 'ease'; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../projects/angular-responsive-carousel/src/lib/carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, ElementRef, ViewChild, EventEmitter, HostBinding, HostListener, Input, Output, OnDestroy, SimpleChanges} from '@angular/core';\n\nimport {Images} from './interfaces';\nimport {Touches} from './touches';\nimport {Carousel} from './carousel';\n\n\n@Component({\n\tselector: 'carousel, [carousel]',\n    exportAs: 'carousel',\n\ttemplateUrl: './carousel.component.html',\n    styleUrls: ['./carousel.component.sass']\n})\n\nexport class CarouselComponent implements OnDestroy {\n\n    get isContainerLocked() {\n        return this.carousel.isContainerLocked;\n    }\n    get slideCounter() {\n        return this.carousel.slideCounter;\n    }\n    get previousSlideCounter() {\n        return this.carousel.previousSlideCounter;\n    }\n    get lapCounter() {\n        return this.carousel.lapCounter;\n    }\n\n    lineUpCells() {\n        this.carousel.lineUpCells();\n    }\n\n    quicklyPositionContainer() {\n        this.carousel.quicklyPositionContainer();\n    }\n    \n    _id: string;\n    _images: Images;\n    touches: any;\n    carousel: any;\n    landscapeMode: any;\n    minTimeout = 30;\n    isVideoPlaying: boolean;\n    _isCounter: boolean;\n    _width: number;\n    _cellWidth: number | '100%' = 200;\n    isMoving: boolean;\n    isNgContent: boolean;\n    cellLength: number;\n    dotsArr:any;\n\n    get isLandscape(){\n        return window.innerWidth > window.innerHeight;\n    }\n\n    get isSafari(): any {\n        const ua = navigator.userAgent.toLowerCase();\n        if (ua.indexOf('safari') !== -1) {\n            return !(ua.indexOf('chrome') > -1);\n        }\n    }\n\n    get counter() {\n        let counter;\n\n        if (this.loop) {\n            counter = this.slideCounter % this.cellLength;\n        } else {\n            counter = this.slideCounter;\n        }\n\n        return counter + 1 + this.counterSeparator + this.cellLength;\n    }\n\n    get cellsElement() {\n        return this.elementRef.nativeElement.querySelector('.carousel-cells');\n    }\n\n    @Input()\n    set images(images: Images & any) {\n        this._images = images;\n    }\n    get images(){\n        return this._images;\n    }\n\n    @Output() events: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() height: number = 200;\n    @Input() width: number;\n    @Input() loop: boolean = false;\n    @Input() autoplay: boolean = false;\n    @Input() autoplayInterval: number = 5000;\n    @Input() pauseOnHover: boolean = true;\n    @Input() dots: boolean = false;\n    @Input() borderRadius: number;\n    @Input() margin: number = 10;\n    @Input() objectFit: 'contain' | 'cover' | 'none' = 'cover';\n    @Input() minSwipeDistance: number = 50;\n    @Input() transitionDuration: number = 200;\n    @Input() transitionTimingFunction: 'ease' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'linear' = 'ease';\n    @Input() videoProperties: any;\n    @Input() counterSeparator: string = \" / \";\n    @Input() overflowCellsLimit: number = 3;\n    @Input() listeners: 'auto' | 'mouse and touch' = 'mouse and touch';\n    @Input() cellsToShow: number;\n    @Input() cellsToScroll: number = 1;\n\n    @Input('cellWidth') set cellWidth(value: number | '100%') {\n        if (value){\n            this._cellWidth = value;\n        }\n    }\n\n    @Input('counter') set isCounter(value: boolean) {\n        if (value){\n            this._isCounter = value;\n        }\n    }\n    get isCounter() {\n        return this._isCounter && this.cellLength > 1;\n    }\n\n    get activeDotIndex() {\n        return this.slideCounter % this.cellLength;\n    }\n\n    @Input() arrows: boolean = true;\n    @Input() arrowsOutside: boolean;\n    @Input() arrowsTheme: 'light' | 'dark' = 'light';\n\n    get cellLimit() {\n        if (this.carousel) {\n            return this.carousel.cellLimit;\n        }\n    }\n\n    @HostBinding('class.carousel') hostClassCarousel: boolean = true;\n    @HostBinding('style.height') hostStyleHeight: string;\n    @HostBinding('style.width') hostStyleWidth: string;\n\n    @HostListener('window:resize', ['$event'])\n    onWindowResize(event: any) {\n        this.landscapeMode = this.isLandscape;\n        this.ref.detectChanges();\n\n        this.initCarousel();\n        this.carousel.lineUpCells();\n    }\n\n    @HostListener('mousemove', ['$event'])\n    onMousemove(event: MouseEvent) {\n        if (this.autoplay && this.pauseOnHover) {\n            this.carousel.stopAutoplay();\n        }\n    }\n\n    @HostListener('mouseleave', ['$event'])\n    onMouseleave(event: MouseEvent) {\n        if (this.autoplay && this.pauseOnHover) {\n            this.carousel.autoplay();\n        }\n    }\n\n    constructor(\n        private elementRef: ElementRef, \n        private ref: ChangeDetectorRef){\n    }\n\n    ngOnInit(){\n        this.isNgContent = this.cellsElement.children.length > 0;\n\n        this.touches = new Touches({\n            element: this.cellsElement,\n            listeners: this.listeners,\n            mouseListeners: {\n                \"mousedown\": \"handleMousedown\",\n                \"mouseup\": \"handleMouseup\"\n            }\n        });\n\n        this.touches.on('touchstart', this.handleTouchstart);\n        this.touches.on('horizontal-swipe', this.handleHorizontalSwipe);\n        this.touches.on('touchend', this.handleTouchend);\n        this.touches.on('mousedown', this.handleTouchstart);\n        this.touches.on('mouseup', this.handleTouchend);\n\n        this.initCarousel();\n        this.setDimensions();\n\n        if (this.autoplay) {\n            this.carousel.autoplay();\n        }\n    }\n\n    ngAfterViewInit() {\n        this.cellLength = this.getCellLength();\n        this.dotsArr = Array(this.cellLength).fill(1);\n        this.ref.detectChanges();\n        this.carousel.lineUpCells();\n\n        /* Start detecting changes in the DOM tree */\n        this.detectDomChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.width || changes.height || changes.images) {\n            this.setDimensions();\n            this.initCarousel();\n            this.carousel.lineUpCells();\n            this.ref.detectChanges();\n        }\n    }\n\n    ngOnDestroy() {\n        this.touches.destroy();\n        this.carousel.destroy();\n    }\n\n    initCarousel() {\n        this.carousel = new Carousel({\n            element: this.elementRef.nativeElement.querySelector('.carousel-cells'),\n            container: this.elementRef.nativeElement,\n            images: this.images,\n            cellWidth: this.getCellWidth(),\n            loop: this.loop,\n            autoplayInterval: this.autoplayInterval,\n            overflowCellsLimit: this.overflowCellsLimit,\n            visibleWidth: this.width,\n            margin: this.margin,\n            minSwipeDistance: this.minSwipeDistance,\n            transitionDuration: this.transitionDuration,\n            transitionTimingFunction: this.transitionTimingFunction,\n            videoProperties: this.videoProperties\n        });\n    }\n\n    detectDomChanges() {\n        const observer = new MutationObserver((mutations) => {\n            this.onDomChanges();\n        });\n\n        var config = { \n            attributes: true, \n            childList: true, \n            characterData: true \n        };\n        observer.observe(this.elementRef.nativeElement, config);\n    }\n\n    onDomChanges() {\n        this.cellLength = this.getCellLength();\n        this.carousel.lineUpCells();\n        this.ref.detectChanges();\n    }\n\n    setDimensions() {\n        this.hostStyleHeight = this.height + 'px';\n        this.hostStyleWidth = this.width + 'px';\n    }\n\n    getFile(index) {\n        return this.carousel.getFile(index);\n    }\n\n    /* Touchstart */\n    handleTouchstart = (event: any) => {\n        //event.preventDefault();\n        this.touches.addEventListeners(\"mousemove\", \"handleMousemove\");\n        this.carousel.handleTouchstart(event);\n        this.isMoving = true;\n    }\n\n    /* Touchmove */\n    handleHorizontalSwipe = (event: any) => {\n        event.preventDefault();\n        this.carousel.handleHorizontalSwipe(event);\n    }\n\n    /* Touchend */\n    handleTouchend = (event: any) => {\n        const touches = event.touches;\n        this.carousel.handleTouchend(event);\n        this.touches.removeEventListeners(\"mousemove\", \"handleMousemove\");\n        this.isMoving = false;\n    }\n\n    handleTransitionendCellContainer(event) {\n        this.carousel.handleSlideEnd();\n    }\n\n    toggleVideo(video) {\n        event.preventDefault();\n        if (this.videoProperties.noPlay) {\n            return;\n        }\n\n        if (video.paused) {\n            video.play();\n            this.isVideoPlaying = true;\n        } else {\n            video.pause();\n            this.isVideoPlaying = false;\n        }\n\n        this.ref.detectChanges();\n    }\n\n    getCurrentIndex() {\n        return this.carousel.slideCounter;\n    }\n\n    getCellWidth() {\n        let elementWidth = this.elementRef.nativeElement.clientWidth;\n\n        if (this.cellsToShow) {\n            let margin = this.cellsToShow > 1 ? this.margin : 0;\n            let totalMargin = margin * (this.cellsToShow - 1);\n            return (elementWidth - totalMargin) / this.cellsToShow;\n        }\n\n        if (this._cellWidth === '100%') {\n\n            return elementWidth;\n        } else {\n            return this._cellWidth;\n        }\n    }\n\n    next() {\n        this.carousel.next(this.cellsToScroll);\n        this.carousel.stopAutoplay();\n    }\n\n    prev() {\n        this.carousel.prev(this.cellsToScroll);\n        this.carousel.stopAutoplay();\n    }\n\n    select(index: number) {\n        this.carousel.select(index);\n    }\n\n    isNextArrowDisabled() {\n        return this.carousel.isNextArrowDisabled();\n    }\n\n    isPrevArrowDisabled() {\n        return this.carousel.isPrevArrowDisabled();\n    }\n\n    getCellLength() {\n        if (this.images) {\n            return this.images.length;\n        } else {\n            return this.cellsElement.children.length;\n        }\n    }\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../projects/angular-responsive-carousel/src/lib/carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, ElementRef, ViewChild, EventEmitter, HostBinding, HostListener, Input, Output, OnDestroy, SimpleChanges} from '@angular/core';\n\nimport {Images} from './interfaces';\nimport {Touches} from './touches';\nimport {Carousel} from './carousel';\n\n\n@Component({\n\tselector: 'carousel, [carousel]',\n    exportAs: 'carousel',\n\ttemplateUrl: './carousel.component.html',\n    styleUrls: ['./carousel.component.sass']\n})\n\nexport class CarouselComponent implements OnDestroy {\n\n    get isContainerLocked() {\n        return this.carousel.isContainerLocked;\n    }\n    get slideCounter() {\n        return this.carousel.slideCounter;\n    }\n    get previousSlideCounter() {\n        return this.carousel.previousSlideCounter;\n    }\n    get lapCounter() {\n        return this.carousel.lapCounter;\n    }\n\n    lineUpCells() {\n        this.carousel.lineUpCells();\n    }\n\n    quicklyPositionContainer() {\n        this.carousel.quicklyPositionContainer();\n    }\n    \n    _id: string;\n    _images: Images;\n    touches: any;\n    carousel: any;\n    landscapeMode: any;\n    minTimeout = 30;\n    isVideoPlaying: boolean;\n    _isCounter: boolean;\n    _width: number;\n    _cellWidth: number | '100%' = 200;\n    isMoving: boolean;\n    isNgContent: boolean;\n    cellLength: number;\n    dotsArr:any;\n\n    get isLandscape(){\n        return window.innerWidth > window.innerHeight;\n    }\n\n    get isSafari(): any {\n        const ua = navigator.userAgent.toLowerCase();\n        if (ua.indexOf('safari') !== -1) {\n            return !(ua.indexOf('chrome') > -1);\n        }\n    }\n\n    get counter() {\n        let counter;\n\n        if (this.loop) {\n            counter = this.slideCounter % this.cellLength;\n        } else {\n            counter = this.slideCounter;\n        }\n\n        return counter + 1 + this.counterSeparator + this.cellLength;\n    }\n\n    get cellsElement() {\n        return this.elementRef.nativeElement.querySelector('.carousel-cells');\n    }\n\n    @Input()\n    set images(images: Images & any) {\n        this._images = images;\n    }\n    get images(){\n        return this._images;\n    }\n\n    @Output() events: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() height: number = 200;\n    @Input() width: number;\n    @Input() loop: boolean = false;\n    @Input() autoplay: boolean = false;\n    @Input() autoplayInterval: number = 5000;\n    @Input() pauseOnHover: boolean = true;\n    @Input() dots: boolean = false;\n    @Input() borderRadius: number;\n    @Input() margin: number = 10;\n    @Input() objectFit: 'contain' | 'cover' | 'none' = 'cover';\n    @Input() minSwipeDistance: number = 10;\n    @Input() transitionDuration: number = 200;\n    @Input() transitionTimingFunction: 'ease' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'linear' = 'ease';\n    @Input() videoProperties: any;\n    @Input() counterSeparator: string = \" / \";\n    @Input() overflowCellsLimit: number = 3;\n    @Input() listeners: 'auto' | 'mouse and touch' = 'mouse and touch';\n    @Input() cellsToShow: number;\n    @Input() cellsToScroll: number = 1;\n\n    @Input('cellWidth') set cellWidth(value: number | '100%') {\n        if (value){\n            this._cellWidth = value;\n        }\n    }\n\n    @Input('counter') set isCounter(value: boolean) {\n        if (value){\n            this._isCounter = value;\n        }\n    }\n    get isCounter() {\n        return this._isCounter && this.cellLength > 1;\n    }\n\n    get activeDotIndex() {\n        return this.slideCounter % this.cellLength;\n    }\n\n    @Input() arrows: boolean = true;\n    @Input() arrowsOutside: boolean;\n    @Input() arrowsTheme: 'light' | 'dark' = 'light';\n\n    get cellLimit() {\n        if (this.carousel) {\n            return this.carousel.cellLimit;\n        }\n    }\n\n    @HostBinding('class.carousel') hostClassCarousel: boolean = true;\n    @HostBinding('style.height') hostStyleHeight: string;\n    @HostBinding('style.width') hostStyleWidth: string;\n\n    @HostListener('window:resize', ['$event'])\n    onWindowResize(event: any) {\n        this.landscapeMode = this.isLandscape;\n        this.ref.detectChanges();\n\n        this.initCarousel();\n        this.carousel.lineUpCells();\n    }\n\n    @HostListener('mousemove', ['$event'])\n    onMousemove(event: MouseEvent) {\n        if (this.autoplay && this.pauseOnHover) {\n            this.carousel.stopAutoplay();\n        }\n    }\n\n    @HostListener('mouseleave', ['$event'])\n    onMouseleave(event: MouseEvent) {\n        if (this.autoplay && this.pauseOnHover) {\n            this.carousel.autoplay();\n        }\n    }\n\n    constructor(\n        private elementRef: ElementRef, \n        private ref: ChangeDetectorRef){\n    }\n\n    ngOnInit(){\n        this.isNgContent = this.cellsElement.children.length > 0;\n\n        this.touches = new Touches({\n            element: this.cellsElement,\n            listeners: this.listeners,\n            mouseListeners: {\n                \"mousedown\": \"handleMousedown\",\n                \"mouseup\": \"handleMouseup\"\n            }\n        });\n\n        this.touches.on('touchstart', this.handleTouchstart);\n        this.touches.on('horizontal-swipe', this.handleHorizontalSwipe);\n        this.touches.on('touchend', this.handleTouchend);\n        this.touches.on('mousedown', this.handleTouchstart);\n        this.touches.on('mouseup', this.handleTouchend);\n\n        this.initCarousel();\n        this.setDimensions();\n\n        if (this.autoplay) {\n            this.carousel.autoplay();\n        }\n    }\n\n    ngAfterViewInit() {\n        this.cellLength = this.getCellLength();\n        this.dotsArr = Array(this.cellLength).fill(1);\n        this.ref.detectChanges();\n        this.carousel.lineUpCells();\n\n        /* Start detecting changes in the DOM tree */\n        this.detectDomChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.width || changes.height || changes.images) {\n            this.setDimensions();\n            this.initCarousel();\n            this.carousel.lineUpCells();\n            this.ref.detectChanges();\n        }\n    }\n\n    ngOnDestroy() {\n        this.touches.destroy();\n        this.carousel.destroy();\n    }\n\n    initCarousel() {\n        this.carousel = new Carousel({\n            element: this.elementRef.nativeElement.querySelector('.carousel-cells'),\n            container: this.elementRef.nativeElement,\n            images: this.images,\n            cellWidth: this.getCellWidth(),\n            loop: this.loop,\n            autoplayInterval: this.autoplayInterval,\n            overflowCellsLimit: this.overflowCellsLimit,\n            visibleWidth: this.width,\n            margin: this.margin,\n            minSwipeDistance: this.minSwipeDistance,\n            transitionDuration: this.transitionDuration,\n            transitionTimingFunction: this.transitionTimingFunction,\n            videoProperties: this.videoProperties\n        });\n    }\n\n    detectDomChanges() {\n        const observer = new MutationObserver((mutations) => {\n            this.onDomChanges();\n        });\n\n        var config = { \n            attributes: true, \n            childList: true, \n            characterData: true \n        };\n        observer.observe(this.elementRef.nativeElement, config);\n    }\n\n    onDomChanges() {\n        this.cellLength = this.getCellLength();\n        this.carousel.lineUpCells();\n        this.ref.detectChanges();\n    }\n\n    setDimensions() {\n        this.hostStyleHeight = this.height + 'px';\n        this.hostStyleWidth = this.width + 'px';\n    }\n\n    getFile(index) {\n        return this.carousel.getFile(index);\n    }\n\n    /* Touchstart */\n    handleTouchstart = (event: any) => {\n        //event.preventDefault();\n        this.touches.addEventListeners(\"mousemove\", \"handleMousemove\");\n        this.carousel.handleTouchstart(event);\n        this.isMoving = true;\n    }\n\n    /* Touchmove */\n    handleHorizontalSwipe = (event: any) => {\n        event.preventDefault();\n        this.carousel.handleHorizontalSwipe(event);\n    }\n\n    /* Touchend */\n    handleTouchend = (event: any) => {\n        const touches = event.touches;\n        this.carousel.handleTouchend(event);\n        this.touches.removeEventListeners(\"mousemove\", \"handleMousemove\");\n        this.isMoving = false;\n    }\n\n    handleTransitionendCellContainer(event) {\n        this.carousel.handleSlideEnd();\n    }\n\n    toggleVideo(video) {\n        event.preventDefault();\n        if (this.videoProperties.noPlay) {\n            return;\n        }\n\n        if (video.paused) {\n            video.play();\n            this.isVideoPlaying = true;\n        } else {\n            video.pause();\n            this.isVideoPlaying = false;\n        }\n\n        this.ref.detectChanges();\n    }\n\n    getCurrentIndex() {\n        return this.carousel.slideCounter;\n    }\n\n    getCellWidth() {\n        let elementWidth = this.elementRef.nativeElement.clientWidth;\n\n        if (this.cellsToShow) {\n            let margin = this.cellsToShow > 1 ? this.margin : 0;\n            let totalMargin = margin * (this.cellsToShow - 1);\n            return (elementWidth - totalMargin) / this.cellsToShow;\n        }\n\n        if (this._cellWidth === '100%') {\n\n            return elementWidth;\n        } else {\n            return this._cellWidth;\n        }\n    }\n\n    next() {\n        this.carousel.next(this.cellsToScroll);\n        this.carousel.stopAutoplay();\n    }\n\n    prev() {\n        this.carousel.prev(this.cellsToScroll);\n        this.carousel.stopAutoplay();\n    }\n\n    select(index: number) {\n        this.carousel.select(index);\n    }\n\n    isNextArrowDisabled() {\n        return this.carousel.isNextArrowDisabled();\n    }\n\n    isPrevArrowDisabled() {\n        return this.carousel.isPrevArrowDisabled();\n    }\n\n    getCellLength() {\n        if (this.images) {\n            return this.images.length;\n        } else {\n            return this.cellsElement.children.length;\n        }\n    }\n}"]} |
export class Carousel { | ||
constructor(properties) { | ||
this.initialPositionX = 0; | ||
this.newContainerPositionIndex = 0; // The index of the new position relative to the active index, for example -1 or +1 | ||
/* The index of the new position relative to the active index, for example -1 or +1 */ | ||
this.newContainerPositionIndex = 0; | ||
this.preliminarySlideCounter = 0; | ||
this.slideCounter = 0; // Scrolling Index (counter) | ||
/* Scrolling Index (counter) */ | ||
this.slideCounter = 0; | ||
this.previousSlideCounter = 0; | ||
@@ -15,19 +17,8 @@ this.isContentImages = true; | ||
this.isTouchstart = true; | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
const touches = event.touches; | ||
if (touches) { | ||
this.startX = touches[0].clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
this.startX = event.clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
this.startX = this.getStartX(event); | ||
this.containerInitialPositionX = this.getElementPosition()['left'] - this.getCarouselElementPosition()['left']; | ||
this.isMoveInProgress = true; | ||
this.stopTransformContainer(); | ||
}; | ||
this.handleHorizontalSwipe = (event) => { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
const touches = event.touches; | ||
@@ -45,3 +36,3 @@ if (touches) { | ||
this.handleTouchend = (event) => { | ||
if (this.isSlideInProgress || !this.isTouchstart) { | ||
if (!this.isTouchstart) { | ||
this.isTouchstart = false; | ||
@@ -135,2 +126,20 @@ return; | ||
} | ||
stopTransformContainer() { | ||
this.transformPositionX(this.containerInitialPositionX, 0); | ||
this.setSlideCounter(); | ||
this.isSlideInProgress = false; | ||
this.newContainerPositionIndex = 0; | ||
this.isSlideLengthLimited = undefined; | ||
} | ||
getStartX(event) { | ||
const touches = event.touches; | ||
let startX; | ||
if (touches) { | ||
startX = touches[0].clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
startX = event.clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
return startX; | ||
} | ||
/* Move */ | ||
@@ -160,2 +169,3 @@ moveContainer() { | ||
} | ||
/* Offset the container to show the last cell completely */ | ||
getContainerPositionCorrection() { | ||
@@ -260,5 +270,3 @@ let correction = 0; | ||
next(length = 1) { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'left'; | ||
@@ -268,5 +276,3 @@ this.handleSlide(length); | ||
prev(length = 1) { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'right'; | ||
@@ -279,40 +285,56 @@ this.handleSlide(length); | ||
} | ||
handleSlide(slideLength = undefined) { | ||
this.slideLength = this.getSlideLength(); | ||
this.slideLength = slideLength ? slideLength : this.limitSlideLength(this.slideLength); | ||
if (this.direction === 'left' && !this.isSlideInProgress) { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
if (!this.detectLastSlide(this.slideCounter + this.slideLength)) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
handleSlide(customSlideLength = undefined) { | ||
let isUsingButton = customSlideLength; | ||
if (isUsingButton && this.isSlideInProgress) { | ||
return; | ||
} | ||
this.slideLength = customSlideLength ? customSlideLength : this.limitSlideLength(this.getSlideLength()); | ||
if (this.direction === 'left') { | ||
this.handleLeftSlide(); | ||
} | ||
if (this.direction === 'right') { | ||
this.handleRightSlide(); | ||
} | ||
this.alignContainer(); | ||
} | ||
handleLeftSlide() { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
let isLastSlide = this.detectLastSlide(this.slideCounter + this.slideLength); | ||
if (!isLastSlide) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
if (this.direction === 'right' && !this.isSlideInProgress) { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
else { | ||
this.slideLength = 0; | ||
} | ||
} | ||
handleRightSlide() { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
this.alignContainer(); | ||
else { | ||
this.slideLength = 0; | ||
} | ||
} | ||
@@ -327,2 +349,6 @@ getSlideLength() { | ||
} | ||
/* | ||
* Limits the length of the slide during calls to the next() and prev() | ||
* methods if the specified position is outside the cell length | ||
*/ | ||
limitSlideLength(slideLength) { | ||
@@ -465,2 +491,2 @@ if (slideLength > 1) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.js","sourceRoot":"","sources":["../../../../projects/angular-responsive-carousel/src/lib/carousel.ts"],"names":[],"mappings":"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","sourcesContent":["export interface Properties {\r\n    element: HTMLElement;\r\n    container: HTMLElement;\r\n    images: any;\r\n    cellWidth: number;\r\n    loop: boolean;\r\n    autoplayInterval: number;\r\n    overflowCellsLimit: number;\r\n    visibleWidth: number;\r\n    margin: number;\r\n    minSwipeDistance: number;\r\n    transitionDuration: number;\r\n    transitionTimingFunction: 'ease' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'linear';\r\n    videoProperties: any;\r\n}\r\n\r\nexport class Carousel {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    startX: number;\r\n    moveX: number;\r\n    direction: 'left' | 'right';\r\n    slideLength: number;\r\n    distanceAbs: number;\r\n    initialPositionX: number = 0;\r\n    cells: HTMLCollection;\r\n\r\n    newContainerPositionIndex: number = 0; // The index of the new position relative to the active index, for example -1 or +1\r\n    preliminarySlideCounter: number = 0;\r\n    slideCounter: number = 0; // Scrolling Index (counter)\r\n    previousSlideCounter: number = 0;\r\n\r\n    isSlideInProgress: boolean;\r\n    isMoveInProgress: boolean;\r\n    isTransitionInProgress: boolean;\r\n    isTouchstart: boolean;\r\n    isSlideLengthLimited: boolean;\r\n    isContainerPositionCorrection: boolean;\r\n\r\n    containerInitialPositionX: number;\r\n    isContentImages: boolean = true;\r\n    visibleWidth: number;\r\n    isLazyLoad: boolean = true;\r\n    isContainerLocked: boolean = true;\r\n    alignCells: \"left\" | \"center\" = \"left\";\r\n    initialContainerPosition: number = 0;\r\n    autoplayId: any;\r\n\r\n    get cellLength() {\r\n        if (this.images) {\r\n            return this.images.length;\r\n        } else {\r\n            return this.cells.length;\r\n        }\r\n    }\r\n\r\n    get totalContainerCellsCount() {\r\n        if (this.images) {\r\n            let cellLength = this.visibleCellsCount + this.overflowCellsLimit * 2;\r\n            if (cellLength > this.images.length) {\r\n                cellLength = this.images.length;\r\n            }\r\n            return cellLength;\r\n        } else {\r\n            return this.cellLength;\r\n        }\r\n    }\r\n\r\n    get isFirstCell() {\r\n        return this.slideCounter === 0;\r\n    }\r\n\r\n    get lastCellIndex() {\r\n        return this.images.length ? (this.images.length - 1) : (this.cells.length - 1);\r\n    }\r\n\r\n    get overflowCellsLimit() {\r\n        if (this.images && this.isImagesLessCellLimit) {\r\n            return Math.floor((this.images.length - this.visibleCellsCount) / 2);\r\n        } else {\r\n            return this.properties.overflowCellsLimit;\r\n        }\r\n    }\r\n\r\n    get isImagesLessCellLimit() {\r\n        return this.properties.overflowCellsLimit * 2 + this.visibleCellsCount > this.images.length;\r\n    }\r\n\r\n    get cellLimit() {\r\n        return this.visibleCellsCount + this.overflowCellsLimit * 2;\r\n    }\r\n\r\n    get images() {\r\n        return this.properties.images;\r\n    }\r\n\r\n    get margin() {\r\n        return this.properties.margin;\r\n    }\r\n\r\n    get minSwipeDistance() {\r\n        return this.properties.minSwipeDistance;\r\n    }\r\n\r\n    get transitionDuration() {\r\n        return this.properties.transitionDuration;\r\n    }\r\n\r\n    get transitionTimingFunction() {\r\n        return this.properties.transitionTimingFunction;\r\n    }\r\n\r\n    get fullCellWidth() {\r\n        return this.properties.cellWidth + this.margin;\r\n    }\r\n\r\n    get visibleCellsCount() {\r\n        return Math.ceil(this.visibleWidth / this.fullCellWidth);\r\n    }\r\n\r\n    get lapCounter() {\r\n        return Math.floor(this.slideCounter / this.totalContainerCellsCount);\r\n    }\r\n\r\n    get visibleCellsOverflowContainer() {\r\n        return (this.visibleCellsCount * this.fullCellWidth -this.margin) > this.visibleWidth;\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.element = properties.element;\r\n        this.properties = properties;\r\n        this.cells = this.element.children;\r\n        this.visibleWidth = this.properties.visibleWidth || this.element.parentElement.clientWidth;\r\n\r\n        this.setContainerWidth();\r\n        this.alignContainer(0);\r\n    }\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.isTouchstart = true;\r\n\r\n        if (this.isSlideInProgress) {\r\n            return;\r\n        }\r\n\r\n        const touches = event.touches;\r\n        if (touches) {\r\n            this.startX = touches[0].clientX - this.getCarouselElementPosition()['left'];\r\n        } else {\r\n            this.startX = event.clientX - this.getCarouselElementPosition()['left'];\r\n        }\r\n        this.containerInitialPositionX = this.getElementPosition()['left'] - this.getCarouselElementPosition()['left'];\r\n        this.isMoveInProgress = true;\r\n    }\r\n\r\n    handleHorizontalSwipe = (event: any) => {\r\n        if (this.isSlideInProgress) {\r\n            return;\r\n        }\r\n\r\n        const touches = event.touches;\r\n        if (touches) {\r\n            this.moveX = touches[0].clientX - this.getCarouselElementPosition()['left'];\r\n        } else {\r\n            this.moveX = event.clientX - this.getCarouselElementPosition()['left'];\r\n        }\r\n        this.distanceAbs = this.getDistanceAbs();\r\n        this.direction = this.getDirection();\r\n\r\n        this.moveContainer();\r\n    }\r\n\r\n    handleTouchend = (event: any) => {\r\n        if (this.isSlideInProgress || !this.isTouchstart) {\r\n            this.isTouchstart = false;\r\n            return;\r\n        }\r\n\r\n        this.isMoveInProgress = false;\r\n\r\n        if (this.detectSlide()) {\r\n            this.handleSlide();\r\n        } else {\r\n            this.newContainerPositionIndex = 0;\r\n            this.alignContainer();\r\n        }\r\n\r\n        this.startX = this.moveX = this.distanceAbs = undefined;\r\n        this.isTouchstart = false;\r\n    }\r\n\r\n    /* Move */\r\n    moveContainer() {\r\n        let positionX = this.getMovePositionX();\r\n        this.transformPositionX(positionX, 0);\r\n    }\r\n\r\n    getMovePositionX() {\r\n        const distance = this.getDistance();\r\n        return this.containerInitialPositionX - distance;\r\n    }\r\n\r\n    /* Align */\r\n    alignContainer(duration: number = this.transitionDuration) {\r\n        let positionX = this.getContainerPosition();\r\n        this.transformPositionX(positionX, duration);\r\n        this.setInitialContainerPosition(positionX);\r\n    }\r\n\r\n    getContainerPosition() {\r\n        let correction = this.getContainerPositionCorrection();\r\n\r\n        this.isContainerPositionCorrection = correction != 0;\r\n        return (this.initialContainerPosition + this.newContainerPositionIndex * this.fullCellWidth) + correction;\r\n    }\r\n\r\n    setInitialContainerPosition(position) {\r\n        let correction = this.getContainerPositionCorrection();\r\n        this.initialContainerPosition = position - correction;\r\n    }\r\n\r\n    getContainerPositionCorrection() {\r\n        let correction = 0;\r\n\r\n        if (this.properties.loop) {\r\n            return 0;\r\n        }\r\n\r\n        if ((this.cellLength - this.preliminarySlideCounter) < this.visibleCellsCount || this.isSlideLengthLimited) {\r\n            if (this.visibleWidth < this.totalContainerCellsCount * this.fullCellWidth) {\r\n                correction = - (this.visibleCellsCount * this.fullCellWidth - this.visibleWidth - this.margin);\r\n            }\r\n\r\n            if (correction >= - this.margin) {\r\n                correction = 0;\r\n            }\r\n        }\r\n\r\n        return correction;\r\n    }\r\n\r\n    /* Quickly center */\r\n    quicklyPositionContainer() {\r\n        let correction = this.getContainerPositionCorrection();\r\n        const initialPosition = this.getNewContainerPosition() + correction;\r\n        this.transformPositionX(initialPosition, 0);\r\n        this.setInitialContainerPosition(initialPosition);\r\n    }\r\n\r\n    getNewContainerPosition() {\r\n        if (this.slideCounter > this.overflowCellsLimit) {\r\n            if (this.alignCells === \"left\") {\r\n                this.lineUpCells();\r\n                return -(this.overflowCellsLimit * this.fullCellWidth);\r\n            }\r\n        }\r\n\r\n        if (this.slideCounter <= this.overflowCellsLimit) {\r\n            if (this.previousSlideCounter > this.overflowCellsLimit) {\r\n                this.lineUpCells();\r\n            }\r\n            return -(this.slideCounter * this.fullCellWidth);\r\n        }\r\n    }\r\n\r\n    setContainerWidth() {\r\n        const containerWidth = this.getContainerWidth();\r\n        this.element.style.width = containerWidth + \"px\";\r\n    }\r\n\r\n    getContainerWidth() {\r\n        let containerWidth = this.totalContainerCellsCount * this.fullCellWidth;\r\n        let totalImageWidth = this.cellLength * this.fullCellWidth;\r\n\r\n        if (totalImageWidth < containerWidth) {\r\n            containerWidth = totalImageWidth;\r\n        }\r\n\r\n        return containerWidth;\r\n    }\r\n\r\n    getFile(cellIndex) {\r\n        let imageIndex = this.getFileIndex(cellIndex); \r\n        let file = this.images[imageIndex];\r\n\r\n        if (file && !file.type) {\r\n            file.type = 'image';\r\n        }\r\n\r\n        return {\r\n            image: this.images[imageIndex],\r\n            imageIndex\r\n        };\r\n    }\r\n\r\n    getFileIndex(cellIndex: number) {\r\n        const positionIndex = this.getPositionIndex(cellIndex);\r\n        const numberLeftCells = (this.totalContainerCellsCount - 1) / 2;\r\n        let imageIndex;\r\n        let counter = this.slideCounter;\r\n\r\n        if (!this.isContainerLocked) {\r\n            if (counter <= this.overflowCellsLimit) {\r\n                return cellIndex;\r\n            } else {\r\n                let cellLimitOverflow = counter - this.overflowCellsLimit;\r\n                imageIndex = positionIndex + cellLimitOverflow;\r\n\r\n                if (this.images && this.properties.loop) {\r\n                    imageIndex = imageIndex % this.images.length;\r\n                }\r\n\r\n                return imageIndex;\r\n            }\r\n        }\r\n\r\n        if (this.alignCells === \"left\") {\r\n            if (counter > this.overflowCellsLimit) {\r\n                let cellLimitOverflow = counter - this.overflowCellsLimit;\r\n                imageIndex = positionIndex + cellLimitOverflow;\r\n            } else {\r\n                imageIndex = cellIndex;\r\n            }\r\n        }\r\n\r\n        if (imageIndex > this.lastCellIndex && !this.properties.loop) {\r\n            return false;\r\n        }\r\n\r\n        return imageIndex;\r\n    }\r\n\r\n    transformPositionX(value, duration = this.transitionDuration) {\r\n        this.element.style.transition = 'transform ' + duration + 'ms ' + this.transitionTimingFunction;\r\n        this.element.style.transform = 'translateX(' + value + 'px)';\r\n    }\r\n\r\n    detectSlide() {\r\n        return this.distanceAbs >= this.minSwipeDistance;\r\n    }\r\n\r\n    next(length: number = 1) {\r\n        if (this.isSlideInProgress) {\r\n            return;\r\n        }\r\n\r\n        this.direction = 'left';\r\n        this.handleSlide(length);\r\n    }\r\n\r\n    prev(length: number = 1) {\r\n        if (this.isSlideInProgress) {\r\n            return;\r\n        }\r\n\r\n        this.direction = 'right';\r\n        this.handleSlide(length);\r\n    }\r\n\r\n    select(index: number) {\r\n        this.slideCounter = index;\r\n        this.quicklyPositionContainer();\r\n    }\r\n\r\n    handleSlide(slideLength: number = undefined): void {\r\n        this.slideLength = this.getSlideLength();\r\n        this.slideLength = slideLength ? slideLength : this.limitSlideLength(this.slideLength);\r\n\r\n        if (this.direction === 'left' && !this.isSlideInProgress) {\r\n            this.preliminarySlideCounter = this.slideCounter + this.slideLength;\r\n\r\n            if (!this.detectLastSlide(this.slideCounter + this.slideLength)) {\r\n                this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength;\r\n                this.isSlideInProgress = true;\r\n\r\n                if (this.isLazyLoad) {\r\n                    this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit;\r\n\r\n                    if (this.detectContainerUnlock()) {\r\n                        this.isContainerLocked = false;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        if (this.direction === 'right' && !this.isSlideInProgress) {\r\n            if (this.slideCounter - this.slideLength < 0) {\r\n                this.slideLength = this.slideCounter;\r\n            }\r\n\r\n            this.preliminarySlideCounter = this.slideCounter - this.slideLength;\r\n\r\n            if (!this.isFirstCell) {\r\n                this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength;\r\n                this.isSlideInProgress = true;\r\n\r\n                if (this.isLazyLoad) {\r\n                    if (this.preliminarySlideCounter > this.overflowCellsLimit) {\r\n                        this.isContainerLocked = true;\r\n                    } else {\r\n                        this.isContainerLocked = false;\r\n                    }\r\n\r\n                    if (this.detectContainerUnlock()) {\r\n                        this.isContainerLocked = false;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        this.alignContainer();\r\n    }\r\n\r\n    getSlideLength() {\r\n        let correction = this.getContainerPositionCorrection();\r\n        let length = Math.floor((this.distanceAbs + correction) / this.fullCellWidth);\r\n\r\n        if (this.distanceAbs % this.fullCellWidth >= this.minSwipeDistance) {\r\n            length++;\r\n        }\r\n        return length;\r\n    }\r\n\r\n    limitSlideLength(slideLength: number) {\r\n        if (slideLength > 1) {\r\n\r\n            for (var i = 0; i < slideLength; i++) {\r\n                let newSlideCounter = this.slideCounter + (slideLength - i);\r\n\r\n                if (!this.detectLastSlide(newSlideCounter)) {\r\n                    slideLength = slideLength - i;\r\n                    this.isSlideLengthLimited = i > 0;\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n        return slideLength;\r\n    }\r\n\r\n    detectLastSlide(slideCounter: number) {\r\n        if (this.properties.loop) {\r\n            return false;\r\n        } else {\r\n            return (this.cellLength - slideCounter) < this.visibleCellsCount;\r\n        }\r\n    }\r\n\r\n    isNextArrowDisabled() {\r\n        if (this.visibleCellsOverflowContainer) {\r\n            return this.detectLastSlide(this.slideCounter + 1) && this.isContainerPositionCorrection;\r\n        } else {\r\n            return this.detectLastSlide(this.slideCounter + 1);\r\n        }\r\n    }\r\n\r\n    isPrevArrowDisabled() {\r\n        return this.slideCounter === 0;\r\n    }\r\n\r\n    detectContainerUnlock() {\r\n        return (this.cellLength - this.preliminarySlideCounter) < (this.visibleCellsCount + this.overflowCellsLimit);\r\n    }\r\n\r\n    handleSlideEnd() {\r\n        if (this.isSlideInProgress) {\r\n            this.transformSlideEnd();\r\n\r\n            this.isSlideInProgress = false;\r\n            this.newContainerPositionIndex = 0;\r\n            this.isSlideLengthLimited = undefined;\r\n        }\r\n    }\r\n\r\n    transformSlideEnd() {\r\n        if (this.isLazyLoad) {\r\n            this.setSlideCounter();\r\n            if (this.images || !this.images && this.properties.loop) {\r\n                this.quicklyPositionContainer();\r\n            }\r\n        }\r\n\r\n        this.previousSlideCounter = this.slideCounter;\r\n    }\r\n\r\n    setSlideCounter() {\r\n        if (this.direction === 'left') {\r\n            this.slideCounter = this.slideCounter + this.slideLength;\r\n        }\r\n\r\n        if (this.direction === 'right') {\r\n            this.slideCounter = this.slideCounter - this.slideLength;\r\n        }\r\n\r\n        this.direction = undefined;\r\n        this.slideLength = 0;\r\n    }\r\n\r\n    resetTransition() {\r\n        this.element.style.transition = '';\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getCarouselElementPosition() {\r\n        return this.properties.container.getBoundingClientRect();\r\n    }\r\n\r\n    getDistance() {\r\n        return this.startX - this.moveX;\r\n    }\r\n\r\n    getDistanceAbs() {\r\n        return Math.abs(this.startX - this.moveX);\r\n    }\r\n\r\n    getDirection() {\r\n        const direction = Math.sign(this.startX - this.moveX);\r\n\r\n        if (direction === -1) {\r\n            return 'right';\r\n        }\r\n        if (direction === 1) {\r\n            return 'left';\r\n        }\r\n    }\r\n\r\n    lineUpCells() {\r\n        const cells = this.element.children;\r\n\r\n        for (var i = 0; i < cells.length; i++) {\r\n            let cell = cells[i];\r\n            let positionX = this.getCellPositionX(i);\r\n            (cell as HTMLElement).style.transform = 'translateX(' + positionX + 'px)';\r\n\r\n            // notice\r\n            (cell as HTMLElement).style.width = this.properties.cellWidth+'px';\r\n        };\r\n    }\r\n\r\n    getCellPositionX(index) {\r\n        let positionIndex = this.getPositionIndex(index);\r\n        return positionIndex * this.fullCellWidth;\r\n    }\r\n\r\n    getPositionIndex(cellIndex) {\r\n        let counter = this.slideCounter;\r\n        let cellLength = this.totalContainerCellsCount;\r\n        let slideCounter = counter - this.overflowCellsLimit;\r\n        let positionIndex;\r\n\r\n        if (slideCounter > cellLength) {\r\n            slideCounter = slideCounter % cellLength;\r\n        }\r\n\r\n        if (slideCounter < 0) {\r\n            return cellIndex;\r\n        } else {\r\n            positionIndex = cellIndex - slideCounter;\r\n            if (positionIndex < 0) {\r\n                positionIndex = cellLength + positionIndex;\r\n            }\r\n        }\r\n\r\n        return positionIndex;\r\n    }\r\n\r\n    getCenterPositionIndex() {\r\n        return (this.totalContainerCellsCount - 1) / 2;\r\n    }\r\n\r\n    autoplay() {\r\n        this.autoplayId = setInterval(() => {\r\n            this.next(); \r\n        }, this.properties.autoplayInterval);\r\n    }\r\n\r\n    stopAutoplay() {\r\n        if (this.autoplayId) {\r\n            clearInterval(this.autoplayId);\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        this.stopAutoplay();\r\n    }\r\n}"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.js","sourceRoot":"","sources":["../../../../projects/angular-responsive-carousel/src/lib/carousel.ts"],"names":[],"mappings":"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","sourcesContent":["export interface Properties {\r\n    element: HTMLElement;\r\n    container: HTMLElement;\r\n    images: any;\r\n    cellWidth: number;\r\n    loop: boolean;\r\n    autoplayInterval: number;\r\n    overflowCellsLimit: number;\r\n    visibleWidth: number;\r\n    margin: number;\r\n    minSwipeDistance: number;\r\n    transitionDuration: number;\r\n    transitionTimingFunction: 'ease' | 'ease-in' | 'ease-out' | 'ease-in-out' | 'linear';\r\n    videoProperties: any;\r\n}\r\n\r\nexport class Carousel {\r\n    properties: Properties;\r\n    element: HTMLElement;\r\n    startX: number;\r\n    moveX: number;\r\n    direction: 'left' | 'right';\r\n    slideLength: number;\r\n    distanceAbs: number;\r\n    initialPositionX: number = 0;\r\n    cells: HTMLCollection;\r\n\r\n    /* The index of the new position relative to the active index, for example -1 or +1 */\r\n    newContainerPositionIndex: number = 0;\r\n\r\n    preliminarySlideCounter: number = 0;\r\n\r\n    /* Scrolling Index (counter) */\r\n    slideCounter: number = 0;\r\n\r\n    previousSlideCounter: number = 0;\r\n    isSlideInProgress: boolean;\r\n    isMoveInProgress: boolean;\r\n    isTouchstart: boolean;\r\n\r\n    /* The slide length has been limited by the limitSlideLength() method */\r\n    isSlideLengthLimited: boolean;\r\n\r\n    isContainerPositionCorrection: boolean;\r\n    containerInitialPositionX: number;\r\n    isContentImages: boolean = true;\r\n    visibleWidth: number;\r\n    isLazyLoad: boolean = true;\r\n    isContainerLocked: boolean = true;\r\n    alignCells: \"left\" | \"center\" = \"left\";\r\n    initialContainerPosition: number = 0;\r\n    autoplayId: any;\r\n\r\n    get cellLength() {\r\n        if (this.images) {\r\n            return this.images.length;\r\n        } else {\r\n            return this.cells.length;\r\n        }\r\n    }\r\n\r\n    get totalContainerCellsCount() {\r\n        if (this.images) {\r\n            let cellLength = this.visibleCellsCount + this.overflowCellsLimit * 2;\r\n            if (cellLength > this.images.length) {\r\n                cellLength = this.images.length;\r\n            }\r\n            return cellLength;\r\n        } else {\r\n            return this.cellLength;\r\n        }\r\n    }\r\n\r\n    get isFirstCell() {\r\n        return this.slideCounter === 0;\r\n    }\r\n\r\n    get lastCellIndex() {\r\n        return this.images.length ? (this.images.length - 1) : (this.cells.length - 1);\r\n    }\r\n\r\n    get overflowCellsLimit() {\r\n        if (this.images && this.isImagesLessCellLimit) {\r\n            return Math.floor((this.images.length - this.visibleCellsCount) / 2);\r\n        } else {\r\n            return this.properties.overflowCellsLimit;\r\n        }\r\n    }\r\n\r\n    get isImagesLessCellLimit() {\r\n        return this.properties.overflowCellsLimit * 2 + this.visibleCellsCount > this.images.length;\r\n    }\r\n\r\n    get cellLimit() {\r\n        return this.visibleCellsCount + this.overflowCellsLimit * 2;\r\n    }\r\n\r\n    get images() {\r\n        return this.properties.images;\r\n    }\r\n\r\n    get margin() {\r\n        return this.properties.margin;\r\n    }\r\n\r\n    get minSwipeDistance() {\r\n        return this.properties.minSwipeDistance;\r\n    }\r\n\r\n    get transitionDuration() {\r\n        return this.properties.transitionDuration;\r\n    }\r\n\r\n    get transitionTimingFunction() {\r\n        return this.properties.transitionTimingFunction;\r\n    }\r\n\r\n    get fullCellWidth() {\r\n        return this.properties.cellWidth + this.margin;\r\n    }\r\n\r\n    get visibleCellsCount() {\r\n        return Math.ceil(this.visibleWidth / this.fullCellWidth);\r\n    }\r\n\r\n    get lapCounter() {\r\n        return Math.floor(this.slideCounter / this.totalContainerCellsCount);\r\n    }\r\n\r\n    get visibleCellsOverflowContainer() {\r\n        return (this.visibleCellsCount * this.fullCellWidth -this.margin) > this.visibleWidth;\r\n    }\r\n\r\n    constructor(properties: Properties) {\r\n        this.element = properties.element;\r\n        this.properties = properties;\r\n        this.cells = this.element.children;\r\n        this.visibleWidth = this.properties.visibleWidth || this.element.parentElement.clientWidth;\r\n\r\n        this.setContainerWidth();\r\n        this.alignContainer(0);\r\n    }\r\n\r\n    handleTouchstart = (event: any) => {\r\n        this.isTouchstart = true;\r\n        this.startX = this.getStartX(event);\r\n        this.containerInitialPositionX = this.getElementPosition()['left'] - this.getCarouselElementPosition()['left'];\r\n        this.isMoveInProgress = true;\r\n        this.stopTransformContainer();\r\n    }\r\n\r\n    stopTransformContainer() {\r\n        this.transformPositionX(this.containerInitialPositionX, 0);\r\n        this.setSlideCounter();\r\n        this.isSlideInProgress = false;\r\n        this.newContainerPositionIndex = 0;\r\n        this.isSlideLengthLimited = undefined;\r\n    }\r\n\r\n    getStartX(event: any) {\r\n        const touches = event.touches;\r\n        let startX;\r\n\r\n        if (touches) {\r\n            startX = touches[0].clientX - this.getCarouselElementPosition()['left'];\r\n        } else {\r\n            startX = event.clientX - this.getCarouselElementPosition()['left'];\r\n        }\r\n\r\n        return startX;\r\n    }\r\n\r\n    handleHorizontalSwipe = (event: any) => {\r\n        const touches = event.touches;\r\n        if (touches) {\r\n            this.moveX = touches[0].clientX - this.getCarouselElementPosition()['left'];\r\n        } else {\r\n            this.moveX = event.clientX - this.getCarouselElementPosition()['left'];\r\n        }\r\n        this.distanceAbs = this.getDistanceAbs();\r\n        this.direction = this.getDirection();\r\n\r\n        this.moveContainer();\r\n    }\r\n\r\n    handleTouchend = (event: any) => {\r\n        if (!this.isTouchstart) {\r\n            this.isTouchstart = false;\r\n            return;\r\n        }\r\n\r\n        this.isMoveInProgress = false;\r\n\r\n        if (this.detectSlide()) {\r\n            this.handleSlide();\r\n        } else {\r\n            this.newContainerPositionIndex = 0;\r\n            this.alignContainer();\r\n        }\r\n\r\n        this.startX = this.moveX = this.distanceAbs = undefined;\r\n        this.isTouchstart = false;\r\n    }\r\n\r\n    /* Move */\r\n    moveContainer() {\r\n        let positionX = this.getMovePositionX();\r\n        this.transformPositionX(positionX, 0);\r\n    }\r\n\r\n    getMovePositionX() {\r\n        const distance = this.getDistance();\r\n        return this.containerInitialPositionX - distance;\r\n    }\r\n\r\n    /* Align */\r\n    alignContainer(duration: number = this.transitionDuration) {\r\n        let positionX = this.getContainerPosition();\r\n        this.transformPositionX(positionX, duration);\r\n        this.setInitialContainerPosition(positionX);\r\n    }\r\n\r\n    getContainerPosition() {\r\n        let correction = this.getContainerPositionCorrection();\r\n\r\n        this.isContainerPositionCorrection = correction != 0;\r\n        return (this.initialContainerPosition + this.newContainerPositionIndex * this.fullCellWidth) + correction;\r\n    }\r\n\r\n    setInitialContainerPosition(position) {\r\n        let correction = this.getContainerPositionCorrection();\r\n        this.initialContainerPosition = position - correction;\r\n    }\r\n\r\n    /* Offset the container to show the last cell completely */\r\n    getContainerPositionCorrection() {\r\n        let correction = 0;\r\n\r\n        if (this.properties.loop) {\r\n            return 0;\r\n        }\r\n\r\n        if ((this.cellLength - this.preliminarySlideCounter) < this.visibleCellsCount || this.isSlideLengthLimited) {\r\n            if (this.visibleWidth < this.totalContainerCellsCount * this.fullCellWidth) {\r\n                correction = - (this.visibleCellsCount * this.fullCellWidth - this.visibleWidth - this.margin);\r\n            }\r\n\r\n            if (correction >= - this.margin) {\r\n                correction = 0;\r\n            }\r\n        }\r\n\r\n        return correction;\r\n    }\r\n\r\n    /* Quickly center */\r\n    quicklyPositionContainer() {\r\n        let correction = this.getContainerPositionCorrection();\r\n        const initialPosition = this.getNewContainerPosition() + correction;\r\n        this.transformPositionX(initialPosition, 0);\r\n        this.setInitialContainerPosition(initialPosition);\r\n    }\r\n\r\n    getNewContainerPosition() {\r\n        if (this.slideCounter > this.overflowCellsLimit) {\r\n            if (this.alignCells === \"left\") {\r\n                this.lineUpCells();\r\n                return -(this.overflowCellsLimit * this.fullCellWidth);\r\n            }\r\n        }\r\n\r\n        if (this.slideCounter <= this.overflowCellsLimit) {\r\n            if (this.previousSlideCounter > this.overflowCellsLimit) {\r\n                this.lineUpCells();\r\n            }\r\n            return -(this.slideCounter * this.fullCellWidth);\r\n        }\r\n    }\r\n\r\n    setContainerWidth() {\r\n        const containerWidth = this.getContainerWidth();\r\n        this.element.style.width = containerWidth + \"px\";\r\n    }\r\n\r\n    getContainerWidth() {\r\n        let containerWidth = this.totalContainerCellsCount * this.fullCellWidth;\r\n        let totalImageWidth = this.cellLength * this.fullCellWidth;\r\n\r\n        if (totalImageWidth < containerWidth) {\r\n            containerWidth = totalImageWidth;\r\n        }\r\n\r\n        return containerWidth;\r\n    }\r\n\r\n    getFile(cellIndex) {\r\n        let imageIndex = this.getFileIndex(cellIndex); \r\n        let file = this.images[imageIndex];\r\n\r\n        if (file && !file.type) {\r\n            file.type = 'image';\r\n        }\r\n\r\n        return {\r\n            image: this.images[imageIndex],\r\n            imageIndex\r\n        };\r\n    }\r\n\r\n    getFileIndex(cellIndex: number) {\r\n        const positionIndex = this.getPositionIndex(cellIndex);\r\n        const numberLeftCells = (this.totalContainerCellsCount - 1) / 2;\r\n        let imageIndex;\r\n        let counter = this.slideCounter;\r\n\r\n        if (!this.isContainerLocked) {\r\n            if (counter <= this.overflowCellsLimit) {\r\n                return cellIndex;\r\n            } else {\r\n                let cellLimitOverflow = counter - this.overflowCellsLimit;\r\n                imageIndex = positionIndex + cellLimitOverflow;\r\n\r\n                if (this.images && this.properties.loop) {\r\n                    imageIndex = imageIndex % this.images.length;\r\n                }\r\n\r\n                return imageIndex;\r\n            }\r\n        }\r\n\r\n        if (this.alignCells === \"left\") {\r\n            if (counter > this.overflowCellsLimit) {\r\n                let cellLimitOverflow = counter - this.overflowCellsLimit;\r\n                imageIndex = positionIndex + cellLimitOverflow;\r\n            } else {\r\n                imageIndex = cellIndex;\r\n            }\r\n        }\r\n\r\n        if (imageIndex > this.lastCellIndex && !this.properties.loop) {\r\n            return false;\r\n        }\r\n\r\n        return imageIndex;\r\n    }\r\n\r\n    transformPositionX(value, duration = this.transitionDuration) {\r\n        this.element.style.transition = 'transform ' + duration + 'ms ' + this.transitionTimingFunction;\r\n        this.element.style.transform = 'translateX(' + value + 'px)';\r\n    }\r\n\r\n    detectSlide() {\r\n        return this.distanceAbs >= this.minSwipeDistance;\r\n    }\r\n\r\n    next(length: number = 1) {\r\n        this.newContainerPositionIndex = 0;\r\n        this.direction = 'left';\r\n        this.handleSlide(length);\r\n    }\r\n\r\n    prev(length: number = 1) {\r\n        this.newContainerPositionIndex = 0;\r\n        this.direction = 'right';\r\n        this.handleSlide(length);\r\n    }\r\n\r\n    select(index: number) {\r\n        this.slideCounter = index;\r\n        this.quicklyPositionContainer();\r\n    }\r\n\r\n    handleSlide(customSlideLength: number = undefined) {\r\n        let isUsingButton = customSlideLength;\r\n\r\n        if (isUsingButton && this.isSlideInProgress) {\r\n            return;\r\n        }\r\n\r\n        this.slideLength = customSlideLength ? customSlideLength : this.limitSlideLength(this.getSlideLength());\r\n\r\n        if (this.direction === 'left') {\r\n            this.handleLeftSlide();\r\n        }\r\n\r\n        if (this.direction === 'right') {\r\n            this.handleRightSlide();\r\n        }\r\n\r\n        this.alignContainer();\r\n    }\r\n\r\n    handleLeftSlide() {\r\n        this.preliminarySlideCounter = this.slideCounter + this.slideLength;\r\n        let isLastSlide = this.detectLastSlide(this.slideCounter + this.slideLength);\r\n\r\n        if (!isLastSlide) {\r\n            this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength;\r\n            this.isSlideInProgress = true;\r\n\r\n            if (this.isLazyLoad) {\r\n                this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit;\r\n\r\n                if (this.detectContainerUnlock()) {\r\n                    this.isContainerLocked = false;\r\n                }\r\n            }\r\n        } else {\r\n            this.slideLength = 0;\r\n        }\r\n    }\r\n\r\n    handleRightSlide() {\r\n        if (this.slideCounter - this.slideLength < 0) {\r\n            this.slideLength = this.slideCounter;\r\n        }\r\n\r\n        this.preliminarySlideCounter = this.slideCounter - this.slideLength;\r\n\r\n        if (!this.isFirstCell) {\r\n            this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength;\r\n            this.isSlideInProgress = true;\r\n\r\n            if (this.isLazyLoad) {\r\n                if (this.preliminarySlideCounter > this.overflowCellsLimit) {\r\n                    this.isContainerLocked = true;\r\n                } else {\r\n                    this.isContainerLocked = false;\r\n                }\r\n\r\n                if (this.detectContainerUnlock()) {\r\n                    this.isContainerLocked = false;\r\n                }\r\n            }\r\n        } else {\r\n            this.slideLength = 0;\r\n        }\r\n    }\r\n\r\n    getSlideLength() {\r\n        let correction = this.getContainerPositionCorrection();\r\n        let length = Math.floor((this.distanceAbs + correction) / this.fullCellWidth);\r\n\r\n        if (this.distanceAbs % this.fullCellWidth >= this.minSwipeDistance) {\r\n            length++;\r\n        }\r\n        return length;\r\n    }\r\n\r\n    /*  \r\n     * Limits the length of the slide during calls to the next() and prev() \r\n     * methods if the specified position is outside the cell length \r\n     */\r\n    limitSlideLength(slideLength: number) {\r\n        if (slideLength > 1) {\r\n\r\n            for (var i = 0; i < slideLength; i++) {\r\n                let newSlideCounter = this.slideCounter + (slideLength - i);\r\n\r\n                if (!this.detectLastSlide(newSlideCounter)) {\r\n                    slideLength = slideLength - i;\r\n                    this.isSlideLengthLimited = i > 0;\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n        return slideLength;\r\n    }\r\n\r\n    detectLastSlide(slideCounter: number) {\r\n        if (this.properties.loop) {\r\n            return false;\r\n        } else {\r\n            return (this.cellLength - slideCounter) < this.visibleCellsCount;\r\n        }\r\n    }\r\n\r\n    isNextArrowDisabled() {\r\n        if (this.visibleCellsOverflowContainer) {\r\n            return this.detectLastSlide(this.slideCounter + 1) && this.isContainerPositionCorrection;\r\n        } else {\r\n            return this.detectLastSlide(this.slideCounter + 1);\r\n        }\r\n    }\r\n\r\n    isPrevArrowDisabled() {\r\n        return this.slideCounter === 0;\r\n    }\r\n\r\n    detectContainerUnlock() {\r\n        return (this.cellLength - this.preliminarySlideCounter) < (this.visibleCellsCount + this.overflowCellsLimit);\r\n    }\r\n\r\n    handleSlideEnd() {\r\n        if (this.isSlideInProgress) {\r\n            this.transformSlideEnd();\r\n\r\n            this.isSlideInProgress = false;\r\n            this.newContainerPositionIndex = 0;\r\n            this.isSlideLengthLimited = undefined;\r\n        }\r\n    }\r\n\r\n    transformSlideEnd() {\r\n        if (this.isLazyLoad) {\r\n            this.setSlideCounter();\r\n            if (this.images || !this.images && this.properties.loop) {\r\n                this.quicklyPositionContainer();\r\n            }\r\n        }\r\n\r\n        this.previousSlideCounter = this.slideCounter;\r\n    }\r\n\r\n    setSlideCounter() {\r\n        if (this.direction === 'left') {\r\n            this.slideCounter = this.slideCounter + this.slideLength;\r\n        }\r\n\r\n        if (this.direction === 'right') {\r\n            this.slideCounter = this.slideCounter - this.slideLength;\r\n        }\r\n\r\n        this.direction = undefined;\r\n        this.slideLength = 0;\r\n    }\r\n\r\n    resetTransition() {\r\n        this.element.style.transition = '';\r\n    }\r\n\r\n    getElementPosition() {\r\n        return this.element.getBoundingClientRect();\r\n    }\r\n\r\n    getCarouselElementPosition() {\r\n        return this.properties.container.getBoundingClientRect();\r\n    }\r\n\r\n    getDistance() {\r\n        return this.startX - this.moveX;\r\n    }\r\n\r\n    getDistanceAbs() {\r\n        return Math.abs(this.startX - this.moveX);\r\n    }\r\n\r\n    getDirection() {\r\n        const direction = Math.sign(this.startX - this.moveX);\r\n\r\n        if (direction === -1) {\r\n            return 'right';\r\n        }\r\n        if (direction === 1) {\r\n            return 'left';\r\n        }\r\n    }\r\n\r\n    lineUpCells() {\r\n        const cells = this.element.children;\r\n\r\n        for (var i = 0; i < cells.length; i++) {\r\n            let cell = cells[i];\r\n            let positionX = this.getCellPositionX(i);\r\n            (cell as HTMLElement).style.transform = 'translateX(' + positionX + 'px)';\r\n\r\n            // notice\r\n            (cell as HTMLElement).style.width = this.properties.cellWidth+'px';\r\n        };\r\n    }\r\n\r\n    getCellPositionX(index) {\r\n        let positionIndex = this.getPositionIndex(index);\r\n        return positionIndex * this.fullCellWidth;\r\n    }\r\n\r\n    getPositionIndex(cellIndex) {\r\n        let counter = this.slideCounter;\r\n        let cellLength = this.totalContainerCellsCount;\r\n        let slideCounter = counter - this.overflowCellsLimit;\r\n        let positionIndex;\r\n\r\n        if (slideCounter > cellLength) {\r\n            slideCounter = slideCounter % cellLength;\r\n        }\r\n\r\n        if (slideCounter < 0) {\r\n            return cellIndex;\r\n        } else {\r\n            positionIndex = cellIndex - slideCounter;\r\n            if (positionIndex < 0) {\r\n                positionIndex = cellLength + positionIndex;\r\n            }\r\n        }\r\n\r\n        return positionIndex;\r\n    }\r\n\r\n    getCenterPositionIndex() {\r\n        return (this.totalContainerCellsCount - 1) / 2;\r\n    }\r\n\r\n    autoplay() {\r\n        this.autoplayId = setInterval(() => {\r\n            this.next(); \r\n        }, this.properties.autoplayInterval);\r\n    }\r\n\r\n    stopAutoplay() {\r\n        if (this.autoplayId) {\r\n            clearInterval(this.autoplayId);\r\n        }\r\n    }\r\n\r\n    destroy() {\r\n        this.stopAutoplay();\r\n    }\r\n}"]} |
@@ -346,5 +346,7 @@ import { EventEmitter, Component, ElementRef, ChangeDetectorRef, Input, Output, HostBinding, HostListener, NgModule } from '@angular/core'; | ||
this.initialPositionX = 0; | ||
this.newContainerPositionIndex = 0; // The index of the new position relative to the active index, for example -1 or +1 | ||
/* The index of the new position relative to the active index, for example -1 or +1 */ | ||
this.newContainerPositionIndex = 0; | ||
this.preliminarySlideCounter = 0; | ||
this.slideCounter = 0; // Scrolling Index (counter) | ||
/* Scrolling Index (counter) */ | ||
this.slideCounter = 0; | ||
this.previousSlideCounter = 0; | ||
@@ -358,19 +360,8 @@ this.isContentImages = true; | ||
this.isTouchstart = true; | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
const touches = event.touches; | ||
if (touches) { | ||
this.startX = touches[0].clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
this.startX = event.clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
this.startX = this.getStartX(event); | ||
this.containerInitialPositionX = this.getElementPosition()['left'] - this.getCarouselElementPosition()['left']; | ||
this.isMoveInProgress = true; | ||
this.stopTransformContainer(); | ||
}; | ||
this.handleHorizontalSwipe = (event) => { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
const touches = event.touches; | ||
@@ -388,3 +379,3 @@ if (touches) { | ||
this.handleTouchend = (event) => { | ||
if (this.isSlideInProgress || !this.isTouchstart) { | ||
if (!this.isTouchstart) { | ||
this.isTouchstart = false; | ||
@@ -478,2 +469,20 @@ return; | ||
} | ||
stopTransformContainer() { | ||
this.transformPositionX(this.containerInitialPositionX, 0); | ||
this.setSlideCounter(); | ||
this.isSlideInProgress = false; | ||
this.newContainerPositionIndex = 0; | ||
this.isSlideLengthLimited = undefined; | ||
} | ||
getStartX(event) { | ||
const touches = event.touches; | ||
let startX; | ||
if (touches) { | ||
startX = touches[0].clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
else { | ||
startX = event.clientX - this.getCarouselElementPosition()['left']; | ||
} | ||
return startX; | ||
} | ||
/* Move */ | ||
@@ -503,2 +512,3 @@ moveContainer() { | ||
} | ||
/* Offset the container to show the last cell completely */ | ||
getContainerPositionCorrection() { | ||
@@ -603,5 +613,3 @@ let correction = 0; | ||
next(length = 1) { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'left'; | ||
@@ -611,5 +619,3 @@ this.handleSlide(length); | ||
prev(length = 1) { | ||
if (this.isSlideInProgress) { | ||
return; | ||
} | ||
this.newContainerPositionIndex = 0; | ||
this.direction = 'right'; | ||
@@ -622,40 +628,56 @@ this.handleSlide(length); | ||
} | ||
handleSlide(slideLength = undefined) { | ||
this.slideLength = this.getSlideLength(); | ||
this.slideLength = slideLength ? slideLength : this.limitSlideLength(this.slideLength); | ||
if (this.direction === 'left' && !this.isSlideInProgress) { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
if (!this.detectLastSlide(this.slideCounter + this.slideLength)) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
handleSlide(customSlideLength = undefined) { | ||
let isUsingButton = customSlideLength; | ||
if (isUsingButton && this.isSlideInProgress) { | ||
return; | ||
} | ||
this.slideLength = customSlideLength ? customSlideLength : this.limitSlideLength(this.getSlideLength()); | ||
if (this.direction === 'left') { | ||
this.handleLeftSlide(); | ||
} | ||
if (this.direction === 'right') { | ||
this.handleRightSlide(); | ||
} | ||
this.alignContainer(); | ||
} | ||
handleLeftSlide() { | ||
this.preliminarySlideCounter = this.slideCounter + this.slideLength; | ||
let isLastSlide = this.detectLastSlide(this.slideCounter + this.slideLength); | ||
if (!isLastSlide) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex - this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
this.isContainerLocked = this.preliminarySlideCounter > this.overflowCellsLimit; | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
if (this.direction === 'right' && !this.isSlideInProgress) { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
else { | ||
this.slideLength = 0; | ||
} | ||
} | ||
handleRightSlide() { | ||
if (this.slideCounter - this.slideLength < 0) { | ||
this.slideLength = this.slideCounter; | ||
} | ||
this.preliminarySlideCounter = this.slideCounter - this.slideLength; | ||
if (!this.isFirstCell) { | ||
this.newContainerPositionIndex = this.newContainerPositionIndex + this.slideLength; | ||
this.isSlideInProgress = true; | ||
if (this.isLazyLoad) { | ||
if (this.preliminarySlideCounter > this.overflowCellsLimit) { | ||
this.isContainerLocked = true; | ||
} | ||
else { | ||
this.isContainerLocked = false; | ||
} | ||
if (this.detectContainerUnlock()) { | ||
this.isContainerLocked = false; | ||
} | ||
} | ||
} | ||
this.alignContainer(); | ||
else { | ||
this.slideLength = 0; | ||
} | ||
} | ||
@@ -670,2 +692,6 @@ getSlideLength() { | ||
} | ||
/* | ||
* Limits the length of the slide during calls to the next() and prev() | ||
* methods if the specified position is outside the cell length | ||
*/ | ||
limitSlideLength(slideLength) { | ||
@@ -824,3 +850,3 @@ if (slideLength > 1) { | ||
this.objectFit = 'cover'; | ||
this.minSwipeDistance = 50; | ||
this.minSwipeDistance = 10; | ||
this.transitionDuration = 200; | ||
@@ -827,0 +853,0 @@ this.transitionTimingFunction = 'ease'; |
@@ -32,3 +32,2 @@ export interface Properties { | ||
isMoveInProgress: boolean; | ||
isTransitionInProgress: boolean; | ||
isTouchstart: boolean; | ||
@@ -63,2 +62,4 @@ isSlideLengthLimited: boolean; | ||
handleTouchstart: (event: any) => void; | ||
stopTransformContainer(): void; | ||
getStartX(event: any): any; | ||
handleHorizontalSwipe: (event: any) => void; | ||
@@ -86,3 +87,5 @@ handleTouchend: (event: any) => void; | ||
select(index: number): void; | ||
handleSlide(slideLength?: number): void; | ||
handleSlide(customSlideLength?: number): void; | ||
handleLeftSlide(): void; | ||
handleRightSlide(): void; | ||
getSlideLength(): number; | ||
@@ -89,0 +92,0 @@ limitSlideLength(slideLength: number): number; |
{ | ||
"name": "angular-responsive-carousel", | ||
"version": "1.4.11", | ||
"version": "1.5.11", | ||
"description": "Carousel for Angular. A simple solution for horizontal scrolling images with lazy loading.", | ||
@@ -16,5 +16,3 @@ "repository": { | ||
"Angular", | ||
"Angular 2", | ||
"ngx", | ||
"ng2", | ||
"Carousel", | ||
@@ -21,0 +19,0 @@ "Swiper", |
@@ -64,3 +64,3 @@ # Carousel for Angular | ||
| cellWidth | number, '100%' | 200 | Cell width. | | ||
| cellsToShow | number | | The number of carousel cells in the visible area. | | ||
| cellsToShow | number | | The number of cells to display, regardless of the width of the container. | | ||
| cellsToScroll | number | 1 | The number of carousel cells to scroll per arrow click. | | ||
@@ -74,5 +74,5 @@ | loop | boolean | false | Infinite loop. | | ||
| margin | number | 10 | Cell spacing. | | ||
| minSwipeDistance | number | 50 | Minimum distance for swipe. | | ||
| transitionDuration | number | 200 | Animation duration. | | ||
| transitionTimingFunction | 'ease', 'ease-in', 'ease-out', 'ease-in-out', 'linear' | 'ease' | Smooth animation function. | | ||
| minSwipeDistance | number | 10 | Minimum distance for swipe. | | ||
| transitionDuration | number | 300 | Animation duration. | | ||
| transitionTimingFunction | 'ease', 'ease-in', 'ease-out', 'ease-in-out', 'linear' | 'ease-in-out' | Smooth animation function. | | ||
| counter | boolean | false | Counter. | | ||
@@ -93,4 +93,2 @@ | counterSeparator | string | " / " | Counter separator. | | ||
`slidesToShow` - the number of cells to display, regardless of the width of the container. | ||
`centerMode` - center the cells inside the container (Pro version). | ||
@@ -100,4 +98,2 @@ | ||
`adaptiveHeight` - the height of the container is set based on the height of the tallest cell currently visible. | ||
`groupCells` - the cells will behave as grouped, the group will include the number of visible cells that fit into the container area. | ||
`adaptiveHeight` - the height of the container is set based on the height of the tallest cell currently visible. |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
541279
4109
95