@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.
- package/esm2020/lib/components/navigation/components/hint-component-base.mjs +120 -0
- package/esm2020/lib/components/navigation/directives/show-hint.directive.mjs +35 -12
- package/esm2020/lib/components/navigation/public-api.mjs +2 -1
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs +149 -11
- package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs +149 -11
- package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/lib/components/navigation/components/hint-component-base.d.ts +65 -0
- package/lib/components/navigation/directives/show-hint.directive.d.ts +7 -4
- package/lib/components/navigation/public-api.d.ts +1 -0
- package/package.json +1 -1
|
@@ -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 "
|
|
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
|
-
|
|
28
|
-
|
|
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
|
-
|
|
48
|
-
|
|
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
|
-
|
|
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":"AAAA,OAAO,EAAqC,OAAO,EAAc,MAAM,sBAAsB,CAAC;AAC9F,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAiB,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjH,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,2BAA2B,CAAC;;;;;AAGtE,MAAM,OAAO,qBAAqB;IAe9B,YACY,QAAiB,EACjB,WAAoC,EACpC,iBAAmC,EACnC,OAAe,EACf,SAAmB,EACnB,YAAuC;QALvC,aAAQ,GAAR,QAAQ,CAAS;QACjB,gBAAW,GAAX,WAAW,CAAyB;QACpC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,YAAO,GAAP,OAAO,CAAQ;QACf,cAAS,GAAT,SAAS,CAAU;QACnB,iBAAY,GAAZ,YAAY,CAA2B;QAnB5C,eAAU,GAAG,KAAK,CAAC;QAKlB,kCAA6B,GAAG,KAAK,CAAC;QAK7B,sBAAiB,GAA8D,EAAE,CAAC;QAClF,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAC;IASpD,CAAC;IAEG,eAAe;QAClB,IAAI,CAAC,gCAAgC,EAAE,CAAC;QAExC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YAChB,IAAI,CAAC,OAAO,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;SAC7F;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAEM,IAAI;QACP,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YAC9D,OAAO;SACV;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACzC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC;QAE9D,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAEM,IAAI;QACP,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC;QAEpC,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SAC1C;IACL,CAAC;IAEO,cAAc;QAClB,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,MAAM,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;iBAChD,gBAAqD,CAAC;YAE3D,aAAa;YACb,IAAI,CAAC,MAAM,IAAI,gBAAgB,CAAC,OAAO,YAAY,UAAU,EAAE;gBAC3D,OAAO,IAAI,CAAC,WAAW,CAAC;aAC3B;YAED,IAAI,CAAC,OAAO,EAAE,CAAC;SAClB;QAED,mFAAmF;QACnF,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ;aACzB,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC;aACrC,aAAa,CAAC;YACX;gBACI,OAAO,EAAE,QAAQ;gBACjB,OAAO,EAAE,QAAQ;gBACjB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,KAAK;gBACf,OAAO,EAAE,CAAC;aACb;SACJ,CAAC;aACD,sBAAsB,CAAC,KAAK,CAAC,CAAC;QAEnC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC9E,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,MAAM,CAAC,wBAAwB,CAAC,gBAAgB,EAAE;oBAClD,6DAA6D;oBAC7D,8CAA8C;oBAC9C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;iBACvC;aACJ;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;YACpC,gBAAgB,EAAE,QAAQ;SAC7B,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW;aACX,WAAW,EAAE;aACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aACrC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAErC;;;6EAGqE;QAErE,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAEO,OAAO;QACX,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,EAAE;YACpD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SAC7B;QAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC9B,CAAC;IAEO,cAAc;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;IAChC,CAAC;IAEO,gCAAgC;QACpC,0FAA0F;QAC1F,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE;YAC/B,OAAO;SACV;QAED,sFAAsF;QACtF,qFAAqF;QACrF,IAAI,IAAI,CAAC,4BAA4B,EAAE,EAAE;YACrC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBACxB,YAAY;gBACZ,GAAG,EAAE;oBACD,IAAI,CAAC,+BAA+B,EAAE,CAAC;oBACvC,IAAI,CAAC,IAAI,EAAE,CAAC;gBAChB,CAAC;aACJ,CAAC,CAAC;SACN;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC/C,CAAC;IAEO,+BAA+B;QACnC,IAAI,IAAI,CAAC,6BAA6B,EAAE;YACpC,OAAO;SACV;QACD,IAAI,CAAC,6BAA6B,GAAG,IAAI,CAAC;QAE1C,MAAM,aAAa,GAA8D,EAAE,CAAC;QACpF,IAAI,IAAI,CAAC,4BAA4B,EAAE,EAAE;YACrC,aAAa,CAAC,IAAI,CACd;gBACI,YAAY;gBACZ,KAAK,CAAC,EAAE;oBACJ,MAAM,SAAS,GAAI,KAAoB,CAAC,aAA4B,CAAC;oBACrE,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,cAAc,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;wBACrE,IAAI,CAAC,IAAI,EAAE,CAAC;qBACf;gBACL,CAAC;aACJ,CACJ,CAAC;SACL;QAED,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC;IAClD,CAAC;IAEO,4BAA4B;QAChC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;IAC1D,CAAC;IAEO,aAAa,CAAC,SAAoE;QACtF,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACP,CAAC;;kHAnLQ,qBAAqB;sGAArB,qBAAqB;2FAArB,qBAAqB;kBADjC,SAAS;mBAAC,EAAE,QAAQ,EAAE,gBAAgB,EAAE;0OAG9B,UAAU;sBADhB,KAAK;gBAIC,IAAI;sBADV,KAAK","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,
|
|
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
|
-
|
|
7931
|
-
|
|
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
|
-
|
|
7951
|
-
|
|
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
|
-
|
|
8132
|
+
this._overlayRef
|
|
7995
8133
|
.outsidePointerEvents()
|
|
7996
8134
|
.pipe(takeUntil(this.unsubscribeAll$))
|
|
7997
|
-
.subscribe(() => this._hintInstance
|
|
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
|