tooltip.directive.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. /* tslint:disable: max-file-line-count deprecation */
  7. import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, ViewContainerRef } from '@angular/core';
  8. import { TooltipContainerComponent } from './tooltip-container.component';
  9. import { TooltipConfig } from './tooltip.config';
  10. import { ComponentLoaderFactory } from 'ngx-bootstrap/component-loader';
  11. import { OnChange, warnOnce, parseTriggers } from 'ngx-bootstrap/utils';
  12. import { PositioningService } from 'ngx-bootstrap/positioning';
  13. import { timer } from 'rxjs';
  14. /** @type {?} */
  15. let id = 0;
  16. export class TooltipDirective {
  17. /**
  18. * @param {?} _viewContainerRef
  19. * @param {?} cis
  20. * @param {?} config
  21. * @param {?} _elementRef
  22. * @param {?} _renderer
  23. * @param {?} _positionService
  24. */
  25. constructor(_viewContainerRef, cis, config, _elementRef, _renderer, _positionService) {
  26. this._elementRef = _elementRef;
  27. this._renderer = _renderer;
  28. this._positionService = _positionService;
  29. this.tooltipId = id++;
  30. /**
  31. * Fired when tooltip content changes
  32. */
  33. /* tslint:disable-next-line:no-any */
  34. this.tooltipChange = new EventEmitter();
  35. /**
  36. * Css class for tooltip container
  37. */
  38. this.containerClass = '';
  39. /**
  40. * @deprecated - removed, will be added to configuration
  41. */
  42. this.tooltipAnimation = true;
  43. /**
  44. * @deprecated
  45. */
  46. this.tooltipFadeDuration = 150;
  47. this.ariaDescribedby = `tooltip-${this.tooltipId}`;
  48. /**
  49. * @deprecated
  50. */
  51. this.tooltipStateChanged = new EventEmitter();
  52. this._tooltip = cis
  53. .createLoader(this._elementRef, _viewContainerRef, this._renderer)
  54. .provide({ provide: TooltipConfig, useValue: config });
  55. Object.assign(this, config);
  56. this.onShown = this._tooltip.onShown;
  57. this.onHidden = this._tooltip.onHidden;
  58. }
  59. /**
  60. * Returns whether or not the tooltip is currently being shown
  61. * @return {?}
  62. */
  63. get isOpen() {
  64. return this._tooltip.isShown;
  65. }
  66. /**
  67. * @param {?} value
  68. * @return {?}
  69. */
  70. set isOpen(value) {
  71. if (value) {
  72. this.show();
  73. }
  74. else {
  75. this.hide();
  76. }
  77. }
  78. /**
  79. * @deprecated - please use `tooltip` instead
  80. * @param {?} value
  81. * @return {?}
  82. */
  83. set htmlContent(value) {
  84. warnOnce('tooltipHtml was deprecated, please use `tooltip` instead');
  85. this.tooltip = value;
  86. }
  87. /**
  88. * @deprecated - please use `placement` instead
  89. * @param {?} value
  90. * @return {?}
  91. */
  92. set _placement(value) {
  93. warnOnce('tooltipPlacement was deprecated, please use `placement` instead');
  94. this.placement = value;
  95. }
  96. /**
  97. * @deprecated - please use `isOpen` instead
  98. * @param {?} value
  99. * @return {?}
  100. */
  101. set _isOpen(value) {
  102. warnOnce('tooltipIsOpen was deprecated, please use `isOpen` instead');
  103. this.isOpen = value;
  104. }
  105. /**
  106. * @return {?}
  107. */
  108. get _isOpen() {
  109. warnOnce('tooltipIsOpen was deprecated, please use `isOpen` instead');
  110. return this.isOpen;
  111. }
  112. /**
  113. * @deprecated - please use `isDisabled` instead
  114. * @param {?} value
  115. * @return {?}
  116. */
  117. set _enable(value) {
  118. warnOnce('tooltipEnable was deprecated, please use `isDisabled` instead');
  119. this.isDisabled = !value;
  120. }
  121. /**
  122. * @return {?}
  123. */
  124. get _enable() {
  125. warnOnce('tooltipEnable was deprecated, please use `isDisabled` instead');
  126. return this.isDisabled;
  127. }
  128. /**
  129. * @deprecated - please use `container="body"` instead
  130. * @param {?} value
  131. * @return {?}
  132. */
  133. set _appendToBody(value) {
  134. warnOnce('tooltipAppendToBody was deprecated, please use `container="body"` instead');
  135. this.container = value ? 'body' : this.container;
  136. }
  137. /**
  138. * @return {?}
  139. */
  140. get _appendToBody() {
  141. warnOnce('tooltipAppendToBody was deprecated, please use `container="body"` instead');
  142. return this.container === 'body';
  143. }
  144. /**
  145. * @deprecated - will replaced with customClass
  146. * @param {?} value
  147. * @return {?}
  148. */
  149. set _popupClass(value) {
  150. warnOnce('tooltipClass deprecated');
  151. }
  152. /**
  153. * @deprecated - removed
  154. * @param {?} value
  155. * @return {?}
  156. */
  157. set _tooltipContext(value) {
  158. warnOnce('tooltipContext deprecated');
  159. }
  160. /**
  161. * @deprecated
  162. * @param {?} value
  163. * @return {?}
  164. */
  165. set _tooltipPopupDelay(value) {
  166. warnOnce('tooltipPopupDelay is deprecated, use `delay` instead');
  167. this.delay = value;
  168. }
  169. /**
  170. * @deprecated - please use `triggers` instead
  171. * @return {?}
  172. */
  173. get _tooltipTrigger() {
  174. warnOnce('tooltipTrigger was deprecated, please use `triggers` instead');
  175. return this.triggers;
  176. }
  177. /**
  178. * @param {?} value
  179. * @return {?}
  180. */
  181. set _tooltipTrigger(value) {
  182. warnOnce('tooltipTrigger was deprecated, please use `triggers` instead');
  183. this.triggers = (value || '').toString();
  184. }
  185. /**
  186. * @return {?}
  187. */
  188. ngOnInit() {
  189. this._tooltip.listen({
  190. triggers: this.triggers,
  191. show: (/**
  192. * @return {?}
  193. */
  194. () => this.show())
  195. });
  196. /* tslint:disable-next-line:no-any */
  197. this.tooltipChange.subscribe((/**
  198. * @param {?} value
  199. * @return {?}
  200. */
  201. (value) => {
  202. if (!value) {
  203. this._tooltip.hide();
  204. }
  205. }));
  206. }
  207. /**
  208. * Toggles an element’s tooltip. This is considered a “manual” triggering of
  209. * the tooltip.
  210. * @return {?}
  211. */
  212. toggle() {
  213. if (this.isOpen) {
  214. return this.hide();
  215. }
  216. this.show();
  217. }
  218. /**
  219. * Opens an element’s tooltip. This is considered a “manual” triggering of
  220. * the tooltip.
  221. * @return {?}
  222. */
  223. show() {
  224. this._positionService.setOptions({
  225. modifiers: {
  226. flip: {
  227. enabled: this.adaptivePosition
  228. },
  229. preventOverflow: {
  230. enabled: this.adaptivePosition
  231. }
  232. }
  233. });
  234. if (this.isOpen ||
  235. this.isDisabled ||
  236. this._delayTimeoutId ||
  237. !this.tooltip) {
  238. return;
  239. }
  240. /** @type {?} */
  241. const showTooltip = (/**
  242. * @return {?}
  243. */
  244. () => {
  245. if (this._delayTimeoutId) {
  246. this._delayTimeoutId = undefined;
  247. }
  248. this._tooltip
  249. .attach(TooltipContainerComponent)
  250. .to(this.container)
  251. .position({ attachment: this.placement })
  252. .show({
  253. content: this.tooltip,
  254. placement: this.placement,
  255. containerClass: this.containerClass,
  256. id: this.ariaDescribedby
  257. });
  258. });
  259. /** @type {?} */
  260. const cancelDelayedTooltipShowing = (/**
  261. * @return {?}
  262. */
  263. () => {
  264. if (this._tooltipCancelShowFn) {
  265. this._tooltipCancelShowFn();
  266. }
  267. });
  268. if (this.delay) {
  269. /** @type {?} */
  270. const _timer = timer(this.delay).subscribe((/**
  271. * @return {?}
  272. */
  273. () => {
  274. showTooltip();
  275. cancelDelayedTooltipShowing();
  276. }));
  277. if (this.triggers) {
  278. parseTriggers(this.triggers)
  279. .forEach((/**
  280. * @param {?} trigger
  281. * @return {?}
  282. */
  283. (trigger) => {
  284. this._tooltipCancelShowFn = this._renderer.listen(this._elementRef.nativeElement, trigger.close, (/**
  285. * @return {?}
  286. */
  287. () => {
  288. _timer.unsubscribe();
  289. cancelDelayedTooltipShowing();
  290. }));
  291. }));
  292. }
  293. }
  294. else {
  295. showTooltip();
  296. }
  297. }
  298. /**
  299. * Closes an element’s tooltip. This is considered a “manual” triggering of
  300. * the tooltip.
  301. * @return {?}
  302. */
  303. hide() {
  304. if (this._delayTimeoutId) {
  305. clearTimeout(this._delayTimeoutId);
  306. this._delayTimeoutId = undefined;
  307. }
  308. if (!this._tooltip.isShown) {
  309. return;
  310. }
  311. this._tooltip.instance.classMap.in = false;
  312. setTimeout((/**
  313. * @return {?}
  314. */
  315. () => {
  316. this._tooltip.hide();
  317. }), this.tooltipFadeDuration);
  318. }
  319. /**
  320. * @return {?}
  321. */
  322. ngOnDestroy() {
  323. this._tooltip.dispose();
  324. }
  325. }
  326. TooltipDirective.decorators = [
  327. { type: Directive, args: [{
  328. selector: '[tooltip], [tooltipHtml]',
  329. exportAs: 'bs-tooltip'
  330. },] }
  331. ];
  332. /** @nocollapse */
  333. TooltipDirective.ctorParameters = () => [
  334. { type: ViewContainerRef },
  335. { type: ComponentLoaderFactory },
  336. { type: TooltipConfig },
  337. { type: ElementRef },
  338. { type: Renderer2 },
  339. { type: PositioningService }
  340. ];
  341. TooltipDirective.propDecorators = {
  342. adaptivePosition: [{ type: Input }],
  343. tooltip: [{ type: Input }],
  344. tooltipChange: [{ type: Output }],
  345. placement: [{ type: Input }],
  346. triggers: [{ type: Input }],
  347. container: [{ type: Input }],
  348. containerClass: [{ type: Input }],
  349. isOpen: [{ type: Input }],
  350. isDisabled: [{ type: Input }],
  351. delay: [{ type: Input }],
  352. onShown: [{ type: Output }],
  353. onHidden: [{ type: Output }],
  354. htmlContent: [{ type: Input, args: ['tooltipHtml',] }],
  355. _placement: [{ type: Input, args: ['tooltipPlacement',] }],
  356. _isOpen: [{ type: Input, args: ['tooltipIsOpen',] }],
  357. _enable: [{ type: Input, args: ['tooltipEnable',] }],
  358. _appendToBody: [{ type: Input, args: ['tooltipAppendToBody',] }],
  359. tooltipAnimation: [{ type: Input }],
  360. _popupClass: [{ type: Input, args: ['tooltipClass',] }],
  361. _tooltipContext: [{ type: Input, args: ['tooltipContext',] }],
  362. _tooltipPopupDelay: [{ type: Input, args: ['tooltipPopupDelay',] }],
  363. tooltipFadeDuration: [{ type: Input }],
  364. _tooltipTrigger: [{ type: Input, args: ['tooltipTrigger',] }],
  365. ariaDescribedby: [{ type: HostBinding, args: ['attr.aria-describedby',] }],
  366. tooltipStateChanged: [{ type: Output }]
  367. };
  368. tslib_1.__decorate([
  369. OnChange(),
  370. tslib_1.__metadata("design:type", Object)
  371. ], TooltipDirective.prototype, "tooltip", void 0);
  372. if (false) {
  373. /** @type {?} */
  374. TooltipDirective.prototype.tooltipId;
  375. /**
  376. * sets disable adaptive position
  377. * @type {?}
  378. */
  379. TooltipDirective.prototype.adaptivePosition;
  380. /**
  381. * Content to be displayed as tooltip.
  382. * @type {?}
  383. */
  384. TooltipDirective.prototype.tooltip;
  385. /**
  386. * Fired when tooltip content changes
  387. * @type {?}
  388. */
  389. TooltipDirective.prototype.tooltipChange;
  390. /**
  391. * Placement of a tooltip. Accepts: "top", "bottom", "left", "right"
  392. * @type {?}
  393. */
  394. TooltipDirective.prototype.placement;
  395. /**
  396. * Specifies events that should trigger. Supports a space separated list of
  397. * event names.
  398. * @type {?}
  399. */
  400. TooltipDirective.prototype.triggers;
  401. /**
  402. * A selector specifying the element the tooltip should be appended to.
  403. * @type {?}
  404. */
  405. TooltipDirective.prototype.container;
  406. /**
  407. * Css class for tooltip container
  408. * @type {?}
  409. */
  410. TooltipDirective.prototype.containerClass;
  411. /**
  412. * Allows to disable tooltip
  413. * @type {?}
  414. */
  415. TooltipDirective.prototype.isDisabled;
  416. /**
  417. * Delay before showing the tooltip
  418. * @type {?}
  419. */
  420. TooltipDirective.prototype.delay;
  421. /**
  422. * Emits an event when the tooltip is shown
  423. * @type {?}
  424. */
  425. TooltipDirective.prototype.onShown;
  426. /**
  427. * Emits an event when the tooltip is hidden
  428. * @type {?}
  429. */
  430. TooltipDirective.prototype.onHidden;
  431. /**
  432. * @deprecated - removed, will be added to configuration
  433. * @type {?}
  434. */
  435. TooltipDirective.prototype.tooltipAnimation;
  436. /**
  437. * @deprecated
  438. * @type {?}
  439. */
  440. TooltipDirective.prototype.tooltipFadeDuration;
  441. /** @type {?} */
  442. TooltipDirective.prototype.ariaDescribedby;
  443. /**
  444. * @deprecated
  445. * @type {?}
  446. */
  447. TooltipDirective.prototype.tooltipStateChanged;
  448. /**
  449. * @type {?}
  450. * @protected
  451. */
  452. TooltipDirective.prototype._delayTimeoutId;
  453. /**
  454. * @type {?}
  455. * @protected
  456. */
  457. TooltipDirective.prototype._tooltipCancelShowFn;
  458. /**
  459. * @type {?}
  460. * @private
  461. */
  462. TooltipDirective.prototype._tooltip;
  463. /**
  464. * @type {?}
  465. * @private
  466. */
  467. TooltipDirective.prototype._elementRef;
  468. /**
  469. * @type {?}
  470. * @private
  471. */
  472. TooltipDirective.prototype._renderer;
  473. /**
  474. * @type {?}
  475. * @private
  476. */
  477. TooltipDirective.prototype._positionService;
  478. }
  479. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://ngx-bootstrap/tooltip/","sources":["tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable: max-file-line-count deprecation */\nimport {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\n\nimport { TooltipContainerComponent } from './tooltip-container.component';\nimport { TooltipConfig } from './tooltip.config';\n\nimport { ComponentLoader, ComponentLoaderFactory } from 'ngx-bootstrap/component-loader';\nimport { OnChange, warnOnce, parseTriggers, Trigger } from 'ngx-bootstrap/utils';\nimport { PositioningService } from 'ngx-bootstrap/positioning';\n\nimport { timer } from 'rxjs';\n\nlet id = 0;\n\n@Directive({\n  selector: '[tooltip], [tooltipHtml]',\n  exportAs: 'bs-tooltip'\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n  tooltipId = id++;\n  /** sets disable adaptive position */\n  @Input() adaptivePosition: boolean;\n  /**\n   * Content to be displayed as tooltip.\n   */\n  @OnChange()\n  @Input()\n  /* tslint:disable-next-line:no-any */\n  tooltip: string | TemplateRef<any>;\n  /** Fired when tooltip content changes */\n  @Output()\n  /* tslint:disable-next-line:no-any */\n  tooltipChange: EventEmitter<string | TemplateRef<any>> = new EventEmitter();\n\n  /**\n   * Placement of a tooltip. Accepts: \"top\", \"bottom\", \"left\", \"right\"\n   */\n  @Input() placement: string;\n  /**\n   * Specifies events that should trigger. Supports a space separated list of\n   * event names.\n   */\n  @Input() triggers: string;\n  /**\n   * A selector specifying the element the tooltip should be appended to.\n   */\n  @Input() container: string;\n  /**\n   * Css class for tooltip container\n   */\n  @Input() containerClass = '';\n  /**\n   * Returns whether or not the tooltip is currently being shown\n   */\n  @Input()\n  get isOpen(): boolean {\n    return this._tooltip.isShown;\n  }\n\n  set isOpen(value: boolean) {\n    if (value) {\n      this.show();\n    } else {\n      this.hide();\n    }\n  }\n\n  /**\n   * Allows to disable tooltip\n   */\n  @Input() isDisabled: boolean;\n\n  /**\n   * Delay before showing the tooltip\n   */\n  @Input() delay: number;\n\n  /**\n   * Emits an event when the tooltip is shown\n   */\n  /* tslint:disable-next-line:no-any */\n  @Output() onShown: EventEmitter<any>;\n  /**\n   * Emits an event when the tooltip is hidden\n   */\n  /* tslint:disable-next-line:no-any */\n  @Output() onHidden: EventEmitter<any>;\n\n  /** @deprecated - please use `tooltip` instead */\n  @Input('tooltipHtml')\n  /* tslint:disable-next-line:no-any */\n  set htmlContent(value: string | TemplateRef<any>) {\n    warnOnce('tooltipHtml was deprecated, please use `tooltip` instead');\n    this.tooltip = value;\n  }\n\n  /** @deprecated - please use `placement` instead */\n  @Input('tooltipPlacement')\n  set _placement(value: string) {\n    warnOnce('tooltipPlacement was deprecated, please use `placement` instead');\n    this.placement = value;\n  }\n\n  /** @deprecated - please use `isOpen` instead */\n  @Input('tooltipIsOpen')\n  set _isOpen(value: boolean) {\n    warnOnce('tooltipIsOpen was deprecated, please use `isOpen` instead');\n    this.isOpen = value;\n  }\n\n  get _isOpen(): boolean {\n    warnOnce('tooltipIsOpen was deprecated, please use `isOpen` instead');\n\n    return this.isOpen;\n  }\n\n  /** @deprecated - please use `isDisabled` instead */\n  @Input('tooltipEnable')\n  set _enable(value: boolean) {\n    warnOnce('tooltipEnable was deprecated, please use `isDisabled` instead');\n    this.isDisabled = !value;\n  }\n\n  get _enable(): boolean {\n    warnOnce('tooltipEnable was deprecated, please use `isDisabled` instead');\n\n    return this.isDisabled;\n  }\n\n  /** @deprecated - please use `container=\"body\"` instead */\n  @Input('tooltipAppendToBody')\n  set _appendToBody(value: boolean) {\n    warnOnce(\n      'tooltipAppendToBody was deprecated, please use `container=\"body\"` instead'\n    );\n    this.container = value ? 'body' : this.container;\n  }\n\n  get _appendToBody(): boolean {\n    warnOnce(\n      'tooltipAppendToBody was deprecated, please use `container=\"body\"` instead'\n    );\n\n    return this.container === 'body';\n  }\n\n  /** @deprecated - removed, will be added to configuration */\n  @Input() tooltipAnimation = true;\n\n  /** @deprecated - will replaced with customClass */\n  @Input('tooltipClass')\n  set _popupClass(value: string) {\n    warnOnce('tooltipClass deprecated');\n  }\n\n  /** @deprecated - removed */\n  @Input('tooltipContext')\n  /* tslint:disable-next-line:no-any */\n  set _tooltipContext(value: any) {\n    warnOnce('tooltipContext deprecated');\n  }\n\n  /** @deprecated */\n  @Input('tooltipPopupDelay')\n  set _tooltipPopupDelay(value: number) {\n    warnOnce('tooltipPopupDelay is deprecated, use `delay` instead');\n    this.delay = value;\n  }\n\n  /** @deprecated */\n  @Input() tooltipFadeDuration = 150;\n\n  /** @deprecated -  please use `triggers` instead */\n  @Input('tooltipTrigger')\n  get _tooltipTrigger(): string | string[] {\n    warnOnce('tooltipTrigger was deprecated, please use `triggers` instead');\n\n    return this.triggers;\n  }\n\n  set _tooltipTrigger(value: string | string[]) {\n    warnOnce('tooltipTrigger was deprecated, please use `triggers` instead');\n    this.triggers = (value || '').toString();\n  }\n\n  @HostBinding('attr.aria-describedby') ariaDescribedby = `tooltip-${this.tooltipId}`;\n\n  /** @deprecated */\n  @Output()\n  tooltipStateChanged: EventEmitter<boolean> = new EventEmitter<boolean>();\n  /* tslint:disable-next-line:no-any */\n  protected _delayTimeoutId: number | any;\n  protected _tooltipCancelShowFn: Function;\n\n  private _tooltip: ComponentLoader<TooltipContainerComponent>;\n  constructor(\n    _viewContainerRef: ViewContainerRef,\n    cis: ComponentLoaderFactory,\n    config: TooltipConfig,\n    private _elementRef: ElementRef,\n    private _renderer: Renderer2,\n    private _positionService: PositioningService\n  ) {\n\n    this._tooltip = cis\n      .createLoader<TooltipContainerComponent>(\n        this._elementRef,\n        _viewContainerRef,\n        this._renderer\n      )\n      .provide({provide: TooltipConfig, useValue: config});\n\n    Object.assign(this, config);\n    this.onShown = this._tooltip.onShown;\n    this.onHidden = this._tooltip.onHidden;\n  }\n\n  ngOnInit(): void {\n    this._tooltip.listen({\n      triggers: this.triggers,\n      show: () => this.show()\n    });\n    /* tslint:disable-next-line:no-any */\n    this.tooltipChange.subscribe((value: any) => {\n      if (!value) {\n        this._tooltip.hide();\n      }\n    });\n  }\n\n  /**\n   * Toggles an element’s tooltip. This is considered a “manual” triggering of\n   * the tooltip.\n   */\n  toggle(): void {\n    if (this.isOpen) {\n      return this.hide();\n    }\n\n    this.show();\n  }\n\n  /**\n   * Opens an element’s tooltip. This is considered a “manual” triggering of\n   * the tooltip.\n   */\n  show(): void {\n    this._positionService.setOptions({\n      modifiers: {\n        flip: {\n          enabled: this.adaptivePosition\n        },\n        preventOverflow: {\n          enabled: this.adaptivePosition\n        }\n      }\n    });\n\n    if (\n      this.isOpen ||\n      this.isDisabled ||\n      this._delayTimeoutId ||\n      !this.tooltip\n    ) {\n      return;\n    }\n\n    const showTooltip = () => {\n      if (this._delayTimeoutId) {\n        this._delayTimeoutId = undefined;\n      }\n\n      this._tooltip\n        .attach(TooltipContainerComponent)\n        .to(this.container)\n        .position({attachment: this.placement})\n        .show({\n          content: this.tooltip,\n          placement: this.placement,\n          containerClass: this.containerClass,\n          id: this.ariaDescribedby\n        });\n    };\n    const cancelDelayedTooltipShowing = () => {\n      if (this._tooltipCancelShowFn) {\n        this._tooltipCancelShowFn();\n      }\n    };\n\n    if (this.delay) {\n      const _timer = timer(this.delay).subscribe(() => {\n        showTooltip();\n        cancelDelayedTooltipShowing();\n      });\n\n      if (this.triggers) {\n        parseTriggers(this.triggers)\n          .forEach((trigger: Trigger) => {\n            this._tooltipCancelShowFn = this._renderer.listen(\n              this._elementRef.nativeElement,\n              trigger.close,\n              () => {\n                _timer.unsubscribe();\n                cancelDelayedTooltipShowing();\n              }\n            );\n          });\n      }\n    } else {\n      showTooltip();\n    }\n  }\n\n  /**\n   * Closes an element’s tooltip. This is considered a “manual” triggering of\n   * the tooltip.\n   */\n  hide(): void {\n    if (this._delayTimeoutId) {\n      clearTimeout(this._delayTimeoutId);\n      this._delayTimeoutId = undefined;\n    }\n\n    if (!this._tooltip.isShown) {\n      return;\n    }\n\n    this._tooltip.instance.classMap.in = false;\n    setTimeout(() => {\n      this._tooltip.hide();\n    }, this.tooltipFadeDuration);\n  }\n\n  ngOnDestroy(): void {\n    this._tooltip.dispose();\n  }\n}\n"]}