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>;
|
2015-03-11 02:11:28 +00:00
|
|
|
/**
|
2015-07-27 16:22:51 +00:00
|
|
|
* Saves the image to the camera roll / gallery.
|
|
|
|
*
|
2016-01-31 01:10:14 +00:00
|
|
|
* On Android, the tag is a local URI, such as `"file:///sdcard/img.png"`.
|
2015-07-27 16:22:51 +00:00
|
|
|
*
|
|
|
|
* On iOS, the tag can be one of the following:
|
|
|
|
*
|
|
|
|
* - local URI
|
|
|
|
* - assets-library tag
|
2015-12-15 17:08:39 +00:00
|
|
|
* - a tag not matching any of the above, which means the image data will
|
2015-07-27 16:22:51 +00:00
|
|
|
* be stored in memory (and consume memory as long as the process is alive)
|
2015-03-11 02:11:28 +00:00
|
|
|
*
|
2016-01-31 01:10:14 +00:00
|
|
|
* Returns a Promise which when resolved will be passed the new URI.
|
2015-03-11 02:11:28 +00:00
|
|
|
*/
|
2016-01-21 16:07:01 +00:00
|
|
|
static saveImageWithTag(tag) {
|
2015-03-11 02:11:28 +00:00
|
|
|
invariant(
|
|
|
|
typeof tag === 'string',
|
|
|
|
'CameraRoll.saveImageWithTag tag must be a valid string.'
|
|
|
|
);
|
2016-01-21 16:07:01 +00:00
|
|
|
if (arguments.length > 1) {
|
|
|
|
console.warn("CameraRoll.saveImageWithTag(tag, success, error) is deprecated. Use the returned Promise instead");
|
|
|
|
let successCallback = arguments[1];
|
|
|
|
let errorCallback = arguments[2] || ( () => {} );
|
|
|
|
RCTCameraRollManager.saveImageWithTag(tag).then(successCallback, errorCallback);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
return RCTCameraRollManager.saveImageWithTag(tag);
|
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) {
|
|
|
|
console.warn("CameraRoll.getPhotos(tag, success, error) is deprecated. Use the returned Promise instead");
|
|
|
|
let successCallback = arguments[1];
|
|
|
|
if (__DEV__) {
|
|
|
|
let callback = arguments[1];
|
|
|
|
successCallback = (response) => {
|
|
|
|
getPhotosReturnChecker(
|
|
|
|
{response},
|
|
|
|
'response',
|
|
|
|
'CameraRoll.getPhotos callback'
|
|
|
|
);
|
|
|
|
callback(response);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
let errorCallback = arguments[2] || ( () => {} );
|
|
|
|
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;
|