modal.directive.js 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. /* tslint:disable:max-file-line-count */
  6. // todo: should we support enforce focus in?
  7. // todo: in original bs there are was a way to prevent modal from showing
  8. // todo: original modal had resize events
  9. import { Directive, ElementRef, EventEmitter, HostListener, Input, Output, Renderer2, ViewContainerRef } from '@angular/core';
  10. import { document, window, isBs3, Utils } from 'ngx-bootstrap/utils';
  11. import { ModalBackdropComponent } from './modal-backdrop.component';
  12. import { CLASS_NAME, DISMISS_REASONS, modalConfigDefaults, ModalOptions } from './modal-options.class';
  13. import { ComponentLoaderFactory } from 'ngx-bootstrap/component-loader';
  14. /** @type {?} */
  15. var TRANSITION_DURATION = 300;
  16. /** @type {?} */
  17. var BACKDROP_TRANSITION_DURATION = 150;
  18. /**
  19. * Mark any code with directive to show it's content in modal
  20. */
  21. var ModalDirective = /** @class */ (function () {
  22. function ModalDirective(_element, _viewContainerRef, _renderer, clf) {
  23. this._element = _element;
  24. this._renderer = _renderer;
  25. /**
  26. * This event fires immediately when the `show` instance method is called.
  27. */
  28. this.onShow = new EventEmitter();
  29. /**
  30. * This event is fired when the modal has been made visible to the user
  31. * (will wait for CSS transitions to complete)
  32. */
  33. this.onShown = new EventEmitter();
  34. /**
  35. * This event is fired immediately when
  36. * the hide instance method has been called.
  37. */
  38. this.onHide = new EventEmitter();
  39. /**
  40. * This event is fired when the modal has finished being
  41. * hidden from the user (will wait for CSS transitions to complete).
  42. */
  43. this.onHidden = new EventEmitter();
  44. this._isShown = false;
  45. this.isBodyOverflowing = false;
  46. this.originalBodyPadding = 0;
  47. this.scrollbarWidth = 0;
  48. this.timerHideModal = 0;
  49. this.timerRmBackDrop = 0;
  50. this.isNested = false;
  51. this._backdrop = clf.createLoader(_element, _viewContainerRef, _renderer);
  52. }
  53. Object.defineProperty(ModalDirective.prototype, "config", {
  54. get: /**
  55. * @return {?}
  56. */
  57. function () {
  58. return this._config;
  59. },
  60. /** allows to set modal configuration via element property */
  61. set: /**
  62. * allows to set modal configuration via element property
  63. * @param {?} conf
  64. * @return {?}
  65. */
  66. function (conf) {
  67. this._config = this.getConfig(conf);
  68. },
  69. enumerable: true,
  70. configurable: true
  71. });
  72. Object.defineProperty(ModalDirective.prototype, "isShown", {
  73. get: /**
  74. * @return {?}
  75. */
  76. function () {
  77. return this._isShown;
  78. },
  79. enumerable: true,
  80. configurable: true
  81. });
  82. /**
  83. * @param {?} event
  84. * @return {?}
  85. */
  86. ModalDirective.prototype.onClick = /**
  87. * @param {?} event
  88. * @return {?}
  89. */
  90. function (event) {
  91. if (this.config.ignoreBackdropClick ||
  92. this.config.backdrop === 'static' ||
  93. event.target !== this._element.nativeElement) {
  94. return;
  95. }
  96. this.dismissReason = DISMISS_REASONS.BACKRDOP;
  97. this.hide(event);
  98. };
  99. // todo: consider preventing default and stopping propagation
  100. // todo: consider preventing default and stopping propagation
  101. /**
  102. * @param {?} event
  103. * @return {?}
  104. */
  105. ModalDirective.prototype.onEsc =
  106. // todo: consider preventing default and stopping propagation
  107. /**
  108. * @param {?} event
  109. * @return {?}
  110. */
  111. function (event) {
  112. if (!this._isShown) {
  113. return;
  114. }
  115. // tslint:disable-next-line:deprecation
  116. if (event.keyCode === 27 || event.key === 'Escape') {
  117. event.preventDefault();
  118. }
  119. if (this.config.keyboard) {
  120. this.dismissReason = DISMISS_REASONS.ESC;
  121. this.hide();
  122. }
  123. };
  124. /**
  125. * @return {?}
  126. */
  127. ModalDirective.prototype.ngOnDestroy = /**
  128. * @return {?}
  129. */
  130. function () {
  131. this.config = void 0;
  132. if (this._isShown) {
  133. this._isShown = false;
  134. this.hideModal();
  135. this._backdrop.dispose();
  136. }
  137. };
  138. /**
  139. * @return {?}
  140. */
  141. ModalDirective.prototype.ngOnInit = /**
  142. * @return {?}
  143. */
  144. function () {
  145. var _this = this;
  146. this._config = this._config || this.getConfig();
  147. setTimeout((/**
  148. * @return {?}
  149. */
  150. function () {
  151. if (_this._config.show) {
  152. _this.show();
  153. }
  154. }), 0);
  155. };
  156. /* Public methods */
  157. /** Allows to manually toggle modal visibility */
  158. /* Public methods */
  159. /**
  160. * Allows to manually toggle modal visibility
  161. * @return {?}
  162. */
  163. ModalDirective.prototype.toggle = /* Public methods */
  164. /**
  165. * Allows to manually toggle modal visibility
  166. * @return {?}
  167. */
  168. function () {
  169. return this._isShown ? this.hide() : this.show();
  170. };
  171. /** Allows to manually open modal */
  172. /**
  173. * Allows to manually open modal
  174. * @return {?}
  175. */
  176. ModalDirective.prototype.show = /**
  177. * Allows to manually open modal
  178. * @return {?}
  179. */
  180. function () {
  181. var _this = this;
  182. this.dismissReason = null;
  183. this.onShow.emit(this);
  184. if (this._isShown) {
  185. return;
  186. }
  187. clearTimeout(this.timerHideModal);
  188. clearTimeout(this.timerRmBackDrop);
  189. this._isShown = true;
  190. this.checkScrollbar();
  191. this.setScrollbar();
  192. if (document && document.body) {
  193. if (document.body.classList.contains(CLASS_NAME.OPEN)) {
  194. this.isNested = true;
  195. }
  196. else {
  197. this._renderer.addClass(document.body, CLASS_NAME.OPEN);
  198. }
  199. }
  200. this.showBackdrop((/**
  201. * @return {?}
  202. */
  203. function () {
  204. _this.showElement();
  205. }));
  206. };
  207. /** Allows to manually close modal */
  208. /**
  209. * Allows to manually close modal
  210. * @param {?=} event
  211. * @return {?}
  212. */
  213. ModalDirective.prototype.hide = /**
  214. * Allows to manually close modal
  215. * @param {?=} event
  216. * @return {?}
  217. */
  218. function (event) {
  219. var _this = this;
  220. if (event) {
  221. event.preventDefault();
  222. }
  223. this.onHide.emit(this);
  224. // todo: add an option to prevent hiding
  225. if (!this._isShown) {
  226. return;
  227. }
  228. window.clearTimeout(this.timerHideModal);
  229. window.clearTimeout(this.timerRmBackDrop);
  230. this._isShown = false;
  231. this._renderer.removeClass(this._element.nativeElement, CLASS_NAME.IN);
  232. if (!isBs3()) {
  233. this._renderer.removeClass(this._element.nativeElement, CLASS_NAME.SHOW);
  234. }
  235. // this._addClassIn = false;
  236. if (this._config.animated) {
  237. this.timerHideModal = window.setTimeout((/**
  238. * @return {?}
  239. */
  240. function () { return _this.hideModal(); }), TRANSITION_DURATION);
  241. }
  242. else {
  243. this.hideModal();
  244. }
  245. };
  246. /** Private methods @internal */
  247. /**
  248. * Private methods \@internal
  249. * @protected
  250. * @param {?=} config
  251. * @return {?}
  252. */
  253. ModalDirective.prototype.getConfig = /**
  254. * Private methods \@internal
  255. * @protected
  256. * @param {?=} config
  257. * @return {?}
  258. */
  259. function (config) {
  260. return Object.assign({}, modalConfigDefaults, config);
  261. };
  262. /**
  263. * Show dialog
  264. * @internal
  265. */
  266. /**
  267. * Show dialog
  268. * \@internal
  269. * @protected
  270. * @return {?}
  271. */
  272. ModalDirective.prototype.showElement = /**
  273. * Show dialog
  274. * \@internal
  275. * @protected
  276. * @return {?}
  277. */
  278. function () {
  279. var _this = this;
  280. // todo: replace this with component loader usage
  281. if (!this._element.nativeElement.parentNode ||
  282. this._element.nativeElement.parentNode.nodeType !== Node.ELEMENT_NODE) {
  283. // don't move modals dom position
  284. if (document && document.body) {
  285. document.body.appendChild(this._element.nativeElement);
  286. }
  287. }
  288. this._renderer.setAttribute(this._element.nativeElement, 'aria-hidden', 'false');
  289. this._renderer.setAttribute(this._element.nativeElement, 'aria-modal', 'true');
  290. this._renderer.setStyle(this._element.nativeElement, 'display', 'block');
  291. this._renderer.setProperty(this._element.nativeElement, 'scrollTop', 0);
  292. if (this._config.animated) {
  293. Utils.reflow(this._element.nativeElement);
  294. }
  295. // this._addClassIn = true;
  296. this._renderer.addClass(this._element.nativeElement, CLASS_NAME.IN);
  297. if (!isBs3()) {
  298. this._renderer.addClass(this._element.nativeElement, CLASS_NAME.SHOW);
  299. }
  300. /** @type {?} */
  301. var transitionComplete = (/**
  302. * @return {?}
  303. */
  304. function () {
  305. if (_this._config.focus) {
  306. _this._element.nativeElement.focus();
  307. }
  308. _this.onShown.emit(_this);
  309. });
  310. if (this._config.animated) {
  311. setTimeout(transitionComplete, TRANSITION_DURATION);
  312. }
  313. else {
  314. transitionComplete();
  315. }
  316. };
  317. /** @internal */
  318. /**
  319. * \@internal
  320. * @protected
  321. * @return {?}
  322. */
  323. ModalDirective.prototype.hideModal = /**
  324. * \@internal
  325. * @protected
  326. * @return {?}
  327. */
  328. function () {
  329. var _this = this;
  330. this._renderer.setAttribute(this._element.nativeElement, 'aria-hidden', 'true');
  331. this._renderer.setStyle(this._element.nativeElement, 'display', 'none');
  332. this.showBackdrop((/**
  333. * @return {?}
  334. */
  335. function () {
  336. if (!_this.isNested) {
  337. if (document && document.body) {
  338. _this._renderer.removeClass(document.body, CLASS_NAME.OPEN);
  339. }
  340. _this.resetScrollbar();
  341. }
  342. _this.resetAdjustments();
  343. _this.focusOtherModal();
  344. _this.onHidden.emit(_this);
  345. }));
  346. };
  347. // todo: original show was calling a callback when done, but we can use
  348. // promise
  349. /** @internal */
  350. // todo: original show was calling a callback when done, but we can use
  351. // promise
  352. /**
  353. * \@internal
  354. * @protected
  355. * @param {?=} callback
  356. * @return {?}
  357. */
  358. ModalDirective.prototype.showBackdrop =
  359. // todo: original show was calling a callback when done, but we can use
  360. // promise
  361. /**
  362. * \@internal
  363. * @protected
  364. * @param {?=} callback
  365. * @return {?}
  366. */
  367. function (callback) {
  368. var _this = this;
  369. if (this._isShown &&
  370. this.config.backdrop &&
  371. (!this.backdrop || !this.backdrop.instance.isShown)) {
  372. this.removeBackdrop();
  373. this._backdrop
  374. .attach(ModalBackdropComponent)
  375. .to('body')
  376. .show({ isAnimated: this._config.animated });
  377. this.backdrop = this._backdrop._componentRef;
  378. if (!callback) {
  379. return;
  380. }
  381. if (!this._config.animated) {
  382. callback();
  383. return;
  384. }
  385. setTimeout(callback, BACKDROP_TRANSITION_DURATION);
  386. }
  387. else if (!this._isShown && this.backdrop) {
  388. this.backdrop.instance.isShown = false;
  389. /** @type {?} */
  390. var callbackRemove = (/**
  391. * @return {?}
  392. */
  393. function () {
  394. _this.removeBackdrop();
  395. if (callback) {
  396. callback();
  397. }
  398. });
  399. if (this.backdrop.instance.isAnimated) {
  400. this.timerRmBackDrop = window.setTimeout(callbackRemove, BACKDROP_TRANSITION_DURATION);
  401. }
  402. else {
  403. callbackRemove();
  404. }
  405. }
  406. else if (callback) {
  407. callback();
  408. }
  409. };
  410. /** @internal */
  411. /**
  412. * \@internal
  413. * @protected
  414. * @return {?}
  415. */
  416. ModalDirective.prototype.removeBackdrop = /**
  417. * \@internal
  418. * @protected
  419. * @return {?}
  420. */
  421. function () {
  422. this._backdrop.hide();
  423. };
  424. /** Events tricks */
  425. // no need for it
  426. // protected setEscapeEvent():void {
  427. // if (this._isShown && this._config.keyboard) {
  428. // $(this._element).on(Event.KEYDOWN_DISMISS, (event) => {
  429. // if (event.which === 27) {
  430. // this.hide()
  431. // }
  432. // })
  433. //
  434. // } else if (!this._isShown) {
  435. // $(this._element).off(Event.KEYDOWN_DISMISS)
  436. // }
  437. // }
  438. // protected setResizeEvent():void {
  439. // console.log(this.renderer.listenGlobal('', Event.RESIZE));
  440. // if (this._isShown) {
  441. // $(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this))
  442. // } else {
  443. // $(window).off(Event.RESIZE)
  444. // }
  445. // }
  446. /**
  447. * Events tricks
  448. * @protected
  449. * @return {?}
  450. */
  451. // no need for it
  452. // protected setEscapeEvent():void {
  453. // if (this._isShown && this._config.keyboard) {
  454. // $(this._element).on(Event.KEYDOWN_DISMISS, (event) => {
  455. // if (event.which === 27) {
  456. // this.hide()
  457. // }
  458. // })
  459. //
  460. // } else if (!this._isShown) {
  461. // $(this._element).off(Event.KEYDOWN_DISMISS)
  462. // }
  463. // }
  464. // protected setResizeEvent():void {
  465. // console.log(this.renderer.listenGlobal('', Event.RESIZE));
  466. // if (this._isShown) {
  467. // $(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this))
  468. // } else {
  469. // $(window).off(Event.RESIZE)
  470. // }
  471. // }
  472. ModalDirective.prototype.focusOtherModal = /**
  473. * Events tricks
  474. * @protected
  475. * @return {?}
  476. */
  477. // no need for it
  478. // protected setEscapeEvent():void {
  479. // if (this._isShown && this._config.keyboard) {
  480. // $(this._element).on(Event.KEYDOWN_DISMISS, (event) => {
  481. // if (event.which === 27) {
  482. // this.hide()
  483. // }
  484. // })
  485. //
  486. // } else if (!this._isShown) {
  487. // $(this._element).off(Event.KEYDOWN_DISMISS)
  488. // }
  489. // }
  490. // protected setResizeEvent():void {
  491. // console.log(this.renderer.listenGlobal('', Event.RESIZE));
  492. // if (this._isShown) {
  493. // $(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this))
  494. // } else {
  495. // $(window).off(Event.RESIZE)
  496. // }
  497. // }
  498. function () {
  499. if (this._element.nativeElement.parentElement == null) {
  500. return;
  501. }
  502. /** @type {?} */
  503. var otherOpenedModals = this._element.nativeElement.parentElement.querySelectorAll('.in[bsModal]');
  504. if (!otherOpenedModals.length) {
  505. return;
  506. }
  507. otherOpenedModals[otherOpenedModals.length - 1].focus();
  508. };
  509. /** @internal */
  510. /**
  511. * \@internal
  512. * @protected
  513. * @return {?}
  514. */
  515. ModalDirective.prototype.resetAdjustments = /**
  516. * \@internal
  517. * @protected
  518. * @return {?}
  519. */
  520. function () {
  521. this._renderer.setStyle(this._element.nativeElement, 'paddingLeft', '');
  522. this._renderer.setStyle(this._element.nativeElement, 'paddingRight', '');
  523. };
  524. /** Scroll bar tricks */
  525. /** @internal */
  526. /** Scroll bar tricks */
  527. /**
  528. * \@internal
  529. * @protected
  530. * @return {?}
  531. */
  532. ModalDirective.prototype.checkScrollbar = /** Scroll bar tricks */
  533. /**
  534. * \@internal
  535. * @protected
  536. * @return {?}
  537. */
  538. function () {
  539. this.isBodyOverflowing = document.body.clientWidth < window.innerWidth;
  540. this.scrollbarWidth = this.getScrollbarWidth();
  541. };
  542. /**
  543. * @protected
  544. * @return {?}
  545. */
  546. ModalDirective.prototype.setScrollbar = /**
  547. * @protected
  548. * @return {?}
  549. */
  550. function () {
  551. if (!document) {
  552. return;
  553. }
  554. this.originalBodyPadding = parseInt(window
  555. .getComputedStyle(document.body)
  556. .getPropertyValue('padding-right') || 0, 10);
  557. if (this.isBodyOverflowing) {
  558. document.body.style.paddingRight = this.originalBodyPadding +
  559. this.scrollbarWidth + "px";
  560. }
  561. };
  562. /**
  563. * @protected
  564. * @return {?}
  565. */
  566. ModalDirective.prototype.resetScrollbar = /**
  567. * @protected
  568. * @return {?}
  569. */
  570. function () {
  571. document.body.style.paddingRight = this.originalBodyPadding + "px";
  572. };
  573. // thx d.walsh
  574. // thx d.walsh
  575. /**
  576. * @protected
  577. * @return {?}
  578. */
  579. ModalDirective.prototype.getScrollbarWidth =
  580. // thx d.walsh
  581. /**
  582. * @protected
  583. * @return {?}
  584. */
  585. function () {
  586. /** @type {?} */
  587. var scrollDiv = this._renderer.createElement('div');
  588. this._renderer.addClass(scrollDiv, CLASS_NAME.SCROLLBAR_MEASURER);
  589. this._renderer.appendChild(document.body, scrollDiv);
  590. /** @type {?} */
  591. var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;
  592. this._renderer.removeChild(document.body, scrollDiv);
  593. return scrollbarWidth;
  594. };
  595. ModalDirective.decorators = [
  596. { type: Directive, args: [{
  597. selector: '[bsModal]',
  598. exportAs: 'bs-modal'
  599. },] }
  600. ];
  601. /** @nocollapse */
  602. ModalDirective.ctorParameters = function () { return [
  603. { type: ElementRef },
  604. { type: ViewContainerRef },
  605. { type: Renderer2 },
  606. { type: ComponentLoaderFactory }
  607. ]; };
  608. ModalDirective.propDecorators = {
  609. config: [{ type: Input }],
  610. onShow: [{ type: Output }],
  611. onShown: [{ type: Output }],
  612. onHide: [{ type: Output }],
  613. onHidden: [{ type: Output }],
  614. onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
  615. onEsc: [{ type: HostListener, args: ['keydown.esc', ['$event'],] }]
  616. };
  617. return ModalDirective;
  618. }());
  619. export { ModalDirective };
  620. if (false) {
  621. /**
  622. * This event fires immediately when the `show` instance method is called.
  623. * @type {?}
  624. */
  625. ModalDirective.prototype.onShow;
  626. /**
  627. * This event is fired when the modal has been made visible to the user
  628. * (will wait for CSS transitions to complete)
  629. * @type {?}
  630. */
  631. ModalDirective.prototype.onShown;
  632. /**
  633. * This event is fired immediately when
  634. * the hide instance method has been called.
  635. * @type {?}
  636. */
  637. ModalDirective.prototype.onHide;
  638. /**
  639. * This event is fired when the modal has finished being
  640. * hidden from the user (will wait for CSS transitions to complete).
  641. * @type {?}
  642. */
  643. ModalDirective.prototype.onHidden;
  644. /**
  645. * This field contains last dismiss reason.
  646. * Possible values: `backdrop-click`, `esc` and `null`
  647. * (if modal was closed by direct call of `.hide()`).
  648. * @type {?}
  649. */
  650. ModalDirective.prototype.dismissReason;
  651. /**
  652. * @type {?}
  653. * @protected
  654. */
  655. ModalDirective.prototype._config;
  656. /**
  657. * @type {?}
  658. * @protected
  659. */
  660. ModalDirective.prototype._isShown;
  661. /**
  662. * @type {?}
  663. * @protected
  664. */
  665. ModalDirective.prototype.isBodyOverflowing;
  666. /**
  667. * @type {?}
  668. * @protected
  669. */
  670. ModalDirective.prototype.originalBodyPadding;
  671. /**
  672. * @type {?}
  673. * @protected
  674. */
  675. ModalDirective.prototype.scrollbarWidth;
  676. /**
  677. * @type {?}
  678. * @protected
  679. */
  680. ModalDirective.prototype.timerHideModal;
  681. /**
  682. * @type {?}
  683. * @protected
  684. */
  685. ModalDirective.prototype.timerRmBackDrop;
  686. /**
  687. * @type {?}
  688. * @protected
  689. */
  690. ModalDirective.prototype.backdrop;
  691. /**
  692. * @type {?}
  693. * @private
  694. */
  695. ModalDirective.prototype._backdrop;
  696. /**
  697. * @type {?}
  698. * @private
  699. */
  700. ModalDirective.prototype.isNested;
  701. /**
  702. * @type {?}
  703. * @private
  704. */
  705. ModalDirective.prototype._element;
  706. /**
  707. * @type {?}
  708. * @private
  709. */
  710. ModalDirective.prototype._renderer;
  711. }
  712. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.directive.js","sourceRoot":"ng://ngx-bootstrap/modal/","sources":["modal.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:max-file-line-count */\n// todo: should we support enforce focus in?\n// todo: in original bs there are was a way to prevent modal from showing\n// todo: original modal had resize events\n\nimport {\n  ComponentRef, Directive, ElementRef, EventEmitter, HostListener, Input,\n  OnDestroy, OnInit, Output, Renderer2, ViewContainerRef\n} from '@angular/core';\n\nimport { document, window, isBs3, Utils } from 'ngx-bootstrap/utils';\nimport { ModalBackdropComponent } from './modal-backdrop.component';\nimport {\n  CLASS_NAME, DISMISS_REASONS, modalConfigDefaults, ModalOptions\n} from './modal-options.class';\nimport { ComponentLoader, ComponentLoaderFactory } from 'ngx-bootstrap/component-loader';\n\nconst TRANSITION_DURATION = 300;\nconst BACKDROP_TRANSITION_DURATION = 150;\n\n/** Mark any code with directive to show it's content in modal */\n@Directive({\n  selector: '[bsModal]',\n  exportAs: 'bs-modal'\n})\nexport class ModalDirective implements OnDestroy, OnInit {\n  /** allows to set modal configuration via element property */\n  @Input()\n  set config(conf: ModalOptions) {\n    this._config = this.getConfig(conf);\n  }\n\n  get config(): ModalOptions {\n    return this._config;\n  }\n\n  /** This event fires immediately when the `show` instance method is called. */\n  @Output()\n  onShow: EventEmitter<ModalDirective> = new EventEmitter<ModalDirective>();\n  /** This event is fired when the modal has been made visible to the user\n   * (will wait for CSS transitions to complete)\n   */\n  @Output()\n  onShown: EventEmitter<ModalDirective> = new EventEmitter<ModalDirective>();\n  /** This event is fired immediately when\n   * the hide instance method has been called.\n   */\n  @Output()\n  onHide: EventEmitter<ModalDirective> = new EventEmitter<ModalDirective>();\n  /** This event is fired when the modal has finished being\n   * hidden from the user (will wait for CSS transitions to complete).\n   */\n  @Output()\n  onHidden: EventEmitter<ModalDirective> = new EventEmitter<ModalDirective>();\n\n  /** This field contains last dismiss reason.\n   * Possible values: `backdrop-click`, `esc` and `null`\n   * (if modal was closed by direct call of `.hide()`).\n   */\n  dismissReason: string;\n\n  get isShown(): boolean {\n    return this._isShown;\n  }\n\n  protected _config: ModalOptions;\n  protected _isShown = false;\n\n  protected isBodyOverflowing = false;\n  protected originalBodyPadding = 0;\n  protected scrollbarWidth = 0;\n\n  protected timerHideModal = 0;\n  protected timerRmBackDrop = 0;\n\n  // reference to backdrop component\n  protected backdrop: ComponentRef<ModalBackdropComponent>;\n  private _backdrop: ComponentLoader<ModalBackdropComponent>;\n\n  private isNested = false;\n\n  constructor(private _element: ElementRef,\n              _viewContainerRef: ViewContainerRef,\n              private _renderer: Renderer2,\n              clf: ComponentLoaderFactory) {\n    this._backdrop = clf.createLoader<ModalBackdropComponent>(\n      _element,\n      _viewContainerRef,\n      _renderer\n    );\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: MouseEvent): void {\n    if (\n      this.config.ignoreBackdropClick ||\n      this.config.backdrop === 'static' ||\n      event.target !== this._element.nativeElement\n    ) {\n      return;\n    }\n    this.dismissReason = DISMISS_REASONS.BACKRDOP;\n    this.hide(event);\n  }\n\n  // todo: consider preventing default and stopping propagation\n  @HostListener('keydown.esc', ['$event'])\n  onEsc(event: KeyboardEvent): void {\n    if (!this._isShown) {\n      return;\n    }\n    // tslint:disable-next-line:deprecation\n    if (event.keyCode === 27 || event.key === 'Escape') {\n      event.preventDefault();\n    }\n\n    if (this.config.keyboard) {\n      this.dismissReason = DISMISS_REASONS.ESC;\n      this.hide();\n    }\n  }\n\n  ngOnDestroy() {\n    this.config = void 0;\n    if (this._isShown) {\n      this._isShown = false;\n      this.hideModal();\n      this._backdrop.dispose();\n    }\n  }\n\n  ngOnInit(): void {\n    this._config = this._config || this.getConfig();\n    setTimeout(() => {\n      if (this._config.show) {\n        this.show();\n      }\n    }, 0);\n  }\n\n  /* Public methods */\n\n  /** Allows to manually toggle modal visibility */\n  toggle(): void {\n    return this._isShown ? this.hide() : this.show();\n  }\n\n  /** Allows to manually open modal */\n  show(): void {\n    this.dismissReason = null;\n    this.onShow.emit(this);\n    if (this._isShown) {\n      return;\n    }\n    clearTimeout(this.timerHideModal);\n    clearTimeout(this.timerRmBackDrop);\n\n    this._isShown = true;\n\n    this.checkScrollbar();\n    this.setScrollbar();\n\n    if (document && document.body) {\n      if (document.body.classList.contains(CLASS_NAME.OPEN)) {\n        this.isNested = true;\n      } else {\n        this._renderer.addClass(document.body, CLASS_NAME.OPEN);\n      }\n    }\n\n    this.showBackdrop(() => {\n      this.showElement();\n    });\n  }\n\n  /** Allows to manually close modal */\n  hide(event?: Event): void {\n    if (event) {\n      event.preventDefault();\n    }\n\n    this.onHide.emit(this);\n\n    // todo: add an option to prevent hiding\n    if (!this._isShown) {\n      return;\n    }\n\n    window.clearTimeout(this.timerHideModal);\n    window.clearTimeout(this.timerRmBackDrop);\n\n    this._isShown = false;\n    this._renderer.removeClass(this._element.nativeElement, CLASS_NAME.IN);\n    if (!isBs3()) {\n      this._renderer.removeClass(this._element.nativeElement, CLASS_NAME.SHOW);\n    }\n    // this._addClassIn = false;\n\n    if (this._config.animated) {\n      this.timerHideModal = window.setTimeout(\n        () => this.hideModal(),\n        TRANSITION_DURATION\n      );\n    } else {\n      this.hideModal();\n    }\n  }\n\n  /** Private methods @internal */\n  protected getConfig(config?: ModalOptions): ModalOptions {\n    return Object.assign({}, modalConfigDefaults, config);\n  }\n\n  /**\n   *  Show dialog\n   *  @internal\n   */\n  protected showElement(): void {\n    // todo: replace this with component loader usage\n    if (\n      !this._element.nativeElement.parentNode ||\n      this._element.nativeElement.parentNode.nodeType !== Node.ELEMENT_NODE\n    ) {\n      // don't move modals dom position\n      if (document && document.body) {\n        document.body.appendChild(this._element.nativeElement);\n      }\n    }\n\n    this._renderer.setAttribute(\n      this._element.nativeElement,\n      'aria-hidden',\n      'false'\n    );\n    this._renderer.setAttribute(\n      this._element.nativeElement,\n      'aria-modal',\n      'true'\n    );\n    this._renderer.setStyle(\n      this._element.nativeElement,\n      'display',\n      'block'\n    );\n    this._renderer.setProperty(\n      this._element.nativeElement,\n      'scrollTop',\n      0\n    );\n\n    if (this._config.animated) {\n      Utils.reflow(this._element.nativeElement);\n    }\n\n    // this._addClassIn = true;\n    this._renderer.addClass(this._element.nativeElement, CLASS_NAME.IN);\n    if (!isBs3()) {\n      this._renderer.addClass(this._element.nativeElement, CLASS_NAME.SHOW);\n    }\n\n    const transitionComplete = () => {\n      if (this._config.focus) {\n        this._element.nativeElement.focus();\n      }\n      this.onShown.emit(this);\n    };\n\n    if (this._config.animated) {\n      setTimeout(transitionComplete, TRANSITION_DURATION);\n    } else {\n      transitionComplete();\n    }\n  }\n\n  /** @internal */\n  protected hideModal(): void {\n    this._renderer.setAttribute(\n      this._element.nativeElement,\n      'aria-hidden',\n      'true'\n    );\n    this._renderer.setStyle(\n      this._element.nativeElement,\n      'display',\n      'none'\n    );\n    this.showBackdrop(() => {\n      if (!this.isNested) {\n        if (document && document.body) {\n          this._renderer.removeClass(document.body, CLASS_NAME.OPEN);\n        }\n        this.resetScrollbar();\n      }\n      this.resetAdjustments();\n      this.focusOtherModal();\n      this.onHidden.emit(this);\n    });\n  }\n\n  // todo: original show was calling a callback when done, but we can use\n  // promise\n  /** @internal */\n  protected showBackdrop(callback?: Function): void {\n    if (\n      this._isShown &&\n      this.config.backdrop &&\n      (!this.backdrop || !this.backdrop.instance.isShown)\n    ) {\n      this.removeBackdrop();\n      this._backdrop\n        .attach(ModalBackdropComponent)\n        .to('body')\n        .show({isAnimated: this._config.animated});\n      this.backdrop = this._backdrop._componentRef;\n\n      if (!callback) {\n        return;\n      }\n\n      if (!this._config.animated) {\n        callback();\n\n        return;\n      }\n\n      setTimeout(callback, BACKDROP_TRANSITION_DURATION);\n    } else if (!this._isShown && this.backdrop) {\n      this.backdrop.instance.isShown = false;\n\n      const callbackRemove = () => {\n        this.removeBackdrop();\n        if (callback) {\n          callback();\n        }\n      };\n\n      if (this.backdrop.instance.isAnimated) {\n        this.timerRmBackDrop = window.setTimeout(\n          callbackRemove,\n          BACKDROP_TRANSITION_DURATION\n        );\n      } else {\n        callbackRemove();\n      }\n    } else if (callback) {\n      callback();\n    }\n  }\n\n  /** @internal */\n  protected removeBackdrop(): void {\n    this._backdrop.hide();\n  }\n\n  /** Events tricks */\n\n  // no need for it\n  // protected setEscapeEvent():void {\n  //   if (this._isShown && this._config.keyboard) {\n  //     $(this._element).on(Event.KEYDOWN_DISMISS, (event) => {\n  //       if (event.which === 27) {\n  //         this.hide()\n  //       }\n  //     })\n  //\n  //   } else if (!this._isShown) {\n  //     $(this._element).off(Event.KEYDOWN_DISMISS)\n  //   }\n  // }\n\n  // protected setResizeEvent():void {\n  // console.log(this.renderer.listenGlobal('', Event.RESIZE));\n  // if (this._isShown) {\n  //   $(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this))\n  // } else {\n  //   $(window).off(Event.RESIZE)\n  // }\n  // }\n\n  protected focusOtherModal() {\n    if (this._element.nativeElement.parentElement == null) {\n      return;\n    }\n    const otherOpenedModals = this._element.nativeElement.parentElement.querySelectorAll('.in[bsModal]');\n    if (!otherOpenedModals.length) {\n      return;\n    }\n    otherOpenedModals[otherOpenedModals.length - 1].focus();\n  }\n\n  /** @internal */\n  protected resetAdjustments(): void {\n    this._renderer.setStyle(\n      this._element.nativeElement,\n      'paddingLeft',\n      ''\n    );\n    this._renderer.setStyle(\n      this._element.nativeElement,\n      'paddingRight',\n      ''\n    );\n  }\n\n  /** Scroll bar tricks */\n  /** @internal */\n  protected checkScrollbar(): void {\n    this.isBodyOverflowing = document.body.clientWidth < window.innerWidth;\n    this.scrollbarWidth = this.getScrollbarWidth();\n  }\n\n  protected setScrollbar(): void {\n    if (!document) {\n      return;\n    }\n\n    this.originalBodyPadding = parseInt(\n      window\n        .getComputedStyle(document.body)\n        .getPropertyValue('padding-right') || 0,\n      10\n    );\n\n    if (this.isBodyOverflowing) {\n      document.body.style.paddingRight = `${this.originalBodyPadding +\n      this.scrollbarWidth}px`;\n    }\n  }\n\n  protected resetScrollbar(): void {\n    document.body.style.paddingRight = `${this.originalBodyPadding}px`;\n  }\n\n  // thx d.walsh\n  protected getScrollbarWidth(): number {\n    const scrollDiv = this._renderer.createElement('div');\n    this._renderer.addClass(scrollDiv, CLASS_NAME.SCROLLBAR_MEASURER);\n    this._renderer.appendChild(document.body, scrollDiv);\n    const scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n    this._renderer.removeChild(document.body, scrollDiv);\n\n    return scrollbarWidth;\n  }\n}\n"]}