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

Detecting Scroll Offset to Trigger an Action When PDF is Fully Scrolled #869

Open
RezaPN opened this issue Sep 17, 2024 · 5 comments
Open

Comments

@RezaPN
Copy link

RezaPN commented Sep 17, 2024

Hi,

I am trying to access the onScroll event in a scrollable component to detect the current scroll offset. My use case involves a PDF file containing a terms and conditions document, and I need to detect how far the user has scrolled through the document. Once the user reaches the bottom and fully scrolls through the PDF, a "Next" button should appear.

However, with the current props available, I can only detect which page the user is on, and I'm unable to determine if the scroll has fully reached the end of the content.

Is there any solution or workaround for this?

@joffblack
Copy link

I also have a very similar issue to @RezaPN.

Any help would be great..

@RaafatDev
Copy link

RaafatDev commented Sep 24, 2024

I have a similar use case ..

currently as a temporary solution to decide that the user has gone through all document pages, I have enabled the paging with the property enablePaging and when the user reaches the final page I can make sure that he has gone through all the document pages and I can show the hidden next-button

@rajivchaulagain
Copy link

rajivchaulagain commented Oct 22, 2024

try this once

import React, { useRef, useState } from 'react';
import { ScrollView, View, Button, StyleSheet } from 'react-native';
import Pdf from 'react-native-pdf';

const PdfViewer = ({ currentUrl, authCookie }) => {
  const [showNextButton, setShowNextButton] = useState(false);
  const scrollViewRef = useRef(null);

  const handleScroll = (event) => {
    const { contentOffset, layoutMeasurement, contentSize } = event.nativeEvent;
    
    if (contentOffset.y + layoutMeasurement.height >= contentSize.height) {
      setShowNextButton(true);
    } else {
      setShowNextButton(false);
    }
  };

  return (
    <View style={styles.container}>
      <ScrollView 
        ref={scrollViewRef}
        onScroll={handleScroll}
        scrollEventThrottle={16} 
      >
        <Pdf
          trustAllCerts={Platform.OS === 'ios'}
          style={styles.pdf}
          source={{
            uri: currentUrl,
            headers: { Cookie: authCookie },
          }}
        />
      </ScrollView>
      {showNextButton && (
        <Button title="Next" onPress={() => {/* Handle next action */}} />
      )}
    </View>
  );
};

const styles = StyleSheet.create({
  container: {
    flex: 1,
  },
  pdf: {
    flex: 1,
    height: 1000, 
  },
});

export default PdfViewer;

@RezaPN
Copy link
Author

RezaPN commented Oct 23, 2024

try this once

import React, { useRef, useState } from 'react';
import { ScrollView, View, Button, StyleSheet } from 'react-native';
import Pdf from 'react-native-pdf';

const PdfViewer = ({ currentUrl, authCookie }) => {
  const [showNextButton, setShowNextButton] = useState(false);
  const scrollViewRef = useRef(null);

  const handleScroll = (event) => {
    const { contentOffset, layoutMeasurement, contentSize } = event.nativeEvent;
    
    if (contentOffset.y + layoutMeasurement.height >= contentSize.height) {
      setShowNextButton(true);
    } else {
      setShowNextButton(false);
    }
  };

  return (
    <View style={styles.container}>
      <ScrollView 
        ref={scrollViewRef}
        onScroll={handleScroll}
        scrollEventThrottle={16} 
      >
        <Pdf
          trustAllCerts={Platform.OS === 'ios'}
          style={styles.pdf}
          source={{
            uri: currentUrl,
            headers: { Cookie: authCookie },
          }}
        />
      </ScrollView>
      {showNextButton && (
        <Button title="Next" onPress={() => {/* Handle next action */}} />
      )}
    </View>
  );
};

const styles = StyleSheet.create({
  container: {
    flex: 1,
  },
  pdf: {
    flex: 1,
    height: 1000, 
  },
});

export default PdfViewer;

The problem with this is that if there are many pages (for example, 10 pages), the bottom part of the PDF does not render (this likely happens due to lazy loading).

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

No branches or pull requests

5 participants
@joffblack @RaafatDev @RezaPN @rajivchaulagain and others