Code Monkey home page Code Monkey logo

rn-pdf-reader-js's Introduction

PDF Reader

Android support 🚀





npm version npm downloads

Read a PDF just with JS (no native libs needed)

Requirements

  • 👉Install react-native-webview on your own!
  • 👉Install expo-file-system on your own!
  • 👉Install expo-constants on your own!
  • Use it into Expo app (from expo client, Standalone app or ExpoKit app).
  • Only React-Native 0.59-0.60+ support, Expo SDK 33-36+

PRs are welcome...

Example

import * as React from 'react'
import { View } from 'react-native'
import PDFReader from 'rn-pdf-reader-js'

export default class App extends React.Component {
  render() {
    return (
      <PDFReader
        source={{
          uri: 'http://gahp.net/wp-content/uploads/2017/09/sample.pdf',
        }}
      />
    )
  }
}

See more detailed example into App.tsx file.

Props

interface Source {
  uri?: string // can be local or served on the web (ie. start with `https://` or `file://`)
  base64?: string // should start with `data:application/pdf;base64,`. A base64 encoded pdf file tends to start with `JVBERi0xL` so your complete string should look something like this: `data:application/pdf;base64,JVBERi0xL...`
  headers?: { [key: string]: string }
}

interface Props {
  source: Source
  style?: View['props']['style'] // style props to override default container style
  webviewStyle?: WebView['props']['style'] // style props to override default WebView style
  webviewProps?: WebView['props']
  noLoader?: boolean
  useGoogleReader?: boolean // If you are not worried about confidentiality
  withScroll?: boolean // Can cause performance issue
  withPinchZoom?: boolean
  customStyle?: {
    readerContainer?: CSS.Properties
    readerContainerDocument?: CSS.Properties
    readerContainerNumbers?: CSS.Properties
    readerContainerNumbersContent?: CSS.Properties
    readerContainerZoomContainer?: CSS.Properties
    readerContainerZoomContainerButton?: CSS.Properties
    readerContainerNavigate?: CSS.Properties
    readerContainerNavigateArrow?: CSS.Properties
  }
  onLoad?(): void // callback that runs after WebView is loaded
  onLoadEnd?(): void // callback that runs after WebView is loaded
  onError?(): void // callback that runs when WebView is on error
}

Possibilities

Render type Platform Source prop
Custom PDF reader Android uri or base64
Direct from WebView iOS uri or base64
Google PDF Reader Android, iOS uri

What rn-pdf-reader-js use?

  • react-pdf (pdf.js)
  • WebView
  • Base64

FAQ

Hire an expert!

Looking for a ReactNative freelance expert with more than 12 years experience? Contact me from my website!

rn-pdf-reader-js's People

Contributors

azuy212 avatar boris-burgos avatar doshidak avatar garrinmf avatar guichaguri avatar jliphard avatar mmoraisa avatar muhammadady07 avatar norezark avatar psergei avatar rgordon95 avatar richjeffery avatar sguha00 avatar sungsong88 avatar umbertoghio avatar victorcabeceira avatar xcarpentier avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar

rn-pdf-reader-js's Issues

Unable to dynamically change PDF URI

So I noticed that there's a loading icon whenever the URI is null, but I couldn't seem to actually get it to work as I would assume it should; show whenever a pdf is not fully loaded in. So I added a quick method that waited for the PDF to load before actually trying to access it, but I noticed that it doesn't rerender the PDF component.

Sidenote: I can integrate the async loading of assets for you, if I ever get time

loadPDF (url) {
    FileSystem.downloadAsync(url, FileSystem.cacheDirectory + 'cachedPDF.pdf').then((uri) => {
      if (this.state.current.file.data.url === url) {
        this.setState(state => {
          state.currentPDF = uri.uri
          state.current.ready = true

          return state
        })
      }
    })
  }
    return (
      <LoggedIn title='Recruiting Calendars' {...this.props} hideBack={true} onBack={this.state.current !== null ? () => this.backToList() : undefined}>
        <View style={style.horizontalContainer}>
          <Animatable.View style={style.horizontalContainerChild} ref={'_slide1'}>
            <KeyboardAwareScrollView bounces={false}>
              <Calendars />
            </KeyboardAwareScrollView>
          </Animatable.View>
          <Animatable.View style={style.horizontalContainerChild} ref={'_slide2'}>
            {this.state.current !== null &&
              <PDFReader
                source={{ uri: this.state.currentPDF }}
                style={{
                  paddingTop: 0
                }}
              />
            }
          </Animatable.View>
        </View>
      </LoggedIn>
    )

