@mapcomponents/react-maplibre 0.1.14 → 0.1.15
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/.github/workflows/storybook.yml +4 -2
- package/coverage/clover.xml +325 -297
- package/coverage/coverage-final.json +8 -8
- package/coverage/lcov-report/index.html +63 -63
- package/coverage/lcov-report/src/components/MapLibreMap/MapLibreMap.js.html +1 -1
- package/coverage/lcov-report/src/components/MapLibreMap/index.html +1 -1
- package/coverage/lcov-report/src/components/MlCreatePdfButton/MlCreatePdfButton.js.html +1 -1
- package/coverage/lcov-report/src/components/MlCreatePdfButton/index.html +1 -1
- package/coverage/lcov-report/src/components/MlFeatureEditor/MlFeatureEditor.js.html +1 -1
- package/coverage/lcov-report/src/components/MlFeatureEditor/index.html +1 -1
- package/coverage/lcov-report/src/components/MlFillExtrusionLayer/MlFillExtrusionLayer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlFillExtrusionLayer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlFollowGps/MlFollowGps.js.html +37 -34
- package/coverage/lcov-report/src/components/MlFollowGps/index.html +11 -11
- package/coverage/lcov-report/src/components/MlGPXViewer/MlGPXViewer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlGPXViewer/gpxConverter.js.html +1 -1
- package/coverage/lcov-report/src/components/MlGPXViewer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlGeoJsonLayer/MlGeoJsonLayer.js.html +96 -30
- package/coverage/lcov-report/src/components/MlGeoJsonLayer/index.html +19 -19
- package/coverage/lcov-report/src/components/MlImageMarkerLayer/MlImageMarkerLayer.js.html +45 -150
- package/coverage/lcov-report/src/components/MlImageMarkerLayer/index.html +19 -19
- package/coverage/lcov-report/src/components/MlLayer/MlLayer.js.html +93 -27
- package/coverage/lcov-report/src/components/MlLayer/index.html +19 -19
- package/coverage/lcov-report/src/components/MlLayerMagnify/MlLayerMagnify.js.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerMagnify/index.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwipe/MlLayerSwipe.js.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwipe/index.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwitcher/MlLayerSwitcher.js.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwitcher/components/LayerBox.js.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwitcher/components/index.html +1 -1
- package/coverage/lcov-report/src/components/MlLayerSwitcher/index.html +1 -1
- package/coverage/lcov-report/src/components/MlMarker/MlMarker.js.html +1 -1
- package/coverage/lcov-report/src/components/MlMarker/index.html +1 -1
- package/coverage/lcov-report/src/components/MlNavigationCompass/MlNavigationCompass.js.html +1 -1
- package/coverage/lcov-report/src/components/MlNavigationCompass/index.html +1 -1
- package/coverage/lcov-report/src/components/MlNavigationTools/MlNavigationTools.js.html +10 -13
- package/coverage/lcov-report/src/components/MlNavigationTools/index.html +7 -7
- package/coverage/lcov-report/src/components/MlOsmLayer/MlOsmLayer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlOsmLayer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlScaleReference/MlScaleReference.js.html +1 -1
- package/coverage/lcov-report/src/components/MlScaleReference/index.html +1 -1
- package/coverage/lcov-report/src/components/MlShareMapState/MlShareMapState.js.html +208 -16
- package/coverage/lcov-report/src/components/MlShareMapState/index.html +9 -9
- package/coverage/lcov-report/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.js.html +1 -1
- package/coverage/lcov-report/src/components/MlSpatialElevationProfile/index.html +1 -1
- package/coverage/lcov-report/src/components/MlThreeJsLayer/MlThreeJsLayer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlThreeJsLayer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlUseMapDebugger/MlUseMapDebugger.js.html +1 -1
- package/coverage/lcov-report/src/components/MlUseMapDebugger/index.html +1 -1
- package/coverage/lcov-report/src/components/MlVectorTileLayer/MlVectorTileLayer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlVectorTileLayer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsFeatureInfoPopup/MlWmsFeatureInfoPopup.js.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsFeatureInfoPopup/index.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsLayer/MlWmsLayer.js.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsLayer/index.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsLoader/MlWmsLoader.js.html +1 -1
- package/coverage/lcov-report/src/components/MlWmsLoader/index.html +1 -1
- package/coverage/lcov-report/src/hooks/index.html +32 -32
- package/coverage/lcov-report/src/hooks/useMap.js.html +85 -163
- package/coverage/lcov-report/src/hooks/useMapState.js.html +82 -82
- package/coverage/lcov-report/src/hooks/useWms.js.html +1 -1
- package/coverage/lcov-report/src/i18n.js.html +1 -1
- package/coverage/lcov-report/src/index.html +1 -1
- package/coverage/lcov-report/src/translations/english.js.html +1 -1
- package/coverage/lcov-report/src/translations/german.js.html +1 -1
- package/coverage/lcov-report/src/translations/index.html +1 -1
- package/coverage/lcov.info +620 -570
- package/dist/index.esm.js +787 -665
- package/dist/index.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/components/MapLibreMap/lib/MapLibreGlWrapper.js +13 -12
- package/src/components/MlFollowGps/MlFollowGps.js +23 -22
- package/src/components/MlGeoJsonLayer/MlGeoJsonLayer.js +23 -1
- package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.js +21 -56
- package/src/components/MlLayer/MlLayer.js +26 -4
- package/src/components/MlNavigationTools/MlNavigationTools.js +4 -5
- package/src/components/MlShareMapState/MlShareMapState.js +73 -9
- package/src/components/MlShareMapState/MlShareMapState.stories.js +24 -1
- package/src/hooks/useMap.js +36 -62
- package/src/hooks/useMapState.js +3 -3
- package/src/index.js +2 -0
package/dist/index.esm.js
CHANGED
|
@@ -5,17 +5,17 @@ import maplibregl from 'maplibre-gl/dist/maplibre-gl';
|
|
|
5
5
|
import 'maplibre-gl/dist/maplibre-gl.css';
|
|
6
6
|
import { v4 } from 'uuid';
|
|
7
7
|
import Button from '@mui/material/Button';
|
|
8
|
+
import RoomIcon from '@mui/icons-material/Room';
|
|
9
|
+
import { lineString, length, lineChunk, point, circle, bbox, lineOffset, distance } from '@turf/turf';
|
|
8
10
|
import maplibregl$1, { Popup } from 'maplibre-gl';
|
|
9
11
|
import jsPDF from 'jspdf';
|
|
10
12
|
import PrinterIcon from '@mui/icons-material/Print';
|
|
11
|
-
import { lineString, length, lineChunk, point, bbox, lineOffset, distance } from '@turf/turf';
|
|
12
13
|
import ButtonGroup from '@mui/material/ButtonGroup';
|
|
13
14
|
import ControlPointIcon from '@mui/icons-material/ControlPoint';
|
|
14
15
|
import RemoveCircleOutlineIcon from '@mui/icons-material/RemoveCircleOutline';
|
|
15
16
|
import GpsFixedIcon from '@mui/icons-material/GpsFixed';
|
|
16
17
|
import _styled from '@emotion/styled/base';
|
|
17
18
|
import { css } from '@emotion/css';
|
|
18
|
-
import RoomIcon from '@mui/icons-material/Room';
|
|
19
19
|
import useMediaQuery from '@mui/material/useMediaQuery';
|
|
20
20
|
import '@mapbox/mapbox-gl-draw/dist/mapbox-gl-draw.css';
|
|
21
21
|
import MapboxDraw from '@mapbox/mapbox-gl-draw';
|
|
@@ -342,7 +342,7 @@ var MapLibreGlWrapper = function MapLibreGlWrapper(props) {
|
|
|
342
342
|
/**
|
|
343
343
|
* Array containing an object for each layer in the MapLibre instance providing information on visibility, loading state, order, paint & layout properties
|
|
344
344
|
*/
|
|
345
|
-
layerState:
|
|
345
|
+
layerState: [],
|
|
346
346
|
|
|
347
347
|
/**
|
|
348
348
|
* Maps layerIds to layerState in JSON string form for quick deep comparisons
|
|
@@ -1039,191 +1039,167 @@ MlFillExtrusionLayer.propTypes = {
|
|
|
1039
1039
|
insertBeforeLayer: PropTypes.string
|
|
1040
1040
|
};
|
|
1041
1041
|
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
state: ["state", "province", "state_code"]
|
|
1048
|
-
};
|
|
1042
|
+
/**
|
|
1043
|
+
* React hook that allows subscribing to map state changes
|
|
1044
|
+
*
|
|
1045
|
+
* @component
|
|
1046
|
+
*/
|
|
1049
1047
|
|
|
1050
|
-
|
|
1051
|
-
|
|
1048
|
+
function useMapState(props) {
|
|
1049
|
+
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
1050
|
+
var mapContext = useContext(MapContext);
|
|
1051
|
+
var initializedRef = useRef(false);
|
|
1052
|
+
var mapRef = useRef(undefined);
|
|
1052
1053
|
|
|
1053
|
-
|
|
1054
|
-
|
|
1055
|
-
|
|
1056
|
-
|
|
1057
|
-
return true;
|
|
1058
|
-
}
|
|
1054
|
+
var _useState = useState(undefined),
|
|
1055
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1056
|
+
center = _useState2[0],
|
|
1057
|
+
setCenter = _useState2[1];
|
|
1059
1058
|
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1059
|
+
var _useState3 = useState(undefined),
|
|
1060
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
1061
|
+
viewport = _useState4[0],
|
|
1062
|
+
setViewport = _useState4[1];
|
|
1063
1063
|
|
|
1064
|
-
|
|
1065
|
-
};
|
|
1064
|
+
var viewportRef = useRef(undefined);
|
|
1066
1065
|
|
|
1067
|
-
var
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
};
|
|
1066
|
+
var _useState5 = useState(undefined),
|
|
1067
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
1068
|
+
layers = _useState6[0],
|
|
1069
|
+
setLayers = _useState6[1];
|
|
1072
1070
|
|
|
1073
|
-
var
|
|
1074
|
-
setLoading(true);
|
|
1075
|
-
var width = 210;
|
|
1076
|
-
var height = 297; // Calculate pixel ratio
|
|
1071
|
+
var layersRef = useRef(undefined); //const mapRef = useRef(props.map);
|
|
1077
1072
|
|
|
1078
|
-
var
|
|
1073
|
+
var componentId = useRef(v4());
|
|
1074
|
+
/**
|
|
1075
|
+
* returns the element if it matches the defined filter criteria
|
|
1076
|
+
* to be used as filter function on the layers array
|
|
1077
|
+
*
|
|
1078
|
+
* @param {object} layer
|
|
1079
|
+
*/
|
|
1079
1080
|
|
|
1080
|
-
var
|
|
1081
|
-
|
|
1082
|
-
document.body.appendChild(hidden);
|
|
1083
|
-
var container = document.createElement("div");
|
|
1084
|
-
container.style.width = toPixels(width);
|
|
1085
|
-
container.style.height = toPixels(height);
|
|
1086
|
-
hidden.appendChild(container); //Render map
|
|
1081
|
+
var layerIdFilter = useCallback(function (layer) {
|
|
1082
|
+
var _props$filter, _props$filter2;
|
|
1087
1083
|
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
zoom: map.getZoom(),
|
|
1092
|
-
bearing: map.getBearing(),
|
|
1093
|
-
pitch: map.getPitch(),
|
|
1094
|
-
interactive: false,
|
|
1095
|
-
preserveDrawingBuffer: true,
|
|
1096
|
-
fadeDuration: 0,
|
|
1097
|
-
attributionControl: false
|
|
1098
|
-
});
|
|
1099
|
-
var style = map.getStyle();
|
|
1084
|
+
if (!(props !== null && props !== void 0 && (_props$filter = props.filter) !== null && _props$filter !== void 0 && _props$filter.includeBaseLayers) && layer.baseLayer) {
|
|
1085
|
+
return false;
|
|
1086
|
+
}
|
|
1100
1087
|
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
if (!src[key]) {
|
|
1107
|
-
delete src[key];
|
|
1088
|
+
if (typeof ((_props$filter2 = props.filter) === null || _props$filter2 === void 0 ? void 0 : _props$filter2.matchLayerIds) !== "undefined") {
|
|
1089
|
+
if (props.filter.matchLayerIds instanceof RegExp) {
|
|
1090
|
+
return props.filter.matchLayerIds.test(layer.id);
|
|
1091
|
+
} else {
|
|
1092
|
+
return layer.id.includes(props.filter.matchLayerIds);
|
|
1108
1093
|
}
|
|
1109
|
-
}
|
|
1110
|
-
};
|
|
1094
|
+
}
|
|
1111
1095
|
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1096
|
+
return true;
|
|
1097
|
+
}, [props.filter]);
|
|
1098
|
+
var refreshLayerState = useCallback(function () {
|
|
1099
|
+
var _layerState = mapRef.current.wrapper.layerState.filter(layerIdFilter);
|
|
1115
1100
|
|
|
1116
|
-
|
|
1117
|
-
renderMap.once("idle", function () {
|
|
1118
|
-
var _hidden$parentNode;
|
|
1101
|
+
var _layerStateString = JSON.stringify(_layerState);
|
|
1119
1102
|
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1103
|
+
if (layersRef.current !== _layerStateString) {
|
|
1104
|
+
layersRef.current = _layerStateString;
|
|
1105
|
+
setLayers(_layerState);
|
|
1106
|
+
}
|
|
1107
|
+
}, [layerIdFilter]);
|
|
1108
|
+
useEffect(function () {
|
|
1109
|
+
var _componentId = componentId.current;
|
|
1110
|
+
return function () {
|
|
1111
|
+
if (mapRef.current) {
|
|
1112
|
+
mapRef.current.cleanup(_componentId);
|
|
1113
|
+
mapRef.current = undefined;
|
|
1129
1114
|
}
|
|
1130
|
-
});
|
|
1131
|
-
var offsetX = 2.5;
|
|
1132
|
-
var offsetY = 2.5;
|
|
1133
|
-
var marginTop = 3;
|
|
1134
|
-
var marginBottom = 3;
|
|
1135
|
-
var innerMargin = 2;
|
|
1136
|
-
var logo = "data:image/png;base64,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";
|
|
1137
|
-
var textBuffer = 1;
|
|
1138
|
-
var lineHeight = 3.25;
|
|
1139
|
-
var text = locationValue ? nmConverter(locationValue.address) : "";
|
|
1140
|
-
var textChunksSeperator = text.split(",");
|
|
1141
|
-
var textChunks = [];
|
|
1142
1115
|
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
} //Render map image
|
|
1116
|
+
initializedRef.current = false;
|
|
1117
|
+
};
|
|
1118
|
+
}, []);
|
|
1119
|
+
useEffect(function () {
|
|
1120
|
+
var _props$watch, _props$watch2;
|
|
1149
1121
|
|
|
1122
|
+
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return; // the MapLibre-gl instance (mapContext.getMap(props.mapId)) is accessible here
|
|
1123
|
+
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1150
1124
|
|
|
1151
|
-
|
|
1125
|
+
initializedRef.current = true;
|
|
1126
|
+
mapRef.current = mapContext.getMap(props.mapId);
|
|
1127
|
+
/*
|
|
1128
|
+
mapRef.current.on(
|
|
1129
|
+
"move",
|
|
1130
|
+
() => {
|
|
1131
|
+
setCenter(mapRef.current.getCenter());
|
|
1132
|
+
},
|
|
1133
|
+
componentId.current
|
|
1134
|
+
);
|
|
1135
|
+
*/
|
|
1152
1136
|
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1137
|
+
if (props !== null && props !== void 0 && (_props$watch = props.watch) !== null && _props$watch !== void 0 && _props$watch.viewport) {
|
|
1138
|
+
setViewport(mapRef.current.wrapper.viewportState);
|
|
1139
|
+
mapRef.current.wrapper.on("viewportchange", function () {
|
|
1140
|
+
var _mapRef$current;
|
|
1156
1141
|
|
|
1157
|
-
|
|
1142
|
+
if (viewportRef.current !== ((_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 ? void 0 : _mapRef$current.wrapper.viewportStateString)) {
|
|
1143
|
+
var _mapRef$current2, _mapRef$current3, _mapRef$current3$wrap;
|
|
1158
1144
|
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1145
|
+
setViewport((_mapRef$current2 = mapRef.current) === null || _mapRef$current2 === void 0 ? void 0 : _mapRef$current2.wrapper.viewportState);
|
|
1146
|
+
setCenter((_mapRef$current3 = mapRef.current) === null || _mapRef$current3 === void 0 ? void 0 : (_mapRef$current3$wrap = _mapRef$current3.wrapper.viewportState) === null || _mapRef$current3$wrap === void 0 ? void 0 : _mapRef$current3$wrap.center);
|
|
1147
|
+
}
|
|
1148
|
+
}, componentId.current);
|
|
1149
|
+
}
|
|
1164
1150
|
|
|
1165
|
-
|
|
1166
|
-
|
|
1151
|
+
if (props !== null && props !== void 0 && (_props$watch2 = props.watch) !== null && _props$watch2 !== void 0 && _props$watch2.layers) {
|
|
1152
|
+
var _props$filter3, _props$filter4;
|
|
1167
1153
|
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1154
|
+
refreshLayerState();
|
|
1155
|
+
mapRef.current.wrapper.on("layerchange", refreshLayerState, {
|
|
1156
|
+
includeBaseLayers: props === null || props === void 0 ? void 0 : (_props$filter3 = props.filter) === null || _props$filter3 === void 0 ? void 0 : _props$filter3.includeBaseLayers,
|
|
1157
|
+
matchLayerIds: props === null || props === void 0 ? void 0 : (_props$filter4 = props.filter) === null || _props$filter4 === void 0 ? void 0 : _props$filter4.matchLayerIds
|
|
1158
|
+
}, componentId.current);
|
|
1159
|
+
}
|
|
1160
|
+
}, [mapContext.mapIds, mapContext, props.mapId, refreshLayerState]);
|
|
1161
|
+
return {
|
|
1162
|
+
layers: layers,
|
|
1163
|
+
viewport: viewport
|
|
1164
|
+
};
|
|
1165
|
+
}
|
|
1171
1166
|
|
|
1172
|
-
|
|
1167
|
+
useMapState.defaultProps = {
|
|
1168
|
+
mapId: undefined,
|
|
1169
|
+
watch: {
|
|
1170
|
+
layers: true,
|
|
1171
|
+
sources: false,
|
|
1172
|
+
viewport: false
|
|
1173
|
+
},
|
|
1174
|
+
filter: {
|
|
1175
|
+
includeBaseLayers: false
|
|
1176
|
+
}
|
|
1177
|
+
};
|
|
1178
|
+
useMapState.propTypes = {
|
|
1179
|
+
/**
|
|
1180
|
+
* Id of the target MapLibre instance in mapContext
|
|
1181
|
+
*/
|
|
1182
|
+
mapId: PropTypes.string,
|
|
1173
1183
|
|
|
1174
|
-
|
|
1175
|
-
|
|
1184
|
+
/**
|
|
1185
|
+
* Defines map Resources to watch
|
|
1186
|
+
*/
|
|
1187
|
+
watch: PropTypes.shape({
|
|
1188
|
+
layers: PropTypes.bool,
|
|
1189
|
+
sources: PropTypes.bool,
|
|
1190
|
+
viewport: PropTypes.bool
|
|
1191
|
+
}),
|
|
1176
1192
|
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
get: function get() {
|
|
1188
|
-
return actualPixelRatio;
|
|
1189
|
-
}
|
|
1190
|
-
});
|
|
1191
|
-
setLoading(false);
|
|
1192
|
-
});
|
|
1193
|
-
};
|
|
1194
|
-
|
|
1195
|
-
/**
|
|
1196
|
-
* Renders a button that will create a PDF version of the current map view (dimensions adjusted to fit Din A4 Paper).
|
|
1197
|
-
*
|
|
1198
|
-
* @component
|
|
1199
|
-
*/
|
|
1200
|
-
|
|
1201
|
-
var MlCreatePdfButton = function MlCreatePdfButton(props) {
|
|
1202
|
-
var mapContext = useContext(MapContext);
|
|
1203
|
-
var initializedRef = useRef(false);
|
|
1204
|
-
var mapRef = useRef(undefined);
|
|
1205
|
-
useEffect(function () {
|
|
1206
|
-
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
1207
|
-
initializedRef.current = true;
|
|
1208
|
-
mapRef.current = mapContext.getMap(props.mapId);
|
|
1209
|
-
}, [mapContext.mapIds, mapContext, props.mapId]);
|
|
1210
|
-
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(Button, {
|
|
1211
|
-
color: "primary",
|
|
1212
|
-
variant: "contained",
|
|
1213
|
-
onClick: function onClick() {
|
|
1214
|
-
createPdf(mapRef.current, null, function () {});
|
|
1215
|
-
}
|
|
1216
|
-
}, /*#__PURE__*/React__default.createElement(PrinterIcon, null)));
|
|
1217
|
-
};
|
|
1218
|
-
|
|
1219
|
-
MlCreatePdfButton.defaultProps = {
|
|
1220
|
-
mapId: undefined
|
|
1221
|
-
};
|
|
1222
|
-
MlCreatePdfButton.propTypes = {
|
|
1223
|
-
/**
|
|
1224
|
-
* Id of the target MapLibre instance in mapContext
|
|
1225
|
-
*/
|
|
1226
|
-
mapId: PropTypes.string
|
|
1193
|
+
/**
|
|
1194
|
+
* Filter string or RegExp to more explicitly define the elements watched and increase performance
|
|
1195
|
+
* strings will be matched using layerId.includes(matchString)
|
|
1196
|
+
* RegExps will be matched using matchRegExp.test(layerId)
|
|
1197
|
+
*/
|
|
1198
|
+
filter: PropTypes.shape({
|
|
1199
|
+
includeBaseLayers: PropTypes.bool,
|
|
1200
|
+
matchLayerIds: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(RegExp)]),
|
|
1201
|
+
matchSourceIds: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(RegExp)])
|
|
1202
|
+
})
|
|
1227
1203
|
};
|
|
1228
1204
|
|
|
1229
1205
|
var _showNextTransitionSegment = function _showNextTransitionSegment(props, layerId, map, transitionInProgressRef, transitionGeojsonDataRef, transitionGeojsonCommonDataRef, currentTransitionStepRef, msPerStep, transitionTimeoutRef) {
|
|
@@ -1399,6 +1375,14 @@ var msPerStep = 50;
|
|
|
1399
1375
|
var MlGeoJsonLayer = function MlGeoJsonLayer(props) {
|
|
1400
1376
|
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
1401
1377
|
var mapContext = useContext(MapContext);
|
|
1378
|
+
var mapState = useMapState({
|
|
1379
|
+
mapId: props.mapId,
|
|
1380
|
+
watch: {
|
|
1381
|
+
viewport: false,
|
|
1382
|
+
layers: true,
|
|
1383
|
+
sources: false
|
|
1384
|
+
}
|
|
1385
|
+
});
|
|
1402
1386
|
var oldGeojsonRef = useRef(null);
|
|
1403
1387
|
var mapRef = useRef(null);
|
|
1404
1388
|
var initializedRef = useRef(false);
|
|
@@ -1463,6 +1447,22 @@ var MlGeoJsonLayer = function MlGeoJsonLayer(props) {
|
|
|
1463
1447
|
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1464
1448
|
|
|
1465
1449
|
if (props.geojson) {
|
|
1450
|
+
//check if insertBeforeLayer exists
|
|
1451
|
+
if (props.insertBeforeLayer) {
|
|
1452
|
+
var _mapState$layers;
|
|
1453
|
+
|
|
1454
|
+
var layerFound = false;
|
|
1455
|
+
mapState === null || mapState === void 0 ? void 0 : (_mapState$layers = mapState.layers) === null || _mapState$layers === void 0 ? void 0 : _mapState$layers.forEach(function (layer) {
|
|
1456
|
+
if (layer.id === props.insertBeforeLayer) {
|
|
1457
|
+
layerFound = true;
|
|
1458
|
+
}
|
|
1459
|
+
});
|
|
1460
|
+
|
|
1461
|
+
if (!layerFound) {
|
|
1462
|
+
return;
|
|
1463
|
+
}
|
|
1464
|
+
}
|
|
1465
|
+
|
|
1466
1466
|
initializedRef.current = true;
|
|
1467
1467
|
var geojson = props.geojson;
|
|
1468
1468
|
|
|
@@ -1503,7 +1503,7 @@ var MlGeoJsonLayer = function MlGeoJsonLayer(props) {
|
|
|
1503
1503
|
oldGeojsonRef.current = props.geojson;
|
|
1504
1504
|
}
|
|
1505
1505
|
}
|
|
1506
|
-
}, [mapContext.mapIds, mapContext, props, transitionToGeojson]);
|
|
1506
|
+
}, [mapContext.mapIds, mapContext, props, transitionToGeojson, mapState.layers]);
|
|
1507
1507
|
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null);
|
|
1508
1508
|
};
|
|
1509
1509
|
|
|
@@ -1582,43 +1582,100 @@ MlGeoJsonLayer.propTypes = {
|
|
|
1582
1582
|
idSuffix: PropTypes.string
|
|
1583
1583
|
};
|
|
1584
1584
|
|
|
1585
|
-
|
|
1585
|
+
function useMap(props) {
|
|
1586
1586
|
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
1587
|
-
var mapRef = useRef(null);
|
|
1588
|
-
var componentId = useRef((props.idPrefix ? props.idPrefix : "MlImageMarkerLayer-") + v4());
|
|
1589
1587
|
var mapContext = useContext(MapContext);
|
|
1590
|
-
var
|
|
1591
|
-
|
|
1592
|
-
|
|
1593
|
-
|
|
1588
|
+
var mapState = useMapState({
|
|
1589
|
+
mapId: props.mapId,
|
|
1590
|
+
watch: {
|
|
1591
|
+
viewport: false,
|
|
1592
|
+
layers: true,
|
|
1593
|
+
sources: false
|
|
1594
|
+
}
|
|
1595
|
+
});
|
|
1596
|
+
var initializedRef = useRef(false);
|
|
1597
|
+
var mapRef = useRef(undefined);
|
|
1598
|
+
var componentId = useRef(v4());
|
|
1599
|
+
|
|
1600
|
+
var _useState = useState(undefined),
|
|
1601
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1602
|
+
mapIsReady = _useState2[0],
|
|
1603
|
+
setMapIsReady = _useState2[1];
|
|
1604
|
+
|
|
1594
1605
|
useEffect(function () {
|
|
1595
1606
|
var _componentId = componentId.current;
|
|
1596
1607
|
return function () {
|
|
1597
|
-
// This is the cleanup function, it is called when this react component is removed from react-dom
|
|
1598
1608
|
if (mapRef.current) {
|
|
1599
1609
|
mapRef.current.cleanup(_componentId);
|
|
1600
|
-
mapRef.current =
|
|
1610
|
+
mapRef.current = undefined;
|
|
1601
1611
|
}
|
|
1612
|
+
|
|
1613
|
+
initializedRef.current = false;
|
|
1614
|
+
setMapIsReady(false);
|
|
1602
1615
|
};
|
|
1603
1616
|
}, []);
|
|
1604
1617
|
useEffect(function () {
|
|
1605
|
-
if (!
|
|
1618
|
+
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
1619
|
+
console.log("initialize useMap hook"); //check if insertBeforeLayer exists
|
|
1620
|
+
|
|
1621
|
+
if (props.waitForLayer) {
|
|
1622
|
+
var _mapState$layers;
|
|
1623
|
+
|
|
1624
|
+
var layerFound = false;
|
|
1625
|
+
mapState === null || mapState === void 0 ? void 0 : (_mapState$layers = mapState.layers) === null || _mapState$layers === void 0 ? void 0 : _mapState$layers.forEach(function (layer) {
|
|
1626
|
+
console.log(layer.id + " " + props.waitForLayer);
|
|
1627
|
+
|
|
1628
|
+
if (layer.id === props.waitForLayer) {
|
|
1629
|
+
layerFound = true;
|
|
1630
|
+
}
|
|
1631
|
+
});
|
|
1632
|
+
|
|
1633
|
+
if (!layerFound) {
|
|
1634
|
+
return;
|
|
1635
|
+
}
|
|
1636
|
+
}
|
|
1637
|
+
|
|
1638
|
+
console.log("done initialize useMap hook"); // the MapLibre-gl instance (mapContext.getMap(props.mapId)) is accessible here
|
|
1639
|
+
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1640
|
+
|
|
1641
|
+
initializedRef.current = true;
|
|
1642
|
+
mapRef.current = mapContext.getMap(props.mapId);
|
|
1643
|
+
setMapIsReady(true);
|
|
1644
|
+
}, [mapContext.mapIds, mapState.layers, mapContext, props.mapId]);
|
|
1645
|
+
return {
|
|
1646
|
+
map: mapRef.current,
|
|
1647
|
+
mapIsReady: mapIsReady,
|
|
1648
|
+
componentId: componentId.current,
|
|
1649
|
+
layers: mapState.layers
|
|
1650
|
+
};
|
|
1651
|
+
}
|
|
1652
|
+
|
|
1653
|
+
var MlImageMarkerLayer = function MlImageMarkerLayer(props) {
|
|
1654
|
+
var mapHook = useMap({
|
|
1655
|
+
mapId: props.mapId,
|
|
1656
|
+
waitForLayer: props.insertBeforeLayer
|
|
1657
|
+
});
|
|
1658
|
+
var layerInitializedRef = useRef(false);
|
|
1659
|
+
var imageIdRef = useRef(props.imageId || "img_" + new Date().getTime());
|
|
1660
|
+
var layerId = useRef(props.layerId || "MlImageMarkerLayer-" + mapHook.componentId);
|
|
1661
|
+
useEffect(function () {
|
|
1662
|
+
if (!mapHook.mapIsReady || mapHook.map && !mapHook.map.getLayer(layerId.current) || !props.options) return; // the MapLibre-gl instance (mapContext.map) is accessible here
|
|
1606
1663
|
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1607
1664
|
|
|
1608
1665
|
var key;
|
|
1609
1666
|
|
|
1610
1667
|
if (props.options.layout) {
|
|
1611
1668
|
for (key in props.options.layout) {
|
|
1612
|
-
|
|
1669
|
+
mapHook.map.setLayoutProperty(layerId.current, key, props.options.layout[key]);
|
|
1613
1670
|
}
|
|
1614
1671
|
}
|
|
1615
1672
|
|
|
1616
1673
|
if (props.options.paint) {
|
|
1617
1674
|
for (key in props.options.paint) {
|
|
1618
|
-
|
|
1675
|
+
mapHook.map.setPaintProperty(layerId.current, key, props.options.paint[key]);
|
|
1619
1676
|
}
|
|
1620
1677
|
}
|
|
1621
|
-
}, [props.options, layerId.current,
|
|
1678
|
+
}, [props.options, layerId.current, props.mapId]);
|
|
1622
1679
|
var addLayer = useCallback(function () {
|
|
1623
1680
|
var tmpOptions = _objectSpread2({
|
|
1624
1681
|
id: layerId.current,
|
|
@@ -1626,438 +1683,632 @@ var MlImageMarkerLayer = function MlImageMarkerLayer(props) {
|
|
|
1626
1683
|
}, props.options);
|
|
1627
1684
|
|
|
1628
1685
|
tmpOptions.layout["icon-image"] = imageIdRef.current;
|
|
1629
|
-
|
|
1630
|
-
}, [props]);
|
|
1686
|
+
mapHook.map.addLayer(tmpOptions, props.insertBeforeLayer, mapHook.componentId);
|
|
1687
|
+
}, [props, mapHook.mapIsReady, mapHook.map]);
|
|
1631
1688
|
useEffect(function () {
|
|
1632
|
-
if (!props.options || !
|
|
1633
|
-
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1634
|
-
|
|
1635
|
-
mapRef.current = mapContext.getMap(props.mapId);
|
|
1689
|
+
if (!props.options || !mapHook.mapIsReady || layerInitializedRef.current) return;
|
|
1636
1690
|
layerInitializedRef.current = true;
|
|
1637
|
-
console.log(props.imgSrc);
|
|
1638
1691
|
|
|
1639
1692
|
if (props.imgSrc) {
|
|
1640
|
-
|
|
1693
|
+
mapHook.map.loadImage(props.imgSrc, function (error, image) {
|
|
1641
1694
|
if (error) throw error;
|
|
1642
|
-
|
|
1695
|
+
mapHook.map.addImage(imageIdRef.current, image, mapHook.componentId);
|
|
1643
1696
|
});
|
|
1644
1697
|
}
|
|
1645
1698
|
|
|
1646
1699
|
addLayer();
|
|
1647
|
-
}, [
|
|
1700
|
+
}, [mapHook.mapIsReady, mapHook.map, addLayer, props]);
|
|
1648
1701
|
useEffect(function () {
|
|
1649
|
-
if (!
|
|
1702
|
+
if (!mapHook.mapIsReady || mapHook.map && !mapHook.map.getLayer(layerId.current) || !props.options) {
|
|
1650
1703
|
return;
|
|
1651
|
-
}
|
|
1652
|
-
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1653
|
-
|
|
1704
|
+
}
|
|
1654
1705
|
|
|
1655
|
-
|
|
1656
|
-
}, [props.options.source.data,
|
|
1706
|
+
mapHook.map.getSource(layerId.current).setData(props.options.source.data);
|
|
1707
|
+
}, [props.options.source.data, props]);
|
|
1657
1708
|
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null);
|
|
1658
1709
|
};
|
|
1659
1710
|
|
|
1660
|
-
|
|
1661
|
-
|
|
1662
|
-
function SvgRotateRight(props) {
|
|
1663
|
-
return /*#__PURE__*/createElement("svg", _extends({
|
|
1664
|
-
width: "39.675098mm",
|
|
1665
|
-
height: "104.27064mm",
|
|
1666
|
-
viewBox: "0 0 39.675098 104.27064"
|
|
1667
|
-
}, props), /*#__PURE__*/createElement("g", {
|
|
1668
|
-
transform: "translate(-86.019554,-58.032633)"
|
|
1669
|
-
}, /*#__PURE__*/createElement("path", {
|
|
1670
|
-
style: {
|
|
1671
|
-
strokeWidth: 0.744756
|
|
1672
|
-
},
|
|
1673
|
-
d: "m 442.74023,219.33594 -117.62695,32.32422 54.71094,31.12304 c -21.99397,41.5931 -32.8507,84.88283 -38.33008,127.89649 -6.86182,50.94051 -5.95715,103.99765 20.23828,155.46484 5.97246,11.72776 13.65817,23.59773 24.38867,35.06641 2.6597,2.84073 5.65602,5.75455 9.12891,8.68164 0.87557,0.7378 1.85363,1.52609 2.95117,2.35547 0.29669,0.22563 0.63616,0.47742 1.02149,0.75586 l 0.58203,0.42578 34.57812,-15.12305 -0.33789,-0.2207 c -0.0265,-0.0151 -0.0842,-0.0587 -0.18359,-0.13086 -0.46723,-0.34885 -0.9819,-0.76796 -1.56055,-1.25 -2.29757,-1.91343 -4.46539,-4.04643 -6.64062,-6.33985 -8.80052,-9.27114 -15.30333,-19.4993 -20.83985,-30.13867 -24.42289,-46.90715 -24.77465,-97.03535 -18.58008,-146.68164 4.94388,-37.37493 13.65299,-74.4847 30.20508,-109.92969 l 58.6211,33.34766 z",
|
|
1674
|
-
transform: "scale(0.26458333)"
|
|
1675
|
-
})));
|
|
1676
|
-
}
|
|
1677
|
-
|
|
1678
|
-
var _g;
|
|
1679
|
-
|
|
1680
|
-
function _extends$1() { _extends$1 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$1.apply(this, arguments); }
|
|
1681
|
-
|
|
1682
|
-
function SvgRotateLeft(props) {
|
|
1683
|
-
return /*#__PURE__*/createElement("svg", _extends$1({
|
|
1684
|
-
width: "39.675098mm",
|
|
1685
|
-
height: "104.27064mm",
|
|
1686
|
-
viewBox: "0 0 39.675098 104.27064"
|
|
1687
|
-
}, props), _g || (_g = /*#__PURE__*/createElement("g", {
|
|
1688
|
-
transform: "translate(-86.019554,-58.032633)"
|
|
1689
|
-
}, /*#__PURE__*/createElement("path", {
|
|
1690
|
-
d: "m 94.572523,58.032633 31.122127,8.55245 -14.4756,8.234638 c 5.81924,11.004841 8.69175,22.458582 10.1415,33.839279 1.81552,13.47801 1.57616,27.51604 -5.35471,41.13341 -1.58021,3.10296 -3.61373,6.24356 -6.45284,9.27798 -0.70371,0.75161 -1.49649,1.52256 -2.41535,2.29702 -0.23167,0.19521 -0.49044,0.40378 -0.78083,0.62322 -0.0785,0.0597 -0.16832,0.12632 -0.27027,0.19999 l -0.154,0.11265 -9.148793,-4.00131 0.0894,-0.0584 c 0.007,-0.004 0.02228,-0.0155 0.04857,-0.0346 0.123621,-0.0923 0.259794,-0.20319 0.412895,-0.33073 0.607899,-0.50626 1.181468,-1.07062 1.756997,-1.67742 2.328481,-2.45299 4.049011,-5.15919 5.513881,-7.97419 6.46189,-12.41085 6.55496,-25.67394 4.91598,-38.80952 -1.30807,-9.888781 -3.61235,-19.707408 -7.99176,-29.085561 l -15.510171,8.823235 z"
|
|
1691
|
-
}))));
|
|
1692
|
-
}
|
|
1693
|
-
|
|
1694
|
-
var _g$1;
|
|
1695
|
-
|
|
1696
|
-
function _extends$2() { _extends$2 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$2.apply(this, arguments); }
|
|
1697
|
-
|
|
1698
|
-
function SvgNeedle(props) {
|
|
1699
|
-
return /*#__PURE__*/createElement("svg", _extends$2({
|
|
1700
|
-
width: "75.967445mm",
|
|
1701
|
-
height: "234.71339mm",
|
|
1702
|
-
viewBox: "0 0 75.967445 234.71339"
|
|
1703
|
-
}, props), _g$1 || (_g$1 = /*#__PURE__*/createElement("g", {
|
|
1704
|
-
transform: "translate(-76.705281,-29.77268)"
|
|
1705
|
-
}, /*#__PURE__*/createElement("path", {
|
|
1706
|
-
d: "m 114.68901,29.77268 37.98372,117.3567 H 76.705281 Z"
|
|
1707
|
-
}), /*#__PURE__*/createElement("path", {
|
|
1708
|
-
d: "m 114.68901,264.48608 37.98372,-117.3567 H 76.705281 Z"
|
|
1709
|
-
}))));
|
|
1710
|
-
}
|
|
1711
|
-
|
|
1712
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
1713
|
-
|
|
1714
|
-
var NeedleButton = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
1715
|
-
target: "e12lzm5x2"
|
|
1716
|
-
} : {
|
|
1717
|
-
target: "e12lzm5x2",
|
|
1718
|
-
label: "NeedleButton"
|
|
1719
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
1720
|
-
name: "1204o9",
|
|
1721
|
-
styles: "width:40%;display:flex;align-items:center;&:hover{cursor:pointer;}path{filter:drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));}&:hover path{filter:drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));}path:nth-of-type(2){fill:#343434;}&:hover path:nth-of-type(2){fill:#434343;}path:nth-of-type(1){fill:#e90318;}&:hover path:nth-of-type(1){fill:#fb4052;}"
|
|
1722
|
-
} : {
|
|
1723
|
-
name: "1204o9",
|
|
1724
|
-
styles: "width:40%;display:flex;align-items:center;&:hover{cursor:pointer;}path{filter:drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));}&:hover path{filter:drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));}path:nth-of-type(2){fill:#343434;}&:hover path:nth-of-type(2){fill:#434343;}path:nth-of-type(1){fill:#e90318;}&:hover path:nth-of-type(1){fill:#fb4052;}",
|
|
1725
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAa+B","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
1726
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
1727
|
-
});
|
|
1728
|
-
|
|
1729
|
-
var NeedleContainer = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
1730
|
-
target: "e12lzm5x1"
|
|
1731
|
-
} : {
|
|
1732
|
-
target: "e12lzm5x1",
|
|
1733
|
-
label: "NeedleContainer"
|
|
1734
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
1735
|
-
name: "1m8y6tb",
|
|
1736
|
-
styles: "pointer-events:none;display:flex;z-index:1002;position:absolute;align-items:center;margin-left:-30%;path:nth-of-type(2){}svg g{transform:translate(-76.7053, -29.7727) scale(2, 1);}svg{z-index:9990;height:150px;width:200px;}"
|
|
1737
|
-
} : {
|
|
1738
|
-
name: "1m8y6tb",
|
|
1739
|
-
styles: "pointer-events:none;display:flex;z-index:1002;position:absolute;align-items:center;margin-left:-30%;path:nth-of-type(2){}svg g{transform:translate(-76.7053, -29.7727) scale(2, 1);}svg{z-index:9990;height:150px;width:200px;}",
|
|
1740
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAwCkC","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
1741
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
1742
|
-
});
|
|
1711
|
+
var marker = "b556faa3bc6829d2.png";
|
|
1743
1712
|
|
|
1744
|
-
var RotateButton = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
1745
|
-
target: "e12lzm5x0"
|
|
1746
|
-
} : {
|
|
1747
|
-
target: "e12lzm5x0",
|
|
1748
|
-
label: "RotateButton"
|
|
1749
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
1750
|
-
name: "1j4uu1m",
|
|
1751
|
-
styles: "width:30%;margin-top:14px;z-index:999;display:flex;svg:hover{cursor:pointer;}svg:hover path{fill:#ececec;filter:drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));}path{fill:#bbb;}svg{transform:scale(0.6);z-index:9990;height:172px;}"
|
|
1752
|
-
} : {
|
|
1753
|
-
name: "1j4uu1m",
|
|
1754
|
-
styles: "width:30%;margin-top:14px;z-index:999;display:flex;svg:hover{cursor:pointer;}svg:hover path{fill:#ececec;filter:drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));}path{fill:#bbb;}svg{transform:scale(0.6);z-index:9990;height:172px;}",
|
|
1755
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AA2D+B","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
1756
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
1757
|
-
});
|
|
1758
1713
|
/**
|
|
1759
|
-
*
|
|
1714
|
+
* Adds a button that makes the map follow the users GPS position using
|
|
1715
|
+
* navigator.geolocation.watchPosition if activated
|
|
1760
1716
|
*
|
|
1761
|
-
*
|
|
1717
|
+
* @param {object} props
|
|
1718
|
+
* @param {string} props.mapId Id of the target MapLibre instance in mapContext
|
|
1762
1719
|
*
|
|
1763
1720
|
* @component
|
|
1764
1721
|
*/
|
|
1765
1722
|
|
|
1766
|
-
|
|
1767
|
-
var MlNavigationCompass = function MlNavigationCompass(props) {
|
|
1723
|
+
var MlFollowGps = function MlFollowGps(props) {
|
|
1768
1724
|
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
1769
1725
|
var mapContext = useContext(MapContext);
|
|
1726
|
+
|
|
1727
|
+
var _useState = useState(false),
|
|
1728
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
1729
|
+
isFollowed = _useState2[0],
|
|
1730
|
+
setIsFollowed = _useState2[1];
|
|
1731
|
+
|
|
1732
|
+
var _useState3 = useState(undefined),
|
|
1733
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
1734
|
+
geoJson = _useState4[0],
|
|
1735
|
+
setGeoJson = _useState4[1];
|
|
1736
|
+
|
|
1737
|
+
var watchIdRef = useRef(undefined);
|
|
1738
|
+
|
|
1739
|
+
var _useState5 = useState(false),
|
|
1740
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
1741
|
+
locationAccessDenied = _useState6[0],
|
|
1742
|
+
setLocationAccessDenied = _useState6[1];
|
|
1743
|
+
|
|
1770
1744
|
var initializedRef = useRef(false);
|
|
1771
1745
|
var mapRef = useRef(undefined);
|
|
1772
|
-
var componentId = useRef((props.idPrefix ? props.idPrefix : "
|
|
1746
|
+
var componentId = useRef((props.idPrefix ? props.idPrefix : "MlFollowGps-") + v4());
|
|
1773
1747
|
|
|
1774
|
-
var
|
|
1775
|
-
|
|
1776
|
-
|
|
1777
|
-
|
|
1748
|
+
var _useState7 = useState(),
|
|
1749
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
1750
|
+
accuracyGeoJson = _useState8[0],
|
|
1751
|
+
setAccuracyGeoJson = _useState8[1];
|
|
1778
1752
|
|
|
1779
1753
|
useEffect(function () {
|
|
1780
1754
|
var _componentId = componentId.current;
|
|
1781
1755
|
return function () {
|
|
1782
1756
|
// This is the cleanup function, it is called when this react component is removed from react-dom
|
|
1757
|
+
// try to remove anything this component has added to the MapLibre-gl instance
|
|
1758
|
+
// e.g.: remove the layer
|
|
1759
|
+
// mapContext.getMap(props.mapId).removeLayer(layerRef.current);
|
|
1760
|
+
// check for the existence of map.style before calling getLayer or getSource
|
|
1783
1761
|
if (mapRef.current) {
|
|
1784
1762
|
mapRef.current.cleanup(_componentId);
|
|
1785
1763
|
mapRef.current = undefined;
|
|
1786
1764
|
}
|
|
1787
1765
|
|
|
1788
|
-
|
|
1766
|
+
if (watchIdRef.current) {
|
|
1767
|
+
initializedRef.current = false;
|
|
1768
|
+
navigator.geolocation.clearWatch(watchIdRef.current);
|
|
1769
|
+
watchIdRef.current = undefined;
|
|
1770
|
+
}
|
|
1789
1771
|
};
|
|
1790
1772
|
}, []);
|
|
1791
1773
|
useEffect(function () {
|
|
1792
|
-
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
1774
|
+
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return; // the MapLibre-gl instance (mapContext.getMap(props.mapId)) is accessible here
|
|
1775
|
+
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1776
|
+
|
|
1793
1777
|
initializedRef.current = true;
|
|
1794
1778
|
mapRef.current = mapContext.getMap(props.mapId);
|
|
1795
|
-
mapRef.current.
|
|
1796
|
-
setBearing(Math.round(mapRef.current.getBearing()));
|
|
1797
|
-
}, componentId.current);
|
|
1798
|
-
setBearing(Math.round(mapRef.current.getBearing()));
|
|
1779
|
+
mapRef.current.setCenter([7.132122000552613, 50.716405378037706]);
|
|
1799
1780
|
}, [mapContext.mapIds, mapContext, props.mapId]);
|
|
1800
|
-
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("div", {
|
|
1801
|
-
className: /*#__PURE__*/css(_objectSpread2({
|
|
1802
|
-
zIndex: 1000,
|
|
1803
|
-
top: 0,
|
|
1804
|
-
position: "absolute"
|
|
1805
|
-
}, props.style), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAmImB","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
1806
|
-
}, /*#__PURE__*/React__default.createElement("div", {
|
|
1807
|
-
className: /*#__PURE__*/css(_objectSpread2({
|
|
1808
|
-
position: "absolute",
|
|
1809
|
-
border: "10px solid #bcbcbc",
|
|
1810
|
-
backgroundColor: "#717171",
|
|
1811
|
-
background: "radial-gradient(#717171, #414141)",
|
|
1812
|
-
height: "200px",
|
|
1813
|
-
width: "200px",
|
|
1814
|
-
borderRadius: "50%",
|
|
1815
|
-
display: "flex",
|
|
1816
|
-
justifyContent: "center",
|
|
1817
|
-
transform: "scale(0.2) translateX(-448px) translateY(-448px)"
|
|
1818
|
-
}, props.backgroundStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AA2IqB","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
1819
|
-
}, /*#__PURE__*/React__default.createElement(RotateButton, {
|
|
1820
|
-
className: /*#__PURE__*/css(_objectSpread2({}, props.rotateRightStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAyJmC","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
1821
|
-
}, /*#__PURE__*/React__default.createElement(SvgRotateRight, {
|
|
1822
|
-
onClick: function onClick() {
|
|
1823
|
-
var _mapRef$current, _mapRef$current2;
|
|
1824
1781
|
|
|
1825
|
-
|
|
1826
|
-
|
|
1782
|
+
var getLocationSuccess = function getLocationSuccess(pos) {
|
|
1783
|
+
if (!mapRef.current) return;
|
|
1784
|
+
mapRef.current.setCenter([pos.coords.longitude, pos.coords.latitude]);
|
|
1785
|
+
var geoJsonPoint = point([pos.coords.longitude, pos.coords.latitude]);
|
|
1786
|
+
setGeoJson(geoJsonPoint);
|
|
1787
|
+
setAccuracyGeoJson(circle(geoJsonPoint, pos.coords.accuracy / 1000));
|
|
1788
|
+
};
|
|
1827
1789
|
|
|
1828
|
-
|
|
1829
|
-
|
|
1830
|
-
|
|
1790
|
+
var getLocationError = function getLocationError(err) {
|
|
1791
|
+
console.log("Access of user location denied");
|
|
1792
|
+
setLocationAccessDenied(true);
|
|
1793
|
+
};
|
|
1831
1794
|
|
|
1832
|
-
|
|
1833
|
-
|
|
1795
|
+
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, isFollowed && geoJson && /*#__PURE__*/React__default.createElement(MlGeoJsonLayer, {
|
|
1796
|
+
geojson: accuracyGeoJson,
|
|
1797
|
+
type: "fill",
|
|
1798
|
+
paint: {
|
|
1799
|
+
"fill-color": "#ee7700",
|
|
1800
|
+
"fill-opacity": 0.5
|
|
1801
|
+
},
|
|
1802
|
+
insertBeforeLayer: "MlFollowGpsMarker"
|
|
1803
|
+
}), isFollowed && geoJson && /*#__PURE__*/React__default.createElement(MlImageMarkerLayer, {
|
|
1804
|
+
layerId: "MlFollowGpsMarker",
|
|
1805
|
+
options: {
|
|
1806
|
+
type: "symbol",
|
|
1807
|
+
source: {
|
|
1808
|
+
type: "geojson",
|
|
1809
|
+
data: geoJson
|
|
1810
|
+
},
|
|
1811
|
+
layout: {
|
|
1812
|
+
"icon-size": 0.1,
|
|
1813
|
+
"icon-offset": [0, -340]
|
|
1834
1814
|
}
|
|
1835
|
-
|
|
1836
|
-
|
|
1837
|
-
|
|
1838
|
-
|
|
1839
|
-
|
|
1815
|
+
},
|
|
1816
|
+
imgSrc: marker
|
|
1817
|
+
}), /*#__PURE__*/React__default.createElement(Button, {
|
|
1818
|
+
sx: _objectSpread2({
|
|
1819
|
+
zIndex: 1002,
|
|
1820
|
+
color: isFollowed ? props.onColor : props.offColor
|
|
1821
|
+
}, props.style),
|
|
1822
|
+
disabled: locationAccessDenied,
|
|
1840
1823
|
onClick: function onClick() {
|
|
1841
|
-
|
|
1824
|
+
if (isFollowed) {
|
|
1825
|
+
navigator.geolocation.clearWatch(watchIdRef.current);
|
|
1826
|
+
} else {
|
|
1827
|
+
watchIdRef.current = navigator.geolocation.watchPosition(getLocationSuccess, getLocationError);
|
|
1828
|
+
}
|
|
1842
1829
|
|
|
1843
|
-
(
|
|
1830
|
+
setIsFollowed(!isFollowed);
|
|
1844
1831
|
}
|
|
1845
|
-
}, /*#__PURE__*/React__default.createElement(
|
|
1846
|
-
|
|
1847
|
-
|
|
1832
|
+
}, " ", /*#__PURE__*/React__default.createElement(RoomIcon, {
|
|
1833
|
+
sx: {
|
|
1834
|
+
fontSize: props.style.fontSize
|
|
1848
1835
|
}
|
|
1849
|
-
},
|
|
1850
|
-
|
|
1851
|
-
}, /*#__PURE__*/React__default.createElement(SvgRotateLeft, {
|
|
1852
|
-
onClick: function onClick() {
|
|
1853
|
-
var _mapRef$current4, _mapRef$current5;
|
|
1836
|
+
}), " "));
|
|
1837
|
+
};
|
|
1854
1838
|
|
|
1855
|
-
|
|
1856
|
-
|
|
1839
|
+
MlFollowGps.defaultProps = {
|
|
1840
|
+
mapId: undefined,
|
|
1841
|
+
style: {
|
|
1842
|
+
minWidth: "30px",
|
|
1843
|
+
minHeight: "30px",
|
|
1844
|
+
width: "30px",
|
|
1845
|
+
height: "30px",
|
|
1846
|
+
backgroundColor: "#414141",
|
|
1847
|
+
borderRadius: "23%",
|
|
1848
|
+
margin: 0.15,
|
|
1849
|
+
fontSize: "1.3em",
|
|
1850
|
+
":hover": {
|
|
1851
|
+
backgroundColor: "#515151",
|
|
1852
|
+
color: "#ececec"
|
|
1853
|
+
}
|
|
1854
|
+
},
|
|
1855
|
+
onColor: "#ececec",
|
|
1856
|
+
offColor: "#666"
|
|
1857
|
+
};
|
|
1858
|
+
MlFollowGps.propTypes = {
|
|
1859
|
+
/**
|
|
1860
|
+
* Id of the target MapLibre instance in mapContext
|
|
1861
|
+
*/
|
|
1862
|
+
mapId: PropTypes.string,
|
|
1857
1863
|
|
|
1858
|
-
|
|
1859
|
-
|
|
1864
|
+
/**
|
|
1865
|
+
* CSS style object that is applied to the button component
|
|
1866
|
+
*/
|
|
1867
|
+
style: PropTypes.object,
|
|
1868
|
+
|
|
1869
|
+
/**
|
|
1870
|
+
* Active button font color
|
|
1871
|
+
*/
|
|
1872
|
+
onColor: PropTypes.string,
|
|
1873
|
+
|
|
1874
|
+
/**
|
|
1875
|
+
* Inactive button font color
|
|
1876
|
+
*/
|
|
1877
|
+
offColor: PropTypes.string
|
|
1878
|
+
};
|
|
1879
|
+
|
|
1880
|
+
var nmMap = {
|
|
1881
|
+
street: ["footway", "street", "road", "street_name", "residential", "path", "pedestrian", "road_reference", "road_reference_intl", "square", "place"],
|
|
1882
|
+
number: ["house_number", "street_number"],
|
|
1883
|
+
place: ["city", "village", "hamlet", "locality", "croft", "neighbourhood", "suburb", "city_district", "district", "quarter", "borough", "city_block", "residential", "commercial", "industrial", "houses", "subdivision", "allotments", "postal_city", "town", "municipality", "local_administrative_area"],
|
|
1884
|
+
zip: ["postcode", "partial_postcode"],
|
|
1885
|
+
state: ["state", "province", "state_code"]
|
|
1886
|
+
};
|
|
1887
|
+
|
|
1888
|
+
var nmConverter = function nmConverter(nmAddress) {
|
|
1889
|
+
var addressArr = [];
|
|
1890
|
+
|
|
1891
|
+
for (var key in nmMap) {
|
|
1892
|
+
nmMap[key].some(function (element) {
|
|
1893
|
+
if (nmAddress.hasOwnProperty(element)) {
|
|
1894
|
+
addressArr.push(nmAddress[element]);
|
|
1895
|
+
return true;
|
|
1860
1896
|
}
|
|
1861
1897
|
|
|
1862
|
-
|
|
1863
|
-
|
|
1898
|
+
return false;
|
|
1899
|
+
});
|
|
1900
|
+
}
|
|
1901
|
+
|
|
1902
|
+
return addressArr.join(", ");
|
|
1903
|
+
};
|
|
1904
|
+
|
|
1905
|
+
var toPixels = function toPixels(length) {
|
|
1906
|
+
var conversionFactor = 96;
|
|
1907
|
+
conversionFactor /= 25.4;
|
|
1908
|
+
return conversionFactor * length + "px";
|
|
1909
|
+
};
|
|
1910
|
+
|
|
1911
|
+
var createPdf = function createPdf(map, locationValue, setLoading) {
|
|
1912
|
+
setLoading(true);
|
|
1913
|
+
var width = 210;
|
|
1914
|
+
var height = 297; // Calculate pixel ratio
|
|
1915
|
+
|
|
1916
|
+
var actualPixelRatio = window.devicePixelRatio; // Create map container
|
|
1917
|
+
|
|
1918
|
+
var hidden = document.createElement("div");
|
|
1919
|
+
hidden.className = "hidden-map";
|
|
1920
|
+
document.body.appendChild(hidden);
|
|
1921
|
+
var container = document.createElement("div");
|
|
1922
|
+
container.style.width = toPixels(width);
|
|
1923
|
+
container.style.height = toPixels(height);
|
|
1924
|
+
hidden.appendChild(container); //Render map
|
|
1925
|
+
|
|
1926
|
+
var renderMap = new maplibregl$1.Map({
|
|
1927
|
+
container: container,
|
|
1928
|
+
center: map.getCenter(),
|
|
1929
|
+
zoom: map.getZoom(),
|
|
1930
|
+
bearing: map.getBearing(),
|
|
1931
|
+
pitch: map.getPitch(),
|
|
1932
|
+
interactive: false,
|
|
1933
|
+
preserveDrawingBuffer: true,
|
|
1934
|
+
fadeDuration: 0,
|
|
1935
|
+
attributionControl: false
|
|
1936
|
+
});
|
|
1937
|
+
var style = map.getStyle();
|
|
1938
|
+
|
|
1939
|
+
var _loop = function _loop(name) {
|
|
1940
|
+
var src = style.sources[name];
|
|
1941
|
+
Object.keys(src).forEach(function (key) {
|
|
1942
|
+
//delete properties if value is undefined.
|
|
1943
|
+
// for instance, raster-dem might has undefined value in "url" and "bounds"
|
|
1944
|
+
if (!src[key]) {
|
|
1945
|
+
delete src[key];
|
|
1864
1946
|
}
|
|
1947
|
+
});
|
|
1948
|
+
};
|
|
1865
1949
|
|
|
1866
|
-
|
|
1950
|
+
for (var name in style.sources) {
|
|
1951
|
+
_loop(name);
|
|
1952
|
+
}
|
|
1953
|
+
|
|
1954
|
+
renderMap.setStyle(style);
|
|
1955
|
+
renderMap.once("idle", function () {
|
|
1956
|
+
var _hidden$parentNode;
|
|
1957
|
+
|
|
1958
|
+
// TO DO: It is still under development
|
|
1959
|
+
var pdf = new jsPDF({
|
|
1960
|
+
orientation: "p",
|
|
1961
|
+
unit: "mm",
|
|
1962
|
+
compress: true
|
|
1963
|
+
});
|
|
1964
|
+
Object.defineProperty(window, "devicePixelRatio", {
|
|
1965
|
+
get: function get() {
|
|
1966
|
+
return 300 / 96;
|
|
1967
|
+
}
|
|
1968
|
+
});
|
|
1969
|
+
var offsetX = 2.5;
|
|
1970
|
+
var offsetY = 2.5;
|
|
1971
|
+
var marginTop = 3;
|
|
1972
|
+
var marginBottom = 3;
|
|
1973
|
+
var innerMargin = 2;
|
|
1974
|
+
var logo = "data:image/png;base64,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";
|
|
1975
|
+
var textBuffer = 1;
|
|
1976
|
+
var lineHeight = 3.25;
|
|
1977
|
+
var text = locationValue ? nmConverter(locationValue.address) : "";
|
|
1978
|
+
var textChunksSeperator = text.split(",");
|
|
1979
|
+
var textChunks = [];
|
|
1980
|
+
|
|
1981
|
+
if (textChunks.length) {
|
|
1982
|
+
textChunksSeperator.forEach(function (chunk) {
|
|
1983
|
+
var limitChunks = chunk.match(/.{1,34}/g);
|
|
1984
|
+
textChunks.push.apply(textChunks, _toConsumableArray(limitChunks));
|
|
1985
|
+
});
|
|
1986
|
+
} //Render map image
|
|
1987
|
+
|
|
1988
|
+
|
|
1989
|
+
pdf.addImage(renderMap.getCanvas().toDataURL("image/png"), "png", 0, 0, 210, 297, null, "FAST"); //Render lower left Copyright box
|
|
1990
|
+
|
|
1991
|
+
pdf.setFillColor("white");
|
|
1992
|
+
pdf.rect(138, 287, 297, 10, "F");
|
|
1993
|
+
pdf.setFontSize(10); // optional
|
|
1994
|
+
|
|
1995
|
+
pdf.text("Datenquelle: © OpenStreetMap-Mitwirkende", 140, pdf.internal.pageSize.height - 3); //Render infobox
|
|
1996
|
+
|
|
1997
|
+
pdf.setFillColor("white");
|
|
1998
|
+
var infoBoxSize = textChunks.length * lineHeight + marginTop + marginBottom + lineHeight * 2 + innerMargin * 2 + textBuffer;
|
|
1999
|
+
pdf.rect(offsetX, 2, 66.5, infoBoxSize, "F");
|
|
2000
|
+
pdf.setFontSize(10);
|
|
2001
|
+
pdf.text("Karten PDF:", 6, offsetY + marginTop); //Render inner infobox
|
|
2002
|
+
|
|
2003
|
+
pdf.rect(6, 7, 60, textChunks.length * lineHeight + innerMargin * 2 + textBuffer);
|
|
2004
|
+
pdf.setFontSize(10); //Write out address
|
|
2005
|
+
|
|
2006
|
+
textChunks.forEach(function (text, i) {
|
|
2007
|
+
pdf.text(text.trim(), 8, 10 + i * 3.5 + innerMargin);
|
|
2008
|
+
}); //Add WG Logo
|
|
2009
|
+
|
|
2010
|
+
pdf.addImage(logo, "png", 5, offsetY + marginTop + lineHeight * 2 + textChunks.length * 3 + innerMargin * 2, 3, 3, null, "FAST"); //Add WG Url
|
|
2011
|
+
|
|
2012
|
+
pdf.setFontSize(10);
|
|
2013
|
+
pdf.text("wheregroup.com", 40, offsetY + marginTop + lineHeight * 2 + textChunks.length * lineHeight + innerMargin * 2 + textBuffer); //Set pdfs props
|
|
2014
|
+
|
|
2015
|
+
pdf.setProperties({
|
|
2016
|
+
title: "Map export",
|
|
2017
|
+
subject: "Map export",
|
|
2018
|
+
creator: "WhereGroup GmbH",
|
|
2019
|
+
author: "(c)WhereGroup GmbH, (c)OpenStreetMap"
|
|
2020
|
+
});
|
|
2021
|
+
pdf.save("Map.pdf");
|
|
2022
|
+
renderMap.remove();
|
|
2023
|
+
(_hidden$parentNode = hidden.parentNode) === null || _hidden$parentNode === void 0 ? void 0 : _hidden$parentNode.removeChild(hidden);
|
|
2024
|
+
Object.defineProperty(window, "devicePixelRatio", {
|
|
2025
|
+
get: function get() {
|
|
2026
|
+
return actualPixelRatio;
|
|
2027
|
+
}
|
|
2028
|
+
});
|
|
2029
|
+
setLoading(false);
|
|
2030
|
+
});
|
|
2031
|
+
};
|
|
2032
|
+
|
|
2033
|
+
/**
|
|
2034
|
+
* Renders a button that will create a PDF version of the current map view (dimensions adjusted to fit Din A4 Paper).
|
|
2035
|
+
*
|
|
2036
|
+
* @component
|
|
2037
|
+
*/
|
|
2038
|
+
|
|
2039
|
+
var MlCreatePdfButton = function MlCreatePdfButton(props) {
|
|
2040
|
+
var mapContext = useContext(MapContext);
|
|
2041
|
+
var initializedRef = useRef(false);
|
|
2042
|
+
var mapRef = useRef(undefined);
|
|
2043
|
+
useEffect(function () {
|
|
2044
|
+
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
2045
|
+
initializedRef.current = true;
|
|
2046
|
+
mapRef.current = mapContext.getMap(props.mapId);
|
|
2047
|
+
}, [mapContext.mapIds, mapContext, props.mapId]);
|
|
2048
|
+
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(Button, {
|
|
2049
|
+
color: "primary",
|
|
2050
|
+
variant: "contained",
|
|
2051
|
+
onClick: function onClick() {
|
|
2052
|
+
createPdf(mapRef.current, null, function () {});
|
|
1867
2053
|
}
|
|
1868
|
-
})))
|
|
2054
|
+
}, /*#__PURE__*/React__default.createElement(PrinterIcon, null)));
|
|
1869
2055
|
};
|
|
1870
2056
|
|
|
1871
|
-
|
|
2057
|
+
MlCreatePdfButton.defaultProps = {
|
|
2058
|
+
mapId: undefined
|
|
2059
|
+
};
|
|
2060
|
+
MlCreatePdfButton.propTypes = {
|
|
1872
2061
|
/**
|
|
1873
|
-
*
|
|
2062
|
+
* Id of the target MapLibre instance in mapContext
|
|
1874
2063
|
*/
|
|
1875
|
-
|
|
2064
|
+
mapId: PropTypes.string
|
|
2065
|
+
};
|
|
1876
2066
|
|
|
1877
|
-
|
|
1878
|
-
* Style object to adjust css definitions of the component.
|
|
1879
|
-
*/
|
|
1880
|
-
style: PropTypes.object,
|
|
2067
|
+
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
1881
2068
|
|
|
1882
|
-
|
|
1883
|
-
|
|
1884
|
-
|
|
1885
|
-
|
|
2069
|
+
function SvgRotateRight(props) {
|
|
2070
|
+
return /*#__PURE__*/createElement("svg", _extends({
|
|
2071
|
+
width: "39.675098mm",
|
|
2072
|
+
height: "104.27064mm",
|
|
2073
|
+
viewBox: "0 0 39.675098 104.27064"
|
|
2074
|
+
}, props), /*#__PURE__*/createElement("g", {
|
|
2075
|
+
transform: "translate(-86.019554,-58.032633)"
|
|
2076
|
+
}, /*#__PURE__*/createElement("path", {
|
|
2077
|
+
style: {
|
|
2078
|
+
strokeWidth: 0.744756
|
|
2079
|
+
},
|
|
2080
|
+
d: "m 442.74023,219.33594 -117.62695,32.32422 54.71094,31.12304 c -21.99397,41.5931 -32.8507,84.88283 -38.33008,127.89649 -6.86182,50.94051 -5.95715,103.99765 20.23828,155.46484 5.97246,11.72776 13.65817,23.59773 24.38867,35.06641 2.6597,2.84073 5.65602,5.75455 9.12891,8.68164 0.87557,0.7378 1.85363,1.52609 2.95117,2.35547 0.29669,0.22563 0.63616,0.47742 1.02149,0.75586 l 0.58203,0.42578 34.57812,-15.12305 -0.33789,-0.2207 c -0.0265,-0.0151 -0.0842,-0.0587 -0.18359,-0.13086 -0.46723,-0.34885 -0.9819,-0.76796 -1.56055,-1.25 -2.29757,-1.91343 -4.46539,-4.04643 -6.64062,-6.33985 -8.80052,-9.27114 -15.30333,-19.4993 -20.83985,-30.13867 -24.42289,-46.90715 -24.77465,-97.03535 -18.58008,-146.68164 4.94388,-37.37493 13.65299,-74.4847 30.20508,-109.92969 l 58.6211,33.34766 z",
|
|
2081
|
+
transform: "scale(0.26458333)"
|
|
2082
|
+
})));
|
|
2083
|
+
}
|
|
1886
2084
|
|
|
1887
|
-
|
|
1888
|
-
* Style object to adjust css definitions of the compass needle.
|
|
1889
|
-
*/
|
|
1890
|
-
needleStyle: PropTypes.object,
|
|
2085
|
+
var _g;
|
|
1891
2086
|
|
|
1892
|
-
|
|
1893
|
-
* Style object to adjust css definitions of the rotate right button.
|
|
1894
|
-
*/
|
|
1895
|
-
rotateRightStyle: PropTypes.object,
|
|
2087
|
+
function _extends$1() { _extends$1 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$1.apply(this, arguments); }
|
|
1896
2088
|
|
|
1897
|
-
|
|
1898
|
-
|
|
1899
|
-
|
|
1900
|
-
|
|
1901
|
-
|
|
2089
|
+
function SvgRotateLeft(props) {
|
|
2090
|
+
return /*#__PURE__*/createElement("svg", _extends$1({
|
|
2091
|
+
width: "39.675098mm",
|
|
2092
|
+
height: "104.27064mm",
|
|
2093
|
+
viewBox: "0 0 39.675098 104.27064"
|
|
2094
|
+
}, props), _g || (_g = /*#__PURE__*/createElement("g", {
|
|
2095
|
+
transform: "translate(-86.019554,-58.032633)"
|
|
2096
|
+
}, /*#__PURE__*/createElement("path", {
|
|
2097
|
+
d: "m 94.572523,58.032633 31.122127,8.55245 -14.4756,8.234638 c 5.81924,11.004841 8.69175,22.458582 10.1415,33.839279 1.81552,13.47801 1.57616,27.51604 -5.35471,41.13341 -1.58021,3.10296 -3.61373,6.24356 -6.45284,9.27798 -0.70371,0.75161 -1.49649,1.52256 -2.41535,2.29702 -0.23167,0.19521 -0.49044,0.40378 -0.78083,0.62322 -0.0785,0.0597 -0.16832,0.12632 -0.27027,0.19999 l -0.154,0.11265 -9.148793,-4.00131 0.0894,-0.0584 c 0.007,-0.004 0.02228,-0.0155 0.04857,-0.0346 0.123621,-0.0923 0.259794,-0.20319 0.412895,-0.33073 0.607899,-0.50626 1.181468,-1.07062 1.756997,-1.67742 2.328481,-2.45299 4.049011,-5.15919 5.513881,-7.97419 6.46189,-12.41085 6.55496,-25.67394 4.91598,-38.80952 -1.30807,-9.888781 -3.61235,-19.707408 -7.99176,-29.085561 l -15.510171,8.823235 z"
|
|
2098
|
+
}))));
|
|
2099
|
+
}
|
|
1902
2100
|
|
|
1903
|
-
var
|
|
2101
|
+
var _g$1;
|
|
2102
|
+
|
|
2103
|
+
function _extends$2() { _extends$2 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$2.apply(this, arguments); }
|
|
2104
|
+
|
|
2105
|
+
function SvgNeedle(props) {
|
|
2106
|
+
return /*#__PURE__*/createElement("svg", _extends$2({
|
|
2107
|
+
width: "75.967445mm",
|
|
2108
|
+
height: "234.71339mm",
|
|
2109
|
+
viewBox: "0 0 75.967445 234.71339"
|
|
2110
|
+
}, props), _g$1 || (_g$1 = /*#__PURE__*/createElement("g", {
|
|
2111
|
+
transform: "translate(-76.705281,-29.77268)"
|
|
2112
|
+
}, /*#__PURE__*/createElement("path", {
|
|
2113
|
+
d: "m 114.68901,29.77268 37.98372,117.3567 H 76.705281 Z"
|
|
2114
|
+
}), /*#__PURE__*/createElement("path", {
|
|
2115
|
+
d: "m 114.68901,264.48608 37.98372,-117.3567 H 76.705281 Z"
|
|
2116
|
+
}))));
|
|
2117
|
+
}
|
|
2118
|
+
|
|
2119
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
2120
|
+
|
|
2121
|
+
var NeedleButton = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
2122
|
+
target: "e12lzm5x2"
|
|
2123
|
+
} : {
|
|
2124
|
+
target: "e12lzm5x2",
|
|
2125
|
+
label: "NeedleButton"
|
|
2126
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
2127
|
+
name: "1204o9",
|
|
2128
|
+
styles: "width:40%;display:flex;align-items:center;&:hover{cursor:pointer;}path{filter:drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));}&:hover path{filter:drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));}path:nth-of-type(2){fill:#343434;}&:hover path:nth-of-type(2){fill:#434343;}path:nth-of-type(1){fill:#e90318;}&:hover path:nth-of-type(1){fill:#fb4052;}"
|
|
2129
|
+
} : {
|
|
2130
|
+
name: "1204o9",
|
|
2131
|
+
styles: "width:40%;display:flex;align-items:center;&:hover{cursor:pointer;}path{filter:drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));}&:hover path{filter:drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));}path:nth-of-type(2){fill:#343434;}&:hover path:nth-of-type(2){fill:#434343;}path:nth-of-type(1){fill:#e90318;}&:hover path:nth-of-type(1){fill:#fb4052;}",
|
|
2132
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAa+B","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
2133
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
2134
|
+
});
|
|
2135
|
+
|
|
2136
|
+
var NeedleContainer = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
2137
|
+
target: "e12lzm5x1"
|
|
2138
|
+
} : {
|
|
2139
|
+
target: "e12lzm5x1",
|
|
2140
|
+
label: "NeedleContainer"
|
|
2141
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
2142
|
+
name: "1m8y6tb",
|
|
2143
|
+
styles: "pointer-events:none;display:flex;z-index:1002;position:absolute;align-items:center;margin-left:-30%;path:nth-of-type(2){}svg g{transform:translate(-76.7053, -29.7727) scale(2, 1);}svg{z-index:9990;height:150px;width:200px;}"
|
|
2144
|
+
} : {
|
|
2145
|
+
name: "1m8y6tb",
|
|
2146
|
+
styles: "pointer-events:none;display:flex;z-index:1002;position:absolute;align-items:center;margin-left:-30%;path:nth-of-type(2){}svg g{transform:translate(-76.7053, -29.7727) scale(2, 1);}svg{z-index:9990;height:150px;width:200px;}",
|
|
2147
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAwCkC","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
2148
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
2149
|
+
});
|
|
1904
2150
|
|
|
2151
|
+
var RotateButton = _styled("div", process.env.NODE_ENV === "production" ? {
|
|
2152
|
+
target: "e12lzm5x0"
|
|
2153
|
+
} : {
|
|
2154
|
+
target: "e12lzm5x0",
|
|
2155
|
+
label: "RotateButton"
|
|
2156
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
2157
|
+
name: "1j4uu1m",
|
|
2158
|
+
styles: "width:30%;margin-top:14px;z-index:999;display:flex;svg:hover{cursor:pointer;}svg:hover path{fill:#ececec;filter:drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));}path{fill:#bbb;}svg{transform:scale(0.6);z-index:9990;height:172px;}"
|
|
2159
|
+
} : {
|
|
2160
|
+
name: "1j4uu1m",
|
|
2161
|
+
styles: "width:30%;margin-top:14px;z-index:999;display:flex;svg:hover{cursor:pointer;}svg:hover path{fill:#ececec;filter:drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));}path{fill:#bbb;}svg{transform:scale(0.6);z-index:9990;height:172px;}",
|
|
2162
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AA2D+B","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */",
|
|
2163
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
2164
|
+
});
|
|
1905
2165
|
/**
|
|
1906
|
-
*
|
|
1907
|
-
* navigator.geolocation.watchPosition if activated
|
|
2166
|
+
* Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.
|
|
1908
2167
|
*
|
|
1909
|
-
* @
|
|
1910
|
-
* @param {string} props.mapId Id of the target MapLibre instance in mapContext
|
|
2168
|
+
* All style props are applied using @emotion/css to allow more complex css selectors.
|
|
1911
2169
|
*
|
|
1912
2170
|
* @component
|
|
1913
2171
|
*/
|
|
1914
2172
|
|
|
1915
|
-
|
|
2173
|
+
|
|
2174
|
+
var MlNavigationCompass = function MlNavigationCompass(props) {
|
|
1916
2175
|
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
1917
2176
|
var mapContext = useContext(MapContext);
|
|
1918
|
-
|
|
1919
|
-
var _useState = useState(false),
|
|
1920
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
1921
|
-
isFollowed = _useState2[0],
|
|
1922
|
-
setIsFollowed = _useState2[1];
|
|
1923
|
-
|
|
1924
|
-
var _useState3 = useState(undefined),
|
|
1925
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
1926
|
-
geoJson = _useState4[0],
|
|
1927
|
-
setGeoJson = _useState4[1];
|
|
1928
|
-
|
|
1929
|
-
var watchIdRef = useRef(undefined);
|
|
1930
|
-
|
|
1931
|
-
var _useState5 = useState(false),
|
|
1932
|
-
_useState6 = _slicedToArray(_useState5, 2),
|
|
1933
|
-
locationAccessDenied = _useState6[0],
|
|
1934
|
-
setLocationAccessDenied = _useState6[1];
|
|
1935
|
-
|
|
1936
2177
|
var initializedRef = useRef(false);
|
|
1937
2178
|
var mapRef = useRef(undefined);
|
|
1938
|
-
var componentId = useRef((props.idPrefix ? props.idPrefix : "
|
|
2179
|
+
var componentId = useRef((props.idPrefix ? props.idPrefix : "MlNavigationCompass-") + v4());
|
|
1939
2180
|
|
|
1940
|
-
var
|
|
1941
|
-
|
|
1942
|
-
|
|
1943
|
-
|
|
2181
|
+
var _useState = useState(0),
|
|
2182
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
2183
|
+
bearing = _useState2[0],
|
|
2184
|
+
setBearing = _useState2[1];
|
|
1944
2185
|
|
|
1945
2186
|
useEffect(function () {
|
|
1946
2187
|
var _componentId = componentId.current;
|
|
1947
2188
|
return function () {
|
|
1948
2189
|
// This is the cleanup function, it is called when this react component is removed from react-dom
|
|
1949
|
-
// try to remove anything this component has added to the MapLibre-gl instance
|
|
1950
|
-
// e.g.: remove the layer
|
|
1951
|
-
// mapContext.getMap(props.mapId).removeLayer(layerRef.current);
|
|
1952
|
-
// check for the existence of map.style before calling getLayer or getSource
|
|
1953
2190
|
if (mapRef.current) {
|
|
1954
2191
|
mapRef.current.cleanup(_componentId);
|
|
1955
2192
|
mapRef.current = undefined;
|
|
1956
2193
|
}
|
|
1957
2194
|
|
|
1958
|
-
|
|
1959
|
-
initializedRef.current = false;
|
|
1960
|
-
navigator.geolocation.clearWatch(watchIdRef.current);
|
|
1961
|
-
watchIdRef.current = undefined;
|
|
1962
|
-
}
|
|
2195
|
+
initializedRef.current = false;
|
|
1963
2196
|
};
|
|
1964
2197
|
}, []);
|
|
1965
2198
|
useEffect(function () {
|
|
1966
|
-
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
1967
|
-
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
1968
|
-
|
|
2199
|
+
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;
|
|
1969
2200
|
initializedRef.current = true;
|
|
1970
2201
|
mapRef.current = mapContext.getMap(props.mapId);
|
|
1971
|
-
mapRef.current.
|
|
2202
|
+
mapRef.current.on("rotate", function () {
|
|
2203
|
+
setBearing(Math.round(mapRef.current.getBearing()));
|
|
2204
|
+
}, componentId.current);
|
|
2205
|
+
setBearing(Math.round(mapRef.current.getBearing()));
|
|
1972
2206
|
}, [mapContext.mapIds, mapContext, props.mapId]);
|
|
2207
|
+
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("div", {
|
|
2208
|
+
className: /*#__PURE__*/css(_objectSpread2({
|
|
2209
|
+
zIndex: 1000,
|
|
2210
|
+
top: 0,
|
|
2211
|
+
position: "absolute"
|
|
2212
|
+
}, props.style), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAmImB","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
2213
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
2214
|
+
className: /*#__PURE__*/css(_objectSpread2({
|
|
2215
|
+
position: "absolute",
|
|
2216
|
+
border: "10px solid #bcbcbc",
|
|
2217
|
+
backgroundColor: "#717171",
|
|
2218
|
+
background: "radial-gradient(#717171, #414141)",
|
|
2219
|
+
height: "200px",
|
|
2220
|
+
width: "200px",
|
|
2221
|
+
borderRadius: "50%",
|
|
2222
|
+
display: "flex",
|
|
2223
|
+
justifyContent: "center",
|
|
2224
|
+
transform: "scale(0.2) translateX(-448px) translateY(-448px)"
|
|
2225
|
+
}, props.backgroundStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AA2IqB","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
2226
|
+
}, /*#__PURE__*/React__default.createElement(RotateButton, {
|
|
2227
|
+
className: /*#__PURE__*/css(_objectSpread2({}, props.rotateRightStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAyJmC","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
2228
|
+
}, /*#__PURE__*/React__default.createElement(SvgRotateRight, {
|
|
2229
|
+
onClick: function onClick() {
|
|
2230
|
+
var _mapRef$current, _mapRef$current2;
|
|
1973
2231
|
|
|
1974
|
-
|
|
1975
|
-
|
|
1976
|
-
mapRef.current.setCenter([pos.coords.longitude, pos.coords.latitude]);
|
|
1977
|
-
setAccuracyRadius(pos.coords.accuracy);
|
|
1978
|
-
setGeoJson(point([pos.coords.longitude, pos.coords.latitude]));
|
|
1979
|
-
};
|
|
1980
|
-
|
|
1981
|
-
var getLocationError = function getLocationError(err) {
|
|
1982
|
-
console.log("Access of user location denied");
|
|
1983
|
-
setLocationAccessDenied(true);
|
|
1984
|
-
};
|
|
2232
|
+
var bearing = Math.round((_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 ? void 0 : _mapRef$current.getBearing());
|
|
2233
|
+
var rest = Math.round(bearing % 90);
|
|
1985
2234
|
|
|
1986
|
-
|
|
1987
|
-
|
|
1988
|
-
type: "circle",
|
|
1989
|
-
paint: {
|
|
1990
|
-
"circle-radius": {
|
|
1991
|
-
stops: [[0, 0], [20, accuracyRadius / 0.075 / Math.cos(geoJson.geometry.coordinates[1] * Math.PI / 180)]],
|
|
1992
|
-
base: 2
|
|
1993
|
-
},
|
|
1994
|
-
"circle-color": "#ee7700",
|
|
1995
|
-
"circle-opacity": 0.5
|
|
1996
|
-
}
|
|
1997
|
-
}), isFollowed && geoJson && /*#__PURE__*/React__default.createElement(MlImageMarkerLayer, {
|
|
1998
|
-
options: {
|
|
1999
|
-
type: "symbol",
|
|
2000
|
-
source: {
|
|
2001
|
-
type: "geojson",
|
|
2002
|
-
data: geoJson
|
|
2003
|
-
},
|
|
2004
|
-
layout: {
|
|
2005
|
-
"icon-size": 0.1,
|
|
2006
|
-
"icon-offset": [0, -340]
|
|
2235
|
+
if (bearing > 0) {
|
|
2236
|
+
rest = 90 - rest;
|
|
2007
2237
|
}
|
|
2008
|
-
|
|
2009
|
-
|
|
2010
|
-
|
|
2011
|
-
sx: _objectSpread2({
|
|
2012
|
-
zIndex: 1002,
|
|
2013
|
-
color: isFollowed ? "#bbb" : "#666"
|
|
2014
|
-
}, props.style),
|
|
2015
|
-
disabled: locationAccessDenied,
|
|
2016
|
-
onClick: function onClick() {
|
|
2017
|
-
if (isFollowed) {
|
|
2018
|
-
navigator.geolocation.clearWatch(watchIdRef.current);
|
|
2019
|
-
} else {
|
|
2020
|
-
watchIdRef.current = navigator.geolocation.watchPosition(getLocationSuccess, getLocationError);
|
|
2238
|
+
|
|
2239
|
+
if (rest === 0) {
|
|
2240
|
+
rest = 90;
|
|
2021
2241
|
}
|
|
2022
2242
|
|
|
2023
|
-
|
|
2243
|
+
(_mapRef$current2 = mapRef.current) === null || _mapRef$current2 === void 0 ? void 0 : _mapRef$current2.setBearing(Math.round(bearing + Math.abs(rest)));
|
|
2244
|
+
}
|
|
2245
|
+
})), /*#__PURE__*/React__default.createElement(NeedleButton, {
|
|
2246
|
+
className: /*#__PURE__*/css(_objectSpread2({}, props.needleStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAyKuB","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */"),
|
|
2247
|
+
onClick: function onClick() {
|
|
2248
|
+
var _mapRef$current3;
|
|
2249
|
+
|
|
2250
|
+
(_mapRef$current3 = mapRef.current) === null || _mapRef$current3 === void 0 ? void 0 : _mapRef$current3.setBearing(0);
|
|
2024
2251
|
}
|
|
2025
|
-
},
|
|
2026
|
-
|
|
2027
|
-
|
|
2252
|
+
}, /*#__PURE__*/React__default.createElement(NeedleContainer, {
|
|
2253
|
+
style: {
|
|
2254
|
+
transform: "rotate(" + bearing + "deg)"
|
|
2028
2255
|
}
|
|
2029
|
-
}
|
|
2030
|
-
};
|
|
2256
|
+
}, /*#__PURE__*/React__default.createElement(SvgNeedle, null))), /*#__PURE__*/React__default.createElement(RotateButton, {
|
|
2257
|
+
className: /*#__PURE__*/css(_objectSpread2({}, props.rotateLeftStyle), process.env.NODE_ENV === "production" ? "" : ";label:MlNavigationCompass;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["MlNavigationCompass.js"],"names":[],"mappings":"AAsLmC","file":"MlNavigationCompass.js","sourcesContent":["import React, { useState, useRef, useEffect, useContext } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { MapContext } from \"@mapcomponents/react-core\";\nimport { v4 as uuidv4 } from \"uuid\";\n\nimport { ReactComponent as RotateRightIcon } from \"./assets/rotate_right.svg\";\nimport { ReactComponent as RotateLeftIcon } from \"./assets/rotate_left.svg\";\nimport { ReactComponent as NeedleIcon } from \"./assets/needle.svg\";\n\nimport styled from \"@emotion/styled\";\nimport { css } from \"@emotion/css\";\n\nconst NeedleButton = styled.div`\n  width: 40%;\n  display: flex;\n  align-items: center;\n\n  &:hover {\n    cursor: pointer;\n  }\n  path {\n    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));\n  }\n  &:hover path {\n    filter: drop-shadow(0px 0px 13px rgba(255, 255, 255, 0.1));\n  }\n  path:nth-of-type(2) {\n    fill: #343434;\n  }\n  &:hover path:nth-of-type(2) {\n    fill: #434343;\n  }\n  path:nth-of-type(1) {\n    fill: #e90318;\n  }\n  &:hover path:nth-of-type(1) {\n    fill: #fb4052;\n  }\n`;\nconst NeedleContainer = styled.div`\n  pointer-events: none;\n  display: flex;\n  z-index: 1002;\n  position: absolute;\n  align-items: center;\n\n  margin-left: -30%;\n  path:nth-of-type(2) {\n  }\n  svg g {\n    transform: translate(-76.7053, -29.7727) scale(2, 1);\n  }\n  svg {\n    z-index: 9990;\n    height: 150px;\n    width: 200px;\n  }\n`;\nconst RotateButton = styled.div`\n  width: 30%;\n  margin-top: 14px;\n  z-index: 999;\n  display: flex;\n\n  svg:hover {\n    cursor: pointer;\n  }\n  svg:hover path {\n    fill: #ececec;\n    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1));\n  }\n  path {\n    fill: #bbb;\n  }\n  svg {\n    transform: scale(0.6);\n    z-index: 9990;\n    height: 172px;\n  }\n`;\n\n/**\n * Navigation component that displays a compass component which indicates the current oriantation of the map it is registered for and offers controls to turn the bearing 90° left/right or reset north to point up.\n *\n * All style props are applied using @emotion/css to allow more complex css selectors.\n *\n * @component\n */\nconst MlNavigationCompass = (props) => {\n  // Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks\n  const mapContext = useContext(MapContext);\n\n  const initializedRef = useRef(false);\n  const mapRef = useRef(undefined);\n  const componentId = useRef((props.idPrefix ? props.idPrefix : \"MlNavigationCompass-\") + uuidv4());\n\n  const [bearing, setBearing] = useState(0);\n\n  useEffect(() => {\n    let _componentId = componentId.current;\n\n    return () => {\n      // This is the cleanup function, it is called when this react component is removed from react-dom\n\n      if (mapRef.current) {\n        mapRef.current.cleanup(_componentId);\n        mapRef.current = undefined;\n      }\n      initializedRef.current = false;\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!mapContext.mapExists(props.mapId) || initializedRef.current) return;\n    initializedRef.current = true;\n    mapRef.current = mapContext.getMap(props.mapId);\n\n    mapRef.current.on(\n      \"rotate\",\n      function () {\n        setBearing(Math.round(mapRef.current.getBearing()));\n      },\n      componentId.current\n    );\n    setBearing(Math.round(mapRef.current.getBearing()));\n  }, [mapContext.mapIds, mapContext, props.mapId]);\n\n  return (\n    <>\n      <div\n        className={css({\n          zIndex: 1000,\n          top: 0,\n          position: \"absolute\",\n          ...props.style,\n        })}\n      >\n        <div\n          className={css({\n            position: \"absolute\",\n            border: \"10px solid #bcbcbc\",\n            backgroundColor: \"#717171\",\n            background: \"radial-gradient(#717171, #414141)\",\n            height: \"200px\",\n            width: \"200px\",\n            borderRadius: \"50%\",\n            display: \"flex\",\n            justifyContent: \"center\",\n            transform: \"scale(0.2) translateX(-448px) translateY(-448px)\",\n            ...props.backgroundStyle,\n          })}\n        >\n          <RotateButton className={css({ ...props.rotateRightStyle })}>\n            <RotateRightIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing > 0) {\n                  rest = 90 - rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing + Math.abs(rest)));\n              }}\n            ></RotateRightIcon>\n          </RotateButton>\n          <NeedleButton\n            className={css({ ...props.needleStyle })}\n            onClick={() => {\n              mapRef.current?.setBearing(0);\n            }}\n          >\n            <NeedleContainer\n              style={{\n                transform: \"rotate(\" + bearing + \"deg)\",\n              }}\n            >\n              <NeedleIcon />\n            </NeedleContainer>\n          </NeedleButton>\n          <RotateButton className={css({ ...props.rotateLeftStyle })}>\n            <RotateLeftIcon\n              onClick={() => {\n                let bearing = Math.round(mapRef.current?.getBearing());\n                let rest = Math.round(bearing % 90);\n                if (bearing < 0) {\n                  rest = 90 + rest;\n                }\n                if (rest === 0) {\n                  rest = 90;\n                }\n                mapRef.current?.setBearing(Math.round(bearing - Math.abs(rest)));\n              }}\n            ></RotateLeftIcon>\n          </RotateButton>\n        </div>\n      </div>\n    </>\n  );\n};\n\nMlNavigationCompass.propTypes = {\n  /**\n   * Component id prefix\n   */\n  idPrefix: PropTypes.string,\n  /**\n   * Style object to adjust css definitions of the component.\n   */\n  style: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the background.\n   */\n  backgroundStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the compass needle.\n   */\n  needleStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate right button.\n   */\n  rotateRightStyle: PropTypes.object,\n  /**\n   * Style object to adjust css definitions of the rotate left button.\n   */\n  rotateLeftStyle: PropTypes.object,\n};\n\nexport default MlNavigationCompass;\n"]} */")
|
|
2258
|
+
}, /*#__PURE__*/React__default.createElement(SvgRotateLeft, {
|
|
2259
|
+
onClick: function onClick() {
|
|
2260
|
+
var _mapRef$current4, _mapRef$current5;
|
|
2031
2261
|
|
|
2032
|
-
|
|
2033
|
-
|
|
2034
|
-
|
|
2035
|
-
|
|
2036
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
2041
|
-
|
|
2042
|
-
|
|
2043
|
-
|
|
2044
|
-
backgroundColor: "#515151",
|
|
2045
|
-
color: "#ececec"
|
|
2262
|
+
var bearing = Math.round((_mapRef$current4 = mapRef.current) === null || _mapRef$current4 === void 0 ? void 0 : _mapRef$current4.getBearing());
|
|
2263
|
+
var rest = Math.round(bearing % 90);
|
|
2264
|
+
|
|
2265
|
+
if (bearing < 0) {
|
|
2266
|
+
rest = 90 + rest;
|
|
2267
|
+
}
|
|
2268
|
+
|
|
2269
|
+
if (rest === 0) {
|
|
2270
|
+
rest = 90;
|
|
2271
|
+
}
|
|
2272
|
+
|
|
2273
|
+
(_mapRef$current5 = mapRef.current) === null || _mapRef$current5 === void 0 ? void 0 : _mapRef$current5.setBearing(Math.round(bearing - Math.abs(rest)));
|
|
2046
2274
|
}
|
|
2047
|
-
}
|
|
2275
|
+
})))));
|
|
2048
2276
|
};
|
|
2049
|
-
|
|
2277
|
+
|
|
2278
|
+
MlNavigationCompass.propTypes = {
|
|
2050
2279
|
/**
|
|
2051
|
-
*
|
|
2280
|
+
* Component id prefix
|
|
2052
2281
|
*/
|
|
2053
|
-
|
|
2282
|
+
idPrefix: PropTypes.string,
|
|
2054
2283
|
|
|
2055
2284
|
/**
|
|
2056
|
-
*
|
|
2285
|
+
* Style object to adjust css definitions of the component.
|
|
2286
|
+
*/
|
|
2287
|
+
style: PropTypes.object,
|
|
2288
|
+
|
|
2289
|
+
/**
|
|
2290
|
+
* Style object to adjust css definitions of the background.
|
|
2291
|
+
*/
|
|
2292
|
+
backgroundStyle: PropTypes.object,
|
|
2293
|
+
|
|
2294
|
+
/**
|
|
2295
|
+
* Style object to adjust css definitions of the compass needle.
|
|
2296
|
+
*/
|
|
2297
|
+
needleStyle: PropTypes.object,
|
|
2298
|
+
|
|
2299
|
+
/**
|
|
2300
|
+
* Style object to adjust css definitions of the rotate right button.
|
|
2301
|
+
*/
|
|
2302
|
+
rotateRightStyle: PropTypes.object,
|
|
2303
|
+
|
|
2304
|
+
/**
|
|
2305
|
+
* Style object to adjust css definitions of the rotate left button.
|
|
2057
2306
|
*/
|
|
2058
|
-
|
|
2307
|
+
rotateLeftStyle: PropTypes.object
|
|
2059
2308
|
};
|
|
2060
2309
|
|
|
2310
|
+
var _excluded$1 = ["color"];
|
|
2311
|
+
|
|
2061
2312
|
var MlNavigationTools = function MlNavigationTools(props) {
|
|
2062
2313
|
var mapContext = useContext(MapContext);
|
|
2063
2314
|
var initializedRef = useRef(false);
|
|
@@ -2080,7 +2331,6 @@ var MlNavigationTools = function MlNavigationTools(props) {
|
|
|
2080
2331
|
minHeight: "20px",
|
|
2081
2332
|
width: mediaIsMobile ? "50px" : "30px",
|
|
2082
2333
|
height: mediaIsMobile ? "50px" : "30px",
|
|
2083
|
-
color: "#bbb",
|
|
2084
2334
|
backgroundColor: "#414141",
|
|
2085
2335
|
borderRadius: "23%",
|
|
2086
2336
|
//border: "1px solid #bbb",
|
|
@@ -2088,9 +2338,9 @@ var MlNavigationTools = function MlNavigationTools(props) {
|
|
|
2088
2338
|
margin: 0.15,
|
|
2089
2339
|
fontSize: mediaIsMobile ? "1.5em" : "1.2em",
|
|
2090
2340
|
":hover": {
|
|
2091
|
-
backgroundColor: "#515151"
|
|
2092
|
-
|
|
2093
|
-
|
|
2341
|
+
backgroundColor: "#515151"
|
|
2342
|
+
},
|
|
2343
|
+
color: "#ececec"
|
|
2094
2344
|
};
|
|
2095
2345
|
useEffect(function () {
|
|
2096
2346
|
var _componentId = componentId.current;
|
|
@@ -2200,7 +2450,12 @@ var MlNavigationTools = function MlNavigationTools(props) {
|
|
|
2200
2450
|
fontSize: mediaIsMobile ? "1.5em" : "1.2em"
|
|
2201
2451
|
}
|
|
2202
2452
|
})), /*#__PURE__*/React__default.createElement(MlFollowGps, {
|
|
2203
|
-
style:
|
|
2453
|
+
style: _objectSpread2({}, function (_ref) {
|
|
2454
|
+
var color = _ref.color,
|
|
2455
|
+
rest = _objectWithoutProperties(_ref, _excluded$1);
|
|
2456
|
+
|
|
2457
|
+
return rest;
|
|
2458
|
+
}(buttonStyle))
|
|
2204
2459
|
}), /*#__PURE__*/React__default.createElement(ButtonGroup, {
|
|
2205
2460
|
orientation: "vertical",
|
|
2206
2461
|
sx: {
|
|
@@ -2216,14 +2471,18 @@ var MlNavigationTools = function MlNavigationTools(props) {
|
|
|
2216
2471
|
}
|
|
2217
2472
|
}
|
|
2218
2473
|
}, /*#__PURE__*/React__default.createElement(Button, {
|
|
2219
|
-
sx: buttonStyle,
|
|
2474
|
+
sx: _objectSpread2(_objectSpread2({}, buttonStyle), {}, {
|
|
2475
|
+
color: "#ececec"
|
|
2476
|
+
}),
|
|
2220
2477
|
onClick: zoomIn
|
|
2221
2478
|
}, /*#__PURE__*/React__default.createElement(ControlPointIcon, {
|
|
2222
2479
|
sx: {
|
|
2223
2480
|
fontSize: mediaIsMobile ? "1.5em" : "1.2em"
|
|
2224
2481
|
}
|
|
2225
2482
|
})), /*#__PURE__*/React__default.createElement(Button, {
|
|
2226
|
-
sx: buttonStyle,
|
|
2483
|
+
sx: _objectSpread2(_objectSpread2({}, buttonStyle), {}, {
|
|
2484
|
+
color: "#ececec"
|
|
2485
|
+
}),
|
|
2227
2486
|
onClick: zoomOut
|
|
2228
2487
|
}, /*#__PURE__*/React__default.createElement(RemoveCircleOutlineIcon, {
|
|
2229
2488
|
sx: {
|
|
@@ -2235,6 +2494,14 @@ var MlNavigationTools = function MlNavigationTools(props) {
|
|
|
2235
2494
|
var MlLayer = function MlLayer(props) {
|
|
2236
2495
|
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
2237
2496
|
var mapContext = useContext(MapContext);
|
|
2497
|
+
var mapState = useMapState({
|
|
2498
|
+
mapId: props.mapId,
|
|
2499
|
+
watch: {
|
|
2500
|
+
viewport: false,
|
|
2501
|
+
layers: true,
|
|
2502
|
+
sources: false
|
|
2503
|
+
}
|
|
2504
|
+
});
|
|
2238
2505
|
var layerInitializedRef = useRef(false);
|
|
2239
2506
|
var mapRef = useRef(null);
|
|
2240
2507
|
var componentId = useRef((props.layerId ? props.layerId : "MlLayer-") + v4());
|
|
@@ -2279,6 +2546,22 @@ var MlLayer = function MlLayer(props) {
|
|
|
2279
2546
|
useEffect(function () {
|
|
2280
2547
|
if (!mapContext.mapExists(props.mapId) || layerInitializedRef.current) return; // the MapLibre-gl instance (mapContext.map) is accessible here
|
|
2281
2548
|
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
2549
|
+
//check if insertBeforeLayer exists
|
|
2550
|
+
|
|
2551
|
+
if (props.insertBeforeLayer) {
|
|
2552
|
+
var _mapState$layers;
|
|
2553
|
+
|
|
2554
|
+
var layerFound = false;
|
|
2555
|
+
mapState === null || mapState === void 0 ? void 0 : (_mapState$layers = mapState.layers) === null || _mapState$layers === void 0 ? void 0 : _mapState$layers.forEach(function (layer) {
|
|
2556
|
+
if (layer.id === props.insertBeforeLayer) {
|
|
2557
|
+
layerFound = true;
|
|
2558
|
+
}
|
|
2559
|
+
});
|
|
2560
|
+
|
|
2561
|
+
if (!layerFound) {
|
|
2562
|
+
return;
|
|
2563
|
+
}
|
|
2564
|
+
}
|
|
2282
2565
|
|
|
2283
2566
|
mapRef.current = mapContext.getMap(props.mapId);
|
|
2284
2567
|
|
|
@@ -2296,7 +2579,7 @@ var MlLayer = function MlLayer(props) {
|
|
|
2296
2579
|
layerPaintConfRef.current = JSON.stringify((_props$options = props.options) === null || _props$options === void 0 ? void 0 : _props$options.paint);
|
|
2297
2580
|
layerLayoutConfRef.current = JSON.stringify((_props$options2 = props.options) === null || _props$options2 === void 0 ? void 0 : _props$options2.layout);
|
|
2298
2581
|
}
|
|
2299
|
-
}, [mapContext.mapIds, mapContext, props,
|
|
2582
|
+
}, [mapContext.mapIds, mapContext, props, mapState.layers]);
|
|
2300
2583
|
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null);
|
|
2301
2584
|
};
|
|
2302
2585
|
|
|
@@ -5531,166 +5814,5 @@ MlSpatialElevationProfile.propTypes = {
|
|
|
5531
5814
|
insertBeforeLayer: PropTypes.string
|
|
5532
5815
|
};
|
|
5533
5816
|
|
|
5534
|
-
|
|
5535
|
-
* React hook that allows subscribing to map state changes
|
|
5536
|
-
*
|
|
5537
|
-
* @component
|
|
5538
|
-
*/
|
|
5539
|
-
|
|
5540
|
-
function useMapState(props) {
|
|
5541
|
-
// Use a useRef hook to reference the layer object to be able to access it later inside useEffect hooks
|
|
5542
|
-
var mapContext = useContext(MapContext);
|
|
5543
|
-
var initializedRef = useRef(false);
|
|
5544
|
-
var mapRef = useRef(undefined);
|
|
5545
|
-
|
|
5546
|
-
var _useState = useState(undefined),
|
|
5547
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
5548
|
-
center = _useState2[0],
|
|
5549
|
-
setCenter = _useState2[1];
|
|
5550
|
-
|
|
5551
|
-
var _useState3 = useState(undefined),
|
|
5552
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
5553
|
-
viewport = _useState4[0],
|
|
5554
|
-
setViewport = _useState4[1];
|
|
5555
|
-
|
|
5556
|
-
var viewportRef = useRef(undefined);
|
|
5557
|
-
|
|
5558
|
-
var _useState5 = useState(undefined),
|
|
5559
|
-
_useState6 = _slicedToArray(_useState5, 2),
|
|
5560
|
-
layers = _useState6[0],
|
|
5561
|
-
setLayers = _useState6[1];
|
|
5562
|
-
|
|
5563
|
-
var layersRef = useRef(undefined); //const mapRef = useRef(props.map);
|
|
5564
|
-
|
|
5565
|
-
var componentId = useRef(v4());
|
|
5566
|
-
/**
|
|
5567
|
-
* returns the element if it matches the defined filter criteria
|
|
5568
|
-
* to be used as filter function on the layers array
|
|
5569
|
-
*
|
|
5570
|
-
* @param {object} layer
|
|
5571
|
-
*/
|
|
5572
|
-
|
|
5573
|
-
var layerIdFilter = useCallback(function (layer) {
|
|
5574
|
-
if (!props.filter.includeBaseLayers && layer.baseLayer) {
|
|
5575
|
-
return false;
|
|
5576
|
-
}
|
|
5577
|
-
|
|
5578
|
-
if (typeof props.filter.matchLayerIds !== "undefined") {
|
|
5579
|
-
if (props.filter.matchLayerIds instanceof RegExp) {
|
|
5580
|
-
return props.filter.matchLayerIds.test(layer.id);
|
|
5581
|
-
} else {
|
|
5582
|
-
return layer.id.includes(props.filter.matchLayerIds);
|
|
5583
|
-
}
|
|
5584
|
-
}
|
|
5585
|
-
|
|
5586
|
-
return true;
|
|
5587
|
-
}, [props.filter]);
|
|
5588
|
-
var refreshLayerState = useCallback(function () {
|
|
5589
|
-
var _layerState = mapRef.current.wrapper.layerState.filter(layerIdFilter);
|
|
5590
|
-
|
|
5591
|
-
var _layerStateString = JSON.stringify(_layerState);
|
|
5592
|
-
|
|
5593
|
-
if (layersRef.current !== _layerStateString) {
|
|
5594
|
-
layersRef.current = _layerStateString;
|
|
5595
|
-
setLayers(_layerState);
|
|
5596
|
-
}
|
|
5597
|
-
}, [layerIdFilter]);
|
|
5598
|
-
useEffect(function () {
|
|
5599
|
-
var _componentId = componentId.current;
|
|
5600
|
-
return function () {
|
|
5601
|
-
if (mapRef.current) {
|
|
5602
|
-
mapRef.current.cleanup(_componentId);
|
|
5603
|
-
mapRef.current = undefined;
|
|
5604
|
-
}
|
|
5605
|
-
|
|
5606
|
-
initializedRef.current = false;
|
|
5607
|
-
};
|
|
5608
|
-
}, []);
|
|
5609
|
-
useEffect(function () {
|
|
5610
|
-
var _props$watch, _props$watch2;
|
|
5611
|
-
|
|
5612
|
-
if (!mapContext.mapExists(props.mapId) || initializedRef.current) return; // the MapLibre-gl instance (mapContext.getMap(props.mapId)) is accessible here
|
|
5613
|
-
// initialize the layer and add it to the MapLibre-gl instance or do something else with it
|
|
5614
|
-
|
|
5615
|
-
initializedRef.current = true;
|
|
5616
|
-
mapRef.current = mapContext.getMap(props.mapId);
|
|
5617
|
-
/*
|
|
5618
|
-
mapRef.current.on(
|
|
5619
|
-
"move",
|
|
5620
|
-
() => {
|
|
5621
|
-
setCenter(mapRef.current.getCenter());
|
|
5622
|
-
},
|
|
5623
|
-
componentId.current
|
|
5624
|
-
);
|
|
5625
|
-
*/
|
|
5626
|
-
|
|
5627
|
-
if (props !== null && props !== void 0 && (_props$watch = props.watch) !== null && _props$watch !== void 0 && _props$watch.viewport) {
|
|
5628
|
-
setViewport(mapRef.current.wrapper.viewportState);
|
|
5629
|
-
mapRef.current.wrapper.on("viewportchange", function () {
|
|
5630
|
-
var _mapRef$current;
|
|
5631
|
-
|
|
5632
|
-
if (viewportRef.current !== ((_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 ? void 0 : _mapRef$current.wrapper.viewportStateString)) {
|
|
5633
|
-
var _mapRef$current2, _mapRef$current3, _mapRef$current3$wrap;
|
|
5634
|
-
|
|
5635
|
-
setViewport((_mapRef$current2 = mapRef.current) === null || _mapRef$current2 === void 0 ? void 0 : _mapRef$current2.wrapper.viewportState);
|
|
5636
|
-
setCenter((_mapRef$current3 = mapRef.current) === null || _mapRef$current3 === void 0 ? void 0 : (_mapRef$current3$wrap = _mapRef$current3.wrapper.viewportState) === null || _mapRef$current3$wrap === void 0 ? void 0 : _mapRef$current3$wrap.center);
|
|
5637
|
-
}
|
|
5638
|
-
}, componentId.current);
|
|
5639
|
-
}
|
|
5640
|
-
|
|
5641
|
-
if (props !== null && props !== void 0 && (_props$watch2 = props.watch) !== null && _props$watch2 !== void 0 && _props$watch2.layers) {
|
|
5642
|
-
var _props$filter, _props$filter2;
|
|
5643
|
-
|
|
5644
|
-
refreshLayerState();
|
|
5645
|
-
mapRef.current.wrapper.on("layerchange", refreshLayerState, {
|
|
5646
|
-
includeBaseLayers: props === null || props === void 0 ? void 0 : (_props$filter = props.filter) === null || _props$filter === void 0 ? void 0 : _props$filter.includeBaseLayers,
|
|
5647
|
-
matchLayerIds: props === null || props === void 0 ? void 0 : (_props$filter2 = props.filter) === null || _props$filter2 === void 0 ? void 0 : _props$filter2.matchLayerIds
|
|
5648
|
-
}, componentId.current);
|
|
5649
|
-
}
|
|
5650
|
-
}, [mapContext.mapIds, mapContext, props.mapId, refreshLayerState]);
|
|
5651
|
-
return {
|
|
5652
|
-
layers: layers,
|
|
5653
|
-
viewport: viewport
|
|
5654
|
-
};
|
|
5655
|
-
}
|
|
5656
|
-
|
|
5657
|
-
useMapState.defaultProps = {
|
|
5658
|
-
mapId: undefined,
|
|
5659
|
-
watch: {
|
|
5660
|
-
layers: true,
|
|
5661
|
-
sources: false,
|
|
5662
|
-
viewport: false
|
|
5663
|
-
},
|
|
5664
|
-
filter: {
|
|
5665
|
-
includeBaseLayers: false
|
|
5666
|
-
}
|
|
5667
|
-
};
|
|
5668
|
-
useMapState.propTypes = {
|
|
5669
|
-
/**
|
|
5670
|
-
* Id of the target MapLibre instance in mapContext
|
|
5671
|
-
*/
|
|
5672
|
-
mapId: PropTypes.string,
|
|
5673
|
-
|
|
5674
|
-
/**
|
|
5675
|
-
* Defines map Resources to watch
|
|
5676
|
-
*/
|
|
5677
|
-
watch: PropTypes.shape({
|
|
5678
|
-
layers: PropTypes.bool,
|
|
5679
|
-
sources: PropTypes.bool,
|
|
5680
|
-
viewport: PropTypes.bool
|
|
5681
|
-
}),
|
|
5682
|
-
|
|
5683
|
-
/**
|
|
5684
|
-
* Filter string or RegExp to more explicitly define the elements watched and increase performance
|
|
5685
|
-
* strings will be matched using layerId.includes(matchString)
|
|
5686
|
-
* RegExps will be matched using matchRegExp.test(layerId)
|
|
5687
|
-
*/
|
|
5688
|
-
filter: PropTypes.shape({
|
|
5689
|
-
includeBaseLayers: PropTypes.bool,
|
|
5690
|
-
matchLayerIds: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(RegExp)]),
|
|
5691
|
-
matchSourceIds: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(RegExp)])
|
|
5692
|
-
})
|
|
5693
|
-
};
|
|
5694
|
-
|
|
5695
|
-
export { GeoJsonContext, GeoJsonProvider, MapLibreMap, MlBasicComponent, MlComponentTemplate, MlCreatePdfButton, MlFeatureEditor, MlFillExtrusionLayer, MlGPXViewer, MlGeoJsonLayer, MlImageMarkerLayer, MlLayer, MlLayerMagnify, MlLayerSwipe, MlNavigationCompass, MlNavigationTools, MlOsmLayer, MlSpatialElevationProfile, MlVectorTileLayer, MlWmsLayer, useMapState };
|
|
5817
|
+
export { GeoJsonContext, GeoJsonProvider, MapLibreMap, MlBasicComponent, MlComponentTemplate, MlCreatePdfButton, MlFeatureEditor, MlFillExtrusionLayer, MlFollowGps, MlGPXViewer, MlGeoJsonLayer, MlImageMarkerLayer, MlLayer, MlLayerMagnify, MlLayerSwipe, MlNavigationCompass, MlNavigationTools, MlOsmLayer, MlSpatialElevationProfile, MlVectorTileLayer, MlWmsLayer, useMap, useMapState };
|
|
5696
5818
|
//# sourceMappingURL=index.esm.js.map
|