UNPKG

ngx-modialog-11

Version:
92 lines 11.3 kB
import { Subject } from 'rxjs'; import { PromiseCompleter } from '../framework/utils'; import { DialogBailOutError } from './errors'; /** * API to an open modal window. */ export class DialogRef { constructor(overlay, context) { this.overlay = overlay; this.context = context; this._resultDeferred = new PromiseCompleter(); this._onDestroy = new Subject(); this.onDestroy = this._onDestroy.asObservable(); } /** * A Promise that is resolved on a close event and rejected on a dismiss event. */ get result() { return this._resultDeferred.promise; } /** * Set a close/dismiss guard * @param guard */ setCloseGuard(guard) { this.closeGuard = guard; } /** * Close the modal with a return value, i.e: result. */ close(result = null) { const _close = () => { this.destroy(); this._resultDeferred.resolve(result); }; this._fireHook('beforeClose') .then(value => value !== true && _close()) .catch(_close); } /** * Close the modal without a return value, i.e: cancelled. * This call is automatically invoked when a user either: * - Presses an exit keyboard key (if configured). * - Clicks outside of the modal window (if configured). * Usually, dismiss represent a Cancel button or a X button. */ dismiss() { const _dismiss = () => { this.destroy(); this._resultDeferred.promise.catch(() => { }); this._resultDeferred.reject(); }; this._fireHook('beforeDismiss') .then(value => value !== true && _dismiss()) .catch(_dismiss); } /** * Gracefully close the overlay/dialog with a rejected result. * Does not trigger canDestroy on the overlay. */ bailOut() { if (this.destroyed !== true) { this.destroyed = true; this._onDestroy.next(null); this._onDestroy.complete(); this._resultDeferred.reject(new DialogBailOutError()); } } destroy() { if (this.destroyed !== true) { this.destroyed = true; if (typeof this.overlayRef.instance.canDestroy === 'function') { this.overlayRef.instance.canDestroy() .catch(() => { }) .then(() => this._destroy()); } else { this._destroy(); } } } _destroy() { this._onDestroy.next(null); this._onDestroy.complete(); this.overlayRef.destroy(); } _fireHook(name) { const guard = this.closeGuard, fn = guard && typeof guard[name] === 'function' && guard[name]; return Promise.resolve(fn ? fn.call(guard) : false); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-ref.js","sourceRoot":"","sources":["../../../../../projects/ngx-modialog-11/src/lib/models/dialog-ref.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAG3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAE9C;;GAEG;AACH,MAAM,OAAO,SAAS;IAyBpB,YAAmB,OAAgB,EAAS,OAAW;QAApC,YAAO,GAAP,OAAO,CAAS;QAAS,YAAO,GAAP,OAAO,CAAI;QAJ/C,oBAAe,GAA0B,IAAI,gBAAgB,EAAO,CAAC;QACrE,eAAU,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAItD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;IAClD,CAAC;IAED;;OAEG;IACH,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;IACtC,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,KAAiB;QAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAc,IAAI;QACtB,MAAM,MAAM,GAAG,GAAG,EAAE;YAClB,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC,CAAC;QACF,IAAI,CAAC,SAAS,CAAU,aAAa,CAAC;aACnC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,IAAI,IAAI,MAAM,EAAE,CAAC;aACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IACnB,CAAC;IAED;;;;;;OAMG;IACH,OAAO;QACL,MAAM,QAAQ,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;QAChC,CAAC,CAAC;QACF,IAAI,CAAC,SAAS,CAAU,eAAe,CAAC;aACrC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,IAAI,IAAI,QAAQ,EAAE,CAAC;aAC3C,KAAK,CAAC,QAAQ,CAAC,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,kBAAkB,EAAE,CAAC,CAAC;SACvD;IACH,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YAEtB,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,KAAK,UAAU,EAAE;gBAC7D,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,EAAE;qBAClC,KAAK,CAAE,GAAG,EAAE,GAAE,CAAC,CAAC;qBAChB,IAAI,CAAG,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAE,CAAC;aACnC;iBAAM;gBACL,IAAI,CAAC,QAAQ,EAAE,CAAC;aACjB;SACF;IACH,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;IAC5B,CAAC;IAEO,SAAS,CAAI,IAAqC;QACxD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,EACvB,EAAE,GAAa,KAAK,IAAI,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,UAAU,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC;QAE/E,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACtD,CAAC;CACF","sourcesContent":["import { Observable, Subject } from 'rxjs';\r\nimport { ComponentRef } from '@angular/core';\r\n\r\nimport { PromiseCompleter } from '../framework/utils';\r\nimport { Overlay, ModalOverlay } from '../overlay/index';\r\nimport { CloseGuard } from './tokens';\r\nimport { DialogBailOutError } from './errors';\r\n\r\n/**\r\n * API to an open modal window.\r\n */\r\nexport class DialogRef<T> {\r\n  /**\r\n   * Reference to the overlay component ref.\r\n   */\r\n  overlayRef: ComponentRef<ModalOverlay>;\r\n\r\n  /**\r\n   * States if the modal is inside a specific element.\r\n   */\r\n  public inElement: boolean;\r\n\r\n  public destroyed: boolean;\r\n\r\n  /**\r\n   * Fired before dialog is destroyed.\r\n   * No need to unsubscribe, done automatically.\r\n   * Note: Always called.\r\n   * When called, overlayRef might or might not be destroyed.\r\n   */\r\n  public onDestroy: Observable<void>;\r\n\r\n  private _resultDeferred: PromiseCompleter<any> = new PromiseCompleter<any>();\r\n  private _onDestroy: Subject<void> = new Subject<void>();\r\n  private closeGuard: CloseGuard;\r\n\r\n  constructor(public overlay: Overlay, public context?: T) {\r\n    this.onDestroy = this._onDestroy.asObservable();\r\n  }\r\n\r\n  /**\r\n   * A Promise that is resolved on a close event and rejected on a dismiss event.\r\n   */\r\n  get result(): Promise<any> {\r\n    return this._resultDeferred.promise;\r\n  }\r\n\r\n  /**\r\n   * Set a close/dismiss guard\r\n   * @param guard\r\n   */\r\n  setCloseGuard(guard: CloseGuard): void {\r\n    this.closeGuard = guard;\r\n  }\r\n\r\n  /**\r\n   *  Close the modal with a return value, i.e: result.\r\n   */\r\n  close(result: any = null) {\r\n    const _close = () => {\r\n      this.destroy();\r\n      this._resultDeferred.resolve(result);\r\n    };\r\n    this._fireHook<boolean>('beforeClose')\r\n      .then(value => value !== true && _close())\r\n      .catch(_close);\r\n  }\r\n\r\n  /**\r\n   *  Close the modal without a return value, i.e: cancelled.\r\n   *  This call is automatically invoked when a user either:\r\n   *  - Presses an exit keyboard key (if configured).\r\n   *  - Clicks outside of the modal window (if configured).\r\n   *  Usually, dismiss represent a Cancel button or a X button.\r\n   */\r\n  dismiss() {\r\n    const _dismiss = () => {\r\n      this.destroy();\r\n      this._resultDeferred.promise.catch(() => {});\r\n      this._resultDeferred.reject();\r\n    };\r\n    this._fireHook<boolean>('beforeDismiss')\r\n      .then(value => value !== true && _dismiss())\r\n      .catch(_dismiss);\r\n  }\r\n\r\n  /**\r\n   * Gracefully close the overlay/dialog with a rejected result.\r\n   * Does not trigger canDestroy on the overlay.\r\n   */\r\n  bailOut() {\r\n    if (this.destroyed !== true) {\r\n      this.destroyed = true;\r\n      this._onDestroy.next(null);\r\n      this._onDestroy.complete();\r\n      this._resultDeferred.reject(new DialogBailOutError());\r\n    }\r\n  }\r\n\r\n  destroy() {\r\n    if (this.destroyed !== true) {\r\n      this.destroyed = true;\r\n\r\n      if (typeof this.overlayRef.instance.canDestroy === 'function') {\r\n        this.overlayRef.instance.canDestroy()\r\n          .catch( () => {})\r\n          .then ( () => this._destroy() );\r\n      } else {\r\n        this._destroy();\r\n      }\r\n    }\r\n  }\r\n\r\n  private _destroy(): void {\r\n    this._onDestroy.next(null);\r\n    this._onDestroy.complete();\r\n    this.overlayRef.destroy();\r\n  }\r\n\r\n  private _fireHook<G>(name: 'beforeClose' | 'beforeDismiss'): Promise<G> {\r\n    const guard = this.closeGuard,\r\n          fn: Function = guard && typeof guard[name] === 'function' && guard[name];\r\n\r\n    return Promise.resolve(fn ? fn.call(guard) : false);\r\n  }\r\n}\r\n"]}