2015-11-27 05:39:00 -08: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.
|
|
|
|
*
|
|
|
|
* @providesModule UIManager
|
|
|
|
* @flow
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2016-05-09 08:20:08 -07:00
|
|
|
const Platform = require('Platform');
|
|
|
|
const NativeModules = require('NativeModules');
|
|
|
|
const { UIManager } = NativeModules;
|
|
|
|
|
2016-07-05 06:34:00 -07:00
|
|
|
const findNodeHandle = require('react/lib/findNodeHandle');
|
2016-08-02 10:08:59 -07:00
|
|
|
const invariant = require('fbjs/lib/invariant');
|
2015-11-27 05:39:00 -08:00
|
|
|
|
2016-08-02 10:08:59 -07:00
|
|
|
invariant(UIManager, 'UIManager is undefined. The native module config is probably incorrect.');
|
2016-02-23 02:26:11 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Capture an image of the screen, window or an individual view. The image
|
|
|
|
* will be stored in a temporary file that will only exist for as long as the
|
|
|
|
* app is running.
|
2016-04-06 09:20:39 -07:00
|
|
|
*
|
2016-02-24 09:05:28 -08:00
|
|
|
* The `view` argument can be the literal string `window` if you want to
|
|
|
|
* capture the entire window, or it can be a reference to a specific
|
2016-02-23 02:26:11 -08:00
|
|
|
* React Native component.
|
|
|
|
*
|
|
|
|
* The `options` argument may include:
|
|
|
|
* - width/height (number) - the width and height of the image to capture.
|
|
|
|
* - format (string) - either 'png' or 'jpeg'. Defaults to 'png'.
|
|
|
|
* - quality (number) - the quality when using jpeg. 0.0 - 1.0 (default).
|
|
|
|
*
|
|
|
|
* Returns a Promise.
|
|
|
|
* @platform ios
|
|
|
|
*/
|
|
|
|
UIManager.takeSnapshot = async function(
|
2016-05-24 18:20:12 -07:00
|
|
|
view ?: 'window' | ReactElement<any> | number,
|
2016-02-23 02:26:11 -08:00
|
|
|
options ?: {
|
2016-08-02 10:08:59 -07:00
|
|
|
width ?: number,
|
|
|
|
height ?: number,
|
|
|
|
format ?: 'png' | 'jpeg',
|
|
|
|
quality ?: number,
|
2016-02-23 02:26:11 -08:00
|
|
|
},
|
|
|
|
) {
|
2016-08-02 10:08:59 -07:00
|
|
|
const _takeSnapshot = UIManager.takeSnapshot;
|
2016-02-23 02:26:11 -08:00
|
|
|
if (!_takeSnapshot) {
|
|
|
|
console.warn('UIManager.takeSnapshot is not available on this platform');
|
|
|
|
return;
|
|
|
|
}
|
2016-02-24 09:05:28 -08:00
|
|
|
if (typeof view !== 'number' && view !== 'window') {
|
|
|
|
view = findNodeHandle(view) || 'window';
|
2016-02-23 02:26:11 -08:00
|
|
|
}
|
|
|
|
return _takeSnapshot(view, options);
|
|
|
|
};
|
|
|
|
|
2016-05-09 08:20:08 -07:00
|
|
|
/**
|
|
|
|
* Copies the ViewManager constants and commands into UIManager. This is
|
|
|
|
* only needed for iOS, which puts the constants in the ViewManager
|
|
|
|
* namespace instead of UIManager, unlike Android.
|
|
|
|
*/
|
|
|
|
if (Platform.OS === 'ios') {
|
|
|
|
// Copied from NativeModules
|
|
|
|
function normalizePrefix(moduleName: string): string {
|
|
|
|
return moduleName.replace(/^(RCT|RK)/, '');
|
|
|
|
}
|
|
|
|
|
|
|
|
Object.keys(UIManager).forEach(viewName => {
|
|
|
|
const viewConfig = UIManager[viewName];
|
|
|
|
if (viewConfig.Manager) {
|
|
|
|
let constants;
|
|
|
|
/* $FlowFixMe - nice try. Flow doesn't like getters */
|
|
|
|
Object.defineProperty(viewConfig, 'Constants', {
|
|
|
|
configurable: true,
|
|
|
|
enumerable: true,
|
|
|
|
get: () => {
|
|
|
|
if (constants) {
|
|
|
|
return constants;
|
|
|
|
}
|
|
|
|
constants = {};
|
|
|
|
const viewManager = NativeModules[normalizePrefix(viewConfig.Manager)];
|
|
|
|
viewManager && Object.keys(viewManager).forEach(key => {
|
|
|
|
const value = viewManager[key];
|
|
|
|
if (typeof value !== 'function') {
|
|
|
|
constants[key] = value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return constants;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
let commands;
|
|
|
|
/* $FlowFixMe - nice try. Flow doesn't like getters */
|
|
|
|
Object.defineProperty(viewConfig, 'Commands', {
|
|
|
|
configurable: true,
|
|
|
|
enumerable: true,
|
|
|
|
get: () => {
|
|
|
|
if (commands) {
|
|
|
|
return commands;
|
|
|
|
}
|
|
|
|
commands = {};
|
|
|
|
const viewManager = NativeModules[normalizePrefix(viewConfig.Manager)];
|
|
|
|
let index = 0;
|
|
|
|
viewManager && Object.keys(viewManager).forEach(key => {
|
|
|
|
const value = viewManager[key];
|
|
|
|
if (typeof value === 'function') {
|
|
|
|
commands[key] = index++;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return commands;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-11-27 05:39:00 -08:00
|
|
|
module.exports = UIManager;
|