react-use/src/useGeolocation.ts
2019-03-31 12:16:17 +11:00

63 lines
1.6 KiB
TypeScript

import {useState, useEffect} from 'react';
export interface GeoLocationSensorState {
loading: boolean,
accuracy: number | null,
altitude: number | null,
altitudeAccuracy: number | null,
heading: number | null,
latitude: number | null,
longitude: number | null,
speed: number | null,
timestamp: number | null,
error?: Error | PositionError
}
const useGeolocation = (): GeoLocationSensorState => {
const [state, setState] = useState<GeoLocationSensorState>({
loading: true,
accuracy: null,
altitude: null,
altitudeAccuracy: null,
heading: null,
latitude: null,
longitude: null,
speed: null,
timestamp: Date.now(),
});
let mounted = true;
let watchId: any;
const onEvent = (event: any) => {
if (mounted) {
setState({
loading: false,
accuracy: event.coords.accuracy,
altitude: event.coords.altitude,
altitudeAccuracy: event.coords.altitudeAccuracy,
heading: event.coords.heading,
latitude: event.coords.latitude,
longitude: event.coords.longitude,
speed: event.coords.speed,
timestamp: event.timestamp,
});
}
};
const onEventError = (error: PositionError) =>
mounted && setState(oldState => ({...oldState, loading: false, error}));
useEffect(() => {
navigator.geolocation.getCurrentPosition(onEvent, onEventError);
watchId = navigator.geolocation.watchPosition(onEvent, onEventError);
return () => {
mounted = false;
navigator.geolocation.clearWatch(watchId);
};
}, []);
return state;
};
export default useGeolocation;