angular-gallery
Version:
Responsive gallery for Angular with touch screen support.
379 lines • 43.4 kB
JavaScript
import { __decorate } from "tslib";
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, OnDestroy, SimpleChanges } from '@angular/core';
import { Touches } from './touches';
import { Carousel } from './carousel';
import { EventService as OverlayEventService } from './overlay/event.service';
var CarouselComponent = /** @class */ (function () {
function CarouselComponent(elementRef, ref, overlayEventService) {
var _this = this;
this.elementRef = elementRef;
this.ref = ref;
this.overlayEventService = overlayEventService;
this.minTimeout = 30;
this._cellWidth = 200;
this._transitionDuration = 200;
this.events = new EventEmitter();
this.height = 200;
this.margin = 10;
this.objectFit = 'cover';
this.minSwipeDistance = 50;
this.transitionTimingFunction = 'ease';
this.counterSeparator = " / ";
this.overflowCellsLimit = 3;
this.listeners = 'mouse and touch';
this.arrows = true;
this.arrowsTheme = 'light';
this.hostClassCarousel = true;
/* Touchstart */
this.handleTouchstart = function (event) {
event.preventDefault();
_this.carousel.handleTouchstart(event);
_this.isMoving = true;
_this.events.emit({
type: 'touchstart',
event: event
});
};
/* Touchmove */
this.handleHorizontalSwipe = function (event) {
event.preventDefault();
_this.carousel.handleHorizontalSwipe(event);
_this.events.emit({
type: 'swipe',
event: event
});
};
/* Touchend */
this.handleTouchend = function (event) {
var touches = event.touches;
_this.carousel.handleTouchend(event);
_this.isMoving = false;
_this.events.emit({
type: 'touchend',
event: event
});
};
/* Tap */
this.handleTap = function (event) {
var i = _this.carousel.slideCounter;
var cellIndex = _this.carousel.currentCellIndex;
var fileIndex = _this.carousel.getFileIndex(i);
var file = _this.carousel.getFile(cellIndex);
_this.events.emit({
type: 'click',
file: file,
index: fileIndex
});
};
}
Object.defineProperty(CarouselComponent.prototype, "isLandscape", {
get: function () {
return window.innerWidth > window.innerHeight;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "isSafari", {
get: function () {
var ua = navigator.userAgent.toLowerCase();
if (ua.indexOf('safari') !== -1) {
return !(ua.indexOf('chrome') > -1);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "counter", {
get: function () {
return this.carousel.slideCounter + 1 + this.counterSeparator + this.images.length;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "images", {
get: function () {
return this._images;
},
set: function (images) {
this._images = images;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "isNgContent", {
get: function () {
return this.elementRef.nativeElement.querySelector('.carousel-content-wrapper').children.length > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "transitionDuration", {
get: function () {
if (this._transitionDuration === 0) {
return 1;
}
else {
return this._transitionDuration;
}
},
set: function (value) {
this._transitionDuration = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "cellWidth", {
set: function (value) {
if (value) {
this._cellWidth = value;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "isCounter", {
get: function () {
return this._isCounter && this.images.length > 1;
},
set: function (value) {
if (value) {
this._isCounter = value;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "overlayProperties", {
set: function (properties) {
this._properties = properties;
this._images = this._properties.metadata.images;
this._cellWidth = this._properties.metadata.width;
this.height = this._properties.metadata.height;
this.objectFit = this._properties.metadata.objectFit;
this.margin = this._properties.metadata.margin;
this.transitionDuration = this._properties.metadata.transitionDuration;
this.overflowCellsLimit = this._properties.metadata.overflowCellsLimit;
this.minSwipeDistance = this._properties.metadata.minSwipeDistance;
this.transitionTimingFunction = this._properties.metadata.transitionTimingFunction;
this._isCounter = this._properties.metadata.counter;
this.counterSeparator = this._properties.metadata.counterSeparator;
this.arrows = this._properties.metadata.arrows;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "properties", {
get: function () {
return this._properties;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CarouselComponent.prototype, "cellLimit", {
get: function () {
if (this.carousel) {
return this.carousel.cellLimit;
}
},
enumerable: true,
configurable: true
});
CarouselComponent.prototype.onWindowResize = function (event) {
this.landscapeMode = this.isLandscape;
this.ref.detectChanges();
this.initCarousel();
this.carousel.lineUpCells();
};
CarouselComponent.prototype.ngOnInit = function () {
this.touches = new Touches({
element: this.elementRef.nativeElement.querySelector('.carousel-cells'),
listeners: this.listeners
});
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.touches.on('tap', this.handleTap);
this.initCarousel();
this.setDimensions();
this.setInitialIndex();
};
CarouselComponent.prototype.ngAfterViewInit = function () {
this.carousel.lineUpCells();
};
CarouselComponent.prototype.ngOnChanges = function (changes) {
if (changes.width || changes.height) {
this.setDimensions();
this.initCarousel();
this.carousel.lineUpCells();
}
};
CarouselComponent.prototype.ngOnDestroy = function () {
this.touches.destroy();
};
CarouselComponent.prototype.initCarousel = function () {
this.carousel = new Carousel({
element: this.elementRef.nativeElement.querySelector('.carousel-cells'),
container: this.elementRef.nativeElement,
images: this.images,
cellWidth: this.getCellWidth(),
overflowCellsLimit: this.overflowCellsLimit,
visibleWidth: this.width,
margin: this.margin,
minSwipeDistance: this.minSwipeDistance,
transitionDuration: this.transitionDuration,
transitionTimingFunction: this.transitionTimingFunction,
videoProperties: this.videoProperties
});
};
CarouselComponent.prototype.setDimensions = function () {
this.hostStyleHeight = this.height + 'px';
this.hostStyleWidth = this.width + 'px';
};
CarouselComponent.prototype.getFile = function (index) {
return this.carousel.getFile(index);
};
CarouselComponent.prototype.handleTransitionendCellContainer = function (event) {
this.carousel.handleSlideEnd();
};
CarouselComponent.prototype.toggleVideo = function (video) {
event.preventDefault();
if (this.videoProperties.noPlay) {
return;
}
if (video.paused) {
video.play();
this.isVideoPlaying = true;
}
else {
video.pause();
this.isVideoPlaying = false;
}
this.ref.detectChanges();
};
CarouselComponent.prototype.getCurrentIndex = function () {
return this.carousel.slideCounter;
};
CarouselComponent.prototype.getCellWidth = function () {
if (this._cellWidth === '100%') {
return this.elementRef.nativeElement.clientWidth;
}
else {
return this._cellWidth;
}
};
CarouselComponent.prototype.next = function () {
this.carousel.next(1);
};
CarouselComponent.prototype.prev = function () {
this.carousel.prev(1);
};
CarouselComponent.prototype.select = function (index) {
this.carousel.select(index);
};
CarouselComponent.prototype.isNextArrowDisabled = function () {
return this.carousel.isNextArrowDisabled();
};
CarouselComponent.prototype.isPrevArrowDisabled = function () {
return this.carousel.isPrevArrowDisabled();
};
CarouselComponent.prototype.close = function () {
this.overlayEventService.emitChangeEvent({
type: 'Hide'
});
};
CarouselComponent.prototype.setInitialIndex = function () {
if (this._properties.metadata.index != undefined) {
this.select(this._properties.metadata.index);
}
};
CarouselComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: ChangeDetectorRef },
{ type: OverlayEventService }
]; };
__decorate([
Input()
], CarouselComponent.prototype, "images", null);
__decorate([
Output()
], CarouselComponent.prototype, "events", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "height", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "width", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "borderRadius", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "margin", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "objectFit", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "minSwipeDistance", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "transitionDuration", null);
__decorate([
Input()
], CarouselComponent.prototype, "transitionTimingFunction", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "videoProperties", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "counterSeparator", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "overflowCellsLimit", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "listeners", void 0);
__decorate([
Input('cellWidth')
], CarouselComponent.prototype, "cellWidth", null);
__decorate([
Input('counter')
], CarouselComponent.prototype, "isCounter", null);
__decorate([
Input()
], CarouselComponent.prototype, "arrows", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "arrowsOutside", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "arrowsTheme", void 0);
__decorate([
Input()
], CarouselComponent.prototype, "overlayProperties", null);
__decorate([
HostBinding('class.carousel')
], CarouselComponent.prototype, "hostClassCarousel", void 0);
__decorate([
HostBinding('style.height')
], CarouselComponent.prototype, "hostStyleHeight", void 0);
__decorate([
HostBinding('style.width')
], CarouselComponent.prototype, "hostStyleWidth", void 0);
__decorate([
HostListener('window:resize', ['$event'])
], CarouselComponent.prototype, "onWindowResize", null);
CarouselComponent = __decorate([
Component({
selector: 'carousel, [carousel]',
exportAs: 'carousel',
template: "<div class=\"carousel-backdrop\"></div>\n\n<div class=\"carousel-close\" (click)=\"close()\"></div>\n\n<div class=\"carousel-counter\" *ngIf=\"isCounter\">{{counter}}</div>\n\n<div class=\"carousel-container\" [class.carousel-moving]=\"isMoving\">\n\t<div class=\"carousel-cells\" (transitionend)=\"handleTransitionendCellContainer($event)\">\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\t\t\t\t<!-- Image -->\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<!-- Video -->\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</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{position:relative;display:block;top:0;left:0;width:100%;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:10000;transform-origin:top left;box-sizing:border-box}:host .carousel-container{overflow:hidden;width:100%;height:100%;cursor:-webkit-grab;cursor:grab}:host .carousel-container.carousel-moving{cursor:-webkit-grabbing;cursor:grabbing}:host .carousel-counter{text-align:right;position:absolute;z-index:30;transition:opacity .2s;top:15px;left:10px;border-radius:13px;background-color:rgba(23,37,68,.3);font-size:13px;color:#fff;padding:5px 7px;line-height:initial}:host .carousel-cells{transition:transform .2s;width:100%;height:100%;display:block}:host .carousel-cells ::ng-deep .carousel-cell.swiper-prev-image{transform:translate3d(-100%,0,0)}:host .carousel-cells ::ng-deep .carousel-cell.swiper-next-image{transform:translate3d(100%,0,0)}:host .carousel-cells ::ng-deep .carousel-cell{width:100%;height:100%;text-align:center;position:absolute;display:flex;align-items:center;justify-content:center;overflow:hidden}:host .carousel-cells ::ng-deep .carousel-cell img,:host .carousel-cells ::ng-deep .carousel-cell video{width:100%;height:100%;position:relative;-o-object-fit:contain;object-fit:contain}:host .carousel-cells ::ng-deep .carousel-cell img.swiper-hide{display:none}:host .carousel-cells ::ng-deep .carousel-cell .carousel-play{position:absolute;top:0;left:0;bottom:0;right:0;z-index:1}:host .carousel-arrow{width:40px;height:40px;background-color:#fff;background-repeat:no-repeat;background-size:31px;background-position:center;border-radius:100px;position:absolute;top:50%;margin-top:-20px;z-index:10;cursor:pointer;box-shadow:0 0 5px rgba(0,0,0,.15)}:host .carousel-arrow-prev{left:10px;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNMTUuNDEgMTYuNTlMMTAuODMgMTJsNC41OC00LjU5TDE0IDZsLTYgNiA2IDYgMS40MS0xLjQxeiIvPjxwYXRoIGQ9Ik0wIDBoMjR2MjRIMFYweiIgZmlsbD0ibm9uZSIvPjwvc3ZnPg==)}:host .carousel-arrow-next{right:10px;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNOC41OSAxNi41OUwxMy4xNyAxMiA4LjU5IDcuNDEgMTAgNmw2IDYtNiA2LTEuNDEtMS40MXoiLz48cGF0aCBkPSJNMCAwaDI0djI0SDBWMHoiIGZpbGw9Im5vbmUiLz48L3N2Zz4=)}:host .carousel-arrows-outside .carousel-arrow-prev{left:-60px}:host .carousel-arrows-outside .carousel-arrow-next{right:-60px}:host .carousel-dark-arrows .carousel-arrow{-webkit-filter:invert(1);filter:invert(1)}:host .carousel-arrow-disabled{cursor:default;opacity:.5}:host .carousel-close{position:fixed;top:10px;right:10px;width:40px;height:40px;z-index:100;cursor:pointer;background-repeat:no-repeat;background-size:31px;background-position:center;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjI0Ij48cGF0aCBkPSJNMTkgNi40MUwxNy41OSA1IDEyIDEwLjU5IDYuNDEgNSA1IDYuNDEgMTAuNTkgMTIgNSAxNy41OSA2LjQxIDE5IDEyIDEzLjQxIDE3LjU5IDE5IDE5IDE3LjU5IDEzLjQxIDEyeiIvPjxwYXRoIGQ9Ik0wIDBoMjR2MjRIMHoiIGZpbGw9Im5vbmUiLz48L3N2Zz4=);-webkit-filter:invert(1);filter:invert(1)}:host .carousel-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000;opacity:.5}"]
})
], CarouselComponent);
return CarouselComponent;
}());
export { CarouselComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"ng://angular-gallery/","sources":["lib/carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, OnDestroy, SimpleChanges} from '@angular/core';\n\nimport {Images} from './interfaces';\nimport {Touches} from './touches';\nimport {Carousel} from './carousel';\nimport {OverlayProperties} from './overlay/interfaces';\nimport {EventService as OverlayEventService} from './overlay/event.service'; \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    _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    _properties: OverlayProperties;\n    _transitionDuration: number = 200;\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        return this.carousel.slideCounter + 1 + this.counterSeparator + this.images.length;\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    get isNgContent(){\n        return this.elementRef.nativeElement.querySelector('.carousel-content-wrapper').children.length > 0;\n    }\n\n    @Output() events: EventEmitter<any> = new EventEmitter<any>();\n\n    @Input() height: number = 200;\n    @Input() width: number;\n    @Input() borderRadius: number;\n    @Input() margin: number = 10;\n    @Input() objectFit: 'contain' | 'cover' | 'none' = 'cover';\n    @Input() minSwipeDistance: number = 50;\n\n    @Input()\n    set transitionDuration(value: number) {\n        this._transitionDuration = value;\n    }\n    get transitionDuration(){\n        if (this._transitionDuration === 0) {\n            return 1;\n        } else {\n            return this._transitionDuration;\n        }\n    }\n\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\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.images.length > 1;\n    }\n\n    @Input() arrows: boolean = true;\n    @Input() arrowsOutside: boolean;\n    @Input() arrowsTheme: 'light' | 'dark' = 'light';\n\n    @Input() set overlayProperties (properties: OverlayProperties) {\n        this._properties = properties;\n        this._images = this._properties.metadata.images;\n        this._cellWidth = this._properties.metadata.width;\n        this.height = this._properties.metadata.height;\n        this.objectFit = this._properties.metadata.objectFit;\n        this.margin = this._properties.metadata.margin;\n        this.transitionDuration = this._properties.metadata.transitionDuration;\n        this.overflowCellsLimit = this._properties.metadata.overflowCellsLimit;\n        this.minSwipeDistance = this._properties.metadata.minSwipeDistance;\n        this.transitionTimingFunction = this._properties.metadata.transitionTimingFunction;\n        this._isCounter = this._properties.metadata.counter;\n        this.counterSeparator = this._properties.metadata.counterSeparator;\n        this.arrows = this._properties.metadata.arrows;\n    }\n\n    get properties() {\n        return this._properties;\n    }\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    constructor(\n        private elementRef: ElementRef, \n        private ref: ChangeDetectorRef,\n        private overlayEventService: OverlayEventService){\n    }\n\n    ngOnInit(){\n        this.touches = new Touches({\n            element: this.elementRef.nativeElement.querySelector('.carousel-cells'),\n            listeners: this.listeners\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        this.touches.on('tap', this.handleTap);\n\n        this.initCarousel();\n        this.setDimensions();\n        this.setInitialIndex();\n    }\n\n    ngAfterViewInit() {\n        this.carousel.lineUpCells();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes.width || changes.height) {\n            this.setDimensions();\n            this.initCarousel();\n            this.carousel.lineUpCells();\n        }\n    }\n\n    ngOnDestroy() {\n        this.touches.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            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    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.carousel.handleTouchstart(event);\n        this.isMoving = true;\n        this.events.emit({\n            type: 'touchstart',\n            event\n        });\n    }\n\n    /* Touchmove */\n    handleHorizontalSwipe = (event: any) => {\n        event.preventDefault();\n        this.carousel.handleHorizontalSwipe(event);\n        this.events.emit({\n            type: 'swipe',\n            event\n        });\n    }\n\n    /* Touchend */\n    handleTouchend = (event: any) => {\n        const touches = event.touches;\n        this.carousel.handleTouchend(event);\n        this.isMoving = false;\n        this.events.emit({\n            type: 'touchend',\n            event\n        });\n    }\n\n    /* Tap */\n    handleTap = (event: any) => {\n        const i = this.carousel.slideCounter;\n        const cellIndex = this.carousel.currentCellIndex;\n        const fileIndex = this.carousel.getFileIndex(i);\n        const file = this.carousel.getFile(cellIndex);\n\n        this.events.emit({\n            type: 'click',\n            file: file,\n            index: fileIndex\n        });\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(): number {\n        if (this._cellWidth === '100%') {\n            return this.elementRef.nativeElement.clientWidth;\n        } else {\n            return this._cellWidth;\n        }\n    }\n\n    next() {\n        this.carousel.next(1);\n    }\n\n    prev() {\n        this.carousel.prev(1);\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    close() {\n        this.overlayEventService.emitChangeEvent({\n            type: 'Hide'\n        });\n    }\n\n    setInitialIndex() {\n        if (this._properties.metadata.index != undefined) {\n            this.select(this._properties.metadata.index);\n        }\n    }\n}"]}