UNPKG

@crystalui/angular-lightbox

Version:

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

331 lines 31.9 kB
import { __decorate } from "tslib"; import { Component, Input, HostBinding, ViewChild } from '@angular/core'; import { EventService } from './event.service'; import { Utils } from './utils'; var LightboxCommonComponent = /** @class */ (function () { function LightboxCommonComponent(eventService) { this.eventService = eventService; this.currentImageIndex = 0; this.indexCurrentSlide = 1; this.containerStyles = { transition: '', transform: '', width: '', height: '', opacity: '' }; this.currImageLoadingState = 'not-loaded'; this.isMobile = Utils.mobileCheck(); } Object.defineProperty(LightboxCommonComponent.prototype, "lightboxImage", { get: function () { return this._lightboxImage; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "lightboxImageElement", { get: function () { if (this.lightboxImage) { return this.lightboxImage.nativeElement; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "lightboxImageNaturalHeight", { get: function () { if (this.lightboxImageElement) { return this.lightboxImageElement.naturalHeight; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "lightboxImageNaturalWidth", { get: function () { if (this.lightboxImageElement) { return this.lightboxImageElement.naturalWidth; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "index", { get: function () { return this.currentImageIndex; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "properties", { get: function () { return this.lightboxData.properties; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "images", { get: function () { return this.lightboxData.images || [this.lightboxData.image]; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "thumbnailImage", { get: function () { return this.images[this.currentImageIndex].nativeElement; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "thumbnailImagePosition", { get: function () { return this.thumbnailImage.getBoundingClientRect(); }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "virtualImageDimension", { // Image size if it is larger than the window size get: function () { var height = this.lightboxImageNaturalHeight; var width = height * this.imageAspectRatio; var windowWidth = document.body.clientWidth; var windowHeight = window.innerHeight; if (this.isImageLargerWindow) { if (height > windowHeight) { height = windowHeight; width = height * this.imageAspectRatio; } if (width > windowWidth) { width = windowWidth; height = width / this.imageAspectRatio; } } else { width = this.lightboxImageNaturalWidth; height = this.lightboxImageNaturalHeight; } if (width === 0 || Number.parseInt(height) === 0) { return { width: 200, height: 200 }; } return { width: width, height: height }; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "containerInitialPosition", { get: function () { var scale = (this.showState === 'initial-thumbnail-image') ? 1 : this.containerScale; var top = this.thumbnailImagePosition.top; var left = this.thumbnailImagePosition.left; return 'matrix(' + scale + ', 0, 0, ' + scale + ',' + left + ',' + top + ')'; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "containerFullscreenPosition", { get: function () { var left = (document.body.clientWidth - this.virtualImageDimension.width) / 2; var top = (window.innerHeight - this.virtualImageDimension.height) / 2; return 'translate3d(' + left + 'px, ' + top + 'px, 0)'; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "containerScale", { get: function () { return this.thumbnailImagePosition.width / this.virtualImageDimension.width; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "imageAspectRatio", { get: function () { return this.thumbnailImage.naturalWidth / this.thumbnailImage.naturalHeight; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "isImageLargerWindow", { get: function () { var imageNaturalWidth = this.lightboxImageNaturalWidth; var imageNaturalHeight = this.lightboxImageNaturalHeight; var windowWidth = document.body.clientWidth; var windowHeight = window.innerHeight; return imageNaturalWidth > windowWidth || imageNaturalHeight > windowHeight; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "isFirstImage", { get: function () { if (this.properties.loop) { return false; } else { return this.index === 0; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "isLastImage", { get: function () { if (this.properties.loop) { return false; } else { return this.index === this.latestImageIndex; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "latestImageIndex", { get: function () { return this.images.length - 1; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "backgroundColor", { get: function () { var opacity = this.properties.backgroundOpacity; var color = this.properties.backgroundColor; if (color === 'black') { return 'rgba(0, 0, 0, ' + opacity + ')'; } else { return 'rgba(255, 255, 255, ' + opacity + ')'; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "animationDuration", { get: function () { var animationDuration = this.properties.animationDuration; if (typeof animationDuration === "string") { return Number.parseInt(animationDuration); } else { return animationDuration; } }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "animationMode", { get: function () { if (this.currImageLoadingState === 'error') { return 'default'; } return this.properties.animationMode; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "animationTimingFunction", { get: function () { return this.properties.animationTimingFunction; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "closeButtonText", { get: function () { return this.properties.closeButtonText; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "counterSeparator", { get: function () { return this.properties.counterSeparator; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxCommonComponent.prototype, "counter", { get: function () { return this.currentImageIndex + 1 + this.counterSeparator + this.images.length; }, enumerable: true, configurable: true }); LightboxCommonComponent.prototype.emitState = function (type, state) { if (state === 'initial-virtual-image' || state === 'initial-styles') { return; } if (state === 'initial-default' || state === 'initial-thumbnail-image') { state = 'initial'; } this.eventService.emitChangeEvent({ type: type + ':' + state }); }; LightboxCommonComponent.prototype.setShowState = function (state) { this.showState = state; this.emitState('show-state', state); }; LightboxCommonComponent.prototype.setClosingState = function (state) { this.closingState = state; this.emitState('closing-state', state); }; LightboxCommonComponent.prototype.setAnimationDuration = function () { this.hostStyleTransition = 'background-color ' + this.animationDuration + 'ms'; this.containerStyles.transition = 'all ' + this.animationDuration + 'ms ' + this.animationTimingFunction; }; LightboxCommonComponent.prototype.setBackgroundColor = function () { this.hostStyleBackgroundColor = this.backgroundColor; }; LightboxCommonComponent.prototype.getContainerHeight = function () { return this.thumbnailImagePosition.height / this.containerScale + 'px'; }; LightboxCommonComponent.prototype.showThumbnailImage = function () { this.thumbnailImage.style.opacity = ''; }; LightboxCommonComponent.prototype.hideThumbnailImage = function () { this.thumbnailImage.style.opacity = 0; }; LightboxCommonComponent.prototype.updateThumbnailPosition = function () { this.containerStyles.transform = this.containerInitialPosition; }; LightboxCommonComponent.ctorParameters = function () { return [ { type: EventService } ]; }; __decorate([ Input() ], LightboxCommonComponent.prototype, "lightboxData", void 0); __decorate([ HostBinding('style.backgroundColor') ], LightboxCommonComponent.prototype, "hostStyleBackgroundColor", void 0); __decorate([ HostBinding('style.transition') ], LightboxCommonComponent.prototype, "hostStyleTransition", void 0); __decorate([ ViewChild('imageFirst', { static: true }) ], LightboxCommonComponent.prototype, "_imageFirst", void 0); __decorate([ ViewChild('imageSecond', { static: true }) ], LightboxCommonComponent.prototype, "_imageSecond", void 0); __decorate([ ViewChild('imageLast', { static: true }) ], LightboxCommonComponent.prototype, "_imageLast", void 0); __decorate([ ViewChild('lightboxImage', { static: true }) ], LightboxCommonComponent.prototype, "_lightboxImage", void 0); LightboxCommonComponent = __decorate([ Component({ selector: 'lightbox-common', template: '' }) ], LightboxCommonComponent); return LightboxCommonComponent; }()); export { LightboxCommonComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightbox-common.component.js","sourceRoot":"ng://@crystalui/angular-lightbox/","sources":["lib/lightbox-common.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, ViewChild, ElementRef } from '@angular/core';\nimport { LightboxData, Properties } from './interfaces';\nimport { ShowState, ClosingState } from './types';\nimport { EventService } from './event.service';\nimport { Utils } from './utils';\n\n@Component({\n    selector: 'lightbox-common',\n    template: ''\n})\n\nexport class LightboxCommonComponent {\n\n    currentImageIndex: number = 0;\n    indexCurrentSlide = 1;\n    showState: ShowState;\n    closingState: ClosingState;\n    containerStyles: any = {\n        transition: '',\n        transform: '',\n        width: '',\n        height: '',\n        opacity: ''\n    };\n    currImageLoadingState: 'not-loaded' | 'loading' | 'uploaded' | 'error' = 'not-loaded';\n    isMobile: boolean;\n\n    @Input() lightboxData: LightboxData;\n\n    @HostBinding('style.backgroundColor') hostStyleBackgroundColor: string;\n    @HostBinding('style.transition') hostStyleTransition: string;\n\n    @ViewChild('imageFirst', { static: true }) _imageFirst: ElementRef;\n    @ViewChild('imageSecond', { static: true }) _imageSecond: ElementRef;\n    @ViewChild('imageLast', { static: true }) _imageLast: ElementRef;\n    @ViewChild('lightboxImage', { static: true }) _lightboxImage: ElementRef;\n\n    get lightboxImage(){\n        return this._lightboxImage;\n    }\n\n    get lightboxImageElement(){\n        if (this.lightboxImage){\n            return this.lightboxImage.nativeElement;\n        }\n    }\n\n    get lightboxImageNaturalHeight(){\n        if (this.lightboxImageElement){\n            return this.lightboxImageElement.naturalHeight;\n        }\n    }\n\n    get lightboxImageNaturalWidth(){\n        if (this.lightboxImageElement){\n            return this.lightboxImageElement.naturalWidth;\n        }\n    }\n\n    get index(){\n        return this.currentImageIndex;\n    }\n\n    get properties(){\n        return this.lightboxData.properties;\n    }\n\n    get images(){\n        return this.lightboxData.images || [this.lightboxData.image];\n    }\n\n    get thumbnailImage(){\n        return this.images[this.currentImageIndex].nativeElement;\n    }\n\n    get thumbnailImagePosition(){\n        return this.thumbnailImage.getBoundingClientRect();\n    }\n\n    // Image size if it is larger than the window size\n    get virtualImageDimension(){\n        let height = this.lightboxImageNaturalHeight;\n        let width = height * this.imageAspectRatio;\n        const windowWidth = document.body.clientWidth;\n        const windowHeight = window.innerHeight;\n\n        if (this.isImageLargerWindow){\n            if (height > windowHeight){\n                height = windowHeight;\n                width = height * this.imageAspectRatio;\n            } \n\n            if (width > windowWidth){\n                width = windowWidth;\n                height = width / this.imageAspectRatio;\n            }\n        } else {\n            width = this.lightboxImageNaturalWidth;\n            height = this.lightboxImageNaturalHeight;\n        }\n\n        if (width === 0 || Number.parseInt(height) === 0){\n            return {width: 200, height: 200};\n        }\n\n        return {width, height};\n    }\n\n    get containerInitialPosition(){\n        const scale =  (this.showState === 'initial-thumbnail-image') ? 1 : this.containerScale; \n        const top = this.thumbnailImagePosition.top;\n        const left = this.thumbnailImagePosition.left;\n        return 'matrix('+ scale +', 0, 0, '+ scale +','+ left +','+ top +')';\n    }\n\n    get containerFullscreenPosition(){\n        const left = (document.body.clientWidth - this.virtualImageDimension.width) / 2;\n        const top = (window.innerHeight - this.virtualImageDimension.height) / 2;\n\n        return 'translate3d('+ left +'px, '+ top +'px, 0)';\n    }\n\n    get containerScale(){\n        return this.thumbnailImagePosition.width / this.virtualImageDimension.width;\n    }\n\n    get imageAspectRatio(){\n        return this.thumbnailImage.naturalWidth / this.thumbnailImage.naturalHeight;\n    }\n\n    get isImageLargerWindow():boolean {\n        const imageNaturalWidth = this.lightboxImageNaturalWidth;\n        const imageNaturalHeight = this.lightboxImageNaturalHeight;\n        const windowWidth = document.body.clientWidth;\n        const windowHeight = window.innerHeight;\n        return imageNaturalWidth > windowWidth || imageNaturalHeight > windowHeight;\n    }\n\n    get isFirstImage(){\n        if (this.properties.loop){\n            return false;\n        } else {\n            return this.index === 0;\n        }\n    }\n\n    get isLastImage(){\n        if (this.properties.loop){\n            return false;\n        } else {\n            return this.index === this.latestImageIndex;\n        }        \n    }\n\n    get latestImageIndex(){\n        return this.images.length - 1;\n    }\n\n    get backgroundColor(){\n        const opacity = this.properties.backgroundOpacity;\n        const color = this.properties.backgroundColor;\n        if (color === 'black') {\n            return 'rgba(0, 0, 0, ' + opacity +')';\n        } else {\n            return 'rgba(255, 255, 255, ' + opacity +')';\n        }\n    }\n\n    get animationDuration(){\n        const animationDuration = this.properties.animationDuration;\n\n        if (typeof animationDuration === \"string\"){\n            return Number.parseInt(animationDuration);\n        } else {\n            return animationDuration;\n        }\n    }\n\n    get animationMode(){\n        if (this.currImageLoadingState === 'error'){\n            return 'default';\n        }\n        return this.properties.animationMode;\n    }\n\n    get animationTimingFunction(){\n        return this.properties.animationTimingFunction;\n    }\n\n    get closeButtonText(){\n        return this.properties.closeButtonText;\n    }\n\n    get counterSeparator(){\n        return this.properties.counterSeparator;\n    }\n\n    get counter(){\n        return this.currentImageIndex + 1 + this.counterSeparator + this.images.length;\n    }\n\n    constructor(public eventService: EventService){\n        this.isMobile = Utils.mobileCheck();\n    }\n\n    emitState(type, state){\n        if (state === 'initial-virtual-image' || \n            state === 'initial-styles'){\n            return;\n        }\n\n        if (state === 'initial-default' || \n            state === 'initial-thumbnail-image'){\n            state = 'initial';\n        }\n\n        this.eventService.emitChangeEvent({\n            type: type+':'+state\n        });\n    }\n\n    setShowState(state: ShowState){\n        this.showState = state;\n        this.emitState('show-state', state)\n    }\n\n    setClosingState(state: ClosingState){\n        this.closingState = state; \n        this.emitState('closing-state', state);\n    }\n\n    setAnimationDuration(){\n        this.hostStyleTransition = 'background-color '+this.animationDuration+'ms';\n        this.containerStyles.transition = 'all '+this.animationDuration+'ms '+this.animationTimingFunction;\n    }\n\n    setBackgroundColor(){\n        this.hostStyleBackgroundColor = this.backgroundColor;\n    }\n\n    getContainerHeight():string {\n        return this.thumbnailImagePosition.height / this.containerScale + 'px';\n    }\n\n    showThumbnailImage() {\n        this.thumbnailImage.style.opacity = '';\n    }\n\n    hideThumbnailImage(){\n        this.thumbnailImage.style.opacity = 0;\n    }\n\n    updateThumbnailPosition(){\n        this.containerStyles.transform = this.containerInitialPosition;\n    }\n} \n"]}