can't render jpg von Android

If we want to render a base64 encoded jpg (as src in an image element) with the pdf-reader, it doesn't show up on Android. However on iOS it is works normally.

left image is base64/jpeg (not showing) right image is base64/png (showing)
image

This is a base64 that doesn't show up on Android:



Doesn't work for local files

When you try to open a local file, the component gives the message "source props is not correct" and keeps loading.

I'm just sending a document that is inside a folder on my project.

My call to the PDF Reader:
return (

<PDFReader
source={{ uri: "../../assets/doc/bio_security_measurements.pdf" }}
/>

)

My Package.json

{
"name": "empty-project-template",
"main": "node_modules/expo/AppEntry.js",
"private": true,
"scripts": {
"start": "expo start",
"android": "expo start --android",
"ios": "expo start --ios",
"eject": "expo eject"
},
"dependencies": {
"expo": "^32.0.0",
"expo-cli": "^2.15.3",
"lodash": "latest",
"native-base": "^2.8.1",
"react": "16.5.0",
"react-native": "https://github.com/expo/react-native/archive/sdk-32.0.0.tar.gz",
"react-native-signature-canvas": "^1.3.0",
"react-navigation": "^2.18.0",
"rn-pdf-reader-js": "^0.2.3"
}
}

Add to reactnative.gallery :)

Hi!

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I help community when I can: sharing my works on open-source, like you do!

But it's hard to be visible sometimes! Right?

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

What do you think?

Do you want to be informed about it?
::BETA:: => https://reactnative.gallery 📬

Or chat about it?
::SLACK:: => https://slack.reactnative.gallery 💬

Question: What is the reasoning for using cached images of the PDF? + Possible solution to zooming

@xcarpentier I've been tinkering around with this Repo locally for the past few days for a project that requires Android PDF viewing with zoom capabilities using Expo without linking. I wanted to ask you why you set up the project to cache a base64 image of the PDF after the page initially loads for the first time? It's difficult to figure out which is being rendered and zooming logic would have to be doubled for images and the <Page /> elements. I ask, because I've found a possible solution to zooming, but wanted to feel out how needed those cached elements are to you.

Here's what I got in gif form:
gif
link https://thumbs.gfycat.com/DeadPoisedBrownbutterfly-max-14mb.gif

I've hacked up this a lot, and I essentially removed all of your cached imaging functions and am now directly rendering the <Page /> and editing the scale prop of the <Page /> element from react-pdf via two small buttons in the bottom corner. I've also edited your styling to make the canvas scroll-able and the buttons and stuff fixed in the webView.

One of the issues I ran into when testing was with clicking the zoom buttons extra fast caused the rendering of Page to fail and cause the whole app to crash. Fixing this was easier than I thought though. <Page /> has another function prop called onRenderSuccess that let's me set a class variable I dubbed __isPageRendering and set it to true whenever the user clicks the zoom button within my scale requirements and I'm not already rendering. Then set it to false once that onRenderSuccess is called allowing the user to zoom again. It's really seamless and has worked flawlessly so far.

I did attempt to get pinch zoom working via Hammer.js, but it had a lot of side effects that I wasn't willing to work it through 😞 .

When I found this repo and saw what was possible via webpack in a webview I was really impressed. I'm surprised no one else has seen this idea, but I wish it was documented a little better in case anyone wanted to edit the styling of your buttons and such like I had to.

Let me know what I can do to help
~Colin

¿How pass uri for state?

Hi

I am trying pass the uri for the state but not works
I need than uri will be dynamic

  render() {
    //string of the route
    // 'https://dev.fundacionidi.org/admin-app-cuc/index.php/archivo/?f=app_reglamento/rutaArchivo_1_20181126170006.pdf'
    const { route } = this.state
    return (
      <PdfReader source={{ uri: route }} />
    );
  }

Only rendering 2nd page of PDF on Android

Thanks for making this! It's working great for me on iOS, but I'm having a weird issue where only the second page is rendering on Android. It only seems to happen with PDF's being generated by a postcard company's API we're trying to use, example:

