raain-ui 2.3.21 → 2.3.23
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/CHANGELOG.md +9 -0
- package/README.md +5 -56
- package/data/wind-markers.css +71 -536
- package/drawers/CartesianDrawer.js +2 -2
- package/drawers/PolarDrawer.js +3 -3
- package/factories/DynamicDateStatusElement.js +5 -6
- package/factories/MapElement.d.ts +19 -20
- package/factories/MapElement.js +52 -50
- package/layers/MarkersLayer.d.ts +3 -3
- package/layers/MarkersLayer.js +13 -12
- package/package.json +3 -3
- package/tools/RaainDivIcon.d.ts +130 -0
- package/tools/RaainDivIcon.js +243 -0
- package/tools/index.d.ts +1 -0
- package/tools/index.js +2 -1
- package/utils/spinning-ball-wrapper.js +2 -2
- package/data/wind-markers-test.css +0 -174
- package/data/wind-markers.v1.css +0 -260
- package/data/wind-markers.v2.css +0 -619
|
@@ -59,7 +59,7 @@ class CartesianDrawer {
|
|
|
59
59
|
const filteredValues = optimization.filteringValues(this.cartesianMapZoom(), this.geoValues, this.cartesianMap2Display);
|
|
60
60
|
for (const mapValue of filteredValues) {
|
|
61
61
|
if (done > optimization.hardLimit) {
|
|
62
|
-
console.warn('cartesian hard limit reached ', optimization.hardLimit);
|
|
62
|
+
console.warn('raain-ui >> cartesian hard limit reached ', optimization.hardLimit);
|
|
63
63
|
break;
|
|
64
64
|
}
|
|
65
65
|
const points = this.cartesianMap2Points(mapValue);
|
|
@@ -78,4 +78,4 @@ class CartesianDrawer {
|
|
|
78
78
|
}
|
|
79
79
|
}
|
|
80
80
|
exports.CartesianDrawer = CartesianDrawer;
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2FydGVzaWFuRHJhd2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2RyYXdlcnMvQ2FydGVzaWFuRHJhd2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFDQUE4QjtBQUU5QixvQ0FBZ0U7QUFDaEUsNkRBQXdEO0FBQ3hELCtFQUEwRTtBQUkxRSxNQUFhLGVBQWU7SUFReEIsWUFDWSxtQkFBNEUsRUFDNUUsb0JBQThELEVBQzlELGdCQUE4QixFQUM5QixJQUFZO1FBSFosd0JBQW1CLEdBQW5CLG1CQUFtQixDQUF5RDtRQUM1RSx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQTBDO1FBQzlELHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBYztRQUM5QixTQUFJLEdBQUosSUFBSSxDQUFRO1FBRXBCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxlQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxhQUFhLEdBQUcseURBQTJCLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDaEUsQ0FBQztJQUVNLFVBQVU7UUFDYixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQztJQUVNLGdCQUFnQixDQUNuQixLQUFhLEVBQ2IsS0FBYSxFQUNiLGFBQTRDO1FBRTVDLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO0lBQ3ZDLENBQUM7SUFFTSxlQUFlO1FBQ2xCLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDbEQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLEdBQUcsQ0FB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
|
package/drawers/PolarDrawer.js
CHANGED
|
@@ -65,7 +65,7 @@ class PolarDrawer {
|
|
|
65
65
|
x2: null,
|
|
66
66
|
};
|
|
67
67
|
if (distanceRatio <= 0) {
|
|
68
|
-
console.warn('polar distanceRatio is 0 - no sense ? ', center, centerPoint);
|
|
68
|
+
console.warn('raain-ui >> polar distanceRatio is 0 - no sense ? ', center, centerPoint);
|
|
69
69
|
return 0;
|
|
70
70
|
}
|
|
71
71
|
const optimization = this.getOptimization();
|
|
@@ -75,7 +75,7 @@ class PolarDrawer {
|
|
|
75
75
|
const filteredValues = optimization.filteringValues(this.polarMapZoom(), this.geoValues, this.polarMap2Display);
|
|
76
76
|
for (let [i, polarValue] of filteredValues.entries()) {
|
|
77
77
|
if (done > optimization.hardLimit) {
|
|
78
|
-
console.warn('polar hard limit reached ', optimization.hardLimit);
|
|
78
|
+
console.warn('raain-ui >> polar hard limit reached ', optimization.hardLimit);
|
|
79
79
|
break;
|
|
80
80
|
}
|
|
81
81
|
polarValue = tools_1.PolarMapValue.Duplicate(polarValue);
|
|
@@ -187,4 +187,4 @@ class PolarDrawer {
|
|
|
187
187
|
}
|
|
188
188
|
}
|
|
189
189
|
exports.PolarDrawer = PolarDrawer;
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PolarDrawer.js","sourceRoot":"","sources":["../../src/drawers/PolarDrawer.ts"],"names":[],"mappings":"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"}
|
|
@@ -29,7 +29,6 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
29
29
|
super(addSomeDebugInfos);
|
|
30
30
|
}
|
|
31
31
|
build(element, inputs) {
|
|
32
|
-
console.log('DynamicDateStatusElement.build');
|
|
33
32
|
this.element = element;
|
|
34
33
|
this.inputs = inputs;
|
|
35
34
|
this.fetchDataFn = this.inputs.fetchDataFn;
|
|
@@ -60,7 +59,7 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
60
59
|
}
|
|
61
60
|
catch (error) {
|
|
62
61
|
if (!document || !document['mocked']) {
|
|
63
|
-
console.error('Error fetching data and focus reset:', error);
|
|
62
|
+
console.error('raain-ui >> Error fetching data and focus reset:', error);
|
|
64
63
|
}
|
|
65
64
|
}
|
|
66
65
|
finally {
|
|
@@ -80,7 +79,7 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
80
79
|
await originalFocusNext();
|
|
81
80
|
}
|
|
82
81
|
catch (error) {
|
|
83
|
-
console.error('Error fetching data:', error);
|
|
82
|
+
console.error('raain-ui >> Error fetching data:', error);
|
|
84
83
|
// Handle error state
|
|
85
84
|
}
|
|
86
85
|
finally {
|
|
@@ -101,7 +100,7 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
101
100
|
await originalFocusPrevious();
|
|
102
101
|
}
|
|
103
102
|
catch (error) {
|
|
104
|
-
console.error('Error fetching data:', error);
|
|
103
|
+
console.error('raain-ui >> Error fetching data:', error);
|
|
105
104
|
// Handle error state
|
|
106
105
|
}
|
|
107
106
|
finally {
|
|
@@ -129,7 +128,7 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
129
128
|
await originalFocusClick(e);
|
|
130
129
|
}
|
|
131
130
|
catch (error) {
|
|
132
|
-
console.error('Error fetching data:', error);
|
|
131
|
+
console.error('raain-ui >> Error fetching data:', error);
|
|
133
132
|
// Handle error state
|
|
134
133
|
}
|
|
135
134
|
finally {
|
|
@@ -149,4 +148,4 @@ class DynamicDateStatusElement extends DateStatusElement_1.DateStatusElement {
|
|
|
149
148
|
}
|
|
150
149
|
}
|
|
151
150
|
exports.DynamicDateStatusElement = DynamicDateStatusElement;
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRHluYW1pY0RhdGVTdGF0dXNFbGVtZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZhY3Rvcmllcy9EeW5hbWljRGF0ZVN0YXR1c0VsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbUNBQWtDO0FBQ2xDLDJEQUF3RjtBQUN4Rix1REFBa0Q7QUFFbEQsTUFBYSw2QkFBOEIsU0FBUSwwQ0FBc0I7SUFDckUsWUFDVyxXQUE0RSxFQUM1RSxVQU9IO1FBQ0EsVUFBVSxFQUFFLENBQUM7UUFDYixTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUU7UUFDckIsVUFBVSxFQUFFLGlCQUFTLENBQUMsSUFBSTtRQUMxQixhQUFhLEVBQUUsQ0FBQztRQUNoQixhQUFhLEVBQUUsR0FBRztRQUNsQixXQUFXLEVBQUUsU0FBUztLQUN6Qjs7UUFFRCxLQUFLLENBQ0QsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFDLE1BQU0sRUFBRSxNQUFBLE9BQU8sQ0FBQyxVQUFVLG1DQUFJLENBQUMsRUFBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNyRCxLQUFLLEVBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3pCLEtBQUssRUFBRSxLQUFLO1lBQ1osTUFBTSxFQUFFLEVBQUU7U0FDYixDQUFDLENBQUMsRUFDSCxNQUFBLE9BQU8sQ0FBQyxTQUFTLG1DQUFJLElBQUksSUFBSSxFQUFFLEVBQy9CLE1BQUEsT0FBTyxDQUFDLFVBQVUsbUNBQUksaUJBQVMsQ0FBQyxJQUFJLEVBQ3BDLE9BQU8sQ0FBQyxhQUFhLEVBQ3JCLE9BQU8sQ0FBQyxhQUFhLENBQ3hCLENBQUM7UUEzQkssZ0JBQVcsR0FBWCxXQUFXLENBQWlFO1FBQzVFLFlBQU8sR0FBUCxPQUFPLENBY2I7SUFhTCxDQUFDO0NBQ0o7QUEvQkQsc0VBK0JDO0FBRUQsTUFBYSx3QkFBeUIsU0FBUSxxQ0FBaUI7SUFLM0QsWUFBWSxp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
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { MapLatLng } from '../tools';
|
|
1
|
+
import { Map, Marker } from 'leaflet';
|
|
2
|
+
import { MapLatLng, RaainDivIcon } from '../tools';
|
|
3
3
|
import { TimeframeContainers } from '../timeframes';
|
|
4
4
|
import { CompositeLayer, MarkersLayer } from '../layers';
|
|
5
5
|
export declare class MapElementInput {
|
|
6
6
|
timeframeContainers?: TimeframeContainers;
|
|
7
|
-
markers
|
|
7
|
+
markers: {
|
|
8
8
|
iconsLatLng: MapLatLng[];
|
|
9
|
-
|
|
9
|
+
raainDivIcon?: RaainDivIcon;
|
|
10
10
|
}[];
|
|
11
11
|
constructor(timeframeContainers?: TimeframeContainers, markers?: {
|
|
12
12
|
iconsLatLng: MapLatLng[];
|
|
13
|
-
|
|
13
|
+
raainDivIcon?: RaainDivIcon;
|
|
14
14
|
}[]);
|
|
15
15
|
}
|
|
16
16
|
export declare class MapElement {
|
|
@@ -38,23 +38,22 @@ export declare class MapElement {
|
|
|
38
38
|
updateMapTimeframe(timeframeContainers: TimeframeContainers): void;
|
|
39
39
|
updateMarkers(markers: {
|
|
40
40
|
iconsLatLng: MapLatLng[];
|
|
41
|
-
|
|
41
|
+
raainDivIcon?: RaainDivIcon;
|
|
42
42
|
}[]): Marker<any>[];
|
|
43
|
-
getMarkerElement(markerToFind: MapLatLng): Marker<any>;
|
|
44
43
|
/**
|
|
45
|
-
*
|
|
46
|
-
* @param marker The marker to
|
|
47
|
-
* @param
|
|
48
|
-
* @
|
|
49
|
-
*
|
|
50
|
-
* Examples:
|
|
51
|
-
* - changeMarkerStyle(marker, 'marker-red')
|
|
52
|
-
* - changeMarkerStyle(marker, 'marker-wind marker-wind-200', {strength: 10})
|
|
53
|
-
* - changeMarkerStyle(marker, {classes: 'marker-wind marker-wind-200', cssVars: {strength: 10}})
|
|
44
|
+
* Set rotation for a marker using RaainDivIcon
|
|
45
|
+
* @param marker The marker to rotate (MapLatLng)
|
|
46
|
+
* @param angle Rotation angle in degrees (0 = North, 90 = East, 180 = South, 270 = West)
|
|
47
|
+
* @returns true if rotation was applied, false if marker not found or not using RaainDivIcon
|
|
54
48
|
*/
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
49
|
+
setMarkerRotation(marker: MapLatLng, angle: number): boolean;
|
|
50
|
+
/**
|
|
51
|
+
* Get the rotation angle of a marker using RaainDivIcon
|
|
52
|
+
* @param marker The marker to query (MapLatLng)
|
|
53
|
+
* @returns The rotation angle in degrees, or null if not found or not using RaainDivIcon
|
|
54
|
+
*/
|
|
55
|
+
getMarkerRotation(marker: MapLatLng): number | null;
|
|
56
|
+
protected getMarkerElement(markerToFind: MapLatLng): Marker<any>;
|
|
57
|
+
protected onZoomEnd(event: any): void;
|
|
59
58
|
private addCompositeLayer;
|
|
60
59
|
}
|
package/factories/MapElement.js
CHANGED
|
@@ -5,7 +5,7 @@ const leaflet_1 = require("leaflet");
|
|
|
5
5
|
const tools_1 = require("../tools");
|
|
6
6
|
const layers_1 = require("../layers");
|
|
7
7
|
class MapElementInput {
|
|
8
|
-
constructor(timeframeContainers, markers) {
|
|
8
|
+
constructor(timeframeContainers, markers = []) {
|
|
9
9
|
this.timeframeContainers = timeframeContainers;
|
|
10
10
|
this.markers = markers;
|
|
11
11
|
}
|
|
@@ -36,6 +36,8 @@ class MapElement {
|
|
|
36
36
|
scrollWheelZoom: false,
|
|
37
37
|
renderer: (0, leaflet_1.canvas)(),
|
|
38
38
|
}).setView([this.center.lat, this.center.lng], 10);
|
|
39
|
+
// Hook into zoom events to preserve marker rotations
|
|
40
|
+
mapLeaflet.on('zoomend', this.onZoomEnd.bind(this));
|
|
39
41
|
(0, leaflet_1.tileLayer)('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
|
40
42
|
attribution: '©<a href="https://www.openstreetmap.org/copyright">osm</a>',
|
|
41
43
|
}).addTo(mapLeaflet);
|
|
@@ -49,16 +51,12 @@ class MapElement {
|
|
|
49
51
|
}
|
|
50
52
|
}
|
|
51
53
|
compositeLayer.addToMap(mapLeaflet);
|
|
52
|
-
// if (firstLayerIdPushed) {
|
|
53
|
-
// compositeLayer.showTheFistMatchingId(firstLayerIdPushed);
|
|
54
|
-
// }
|
|
55
54
|
compositeLayer.showAll(this.alpha);
|
|
56
55
|
// Markers
|
|
57
|
-
let markersProduced = [];
|
|
58
56
|
const markersLayer = new layers_1.MarkersLayer();
|
|
59
57
|
markersLayer.setCurrentWidth(width);
|
|
60
58
|
markersLayer.setCurrentHeight(height);
|
|
61
|
-
markersProduced = markersLayer.render(inputs.markers).markers;
|
|
59
|
+
const markersProduced = markersLayer.render(inputs.markers).markers;
|
|
62
60
|
markersLayer.addToMap(mapLeaflet);
|
|
63
61
|
mapLeaflet.invalidateSize({ animate: true });
|
|
64
62
|
this.mapLeaflet = mapLeaflet;
|
|
@@ -84,9 +82,45 @@ class MapElement {
|
|
|
84
82
|
this.mapLeaflet.invalidateSize({ animate: true });
|
|
85
83
|
}
|
|
86
84
|
updateMarkers(markers) {
|
|
87
|
-
|
|
85
|
+
const result = this.markersLayer.render(markers);
|
|
86
|
+
this.markersProduced = result.markers;
|
|
87
|
+
this.markersLayer.addToMap(this.mapLeaflet);
|
|
88
88
|
return this.markersProduced;
|
|
89
89
|
}
|
|
90
|
+
/**
|
|
91
|
+
* Set rotation for a marker using RaainDivIcon
|
|
92
|
+
* @param marker The marker to rotate (MapLatLng)
|
|
93
|
+
* @param angle Rotation angle in degrees (0 = North, 90 = East, 180 = South, 270 = West)
|
|
94
|
+
* @returns true if rotation was applied, false if marker not found or not using RaainDivIcon
|
|
95
|
+
*/
|
|
96
|
+
setMarkerRotation(marker, angle) {
|
|
97
|
+
const markerFound = this.getMarkerElement(marker);
|
|
98
|
+
if (!markerFound) {
|
|
99
|
+
return false;
|
|
100
|
+
}
|
|
101
|
+
const icon = markerFound.options.icon;
|
|
102
|
+
if (icon instanceof tools_1.RaainDivIcon) {
|
|
103
|
+
icon.setRotation(angle);
|
|
104
|
+
return true;
|
|
105
|
+
}
|
|
106
|
+
return false;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Get the rotation angle of a marker using RaainDivIcon
|
|
110
|
+
* @param marker The marker to query (MapLatLng)
|
|
111
|
+
* @returns The rotation angle in degrees, or null if not found or not using RaainDivIcon
|
|
112
|
+
*/
|
|
113
|
+
getMarkerRotation(marker) {
|
|
114
|
+
const markerFound = this.getMarkerElement(marker);
|
|
115
|
+
if (!markerFound) {
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
const icon = markerFound.options.icon;
|
|
119
|
+
if (icon instanceof tools_1.RaainDivIcon) {
|
|
120
|
+
return icon.getRotation();
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
90
124
|
getMarkerElement(markerToFind) {
|
|
91
125
|
var _a;
|
|
92
126
|
if (!((_a = this.markersProduced) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
@@ -99,50 +133,18 @@ class MapElement {
|
|
|
99
133
|
}
|
|
100
134
|
return founds[0];
|
|
101
135
|
}
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
* @param cssVars Optional object with CSS custom properties (e.g., {strength: 10})
|
|
107
|
-
*
|
|
108
|
-
* Examples:
|
|
109
|
-
* - changeMarkerStyle(marker, 'marker-red')
|
|
110
|
-
* - changeMarkerStyle(marker, 'marker-wind marker-wind-200', {strength: 10})
|
|
111
|
-
* - changeMarkerStyle(marker, {classes: 'marker-wind marker-wind-200', cssVars: {strength: 10}})
|
|
112
|
-
*/
|
|
113
|
-
changeMarkerStyle(marker, style, cssVars) {
|
|
114
|
-
const markerFound = this.getMarkerElement(marker);
|
|
115
|
-
if (!markerFound) {
|
|
116
|
-
return;
|
|
117
|
-
}
|
|
118
|
-
const element = markerFound.getElement();
|
|
119
|
-
if (!element) {
|
|
136
|
+
onZoomEnd(event) {
|
|
137
|
+
var _a;
|
|
138
|
+
// Re-apply rotation to all RaainDivIcon markers after zoom
|
|
139
|
+
if (!((_a = this.markersProduced) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
120
140
|
return;
|
|
121
141
|
}
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
classesToAdd = style.classes;
|
|
131
|
-
varsToSet = style.cssVars;
|
|
132
|
-
}
|
|
133
|
-
// Add CSS classes (space-separated)
|
|
134
|
-
if (classesToAdd) {
|
|
135
|
-
const classes = classesToAdd.split(' ').filter((c) => c.trim());
|
|
136
|
-
classes.forEach((className) => {
|
|
137
|
-
element.classList.add(className);
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
// Set CSS custom properties
|
|
141
|
-
if (varsToSet) {
|
|
142
|
-
Object.entries(varsToSet).forEach(([key, value]) => {
|
|
143
|
-
element.style.setProperty(`--${key}`, String(value));
|
|
144
|
-
});
|
|
145
|
-
}
|
|
142
|
+
this.markersProduced.forEach((marker) => {
|
|
143
|
+
const icon = marker.options.icon;
|
|
144
|
+
if (typeof icon.applyRotation === 'function') {
|
|
145
|
+
icon.applyRotation();
|
|
146
|
+
}
|
|
147
|
+
});
|
|
146
148
|
}
|
|
147
149
|
addCompositeLayer(mapLeaflet, compositeLayer, timeFrameContainer) {
|
|
148
150
|
const layerIds = [];
|
|
@@ -170,4 +172,4 @@ class MapElement {
|
|
|
170
172
|
}
|
|
171
173
|
}
|
|
172
174
|
exports.MapElement = MapElement;
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFwRWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mYWN0b3JpZXMvTWFwRWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBNEQ7QUFDNUQsb0NBQWlHO0FBRWpHLHNDQVFtQjtBQUVuQixNQUFhLGVBQWU7SUFDeEIsWUFDVyxtQkFBeUMsRUFDekMsVUFHRCxFQUFFO1FBSkQsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFzQjtRQUN6QyxZQUFPLEdBQVAsT0FBTyxDQUdOO0lBQ1QsQ0FBQztDQUNQO0FBUkQsMENBUUM7QUFFRCxNQUFhLFVBQVU7SUFPbkIsWUFDVyxTQUlLLEVBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFDLEVBQ2xCLG9CQUFvQixLQUFLO1FBTDVCLFdBQU0sR0FBTixNQUFNLENBSWU7UUFDbEIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFRO1FBUmhDLFVBQUssR0FBRyxDQUFDLENBQUM7UUFVYixNQUFNLEdBQUcsR0FBRyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxLQUFLLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDO1FBQzVGLE1BQU0sR0FBRyxHQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEtBQUssV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUM7UUFDckYsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLGlCQUFTLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFTSxLQUFLLENBQUMsT0FBb0IsRUFBRSxNQUF1Qjs7UUFDdEQsY0FBYztRQUNkLE1BQU0sS0FB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
|
package/layers/MarkersLayer.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { LayerGroup, Map, Marker } from 'leaflet';
|
|
2
2
|
import { IPixiLayer } from './IPixiLayer';
|
|
3
|
-
import { MapLatLng } from '../tools
|
|
3
|
+
import { MapLatLng, RaainDivIcon } from '../tools';
|
|
4
4
|
export declare class MarkersLayer implements IPixiLayer {
|
|
5
5
|
protected _layerGroup: LayerGroup;
|
|
6
6
|
protected _width: number;
|
|
@@ -12,7 +12,7 @@ export declare class MarkersLayer implements IPixiLayer {
|
|
|
12
12
|
setCurrentHeight(height: number): void;
|
|
13
13
|
render(markers: {
|
|
14
14
|
iconsLatLng: MapLatLng[];
|
|
15
|
-
|
|
15
|
+
raainDivIcon?: RaainDivIcon;
|
|
16
16
|
}[]): {
|
|
17
17
|
markers: Marker[];
|
|
18
18
|
};
|
package/layers/MarkersLayer.js
CHANGED
|
@@ -34,18 +34,12 @@ class MarkersLayer {
|
|
|
34
34
|
if (this._layerGroup) {
|
|
35
35
|
this._layerGroup.clearLayers();
|
|
36
36
|
}
|
|
37
|
-
if (!markers) {
|
|
38
|
-
return { markers: [] };
|
|
39
|
-
}
|
|
40
37
|
// Add markers
|
|
41
38
|
const ms = [];
|
|
42
39
|
let x;
|
|
43
40
|
let y;
|
|
44
41
|
for (const marker of markers) {
|
|
45
|
-
|
|
46
|
-
if (marker.iconOptions) {
|
|
47
|
-
iconOption = (0, leaflet_1.icon)(marker.iconOptions);
|
|
48
|
-
}
|
|
42
|
+
const raainDivIcon = marker.raainDivIcon;
|
|
49
43
|
for (const iconsLatLng of marker.iconsLatLng) {
|
|
50
44
|
x = iconsLatLng.lat;
|
|
51
45
|
y = iconsLatLng.lng;
|
|
@@ -54,14 +48,21 @@ class MarkersLayer {
|
|
|
54
48
|
title: iconsLatLng.name,
|
|
55
49
|
alt: iconsLatLng.id,
|
|
56
50
|
};
|
|
57
|
-
if (
|
|
58
|
-
options.icon =
|
|
51
|
+
if (raainDivIcon) {
|
|
52
|
+
options.icon = raainDivIcon;
|
|
53
|
+
}
|
|
54
|
+
const leafletMarkerInstance = (0, leaflet_1.marker)([x, y], options);
|
|
55
|
+
if (raainDivIcon) {
|
|
56
|
+
raainDivIcon.bindToMarker(leafletMarkerInstance);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
console.warn('raain-ui >> no raainDivIcon provided for this marker!');
|
|
59
60
|
}
|
|
60
|
-
ms.push(
|
|
61
|
+
ms.push(leafletMarkerInstance);
|
|
61
62
|
}
|
|
62
63
|
else {
|
|
63
64
|
// implement your own error handling
|
|
64
|
-
console.error('MARKER ERROR: ', iconsLatLng.id, 'x: ', x, ' y: ', y);
|
|
65
|
+
console.error('raain-ui >> MARKER ERROR: ', iconsLatLng.id, 'x: ', x, ' y: ', y);
|
|
65
66
|
}
|
|
66
67
|
}
|
|
67
68
|
}
|
|
@@ -70,4 +71,4 @@ class MarkersLayer {
|
|
|
70
71
|
}
|
|
71
72
|
}
|
|
72
73
|
exports.MarkersLayer = MarkersLayer;
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFya2Vyc0xheWVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xheWVycy9NYXJrZXJzTGF5ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUNBQW9HO0FBSXBHLE1BQWEsWUFBWTtJQUtyQjtRQUNJLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBQ2hCLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFFTSxRQUFRLENBQUMsR0FBUTtRQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNuQixPQUFPO1NBQ1Y7UUFFRCxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUU7WUFDakMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDbEM7SUFDTCxDQUFDO0lBRU0sYUFBYSxDQUFDLEdBQVE7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDbkIsT0FBTztTQUNWO1FBRUQsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUNoQyxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUNyQztJQUNMLENBQUM7SUFFTSxlQUFlLENBQUMsS0FBYTtRQUNoQyxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztJQUN4QixDQUFDO0lBRU0sZ0JBQWdCLENBQUMsTUFBYztRQUNsQyxJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUMxQixDQUFDO0lBRU0sTUFBTSxDQUFDLE9BQWtFO1FBRzVFLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNsQixJQUFJLENBQUMsV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ2xDO1FBRUQsY0FBYztRQUNkLE1BQU0sRUFBRSxHQUFhLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQVMsQ0FBQztRQUNkLElBQUksQ0FBUyxDQUFDO1FBQ2QsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUU7WUFDMUIsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQztZQUV6QyxLQUFLLE1BQU0sV0FBVyxJQUFJLE1BQU0sQ0FBQyxXQUFXLEVBQUU7Z0JBQzFDLENBQUMsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDO2dCQUNwQixDQUFDLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQztnQkFFcEIsSUFBSSxDQUFDLEtBQUssU0FBUyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxTQUFTLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUU7b0JBQzlELE1BQU0sT0FBTyxHQUFrQjt3QkFDM0IsS0FBSyxFQUFFLFdBQVcsQ0FBQyxJQUFJO3dCQUN2QixHQUFHLEVBQUUsV0FBVyxDQUFDLEVBQUU7cUJBQ3RCLENBQUM7b0JBRUYsSUFBSSxZQUFZLEVBQUU7d0JBQ2QsT0FBTyxDQUFDLElBQUksR0FBRyxZQUFZLENBQUM7cUJBQy9CO29CQUVELE1BQU0scUJBQXFCLEdBQUcsSUFBQSxnQkFBYSxFQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO29CQUU3RCxJQUFJLFlBQVksRUFBRTt3QkFDZCxZQUFZLENBQUMsWUFBWSxDQUFDLHFCQUFxQixDQUFDLENBQUM7cUJBQ3BEO3lCQUFNO3dCQUNILE9BQU8sQ0FBQyxJQUFJLENBQUMsdURBQXVELENBQUMsQ0FBQztxQkFDekU7b0JBRUQsRUFBRSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2lCQUNsQztxQkFBTTtvQkFDSCxvQ0FBb0M7b0JBQ3BDLE9BQU8sQ0FBQyxLQUFLLENBQ1QsNEJBQTRCLEVBQzVCLFdBQVcsQ0FBQyxFQUFFLEVBQ2QsS0FBSyxFQUNMLENBQUMsRUFDRCxNQUFNLEVBQ04sQ0FBQyxDQUNKLENBQUM7aUJBQ0w7YUFDSjtTQUNKO1FBRUQsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFBLG9CQUFVLEVBQUMsRUFBRSxDQUFDLENBQUM7UUFDbEMsT0FBTyxFQUFDLE9BQU8sRUFBRSxFQUFFLEVBQUMsQ0FBQztJQUN6QixDQUFDO0NBQ0o7QUE3RkQsb0NBNkZDIn0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "raain-ui",
|
|
3
|
-
"version": "2.3.
|
|
3
|
+
"version": "2.3.23",
|
|
4
4
|
"author": "contact@raain.io",
|
|
5
5
|
"homepage": "https://github.com/raainio/raain-ui",
|
|
6
6
|
"description": "raain.io ui layers",
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
"geolib": "~3.3.4",
|
|
36
36
|
"leaflet": "~1.9.4",
|
|
37
37
|
"pixi.js": "~5.3.12",
|
|
38
|
-
"raain-model": "~3.
|
|
38
|
+
"raain-model": "~3.1.1",
|
|
39
39
|
"satellite-view": "~2.1.2",
|
|
40
40
|
"spinning-ball": "~0.5.0",
|
|
41
41
|
"tile-setter": "~0.1.12",
|
|
@@ -69,4 +69,4 @@
|
|
|
69
69
|
"ts-node": "~8.3.0",
|
|
70
70
|
"typescript": "~4.8.4"
|
|
71
71
|
}
|
|
72
|
-
}
|
|
72
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { DivIcon, DivIconOptions, Marker } from 'leaflet';
|
|
2
|
+
/**
|
|
3
|
+
* Extended DivIconOptions to include rotation and dynamic sizing properties
|
|
4
|
+
*/
|
|
5
|
+
export interface RaainDivIconOptions extends DivIconOptions {
|
|
6
|
+
/**
|
|
7
|
+
* Initial rotation angle in degrees (0 = North, 90 = East, 180 = South, 270 = West)
|
|
8
|
+
*/
|
|
9
|
+
rotationAngle?: number;
|
|
10
|
+
/**
|
|
11
|
+
* CSS transform-origin for rotation (default: 'center center')
|
|
12
|
+
*/
|
|
13
|
+
rotationOrigin?: string;
|
|
14
|
+
/**
|
|
15
|
+
* Dynamic width in pixels (overrides iconSize width if provided)
|
|
16
|
+
*/
|
|
17
|
+
width?: number;
|
|
18
|
+
/**
|
|
19
|
+
* Dynamic height in pixels (overrides iconSize height if provided)
|
|
20
|
+
*/
|
|
21
|
+
height?: number;
|
|
22
|
+
/**
|
|
23
|
+
* Base HTML template - can include {width} and {height} placeholders for dynamic sizing
|
|
24
|
+
*/
|
|
25
|
+
htmlTemplate?: string;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* A DivIcon with built-in rotation and dynamic sizing support
|
|
29
|
+
*
|
|
30
|
+
* Usage:
|
|
31
|
+
* ```typescript
|
|
32
|
+
* // Basic usage with rotation
|
|
33
|
+
* const icon = new RaainDivIcon({
|
|
34
|
+
* html: '<div style="width: 30px; height: 30px; background: red;"></div>',
|
|
35
|
+
* rotationAngle: 0,
|
|
36
|
+
* className: 'my-custom-marker'
|
|
37
|
+
* });
|
|
38
|
+
*
|
|
39
|
+
* // With dynamic sizing (for wind speed visualization)
|
|
40
|
+
* const windIcon = new RaainDivIcon({
|
|
41
|
+
* htmlTemplate: `<div style="width: {width}px; height: {height}px; background: blue;"></div>`,
|
|
42
|
+
* width: 40,
|
|
43
|
+
* height: 40,
|
|
44
|
+
* rotationAngle: 45
|
|
45
|
+
* });
|
|
46
|
+
*
|
|
47
|
+
* const marker = L.marker([51.505, -0.09], { icon: windIcon }).addTo(map);
|
|
48
|
+
*
|
|
49
|
+
* // Update rotation dynamically
|
|
50
|
+
* windIcon.setRotation(90);
|
|
51
|
+
*
|
|
52
|
+
* // Update size dynamically (e.g., based on wind speed)
|
|
53
|
+
* windIcon.setSize(60, 60);
|
|
54
|
+
*
|
|
55
|
+
* // Update both size and rotation
|
|
56
|
+
* windIcon.update({ width: 50, height: 50, rotationAngle: 180 });
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
export declare class RaainDivIcon extends DivIcon {
|
|
60
|
+
options: RaainDivIconOptions;
|
|
61
|
+
private _icon;
|
|
62
|
+
private _marker;
|
|
63
|
+
constructor(options: RaainDivIconOptions);
|
|
64
|
+
/**
|
|
65
|
+
* Process size options and generate HTML from template if needed
|
|
66
|
+
*/
|
|
67
|
+
private static _processSizeOptions;
|
|
68
|
+
/**
|
|
69
|
+
* Override createIcon to store reference and apply initial rotation
|
|
70
|
+
*/
|
|
71
|
+
createIcon(oldIcon?: HTMLElement): HTMLElement;
|
|
72
|
+
/**
|
|
73
|
+
* Set the rotation angle in degrees
|
|
74
|
+
* @param angle Rotation angle (0 = North, 90 = East, 180 = South, 270 = West)
|
|
75
|
+
*/
|
|
76
|
+
setRotation(angle: number): this;
|
|
77
|
+
/**
|
|
78
|
+
* Get the current rotation angle
|
|
79
|
+
*/
|
|
80
|
+
getRotation(): number;
|
|
81
|
+
/**
|
|
82
|
+
* Set the size (width and height) of the icon dynamically
|
|
83
|
+
* @param width New width in pixels
|
|
84
|
+
* @param height New height in pixels
|
|
85
|
+
*/
|
|
86
|
+
setSize(width: number, height: number): this;
|
|
87
|
+
/**
|
|
88
|
+
* Get the current size
|
|
89
|
+
*/
|
|
90
|
+
getSize(): {
|
|
91
|
+
width: number;
|
|
92
|
+
height: number;
|
|
93
|
+
};
|
|
94
|
+
/**
|
|
95
|
+
* Update multiple properties at once (size, rotation)
|
|
96
|
+
* @param updates Object with properties to update
|
|
97
|
+
*/
|
|
98
|
+
update(updates: {
|
|
99
|
+
width?: number;
|
|
100
|
+
height?: number;
|
|
101
|
+
rotationAngle?: number;
|
|
102
|
+
}): this;
|
|
103
|
+
/**
|
|
104
|
+
* Set the transform origin for rotation
|
|
105
|
+
* @param origin CSS transform-origin value (e.g., 'center center', '50% 50%')
|
|
106
|
+
*/
|
|
107
|
+
setRotationOrigin(origin: string): this;
|
|
108
|
+
/**
|
|
109
|
+
* Apply the current rotation to the icon element
|
|
110
|
+
* This preserves any existing translate3d transformations from Leaflet
|
|
111
|
+
*/
|
|
112
|
+
applyRotation(): this;
|
|
113
|
+
/**
|
|
114
|
+
* Bind this icon to a marker for automatic rotation updates
|
|
115
|
+
* @param marker The Leaflet marker to bind to
|
|
116
|
+
*/
|
|
117
|
+
bindToMarker(marker: Marker): this;
|
|
118
|
+
/**
|
|
119
|
+
* Unbind from the current marker
|
|
120
|
+
*/
|
|
121
|
+
unbindFromMarker(): this;
|
|
122
|
+
/**
|
|
123
|
+
* Get the icon HTML element (if created)
|
|
124
|
+
*/
|
|
125
|
+
getIconElement(): HTMLElement | null;
|
|
126
|
+
/**
|
|
127
|
+
* Internal method to update the icon's size
|
|
128
|
+
*/
|
|
129
|
+
private _updateSize;
|
|
130
|
+
}
|