blob: c52b8df05a76f96db1aaee20777e08da6c64a9d6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
import { useEffect } from 'react';
import { useSelector } from 'react-redux';
import dimensions from '../../common/theme/dimensions';
import { map } from '../core/MapView';
import { usePrevious } from '../../reactHelper';
import usePersistedState from '../../common/util/usePersistedState';
import { useAttributePreference } from '../../common/util/preferences';
const MapSelectedDevice = () => {
const selectedDeviceId = useSelector((state) => state.devices.selectedId);
const previousDeviceId = usePrevious(selectedDeviceId);
const selectZoom = useAttributePreference('web.selectZoom', 10);
const position = useSelector((state) => state.positions.items[selectedDeviceId]);
const [mapFollow] = usePersistedState('mapFollow', false);
useEffect(() => {
if ((selectedDeviceId !== previousDeviceId || mapFollow) && position) {
map.easeTo({
center: [position.longitude, position.latitude],
zoom: Math.max(map.getZoom(), selectZoom),
offset: [0, -dimensions.popupMapOffset / 2],
});
}
});
return null;
};
export default MapSelectedDevice;
|