@ng-bootstrap/ng-bootstrap
Version:
Angular powered Bootstrap
194 lines • 29.2 kB
JavaScript
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"]}