mirror of
https://github.com/status-im/react-native.git
synced 2025-01-15 12:05:06 +00:00
f7cf017d29
- [ReactNative] Remove pushNotification prop from renderApplication | Eric Vicenti - [react_native] Stub VibrationIOS on Android | Andy Street - [ReactNative] Simplify and test interpolators | Christopher Chedeau - [ReactNative] Increase timeout for obj-c tests | Christopher Chedeau - [ReactNative] Updated RKText to new UIManager system | Nick Lockwood - [ReactNative] Unforked RCTShadowView, moved RKTextView into FBReactKitTextModule | Nick Lockwood - [ReactKit] Remove NativeModulesDeprecated | Spencer Ahrens - [ReactNative] Allow single callbacks in NativeModules | Spencer Ahrens - [ReactNative] s/RK/RCT in OSS | Spencer Ahrens - [ReactNative] Cleanup StyleSheet API | Christopher Chedeau - [RCTVibration] Basic Vibration API | Christopher Chedeau - [React Native] Prevent crash in redbox code with two thrown errors | Ben Alpert - [ReactNative] unbreak Android | Andrew Rasmussen
45 lines
1.3 KiB
JavaScript
45 lines
1.3 KiB
JavaScript
/**
|
|
* Copyright 2004-present Facebook. All Rights Reserved.
|
|
*
|
|
* @providesModule Dimensions
|
|
*/
|
|
'use strict';
|
|
|
|
var NativeModules = require('NativeModules');
|
|
|
|
var invariant = require('invariant');
|
|
|
|
var dimensions = NativeModules.RCTUIManager.Dimensions;
|
|
|
|
class Dimensions {
|
|
/**
|
|
* This should only be called from native code.
|
|
*
|
|
* @param {object} dims Simple string-keyed object of dimensions to set
|
|
*/
|
|
static set(dims) {
|
|
Object.assign(dimensions, dims);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Initial dimensions are set before `runApplication` is called so they should
|
|
* be available before any other require's are run, but may be updated later.
|
|
*
|
|
* Note: Although dimensions are available immediately, they may change (e.g
|
|
* due to device rotation) so any rendering logic or styles that depend on
|
|
* these constants should try to call this function on every render, rather
|
|
* than caching the value (for example, using inline styles rather than
|
|
* setting a value in a `StyleSheet`).
|
|
*
|
|
* @param {string} dim Name of dimension as defined when calling `set`.
|
|
* @returns {Object?} Value for the dimension.
|
|
*/
|
|
static get(dim) {
|
|
invariant(dimensions[dim], 'No dimension set for key ' + dim);
|
|
return dimensions[dim];
|
|
}
|
|
}
|
|
|
|
module.exports = Dimensions;
|