mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
4b4455f827
Summary:Unfortunately the 'screen' option in the `UIManager.takeSnapshot` API appears to work only on the iOS simulator, not on an actual device. This diff removes the 'screen' option until a solution can be found that works on the device. (Taking a snapshot of the window still works fine - it just won't include the status bar, etc.) Reviewed By: javache Differential Revision: D2971091 fb-gh-sync-id: 026b9d4eb2f59f686f58c18a16381ff325df612b shipit-source-id: 026b9d4eb2f59f686f58c18a16381ff325df612b
85 lines
2.4 KiB
JavaScript
85 lines
2.4 KiB
JavaScript
/**
|
|
* 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';
|
|
|
|
var UIManager = require('NativeModules').UIManager;
|
|
var findNodeHandle = require('findNodeHandle');
|
|
|
|
if (!UIManager.setChildren) {
|
|
|
|
/**
|
|
* Index cache (used by setChildren())
|
|
*/
|
|
UIManager._cachedIndexArray = function(size) {
|
|
var cachedResult = this._cachedIndexArray._cache[size];
|
|
if (!cachedResult) {
|
|
var arr = [];
|
|
for (var i = 0; i < size; i++) {
|
|
arr[i] = i;
|
|
}
|
|
this._cachedIndexArray._cache[size] = arr;
|
|
return arr;
|
|
} else {
|
|
return cachedResult;
|
|
}
|
|
};
|
|
UIManager._cachedIndexArray._cache = {};
|
|
|
|
/**
|
|
* Fallback setChildren() implementation for Android
|
|
*/
|
|
UIManager.setChildren = function(containerTag, createdTags) {
|
|
var indexes = this._cachedIndexArray(createdTags.length);
|
|
UIManager.manageChildren(containerTag, null, null, createdTags, indexes, null);
|
|
};
|
|
}
|
|
|
|
const _takeSnapshot = UIManager.takeSnapshot;
|
|
|
|
/**
|
|
* 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.
|
|
*
|
|
* 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
|
|
* 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(
|
|
view ?: 'window' | ReactElement | number,
|
|
options ?: {
|
|
width ?: number;
|
|
height ?: number;
|
|
format ?: 'png' | 'jpeg';
|
|
quality ?: number;
|
|
},
|
|
) {
|
|
if (!_takeSnapshot) {
|
|
console.warn('UIManager.takeSnapshot is not available on this platform');
|
|
return;
|
|
}
|
|
if (typeof view !== 'number' && view !== 'window') {
|
|
view = findNodeHandle(view) || 'window';
|
|
}
|
|
return _takeSnapshot(view, options);
|
|
};
|
|
|
|
module.exports = UIManager;
|