https://s3.us-west-2.amazonaws.com/assets.lob.com/psc_c6054c7d048d585d.pdf?AWSAccessKeyId=AKIAIILJUBJGGIBQDPQQ&Expires=1532565500&Signature=Gu86u4f6n2rjnrmewFIz3UNnA0k%3D

Full code:

<View style={styles.container}>
          <PDFReader
            source={{
              uri: "https://s3.us-west-2.amazonaws.com/assets.lob.com/psc_c6054c7d048d585d.pdf?AWSAccessKeyId=AKIAIILJUBJGGIBQDPQQ&Expires=1532565500&Signature=Gu86u4f6n2rjnrmewFIz3UNnA0k%3D"
            }}
          />
</View>

Style:

const styles = StyleSheet.create({
  container: {
    flex: 1,
    paddingTop: 0,
    backgroundColor: "#525659"
  }
});

Display simple pdf on android like iOS when there is only one screeen

Thanks for the awesome component. Is there possible to remove the extra file option on android like remove plus and minus buttons and up, down arrow buttons on bottom and page counter on top.

iOS seems okay. It is happening on android because of allowFileAccess webView props. but is there any workaround to remove the extra content.

Thanks

Add to reactnative.gallery :)

Hi @xcarpentier!

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I try to help community when I can: sharing my works on open-source, like you do! :)

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

Do you want to be informed about it?
::BETA:: => https://reactnative.gallery 📬

Typescript Support

Hey!
I liked the work done here just one piece is missing Typing for typescript.
Plese add it.

Thanks!

IOS Padding Still Exists

I am using v0.2.1 and it seems that this error hasn't been fixed. I am attaching a screenshot and the
code.

https://gyazo.com/6b2bbf4056e9c6b1daad2e7e6bb4d6cb

render function dumbed down

    render () {
      return (
        <LoggedIn title='Recruiting Calendars' {...this.props} hideBack={true} onBack={this.state.current !== null ? () => this.backToList() : undefined}>
          <View style={style.horizontalContainer}>
            <Animatable.View style={style.horizontalContainerChild} ref={'_slide1'}>
              <KeyboardAwareScrollView bounces={false}>
                <Calendars />
              </KeyboardAwareScrollView>
            </Animatable.View>
            <Animatable.View style={style.horizontalContainerChild} ref={'_slide2'}>
              {this.state.current !== null &&
                <PDFReader
                  source={{ uri: this.state.current !== null ? this.state.current.file.data.url : null }}
                />
              }
            </Animatable.View>
          </View>
        </LoggedIn>
      )
    }

styles

const style = StyleSheet.create({
  horizontalContainer: {
    flex: 1,
    flexDirection: 'row',
    margin: 0,
    padding: 0
  },
  horizontalContainerChild: {
    flex: 0,
    width: width,
    padding: 0,
    margin: 0
  },
  calendar: {
    backgroundColor: Colors.white,
    padding: 20,
    paddingTop: 20,
    paddingBottom: 20,
    borderBottomColor: 'rgba(0,0,0,0.1)'
  },
  calendarText: {
    color: Colors.black,
    fontFamily: Fonts.header,
    fontSize: 20,
    marginBottom: -10,
    textTransform: 'uppercase'
  },
})

No PDF displayed on click

I have a screen in which when you click on the touchable, a PDF is supposed to render. I can make the PDF render if I manually put in the PDF code. But, when I use the touchable, all that is displayed is a small grey bar. I have been trying to fix this for over 3 weeks now, but I can not find a solution. Here's my code. Any ideas on how to fix this?

import React from 'react';
import Touchable from 'react-native-platform-touchable';
import {
	Dimensions,
	Image,
	ListView,
	Platform,
	ScrollView,
	SectionList,
	StyleSheet,
	Text,
	TouchableOpacity,
	View,
} from 'react-native';

import {
	WebBrowser,
	Constants,
	Icon,
} from 'expo';

import {
	MonoText
} from '../components/StyledText';

import firebase from "firebase";
import PDFReader from 'rn-pdf-reader-js';
import TabBarIcon from '../components/TabBarIcon';
import Colors from '../constants/Colors';

/*import {
	articleList,
	storageRef,
	allArticlesRef,
	addArticlesToList,
} from '../data/GetArticles';
*/

// Initialize Firebase

var config = {
	apiKey: "...",
	authDomain: "....firebaseapp.com",
	databaseURL: "https://....firebaseio.com",
	projectId: "...",
	storageBucket: "....appspot.com",
	messagingSenderId: "..."
};
firebase.initializeApp(config);
var storage = firebase.storage();
var database = firebase.database();
var storageRef = storage.ref();

var articleList = [];
var currentMag = storageRef.child('issue 6 2.pdf');
var source = {uri:'https://s2.q4cdn.com/235752014/files/doc_downloads/test.pdf',cache:true};

class PDF extends React.Component {
	constructor(props) {
		super(props);
		this.state = {PDF: false};

		console.log('Current Mag: ' + currentMag);
		
		currentMag.getDownloadURL().then(function(url) {
			var xhr = new XMLHttpRequest();
			xhr.responseType = 'blob';
			xhr.onload = function(event) {
				var blob = xhr.response;
				console.log('blob from xhr: ' + JSON.stringify(blob));
				var reader = new FileReader();
				reader.onload = function() {
					source.uri = reader.result;
					this.setState(previousState => (
						{PDF: !previousState.PDF}
					))
				}.bind(this);
				reader.readAsDataURL(blob);
			}.bind(this);
			xhr.open('GET', url);
			xhr.send();
			
			
		}.bind(this)).catch(function(error) {
			return (
				<View style={styles.container}>
					<Text>Error: {error}</Text>
				</View>
			);
		});
	}
	
	render() {
		if (!this.state.PDF) {
			return (
				<View style={{flex: 1, justifyContent: "center", alignItems: "center"}}>
					<Text>Loading Articles...</Text>
				</View>
			);
		}
		
		return (
			<View style={styles.container}>
				<PDFReader
					source={source}
					onLoadComplete={(numberOfPages,filePath)=>{
						console.log(`number of pages: ${numberOfPages}`);
					}}
					onPageChanged={(page,numberOfPages)=>{
						console.log(`current page: ${page}`);
					}}
					onError={(error)=>{
						console.log(error);
					}}
					style={styles.pdf}/>
			</View>
			//const source = require('https://firebasestorage.googleapis.com/v0/b/bulletin-magazine.appspot.com/o/issue%206%202.pdf?alt=media&token=e9e915db-1a70-47a2-ba56-63ae8404d606');  // ios only
			//const source = {uri:'bundle-assets://https://firebasestorage.googleapis.com/v0/b/bulletin-magazine.appspot.com/o/issue%206%202.pdf?alt=media&token=e9e915db-1a70-47a2-ba56-63ae8404d606'};

			//const source = {uri:'file:///sdcard/test.pdf'};
			//const source = {uri:"data:application/pdf;base64,..."};
		);
	}	
}

class SectionListItem extends React.Component {
	constructor(props) {
		super(props);
		this.state = {openArticle: false};
		this.getValue = this.getValue.bind(this);
    }

    getValue() {
        return this.state.openArticle;
    }
	
	_openArticle = (articleName) => {
		console.log('Clicked ' + articleName);
		currentMag = storageRef.child(articleName);
		this.setState(previousState => (
			{openArticle: !previousState.openArticle}
		));
	}
	
	_goBack = () => {
		return (
			<View style={styles.container}>
				<ArticleList/>
			</View>
		);
	}
	
	render() {
		if (this.state.openArticle) {
			console.log('Beginning main article render');
			return(
				<View style={{
					position: 'relative',
					flex: 0
				}}>
					<Touchable
						style={styles.option}
						background={Touchable.Ripple('#ccc', false)}
						onPress={() => this._goBack()}>
						<View style={{
							flex: 1,
							flexDirection: 'column',
							backgroundColor: '#FFFFFF'
						}}>
							<Icon.Ionicons
								name={
								Platform.OS === 'ios'? 
									`ios-arrow-back`
									: 'md-arrow-back'
								}
								size={26}
								style={{ marginBottom: -3 }}
								color={Colors.tabIconDefault}
							/>
							<Text style={{
								color: '#122EFF',
								fontSize: 16,
							}}>
								Back
							</Text>
						</View>
					</Touchable>
					<PDF/>
				</View>
			);
		}
		
		return (
			<View>
				<Touchable
					style={styles.option}
					background={Touchable.Ripple('#ccc', false)}
					onPress={() => this._openArticle(this.props.item.fileName)}>
					<View style={{
						flex: 1,
						flexDirection: 'column',
						backgroundColor: '#FFFFFF'
					}}>
						<Text style={{
							fontSize: 16,
							fontWeight: 'bold',
							color: '#000000',
							marginLeft: 15,
							marginRight: 10,
						}}>
							{this.props.item.title}
						</Text>
						<Text style={{
							fontSize: 16,
							color: '#000000',
							marginLeft: 20,
							marginRight: 10,
						}}>
							{this.props.item.date}
						</Text>
						<View style={{
							backgroundColor: '#CCCCCC',
							height: 1,
							margin: 6,
							marginLeft: 15,
							marginRight: 10
						}}>				
						</View>
					</View>
				</Touchable>
			</View>
		);
	}
}

class SectionHeader extends React.Component {
	render() {
		return (
			<View style={{
				flex: 1,
				backgroundColor: '#222222',
			}}>
				<Text style={{
					fontSize: 16,
					fontWeight: 'bold',
					color: 'white',
					marginTop: 30,
					marginLeft: 20,
					marginBottom: 15
				}}>{this.props.section.title}
				</Text>
			</View>
		);
	}
}

class ArticleList extends React.Component {
	constructor(props) {
		super(props);
		this.state = {articleListAquired: false};
		
		var allArticles;
		var allArticlesRef = firebase.database().ref('articles').once('value').then(function(snapshot) {
			allArticles = snapshot.val();
			console.log('All articles: ' + JSON.stringify(allArticles));
			var tempArticleObj = {data:[], title: 'Articles'};
			Object.keys(allArticles).forEach(function (item) {
				tempArticleObj['data'].push({
					title: allArticles[item].title,
					date: allArticles[item].formatDate,
					fileName: allArticles[item].fileName
				});
			});
			articleList.push(tempArticleObj);
			this.setState(previousState => (
				{articleListAquired: !previousState.articleListAquired}
			))
		}.bind(this));
	}
	
	render() {
		if (!this.state.articleListAquired) {
			return (
				<View style={{flex: 1, justifyContent: "center", alignItems: "center"}}>
					<Text>Loading Article...</Text>
				</View>
			);
		}
		
		return (
			<View style={styles.container}>
				<SectionList
					renderItem={({item, index}) => {
						return (
							<SectionListItem
								item={item}
								index={index}/>
						);
					}}
					renderSectionHeader={({section}) => {
						return (
							<SectionHeader section={section}/>
						);
					}}
					sections={articleList}
					keyExtractor={(item, index) => item.title}
				>
				</SectionList>
			</View>
		);
	}
}

export default class HomeScreen extends React.Component {
	static navigationOptions = {
		title: 'Articles',
		header: null,
	};
	
	render() {
		/*if (!this.state.articleListAquired) {
			return (
				<View style={styles.container}>
					<Text>Loading Articles...</Text>
				</View>
			);
		}*/
		
        return (
            <View style={styles.container}>
				<ArticleList/>
            </View>
        );
	}
}

