UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

134 lines 23.7 kB
import { Component, EventEmitter, HostBinding, Inject, Input, Output, ViewChild } from '@angular/core'; import { NavigationStart } from '@angular/router'; import { fromEvent } from 'rxjs'; import { filter, take } from 'rxjs/operators'; import { OverlayDirective } from './overlay.directive'; import { DOCUMENT } from '@angular/common'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@angular/common"; import * as i3 from "./overlay.directive"; export class OverlayComponent { constructor(document, cfResolver, router, renderer) { this.document = document; this.cfResolver = cfResolver; this.router = router; this.renderer = renderer; this.className = ``; this.br = `0`; this.state = 'closed'; this.resultEvent = new EventEmitter(); } loadComponent() { const componentFactory = this.cfResolver.resolveComponentFactory(this.options.component); const viewRef = this.modalDirective.viewContainerRef; viewRef.clear(); const componentRef = viewRef.createComponent(componentFactory); componentRef.instance.options = this.options; componentRef.instance.resultEvent.subscribe(res => { this.onResult(res); }); } onResult(res) { this.resultEvent.next(res); this.resultEvent.complete(); } onBackdrop() { if (this.options.hideOnBackdrop) { this.onResult(); } } /** * - if `fitWidth` config options is true * there are width declared depending on its parent element * - if `rects.top` calculated there is enough place to drop it down, * if it hits `rects.bottom` – show it above the element */ setDropdownPosition() { if (this.rects.width) { this.renderer.setStyle(this.overlayElem.nativeElement, `width`, `${this.rects.width}px`); } if (this.rects.top) { this.renderer.setStyle(this.overlayElem.nativeElement, `top`, `${this.rects.top}px`); } else { this.renderer.setStyle(this.overlayElem.nativeElement, `bottom`, `${this.rects.bottom}px`); } this.renderer.setStyle(this.overlayElem.nativeElement, `left`, `${this.rects.left || this.options.triggerRect.left}px`); this.renderer.setStyle(this.overlayElem.nativeElement, `opacity`, 1); } hideOnRouterEvents() { const sub = this.router.events.pipe(filter(event => event instanceof NavigationStart)).subscribe(() => { this.onBackdrop(); }); this.sub ? this.sub.add(sub) : this.sub = sub; } /** * detect window resize and scroll to prevent failed dropdown position */ initClosingSubscriptions() { if (this.options.hideOnScroll) { const sub = fromEvent(window, 'scroll').pipe(take(1)).subscribe(() => { this.onResult(); }); this.sub ? this.sub.add(sub) : this.sub = sub; } if (this.options.hideOnWindowResize) { const sub = fromEvent(window, 'resize').pipe(take(1)).subscribe(() => { this.onResult(); }); this.sub ? this.sub.add(sub) : this.sub = sub; } } /** * keyboard events */ initKeydownSubscription() { this.sub.add(fromEvent(this.document, 'keydown').subscribe((e) => { switch (e.key || e.code) { case 'Escape': e.preventDefault(); e.stopPropagation(); this.onResult(); break; default: return; } })); } ngOnInit() { this.state = 'opened'; if (this.options.borderRadius > 0) { this.br = `${this.options.borderRadius}px`; } this.loadComponent(); this.hideOnRouterEvents(); } ngOnDestroy() { this.resultEvent?.complete(); this.sub?.unsubscribe(); } } OverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: OverlayComponent, deps: [{ token: DOCUMENT }, { token: i0.ComponentFactoryResolver }, { token: i1.Router }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); OverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: OverlayComponent, selector: "sdk-overlay", inputs: { options: "options" }, outputs: { resultEvent: "resultEvent" }, host: { properties: { "attr.state": "this.state" } }, viewQueries: [{ propertyName: "modalDirective", first: true, predicate: OverlayDirective, descendants: true, static: true }, { propertyName: "overlayElem", first: true, predicate: ["overlay"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"sdk-overlay-wrap flex-column layout-center-center\" [style.zIndex]=\"options.index\" autofocus>\n <div class=\"sdk-overlay-container flex-row layout-center-center\">\n <div class=\"sdk-overlay-backdrop\" [class.visible]=\"options.backdropVisible\" (click)=\"onBackdrop()\"></div>\n <div class=\"sdk-overlay-content-wrap flex-column\" [style.borderRadius]=\"br\">\n <div class=\"sdk-overlay-content\"\n [ngStyle]=\"options.styles\"\n [class.disable-scroll]=\"options.disableScroll\">\n <ng-template sdkOverlay #overlay></ng-template>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes openOverlay{0%{transform:scale(.5) translateY(100px);opacity:0}}.sdk-overlay-wrap{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;width:100vw;height:100vh;overflow:hidden}.sdk-overlay-wrap .sdk-overlay-container{position:relative;z-index:1;width:100%;height:100%;overflow-x:hidden;overflow-y:auto}.sdk-overlay-wrap .sdk-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;width:100%;height:100%;animation:opacity .2s}.sdk-overlay-wrap .sdk-overlay-backdrop.visible{background:rgba(21,21,21,.6)}.sdk-overlay-wrap .sdk-overlay-content-wrap{position:relative;z-index:2;min-width:64px;max-width:100%;min-height:64px;max-height:100%;animation:openOverlay .3s}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content{position:relative}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.full-width,.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fullscreen{width:100vw}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.full-height,.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fullscreen{height:100vh}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fit-width{width:100%}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fit-height{height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.OverlayDirective, selector: "[sdkOverlay]" }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: OverlayComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-overlay', template: "<div class=\"sdk-overlay-wrap flex-column layout-center-center\" [style.zIndex]=\"options.index\" autofocus>\n <div class=\"sdk-overlay-container flex-row layout-center-center\">\n <div class=\"sdk-overlay-backdrop\" [class.visible]=\"options.backdropVisible\" (click)=\"onBackdrop()\"></div>\n <div class=\"sdk-overlay-content-wrap flex-column\" [style.borderRadius]=\"br\">\n <div class=\"sdk-overlay-content\"\n [ngStyle]=\"options.styles\"\n [class.disable-scroll]=\"options.disableScroll\">\n <ng-template sdkOverlay #overlay></ng-template>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes openOverlay{0%{transform:scale(.5) translateY(100px);opacity:0}}.sdk-overlay-wrap{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;width:100vw;height:100vh;overflow:hidden}.sdk-overlay-wrap .sdk-overlay-container{position:relative;z-index:1;width:100%;height:100%;overflow-x:hidden;overflow-y:auto}.sdk-overlay-wrap .sdk-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;width:100%;height:100%;animation:opacity .2s}.sdk-overlay-wrap .sdk-overlay-backdrop.visible{background:rgba(21,21,21,.6)}.sdk-overlay-wrap .sdk-overlay-content-wrap{position:relative;z-index:2;min-width:64px;max-width:100%;min-height:64px;max-height:100%;animation:openOverlay .3s}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content{position:relative}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.full-width,.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fullscreen{width:100vw}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.full-height,.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fullscreen{height:100vh}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fit-width{width:100%}.sdk-overlay-wrap .sdk-overlay-content-wrap .sdk-overlay-content.fit-height{height:100%}\n"] }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i0.ComponentFactoryResolver }, { type: i1.Router }, { type: i0.Renderer2 }]; }, propDecorators: { options: [{ type: Input }], modalDirective: [{ type: ViewChild, args: [OverlayDirective, { static: true }] }], overlayElem: [{ type: ViewChild, args: ['overlay', { static: true }] }], state: [{ type: HostBinding, args: ['attr.state'] }], resultEvent: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../libs/ngx-slice-kit/src/lib/overlay/overlay.component.ts","../../../../../libs/ngx-slice-kit/src/lib/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { OverlayModel, OverlayOptions } from './overlay.model';\nimport { NavigationStart, Router } from '@angular/router';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { OverlayDirective } from './overlay.directive';\nimport { DOCUMENT } from '@angular/common';\n\n@Component({\n    selector: 'sdk-overlay',\n    templateUrl: './overlay.component.html',\n    styleUrls: ['./overlay.component.scss']\n})\nexport class OverlayComponent implements OnInit, OnDestroy, OverlayModel {\n\n    public sub: Subscription;\n    public className: string = ``;\n    public br: string = `0`;\n    public rects: { top, bottom, right, left, width, height, x, y };\n\n    @Input() public options: OverlayOptions;\n    @ViewChild(OverlayDirective, {static: true}) public modalDirective: OverlayDirective;\n    @ViewChild('overlay', {static: true}) public overlayElem: ElementRef;\n    @HostBinding('attr.state') public state: 'opened' | 'closed' = 'closed';\n    @Output() public resultEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        private cfResolver: ComponentFactoryResolver,\n        private router: Router,\n        private renderer: Renderer2\n    ) {\n    }\n\n    public loadComponent(): void {\n        const componentFactory = this.cfResolver.resolveComponentFactory(this.options.component);\n\n        const viewRef = this.modalDirective.viewContainerRef;\n        viewRef.clear();\n\n        const componentRef = viewRef.createComponent(componentFactory);\n        (componentRef.instance as OverlayModel).options = this.options;\n        (componentRef.instance as OverlayModel).resultEvent.subscribe(res => {\n            this.onResult(res);\n        });\n    }\n\n    public onResult(res?: any): void {\n        this.resultEvent.next(res);\n        this.resultEvent.complete();\n    }\n\n    public onBackdrop(): void {\n        if (this.options.hideOnBackdrop) {\n            this.onResult();\n        }\n    }\n\n    /**\n     * - if `fitWidth` config options is true\n     * there are width declared depending on its parent element\n     * - if `rects.top` calculated there is enough place to drop it down,\n     *  if it hits `rects.bottom` – show it above the element\n     */\n    public setDropdownPosition(): void {\n        if (this.rects.width) {\n            this.renderer.setStyle(this.overlayElem.nativeElement, `width`, `${this.rects.width}px`);\n        }\n\n        if (this.rects.top) {\n            this.renderer.setStyle(this.overlayElem.nativeElement, `top`, `${this.rects.top}px`);\n        } else {\n            this.renderer.setStyle(this.overlayElem.nativeElement, `bottom`, `${this.rects.bottom}px`);\n        }\n\n        this.renderer.setStyle(this.overlayElem.nativeElement, `left`, `${this.rects.left || this.options.triggerRect.left}px`);\n        this.renderer.setStyle(this.overlayElem.nativeElement, `opacity`, 1);\n    }\n\n    public hideOnRouterEvents(): void {\n        const sub = this.router.events.pipe(\n            filter(event => event instanceof NavigationStart)\n        ).subscribe(() => {\n            this.onBackdrop();\n        });\n\n        this.sub ? this.sub.add(sub) : this.sub = sub;\n    }\n\n\n    /**\n     * detect window resize and scroll to prevent failed dropdown position\n     */\n    public initClosingSubscriptions(): void {\n        if (this.options.hideOnScroll) {\n            const sub = fromEvent(window, 'scroll').pipe(\n                take(1)\n            ).subscribe(() => {\n                this.onResult();\n            });\n            this.sub ? this.sub.add(sub) : this.sub = sub;\n        }\n\n        if (this.options.hideOnWindowResize) {\n            const sub = fromEvent(window, 'resize').pipe(\n                take(1)\n            ).subscribe(() => {\n                this.onResult();\n            });\n            this.sub ? this.sub.add(sub) : this.sub = sub;\n        }\n    }\n\n    /**\n     * keyboard events\n     */\n    public initKeydownSubscription(): void {\n        this.sub.add(\n            fromEvent(this.document, 'keydown').subscribe((e: KeyboardEvent) => {\n                switch (e.key || e.code) {\n                    case 'Escape':\n                        e.preventDefault();\n                        e.stopPropagation();\n                        this.onResult();\n                        break;\n                    default:\n                        return;\n                }\n            })\n        );\n    }\n\n    public ngOnInit(): void {\n        this.state = 'opened';\n        if (this.options.borderRadius > 0) {\n            this.br = `${this.options.borderRadius}px`;\n        }\n\n        this.loadComponent();\n\n        this.hideOnRouterEvents();\n    }\n\n    public ngOnDestroy(): void {\n        this.resultEvent?.complete();\n        this.sub?.unsubscribe();\n    }\n}\n","<div class=\"sdk-overlay-wrap flex-column layout-center-center\" [style.zIndex]=\"options.index\" autofocus>\n    <div class=\"sdk-overlay-container flex-row layout-center-center\">\n        <div class=\"sdk-overlay-backdrop\" [class.visible]=\"options.backdropVisible\" (click)=\"onBackdrop()\"></div>\n        <div class=\"sdk-overlay-content-wrap flex-column\" [style.borderRadius]=\"br\">\n            <div class=\"sdk-overlay-content\"\n                 [ngStyle]=\"options.styles\"\n                 [class.disable-scroll]=\"options.disableScroll\">\n                <ng-template sdkOverlay #overlay></ng-template>\n            </div>\n        </div>\n    </div>\n</div>\n"]}