/** * @fileoverview added by tsickle * Generated from: src/material/dialog/dialog-ref.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes'; import { Subject } from 'rxjs'; import { filter, take } from 'rxjs/operators'; // TODO(jelbourn): resizing // Counter for unique dialog ids. /** @type {?} */ let uniqueId = 0; /** @enum {number} */ const MatDialogState = { OPEN: 0, CLOSING: 1, CLOSED: 2, }; export { MatDialogState }; /** * Reference to a dialog opened via the MatDialog service. * @template T, R */ export class MatDialogRef { /** * @param {?} _overlayRef * @param {?} _containerInstance * @param {?=} id */ constructor(_overlayRef, _containerInstance, id = `mat-dialog-${uniqueId++}`) { this._overlayRef = _overlayRef; this._containerInstance = _containerInstance; this.id = id; /** * Whether the user is allowed to close the dialog. */ this.disableClose = this._containerInstance._config.disableClose; /** * Subject for notifying the user that the dialog has finished opening. */ this._afterOpened = new Subject(); /** * Subject for notifying the user that the dialog has finished closing. */ this._afterClosed = new Subject(); /** * Subject for notifying the user that the dialog has started closing. */ this._beforeClosed = new Subject(); /** * Current state of the dialog. */ this._state = 0 /* OPEN */; // Pass the id along to the container. _containerInstance._id = id; // Emit when opening animation completes _containerInstance._animationStateChanged.pipe(filter((/** * @param {?} event * @return {?} */ event => event.phaseName === 'done' && event.toState === 'enter')), take(1)) .subscribe((/** * @return {?} */ () => { this._afterOpened.next(); this._afterOpened.complete(); })); // Dispose overlay when closing animation is complete _containerInstance._animationStateChanged.pipe(filter((/** * @param {?} event * @return {?} */ event => event.phaseName === 'done' && event.toState === 'exit')), take(1)).subscribe((/** * @return {?} */ () => { clearTimeout(this._closeFallbackTimeout); this._overlayRef.dispose(); })); _overlayRef.detachments().subscribe((/** * @return {?} */ () => { this._beforeClosed.next(this._result); this._beforeClosed.complete(); this._afterClosed.next(this._result); this._afterClosed.complete(); this.componentInstance = (/** @type {?} */ (null)); this._overlayRef.dispose(); })); _overlayRef.keydownEvents() .pipe(filter((/** * @param {?} event * @return {?} */ event => { return event.keyCode === ESCAPE && !this.disableClose && !hasModifierKey(event); }))) .subscribe((/** * @param {?} event * @return {?} */ event => { event.preventDefault(); this.close(); })); } /** * Close the dialog. * @param {?=} dialogResult Optional result to return to the dialog opener. * @return {?} */ close(dialogResult) { this._result = dialogResult; // Transition the backdrop in parallel to the dialog. this._containerInstance._animationStateChanged.pipe(filter((/** * @param {?} event * @return {?} */ event => event.phaseName === 'start')), take(1)) .subscribe((/** * @param {?} event * @return {?} */ event => { this._beforeClosed.next(dialogResult); this._beforeClosed.complete(); this._state = 2 /* CLOSED */; this._overlayRef.detachBackdrop(); // The logic that disposes of the overlay depends on the exit animation completing, however // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback // timeout which will clean everything up if the animation hasn't fired within the specified // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the // vast majority of cases the timeout will have been cleared before it has the chance to fire. this._closeFallbackTimeout = setTimeout((/** * @return {?} */ () => { this._overlayRef.dispose(); }), event.totalTime + 100); })); this._containerInstance._startExitAnimation(); this._state = 1 /* CLOSING */; } /** * Gets an observable that is notified when the dialog is finished opening. * @return {?} */ afterOpened() { return this._afterOpened.asObservable(); } /** * Gets an observable that is notified when the dialog is finished closing. * @return {?} */ afterClosed() { return this._afterClosed.asObservable(); } /** * Gets an observable that is notified when the dialog has started closing. * @return {?} */ beforeClosed() { return this._beforeClosed.asObservable(); } /** * Gets an observable that emits when the overlay's backdrop has been clicked. * @return {?} */ backdropClick() { return this._overlayRef.backdropClick(); } /** * Gets an observable that emits when keydown events are targeted on the overlay. * @return {?} */ keydownEvents() { return this._overlayRef.keydownEvents(); } /** * Updates the dialog's position. * @template THIS * @this {THIS} * @param {?=} position New dialog position. * @return {THIS} */ updatePosition(position) { /** @type {?} */ let strategy = (/** @type {?} */ (this))._getPositionStrategy(); if (position && (position.left || position.right)) { position.left ? strategy.left(position.left) : strategy.right(position.right); } else { strategy.centerHorizontally(); } if (position && (position.top || position.bottom)) { position.top ? strategy.top(position.top) : strategy.bottom(position.bottom); } else { strategy.centerVertically(); } (/** @type {?} */ (this))._overlayRef.updatePosition(); return (/** @type {?} */ (this)); } /** * Updates the dialog's width and height. * @template THIS * @this {THIS} * @param {?=} width New width of the dialog. * @param {?=} height New height of the dialog. * @return {THIS} */ updateSize(width = '', height = '') { (/** @type {?} */ (this))._getPositionStrategy().width(width).height(height); (/** @type {?} */ (this))._overlayRef.updatePosition(); return (/** @type {?} */ (this)); } /** * Add a CSS class or an array of classes to the overlay pane. * @template THIS * @this {THIS} * @param {?} classes * @return {THIS} */ addPanelClass(classes) { (/** @type {?} */ (this))._overlayRef.addPanelClass(classes); return (/** @type {?} */ (this)); } /** * Remove a CSS class or an array of classes from the overlay pane. * @template THIS * @this {THIS} * @param {?} classes * @return {THIS} */ removePanelClass(classes) { (/** @type {?} */ (this))._overlayRef.removePanelClass(classes); return (/** @type {?} */ (this)); } /** * Gets the current state of the dialog's lifecycle. * @return {?} */ getState() { return this._state; } /** * Fetches the position strategy object from the overlay ref. * @private * @return {?} */ _getPositionStrategy() { return (/** @type {?} */ (this._overlayRef.getConfig().positionStrategy)); } } if (false) { /** * The instance of component opened into the dialog. * @type {?} */ MatDialogRef.prototype.componentInstance; /** * Whether the user is allowed to close the dialog. * @type {?} */ MatDialogRef.prototype.disableClose; /** * Subject for notifying the user that the dialog has finished opening. * @type {?} * @private */ MatDialogRef.prototype._afterOpened; /** * Subject for notifying the user that the dialog has finished closing. * @type {?} * @private */ MatDialogRef.prototype._afterClosed; /** * Subject for notifying the user that the dialog has started closing. * @type {?} * @private */ MatDialogRef.prototype._beforeClosed; /** * Result to be passed to afterClosed. * @type {?} * @private */ MatDialogRef.prototype._result; /** * Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. * @type {?} * @private */ MatDialogRef.prototype._closeFallbackTimeout; /** * Current state of the dialog. * @type {?} * @private */ MatDialogRef.prototype._state; /** * @type {?} * @private */ MatDialogRef.prototype._overlayRef; /** @type {?} */ MatDialogRef.prototype._containerInstance; /** @type {?} */ MatDialogRef.prototype.id; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-ref.js","sourceRoot":"","sources":["../../../../../../src/material/dialog/dialog-ref.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ESCAPE, hasModifierKey} from '@angular/cdk/keycodes';\nimport {GlobalPositionStrategy, OverlayRef} from '@angular/cdk/overlay';\nimport {Observable, Subject} from 'rxjs';\nimport {filter, take} from 'rxjs/operators';\nimport {DialogPosition} from './dialog-config';\nimport {MatDialogContainer} from './dialog-container';\n\n\n// TODO(jelbourn): resizing\n\n// Counter for unique dialog ids.\nlet uniqueId = 0;\n\n/** Possible states of the lifecycle of a dialog. */\nexport const enum MatDialogState {OPEN, CLOSING, CLOSED}\n\n/**\n * Reference to a dialog opened via the MatDialog service.\n */\nexport class MatDialogRef<T, R = any> {\n  /** The instance of component opened into the dialog. */\n  componentInstance: T;\n\n  /** Whether the user is allowed to close the dialog. */\n  disableClose: boolean | undefined = this._containerInstance._config.disableClose;\n\n  /** Subject for notifying the user that the dialog has finished opening. */\n  private readonly _afterOpened = new Subject<void>();\n\n  /** Subject for notifying the user that the dialog has finished closing. */\n  private readonly _afterClosed = new Subject<R | undefined>();\n\n  /** Subject for notifying the user that the dialog has started closing. */\n  private readonly _beforeClosed = new Subject<R | undefined>();\n\n  /** Result to be passed to afterClosed. */\n  private _result: R | undefined;\n\n  /** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */\n  private _closeFallbackTimeout: number;\n\n  /** Current state of the dialog. */\n  private _state = MatDialogState.OPEN;\n\n  constructor(\n    private _overlayRef: OverlayRef,\n    public _containerInstance: MatDialogContainer,\n    readonly id: string = `mat-dialog-${uniqueId++}`) {\n\n    // Pass the id along to the container.\n    _containerInstance._id = id;\n\n    // Emit when opening animation completes\n    _containerInstance._animationStateChanged.pipe(\n      filter(event => event.phaseName === 'done' && event.toState === 'enter'),\n      take(1)\n    )\n    .subscribe(() => {\n      this._afterOpened.next();\n      this._afterOpened.complete();\n    });\n\n    // Dispose overlay when closing animation is complete\n    _containerInstance._animationStateChanged.pipe(\n      filter(event => event.phaseName === 'done' && event.toState === 'exit'),\n      take(1)\n    ).subscribe(() => {\n      clearTimeout(this._closeFallbackTimeout);\n      this._overlayRef.dispose();\n    });\n\n    _overlayRef.detachments().subscribe(() => {\n      this._beforeClosed.next(this._result);\n      this._beforeClosed.complete();\n      this._afterClosed.next(this._result);\n      this._afterClosed.complete();\n      this.componentInstance = null!;\n      this._overlayRef.dispose();\n    });\n\n    _overlayRef.keydownEvents()\n      .pipe(filter(event => {\n        return event.keyCode === ESCAPE && !this.disableClose && !hasModifierKey(event);\n      }))\n      .subscribe(event => {\n        event.preventDefault();\n        this.close();\n      });\n  }\n\n  /**\n   * Close the dialog.\n   * @param dialogResult Optional result to return to the dialog opener.\n   */\n  close(dialogResult?: R): void {\n    this._result = dialogResult;\n\n    // Transition the backdrop in parallel to the dialog.\n    this._containerInstance._animationStateChanged.pipe(\n      filter(event => event.phaseName === 'start'),\n      take(1)\n    )\n    .subscribe(event => {\n      this._beforeClosed.next(dialogResult);\n      this._beforeClosed.complete();\n      this._state = MatDialogState.CLOSED;\n      this._overlayRef.detachBackdrop();\n\n      // The logic that disposes of the overlay depends on the exit animation completing, however\n      // it isn't guaranteed if the parent view is destroyed while it's running. Add a fallback\n      // timeout which will clean everything up if the animation hasn't fired within the specified\n      // amount of time plus 100ms. We don't need to run this outside the NgZone, because for the\n      // vast majority of cases the timeout will have been cleared before it has the chance to fire.\n      this._closeFallbackTimeout = setTimeout(() => {\n        this._overlayRef.dispose();\n      }, event.totalTime + 100);\n    });\n\n    this._containerInstance._startExitAnimation();\n    this._state = MatDialogState.CLOSING;\n  }\n\n  /**\n   * Gets an observable that is notified when the dialog is finished opening.\n   */\n  afterOpened(): Observable<void> {\n    return this._afterOpened.asObservable();\n  }\n\n  /**\n   * Gets an observable that is notified when the dialog is finished closing.\n   */\n  afterClosed(): Observable<R | undefined> {\n    return this._afterClosed.asObservable();\n  }\n\n  /**\n   * Gets an observable that is notified when the dialog has started closing.\n   */\n  beforeClosed(): Observable<R | undefined> {\n    return this._beforeClosed.asObservable();\n  }\n\n  /**\n   * Gets an observable that emits when the overlay's backdrop has been clicked.\n   */\n  backdropClick(): Observable<MouseEvent> {\n    return this._overlayRef.backdropClick();\n  }\n\n  /**\n   * Gets an observable that emits when keydown events are targeted on the overlay.\n   */\n  keydownEvents(): Observable<KeyboardEvent> {\n    return this._overlayRef.keydownEvents();\n  }\n\n  /**\n   * Updates the dialog's position.\n   * @param position New dialog position.\n   */\n  updatePosition(position?: DialogPosition): this {\n    let strategy = this._getPositionStrategy();\n\n    if (position && (position.left || position.right)) {\n      position.left ? strategy.left(position.left) : strategy.right(position.right);\n    } else {\n      strategy.centerHorizontally();\n    }\n\n    if (position && (position.top || position.bottom)) {\n      position.top ? strategy.top(position.top) : strategy.bottom(position.bottom);\n    } else {\n      strategy.centerVertically();\n    }\n\n    this._overlayRef.updatePosition();\n\n    return this;\n  }\n\n  /**\n   * Updates the dialog's width and height.\n   * @param width New width of the dialog.\n   * @param height New height of the dialog.\n   */\n  updateSize(width: string = '', height: string = ''): this {\n    this._getPositionStrategy().width(width).height(height);\n    this._overlayRef.updatePosition();\n    return this;\n  }\n\n  /** Add a CSS class or an array of classes to the overlay pane. */\n  addPanelClass(classes: string | string[]): this {\n    this._overlayRef.addPanelClass(classes);\n    return this;\n  }\n\n  /** Remove a CSS class or an array of classes from the overlay pane. */\n  removePanelClass(classes: string | string[]): this {\n    this._overlayRef.removePanelClass(classes);\n    return this;\n  }\n\n  /** Gets the current state of the dialog's lifecycle. */\n  getState(): MatDialogState {\n    return this._state;\n  }\n\n  /** Fetches the position strategy object from the overlay ref. */\n  private _getPositionStrategy(): GlobalPositionStrategy {\n    return this._overlayRef.getConfig().positionStrategy as GlobalPositionStrategy;\n  }\n}\n"]}