@crystalui/angular-lightbox
Version:
Angular library for viewing images in a pop-up window with touch screen support.
158 lines • 14.2 kB
JavaScript
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"]}