2015-03-11 02:11:28 +00:00
|
|
|
/**
|
2015-03-23 22:07:33 +00:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
2015-03-11 02:11:28 +00:00
|
|
|
*
|
|
|
|
* @providesModule CameraRoll
|
2015-03-25 22:36:50 +00:00
|
|
|
* @flow
|
2015-03-11 02:11:28 +00:00
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var ReactPropTypes = require('ReactPropTypes');
|
2015-03-18 22:57:49 +00:00
|
|
|
var RCTCameraRollManager = require('NativeModules').CameraRollManager;
|
2015-03-11 02:11:28 +00:00
|
|
|
|
|
|
|
var createStrictShapeTypeChecker = require('createStrictShapeTypeChecker');
|
|
|
|
var deepFreezeAndThrowOnMutationInDev =
|
|
|
|
require('deepFreezeAndThrowOnMutationInDev');
|
2016-03-02 12:27:13 +00:00
|
|
|
var invariant = require('fbjs/lib/invariant');
|
2015-03-11 02:11:28 +00:00
|
|
|
|
|
|
|
var GROUP_TYPES_OPTIONS = [
|
|
|
|
'Album',
|
|
|
|
'All',
|
|
|
|
'Event',
|
|
|
|
'Faces',
|
|
|
|
'Library',
|
|
|
|
'PhotoStream',
|
|
|
|
'SavedPhotos', // default
|
|
|
|
];
|
|
|
|
|
2015-06-01 22:46:06 +00:00
|
|
|
var ASSET_TYPE_OPTIONS = [
|
|
|
|
'All',
|
|
|
|
'Videos',
|
|
|
|
'Photos', // default
|
|
|
|
];
|
|
|
|
|
2015-03-25 22:36:50 +00:00
|
|
|
// Flow treats Object and Array as disjoint types, currently.
|
|
|
|
deepFreezeAndThrowOnMutationInDev((GROUP_TYPES_OPTIONS: any));
|
2015-06-01 22:46:06 +00:00
|
|
|
deepFreezeAndThrowOnMutationInDev((ASSET_TYPE_OPTIONS: any));
|
2015-03-11 02:11:28 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Shape of the param arg for the `getPhotos` function.
|
|
|
|
*/
|
|
|
|
var getPhotosParamChecker = createStrictShapeTypeChecker({
|
|
|
|
/**
|
|
|
|
* The number of photos wanted in reverse order of the photo application
|
|
|
|
* (i.e. most recent first for SavedPhotos).
|
|
|
|
*/
|
|
|
|
first: ReactPropTypes.number.isRequired,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A cursor that matches `page_info { end_cursor }` returned from a previous
|
|
|
|
* call to `getPhotos`
|
|
|
|
*/
|
|
|
|
after: ReactPropTypes.string,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specifies which group types to filter the results to.
|
|
|
|
*/
|
|
|
|
groupTypes: ReactPropTypes.oneOf(GROUP_TYPES_OPTIONS),
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specifies filter on group names, like 'Recent Photos' or custom album
|
|
|
|
* titles.
|
|
|
|
*/
|
|
|
|
groupName: ReactPropTypes.string,
|
2015-06-01 22:46:06 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Specifies filter on asset type
|
|
|
|
*/
|
|
|
|
assetType: ReactPropTypes.oneOf(ASSET_TYPE_OPTIONS),
|
2015-06-17 19:21:07 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filter by mimetype (e.g. image/jpeg).
|
|
|
|
*/
|
|
|
|
mimeTypes: ReactPropTypes.arrayOf(ReactPropTypes.string),
|
2015-03-11 02:11:28 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shape of the return value of the `getPhotos` function.
|
|
|
|
*/
|
|
|
|
var getPhotosReturnChecker = createStrictShapeTypeChecker({
|
|
|
|
edges: ReactPropTypes.arrayOf(createStrictShapeTypeChecker({
|
|
|
|
node: createStrictShapeTypeChecker({
|
|
|
|
type: ReactPropTypes.string.isRequired,
|
|
|
|
group_name: ReactPropTypes.string.isRequired,
|
|
|
|
image: createStrictShapeTypeChecker({
|
|
|
|
uri: ReactPropTypes.string.isRequired,
|
|
|
|
height: ReactPropTypes.number.isRequired,
|
|
|
|
width: ReactPropTypes.number.isRequired,
|
|
|
|
isStored: ReactPropTypes.bool,
|
|
|
|
}).isRequired,
|
|
|
|
timestamp: ReactPropTypes.number.isRequired,
|
|
|
|
location: createStrictShapeTypeChecker({
|
|
|
|
latitude: ReactPropTypes.number,
|
|
|
|
longitude: ReactPropTypes.number,
|
|
|
|
altitude: ReactPropTypes.number,
|
|
|
|
heading: ReactPropTypes.number,
|
|
|
|
speed: ReactPropTypes.number,
|
|
|
|
}),
|
|
|
|
}).isRequired,
|
|
|
|
})).isRequired,
|
|
|
|
page_info: createStrictShapeTypeChecker({
|
|
|
|
has_next_page: ReactPropTypes.bool.isRequired,
|
|
|
|
start_cursor: ReactPropTypes.string,
|
|
|
|
end_cursor: ReactPropTypes.string,
|
|
|
|
}).isRequired,
|
|
|
|
});
|
|
|
|
|
2015-07-27 16:22:51 +00:00
|
|
|
/**
|
|
|
|
* `CameraRoll` provides access to the local camera roll / gallery.
|
|
|
|
*/
|
2015-03-11 02:11:28 +00:00
|
|
|
class CameraRoll {
|
2015-05-12 21:22:22 +00:00
|
|
|
|
|
|
|
static GroupTypesOptions: Array<string>;
|
2015-06-01 22:46:06 +00:00
|
|
|
static AssetTypeOptions: Array<string>;
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
|
2016-06-08 10:58:57 +00:00
|
|
|
static saveImageWithTag(tag: string): Promise<Object> {
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
console.warn('CameraRoll.saveImageWithTag is deprecated. Use CameraRoll.saveToCameraRoll instead');
|
|
|
|
return this.saveToCameraRoll(tag, 'photo');
|
|
|
|
}
|
|
|
|
|
2015-03-11 02:11:28 +00:00
|
|
|
/**
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
* Saves the photo or video to the camera roll / gallery.
|
2015-07-27 16:22:51 +00:00
|
|
|
*
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
* On Android, the tag must be a local image or video URI, such as `"file:///sdcard/img.png"`.
|
2015-07-27 16:22:51 +00:00
|
|
|
*
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
* 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).
|
2015-07-27 16:22:51 +00:00
|
|
|
*
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
* 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'.
|
2015-03-11 02:11:28 +00:00
|
|
|
*
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
* Returns a Promise which will resolve with the new URI.
|
2015-03-11 02:11:28 +00:00
|
|
|
*/
|
2016-06-08 10:58:57 +00:00
|
|
|
static saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<Object> {
|
2015-03-11 02:11:28 +00:00
|
|
|
invariant(
|
|
|
|
typeof tag === 'string',
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
'CameraRoll.saveToCameraRoll must be a valid string.'
|
|
|
|
);
|
|
|
|
|
|
|
|
invariant(
|
|
|
|
type === 'photo' || type === 'video' || type === undefined,
|
|
|
|
`The second argument to saveToCameraRoll must be 'photo' or 'video'. You passed ${type}`
|
2015-03-11 02:11:28 +00:00
|
|
|
);
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
|
|
|
|
let mediaType = 'photo';
|
|
|
|
if (type) {
|
|
|
|
mediaType = type;
|
|
|
|
} else if (['mov', 'mp4'].indexOf(tag.split('.').slice(-1)[0]) >= 0) {
|
|
|
|
mediaType = 'video';
|
2016-01-21 16:07:01 +00:00
|
|
|
}
|
Allow CameraRoll to export videos
Summary:
This PR adds the ability to export videos to the CameraRoll on both Android and iOS (previously only photos were possible, at least on iOS). The API has changed as follows:
```
// old
saveImageWithTag(tag: string): Promise<string>
// new
saveToCameraRoll(tag: string, type?: 'photo' | 'video'): Promise<string>
```
if no `type` parameter is passed, `video` is inferred if the tag ends with ".mov" or ".mp4", otherwise `photo` is assumed.
I've left in the `saveImageWithTag` method for now with a deprecation warning.
**Test plan (required)**
I created the following very simple app to test exporting photos and videos to the CameraRoll, and ran it on both iOS and Android. The functionality works as intended on both platforms.
```js
// index.js
/**
* Sample React Native App
* https://github.com/facebook/react-native
* flow
*/
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
CameraRoll,
} from 'react-native';
import FS fro
Closes https://github.com/facebook/react-native/pull/7988
Differential Revision: D3401251
Pulled By: nicklockwood
fbshipit-source-id: af3fc24e6fa5b84ac377e9173f3709c6f9795f20
2016-06-07 23:37:48 +00:00
|
|
|
|
|
|
|
return RCTCameraRollManager.saveToCameraRoll(tag, mediaType);
|
2015-03-11 02:11:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-01-31 01:10:14 +00:00
|
|
|
* Returns a Promise with photo identifier objects from the local camera
|
|
|
|
* roll of the device matching shape defined by `getPhotosReturnChecker`.
|
2016-01-21 16:07:01 +00:00
|
|
|
*
|
2016-01-31 01:10:14 +00:00
|
|
|
* @param {object} params See `getPhotosParamChecker`.
|
2016-01-21 16:07:01 +00:00
|
|
|
*
|
2016-01-31 01:10:14 +00:00
|
|
|
* Returns a Promise which when resolved will be of shape `getPhotosReturnChecker`.
|
2015-03-11 02:11:28 +00:00
|
|
|
*/
|
2016-01-21 16:07:01 +00:00
|
|
|
static getPhotos(params) {
|
2015-03-11 02:11:28 +00:00
|
|
|
if (__DEV__) {
|
|
|
|
getPhotosParamChecker({params}, 'params', 'CameraRoll.getPhotos');
|
|
|
|
}
|
2016-01-21 16:07:01 +00:00
|
|
|
if (arguments.length > 1) {
|
2016-03-18 17:20:07 +00:00
|
|
|
console.warn('CameraRoll.getPhotos(tag, success, error) is deprecated. Use the returned Promise instead');
|
2016-01-21 16:07:01 +00:00
|
|
|
let successCallback = arguments[1];
|
|
|
|
if (__DEV__) {
|
2016-03-18 17:20:07 +00:00
|
|
|
const callback = arguments[1];
|
2016-01-21 16:07:01 +00:00
|
|
|
successCallback = (response) => {
|
|
|
|
getPhotosReturnChecker(
|
|
|
|
{response},
|
|
|
|
'response',
|
|
|
|
'CameraRoll.getPhotos callback'
|
|
|
|
);
|
|
|
|
callback(response);
|
|
|
|
};
|
|
|
|
}
|
2016-03-18 17:20:07 +00:00
|
|
|
const errorCallback = arguments[2] || ( () => {} );
|
2016-01-21 16:07:01 +00:00
|
|
|
RCTCameraRollManager.getPhotos(params).then(successCallback, errorCallback);
|
2015-03-11 02:11:28 +00:00
|
|
|
}
|
2016-01-21 16:07:01 +00:00
|
|
|
// TODO: Add the __DEV__ check back in to verify the Promise result
|
|
|
|
return RCTCameraRollManager.getPhotos(params);
|
2015-03-11 02:11:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
CameraRoll.GroupTypesOptions = GROUP_TYPES_OPTIONS;
|
2015-06-01 22:46:06 +00:00
|
|
|
CameraRoll.AssetTypeOptions = ASSET_TYPE_OPTIONS;
|
2015-03-11 02:11:28 +00:00
|
|
|
|
|
|
|
module.exports = CameraRoll;
|