UNPKG

@crystalui/angular-lightbox

Version:

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

158 lines 14.2 kB
import { __decorate } from "tslib"; import { Directive, ElementRef, Input, Output, HostListener, HostBinding, OnInit, EventEmitter } from '@angular/core'; import { EventService } from './event.service'; import { CrystalLightbox } from './lightbox.service'; var LightboxDirective = /** @class */ (function () { function LightboxDirective(lightbox, eventService, elementRef) { var _this = this; this.lightbox = lightbox; this.eventService = eventService; this.elementRef = elementRef; this.properties = {}; this.events = new EventEmitter(); this.hostLightboxGroup = true; this.globalEventsSubscription = this.eventService.emitter.subscribe(function (event) { _this.handleGlobalEvents(event); }); } Object.defineProperty(LightboxDirective.prototype, "hostSimpleMode", { get: function () { return this.simpleMode; }, enumerable: true, configurable: true }); Object.defineProperty(LightboxDirective.prototype, "isGroupImage", { get: function () { return this.elementRef.nativeElement.closest(".lightbox-group"); }, enumerable: true, configurable: true }); LightboxDirective.prototype.onClick = function (event) { if (this.disable) { return; } if (this.isGroupImage) { this.eventService.emitChangeEvent({ type: 'thumbnail:click', elementRef: this.elementRef, properties: this.properties }); } else { this.image = this.getImage(); this.lightbox.open({ images: [this.image], properties: this.properties, index: 0 }); } }; LightboxDirective.prototype.ngOnChanges = function (changes) { this.properties = Object.assign({}, this.properties, this.getProperties(changes)); }; LightboxDirective.prototype.handleGlobalEvents = function (event) { this.events.emit(event); }; LightboxDirective.prototype.getImage = function () { var image = {}; var nativeElement = this.elementRef.nativeElement; if (this.fullImage) { image.fullImage = this.fullImage; } image.thumbnailImage = { path: nativeElement.src, height: nativeElement.naturalHeight, width: nativeElement.naturalWidth }; image.nativeElement = nativeElement; return image; }; ; LightboxDirective.prototype.getProperties = function (changes) { var properties = {}; for (var prop in changes) { if (prop !== 'fullImage') { properties[prop] = changes[prop].currentValue; } } return properties; }; LightboxDirective.ctorParameters = function () { return [ { type: CrystalLightbox }, { type: EventService }, { type: ElementRef } ]; }; __decorate([ Input() ], LightboxDirective.prototype, "fullImage", void 0); __decorate([ Input() ], LightboxDirective.prototype, "properties", void 0); __decorate([ Input() ], LightboxDirective.prototype, "loop", void 0); __decorate([ Input() ], LightboxDirective.prototype, "backgroundOpacity", void 0); __decorate([ Input() ], LightboxDirective.prototype, "counter", void 0); __decorate([ Input() ], LightboxDirective.prototype, "imageMaxHeight", void 0); __decorate([ Input() ], LightboxDirective.prototype, "imageMaxWidth", void 0); __decorate([ Input() ], LightboxDirective.prototype, "animationDuration", void 0); __decorate([ Input() ], LightboxDirective.prototype, "animationMode", void 0); __decorate([ Input() ], LightboxDirective.prototype, "animationTimingFunction", void 0); __decorate([ Input() ], LightboxDirective.prototype, "closeButtonText", void 0); __decorate([ Input() ], LightboxDirective.prototype, "counterSeparator", void 0); __decorate([ Input() ], LightboxDirective.prototype, "disable", void 0); __decorate([ Input() ], LightboxDirective.prototype, "simpleMode", void 0); __decorate([ Input() ], LightboxDirective.prototype, "backgroundColor", void 0); __decorate([ Input() ], LightboxDirective.prototype, "hideThumbnail", void 0); __decorate([ Input() ], LightboxDirective.prototype, "gestureEnable", void 0); __decorate([ Output() ], LightboxDirective.prototype, "events", void 0); __decorate([ HostBinding('class.lightbox-single') ], LightboxDirective.prototype, "hostLightboxGroup", void 0); __decorate([ HostBinding('class.lightbox-simple-mode') ], LightboxDirective.prototype, "hostSimpleMode", null); __decorate([ HostListener('click', ['$event']) ], LightboxDirective.prototype, "onClick", null); LightboxDirective = __decorate([ Directive({ selector: '[lightbox]' }) ], LightboxDirective); return LightboxDirective; }()); export { LightboxDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightbox.directive.js","sourceRoot":"ng://@crystalui/angular-lightbox/","sources":["lib/lightbox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Output, HostListener, HostBinding, OnInit, EventEmitter } from '@angular/core';\nimport { EventService } from './event.service';\nimport { CrystalLightbox } from'./lightbox.service';\nimport { Properties, ImageExtended, Image } from './interfaces';\n\n@Directive({\n    selector: '[lightbox]'\n})\n\nexport class LightboxDirective {\n\n    globalEventsSubscription;\n    image: ImageExtended;\n    @Input() fullImage: Image;\n    @Input() properties: Properties = {};\n    @Input() loop: boolean;\n    @Input() backgroundOpacity: number;\n    @Input() counter: boolean;\n    @Input() imageMaxHeight: string;\n    @Input() imageMaxWidth: string;\n    @Input() animationDuration: number;\n    @Input() animationMode: 'default' | 'zoom' | 'zoom-blur' | 'zoom-preloader' | 'opacity' | 'none'; \n    @Input() animationTimingFunction: string;\n    @Input() closeButtonText: string;\n    @Input() counterSeparator: string;\n    @Input() disable: boolean;\n    @Input() simpleMode: boolean;\n    @Input() backgroundColor: 'black' | 'white';\n    @Input() hideThumbnail: boolean;\n    @Input() gestureEnable: boolean;\n\n    @Output() events: EventEmitter<any> = new EventEmitter<any>();\n\n    @HostBinding('class.lightbox-single') hostLightboxGroup: boolean = true;\n    @HostBinding('class.lightbox-simple-mode') \n    get hostSimpleMode(){\n        return this.simpleMode;\n    }\n\n    get isGroupImage():boolean {\n        return this.elementRef.nativeElement.closest(\".lightbox-group\");\n    }\n\n    constructor( \n        private lightbox: CrystalLightbox, \n        private eventService: EventService,\n        private elementRef: ElementRef) {\n        this.globalEventsSubscription = this.eventService.emitter.subscribe(\n            (event) => {\n                this.handleGlobalEvents(event);\n            }\n        );\n    }\n\n    @HostListener('click', ['$event'])\n    onClick(event){\n        if (this.disable){\n            return;\n        }\n\n        if (this.isGroupImage){\n            this.eventService.emitChangeEvent({\n                type: 'thumbnail:click',\n                elementRef: this.elementRef,\n                properties: this.properties\n            });\n        } else {\n            this.image = this.getImage();\n\n            this.lightbox.open({\n                images: [this.image],\n                properties: this.properties,\n                index: 0\n            });\n        }\n    }\n\n    ngOnChanges(changes) {\n        this.properties = Object.assign({}, this.properties, this.getProperties(changes));\n    }\n\n    handleGlobalEvents(event){\n        this.events.emit(event);\n    }\n\n    getImage(){\n        let image: ImageExtended = {};\n        const nativeElement = this.elementRef.nativeElement;\n\n        if (this.fullImage){\n            image.fullImage = this.fullImage;\n        }\n\n        image.thumbnailImage = {\n            path: nativeElement.src,\n            height: nativeElement.naturalHeight,\n            width: nativeElement.naturalWidth\n        }\n\n        image.nativeElement = nativeElement;\n        return image;\n    };\n\n    getProperties(changes){\n        let properties = {};\n\n        for (var prop in changes) {\n            if (prop !== 'fullImage'){\n                properties[prop] = changes[prop].currentValue;\n            }\n        }\n        return properties;\n    }\n}\n"]}