angular-gallery
Version:
Responsive gallery for Angular with touch screen support.
179 lines • 20.1 kB
JavaScript
import { __decorate } from "tslib";
import { Component, OnInit, HostBinding, HostListener, ViewChild, ElementRef, Input, ComponentFactoryResolver } from '@angular/core';
import { EventService } from './event.service';
import { AdDirective } from './ad.directive';
let OverlayContainerComponent = class OverlayContainerComponent {
constructor(componentFactoryResolver, elementRef, eventService) {
this.componentFactoryResolver = componentFactoryResolver;
this.elementRef = elementRef;
this.eventService = eventService;
this.overlayBackdrop = true;
this.minTimeout = 30;
this._hostOpacity = 0;
this.globalEventsSubscription = this.eventService.emitter.subscribe((event) => {
this.handleGlobalEvents(event);
});
}
get hostOpacity() {
return this.properties.fadeIn ? this._hostOpacity : 1;
}
set hostOpacity(value) {
this._hostOpacity = value;
}
get hostTransition() {
const duration = this.properties.animationDuration + 'ms ';
const esing = this.properties.animationTimingFunction;
return 'opacity ' + duration + esing + ', transform ' + duration + esing;
}
get hostZIndex() {
return this.properties.zIndex;
}
get hostWidth() {
return this.properties.wrapperWidth;
}
get hostHeight() {
return this.properties.wrapperHeight;
}
get hostPosition() {
return this.properties.position;
}
onClick(event) {
if (!this.elementRef.nativeElement.contains(event.target)) {
if (this.hostShown) {
this.closeOverlay();
}
}
}
transitionEnd(event) {
if (event.target.tagName.toLowerCase() != "overlay") {
return;
}
if (event.propertyName != "opacity") {
return;
}
if (this.hostShown) {
this.closeOverlayEnd();
//this.stateEvents.emit("shown");
}
else {
this.hostShown = true;
//this.stateEvents.emit("hidden");
}
}
get popoverClass() {
if (this.properties.metadata) {
return this.properties.metadata.popoverClass;
}
}
ngOnInit() {
this.loadComponent();
this.initialOverlay();
setTimeout(() => {
this.isInitial = true;
}, this.minTimeout); // Note: not good
}
ngAfterViewInit() {
setTimeout(() => {
this.showOverlayAnimation();
}, this.minTimeout);
}
ngOnDestroy() {
if (this.globalEventsSubscription) {
this.globalEventsSubscription.unsubscribe();
}
}
initialOverlay() {
this.hostTransform = 'translateY(' + this.properties.animationTranslateY + ')';
}
showOverlayAnimation() {
this.hostOpacity = 1;
this.hostTransform = 'translateY(0px)';
}
loadComponent() {
let adItem = this.properties;
let componentFactory = this.componentFactoryResolver.resolveComponentFactory(adItem.mainComponent);
let viewContainerRef = this.adHost.viewContainerRef;
viewContainerRef.clear();
let componentRef = viewContainerRef.createComponent(componentFactory);
let componentRefElement = componentRef.location.nativeElement;
// Set styles
componentRefElement.style.width = this.properties.width;
componentRefElement.style.height = this.properties.height;
// Set classes
if (typeof this.popoverClass === 'string') {
componentRefElement.classList.add(this.popoverClass);
}
if (typeof this.popoverClass === 'object') {
this.popoverClass.forEach(function (className) {
componentRefElement.classList.add(className);
});
}
// Pass properties
componentRef.instance.overlayProperties = this.properties;
}
closeOverlay() {
this.hostOpacity = 0;
this.hostTransform = 'translateY(' + this.properties.animationTranslateY + ')';
}
closeOverlayEnd() {
this.hostShown = false;
this.eventService.emitChangeEvent({
type: '[Overlay] Hide'
});
}
handleGlobalEvents(event) {
if (event.type === 'Hide') {
this.closeOverlay();
}
}
};
OverlayContainerComponent.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: ElementRef },
{ type: EventService }
];
__decorate([
ViewChild(AdDirective, { static: true })
], OverlayContainerComponent.prototype, "adHost", void 0);
__decorate([
Input()
], OverlayContainerComponent.prototype, "properties", void 0);
__decorate([
HostBinding('style.opacity')
], OverlayContainerComponent.prototype, "hostOpacity", null);
__decorate([
HostBinding('style.transition')
], OverlayContainerComponent.prototype, "hostTransition", null);
__decorate([
HostBinding('style.transform')
], OverlayContainerComponent.prototype, "hostTransform", void 0);
__decorate([
HostBinding('style.z-index')
], OverlayContainerComponent.prototype, "hostZIndex", null);
__decorate([
HostBinding('style.width')
], OverlayContainerComponent.prototype, "hostWidth", null);
__decorate([
HostBinding('style.height')
], OverlayContainerComponent.prototype, "hostHeight", null);
__decorate([
HostBinding('style.position')
], OverlayContainerComponent.prototype, "hostPosition", null);
__decorate([
HostBinding('class.overlay-shown')
], OverlayContainerComponent.prototype, "hostShown", void 0);
__decorate([
HostListener('document:click', ['$event'])
], OverlayContainerComponent.prototype, "onClick", null);
__decorate([
HostListener('transitionend', ['$event'])
], OverlayContainerComponent.prototype, "transitionEnd", null);
OverlayContainerComponent = __decorate([
Component({
selector: 'overlay',
template: "<!--\n<div class=\"overlay-backdrop\" \n\t*ngIf=\"properties.overlayBackdrop\" \n\t(click)=\"onBackdropClick()\" \n\t[ngClass]=\"properties.backdropClass\"></div>\n-->\n<!--\n<div class=\"overlay-container\"\n\t[ngStyle]=\"containerStyles\" \n\t[ngClass]=\"properties.overlayClass\">\n\n\t<ng-template ad-host></ng-template>\n</div>\n-->\n\n<ng-template ad-host></ng-template>",
styles: [":host{position:absolute;top:0;left:0}:host .overlay-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000;opacity:0;z-index:1000;pointer-events:auto}"]
})
], OverlayContainerComponent);
export { OverlayContainerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-container.component.js","sourceRoot":"ng://angular-gallery/","sources":["lib/overlay/overlay-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostBinding, HostListener, ViewChild, ElementRef, Input, ComponentFactoryResolver\n} from '@angular/core';\nimport { EventService } from './event.service';\nimport { AdDirective } from './ad.directive';\nimport { ComponentProperties, OverlayProperties } from './interfaces';\n\n@Component({\n    selector: 'overlay',\n    templateUrl: './overlay-container.component.html',\n    styleUrls: ['./overlay-container.component.sass']\n})\n\nexport class OverlayContainerComponent implements OnInit {\n    public isInitial: boolean;\n    globalEventsSubscription;\n    public overlayBackdrop: boolean = true;\n    minTimeout: number = 30;\n    _hostOpacity: number = 0;\n\n    @ViewChild(AdDirective, {static: true}) adHost: AdDirective;\n\n    @Input() properties: OverlayProperties;\n\n    @HostBinding('style.opacity')\n    get hostOpacity(){\n        return this.properties.fadeIn ? this._hostOpacity : 1;\n    }\n    set hostOpacity(value){\n        this._hostOpacity = value;\n    }\n\n    @HostBinding('style.transition')\n    get hostTransition(){\n        const duration = this.properties.animationDuration+'ms ';\n        const esing = this.properties.animationTimingFunction;\n        return 'opacity '+ duration + esing + ', transform '+ duration + esing;\n    }\n\n    @HostBinding('style.transform') hostTransform: string;\n    @HostBinding('style.z-index') \n    get hostZIndex(){\n        return this.properties.zIndex;\n    }\n\n    @HostBinding('style.width') \n    get hostWidth(){\n        return this.properties.wrapperWidth;\n    }\n    @HostBinding('style.height') \n    get hostHeight(){\n        return this.properties.wrapperHeight;\n    }\n\n    @HostBinding('style.position') \n    get hostPosition(){\n        return this.properties.position;\n    }\n\n    @HostBinding('class.overlay-shown') hostShown: boolean;\n\n    @HostListener('document:click', ['$event'])\n    onClick(event){\n        if (!this.elementRef.nativeElement.contains(event.target)) {\n            if (this.hostShown){\n                this.closeOverlay();\n            }\n        }\n    }\n\n    @HostListener('transitionend', ['$event'])\n    transitionEnd(event) {\n        if (event.target.tagName.toLowerCase() != \"overlay\"){\n            return;\n        }\n\n        if (event.propertyName != \"opacity\") {\n            return;\n        }\n\n        if (this.hostShown) {\n            this.closeOverlayEnd();\n            //this.stateEvents.emit(\"shown\");\n        } else {\n            this.hostShown = true;\n            //this.stateEvents.emit(\"hidden\");\n        }\n    }\n\n    get popoverClass(){\n        if (this.properties.metadata){\n            return this.properties.metadata.popoverClass;\n        }\n    }\n\n    constructor(\n        private componentFactoryResolver: ComponentFactoryResolver,\n        public elementRef: ElementRef,\n        private eventService: EventService) {\n        this.globalEventsSubscription = this.eventService.emitter.subscribe(\n            (event) => {\n                this.handleGlobalEvents(event);\n            }\n        );\n    }\n\n    ngOnInit() {\n        this.loadComponent();\n        this.initialOverlay();\n\n        setTimeout(() => {\n            this.isInitial = true;\n        }, this.minTimeout); // Note: not good\n    }\n\n    ngAfterViewInit() {\n        setTimeout(() => {\n            this.showOverlayAnimation();\n        }, this.minTimeout);\n    }\n\n    ngOnDestroy() {\n        if (this.globalEventsSubscription) {\n            this.globalEventsSubscription.unsubscribe();\n        }\n    }\n\n    initialOverlay(){\n        this.hostTransform = 'translateY('+this.properties.animationTranslateY+')';\n    }\n\n    showOverlayAnimation(){\n        this.hostOpacity = 1;\n        this.hostTransform = 'translateY(0px)';\n    }\n\n    loadComponent() {\n        let adItem = this.properties;\n        let componentFactory = this.componentFactoryResolver.resolveComponentFactory(adItem.mainComponent);\n        let viewContainerRef = this.adHost.viewContainerRef;\n\n        viewContainerRef.clear();\n\n        let componentRef = viewContainerRef.createComponent(componentFactory);\n        let componentRefElement = (<ComponentProperties>componentRef.location).nativeElement;\n\n        // Set styles\n        componentRefElement.style.width = this.properties.width;\n        componentRefElement.style.height = this.properties.height;\n\n        // Set classes\n        if (typeof this.popoverClass === 'string') {\n            componentRefElement.classList.add(this.popoverClass);\n        }\n        if (typeof this.popoverClass === 'object') {\n            this.popoverClass.forEach(function(className) {\n                componentRefElement.classList.add(className);\n            }); \n        }\n\n        // Pass properties\n        (<ComponentProperties>componentRef.instance).overlayProperties = this.properties;\n    }\n\n    closeOverlay(){\n        this.hostOpacity = 0;\n        this.hostTransform = 'translateY('+this.properties.animationTranslateY+')';\n    }\n\n    closeOverlayEnd() {\n        this.hostShown = false;\n        this.eventService.emitChangeEvent({\n            type: '[Overlay] Hide'\n        });\n    }\n\n    handleGlobalEvents(event){\n        if (event.type === 'Hide'){\n            this.closeOverlay();\n        }\n    }\n}\n"]}