UNPKG

angular-gallery

Version:

Responsive gallery for Angular with touch screen support.

211 lines 22.4 kB
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"]}