Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

react-native-share

Package Overview
Dependencies
Maintainers
5
Versions
157
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-native-share - npm Package Compare versions

Comparing version 1.2.1 to 2.0.0

android/src/main/java/cl/json/social/LinkedinShare.java

5

changelog.js
#!/usr/bin/env node
const git = require('simple-git');
const changelog = require('generate-changelog');
const generate_changelog = require('generate-changelog');
const fs = require('fs');

@@ -9,2 +9,3 @@ const idx = require('idx');

// eslint-disable-next-line handle-callback-err
git().tags((err, tags) => {

@@ -15,3 +16,3 @@ const currentChangelog = fs.readFileSync('./CHANGELOG.md');

changelog
generate_changelog
.generate({

@@ -18,0 +19,0 @@ major: argv.major,

37

index.js

@@ -19,2 +19,3 @@ /*

} from 'react-native';
import type { ViewStyleProp } from 'react-native/Libraries/StyleSheet/StyleSheet';

@@ -45,7 +46,7 @@ import Overlay from './components/Overlay';

children: React.Node,
style?: {},
overlayStyle?: {},
style?: ViewStyleProp,
overlayStyle?: ViewStyleProp,
};
const shareSheetStyle = {flex: 1};
const shareSheetStyle = { flex: 1 };

@@ -72,14 +73,9 @@ class ShareSheet extends React.Component<Props> {

render() {
const {style = {}, overlayStyle = {}, ...props} = this.props;
const { style = {}, overlayStyle = {}, ...props } = this.props;
return (
<Overlay visible={this.props.visible} {...props}>
<View style={[styles.actionSheetContainer, overlayStyle]}>
<TouchableOpacity
style={shareSheetStyle}
onPress={this.props.onCancel}
/>
<TouchableOpacity style={shareSheetStyle} onPress={this.props.onCancel} />
<Sheet visible={this.props.visible}>
<View style={[styles.buttonContainer, style]}>
{this.props.children}
</View>
<View style={[styles.buttonContainer, style]}>{this.props.children}</View>
</Sheet>

@@ -115,8 +111,6 @@ </View>

type OpenReturn = {app?: string, dismissedAction?: boolean};
type ShareSingleReturn = {message: string};
type OpenReturn = { app?: string, dismissedAction?: boolean };
type ShareSingleReturn = { message: string, isInstalled?: boolean };
const requireAndAskPermissions = async (
options: Options | MultipleOptions,
): Promise<any> => {
const requireAndAskPermissions = async (options: Options | MultipleOptions): Promise<any> => {
if ((options.url || options.urls) && Platform.OS === 'android') {

@@ -168,3 +162,3 @@ const urls: Array<string> = options.urls || [options.url];

static Button: any;
static ShareSheet: React.Element<*>;
static ShareSheet: RNShare.ShareSheet;
static Overlay: any;

@@ -181,2 +175,3 @@ static Sheet: any;

PINTEREST: NativeModules.RNShare.PINTEREST || 'pinterest',
LINKEDIN: NativeModules.RNShare.LINKEDIN || 'linkedin',
};

@@ -193,3 +188,3 @@

error => {
return reject({error: error});
return reject({ error: error });
},

@@ -214,3 +209,3 @@ (success, activityType) => {

e => {
return reject({error: e});
return reject({ error: e });
},

@@ -246,3 +241,3 @@ (success, activityType) => {

e => {
return reject({error: e});
return reject({ error: e });
},

@@ -270,3 +265,3 @@ (e, activityType) => {

e => {
return reject({error: e});
return reject({ error: e });
},

@@ -273,0 +268,0 @@ isInstalled => {

{
"name": "react-native-share",
"description": "Social share, sending simple data to other apps.",
"version": "1.2.1",
"version": "2.0.0",
"repository": {

@@ -10,23 +10,23 @@ "type": "git",

"devDependencies": {
"@commitlint/cli": "6.2.0",
"@commitlint/config-conventional": "6.1.3",
"@react-native-community/eslint-config": "0.0.4",
"babel-eslint": "8.2.6",
"eslint": "4.19.1",
"eslint-plugin-flowtype": "2.50.3",
"@commitlint/cli": "8.0.0",
"@commitlint/config-conventional": "8.0.0",
"@react-native-community/eslint-config": "0.0.5",
"babel-eslint": "10.0.1",
"eslint": "5.16.0",
"eslint-plugin-flowtype": "3.10.3",
"eslint-plugin-import": "2.17.3",
"eslint-plugin-prettier": "2.6.2",
"eslint-plugin-prettier": "3.1.0",
"eslint-plugin-react": "7.13.0",
"eslint-plugin-react-native": "3.7.0",
"flow-bin": "0.92.0",
"flow-bin": "^0.101",
"generate-changelog": "1.7.1",
"husky": "0.14.3",
"husky": "2.4.1",
"idx": "2.5.6",
"lint-staged": "7.3.0",
"lint-staged": "8.2.0",
"minimist": "1.2.0",
"pre-commit": "1.2.2",
"prettier": "1.17.1",
"prettier": "^1.18.2",
"react": "16.8.3",
"react-native": "0.59.5",
"simple-git": "1.89.0"
"react-native": "0.60.3",
"simple-git": "1.113.0"
},

@@ -51,4 +51,3 @@ "keywords": [

"*.js": [
"yarn prettier",
"eslint --fix",
"yarn validate",
"git add"

@@ -61,10 +60,14 @@ ]

"commitmsg": "commitlint -e $GIT_PARAMS",
"dev-sync": "echo 'This is not needed anymore, the example is always synced'; exit 1",
"lint": "eslint index.js --max-warnings=0",
"lint:staged": "lint-staged",
"prettier": "prettier --write --single-quote true --trailing-comma all --print-width 100",
"release:major": "node ./changelog --major && npm version major && git push origin && git push origin --follow-tags",
"release:minor": "node ./changelog --minor && npm version minor && git push origin && git push origin --follow-tags",
"release:patch": "node ./changelog --patch && npm version patch && git push origin && git push origin --follow-tags",
"release:version": "node ./changelog --version $VERSION && git push origin && git push origin --follow-tags"
"release:version": "node ./changelog --version $VERSION && git push origin && git push origin --follow-tags",
"validate": "yarn validate:prettier && yarn validate:lint && yarn validate:flow",
"validate:flow": "yarn flow",
"validate:lint": "eslint *js components/*.js --max-warnings=0",
"validate:prettier": "prettier --write *.js components/*.js"
}
}
# react-native-share [![CircleCI](https://circleci.com/gh/react-native-community/react-native-share/tree/master.svg?style=svg&circle-token=0c6860240abba4e16bd07df0ea805a72b67b8d41)](https://circleci.com/gh/react-native-community/react-native-share/tree/master) [![npm version](https://badge.fury.io/js/react-native-share.svg)](http://badge.fury.io/js/react-native-share)
Share Social , Sending Simple Data to Other Apps
React Native Share, a simple tool for share message and file to other apps.
***NOTE: React Native now implements share functionality [Read more](https://facebook.github.io/react-native/docs/share.html)***
## Sponsors
# Sponsors
---
If you use this library on your commercial/personal projects, you can help us by funding the work on specific issues that you choose by using IssueHunt.io!

@@ -13,30 +12,61 @@

## Getting started
### Mostly automatic install
1. `yarn add react-native-share`
2. `react-native link react-native-share`
# Getting started
---
#### How to use master branch?
### If you are using `react-native` >= 0.60.0 please use `react-native-share` >= 2.0.0
We recommend using the releases from npm, however you can use the master branch if you need any feature that is not available on NPM. By doing this you will be able to use unreleased features, but the module may be less stable.
## Automatic Way
---
```
yarn add react-native-share
```
**yarn**: `yarn add react-native-share@git+https://git@github.com/react-native-community/react-native-share.git`
or if you're using npm
```
npm install react-native-share --save
```
---
**npm**: `npm install --save react-native-share@git+https://git@github.com/react-native-community/react-native-share.git`
#### Important:
Linking is not needed anymore. ``react-native@0.60.0+`` supports dependencies auto linking.
For iOS you also need additional step to install auto linked Pods (Cocoapods should be installed):
```
cd ios && pod install && cd ../
```
___
### Manual install
### If you are using `react-native` <= 0.59.10 please use `react-native-share` <= 1.2.1:
If you are having any problems with this library, or need to use >= 2.0.0 please refer to: [jetifier](https://github.com/mikehardy/jetifier#to-reverse-jetify--convert-node_modules-dependencies-to-support-libraries).
`npm install react-native-share --save`
After installing jetifier, runs a ```npx jetify -r``` and test if this works by running a ```react-native run-android```.
## Automatic Way
- [iOS](https://github.com/react-native-community/react-native-share#iOS-Install)
---
```
yarn add react-native-share
react-native link react-native-share
```
- [Android](https://github.com/react-native-community/react-native-share#Android-Install)
or if you're using npm
```
npm install react-native-share --save
react-native link react-native-share
```
---
- [Windows](https://github.com/react-native-community/react-native-share#Windows-Install)
We recommend using the releases from npm, however you can use the master branch if you need any feature that is not available on NPM. By doing this you will be able to use unreleased features, but the module may be less stable.
**yarn**:
```
yarn add react-native-share@git+https://git@github.com/react-native-community/react-native-share.git
```
#### iOS Install
1. `npm install react-native-share --save`
## Manual install
### iOS Install
1. `yarn add react-native-share`
2. In XCode, in the project navigator, right click `Libraries` ➜ `Add Files to [your project's name]`

@@ -62,4 +92,5 @@ 3. Go to `node_modules` ➜ `react-native-share` ➜ `ios` and add `RNShare.xcodeproj`

#### iOS Install(using Pods)
### iOS Install(using Pods)
If you wish, you can use [cocopoads](https://cocoapods.org/) to use react-native-share.

@@ -82,5 +113,7 @@

#### Android Install
1. `npm install react-native-share --save`
### Android Install
1. `yarn add react-native-share`
2. Open up `android/app/src/main/java/[...]/MainApplication.java`

@@ -103,7 +136,8 @@ - Add `import cl.json.RNSharePackage;` and `import cl.json.ShareApplication;` to the imports at the top of the file

#### Windows Install
### Windows Install
[Read it! :D](https://github.com/ReactWindows/react-native)
1. `npm install react-native-share --save`
1. `yarn add react-native-share`
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.

@@ -115,6 +149,8 @@ 2. Open up your `MainPage.cs` app

### Methods
#### open(options)
# Methods
---
### open(options)
Open Simple share dialog

@@ -124,2 +160,6 @@

*For share multiple files, you must using option urls instead of url to share multiple files/images/docs.
Example could be found in Example folder
```jsx

@@ -135,4 +175,4 @@ Share.open(options)

| :---- | :------: | :--- |
| 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 ) |
| url | string | URL you want to share (only support base64 string in iOS & Android ). |
| urls | Array[string] | array of base64 string you want to share (only support iOS & Android). |
| type | string | File mime type (optional) |

@@ -146,4 +186,21 @@ | message | string | |

#### shareSingle(options) (in iOS & Android)
#### 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>"
```
***Share file directly
When share a local file directly, please follow the format below:
```
url: "file://<file_path>",
```
---
### shareSingle(options) (in iOS & Android)
Open share dialog with specific application

@@ -165,5 +222,6 @@

***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***
***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***
#### isPackageInstalled (in Android)
---
### isPackageInstalled(<app>) (in Android)
It's a method that checks if an app (package) is installed on Android.

@@ -180,5 +238,5 @@ It returns a promise with `isInstalled`. e.g.

---
## Static Values for social
### Static Values for social
These can be assessed using Share.Social property

@@ -210,4 +268,5 @@ For eg.

| **MESSENGER** | yes | no | no |
| **LINKEDIN** | yes | no | no |
## How it looks:
#### How it looks:

@@ -219,240 +278,5 @@ | | Android | IOS | Windows |

## Usage
### Example code
```javascript
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: PINTEREST_ICON }}
onPress={()=>{
this.onCancel();
setTimeout(() => {
Share.shareSingle(Object.assign(shareOptions, {
"social": "pinterest"
}));
},300);
}}>Pinterest</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 = "";
// pinterest icon
const PINTEREST_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"
```
### Troubleshooting
---
# Troubleshooting
---
#### Share Remote PDF File with Gmail & WhatsApp (iOS)

@@ -541,3 +365,3 @@

<provider
android:name="android.support.v4.content.FileProvider"
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.provider"

@@ -544,0 +368,0 @@ android:grantUriPermissions="true"

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc