Share Social , Sending Simple Data to Other Apps
NOTE: React Native now implements share functionality Read more
npm install react-native-share --savereact-native link
-
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âžśiosand addRNShare.xcodeproj -
In XCode, in the project navigator, select your project. Add
libRNShare.ato your project'sBuild PhasesâžśLink Binary With Libraries -
In XCode, in the project navigator, select your project. Add
Social.frameworkandMessageUI.frameworkto your project'sGeneralâžśLinked Frameworks and Libraries -
In file Info.plist, add
<key>LSApplicationQueriesSchemes</key> <array> <string>whatsapp</string> <string>mailto</string> </array>
-
Run your project (
Cmd+R)
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 Example: Put this in
AndroidManifest.xmlwhereapplicationIdis something that you have defined inandroid/app/build.gradle.<applicaiton> <provider android:name="android.support.v4.content.FileProvider" android:authorities="${applicationId}.provider" android:grantUriPermissions="true" android:exported="false"> </provider> </application>
-
Make your
Applicationclass implementsShareApplication
-
Make
getFileProviderAuthorityfunction return theandroid:authoritiesthat was added on AndroidManifest file -
Example:
applicationIdis defined inandroid/app/build.gradle.import cl.json.ShareApplication class MyApplication extends Application implements ShareApplication, ReactApplication { { @Override public String getFileProviderAuthority() { return "${applicationId}.provider" } }
npm install react-native-share --save- In Visual Studio add the
RNShare.slninnode_modules/react-native-share/windows/RNShare.slnfolder to their solution, reference from their app. - Open up your
MainPage.csapp
- Add
using Cl.Json.RNShare;to the usings at the top of the file - Add
new RNSharePackage()to theList<IReactPackage>returned by thePackagesmethod
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.open(options).catch((err) => { err && console.log(err); })Supported options:
| Name | Type | Description |
|---|---|---|
| url | string | URL you want to share (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) |
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, 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
| Android | IOS | Windows | |
|---|---|---|---|
| Simple Share | ![]() |
![]() |
![]() |
| UI Component | ![]() |
![]() |
TODO |
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
TouchableOpacity,
View,
Clipboard,
ToastAndroid,
AlertIOS,
Platform
} from 'react-native';
import Share, {ShareSheet, Button} from 'react-native-share';
class TestShare extends Component {
constructor(props) {
super(props);
this.state = {
visible: false
}
}
onCancel() {
console.log("CANCEL")
this.setState({visible:false});
}
onOpen() {
console.log("OPEN")
this.setState({visible:true});
}
render() {
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={styles.container}>
<TouchableOpacity onPress={()=>{
Share.open(shareImageBase64);
}}>
<View style={styles.instructions}>
<Text>Simple Share Image Base 64</Text>
</View>
</TouchableOpacity>
<TouchableOpacity onPress={()=>{
Share.open(shareOptions);
}}>
<View style={styles.instructions}>
<Text>Simple Share</Text>
</View>
</TouchableOpacity>
<TouchableOpacity onPress={this.onOpen.bind(this)}>
<View style={styles.instructions}>
<Text>Share UI Component</Text>
</View>
</TouchableOpacity>
<ShareSheet visible={this.state.visible} onCancel={this.onCancel.bind(this)}>
<Button iconSrc={{ uri: TWITTER_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "twitter"
}));
},300);
}}>Twitter</Button>
<Button iconSrc={{ uri: FACEBOOK_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "facebook"
}));
},300);
}}>Facebook</Button>
<Button iconSrc={{ uri: WHATSAPP_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "whatsapp"
}));
},300);
}}>Whatsapp</Button>
<Button iconSrc={{ uri: GOOGLE_PLUS_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "googleplus"
}));
},300);
}}>Google +</Button>
<Button iconSrc={{ uri: EMAIL_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "email"
}));
},300);
}}>Email</Button>
<Button
iconSrc={{ uri: CLIPBOARD_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
if(typeof shareOptions["url"] !== undefined) {
Clipboard.setString(shareOptions["url"]);
if (Platform.OS === "android") {
ToastAndroid.show('Link copiado al portapapeles', ToastAndroid.SHORT);
} else if (Platform.OS === "ios") {
AlertIOS.alert('Link copiado al portapapeles');
}
}
},300);
}}>Copy Link</Button>
<Button iconSrc={{ uri: MORE_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.open(shareOptions)
},300);
}}>More</Button>
</ShareSheet>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
instructions: {
marginTop: 20,
marginBottom: 20,
},
});
// twitter icon
const TWITTER_ICON = "";
// facebook icon
const FACEBOOK_ICON = "";
// whatsapp icon
const WHATSAPP_ICON = "";
// gplus icon
const GOOGLE_PLUS_ICON = "";
// email icon
const EMAIL_ICON = "";
// clipboard icon
const CLIPBOARD_ICON = "";
// more icon
const MORE_ICON = "";
const REACT_ICON = '';
AppRegistry.registerComponent('TestShare', () => TestShare);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>"
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"




