# react-native-share Share Social , Sending Simple Data to Other Apps
NOTE: React Native now implements share functionality Read more
Getting started
Mostly automatic install
npm install react-native-share --save
react-native link
Manual install
npm install react-native-share --save
iOS Install
-
npm install react-native-share --save
-
In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
-
Go to
node_modules
➜react-native-share
➜ios
and addRNShare.xcodeproj
-
In XCode, in the project navigator, select your project. Add
libRNShare.a
to your project'sBuild Phases
➜Link Binary With Libraries
-
In XCode, in the project navigator, select your project. Add
Social.framework
andMessageUI.framework
to your project'sGeneral
➜Linked Frameworks and Libraries
-
In file Info.plist, add
LSApplicationQueriesSchemeswhatsappmailto -
Run your project (
Cmd+R
)
Android Install
npm install react-native-share --save
- Open up
android/app/src/main/java/[...]/MainApplication.java
- Add
import cl.json.RNSharePackage;
to the imports at the top of the file - Add
new RNSharePackage()
to the list returned by thegetPackages()
method
-
Append the following lines to
android/settings.gradle
:include ':react-native-share' project(':react-native-share').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-share/android')
-
Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-share')
-
Follow this guide. For example:
-
Put this in
AndroidManifest.xml
whereapplicationId
is something that you have defined inandroid/app/build.gradle
: -
Create a
filepaths.xml
under this directory:android/app/src/main/res/xml
. In this file, add the following contents:
- Edit your
MainApplication
class to implementShareApplication
-
Also add the
getFileProviderAuthority
method to your MainApplication class, and have it return theandroid:authorities
that was added in AndroidManifest file. -
For example: Replace the
com.example.yourappidhere
below with theapplicationId
that is defined in yourandroid/app/build.gradle
. It must be hard-coded here to work properly.import cl.json.ShareApplication class MyApplication extends Application implements ShareApplication, ReactApplication { { //... @Override public String getFileProviderAuthority() { return "com.example.yourappidhere.provider"; } }
Windows Install
npm install react-native-share --save
- In Visual Studio add the
RNShare.sln
innode_modules/react-native-share/windows/RNShare.sln
folder to their solution, reference from their app. - Open up your
MainPage.cs
app
- Add
using Cl.Json.RNShare;
to the usings at the top of the file - Add
new RNSharePackage()
to theList<IReactPackage>
returned by thePackages
method
Methods
open(options)
Open Simple share dialog
Returns a promise that fulfills or rejects as soon as user successfully open the share action sheet or cancelled/failed to do so. As a result you might need to further handle the rejection while necessary. e.g.
Share ;
Supported options:
Name | Type | Description |
---|---|---|
url | string | URL you want to share (you can share a base64 file url only in iOS & Android ) |
urls | Array[string] | URL's you want to share, Only for iOS and Android (you can share a base64 file url only in iOS & Android ) |
type | string | File mime type (optional) |
message | string | |
title | string | (optional) |
subject | string | (optional) |
excludedActivityTypes | string | (optional) |
failOnCancel | boolean | (defaults to true) On iOS, specifies whether promise should reject if user cancels share dialog (optional) |
showAppsToView | boolean | (optional) only android |
shareSingle(options) (in iOS & Android)
Open share dialog with specific application
This returns a promise too.
Supported options:
Name | Type | Description |
---|---|---|
url | string | URL you want to share |
type | string | File mime type (optional) |
message | string | |
title | string | (optional) |
subject | string | (optional) |
social | string | supported social apps: twitter, facebook, pagesmanager (only Android), whatsapp, googleplus, email |
NOTE: If both message
and url
are provided url
will be concatenated to the end of message
to form the body of the message. If only one is provided it will be used
how it looks:
Android | IOS | Windows | |
---|---|---|---|
Simple Share | |||
UI Component | TODO |
Usage
Example code
;;; { superprops; thisstate = visible: false } { console this; } { console this; } { let shareOptions = title: "React Native" message: "Hola mundo" url: "http://facebook.github.io/react-native/" subject: "Share Link" // for email ; let shareImageBase64 = title: "React Native" message: "Hola mundo" url: REACT_ICON subject: "Share Link" // for email ; return <View style=stylescontainer> <TouchableOpacity onPress={ Share; }> <View style=stylesinstructions> <Text>Simple Share Image Base 64</Text> </View> </TouchableOpacity> <TouchableOpacity onPress={ Share; }> <View style=stylesinstructions> <Text>Simple Share</Text> </View> </TouchableOpacity> <TouchableOpacity onPress=thisonOpen> <View style=stylesinstructions> <Text>Share UI Component</Text> </View> </TouchableOpacity> <ShareSheet visible=thisstatevisible onCancel=thisonCancel> <Button iconSrc= uri: TWITTER_ICON onPress={ this; ; }>Twitter</Button> <Button iconSrc= uri: FACEBOOK_ICON onPress={ this; ; }>Facebook</Button> <Button iconSrc= uri: WHATSAPP_ICON onPress={ this; ; }>Whatsapp</Button> <Button iconSrc= uri: GOOGLE_PLUS_ICON onPress={ this; ; }>Google +</Button> <Button iconSrc= uri: EMAIL_ICON onPress={ this; ; }>Email</Button> <Button iconSrc= uri: CLIPBOARD_ICON onPress={ this; ; }>Copy Link</Button> <Button iconSrc= uri: MORE_ICON onPress={ this; ; }>More</Button> </ShareSheet> </View> ; } const styles = StyleSheet; // twitter iconconst TWITTER_ICON = ""; // facebook iconconst FACEBOOK_ICON = ""; // whatsapp iconconst WHATSAPP_ICON = ""; // gplus iconconst GOOGLE_PLUS_ICON = ""; // email iconconst EMAIL_ICON = ""; // clipboard iconconst CLIPBOARD_ICON = ""; // more iconconst MORE_ICON = ""; const REACT_ICON = ''; AppRegistry;
Url format when sharing a file
Share base 64 file
When share a base 64 file, please follow the format below:
url: "data:<data_type>/<file_extension>;base64,<base64_data>"
For example, when share a base 64 mp3
file, the url
should be:
url: "data:audio/mp3;base64,<base64_data>"
When share a base 64 image file with png
file extension, the url
should be:
url: "data:image/png;base64,<base64_data>"
Share file directly
When share a local file directly, please follow the format below:
url: "file://<file_path>",
For example, when share a pdf
file from: /storage/emulated/0/demo/test.pdf
, the url
should be:
url: "file:///storage/emulated/0/demo/test.pdf"
Troubleshooting
Share Remote PDF File with Gmail & WhatsApp (iOS)
When sharing a pdf file with base64, there are two current problems.
- On WhatsApp base64 wont be recognized => nothing to share
- In the GmailApp the file extension is wrong (.dat).
Therefore we use this "workaround" in order to handle pdf sharing for iOS Apps to mentioned Apps
- Install react-native-fetch-blob
- Set a specific path in the RNFetchBlob configurations
- Download the PDF file to temp device storage
- Share the response's path() of the donwloaded file directly
Code:
static sharePDFWithIOS(fileUrl, type) {
let filePath = null;
let file_url_length = fileUrl.length;
const configOptions = {
fileCache: true,
path:
DIRS.DocumentDir + (type === 'application/pdf' ? '/SomeFileName.pdf' : '/SomeFileName.png') // no difference when using jpeg / jpg / png /
};
RNFetchBlob.config(configOptions)
.fetch('GET', fileUrl)
.then(async resp => {
filePath = resp.path();
let options = {
type: type,
url: filePath // (Platform.OS === 'android' ? 'file://' + filePath)
};
await Share.open(options);
// remove the image or pdf from device's storage
await RNFS.unlink(filePath);
});
}
Nothing to do on Android. You can share the pdf file with base64
static sharePDFWithAndroid(fileUrl, type) {
let filePath = null;
let file_url_length = fileUrl.length;
const configOptions = { fileCache: true };
RNFetchBlob.config(configOptions)
.fetch('GET', fileUrl)
.then(resp => {
filePath = resp.path();
return resp.readFile('base64');
})
.then(async base64Data => {
base64Data = `data:${type};base64,` + base64Data;
await Share.open({ url: base64Data });
// remove the image or pdf from device's storage
await RNFS.unlink(filePath);
});
}