UNPKG

@ng-bootstrap/ng-bootstrap

Version:
194 lines 29.2 kB
import { DOCUMENT } from '@angular/common'; import { createComponent, EventEmitter, Inject, Injectable, Injector, TemplateRef, } from '@angular/core'; import { finalize } from 'rxjs/operators'; import { Subject } from 'rxjs'; import { ngbFocusTrap } from '../util/focus-trap'; import { ContentRef } from '../util/popup'; import { isDefined, isString } from '../util/util'; import { NgbActiveOffcanvas, NgbOffcanvasRef } from './offcanvas-ref'; import { NgbOffcanvasBackdrop } from './offcanvas-backdrop'; import { NgbOffcanvasPanel } from './offcanvas-panel'; import * as i0 from "@angular/core"; import * as i1 from "../util/scrollbar"; class NgbOffcanvasStack { constructor(_applicationRef, _injector, _document, _scrollBar, _ngZone) { this._applicationRef = _applicationRef; this._injector = _injector; this._document = _document; this._scrollBar = _scrollBar; this._ngZone = _ngZone; this._activePanelCmptHasChanged = new Subject(); this._scrollBarRestoreFn = null; this._backdropAttributes = ['animation', 'backdropClass']; this._panelAttributes = ['animation', 'ariaDescribedBy', 'ariaLabelledBy', 'keyboard', 'panelClass', 'position']; this._activeInstance = new EventEmitter(); // Trap focus on active PanelCmpt this._activePanelCmptHasChanged.subscribe(() => { if (this._panelCmpt) { ngbFocusTrap(this._ngZone, this._panelCmpt.location.nativeElement, this._activePanelCmptHasChanged); } }); } _restoreScrollBar() { const scrollBarRestoreFn = this._scrollBarRestoreFn; if (scrollBarRestoreFn) { this._scrollBarRestoreFn = null; scrollBarRestoreFn(); } } _hideScrollBar() { if (!this._scrollBarRestoreFn) { this._scrollBarRestoreFn = this._scrollBar.hide(); } } open(contentInjector, content, options) { const containerEl = options.container instanceof HTMLElement ? options.container : isDefined(options.container) ? this._document.querySelector(options.container) : this._document.body; if (!containerEl) { throw new Error(`The specified offcanvas container "${options.container || 'body'}" was not found in the DOM.`); } if (!options.scroll) { this._hideScrollBar(); } const activeOffcanvas = new NgbActiveOffcanvas(); const contentRef = this._getContentRef(options.injector || contentInjector, content, activeOffcanvas); let backdropCmptRef = options.backdrop !== false ? this._attachBackdrop(containerEl) : undefined; let panelCmptRef = this._attachWindowComponent(containerEl, contentRef.nodes); let ngbOffcanvasRef = new NgbOffcanvasRef(panelCmptRef, contentRef, backdropCmptRef, options.beforeDismiss); this._registerOffcanvasRef(ngbOffcanvasRef); this._registerPanelCmpt(panelCmptRef); ngbOffcanvasRef.hidden.pipe(finalize(() => this._restoreScrollBar())).subscribe(); activeOffcanvas.close = (result) => { ngbOffcanvasRef.close(result); }; activeOffcanvas.dismiss = (reason) => { ngbOffcanvasRef.dismiss(reason); }; this._applyPanelOptions(panelCmptRef.instance, options); if (backdropCmptRef && backdropCmptRef.instance) { this._applyBackdropOptions(backdropCmptRef.instance, options); backdropCmptRef.changeDetectorRef.detectChanges(); } panelCmptRef.changeDetectorRef.detectChanges(); return ngbOffcanvasRef; } get activeInstance() { return this._activeInstance; } dismiss(reason) { this._offcanvasRef?.dismiss(reason); } hasOpenOffcanvas() { return !!this._offcanvasRef; } _attachBackdrop(containerEl) { let backdropCmptRef = createComponent(NgbOffcanvasBackdrop, { environmentInjector: this._applicationRef.injector, elementInjector: this._injector, }); this._applicationRef.attachView(backdropCmptRef.hostView); containerEl.appendChild(backdropCmptRef.location.nativeElement); return backdropCmptRef; } _attachWindowComponent(containerEl, projectableNodes) { let panelCmptRef = createComponent(NgbOffcanvasPanel, { environmentInjector: this._applicationRef.injector, elementInjector: this._injector, projectableNodes, }); this._applicationRef.attachView(panelCmptRef.hostView); containerEl.appendChild(panelCmptRef.location.nativeElement); return panelCmptRef; } _applyPanelOptions(windowInstance, options) { this._panelAttributes.forEach((optionName) => { if (isDefined(options[optionName])) { windowInstance[optionName] = options[optionName]; } }); } _applyBackdropOptions(backdropInstance, options) { this._backdropAttributes.forEach((optionName) => { if (isDefined(options[optionName])) { backdropInstance[optionName] = options[optionName]; } }); backdropInstance.static = options.backdrop === 'static'; } _getContentRef(contentInjector, content, activeOffcanvas) { if (!content) { return new ContentRef([]); } else if (content instanceof TemplateRef) { return this._createFromTemplateRef(content, activeOffcanvas); } else if (isString(content)) { return this._createFromString(content); } else { return this._createFromComponent(contentInjector, content, activeOffcanvas); } } _createFromTemplateRef(templateRef, activeOffcanvas) { const context = { $implicit: activeOffcanvas, close(result) { activeOffcanvas.close(result); }, dismiss(reason) { activeOffcanvas.dismiss(reason); }, }; const viewRef = templateRef.createEmbeddedView(context); this._applicationRef.attachView(viewRef); return new ContentRef([viewRef.rootNodes], viewRef); } _createFromString(content) { const component = this._document.createTextNode(`${content}`); return new ContentRef([[component]]); } _createFromComponent(contentInjector, componentType, context) { const elementInjector = Injector.create({ providers: [{ provide: NgbActiveOffcanvas, useValue: context }], parent: contentInjector, }); const componentRef = createComponent(componentType, { environmentInjector: this._applicationRef.injector, elementInjector, }); const componentNativeEl = componentRef.location.nativeElement; this._applicationRef.attachView(componentRef.hostView); return new ContentRef([[componentNativeEl]], componentRef.hostView, componentRef); } _registerOffcanvasRef(ngbOffcanvasRef) { const unregisterOffcanvasRef = () => { this._offcanvasRef = undefined; this._activeInstance.emit(this._offcanvasRef); }; this._offcanvasRef = ngbOffcanvasRef; this._activeInstance.emit(this._offcanvasRef); ngbOffcanvasRef.result.then(unregisterOffcanvasRef, unregisterOffcanvasRef); } _registerPanelCmpt(ngbPanelCmpt) { this._panelCmpt = ngbPanelCmpt; this._activePanelCmptHasChanged.next(); ngbPanelCmpt.onDestroy(() => { this._panelCmpt = undefined; this._activePanelCmptHasChanged.next(); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbOffcanvasStack, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: DOCUMENT }, { token: i1.ScrollBar }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbOffcanvasStack, providedIn: 'root' }); } } export { NgbOffcanvasStack }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbOffcanvasStack, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i1.ScrollBar }, { type: i0.NgZone }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"offcanvas-stack.js","sourceRoot":"","sources":["../../../../src/offcanvas/offcanvas-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n\tApplicationRef,\n\tComponentRef,\n\tcreateComponent,\n\tEventEmitter,\n\tInject,\n\tInjectable,\n\tInjector,\n\tNgZone,\n\tTemplateRef,\n\tType,\n} from '@angular/core';\nimport { finalize } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\nimport { ngbFocusTrap } from '../util/focus-trap';\nimport { ContentRef } from '../util/popup';\nimport { ScrollBar } from '../util/scrollbar';\nimport { isDefined, isString } from '../util/util';\nimport { NgbActiveOffcanvas, NgbOffcanvasRef } from './offcanvas-ref';\nimport { NgbOffcanvasOptions } from './offcanvas-config';\nimport { NgbOffcanvasBackdrop } from './offcanvas-backdrop';\nimport { NgbOffcanvasPanel } from './offcanvas-panel';\n\n@Injectable({ providedIn: 'root' })\nexport class NgbOffcanvasStack {\n\tprivate _activePanelCmptHasChanged = new Subject<void>();\n\tprivate _scrollBarRestoreFn: null | (() => void) = null;\n\tprivate _backdropAttributes = ['animation', 'backdropClass'];\n\tprivate _offcanvasRef?: NgbOffcanvasRef;\n\tprivate _panelAttributes = ['animation', 'ariaDescribedBy', 'ariaLabelledBy', 'keyboard', 'panelClass', 'position'];\n\tprivate _panelCmpt?: ComponentRef<NgbOffcanvasPanel>;\n\tprivate _activeInstance: EventEmitter<NgbOffcanvasRef | undefined> = new EventEmitter();\n\n\tconstructor(\n\t\tprivate _applicationRef: ApplicationRef,\n\t\tprivate _injector: Injector,\n\t\t@Inject(DOCUMENT) private _document: any,\n\t\tprivate _scrollBar: ScrollBar,\n\t\tprivate _ngZone: NgZone,\n\t) {\n\t\t// Trap focus on active PanelCmpt\n\t\tthis._activePanelCmptHasChanged.subscribe(() => {\n\t\t\tif (this._panelCmpt) {\n\t\t\t\tngbFocusTrap(this._ngZone, this._panelCmpt.location.nativeElement, this._activePanelCmptHasChanged);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate _restoreScrollBar() {\n\t\tconst scrollBarRestoreFn = this._scrollBarRestoreFn;\n\t\tif (scrollBarRestoreFn) {\n\t\t\tthis._scrollBarRestoreFn = null;\n\t\t\tscrollBarRestoreFn();\n\t\t}\n\t}\n\n\tprivate _hideScrollBar() {\n\t\tif (!this._scrollBarRestoreFn) {\n\t\t\tthis._scrollBarRestoreFn = this._scrollBar.hide();\n\t\t}\n\t}\n\n\topen(contentInjector: Injector, content: any, options: NgbOffcanvasOptions): NgbOffcanvasRef {\n\t\tconst containerEl =\n\t\t\toptions.container instanceof HTMLElement\n\t\t\t\t? options.container\n\t\t\t\t: isDefined(options.container)\n\t\t\t\t? this._document.querySelector(options.container)\n\t\t\t\t: this._document.body;\n\t\tif (!containerEl) {\n\t\t\tthrow new Error(`The specified offcanvas container \"${options.container || 'body'}\" was not found in the DOM.`);\n\t\t}\n\n\t\tif (!options.scroll) {\n\t\t\tthis._hideScrollBar();\n\t\t}\n\n\t\tconst activeOffcanvas = new NgbActiveOffcanvas();\n\t\tconst contentRef = this._getContentRef(options.injector || contentInjector, content, activeOffcanvas);\n\n\t\tlet backdropCmptRef: ComponentRef<NgbOffcanvasBackdrop> | undefined =\n\t\t\toptions.backdrop !== false ? this._attachBackdrop(containerEl) : undefined;\n\t\tlet panelCmptRef: ComponentRef<NgbOffcanvasPanel> = this._attachWindowComponent(containerEl, contentRef.nodes);\n\t\tlet ngbOffcanvasRef: NgbOffcanvasRef = new NgbOffcanvasRef(\n\t\t\tpanelCmptRef,\n\t\t\tcontentRef,\n\t\t\tbackdropCmptRef,\n\t\t\toptions.beforeDismiss,\n\t\t);\n\n\t\tthis._registerOffcanvasRef(ngbOffcanvasRef);\n\t\tthis._registerPanelCmpt(panelCmptRef);\n\t\tngbOffcanvasRef.hidden.pipe(finalize(() => this._restoreScrollBar())).subscribe();\n\t\tactiveOffcanvas.close = (result: any) => {\n\t\t\tngbOffcanvasRef.close(result);\n\t\t};\n\t\tactiveOffcanvas.dismiss = (reason: any) => {\n\t\t\tngbOffcanvasRef.dismiss(reason);\n\t\t};\n\n\t\tthis._applyPanelOptions(panelCmptRef.instance, options);\n\n\t\tif (backdropCmptRef && backdropCmptRef.instance) {\n\t\t\tthis._applyBackdropOptions(backdropCmptRef.instance, options);\n\t\t\tbackdropCmptRef.changeDetectorRef.detectChanges();\n\t\t}\n\t\tpanelCmptRef.changeDetectorRef.detectChanges();\n\t\treturn ngbOffcanvasRef;\n\t}\n\n\tget activeInstance() {\n\t\treturn this._activeInstance;\n\t}\n\n\tdismiss(reason?: any) {\n\t\tthis._offcanvasRef?.dismiss(reason);\n\t}\n\n\thasOpenOffcanvas(): boolean {\n\t\treturn !!this._offcanvasRef;\n\t}\n\n\tprivate _attachBackdrop(containerEl: Element): ComponentRef<NgbOffcanvasBackdrop> {\n\t\tlet backdropCmptRef = createComponent(NgbOffcanvasBackdrop, {\n\t\t\tenvironmentInjector: this._applicationRef.injector,\n\t\t\telementInjector: this._injector,\n\t\t});\n\t\tthis._applicationRef.attachView(backdropCmptRef.hostView);\n\t\tcontainerEl.appendChild(backdropCmptRef.location.nativeElement);\n\t\treturn backdropCmptRef;\n\t}\n\n\tprivate _attachWindowComponent(containerEl: Element, projectableNodes: Node[][]): ComponentRef<NgbOffcanvasPanel> {\n\t\tlet panelCmptRef = createComponent(NgbOffcanvasPanel, {\n\t\t\tenvironmentInjector: this._applicationRef.injector,\n\t\t\telementInjector: this._injector,\n\t\t\tprojectableNodes,\n\t\t});\n\t\tthis._applicationRef.attachView(panelCmptRef.hostView);\n\t\tcontainerEl.appendChild(panelCmptRef.location.nativeElement);\n\t\treturn panelCmptRef;\n\t}\n\n\tprivate _applyPanelOptions(windowInstance: NgbOffcanvasPanel, options: NgbOffcanvasOptions): void {\n\t\tthis._panelAttributes.forEach((optionName: string) => {\n\t\t\tif (isDefined(options[optionName])) {\n\t\t\t\twindowInstance[optionName] = options[optionName];\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate _applyBackdropOptions(backdropInstance: NgbOffcanvasBackdrop, options: NgbOffcanvasOptions): void {\n\t\tthis._backdropAttributes.forEach((optionName: string) => {\n\t\t\tif (isDefined(options[optionName])) {\n\t\t\t\tbackdropInstance[optionName] = options[optionName];\n\t\t\t}\n\t\t});\n\t\tbackdropInstance.static = options.backdrop === 'static';\n\t}\n\n\tprivate _getContentRef(\n\t\tcontentInjector: Injector,\n\t\tcontent: Type<any> | TemplateRef<any> | string,\n\t\tactiveOffcanvas: NgbActiveOffcanvas,\n\t): ContentRef {\n\t\tif (!content) {\n\t\t\treturn new ContentRef([]);\n\t\t} else if (content instanceof TemplateRef) {\n\t\t\treturn this._createFromTemplateRef(content, activeOffcanvas);\n\t\t} else if (isString(content)) {\n\t\t\treturn this._createFromString(content);\n\t\t} else {\n\t\t\treturn this._createFromComponent(contentInjector, content, activeOffcanvas);\n\t\t}\n\t}\n\n\tprivate _createFromTemplateRef(templateRef: TemplateRef<any>, activeOffcanvas: NgbActiveOffcanvas): ContentRef {\n\t\tconst context = {\n\t\t\t$implicit: activeOffcanvas,\n\t\t\tclose(result) {\n\t\t\t\tactiveOffcanvas.close(result);\n\t\t\t},\n\t\t\tdismiss(reason) {\n\t\t\t\tactiveOffcanvas.dismiss(reason);\n\t\t\t},\n\t\t};\n\t\tconst viewRef = templateRef.createEmbeddedView(context);\n\t\tthis._applicationRef.attachView(viewRef);\n\t\treturn new ContentRef([viewRef.rootNodes], viewRef);\n\t}\n\n\tprivate _createFromString(content: string): ContentRef {\n\t\tconst component = this._document.createTextNode(`${content}`);\n\t\treturn new ContentRef([[component]]);\n\t}\n\n\tprivate _createFromComponent(\n\t\tcontentInjector: Injector,\n\t\tcomponentType: Type<any>,\n\t\tcontext: NgbActiveOffcanvas,\n\t): ContentRef {\n\t\tconst elementInjector = Injector.create({\n\t\t\tproviders: [{ provide: NgbActiveOffcanvas, useValue: context }],\n\t\t\tparent: contentInjector,\n\t\t});\n\t\tconst componentRef = createComponent(componentType, {\n\t\t\tenvironmentInjector: this._applicationRef.injector,\n\t\t\telementInjector,\n\t\t});\n\t\tconst componentNativeEl = componentRef.location.nativeElement;\n\t\tthis._applicationRef.attachView(componentRef.hostView);\n\t\treturn new ContentRef([[componentNativeEl]], componentRef.hostView, componentRef);\n\t}\n\n\tprivate _registerOffcanvasRef(ngbOffcanvasRef: NgbOffcanvasRef) {\n\t\tconst unregisterOffcanvasRef = () => {\n\t\t\tthis._offcanvasRef = undefined;\n\t\t\tthis._activeInstance.emit(this._offcanvasRef);\n\t\t};\n\t\tthis._offcanvasRef = ngbOffcanvasRef;\n\t\tthis._activeInstance.emit(this._offcanvasRef);\n\t\tngbOffcanvasRef.result.then(unregisterOffcanvasRef, unregisterOffcanvasRef);\n\t}\n\n\tprivate _registerPanelCmpt(ngbPanelCmpt: ComponentRef<NgbOffcanvasPanel>) {\n\t\tthis._panelCmpt = ngbPanelCmpt;\n\t\tthis._activePanelCmptHasChanged.next();\n\n\t\tngbPanelCmpt.onDestroy(() => {\n\t\t\tthis._panelCmpt = undefined;\n\t\t\tthis._activePanelCmptHasChanged.next();\n\t\t});\n\t}\n}\n"]}