modal-ref.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. /**
  6. * A reference to the currently opened (active) modal.
  7. *
  8. * Instances of this class can be injected into your component passed as modal content.
  9. * So you can `.close()` or `.dismiss()` the modal window from your component.
  10. */
  11. var /**
  12. * A reference to the currently opened (active) modal.
  13. *
  14. * Instances of this class can be injected into your component passed as modal content.
  15. * So you can `.close()` or `.dismiss()` the modal window from your component.
  16. */
  17. NgbActiveModal = /** @class */ (function () {
  18. function NgbActiveModal() {
  19. }
  20. /**
  21. * Closes the modal with an optional `result` value.
  22. *
  23. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  24. */
  25. /**
  26. * Closes the modal with an optional `result` value.
  27. *
  28. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  29. * @param {?=} result
  30. * @return {?}
  31. */
  32. NgbActiveModal.prototype.close = /**
  33. * Closes the modal with an optional `result` value.
  34. *
  35. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  36. * @param {?=} result
  37. * @return {?}
  38. */
  39. function (result) { };
  40. /**
  41. * Dismisses the modal with an optional `reason` value.
  42. *
  43. * The `NgbModalRef.result` promise will be rejected with the provided value.
  44. */
  45. /**
  46. * Dismisses the modal with an optional `reason` value.
  47. *
  48. * The `NgbModalRef.result` promise will be rejected with the provided value.
  49. * @param {?=} reason
  50. * @return {?}
  51. */
  52. NgbActiveModal.prototype.dismiss = /**
  53. * Dismisses the modal with an optional `reason` value.
  54. *
  55. * The `NgbModalRef.result` promise will be rejected with the provided value.
  56. * @param {?=} reason
  57. * @return {?}
  58. */
  59. function (reason) { };
  60. return NgbActiveModal;
  61. }());
  62. /**
  63. * A reference to the currently opened (active) modal.
  64. *
  65. * Instances of this class can be injected into your component passed as modal content.
  66. * So you can `.close()` or `.dismiss()` the modal window from your component.
  67. */
  68. export { NgbActiveModal };
  69. /**
  70. * A reference to the newly opened modal returned by the `NgbModal.open()` method.
  71. */
  72. var /**
  73. * A reference to the newly opened modal returned by the `NgbModal.open()` method.
  74. */
  75. NgbModalRef = /** @class */ (function () {
  76. function NgbModalRef(_windowCmptRef, _contentRef, _backdropCmptRef, _beforeDismiss) {
  77. var _this = this;
  78. this._windowCmptRef = _windowCmptRef;
  79. this._contentRef = _contentRef;
  80. this._backdropCmptRef = _backdropCmptRef;
  81. this._beforeDismiss = _beforeDismiss;
  82. _windowCmptRef.instance.dismissEvent.subscribe((/**
  83. * @param {?} reason
  84. * @return {?}
  85. */
  86. function (reason) { _this.dismiss(reason); }));
  87. this.result = new Promise((/**
  88. * @param {?} resolve
  89. * @param {?} reject
  90. * @return {?}
  91. */
  92. function (resolve, reject) {
  93. _this._resolve = resolve;
  94. _this._reject = reject;
  95. }));
  96. this.result.then(null, (/**
  97. * @return {?}
  98. */
  99. function () { }));
  100. }
  101. Object.defineProperty(NgbModalRef.prototype, "componentInstance", {
  102. /**
  103. * The instance of a component used for the modal content.
  104. *
  105. * When a `TemplateRef` is used as the content or when the modal is closed, will return `undefined`.
  106. */
  107. get: /**
  108. * The instance of a component used for the modal content.
  109. *
  110. * When a `TemplateRef` is used as the content or when the modal is closed, will return `undefined`.
  111. * @return {?}
  112. */
  113. function () {
  114. if (this._contentRef && this._contentRef.componentRef) {
  115. return this._contentRef.componentRef.instance;
  116. }
  117. },
  118. enumerable: true,
  119. configurable: true
  120. });
  121. /**
  122. * Closes the modal with an optional `result` value.
  123. *
  124. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  125. */
  126. /**
  127. * Closes the modal with an optional `result` value.
  128. *
  129. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  130. * @param {?=} result
  131. * @return {?}
  132. */
  133. NgbModalRef.prototype.close = /**
  134. * Closes the modal with an optional `result` value.
  135. *
  136. * The `NgbMobalRef.result` promise will be resolved with the provided value.
  137. * @param {?=} result
  138. * @return {?}
  139. */
  140. function (result) {
  141. if (this._windowCmptRef) {
  142. this._resolve(result);
  143. this._removeModalElements();
  144. }
  145. };
  146. /**
  147. * @private
  148. * @param {?=} reason
  149. * @return {?}
  150. */
  151. NgbModalRef.prototype._dismiss = /**
  152. * @private
  153. * @param {?=} reason
  154. * @return {?}
  155. */
  156. function (reason) {
  157. this._reject(reason);
  158. this._removeModalElements();
  159. };
  160. /**
  161. * Dismisses the modal with an optional `reason` value.
  162. *
  163. * The `NgbModalRef.result` promise will be rejected with the provided value.
  164. */
  165. /**
  166. * Dismisses the modal with an optional `reason` value.
  167. *
  168. * The `NgbModalRef.result` promise will be rejected with the provided value.
  169. * @param {?=} reason
  170. * @return {?}
  171. */
  172. NgbModalRef.prototype.dismiss = /**
  173. * Dismisses the modal with an optional `reason` value.
  174. *
  175. * The `NgbModalRef.result` promise will be rejected with the provided value.
  176. * @param {?=} reason
  177. * @return {?}
  178. */
  179. function (reason) {
  180. var _this = this;
  181. if (this._windowCmptRef) {
  182. if (!this._beforeDismiss) {
  183. this._dismiss(reason);
  184. }
  185. else {
  186. /** @type {?} */
  187. var dismiss = this._beforeDismiss();
  188. if (dismiss && dismiss.then) {
  189. dismiss.then((/**
  190. * @param {?} result
  191. * @return {?}
  192. */
  193. function (result) {
  194. if (result !== false) {
  195. _this._dismiss(reason);
  196. }
  197. }), (/**
  198. * @return {?}
  199. */
  200. function () { }));
  201. }
  202. else if (dismiss !== false) {
  203. this._dismiss(reason);
  204. }
  205. }
  206. }
  207. };
  208. /**
  209. * @private
  210. * @return {?}
  211. */
  212. NgbModalRef.prototype._removeModalElements = /**
  213. * @private
  214. * @return {?}
  215. */
  216. function () {
  217. /** @type {?} */
  218. var windowNativeEl = this._windowCmptRef.location.nativeElement;
  219. windowNativeEl.parentNode.removeChild(windowNativeEl);
  220. this._windowCmptRef.destroy();
  221. if (this._backdropCmptRef) {
  222. /** @type {?} */
  223. var backdropNativeEl = this._backdropCmptRef.location.nativeElement;
  224. backdropNativeEl.parentNode.removeChild(backdropNativeEl);
  225. this._backdropCmptRef.destroy();
  226. }
  227. if (this._contentRef && this._contentRef.viewRef) {
  228. this._contentRef.viewRef.destroy();
  229. }
  230. this._windowCmptRef = null;
  231. this._backdropCmptRef = null;
  232. this._contentRef = null;
  233. };
  234. return NgbModalRef;
  235. }());
  236. /**
  237. * A reference to the newly opened modal returned by the `NgbModal.open()` method.
  238. */
  239. export { NgbModalRef };
  240. if (false) {
  241. /**
  242. * @type {?}
  243. * @private
  244. */
  245. NgbModalRef.prototype._resolve;
  246. /**
  247. * @type {?}
  248. * @private
  249. */
  250. NgbModalRef.prototype._reject;
  251. /**
  252. * The promise that is resolved when the modal is closed and rejected when the modal is dismissed.
  253. * @type {?}
  254. */
  255. NgbModalRef.prototype.result;
  256. /**
  257. * @type {?}
  258. * @private
  259. */
  260. NgbModalRef.prototype._windowCmptRef;
  261. /**
  262. * @type {?}
  263. * @private
  264. */
  265. NgbModalRef.prototype._contentRef;
  266. /**
  267. * @type {?}
  268. * @private
  269. */
  270. NgbModalRef.prototype._backdropCmptRef;
  271. /**
  272. * @type {?}
  273. * @private
  274. */
  275. NgbModalRef.prototype._beforeDismiss;
  276. }
  277. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-ref.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["modal/modal-ref.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef} from '@angular/core';\n\nimport {NgbModalBackdrop} from './modal-backdrop';\nimport {NgbModalWindow} from './modal-window';\n\nimport {ContentRef} from '../util/popup';\n\n/**\n * A reference to the currently opened (active) modal.\n *\n * Instances of this class can be injected into your component passed as modal content.\n * So you can `.close()` or `.dismiss()` the modal window from your component.\n */\nexport class NgbActiveModal {\n  /**\n   * Closes the modal with an optional `result` value.\n   *\n   * The `NgbMobalRef.result` promise will be resolved with the provided value.\n   */\n  close(result?: any): void {}\n\n  /**\n   * Dismisses the modal with an optional `reason` value.\n   *\n   * The `NgbModalRef.result` promise will be rejected with the provided value.\n   */\n  dismiss(reason?: any): void {}\n}\n\n/**\n * A reference to the newly opened modal returned by the `NgbModal.open()` method.\n */\nexport class NgbModalRef {\n  private _resolve: (result?: any) => void;\n  private _reject: (reason?: any) => void;\n\n  /**\n   * The instance of a component used for the modal content.\n   *\n   * When a `TemplateRef` is used as the content or when the modal is closed, will return `undefined`.\n   */\n  get componentInstance(): any {\n    if (this._contentRef && this._contentRef.componentRef) {\n      return this._contentRef.componentRef.instance;\n    }\n  }\n\n  /**\n   * The promise that is resolved when the modal is closed and rejected when the modal is dismissed.\n   */\n  result: Promise<any>;\n\n  constructor(\n      private _windowCmptRef: ComponentRef<NgbModalWindow>, private _contentRef: ContentRef,\n      private _backdropCmptRef?: ComponentRef<NgbModalBackdrop>, private _beforeDismiss?: Function) {\n    _windowCmptRef.instance.dismissEvent.subscribe((reason: any) => { this.dismiss(reason); });\n\n    this.result = new Promise((resolve, reject) => {\n      this._resolve = resolve;\n      this._reject = reject;\n    });\n    this.result.then(null, () => {});\n  }\n\n  /**\n   * Closes the modal with an optional `result` value.\n   *\n   * The `NgbMobalRef.result` promise will be resolved with the provided value.\n   */\n  close(result?: any): void {\n    if (this._windowCmptRef) {\n      this._resolve(result);\n      this._removeModalElements();\n    }\n  }\n\n  private _dismiss(reason?: any) {\n    this._reject(reason);\n    this._removeModalElements();\n  }\n\n  /**\n   * Dismisses the modal with an optional `reason` value.\n   *\n   * The `NgbModalRef.result` promise will be rejected with the provided value.\n   */\n  dismiss(reason?: any): void {\n    if (this._windowCmptRef) {\n      if (!this._beforeDismiss) {\n        this._dismiss(reason);\n      } else {\n        const dismiss = this._beforeDismiss();\n        if (dismiss && dismiss.then) {\n          dismiss.then(\n              result => {\n                if (result !== false) {\n                  this._dismiss(reason);\n                }\n              },\n              () => {});\n        } else if (dismiss !== false) {\n          this._dismiss(reason);\n        }\n      }\n    }\n  }\n\n  private _removeModalElements() {\n    const windowNativeEl = this._windowCmptRef.location.nativeElement;\n    windowNativeEl.parentNode.removeChild(windowNativeEl);\n    this._windowCmptRef.destroy();\n\n    if (this._backdropCmptRef) {\n      const backdropNativeEl = this._backdropCmptRef.location.nativeElement;\n      backdropNativeEl.parentNode.removeChild(backdropNativeEl);\n      this._backdropCmptRef.destroy();\n    }\n\n    if (this._contentRef && this._contentRef.viewRef) {\n      this._contentRef.viewRef.destroy();\n    }\n\n    this._windowCmptRef = null;\n    this._backdropCmptRef = null;\n    this._contentRef = null;\n  }\n}\n"]}