Quantcast
Channel: Active questions tagged react-native+typescript - Stack Overflow
Viewing all articles
Browse latest Browse all 6290

React question about geofire and useEffect

$
0
0

I have a question about react, Although I don't have much experience. I'm trying to do a query with geoFire and get the location after that find the data in my database.

Geofire creates an event that I'm subscribed and send me the closest locations.

This moment I have a query with geoFire and with an useEffect I do update data in my state for caching the values.

When I update my state this action breaks geofire event and must start again from the beginning. So this is a problem? or is there a better solution?

method getQuery

const firebaseRef: any = database().ref();const geoFire = new GeoFire(firebaseRef);  static getQuery(currentLocation: [number, number], radius: number): GeoQuery {  return geoFire.query({    center: currentLocation,    radius,  });}
import React, {useState, useEffect} from 'react';import {View, Text} from 'react-native';import {GeoPosition, GeoError} from 'react-native-geolocation-service';import {GeoQuery} from 'geofire';import {getCurrentLocation, LocationInfo} from '../../util/geolocation';import GeoFireService, {EVENT_TYPE} from './services/GeoFireService';// import AdService from './services/AdService';interface CurrentLocation {  [key: string]: {    location: [number, number];    distance: number;  };}const Ads = () => {  const [locationInfo, setLocationInfo] = useState({    latitude: 0,    longitude: 0,    altitude: 0,    accuracy: 0,  } as LocationInfo);  const [query, setQuery]: [GeoQuery | null, Function] = useState(null);  const [currentLocation, setCurrentLocation] = useState({} as CurrentLocation);  // set the current location  useEffect(() => {    getCurrentLocation(      (position: GeoPosition) => {        const {latitude, longitude, accuracy, altitude} = position.coords;        setLocationInfo({latitude, longitude, accuracy, altitude});      },      (err: GeoError) => {        console.log(err);      },    );  }, []);  // set the event query  useEffect(() => {    (async () => {      const geoFireQuery = await GeoFireService.getQuery(        [-34.5742746, -58.4744191],        30,      );      setQuery(geoFireQuery);      return () => geoFireQuery.cancel();    })();  }, []);  useEffect(() => {    if (query) {      (query as GeoQuery).on(        EVENT_TYPE.KEY_ENTERED,        (key: string, location: [number, number], distance: number) => {          console.log(key);          if (!currentLocation[key]) {            setCurrentLocation({              ...currentLocation,              [key]: {location, distance},            });          }        },      );    }  }, [query, currentLocation]);  return (<View><Text>        Latitude: {locationInfo.latitude} Longitude: {locationInfo.longitude}</Text>      {Object.keys(currentLocation).map((key: string) => (<Text key={key}>          Ubicacion: {key}, Km: {currentLocation[key].distance.toFixed(2)}</Text>      ))}</View>  );};export default Ads;

This moment I have 3 location but this repeats too much. The console output should only show three locations

[Sun Jun 07 2020 20:06:14.990]  LOG      1wr0cDenn4DmJ8S0xraG[Sun Jun 07 2020 20:06:14.120]  LOG      58zvRXriUELSW96HprHh[Sun Jun 07 2020 20:06:14.121]  LOG      58zvRXriUELSW96HprHh[Sun Jun 07 2020 20:06:14.122]  LOG      58zvRXriUELSW96HprHh[Sun Jun 07 2020 20:06:14.134]  LOG      58zvRXriUELSW96HprHh[Sun Jun 07 2020 20:06:14.145]  LOG      1wr0cDenn4DmJ8S0xraG[Sun Jun 07 2020 20:06:14.158]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.159]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.160]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.174]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.187]  LOG      1wr0cDenn4DmJ8S0xraG[Sun Jun 07 2020 20:06:14.188]  LOG      58zvRXriUELSW96HprHh[Sun Jun 07 2020 20:06:14.189]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.198]  LOG      1wr0cDenn4DmJ8S0xraG[Sun Jun 07 2020 20:06:14.199]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.240]  LOG      2Y5DBEsPQ1eFosxoAimB[Sun Jun 07 2020 20:06:14.286]  LOG      1wr0cDenn4DmJ8S0xraG

Viewing all articles
Browse latest Browse all 6290

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>