Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug]: Mapbox.Location component not woking properly when using React Native 0.76 with new architecture #3681

Open
EmilJunker opened this issue Nov 4, 2024 · 3 comments
Labels
bug 🪲 Something isn't working

Comments

@EmilJunker
Copy link

EmilJunker commented Nov 4, 2024

Mapbox Implementation

Mapbox

Mapbox Version

default

React Native Version

0.76.1

Platform

Android

@rnmapbox/maps version

10.1.33

Standalone component to reproduce

import React, { useEffect, useState } from 'react';
import { StyleSheet, View } from 'react-native';
import Mapbox, { requestAndroidLocationPermissions } from '@rnmapbox/maps';

const MapViewWithLocation = () => {
  const [haveLocationPermission, setHaveLocationPermission] = useState(false);

  useEffect(() => {
    requestAndroidLocationPermissions().then((havePermission) => setHaveLocationPermission(havePermission));
  }, []);

  const onLocationUpdate = (location: Mapbox.Location) => {
    console.log('MAPBOX-LOCATION:', location);
  }

  return (
    <Mapbox.MapView style={styles.map}>
      {haveLocationPermission && <Mapbox.UserLocation visible={true} minDisplacement={0} onUpdate={onLocationUpdate} />}
    </Mapbox.MapView>
  );
}

const styles = StyleSheet.create({
  map: {
    flex: 1
  }
});

export default MapViewWithLocation;

Observed behavior and steps to reproduce

Include the above component in a React Native 0.76 app with the new architecture enabled. Then build and run the app for Android. When prompted, give the app permission to access your location.

Then observe the following problems:

  • The onLocationUpdate callback only gets called once and is never updated when the location changes
  • The location pin on the map also doesn't update when the location changes
  • The following error message appears in the console:
Mapbox [error] ViewTagResolver | view: null found with tag: 428 but it's either null or not the correct type

Expected behavior

The onLocationUpdate callback should be called every time there is a new location (i.e. about once every second). The location pin displayed on the map should update accordingly.

Notes / preliminary analysis

If you set newArchEnabled=false in android\gradle.properties and rebuild the app, everything will work properly.

Additional links and references

Minimal reproducible example app: https://github.com/EmilJunker/RNMapboxTestApp

@gabri3l0
Copy link

I have the same issue @EmilJunker. Were you able to solve it?

@EmilJunker
Copy link
Author

@gabri3l0 I disabled the new architecture for now.

@two3d
Copy link

two3d commented Jan 27, 2025

Use this : <MapView instead of this: <Mapbox.MapView and import MapView from rnmapbox.
EDIT: Sometimes the error is displayed, sometimes not... re-saving the file I'm working on after encountering an error removes the error message.
EDIT : On reflection, it may be that Mapbox was not yet loaded at the time of the error, so there may be a good way to initialize the map, as here, with the “render()” method.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug 🪲 Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants