@recursyve/nice-ui-kit.v2 14.0.0-beta.107 → 14.0.0-beta.108

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.
@@ -0,0 +1,120 @@
1
+ import { ChangeDetectorRef, Directive, HostListener } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import * as i0 from "@angular/core";
4
+ // tslint:disable-next-line:class-name directive-class-suffix
5
+ export class _HintComponentBase {
6
+ constructor(_changeDetectorRef) {
7
+ this._changeDetectorRef = _changeDetectorRef;
8
+ /** Whether interactions on the page should close the tooltip */
9
+ this._closeOnInteraction = false;
10
+ /** Whether the tooltip is currently visible. */
11
+ this._isVisible = false;
12
+ /** Subject for notifying that the tooltip has been hidden from the view */
13
+ this._onHide = new Subject();
14
+ }
15
+ /**
16
+ * Shows the tooltip with an animation originating from the provided origin
17
+ * @param delay Amount of milliseconds to the delay showing the tooltip.
18
+ */
19
+ show(delay) {
20
+ // Cancel the delayed hide if it is scheduled
21
+ clearTimeout(this._hideTimeoutId);
22
+ this._showTimeoutId = setTimeout(() => {
23
+ this._toggleVisibility(true);
24
+ this._showTimeoutId = undefined;
25
+ }, delay);
26
+ }
27
+ /**
28
+ * Begins the animation to hide the tooltip after the provided delay in ms.
29
+ * @param delay Amount of milliseconds to delay showing the tooltip.
30
+ */
31
+ hide(delay) {
32
+ // Cancel the delayed show if it is scheduled
33
+ clearTimeout(this._showTimeoutId);
34
+ this._hideTimeoutId = setTimeout(() => {
35
+ this._toggleVisibility(false);
36
+ this._hideTimeoutId = undefined;
37
+ }, delay);
38
+ }
39
+ /** Returns an observable that notifies when the tooltip has been hidden from view. */
40
+ afterHidden() {
41
+ return this._onHide;
42
+ }
43
+ /** Whether the tooltip is being displayed. */
44
+ isVisible() {
45
+ return this._isVisible;
46
+ }
47
+ ngOnDestroy() {
48
+ this._cancelPendingAnimations();
49
+ this._onHide.complete();
50
+ this._triggerElement = null;
51
+ }
52
+ /**
53
+ * Interactions on the HTML body should close the tooltip immediately as defined in the
54
+ * material design spec.
55
+ * https://material.io/design/components/tooltips.html#behavior
56
+ */
57
+ _handleBodyInteraction() {
58
+ if (this._closeOnInteraction) {
59
+ this.hide(0);
60
+ }
61
+ }
62
+ /**
63
+ * Marks that the tooltip needs to be checked in the next change detection run.
64
+ * Mainly used for rendering the initial text before positioning a tooltip, which
65
+ * can be problematic in components with OnPush change detection.
66
+ */
67
+ _markForCheck() {
68
+ this._changeDetectorRef.markForCheck();
69
+ }
70
+ _handleMouseLeave({ relatedTarget }) {
71
+ if (!relatedTarget || !this._triggerElement.contains(relatedTarget)) {
72
+ if (this.isVisible()) {
73
+ this.hide(this._mouseLeaveHideDelay);
74
+ }
75
+ else {
76
+ this._finalizeAnimation(false);
77
+ }
78
+ }
79
+ }
80
+ /**
81
+ * Callback for when the timeout in this.show() gets completed.
82
+ * This method is only needed by the mdc-tooltip, and so it is only implemented
83
+ * in the mdc-tooltip, not here.
84
+ */
85
+ _onShow() { }
86
+ /** Cancels any pending animation sequences. */
87
+ _cancelPendingAnimations() {
88
+ clearTimeout(this._showTimeoutId);
89
+ clearTimeout(this._hideTimeoutId);
90
+ this._showTimeoutId = this._hideTimeoutId = undefined;
91
+ }
92
+ /** Handles the cleanup after an animation has finished. */
93
+ _finalizeAnimation(toVisible) {
94
+ if (toVisible) {
95
+ this._closeOnInteraction = true;
96
+ }
97
+ else if (!this.isVisible()) {
98
+ this._onHide.next();
99
+ }
100
+ }
101
+ /** Toggles the visibility of the tooltip element. */
102
+ _toggleVisibility(isVisible) {
103
+ // We set the classes directly here ourselves so that toggling the tooltip state
104
+ // isn't bound by change detection. This allows us to hide it even if the
105
+ // view ref has been detached from the CD tree.
106
+ this._isVisible = isVisible;
107
+ if (isVisible) {
108
+ this._onShow();
109
+ }
110
+ }
111
+ }
112
+ _HintComponentBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
113
+ _HintComponentBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: _HintComponentBase, host: { listeners: { "mouseleave": "_handleMouseLeave($event)" } }, ngImport: i0 });
114
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, decorators: [{
115
+ type: Directive
116
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _handleMouseLeave: [{
117
+ type: HostListener,
118
+ args: ["mouseleave", ["$event"]]
119
+ }] } });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hint-component-base.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/components/hint-component-base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAA2B,YAAY,EAAa,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;;AAG3C,6DAA6D;AAC7D,MAAM,OAAgB,kBAAkB;IA0BpC,YAAoB,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;QATzD,gEAAgE;QACxD,wBAAmB,GAAG,KAAK,CAAC;QAEpC,gDAAgD;QACxC,eAAU,GAAG,KAAK,CAAC;QAE3B,2EAA2E;QAC1D,YAAO,GAAkB,IAAI,OAAO,EAAE,CAAC;IAEI,CAAC;IAE7D;;;OAGG;IACH,IAAI,CAAC,KAAa;QACd,6CAA6C;QAC7C,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAElC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QACpC,CAAC,EAAE,KAAK,CAAsB,CAAC;IACnC,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,KAAa;QACd,6CAA6C;QAC7C,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAElC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAC9B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QACpC,CAAC,EAAE,KAAK,CAAsB,CAAC;IACnC,CAAC;IAED,sFAAsF;IACtF,WAAW;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,8CAA8C;IAC9C,SAAS;QACL,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,sBAAsB;QAClB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAChB;IACL,CAAC;IAED;;;;OAIG;IACH,aAAa;QACT,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IAGD,iBAAiB,CAAC,EAAC,aAAa,EAAa;QACzC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,aAAqB,CAAC,EAAE;YACzE,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE;gBAClB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;aACxC;iBAAM;gBACH,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;aAClC;SACJ;IACL,CAAC;IAED;;;;OAIG;IACO,OAAO,KAAU,CAAC;IAE5B,+CAA+C;IAC/C,wBAAwB;QACpB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAClC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAClC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IAC1D,CAAC;IAED,2DAA2D;IACnD,kBAAkB,CAAC,SAAkB;QACzC,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;SACnC;aAAM,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE;YAC1B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;SACvB;IACL,CAAC;IAED,qDAAqD;IAC7C,iBAAiB,CAAC,SAAkB;QACxC,gFAAgF;QAChF,yEAAyE;QACzE,+CAA+C;QAC/C,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAE5B,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,OAAO,EAAE,CAAC;SAClB;IACL,CAAC;;+GAxIiB,kBAAkB;mGAAlB,kBAAkB;2FAAlB,kBAAkB;kBAFvC,SAAS;wGA+FN,iBAAiB;sBADhB,YAAY;uBAAC,YAAY,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, HostBinding, HostListener, OnDestroy } from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\n\n@Directive()\n// tslint:disable-next-line:class-name directive-class-suffix\nexport abstract class _HintComponentBase implements OnDestroy {\n\n    /** The timeout ID of any current timer set to show the tooltip */\n    private _showTimeoutId: number | undefined;\n\n    /** The timeout ID of any current timer set to hide the tooltip */\n    private _hideTimeoutId: number | undefined;\n\n    /** Element that caused the tooltip to open. */\n    _triggerElement: HTMLElement;\n\n    /** Amount of milliseconds to delay the closing sequence. */\n    _mouseLeaveHideDelay: number;\n\n    /** Reference to the internal tooltip element. */\n    abstract _hint: ElementRef<HTMLElement>;\n\n    /** Whether interactions on the page should close the tooltip */\n    private _closeOnInteraction = false;\n\n    /** Whether the tooltip is currently visible. */\n    private _isVisible = false;\n\n    /** Subject for notifying that the tooltip has been hidden from the view */\n    private readonly _onHide: Subject<void> = new Subject();\n\n    constructor(private _changeDetectorRef: ChangeDetectorRef) {}\n\n    /**\n     * Shows the tooltip with an animation originating from the provided origin\n     * @param delay Amount of milliseconds to the delay showing the tooltip.\n     */\n    show(delay: number): void {\n        // Cancel the delayed hide if it is scheduled\n        clearTimeout(this._hideTimeoutId);\n\n        this._showTimeoutId = setTimeout(() => {\n            this._toggleVisibility(true);\n            this._showTimeoutId = undefined;\n        }, delay) as unknown as number;\n    }\n\n    /**\n     * Begins the animation to hide the tooltip after the provided delay in ms.\n     * @param delay Amount of milliseconds to delay showing the tooltip.\n     */\n    hide(delay: number): void {\n        // Cancel the delayed show if it is scheduled\n        clearTimeout(this._showTimeoutId);\n\n        this._hideTimeoutId = setTimeout(() => {\n            this._toggleVisibility(false);\n            this._hideTimeoutId = undefined;\n        }, delay) as unknown as number;\n    }\n\n    /** Returns an observable that notifies when the tooltip has been hidden from view. */\n    afterHidden(): Observable<void> {\n        return this._onHide;\n    }\n\n    /** Whether the tooltip is being displayed. */\n    isVisible(): boolean {\n        return this._isVisible;\n    }\n\n    ngOnDestroy() {\n        this._cancelPendingAnimations();\n        this._onHide.complete();\n        this._triggerElement = null;\n    }\n\n    /**\n     * Interactions on the HTML body should close the tooltip immediately as defined in the\n     * material design spec.\n     * https://material.io/design/components/tooltips.html#behavior\n     */\n    _handleBodyInteraction(): void {\n        if (this._closeOnInteraction) {\n            this.hide(0);\n        }\n    }\n\n    /**\n     * Marks that the tooltip needs to be checked in the next change detection run.\n     * Mainly used for rendering the initial text before positioning a tooltip, which\n     * can be problematic in components with OnPush change detection.\n     */\n    _markForCheck(): void {\n        this._changeDetectorRef.markForCheck();\n    }\n\n    @HostListener(\"mouseleave\", [\"$event\"])\n    _handleMouseLeave({relatedTarget}: MouseEvent) {\n        if (!relatedTarget || !this._triggerElement.contains(relatedTarget as Node)) {\n            if (this.isVisible()) {\n                this.hide(this._mouseLeaveHideDelay);\n            } else {\n                this._finalizeAnimation(false);\n            }\n        }\n    }\n\n    /**\n     * Callback for when the timeout in this.show() gets completed.\n     * This method is only needed by the mdc-tooltip, and so it is only implemented\n     * in the mdc-tooltip, not here.\n     */\n    protected _onShow(): void {}\n\n    /** Cancels any pending animation sequences. */\n    _cancelPendingAnimations() {\n        clearTimeout(this._showTimeoutId);\n        clearTimeout(this._hideTimeoutId);\n        this._showTimeoutId = this._hideTimeoutId = undefined;\n    }\n\n    /** Handles the cleanup after an animation has finished. */\n    private _finalizeAnimation(toVisible: boolean) {\n        if (toVisible) {\n            this._closeOnInteraction = true;\n        } else if (!this.isVisible()) {\n            this._onHide.next();\n        }\n    }\n\n    /** Toggles the visibility of the tooltip element. */\n    private _toggleVisibility(isVisible: boolean) {\n        // We set the classes directly here ourselves so that toggling the tooltip state\n        // isn't bound by change detection. This allows us to hide it even if the\n        // view ref has been detached from the CD tree.\n        this._isVisible = isVisible;\n\n        if (isVisible) {\n            this._onShow();\n        }\n    }\n}\n"]}
@@ -1,3 +1,4 @@
1
+ import { FocusMonitor } from "@angular/cdk/a11y";
1
2
  import { Overlay } from "@angular/cdk/overlay";