//App styling, similar to CSS
const styles = StyleSheet.create({
	container: {
		flex: 1,
		backgroundColor: '#fff',
	},
	pdf: {
        flex:1,
        width:Dimensions.get('window').width,
    },
	developmentModeText: {
		marginBottom: 20,
		color: 'rgba(0,0,0,0.4)',
		fontSize: 14,
		lineHeight: 19,
		textAlign: 'center',
	},
	contentContainer: {
		paddingTop: 30,
	},
	welcomeContainer: {
		alignItems: 'center',
		marginTop: 10,
		marginBottom: 20,
	},
	welcomeImage: {
		width: 100,
		height: 80,
		resizeMode: 'contain',
		marginTop: 3,
		marginLeft: -10,
	},
	getStartedContainer: {
		alignItems: 'center',
		marginHorizontal: 50,
	},
	homeScreenFilename: {
		marginVertical: 7,
	},
	codeHighlightText: {
		color: 'rgba(96,100,109, 0.8)',
	},
	codeHighlightContainer: {
		backgroundColor: 'rgba(0,0,0,0.05)',
		borderRadius: 3,
		paddingHorizontal: 4,
	},
	getStartedText: {
		fontSize: 17,
		color: 'rgba(96,100,109, 1)',
		lineHeight: 24,
		textAlign: 'center',
	},
	tabBarInfoContainer: {
		position: 'absolute',
		bottom: 0,
		left: 0,
		right: 0,
		...Platform.select({
			ios: {
				shadowColor: 'black',
				shadowOffset: {
					height: -3
				},
				shadowOpacity: 0.1,
				shadowRadius: 3,
			},
			android: {
				elevation: 20,
			},
		}),
		alignItems: 'center',
		backgroundColor: '#fbfbfb',
		paddingVertical: 20,
	},
	tabBarInfoText: {
		fontSize: 17,
		color: 'rgba(96,100,109, 1)',
		textAlign: 'center',
	},
	navigationFilename: {
		marginTop: 5,
	},
	helpContainer: {
		marginTop: 15,
		alignItems: 'center',
	},
	helpLink: {
		paddingVertical: 15,
	},
	helpLinkText: {
		fontSize: 14,
		color: '#2e78b7',
	},
	optionsTitleText: {
		fontSize: 16,
		marginLeft: 15,
		marginTop: 9,
		marginBottom: 12,
	},
	optionIconContainer: {
		marginRight: 9,
	},
	option: {
		backgroundColor: '#fdfdfd',
		borderBottomWidth: StyleSheet.hairlineWidth,
		borderBottomColor: '#EDEDED',
	},
	optionText: {
		fontSize: 15,
		marginTop: 1,
	},
});

Correct usage of the base64 string option?

According to the documentation, you can display a pdf based on either a uri of a file, or a base64 encoded string. After reading the code, it's (probably) looking for a string like this: data:JVBERi0xLjMKJcT.... where JVBERi0xL is the usual start of a pdf in base64. However, WebKit is giving a WebKitInternal error: DataURL decoding failed. Is there a working example of this functionality, or what am I doing wrong?

If I'm faithful to the documentation (which says to prepend with data without the :, giving dataJVBERi0xLjMKJcT...) then I get a -1100 requested url not found on server error.

Thanks!

Add rn-pdf-reader-js to reactnative.gallery 🎨

Hi @xcarpentier!

Sorry, this is not an issue...

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I try to help community when I can: sharing my works on open-source, like you do!

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

https://reactnative.gallery

Add support for Incognito mode

Hello, Kudos to the team of rn-pdf-reader-js I love it!.
I wanted to ask that since this lib uses WebView, will it be possible to add support for incognito mode?. Cause am trying to stop users from taking screenshots some pdf's, If is possible I will be willing to do the PR myself if the team is too busy to do that.

Need a tutorial

I'm not understand about this code because I'm beginner on react native, can you make tutorial video for this please ?

functionalities of the pdf

i need to create a pdf reader including fallowing functions.
getcurrentpage
nextpage
previouspage

how to make the pdf to scroll horizontally. The pages should move horizontally, rather than vertically when moving to the(scroll) next page.

is it possible to create those function with this library

Add rn-pdf-reader-js to reactnative.gallery :)

Hi @xcarpentier!

Sorry, this is not an issue...

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I try to help community when I can: sharing my works on open-source, like you do!

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

https://reactnative.gallery

Add rn-pdf-reader-js to reactnative.gallery :)

Hi @xcarpentier!

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I try to help community when I can: sharing my works on open-source, like you do! :)

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

Do you want to know more?
https://reactnative.gallery

Add rn-pdf-reader-js to reactnative.gallery :)

Hi @xcarpentier!

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I try to help community when I can: sharing my works on open-source, like you do! :)

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

https://reactnative.gallery

Action required: Greenkeeper could not be activated 🚨

🚨 You need to enable Continuous Integration on all branches of this repository. 🚨

To enable Greenkeeper, you need to make sure that a commit status is reported on all branches. This is required by Greenkeeper because it uses your CI build statuses to figure out when to notify you about breaking changes.

Since we didn’t receive a CI status on the greenkeeper/initial branch, it’s possible that you don’t have CI set up yet. We recommend using Travis CI, but Greenkeeper will work with every other CI service as well.

If you have already set up a CI for this repository, you might need to check how it’s configured. Make sure it is set to run on all new branches. If you don’t want it to run on absolutely every branch, you can whitelist branches starting with greenkeeper/.

