popover.js 34 KB

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