react-native-doc-viewer ![npm version](https://img.shields.io/npm/v/react-native-doc-viewer.svg?style=flat)
A React Native bridge module: Document Viewer for files (pdf, png, jpg, xls, doc, ppt, xlsx, docx, pptx etc.)
2017 Roadmap
- Loading Spinner for big Files IOS
- base64 Support for Android
2018 Roadmap
- Android file without external Application
- Loading Spinner for big Files Android
IMPORTANT INFORMATION: THIS IS A OPEN SOURCE PROJECT, SOMETIMES I HAVE NO TIME TO DEVELOP THIS PROJECT. THANK YOU FOR YOUR PULL REQUEST AND YOUR SUPPORT. I will continue to develop it as it is possible in time.
![nodei.co](https://nodei.co/npm/react-native-doc-viewer.png?downloads=true&downloadRank=true&stars=true)
Changelog:
2.5.5 - Android Openbase64
2.5.2 - OpenDocAndroid
2.5.1 - Cleanings
2.5.0 - Update Project for React Native 0.50.3
Getting started
$ npm install react-native-doc-viewer --save
Automatic installation
$ react-native link react-native-doc-viewer
Manual installation
iOS
-
In XCode, in the project navigator, right click Libraries
➜ Add Files to [your project's name]
-
Go to node_modules
➜ react-native-doc-viewer
and add RNReactNativeDocViewer.xcodeproj
-
In XCode, in the project navigator, select your project. Add libRNReactNativeDocViewer.a
to your project's Build Phases
➜ Link Binary With Libraries
-
Linked Frameworks and Libraries must have this 2 Libraries (AssetsLibrary.framework & QuickLock.framework). When not you have to add them.
![Xcode add Library Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/screenshot_xcode_addlibrary.png)
![Xcode add Library Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/screenshot_xcode_addlibrary2.png)
-
When you Show http Links don't forget to set APP Transport Security Settings ->
Allow Arbitrary Loads to YES
![Plist Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/plist_file.png)
- Run your project (
Cmd+R
)<
Android
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import com.reactlibrary.RNReactNativeDocViewerPackage;
to the imports at the top of the file - Add
new RNReactNativeDocViewerPackage()
to the list returned by the getPackages()
method
- Append the following lines to
android/settings.gradle
:
include ':react-native-doc-viewer'
project(':react-native-doc-viewer').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-doc-viewer/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:
compile project(':react-native-doc-viewer')
Windows on the Roadmap
Read it! :D
- In Visual Studio add the
RNReactNativeDocViewer.sln
in node_modules/react-native-react-native-doc-viewer/windows/RNReactNativeDocViewer.sln
folder to their solution, reference from their app. - Open up your
MainPage.cs
app
- Add
using Com.Reactlibrary.RNReactNativeDocViewer;
to the usings at the top of the file - Add
new RNReactNativeDocViewerPackage()
to the List<IReactPackage>
returned by the Packages
method
Usage
import OpenFile from 'react-native-doc-viewer';
var RNFS = require('react-native-fs');
var SavePath = Platform.OS === 'ios' ? RNFS.MainBundlePath : RNFS.DocumentDirectoryPath;
handlePress = () => {
OpenFile.openDoc([{
url:"http://www.snee.com/xml/xslt/sample.doc",
fileName:"sample",
fileExt:"",
fileType:""
}], (error, url) => {
if (error) {
console.error(error);
} else {
console.log(url)
}
})
}
handlePressBinaryinUrl = () => {
OpenFile.openDocBinaryinUrl([{
url:"http://mail.hartl-haus.at/uploads/tx_hhhouses/{binaryString}",
fileName:"sample",
fileType:'jpg'
}], (error, url) => {
if (error) {
console.error(error);
} else {
console.log(url)
}
})
}
handlePressLocalFile = () => {
OpenFile.openDoc([{
url:SavePath+"filename.pdf",
fileName:"sample",
fileType:"",
fileExt:""
}], (error, url) => {
if (error) {
console.error(error);
} else {
console.log(url)
}
})
}
handlePressb64 = () => {
OpenFile.openDocb64([{
base64:"{BASE64String}"
fileName:"sample",
fileType:"png"
}], (error, url) => {
if (error) {
console.error(error);
} else {
console.log(url)
}
})
}
<Button
onPress={this.handlePress.bind(this)}
title="Press Me Open Doc Url"
accessibilityLabel="See a Document"
/>
<Button
onPress={this.handlePressBinaryinUrl.bind(this)}
title="Press Me Open BinaryinUrl"
accessibilityLabel="See a Document"
/>
<Button
onPress={this.handlePressb64.bind(this)}
title="Press Me Open Base64 String"
accessibilityLabel="See a Document"
/>
<Button
onPress={()=>this.handlePressVideo("Path/to/Video.mp4")}
title="Press Me Open Video"
accessibilityLabel="See a Document"
/>
Screenshots
![Screenshot 1 Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/Screenshot.png)
![Screenshot 2 Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/Screenshot1.png)
![Screenshot 3 Alt text](https://raw.githubusercontent.com/philipphecht/react-native-doc-viewer/master/Screenshots/Screenshot2.png)
ROADMAP
- Android Quicklook support without an external application
- Base64StringtoFile Android
- Windows Support
Copyright (c) 2017-present, Philipp Hecht
philipp.hecht@icloud.com