2
3
  import { Platform } from "@angular/cdk/platform";
3
4
  import { ComponentPortal } from "@angular/cdk/portal";
@@ -8,14 +9,16 @@ import { NiceNavigationHintService } from "../providers/hint.service";
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@angular/cdk/overlay";
10
11
  import * as i2 from "@angular/cdk/platform";
11
- import * as i3 from "../providers/hint.service";
12
+ import * as i3 from "@angular/cdk/a11y";
13
+ import * as i4 from "../providers/hint.service";
12
14
  export class NiceShowHintDirective {
13
- constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _hintService) {
15
+ constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _focusMonitor, _hintService) {
14
16
  this._overlay = _overlay;
15
17
  this._elementRef = _elementRef;
16
18
  this._viewContainerRef = _viewContainerRef;
17
19
  this._ngZone = _ngZone;
18
20
  this._platform = _platform;
21
+ this._focusMonitor = _focusMonitor;
19
22
  this._hintService = _hintService;
20
23
  this.shouldShow = false;
21
24
  this._pointerExitEventsInitialized = false;
@@ -24,9 +27,18 @@ export class NiceShowHintDirective {
24
27
  }
25
28
  ngAfterViewInit() {
26
29
  this._setupPointerEnterEventsIfNeeded();
27
- if (this.item.hint) {
28
- this._portal = new ComponentPortal(this.item.hint.component, this._viewContainerRef);
29
- }
30
+ this._focusMonitor
31
+ .monitor(this._elementRef)
32
+ .pipe(takeUntil(this.unsubscribeAll$))
33
+ .subscribe(origin => {
34
+ // Note that the focus monitor runs outside the Angular zone.
35
+ if (!origin) {
36
+ this._ngZone.run(() => this.hide());
37
+ }
38
+ else if (origin === "keyboard") {
39
+ this._ngZone.run(() => this.show());
40
+ }
41
+ });
30
42
  }
31
43
  ngOnDestroy() {
32
44
  this.unsubscribeAll$.next();
@@ -37,15 +49,26 @@ export class NiceShowHintDirective {
37
49
  return;
38
50
  }
39
51
  const overlayRef = this._createOverlay();
52
+ this._portal = this._portal || new ComponentPortal(this.item.hint.component);
40
53
  this._detach();
41
54
  this._hintInstance = overlayRef.attach(this._portal).instance;
55
+ this._hintInstance._triggerElement = this._elementRef.nativeElement;
56
+ this._hintInstance
57
+ .afterHidden()
58
+ .pipe(takeUntil(this.unsubscribeAll$))
59
+ .subscribe(() => this._detach());
42
60
  this._hintService.setActiveHint(true);
43
61
  }
44
62
  hide() {
45
63
  const instance = this._hintInstance;
46
64
  if (instance) {
47
- this._detach();
48
- this._hintService.setActiveHint(false);
65
+ if (instance.isVisible()) {
66
+ instance.hide(0);
67
+ }
68
+ else {
69
+ instance._cancelPendingAnimations();
70
+ this._detach();
71
+ }
49
72
  }
50
73
  }
51
74
  _createOverlay() {
@@ -88,10 +111,10 @@ export class NiceShowHintDirective {
88
111
  .detachments()
89
112
  .pipe(takeUntil(this.unsubscribeAll$))
90
113
  .subscribe(() => this._detach());
91
- /*this._overlayRef
114
+ this._overlayRef
92
115
  .outsidePointerEvents()
93
116
  .pipe(takeUntil(this.unsubscribeAll$))
94
- .subscribe(() => this._hintInstance?._handleBodyInteraction());*/
117
+ .subscribe(() => this._hintInstance?._handleBodyInteraction());
95
118
  return this._overlayRef;
96
119
  }
97
120
  _detach() {
@@ -150,14 +173,14 @@ export class NiceShowHintDirective {
150
173
  });
151
174
  }
152
175
  }
153
- NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i2.Platform }, { token: i3.NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
176
+ NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i2.Platform }, { token: i3.FocusMonitor }, { token: i4.NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
154
177
  NiceShowHintDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: NiceShowHintDirective, selector: "[niceShowHint]", inputs: { shouldShow: "shouldShow", item: "item" }, ngImport: i0 });
155
178
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, decorators: [{
156
179
  type: Directive,
157
180
  args: [{ selector: "[niceShowHint]" }]
158
- }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i2.Platform }, { type: i3.NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
181
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i2.Platform }, { type: i3.FocusMonitor }, { type: i4.NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
159
182
  type: Input
160
183
  }], item: [{
161
184
  type: Input
162
185
  }] } });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-hint.directive.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/directives/show-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { NiceNavigationItem } from \"../navigation.types\";\nimport { NiceNavigationHintService } from \"../providers/hint.service\";\n\n@Directive({ selector: \"[niceShowHint]\" })\nexport class NiceShowHintDirective implements AfterViewInit, OnDestroy {\n    @Input()\n    public shouldShow = false;\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    private _pointerExitEventsInitialized = false;\n    private _portal: ComponentPortal<any>;\n    private _hintInstance: any;\n    private _overlayRef: OverlayRef;\n\n    private readonly _passiveListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n    private readonly unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private _overlay: Overlay,\n        private _elementRef: ElementRef<HTMLElement>,\n        private _viewContainerRef: ViewContainerRef,\n        private _ngZone: NgZone,\n        private _platform: Platform,\n        private _hintService: NiceNavigationHintService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this._setupPointerEnterEventsIfNeeded();\n\n        if (this.item.hint) {\n            this._portal = new ComponentPortal<any>(this.item.hint.component, this._viewContainerRef);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public show(): void {\n        if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {\n            return;\n        }\n\n        const overlayRef = this._createOverlay();\n        this._detach();\n        this._hintInstance = overlayRef.attach(this._portal).instance;\n\n        this._hintService.setActiveHint(true);\n    }\n\n    public hide(): void {\n        const instance = this._hintInstance;\n\n        if (instance) {\n            this._detach();\n            this._hintService.setActiveHint(false);\n        }\n    }\n\n    private _createOverlay(): OverlayRef {\n        if (this._overlayRef) {\n            const existingStrategy = this._overlayRef.getConfig()\n                .positionStrategy as FlexibleConnectedPositionStrategy;\n\n            // @ts-ignore\n            if (!origin && existingStrategy._origin instanceof ElementRef) {\n                return this._overlayRef;\n            }\n\n            this._detach();\n        }\n\n        // Create connected position strategy that listens for scroll events to reposition.\n        const strategy = this._overlay\n            .position()\n            .flexibleConnectedTo(this._elementRef)\n            .withPositions([\n                {\n                    originX: \"center\",\n                    originY: \"bottom\",\n                    overlayX: \"start\",\n                    overlayY: \"top\",\n                    offsetY: 8\n                }\n            ])\n            .withFlexibleDimensions(false);\n\n        strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {\n            if (this._hintInstance) {\n                if (change.scrollableViewProperties.isOverlayClipped) {\n                    // After position changes occur and the overlay is clipped by\n                    // a parent scrollable then close the tooltip.\n                    this._ngZone.run(() => this.hide());\n                }\n            }\n        });\n\n        this._overlayRef = this._overlay.create({\n            positionStrategy: strategy\n        });\n\n        this._overlayRef\n            .detachments()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        /*this._overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._hintInstance?._handleBodyInteraction());*/\n\n        return this._overlayRef;\n    }\n\n    private _detach() {\n        if (this._overlayRef && this._overlayRef.hasAttached()) {\n            this._overlayRef.detach();\n        }\n\n        this._hintInstance = null;\n    }\n\n    private _isHintVisible(): boolean {\n        return !!this._hintInstance;\n    }\n\n    private _setupPointerEnterEventsIfNeeded() {\n        // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.\n        if (this._passiveListeners.length) {\n            return;\n        }\n\n        // The mouse events shouldn't be bound on mobile devices, because they can prevent the\n        // first tap from firing its click event or can cause the tooltip to open for clicks.\n        if (this._platformSupportsMouseEvents()) {\n            this._passiveListeners.push([\n                \"mouseenter\",\n                () => {\n                    this._setupPointerExitEventsIfNeeded();\n                    this.show();\n                },\n            ]);\n        }\n\n        this._addListeners(this._passiveListeners);\n    }\n\n    private _setupPointerExitEventsIfNeeded() {\n        if (this._pointerExitEventsInitialized) {\n            return;\n        }\n        this._pointerExitEventsInitialized = true;\n\n        const exitListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n        if (this._platformSupportsMouseEvents()) {\n            exitListeners.push(\n                [\n                    \"mouseleave\",\n                    event => {\n                        const newTarget = (event as MouseEvent).relatedTarget as Node | null;\n                        if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {\n                            this.hide();\n                        }\n                    },\n                ]\n            );\n        }\n\n        this._addListeners(exitListeners);\n        this._passiveListeners.push(...exitListeners);\n    }\n\n    private _platformSupportsMouseEvents() {\n        return !this._platform.IOS && !this._platform.ANDROID;\n    }\n\n    private _addListeners(listeners: (readonly [string, EventListenerOrEventListenerObject])[]) {\n        listeners.forEach(([event, listener]) => {\n            this._elementRef.nativeElement.addEventListener(event, listener);\n        });\n    }\n}\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-hint.directive.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/directives/show-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from \"@angular/cdk/a11y\";\nimport { FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { _HintComponentBase } from \"../components/hint-component-base\";\nimport { NiceNavigationItem } from \"../navigation.types\";\nimport { NiceNavigationHintService } from \"../providers/hint.service\";\n\n@Directive({ selector: \"[niceShowHint]\" })\nexport class NiceShowHintDirective<T extends _HintComponentBase> implements AfterViewInit, OnDestroy {\n    @Input()\n    public shouldShow = false;\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    private _pointerExitEventsInitialized = false;\n    private _portal: ComponentPortal<any>;\n    private _hintInstance: T;\n    private _overlayRef: OverlayRef;\n\n    private readonly _passiveListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n    private readonly unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private _overlay: Overlay,\n        private _elementRef: ElementRef<HTMLElement>,\n        private _viewContainerRef: ViewContainerRef,\n        private _ngZone: NgZone,\n        private _platform: Platform,\n        private _focusMonitor: FocusMonitor,\n        private _hintService: NiceNavigationHintService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this._setupPointerEnterEventsIfNeeded();\n\n        this._focusMonitor\n            .monitor(this._elementRef)\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(origin => {\n                // Note that the focus monitor runs outside the Angular zone.\n                if (!origin) {\n                    this._ngZone.run(() => this.hide());\n                } else if (origin === \"keyboard\") {\n                    this._ngZone.run(() => this.show());\n                }\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public show(): void {\n        if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {\n            return;\n        }\n\n        const overlayRef = this._createOverlay();\n        this._portal = this._portal || new ComponentPortal<any>(this.item.hint.component);\n        this._detach();\n        this._hintInstance = overlayRef.attach(this._portal).instance;\n\n        this._hintInstance._triggerElement = this._elementRef.nativeElement;\n        this._hintInstance\n            .afterHidden()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        this._hintService.setActiveHint(true);\n    }\n\n    public hide(): void {\n        const instance = this._hintInstance;\n\n        if (instance) {\n            if (instance.isVisible()) {\n                instance.hide(0);\n            } else {\n                instance._cancelPendingAnimations();\n                this._detach();\n            }\n        }\n    }\n\n    private _createOverlay(): OverlayRef {\n        if (this._overlayRef) {\n            const existingStrategy = this._overlayRef.getConfig()\n                .positionStrategy as FlexibleConnectedPositionStrategy;\n\n            // @ts-ignore\n            if (!origin && existingStrategy._origin instanceof ElementRef) {\n                return this._overlayRef;\n            }\n\n            this._detach();\n        }\n\n        // Create connected position strategy that listens for scroll events to reposition.\n        const strategy = this._overlay\n            .position()\n            .flexibleConnectedTo(this._elementRef)\n            .withPositions([\n                {\n                    originX: \"center\",\n                    originY: \"bottom\",\n                    overlayX: \"start\",\n                    overlayY: \"top\",\n                    offsetY: 8\n                }\n            ])\n            .withFlexibleDimensions(false);\n\n        strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {\n            if (this._hintInstance) {\n                if (change.scrollableViewProperties.isOverlayClipped) {\n                    // After position changes occur and the overlay is clipped by\n                    // a parent scrollable then close the tooltip.\n                    this._ngZone.run(() => this.hide());\n                }\n            }\n        });\n\n        this._overlayRef = this._overlay.create({\n            positionStrategy: strategy\n        });\n\n        this._overlayRef\n            .detachments()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        this._overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._hintInstance?._handleBodyInteraction());\n\n        return this._overlayRef;\n    }\n\n    private _detach() {\n        if (this._overlayRef && this._overlayRef.hasAttached()) {\n            this._overlayRef.detach();\n        }\n\n        this._hintInstance = null;\n    }\n\n    private _isHintVisible(): boolean {\n        return !!this._hintInstance;\n    }\n\n    private _setupPointerEnterEventsIfNeeded() {\n        // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.\n        if (this._passiveListeners.length) {\n            return;\n        }\n\n        // The mouse events shouldn't be bound on mobile devices, because they can prevent the\n        // first tap from firing its click event or can cause the tooltip to open for clicks.\n        if (this._platformSupportsMouseEvents()) {\n            this._passiveListeners.push([\n                \"mouseenter\",\n                () => {\n                    this._setupPointerExitEventsIfNeeded();\n                    this.show();\n                },\n            ]);\n        }\n\n        this._addListeners(this._passiveListeners);\n    }\n\n    private _setupPointerExitEventsIfNeeded() {\n        if (this._pointerExitEventsInitialized) {\n            return;\n        }\n        this._pointerExitEventsInitialized = true;\n\n        const exitListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n        if (this._platformSupportsMouseEvents()) {\n            exitListeners.push(\n                [\n                    \"mouseleave\",\n                    event => {\n                        const newTarget = (event as MouseEvent).relatedTarget as Node | null;\n                        if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {\n                            this.hide();\n                        }\n                    },\n                ]\n            );\n        }\n\n        this._addListeners(exitListeners);\n        this._passiveListeners.push(...exitListeners);\n    }\n\n    private _platformSupportsMouseEvents() {\n        return !this._platform.IOS && !this._platform.ANDROID;\n    }\n\n    private _addListeners(listeners: (readonly [string, EventListenerOrEventListenerObject])[]) {\n        listeners.forEach(([event, listener]) => {\n            this._elementRef.nativeElement.addEventListener(event, listener);\n        });\n    }\n}\n"]}