Once you have installed and configured CI on this repository correctly, you’ll need to re-trigger Greenkeeper’s initial pull request. To do this, please delete the greenkeeper/initial branch in this repository, and then remove and re-add this repository to the Greenkeeper App’s white list on Github. You'll find this list on your repo or organization’s settings page, under Installed GitHub Apps.

On iOS, pdf does not render

On Android, it works totally fine. But on iOS fullscreen and wrapped PDFReader in view, it will display nothing. I tried it on safari url actually takes me to download as opposed to loading the pdf. Any ideas?

Here is what i did:

      <View style={styles.container}>
        <PDFReader
          source={{uri: 'https://littlefleets-assets.s3.amazonaws.com/uploads/5acb2218-fd61-4cda-ab07-7e683a02f845/intro_to_npc.pdf'}}
        />
      </View>

expo version is 27

Network request failed

Why does the component give "Network request failed" error although I am connected to the internet.

Extra padding at top of PdfViewer

Hi, thank you for this library 😃

I have an issue with additional padding at the top of the component. Using the following code:

const WebScreen = props => (
  <View style={styles.container}>
    <MyHeader name={props.navigation.getParam('name')} />
    <View style={{ flex: 1 }}>
      <PdfReader
        style={{ flex: 1, padding: 0, margin: 0 }}
        source={{ uri: props.navigation.getParam('uri') }}
      />
    </View>
    <BottomBar />
  </View>
);

const styles = StyleSheet.create({
  container: {
    flex: 1,
    backgroundColor: '#fff',
  },
});

export default WebScreen;

I get the following result, with an extra 24px padding at the top.
photo_2018-07-26_01-42-56

After some inspection, I found the extra padding to be due to this line. By changing paddingTop to 0, I was able to achieve the following:
photo_2018-07-26_01-45-05

Would it be possible for us to control paddingTop via a prop? I believe #22 is a related issue (have not tested on iOS)

View doc, xls, ppt, etc

Hi, I thought it'd be great if there'd be something like react-native-doc-viewer compatible with expo,
Your component is the only available to view pdf and compatible with expo,
So, may be you may like to consider extending to other formats :)

Download Option

Is there any possibility that this library can provide a download feature (e.g. a UI button or method) that we can not only display PDF and also allows ppl to download and save it for later usage (e.g use their own application to open this PDF)
Thanks!

component doesn't render

Hi i have following versions:

"devDependencies": {
"jest-expo": "27.0.0",
"react-native-scripts": "1.11.1",
"react-test-renderer": "16.2.0"
},
"dependencies": {
"expo": "^27.0.0",
"react": "^16.3.1",
"react-native": "^0.55.4"
}

"expo": {
"sdkVersion": "27.0.0",
}

The component doesn't give any error just nothing. The problem is not in uri/base64 they are fine, i tried uri from your example

This is the code:
KeyboardAvoidingView keyboardVerticalOffset={80} behavior="padding" style={{ flex: 1 }}
ScrollView style={{ flex: 1 }}
View style={{ flex: 1,
paddingTop: Constants.statusBarHeight}}>
<PDFReader
source={{ uri: "http://gahp.net/wp-content/uploads/2017/09/sample.pdf" }}
/>
View
ScrollView
KeyboardAvoidingView

Thank you

upd: the full code not displayed i don't know why, it displays only in edit mode

base64 doesn't work on Android

The source parameter below works on iOS, but not on Android

