UNPKG

angular-gallery

Version:

Responsive gallery for Angular with touch screen support.

179 lines 20.1 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'; 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":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,wBAAwB,EAC5G,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAS7C,IAAa,yBAAyB,GAAtC,MAAa,yBAAyB;IAkFlC,YACY,wBAAkD,EACnD,UAAsB,EACrB,YAA0B;QAF1B,6BAAwB,GAAxB,wBAAwB,CAA0B;QACnD,eAAU,GAAV,UAAU,CAAY;QACrB,iBAAY,GAAZ,YAAY,CAAc;QAlF/B,oBAAe,GAAY,IAAI,CAAC;QACvC,eAAU,GAAW,EAAE,CAAC;QACxB,iBAAY,GAAW,CAAC,CAAC;QAiFrB,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAC/D,CAAC,KAAK,EAAE,EAAE;YACN,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACnC,CAAC,CACJ,CAAC;IACN,CAAC;IA/ED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;IACD,IAAI,WAAW,CAAC,KAAK;QACjB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC9B,CAAC;IAGD,IAAI,cAAc;QACd,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,GAAC,KAAK,CAAC;QACzD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC;QACtD,OAAO,UAAU,GAAE,QAAQ,GAAG,KAAK,GAAG,cAAc,GAAE,QAAQ,GAAG,KAAK,CAAC;IAC3E,CAAC;IAID,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAClC,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;IACxC,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;IAGD,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;IACpC,CAAC;IAKD,OAAO,CAAC,KAAK;QACT,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YACvD,IAAI,IAAI,CAAC,SAAS,EAAC;gBACf,IAAI,CAAC,YAAY,EAAE,CAAC;aACvB;SACJ;IACL,CAAC;IAGD,aAAa,CAAC,KAAK;QACf,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,SAAS,EAAC;YAChD,OAAO;SACV;QAED,IAAI,KAAK,CAAC,YAAY,IAAI,SAAS,EAAE;YACjC,OAAO;SACV;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,iCAAiC;SACpC;aAAM;YACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,kCAAkC;SACrC;IACL,CAAC;IAED,IAAI,YAAY;QACZ,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAC;YACzB,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC;SAChD;IACL,CAAC;IAaD,QAAQ;QACJ,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,cAAc,EAAE,CAAC;QAEtB,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAC1B,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB;IAC1C,CAAC;IAED,eAAe;QACX,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAChC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACxB,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,wBAAwB,EAAE;YAC/B,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;SAC/C;IACL,CAAC;IAED,cAAc;QACV,IAAI,CAAC,aAAa,GAAG,aAAa,GAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,GAAC,GAAG,CAAC;IAC/E,CAAC;IAED,oBAAoB;QAChB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC;IAC3C,CAAC;IAED,aAAa;QACT,IAAI,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;QAC7B,IAAI,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACnG,IAAI,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;QAEpD,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAEzB,IAAI,YAAY,GAAG,gBAAgB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QACtE,IAAI,mBAAmB,GAAyB,YAAY,CAAC,QAAS,CAAC,aAAa,CAAC;QAErF,aAAa;QACb,mBAAmB,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QACxD,mBAAmB,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;QAE1D,cAAc;QACd,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE;YACvC,mBAAmB,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACxD;QACD,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE;YACvC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,UAAS,SAAS;gBACxC,mBAAmB,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;SACN;QAED,kBAAkB;QACI,YAAY,CAAC,QAAS,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC;IACrF,CAAC;IAED,YAAY;QACR,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,aAAa,GAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,GAAC,GAAG,CAAC;IAC/E,CAAC;IAED,eAAe;QACX,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC;YAC9B,IAAI,EAAE,gBAAgB;SACzB,CAAC,CAAC;IACP,CAAC;IAED,kBAAkB,CAAC,KAAK;QACpB,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,EAAC;YACtB,IAAI,CAAC,YAAY,EAAE,CAAC;SACvB;IACL,CAAC;CACJ,CAAA;;YArFyC,wBAAwB;YACvC,UAAU;YACP,YAAY;;AA9EE;IAAvC,SAAS,CAAC,WAAW,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC;yDAAqB;AAEnD;IAAR,KAAK,EAAE;6DAA+B;AAGvC;IADC,WAAW,CAAC,eAAe,CAAC;4DAG5B;AAMD;IADC,WAAW,CAAC,kBAAkB,CAAC;+DAK/B;AAE+B;IAA/B,WAAW,CAAC,iBAAiB,CAAC;gEAAuB;AAEtD;IADC,WAAW,CAAC,eAAe,CAAC;2DAG5B;AAGD;IADC,WAAW,CAAC,aAAa,CAAC;0DAG1B;AAED;IADC,WAAW,CAAC,cAAc,CAAC;2DAG3B;AAGD;IADC,WAAW,CAAC,gBAAgB,CAAC;6DAG7B;AAEmC;IAAnC,WAAW,CAAC,qBAAqB,CAAC;4DAAoB;AAGvD;IADC,YAAY,CAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC,CAAC;wDAO1C;AAGD;IADC,YAAY,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,CAAC;8DAiBzC;AA1EQ,yBAAyB;IANrC,SAAS,CAAC;QACP,QAAQ,EAAE,SAAS;QACnB,oYAAiD;;KAEpD,CAAC;GAEW,yBAAyB,CAwKrC;SAxKY,yBAAyB","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"]}