@agorapulse/ui-components 13.1.9 → 13.2.1
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/agorapulse-ui-components-13.2.1.tgz +0 -0
- package/esm2020/src/lib/labels/label-list.component.mjs +25 -7
- package/esm2020/src/lib/labels/label.component.mjs +10 -4
- package/esm2020/src/lib/labels-selector/labels-selector.component.mjs +1 -1
- package/esm2020/src/lib/text-measurement/text-measurement.service.mjs +3 -3
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.component.mjs +6 -6
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.directive.mjs +47 -18
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.model.mjs +1 -1
- package/esm2020/src/lib/tooltip-neo/tooltip-neo.service.mjs +2 -2
- package/fesm2015/agorapulse-ui-components.mjs +88 -35
- package/fesm2015/agorapulse-ui-components.mjs.map +1 -1
- package/fesm2020/agorapulse-ui-components.mjs +88 -35
- package/fesm2020/agorapulse-ui-components.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/labels/label-list.component.d.ts +21 -4
- package/src/lib/labels/label.component.d.ts +9 -2
- package/src/lib/tooltip-neo/tooltip-neo.component.d.ts +4 -4
- package/src/lib/tooltip-neo/tooltip-neo.directive.d.ts +9 -3
- package/src/lib/tooltip-neo/tooltip-neo.model.d.ts +1 -1
- package/src/lib/tooltip-neo/tooltip-neo.service.d.ts +1 -1
- package/agorapulse-ui-components-13.1.9.tgz +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Directive, HostListener, Input, } from '@angular/core';
|
|
2
2
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
-
import { fromEvent,
|
|
3
|
+
import { fromEvent, of, Subject } from 'rxjs';
|
|
4
4
|
import { delay, switchMap, takeUntil } from 'rxjs/operators';
|
|
5
5
|
import { tooltipNeoPositions } from './tooltip-neo.const';
|
|
6
6
|
import { TooltipNeoComponent } from './tooltip-neo.component';
|
|
@@ -14,9 +14,8 @@ export class TooltipNeoDirective {
|
|
|
14
14
|
this.overlayPositionBuilder = overlayPositionBuilder;
|
|
15
15
|
this.tooltipNeoService = tooltipNeoService;
|
|
16
16
|
this.destroy$ = new Subject();
|
|
17
|
-
this.
|
|
17
|
+
this.display$ = new Subject();
|
|
18
18
|
this.mouseEntered = false;
|
|
19
|
-
this.show$ = new Subject();
|
|
20
19
|
}
|
|
21
20
|
static enableTooltip(content, contentType, display) {
|
|
22
21
|
return !!content && !!contentType && !!display;
|
|
@@ -24,17 +23,32 @@ export class TooltipNeoDirective {
|
|
|
24
23
|
ngOnChanges(changes) {
|
|
25
24
|
if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {
|
|
26
25
|
this.setSettings();
|
|
27
|
-
this.
|
|
26
|
+
this.display$.next(this.allowDisplay);
|
|
28
27
|
}
|
|
29
28
|
}
|
|
30
29
|
ngOnInit() {
|
|
31
30
|
this.initiateTooltip();
|
|
32
31
|
}
|
|
33
32
|
ngOnDestroy() {
|
|
34
|
-
this.
|
|
33
|
+
this.dispose();
|
|
35
34
|
this.destroy$.next();
|
|
36
35
|
this.destroy$.complete();
|
|
37
36
|
}
|
|
37
|
+
/**
|
|
38
|
+
* To fix issue on inbox virtual scroller, it's a manual cleaner at DOM level
|
|
39
|
+
* It checks the route and also the DOM element where it's called
|
|
40
|
+
* @private
|
|
41
|
+
*/
|
|
42
|
+
cleanUpPersistentTooltip() {
|
|
43
|
+
if (window.location.href.includes('inbox') && this.elementRef.nativeElement.parentElement.className.includes('item-button-actions')) {
|
|
44
|
+
const tooltips = document.getElementsByTagName('ap-tooltip-neo');
|
|
45
|
+
if (tooltips) {
|
|
46
|
+
Array.from(tooltips).forEach(tooltip => {
|
|
47
|
+
tooltip.parentElement.parentElement.remove();
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
38
52
|
setSettings() {
|
|
39
53
|
if (typeof this.apTooltipNeo === 'object') {
|
|
40
54
|
const { content, backgroundColor = '#ffffff', borderColor, contentType = 'text', display = true, displayArrow = true, maxWidth = 'full', position = 'top', title = '' } = this.apTooltipNeo;
|
|
@@ -51,12 +65,12 @@ export class TooltipNeoDirective {
|
|
|
51
65
|
const maxWidth = 'full';
|
|
52
66
|
const position = 'top';
|
|
53
67
|
const title = '';
|
|
54
|
-
this.params = { content, backgroundColor, borderColor, contentType,
|
|
68
|
+
this.params = { content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title };
|
|
55
69
|
this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);
|
|
56
70
|
}
|
|
57
71
|
}
|
|
58
72
|
initiateTooltip() {
|
|
59
|
-
|
|
73
|
+
this.display$
|
|
60
74
|
.pipe(switchMap(bool => {
|
|
61
75
|
if (!bool) {
|
|
62
76
|
return of(bool);
|
|
@@ -66,7 +80,8 @@ export class TooltipNeoDirective {
|
|
|
66
80
|
.subscribe(bool => {
|
|
67
81
|
if (bool) {
|
|
68
82
|
this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')
|
|
69
|
-
.subscribe(() => this.
|
|
83
|
+
.subscribe(() => this.dispose());
|
|
84
|
+
this.cleanUpPersistentTooltip();
|
|
70
85
|
const positionStrategy = this.overlayPositionBuilder
|
|
71
86
|
.flexibleConnectedTo(this.elementRef)
|
|
72
87
|
.withPositions([tooltipNeoPositions[this.params.position]]);
|
|
@@ -76,29 +91,40 @@ export class TooltipNeoDirective {
|
|
|
76
91
|
tooltipRef.instance.params = this.params;
|
|
77
92
|
}
|
|
78
93
|
else {
|
|
79
|
-
this.
|
|
94
|
+
this.dispose();
|
|
80
95
|
}
|
|
81
96
|
});
|
|
82
|
-
this.tooltipNeoService.
|
|
97
|
+
this.tooltipNeoService.dispose$
|
|
83
98
|
.pipe(takeUntil(this.destroy$))
|
|
84
|
-
.subscribe(() =>
|
|
99
|
+
.subscribe(() => {
|
|
100
|
+
this.display$.next(false);
|
|
101
|
+
});
|
|
85
102
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
103
|
+
dispose() {
|
|
104
|
+
if (this.overlayRef) {
|
|
105
|
+
this.overlayRef.dispose();
|
|
106
|
+
}
|
|
107
|
+
if (this.elementRefMouseLeave$) {
|
|
108
|
+
this.elementRefMouseLeave$.unsubscribe();
|
|
109
|
+
}
|
|
89
110
|
}
|
|
90
111
|
onMouseEnter() {
|
|
91
112
|
this.setSettings();
|
|
92
113
|
this.mouseEntered = true;
|
|
93
|
-
this.allowDisplay && this.params
|
|
114
|
+
if (this.allowDisplay && this.params) {
|
|
115
|
+
this.display$.next(true);
|
|
116
|
+
}
|
|
94
117
|
}
|
|
95
118
|
onMouseLeave() {
|
|
96
119
|
this.mouseEntered = false;
|
|
97
|
-
this.
|
|
120
|
+
this.display$.next(false);
|
|
121
|
+
}
|
|
122
|
+
onClick() {
|
|
123
|
+
this.display$.next(false);
|
|
98
124
|
}
|
|
99
125
|
}
|
|
100
126
|
/** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, deps: [{ token: i0.ElementRef }, { token: i1.Overlay }, { token: i1.OverlayPositionBuilder }, { token: i2.TooltipNeoService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
101
|
-
/** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, usesOnChanges: true, ngImport: i0 });
|
|
127
|
+
/** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
|
|
102
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, decorators: [{
|
|
103
129
|
type: Directive,
|
|
104
130
|
args: [{ selector: '[apTooltipNeo]' }]
|
|
@@ -110,5 +136,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
110
136
|
}], onMouseLeave: [{
|
|
111
137
|
type: HostListener,
|
|
112
138
|
args: ['mouseleave']
|
|
139
|
+
}], onClick: [{
|
|
140
|
+
type: HostListener,
|
|
141
|
+
args: ['click']
|
|
113
142
|
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-neo.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/tooltip-neo/tooltip-neo.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Input, OnChanges,\n    OnDestroy,\n    OnInit, SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport {ComponentPortal} from '@angular/cdk/portal';\nimport {Overlay, OverlayPositionBuilder, OverlayRef} from '@angular/cdk/overlay';\nimport {fromEvent, merge, of, Subject, Subscription} from 'rxjs';\nimport {delay, switchMap, takeUntil} from 'rxjs/operators';\nimport {tooltipNeoPositions} from './tooltip-neo.const';\nimport {TooltipNeoParams} from './tooltip-neo.model';\nimport {TooltipNeoService} from './tooltip-neo.service';\nimport {TooltipNeoComponent} from './tooltip-neo.component';\n\n@Directive({selector: '[apTooltipNeo]'})\nexport class TooltipNeoDirective implements OnInit, OnDestroy, OnChanges {\n    @Input() apTooltipNeo: string | TooltipNeoParams;\n\n    private allowDisplay: boolean;\n    private destroy$: Subject<void> = new Subject<void>();\n    private hide$: Subject<boolean> = new Subject<boolean>();\n    private mouseEntered = false;\n    private overlayRef: OverlayRef;\n    private params: TooltipNeoParams;\n    private show$: Subject<boolean> = new Subject<boolean>();\n    private elementRefMouseLeave$: Subscription;\n\n    static enableTooltip(content: string | TemplateRef<any>, contentType: string, display: boolean): boolean {\n        return !!content && !!contentType && !!display;\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private tooltipNeoService: TooltipNeoService,\n    ) {\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {\n            this.setSettings();\n            this.allowDisplay ? this.show$.next(true) : this.hide$.next(false);\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateTooltip();\n    }\n\n    ngOnDestroy(): void {\n        this.detach();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private setSettings(): void {\n        if (typeof this.apTooltipNeo === 'object') {\n            const {\n                content,\n                backgroundColor = '#ffffff',\n                borderColor,\n                contentType = 'text',\n                display = true,\n                displayArrow = true,\n                maxWidth = 'full',\n                position = 'top',\n                title = ''\n            } = this.apTooltipNeo as TooltipNeoParams;\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n        if (typeof this.apTooltipNeo === 'string') {\n            const content = this.apTooltipNeo as string;\n            const backgroundColor = '#ffffff';\n            const borderColor = undefined;\n            const contentType = 'text';\n            const display = true;\n            const displayArrow = true;\n            const maxWidth = 'full';\n            const position = 'top';\n            const title = '';\n            this.params = {content, backgroundColor, borderColor, contentType, position, display, displayArrow, title, maxWidth};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n    }\n\n    private initiateTooltip(): void {\n        merge(this.hide$, this.show$)\n            .pipe(\n                switchMap(bool => {\n                    if (!bool) {\n                        return of(bool);\n                    }\n                    return of(bool).pipe(delay(200));\n                }),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(bool => {\n                if (bool) {\n                    this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')\n                        .subscribe(() => this.detach());\n                    const positionStrategy = this.overlayPositionBuilder\n                        .flexibleConnectedTo(this.elementRef)\n                        .withPositions([tooltipNeoPositions[this.params.position]]);\n                    const scrollStrategy = this.overlay.scrollStrategies.close();\n                    this.overlayRef = this.overlay.create({positionStrategy, scrollStrategy});\n                    const tooltipRef: ComponentRef<TooltipNeoComponent> = this.overlayRef.attach(new ComponentPortal(TooltipNeoComponent));\n                    tooltipRef.instance.params = this.params;\n                } else {\n                    this.detach();\n                }\n            });\n        this.tooltipNeoService.clickOutside$\n            .pipe(\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => this.hide$.next(false));\n    }\n\n    private detach(): void {\n        this.overlayRef && this.overlayRef.hasAttached() && this.overlayRef.detach();\n        this.elementRefMouseLeave$ && this.elementRefMouseLeave$.unsubscribe();\n    }\n\n    @HostListener('mouseenter')\n    onMouseEnter(): void {\n        this.setSettings();\n        this.mouseEntered = true;\n        this.allowDisplay && this.params && this.show$.next(true);\n    }\n\n    @HostListener('mouseleave')\n    onMouseLeave(): void {\n        this.mouseEntered = false;\n        this.hide$.next(false);\n    }\n}\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-neo.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/tooltip-neo/tooltip-neo.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Input, OnChanges,\n    OnDestroy,\n    OnInit, SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport {ComponentPortal} from '@angular/cdk/portal';\nimport {Overlay, OverlayPositionBuilder, OverlayRef} from '@angular/cdk/overlay';\nimport {fromEvent, of, Subject, Subscription} from 'rxjs';\nimport {delay, switchMap, takeUntil} from 'rxjs/operators';\nimport {tooltipNeoPositions} from './tooltip-neo.const';\nimport {TooltipNeoParams} from './tooltip-neo.model';\nimport {TooltipNeoService} from './tooltip-neo.service';\nimport {TooltipNeoComponent} from './tooltip-neo.component';\n\n@Directive({selector: '[apTooltipNeo]'})\nexport class TooltipNeoDirective implements OnInit, OnDestroy, OnChanges {\n\n    @Input() apTooltipNeo: string | TooltipNeoParams;\n\n    private allowDisplay: boolean;\n    private destroy$: Subject<void> = new Subject<void>();\n    private display$: Subject<boolean> = new Subject<boolean>();\n    private mouseEntered = false;\n    private overlayRef: OverlayRef;\n    private params: TooltipNeoParams;\n    private elementRefMouseLeave$: Subscription;\n\n    static enableTooltip(content: string | TemplateRef<any>, contentType: string, display: boolean): boolean {\n        return !!content && !!contentType && !!display;\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private tooltipNeoService: TooltipNeoService,\n    ) {\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {\n            this.setSettings();\n            this.display$.next(this.allowDisplay);\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateTooltip();\n    }\n\n    ngOnDestroy(): void {\n        this.dispose();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    /**\n     * To fix issue on inbox virtual scroller, it's a manual cleaner at DOM level\n     * It checks the route and also the DOM element where it's called\n     * @private\n     */\n    private cleanUpPersistentTooltip(): void {\n        if (window.location.href.includes('inbox') && this.elementRef.nativeElement.parentElement.className.includes('item-button-actions')) {\n            const tooltips = document.getElementsByTagName('ap-tooltip-neo');\n            if (tooltips) {\n                Array.from(tooltips).forEach(tooltip => {\n                    tooltip.parentElement.parentElement.remove();\n                });\n            }\n        }\n    }\n\n    private setSettings(): void {\n        if (typeof this.apTooltipNeo === 'object') {\n            const {\n                content,\n                backgroundColor = '#ffffff',\n                borderColor,\n                contentType = 'text',\n                display = true,\n                displayArrow = true,\n                maxWidth = 'full',\n                position = 'top',\n                title = ''\n            } = this.apTooltipNeo as TooltipNeoParams;\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n        if (typeof this.apTooltipNeo === 'string') {\n            const content = this.apTooltipNeo as string;\n            const backgroundColor = '#ffffff';\n            const borderColor = undefined;\n            const contentType = 'text';\n            const display = true;\n            const displayArrow = true;\n            const maxWidth = 'full';\n            const position = 'top';\n            const title = '';\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n    }\n\n    private initiateTooltip(): void {\n        this.display$\n            .pipe(\n                switchMap(bool => {\n                    if (!bool) {\n                        return of(bool);\n                    }\n                    return of(bool).pipe(delay(200));\n                }),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(bool => {\n                if (bool) {\n                    this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')\n                        .subscribe(() => this.dispose());\n                    this.cleanUpPersistentTooltip();\n                    const positionStrategy = this.overlayPositionBuilder\n                        .flexibleConnectedTo(this.elementRef)\n                        .withPositions([tooltipNeoPositions[this.params.position]]);\n                    const scrollStrategy = this.overlay.scrollStrategies.close();\n                    this.overlayRef = this.overlay.create({positionStrategy, scrollStrategy});\n                    const tooltipRef: ComponentRef<TooltipNeoComponent> = this.overlayRef.attach(new ComponentPortal(TooltipNeoComponent));\n                    tooltipRef.instance.params = this.params;\n                } else {\n                    this.dispose();\n                }\n            });\n        this.tooltipNeoService.dispose$\n            .pipe(\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.display$.next(false);\n            });\n    }\n\n    private dispose(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        if (this.elementRefMouseLeave$) {\n            this.elementRefMouseLeave$.unsubscribe();\n        }\n    }\n\n    @HostListener('mouseenter')\n    onMouseEnter(): void {\n        this.setSettings();\n        this.mouseEntered = true;\n        if (this.allowDisplay && this.params) {\n            this.display$.next(true);\n        }\n    }\n\n    @HostListener('mouseleave')\n    onMouseLeave(): void {\n        this.mouseEntered = false;\n        this.display$.next(false);\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        this.display$.next(false);\n    }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi90b29sdGlwLW5lby90b29sdGlwLW5lby5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVG9vbHRpcE5lb1BhcmFtcyB7XG4gICAgY29udGVudDogc3RyaW5nIHwgVGVtcGxhdGVSZWY8YW55PjtcbiAgICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gICAgYm9yZGVyQ29sb3I/OiBzdHJpbmc7XG4gICAgY29udGVudFR5cGU/OiAndGV4dCcgfCAndGVtcGxhdGUnO1xuICAgIGRpc3BsYXk/OiBib29sZWFuO1xuICAgIGRpc3BsYXlBcnJvdz86IGJvb2xlYW47XG4gICAgbWF4V2lkdGg/OiAnbWVkaXVtJyB8ICdmdWxsJztcbiAgICBwb3NpdGlvbj86ICd0b3BMZWZ0JyB8ICd0b3AnIHwgJ3RvcFJpZ2h0JyB8ICdsZWZ0JyB8ICdyaWdodCcgfCAnYm90dG9tTGVmdCcgfCAnYm90dG9tJyB8ICdib3R0b21SaWdodCc7XG4gICAgdGl0bGU/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -3,7 +3,7 @@ import { Subject } from 'rxjs';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class TooltipNeoService {
|
|
5
5
|
constructor() {
|
|
6
|
-
this.
|
|
6
|
+
this.dispose$ = new Subject();
|
|
7
7
|
}
|
|
8
8
|
}
|
|
9
9
|
/** @nocollapse */ /** @nocollapse */ TooltipNeoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -14,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
14
14
|
providedIn: 'root'
|
|
15
15
|
}]
|
|
16
16
|
}] });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9zcmMvbGliL3Rvb2x0aXAtbmVvL3Rvb2x0aXAtbmVvLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUs3QixNQUFNLE9BQU8saUJBQWlCO0lBSDlCO1FBSVcsYUFBUSxHQUFrQixJQUFJLE9BQU8sRUFBUSxDQUFDO0tBQ3hEOztvSkFGWSxpQkFBaUI7d0pBQWpCLGlCQUFpQixjQUZkLE1BQU07MkZBRVQsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFRvb2x0aXBOZW9TZXJ2aWNlIHtcbiAgICBwdWJsaWMgZGlzcG9zZSQ6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdDx2b2lkPigpO1xufVxuIl19
|