source={{ base64: "data:application/pdf;base64,JVBERi0xLjcKCjEgMCBvYmogICUgZW50cnkgcG9pbnQKPDwKICAvVHlwZSAvQ2F0YWxvZwogIC9QYWdlcyAyIDAgUgo+PgplbmRvYmoKCjIgMCBvYmoKPDwKICAvVHlwZSAvUGFnZXMKICAvTWVkaWFCb3ggWyAwIDAgMjAwIDIwMCBdCiAgL0NvdW50IDEKICAvS2lkcyBbIDMgMCBSIF0KPj4KZW5kb2JqCgozIDAgb2JqCjw8CiAgL1R5cGUgL1BhZ2UKICAvUGFyZW50IDIgMCBSCiAgL1Jlc291cmNlcyA8PAogICAgL0ZvbnQgPDwKICAgICAgL0YxIDQgMCBSIAogICAgPj4KICA+PgogIC9Db250ZW50cyA1IDAgUgo+PgplbmRvYmoKCjQgMCBvYmoKPDwKICAvVHlwZSAvRm9udAogIC9TdWJ0eXBlIC9UeXBlMQogIC9CYXNlRm9udCAvVGltZXMtUm9tYW4KPj4KZW5kb2JqCgo1IDAgb2JqICAlIHBhZ2UgY29udGVudAo8PAogIC9MZW5ndGggNDQKPj4Kc3RyZWFtCkJUCjcwIDUwIFRECi9GMSAxMiBUZgooSGVsbG8sIHdvcmxkISkgVGoKRVQKZW5kc3RyZWFtCmVuZG9iagoKeHJlZgowIDYKMDAwMDAwMDAwMCA2NTUzNSBmIAowMDAwMDAwMDEwIDAwMDAwIG4gCjAwMDAwMDAwNzkgMDAwMDAgbiAKMDAwMDAwMDE3MyAwMDAwMCBuIAowMDAwMDAwMzAxIDAwMDAwIG4gCjAwMDAwMDAzODAgMDAwMDAgbiAKdHJhaWxlcgo8PAogIC9TaXplIDYKICAvUm9vdCAxIDAgUgo+PgpzdGFydHhyZWYKNDkyCiUlRU9G==" }}

On iOS, padding top is incorrect

import React from 'react';
import { StyleSheet, View } from 'react-native';
import PDFReader from 'rn-pdf-reader-js';

export default class PdfPage extends React.Component {
    render() {
        const { source } = this.props.navigation.state.params;;
        
        return (
            <View style={styles.container}>
                <PDFReader source={source} />
            </View>
        );
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,
        backgroundColor: '#ecf0f1',
    },
});  

37209754_2009532672433052_538383882949492736_n

Notice the padding at the top of the size of the status bar

Publish to npm

The current npm version has out of date imports and hasn't been published in 4 months.

Is it possible for the latest to be published to npm?

Add to reactnative.gallery :)

Hi @xcarpentier!

I'm Xavier and I’ve been working as a freelance React Native developer for more than 2 years.
I help community when I can: sharing my works on open-source, like you do!

But it's hard to be visible sometimes! Right?

Good news: I want to help developers to have more visibility.
So, I've created a website where developers can share with entire
world their React Native projects, components, apps...

This website allow developers to show their works and get feedback.
Just like a Dribbble but for React Native developers.

What do you think?

Do you want to be informed about it?
::BETA:: => https://reactnative.gallery 📬

Or chat about it?
::SLACK:: => https://slack.reactnative.gallery 💬

Use headers in the source

This looks like a great solution for me, but i have to authenticate my user in order to allow them to see documents. I do this in iOS by passing in additional headers with a Bearer accessToken.

Can this be added to the fetching of the PDF document for Android? I had a brief look under the hood and looks like you do use the WebView in there at some point, so we should be able to pass in additional headers if required?

Scrolling issue on Android

Hi,
I'm having a strange issue with the latest version (0.2.1) on Android when I try to scroll down I see the following:

screenshot at feb 12 16-51-22

The first page of the PDF loads properly but when I try scrolling up/down to see the next page it doesn't work and instead I see the text "Loading ..." over a grey background, the only way to get to the next page is to press the up/down arrows (which seem to work properly)

Any suggestions?

Thanks!

Unable to use `style` prop

Hi there, just wanted to start by saying great work with the module, it's really helping me get around the problem of loading PDF's without additional Native Libraries etc.

I'm just experiencing a problem with the use of the style prop against the component. I had look through the source code in this repo and can see that in index.js (on lines 181 and 193) that the component is merging styles from the supplied style prop. However, when using this within the application the changes aren't reflected, my code:

import PDFView from 'rn-pdf-reader-js';
...
  <PDFView
    source={{ uri: url }}
    style={{ paddingTop: 0 }}
/>

I was hoping this would close the extra gap that appears as per #24 but it doesn't seem to be the case.

I also found that when inspecting the definition of the component in VS Code the code looks like this...

Screenshot 2019-03-25 at 16 49 13

Which looks different to the code on GH. I wasn't sure if there was a discrepancy between the code on GH versus code on NPM?

Thanks again!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.