UNPKG

@crystalui/angular-lightbox

Version:

Angular library for viewing images in a pop-up window with touch screen support.

431 lines 55.5 kB
import { __decorate, __extends } from "tslib"; import { Component, Input, EventEmitter, OnInit, HostBinding, HostListener, ViewChild, ViewChildren, ElementRef, ChangeDetectorRef, ContentChildren, QueryList } from '@angular/core'; import { EventService } from './event.service'; import { LightboxCommonComponent } from './lightbox-common.component'; var LightboxComponent = /** @class */ (function (_super) { __extends(LightboxComponent, _super); function LightboxComponent(elementRef, ref, eventService) { var _this = _super.call(this, eventService) || this; _this.elementRef = elementRef; _this.ref = ref; _this.eventService = eventService; _this.spinnerHeight = 30; _this.minTimeout = 30; _this.preloaderTimeout = 100; _this.spinnerStyles = { transform: '' }; _this.configThumbnailPreloader = true; _this.events = new EventEmitter(); _this.hostShown = false; _this.hideControls = false; return _this; } Object.defineProperty(LightboxComponent.prototype, "simpleMode", { get: function () { return this.properties.simpleMode; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "hostLightTheme", { get: function () { return this.properties.backgroundColor === 'white'; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "currImagePath", { get: function () { var image = this.images[this.index]; var path; if (!image) { return false; } if (image.fullImage && image.fullImage.path) { path = image.fullImage.path; } else if (image.thumbnailImage && image.thumbnailImage.path) { path = image.thumbnailImage.path; } else if (image.path) { path = image.path; } return path; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "prevImagePath", { get: function () { return this.images[this.prevIndex]; }, set: function (value) { this.images[this.prevIndex] = value; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "isHiddenPrevArrow", { get: function () { return this.isFirstImage && !this.properties.loop || this.isZoomIn; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "isHiddenNextArrow", { get: function () { return this.isLastImage && !this.properties.loop || this.isZoomIn; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "isPreloader", { get: function () { return this.animationMode === 'zoom-preloader' && this.showState != 'animation-end' && this.currImageLoadingState === 'loading'; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxComponent.prototype, "imageOrientation", { get: function () { if (this.thumbnailImage.naturalWidth > this.thumbnailImage.naturalHeight) { return 'horizontal'; } else { return 'vertical'; } }, enumerable: true, configurable: true }); LightboxComponent.prototype.scrolling = function () { if (this.showState === 'initial-thumbnail-image' || this.showState === 'initial-virtual-image' || this.closingState === 'animation') { this.updateThumbnailPosition(); } }; LightboxComponent.prototype.onKeyDown = function (event) { switch (event.key) { case 'ArrowLeft': this.prev(); break; case 'ArrowRight': this.next(); break; case 'Escape': this.closeLightbox(); break; } }; LightboxComponent.prototype.onMouseEnter = function (event) { this.hideControls = false; }; LightboxComponent.prototype.transitionEnd = function (event) { if (event.propertyName === "transform" && this.hostAnimation) { this.hostAnimation = false; } }; LightboxComponent.prototype.ngOnInit = function () { this.currentImageIndex = this.properties.index; this.initialLightbox(); }; LightboxComponent.prototype.ngAfterViewInit = function () { var _this = this; setTimeout(function () { if (_this.currImageLoadingState === 'not-loaded') { _this.currImageLoadingState = 'loading'; } }, this.preloaderTimeout); // Mode: default if (this.animationMode === 'default') { setTimeout(function () { _this.showLightboxAnimation(); }, this.minTimeout); } }; LightboxComponent.prototype.onImageLoaded = function () { var _this = this; // When opening lightbox if (this.animationMode === 'zoom-preloader' && this.showState === 'initial-thumbnail-image') { this.initialLightboxVirtualImage(); setTimeout(function () { _this.currImageLoadingState = 'uploaded'; _this.showLightboxAnimation(); if (_this.properties.hideThumbnail) { _this.hideThumbnailImage(); } }, this.minTimeout); } // When opening next / previous image if (this.showState === 'animation-end') { this.currImageLoadingState = 'uploaded'; if (this.properties.hideThumbnail) { this.hideThumbnailImage(); } } this.ref.detectChanges(); }; LightboxComponent.prototype.onImageError = function (event) { var _this = this; this.currImageLoadingState = 'error'; this.initialLightboxDefault(); setTimeout(function () { _this.showLightboxAnimation(); }, this.minTimeout); }; LightboxComponent.prototype.onContainerClick = function (event) { if (event.target === this.lightboxContainerElem.nativeElement || this.simpleMode) { this.closeLightbox(); } }; LightboxComponent.prototype.initialLightbox = function () { this.setMaxDimensions(); this.setAnimationDuration(); switch (this.animationMode) { case 'zoom-preloader': this.initialLightboxThumbnailImage(); break; case 'default': this.initialLightboxDefault(); break; } }; LightboxComponent.prototype.initialLightboxDefault = function () { this.showState = 'initial-default'; this.containerStyles = { transform: 'translate3d(0, 0, 0)', height: '100%', width: '100%', opacity: '0' }; // next step: AfterViewInit }; LightboxComponent.prototype.initialLightboxVirtualImage = function () { this.setShowState('initial-virtual-image'); this.containerStyles = { transform: this.containerInitialPosition, height: this.virtualImageDimension.height + 'px', width: this.virtualImageDimension.width + 'px' }; // next step: onImageLoaded() -> showLightboxAnimation() }; LightboxComponent.prototype.initialLightboxThumbnailImage = function () { this.setShowState('initial-thumbnail-image'); this.containerStyles = { transform: this.containerInitialPosition, height: this.thumbnailImagePosition.height + 'px', width: this.thumbnailImagePosition.width + 'px' }; // next step: onImageLoaded() }; LightboxComponent.prototype.showLightboxAnimation = function () { this.hostAnimation = true; this.setShowState('animation'); this.hostShown = true; this.setBackgroundColor(); this.setAnimationDuration(); // Mode: zoom preloader if (this.animationMode === 'zoom-preloader' && this.currImageLoadingState !== 'error') { this.containerStyles.transform = this.containerFullscreenPosition; } // Mode: default if (this.animationMode === 'default') { this.containerStyles.opacity = '1'; } // next step: handleLightboxTransitionEnd }; LightboxComponent.prototype.showLightboxAnimationEnd = function () { this.setShowState('animation-end'); this.containerStyles = { transform: 'translate3d(0, 0, 0)', height: '100%', width: '100%', }; }; LightboxComponent.prototype.closeLightbox = function () { this.setClosingState('initial'); this.hostShown = false; this.closeLightboxInitial(); }; LightboxComponent.prototype.closeLightboxInitial = function () { var _this = this; this.setClosingState('initial-styles'); // Mode: zoom preloader if (this.animationMode === 'zoom-preloader') { this.containerStyles = { transform: this.containerFullscreenPosition, height: this.virtualImageDimension.height + 'px', width: this.virtualImageDimension.width + 'px', }; } // Mode: default if (this.animationMode === 'default') { this.containerStyles.opacity = '1'; } setTimeout(function () { _this.closeLightboxAnimation(); }, this.minTimeout); }; LightboxComponent.prototype.closeLightboxAnimation = function () { this.setClosingState('animation'); // Mode: zoom preloader if (this.animationMode === 'zoom-preloader') { this.hostAnimation = true; this.containerStyles = { transform: this.containerInitialPosition, height: this.getContainerHeight(), width: this.getContainerWidth(), }; this.hostStyleBackgroundColor = ''; } // Mode: default if (this.animationMode === 'default') { this.hostAnimation = true; this.containerStyles.opacity = '0'; this.hostStyleBackgroundColor = ''; } this.setAnimationDuration(); // next step: handleLightboxTransitionEnd if (this.animationDuration === 0) { // in the future, change to a type conversion getter this.closeLightboxAnimationEnd(); } }; LightboxComponent.prototype.closeLightboxAnimationEnd = function () { this.setClosingState('animation-end'); this.events.emit({ type: 'close' }); // Mode: zoom preloader if (this.animationMode === 'zoom-preloader') { this.showThumbnailImage(); } }; /* * Transition End */ LightboxComponent.prototype.handleLightboxTransitionEnd = function (event) { if (this.showState === 'animation') { this.showLightboxAnimationEnd(); } // Last close step if (this.closingState === 'animation') { this.closeLightboxAnimationEnd(); } }; LightboxComponent.prototype.next = function () { var _this = this; if (this.animationMode === 'zoom-preloader') { this.showThumbnailImage(); } if (this.isLastImage) { if (this.properties.loop) { this.currentImageIndex = 0; } else { return; } } else { this.currentImageIndex++; this.currImageLoadingState = 'loading'; } setTimeout(function () { if (_this.currImageLoadingState !== 'uploaded') { _this.currImageLoadingState = 'loading'; } }, this.preloaderTimeout); }; LightboxComponent.prototype.prev = function () { var _this = this; if (this.animationMode === 'zoom-preloader') { this.showThumbnailImage(); } if (this.isFirstImage) { if (this.properties.loop) { this.currentImageIndex = this.latestImageIndex; } else { return; } } else { this.currentImageIndex--; this.currImageLoadingState = 'loading'; } setTimeout(function () { if (_this.currImageLoadingState !== 'uploaded') { _this.currImageLoadingState = 'loading'; } }, this.preloaderTimeout); }; LightboxComponent.prototype.setMaxDimensions = function () { this.lightboxImage.nativeElement.style.maxHeight = 'calc(' + this.properties.imageMaxHeight + ')'; this.lightboxImage.nativeElement.style.maxWidth = this.properties.imageMaxWidth; }; LightboxComponent.prototype.handlePinchZoomEvents = function (event) { if (event.type === "zoom-in") { this.isZoomIn = true; } if (event.type === "zoom-out") { this.isZoomIn = false; } }; LightboxComponent.prototype.getContainerWidth = function () { return this.thumbnailImagePosition.width / this.containerScale + 'px'; }; LightboxComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: ChangeDetectorRef }, { type: EventService } ]; }; __decorate([ HostBinding('class.lightbox-shown') ], LightboxComponent.prototype, "hostShown", void 0); __decorate([ HostBinding('class.lightbox-hide-controls') ], LightboxComponent.prototype, "hideControls", void 0); __decorate([ HostBinding('class.lightbox-animation') ], LightboxComponent.prototype, "hostAnimation", void 0); __decorate([ HostBinding('class.lightbox-simple-mode') ], LightboxComponent.prototype, "simpleMode", null); __decorate([ HostBinding('class.lightbox-light') ], LightboxComponent.prototype, "hostLightTheme", null); __decorate([ HostBinding('style.backgroundColor') ], LightboxComponent.prototype, "hostStyleBackgroundColor", void 0); __decorate([ ViewChild('prevImageElem', { static: true }) ], LightboxComponent.prototype, "prevImageElem", void 0); __decorate([ ViewChild('lightboxContainer', { static: true }) ], LightboxComponent.prototype, "lightboxContainerElem", void 0); __decorate([ HostListener('window:scroll') ], LightboxComponent.prototype, "scrolling", null); __decorate([ HostListener('window:keydown', ['$event']) ], LightboxComponent.prototype, "onKeyDown", null); __decorate([ HostListener("mouseenter", ['$event']) ], LightboxComponent.prototype, "onMouseEnter", null); __decorate([ HostListener('transitionend', ['$event']) ], LightboxComponent.prototype, "transitionEnd", null); LightboxComponent = __decorate([ Component({ selector: 'crystal-lightbox', template: "<div class=\"lightbox-counter\" *ngIf=\"properties.counter && images.length > 1\">{{counter}}</div>\n<div class=\"lightbox-close\" *ngIf=\"!simpleMode\" (click)=\"closeLightbox()\">{{closeButtonText}}</div>\n<div class=\"lightbox-spinner\" \n\t*ngIf=\"currImageLoadingState === 'loading' && showState === 'animation-end'\"></div>\n<div class=\"lightbox-container\" \n\t#lightboxContainer\n\t[ngStyle]=\"containerStyles\"\n\t(transitionend)=\"handleLightboxTransitionEnd($event)\"\n\t(click)=\"onContainerClick($event)\">\n\n\t<div class=\"lightbox-preloader\" *ngIf=\"isPreloader\">\n\t\t<div class=\"lightbox-spinner\"></div>\n\t</div>\n\n\t<div class=\"lightbox-error\" *ngIf=\"currImageLoadingState === 'error' && !closingState\">Failed to load image</div>\n\n\t<img class=\"lightbox-curr-image\" \n\t\t#lightboxImage\n\t\t[src]=\"currImagePath\" \n\t\t[class.lightbox-show]=\"currImageLoadingState === 'uploaded'\" \n\t\t(load)=\"onImageLoaded()\"\n\t\t(error)=\"onImageError($event)\" />\n</div>\n\n<div class=\"lightbox-prev\" [hidden]=\"isHiddenPrevArrow\" (click)=\"prev()\"></div>\n<div class=\"lightbox-next\" [hidden]=\"isHiddenNextArrow\" (click)=\"next()\"></div>", styles: [".lightbox-spinner,.lightbox-spinner:after,.lightbox-spinner:before{border-radius:50%;width:10px;height:10px;-webkit-animation:1.5s ease-in-out infinite lightbox-load;animation:1.5s ease-in-out infinite lightbox-load}.lightbox-spinner{color:#fff;font-size:10px;margin:0 auto 20px;position:relative;text-indent:-9999em;transform:translateZ(0);-webkit-animation-delay:-.16s;animation-delay:-.16s}.lightbox-spinner:after,.lightbox-spinner:before{content:\"\";position:absolute;top:0}.lightbox-spinner:before{left:-32px;-webkit-animation-delay:-.32s;animation-delay:-.32s}.lightbox-spinner:after{left:32px}@-webkit-keyframes lightbox-load{0%,100%,80%{box-shadow:0 2.5em 0 -1.3em}40%{box-shadow:0 2.5em 0 0}}@keyframes lightbox-load{0%,100%,80%{box-shadow:0 10px 0 -1.3em}40%{box-shadow:0 10px 0 0}}:host.lightbox-shown{opacity:1}:host.lightbox-shown .lightbox-close,:host.lightbox-shown .lightbox-next,:host.lightbox-shown .lightbox-prev{opacity:.5;transition-delay:.1s}:host.lightbox-shown .lightbox-close:hover,:host.lightbox-shown .lightbox-next:hover,:host.lightbox-shown .lightbox-prev:hover{opacity:1;transition-delay:0}:host.lightbox-shown .lightbox-counter{opacity:1}:host.lightbox-hide-controls .lightbox-close,:host.lightbox-hide-controls .lightbox-next,:host.lightbox-hide-controls .lightbox-prev{opacity:0}:host.lightbox-simple-mode .lightbox-container{cursor:zoom-out}:host:not(.lightbox-animation) .lightbox-container{display:flex;align-items:center;justify-content:center;top:0;left:0;height:100%}:host.lightbox-light{color:#000;text-shadow:none}:host{position:fixed;top:0;left:0;width:100%;height:100%;color:#fff;text-shadow:0 0 1px rgba(0,0,0,.65);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:10000}:host img{opacity:1;max-width:100%;max-height:100%}:host img.lightbox-curr-image.lightbox-show{opacity:1}:host img.lightbox-curr-image{opacity:0;z-index:10}:host .lightbox-container.lightbox-hide{display:none}:host .lightbox-container{position:absolute;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;transform-origin:top left}:host .lightbox-preloader{background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:absolute}:host .lightbox-spinner{position:absolute;top:51%;left:50%;margin-top:-15px;margin-left:-5px}:host .lightbox-preloader .lightbox-spinner{margin-top:-9px;margin-left:-3px}:host .lightbox-preloader .lightbox-spinner,:host .lightbox-preloader .lightbox-spinner:after,:host .lightbox-preloader .lightbox-spinner:before{width:6px;height:6px}:host .lightbox-preloader .lightbox-spinner:before{left:-21px}:host .lightbox-preloader .lightbox-spinner:after{left:21px}:host .lightbox-counter{text-align:left;position:absolute;left:22px;top:13px;font-size:14px;z-index:30}:host .lightbox-description{text-align:center;max-width:calc(100% - 200px);margin:0 auto;font-size:14px;line-height:43px;position:relative;z-index:50}:host .lightbox-error{color:rgba(255,255,255,.75);font-size:19px}:host .lightbox-close{position:absolute;top:0;right:0;padding:13px 22px;font-size:13px;text-transform:uppercase;cursor:pointer;opacity:.5;z-index:30;transition:opacity .1s ease-in-out}:host .lightbox-next,:host .lightbox-prev{width:100px;height:100%;position:absolute;top:0;cursor:pointer;opacity:.5;z-index:20;transition:opacity .1s ease-in-out;-webkit-tap-highlight-color:rgba(255,255,255,0)}:host .lightbox-prev{left:0;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAiCAYAAABbXymAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTM4IDc5LjE1OTgyNCwgMjAxNi8wOS8xNC0wMTowOTowMSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTcgKFdpbmRvd3MpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjMzMTZCQzFERDgzMTExRTc5QUYxQTUxRDI5MkM5ODZCIiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjMzMTZCQzFFRDgzMTExRTc5QUYxQTUxRDI5MkM5ODZCIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6MzMxNkJDMUJEODMxMTFFNzlBRjFBNTFEMjkyQzk4NkIiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6MzMxNkJDMUNEODMxMTFFNzlBRjFBNTFEMjkyQzk4NkIiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz7VrwZKAAAClElEQVR42qzWSY8SQRgGYLoVHPeTXlwCiIwMArJGtiABNep4IGZi4oEfMJooLjePrnFGf5yJS0hYmq2b/aBxiQ6+lRRJdaUZq5vp5E2TLnioVFd9VZLN+iUxIdeMiW2fRVCmvz2DpJBVCk6X6SVBHQRLpVKb7Xb782g0Usrl8jM8W0P20+9YQn3JZPIhwN6MXoPBoI3nG8iKGZhF14A+AqrOmKtWq31F213kkOgQ69B0Ol0BqrFot9vV/H7/c7RfEoVZ1G+EdjqdvtfrfYn2K8gJkaHQodlstjIej/ssihdH0Ddov4acQo7QlycJo5PJhEc1j8fzmqJk2h1D7Lv1lkUv5nK5xzzaarWMUIcwms/nCTrgUbfbTdCrVtAAQafTqQ5VFEVdCi0UCk/Q0yGLNptN1el0vqLoaRHUxqPoKY/2KFo0g0r0ba4Wi8WnQEcs2mg0VAPULrJsZTqpNzDZ6yxar9dVl8tFVtR10SnFohJdgnZYuh9IkjSTZfknPn5DviO/kL/IjkgtIOhhJJ7JZF5gdU24hdDG6qqg/QJywEzlmg/FSTLhE4nE9nA4nHJFRvH5fJto94gOBfvyjtJxXI/H4x+A63re6/UUVDCCnzeDz6fbceQscjsWi703wFsM7hDBJQN8PRqNbmNn0OGapu0JfoviYx4PBAL30e5dCg+Hw0Z4e8/wfr/P451QKPRgaRzIFjDdksefsbjdKn5zER6JRMiwuP+3Ne2KB4PBLVVVR1xd+YK2O2bOFYvwd8CHbK/x/J6Zc8Ui/AZmxdtqtdrAwlFLpRLZrS/PYcnkEUuiY7hCS+g5sovT55+Qj7QS/jYD8zjp/UF6t9GS+oPed8zCLC5zJ0tSo//Q+8wKLHTw/ifAAMQVS4vHZR2VAAAAAElFTkSuQmCC) center left 22px no-repeat}:host .lightbox-next{right:0;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAiCAYAAABbXymAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTM4IDc5LjE1OTgyNCwgMjAxNi8wOS8xNC0wMTowOTowMSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTcgKFdpbmRvd3MpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjEyNDE3MDE1RDgzMTExRTc5NjM4QTIzQzI2Rjc2Qjg2IiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjEyNDE3MDE2RDgzMTExRTc5NjM4QTIzQzI2Rjc2Qjg2Ij4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6MTI0MTcwMTNEODMxMTFFNzk2MzhBMjNDMjZGNzZCODYiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6MTI0MTcwMTREODMxMTFFNzk2MzhBMjNDMjZGNzZCODYiLz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz7zv5BKAAACl0lEQVR42rTW224SQRwGcHZb8FT1Sm88BJCiFAE5JpyCBNRE8coYEy94AGqi9XDXS0+JVh/CB/EhiFET5LjAclgWjaa1aazfJDM6u6LuLjrJl2124cd0duY/I9h+NoELabtcTLcFCon0bw+SRE4h28hn2xyNoIvISrlcfqAoSluSpLepVKqCe6cRB/2MYAXei1wfjUbSLm34gX4ymbyN+z6rOBmC/ciNer3+fpdrwGXgd8h/YwVn8Dm/37/e6/UGOnyQTqfXrOBsKI4g571e76Nutzv8De43gwv05S0hx5CLwJ/iBWrwyWQyzGazpnHyITtyCDlBcI/H8wS4ZlhUVbWMO/R4p9P5Bc/lcnfx/Ow8+AW32z0LH+Xz+X+Dt9ttmcen0ynDA1bx4wR3Op2PW62WrOv5uFAo3JsXL1K8r+v5LNxmZrb8wJvNpn5YlGKxeJ/WFruZBcRPxUsul2u90WhocCyqBqk3dLGJiwbgb/T6FflCSqkoiluCIGjqNGzWgQUz9YR8aQ9yBqtyDQtH0q1KNZPJPMTzOHKA4oaHwuPz+SooUm0eHY/H00QisUEWFHKUDYVRdBmVr9Lv9/WoGo/HX+J5iY7/QSMvj003hnb0aCwWe4HnV5GTyGEj002DDgYDDYqdRo1Goxu0p3pU+BvqDQQCqzPQCUWvzINKejQcDltHQ6HQLaBdHh0Oh5ZRO0OBaFD8iIL7z82ibGtyRyKR1T+gl82g/GZ6Dev/HY/KsqwEg0FLKL/93+R7C3QM9Nk8KDtiOWq12jb2s2XS01Kp9Kparb7G/TfIR2QT2TF6UBS42bBEi/UK/SIBPyCfkC0zKA+z6rWPXm30tLlJr6ZQ/ZmYDYnI1eEdejV9Thb+18H7uwADAOG/Wcm4x+knAAAAAElFTkSuQmCC) center right 22px no-repeat}:host .lightbox-close,:host .lightbox-counter,:host .lightbox-next,:host .lightbox-prev{opacity:0;transition:opacity 150ms cubic-bezier(.475,.105,.445,.945)}"] }) ], LightboxComponent); return LightboxComponent; }(LightboxCommonComponent)); export { LightboxComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightbox.component.js","sourceRoot":"ng://@crystalui/angular-lightbox/","sources":["lib/lightbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, EventEmitter, OnInit, HostBinding, HostListener, ViewChild, ViewChildren, ElementRef, ChangeDetectorRef, ContentChildren, QueryList } from '@angular/core';\nimport { LightboxData } from './interfaces';\nimport { ShowState, ClosingState } from './types';\nimport { EventService } from './event.service';\nimport { LightboxCommonComponent } from './lightbox-common.component';\n\n@Component({\n    selector: 'crystal-lightbox',\n    templateUrl: './lightbox.component.html',\n    styleUrls: ['./css/lightbox.component.sass']\n})\n\nexport class LightboxComponent extends LightboxCommonComponent {\n    prevIndex: number;\n    spinnerHeight: number = 30;\n    isZoomIn: boolean;\n    minTimeout: number = 30;\n    preloaderTimeout: number = 100;\n    spinnerStyles: any = {\n        transform: ''\n    };\n    configThumbnailPreloader = true;\n    events = new EventEmitter();\n\n    @HostBinding('class.lightbox-shown') hostShown: boolean = false;\n    @HostBinding('class.lightbox-hide-controls') hideControls: boolean = false;\n    @HostBinding('class.lightbox-animation') hostAnimation: boolean;\n    @HostBinding('class.lightbox-simple-mode')\n    get simpleMode(){\n        return this.properties.simpleMode;\n    }\n\n    @HostBinding('class.lightbox-light') get hostLightTheme(){\n        return this.properties.backgroundColor === 'white';\n    }\n\n    @HostBinding('style.backgroundColor') hostStyleBackgroundColor: string;\n\n    @ViewChild('prevImageElem', { static: true }) prevImageElem: ElementRef;\n    @ViewChild('lightboxContainer', { static: true }) lightboxContainerElem: ElementRef;\n\n    get currImagePath(){\n        let image = this.images[this.index];\n        let path;\n\n        if (!image){\n            return false;\n        }\n\n        if (image.fullImage && image.fullImage.path){\n            path =  image.fullImage.path;\n        } else if (image.thumbnailImage && image.thumbnailImage.path) {\n            path = image.thumbnailImage.path;\n        } else if (image.path){\n            path = image.path;\n        }\n\n        return path;\n    }\n\n    get prevImagePath(){\n        return this.images[this.prevIndex];\n    }\n\n    set prevImagePath(value: any){\n        this.images[this.prevIndex] = value;\n    }\n\n    get isHiddenPrevArrow(){\n        return this.isFirstImage && !this.properties.loop || this.isZoomIn;\n    }\n    get isHiddenNextArrow(){\n        return this.isLastImage && !this.properties.loop || this.isZoomIn;\n    }\n\n    get isPreloader(){\n        return this.animationMode === 'zoom-preloader' && \n           this.showState != 'animation-end' && \n           this.currImageLoadingState === 'loading';\n    }\n\n    get imageOrientation():'vertical' | 'horizontal' {\n        if (this.thumbnailImage.naturalWidth > this.thumbnailImage.naturalHeight){\n            return 'horizontal';\n        } else {\n            return 'vertical';\n        }\n    }\n\n    @HostListener('window:scroll') scrolling(){\n        if (this.showState === 'initial-thumbnail-image' ||\n            this.showState === 'initial-virtual-image' ||\n            this.closingState === 'animation'){\n            this.updateThumbnailPosition();\n        }\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    onKeyDown(event: any) {\n        switch(event.key) {\n            case 'ArrowLeft':\n                this.prev();\n                break;\n            case 'ArrowRight':\n                this.next();\n                break;\n            case 'Escape':\n                this.closeLightbox();\n                break;\n        }\n    }\n\n    @HostListener(\"mouseenter\", ['$event'])\n    onMouseEnter(event: any) {\n        this.hideControls = false;\n    }\n\n    @HostListener('transitionend', ['$event'])\n    transitionEnd(event) {\n        if (event.propertyName === \"transform\" && this.hostAnimation){\n            this.hostAnimation = false;\n        }\n    }\n\n    constructor(\n        private elementRef: ElementRef, \n        private ref: ChangeDetectorRef,\n        public eventService: EventService){\n        super(eventService);\n    }\n\n    ngOnInit(){\n        this.currentImageIndex = this.properties.index;\n        this.initialLightbox();\n    }\n\n    ngAfterViewInit() {\n        setTimeout(() => {\n            if (this.currImageLoadingState === 'not-loaded'){\n                this.currImageLoadingState = 'loading';\n            }\n        }, this.preloaderTimeout);\n\n        // Mode: default\n        if (this.animationMode === 'default'){ \n            setTimeout(() => {\n                this.showLightboxAnimation();\n            }, this.minTimeout);\n        }\n    }\n\n    onImageLoaded(){\n        // When opening lightbox\n        if (this.animationMode === 'zoom-preloader' && \n            this.showState === 'initial-thumbnail-image'){\n            this.initialLightboxVirtualImage();\n            setTimeout(() => {\n                this.currImageLoadingState = 'uploaded';\n                this.showLightboxAnimation();\n                if (this.properties.hideThumbnail){\n                    this.hideThumbnailImage();\n                }\n            }, this.minTimeout);\n        }\n\n        // When opening next / previous image\n        if (this.showState === 'animation-end'){\n            this.currImageLoadingState = 'uploaded';\n            if (this.properties.hideThumbnail){\n                this.hideThumbnailImage();\n            }\n        }\n\n        this.ref.detectChanges();\n    }\n\n    onImageError(event){\n        this.currImageLoadingState = 'error';\n        this.initialLightboxDefault();\n\n        setTimeout(() => {\n            this.showLightboxAnimation();\n        }, this.minTimeout);\n    }\n\n    onContainerClick(event){\n        if (event.target === this.lightboxContainerElem.nativeElement || this.simpleMode){\n            this.closeLightbox();\n        }\n    }\n\n    initialLightbox(){\n        this.setMaxDimensions();\n        this.setAnimationDuration();\n\n        switch (this.animationMode) {\n            case 'zoom-preloader':\n                this.initialLightboxThumbnailImage();\n                break;\n            case 'default':\n                this.initialLightboxDefault();\n                break;\n        }\n    }\n\n    initialLightboxDefault(){\n        this.showState = 'initial-default';\n        this.containerStyles = {\n            transform: 'translate3d(0, 0, 0)',\n            height: '100%',\n            width: '100%',\n            opacity: '0'\n        }\n        // next step: AfterViewInit\n    }\n\n    initialLightboxVirtualImage(){\n        this.setShowState('initial-virtual-image');\n        this.containerStyles = {\n            transform: this.containerInitialPosition,\n            height: this.virtualImageDimension.height + 'px',\n            width: this.virtualImageDimension.width + 'px'\n        }\n        // next step: onImageLoaded() -> showLightboxAnimation()\n    }\n\n    initialLightboxThumbnailImage(){\n        this.setShowState('initial-thumbnail-image');\n        this.containerStyles = {\n            transform: this.containerInitialPosition,\n            height: this.thumbnailImagePosition.height + 'px',\n            width: this.thumbnailImagePosition.width + 'px'\n        }\n        // next step: onImageLoaded()\n    }\n\n    showLightboxAnimation(){\n        this.hostAnimation = true;\n        this.setShowState('animation');\n        this.hostShown = true;\n        this.setBackgroundColor();\n        this.setAnimationDuration();\n        \n        // Mode: zoom preloader\n        if (this.animationMode === 'zoom-preloader' &&\n            this.currImageLoadingState !== 'error'){ \n            this.containerStyles.transform = this.containerFullscreenPosition;\n        } \n\n        // Mode: default\n        if (this.animationMode === 'default'){\n            this.containerStyles.opacity = '1';\n        }\n        // next step: handleLightboxTransitionEnd\n    }\n\n    showLightboxAnimationEnd(){\n        this.setShowState('animation-end');\n        this.containerStyles = {\n            transform: 'translate3d(0, 0, 0)',\n            height: '100%',\n            width: '100%',\n        }\n    }\n\n    closeLightbox(){\n        this.setClosingState('initial');\n        this.hostShown = false;\n        this.closeLightboxInitial()