@@ -1,3 +1,4 @@
1
+ export * from "./components/hint-component-base";
1
2
  export * from "./horizontal/horizontal.component";
2
3
  export * from "./horizontal/components/basic/basic.component";
3
4
  export * from "./horizontal/components/branch/branch.component";
@@ -16,4 +17,4 @@ export * from "./navigation.service";
16
17
  export * from "./navigation.types";
17
18
  export * from "./providers/hide-item.resolver";
18
19
  export * from "./providers/hint.resolver";
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxvQkFBb0IsQ0FBQztBQUVuQyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2hvcml6b250YWwuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2NvbXBvbmVudHMvYmFzaWMvYmFzaWMuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2NvbXBvbmVudHMvYnJhbmNoL2JyYW5jaC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2hvcml6b250YWwvY29tcG9uZW50cy9kaXZpZGVyL2RpdmlkZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2NvbXBvbmVudHMvc3BhY2VyL3NwYWNlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL3ZlcnRpY2FsLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9hc2lkZS9hc2lkZS5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvYmFzaWMvYmFzaWMuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC9jb21wb25lbnRzL2NvbGxhcHNhYmxlL2NvbGxhcHNhYmxlLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9kaXZpZGVyL2RpdmlkZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC9jb21wb25lbnRzL2dyb3VwL2dyb3VwLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9zcGFjZXIvc3BhY2VyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbmF2aWdhdGlvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL25hdmlnYXRpb24ubW9kdWxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uYXZpZ2F0aW9uLnNlcnZpY2VcIjtcbmV4cG9ydCAqIGZyb20gXCIuL25hdmlnYXRpb24udHlwZXNcIjtcblxuZXhwb3J0ICogZnJvbSBcIi4vcHJvdmlkZXJzL2hpZGUtaXRlbS5yZXNvbHZlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vcHJvdmlkZXJzL2hpbnQucmVzb2x2ZXJcIjtcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG9CQUFvQixDQUFDO0FBRW5DLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvaGludC1jb21wb25lbnQtYmFzZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9ob3Jpem9udGFsLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL2Jhc2ljL2Jhc2ljLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL2JyYW5jaC9icmFuY2guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob3Jpem9udGFsL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaG9yaXpvbnRhbC9jb21wb25lbnRzL3NwYWNlci9zcGFjZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC92ZXJ0aWNhbC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvYXNpZGUvYXNpZGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi92ZXJ0aWNhbC9jb21wb25lbnRzL2Jhc2ljL2Jhc2ljLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9jb2xsYXBzYWJsZS9jb2xsYXBzYWJsZS5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmVydGljYWwvY29tcG9uZW50cy9ncm91cC9ncm91cC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZlcnRpY2FsL2NvbXBvbmVudHMvc3BhY2VyL3NwYWNlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL25hdmlnYXRpb24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uYXZpZ2F0aW9uLm1vZHVsZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbmF2aWdhdGlvbi5zZXJ2aWNlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uYXZpZ2F0aW9uLnR5cGVzXCI7XG5cbmV4cG9ydCAqIGZyb20gXCIuL3Byb3ZpZGVycy9oaWRlLWl0ZW0ucmVzb2x2ZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Byb3ZpZGVycy9oaW50LnJlc29sdmVyXCI7XG4iXX0=
@@ -7066,6 +7066,123 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
7066
7066
  }]
