@flywheel-io/vision 2.6.2 → 2.7.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,92 +1,39 @@
1
- /* eslint-disable @rx-angular/prefer-no-layout-sensitive-apis */
2
- import { animate, style, transition, trigger } from '@angular/animations';
3
- import { ChangeDetectorRef, Component, computed, HostBinding, inject, Input, input } from '@angular/core';
1
+ import { Component, HostBinding, Input, input } from '@angular/core';
4
2
  import * as i0 from "@angular/core";
5
3
  import * as i1 from "@angular/common";
6
- import * as i2 from "@angular/cdk/overlay";
7
- import * as i3 from "./tooltip-panel/tooltip-panel.component";
8
- const delayMap = {
9
- 'none': 0,
10
- 'short': 400,
11
- 'long': 700,
12
- };
4
+ import * as i2 from "./tooltip.directive";
13
5
  /**
14
6
  * component for giving extra context when a user hovers something
15
7
  * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)
16
8
  */
17
9
  export class FwTooltipComponent {
18
10
  constructor() {
19
- this.color = 'light';
11
+ this.color = 'dark';
20
12
  this.position = 'above';
21
13
  this.maxWidth = 200;
22
14
  this.fullWidth = false;
15
+ // TODO v3: remove, we shouldn't need to give direct control over a tooltip's open state
23
16
  this.isOpen = false;
24
- this.cdRef = inject(ChangeDetectorRef);
25
17
  this.delay = input('short');
26
- this.delayMs = computed(() => delayMap[this.delay()]);
27
- this.positionMap = {
28
- 'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
29
- 'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
30
- 'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },
31
- 'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },
32
- 'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },
33
- };
34
18
  }
35
19
  get classes() {
36
20
  return ['fw-tooltip', this.fullWidth ? 'full-width' : null].filter(Boolean).join(' ');
37
21
  }
38
22
  ;
39
- handleMouseEnter(event) {
40
- // filter out events that start from the overlay
41
- const originatedFromOverlay = event.relatedTarget?.classList.contains('cdk-overlay-pane');
42
- if (originatedFromOverlay) {
43
- return;
44
- }
45
- const delayMs = this.delayMs();
46
- if (!delayMs) {
47
- this.isOpen = true;
48
- this.openDelayTimer = null;
49
- }
50
- else {
51
- this.openDelayTimer = window.setTimeout(() => {
52
- this.isOpen = true;
53
- this.openDelayTimer = null;
54
- this.cdRef.detectChanges();
55
- }, delayMs);
56
- }
57
- }
58
- handleMouseLeave() {
59
- if (this.openDelayTimer) {
60
- window.clearTimeout(this.openDelayTimer);
61
- }
62
- this.isOpen = false;
23
+ /**
24
+ * stops the browser built-in tooltip from showing up
25
+ * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title
26
+ */
27
+ get attrTitle() {
28
+ return '';
63
29
  }
30
+ ;
64
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
65
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipComponent, selector: "fw-tooltip", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: false, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "maxWidth", isSignal: false, isRequired: false, transformFunction: null }, fullWidth: { classPropertyName: "fullWidth", publicName: "fullWidth", isSignal: false, isRequired: false, transformFunction: null }, isOpen: { classPropertyName: "isOpen", publicName: "isOpen", isSignal: false, isRequired: false, transformFunction: null }, trigger: { classPropertyName: "trigger", publicName: "trigger", isSignal: false, isRequired: false, transformFunction: null }, delay: { classPropertyName: "delay", publicName: "delay", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.class": "this.classes", "attr.title": "this['']" } }, ngImport: i0, template: "<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"isOpen\"\n [cdkConnectedOverlayPositions]=\"[positionMap[position]]\">\n <fw-tooltip-panel\n @fadeInFadeOut\n *ngIf=\"title\"\n [position]=\"position\"\n [color]=\"color\"\n [maxWidth]=\"maxWidth\">\n <h5 class=\"vision-h5\">{{ title }}</h5>\n </fw-tooltip-panel>\n</ng-template>\n<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\"\n (mouseenter)=\"handleMouseEnter($event)\" (mouseleave)=\"handleMouseLeave()\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: i3.FwTooltipPanelComponent, selector: "fw-tooltip-panel", inputs: ["position", "color", "maxWidth"], outputs: ["mouseLeave"] }], animations: [
66
- trigger('fadeInFadeOut', [
67
- transition(':enter', [
68
- style({ opacity: 0 }),
69
- animate('150ms', style({ opacity: 1 })),
70
- ]),
71
- transition(':leave', [
72
- animate('200ms', style({ opacity: 0 })),
73
- ]),
74
- ]),
75
- ] }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipComponent, selector: "fw-tooltip", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: false, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "maxWidth", isSignal: false, isRequired: false, transformFunction: null }, fullWidth: { classPropertyName: "fullWidth", publicName: "fullWidth", isSignal: false, isRequired: false, transformFunction: null }, isOpen: { classPropertyName: "isOpen", publicName: "isOpen", isSignal: false, isRequired: false, transformFunction: null }, trigger: { classPropertyName: "trigger", publicName: "trigger", isSignal: false, isRequired: false, transformFunction: null }, delay: { classPropertyName: "delay", publicName: "delay", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.class": "this.classes", "attr.title": "this.attrTitle" } }, ngImport: i0, template: "<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n [fwTooltip]=\"title\"\n [fwTooltipDelay]=\"delay()\"\n [fwTooltipPosition]=\"position\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.FwTooltipDirective, selector: "[fwTooltip]", inputs: ["fwTooltipDelay", "fwTooltip", "fwTooltipPosition", "fwTooltipMaxWidthPx", "fwTooltipEnabled"], outputs: ["fwTooltipChange", "fwTooltipPositionChange", "fwTooltipMaxWidthPxChange", "fwTooltipEnabledChange"] }] }); }
76
33
  }
77
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipComponent, decorators: [{
78
35
  type: Component,
79
- args: [{ selector: 'fw-tooltip', animations: [
80
- trigger('fadeInFadeOut', [
81
- transition(':enter', [
82
- style({ opacity: 0 }),
83
- animate('150ms', style({ opacity: 1 })),
84
- ]),
85
- transition(':leave', [
86
- animate('200ms', style({ opacity: 0 })),
87
- ]),
88
- ]),
89
- ], template: "<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"isOpen\"\n [cdkConnectedOverlayPositions]=\"[positionMap[position]]\">\n <fw-tooltip-panel\n @fadeInFadeOut\n *ngIf=\"title\"\n [position]=\"position\"\n [color]=\"color\"\n [maxWidth]=\"maxWidth\">\n <h5 class=\"vision-h5\">{{ title }}</h5>\n </fw-tooltip-panel>\n</ng-template>\n<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\"\n (mouseenter)=\"handleMouseEnter($event)\" (mouseleave)=\"handleMouseLeave()\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"] }]
36
+ args: [{ selector: 'fw-tooltip', template: "<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n [fwTooltip]=\"title\"\n [fwTooltipDelay]=\"delay()\"\n [fwTooltipPosition]=\"position\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"] }]
90
37
  }], propDecorators: { title: [{
91
38
  type: Input
92
39
  }], color: [{
@@ -104,8 +51,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
104
51
  }], classes: [{
105
52
  type: HostBinding,
106
53
  args: ['attr.class']
107
- }], '': [{
54
+ }], attrTitle: [{
108
55
  type: HostBinding,
109
56
  args: ['attr.title']
110
57
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.component.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/tooltip.component.ts","../../../../../src/components/tooltip/tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @rx-angular/prefer-no-layout-sensitive-apis */\nimport { animate, style, transition, trigger } from '@angular/animations';\nimport { CdkOverlayOrigin, ConnectedPosition, FlexibleConnectedPositionStrategyOrigin } from '@angular/cdk/overlay';\nimport { ChangeDetectorRef, Component, computed, HostBinding, inject, Input, input } from '@angular/core';\n\ntype DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\n\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\n/**\n * component for giving extra context when a user hovers something\n * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)\n */\n@Component({\n  selector: 'fw-tooltip',\n  templateUrl: './tooltip.component.html',\n  styleUrls: ['./tooltip.component.scss'],\n  animations: [\n    trigger('fadeInFadeOut', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        animate('150ms', style({ opacity: 1 })),\n      ]),\n      transition(':leave', [\n        animate('200ms', style({ opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class FwTooltipComponent {\n  @Input() title: string;\n  @Input() color: 'light' | 'dark' = 'light';\n  @Input() position: 'above' | 'below' | 'left' | 'right' | 'none' = 'above';\n  @Input() maxWidth?: number = 200;\n  @Input() fullWidth?: boolean = false;\n  @Input() isOpen: boolean = false;\n  @Input() trigger: CdkOverlayOrigin | FlexibleConnectedPositionStrategyOrigin;\n\n  private cdRef = inject(ChangeDetectorRef);\n\n  delay = input<DelayLength>('short');\n  delayMs = computed(() => delayMap[this.delay()]);\n\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-tooltip', this.fullWidth ? 'full-width' : null].filter(Boolean).join(' ');\n  };\n\n\n  /**\n   * stops the browser built-in tooltip from showing up\n   * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title\n  */\n  @HostBinding('attr.title') '';\n\n  positionMap: { [key: string]: ConnectedPosition } = {\n    'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n    'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n    'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n    'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n    'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n  };\n\n  private openDelayTimer: number;\n\n  handleMouseEnter(event: MouseEvent): void {\n\n    // filter out events that start from the overlay\n    const originatedFromOverlay = (event.relatedTarget as HTMLElement)?.classList.contains('cdk-overlay-pane')\n    if (originatedFromOverlay) {\n      return;\n    }\n\n    const delayMs = this.delayMs();\n\n    if (!delayMs) {\n      this.isOpen = true;\n      this.openDelayTimer = null;\n    } else {\n      this.openDelayTimer = window.setTimeout(() => {\n        this.isOpen = true;\n        this.openDelayTimer = null;\n        this.cdRef.detectChanges()\n      }, delayMs);\n    }\n  }\n\n  handleMouseLeave(): void {\n    if (this.openDelayTimer) {\n      window.clearTimeout(this.openDelayTimer);\n    }\n    this.isOpen = false;\n  }\n}\n","<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"trigger\"\n  [cdkConnectedOverlayOpen]=\"isOpen\"\n  [cdkConnectedOverlayPositions]=\"[positionMap[position]]\">\n  <fw-tooltip-panel\n    @fadeInFadeOut\n    *ngIf=\"title\"\n    [position]=\"position\"\n    [color]=\"color\"\n    [maxWidth]=\"maxWidth\">\n    <h5 class=\"vision-h5\">{{ title }}</h5>\n  </fw-tooltip-panel>\n</ng-template>\n<div\n  [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n  cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\"\n  (mouseenter)=\"handleMouseEnter($event)\" (mouseleave)=\"handleMouseLeave()\">\n  <ng-content></ng-content>\n</div>\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBQyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFNcEU7OztHQUdHO0FBTUgsTUFBTSxPQUFPLGtCQUFrQjtJQUwvQjtRQU9XLFVBQUssR0FBcUIsTUFBTSxDQUFDO1FBQ2pDLGFBQVEsR0FBbUIsT0FBTyxDQUFDO1FBQ25DLGFBQVEsR0FBWSxHQUFHLENBQUM7UUFDeEIsY0FBUyxHQUFhLEtBQUssQ0FBQztRQUNyQyx3RkFBd0Y7UUFDL0UsV0FBTSxHQUFZLEtBQUssQ0FBQztRQUlqQyxVQUFLLEdBQUcsS0FBSyxDQUFjLE9BQU8sQ0FBQyxDQUFDO0tBY3JDO0lBWkMsSUFBK0IsT0FBTztRQUNwQyxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN4RixDQUFDO0lBQUEsQ0FBQztJQUVGOzs7TUFHRTtJQUNGLElBQStCLFNBQVM7UUFDdEMsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBQUEsQ0FBQzsrR0F2QlMsa0JBQWtCO21HQUFsQixrQkFBa0Isb29DQ2pCL0IsME1BT0E7OzRGRFVhLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZOzhCQUtiLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsTUFBTTtzQkFBZCxLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFJeUIsT0FBTztzQkFBckMsV0FBVzt1QkFBQyxZQUFZO2dCQVFNLFNBQVM7c0JBQXZDLFdBQVc7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEByeC1hbmd1bGFyL3ByZWZlci1uby1sYXlvdXQtc2Vuc2l0aXZlLWFwaXMgKi9cbmltcG9ydCB7IENka092ZXJsYXlPcmlnaW4sIEZsZXhpYmxlQ29ubmVjdGVkUG9zaXRpb25TdHJhdGVneU9yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNpbXBsZVBvc2l0aW9uIH0gZnJvbSAnLi90b29sdGlwLXBhbmVsL3Rvb2x0aXAtcGFuZWwuY29tcG9uZW50JztcblxudHlwZSBEZWxheUxlbmd0aCA9ICdub25lJyB8ICdzaG9ydCcgfCAnbG9uZyc7XG5cbi8qKlxuICogY29tcG9uZW50IGZvciBnaXZpbmcgZXh0cmEgY29udGV4dCB3aGVuIGEgdXNlciBob3ZlcnMgc29tZXRoaW5nXG4gKiBAc2VlIFtWaXNpb24gRG9jc10oaHR0cHM6Ly9jZG4uZmx5d2hlZWwuaW8vZG9jcy92aXNpb24vbWFzdGVyLz9wYXRoPS9kb2NzL2NvbXBvbmVudHMtdG9vbHRpcC0tZG9jcylcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnctdG9vbHRpcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90b29sdGlwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9vbHRpcC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGd1Rvb2x0aXBDb21wb25lbnQge1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xuICBASW5wdXQoKSBjb2xvcjogJ2xpZ2h0JyB8ICdkYXJrJyA9ICdkYXJrJztcbiAgQElucHV0KCkgcG9zaXRpb246IFNpbXBsZVBvc2l0aW9uID0gJ2Fib3ZlJztcbiAgQElucHV0KCkgbWF4V2lkdGg/OiBudW1iZXIgPSAyMDA7XG4gIEBJbnB1dCgpIGZ1bGxXaWR0aD86IGJvb2xlYW4gPSBmYWxzZTtcbiAgLy8gVE9ETyB2MzogcmVtb3ZlLCB3ZSBzaG91bGRuJ3QgbmVlZCB0byBnaXZlIGRpcmVjdCBjb250cm9sIG92ZXIgYSB0b29sdGlwJ3Mgb3BlbiBzdGF0ZVxuICBASW5wdXQoKSBpc09wZW46IGJvb2xlYW4gPSBmYWxzZTtcbiAgLy8gVE9ETyB2MzogdGhpcyBpcyBhIG5vLW9wIGlucHV0LCB3ZSBzaG91bGQgcmVtb3ZlXG4gIEBJbnB1dCgpIHRyaWdnZXI6IENka092ZXJsYXlPcmlnaW4gfCBGbGV4aWJsZUNvbm5lY3RlZFBvc2l0aW9uU3RyYXRlZ3lPcmlnaW47XG5cbiAgZGVsYXkgPSBpbnB1dDxEZWxheUxlbmd0aD4oJ3Nob3J0Jyk7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmNsYXNzJykgZ2V0IGNsYXNzZXMoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gWydmdy10b29sdGlwJywgdGhpcy5mdWxsV2lkdGggPyAnZnVsbC13aWR0aCcgOiBudWxsXS5maWx0ZXIoQm9vbGVhbikuam9pbignICcpO1xuICB9O1xuXG4gIC8qKlxuICAgKiBzdG9wcyB0aGUgYnJvd3NlciBidWlsdC1pbiB0b29sdGlwIGZyb20gc2hvd2luZyB1cFxuICAgKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0hUTUwvUmVmZXJlbmNlL0dsb2JhbF9hdHRyaWJ1dGVzL3RpdGxlXG4gICovXG4gIEBIb3N0QmluZGluZygnYXR0ci50aXRsZScpIGdldCBhdHRyVGl0bGUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJyc7XG4gIH07XG5cbn1cbiIsIjxkaXZcbiAgW25nQ2xhc3NdPVwiWyd0b29sdGlwLXRyaWdnZXInLGZ1bGxXaWR0aD8nZnVsbC13aWR0aCc6JyddXCJcbiAgW2Z3VG9vbHRpcF09XCJ0aXRsZVwiXG4gIFtmd1Rvb2x0aXBEZWxheV09XCJkZWxheSgpXCJcbiAgW2Z3VG9vbHRpcFBvc2l0aW9uXT1cInBvc2l0aW9uXCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
@@ -0,0 +1,114 @@
1
+ import { Overlay } from '@angular/cdk/overlay';
2
+ import { ComponentPortal } from '@angular/cdk/portal';
3
+ import { computed, Directive, effect, ElementRef, inject, input, model, signal, ViewContainerRef } from '@angular/core';
4
+ import { FwTooltipPanelComponent } from './tooltip-panel/tooltip-panel.component';
5
+ import * as i0 from "@angular/core";
6
+ const positionMap = {
7
+ 'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
8
+ 'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
9
+ 'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },
10
+ 'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },
11
+ 'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },
12
+ };
13
+ const delayMap = {
14
+ 'none': 0,
15
+ 'short': 400,
16
+ 'long': 700,
17
+ };
18
+ const delayNameToMs = (name) => {
19
+ return delayMap[name];
20
+ };
21
+ export class FwTooltipDirective {
22
+ constructor() {
23
+ // External Context
24
+ this.elementRef = inject(ElementRef);
25
+ this.viewContainerRef = inject(ViewContainerRef);
26
+ this.overlayService = inject(Overlay);
27
+ // Internal refs
28
+ this.overlayRef = signal(undefined);
29
+ this.tooltipRef = signal(undefined);
30
+ // Inputs
31
+ this.delayMs = input(400, {
32
+ transform: delayNameToMs,
33
+ alias: 'fwTooltipDelay',
34
+ });
35
+ // a lot of these ideally wouldn't be models,
36
+ // but it makes it easier to interact with this from derivative directives
37
+ this.title = model('undefined', {
38
+ alias: 'fwTooltip',
39
+ });
40
+ this.position = model('above', {
41
+ alias: 'fwTooltipPosition',
42
+ });
43
+ this.maxWidth = model(200, {
44
+ alias: 'fwTooltipMaxWidthPx',
45
+ });
46
+ this.enabled = model(true, {
47
+ alias: 'fwTooltipEnabled'
48
+ });
49
+ // derived state
50
+ this.connectedPosition = computed(() => [positionMap[this.position()]]);
51
+ this.positionStrategy = computed(() => {
52
+ const positionBuilder = this.overlayService.position();
53
+ const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);
54
+ const completedStrategy = withOrigin.withPositions(this.connectedPosition());
55
+ return completedStrategy;
56
+ });
57
+ this.overlayConfig = computed(() => ({
58
+ positionStrategy: this.positionStrategy(),
59
+ maxWidth: this.maxWidth(),
60
+ ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),
61
+ disposeOnNavigation: true,
62
+ }));
63
+ // effects and methods
64
+ this.addMouseEventListeners = effect(() => {
65
+ const nativeElement = this.elementRef.nativeElement;
66
+ nativeElement.addEventListener('mouseenter', () => {
67
+ this.showTooltip();
68
+ });
69
+ nativeElement.addEventListener('mouseleave', () => {
70
+ this.hideTooltip();
71
+ });
72
+ });
73
+ }
74
+ ngOnInit() {
75
+ this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);
76
+ this.overlayRef.set(this.overlayService.create());
77
+ }
78
+ showTooltip() {
79
+ if (!this.enabled()) {
80
+ return;
81
+ }
82
+ const overlayRef = this.overlayRef();
83
+ overlayRef.updatePositionStrategy(this.positionStrategy());
84
+ if (this.openDelayTimer) {
85
+ return;
86
+ }
87
+ this.openDelayTimer = window.setTimeout(() => {
88
+ const tooltipRef = overlayRef.attach(this.tooltipPortal);
89
+ this.tooltipRef.set(tooltipRef);
90
+ tooltipRef.setInput('title', this.title());
91
+ tooltipRef.setInput('position', this.position());
92
+ tooltipRef.changeDetectorRef.detectChanges();
93
+ }, this.delayMs());
94
+ }
95
+ hideTooltip() {
96
+ const animationDelayMs = 200;
97
+ this.closeDelayTimer = window.setTimeout(() => {
98
+ window.clearTimeout(this.openDelayTimer);
99
+ this.openDelayTimer = undefined;
100
+ this.overlayRef().detach();
101
+ this.tooltipRef.set(undefined);
102
+ }, animationDelayMs);
103
+ }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
105
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipDirective, isStandalone: true, selector: "[fwTooltip]", inputs: { delayMs: { classPropertyName: "delayMs", publicName: "fwTooltipDelay", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "fwTooltip", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "fwTooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "fwTooltipMaxWidthPx", isSignal: true, isRequired: false, transformFunction: null }, enabled: { classPropertyName: "enabled", publicName: "fwTooltipEnabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { title: "fwTooltipChange", position: "fwTooltipPositionChange", maxWidth: "fwTooltipMaxWidthPxChange", enabled: "fwTooltipEnabledChange" }, ngImport: i0 }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, decorators: [{
108
+ type: Directive,
109
+ args: [{
110
+ selector: '[fwTooltip]',
111
+ standalone: true,
112
+ }]
113
+ }] });
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, computed, Directive, effect, ElementRef, inject, input, model, OnInit, signal, ViewContainerRef } from '@angular/core';\n\nimport { FwTooltipPanelComponent, SimplePosition } from './tooltip-panel/tooltip-panel.component';\n\ntype DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\n\nconst positionMap: { [key: string]: ConnectedPosition } = {\n  'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n  'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n  'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n};\n\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\nconst delayNameToMs = (name: DelayLength): number => {\n  return delayMap[name];\n}\n\n@Directive({\n  selector: '[fwTooltip]',\n  standalone: true,\n})\nexport class FwTooltipDirective implements OnInit {\n\n  // External Context\n  private elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private overlayService = inject(Overlay);\n\n  // Internal refs\n  private overlayRef = signal<OverlayRef>(undefined);\n  private tooltipRef = signal<ComponentRef<FwTooltipPanelComponent>>(undefined);\n  private tooltipPortal: ComponentPortal<FwTooltipPanelComponent>;\n\n  // Inputs\n  delayMs = input(400, {\n    transform: delayNameToMs,\n    alias: 'fwTooltipDelay',\n  });\n\n  // a lot of these ideally wouldn't be models,\n  // but it makes it easier to interact with this from derivative directives\n\n  title = model<string>('undefined', {\n    alias: 'fwTooltip',\n  })\n\n  position = model<SimplePosition>('above', {\n    alias: 'fwTooltipPosition',\n  });\n\n  maxWidth = model<number>(200, {\n    alias: 'fwTooltipMaxWidthPx',\n  })\n\n  enabled = model(true, {\n    alias: 'fwTooltipEnabled'\n  });\n\n  // derived state\n  connectedPosition = computed(() => [positionMap[this.position()]]);\n\n  positionStrategy = computed(() => {\n    const positionBuilder = this.overlayService.position();\n    const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);\n    const completedStrategy = withOrigin.withPositions(this.connectedPosition());\n    return completedStrategy;\n  });\n\n  overlayConfig = computed<OverlayConfig>(() => ({\n    positionStrategy: this.positionStrategy(),\n    maxWidth: this.maxWidth(),\n    ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),\n    disposeOnNavigation: true,\n  }));\n\n  // effects and methods\n  addMouseEventListeners = effect(() => {\n\n    const nativeElement = this.elementRef.nativeElement;\n\n    nativeElement.addEventListener('mouseenter', () => {\n      this.showTooltip();\n    });\n\n    nativeElement.addEventListener('mouseleave', () => {\n      this.hideTooltip();\n    });\n  })\n\n  ngOnInit(): void {\n    this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);\n\n    this.overlayRef.set(this.overlayService.create());\n  }\n\n\n  private openDelayTimer: number;\n  private closeDelayTimer: number;\n\n  showTooltip(): void {\n\n    if(!this.enabled()) {\n      return;\n    }\n\n    const overlayRef = this.overlayRef();\n    overlayRef.updatePositionStrategy(this.positionStrategy());\n\n    if (this.openDelayTimer) {\n      return;\n    }\n\n    this.openDelayTimer = window.setTimeout(() => {\n      const tooltipRef = overlayRef.attach(this.tooltipPortal);\n      this.tooltipRef.set(tooltipRef);\n\n      tooltipRef.setInput('title', this.title());\n      tooltipRef.setInput('position', this.position());\n      tooltipRef.changeDetectorRef.detectChanges();\n    }, this.delayMs());\n  }\n\n  hideTooltip(): void {\n\n    const animationDelayMs = 200;\n\n\n    this.closeDelayTimer = window.setTimeout(() => {\n      window.clearTimeout(this.openDelayTimer);\n      this.openDelayTimer = undefined;\n      this.overlayRef().detach();\n      this.tooltipRef.set(undefined);\n    }, animationDelayMs);\n  }\n\n}\n"]}
@@ -1,8 +1,10 @@
1
1
  import { Overlay, OverlayModule } from '@angular/cdk/overlay';
2
+ import { CdkNoDataRow } from '@angular/cdk/table';
2
3
  import { CommonModule } from '@angular/common';
3
4
  import { NgModule } from '@angular/core';
4
5
  import { FwPopoverModule } from '../popover/popover.module';
5
6
  import { FwTooltipComponent } from './tooltip.component';
7
+ import { FwTooltipDirective } from './tooltip.directive';
6
8
  import { FwTooltipPanelComponent } from './tooltip-panel/tooltip-panel.component';
7
9
  import * as i0 from "@angular/core";
8
10
  export class FwTooltipModule {
@@ -10,8 +12,11 @@ export class FwTooltipModule {
10
12
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipModule, declarations: [FwTooltipComponent,
11
13
  FwTooltipPanelComponent], imports: [CommonModule,
12
14
  FwPopoverModule,
13
- OverlayModule], exports: [FwTooltipComponent,
14
- FwTooltipPanelComponent] }); }
15
+ OverlayModule,
16
+ CdkNoDataRow,
17
+ FwTooltipDirective], exports: [FwTooltipComponent,
18
+ FwTooltipPanelComponent,
19
+ FwTooltipDirective] }); }
15
20
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipModule, providers: [
16
21
  Overlay,
17
22
  ], imports: [CommonModule,
@@ -25,10 +30,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
25
30
  CommonModule,
26
31
  FwPopoverModule,
27
32
  OverlayModule,
33
+ CdkNoDataRow,
34
+ FwTooltipDirective,
28
35
  ],
29
36
  exports: [
30
37
  FwTooltipComponent,
31
38
  FwTooltipPanelComponent,
39
+ FwTooltipDirective,
32
40
  ],
33
41
  declarations: [
34
42
  FwTooltipComponent,
@@ -39,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
39
47
  ],
40
48
  }]
41
49
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDOztBQW9CbEYsTUFBTSxPQUFPLGVBQWU7K0dBQWYsZUFBZTtnSEFBZixlQUFlLGlCQVB4QixrQkFBa0I7WUFDbEIsdUJBQXVCLGFBVnZCLFlBQVk7WUFDWixlQUFlO1lBQ2YsYUFBYSxhQUdiLGtCQUFrQjtZQUNsQix1QkFBdUI7Z0hBVWQsZUFBZSxhQUpmO1lBQ1QsT0FBTztTQUNSLFlBZEMsWUFBWTtZQUNaLGVBQWU7WUFDZixhQUFhOzs0RkFjSixlQUFlO2tCQWxCM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7cUJBQ2Q7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsdUJBQXVCO3FCQUN4QjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osa0JBQWtCO3dCQUNsQix1QkFBdUI7cUJBQ3hCO29CQUNELFNBQVMsRUFBRTt3QkFDVCxPQUFPO3FCQUNSO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSwgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBGd1BvcG92ZXJNb2R1bGUgfSBmcm9tICcuLi9wb3BvdmVyL3BvcG92ZXIubW9kdWxlJztcbmltcG9ydCB7IEZ3VG9vbHRpcENvbXBvbmVudCB9IGZyb20gJy4vdG9vbHRpcC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRndUb29sdGlwUGFuZWxDb21wb25lbnQgfSBmcm9tICcuL3Rvb2x0aXAtcGFuZWwvdG9vbHRpcC1wYW5lbC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZ3UG9wb3Zlck1vZHVsZSxcbiAgICBPdmVybGF5TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRndUb29sdGlwQ29tcG9uZW50LFxuICAgIEZ3VG9vbHRpcFBhbmVsQ29tcG9uZW50LFxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBGd1Rvb2x0aXBDb21wb25lbnQsXG4gICAgRndUb29sdGlwUGFuZWxDb21wb25lbnQsXG4gIF0sXG4gIHByb3ZpZGVyczogW1xuICAgIE92ZXJsYXksXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZ3VG9vbHRpcE1vZHVsZSB7XG59XG4iXX0=
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQzs7QUF1QmxGLE1BQU0sT0FBTyxlQUFlOytHQUFmLGVBQWU7Z0hBQWYsZUFBZSxpQkFQeEIsa0JBQWtCO1lBQ2xCLHVCQUF1QixhQWJ2QixZQUFZO1lBQ1osZUFBZTtZQUNmLGFBQWE7WUFDYixZQUFZO1lBQ1osa0JBQWtCLGFBR2xCLGtCQUFrQjtZQUNsQix1QkFBdUI7WUFDdkIsa0JBQWtCO2dIQVVULGVBQWUsYUFKZjtZQUNULE9BQU87U0FDUixZQWpCQyxZQUFZO1lBQ1osZUFBZTtZQUNmLGFBQWE7OzRGQWlCSixlQUFlO2tCQXJCM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsWUFBWTt3QkFDWixrQkFBa0I7cUJBQ3JCO29CQUNDLE9BQU8sRUFBRTt3QkFDUCxrQkFBa0I7d0JBQ2xCLHVCQUF1Qjt3QkFDdkIsa0JBQWtCO3FCQUNuQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osa0JBQWtCO3dCQUNsQix1QkFBdUI7cUJBQ3hCO29CQUNELFNBQVMsRUFBRTt3QkFDVCxPQUFPO3FCQUNSO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSwgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENka05vRGF0YVJvdyB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90YWJsZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRndQb3BvdmVyTW9kdWxlIH0gZnJvbSAnLi4vcG9wb3Zlci9wb3BvdmVyLm1vZHVsZSc7XG5pbXBvcnQgeyBGd1Rvb2x0aXBDb21wb25lbnQgfSBmcm9tICcuL3Rvb2x0aXAuY29tcG9uZW50JztcbmltcG9ydCB7IEZ3VG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vdG9vbHRpcC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRndUb29sdGlwUGFuZWxDb21wb25lbnQgfSBmcm9tICcuL3Rvb2x0aXAtcGFuZWwvdG9vbHRpcC1wYW5lbC5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZ3UG9wb3Zlck1vZHVsZSxcbiAgICBPdmVybGF5TW9kdWxlLFxuICAgIENka05vRGF0YVJvdyxcbiAgICBGd1Rvb2x0aXBEaXJlY3RpdmUsXG5dLFxuICBleHBvcnRzOiBbXG4gICAgRndUb29sdGlwQ29tcG9uZW50LFxuICAgIEZ3VG9vbHRpcFBhbmVsQ29tcG9uZW50LFxuICAgIEZ3VG9vbHRpcERpcmVjdGl2ZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRndUb29sdGlwQ29tcG9uZW50LFxuICAgIEZ3VG9vbHRpcFBhbmVsQ29tcG9uZW50LFxuICBdLFxuICBwcm92aWRlcnM6IFtcbiAgICBPdmVybGF5LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBGd1Rvb2x0aXBNb2R1bGUge1xufVxuIl19
@@ -120,6 +120,7 @@ export * from './components/text-input/text-input.module';
120
120
  export * from './components/textarea-input/textarea-input.component';
121
121
  export * from './components/textarea-input/textarea-input.module';
122
122
  export * from './components/tooltip/tooltip.component';
123
+ export * from './components/tooltip/tooltip.directive';
123
124
  export * from './components/tooltip/tooltip.module';
124
125
  export * from './components/tooltip/tooltip-panel/tooltip-panel.component';
125
126
  export * from './components/typeahead/typeahead.component';
@@ -128,4 +129,4 @@ export * from './components/wrapped-input/wrapped-input.component';
128
129
  export * from './components/wrapped-input/wrapped-input.module';
129
130
  export * from './directives/menu-register.directive';
130
131
  export { CdkTableModule } from '@angular/cdk/table';
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../src/public-api.ts"],"names":[],"mappings":"AAAA,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,0CAA0C,CAAC;AACzD,cAAc,uCAAuC,CAAC;AACtD,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,0CAA0C,CAAC;AACzD,cAAc,sCAAsC,CAAC;AACrD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mCAAmC,CAAC;AAClD,cAAc,kDAAkD,CAAC;AACjE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,4EAA4E,CAAC;AAC3F,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,2DAA2D,CAAC;AAC1E,cAAc,qDAAqD,CAAC;AACpE,cAAc,uDAAuD,CAAC;AACtE,cAAc,qDAAqD,CAAC;AACpE,cAAc,qDAAqD,CAAC;AACpE,cAAc,0CAA0C,CAAC;AACzD,cAAc,uCAAuC,CAAC;AACtD,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,wDAAwD,CAAC;AACvE,cAAc,qDAAqD,CAAC;AACpE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,oCAAoC,CAAC;AACnD,cAAc,kDAAkD,CAAC;AACjE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,0CAA0C,CAAC;AACzD,cAAc,6CAA6C,CAAC;AAC5D,cAAc,qCAAqC,CAAC;AACpD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iDAAiD,CAAC;AAChE,cAAc,2DAA2D,CAAC;AAC1E,cAAc,qDAAqD,CAAC;AACpE,cAAc,iDAAiD,CAAC;AAChE,cAAc,6DAA6D,CAAC;AAC5E,cAAc,2DAA2D,CAAC;AAC1E,cAAc,yDAAyD,CAAC;AACxE,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,2DAA2D,CAAC;AAC1E,cAAc,uDAAuD,CAAC;AACtE,cAAc,+DAA+D,CAAC;AAC9E,cAAc,kDAAkD,CAAC;AACjE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,4CAA4C,CAAC;AAC3D,cAAc,yCAAyC,CAAC;AACxD,cAAc,wEAAwE,CAAC;AACvF,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,4DAA4D,CAAC;AAC3E,cAAc,yCAAyC,CAAC;AACxD,cAAc,uCAAuC,CAAC;AACtD,cAAc,iDAAiD,CAAC;AAChE,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,0CAA0C,CAAC;AACzD,cAAc,gEAAgE,CAAC;AAC/E,cAAc,wDAAwD,CAAC;AACvE,cAAc,qDAAqD,CAAC;AACpE,cAAc,8EAA8E,CAAC;AAC7F,cAAc,8EAA8E,CAAC;AAC7F,cAAc,wEAAwE,CAAC;AACvF,cAAc,gDAAgD,CAAC;AAC/D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,mDAAmD,CAAC;AAClE,cAAc,yCAAyC,CAAC;AACxD,cAAc,uCAAuC,CAAC;AACtD,cAAc,wCAAwC,CAAC;AACvD,cAAc,mDAAmD,CAAC;AAClE,cAAc,uEAAuE,CAAC;AACtF,cAAc,8CAA8C,CAAC;AAC7D,cAAc,qCAAqC,CAAC;AACpD,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,oCAAoC,CAAC;AACnD,cAAc,iCAAiC,CAAC;AAChD,cAAc,0CAA0C,CAAC;AACzD,cAAc,qCAAqC,CAAC;AACpD,cAAc,iDAAiD,CAAC;AAChE,cAAc,kCAAkC,CAAC;AACjD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,8CAA8C,CAAC;AAC7D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC;AAClE,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,4DAA4D,CAAC;AAC3E,cAAc,4CAA4C,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AAClF,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,sCAAsC,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC","sourcesContent":["export * from './components/alert/alert.component';\nexport * from './components/alert/alert.module';\nexport * from './components/app-icon/app-icon.component';\nexport * from './components/app-icon/app-icon.module';\nexport * from './components/avatar/avatar.component';\nexport * from './components/avatar/avatar.module';\nexport * from './components/avatar-list/avatar-list.component';\nexport * from './components/badge/badge.component';\nexport * from './components/badge/badge.module';\nexport * from './components/breadcrumbs/breadcrumbs.component';\nexport * from './components/breadcrumbs/breadcrumbs.module';\nexport * from './components/breadcrumbs/crumb.component';\nexport * from './components/button/button.component';\nexport * from './components/button/button.directives';\nexport * from './components/button/button.module';\nexport * from './components/button-group/button-group.component';\nexport * from './components/button-group/button-group.module';\nexport * from './components/button-toggle/button-toggle.component';\nexport * from './components/button-toggle/button-toggle.module';\nexport * from './components/button-toggle/button-toggle-item/button-toggle-item.component';\nexport * from './components/card/card.component';\nexport * from './components/card/card.module';\nexport * from './components/card/card-attribute/card-attribute.component';\nexport * from './components/card/card-author/card-author.component';\nexport * from './components/card/card-content/card-content.component';\nexport * from './components/card/card-footer/card-footer.component';\nexport * from './components/card/card-header/card-header.component';\nexport * from './components/checkbox/checkbox.component';\nexport * from './components/checkbox/checkbox.module';\nexport * from './components/chip/chip.component';\nexport * from './components/chip/chip.module';\nexport * from './components/contained-input/contained-input.component';\nexport * from './components/contained-input/contained-input.module';\nexport * from './components/date-input/date-input.component';\nexport * from './components/date-input/date-input.module';\nexport * from './components/dialog/dialog.component';\nexport * from './components/dialog/dialog.service';\nexport * from './components/dialog/dialog-actions.component';\nexport * from './components/dialog/dialog-confirm.component';\nexport * from './components/dialog/dialog-content.component';\nexport * from './components/dialog/dialog-header.component';\nexport * from './components/dialog/dialog-simple.component';\nexport * from './components/dialog/dialogs.module';\nexport * from './components/form-heading/form-heading.component';\nexport * from './components/form-heading/form-heading.module';\nexport * from './components/forms/validators';\nexport * from './components/icon/icon.component';\nexport * from './components/icon/icon.module';\nexport * from './components/icon/icon.types';\nexport * from './components/icon-button/icon-button.component';\nexport * from './components/icon-button/icon-button.module';\nexport * from './components/layouts/context/context.component';\nexport * from './components/layouts/grid/grid.component';\nexport * from './components/layouts/layout-group.component';\nexport * from './components/layouts/layouts.module';\nexport * from './components/layouts/panel/panel.component';\nexport * from './components/layouts/sidebar/sidebar.component';\nexport * from './components/layouts/toolbar/toolbar.component';\nexport * from './components/menu/menu.component';\nexport * from './components/menu/menu.module';\nexport * from './components/menu/menu-close-triggers.directive';\nexport * from './components/menu/menu-container/menu-container.component';\nexport * from './components/menu/menu-header/menu-header.component';\nexport * from './components/menu/menu-item/menu-item.component';\nexport * from './components/menu/menu-item-group/menu-item-group.component';\nexport * from './components/menu/menu-separator/menu-separator.component';\nexport * from './components/menu/menu-sub-item/menu-sub-item.component';\nexport * from './components/navbar/navbar.component';\nexport * from './components/navbar/navbar.module';\nexport * from './components/navbar/navbar-header/navbar-header.component';\nexport * from './components/navbar/navbar-item/navbar-item.component';\nexport * from './components/navbar/navbar-sub-item/navbar-sub-item.component';\nexport * from './components/number-input/number-input.component';\nexport * from './components/number-input/number-input.module';\nexport * from './components/paginator/paginator.component';\nexport * from './components/paginator/paginator.module';\nexport * from './components/paginator/paginator-advanced/paginator-advanced.component';\nexport * from './components/phone-input/phone-input.component';\nexport * from './components/phone-input/phone-input.module';\nexport * from './components/popover/popover.component';\nexport * from './components/popover/popover.module';\nexport * from './components/popover/popover-panel/popover-panel.component';\nexport * from './components/progress/bar/bar.component';\nexport * from './components/progress/progress.module';\nexport * from './components/progress/spinner/spinner.component';\nexport * from './components/radio/radio.component';\nexport * from './components/radio/radio.module';\nexport * from './components/radio/radio-group.component';\nexport * from './components/section-heading/back-button/back-button.component';\nexport * from './components/section-heading/section-heading.component';\nexport * from './components/section-heading/section-heading.module';\nexport * from './components/section-heading/subsection-heading/subsection-heading.component';\nexport * from './components/section-heading/subsection-heading/subsection-heading.component';\nexport * from './components/select-menu/multi-select-menu/multi-select-menu.component';\nexport * from './components/select-menu/select-menu.component';\nexport * from './components/select-menu/select-menu.module';\nexport * from './components/shared/services/menu-manager.service';\nexport * from './components/shared/translation.service';\nexport * from './components/snackbar/snackbar.module';\nexport * from './components/snackbar/snackbar.service';\nexport * from './components/snackbar/snackbar/snackbar.component';\nexport * from './components/snackbar/snackbar-container/snackbar-container.component';\nexport * from './components/snackbar/snackbar-message.model';\nexport * from './components/stepper/step.component';\nexport * from './components/stepper/stepper.component';\nexport * from './components/stepper/stepper.module';\nexport * from './components/switch/switch.component';\nexport * from './components/switch/switch.module';\nexport * from './components/table/cell';\nexport * from './components/table/row';\nexport * from './components/table/table.component';\nexport * from './components/table/table.module';\nexport * from './components/table/table-dense.component';\nexport * from './components/tabs/tab/tab.component';\nexport * from './components/tabs/tab-panel/tab-panel.component';\nexport * from './components/tabs/tabs.component';\nexport * from './components/tabs/tabs.module';\nexport * from './components/text-input/text-input.component';\nexport * from './components/text-input/text-input.module';\nexport * from './components/textarea-input/textarea-input.component';\nexport * from './components/textarea-input/textarea-input.module';\nexport * from './components/tooltip/tooltip.component';\nexport * from './components/tooltip/tooltip.module';\nexport * from './components/tooltip/tooltip-panel/tooltip-panel.component';\nexport * from './components/typeahead/typeahead.component';\nexport { FwTypeaheadComponent } from './components/typeahead/typeahead.component';\nexport * from './components/wrapped-input/wrapped-input.component';\nexport * from './components/wrapped-input/wrapped-input.module';\nexport * from './directives/menu-register.directive';\nexport { CdkTableModule } from '@angular/cdk/table';\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["export * from './components/alert/alert.component';\nexport * from './components/alert/alert.module';\nexport * from './components/app-icon/app-icon.component';\nexport * from './components/app-icon/app-icon.module';\nexport * from './components/avatar/avatar.component';\nexport * from './components/avatar/avatar.module';\nexport * from './components/avatar-list/avatar-list.component';\nexport * from './components/badge/badge.component';\nexport * from './components/badge/badge.module';\nexport * from './components/breadcrumbs/breadcrumbs.component';\nexport * from './components/breadcrumbs/breadcrumbs.module';\nexport * from './components/breadcrumbs/crumb.component';\nexport * from './components/button/button.component';\nexport * from './components/button/button.directives';\nexport * from './components/button/button.module';\nexport * from './components/button-group/button-group.component';\nexport * from './components/button-group/button-group.module';\nexport * from './components/button-toggle/button-toggle.component';\nexport * from './components/button-toggle/button-toggle.module';\nexport * from './components/button-toggle/button-toggle-item/button-toggle-item.component';\nexport * from './components/card/card.component';\nexport * from './components/card/card.module';\nexport * from './components/card/card-attribute/card-attribute.component';\nexport * from './components/card/card-author/card-author.component';\nexport * from './components/card/card-content/card-content.component';\nexport * from './components/card/card-footer/card-footer.component';\nexport * from './components/card/card-header/card-header.component';\nexport * from './components/checkbox/checkbox.component';\nexport * from './components/checkbox/checkbox.module';\nexport * from './components/chip/chip.component';\nexport * from './components/chip/chip.module';\nexport * from './components/contained-input/contained-input.component';\nexport * from './components/contained-input/contained-input.module';\nexport * from './components/date-input/date-input.component';\nexport * from './components/date-input/date-input.module';\nexport * from './components/dialog/dialog.component';\nexport * from './components/dialog/dialog.service';\nexport * from './components/dialog/dialog-actions.component';\nexport * from './components/dialog/dialog-confirm.component';\nexport * from './components/dialog/dialog-content.component';\nexport * from './components/dialog/dialog-header.component';\nexport * from './components/dialog/dialog-simple.component';\nexport * from './components/dialog/dialogs.module';\nexport * from './components/form-heading/form-heading.component';\nexport * from './components/form-heading/form-heading.module';\nexport * from './components/forms/validators';\nexport * from './components/icon/icon.component';\nexport * from './components/icon/icon.module';\nexport * from './components/icon/icon.types';\nexport * from './components/icon-button/icon-button.component';\nexport * from './components/icon-button/icon-button.module';\nexport * from './components/layouts/context/context.component';\nexport * from './components/layouts/grid/grid.component';\nexport * from './components/layouts/layout-group.component';\nexport * from './components/layouts/layouts.module';\nexport * from './components/layouts/panel/panel.component';\nexport * from './components/layouts/sidebar/sidebar.component';\nexport * from './components/layouts/toolbar/toolbar.component';\nexport * from './components/menu/menu.component';\nexport * from './components/menu/menu.module';\nexport * from './components/menu/menu-close-triggers.directive';\nexport * from './components/menu/menu-container/menu-container.component';\nexport * from './components/menu/menu-header/menu-header.component';\nexport * from './components/menu/menu-item/menu-item.component';\nexport * from './components/menu/menu-item-group/menu-item-group.component';\nexport * from './components/menu/menu-separator/menu-separator.component';\nexport * from './components/menu/menu-sub-item/menu-sub-item.component';\nexport * from './components/navbar/navbar.component';\nexport * from './components/navbar/navbar.module';\nexport * from './components/navbar/navbar-header/navbar-header.component';\nexport * from './components/navbar/navbar-item/navbar-item.component';\nexport * from './components/navbar/navbar-sub-item/navbar-sub-item.component';\nexport * from './components/number-input/number-input.component';\nexport * from './components/number-input/number-input.module';\nexport * from './components/paginator/paginator.component';\nexport * from './components/paginator/paginator.module';\nexport * from './components/paginator/paginator-advanced/paginator-advanced.component';\nexport * from './components/phone-input/phone-input.component';\nexport * from './components/phone-input/phone-input.module';\nexport * from './components/popover/popover.component';\nexport * from './components/popover/popover.module';\nexport * from './components/popover/popover-panel/popover-panel.component';\nexport * from './components/progress/bar/bar.component';\nexport * from './components/progress/progress.module';\nexport * from './components/progress/spinner/spinner.component';\nexport * from './components/radio/radio.component';\nexport * from './components/radio/radio.module';\nexport * from './components/radio/radio-group.component';\nexport * from './components/section-heading/back-button/back-button.component';\nexport * from './components/section-heading/section-heading.component';\nexport * from './components/section-heading/section-heading.module';\nexport * from './components/section-heading/subsection-heading/subsection-heading.component';\nexport * from './components/section-heading/subsection-heading/subsection-heading.component';\nexport * from './components/select-menu/multi-select-menu/multi-select-menu.component';\nexport * from './components/select-menu/select-menu.component';\nexport * from './components/select-menu/select-menu.module';\nexport * from './components/shared/services/menu-manager.service';\nexport * from './components/shared/translation.service';\nexport * from './components/snackbar/snackbar.module';\nexport * from './components/snackbar/snackbar.service';\nexport * from './components/snackbar/snackbar/snackbar.component';\nexport * from './components/snackbar/snackbar-container/snackbar-container.component';\nexport * from './components/snackbar/snackbar-message.model';\nexport * from './components/stepper/step.component';\nexport * from './components/stepper/stepper.component';\nexport * from './components/stepper/stepper.module';\nexport * from './components/switch/switch.component';\nexport * from './components/switch/switch.module';\nexport * from './components/table/cell';\nexport * from './components/table/row';\nexport * from './components/table/table.component';\nexport * from './components/table/table.module';\nexport * from './components/table/table-dense.component';\nexport * from './components/tabs/tab/tab.component';\nexport * from './components/tabs/tab-panel/tab-panel.component';\nexport * from './components/tabs/tabs.component';\nexport * from './components/tabs/tabs.module';\nexport * from './components/text-input/text-input.component';\nexport * from './components/text-input/text-input.module';\nexport * from './components/textarea-input/textarea-input.component';\nexport * from './components/textarea-input/textarea-input.module';\nexport * from './components/tooltip/tooltip.component';\nexport * from './components/tooltip/tooltip.directive';\nexport * from './components/tooltip/tooltip.module';\nexport * from './components/tooltip/tooltip-panel/tooltip-panel.component';\nexport * from './components/typeahead/typeahead.component';\nexport { FwTypeaheadComponent } from './components/typeahead/typeahead.component';\nexport * from './components/wrapped-input/wrapped-input.component';\nexport * from './components/wrapped-input/wrapped-input.module';\nexport * from './directives/menu-register.directive';\nexport { CdkTableModule } from '@angular/cdk/table';\n"]}