popover.js 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Directive, Input, Output, EventEmitter, ChangeDetectionStrategy, Inject, Injector, Renderer2, ElementRef, TemplateRef, ViewContainerRef, ComponentFactoryResolver, NgZone, ViewEncapsulation, ChangeDetectorRef, ApplicationRef } from '@angular/core';
  6. import { DOCUMENT } from '@angular/common';
  7. import { listenToTriggers } from '../util/triggers';
  8. import { ngbAutoClose } from '../util/autoclose';
  9. import { positionElements } from '../util/positioning';
  10. import { PopupService } from '../util/popup';
  11. import { NgbPopoverConfig } from './popover-config';
  12. /** @type {?} */
  13. var nextId = 0;
  14. var NgbPopoverWindow = /** @class */ (function () {
  15. function NgbPopoverWindow() {
  16. }
  17. /**
  18. * @return {?}
  19. */
  20. NgbPopoverWindow.prototype.isTitleTemplate = /**
  21. * @return {?}
  22. */
  23. function () { return this.title instanceof TemplateRef; };
  24. NgbPopoverWindow.decorators = [
  25. { type: Component, args: [{
  26. selector: 'ngb-popover-window',
  27. changeDetection: ChangeDetectionStrategy.OnPush,
  28. encapsulation: ViewEncapsulation.None,
  29. host: { '[class]': '"popover" + (popoverClass ? " " + popoverClass : "")', 'role': 'tooltip', '[id]': 'id' },
  30. template: "\n <div class=\"arrow\"></div>\n <h3 class=\"popover-header\" *ngIf=\"title != null\">\n <ng-template #simpleTitle>{{title}}</ng-template>\n <ng-template [ngTemplateOutlet]=\"isTitleTemplate() ? title : simpleTitle\" [ngTemplateOutletContext]=\"context\"></ng-template>\n </h3>\n <div class=\"popover-body\"><ng-content></ng-content></div>",
  31. styles: ["ngb-popover-window.bs-popover-bottom>.arrow,ngb-popover-window.bs-popover-top>.arrow{left:50%;margin-left:-.5rem}ngb-popover-window.bs-popover-bottom-left>.arrow,ngb-popover-window.bs-popover-top-left>.arrow{left:2em}ngb-popover-window.bs-popover-bottom-right>.arrow,ngb-popover-window.bs-popover-top-right>.arrow{left:auto;right:2em}ngb-popover-window.bs-popover-left>.arrow,ngb-popover-window.bs-popover-right>.arrow{top:50%;margin-top:-.5rem}ngb-popover-window.bs-popover-left-top>.arrow,ngb-popover-window.bs-popover-right-top>.arrow{top:.7em}ngb-popover-window.bs-popover-left-bottom>.arrow,ngb-popover-window.bs-popover-right-bottom>.arrow{top:auto;bottom:.7em}"]
  32. }] }
  33. ];
  34. NgbPopoverWindow.propDecorators = {
  35. title: [{ type: Input }],
  36. id: [{ type: Input }],
  37. popoverClass: [{ type: Input }],
  38. context: [{ type: Input }]
  39. };
  40. return NgbPopoverWindow;
  41. }());
  42. export { NgbPopoverWindow };
  43. if (false) {
  44. /** @type {?} */
  45. NgbPopoverWindow.prototype.title;
  46. /** @type {?} */
  47. NgbPopoverWindow.prototype.id;
  48. /** @type {?} */
  49. NgbPopoverWindow.prototype.popoverClass;
  50. /** @type {?} */
  51. NgbPopoverWindow.prototype.context;
  52. }
  53. /**
  54. * A lightweight and extensible directive for fancy popover creation.
  55. */
  56. var NgbPopover = /** @class */ (function () {
  57. function NgbPopover(_elementRef, _renderer, injector, componentFactoryResolver, viewContainerRef, config, _ngZone, _document, _changeDetector, applicationRef) {
  58. var _this = this;
  59. this._elementRef = _elementRef;
  60. this._renderer = _renderer;
  61. this._ngZone = _ngZone;
  62. this._document = _document;
  63. this._changeDetector = _changeDetector;
  64. /**
  65. * An event emitted when the popover is shown. Contains no payload.
  66. */
  67. this.shown = new EventEmitter();
  68. /**
  69. * An event emitted when the popover is hidden. Contains no payload.
  70. */
  71. this.hidden = new EventEmitter();
  72. this._ngbPopoverWindowId = "ngb-popover-" + nextId++;
  73. this.autoClose = config.autoClose;
  74. this.placement = config.placement;
  75. this.triggers = config.triggers;
  76. this.container = config.container;
  77. this.disablePopover = config.disablePopover;
  78. this.popoverClass = config.popoverClass;
  79. this.openDelay = config.openDelay;
  80. this.closeDelay = config.closeDelay;
  81. this._popupService = new PopupService(NgbPopoverWindow, injector, viewContainerRef, _renderer, componentFactoryResolver, applicationRef);
  82. this._zoneSubscription = _ngZone.onStable.subscribe((/**
  83. * @return {?}
  84. */
  85. function () {
  86. if (_this._windowRef) {
  87. positionElements(_this._elementRef.nativeElement, _this._windowRef.location.nativeElement, _this.placement, _this.container === 'body', 'bs-popover');
  88. }
  89. }));
  90. }
  91. /**
  92. * @private
  93. * @return {?}
  94. */
  95. NgbPopover.prototype._isDisabled = /**
  96. * @private
  97. * @return {?}
  98. */
  99. function () {
  100. if (this.disablePopover) {
  101. return true;
  102. }
  103. if (!this.ngbPopover && !this.popoverTitle) {
  104. return true;
  105. }
  106. return false;
  107. };
  108. /**
  109. * Opens the popover.
  110. *
  111. * This is considered to be a "manual" triggering.
  112. * The `context` is an optional value to be injected into the popover template when it is created.
  113. */
  114. /**
  115. * Opens the popover.
  116. *
  117. * This is considered to be a "manual" triggering.
  118. * The `context` is an optional value to be injected into the popover template when it is created.
  119. * @param {?=} context
  120. * @return {?}
  121. */
  122. NgbPopover.prototype.open = /**
  123. * Opens the popover.
  124. *
  125. * This is considered to be a "manual" triggering.
  126. * The `context` is an optional value to be injected into the popover template when it is created.
  127. * @param {?=} context
  128. * @return {?}
  129. */
  130. function (context) {
  131. var _this = this;
  132. if (!this._windowRef && !this._isDisabled()) {
  133. this._windowRef = this._popupService.open(this.ngbPopover, context);
  134. this._windowRef.instance.title = this.popoverTitle;
  135. this._windowRef.instance.context = context;
  136. this._windowRef.instance.popoverClass = this.popoverClass;
  137. this._windowRef.instance.id = this._ngbPopoverWindowId;
  138. this._renderer.setAttribute(this._elementRef.nativeElement, 'aria-describedby', this._ngbPopoverWindowId);
  139. if (this.container === 'body') {
  140. this._document.querySelector(this.container).appendChild(this._windowRef.location.nativeElement);
  141. }
  142. // We need to detect changes, because we don't know where .open() might be called from.
  143. // Ex. opening popover from one of lifecycle hooks that run after the CD
  144. // (say from ngAfterViewInit) will result in 'ExpressionHasChanged' exception
  145. this._windowRef.changeDetectorRef.detectChanges();
  146. // We need to mark for check, because popover won't work inside the OnPush component.
  147. // Ex. when we use expression like `{{ popover.isOpen() : 'opened' : 'closed' }}`
  148. // inside the template of an OnPush component and we change the popover from
  149. // open -> closed, the expression in question won't be updated unless we explicitly
  150. // mark the parent component to be checked.
  151. this._windowRef.changeDetectorRef.markForCheck();
  152. ngbAutoClose(this._ngZone, this._document, this.autoClose, (/**
  153. * @return {?}
  154. */
  155. function () { return _this.close(); }), this.hidden, [this._windowRef.location.nativeElement]);
  156. this.shown.emit();
  157. }
  158. };
  159. /**
  160. * Closes the popover.
  161. *
  162. * This is considered to be a "manual" triggering of the popover.
  163. */
  164. /**
  165. * Closes the popover.
  166. *
  167. * This is considered to be a "manual" triggering of the popover.
  168. * @return {?}
  169. */
  170. NgbPopover.prototype.close = /**
  171. * Closes the popover.
  172. *
  173. * This is considered to be a "manual" triggering of the popover.
  174. * @return {?}
  175. */
  176. function () {
  177. if (this._windowRef) {
  178. this._renderer.removeAttribute(this._elementRef.nativeElement, 'aria-describedby');
  179. this._popupService.close();
  180. this._windowRef = null;
  181. this.hidden.emit();
  182. this._changeDetector.markForCheck();
  183. }
  184. };
  185. /**
  186. * Toggles the popover.
  187. *
  188. * This is considered to be a "manual" triggering of the popover.
  189. */
  190. /**
  191. * Toggles the popover.
  192. *
  193. * This is considered to be a "manual" triggering of the popover.
  194. * @return {?}
  195. */
  196. NgbPopover.prototype.toggle = /**
  197. * Toggles the popover.
  198. *
  199. * This is considered to be a "manual" triggering of the popover.
  200. * @return {?}
  201. */
  202. function () {
  203. if (this._windowRef) {
  204. this.close();
  205. }
  206. else {
  207. this.open();
  208. }
  209. };
  210. /**
  211. * Returns `true`, if the popover is currently shown.
  212. */
  213. /**
  214. * Returns `true`, if the popover is currently shown.
  215. * @return {?}
  216. */
  217. NgbPopover.prototype.isOpen = /**
  218. * Returns `true`, if the popover is currently shown.
  219. * @return {?}
  220. */
  221. function () { return this._windowRef != null; };
  222. /**
  223. * @return {?}
  224. */
  225. NgbPopover.prototype.ngOnInit = /**
  226. * @return {?}
  227. */
  228. function () {
  229. this._unregisterListenersFn = listenToTriggers(this._renderer, this._elementRef.nativeElement, this.triggers, this.isOpen.bind(this), this.open.bind(this), this.close.bind(this), +this.openDelay, +this.closeDelay);
  230. };
  231. /**
  232. * @param {?} __0
  233. * @return {?}
  234. */
  235. NgbPopover.prototype.ngOnChanges = /**
  236. * @param {?} __0
  237. * @return {?}
  238. */
  239. function (_a) {
  240. var ngbPopover = _a.ngbPopover, popoverTitle = _a.popoverTitle, disablePopover = _a.disablePopover, popoverClass = _a.popoverClass;
  241. if (popoverClass && this.isOpen()) {
  242. this._windowRef.instance.popoverClass = popoverClass.currentValue;
  243. }
  244. // close popover if title and content become empty, or disablePopover set to true
  245. if ((ngbPopover || popoverTitle || disablePopover) && this._isDisabled()) {
  246. this.close();
  247. }
  248. };
  249. /**
  250. * @return {?}
  251. */
  252. NgbPopover.prototype.ngOnDestroy = /**
  253. * @return {?}
  254. */
  255. function () {
  256. this.close();
  257. // This check is needed as it might happen that ngOnDestroy is called before ngOnInit
  258. // under certain conditions, see: https://github.com/ng-bootstrap/ng-bootstrap/issues/2199
  259. if (this._unregisterListenersFn) {
  260. this._unregisterListenersFn();
  261. }
  262. this._zoneSubscription.unsubscribe();
  263. };
  264. NgbPopover.decorators = [
  265. { type: Directive, args: [{ selector: '[ngbPopover]', exportAs: 'ngbPopover' },] }
  266. ];
  267. /** @nocollapse */
  268. NgbPopover.ctorParameters = function () { return [
  269. { type: ElementRef },
  270. { type: Renderer2 },
  271. { type: Injector },
  272. { type: ComponentFactoryResolver },
  273. { type: ViewContainerRef },
  274. { type: NgbPopoverConfig },
  275. { type: NgZone },
  276. { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
  277. { type: ChangeDetectorRef },
  278. { type: ApplicationRef }
  279. ]; };
  280. NgbPopover.propDecorators = {
  281. autoClose: [{ type: Input }],
  282. ngbPopover: [{ type: Input }],
  283. popoverTitle: [{ type: Input }],
  284. placement: [{ type: Input }],
  285. triggers: [{ type: Input }],
  286. container: [{ type: Input }],
  287. disablePopover: [{ type: Input }],
  288. popoverClass: [{ type: Input }],
  289. openDelay: [{ type: Input }],
  290. closeDelay: [{ type: Input }],
  291. shown: [{ type: Output }],
  292. hidden: [{ type: Output }]
  293. };
  294. return NgbPopover;
  295. }());
  296. export { NgbPopover };
  297. if (false) {
  298. /**
  299. * Indicates whether the popover should be closed on `Escape` key and inside/outside clicks:
  300. *
  301. * * `true` - closes on both outside and inside clicks as well as `Escape` presses
  302. * * `false` - disables the autoClose feature (NB: triggers still apply)
  303. * * `"inside"` - closes on inside clicks as well as Escape presses
  304. * * `"outside"` - closes on outside clicks (sometimes also achievable through triggers)
  305. * as well as `Escape` presses
  306. *
  307. * \@since 3.0.0
  308. * @type {?}
  309. */
  310. NgbPopover.prototype.autoClose;
  311. /**
  312. * The string content or a `TemplateRef` for the content to be displayed in the popover.
  313. *
  314. * If the title and the content are empty, the popover won't open.
  315. * @type {?}
  316. */
  317. NgbPopover.prototype.ngbPopover;
  318. /**
  319. * The title of the popover.
  320. *
  321. * If the title and the content are empty, the popover won't open.
  322. * @type {?}
  323. */
  324. NgbPopover.prototype.popoverTitle;
  325. /**
  326. * The preferred placement of the popover.
  327. *
  328. * Possible values are `"top"`, `"top-left"`, `"top-right"`, `"bottom"`, `"bottom-left"`,
  329. * `"bottom-right"`, `"left"`, `"left-top"`, `"left-bottom"`, `"right"`, `"right-top"`,
  330. * `"right-bottom"`
  331. *
  332. * Accepts an array of strings or a string with space separated possible values.
  333. *
  334. * The default order of preference is `"auto"` (same as the sequence above).
  335. *
  336. * Please see the [positioning overview](#/positioning) for more details.
  337. * @type {?}
  338. */
  339. NgbPopover.prototype.placement;
  340. /**
  341. * Specifies events that should trigger the tooltip.
  342. *
  343. * Supports a space separated list of event names.
  344. * For more details see the [triggers demo](#/components/popover/examples#triggers).
  345. * @type {?}
  346. */
  347. NgbPopover.prototype.triggers;
  348. /**
  349. * A selector specifying the element the popover should be appended to.
  350. *
  351. * Currently only supports `body`.
  352. * @type {?}
  353. */
  354. NgbPopover.prototype.container;
  355. /**
  356. * If `true`, popover is disabled and won't be displayed.
  357. *
  358. * \@since 1.1.0
  359. * @type {?}
  360. */
  361. NgbPopover.prototype.disablePopover;
  362. /**
  363. * An optional class applied to the popover window element.
  364. *
  365. * \@since 2.2.0
  366. * @type {?}
  367. */
  368. NgbPopover.prototype.popoverClass;
  369. /**
  370. * The opening delay in ms. Works only for "non-manual" opening triggers defined by the `triggers` input.
  371. *
  372. * \@since 4.1.0
  373. * @type {?}
  374. */
  375. NgbPopover.prototype.openDelay;
  376. /**
  377. * The closing delay in ms. Works only for "non-manual" opening triggers defined by the `triggers` input.
  378. *
  379. * \@since 4.1.0
  380. * @type {?}
  381. */
  382. NgbPopover.prototype.closeDelay;
  383. /**
  384. * An event emitted when the popover is shown. Contains no payload.
  385. * @type {?}
  386. */
  387. NgbPopover.prototype.shown;
  388. /**
  389. * An event emitted when the popover is hidden. Contains no payload.
  390. * @type {?}
  391. */
  392. NgbPopover.prototype.hidden;
  393. /**
  394. * @type {?}
  395. * @private
  396. */
  397. NgbPopover.prototype._ngbPopoverWindowId;
  398. /**
  399. * @type {?}
  400. * @private
  401. */
  402. NgbPopover.prototype._popupService;
  403. /**
  404. * @type {?}
  405. * @private
  406. */
  407. NgbPopover.prototype._windowRef;
  408. /**
  409. * @type {?}
  410. * @private
  411. */
  412. NgbPopover.prototype._unregisterListenersFn;
  413. /**
  414. * @type {?}
  415. * @private
  416. */
  417. NgbPopover.prototype._zoneSubscription;
  418. /**
  419. * @type {?}
  420. * @private
  421. */
  422. NgbPopover.prototype._elementRef;
  423. /**
  424. * @type {?}
  425. * @private
  426. */
  427. NgbPopover.prototype._renderer;
  428. /**
  429. * @type {?}
  430. * @private
  431. */
  432. NgbPopover.prototype._ngZone;
  433. /**
  434. * @type {?}
  435. * @private
  436. */
  437. NgbPopover.prototype._document;
  438. /**
  439. * @type {?}
  440. * @private
  441. */
  442. NgbPopover.prototype._changeDetector;
  443. }
  444. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["popover/popover.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  OnInit,\n  OnDestroy,\n  OnChanges,\n  Inject,\n  Injector,\n  Renderer2,\n  ComponentRef,\n  ElementRef,\n  TemplateRef,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  NgZone,\n  SimpleChanges,\n  ViewEncapsulation,\n  ChangeDetectorRef,\n  ApplicationRef\n} from '@angular/core';\nimport {DOCUMENT} from '@angular/common';\n\nimport {listenToTriggers} from '../util/triggers';\nimport {ngbAutoClose} from '../util/autoclose';\nimport {positionElements, PlacementArray} from '../util/positioning';\nimport {PopupService} from '../util/popup';\n\nimport {NgbPopoverConfig} from './popover-config';\n\nlet nextId = 0;\n\n@Component({\n  selector: 'ngb-popover-window',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {'[class]': '\"popover\" + (popoverClass ? \" \" + popoverClass : \"\")', 'role': 'tooltip', '[id]': 'id'},\n  template: `\n    <div class=\"arrow\"></div>\n    <h3 class=\"popover-header\" *ngIf=\"title != null\">\n      <ng-template #simpleTitle>{{title}}</ng-template>\n      <ng-template [ngTemplateOutlet]=\"isTitleTemplate() ? title : simpleTitle\" [ngTemplateOutletContext]=\"context\"></ng-template>\n    </h3>\n    <div class=\"popover-body\"><ng-content></ng-content></div>`,\n  styleUrls: ['./popover.scss']\n})\nexport class NgbPopoverWindow {\n  @Input() title: undefined | string | TemplateRef<any>;\n  @Input() id: string;\n  @Input() popoverClass: string;\n  @Input() context: any;\n\n  isTitleTemplate() { return this.title instanceof TemplateRef; }\n}\n\n/**\n * A lightweight and extensible directive for fancy popover creation.\n */\n@Directive({selector: '[ngbPopover]', exportAs: 'ngbPopover'})\nexport class NgbPopover implements OnInit, OnDestroy, OnChanges {\n  /**\n   * Indicates whether the popover should be closed on `Escape` key and inside/outside clicks:\n   *\n   * * `true` - closes on both outside and inside clicks as well as `Escape` presses\n   * * `false` - disables the autoClose feature (NB: triggers still apply)\n   * * `\"inside\"` - closes on inside clicks as well as Escape presses\n   * * `\"outside\"` - closes on outside clicks (sometimes also achievable through triggers)\n   * as well as `Escape` presses\n   *\n   * @since 3.0.0\n   */\n  @Input() autoClose: boolean | 'inside' | 'outside';\n\n  /**\n   * The string content or a `TemplateRef` for the content to be displayed in the popover.\n   *\n   * If the title and the content are empty, the popover won't open.\n   */\n  @Input() ngbPopover: string | TemplateRef<any>;\n\n  /**\n   * The title of the popover.\n   *\n   * If the title and the content are empty, the popover won't open.\n   */\n  @Input() popoverTitle: string | TemplateRef<any>;\n\n  /**\n   * The preferred placement of the popover.\n   *\n   * Possible values are `\"top\"`, `\"top-left\"`, `\"top-right\"`, `\"bottom\"`, `\"bottom-left\"`,\n   * `\"bottom-right\"`, `\"left\"`, `\"left-top\"`, `\"left-bottom\"`, `\"right\"`, `\"right-top\"`,\n   * `\"right-bottom\"`\n   *\n   * Accepts an array of strings or a string with space separated possible values.\n   *\n   * The default order of preference is `\"auto\"` (same as the sequence above).\n   *\n   * Please see the [positioning overview](#/positioning) for more details.\n   */\n  @Input() placement: PlacementArray;\n\n  /**\n   * Specifies events that should trigger the tooltip.\n   *\n   * Supports a space separated list of event names.\n   * For more details see the [triggers demo](#/components/popover/examples#triggers).\n   */\n  @Input() triggers: string;\n\n  /**\n   * A selector specifying the element the popover should be appended to.\n   *\n   * Currently only supports `body`.\n   */\n  @Input() container: string;\n\n  /**\n   * If `true`, popover is disabled and won't be displayed.\n   *\n   * @since 1.1.0\n   */\n  @Input() disablePopover: boolean;\n\n  /**\n   * An optional class applied to the popover window element.\n   *\n   * @since 2.2.0\n   */\n  @Input() popoverClass: string;\n\n  /**\n   * The opening delay in ms. Works only for \"non-manual\" opening triggers defined by the `triggers` input.\n   *\n   * @since 4.1.0\n   */\n  @Input() openDelay: number;\n\n  /**\n   * The closing delay in ms. Works only for \"non-manual\" opening triggers defined by the `triggers` input.\n   *\n   * @since 4.1.0\n   */\n  @Input() closeDelay: number;\n\n  /**\n   * An event emitted when the popover is shown. Contains no payload.\n   */\n  @Output() shown = new EventEmitter<void>();\n\n  /**\n   * An event emitted when the popover is hidden. Contains no payload.\n   */\n  @Output() hidden = new EventEmitter<void>();\n\n  private _ngbPopoverWindowId = `ngb-popover-${nextId++}`;\n  private _popupService: PopupService<NgbPopoverWindow>;\n  private _windowRef: ComponentRef<NgbPopoverWindow>;\n  private _unregisterListenersFn;\n  private _zoneSubscription: any;\n  private _isDisabled(): boolean {\n    if (this.disablePopover) {\n      return true;\n    }\n    if (!this.ngbPopover && !this.popoverTitle) {\n      return true;\n    }\n    return false;\n  }\n\n  constructor(\n      private _elementRef: ElementRef<HTMLElement>, private _renderer: Renderer2, injector: Injector,\n      componentFactoryResolver: ComponentFactoryResolver, viewContainerRef: ViewContainerRef, config: NgbPopoverConfig,\n      private _ngZone: NgZone, @Inject(DOCUMENT) private _document: any, private _changeDetector: ChangeDetectorRef,\n      applicationRef: ApplicationRef) {\n    this.autoClose = config.autoClose;\n    this.placement = config.placement;\n    this.triggers = config.triggers;\n    this.container = config.container;\n    this.disablePopover = config.disablePopover;\n    this.popoverClass = config.popoverClass;\n    this.openDelay = config.openDelay;\n    this.closeDelay = config.closeDelay;\n    this._popupService = new PopupService<NgbPopoverWindow>(\n        NgbPopoverWindow, injector, viewContainerRef, _renderer, componentFactoryResolver, applicationRef);\n\n    this._zoneSubscription = _ngZone.onStable.subscribe(() => {\n      if (this._windowRef) {\n        positionElements(\n            this._elementRef.nativeElement, this._windowRef.location.nativeElement, this.placement,\n            this.container === 'body', 'bs-popover');\n      }\n    });\n  }\n\n  /**\n   * Opens the popover.\n   *\n   * This is considered to be a \"manual\" triggering.\n   * The `context` is an optional value to be injected into the popover template when it is created.\n   */\n  open(context?: any) {\n    if (!this._windowRef && !this._isDisabled()) {\n      this._windowRef = this._popupService.open(this.ngbPopover, context);\n      this._windowRef.instance.title = this.popoverTitle;\n      this._windowRef.instance.context = context;\n      this._windowRef.instance.popoverClass = this.popoverClass;\n      this._windowRef.instance.id = this._ngbPopoverWindowId;\n\n      this._renderer.setAttribute(this._elementRef.nativeElement, 'aria-describedby', this._ngbPopoverWindowId);\n\n      if (this.container === 'body') {\n        this._document.querySelector(this.container).appendChild(this._windowRef.location.nativeElement);\n      }\n\n      // We need to detect changes, because we don't know where .open() might be called from.\n      // Ex. opening popover from one of lifecycle hooks that run after the CD\n      // (say from ngAfterViewInit) will result in 'ExpressionHasChanged' exception\n      this._windowRef.changeDetectorRef.detectChanges();\n\n      // We need to mark for check, because popover won't work inside the OnPush component.\n      // Ex. when we use expression like `{{ popover.isOpen() : 'opened' : 'closed' }}`\n      // inside the template of an OnPush component and we change the popover from\n      // open -> closed, the expression in question won't be updated unless we explicitly\n      // mark the parent component to be checked.\n      this._windowRef.changeDetectorRef.markForCheck();\n\n      ngbAutoClose(\n          this._ngZone, this._document, this.autoClose, () => this.close(), this.hidden,\n          [this._windowRef.location.nativeElement]);\n      this.shown.emit();\n    }\n  }\n\n  /**\n   * Closes the popover.\n   *\n   * This is considered to be a \"manual\" triggering of the popover.\n   */\n  close(): void {\n    if (this._windowRef) {\n      this._renderer.removeAttribute(this._elementRef.nativeElement, 'aria-describedby');\n      this._popupService.close();\n      this._windowRef = null;\n      this.hidden.emit();\n      this._changeDetector.markForCheck();\n    }\n  }\n\n  /**\n   * Toggles the popover.\n   *\n   * This is considered to be a \"manual\" triggering of the popover.\n   */\n  toggle(): void {\n    if (this._windowRef) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  /**\n   * Returns `true`, if the popover is currently shown.\n   */\n  isOpen(): boolean { return this._windowRef != null; }\n\n  ngOnInit() {\n    this._unregisterListenersFn = listenToTriggers(\n        this._renderer, this._elementRef.nativeElement, this.triggers, this.isOpen.bind(this), this.open.bind(this),\n        this.close.bind(this), +this.openDelay, +this.closeDelay);\n  }\n\n  ngOnChanges({ngbPopover, popoverTitle, disablePopover, popoverClass}: SimpleChanges) {\n    if (popoverClass && this.isOpen()) {\n      this._windowRef.instance.popoverClass = popoverClass.currentValue;\n    }\n    // close popover if title and content become empty, or disablePopover set to true\n    if ((ngbPopover || popoverTitle || disablePopover) && this._isDisabled()) {\n      this.close();\n    }\n  }\n\n  ngOnDestroy() {\n    this.close();\n    // This check is needed as it might happen that ngOnDestroy is called before ngOnInit\n    // under certain conditions, see: https://github.com/ng-bootstrap/ng-bootstrap/issues/2199\n    if (this._unregisterListenersFn) {\n      this._unregisterListenersFn();\n    }\n    this._zoneSubscription.unsubscribe();\n  }\n}\n"]}