7067
7067
  }] });
7068
7068
 
7069
+ // tslint:disable-next-line:class-name directive-class-suffix
7070
+ class _HintComponentBase {
7071
+ constructor(_changeDetectorRef) {
7072
+ this._changeDetectorRef = _changeDetectorRef;
7073
+ /** Whether interactions on the page should close the tooltip */
7074
+ this._closeOnInteraction = false;
7075
+ /** Whether the tooltip is currently visible. */
7076
+ this._isVisible = false;
7077
+ /** Subject for notifying that the tooltip has been hidden from the view */
7078
+ this._onHide = new Subject();
7079
+ }
7080
+ /**
7081
+ * Shows the tooltip with an animation originating from the provided origin
7082
+ * @param delay Amount of milliseconds to the delay showing the tooltip.
7083
+ */
7084
+ show(delay) {
7085
+ // Cancel the delayed hide if it is scheduled
7086
+ clearTimeout(this._hideTimeoutId);
7087
+ this._showTimeoutId = setTimeout(() => {
7088
+ this._toggleVisibility(true);
7089
+ this._showTimeoutId = undefined;
7090
+ }, delay);
7091
+ }
7092
+ /**
7093
+ * Begins the animation to hide the tooltip after the provided delay in ms.
7094
+ * @param delay Amount of milliseconds to delay showing the tooltip.
7095
+ */
7096
+ hide(delay) {
7097
+ // Cancel the delayed show if it is scheduled
7098
+ clearTimeout(this._showTimeoutId);
7099
+ this._hideTimeoutId = setTimeout(() => {
7100
+ this._toggleVisibility(false);
7101
+ this._hideTimeoutId = undefined;
7102
+ }, delay);
7103
+ }
7104
+ /** Returns an observable that notifies when the tooltip has been hidden from view. */
7105
+ afterHidden() {
7106
+ return this._onHide;
7107
+ }
7108
+ /** Whether the tooltip is being displayed. */
7109
+ isVisible() {
7110
+ return this._isVisible;
7111
+ }
7112
+ ngOnDestroy() {
7113
+ this._cancelPendingAnimations();
7114
+ this._onHide.complete();
7115
+ this._triggerElement = null;
7116
+ }
7117
+ /**
7118
+ * Interactions on the HTML body should close the tooltip immediately as defined in the
7119
+ * material design spec.
7120
+ * https://material.io/design/components/tooltips.html#behavior
7121
+ */
7122
+ _handleBodyInteraction() {
7123
+ if (this._closeOnInteraction) {
7124
+ this.hide(0);
7125
+ }
7126
+ }
7127
+ /**
7128
+ * Marks that the tooltip needs to be checked in the next change detection run.
7129
+ * Mainly used for rendering the initial text before positioning a tooltip, which
7130
+ * can be problematic in components with OnPush change detection.
7131
+ */
7132
+ _markForCheck() {
7133
+ this._changeDetectorRef.markForCheck();
7134
+ }
7135
+ _handleMouseLeave({ relatedTarget }) {
7136
+ if (!relatedTarget || !this._triggerElement.contains(relatedTarget)) {
7137
+ if (this.isVisible()) {
7138
+ this.hide(this._mouseLeaveHideDelay);
7139
+ }
7140
+ else {
7141
+ this._finalizeAnimation(false);
7142
+ }
7143
+ }
7144
+ }
7145
+ /**
7146
+ * Callback for when the timeout in this.show() gets completed.
7147
+ * This method is only needed by the mdc-tooltip, and so it is only implemented
7148
+ * in the mdc-tooltip, not here.
7149
+ */
7150
+ _onShow() { }
7151
+ /** Cancels any pending animation sequences. */
7152
+ _cancelPendingAnimations() {
7153
+ clearTimeout(this._showTimeoutId);
7154
+ clearTimeout(this._hideTimeoutId);
7155
+ this._showTimeoutId = this._hideTimeoutId = undefined;
7156
+ }
7157
+ /** Handles the cleanup after an animation has finished. */
7158
+ _finalizeAnimation(toVisible) {
7159
+ if (toVisible) {
7160
+ this._closeOnInteraction = true;
7161
+ }
7162
+ else if (!this.isVisible()) {
7163
+ this._onHide.next();
7164
+ }
7165
+ }
7166
+ /** Toggles the visibility of the tooltip element. */
7167
+ _toggleVisibility(isVisible) {
7168
+ // We set the classes directly here ourselves so that toggling the tooltip state
7169
+ // isn't bound by change detection. This allows us to hide it even if the
7170
+ // view ref has been detached from the CD tree.
7171
+ this._isVisible = isVisible;
7172
+ if (isVisible) {
7173
+ this._onShow();
7174
+ }
7175
+ }
7176
+ }
7177
+ _HintComponentBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
7178
+ _HintComponentBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: _HintComponentBase, host: { listeners: { "mouseleave": "_handleMouseLeave($event)" } }, ngImport: i0 });
7179
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: _HintComponentBase, decorators: [{
7180
+ type: Directive
7181
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _handleMouseLeave: [{
7182
+ type: HostListener,
7183
+ args: ["mouseleave", ["$event"]]
7184
+ }] } });
7185
+
7069
7186
  class NiceNavigationService {
7070
7187
  /**
7071
7188
  * Constructor
@@ -7913,12 +8030,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
7913
8030
  }] });
7914
8031
 
7915
8032
  class NiceShowHintDirective {
7916
- constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _hintService) {
8033
+ constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform, _focusMonitor, _hintService) {
7917
8034
  this._overlay = _overlay;
7918
8035
  this._elementRef = _elementRef;
7919
8036
  this._viewContainerRef = _viewContainerRef;
7920
8037
  this._ngZone = _ngZone;
7921
8038
  this._platform = _platform;
8039
+ this._focusMonitor = _focusMonitor;
7922
8040
  this._hintService = _hintService;
7923
8041
  this.shouldShow = false;
7924
8042
  this._pointerExitEventsInitialized = false;
@@ -7927,9 +8045,18 @@ class NiceShowHintDirective {
7927
8045
  }
7928
8046
  ngAfterViewInit() {
7929
8047
  this._setupPointerEnterEventsIfNeeded();
7930
- if (this.item.hint) {
7931
- this._portal = new ComponentPortal(this.item.hint.component, this._viewContainerRef);
7932
- }
8048
+ this._focusMonitor
8049
+ .monitor(this._elementRef)
8050
+ .pipe(takeUntil(this.unsubscribeAll$))
8051
+ .subscribe(origin => {
8052
+ // Note that the focus monitor runs outside the Angular zone.
8053
+ if (!origin) {
8054
+ this._ngZone.run(() => this.hide());
8055
+ }
8056
+ else if (origin === "keyboard") {
8057
+ this._ngZone.run(() => this.show());
8058
+ }
8059
+ });
7933
8060
  }
7934
8061
  ngOnDestroy() {
7935
8062
  this.unsubscribeAll$.next();
@@ -7940,15 +8067,26 @@ class NiceShowHintDirective {
7940
8067
  return;
7941
8068
  }
7942
8069
  const overlayRef = this._createOverlay();
8070
+ this._portal = this._portal || new ComponentPortal(this.item.hint.component);
7943
8071
  this._detach();
7944
8072
  this._hintInstance = overlayRef.attach(this._portal).instance;
8073
+ this._hintInstance._triggerElement = this._elementRef.nativeElement;
8074
+ this._hintInstance
8075
+ .afterHidden()
8076
+ .pipe(takeUntil(this.unsubscribeAll$))
8077
+ .subscribe(() => this._detach());
7945
8078
  this._hintService.setActiveHint(true);
7946
8079
  }
7947
8080
  hide() {
7948
8081
  const instance = this._hintInstance;
7949
8082
  if (instance) {
7950
- this._detach();
7951
- this._hintService.setActiveHint(false);
8083
+ if (instance.isVisible()) {
8084
+ instance.hide(0);
8085
+ }
8086
+ else {
8087
+ instance._cancelPendingAnimations();
8088
+ this._detach();
8089
+ }
7952
8090
  }
7953
8091
  }
7954
8092
  _createOverlay() {
@@ -7991,10 +8129,10 @@ class NiceShowHintDirective {
7991
8129
  .detachments()
7992
8130
  .pipe(takeUntil(this.unsubscribeAll$))
7993
8131
  .subscribe(() => this._detach());
7994
- /*this._overlayRef
8132
+ this._overlayRef
7995
8133
  .outsidePointerEvents()
7996
8134
  .pipe(takeUntil(this.unsubscribeAll$))
7997
- .subscribe(() => this._hintInstance?._handleBodyInteraction());*/
8135
+ .subscribe(() => { var _a; return (_a = this._hintInstance) === null || _a === void 0 ? void 0 : _a._handleBodyInteraction(); });
7998
8136
  return this._overlayRef;
7999
8137
  }
