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

RefreshControl refresh indicator is not shown on iOS #35779

Open
danielmorlock opened this issue Jan 5, 2023 · 15 comments
Open

RefreshControl refresh indicator is not shown on iOS #35779

danielmorlock opened this issue Jan 5, 2023 · 15 comments

Comments

@danielmorlock
Copy link

danielmorlock commented Jan 5, 2023

Description

The refresh indicator for <RefreshControl /> is not shown in<ScrollView> and related components like <VirtualizedList /> and <FlatList /> etc.. when refreshing is initially set as true (i.e. refreshing={true}).

This happens in both, when using Expo Go and when using the build iOS app.

Version

0.69.7, 0.70.6

Output of npx react-native info

System:
OS: Linux 5.15 Gentoo Linux
CPU: (12) x64 Intel(R) Core(TM) i9-8950HK CPU @ 2.90GHz
Memory: 16.15 GB / 62.44 GB
Shell: 5.9 - /bin/zsh
Binaries:
Node: 16.17.0 - ~/.config/nvm/versions/node/v16.17.0/bin/node
Yarn: 1.22.19 - ~/workspace/fgs/mobile/node_modules/.bin/yarn
npm: 2.15.12 - ~/workspace/fgs/mobile/node_modules/.bin/npm
Watchman: Not Found
SDKs:
Android SDK: Not Found
IDEs:
Android Studio: Not Found
Languages:
Java: 11.0.15 - /usr/bin/javac
npmPackages:
@react-native-community/cli: Not Found
react: 18.0.0 => 18.0.0
react-native: 0.69.6 => 0.69.6
npmGlobalPackages:
react-native: Not Found

Steps to reproduce

<ScrollView
        contentContainerStyle={styles.scrollView}
        refreshControl={
          <RefreshControl
            refreshing={true}
            onRefresh={onRefresh}
          />
        }
      >
        <Text>
        This refresh indicator is not shown on iOS
        </Text>
      </ScrollView>

Snack, code example, screenshot, or link to a repository

https://snack.expo.dev/@danielmorlock/refresh-indicator-bug

@ngima
Copy link

ngima commented Jan 23, 2023

I'm also having this issue. To resolve I'm setting refreshing boolean after 10 mills

const fetchData = ()=>{
    this.setRefreshing(true)
    //... data fetching logic
}


React.useEffect(() => {
    setTimeout(() => {
        state.fetchData()
    }, 10)
}, [])

@built-by-as
Copy link

I am also having this issue, the RefreshControl will not show when initially set to true. It will only show on pull to refresh

@Alecattie
Copy link

I am also having this issue, any update?

@madox2
Copy link

madox2 commented Aug 17, 2023

I was able to work around with setTimeout as @ngima mentioned above:

import { useEffect, useState } from 'react';
import {
  RefreshControlProps,
  RefreshControl as RefreshControlRN,
} from 'react-native';

export function RefreshControl({ refreshing, ...other }: RefreshControlProps) {
  const [isRefreshing, setRefreshing] = useState(false);
  useEffect(() => {
    setTimeout(() => {
      setRefreshing(refreshing);
    }, 10);
  }, [refreshing]);
  return <RefreshControlRN refreshing={isRefreshing} {...other} />;
}

High5Apps added a commit to High5Apps/organize-rn that referenced this issue Oct 23, 2023
- Not present on Android
- Not present for any subsequent tabs
- Not present when manually pulling-to-refresh
- Others are facing this in facebook/react-native#35779
- Hack suggested in facebook/react-native#35779 (comment)
High5Apps added a commit to High5Apps/organize-rn that referenced this issue Oct 23, 2023
- Not present on Android
- Not present for any subsequent tabs
- Not present when manually pulling-to-refresh
- Others are facing this in facebook/react-native#35779
- Hack suggested in facebook/react-native#35779 (comment)
  - A 10 ms timeout worked on the simulator, but failed on the physical device
  - As such, I raised the timeout to 100 ms, which works on both
Copy link

This issue is stale because it has been open 180 days with no activity. Remove stale label or comment or this will be closed in 7 days.

@github-actions github-actions bot added the Stale There has been a lack of activity on this issue and it may be closed soon. label Feb 14, 2024
@zackify
Copy link

zackify commented Feb 14, 2024

It’s still a problem…

@github-actions github-actions bot removed the Stale There has been a lack of activity on this issue and it may be closed soon. label Feb 15, 2024
@saurori
Copy link

saurori commented Feb 21, 2024

I am experiencing this exact problem. In the code example (or in your app), if you pull the screen down a bit you can see the loading icon so it's there, just not visible.

@w3company-leo
Copy link

same

@Thanhal-P-A
Copy link

I have implemented a workaround by programmatically scrolling the view slightly, which makes the hidden refresh control visible on iOS.

import React, { useRef, useState, useEffect } from 'react';
import { ScrollView, RefreshControl } from 'react-native';

const App = () => {
  ....
  const [loading, setLoading] = useState<boolean>(true);

  const scrollRef = useRef<ScrollView>(null);

  useEffect(() => {
    setTimeout(() => {
      scrollRef?.current?.scrollTo({ y: -50 });
    }, 500);
    fetchData();
  }, []);

  const fetchData = () => {
    setLoading(true)
    // Your refresh logic here
    setLoading(false)
  };

  ....
  
  return (
    <ScrollView
      ref={scrollRef}
      refreshControl={
        <RefreshControl
          refreshing={loading}
          onRefresh={fetchData}
        />
      }
    >
    ....
    ....
    </ScrollView>
  );
};

The above code uses a useRef to hold a reference to the <ScrollView>. In the useEffect, it programmatically scrolls the view slightly upwards after a delay, which makes the refresh control visible.

This workaround ensures that the refresh control is displayed properly on iOS when the refreshing prop is true without pulling.

@lsarni
Copy link

lsarni commented Jul 16, 2024

We are having the same issue with FlashList. It's also reported on that repo but the issue is not of the library but of react native.
Shopify/flash-list#875

@ashwini-ksingh
Copy link

Working fine for me with recent unreleased fixes. (tested with 0.75.4)
#46655
#46628

@thoughtworks-tcaceres
Copy link

Facing this issue currently as well.
react native : 0.73.6
flashlist: 1.7.0

@jerone
Copy link

jerone commented Dec 3, 2024

This issue has been reported before (and sometimes incorrectly closed): #24855 & #37308 & #36173 & #24530
Some of those issues are related to a FlatList, while this story is related to a ScrollView.

For us this is still reproducible:

  expo-env-info 1.2.1 environment info:
    System:
      OS: Windows 11 10.0.22631
    Binaries:
      Node: 22.6.0
      Yarn: 1.22.22
      npm: 10.9.1
    IDEs:
      Android Studio: AI-242.23339.11.2421.12550806
    npmPackages:
      expo: ~52.0.14 => 52.0.14
      expo-router: ~4.0.11 => 4.0.11
      react: 18.3.1 => 18.3.1
      react-dom: 18.3.1 => 18.3.1
      react-native: 0.76.3 => 0.76.3
      react-native-web: ^0.19.13 => 0.19.13
    Expo Workflow: bare

Please upvote the issue 👍to get more attention.

@shuo-hiwintech
Copy link

+1

@anilalanofc
Copy link

Having the same issue with Flatlist and Flashlist

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests