#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, }, }); ```