Share your code. npm Orgs help your team discover, share, and reuse code. Create a free org »

    react-native-sharepublic

    # react-native-share npm version Share Social , Sending Simple Data to Other Apps

    NOTE: React Native now implements share functionality Read more

    Getting started

    Mostly automatic install

    1. npm install react-native-share --save
    2. react-native link

    Manual install

    iOS

    1. npm install react-native-share --save

    2. In XCode, in the project navigator, right click LibrariesAdd Files to [your project's name]

    3. Go to node_modulesreact-native-shareios and add RNShare.xcodeproj

    4. In XCode, in the project navigator, select your project. Add libRNShare.a to your project's Build PhasesLink Binary With Libraries

    5. In XCode, in the project navigator, select your project. Add Social.framework and MessageUI.framework to your project's GeneralLinked Frameworks and Libraries

    6. In file Info.plist, add

      <key>LSApplicationQueriesSchemes</key>
      <array>
        <string>whatsapp</string>
        <string>mailto</string>
      </array>
    7. Run your project (Cmd+R)

    Android

    1. npm install react-native-share --save
    2. 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 the getPackages() method
    1. 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')
      
    2. Insert the following lines inside the dependencies block in android/app/build.gradle:

        compile project(':react-native-share')
      
    3. Follow this guide. For example:

    • Put this in AndroidManifest.xml where applicationId is something that you have defined in android/app/build.gradle:

        <application>
          <provider
              android:name="android.support.v4.content.FileProvider"
              android:authorities="${applicationId}.provider"
              android:grantUriPermissions="true"
              android:exported="false">
              <meta-data
                  android:name="android.support.FILE_PROVIDER_PATHS"
                  android:resource="@xml/filepaths" />
          </provider>
        </application>
    • Create a filepaths.xml under this directory: android/app/src/main/res/xml. In this file, add the following contents:

        <?xml version="1.0" encoding="utf-8"?>
        <paths xmlns:android="http://schemas.android.com/apk/res/android">
            <external-path name="myexternalimages" path="Download/" />
        </paths>
    1. Edit your MainApplication class to implement ShareApplication
    • Also add the getFileProviderAuthority method to your MainApplication class, and have it return the android:authorities that was added in AndroidManifest file.

    • For example: Replace the com.example.yourappidhere below with the applicationId that is defined in your android/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

    Read it! :D

    1. npm install react-native-share --save
    2. In Visual Studio add the RNShare.sln in node_modules/react-native-share/windows/RNShare.sln folder to their solution, reference from their app.
    3. Open up your MainPage.cs app
    • Add using Cl.Json.RNShare; to the usings at the top of the file
    • Add new RNSharePackage() to the List<IReactPackage> returned by the Packages 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.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)

    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, 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 Demo Android Demo iOS Demo Windows
    UI Component Demo Android UI Component Demo Android UI Component TODO

    Usage

    Example code

    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);

    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"
    

    install

    npm i react-native-share

    Downloadsweekly downloads

    7,232

    version

    1.0.27

    license

    MIT

    repository

    githubgithub

    last publish

    collaborators

    • avatar
    • avatar
    • avatar