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]: onMapIdle is not getting triggered when the internet is unreachable #3713

Open
pranshuchittora opened this issue Dec 4, 2024 · 1 comment
Labels
bug 🪲 Something isn't working

Comments

@pranshuchittora
Copy link
Contributor

pranshuchittora commented Dec 4, 2024

Mapbox Implementation

Mapbox

Mapbox Version

11.8.0

React Native Version

0.75.x

Platform

iOS, Android

@rnmapbox/maps version

#main

Standalone component to reproduce

example/ShowMap.tsx

import React, { useState, useEffect } from 'react';
import { Alert } from 'react-native';
import Mapbox from '@rnmapbox/maps';
import { ButtonGroup } from '@rneui/base';

const ShowMap = () => {
  useEffect(() => {
    Mapbox.locationManager.start();

    return (): void => {
      Mapbox.locationManager.stop();
    };
  }, []);

  const onMapChange = (index: number, newStyleURL: Mapbox.StyleURL): void => {};

  const onUserMarkerPress = (): void => {
    Alert.alert('You pressed on the user location annotation');
  };

  return (
    <>
      <Mapbox.MapView
        testID={'show-map'}
        onMapIdle={() => {
          console.debug('======> onMapIdle');
        }}
        onCameraChanged={() => {
          console.debug('======> onCameraChanged');
        }}
      >
        <Mapbox.Camera
          followZoomLevel={12}
          followUserLocation
          animationDuration={0}
        />

        <Mapbox.UserLocation onPress={onUserMarkerPress} />
      </Mapbox.MapView>
    </>
  );
};

export default ShowMap;

Observed behavior and steps to reproduce

When the device is offline, onMapIdle method is not being triggered as expected.

Steps to repro

  1. Run the example app, replace the ShowMap.tsx file with the above code. Just add the console logs as mentioned
  2. Go offline and run the app.
  3. Open the ShowMap screen, try changing the layer.
  4. Pan the map and check for the logs

iOS

Screen.Recording.2024-12-04.at.16.36.22.mov

Android

Screen.Recording.2024-12-04.at.16.28.03.mp4

Expected behavior

onMapIdle should fire while being offline. It does fires when the device is online.

Notes / preliminary analysis

Most likely due to the SDK not able to fetch the tiles successfully, in turn not triggering the onMapIdle

Additional links and references

No response

Full Code

import React, { useState, useEffect } from 'react';
import { Alert } from 'react-native';
import Mapbox from '@rnmapbox/maps';
import { ButtonGroup } from '@rneui/base';

import sheet from '../../styles/sheet';
import { onSortOptions } from '../../utils';
import { ExampleWithMetadata } from '../common/ExampleMetadata'; // exclude-from-doc

const ShowMap = () => {
  const _mapOptions = Object.keys(Mapbox.StyleURL)
    .map((key) => {
      return {
        label: key,
        data: (Mapbox.StyleURL as any)[key], // bad any, because enums
      };
    })
    .sort(onSortOptions);

  const [styleURL, setStyleURL] = useState({ styleURL: _mapOptions[0].data });

  useEffect(() => {
    Mapbox.locationManager.start();

    return (): void => {
      Mapbox.locationManager.stop();
    };
  }, []);

  const onMapChange = (index: number, newStyleURL: Mapbox.StyleURL): void => {
    setStyleURL({ styleURL: newStyleURL });
  };

  const onUserMarkerPress = (): void => {
    Alert.alert('You pressed on the user location annotation');
  };

  return (
    <>
      <ButtonGroup
        buttons={_mapOptions.map((i) => i.label)}
        selectedIndex={_mapOptions.findIndex(
          (i) => i.data === styleURL.styleURL,
        )}
        onPress={(index) => onMapChange(index, _mapOptions[index].data)}
      />
      <Mapbox.MapView
        styleURL={styleURL.styleURL}
        style={sheet.matchParent}
        testID={'show-map'}
        onMapIdle={() => {
          console.debug('======> onMapIdle');
        }}
        onCameraChanged={() => {
          console.debug('======> onCameraChanged');
        }}
      >
        <Mapbox.Camera
          followZoomLevel={12}
          followUserLocation
          animationDuration={0}
        />

        <Mapbox.UserLocation onPress={onUserMarkerPress} />
      </Mapbox.MapView>
    </>
  );
};

export default ShowMap;

/* end-example-doc */

const metadata: ExampleWithMetadata['metadata'] = {
  title: 'Show Map',
  tags: ['Camera#followZoomLevel', 'UserLocation#onPress'],
  docs: `
Shows a map with the user location annotation enabled, and on press of the user location annotation, an alert is shown.
`,
};
ShowMap.metadata = metadata;
@Manikandan-saminathan
Copy link

In my case, I was using the following versions of React Native and Mapbox:

"react-native": "0.76.5",
"@rnmapbox/maps": "^10.1.33"

In React Native 0.76, the new architecture is enabled by default. The issue occurred when I needed to disable the new architecture.

Here’s how I resolved it:

  1. For iOS:
    Run the following command to disable the new architecture before installing pods:
RCT_NEW_ARCH_ENABLED=0 pod install
  1. For Android:
    Set the newArchEnabled property to false in your gradle.properties or the corresponding configuration file.

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

2 participants