UNPKG

ngx-slice-kit

Version:

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

95 lines 12.3 kB
import { Inject, Injectable, PLATFORM_ID } from '@angular/core'; import { fromEvent, Subject } from 'rxjs'; import { DOCUMENT, isPlatformServer } from '@angular/common'; import { OverlayComponent } from './overlay.component'; import * as i0 from "@angular/core"; const LOWER_INDEX = 100; export class OverlayService { constructor(document, platformId, injector, appRef, cfResolver) { this.document = document; this.platformId = platformId; this.injector = injector; this.appRef = appRef; this.cfResolver = cfResolver; this.currentId = LOWER_INDEX; this.refs = []; } /** * showOverlay runs overlay with specified component * @param options * overlay.model, optional */ createOverlay(options = {}) { if (isPlatformServer(this.platformId)) { return; } const overlay = this.document.createElement('sdk-overlay'); const factory = this.cfResolver.resolveComponentFactory(OverlayComponent); const overlayRef = factory.create(this.injector, [], overlay); this.currentId++; options.index = this.currentId; overlayRef.instance.options = options; this.refs.push(overlayRef); if (options.hideOnEscape) { this.escapeListener(); } this.appRef.attachView(overlayRef.hostView); this.document.body.appendChild(overlay); const result = new Subject(); overlayRef.instance.resultEvent.subscribe((res) => { result.next(res); result.complete(); this.refs.pop(); if (this.refs.length === 0) { if (this.escapeSub) { this.escapeSub.unsubscribe(); } } this.currentId--; this.document.body.removeChild(overlay); this.appRef.detachView(overlayRef.hostView); }); return result.asObservable(); } escapeListener() { if (this.escapeSub && !this.escapeSub.closed) { return; } this.escapeSub = fromEvent(document, 'keyup').subscribe((ev) => { ev.stopPropagation(); ev.preventDefault(); if (ev.code === 'Escape' || ev.key === 'Escape') { this.onResultKey(null); } else if (ev.code === 'Enter' || ev.key === 'Enter') { // this.onResultKey(true); } else if (ev.code === 'Space' || ev.key === 'Space') { // this.onResultKey(); } }); } onResultKey(emitValue) { if (this.refs && this.refs.length) { const dialog = this.refs[this.refs.length - 1]; if (dialog.instance.hideOnEscape) { dialog.instance.closed.emit(emitValue); } } } } OverlayService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: OverlayService, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.Injector }, { token: i0.ApplicationRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Injectable }); OverlayService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: OverlayService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: OverlayService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }, { type: i0.Injector }, { type: i0.ApplicationRef }, { type: i0.ComponentFactoryResolver }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../libs/ngx-slice-kit/src/lib/overlay/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationRef, ComponentFactoryResolver, Inject, Injectable, Injector, PLATFORM_ID } from '@angular/core';\nimport { fromEvent, Observable, Subject, Subscription } from 'rxjs';\nimport { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { OverlayComponent } from './overlay.component';\nimport { OverlayOptions } from './overlay.model';\n\nconst LOWER_INDEX = 100;\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class OverlayService {\n\n    private currentId = LOWER_INDEX;\n    private refs: any = [];\n    public escapeSub: Subscription;\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        @Inject(PLATFORM_ID) private platformId: any,\n        private injector: Injector,\n        private appRef: ApplicationRef,\n        private cfResolver: ComponentFactoryResolver,\n    ) {\n    }\n\n    /**\n     * showOverlay runs overlay with specified component\n     * @param options\n     * overlay.model, optional\n     */\n    public createOverlay(options: OverlayOptions = {}): Observable<any> {\n        if (isPlatformServer(this.platformId)) {\n            return;\n        }\n\n        const overlay = this.document.createElement('sdk-overlay');\n\n        const factory = this.cfResolver.resolveComponentFactory(OverlayComponent);\n        const overlayRef = factory.create(this.injector, [], overlay);\n\n        this.currentId++;\n\n        options.index = this.currentId;\n        overlayRef.instance.options = options;\n        this.refs.push(overlayRef);\n\n        if (options.hideOnEscape) {\n            this.escapeListener();\n        }\n\n        this.appRef.attachView(overlayRef.hostView);\n\n        this.document.body.appendChild(overlay);\n\n        const result = new Subject();\n        overlayRef.instance.resultEvent.subscribe((res: any) => {\n            result.next(res);\n            result.complete();\n            this.refs.pop();\n            if (this.refs.length === 0) {\n                if (this.escapeSub) {\n                    this.escapeSub.unsubscribe();\n                }\n            }\n            this.currentId--;\n            this.document.body.removeChild(overlay);\n            this.appRef.detachView(overlayRef.hostView);\n        });\n\n        return result.asObservable();\n    }\n\n    private escapeListener(): void {\n        if (this.escapeSub && !this.escapeSub.closed) {\n            return;\n        }\n\n        this.escapeSub = fromEvent(document, 'keyup').subscribe((ev: KeyboardEvent) => {\n            ev.stopPropagation();\n            ev.preventDefault();\n            if (ev.code === 'Escape' || ev.key === 'Escape') {\n                this.onResultKey(null);\n            } else if (ev.code === 'Enter' || ev.key === 'Enter') {\n                // this.onResultKey(true);\n            } else if (ev.code === 'Space' || ev.key === 'Space') {\n                // this.onResultKey();\n            }\n        });\n    }\n\n    private onResultKey(emitValue?: any): void {\n        if (this.refs && this.refs.length) {\n            const dialog = this.refs[this.refs.length - 1];\n            if (dialog.instance.hideOnEscape) {\n                dialog.instance.closed.emit(emitValue);\n            }\n        }\n    }\n}\n"]}