2.1.4 • Published 5 years ago

react-native-open-doc v2.1.4

Weekly downloads
18
License
MIT
Repository
github
Last release
5 years ago

react-native-open-doc

Open files stored on device for preview - Android and iOS.

Pick files using native file pickers for iOS and Android (UIDocumentPickerViewController / Intent.ACTION_OPEN_DOCUMENT)

Share files on Android (for iOS use the react-native Share.share({ url: selectedUri }) api).

Getting started

$ npm install react-native-open-doc --save

Mostly automatic installation

  1. $ react-native link react-native-open-doc

  2. Define a FileProvider

    Note that the authorities value should be <your package name>.provider, for example:

    <provider
                android:name="android.support.v4.content.FileProvider"
                android:authorities="com.mydomain.provider"
                android:exported="false"
                android:grantUriPermissions="true">
                ...
    </provider>

Manual installation

iOS

  1. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]
  2. Go to node_modulesreact-native-open-doc and add RNCOpenDoc.xcodeproj
  3. In XCode, in the project navigator, select your project. Add libRNCOpenDoc.a to your project's Build PhasesLink Binary With Libraries
  4. Run your project (Cmd+R)<

Android

  1. Open up android/app/src/main/java/[...]/MainActivity.java
  • Add import com.capriza.reactlibrary.RNCOpenDocPackage; to the imports at the top of the file
  • Add new RNCOpenDocPackage() to the list returned by the getPackages() method
  1. Append the following lines to android/settings.gradle:
    include ':react-native-open-doc'
    project(':react-native-open-doc').projectDir = new File(rootProject.projectDir, 	'../node_modules/react-native-open-doc/android')
  2. Insert the following lines inside the dependencies block in android/app/build.gradle:
      implementation project(':react-native-open-doc')
  3. Define a FileProvider

Usage

import RNCOpenDoc from 'react-native-open-doc';

RNCOpenDoc.open(pathToFile);
RNCOpenDoc.share(pathToFile);
RNCOpenDoc.pick(null, (error, files) => {
    if (error) {
        console.log(`error in RNCOpenDoc.pick ${error}`);
    }
    else if (files) {
    	this.handleSelectedFiles(files);
    }
});

files is an array of objects with the following properties:

  • fileName (string) e.g. "foo.html"
  • fileSize (number) (iOS only) File size in bytes
  • mimeType (string) (iOS only) e.g. "text/html"
  • uri (string) Example (iOS): "file:///private/var/mobile/Containers/Data/Application/.../foo.html"
2.1.4

5 years ago

2.1.3

5 years ago

2.1.2

5 years ago

2.1.1

5 years ago

2.1.0

5 years ago

2.0.0

5 years ago

1.3.0

5 years ago

1.2.0

5 years ago

1.1.0

6 years ago

1.0.6

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago