2019-03-03 14:39:57 +08:00
# `@react-native-community/cameraroll`
2019-02-24 10:52:56 +08:00
2019-03-03 14:39:57 +08:00
[![CircleCI Status ](https://img.shields.io/circleci/project/github/react-native-community/react-native-netinfo/master.svg )](https://circleci.com/gh/react-native-community/workflows/react-native-cameraroll/tree/master) ![Supports Android and iOS ](https://img.shields.io/badge/platforms-android%20|%20ios-lightgrey.svg ) ![MIT License ](https://img.shields.io/npm/l/@react-native-community/cameraroll.svg )
2019-02-24 10:52:56 +08:00
## Getting started
2019-02-24 12:59:58 +08:00
`$ npm install @react-native-community/cameraroll --save`
2019-02-24 10:52:56 +08:00
### Mostly automatic installation
2019-02-24 12:59:58 +08:00
`$ react-native link @react-native-community/cameraroll`
2019-02-24 10:52:56 +08:00
### Manual installation
#### iOS
1. In XCode, in the project navigator, right click `Libraries` ➜ `Add Files to [your project's name]`
2019-02-24 12:59:58 +08:00
2. Go to `node_modules` ➜ `@react-native-community/cameraroll` and add `RNCCameraroll.xcodeproj`
2019-02-24 10:52:56 +08:00
3. In XCode, in the project navigator, select your project. Add `libRNCCameraroll.a` to your project's `Build Phases` ➜ `Link Binary With Libraries`
4. Run your project (`Cmd+R` )<
#### Android
2019-03-25 13:21:57 -04:00
1. Open up `android/app/src/main/java/[...]/MainApplication.java`
- Add `import com.reactnativecommunity.cameraroll.CameraRollPackage;` to the imports at the top of the file
- Add `new CameraRollPackage()` to the list returned by the `getPackages()` method
2019-02-24 10:52:56 +08:00
2. Append the following lines to `android/settings.gradle` :
```
2019-03-25 13:21:57 -04:00
include ':@react -native-community_cameraroll'
project(':@react -native-community_cameraroll').projectDir = new File(rootProject.projectDir, '../node_modules/@react -native-community/cameraroll/android')
2019-02-24 10:52:56 +08:00
```
3. Insert the following lines inside the dependencies block in `android/app/build.gradle` :
```
2019-03-25 13:21:57 -04:00
compile project(':@react -native-community_cameraroll')
2019-02-24 10:52:56 +08:00
```
2019-03-03 14:39:57 +08:00
## Migrating from the core `react-native` module
This module was created when the CameraRoll was split out from the core of React Native. To migrate to this module you need to follow the installation instructions above and then change you imports from:
```javascript
import { CameraRoll } from "react-native";
```
to:
```javascript
import CameraRoll from "@react -native-community/cameraroll";
```
2019-02-24 10:52:56 +08:00
## Usage
2019-02-24 13:48:06 +08:00
`CameraRoll` provides access to the local camera roll or photo library.
### Permissions
The user's permission is required in order to access the Camera Roll on devices running iOS 10 or later. Add the `NSPhotoLibraryUsageDescription` key in your `Info.plist` with a string that describes how your app will use this data. This key will appear as `Privacy - Photo Library Usage Description` in Xcode.
If you are targeting devices running iOS 11 or later, you will also need to add the `NSPhotoLibraryAddUsageDescription` key in your `Info.plist` . Use this key to define a string that describes how your app will use this data. By adding this key to your `Info.plist` , you will be able to request write-only access permission from the user. If you try to save to the camera roll without this permission, your app will exit.
2019-03-03 21:23:25 +08:00
On Android permission is required to read the external storage. Add below line to your manifest to request this permission on app install.
```
< manifest >
...
< uses-permission android:name = "android.permission.READ_EXTERNAL_STORAGE" / >
...
< application >
```
2019-02-24 13:48:06 +08:00
### Methods
2019-03-30 23:05:55 +05:30
* [`saveToCameraRoll` ](README.md#savetocameraroll )
* [`getPhotos` ](README.md#getphotos )
2019-02-24 13:48:06 +08:00
---
# Reference
## Methods
### `saveToCameraRoll()`
2019-02-24 10:52:56 +08:00
```javascript
2019-02-24 13:48:06 +08:00
CameraRoll.saveToCameraRoll(tag, [type]);
```
Saves the photo or video to the camera roll or photo library.
On Android, the tag must be a local image or video URI, such as `"file:///sdcard/img.png"` .
On iOS, the tag can be any image URI (including local, remote asset-library and base64 data URIs) or a local video file URI (remote or data URIs are not supported for saving video at this time).
If the tag has a file extension of .mov or .mp4, it will be inferred as a video. Otherwise it will be treated as a photo. To override the automatic choice, you can pass an optional `type` parameter that must be one of 'photo' or 'video'.
2019-02-24 10:52:56 +08:00
2019-02-24 13:48:06 +08:00
Returns a Promise which will resolve with the new URI.
**Parameters:**
| Name | Type | Required | Description |
| ---- | ---------------------- | -------- | ---------------------------------------------------------- |
| tag | string | Yes | See above. |
| type | enum('photo', 'video') | No | Overrides automatic detection based on the file extension. |
---
### `getPhotos()`
```javascript
CameraRoll.getPhotos(params);
2019-02-24 10:52:56 +08:00
```
2019-02-24 13:48:06 +08:00
Returns a Promise with photo identifier objects from the local camera roll of the device matching shape defined by `getPhotosReturnChecker` .
**Parameters:**
| Name | Type | Required | Description |
| ------ | ------ | -------- | ------------------------------------------------ |
| params | object | Yes | Expects a params with the shape described below. |
2019-04-01 13:56:44 -07:00
* `first` : {number} : The number of photos wanted in reverse order of the photo application (i.e. most recent first for SavedPhotos). Required.
2019-02-24 13:48:06 +08:00
* `after` : {string} : A cursor that matches `page_info { end_cursor }` returned from a previous call to `getPhotos` .
* `groupTypes` : {string} : Specifies which group types to filter the results to. Valid values are:
* `Album`
2019-04-01 13:56:44 -07:00
* `All` // default
2019-02-24 13:48:06 +08:00
* `Event`
* `Faces`
* `Library`
* `PhotoStream`
2019-04-01 13:56:44 -07:00
* `SavedPhotos`
2019-02-24 13:48:06 +08:00
* `groupName` : {string} : Specifies filter on group names, like 'Recent Photos' or custom album titles.
* `assetType` : {string} : Specifies filter on asset type. Valid values are:
* `All`
* `Videos`
* `Photos` // default
* `mimeTypes` : {Array} : Filter by mimetype (e.g. image/jpeg).
Returns a Promise which when resolved will be of the following shape:
* `edges` : {Array< node > } An array of node objects
* `node` : {object} An object with the following shape:
* `type` : {string}
* `group_name` : {string}
* `image` : {object} : An object with the following shape:
* `uri` : {string}
* `height` : {number}
* `width` : {number}
* `isStored` : {boolean}
* `playableDuration` : {number}
* `timestamp` : {number}
* `location` : {object} : An object with the following shape:
* `latitude` : {number}
* `longitude` : {number}
* `altitude` : {number}
* `heading` : {number}
* `speed` : {number}
* `page_info` : {object} : An object with the following shape:
* `has_next_page` : {boolean}
* `start_cursor` : {string}
* `end_cursor` : {string}
#### Example
Loading images:
```javascript
_handleButtonPress = () => {
CameraRoll.getPhotos({
first: 20,
assetType: 'Photos',
})
.then(r => {
this.setState({ photos: r.edges });
})
.catch((err) => {
//Error Loading Images
});
};
render() {
return (
< View >
< Button title = "Load Images" onPress = {this._handleButtonPress} / >
< ScrollView >
{this.state.photos.map((p, i) => {
return (
< Image
key={i}
style={{
width: 300,
height: 100,
}}
source={{ uri: p.node.image.uri }}
/>
);
})}
< / ScrollView >
< / View >
);
}
2019-03-03 14:39:57 +08:00
```