| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 |
- /**
- * @fileoverview added by tsickle
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
- */
- import { DOCUMENT } from '@angular/common';
- import { Component, ElementRef, EventEmitter, Inject, Input, NgZone, Output, ViewChild, ViewEncapsulation } from '@angular/core';
- import { fromEvent, Subject } from 'rxjs';
- import { filter, switchMap, take, takeUntil, tap } from 'rxjs/operators';
- import { getFocusableBoundaryElements } from '../util/focus-trap';
- import { Key } from '../util/key';
- import { ModalDismissReasons } from './modal-dismiss-reasons';
- var NgbModalWindow = /** @class */ (function () {
- function NgbModalWindow(_document, _elRef, _zone) {
- this._document = _document;
- this._elRef = _elRef;
- this._zone = _zone;
- this._closed$ = new Subject();
- this.backdrop = true;
- this.keyboard = true;
- this.dismissEvent = new EventEmitter();
- }
- /**
- * @param {?} reason
- * @return {?}
- */
- NgbModalWindow.prototype.dismiss = /**
- * @param {?} reason
- * @return {?}
- */
- function (reason) { this.dismissEvent.emit(reason); };
- /**
- * @return {?}
- */
- NgbModalWindow.prototype.ngOnInit = /**
- * @return {?}
- */
- function () { this._elWithFocus = this._document.activeElement; };
- /**
- * @return {?}
- */
- NgbModalWindow.prototype.ngAfterViewInit = /**
- * @return {?}
- */
- function () {
- var _this = this;
- var nativeElement = this._elRef.nativeElement;
- this._zone.runOutsideAngular((/**
- * @return {?}
- */
- function () {
- fromEvent(nativeElement, 'keydown')
- .pipe(takeUntil(_this._closed$),
- // tslint:disable-next-line:deprecation
- filter((/**
- * @param {?} e
- * @return {?}
- */
- function (e) { return e.which === Key.Escape && _this.keyboard; })))
- .subscribe((/**
- * @param {?} event
- * @return {?}
- */
- function (event) { return requestAnimationFrame((/**
- * @return {?}
- */
- function () {
- if (!event.defaultPrevented) {
- _this._zone.run((/**
- * @return {?}
- */
- function () { return _this.dismiss(ModalDismissReasons.ESC); }));
- }
- })); }));
- // We're listening to 'mousedown' and 'mouseup' to prevent modal from closing when pressing the mouse
- // inside the modal dialog and releasing it outside
- /** @type {?} */
- var preventClose = false;
- fromEvent(_this._dialogEl.nativeElement, 'mousedown')
- .pipe(takeUntil(_this._closed$), tap((/**
- * @return {?}
- */
- function () { return preventClose = false; })), switchMap((/**
- * @return {?}
- */
- function () { return fromEvent(nativeElement, 'mouseup').pipe(takeUntil(_this._closed$), take(1)); })), filter((/**
- * @param {?} __0
- * @return {?}
- */
- function (_a) {
- var target = _a.target;
- return nativeElement === target;
- })))
- .subscribe((/**
- * @return {?}
- */
- function () { preventClose = true; }));
- // We're listening to 'click' to dismiss modal on modal window click, except when:
- // 1. clicking on modal dialog itself
- // 2. closing was prevented by mousedown/up handlers
- // 3. clicking on scrollbar when the viewport is too small and modal doesn't fit (click is not triggered at all)
- fromEvent(nativeElement, 'click').pipe(takeUntil(_this._closed$)).subscribe((/**
- * @param {?} __0
- * @return {?}
- */
- function (_a) {
- var target = _a.target;
- if (_this.backdrop === true && nativeElement === target && !preventClose) {
- _this._zone.run((/**
- * @return {?}
- */
- function () { return _this.dismiss(ModalDismissReasons.BACKDROP_CLICK); }));
- }
- preventClose = false;
- }));
- }));
- if (!nativeElement.contains(document.activeElement)) {
- /** @type {?} */
- var autoFocusable = (/** @type {?} */ (nativeElement.querySelector("[ngbAutofocus]")));
- /** @type {?} */
- var firstFocusable = getFocusableBoundaryElements(nativeElement)[0];
- /** @type {?} */
- var elementToFocus = autoFocusable || firstFocusable || nativeElement;
- elementToFocus.focus();
- }
- };
- /**
- * @return {?}
- */
- NgbModalWindow.prototype.ngOnDestroy = /**
- * @return {?}
- */
- function () {
- var _this = this;
- /** @type {?} */
- var body = this._document.body;
- /** @type {?} */
- var elWithFocus = this._elWithFocus;
- /** @type {?} */
- var elementToFocus;
- if (elWithFocus && elWithFocus['focus'] && body.contains(elWithFocus)) {
- elementToFocus = elWithFocus;
- }
- else {
- elementToFocus = body;
- }
- this._zone.runOutsideAngular((/**
- * @return {?}
- */
- function () {
- setTimeout((/**
- * @return {?}
- */
- function () { return elementToFocus.focus(); }));
- _this._elWithFocus = null;
- }));
- this._closed$.next();
- };
- NgbModalWindow.decorators = [
- { type: Component, args: [{
- selector: 'ngb-modal-window',
- host: {
- '[class]': '"modal fade show d-block" + (windowClass ? " " + windowClass : "")',
- 'role': 'dialog',
- 'tabindex': '-1',
- '[attr.aria-modal]': 'true',
- '[attr.aria-labelledby]': 'ariaLabelledBy',
- },
- template: "\n <div #dialog [class]=\"'modal-dialog' + (size ? ' modal-' + size : '') + (centered ? ' modal-dialog-centered' : '') +\n (scrollable ? ' modal-dialog-scrollable' : '')\" role=\"document\">\n <div class=\"modal-content\"><ng-content></ng-content></div>\n </div>\n ",
- encapsulation: ViewEncapsulation.None,
- styles: ["ngb-modal-window .component-host-scrollable{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;overflow:hidden}"]
- }] }
- ];
- /** @nocollapse */
- NgbModalWindow.ctorParameters = function () { return [
- { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
- { type: ElementRef },
- { type: NgZone }
- ]; };
- NgbModalWindow.propDecorators = {
- _dialogEl: [{ type: ViewChild, args: ['dialog', { static: true },] }],
- ariaLabelledBy: [{ type: Input }],
- backdrop: [{ type: Input }],
- centered: [{ type: Input }],
- keyboard: [{ type: Input }],
- scrollable: [{ type: Input }],
- size: [{ type: Input }],
- windowClass: [{ type: Input }],
- dismissEvent: [{ type: Output, args: ['dismiss',] }]
- };
- return NgbModalWindow;
- }());
- export { NgbModalWindow };
- if (false) {
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._closed$;
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._elWithFocus;
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._dialogEl;
- /** @type {?} */
- NgbModalWindow.prototype.ariaLabelledBy;
- /** @type {?} */
- NgbModalWindow.prototype.backdrop;
- /** @type {?} */
- NgbModalWindow.prototype.centered;
- /** @type {?} */
- NgbModalWindow.prototype.keyboard;
- /** @type {?} */
- NgbModalWindow.prototype.scrollable;
- /** @type {?} */
- NgbModalWindow.prototype.size;
- /** @type {?} */
- NgbModalWindow.prototype.windowClass;
- /** @type {?} */
- NgbModalWindow.prototype.dismissEvent;
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._document;
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._elRef;
- /**
- * @type {?}
- * @private
- */
- NgbModalWindow.prototype._zone;
- }
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-window.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["modal/modal-window.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {fromEvent, Subject} from 'rxjs';\nimport {filter, switchMap, take, takeUntil, tap} from 'rxjs/operators';\n\nimport {getFocusableBoundaryElements} from '../util/focus-trap';\nimport {Key} from '../util/key';\nimport {ModalDismissReasons} from './modal-dismiss-reasons';\n\n@Component({\n  selector: 'ngb-modal-window',\n  host: {\n    '[class]': '\"modal fade show d-block\" + (windowClass ? \" \" + windowClass : \"\")',\n    'role': 'dialog',\n    'tabindex': '-1',\n    '[attr.aria-modal]': 'true',\n    '[attr.aria-labelledby]': 'ariaLabelledBy',\n  },\n  template: `\n    <div #dialog [class]=\"'modal-dialog' + (size ? ' modal-' + size : '') + (centered ? ' modal-dialog-centered' : '') +\n     (scrollable ? ' modal-dialog-scrollable' : '')\" role=\"document\">\n        <div class=\"modal-content\"><ng-content></ng-content></div>\n    </div>\n    `,\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./modal.scss']\n})\nexport class NgbModalWindow implements OnInit,\n    AfterViewInit, OnDestroy {\n  private _closed$ = new Subject<void>();\n  private _elWithFocus: Element;  // element that is focused prior to modal opening\n\n  @ViewChild('dialog', {static: true}) private _dialogEl: ElementRef<HTMLElement>;\n\n  @Input() ariaLabelledBy: string;\n  @Input() backdrop: boolean | string = true;\n  @Input() centered: string;\n  @Input() keyboard = true;\n  @Input() scrollable: string;\n  @Input() size: string;\n  @Input() windowClass: string;\n\n  @Output('dismiss') dismissEvent = new EventEmitter();\n\n  constructor(\n      @Inject(DOCUMENT) private _document: any, private _elRef: ElementRef<HTMLElement>, private _zone: NgZone) {}\n\n  dismiss(reason): void { this.dismissEvent.emit(reason); }\n\n  ngOnInit() { this._elWithFocus = this._document.activeElement; }\n\n  ngAfterViewInit() {\n    const {nativeElement} = this._elRef;\n    this._zone.runOutsideAngular(() => {\n\n      fromEvent<KeyboardEvent>(nativeElement, 'keydown')\n          .pipe(\n              takeUntil(this._closed$),\n              // tslint:disable-next-line:deprecation\n              filter(e => e.which === Key.Escape && this.keyboard))\n          .subscribe(event => requestAnimationFrame(() => {\n                       if (!event.defaultPrevented) {\n                         this._zone.run(() => this.dismiss(ModalDismissReasons.ESC));\n                       }\n                     }));\n\n      // We're listening to 'mousedown' and 'mouseup' to prevent modal from closing when pressing the mouse\n      // inside the modal dialog and releasing it outside\n      let preventClose = false;\n      fromEvent<MouseEvent>(this._dialogEl.nativeElement, 'mousedown')\n          .pipe(\n              takeUntil(this._closed$), tap(() => preventClose = false),\n              switchMap(() => fromEvent<MouseEvent>(nativeElement, 'mouseup').pipe(takeUntil(this._closed$), take(1))),\n              filter(({target}) => nativeElement === target))\n          .subscribe(() => { preventClose = true; });\n\n      // We're listening to 'click' to dismiss modal on modal window click, except when:\n      // 1. clicking on modal dialog itself\n      // 2. closing was prevented by mousedown/up handlers\n      // 3. clicking on scrollbar when the viewport is too small and modal doesn't fit (click is not triggered at all)\n      fromEvent<MouseEvent>(nativeElement, 'click').pipe(takeUntil(this._closed$)).subscribe(({target}) => {\n        if (this.backdrop === true && nativeElement === target && !preventClose) {\n          this._zone.run(() => this.dismiss(ModalDismissReasons.BACKDROP_CLICK));\n        }\n        preventClose = false;\n      });\n    });\n\n    if (!nativeElement.contains(document.activeElement)) {\n      const autoFocusable = nativeElement.querySelector(`[ngbAutofocus]`) as HTMLElement;\n      const firstFocusable = getFocusableBoundaryElements(nativeElement)[0];\n\n      const elementToFocus = autoFocusable || firstFocusable || nativeElement;\n      elementToFocus.focus();\n    }\n  }\n\n  ngOnDestroy() {\n    const body = this._document.body;\n    const elWithFocus = this._elWithFocus;\n\n    let elementToFocus;\n    if (elWithFocus && elWithFocus['focus'] && body.contains(elWithFocus)) {\n      elementToFocus = elWithFocus;\n    } else {\n      elementToFocus = body;\n    }\n    this._zone.runOutsideAngular(() => {\n      setTimeout(() => elementToFocus.focus());\n      this._elWithFocus = null;\n    });\n\n    this._closed$.next();\n  }\n}\n"]}
|