react-native-community/react-native-share

Name: react-native-share

Owner: React Native Community

Description: Share Social , Sending Simple Data to Other Apps

Created: 2015-09-30 02:27:34.0

Updated: 2018-05-24 12:25:05.0

Pushed: 2018-05-18 11:53:53.0

Homepage: null

Size: 877

Language: Java

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

?# 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 Libraries ? Add Files to [your project's name]

  3. Go to node_modules ? react-native-share ? ios and add RNShare.xcodeproj

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

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

  6. In file Info.plist, add

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

Android

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

  2. Open up android/app/src/main/java/[...]/MainApplication.java

  3. Add import cl.json.RNSharePackage; to the imports at the top of the file

  4. Add new RNSharePackage() to the list returned by the getPackages() method

  5. Append the following lines to android/settings.gradle:

    ude ':react-native-share'
    ect(':react-native-share').projectDir = new File(rootProject.projectDir,    '../node_modules/react-native-share/android')
    
  6. Insert the following lines inside the dependencies block in android/app/build.gradle:

    mpile project(':react-native-share')
    
  7. Follow this guide. For example:

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

    pplication>
    <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>
    
  9. 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"?>
    aths xmlns:android="http://schemas.android.com/apk/res/android">
      <external-path name="myexternalimages" path="Download/" />
    paths>
    
  10. Edit your MainApplication class to implement ShareApplication

  11. Also add the getFileProviderAuthority method to your MainApplication class, and have it return the android:authorities that was added in AndroidManifest file.

  12. 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.

    rt cl.json.ShareApplication
    
    s MyApplication extends Application implements ShareApplication, ReactApplication {
    
    
    
     //...
    
     @Override
     public String getFileProviderAuthority() {
            return "com.example.yourappidhere.provider";
     }
    
    
    
  13. When using targetSdkVersion 23 or greater, you might need to explicitly ask for permission otherwise sharing a base64 image will fail :

    t allowedStorage = await PermissionsAndroid.request(
    issionsAndroid.PERMISSIONS.WRITE_EXTERNAL_STORAGE
    
    

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
  4. Add using Cl.Json.RNShare; to the usings at the top of the file
  5. 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.

e.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) | | 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, 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
rt React, { Component } from 'react';
rt {
pRegistry,
yleSheet,
xt,
uchableOpacity,
ew,
ipboard,
astAndroid,
ertIOS,
atform
om 'react-native';
rt Share, {ShareSheet, Button} from 'react-native-share';

s TestShare extends Component {
nstructor(props) {
super(props);
this.state = {
  visible: false
}

Cancel() {
console.log("CANCEL")
this.setState({visible:false});

Open() {
console.log("OPEN")
this.setState({visible:true});

nder() {

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



t styles = StyleSheet.create({
ntainer: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',

structions: {
marginTop: 20,
marginBottom: 20,



twitter icon
t TWITTER_ICON = "";

facebook icon
t FACEBOOK_ICON = "";

whatsapp icon
t WHATSAPP_ICON = "";

gplus icon
t GOOGLE_PLUS_ICON = "";

email icon
t EMAIL_ICON = "";

clipboard icon
t CLIPBOARD_ICON = "";

more icon
t MORE_ICON = "";


t REACT_ICON = '';

egistry.registerComponent('TestShare', () => TestShare);
Url format when sharing a file
Share base 64 file

When share a base 64 file, please follow the format below:

 "data:<data_type>/<file_extension>;base64,<base64_data>"

For example, when share a base 64 mp3 file, the url should be:

 "data:audio/mp3;base64,<base64_data>"

When share a base 64 image file with png file extension, the url should be:

 "data:image/png;base64,<base64_data>"
Share file directly

When share a local file directly, please follow the format below:

 "file://<file_path>",

For example, when share a pdf file from: /storage/emulated/0/demo/test.pdf, the url should be:

 "file:///storage/emulated/0/demo/test.pdf"

This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.