#maps Component
```import React, {useEffect, useRef, useState} from 'react';
import {
Dimensions,
Image,
Platform,
StyleSheet,
Text,
TouchableOpacity,
View,
} from 'react-native';
import MapView, {
AnimatedRegion,
Marker,
Animated as AnimatedMap,
} from 'react-native-maps'; // remove PROVIDER_GOOGLE import if not using Google Maps
import MapViewDirections from 'react-native-maps-directions';
import {useTheme} from 'react-native-paper';
import Animated from 'react-native-reanimated';
import BottomSheet from 'reanimated-bottom-sheet';
import {GOOGLE_MAPS_APIKEY} from '../../constants/googlekey';
import mapIcons from '../../constants/mapIcons';
import {getCurrentLocation, locationPermission} from './helper';
// const origin = {latitude: 37.3318456, longitude: -122.0296002};
// const destination = {latitude: 37.771707, longitude: -122.4053769};
const {width, height} = Dimensions.get('window');
const screen = Dimensions.get('window');
const ASPECT_RATIO = screen.width / screen.height;
const LATITUDE_DELTA = 0.6;
const LONGITUDE_DELTA = LATITUDE_DELTA * ASPECT_RATIO;
function isCoordinateInRegion(coordinate, region) {
const top = region.latitude + region.latitudeDelta / 2;
const bot = region.latitude - region.latitudeDelta / 2;
const right = region.longitude + region.logitudeDelta / 2;
const left = region.longitude - region.logitudeDelta / 2;
return (
coordinate.latitude <= top &&
coordinate.latitude >= bottom &&
coordinate.longitude <= right &&
coordinate.longitude >= left
);
}
export default function MapScreen() {
const markerRef = useRef();
const {colors} = useTheme();
const userLocationCoordinates = useRef(
new AnimatedRegion({
latitude: 17.385,
longitude: 78.4867,
latitudeDelta: LATITUDE_DELTA,
longitudeDelta: LONGITUDE_DELTA,
}),
);
const [state, setState] = useState({
curLoc: {
latitude: 17.385,
longitude: 78.4867,
},
destinationCords: {
latitude: 18.5204,
longitude: 73.8567,
},
isLoading: false,
// coordinate: new AnimatedRegion({
// latitude: 17.385,
// longitude: 78.4867,
// latitudeDelta: LATITUDE_DELTA,
// longitudeDelta: LONGITUDE_DELTA,
// }),
});
const {curLoc, destinationCords, isLoading, coordinate} = state;
const getLiveLocation = async () => {
const locPermission = await locationPermission();
console.log('loaction Permisssom', locPermission);
if (locPermission) {
// const res = await getCurrentLocation();
// console.log('res....', res);
const {latitude, longitude} = await getCurrentLocation();
console.log('get live location after 4 second', latitude, longitude);
animate(latitude, longitude);
setState(prev => ({
...prev,
curLoc: {latitude, longitude},
// coordinate: new AnimatedRegion({
// latitude: latitude,
// longitude: longitude,
// latitudeDelta: LATITUDE_DELTA,
// longitudeDelta: LONGITUDE_DELTA,
// }),
}));
}
};
const animateToLiveLocation = async () => {
const locPermission = await locationPermission();
console.log('animateLiveLocation', locPermission);
if (locPermission) {
// const res = await getCurrentLocation();
// console.log('res....', res);
const {latitude, longitude} = await getCurrentLocation();
console.log(
'get live location after 4 second & animateLive Location',
latitude,
longitude,
);
animate(latitude, longitude);
setState(prev => ({
...prev,
curLoc: {latitude, longitude},
// coordinate: new AnimatedRegion({
// latitude: latitude,
// longitude: longitude,
// latitudeDelta: LATITUDE_DELTA,
// longitudeDelta: LONGITUDE_DELTA,
// }),
}));
}
};
useEffect(() => {
getLiveLocation();
const interval = setInterval(() => {
animateToLiveLocation();
}, 6000);
return () => clearInterval(interval);
}, []);
const animate = (latitude, longitude) => {
const newCoordinate = {latitude, longitude};
if (Platform.OS == 'android') {
if (markerRef.current) {
markerRef.current.animateMarkerToCoordinate(newCoordinate, 7000);
}
} else {
userLocationCoordinates.current.timing(newCoordinate).start();
}
mapRef.current.fitToCoordinates([newCoordinate], {
// edgePadding: {top: 50, right: 50, bottom: 400, left: 50},
});
};
const onCenter = () => {
mapRef.current.animateToRegion({
latitude: curLoc.latitude,
longitude: curLoc.longitude,
latitudeDelta: LATITUDE_DELTA,
longitudeDelta: LONGITUDE_DELTA,
});
};
const renderInner = () => (
<View style={styles.panel}>
<View
style={{
flexDirection: 'row',
paddingRight: 20,
alignItems: 'center',
}}>
<Image
style={{height: 40, width: 40}}
// source={{
// uri:
// '',
// }}
source={require('./../../assets/dump-truck.png')}
/>
<Text style={{fontSize: 15, color: 'black', marginLeft: 10}}>
City Tower, Mumbai Hwy, Judges Colony, New Malakpet, Hyderabad,
</Text>
</View>
<View
style={{
flexDirection: 'row',
paddingRight: 20,
alignItems: 'center',
}}>
<Image
style={{height: 40, width: 40}}
// source={{
// uri:
// '',
// }}
source={require('./../../assets/tipper.png')}
/>
<Text style={{fontSize: 15, color: 'black', marginLeft: 10}}>
Shivaji Marg, Vinayaka Hills, Vignanapuri Teachers Colony, B N Reddy
Nagar, Hyderabad
</Text>
</View>
<View style={{flexDirection: 'row', margin: 5}}>
{/* <Icon name="dot-single" style={{color: 'red'}} size={35} /> */}
<Text style={{fontSize: 15, color: 'black'}}>Commodity : </Text>
<Text style={{fontWeight: 'bold'}}> Black Dirt</Text>
</View>
<TouchableOpacity
style={styles.panelButton}
onPress={() => bs.current.snapTo(1)}>
<Text style={styles.panelButtonTitle}>Start</Text>
</TouchableOpacity>
</View>
);
const renderHeader = () => (
<View style={styles.header}>
<View style={styles.panelHeader}>
<View style={styles.panelHandle} />
</View>
</View>
);
const iosSnapPoints = [590, 430];
const bs = React.createRef();
const fall = new Animated.Value(1);
const mapRef = React.useRef();
return (
<View style={styles.container}>
<AnimatedMap
// provider={PROVIDER_GOOGLE} // remove if not using Google Maps
onRegionChange={console.log}
ref={mapRef}
style={styles.map}
initialRegion={{
...curLoc,
latitudeDelta: LATITUDE_DELTA,
longitudeDelta: LONGITUDE_DELTA,
}}>
{/* {Object.keys(curLoc).length > 0 && ( */}
<Marker.Animated
ref={markerRef}
coordinate={userLocationCoordinates.current}
image={mapIcons.currentLocation}
/>
{/* )} */}
{Object.keys(destinationCords).length > 0 && (
<Marker coordinate={destinationCords} image={mapIcons.destination} />
)}
{Object.keys(destinationCords).length > 0 && (
<MapViewDirections
origin={curLoc}
destination={destinationCords}
apikey={GOOGLE_MAPS_APIKEY}
strokeWidth={3}
strokeColor="#223664"
optimizeWaypoints={true}
onStart={params => {
console.log(
`Started routing between "${params.origin}" and "${params.destination}"`,
);
}}
onReady={result => {
console.log(`Distance: ${result.distance} km`);
console.log(`Duration: ${result.duration} min.`);
mapRef.current.fitToCoordinates(result.coordinates, {
edgePadding: {
// right: 50,
// left: 50,
// bottom: 300,
// top: 100,
},
});
}}
/>
)}
</AnimatedMap>
<TouchableOpacity
style={{
position: 'absolute',
// bottom: 0,
// right: 0,
left: 0,
top: 0,
}}
onPress={onCenter}>
<Image source={mapIcons.greenIndicator} />
</TouchableOpacity>
<BottomSheet
ref={bs}
snapPoints={Platform.OS === 'android' ? [500, 400] : iosSnapPoints}
renderContent={renderInner}
renderHeader={renderHeader}
initialSnap={0}
callbackNode={fall}
enabledGestureInteraction={true}
enabledHeaderGestureInteraction={true}
/>
</View>
);
}
const styles = StyleSheet.create({
panel: {
padding: 20,
backgroundColor: '#FFFFFF',
paddingTop: -20,
// borderTopLeftRadius: 20,
// borderTopRightRadius: 20,
// shadowColor: '#000000',
// shadowOffset: {width: 0, height: 0},
// shadowRadius: 5,
// shadowOpacity: 0.4,
// flex: 1,
// marginLeft: -400,
},
container: {
...StyleSheet.absoluteFillObject,
height: height,
width: width,
justifyContent: 'flex-end',
alignItems: 'center',
flex: 1,
},
map: {
...StyleSheet.absoluteFillObject,
},
panelButton: {
padding: 13,
borderRadius: 10,
backgroundColor: '#223664',
alignItems: 'center',
marginVertical: 7,
},
panelButtonTitle: {
fontSize: 17,
fontWeight: 'bold',
color: 'white',
},
header: {
backgroundColor: '#FFFFFF',
shadowColor: '#333333',
shadowOffset: {width: -1, height: -3},
shadowRadius: 2,
shadowOpacity: 0.4,
// elevation: 5,
paddingTop: 20,
borderTopLeftRadius: 20,
borderTopRightRadius: 20,
},
panelHeader: {
alignItems: 'center',
},
panelHandle: {
width: 40,
height: 8,
borderRadius: 4,
backgroundColor: '#00000040',
marginBottom: 10,
},
});
```