angular-gallery
Version:
Responsive gallery for Angular with touch screen support.
211 lines • 22.4 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';
var OverlayContainerComponent = /** @class */ (function () {
function OverlayContainerComponent(componentFactoryResolver, elementRef, eventService) {
var _this = this;
this.componentFactoryResolver = componentFactoryResolver;
this.elementRef = elementRef;
this.eventService = eventService;
this.overlayBackdrop = true;
this.minTimeout = 30;
this._hostOpacity = 0;
this.globalEventsSubscription = this.eventService.emitter.subscribe(function (event) {
_this.handleGlobalEvents(event);
});
}
Object.defineProperty(OverlayContainerComponent.prototype, "hostOpacity", {
get: function () {
return this.properties.fadeIn ? this._hostOpacity : 1;
},
set: function (value) {
this._hostOpacity = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(OverlayContainerComponent.prototype, "hostTransition", {
get: function () {
var duration = this.properties.animationDuration + 'ms ';
var esing = this.properties.animationTimingFunction;
return 'opacity ' + duration + esing + ', transform ' + duration + esing;
},
enumerable: true,
configurable: true
});
Object.defineProperty(OverlayContainerComponent.prototype, "hostZIndex", {
get: function () {
return this.properties.zIndex;
},
enumerable: true,
configurable: true
});
Object.defineProperty(OverlayContainerComponent.prototype, "hostWidth", {
get: function () {
return this.properties.wrapperWidth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(OverlayContainerComponent.prototype, "hostHeight", {
get: function () {
return this.properties.wrapperHeight;
},
enumerable: true,
configurable: true
});
Object.defineProperty(OverlayContainerComponent.prototype, "hostPosition", {
get: function () {
return this.properties.position;
},
enumerable: true,
configurable: true
});
OverlayContainerComponent.prototype.onClick = function (event) {
if (!this.elementRef.nativeElement.contains(event.target)) {
if (this.hostShown) {
this.closeOverlay();
}
}
};
OverlayContainerComponent.prototype.transitionEnd = function (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");
}
};
Object.defineProperty(OverlayContainerComponent.prototype, "popoverClass", {
get: function () {
if (this.properties.metadata) {
return this.properties.metadata.popoverClass;
}
},
enumerable: true,
configurable: true
});
OverlayContainerComponent.prototype.ngOnInit = function () {
var _this = this;
this.loadComponent();
this.initialOverlay();
setTimeout(function () {
_this.isInitial = true;
}, this.minTimeout); // Note: not good
};
OverlayContainerComponent.prototype.ngAfterViewInit = function () {
var _this = this;
setTimeout(function () {
_this.showOverlayAnimation();
}, this.minTimeout);
};
OverlayContainerComponent.prototype.ngOnDestroy = function () {
if (this.globalEventsSubscription) {
this.globalEventsSubscription.unsubscribe();
}
};
OverlayContainerComponent.prototype.initialOverlay = function () {
this.hostTransform = 'translateY(' + this.properties.animationTranslateY + ')';
};
OverlayContainerComponent.prototype.showOverlayAnimation = function () {
this.hostOpacity = 1;
this.hostTransform = 'translateY(0px)';
};
OverlayContainerComponent.prototype.loadComponent = function () {
var adItem = this.properties;
var componentFactory = this.componentFactoryResolver.resolveComponentFactory(adItem.mainComponent);
var viewContainerRef = this.adHost.viewContainerRef;
viewContainerRef.clear();
var componentRef = viewContainerRef.createComponent(componentFactory);
var 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;
};
OverlayContainerComponent.prototype.closeOverlay = function () {
this.hostOpacity = 0;
this.hostTransform = 'translateY(' + this.properties.animationTranslateY + ')';
};
OverlayContainerComponent.prototype.closeOverlayEnd = function () {
this.hostShown = false;
this.eventService.emitChangeEvent({
type: '[Overlay] Hide'
});
};
OverlayContainerComponent.prototype.handleGlobalEvents = function (event) {
if (event.type === 'Hide') {
this.closeOverlay();
}
};
OverlayContainerComponent.ctorParameters = function () { return [
{ 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);
return 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"]}