@provoly/dashboard 1.4.0 → 1.4.2
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/esm2022/lib/core/store/search/search.service.mjs +10 -4
- package/esm2022/widgets/widget-map/component/widget-map.component.mjs +3 -3
- package/esm2022/widgets/widget-map/interaction/tooltip-manager.class.mjs +51 -54
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +52 -55
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +9 -3
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/package.json +1 -1
- package/styles/components/_m-tooltip.scss +0 -6
- package/widgets/widget-map/interaction/tooltip-manager.class.d.ts +4 -2
|
@@ -5,8 +5,10 @@ import { TOOLTIP_PADDING } from '../component/widget-map.component';
|
|
|
5
5
|
export class TooltipManager {
|
|
6
6
|
constructor() {
|
|
7
7
|
this.classicFeatures$ = new BehaviorSubject([]);
|
|
8
|
-
this.tooltipIndex = 0;
|
|
9
8
|
this.tooltipNumber = 0;
|
|
9
|
+
this.tooltipDisplayedIndex$ = new BehaviorSubject(0);
|
|
10
|
+
this.previous = '-';
|
|
11
|
+
this.previousPromise = undefined;
|
|
10
12
|
}
|
|
11
13
|
init(tooltipFactoryService, injector, store, subscriptions, widgetSize$, displayHeader$, map, popup, popupContent, interactionManager, parent) {
|
|
12
14
|
this.tooltipFactoryService = tooltipFactoryService;
|
|
@@ -18,11 +20,10 @@ export class TooltipManager {
|
|
|
18
20
|
this.popup = popup;
|
|
19
21
|
this.interactionManager = interactionManager;
|
|
20
22
|
this.wmsFeatures$ = this.store.select(DashboardSelectors.wmsFeatures(this.parent.id));
|
|
21
|
-
subscriptions.add(combineLatest([this.wmsFeatures$, this.classicFeatures$])
|
|
23
|
+
subscriptions.add(combineLatest([this.wmsFeatures$, this.classicFeatures$, this.tooltipDisplayedIndex$])
|
|
22
24
|
.pipe(debounceTime(50), withLatestFrom(widgetSize$, displayHeader$))
|
|
23
|
-
.subscribe(([[wmsFeatures, classicFeatures], size, header]) => {
|
|
25
|
+
.subscribe(([[wmsFeatures, classicFeatures, tooltipIndex], size, header]) => {
|
|
24
26
|
if (map) {
|
|
25
|
-
this.tooltipIndex = 0;
|
|
26
27
|
if (this.popupOverlay !== null) {
|
|
27
28
|
this.clearTooltip();
|
|
28
29
|
}
|
|
@@ -32,17 +33,10 @@ export class TooltipManager {
|
|
|
32
33
|
});
|
|
33
34
|
this.map.addOverlay(this.popupOverlay);
|
|
34
35
|
this.popupContent.clear();
|
|
35
|
-
const
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
classicFeatures.forEach((value) => {
|
|
40
|
-
componentPromises.push(this.generateTooltip(value.values));
|
|
41
|
-
});
|
|
42
|
-
Promise.all(componentPromises).then((promises) => {
|
|
43
|
-
const realComponents = promises.filter((component) => !!component);
|
|
44
|
-
this.tooltipNumber = realComponents.length;
|
|
45
|
-
if (realComponents.length <= 0) {
|
|
36
|
+
const allTooltipValues = [...wmsFeatures, ...classicFeatures.map((cf) => cf.values)];
|
|
37
|
+
this.generateTooltip(allTooltipValues[tooltipIndex]).then((component) => {
|
|
38
|
+
this.tooltipNumber = allTooltipValues.length;
|
|
39
|
+
if (!component) {
|
|
46
40
|
popup.nativeElement.hidden = true;
|
|
47
41
|
this.popupOverlay?.setPosition([-9999999999, -9999999999]);
|
|
48
42
|
}
|
|
@@ -53,17 +47,17 @@ export class TooltipManager {
|
|
|
53
47
|
height: 200 + (header ? WIDGET_HEADER_HEIGHT.value : 0) + TOOLTIP_PADDING,
|
|
54
48
|
width: 300 + TOOLTIP_PADDING
|
|
55
49
|
};
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
pixel[0]
|
|
50
|
+
if (!this.calculatedTooltipPosition) {
|
|
51
|
+
let pixel = this.tooltipEvent?.pixel;
|
|
52
|
+
if (!!pixel && pixel[0] + rect.width > size.width) {
|
|
53
|
+
pixel[0] = size.width - rect.width;
|
|
54
|
+
}
|
|
55
|
+
if (!!pixel && pixel[1] + rect.height > size.height) {
|
|
56
|
+
pixel[1] = size.height - rect.height;
|
|
57
|
+
}
|
|
58
|
+
this.calculatedTooltipPosition = this.map.getCoordinateFromPixel(pixel ?? [0, 0]);
|
|
59
59
|
}
|
|
60
|
-
|
|
61
|
-
pixel[1] = size.height - rect.height;
|
|
62
|
-
}
|
|
63
|
-
setTimeout(() => {
|
|
64
|
-
this.tooltipMove(0);
|
|
65
|
-
}, 10);
|
|
66
|
-
this.popupOverlay?.setPosition(this.map.getCoordinateFromPixel(pixel ?? [0, 0]));
|
|
60
|
+
this.popupOverlay?.setPosition(this.calculatedTooltipPosition);
|
|
67
61
|
}
|
|
68
62
|
});
|
|
69
63
|
}
|
|
@@ -98,6 +92,7 @@ export class TooltipManager {
|
|
|
98
92
|
this.getFeatureFromServer(wmsLayers, event.coordinate);
|
|
99
93
|
}
|
|
100
94
|
this.tooltipEvent = event;
|
|
95
|
+
this.calculatedTooltipPosition = undefined;
|
|
101
96
|
};
|
|
102
97
|
if (this.parent.optionsCopy.tooltipMode !== TooltipMode.NONE) {
|
|
103
98
|
this.parent.map.un('singleclick', popupListener);
|
|
@@ -105,21 +100,33 @@ export class TooltipManager {
|
|
|
105
100
|
}
|
|
106
101
|
}
|
|
107
102
|
generateTooltip(value) {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
103
|
+
if (value) {
|
|
104
|
+
if (this.previous !== JSON.stringify(value)) {
|
|
105
|
+
this.previous = JSON.stringify(value);
|
|
106
|
+
this.previousPromise = new Promise((resolve) => {
|
|
107
|
+
const component$ = this.tooltipFactoryService.generateTooltip(value.oClass, this.injector, this.popupContent);
|
|
108
|
+
this.previousTooltipSub?.unsubscribe();
|
|
109
|
+
this.previousTooltipSub = component$.subscribe((component) => {
|
|
110
|
+
if (component) {
|
|
111
|
+
if (this.previousTooltip) {
|
|
112
|
+
this.previousTooltip.destroy();
|
|
113
|
+
}
|
|
114
|
+
component.instance.data.item = value;
|
|
115
|
+
component.instance.popup = this.popup;
|
|
116
|
+
resolve(component);
|
|
117
|
+
}
|
|
118
|
+
resolve(null);
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
return this.previousPromise;
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
return this.previousPromise;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
return Promise.resolve(null);
|
|
129
|
+
}
|
|
123
130
|
}
|
|
124
131
|
clearTooltip(empty = false) {
|
|
125
132
|
if (this.popupOverlay)
|
|
@@ -134,22 +141,12 @@ export class TooltipManager {
|
|
|
134
141
|
}
|
|
135
142
|
tooltipMove(number) {
|
|
136
143
|
if (this.tooltipCanMove(number)) {
|
|
137
|
-
this.
|
|
138
|
-
this.tooltipIndex = this.tooltipIndex + number;
|
|
139
|
-
this.setStyleAsync(this.tooltipIndex, 'block');
|
|
144
|
+
this.tooltipDisplayedIndex$.next(this.tooltipDisplayedIndex$.getValue() + number);
|
|
140
145
|
}
|
|
141
146
|
}
|
|
142
|
-
setStyleAsync(idx, value) {
|
|
143
|
-
setTimeout(() => {
|
|
144
|
-
const targetContainer = this.popupContent.get(idx);
|
|
145
|
-
if (targetContainer) {
|
|
146
|
-
// @ts-ignore
|
|
147
|
-
targetContainer.rootNodes[0].style.display = value;
|
|
148
|
-
}
|
|
149
|
-
}, 100);
|
|
150
|
-
}
|
|
151
147
|
tooltipCanMove(number) {
|
|
152
|
-
return this.
|
|
148
|
+
return (this.tooltipDisplayedIndex$.getValue() + number >= 0 &&
|
|
149
|
+
this.tooltipDisplayedIndex$.getValue() + number < this.tooltipNumber);
|
|
153
150
|
}
|
|
154
151
|
getFeatureFromServer(wmsLayers, pixel) {
|
|
155
152
|
for (const layer of wmsLayers) {
|
|
@@ -188,4 +185,4 @@ export class TooltipManager {
|
|
|
188
185
|
this.previousTooltip?.destroy();
|
|
189
186
|
}
|
|
190
187
|
}
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-manager.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/interaction/tooltip-manager.class.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,gBAAgB,EAChB,kBAAkB,EAIlB,WAAW,EACX,oBAAoB,EACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,YAAY,EAA4B,cAAc,EAAE,MAAM,MAAM,CAAC;AAC9G,OAAO,EAAE,OAAO,EAAwB,OAAO,EAAE,MAAM,IAAI,CAAC;AAE5D,OAAO,EAAE,eAAe,EAAsB,MAAM,mCAAmC,CAAC;AAIxF,MAAM,OAAO,cAAc;IAA3B;QAKE,qBAAgB,GAAyB,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QAC1D,iBAAY,GAAG,CAAC,CAAC;QAKjB,kBAAa,GAAG,CAAC,CAAC;IAkO3B,CAAC;IA1NC,IAAI,CACF,qBAA4C,EAC5C,QAAkB,EAClB,KAAY,EACZ,aAA2B,EAC3B,WAA6B,EAC7B,cAA8D,EAC9D,GAAQ,EACR,KAAiB,EACjB,YAA8B,EAC9B,kBAAsC,EACtC,MAA0B;QAE1B,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAEtF,aAAa,CAAC,GAAG,CACf,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtD,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;aACnE,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE;YAC5D,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;gBACtB,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE,CAAC;oBAC/B,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,CAAC;gBACD,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAAC;oBAC9B,OAAO,EAAE,KAAK,CAAC,aAAa;oBAC5B,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;iBACf,CAAC,CAAC;gBACH,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACvC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;gBAC1B,MAAM,iBAAiB,GAAG,EAA0D,CAAC;gBACrF,WAAW,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;oBAC5B,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;gBACtD,CAAC,CAAC,CAAC;gBACH,eAAe,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBACrC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC7D,CAAC,CAAC,CAAC;gBAEH,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE;oBAC/C,MAAM,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;oBACnE,IAAI,CAAC,aAAa,GAAG,cAAc,CAAC,MAAM,CAAC;oBAC3C,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;wBAC/B,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC;wBAClC,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;oBAC7D,CAAC;yBAAM,CAAC;wBACN,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,KAAK,CAAC;wBACnC,4BAA4B;wBAC5B,MAAM,IAAI,GAAG;4BACX,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,eAAe;4BACzE,KAAK,EAAE,GAAG,GAAG,eAAe;yBAC7B,CAAC;wBACF,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC;wBACrC,IAAI,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;4BAClD,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;wBACrC,CAAC;wBACD,IAAI,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;4BACpD,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;wBACvC,CAAC;wBACD,UAAU,CAAC,GAAG,EAAE;4BACd,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;wBACtB,CAAC,EAAE,EAAE,CAAC,CAAC;wBACP,IAAI,CAAC,YAAY,EAAE,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,sBAAsB,CAAC,KAAK,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;oBACnF,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CACL,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,GAAG,EAAE;YACnD,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAE/B,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,uBAAuB;QAC7B,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAClC,IAAI,CAAC,uBAAuB,GAAG,IAAI,OAAO,CAAC;gBACzC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;gBACjC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACf,CAAC,CAAC;YACH,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QACpD,CAAC;QAED,MAAM,aAAa,GAAG,CAAC,KAAkC,EAAE,EAAE;YAC3D,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC;YAC7E,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;iBAC9F,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;iBAC3D,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBACf,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,QAAQ,CAAC;gBAC5B,WAAW,EAAE,KAAK,CAAC,UAAU;gBAC7B,MAAM,EACJ,KAAK,YAAY,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS;aAC9G,CAAC,CAAC;iBACF,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACnC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;YAC7C,IAAI,SAAS,EAAE,CAAC;gBACd,IAAI,CAAC,oBAAoB,CAAC,SAAS,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;YACzD,CAAC;YACD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC5B,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,KAAK,WAAW,CAAC,IAAI,EAAE,CAAC;YAC7D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YACjD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;IAED,eAAe,CAAC,KAIf;QACC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC7B,MAAM,UAAU,GAAG,IAAI,CAAC,qBAAqB,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;YAC9G,IAAI,CAAC,kBAAkB,EAAE,WAAW,EAAE,CAAC;YACvC,IAAI,CAAC,kBAAkB,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;gBAC3D,IAAI,SAAS,EAAE,CAAC;oBACd,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;wBACzB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;oBACjC,CAAC;oBACD,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;oBACrC,SAAS,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;oBACtC,OAAO,CAAC,SAAS,CAAC,CAAC;gBACrB,CAAC;gBACD,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,YAAY,CAAC,KAAK,GAAG,KAAK;QAC/B,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAClE,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,CAAC;QAChC,IAAI,CAAC,kBAAkB,EAAE,WAAW,EAAE,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YACxF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAEM,WAAW,CAAC,MAAc;QAC/B,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;YAC9C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;YAC/C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAEO,aAAa,CAAC,GAAW,EAAE,KAAa;QAC9C,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACnD,IAAI,eAAe,EAAE,CAAC;gBACpB,aAAa;gBACb,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;YACrD,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEM,cAAc,CAAC,MAAc;QAClC,OAAO,IAAI,CAAC,YAAY,GAAG,MAAM,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,GAAG,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;IAC5F,CAAC;IAED,oBAAoB,CAAC,SAAuB,EAAE,KAAY;QACxD,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE,CAAC;YAC9B,IAAI,GAAG,GAAG,KAAK;iBACZ,SAAS,EAAE;iBACX,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,aAAa,EAAE,EAAE;gBAChG,WAAW,EAAE,kBAAkB;gBAC/B,aAAa,EAAE,EAAE;gBACjB,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC,oCAAoC,CAAC;aAC/D,CAAC,CAAC;YACL,IAEI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;gBACzC,OAAO,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,aAAa,EAAE,CAAC,OAAO,CAAC,CAAC;YACpD,CAAC,CACF,EAAE,yBAAyB,EAC5B,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,mCAAmC,CAAC;oBACnD,GAAG;oBACH,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE;oBAC7C,WAAW,EAAE,KAAK;oBAClB,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE;iBAC5B,CAAC,CACH,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;oBACpE,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,cAAc,CAAC;wBAC9B,GAAG;wBACH,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE;wBAC7C,WAAW,EAAE,KAAK;wBAClB,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE;qBAC5B,CAAC,CACH,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACxF,IAAI,CAAC,kBAAkB,EAAE,WAAW,EAAE,CAAC;QACvC,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,CAAC;IAClC,CAAC;CACF","sourcesContent":["import { Pixel } from 'ol/pixel';\nimport { ComponentRef, ElementRef, Injector, ViewContainerRef } from '@angular/core';\nimport {\n  BaseTooltipComponent,\n  DashboardActions,\n  DashboardSelectors,\n  MapGeoServerLayerOptions,\n  Size,\n  TooltipFactoryService,\n  TooltipMode,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, debounceTime, Observable, Subscription, withLatestFrom } from 'rxjs';\nimport { Feature, Map, MapBrowserEvent, Overlay } from 'ol';\nimport { Store } from '@ngrx/store';\nimport { TOOLTIP_PADDING, WidgetMapComponent } from '../component/widget-map.component';\nimport { InteractionManager } from './interaction-manager.class';\nimport { Layer } from 'ol/layer';\n\nexport class TooltipManager {\n  private tooltipFactoryService!: TooltipFactoryService;\n  private injector!: Injector;\n  private store!: Store;\n  wmsFeatures$!: Observable<any[]>;\n  classicFeatures$: BehaviorSubject<any> = new BehaviorSubject([]);\n  public tooltipIndex = 0;\n  popupOverlay?: Overlay;\n  map!: Map;\n  popup!: ElementRef;\n  popupContent!: ViewContainerRef;\n  public tooltipNumber = 0;\n  interactionManager!: InteractionManager;\n  previousTooltip?: ComponentRef<BaseTooltipComponent>;\n  previousTooltipSub?: Subscription;\n  public tooltipEvent?: MapBrowserEvent<MouseEvent>;\n  parent!: WidgetMapComponent;\n  interactionPopupOverlay!: Overlay;\n\n  init(\n    tooltipFactoryService: TooltipFactoryService,\n    injector: Injector,\n    store: Store,\n    subscriptions: Subscription,\n    widgetSize$: Observable<Size>,\n    displayHeader$: Observable<boolean | { [p: string]: boolean }>,\n    map: Map,\n    popup: ElementRef,\n    popupContent: ViewContainerRef,\n    interactionManager: InteractionManager,\n    parent: WidgetMapComponent\n  ) {\n    this.tooltipFactoryService = tooltipFactoryService;\n    this.injector = injector;\n    this.store = store;\n    this.parent = parent;\n    this.map = map;\n    this.popupContent = popupContent;\n    this.popup = popup;\n    this.interactionManager = interactionManager;\n    this.wmsFeatures$ = this.store.select(DashboardSelectors.wmsFeatures(this.parent.id));\n\n    subscriptions.add(\n      combineLatest([this.wmsFeatures$, this.classicFeatures$])\n        .pipe(debounceTime(50), withLatestFrom(widgetSize$, displayHeader$))\n        .subscribe(([[wmsFeatures, classicFeatures], size, header]) => {\n          if (map) {\n            this.tooltipIndex = 0;\n            if (this.popupOverlay !== null) {\n              this.clearTooltip();\n            }\n            this.popupOverlay = new Overlay({\n              element: popup.nativeElement,\n              offset: [9, 9]\n            });\n            this.map.addOverlay(this.popupOverlay);\n            this.popupContent.clear();\n            const componentPromises = [] as Promise<ComponentRef<BaseTooltipComponent> | null>[];\n            wmsFeatures.forEach((value) => {\n              componentPromises.push(this.generateTooltip(value));\n            });\n            classicFeatures.forEach((value: any) => {\n              componentPromises.push(this.generateTooltip(value.values));\n            });\n\n            Promise.all(componentPromises).then((promises) => {\n              const realComponents = promises.filter((component) => !!component);\n              this.tooltipNumber = realComponents.length;\n              if (realComponents.length <= 0) {\n                popup.nativeElement.hidden = true;\n                this.popupOverlay?.setPosition([-9999999999, -9999999999]);\n              } else {\n                popup.nativeElement.hidden = false;\n                // Do not go outside the map\n                const rect = {\n                  height: 200 + (header ? WIDGET_HEADER_HEIGHT.value : 0) + TOOLTIP_PADDING,\n                  width: 300 + TOOLTIP_PADDING\n                };\n                let pixel = this.tooltipEvent?.pixel;\n                if (!!pixel && pixel[0] + rect.width > size.width) {\n                  pixel[0] = size.width - rect.width;\n                }\n                if (!!pixel && pixel[1] + rect.height > size.height) {\n                  pixel[1] = size.height - rect.height;\n                }\n                setTimeout(() => {\n                  this.tooltipMove(0);\n                }, 10);\n                this.popupOverlay?.setPosition(this.map.getCoordinateFromPixel(pixel ?? [0, 0]));\n              }\n            });\n          }\n        })\n    );\n\n    window.addEventListener('forceCloseMapTooltip', () => {\n      this.clearTooltip();\n    });\n\n    this.addOverlayOnInteraction();\n\n    return this;\n  }\n\n  private addOverlayOnInteraction() {\n    if (!this.interactionPopupOverlay) {\n      this.interactionPopupOverlay = new Overlay({\n        element: this.popup.nativeElement,\n        offset: [9, 9]\n      });\n      this.map.addOverlay(this.interactionPopupOverlay);\n    }\n\n    const popupListener = (event: MapBrowserEvent<MouseEvent>) => {\n      const values = this.map.getFeaturesAtPixel(event.pixel, { hitTolerance: 5 });\n      const valuesToDisplay = [...new Set(values.map((value) => value.get('id')).filter((id) => !!id))]\n        .map((id) => values.find((value) => value.get('id') === id))\n        .map((value) => ({\n          oClass: value?.get('oClass'),\n          coordinates: event.coordinate,\n          values:\n            value instanceof Feature ? value.getKeys().reduce((p, c) => ({ ...p, [c]: value?.get(c) }), {}) : undefined\n        }))\n        .filter((value) => value.oClass);\n      this.classicFeatures$.next(valuesToDisplay);\n      const wmsLayers = this.parent.getWMSLayers();\n      if (wmsLayers) {\n        this.getFeatureFromServer(wmsLayers, event.coordinate);\n      }\n      this.tooltipEvent = event;\n    };\n\n    if (this.parent.optionsCopy.tooltipMode !== TooltipMode.NONE) {\n      this.parent.map.un('singleclick', popupListener);\n      this.parent.map.on('singleclick', popupListener);\n    }\n  }\n\n  generateTooltip(value: {\n    oClass: string;\n    coordinates: Pixel;\n    values: any;\n  }): Promise<ComponentRef<BaseTooltipComponent> | null> {\n    return new Promise((resolve) => {\n      const component$ = this.tooltipFactoryService.generateTooltip(value.oClass, this.injector, this.popupContent);\n      this.previousTooltipSub?.unsubscribe();\n      this.previousTooltipSub = component$.subscribe((component) => {\n        if (component) {\n          if (this.previousTooltip) {\n            this.previousTooltip.destroy();\n          }\n          component.instance.data.item = value;\n          component.instance.popup = this.popup;\n          resolve(component);\n        }\n        resolve(null);\n      });\n    });\n  }\n\n  public clearTooltip(empty = false) {\n    if (this.popupOverlay) this.map?.removeOverlay(this.popupOverlay);\n    this.popupContent?.clear();\n    this.previousTooltip?.destroy();\n    this.previousTooltipSub?.unsubscribe();\n    if (empty) {\n      this.store.dispatch(DashboardActions.resetWmsFeatures({ componentId: this.parent.id }));\n      this.classicFeatures$.next([]);\n    }\n  }\n\n  public tooltipMove(number: number) {\n    if (this.tooltipCanMove(number)) {\n      this.setStyleAsync(this.tooltipIndex, 'none');\n      this.tooltipIndex = this.tooltipIndex + number;\n      this.setStyleAsync(this.tooltipIndex, 'block');\n    }\n  }\n\n  private setStyleAsync(idx: number, value: string) {\n    setTimeout(() => {\n      const targetContainer = this.popupContent.get(idx);\n      if (targetContainer) {\n        // @ts-ignore\n        targetContainer.rootNodes[0].style.display = value;\n      }\n    }, 100);\n  }\n\n  public tooltipCanMove(number: number) {\n    return this.tooltipIndex + number >= 0 && this.tooltipIndex + number < this.tooltipNumber;\n  }\n\n  getFeatureFromServer(wmsLayers: Layer<any>[], pixel: Pixel) {\n    for (const layer of wmsLayers) {\n      let url = layer\n        .getSource()\n        .getFeatureInfoUrl(pixel, this.map.getView().getResolution(), this.map.getView().getProjection(), {\n          INFO_FORMAT: 'application/json',\n          FEATURE_COUNT: 10,\n          ...layer.getProperties()['getFeatureInfoAdditionalParameters']\n        });\n      if (\n        (\n          this.parent.optionsCopy.layers?.find((l) => {\n            return l.title === layer.getProperties()['title'];\n          }) as MapGeoServerLayerOptions\n        )?.getWfsFeaturesForTooltips\n      ) {\n        this.store.dispatch(\n          DashboardActions.getWfsFeaturesForPointStackTooltips({\n            url,\n            oClass: layer.getProperties()['oClass'] ?? '',\n            coordinates: pixel,\n            componentId: this.parent.id\n          })\n        );\n      } else {\n        if (url && url.indexOf('I=-1') === -1 && url.indexOf('J=-1') === -1) {\n          this.store.dispatch(\n            DashboardActions.getWmsFeatures({\n              url,\n              oClass: layer.getProperties()['oClass'] ?? '',\n              coordinates: pixel,\n              componentId: this.parent.id\n            })\n          );\n        }\n      }\n    }\n  }\n\n  destroy() {\n    this.store.dispatch(DashboardActions.resetWmsFeatures({ componentId: this.parent.id }));\n    this.previousTooltipSub?.unsubscribe();\n    this.previousTooltip?.destroy();\n  }\n}\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-manager.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/interaction/tooltip-manager.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pixel } from 'ol/pixel';\nimport { ComponentRef, ElementRef, Injector, ViewContainerRef } from '@angular/core';\nimport {\n  BaseTooltipComponent,\n  DashboardActions,\n  DashboardSelectors,\n  MapGeoServerLayerOptions,\n  Size,\n  TooltipFactoryService,\n  TooltipMode,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, debounceTime, Observable, Subscription, withLatestFrom } from 'rxjs';\nimport { Feature, Map, MapBrowserEvent, Overlay } from 'ol';\nimport { Store } from '@ngrx/store';\nimport { TOOLTIP_PADDING, WidgetMapComponent } from '../component/widget-map.component';\nimport { InteractionManager } from './interaction-manager.class';\nimport { Layer } from 'ol/layer';\nimport { Coordinate } from 'ol/coordinate';\n\nexport class TooltipManager {\n  private tooltipFactoryService!: TooltipFactoryService;\n  private injector!: Injector;\n  private store!: Store;\n  wmsFeatures$!: Observable<any[]>;\n  classicFeatures$: BehaviorSubject<any> = new BehaviorSubject([]);\n  popupOverlay?: Overlay;\n  map!: Map;\n  popup!: ElementRef;\n  popupContent!: ViewContainerRef;\n  public tooltipNumber = 0;\n  interactionManager!: InteractionManager;\n  previousTooltip?: ComponentRef<BaseTooltipComponent>;\n  previousTooltipSub?: Subscription;\n  public tooltipEvent?: MapBrowserEvent<MouseEvent>;\n  parent!: WidgetMapComponent;\n  interactionPopupOverlay!: Overlay;\n  tooltipDisplayedIndex$ = new BehaviorSubject(0);\n  private calculatedTooltipPosition?: Coordinate;\n\n  init(\n    tooltipFactoryService: TooltipFactoryService,\n    injector: Injector,\n    store: Store,\n    subscriptions: Subscription,\n    widgetSize$: Observable<Size>,\n    displayHeader$: Observable<boolean | { [p: string]: boolean }>,\n    map: Map,\n    popup: ElementRef,\n    popupContent: ViewContainerRef,\n    interactionManager: InteractionManager,\n    parent: WidgetMapComponent\n  ) {\n    this.tooltipFactoryService = tooltipFactoryService;\n    this.injector = injector;\n    this.store = store;\n    this.parent = parent;\n    this.map = map;\n    this.popupContent = popupContent;\n    this.popup = popup;\n    this.interactionManager = interactionManager;\n    this.wmsFeatures$ = this.store.select(DashboardSelectors.wmsFeatures(this.parent.id));\n\n    subscriptions.add(\n      combineLatest([this.wmsFeatures$, this.classicFeatures$, this.tooltipDisplayedIndex$])\n        .pipe(debounceTime(50), withLatestFrom(widgetSize$, displayHeader$))\n        .subscribe(([[wmsFeatures, classicFeatures, tooltipIndex], size, header]) => {\n          if (map) {\n            if (this.popupOverlay !== null) {\n              this.clearTooltip();\n            }\n            this.popupOverlay = new Overlay({\n              element: popup.nativeElement,\n              offset: [9, 9]\n            });\n            this.map.addOverlay(this.popupOverlay);\n            this.popupContent.clear();\n            const allTooltipValues = [...wmsFeatures, ...classicFeatures.map((cf: any) => cf.values)];\n\n            this.generateTooltip(allTooltipValues[tooltipIndex]).then((component) => {\n              this.tooltipNumber = allTooltipValues.length;\n              if (!component) {\n                popup.nativeElement.hidden = true;\n                this.popupOverlay?.setPosition([-9999999999, -9999999999]);\n              } else {\n                popup.nativeElement.hidden = false;\n                // Do not go outside the map\n                const rect = {\n                  height: 200 + (header ? WIDGET_HEADER_HEIGHT.value : 0) + TOOLTIP_PADDING,\n                  width: 300 + TOOLTIP_PADDING\n                };\n                if (!this.calculatedTooltipPosition) {\n                  let pixel = this.tooltipEvent?.pixel;\n                  if (!!pixel && pixel[0] + rect.width > size.width) {\n                    pixel[0] = size.width - rect.width;\n                  }\n                  if (!!pixel && pixel[1] + rect.height > size.height) {\n                    pixel[1] = size.height - rect.height;\n                  }\n                  this.calculatedTooltipPosition = this.map.getCoordinateFromPixel(pixel ?? [0, 0]);\n                }\n                this.popupOverlay?.setPosition(this.calculatedTooltipPosition);\n              }\n            });\n          }\n        })\n    );\n\n    window.addEventListener('forceCloseMapTooltip', () => {\n      this.clearTooltip();\n    });\n\n    this.addOverlayOnInteraction();\n\n    return this;\n  }\n\n  private addOverlayOnInteraction() {\n    if (!this.interactionPopupOverlay) {\n      this.interactionPopupOverlay = new Overlay({\n        element: this.popup.nativeElement,\n        offset: [9, 9]\n      });\n      this.map.addOverlay(this.interactionPopupOverlay);\n    }\n\n    const popupListener = (event: MapBrowserEvent<MouseEvent>) => {\n      const values = this.map.getFeaturesAtPixel(event.pixel, { hitTolerance: 5 });\n      const valuesToDisplay = [...new Set(values.map((value) => value.get('id')).filter((id) => !!id))]\n        .map((id) => values.find((value) => value.get('id') === id))\n        .map((value) => ({\n          oClass: value?.get('oClass'),\n          coordinates: event.coordinate,\n          values:\n            value instanceof Feature ? value.getKeys().reduce((p, c) => ({ ...p, [c]: value?.get(c) }), {}) : undefined\n        }))\n        .filter((value) => value.oClass);\n      this.classicFeatures$.next(valuesToDisplay);\n      const wmsLayers = this.parent.getWMSLayers();\n      if (wmsLayers) {\n        this.getFeatureFromServer(wmsLayers, event.coordinate);\n      }\n      this.tooltipEvent = event;\n      this.calculatedTooltipPosition = undefined;\n    };\n\n    if (this.parent.optionsCopy.tooltipMode !== TooltipMode.NONE) {\n      this.parent.map.un('singleclick', popupListener);\n      this.parent.map.on('singleclick', popupListener);\n    }\n  }\n\n  previous = '-';\n  previousPromise?: Promise<any> = undefined;\n\n  generateTooltip(value: {\n    oClass: string;\n    coordinates: Pixel;\n    values: any;\n  }): Promise<ComponentRef<BaseTooltipComponent> | null> {\n    if (value) {\n      if (this.previous !== JSON.stringify(value)) {\n        this.previous = JSON.stringify(value);\n        this.previousPromise = new Promise((resolve) => {\n          const component$ = this.tooltipFactoryService.generateTooltip(value.oClass, this.injector, this.popupContent);\n          this.previousTooltipSub?.unsubscribe();\n          this.previousTooltipSub = component$.subscribe((component) => {\n            if (component) {\n              if (this.previousTooltip) {\n                this.previousTooltip.destroy();\n              }\n              component.instance.data.item = value;\n              component.instance.popup = this.popup;\n              resolve(component);\n            }\n            resolve(null);\n          });\n        });\n        return this.previousPromise;\n      } else {\n        return this.previousPromise!;\n      }\n    } else {\n      return Promise.resolve(null);\n    }\n  }\n\n  public clearTooltip(empty = false) {\n    if (this.popupOverlay) this.map?.removeOverlay(this.popupOverlay);\n    this.popupContent?.clear();\n    this.previousTooltip?.destroy();\n    this.previousTooltipSub?.unsubscribe();\n    if (empty) {\n      this.store.dispatch(DashboardActions.resetWmsFeatures({ componentId: this.parent.id }));\n      this.classicFeatures$.next([]);\n    }\n  }\n\n  public tooltipMove(number: number) {\n    if (this.tooltipCanMove(number)) {\n      this.tooltipDisplayedIndex$.next(this.tooltipDisplayedIndex$.getValue() + number);\n    }\n  }\n\n  public tooltipCanMove(number: number) {\n    return (\n      this.tooltipDisplayedIndex$.getValue() + number >= 0 &&\n      this.tooltipDisplayedIndex$.getValue() + number < this.tooltipNumber\n    );\n  }\n\n  getFeatureFromServer(wmsLayers: Layer<any>[], pixel: Pixel) {\n    for (const layer of wmsLayers) {\n      let url = layer\n        .getSource()\n        .getFeatureInfoUrl(pixel, this.map.getView().getResolution(), this.map.getView().getProjection(), {\n          INFO_FORMAT: 'application/json',\n          FEATURE_COUNT: 10,\n          ...layer.getProperties()['getFeatureInfoAdditionalParameters']\n        });\n      if (\n        (\n          this.parent.optionsCopy.layers?.find((l) => {\n            return l.title === layer.getProperties()['title'];\n          }) as MapGeoServerLayerOptions\n        )?.getWfsFeaturesForTooltips\n      ) {\n        this.store.dispatch(\n          DashboardActions.getWfsFeaturesForPointStackTooltips({\n            url,\n            oClass: layer.getProperties()['oClass'] ?? '',\n            coordinates: pixel,\n            componentId: this.parent.id\n          })\n        );\n      } else {\n        if (url && url.indexOf('I=-1') === -1 && url.indexOf('J=-1') === -1) {\n          this.store.dispatch(\n            DashboardActions.getWmsFeatures({\n              url,\n              oClass: layer.getProperties()['oClass'] ?? '',\n              coordinates: pixel,\n              componentId: this.parent.id\n            })\n          );\n        }\n      }\n    }\n  }\n\n  destroy() {\n    this.store.dispatch(DashboardActions.resetWmsFeatures({ componentId: this.parent.id }));\n    this.previousTooltipSub?.unsubscribe();\n    this.previousTooltip?.destroy();\n  }\n}\n"]}
|