8000
8138
  _detach() {
@@ -8054,12 +8192,12 @@ class NiceShowHintDirective {
8054
8192
  });
8055
8193
  }
8056
8194
  }
8057
- NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1$5.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i1$d.Platform }, { token: NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
8195
+ NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1$5.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i1$d.Platform }, { token: i2$2.FocusMonitor }, { token: NiceNavigationHintService }], target: i0.ɵɵFactoryTarget.Directive });
8058
8196
  NiceShowHintDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.3", type: NiceShowHintDirective, selector: "[niceShowHint]", inputs: { shouldShow: "shouldShow", item: "item" }, ngImport: i0 });
8059
8197
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceShowHintDirective, decorators: [{
8060
8198
  type: Directive,
8061
8199
  args: [{ selector: "[niceShowHint]" }]
8062
- }], ctorParameters: function () { return [{ type: i1$5.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i1$d.Platform }, { type: NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
8200
+ }], ctorParameters: function () { return [{ type: i1$5.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i1$d.Platform }, { type: i2$2.FocusMonitor }, { type: NiceNavigationHintService }]; }, propDecorators: { shouldShow: [{
8063
8201
  type: Input
8064
8202
  }], item: [{
8065
8203
  type: Input
@@ -10600,5 +10738,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
10600
10738
  * Generated bundle index. Do not edit.
10601
10739
  */
10602
10740
 
10603
- export { ArrayUtils, BooleanPipe, CapitalizeFirstLetterPipe, CarouselComponent, CaseUtils, CeilPipe, ChipListItemLabelDirective, ColorsUtils, DateUtils, DefaultExportBottomSheetService, EntriesPipe, ExportBottomSheetComponent, ExportBottomSheetService, FileUtils, FindByKeyPipe, FirstLetterPipe, FloorPipe, FontAwesomeUtils, FormDataUtils, HttpStatusCodes, ImgCropperConfig, ImgCropperError, ImgResolution, JoinPipe, KeyboardCodes, LinkPipe, LocalizedBooleanPipe, LocalizedCurrencyPipe, LocalizedDateOnlyPipe, LocalizedDatePipe, MinutesToTimePipe, ModalMode, NavigationHideItemResolver, NavigationHintResolver, NiceAlertComponent, NiceAlertModule, NiceAlertService, NiceApiException, NiceAssetsCarouselActiveContentDirective, NiceAssetsCarouselComponent, NiceAssetsCarouselModule, NiceAsyncTypeaheadComponent, NiceAsyncTypeaheadModule, NiceAsyncTypeaheadProvider, NiceAutofocusDirective, NiceAutofocusDirectiveModule, NiceAutogrowDirective, NiceAutogrowModule, NiceBaseForm, NiceBaseFormComponent, NiceBaseFormModule, NiceCardComponent, NiceCardModule, NiceCarouselModule, NiceChipAsyncTypeaheadDirective, NiceChipListDirective, NiceChipListDirectiveModule, NiceChipListItemsComponent, NiceClickStopPropagationDirective, NiceCollapsableComponent, NiceCollapsableModule, NiceConfigModule, NiceConfigService, NiceControlStatusDirective, NiceCropperAreaComponent, NiceDateRangePickerComponent, NiceDateRangePickerModule, NiceDrawerComponent, NiceDrawerModule, NiceDrawerService, NiceDropzoneDirective, NiceDropzoneModule, NiceExportBottomSheetModule, NiceFormErrorComponent, NiceFormErrorModule, NiceFormSubmitDirective, NiceHorizontalNavigationBasicItemComponent, NiceHorizontalNavigationBranchItemComponent, NiceHorizontalNavigationComponent, NiceHorizontalNavigationDividerItemComponent, NiceHorizontalNavigationSpacerItemComponent, NiceHorizontalStepperComponent, NiceHorizontalStepperModule, NiceHttpExceptionFactory, NiceImageCropperComponent, NiceImageCropperModule, NiceImageErrorPlaceholderDirective, NiceImageErrorPlaceholderDirectiveModule, NiceLayoutComponent, NiceLayoutModule, NiceLoadingDirective, NiceLoadingSpinnerComponent, NiceLoadingSpinnerModule, NiceLottieComponent, NiceLottieModule, NiceMaterialModule, NiceMaterialStyleDirective, NiceMediaWatcherModule, NiceMediaWatcherService, NiceModalOnClickDirective, NiceModalOpenerDirective, NiceModule, NiceNavigationComponent, NiceNavigationModule, NiceNavigationService, NicePipesModule, NicePreventCloseWindowDirective, NiceRoundedStyleDirective, NiceScrollResetDirective, NiceScrollResetModule, NiceScrollbarDirective, NiceScrollbarModule, NiceSearchBarComponent, NiceSearchBarModule, NiceSplashScreenModule, NiceSplashScreenService, NiceStepComponent, NiceStopPropagationModule, NiceSweetAlertComponent, NiceSweetAlertDirective, NiceSweetAlertModule, NiceSweetAlertService, NiceToastComponent, NiceToastModule, NiceToastService, NiceToggleButtonGroupModule, NiceTransformResponseInterceptor, NiceTypeaheadComponent, NiceTypeaheadModule, NiceTypeaheadNewValue, NiceUtilsModule, NiceUtilsService, NiceVerticalNavigationAsideItemComponent, NiceVerticalNavigationBasicItemComponent, NiceVerticalNavigationCollapsableItemComponent, NiceVerticalNavigationComponent, NiceVerticalNavigationDividerItemComponent, NiceVerticalNavigationGroupItemComponent, NiceVerticalNavigationSpacerItemComponent, NiceWindowDirectiveModule, NumberToOrdinalIndicatorPipe, NumberUtils, ObjectUtils, OptionsScrollDirective, PadPipe, PhonePipe, PictureModalComponent, PictureModalService, PostalCodePipe, PromiseUtils, QueryParamsUtils, RangePipe, RegexUtils, RoundPipe, SanitizeBypassPipe, SecondsToTimePipe, TRANSFORM_TYPE, ToggleButtonComponent, ToggleButtonGroupComponent, TrackByPropPipe, TypeUtils, UrlUtils, _normalizeDegrees, isNotNullOrUndefined, isNullOrUndefined, mergeDeep, mixinNiceApi, niceAnimations, round };
10741
+ export { ArrayUtils, BooleanPipe, CapitalizeFirstLetterPipe, CarouselComponent, CaseUtils, CeilPipe, ChipListItemLabelDirective, ColorsUtils, DateUtils, DefaultExportBottomSheetService, EntriesPipe, ExportBottomSheetComponent, ExportBottomSheetService, FileUtils, FindByKeyPipe, FirstLetterPipe, FloorPipe, FontAwesomeUtils, FormDataUtils, HttpStatusCodes, ImgCropperConfig, ImgCropperError, ImgResolution, JoinPipe, KeyboardCodes, LinkPipe, LocalizedBooleanPipe, LocalizedCurrencyPipe, LocalizedDateOnlyPipe, LocalizedDatePipe, MinutesToTimePipe, ModalMode, NavigationHideItemResolver, NavigationHintResolver, NiceAlertComponent, NiceAlertModule, NiceAlertService, NiceApiException, NiceAssetsCarouselActiveContentDirective, NiceAssetsCarouselComponent, NiceAssetsCarouselModule, NiceAsyncTypeaheadComponent, NiceAsyncTypeaheadModule, NiceAsyncTypeaheadProvider, NiceAutofocusDirective, NiceAutofocusDirectiveModule, NiceAutogrowDirective, NiceAutogrowModule, NiceBaseForm, NiceBaseFormComponent, NiceBaseFormModule, NiceCardComponent, NiceCardModule, NiceCarouselModule, NiceChipAsyncTypeaheadDirective, NiceChipListDirective, NiceChipListDirectiveModule, NiceChipListItemsComponent, NiceClickStopPropagationDirective, NiceCollapsableComponent, NiceCollapsableModule, NiceConfigModule, NiceConfigService, NiceControlStatusDirective, NiceCropperAreaComponent, NiceDateRangePickerComponent, NiceDateRangePickerModule, NiceDrawerComponent, NiceDrawerModule, NiceDrawerService, NiceDropzoneDirective, NiceDropzoneModule, NiceExportBottomSheetModule, NiceFormErrorComponent, NiceFormErrorModule, NiceFormSubmitDirective, NiceHorizontalNavigationBasicItemComponent, NiceHorizontalNavigationBranchItemComponent, NiceHorizontalNavigationComponent, NiceHorizontalNavigationDividerItemComponent, NiceHorizontalNavigationSpacerItemComponent, NiceHorizontalStepperComponent, NiceHorizontalStepperModule, NiceHttpExceptionFactory, NiceImageCropperComponent, NiceImageCropperModule, NiceImageErrorPlaceholderDirective, NiceImageErrorPlaceholderDirectiveModule, NiceLayoutComponent, NiceLayoutModule, NiceLoadingDirective, NiceLoadingSpinnerComponent, NiceLoadingSpinnerModule, NiceLottieComponent, NiceLottieModule, NiceMaterialModule, NiceMaterialStyleDirective, NiceMediaWatcherModule, NiceMediaWatcherService, NiceModalOnClickDirective, NiceModalOpenerDirective, NiceModule, NiceNavigationComponent, NiceNavigationModule, NiceNavigationService, NicePipesModule, NicePreventCloseWindowDirective, NiceRoundedStyleDirective, NiceScrollResetDirective, NiceScrollResetModule, NiceScrollbarDirective, NiceScrollbarModule, NiceSearchBarComponent, NiceSearchBarModule, NiceSplashScreenModule, NiceSplashScreenService, NiceStepComponent, NiceStopPropagationModule, NiceSweetAlertComponent, NiceSweetAlertDirective, NiceSweetAlertModule, NiceSweetAlertService, NiceToastComponent, NiceToastModule, NiceToastService, NiceToggleButtonGroupModule, NiceTransformResponseInterceptor, NiceTypeaheadComponent, NiceTypeaheadModule, NiceTypeaheadNewValue, NiceUtilsModule, NiceUtilsService, NiceVerticalNavigationAsideItemComponent, NiceVerticalNavigationBasicItemComponent, NiceVerticalNavigationCollapsableItemComponent, NiceVerticalNavigationComponent, NiceVerticalNavigationDividerItemComponent, NiceVerticalNavigationGroupItemComponent, NiceVerticalNavigationSpacerItemComponent, NiceWindowDirectiveModule, NumberToOrdinalIndicatorPipe, NumberUtils, ObjectUtils, OptionsScrollDirective, PadPipe, PhonePipe, PictureModalComponent, PictureModalService, PostalCodePipe, PromiseUtils, QueryParamsUtils, RangePipe, RegexUtils, RoundPipe, SanitizeBypassPipe, SecondsToTimePipe, TRANSFORM_TYPE, ToggleButtonComponent, ToggleButtonGroupComponent, TrackByPropPipe, TypeUtils, UrlUtils, _HintComponentBase, _normalizeDegrees, isNotNullOrUndefined, isNullOrUndefined, mergeDeep, mixinNiceApi, niceAnimations, round };
10604
10742
  //# sourceMappingURL=recursyve-nice-ui-kit.v2.mjs.map